/* admin editor — dark, compact, on-brand with the film */
:root{
  --bg:#070a10; --panel:#0d121b; --panel2:#111826; --line:#1d2735;
  --cyan:#00e5ff; --text:#e7eef5; --muted:#8a98ab; --faint:#56657a;
  --danger:#ff5470; --ok:#37ffc6;
  --mono:'JetBrains Mono',ui-monospace,monospace;
  --sans:'Manrope',system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
body{background:var(--bg);color:var(--text);font-family:var(--sans);font-size:14px;line-height:1.5}
a{color:var(--cyan);text-decoration:none}
button{font-family:var(--sans);cursor:pointer}

/* ---- login ---- */
#login{min-height:100vh;display:flex;align-items:center;justify-content:center}
#login .card{width:min(380px,90vw);background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:34px}
#login h1{font-family:var(--mono);font-size:13px;letter-spacing:.3em;text-transform:uppercase;color:var(--cyan);margin-bottom:6px}
#login p{color:var(--muted);font-size:13px;margin-bottom:22px}
#login input{width:100%;padding:12px 14px;background:var(--panel2);border:1px solid var(--line);border-radius:6px;color:var(--text);font-family:var(--mono);font-size:14px;margin-bottom:14px}
#login input:focus{outline:none;border-color:var(--cyan)}
#login button{width:100%;padding:12px;background:var(--cyan);color:#02141a;border:none;border-radius:6px;font-weight:700;letter-spacing:.05em}
#login .err{color:var(--danger);font-family:var(--mono);font-size:12px;min-height:16px;margin-top:8px}

/* ---- topbar ---- */
.topbar{position:sticky;top:0;z-index:10;display:flex;align-items:center;gap:16px;padding:14px 22px;background:rgba(7,10,16,.92);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.topbar h1{font-family:var(--mono);font-size:12px;letter-spacing:.28em;text-transform:uppercase;color:var(--cyan)}
.topbar .spacer{flex:1}
.topbar .status{font-family:var(--mono);font-size:12px;color:var(--muted);min-width:90px;text-align:right}
.topbar button{padding:9px 16px;border-radius:6px;border:1px solid var(--line);background:var(--panel2);color:var(--text);font-size:13px}
.topbar button.primary{background:var(--cyan);color:#02141a;border-color:var(--cyan);font-weight:700}
.topbar button.ghost{background:transparent}
.topbar a.view{font-family:var(--mono);font-size:12px;color:var(--muted)}

/* ---- layout ---- */
.wrap{max-width:1000px;margin:0 auto;padding:24px 22px 120px}
.section{margin-bottom:14px;background:var(--panel);border:1px solid var(--line);border-radius:10px;overflow:hidden}
.section>.head{display:flex;align-items:center;gap:12px;padding:14px 16px;cursor:pointer;user-select:none}
.section>.head .idx{font-family:var(--mono);font-size:11px;color:var(--cyan);background:rgba(0,229,255,.08);border:1px solid rgba(0,229,255,.25);padding:3px 8px;border-radius:4px}
.section>.head .ttl{font-weight:600;flex:1}
.section>.head .ttl small{color:var(--faint);font-weight:400;font-family:var(--mono);font-size:11px;margin-left:8px}
.section>.head .ctrl{display:flex;gap:6px}
.section>.head .ctrl button{width:30px;height:28px;border-radius:5px;border:1px solid var(--line);background:var(--panel2);color:var(--muted);font-size:13px;display:flex;align-items:center;justify-content:center}
.section>.head .ctrl button:hover{color:var(--text);border-color:var(--cyan)}
.section>.head .ctrl button.del:hover{color:var(--danger);border-color:var(--danger)}
.section>.body{padding:4px 16px 18px;border-top:1px solid var(--line);display:none}
.section.open>.body{display:block}
.section.open>.head .chev{transform:rotate(90deg)}
.chev{color:var(--faint);transition:transform .2s}

/* ---- fields ---- */
.grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.field{margin-top:14px}
.field.full{grid-column:1/-1}
.field label{display:block;font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:6px}
.field input,.field textarea,.field select{width:100%;padding:9px 11px;background:var(--panel2);border:1px solid var(--line);border-radius:6px;color:var(--text);font-family:var(--mono);font-size:13px}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--cyan)}
.field textarea{resize:vertical;min-height:64px;line-height:1.6}
.field .hint{color:var(--faint);font-size:11px;margin-top:5px;font-family:var(--mono)}
.field.color input[type=color]{height:38px;padding:3px;width:54px;vertical-align:middle}
.row-inline{display:flex;gap:10px;align-items:center}

/* ---- repeaters (details/chips/stats/social) ---- */
.rep{margin-top:14px}
.rep>label{display:block;font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:8px}
.rep .item{display:flex;gap:8px;align-items:flex-start;margin-bottom:8px}
.rep .item textarea,.rep .item input{flex:1}
.rep .item .mini{width:30px;height:34px;flex:none;border-radius:5px;border:1px solid var(--line);background:var(--panel2);color:var(--muted)}
.rep .item .mini:hover{color:var(--danger);border-color:var(--danger)}
.rep .add{margin-top:4px;padding:7px 13px;border-radius:6px;border:1px dashed var(--line);background:transparent;color:var(--cyan);font-family:var(--mono);font-size:12px}
.rep .add:hover{border-color:var(--cyan)}
.chk{display:inline-flex;align-items:center;gap:6px;font-family:var(--mono);font-size:12px;color:var(--muted);white-space:nowrap}

.addscene{display:block;width:100%;padding:14px;margin-top:6px;border:1px dashed var(--line);background:transparent;color:var(--cyan);border-radius:10px;font-family:var(--mono);font-size:13px;letter-spacing:.1em}
.addscene:hover{border-color:var(--cyan)}

.toast{position:fixed;left:50%;bottom:26px;transform:translateX(-50%);background:var(--panel2);border:1px solid var(--line);padding:11px 20px;border-radius:8px;font-family:var(--mono);font-size:13px;z-index:50;opacity:0;transition:opacity .25s,transform .25s;pointer-events:none}
.toast.show{opacity:1;transform:translateX(-50%) translateY(-4px)}
.toast.ok{border-color:var(--ok);color:var(--ok)}
.toast.err{border-color:var(--danger);color:var(--danger)}
