/* K-Popit Tour Tracker — Shared Styles */
:root{
  --c-bg:#FFF6E5;
  --c-bg-2:#FFEFD0;
  --c-ink:#2A1B3D;
  --c-muted:#6F5E78;
  --c-card:#FFFCF4;
  --c-line:#E5D5BA;
  --c-purple:#7C5CE6;
  --c-purple-dk:#3C1F8C;
  --c-pink:#FF7AB2;
  --c-pink-dk:#B8336A;
  --c-yellow:#FFD23F;
  --c-yellow-dk:#A07700;
  --c-orange:#FF6B35;
  --c-orange-dk:#A93A0E;
  --c-green:#5FCB7E;
  --c-green-dk:#1F7A3F;
  --c-blue:#4FB3F0;
  --c-blue-dk:#0A4F87;
  --shadow-pop:4px 4px 0 var(--c-ink);
  --shadow-pop-lg:6px 6px 0 var(--c-ink);
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{font-family:'Gowun Dodum','Fredoka',sans-serif;color:var(--c-ink);background:var(--c-bg);overflow-x:hidden}
body{
  background:
    radial-gradient(circle at 15% 20%,rgba(255,210,63,.25) 0,transparent 40%),
    radial-gradient(circle at 85% 80%,rgba(255,122,178,.2) 0,transparent 45%),
    linear-gradient(180deg,#FFEFD0 0%,#FFF6E5 50%,#FFE5F0 100%);
  min-height:100vh;
  position:relative;
}
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:0;
  background-image:
    radial-gradient(circle at 8% 12%,#FFD23F 2px,transparent 3px),
    radial-gradient(circle at 92% 18%,#FF7AB2 2px,transparent 3px),
    radial-gradient(circle at 25% 90%,#7C5CE6 2px,transparent 3px),
    radial-gradient(circle at 78% 85%,#5FCB7E 2px,transparent 3px),
    radial-gradient(circle at 50% 5%,#4FB3F0 2px,transparent 3px);
}
.shell{position:relative;z-index:1;max-width:1480px;margin:0 auto;padding:18px 24px 32px}

/* ===== Header / Brand ===== */
header.hero{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:18px;flex-wrap:wrap}
.brand{display:flex;align-items:center;gap:14px;text-decoration:none;color:inherit}
.brand-mark{width:54px;height:54px;border-radius:14px;background:var(--c-yellow);border:3px solid var(--c-ink);box-shadow:var(--shadow-pop);display:flex;align-items:center;justify-content:center;font-family:'Jua',sans-serif;font-size:26px;color:var(--c-ink);transform:rotate(-4deg);flex-shrink:0}
.brand-text h1{font-family:'Jua',sans-serif;font-size:clamp(20px,2.6vw,28px);letter-spacing:.5px;line-height:1;color:var(--c-purple-dk);text-shadow:2px 2px 0 var(--c-yellow)}
.brand-text .sub{font-size:13px;color:var(--c-muted);margin-top:4px;font-weight:500}
.live-badge{display:inline-flex;align-items:center;gap:6px;background:var(--c-pink);color:#fff;font-family:'Jua',sans-serif;padding:8px 16px;border-radius:24px;border:3px solid var(--c-ink);box-shadow:var(--shadow-pop);font-size:14px;transform:rotate(2deg)}
.live-badge::before{content:"";width:8px;height:8px;border-radius:50%;background:#fff;animation:blink 1s infinite}
@keyframes blink{50%{opacity:.3}}

/* ===== Language toggle ===== */
.lang-toggle{
  background:var(--c-card);border:3px solid var(--c-ink);border-radius:24px;
  padding:8px 18px;font-family:'Jua',sans-serif;font-size:14px;color:var(--c-ink);
  cursor:pointer;box-shadow:var(--shadow-pop);transition:transform .1s;
  letter-spacing:.5px;min-width:64px;text-align:center;flex-shrink:0;
}
.lang-toggle:hover{background:var(--c-yellow)}
.lang-toggle:active{transform:translate(2px,2px);box-shadow:1px 1px 0 var(--c-ink)}

/* ===== City info toggle ===== */
.info-toggle{
  display:block;width:100%;
  margin:10px 0 4px;
  padding:9px 12px;
  background:var(--c-bg-2);
  border:2px dashed var(--c-purple);
  border-radius:10px;
  font-family:'Jua',sans-serif;font-size:13px;letter-spacing:.3px;
  color:var(--c-purple-dk);
  cursor:pointer;
  transition:background .15s, transform .1s;
}
.info-toggle:hover{background:var(--c-yellow);border-style:solid}
.info-toggle:active{transform:translateY(1px)}
.info-extra{animation:fadeInExtra .25s ease-out}
@keyframes fadeInExtra{
  from{opacity:0;transform:translateY(-4px)}
  to{opacity:1;transform:translateY(0)}
}

/* ===== Chat ===== */
#chat{margin-top:16px}
.chat-card{
  background:var(--c-card);
  border:3px solid var(--c-ink);
  border-radius:14px;
  box-shadow:var(--shadow-pop);
  overflow:hidden;
  display:flex;flex-direction:column;
}
.chat-header{
  background:linear-gradient(135deg,var(--c-purple) 0%,var(--c-pink) 100%);
  color:#fff;
  padding:11px 14px;
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  border-bottom:3px solid var(--c-ink);
}
.chat-title{display:flex;align-items:center;gap:8px;font-family:'Jua',sans-serif;font-size:17px;letter-spacing:.3px}
.chat-emoji{font-size:18px}
.chat-status{
  font-family:'Jua',sans-serif;font-size:11px;letter-spacing:.6px;
  padding:4px 10px;border-radius:14px;border:2px solid var(--c-ink);
  display:inline-flex;align-items:center;gap:5px;flex-shrink:0;
}
.chat-status.live{background:var(--c-pink-dk);color:#fff}
.chat-status.live .dot{
  width:6px;height:6px;border-radius:50%;background:#fff;animation:blink 1s infinite;
}
.chat-status.demo{background:var(--c-yellow);color:var(--c-ink)}

.chat-messages{
  min-height:160px;max-height:300px;overflow-y:auto;
  padding:12px;background:linear-gradient(180deg,#FFFCF4 0%,#FFF6E5 100%);
  display:flex;flex-direction:column;gap:8px;
  scrollbar-width:thin;scrollbar-color:var(--c-purple) transparent;
}
.chat-messages::-webkit-scrollbar{width:6px}
.chat-messages::-webkit-scrollbar-thumb{background:var(--c-purple);border-radius:3px}
.chat-empty{color:var(--c-muted);font-size:13px;text-align:center;padding:36px 16px;font-style:italic}
.chat-empty.chat-err-state{
  color:var(--c-pink-dk);font-style:normal;font-weight:600;
  background:#FFE5EE;border:2px dashed var(--c-pink-dk);border-radius:10px;
  padding:18px 14px;margin:8px;line-height:1.5;
}

.chat-msg{
  background:#fff;
  border:2px solid var(--c-ink);
  border-radius:10px;
  padding:8px 10px;
  box-shadow:2px 2px 0 var(--c-ink);
}
.chat-msg.is-new{animation:fadeInMsg .35s ease-out}
@keyframes fadeInMsg{
  from{opacity:0;transform:translateY(8px) scale(.98)}
  to{opacity:1;transform:translateY(0) scale(1)}
}
.chat-msg-head{display:flex;align-items:center;gap:6px;font-size:12px;margin-bottom:4px;flex-wrap:wrap}
.chat-flag{font-size:15px;line-height:1}
.chat-nick-label{font-family:'Jua',sans-serif;color:var(--c-purple-dk);font-weight:600}
.chat-time{margin-left:auto;color:var(--c-muted);font-size:11px}
.chat-msg-body{font-size:14px;color:var(--c-ink);word-break:break-word;line-height:1.45}

.chat-input{
  padding:10px 12px 12px;border-top:3px solid var(--c-ink);background:var(--c-bg-2);
}
.chat-input-row{display:flex;gap:6px;margin-bottom:6px;align-items:stretch}
.chat-input-row:last-of-type{margin-bottom:0}
.chat-nick,.chat-country,.chat-text{
  border:2px solid var(--c-ink);border-radius:8px;padding:7px 10px;
  font-family:'Gowun Dodum',sans-serif;font-size:13px;
  background:#fff;color:var(--c-ink);min-width:0;
}
.chat-nick{flex:1.1}
.chat-country{flex:1.4;cursor:pointer;font-size:12px;appearance:none;-webkit-appearance:none;
  background-image:linear-gradient(45deg,transparent 50%,var(--c-purple) 50%),linear-gradient(135deg,var(--c-purple) 50%,transparent 50%);
  background-position:calc(100% - 14px) 50%,calc(100% - 9px) 50%;
  background-size:5px 5px,5px 5px;background-repeat:no-repeat;padding-right:24px;
}
.chat-text{flex:1}
.chat-text:focus,.chat-nick:focus,.chat-country:focus{outline:none;background:#FFF8E1}
.chat-send{
  background:var(--c-purple);color:#fff;
  border:2px solid var(--c-ink);border-radius:8px;
  padding:7px 14px;font-family:'Jua',sans-serif;font-size:13px;letter-spacing:.3px;
  cursor:pointer;box-shadow:2px 2px 0 var(--c-ink);
  white-space:nowrap;flex-shrink:0;
  transition:transform .08s;
}
.chat-send:hover{background:var(--c-purple-dk)}
.chat-send:active{transform:translate(2px,2px);box-shadow:0 0 0 var(--c-ink)}
.chat-counter{font-size:11px;color:var(--c-muted);text-align:right;margin-top:4px;font-variant-numeric:tabular-nums}

.chat-error{
  display:none;
  margin:6px 0 0;padding:7px 10px;
  background:#FFE5EE;border:2px solid var(--c-pink-dk);
  border-radius:8px;
  color:var(--c-pink-dk);font-size:12px;font-weight:600;
  box-shadow:2px 2px 0 var(--c-ink);
}
.chat-error.show{display:block;animation:fadeInMsg .25s ease-out}

.chat-status[title]{cursor:help}
.chat-status.demo{position:relative}
.chat-status.demo::after{
  content:"?";display:inline-block;margin-left:4px;
  width:14px;height:14px;border-radius:50%;
  background:var(--c-ink);color:var(--c-yellow);
  font-size:10px;line-height:14px;text-align:center;font-family:'Jua',sans-serif;
}

@media(max-width:520px){
  .chat-meta-row{flex-direction:column}
  .chat-status{font-size:10px;padding:3px 8px}
}

/* ===== Stats Strip ===== */
.stats-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:18px}
.stat{background:var(--c-card);border:3px solid var(--c-ink);border-radius:14px;padding:12px 14px;box-shadow:var(--shadow-pop);position:relative;overflow:hidden}
.stat::after{content:"";position:absolute;top:-10px;right:-10px;width:40px;height:40px;background:var(--accent,var(--c-yellow));border-radius:50%;opacity:.4}
.stat .n{font-family:'Jua',sans-serif;font-size:30px;color:var(--c-ink);line-height:1}
.stat .l{font-size:12px;color:var(--c-muted);margin-top:4px;font-weight:600}
.stat:nth-child(1){--accent:#FFD23F}
.stat:nth-child(2){--accent:#FF7AB2}
.stat:nth-child(3){--accent:#5FCB7E}
.stat:nth-child(4){--accent:#4FB3F0}

/* ===== Tracker Layout ===== */
.layout{display:grid;grid-template-columns:1fr 420px;gap:16px;align-items:start}
@media(max-width:1100px){.layout{grid-template-columns:1fr}}
.map-card{background:linear-gradient(180deg,#D8ECFB 0%,#F4DDF1 60%,#FFE9C8 100%);border:3px solid var(--c-ink);border-radius:18px;box-shadow:var(--shadow-pop-lg);padding:8px;position:relative;overflow:hidden}
.map-card::before{content:"☁️";position:absolute;top:14px;left:24px;font-size:22px;opacity:.5;animation:drift 30s linear infinite}
.map-card::after{content:"☁️";position:absolute;top:32px;right:28px;font-size:18px;opacity:.45;animation:drift 40s linear infinite reverse}
@keyframes drift{0%{transform:translateX(0)}50%{transform:translateX(40px)}100%{transform:translateX(0)}}
#map{width:100%;height:min(640px,72vh);min-height:480px;display:block;background:transparent;border-radius:12px}

/* ===== Zoom & Controls ===== */
.zoom-controls{position:absolute;top:18px;right:18px;display:flex;flex-direction:column;gap:6px;z-index:5}
.zoom-btn{width:36px;height:36px;border-radius:50%;background:var(--c-card);border:2.5px solid var(--c-ink);font-family:'Jua',sans-serif;font-size:20px;cursor:pointer;box-shadow:3px 3px 0 var(--c-ink);color:var(--c-ink);display:flex;align-items:center;justify-content:center;transition:transform .1s}
.zoom-btn:hover{background:var(--c-yellow)}
.zoom-btn:active{transform:translate(2px,2px);box-shadow:1px 1px 0 var(--c-ink)}
.controls-card{margin-top:14px;background:var(--c-card);border:3px solid var(--c-ink);border-radius:14px;padding:14px 16px;box-shadow:var(--shadow-pop);display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.btn{background:var(--c-card);color:var(--c-ink);font-family:'Jua',sans-serif;font-size:14px;padding:8px 16px;border:2.5px solid var(--c-ink);border-radius:10px;cursor:pointer;box-shadow:3px 3px 0 var(--c-ink);transition:transform .08s;text-decoration:none;display:inline-flex;align-items:center;gap:6px}
.btn:hover{background:var(--c-yellow)}
.btn:active{transform:translate(2px,2px);box-shadow:1px 1px 0 var(--c-ink)}
.btn.primary{background:var(--c-purple);color:#fff}
.btn.primary:hover{background:var(--c-purple-dk)}
.btn.active{background:var(--c-pink);color:#fff}
#slider{flex:1;min-width:160px;-webkit-appearance:none;height:8px;background:var(--c-bg-2);border:2px solid var(--c-ink);border-radius:6px;outline:none}
#slider::-webkit-slider-thumb{-webkit-appearance:none;width:20px;height:20px;border-radius:50%;background:var(--c-pink);border:2.5px solid var(--c-ink);cursor:pointer;box-shadow:2px 2px 0 var(--c-ink)}
#slider::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:var(--c-pink);border:2.5px solid var(--c-ink);cursor:pointer}
.date-display{font-family:'Jua',sans-serif;font-size:15px;color:var(--c-purple-dk);min-width:160px;text-align:right}

/* ===== Side Panel / Info Card ===== */
.panel{display:flex;flex-direction:column;gap:14px}
.info-card{background:var(--c-card);border:3px solid var(--c-ink);border-radius:18px;box-shadow:var(--shadow-pop-lg);padding:0;overflow:hidden}
.info-hero{padding:18px 20px 14px;color:#fff;position:relative;overflow:hidden;background:linear-gradient(135deg,var(--c-purple) 0%,var(--c-pink) 100%)}
.info-hero.r-asia{background:linear-gradient(135deg,#FF7AB2 0%,#FFD23F 100%)}
.info-hero.r-na{background:linear-gradient(135deg,#4FB3F0 0%,#7C5CE6 100%)}
.info-hero.r-latam{background:linear-gradient(135deg,#FF6B35 0%,#FFD23F 100%)}
.info-hero.r-eu{background:linear-gradient(135deg,#5FCB7E 0%,#4FB3F0 100%)}
.info-hero.r-oce{background:linear-gradient(135deg,#FF7AB2 0%,#7C5CE6 100%)}
.info-hero::after{content:"";position:absolute;top:-30px;right:-30px;width:120px;height:120px;background:rgba(255,255,255,.18);border-radius:50%}
.info-hero::before{content:"";position:absolute;bottom:-20px;left:-20px;width:80px;height:80px;background:rgba(255,255,255,.12);border-radius:50%}
.region-badge{display:inline-block;font-family:'Jua',sans-serif;font-size:12px;background:rgba(255,255,255,.25);padding:4px 12px;border-radius:12px;margin-bottom:8px;letter-spacing:.5px}
.city-name{font-family:'Jua',sans-serif;font-size:30px;line-height:1.1;margin-bottom:4px;text-shadow:2px 2px 0 rgba(0,0,0,.2);position:relative;z-index:1}
.country-name{font-size:14px;opacity:.95;font-weight:500;position:relative;z-index:1}
.show-pill{display:inline-block;background:#fff;color:var(--c-ink);font-family:'Jua',sans-serif;font-size:13px;padding:5px 12px;border-radius:12px;border:2px solid var(--c-ink);margin-top:10px;box-shadow:2px 2px 0 var(--c-ink);position:relative;z-index:1}
.show-pill.live{background:var(--c-yellow);animation:pop 1s infinite alternate}
@keyframes pop{from{transform:scale(1)}to{transform:scale(1.05)}}
.info-body{padding:18px 20px}
.info-section{margin-bottom:14px;padding-bottom:14px;border-bottom:2px dashed var(--c-line)}
.info-section:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}
.section-label{display:flex;align-items:center;gap:6px;font-family:'Jua',sans-serif;font-size:13px;color:var(--c-purple-dk);margin-bottom:6px;letter-spacing:.3px}
.section-label .ico{width:22px;height:22px;border-radius:6px;background:var(--c-yellow);border:2px solid var(--c-ink);display:flex;align-items:center;justify-content:center;font-size:12px}
.info-text{font-size:13.5px;line-height:1.7;color:var(--c-ink)}
.info-text strong{color:var(--c-purple-dk)}
.facts-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:6px}
.fact{background:var(--c-bg-2);border:2px solid var(--c-line);border-radius:10px;padding:8px 10px}
.fact .k{font-size:11px;color:var(--c-muted);font-weight:600}
.fact .v{font-size:13px;color:var(--c-ink);font-family:'Jua',sans-serif;margin-top:2px}
.fly-card{background:linear-gradient(135deg,#D8ECFB 0%,#FFEFD0 100%);border:3px solid var(--c-ink);border-radius:18px;box-shadow:var(--shadow-pop-lg);padding:20px;text-align:center}
.fly-emoji{font-size:48px;line-height:1;margin-bottom:6px;display:block;animation:fly 2s ease-in-out infinite alternate}
@keyframes fly{from{transform:translateX(-6px) rotate(-3deg)}to{transform:translateX(6px) rotate(3deg)}}
.fly-route{font-family:'Jua',sans-serif;font-size:22px;color:var(--c-purple-dk);margin-bottom:6px}
.fly-meta{font-size:13px;color:var(--c-muted);margin-bottom:14px}
.fly-bar{height:10px;background:#fff;border:2px solid var(--c-ink);border-radius:6px;overflow:hidden;margin-bottom:8px;box-shadow:2px 2px 0 var(--c-ink)}
.fly-fill{height:100%;background:var(--c-pink);transition:width .15s;border-right:2px solid var(--c-ink)}
.fly-pct{font-family:'Jua',sans-serif;color:var(--c-pink-dk);font-size:14px}
.legend{display:flex;gap:14px;font-size:12px;color:var(--c-muted);margin-top:6px;flex-wrap:wrap}
.legend-item{display:flex;align-items:center;gap:5px}
.legend-dot{width:10px;height:10px;border-radius:50%;border:2px solid var(--c-ink)}
.note-bar{background:var(--c-bg-2);border:2px dashed var(--c-line);border-radius:10px;padding:10px 14px;font-size:12px;color:var(--c-muted);text-align:center;margin-top:14px}
footer{margin-top:24px;text-align:center;font-size:12px;color:var(--c-muted);padding:14px}
footer .heart{color:var(--c-pink)}
.loading{padding:40px;text-align:center;color:var(--c-muted);font-family:'Jua',sans-serif}

/* ===== SVG Map Elements ===== */
.country{fill:#FFF8DC;stroke:#A89578;stroke-width:.5}
.country.korea{fill:#FFB8D6;stroke:#B8336A;stroke-width:1.4}
.country.tour-country{fill:#FFEFD0;stroke:#A89578;stroke-width:.7}
.bg-cloud{fill:#fff;opacity:.85;stroke:#D5C9A8;stroke-width:.6}
.deco-star{transform-box:fill-box;transform-origin:center;animation:tw 3s ease-in-out infinite alternate}
@keyframes tw{from{opacity:.4}to{opacity:.85}}
.route{fill:none;stroke:#7C5CE6;stroke-width:1.4;stroke-dasharray:3 5;opacity:.45}
.route.passed{opacity:1;stroke-dasharray:none;stroke-width:2.4;stroke:#3C1F8C}
.cg{cursor:pointer}
.city-marker{stroke-width:2.2;stroke:#2A1B3D}
.city-marker.up{fill:#fff}
.city-marker.passed{fill:#7C5CE6}
.city-marker.current{fill:#FF6B35;stroke-width:3}
.cg:hover .city-marker{stroke-width:3.5}
.cg.cur .city-marker{transform-box:fill-box;transform-origin:center;animation:bn .8s ease-in-out infinite alternate}
@keyframes bn{from{transform:scale(1)}to{transform:scale(1.3)}}
/* Labels live in a top-layer group (#cgLabels) above FX/plane so they're
   never occluded during concerts. State classes (.cur/.act/.hover) are
   mirrored onto each label by tracker.js since the label is no longer
   a descendant of the .cg group. */
.city-label{font-family:'Jua',sans-serif;font-size:11px;fill:var(--c-ink);pointer-events:none;opacity:0;transition:opacity .15s;paint-order:stroke;stroke:#fff;stroke-width:4;stroke-linejoin:round}
.city-label.hover,.city-label.cur,.city-label.act{opacity:1}
.city-label.cur{font-size:13px;fill:#A93A0E;stroke-width:5.5}
.pulse{fill:none;stroke:#FF6B35;stroke-width:3;transform-box:fill-box;transform-origin:center;animation:p 1.6s ease-out infinite;pointer-events:none}
@keyframes p{0%{transform:scale(.4);opacity:.95}100%{transform:scale(4);opacity:0}}
.big-star{transform-box:fill-box;transform-origin:center;animation:rot 9s linear infinite;pointer-events:none}
@keyframes rot{to{transform:rotate(360deg)}}
.mem{transform-box:fill-box;transform-origin:center bottom;pointer-events:none}
.mem.w1{animation:sing1 .42s ease-in-out infinite alternate}
.mem.w2{animation:sing2 .42s ease-in-out infinite alternate}
@keyframes sing1{
  from{transform:translateY(0)      rotate(-7deg)}
  to  {transform:translateY(-2.5px) rotate(7deg)}
}
@keyframes sing2{
  from{transform:translateY(-2.5px) rotate(7deg)}
  to  {transform:translateY(0)      rotate(-7deg)}
}

/* Concert logo above the stage — gentle "singing" pulse + bob.
   When the artist has a `concertLogo` URL set, the logo IS the on-stage
   performer (centered, with a white halo behind, characters hidden).
   Otherwise the 3-orb brand-color fallback (.logo-orb) renders above
   the stage as a small accent. */
.concert-logo-asset{
  transform-box:fill-box;transform-origin:center;
  animation:logoSing 1.4s ease-in-out infinite;
  pointer-events:none;
}
@keyframes logoSing{
  0%,100%{transform:translateY(0)   scale(.96)}
  50%    {transform:translateY(-2px) scale(1.02)}
}

/* White halo behind the on-stage logo — soft glow that breathes with the song. */
.logo-halo-outer,.logo-halo-inner{
  transform-box:fill-box;transform-origin:center;pointer-events:none;
}
.logo-halo-outer{animation:haloOuter 1.8s ease-in-out infinite}
.logo-halo-inner{animation:haloInner 1.8s ease-in-out infinite}
@keyframes haloOuter{
  0%,100%{transform:scale(1);opacity:.45}
  50%    {transform:scale(1.08);opacity:.62}
}
@keyframes haloInner{
  0%,100%{transform:scale(1);opacity:.92}
  50%    {transform:scale(1.04);opacity:1}
}
.logo-orb{
  transform-box:fill-box;transform-origin:center;
  animation:orbBob .65s ease-in-out infinite alternate;
}
@keyframes orbBob{
  from{transform:translateY(0)    scale(.95)}
  to  {transform:translateY(-2px) scale(1.06)}
}

/* Floating music notes from the stage (during a concert) */
.note{
  font-family:'Jua',sans-serif;
  pointer-events:none;
  transform-box:fill-box;transform-origin:center;
  animation:noteFloat 2.4s ease-out infinite;
  opacity:0;
}
@keyframes noteFloat{
  0%   {opacity:0;   transform:translateY(0)     scale(.55) rotate(-8deg)}
  18%  {opacity:.95}
  60%  {opacity:.85; transform:translateY(-22px) scale(1.05) rotate(8deg)}
  100% {opacity:0;   transform:translateY(-36px) scale(1.15) rotate(-4deg)}
}
.conf{transform-box:fill-box;transform-origin:center;pointer-events:none;animation:fall 2s ease-out infinite}
@keyframes fall{0%{transform:translate(0,0) rotate(0);opacity:1}100%{transform:translate(var(--cx),32px) rotate(540deg);opacity:0}}
.trailpuff{transform-box:fill-box;transform-origin:center;animation:puff 1.2s ease-out infinite;pointer-events:none}
@keyframes puff{0%{opacity:.9;transform:scale(.6)}100%{opacity:0;transform:scale(1.8)}}
.bird{transform-box:fill-box;transform-origin:center;animation:flap .55s ease-in-out infinite alternate}
@keyframes flap{from{transform:scaleY(1)}to{transform:scaleY(.5)}}

/* ===== Artist Picker (index.html) ===== */
.picker-hero{text-align:center;padding:30px 0 24px}
.picker-title{font-family:'Jua',sans-serif;font-size:clamp(28px,5vw,44px);color:var(--c-purple-dk);text-shadow:3px 3px 0 var(--c-yellow);line-height:1.15;margin-bottom:10px}
.picker-sub{font-size:15px;color:var(--c-muted);max-width:600px;margin:0 auto;line-height:1.6}
.picker-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;margin-top:16px}
.artist-card{background:var(--c-card);border:3px solid var(--c-ink);border-radius:18px;padding:20px;box-shadow:var(--shadow-pop-lg);cursor:pointer;transition:transform .15s;position:relative;overflow:hidden;text-decoration:none;color:inherit;display:block}
.artist-card:hover{transform:translate(-2px,-3px);box-shadow:8px 8px 0 var(--c-ink)}
.artist-card.upcoming{opacity:.6;cursor:not-allowed}
.artist-card.upcoming:hover{transform:none;box-shadow:var(--shadow-pop-lg)}
.artist-card-emoji{font-size:48px;display:block;margin-bottom:10px;line-height:1}
.artist-card-name{font-family:'Jua',sans-serif;font-size:24px;color:var(--c-ink);margin-bottom:2px}
.artist-card-name-ko{font-size:13px;color:var(--c-muted);margin-bottom:10px}
.artist-card-tour{font-family:'Jua',sans-serif;font-size:15px;margin-bottom:4px}
.artist-card-period{font-size:12px;color:var(--c-muted);margin-bottom:14px}
.artist-card-stats{display:flex;gap:12px;font-size:11px;color:var(--c-muted)}
.artist-card-stats strong{color:var(--c-purple-dk);font-family:'Jua',sans-serif;font-size:14px}
.status-tag{position:absolute;top:14px;right:14px;font-family:'Jua',sans-serif;font-size:11px;padding:3px 10px;border-radius:10px;border:2px solid var(--c-ink)}
.status-tag.live{background:var(--c-pink);color:#fff;animation:pop 1s infinite alternate}
.status-tag.upcoming{background:var(--c-bg-2);color:var(--c-muted)}
.empty-card{background:transparent;border:3px dashed var(--c-line);border-radius:18px;padding:30px 20px;text-align:center;color:var(--c-muted);font-size:13px;line-height:1.6}
.empty-card .em{font-size:32px;display:block;margin-bottom:8px;opacity:.5}
