
:root{
  --bg:#020617;
  --panel:rgba(7,18,31,.78);
  --panel2:rgba(2,6,23,.72);
  --stroke:rgba(255,255,255,.14);
  --gold:#f5c542;
  --gold2:#ffe08a;
  --cyan:#23d5ff;
  --green:#22c55e;
  --red:#fb7185;
  --text:#f8fafc;
  --muted:#b6c2d2;
  --shadow:0 24px 80px rgba(0,0,0,.45);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter, Arial, Helvetica, sans-serif;
  color:var(--text);
  min-height:100vh;
  background:
    radial-gradient(circle at 20% 0%, rgba(35,213,255,.22), transparent 34%),
    radial-gradient(circle at 90% 10%, rgba(245,197,66,.22), transparent 30%),
    linear-gradient(rgba(2,6,23,.78),rgba(2,6,23,.92)),
    url("img/cartaz.jpg") center/cover fixed;
}
body:before{
  content:"";
  position:fixed; inset:0;
  background:
    linear-gradient(90deg, rgba(255,255,255,.035) 1px, transparent 1px),
    linear-gradient(rgba(255,255,255,.028) 1px, transparent 1px);
  background-size:42px 42px;
  pointer-events:none;
  mask-image:linear-gradient(to bottom, black, transparent 82%);
}
.wrap{max-width:1240px;margin:auto;padding:22px;position:relative}
.hero{
  min-height:250px;
  display:flex;align-items:center;justify-content:space-between;gap:24px;
  padding:28px;
  margin-bottom:22px;
  border-radius:32px;
  background:
    linear-gradient(135deg, rgba(255,255,255,.14), rgba(255,255,255,.04)),
    linear-gradient(135deg, rgba(245,197,66,.18), rgba(35,213,255,.12));
  border:1px solid rgba(255,255,255,.18);
  box-shadow:var(--shadow);
  backdrop-filter:blur(18px);
  overflow:hidden;
  position:relative;
}
.hero:before{
  content:"";
  position:absolute; inset:-2px;
  background:linear-gradient(120deg, transparent 0%, rgba(35,213,255,.22) 35%, rgba(245,197,66,.2) 65%, transparent 100%);
  opacity:.6;
  pointer-events:none;
}
.hero>*{position:relative;z-index:1}
.brand{display:flex;align-items:center;gap:20px}
.logo{
  width:118px;height:118px;object-fit:cover;border-radius:28px;
  background:rgba(0,0,0,.42);
  padding:8px;
  border:1px solid rgba(245,197,66,.45);
  box-shadow:0 0 30px rgba(245,197,66,.18), 0 0 45px rgba(35,213,255,.13);
}
h1,h2,h3,h4{margin:0 0 12px}
h1{
  color:var(--gold2);
  font-size:clamp(34px,6vw,70px);
  line-height:.95;
  letter-spacing:-1.5px;
  text-transform:uppercase;
  text-shadow:0 0 24px rgba(245,197,66,.28);
}
h2{font-size:clamp(23px,3vw,34px)}
h3{color:var(--gold2)}
p{color:var(--muted);line-height:1.55}
.card{
  background:var(--panel);
  border:1px solid var(--stroke);
  border-radius:28px;
  padding:22px;
  margin-bottom:20px;
  backdrop-filter: blur(18px);
  box-shadow:0 18px 60px rgba(0,0,0,.3);
}
.tabs{
  display:flex;gap:10px;flex-wrap:wrap;margin-bottom:18px;
  position:sticky;top:10px;z-index:5;
  background:rgba(2,6,23,.55);
  backdrop-filter: blur(14px);
  padding:10px;border-radius:22px;border:1px solid rgba(255,255,255,.08)
}
.tab{
  color:white;text-decoration:none;
  border:1px solid rgba(255,255,255,.14);
  padding:12px 16px;border-radius:16px;
  background:rgba(255,255,255,.08);
  font-weight:900;
  cursor:pointer;
  transition:.2s transform,.2s background,.2s border;
}
.tab:hover{transform:translateY(-2px);background:rgba(255,255,255,.14)}
.tab.active{
  background:linear-gradient(135deg,var(--gold),#fff1a8);
  color:#07111f;
  border-color:rgba(245,197,66,.75);
  box-shadow:0 0 26px rgba(245,197,66,.22);
}
.grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}
input,button,select{
  border:0;border-radius:16px;padding:14px 15px;font-size:15px;outline:none
}
input,select{
  width:100%;
  background:rgba(255,255,255,.96);
  color:#0f172a;
  margin:6px 0;
  border:1px solid transparent;
}
input:focus{border-color:var(--cyan);box-shadow:0 0 0 4px rgba(35,213,255,.15)}
button{
  background:linear-gradient(135deg,var(--gold),#fff0a6);
  color:#07111f;font-weight:950;cursor:pointer;margin:6px 6px 6px 0;
  box-shadow:0 10px 28px rgba(245,197,66,.16);
  transition:.2s transform,.2s filter;
}
button:hover{transform:translateY(-2px);filter:brightness(1.05)}
button.secondary{
  background:rgba(255,255,255,.1);color:white;border:1px solid rgba(255,255,255,.18);
  box-shadow:none;
}
.group,.match,.tablebox,.ko-card{
  background:linear-gradient(135deg,rgba(255,255,255,.1),rgba(255,255,255,.035));
  border-radius:22px;
  padding:17px;
  border:1px solid rgba(255,255,255,.12);
  box-shadow:0 12px 35px rgba(0,0,0,.18);
}
.group h3,.tablebox h3{
  text-align:center;
  border-bottom:1px solid rgba(245,197,66,.25);
  padding-bottom:12px;
}
.team{
  padding:13px 14px;margin:9px 0;border-radius:16px;
  background:rgba(255,255,255,.09);
  border:1px solid rgba(255,255,255,.08);
  font-weight:800;
}
.match{
  display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:14px;margin:12px 0;
  position:relative;overflow:hidden;
}
.match:before{
  content:"";
  position:absolute;left:0;top:0;bottom:0;width:5px;
  background:linear-gradient(var(--gold),var(--cyan));
}
.match .teamA{text-align:right;font-weight:950;font-size:17px}
.match .teamB{text-align:left;font-weight:950;font-size:17px}
.score{
  min-width:96px;
  padding:10px 12px;
  text-align:center;
  font-size:24px;
  color:var(--gold2);
  font-weight:1000;
  white-space:nowrap;
  background:rgba(0,0,0,.35);
  border:1px solid rgba(245,197,66,.25);
  border-radius:16px;
}
.badge{
  display:inline-block;
  color:#03130b;background:var(--green);
  padding:5px 10px;border-radius:999px;
  font-size:11px;font-weight:1000;margin-top:6px;
}
.badge.ko{background:var(--cyan);color:#03131a}
table{width:100%;border-collapse:separate;border-spacing:0;overflow:hidden;border-radius:18px}
th,td{padding:12px 10px;border-bottom:1px solid rgba(255,255,255,.1);text-align:center}
th{
  color:#07111f;
  background:linear-gradient(135deg,var(--gold),#fff1a8);
  font-weight:1000;
}
td:first-child,th:first-child{text-align:left}
tbody tr:nth-child(1) td{background:rgba(245,197,66,.12)}
tbody tr:nth-child(2) td, tbody tr:nth-child(3) td{background:rgba(35,213,255,.08)}
.admin-row{
  display:grid;grid-template-columns:1fr 76px 76px 1fr auto;gap:9px;align-items:center;
  background:rgba(2,6,23,.48);padding:12px;border-radius:18px;margin:10px 0;
  border:1px solid rgba(255,255,255,.08)
}
.admin-row strong:first-child{text-align:right}
.nav a{
  color:white;text-decoration:none;margin-left:10px;
  border:1px solid rgba(255,255,255,.2);
  padding:12px 15px;border-radius:16px;background:rgba(0,0,0,.26);
  font-weight:900
}
.bracket{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px;align-items:start}
.round-title{
  color:var(--gold2);text-align:center;
  background:rgba(0,0,0,.22);
  border:1px solid rgba(245,197,66,.18);
  border-radius:18px;padding:12px;
}
.ko-card{margin-bottom:14px;position:relative}
.ko-card h4{margin:0 0 12px;color:var(--cyan);font-size:16px}
.winner{color:var(--green);font-weight:1000;padding:8px;border-radius:12px;background:rgba(34,197,94,.1)}
.loser{color:#cbd5e1;padding:8px}
.champion{
  text-align:center;
  background:
    radial-gradient(circle at center, rgba(245,197,66,.24), transparent 60%),
    linear-gradient(135deg,rgba(245,197,66,.22),rgba(34,197,94,.1));
  border:1px solid rgba(245,197,66,.45);
}
.hidden{display:none}
@media(max-width:850px){
  .wrap{padding:14px}
  .grid,.match,.admin-row,.bracket{grid-template-columns:1fr}
  .match .teamA,.match .teamB{text-align:center}
  .hero{display:block;text-align:center;padding:22px;min-height:unset}
  .brand{justify-content:center;flex-direction:column}
  .nav{margin-top:16px}
  .logo{width:98px;height:98px}
  .tabs{position:static;overflow-x:auto;flex-wrap:nowrap}
  .tab{white-space:nowrap}
  .card{padding:16px;border-radius:22px}
  .score{margin:auto}
  table{font-size:12px}
  th,td{padding:9px 6px}
}

.move-controls{
  grid-column:1/-1;
  display:flex;
  justify-content:center;
  gap:8px;
  flex-wrap:wrap;
}
button.mini{
  padding:9px 12px;
  font-size:13px;
  border-radius:12px;
}

.hero .nav:empty{display:none}


/* FIX MOBILE RESPONSIVE */
html, body{
  width:100%;
  max-width:100%;
  overflow-x:hidden;
}

img, video{
  max-width:100%;
}

@media(max-width:850px){
  .wrap{
    width:100%;
    max-width:100%;
    padding:12px;
    overflow-x:hidden;
  }

  .hero{
    width:100%;
    min-height:auto;
    padding:18px 14px;
    border-radius:24px;
    margin-bottom:16px;
  }

  .brand{
    width:100%;
    gap:12px;
  }

  .brand > div{
    width:100%;
    max-width:100%;
  }

  h1{
    font-size:30px;
    line-height:1.05;
    word-break:normal;
  }

  h2{
    font-size:24px;
  }

  p{
    font-size:15px;
  }

  .logo{
    width:86px;
    height:86px;
    border-radius:22px;
  }

  .tabs{
    position:static;
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:10px;
    width:100%;
    overflow:visible;
    padding:8px;
  }

  .tab{
    width:100%;
    text-align:center;
    padding:12px 8px;
    font-size:14px;
    white-space:normal;
    line-height:1.15;
  }

  .card{
    width:100%;
    max-width:100%;
    padding:16px;
    border-radius:22px;
  }

  .grid{
    grid-template-columns:1fr;
    gap:14px;
  }

  .group,
  .match,
  .tablebox,
  .ko-card{
    width:100%;
    max-width:100%;
  }

  .match{
    grid-template-columns:1fr;
    gap:10px;
    text-align:center;
    padding:16px 12px;
  }

  .match .teamA,
  .match .teamB{
    text-align:center;
    font-size:16px;
    overflow-wrap:anywhere;
  }

  .score{
    min-width:0;
    width:max-content;
    max-width:100%;
    margin:auto;
    font-size:22px;
  }

  .team{
    overflow-wrap:anywhere;
  }

  .tablebox{
    overflow-x:auto;
  }

  table{
    min-width:560px;
  }

  .bracket{
    grid-template-columns:1fr;
  }

  .admin-row{
    grid-template-columns:1fr;
  }

  .admin-row strong:first-child{
    text-align:center;
  }

  input, button, select{
    width:100%;
  }

  button{
    margin:6px 0;
  }
}

@media(max-width:420px){
  .wrap{
    padding:10px;
  }

  h1{
    font-size:26px;
  }

  .tabs{
    grid-template-columns:1fr 1fr;
  }

  .tab{
    font-size:13px;
    padding:11px 6px;
  }

  .hero{
    border-radius:20px;
  }

  .card{
    padding:14px;
  }
}


/* MENU MOBILE */
.mobile-menu-btn{
  display:none;
}

@media(max-width:850px){

  .mobile-menu-btn{
    display:flex;
    align-items:center;
    justify-content:center;
    width:100%;
    padding:14px;
    border-radius:18px;
    background:linear-gradient(135deg,var(--gold),#fff1a8);
    color:#07111f;
    font-size:18px;
    font-weight:900;
    margin-bottom:12px;
    cursor:pointer;
  }

  .tabs{
    display:none !important;
    grid-template-columns:1fr;
    width:100%;
  }

  .tabs.open{
    display:grid !important;
  }

  .tab{
    width:100%;
  }
}


/* ALINHAMENTO DOS RESULTADOS NO ADMIN */
.admin-row{
  grid-template-columns:1fr 76px 20px 76px 1fr auto !important;
}

.admin-team{
  font-weight:900;
  text-align:center;
  overflow-wrap:anywhere;
}

.score-separator{
  text-align:center;
  font-weight:900;
  color:var(--gold2);
  font-size:20px;
}

.score-input{
  text-align:center;
}

.save-btn{
  min-width:110px;
}

.datetime-input{
  grid-column:1 / -1 !important;
}

.admin-row small{
  grid-column:1 / -1 !important;
  color:#b8c7c0;
  text-align:center;
}

@media(max-width:850px){
  .admin-row{
    display:grid !important;
    grid-template-columns:1fr 16px 1fr !important;
    gap:10px !important;
    align-items:center !important;
    padding:16px !important;
  }

  .admin-team-a{
    grid-column:1 / 2;
    grid-row:1;
  }

  .score-a{
    grid-column:1 / 2;
    grid-row:2;
  }

  .score-separator{
    grid-column:2 / 3;
    grid-row:2;
    align-self:center;
  }

  .admin-team-b{
    grid-column:3 / 4;
    grid-row:1;
  }

  .score-b{
    grid-column:3 / 4;
    grid-row:2;
  }

  .admin-team{
    font-size:15px;
    line-height:1.2;
    min-height:34px;
    display:flex;
    align-items:end;
    justify-content:center;
    text-align:center;
  }

  .score-input{
    width:100% !important;
    height:48px;
    margin:0 !important;
    text-align:center;
    font-size:16px;
  }

  .save-btn{
    grid-column:1 / -1;
    width:100%;
    margin:8px 0 0;
    height:50px;
  }

  .move-controls{
    grid-column:1 / -1 !important;
    display:grid !important;
    grid-template-columns:1fr 1fr;
    gap:10px;
  }

  .move-controls button{
    width:100%;
    margin:0;
  }

  .datetime-input{
    grid-column:1 / -1 !important;
    width:100%;
    margin-top:8px !important;
  }

  .admin-row small{
    grid-column:1 / -1 !important;
    text-align:center;
    font-size:12px;
  }
}
