/* =========================================================
   VIRTUAL FRENZY 推し祭 — 2026 台北漫博
   Japanese Summer Festival (夏日祭典) theme
   ========================================================= */
:root{
  --red:#e0392b; --red-deep:#b21f17; --gold:#f4c430; --gold-soft:#ffe08a;
  --ink:#241015; --ink-2:#3a1822; --cream:#fff6e6; --navy:#1a1030;
  --teal:#2fb3a8; --pink:#ff7a9c; --paper:#fbf2e2;
  --shadow:0 18px 50px rgba(60,8,20,.35); --radius:20px; --maxw:1180px;
  --font:"Noto Sans TC","PingFang TC","Microsoft JhengHei",sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;overflow-x:hidden}
html,body{max-width:100%}
body{font-family:var(--font);color:var(--cream);background:var(--ink);line-height:1.65;overflow-x:hidden;position:relative;width:100%;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.bg-festival{position:fixed;inset:0;z-index:-3;
  background:
    radial-gradient(1100px 600px at 15% -10%, rgba(244,196,48,.18), rgba(244,196,48,0) 66%),
    radial-gradient(900px 700px at 95% 10%, rgba(224,57,43,.30), rgba(224,57,43,0) 66%),
    radial-gradient(1200px 900px at 50% 120%, rgba(47,179,168,.18), rgba(47,179,168,0) 66%),
    linear-gradient(180deg,#2a0f1a 0%, #200a16 40%, #160712 100%)}
.bg-festival::after{content:"";position:absolute;inset:0;opacity:.06;
  background-image:radial-gradient(circle, #fff 1px, transparent 1.4px);background-size:26px 26px}
.lanterns{position:fixed;inset:0;z-index:-2;overflow:hidden;pointer-events:none}
.lantern{position:absolute;width:34px;height:46px;border-radius:50% 50% 46% 46%/60% 60% 40% 40%;
  background:linear-gradient(180deg,#ff6b5e,#d8261a);
  box-shadow:0 0 24px rgba(255,120,90,.55), inset 0 -8px 10px rgba(120,0,0,.4);
  opacity:.55;animation:floaty linear infinite}
.lantern::before{content:"";position:absolute;left:50%;top:-7px;width:2px;height:9px;background:var(--gold);transform:translateX(-50%)}
.lantern::after{content:"";position:absolute;left:50%;bottom:-6px;width:8px;height:8px;background:var(--gold);border-radius:2px;transform:translateX(-50%)}
@keyframes floaty{0%{transform:translateY(20px) rotate(-3deg)}50%{transform:translateY(-18px) rotate(3deg)}100%{transform:translateY(20px) rotate(-3deg)}}
header.nav{position:sticky;top:0;z-index:50;backdrop-filter:blur(12px);background:rgba(28,8,16,.72);border-bottom:1px solid rgba(244,196,48,.25)}
.nav-inner{max-width:var(--maxw);margin:0 auto;display:flex;align-items:center;justify-content:space-between;padding:12px 22px;gap:16px}
.brand-logo{display:flex;align-items:center;gap:12px;font-weight:900;letter-spacing:.5px}
.brand-logo .vf{font-size:18px;color:var(--gold);text-shadow:0 1px 0 var(--red-deep);line-height:1.05}
.brand-logo .vf small{display:block;font-size:11px;color:var(--cream);font-weight:600;letter-spacing:3px;margin-top:3px}
.nav-links{display:flex;gap:6px;align-items:center}
.nav-links a{padding:8px 14px;border-radius:999px;font-weight:700;font-size:14.5px;color:var(--cream);transition:.2s}
.nav-links a:hover{background:rgba(244,196,48,.18);color:var(--gold-soft)}
.nav-links a.cta{background:var(--gold);color:#5a2a00;box-shadow:0 6px 16px rgba(244,196,48,.4)}
.nav-links a.cta:hover{background:#ffd34d;color:#5a2a00}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;width:30px;height:24px;position:relative;padding:0}
.nav-toggle .bar{position:absolute;left:0;right:0;height:3px;border-radius:3px;background:var(--gold);transition:transform .35s cubic-bezier(.16,1,.3,1),opacity .25s ease,background .2s ease}
.nav-toggle .bar:nth-child(1){top:2px}
.nav-toggle .bar:nth-child(2){top:50%;transform:translateY(-50%)}
.nav-toggle .bar:nth-child(3){bottom:2px}
.hero{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;text-align:center;padding:100px 20px 150px;overflow:hidden}
.hero-kv{position:absolute;inset:0;z-index:-1}
.hero-kv img{width:100%;height:100%;object-fit:cover;opacity:.34;filter:saturate(1.1)}
.hero-kv::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(22,7,18,.55),rgba(22,7,18,.30) 40%,rgba(22,7,18,.92))}
.hero-content{max-width:860px;position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;gap:6px}
.hero .season-badge{display:inline-flex;align-items:center;gap:8px;background:linear-gradient(90deg,var(--red),var(--red-deep));color:#fff;font-weight:800;letter-spacing:4px;font-size:13px;padding:8px 22px;border-radius:999px;border:1px solid rgba(255,224,138,.6);box-shadow:var(--shadow);margin-bottom:4px}
.hero h1{font-size:clamp(40px,8vw,86px);font-weight:900;line-height:1.02;letter-spacing:2px;color:#fff;text-shadow:0 2px 0 var(--red-deep),0 6px 28px rgba(224,57,43,.55);margin-bottom:6px}
.hero h1 .frenzy{color:var(--gold);text-shadow:0 2px 0 #8a5a00,0 8px 30px rgba(244,196,48,.5)}
.hero .subtitle{font-size:clamp(22px,4.4vw,40px);font-weight:900;color:var(--gold-soft);letter-spacing:8px;margin:8px 0 26px;text-shadow:0 3px 16px rgba(0,0,0,.5)}
.hero .subtitle::before,.hero .subtitle::after{content:"\2749";color:var(--red);margin:0 14px;font-size:.7em;vertical-align:middle}
.hero-meta{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;margin-bottom:30px}
.hero-meta .chip{background:rgba(255,246,230,.10);border:1px solid rgba(244,196,48,.4);border-radius:14px;padding:12px 20px;font-weight:700;font-size:15.5px;display:flex;align-items:center;gap:9px;backdrop-filter:blur(4px)}
.hero-meta .chip i{font-style:normal;font-size:19px}
.hero-cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:6px}
.hero-cta .btn{min-height:50px;padding:0 24px;gap:10px;font-size:15px;font-weight:900;letter-spacing:.8px;border:1px solid transparent;box-shadow:none}
.hero-cta .btn svg{width:18px;height:18px;stroke-width:2.25;flex-shrink:0}
.hero-cta .btn-primary{background:linear-gradient(180deg,#ffe08a,#f4c430);color:#3b2100;box-shadow:0 10px 24px rgba(244,196,48,.25), inset 0 1px 0 rgba(255,255,255,.42)}
.hero-cta .btn-primary:hover{background:linear-gradient(180deg,#ffe8a4,#ffd34d);box-shadow:0 14px 28px rgba(244,196,48,.30), inset 0 1px 0 rgba(255,255,255,.5)}
.hero-cta .btn-ghost{background:rgba(255,246,230,.06);color:var(--cream);border-color:rgba(255,224,138,.44);box-shadow:inset 0 1px 0 rgba(255,255,255,.08)}
.hero-cta .btn-ghost:hover{background:rgba(255,224,138,.14);border-color:rgba(255,224,138,.72);box-shadow:0 12px 24px rgba(0,0,0,.16), inset 0 1px 0 rgba(255,255,255,.10)}
.btn{display:inline-flex;align-items:center;gap:9px;font-weight:800;font-size:16px;padding:14px 30px;border-radius:999px;transition:.22s;cursor:pointer;border:0}
/* 通用按鈕內 SVG 圖示尺寸（對齊 hero 按鈕） */
.btn svg{width:18px;height:18px;stroke-width:2.25;flex-shrink:0}
/* 打靶區「看活動預告」對齊 hero 主按鈕設計 */
.shooting-text .btn{min-height:50px;padding:0 26px;gap:10px;font-size:15px;font-weight:900;letter-spacing:.8px;border:1px solid transparent;box-shadow:0 10px 26px rgba(244,196,48,.45)}
.shooting-text .btn svg{width:18px;height:18px;stroke-width:2.25}
.btn-primary{background:var(--gold);color:#5a2a00;box-shadow:0 10px 26px rgba(244,196,48,.45)}
.btn-primary:hover{transform:translateY(-2px);background:#ffd750}
.btn-ghost{background:rgba(255,255,255,.08);color:var(--cream);border:1.5px solid rgba(244,196,48,.55)}
.btn-ghost:hover{background:rgba(244,196,48,.18);transform:translateY(-2px)}
section{padding:80px 20px;position:relative;overflow-x:clip}
.wrap{max-width:var(--maxw);margin:0 auto}
.sec-head{text-align:center;margin-bottom:46px}
.sec-head .kicker{display:inline-block;color:var(--gold);font-weight:800;letter-spacing:5px;font-size:13px;margin-bottom:10px;text-transform:uppercase}
.sec-head h2{font-size:clamp(28px,5vw,46px);font-weight:900;color:#fff;letter-spacing:2px;text-shadow:0 3px 18px rgba(224,57,43,.4)}
.sec-head h2 .mark{color:var(--gold)}
.sec-head p{color:rgba(255,246,230,.78);margin-top:12px;font-size:16px;max-width:660px;margin-left:auto;margin-right:auto}
.sec-divider{height:8px;background:repeating-linear-gradient(90deg,var(--red) 0 26px,var(--gold) 26px 52px);opacity:.85}
.booth-grid{display:grid;grid-template-columns:1fr 1fr;gap:26px}
.booth-card{position:relative;border-radius:var(--radius);overflow:hidden;border:1px solid rgba(244,196,48,.3);background:linear-gradient(165deg,rgba(224,57,43,.16),rgba(36,16,21,.6));padding:34px 30px;transition:.25s}
.booth-card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--gold)}
.booth-card .tag{display:inline-block;background:var(--gold);color:#5a2a00;font-weight:900;font-size:13px;letter-spacing:2px;padding:6px 16px;border-radius:999px;margin-bottom:16px}
.booth-card.game .tag{background:var(--teal);color:#04332f}
.booth-card h3{font-size:24px;font-weight:900;color:#fff;margin-bottom:6px}
.booth-card .sub{color:rgba(255,246,230,.72);font-size:14.5px;margin-bottom:18px}
.booth-card .members{display:flex;flex-wrap:wrap;gap:8px}
.booth-card .members span{background:rgba(255,246,230,.1);border:1px solid rgba(244,196,48,.3);padding:6px 13px;border-radius:999px;font-size:13.5px;font-weight:700}
.booth-card.game .members span{border-color:rgba(47,179,168,.4)}
.shooting{position:relative}
.shooting-inner{display:grid;grid-template-columns:1.05fr .95fr;gap:40px;align-items:center}
.shooting-text .game-title{font-size:clamp(30px,5vw,50px);font-weight:900;color:#fff;line-height:1.1;text-shadow:0 3px 0 var(--red-deep),0 8px 26px rgba(224,57,43,.5);margin-bottom:8px}
.shooting-text .game-title .t{color:var(--gold)}
.shooting-text .lead{color:rgba(255,246,230,.85);font-size:17px;margin:14px 0 24px}
.shooting-visual{position:relative;border-radius:var(--radius);overflow:hidden;border:2px solid rgba(244,196,48,.4);box-shadow:var(--shadow)}
.shooting-visual img{width:100%;height:100%;object-fit:cover}
.target{position:absolute;width:120px;height:120px;border-radius:50%;background:repeating-radial-gradient(circle,#fff 0 12px,var(--red) 12px 24px);opacity:.16;animation:spin 24s linear infinite}
.target.t1{top:-30px;right:-30px}
.target.t2{bottom:-40px;left:-30px;width:90px;height:90px}
@keyframes spin{to{transform:rotate(360deg)}}
.trailer-grid{display:grid;grid-template-columns:1fr 1fr;gap:28px}
.trailer{background:rgba(255,246,230,.05);border:1px solid rgba(244,196,48,.28);border-radius:var(--radius);overflow:hidden;transition:.25s}
.trailer:hover{border-color:var(--gold);box-shadow:var(--shadow)}
.trailer .vid{position:relative;aspect-ratio:16/9;background:#0c0510}
.trailer .vid iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.trailer .cap{padding:18px 22px}
.trailer .cap .t{font-weight:900;font-size:19px;color:#fff;margin-bottom:4px}
.trailer .cap .d{color:rgba(255,246,230,.7);font-size:14px}
.trailer .cap .badge{display:inline-block;background:var(--red);color:#fff;font-size:12px;font-weight:800;padding:3px 11px;border-radius:999px;margin-bottom:8px;letter-spacing:1px}
.promo{background:linear-gradient(165deg,rgba(224,57,43,.14),rgba(26,16,48,.4))}
.promo-inner{display:grid;grid-template-columns:.95fr 1.05fr;gap:38px;align-items:center}
.promo-visual{border-radius:var(--radius);overflow:hidden;border:2px solid rgba(244,196,48,.4);box-shadow:var(--shadow)}
.promo-text h3{font-size:clamp(26px,4.5vw,40px);font-weight:900;color:#fff;margin-bottom:8px;text-shadow:0 3px 16px rgba(224,57,43,.4)}
.promo-text h3 .k{color:var(--gold)}
.promo-text .note{display:inline-block;background:rgba(244,196,48,.18);border:1px solid rgba(244,196,48,.4);color:var(--gold-soft);font-weight:700;font-size:13px;padding:5px 14px;border-radius:999px;margin-bottom:16px}
.promo-text p{color:rgba(255,246,230,.82);font-size:16px;margin-bottom:20px}
.king-list{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.king-item{display:flex;align-items:center;gap:12px;background:rgba(255,246,230,.06);border:1px solid rgba(244,196,48,.22);border-radius:12px;padding:10px 14px}
.king-item .date{background:var(--red);color:#fff;font-weight:900;font-size:12px;border-radius:8px;padding:5px 9px;text-align:center;min-width:52px;line-height:1.15}
.king-item .who{font-size:14px;font-weight:700}
.king-item .who small{display:block;color:rgba(255,246,230,.65);font-weight:600;font-size:12px}
.logo-wall{display:grid;gap:16px}
.brand-wall{grid-template-columns:repeat(6,minmax(0,1fr))}
.sponsor-wall{grid-template-columns:repeat(6,minmax(0,1fr))}
.logo-cell{display:flex;align-items:center;justify-content:center;aspect-ratio:3/2;padding:18px;border-radius:16px;transition:.22s;min-width:0;overflow:hidden}
.brand-cell{background:#fff;border:1px solid rgba(244,196,48,.45)}
.sponsor-cell{background:rgba(20,10,18,.55);border:1px solid rgba(255,246,230,.14)}
.logo-cell:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.logo-cell img{max-height:100%;max-width:100%;width:auto;height:auto;object-fit:contain;display:block}
.thanks-note{text-align:center;color:rgba(255,246,230,.6);font-size:14px;margin-top:18px;letter-spacing:1px}
footer{background:rgba(12,5,12,.9);border-top:2px solid var(--red);padding:50px 20px 36px;text-align:center}
footer .f-brand{font-size:22px;font-weight:900;color:var(--gold);margin-bottom:8px}
footer .f-brand small{display:block;font-size:12px;letter-spacing:4px;color:var(--cream);font-weight:600}
footer .f-info{color:rgba(255,246,230,.7);font-size:14px;margin:14px 0;line-height:1.9}
footer .f-links{display:flex;gap:18px;justify-content:center;margin:18px 0;flex-wrap:wrap}
footer .f-links a{color:var(--gold-soft);font-weight:700;font-size:14px}
footer .f-links a:hover{color:#fff}
footer .copy{color:rgba(255,246,230,.45);font-size:12.5px;margin-top:18px}
.reveal{opacity:0;transform:translateY(28px);transition:.7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
@media(max-width:980px){
  .booth-grid{grid-template-columns:1fr}
  .shooting-inner,.promo-inner{grid-template-columns:1fr;gap:28px}
  .trailer-grid{grid-template-columns:1fr}
  .brand-wall{grid-template-columns:repeat(4,minmax(0,1fr))}
  .sponsor-wall{grid-template-columns:repeat(4,minmax(0,1fr))}
}
@media(max-width:640px){
  section{padding:56px 16px}
  .nav-links{position:absolute;top:100%;left:0;right:0;display:flex;flex-direction:column;gap:6px;
    background:rgba(28,8,16,.97);padding:0 14px;border-bottom:1px solid rgba(244,196,48,0);
    max-height:0;opacity:0;overflow:hidden;pointer-events:none;
    transform:translateY(-8px);
    transition:max-height .42s cubic-bezier(.16,1,.3,1),opacity .3s ease,transform .42s cubic-bezier(.16,1,.3,1),padding .42s ease,border-color .3s ease}
  .nav-links.open{max-height:420px;opacity:1;pointer-events:auto;transform:translateY(0);
    padding:14px;border-bottom-color:rgba(244,196,48,.3)}
  .nav-links a{width:100%;opacity:0;transform:translateY(-6px);
    transition:opacity .3s ease,transform .3s ease,background .2s ease,color .2s ease}
  .nav-links.open a{opacity:1;transform:translateY(0)}
  .nav-links.open a:nth-child(1){transition-delay:.06s}
  .nav-links.open a:nth-child(2){transition-delay:.10s}
  .nav-links.open a:nth-child(3){transition-delay:.14s}
  .nav-links.open a:nth-child(4){transition-delay:.18s}
  .nav-links.open a:nth-child(5){transition-delay:.22s}
  .nav-links.open a:nth-child(6){transition-delay:.26s}
  .nav-links.open a:nth-child(7){transition-delay:.30s}
  .nav-toggle{display:block}
  .nav-toggle.open .bar{background:var(--gold-soft)}
  .nav-toggle.open .bar:nth-child(1){top:50%;transform:translateY(-50%) rotate(45deg)}
  .nav-toggle.open .bar:nth-child(2){opacity:0;transform:translateY(-50%) scaleX(.4)}
  .nav-toggle.open .bar:nth-child(3){bottom:auto;top:50%;transform:translateY(-50%) rotate(-45deg)}
  .king-list{grid-template-columns:1fr}
  .brand-wall{grid-template-columns:repeat(3,minmax(0,1fr))}
  .sponsor-wall{grid-template-columns:repeat(3,minmax(0,1fr))}
  .hero .subtitle{letter-spacing:4px}
}

/* ===================== LIVE SCHEDULE PAGE ===================== */
.live-hero{padding:120px 20px 50px;text-align:center;position:relative}
.live-hero .season-badge{display:inline-flex;align-items:center;gap:8px;background:linear-gradient(90deg,var(--red),var(--red-deep));color:#fff;font-weight:800;letter-spacing:4px;font-size:13px;padding:8px 22px;border-radius:999px;border:1px solid rgba(255,224,138,.6);box-shadow:var(--shadow);margin-bottom:18px}
.live-hero h1{font-size:clamp(34px,7vw,68px);font-weight:900;color:#fff;letter-spacing:3px;text-shadow:0 2px 0 var(--red-deep),0 8px 30px rgba(224,57,43,.5)}
.live-hero h1 .mark{color:var(--gold)}
.live-hero p{color:rgba(255,246,230,.8);margin-top:14px;font-size:16px}
.live-note{margin-top:14px;display:inline-block;background:rgba(255,246,230,.08);border:1px solid rgba(244,196,48,.35);border-radius:12px;padding:9px 18px;font-size:14px;color:var(--gold-soft);font-weight:700}

/* day tabs */
.day-tabs{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin:36px auto 32px;max-width:760px}
.day-tab{cursor:pointer;border:1px solid rgba(244,196,48,.35);background:rgba(255,246,230,.05);color:var(--cream);
  border-radius:14px;padding:12px 20px;font-weight:800;font-size:15px;text-align:center;transition:.2s;min-width:104px}
.day-tab small{display:block;font-size:12px;font-weight:600;color:rgba(255,246,230,.65);margin-top:2px}
.day-tab:hover{border-color:var(--gold);background:rgba(244,196,48,.12)}
.day-tab.active{background:linear-gradient(90deg,var(--red),var(--red-deep));border-color:var(--gold);color:#fff;box-shadow:var(--shadow)}
.day-tab.active small{color:rgba(255,255,255,.85)}

/* schedule grid */
.sched-wrap{max-width:920px;margin:0 auto}
.sched-day{display:none}
.sched-day.active{display:block;animation:fadein .4s}
@keyframes fadein{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
.sched-list{display:flex;flex-direction:column;gap:12px}
.sched-row{display:grid;grid-template-columns:130px 1fr;gap:18px;align-items:center;
  background:linear-gradient(120deg,rgba(255,246,230,.07),rgba(255,246,230,.02));
  border:1px solid rgba(244,196,48,.25);border-radius:16px;padding:18px 22px;transition:.2s}
.sched-row:hover{border-color:var(--gold);transform:translateX(4px)}
.sched-row .time{font-weight:900;font-size:20px;color:var(--gold);display:flex;flex-direction:column;line-height:1.1}
.sched-row .time small{font-size:12px;color:rgba(255,246,230,.6);font-weight:600;margin-top:3px}
.sched-row .who{display:flex;align-items:center;gap:14px}
.sched-row .who .avatar{width:46px;height:46px;border-radius:50%;background:linear-gradient(135deg,var(--red),var(--gold));
  display:flex;align-items:center;justify-content:center;font-weight:900;font-size:18px;color:#fff;flex-shrink:0;box-shadow:0 4px 12px rgba(224,57,43,.35)}
.sched-row .who .meta .name{font-size:19px;font-weight:900;color:#fff}
.sched-row .who .meta .guild{font-size:13.5px;color:var(--gold-soft);font-weight:700}
.sched-row.empty{opacity:.5;background:rgba(255,246,230,.03);border-style:dashed}
.sched-row.empty .who .meta .name{color:rgba(255,246,230,.6);font-weight:700;font-size:16px}
.sched-row.closed{opacity:.6}
.sched-row.closed .avatar{background:#555}
.sched-row.special .avatar{background:linear-gradient(135deg,var(--teal),#1f7d76)}
.test-note{text-align:center;color:rgba(255,246,230,.55);font-size:13.5px;margin-top:26px}

@media(max-width:640px){
  .sched-row{grid-template-columns:88px 1fr;gap:12px;padding:14px 16px}
  .sched-row .time{font-size:17px}
  .sched-row .who .avatar{width:40px;height:40px;font-size:16px}
  .sched-row .who .meta .name{font-size:16px}
  .day-tab{min-width:88px;padding:10px 14px;font-size:14px}
}

/* ===================== 夏日祭打靶 動態場景 ===================== */
.shooting-visual.stage{border:2px solid rgba(244,196,48,.45);background:#160712;aspect-ratio:4/3;min-height:340px}
.festival-scene{position:absolute;inset:0;overflow:hidden}
.fs-sky{position:absolute;inset:0;background:
  radial-gradient(120% 80% at 50% 120%, rgba(224,57,43,.55), rgba(224,57,43,0) 68%),
  linear-gradient(180deg,#1a0a2e 0%, #2a0f2a 55%, #3a1320 100%)}
.fs-sky::after{content:"";position:absolute;inset:0;opacity:.5;
  background-image:radial-gradient(circle,#fff 1px,transparent 1.5px);background-size:34px 34px;
  -webkit-mask-image:linear-gradient(180deg,#000 0%,transparent 60%);mask-image:linear-gradient(180deg,#000 0%,transparent 60%)}
.fs-fireworks{position:absolute;inset:0}
.fw{position:absolute;width:0;height:0}
.fw span{position:absolute;left:0;top:0;width:6px;height:6px;border-radius:50%;
  animation:fwpop 1s ease-out forwards;box-shadow:0 0 8px currentColor}
@keyframes fwpop{0%{transform:translate(0,0) scale(.3);opacity:1}80%{opacity:.9}
  100%{transform:translate(var(--tx),var(--ty)) scale(1);opacity:0}}
.fs-target{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:150px;height:150px;
  filter:drop-shadow(0 8px 20px rgba(224,57,43,.5))}
.fs-target .ring{position:absolute;border-radius:50%;left:50%;top:50%;transform:translate(-50%,-50%)}
.fs-target .r5{width:150px;height:150px;background:#fff}
.fs-target .r4{width:120px;height:120px;background:var(--red)}
.fs-target .r3{width:90px;height:90px;background:#fff}
.fs-target .r2{width:60px;height:60px;background:var(--red)}
.fs-target .r1{width:32px;height:32px;background:#fff}
.fs-target .bullseye{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:14px;height:14px;border-radius:50%;background:var(--red-deep)}
.fs-target .hit{position:absolute;left:50%;top:50%;width:18px;height:18px;border-radius:50%;
  background:radial-gradient(circle,#fff,#ffd34d 60%,transparent);opacity:0;transform:translate(-50%,-50%) scale(.4);
  transition:.2s;box-shadow:0 0 14px #ffd34d}
.fs-flags{position:absolute;top:14px;left:0;right:0;height:26px;display:flex}
.fs-flags span{flex:1;height:18px;clip-path:polygon(0 0,100% 0,100% 60%,50% 100%,0 60%);
  animation:flagwave 2.4s ease-in-out infinite}
.fs-flags span:nth-child(odd){background:var(--red)}
.fs-flags span:nth-child(even){background:var(--gold)}
.fs-flags span:nth-child(2){animation-delay:.2s}.fs-flags span:nth-child(3){animation-delay:.4s}
.fs-flags span:nth-child(4){animation-delay:.6s}.fs-flags span:nth-child(5){animation-delay:.8s}
.fs-flags span:nth-child(6){animation-delay:1s}.fs-flags span:nth-child(7){animation-delay:1.2s}
.fs-flags span:nth-child(8){animation-delay:1.4s}
@keyframes flagwave{0%,100%{transform:translateY(0)}50%{transform:translateY(4px)}}
.fs-stalls{position:absolute;bottom:0;left:0;right:0;height:54px;display:flex;gap:6px;padding:0 10px}
.fs-stalls span{flex:1;height:46px;align-self:flex-end;border-radius:6px 6px 0 0;
  background:repeating-linear-gradient(90deg,var(--red) 0 14px,#fff 14px 28px);opacity:.85;
  border-top:4px solid var(--gold)}
.fs-stalls span:nth-child(2){height:38px}.fs-stalls span:nth-child(3){height:50px}
.fs-label{position:absolute;bottom:62px;left:0;right:0;text-align:center;font-weight:900;font-size:22px;color:#fff;
  text-shadow:0 2px 0 var(--red-deep),0 6px 18px rgba(0,0,0,.6);letter-spacing:2px}
.fs-label small{display:block;font-size:11px;letter-spacing:3px;color:var(--gold-soft);font-weight:700;margin-top:4px}

/* ===================== COVER 打上花火 ===================== */
.song{background:linear-gradient(180deg,rgba(26,16,48,.45),rgba(36,16,21,.2))}
.song-inner{display:grid;grid-template-columns:1.15fr .85fr;gap:34px;align-items:start}
.song-video{position:relative;border-radius:var(--radius);overflow:visible}
.song-video .vid{position:relative;aspect-ratio:16/9;border-radius:var(--radius);overflow:hidden;
  border:2px solid rgba(244,196,48,.4);box-shadow:var(--shadow);background:#0c0510}
.song-video .vid iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.song-firework{position:absolute;width:60px;height:60px;border-radius:50%;pointer-events:none;
  background:radial-gradient(circle,rgba(255,211,77,.5),transparent 70%);animation:pulse 3s ease-in-out infinite}
.song-firework.f1{top:-24px;right:-18px}
.song-firework.f2{bottom:-20px;left:-20px;width:46px;height:46px;animation-delay:1.4s;
  background:radial-gradient(circle,rgba(255,122,156,.5),transparent 70%)}
@keyframes pulse{0%,100%{transform:scale(.8);opacity:.5}50%{transform:scale(1.2);opacity:1}}
.song-credit{background:linear-gradient(160deg,rgba(255,246,230,.07),rgba(255,246,230,.02));
  border:1px solid rgba(244,196,48,.3);border-radius:var(--radius);padding:26px 26px}
.song-title-card{display:flex;flex-direction:column;align-items:center;text-align:center;
  padding-bottom:18px;margin-bottom:16px;border-bottom:1px dashed rgba(244,196,48,.4)}
.song-title-card .song-jp{font-size:34px;font-weight:900;color:#fff;letter-spacing:4px;
  text-shadow:0 2px 0 var(--red-deep),0 6px 18px rgba(224,57,43,.4)}
.song-title-card .song-en{font-size:13px;letter-spacing:3px;color:var(--gold-soft);font-weight:700;margin-top:6px}
.credit-list{list-style:none;display:flex;flex-direction:column;gap:11px}
.credit-list li{display:grid;grid-template-columns:118px 1fr;gap:14px;align-items:start;font-size:14px;line-height:1.6}
.credit-list .role{color:var(--gold);font-weight:800;font-size:12.5px;letter-spacing:.5px;white-space:nowrap;
  text-align:right;padding-top:1px;position:relative}
.credit-list .role::before{content:"▸ ";color:var(--red)}
.credit-list .val{color:rgba(255,246,230,.9);font-weight:600}
.credit-list .val a{color:var(--gold-soft);font-weight:700;border-bottom:1px solid rgba(244,196,48,.4)}
.credit-list .val a:hover{color:#fff}
.presented-by{margin-top:20px;padding-top:16px;border-top:1px dashed rgba(244,196,48,.4);
  text-align:center;font-size:14px;font-weight:800;color:var(--gold-soft);letter-spacing:1px}

/* ===================== 參展成員立繪牆 ===================== */
/* 主視覺輪播 */
.char-showcase{position:relative;display:flex;align-items:center;gap:10px;margin-top:8px}
.cs-stage{flex:1;display:grid;grid-template-columns:1fr 1fr;align-items:center;gap:30px;min-height:420px;
  background:linear-gradient(150deg,rgba(224,57,43,.14),rgba(26,12,30,.4));
  border:1px solid rgba(244,196,48,.3);border-radius:24px;padding:24px 34px;overflow:hidden;position:relative}
.cs-stage::before{content:"";position:absolute;left:-10%;top:-20%;width:55%;height:140%;border-radius:50%;
  background:radial-gradient(circle,rgba(244,196,48,.18),rgba(244,196,48,0) 70%);filter:blur(30px);pointer-events:none}
.cs-figure{position:relative;height:380px;display:flex;align-items:flex-end;justify-content:center;cursor:zoom-in}
.cs-figure img{max-height:380px;width:auto;object-fit:contain;object-position:bottom;
  filter:drop-shadow(0 14px 30px rgba(0,0,0,.55));transition:.4s;opacity:0;transform:translateY(14px) scale(.97);
  animation:figfloat 6s ease-in-out infinite}
.cs-figure.in img{opacity:1;transform:translateY(0) scale(1)}
.cs-figure:hover img{filter:drop-shadow(0 14px 30px rgba(0,0,0,.55)) drop-shadow(0 0 26px rgba(244,196,48,.3))}
@keyframes figfloat{0%,100%{margin-bottom:0}50%{margin-bottom:10px}}
.cs-info{position:relative}
.cs-guild{display:inline-block;color:var(--gold-soft);font-weight:800;font-size:14px;letter-spacing:1px;
  background:rgba(244,196,48,.14);border:1px solid rgba(244,196,48,.4);border-radius:999px;padding:6px 16px;margin-bottom:16px}
.cs-name{font-size:clamp(34px,5vw,52px);font-weight:900;color:#fff;line-height:1.08;
  text-shadow:0 3px 0 var(--red-deep),0 8px 24px rgba(224,57,43,.4)}
.cs-zoom{display:inline-flex;align-items:center;gap:8px;margin-top:22px;background:var(--gold);color:#5a2a00;font-weight:800;font-size:14px;
  border:0;border-radius:999px;padding:11px 22px;cursor:pointer;transition:.2s;box-shadow:0 8px 20px rgba(244,196,48,.4)}
.cs-zoom svg{width:17px;height:17px}
.cs-zoom:hover{transform:translateY(-2px);background:#ffd750}
.cs-nav{flex-shrink:0;width:48px;height:48px;border-radius:50%;background:rgba(255,246,230,.08);
  border:1px solid rgba(244,196,48,.4);color:var(--gold-soft);font-size:19px;cursor:pointer;transition:.2s}
.cs-nav:hover{background:var(--gold);color:#5a2a00;transform:scale(1.08)}
/* 縮圖列 */
.cs-thumbs{display:flex;gap:10px;overflow-x:auto;padding:18px 4px 6px;scroll-behavior:smooth;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 3%,#000 97%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 3%,#000 97%,transparent)}
.cs-thumbs::-webkit-scrollbar{height:6px}
.cs-thumbs::-webkit-scrollbar-thumb{background:rgba(244,196,48,.4);border-radius:3px}
.cs-thumb{flex-shrink:0;width:84px;height:104px;border-radius:12px;overflow:hidden;cursor:pointer;padding:0;
  background:linear-gradient(180deg,rgba(224,57,43,.16),rgba(26,12,30,.6));
  border:2px solid rgba(244,196,48,.22);transition:.22s;opacity:.7}
.cs-thumb img{width:100%;height:100%;object-fit:cover;object-position:top}
.cs-thumb:hover{opacity:1;transform:translateY(-4px)}
.cs-thumb.active{opacity:1;border-color:var(--gold);box-shadow:0 6px 16px rgba(244,196,48,.35)}
/* ===== 立繪燈箱 ===== */
.char-lightbox{position:fixed;inset:0;z-index:1000;display:none;align-items:center;justify-content:center;padding:30px}
.char-lightbox.open{display:flex}
.clb-backdrop{position:absolute;inset:0;background:rgba(12,5,12,.88);backdrop-filter:blur(8px)}
.clb-stage{position:relative;z-index:2;display:flex;align-items:center;gap:36px;max-width:900px;width:100%;justify-content:center;
  animation:clbpop .35s cubic-bezier(.2,.8,.2,1)}
@keyframes clbpop{from{opacity:0;transform:scale(.92) translateY(10px)}to{opacity:1;transform:none}}
.clb-img{flex-shrink:0}
.clb-img img{max-height:74vh;max-width:46vw;width:auto;object-fit:contain;
  filter:drop-shadow(0 20px 50px rgba(0,0,0,.6)) drop-shadow(0 0 40px rgba(244,196,48,.15))}
.clb-info{max-width:280px}
.clb-guild{display:inline-block;color:var(--gold-soft);font-weight:800;font-size:14px;letter-spacing:1px;
  background:rgba(244,196,48,.14);border:1px solid rgba(244,196,48,.4);border-radius:999px;padding:6px 16px;margin-bottom:16px}
.clb-name{font-size:clamp(32px,5vw,48px);font-weight:900;color:#fff;line-height:1.1;
  text-shadow:0 3px 0 var(--red-deep),0 8px 24px rgba(224,57,43,.4)}
.clb-nav{position:absolute;z-index:3;top:50%;transform:translateY(-50%);width:50px;height:50px;border-radius:50%;
  background:rgba(255,246,230,.1);border:1px solid rgba(244,196,48,.4);color:var(--gold-soft);font-size:20px;cursor:pointer;transition:.2s}
.clb-nav:hover{background:var(--gold);color:#5a2a00;transform:translateY(-50%) scale(1.08)}
.clb-nav.prev{left:18px}.clb-nav.next{right:18px}
.clb-close{position:absolute;z-index:3;top:20px;right:22px;width:44px;height:44px;border-radius:50%;
  background:rgba(255,246,230,.1);border:1px solid rgba(244,196,48,.4);color:var(--cream);font-size:18px;cursor:pointer;transition:.2s}
.clb-close:hover{background:var(--red);color:#fff;border-color:var(--red)}

@media(max-width:980px){
  .song-inner{grid-template-columns:1fr;gap:26px}
}
@media(max-width:640px){
  .shooting-visual.stage{min-height:300px}
  .fs-label{font-size:18px}
  .credit-list li{grid-template-columns:96px 1fr;gap:10px;font-size:13px}
}

/* ===================== HERO 純前端夏日祭典場景 ===================== */
.hero-scene{position:absolute;inset:0;z-index:-1;overflow:hidden;
  background:linear-gradient(180deg,#1a0a2e 0%, #2a0f2a 45%, #3a1320 78%, #4a1424 100%)}
.hero-scene .hs-glow{position:absolute;inset:0;filter:blur(8px);
  background:
    radial-gradient(900px 520px at 50% 118%, rgba(224,57,43,.55), rgba(224,57,43,0) 68%),
    radial-gradient(700px 420px at 18% -10%, rgba(244,196,48,.22), rgba(244,196,48,0) 66%),
    radial-gradient(700px 420px at 86% -6%, rgba(255,122,156,.20), rgba(255,122,156,0) 66%)}
.hero-scene::after{content:"";position:absolute;inset:0;opacity:.55;
  background-image:radial-gradient(circle,#fff 1px,transparent 1.6px);background-size:36px 36px;
  -webkit-mask-image:linear-gradient(180deg,#000 0%,transparent 55%);mask-image:linear-gradient(180deg,#000 0%,transparent 55%)}
.hs-fireworks{position:absolute;inset:0;z-index:1}
.hs-moon{position:absolute;top:9%;right:13%;width:88px;height:88px;border-radius:50%;
  background:radial-gradient(circle at 38% 38%, #fff7e0, #ffe08a 60%, #f4c430);
  box-shadow:0 0 50px rgba(244,196,48,.55), inset -8px -8px 0 rgba(210,150,20,.25)}
.hs-flags{position:absolute;top:0;left:-2%;right:-2%;height:34px;display:flex;z-index:1;
  filter:drop-shadow(0 4px 6px rgba(0,0,0,.35))}
.hs-flags span{flex:1;height:24px;clip-path:polygon(0 0,100% 0,100% 55%,50% 100%,0 55%);
  animation:flagwave 2.6s ease-in-out infinite;transform-origin:top}
.hs-flags span:nth-child(odd){background:var(--red)}
.hs-flags span:nth-child(even){background:var(--gold)}
.hs-flags span:nth-child(2){animation-delay:.15s}.hs-flags span:nth-child(3){animation-delay:.3s}
.hs-flags span:nth-child(4){animation-delay:.45s}.hs-flags span:nth-child(5){animation-delay:.6s}
.hs-flags span:nth-child(6){animation-delay:.75s}.hs-flags span:nth-child(7){animation-delay:.9s}
.hs-flags span:nth-child(8){animation-delay:1.05s}.hs-flags span:nth-child(9){animation-delay:1.2s}
.hs-flags span:nth-child(10){animation-delay:1.35s}.hs-flags span:nth-child(11){animation-delay:1.5s}
.hs-flags span:nth-child(12){animation-delay:1.65s}
/* festival skyline silhouette */
.hs-skyline{position:absolute;bottom:0;left:0;right:0;height:140px;z-index:0;opacity:.85;
  display:flex;align-items:flex-end;justify-content:center;gap:30px;opacity:.92}
.hs-skyline span{position:relative;display:block}
.hs-skyline .stall{width:120px;height:78px;border-radius:8px 8px 0 0;
  background:repeating-linear-gradient(90deg,#c0241b 0 16px,#f4ece0 16px 32px);
  border-top:6px solid var(--gold)}
.hs-skyline .stall::before{content:"";position:absolute;top:-18px;left:-8px;right:-8px;height:14px;
  background:#9c1c14;border-radius:6px 6px 0 0}
.hs-skyline .stall.s2{height:64px}.hs-skyline .stall.s3{height:88px}
.hs-skyline .torii{width:86px;height:118px}
.hs-skyline .torii::before{content:"";position:absolute;bottom:0;left:8px;width:12px;height:118px;background:#e0392b;box-shadow:54px 0 0 #e0392b}
.hs-skyline .torii::after{content:"";position:absolute;top:6px;left:-10px;width:106px;height:16px;background:#c0241b;
  border-radius:4px;box-shadow:0 22px 0 -2px #e0392b}
.hs-skyline .torii.t2{height:96px}
.hs-skyline .lantern-pole{width:24px;height:128px}
.hs-skyline .lantern-pole::before{content:"";position:absolute;bottom:0;left:10px;width:5px;height:128px;background:#5a2a2a}
.hs-skyline .lantern-pole::after{content:"";position:absolute;top:12px;left:0;width:24px;height:32px;border-radius:50% 50% 46% 46%;
  background:linear-gradient(180deg,#ff6b5e,#d8261a);box-shadow:0 0 18px rgba(255,120,90,.6), 0 44px 0 -2px #d8261a}
.hs-water{position:absolute;bottom:0;left:0;right:0;height:120px;z-index:0;
  background:linear-gradient(180deg,rgba(22,7,18,0),rgba(22,7,18,.55) 55%,rgba(22,7,18,.92))}
.hero::after{content:"";position:absolute;inset:0;z-index:-1;pointer-events:none;
  background:linear-gradient(180deg,rgba(22,7,18,.35),rgba(22,7,18,.10) 45%,rgba(22,7,18,.78))}
@media(max-width:640px){
  .hs-moon{width:60px;height:60px;top:7%;right:8%}
  .hs-skyline{gap:14px;bottom:0;height:120px}
  .hs-skyline .stall{width:78px}
}

/* ===================== LIVE 頭像改用品牌 LOGO ===================== */
.sched-row .who .avatar.logo{background:#fff;padding:6px;overflow:hidden}
.sched-row .who .avatar.logo img{width:100%;height:100%;object-fit:contain}
.sched-row .who .avatar.logo.dark{background:#1c0c16;border:1px solid rgba(244,196,48,.35)}
.sched-row .who .avatar.photo{background:#1c0c16;padding:0;overflow:hidden;border:1px solid rgba(255,246,230,.18)}
.sched-row .who .avatar.photo img{width:100%;height:100%;object-fit:cover}

/* ===================== 全站打靶游標 + 點擊命中特效 ===================== */
/* 自訂打靶游標（全站） */
:root{--aim-cursor:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='40' height='40' viewBox='0 0 40 40'%3E%3Ccircle cx='20' cy='20' r='15' fill='none' stroke='%23e0392b' stroke-width='2.5'/%3E%3Ccircle cx='20' cy='20' r='8' fill='none' stroke='%23f4c430' stroke-width='2'/%3E%3Ccircle cx='20' cy='20' r='2.5' fill='%23e0392b'/%3E%3Cline x1='20' y1='2' x2='20' y2='10' stroke='%23fff' stroke-width='2'/%3E%3Cline x1='20' y1='30' x2='20' y2='38' stroke='%23fff' stroke-width='2'/%3E%3Cline x1='2' y1='20' x2='10' y2='20' stroke='%23fff' stroke-width='2'/%3E%3Cline x1='30' y1='20' x2='38' y2='20' stroke='%23fff' stroke-width='2'/%3E%3C/svg%3E") 20 20}
body{cursor:var(--aim-cursor), crosshair}
a,button,input,textarea,select,label,iframe,.day-tab,.char-card,.logo-cell,.btn{cursor:pointer}
input[type=text],textarea{cursor:text}
/* 全站命中特效層（固定覆蓋） */
.hit-layer{position:fixed;inset:0;z-index:9999;pointer-events:none}
/* 舊：hero 內特效層（保留相容） */
.hero-hits{position:absolute;inset:0;z-index:3;pointer-events:none}
.hit-mark{position:absolute;width:54px;height:54px;transform:translate(-50%,-50%) scale(.2);
  opacity:0;animation:hitpop .6s ease-out forwards}
.hit-mark .hr{position:absolute;inset:0;border-radius:50%;border:3px solid var(--red)}
.hit-mark .hr.g{inset:12px;border-color:var(--gold)}
.hit-mark .hc{position:absolute;left:50%;top:50%;width:8px;height:8px;border-radius:50%;
  background:var(--red-deep);transform:translate(-50%,-50%)}
.hit-mark .spark{position:absolute;left:50%;top:50%;width:5px;height:5px;border-radius:50%;
  background:var(--gold);box-shadow:0 0 6px var(--gold);animation:sparkfly .6s ease-out forwards}
@keyframes hitpop{0%{transform:translate(-50%,-50%) scale(.2);opacity:1}
  60%{opacity:1}100%{transform:translate(-50%,-50%) scale(1.25);opacity:0}}
@keyframes sparkfly{0%{transform:translate(-50%,-50%) translate(0,0);opacity:1}
  100%{transform:translate(-50%,-50%) translate(var(--sx),var(--sy));opacity:0}}

/* ===================== HERO 主題視覺強化 ===================== */
/* 標題列 + 兩側祭典印章 */
.hero-title-row{display:flex;align-items:center;justify-content:center;gap:22px;flex-wrap:nowrap}
.hero-title-row h1{margin:0}
.hero-seal{flex-shrink:0;width:72px;height:72px;border-radius:14px;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(145deg,var(--red),var(--red-deep));
  border:2px solid var(--gold-soft);box-shadow:0 8px 22px rgba(224,57,43,.5), inset 0 0 0 4px rgba(255,224,138,.25);
  transform:rotate(-8deg);animation:sealfloat 5s ease-in-out infinite}
.hero-seal.right{transform:rotate(8deg);animation-delay:-2.5s}
.hero-seal b{font-size:38px;font-weight:900;color:#fff;text-shadow:0 2px 4px rgba(120,0,0,.6);line-height:1}
@keyframes sealfloat{0%,100%{transform:rotate(-8deg) translateY(0)}50%{transform:rotate(-8deg) translateY(-8px)}}
.hero-seal.right{animation-name:sealfloatR}
@keyframes sealfloatR{0%,100%{transform:rotate(8deg) translateY(0)}50%{transform:rotate(8deg) translateY(-8px)}}
/* 主題標語 */
.hero-edition{display:inline-flex;align-items:center;gap:14px;margin:2px 0 2px}
.hero-edition span{font-size:clamp(20px,3.4vw,30px);font-weight:900;color:var(--gold-soft);letter-spacing:10px;padding-left:10px;text-shadow:0 3px 16px rgba(0,0,0,.5)}
.hero-edition::before,.hero-edition::after{content:"";width:30px;height:2px;background:linear-gradient(90deg,transparent,var(--gold))}
.hero-edition::before{transform:scaleX(-1)}
.hero-tagline{margin:4px auto 18px;font-size:clamp(15px,2.4vw,19px);font-weight:700;color:var(--gold-soft);
  letter-spacing:2px;max-width:640px;position:relative;display:inline-block;padding:0 6px}
.hero-tagline::before,.hero-tagline::after{content:"";position:absolute;top:50%;width:42px;height:2px;
  background:linear-gradient(90deg,transparent,var(--gold));opacity:.7}
.hero-tagline::before{right:100%;margin-right:14px;transform:scaleX(-1)}
.hero-tagline::after{left:100%;margin-left:14px}
/* 向下捲動指示 */
.hero-scroll{position:absolute;left:50%;bottom:22px;transform:translateX(-50%);z-index:5;
  display:flex;flex-direction:column;align-items:center;gap:8px;opacity:.85;transition:.25s}
.hero-scroll:hover{opacity:1;transform:translateX(-50%) translateY(3px)}
.hero-scroll .hs-txt{font-size:11px;letter-spacing:4px;font-weight:800;color:var(--gold-soft);text-shadow:0 1px 6px rgba(0,0,0,.85)}
.hero-scroll .hs-arrow{width:24px;height:24px;border-right:2.5px solid var(--gold);border-bottom:2.5px solid var(--gold);
  transform:rotate(45deg);animation:scrolldown 1.8s ease-in-out infinite}
@keyframes scrolldown{0%{opacity:0;transform:rotate(45deg) translate(-4px,-4px)}
  50%{opacity:1}100%{opacity:0;transform:rotate(45deg) translate(4px,4px)}}
@media(max-width:640px){
  .hero-title-row{gap:10px}
  .hero-seal{width:48px;height:48px;border-radius:10px}
  .hero-seal b{font-size:24px}
  .hero-tagline::before,.hero-tagline::after{width:20px}
  .hero-scroll{bottom:16px}
}

/* ===================== 活動 LOGO（Hero 主視覺 + Nav 品牌） ===================== */
.hero-logo{margin:0 auto;max-width:500px;animation:logofloat 6s ease-in-out infinite}
.hero-logo img{width:100%;height:auto;
  filter:drop-shadow(0 14px 36px rgba(224,57,43,.45)) drop-shadow(0 4px 14px rgba(0,0,0,.4))}
@keyframes logofloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
/* Nav 品牌 LOGO 標記 */
.brand-mark{height:40px;width:auto;flex-shrink:0;
  filter:drop-shadow(0 2px 6px rgba(0,0,0,.4))}
@media(max-width:640px){
  .hero{padding:84px 18px 120px;min-height:92vh}
  .hero-logo{max-width:300px}
  .hero-edition span{letter-spacing:6px;font-size:20px}
  .hero-edition::before,.hero-edition::after{width:18px}
  .brand-mark{height:32px}
  .brand-logo .vf{font-size:15px}
  .brand-logo .vf small{font-size:9.5px;letter-spacing:2px}
}

/* 頁尾活動 LOGO */
footer .f-logo{height:96px;width:auto;margin:0 auto 6px;opacity:.95;filter:drop-shadow(0 4px 14px rgba(0,0,0,.45))}
@media(max-width:640px){footer .f-logo{height:72px}}
/* ===================== 活動資訊 改版（不對稱主從 + 倒數 + 和風） ===================== */
.info-layout{display:grid;grid-template-columns:1.35fr 1fr;gap:20px;align-items:stretch}
/* 統一線條圖示底座 */
.info-ico{display:inline-flex;align-items:center;justify-content:center;width:52px;height:52px;border-radius:14px;
  background:linear-gradient(145deg,rgba(224,57,43,.28),rgba(244,196,48,.14));
  border:1px solid rgba(244,196,48,.45);color:var(--gold-soft);flex-shrink:0;transition:.25s}
.info-ico svg{width:28px;height:28px}
.info-ico.sm{width:46px;height:46px}.info-ico.sm svg{width:24px;height:24px}
.info-label{color:var(--gold);font-weight:800;letter-spacing:2px;font-size:12.5px}

/* 主卡（日期 + 倒數） */
.info-hero{position:relative;overflow:hidden;border-radius:var(--radius);padding:30px 32px;
  background:linear-gradient(155deg,rgba(224,57,43,.20),rgba(36,16,21,.55));
  border:1px solid rgba(244,196,48,.4);box-shadow:var(--shadow);
  display:flex;flex-direction:column;justify-content:center;transition:.25s}
.info-hero:hover{border-color:var(--gold);transform:translateY(-4px)}
.info-hero:hover .info-ico{transform:rotate(-6deg) scale(1.05)}
/* 市松紋裝飾（右上角） */
.info-hero .ichimatsu{position:absolute;top:-20px;right:-20px;width:130px;height:130px;opacity:.14;transform:rotate(12deg);
  background-image:
    linear-gradient(45deg,var(--gold) 25%,transparent 25%,transparent 75%,var(--gold) 75%),
    linear-gradient(45deg,var(--gold) 25%,transparent 25%,transparent 75%,var(--gold) 75%);
  background-size:24px 24px;background-position:0 0,12px 12px}
.info-hero-top{display:flex;align-items:center;gap:14px;margin-bottom:16px;position:relative}
.info-hero-date{font-size:clamp(34px,5.5vw,56px);font-weight:900;color:#fff;line-height:1;letter-spacing:1px;
  text-shadow:0 3px 0 var(--red-deep),0 8px 22px rgba(224,57,43,.45)}
.info-hero-date .slash{color:var(--gold);margin:0 1px}
.info-hero-date .dash{color:var(--gold-soft);margin:0 8px;font-weight:700}
.info-hero-sub{color:rgba(255,246,230,.82);font-size:15px;font-weight:600;margin:12px 0 20px}
/* 倒數 */
.countdown{display:flex;align-items:center;gap:6px}
.cd-unit{display:flex;flex-direction:column;align-items:center;
  background:rgba(20,8,16,.5);border:1px solid rgba(244,196,48,.35);border-radius:12px;
  padding:10px 0;min-width:60px}
.cd-num{font-size:30px;font-weight:900;color:var(--gold-soft);line-height:1;font-variant-numeric:tabular-nums;
  text-shadow:0 2px 10px rgba(244,196,48,.35)}
.cd-lab{font-size:11px;color:rgba(255,246,230,.7);font-weight:700;margin-top:5px;letter-spacing:1px}
.cd-sep{font-size:24px;font-weight:900;color:var(--red);align-self:flex-start;margin-top:10px}
.countdown-note{margin-top:12px;font-size:13.5px;color:var(--gold);font-weight:700;letter-spacing:1px}
.countdown-note::before{content:"❉ ";color:var(--red)}

/* 三張小卡 */
.info-side{display:flex;flex-direction:column;gap:16px}
.info-mini{display:flex;align-items:center;gap:16px;flex:1;
  background:linear-gradient(160deg,rgba(255,246,230,.07),rgba(255,246,230,.02));
  border:1px solid rgba(244,196,48,.28);border-radius:var(--radius);padding:18px 22px;transition:.25s}
.info-mini:hover{transform:translateX(5px);border-color:var(--gold);box-shadow:var(--shadow)}
.info-mini:hover .info-ico{transform:scale(1.08);color:#fff}
.info-mini-txt .info-label{margin-bottom:5px;display:block}
.info-val{font-size:19px;font-weight:900;color:#fff;line-height:1.3}
.info-val small{display:block;font-size:12.5px;color:rgba(255,246,230,.68);font-weight:600;margin-top:3px}

@media(max-width:860px){
  .info-layout{grid-template-columns:1fr}
}
@media(max-width:640px){
  .info-hero{padding:24px 20px}
  .cd-unit{min-width:0;flex:1}
  .cd-num{font-size:24px}
  .info-val{font-size:17px}
}



/* ===================== 祭典打靶 獎品清單 ===================== */
.shooting-text .lead-sub{color:rgba(255,246,230,.72);font-size:15px;margin:-8px 0 22px;line-height:1.7}
.prize-section{margin-top:56px}
.prize-head{text-align:center;margin-bottom:30px}
.prize-head .prize-kicker{display:inline-block;color:var(--gold);font-weight:800;letter-spacing:3px;font-size:13px;margin-bottom:10px}
.prize-head h3{font-size:clamp(24px,4vw,36px);font-weight:900;color:#fff;letter-spacing:1px;text-shadow:0 3px 16px rgba(224,57,43,.4)}
.prize-head h3 .mark{color:var(--gold)}
.prize-head p{color:rgba(255,246,230,.78);margin-top:10px;font-size:15.5px}
.prize-list{list-style:none;max-width:760px;margin:0 auto;display:flex;flex-direction:column;gap:12px;padding:0}
.prize-list li{position:relative;display:grid;grid-template-columns:auto auto 1fr auto;align-items:center;gap:16px;
  background:linear-gradient(120deg,rgba(255,246,230,.07),rgba(255,246,230,.02));
  border:1px solid rgba(244,196,48,.28);border-radius:14px;padding:16px 22px 16px 18px;transition:.24s}
.prize-list li::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;border-radius:14px 0 0 14px;
  background:linear-gradient(180deg,var(--red),var(--gold))}
.prize-list li:hover{transform:translateX(5px);border-color:var(--gold);box-shadow:var(--shadow)}
.pl-ico{flex-shrink:0;width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(145deg,rgba(224,57,43,.28),rgba(244,196,48,.14));
  border:1px solid rgba(244,196,48,.4);color:var(--gold-soft);transition:.24s}
.pl-ico svg{width:24px;height:24px}
.prize-list li:hover .pl-ico{transform:rotate(-6deg) scale(1.06);color:#fff}
.pl-brand{color:var(--gold);font-weight:800;font-size:13.5px;letter-spacing:.5px;white-space:nowrap}
.pl-name{color:#fff;font-weight:800;font-size:16.5px;line-height:1.35;min-width:0}
.pl-qty{color:var(--gold-soft);font-weight:900;font-size:15px;white-space:nowrap;
  background:rgba(20,8,16,.45);border:1px solid rgba(244,196,48,.3);border-radius:999px;padding:5px 14px}
/* 現場限定列：teal 區隔 */
.prize-list li.extra{background:linear-gradient(120deg,rgba(47,179,168,.13),rgba(255,246,230,.02));border-color:rgba(47,179,168,.4)}
.prize-list li.extra::before{background:linear-gradient(180deg,var(--teal),var(--gold))}
.prize-list li.extra .pl-ico{color:var(--teal);border-color:rgba(47,179,168,.45)}
.prize-list li.extra .pl-brand{color:var(--teal)}
.prize-foot{text-align:center;color:rgba(255,246,230,.55);font-size:13px;margin-top:22px;letter-spacing:.5px}
@media(max-width:640px){
  .prize-list li{grid-template-columns:auto 1fr auto;gap:12px;padding:14px 16px 14px 14px}
  .pl-brand{grid-column:2;font-size:12.5px}
  .pl-name{grid-column:2;font-size:15px}
  .pl-ico{grid-row:span 2}
  .pl-qty{grid-row:span 2}
}

/* ===================== 攤位陣容 ・ 日式屋台 + LOGO 牆 ===================== */
.booth-grid{display:grid;grid-template-columns:1fr 1fr;gap:28px;align-items:start}
.yatai{position:relative;border-radius:0 0 var(--radius) var(--radius);overflow:visible;
  background:linear-gradient(180deg,rgba(36,16,21,.62),rgba(26,12,18,.5));
  border:1px solid rgba(244,196,48,.3);border-top:0;transition:.25s;margin-top:54px}
.yatai:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--gold)}
/* 屋台頂棚（木紋暖簾） */
.yatai-roof{position:absolute;top:-54px;left:-10px;right:-10px;height:54px;border-radius:12px 12px 0 0;
  background:repeating-linear-gradient(90deg,#b21f17 0 26px,#8e1812 26px 52px);
  box-shadow:0 6px 16px rgba(120,8,12,.45);display:flex;align-items:center;justify-content:center;
  border:2px solid var(--gold)}
.yatai-roof::before{content:"";position:absolute;top:-9px;left:8px;right:8px;height:12px;border-radius:8px 8px 0 0;
  background:#7a140f}
.yatai.game .yatai-roof{background:repeating-linear-gradient(90deg,#0f6e56 0 26px,#0b5343 26px 52px)}
.yatai .noren{position:relative;color:#fff;font-weight:900;font-size:17px;letter-spacing:3px;
  text-shadow:0 2px 4px rgba(0,0,0,.5)}
/* 掛旗 */
.yatai-flags{position:absolute;top:4px;left:6px;right:6px;height:18px;display:flex;z-index:2}
.yatai-flags span{flex:1;height:13px;clip-path:polygon(0 0,100% 0,100% 55%,50% 100%,0 55%);
  animation:flagwave 2.6s ease-in-out infinite}
.yatai-flags span:nth-child(odd){background:var(--gold)}
.yatai-flags span:nth-child(even){background:#fff}
.yatai-flags span:nth-child(2){animation-delay:.15s}.yatai-flags span:nth-child(3){animation-delay:.3s}
.yatai-flags span:nth-child(4){animation-delay:.45s}.yatai-flags span:nth-child(5){animation-delay:.6s}
.yatai-flags span:nth-child(6){animation-delay:.75s}.yatai-flags span:nth-child(7){animation-delay:.9s}
.yatai-flags span:nth-child(8){animation-delay:1.05s}
/* 屋台內容 */
.yatai-body{padding:26px 24px 28px}
.yatai-sub{display:inline-flex;align-items:center;gap:7px;color:var(--gold-soft);font-size:13px;font-weight:800;letter-spacing:2px;margin-bottom:20px;padding:6px 16px;background:rgba(244,196,48,.12);border:1px solid rgba(244,196,48,.4);border-radius:999px}
.yatai-sub::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--red)}
.yatai.game .yatai-sub{color:#7fe7d6;background:rgba(47,179,168,.14);border-color:rgba(47,179,168,.45)}
.yatai.game .yatai-sub::before{background:var(--teal)}
/* LOGO 牆 */
.booth-logos{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.booth-logos.main{grid-template-columns:repeat(5,1fr)}
.booth-logo{display:flex;align-items:center;justify-content:center;aspect-ratio:1/1;padding:8px;
  background:#fff;border:1px solid rgba(244,196,48,.4);border-radius:12px;transition:.22s;position:relative}
.booth-logo img{max-width:100%;max-height:100%;object-fit:contain}
.booth-logo:hover{transform:translateY(-4px);box-shadow:0 8px 20px rgba(0,0,0,.35);outline:2px solid var(--gold);outline-offset:-2px}

@media(max-width:980px){
  .booth-grid{grid-template-columns:1fr;gap:54px}
}
@media(max-width:560px){
  .booth-logos{grid-template-columns:repeat(3,1fr)}
  .booth-logos.main{grid-template-columns:repeat(3,1fr)}
  .yatai .noren{font-size:14px;letter-spacing:1.5px}
}

/* ===================== 立繪輪播 + 燈箱 RWD ===================== */
@media(max-width:980px){
  .cs-stage{min-height:0;gap:18px;padding:20px 22px}
  .cs-figure{height:300px}.cs-figure img{max-height:300px}
  .clb-stage{gap:24px}
  .clb-img img{max-width:54vw}
}
@media(max-width:640px){
  .char-showcase{gap:4px}
  .cs-stage{grid-template-columns:1fr;text-align:center;padding:18px 16px}
  .cs-figure{height:260px}.cs-figure img{max-height:260px}
  .cs-name{font-size:30px}
  .cs-nav{width:40px;height:40px}
  .cs-thumb{width:66px;height:84px}
  .clb-stage{flex-direction:column;gap:16px;text-align:center}
  .clb-img img{max-width:80vw;max-height:54vh}
  .clb-info{max-width:90vw}
  .clb-nav.prev{left:6px}.clb-nav.next{right:6px}
  .clb-nav{width:42px;height:42px}
}

/* 燈箱 YouTube 連結按鈕 */
.clb-yt{display:inline-flex;align-items:center;gap:9px;margin-top:22px;background:#ff0033;color:#fff;
  font-weight:800;font-size:14px;border-radius:999px;padding:11px 22px;transition:.2s;box-shadow:0 8px 20px rgba(255,0,51,.35)}
.clb-yt svg{width:22px;height:22px}
.clb-yt:hover{transform:translateY(-2px);background:#e60030}

/* ===================== LIVE 主播名字可點擊（連 YouTube） ===================== */
.sched-row .who .meta .name-link{display:inline-flex;align-items:center;gap:7px;
  font-size:19px;font-weight:900;color:#fff;text-decoration:none;transition:.18s}
.sched-row .who .meta .name-link .name-yt{width:18px;height:18px;color:#ff0033;opacity:.55;flex-shrink:0;transition:.18s}
.sched-row .who .meta .name-link:hover{color:var(--gold-soft)}
.sched-row .who .meta .name-link:hover .name-yt{opacity:1;transform:scale(1.12)}
@media(max-width:640px){
  .sched-row .who .meta .name-link{font-size:16px}
}

/* Presented By 標籤與名單（窄螢幕拆兩行） */
.presented-by .pb-label{margin-right:10px}
.presented-by .pb-names{white-space:nowrap}
@media(max-width:560px){
  .presented-by .pb-label{display:block;margin-right:0;margin-bottom:4px}
  .presented-by .pb-names{display:block;white-space:normal}
}

/* ===================== 圖片防護輔助（透明遮罩 + 不可選取） ===================== */
img{-webkit-user-select:none;user-select:none;-webkit-user-drag:none;-webkit-touch-callout:none}
/* 燈箱大圖、hero LOGO 加透明遮罩，右鍵/長按點到空層 */
.clb-img,.hero-logo,.promo-visual{position:relative}
.clb-img::after,.hero-logo::after,.promo-visual::after{content:"";position:absolute;inset:0;z-index:2}

/* 燈箱開啟時，暫停背景的浮動動畫（避免整個介面像在呼吸） */
body.lb-open .cs-figure img{animation-play-state:paused}
body.lb-open .lantern{animation-play-state:paused}
body.lb-open .hero-logo{animation-play-state:paused}

/* ===================== 影片「敬請期待」遮罩 ===================== */
.vid.vid-soon{display:flex;align-items:center;justify-content:center;
  background:linear-gradient(150deg,rgba(224,57,43,.22),rgba(26,12,30,.7));position:relative;overflow:hidden}
.vid.vid-soon::before{content:"";position:absolute;inset:0;opacity:.5;
  background-image:radial-gradient(circle,rgba(255,255,255,.6) 1px,transparent 1.4px);background-size:28px 28px;
  -webkit-mask-image:radial-gradient(circle at 50% 50%,#000,transparent 70%);mask-image:radial-gradient(circle at 50% 50%,#000,transparent 70%)}
.soon-inner{position:relative;z-index:1;text-align:center;display:flex;flex-direction:column;align-items:center;gap:6px}
.soon-ico{width:64px;height:64px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  background:rgba(255,246,230,.08);border:2px solid rgba(244,196,48,.5);color:var(--gold-soft);margin-bottom:6px;
  animation:soonpulse 2.4s ease-in-out infinite}
.soon-ico svg{width:30px;height:30px;margin-left:3px}
@keyframes soonpulse{0%,100%{transform:scale(1);box-shadow:0 0 0 0 rgba(244,196,48,.35)}50%{transform:scale(1.06);box-shadow:0 0 0 10px rgba(244,196,48,0)}}
.soon-title{font-size:22px;font-weight:900;color:#fff;letter-spacing:4px;text-shadow:0 2px 12px rgba(224,57,43,.5)}
.soon-sub{font-size:12px;font-weight:800;letter-spacing:5px;color:var(--gold-soft)}
