/* ===== Delight Book — styles ===== */
:root{
  --bg:#0a100e; --stage:#060908; --surface:#121b18; --surface-2:#16211d;
  --line:rgba(120,200,180,0.10); --line-strong:rgba(120,200,180,0.18);
  --aqua:#5fe7c9; --aqua-dim:#39b59b; --aqua-glow:rgba(95,231,201,0.22);
  --text:#eaf4f0; --muted:#8aa39c; --muted-2:#5f756f;
  --danger:#ff8a7a; --warn:#ffc56b;
  --serif:"Fraunces",Georgia,serif; --sans:"Inter",system-ui,sans-serif;
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;height:100%}
body{
  background:radial-gradient(120% 70% at 50% -8%, #0e1b18 0%, var(--stage) 60%);
  color:var(--text);font-family:var(--sans);min-height:100%;
}
#app{max-width:480px;margin:0 auto;min-height:100dvh;display:flex;flex-direction:column;
  background:var(--bg);box-shadow:0 0 80px -20px rgba(0,0,0,.6)}
.boot{margin:auto;color:var(--muted)}
button{font-family:var(--sans)}
input,textarea,select{font-family:var(--sans)}
.hidden{display:none !important}

/* ---- top bar ---- */
.topbar{position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;
  padding:max(14px,env(safe-area-inset-top)) 18px 12px;border-bottom:1px solid var(--line);
  background:linear-gradient(180deg,rgba(10,16,14,.96),rgba(10,16,14,.8));backdrop-filter:blur(8px)}
.wordmark{display:flex;align-items:center;height:24px}
.wordmark .dot{color:var(--aqua);text-shadow:0 0 16px var(--aqua-glow)}
.tagline{font-size:10px;color:var(--muted-2);letter-spacing:.5px;margin-top:3px;font-weight:600}
.who{font-size:11px;color:var(--muted);text-align:right;line-height:1.4}
.who b{color:var(--text);font-weight:600;display:block;font-size:12px}
.who a{color:var(--aqua-dim);cursor:pointer;text-decoration:none;font-size:11px}

/* ---- scroll area & views ---- */
.screen{flex:1 1 auto;overflow-y:auto;-webkit-overflow-scrolling:touch}
.view{display:none;padding:16px 14px 30px}
.view.active{display:block;animation:fade .3s ease}
@keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.eyebrow{font-size:11px;letter-spacing:1.4px;text-transform:uppercase;color:var(--aqua-dim);font-weight:700;margin:0 4px 8px}
.sec-h{font-family:var(--serif);font-size:24px;font-weight:600;margin:4px 4px 4px}
.sec-sub{font-size:12.5px;color:var(--muted);margin:0 4px 16px;line-height:1.5}
.demo-note{font-size:10.5px;color:var(--muted-2);text-align:center;padding-top:4px}

/* ---- cards ---- */
.card{background:var(--surface);border:1px solid var(--line);border-radius:22px;overflow:hidden;margin-bottom:18px}
.card .photo{position:relative;aspect-ratio:4/5;background-size:cover;background-position:center}
.card .scrim{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,0) 28%,rgba(0,0,0,.62) 100%);z-index:1}
.cat-chip{position:absolute;top:14px;left:16px;z-index:3;font-size:12px;font-weight:600;letter-spacing:.3px;
  color:var(--aqua);background:rgba(8,20,17,.55);border:1px solid rgba(95,231,201,.35);
  backdrop-filter:blur(6px);padding:6px 13px;border-radius:30px}
.cc{position:absolute;left:0;right:0;bottom:16px;z-index:3;height:30px;overflow:hidden;display:none;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 14%,#000 86%,transparent);
          mask-image:linear-gradient(90deg,transparent,#000 14%,#000 86%,transparent)}
.cc.on{display:block}
.cc-line{position:absolute;left:0;top:0;white-space:nowrap;padding-left:100%;
  font-family:var(--serif);font-style:italic;font-size:18px;line-height:30px;will-change:transform}
.cc-line .w{color:rgba(234,244,240,.4);margin-right:.32em;transition:color .12s;text-shadow:0 1px 9px rgba(0,0,0,.85)}
.cc-line .w.spoken{color:#eaf4f0}
.cc-line .w.now{color:var(--aqua);text-shadow:0 0 11px var(--aqua-glow)}

.bar{display:flex;align-items:center;gap:13px;padding:13px 15px}
.meta{flex:1 1 auto;min-width:0}
.meta .name{font-size:13.5px;font-weight:600;display:flex;align-items:center;gap:7px;flex-wrap:wrap}
.meta .listens{font-size:12px;color:var(--muted);margin-top:3px}
.meta .listens b{color:var(--aqua);font-weight:600;font-variant-numeric:tabular-nums}
.meta .listens .you{color:var(--aqua)}
.dur{font-size:11px;color:var(--muted-2);font-variant-numeric:tabular-nums;min-width:30px;text-align:right}
.kebab{flex:0 0 auto;width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  color:var(--muted);cursor:pointer;border:1px solid transparent}
.kebab:hover{border-color:var(--line);color:var(--text)}

/* ---- listen ring ---- */
.player{position:relative;width:50px;height:50px;flex:0 0 auto;cursor:pointer}
.player svg{transform:rotate(-90deg);display:block}
.player .track{stroke:var(--line-strong);fill:none;stroke-width:3}
.player .prog{stroke:var(--aqua);fill:none;stroke-width:3;stroke-linecap:round;
  stroke-dasharray:138.2;stroke-dashoffset:138.2;transition:stroke-dashoffset .1s linear;filter:drop-shadow(0 0 5px var(--aqua-glow))}
.player .glyph{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:var(--aqua)}
.player.done .glyph{color:var(--aqua-dim)}
.player.pulse{animation:pulse .5s ease}
@keyframes pulse{0%{transform:scale(1)}40%{transform:scale(1.12)}100%{transform:scale(1)}}

/* ---- buttons / forms ---- */
.btn{display:block;width:100%;text-align:center;border:none;cursor:pointer;border-radius:14px;padding:15px;
  font-size:15px;font-weight:600;margin-top:16px;transition:.18s}
.btn-primary{background:var(--aqua);color:#06231c;box-shadow:0 8px 30px -12px var(--aqua-glow)}
.btn-primary:hover{background:#79f0d6}
.btn-primary:disabled{background:var(--surface-2);color:var(--muted-2);cursor:not-allowed;box-shadow:none}
.btn-ghost{background:transparent;border:1px solid var(--line-strong);color:var(--text)}
.btn-row{display:flex;gap:10px}.btn-row .btn{margin-top:0}
label.fld{display:block;font-size:12px;color:var(--muted);margin:14px 4px 6px;font-weight:600}
input.in,textarea.in,select.in{width:100%;background:var(--surface);border:1px solid var(--line-strong);
  color:var(--text);border-radius:12px;padding:13px;font-size:15px;outline:none}
input.in:focus,textarea.in:focus,select.in:focus{border-color:var(--aqua-dim)}
textarea.in{resize:none;min-height:90px}
.err{color:var(--danger);font-size:12.5px;margin:12px 4px 0;min-height:1em}
.muted-link{color:var(--aqua-dim);cursor:pointer;font-size:13px;text-align:center;margin-top:18px;display:block}

/* ---- auth + pending screens ---- */
.center-screen{flex:1;display:flex;flex-direction:column;justify-content:center;padding:30px 22px;max-width:480px;margin:0 auto;width:100%}
.brand-big{display:flex;justify-content:center;align-items:center;margin:0 0 2px}
.brand-big .dot{color:var(--aqua);text-shadow:0 0 20px var(--aqua-glow)}
.brand-sub{text-align:center;color:var(--muted);font-size:13px;margin:6px 0 26px}
.pending-card{background:var(--surface);border:1px solid var(--line);border-radius:20px;padding:26px;text-align:center}
.pending-card .ic{font-size:36px}
.pending-card h2{font-family:var(--serif);font-weight:600;margin:12px 0 6px}
.pending-card p{color:var(--muted);font-size:13.5px;line-height:1.6;margin:0}

/* ---- create flow ---- */
.steps-dots{display:flex;gap:6px;justify-content:center;margin:0 0 18px}
.steps-dots i{width:7px;height:7px;border-radius:50%;background:var(--line-strong)}
.steps-dots i.on{background:var(--aqua);width:18px;border-radius:6px}
.step{display:none}.step.active{display:block;animation:fade .3s ease}
.dropzone{border:1.5px dashed var(--line-strong);border-radius:22px;aspect-ratio:4/5;display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:12px;color:var(--muted);cursor:pointer;text-align:center;padding:20px;
  background-size:cover;background-position:center;overflow:hidden}
.dropzone:hover{border-color:var(--aqua-dim);color:var(--text)}
.dropzone .big{font-size:40px}
.dropzone.has-img{border-style:solid;border-color:var(--line)}
.detecting{font-size:12px;color:var(--aqua-dim);text-align:center;margin-top:10px}
.notice{display:flex;gap:11px;background:rgba(255,197,107,.08);border:1px solid rgba(255,197,107,.28);
  border-radius:14px;padding:13px 14px;margin-top:14px}
.notice .ic{font-size:20px;flex:0 0 auto}
.notice p{margin:0;font-size:12.5px;line-height:1.5;color:#f1ddb6}
.notice b{color:var(--warn)}
.rec{display:flex;flex-direction:column;align-items:center;gap:18px;padding:24px 0 8px}
.rec-btn{width:96px;height:96px;border-radius:50%;border:none;cursor:pointer;
  background:radial-gradient(circle at 50% 35%, #2a3b36, #16211d);
  box-shadow:0 0 0 1px var(--line-strong),0 0 40px -10px var(--aqua-glow);display:flex;align-items:center;justify-content:center}
.rec-btn .core{width:34px;height:34px;border-radius:9px;background:var(--danger);transition:.25s}
.rec-btn.live .core{width:26px;height:26px;border-radius:5px}
.rec-btn.live{animation:recpulse 1.4s ease-in-out infinite}
.rec-btn:disabled{opacity:.5;cursor:not-allowed}
@keyframes recpulse{0%,100%{box-shadow:0 0 0 1px var(--line-strong),0 0 0 0 rgba(255,138,122,.4)}50%{box-shadow:0 0 0 1px var(--line-strong),0 0 0 14px rgba(255,138,122,0)}}
.timer{font-family:var(--serif);font-size:38px;font-variant-numeric:tabular-nums}
.timer .max{font-size:16px;color:var(--muted-2);font-family:var(--sans)}
.rec-hint{font-size:12px;color:var(--muted)}
.scrub{width:100%;height:5px;border-radius:6px;background:var(--line-strong);overflow:hidden}
.scrub i{display:block;height:100%;width:0;background:var(--aqua);box-shadow:0 0 8px var(--aqua-glow)}
audio.preview{width:100%;margin-top:8px}
.cat-grid{display:flex;flex-wrap:wrap;gap:9px;margin-top:6px}
.cat-pick{border:1px solid var(--line-strong);background:var(--surface);color:var(--muted);border-radius:30px;
  padding:9px 15px;font-size:13px;font-weight:600;cursor:pointer;transition:.15s}
.cat-pick:hover{color:var(--text)}
.cat-pick.sel{background:rgba(95,231,201,.14);color:var(--aqua);border-color:rgba(95,231,201,.4)}

/* ---- admin ---- */
.admin-tabs{display:flex;gap:5px;background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:5px;margin-bottom:18px;overflow-x:auto}
.admin-tabs button{flex:1 0 auto;background:transparent;border:none;color:var(--muted);font-weight:600;font-size:11px;
  padding:9px 8px;border-radius:10px;cursor:pointer;white-space:nowrap}
.admin-tabs button.on{background:var(--surface-2);color:var(--aqua)}
.panel{display:none}.panel.on{display:block;animation:fade .3s ease}
.row{background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:13px;margin-bottom:11px;display:flex;gap:12px;align-items:center}
.row .thumb{width:52px;height:52px;border-radius:12px;flex:0 0 auto;display:flex;align-items:center;justify-content:center;
  font-size:22px;background-size:cover;background-position:center}
.row .body{flex:1;min-width:0}
.row .t{font-size:13.5px;font-weight:600;word-break:break-word}
.row .s{font-size:11.5px;color:var(--muted);margin-top:3px;line-height:1.4}
.row .s .flagwhy{color:var(--danger);font-weight:600}
.row .s .tagp{color:var(--aqua-dim);font-weight:600}
.acts{display:flex;flex-direction:column;gap:6px;flex:0 0 auto}
.mini{border:none;cursor:pointer;border-radius:9px;padding:7px 12px;font-size:11.5px;font-weight:600}
.mini.ok{background:var(--aqua);color:#06231c}
.mini.no{background:rgba(255,138,122,.14);color:var(--danger);border:1px solid rgba(255,138,122,.3)}
.mini.neutral{background:transparent;border:1px solid var(--line-strong);color:var(--muted)}
.mini.toggle{background:transparent;border:1px solid var(--line-strong);color:var(--muted);min-width:96px}
.mini.toggle.on{background:rgba(95,231,201,.14);color:var(--aqua);border-color:rgba(95,231,201,.35)}
.badge{font-size:9.5px;font-weight:700;letter-spacing:.4px;padding:2px 7px;border-radius:20px;border:1px solid var(--line-strong);color:var(--muted)}
.badge.approved{color:var(--aqua);border-color:rgba(95,231,201,.35)}
.badge.pending{color:var(--warn);border-color:rgba(255,197,107,.35)}
.badge.suspended{color:var(--danger);border-color:rgba(255,138,122,.35)}
.badge.admin{color:#9fb0ff;border-color:rgba(159,176,255,.4)}
.cat-row{display:flex;align-items:center;gap:10px;background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:11px 13px;margin-bottom:9px}
.cat-row .cn{flex:1;font-size:14px;font-weight:600}
.cat-row .cct{font-size:11px;color:var(--muted-2);font-variant-numeric:tabular-nums;min-width:62px;text-align:right}
.cat-row .lock{font-size:9.5px;color:var(--aqua-dim);border:1px solid rgba(95,231,201,.25);border-radius:6px;padding:2px 6px;font-weight:700;letter-spacing:.4px}
.cat-row input.rn{flex:1;background:var(--stage);border:1px solid var(--aqua-dim);color:var(--text);border-radius:9px;padding:7px 9px;font-size:14px;outline:none}
.cat-row .ico{background:none;border:none;color:var(--muted);cursor:pointer;font-size:15px;padding:4px;line-height:1}
.cat-row .ico:hover{color:var(--text)}.cat-row .ico.del:hover{color:var(--danger)}
.add-cat{display:flex;gap:8px;margin:2px 0 16px}
.add-cat input{flex:1;background:var(--surface);border:1px solid var(--line-strong);color:var(--text);border-radius:12px;padding:11px 13px;font-size:14px;outline:none}
.add-cat input:focus{border-color:var(--aqua-dim)}
.add-cat button{background:var(--aqua);color:#06231c;border:none;border-radius:12px;padding:0 16px;font-weight:700;cursor:pointer}
.empty{text-align:center;color:var(--muted-2);padding:34px 16px;font-size:13px}
.empty .big{font-size:30px;display:block;margin-bottom:8px;opacity:.7}

/* ---- tab bar ---- */
.tabbar{position:sticky;bottom:0;display:flex;border-top:1px solid var(--line);background:rgba(8,13,11,.94);
  backdrop-filter:blur(8px);padding:9px 6px calc(env(safe-area-inset-bottom) + 12px);z-index:20}
.tab{flex:1;background:none;border:none;cursor:pointer;color:var(--muted-2);display:flex;flex-direction:column;align-items:center;gap:4px;font-size:10px;font-weight:600}
.tab svg{width:23px;height:23px;stroke:currentColor;fill:none;stroke-width:1.7}
.tab.on{color:var(--aqua)}
.tab.create .ring{width:42px;height:42px;border-radius:50%;background:var(--aqua);color:#06231c;display:flex;align-items:center;justify-content:center;margin-top:-4px;box-shadow:0 6px 22px -8px var(--aqua-glow)}
.tab.create .ring svg{stroke:#06231c;stroke-width:2.2}

/* ---- toast + sheet ---- */
.toast{position:fixed;left:50%;bottom:96px;transform:translateX(-50%) translateY(20px);opacity:0;
  background:#04110d;border:1px solid var(--line-strong);color:var(--text);padding:11px 16px;border-radius:12px;font-size:13px;
  pointer-events:none;transition:.3s;z-index:60;max-width:88%;text-align:center;box-shadow:0 10px 30px -10px #000}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.sheet-bg{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:70;display:none;align-items:flex-end;justify-content:center}
.sheet-bg.show{display:flex;animation:fade .2s}
.sheet{width:100%;max-width:480px;background:var(--surface);border-radius:22px 22px 0 0;border-top:1px solid var(--line-strong);
  padding:10px 12px calc(env(safe-area-inset-bottom) + 16px)}
.sheet .grip{width:38px;height:4px;background:var(--line-strong);border-radius:3px;margin:6px auto 12px}
.sheet button{width:100%;background:transparent;border:none;color:var(--text);font-size:15px;text-align:left;
  padding:15px 14px;border-radius:12px;cursor:pointer;display:flex;gap:11px;align-items:center}
.sheet button:hover{background:var(--surface-2)}
.sheet button.warn{color:var(--danger)}

@media (prefers-reduced-motion: reduce){*{animation:none !important;transition:none !important}}

/* ---- brand logo ---- */
.brand-logo{display:flex;justify-content:center;margin-bottom:10px}
.brand-logo svg{width:104px;height:104px;display:block;filter:drop-shadow(0 0 22px var(--aqua-glow))}
.brand-row{display:flex;align-items:center;gap:11px}
.brand-mark{flex:0 0 auto;display:flex}
.brand-mark svg{width:34px;height:34px;display:block}
.wm-svg{display:block;width:auto}
.wm-big .wm-svg{height:54px}
.wm-small .wm-svg{height:24px}

/* ---- admin post management ---- */
.row.removed{opacity:.55}
.catsel{margin-top:9px;width:100%;background:var(--stage);border:1px solid var(--line-strong);color:var(--text);
  border-radius:9px;padding:7px 9px;font-size:12.5px;outline:none}
.catsel:focus{border-color:var(--aqua-dim)}

/* ===================== Phase 1 ===================== */
.about-links{margin-top:20px;text-align:center;font-size:13px;color:var(--muted-2)}
.about-links a{color:var(--aqua-dim);cursor:pointer;text-decoration:none;margin:0 8px}
.about-links span{color:var(--muted-2)}

/* username availability hint */
.uhint{font-size:12px;min-height:16px;margin:-6px 2px 8px;color:var(--muted-2)}
.uhint.ok{color:var(--aqua)}
.uhint.bad{color:var(--danger)}

/* onboarding */
.onb .brand-sub{margin-bottom:18px}
.onb-doc{background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:16px 16px 4px;
  max-height:46vh;overflow:auto;margin-bottom:14px;text-align:left}
.onb-doc h2{font-size:16px;margin:0 0 10px;color:var(--text)}
.doc-body{white-space:pre-wrap;font-size:13.5px;line-height:1.62;color:var(--muted);text-align:left}
.agree{display:flex;align-items:flex-start;gap:9px;font-size:13px;color:var(--text);
  margin:2px 4px 16px;cursor:pointer;line-height:1.4}
.agree input{margin-top:2px;width:17px;height:17px;accent-color:var(--aqua)}
.onb-preview{margin:4px 0 18px}
.onb-cap{font-size:11px;letter-spacing:1.2px;text-transform:uppercase;color:var(--aqua-dim);font-weight:700;margin-bottom:8px;text-align:center}
.onb-thumbs{display:flex;gap:8px;justify-content:center;flex-wrap:wrap}
.onb-thumb{width:62px;height:62px;border-radius:13px;background-size:cover;background-position:center;
  border:1px solid var(--line-strong)}

/* find people */
.find{margin-bottom:16px}
.find-res{margin-top:8px}
.find-row{display:flex;align-items:center;gap:10px;background:var(--surface);border:1px solid var(--line);
  border-radius:13px;padding:10px 12px;margin-bottom:8px;cursor:pointer}
.find-row .fr-id{flex:1;min-width:0}
.find-row .fr-id b{display:block;font-size:14px;color:var(--text)}
.find-row .fr-id span{font-size:12px;color:var(--muted-2)}
.find-empty{font-size:13px;color:var(--muted-2);padding:6px 4px}

/* centered modal (member card / daily) */
.modal-bg{align-items:center}
.modal{width:100%;max-width:340px;margin:0 20px;background:var(--surface);border:1px solid var(--line-strong);
  border-radius:22px;padding:24px 22px;text-align:center;animation:pop .22s ease}
@keyframes pop{from{transform:scale(.94);opacity:0}to{transform:scale(1);opacity:1}}
.modal .btn{margin-top:10px}
.mc-name{font-size:19px;font-weight:700;color:var(--text)}
.mc-user{font-size:13px;color:var(--aqua-dim);margin-top:2px}
.mc-stats{display:flex;gap:18px;justify-content:center;margin:16px 0 18px;font-size:13px;color:var(--muted)}
.mc-stats b{color:var(--aqua);font-variant-numeric:tabular-nums}

/* profile stats */
.pstats{display:flex;flex-wrap:wrap;gap:10px;margin:4px 2px 6px}
.pstat{flex:1;min-width:84px;background:var(--surface);border:1px solid var(--line);border-radius:14px;
  padding:12px 10px;text-align:center}
.pstat b{display:block;font-size:18px;color:var(--aqua);font-variant-numeric:tabular-nums}
.pstat span{font-size:11px;color:var(--muted-2);letter-spacing:.3px}

/* daily popup */
.daily-eyebrow{font-size:11px;letter-spacing:1.4px;text-transform:uppercase;color:var(--aqua-dim);font-weight:700}
.daily-quote{font-family:var(--serif,Georgia,serif);font-size:18px;line-height:1.45;color:var(--text);margin:14px 0 6px}
.daily-author{font-size:12.5px;color:var(--muted)}
.daily-prompt{font-size:14px;color:var(--text);margin:18px 0 2px;font-weight:600}

/* new since last visit */
.newbar{background:rgba(95,231,201,.10);border:1px solid rgba(95,231,201,.28);color:var(--aqua);
  border-radius:12px;padding:9px 12px;font-size:12.5px;font-weight:600;margin:0 2px 14px;text-align:center}

/* tappable poster name */
.name-link{cursor:pointer;border-bottom:1px dotted transparent}
.name-link:hover{border-bottom-color:var(--aqua-dim)}

/* public doc page */
.doc-page{padding-top:8px}
.doc-page-body{padding:2px}
.doc-page .btn-ghost{margin-top:22px}

/* admin content editor */
.cedit{background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:14px;margin-bottom:14px}
.cedit .eyebrow{margin-bottom:10px}
.cedit input,.cedit textarea{width:100%;background:var(--stage);border:1px solid var(--line-strong);color:var(--text);
  border-radius:11px;padding:10px 12px;font-size:13.5px;outline:none;margin-bottom:10px;font-family:inherit}
.cedit textarea{resize:vertical;line-height:1.5}
.cedit input:focus,.cedit textarea:focus{border-color:var(--aqua-dim)}
.cedit .btn{margin-top:0}
