@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap');

:root {
  --bg:#0a0a0f; --surface:#12121a; --card:#1a1a26; --border:#252538; --border2:#2d2d45;
  --accent:#7c3aed; --accent-l:#a78bfa; --accent-dim:#7c3aed22; --accent-dim2:#7c3aed44;
  --grad:linear-gradient(135deg,#7c3aed,#2563eb);
  --grad-btn:linear-gradient(135deg,#8b46f0,#3b71f7);
  --text:#f0f0f8; --text2:#9090aa; --muted:#55556a;
  --green:#10b981; --green-dim:#10b98120;
  --red:#ef4444; --red-dim:#ef444420;
  --yellow:#f59e0b;
  --font:'Inter',-apple-system,sans-serif;
  --r:10px; --r-lg:16px;
  --shadow:0 4px 24px #0006;
  --shadow-a:0 4px 24px #7c3aed44;
}
*{margin:0;padding:0;box-sizing:border-box;}
body{background:var(--bg);color:var(--text);font-family:var(--font);min-height:100vh;-webkit-font-smoothing:antialiased;}
a{color:inherit;text-decoration:none;}
::-webkit-scrollbar{width:4px;} ::-webkit-scrollbar-track{background:transparent;} ::-webkit-scrollbar-thumb{background:var(--border2);border-radius:2px;}

/* ── AUTH / SETUP PAGES ── */
.auth-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;}
.auth-box{background:var(--surface);border:1px solid var(--border2);border-radius:var(--r-lg);padding:44px 40px;width:100%;max-width:420px;box-shadow:var(--shadow);}
.auth-logo{font-size:22px;font-weight:700;margin-bottom:4px;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.auth-sub{font-size:13px;color:var(--text2);margin-bottom:28px;}
.auth-toggle{display:flex;background:var(--card);border-radius:8px;padding:4px;margin-bottom:24px;}
.auth-tab{flex:1;background:none;border:none;color:var(--muted);font-family:var(--font);font-size:13px;font-weight:500;padding:8px;border-radius:6px;cursor:pointer;transition:all .2s;}
.auth-tab.active{background:var(--accent);color:#fff;}

/* ── FORM ── */
.field{margin-bottom:16px;}
.field label{display:block;font-size:12px;font-weight:500;color:var(--text2);margin-bottom:6px;}
.field input,.field textarea{width:100%;background:var(--card);border:1px solid var(--border2);color:var(--text);font-family:var(--font);font-size:14px;padding:11px 14px;border-radius:8px;outline:none;transition:all .2s;}
.field input:focus,.field textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim);}
.f-label{display:block;font-size:12px;font-weight:500;color:var(--text2);margin-bottom:6px;margin-top:14px;}
.f-label:first-child{margin-top:0;}
.f-input,.f-select,.f-textarea{width:100%;background:var(--surface);border:1px solid var(--border2);color:var(--text);font-family:var(--font);font-size:13px;padding:10px 12px;border-radius:8px;outline:none;transition:all .2s;}
.f-input:focus,.f-select:focus,.f-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim);}
.f-textarea{resize:vertical;min-height:80px;}
.f-row{display:flex;gap:8px;} .f-row .f-input{flex:1;}

/* ── BUTTONS ── */
.btn-primary{width:100%;background:var(--grad-btn);border:none;color:#fff;font-family:var(--font);font-size:14px;font-weight:600;padding:12px;border-radius:8px;cursor:pointer;transition:all .2s;box-shadow:var(--shadow-a);}
.btn-primary:hover{opacity:.9;transform:translateY(-1px);}
.btn-primary:disabled{opacity:.45;cursor:not-allowed;transform:none;}
.btn-secondary{background:var(--card);border:1px solid var(--border2);color:var(--text);font-family:var(--font);font-size:13px;font-weight:500;padding:9px 16px;border-radius:8px;cursor:pointer;transition:all .15s;}
.btn-secondary:hover{background:var(--border);}
.btn-accent{background:var(--accent-dim);border:1px solid var(--accent);color:var(--accent-l);font-family:var(--font);font-size:13px;font-weight:500;padding:9px 16px;border-radius:8px;cursor:pointer;transition:all .15s;}
.btn-accent:hover{background:var(--accent);color:#fff;}
.btn-accent:disabled{opacity:.4;cursor:not-allowed;}
.btn-green{background:var(--green-dim);border:1px solid var(--green);color:var(--green);font-family:var(--font);font-size:13px;font-weight:500;padding:9px 16px;border-radius:8px;cursor:pointer;transition:all .15s;}
.btn-green:hover{background:var(--green);color:#fff;}
.btn-green:disabled{opacity:.4;cursor:not-allowed;}
.btn-danger{background:var(--red-dim);border:1px solid var(--red);color:var(--red);font-family:var(--font);font-size:12px;padding:7px 14px;border-radius:6px;cursor:pointer;transition:all .15s;}
.btn-danger:hover{background:var(--red);color:#fff;}
.btn-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px;}
.btn-sm{font-size:11px !important;padding:5px 10px !important;}

/* ── ALERTS ── */
.alert{font-size:13px;padding:10px 14px;border-radius:8px;margin-bottom:16px;display:none;}
.alert-err{background:var(--red-dim);color:var(--red);border:1px solid #ef44441a;}
.alert-ok{background:var(--green-dim);color:var(--green);border:1px solid #10b9811a;}
.alert-warn{background:#1a150610;color:var(--yellow);border:1px solid #f59e0b33;}

/* ── APP LAYOUT ── */
#app{flex-direction:column;min-height:100vh;}
.topbar{background:var(--surface);border-bottom:1px solid var(--border);padding:0 24px;height:56px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100;}
.topbar-logo{font-size:17px;font-weight:700;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.topbar-user{display:flex;align-items:center;gap:10px;}
.user-email{font-size:12px;color:var(--text2);}
.user-avatar{width:32px;height:32px;border-radius:50%;background:var(--grad);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:#fff;cursor:pointer;flex-shrink:0;}
.app-body{display:flex;flex:1;}
.sidebar{width:210px;background:var(--surface);border-right:1px solid var(--border);padding:16px 10px;position:sticky;top:56px;height:calc(100vh - 56px);overflow-y:auto;flex-shrink:0;}
.nav-section{margin-bottom:24px;}
.nav-section-label{font-size:10px;font-weight:600;color:var(--muted);letter-spacing:1.5px;text-transform:uppercase;padding:0 8px;margin-bottom:6px;display:block;}
.nav-item{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:8px;cursor:pointer;color:var(--text2);font-size:13px;font-weight:500;transition:all .15s;border:none;background:none;width:100%;text-align:left;text-decoration:none;}
.nav-item:hover{background:var(--card);color:var(--text);}
.nav-item.active{background:var(--accent-dim);color:var(--accent-l);}
.nav-icon{font-size:15px;flex-shrink:0;}
.main{flex:1;padding:28px;padding-bottom:60px;min-width:0;}

/* ── PAGE HEADER ── */
.page-header{margin-bottom:24px;}
.page-title{font-size:22px;font-weight:700;margin-bottom:4px;}
.page-sub{font-size:14px;color:var(--text2);}

/* ── CARDS ── */
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:20px;margin-bottom:16px;}
.card-title{font-size:11px;font-weight:600;color:var(--text2);letter-spacing:1px;text-transform:uppercase;margin-bottom:14px;padding-bottom:10px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;}

/* ── TWO COLUMN ── */
.two-col{display:grid;grid-template-columns:310px 1fr;gap:16px;align-items:start;}
@media(max-width:900px){.two-col{grid-template-columns:1fr;}}

/* ── IDEAS ── */
.idea-chip{display:flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:9px 12px;cursor:pointer;font-size:13px;color:var(--text2);transition:all .15s;width:100%;text-align:left;margin-bottom:6px;font-family:var(--font);}
.idea-chip:hover,.idea-chip.selected{border-color:var(--accent);color:var(--text);background:var(--accent-dim);}
.idea-dot{width:6px;height:6px;border-radius:50%;background:var(--accent);flex-shrink:0;}
#topic-badge{display:none;background:var(--accent-dim);border:1px solid var(--accent);border-radius:8px;padding:10px 14px;font-size:13px;color:var(--accent-l);margin-bottom:14px;}

/* ── LOADER ── */
.loader{display:none;text-align:center;padding:32px;}
.spinner{width:24px;height:24px;border:2px solid var(--border2);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite;margin:0 auto 12px;}
@keyframes spin{to{transform:rotate(360deg);}}
.loader-msg{font-size:12px;color:var(--text2);}

/* ── SCENES ── */
.scene-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px;margin-top:14px;}
.scene-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;}
.scene-thumb{width:100%;height:135px;object-fit:cover;display:block;}
.scene-nothumb{width:100%;height:135px;background:var(--border);display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:11px;}
.scene-body{padding:12px;}
.scene-label{font-size:10px;font-weight:600;color:var(--accent-l);letter-spacing:1px;text-transform:uppercase;margin-bottom:3px;}
.scene-timing{font-size:11px;color:var(--muted);margin-bottom:6px;}
.scene-text{font-size:13px;color:var(--text);line-height:1.6;margin-bottom:8px;}
.scene-kw{font-size:11px;color:var(--muted);margin-bottom:8px;}
.scene-dl{display:block;text-align:center;font-size:11px;color:var(--accent-l);border:1px solid var(--border);padding:7px;border-radius:6px;text-decoration:none;transition:all .15s;}
.scene-dl:hover{background:var(--accent);color:#fff;border-color:var(--accent);}
.scene-err{font-size:11px;color:var(--red);margin-top:6px;line-height:1.5;}

/* ── COPY BOX ── */
.copy-box{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:14px;font-size:13px;line-height:1.8;color:var(--text);white-space:pre-wrap;max-height:160px;overflow-y:auto;margin-bottom:8px;font-family:'Courier New',monospace;}

/* ── ARCHIVE ── */
.arch-item{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:14px;margin-bottom:8px;display:flex;align-items:center;justify-content:space-between;gap:10px;}
.arch-topic{font-size:14px;font-weight:500;margin-bottom:2px;}
.arch-date{font-size:11px;color:var(--muted);}

/* ── GUIDE STEPS ── */
.guide-steps{display:flex;align-items:center;margin-bottom:24px;}
.guide-step{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:500;color:var(--muted);}
.guide-step-num{width:24px;height:24px;border-radius:50%;background:var(--border);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex-shrink:0;}
.guide-step.active{color:var(--text);} .guide-step.active .guide-step-num{background:var(--accent);color:#fff;}
.guide-step.done .guide-step-num{background:var(--green);color:#fff;}
.guide-step-sep{flex:1;height:1px;background:var(--border);margin:0 12px;}

/* ── PHOTO APPROVAL ── */
.photo-approval-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:12px;margin-top:12px;}
.photo-card{background:var(--surface);border:1px solid var(--border);border-radius:8px;overflow:hidden;position:relative;transition:border-color .15s;}
.photo-card img{width:100%;height:120px;object-fit:cover;display:block;}
.photo-nothumb{width:100%;height:120px;background:var(--border);display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:11px;}
.photo-card-body{padding:10px;}
.photo-card-label{font-size:11px;color:var(--text2);margin-bottom:8px;font-weight:500;}
.photo-card-actions{display:flex;gap:6px;}
.photo-approved{border-color:var(--green);}
.photo-approved-badge{position:absolute;top:8px;right:8px;background:var(--green);color:#fff;width:22px;height:22px;border-radius:50%;display:none;align-items:center;justify-content:center;font-size:12px;font-weight:700;}
.photo-approved .photo-approved-badge{display:flex;}

/* ── PUZZLE SELECT ── */
.puzzle-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:12px 0;}
.puzzle-opt{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:16px 10px;cursor:pointer;text-align:center;transition:all .15s;}
.puzzle-opt:hover,.puzzle-opt.selected{border-color:var(--accent);background:var(--accent-dim);}
.puzzle-opt-icon{font-size:24px;margin-bottom:6px;}
.puzzle-opt-label{font-size:11px;color:var(--text2);font-weight:500;}
.puzzle-opt.selected .puzzle-opt-label{color:var(--accent-l);}

/* ── STATUS BAR ── */
#statusbar{position:fixed;bottom:0;left:0;right:0;background:var(--surface);border-top:1px solid var(--border);padding:8px 24px;font-size:12px;color:var(--muted);display:flex;align-items:center;gap:8px;z-index:200;}
#statusdot{width:6px;height:6px;border-radius:50%;background:var(--green);flex-shrink:0;}
#statusbar.err #statusdot{background:var(--red);}

/* ── SETUP PAGE ── */
.setup-steps{background:var(--card);border-radius:var(--r);padding:18px 20px;margin-bottom:20px;}
.setup-step{font-size:13px;color:var(--text2);padding:6px 0;border-bottom:1px solid var(--border);display:flex;gap:10px;}
.setup-step:last-child{border-bottom:none;}
.setup-step-num{color:var(--accent-l);font-weight:600;flex-shrink:0;}

hr.sep{border:none;border-top:1px solid var(--border);margin:16px 0;}
