/* Pulse — app preview styles. White / red / black, outlined editorial. */
:root{
  --bg:#ffffff; --ink:#121212; --ink2:#454545; --muted:#7a7a7a;
  --red:#e5231b; --line:rgba(18,18,18,.13);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  font-family:'Space Grotesk',system-ui,sans-serif;color:var(--ink);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;min-height:100vh}
.head{font-family:'Fraunces',Georgia,serif}
.mono{font-family:'Geist Mono',ui-monospace,monospace}

/* shell — flex row so a sidebar can grow in on wide screens later. */
#shell{display:flex;min-height:100vh;min-height:100dvh;width:100%}
#rail{display:none}
/* main app column — fills the remaining viewport at every width. */
#app{flex:1;min-width:0;background:var(--bg);position:relative;display:flex;flex-direction:column;
  min-height:100vh;min-height:100dvh;overflow:hidden}

/* Wide screens: cap an editorial reading column so lines don't sprawl across a
   1080p+ monitor. Top/bottom bars stay full-bleed, like a normal webapp. */
@media (min-width:760px){
  .feed,.read,.chat,.scroll,.up-pad,.pf-pad{
    max-width:720px;margin-left:auto;margin-right:auto;width:100%}
}
/* The simulated iOS statusbar belongs in the phone mock; real desktop browsers
   already provide a chrome bar, so hide it everywhere except actual mobile.
   !important so it wins over the later `.statusbar{display:flex}` definition. */
@media (min-width:500px){
  .statusbar{display:none!important}
}

/* shared chrome */
.statusbar{height:44px;flex:none;display:flex;align-items:center;justify-content:space-between;padding:0 22px;font-size:13px;font-weight:600}
.statusbar .r{display:flex;gap:7px;align-items:center}
.appbar{height:54px;flex:none;display:flex;align-items:center;justify-content:space-between;padding:0 18px;border-bottom:2px solid var(--ink)}
.appbar .l{display:flex;align-items:center;gap:9px}
.appbar b{font-size:19px;letter-spacing:-.02em}
.appbar .r{display:flex;align-items:center;gap:11px}
.mark{width:25px;height:25px;border-radius:7px;background:var(--red);border:2px solid var(--ink);display:flex;align-items:center;justify-content:center}
.mark i{width:8px;height:8px;border-radius:50%;background:#fff;display:block}
.mark,.mk{background:transparent!important;border:none!important;box-shadow:none!important;overflow:visible}
.mark>svg,.mk>svg{width:100%;height:100%;display:block}
.pill{font-family:'Geist Mono',monospace;font-size:10px;font-weight:600;letter-spacing:.12em;border:2px solid var(--ink);border-radius:20px;padding:3px 9px;cursor:pointer}
.pill.prem{background:var(--ink);color:#fff}
.ico{width:24px;height:24px;color:var(--ink);cursor:pointer}
.searchwrap{flex:1;display:flex;align-items:center;gap:9px;border:2px solid var(--ink);border-radius:11px;height:40px;padding:0 13px;margin-left:6px}
.searchwrap svg{width:18px;height:18px;color:var(--muted);flex:none}
.searchwrap input{flex:1;border:none;background:transparent;font-family:inherit;font-size:14px;font-weight:500;color:var(--ink);outline:none;min-width:0}
.searchwrap input::placeholder{color:var(--muted)}
.bar{height:52px;flex:none;display:flex;align-items:center;justify-content:space-between;padding:0 16px;border-bottom:2px solid var(--ink)}
.bar b{font-size:16px}
.bar .r{display:flex;align-items:center;gap:2px}
.ibtn{width:38px;height:38px;display:flex;align-items:center;justify-content:center;color:var(--ink);cursor:pointer}
.ibtn svg{width:22px;height:22px}

/* nav */
.nav{height:72px;flex:none;background:#fff;border-top:2px solid var(--ink);display:flex;align-items:flex-start;padding:11px 4px 0}
.nav a{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;font-size:10px;font-weight:600;color:var(--ink);opacity:.42;cursor:pointer}
.nav a svg{width:22px;height:22px}
.nav a.on{color:var(--red);opacity:1}

/* segmented */
.seg{display:flex;border:2px solid var(--ink);border-radius:11px;overflow:hidden;height:42px;flex:none}
.seg span{flex:1;display:flex;align-items:center;justify-content:center;gap:7px;font-size:13.5px;font-weight:600;border-right:2px solid var(--ink);cursor:pointer}
.seg span:last-child{border-right:none}
.seg .on{background:var(--red);color:#fff}
.seg .tag{font-family:'Geist Mono',monospace;font-size:8.5px;font-weight:700;letter-spacing:.06em;background:#fff;color:var(--red);border-radius:4px;padding:2px 5px}
.seg .on .tag{background:#fff}

/* onboarding */
.ob-top{flex:none;padding:4px 22px 12px}
.brand{display:flex;align-items:center;gap:9px;margin-bottom:18px}
.brand .mark{width:28px;height:28px;border-radius:8px;box-shadow:2px 2px 0 var(--ink)}
.brand .mark i{width:9px;height:9px}
.brand b{font-size:20px;letter-spacing:-.02em}
.step{font-family:'Geist Mono',monospace;font-size:11px;color:var(--muted);letter-spacing:.16em;text-transform:uppercase;margin-bottom:11px}
.ob-top h1{font-size:32px;line-height:1.02;letter-spacing:-.025em;font-weight:600;margin-bottom:9px}
.ob-top h1 em{font-style:italic;color:var(--red)}
.sub{font-size:14px;color:var(--ink2);line-height:1.42;max-width:300px}
.scroll{flex:1;overflow-y:auto;scrollbar-width:none}
.scroll::-webkit-scrollbar{display:none}
.grid{display:grid;grid-template-columns:1fr 1fr;gap:13px;padding:6px 22px 16px}
.tile{position:relative;border:2px solid var(--ink);border-radius:13px;background:#fff;aspect-ratio:1/.82;padding:13px;display:flex;flex-direction:column;justify-content:space-between;cursor:pointer;transition:transform .08s}
.tile:active{transform:scale(.98)}
.tile .ix{font-family:'Geist Mono',monospace;font-size:11px;color:var(--muted)}
.tile .nm{font-size:18px;font-weight:600;letter-spacing:-.015em;line-height:1.05}
.tile .c{font-family:'Geist Mono',monospace;font-size:10.5px;color:var(--muted);margin-top:3px}
.tile .chk{position:absolute;top:11px;right:11px;width:23px;height:23px;border-radius:50%;border:2px solid var(--ink);background:#fff;display:flex;align-items:center;justify-content:center}
.tile .chk svg{opacity:0;width:12px;height:12px}
.tile.sel{background:var(--red);color:#fff;box-shadow:3px 3px 0 var(--ink)}
.tile.sel .ix,.tile.sel .c{color:rgba(255,255,255,.85)}
.tile.sel .chk{background:#fff}
.tile.sel .chk svg{opacity:1}
.tile.sel .chk path{stroke:var(--red)}
.foot{flex:none;position:relative;padding:14px 22px 24px;background:#fff}
.foot::before{content:"";position:absolute;left:0;right:0;top:-26px;height:26px;background:linear-gradient(180deg,rgba(255,255,255,0),#fff);pointer-events:none}
.cta{height:54px;border-radius:14px;background:var(--red);color:#fff;border:2px solid var(--ink);display:flex;align-items:center;justify-content:center;gap:10px;font-size:16px;font-weight:600;box-shadow:4px 4px 0 var(--ink);cursor:pointer}
.cta.disabled{background:#fff;color:var(--muted);box-shadow:none;cursor:default}
.cta .n{background:#fff;color:var(--ink);border-radius:20px;padding:1px 10px;font-size:13px;font-weight:600;font-family:'Geist Mono',monospace;border:2px solid var(--ink)}
.cta.disabled .n{border-color:var(--muted);color:var(--muted)}
.cta svg{width:17px;height:17px}
.hint{text-align:center;font-size:12px;color:var(--muted);margin-top:11px}

/* feed */
.subhd{padding:13px 18px 11px;flex:none}
.feed{flex:1;overflow-y:auto;scrollbar-width:none;padding:0 18px 20px}
.feed::-webkit-scrollbar{display:none}
.reorder{font-family:'Geist Mono',monospace;font-size:10px;color:var(--muted);display:flex;align-items:center;gap:6px;margin:2px 0 12px}
.reorder .d{width:5px;height:5px;border-radius:50%;background:var(--red)}
.kick{font-family:'Geist Mono',monospace;font-size:10.5px;font-weight:600;letter-spacing:.11em;text-transform:uppercase;color:var(--red);display:flex;align-items:center;gap:8px}
.hero{padding:2px 0 14px;cursor:pointer}
.himg{height:198px;border:2px solid var(--ink);border-radius:14px;box-shadow:3px 3px 0 var(--ink);overflow:hidden;background:#ededed}
.himg img{width:100%;height:100%;object-fit:cover;display:block;filter:grayscale(1) contrast(1.04)}
.hero h2{font-size:24px;line-height:1.08;letter-spacing:-.02em;font-weight:600;margin:13px 0 0}
.ailine{display:flex;gap:8px;align-items:flex-start;margin-top:9px;font-size:12px;line-height:1.4;color:var(--ink2)}
.ailine .t{flex:none;font-family:'Geist Mono',monospace;font-size:8px;font-weight:700;letter-spacing:.08em;background:var(--red);color:#fff;border-radius:4px;padding:2px 5px;margin-top:1px}
.meta{display:flex;align-items:center;justify-content:space-between;margin-top:12px}
.src{font-family:'Geist Mono',monospace;font-size:11px;color:var(--muted);display:flex;align-items:center;gap:6px}
.src b{color:var(--ink);font-weight:600}
.src .srclink{color:var(--ink);font-weight:600;text-decoration:none;border-bottom:1px solid rgba(18,18,18,.32)}
.src .srclink:hover{color:var(--red);border-color:var(--red)}
.acts{display:flex;align-items:center;gap:15px;color:var(--ink)}
.acts svg{width:18px;height:18px;display:block;cursor:pointer}
.acts .on{color:var(--red)}
.dv{border-top:1px solid var(--line)}
.item{display:flex;gap:14px;padding:15px 0;cursor:pointer}
.item .tx{flex:1;min-width:0}
.item h3{font-size:16px;line-height:1.14;letter-spacing:-.01em;font-weight:600;margin-top:6px}
.item .kick{margin-bottom:0}
.item .meta{margin-top:9px}
.thumb{width:76px;height:76px;flex:none;border:2px solid var(--ink);border-radius:11px;overflow:hidden;background:#ededed;margin-top:2px}
.thumb img{width:100%;height:100%;object-fit:cover;display:block;filter:grayscale(1) contrast(1.04)}
.empty{text-align:center;color:var(--muted);font-size:13px;padding:60px 30px;line-height:1.5}

/* promo + briefing entry (inverted) */
.promo{margin:16px 0;border:2px solid var(--ink);border-radius:16px;background:var(--ink);color:#fff;padding:18px;box-shadow:4px 4px 0 var(--red);cursor:pointer}
.promo .pk{font-family:'Geist Mono',monospace;font-size:10px;letter-spacing:.13em;text-transform:uppercase;color:var(--red);font-weight:600;margin-bottom:9px;display:flex;align-items:center;gap:7px}
.promo h4{font-size:20px;line-height:1.1;margin-bottom:7px;letter-spacing:-.01em}
.promo p{font-size:12.5px;color:rgba(255,255,255,.68);line-height:1.45;margin-bottom:15px;max-width:250px}
.promo .go{display:inline-flex;align-items:center;gap:9px;background:var(--red);color:#fff;border-radius:11px;padding:11px 17px;font-size:14px;font-weight:600}
.promo .go svg{width:15px;height:15px}
.brief{margin:2px 0 18px;border:2px solid var(--ink);border-radius:15px;background:var(--ink);color:#fff;padding:14px 15px;box-shadow:3px 3px 0 var(--red);display:flex;align-items:center;gap:13px;cursor:pointer}
.brief .bi{width:44px;height:44px;border-radius:12px;border:2px solid rgba(255,255,255,.22);display:flex;align-items:center;justify-content:center;flex:none;color:#fff}
.brief .bi svg{width:23px;height:23px}
.brief .tx{flex:1;min-width:0}
.brief .k{font-family:'Geist Mono',monospace;font-size:9px;letter-spacing:.13em;text-transform:uppercase;color:var(--red);font-weight:600;margin-bottom:3px}
.brief h4{font-size:16px;letter-spacing:-.01em;line-height:1.08}
.brief .m{font-family:'Geist Mono',monospace;font-size:10px;color:rgba(255,255,255,.58);margin-top:4px}
.brief .arr{width:31px;height:31px;border-radius:50%;background:var(--red);display:flex;align-items:center;justify-content:center;flex:none}
.brief .arr svg{width:15px;height:15px}

/* reader */
.read{flex:1;overflow-y:auto;scrollbar-width:none;padding:18px 22px}
.read::-webkit-scrollbar{display:none}
.read h1{font-size:29px;line-height:1.06;letter-spacing:-.02em;font-weight:600;margin:9px 0 13px}
.byl{display:flex;align-items:center;gap:8px;font-family:'Geist Mono',monospace;font-size:11px;color:var(--muted);margin-bottom:16px}
.byl b{color:var(--ink);font-weight:600}
.rimg{height:210px;border:2px solid var(--ink);border-radius:14px;box-shadow:3px 3px 0 var(--ink);overflow:hidden;background:#ededed}
.rimg img{width:100%;height:100%;object-fit:cover;display:block;filter:grayscale(1) contrast(1.04)}
.cap{font-family:'Geist Mono',monospace;font-size:10px;color:var(--muted);margin-top:7px}
.ai{margin:20px 0 6px;border:2px solid var(--ink);border-radius:15px;background:var(--ink);color:#fff;padding:17px;box-shadow:3px 3px 0 var(--red)}
.ai .h{display:flex;align-items:center;gap:9px;margin-bottom:13px}
.ai .tag{font-family:'Geist Mono',monospace;font-size:9px;letter-spacing:.13em;text-transform:uppercase;color:#fff;background:var(--red);border-radius:5px;padding:3px 7px;font-weight:600}
.ai .h b{font-size:13.5px;font-weight:600}
.ai ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.ai li{display:flex;gap:10px;font-size:13px;line-height:1.42;color:rgba(255,255,255,.92)}
.ai li::before{content:"";flex:none;width:7px;height:7px;border-radius:2px;background:var(--red);margin-top:5px}
.ai .why{margin-top:14px;padding-top:12px;border-top:1px solid rgba(255,255,255,.22);font-size:11px;color:rgba(255,255,255,.6);line-height:1.4}
.ai .why em{color:#fff;font-style:normal;font-weight:600}
.ai.locked{cursor:pointer}
.ai.locked .blur{filter:blur(4px);opacity:.5;user-select:none}
.ai .unlock{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:14px;background:var(--red);border-radius:10px;padding:10px;font-size:13px;font-weight:600}
.body{margin-top:18px}
.body p{font-family:'Fraunces',Georgia,serif;font-size:16.5px;line-height:1.62;color:#1b1b1b;margin-bottom:15px}
.body p:first-child::first-letter{font-size:50px;float:left;line-height:.82;font-weight:600;padding:4px 9px 0 0;color:var(--red)}
.readmore{display:inline-flex;align-items:center;gap:6px;margin-top:8px;font-family:'Geist Mono',monospace;font-size:12px;font-weight:600;color:var(--red);border-bottom:2px solid var(--red);padding-bottom:1px}
.loadmore{font-family:'Geist Mono',monospace;font-size:12px;color:var(--muted);margin:8px 0 2px;display:flex;align-items:center;gap:9px}
.loadmore::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--red);animation:livePulse 1s ease-in-out infinite}
.abar{height:60px;flex:none;border-top:2px solid var(--ink);display:flex;align-items:center;justify-content:space-between;padding:0 20px;background:#fff}
.abar .grp{display:flex;align-items:center;gap:20px;color:var(--ink)}
.abar .a{display:flex;align-items:center;gap:6px;font-size:12.5px;font-weight:600;font-family:'Geist Mono',monospace;cursor:pointer}
.abar svg{width:21px;height:21px;display:block;cursor:pointer}
.abar .on{color:var(--red)}

/* briefing */
.date{font-family:'Geist Mono',monospace;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:8px}
.br-pad{padding:20px 22px 18px}
.br-pad h1{font-size:34px;line-height:1.0;letter-spacing:-.025em;font-weight:600;margin-bottom:11px}
.br-pad h1 em{font-style:italic;color:var(--red)}
.gen{display:inline-flex;align-items:center;gap:7px;font-family:'Geist Mono',monospace;font-size:11px;color:var(--ink2)}
.gen .tag{font-size:8.5px;letter-spacing:.12em;text-transform:uppercase;color:#fff;background:var(--red);border-radius:4px;padding:2px 6px;font-weight:700}
.play{display:flex;align-items:center;gap:12px;border:2px solid var(--ink);border-radius:14px;padding:11px 14px;margin-top:16px;box-shadow:3px 3px 0 var(--ink);cursor:pointer}
.play .pi{width:36px;height:36px;border-radius:50%;background:var(--red);display:flex;align-items:center;justify-content:center;flex:none}
.play .pi svg{width:14px;height:14px}
.play .pt b{font-size:14px;display:block}
.play .pt span{font-family:'Geist Mono',monospace;font-size:10px;color:var(--muted)}
.wave{margin-left:auto;display:flex;gap:3px;align-items:center;height:24px}
.wave i{width:3px;background:var(--red);border-radius:2px;display:block}
.big{margin:20px 0 2px;border:2px solid var(--ink);border-radius:15px;background:var(--ink);color:#fff;padding:17px;box-shadow:3px 3px 0 var(--red)}
.big .k{font-family:'Geist Mono',monospace;font-size:9px;letter-spacing:.13em;text-transform:uppercase;color:var(--red);font-weight:700;margin-bottom:9px}
.big p{font-size:14.5px;line-height:1.5;color:#fff}
.bitem{display:flex;gap:14px;padding:18px 0;border-top:1px solid var(--line)}
.bitem:first-of-type{border-top:none;padding-top:22px}
.bn{font-size:23px;font-weight:600;color:var(--red);flex:none;line-height:1;width:28px;letter-spacing:-.02em}
.bc{flex:1;min-width:0}
.bc h3{font-size:18px;line-height:1.14;letter-spacing:-.01em;font-weight:600;margin-bottom:7px;cursor:pointer}
.bc p{font-size:13px;line-height:1.5;color:var(--ink2);margin-bottom:11px}
.chips{display:flex;gap:7px;flex-wrap:wrap}
.chip{font-family:'Geist Mono',monospace;font-size:9.5px;border:1.5px solid var(--ink);border-radius:20px;padding:3px 9px;color:var(--ink);font-weight:500}
.end{font-family:'Geist Mono',monospace;font-size:11px;color:var(--muted);text-align:center;padding:18px 0 4px;border-top:1px solid var(--line);margin-top:8px}

/* chat */
.chat{flex:1;overflow-y:auto;scrollbar-width:none;padding:18px}
.chat::-webkit-scrollbar{display:none}
.msg{margin-bottom:16px;max-width:85%}
.msg.ai{margin-right:auto}
.msg.me{margin-left:auto}
.lbl{display:flex;align-items:center;gap:7px;margin-bottom:7px;font-family:'Geist Mono',monospace;font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:var(--red);font-weight:700}
.lbl .d{width:7px;height:7px;border-radius:50%;background:var(--red)}
.bub{border:2px solid var(--ink);border-radius:16px;padding:12px 14px;font-size:14px;line-height:1.46}
.ai .bub{background:#fff;border-bottom-left-radius:5px}
.me .bub{background:var(--red);color:#fff;border-bottom-right-radius:5px;box-shadow:2px 2px 0 var(--ink)}
.cites{display:flex;gap:6px;flex-wrap:wrap;margin-top:11px;padding-top:10px;border-top:1px solid var(--line)}
.cite{font-family:'Geist Mono',monospace;font-size:9px;border:1.5px solid var(--ink);border-radius:20px;padding:2px 8px;display:flex;align-items:center;gap:5px}
.cite .n{color:var(--red);font-weight:700}
.sugttl{font-family:'Geist Mono',monospace;font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin:4px 0 10px}
.sugs{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:6px}
.sug{font-size:12.5px;border:2px solid var(--ink);border-radius:20px;padding:8px 13px;font-weight:500;background:#fff;cursor:pointer}
.inbar{flex:none;border-top:2px solid var(--ink);padding:12px 16px 18px;display:flex;align-items:center;gap:10px;background:#fff}
.inbar input{flex:1;border:2px solid var(--ink);border-radius:24px;height:46px;padding:0 17px;font-family:inherit;font-size:13.5px;color:var(--ink);outline:none;background:#fff}
.inbar input::placeholder{color:var(--muted)}
.send{width:46px;height:46px;border-radius:50%;background:var(--red);border:2px solid var(--ink);display:flex;align-items:center;justify-content:center;flex:none;box-shadow:2px 2px 0 var(--ink);cursor:pointer}
.send svg{width:18px;height:18px}

/* upgrade */
.up-pad{flex:1;overflow-y:auto;scrollbar-width:none;padding:2px 22px 12px}
.up-pad::-webkit-scrollbar{display:none}
.up-kick{font-family:'Geist Mono',monospace;font-size:10.5px;font-weight:700;letter-spacing:.13em;text-transform:uppercase;color:var(--red);margin-bottom:9px;display:flex;align-items:center;gap:8px}
.mk{width:22px;height:22px;border-radius:6px;background:var(--red);border:2px solid var(--ink);display:flex;align-items:center;justify-content:center}
.mk i{width:7px;height:7px;border-radius:50%;background:#fff;display:block}
.up-pad h1{font-size:33px;line-height:1.02;letter-spacing:-.025em;font-weight:600;margin-bottom:8px}
.up-pad h1 em{font-style:italic;color:var(--red)}
.lead{font-size:14px;color:var(--ink2);line-height:1.45;max-width:300px}
.feat{margin:18px 0 0;border:2px solid var(--ink);border-radius:16px;background:var(--ink);color:#fff;padding:6px 16px;box-shadow:4px 4px 0 var(--red)}
.feat .row{display:flex;align-items:flex-start;gap:12px;padding:13px 0;border-bottom:1px solid rgba(255,255,255,.13)}
.feat .row:last-child{border-bottom:none}
.ck{width:23px;height:23px;border-radius:50%;background:var(--red);flex:none;display:flex;align-items:center;justify-content:center;margin-top:1px}
.ck svg{width:12px;height:12px}
.ft b{font-size:14.5px;display:block;letter-spacing:-.01em}
.ft span{font-size:11.5px;color:rgba(255,255,255,.6);line-height:1.35;display:block;margin-top:2px}
.price{display:flex;align-items:baseline;gap:9px;margin:18px 0 2px}
.amt{font-size:42px;font-weight:600;letter-spacing:-.03em;line-height:1}
.per{font-family:'Geist Mono',monospace;font-size:12px;color:var(--muted)}
.was{font-family:'Geist Mono',monospace;font-size:13px;color:var(--muted);text-decoration:line-through}
.note{font-family:'Geist Mono',monospace;font-size:11px;color:var(--ink2)}
.fine{text-align:center;font-size:11px;color:var(--muted);margin-top:11px;line-height:1.4}
.bar .rs{font-family:'Geist Mono',monospace;font-size:11px;color:var(--muted);cursor:pointer}

/* profile */
.pf-pad{flex:1;overflow-y:auto;scrollbar-width:none;padding:20px 22px 18px}
.pf-pad::-webkit-scrollbar{display:none}
.phead{display:flex;align-items:center;gap:15px}
.av{width:64px;height:64px;border-radius:50%;border:2px solid var(--ink);overflow:hidden;flex:none;background:#ededed;box-shadow:3px 3px 0 var(--ink)}
.av img{width:100%;height:100%;object-fit:cover;display:block;filter:grayscale(1)}
.pinfo h2{font-size:22px;letter-spacing:-.015em;line-height:1}
.pinfo .h{font-family:'Geist Mono',monospace;font-size:11.5px;color:var(--muted);margin:5px 0 7px}
.ppill{font-family:'Geist Mono',monospace;font-size:9.5px;font-weight:700;letter-spacing:.1em;background:var(--ink);color:#fff;border-radius:20px;padding:3px 9px}
.ppill.free{background:#fff;color:var(--ink);border:2px solid var(--ink);padding:2px 8px}
.stats{display:flex;border:2px solid var(--ink);border-radius:14px;margin-top:18px;overflow:hidden}
.stat{flex:1;padding:13px 6px;text-align:center;border-right:2px solid var(--ink)}
.stat:last-child{border-right:none}
.stat b{font-size:23px;display:block;line-height:1;letter-spacing:-.02em}
.stat span{font-family:'Geist Mono',monospace;font-size:9px;text-transform:uppercase;letter-spacing:.07em;color:var(--muted);margin-top:6px;display:block}
.sec{font-family:'Geist Mono',monospace;font-size:10px;letter-spacing:.13em;text-transform:uppercase;color:var(--muted);margin:26px 0 0}
.subnote{font-size:11.5px;color:var(--muted);margin-top:5px;line-height:1.4}
.pf-pad .seg{margin-top:12px}
.tchips{display:flex;flex-wrap:wrap;gap:9px;margin-top:13px}
.tchip{display:flex;align-items:center;gap:8px;border:2px solid var(--ink);border-radius:20px;padding:7px 12px;font-size:13px;font-weight:600}
.tchip .x{display:flex;opacity:.45;cursor:pointer}
.tchip .x svg{width:12px;height:12px}
.tchip.add{border-style:dashed;color:var(--red);border-color:var(--red);cursor:pointer}
.trow{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:15px 0;border-top:1px solid var(--line)}
.sec + .trow{border-top:none;padding-top:14px}
.tt b{font-size:14.5px;display:block;letter-spacing:-.005em}
.tt span{font-size:11.5px;color:var(--muted);display:block;margin-top:2px}
.sw{width:48px;height:28px;border-radius:20px;border:2px solid var(--ink);background:#fff;position:relative;flex:none;cursor:pointer}
.sw i{position:absolute;top:2px;left:2px;width:20px;height:20px;border-radius:50%;background:var(--ink);display:block;transition:left .16s}
.sw.on{background:var(--red)}
.sw.on i{left:22px;background:#fff}

/* toast */
.toast{position:fixed;left:50%;bottom:92px;transform:translateX(-50%);background:var(--ink);color:#fff;font-size:12.5px;font-weight:600;padding:10px 16px;border-radius:24px;box-shadow:2px 2px 0 var(--red);opacity:0;transition:opacity .2s,transform .2s;pointer-events:none;z-index:50;white-space:nowrap}
.toast.show{opacity:1;transform:translateX(-50%) translateY(-4px)}

/* ---------- micro-animations ---------- */
@keyframes screenIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
@keyframes riseIn{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
@keyframes bubbleIn{from{opacity:0;transform:translateY(8px) scale(.98)}to{opacity:1;transform:none}}
@keyframes pop{0%{transform:scale(1)}40%{transform:scale(1.3)}70%{transform:scale(.93)}100%{transform:scale(1)}}
@keyframes livePulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.3);opacity:.6}}
@keyframes wavePulse{0%,100%{transform:scaleY(.4)}50%{transform:scaleY(1)}}
@keyframes dotBlink{0%,80%,100%{opacity:.25;transform:translateY(0)}40%{opacity:1;transform:translateY(-3px)}}
/* screen entry (only on route change, gated by .anim) */
#app.anim .feed,#app.anim .read,#app.anim .br-pad,#app.anim .pf-pad,#app.anim .up-pad,#app.anim .chat,#app.anim .scroll{animation:screenIn .34s ease both}
#app.anim .feed .hero,#app.anim .feed .item,#app.anim .feed .brief,#app.anim .feed .promo{animation:riseIn .46s cubic-bezier(.22,.61,.36,1) both;animation-delay:var(--d,0ms)}
#app.anim .bitem,#app.anim .feat .row{animation:riseIn .42s ease both;animation-delay:var(--d,0ms)}
#app.anim .nav a.on svg{animation:pop .44s ease}
/* press feedback */
.cta,.sug,.send,.pill,.tchip,.play,.brief,.promo,.seg span,.ibtn,.arr{transition:transform .09s ease,box-shadow .09s ease}
.cta:active,.sug:active,.send:active,.pill:active,.tchip:active,.play:active,.brief:active,.promo:active,.seg span:active{transform:scale(.97)}
.cta:active{box-shadow:1px 1px 0 var(--ink)}
.tile:active{transform:scale(.96)}
.item,.hero,.bc h3{transition:opacity .12s ease}
.item:active,.hero:active,.bc h3:active{opacity:.55}
.nav a svg{transition:transform .12s ease}
.nav a:active svg{transform:scale(.82)}
/* like / save */
[data-act="like"].on,[data-act="save"].on{color:var(--red)}
.acts svg,.abar svg,.bar .r svg{transition:transform .1s ease}
.pop{animation:pop .34s cubic-bezier(.34,1.56,.64,1)}
/* live brand dot — it's called Pulse */
.mark i{animation:livePulse 2.6s ease-in-out infinite}
/* briefing waveform */
.wave i{transform-origin:bottom;transform:scaleY(.5)}
.play.playing .wave i{animation:wavePulse 1s ease-in-out infinite}
.wave i:nth-child(2){animation-delay:.1s}.wave i:nth-child(3){animation-delay:.22s}.wave i:nth-child(4){animation-delay:.32s}.wave i:nth-child(5){animation-delay:.16s}.wave i:nth-child(6){animation-delay:.26s}.wave i:nth-child(7){animation-delay:.06s}
/* chat */
.chat .msg:last-child{animation:bubbleIn .3s ease both}
.typing{display:flex!important;gap:5px;align-items:center;min-height:21px}
.typing span{width:7px;height:7px;border-radius:50%;background:var(--muted);display:block;animation:dotBlink 1.1s infinite}
.typing span:nth-child(2){animation-delay:.15s}.typing span:nth-child(3){animation-delay:.3s}

/* ---------- hover (pointer devices only) ---------- */
@media (hover:hover){
  .item h3,.hero h2,.bc h3,.nav a,.ico,.cta svg,.brief .arr,.promo .go,.chip,.acts svg,.abar svg,.bar .r svg{transition:all .16s ease}
  .himg img,.rimg img,.thumb img{transition:transform .4s ease}
  .item:hover h3,.hero:hover h2,.bc h3:hover{color:var(--red)}
  .hero:hover .himg img,.item:hover .thumb img{transform:scale(1.06)}
  .tile:hover:not(:active){transform:translateY(-3px);box-shadow:4px 4px 0 var(--ink)}
  .tile.sel:hover:not(:active){box-shadow:5px 5px 0 var(--ink)}
  .cta:hover:not(:active){transform:translateY(-2px);box-shadow:6px 6px 0 var(--ink)}
  .cta:hover svg{transform:translateX(3px)}
  .brief:hover:not(:active),.promo:hover:not(:active){transform:translateY(-2px);box-shadow:6px 6px 0 var(--red)}
  .play:hover:not(:active){transform:translateY(-2px);box-shadow:5px 5px 0 var(--ink)}
  .brief:hover .arr{transform:scale(1.1)}
  .promo:hover .go{transform:translateX(3px)}
  .sug:hover,.tchip:hover{background:var(--ink);color:#fff}
  .tchip.add:hover{background:var(--red);color:#fff;border-color:var(--red)}
  .chip:hover{background:var(--ink);color:#fff}
  .seg span:not(.on):hover{background:rgba(18,18,18,.05)}
  .nav a:not(.on):hover{opacity:.78}
  .acts svg:hover,.abar svg:hover,.bar .r svg:hover,.ico:hover{transform:scale(1.18)}
  .ibtn:hover svg{transform:scale(1.15)}
  [data-act="like"]:hover{color:var(--red)}
  .send:hover:not(:active){transform:scale(1.07)}
  .sw:hover{box-shadow:0 0 0 3px rgba(229,35,27,.18)}
}
@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}

/* ---------- dark mode ---------- */
body.dark{--bg:#131418;--ink:#f3f1ec;--ink2:#b9b5ad;--muted:#8c8884;--line:rgba(243,241,236,.15);--red:#ff4a39;background:#08090b}
body.dark #app{background:var(--bg)}
body.dark .nav,body.dark #rail{background:var(--bg)}
body.dark .statusbar svg *{fill:var(--ink);stroke:var(--ink)}
body.dark .tile,body.dark .sw,body.dark .rtoggle,body.dark .ai .bub{background:#1b1d22}
body.dark .inbar{background:var(--bg)}
body.dark .inbar input{background:#1b1d22;color:var(--ink)}
body.dark .body p{color:var(--ink)}
body.dark .foot{background:var(--bg)}
body.dark .foot::before{background:linear-gradient(180deg,rgba(19,20,24,0),var(--bg))}
/* inverted/premium panels become elevated dark surfaces */
body.dark .brief,body.dark .promo,body.dark .ai,body.dark .big,body.dark .feat{background:#1b1d22;border-color:var(--ink)}
body.dark .pill.prem{background:var(--red);color:#fff;border-color:var(--red)}
body.dark .ppill{background:var(--red);color:#fff}
body.dark .ppill.free{background:transparent;color:var(--ink);border-color:var(--ink)}
body.dark .toast{background:#26282e;color:var(--ink)}
body.dark .sug:hover,body.dark .tchip:hover,body.dark .chip:hover{background:var(--ink);color:var(--bg)}
body.dark .rnav a:hover:not(.on),body.dark .rtheme:hover{background:rgba(243,241,236,.07)}
body.dark .st-hero{background:#1b1d22;border-color:var(--ink)}

/* ---------- streak ---------- */
.st-hero{margin:4px 0 2px;border:2px solid var(--ink);border-radius:18px;background:var(--ink);color:#fff;padding:20px;box-shadow:4px 4px 0 var(--red);display:flex;align-items:center;gap:18px}
.st-hero .fl{width:50px;height:50px;color:var(--red);flex:none}
.st-hero .n{font-size:50px;font-weight:600;line-height:.9;letter-spacing:-.03em}
.st-hero .lab{font-size:12.5px;color:rgba(255,255,255,.72);margin-top:5px;line-height:1.35}
.goal{margin-top:16px;border:2px solid var(--ink);border-radius:14px;padding:15px}
.goal .top{display:flex;justify-content:space-between;align-items:center;font-size:13.5px;font-weight:600;margin-bottom:11px}
.goal .top .mono{font-family:'Geist Mono',monospace;font-size:12px;color:var(--muted)}
.gbar{height:13px;border:2px solid var(--ink);border-radius:8px;overflow:hidden}
.gfill{height:100%;background:var(--red);transition:width .45s ease}
.hm{display:flex;gap:4px;margin-top:12px}
.hmcol{display:flex;flex-direction:column;gap:4px;flex:1}
.hc{aspect-ratio:1;border-radius:3px;border:1.5px solid var(--line);background:transparent}
.hc.l1{background:rgba(229,35,27,.4);border-color:transparent}
.hc.l2{background:rgba(229,35,27,.7);border-color:transparent}
.hc.l3{background:var(--red);border-color:transparent}
.hc.today{border:2px solid var(--ink)}
.hc.fut{opacity:.3}
.hmleg{display:flex;align-items:center;gap:5px;justify-content:flex-end;margin-top:12px;font-family:'Geist Mono',monospace;font-size:10px;color:var(--muted)}
.hmleg .hc{width:13px;height:13px;aspect-ratio:auto;flex:none}

/* ---------- shell / desktop layout ---------- */
#shell{display:contents}
#rail{display:none}
@media (min-width:980px){
  body{display:block;padding:0;background:#fff;background-image:none;min-height:100vh}
  #shell{display:flex;height:100vh;width:100vw;overflow:hidden}
  /* sidebar */
  #rail{display:flex;flex-direction:column;width:256px;flex:none;border-right:2px solid var(--ink);padding:22px 16px;background:#fff;transition:width .22s ease}
  .rbrand{display:flex;align-items:center;gap:10px;padding:6px 10px 24px}
  .rbrand .mark{width:30px;height:30px;border-radius:8px;background:var(--red);border:2px solid var(--ink);display:flex;align-items:center;justify-content:center;box-shadow:2px 2px 0 var(--ink)}
  .rbrand .mark i{width:10px;height:10px;border-radius:50%;background:#fff;display:block}
  .rbrand b{font-size:22px;letter-spacing:-.02em}
  .rnav{display:flex;flex-direction:column;gap:5px}
  .rnav a{display:flex;align-items:center;gap:13px;padding:11px 13px;border-radius:11px;font-size:15px;font-weight:600;color:var(--ink);cursor:pointer;border:2px solid transparent;transition:background .14s,box-shadow .12s,transform .12s,color .12s}
  .rnav a svg{width:22px;height:22px}
  .rnav a:hover:not(.on){background:rgba(18,18,18,.05)}
  .rnav a.on{background:var(--red);color:#fff;border-color:var(--ink);box-shadow:3px 3px 0 var(--ink)}
  .rfoot{margin-top:auto;display:flex;flex-direction:column;gap:12px;align-items:flex-start;padding:10px}
  .rfoot .pill{font-size:11px;cursor:pointer}
  .rgo{font-size:13px;font-weight:600;color:#fff;background:var(--ink);border:2px solid var(--ink);border-radius:10px;padding:9px 14px;cursor:pointer;box-shadow:3px 3px 0 var(--red);transition:transform .12s,box-shadow .12s}
  .rgo:hover{transform:translateY(-2px);box-shadow:5px 5px 0 var(--red)}
  .rtheme{display:flex;align-items:center;gap:11px;cursor:pointer;font-size:14px;font-weight:600;color:var(--ink);padding:9px 10px;border-radius:10px}
  .rtheme svg{width:20px;height:20px;color:var(--ink)}
  .rtheme:hover{background:rgba(18,18,18,.05)}
  #shell.rail-collapsed .rtheme span{display:none}
  #shell.rail-collapsed .rtheme{justify-content:center;padding:9px 0}
  #shell[data-route="onboarding"] #rail{display:none}
  /* main panel */
  #app{width:auto;flex:1;height:100vh;max-width:none;border:none;border-radius:0;box-shadow:none;background:var(--bg)}
  #app .statusbar,#app .appbar,#app .nav{display:none!important}
  #app .subhd,#app .feed,#app .read,#app .br-pad,#app .pf-pad,#app .up-pad,#app .chat,#app .abar,#app .inbar,#app .foot,#app .ob-top,#app .scroll{width:100%;max-width:1100px;align-self:center}
  #app .bar{width:100%}
  #app .subhd{padding-top:24px}
  #app .himg{height:360px}
  #app .hero h2{font-size:34px;line-height:1.05}
  #app .read h1{font-size:40px}
  #app .read{padding-top:26px}
  #app .ob-top{padding-top:42px}
  #app .ob-top h1{font-size:46px}
  #app .grid{grid-template-columns:repeat(3,1fr)}
}
@media (min-width:1280px){
  #app .subhd,#app .feed,#app .read,#app .br-pad,#app .pf-pad,#app .up-pad,#app .chat,#app .abar,#app .inbar,#app .foot{max-width:1200px}
}
@media (min-width:980px){
  /* sidebar collapse */
  .rhead{display:flex;align-items:center;justify-content:space-between;padding:6px 4px 22px}
  .rbrand{padding:0}
  .rtoggle{width:31px;height:31px;border:2px solid var(--ink);border-radius:8px;background:#fff;color:var(--ink);display:flex;align-items:center;justify-content:center;cursor:pointer;flex:none;transition:transform .12s,box-shadow .12s}
  .rtoggle svg{width:16px;height:16px}
  .rtoggle:hover{box-shadow:2px 2px 0 var(--ink);transform:translateY(-1px)}
  #shell.rail-collapsed #rail{width:74px;padding:22px 10px}
  #shell.rail-collapsed .rhead{flex-direction:column;gap:16px;padding:6px 0 20px}
  #shell.rail-collapsed .rbrand b{display:none}
  #shell.rail-collapsed .rnav a{justify-content:center;gap:0;padding:11px 0}
  #shell.rail-collapsed .rnav a span{display:none}
  #shell.rail-collapsed .rfoot{display:none}
  /* keep long-form prose readable even though the column is wide */
  #app .read .body p,#app .read .pq{max-width:720px}
}

/* ---------- AI summary (reader) ---------- */
.ai .ai-sum{font-size:14px;line-height:1.5;color:#fff;margin-bottom:4px}
.ai ul{margin-top:11px}
.ai .ainote{margin-top:13px;padding-top:11px;border-top:1px solid rgba(255,255,255,.18);font-family:'Geist Mono',monospace;font-size:10px;letter-spacing:.01em;color:rgba(255,255,255,.55);line-height:1.45}
.ai-skel{display:flex;flex-direction:column;gap:9px}
.ai-skel span{height:11px;border-radius:5px;background:linear-gradient(90deg,rgba(255,255,255,.12),rgba(255,255,255,.28),rgba(255,255,255,.12));background-size:200% 100%;animation:aiShimmer 1.2s ease-in-out infinite}
.ai-skel span:nth-child(2){width:88%}.ai-skel span:nth-child(3){width:64%}
.ai-load{margin-top:12px;display:flex;align-items:center;gap:9px;font-family:'Geist Mono',monospace;font-size:11px;color:rgba(255,255,255,.6)}
.ai-load::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--red);animation:livePulse 1s ease-in-out infinite}
@keyframes aiShimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
/* source brief heading inside reader body */
.read .body .srcbrief-h{font-family:'Geist Mono',monospace;font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin:2px 0 10px}
/* briefing AI states */
.gen .genwait{font-style:italic;color:var(--muted)}
.end.ai{font-family:'Geist Mono',monospace;font-size:10px;color:var(--muted);line-height:1.5}
/* install (PWA) row in profile */
.trow.inst{cursor:pointer}
.instbtn{flex:none;display:inline-flex;align-items:center;gap:7px;background:var(--red);color:#fff;border:2px solid var(--ink);border-radius:10px;padding:9px 14px;font-size:13px;font-weight:600;box-shadow:3px 3px 0 var(--ink);transition:transform .12s,box-shadow .12s}
.instbtn svg{width:15px;height:15px}
.trow.inst:hover .instbtn{transform:translateY(-2px);box-shadow:5px 5px 0 var(--ink)}
.instdone{flex:none;width:30px;height:30px;border-radius:50%;background:var(--red);display:flex;align-items:center;justify-content:center}
.instdone svg{width:15px;height:15px}

/* ---------------- Quote Cards: selection bubble + share modal ---------------- */
#qcFab{position:absolute;z-index:9999;display:none;align-items:center;gap:7px;
  background:var(--ink);color:#fff;border:2px solid var(--ink);border-radius:11px;
  padding:7px 12px;font-family:'Space Grotesk',system-ui,sans-serif;font-size:12px;font-weight:700;letter-spacing:.02em;
  box-shadow:3px 3px 0 var(--red);cursor:pointer;user-select:none;-webkit-user-select:none;
  transition:transform .12s ease,box-shadow .12s ease}
#qcFab:hover{transform:translateY(-1px);box-shadow:5px 5px 0 var(--red)}
#qcFab svg{flex:none}
#qcModal{position:fixed;inset:0;z-index:10000;display:none;align-items:center;justify-content:center;padding:20px}
.qc-back{position:absolute;inset:0;background:rgba(18,18,18,.62);backdrop-filter:blur(2px)}
.qc-sheet{position:relative;background:#fff;border:2px solid var(--ink);border-radius:18px;box-shadow:8px 8px 0 var(--ink);
  padding:18px;max-width:560px;width:100%;max-height:calc(100dvh - 40px);overflow:auto;
  display:flex;flex-direction:column;gap:14px;scrollbar-width:none}
.qc-sheet::-webkit-scrollbar{display:none}
.qc-h{display:flex;align-items:center;justify-content:space-between}
.qc-h b{font-size:20px}
.qc-close{font-size:26px;line-height:1;cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center;
  border-radius:50%;background:rgba(18,18,18,.05);color:var(--ink);user-select:none}
.qc-close:hover{background:rgba(18,18,18,.1)}
.qc-canvas-wrap{display:flex;justify-content:center;background:#e9e6e0;
  background-image:radial-gradient(circle at 1px 1px,rgba(18,18,18,.06) 1px,transparent 0);background-size:22px 22px;
  border-radius:14px;padding:12px}
#qcCanvas{max-width:100%;height:auto;border:2px solid var(--ink);border-radius:8px;display:block}
.qc-row{display:flex;gap:8px}
.qc-style{flex:1;padding:10px 12px;border:2px solid var(--ink);border-radius:11px;background:#fff;
  font-family:inherit;font-weight:600;cursor:pointer;font-size:13px;transition:transform .1s,box-shadow .1s}
.qc-style.on{background:var(--ink);color:#fff}
.qc-style:not(.on):hover{transform:translateY(-1px);box-shadow:3px 3px 0 var(--ink)}
.qc-actions{display:flex;gap:10px}
.qc-btn{flex:1;padding:14px;border:2px solid var(--ink);border-radius:12px;background:#fff;
  font-family:inherit;font-weight:700;cursor:pointer;font-size:14px;transition:transform .12s,box-shadow .12s}
.qc-btn:hover{transform:translateY(-1px);box-shadow:3px 3px 0 var(--ink)}
.qc-btn.primary{background:var(--red);color:#fff;box-shadow:3px 3px 0 var(--ink)}
.qc-btn.primary:hover{transform:translateY(-2px);box-shadow:5px 5px 0 var(--ink)}
.qc-textwrap{display:flex;flex-direction:column;gap:6px}
.qc-textlbl{font-family:'Geist Mono',monospace;font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
#qcText{width:100%;border:2px solid var(--ink);border-radius:11px;padding:11px 12px;font-family:'Fraunces',Georgia,serif;font-size:15px;font-weight:500;line-height:1.4;color:var(--ink);background:#fff;resize:vertical;outline:none;min-height:62px}
#qcText:focus{box-shadow:0 0 0 3px color-mix(in srgb,var(--red) 18%,transparent)}
/* article body skeleton while Claude writes the long recap */
.art-skel{display:flex;flex-direction:column;gap:13px;padding:6px 0 4px}
.art-skel span{display:block;height:13px;border-radius:5px;background:linear-gradient(90deg,rgba(18,18,18,.05),rgba(18,18,18,.13),rgba(18,18,18,.05));background-size:200% 100%;animation:artShim 1.4s ease-in-out infinite}
.art-skel span:nth-child(2){width:94%}.art-skel span:nth-child(3){width:88%}
.art-skel span:nth-child(4){width:96%}.art-skel span:nth-child(5){width:78%}
.art-skel span:nth-child(6){width:64%}
@keyframes artShim{0%{background-position:200% 0}100%{background-position:-200% 0}}
/* article mode selector — magazine / executive / deep dive / analogy */
.modesel{display:flex;gap:6px;border:2px solid var(--ink);border-radius:13px;padding:4px;background:#fff;overflow:hidden;margin:14px 0 2px}
.modesel .mo{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:8px 6px;border-radius:9px;cursor:pointer;line-height:1.1;transition:background .14s,color .14s,box-shadow .12s;text-align:center;min-width:0}
.modesel .mo b{font-size:13px;font-weight:700;letter-spacing:-.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}
.modesel .mo span{font-family:'Geist Mono',monospace;font-size:9.5px;letter-spacing:.06em;color:var(--muted);text-transform:uppercase;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}
.modesel .mo:not(.on):hover{background:rgba(18,18,18,.04)}
.modesel .mo.on{background:var(--ink);color:#fff;box-shadow:2px 2px 0 var(--red)}
.modesel .mo.on span{color:rgba(255,255,255,.7)}
@media (max-width:520px){
  .modesel .mo span{display:none}
  .modesel .mo{padding:9px 4px}
}
/* compact bullet list rendered alongside the body in Executive / Deep Dive modes */
.body .bodypts{list-style:none;margin:14px 0 0;padding:13px 0 0;border-top:1px solid var(--line);display:flex;flex-direction:column;gap:9px}
.body .bodypts li{position:relative;padding-left:18px;font-size:14.5px;line-height:1.45;color:var(--ink)}
.body .bodypts li::before{content:"";position:absolute;left:0;top:8px;width:7px;height:7px;border-radius:2px;background:var(--red)}
/* keyboard focus ring on feed items */
.kbfocus{position:relative;outline:2px solid var(--red);outline-offset:4px;border-radius:11px;transition:outline-color .12s}
/* Command palette (⌘K / Ctrl+K) */
#palette{position:fixed;inset:0;z-index:10001;display:none;align-items:flex-start;justify-content:center;padding:7vh 20px 20px}
.p-back{position:absolute;inset:0;background:rgba(18,18,18,.55);backdrop-filter:blur(3px)}
.p-sheet{position:relative;width:100%;max-width:580px;background:#fff;border:2px solid var(--ink);border-radius:16px;box-shadow:8px 8px 0 var(--ink);overflow:hidden;display:flex;flex-direction:column;max-height:74vh}
#paletteInput{padding:18px 22px;border:none;outline:none;font-family:'Space Grotesk',system-ui,sans-serif;font-size:16px;font-weight:500;color:var(--ink);border-bottom:2px solid var(--ink);background:#fff}
#paletteInput::placeholder{color:var(--muted)}
.p-results{flex:1;overflow-y:auto;scrollbar-width:none}
.p-results::-webkit-scrollbar{display:none}
.p-item{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:13px 18px;cursor:pointer;border-bottom:1px solid var(--line);user-select:none}
.p-item:last-child{border-bottom:none}
.p-item.on{background:rgba(229,35,27,.08)}
.p-item.on::before{content:"";position:absolute;left:0;width:3px;height:24px;background:var(--red);border-radius:0 3px 3px 0}
.p-item{position:relative}
.p-item b{flex:1;font-size:14.5px;font-weight:600;color:var(--ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.p-item kbd{font-family:'Geist Mono',monospace;font-size:10px;background:rgba(18,18,18,.07);padding:3px 7px;border-radius:5px;color:var(--muted);font-weight:600;letter-spacing:.04em}
.p-item.p-art b{font-weight:500;font-family:'Fraunces',Georgia,serif;font-size:14px}
.p-section{padding:9px 18px 6px;font-family:'Geist Mono',monospace;font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);background:rgba(18,18,18,.02)}
.p-empty{padding:20px 22px;color:var(--muted);font-size:14px;font-family:'Geist Mono',monospace;text-align:center}
.p-foot{padding:9px 18px;border-top:1px solid var(--line);font-family:'Geist Mono',monospace;font-size:10px;color:var(--muted);display:flex;gap:10px;align-items:center;letter-spacing:.04em}
.p-foot kbd{font-family:inherit;font-size:9.5px;background:rgba(18,18,18,.07);padding:2px 6px;border-radius:4px;margin-right:3px}
