/* ============================================================
   Admin - Bolao da Copa
   ============================================================ */
:root{
  /* Paleta Wissence */
  --cream:#F2EBE1;--coffee:#382A21;--cocoa:#7C5D48;--sage:#B3B792;--sand:#E5D2B8;
  --green:#6f8a4f;--green-d:#4f6438;--green-l:#82a05f;--gold:#c9a55c;
  --ink:#2a1f17;--line:#e7ded0;--bg:#f3ede2;--danger:#b5563b;--blue:#1d4ed8;
}
*{box-sizing:border-box}
body{margin:0;font-family:'Segoe UI',system-ui,Roboto,Arial,sans-serif;color:var(--ink);background:var(--bg)}
.hidden{display:none!important}
.err{color:var(--danger);font-weight:600;font-size:14px;min-height:1px;margin:8px 0 0}
.hint{color:#5a6b60;font-size:13px;margin:0 0 14px}
.hint code{background:#dfe7e1;padding:1px 6px;border-radius:5px}
hr{border:none;border-top:1px solid var(--line);margin:18px 0}

/* ---- login ---- */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;
  background:radial-gradient(900px 600px at 50% -10%,#8aa56a,#6f8a4f 45%,#3a2c22)}
.login-card{background:#fff;border-radius:22px;padding:34px 30px;width:min(92vw,380px);text-align:center;box-shadow:0 20px 60px rgba(0,0,0,.3)}
.login-emoji{font-size:52px}
.login-card h1{margin:6px 0;font-size:24px}
.login-card p{color:#5a6b60;margin:0 0 16px}
.login-card input{width:100%;padding:14px;border:2px solid var(--line);border-radius:12px;font-size:22px;text-align:center;letter-spacing:6px}
.back{display:block;margin-top:14px;color:#7a8a80;font-size:13px;text-decoration:none}

/* ---- botoes ---- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;border:none;border-radius:11px;
  padding:12px 18px;font-weight:800;font-size:15px;cursor:pointer;transition:.12s;margin-top:12px}
.btn:active{transform:translateY(1px)}
.btn.primary{background:linear-gradient(120deg,#e0bc6e,var(--gold));color:#3a2a00}
.btn.ghost{background:#e7eee9;color:#33433a}
.btn.danger{background:#fdecea;color:var(--danger)}
.btn.sm{padding:7px 12px;font-size:13px;margin-top:0}
.btn[disabled]{opacity:.6;cursor:wait}

/* ---- topbar ---- */
.topbar{display:flex;align-items:center;gap:12px;background:var(--coffee);color:#fff;padding:10px 18px;position:sticky;top:0;z-index:10;flex-wrap:wrap}
.topbar strong{font-size:16px;display:flex;align-items:center;gap:9px;white-space:nowrap}
.topbar-logo{width:32px;height:32px;border-radius:50%;background:var(--cream);padding:4px;box-sizing:border-box;flex:0 0 auto}

/* ---- campaign bar (topbar) ---- */
.campaign-bar{display:flex;align-items:center;gap:8px;margin-left:auto}
.cb-label{font-size:12px;opacity:.85}
.topbar .btn{margin-top:0}

/* dropdown custom de campanha */
.cdrop{position:relative}
.cdrop-btn{display:flex;align-items:center;justify-content:space-between;gap:10px;height:38px;
  min-width:200px;max-width:300px;padding:0 12px;border-radius:10px;background:#4a3527;color:#fff;
  border:1px solid #5d4636;font-weight:700;font-size:14px;cursor:pointer;font-family:inherit}
.cdrop-btn:hover{background:#54402f}
.cdrop-btn #campaignDropLabel{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cdrop-arrow{opacity:.75;font-size:11px;transition:transform .15s}
.cdrop.open .cdrop-arrow{transform:rotate(180deg)}
.cdrop-menu{position:absolute;top:calc(100% + 6px);right:0;min-width:250px;background:#fff;
  border:1px solid var(--line);border-radius:12px;box-shadow:0 16px 44px rgba(56,42,33,.28);
  padding:6px;z-index:40;max-height:64vh;overflow:auto}
.cdrop-item{display:flex;align-items:center;gap:8px;padding:10px 11px;border-radius:9px;cursor:pointer;
  font-weight:700;font-size:14px;color:var(--ink)}
.cdrop-item:hover{background:var(--bg)}
.cdrop-item.sel{background:#eef4e9;color:var(--green-d)}
.cdrop-item .ci-tag{margin-left:auto;font-size:10px;font-weight:800;padding:2px 8px;border-radius:999px}
.cdrop-item .ci-tag.vip{background:#fff3cf;color:#7a5a00}
.cdrop-item .ci-tag.pub{background:#eaf4ee;color:var(--green-d)}
.cdrop-empty{padding:12px;color:#9a8b78;font-size:13px;text-align:center}

/* ---- tabs ---- */
.tabs{display:flex;align-items:center;gap:4px;overflow-x:auto;background:#fff;padding:8px 12px;border-bottom:1px solid var(--line);position:sticky;top:48px;z-index:9}
.tabs button{border:none;background:transparent;padding:9px 14px;border-radius:10px;font-weight:700;font-size:14px;color:#5a6b60;cursor:pointer;white-space:nowrap}
.tabs button.active{background:var(--green);color:#fff}
.tabs-group{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.6px;color:#9aa9a0;white-space:nowrap;padding:0 4px}
.tabs-group b{color:var(--green-d)}
.tabs-sep{width:1px;height:24px;background:var(--line);margin:0 4px;flex:0 0 auto}

/* ---- lista de campanhas ---- */
.campaign-list{display:flex;flex-direction:column;gap:10px;margin-bottom:16px}
.camp-card{display:flex;align-items:center;gap:12px;border:2px solid var(--line);border-radius:14px;padding:14px;background:#fbfdfc;flex-wrap:wrap}
.camp-card.sel{border-color:var(--green-l);box-shadow:0 0 0 3px rgba(22,163,74,.12)}
.camp-card-main{flex:1;min-width:0}
.camp-title{font-weight:800;font-size:16px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.camp-url{font-family:monospace;font-size:13px;color:var(--green-d);text-decoration:none}
.camp-url:hover{text-decoration:underline}
.camp-meta{color:#7a8a80;font-size:12px;margin-top:3px}
.camp-card-actions{display:flex;gap:8px;flex-wrap:wrap}
.badge-global{font-size:11px;font-weight:800;background:#eaf0fb;color:#1d4ed8;padding:3px 10px;border-radius:999px;vertical-align:middle}
.need-campaign{background:#fff8e6;border:1px dashed var(--gold);color:#7a5a00;padding:16px;border-radius:12px;font-weight:700;text-align:center}

/* ---- match picker (config) ---- */
.match-pick{display:flex;flex-direction:column;gap:6px;margin-top:8px}
.pick-item{display:flex;align-items:center;gap:8px;background:#fbfdfc;border:1px solid var(--line);border-radius:10px;padding:9px 12px;margin:0;font-weight:600;cursor:pointer}
.pick-item input{width:auto;margin:0}
.fmini{width:20px;height:14px;border-radius:2px;object-fit:cover;box-shadow:0 1px 3px rgba(0,0,0,.2)}
.del-rule{background:#fdecea;color:var(--danger);border:none;border-radius:8px;width:30px;height:30px;font-weight:900;cursor:pointer}
.panel h4{margin:0 0 6px;font-size:14px}

/* ---- content ---- */
.content{max-width:920px;margin:0 auto;padding:22px 16px 80px}
.panel{background:#fff;border-radius:18px;padding:22px;box-shadow:0 8px 30px rgba(0,0,0,.06)}
.panel h2{margin:0 0 4px}
.panel h3{margin:18px 0 8px}
label{display:block;font-weight:700;font-size:13px;color:#33433a;margin:12px 0 0}
input,select,textarea{width:100%;margin-top:5px;padding:11px 12px;border:2px solid var(--line);border-radius:10px;font-size:15px;font-family:inherit;background:#f8faf9}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--green-l);background:#fff}
.row{display:flex;gap:12px;align-items:center;flex-wrap:wrap;margin-top:12px}
.chk{display:flex;align-items:center;gap:8px;margin-top:0}
.chk input{width:auto;margin:0}

/* ---- linhas dinamicas (jogos/brindes/combos) ---- */
.dyn{border:2px solid var(--line);border-radius:14px;padding:14px;margin-top:12px;background:#fbfdfc;position:relative}
.dyn .del{position:absolute;top:8px;right:8px;background:#fdecea;color:var(--danger);border:none;border-radius:8px;width:28px;height:28px;font-weight:900;cursor:pointer}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.grid3{display:grid;grid-template-columns:1fr 90px 1fr;gap:10px;align-items:end}
.grid-mini{display:grid;grid-template-columns:1fr 80px;gap:8px;align-items:end}
.small{font-size:12px;color:#7a8a80}

/* seletor de bandeira */
.flag-pick{display:flex;align-items:center;gap:8px;margin-top:5px}
.flag-pick select{margin-top:0}
.flag-prev{width:42px;height:28px;border-radius:5px;object-fit:cover;box-shadow:0 2px 6px rgba(0,0,0,.22);flex:0 0 auto}
.flag-prev.empty{display:inline-flex;align-items:center;justify-content:center;background:#e7eee9;font-size:18px}

/* ---- card de jogo (layout melhorado) ---- */
.match-row{padding:0;overflow:hidden}
.match-head{
  display:flex;align-items:center;justify-content:center;gap:14px;flex-wrap:wrap;
  background:linear-gradient(120deg,#0a7d2c,#065c1f);color:#fff;
  padding:14px 46px;font-weight:800;font-size:16px;
}
.mh-team{display:flex;align-items:center;gap:8px;max-width:42%}
.mh-team span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mh-home{justify-content:flex-end;text-align:right}
.mh-away{justify-content:flex-start}
.mh-flag{width:34px;height:23px;border-radius:4px;object-fit:cover;box-shadow:0 2px 6px rgba(0,0,0,.3);flex:0 0 auto}
.mh-flag.empty{display:inline-flex;align-items:center;justify-content:center;background:rgba(255,255,255,.2);font-size:15px}
.mh-vs{background:var(--gold);color:#3a2a00;width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:15px;flex:0 0 auto}
.match-row>.del{z-index:2}

.match-teams{display:flex;align-items:flex-end;gap:14px;padding:18px 16px 4px}
.team-edit{flex:1;min-width:0;background:#fbfdfc;border:1px solid var(--line);border-radius:14px;padding:12px}
.te-label{font-size:12px;font-weight:800;color:var(--green-d);text-transform:uppercase;letter-spacing:.5px}
.team-edit .flag-pick{margin-top:8px}
.team-edit .flag-pick select{flex:1;min-width:0}
.team-edit .m-home,.team-edit .m-away{margin-top:8px;font-weight:700}
.vs-badge{flex:0 0 auto;width:36px;height:36px;border-radius:50%;background:var(--gold);color:#3a2a00;
  display:flex;align-items:center;justify-content:center;font-weight:900;font-size:18px;margin-bottom:14px;box-shadow:0 4px 10px rgba(224,161,6,.4)}

.match-meta{display:grid;grid-template-columns:1.1fr 1fr 1.3fr;gap:12px;padding:8px 16px 18px}
.match-meta label{margin-top:0}

@media(max-width:620px){
  .match-teams{flex-direction:column;align-items:stretch}
  .vs-badge{margin:0 auto;transform:rotate(90deg)}
  .match-meta{grid-template-columns:1fr}
  .mh-team{max-width:38%}
}

/* combos: selecao de itens */
.combo-items-edit{margin-top:10px;border-top:1px dashed var(--line);padding-top:10px}
.combo-item-row{display:grid;grid-template-columns:1fr 70px 34px;gap:8px;align-items:center;margin-top:6px}
.combo-item-row .del{position:static;width:30px;height:30px}

/* regras */
.rules-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.rule-row{display:grid;grid-template-columns:auto 60px auto 1fr 30px;gap:8px;align-items:center;margin-top:8px}
.rule-row .lbl{font-size:13px;font-weight:700;white-space:nowrap}
@media(max-width:640px){.rules-grid{grid-template-columns:1fr}.grid3{grid-template-columns:1fr}}

/* whitelist */
.wl-list{margin-top:16px;display:flex;flex-direction:column;gap:8px}
.wl-item{display:flex;align-items:center;gap:10px;background:#fbfdfc;border:1px solid var(--line);border-radius:10px;padding:10px 12px;font-size:14px;flex-wrap:wrap}
.wl-item .who{font-weight:700}
.wl-item .lnk{font-family:monospace;font-size:12px;background:#eaf4ee;color:var(--green-d);padding:3px 8px;border-radius:6px;cursor:pointer}
.wl-item .used{color:#c0392b;font-size:12px;font-weight:700}
.wl-item .del{margin-left:auto;background:#fdecea;color:var(--danger);border:none;border-radius:8px;width:28px;height:28px;font-weight:900;cursor:pointer}

/* participantes */
.part-list{margin-top:14px;display:flex;flex-direction:column;gap:6px}
.part{display:grid;grid-template-columns:1fr auto;gap:10px;background:#fbfdfc;border:1px solid var(--line);border-radius:10px;padding:10px 12px;font-size:14px}
.part .meta{color:#7a8a80;font-size:12px}
.tag{font-size:11px;font-weight:800;padding:2px 8px;border-radius:999px}
.tag.vip{background:#fff3cf;color:#7a5a00}
.tag.public{background:#eaf4ee;color:var(--green-d)}
.tag.win{background:#eafbef;color:var(--green-d)}

/* resultados */
.result-row{display:grid;grid-template-columns:1fr auto;gap:12px;align-items:center;background:#fbfdfc;border:1px solid var(--line);border-radius:12px;padding:12px;margin-top:10px}
.result-row .score-edit{display:flex;align-items:center;gap:6px}
.result-row .score-edit input{width:54px;text-align:center;font-size:18px;font-weight:800}
.result-row .badge-fin{font-size:12px;font-weight:800;color:var(--green-d);background:#eafbef;padding:3px 9px;border-radius:999px}
.summary{margin-top:16px;font-weight:700}
.summary .ok{color:var(--green-d)}
#winnersList{margin-top:12px;display:flex;flex-direction:column;gap:6px}

/* toast */
.toast{position:fixed;left:50%;bottom:24px;transform:translateX(-50%) translateY(16px);background:#0b1d12;color:#fff;padding:12px 20px;border-radius:12px;font-weight:700;opacity:0;transition:.3s;z-index:50}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast.error{background:#7a1f17}
