/* ===========================================================================
   Jogada Sport — kickoff.css
   Direction: bright photographic sports-broadcast editorial (light)
   Palette : paper + ink, pitch-green primary, energy-orange pop, blue rare
   Type    : Oswald (condensed display, uppercase) + Hanken Grotesk (body)
   Signature: skewed green "matchday" tab + section index, diagonal stripe accent
   =========================================================================== */

/* ---- fonts (self-hosted) ---- */
@font-face{font-family:"Oswald";src:url("../fonts/oswald-500.woff2") format("woff2");font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:"Oswald";src:url("../fonts/oswald-700.woff2") format("woff2");font-weight:700;font-style:normal;font-display:swap}
@font-face{font-family:"Hanken";src:url("../fonts/hanken-400.woff2") format("woff2");font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:"Hanken";src:url("../fonts/hanken-600.woff2") format("woff2");font-weight:600;font-style:normal;font-display:swap}
@font-face{font-family:"Hanken";src:url("../fonts/hanken-800.woff2") format("woff2");font-weight:800;font-style:normal;font-display:swap}

:root{
  --paper:#f6f7f4;
  --paper-2:#eef1ea;
  --ink:#0e1a14;
  --ink-soft:#33433b;
  --muted:#5d6b63;
  --green:#0fa958;
  --green-deep:#0b7d6f;
  --green-ink:#063a2b;
  --orange:#ff5a1f;
  --blue:#1f6dff;
  --line:rgba(14,26,20,.12);
  --line-strong:rgba(14,26,20,.22);
  --card:#ffffff;
  --shadow:0 18px 50px -28px rgba(8,40,28,.45);
  --container:1280px;
  --pad:clamp(1.25rem,4vw,2rem);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:"Hanken",system-ui,sans-serif;
  background:var(--paper);
  color:var(--ink);
  font-size:clamp(1rem,1.05vw,1.0625rem);
  line-height:1.62;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer}
:focus-visible{outline:3px solid var(--green);outline-offset:2px}

/* ---- shared primitives ---- */
.shell{width:100%;max-width:var(--container);margin-inline:auto;padding-inline:var(--pad)}
.display{font-family:"Oswald",Impact,sans-serif;font-weight:700;text-transform:uppercase;line-height:.94;letter-spacing:.012em}
.tab{
  display:inline-flex;align-items:center;gap:.5rem;
  font-family:"Oswald",sans-serif;font-weight:500;text-transform:uppercase;letter-spacing:.16em;
  font-size:.78rem;color:#fff;background:var(--green);
  padding:.42rem .9rem;transform:skewX(-9deg);
}
.tab > span{display:inline-block;transform:skewX(9deg)}
.tab.ghost{background:transparent;color:var(--green-deep);border:1.5px solid var(--green);}

/* centered section header (aligned, balanced) */
.sec{padding:clamp(3.5rem,8vw,6.5rem) 0;position:relative}
.sec-head{max-width:50rem;margin:0 auto clamp(2.2rem,5vw,3.4rem);text-align:center;display:flex;flex-direction:column;align-items:center;gap:1rem}
.sec-head h2{font-family:"Oswald",sans-serif;font-weight:700;text-transform:uppercase;line-height:.96;letter-spacing:.01em;font-size:clamp(2.1rem,5.4vw,3.6rem)}
.sec-head h2 em{font-style:normal;color:var(--green)}
.sec-head p{color:var(--muted);max-width:42rem;font-size:1.05rem}
.idx{font-family:"Oswald",sans-serif;letter-spacing:.3em;font-size:.8rem;color:var(--orange);text-transform:uppercase}

/* buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.55rem;
  font-family:"Oswald",sans-serif;font-weight:500;text-transform:uppercase;letter-spacing:.06em;
  padding:.95rem 1.5rem;border-radius:2px;border:2px solid transparent;transition:.2s ease;white-space:nowrap}
.btn-green{background:var(--green);color:#fff}
.btn-green:hover{background:var(--green-deep);transform:translateY(-2px)}
.btn-ink{background:var(--ink);color:#fff}
.btn-ink:hover{background:#1d3329;transform:translateY(-2px)}
.btn-out{border-color:currentColor;color:var(--ink)}
.btn-out:hover{background:var(--ink);color:#fff;border-color:var(--ink)}
.btn-out.on-dark{color:#fff}
.btn-out.on-dark:hover{background:#fff;color:var(--ink)}

/* google-play badge */
.gplay{display:inline-flex;align-items:center;gap:.7rem;background:var(--ink);color:#fff;
  padding:.7rem 1.25rem;border-radius:6px;transition:.2s}
.gplay:hover{transform:translateY(-2px);background:#16271f}
.gplay svg{width:26px;height:26px;flex:0 0 auto}
.gplay small{display:block;font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;opacity:.8;line-height:1}
.gplay b{font-family:"Oswald",sans-serif;font-weight:500;font-size:1.18rem;letter-spacing:.02em;line-height:1.1}

/* ============================ NAV ============================ */
.nav{position:fixed;inset:0 0 auto 0;z-index:60;transition:.3s}
.nav-in{display:flex;align-items:center;justify-content:space-between;gap:1rem;
  width:100%;max-width:var(--container);margin-inline:auto;padding:1rem var(--pad)}
.nav.solid{background:rgba(246,247,244,.94);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.brand{display:flex;align-items:center;gap:.6rem;font-family:"Oswald",sans-serif;font-weight:700;
  text-transform:uppercase;letter-spacing:.04em;font-size:1.2rem;color:#fff}
.nav.solid .brand{color:var(--ink)}
.brand img{width:38px;height:38px;border-radius:9px}
.brand .g{color:var(--green)}
.nav-menu{display:flex;align-items:center;gap:2rem}
.nav-menu a.lk{font-family:"Oswald",sans-serif;font-weight:500;text-transform:uppercase;letter-spacing:.08em;
  font-size:.85rem;color:rgba(255,255,255,.92);position:relative;padding:.2rem 0}
.nav.solid .nav-menu a.lk{color:var(--ink-soft)}
.nav-menu a.lk::after{content:"";position:absolute;left:0;bottom:-3px;height:2px;width:0;background:var(--green);transition:.25s}
.nav-menu a.lk:hover::after{width:100%}
.nav-cta{padding:.6rem 1.1rem}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;padding:8px}
.burger span{width:26px;height:2px;background:#fff;transition:.3s}
.nav.solid .burger span{background:var(--ink)}

/* full-screen overlay menu (mobile) */
.overlay{position:fixed;inset:0;z-index:70;background:var(--green-ink);
  display:flex;flex-direction:column;justify-content:center;align-items:center;gap:1.4rem;
  transform:translateY(-100%);transition:transform .4s cubic-bezier(.7,0,.2,1);opacity:0;visibility:hidden}
.overlay.open{transform:translateY(0);opacity:1;visibility:visible}
.overlay a{font-family:"Oswald",sans-serif;font-weight:700;text-transform:uppercase;letter-spacing:.04em;
  font-size:2rem;color:#fff;opacity:.85}
.overlay a:hover{color:var(--orange)}
.overlay .close{position:absolute;top:1.5rem;right:1.5rem;background:none;border:0;color:#fff;font-size:2.4rem;line-height:1}

/* ============================ HERO ============================ */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;
  padding:9rem 0 4rem;color:#fff;overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:0;
  background:linear-gradient(135deg,var(--green-ink) 0%,#0a4a37 48%,var(--green-deep) 100%)}
.hero-bg::after{content:"";position:absolute;inset:0;opacity:.08;
  background:repeating-linear-gradient(-45deg,#fff 0 2px,transparent 2px 26px)}
.hero-grid{position:relative;z-index:2;display:grid;grid-template-columns:1.05fr .95fr;gap:3rem;align-items:center}
.hero-copy{max-width:38rem}
.hero-rating{display:flex;align-items:center;gap:.8rem;margin:1.3rem 0;flex-wrap:wrap}
.hero-rating .ico{width:54px;height:54px;border-radius:13px;box-shadow:var(--shadow)}
.stars{color:var(--orange);letter-spacing:.1em;font-size:1.1rem}
.hero h1{font-family:"Oswald",sans-serif;font-weight:700;text-transform:uppercase;line-height:.86;
  font-size:clamp(3.2rem,9vw,6.6rem);letter-spacing:.01em;margin:.6rem 0}
.hero h1 .l2{color:var(--green);display:block}
.hero-lead{font-size:clamp(1.05rem,1.6vw,1.28rem);color:#e7f0ea;max-width:34rem}
.hero-cta{display:flex;gap:1rem;flex-wrap:wrap;align-items:center;margin-top:1.8rem}
.hero-chips{display:flex;gap:.6rem;flex-wrap:wrap;margin-top:1.8rem}
.chip{font-family:"Oswald",sans-serif;font-weight:500;text-transform:uppercase;letter-spacing:.1em;
  font-size:.72rem;color:#fff;border:1px solid rgba(255,255,255,.32);padding:.42rem .8rem;border-radius:999px}
.chip b{color:var(--green)}

/* hero visual — floating broadcast card */
.hero-visual{position:relative;justify-self:center}
.screen-card{position:relative;width:min(100%,330px);border-radius:14px;overflow:hidden;
  border:1px solid rgba(255,255,255,.18);box-shadow:0 40px 80px -30px rgba(0,0,0,.7);background:#0b1410}
.screen-card .bar{display:flex;align-items:center;gap:.4rem;padding:.6rem .8rem;background:#0b1410}
.screen-card .bar i{width:10px;height:10px;border-radius:50%;background:#2a3c33;display:inline-block}
.screen-card img{display:block;width:100%;height:auto;background:#0b1410}
.live-tab{position:absolute;top:-14px;left:18px;z-index:3;
  font-family:"Oswald",sans-serif;font-weight:700;letter-spacing:.14em;font-size:.74rem;text-transform:uppercase;
  background:var(--orange);color:#fff;padding:.4rem .8rem;transform:skewX(-9deg);box-shadow:0 8px 18px -8px rgba(0,0,0,.6)}
.live-tab span{display:inline-block;transform:skewX(9deg)}
.float-mark{position:absolute;bottom:-22px;right:-10px;width:92px;height:92px;border-radius:22px;
  box-shadow:0 22px 40px -16px rgba(0,0,0,.6);border:3px solid #fff}

/* ============================ TICKER ============================ */
.ticker{background:var(--ink);color:#fff;overflow:hidden;white-space:nowrap;
  border-top:3px solid var(--green);border-bottom:3px solid var(--green)}
.ticker-row{display:inline-flex;gap:0;padding:.75rem 0;animation:slide 30s linear infinite;will-change:transform}
.ticker-row span{font-family:"Oswald",sans-serif;font-weight:500;text-transform:uppercase;letter-spacing:.08em;
  font-size:1.05rem;padding:0 1.4rem;display:inline-flex;align-items:center;gap:1.4rem;color:#cfe5da}
.ticker-row span::after{content:"";width:7px;height:7px;background:var(--orange);transform:rotate(45deg)}
@keyframes slide{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media(prefers-reduced-motion:reduce){.ticker-row{animation:none}}

/* ============================ STATS BAND ============================ */
.stats{background:linear-gradient(120deg,var(--green) 0%,var(--green-deep) 100%);color:#fff;
  position:relative;overflow:hidden}
.stats::before{content:"";position:absolute;inset:0;opacity:.12;
  background:repeating-linear-gradient(-45deg,#fff 0 2px,transparent 2px 26px)}
.stats-grid{position:relative;display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;
  padding:clamp(2.4rem,5vw,3.4rem) 0;text-align:center}
.stats-grid .v{font-family:"Oswald",sans-serif;font-weight:700;font-size:clamp(2.4rem,5.5vw,3.6rem);line-height:1}
.stats-grid .k{text-transform:uppercase;letter-spacing:.14em;font-size:.78rem;margin-top:.5rem;color:#dcf3e8}
.stats-grid > div + div{border-left:1px solid rgba(255,255,255,.22)}
@media(max-width:760px){.stats-grid{grid-template-columns:repeat(2,1fr);gap:2rem}.stats-grid > div + div{border-left:0}}

/* ============================ FEATURES / LINE-UP ============================ */
.lineup-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;max-width:1080px;margin:0 auto}
.feat{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:2.4rem 1.9rem;
  position:relative;transition:.25s;overflow:hidden;
  display:flex;flex-direction:column;align-items:center;text-align:center}
.feat::after{content:"";position:absolute;left:0;top:0;width:100%;height:4px;background:var(--green);transform:scaleX(0);transform-origin:left;transition:.3s}
.feat:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:transparent}
.feat:hover::after{transform:scaleX(1)}
.feat .n{font-family:"Oswald",sans-serif;font-weight:700;font-size:2.4rem;line-height:1;
  position:absolute;right:1.2rem;top:1rem;color:rgba(15,169,88,.14)}
.feat .fi{width:54px;height:54px;border-radius:12px;display:grid;place-items:center;
  background:rgba(15,169,88,.12);color:var(--green-deep);margin:0 auto 1.2rem}
.feat .fi svg{width:26px;height:26px}
.feat h3{font-family:"Oswald",sans-serif;font-weight:600;text-transform:uppercase;letter-spacing:.02em;
  font-size:1.35rem;margin-bottom:.5rem}
.feat p{color:var(--muted);font-size:.98rem;max-width:32ch}
@media(max-width:900px){.lineup-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.lineup-grid{grid-template-columns:1fr}}

/* ============================ SCREENS RAIL ============================ */
.rail-wrap{position:relative}
.rail{display:flex;gap:1.3rem;overflow-x:auto;overflow-y:hidden;padding:.5rem .25rem 1.6rem;scroll-snap-type:x mandatory}
.rail::-webkit-scrollbar{height:8px}
.rail::-webkit-scrollbar-thumb{background:var(--line-strong);border-radius:99px}
.frame{flex:0 0 auto;width:auto;max-width:86vw;scroll-snap-align:center;background:var(--card);
  border:1px solid var(--line);border-radius:14px;overflow:hidden;box-shadow:var(--shadow)}
.frame .top{display:flex;align-items:center;gap:.4rem;padding:.65rem .9rem;border-bottom:1px solid var(--line)}
.frame .top i{width:9px;height:9px;border-radius:50%;background:var(--line-strong);display:inline-block}
.frame .top em{margin-left:auto;font-style:normal;font-family:"Oswald",sans-serif;font-size:.72rem;
  letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.frame img{display:block;width:auto;height:min(64vh,560px);max-width:86vw;object-fit:contain;background:#0b1410}
.frame .cap{padding:.85rem 1rem;font-family:"Oswald",sans-serif;font-weight:500;text-transform:uppercase;
  letter-spacing:.05em;font-size:.95rem;display:flex;justify-content:space-between;align-items:center}
.frame .cap b{color:var(--green);font-weight:700}
.rail-hint{text-align:center;color:var(--muted);font-size:.85rem;letter-spacing:.04em}

/* ============================ FULL-BLEED ROW (how it works) ============================ */
.row-bleed{position:relative;color:#fff;overflow:hidden}
.row-bleed .bg{position:absolute;inset:0;z-index:0;background-size:cover;background-position:center}
.row-bleed .bg::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(6,40,28,.94),rgba(6,40,28,.66))}
.row-bleed .inner{position:relative;z-index:2;display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center;
  padding:clamp(3.5rem,8vw,6rem) 0}
.steps{display:grid;gap:1.2rem}
.step{display:flex;gap:1.1rem;align-items:flex-start;background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.14);border-radius:12px;padding:1.2rem 1.3rem;backdrop-filter:blur(3px)}
.step .num{font-family:"Oswald",sans-serif;font-weight:700;font-size:1.6rem;color:var(--orange);
  background:rgba(255,90,31,.14);width:52px;height:52px;border-radius:11px;display:grid;place-items:center;flex:0 0 52px}
.step h4{font-family:"Oswald",sans-serif;font-weight:600;text-transform:uppercase;letter-spacing:.03em;font-size:1.2rem;margin-bottom:.25rem}
.step p{color:#d6e6dd;font-size:.96rem}
.row-bleed .lead h2{font-family:"Oswald",sans-serif;font-weight:700;text-transform:uppercase;
  font-size:clamp(2rem,5vw,3.2rem);line-height:.96;margin:.8rem 0}
.row-bleed .lead h2 em{font-style:normal;color:var(--green)}
.row-bleed .lead p{color:#d6e6dd;max-width:30rem}
@media(max-width:860px){.row-bleed .inner{grid-template-columns:1fr;gap:2rem}}

/* ============================ SPLIT (about) ============================ */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.split .media{border-radius:14px;overflow:hidden;box-shadow:var(--shadow);position:relative}
.split .media img{width:100%;aspect-ratio:4/3;object-fit:cover}
.split .media .badge{position:absolute;left:1rem;bottom:1rem;font-family:"Oswald",sans-serif;font-weight:700;
  text-transform:uppercase;letter-spacing:.1em;font-size:.78rem;background:var(--ink);color:#fff;padding:.5rem .9rem;transform:skewX(-9deg)}
.split .media .badge span{display:inline-block;transform:skewX(9deg)}
.split .txt h2{font-family:"Oswald",sans-serif;font-weight:700;text-transform:uppercase;
  font-size:clamp(2rem,4.6vw,3rem);line-height:.98;margin-bottom:1rem}
.split .txt h2 em{font-style:normal;color:var(--green)}
.split .txt p{color:var(--muted);margin-bottom:1rem}
.tick{list-style:none;display:grid;gap:.7rem;margin-top:.5rem}
.tick li{display:flex;gap:.7rem;align-items:flex-start;font-weight:600}
.tick li svg{width:22px;height:22px;flex:0 0 22px;color:var(--green);margin-top:.15rem}
@media(max-width:860px){.split{grid-template-columns:1fr;gap:2rem}.split.rev .media{order:-1}}

/* ============================ FAQ ============================ */
.faq-wrap{max-width:54rem;margin:0 auto;border-top:1px solid var(--line)}
.qa{border-bottom:1px solid var(--line)}
.qa button{width:100%;background:none;border:0;text-align:left;display:flex;justify-content:space-between;
  align-items:center;gap:1.2rem;padding:1.35rem .25rem;font-family:"Oswald",sans-serif;font-weight:600;
  text-transform:uppercase;letter-spacing:.02em;font-size:1.12rem;color:var(--ink)}
.qa button .pm{flex:0 0 auto;width:30px;height:30px;border-radius:50%;border:2px solid var(--green);color:var(--green);
  display:grid;place-items:center;font-size:1.2rem;transition:.25s;line-height:1}
.qa.open button .pm{background:var(--green);color:#fff;transform:rotate(45deg)}
.qa .ans{max-height:0;overflow:hidden;transition:max-height .3s ease}
.qa .ans p{padding:0 .25rem 1.35rem;color:var(--muted);max-width:48rem}

/* ============================ SIGNUP / FORM ============================ */
.signup{background:var(--ink);color:#fff;position:relative;overflow:hidden}
.signup::before{content:"";position:absolute;right:-10%;top:-30%;width:520px;height:520px;border-radius:50%;
  background:radial-gradient(circle,rgba(15,169,88,.35),transparent 65%)}
.signup-grid{position:relative;display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2rem,5vw,3.5rem);align-items:center;
  padding:clamp(3.2rem,7vw,5.2rem) 0}
.signup .lead .tab{margin-bottom:1.1rem}
.signup .lead h2{font-family:"Oswald",sans-serif;font-weight:700;text-transform:uppercase;
  font-size:clamp(2rem,5vw,3.2rem);line-height:.96;margin-bottom:1rem}
.signup .lead h2 em{font-style:normal;color:var(--green)}
.signup .lead p{color:#cdddD3;color:#caddd2;max-width:30rem;margin-bottom:1.6rem}
.contact-mini{display:grid;gap:.8rem;margin-top:1.4rem}
.contact-mini a,.contact-mini div{display:flex;gap:.7rem;align-items:center;color:#dfece5;font-size:.96rem}
.contact-mini svg{width:20px;height:20px;color:var(--green);flex:0 0 20px}

.card-form{background:#fff;color:var(--ink);border-radius:16px;padding:clamp(1.6rem,3vw,2.2rem);box-shadow:var(--shadow)}
.card-form h3{font-family:"Oswald",sans-serif;font-weight:700;text-transform:uppercase;font-size:1.5rem;margin-bottom:.3rem}
.card-form .sub{color:var(--muted);font-size:.92rem;margin-bottom:1.3rem}
.field{margin-bottom:1rem}
.field label{display:block;font-family:"Oswald",sans-serif;font-weight:500;text-transform:uppercase;
  letter-spacing:.08em;font-size:.74rem;color:var(--ink-soft);margin-bottom:.4rem}
.field input[type=text],.field input[type=tel],.field input[type=email]{
  width:100%;padding:.85rem .95rem;border:1.5px solid var(--line-strong);border-radius:8px;
  background:var(--paper);font-size:1rem;transition:.2s}
.field input:focus{border-color:var(--green);background:#fff;outline:none}
.consent{display:flex;gap:.6rem;align-items:flex-start;font-size:.86rem;color:var(--muted);margin-bottom:1.1rem}
.consent input{margin-top:.25rem;width:18px;height:18px;accent-color:var(--green);flex:0 0 18px}
.consent a{color:var(--green-deep);text-decoration:underline}
.card-form .btn-green{width:100%}
.success-msg{display:none;margin-top:.9rem;background:rgba(15,169,88,.12);color:var(--green-deep);
  border:1px solid var(--green);border-radius:8px;padding:.8rem 1rem;font-weight:600;font-size:.92rem}
.success-msg.show{display:block}
@media(max-width:860px){.signup-grid{grid-template-columns:1fr}}

/* ============================ CTA BANNER ============================ */
.cta{position:relative;color:#fff;text-align:center;overflow:hidden}
.cta .bg{position:absolute;inset:0;z-index:0;background:url("../img/crowd.webp") center/cover}
.cta .bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(6,40,28,.86),rgba(11,125,111,.86))}
.cta .inner{position:relative;z-index:2;padding:clamp(3.5rem,9vw,6.5rem) 0;display:flex;flex-direction:column;align-items:center;gap:1.3rem}
.cta h2{font-family:"Oswald",sans-serif;font-weight:700;text-transform:uppercase;line-height:.9;
  font-size:clamp(2.4rem,7vw,5rem)}
.cta h2 em{font-style:normal;color:var(--orange)}
.cta p{color:#e7f0ea;max-width:36rem}

/* ============================ FOOTER ============================ */
.foot{background:var(--green-ink);color:#cfe1d8;padding:clamp(3rem,6vw,4.5rem) 0 2rem}
.foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.2fr;gap:2.2rem}
.foot .brand{color:#fff;margin-bottom:1rem}
.foot .blurb{font-size:.95rem;max-width:24rem;margin-bottom:1.2rem;color:#aecabd}
.foot-col h4{font-family:"Oswald",sans-serif;font-weight:600;text-transform:uppercase;letter-spacing:.12em;
  font-size:.82rem;color:#fff;margin-bottom:1rem}
.foot-col a{display:block;margin-bottom:.6rem;color:#bcd6c9;font-size:.94rem;transition:.2s}
.foot-col a:hover{color:#fff;padding-left:4px}
.foot-contact div{display:flex;gap:.6rem;align-items:flex-start;margin-bottom:.7rem;font-size:.92rem;color:#bcd6c9}
.foot-contact svg{width:18px;height:18px;color:var(--green);flex:0 0 18px;margin-top:.2rem}
.foot-bottom{border-top:1px solid rgba(255,255,255,.12);margin-top:2.4rem;padding-top:1.5rem;
  display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;font-size:.85rem;color:#9bbbab}
.foot-bottom .disc{max-width:46rem}
@media(max-width:860px){.foot-grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.foot-grid{grid-template-columns:1fr}}

/* ============================ COOKIE BANNER ============================ */
.cookie{position:fixed;left:1rem;right:1rem;bottom:1rem;z-index:80;max-width:760px;margin-inline:auto;
  background:#fff;border:1px solid var(--line);border-left:5px solid var(--green);border-radius:12px;
  box-shadow:0 24px 60px -20px rgba(8,40,28,.5);padding:1.2rem 1.4rem;
  display:flex;gap:1.2rem;align-items:center;flex-wrap:wrap;transform:translateY(160%);transition:transform .45s cubic-bezier(.6,0,.2,1)}
.cookie.show{transform:translateY(0)}
.cookie p{font-size:.9rem;color:var(--ink-soft);flex:1;min-width:240px}
.cookie p a{color:var(--green-deep);text-decoration:underline}
.cookie .acts{display:flex;gap:.7rem;flex-wrap:wrap}
.cookie .btn{padding:.7rem 1.2rem;font-size:.82rem}

/* ============================ scroll reveal ============================ */
.rv{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s ease}
.rv.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.rv{opacity:1;transform:none;transition:none}}

/* ============================ HERO responsive ============================ */
@media(max-width:960px){
  .nav-menu{display:none}
  .burger{display:flex}
  .hero-grid{grid-template-columns:1fr;gap:2.5rem}
  .hero-visual{order:2;margin-top:.5rem}
  .hero{min-height:auto;padding:7.5rem 0 3.5rem}
}
@media(max-width:520px){
  .hero-cta{flex-direction:column;align-items:stretch}
  .hero-cta .btn,.hero-cta .gplay{width:100%}
}

/* legal / content pages */
.page-hero{background:var(--green-ink);color:#fff;padding:8rem 0 3rem;position:relative;overflow:hidden}
.page-hero::after{content:"";position:absolute;inset:0;opacity:.1;background:repeating-linear-gradient(-45deg,#fff 0 2px,transparent 2px 28px)}
.page-hero .shell{position:relative}
.page-hero h1{font-family:"Oswald",sans-serif;font-weight:700;text-transform:uppercase;font-size:clamp(2.4rem,6vw,4rem);line-height:.95}
.page-hero p{color:#bcd6c9;margin-top:.7rem}
.prose{max-width:52rem;margin:0 auto;padding:clamp(2.5rem,6vw,4rem) 0}
.prose h2{font-family:"Oswald",sans-serif;font-weight:700;text-transform:uppercase;letter-spacing:.01em;
  font-size:1.5rem;margin:2.2rem 0 .8rem;color:var(--ink)}
.prose h2:first-child{margin-top:0}
.prose p,.prose li{color:var(--ink-soft);margin-bottom:.9rem}
.prose ul{padding-left:1.3rem;margin-bottom:1rem}
.prose a{color:var(--green-deep);text-decoration:underline}
.prose .meta{color:var(--muted);font-size:.9rem;margin-bottom:2rem}
.contact-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;margin:2rem 0}
@media(max-width:760px){.contact-cards{grid-template-columns:1fr}}
.cc{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:1.6rem}
.cc .fi{width:46px;height:46px;border-radius:11px;background:rgba(15,169,88,.12);color:var(--green-deep);display:grid;place-items:center;margin-bottom:.9rem}
.cc h3{font-family:"Oswald",sans-serif;font-weight:600;text-transform:uppercase;font-size:1.1rem;margin-bottom:.3rem}
.cc p,.cc a{color:var(--muted);font-size:.95rem}
.cc a{color:var(--green-deep)}

/* 404 */
.nf{min-height:80vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:1.2rem;padding:6rem 1rem}
.nf .big{font-family:"Oswald",sans-serif;font-weight:700;font-size:clamp(5rem,20vw,12rem);line-height:.85;color:var(--green)}
