/* ClipeArena — design system. Tokens + componentes. Identidade própria (esportiva,
   moderna), não template genérico. As cores viram CSS vars, sobrescritas por arena. */
:root{
  --bg:#080d18; --surface:#111a2e; --surface2:#16213c; --line:#243252;
  --line-soft:rgba(255,255,255,.06);
  --txt:#E6EAF2; --muted:#8A97B1; --primary:#0EA5E9; --secondary:#22D3EE;
  --accent:#38F5B5; --danger:#F97066; --warn:#FBBF24;
  --radius:18px; --radius-sm:11px; --shadow:0 18px 50px -18px rgba(0,0,0,.65);
  --glow:0 0 0 1px rgba(34,211,238,.06),0 18px 50px -20px rgba(14,165,233,.35);
  --glass:rgba(19,28,50,.55);
  --maxw:1100px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
html,body{margin:0}
body{
  background:
    radial-gradient(1100px 560px at 82% -12%,rgba(34,211,238,.13),transparent 60%),
    radial-gradient(900px 500px at 8% 8%,rgba(56,245,181,.08),transparent 55%),
    linear-gradient(180deg,#0a1120,var(--bg) 40%);
  background-attachment:fixed;
  color:var(--txt);font-family:system-ui,-apple-system,"Segoe UI",Roboto,Inter,sans-serif;
  line-height:1.55;-webkit-font-smoothing:antialiased;min-height:100vh;
}
@keyframes rise{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
a{color:var(--secondary);text-decoration:none}
a:hover{opacity:.9}
img{max-width:100%}
h1,h2,h3{letter-spacing:-.02em;line-height:1.15}
h1{letter-spacing:-.03em}

.wrap{max-width:var(--maxw);margin:0 auto;padding:24px}
.muted{color:var(--muted)}
.tag{display:inline-block;font-size:12px;color:var(--secondary);border:1px solid var(--line);border-radius:999px;padding:4px 10px}

.brand{display:flex;align-items:center;gap:10px;font-weight:800;letter-spacing:-.02em}
.brand .dot{width:12px;height:12px;border-radius:50%;flex:none;
  background:linear-gradient(135deg,var(--primary),var(--accent));box-shadow:0 0 18px var(--secondary)}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;
  background:linear-gradient(135deg,var(--primary),var(--secondary));color:#04121c;font-weight:700;
  border:0;border-radius:12px;padding:12px 18px;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease;
  font-size:15px;text-align:center}
.btn:hover{transform:translateY(-1px);box-shadow:0 8px 24px -10px var(--secondary)}
.btn:active{transform:translateY(0)}
.btn.ghost{background:transparent;color:var(--txt);border:1px solid var(--line);box-shadow:none}
.btn.ghost:hover{background:var(--surface)}
.btn:disabled{opacity:.55;cursor:not-allowed;transform:none;box-shadow:none}
.linkbtn{background:none;border:0;color:var(--danger);cursor:pointer;font:inherit;padding:0}
.linkbtn:hover{text-decoration:underline}
.inline{display:inline}

.card{position:relative;background:linear-gradient(180deg,rgba(255,255,255,.03),transparent),var(--glass);
  border:1px solid var(--line-soft);border-radius:var(--radius);padding:22px;
  backdrop-filter:blur(12px) saturate(1.1);box-shadow:var(--shadow);animation:rise .35s ease both}
.card>h3:first-child,.card>h2:first-child{margin-top:0}
a.card{display:block;transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease}
a.card:hover{transform:translateY(-3px);border-color:rgba(34,211,238,.5);box-shadow:var(--glow);opacity:1}

.grid{display:grid;gap:16px}
@media(min-width:720px){.grid.cols-2{grid-template-columns:repeat(2,1fr)}.grid.cols-3{grid-template-columns:repeat(3,1fr)}}

label{display:block;font-size:14px;color:var(--muted);margin:14px 0 6px}
input,select,textarea{width:100%;background:#0c1526;border:1px solid var(--line);color:var(--txt);
  border-radius:var(--radius-sm);padding:12px 14px;font-size:15px;font-family:inherit}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--secondary);box-shadow:0 0 0 3px rgba(34,211,238,.18)}
:focus-visible{outline:2px solid var(--secondary);outline-offset:2px}

.alert{background:rgba(249,112,102,.12);border:1px solid var(--danger);color:#ffd7d3;border-radius:var(--radius-sm);padding:12px 14px;margin:12px 0}
.topbar{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:18px 24px;border-bottom:1px solid var(--line)}
.kpi{font-size:32px;font-weight:800;letter-spacing:-.02em}

.badge{font-size:12px;padding:3px 9px;border-radius:999px;border:1px solid var(--line);white-space:nowrap}
.badge.ativa,.badge.online,.badge.ativo{color:var(--accent);border-color:var(--accent)}
.badge.bloqueada,.badge.erro{color:var(--danger);border-color:var(--danger)}
.badge.offline,.badge.pendente{color:var(--muted)}

table{width:100%;border-collapse:collapse}
th,td{text-align:left;padding:12px 10px;border-bottom:1px solid var(--line)}
th{color:var(--muted);font-size:13px;font-weight:600}
tr:hover td{background:rgba(255,255,255,.02)}

.toast{border-radius:var(--radius-sm);padding:12px 16px;margin-bottom:18px;border:1px solid var(--line)}
.toast.ok{background:rgba(56,245,181,.10);border-color:var(--accent);color:#bff7e4}
.toast.erro{background:rgba(249,112,102,.12);border-color:var(--danger);color:#ffd7d3}

/* utilidades de layout dos painéis */
.shell{display:grid;grid-template-columns:236px 1fr;min-height:100vh}
.shell .side{background:linear-gradient(180deg,rgba(19,28,50,.7),rgba(10,17,32,.7));backdrop-filter:blur(14px);
  border-right:1px solid var(--line-soft);padding:20px 14px;position:sticky;top:0;height:100vh}
.shell .side .brand{padding:6px 10px 18px}
.shell .side a{display:block;color:var(--muted);padding:11px 12px;border-radius:var(--radius-sm);margin-bottom:4px;font-weight:600;transition:background .12s ease}
.shell .side a:hover{background:var(--surface);color:var(--txt)}
.shell .side a.on{background:linear-gradient(135deg,rgba(14,165,233,.22),rgba(34,211,238,.10));color:#fff;
  border:1px solid rgba(34,211,238,.28);box-shadow:0 0 18px -6px rgba(34,211,238,.5)}
.shell .main{padding:26px 30px}
.shell .main .head{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:22px}
@media(max-width:720px){.shell{grid-template-columns:1fr}.shell .side{display:flex;gap:6px;overflow:auto}.shell .main{padding:20px 16px}}

/* ── estatísticas / gráficos ─────────────────────────────────────────────── */
.stat-grid{display:grid;gap:14px;grid-template-columns:repeat(2,1fr)}
@media(min-width:820px){.stat-grid{grid-template-columns:repeat(4,1fr)}}
.stat{position:relative;overflow:hidden;background:linear-gradient(180deg,rgba(255,255,255,.03),transparent),var(--glass);
  border:1px solid var(--line-soft);border-radius:var(--radius);padding:16px 16px 12px;
  backdrop-filter:blur(12px);box-shadow:var(--shadow);animation:rise .4s ease both;transition:transform .18s ease,box-shadow .18s ease}
.stat:hover{transform:translateY(-2px);box-shadow:var(--glow)}
.stat::after{content:"";position:absolute;inset:0 0 auto 0;height:2px;
  background:linear-gradient(90deg,transparent,var(--secondary),transparent);opacity:.6}
.stat-top{display:flex;justify-content:space-between;align-items:center;gap:8px}
.stat-label{font-size:13px;color:var(--muted);font-weight:600}
.delta{font-size:12px;font-weight:700;padding:2px 8px;border-radius:999px;white-space:nowrap;border:1px solid transparent}
.delta.up{color:var(--accent);background:rgba(56,245,181,.10);border-color:rgba(56,245,181,.25)}
.delta.down{color:var(--danger);background:rgba(249,112,102,.10);border-color:rgba(249,112,102,.25)}
.delta.flat{color:var(--muted);background:rgba(255,255,255,.04)}
.stat-val{font-size:30px;font-weight:800;letter-spacing:-.02em;margin:2px 0 2px}
.stat-spark{height:34px;margin:2px -4px 2px}
.stat-sub{font-size:12px}
.card-head{display:flex;justify-content:space-between;align-items:center;gap:10px;margin:-2px 0 12px}
.card-head h3{margin:0;font-size:16px}
.chart{display:block;overflow:visible}
.spark{display:block}
.chart-legend{display:flex;gap:16px;font-size:12px;color:var(--muted);margin-bottom:6px}
.chart-legend i{display:inline-block;width:9px;height:9px;border-radius:3px;margin-right:5px;vertical-align:middle}
.tbl{width:100%;border-collapse:collapse}
.tbl th,.tbl td{padding:10px 8px;border-bottom:1px solid var(--line);font-size:14px}
.bar-track{height:8px;border-radius:999px;background:rgba(255,255,255,.06);overflow:hidden}
.bar-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,var(--primary),var(--accent))}
.link-card{color:var(--txt)}
.link-card h3{margin-top:0;font-size:16px}
.page-head{display:flex;justify-content:space-between;align-items:center;gap:12px;margin:0 0 16px;flex-wrap:wrap}
.seg{display:inline-flex;background:var(--glass);border:1px solid var(--line-soft);border-radius:999px;padding:3px;backdrop-filter:blur(8px)}
.seg a{padding:6px 14px;border-radius:999px;color:var(--muted);font-weight:700;font-size:13px;transition:.15s ease}
.seg a:hover{color:var(--txt)}
.seg a.on{background:linear-gradient(135deg,var(--primary),var(--secondary));color:#04121c;box-shadow:0 4px 14px -6px var(--secondary)}

/* ── Logo ClipeArena (emblema animado + wordmark) ─────────────────────────── */
.logo{display:inline-flex;align-items:center;gap:10px;font-weight:800;letter-spacing:-.02em;line-height:1}
.logo-mark{flex:none;overflow:visible;transform-origin:center;
  filter:drop-shadow(0 3px 12px rgba(34,211,238,.28))}
.lg-shield{stroke-dasharray:150;stroke-dashoffset:150;animation:lg-draw 1s cubic-bezier(.6,.05,.2,1) forwards}
.lg-cam{opacity:0;transform-box:fill-box;transform-origin:center;
  animation:lg-pop .5s cubic-bezier(.34,1.56,.64,1) .5s forwards}
.lg-play{transform-box:fill-box;transform-origin:center;opacity:0;
  animation:lg-pop .45s cubic-bezier(.34,1.56,.64,1) .68s forwards, lg-breathe 3.4s ease-in-out 1.6s infinite}
.lg-spark{transform-box:view-box;transform-origin:24px 25px;
  animation:lg-orbit 1.1s cubic-bezier(.5,0,.3,1) .55s 2 both, lg-spark-out .4s ease 2.75s forwards}
.logo:hover .logo-mark{animation:lg-spin .7s cubic-bezier(.6,.05,.2,1)}
.logo-word{display:inline-flex;font-size:calc(var(--mk,30px)*.6);animation:lg-word .6s ease .5s both}
.logo-word .w1{color:var(--txt)}
.logo-word .w2{background:linear-gradient(120deg,var(--primary),var(--accent),var(--secondary),var(--accent));
  background-size:220% 100%;-webkit-background-clip:text;background-clip:text;color:transparent;
  animation:lg-shine 6s linear infinite}
.logo-sub{font-size:11px;color:var(--muted);font-weight:600;text-transform:lowercase;
  border:1px solid var(--line-soft);padding:2px 8px;border-radius:999px;margin-left:2px}
@keyframes lg-draw{to{stroke-dashoffset:0}}
@keyframes lg-orbit{from{transform:rotate(0)}to{transform:rotate(360deg)}}
@keyframes lg-spark-out{to{opacity:0}}
@keyframes lg-pop{0%{transform:scale(0);opacity:0}60%{transform:scale(1.14)}100%{transform:scale(1);opacity:1}}
@keyframes lg-breathe{0%,100%{transform:scale(1)}50%{transform:scale(1.07)}}
@keyframes lg-spin{to{transform:rotate(360deg)}}
@keyframes lg-word{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}
@keyframes lg-shine{to{background-position:220% 0}}
@media (prefers-reduced-motion:reduce){
  .lg-shield{stroke-dashoffset:0;animation:none}
  .lg-cam{opacity:1;animation:none}
  .lg-play{opacity:1;animation:none}
  .lg-spark{opacity:0;animation:none}
  .logo:hover .logo-mark{animation:none}
  .logo-word,.logo-word .w2{animation:none}
  .logo-word .w2{background-position:0 0}
}

/* ── Chaveamento de torneio (bracket) ─────────────────────────────────────── */
.bracket{display:flex;gap:22px;overflow-x:auto;padding:6px 2px 12px}
.bround{display:flex;flex-direction:column;justify-content:space-around;gap:14px;min-width:210px}
.brtit{font-size:12px;color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:.04em;margin-bottom:2px}
.bmatch{background:#0c1526;border:1px solid var(--line);border-radius:10px;padding:8px 10px}
.brow{display:flex;justify-content:space-between;gap:10px;padding:3px 0}
.brow b{font-variant-numeric:tabular-nums;color:var(--muted)}
.brow.win{color:var(--accent);font-weight:700}
.brow.win b{color:var(--accent)}
.bscore{display:flex;align-items:center;gap:6px;margin-top:8px;border-top:1px dashed var(--line);padding-top:8px}
.bscore input{width:52px;padding:6px 8px;text-align:center}
.champ{display:flex;align-items:center;gap:10px;background:linear-gradient(135deg,rgba(56,245,181,.12),transparent);border:1px solid var(--accent);border-radius:12px;padding:12px 16px;margin-bottom:14px;font-weight:700}
.bwatch{display:block;font-size:12px;margin-top:8px;color:var(--secondary);border-top:1px dashed var(--line);padding-top:6px}
.jogos{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}
