/* =========================================================
   Brazil Day ATX — Festa do 07 · Sponsorship Landing Page
   Cultura Brasil Austin (CBA)
   ========================================================= */

:root{
  /* Brand palette */
  --navy:#071B4D;
  --navy-2:#0c2a6b;
  --navy-deep:#04102f;
  --green:#1FA64A;
  --green-2:#41C96B;
  --yellow:#F4C430;
  --yellow-deep:#e0ad14;
  --white:#FFFFFF;
  --cream:#FFF8E8;
  --cream-2:#fffdf6;
  --ink:#101828;
  --muted:#5a6172;

  /* Gradients */
  --grad-gold:linear-gradient(135deg,#F4C430 0%,#ffd755 50%,#e0ad14 100%);
  --grad-green:linear-gradient(135deg,#1FA64A 0%,#41C96B 100%);
  --grad-flag:linear-gradient(90deg,var(--green),var(--yellow),var(--green-2));

  /* Type */
  --f-display:"Anton",system-ui,sans-serif;
  --f-head:"Oswald",system-ui,sans-serif;
  --f-body:"Inter",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;

  /* Layout */
  --maxw:1200px;
  --radius:18px;
  --radius-sm:12px;
  --shadow-sm:0 4px 14px rgba(7,27,77,.08);
  --shadow:0 18px 50px -18px rgba(7,27,77,.35);
  --shadow-lg:0 40px 90px -30px rgba(7,27,77,.5);
  --header-h:74px;
  --ease:cubic-bezier(.2,.7,.2,1);
}

/* ---------- Language toggle visibility ---------- */
[data-lang="en"] [lang="pt"],
[data-lang="pt"] [lang="en"]{ display:none !important; }

/* ---------- Reset / base ---------- */
*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  margin:0;
  font-family:var(--f-body);
  color:var(--ink);
  background:var(--cream);
  line-height:1.6;
  font-size:17px;
  overflow-x:hidden;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
ul{ margin:0; padding:0; list-style:none; }
button{ font-family:inherit; cursor:pointer; }
h1,h2,h3,h4{ margin:0; line-height:1.05; }
:focus-visible{ outline:3px solid var(--green-2); outline-offset:3px; border-radius:6px; }

.container{ width:100%; max-width:var(--maxw); margin:0 auto; padding:0 24px; }
.container--narrow{ max-width:820px; }

.skip-link{
  position:absolute; left:-9999px; top:0; z-index:2000;
  background:var(--navy); color:#fff; padding:12px 20px; border-radius:0 0 12px 0;
}
.skip-link:focus{ left:0; }

[hidden]{ display:none !important; }

/* SVG icon defaults (stroke style) */
.ic{ width:1.15em; height:1.15em; fill:none; stroke:currentColor; stroke-width:1.8;
  stroke-linecap:round; stroke-linejoin:round; flex:none; }

/* ---------- Buttons ---------- */
.btn{
  --b:var(--navy);
  display:inline-flex; align-items:center; justify-content:center; gap:.5em;
  font-family:var(--f-head); font-weight:600; letter-spacing:.04em; text-transform:uppercase;
  font-size:.93rem; padding:15px 30px; border-radius:999px; border:2px solid transparent;
  transition:transform .25s var(--ease), box-shadow .3s var(--ease), background .25s, color .25s;
  white-space:nowrap; line-height:1;
}
.btn:hover{ transform:translateY(-3px); }
.btn:active{ transform:translateY(-1px); }
.btn-primary{ background:var(--grad-gold); color:var(--navy); box-shadow:0 12px 28px -10px rgba(244,196,48,.7); }
.btn-primary:hover{ box-shadow:0 18px 38px -10px rgba(244,196,48,.85); }
.btn-ghost{ background:rgba(255,255,255,.08); color:#fff; border-color:rgba(255,255,255,.55); backdrop-filter:blur(6px); }
.btn-ghost:hover{ background:rgba(255,255,255,.16); border-color:#fff; }
.btn-outline{ background:transparent; color:var(--navy); border-color:var(--navy); }
.btn-outline:hover{ background:var(--navy); color:#fff; }
.btn-sm{ padding:11px 20px; font-size:.82rem; }
.btn-lg{ padding:19px 42px; font-size:1.05rem; }
.btn-block{ width:100%; }
.btn-glow{ position:relative; }
.btn-glow::after{
  content:""; position:absolute; inset:-2px; border-radius:999px; z-index:-1;
  background:var(--grad-gold); filter:blur(16px); opacity:.55; animation:pulseGlow 3.2s ease-in-out infinite;
}
@keyframes pulseGlow{ 0%,100%{ opacity:.35; } 50%{ opacity:.7; } }

/* ---------- Section scaffolding ---------- */
.section{ padding:96px 0; position:relative; }
section[id]{ scroll-margin-top:90px; }
.section-head{ max-width:780px; margin:0 auto 56px; text-align:center; }
.section-head--light{ color:#fff; }
.eyebrow{
  display:inline-block; font-family:var(--f-head); font-weight:600; letter-spacing:.22em;
  text-transform:uppercase; font-size:.8rem; color:var(--green);
  padding:7px 16px; border-radius:999px; background:rgba(31,166,74,.1); margin-bottom:18px;
}
.eyebrow--light{ color:var(--yellow); background:rgba(244,196,48,.14); }
.section-title{
  font-family:var(--f-display); font-weight:400; letter-spacing:.01em;
  font-size:clamp(2rem,4.6vw,3.4rem); color:var(--navy); line-height:1.02; text-transform:uppercase;
}
.section-head--light .section-title{ color:#fff; }
.section-lead{ margin:20px auto 0; font-size:1.1rem; color:var(--muted); max-width:680px; }
.section-head--light .section-lead{ color:rgba(255,255,255,.82); }

/* =========================================================
   HEADER
   ========================================================= */
.site-header{
  position:fixed; top:0; left:0; right:0; z-index:1000; height:var(--header-h);
  display:flex; align-items:center;
  transition:background .35s var(--ease), box-shadow .35s var(--ease), backdrop-filter .35s;
}
.site-header.scrolled{
  background:rgba(7,27,77,.92); backdrop-filter:blur(12px) saturate(140%);
  box-shadow:0 8px 30px -12px rgba(0,0,0,.5);
}
.header-inner{ display:flex; align-items:center; justify-content:space-between; gap:18px; }
.brand{ display:flex; align-items:center; gap:12px; min-width:0; }
.brand-logo{ height:42px; width:auto; }
.brand-text{ font-family:var(--f-head); font-weight:700; color:#fff; font-size:1rem; letter-spacing:.04em;
  text-shadow:0 1px 10px rgba(0,0,0,.4); white-space:nowrap; }
.brand-sep{ color:var(--yellow); margin:0 2px; }
.brand-sub{ font-weight:500; opacity:.9; }

.main-nav{ display:flex; align-items:center; gap:30px; margin-left:auto; }
.nav-link{
  font-family:var(--f-head); font-weight:500; color:#fff; letter-spacing:.05em; text-transform:uppercase;
  font-size:.92rem; position:relative; padding:6px 0; text-shadow:0 1px 8px rgba(0,0,0,.4); transition:color .2s;
}
.nav-link::after{ content:""; position:absolute; left:0; right:100%; bottom:0; height:2px;
  background:var(--grad-flag); transition:right .3s var(--ease); }
.nav-link:hover{ color:var(--yellow); }
.nav-link:hover::after{ right:0; }
.mobile-menu{ display:none; }

.header-right{ display:flex; align-items:center; gap:14px; }
.lang-toggle{ display:flex; align-items:center; gap:4px; padding:5px 10px; border-radius:999px;
  background:rgba(255,255,255,.1); border:1px solid rgba(255,255,255,.2); }
.lang-btn{ background:none; border:none; color:rgba(255,255,255,.65); font-family:var(--f-head);
  font-weight:600; font-size:.82rem; letter-spacing:.08em; padding:3px 6px; border-radius:6px; transition:color .2s; }
.lang-btn.is-active{ color:var(--yellow); }
.lang-btn:hover{ color:#fff; }
.lang-divider{ color:rgba(255,255,255,.4); font-size:.8rem; }

.nav-toggle{ display:none; flex-direction:column; gap:5px; width:44px; height:44px; border:none;
  background:rgba(255,255,255,.1); border-radius:12px; align-items:center; justify-content:center; }
.nav-toggle span{ width:22px; height:2px; background:#fff; border-radius:2px; transition:.3s var(--ease); }

/* =========================================================
   HERO
   ========================================================= */
.hero{
  position:relative; min-height:100svh; display:flex; align-items:center;
  padding:calc(var(--header-h) + 40px) 0 90px; overflow:hidden; color:#fff;
}
.hero-media{ position:absolute; inset:0; z-index:0; }
.hero-img{ width:100%; height:120%; object-fit:cover; will-change:transform; }
.hero-overlay{ position:absolute; inset:0;
  background:
    radial-gradient(120% 90% at 80% 0%, rgba(31,166,74,.32), transparent 55%),
    radial-gradient(120% 80% at 0% 100%, rgba(244,196,48,.20), transparent 50%),
    linear-gradient(180deg, rgba(4,16,47,.78) 0%, rgba(4,16,47,.55) 35%, rgba(4,16,47,.86) 100%);
}
.hero-flagline{ position:absolute; left:0; right:0; bottom:0; height:7px; background:var(--grad-flag);
  background-size:200% 100%; animation:flagShift 7s linear infinite; }
@keyframes flagShift{ to{ background-position:200% 0; } }

.hero-content{ position:relative; z-index:2; max-width:880px; }
.badge{
  display:inline-flex; align-items:center; gap:8px; font-family:var(--f-head); font-weight:600;
  letter-spacing:.18em; text-transform:uppercase; font-size:.8rem; color:var(--navy);
  background:var(--grad-gold); padding:9px 18px; border-radius:999px;
  box-shadow:0 10px 30px -10px rgba(244,196,48,.6); margin-bottom:26px;
}
.hero-title{
  font-family:var(--f-display); font-weight:400; text-transform:uppercase; letter-spacing:.005em;
  font-size:clamp(2.4rem,6.2vw,5rem); line-height:.98; text-wrap:balance;
  text-shadow:0 4px 40px rgba(0,0,0,.4);
}
.hero-title span[lang]{ display:block; }
.hero-sub{ font-size:clamp(1.05rem,1.8vw,1.3rem); max-width:680px; margin:24px 0 0; color:rgba(255,255,255,.92); }
.hero-meta{ display:inline-flex; align-items:center; gap:10px; margin:22px 0 0; font-family:var(--f-head);
  font-weight:500; letter-spacing:.04em; color:var(--yellow); font-size:1.02rem; }
.hero-meta .ic{ stroke:var(--yellow); }
.hero-cta{ display:flex; flex-wrap:wrap; gap:16px; margin:34px 0 0; }
.hero-trust{
  margin:30px 0 0; padding-top:24px; border-top:1px solid rgba(255,255,255,.18);
  font-size:.96rem; color:rgba(255,255,255,.8); max-width:680px; letter-spacing:.01em;
}

.hero-scroll{ position:absolute; left:50%; bottom:26px; transform:translateX(-50%); z-index:2;
  width:28px; height:46px; border:2px solid rgba(255,255,255,.55); border-radius:16px; }
.hero-scroll span{ position:absolute; left:50%; top:8px; width:5px; height:5px; border-radius:50%;
  background:var(--yellow); transform:translateX(-50%); animation:scrollDot 1.8s infinite; }
@keyframes scrollDot{ 0%{ opacity:0; top:8px; } 30%{ opacity:1; } 70%{ opacity:1; top:26px; } 100%{ opacity:0; top:26px; } }

/* =========================================================
   PROOF BAR
   ========================================================= */
.proof{ background:linear-gradient(160deg,var(--navy) 0%, var(--navy-deep) 100%); padding:64px 0; position:relative; }
.proof::before{ content:""; position:absolute; inset:0; opacity:.5;
  background:radial-gradient(60% 100% at 50% 0%, rgba(31,166,74,.18), transparent 70%); }
.proof-grid{ position:relative; display:grid; grid-template-columns:repeat(5,1fr); gap:18px; }
.proof-card{
  background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.12); border-radius:var(--radius);
  padding:30px 20px; text-align:center; backdrop-filter:blur(8px);
  transition:transform .35s var(--ease), border-color .35s, background .35s;
}
.proof-card:hover{ transform:translateY(-6px); border-color:rgba(244,196,48,.5); background:rgba(255,255,255,.1); }
.proof-num{ font-family:var(--f-display); font-weight:400; color:var(--yellow);
  font-size:clamp(1.7rem,2.7vw,2.5rem); line-height:1; letter-spacing:.01em; }
.proof-num--sm{ font-family:var(--f-head); font-weight:700; font-size:1.15rem; color:#fff;
  text-transform:uppercase; letter-spacing:.03em; line-height:1.2; }
.proof-label{ margin-top:10px; color:rgba(255,255,255,.78); font-size:.9rem; font-weight:500; letter-spacing:.02em; }

/* =========================================================
   WHY SPONSOR
   ========================================================= */
.why{ background:var(--cream); }
.cards-4{ display:grid; grid-template-columns:repeat(4,1fr); gap:24px; }
.benefit-card{
  background:#fff; border-radius:var(--radius); padding:34px 28px; border:1px solid rgba(7,27,77,.06);
  box-shadow:var(--shadow-sm); transition:transform .35s var(--ease), box-shadow .35s; position:relative; overflow:hidden;
}
.benefit-card::before{ content:""; position:absolute; left:0; top:0; height:4px; width:100%; background:var(--grad-flag);
  transform:scaleX(0); transform-origin:left; transition:transform .4s var(--ease); }
.benefit-card:hover{ transform:translateY(-8px); box-shadow:var(--shadow); }
.benefit-card:hover::before{ transform:scaleX(1); }
.benefit-ic{ width:60px; height:60px; border-radius:16px; display:grid; place-items:center; margin-bottom:20px;
  background:linear-gradient(135deg, rgba(31,166,74,.14), rgba(244,196,48,.18)); color:var(--green); }
.benefit-ic svg{ width:30px; height:30px; fill:none; stroke:currentColor; stroke-width:1.7; stroke-linecap:round; stroke-linejoin:round; }
.benefit-card h3{ font-family:var(--f-head); font-weight:700; font-size:1.22rem; color:var(--navy); text-transform:uppercase; letter-spacing:.02em; margin-bottom:10px; }
.benefit-card p{ color:var(--muted); font-size:.97rem; margin:0; }

/* =========================================================
   EVENT / ABOUT
   ========================================================= */
.event{ background:var(--cream-2); }
.event-grid{ display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:center; }
.event-copy .section-title{ margin-bottom:20px; }
.event-copy > p{ color:var(--muted); font-size:1.05rem; }
.fact-list{ display:grid; gap:16px; margin-top:30px; }
.fact-list li{ display:flex; gap:14px; align-items:flex-start; }
.fact-list .ic{ width:24px; height:24px; stroke:var(--green); margin-top:3px; }
.fact-list strong{ display:block; font-family:var(--f-head); text-transform:uppercase; letter-spacing:.04em;
  color:var(--navy); font-size:.82rem; font-weight:600; }
.fact-list div span:not(.ic){ color:var(--ink); font-weight:500; }

.event-collage{ position:relative; display:grid; grid-template-columns:1fr 1fr; grid-template-rows:auto auto;
  gap:16px; }
.event-collage figure{ margin:0; border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow); }
.event-collage img{ width:100%; height:100%; object-fit:cover; }
.collage-main{ grid-column:1 / -1; aspect-ratio:16/10; }
.collage-2,.collage-3{ aspect-ratio:3/4; }
.collage-badge{ position:absolute; right:-14px; top:-22px; background:var(--grad-gold); color:var(--navy);
  width:96px; height:96px; border-radius:50%; display:grid; place-content:center; text-align:center;
  font-family:var(--f-head); font-weight:700; box-shadow:var(--shadow); transform:rotate(8deg); line-height:1; }
.collage-badge strong{ font-family:var(--f-display); font-size:2rem; }
.collage-badge span{ font-size:.62rem; text-transform:uppercase; letter-spacing:.08em; margin-top:2px; }

/* =========================================================
   AUDIENCE
   ========================================================= */
.audience{ background:var(--navy); color:#fff; overflow:hidden; }
.audience-bg{ position:absolute; inset:0; z-index:0;
  background:linear-gradient(180deg, rgba(7,27,77,.92), rgba(4,16,47,.96)), url("../img/audience-bg.webp") center/cover no-repeat;
}
.audience .container{ position:relative; z-index:1; }
.audience-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.aud-card{
  background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.12); border-left:4px solid var(--green-2);
  border-radius:var(--radius-sm); padding:22px 24px; font-weight:600; font-size:1.02rem;
  display:flex; align-items:center; transition:transform .3s var(--ease), background .3s, border-color .3s;
}
.aud-card:hover{ transform:translateX(6px); background:rgba(255,255,255,.1); border-left-color:var(--yellow); }
.aud-card--wide{ grid-column:span 3; border-left-color:var(--yellow); }
.pull-quote{
  margin:50px auto 0; max-width:860px; text-align:center; font-family:var(--f-display); font-weight:400;
  text-transform:uppercase; line-height:1.1; font-size:clamp(1.5rem,3.4vw,2.5rem); color:#fff; position:relative;
  padding:30px 20px;
}
.pull-quote::before{ content:"“"; font-family:var(--f-display); color:var(--yellow); font-size:4rem; display:block; line-height:.4; margin-bottom:18px; }

/* =========================================================
   HIGHLIGHTS
   ========================================================= */
.highlights{ background:var(--cream); }
.cards-3{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.hl-card{
  background:#fff; border-radius:var(--radius); padding:32px 28px; border:1px solid rgba(7,27,77,.06);
  box-shadow:var(--shadow-sm); transition:transform .35s var(--ease), box-shadow .35s;
}
.hl-card:hover{ transform:translateY(-8px); box-shadow:var(--shadow); }
.hl-ic{ width:54px; height:54px; border-radius:14px; display:grid; place-items:center; margin-bottom:18px;
  background:var(--grad-green); color:#fff; box-shadow:0 10px 24px -10px rgba(31,166,74,.7); }
.hl-ic svg{ width:28px; height:28px; fill:none; stroke:currentColor; stroke-width:1.7; stroke-linecap:round; stroke-linejoin:round; }
.hl-card h3{ font-family:var(--f-head); font-weight:700; text-transform:uppercase; letter-spacing:.02em;
  color:var(--navy); font-size:1.18rem; margin-bottom:8px; }
.hl-card p{ color:var(--muted); font-size:.96rem; margin:0; }

/* =========================================================
   BRAND VISIBILITY
   ========================================================= */
.visibility{ background:linear-gradient(160deg,var(--navy-2) 0%, var(--navy-deep) 100%); color:#fff; }
.vis-grid{ display:grid; grid-template-columns:repeat(5,1fr); gap:14px; }
.vis-item{ display:flex; align-items:center; gap:12px; padding:20px 18px; border-radius:var(--radius-sm);
  background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.12); font-weight:600; font-size:.96rem;
  transition:transform .3s var(--ease), background .3s; }
.vis-item:hover{ transform:translateY(-5px); background:rgba(244,196,48,.12); }
.vis-dot{ width:12px; height:12px; border-radius:50%; background:var(--grad-gold); flex:none; box-shadow:0 0 12px rgba(244,196,48,.7); }

/* =========================================================
   PACKAGES
   ========================================================= */
.packages{ background:var(--cream); }
.pkg-grid{ display:grid; grid-template-columns:1.15fr 1fr 1fr; gap:26px; align-items:start; }
.pkg-card{
  background:#fff; border-radius:22px; padding:36px 30px; border:1px solid rgba(7,27,77,.08);
  box-shadow:var(--shadow-sm); position:relative; display:flex; flex-direction:column; height:100%;
  transition:transform .35s var(--ease), box-shadow .35s;
}
.pkg-card:hover{ transform:translateY(-6px); box-shadow:var(--shadow); }
.pkg-gold{
  background:linear-gradient(180deg,#fffdf4,#fff); border:2px solid var(--yellow);
  box-shadow:0 40px 90px -34px rgba(244,196,48,.6); transform:translateY(-10px);
}
.pkg-gold:hover{ transform:translateY(-16px); }
.pkg-flag{ position:absolute; top:-15px; left:50%; transform:translateX(-50%); background:var(--grad-gold);
  color:var(--navy); font-family:var(--f-head); font-weight:700; text-transform:uppercase; letter-spacing:.08em;
  font-size:.74rem; padding:8px 20px; border-radius:999px; box-shadow:var(--shadow-sm); white-space:nowrap; }
.pkg-head{ text-align:center; padding-bottom:22px; border-bottom:1px dashed rgba(7,27,77,.15); margin-bottom:22px; }
.pkg-gold .pkg-head{ padding-top:8px; }
.pkg-name{ font-family:var(--f-display); font-weight:400; text-transform:uppercase; font-size:2rem; color:var(--navy); letter-spacing:.02em; }
.pkg-gold .pkg-name{ color:var(--yellow-deep); }
.pkg-tag{ margin:6px 0 0; font-family:var(--f-head); font-weight:500; text-transform:uppercase; letter-spacing:.06em;
  font-size:.82rem; color:var(--muted); }
.pkg-price{ font-family:var(--f-display); font-size:3.2rem; color:var(--navy); margin-top:14px; line-height:1; }
.pkg-gold .pkg-price{ color:var(--green); }
.pkg-price--talk{ font-family:var(--f-head); font-weight:700; font-size:1.7rem; text-transform:uppercase; color:var(--green); }
.pkg-list{ display:grid; gap:11px; margin-bottom:26px; flex:1; }
.pkg-list li{ position:relative; padding-left:30px; font-size:.94rem; color:var(--ink); line-height:1.45; }
.pkg-list li::before{ content:""; position:absolute; left:0; top:3px; width:18px; height:18px; border-radius:50%;
  background:var(--grad-green); }
.pkg-list li::after{ content:""; position:absolute; left:6px; top:8px; width:6px; height:3.5px;
  border-left:2px solid #fff; border-bottom:2px solid #fff; transform:rotate(-45deg); }
.pkg-custom{ background:linear-gradient(180deg,#0c2a6b,#071b4d); color:#fff; border:none; }
.pkg-custom .pkg-name,.pkg-custom .pkg-price--talk{ color:#fff; }
.pkg-custom .pkg-tag{ color:rgba(255,255,255,.7); }
.pkg-custom .pkg-head{ border-bottom-color:rgba(255,255,255,.2); }
.pkg-custom-body{ flex:1; }
.pkg-custom-body p{ color:rgba(255,255,255,.85); margin:0 0 26px; font-size:1.02rem; }
.pkg-custom .btn-outline{ color:#fff; border-color:var(--yellow); }
.pkg-custom .btn-outline:hover{ background:var(--yellow); color:var(--navy); }

/* =========================================================
   CATEGORIES
   ========================================================= */
.categories{ background:var(--cream-2); }
.cat-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:16px; max-width:980px; margin:0 auto; }
.cat-card{ display:flex; align-items:center; gap:14px; background:#fff; border:1px solid rgba(7,27,77,.07);
  border-radius:var(--radius-sm); padding:20px 24px; font-weight:600; color:var(--navy); box-shadow:var(--shadow-sm);
  transition:transform .3s var(--ease), border-color .3s; }
.cat-card::before{ content:""; width:10px; height:10px; border-radius:3px; background:var(--grad-gold); flex:none;
  transform:rotate(45deg); }
.cat-card:hover{ transform:translateX(6px); border-color:var(--green-2); }

/* =========================================================
   GALLERY
   ========================================================= */
.gallery{ background:var(--cream); padding-bottom:104px; }
.gallery-grid{ column-count:4; column-gap:14px; max-width:1280px; margin:0 auto; padding:0 24px; }
.g-item{ break-inside:avoid; margin:0 0 14px; border-radius:var(--radius-sm); overflow:hidden; position:relative;
  cursor:pointer; box-shadow:var(--shadow-sm); display:block; }
.g-item img{ width:100%; height:auto; transition:transform .6s var(--ease); }
.g-item::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,transparent 45%, rgba(7,27,77,.75));
  opacity:0; transition:opacity .35s; }
.g-item:hover img{ transform:scale(1.07); }
.g-item:hover::after{ opacity:1; }
.g-item figcaption{ position:absolute; left:16px; bottom:14px; z-index:2; color:#fff; font-family:var(--f-head);
  font-weight:600; text-transform:uppercase; letter-spacing:.1em; font-size:.95rem; opacity:0; transform:translateY(8px);
  transition:opacity .35s, transform .35s; text-shadow:0 2px 10px rgba(0,0,0,.5); }
.g-item:hover figcaption{ opacity:1; transform:translateY(0); }

/* =========================================================
   SPONSOR / FORM
   ========================================================= */
.sponsor{ background:linear-gradient(160deg,var(--navy) 0%, var(--navy-deep) 100%); color:#fff; }
.sponsor-grid{ display:grid; grid-template-columns:.92fr 1.08fr; gap:54px; align-items:start; }
.sponsor-intro .section-title{ margin:18px 0; color:#fff; }
.sponsor-subtitle{ color:rgba(255,255,255,.82); font-size:1.05rem; }
.contact-card{ margin-top:34px; background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.14);
  border-radius:var(--radius); padding:26px; }
.contact-card h3{ font-family:var(--f-head); font-weight:700; text-transform:uppercase; letter-spacing:.04em;
  font-size:1.05rem; color:var(--yellow); margin-bottom:16px; }
.contact-list{ display:grid; gap:14px; }
.contact-list li{ display:flex; align-items:center; gap:12px; font-weight:500; }
.contact-list .ic{ stroke:var(--green-2); width:20px; height:20px; }
.contact-list a:hover{ color:var(--yellow); }

.sponsor-formwrap{ background:#fff; border-radius:22px; padding:36px; box-shadow:var(--shadow-lg); color:var(--ink); }
.sponsor-form{ display:grid; gap:18px; }
.form-row{ display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.field{ display:flex; flex-direction:column; gap:7px; }
.field label{ font-family:var(--f-head); font-weight:600; font-size:.82rem; text-transform:uppercase;
  letter-spacing:.05em; color:var(--navy); }
.req{ color:var(--green); }
.field input,.field select,.field textarea{
  font-family:var(--f-body); font-size:.98rem; padding:13px 15px; border:1.5px solid #d7dbe4; border-radius:11px;
  background:#fbfcfe; color:var(--ink); transition:border-color .2s, box-shadow .2s; width:100%;
}
.field input:focus,.field select:focus,.field textarea:focus{ outline:none; border-color:var(--green);
  box-shadow:0 0 0 4px rgba(31,166,74,.15); }
.field input.invalid,.field select.invalid{ border-color:#e23d3d; box-shadow:0 0 0 4px rgba(226,61,61,.12); }
.field textarea{ resize:vertical; }
.err{ color:#e23d3d; font-size:.8rem; min-height:0; }
.radio-row{ display:flex; flex-wrap:wrap; gap:16px; padding-top:6px; }
.radio{ display:inline-flex; align-items:center; gap:7px; font-family:var(--f-body); font-weight:500;
  font-size:.95rem; text-transform:none; letter-spacing:0; color:var(--ink); cursor:pointer; }
.radio input{ width:18px; height:18px; accent-color:var(--green); }
.form-success{ background:rgba(31,166,74,.12); border:1px solid rgba(31,166,74,.4); color:#0d7a36;
  padding:16px 18px; border-radius:12px; font-weight:600; margin:0; text-align:center; }

/* =========================================================
   FAQ
   ========================================================= */
.faq{ background:var(--cream); }
.faq-list{ display:grid; gap:14px; }
.faq-item{ background:#fff; border:1px solid rgba(7,27,77,.08); border-radius:var(--radius-sm); overflow:hidden;
  box-shadow:var(--shadow-sm); }
.faq-item summary{ list-style:none; cursor:pointer; padding:22px 26px; font-family:var(--f-head); font-weight:600;
  font-size:1.08rem; color:var(--navy); display:flex; justify-content:space-between; align-items:center; gap:18px; }
.faq-item summary::-webkit-details-marker{ display:none; }
.faq-item summary::after{ content:"+"; font-family:var(--f-body); font-weight:400; font-size:1.6rem; color:var(--green);
  transition:transform .3s var(--ease); flex:none; line-height:1; }
.faq-item[open] summary::after{ transform:rotate(45deg); }
.faq-a{ padding:0 26px 24px; }
.faq-a p{ margin:0; color:var(--muted); }

/* =========================================================
   FINAL CTA
   ========================================================= */
.final-cta{ position:relative; color:#fff; text-align:center; padding:110px 0; overflow:hidden; }
.final-bg{ position:absolute; inset:0; z-index:0;
  background:linear-gradient(180deg, rgba(7,27,77,.86), rgba(4,16,47,.93)), url("../img/cta-bg.webp") center/cover no-repeat;
}
.final-bg::after{ content:""; position:absolute; inset:0;
  background:radial-gradient(80% 60% at 50% 50%, rgba(31,166,74,.28), transparent 70%); }
.final-inner{ position:relative; z-index:1; max-width:880px; }
.final-title{ font-family:var(--f-display); font-weight:400; text-transform:uppercase; line-height:1;
  font-size:clamp(2rem,5vw,3.8rem); text-wrap:balance; text-shadow:0 4px 30px rgba(0,0,0,.4); }
.final-copy{ margin:24px auto 36px; font-size:1.12rem; color:rgba(255,255,255,.9); max-width:680px; }

/* =========================================================
   FOOTER
   ========================================================= */
.site-footer{ background:var(--navy-deep); color:rgba(255,255,255,.8); padding-top:64px; }
.footer-grid{ display:grid; grid-template-columns:1.4fr 1fr 1.2fr; gap:40px; padding-bottom:50px; }
.footer-logo{ height:52px; width:auto; margin-bottom:16px; }
.footer-org{ font-family:var(--f-head); font-weight:700; color:#fff; font-size:1.1rem; margin:0 0 4px; }
.footer-event{ font-family:var(--f-head); color:var(--yellow); font-weight:600; margin:0 0 10px; letter-spacing:.03em; }
.footer-detail{ font-size:.94rem; margin:0; line-height:1.6; }
.footer-nav h4,.footer-contact h4{ font-family:var(--f-head); text-transform:uppercase; letter-spacing:.08em;
  color:#fff; font-size:.92rem; margin-bottom:16px; }
.footer-nav{ display:flex; flex-direction:column; gap:11px; }
.footer-nav a:hover{ color:var(--yellow); }
.footer-contact p{ margin:0 0 10px; font-size:.95rem; }
.footer-contact a:hover{ color:var(--yellow); }
.footer-cta{ margin-top:8px; }
.footer-bottom{ border-top:1px solid rgba(255,255,255,.1); padding:22px 0; font-size:.86rem; color:rgba(255,255,255,.55); }
.footer-bottom-inner{ display:flex; justify-content:space-between; align-items:center; gap:16px; flex-wrap:wrap; }
.footer-bottom-inner p{ margin:0; }
.powered-by a{ color:var(--yellow); font-weight:700; }
.powered-by a:hover{ text-decoration:underline; }
@media (max-width:560px){ .footer-bottom-inner{ flex-direction:column; text-align:center; gap:8px; } }

/* =========================================================
   MOBILE STICKY CTA
   ========================================================= */
.mobile-cta{ display:none; position:fixed; left:16px; right:16px; bottom:calc(16px + env(safe-area-inset-bottom,0px)); z-index:900;
  background:var(--grad-gold); color:var(--navy); text-align:center; padding:16px; border-radius:14px;
  font-family:var(--f-head); font-weight:700; text-transform:uppercase; letter-spacing:.06em;
  box-shadow:0 16px 36px -10px rgba(0,0,0,.5); transform:translateY(140%); transition:transform .4s var(--ease); }
.mobile-cta.show{ transform:translateY(0); }

/* =========================================================
   LIGHTBOX
   ========================================================= */
.lightbox{ position:fixed; inset:0; z-index:2000; background:rgba(4,16,47,.95); display:none;
  align-items:center; justify-content:center; padding:40px; opacity:0; transition:opacity .3s; }
.lightbox.open{ display:flex; opacity:1; }
.lb-img{ max-width:92vw; max-height:84vh; border-radius:10px; box-shadow:0 30px 80px rgba(0,0,0,.6); }
.lb-close,.lb-nav{ position:absolute; background:rgba(255,255,255,.12); border:1px solid rgba(255,255,255,.25);
  color:#fff; width:52px; height:52px; border-radius:50%; font-size:1.4rem; display:grid; place-items:center;
  transition:background .25s; }
.lb-close:hover,.lb-nav:hover{ background:var(--yellow); color:var(--navy); }
.lb-close{ top:24px; right:24px; }
.lb-prev{ left:24px; top:50%; transform:translateY(-50%); }
.lb-next{ right:24px; top:50%; transform:translateY(-50%); }
.lb-caption{ position:absolute; bottom:26px; left:0; right:0; text-align:center; color:#fff;
  font-family:var(--f-head); text-transform:uppercase; letter-spacing:.1em; }

/* =========================================================
   REVEAL ANIMATIONS
   ========================================================= */
.reveal{ opacity:0; transform:translateY(28px); transition:opacity .7s var(--ease), transform .7s var(--ease); }
.reveal.in-view{ opacity:1; transform:none; }
.reveal-delay-1{ transition-delay:.08s; }
.reveal-delay-2{ transition-delay:.16s; }

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width:1080px){
  .proof-grid{ grid-template-columns:repeat(3,1fr); }
  .cards-4{ grid-template-columns:repeat(2,1fr); }
  .vis-grid{ grid-template-columns:repeat(3,1fr); }
  .gallery-grid{ column-count:3; }
  .pkg-grid{ grid-template-columns:1fr; max-width:560px; margin:0 auto; }
  .pkg-gold{ transform:none; order:-1; }
  .pkg-gold:hover{ transform:translateY(-6px); }
}

@media (max-width:860px){
  .section{ padding:72px 0; }
  .header-cta{ display:none; }
  .lang-toggle--header{ display:none; }
  .nav-toggle{ display:flex; }

  /* desktop links hidden on mobile — navigation lives in #mobileMenu */
  .main-nav{ display:none; }

  /* ===== Premium mobile menu (#mobileMenu) ===== */
  .mobile-menu{ display:block; position:fixed; inset:0; z-index:1100; visibility:hidden; opacity:0;
    transition:opacity .4s var(--ease), visibility 0s linear .4s; }
  body.nav-open .mobile-menu{ visibility:visible; opacity:1; transition:opacity .4s var(--ease); }
  body.nav-open{ overflow:hidden; }

  .mm-bg{ position:absolute; inset:0;
    background:linear-gradient(165deg, rgba(7,27,77,.93) 0%, rgba(3,17,47,.97) 100%),
      url("../img/gallery-crowd-night-720.jpg") center/cover no-repeat;
    transform:scale(1.1); filter:blur(4px) saturate(115%); }
  .mm-bg::after{ content:""; position:absolute; inset:0;
    background:radial-gradient(70% 45% at 85% 6%, rgba(31,166,74,.22), transparent 60%),
      radial-gradient(65% 40% at 0% 100%, rgba(244,196,48,.13), transparent 60%); }
  .mm-grain{ position:absolute; inset:0; pointer-events:none; opacity:.045;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E"); }

  .mm-inner{ position:relative; z-index:2; height:100%; overflow-y:auto; -webkit-overflow-scrolling:touch;
    display:flex; flex-direction:column;
    padding:calc(env(safe-area-inset-top,0px) + 16px) 22px calc(env(safe-area-inset-bottom,0px) + 26px);
    transform:translateY(14px); transition:transform .45s var(--ease); }
  body.nav-open .mm-inner{ transform:translateY(0); }

  .mm-head{ display:flex; align-items:center; justify-content:space-between; padding-bottom:8px; }
  .mm-logo{ height:46px; width:auto; }
  .mm-close{ position:relative; width:48px; height:48px; border-radius:50%; background:rgba(255,255,255,.08);
    border:1px solid rgba(255,255,255,.2); display:grid; place-items:center;
    transition:background .25s, box-shadow .25s, transform .3s var(--ease); }
  .mm-close:hover, .mm-close:active{ background:rgba(244,196,48,.18); box-shadow:0 0 0 4px rgba(244,196,48,.16); transform:rotate(90deg); }
  .mm-close span{ position:absolute; width:19px; height:2px; background:#fff; border-radius:2px; }
  .mm-close span:first-child{ transform:rotate(45deg); }
  .mm-close span:last-child{ transform:rotate(-45deg); }

  /* editorial nav links + microdescriptions */
  .mm-nav{ display:flex; flex-direction:column; margin-top:4px; }
  .mm-link{ display:block; padding:14px 0; border-bottom:1px solid rgba(255,255,255,.09); position:relative;
    opacity:0; transform:translateX(20px); transition:opacity .4s var(--ease), transform .4s var(--ease); }
  body.nav-open .mm-link{ opacity:1; transform:translateX(0); }
  .mm-link::before{ content:""; position:absolute; left:-22px; top:50%; transform:translateY(-50%);
    width:4px; height:0; background:var(--grad-flag); border-radius:0 3px 3px 0; transition:height .25s var(--ease); }
  .mm-link-t{ display:block; font-family:var(--f-head); font-weight:700; text-transform:uppercase; letter-spacing:.01em;
    font-size:1.65rem; line-height:1.04; color:#fff; transition:color .2s; }
  .mm-link-d{ display:block; font-size:.82rem; color:rgba(255,255,255,.55); margin-top:3px; }
  .mm-link:hover .mm-link-t, .mm-link.is-current .mm-link-t{ color:var(--yellow); }
  .mm-link:hover::before, .mm-link.is-current::before{ height:64%; }
  body.nav-open .mm-link:nth-child(1){ transition-delay:.06s; }
  body.nav-open .mm-link:nth-child(2){ transition-delay:.11s; }
  body.nav-open .mm-link:nth-child(3){ transition-delay:.16s; }
  body.nav-open .mm-link:nth-child(4){ transition-delay:.21s; }
  body.nav-open .mm-link:nth-child(5){ transition-delay:.26s; }
  body.nav-open .mm-link:nth-child(6){ transition-delay:.31s; }

  /* mini stats */
  .mm-stats{ display:grid; grid-template-columns:repeat(3,1fr); gap:8px; margin:18px 0 4px;
    opacity:0; transform:translateY(10px); transition:opacity .4s var(--ease) .34s, transform .4s var(--ease) .34s; }
  body.nav-open .mm-stats{ opacity:1; transform:translateY(0); }
  .mm-stat{ background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.12); border-radius:12px; padding:11px 6px; text-align:center; }
  .mm-stat strong{ display:block; font-family:var(--f-head); font-weight:700; color:var(--yellow); font-size:1rem; line-height:1.1; }
  .mm-stat span{ display:block; font-size:.62rem; text-transform:uppercase; letter-spacing:.04em; color:rgba(255,255,255,.6); margin-top:4px; }

  /* language pill */
  .mm-lang{ display:flex; align-items:center; justify-content:space-between; gap:12px; margin:16px 0 2px; }
  .mm-lang-label{ font-family:var(--f-head); font-weight:600; text-transform:uppercase; letter-spacing:.16em; font-size:.7rem; color:rgba(255,255,255,.5); }
  .lang-toggle--menu{ display:grid; grid-template-columns:1fr 1fr; gap:4px; padding:5px; flex:1; max-width:230px;
    background:rgba(255,255,255,.07); border:1px solid rgba(255,255,255,.18); border-radius:999px; }
  .lang-toggle--menu .lang-btn{ padding:9px 8px; font-size:.82rem; letter-spacing:.02em; border-radius:999px;
    color:rgba(255,255,255,.7); text-align:center; transition:background .25s var(--ease), color .25s, box-shadow .25s; }
  .lang-toggle--menu .lang-btn.is-active{ background:var(--grad-gold); color:var(--navy); box-shadow:0 4px 12px -4px rgba(244,196,48,.6); }

  /* CTAs */
  .mm-cta{ display:flex; flex-direction:column; gap:10px; margin-top:18px;
    opacity:0; transform:translateY(12px); transition:opacity .45s var(--ease) .42s, transform .45s var(--ease) .42s; }
  body.nav-open .mm-cta{ opacity:1; transform:translateY(0); }
  .mm-cta .btn{ padding:16px; font-size:.95rem; }

  /* quick help */
  .mm-help{ margin-top:18px; padding-top:16px; border-top:1px solid rgba(255,255,255,.1); text-align:center; }
  .mm-help-q{ display:block; font-family:var(--f-head); font-weight:700; text-transform:uppercase; letter-spacing:.03em; color:#fff; font-size:.98rem; }
  .mm-help-sub{ display:block; color:rgba(255,255,255,.6); font-size:.82rem; margin:3px 0 12px; }
  .mm-help-links{ display:flex; justify-content:center; gap:8px; }
  .mm-help-links a{ flex:1; max-width:120px; padding:11px 6px; border-radius:10px; background:rgba(255,255,255,.06);
    border:1px solid rgba(255,255,255,.14); color:#fff; font-family:var(--f-head); font-weight:600; font-size:.8rem;
    text-transform:uppercase; letter-spacing:.04em; transition:background .2s, color .2s, transform .2s; }
  .mm-help-links a:hover, .mm-help-links a:active{ background:var(--green-2); color:var(--navy); transform:translateY(-2px); }

  .mm-flag{ position:absolute; left:0; right:0; bottom:0; height:6px; z-index:3;
    background:var(--grad-flag); background-size:200% 100%; animation:flagShift 7s linear infinite; }

  .event-grid{ grid-template-columns:1fr; gap:42px; }
  .audience-grid{ grid-template-columns:repeat(2,1fr); }
  .aud-card--wide{ grid-column:span 2; }
  .cards-3{ grid-template-columns:1fr 1fr; }
  .sponsor-grid{ grid-template-columns:1fr; gap:36px; }
  .footer-grid{ grid-template-columns:1fr 1fr; gap:32px; }
  .mobile-cta{ display:block; }
}

@media (max-width:560px){
  body{ font-size:16px; }
  .container{ padding:0 18px; }
  .brand-sub{ display:none; }
  .proof-grid{ grid-template-columns:1fr 1fr; }
  .cards-4{ grid-template-columns:1fr; }
  .vis-grid{ grid-template-columns:1fr 1fr; }
  .audience-grid{ grid-template-columns:1fr; }
  .aud-card--wide{ grid-column:span 1; }
  .cards-3{ grid-template-columns:1fr; }
  .cat-grid{ grid-template-columns:1fr; }
  .form-row{ grid-template-columns:1fr; }
  .gallery-grid{ column-count:2; padding:0 16px; }
  .sponsor-formwrap{ padding:24px; }
  .collage-badge{ width:78px; height:78px; right:0; }
  .collage-badge strong{ font-size:1.5rem; }
  .hero{ min-height:90svh; }
  .lb-prev{ left:10px; } .lb-next{ right:10px; }
  .lb-nav{ width:44px; height:44px; }
}

/* =========================================================
   REDUCED MOTION
   ========================================================= */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{ animation-duration:.001ms !important; animation-iteration-count:1 !important;
    transition-duration:.001ms !important; scroll-behavior:auto !important; }
  .reveal{ opacity:1; transform:none; }
  .hero-img,.hero-video{ height:100%; }
}

/* =========================================================
   REFINEMENT v2 — hero video, Why Sponsors Win, brand placement,
   video gallery, package accordion, form upgrades, video lightbox
   ========================================================= */

/* Hero video background */
.hero-video{ width:100%; height:120%; object-fit:cover; will-change:transform; background:var(--navy-deep); }

/* Hero deck link (tertiary) */
.btn-link-deck{ display:inline-flex; align-items:center; gap:.5em; align-self:center;
  font-family:var(--f-head); font-weight:600; letter-spacing:.05em; text-transform:uppercase; font-size:.82rem;
  color:#fff; padding:12px 6px; border-bottom:2px solid rgba(244,196,48,.6); border-radius:0; transition:color .2s, border-color .2s; }
.btn-link-deck::before{ content:"↓"; font-size:1em; }
.btn-link-deck:hover{ color:var(--yellow); border-color:var(--yellow); transform:translateY(-2px); }

/* ---- Why Sponsors Win ---- */
.wins{ background:linear-gradient(160deg,var(--navy) 0%, var(--navy-deep) 100%); color:#fff; }
.cards-5{ display:grid; grid-template-columns:repeat(5,1fr); gap:18px; }
.win-card{ background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.12); border-radius:var(--radius);
  padding:28px 22px; transition:transform .35s var(--ease), background .35s, border-color .35s; }
.win-card:hover{ transform:translateY(-7px); background:rgba(255,255,255,.09); border-color:rgba(244,196,48,.5); }
.win-n{ font-family:var(--f-display); font-size:1.7rem; color:var(--yellow); line-height:1; display:block; margin-bottom:12px; }
.win-card h3{ font-family:var(--f-head); font-weight:700; text-transform:uppercase; letter-spacing:.02em; font-size:1.05rem; margin-bottom:8px; }
.win-card p{ color:rgba(255,255,255,.78); font-size:.92rem; margin:0; }

/* ---- Brand placement (visual) ---- */
.place{ background:var(--cream); }
.place-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.place-card{ position:relative; border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow-sm);
  aspect-ratio:4/3; transition:transform .35s var(--ease), box-shadow .35s; }
.place-card.place-lg{ grid-column:span 1; }
.place-card img{ width:100%; height:100%; object-fit:cover; transition:transform .6s var(--ease); }
.place-card:hover{ transform:translateY(-6px); box-shadow:var(--shadow); }
.place-card:hover img{ transform:scale(1.06); }
.place-ov{ position:absolute; inset:0; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:14px;
  background:linear-gradient(180deg, rgba(7,27,77,.35), rgba(7,27,77,.72)); text-align:center; padding:18px; }
.place-slot{ font-family:var(--f-head); font-weight:700; text-transform:uppercase; letter-spacing:.12em; font-size:.82rem;
  color:#fff; padding:14px 22px; border:2px dashed rgba(255,255,255,.7); border-radius:12px;
  background:rgba(255,255,255,.08); backdrop-filter:blur(3px); }
.place-label{ font-family:var(--f-head); font-weight:600; text-transform:uppercase; letter-spacing:.05em; font-size:1rem;
  color:var(--yellow); text-shadow:0 2px 10px rgba(0,0,0,.5); }

/* ---- Video gallery ---- */
.videos{ background:var(--cream-2); }
.video-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.video-card{ position:relative; border:none; padding:0; border-radius:var(--radius); overflow:hidden; cursor:pointer;
  background:var(--navy); box-shadow:var(--shadow-sm); aspect-ratio:16/9; display:block; width:100%;
  transition:transform .35s var(--ease), box-shadow .35s; }
.video-card picture,.video-card img{ width:100%; height:100%; display:block; }
.video-card img{ object-fit:cover; transition:transform .6s var(--ease); }
.video-card::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(7,27,77,.05) 40%, rgba(7,27,77,.78)); }
.video-card:hover{ transform:translateY(-6px); box-shadow:var(--shadow); }
.video-card:hover img{ transform:scale(1.06); }
.play-btn{ position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); z-index:2;
  width:68px; height:68px; border-radius:50%; background:var(--grad-gold); display:grid; place-items:center;
  box-shadow:0 12px 30px -8px rgba(244,196,48,.8); transition:transform .3s var(--ease); }
.video-card:hover .play-btn{ transform:translate(-50%,-50%) scale(1.1); }
.play-btn svg{ width:30px; height:30px; fill:var(--navy); margin-left:3px; }
.video-cap{ position:absolute; left:18px; bottom:16px; z-index:2; color:#fff; font-family:var(--f-head); font-weight:600;
  text-transform:uppercase; letter-spacing:.05em; font-size:1rem; text-shadow:0 2px 10px rgba(0,0,0,.6); text-align:left; padding-right:14px; }

/* ---- Packages: view-all accordion ---- */
.pkg-toggle{ display:none; width:100%; background:none; border:1px dashed rgba(7,27,77,.3); color:var(--navy);
  font-family:var(--f-head); font-weight:600; text-transform:uppercase; letter-spacing:.04em; font-size:.82rem;
  padding:11px; border-radius:10px; margin-bottom:18px; transition:background .2s; }
.pkg-toggle:hover{ background:rgba(7,27,77,.05); }
.pkg-custom .pkg-toggle{ color:#fff; border-color:rgba(255,255,255,.35); }

/* ---- Form upgrades ---- */
.urgency{ display:flex; gap:12px; align-items:flex-start; background:rgba(244,196,48,.14); border:1px solid rgba(244,196,48,.4);
  color:#fff; border-radius:12px; padding:16px 18px; font-weight:500; font-size:.96rem; margin:18px 0 0; }
.urgency::before{ content:"★"; color:var(--yellow); font-size:1.1rem; line-height:1.4; flex:none; }
.quick-tiers{ display:flex; flex-wrap:wrap; gap:10px; align-items:center; margin-bottom:22px; }
.quick-label{ font-family:var(--f-head); font-weight:600; text-transform:uppercase; letter-spacing:.05em; font-size:.78rem; color:var(--muted); }
.quick-btn{ font-family:var(--f-head); font-weight:600; font-size:.82rem; letter-spacing:.02em; padding:9px 15px; border-radius:999px;
  border:1.5px solid #d7dbe4; background:#fff; color:var(--navy); transition:all .2s var(--ease); }
.quick-btn:hover{ border-color:var(--green); background:rgba(31,166,74,.08); transform:translateY(-2px); }
.quick-btn--master{ border-color:var(--green); background:var(--green); color:#fff; }
.quick-btn--master:hover{ background:var(--green-2); border-color:var(--green-2); color:var(--navy); }
.wa-link{ display:inline-block; margin-left:auto; font-family:var(--f-head); font-weight:600; font-size:.74rem; letter-spacing:.04em;
  text-transform:uppercase; color:var(--navy); background:var(--green-2); padding:5px 11px; border-radius:999px; transition:background .2s, transform .2s; }
.wa-link:hover{ background:var(--green); color:#fff; transform:translateY(-2px); }
.contact-list li{ flex-wrap:wrap; }
.btn-outline-light{ background:transparent; color:#fff; border-color:rgba(255,255,255,.6); }
.btn-outline-light:hover{ background:#fff; color:var(--navy); border-color:#fff; }
.deck-btn{ margin-top:18px; }

/* ---- Video lightbox ---- */
.lb-video{ max-width:92vw; max-height:84vh; border-radius:10px; box-shadow:0 30px 80px rgba(0,0,0,.6); background:#000; }

/* ---- Responsive (refinement) ---- */
@media (max-width:1080px){
  .cards-5{ grid-template-columns:repeat(2,1fr); }
  .place-grid{ grid-template-columns:repeat(2,1fr); }
  .video-grid{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width:860px){
  .wins .cards-5{ grid-template-columns:1fr 1fr; }
  /* package benefit collapse on mobile */
  .pkg-extra{ display:none; }
  .pkg-card.open .pkg-extra{ display:list-item; }
  .pkg-toggle{ display:block; }
  .hero-cta{ flex-direction:column; align-items:stretch; }
  .hero-cta .btn{ width:100%; }
  .btn-link-deck{ align-self:stretch; justify-content:center; }
}
@media (max-width:560px){
  .cards-5{ grid-template-columns:1fr; }
  .place-grid{ grid-template-columns:1fr; }
  .video-grid{ grid-template-columns:1fr; }
  .place-card{ aspect-ratio:16/10; }
  .wa-link{ margin-left:0; }
  .urgency{ font-size:.9rem; }
}

/* =========================================================
   SPONSORSHIP TIERS (rebuilt) — premium dark conversion section
   ========================================================= */
.tiers{ position:relative; background:linear-gradient(170deg,var(--navy) 0%, var(--navy-deep) 100%); color:#fff; overflow:hidden; }
.tiers-bg{ position:absolute; inset:0 0 auto 0; height:60%; z-index:0; opacity:.18; pointer-events:none;
  background:url("../img/gallery-crowd-night-720.jpg") center top/cover no-repeat;
  -webkit-mask-image:linear-gradient(180deg,#000,transparent); mask-image:linear-gradient(180deg,#000,transparent); }
.tiers::before{ content:""; position:absolute; inset:0; z-index:0; pointer-events:none;
  background:radial-gradient(70% 50% at 80% 0%, rgba(31,166,74,.20), transparent 60%),
             radial-gradient(60% 45% at 10% 30%, rgba(244,196,48,.12), transparent 60%); }
.tiers .container{ position:relative; z-index:1; }

/* --- main cards --- */
.tier-grid{ display:grid; grid-template-columns:1fr; gap:24px; align-items:start; margin-bottom:64px; }
.tier-rest{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; align-items:start; }
.tier-card{ position:relative; display:flex; flex-direction:column; height:100%;
  background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.14); border-radius:22px;
  padding:32px 28px 30px; backdrop-filter:blur(10px); box-shadow:0 24px 60px -28px rgba(0,0,0,.55);
  transition:transform .35s var(--ease), box-shadow .35s, border-color .35s; }
.tier-card:hover{ transform:translateY(-8px); box-shadow:0 40px 80px -30px rgba(0,0,0,.7); }
.tier-gold{ border:2px solid var(--yellow); background:linear-gradient(180deg, rgba(244,196,48,.12), rgba(255,255,255,.05)); }
.tier-gold::after{ content:""; position:absolute; inset:-1px; border-radius:22px; pointer-events:none;
  box-shadow:0 0 40px -10px rgba(244,196,48,.3) inset; }
.tier-bronze{ border:2px solid rgba(65,201,107,.65); }
.tier-custom{ border:1px solid rgba(255,248,232,.35); background:linear-gradient(180deg, rgba(255,248,232,.10), rgba(255,255,255,.04)); }

/* ===== MASTER flagship ===== */
.tier-master{ display:grid; grid-template-columns:0.92fr 1.08fr; gap:34px; align-items:center;
  border:2px solid transparent; border-radius:24px; padding:38px 36px;
  background:
    linear-gradient(180deg, rgba(31,166,74,.12), rgba(7,27,77,.5)) padding-box,
    linear-gradient(120deg, var(--green) 0%, var(--yellow) 55%, var(--gold,#D6A328) 100%) border-box;
  box-shadow:0 36px 90px -34px rgba(31,166,74,.5), 0 0 0 1px rgba(255,255,255,.05) inset; }
.tier-master::after{ content:""; position:absolute; inset:-2px; border-radius:24px; pointer-events:none; z-index:0;
  box-shadow:0 0 70px -10px rgba(244,196,48,.3) inset; }
.tier-master:hover{ transform:translateY(-6px); box-shadow:0 46px 100px -34px rgba(31,166,74,.6); }
.tier-master > *{ position:relative; z-index:1; }
.tier-master .tier-name{ font-size:2.4rem; color:#fff; }
.tier-master .tier-price{ color:var(--yellow); display:flex; align-items:baseline; gap:8px; flex-wrap:wrap; }
.tier-master .tp-label{ font-family:var(--f-head); font-weight:600; font-size:1rem; text-transform:uppercase; letter-spacing:.04em; color:rgba(255,255,255,.7); }
.tier-note{ margin:8px 0 0; font-size:.8rem; color:rgba(255,255,255,.6); font-style:italic; }
.tier-badge--master{ background:linear-gradient(120deg, var(--green), var(--yellow)); color:var(--navy); }
.tm-main{ display:flex; flex-direction:column; }
.tm-main .tier-head{ text-align:left; border-bottom:1px solid rgba(255,255,255,.16); }
.tm-main .tier-desc{ margin-top:18px; }
.tm-main .tier-micro{ margin-bottom:18px; }
.tm-benefits .tier-prev-label{ display:flex; align-items:center; gap:8px; color:var(--yellow); }
.prev-ic{ width:18px; height:18px; fill:none; stroke:var(--yellow); stroke-width:1.7; stroke-linejoin:round; }
.tier-prev--2col{ grid-template-columns:1fr 1fr; gap:10px 18px; }

.tier-badge{ position:absolute; top:-14px; left:50%; transform:translateX(-50%); white-space:nowrap;
  display:inline-flex; align-items:center; gap:7px; font-family:var(--f-head); font-weight:700; text-transform:uppercase;
  letter-spacing:.08em; font-size:.72rem; padding:8px 18px; border-radius:999px; box-shadow:var(--shadow-sm);
  background:var(--grad-gold); color:var(--navy); }
.tier-badge--green{ background:var(--grad-green); color:#fff; }
.tier-badge--cream{ background:var(--cream); color:var(--navy); }
.badge-ic{ width:15px; height:15px; fill:none; stroke:currentColor; stroke-width:1.8; stroke-linecap:round; stroke-linejoin:round; }

.tier-head{ text-align:center; padding:10px 0 20px; border-bottom:1px solid rgba(255,255,255,.14); margin-bottom:20px; }
.tier-name{ font-family:var(--f-display); font-weight:400; text-transform:uppercase; font-size:1.9rem; letter-spacing:.02em; }
.tier-gold .tier-name{ color:var(--yellow); }
.tier-bronze .tier-name{ color:var(--green-2); }
.tier-pos{ margin:6px 0 0; font-family:var(--f-head); font-weight:500; text-transform:uppercase; letter-spacing:.05em; font-size:.8rem; color:rgba(255,255,255,.72); }
.tier-price{ font-family:var(--f-display); font-size:3rem; line-height:1; margin-top:14px; color:#fff; }
.tier-gold .tier-price{ color:var(--yellow); }
.tier-price--talk{ font-family:var(--f-head); font-weight:700; font-size:1.7rem; text-transform:uppercase; color:var(--green-2); }
.tier-desc{ color:rgba(255,255,255,.82); font-size:.96rem; margin:0 0 20px; }
.tier-prev-label{ font-family:var(--f-head); font-weight:600; text-transform:uppercase; letter-spacing:.08em; font-size:.74rem; color:var(--yellow); margin:0 0 12px; }
.tier-bronze .tier-prev-label{ color:var(--green-2); }
.tier-prev{ display:grid; gap:10px; margin-bottom:18px; }
.tier-prev li{ position:relative; padding-left:28px; font-size:.96rem; color:#fff; line-height:1.4; }
.tier-prev li::before{ content:""; position:absolute; left:0; top:2px; width:17px; height:17px; border-radius:50%; background:var(--grad-green); }
.tier-prev li::after{ content:""; position:absolute; left:5.5px; top:7px; width:6px; height:3.5px; border-left:2px solid #fff; border-bottom:2px solid #fff; transform:rotate(-45deg); }
.tier-gold .tier-prev li::before{ background:var(--grad-gold); }
.tier-gold .tier-prev li::after{ border-color:var(--navy); }
.tier-micro{ font-size:.9rem; font-style:italic; color:rgba(255,255,255,.7); margin:0 0 22px; }
.tier-card .btn{ margin-top:auto; }

/* --- comparison "at a glance" --- */
.cmp{ margin-bottom:60px; }
.cmp-title{ text-align:center; font-family:var(--f-display); font-weight:400; text-transform:uppercase; font-size:clamp(1.5rem,3vw,2.2rem); margin-bottom:26px; }
.cmp-title-wrap .cmp-title{ margin-bottom:8px; }
.cmp-sub{ text-align:center; color:rgba(255,255,255,.72); font-size:1rem; line-height:1.55; margin:0 auto; max-width:640px; }
.cmp-wrap{ border-radius:18px; overflow:hidden; border:1px solid rgba(255,255,255,.14); }
.cmp-table{ width:100%; border-collapse:collapse; font-size:.95rem; }
.cmp-table th, .cmp-table td{ padding:15px 18px; text-align:left; border-bottom:1px solid rgba(255,255,255,.1); }
.cmp-table thead th{ background:rgba(255,255,255,.06); font-family:var(--f-head); font-weight:700; text-transform:uppercase; letter-spacing:.04em; font-size:.82rem; color:#fff; }
.cmp-table thead .cmp-col-gold{ color:var(--yellow); background:rgba(244,196,48,.12); }
.cmp-table thead .cmp-col-master{ color:#fff; background:linear-gradient(180deg, rgba(31,166,74,.4), rgba(31,166,74,.22)); }
.cmp-table tbody th[scope="row"]{ font-weight:600; color:rgba(255,255,255,.9); }
.cmp-table td{ color:rgba(255,255,255,.82); }
.cmp-table td.cmp-gold{ color:#fff; font-weight:600; background:rgba(244,196,48,.08); }
.cmp-table td.cmp-master{ color:#fff; font-weight:700; background:rgba(31,166,74,.16); box-shadow:inset 1px 0 0 rgba(255,255,255,.06), inset -1px 0 0 rgba(255,255,255,.06); }
.cmp-table td.cmp-no{ color:rgba(255,255,255,.35); }
.cmp-table tbody tr:hover td, .cmp-table tbody tr:hover th{ background:rgba(255,255,255,.04); }
.cmp-table td.cmp-master.cmp-no{ color:rgba(255,255,255,.6); }
.cmp-table tbody tr:hover td.cmp-gold{ background:rgba(244,196,48,.14); }
.cmp-table tbody tr:hover td.cmp-master{ background:rgba(31,166,74,.24); }
/* tighter padding for 5-column comparison */
.cmp-table--5 th, .cmp-table--5 td{ padding:13px 12px; font-size:.9rem; }

/* --- full-benefit accordions --- */
.tier-acc{ max-width:920px; margin:0 auto 60px; display:grid; gap:14px; }
.acc-item{ background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.14); border-radius:14px; overflow:hidden; }
.acc-master{ border-color:rgba(31,166,74,.55); background:rgba(31,166,74,.08); }
.acc-master .acc-cat h4{ color:var(--green-2); }
.acc-gold{ border-color:rgba(244,196,48,.4); }
.acc-bronze{ border-color:rgba(65,201,107,.4); }
.acc-item summary{ list-style:none; cursor:pointer; display:flex; justify-content:space-between; align-items:center; gap:16px;
  padding:20px 24px; font-family:var(--f-head); font-weight:600; font-size:1.05rem; color:#fff; }
.acc-item summary::-webkit-details-marker{ display:none; }
.acc-mark{ font-family:var(--f-body); font-weight:400; font-size:1.6rem; color:var(--yellow); line-height:1; transition:transform .3s var(--ease); flex:none; }
.acc-item[open] .acc-mark{ transform:rotate(45deg); }
.acc-body{ padding:0 24px 22px; }
.acc-cat{ margin-top:18px; }
.acc-cat h4{ font-family:var(--f-head); font-weight:700; text-transform:uppercase; letter-spacing:.06em; font-size:.8rem; color:var(--yellow); margin-bottom:10px; padding-bottom:7px; border-bottom:1px solid rgba(255,255,255,.12); }
.acc-bronze .acc-cat h4{ color:var(--green-2); }
.acc-cat ul{ display:grid; gap:8px; }
.acc-cat li{ position:relative; padding-left:20px; font-size:.94rem; color:rgba(255,255,255,.85); line-height:1.45; }
.acc-cat li::before{ content:""; position:absolute; left:0; top:8px; width:7px; height:7px; border-radius:2px; background:var(--green-2); transform:rotate(45deg); }
.acc-text{ margin:18px 0 0; color:rgba(255,255,255,.85); font-size:1rem; }

/* --- which package --- */
.which{ margin-bottom:56px; }
.which-title{ text-align:center; font-family:var(--f-display); font-weight:400; text-transform:uppercase; font-size:clamp(1.5rem,3vw,2.2rem); margin-bottom:26px; }
.which-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.which-grid--4{ grid-template-columns:repeat(4,1fr); }
.which-card{ background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.14); border-radius:16px; padding:24px; border-top:4px solid var(--yellow); }
.which-master{ border-top-color:var(--green); background:linear-gradient(180deg, rgba(31,166,74,.14), rgba(255,255,255,.04)); }
.which-master .which-k{ color:var(--green-2); }
.which-gold{ border-top-color:var(--yellow); } .which-bronze{ border-top-color:var(--green-2); } .which-custom{ border-top-color:var(--cream); }
.which-k{ display:block; font-family:var(--f-head); font-weight:700; text-transform:uppercase; letter-spacing:.04em; font-size:1.02rem; color:#fff; margin-bottom:10px; }
.which-gold .which-k{ color:var(--yellow); } .which-bronze .which-k{ color:var(--green-2); }
.which-card p{ margin:0; color:rgba(255,255,255,.8); font-size:.95rem; }

/* --- final band --- */
.tier-band{ text-align:center; background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.16); border-radius:22px; padding:48px 32px; }
.band-title{ font-family:var(--f-display); font-weight:400; text-transform:uppercase; font-size:clamp(1.7rem,3.6vw,2.8rem); line-height:1.04; text-wrap:balance; }
.band-sub{ margin:16px auto 28px; max-width:640px; color:rgba(255,255,255,.82); }
.band-cta{ display:flex; flex-wrap:wrap; gap:16px; justify-content:center; }

/* --- tiers responsive --- */
@media (max-width:1080px){
  .tier-master{ grid-template-columns:1fr; gap:22px; padding:30px 24px; }
  .tier-rest{ grid-template-columns:1fr; max-width:560px; margin:0 auto; }
  .which-grid, .which-grid--4{ grid-template-columns:1fr 1fr; }
}
@media (max-width:560px){
  .tier-prev--2col{ grid-template-columns:1fr; }
  .which-grid, .which-grid--4{ grid-template-columns:1fr; }
  .tier-master .tier-name{ font-size:2rem; }
}
@media (max-width:760px){
  .cmp-wrap{ border:none; }
  .cmp-table thead{ position:absolute; left:-9999px; }
  .cmp-table, .cmp-table tbody, .cmp-table tr, .cmp-table th, .cmp-table td{ display:block; width:100%; }
  .cmp-table tr{ background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.14); border-radius:14px; margin-bottom:14px; padding:8px 16px 14px; }
  .cmp-table tbody th[scope="row"]{ font-family:var(--f-head); font-weight:700; text-transform:uppercase; letter-spacing:.03em; font-size:.92rem; color:var(--yellow); padding:12px 0 10px; border-bottom:1px solid rgba(255,255,255,.14); }
  .cmp-table td{ display:flex; justify-content:space-between; align-items:center; gap:14px; padding:9px 0; border:none; font-size:.95rem; }
  .cmp-table td::before{ content:attr(data-label); font-family:var(--f-head); font-weight:600; text-transform:uppercase; letter-spacing:.04em; font-size:.78rem; color:rgba(255,255,255,.6); }
  .cmp-table td.cmp-gold{ background:none; }
  .cmp-table td.cmp-gold::before{ color:var(--yellow); }
  .band-cta .btn{ width:100%; }
}
