/* ============================================================
   GARAGE PUNK — zine / scrapbook UI
   Palette: bone paper, oxblood red, ink, denim, mustard, moss.
   ============================================================ */
:root{
  --paper:#efe4cc; --paper2:#e4d5b3; --card:#fbf6ea; --card2:#f4ecda;
  --ink:#211d17; --ink2:#3a342a; --muted:#8f836c; --line:#d8c9a4;
  --red:#b5341f; --red2:#8f2416; --denim:#2b5c78; --denim2:#1f4257;
  --mustard:#d99a1c; --moss:#3d7a52; --paperhi:#fffaf0;
  --sh1:2px 2px 0 rgba(33,29,23,.9);
  --sh-card:0 2px 0 rgba(33,29,23,.18), 0 10px 22px -8px rgba(33,29,23,.35);
  --sh-pop:0 4px 0 rgba(33,29,23,.22), 0 18px 40px -10px rgba(33,29,23,.5);
  --r:12px; --r-sm:8px;
  --disp:"Bahnschrift","Arial Narrow",Impact,system-ui,sans-serif;
  --body:"Segoe UI",system-ui,-apple-system,sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:var(--body); color:var(--ink); line-height:1.45;
  background-color:#e8dcbf;
  background-image:
    repeating-linear-gradient(45deg, rgba(120,90,40,.03) 0 1px, transparent 1px 5px),
    repeating-linear-gradient(-45deg, rgba(120,90,40,.025) 0 1px, transparent 1px 7px),
    radial-gradient(120% 90% at 15% 0%, #f4ecd6 0%, #e6d7b6 60%, #ddcba6 100%);
  min-height:100vh;
}
#app{max-width:1120px;margin:0 auto;padding:0 16px 40px}

/* ---- typography ---- */
h1,h2,h3{font-family:var(--disp);font-weight:700;letter-spacing:.4px;margin:.15em 0;line-height:1.05}
h2{font-size:1.7rem;text-transform:uppercase}
h3{font-size:1.15rem}
small{font-weight:400;color:var(--muted)}
b{font-weight:700}

/* ---- buttons ---- */
button{font-family:var(--disp);font-size:.95rem;letter-spacing:.3px;cursor:pointer;
  border:2px solid var(--ink);border-radius:var(--r-sm);background:var(--card);color:var(--ink);
  padding:9px 14px;font-weight:700;box-shadow:var(--sh1);transition:transform .07s,box-shadow .07s,background .1s}
button:hover{transform:translate(-1px,-1px);box-shadow:3px 3px 0 rgba(33,29,23,.9)}
button:active{transform:translate(2px,2px);box-shadow:0 0 0 rgba(0,0,0,0)}
button:disabled{opacity:.4;cursor:not-allowed;box-shadow:none;transform:none}
button.primary{background:var(--red);color:#fff;border-color:var(--red2)}
button.primary:hover{background:var(--red2)}
button.ghost{background:transparent;box-shadow:none}
button.ghost:hover{background:rgba(33,29,23,.06);box-shadow:none;transform:none}
button.big{font-size:1.1rem;padding:13px 18px;width:100%;margin-top:12px;text-transform:uppercase}
button.sm{padding:6px 11px;font-size:.82rem}
button.mini{padding:5px 9px}
button small{color:inherit;opacity:.8;font-weight:600}

input,select{font-family:var(--body);font-size:.95rem;padding:9px 11px;border:2px solid var(--ink);
  border-radius:var(--r-sm);background:var(--paperhi);width:100%;color:var(--ink)}
input:focus,select:focus{outline:none;border-color:var(--denim);box-shadow:0 0 0 3px rgba(43,92,120,.18)}
label{display:block;font-family:var(--disp);font-weight:700;font-size:.82rem;text-transform:uppercase;
  letter-spacing:.5px;color:var(--ink2);margin:10px 0}
label input,label select{margin-top:4px;font-family:var(--body);font-weight:400;text-transform:none;letter-spacing:0}

.card{background:var(--card);border:2px solid var(--ink);border-radius:var(--r);padding:16px;box-shadow:var(--sh-card)}

/* ============================================================
   TOP BAR + NAV (sticky header block)
   ============================================================ */
.topbar{position:sticky;top:0;z-index:30;display:flex;flex-wrap:wrap;gap:10px;align-items:center;
  justify-content:space-between;background:linear-gradient(180deg,#2a251d,#211d17);
  color:var(--paper);padding:11px 16px;border:2px solid var(--ink);border-radius:0 0 var(--r) var(--r);
  box-shadow:var(--sh-card);margin-bottom:12px}
.topbar .brand{font-family:var(--disp);font-size:1.35rem;font-weight:700;line-height:1;letter-spacing:.5px;
  display:flex;align-items:center;gap:8px}
.topbar .brand small{color:#d8c39a;display:block;font-size:.68rem;letter-spacing:1px;text-transform:uppercase;margin-top:2px}
.stats{display:flex;flex-wrap:wrap;gap:5px}
.pill{display:inline-flex;align-items:center;gap:4px;background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.12);padding:4px 10px;border-radius:20px;font-size:.8rem;
  font-weight:700;white-space:nowrap;color:#f3e9d2}
.pill.good{background:var(--moss);border-color:transparent;color:#fff}
.pill.bad{background:var(--red);border-color:transparent;color:#fff}

.nav{position:sticky;top:64px;z-index:20;display:flex;flex-wrap:wrap;gap:6px;margin-bottom:16px;
  padding:8px;background:var(--card);border:2px solid var(--ink);border-radius:var(--r);box-shadow:var(--sh-card)}
.navbtn{background:transparent;border-color:transparent;box-shadow:none;text-transform:uppercase;
  font-size:.82rem;padding:7px 12px;color:var(--ink2)}
.navbtn:hover{background:var(--paper2);box-shadow:none;transform:none}
.navbtn.on{background:var(--denim);border-color:var(--denim2);color:#fff;box-shadow:var(--sh1)}
.navbtn.adv{margin-left:auto;background:var(--mustard);border-color:#a9781a;color:var(--ink);box-shadow:var(--sh1)}
.navbtn.adv:hover{background:#c98c15;transform:translate(-1px,-1px)}

/* ---- section header w/ marker underline ---- */
.screen h2{position:relative;padding-bottom:8px;margin-bottom:14px;display:flex;align-items:baseline;gap:10px;flex-wrap:wrap}
.screen h2::after{content:"";position:absolute;left:0;bottom:0;width:100%;height:4px;
  background:var(--ink);border-radius:2px}
.screen h2 small{font-size:.85rem;text-transform:none;letter-spacing:0}
.hint{color:var(--ink2);font-size:.9rem;margin:2px 0 16px;max-width:70ch}
.warn{color:var(--red);font-weight:700;background:#f7e2dc;border:1px solid var(--red);
  padding:8px 12px;border-radius:var(--r-sm);display:inline-block}
.rowbtns{margin-top:16px}

/* ============================================================
   NEW GAME
   ============================================================ */
.newgame{max-width:540px;margin:5vh auto;text-align:center}
.logo{font-family:Impact,var(--disp);font-size:4rem;line-height:.88;color:var(--ink);
  text-shadow:4px 4px 0 var(--red),4px 4px 0 var(--red);letter-spacing:1px;transform:rotate(-1.5deg)}
.logo span{color:var(--red);text-shadow:4px 4px 0 var(--ink)}
.tag{color:var(--ink2);font-style:italic;font-size:1.05rem;margin:14px 0 22px}
.form{text-align:left}
.form .mini{margin-top:-4px;margin-bottom:8px}

/* ============================================================
   GRIDS + MEMBER CARDS
   ============================================================ */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(236px,1fr));gap:14px}

.member{display:flex;flex-direction:column;align-items:center;text-align:center;position:relative;transition:transform .1s}
.member:hover{transform:translateY(-2px)}
.member.inband{outline:3px solid var(--moss);outline-offset:2px}
.member.inband::before{content:"IN BAND";position:absolute;top:-9px;right:10px;background:var(--moss);color:#fff;
  font-family:var(--disp);font-size:.62rem;letter-spacing:1px;padding:2px 8px;border-radius:10px;z-index:2}
.avatar{border-radius:10px;overflow:hidden;border:2px solid var(--ink);background:#fff;margin-bottom:8px;
  box-shadow:var(--sh1)}
.avatar svg{display:block}
.mhead{width:100%}
.mhead b{font-size:1.1rem;font-family:var(--disp)}
.role{display:block;font-size:.78rem;color:var(--denim);font-weight:700;text-transform:uppercase;letter-spacing:.5px}
.tier{font-size:.7rem;font-weight:700;margin:4px 0;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}
.talentrow{display:flex;align-items:center;gap:8px;margin:2px 0 6px;flex-wrap:wrap}
.stars{letter-spacing:1px;font-size:1rem;line-height:1}
.star.on{color:var(--mustard)} .star.half{color:var(--mustard);opacity:.6}
.star.pot{color:var(--mustard);opacity:.28} .star.off{color:var(--muted);opacity:.4}
.legendtitle{font-size:.72rem;font-weight:800;color:var(--ink2);text-transform:uppercase;letter-spacing:.5px}
.talentbig{display:flex;align-items:center;gap:8px;margin-bottom:8px}
.talentbig .stars{font-size:1.25rem}
.talentbig b{font-family:var(--disp)}
.mbar-f.xp{background:var(--mustard)}
.tier.t-star{color:var(--mustard)} .tier.t-hot{color:var(--red)}
.statrow{display:flex;align-items:center;gap:8px;width:100%;font-size:.74rem;margin:3px 0}
.statlbl{width:62px;text-align:left;color:var(--muted);text-transform:uppercase;font-size:.66rem;letter-spacing:.4px}
.statbar{flex:1;height:9px;background:#e0d3b2;border-radius:5px;overflow:hidden;border:1px solid var(--line)}
.statbar i{display:block;height:100%;background:linear-gradient(90deg,var(--denim),#3d7ba0);border-radius:5px}
.statnum{width:22px;text-align:right;font-weight:700}
.egoline{font-size:.7rem;color:var(--muted);margin:7px 0;font-weight:600}
.chips{display:flex;flex-wrap:wrap;gap:4px;justify-content:center;margin:6px 0}
.chip{font-size:.66rem;padding:2px 7px;border-radius:10px;border:1px solid var(--ink);font-weight:700}
.chip.creative{background:#d8ecd8} .chip.drama{background:#f6ddd6}

/* ============================================================
   WRITE
   ============================================================ */
.focusgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(155px,1fr));gap:9px;margin-top:10px}
.focusbtn{display:flex;flex-direction:column;gap:3px;text-align:left;background:var(--paperhi);align-items:flex-start;padding:11px}
.focusbtn:hover{background:var(--mustard);color:var(--ink)}
.focusbtn b{font-size:.92rem;font-family:var(--disp)} .focusbtn span{font-size:.72rem;color:var(--muted);font-weight:400;line-height:1.3}
.focusbtn:hover span{color:var(--ink2)}
.songlist{display:flex;flex-direction:column;gap:7px;margin-top:8px}
.songrow{display:grid;grid-template-columns:auto 1fr auto auto;align-items:center;gap:12px;background:var(--card);
  border:2px solid var(--ink);border-radius:var(--r-sm);padding:9px 12px;box-shadow:var(--sh1)}
.songrow b{font-family:var(--body)}
.songrow .minidim{font-size:.76rem;color:var(--muted);white-space:nowrap}
.songrow .focus{font-size:.68rem;background:var(--paper2);padding:3px 8px;border-radius:8px;text-transform:uppercase;letter-spacing:.5px;font-weight:700}

.score{display:inline-flex;align-items:center;justify-content:center;min-width:34px;height:26px;
  font-family:var(--disp);font-weight:700;font-size:.95rem;color:#fff;border-radius:6px;padding:0 6px;box-shadow:var(--sh1)}
.sc-hi{background:var(--moss)} .sc-mid{background:var(--denim)}
.sc-lo{background:var(--mustard);color:var(--ink)} .sc-bad{background:var(--red)}

/* ============================================================
   STUDIO  (fixed: robust grid rows)
   ============================================================ */
.studiowrap{display:grid;grid-template-columns:1fr 280px;gap:14px;align-items:start}
.picklist{padding:0;overflow:hidden}
.picklist-head{display:flex;justify-content:space-between;padding:10px 14px;background:var(--ink);color:var(--paper);
  font-family:var(--disp);font-size:.72rem;text-transform:uppercase;letter-spacing:1px}
.picklist-rows{display:flex;flex-direction:column;max-height:62vh;overflow:auto;padding:8px}
.pickrow{display:grid;grid-template-columns:22px 40px 1fr auto auto;align-items:center;gap:11px;
  padding:9px 11px;border:2px solid transparent;border-bottom:1px solid var(--line);border-radius:var(--r-sm);
  cursor:pointer;transition:background .1s}
.pickrow:hover{background:var(--paper2)}
.pickrow.on{border-color:var(--moss);background:#eef6ea}
.pcheck{width:18px;height:18px;accent-color:var(--moss);cursor:pointer}
.ptitle{font-weight:700;font-size:.95rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.pdims{font-size:.76rem;color:var(--muted);white-space:nowrap}
.pfocus{font-size:.64rem;background:var(--paper2);padding:3px 7px;border-radius:8px;text-transform:uppercase;
  letter-spacing:.5px;font-weight:700;color:var(--ink2)}

.releasebox{position:sticky;top:130px;text-align:center}
.rb-type{font-family:var(--disp);font-size:2rem;font-weight:700;text-transform:uppercase;color:var(--muted);letter-spacing:1px}
.rb-type.rb-active{color:var(--red)}
.rb-count{font-weight:700;margin-top:2px}
.rb-hint{font-size:.82rem;color:var(--muted);margin:4px 0 6px;font-style:italic}
.releasebox label{text-align:left}

/* ============================================================
   MODALS (release / show / event / month / awards / ending)
   ============================================================ */
.overlay{position:fixed;inset:0;background:rgba(20,17,12,.74);backdrop-filter:blur(2px);
  display:flex;align-items:center;justify-content:center;z-index:60;padding:16px}
.modal-wrap{width:100%;max-width:460px}
.release-result,.monthcard,.eventcard,.ending{box-shadow:var(--sh-pop)}
.release-result{text-align:center;animation:pop .28s}
@keyframes pop{from{transform:scale(.9) translateY(8px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}
.release-result .cover{display:flex;justify-content:center;margin-bottom:10px}
.release-result .cover svg{border:3px solid var(--ink);border-radius:6px;box-shadow:var(--sh1)}
.verdict{font-family:var(--disp);font-size:1.8rem;margin:6px 0;transform:rotate(-1.5deg);text-transform:uppercase}
.v-classicalbum,.v-mainstreamhit{color:var(--moss)}
.v-criticsdarling,.v-cultfavorite{color:var(--denim)}
.v-flop{color:var(--red)}
.scoregrid{display:flex;gap:12px;justify-content:center;margin:12px 0}
.bigscore{display:flex;flex-direction:column;align-items:center;padding:10px 20px;border-radius:10px;color:#fff;box-shadow:var(--sh1)}
.bigscore span{font-size:.72rem;text-transform:uppercase;letter-spacing:1px} .bigscore b{font-size:2.2rem;line-height:1;font-family:var(--disp)}
.reslist{list-style:none;padding:0;text-align:left;max-width:300px;margin:10px auto}
.reslist li{border-bottom:1px dashed var(--line);padding:6px 2px}
.good{color:var(--moss)} .bad{color:var(--red)}

/* ============================================================
   GEAR
   ============================================================ */
.gearcard{position:relative;display:flex;flex-direction:column;gap:3px}
.gearcard.owned{opacity:.72;outline:2px solid var(--moss)}
.gearcat{font-size:.68rem;color:var(--denim);font-weight:700;text-transform:uppercase;letter-spacing:.6px}
.gearcard b{font-family:var(--disp);font-size:1.02rem}
.offgenre{color:var(--red)}
.effs{font-size:.82rem;margin:4px 0;color:var(--ink2)}
.forgenre{font-size:.72rem;color:var(--muted);margin-bottom:6px}
.ownedtag{color:var(--moss);font-weight:900;font-family:var(--disp)}

/* ---- gear tabs + era lock + loadout ---- */
.gtabs{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:14px}
.gtab{background:var(--paper2);border-color:transparent;box-shadow:none;font-size:.82rem;padding:7px 12px}
.gtab:hover{background:var(--mustard);transform:none}
.gtab.on{background:var(--denim);color:#fff;box-shadow:var(--sh1)}
.gyear{font-family:var(--disp);background:var(--ink);color:var(--paper);padding:1px 7px;border-radius:8px;font-size:.7rem}
/* gear icons + marketplace cards */
.gicon{width:44px;height:44px;flex-shrink:0;display:grid;place-items:center;background:var(--paperhi);border:2px solid var(--ink);border-radius:8px;padding:3px;box-shadow:var(--sh1);overflow:hidden}
.gicon img,.gicon-svg{width:100%;height:100%;display:block;object-fit:contain}
.gicon-svg{display:none}
.geartop{display:flex;gap:10px;align-items:flex-start;margin-bottom:2px}
.gearmeta{flex:1;min-width:0}
.gearmeta b{display:block;line-height:1.1;font-size:.92rem}
.gearpills{display:flex;flex-wrap:wrap;gap:5px;align-items:center;margin-top:4px}
.cond{font-size:.6rem;font-weight:800;text-transform:uppercase;letter-spacing:.5px;padding:1px 7px;border-radius:8px;border:1.5px solid var(--ink)}
.cond-new{background:var(--moss);color:#fff;border-color:var(--moss)}
.cond-used{background:var(--paper2);color:var(--ink2)}
.cond-mojo{background:#c9a26a;color:var(--ink)}
.cond-mod{background:var(--red);color:#fff;border-color:var(--red)}
.cond-reissue{background:var(--denim);color:#fff;border-color:var(--denim)}
.cond-vintage{background:var(--mustard);color:var(--ink)}
.cond-sig{background:#7d3cc0;color:#fff;border-color:#7d3cc0}
.cond-boutique{background:#b5341f;color:#fff;border-color:#b5341f}
.cond-custom{background:var(--ink);color:var(--paper)}
.vintagecard{background:linear-gradient(180deg,#fbf1d6,var(--card))}
.shophead{font-family:var(--disp);font-size:1.05rem;letter-spacing:.5px;margin:20px 0 10px;border-bottom:2px solid var(--ink);padding-bottom:4px}
.shophead small{font-weight:400;color:var(--muted);text-transform:none;letter-spacing:0}
.slotchip .gicon{width:30px;height:30px;padding:2px;margin-bottom:2px}
.assignrow .gicon{width:34px;height:34px;position:absolute;right:10px;top:10px}
.gearcard.locked{opacity:.55;filter:grayscale(.4)}
.unassigned{color:var(--red)}
.loadout{display:flex;flex-wrap:wrap;gap:5px;width:100%;margin:6px 0}
.slotchip{display:flex;flex-direction:column;align-items:flex-start;gap:1px;text-align:left;background:var(--paperhi);
  padding:5px 9px;font-size:.7rem;flex:1;min-width:80px;box-shadow:none;border-width:2px}
.slotchip.empty{border-style:dashed;color:var(--muted)}
.slotchip.filled{border-color:var(--denim)}
.slotchip:hover{background:var(--mustard);transform:none}
.slotlbl{text-transform:uppercase;letter-spacing:.5px;font-size:.6rem;color:var(--muted)}
.slotchip.filled .slotlbl{color:var(--denim)}
.slotval{font-weight:700;font-family:var(--body)}
.assigncard{max-width:440px;box-shadow:var(--sh-pop)}
.assignlist{display:flex;flex-direction:column;gap:6px;margin:10px 0;max-height:50vh;overflow:auto}
.assignrow{display:flex;flex-direction:column;align-items:flex-start;gap:2px;text-align:left;background:var(--paperhi);position:relative}
.assignrow.on{border-color:var(--moss);background:#eef6ea}
.assignrow b{font-family:var(--body)} .assignrow span{font-size:.76rem;color:var(--muted)}
.assignrow i{color:var(--denim);font-style:normal}
.eqtag{position:absolute;top:8px;right:10px;background:var(--moss);color:#fff;font-size:.6rem;padding:2px 7px;border-radius:8px;font-family:var(--disp);letter-spacing:.5px}

/* ============================================================
   PRESS
   ============================================================ */
.magazine{background:var(--paperhi);border:2px solid var(--ink);border-radius:6px;padding:20px;box-shadow:var(--sh-card);max-width:640px}
.masthead{font-family:Impact,var(--disp);font-size:2.6rem;letter-spacing:3px;border-bottom:4px double var(--ink);margin-bottom:12px}
.masthead small{font-size:.85rem;letter-spacing:0}
.headline{font-family:var(--disp);font-weight:700;font-size:1.35rem;margin-bottom:14px;background:var(--ink);
  color:var(--paper);padding:7px 12px;display:inline-block;transform:rotate(-.8deg);box-shadow:var(--sh1)}
.trendbox p{margin:7px 0}
.reppath{margin-top:14px;font-size:1.05rem;border-top:2px dashed var(--line);padding-top:10px}

/* ============================================================
   DISCOGRAPHY
   ============================================================ */
.discoitem{display:flex;gap:12px;align-items:center}
.discoitem .cover svg{border:2px solid var(--ink);border-radius:4px;box-shadow:var(--sh1)}
.discoitem b{font-family:var(--disp);font-size:1.05rem}
.verdict-sm{font-family:var(--disp);font-weight:700;color:var(--red);font-size:.82rem;text-transform:uppercase}

/* ---- game over ---- */
.gameover{text-align:center;box-shadow:var(--sh-pop)}
.gameover h2{color:var(--red);font-size:2rem}

/* ============================================================
   LIVE SHOWS
   ============================================================ */
.venue{display:flex;flex-direction:column;gap:8px}
.venue.locked{opacity:.55}
.vname{font-family:var(--disp);font-size:1.1rem;font-weight:700}
.vmeta{font-size:.78rem;color:var(--muted);line-height:1.4}
.vlock{font-size:.82rem;color:var(--red);font-weight:700}
.attn{font-weight:700;margin:6px 0;font-family:var(--disp);font-size:1.05rem}
.shownote{font-style:italic;color:var(--ink2);margin:8px 0}

/* ============================================================
   TEAM: staff + tree + evolve
   ============================================================ */
.staffcard{display:flex;flex-direction:column;gap:5px}
.staffcard.owned{outline:2px solid var(--moss)}
.staffcard b{font-family:var(--disp);font-size:1.02rem}
.staffblurb{font-size:.82rem;color:var(--muted);flex:1;line-height:1.35}
.staffcost{font-weight:700;font-size:.85rem}
.tree{display:flex;flex-direction:column;gap:5px;max-width:580px}
.treenode{display:flex;align-items:center;gap:12px;padding:10px 12px;border:2px solid var(--line);border-radius:var(--r-sm);background:var(--card)}
.treenode.done{border-color:var(--moss);background:#eef6ea}
.treenode.cur{border-color:var(--mustard);background:#fbf1d8;box-shadow:var(--sh1)}
.treenode.lock{opacity:.5}
.tndot{width:28px;height:28px;border-radius:50%;background:var(--ink);color:var(--paper);display:flex;
  align-items:center;justify-content:center;font-weight:700;font-size:.9rem;flex-shrink:0;font-family:var(--disp)}
.treenode.done .tndot{background:var(--moss)}
.treenode.cur .tndot{background:var(--mustard);color:var(--ink)}
.tnlabel{flex:1;font-weight:700}

.tourbar{background:var(--card);border:2px solid var(--ink);border-radius:var(--r-sm);padding:10px 14px;
  margin-bottom:12px;font-weight:700;box-shadow:var(--sh1)}
.tourbar select{width:auto;display:inline-block;margin:0 5px}
.tourbar small{font-weight:400;color:var(--muted)}
.vbtns{display:flex;gap:7px}
.vbtns button{flex:1}

/* ---- month summary ---- */
.monthcard{max-width:440px;text-align:center;animation:pop .28s}
.masthead-sm{font-family:Impact,var(--disp);font-size:2rem;letter-spacing:2px;border-bottom:3px double var(--ink);margin-bottom:10px}
.monthcard .headline{font-size:1.05rem;margin-bottom:12px}
.risers{color:var(--moss);font-weight:700;font-size:.85rem}
.monthbal{margin:10px 0;font-size:1.15rem;font-weight:700;border-top:2px dashed var(--line);padding-top:10px;font-family:var(--disp)}

/* ---- career panel ---- */
.careerpanel{margin-top:16px;max-width:640px}
.careerhead{font-family:var(--disp);font-size:1.15rem;text-transform:uppercase;border-bottom:2px solid var(--ink);margin-bottom:10px;padding-bottom:4px}
.rankrow{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.rankbadge{font-family:var(--disp);font-size:1.2rem;padding:5px 14px;border-radius:8px;color:#fff;background:var(--ink);text-transform:uppercase;box-shadow:var(--sh1)}
.rank-legend{background:linear-gradient(90deg,var(--mustard),var(--red));color:#fff}
.rank-mainstream{background:var(--red)} .rank-critical{background:var(--denim)}
.rank-corporate{background:#555} .rank-cult{background:var(--mustard);color:var(--ink)}
.rank-working{background:var(--moss)} .rank-nobody{background:var(--muted)}
.reppath-sm{color:var(--muted);font-size:.9rem}
.rankblurb{font-style:italic;color:var(--ink2);margin:8px 0}
.goalline{font-size:.85rem;background:var(--paper2);padding:10px 12px;border-radius:var(--r-sm);margin:10px 0}

/* ---- era timeline ---- */
.erapill{background:rgba(217,154,28,.25)!important;border-color:rgba(217,154,28,.5)!important;color:#f3e0b0!important}
.timeline{margin-top:16px;max-width:680px}
.eraflags{font-size:.82rem;font-weight:700;color:var(--ink2);margin-bottom:10px}
.eras{display:flex;flex-direction:column;gap:8px}
.erarow{display:grid;grid-template-columns:74px 1fr;gap:12px;padding:10px 12px;border:2px solid var(--line);
  border-left:6px solid var(--ec);border-radius:var(--r-sm);background:var(--card);opacity:.62}
.erarow.now{opacity:1;border-color:var(--ec);background:var(--paperhi);box-shadow:var(--sh1)}
.erarow.past{opacity:.5}
.erayears{font-family:var(--disp);font-weight:700;font-size:.9rem;color:var(--ec)}
.eraname{font-family:var(--disp);font-size:1.05rem;font-weight:700}
.eranow{color:var(--red);font-size:.7rem;letter-spacing:1px}
.eratag{font-size:.82rem;color:var(--muted);font-style:italic}
.eradetail{font-size:.82rem;margin-top:6px;line-height:1.5;background:var(--paper2);padding:8px 10px;border-radius:6px}
.eratrans{text-align:center;border-top:8px solid var(--ec);box-shadow:var(--sh-pop);animation:pop .4s}
.milestonecard{border-top:6px solid var(--mustard)}

/* ---- evolve panel ---- */
.evolvepanel{margin-top:18px;max-width:640px}
.evolvepanel b{font-family:var(--disp);font-size:1.1rem;text-transform:uppercase}
.evolvebtns{display:flex;flex-wrap:wrap;gap:7px;margin-top:8px}
.evolvebtn small{color:var(--red);font-weight:400}

/* ---- endings ---- */
.ending{max-width:490px;text-align:center;animation:pop .4s}
.endkicker{letter-spacing:5px;font-weight:700;color:var(--muted);font-size:.78rem;font-family:var(--disp)}
.endtitle{font-family:var(--disp);font-size:2.6rem;line-height:1;margin:8px 0;color:var(--ink);text-shadow:3px 3px 0 var(--mustard);text-transform:uppercase}
.ending-legend .endtitle{background:linear-gradient(90deg,var(--red),var(--mustard));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;text-shadow:none}
.endblurb{font-size:1.05rem;line-height:1.45;margin:12px 0}
.endstats{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin:16px 0;padding:12px 0;border-top:2px dashed var(--line);border-bottom:2px dashed var(--line)}
.endstats span{display:flex;flex-direction:column;font-size:.68rem;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}
.endstats b{font-size:1.5rem;color:var(--ink);font-family:var(--disp)}
.endbtns{display:flex;gap:9px} .endbtns button{flex:1}

/* ---- event modal ---- */
.eventcard{max-width:470px;text-align:center;animation:pop .28s}
.eventtitle{font-size:1.6rem;transform:rotate(-1deg)}
.eventtext{font-size:1.02rem;line-height:1.45;margin:12px 0}
.eventchoices{display:flex;flex-direction:column;gap:9px}
.eventchoice{display:flex;flex-direction:column;text-align:left;gap:2px;background:var(--paperhi)}
.eventchoice:hover{background:var(--mustard)}
.eventchoice b{font-size:.95rem;font-family:var(--disp)} .eventchoice span{font-size:.78rem;color:var(--muted);font-weight:400}
.eventchoice:hover span{color:var(--ink2)}

/* ============================================================
   JAM SPOT — animated rehearsal scene
   ============================================================ */
.spotpick{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px}
.spotcard{display:flex;flex-direction:column;align-items:flex-start;gap:2px;text-align:left;
  background:var(--card);flex:1;min-width:160px;padding:10px 12px}
.spotcard.on{background:var(--denim);color:#fff;border-color:var(--denim2)}
.spotcard.on .spotmeta,.spotcard.on .spotblurb{color:rgba(255,255,255,.85)}
.spotcard b{font-family:var(--disp);font-size:1rem}
.spotmeta{font-size:.72rem;color:var(--denim);font-weight:700}
.spotblurb{font-size:.74rem;color:var(--muted);line-height:1.3}
.spotcard.locked{opacity:.5}

.jamstage{position:relative;height:280px;border:3px solid var(--ink);border-radius:var(--r);overflow:hidden;
  box-shadow:inset 0 0 60px rgba(0,0,0,.5),var(--sh-card);margin-bottom:12px}
.bg-garage{background:linear-gradient(180deg,#6b5a44,#37302a 70%),repeating-linear-gradient(90deg,rgba(0,0,0,.1) 0 60px,transparent 60px 62px)}
.bg-basement{background:linear-gradient(180deg,#4a4a52,#26262c),repeating-linear-gradient(0deg,rgba(255,255,255,.03) 0 24px,transparent 24px 26px)}
.bg-warehouse{background:linear-gradient(180deg,#5a5f66,#2b2f36)}
.bg-studio{background:linear-gradient(180deg,#3a2f3f,#211a26)}
.bg-lockout{background:linear-gradient(180deg,#3a2b1f,#1e1712)}
.jamstage .ampglow{position:absolute;left:50%;top:60%;width:340px;height:340px;transform:translate(-50%,-50%);
  background:radial-gradient(circle,rgba(217,154,28,.5),transparent 65%);animation:glow 1.1s ease-in-out infinite alternate;pointer-events:none}
@keyframes glow{from{opacity:.35;transform:translate(-50%,-50%) scale(.9)}to{opacity:.8;transform:translate(-50%,-50%) scale(1.08)}}
.jammers{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;gap:clamp(6px,3vw,34px);z-index:2}
.jammer{display:flex;flex-direction:column;align-items:center;animation:bob .55s ease-in-out infinite alternate}
@keyframes bob{from{transform:translateY(4px)}to{transform:translateY(-11px)}}
.jamav{width:72px;height:72px;border-radius:10px;overflow:hidden;border:2px solid #111;box-shadow:0 6px 12px rgba(0,0,0,.5)}
.jamav svg{display:block}
.jaminst{font-size:1.5rem;line-height:1;margin-bottom:2px;filter:drop-shadow(0 2px 2px rgba(0,0,0,.6))}
.jamname{font-family:var(--disp);font-size:.72rem;color:#fff;background:rgba(0,0,0,.4);padding:1px 8px;border-radius:8px;margin-top:4px;letter-spacing:.5px}
.eq{position:absolute;left:0;right:0;bottom:0;height:46px;display:flex;align-items:flex-end;justify-content:center;
  gap:4px;padding:0 10px;z-index:1;opacity:.85}
.eq span{width:8px;height:20%;background:linear-gradient(180deg,var(--mustard),var(--red));border-radius:2px 2px 0 0;
  animation:eqbar .5s ease-in-out infinite alternate}
@keyframes eqbar{from{height:8%}to{height:95%}}
.jamnotes .jn{position:absolute;font-size:1.4rem;color:rgba(255,255,255,.7);z-index:2;animation:floatup 2.6s linear infinite}
.jn.n1{left:30%;animation-delay:0s} .jn.n2{left:45%;animation-delay:.8s}
.jn.n3{left:60%;animation-delay:1.5s} .jn.n4{left:70%;animation-delay:2.1s}
@keyframes floatup{0%{bottom:40px;opacity:0} 15%{opacity:.9} 100%{bottom:250px;opacity:0}}
.spotlabel{position:absolute;top:8px;left:10px;font-family:var(--disp);font-size:.75rem;color:#fff;
  background:rgba(0,0,0,.45);padding:3px 10px;border-radius:8px;letter-spacing:1px;text-transform:uppercase;z-index:3}

.jammeters{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:12px}
.jmeter{flex:1;min-width:200px}
.jmlbl{font-size:.82rem;font-weight:700;display:block;margin-bottom:4px}
.jmbar{display:block;height:12px;background:#e0d3b2;border:2px solid var(--ink);border-radius:7px;overflow:hidden}
.jmbar i{display:block;height:100%;border-radius:5px;transition:width .3s}
.jamcontrols label{text-transform:none;letter-spacing:0}
.jamcontrols input[type=range]{accent-color:var(--red)}
.jambtns{display:flex;gap:9px;flex-wrap:wrap}
.jambtns button{flex:1;min-width:130px;flex-direction:column;display:flex;gap:1px}
.jambtns button small{color:rgba(255,255,255,.85);font-weight:600;text-transform:none}

/* ---- story decision cards ---- */
.storycard{max-width:520px;border-top:6px solid var(--mustard);
  background:linear-gradient(180deg,#fdf8ec,var(--card))}
.storycard .endkicker{color:var(--red);margin-bottom:4px}
.storycard .eventtitle{font-size:1.7rem}
.storycard .eventtext{font-size:1.05rem;text-align:left;line-height:1.5}

/* ---- toast ---- */
.toast{position:fixed;bottom:22px;left:50%;transform:translateX(-50%) translateY(20px);
  background:var(--ink);color:var(--paper);padding:11px 20px;border-radius:24px;font-weight:700;
  font-family:var(--disp);letter-spacing:.3px;opacity:0;transition:all .3s;z-index:100;box-shadow:var(--sh-pop)}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast.good{background:var(--moss)} .toast.bad{background:var(--red)}

/* ---- tone lab ---- */
.tonelab{margin-bottom:18px;background:linear-gradient(180deg,var(--card),var(--card2))}
.tonelab-head{display:flex;flex-direction:column;gap:2px;margin-bottom:12px}
.tonelab-head h3{margin:0;font-family:var(--disp);font-size:1.15rem;letter-spacing:.5px}
.tonelab-head h3 small{color:var(--red);font-weight:700;text-transform:uppercase;font-size:.7rem;margin-left:6px}
.tonelab-head .hint{margin:0}
.tonegrid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.tonecol{background:var(--paperhi);border:2px solid var(--ink);border-radius:var(--r-sm);padding:11px 13px;box-shadow:var(--sh1)}
.tonecol-head{display:flex;justify-content:space-between;align-items:center;font-family:var(--disp);
  font-weight:700;font-size:.9rem;margin-bottom:9px;padding-bottom:7px;border-bottom:2px dotted var(--line)}
.tmatch{font-family:var(--disp);font-weight:800;font-size:1.05rem;color:var(--ink2)}
.tmatch small{font-weight:400;color:var(--muted);font-size:.6rem;margin-left:2px}
.tmatch.good{color:var(--moss)} .tmatch.bad{color:var(--red)}
.tbar-row{display:grid;grid-template-columns:96px 1fr 26px;align-items:center;gap:9px;margin:6px 0}
.tbar-lab{font-size:.72rem;color:var(--ink2);font-weight:600;white-space:nowrap}
.tbar-track{position:relative;height:11px;background:var(--paper2);border:1px solid var(--ink);border-radius:6px;overflow:hidden}
.tbar-fill{position:absolute;left:0;top:0;bottom:0;background:var(--denim);border-radius:6px 0 0 6px}
.tbar-fill.hit{background:var(--moss)}
.tbar-ideal{position:absolute;top:-2px;bottom:-2px;width:2px;background:var(--red);transform:translateX(-1px);z-index:2}
.tbar-val{font-size:.7rem;color:var(--muted);text-align:right;font-variant-numeric:tabular-nums}
.synergies{display:flex;flex-wrap:wrap;gap:7px;margin-top:12px}
.syn{font-size:.72rem;font-weight:700;padding:3px 9px;border:2px solid var(--ink);border-radius:12px;
  background:var(--mustard);color:var(--ink);box-shadow:var(--sh1);cursor:help}
.rig{margin-top:13px;border-top:2px dotted var(--line);padding-top:11px}
.rig-head{font-family:var(--disp);font-weight:700;font-size:.82rem;text-transform:uppercase;letter-spacing:.5px;
  color:var(--ink2);margin-bottom:8px}
.rigrow{display:grid;grid-template-columns:150px 1fr;gap:10px;align-items:center;padding:6px 0;border-bottom:1px dotted var(--line)}
.rigrow>b{font-size:.82rem}
.knobs{display:flex;flex-wrap:wrap;gap:12px}
.knob{display:flex;align-items:center;gap:7px;font-size:.72rem}
.knob-lab{color:var(--ink2);font-weight:600;min-width:52px}
.knob input[type=range]{width:96px;padding:0;height:16px;accent-color:var(--red);border:none;background:transparent}
.knob-val{font-weight:700;color:var(--denim);min-width:26px;font-variant-numeric:tabular-nums}

/* ---- inner life ---- */
.lifestrip{display:flex;flex-wrap:wrap;align-items:center;gap:6px;margin:8px 0 4px}
.moodpill{font-size:.72rem;font-weight:800;padding:2px 8px;border:2px solid var(--ink);border-radius:12px;
  background:var(--paperhi);color:var(--ink);font-variant-numeric:tabular-nums}
.moodpill.good{background:var(--moss);color:#fff;border-color:var(--moss)}
.moodpill.bad{background:var(--red);color:#fff;border-color:var(--red)}
.ambchip{font-size:.7rem;color:var(--ink2);font-weight:600;flex:1;min-width:90px}
.btn.xs,.ghost.xs{font-size:.68rem;padding:3px 8px}
button.xs{font-size:.68rem;padding:3px 8px}
.lifecard{max-width:440px;text-align:left;max-height:88vh;overflow-y:auto}
.life-head{display:flex;gap:12px;align-items:center;margin-bottom:10px}
.life-head h3{margin:0;font-family:var(--disp)}
.life-head .avatar{margin:0;flex-shrink:0}
.life-sec{border-top:2px dotted var(--line);padding-top:10px;margin-top:10px}
.life-sec h4{margin:0 0 8px;font-family:var(--disp);font-size:.92rem;letter-spacing:.4px;display:flex;
  justify-content:space-between;align-items:center}
.life-sec h4 small{font-weight:400;color:var(--muted);font-size:.66rem}
.mbar{display:grid;grid-template-columns:92px 1fr 26px;align-items:center;gap:8px;margin:5px 0}
.mbar-l{font-size:.72rem;color:var(--ink2);font-weight:600}
.mbar-t{position:relative;height:10px;background:var(--paper2);border:1px solid var(--ink);border-radius:6px;overflow:hidden}
.mbar-f{position:absolute;left:0;top:0;bottom:0;background:var(--moss);border-radius:6px 0 0 6px}
.mbar-f.burn{background:var(--red)} .mbar-f.amb{background:var(--mustard)}
.mbar-v{font-size:.7rem;color:var(--muted);text-align:right;font-variant-numeric:tabular-nums}
.vaxis{margin:8px 0}
.vaxis-ends{display:flex;justify-content:space-between;font-size:.68rem;color:var(--muted);margin-bottom:3px}
.vaxis-ends b{color:var(--ink2);font-family:var(--disp)}
.vaxis-t{position:relative;height:7px;background:linear-gradient(90deg,var(--denim),var(--mustard));
  border:1px solid var(--ink);border-radius:5px}
.vaxis-dot{position:absolute;top:-3px;width:11px;height:11px;background:var(--card);border:2px solid var(--ink);
  border-radius:50%;transform:translateX(-50%)}
.checkinrow{display:flex;flex-wrap:wrap;gap:8px}
.lifecard .focusgrid{grid-template-columns:1fr 1fr}

/* ---- relationships ---- */
.relrow{border:2px solid var(--ink);border-radius:var(--r-sm);padding:9px 11px;margin:7px 0;background:var(--paperhi);box-shadow:var(--sh1)}
.relhead{display:flex;justify-content:space-between;align-items:center;gap:8px}
.relhead b{font-size:.92rem}
.stagebadge{font-size:.62rem;font-weight:800;text-transform:uppercase;letter-spacing:.4px;padding:2px 8px;
  border:2px solid var(--ink);border-radius:10px;background:var(--card)}
.stagebadge.s-crush{background:var(--paper2)} .stagebadge.s-dating{background:var(--mustard)}
.stagebadge.s-together{background:var(--denim);color:#fff} .stagebadge.s-committed{background:var(--moss);color:#fff}
.stagebadge.s-ex{background:var(--muted);color:#fff}
.relarch{font-size:.72rem;color:var(--muted);margin:3px 0 6px}
.relbars{display:flex;gap:10px;margin-bottom:8px}
.lmini{display:flex;align-items:center;gap:4px;flex:1}
.lmini i{font-style:normal;font-size:.7rem}
.lmini-t{position:relative;flex:1;height:7px;background:var(--paper2);border:1px solid var(--ink);border-radius:4px;overflow:hidden}
.lmini-f{position:absolute;left:0;top:0;bottom:0}
.lmini-f.aff{background:var(--red)} .lmini-f.tru{background:var(--moss)} .lmini-f.ten{background:var(--mustard)}
.relbtns{display:flex;flex-wrap:wrap;gap:6px}
.secretbtn{border-color:var(--red2);color:var(--red2);font-weight:800;letter-spacing:2px}
.datecard{max-width:420px;text-align:left}
.datecard.secret{background:linear-gradient(180deg,#2a1417,#3a1c22);color:var(--paper);border-color:#5a2530}
.datecard.secret h3,.datecard.secret .datetext{color:var(--paper)}
.datetext{font-size:1rem;line-height:1.5;margin:6px 0 16px;font-style:italic}
.datechoices{display:flex;flex-direction:column;gap:8px}
.datechoice{text-align:left;padding:11px 14px;border:2px solid var(--ink);border-radius:var(--r-sm);
  background:var(--card);color:var(--ink);font-weight:600;box-shadow:var(--sh1);cursor:pointer}
.datechoice:hover{background:var(--mustard)}
.datecard.secret .datechoice{background:#4a2028;color:var(--paper);border-color:#6a303a}
.datecard.secret .datechoice:hover{background:var(--red2)}

/* ---- day jobs ---- */
.jobcard,.joboffer{border:2px solid var(--ink);border-radius:var(--r-sm);padding:9px 11px;margin:7px 0;
  background:var(--paperhi);box-shadow:var(--sh1)}
.jobcard-h{display:flex;justify-content:space-between;align-items:center;gap:8px}
.jobcard-h b{font-size:.9rem}
.jobpay{font-family:var(--disp);font-weight:800;color:var(--moss);font-size:.9rem}
.joboffer .relbtns,.joboffer>button{margin-top:8px}

/* ---- session mayhem ---- */
.mayhemcard{max-width:640px;text-align:center}
.mayhem-h{font-family:Impact,var(--disp);font-size:1.8rem;letter-spacing:2px;color:var(--red);
  text-shadow:2px 2px 0 var(--ink);margin-bottom:2px}
.augrow{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;margin:12px 0}
.augcard{display:flex;flex-direction:column;align-items:center;gap:5px;text-align:center;padding:14px 10px;
  border:2px solid var(--ink);border-radius:var(--r-sm);background:var(--card);color:var(--ink);
  box-shadow:var(--sh1);cursor:pointer;transition:transform .08s}
.augcard:hover{transform:translateY(-3px)}
.augcard b{font-family:var(--disp);font-size:.95rem;line-height:1.1}
.aug-icon{font-size:1.8rem;line-height:1}
.aug-tier{font-size:.58rem;font-weight:800;text-transform:uppercase;letter-spacing:1px;padding:1px 7px;
  border-radius:8px;border:1.5px solid var(--ink)}
.aug-desc{font-size:.72rem;color:var(--ink2);line-height:1.25}
.augcard.t-common{border-color:var(--muted)} .augcard.t-common .aug-tier{background:var(--paper2);color:var(--ink2)}
.augcard.t-rare{border-color:var(--denim)} .augcard.t-rare .aug-tier{background:var(--denim);color:#fff}
.augcard.t-epic{border-color:#7d3cc0} .augcard.t-epic .aug-tier{background:#7d3cc0;color:#fff}
.augcard.t-epic:hover{box-shadow:0 0 0 2px #7d3cc0,var(--sh1)}
.augcard.t-legendary{border-color:var(--mustard);background:linear-gradient(180deg,#fff6e0,var(--card))}
.augcard.t-legendary .aug-tier{background:var(--mustard);color:var(--ink)}
.augcard.t-legendary:hover{box-shadow:0 0 0 2px var(--mustard),0 0 14px rgba(217,154,28,.5)}
.mayhem-foot{display:flex;justify-content:center;gap:12px;margin-top:6px}
.augtag{display:inline-block;font-size:.72rem;font-weight:800;padding:3px 10px;margin:2px 0 8px;
  border:2px solid var(--ink);border-radius:12px;background:var(--mustard);color:var(--ink);box-shadow:var(--sh1)}

/* ---- main story ---- */
.storycard{max-width:520px;text-align:left;background:linear-gradient(180deg,#f7efdc,var(--card))}
.story-act{font-family:var(--disp);font-weight:800;font-size:.7rem;letter-spacing:3px;color:var(--red);text-transform:uppercase}
.story-title{font-family:Impact,var(--disp);font-size:1.7rem;line-height:1;margin:2px 0 10px;color:var(--ink)}
.storytext{font-size:1.02rem;line-height:1.6;margin:0 0 16px;color:var(--ink2)}
.storytext i{color:var(--red2)}
.storychoices{display:flex;flex-direction:column;gap:9px}
.storychoice{text-align:left;padding:12px 14px;border:2px solid var(--ink);border-radius:var(--r-sm);
  background:var(--paperhi);color:var(--ink);box-shadow:var(--sh1);cursor:pointer;display:flex;flex-direction:column;gap:2px}
.storychoice:hover{background:var(--mustard);transform:translateX(3px)}
.storychoice b{font-size:.96rem}
.storychoice span{font-size:.74rem;color:var(--muted)}
.storychoice:hover span{color:var(--ink2)}
.story-arc{font-family:var(--disp);font-weight:800;font-size:.82rem;color:var(--denim);text-transform:uppercase;letter-spacing:.5px}
.story-arc b{color:var(--red)}
/* saga chronicle */
.sagacard{margin-top:16px}
.saga-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.saga-head h3{margin:0;font-family:var(--disp)}
.sagabar{height:8px;background:var(--paper2);border:2px solid var(--ink);border-radius:5px;overflow:hidden}
.sagabar>span{display:block;height:100%;background:var(--red)}
.sagabeat{border-left:3px solid var(--mustard);padding:5px 0 5px 10px;margin:8px 0}
.sagabeat-h{display:flex;justify-content:space-between;gap:8px;font-size:.86rem}
.sagachoice{font-size:.78rem;color:var(--ink2);font-style:italic;margin-top:2px}
/* band life feed + whims */
.lifefeed{margin-top:16px}
.lifefeed h3{margin:0 0 2px;font-family:var(--disp)}
.lifeitem{display:flex;align-items:center;gap:9px;padding:5px 0;border-bottom:1px dotted var(--line);font-size:.86rem}
.lifeicon{font-size:1.05rem;flex-shrink:0}
.lifetxt{flex:1;color:var(--ink2)}
.whim{font-size:.74rem;color:var(--muted);font-style:italic;margin:4px 0 2px;line-height:1.3}

/* ---- stamina / condition ---- */
.condrow{display:flex;flex-direction:column;gap:4px;margin:7px 0 4px}
.condline{display:grid;grid-template-columns:16px 1fr auto;align-items:center;gap:7px}
.condlbl{font-size:.82rem;text-align:center}
.condbar{position:relative;height:9px;background:var(--paper2);border:1.5px solid var(--ink);border-radius:5px;overflow:hidden}
.condbar-f{position:absolute;left:0;top:0;bottom:0;border-radius:4px}
.condval{font-size:.68rem;color:var(--muted);font-variant-numeric:tabular-nums;white-space:nowrap}
.condval small{color:var(--muted)}
/* shared energy state colors (also used by .mbar-f.s-*) */
.s-fresh{background:var(--moss)} .s-good{background:#5aa06a} .s-mid{background:var(--mustard)}
.s-low{background:#d9701c} .s-crit{background:var(--red)}
.mbar-f.s-fresh,.mbar-f.s-good{background:var(--moss)} .mbar-f.s-mid{background:var(--mustard)}
.mbar-f.s-low{background:#d9701c} .mbar-f.s-crit{background:var(--red)}
/* band readiness strip on action screens */
.readystrip{display:flex;flex-wrap:wrap;align-items:center;gap:8px;background:var(--card2);border:2px solid var(--ink);
  border-radius:var(--r-sm);padding:8px 12px;margin-bottom:14px;box-shadow:var(--sh1)}
.readylbl{font-family:var(--disp);font-weight:700;font-size:.8rem;text-transform:uppercase;letter-spacing:.5px}
.readydot{display:flex;flex-direction:column;align-items:center;line-height:1;min-width:42px;padding:3px 6px;border:2px solid var(--ink);border-radius:8px;color:#fff}
.readydot.s-fresh{background:var(--moss)} .readydot.s-good{background:#5aa06a} .readydot.s-mid{background:var(--mustard);color:var(--ink)}
.readydot.s-low{background:#d9701c} .readydot.s-crit{background:var(--red)}
.readydot b{font-size:.82rem} .readydot i{font-size:.6rem;font-style:normal;opacity:.9}
.readywarn{font-size:.74rem;font-weight:700;color:var(--red);margin-left:auto}
/* recovery breakdown chips in Inner Life */
.recchips{display:flex;flex-wrap:wrap;gap:5px}
.recchip{font-size:.68rem;font-weight:700;padding:2px 8px;border-radius:10px;border:1.5px solid var(--ink)}
.recchip.pos{background:#e7f2e3;color:var(--moss)} .recchip.neg{background:#f7e3df;color:var(--red)}

/* ---- gig planner ---- */
.venuegrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px}
.venue2{text-align:left;padding:11px 13px;border:2px solid var(--ink);border-radius:var(--r-sm);background:var(--card);
  box-shadow:var(--sh1);cursor:pointer;display:flex;flex-direction:column;gap:3px}
.venue2:hover{background:var(--mustard);transform:translateY(-2px)}
.venue2.on{outline:3px solid var(--red);background:#fdf3d4}
.venue2.locked{opacity:.5;filter:grayscale(.4);cursor:not-allowed}
.venue2 .vname{font-family:var(--disp);font-weight:800;font-size:1rem}
.venue2 .vmeta{font-size:.68rem;color:var(--muted)}
.venue2 .vblurb{font-size:.72rem;color:var(--ink2);line-height:1.3}
.gigplan{margin-bottom:16px}
.gigplan h3{font-family:var(--disp);margin:0 0 10px}
.optrow{display:grid;grid-template-columns:110px 1fr;align-items:center;gap:10px;margin:7px 0}
.optlabel{font-size:.78rem;font-weight:700;color:var(--ink2);text-transform:uppercase;letter-spacing:.4px}
.optchips{display:flex;flex-wrap:wrap;gap:6px}
.optchip{font-size:.76rem;padding:5px 11px;border:2px solid var(--ink);border-radius:14px;background:var(--paperhi);
  box-shadow:var(--sh1);cursor:pointer}
.optchip:hover{background:var(--mustard)}
.optchip.on{background:var(--denim);color:#fff}
.stagesummary{border-top:2px dotted var(--line);margin-top:10px;padding-top:10px}
.stagesum-h{display:flex;align-items:center;gap:8px;margin-bottom:6px}
.stagebars{display:flex;flex-wrap:wrap;align-items:center;gap:10px;margin:4px 0}
.sbmini{display:flex;align-items:center;gap:4px}
.sbmini i{font-style:normal;font-size:.8rem}
.sbmini-t{position:relative;width:54px;height:7px;background:var(--paper2);border:1px solid var(--ink);border-radius:4px;overflow:hidden}
.sbmini-f{position:absolute;left:0;top:0;bottom:0}
.gigfooter{border-top:2px dotted var(--line);margin-top:10px;padding-top:10px;display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px}
.gigbtns{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.tourinline{font-size:.78rem;color:var(--ink2)} .tourinline select{width:auto;display:inline-block;padding:4px 6px}
.gplansum{font-size:.72rem;color:var(--muted);margin:2px 0 6px;text-transform:capitalize}

/* ---- stage designer ---- */
.stagecard{max-width:560px}
.stagegrid{background:repeating-linear-gradient(90deg,#3a342a,#3a342a 2px,#2c2820 2px,#2c2820 40px);
  border:3px solid var(--ink);border-radius:var(--r-sm);padding:10px;margin:8px 0}
.stagerow{display:grid;grid-template-columns:repeat(5,1fr);gap:6px;margin-bottom:6px}
.stagecell{aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;
  border:2px dashed rgba(239,228,204,.4);border-radius:6px;background:rgba(239,228,204,.06);color:var(--paper);
  cursor:pointer;padding:2px;min-height:44px}
.stagecell:hover{background:rgba(217,154,28,.3);border-color:var(--mustard)}
.stagecell.filled{border-style:solid;border-color:var(--paper);background:rgba(239,228,204,.14)}
.stagecell.back{border-top-width:3px} .stagecell.front{border-bottom-color:var(--red)}
.scell-empty{font-size:1.3rem;opacity:.4}
.scell-mem,.scell-el{display:flex;flex-direction:column;align-items:center;font-size:1.2rem;line-height:1}
.scell-mem i,.scell-el i{font-style:normal;font-size:.52rem;opacity:.85;margin-top:1px}
.stagecell .gicon{width:30px;height:30px;padding:2px}
.crowdline{text-align:center;color:var(--mustard);font-size:.7rem;letter-spacing:2px;font-weight:700;margin-top:4px}
.stagescore{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin:8px 0}
.stagescore b{font-family:var(--disp)}
.stagenotes{display:flex;flex-wrap:wrap;gap:6px;margin:6px 0}
.snote{font-size:.7rem;padding:2px 8px;border-radius:10px;background:var(--paper2);border:1px solid var(--ink);color:var(--ink2)}
.palette{display:grid;grid-template-columns:repeat(auto-fill,minmax(78px,1fr));gap:7px;max-height:180px;overflow-y:auto}
.palitem{display:flex;flex-direction:column;align-items:center;gap:2px;padding:7px 4px;border:2px solid var(--ink);
  border-radius:var(--r-sm);background:var(--paperhi);box-shadow:var(--sh1);cursor:pointer;position:relative}
.palitem:hover{background:var(--mustard)}
.palitem.on{outline:3px solid var(--red);background:#fdf3d4}
.palitem.placed{opacity:.6}
.palic{font-size:1.3rem;line-height:1} .palic .gicon{width:30px;height:30px;padding:2px}
.pallabel{font-size:.62rem;text-align:center;line-height:1.05}
.palok{position:absolute;top:2px;right:4px;color:var(--moss);font-weight:900;font-size:.7rem}

/* ---- song workshop ---- */
.qw-head{display:flex;flex-direction:column;gap:1px;margin-bottom:8px}
.qw-head b{font-family:var(--disp);font-size:1.05rem}
.quickwrite{margin-bottom:14px}
.workshop{margin-bottom:16px}
.worklead{display:grid;grid-template-columns:110px 1fr;align-items:center;gap:10px;margin:4px 0 10px;
  padding-bottom:10px;border-bottom:2px dotted var(--line)}
.optchip small{opacity:.7;font-size:.62rem}
.optchip.offg{border-style:dashed;opacity:.85}
.optchip.offg.on{background:var(--red);color:#fff}
.workpreview{margin-top:12px;border-top:2px solid var(--ink);padding-top:12px}
.wp-head{display:flex;flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:6px}
.wp-head b{font-family:var(--disp);font-size:1rem;display:flex;align-items:center;gap:6px}
.cohpill{font-size:.7rem;font-weight:800;padding:2px 9px;border-radius:10px;border:2px solid var(--ink);background:var(--paper2)}
.cohpill.good{background:var(--moss);color:#fff;border-color:var(--moss)} .cohpill.bad{background:var(--red);color:#fff;border-color:var(--red)}
.character{font-style:italic;color:var(--ink2);font-size:.95rem;margin:6px 0;line-height:1.4}
.wpdims{margin:8px 0}
.wtitle{display:flex;align-items:center;gap:6px;font-size:.8rem;flex:1;min-width:140px}
.wtitle input{width:auto;flex:1}
.songrow.hasch{grid-template-columns:auto 1fr auto auto;align-items:center}
.songrow-main{display:flex;flex-direction:column;gap:1px;min-width:0}
.songchar{font-size:.68rem;color:var(--muted);font-style:italic;line-height:1.2;overflow:hidden;text-overflow:ellipsis}
.songchar b{font-style:normal}

/* ---- modal close X ---- */
.modalx{position:absolute;top:8px;right:8px;width:30px;height:30px;border:2px solid var(--ink);border-radius:50%;
  background:var(--card);color:var(--ink);font-size:.9rem;font-weight:900;cursor:pointer;box-shadow:var(--sh1);
  display:flex;align-items:center;justify-content:center;padding:0;z-index:5}
.modalx:hover{background:var(--red);color:#fff;transform:rotate(90deg)}
.modal-wrap .card{position:relative}

/* ---- band life screen ---- */
.lovehub{margin-bottom:16px}
.relowner{color:var(--red);font-weight:800}
.relmem{font-size:.72rem;color:var(--muted);margin:5px 0 2px;line-height:1.3}
.relmem i{font-style:italic} .relmem small{opacity:.8}
.relrow.hassecret{border-color:var(--red2);box-shadow:0 0 0 1px var(--red2),var(--sh1)}
.singlesrow{font-size:.78rem;color:var(--muted);margin-top:10px;padding-top:8px;border-top:1px dotted var(--line)}
.glancegrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px}
.glancecard{display:flex;flex-direction:column;align-items:center;gap:3px;text-align:center;padding:10px;
  border:2px solid var(--ink);border-radius:var(--r-sm);background:var(--paperhi);box-shadow:var(--sh1);cursor:pointer}
.glancecard:hover{background:var(--mustard);transform:translateY(-2px)}
.glancecard .avatar{margin:0}
.gc-name{font-weight:800;font-size:.84rem;display:flex;align-items:center;gap:4px;flex-wrap:wrap;justify-content:center}
.gc-name .stars{font-size:.8rem}
.gc-whim{font-size:.66rem;color:var(--ink2);font-style:italic;line-height:1.2}
.gc-meta{font-size:.64rem;color:var(--muted)}

/* ---- onboarding / help / saves / audio ---- */
.tipbar{display:flex;align-items:center;gap:10px;background:#fdf3d4;border:2px solid var(--ink);border-left:6px solid var(--mustard);
  border-radius:var(--r-sm);padding:9px 12px;margin-bottom:14px;box-shadow:var(--sh1);font-size:.86rem;color:var(--ink2)}
.tipmark{font-size:1.1rem;flex-shrink:0}
.tipbar>span{flex:1;line-height:1.4}
.mutebtn,.helpbtn{cursor:pointer;font-family:inherit;font-size:.9rem;line-height:1}
.helpcard{max-width:480px;text-align:left}
.helplist{margin:6px 0 12px;padding-left:22px;line-height:1.7;font-size:.94rem;color:var(--ink2)}
.helplist li{margin:3px 0}
.helplist b{color:var(--ink)}
.saveio{width:100%;min-height:64px;font-family:monospace;font-size:.72rem;resize:vertical;margin-bottom:8px;
  border:2px solid var(--ink);border-radius:var(--r-sm);padding:8px;background:var(--paperhi)}
/* nav attention badge */
.navbtn{position:relative}
.navbadge{position:absolute;top:-5px;right:-5px;min-width:16px;height:16px;padding:0 4px;border-radius:8px;
  background:var(--red);color:#fff;font-size:.62rem;font-weight:800;display:flex;align-items:center;justify-content:center;
  border:1.5px solid var(--paper);box-shadow:var(--sh1)}

/* ---- responsive ---- */
@media(max-width:680px){
  .studiowrap{grid-template-columns:1fr}
  .releasebox{position:static}
  .tonegrid{grid-template-columns:1fr}
  .rigrow{grid-template-columns:1fr}
  .lifecard .focusgrid{grid-template-columns:1fr}
  .logo{font-size:2.8rem}
  .topbar{position:static;flex-direction:column;align-items:flex-start}
  .nav{position:static;top:auto}
  h2{font-size:1.4rem}
}

/* ============================================================
   MERCH — brand designer, product line, tech tree, deals
   ============================================================ */
.merchhead{display:flex;gap:22px;flex-wrap:wrap;align-items:center;justify-content:center;padding:14px 18px}
.merchstat{display:flex;flex-direction:column;align-items:center;min-width:120px}
.merchstat .ms-val{font-family:var(--disp);font-size:26px;font-weight:800;color:var(--red)}
.merchstat .ms-lbl{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}

.micon{width:48px;height:48px;display:block;filter:drop-shadow(1px 1px 0 rgba(33,29,23,.25))}
.micon.big{width:132px;height:132px}

/* deal panels */
.mdeal{border-left:5px solid var(--denim)}
.mdeal.offer{border-left-color:var(--mustard);background:linear-gradient(180deg,#fff7e6,var(--card))}
.mdeal.signed{border-left-color:var(--moss)}
.mdeal-h{font-family:var(--disp);font-size:19px;font-weight:800;margin-bottom:4px}
.mdeal-btns{display:flex;gap:8px;margin-top:8px}

/* brand designer */
.mdesign-grid{display:flex;gap:18px;flex-wrap:wrap}
.mpreview{flex:0 0 160px;display:flex;flex-direction:column;align-items:center;gap:6px;
  background:var(--card2);border:2px solid var(--line);border-radius:var(--r);padding:14px}
.mpreview-cap{font-size:12px;color:var(--muted);text-align:center;font-weight:600}
.mdesign-picks{flex:1 1 340px;min-width:280px;display:flex;flex-direction:column;gap:8px}
.mrow{display:flex;align-items:baseline;gap:10px;flex-wrap:wrap}
.mrow-l{flex:0 0 66px;font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-weight:700}
.mrow-o{display:flex;gap:5px;flex-wrap:wrap}
.mpick{font-family:var(--body);font-size:12px;padding:4px 9px;border:1.5px solid var(--line);
  border-radius:20px;background:var(--card);cursor:pointer;color:var(--ink)}
.mpick:hover{border-color:var(--ink2)}
.mpick.on{background:var(--ink);color:var(--paperhi);border-color:var(--ink)}
.mvibe-note{font-size:12px;color:var(--ink2);font-style:italic;margin-top:2px}

/* product line */
.mprod-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px}
.mprod{display:flex;flex-direction:column;align-items:center;gap:3px;text-align:center;
  border:2px solid var(--line);border-radius:var(--r);background:var(--card);padding:12px 8px;cursor:pointer;color:var(--ink)}
.mprod:hover{border-color:var(--ink2)}
.mprod.on{border-color:var(--moss);background:#f0f6ec;box-shadow:inset 0 0 0 1px var(--moss)}
.mprod b{font-size:13px}
.mprod-tag{font-size:11px;color:var(--muted);line-height:1.3}
.mprod-price{font-size:11px;color:var(--ink2);font-weight:600}
.mprod-state{font-size:11px;font-weight:700;margin-top:2px;color:var(--muted)}
.mprod.on .mprod-state{color:var(--moss)}

/* tech tree */
.mtech{display:flex;align-items:center;gap:12px;padding:9px 10px;border-bottom:1px solid var(--line)}
.mtech:last-child{border-bottom:none}
.mtech.locked{opacity:.5}
.mtech.owned{background:#f0f6ec}
.mtech-i{font-size:22px;flex:0 0 26px;text-align:center}
.mtech-b{flex:1 1 auto}
.mtech-blurb{font-size:12px;color:var(--muted)}
.mtech-tag{font-size:12px;font-weight:700;color:var(--moss)}
.mtech-tag.lock{color:var(--muted)}

/* pricing */
.mprice-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:8px}
.mprice{display:flex;flex-direction:column;gap:2px;text-align:left;border:2px solid var(--line);
  border-radius:var(--r);background:var(--card);padding:9px 11px;cursor:pointer;color:var(--ink)}
.mprice:hover{border-color:var(--ink2)}
.mprice.on{border-color:var(--red);background:#fbeee9}
.mprice.locked{opacity:.55;cursor:not-allowed}
.mprice b{font-size:13px}
.mmults{margin-top:8px;text-align:center;font-variant-numeric:tabular-nums}

/* ============================================================
   CASTER + custom confirm modal (Movement 0.1)
   ============================================================ */
.casterline{margin:6px 0 10px;padding:8px 12px;border-left:4px solid var(--denim);
  background:var(--card2);border-radius:var(--r-sm);font-size:13px;color:var(--ink2)}
.casterline b{color:var(--denim)}

.confirmcard{max-width:420px;text-align:center}
.confirmcard h3{margin:0 0 8px;font-family:var(--disp);font-size:20px}
.confirm-body{margin:0 0 16px;color:var(--ink2)}
.confirm-btns{display:flex;gap:10px;justify-content:center}
.confirmcard.danger{border-top:4px solid var(--red)}
.dangerbtn{background:var(--red);border-color:var(--red2)}
.dangerbtn:hover{background:var(--red2)}

/* weekly advance: secondary "skip to month end" button (Movement 1.1) */
.navbtn.adv2{background:var(--card2);color:var(--ink2);border-color:var(--line);margin-left:4px}
.navbtn.adv2:hover{background:var(--paperhi)}
.weekcard{max-width:440px}

/* ============================================================
   THE WEEK — Persona-style scheduler hub (Movement 1.2)
   ============================================================ */
.weekhub{display:flex;flex-wrap:wrap;align-items:center;gap:16px 24px}
.weekslots{display:flex;flex-direction:column;gap:5px}
.wslabel{font-size:11px;text-transform:uppercase;letter-spacing:.07em;color:var(--muted);font-weight:700}
.slotdots{display:flex;gap:6px}
.slotdot{width:20px;height:20px;border-radius:50%;border:2px solid var(--ink);display:inline-block}
.slotdot.open{background:var(--mustard);box-shadow:inset 0 0 0 2px var(--card)}
.slotdot.used{background:var(--card2);opacity:.5}
.slotcount{font-size:13px;font-weight:700}
.slotcount.bad{color:var(--red)}
.weekcond{font-size:14px;font-weight:600}
.weekadv{margin-left:auto}
.weekplan{display:flex;flex-direction:column;gap:6px}
.planitem{display:flex;align-items:center;gap:10px;padding:7px 10px;background:var(--card2);border-radius:var(--r-sm);border-left:3px solid var(--mustard)}
.planicon{font-size:18px}
.actgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px}
.actcard{display:flex;flex-direction:column;align-items:flex-start;gap:2px;text-align:left;
  border:2px solid var(--line);border-radius:var(--r);background:var(--card);padding:12px;cursor:pointer;color:var(--ink)}
.actcard:hover{border-color:var(--ink2);transform:translateY(-1px)}
.actcard.spent{opacity:.55}
.acticon{font-size:24px}
.actcard b{font-size:14px}

/* ============================================================
   STUDY — music-theory learning (Movement 2)
   ============================================================ */
.conceptcard{display:flex;flex-direction:column;gap:8px}
.conceptcard.known{border-left:4px solid var(--moss)}
.conceptcard.learnable{border-left:4px solid var(--mustard)}
.conceptcard.locked{opacity:.6}
.cc-head{display:flex;align-items:center;gap:8px}
.cc-i{font-size:22px}
.cc-head b{font-family:var(--disp);font-size:16px;flex:1}
.cc-tag{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em}
.cc-tag.ok{color:var(--moss)}
.cc-tag.learn{color:var(--mustard)}
.cc-blurb{font-size:13px;line-height:1.5;color:var(--ink2);margin:0}
.cc-blurb b{color:var(--ink)}
.cc-prog{display:flex;align-items:center;gap:8px}
.cc-pt{flex:1;height:8px;background:var(--card2);border:1px solid var(--line);border-radius:5px;overflow:hidden}
.cc-pf{display:block;height:100%;background:var(--mustard)}
.cc-btns{display:flex;gap:6px;flex-wrap:wrap}
.cc-btns small{opacity:.7;font-weight:400}
.bookcard{display:flex;flex-direction:column;gap:6px}
.bookcard b{font-size:14px}
/* workshop lock states */
.optchip.locked{background:var(--card2);color:var(--muted);border-style:dashed;cursor:not-allowed;opacity:.75}
.optchip.locked small{opacity:.9}
.optchip.locked.req{border-color:var(--red);color:var(--red2)}
.lockednote{margin-top:10px;padding:8px 12px;background:var(--card2);border-radius:var(--r-sm);font-size:13px}
.linklike{background:none;border:none;color:var(--denim);font-weight:700;cursor:pointer;text-decoration:underline;padding:0;font-size:13px}

/* ============================================================
   IDENTITY — band look/scene + world culture (Movement 3)
   ============================================================ */
.idsub{font-size:11px;text-transform:uppercase;letter-spacing:.07em;color:var(--muted);font-weight:700;margin:12px 0 6px}
.scenecard .acticon{font-size:24px}
.fusionchip{border-style:solid;background:linear-gradient(180deg,#fbf1e6,var(--card))}
.fusionchip.on{background:var(--denim);color:var(--paperhi);border-color:var(--denim2)}
.fusionchip small{opacity:.7}
.linklike-chip{background:none;border:1.5px dashed var(--denim);color:var(--denim);font-weight:700}

/* ============================================================
   REAL ESTATE — homes, amenities, animated hero (Movement 4)
   ============================================================ */
.hicon{width:52px;height:52px;display:block;filter:drop-shadow(1px 2px 0 rgba(33,29,23,.25))}
.hicon.big{width:132px;height:132px}
.homehero{display:flex;gap:20px;align-items:center;flex-wrap:wrap;overflow:hidden;position:relative}
.homehero .hicon.big{animation:homefloat 3.6s ease-in-out infinite}
@keyframes homefloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-7px)}}
.homehero::after{content:"";position:absolute;top:0;left:-60%;width:40%;height:100%;
  background:linear-gradient(100deg,transparent,rgba(255,255,255,.35),transparent);
  transform:skewX(-20deg);animation:homeshine 5s ease-in-out infinite}
@keyframes homeshine{0%,72%{left:-60%}86%,100%{left:130%}}
.homeinfo{flex:1 1 240px}
.homeinfo h3{margin:2px 0;font-family:var(--disp);font-size:22px}
.hometier{letter-spacing:2px}
.htier{color:var(--line)}
.htier.on{color:var(--mustard)}
.buffchips{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}
.buffchip{font-size:12px;font-weight:700;background:var(--card2);border:1px solid var(--line);border-radius:20px;padding:3px 10px}
.amencard{display:flex;flex-direction:column;gap:6px}
.amencard.owned{border-left:4px solid var(--moss)}
.amencard.locked{opacity:.6}
.homecard{display:flex;flex-direction:column;align-items:center;gap:6px;text-align:center;transition:transform .12s ease,box-shadow .12s ease}
.homecard:hover{transform:translateY(-3px);box-shadow:var(--sh-pop)}
.homecard.current{border:2px solid var(--moss);background:#f0f6ec}
.homemeta{display:flex;flex-direction:column;gap:2px}
.homemeta b{font-size:14px}

/* ============================================================
   DOWNTIME — Rest & Recharge (weekly recovery activities)
   ============================================================ */
.relaxcard{border-left:4px solid var(--moss)}
.relaxcard.t-free{border-left-color:var(--moss)}
.relaxcard.t-cheap{border-left-color:#4a9a7a}
.relaxcard.t-mid{border-left-color:var(--denim)}
.relaxcard.t-premium{border-left-color:var(--mustard)}
.relaxcard.risky{border-left-color:var(--red)}
.relaxfx{font-size:12px;font-weight:700;color:var(--ink2);font-variant-numeric:tabular-nums}
.relaxcard.risky .relaxfx{color:var(--red2)}

/* ============================================================
   SESSION MUSICIANS (Movement 5 — Industry & Production)
   ============================================================ */
.sesscard{display:flex;flex-direction:column;gap:5px}
.staffrole{font-size:12px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.05em}
.sesstier{font-size:11px;font-weight:800;padding:1px 7px;border-radius:20px;vertical-align:middle}
.sesstier.t-journeyman{background:var(--card2);color:var(--ink2)}
.sesstier.t-pro{background:#e6efe8;color:var(--moss)}
.sesstier.t-legend{background:#f6ecd0;color:#9a7a1a}

/* ============================================================
   RELEASE CAMPAIGNS + discography overhaul (Movement 5.4)
   ============================================================ */
.campaign-panel{margin:8px 0;padding:10px;background:var(--card2);border:1px solid var(--line);border-radius:var(--r-sm);text-align:left}
.cp-head{font-family:var(--disp);font-weight:800;font-size:15px;margin-bottom:6px}
.campaign-panel .optrow{margin:5px 0}
.campaign-panel .optlabel{flex:0 0 78px;font-size:11px}
.discolist{display:flex;flex-direction:column;gap:10px}
.discoitem2{display:flex;gap:14px;align-items:center}
.discoitem2 .cover{flex:0 0 64px}
.disco-main{flex:1 1 auto}
.disco-stats{font-size:13px;color:var(--ink2);margin-top:2px}
.disco-camp{font-size:12px;color:var(--denim);font-weight:600;margin-top:3px}
.disco-chart{flex:0 0 110px;display:flex;flex-direction:column;align-items:center;gap:3px}
.salesbars{display:flex;align-items:flex-end;gap:3px;height:46px;width:100%;justify-content:center}
.salesbar{flex:1 1 auto;max-width:16px;background:linear-gradient(180deg,var(--mustard),var(--red));border-radius:2px 2px 0 0;min-height:6px}

/* ============================================================
   BAND FATIGUE display (Band screen)
   ============================================================ */
.fatbadge{font-size:11px;font-weight:800;padding:1px 8px;border-radius:20px;text-transform:uppercase;letter-spacing:.03em}
.fatbadge.f-fresh{background:#e2f2e6;color:#2f7a45}
.fatbadge.f-good{background:#eaf3ea;color:#4a8a55}
.fatbadge.f-mid{background:#f6efd6;color:#9a7a1a}
.fatbadge.f-low{background:#f7e2d2;color:#b5341f}
.fatbadge.f-crit{background:#f6d5d0;color:#8f2416}
.fatbar{padding:12px 14px}
.fatbar-head{font-family:var(--disp);font-weight:800;font-size:15px;margin-bottom:8px}
.fatwarn{font-size:12px;font-weight:700;color:var(--red);background:#f6d5d0;padding:1px 8px;border-radius:20px}
.fatchips{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:6px}
.fatchip{font-size:12px;font-weight:600;padding:3px 9px;border-radius:20px;border:1.5px solid var(--line)}
.fatchip b{font-variant-numeric:tabular-nums}
.fatchip.f-fresh{border-color:#7bc48f;background:#eef8f0}
.fatchip.f-good{border-color:#9ac9a4;background:#f2f8f2}
.fatchip.f-mid{border-color:var(--mustard);background:#fbf3dd}
.fatchip.f-low{border-color:#e08a5a;background:#fbeadd}
.fatchip.f-crit{border-color:var(--red);background:#fbdcd6}

/* ============================================================
   RIVAL BANDS — the competitive scene (Press screen)
   ============================================================ */
.rivals h3{margin-bottom:6px}
.rivallist{display:flex;flex-direction:column;gap:4px;margin-top:6px}
.rivalrow{display:flex;align-items:center;gap:8px;padding:4px 6px;border-radius:var(--r-sm)}
.rivalrow.you{background:#f3ecd6;box-shadow:inset 0 0 0 1.5px var(--mustard)}
.riv-rank{flex:0 0 26px;font-weight:800;color:var(--muted);font-variant-numeric:tabular-nums}
.riv-name{flex:1 1 auto;font-weight:600}
.riv-name small{color:var(--muted);font-weight:400}
.riv-bar{flex:0 0 90px;height:8px;background:var(--card2);border:1px solid var(--line);border-radius:5px;overflow:hidden}
.riv-fill{display:block;height:100%;background:var(--denim)}
.riv-fill.me{background:linear-gradient(90deg,var(--mustard),var(--red))}
.riv-fame{flex:0 0 52px;text-align:right;font-weight:700;font-variant-numeric:tabular-nums}
.riv-up{color:var(--moss)}
.riv-down{color:var(--red)}
.riv-flat{color:var(--muted)}
.riv-you{font-size:10px;font-weight:800;color:var(--mustard);text-transform:uppercase}

/* ============================================================
   PRESS FEED — the magazine aggregator (Movement 5.5)
   ============================================================ */
.pressfeed{display:flex;flex-direction:column;gap:8px;margin:10px 0}
.pfstory{padding:9px 12px;background:var(--card);border:1px solid var(--line);border-left:3px solid var(--red);border-radius:var(--r-sm)}
.pfkicker{font-size:10px;font-weight:800;letter-spacing:.1em;color:var(--red);text-transform:uppercase}
.pftitle{font-family:var(--disp);font-weight:700;font-size:15px;line-height:1.25;margin-top:1px}
.pfbody{font-size:13px;color:var(--ink2);margin-top:3px;font-style:italic}

/* ============================================================
   CONTRACTS & SPONSORSHIPS (Movement 5.1)
   ============================================================ */
.dealbar{display:flex;flex-wrap:wrap;gap:8px 18px;padding:8px 12px;background:var(--card2);border:1px solid var(--line);border-radius:var(--r-sm);font-size:13px;font-weight:600;margin-bottom:8px}
.sponcard{display:flex;flex-direction:column;gap:5px}
.sponcard.active{border-left:4px solid var(--moss)}

/* ============================================================
   THE HIDDEN WORLD — occult capstone (Movement 6)
   ============================================================ */
.powercard{display:flex;flex-direction:column;gap:8px;background:linear-gradient(180deg,#171320,#1e1830);color:#e8e2f0;border-color:#3a3050}
.powercard.ascended{box-shadow:0 0 0 1.5px #b89b4e, var(--sh-card)}
.power-head{display:flex;align-items:center;gap:12px}
.power-sym{font-size:34px;filter:drop-shadow(0 0 6px #9a7bd0)}
.power-head b{font-family:var(--disp);font-size:18px;color:#f0eaff}
.power-ep{font-size:12px;color:#a99ec8;font-style:italic}
.devbar{display:flex;align-items:center;gap:8px}
.devbar-t{flex:1;height:7px;background:#0e0a18;border:1px solid #3a3050;border-radius:5px;overflow:hidden}
.devbar-f{display:block;height:100%;background:linear-gradient(90deg,#7b5cc0,#b89b4e)}
.devbar .hint{color:#a99ec8}
.occlore{font-size:13px;line-height:1.55;color:#cfc6e4;font-style:italic;margin:2px 0;padding-left:8px;border-left:2px solid #4a3f66}
.occlocked{color:#8a7fae !important}
.occtalentline{font-size:13px;color:#e8d9a8;background:#241d38;padding:6px 9px;border-radius:6px;margin:0}
.pactcard{margin-top:6px;padding:9px;background:#241226;border:1px solid #5a2440;border-radius:6px}
.pactcard b{color:#f0b9c4}
.pactcard .hint{color:#c69aa8}
.occdebts{background:#241226;color:#f0d9d9;border-color:#5a2440}
.occdebts .hint{color:#d6a9b0}
.occultnote{color:#7a5cc0;font-weight:600}
/* contested market — a piece a rival collector grabbed first */
.gearcard.soldcard{opacity:.6;filter:grayscale(.4)}
.soldtag{margin-top:6px;font-size:.82em;font-weight:700;color:#b5341f;letter-spacing:.02em}
/* market read (taste) — what the scene wants, surfaced where it's actionable */
.marketpulse{border-left:4px solid #c8792b;background:#f4ead5}
.marketpulse b{color:#8a4a12}
.tastenote{margin:2px 0 8px;font-style:italic;color:#6a5a3a}
/* bad mayhem — the fallout: pick your poison */
.mayhemcard.badmayhem{border-color:#7a2a2a}
.mayhem-h.bad{color:#b5341f}
.augcard.badcard{border-color:#8a3a2a;background:#2a1614;color:#f0d9d9}
.augcard.badcard .aug-tier{background:#5a2018;color:#f0c9c0}
.augcard.badcard.sev-severe{border-color:#c0392b;box-shadow:0 0 0 2px rgba(192,57,43,.35)}
.augcard.badcard.sev-bad{border-color:#9a4a2a}
.augcard.badcard.sev-mild{border-color:#7a5a3a;opacity:.94}

/* ==================================================================
   ★★ PUNK 2.0 — black / neon-green re-skin · mobile-first · tactile gear
   Overrides the zine palette via the cascade. Splashes: neon green (hero),
   cyan, acid, hot-pink. Everything reads dark, loud, and phone-friendly.
   ================================================================== */
:root{
  --paper:#0b0b0d; --paper2:#131317; --card:#16161c; --card2:#1e1e25;
  --ink:#ece9df; --ink2:#c1beb4; --muted:#84848e; --line:#2b2b34; --paperhi:#0f0f14;
  --red:#ff2e63; --red2:#d41e4f;               /* hot punk pink — danger / bad / warn */
  --neon:#57ff5f; --neon2:#2fd23c;             /* HERO neon green */
  --denim:#25e2ff; --denim2:#12b6d8;           /* accent cyan — links */
  --mustard:#e9ff3d; --moss:#57ff5f;           /* acid / good=neon */
  --sh1:2px 2px 0 rgba(0,0,0,.8);
  --sh-card:0 1px 0 rgba(255,255,255,.04), 0 12px 26px -12px rgba(0,0,0,.8);
  --sh-pop:0 0 0 1px rgba(87,255,95,.18), 0 22px 46px -12px rgba(0,0,0,.85);
}
body{color:var(--ink);background-color:#08080a;overflow-x:hidden;
  background-image:
    repeating-linear-gradient(90deg, rgba(87,255,95,.02) 0 1px, transparent 1px 4px),
    repeating-linear-gradient(0deg, rgba(255,255,255,.014) 0 1px, transparent 1px 6px),
    radial-gradient(130% 100% at 18% -10%, #17171e 0%, #0d0d11 55%, #08080a 100%)}
a{color:var(--denim)}
h1,h2,h3{color:var(--ink)}
.screen h2::after{background:linear-gradient(90deg,var(--neon),transparent);height:3px}
.hint{color:var(--ink2)} small{color:var(--muted)}
.warn{color:#ffd7e2;background:#3a0f1d;border-color:var(--red)}

button{border-color:#3a3a45;background:#1c1c23;color:var(--ink);box-shadow:var(--sh1)}
button:hover{box-shadow:3px 3px 0 rgba(0,0,0,.85);border-color:var(--neon)}
button.primary{background:var(--neon);color:#07130a;border-color:var(--neon2);
  box-shadow:0 0 0 1px rgba(87,255,95,.4),2px 2px 0 rgba(0,0,0,.8)}
button.primary:hover{background:#6dff74}
button.ghost{background:transparent;border-color:#33333d;box-shadow:none}
button.ghost:hover{background:rgba(87,255,95,.09);border-color:var(--neon)}
button.sm,button.mini{background:#20202a}
input,select,textarea{background:#0f0f14;color:var(--ink);border-color:#33333d}
input:focus,select:focus{border-color:var(--neon);box-shadow:0 0 0 3px rgba(87,255,95,.18)}
label{color:var(--ink2)}
.card{background:var(--card);border-color:#2c2c36;box-shadow:var(--sh-card)}

.topbar{background:linear-gradient(180deg,#141418,#0b0b0e);border-color:#2c2c36;color:var(--ink)}
.topbar .brand{color:var(--neon);text-shadow:0 0 12px rgba(87,255,95,.35)}
.topbar .brand small{color:var(--muted)}
.pill{background:rgba(255,255,255,.05);border-color:rgba(255,255,255,.09);color:var(--ink2)}
.pill.good{background:var(--neon);color:#07130a;border-color:transparent}
.pill.bad{background:var(--red);color:#fff;border-color:transparent}
.nav{background:var(--card);border-color:#2c2c36}
.navbtn{color:var(--ink2)}
.navbtn:hover{background:#24242d;color:var(--ink)}
.navbtn.on{background:var(--neon);border-color:var(--neon2);color:#07130a;box-shadow:0 0 12px rgba(87,255,95,.3)}
.navbtn.adv{background:var(--red);border-color:var(--red2);color:#fff}
.navbtn.adv:hover{background:var(--red2)}
.logo{color:var(--ink);text-shadow:4px 4px 0 var(--neon2);font-size:clamp(2.2rem,10.5vw,4rem);word-break:break-word}
.logo span{color:var(--neon);text-shadow:4px 4px 0 #000,0 0 22px rgba(87,255,95,.5)}
.tag{color:var(--ink2)}
#app{overflow-x:hidden}
.newgame{max-width:min(540px,calc(100vw - 18px))}
.member.inband{outline-color:var(--neon)} .member.inband::before{background:var(--neon);color:#07130a}

/* ---- GEAR AS TACTILE, COLOURFUL BOXES (placeholder art = the category icon) ---- */
.rig{margin-top:14px}
.rig-head{font-family:var(--disp);text-transform:uppercase;letter-spacing:1px;color:var(--neon);font-size:.8rem;margin-bottom:10px}
.gearbox{display:flex;gap:12px;align-items:stretch;background:linear-gradient(160deg,#1d1d25,#131318);
  border:2px solid #34343f;border-radius:14px;padding:12px;margin-bottom:12px;position:relative;overflow:hidden}
.gearbox::before{content:"";position:absolute;inset:0;pointer-events:none;
  background:repeating-linear-gradient(45deg,rgba(255,255,255,.02) 0 2px,transparent 2px 9px)}
.gearbox-art{flex:0 0 66px;width:66px;height:66px;border-radius:10px;display:grid;place-items:center;
  background:radial-gradient(120% 120% at 30% 20%,#26262f,#101015);border:2px solid rgba(87,255,95,.22);
  box-shadow:inset 0 2px 10px rgba(0,0,0,.55),0 0 0 1px rgba(0,0,0,.4)}
.gearbox-art svg{width:46px;height:46px}
.gearbox-body{flex:1;min-width:0}
.gearbox-name{font-family:var(--disp);font-weight:800;text-transform:uppercase;letter-spacing:.5px;color:var(--ink);
  font-size:.9rem;margin-bottom:9px;padding:3px 8px;background:#0d0d11;border-left:3px solid var(--neon);border-radius:3px;display:inline-block}
.knobs{display:flex;flex-wrap:wrap;gap:12px}
.knob{display:flex;flex-direction:column;align-items:center;gap:5px;font-size:.64rem;background:#0d0d12;
  border:1px solid #2b2b35;border-radius:12px;padding:8px 10px 9px;min-width:78px}
.knob-lab{color:var(--ink2);font-weight:700;text-transform:uppercase;letter-spacing:.4px;min-width:0}
.knob input[type=range]{width:86px;accent-color:var(--neon);height:18px;background:transparent}
.knob-val{font-weight:800;color:var(--neon);font-variant-numeric:tabular-nums;font-size:.82rem}
.gearcard{background:#17171d;border-color:#2c2c36}
.gearcard.owned{outline-color:var(--neon)}
.tonelab{background:linear-gradient(180deg,#17171d,#0f0f14)}
.tonelab-head h3 small{color:var(--neon)}

/* ---- MOBILE: scrollable header/nav, single-column, big tap targets ---- */
@media (max-width:640px){
  #app{padding:0 8px 34px}
  .topbar{padding:8px 10px;gap:6px;flex-wrap:nowrap}
  .topbar .brand{font-size:1.02rem}
  .topbar .brand small{font-size:.6rem}
  .stats{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:2px}
  .stats::-webkit-scrollbar{display:none}
  .nav{position:static;flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;gap:5px;padding:6px}
  .nav::-webkit-scrollbar{display:none}
  .navbtn{white-space:nowrap;padding:10px 13px;font-size:.8rem}
  .navbtn.adv{margin-left:0}
  .grid{grid-template-columns:1fr;gap:10px}
  .tonegrid{grid-template-columns:1fr}
  button{min-height:44px}
  button.sm,button.mini{min-height:38px}
  h2{font-size:1.35rem}
  .gearbox-art{flex-basis:56px;width:56px;height:56px}
  .gearbox-art svg{width:38px;height:38px}
  .knob input[type=range]{width:74px}
  .modal-wrap .card{width:96vw;max-width:none}
  .logo{font-size:2.4rem;text-shadow:3px 3px 0 var(--neon2)}
  .logo span{text-shadow:3px 3px 0 #000,0 0 16px rgba(87,255,95,.5)}
  .newgame{max-width:100%;margin:3vh auto}
  .tag{font-size:.92rem}
}
/* study proficiency — the concept mastery progression */
.cc-tag.lvl-novice{background:#e7e0d0;color:#6a5f48}
.cc-tag.lvl-practiced{background:#dce6cf;color:#4d6a2e}
.cc-tag.lvl-fluent{background:#cfe0ea;color:#245a72}
.cc-tag.lvl-master{background:#3a2a4e;color:#e9d9ff;font-weight:700}
.cc-pf.lvl-novice{background:#b7a97f}
.cc-pf.lvl-practiced{background:#7ba33e}
.cc-pf.lvl-fluent{background:#3f8fb5}
.cc-pf.lvl-master{background:linear-gradient(90deg,#7a5cc0,#b58bff)}

/* ── Band Life: section tabs (one panel at a time, no more endless scroll) ── */
.subtabs{display:flex;gap:6px;margin:2px 0 12px;overflow-x:auto;-webkit-overflow-scrolling:touch;
  scrollbar-width:none;padding-bottom:2px}
.subtabs::-webkit-scrollbar{display:none}
.subtab{flex:0 0 auto;background:#141418;color:#c9c9cf;border:1px solid #26262c;border-radius:999px;
  padding:8px 14px;font-weight:700;font-size:.92rem;min-height:40px;letter-spacing:.3px;
  display:inline-flex;align-items:center;gap:6px;transition:transform .05s,border-color .12s}
.subtab:hover{border-color:#3a3a44;transform:none}
.subtab.on{background:var(--neon);color:#04140a;border-color:var(--neon);box-shadow:0 0 0 1px var(--neon),0 0 14px rgba(87,255,95,.35)}
.subtab-n{display:inline-flex;align-items:center;justify-content:center;min-width:19px;height:19px;
  padding:0 5px;border-radius:999px;background:rgba(0,0,0,.28);color:inherit;font-size:.76rem;font-weight:800}
.subtab:not(.on) .subtab-n{background:#26262c;color:#8aff92}
/* relationships lay out as responsive cards instead of one tall column */
.relgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:12px}
@media (max-width:640px){.relgrid{grid-template-columns:1fr}}
