@import url('https://fonts.googleapis.com/css2?family=Cinzel:wght@500;700&display=swap');

/* ============================================================
   Tema "OT server" - azul-aco + pergaminho creme + faixas marrom
   Fonte: Verdana/Tahoma no corpo (legivel), Cinzel nos titulos
   ============================================================ */
:root{
  --parch:#f6f0e2;        /* pergaminho claro */
  --parch2:#efe5c9;       /* zebrado / cabecalho de tabela */
  --parch3:#e3d6ad;
  --ink:#2a2417;          /* texto escuro */
  --ink-muted:#6b5f44;
  --gold:#b8902f;
  --gold-l:#e6c768;
  --frame:#4a4030;        /* moldura escura (peltre/marrom) */
  --frame-d:#2c2518;
  --head1:#7d6c55;        /* faixa marrom/taupe */
  --head2:#5b4c39;
  --ok:#2e7d32;           /* verde (numeros/pago) */
  --danger:#b23b22;
  --blue:#23578f;         /* links */
  --cyan:#57c4d4;
  --paper:url('parchment.png');  /* textura de pergaminho (imagem) */
}
*{box-sizing:border-box}
body{
  margin:0;color:var(--ink);
  font:15px/1.55 Verdana,Tahoma,'Segoe UI',Arial,sans-serif;
  background-color:#0d1822;
  background-image:
    radial-gradient(circle at 50% -8%, rgba(60,95,135,.38), transparent 55%),
    repeating-linear-gradient(135deg, rgba(255,255,255,.012) 0 2px, transparent 2px 8px),
    linear-gradient(#15293a,#0a141d);
  background-attachment:fixed;
}
a{color:var(--blue)}
a:hover{text-decoration:underline}
.muted{color:var(--ink-muted)}
.small{font-size:.85em}
.right{text-align:right}

h1,h2,h3{font-family:'Cinzel',Georgia,serif;letter-spacing:.4px}
h1{font-size:1.5rem;margin:.2em 0 .6em;color:#ecdca8;text-shadow:1px 1px 2px rgba(0,0,0,.7)}
.card h1{color:#473312;text-shadow:none}
h2{font-size:1.12rem;margin:0 0 .6em}
h3{margin:.2em 0 .5em;color:#4a3a18}

/* ===== Topo (azul-aco + dourado) ===== */
.topbar{
  position:sticky;top:0;z-index:50;
  display:flex;justify-content:space-between;align-items:center;gap:12px;
  padding:10px 22px;flex-wrap:wrap;
  background:linear-gradient(#1b3047,#0d1a27);
  border-bottom:3px solid var(--gold);box-shadow:0 3px 14px rgba(0,0,0,.65);
}
.brand a{font-family:'Cinzel',serif;font-weight:700;font-size:1.4rem;color:var(--gold-l);text-shadow:1px 1px 2px #000;display:inline-flex;align-items:center;gap:6px}
.brand-sword{color:var(--gold);font-size:1.15em;text-shadow:0 0 8px rgba(230,199,104,.5)}
.brand-sub{color:#9fb4c4;font-size:.78em;margin-left:6px;text-transform:uppercase;letter-spacing:1px}
.topbar nav{display:flex;align-items:center;gap:6px;flex-wrap:wrap}

.navlink{
  font-family:'Cinzel',serif;color:#cfdcea;font-weight:500;letter-spacing:.4px;
  text-decoration:none;padding:7px 12px;border-radius:6px;
  border:1px solid transparent;transition:.15s;
}
.navlink:hover{color:#fff;background:rgba(255,255,255,.06);text-decoration:none}
.navlink.active{color:var(--gold-l);background:rgba(230,199,104,.12);border-color:rgba(230,199,104,.4)}
.navlink.logout{color:#bd9e74}
.navlink.logout:hover{color:#ff9a8a;background:rgba(217,83,79,.14)}

.user-chip{
  display:inline-flex;align-items:center;gap:8px;text-decoration:none;
  background:rgba(255,255,255,.06);border:1px solid rgba(230,199,104,.3);
  border-radius:999px;padding:3px 12px 3px 4px;margin-left:4px;transition:.15s;
}
.user-chip:hover{background:rgba(230,199,104,.14);border-color:rgba(230,199,104,.55);text-decoration:none}
.nav-avatar{
  width:30px;height:30px;border-radius:50%;flex:0 0 auto;
  background:linear-gradient(#e9c45f,#b8860b);color:#2a1f06;
  display:flex;align-items:center;justify-content:center;
  font:700 1rem 'Cinzel',serif;box-shadow:0 0 0 1px #fff7df inset,0 1px 3px rgba(0,0,0,.4);
}
.nav-uname{color:#f0dca0;font-weight:600;font-family:'Cinzel',serif}
.wrap{max-width:1040px;margin:0 auto;padding:22px}
.foot{text-align:center;color:#7f8ea0;padding:24px;font-size:.85em;font-family:'Cinzel',serif}

/* ===== Botao fixo do Discord ===== */
.discord-fab{
  /* posicao fixa: canto superior direito (em todas as paginas) */
  position:fixed;z-index:60;top:100px;right:48px;
  display:inline-flex;align-items:center;gap:8px;
  background:#5865F2;color:#fff;text-decoration:none;
  padding:10px 16px;border-radius:999px;
  font:700 14px Verdana,Tahoma,sans-serif;letter-spacing:.3px;
  border:1px solid #3b45c9;box-shadow:0 5px 16px rgba(0,0,0,.5);
  transition:background .15s, box-shadow .15s, transform .15s;
}
.discord-fab:hover{background:#4a54e0;color:#fff;text-decoration:none;transform:scale(1.05);box-shadow:0 7px 20px rgba(0,0,0,.55)}
.discord-fab svg{width:20px;height:20px;fill:currentColor;flex:0 0 auto}
@media(max-width:1340px){
  /* gutter estreito/celular: canto inferior direito (nao sobrepoe o conteudo) */
  .discord-fab{top:auto;bottom:20px;left:auto;right:18px}
}

/* ===== Painel de pergaminho com moldura ===== */
.card,.meus-claims{
  position:relative;color:var(--ink);
  background:var(--paper), linear-gradient(#f7f1e3,#efe5c9);
  border:2px solid var(--frame);border-radius:5px;padding:18px 20px;margin-bottom:18px;
  box-shadow:0 0 0 2px var(--gold) inset,0 6px 16px rgba(0,0,0,.5);
}
.card.narrow{max-width:400px;margin:48px auto}

/* Titulo de secao = faixa.
   Usa a textura assets/banner.png (se existir); senao cai no gradiente marrom. */
.card h2,.meus-claims h2{
  background:url('banner.png') repeat-x center/auto 100%, linear-gradient(var(--head1),var(--head2));
  color:#f4ead2;text-shadow:1px 1px 2px rgba(0,0,0,.7);
  margin:-18px -20px 16px;padding:10px 18px;
  border-bottom:2px solid var(--gold);border-radius:3px 3px 0 0;
  font-size:1.05rem;letter-spacing:.6px;
}

/* ===== Formularios ===== */
label{display:block;margin:10px 0;font-size:.9em;color:#4a3a18;font-weight:600}
label input,input,textarea,select{
  width:100%;margin-top:4px;padding:9px 10px;
  background:#fcf7e9;border:1px solid var(--frame);border-radius:4px;
  color:var(--ink);font:14px Verdana,Tahoma,sans-serif;
}
input:focus,textarea:focus,select:focus{outline:2px solid var(--gold);border-color:var(--gold)}
.inline{display:inline-flex;gap:6px;align-items:center;flex-wrap:wrap}
.inline input[type=date]{width:auto;margin-top:0}
.inline select{width:auto;margin-top:0}
.gb-pay{display:flex;align-items:center;gap:6px;flex-wrap:nowrap;white-space:nowrap}

/* ===== Botoes ===== */
.btn{
  display:inline-block;padding:8px 14px;cursor:pointer;
  font:700 13px Verdana,Tahoma,sans-serif;color:#3a2c10;
  background:linear-gradient(#ecd9a0,#cdb066);
  border:1px solid var(--frame);border-radius:4px;
  box-shadow:0 1px 0 #fff6d8 inset,0 1px 2px rgba(0,0,0,.3);
}
.btn:hover{background:linear-gradient(#f3e3b4,#d8bd74)}
.btn.small{padding:5px 10px;font-size:.82em}
.btn.primary{background:linear-gradient(#e6bf52,#b8860b);color:#2a1f06;border-color:var(--frame-d)}
.btn.primary:hover{background:linear-gradient(#f0cd66,#c8930f)}
.btn.danger{background:linear-gradient(#c0654f,#94301f);color:#fff;border-color:#5a1a10}
.btn.danger:hover{background:linear-gradient(#cf7460,#a53826)}
.btn:disabled{opacity:.45;cursor:not-allowed}

/* ===== Tabelas (zebradas, estilo ranking) ===== */
table{width:100%;border-collapse:collapse;margin-top:8px;background:#fcf7e9;border:1px solid var(--frame)}
th,td{text-align:left;padding:8px 10px;border-bottom:1px solid #e0d3ab;vertical-align:middle}
th{font-family:'Cinzel',serif;background:var(--parch3);color:#4a3712;font-size:.85em;border-bottom:2px solid var(--frame)}
table tr:nth-child(2n) td{background:rgba(120,90,40,.06)}
tr:hover td{background:rgba(184,144,47,.14)}
tr.inativo{opacity:.5}

/* ===== Selos / etiquetas ===== */
.badge{background:var(--danger);color:#fff;border-radius:10px;padding:1px 8px;font-size:.75em;margin-left:6px}
.tag{font-size:.74em;padding:2px 8px;border-radius:4px;background:var(--parch3);border:1px solid var(--frame);color:#4a3a16}
.tag.mini{font-size:.7em;padding:1px 6px;margin-left:4px}
.tag.danger{color:#fff;background:var(--danger);border-color:#5a1a10}

.flash{background:linear-gradient(#fbf0cf,#f2e3b8);border:1px solid var(--gold);border-left:5px solid var(--gold);padding:10px 14px;border-radius:5px;margin-bottom:16px;color:#4a3a14}
.flash.ok{background:linear-gradient(#e8f6e0,#d6edc8);border-color:#4e7d2e;border-left-color:#4e7d2e;color:#274d12}
.flash.err{background:linear-gradient(#fbe4e0,#f5cdc6);border-color:#9c2a14;border-left-color:#9c2a14;color:#6e1d0f}
.erro{color:#9c2a14;font-weight:600}.sucesso{color:var(--ok);font-weight:600}
.pago{color:var(--ok);font-weight:700}.naopago{color:#9c6a14;font-weight:600}

/* ===== Banner de status do jogador ===== */
.status-banner{display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap;padding:12px 16px;border-radius:5px;margin-bottom:18px;border:2px solid var(--frame);box-shadow:0 0 0 1px var(--gold) inset}
.status-banner.ok{background:linear-gradient(#e6efce,#d6e3b2)}
.status-banner.warn{background:linear-gradient(#f6e6c0,#ecd29a)}

/* ===== Meus claims ===== */
.meus-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:12px}
.meu-card{position:relative;background:var(--paper), linear-gradient(#fdf8ea,#f1e7cb);border:1px solid var(--frame);border-left:4px solid var(--gold);border-radius:7px;padding:11px 13px;box-shadow:0 1px 0 #fff8e4 inset, 0 2px 6px rgba(0,0,0,.25)}
.meu-nome{font-family:'Cinzel',serif;font-weight:700;font-size:1.02rem;color:#4a3414;line-height:1.15}
.meu-city{font-family:Verdana,sans-serif;font-weight:400;font-size:.7rem;color:var(--ink-muted);text-transform:uppercase;letter-spacing:.5px;margin-left:4px}
.meu-meta{display:flex;gap:6px;flex-wrap:wrap;margin:8px 0}
.char-tag{display:inline-flex;align-items:center;gap:4px;background:#efe0b8;border:1px solid var(--frame);border-radius:999px;padding:2px 10px;font-size:.82rem;font-weight:600;color:#4a3414}
.next-tag{display:inline-flex;align-items:center;background:var(--blue);color:#fff;border-radius:999px;padding:2px 9px;font-size:.78rem;font-weight:600}
.meu-timer{font-size:.85rem;margin-bottom:6px;color:var(--ink-muted)}
.meu-timer .timer.big{font:700 1.18rem 'Cinzel',serif;color:#9c5a00;font-variant-numeric:tabular-nums}
.meu-bar-wrap{height:6px;background:#e2d4ab;border-radius:99px;overflow:hidden;margin-bottom:10px}
.meu-bar{height:100%;border-radius:99px;transition:width .4s}
.meu-bar.ok{background:linear-gradient(90deg,#3fae63,#2f7d3f)}
.meu-bar.mid{background:linear-gradient(90deg,#e0a93b,#b8860b)}
.meu-bar.low{background:linear-gradient(90deg,#d9694f,#a8341f)}
.na-fila-resumo{margin:10px 0 0;font-size:.9em;color:var(--ink-muted)}

/* ===== Avisos de guild bank (sexta / bloqueio) ===== */
.alerta-bloqueio{
  background:linear-gradient(#c0392b,#7a1f10);color:#fff;border:2px solid #5a1408;
  border-radius:8px;padding:13px 18px;margin-bottom:16px;font-size:1.02rem;
  box-shadow:0 0 0 1px rgba(255,255,255,.12) inset, 0 4px 12px rgba(0,0,0,.45);
}
.alerta-sexta{
  background:linear-gradient(#f1da8c,#e2bb50);color:#4a3408;border:2px solid var(--gold);
  border-radius:8px;padding:11px 18px;margin-bottom:16px;
  box-shadow:0 0 0 1px #fff7df inset, 0 3px 9px rgba(0,0,0,.3);
}
.alerta-x{cursor:pointer;float:right;font-weight:700;opacity:.7;margin-left:12px;font-size:1.2em;line-height:1;color:inherit}
.alerta-x:hover{opacity:1}

/* ===== Avisos de claim (botao toggle + banner) ===== */
.btn.btn-avisos{
  display:inline-flex;align-items:center;gap:7px;margin-left:12px;vertical-align:middle;
  font:700 .8rem Verdana,sans-serif;letter-spacing:.2px;text-transform:none;
  padding:5px 14px;border-radius:999px;cursor:pointer;
  background:rgba(0,0,0,.22);color:var(--gold-l);border:1px solid var(--gold);
  box-shadow:0 1px 3px rgba(0,0,0,.35);transition:.18s;
}
.btn.btn-avisos:hover{background:rgba(0,0,0,.34);color:#fff;border-color:var(--gold-l)}
.btn.btn-avisos.active{
  background:linear-gradient(#43b56a,#2c7a40);color:#fff;border-color:#1f5a2d;
  text-shadow:0 1px 1px rgba(0,0,0,.3);
  box-shadow:0 0 0 1px rgba(255,255,255,.18) inset, 0 0 10px rgba(63,174,99,.55);
}
.btn.btn-avisos.active::after{
  content:'';width:8px;height:8px;border-radius:50%;background:#c6ffd6;
  box-shadow:0 0 6px #7CFFA0;animation:avisoPulse 1.4s infinite;
}
@keyframes avisoPulse{0%,100%{opacity:.35;transform:scale(.8)}50%{opacity:1;transform:scale(1.15)}}
.aviso-pop{position:fixed;top:78px;right:18px;z-index:200;max-width:330px;
  background:linear-gradient(#8a1c1c,#560d0d);color:#f4ead2;border:2px solid var(--gold);
  border-radius:8px;padding:12px 16px;font-weight:600;box-shadow:0 6px 20px rgba(0,0,0,.6);
  animation:avisoIn .25s ease}
.aviso-pop .aviso-x{cursor:pointer;margin-left:8px;opacity:.85;font-weight:700;float:right}
.aviso-pop .aviso-x:hover{opacity:1}
@keyframes avisoIn{from{transform:translateX(24px);opacity:0}to{transform:translateX(0);opacity:1}}

/* bolinhas de status nas listas (livre/ocupado/meu) */
.stdot{display:inline-block;width:9px;height:9px;border-radius:50%;margin-right:6px;vertical-align:middle;flex:0 0 auto}
.stdot.ok{background:#2f9d4f;box-shadow:0 0 5px rgba(63,191,106,.6)}
.stdot.no{background:#c43b22;box-shadow:0 0 5px rgba(196,59,34,.5)}
.stdot.gold{background:var(--gold);box-shadow:0 0 5px rgba(230,199,104,.8)}

/* ===== Barra de resumo + filtros ===== */
.toolbar{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:14px;
  background:var(--paper), linear-gradient(#f1e7cb,#e6d5a8);border:2px solid var(--frame);border-radius:5px;padding:10px 14px;box-shadow:0 0 0 1px var(--gold) inset}
.resumo{display:flex;gap:14px;flex-wrap:wrap;font-weight:700;font-size:.9em}
.resumo .r-livre{color:var(--ok)}.resumo .r-ocup{color:#b23b22}
.resumo .r-meu{color:#9c6b12}.resumo .r-fila{color:var(--blue)}
.filtros{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.filtros #f-search{width:200px}
.filtros input,.filtros select{padding:7px 10px}
.status-tabs{display:flex;gap:4px}
.status-tabs .btn.active{background:linear-gradient(#e6bf52,#b8860b);color:#2a1f06;border-color:var(--frame-d)}

/* ===== Lista compacta por cidade ===== */
.city-group{margin-bottom:16px;border:1px solid var(--frame);border-radius:5px;overflow:hidden;background:#fcf7e9}
.city-head{
  font-family:'Cinzel',serif;margin:0;padding:9px 14px;
  background:url('banner.png') repeat-x center/auto 100%, linear-gradient(var(--head1),var(--head2));
  color:#f4ead2;text-shadow:1px 1px 2px rgba(0,0,0,.7);border-bottom:2px solid var(--gold);
  font-size:.98rem;letter-spacing:1px;text-transform:uppercase;
}
.city-head .muted{color:#e0d2b0}
.rsp-row{
  display:grid;grid-template-columns:1fr auto auto;align-items:center;gap:12px;
  padding:9px 14px;border-bottom:1px solid #e6dab4;border-left:4px solid transparent;
}
.rsp-row:nth-child(2n){background:rgba(120,90,40,.05)}
.rsp-row:hover{background:rgba(184,144,47,.14)}
.rsp-row.st-livre{border-left-color:var(--ok)}
.rsp-row.st-ocupado{border-left-color:#b23b22}
.rsp-row.st-meu{border-left-color:var(--gold);background:linear-gradient(#f6e6a8,#eedb95)}
.rsp-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:600}
.rsp-status{font-size:.9em;white-space:nowrap}
.rsp-next{display:block;margin-top:3px;font-size:.85em;color:#5a4a22;font-weight:600;white-space:normal}

/* oferta / sua vez */
.rsp-row.st-vez{border-left-color:var(--gold);background:linear-gradient(#f7e9b0,#efdd97)}
.stdot.vez{background:var(--gold);box-shadow:0 0 6px rgba(230,199,104,.95)}
.sua-vez{box-shadow:0 0 0 2px var(--gold) inset, 0 0 16px rgba(230,199,104,.5), 0 6px 16px rgba(0,0,0,.5)}
.sua-vez h2{background:linear-gradient(#b8860b,#7a5a0e)}
.rsp-status .timer{color:#9c5a00;font-weight:700;float:none}
.rsp-action{display:flex;gap:6px;align-items:center;justify-content:flex-end}

/* etiquetas de fila */
.fila-item{display:inline-block;background:var(--parch3);border:1px solid var(--frame);border-radius:4px;padding:1px 7px;margin:2px 2px 0 0;font-size:.85em}
.fila-item.eu{background:var(--blue);color:#fff;border-color:#16305c}
.timer{font-variant-numeric:tabular-nums}

/* ===== Banner do usuario (cabecalho do dashboard) ===== */
.user-banner{
  display:flex;align-items:center;gap:16px;flex-wrap:wrap;
  background:var(--paper), linear-gradient(#f5edd3,#e9dcb6);
  border:2px solid var(--frame);border-radius:8px;padding:12px 18px;margin-bottom:18px;
  box-shadow:0 0 0 1px var(--gold) inset, 0 4px 12px rgba(0,0,0,.4);
}
.user-banner.warn{background:var(--paper), linear-gradient(#f6e6c0,#ecd29a)}
.ub-id{display:flex;align-items:center;gap:12px}
.avatar{
  width:46px;height:46px;border-radius:50%;flex:0 0 auto;
  background:linear-gradient(#e9c45f,#b8860b);color:#2a1f06;
  display:flex;align-items:center;justify-content:center;
  font:700 1.4rem 'Cinzel',serif;
  box-shadow:0 0 0 2px #fff7df inset, 0 2px 5px rgba(0,0,0,.35);
}
.ub-name{font-family:'Cinzel',serif;font-weight:700;font-size:1.15rem;color:#3a2c10;line-height:1.15}
.ub-role .tag{margin-top:3px;display:inline-block}
.ub-divider{align-self:stretch;width:1px;background:var(--frame);opacity:.35;margin:2px 0}
.ub-chars{display:flex;align-items:center;gap:8px;flex-wrap:wrap;flex:1 1 auto}
.ub-label{font-size:.72rem;text-transform:uppercase;letter-spacing:1px;color:var(--ink-muted);font-weight:700;font-family:'Cinzel',serif}
.ub-msg{color:#9c6a14;font-weight:600}
.gb-pill{display:inline-flex;align-items:center;gap:7px;background:#fcf7e9;border:1px solid var(--frame);border-radius:999px;padding:4px 12px;box-shadow:0 1px 0 #fff8e4 inset}
.gb-pill .dot{width:9px;height:9px;border-radius:50%;flex:0 0 auto}
.gb-pill.ok .dot{background:#2f9d4f;box-shadow:0 0 5px rgba(63,191,106,.8)}
.gb-pill.no{border-color:#c08a6a}
.gb-pill.no .dot{background:#c43b22;box-shadow:0 0 5px rgba(196,59,34,.6)}
.gb-pill b{font-weight:700;color:#3a2c10}
.gb-date{font-size:.76rem;color:var(--ink-muted)}
.ub-summary{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  margin-left:auto;background:#fcf7e9;border:1px solid var(--frame);border-radius:8px;
  padding:5px 16px;min-width:66px;box-shadow:0 1px 0 #fff8e4 inset;
}
.ub-count{font:700 1.25rem 'Cinzel',serif;color:#2f7d3f;line-height:1}
.ub-summary.partial .ub-count{color:#b06a14}
.ub-count-label{font-size:.66rem;text-transform:uppercase;letter-spacing:1px;color:var(--ink-muted)}
@media(max-width:640px){
  .user-banner{gap:12px}
  .ub-divider{display:none}
  .ub-summary{margin-left:0}
}

/* ===== Selos de guild bank por character ===== */
.tag.gb-ok{background:#dff0d8;color:#2f7d3f;border-color:#2f7d3f}
.tag.gb-no{background:#f6e0c0;color:#9c2a14;border-color:#9c2a14}
.char-gb{display:flex;align-items:center;gap:6px;flex-wrap:wrap;padding:4px 0;border-bottom:1px solid var(--parch3)}
.char-gb:last-child{border-bottom:none}
.char-gb .gbname{font-weight:700;min-width:90px}

/* ===== Guild Bank (tela dedicada) ===== */
.gb-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:18px}
.gb-stat{background:var(--paper), linear-gradient(#f5edd3,#e9dcb6);border:2px solid var(--frame);border-top:4px solid var(--frame);border-radius:8px;padding:12px 14px;text-align:center;box-shadow:0 0 0 1px var(--gold) inset,0 3px 8px rgba(0,0,0,.35)}
.gb-stat.ok{border-top-color:#2f9d4f}
.gb-stat.warn{border-top-color:#d9a93b}
.gb-stat.danger{border-top-color:#c43b22}
.gb-stat-num{display:block;font:700 1.7rem 'Cinzel',serif;color:#4a3414;line-height:1}
.gb-stat.ok .gb-stat-num{color:#2f7d3f}
.gb-stat.warn .gb-stat-num{color:#b06a14}
.gb-stat.danger .gb-stat-num{color:#a8341f}
.gb-stat-lbl{font-size:.7rem;text-transform:uppercase;letter-spacing:.5px;color:var(--ink-muted);font-weight:700;font-family:'Cinzel',serif}
.gb-toolbar{display:flex;justify-content:space-between;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:10px}
.gb-toolbar #gb-search{width:220px;max-width:100%}
.gb-badge{display:inline-block;border-radius:999px;padding:2px 10px;font-size:.76rem;font-weight:700}
.gb-badge.ok{background:#dff0d8;color:#2f7d3f;border:1px solid #2f7d3f}
.gb-badge.warn{background:#f6ead0;color:#b06a14;border:1px solid #b06a14}
.gb-badge.danger{background:#f6e0c0;color:#a8341f;border:1px solid #a8341f}
@media(max-width:640px){.gb-stats{grid-template-columns:repeat(2,1fr)}}

/* ===== Lista de ocupados (dentro de card) ===== */
.ocupados-list{border:1px solid var(--frame);border-radius:5px;overflow:hidden;background:#fcf7e9}
.ocupados-list .rsp-row:last-child{border-bottom:none}

/* ===== Secoes recolhiveis (Painel) ===== */
.card.collapsible > h2{cursor:pointer;user-select:none}
.card.collapsible > h2::after{content:'▾';float:right;opacity:.85;font-size:.85em}
.card.collapsed > h2::after{content:'▸'}
.card.collapsed{padding:0}
.card.collapsed > h2{margin:0;border-radius:4px}
.card.collapsed > :not(h2){display:none}

/* ===== Meus serviceiros (Minha conta) ===== */
.serv-row{border:1px solid var(--frame);border-radius:6px;padding:10px 12px;margin-bottom:8px;background:linear-gradient(#fdf8ea,#f1e7cb)}
.serv-head{display:flex;align-items:center;gap:8px;margin-bottom:8px}
.serv-head form{margin-left:auto}
.serv-chars{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.char-toggle.on{background:linear-gradient(#43b56a,#2c7a40);color:#fff;border-color:#1f5a2d}

/* ===== Painel: avatares, badges de cargo, chips de conta ===== */
.tavatar{display:inline-flex;width:30px;height:30px;border-radius:50%;background:linear-gradient(#e9c45f,#b8860b);color:#2a1f06;align-items:center;justify-content:center;font:700 .9rem 'Cinzel',serif;box-shadow:0 0 0 1px #fff7df inset;vertical-align:middle;margin-right:8px;flex:0 0 auto}
.tavatar.sm{width:22px;height:22px;font-size:.72rem;margin-right:4px}
.rbadge{display:inline-flex;align-items:center;gap:4px;border-radius:5px;padding:2px 9px;font:700 .7rem 'Cinzel',serif;letter-spacing:.5px;border:1px solid;vertical-align:middle}
.rbadge .skull{margin-top:-1px;flex:0 0 auto}
.rbadge.adm{background:linear-gradient(#f0d27a,#d9b14a);color:#4a3408;border-color:#a9842f}
.rbadge.lider{background:#e8e3d6;color:#161616;border-color:#4a4a4a}        /* caveira preta */
.rbadge.player{background:#f7e2dd;color:#b0271a;border-color:#c0392b}       /* caveira vermelha */
.rbadge.serviceiro{background:#dff0df;color:#1f7a3d;border-color:#2f8f4a}   /* caveira verde */
.acc-chip{display:inline-flex;align-items:center;gap:5px;background:#fcf7e9;border:1px solid var(--frame);border-radius:999px;padding:3px 9px 3px 3px;margin:0 5px 5px 0;font-size:.86em}
.acc-chip.r-adm{border-color:#b8860b;box-shadow:inset 0 0 0 1px #b8860b}
.acc-chip.r-lider{border-color:#3a3a3a;box-shadow:inset 0 0 0 1px #3a3a3a}
.acc-chip.r-player{border-color:#2e5e9e;box-shadow:inset 0 0 0 1px #2e5e9e}
.acc-chip.r-serviceiro{border-color:#4e7d2e;box-shadow:inset 0 0 0 1px #4e7d2e}
/* bolinha (avatar) colorida por cargo dentro do chip */
.acc-chip.r-adm .tavatar{background:#1a1a1a;color:#e8b923;box-shadow:0 0 0 1px #e8b923 inset}
.acc-chip.r-lider .tavatar{background:#1a1a1a;color:#f0e6d2;box-shadow:0 0 0 1px #555 inset}
.acc-chip.r-player .tavatar{background:#2e5e9e;color:#eaf2ff;box-shadow:0 0 0 1px #6f9ed6 inset}
.acc-chip.r-serviceiro .tavatar{background:#4e7d2e;color:#eef7e4;box-shadow:0 0 0 1px #86b35e inset}
.link-form{display:none}
.link-form.open{display:inline-flex}
.link-toggle{border-radius:999px;padding:3px 10px;font-weight:700}
.char-sword{color:var(--gold);text-shadow:0 0 5px rgba(230,199,104,.45)}

/* ===== Characters (chips) ===== */
.chars-list{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:6px}
.char-chip{display:inline-flex;align-items:center;gap:4px;background:var(--parch3);border:1px solid var(--frame);border-radius:12px;padding:2px 6px 2px 10px;font-size:.85em;font-weight:600}
.char-x{background:none;border:none;color:#9c2a14;font-size:1.1em;line-height:1;cursor:pointer;padding:0 2px;font-weight:700}
.char-x:hover{color:#d9534f}
.char-add input{width:160px}
.meu-char{font-size:.88em;color:#6b4f1e;margin-bottom:6px}
.claim-as-wrap{display:flex;align-items:center;gap:6px;margin:0;font-size:.88em;font-weight:600;color:#4a3a18}
.claim-as-wrap select{width:auto;padding:6px 8px}

/* ===== Admin: colunas ===== */
.cols{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}
.box{background:var(--paper), linear-gradient(#fdf8ea,#f1e7cb);border:1px solid var(--frame);border-radius:5px;padding:14px}
.box h3{color:#4a3414}

@media(max-width:640px){.cols{grid-template-columns:1fr}}
@media(max-width:600px){
  .rsp-row{grid-template-columns:1fr auto;grid-template-areas:'name action' 'status action';row-gap:2px}
  .rsp-name{grid-area:name}.rsp-status{grid-area:status}.rsp-action{grid-area:action}
  .filtros{width:100%}.filtros #f-search{width:100%}
}
