:root{
  --ink:#0c0e13; --panel:#171b25; --panel2:#1e2330; --panel3:#252b3a;
  --line:#2c3343; --line2:#3a4254;
  --paper:#ECE6D8; --paper-dim:#b9b3a6; --muted:#8a8e9c;
  --brass:#E0A93B; --blue:#5B8DEF; --teal:#3FB6A8; --plum:#C77DFF;
  --bar-h:62px;
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html,body{height:100%}
body{
  background:var(--ink);color:var(--paper);
  font-family:'Inter',system-ui,-apple-system,sans-serif;line-height:1.55;
  -webkit-font-smoothing:antialiased;overflow:hidden;height:100vh;height:100dvh;
  background-image:radial-gradient(circle at 15% 0,rgba(224,169,59,.07),transparent 40%),radial-gradient(circle at 90% 100%,rgba(91,141,239,.06),transparent 45%);
}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
h1,h2,h3,h4{font-family:'Fraunces',Georgia,serif;font-weight:900;line-height:1.08;letter-spacing:-.3px}

#app{height:100vh;height:100dvh;display:flex;flex-direction:column;max-width:520px;margin:0 auto;position:relative}

/* app bar */
.appbar{display:flex;align-items:center;justify-content:space-between;padding:calc(env(safe-area-inset-top) + 10px) 18px 10px;border-bottom:1px solid var(--line);flex:none;background:rgba(12,14,19,.85);backdrop-filter:blur(8px);z-index:20}
.logo{font-family:'Fraunces',serif;font-weight:900;font-size:22px}
.logo i{color:var(--brass);font-style:normal}
.appbar .icon{width:40px;height:40px;display:grid;place-items:center;font-size:17px;color:var(--paper-dim);border-radius:50%}

/* scroll area */
#screen{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:14px 14px calc(var(--bar-h) + env(safe-area-inset-bottom) + 18px)}
#screen::-webkit-scrollbar{width:0}

/* tab bar */
.tabbar{position:absolute;left:0;right:0;bottom:0;display:flex;background:rgba(8,10,15,.95);backdrop-filter:blur(10px);border-top:1px solid var(--line);padding:7px 4px calc(env(safe-area-inset-bottom) + 8px);z-index:20}
.tab{flex:1;min-height:46px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;font-size:10px;font-weight:600;color:var(--muted)}
.tab .g{font-size:19px;line-height:1}
.tab.on{color:var(--brass)}

/* generic bits */
.eyebrow{font-family:'Space Mono',monospace;font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--brass)}
.screen-h{margin:6px 2px 14px}
.screen-h h2{font-size:25px;margin-top:4px}
.seclab{font-family:'Fraunces',serif;font-weight:900;font-size:17px;margin:24px 2px 12px;display:flex;align-items:center;gap:9px}
.rub{font-family:'Space Mono',monospace;font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--brass)}
.dek{font-size:12.5px;color:var(--muted);margin-top:4px;line-height:1.4}
.note{font-size:12px;color:var(--muted);line-height:1.5;margin:8px 2px}
.disclaim{font-size:11.5px;color:var(--paper-dim);background:rgba(199,125,255,.07);border:1px solid rgba(199,125,255,.22);border-radius:11px;padding:11px 13px;margin:10px 0;line-height:1.5}

.pill{font-family:'Space Mono',monospace;font-size:9px;letter-spacing:1px;text-transform:uppercase;padding:3px 8px;border-radius:20px;border:1px solid var(--line2);color:var(--paper-dim);white-space:nowrap}
.pill.ok{color:var(--teal);border-color:rgba(63,182,168,.4);background:rgba(63,182,168,.08)}
.pill.warn{color:var(--brass);border-color:rgba(224,169,59,.4);background:rgba(224,169,59,.08)}
.pill.unk{color:var(--muted)}
.pill.concept{color:var(--plum);border-color:rgba(199,125,255,.4);background:rgba(199,125,255,.08)}
.pill.local{color:var(--brass);border-color:rgba(224,169,59,.4);background:rgba(224,169,59,.08)}

.btn{display:block;width:100%;min-height:50px;background:var(--brass);color:var(--ink);font-family:inherit;font-weight:700;font-size:15px;border:none;border-radius:13px;cursor:pointer;margin:8px 0}
.btn:disabled{opacity:.6}
.btn.ghost{background:transparent;border:1px solid var(--line2);color:var(--paper)}

/* hero */
.hero{position:relative;display:block;border-radius:18px;overflow:hidden;height:230px;margin-bottom:14px;background:#17120d}
.hero img{width:100%;height:100%;object-fit:cover}
.hero-ov{position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,9,13,.05),rgba(8,9,13,.85))}
.hero-tx{position:absolute;left:16px;right:16px;bottom:15px}
.hero-tx h2{font-size:24px;color:var(--paper);margin-top:5px;text-shadow:0 1px 14px rgba(0,0,0,.6)}

/* tiles */
.tiles{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:6px 0}
.tile{background:var(--panel);border:1px solid var(--line);border-radius:15px;padding:15px;min-height:92px;display:flex;flex-direction:column;gap:3px}
.tile .g{font-size:21px}
.tile b{font-size:14px}
.tile span{font-size:11px;color:var(--muted)}
.tile:active{background:var(--panel2)}

/* cards */
.card{display:block;background:var(--panel);border:1px solid var(--line);border-radius:15px;overflow:hidden;margin-bottom:12px}
.card:active{background:var(--panel2)}
.card>img{width:100%;height:172px;object-fit:cover}
.card-noimg{height:8px;background:linear-gradient(90deg,var(--brass),var(--blue))}
.card-tx{padding:13px 14px}
.card-tx h3{font-size:18px;margin:4px 0 2px}
.card.row{display:flex;align-items:center}
.card.row>img{width:96px;height:96px;flex:none}
.card.row .card-tx{flex:1}
.card.row h3{font-size:15px}

/* chips */
.chips{display:flex;gap:8px;overflow-x:auto;padding:2px 2px 12px;scrollbar-width:none}
.chips::-webkit-scrollbar{display:none}
.chip{flex:none;min-height:36px;display:inline-flex;align-items:center;font-size:12.5px;font-weight:600;padding:7px 14px;border-radius:20px;border:1px solid var(--line2);background:none;color:var(--paper-dim);white-space:nowrap;cursor:pointer;font-family:inherit}
.chip.on{background:var(--brass);color:var(--ink);border-color:var(--brass)}

/* search + form */
.searchbar{margin:2px 0 6px}
.searchbar input,.form2 input{width:100%;min-height:46px;background:var(--panel);border:1px solid var(--line2);border-radius:12px;color:var(--paper);font-family:inherit;font-size:15px;padding:0 14px}
.form2{display:flex;gap:10px;margin:6px 0}
.form2 #date{flex:none;width:48%}

/* reader */
.reader-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}
.back,.fav{width:42px;height:42px;display:grid;place-items:center;background:var(--panel);border:1px solid var(--line);border-radius:50%;color:var(--paper);font-size:18px;cursor:pointer;font-family:inherit}
.fav.on{color:var(--brass);border-color:var(--brass)}
.reader-hero{width:100%;height:210px;object-fit:cover;border-radius:16px;margin-bottom:14px;background:#17120d}
.reader-body .rub{margin-bottom:6px}
.reader-body h1{font-size:27px;margin:2px 0 8px}
.reader-body p{font-size:15.5px;color:#dcd7ca;margin-bottom:14px;line-height:1.62}
.reader-body p.lead{font-size:17px;color:var(--paper)}
.reader-body .pull{font-family:'Fraunces',serif;font-style:italic;font-size:19px;color:var(--brass);border-left:3px solid var(--brass);padding:2px 0 2px 14px;margin:18px 0}
.reader-body .credit{font-family:'Space Mono',monospace;font-size:10.5px;color:var(--muted)}

/* podcasts + vote */
.pod{display:flex;align-items:center;gap:12px;width:100%;text-align:left;background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:11px;margin-bottom:9px;cursor:pointer;font-family:inherit;color:inherit}
.pod .play{width:42px;height:42px;flex:none;border-radius:50%;background:var(--brass);color:var(--ink);display:grid;place-items:center;font-size:15px}
.pod h4{font-size:13.5px}.pod .meta{font-size:10.5px;color:var(--muted);margin-top:2px}
.pod .lock{margin-left:auto;font-size:15px;opacity:.8}
.vote{position:relative;overflow:hidden;width:100%;text-align:left;background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:8px;margin-bottom:9px;cursor:pointer;font-family:inherit;color:inherit}
.vote.picked{border-color:var(--brass)}
.vote .bar{position:absolute;inset:0;background:linear-gradient(90deg,rgba(224,169,59,.18),rgba(224,169,59,.03));transition:width .5s ease}
.vrow{position:relative;display:flex;align-items:center;gap:11px}
.vrow img{width:48px;height:48px;border-radius:9px;object-fit:cover;flex:none;background:var(--panel3)}
.vti{flex:1}.vti b{font-size:13.5px}.vti .a{font-size:11px;color:var(--muted)}
.pct{font-family:'Space Mono',monospace;font-size:13px;font-weight:700;color:var(--brass)}

/* archives */
.archgrid{display:grid;grid-template-columns:1fr 1fr;gap:11px}
.cover{position:relative;aspect-ratio:3/4;border-radius:13px;border:none;display:flex;flex-direction:column;justify-content:flex-end;padding:13px;color:#0c0e13;font-family:'Fraunces',serif;text-align:left;cursor:pointer;overflow:hidden}
.cover .yr{font-family:'Space Mono',monospace;font-size:9.5px;letter-spacing:1px;opacity:.7}
.cover .ti{font-weight:900;font-size:15px;line-height:1.05;margin-top:3px}
.cover .lock{position:absolute;top:10px;right:11px;font-size:15px}

/* 24h guide output */
.g-intro{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:14px;margin:6px 0 4px}
.g-intro b{font-family:'Fraunces',serif;font-size:16px}
.g-intro p{font-size:13px;color:var(--paper-dim);margin-top:6px}
.slot{background:var(--panel);border:1px solid var(--line);border-left:3px solid var(--brass);border-radius:12px;padding:12px 13px;margin-bottom:10px}
.slot-h{display:flex;align-items:center;gap:8px;margin-bottom:4px}
.slot-time{font-family:'Space Mono',monospace;font-size:12px;color:var(--brass);font-weight:700}
.slot h4{font-size:16px}
.slot-kind{font-size:11px;color:var(--muted);margin:2px 0 6px}
.slot p{font-size:13px;color:#cfcabd}
.slot-note{font-size:11px;color:var(--muted);margin-top:6px;font-style:italic}
.slot-link{display:inline-block;margin-top:8px;font-size:12.5px;font-weight:600;color:var(--blue)}
.venue{display:block;background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:11px 13px;margin-bottom:8px}
.venue b{font-size:14px}
.tips{margin:0 0 4px 18px;font-size:13px;color:var(--paper-dim)}.tips li{margin-bottom:5px}
.loading{display:flex;align-items:center;gap:11px;color:var(--paper-dim);font-size:13.5px;padding:18px 4px}
.spin{width:20px;height:20px;border:2px solid var(--line2);border-top-color:var(--brass);border-radius:50%;animation:spin 1s linear infinite;flex:none}
@keyframes spin{to{transform:rotate(360deg)}}

/* settings */
.set-card{background:var(--panel);border:1px solid var(--line);border-radius:15px;padding:16px;margin-bottom:14px}
.set-row{display:flex;justify-content:space-between;align-items:center;padding:7px 0;font-size:14px;border-bottom:1px solid var(--line)}
.set-row:last-of-type{border-bottom:none}

/* modal / paywall */
.modal{position:absolute;inset:0;background:rgba(6,7,11,.6);backdrop-filter:blur(3px);display:flex;align-items:flex-end;z-index:40}
.modal[hidden]{display:none}
.sheet{position:relative;background:var(--panel2);border-top-left-radius:22px;border-top-right-radius:22px;border:1px solid var(--line);padding:24px 20px calc(env(safe-area-inset-bottom) + 24px);width:100%;animation:up .25s ease}
@keyframes up{from{transform:translateY(40px);opacity:.6}to{transform:none;opacity:1}}
.sheet-x{position:absolute;right:18px;top:16px;background:none;border:none;color:var(--muted);font-size:20px;cursor:pointer}
.sheet h2{font-size:23px;margin:6px 0 8px}
.sheet>p{font-size:13.5px;color:var(--paper-dim);margin-bottom:16px}
.prices{display:flex;gap:10px;margin-bottom:14px}
.price{flex:1;border:1px solid var(--line2);border-radius:13px;padding:13px;text-align:center}
.price.on{border-color:var(--brass);background:rgba(224,169,59,.08)}
.price b{font-family:'Fraunces',serif;font-size:19px;display:block}
.price span{font-size:11px;color:var(--muted)}

@media (min-width:520px){ #app{border-left:1px solid var(--line);border-right:1px solid var(--line)} }
