:root{
  --verde:#00a14b;
  --verde-2:#007a39;
  --verde-deep:#04140d;
  --amarelo:#ffdf2b;
  --amarelo-2:#ffc400;
  --azul:#1535b8;
  --azul-2:#0a1f7a;
  --vermelho:#e23b4e;
  --cream:#f6f8f3;
  --ink:#0c1a12;
  --muted:#7d8a82;
  --card:#ffffff;
  --radius:18px;
  --shadow:0 18px 40px -18px rgba(0,0,0,.55);
  --maxw:760px;
  font-size:16px;
}

*{box-sizing:border-box;margin:0;padding:0;}
html{-webkit-text-size-adjust:100%;}
body{
  font-family:'Manrope',system-ui,sans-serif;
  background:var(--verde-deep);
  color:var(--cream);
  line-height:1.55;
  min-height:100vh;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}

/* ---------- Fundo estádio ---------- */
.pitch-bg{
  position:fixed;inset:0;z-index:-2;
  background:
    radial-gradient(1100px 520px at 15% -10%, rgba(0,161,75,.32), transparent 60%),
    radial-gradient(900px 500px at 92% 0%, rgba(21,53,184,.30), transparent 60%),
    radial-gradient(700px 700px at 50% 120%, rgba(255,223,43,.10), transparent 55%),
    linear-gradient(180deg,#05160e 0%, #04120c 55%, #030d08 100%);
}
.pitch-bg::after{
  content:"";position:absolute;inset:0;opacity:.06;
  background-image:repeating-linear-gradient(90deg,#fff 0 2px,transparent 2px 84px);
  mask-image:linear-gradient(180deg,transparent,#000 40%,#000 70%,transparent);
}
.grain{
  position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:.05;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ---------- Topbar ---------- */
.topbar{
  position:sticky;top:0;z-index:40;
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:14px clamp(16px,4vw,28px);
  background:rgba(4,18,12,.72);
  backdrop-filter:blur(14px);
  border-bottom:1px solid rgba(255,255,255,.08);
}
.brand{display:flex;align-items:center;}
.brand-logo{height:37px;width:auto;display:block;}
.nav-toggle{
  display:flex;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px;
}
.nav-toggle span{width:26px;height:2.5px;background:var(--cream);border-radius:2px;transition:.3s;}
.nav-toggle.open span:nth-child(1){transform:translateY(7.5px) rotate(45deg);}
.nav-toggle.open span:nth-child(2){opacity:0;}
.nav-toggle.open span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg);}

.nav{
  position:fixed;inset:64px 0 auto 0;
  flex-direction:column;gap:2px;
  background:rgba(4,18,12,.97);
  backdrop-filter:blur(14px);
  padding:10px 16px 18px;
  border-bottom:1px solid rgba(255,255,255,.08);
  display:none;
}
.nav.open{display:flex;animation:slideDown .3s ease;}
.nav a{
  color:var(--cream);text-decoration:none;font-weight:600;font-size:1.05rem;
  padding:13px 10px;border-radius:10px;letter-spacing:.2px;
}
.nav a.active{color:var(--amarelo);background:rgba(255,223,43,.08);}
.nav-user{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:8px;padding-top:12px;border-top:1px solid rgba(255,255,255,.1);}
.nav-user-name{font-weight:700;color:var(--amarelo);font-size:.95rem;}
.btn-sair{background:rgba(226,59,78,.16);color:#ff9aa5;border:1px solid rgba(226,59,78,.4);border-radius:9px;padding:7px 14px;font-weight:700;cursor:pointer;font-size:.85rem;}
.btn-sair:active{transform:scale(.96);}

@media(min-width:780px){
  .nav-toggle{display:none;}
  .nav{position:static;display:flex;flex-direction:row;align-items:center;background:none;backdrop-filter:none;border:0;padding:0;inset:auto;}
  .nav a{padding:8px 12px;font-size:.98rem;}
  .nav-user{margin:0 0 0 8px;padding:0 0 0 14px;border-top:0;border-left:1px solid rgba(255,255,255,.14);}
}

/* ---------- Layout ---------- */
.app{max-width:var(--maxw);margin:0 auto;padding:clamp(18px,4vw,30px) clamp(16px,4vw,24px) 40px;}
.view{animation:fadeUp .5s ease both;}

/* ---------- Tipografia ---------- */
.display{font-family:'Anton',sans-serif;font-weight:400;letter-spacing:.5px;line-height:.92;text-transform:uppercase;}
.eyebrow{font-weight:800;letter-spacing:3px;text-transform:uppercase;font-size:.72rem;color:var(--amarelo);}

/* ---------- Hero ---------- */
.hero{text-align:center;padding:14px 0 8px;}
.hero .pill{
  display:inline-flex;gap:8px;align-items:center;
  background:linear-gradient(90deg,var(--amarelo),var(--amarelo-2));
  color:#06210f;font-weight:800;letter-spacing:2px;font-size:.72rem;
  padding:7px 16px;border-radius:30px;box-shadow:0 8px 20px -8px rgba(255,223,43,.6);
  animation:pop .6s .1s both;
}
.hero h1{
  font-family:'Anton',sans-serif;text-transform:uppercase;
  font-size:clamp(3rem,16vw,6rem);line-height:.86;margin:14px 0 6px;
  background:linear-gradient(180deg,#fff,#cfe9d6);-webkit-background-clip:text;background-clip:text;color:transparent;
  text-shadow:0 6px 30px rgba(0,161,75,.25);
}
.hero h1 .accent{
  display:block;
  background:linear-gradient(180deg,var(--amarelo),var(--amarelo-2));-webkit-background-clip:text;background-clip:text;color:transparent;
}
.hero .sub{color:#bcd3c5;font-size:1.02rem;max-width:30ch;margin:6px auto 0;}

.cta{
  display:inline-flex;align-items:center;gap:10px;margin-top:22px;
  background:linear-gradient(135deg,var(--verde),var(--verde-2));
  color:#fff;font-weight:800;font-size:1.05rem;letter-spacing:.3px;
  padding:16px 32px;border:0;border-radius:40px;cursor:pointer;text-decoration:none;
  box-shadow:0 14px 30px -10px rgba(0,161,75,.7), inset 0 1px 0 rgba(255,255,255,.25);
  transition:transform .12s ease, box-shadow .2s;animation:pop .6s .2s both;
}
.cta:hover{transform:translateY(-2px);box-shadow:0 20px 36px -10px rgba(0,161,75,.8);}
.cta:active{transform:translateY(1px) scale(.99);}
.cta .ball{animation:spin 4s linear infinite;font-size:1.2em;}

/* ---------- Cards ---------- */
.card{
  background:var(--card);color:var(--ink);border-radius:var(--radius);
  box-shadow:var(--shadow);overflow:hidden;
}
.section-title{
  display:flex;align-items:center;gap:12px;margin:34px 4px 16px;
}
.section-title h2{font-family:'Anton',sans-serif;text-transform:uppercase;font-size:1.7rem;letter-spacing:.5px;color:#fff;}
.section-title .line{flex:1;height:3px;border-radius:3px;background:linear-gradient(90deg,var(--amarelo),transparent);}

/* Como participar */
.steps{display:grid;gap:12px;margin-top:8px;}
.step{
  display:flex;gap:14px;align-items:flex-start;background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:14px 16px;
  animation:fadeUp .5s both;
}
.step .n{
  flex:none;width:30px;height:30px;border-radius:50%;display:grid;place-items:center;
  font-weight:800;color:#06210f;background:linear-gradient(135deg,var(--amarelo),var(--amarelo-2));
}
.step p{color:#d6e4da;font-size:.95rem;}
.step b{color:#fff;}

/* Prêmios */
.prizes{display:grid;gap:14px;grid-template-columns:1fr;margin-top:8px;}
@media(min-width:640px){.prizes{grid-template-columns:repeat(3,1fr);}}
.prize{
  position:relative;border-radius:16px;padding:20px 16px;text-align:center;overflow:hidden;
  background:linear-gradient(160deg,#0c2a18,#071c11);
  border:1px solid rgba(255,255,255,.08);animation:fadeUp .5s both;
}
.prize .medal{font-size:1.8rem;min-height:120px;display:flex;align-items:center;justify-content:center;}
.prize .medal img{height:120px;width:auto;object-fit:contain;filter:drop-shadow(0 10px 16px rgba(0,0,0,.5));}
.prize .jogo{font-size:.7rem;letter-spacing:1.5px;color:var(--amarelo);font-weight:800;text-transform:uppercase;margin-top:6px;}
.prize .nome{font-weight:800;color:#fff;margin-top:4px;font-size:1.05rem;}
.prize::before{content:"";position:absolute;inset:0;background:radial-gradient(120px 60px at 50% 0,rgba(255,223,43,.18),transparent);}

/* ---------- Jogo card (palpite) ---------- */
.match{margin-bottom:26px;animation:fadeUp .5s both;}
.match-head{
  display:flex;align-items:center;justify-content:space-between;gap:8px;
  padding:12px 16px;background:linear-gradient(135deg,var(--azul-2),var(--azul));color:#fff;
}
.match-head .when{font-size:.78rem;font-weight:700;color:#cdd6ff;}
.match-prize{font-size:.72rem;font-weight:800;color:var(--amarelo);letter-spacing:.5px;display:flex;align-items:center;gap:5px;}
.match-prize .thumb{height:42px;width:auto;object-fit:contain;filter:drop-shadow(0 3px 6px rgba(0,0,0,.4));}
.match-body{padding:18px 12px;}
/* Linha única: time(bandeira+nome) | placar | × | placar | time */
.match-row{display:flex;align-items:flex-start;justify-content:center;gap:8px;}
.team{display:flex;flex-direction:column;align-items:center;gap:7px;flex:1 1 0;min-width:0;max-width:120px;}
.flag{
  width:92px;height:62px;border-radius:8px;object-fit:cover;
  box-shadow:0 6px 14px -4px rgba(0,0,0,.5);border:1px solid rgba(0,0,0,.1);
}
.team-name{font-weight:800;font-size:.84rem;text-align:center;color:var(--ink);letter-spacing:.3px;text-transform:uppercase;line-height:1.15;}

/* Placar editável no meio da linha */
.score-col{display:flex;flex-direction:column;align-items:center;gap:8px;flex:0 0 auto;}
.stepper{display:flex;align-items:center;gap:8px;}
.stepper button{
  width:34px;height:34px;border-radius:11px;border:0;cursor:pointer;font-size:1.35rem;line-height:1;font-weight:800;
  background:var(--verde);color:#fff;display:grid;place-items:center;transition:transform .08s, background .2s;
  box-shadow:0 4px 0 var(--verde-2);
}
.stepper button:active{transform:translateY(3px);box-shadow:0 1px 0 var(--verde-2);}
.stepper.b button{background:var(--vermelho);box-shadow:0 4px 0 #b32a3a;}
.stepper.b button:active{box-shadow:0 1px 0 #b32a3a;}
.score-val{
  font-family:'Anton',sans-serif;font-size:2.6rem;min-width:46px;text-align:center;color:var(--ink);
  background:var(--cream);border-radius:12px;padding:2px 6px;border:2px solid rgba(0,0,0,.06);line-height:1.1;
}
.match-row .x{font-family:'Anton',sans-serif;font-size:1.5rem;color:var(--muted);align-self:flex-start;margin-top:10px;flex:0 0 auto;}

.match-foot{padding:0 16px 18px;display:flex;flex-direction:column;gap:10px;}
.countdown{
  text-align:center;font-size:.82rem;font-weight:700;color:var(--azul);
  background:rgba(21,53,184,.08);border-radius:10px;padding:8px;
}
.countdown.urgent{color:var(--vermelho);background:rgba(226,59,78,.1);}
.btn-save{
  width:100%;background:linear-gradient(135deg,var(--verde),var(--verde-2));color:#fff;border:0;
  padding:15px;border-radius:14px;font-weight:800;font-size:1.05rem;cursor:pointer;letter-spacing:.3px;
  box-shadow:0 10px 22px -10px rgba(0,161,75,.7);transition:transform .1s;
}
.btn-save:active{transform:scale(.99);}
.btn-save:disabled{opacity:.55;cursor:not-allowed;}
.locked-note{text-align:center;color:var(--muted);font-size:.85rem;font-weight:600;}
.saved-badge{display:inline-flex;align-items:center;gap:6px;background:rgba(0,161,75,.12);color:var(--verde-2);font-weight:800;font-size:.78rem;padding:5px 12px;border-radius:20px;}

/* ---------- Aviso de palpite não salvo ---------- */
.unsaved-banner{
  position:sticky;top:72px;z-index:30;margin:0 0 16px;
  background:linear-gradient(135deg,var(--amarelo),var(--amarelo-2));color:#5a3d00;
  border:1px solid var(--amarelo-2);border-radius:14px;padding:12px 16px;
  font-size:.86rem;font-weight:700;text-align:center;line-height:1.4;
  box-shadow:0 10px 24px -12px rgba(0,0,0,.5);
}
.unsaved-banner b{color:#3d2900;}
.unsaved-note{display:none;margin-top:10px;text-align:center;font-size:.82rem;font-weight:700;color:#9a5b00;background:rgba(255,196,0,.16);border-radius:10px;padding:8px 10px;}
.match.dirty{outline:2px solid var(--amarelo-2);outline-offset:2px;}
.match.dirty .unsaved-note{display:block;}
.match.dirty .btn-save{
  background:linear-gradient(135deg,var(--amarelo-2),#e09b00);color:#3d2900;
  box-shadow:0 10px 22px -10px rgba(224,155,0,.8);animation:pulseSave 1.2s ease-in-out infinite;
}
@keyframes pulseSave{0%,100%{transform:scale(1);}50%{transform:scale(1.025);}}

/* ---------- Resultados ---------- */
.result{margin-bottom:16px;}
.result .placar-final{font-family:'Anton',sans-serif;font-size:2rem;color:var(--ink);text-align:center;}
.result-row{display:flex;justify-content:space-between;gap:8px;padding:10px 16px;border-top:1px solid rgba(0,0,0,.06);font-size:.9rem;color:var(--ink);}
.result-row b{color:var(--ink);}
.hit{color:var(--verde-2);font-weight:800;}
.miss{color:var(--vermelho);font-weight:800;}
.chips{display:flex;flex-wrap:wrap;gap:6px;padding:6px 16px 14px;}
.chip{background:rgba(0,161,75,.1);color:var(--verde-2);font-weight:700;font-size:.75rem;padding:4px 10px;border-radius:14px;}

/* ---------- Login ---------- */
.auth-card{max-width:420px;margin:20px auto 28px;padding:26px 22px;}
.auth-card h2{font-family:'Anton',sans-serif;text-transform:uppercase;color:var(--ink);font-size:1.8rem;text-align:center;}
.auth-card p.lead{color:var(--muted);text-align:center;font-size:.92rem;margin:4px 0 20px;}
.dest-hint{font-size:.78rem;line-height:1.5;color:var(--muted);background:#f4f7f3;border:1px solid #e3eadf;border-radius:10px;padding:10px 12px;margin-bottom:14px;text-align:center;}
.dest-hint b{color:#3a463e;font-weight:700;}
.field{margin-bottom:14px;}
.field label{display:block;font-weight:700;font-size:.82rem;color:#3a463e;margin-bottom:6px;}
.field input{
  width:100%;padding:14px 16px;border:2px solid #dde4dc;border-radius:12px;font-size:1.05rem;color:var(--ink);
  font-family:inherit;transition:border-color .2s;background:#fff;
}
.field input:focus{outline:0;border-color:var(--verde);}
.field input.code{text-align:center;letter-spacing:.5em;font-family:'Anton',sans-serif;font-size:1.8rem;padding-left:.5em;}
.err{color:var(--vermelho);font-size:.82rem;font-weight:600;min-height:1.1em;margin-top:6px;}
.btn-primary{
  width:100%;background:linear-gradient(135deg,var(--verde),var(--verde-2));color:#fff;border:0;
  padding:15px;border-radius:12px;font-weight:800;font-size:1.05rem;cursor:pointer;margin-top:6px;
  box-shadow:0 10px 22px -10px rgba(0,161,75,.7);
}
.btn-primary:disabled{opacity:.6;cursor:wait;}
.btn-link{background:none;border:0;color:var(--azul);font-weight:700;cursor:pointer;font-size:.88rem;margin-top:14px;text-decoration:underline;}
.ts-box{margin:10px 0;display:flex;justify-content:center;}

/* ---------- Regulamento ---------- */
.reg{padding:24px 22px;color:var(--ink);}
.reg h2{font-family:'Anton',sans-serif;text-transform:uppercase;font-size:1.7rem;margin-bottom:6px;}
.reg h3{margin:18px 0 6px;color:var(--verde-2);font-size:1.05rem;}
.reg p{color:#34423a;font-size:.92rem;margin-bottom:8px;}

/* ---------- Footer ---------- */
.site-footer{
  text-align:center;color:#7fa590;font-size:.7rem;letter-spacing:1.5px;padding:26px 16px;
  border-top:1px solid rgba(255,255,255,.07);margin-top:20px;
}
.footer-flag{display:flex;justify-content:center;gap:0;margin-bottom:12px;}
.footer-flag i{width:40px;height:5px;border-radius:3px;}
.footer-flag i:nth-child(1){background:var(--verde);}
.footer-flag i:nth-child(2){background:var(--amarelo);}
.footer-flag i:nth-child(3){background:var(--azul);}

/* ---------- Loading / empty ---------- */
.loader{text-align:center;padding:50px 0;color:#bcd3c5;}
.spinner{width:42px;height:42px;border:4px solid rgba(255,255,255,.15);border-top-color:var(--amarelo);border-radius:50%;margin:0 auto 14px;animation:spin 1s linear infinite;}
.empty{text-align:center;color:#bcd3c5;padding:40px 16px;}

/* ---------- Toast / confetti ---------- */
.toast{
  position:fixed;left:50%;bottom:24px;transform:translate(-50%,140px);z-index:60;
  background:linear-gradient(135deg,var(--azul),var(--azul-2));color:#fff;font-weight:700;
  padding:14px 24px;border-radius:30px;box-shadow:0 14px 30px -8px rgba(0,0,0,.5);
  max-width:90vw;text-align:center;transition:transform .4s cubic-bezier(.2,.9,.3,1.3);
}
.toast.show{transform:translate(-50%,0);}
.toast.ok{background:linear-gradient(135deg,var(--verde),var(--verde-2));}
.toast.err{background:linear-gradient(135deg,var(--vermelho),#b32a3a);}
#confetti{position:fixed;inset:0;pointer-events:none;z-index:55;}

/* ---------- Animations ---------- */
@keyframes fadeUp{from{opacity:0;transform:translateY(16px);}to{opacity:1;transform:none;}}
@keyframes slideDown{from{opacity:0;transform:translateY(-10px);}to{opacity:1;transform:none;}}
@keyframes pop{0%{opacity:0;transform:scale(.85);}60%{transform:scale(1.04);}100%{opacity:1;transform:scale(1);}}
@keyframes spin{to{transform:rotate(360deg);}}
@keyframes flagwave{0%,100%{transform:rotate(-1.5deg);}50%{transform:rotate(1.5deg);}}
.flag{animation:flagwave 3.5s ease-in-out infinite;}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important;}}
