/* ===== RESET ===== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent;-webkit-text-size-adjust:100%}

/* ===== THEME TOKENS — LIGHT (default) ===== */
body{
  --bg:#EDE5D0;--surface:#E4D9BF;--surface-2:#dccfb1;--raise:#F2EBD9;
  --text:#1A1A1A;--dim:#6B6657;--faint:#9A9078;
  --hair:rgba(26,26,26,.13);--hair-strong:rgba(26,26,26,.22);
  --accent:#2b2fb8;--accent-text:#2b2fb8;--accent-soft:rgba(43,47,184,.12);
  --conflict:#9a1f0e;--conflict-soft:rgba(154,31,14,.12);
  --tab-off:#a39a82;--heart:#2b2fb8;--heart-off:#c3b896;
  --grain-op:.10;--grain-blend:multiply;
  --grain-img:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='1.1' numOctaves='2' stitchTiles='stitch' seed='7'/><feColorMatrix values='0 0 0 0 0.18  0 0 0 0 0.15  0 0 0 0 0.1  0 0 0 0.5 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
}

/* ===== THEME TOKENS — DARK ===== */
body[data-theme="dark"]{
  --bg:#0E1017;--surface:#161A24;--surface-2:#1c2130;--raise:#1a1f2b;
  --text:#E8E0CC;--dim:#7C8190;--faint:#565b6a;
  --hair:rgba(232,224,204,.10);--hair-strong:rgba(232,224,204,.18);
  --accent:#6a6ef0;--accent-text:#a9adff;--accent-soft:rgba(80,84,234,.16);
  --conflict:#e06040;--conflict-soft:rgba(200,64,48,.16);
  --tab-off:#565b6a;--heart:#6a6ef0;--heart-off:#3a3f4d;
  --grain-op:.05;--grain-blend:screen;
  --grain-img:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='1.1' numOctaves='2' stitchTiles='stitch' seed='3'/><feColorMatrix values='0 0 0 0 1  0 0 0 0 1  0 0 0 0 1  0 0 0 0.6 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
}

/* ===== BASE ===== */
html,body{height:100%;overflow:hidden}
body{
  font-family:"Noto Sans SC","Noto Sans",sans-serif;
  font-size:13px;line-height:1.5;
  background:var(--bg);color:var(--text);
  -webkit-font-smoothing:antialiased;
  overscroll-behavior:none;
}
*{scrollbar-width:none}
::-webkit-scrollbar{width:0;height:0}

/* ===== GRAIN ===== */
.grain{
  position:fixed;inset:0;pointer-events:none;z-index:9999;
  background-size:200px 200px;
  opacity:var(--grain-op);mix-blend-mode:var(--grain-blend);
  background-image:var(--grain-img);
}

/* ===== FONT HELPERS ===== */
.syne{font-family:"Syne",sans-serif}
.mono{font-family:"Space Mono",monospace}
.dim{color:var(--dim)}

/* ===== BRAND DOT ===== */
.dot{
  display:inline-block;border-radius:50%;flex-shrink:0;
  background:radial-gradient(circle at 38% 32%,#6a6ef0 0%,#2b2fb8 46%,#1b2178 100%);
}
body[data-theme="dark"] .dot{box-shadow:0 0 14px rgba(80,84,234,.55)}

/* ===== LAYOUT ===== */
#app-root{display:flex;flex-direction:column;height:100%;position:relative}
#main-content{flex:1;min-height:0;position:relative;overflow:hidden}

/* ===== VIEWS ===== */
.view{
  position:absolute;inset:0;
  display:none;flex-direction:column;
  background:var(--bg);
}
.view.on{display:flex}

.scr-body{flex:1;min-height:0;overflow-y:auto}

/* ===== SCREEN ENTRANCE ===== */
@keyframes screen-in{from{transform:translateY(10px)}to{transform:none}}
.screen-anim{animation:screen-in .34s cubic-bezier(.3,.8,.3,1)}
@media(prefers-reduced-motion:reduce){.screen-anim{animation:none}}

/* ===== BOTTOM TAB BAR ===== */
#tabbar{
  flex-shrink:0;
  padding:11px 12px calc(22px + env(safe-area-inset-bottom,0px));
  border-top:1px solid var(--hair);
  background:var(--bg);
  position:relative;z-index:100;
}
.tab-row{position:relative;display:flex;width:100%}
.tab-ind{
  position:absolute;top:0;
  width:5px;height:5px;margin-left:-2.5px;
  border-radius:50%;background:var(--accent);
  transition:left .36s cubic-bezier(.45,1.35,.4,1);
}
body[data-theme="dark"] .tab-ind{box-shadow:0 0 8px var(--accent)}
@media(prefers-reduced-motion:reduce){.tab-ind{transition:none}}

.tab-btn{
  flex:1;background:none;border:none;cursor:pointer;
  display:flex;flex-direction:column;align-items:center;gap:5px;
  color:var(--tab-off);padding:8px 6px 2px;
}
.tab-btn.on{color:var(--text)}
.tab-ic{
  display:inline-flex;align-items:center;justify-content:center;
  font-size:15px;line-height:1;position:relative;
  transition:transform .32s cubic-bezier(.4,1.4,.4,1);
}
.tab-btn.on .tab-ic{transform:translateY(-2px) scale(1.14)}
@media(prefers-reduced-motion:reduce){.tab-ic{transition:none}}
.tab-lbl{font-family:"Space Mono",monospace;font-size:8.5px;letter-spacing:.04em}
.tab-badge{
  position:absolute;top:-7px;right:-11px;
  background:var(--accent);color:#fff;
  font-family:"Space Mono",monospace;font-size:7.5px;font-weight:700;
  border-radius:8px;padding:1px 4px;line-height:1.3;
}

/* ===== SCREEN HEAD ===== */
.scr-head{
  padding:18px 24px 0;
  display:flex;justify-content:space-between;align-items:flex-start;
  flex-shrink:0;
}
.scr-title{
  font-family:"Syne",sans-serif;font-weight:800;font-size:30px;
  letter-spacing:-.01em;line-height:1;color:var(--text);
}
.scr-sub{
  font-family:"Space Mono",monospace;font-size:9.5px;
  letter-spacing:.1em;margin-top:6px;color:var(--dim);
  text-transform:uppercase;
}

/* ===== THEME TOGGLE BUTTON ===== */
.theme-toggle{
  display:flex;align-items:center;gap:7px;cursor:pointer;
  border:1px solid var(--hair-strong);background:var(--surface);color:var(--text);
  border-radius:22px;padding:6px 11px 6px 8px;
  font-family:inherit;font-size:inherit;flex-shrink:0;
}
.theme-toggle-icon{font-size:13px;line-height:1}
.theme-toggle-lbl{
  font-family:"Space Mono",monospace;font-size:9.5px;
  letter-spacing:.08em;color:var(--dim);
}

/* ===== HOME SCREEN ===== */
#vhome .scr-body{
  padding:26px 24px 20px;
  display:flex;flex-direction:column;
}
.home-top{display:flex;justify-content:space-between;align-items:flex-start}
.home-top-controls{display:flex;align-items:center;gap:8px}
.home-brand-label{
  font-family:"Space Mono",monospace;font-size:9.5px;
  letter-spacing:.2em;text-transform:uppercase;
  color:var(--dim);max-width:180px;line-height:1.5;
}
.home-wordmark{
  font-family:"Syne",sans-serif;font-weight:800;
  font-size:64px;line-height:.88;letter-spacing:-.025em;
  margin-top:30px;color:var(--text);
}
.home-ps-title{
  font-family:"Syne",sans-serif;font-weight:700;
  font-size:12.5px;letter-spacing:.14em;color:var(--dim);margin-top:24px;
}
.home-location{
  font-family:"Space Mono",monospace;font-size:10px;
  margin-top:7px;letter-spacing:.04em;color:var(--dim);
}
.countdown-card{
  margin-top:26px;padding:18px 20px;border-radius:18px;
  background:var(--surface);border:1px solid var(--hair);
  display:flex;justify-content:space-between;align-items:center;
}
.countdown-label{
  font-family:"Space Mono",monospace;font-size:9px;
  letter-spacing:.14em;color:var(--dim);
}
.countdown-days{
  font-family:"Syne",sans-serif;font-size:32px;font-weight:800;
  margin-top:5px;color:var(--text);
}
.countdown-days-unit{font-size:14px;color:var(--dim)}
.countdown-dates{
  font-family:"Space Mono",monospace;font-size:10px;
  text-align:right;line-height:1.7;color:var(--dim);
}
.home-upnext-card{
  margin-top:26px;border-radius:16px;border:1px solid var(--hair);
  background:var(--surface);padding-bottom:10px;
}
.home-upnext-hdr{
  font-family:"Space Mono",monospace;font-size:8px;
  letter-spacing:.18em;color:var(--accent-text);
  padding:10px 14px 4px;
}
.home-banner{
  margin:12px 0 0;padding:12px 14px;
  background:#FF8C0015;border:1px solid #FF8C0050;
  border-radius:12px;font-size:13px;line-height:1.6;color:var(--text);
}
.home-nav{margin-top:22px}
.home-nav-item{
  display:flex;justify-content:space-between;align-items:center;
  gap:12px;padding:16px 0;
  border-top:1px solid var(--hair);cursor:pointer;
}
.home-nav-item:first-child{border-top:none}
.home-nav-title{font-size:16px;font-weight:700;color:var(--text)}
.home-nav-sub{
  font-family:"Space Mono",monospace;font-size:8.5px;
  letter-spacing:.05em;margin-top:3px;color:var(--dim);
}
.home-nav-arrow{color:var(--dim);font-size:22px;flex-shrink:0;transition:transform .15s}
.home-nav-item:hover .home-nav-arrow{transform:translate(2px,-2px)}
.home-spacer{flex:1;min-height:18px}
.home-footer{
  padding-top:16px;border-top:1px solid var(--hair);
  display:flex;flex-direction:column;gap:10px;flex-shrink:0;
}
.home-made-by{
  font-family:"Space Mono",monospace;font-size:9px;
  letter-spacing:.08em;color:var(--dim);
}
.home-brand-stmt{
  font-family:"Space Mono",monospace;font-size:9px;
  letter-spacing:.06em;color:var(--dim);line-height:2;
}
.home-kofi{
  font-family:"Space Mono",monospace;font-size:9px;
  letter-spacing:.06em;color:var(--dim);text-decoration:none;
}
.home-kofi:hover{color:var(--text)}
.hub-title-row{display:flex;align-items:center;gap:7px;flex-wrap:wrap}
.hub-badge{
  font-family:"Space Mono",monospace;font-size:9px;
  letter-spacing:.08em;font-weight:700;
  padding:2px 7px;border-radius:20px;white-space:nowrap;line-height:1.6;
}.hub-ended{background:rgba(128,128,128,.13);color:var(--dim)}
.hub-upcoming{background:rgba(80,168,255,.1);color:#5aabff}
.hub-live{background:rgba(74,222,128,.15);color:#4ade80;animation:hub-pulse 2s ease-in-out infinite}
@keyframes hub-pulse{0%,100%{opacity:1}50%{opacity:.55}}
.lang-menu{position:relative}
.lang-menu-btn{
  display:inline-flex;align-items:center;gap:4px;
  font-family:"Space Mono",monospace;font-size:10px;letter-spacing:.08em;
  color:var(--dim);background:var(--surface);
  border:1px solid var(--hair-strong);border-radius:20px;
  padding:5px 11px;cursor:pointer;
}
.lang-menu-arrow{font-size:8px;opacity:.7}
.lang-menu-dd{
  display:none;position:absolute;right:0;top:calc(100% + 6px);
  background:var(--surface);border:1px solid var(--hair-strong);
  border-radius:12px;overflow:hidden;z-index:200;min-width:110px;
  box-shadow:0 6px 20px rgba(0,0,0,.13);
}
.lang-menu-dd.open{display:block}
.lang-menu-item{
  display:block;width:100%;text-align:left;
  padding:10px 16px;font-family:"Space Mono",monospace;font-size:10px;
  color:var(--dim);background:none;border:none;cursor:pointer;letter-spacing:.04em;
}
.lang-menu-item.on{color:var(--accent-text);font-weight:700}
.lang-menu-item:active{background:var(--surface-2)}

/* ===== NOW PLAYING (global bar above tab bar) ===== */
#now-playing{
  display:none;flex-shrink:0;
  background:var(--surface);
  border:1px solid var(--hair);
  border-radius:16px;
  margin:8px 16px 0;
  overflow:hidden;
  position:relative;
  padding-bottom:10px;
}
.np-header{
  font-family:"Space Mono",monospace;font-size:8px;
  letter-spacing:.18em;color:var(--accent-text);
  text-transform:uppercase;padding:10px 14px 4px;
}
.np-group{display:flex;align-items:center}
.np-group-artists{flex:1;min-width:0}
.np-row{
  display:flex;align-items:center;gap:8px;
  padding:6px 14px;
}
.np-name{
  flex:1;min-width:0;overflow:hidden;
  text-overflow:ellipsis;white-space:nowrap;font-size:14px;
}
.np-time{
  font-family:"Space Mono",monospace;
  font-variant-numeric:tabular-nums;white-space:nowrap;
  min-width:40px;text-align:right;padding:0 14px 0 8px;font-size:13px;
}
.np-more-link{
  display:block;font-family:"Space Mono",monospace;font-size:10px;
  color:var(--dim);text-align:right;padding:2px 14px 6px;cursor:pointer;
}
.spill{
  border-radius:4px;padding:2px 6px;font-size:8px;
  font-family:"Space Mono",monospace;letter-spacing:.03em;
  border:1px solid transparent;white-space:nowrap;flex-shrink:0;
}
@keyframes upnextglow{
  0%,100%{box-shadow:0 0 var(--hs-b1,8px) 2px var(--gc,#888)33}
  50%{box-shadow:0 0 var(--hs-b2,16px) 5px var(--gc,#888)66}
}

/* ===== DAY CAPSULE TABS ===== */
#dtabs{
  display:block;padding:10px 24px 0;
  flex-shrink:0;position:relative;
}
#dtabs-map{
  display:block;padding:10px 24px 8px;
  flex-shrink:0;position:relative;
}
.dtab-row{display:flex;gap:6px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;}
.dtab-row::-webkit-scrollbar{display:none}
.dtab{
  flex-shrink:0;white-space:nowrap;
  font-family:"Space Mono",monospace;font-size:11px;font-weight:700;
  padding:7px 14px;border-radius:22px;
  background:var(--surface);color:var(--dim);
  border:none;cursor:pointer;transition:background .15s,color .15s;
}
.dtab.on{background:var(--text);color:var(--bg);}
.day-picker{position:relative;}
.day-picker-btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:7px 14px;border-radius:22px;
  background:var(--surface);color:var(--text);
  border:none;cursor:pointer;
  font-family:"Space Mono",monospace;font-size:11px;font-weight:700;
  transition:background .15s;
}
.day-picker-caret{font-size:9px;opacity:0.4;transition:transform .2s;}
.day-picker-btn.open .day-picker-caret{transform:rotate(180deg);}
.day-picker-panel{
  position:absolute;top:calc(100% + 6px);left:0;right:0;
  background:var(--card,var(--surface));
  border-radius:14px;padding:8px;
  display:grid;grid-template-columns:repeat(4,1fr);gap:4px;
  z-index:200;
  box-shadow:0 8px 32px rgba(0,0,0,0.24);
  opacity:0;pointer-events:none;
  transform:translateY(-6px) scaleY(0.95);
  transform-origin:top center;
  transition:opacity .15s,transform .15s;
}
.day-picker-panel.open{
  opacity:1;pointer-events:auto;
  transform:translateY(0) scaleY(1);
}
.dtab-opt{
  text-align:center;padding:9px 2px;border-radius:8px;
  cursor:pointer;background:transparent;color:var(--dim);
  border:none;transition:background .15s,color .15s;
}
.dtab-opt.on{background:var(--text);color:var(--bg);}
.dtab-opt-dow{display:block;font-size:8px;opacity:0.6;line-height:1.3;}
.dtab-opt-md{display:block;font-size:10px;font-weight:700;line-height:1.5;}

/* ===== SORT BAR ===== */
#sort-bar{
  display:flex;gap:6px;padding:13px 24px 4px;flex-shrink:0;
}
#sort-bar .slbl{display:none}
.srt{
  font-family:"Space Mono",monospace;font-size:9px;
  padding:6px 11px;border-radius:20px;cursor:pointer;
  border:1px solid var(--hair-strong);background:transparent;
  color:var(--dim);transition:all .15s;
}
.srt.on{background:var(--accent-soft);color:var(--accent-text);border-color:transparent}
.srt-fav{margin-left:auto}

/* ===== CATEGORY TAB BAR ===== */
.cat-tabs{
  display:flex;gap:0;padding:6px 16px 0;flex-shrink:0;
  border-bottom:1px solid var(--hair);overflow-x:auto;scrollbar-width:none;
}
.cat-tabs::-webkit-scrollbar{display:none}
.ctab{
  font-family:"Space Mono",monospace;font-size:10px;font-weight:700;letter-spacing:0.06em;
  padding:6px 12px 8px;border:none;background:transparent;cursor:pointer;
  color:var(--dim);white-space:nowrap;flex-shrink:0;
  border-bottom:2px solid transparent;margin-bottom:-1px;
  transition:color .15s,border-color .15s;
}
.ctab.on{color:var(--text);border-bottom-color:var(--text);}

/* ===== STAGE FILTER BAR ===== */
#fbar{
  display:flex;flex-direction:column;gap:0;flex-shrink:0;
}
.sfs{
  display:flex;gap:6px;padding:8px 24px 0;
  overflow-x:auto;scrollbar-width:none;
}
.sfs::-webkit-scrollbar{display:none}
.sfb{
  font-family:"Space Mono",monospace;font-size:9px;
  padding:5px 10px;border-radius:11px;
  border:1px solid var(--hair-strong);cursor:pointer;
  white-space:nowrap;background:var(--surface);color:var(--dim);
  transition:all .15s;flex-shrink:0;
}
.sfb.all.on{background:var(--text);color:var(--bg);border-color:transparent}
.dbadge{display:none}

/* ===== SCHEDULE LIST ===== */
#slist{padding:8px 24px 16px}

/* ===== SHOW CARDS ===== */
.si{
  display:flex;align-items:center;gap:14px;
  padding:13px 15px;margin-bottom:9px;
  border-radius:16px;background:var(--surface);
  border:1px solid var(--hair);
  transition:border-color .2s,opacity .2s;
  position:relative;overflow:visible;
}
.si.current-set{border-color:var(--accent-soft)}
/* .si.faved — no extra style in new design */
.si.past{opacity:.42}
.si.dimmed{opacity:.3}

.stime{flex-shrink:0;display:flex;flex-direction:column;gap:2px}
.tstart{
  font-family:"Space Mono",monospace;font-size:11px;font-weight:700;
  font-variant-numeric:tabular-nums;color:var(--text);line-height:1;
}
.tend{font-family:"Space Mono",monospace;font-size:9px;font-variant-numeric:tabular-nums;color:var(--dim);line-height:1}
.tlate{display:none}
.scur{
  font-family:"Space Mono",monospace;font-size:7px;
  color:var(--accent-text);
  animation:blink 1s step-end infinite;line-height:1;
}
@keyframes blink{50%{opacity:0}}

/* hide legacy elements */
.hlbar{display:none}

.sartist{flex:1;min-width:0}
.aname{
  font-family:"Syne",sans-serif;font-size:15.5px;font-weight:700;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
  line-height:1.2;color:var(--text);
}
.sc-stage-lbl{
  font-family:"Space Mono",monospace;font-size:8.5px;
  color:var(--dim);margin-top:2px;
}
.hllabel{display:none}
.conflict-badge{
  font-family:"Space Mono",monospace;font-size:8px;
  color:var(--conflict);margin-top:2px;display:inline-block;
}
.hl-badge{
  font-family:"Space Mono",monospace;font-size:9px;
  color:var(--accent-text);font-weight:400;letter-spacing:.03em;
  vertical-align:middle;opacity:.9;
}
.cancelled-badge{
  font-family:"Space Mono",monospace;font-size:9px;
  color:var(--dim);font-weight:400;letter-spacing:.04em;
  vertical-align:middle;
}
.si.cancelled,.my-item.cancelled{opacity:0.55;}
.orig-time{text-decoration:line-through;opacity:0.5;font-weight:400;}

/* legacy fav-star fallback */
.fav-star{
  font-size:16px;cursor:pointer;flex-shrink:0;
  padding:4px;line-height:1;background:none;border:none;
  color:var(--heart-off);transition:color .15s;
}
.si.faved .fav-star,.fav-star.on{color:var(--heart)}

/* past toggle */
.past-toggle{
  display:block;width:100%;padding:7px 0;
  background:none;border:none;color:var(--dim);
  font-family:"Space Mono",monospace;font-size:9px;
  letter-spacing:.08em;text-align:left;cursor:pointer;margin-bottom:6px;
}
.past-toggle.on{color:var(--text)}
.past-sep{height:1px;background:var(--hair);margin:4px 0 12px}
.foot{
  font-family:"Space Mono",monospace;font-size:9px;color:var(--dim);
  text-align:center;padding:12px 0;letter-spacing:.05em;
}

/* ===== HEART BUTTON ===== */
.heart-btn{
  background:none;border:none;cursor:pointer;
  line-height:1;padding:4px;position:relative;
  flex-shrink:0;font-size:17px;color:var(--heart-off);
  transition:color .15s;
}
.heart-btn.on{color:var(--heart)}
.heart-btn .glyph{display:inline-block}
.heart-btn.pop .glyph{animation:heart-pop .4s cubic-bezier(.3,1.7,.5,1)}
@keyframes heart-pop{
  0%{transform:scale(1)}28%{transform:scale(1.5)}
  52%{transform:scale(.82)}78%{transform:scale(1.12)}100%{transform:scale(1)}
}
.heart-btn .ring{
  position:absolute;inset:0;margin:auto;
  width:22px;height:22px;border-radius:50%;
  border:2px solid var(--heart);opacity:0;pointer-events:none;
}
.heart-btn.pop .ring{animation:heart-ring .45s ease-out}
@keyframes heart-ring{
  0%{transform:scale(.3);opacity:.55}100%{transform:scale(1.9);opacity:0}
}
@media(prefers-reduced-motion:reduce){
  .heart-btn.pop .glyph,.heart-btn.pop .ring{animation:none}
}

/* ===== MAP SCREEN ===== */
#vmap .scr-body{
  display:flex;flex-direction:column;
  padding:16px 18px 14px;gap:0;
}
#mapview{display:flex;flex-direction:column;flex:1;gap:0}
.map-hint-bar{
  display:flex;align-items:center;justify-content:space-between;
  padding:7px 4px 9px;flex-shrink:0;
}
.map-hint-bar span{
  font-family:"Space Mono",monospace;font-size:9px;color:var(--dim);
}
.zbtn{
  background:var(--raise);border:1px solid var(--hair-strong);
  color:var(--text);border-radius:10px;padding:4px 12px;
  font-size:13px;cursor:pointer;font-family:"Space Mono",monospace;
}
.rbtn{
  background:var(--raise);border:1px solid var(--hair-strong);
  color:var(--dim);border-radius:10px;padding:4px 9px;
  font-size:10px;cursor:pointer;font-family:"Space Mono",monospace;
}
.map-wrap{
  position:relative;width:100%;overflow:hidden;
  background:var(--surface-2);touch-action:none;user-select:none;
  border-radius:14px;border:1px solid var(--hair);
  aspect-ratio:var(--map-w,2000)/var(--map-h,1345);max-height:65vh;flex-shrink:0;
}
.map-inner{
  position:relative;transform-origin:0 0;
  will-change:transform;line-height:0;width:calc(var(--map-w,2000)*1px);
}
#mapimg{
  display:block;width:calc(var(--map-w,2000)*1px);height:calc(var(--map-h,1345)*1px);
  pointer-events:none;user-select:none;-webkit-user-drag:none;
  image-rendering:auto;
}
.hs{
  position:absolute;border-radius:6px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  box-sizing:border-box;
  transition:border-color .3s,box-shadow .3s,background .3s;
}
.hs.selected{
  border-width:2px!important;
  box-shadow:0 0 12px 3px var(--hs-glow,rgba(255,255,255,.6)),0 0 24px 6px var(--hs-glow,rgba(255,255,255,.3));
}
@keyframes hsglow{
  0%,100%{box-shadow:0 0 var(--hs-b1,8px) var(--gc,#fff)44}
  50%{box-shadow:0 0 var(--hs-b2,18px) var(--gc,#fff)88}
}
.hs-label{
  font-family:"Space Mono",monospace;
  font-size:clamp(7px,2vw,10px);
  font-weight:700;
  background:rgba(255,255,255,0.92);border-radius:3px;
  padding:2px 5px;pointer-events:none;white-space:nowrap;
  color:inherit;line-height:1.3;
}
#stagepop{
  display:none;margin:10px 0 0;
  background:var(--surface);border:1px solid var(--hair-strong);
  border-radius:14px;overflow:hidden;opacity:0;transition:opacity .25s;
  flex-shrink:0;
}
#stagepop.visible{opacity:1}
.pop-head{
  padding:11px 14px 9px;border-bottom:1px solid var(--hair);
  display:flex;align-items:center;justify-content:space-between;
}
.pop-stage{font-family:"Syne",sans-serif;font-size:15px;font-weight:700}
.pop-close{
  background:none;border:none;color:var(--dim);
  font-size:20px;cursor:pointer;line-height:1;padding:0 3px;
}
.pop-show{
  display:flex;align-items:center;gap:10px;
  padding:9px 14px;border-bottom:1px solid var(--hair);
}
.pop-show:last-child{border-bottom:none}
.pop-show.live-row{background:var(--accent-soft)}
.pop-time{
  font-family:"Space Mono",monospace;font-size:11px;
  color:var(--dim);min-width:38px;font-variant-numeric:tabular-nums;
}
.pop-artist{font-size:13px;color:var(--text);flex:1}
.pop-artist.hl{font-family:"Syne",sans-serif;font-weight:700}
.pop-fav{font-size:15px;color:var(--heart-off);cursor:pointer;transition:color .15s}
.pop-fav.on{color:var(--heart)}
.pop-cur{
  font-family:"Space Mono",monospace;font-size:9px;
  color:var(--accent-text);margin-left:4px;
  animation:blink 1s step-end infinite;
}
.pop-empty{padding:16px;font-size:11px;color:var(--dim);text-align:center}
.foot.mapfoot{font-family:"Space Mono",monospace;font-size:9px;color:var(--dim);padding:8px 4px 0;text-align:left}
.map-official-btn{
  display:block;font-family:"Space Mono",monospace;font-size:10px;
  color:var(--accent-text);letter-spacing:.04em;
  text-decoration:none;padding:8px 4px 4px;
  text-align:center;
}

/* ===== FAVORITES SCREEN ===== */
#mylist{padding:18px 24px 16px}
.my-day-header{
  font-family:"Space Mono",monospace;font-size:9.5px;
  letter-spacing:.16em;color:var(--dim);
  margin-bottom:10px;text-transform:uppercase;
}
.my-item{
  display:flex;align-items:center;gap:14px;
  padding:12px 15px;margin-bottom:8px;
  border-radius:16px;background:var(--surface);border:1px solid var(--hair);
}
.my-item.conflict{
  border-color:var(--conflict-soft);
  box-shadow:inset 3px 0 0 var(--conflict);
}
.my-item.current-set{border-color:var(--accent-soft)}
.my-conflict-label{
  font-family:"Space Mono",monospace;font-size:8px;
  color:var(--conflict);margin-top:2px;
}
.my-empty{padding:70px 24px;text-align:center}
.my-empty-heart{font-size:34px;color:var(--heart-off)}
.my-empty-text{
  font-family:"Space Mono",monospace;font-size:11px;
  color:var(--dim);margin-top:14px;line-height:1.9;letter-spacing:.04em;
}

/* ===== INFO SCREEN ===== */
#info-body{padding:16px 24px 20px}
.info-section{
  margin-bottom:11px;padding:15px 16px;
  border-radius:16px;background:var(--surface);border:1px solid var(--hair);
}
.info-h{
  font-family:"Syne",sans-serif;font-size:14px;font-weight:700;
  color:var(--text);margin-bottom:10px;
}
.info-row{
  display:flex;gap:10px;margin-bottom:8px;align-items:baseline;
}
.info-row:last-child{margin-bottom:0}
.info-icon{
  font-size:16px;flex-shrink:0;width:24px;
  text-align:center;line-height:1.5;
}
.info-text{font-size:12px;color:var(--text);line-height:1.55}
.info-text strong{color:var(--text)}
.info-chip{
  display:inline-block;background:var(--surface-2);
  border:1px solid var(--hair-strong);border-radius:8px;
  padding:2px 8px;font-family:"Space Mono",monospace;font-size:10px;
  color:var(--dim);margin:2px 3px 2px 0;
}
.info-chip.red{border-color:rgba(255,87,34,.3);color:#d94a1e;background:rgba(255,87,34,.08)}
.info-chip.green{border-color:rgba(74,222,128,.3);color:#2d9a5a;background:rgba(74,222,128,.08)}
.weather-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:6px}
.weather-day{
  background:var(--surface-2);border:1px solid var(--hair);
  border-radius:12px;padding:8px 12px;text-align:center;
  flex:1;min-width:60px;
}
.wd-date{font-family:"Space Mono",monospace;font-size:9px;color:var(--dim);margin-bottom:4px}
.wd-icon{font-size:20px;margin-bottom:2px}
.wd-temp{font-family:"Syne",sans-serif;font-size:14px;font-weight:700;color:var(--text)}
.wd-desc{font-family:"Space Mono",monospace;font-size:9px;color:var(--dim);margin-top:2px}
.footer-link,.footer-mail{color:var(--accent-text);text-decoration:underline;text-underline-offset:2px}
#app-footer{display:none}
.info-footer{padding:20px 18px 32px;border-top:1px solid var(--hair);margin-top:8px;text-align:center}
#vhome .info-footer{padding-left:0;padding-right:0}
.info-footer p{margin:0 0 10px}
.info-disclaimer{font-family:"Space Mono",monospace;font-size:9px;color:var(--dim);line-height:1.8}
.info-made{font-family:"Space Mono",monospace;font-size:10px;color:var(--dim)}
.info-ig{color:var(--accent-text);cursor:pointer;text-decoration:underline;text-underline-offset:2px}
.info-privacy{font-family:"Space Mono",monospace;font-size:8px;color:var(--faint);line-height:1.6}

/* ===== VIEW TRANSITIONS ===== */
@supports(view-transition-name:root){
  ::view-transition-old(root){animation:none;z-index:1}
  ::view-transition-new(root){animation:vt-reveal .55s cubic-bezier(.45,0,.2,1);z-index:2}
  @keyframes vt-reveal{
    from{clip-path:circle(0px at var(--vt-x,50%) var(--vt-y,10%))}
    to{clip-path:circle(160vmax at var(--vt-x,50%) var(--vt-y,10%))}
  }
}
@media(prefers-reduced-motion:reduce){
  ::view-transition-old(root),::view-transition-new(root){animation:none!important}
}
