/* =====================================================================
   Bolão da Copa — SH Pardo + Corpore
   Conceito: "Estádio em Movimento" — design esportivo cinético,
   estética de transmissão (broadcast), tipografia condensada com
   sensação de velocidade. Paleta: teal SH Pardo + verde-limão.
   ===================================================================== */
:root{
  --teal:#3C99A3;
  --teal-deep:#226069;
  --lime:#C0EC2E;
  --lime-deep:#9bc40f;
  --green:#0A7A2A;
  --br-green:#0A7A2A;
  --br-yellow:#FFDF00;
  --ink:#091420;
  --ink-2:#0E2532;
  --ink-3:#13313f;
  --gold:#FFC94D;
  --silver:#CBD5DA;
  --bronze:#E08A4B;
  --paper:#EFF5F4;
  --white:#fff;
  --muted:#5b7077;
  --muted-2:#8aa0a5;
  --line:#e1ecec;
  --shadow:0 14px 38px rgba(9,20,32,.12);
  --shadow-lg:0 34px 80px rgba(9,20,32,.30);
  --radius:20px;
  --radius-sm:13px;
  --maxw:1180px;
  --display:'Anton',Impact,sans-serif;
  --head:'Archivo','Inter',system-ui,sans-serif;
  --body:'Inter',system-ui,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:var(--body);color:var(--ink);
  background:var(--paper);line-height:1.65;-webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:var(--teal-deep);text-decoration:none}
h1,h2,h3,h4{font-family:var(--head);line-height:1.04;margin:0 0 .4em;font-weight:800;letter-spacing:-.01em}
.container{max-width:var(--maxw);margin:0 auto;padding:0 22px}
section{padding:88px 0;position:relative}

/* Display headline (Anton, condensado) */
.display{font-family:var(--display);font-weight:400;letter-spacing:.005em;line-height:.95;text-transform:uppercase}

/* Kicker em itálico inclinado = sensação de movimento */
.kicker{display:inline-block;font-family:var(--head);font-weight:800;font-style:italic;
  letter-spacing:.14em;text-transform:uppercase;font-size:.78rem;color:var(--teal);
  transform:skewX(-6deg)}

/* Reveal on scroll */
[data-reveal]{opacity:0;transform:translateY(28px);transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1)}
[data-reveal].is-in{opacity:1;transform:none}
[data-reveal][data-delay="1"]{transition-delay:.08s}
[data-reveal][data-delay="2"]{transition-delay:.16s}
[data-reveal][data-delay="3"]{transition-delay:.24s}
@media (prefers-reduced-motion:reduce){
  [data-reveal]{opacity:1;transform:none;transition:none}
  html{scroll-behavior:auto}
  .ticker__track{animation:none}
  .hero__bg,.hero__lines,.pitch-band__bg{transform:none !important}
}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.55em;justify-content:center;
  background:var(--teal);color:#fff;font-weight:800;font-family:var(--head);
  padding:15px 30px;border-radius:999px;border:0;cursor:pointer;font-size:.98rem;
  letter-spacing:.02em;text-transform:uppercase;position:relative;
  transition:transform .18s cubic-bezier(.2,.7,.2,1),box-shadow .18s,filter .18s;
  box-shadow:0 10px 24px rgba(60,153,163,.32);
}
.btn:hover{transform:translateY(-3px);box-shadow:0 16px 32px rgba(60,153,163,.42)}
.btn:active{transform:translateY(-1px)}
.btn--lime{background:var(--lime);color:var(--ink);box-shadow:0 10px 24px rgba(192,236,46,.45)}
.btn--lime:hover{box-shadow:0 16px 34px rgba(192,236,46,.6)}
.btn--ghost{background:transparent;color:#fff;border:2px solid rgba(255,255,255,.55);box-shadow:none;backdrop-filter:blur(4px)}
.btn--ghost:hover{background:rgba(255,255,255,.12);border-color:#fff}
.btn--block{width:100%}
.btn--sm{padding:10px 20px;font-size:.86rem}
.btn--outline{background:#fff;color:var(--teal-deep);border:2px solid var(--line);box-shadow:none}
.btn--danger{background:#e2503e;box-shadow:none}
.btn svg{width:1.05em;height:1.05em}

/* ---------- Header ---------- */
.site-header{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.86);
  backdrop-filter:blur(14px) saturate(1.2);border-bottom:1px solid var(--line);
  transition:box-shadow .25s,background .25s}
.site-header.scrolled{box-shadow:0 8px 26px rgba(9,20,32,.10)}
.site-header::before{content:"";position:absolute;left:0;right:0;top:0;height:3px;z-index:1;
  background:var(--br-green)}
.site-header__inner{display:flex;align-items:center;justify-content:space-between;
  gap:16px;min-height:74px}
.brand{display:flex;align-items:center;gap:14px;font-weight:800}
.brand__sh{height:56px;width:auto}
.brand__x{color:var(--muted-2);font-size:1.4rem;font-weight:400}
.brand__corpore{height:46px;width:auto}
.site-nav{display:flex;align-items:center;gap:24px}
.site-nav a{color:var(--ink);font-weight:600;font-size:.85rem;position:relative}
.site-nav a:not(.btn)::after{content:"";position:absolute;left:0;right:100%;bottom:-6px;height:2px;
  background:var(--lime);transition:right .25s ease}
.site-nav a:not(.btn):hover::after{right:0}
.site-nav a.is-active{color:var(--teal-deep)}
.site-nav a.is-active:not(.btn)::after{right:0;background:var(--teal)}
.site-nav a.nav-out{color:var(--muted)}
.nav-toggle{display:none;background:none;border:0;font-size:1.6rem;cursor:pointer;color:var(--ink)}

/* ---------- HERO ---------- */
.hero{position:relative;color:#fff;overflow:hidden;background:var(--ink);isolation:isolate}
.hero__bg{position:absolute;inset:-12% 0 -12% 0;z-index:0;
  background-size:cover;background-position:center 38%;will-change:transform}
.hero__scrim{position:absolute;inset:0;z-index:1;pointer-events:none;
  background:rgba(9,20,32,.82)}
.hero__lines{position:absolute;inset:0;z-index:1;opacity:.16;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='1200' height='600' fill='none' stroke='%23ffffff' stroke-width='2'%3E%3Crect x='40' y='40' width='1120' height='520' rx='4'/%3E%3Cline x1='600' y1='40' x2='600' y2='560'/%3E%3Ccircle cx='600' cy='300' r='90'/%3E%3Crect x='40' y='180' width='130' height='240'/%3E%3Crect x='1030' y='180' width='130' height='240'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:center;background-size:cover;will-change:transform}
.hero__inner{position:relative;z-index:3;display:grid;grid-template-columns:1.15fr .85fr;
  gap:48px 48px;align-items:center;padding:84px 0 120px}
.hero__side{display:flex;flex-direction:column;gap:22px}
.hero__logo{line-height:0;text-align:center}
.hero__logo img{width:min(380px,86%);height:auto;margin:0 auto;
  filter:drop-shadow(0 14px 30px rgba(0,0,0,.5))}
.hero .eyebrow{display:inline-flex;align-items:center;gap:9px;background:rgba(192,236,46,.12);
  border:1px solid rgba(192,236,46,.4);color:var(--lime);font-family:var(--head);font-weight:800;
  padding:8px 16px;border-radius:999px;font-size:.78rem;letter-spacing:.1em;text-transform:uppercase}
.hero .eyebrow svg{width:1.05em;height:1.05em}
.hero h1{font-size:clamp(2.9rem,7vw,5.6rem);color:#fff;margin:.28em 0 .3em;line-height:1.02;text-shadow:0 4px 30px rgba(0,0,0,.4)}
.hero h1 em{font-style:normal;color:var(--lime);display:inline;padding-top:.08em}
.hero p.lead{font-size:1.18rem;color:rgba(255,255,255,.82);max-width:42ch}
.hero__cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:30px}
.hero__stats{display:flex;gap:14px;margin-top:38px;flex-wrap:wrap}
.hero__stats .stat{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);
  border-radius:14px;padding:14px 20px;backdrop-filter:blur(6px)}
.hero__stats .stat b{display:block;font-family:var(--display);font-size:2.1rem;color:var(--lime);line-height:1}
.hero__stats .stat span{font-size:.78rem;color:rgba(255,255,255,.7);text-transform:uppercase;letter-spacing:.08em;font-weight:600}

/* Scoreboard card */
.scoreboard{background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.18);border-radius:24px;padding:8px;backdrop-filter:blur(12px);
  box-shadow:var(--shadow-lg)}
.scoreboard__head{display:flex;align-items:center;gap:10px;padding:18px 22px 14px;
  font-family:var(--head);font-weight:800;text-transform:uppercase;letter-spacing:.06em;
  color:#fff;font-size:1.02rem}
.scoreboard__head svg{width:1.3em;height:1.3em;color:var(--gold)}
.scoreboard__body{background:rgba(9,20,32,.42);border-radius:18px;padding:6px 18px}
.prize-row{display:flex;align-items:center;gap:14px;padding:16px 0;border-bottom:1px dashed rgba(255,255,255,.14)}
.prize-row:last-child{border-bottom:0}
.prize-row .info{display:flex;flex-direction:column}
.prize-row b{color:#fff;font-family:var(--head);font-weight:700;font-size:1.02rem}
.prize-row span.pos{color:rgba(255,255,255,.65);font-size:.78rem;text-transform:uppercase;letter-spacing:.08em}
.prize-row .val{margin-left:auto;color:var(--lime);font-family:var(--display);font-size:1.5rem;white-space:nowrap}

/* ---------- Medalha em CSS (sem emoji) ---------- */
.medal{--c2:#e0a020;flex:none;width:46px;height:46px;border-radius:50%;
  display:grid;place-items:center;position:relative;
  background:var(--c2);
  box-shadow:inset 0 2px 4px rgba(255,255,255,.6),inset 0 -3px 6px rgba(0,0,0,.25),0 6px 14px rgba(0,0,0,.3);
  font-family:var(--display);color:#5b3d00;font-size:1.25rem;line-height:1}
.medal::before{content:"";position:absolute;inset:5px;border-radius:50%;border:2px dashed rgba(0,0,0,.18)}
.medal--1{--c2:#e0a31e}
.medal--2{--c2:#9fb0b8;color:#374049}
.medal--3{--c2:#c06a2e;color:#4a2400}
.medal--lg{width:84px;height:84px;font-size:2.3rem}

/* ---------- Ticker (faixa em movimento) ---------- */
.ticker{position:relative;z-index:3;background:var(--br-green);color:#fff;overflow:hidden;
  border-top:3px solid var(--ink);border-bottom:3px solid var(--ink)}
.ticker__track{display:flex;gap:0;white-space:nowrap;animation:ticker 26s linear infinite;will-change:transform}
.ticker__track span{display:inline-flex;align-items:center;gap:18px;padding:11px 26px;
  font-family:var(--display);text-transform:uppercase;letter-spacing:.06em;font-size:1.02rem}
.ticker__track span::after{content:"";width:9px;height:9px;border-radius:50%;background:var(--br-yellow)}
@keyframes ticker{to{transform:translateX(-50%)}}
.ticker:hover .ticker__track{animation-play-state:paused}

/* ---------- Section heads ---------- */
.sec-head{max-width:680px;margin:0 auto 54px;text-align:center}
.sec-head h2{font-size:clamp(2.1rem,4.6vw,3.2rem);margin-top:.18em;text-transform:uppercase}
.sec-head p{color:var(--muted);font-size:1.05rem}

/* ---------- Steps ---------- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.step{position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:32px 26px 28px;box-shadow:var(--shadow);overflow:hidden;
  transition:transform .25s,box-shadow .25s,border-color .25s}
.step::before{content:"";position:absolute;left:0;top:0;width:100%;height:5px;
  background:var(--lime);transform:scaleX(0);transform-origin:left;transition:transform .3s}
.step:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg);border-color:transparent}
.step:hover::before{transform:scaleX(1)}
.step__n{font-family:var(--display);font-size:3.4rem;line-height:.8;color:transparent;
  -webkit-text-stroke:2px var(--teal);margin-bottom:14px;display:block;transition:color .3s}
.step:hover .step__n{color:var(--lime);-webkit-text-stroke:2px var(--lime)}
.step h3{font-family:var(--head);font-size:1.16rem;font-weight:800;margin-bottom:.35em;text-transform:uppercase;letter-spacing:.01em}
.step p{color:var(--muted);font-size:.95rem;margin:0}

/* ---------- Scoring (placar) ---------- */
.scoring{background:var(--ink);color:#fff;overflow:hidden}
.scoring .sec-head h2{color:#fff}
.scoring .sec-head p{color:rgba(255,255,255,.7)}
.score-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px;max-width:820px;margin:0 auto}
.score-card{position:relative;background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.16);border-radius:var(--radius);padding:38px 30px;text-align:center;
  transition:transform .25s,border-color .25s}
.score-card:hover{transform:translateY(-6px);border-color:rgba(192,236,46,.5)}
.score-card .pts{font-family:var(--display);font-size:4.4rem;line-height:.9;color:var(--lime)}
.score-card .pts span{font-family:var(--head);font-weight:800;font-size:1.15rem;text-transform:uppercase;letter-spacing:.04em;
  -webkit-text-fill-color:var(--lime);color:var(--lime)}
.score-card h3{color:#fff;font-family:var(--head);font-weight:800;font-size:1.18rem;margin:.5em 0 .25em;text-transform:uppercase}
.score-card p{color:rgba(255,255,255,.72);margin:0;font-size:.95rem}

/* ---------- Parallax band (gramado) ---------- */
.pitch-band{position:relative;color:#fff;text-align:center;overflow:hidden;padding:0;isolation:isolate}
.pitch-band__bg{position:absolute;inset:-18% 0;z-index:0;background-size:cover;background-position:center;will-change:transform}
.pitch-band__inner{position:relative;z-index:2;padding:120px 0;
  background:rgba(9,20,32,.66)}
.pitch-band h2{font-family:var(--display);font-size:clamp(2.2rem,5vw,3.6rem);color:#fff;text-transform:uppercase}
.pitch-band h2 em{font-style:normal;color:var(--lime)}
.pitch-band p{color:rgba(255,255,255,.85);max-width:54ch;margin:0 auto;font-size:1.1rem}

/* ---------- Prizes (pódio) ---------- */
.prizes{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;align-items:end}
.prize-card{position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:36px 28px 32px;text-align:center;box-shadow:var(--shadow);overflow:hidden;
  transition:transform .25s,box-shadow .25s}
.prize-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg)}
.prize-card .medal{margin:0 auto 16px}
.prize-card--1{border:2px solid var(--gold);box-shadow:0 24px 60px rgba(255,201,77,.28)}
.prize-card--1::after{content:"CAMPEÃO";position:absolute;top:16px;right:-34px;transform:rotate(45deg);
  background:var(--gold);color:#5b3d00;font-family:var(--head);font-weight:900;font-size:.66rem;
  letter-spacing:.12em;padding:5px 40px}
@media (min-width:901px){.prize-card--1{transform:translateY(-22px)}.prize-card--1:hover{transform:translateY(-30px)}}
.prize-card .pos{font-family:var(--head);font-weight:900;font-size:.86rem;color:var(--teal-deep);
  text-transform:uppercase;letter-spacing:.12em}
.prize-card h3{font-family:var(--head);font-weight:800;font-size:1.22rem;margin:.25em 0 .1em;text-transform:uppercase}
.prize-card .value{display:inline-block;margin-top:12px;background:var(--ink);
  color:var(--lime);font-family:var(--display);font-size:1.35rem;padding:6px 20px;border-radius:999px}
.prizes-note{text-align:center;color:var(--muted);margin:32px auto 0;max-width:62ch;font-size:.93rem}

/* ---------- CTA band ---------- */
.cta-band{position:relative;overflow:hidden;text-align:center;color:#fff;
  background:var(--teal)}
.cta-band::before{content:"";position:absolute;inset:0;opacity:.18;
  background-image:repeating-linear-gradient(115deg,transparent 0 38px,rgba(255,255,255,.5) 38px 41px)}
.cta-band .container{position:relative;z-index:2}
.cta-band h2{color:#fff;font-family:var(--display);font-size:clamp(2.1rem,5vw,3.4rem);text-transform:uppercase}
.cta-band p{color:rgba(255,255,255,.92);max-width:48ch;margin:0 auto 28px;font-size:1.08rem}

/* ---------- Forms / auth ---------- */
.auth{display:grid;place-items:center;padding:64px 0;position:relative}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:38px}
.auth .card{width:100%;max-width:500px}
.card h1{font-family:var(--head);font-size:1.9rem;text-transform:uppercase}
.field{margin-bottom:17px}
.field label{display:block;font-weight:700;font-size:.9rem;margin-bottom:6px;font-family:var(--head)}
.field input,.field select{width:100%;padding:13px 15px;border:1.5px solid var(--line);
  border-radius:var(--radius-sm);font:inherit;background:#fff;transition:border .15s,box-shadow .15s}
.field input:focus,.field select:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 4px rgba(60,153,163,.12)}
.field .hint{font-size:.82rem;color:var(--muted);margin-top:4px}
.checkbox{display:flex;gap:10px;align-items:flex-start;font-size:.92rem;color:var(--muted)}
.checkbox input{width:auto;margin-top:4px}
.form-foot{margin-top:18px;text-align:center;color:var(--muted);font-size:.92rem}

/* ---------- Flash ---------- */
.flash{max-width:var(--maxw);margin:16px auto 0;padding:14px 18px;border-radius:var(--radius-sm);font-weight:600}
.flash--ok{background:#e7f7ed;color:#1d6b3a;border:1px solid #b9e6c9}
.flash--erro{background:#fdecea;color:#b4271a;border:1px solid #f5c6bf}
.flash--info{background:#e9f3f4;color:var(--teal-deep);border:1px solid #c5e2e5}

/* ---------- Tables ---------- */
.table-wrap{overflow-x:auto;background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}
table.data{width:100%;border-collapse:collapse;min-width:520px}
table.data th,table.data td{padding:14px 16px;text-align:left;border-bottom:1px solid var(--line)}
table.data th{background:var(--paper);font-family:var(--head);font-size:.78rem;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}
table.data tr:last-child td{border-bottom:0}
table.data tbody tr:hover{background:#f6fbfb}

/* ---------- Ranking ---------- */
.rank-pos{font-weight:800;font-family:var(--display);font-size:1.3rem;color:var(--teal-deep)}
.rank-row--1 td{background:rgba(255,201,77,.14)}
.rank-row--2 td{background:rgba(160,170,176,.12)}
.rank-row--3 td{background:rgba(224,138,75,.11)}
.badge{display:inline-block;font-family:var(--head);font-size:.7rem;font-weight:800;padding:3px 10px;border-radius:999px;text-transform:uppercase;letter-spacing:.05em}
.badge--corpore{background:var(--lime);color:var(--ink)}
.badge--pts{background:var(--teal);color:#fff;font-size:.95rem;padding:5px 12px;font-family:var(--display)}
.badge--ok{background:#1f9d57;color:#fff}
.badge--wait{background:#f3e3b3;color:#7a5a00}

/* ---------- Banner de verificação de e-mail ---------- */
.verify-bar{background:#fff8e1;border-bottom:1px solid #f0e2b0}
.verify-bar__inner{display:flex;gap:14px;align-items:center;justify-content:space-between;flex-wrap:wrap;
  padding:11px 0;font-size:.92rem;color:#7a5a00}
.verify-bar form{margin:0;flex:0 0 auto}

/* ---------- Paginação (admin) ---------- */
.pager{display:flex;gap:14px;align-items:center;justify-content:center;margin:20px 0}
.pager__info{color:var(--muted);font-size:.9rem}

/* ---------- Palpites ---------- */
/* Aviso (palpites) */
.notice{max-width:1100px;margin:0 auto 22px;padding:13px 18px;border-radius:var(--radius-sm);font-size:.92rem;line-height:1.5;
  display:flex;gap:10px;align-items:flex-start}
.notice__text{flex:1;min-width:0}
.notice--warn{background:#fff8e6;color:#73560a;border:1px solid #f3e0a8}
.notice--warn::before{content:"⚠️";font-size:1.05rem;line-height:1.4;flex:none}

/* Lista compacta de jogos */
.match-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(310px,1fr));gap:12px;max-width:1100px;margin:0 auto;align-items:start}
.match-day{grid-column:1/-1;display:flex;align-items:center;gap:12px;margin:16px 0 2px;
  font-family:var(--head);font-weight:800;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);font-size:.82rem}
.match-day:first-child{margin-top:0}
.match-day::after{content:"";flex:1;height:1px;background:var(--line)}
.match{background:#fff;border:1px solid var(--line);border-radius:14px;padding:12px 14px;box-shadow:var(--shadow);transition:border-color .2s,box-shadow .2s}
.match:hover{border-color:var(--teal);box-shadow:var(--shadow-lg)}
.match--locked{opacity:.72}
.match__top{display:flex;justify-content:space-between;align-items:center;font-size:.7rem;color:var(--muted);margin-bottom:9px;font-family:var(--head);text-transform:uppercase;letter-spacing:.04em}
.match__tag{background:var(--paper);padding:3px 9px;border-radius:999px;font-weight:700}
.match__time{font-weight:700}
.match__row{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:8px}
.team{display:flex;align-items:center;gap:7px;font-weight:700;font-family:var(--head);min-width:0}
.team__name{font-size:.86rem;line-height:1.15;white-space:normal}
.team .flag{font-size:1.25rem;flex:none}
.team--away{justify-content:flex-end;text-align:right}
.match__score{display:flex;align-items:center;gap:5px}
.score-input{width:40px;height:42px;text-align:center;font-size:1.2rem;font-weight:700;font-family:var(--display);border:1.5px solid var(--line);border-radius:9px;transition:border .15s,box-shadow .15s;padding:0}
.score-input:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px rgba(60,153,163,.12)}
.score-input:disabled{background:var(--paper);color:var(--ink)}
.match__vs{font-family:var(--display);color:var(--muted-2);font-size:.95rem}
.match__status{display:flex;justify-content:space-between;align-items:center;margin-top:10px;padding-top:9px;border-top:1px solid var(--line);font-size:.78rem;gap:8px}
.lock{color:#b4271a;font-weight:700}
.pts-tag{font-weight:800;color:var(--green);font-family:var(--head)}
.result-final{color:var(--muted)}
.palpites-bar{position:sticky;bottom:0;z-index:5;text-align:center;margin-top:26px;padding:16px 0;
  background:var(--paper);border-top:1px solid var(--line)}

/* ---------- Footer ---------- */
.site-footer{background:var(--ink);color:rgba(255,255,255,.8);padding:56px 0 30px;position:relative;overflow:hidden}
.site-footer::before{content:"";position:absolute;inset:0 0 auto 0;height:4px;background:var(--br-green)}
.site-footer__inner{display:grid;grid-template-columns:1.4fr 1fr;gap:30px;align-items:start}
.site-footer__brand img{height:40px;margin-bottom:14px}
.site-footer__nav{display:flex;flex-direction:column;gap:9px}
.site-footer__nav a{color:rgba(255,255,255,.8);font-family:var(--head);font-weight:600;font-size:.85rem}
.site-footer__nav a:hover{color:var(--lime)}
.site-footer__legal{grid-column:1/-1;border-top:1px solid rgba(255,255,255,.12);padding-top:18px;font-size:.74rem;color:rgba(255,255,255,.55);line-height:1.7}
.site-footer__legal a{color:rgba(255,255,255,.8);font-weight:700}
.site-footer__legal a:hover{color:var(--lime)}

/* ---------- Prose ---------- */
.prose{max-width:800px;margin:0 auto;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:44px;box-shadow:var(--shadow)}
.prose h1{font-family:var(--head);font-size:2.1rem;text-transform:uppercase}
.prose h2{font-family:var(--head);font-size:1.4rem;margin-top:1.5em;text-transform:uppercase}
.prose ol,.prose ul{padding-left:1.2em}
.prose li{margin-bottom:.5em}

/* ---------- Admin ---------- */
.admin-shell{display:grid;grid-template-columns:230px 1fr;min-height:100vh}
.admin-side{background:var(--ink);color:#fff;padding:24px 16px}
.admin-side .brand{color:#fff;margin-bottom:26px}
.admin-side .brand span{color:#fff}
.admin-side .brand img{height:30px}
.admin-side nav{display:flex;flex-direction:column;gap:3px}
.admin-side nav a{color:rgba(255,255,255,.75);padding:9px 13px;border-radius:10px;font-weight:600;font-size:.84rem;font-family:var(--head);transition:background .15s,color .15s}
.admin-side nav a:hover{background:rgba(255,255,255,.08);color:#fff}
.admin-side nav a.is-active{background:var(--teal);color:#fff}
.admin-side .admin-out{margin-top:22px;color:rgba(255,255,255,.55);font-size:.82rem}
.admin-main{padding:30px 34px;background:var(--paper);font-size:.92rem}
.admin-main .admin-topbar h1{font-size:1.45rem}
.admin-main h2{font-size:1.05rem}
.admin-main table.data th,.admin-main table.data td{padding:10px 13px;font-size:.86rem}
.admin-main .kpi{padding:18px}
.admin-main .kpi b{font-size:2rem}
.admin-topbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:28px;flex-wrap:wrap;gap:12px}
.admin-topbar h1{font-family:var(--head);font-size:1.9rem;margin:0;text-transform:uppercase}
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:28px}
.kpi{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow)}
.kpi b{display:block;font-family:var(--display);font-size:2.4rem;color:var(--teal-deep);line-height:1}
.kpi span{color:var(--muted);font-size:.86rem;text-transform:uppercase;letter-spacing:.05em;font-family:var(--head);font-weight:600}
.toolbar{display:flex;gap:12px;flex-wrap:wrap;align-items:center;margin-bottom:18px}
.toolbar input[type=search]{padding:11px 14px;border:1.5px solid var(--line);border-radius:var(--radius-sm);min-width:240px;font:inherit}
.inline-form{display:flex;gap:8px;align-items:center}
.inline-form input[type=number]{width:54px;padding:8px;text-align:center;border:1.5px solid var(--line);border-radius:8px;font:inherit}
.admin-login{display:grid;place-items:center;min-height:100vh;background:var(--ink)}
.admin-login .card{width:100%;max-width:410px}

/* ---------- Responsive ---------- */
@media (max-width:900px){
  .hero__inner{grid-template-columns:1fr;padding:56px 0 90px}
  .hero__logo{margin:0 auto 10px;text-align:center}
  .hero__logo img{width:min(440px,84%)}
  .steps{grid-template-columns:repeat(2,1fr)}
  .score-grid{grid-template-columns:1fr}
  .prizes{grid-template-columns:1fr;max-width:420px;margin:0 auto}
  .site-footer__inner{grid-template-columns:1fr}
  .admin-shell{grid-template-columns:1fr}
  .admin-side{display:flex;flex-wrap:wrap;align-items:center;gap:6px;padding:14px}
  .admin-side .brand{margin:0 12px 0 0}
  .admin-side nav{flex-direction:row;flex-wrap:wrap}
  .kpis{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:640px){
  section{padding:60px 0}
  .site-nav{position:fixed;inset:74px 0 auto 0;background:#fff;flex-direction:column;
    align-items:stretch;padding:18px 22px;gap:14px;border-bottom:1px solid var(--line);
    box-shadow:var(--shadow);display:none}
  body.nav-open .site-nav{display:flex}
  .site-nav a:not(.btn)::after{display:none}
  .nav-toggle{display:block}
  .steps{grid-template-columns:1fr}
  .hero__stats{gap:10px}
  .kpis{grid-template-columns:1fr}
  .pitch-band__inner{padding:84px 0}
  .match-list{grid-template-columns:1fr}
}

/* ---------- Acessibilidade: skip-link + foco visível ---------- */
.skip-link{position:absolute;left:-9999px;top:0;z-index:200;background:var(--ink);color:#fff;
  padding:12px 18px;border-radius:0 0 10px 0;font-weight:700;font-family:var(--head)}
.skip-link:focus{left:0}
:focus-visible{outline:3px solid var(--teal);outline-offset:2px;border-radius:4px}
.btn:focus-visible{outline:3px solid var(--ink);outline-offset:3px}

/* ---------- Botão "compartilhar no WhatsApp" ---------- */
.share{display:inline-flex;align-items:center;gap:8px}
.share span[aria-hidden]{font-size:1.05em;line-height:1}
.cta-band__actions{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;margin-top:6px}

/* ---------- Flash: botão fechar + saída ---------- */
.flash{position:relative;display:flex;align-items:center;gap:10px;transition:opacity .3s ease,transform .3s ease}
.flash--out{opacity:0;transform:translateY(-8px)}
.flash__close{margin-left:auto;background:none;border:0;font-size:1.4rem;line-height:1;
  cursor:pointer;color:inherit;opacity:.6;padding:0 2px}
.flash__close:hover{opacity:1}

/* ---------- Resumo "sua posição" (ranking / meu desempenho) ---------- */
.rank-summary{display:flex;align-items:center;gap:22px;flex-wrap:wrap;max-width:860px;margin:0 auto 26px;
  padding:20px 24px;background:var(--ink-2);color:#fff;
  border-radius:var(--radius);box-shadow:var(--shadow)}
.rank-summary__pos{display:flex;flex-direction:column;line-height:1.05}
.rank-summary__label{font-size:.74rem;text-transform:uppercase;letter-spacing:.08em;color:var(--lime);font-weight:700;font-family:var(--head)}
.rank-summary__pos strong{font-family:var(--display);font-size:2.8rem;color:#fff}
.rank-summary__of{font-size:.8rem;color:rgba(255,255,255,.7)}
.rank-summary__stats{display:flex;gap:22px;flex-wrap:wrap}
.rank-summary__stats div{display:flex;flex-direction:column;line-height:1.1}
.rank-summary__stats b{font-family:var(--display);font-size:1.5rem;color:var(--lime)}
.rank-summary__stats span{font-size:.74rem;text-transform:uppercase;letter-spacing:.05em;color:rgba(255,255,255,.7);font-family:var(--head);font-weight:600}
.rank-summary .share{margin-left:auto}
@media (max-width:640px){
  .rank-summary{gap:16px;padding:18px}
  .rank-summary .share{margin-left:0;width:100%;justify-content:center}
}

/* ---------- Indicador "fecha em / fechado" no card de palpite ---------- */
.match__close{font-size:.72rem;font-weight:700;font-family:var(--head);text-transform:uppercase;
  letter-spacing:.04em;color:var(--teal-deep);background:#e9f3f4;border:1px solid #c5e2e5;
  padding:2px 8px;border-radius:999px;margin-left:auto;margin-right:8px}
.match__close--locked{color:#b4271a;background:#fdecea;border-color:#f5c6bf}

/* ---------- Tabela "meu desempenho": célula de pontos ---------- */
.pts-cell{display:inline-block;min-width:42px;text-align:center;font-weight:800;font-family:var(--head);
  padding:3px 10px;border-radius:999px;background:#eef1f3;color:var(--ink)}
.pts-cell--exato{background:var(--lime);color:var(--ink)}
.pts-cell--acerto{background:#e7f7ed;color:#1d6b3a}
.pts-cell--zero{background:#f1f1f1;color:var(--muted)}

/* ---------- Página de conteúdo (prose): privacidade, etc. ---------- */
.prose{max-width:760px;margin:0 auto;line-height:1.7}
.prose h1{font-family:var(--head);text-transform:uppercase;font-size:2rem;margin:0 0 6px}
.prose h2{font-family:var(--head);text-transform:uppercase;font-size:1.15rem;margin:1.8em 0 .5em;color:var(--teal-deep)}
.prose ul{padding-left:20px}
.prose li{margin:.35em 0}
.prose p{margin:.7em 0}

/* ---------- Co-branding header (Corpore = realização · SH Pardo = apoio) ---------- */
.site-header__left{display:flex;align-items:center;gap:16px;min-width:0}
.brand{display:flex;align-items:center}
.brand__corpore{height:50px;width:auto;display:block}
.brand__sponsor{display:flex;align-items:center;padding-left:16px;border-left:1px solid rgba(9,20,32,.14)}
.brand__sh{height:48px;width:auto;display:block}
.site-footer__logos{display:flex;align-items:center;gap:18px;flex-wrap:wrap;margin-bottom:14px}
.site-footer__brand img{height:46px;width:auto;margin:0}
@media (max-width:600px){
  .site-header__left{gap:10px}
  .brand__corpore{height:38px}
  .brand__sh{height:36px}
  .brand__sponsor{padding-left:10px}
}

/* ---------- Portão de acesso (login na home) ---------- */
.auth--gate{padding:clamp(28px,6vw,72px) 0}
.auth__inner{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(28px,5vw,64px);align-items:center}
.auth__intro .kicker{color:var(--teal-deep)}
.auth__intro .display{margin:.18em 0 .3em}
.auth__intro .lead{color:var(--muted);max-width:36ch}
.auth__hint{margin-top:1.1em;color:var(--muted)}
.auth__card{width:100%;max-width:430px;justify-self:end}
@media (max-width:820px){
  .auth__inner{grid-template-columns:1fr;gap:24px}
  .auth__card{justify-self:stretch;max-width:none}
}
