:root{
  --bg:#f5f7fa; --panel:#fff; --ink:#1b2533; --ink-2:#46546a; --muted:#7a8699;
  --line:#e7ebf0; --primary:#2f6bff; --primary-600:#2358e6; --ok:#16a34a; --ok-soft:#e6f6ec;
  --warn:#d97706; --warn-soft:#fdf0db; --r:12px; --r-sm:8px; --r-pill:999px;
  --shadow:0 1px 2px rgba(16,24,40,.04),0 1px 3px rgba(16,24,40,.06);
}
*{box-sizing:border-box}
[hidden]{display:none!important}
html,body{height:100%}
body{margin:0;font:14px/1.5 -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;color:var(--ink);background:var(--bg)}
a{color:var(--primary);text-decoration:none}
.muted{color:var(--muted)} .muted-sm{color:var(--muted);font-size:12px}
.right{margin-left:auto}

/* auth gate */
.app{display:none;height:100vh;flex-direction:column}
html.auth-ready .app{display:flex}
.auth-gate{position:fixed;inset:0;z-index:9999;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;background:var(--bg);color:var(--muted);text-align:center;padding:24px}
html.auth-ready .auth-gate{display:none}
.auth-gate .spinner{width:36px;height:36px;border-radius:50%;border:3px solid var(--line);border-top-color:var(--primary);animation:spin .8s linear infinite}
.auth-gate .gate-msg b{display:block;color:var(--ink);font-size:15px;margin-bottom:4px}
@keyframes spin{to{transform:rotate(360deg)}}

/* top bar */
.topbar{display:flex;align-items:center;gap:14px;padding:10px 18px;background:var(--panel);border-bottom:1px solid var(--line);flex:0 0 auto}
.brand{display:flex;align-items:center;gap:9px;font-weight:700}
.brand .mark{width:26px;height:26px;color:#ff7a18}
.brand small{display:block;font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);font-weight:600}
.toolbar-right{margin-left:auto;display:flex;align-items:center;gap:10px}
.name-input{padding:8px 11px;border:1px solid var(--line);border-radius:var(--r-sm);font:inherit;min-width:240px;background:var(--bg)}
.name-input:focus{outline:none;border-color:var(--primary);background:#fff}
.save-state{font-size:12px;color:var(--muted)}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:7px;justify-content:center;background:var(--primary);color:#fff;border:1px solid var(--primary);border-radius:var(--r-sm);padding:9px 15px;font:600 13px/1 inherit;cursor:pointer;text-decoration:none}
.btn:hover{background:var(--primary-600);border-color:var(--primary-600)}
.btn:disabled{opacity:.55;cursor:default}
.btn.ghost{background:var(--panel);color:var(--ink-2);border-color:var(--line)}
.btn.ghost:hover{background:var(--bg)}
.btn.sm{padding:6px 11px;font-size:12px}

/* list view */
.list-wrap{flex:1;overflow:auto;padding:26px}
.list-head{display:flex;align-items:center;gap:14px;max-width:1000px;margin:0 auto 18px}
.list-head h1{margin:0;font-size:22px}
.list-head p{margin:3px 0 0;color:var(--muted)}
.grid{max-width:1000px;margin:0 auto;display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:16px}
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow);overflow:hidden;display:flex;flex-direction:column}
.card .thumb{aspect-ratio:16/10;background:linear-gradient(135deg,#eef2f9,#fff);display:grid;place-items:center;color:#b7c2d2;font-size:30px;border-bottom:1px solid var(--line)}
.card .meta{padding:12px 13px}
.card .meta b{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.card .meta .sub{display:flex;align-items:center;gap:8px;margin-top:6px}
.card.new{align-items:center;justify-content:center;border-style:dashed;cursor:pointer;color:var(--primary);font-weight:600;min-height:170px;gap:6px}
.card.new:hover{background:#fbfcfe}
.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:var(--r-pill);font-size:11px;font-weight:600;background:var(--line);color:var(--ink-2)}
.badge.published{background:var(--ok-soft);color:var(--ok)} .badge.draft{background:var(--warn-soft);color:var(--warn)}
.empty{max-width:1000px;margin:40px auto;text-align:center;color:var(--muted)}

/* editor */
.editor{flex:1;display:flex;min-height:0}
#gjs{flex:1;min-height:0;border:0}
.gjs-one-bg{background-color:var(--primary)}
