/* =======================================================
   QUIZMIZ — GLOBAL STYLES (Consolidated)
   Theme tokens: light default, dark via [data-theme="dark"]
   Mobile-first, sticky topbar, accessible drawer, CLS-safe ads
   ======================================================= */

/* ===== THEME TOKENS ===== */
/* Light (default) */
:root{
  --bg:#f5f7fb; --panel:#ffffff; --card:#ffffff; --text:#171a1f; --muted:#636b75; --border:#e2e6ec;
  --accent:#d93f49; --accent-hover:#e2525c; --accent-weak:rgba(217,63,73,.12);
  --steel:#2f54c2; --steel-weak:rgba(47,84,194,.15);
  --shadow:0 8px 18px rgba(0,0,0,.08);
  --focus:rgba(47,84,194,.25);
  --z-topbar:1000; --z-drawer:1200; --z-scrim:1100; --z-confetti:70; --z-modal:1400; --z-backdrop:1350;
  --content-max:1180px; --rail-gap:20px;
}
/* Dark */
:root[data-theme="dark"]{
  --bg:#111315; --panel:#171a1f; --card:#1d2026; --text:#e6e8ea; --muted:#9ca3af; --border:#2a2f36;
  --accent:#ff4d57; --accent-hover:#ff626b; --accent-weak:rgba(255,77,87,.12);
  --steel:#4b70dd; --steel-weak:rgba(75,112,221,.15);
  --shadow:0 12px 28px rgba(0,0,0,.25);
  --focus:rgba(255,77,87,.35);
}

/* ===== RESET / BASE ===== */
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;max-width:100%;overflow-x:hidden;min-height:100%}
body{
  font-family:"Inter",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  background:var(--bg); color:var(--text);
  -webkit-font-smoothing:antialiased; -moz-osx-font-smoothing:grayscale;
  line-height:1.45;
}
img,svg{max-width:100%;height:auto;display:block}
a{color:var(--steel);text-decoration:none}
a:hover{text-decoration:underline}
:where(a,button,input,textarea,.nav-item,.iconbtn,.tab):focus-visible{
  outline:2px solid var(--focus); outline-offset:2px; border-radius:10px;
}

/* ===== UTILITY BAR (desktop, top) ===== */
.utilitybar{position:sticky;top:0;z-index:900;background:var(--panel);border-bottom:1px solid var(--border)}
.utility-wrap{max-width:1120px;margin:0 auto;padding:8px 20px;display:flex;gap:18px;justify-content:flex-end;flex-wrap:wrap}
.utility-wrap a{font-weight:600;opacity:.9}
.utility-wrap a:hover{text-decoration:underline}
@media (max-width:900px){ .utilitybar{display:none} }

/* ===== APP LAYOUT ===== */
.layout{display:grid;grid-template-columns:260px 1fr;min-height:100vh}
@media (max-width:940px){.layout{grid-template-columns:1fr}}

/* ===== SIDEBAR (desktop) ===== */
.sidebar{background:var(--panel);border-right:1px solid var(--border);padding:22px 18px;display:flex;flex-direction:column;gap:22px}
@media (max-width:940px){.sidebar{display:none}}
.brand,.topbar-brand{display:flex;align-items:center;gap:12px;color:var(--text);text-decoration:none}
.brand-logo{width:28px;height:28px;object-fit:contain;border-radius:6px}
.brand-text{display:flex;flex-direction:column;line-height:1.2}
.brand-title{font-size:18px;font-weight:700}
.brand-sub{font-size:13px;color:var(--muted)}
.nav{display:flex;flex-direction:column;gap:4px}
.nav-item{display:block;padding:10px 12px;border-radius:10px;color:var(--text);border:1px solid transparent;background:transparent;transition:.15s ease;font-size:15px}
.nav-item:hover{background:var(--steel-weak)}
.nav-item.active{background:var(--accent-weak);border-left:4px solid var(--accent);padding-left:8px}
.sidebar-foot{margin-top:auto;padding-top:12px;border-top:1px dashed var(--border)}

/* ===== MOBILE TOPBAR ===== */
.topbar{
  display:grid;grid-template-columns:48px 1fr 48px;align-items:center;height:64px;
  background:var(--panel);border-bottom:1px solid var(--border);
  padding:calc(env(safe-area-inset-top,0) + 0px) 8px 0;position:sticky;top:0;z-index:var(--z-topbar);
  box-shadow:0 4px 16px rgba(0,0,0,.25);
}
@media (min-width:941px){.topbar{display:none}}
#menuOpen{grid-column:1;justify-self:start;width:44px;height:44px;font-size:20px}
.topbar-brand{grid-column:2;justify-self:center;gap:10px;font-weight:800;font-size:18px;letter-spacing:.2px}
.topbar-brand img{width:28px;height:28px;border-radius:7px;object-fit:cover}
.topbar .topbar-brand span{font-weight:700}

/* ===== DRAWER (mobile) ===== */
:root{
  --drawer-backdrop: rgba(15,17,20,0.55);
  --drawer-surface:  rgba(26,29,35,0.72);
  --drawer-border:   rgba(255,255,255,0.06);
  --drawer-shadow:   0 20px 50px rgba(0,0,0,.45);
}
.drawer-scrim{
  position:fixed; inset:0; background:var(--drawer-backdrop);
  -webkit-backdrop-filter: blur(2px); backdrop-filter: blur(2px);
  z-index:var(--z-scrim);
}
.drawer-scrim[hidden]{display:none}
.drawer{
  position:fixed; top:0; left:0; height:100dvh; width:min(84vw,320px);
  transform:translateX(-106%); will-change:transform;
  transition:transform .22s cubic-bezier(.24,.75,.20,1);
  z-index:var(--z-drawer); display:flex; flex-direction:column;
  background:var(--drawer-surface); border-right:1px solid var(--drawer-border);
  -webkit-backdrop-filter: blur(6px); backdrop-filter: blur(6px); box-shadow:var(--drawer-shadow);
}
.drawer.open{transform:translateX(0)}
.drawer-head{
  height:56px; display:flex; align-items:center; justify-content:space-between;
  padding:calc(env(safe-area-inset-top,0) + 8px) 12px 8px; border-bottom:1px solid var(--drawer-border);
}
#menuClose{
  width:40px; height:40px; border-radius:10px; border:1px solid var(--border);
  background:transparent; color:var(--text); cursor:pointer;
}
#menuClose:hover{background:rgba(255,255,255,.06)}
.drawer-list{list-style:none;margin:8px 0 0;padding:8px;display:grid;gap:8px;padding-bottom:calc(env(safe-area-inset-bottom,0) + 14px)}
.drawer-list a{
  position:relative; display:block; padding:12px 14px; border-radius:12px;
  color:var(--text); text-decoration:none; border:1px solid var(--drawer-border);
  background:linear-gradient(180deg,rgba(255,255,255,.02),rgba(255,255,255,0));
  overflow:hidden; transition:background .15s ease, transform .06s ease, border-color .15s ease;
}
.drawer-list a:hover{background:rgba(255,255,255,.05)}
.drawer-list a:active{transform:scale(.99)}
.drawer-list a.active{border-color:var(--accent);background:var(--accent-weak)}
.drawer-list a::after{
  content:""; position:absolute; width:0; height:0; border-radius:999px; pointer-events:none;
  background:rgba(255,255,255,.18); left:var(--rx,50%); top:var(--ry,50%);
  transform:translate(-50%,-50%); transition:width .28s ease, height .28s ease, opacity .32s ease; opacity:0;
}
.drawer-list a:active::after{ width:260px; height:260px; opacity:.35 }
.drawer-list a, #menuClose{cursor:pointer}

/* ===== MAIN CONTENT ===== */
.content{padding:28px;max-width:1100px;margin:0 auto}
@media (max-width:940px){.content{padding:calc(28px + env(safe-area-inset-top,0)) 18px 18px}}
.card{background:var(--card);border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow);padding:18px}
.panel{background:var(--panel);border:1px solid var(--border);border-radius:14px;padding:14px;box-shadow:var(--shadow)}
.panel h3{margin:0 0 8px;color:var(--steel)}
.banner{margin-bottom:18px}
.foot{text-align:center;margin:20px 0;color:var(--muted)}
.foot a{color:var(--steel)}

/* ===== TABS ===== */
.tabs{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:18px}
.tab{background:var(--panel);border:1px solid var(--border);border-radius:10px;padding:10px 16px;color:var(--muted);cursor:pointer;min-height:44px;transition:.15s ease;font-weight:600}
.tab:active{transform:scale(.98)}
.tab.is-active{color:var(--text);border-color:var(--accent);background:var(--accent-weak)}

/* ===== GAME AREA ===== */
.game{display:flex;flex-direction:column;gap:18px}
.game-head{display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border);padding-bottom:10px}
.game .grid{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(0,1fr);gap:16px}
@media (max-width:940px){.game .grid{grid-template-columns:minmax(0,1fr)}}
.banner.tip{display:flex;align-items:center;gap:10px;padding:12px 16px;border-radius:12px;background:linear-gradient(180deg,rgba(75,112,221,.15),rgba(75,112,221,.06));border:1px solid rgba(255,255,255,.08);color:var(--text);font-size:15px;line-height:1.4;box-shadow:0 4px 14px rgba(0,0,0,.25) inset}
.banner.tip::before{content:"💡";flex-shrink:0;display:grid;place-items:center;width:26px;height:26px;border-radius:8px;background:rgba(75,112,221,.18);font-size:15px}

/* Inputs + buttons */
.guess-row{display:grid;grid-template-columns:1fr auto;gap:8px;position:relative}
@media (max-width:720px){.guess-row{position:sticky;bottom:env(safe-area-inset-bottom,0);z-index:5}.guess-row input{font-size:16px}}
input[type="text"],input[type="search"],input,textarea{
  width:100%;padding:12px 14px;font-size:15px;background:var(--panel);border:1px solid var(--border);border-radius:10px;color:var(--text)
}
input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-weak)}
.btn{background:var(--accent);color:#fff;border-radius:10px;border:none;font-weight:600;cursor:pointer;padding:12px 16px;box-shadow:0 2px 8px rgba(0,0,0,.35);transition:.15s ease,transform .06s ease}
.btn:hover{background:var(--accent-hover);transform:translateY(-1px)}
.btn:active{transform:translateY(0);box-shadow:none}
.btn.ghost{background:transparent;border:1px solid var(--border);color:var(--text)}
.btn[disabled]{opacity:.6;cursor:not-allowed}
.feedback{color:#ffd76a;font-size:14px;font-weight:600}
.muted{color:var(--muted);font-size:13px}
.muted.small{opacity:.85;font-size:12px}
.reveal{margin-top:14px}
.answer{font-weight:700}

/* Suggestions */
.suggestions{list-style:none;margin:8px 0 0;padding:0;border:1px solid var(--border);background:var(--card);border-radius:12px;max-height:220px;overflow:auto;z-index:1200}
.suggestions li{padding:10px 12px;border-bottom:1px solid var(--border);cursor:pointer}
.suggestions li:last-child{border-bottom:none}
.suggestions li:hover,.suggestions li.active{background:rgba(255,255,255,.06)}
.suggestions.hidden{display:none}

/* ===== MODALS ===== */
.modal-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.55);backdrop-filter:blur(4px);opacity:0;pointer-events:none;transition:opacity .2s;z-index:var(--z-backdrop)}
.modal-backdrop.open{opacity:1;pointer-events:auto}
.modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-46%) scale(.96);width:min(740px,92vw);background:var(--card);color:var(--text);border:1px solid var(--border);border-radius:16px;padding:18px 20px;box-shadow:var(--shadow);opacity:0;pointer-events:none;transition:.22s ease;z-index:var(--z-modal)}
.modal.open{opacity:1;pointer-events:auto;transform:translate(-50%,-50%) scale(1)}
.modal-head{display:flex;justify-content:space-between;align-items:center;padding-bottom:8px;border-bottom:1px solid var(--border)}
.modal-title{font-size:18px;font-weight:600}
.modal-body{margin-top:10px;display:grid;gap:10px;font-size:15px;line-height:1.5}
.modal-foot{margin-top:14px;padding-top:10px;text-align:right;border-top:1px solid var(--border)}
.modal-close{border:1px solid var(--border);background:var(--panel);padding:8px 14px;border-radius:10px;cursor:pointer;color:var(--text)}
.modal-close:hover{background:var(--steel-weak)}

/* ===== UTILITIES ===== */
.hidden{display:none !important}
.center{text-align:center}
.text-sm{font-size:14px}
.text-muted{color:var(--muted)}

/* ===== ANIMATIONS ===== */
.reveal.revealed{animation:gocFadeIn .18s ease-out}
@keyframes gocFadeIn{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}
.streak.bump{animation:gocBump .28s ease-out}
@keyframes gocBump{0%{transform:scale(1)}40%{transform:scale(1.14)}100%{transform:scale(1)}}
#share-btn.pulse{animation:gocPulse 1.2s ease-in-out 2}
@keyframes gocPulse{0%{box-shadow:0 0 0 0 rgba(255,77,87,0)}50%{box-shadow:0 0 0 6px rgba(255,77,87,.18)}100%{box-shadow:0 0 0 0 rgba(255,77,87,0)}}

/* Confetti */
.goc-confetti{position:fixed;top:0;left:0;width:100%;height:0;pointer-events:none;z-index:var(--z-confetti)}
.goc-confetti i{position:absolute;top:-10px;width:6px;height:10px;border-radius:2px;animation:drop var(--t,900ms) ease-in forwards}
@keyframes drop{to{transform:translate(var(--x,0),var(--y,60vh)) rotate(var(--r,180deg));opacity:.9}}

/* Subtle tint + guess verdict */
:root .clue{border-left:3px solid rgba(255,165,0,.35);padding-left:.6rem}
.guess.ok{background:rgba(46,204,113,.12)}
.guess.no{background:rgba(231,76,60,.10)}

/* ===== PREMIUM POLISH ===== */
/* Mobile */
@media (max-width:940px){
  .banner{margin-top:8px}
  .guess-row{box-shadow:0 -8px 18px rgba(0,0,0,.28);background:linear-gradient(180deg,rgba(0,0,0,0),rgba(0,0,0,.16));padding-top:8px;border-top-left-radius:12px;border-top-right-radius:12px}
  #today{opacity:.95;font-weight:700}
}
/* Desktop */
@media (min-width:941px){
  .content{max-width:1180px;padding-top:28px}
  .panel,.card{background:linear-gradient(180deg,rgba(255,255,255,.018),rgba(255,255,255,0));border:1px solid rgba(255,255,255,.06);box-shadow:0 18px 44px rgba(0,0,0,.34);backdrop-filter:blur(6px)}
  .ad-placeholder{min-height:68px;margin:10px 0 14px;border-radius:12px;opacity:.55}
  .tabs{position:sticky;top:12px;z-index:50;padding:8px;margin:10px 0 16px;border-radius:14px;background:linear-gradient(180deg,rgba(255,255,255,.02),rgba(255,255,255,0));border:1px solid rgba(255,255,255,.06);box-shadow:0 10px 28px rgba(0,0,0,.22);backdrop-filter:blur(5px)}
  .tab{padding:10px 16px;border-radius:12px}
  .tab.is-active{background:linear-gradient(180deg,var(--accent-weak),rgba(255,255,255,.03));border-color:var(--accent);box-shadow:0 10px 26px rgba(255,77,87,.16)}
  .game-head{padding-bottom:12px;margin-bottom:6px;border-bottom:1px solid rgba(255,255,255,.06)}
  .game .panel h3,.game .card h3{font-size:17px;letter-spacing:.2px;color:var(--muted)}
  .game .grid{grid-template-columns:minmax(0,1.15fr) minmax(0,1fr);gap:18px}
  input:focus{box-shadow:0 0 0 3px var(--accent-weak),0 10px 24px rgba(0,0,0,.28)}
  .btn:hover{box-shadow:0 8px 22px rgba(0,0,0,.32)}
  .banner.tip{margin-top:6px;border-radius:14px;background:linear-gradient(180deg,rgba(75,112,221,.12),rgba(75,112,221,.06));border:1px solid rgba(255,255,255,.06);box-shadow:0 8px 26px rgba(0,0,0,.26) inset}
}

/* ===== ADS (CLS-safe placeholders) ===== */
.ad-box{
  display:flex;align-items:center;justify-content:center;color:var(--muted);
  background:rgba(255,255,255,.02);border:1px dashed var(--border);border-radius:12px;text-align:center;font-size:13px
}
/* Fixed sizes to avoid CLS */
.ad-300x600{width:300px;height:600px}
.ad-300x250{width:300px;height:250px}
.ad-320x50{width:320px;height:50px}
@media (max-width:420px){ .ad-320x50{height:100px} }
/* Top banner */
.ad-placeholder{min-height:120px;opacity:.4;border:1px dashed rgba(255,255,255,.06)}
/* Inline/native in grid (desktop only) */
.ad-inline{display:none}
@media (min-width:1100px){ .ad-inline{display:block} }

/* Side rails aligned to content center */
.ad-rail{position:fixed;top:300px;z-index:40;opacity:0;pointer-events:none;transition:opacity .15s ease;display:none}
.ad-rail.show{opacity:1;pointer-events:auto}
.ad-rail--right{right:max(12px,calc((100vw - var(--content-max))/2 - (300px + var(--rail-gap))))}
.ad-rail--left{left:max(12px,calc((100vw - var(--content-max))/2 - (300px + var(--rail-gap))))}
@media (min-width:1280px){ .ad-rail--right{display:block} }
@media (min-width:1600px){ .ad-rail--left{display:block} }
@media (max-height:900px){ .ad-rail .ad-300x600{height:250px} }

/* Mobile bottom sticky (JS toggles .show) */
.ad-sticky{
  position:fixed;left:0;right:0;bottom:0;display:none;
  padding:10px 12px calc(env(safe-area-inset-bottom,0) + 10px);
  background:linear-gradient(180deg,rgba(0,0,0,0),rgba(0,0,0,.34));
  backdrop-filter:blur(6px); z-index:50;
  transform:translateY(12px); opacity:0; transition:transform .18s ease, opacity .18s ease;
}
.ad-sticky.show{display:block;transform:translateY(0);opacity:1}
.ad-sticky .ad-box{
  position:relative;margin:0 auto;width:min(320px,94vw);height:50px;border-radius:10px;background:var(--panel)
}
.ad-sticky .ad-close{
  position:absolute;right:6px;top:6px;width:30px;height:30px;border-radius:8px;border:1px solid var(--border);
  background:rgba(0,0,0,.35);color:var(--text);display:grid;place-items:center;cursor:pointer
}

/* Ads never eat clicks */
.ad-placeholder,.ad-inline,.panel .ad-placeholder{pointer-events:none}

/* ===== THEME TOGGLE (single floating) ===== */
.theme-emoji-btn.theme-floating{
  position:fixed;top:12px;right:12px;z-index:2000;
  width:44px;height:44px;border-radius:12px;border:1px solid var(--border);
  background:rgba(0,0,0,.15);color:var(--text);display:grid;place-items:center;cursor:pointer;
  transition:background-color .12s ease, transform .12s ease, border-color .12s ease;
}
.theme-emoji-btn.theme-floating:hover{transform:translateY(-1px);background:rgba(255,255,255,.08)}
:root[data-theme="dark"] .theme-emoji-btn.theme-floating{background:rgba(255,255,255,.06)}
.theme-emoji-btn:focus-visible{box-shadow:0 0 0 3px var(--accent-weak)}

/* ===== LANDING — HERO + CARDS ===== */
.hero{display:grid;grid-template-columns:1fr;align-items:center;gap:14px;padding:18px}
.hero-left{display:flex;gap:14px;align-items:flex-start}
.hero-logo{font-size:26px;filter:drop-shadow(0 6px 16px rgba(0,0,0,.25))}
.kicker{color:var(--muted);font-weight:700;letter-spacing:.3px;margin-bottom:2px}
.hero-title{margin:2px 0 6px;font-weight:900;line-height:1.15;font-size:clamp(22px,4.2vw,34px)}
.hero-sub{margin:0}
.hero-cta{display:flex;gap:10px;flex-wrap:wrap;margin-top:8px}
.hero-cta .btn{min-width:180px}
.game-card{
  display:grid;grid-template-rows:auto auto 1fr auto;gap:10px;padding:16px;text-decoration:none;
  transition:transform .12s ease, box-shadow .12s ease, border-color .12s ease;
  border:1px solid var(--border);border-radius:12px;background:var(--panel)
}
.game-card:hover{transform:translateY(-1px);box-shadow:0 14px 36px rgba(0,0,0,.32);border-color:rgba(0,0,0,.08)}
.game-card .game-headline{display:flex;align-items:center;gap:12px}
.game-card .game-icon{font-size:20px}
.game-card .game-title h2{margin:0;font-size:18px}
.game-card .badge{display:inline-block;margin-left:8px;padding:2px 8px;border-radius:999px;font-size:12px;font-weight:700;color:var(--text);border:1px solid var(--border);background:var(--panel)}
.game-card .game-meta{color:var(--muted);font-size:13px}
.game-card .game-actions .btn{width:fit-content}
@media (max-width:940px){
  [data-landing] .hero{padding:14px;gap:10px}
  [data-landing] .hero-cta{flex-direction:column}
  [data-landing] .hero-cta .btn{width:100%}
  .game-card{padding:14px;gap:8px}
  .game-card .game-actions .btn{width:100%}
}

/* ===== REDUCED MOTION ===== */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none !important;transition:none !important;scroll-behavior:auto !important}
}

/* ===== BACKDROP/BLUR FALLBACK ===== */
@supports not ((backdrop-filter:blur(4px)) or (-webkit-backdrop-filter:blur(4px))){
  .modal-backdrop{backdrop-filter:none}
  .panel,.card,.tabs{backdrop-filter:none;background:var(--card)}
}

/* ===== STREAK MODAL (compact) ===== */
.streak-list{display:grid;gap:8px;max-height:360px;overflow:auto}
.streak-item{display:flex;justify-content:space-between;align-items:center;border:1px solid var(--border);background:var(--panel);border-radius:10px;padding:8px 10px;font-size:14px}
.streak-item .pill{border-radius:999px;padding:4px 10px;border:1px solid var(--border);font-weight:700}
.pill.win{background:rgba(52,211,153,.15);color:#34d399}
.pill.lose{background:rgba(239,68,68,.15);color:#ef4444}

/* Ensure important elements sit above shadows */
.guess-row{position:relative;z-index:10}
.panel{position:relative}

/* === Landing: compact 2-up cards === */
.landing-grid{display:grid;grid-template-columns:1fr;gap:14px;margin-top:14px}
@media (min-width:900px){.landing-grid{grid-template-columns:1fr 1fr}}

.landing-card{
  background:var(--card);border:1px solid var(--border);
  border-radius:14px;padding:14px 16px;box-shadow:var(--shadow);
  transition:.15s ease; display:grid; gap:10px
}
.landing-card:hover{transform:translateY(-2px);box-shadow:0 10px 24px rgba(0,0,0,.18)}
.landing-card.is-cars{border-top:3px solid var(--accent)}
.landing-card.is-hoops{border-top:3px solid var(--steel)}
.landing-card .h{margin:0;font-size:20px;font-weight:800}
.landing-card .p{margin:0;color:var(--muted);font-size:14px}
.landing-card .btn{width:fit-content;padding:10px 14px;font-size:14px}

/* === Landing: blog preview === */
.landing-blog{margin-top:28px}
.section-head{display:flex;justify-content:space-between;align-items:center;margin:4px 0 12px}
.section-head h2{margin:0;font-size:22px;font-weight:800}
.section-head .more{font-weight:700}
.blog-grid{display:grid;grid-template-columns:1fr;gap:12px}
@media (min-width:900px){.blog-grid{grid-template-columns:repeat(3,1fr)}}
.blog-card{
  display:block;background:var(--panel);border:1px solid var(--border);
  border-radius:12px;padding:14px;transition:.12s ease
}
.blog-card:hover{border-color:var(--accent);transform:translateY(-1px)}
.blog-card h3{margin:0 0 6px;font-size:16px}
.blog-card p{margin:0;font-size:14px;color:var(--muted)}

/* === Topbar: add Blog link (desktop only) === */
.topbar-links{margin-left:auto;display:none;gap:16px;align-items:center}
.topbar-links a{font-weight:600;opacity:.9}
.topbar-links a:hover{text-decoration:underline}
@media (min-width:941px){.topbar-links{display:flex}}

/* ==== Sidebar layout ==== */
.app-shell {
  display: grid;
  grid-template-columns: 260px 1fr;
  min-height: calc(100vh - 48px); /* 48px if your utilitybar is ~48px tall */
}

/* top-left toggle button */
.sidebar-toggle {
  position: fixed;
  top: 8px; left: 8px;
  z-index: var(--z-topbar, 1000);
  display: inline-flex; align-items: center; justify-content: center;
  width: 36px; height: 36px;
  border-radius: 999px;
  background: var(--panel);
  border: 1px solid var(--border);
  color: var(--text);
  box-shadow: var(--shadow);
  cursor: pointer;
}
.sidebar-toggle:hover { filter: brightness(1.05); }

/* sidebar */
.sidebar {
  background: var(--panel);
  border-right: 1px solid var(--border);
  padding: 16px 12px;
}
.brand {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 8px; border-radius: 12px;
  text-decoration: none; color: var(--text);
}
.brand:hover { background: var(--card, #1d2026); }
.brand-icon { width: 28px; height: 28px; border-radius: 6px; }
.brand-text { display: flex; flex-direction: column; line-height: 1.1; }
.brand-title { font-weight: 800; }
.brand-sub { font-size: 12px; color: var(--muted); }

.side-links { margin-top: 14px; display: grid; gap: 6px; }
.side-links a {
  display: grid; grid-template-columns: 24px 1fr; align-items: center; gap: 10px;
  padding: 10px 10px; border-radius: 10px; color: var(--text); text-decoration: none;
}
.side-links a:hover { background: var(--card, #1d2026); }
.side-links .emoji { text-align: center; }
.side-links .label { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

.main { padding: 24px; }

/* ==== Collapsed state ==== */
body.sidebar-collapsed .app-shell {
  grid-template-columns: 72px 1fr; /* skinny rail */
}

body.sidebar-collapsed .brand-text,
body.sidebar-collapsed .side-links .label {
  display: none;
}

body.sidebar-collapsed .sidebar {
  padding: 16px 8px;
}

/* Keep utility bar spanning full width; ensure it sits above */
.utilitybar { position: sticky; top: 0; z-index: var(--z-topbar, 1000); }

/* Match landing order on mobile: brand | hamburger | toggle */
@media (max-width:768px){
  .header-fixed .nav-left { display:flex; align-items:center; }
  .header-fixed .nav-left .brand { order:0; }
  .header-fixed .nav-left .ham   { order:1; }
}
