/* =========================================================
   월드컵 단체응원전 — 홍보부문
   World Cup Red × GS Caltex tone
   ========================================================= */

@import url('https://cdn.jsdelivr.net/gh/orioncactus/pretendard@v1.3.9/packages/pretendard/dist/web/static/pretendard.css');
@import url('https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700;0,9..40,800;1,9..40,600&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Anton&display=swap');

:root{
  /* World Cup Red */
  --kr-red:      #D7182A;
  --kr-red-600:  #B5111F;
  --kr-red-700:  #8E0C18;
  --kr-red-soft: #FCE9EB;
  --kr-blue:     #1B3A8C;   /* taegeuk / czech blue accent */

  /* GS Caltex anchors (절충) */
  --jade:    #009999;
  --jade-700:#006868;
  --forest:  #1B5230;
  --forest-900:#0F3020;
  --orange:  #E87722;
  --orange-700:#BF5500;

  /* Ink / surfaces */
  --ink:      #0E1220;   /* hero base */
  --ink-2:    #161B2B;
  --ink-3:    #222840;
  --neutral-900:#1A1E28;
  --neutral-600:#5A6070;
  --neutral-400:#9AA1AD;
  --neutral-200:#D8DDE4;
  --neutral-100:#EEF0F2;
  --neutral-50: #F7F8F9;
  --white:     #FFFFFF;
  --gold:      #E9B949;

  --page-bg: #F4F5F7;

  --font: 'Pretendard','Apple SD Gothic Neo','NanumGothic',sans-serif;
  --font-en: 'DM Sans','Pretendard',sans-serif;
  --font-poster: 'Anton','DM Sans',sans-serif;

  --maxw: 1160px;
  --radius: 16px;
  --radius-sm: 10px;
  --shadow-card: 0 1px 3px rgba(16,20,40,.06), 0 8px 28px rgba(16,20,40,.06);
  --shadow-lift: 0 18px 50px rgba(16,20,40,.16);

  /* accent — swappable via Tweaks */
  --accent: var(--jade);
  --accent-700: var(--jade-700);
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; scroll-padding-top:78px; }
body{
  margin:0;
  font-family:var(--font);
  color:var(--neutral-900);
  background:var(--page-bg);
  -webkit-font-smoothing:antialiased;
  text-wrap:pretty;
  line-height:1.6;
}
img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
.en{ font-family:var(--font-en); }

/* ---------- layout ---------- */
.wrap{ width:100%; max-width:var(--maxw); margin:0 auto; padding:0 28px; }
section{ position:relative; }
.section-pad{ padding:96px 0; }
.eyebrow{
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--font-en); font-weight:700; font-size:13px; letter-spacing:.16em;
  text-transform:uppercase; color:var(--accent);
}
.eyebrow::before{ content:""; width:26px; height:2px; background:var(--accent); }
.kicker-kr{ font-size:14px; font-weight:700; color:var(--kr-red); letter-spacing:.02em; }
.sec-title{
  font-size:clamp(30px,3.4vw,44px); font-weight:800; line-height:1.14;
  letter-spacing:-.02em; margin:14px 0 0;
}
.sec-title .hl{ color:var(--kr-red); }
.sec-sub{ margin:16px 0 0; color:var(--neutral-600); font-size:17px; max-width:640px; }
.center{ text-align:center; }
.center .eyebrow{ justify-content:center; }
.center .sec-sub{ margin-left:auto; margin-right:auto; }

/* ---------- top nav ---------- */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:100;
  height:72px; display:flex; align-items:center;
  background:rgba(14,18,32,0);
  transition:background .3s ease, box-shadow .3s ease, height .3s ease;
}
.nav.solid{ background:rgba(13,16,28,.92); backdrop-filter:blur(12px); box-shadow:0 1px 0 rgba(255,255,255,.06); height:66px; }
.nav .wrap{ display:flex; align-items:center; gap:24px; }
.brand{ display:flex; align-items:center; gap:11px; color:#fff; font-weight:800; letter-spacing:-.01em; }
.brand .mark{
  width:34px; height:34px; border-radius:9px; display:grid; place-items:center;
  background:var(--kr-red); color:#fff; font-family:var(--font-poster); font-size:19px; line-height:1;
  box-shadow:0 4px 14px rgba(215,24,42,.45);
}
.brand .mark span{ transform:translateY(1px); }
.brand b{ font-size:16px; }
.brand small{ display:block; font-size:11px; font-weight:600; color:rgba(255,255,255,.6); letter-spacing:.02em; }
.nav-links{ display:flex; gap:4px; margin-left:auto; }
.nav-links a{
  padding:9px 14px; border-radius:999px; font-size:14.5px; font-weight:600; white-space:nowrap;
  color:rgba(255,255,255,.78); transition:color .15s, background .15s;
}
.nav-links a:hover{ color:#fff; background:rgba(255,255,255,.1); }
.nav-cta{
  margin-left:6px; display:inline-flex; align-items:center; gap:8px; white-space:nowrap;
  padding:10px 18px; border-radius:999px; font-weight:700; font-size:14.5px;
  background:var(--kr-red); color:#fff; box-shadow:0 6px 18px rgba(215,24,42,.4);
  transition:transform .15s, box-shadow .15s, background .15s;
}
.nav-cta:hover{ transform:translateY(-1px); background:var(--kr-red-600); box-shadow:0 10px 24px rgba(215,24,42,.5); }

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:9px;
  padding:15px 28px; border-radius:999px; font-weight:700; font-size:16px; white-space:nowrap;
  cursor:pointer; border:none; transition:transform .15s, box-shadow .15s, background .15s, color .15s;
}
.btn-red{ background:var(--kr-red); color:#fff; box-shadow:0 10px 26px rgba(215,24,42,.4); }
.btn-red:hover{ transform:translateY(-2px); background:var(--kr-red-600); box-shadow:0 16px 34px rgba(215,24,42,.5); }
.btn-ghost{ background:rgba(255,255,255,.08); color:#fff; border:1.5px solid rgba(255,255,255,.28); }
.btn-ghost:hover{ background:rgba(255,255,255,.16); transform:translateY(-2px); }
.btn-dark{ background:var(--ink); color:#fff; }
.btn-dark:hover{ background:#000; transform:translateY(-2px); }
.btn-lg{ padding:18px 36px; font-size:18px; }

/* ---------- pills / chips ---------- */
.chip{
  display:inline-flex; align-items:center; gap:8px;
  padding:9px 16px; border-radius:999px; font-size:14.5px; font-weight:600;
}
.chip-glass{ background:rgba(255,255,255,.1); border:1px solid rgba(255,255,255,.22); color:#fff; backdrop-filter:blur(6px); }
.chip-ico{ font-size:15px; opacity:.9; }
.badge-gift{
  display:inline-flex; align-items:center; gap:6px;
  padding:6px 13px; border-radius:999px; font-size:13px; font-weight:700;
  background:var(--orange); color:#fff;
}
.badge-soft{
  display:inline-flex; align-items:center; gap:6px;
  padding:5px 12px; border-radius:999px; font-size:12.5px; font-weight:700;
  background:var(--kr-red-soft); color:var(--kr-red-700);
}

/* ================= HERO ================= */
.hero{ position:relative; min-height:100vh; display:flex; align-items:center; overflow:hidden; background:var(--ink); }
.hero-bg{ position:absolute; inset:0; z-index:0; }
.hero-bg img{ width:100%; height:100%; object-fit:cover; }
.hero-grad{ position:absolute; inset:0; z-index:1; }
.hero-noise{ position:absolute; inset:0; z-index:1; opacity:.5; mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.5'/%3E%3C/svg%3E"); }
.hero .wrap{ position:relative; z-index:3; width:100%; }

.hero-inner{ display:grid; grid-template-columns:1.05fr .95fr; gap:48px; align-items:center; padding-top:90px; padding-bottom:60px; }
.hero-copy{ max-width:600px; }
.hero-slogan{ font-size:13px; font-weight:700; letter-spacing:.18em; text-transform:uppercase; color:#fff; opacity:.78; font-family:var(--font-en); }
.hero h1{
  margin:18px 0 0; color:#fff; font-weight:800; letter-spacing:-.03em;
  font-size:clamp(40px,6vw,74px); line-height:1.02;
}
.hero h1 .red{ color:#fff; }
.hero h1 .stroke{
  font-family:var(--font-poster); -webkit-text-stroke:2px rgba(255,255,255,.85); color:transparent;
  letter-spacing:.01em;
}
.hero .lead{ margin:22px 0 0; color:rgba(255,255,255,.84); font-size:18px; line-height:1.65; max-width:520px; }
.hero-meta{ display:flex; flex-wrap:wrap; gap:10px; margin-top:26px; }
.hero-actions{ display:flex; flex-wrap:wrap; gap:14px; margin-top:34px; }

/* hero side card / countdown */
.hero-card{
  background:rgba(13,16,28,.55); border:1px solid rgba(255,255,255,.14);
  border-radius:22px; padding:28px; backdrop-filter:blur(14px);
  box-shadow:0 30px 70px rgba(0,0,0,.4);
}
.hero-card .vs-row{ display:flex; align-items:center; justify-content:space-between; gap:12px; }
.team{ display:flex; flex-direction:column; align-items:center; gap:10px; flex:1; }
.flag{
  width:84px; height:58px; border-radius:8px; overflow:hidden; box-shadow:0 6px 18px rgba(0,0,0,.35);
  display:grid; place-items:center; background:#fff;
}
.flag svg{ width:100%; height:100%; display:block; }
.team b{ color:#fff; font-size:18px; white-space:nowrap; }
.team small{ color:rgba(255,255,255,.55); font-family:var(--font-en); font-size:11px; letter-spacing:.1em; white-space:nowrap; }
.vs-mid{ display:flex; flex-direction:column; align-items:center; gap:6px; }
.vs-mid .vs{ font-family:var(--font-poster); font-size:34px; color:var(--kr-red); line-height:1; }
.vs-mid .grp{ font-size:11px; color:rgba(255,255,255,.6); font-weight:600; }
.hero-card .divider{ height:1px; background:rgba(255,255,255,.12); margin:22px 0; }

.countdown-label{ font-size:12px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:rgba(255,255,255,.6); font-family:var(--font-en); text-align:center; }
.countdown{ display:flex; justify-content:center; gap:10px; margin-top:12px; }
.cd-unit{ background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.12); border-radius:12px; padding:12px 0; width:64px; text-align:center; }
.cd-unit b{ display:block; font-family:var(--font-en); font-weight:700; font-size:30px; color:#fff; line-height:1; font-variant-numeric:tabular-nums; }
.cd-unit span{ display:block; margin-top:6px; font-size:11px; color:rgba(255,255,255,.55); font-weight:600; }

.hero-scroll{ position:absolute; left:50%; bottom:26px; transform:translateX(-50%); z-index:3; color:rgba(255,255,255,.6); font-size:12px; letter-spacing:.2em; text-transform:uppercase; font-family:var(--font-en); display:flex; flex-direction:column; align-items:center; gap:8px; }
.hero-scroll .mouse{ width:22px; height:34px; border:2px solid rgba(255,255,255,.4); border-radius:12px; position:relative; }
.hero-scroll .mouse::after{ content:""; position:absolute; left:50%; top:7px; width:3px; height:7px; background:#fff; border-radius:2px; transform:translateX(-50%); animation:scrolly 1.6s infinite; }
@keyframes scrolly{ 0%{ opacity:0; transform:translate(-50%,0);} 40%{opacity:1;} 80%{opacity:0; transform:translate(-50%,9px);} }

/* hero variant B (typographic) */
.hero[data-variant="b"] .hero-inner{ grid-template-columns:1fr; text-align:center; place-items:center; }
.hero[data-variant="b"] .hero-copy{ max-width:880px; }
.hero[data-variant="b"] .hero-meta{ justify-content:center; }
.hero[data-variant="b"] .hero-actions{ justify-content:center; }
.hero[data-variant="b"] .hero-side{ display:none; }
.hero[data-variant="b"] h1{ font-size:clamp(48px,8vw,104px); }

/* hero variant C (split card forward) handled by default grid + bg swap */
.hero[data-variant="c"] .hero-noise{ opacity:.3; }

/* ================= generic card grid ================= */
.cards-3{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-top:44px; }
.info-card{
  background:#fff; border:1px solid var(--neutral-100); border-radius:var(--radius);
  padding:30px; box-shadow:var(--shadow-card); position:relative; overflow:hidden;
  transition:transform .2s, box-shadow .2s;
}
.info-card:hover{ transform:translateY(-4px); box-shadow:var(--shadow-lift); }
.info-card .ic{ width:50px; height:50px; border-radius:13px; display:grid; place-items:center; font-size:24px; margin-bottom:18px; }
.info-card h3{ margin:0 0 6px; font-size:20px; font-weight:800; }
.info-card .big{ font-family:var(--font-en); font-weight:700; font-size:22px; letter-spacing:-.01em; }
.info-card p{ margin:6px 0 0; color:var(--neutral-600); font-size:15px; }
.ic-red{ background:var(--kr-red-soft); color:var(--kr-red); }
.ic-jade{ background:#E0F7F7; color:var(--jade-700); }
.ic-orange{ background:#FFF4E6; color:var(--orange-700); }
.card-tab{ position:absolute; top:0; left:0; width:100%; height:4px; }

/* ================= match section ================= */
.match{ background:var(--ink); color:#fff; }
.match .sec-title{ color:#fff; }
.match .sec-sub{ color:rgba(255,255,255,.7); }
.match-grid{ display:grid; grid-template-columns:1fr 1fr; gap:40px; align-items:center; margin-top:48px; }
.match-vs{
  background:linear-gradient(160deg,rgba(255,255,255,.07),rgba(255,255,255,.02));
  border:1px solid rgba(255,255,255,.12); border-radius:24px; padding:38px;
}
.match-vs .teams{ display:flex; align-items:center; justify-content:space-between; gap:16px; }
.match-vs .flag{ width:108px; height:74px; }
.match-vs .team b{ font-size:22px; margin-top:4px; }
.match-vs .vs{ font-family:var(--font-poster); font-size:50px; color:var(--kr-red); }
.match-facts{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; margin-top:32px; background:rgba(255,255,255,.1); border-radius:14px; overflow:hidden; }
.fact{ background:var(--ink-2); padding:18px 14px; text-align:center; }
.fact .lab{ font-size:12px; color:rgba(255,255,255,.55); font-weight:600; }
.fact .val{ font-size:16px; font-weight:700; margin-top:6px; }
.fact .val.en{ font-family:var(--font-en); }

/* compare table (GS data-table flavor on dark) */
.compare{ width:100%; border-collapse:collapse; border-radius:14px; overflow:hidden; border:1px solid rgba(255,255,255,.12); }
.compare th, .compare td{ padding:13px 16px; font-size:15px; }
.compare thead th{ background:var(--forest); color:#fff; font-weight:700; font-size:13px; letter-spacing:.02em; }
.compare thead th.kr{ background:var(--kr-red-700); }
.compare tbody td{ border-top:1px solid rgba(255,255,255,.08); color:rgba(255,255,255,.92); text-align:center; }
.compare tbody td.metric{ text-align:left; color:rgba(255,255,255,.6); font-weight:600; font-size:13px; }
.compare tbody tr:nth-child(even) td{ background:rgba(255,255,255,.03); }
.compare .win{ color:#fff; font-weight:800; }
.compare .win::after{ content:" ▲"; color:var(--kr-red); font-size:11px; }
.win-prob{ display:flex; height:14px; border-radius:999px; overflow:hidden; margin-top:8px; font-size:0; }
.win-prob i{ display:block; height:100%; }

/* ================= dress code ================= */
.dress{ background:linear-gradient(135deg,var(--kr-red) 0%,var(--kr-red-700) 100%); color:#fff; overflow:hidden; }
.dress::before{ content:""; position:absolute; right:-120px; top:-120px; width:420px; height:420px; border-radius:50%; background:rgba(255,255,255,.07); }
.dress::after{ content:""; position:absolute; left:-80px; bottom:-140px; width:340px; height:340px; border-radius:50%; background:rgba(0,0,0,.08); }
.dress .wrap{ position:relative; z-index:2; }
.dress-grid{ display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:center; }
.dress .eyebrow{ color:#fff; }
.dress .eyebrow::before{ background:#fff; }
.dress h2{ font-size:clamp(30px,3.6vw,46px); font-weight:800; margin:14px 0 0; letter-spacing:-.02em; }
.dress p.big{ font-size:19px; margin-top:18px; line-height:1.6; }
.dress .must{ font-weight:800; background:#fff; color:var(--kr-red); padding:0 8px; border-radius:6px; }
.dress-examples{ display:flex; flex-wrap:wrap; gap:10px; margin-top:24px; }
.ex-pill{ display:inline-flex; align-items:center; gap:8px; padding:10px 16px; border-radius:999px; background:rgba(255,255,255,.14); border:1px solid rgba(255,255,255,.25); font-weight:600; font-size:15px; white-space:nowrap; flex-shrink:0; }
.ex-pill svg{ flex-shrink:0; display:block; background:#fff; border-radius:50%; padding:3px; box-sizing:content-box; width:16px; height:16px; }
.dv-item.jersey{ background:rgba(255,255,255,.14); }
.dv-item.jersey svg{ width:74%; height:auto; filter:drop-shadow(0 12px 24px rgba(0,0,0,.32)); }
.dress-note{ margin-top:26px; display:flex; gap:12px; align-items:flex-start; background:rgba(0,0,0,.18); border-left:4px solid #fff; border-radius:0 12px 12px 0; padding:16px 20px; font-size:14.5px; }
.dress-visual{ display:grid; grid-template-columns:repeat(2,1fr); grid-template-rows:repeat(2,1fr); gap:14px; }
.dv-item{ border-radius:18px; overflow:hidden; aspect-ratio:1; box-shadow:0 16px 40px rgba(0,0,0,.3); background:rgba(255,255,255,.1); display:grid; place-items:center; }
.dv-item img{ width:100%; height:100%; object-fit:cover; }
.dv-item.big-emoji{ font-size:62px; background:rgba(255,255,255,.12); }

/* ================= prediction events ================= */
.predict{ background:var(--neutral-50); }
.pred-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:20px; margin-top:48px; }
.pred-card{
  background:#fff; border:1px solid var(--neutral-100); border-radius:18px; padding:26px 28px;
  display:flex; gap:20px; align-items:flex-start; box-shadow:var(--shadow-card);
  transition:transform .2s, box-shadow .2s, border-color .2s;
}
.pred-card:hover{ transform:translateY(-4px); box-shadow:var(--shadow-lift); border-color:var(--kr-red); }
.pred-card.span2{ grid-column:span 2; align-items:center; background:linear-gradient(120deg,#fff,var(--kr-red-soft)); }
.pred-num{ flex-shrink:0; width:54px; height:54px; border-radius:14px; background:var(--ink); color:#fff; font-family:var(--font-poster); font-size:26px; display:grid; place-items:center; }
.pred-card:hover .pred-num{ background:var(--kr-red); }
.pred-body{ flex:1; }
.pred-body h3{ margin:2px 0 0; font-size:20px; font-weight:800; }
.pred-eg{ margin:8px 0 0; color:var(--neutral-600); font-size:14.5px; }
.pred-eg b{ color:var(--neutral-900); }
.pred-foot{ margin-top:16px; }

/* ================= toto form ================= */
.toto{ background:var(--ink); color:#fff; }
.toto-shell{ display:grid; grid-template-columns:1fr 1fr; gap:0; margin-top:48px; border-radius:24px; overflow:hidden; box-shadow:0 30px 70px rgba(0,0,0,.4); }
.toto-aside{ background:linear-gradient(160deg,var(--kr-red),var(--kr-red-700)); padding:48px; display:flex; flex-direction:column; }
.toto-aside h3{ font-size:30px; font-weight:800; margin:14px 0 0; letter-spacing:-.02em; }
.toto-aside p{ color:rgba(255,255,255,.85); margin-top:14px; font-size:15.5px; line-height:1.6; }
.toto-steps{ margin-top:26px; display:flex; flex-direction:column; gap:14px; }
.toto-step{ display:flex; gap:12px; align-items:center; font-size:15px; }
.toto-step i{ width:28px; height:28px; border-radius:50%; background:rgba(255,255,255,.2); display:grid; place-items:center; font-style:normal; font-weight:700; font-size:13px; flex-shrink:0; }
.toto-form{ background:#fff; color:var(--neutral-900); padding:44px; }
.toto-form .fhead{ display:flex; align-items:center; justify-content:space-between; }
.toto-form .fhead b{ font-size:18px; }
.field{ margin-top:18px; }
.field label{ display:block; font-size:14px; font-weight:700; margin-bottom:8px; }
.field label .q{ color:var(--kr-red); font-family:var(--font-en); margin-right:6px; }
.score-row{ display:flex; align-items:center; gap:12px; }
.score-row .tname{ font-weight:700; font-size:14px; width:64px; }
.num-in{ width:62px; }
.score-sep{ font-weight:800; color:var(--neutral-400); }
input.fin, select.fin{
  width:100%; padding:12px 14px; border:1.5px solid var(--neutral-200); border-radius:10px;
  font-family:var(--font); font-size:15px; color:var(--neutral-900); background:#fff; transition:border-color .15s, box-shadow .15s;
}
input.fin:focus, select.fin:focus{ outline:none; border-color:var(--kr-red); box-shadow:0 0 0 3px rgba(215,24,42,.14); }
.toto-form .submit-row{ margin-top:26px; display:flex; flex-direction:column; gap:10px; }
.toto-hint{ font-size:13px; color:var(--neutral-400); text-align:center; }
.toto-hint a{ color:var(--jade-700); font-weight:700; text-decoration:underline; }

/* ================= king / award ================= */
.king{ background:linear-gradient(135deg,#0E1220,#161B2B); color:#fff; text-align:center; overflow:hidden; }
.king::before{ content:""; position:absolute; inset:0; background:radial-gradient(circle at 50% 0%, rgba(233,185,73,.18), transparent 55%); }
.king .wrap{ position:relative; z-index:2; }
.crown{ font-size:64px; filter:drop-shadow(0 8px 24px rgba(233,185,73,.5)); }
.king h2{ font-size:clamp(32px,4vw,52px); font-weight:800; margin:18px 0 0; letter-spacing:-.02em; }
.king .king-name{ background:linear-gradient(90deg,var(--gold),#FFD77A); -webkit-background-clip:text; background-clip:text; color:transparent; }
.king p{ color:rgba(255,255,255,.78); font-size:18px; margin-top:18px; max-width:620px; margin-left:auto; margin-right:auto; }
.king-prize{ display:inline-flex; flex-direction:column; align-items:center; gap:4px; margin-top:34px; padding:24px 44px; border-radius:20px; border:1px solid rgba(233,185,73,.4); background:rgba(233,185,73,.08); }
.king-prize b{ font-size:22px; color:var(--gold); }
.king-prize small{ color:rgba(255,255,255,.6); }

/* ================= map / location ================= */
.loc-grid{ display:grid; grid-template-columns:1fr 1fr; gap:44px; align-items:center; margin-top:48px; }
.loc-photos{ display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.loc-photos .big{ grid-column:span 2; }
.loc-photos figure{ margin:0; border-radius:16px; overflow:hidden; box-shadow:var(--shadow-card); aspect-ratio:16/10; }
.loc-photos .big figure, .loc-photos figure.big{ aspect-ratio:16/8; }
.loc-photos img{ width:100%; height:100%; object-fit:cover; transition:transform .4s; }
.loc-photos figure:hover img{ transform:scale(1.05); }
.loc-info .addr{ display:flex; gap:14px; align-items:flex-start; margin-top:8px; }
.loc-info .addr .pin{ width:44px; height:44px; border-radius:12px; background:var(--kr-red-soft); color:var(--kr-red); display:grid; place-items:center; font-size:20px; flex-shrink:0; }
.loc-detail-list{ list-style:none; padding:0; margin:24px 0 0; }
.loc-detail-list li{ display:flex; gap:12px; padding:14px 0; border-bottom:1px solid var(--neutral-100); font-size:15.5px; }
.loc-detail-list li b{ width:90px; color:var(--neutral-600); font-weight:600; flex-shrink:0; }
.map-embed{ margin-top:22px; border-radius:14px; overflow:hidden; border:1px solid var(--neutral-200); }
.map-embed iframe{ width:100%; height:260px; border:0; display:block; }

/* ================= footer ================= */
.foot{ background:var(--ink); color:#fff; padding:64px 0 40px; text-align:center; }
.foot .cheer{ font-family:var(--font-poster); font-size:clamp(40px,7vw,90px); color:transparent; -webkit-text-stroke:2px rgba(255,255,255,.7); letter-spacing:.04em; }
.foot .cheer b{ color:var(--kr-red); -webkit-text-stroke:0; }
.foot .sub{ color:rgba(255,255,255,.6); margin-top:18px; font-size:15px; }
.foot .divider{ height:1px; background:rgba(255,255,255,.12); margin:40px 0 24px; }
.foot .meta{ color:rgba(255,255,255,.4); font-size:13px; }

/* reveal animation */
.reveal{ opacity:0; transform:translateY(28px); transition:opacity .7s cubic-bezier(.2,.7,.2,1), transform .7s cubic-bezier(.2,.7,.2,1); }
.reveal.in{ opacity:1; transform:none; }
@media (prefers-reduced-motion: reduce){ .reveal{ opacity:1; transform:none; transition:none; } }

/* ---------- responsive ---------- */
@media (max-width:980px){
  .hero-inner{ grid-template-columns:1fr; }
  .hero-side{ display:none; }
  .match-grid, .dress-grid, .toto-shell, .loc-grid{ grid-template-columns:1fr; }
  .cards-3{ grid-template-columns:1fr; }
  .pred-grid{ grid-template-columns:1fr; }
  .pred-card.span2{ grid-column:auto; }
  .nav-links{ display:none; }
}
@media (max-width:560px){
  .section-pad{ padding:64px 0; }
  .wrap{ padding:0 18px; }
  .toto-aside, .toto-form{ padding:30px; }
}
