:root{
  /* Paleta Brasil: verde, amarelo, azul */
  --bg:#07140d; --bg2:#0c1b13; --card:#102217; --line:#1d3a28;
  --green:#009c3b; --green-d:#007a2e; --gold:#ffdf00;
  --txt:#eaf2ee; --muted:#86a596; --red:#e5484d; --yellow:#ffdf00; --blue:#1f4fd0;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  background:radial-gradient(1200px 600px at 50% -10%, #0c2a18 0%, var(--bg) 60%);
  color:var(--txt); font:16px/1.45 system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  -webkit-tap-highlight-color:transparent; overscroll-behavior:none;
}
#app{max-width:560px;margin:0 auto;min-height:100%;display:flex;flex-direction:column;
  padding-bottom:env(safe-area-inset-bottom)}

/* topbar */
.topbar{display:flex;align-items:center;justify-content:space-between;
  padding:14px 16px;position:sticky;top:0;z-index:5;
  background:linear-gradient(180deg,rgba(10,15,12,.95),rgba(10,15,12,.6) 80%,transparent);
  backdrop-filter:blur(8px)}
.brand{display:flex;align-items:center;gap:8px;font-weight:800;letter-spacing:.3px}
.brand-mark{font-size:22px}
.brand-name{font-size:18px}
.wallet{display:flex;align-items:center;gap:6px;background:var(--card);
  border:1px solid var(--line);border-radius:999px;padding:6px 12px;font-weight:700}

/* main + cards */
main{flex:1;padding:8px 14px 90px}
section{display:flex;flex-direction:column;gap:12px}
.card{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:16px}
.card h3{font-size:14px;text-transform:uppercase;letter-spacing:.6px;color:var(--muted);margin-bottom:10px}
.center{text-align:center;align-items:center}
.muted{color:var(--muted)} .small{font-size:13px}
.hero{font-size:28px;margin-bottom:6px}

/* buttons */
.btn{appearance:none;border:0;border-radius:12px;background:var(--green);color:#fff;
  font-weight:800;font-size:16px;padding:14px 18px;cursor:pointer;transition:.12s transform,.12s filter}
.btn:active{transform:translateY(1px) scale(.99)}
.btn.big{width:100%;padding:16px;font-size:18px;
  background:linear-gradient(180deg,var(--green),var(--green-d));box-shadow:0 6px 18px rgba(22,163,74,.25)}
.btn.ghost{background:transparent;border:1px solid var(--line);color:var(--txt);font-size:14px;padding:10px 14px}
.mini{border:1px solid var(--green);background:transparent;color:var(--green);
  border-radius:999px;font-weight:700;font-size:13px;padding:6px 12px;cursor:pointer}

/* fields */
.field{display:flex;flex-direction:column;gap:6px;text-align:left;width:100%;margin:12px 0}
.field span{font-size:13px;color:var(--muted)}
.field input{background:var(--bg2);border:1px solid var(--line);border-radius:12px;
  color:var(--txt);padding:14px;font-size:16px}

/* team head */
.teamhead{display:flex;align-items:center;gap:14px}
.crest{font-size:40px;width:56px;height:56px;display:grid;place-items:center;
  background:var(--bg2);border-radius:14px;border:1px solid var(--line)}
.crest.sm{font-size:22px;width:34px;height:34px;border-radius:9px}

/* players */
.players{list-style:none;display:flex;flex-direction:column;gap:2px}
.player{display:flex;align-items:center;gap:10px;padding:9px 6px;border-bottom:1px solid rgba(255,255,255,.04)}
.player:last-child{border-bottom:0}
.pos{font-size:11px;font-weight:800;width:34px;text-align:center;padding:3px 0;border-radius:6px}
.pos-GK{background:#3b2f0b;color:#e9b949}.pos-DEF{background:#0b2a3b;color:#5ec6e9}
.pos-MID{background:#0b3b22;color:#5ee99a}
.pos-ATT{background:#3b0b16;color:#e95e7a}
.pname{flex:1;font-weight:600}
.ovr{font-weight:800;background:var(--bg2);border:1px solid var(--line);border-radius:8px;padding:3px 9px}
.train .player{border-bottom:0;padding:6px}

/* tatica */
.tatpick{display:flex;gap:8px}
.tat{flex:1;border:1px solid var(--line);background:var(--bg2);color:var(--muted);
  border-radius:10px;padding:12px 6px;font-weight:700;cursor:pointer}
.tat.is-active{border-color:var(--green);color:#fff;background:rgba(22,163,74,.15)}

/* scorecard + feed */
.scorecard{display:flex;align-items:center;justify-content:space-between;gap:8px}
.sc{display:flex;align-items:center;gap:8px;flex:1;font-weight:700}
.sc:last-child{justify-content:flex-end;text-align:right}
.score{font-size:26px;font-weight:900;background:var(--bg2);border-radius:10px;padding:6px 14px;border:1px solid var(--blue)}
.controls{display:flex;justify-content:space-between;align-items:center;margin:10px 0}
.clock{font-weight:800;color:var(--gold)}
.feed{list-style:none;display:flex;flex-direction:column;gap:6px}
.ev{display:flex;gap:10px;background:var(--card);border:1px solid var(--line);
  border-radius:10px;padding:10px 12px;animation:pop .2s ease}
.ev .min{color:var(--muted);font-variant-numeric:tabular-nums;min-width:30px;font-weight:700}
.ev-goal{border-color:var(--green);background:rgba(22,163,74,.12);font-weight:700}
.ev-red{border-color:var(--red)} .ev-yellow{border-left:3px solid var(--yellow)}
@keyframes pop{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:none}}
.result{flex-direction:row;justify-content:center;gap:12px;margin-top:10px}
.result b{font-size:18px}

/* liga / treino */
.code{font-size:28px;font-weight:900;letter-spacing:6px;background:var(--bg2);
  border:1px dashed var(--line);border-radius:12px;padding:14px;margin:10px 0}
.standings{list-style:none;counter-reset:r}
.standings li{counter-increment:r;display:flex;justify-content:space-between;
  padding:10px 4px;border-bottom:1px solid rgba(255,255,255,.05)}
.standings li::before{content:counter(r);color:var(--muted);margin-right:10px;font-weight:800}
.big-num{font-size:44px;font-weight:900;color:var(--gold);margin:6px 0}

/* tabbar */
.tabbar{position:fixed;bottom:0;left:0;right:0;max-width:560px;margin:0 auto;
  display:flex;background:rgba(10,15,12,.92);backdrop-filter:blur(10px);
  border-top:1px solid var(--line);padding-bottom:env(safe-area-inset-bottom)}
.tab{flex:1;background:transparent;border:0;color:var(--muted);font-weight:700;
  font-size:13px;padding:14px 0;cursor:pointer}
.tab.is-active{color:var(--green)}

/* ---- v2: avatar / kit / crest / RPG ---- */
.avatar-svg,.kit-svg,.crest-svg{display:block}
.teamhead .crest{padding:6px}
.teamhead .th-info{flex:1}
.th-kit{display:grid;place-items:center}
.pmini{display:grid;place-items:center;width:30px;height:30px;border-radius:50%;
  overflow:hidden;background:var(--bg2);flex:none}
.lvl{font-weight:800;color:var(--gold);font-size:13px;min-width:34px;text-align:right}

/* onboarding editor */
.previewrow{display:flex;gap:12px;justify-content:center;margin:12px 0}
.preview{background:var(--bg2);border:1px solid var(--line);border-radius:16px;
  padding:10px;display:grid;place-items:center}
.ctrls{display:flex;gap:10px;flex-wrap:wrap;margin:8px 0}
.colorfield{display:flex;flex-direction:column;gap:4px;font-size:12px;color:var(--muted)}
.colorfield input[type=color]{width:64px;height:40px;border:1px solid var(--line);
  border-radius:10px;background:var(--bg2);padding:2px;cursor:pointer}
.chips{display:flex;gap:8px;flex-wrap:wrap;margin:6px 0}
.chip{border:1px solid var(--line);background:var(--bg2);color:var(--muted);
  border-radius:999px;padding:8px 14px;font-weight:700;font-size:13px;cursor:pointer;text-transform:capitalize}
.chip.is-active{border-color:var(--green);color:#fff;background:rgba(0,156,59,.18)}
.swatches{display:flex;gap:8px;flex-wrap:wrap;margin:8px 0}
.sw{width:34px;height:34px;border-radius:9px;border:2px solid var(--line);cursor:pointer}
.sw.is-active{border-color:var(--gold);box-shadow:0 0 0 2px rgba(255,223,0,.3)}
.sw-emoji{width:40px;height:40px;border-radius:10px;border:2px solid var(--line);
  background:var(--bg2);font-size:20px;cursor:pointer}
.sw-emoji.is-active{border-color:var(--gold);box-shadow:0 0 0 2px rgba(255,223,0,.3)}

/* modal / sheet */
.modal{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:30;display:flex;
  align-items:flex-end;justify-content:center;animation:fade .15s ease}
@keyframes fade{from{opacity:0}to{opacity:1}}
.sheet{width:100%;max-width:560px;max-height:92vh;overflow-y:auto;border-radius:20px 20px 0 0;
  position:relative;animation:slideup .2s ease}
@keyframes slideup{from{transform:translateY(30px)}to{transform:none}}
.sheet h2{margin-bottom:6px}
.sheet .x{position:absolute;top:12px;right:12px;width:34px;height:34px;border-radius:50%;
  border:1px solid var(--line);background:var(--bg2);color:var(--txt);font-size:15px;cursor:pointer;z-index:2}

/* ficha do jogador */
.ficha-head{display:flex;align-items:center;gap:14px;margin:6px 0 14px}
.ficha-av{width:88px;height:88px;border-radius:16px;overflow:hidden;background:var(--bg2);
  border:1px solid var(--line);display:grid;place-items:center;flex:none}
.tag{background:rgba(31,79,208,.25);color:#9db7ff;border-radius:6px;padding:1px 6px;font-size:11px;font-weight:700}
.lvlrow{display:flex;align-items:center;gap:10px;margin:10px 0}
.lvl.big{font-size:14px;color:var(--txt);white-space:nowrap}
.lvl.big b{color:var(--gold)}
.bar{flex:1;height:9px;background:var(--bg2);border:1px solid var(--line);
  border-radius:999px;overflow:hidden}
.bar i{display:block;height:100%;background:linear-gradient(90deg,var(--green),#3fd178)}
.bar.xp i{background:linear-gradient(90deg,var(--gold),#ffe860)}
.evo{background:rgba(255,223,0,.1);border:1px solid rgba(255,223,0,.3);
  border-radius:10px;padding:8px 10px;margin:8px 0}
.evo.hidden{display:none}
.attrs{display:flex;flex-direction:column;gap:8px;margin:10px 0}
.attrrow{display:flex;align-items:center;gap:10px}
.attr{display:flex;align-items:center;gap:10px;flex:1}
.attr-l{width:64px;font-size:12px;color:var(--muted);text-transform:capitalize}
.attr-v{width:28px;text-align:right;font-weight:800;font-variant-numeric:tabular-nums}
.plus{border:1px solid var(--green);background:rgba(0,156,59,.12);color:var(--green);
  border-radius:8px;font-weight:800;font-size:13px;padding:6px 10px;cursor:pointer;flex:none}
.plus:disabled{opacity:.35;cursor:default;border-color:var(--line);color:var(--muted);background:transparent}
.fichameta{margin-top:8px;text-align:center}

/* steppers de criação */
.budget{background:var(--bg2);border:1px solid var(--line);border-radius:10px;
  padding:8px 10px;font-size:13px;color:var(--muted);margin:6px 0}
.budget b{color:var(--gold)}
.steppers{display:flex;flex-direction:column;gap:8px;margin:8px 0}
.stepper{display:flex;align-items:center;gap:10px}
.st-l{flex:1;font-weight:600;text-transform:capitalize}
.st-v{width:36px;text-align:center;font-weight:800;font-variant-numeric:tabular-nums;
  background:var(--bg2);border:1px solid var(--line);border-radius:8px;padding:4px 0}
.st-btn{width:38px;height:38px;border-radius:10px;border:1px solid var(--green);
  background:rgba(0,156,59,.12);color:var(--green);font-size:20px;font-weight:800;cursor:pointer}
.st-btn:disabled{opacity:.35;cursor:default;border-color:var(--line);color:var(--muted);background:transparent}

/* level up banner */
.levelup{flex-direction:column;gap:4px;margin-top:8px;border-color:var(--gold);
  background:rgba(255,223,0,.08)}
.levelup b{color:var(--gold)}

/* ---- v3: auth / cosméticos / conta ---- */
.btn.full{width:100%}

/* topbar conta */
.topright{display:flex;align-items:center;gap:8px}
.account{display:flex;align-items:center;gap:6px}
.acc-email{font-size:12px;color:var(--muted);max-width:120px;overflow:hidden;
  text-overflow:ellipsis;white-space:nowrap}
.acc-btn{border:1px solid var(--line);background:var(--bg2);color:var(--txt);
  border-radius:999px;font-weight:700;font-size:12px;padding:5px 10px;cursor:pointer}
.acc-btn.cta{border-color:var(--green);color:var(--green)}

/* login / cadastro */
.authcard{margin-top:8px}
.authtabs{display:flex;gap:8px;margin:12px 0}
.authtab{flex:1;border:1px solid var(--line);background:var(--bg2);color:var(--muted);
  border-radius:10px;padding:11px 6px;font-weight:800;cursor:pointer}
.authtab.is-active{border-color:var(--green);color:#fff;background:rgba(0,156,59,.15)}
.autherr{background:rgba(229,72,77,.12);border:1px solid rgba(229,72,77,.45);
  color:#ffb3b5;border-radius:10px;padding:10px 12px;font-size:13px;margin:4px 0 10px}
.authcard .btn.big{margin-top:4px}
.authcard .btn.ghost{margin-top:10px}

/* grid de cosméticos */
.cosmo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:8px 0}
.cosmo{display:flex;flex-direction:column;align-items:center;gap:6px;
  background:var(--bg2);border:2px solid var(--line);border-radius:14px;padding:10px 6px;
  cursor:pointer;text-align:center}
button.cosmo{font:inherit;color:var(--txt)}
.cosmo.card2{cursor:default}
.cosmo.is-sel{border-color:var(--gold);box-shadow:0 0 0 2px rgba(255,223,0,.25)}
.cosmo.locked{opacity:.85}
.cosmo-pv{display:grid;place-items:center;width:72px;height:72px}
.cosmo-nm{font-size:12px;font-weight:700;line-height:1.1}
.cosmo-btn{border:1px solid var(--green);background:rgba(0,156,59,.12);color:var(--green);
  border-radius:8px;font-weight:800;font-size:12px;padding:6px 10px;cursor:pointer;width:100%}
.cosmo-btn.unlock{border-color:var(--gold);color:var(--gold);background:rgba(255,223,0,.1)}
.cosmo-tag{font-size:11px;font-weight:800;padding:4px 8px;border-radius:8px}
.cosmo-tag.eq{background:rgba(0,156,59,.18);color:#5ee99a;border:1px solid var(--green)}
.cosmotabs{display:flex;gap:8px;margin:10px 0}
.cosmotab{flex:1;border:1px solid var(--line);background:var(--bg2);color:var(--muted);
  border-radius:10px;padding:10px 6px;font-weight:800;cursor:pointer}
.cosmotab.is-active{border-color:var(--green);color:#fff;background:rgba(0,156,59,.15)}

/* ---- v3: Centro Estratégico (Tática) ---- */
.player{cursor:pointer}
.player:active{background:rgba(255,255,255,.03)}

/* seletor de formação */
.formpick{display:grid;grid-template-columns:repeat(5,1fr);gap:6px}
.formbtn{border:1px solid var(--line);background:var(--bg2);color:var(--muted);
  border-radius:10px;padding:11px 4px;font-weight:800;font-size:13px;cursor:pointer}
.formbtn.is-active{border-color:var(--gold);color:#fff;background:rgba(255,223,0,.14)}

/* campo / linhas de escalação */
.fieldline{display:flex;align-items:flex-start;gap:8px;margin:6px 0;
  background:linear-gradient(180deg,rgba(0,156,59,.06),transparent);
  border-radius:10px;padding:4px 6px}
.fieldline-l{width:34px;flex:none;font-size:11px;font-weight:800;color:var(--muted);
  letter-spacing:.5px;padding-top:12px;text-align:center}
.players.lineup{flex:1;gap:4px}
.lp{display:flex;align-items:center;gap:8px;padding:8px 8px;cursor:pointer;
  border:1px solid transparent;border-radius:10px;background:var(--bg2)}
.lp:active{transform:translateY(1px) scale(.995)}
.lp.is-sel{border-color:var(--gold);background:rgba(255,223,0,.12);
  box-shadow:0 0 0 2px rgba(255,223,0,.22)}
.lp .pname{flex:1;font-weight:600;font-size:14px;min-width:0;overflow:hidden;
  text-overflow:ellipsis;white-space:nowrap}
.lp .pmini{width:26px;height:26px}
.badge-fora{font-size:10px;font-weight:800;color:#ffb3b5;background:rgba(229,72,77,.16);
  border:1px solid rgba(229,72,77,.45);border-radius:6px;padding:2px 6px;white-space:nowrap}

/* resumo na partida */
.matchsum{display:flex;align-items:center;justify-content:space-between;gap:10px}
.matchsum-info{display:flex;flex-direction:column;gap:2px}
.matchsum-info b{font-size:16px}

/* toast */
.toast{position:fixed;left:50%;bottom:84px;transform:translateX(-50%) translateY(20px);
  background:#000;border:1px solid var(--line);color:#fff;padding:10px 16px;border-radius:999px;
  opacity:0;transition:.2s;z-index:20;font-size:14px}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
