/* ==========================================================================
   Cromos · Copa 2026 — estilo desportivo / estádio
   Vivo, energético, otimizado para toque (iPhone/iPad) e com modo escuro.
   ========================================================================== */
:root{
  --pitch:#00a14a;        /* verde relvado */
  --pitch-dk:#008a3e;
  --sky:#1486ff;          /* azul elétrico */
  --sky-dk:#0a6ae0;
  --gold:#ffc21a;         /* destaque (troca mútua) */
  --falta:#ff3b30;        /* em falta */
  --falta-dk:#e22b21;
  --tenho:#0bb85b;        /* tenho */
  --tenho-dk:#069a4b;
  --rep:#1486ff;          /* repetido */
  --rep-dk:#0a6ae0;

  --ink:#0c1c26;
  --muted:#5f7585;
  --bg:#eaf1f4;
  --bg2:#dfeaef;
  --card:#ffffff;
  --line:#d6e1e8;
  --scoreboard:#0a1922;

  --radius:18px;
  --radius-sm:12px;
  --shadow:0 1px 2px rgba(12,28,38,.06), 0 10px 26px rgba(12,28,38,.07);
  --shadow-sm:0 1px 2px rgba(12,28,38,.08);
  --tap:transparent;
}
@media (prefers-color-scheme: dark){
  :root{
    --ink:#e9f2f7; --muted:#8aa1b0;
    --bg:#06121a; --bg2:#0a1a24; --card:#10222e; --line:#21384a;
    --scoreboard:#040d12;
    --shadow:0 1px 2px rgba(0,0,0,.4), 0 14px 30px rgba(0,0,0,.35);
    --shadow-sm:0 1px 2px rgba(0,0,0,.4);
  }
}

*{box-sizing:border-box;}
html{-webkit-text-size-adjust:100%;}
body{
  margin:0;
  font-family:-apple-system,BlinkMacSystemFont,"SF Pro Text","Segoe UI",system-ui,sans-serif;
  color:var(--ink);
  background:
    radial-gradient(1200px 500px at 100% -10%, rgba(20,134,255,.10), transparent 60%),
    radial-gradient(1000px 500px at -10% 0%, rgba(0,161,74,.12), transparent 55%),
    var(--bg);
  background-attachment:fixed;
  line-height:1.42;
  -webkit-tap-highlight-color:var(--tap);
}
body.app{ padding-bottom:0; }
a{color:var(--sky);}
.wrap{max-width:1120px;margin:0 auto;}

/* ---------------- Cabeçalho ---------------- */
header.top{
  background:
    repeating-linear-gradient(115deg, rgba(255,255,255,.06) 0 22px, rgba(255,255,255,0) 22px 44px),
    linear-gradient(120deg, var(--pitch-dk) 0%, var(--pitch) 42%, var(--sky) 100%);
  color:#fff;
  padding:calc(env(safe-area-inset-top) + 12px) 18px 12px;
  box-shadow:0 6px 20px rgba(0,138,62,.20);
}
.bar{display:flex;align-items:center;gap:12px;}
.brand{display:flex;align-items:center;gap:11px;text-decoration:none;color:#fff;}
.ball{
  width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.16);
  display:flex;align-items:center;justify-content:center;font-size:22px;
  box-shadow:inset 0 0 0 1.5px rgba(255,255,255,.30);flex:none;
}
.brandtext{display:flex;flex-direction:column;line-height:1.05;}
.eyebrow{font-size:10px;letter-spacing:.2em;text-transform:uppercase;font-weight:800;color:rgba(255,255,255,.78);}
.bt{font-size:20px;font-weight:900;letter-spacing:-.01em;}
.logout{margin-left:auto;}
.logoutbtn{
  display:inline-flex;align-items:center;gap:7px;border:0;cursor:pointer;
  background:rgba(255,255,255,.16);color:#fff;font:inherit;font-weight:800;font-size:14px;
  padding:9px 14px;border-radius:999px;
}
.logoutbtn svg{width:18px;height:18px;}
.logoutbtn:hover{background:rgba(255,255,255,.26);}

/* ---------------- Abas (topo no desktop, fundo no telemóvel) ---------------- */
.tabs{background:var(--card);border-bottom:1px solid var(--line);}
.tabsrow{display:flex;gap:4px;padding:7px 12px;}
.tab{
  display:flex;align-items:center;gap:8px;text-decoration:none;color:var(--muted);
  font-weight:800;font-size:14px;padding:10px 14px;border-radius:12px;
}
.tab svg{width:20px;height:20px;}
.tab:hover{background:var(--bg2);color:var(--ink);}
.tab.active{color:#fff;background:linear-gradient(120deg,var(--pitch),var(--sky));box-shadow:0 6px 14px rgba(0,161,74,.28);}

/* ---------------- Avisos ---------------- */
.flashes{max-width:1120px;margin:14px auto 0;padding:0 18px;display:grid;gap:8px;}
.flash{padding:11px 15px;border-radius:12px;font-size:14px;font-weight:700;box-shadow:var(--shadow-sm);}
.flash.ok{background:rgba(11,184,91,.14);color:var(--tenho-dk);border:1px solid rgba(11,184,91,.4);}
.flash.erro{background:rgba(255,59,48,.12);color:var(--falta-dk);border:1px solid rgba(255,59,48,.4);}
@media (prefers-color-scheme: dark){
  .flash.ok{color:#48e08c;} .flash.erro{color:#ff7a70;}
}

/* ---------------- Barra de ações / placar ---------------- */
.toolbar{
  position:sticky;top:0;z-index:30;
  background:color-mix(in srgb, var(--bg) 86%, transparent);
  backdrop-filter:saturate(1.5) blur(10px);
  -webkit-backdrop-filter:saturate(1.5) blur(10px);
  border-bottom:1px solid var(--line);padding:12px 18px;
}
.toolbar .row{display:flex;gap:10px;align-items:center;flex-wrap:wrap;}
.chip{
  display:flex;flex-direction:column;align-items:center;gap:1px;
  background:var(--scoreboard);border-radius:14px;padding:8px 16px;min-width:92px;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.05), var(--shadow-sm);
}
.chip b{
  font-size:24px;font-weight:900;font-variant-numeric:tabular-nums;letter-spacing:.04em;
  font-feature-settings:"tnum";line-height:1.05;
}
.chip.falta b{color:#ff5c50;text-shadow:0 0 12px rgba(255,92,80,.55);}
.chip.rep b{color:#46b4ff;text-shadow:0 0 12px rgba(70,180,255,.5);}
.chip span{font-size:9.5px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:#7c95a5;}
.search{
  flex:1;min-width:150px;border:1px solid var(--line);border-radius:14px;background:var(--card);
  padding:12px 15px;font-size:16px;color:var(--ink);box-shadow:var(--shadow-sm);
}
.search:focus{outline:2px solid var(--sky);outline-offset:1px;}
.btn{
  border:1px solid var(--line);background:var(--card);color:var(--ink);border-radius:14px;
  padding:12px 18px;font-size:15px;font-weight:800;cursor:pointer;box-shadow:var(--shadow-sm);
  white-space:nowrap;text-decoration:none;display:inline-flex;align-items:center;gap:7px;
  touch-action:manipulation;
}
.btn:hover{border-color:#aebfcb;}
.btn.primary{background:linear-gradient(120deg,var(--pitch),var(--sky));border:0;color:#fff;box-shadow:0 8px 18px rgba(0,161,74,.28);}
.btn.primary:hover{filter:brightness(1.05);}
.btn.danger{color:var(--falta-dk);border-color:rgba(255,59,48,.45);}
.btn:focus-visible{outline:2px solid var(--sky);outline-offset:2px;}

/* ---------------- Legenda ---------------- */
.hint{max-width:1120px;margin:14px auto 0;padding:0 18px;font-size:13px;color:var(--muted);}
.dot{display:inline-block;width:13px;height:13px;border-radius:4px;vertical-align:-2px;margin:0 4px 0 12px;}
.dot.f{background:var(--falta);} .dot.t{background:var(--tenho);} .dot.r{background:var(--rep);}

/* ---------------- Grelha ---------------- */
main{max-width:1120px;margin:0 auto;padding:16px 18px 40px;}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(330px,1fr));gap:16px;}
.team{
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:16px 16px 14px;box-shadow:var(--shadow);position:relative;overflow:hidden;
}
.team::before{content:"";position:absolute;left:0;top:0;height:4px;width:100%;
  background:linear-gradient(90deg,var(--pitch),var(--sky));opacity:.9;}
.team h2{margin:6px 0 12px;font-size:16px;font-weight:900;display:flex;align-items:center;gap:10px;}
.team h2 .flag{font-size:24px;line-height:1;}
.team h2 .code{font-size:11px;letter-spacing:.06em;color:var(--muted);font-weight:800;border:1px solid var(--line);border-radius:7px;padding:3px 7px;}
.team h2 .name{font-weight:900;}
.team h2 .tcount{margin-left:auto;font-size:11px;font-weight:900;text-transform:uppercase;letter-spacing:.04em;color:var(--falta);
  background:rgba(255,59,48,.12);padding:4px 9px;border-radius:999px;}
.team h2 .tcount.zero{color:var(--tenho-dk);background:rgba(11,184,91,.14);}
.glabel{font-size:11px;font-weight:900;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;margin:10px 0 7px;}

.nums{display:grid;grid-template-columns:repeat(10,1fr);gap:7px;}
.cell{position:relative;}
.num{
  width:100%;aspect-ratio:1/1;border:0;border-radius:11px;
  font-size:14px;font-weight:900;font-variant-numeric:tabular-nums;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:transform .07s ease, filter .12s ease;
  touch-action:manipulation;user-select:none;-webkit-user-select:none;
  /* em falta (qtd 0) */
  background:linear-gradient(160deg,var(--falta),var(--falta-dk));color:#fff;
  box-shadow:0 3px 8px rgba(255,59,48,.30), inset 0 1px 0 rgba(255,255,255,.25);
}
.num:active{transform:scale(.90);}
.num:focus-visible{outline:3px solid var(--sky);outline-offset:2px;}
.cell.has:not(.rep) .num{
  background:linear-gradient(160deg,var(--tenho),var(--tenho-dk));
  box-shadow:0 3px 8px rgba(11,184,91,.28), inset 0 1px 0 rgba(255,255,255,.25);
}
.cell.rep .num{
  background:linear-gradient(160deg,var(--rep),var(--rep-dk));
  box-shadow:0 3px 8px rgba(20,134,255,.30), inset 0 1px 0 rgba(255,255,255,.25);
}
.badge{
  position:absolute;top:-7px;right:-7px;min-width:20px;height:20px;padding:0 5px;border-radius:11px;
  background:var(--gold);color:#3a2a00;font-size:11px;font-weight:900;line-height:20px;text-align:center;
  display:none;box-shadow:0 2px 6px rgba(0,0,0,.25);
}
.cell.rep .badge{display:block;}
.minus{
  position:absolute;left:-7px;top:-7px;width:22px;height:22px;border-radius:50%;border:0;
  background:var(--card);color:var(--ink);font-size:16px;font-weight:900;line-height:1;cursor:pointer;
  box-shadow:0 2px 7px rgba(0,0,0,.28);display:none;padding:0;
  align-items:center;justify-content:center;touch-action:manipulation;
}
.cell.has .minus{display:flex;}
.teamactions{display:flex;gap:8px;margin-top:14px;}
.miniact{
  font-size:13px;font-weight:800;color:var(--muted);background:var(--bg2);border:0;border-radius:10px;
  padding:9px 13px;cursor:pointer;touch-action:manipulation;
}
.miniact:hover{color:var(--ink);}

/* ---------------- Trocas ---------------- */
.section-title{font-size:19px;font-weight:900;margin:10px 0 14px;display:flex;align-items:center;gap:9px;}
.section-title::before{content:"";width:5px;height:20px;border-radius:3px;background:linear-gradient(var(--pitch),var(--sky));}
.matchcard{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow);margin-bottom:13px;}
.matchcard.is-mutua{border-color:var(--gold);box-shadow:0 0 0 1px var(--gold), var(--shadow);}
.matchcard .head{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:10px;}
.matchcard .pname{font-weight:900;font-size:17px;}
.tag{font-size:11px;font-weight:900;text-transform:uppercase;letter-spacing:.05em;padding:4px 10px;border-radius:999px;}
.tag.mutua{background:var(--gold);color:#3a2a00;}
.contact{font-size:13px;color:var(--muted);display:flex;gap:14px;flex-wrap:wrap;align-items:center;}
.contact a{font-weight:800;text-decoration:none;display:inline-flex;align-items:center;gap:5px;}
.cromolist{display:flex;flex-wrap:wrap;gap:7px;margin-top:6px;}
.cromo{font-size:13px;font-weight:800;background:linear-gradient(160deg,rgba(20,134,255,.14),rgba(0,161,74,.12));
  color:var(--ink);border:1px solid var(--line);border-radius:10px;padding:5px 10px;}
.empty{background:var(--card);border:1.5px dashed var(--line);border-radius:var(--radius);padding:30px;text-align:center;color:var(--muted);font-weight:600;}

/* ---------------- Formulários / painéis ---------------- */
.panel{max-width:560px;margin:30px auto;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:26px;box-shadow:var(--shadow);}
.panel.wide{max-width:940px;}
.panel h1{font-size:24px;font-weight:900;margin:0 0 4px;}
.panel p.sub{margin:0 0 20px;color:var(--muted);font-size:14px;}
.field{margin:0 0 15px;}
.field label{display:block;font-size:13px;font-weight:800;margin:0 0 6px;}
.field input,.field select{width:100%;border:1px solid var(--line);border-radius:12px;padding:13px 14px;font-size:16px;color:var(--ink);background:var(--card);}
.field input:focus,.field select:focus{outline:2px solid var(--sky);outline-offset:1px;}
.formrow{display:flex;gap:13px;flex-wrap:wrap;}
.formrow .field{flex:1;min-width:160px;}
fieldset{border:1px solid var(--line);border-radius:14px;padding:18px;margin:0 0 18px;}
fieldset legend{font-weight:900;font-size:14px;padding:0 6px;}
table.users{width:100%;border-collapse:collapse;font-size:14px;}
table.users th,table.users td{text-align:left;padding:11px 8px;border-bottom:1px solid var(--line);vertical-align:top;}
table.users th{font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);font-weight:900;}
.inline{display:flex;gap:7px;align-items:center;flex-wrap:wrap;}
.inline input{width:150px;border:1px solid var(--line);border-radius:10px;padding:9px 11px;font-size:14px;background:var(--card);color:var(--ink);}
.pill{font-size:11px;font-weight:900;padding:3px 9px;border-radius:999px;}
.pill.admin{background:rgba(20,134,255,.16);color:var(--sky-dk);}
.pill.comum{background:var(--bg2);color:var(--muted);}
@media (prefers-color-scheme: dark){ .pill.admin{color:#6cb6ff;} }

/* ---------------- Login (sem cabeçalho) ---------------- */
body:not(.app){
  display:flex;align-items:center;justify-content:center;min-height:100vh;min-height:100dvh;padding:20px;
}
body:not(.app) .panel{margin:0;width:100%;}

/* ---------------- Responsivo ---------------- */
@media (hover:hover){
  .team{transition:transform .12s ease, box-shadow .12s ease;}
  .team:hover{transform:translateY(-2px);box-shadow:0 14px 34px rgba(12,28,38,.12);}
}

/* Tablet (iPad) */
@media (max-width:820px){
  .grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));}
}

/* Telemóvel: abas em barra inferior fixa + alvos maiores */
@media (max-width:640px){
  body.app{padding-bottom:calc(72px + env(safe-area-inset-bottom));}
  .bt{font-size:18px;}
  .logoutbtn span{display:none;}
  .logoutbtn{padding:10px;}

  .tabs{
    position:fixed;left:0;right:0;bottom:0;top:auto;z-index:60;
    border-top:1px solid var(--line);border-bottom:0;
    box-shadow:0 -6px 20px rgba(12,28,38,.10);
    padding-bottom:env(safe-area-inset-bottom);
  }
  .tabsrow{padding:8px 6px;justify-content:space-around;gap:0;}
  .tab{flex-direction:column;gap:3px;font-size:11px;font-weight:800;padding:6px 10px;border-radius:14px;flex:1;text-align:center;}
  .tab svg{width:24px;height:24px;}
  .tab.active{background:none;color:var(--pitch);box-shadow:none;}
  @media (prefers-color-scheme: dark){ .tab.active{color:#37d27e;} }

  .toolbar{padding:11px 14px;}
  .chip{min-width:0;flex:1;padding:8px 10px;}
  main{padding:14px 14px 30px;}
  .grid{grid-template-columns:1fr;gap:14px;}

  .nums{grid-template-columns:repeat(5,1fr);gap:10px;}
  .num{font-size:18px;border-radius:13px;}
  .minus{width:26px;height:26px;font-size:19px;left:-8px;top:-8px;}
  .badge{min-width:22px;height:22px;line-height:22px;font-size:12px;right:-8px;top:-8px;}
  .miniact{flex:1;padding:12px;font-size:14px;}
}

@media (prefers-reduced-motion:reduce){
  *{transition:none !important;animation:none !important;}
}

/* ====================== Impressão ====================== */
.printout{display:none;}
@media print{
  @page{margin:13mm;}
  header.top,.tabs,.toolbar,.flashes,.printbar{display:none !important;}
  body{background:#fff;padding:0;}
  .printout{display:block;color:#000;}
}
.printbar{max-width:900px;margin:18px auto;padding:0 18px;display:flex;gap:10px;align-items:center;flex-wrap:wrap;}
.printout{max-width:900px;margin:0 auto;padding:0 18px;color:#000;font-size:12pt;}
.printout h1{font-size:19pt;margin:0 0 2px;}
.printout .meta{font-size:10pt;color:#333;margin:0 0 6px;}
.printout .totais{font-weight:800;font-size:12.5pt;margin:0 0 14px;}
.plist{column-count:2;column-gap:26px;}
.pteam{break-inside:avoid;margin:0 0 8px;font-size:11.5pt;line-height:1.4;}
.pteam .pcode{font-weight:800;}
.pteam .lbl{font-weight:700;color:#444;}
.pshop{margin-top:18px;padding-top:10px;border-top:1.5px solid #000;font-size:10pt;line-height:1.5;break-inside:avoid;}
.pshop b{font-size:11pt;}
.pempty{font-size:13pt;}
