:root{
  --bg:#060b18; --bg2:#0a1430; --panel:#0e1a3a; --panel2:#101f47;
  --ink:#eaf0ff; --sub:#9fb0d6; --mut:#6f80a6; --line:rgba(120,150,220,.16); --line2:rgba(120,150,220,.10);
  --jp:#ff1f48; --jp2:#e60026; --jp-soft:rgba(255,31,72,.14);
  --gold:#ffd45e; --silver:#cdd8ee; --bronze:#e0975a; --ice:#5fd0ff;
  --r:16px; --shadow:0 18px 50px rgba(0,0,0,.45);
}
*{box-sizing:border-box;margin:0;padding:0}
html{background:var(--bg)}
body{font-family:"Noto Sans JP",system-ui,sans-serif;background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;overflow-x:hidden}
.app{max-width:700px;margin:0 auto;min-height:100vh;background:
  radial-gradient(120% 60% at 50% -5%,rgba(40,90,200,.16),transparent 60%),var(--bg)}
.wrap{padding:0 14px 48px}
h2{font-size:18px;font-weight:900;letter-spacing:.01em}
a{color:var(--ice)}

/* ============ HERO ============ */
.hero{position:relative;overflow:hidden;color:#fff;min-height:520px;
  background:
    radial-gradient(85% 65% at 82% 6%,rgba(255,31,72,.32),transparent 55%),
    radial-gradient(75% 60% at 10% 98%,rgba(40,110,255,.28),transparent 60%),
    linear-gradient(180deg,#070d1f,#0b1740 58%,#070d1f)}
.hero-sun{position:absolute;top:-160px;right:-120px;width:460px;height:460px;border-radius:50%;pointer-events:none;
  background:conic-gradient(from 0deg,rgba(255,31,72,.22),transparent 18deg,rgba(255,31,72,.22) 36deg,transparent 54deg,rgba(255,31,72,.22) 72deg,transparent 90deg,rgba(255,31,72,.22) 108deg,transparent 126deg,rgba(255,31,72,.22) 144deg,transparent 162deg,rgba(255,31,72,.22) 180deg,transparent 198deg,rgba(255,31,72,.22) 216deg,transparent 234deg,rgba(255,31,72,.22) 252deg,transparent 270deg,rgba(255,31,72,.22) 288deg,transparent 306deg,rgba(255,31,72,.22) 324deg,transparent 342deg);
  -webkit-mask:radial-gradient(closest-side,#000 38%,transparent 72%);mask:radial-gradient(closest-side,#000 38%,transparent 72%);
  opacity:.5;animation:sunspin 90s linear infinite}
@keyframes sunspin{to{transform:rotate(1turn)}}
.hero-grid{position:absolute;inset:0;pointer-events:none;opacity:.5;
  background:repeating-linear-gradient(115deg,transparent 0 38px,rgba(255,255,255,.035) 38px 39px)}
.hero-in{position:relative;padding:26px 22px 92px;z-index:3}
.hero-top{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.badge-jp{font-family:Archivo,sans-serif;font-weight:900;font-size:11px;letter-spacing:.12em;color:#fff;
  background:linear-gradient(120deg,var(--jp2),var(--jp));padding:5px 11px;border-radius:999px;box-shadow:0 4px 16px rgba(255,31,72,.4)}
.kick{font-family:Archivo,sans-serif;font-weight:700;letter-spacing:.22em;font-size:10.5px;color:var(--sub);text-transform:uppercase}
.unofficial{font-family:Archivo,sans-serif;font-size:9px;font-weight:800;letter-spacing:.12em;color:var(--mut);border:1px solid var(--line);border-radius:999px;padding:3px 9px;white-space:nowrap}
.hero-en{font-family:Anton,sans-serif;font-weight:400;font-size:54px;line-height:.92;margin-top:18px;letter-spacing:.005em;
  text-shadow:0 4px 30px rgba(0,0,0,.5)}
.hero-en span{color:var(--gold);text-shadow:0 0 26px rgba(255,212,94,.45)}
.hero-jp{font-size:16px;font-weight:800;color:var(--sub);margin-top:8px;letter-spacing:.06em}
.hero-meta{display:flex;align-items:center;gap:9px;margin-top:14px;font-size:13px;font-weight:700;color:#dce6ff}
.hero-meta .dot{color:var(--mut)}
/* countdown */
.cd{margin-top:22px}
.cd-l{font-family:Archivo,sans-serif;font-weight:800;letter-spacing:.22em;font-size:10.5px;color:var(--gold);text-transform:uppercase}
.cd-nums{display:flex;align-items:flex-start;gap:5px;margin-top:9px}
.cd-sep{font-family:Anton;font-size:26px;color:rgba(255,255,255,.3);margin-top:6px;animation:blink 1s steps(1) infinite}
@keyframes blink{50%{opacity:.2}}
.cd-u{flex:1;max-width:88px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.12);border-radius:12px;
  padding:11px 4px 8px;text-align:center;backdrop-filter:blur(4px)}
.cd-u b{display:block;font-family:Anton,sans-serif;font-size:36px;line-height:1;text-shadow:0 0 18px rgba(120,190,255,.35)}
.cd-u span{font-size:9px;font-weight:800;letter-spacing:.14em;color:var(--mut)}
.cd-u.sec{background:linear-gradient(165deg,rgba(255,212,94,.18),rgba(255,255,255,.04));border-color:rgba(255,212,94,.45)}
.cd-u.sec b{color:var(--gold);text-shadow:0 0 18px rgba(255,212,94,.6)}
.cd-u.sec span{color:var(--gold)}
/* hero stats */
.hero-stats{display:flex;gap:22px;margin-top:22px}
.hs{display:flex;flex-direction:column}
.hs b{font-family:Anton,sans-serif;font-size:30px;line-height:1}
.hs span{font-size:9.5px;font-weight:800;letter-spacing:.12em;color:var(--mut);margin-top:2px}
.hs.jp b{color:var(--jp)}
.hs.jp span{color:#ffd0d8}

/* hero water animation */
.hw{position:absolute;left:0;right:0;bottom:8px;height:74px;z-index:2;pointer-events:none}
.hw-lane{position:absolute;left:0;width:100%;top:var(--y);height:18px;animation:glide var(--d) linear var(--delay) infinite}
.hw-boat{position:absolute;left:0;top:0;color:rgba(180,205,255,.6);animation:surge 2.6s ease-in-out infinite}
.hw-boat.jp{color:var(--jp);filter:drop-shadow(0 0 9px rgba(255,31,72,.7))}
@keyframes glide{from{transform:translateX(-24%)}to{transform:translateX(120%)}}
@keyframes surge{0%,100%{transform:translateX(0)}55%{transform:translateX(3px)}}

/* ============ NOTICE ============ */
.notice{display:flex;flex-wrap:wrap;align-items:center;gap:4px 12px;justify-content:space-between;
  margin:16px 0 6px;padding:11px 15px;border-radius:12px;background:var(--panel);border:1px solid var(--line);
  font-size:12.5px;color:var(--sub);font-weight:600}
.notice b{font-weight:800;color:#dce6ff}
.notice i{font-style:normal;color:var(--mut);font-size:11px}
.notice.live{border-color:rgba(255,31,72,.4);background:linear-gradient(120deg,rgba(255,31,72,.12),var(--panel))}
.liveb{display:inline-flex;align-items:center;gap:6px;color:#fff!important;background:var(--jp);padding:2px 9px;border-radius:6px;font-size:11px}
.ld{width:7px;height:7px;border-radius:50%;background:#fff;animation:pulse 1.2s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}

/* ============ TEAM JAPAN ============ */
.tj{margin-top:26px}
.tj-head{display:flex;align-items:center;gap:13px}
.tj-bar{width:5px;height:42px;border-radius:3px;background:linear-gradient(var(--jp),var(--jp2));box-shadow:0 0 14px rgba(255,31,72,.5)}
.tj-en{font-family:Archivo,sans-serif;font-weight:900;letter-spacing:.2em;font-size:11px;color:var(--jp)}
.tj-head h2{font-size:20px;margin-top:1px}
.tj-count{margin-left:auto;font-family:Anton,sans-serif;font-size:30px;color:#fff;line-height:1}
.tj-count i{font-style:normal;font-size:12px;color:var(--mut);font-weight:800;margin-left:2px}
.tj-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:13px}
.tj-card{position:relative;overflow:hidden;border-radius:var(--r);padding:14px 13px 13px;
  background:linear-gradient(160deg,var(--panel2),var(--panel));border:1px solid var(--line);box-shadow:var(--shadow)}
.tj-card::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:linear-gradient(var(--jp),var(--jp2))}
.tj-card.pri{border-color:rgba(255,212,94,.4)}
.tj-card.pri::after{content:"";position:absolute;right:-30px;top:-30px;width:80px;height:80px;border-radius:50%;
  background:radial-gradient(circle,rgba(255,212,94,.22),transparent 70%)}
.tj-c-top{display:flex;align-items:center;justify-content:space-between;gap:6px}
.tj-ab{font-family:Archivo,sans-serif;font-weight:900;font-size:15px;color:#fff;letter-spacing:.02em}
.tj-star{font-size:9px;font-weight:900;color:#1b1300;background:linear-gradient(120deg,var(--gold),#ffe79a);
  padding:2px 7px;border-radius:999px;letter-spacing:.02em;white-space:nowrap}
.tj-ev{font-size:12px;font-weight:700;color:var(--sub);margin:2px 0 9px}
.tj-mem{display:flex;flex-direction:column;gap:6px}
.tj-m{display:flex;flex-direction:column;line-height:1.25}
.tj-m b{font-size:14.5px;font-weight:800;color:#fff}
.tj-m i{font-style:normal;font-size:10.5px;color:var(--mut);font-weight:600}
.src-note{font-size:10.5px;color:var(--mut);margin-top:10px;font-weight:600}

/* ============ SECTION / EVENTS ============ */
.sec{margin-top:30px}
.sec-head{display:flex;align-items:center;gap:11px;margin-bottom:13px}
.sec-bar{width:5px;height:24px;border-radius:3px;background:linear-gradient(var(--ice),#2f7cf6)}
.sec-count{margin-left:auto;font-family:Archivo;font-size:12px;font-weight:800;color:#cfe0ff;background:var(--panel);border:1px solid var(--line);border-radius:999px;padding:3px 12px}
.ev-list{display:flex;flex-direction:column;gap:8px}
.ev{background:var(--panel);border:1px solid var(--line);border-radius:13px;overflow:hidden;transition:border-color .15s}
.ev.jp{border-color:rgba(255,31,72,.32);background:linear-gradient(110deg,rgba(255,31,72,.07),var(--panel))}
.ev-h{display:flex;align-items:center;gap:11px;padding:13px 14px}
.ev.has .ev-h{cursor:pointer}
.ev.has:hover{border-color:rgba(120,150,220,.35)}
.ev-ab{font-family:Archivo;font-weight:900;font-size:12.5px;color:var(--ice);min-width:52px}
.ev.jp .ev-ab{color:var(--jp)}
.ev-nm{flex:1;font-size:13.5px;font-weight:700;display:flex;align-items:center;gap:7px}
.ev-jp{font-size:12px}
.ev-st{font-size:11px;font-weight:800;color:var(--mut)}
.ev.has .ev-st{color:var(--ice)}
.ev-body{border-top:1px solid var(--line2);padding:4px 12px 12px;background:rgba(0,0,0,.18)}
.race{margin-top:11px}
.race-h{display:flex;align-items:center;gap:7px;font-size:11.5px;font-weight:800;color:var(--sub);margin-bottom:6px}
.race.final .race-h{color:var(--gold)}
.fin-tag{font-family:Archivo;font-size:8.5px;font-weight:900;color:#1b1300;background:linear-gradient(120deg,var(--gold),#ffe79a);padding:1px 6px;border-radius:4px;letter-spacing:.05em}
.race-empty{font-size:11px;color:var(--mut);padding:3px 0}
.boat{display:flex;align-items:center;gap:10px;padding:7px 9px;border-radius:9px}
.boat+.boat{margin-top:3px}
.boat.jpn{background:var(--jp-soft);box-shadow:inset 0 0 0 1px rgba(255,31,72,.3)}
.boat.gold{background:linear-gradient(100deg,rgba(255,212,94,.16),transparent)}
.boat.silver{background:linear-gradient(100deg,rgba(205,216,238,.12),transparent)}
.boat.bronze{background:linear-gradient(100deg,rgba(224,151,90,.13),transparent)}
.b-rank{font-family:Anton;font-size:17px;width:24px;text-align:center;color:var(--sub)}
.boat.jpn .b-rank{color:var(--jp)}
.boat.gold .b-rank{color:var(--gold);text-shadow:0 0 12px rgba(255,212,94,.6)}
.boat.silver .b-rank{color:var(--silver)}
.boat.bronze .b-rank{color:var(--bronze)}
.b-cty{font-family:Archivo;font-weight:800;font-size:11px;color:var(--mut);width:36px;letter-spacing:.03em}
.boat.jpn .b-cty{color:var(--jp)}
.b-main{flex:1;min-width:0}
.b-main b{font-size:13px;font-weight:700;color:var(--ink)}
.b-time{font-family:Archivo;font-weight:700;font-size:12.5px;color:#dce6ff;white-space:nowrap;letter-spacing:.02em}

.loading,.err{padding:18px;text-align:center;color:var(--mut);font-size:13px}
.err{color:var(--jp)}

/* ============ FOOTER ============ */
.ft{margin-top:32px;padding-top:18px;border-top:1px solid var(--line);text-align:center}
.ft-comp{font-size:12px;font-weight:700;color:var(--sub)}
.ft-note{margin-top:7px;font-size:11px;font-weight:700;color:var(--sub);background:rgba(255,31,72,.08);border:1px solid rgba(255,31,72,.25);border-radius:8px;padding:7px 12px;display:inline-block}
.ft-src{margin-top:8px;font-family:Archivo;font-size:10.5px;font-weight:700;letter-spacing:.1em;color:var(--mut)}

@media (prefers-reduced-motion:reduce){
  .hero-sun,.hw-lane,.hw-boat,.cd-sep,.ld{animation:none!important}
}
