:root{
  --bg:#f6f7f9; --surface:#fff; --surface-2:#f0f2f5; --ink:#171a1f; --muted:#697586;
  --line:#e3e7ec; --accent:#2f6bff; --accent-ink:#1b4fd6; --ok:#0f9d58; --warn:#b7791f;
  --err:#d64545; --radius:12px; --radius-sm:8px; --shadow:0 1px 2px rgba(16,24,40,.06),0 6px 20px rgba(16,24,40,.06);
  --sans:'Inter',system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0}
body{font-family:var(--sans);background:var(--bg);color:var(--ink);font-size:15px;line-height:1.5}
a{color:var(--accent-ink);text-decoration:none}
a:hover{text-decoration:underline}
b{font-weight:650}

/* Topbar */
.topbar{display:flex;align-items:center;gap:20px;padding:12px 22px;background:var(--surface);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:10}
.brand{display:inline-flex;align-items:center;gap:9px;font-weight:600;color:var(--ink);font-size:17px}
.brand:hover{text-decoration:none}
.brand.big{font-size:22px;margin-bottom:18px}
.brand-mark{width:16px;height:16px;border-radius:5px;background:linear-gradient(135deg,var(--accent),#7aa2ff);box-shadow:inset 0 0 0 2px rgba(255,255,255,.4)}
.brand.big .brand-mark{width:22px;height:22px}
.topnav{display:flex;gap:18px;margin-left:8px}
.topnav a{color:var(--muted);font-weight:500}
.topnav a:hover{color:var(--ink);text-decoration:none}
.logout{margin-left:auto;display:flex;align-items:center;gap:12px}
.who{color:var(--muted);font-size:13px}
.btn-link{background:none;border:0;color:var(--muted);cursor:pointer;font:inherit;font-size:13px}
.btn-link:hover{color:var(--err)}

/* Layout */
.wrap{max-width:1040px;margin:26px auto;padding:0 22px}
.foot{max-width:1040px;margin:40px auto;padding:0 22px;color:var(--muted);font-size:12px}
.page-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}
h1{font-size:24px;margin:0}
h2{font-size:15px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);margin:22px 0 10px}
.muted{color:var(--muted)}
.opt{color:var(--muted);font-weight:400;text-transform:none;letter-spacing:0}

/* Cards */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow)}
.card.empty{text-align:center;padding:44px}
.card+.card{margin-top:16px}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:8px;padding:9px 15px;border-radius:var(--radius-sm);border:1px solid var(--line);background:var(--surface);color:var(--ink);font:inherit;font-weight:550;cursor:pointer;transition:.12s}
.btn:hover{text-decoration:none;background:var(--surface-2)}
.btn-primary{background:var(--accent);border-color:var(--accent);color:#fff}
.btn-primary:hover{background:var(--accent-ink);border-color:var(--accent-ink)}
.btn-danger{color:var(--err);border-color:#f0caca}
.btn-danger:hover{background:#fff2f2}
.btn-block{width:100%;justify-content:center;margin-top:8px}

/* Forms */
.form label{display:block;margin:0 0 14px;font-weight:550;font-size:13px}
.form input,.form textarea,.form select{display:block;width:100%;margin-top:6px;padding:9px 11px;border:1px solid var(--line);border-radius:var(--radius-sm);font:inherit;background:#fff;color:var(--ink)}
.form input:focus,.form textarea:focus,.form select:focus{outline:2px solid #cfe0ff;border-color:var(--accent)}
.form textarea{min-height:90px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:13px}
.form small{display:block;margin-top:5px;color:var(--muted);font-weight:400}
.form-actions{margin-top:18px;display:flex;gap:10px}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:0 20px}
@media(max-width:640px){.grid-2{grid-template-columns:1fr}}

/* Flash */
.flash{padding:11px 15px;border-radius:var(--radius-sm);margin-bottom:16px;font-size:14px;border:1px solid}
.flash-ok{background:#e9f7ef;border-color:#bfe6cd;color:#106b3a}
.flash-error,.flash-err{background:#fdecec;border-color:#f4c7c7;color:#9b2020}
.flash-warn{background:#fef6e7;border-color:#f5e2b8;color:#8a5a12}

/* Site grid */
.site-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}
.site-card{display:block;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow);color:var(--ink)}
.site-card:hover{text-decoration:none;border-color:#c9d3e0;transform:translateY(-1px);transition:.12s}
.site-card-top{display:flex;align-items:center;gap:8px;font-size:16px}
.site-card-meta{display:flex;gap:8px;margin-top:12px;flex-wrap:wrap;font-size:12px;color:var(--muted)}
.pill{background:var(--surface-2);border-radius:20px;padding:2px 9px}
.dot{width:9px;height:9px;border-radius:50%;background:var(--muted);display:inline-block}
.dot-draft{background:#c2ccd8}.dot-built{background:var(--warn)}.dot-live{background:var(--ok)}

/* Login */
.login-body{display:grid;place-items:center;min-height:100vh;background:linear-gradient(160deg,#eef2f8,#f6f7f9)}
.login-card{background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:34px;width:min(380px,92vw);box-shadow:var(--shadow)}
.login-card label{display:block;margin-bottom:14px;font-weight:550;font-size:13px}
.login-card input{display:block;width:100%;margin-top:6px;padding:10px 12px;border:1px solid var(--line);border-radius:var(--radius-sm);font:inherit}

/* Site show + article */
.head-actions{display:flex;gap:8px;align-items:center}
.head-actions form{margin:0}
.lang-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:6px 14px;margin-bottom:14px}
.chk{display:flex;align-items:center;gap:7px;font-weight:500;font-size:14px}
.chk input{width:auto;margin:0}
.gen-form small{margin-top:8px}
.tbl{width:100%;border-collapse:collapse;font-size:14px}
.tbl th{text-align:left;color:var(--muted);font-weight:550;font-size:12px;text-transform:uppercase;letter-spacing:.03em;padding:6px 8px;border-bottom:1px solid var(--line)}
.tbl td{padding:9px 8px;border-bottom:1px solid var(--line)}
.tbl td.right,.tbl th.right{text-align:right}
.tbl form{display:inline;margin:0}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:16px}
@media(max-width:640px){.two-col{grid-template-columns:1fr}}
.plain{list-style:none;padding:0;margin:0 0 14px}
.plain li{padding:4px 0;border-bottom:1px solid var(--line)}
.inline-add{display:flex;gap:8px;flex-wrap:wrap}
.inline-add input{width:auto;flex:1;margin-top:0}
.inline-add .btn{margin-top:0}
.danger-zone{margin-top:26px}
.art-meta{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;font-size:14px}
.lang-block summary{cursor:pointer;font-size:16px;padding:4px 0}
.takeaways{margin:14px 0;padding:12px 16px;background:var(--surface-2);border-radius:var(--radius-sm);font-size:14px}
.takeaways ul{margin:8px 0 0;padding-left:20px}
.preview{margin-top:16px;border-top:1px solid var(--line);padding-top:14px}
.preview-label{font-size:12px;text-transform:uppercase;letter-spacing:.03em;color:var(--muted);margin-bottom:8px}
.prose{max-width:70ch;line-height:1.7}
.prose h2{font-size:20px;text-transform:none;letter-spacing:0;color:var(--ink);margin:22px 0 8px}
.prose h3{font-size:16px;margin:18px 0 6px}
.prose p{margin:0 0 14px}
.prose ul,.prose ol{margin:0 0 14px;padding-left:22px}
.prose blockquote{margin:0 0 14px;padding-left:14px;border-left:3px solid var(--line);color:var(--muted)}

/* job status badges + misc */
.btn-ghost{background:transparent;border:1px solid var(--line);color:var(--accent-ink)}
.btn-ghost:hover{background:var(--surface-2)}
.nowrap{white-space:nowrap}
.tbl td.nowrap form{display:inline;margin-left:6px}
.job-queued{background:#eef2f8;color:#5b6470}
.job-running{background:#fff4e0;color:#8a5a12}
.job-done{background:#e9f7ef;color:#106b3a}
.job-failed{background:#fdecec;color:#9b2020}
