:root{
  --bg:#0a0c0e;--bg-2:#101418;--panel:#13181d;--ink:#e8e6df;--ink-dim:#9aa0a3;
  --line:#2a3036;--accent:#c6553c;--accent-2:#3f6b6f;--signal:#d4b352;--ok:#4f9d6b;
  --mono:'JetBrains Mono',monospace;--display:'Oswald',sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
body{background:var(--bg);color:var(--ink);font-family:var(--mono);font-size:14px;-webkit-font-smoothing:antialiased}
a{color:var(--accent);text-decoration:none}

/* topbar */
.adm-top{background:#06080a;border-bottom:1px solid var(--line);padding:14px 24px;display:flex;align-items:center;gap:16px;position:sticky;top:0;z-index:50}
.adm-top .brand{display:flex;align-items:center;gap:12px;color:var(--ink)}
.adm-top .crest{width:34px;height:34px;border:1.5px solid var(--accent);border-radius:50%;display:grid;place-items:center}
.adm-top .crest svg{width:19px;height:19px}
.adm-top b{font-family:var(--display);font-size:18px;letter-spacing:.18em}
.adm-top .right{margin-left:auto;display:flex;gap:18px;align-items:center}
.adm-top .right a{color:var(--ink-dim);letter-spacing:.08em;text-transform:uppercase;font-size:12px}
.adm-top .right a:hover{color:var(--ink)}

.adm-wrap{max-width:1100px;margin:0 auto;padding:40px 24px 80px}
.page-head{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:30px;flex-wrap:wrap}
h1.page-title{font-family:var(--display);font-weight:600;text-transform:uppercase;letter-spacing:.06em;font-size:30px}

.btn-primary{background:var(--accent);color:#fff;border:none;font-family:var(--display);font-weight:600;letter-spacing:.12em;text-transform:uppercase;font-size:13px;padding:13px 22px;cursor:pointer;transition:.2s;display:inline-block}
.btn-primary:hover{background:#a8442e}
.btn-ghost{background:none;border:1px solid var(--line);color:var(--ink);font-family:var(--mono);font-size:12px;letter-spacing:.08em;padding:9px 14px;cursor:pointer;transition:.2s;text-transform:uppercase}
.btn-ghost:hover{border-color:var(--accent);color:#fff}
.btn-danger{border-color:#7a2a22;color:#d98b80}
.btn-danger:hover{border-color:var(--accent);background:rgba(198,85,60,.12)}

.alert{padding:12px 16px;border:1px solid var(--line);margin-bottom:20px;font-size:13px;letter-spacing:.04em}
.alert.ok{border-color:var(--ok);color:#8fd0a6;background:rgba(79,157,107,.08)}
.alert.err{border-color:var(--accent);color:#e3a397;background:rgba(198,85,60,.08)}

/* tabla de artículos */
.tbl{width:100%;border-collapse:collapse;border:1px solid var(--line)}
.tbl th{background:#0c1014;text-align:left;padding:13px 14px;font-family:var(--display);text-transform:uppercase;letter-spacing:.1em;font-size:12px;color:var(--ink-dim);border-bottom:1px solid var(--line)}
.tbl td{padding:13px 14px;border-bottom:1px solid rgba(42,48,54,.5);vertical-align:middle}
.tbl tr:hover td{background:rgba(63,107,111,.06)}
.tbl .t-title{color:var(--ink);font-family:var(--display);letter-spacing:.02em;font-size:15px}
.tbl .acts{display:flex;gap:8px;flex-wrap:wrap}
.tbl .acts a,.tbl .acts button{font-size:11px;padding:7px 11px}

.badge{display:inline-block;padding:3px 9px;font-size:10px;letter-spacing:.12em;text-transform:uppercase;border:1px solid var(--line)}
.badge.publicado{color:var(--ok);border-color:var(--ok)}
.badge.archivado{color:var(--signal);border-color:var(--signal)}
.badge.borrador{color:var(--ink-dim)}

.empty{border:1px dashed var(--line);padding:50px;text-align:center;color:var(--ink-dim);letter-spacing:.08em}

/* formulario */
.form{background:var(--panel);border:1px solid var(--line);padding:32px}
.form .row{margin-bottom:22px}
.form .two{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.form label{display:block;font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-dim);margin-bottom:8px}
.form input[type=text],.form select,.form textarea{
  width:100%;background:var(--bg-2);border:1px solid var(--line);color:var(--ink);
  font-family:var(--mono);font-size:14px;padding:12px 14px;outline:none;transition:.2s}
.form textarea{min-height:280px;line-height:1.6;resize:vertical;font-family:var(--mono)}
.form input:focus,.form select:focus,.form textarea:focus{border-color:var(--accent)}
.form .hint{font-size:11px;color:var(--ink-dim);margin-top:6px;letter-spacing:.03em}
.form .actions{display:flex;gap:12px;align-items:center;margin-top:10px}
.thumb-prev{width:120px;height:72px;object-fit:cover;border:1px solid var(--line);margin-top:10px;display:block}

/* login */
.login-body{min-height:100vh;display:grid;place-items:center;
  background:radial-gradient(ellipse at 50% 0%,rgba(63,107,111,.18),transparent 60%),#0a0c0e}
.login-card{background:var(--panel);border:1px solid var(--line);padding:42px 38px;width:340px;text-align:center}
.login-crest{width:54px;height:54px;border:1.5px solid var(--accent);border-radius:50%;display:grid;place-items:center;margin:0 auto 18px}
.login-crest svg{width:30px;height:30px}
.login-card h1{font-family:var(--display);font-weight:700;letter-spacing:.2em;font-size:24px}
.login-card .sub{color:var(--ink-dim);font-size:12px;letter-spacing:.14em;text-transform:uppercase;margin-bottom:24px}
.login-card label{display:block;text-align:left;font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-dim);margin:14px 0 7px}
.login-card input{width:100%;background:var(--bg-2);border:1px solid var(--line);color:var(--ink);font-family:var(--mono);padding:12px 14px;outline:none}
.login-card input:focus{border-color:var(--accent)}
.login-card .btn-primary{width:100%;margin-top:24px}

@media(max-width:640px){.form .two{grid-template-columns:1fr}.tbl thead{display:none}.tbl td{display:block;border:none}.tbl tr{display:block;border-bottom:1px solid var(--line);padding:8px 0}}
