/* PetitionFox — app shell design system (Pass 1) */

:root{
  --ember:#EE571C; --ember-deep:#C53C0C;
  --green:#18A06B; --amber:#E8A219; --blue:#2E6BE6;
  --font-display:'Bricolage Grotesque',system-ui,sans-serif;
  --font-ui:'Inter',system-ui,-apple-system,sans-serif;
  --font-mono:'JetBrains Mono',ui-monospace,Menlo,monospace;
  --maxw:460px; --nav-h:64px; --top-h:54px; --sp:16px;
}
[data-theme="light"]{
  --bg:#F3F0EA; --bg-2:#EAE5DC; --grain:rgba(23,19,15,.035);
  --card:#FFFFFF; --card-2:#FBFAF7;
  --text:#171310; --text-2:#6B6256; --text-3:#9C9385;
  --line:#E8E1D5; --line-2:#F0EBE1;
  --glass:rgba(243,240,234,.82); --glass-brd:rgba(23,19,15,.07);
  --ember-soft:#FCE7DC; --green-soft:#D9F0E6; --amber-soft:#FBEFD2; --blue-soft:#E1EBFE;
  --shadow:0 1px 2px rgba(20,16,12,.04),0 8px 24px rgba(20,16,12,.06);
  --shadow-lift:0 12px 40px rgba(20,16,12,.16);
  --press:rgba(23,19,15,.05);
}
[data-theme="dark"]{
  --bg:#14100C; --bg-2:#1B1611; --grain:rgba(255,255,255,.025);
  --card:#1E1913; --card-2:#241E17;
  --text:#F4EEE6; --text-2:#A99F90; --text-3:#796F60;
  --line:rgba(255,255,255,.085); --line-2:rgba(255,255,255,.05);
  --glass:rgba(18,14,10,.72); --glass-brd:rgba(255,255,255,.08);
  --ember-soft:rgba(238,87,28,.16); --green-soft:rgba(24,160,107,.18);
  --amber-soft:rgba(232,162,25,.18); --blue-soft:rgba(46,107,230,.2);
  --shadow:0 1px 2px rgba(0,0,0,.3),0 10px 30px rgba(0,0,0,.4);
  --shadow-lift:0 18px 50px rgba(0,0,0,.6);
  --press:rgba(255,255,255,.06);
}
*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:var(--font-ui);color:var(--text);background:var(--bg-2);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;font-size:15px;line-height:1.5;overscroll-behavior-y:none}
img{max-width:100%;display:block}
button{font-family:inherit;cursor:pointer;border:0;background:none;color:inherit}
input,textarea,select{font-family:inherit;font-size:16px;color:inherit}
::selection{background:var(--ember);color:#fff}
h1,h2,h3,h4{margin:0;font-family:var(--font-display);font-weight:700;letter-spacing:-.02em;line-height:1.12}
.mono{font-family:var(--font-mono)}
:focus-visible{outline:2px solid var(--ember);outline-offset:2px;border-radius:6px}
.canvas{min-height:100vh;min-height:100dvh;display:block;background:var(--bg)}
.deskrail{display:none}
.app{position:relative;width:100%;max-width:100%;height:100vh;height:100dvh;background:var(--bg);background-image:radial-gradient(circle at 1px 1px,var(--grain) 1px,transparent 0);background-size:18px 18px;display:flex;flex-direction:column;overflow:hidden}
@media(min-width:1040px){
  .canvas{display:flex;justify-content:center;align-items:flex-start;padding:26px;background:var(--bg-2)}
  .app{margin:0 auto}
  .deskrail{display:none}
  .app{border-radius:28px;height:92vh;max-width:1140px;width:100%;min-height:0;flex-direction:row;overflow:hidden}
  .side{display:flex}
  .main{flex:1;min-width:0;display:flex;flex-direction:column;position:relative;overflow:hidden}
  .dock{display:none}
  .top{padding:0 22px}
  .top .brand{display:none}
  .scroll{padding-bottom:40px}
  .scroll>.tabview{max-width:600px;margin:0 auto;width:100%}
  .scrim{border-radius:28px}
  .sheet{left:50%;right:auto;top:50%;bottom:auto;width:min(480px,92%);max-height:84vh;border-radius:24px;transform:translate(-50%,-46%) scale(.96);opacity:0;pointer-events:none;transition:transform .4s cubic-bezier(.32,.72,0,1),opacity .3s ease}
  .sheet.on{transform:translate(-50%,-50%) scale(1);opacity:1;pointer-events:auto}
  .sheet.full{top:50%;bottom:auto;max-height:88vh;height:auto;border-radius:24px}
  .sheet .grab{display:none}
  .toast{bottom:26px}
}
.top{position:sticky;top:0;z-index:30;height:var(--top-h);flex:0 0 auto;display:flex;align-items:center;gap:10px;padding:0 14px;background:var(--glass);backdrop-filter:blur(18px) saturate(1.4);-webkit-backdrop-filter:blur(18px) saturate(1.4);border-bottom:1px solid var(--glass-brd)}
.brand{display:flex;align-items:center;gap:9px;font-family:var(--font-display);font-weight:800;font-size:18.5px;letter-spacing:-.02em}
.mark{width:30px;height:30px;border-radius:9px;display:grid;place-items:center;background:var(--ember);color:#fff;box-shadow:0 4px 12px color-mix(in srgb,var(--ember) 45%,transparent);flex:0 0 auto}
.mark svg{width:18px;height:18px}
.brand small{font-family:var(--font-mono);font-weight:600;font-size:7.5px;letter-spacing:.08em;color:var(--text-3);display:block;margin-top:-1px;white-space:nowrap}
.top .sp{flex:1}
.iconbtn{width:38px;height:38px;border-radius:11px;display:grid;place-items:center;color:var(--text-2);transition:.15s;position:relative}
.iconbtn:hover{background:var(--press);color:var(--text)}
.iconbtn:active{transform:scale(.92)}
.iconbtn svg{width:21px;height:21px}
.iconbtn .dot{position:absolute;top:7px;right:8px;width:8px;height:8px;border-radius:50%;background:var(--ember);border:2px solid var(--glass)}
.livestrip{flex:0 0 auto;display:flex;align-items:center;gap:10px;padding:7px 14px;background:var(--card-2);border-bottom:1px solid var(--line);overflow:hidden;transition:.3s}
.livestrip.hide{height:0;padding:0;border:0;opacity:0}
.livestrip .lv{display:inline-flex;align-items:center;gap:6px;flex:0 0 auto;font-family:var(--font-mono);font-size:9px;letter-spacing:.14em;color:var(--ember-deep);font-weight:600}
.lvdot{width:7px;height:7px;border-radius:50%;background:var(--ember);position:relative}
.lvdot::after{content:"";position:absolute;inset:0;border-radius:50%;background:var(--ember);animation:ping 1.7s cubic-bezier(0,0,.2,1) infinite}
@keyframes ping{75%,100%{transform:scale(2.6);opacity:0}}
.lvport{flex:1;overflow:hidden;min-width:0;-webkit-mask-image:linear-gradient(90deg,transparent,#000 18px,#000 calc(100% - 28px),transparent);mask-image:linear-gradient(90deg,transparent,#000 18px,#000 calc(100% - 28px),transparent)}
.lvtrack{display:flex;gap:26px;width:max-content;white-space:nowrap;animation:scroll 36s linear infinite;font-size:12px;color:var(--text-2)}
.lvtrack b{color:var(--text);font-weight:600}
.lvtrack .fresh{color:var(--ember-deep);font-weight:600}
.lvport:hover .lvtrack{animation-play-state:paused}
@keyframes scroll{to{transform:translateX(-50%)}}
.scroll{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;padding-bottom:calc(var(--nav-h) + env(safe-area-inset-bottom,0px) + 28px)}
.tabview{display:none;animation:fade .35s ease}
.tabview.on{display:block}
@keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.wallhd{display:flex;align-items:flex-end;justify-content:space-between;padding:16px var(--sp) 2px}
.wallhd h2{font-size:25px;letter-spacing:-.03em}
.wallhd .seg{display:flex;gap:4px;background:var(--card);border:1px solid var(--line);border-radius:999px;padding:3px}
.wallhd .seg button,.wallhd .seg a{font-family:var(--font-mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;padding:6px 11px;border-radius:999px;color:var(--text-3);font-weight:600;text-decoration:none;display:inline-block;cursor:pointer;border:0;background:transparent}
.wallhd .seg button.on,.wallhd .seg a.on{background:var(--text);color:var(--bg)}
.wsub{padding:2px var(--sp) 12px;color:var(--text-2);font-size:13px}
.composer{display:flex;align-items:center;gap:11px;margin:2px var(--sp) 14px;padding:11px 13px;background:var(--card);border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow)}
.composer .me{width:36px;height:36px;border-radius:50%;flex:0 0 auto;display:grid;place-items:center;font-family:var(--font-display);font-weight:700;font-size:13px;color:#fff;background:linear-gradient(135deg,#7C3AED,#4F46E5)}
.composer .ph{flex:1;color:var(--text-3);font-size:13.5px}
.composer .go{width:36px;height:36px;border-radius:11px;background:var(--ember);color:#fff;display:grid;place-items:center;flex:0 0 auto;box-shadow:0 4px 12px color-mix(in srgb,var(--ember) 40%,transparent)}
.composer .go svg{width:19px;height:19px}
.composer:active{transform:scale(.99)}
.catrail{display:flex;gap:8px;overflow-x:auto;padding:0 var(--sp) 14px;scrollbar-width:none}
.catrail::-webkit-scrollbar{display:none}
.chip{flex:0 0 auto;display:inline-flex;align-items:center;gap:6px;padding:8px 13px;border-radius:999px;background:var(--card);border:1px solid var(--line);font-size:12.5px;font-weight:500;color:var(--text-2);transition:.15s;white-space:nowrap}
.chip:active{transform:scale(.95)}
.chip.on{background:var(--ember);color:#fff;border-color:var(--ember)}
.feed{display:flex;flex-direction:column;gap:14px;padding:0 var(--sp) 8px}
.card{background:var(--card);border:1px solid var(--line);border-radius:20px;box-shadow:var(--shadow);overflow:hidden;transition:transform .12s,box-shadow .2s}
.card.fresh-in{animation:freshin .6s cubic-bezier(.2,.7,.3,1)}
@keyframes freshin{0%{opacity:0;transform:translateY(-14px) scale(.97)}100%{opacity:1;transform:none}}
.chead{display:flex;align-items:center;gap:10px;padding:14px 14px 10px;cursor:pointer}
.av{width:38px;height:38px;border-radius:50%;display:grid;place-items:center;font-family:var(--font-display);font-weight:700;font-size:14px;color:#fff;flex:0 0 auto;box-shadow:inset 0 0 0 1px rgba(0,0,0,.06)}
.who{flex:1;min-width:0;line-height:1.25}
.who .nm{font-weight:600;font-size:14px;display:flex;align-items:center;gap:5px}
.who .meta{font-size:11.5px;color:var(--text-3);font-family:var(--font-mono);letter-spacing:.02em;display:flex;gap:6px;align-items:center;margin-top:1px}
.geo{display:inline-flex;align-items:center;gap:3px}
.geo svg{width:11px;height:11px;opacity:.8}
.more{color:var(--text-3);padding:6px;border-radius:8px}
.more:hover{background:var(--press)}
.more svg{width:18px;height:18px}
.brandchip{display:inline-flex;align-items:center;gap:7px;margin:0 14px 12px;padding:7px 11px 7px 8px;border-radius:12px;background:var(--bg-2);border:1px solid var(--line-2);font-size:12.5px;width:fit-content}
.bc-logo{width:22px;height:22px;border-radius:6px;display:grid;place-items:center;font-family:var(--font-display);font-weight:800;font-size:11px;color:#fff}
.brandchip .tgt{font-family:var(--font-mono);font-size:9px;letter-spacing:.1em;color:var(--text-3);text-transform:uppercase}
.brandchip b{font-weight:600}
.cbody{padding:0 14px}
.ttl{font-size:18px;letter-spacing:-.02em;line-height:1.2;margin-bottom:7px;cursor:pointer}
.ask{font-size:13.5px;color:var(--text-2);line-height:1.45;margin-bottom:13px}
.ask b{color:var(--text);font-weight:600}
.media{position:relative;margin:0 0 13px;border-radius:14px;overflow:hidden;border:1px solid var(--line-2);background:var(--bg-2);aspect-ratio:16/10}
.media .evtag{position:absolute;top:9px;left:9px;z-index:3;font-family:var(--font-mono);font-size:8.5px;letter-spacing:.14em;text-transform:uppercase;background:rgba(8,6,4,.62);color:#fff;padding:4px 8px;border-radius:6px;backdrop-filter:blur(6px);display:flex;align-items:center;gap:5px}
.evtag svg{width:11px;height:11px}
.media img,.media video{width:100%;height:100%;object-fit:cover;display:block}
.play{position:absolute;inset:0;display:grid;place-items:center;z-index:2;background:rgba(8,6,4,.12);transition:opacity .25s}
.play .pbtn{width:56px;height:56px;border-radius:50%;background:rgba(255,255,255,.94);display:grid;place-items:center;box-shadow:0 6px 22px rgba(0,0,0,.34)}
.play .pbtn svg{width:23px;height:23px;color:#171310;margin-left:3px}
.play .dur{position:absolute;bottom:10px;right:10px;font-family:var(--font-mono);font-size:10px;background:rgba(8,6,4,.66);color:#fff;padding:3px 7px;border-radius:6px;display:flex;align-items:center;gap:4px}
.play .dur svg{width:10px;height:10px}
.media.playing .play{opacity:0;pointer-events:none}
.burst{position:absolute;inset:0;display:grid;place-items:center;z-index:5;pointer-events:none}
.burst svg{width:96px;height:96px;color:#fff;filter:drop-shadow(0 4px 14px rgba(0,0,0,.4));opacity:0}
.burst.go svg{animation:burst .8s cubic-bezier(.2,.7,.3,1)}
@keyframes burst{0%{opacity:0;transform:scale(.3)}15%{opacity:1;transform:scale(1.15)}40%{transform:scale(.95)}70%{opacity:1}100%{opacity:0;transform:scale(1.1)}}
.gallery{display:grid;grid-template-columns:1fr 1fr;gap:5px;margin:0 0 13px;border-radius:14px;overflow:hidden;border:1px solid var(--line-2)}
.gallery .g{position:relative;aspect-ratio:1;background:var(--bg-2)}
.gallery .g img{width:100%;height:100%;object-fit:cover}
.gallery .g .evtag{position:absolute;top:8px;left:8px;font-family:var(--font-mono);font-size:8px;letter-spacing:.12em;text-transform:uppercase;background:rgba(8,6,4,.62);color:#fff;padding:3px 7px;border-radius:5px}
.tracker{margin:0 14px 12px;padding:12px 14px;border-radius:14px;background:var(--bg-2);border:1px solid var(--line-2)}
.tracker.big{margin:0 0 14px;padding:14px 16px}
.trk-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:11px}
.trk-now{display:flex;align-items:center;gap:7px;font-size:12.5px;font-weight:600}
.trk-now .pulse{width:8px;height:8px;border-radius:50%;flex:0 0 auto}
.trk-step{font-family:var(--font-mono);font-size:9.5px;letter-spacing:.1em;color:var(--text-3);text-transform:uppercase}
.rail{position:relative;height:30px;margin:0 6px}
.rail .line{position:absolute;top:9px;left:0;right:0;height:3px;border-radius:3px;background:var(--line)}
.rail .fill{position:absolute;top:9px;left:0;height:3px;border-radius:3px;background:linear-gradient(90deg,var(--ember),var(--amber));transition:width .6s cubic-bezier(.4,0,.2,1)}
.rail.done .fill{background:linear-gradient(90deg,var(--ember),var(--green))}
.nodes{position:absolute;top:0;left:0;right:0;display:flex;justify-content:space-between}
.node{display:flex;flex-direction:column;align-items:center;gap:6px;position:relative;z-index:2}
.dotn{width:13px;height:13px;border-radius:50%;background:var(--card);border:2px solid var(--line);transition:.3s}
.node.done .dotn{background:var(--ember);border-color:var(--ember)}
.node.active .dotn{border-color:var(--ember);background:var(--card);box-shadow:0 0 0 4px var(--ember-soft)}
.rail.done .node.done .dotn{background:var(--green);border-color:var(--green)}
.node .lbl{font-family:var(--font-mono);font-size:8px;letter-spacing:.06em;text-transform:uppercase;color:var(--text-3);position:absolute;top:18px;white-space:nowrap}
.node.active .lbl,.node.done .lbl{color:var(--text-2)}
.spark{position:absolute;top:6px;width:9px;height:9px;border-radius:50%;background:#fff;box-shadow:0 0 10px 3px var(--ember);z-index:3;opacity:0}
@keyframes sparkrun{0%{left:0;opacity:0}10%{opacity:1}90%{opacity:1}100%{left:100%;opacity:0}}
.official{margin:0 14px 13px;padding:13px 14px;border-radius:14px;background:var(--blue-soft);border:1px solid color-mix(in srgb,var(--blue) 22%,transparent)}
.official.flush{margin:0 0 14px}
.official .oh{display:flex;align-items:center;gap:8px;margin-bottom:7px}
.official .obadge{display:inline-flex;align-items:center;gap:4px;font-family:var(--font-mono);font-size:8.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--blue);font-weight:600}
.official .obadge svg{width:13px;height:13px}
.official .oname{font-weight:600;font-size:13px}
.official p{margin:0;font-size:13px;color:var(--text);line-height:1.5}
.crowd{display:flex;align-items:center;gap:11px;padding:0 14px 13px}
.faces{display:flex;flex:0 0 auto}
.faces .fav{width:25px;height:25px;border-radius:50%;display:grid;place-items:center;font-size:9px;font-weight:700;color:#fff;border:2px solid var(--card);margin-left:-9px;font-family:var(--font-display);transition:transform .3s}
.faces .fav:first-child{margin-left:0}
.faces .fav.pop{animation:facepop .5s cubic-bezier(.2,.7,.3,1)}
@keyframes facepop{0%{transform:scale(0) translateY(6px);opacity:0}60%{transform:scale(1.18)}100%{transform:scale(1);opacity:1}}
.faces .fmore{width:25px;height:25px;border-radius:50%;background:var(--bg-2);color:var(--text-2);border:2px solid var(--card);display:grid;place-items:center;font-size:8.5px;font-weight:600;margin-left:-9px;font-family:var(--font-mono)}
.cprog{flex:1;min-width:0}
.cprog .bar{height:5px;border-radius:5px;background:var(--line);overflow:hidden}
.cprog .bar i{display:block;height:100%;border-radius:5px;background:var(--ember);transition:width .5s}
.cprog .cnt{font-size:11.5px;color:var(--text-2);margin-top:5px;font-family:var(--font-mono)}
.cprog .cnt b{color:var(--text);font-weight:600}
.acts{display:flex;align-items:center;border-top:1px solid var(--line-2)}
.act{flex:1;display:flex;align-items:center;justify-content:center;gap:7px;padding:13px 4px;font-size:13px;font-weight:500;color:var(--text-2);transition:.12s;position:relative}
.act svg{width:19px;height:19px;transition:transform .2s}
.act:active{background:var(--press)}
.act:active svg{transform:scale(.85)}
.act .ac{font-variant-numeric:tabular-nums}
.act.is-back.on{color:var(--ember);font-weight:600}
.act.is-back.on svg{fill:var(--ember);color:var(--ember)}
.act .div{position:absolute;right:0;top:22%;height:56%;width:1px;background:var(--line-2)}
.heartpop{animation:pop .45s ease}
@keyframes pop{0%{transform:scale(1)}35%{transform:scale(1.5)}60%{transform:scale(.85)}100%{transform:scale(1)}}
.cmts{border-top:1px solid var(--line-2);max-height:0;overflow:hidden;transition:max-height .35s ease;background:var(--card-2)}
.cmts.open{max-height:560px;overflow-y:auto}
.cmts-in{padding:12px 14px 4px}
.cmt{display:flex;gap:9px;margin-bottom:13px}
.cmt .cav{width:28px;height:28px;border-radius:50%;flex:0 0 auto;display:grid;place-items:center;font-family:var(--font-display);font-weight:700;font-size:11px;color:#fff}
.cmt .cb{flex:1;min-width:0}
.cmt .cbub{background:var(--card);border:1px solid var(--line);border-radius:13px;padding:8px 11px}
.cmt .cn{font-size:12.5px;font-weight:600;display:flex;align-items:center;gap:5px;margin-bottom:2px}
.cmt .cn .ct{font-family:var(--font-mono);font-size:9px;color:var(--text-3);font-weight:500;letter-spacing:.04em}
.cmt .cx{font-size:13px;color:var(--text);line-height:1.45}
.cmt .crow{display:flex;gap:16px;margin:5px 2px 0}
.cmt .crow button{font-size:11px;color:var(--text-3);font-family:var(--font-mono);letter-spacing:.03em;display:flex;align-items:center;gap:4px}
.cmt .crow button svg{width:13px;height:13px}
.cmt .crow button.liked{color:var(--ember)}
.cmt .crow button.liked svg{fill:var(--ember)}
.cmtbox{display:flex;align-items:center;gap:9px;padding:8px 14px 14px;position:sticky;bottom:0;background:var(--card-2)}
.cmtbox .cme{width:28px;height:28px;border-radius:50%;flex:0 0 auto;display:grid;place-items:center;font-family:var(--font-display);font-weight:700;font-size:11px;color:#fff;background:linear-gradient(135deg,#7C3AED,#4F46E5)}
.cmtbox input{flex:1;background:var(--card);border:1px solid var(--line);border-radius:999px;padding:9px 14px;font-size:13.5px;outline:none}
.cmtbox input:focus{border-color:var(--ember)}
.cmtbox .send{width:34px;height:34px;border-radius:50%;background:var(--ember);color:#fff;display:grid;place-items:center;flex:0 0 auto;transition:.15s}
.cmtbox .send:active{transform:scale(.9)}
.cmtbox .send svg{width:17px;height:17px}
.feedend{text-align:center;padding:18px 24px 8px;color:var(--text-3)}
.feedend .ln{font-family:var(--font-mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase}
.feedend .ln::before,.feedend .ln::after{content:"";display:inline-block;width:26px;height:1px;background:var(--line);vertical-align:middle;margin:0 8px}
.vtitle{font-size:25px;letter-spacing:-.03em;padding:18px var(--sp) 2px}
.vsub{padding:0 var(--sp) 14px;color:var(--text-2);font-size:13.5px}
.databar{margin:0 var(--sp) 14px;padding:14px 16px;border-radius:16px;background:linear-gradient(135deg,var(--ember),var(--ember-deep));color:#fff;box-shadow:0 10px 26px color-mix(in srgb,var(--ember) 38%,transparent)}
.databar .dt{font-family:var(--font-mono);font-size:9px;letter-spacing:.16em;text-transform:uppercase;opacity:.85}
.databar h3{color:#fff;font-size:18px;margin:5px 0 4px}
.databar p{margin:0;font-size:12.5px;opacity:.92;line-height:1.45}
.brow{display:flex;align-items:center;gap:12px;margin:0 var(--sp) 10px;padding:12px 14px;background:var(--card);border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow);transition:.12s}
.brow:active{transform:scale(.99)}
.brow .blogo{width:42px;height:42px;border-radius:11px;display:grid;place-items:center;font-family:var(--font-display);font-weight:800;font-size:17px;color:#fff;flex:0 0 auto}
.brow .bmid{flex:1;min-width:0}
.brow .bn{font-weight:700;font-size:15px;display:flex;align-items:center;gap:6px}
.brow .bmeta{font-size:11.5px;color:var(--text-2);font-family:var(--font-mono);margin-top:2px}
.brow .bstat{text-align:right;flex:0 0 auto}
.brow .bstat .bnum{font-family:var(--font-display);font-weight:800;font-size:20px;line-height:1}
.brow .bstat .blab{font-family:var(--font-mono);font-size:8.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--text-3)}
.pill-res{font-family:var(--font-mono);font-size:8px;letter-spacing:.08em;text-transform:uppercase;color:var(--green);background:var(--green-soft);padding:3px 6px;border-radius:5px}
.crow-mini{display:flex;flex-direction:column;gap:9px;margin:0 var(--sp) 11px;padding:13px 15px;background:var(--card);border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow);transition:.12s}
.crow-mini:active{transform:scale(.99)}
.crow-mini .cm-top{display:flex;align-items:center;gap:9px}
.crow-mini .cm-logo{width:30px;height:30px;border-radius:8px;display:grid;place-items:center;font-family:var(--font-display);font-weight:800;font-size:12px;color:#fff;flex:0 0 auto}
.crow-mini .cm-ttl{flex:1;min-width:0;font-weight:600;font-size:13.5px;line-height:1.25;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.crow-mini .cm-stage{font-family:var(--font-mono);font-size:9px;letter-spacing:.06em;text-transform:uppercase;padding:4px 8px;border-radius:6px;flex:0 0 auto}
.minibar{height:4px;border-radius:4px;background:var(--line);overflow:hidden}
.minibar i{display:block;height:100%;border-radius:4px}
.section-lbl{font-family:var(--font-mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--text-3);padding:6px var(--sp) 10px;display:flex;align-items:center;gap:8px}
.section-lbl::after{content:"";flex:1;height:1px;background:var(--line)}
.emptystate{margin:10px var(--sp);padding:30px 22px;text-align:center;border:1px dashed var(--line);border-radius:18px;color:var(--text-3)}
.emptystate .es-ico{width:46px;height:46px;border-radius:14px;background:var(--ember-soft);color:var(--ember);display:grid;place-items:center;margin:0 auto 12px}
.emptystate .es-ico svg{width:24px;height:24px}
.emptystate p{margin:0;font-size:13.5px;line-height:1.5}
.profcard{margin:6px var(--sp) 16px;padding:20px;background:var(--card);border:1px solid var(--line);border-radius:20px;box-shadow:var(--shadow);text-align:center}
.profcard .pav{width:72px;height:72px;border-radius:50%;margin:0 auto 12px;display:grid;place-items:center;font-family:var(--font-display);font-weight:800;font-size:28px;color:#fff;background:linear-gradient(135deg,#7C3AED,#4F46E5)}
.profcard h3{font-size:20px}
.profcard .ph{font-family:var(--font-mono);font-size:11px;color:var(--text-3);margin-top:3px}
.profstats{display:flex;margin:6px var(--sp) 16px;background:var(--card);border:1px solid var(--line);border-radius:16px;overflow:hidden}
.profstats .ps{flex:1;text-align:center;padding:14px 6px;border-right:1px solid var(--line-2)}
.profstats .ps:last-child{border-right:0}
.profstats .ps .n{font-family:var(--font-display);font-weight:800;font-size:22px}
.profstats .ps .l{font-family:var(--font-mono);font-size:8.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--text-3);margin-top:2px}
.setrow{display:flex;align-items:center;gap:13px;margin:0 var(--sp) 9px;padding:14px 15px;background:var(--card);border:1px solid var(--line);border-radius:14px}
.setrow .si{width:34px;height:34px;border-radius:10px;background:var(--bg-2);display:grid;place-items:center;color:var(--text-2);flex:0 0 auto}
.setrow .si svg{width:18px;height:18px}
.setrow .st{flex:1;font-size:14px;font-weight:500}
.setrow .sv{font-size:12.5px;color:var(--text-3);font-family:var(--font-mono)}
.toggle{width:46px;height:27px;border-radius:999px;background:var(--line);position:relative;transition:.2s;flex:0 0 auto}
.toggle.on{background:var(--ember)}
.toggle i{position:absolute;top:3px;left:3px;width:21px;height:21px;border-radius:50%;background:#fff;transition:.22s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 5px rgba(0,0,0,.25)}
.toggle.on i{left:22px}
.dock{position:absolute;left:0;bottom:0;z-index:36;width:100%;height:calc(var(--nav-h) + env(safe-area-inset-bottom,0px));padding-bottom:env(safe-area-inset-bottom,0px);background:var(--glass);border-top:1px solid var(--glass-brd);backdrop-filter:blur(22px) saturate(1.5);-webkit-backdrop-filter:blur(22px) saturate(1.5);box-shadow:0 -1px 0 var(--glass-brd);transition:background .35s ease,border-color .35s ease}
.dockrow{display:flex;align-items:center;width:100%;height:var(--nav-h)}
.db{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;color:var(--text-3);font-size:9.5px;font-weight:600;font-family:var(--font-mono);letter-spacing:.04em;padding-top:6px;overflow:hidden;white-space:nowrap;max-width:120px;transition:opacity .32s ease,max-width .46s cubic-bezier(.34,.01,.18,1),transform .4s ease,color .15s,padding .4s}
.db svg{width:23px;height:23px;transition:transform .35s ease,width .35s ease,height .35s ease,color .2s}
.db:active svg{transform:scale(.86)}
.db.on{color:var(--text)}
.db.on svg{color:var(--ember)}
.db .lbl{transition:opacity .22s ease,max-height .34s ease;overflow:hidden;max-height:14px}
.db.fab{position:relative}
.fabbtn{width:44px;height:44px;border-radius:14px;background:var(--ember);color:#fff;display:grid;place-items:center;margin-top:-12px;box-shadow:0 6px 16px color-mix(in srgb,var(--ember) 48%,transparent),0 0 0 3px var(--bg);transition:.32s cubic-bezier(.34,.01,.18,1)}
.fabbtn svg{width:22px;height:22px}
.fabbtn:active{transform:scale(.9)}
.db.fab span.lbl{margin-top:1px}
.scrim{position:absolute;inset:0;z-index:40;background:rgba(8,6,4,.46);backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);opacity:0;pointer-events:none;transition:opacity .3s}
.scrim.on{opacity:1;pointer-events:auto}
.sheet{position:absolute;left:0;right:0;bottom:0;z-index:41;background:var(--bg);border-radius:24px 24px 0 0;box-shadow:var(--shadow-lift);transform:translateY(102%);transition:transform .44s cubic-bezier(.32,.72,0,1);display:flex;flex-direction:column;max-height:94%;overflow:hidden}
.sheet.on{transform:translateY(0)}
.sheet.full{top:0;max-height:100%;border-radius:0}
.grab{flex:0 0 auto;display:flex;justify-content:center;padding:9px 0 4px}
.grab i{width:38px;height:4px;border-radius:4px;background:var(--line);display:block}
.shead{flex:0 0 auto;display:flex;align-items:center;gap:10px;padding:6px 14px 12px;border-bottom:1px solid var(--line)}
.shead.glass{background:var(--glass);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px)}
.shead h3{flex:1;font-size:16px}
.sbody{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch}
.xbtn{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;color:var(--text-2);background:var(--card)}
.xbtn:hover{background:var(--press)}
.xbtn:active{transform:scale(.92)}
.xbtn svg{width:19px;height:19px}
.nrow{display:flex;gap:12px;padding:13px 16px;border-bottom:1px solid var(--line-2);align-items:flex-start;transition:.12s}
.nrow:active{background:var(--press)}
.nrow.unread{background:color-mix(in srgb,var(--ember) 4%,transparent)}
.nrow .ni{width:36px;height:36px;border-radius:11px;display:grid;place-items:center;flex:0 0 auto;color:#fff}
.nrow .ni svg{width:18px;height:18px}
.nrow .nb2{flex:1;min-width:0}
.nrow .nb2 .nx{font-size:13.5px;line-height:1.4}
.nrow .nb2 .nx b{font-weight:600}
.nrow .nb2 .ntime{font-family:var(--font-mono);font-size:10px;color:var(--text-3);margin-top:3px}
.nrow .ndot{width:8px;height:8px;border-radius:50%;background:var(--ember);flex:0 0 auto;margin-top:6px}
.searchbar{display:flex;align-items:center;gap:10px;margin:4px 16px 12px;padding:11px 14px;background:var(--card);border:1px solid var(--line);border-radius:14px}
.searchbar.focus{border-color:var(--ember)}
.searchbar svg{width:19px;height:19px;color:var(--text-3);flex:0 0 auto}
.searchbar input{flex:1;background:none;border:0;outline:none;font-size:15px}
.sres{padding:0 0 16px}
.sresrow{display:flex;align-items:center;gap:12px;padding:11px 16px;border-bottom:1px solid var(--line-2);transition:.12s}
.sresrow:active{background:var(--press)}
.sresrow .srl{width:38px;height:38px;border-radius:10px;display:grid;place-items:center;font-family:var(--font-display);font-weight:800;font-size:15px;color:#fff;flex:0 0 auto}
.sresrow .srm{flex:1;min-width:0}
.sresrow .srt{font-weight:600;font-size:14px;line-height:1.25;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}
.sresrow .srs{font-size:11.5px;color:var(--text-2);font-family:var(--font-mono);margin-top:2px}
.skicker{font-family:var(--font-mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--text-3);padding:14px 16px 8px}
.cmp-prog{display:flex;gap:6px;padding:4px 16px 14px}
.cmp-prog .dot{flex:1;height:4px;border-radius:4px;background:var(--line);transition:.3s}
.cmp-prog .dot.on{background:var(--ember)}
.cmp-step{padding:4px 16px 16px;animation:fade .3s ease}
.cmp-kicker{font-family:var(--font-mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--ember-deep);margin-bottom:6px}
.cmp-q{font-size:21px;letter-spacing:-.02em;margin-bottom:6px;line-height:1.18}
.cmp-hint{font-size:13px;color:var(--text-2);margin-bottom:16px;line-height:1.45}
.brandgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:9px}
.bpick{display:flex;flex-direction:column;align-items:center;gap:7px;padding:14px 6px;border-radius:14px;background:var(--card);border:1.5px solid var(--line);transition:.15s}
.bpick:active{transform:scale(.96)}
.bpick.on{border-color:var(--ember);background:var(--ember-soft)}
.bpick .bg-logo{width:38px;height:38px;border-radius:10px;display:grid;place-items:center;font-family:var(--font-display);font-weight:800;font-size:16px;color:#fff}
.bpick .bnm{font-size:11.5px;font-weight:600}
.cmp-ta{width:100%;min-height:130px;background:var(--card);border:1.5px solid var(--line);border-radius:14px;padding:14px;font-size:15px;line-height:1.5;resize:none;outline:none}
.cmp-ta:focus{border-color:var(--ember)}
.cmp-in{width:100%;background:var(--card);border:1.5px solid var(--line);border-radius:13px;padding:13px 14px;font-size:15px;outline:none;margin-bottom:10px}
.cmp-in:focus{border-color:var(--ember)}
.cmp-lab{font-size:12px;font-weight:600;color:var(--text-2);margin:0 0 7px 2px;font-family:var(--font-mono);letter-spacing:.04em;text-transform:uppercase}
.evtiles{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:6px}
.evtile{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:24px 10px;border-radius:14px;border:1.5px dashed var(--line);background:var(--card);transition:.15s}
.evtile:active{transform:scale(.97)}
.evtile.on{border-style:solid;border-color:var(--ember);background:var(--ember-soft)}
.evtile .eti{width:40px;height:40px;border-radius:12px;background:var(--bg-2);display:grid;place-items:center;color:var(--text-2)}
.evtile.on .eti{background:var(--ember);color:#fff}
.evtile .eti svg{width:20px;height:20px}
.evtile span{font-size:12.5px;font-weight:600}
.cmp-foot{flex:0 0 auto;display:flex;gap:10px;padding:12px 16px;border-top:1px solid var(--line);background:var(--glass);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px)}
.btn{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:14px;border-radius:14px;font-size:15px;font-weight:600;transition:.15s}
.btn:active{transform:scale(.98)}
.btn.primary{background:var(--ember);color:#fff;box-shadow:0 6px 18px color-mix(in srgb,var(--ember) 40%,transparent)}
.btn.ghost{background:var(--card);border:1px solid var(--line);color:var(--text);flex:0 0 auto;width:54px}
.btn.primary svg{width:18px;height:18px}
.btn.ghost svg{width:18px;height:18px}
.cmp-done{padding:40px 24px;text-align:center}
.cmp-done .seal{width:88px;height:88px;border-radius:26px;margin:0 auto 20px;display:grid;place-items:center;color:#fff;background:linear-gradient(135deg,var(--ember),var(--ember-deep));box-shadow:0 14px 36px color-mix(in srgb,var(--ember) 42%,transparent);animation:sealpop .55s cubic-bezier(.2,.7,.3,1)}
.cmp-done .seal svg{width:42px;height:42px}
@keyframes sealpop{0%{transform:scale(.4);opacity:0}60%{transform:scale(1.12)}100%{transform:scale(1);opacity:1}}
.cmp-done h2{font-size:24px;margin-bottom:8px}
.cmp-done p{color:var(--text-2);font-size:14px;line-height:1.5;margin:0 auto 22px;max-width:280px}
.cmp-done .minitrk{margin:0 auto 24px;max-width:300px}
.cd-hero{padding:16px 16px 4px}
.cd-status{display:flex;align-items:center;gap:8px;margin-bottom:12px;flex-wrap:wrap}
.statpill{display:inline-flex;align-items:center;gap:5px;font-family:var(--font-mono);font-size:9.5px;letter-spacing:.08em;text-transform:uppercase;padding:5px 10px;border-radius:8px;font-weight:600}
.statpill.live{background:var(--ember-soft);color:var(--ember-deep)}
.statpill.res{background:var(--green-soft);color:var(--green)}
.statpill.cat{background:var(--bg-2);color:var(--text-2)}
.cd-title{font-size:23px;letter-spacing:-.025em;line-height:1.16;margin-bottom:12px}
.cd-who{display:flex;align-items:center;gap:10px;margin-bottom:4px}
.cd-who .meta{font-size:11.5px;color:var(--text-3);font-family:var(--font-mono);display:flex;gap:6px;align-items:center}
.cd-ask{margin:0 16px 16px;padding:14px 16px;border-radius:14px;background:var(--ember-soft);border:1px solid color-mix(in srgb,var(--ember) 20%,transparent)}
.cd-ask .lab{font-family:var(--font-mono);font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:var(--ember-deep);margin-bottom:5px}
.cd-ask p{margin:0;font-size:14.5px;font-weight:500;line-height:1.45}
.cd-sec{padding:0 16px;margin-bottom:8px}
.cd-seclab{font-family:var(--font-mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--text-3);margin:18px 0 12px;display:flex;align-items:center;gap:8px}
.cd-seclab::after{content:"";flex:1;height:1px;background:var(--line)}
.cd-media{margin:0 0 8px;border-radius:16px;overflow:hidden;border:1px solid var(--line-2);position:relative;aspect-ratio:16/10;background:var(--bg-2)}
.cd-media img,.cd-media video{width:100%;height:100%;object-fit:cover}
.tl{position:relative;padding-left:30px;margin:0 16px}
.tl::before{content:"";position:absolute;left:9px;top:6px;bottom:10px;width:2px;background:var(--line)}
.tle{position:relative;padding-bottom:18px}
.tle::before{content:"";position:absolute;left:-26px;top:3px;width:14px;height:14px;border-radius:50%;background:var(--card);border:2px solid var(--line)}
.tle.done::before{background:var(--ember);border-color:var(--ember)}
.tle.done.green::before{background:var(--green);border-color:var(--green)}
.tle.active::before{border-color:var(--ember);box-shadow:0 0 0 4px var(--ember-soft)}
.tle .th{display:flex;align-items:center;gap:8px;margin-bottom:4px}
.tle .ts{font-weight:600;font-size:14px}
.tle .ttime{font-family:var(--font-mono);font-size:9.5px;color:var(--text-3)}
.tle .tnote{font-size:13px;color:var(--text-2);line-height:1.45}
.tle .tby{font-family:var(--font-mono);font-size:10px;color:var(--ember-deep);margin-top:5px;display:flex;align-items:center;gap:5px}
.tle .tby svg{width:12px;height:12px}
.cd-conv{padding:0 0 12px}
.cd-back{flex:0 0 auto;display:flex;align-items:center;gap:12px;padding:12px 16px;border-top:1px solid var(--line);background:var(--glass);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px)}
.cd-back .summ{flex:1;min-width:0}
.cd-back .summ .n{font-family:var(--font-display);font-weight:800;font-size:18px;line-height:1}
.cd-back .summ .l{font-family:var(--font-mono);font-size:9.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--text-3);margin-top:2px}
.cd-back .bigback{flex:0 0 auto;display:flex;align-items:center;gap:8px;padding:13px 22px;border-radius:14px;background:var(--ember);color:#fff;font-weight:600;font-size:15px;box-shadow:0 6px 18px color-mix(in srgb,var(--ember) 42%,transparent);transition:.15s}
.cd-back .bigback:active{transform:scale(.97)}
.cd-back .bigback.on{background:var(--green-soft);color:var(--green);box-shadow:none}
.cd-back .bigback svg{width:18px;height:18px;fill:currentColor}
.toast{position:absolute;left:50%;bottom:calc(var(--nav-h) + 24px);transform:translate(-50%,20px);z-index:60;background:var(--text);color:var(--bg);font-size:13px;font-weight:500;padding:11px 16px;border-radius:13px;box-shadow:var(--shadow-lift);opacity:0;pointer-events:none;transition:.3s;display:flex;align-items:center;gap:8px;max-width:84%}
.toast.on{opacity:1;transform:translate(-50%,0)}
.toast svg{width:16px;height:16px;flex:0 0 auto}

/* ===== main wrapper + sidebar (desktop) ===== */
.main{display:flex;flex-direction:column;flex:1 1 auto;min-height:0;width:100%;position:relative}
.side{display:none;flex-direction:column;width:248px;flex:0 0 248px;padding:20px 14px;background:var(--bg);border-right:1px solid var(--line)}
.side-brand{display:flex;align-items:center;gap:11px;padding:6px 10px 20px}
.side-brand .mark{width:42px;height:42px;border-radius:13px;flex:0 0 auto}
.side-brand .mark svg{width:24px;height:24px}
.side-brand .sb-name{font-family:var(--font-display);font-weight:800;font-size:19px;letter-spacing:-.02em;line-height:1.05}
.side-brand .sb-tag{font-family:var(--font-mono);font-size:7.5px;letter-spacing:.07em;color:var(--text-3);margin-top:2px;white-space:nowrap}
.side-nav{display:flex;flex-direction:column;gap:3px}
.snav{display:flex;align-items:center;gap:14px;padding:12px 14px;border-radius:14px;color:var(--text-2);font-family:var(--font-ui);font-weight:600;font-size:15.5px;width:100%;text-align:left;transition:.14s;cursor:pointer}
.snav svg{width:23px;height:23px;flex:0 0 auto}
.snav:hover{background:var(--press);color:var(--text)}
.snav.on{background:var(--ember-soft);color:var(--ember-deep)}
.snav.on svg{color:var(--ember)}
.side-speak{display:flex;align-items:center;justify-content:center;gap:9px;margin:16px 4px;padding:13px;border-radius:15px;background:var(--ember);color:#fff;font-family:var(--font-ui);font-weight:600;font-size:15px;box-shadow:0 8px 20px color-mix(in srgb,var(--ember) 38%,transparent);transition:.15s;cursor:pointer}
.side-speak:hover{transform:translateY(-1px)}
.side-speak svg{width:20px;height:20px}
.side-foot{margin-top:auto;display:flex;align-items:center;gap:8px;padding-top:16px;border-top:1px solid var(--line)}
.side-prof{flex:1;display:flex;align-items:center;gap:11px;padding:8px 10px;border-radius:13px;transition:.14s;min-width:0;cursor:pointer}
.side-prof:hover{background:var(--press)}
.side-prof .sp-av{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#7C3AED,#4F46E5);color:#fff;display:grid;place-items:center;font-family:var(--font-display);font-weight:800;font-size:15px;flex:0 0 auto;overflow:hidden}
.side-prof .sp-meta{min-width:0}
.side-prof .sp-n{font-weight:700;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.side-prof .sp-h{font-family:var(--font-mono);font-size:10px;color:var(--text-3)}
.side-theme{width:40px;height:40px;border-radius:12px;display:grid;place-items:center;color:var(--text-2);background:var(--press);flex:0 0 auto;transition:.14s;cursor:pointer}
.side-theme:hover{color:var(--text)}
.side-theme svg{width:20px;height:20px}

/* ===== brand logos (clearbit) ===== */
.pf-logo{position:relative;overflow:hidden}
.pf-logo>img{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;background:#fff;padding:14%}
.pf-logo>b{font-weight:800;line-height:1}

/* ===== other-url row ===== */
.other-url{animation:fade .25s ease}
.url-row{display:flex;gap:9px;align-items:stretch}
.url-row .cmp-in{flex:1;margin-bottom:0}
.btn.url-use{flex:0 0 auto;width:auto;padding:0 20px}

/* ===== self avatars (image) ===== */
.selfav{overflow:hidden}
.selfav img{width:100%;height:100%;object-fit:cover;display:block}
.pav-wrap{position:relative;width:72px;height:72px;margin:0 auto 12px}
.pav-wrap .pav{margin:0;width:100%;height:100%}
.pav-cam{position:absolute;right:-3px;bottom:-1px;width:28px;height:28px;border-radius:50%;background:var(--ember);color:#fff;display:grid;place-items:center;border:3px solid var(--card);cursor:pointer}
.pav-cam svg{width:14px;height:14px}
#youAvatar{cursor:pointer}

/* ===== avatar picker sheet ===== */
.avgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:13px;padding:16px 18px 8px}
.avopt{aspect-ratio:1;border-radius:50%;overflow:hidden;border:2.5px solid transparent;position:relative;cursor:pointer;transition:.14s}
.avopt:active{transform:scale(.94)}
.avopt.on{border-color:var(--ember);box-shadow:0 0 0 3px color-mix(in srgb,var(--ember) 18%,transparent)}
.avopt img{width:100%;height:100%;object-fit:cover}
.avopt.initial{display:grid;place-items:center;background:linear-gradient(135deg,#7C3AED,#4F46E5);color:#fff;font-family:var(--font-display);font-weight:800;font-size:22px}

/* ===== GATE ===== */
.gate{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;padding:22px;opacity:1;transition:opacity .5s ease}
.gate.closing{opacity:0;pointer-events:none}
.gate-bg{position:absolute;inset:0;background:radial-gradient(900px 520px at 50% -8%,color-mix(in srgb,var(--ember) 30%,transparent),transparent 60%),var(--bg-2)}
.gate-bg::after{content:"";position:absolute;inset:0;backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px)}
.gate-card{position:relative;width:100%;max-width:382px;background:var(--glass);color:var(--text);border:1px solid var(--glass-brd);border-radius:26px;box-shadow:var(--shadow-lift);backdrop-filter:blur(28px) saturate(1.6);-webkit-backdrop-filter:blur(28px) saturate(1.6);padding:26px 24px 24px;animation:gaterise .55s cubic-bezier(.2,.7,.3,1)}
@keyframes gaterise{from{opacity:0;transform:translateY(18px) scale(.97)}to{opacity:1;transform:none}}
.gate-x{position:absolute;top:15px;right:15px;width:34px;height:34px;border-radius:11px;display:grid;place-items:center;color:var(--text-2);background:color-mix(in srgb,var(--text) 7%,transparent);cursor:pointer;transition:.14s;z-index:3}
.gate-x:hover{color:var(--text)}
.gate-x:active{transform:scale(.92)}
.gate-x svg{width:18px;height:18px}
.gate-brand{display:flex;align-items:center;gap:11px;margin-bottom:20px}
.gate-brand .mark{width:46px;height:46px;border-radius:14px;flex:0 0 auto}
.gate-brand .mark svg{width:26px;height:26px}
.gt-name{font-family:var(--font-display);font-weight:800;font-size:21px;letter-spacing:-.02em;line-height:1.05}
.gt-tag{font-family:var(--font-mono);font-size:7.5px;letter-spacing:.09em;color:var(--text-3);margin-top:2px;white-space:nowrap}
.gate-h{font-size:23px;letter-spacing:-.02em;line-height:1.18;margin-bottom:7px}
.gate-sub{font-size:13.5px;color:var(--text-2);line-height:1.45;margin-bottom:20px}
.g-google{width:100%;display:flex;align-items:center;justify-content:center;gap:10px;padding:14px;border-radius:14px;background:#fff;color:#1a1410;font-family:var(--font-ui);font-weight:600;font-size:15px;border:1px solid rgba(0,0,0,.08);box-shadow:0 2px 9px rgba(0,0,0,.08);cursor:pointer;transition:.14s}
.g-google:hover{box-shadow:0 4px 14px rgba(0,0,0,.12)}
.g-google:active{transform:scale(.98)}
.g-google svg{width:20px;height:20px}
.g-or{display:flex;align-items:center;gap:12px;margin:15px 0;color:var(--text-3);font-family:var(--font-mono);font-size:10px;letter-spacing:.1em}
.g-or::before,.g-or::after{content:"";flex:1;height:1px;background:var(--line)}
.g-in{width:100%;background:var(--card);border:1.5px solid var(--line);border-radius:13px;padding:13px 14px;font-size:15px;outline:none;margin-bottom:10px;transition:.14s}
.g-in:focus{border-color:var(--ember)}
.g-email-go{width:100%;padding:13px;border-radius:13px;background:color-mix(in srgb,var(--ember) 13%,transparent);color:var(--ember-deep);font-family:var(--font-ui);font-weight:700;font-size:14.5px;cursor:pointer;transition:.14s;border:1px solid color-mix(in srgb,var(--ember) 22%,transparent)}
.g-email-go:hover{background:color-mix(in srgb,var(--ember) 18%,transparent)}
.g-foot{margin-top:17px;text-align:center;font-size:12.5px;color:var(--text-3)}
.g-foot a{color:var(--ember);font-weight:600;cursor:pointer}
.code-row{display:flex;gap:9px;justify-content:center;margin:20px 0}
.code-row input{width:46px;height:54px;text-align:center;font-size:22px;font-family:var(--font-display);font-weight:700;color:var(--text);background:var(--card);border:1.5px solid var(--line);border-radius:13px;outline:none;transition:.14s}
.code-row input:focus{border-color:var(--ember);box-shadow:0 0 0 3px color-mix(in srgb,var(--ember) 14%,transparent)}
.gate-back{display:inline-flex;align-items:center;gap:6px;color:var(--text-3);font-size:13px;cursor:pointer;margin-top:4px}
.gate-check{text-align:center;padding:6px 0 2px}
.gate-orb{width:84px;height:84px;border-radius:24px;margin:8px auto 24px;display:grid;place-items:center;background:linear-gradient(135deg,var(--ember),var(--ember-deep));color:#fff;box-shadow:0 12px 34px color-mix(in srgb,var(--ember) 42%,transparent);position:relative}
.gate-orb svg{width:40px;height:40px;position:relative;z-index:2}
.gate-orb::after{content:"";position:absolute;inset:-6px;border-radius:30px;border:2px solid var(--ember);opacity:.5;animation:gatepulse 1.7s ease-out infinite}
@keyframes gatepulse{0%{transform:scale(1);opacity:.5}100%{transform:scale(1.28);opacity:0}}
.chk-list{text-align:left;max-width:230px;margin:0 auto}
.chk{display:flex;align-items:center;gap:12px;padding:9px 0;font-size:14px;color:var(--text-3);opacity:.4;transition:opacity .35s,color .35s}
.chk.on{opacity:1;color:var(--text)}
.chk .ico{width:22px;height:22px;display:grid;place-items:center;flex:0 0 auto}
.chk .spin{width:20px;height:20px;border-radius:50%;border:2px solid var(--line);border-top-color:var(--ember);animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.chk .ck{width:22px;height:22px;border-radius:50%;background:var(--green);display:grid;place-items:center;animation:pop .3s cubic-bezier(.2,1.4,.4,1)}
@keyframes pop{from{transform:scale(.3)}to{transform:scale(1)}}
.chk .ck svg{width:13px;height:13px;color:#fff}
.gate-welcome{text-align:center;padding:14px 0 6px;animation:fade .4s ease}
.gw-av{width:82px;height:82px;border-radius:50%;margin:6px auto 16px;overflow:hidden;box-shadow:0 10px 26px rgba(0,0,0,.22);border:3px solid var(--card)}
.gw-av img{width:100%;height:100%;object-fit:cover}
.gate-welcome h2{font-size:24px;letter-spacing:-.02em;margin-bottom:6px}
.gate-welcome p{color:var(--text-2);font-size:14px}
@keyframes fade{from{opacity:0}to{opacity:1}}
.av-box{padding:18px 18px 24px;text-align:center}
.av-big{width:108px;height:108px;border-radius:50%;margin:0 auto 18px;background:linear-gradient(135deg,#7C3AED,#4F46E5);color:#fff;display:grid;place-items:center;font-family:var(--font-display);font-weight:800;font-size:42px;box-shadow:0 8px 24px rgba(0,0,0,.18)}
.av-acts{display:flex;flex-direction:column;gap:10px;max-width:280px;margin:0 auto 4px}
/* gate biz strip */
.g-biz{margin-top:18px;padding-top:18px;border-top:1px solid var(--line);display:flex;align-items:center;gap:12px}
.g-biz-txt{flex:1;min-width:0}
.g-biz-txt b{display:block;font-size:13.5px;line-height:1.3}
.g-biz-txt span{font-size:11.5px;color:var(--text-3);line-height:1.35;display:block;margin-top:2px}
.g-biz-btn{flex:0 0 auto;padding:10px 14px;border-radius:11px;background:color-mix(in srgb,var(--text) 7%,transparent);color:var(--text);font-family:var(--font-ui);font-weight:600;font-size:13px;white-space:nowrap;cursor:pointer;transition:.14s}
.g-biz-btn:hover{background:color-mix(in srgb,var(--text) 12%,transparent)}
/* business console */
.biz{position:fixed;inset:0;z-index:150;background:var(--bg);display:none;flex-direction:column}
.biz-top{flex:0 0 auto;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 18px;border-bottom:1px solid var(--line);background:var(--glass);backdrop-filter:blur(18px) saturate(1.4);-webkit-backdrop-filter:blur(18px) saturate(1.4)}
.biz-brand{display:flex;align-items:center;gap:12px;min-width:0}
.biz-logo{width:44px;height:44px;border-radius:12px;display:grid;place-items:center;font-family:var(--font-display);font-weight:800;font-size:17px;color:#fff;flex:0 0 auto;background:#1f2937}
.biz-name{font-family:var(--font-display);font-weight:800;font-size:18px;letter-spacing:-.02em;line-height:1.1}
.biz-badge{display:inline-flex;align-items:center;gap:5px;font-family:var(--font-mono);font-size:9px;letter-spacing:.07em;text-transform:uppercase;color:var(--green);font-weight:600;margin-top:3px}
.biz-badge svg{width:12px;height:12px}
.biz-exit{display:inline-flex;align-items:center;gap:7px;padding:9px 14px;border-radius:11px;background:var(--press);color:var(--text-2);font-family:var(--font-ui);font-weight:600;font-size:13px;flex:0 0 auto;cursor:pointer;transition:.14s}
.biz-exit:hover{color:var(--text)}
.biz-exit svg{width:15px;height:15px}
.biz-scroll{flex:1;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch}
.biz-sub{padding:20px 18px 6px;font-family:var(--font-mono);font-size:11px;letter-spacing:.05em;text-transform:uppercase;color:var(--text-3);max-width:780px;margin:0 auto;width:100%}
.biz-list{padding:10px 16px 48px;display:flex;flex-direction:column;gap:14px;max-width:780px;margin:0 auto;width:100%}
.biz-card{background:var(--card);border:1px solid var(--line);border-radius:18px;padding:16px}
.biz-c-top{display:flex;align-items:center;gap:11px;margin-bottom:11px}
.biz-c-top .av{width:38px;height:38px;border-radius:50%;display:grid;place-items:center;color:#fff;font-family:var(--font-display);font-weight:700;font-size:14px;flex:0 0 auto}
.biz-c-name{font-weight:600;font-size:14px}
.biz-c-name span{color:var(--text-3);font-weight:500}
.biz-c-stage{font-family:var(--font-mono);font-size:11px;color:var(--text-3);margin-top:2px}
.biz-c-ttl{font-family:var(--font-display);font-weight:700;font-size:16px;line-height:1.26;letter-spacing:-.01em;margin-bottom:7px}
.biz-c-ask{font-size:13.5px;color:var(--text-2);line-height:1.45;margin-bottom:13px}
.biz-c-ask b{color:var(--text)}
.biz-c-resp{background:var(--blue-soft);border:1px solid color-mix(in srgb,var(--blue) 22%,transparent);border-radius:13px;padding:12px 13px;margin-bottom:13px}
.biz-c-resp .obadge{display:inline-flex;align-items:center;gap:5px;font-family:var(--font-mono);font-size:8.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--blue);font-weight:600;margin-bottom:6px}
.biz-c-resp .obadge svg{width:13px;height:13px}
.biz-c-resp p{margin:0;font-size:13px;line-height:1.5;color:var(--text)}
.biz-respond{width:100%;padding:12px;border-radius:13px;background:var(--ember);color:#fff;font-family:var(--font-ui);font-weight:600;font-size:14px;cursor:pointer;transition:.15s}
.biz-respond:active{transform:scale(.99)}
.biz-edit{margin-bottom:11px}
.biz-ta{width:100%;min-height:98px;background:var(--bg);border:1.5px solid var(--line);border-radius:13px;padding:12px 13px;font-size:14px;font-family:var(--font-ui);color:var(--text);outline:none;resize:vertical;line-height:1.5}
.biz-ta:focus{border-color:var(--ember)}
.biz-edit-acts{display:flex;gap:9px;margin-top:9px}
.biz-edit-acts .btn{flex:1}
.biz-empty{text-align:center;color:var(--text-3);font-size:14px;padding:48px 24px;line-height:1.55}
.sec-orb{width:88px;height:88px;margin:8px auto 22px;position:relative;display:grid;place-items:center}
.sec-orb .ring{position:absolute;inset:0;border-radius:50%;border:2px solid color-mix(in srgb,var(--ember) 32%,transparent);animation:secpulse 1.6s ease-out infinite}
.sec-shield{width:58px;height:58px;position:relative;z-index:2}
.sec-shield .body{stroke:var(--ember);stroke-width:2.2;fill:color-mix(in srgb,var(--ember) 11%,transparent);stroke-dasharray:1;stroke-dashoffset:1;animation:secdraw .7s ease forwards}
.sec-shield .tick{stroke:var(--ember);stroke-width:2.6;stroke-linecap:round;stroke-linejoin:round;fill:none;stroke-dasharray:1;stroke-dashoffset:1;animation:secdraw .5s ease .62s forwards}
@keyframes secdraw{to{stroke-dashoffset:0}}
@keyframes secpulse{0%{transform:scale(1);opacity:.55}100%{transform:scale(1.35);opacity:0}}
.sec-status{font-size:14.5px;color:var(--text-2);text-align:center;transition:opacity .15s ease;min-height:20px}
.sec-bar{width:172px;height:5px;border-radius:99px;background:color-mix(in srgb,var(--text) 9%,transparent);margin:16px auto 4px;overflow:hidden}
.sec-bar i{display:block;height:100%;width:0;border-radius:99px;background:linear-gradient(90deg,var(--ember),var(--ember-deep))}
.sec-dots{display:flex;justify-content:center;gap:9px;margin:18px auto 4px}
.sec-dots i{width:9px;height:9px;border-radius:50%;background:var(--ember);animation:secdots 1s ease-in-out infinite}
.sec-dots i:nth-child(2){animation-delay:.15s}
.sec-dots i:nth-child(3){animation-delay:.3s}
.sec-dots i:nth-child(4){animation-delay:.45s}
@keyframes secdots{0%,75%,100%{transform:scale(.55);opacity:.3}38%{transform:scale(1);opacity:1}}
/* image lightbox */
.lbox{position:fixed;inset:0;z-index:170;background:rgba(8,6,4,.93);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:none;flex-direction:column;opacity:0;transition:opacity .28s ease}
.lbox.on{display:flex;opacity:1}
.lbox-head{flex:0 0 auto;display:flex;align-items:center;gap:12px;padding:14px 16px;color:#fff}
.lbox-x{width:38px;height:38px;border-radius:50%;display:grid;place-items:center;background:rgba(255,255,255,.13);color:#fff;flex:0 0 auto;cursor:pointer}
.lbox-x svg{width:18px;height:18px}
.lbox-cap{flex:1;min-width:0;font-size:13px;color:rgba(255,255,255,.85);line-height:1.35;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.lbox-brand{font-weight:700;color:#fff}
.lbox-nav{display:flex;align-items:center;gap:8px;color:#fff;font-family:var(--font-mono);font-size:12px;flex:0 0 auto}
.lbox-nav:empty{display:none}
.lbox-nav button{width:32px;height:32px;border-radius:50%;background:rgba(255,255,255,.13);color:#fff;font-size:17px;display:grid;place-items:center;cursor:pointer}
.lbox-img-wrap{flex:1;min-height:0;display:flex;align-items:center;justify-content:center;padding:6px 10px}
.lbox-img-wrap img{max-width:100%;max-height:100%;object-fit:contain;border-radius:10px}
.lbox-panel{flex:0 0 auto;background:var(--bg);border-radius:22px 22px 0 0;max-height:46%;display:flex;flex-direction:column;overflow:hidden}
.lbox-acts{flex:0 0 auto;display:flex;align-items:center;gap:8px;padding:12px 16px;border-bottom:1px solid var(--line)}
.lba{display:inline-flex;align-items:center;gap:7px;padding:9px 14px;border-radius:12px;background:var(--card);border:1px solid var(--line);color:var(--text);font-weight:600;font-size:13.5px;cursor:pointer;transition:.14s}
.lba svg{width:18px;height:18px}
.lba.on{color:var(--ember);background:var(--ember-soft);border-color:transparent}
.lbox-cmts{flex:1;min-height:54px;overflow-y:auto;padding:13px 16px}
.lbc{display:flex;gap:10px;margin-bottom:14px}
.lbc-av{width:30px;height:30px;border-radius:50%;display:grid;place-items:center;color:#fff;font-family:var(--font-display);font-weight:700;font-size:12px;flex:0 0 auto}
.lbc-n{font-weight:600;font-size:13px}
.lbc-n span{color:var(--text-3);font-weight:500;font-size:11px;margin-left:5px}
.lbc-x{font-size:13.5px;color:var(--text-2);line-height:1.42;margin-top:2px}
.lbc-empty{color:var(--text-3);font-size:13px;text-align:center;padding:20px}
.lbox-addc{flex:0 0 auto;display:flex;align-items:center;gap:9px;padding:10px 14px;border-top:1px solid var(--line)}
.lbox-addc .cme{width:30px;height:30px}
.lbox-addc input{flex:1;background:var(--card);border:1px solid var(--line);border-radius:11px;padding:10px 12px;font-size:14px;outline:none;color:var(--text)}
.lbox-addc input:focus{border-color:var(--ember)}
.lbox-addc button{width:38px;height:38px;border-radius:11px;background:var(--ember);color:#fff;display:grid;place-items:center;flex:0 0 auto;cursor:pointer}
.lbox-addc button svg{width:18px;height:18px}
@media(min-width:1040px){
  .lbox{flex-direction:row}
  .lbox-head{position:absolute;top:0;left:0;right:380px;z-index:2;background:linear-gradient(180deg,rgba(0,0,0,.55),transparent)}
  .lbox-img-wrap{flex:1}
  .lbox-panel{width:380px;max-height:100%;height:100%;border-radius:0;border-left:1px solid var(--line)}
}

/* ===== Pass 1 additions: wall cards, live marquee, helpers ===== */
.lvtrack{animation:pf-marquee 36s linear infinite !important;animation-play-state:running !important}
@keyframes pf-marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.lv-item{display:inline-flex;align-items:center;gap:7px}
.lv-item a{color:var(--ember-deep);font-weight:600;text-decoration:none}
.lv-item b{color:var(--text);font-weight:700}

.feed{padding:14px 14px 4px}
.pcard{background:var(--card);border:1px solid var(--line);border-radius:20px;margin-bottom:16px;overflow:hidden;box-shadow:0 1px 2px rgba(0,0,0,.04)}
.pcard__head{display:flex;align-items:center;gap:11px;padding:15px 16px 0}
.pcard__logo{width:44px;height:44px;border-radius:13px;flex:0 0 auto;background:#fff;display:grid;place-items:center;overflow:hidden;border:1px solid var(--line)}
.pcard__logo img{width:100%;height:100%;object-fit:contain;padding:13%}
.pcard__logo b{font-family:var(--font-display);font-weight:800;color:var(--text-2)}
.pcard__targ{min-width:0;flex:1}
.pcard__tlabel{font-family:var(--font-mono);font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:var(--text-3)}
.pcard__tname{font-family:var(--font-display);font-weight:700;font-size:15px;line-height:1.2;letter-spacing:-.01em;color:var(--text)}
.pcard__pill{flex:0 0 auto;display:inline-flex;align-items:center;gap:4px;font-family:var(--font-mono);font-size:9px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;padding:5px 9px;border-radius:99px}
.pcard__pill.resolved{background:color-mix(in srgb,var(--green) 14%,transparent);color:var(--green)}
.pcard__pill.response{background:var(--blue-soft);color:var(--blue)}
.pcard__pill.closed{background:color-mix(in srgb,var(--text) 8%,transparent);color:var(--text-3)}
.pcard__pill svg{width:11px;height:11px}
.pcard__body{display:block;padding:12px 16px 0;color:inherit;text-decoration:none}
.pcard__cat{display:inline-block;font-family:var(--font-mono);font-size:10px;letter-spacing:.04em;color:var(--text-3);margin-bottom:7px}
.pcard__title{font-family:var(--font-display);font-weight:800;font-size:19px;line-height:1.25;letter-spacing:-.02em;color:var(--text);margin:0 0 8px}
.pcard__ask{font-size:13.5px;line-height:1.5;color:var(--text-2);margin:0 0 12px}
.pcard__ask b{color:var(--text)}
.pcard__media{position:relative;display:block;margin:0 16px 14px;border-radius:14px;overflow:hidden;background:var(--card-2);cursor:zoom-in}
.pcard__media img{width:100%;display:block;max-height:340px;object-fit:cover}
.pcard__media .evtag{position:absolute;left:10px;top:10px;display:inline-flex;align-items:center;gap:5px;background:rgba(8,6,4,.62);color:#fff;font-family:var(--font-mono);font-size:9px;letter-spacing:.1em;text-transform:uppercase;padding:5px 9px;border-radius:8px}
.pcard__media .gcount{position:absolute;right:10px;bottom:10px;background:rgba(8,6,4,.62);color:#fff;font-size:11px;font-weight:600;padding:4px 9px;border-radius:8px}
.pcard__prog{padding:0 16px 12px}
.pcard__prog-row{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:6px}
.pcard__count{font-family:var(--font-display);font-weight:800;font-size:16px;letter-spacing:-.01em;color:var(--text)}
.pcard__goal{font-size:12px;color:var(--text-3)}
.pbar{height:7px;border-radius:99px;background:color-mix(in srgb,var(--text) 8%,transparent);overflow:hidden}
.pbar i{display:block;height:100%;border-radius:99px;background:linear-gradient(90deg,var(--ember),var(--ember-deep))}
.pbar i.resolved{background:linear-gradient(90deg,var(--green),color-mix(in srgb,var(--green) 65%,#0a8))}
.pcard__resp{margin:0 16px 14px;background:var(--blue-soft);border:1px solid color-mix(in srgb,var(--blue) 22%,transparent);border-radius:13px;padding:11px 13px}
.pcard__resp .rb{display:inline-flex;align-items:center;gap:5px;font-family:var(--font-mono);font-size:8.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--blue);font-weight:600;margin-bottom:5px}
.pcard__resp .rb svg{width:12px;height:12px}
.pcard__resp p{margin:0;font-size:13px;line-height:1.5;color:var(--text)}
.pcard__acts{display:flex;align-items:center;gap:8px;padding:6px 12px 12px;border-top:1px solid var(--line);margin-top:2px}
.pact{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:10px;border-radius:12px;background:transparent;color:var(--text-2);font-family:var(--font-ui);font-weight:600;font-size:13.5px;cursor:pointer;border:0;text-decoration:none;transition:.14s}
.pact:hover{background:var(--press)}
.pact svg{width:18px;height:18px}
.pact.back.on{color:var(--ember)}
.pact.back.on svg{fill:var(--ember)}
.pf-empty{padding:30px 18px;text-align:center;color:var(--text-3);font-size:13.5px}
.gate-skip-text{display:block;margin-top:14px;text-align:center;font-size:12.5px;color:var(--text-3)}
.gate-skip-text a{color:var(--ember);font-weight:600;cursor:pointer}
.feed-end{text-align:center;padding:8px 16px 26px}
.feed-end a{color:var(--ember);font-weight:600;font-size:14px;text-decoration:none}
.wallhd{padding:18px 16px 2px}
.wallhd h1{font-family:var(--font-display);font-weight:800;font-size:30px;letter-spacing:-.03em;margin:0}
.wallhd p{color:var(--text-2);font-size:13.5px;margin:4px 0 0}
.catbar{display:flex;gap:8px;overflow-x:auto;padding:14px 16px 6px;scrollbar-width:none}
.catbar::-webkit-scrollbar{display:none}
.catchip{flex:0 0 auto;display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border-radius:99px;background:var(--card);border:1px solid var(--line);color:var(--text-2);font-size:13px;font-weight:600;text-decoration:none;white-space:nowrap}
.catchip.on{background:var(--ember);border-color:transparent;color:#fff}

/* ============================================================
   Auth page (sign in / sign up / verify) — focused centered layout
   ============================================================ */
.authpage{min-height:100vh;min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:24px 18px;background:var(--bg);background-image:radial-gradient(circle at 1px 1px,var(--grain) 1px,transparent 0);background-size:18px 18px;position:relative}
.auth-top{position:fixed;top:16px;right:16px}
.auth-top .iconbtn{background:var(--card);border:1px solid var(--line)}
.authwrap{width:100%;max-width:412px}
.auth-card{background:var(--card);border:1px solid var(--line);border-radius:24px;padding:30px 26px;box-shadow:var(--shadow-lift,0 20px 50px -20px rgba(0,0,0,.25))}
.auth-brand{display:flex;align-items:center;gap:11px;margin-bottom:22px}
.auth-brand .mark{width:42px;height:42px}
.auth-brand .ab-name{font-family:var(--font-display);font-weight:800;font-size:19px;letter-spacing:-.02em;color:var(--text)}
.auth-brand .ab-tag{font-family:var(--font-mono);font-size:8.5px;letter-spacing:.13em;text-transform:uppercase;color:var(--text-3);margin-top:1px}
.auth-h{font-family:var(--font-display);font-weight:800;font-size:24px;letter-spacing:-.025em;color:var(--text);margin:0 0 6px}
.auth-sub{font-size:13.5px;line-height:1.5;color:var(--text-2);margin:0 0 20px}
.auth-div{display:flex;align-items:center;gap:12px;margin:18px 0;color:var(--text-3);font-size:11.5px;font-family:var(--font-mono);letter-spacing:.08em;text-transform:uppercase}
.auth-div::before,.auth-div::after{content:"";flex:1;height:1px;background:var(--line)}
.auth-field{margin-bottom:13px}
.auth-field label{display:block;font-size:12px;font-weight:600;color:var(--text-2);margin-bottom:6px}
.auth-in{width:100%;border:1.5px solid var(--line);border-radius:13px;padding:13px 14px;font-family:var(--font-ui);font-size:15px;color:var(--text);background:var(--card-2);outline:none;transition:border-color .15s,background .15s}
.auth-in:focus{border-color:var(--ember);background:var(--card)}
.auth-in::placeholder{color:var(--text-3)}
.auth-err{background:color-mix(in srgb,var(--ember) 12%,transparent);color:var(--ember-deep);font-size:12.5px;line-height:1.45;padding:10px 13px;border-radius:11px;margin-bottom:14px}
.auth-err[hidden]{display:none}
.auth-go{width:100%;background:var(--ember);color:#fff;font-family:var(--font-ui);font-weight:700;font-size:15px;padding:15px;border-radius:14px;border:0;cursor:pointer;margin-top:4px;box-shadow:0 4px 16px color-mix(in srgb,var(--ember) 32%,transparent);transition:filter .15s}
.auth-go:hover{filter:brightness(1.04)}
.auth-go:disabled{opacity:.6;cursor:default}
.auth-alt{text-align:center;font-size:13px;color:var(--text-2);margin-top:18px}
.auth-alt a{color:var(--ember);font-weight:600;cursor:pointer}
.auth-otp{width:100%;text-align:center;font-family:var(--font-mono);font-size:30px;font-weight:600;letter-spacing:.36em;padding:16px 14px 16px 24px;border:1.5px solid var(--line);border-radius:14px;background:var(--card-2);color:var(--text);outline:none}
.auth-otp:focus{border-color:var(--ember);background:var(--card)}
.auth-resend{text-align:center;font-size:12.5px;color:var(--text-3);margin-top:14px}
.auth-resend a{color:var(--ember);font-weight:600;cursor:pointer}
.auth-resend a.dim{color:var(--text-3);cursor:default;font-weight:500}
.auth-back{display:inline-flex;align-items:center;gap:5px;font-size:12.5px;color:var(--text-3);cursor:pointer;margin-bottom:14px;background:none;border:0;padding:0}
.auth-back svg{width:14px;height:14px}
.auth-mailto{font-weight:700;color:var(--text)}
.auth-foot{text-align:center;font-size:11.5px;color:var(--text-3);margin-top:18px;line-height:1.5}
.auth-foot a{color:var(--text-2)}
.auth-step[hidden]{display:none}

/* gate: secondary email button */
.g-email{margin-top:10px}
.g-email svg{width:20px;height:20px;color:var(--text-2)}

/* ============================================================
   Pass 2 — case page: real-data shell + bits not in the mock
   (uses the preview's existing case classes; adds only what the
    mock didn't need — a standalone page frame, story prose,
    timeline gutter, minimal creator controls)
   ============================================================ */
.caseview{display:flex;flex-direction:column;height:100vh;height:100dvh;background:var(--bg);background-image:radial-gradient(circle at 1px 1px,var(--grain) 1px,transparent 0);background-size:18px 18px;max-width:100%;margin:0 auto}
.cd-prose{font-size:14px;line-height:1.6;color:var(--text-2)}
.cd-prose p{margin:0 0 10px}.cd-prose p:last-child{margin-bottom:0}
.cd-prose a{color:var(--ember-deep);text-decoration:underline}
.cd-prose strong,.cd-prose b{color:var(--text);font-weight:700}
.cd-prose ul,.cd-prose ol{margin:0 0 10px;padding-left:18px}.cd-prose li{margin-bottom:4px}
.cd-timeline{position:relative;padding:0 16px 4px 42px}
.cd-timeline::before{content:"";position:absolute;left:22px;top:7px;bottom:20px;width:2px;background:var(--line);border-radius:2px}
.cmgmt{margin:0 16px;padding:13px 14px;border:1px dashed var(--line);border-radius:14px;background:var(--card-2)}
.cmgmt-lab{font-family:var(--font-mono);font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:var(--text-3);margin-bottom:9px}
.cmgmt-q{font-size:13.5px;color:var(--text);font-weight:600;margin:0 0 10px}
.cmgmt-btns{display:flex;gap:8px;flex-wrap:wrap}
.cmgmt-btn{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;font-weight:600;font-family:var(--font-ui);padding:9px 13px;border-radius:11px;border:1.5px solid var(--line);background:var(--card);color:var(--text-2);cursor:pointer}
.cmgmt-btn svg{width:15px;height:15px}
.cmgmt-btn.ok{border-color:color-mix(in srgb,var(--green) 45%,transparent);color:var(--green)}
.cmgmt-btn.danger{border-color:color-mix(in srgb,var(--ember) 35%,transparent);color:var(--ember-deep)}
.cmgmt-btn:disabled{opacity:.5}
.cmgmt-done{font-weight:700;font-size:13.5px}
.cmgmt-done.ok{color:var(--green)}.cmgmt-done.no{color:var(--text-2)}
.cd-loading{padding:14px 16px;color:var(--text-3);font-size:13px}
.cmt-actions{position:relative}
.cmt-del{font-size:11px;color:var(--text-3);font-family:var(--font-mono);background:none;border:0;cursor:pointer}
.cmt-replybox{display:flex;align-items:center;gap:8px;margin:8px 0 4px 37px}
.cmt-replybox input{flex:1;background:var(--card);border:1px solid var(--line);border-radius:999px;padding:8px 13px;font-size:13px;outline:none}
.cmt-replybox input:focus{border-color:var(--ember)}
.cmt-replybox .send{width:30px;height:30px;border-radius:50%;background:var(--ember);color:#fff;display:grid;place-items:center;flex:0 0 auto;border:0;cursor:pointer}
.cmt-replybox .send svg{width:15px;height:15px}
.cmt .replies{margin-top:11px;padding-left:37px;display:flex;flex-direction:column;gap:11px}
.bigback.disabled{opacity:.55;pointer-events:none}
.cd-signin-note{font-size:12.5px;color:var(--text-3);text-align:center;padding:10px 14px}
.cd-signin-note a{color:var(--ember);font-weight:600}
@media(min-width:1040px){
  .caseview{max-width:600px;height:92vh;margin:26px auto;border:1px solid var(--line);border-radius:28px;overflow:hidden;box-shadow:var(--shadow-lift,0 24px 60px -24px rgba(0,0,0,.3))}
}

/* ============================================================
   Wall card: tracker rail + backer faces (crowd) + video
   (brings the feed card up to the confirmed preview)
   ============================================================ */
.faces .fav img{width:100%;height:100%;border-radius:50%;object-fit:cover;display:block}
.pcard__track .tracker{margin:0 16px 12px}
.pcard .crowd{padding:2px 16px 16px;align-items:center}
.pcard .crowd .faces{flex:0 0 auto}
.crowd-prog{flex:1;min-width:0}
.crowd-prog .pbar{margin:0}
.crowd-prog .cnt{margin-top:6px}
.pcard__media--video{cursor:default;aspect-ratio:16/10;background:#000;display:block;position:relative;margin:0 16px 14px;border-radius:14px;overflow:hidden}
.pcard__media--video video{width:100%;height:100%;object-fit:contain;background:#000;display:block;max-height:340px}
.cd-crowd{display:flex;align-items:center;gap:11px;padding:0 16px 14px}
.cd-crowd .cnt{margin-top:0}

/* ============================================================
   Wall card (preview .card) extras: avatar photo, card media,
   comment states, New/Rising toggle, no-underline nav
   ============================================================ */
.av{overflow:hidden}
.av img{width:100%;height:100%;object-fit:cover;border-radius:50%;display:block}
.cmedia{position:relative;display:block;margin:10px 0 2px;border-radius:14px;overflow:hidden;background:var(--card-2);cursor:zoom-in}
.cmedia img{width:100%;display:block;max-height:340px;object-fit:cover}
.cmedia--video{cursor:default;aspect-ratio:16/10;background:#000}
.cmedia--video video{width:100%;height:100%;object-fit:contain;background:#000;display:block;max-height:340px}
.cmedia .evtag{position:absolute;left:10px;top:10px;display:inline-flex;align-items:center;gap:5px;background:rgba(8,6,4,.62);color:#fff;font-family:var(--font-mono);font-size:9px;letter-spacing:.1em;text-transform:uppercase;padding:5px 9px;border-radius:8px}
.cmedia .gcount{position:absolute;right:10px;bottom:10px;background:rgba(8,6,4,.62);color:#fff;font-size:11px;font-weight:600;padding:4px 9px;border-radius:8px}
.cmts-loading,.cmts-empty{padding:12px 4px;color:var(--text-3);font-size:13px}
.wallsort{display:flex;gap:8px;padding:0 16px 12px}
.wsort{flex:0 0 auto;padding:7px 16px;border-radius:999px;border:1px solid var(--line);background:var(--card);color:var(--text-2);font-size:13px;font-weight:600;text-decoration:none;font-family:var(--font-ui);cursor:pointer}
.wsort.on{background:var(--ember);border-color:var(--ember);color:#fff}
.db,.snav,.side-speak,.side-prof,.side-brand,.brand,.catchip,.wsort,.more,.ttl,.dock a,.cbody a{text-decoration:none}

/* inline card comments extras */
.cmts-loading,.cmts-empty{padding:14px 4px;color:var(--text-3);font-size:13px;text-align:center}
.cmts-empty{text-align:left}
.creplies{margin-top:11px;padding-left:37px;display:flex;flex-direction:column;gap:11px}
.cmts-n{font-weight:600;color:var(--ember-deep);font-family:var(--font-mono);font-size:12px}
.pcard__acts [data-cmts-toggle].on,.pact[aria-expanded="true"]{color:var(--ember)}
