/* ═══════════════════════════════════════════════════════════════
   RISO SEM FRONTEIRAS — Portal de Voluntários
   Paleta arco-íris da marca (logo do palhaço)
   ═══════════════════════════════════════════════════════════════ */
:root{
  --vermelho:#E63329; --laranja:#F7941E; --amarelo:#FFC60B; --verde:#39B54A;
  --ciano:#00AEEF; --azul:#2E3192; --roxo:#92278F; --rosa:#EC008C;
  --preto:#16131A; --tinta:#2b2733; --cinza:#8a8597; --linha:#efeaf2;
  --bg:#FBF7FF; --branco:#fff; --creme:#FFF9F0;
  --rad:22px; --rad-sm:14px; --sombra:0 14px 38px rgba(70,30,90,.10);
  --sombra-sm:0 6px 18px rgba(70,30,90,.08);
  /* gradiente principal — tema circo/palhaço (quente, diagonal — sem listras arco-íris) */
  --grad-arco:linear-gradient(135deg,#EC008C 0%,#F7531E 55%,#FFB400 100%);
  --grad-festa:linear-gradient(135deg,#00AEEF 0%,#92278F 100%);
  --ff:'Nunito',system-ui,sans-serif; --fh:'Baloo 2','Nunito',sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--ff);color:var(--tinta);-webkit-font-smoothing:antialiased;
  background-color:var(--bg);
  background-image:radial-gradient(rgba(236,0,140,.05) 2px,transparent 2px),
                   radial-gradient(rgba(0,174,239,.045) 2px,transparent 2px);
  background-size:34px 34px;background-position:0 0,17px 17px}

/* ───────── RASTRO DIVERTIDO DO CURSOR ───────── */
.trail{position:fixed;z-index:9998;pointer-events:none;transform:translate(-50%,-50%);
  line-height:1;will-change:transform,opacity;animation:trailUp .9s ease-out forwards}
.trail-dot{border-radius:50%;box-shadow:0 0 8px rgba(0,0,0,.12)}
@keyframes trailUp{
  0%{opacity:0;transform:translate(-50%,-50%) scale(.3) rotate(0deg)}
  18%{opacity:1;transform:translate(calc(-50% + var(--dx)*.3),calc(-50% + var(--dy)*.3)) scale(1.15) rotate(calc(var(--rot)*.3))}
  100%{opacity:0;transform:translate(calc(-50% + var(--dx)),calc(-50% + var(--dy))) scale(.5) rotate(var(--rot))}
}
@media(hover:none){.trail{display:none}}

/* ───────── MASCOTE RISOLINO (ícones) ───────── */
.ico-riso{height:46px;width:auto;display:inline-block;vertical-align:middle;filter:drop-shadow(0 3px 5px rgba(0,0,0,.28))}
.ico-riso-big{height:92px;width:auto;display:inline-block;filter:drop-shadow(0 5px 9px rgba(0,0,0,.2))}
.ico-riso-sm{height:1.5em;width:auto;vertical-align:-0.42em}
.nav-riso{height:26px;width:auto;display:block;margin:0 auto}
.stat .ico .ico-riso{height:48px;margin-top:-4px}
.vol-hero .ico-riso-sm{height:1.8rem;vertical-align:-0.5rem}
.modal-tit .ico-riso-sm{height:1.4em;vertical-align:-0.35em}
.hidden{display:none!important}
button{font-family:var(--ff);cursor:pointer;border:none;background:none}
input,select,textarea{font-family:var(--ff)}
a{cursor:pointer;text-decoration:none;color:inherit}
::selection{background:var(--rosa);color:#fff}

/* ───────── LOGIN ───────── */
.login-wrap{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;
  position:relative;overflow:hidden;padding:20px;
  background:radial-gradient(circle at 20% 20%,#fff,#FBEFFB 45%,#EAF6FF 100%)}
.login-hero{position:relative;z-index:2;width:min(72vw,240px);height:auto;display:block;margin-bottom:-8px;
  filter:drop-shadow(0 14px 24px rgba(120,40,120,.22));animation:bob 4s ease-in-out infinite}
@keyframes bob{0%,100%{transform:translateY(0) rotate(-1deg)}50%{transform:translateY(-12px) rotate(1deg)}}
.login-bg span{position:absolute;border-radius:50%;filter:blur(6px);opacity:.5;animation:flut 9s ease-in-out infinite}
.login-bg span:nth-child(1){width:140px;height:140px;background:var(--amarelo);top:8%;left:10%}
.login-bg span:nth-child(2){width:90px;height:90px;background:var(--rosa);top:70%;left:14%;animation-delay:1s}
.login-bg span:nth-child(3){width:120px;height:120px;background:var(--ciano);top:18%;right:12%;animation-delay:2s}
.login-bg span:nth-child(4){width:80px;height:80px;background:var(--verde);bottom:12%;right:18%;animation-delay:1.5s}
.login-bg span:nth-child(5){width:60px;height:60px;background:var(--laranja);top:46%;left:6%;animation-delay:.5s}
.login-bg span:nth-child(6){width:70px;height:70px;background:var(--roxo);bottom:8%;left:42%;animation-delay:2.5s}
@keyframes flut{0%,100%{transform:translateY(0) scale(1)}50%{transform:translateY(-26px) scale(1.08)}}
.login-card{position:relative;z-index:2;width:min(92vw,400px);background:rgba(255,255,255,.92);
  backdrop-filter:blur(8px);border-radius:30px;padding:38px 34px 34px;box-shadow:0 30px 70px rgba(120,40,120,.22);
  border:3px solid #fff;text-align:center;animation:pop .5s cubic-bezier(.2,1.4,.4,1)}
@keyframes pop{from{transform:scale(.9) translateY(20px);opacity:0}to{transform:none;opacity:1}}
.login-logo{width:120px;height:120px;object-fit:contain;margin-bottom:6px;filter:drop-shadow(0 8px 14px rgba(0,0,0,.15))}
.login-title{font-family:var(--fh);font-size:1.7rem;font-weight:800;
  background:var(--grad-arco);-webkit-background-clip:text;background-clip:text;color:transparent}
.login-sub{color:var(--cinza);font-weight:600;font-size:.9rem;margin:2px 0 22px}
.campo{display:block;text-align:left;margin-bottom:14px}
.campo>span{display:block;font-weight:800;font-size:.78rem;color:var(--roxo);margin-bottom:5px;text-transform:uppercase;letter-spacing:.04em}
.campo input,.campo select,.campo textarea{width:100%;padding:13px 15px;border:2.5px solid var(--linha);
  border-radius:var(--rad-sm);font-size:1rem;font-weight:600;background:#fff;transition:.2s}
.campo input:focus,.campo select:focus,.campo textarea:focus{outline:none;border-color:var(--rosa);box-shadow:0 0 0 4px rgba(236,0,140,.12)}
.btn-entrar{width:100%;padding:14px;border-radius:var(--rad-sm);color:#fff;font-weight:800;font-size:1.05rem;
  background:var(--grad-arco);background-size:200% auto;box-shadow:0 10px 24px rgba(236,0,140,.32);transition:.3s}
.btn-entrar:hover{background-position:right center;transform:translateY(-2px)}
.login-erro{color:var(--vermelho);font-weight:700;font-size:.86rem;min-height:18px;margin-bottom:8px}

/* ───────── APP SHELL ───────── */
.app{display:grid;grid-template-columns:264px 1fr;min-height:100vh}
.sidebar{background:linear-gradient(180deg,#1d1726,#241a30);color:#fff;display:flex;flex-direction:column;
  padding:22px 16px;position:sticky;top:0;height:100vh}
.brand{display:flex;flex-direction:column;align-items:center;gap:8px;padding:8px 6px 22px;
  border-bottom:1px solid rgba(255,255,255,.12);margin-bottom:22px;text-align:center}
.brand img{width:96px;height:96px;object-fit:contain;filter:drop-shadow(0 6px 12px rgba(0,0,0,.35))}
.brand-nome{font-family:var(--fh);font-size:1.5rem;font-weight:800;line-height:1.05;
  background:var(--grad-arco);-webkit-background-clip:text;background-clip:text;color:transparent}
.menu{display:flex;flex-direction:column;gap:5px;flex:1}
.menu a{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:14px;color:#cfc6dd;
  font-weight:700;font-size:.96rem;transition:.18s;position:relative}
.menu a i{font-style:normal;font-size:1.2rem;width:24px;text-align:center}
.menu a:hover{background:rgba(255,255,255,.07);color:#fff}
.menu a.ativo{background:var(--grad-arco);color:#fff;box-shadow:0 8px 20px rgba(236,0,140,.35)}
.user-box{display:flex;align-items:center;gap:10px;background:rgba(255,255,255,.06);padding:10px;border-radius:16px}
.avatar{width:40px;height:40px;border-radius:12px;display:grid;place-items:center;font-weight:800;color:#fff;
  background:var(--grad-arco);font-size:1.1rem;flex-shrink:0}
.user-info{flex:1;min-width:0}
.user-info strong{display:block;font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.user-info small{color:#b9aecb;font-size:.72rem;font-weight:700;text-transform:uppercase}
.user-box button{color:#fff;font-size:1.3rem;opacity:.7}.user-box button:hover{opacity:1}

.conteudo{display:flex;flex-direction:column;min-width:0}
.topo{display:flex;align-items:center;gap:14px;padding:20px 30px;position:sticky;top:0;z-index:30;
  background:rgba(251,247,255,.85);backdrop-filter:blur(10px);border-bottom:1px solid var(--linha)}
.topo h2{font-family:var(--fh);font-size:1.5rem;font-weight:800;color:var(--preto);flex:1}
.menu-toggle{display:none;font-size:1.5rem;color:var(--roxo)}
.topo-acoes{display:flex;gap:10px;flex-wrap:wrap}
.view{padding:26px 30px 60px;animation:fade .35s}
@keyframes fade{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}

/* ───────── BOTÕES ───────── */
.btn{padding:11px 20px;border-radius:12px;font-weight:800;font-size:.92rem;display:inline-flex;align-items:center;
  gap:7px;transition:.2s;box-shadow:var(--sombra-sm)}
.btn:hover{transform:translateY(-2px)}
.btn-rosa{background:var(--rosa);color:#fff}.btn-roxo{background:var(--roxo);color:#fff}
.btn-azul{background:var(--azul);color:#fff}.btn-verde{background:var(--verde);color:#fff}
.btn-amarelo{background:var(--amarelo);color:#5a4500}.btn-arco{background:var(--grad-arco);color:#fff}
.btn-ghost{background:#fff;color:var(--roxo);border:2px solid var(--linha);box-shadow:none}
.btn-ghost:hover{border-color:var(--rosa)}
.btn-sm{padding:7px 13px;font-size:.82rem;border-radius:10px}
.btn-icon{width:36px;height:36px;border-radius:11px;display:grid;place-items:center;font-size:1rem;padding:0;background:#fff;box-shadow:var(--sombra-sm)}
.btn-icon:hover{transform:translateY(-2px)}

/* ───────── GRID DE CARDS (bolhas variadas) ───────── */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(148px,166px));justify-content:start;gap:14px;margin-bottom:24px}
.stat{position:relative;border-radius:24px;padding:18px;color:#fff;overflow:hidden;aspect-ratio:1/1;
  display:flex;flex-direction:column;justify-content:space-between;box-shadow:var(--sombra);transition:.25s}
.stat:hover{transform:translateY(-5px) rotate(-1deg)}
.stat::after{content:'';position:absolute;width:130px;height:130px;border-radius:50%;
  background:rgba(255,255,255,.18);top:-44px;right:-30px}
.stat::before{content:'';position:absolute;width:70px;height:70px;border-radius:50%;
  background:rgba(255,255,255,.12);bottom:-26px;left:-10px}
.stat .ico{font-size:1.7rem;position:relative;z-index:1}
.stat .num{font-family:var(--fh);font-size:2.1rem;font-weight:800;line-height:1;position:relative;z-index:1}
.stat .lbl{font-weight:700;opacity:.95;position:relative;z-index:1;font-size:.92rem}
.s-rosa{background:linear-gradient(135deg,#EC008C,#ff5ab3)}
.s-roxo{background:linear-gradient(135deg,#92278F,#c44ec0)}
.s-azul{background:linear-gradient(135deg,#2E3192,#5a5edb)}
.s-ciano{background:linear-gradient(135deg,#00AEEF,#56d0ff)}
.s-verde{background:linear-gradient(135deg,#39B54A,#74da82)}
.s-laranja{background:linear-gradient(135deg,#F7941E,#ffb85a)}
.s-amarelo{background:linear-gradient(135deg,#FFC60B,#ffe06a);color:#6a5100}
.s-vermelho{background:linear-gradient(135deg,#E63329,#ff6a62)}

/* painel branco */
.painel{background:#fff;border-radius:var(--rad);padding:22px;box-shadow:var(--sombra-sm);border:1px solid var(--linha)}
.painel-tit{font-family:var(--fh);font-size:1.15rem;font-weight:800;color:var(--preto);margin-bottom:4px;display:flex;align-items:center;gap:8px}
.painel-sub{color:var(--cinza);font-size:.84rem;font-weight:600;margin-bottom:16px}
.cols{display:grid;gap:18px}
.cols-2{grid-template-columns:1.4fr 1fr}
.cols-3{grid-template-columns:repeat(3,1fr)}
@media(max-width:1100px){.cols-2,.cols-3{grid-template-columns:1fr}}

/* ───────── TABELAS ───────── */
.tabela-wrap{background:#fff;border-radius:var(--rad);box-shadow:var(--sombra-sm);overflow:hidden;border:1px solid var(--linha)}
table{width:100%;border-collapse:collapse}
thead th{background:#faf6fe;text-align:left;padding:13px 16px;font-size:.74rem;font-weight:800;color:var(--roxo);
  text-transform:uppercase;letter-spacing:.04em;border-bottom:2px solid var(--linha);white-space:nowrap}
tbody td{padding:12px 16px;border-bottom:1px solid var(--linha);font-weight:600;font-size:.9rem;vertical-align:middle}
tbody tr:hover{background:#fdf4fb}
tbody tr:last-child td{border-bottom:none}
.id-badge{display:inline-grid;place-items:center;min-width:34px;height:28px;padding:0 8px;border-radius:9px;
  background:var(--grad-arco);color:#fff;font-weight:800;font-size:.82rem}
.tag{display:inline-flex;align-items:center;gap:5px;padding:4px 11px;border-radius:999px;font-size:.74rem;font-weight:800;text-transform:uppercase;letter-spacing:.02em}
.tag-verde{background:#e3f7e7;color:#1f8f33}.tag-cinza{background:#eee;color:#888}
.tag-rosa{background:#ffe3f3;color:#c2007a}.tag-azul{background:#e3ecff;color:#2730a8}
.tag-amarelo{background:#fff3cf;color:#9a7400}.tag-kids{background:linear-gradient(90deg,#FFC60B,#EC008C);color:#fff}

/* ───────── BARRA DE FERRAMENTAS ───────── */
.toolbar{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-bottom:18px}
.busca{flex:1;min-width:220px;position:relative}
.busca input{width:100%;padding:12px 16px 12px 42px;border:2.5px solid var(--linha);border-radius:14px;font-weight:600;font-size:.95rem;background:#fff}
.busca input:focus{outline:none;border-color:var(--rosa)}
.busca::before{content:'🔍';position:absolute;left:14px;top:50%;transform:translateY(-50%);opacity:.5}
.filtro{padding:11px 14px;border:2.5px solid var(--linha);border-radius:14px;font-weight:700;background:#fff;color:var(--tinta)}
.filtro:focus{outline:none;border-color:var(--rosa)}

/* listinha de barras (ranking) */
.bars{display:flex;flex-direction:column;gap:12px}
.bar-row{display:grid;grid-template-columns:1fr auto;gap:6px}
.bar-top{display:flex;justify-content:space-between;font-weight:700;font-size:.86rem}
.bar-track{grid-column:1/-1;height:11px;background:#f0eaf5;border-radius:99px;overflow:hidden}
.bar-fill{height:100%;border-radius:99px;background:var(--grad-arco);transition:width .8s cubic-bezier(.2,1,.3,1)}

/* lista de itens (respostas recentes / aniversariantes) */
.lista{display:flex;flex-direction:column;gap:10px}
.item{display:flex;align-items:center;gap:12px;padding:11px 14px;border-radius:14px;background:#faf7fe;transition:.15s}
.item:hover{background:#f3ebfb;transform:translateX(3px)}
.item .ava{width:38px;height:38px;border-radius:11px;display:grid;place-items:center;font-weight:800;color:#fff;flex-shrink:0}
.item .txt{flex:1;min-width:0}
.item .txt b{display:block;font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.item .txt small{color:var(--cinza);font-weight:600;font-size:.78rem}
.item .quando{font-size:.74rem;color:var(--cinza);font-weight:700;white-space:nowrap}

/* ───────── CARDS DE FORMULÁRIO ───────── */
.forms-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,262px));justify-content:start;gap:18px}
.fcard{position:relative;border-radius:var(--rad);background:#fff;box-shadow:var(--sombra-sm);overflow:hidden;
  border:1px solid var(--linha);transition:.25s;display:flex;flex-direction:column}
.fcard:hover{transform:translateY(-5px);box-shadow:var(--sombra)}
.fcard-top{padding:20px;color:#fff;position:relative;overflow:hidden}
.fcard-top::after{content:'';position:absolute;width:120px;height:120px;border-radius:50%;background:rgba(255,255,255,.15);top:-40px;right:-30px}
.fcard-ico{font-size:2rem;position:relative;z-index:1}
.fcard-tit{font-family:var(--fh);font-size:1.2rem;font-weight:800;margin-top:6px;position:relative;z-index:1}
.fcard-body{padding:16px 20px;flex:1;display:flex;flex-direction:column;gap:10px}
.fcard-desc{color:var(--cinza);font-size:.86rem;font-weight:600;flex:1}
.fcard-meta{display:flex;gap:14px;font-size:.78rem;font-weight:700;color:var(--tinta)}
.fcard-meta b{color:var(--roxo)}
.fcard-acoes{display:flex;gap:6px;padding:0 16px 16px;flex-wrap:wrap}

/* status pill */
.status-dot{display:inline-flex;align-items:center;gap:6px;font-weight:800;font-size:.74rem;text-transform:uppercase}
.status-dot::before{content:'';width:9px;height:9px;border-radius:50%}
.st-ativo::before{background:var(--verde);box-shadow:0 0 0 4px #39b54a33}
.st-rascunho::before{background:var(--amarelo);box-shadow:0 0 0 4px #ffc60b33}
.st-encerrado::before{background:var(--cinza);box-shadow:0 0 0 4px #8a859733}

/* ───────── CONSTRUTOR DE FORMULÁRIO ───────── */
.builder{display:grid;grid-template-columns:1fr 320px;gap:20px;align-items:start}
@media(max-width:1000px){.builder{grid-template-columns:1fr}}
.campo-item{background:#fff;border:2px solid var(--linha);border-radius:16px;padding:14px 16px;margin-bottom:12px;transition:.2s}
.campo-item:hover{border-color:#e0d4ec}
.campo-head{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.campo-tipo-badge{font-size:.7rem;font-weight:800;padding:3px 9px;border-radius:8px;background:#f3ebfb;color:var(--roxo);text-transform:uppercase}
.add-campo-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:9px}
.add-campo-grid button{padding:13px 10px;border-radius:13px;background:#faf7fe;border:2px solid var(--linha);
  font-weight:800;font-size:.84rem;color:var(--tinta);display:flex;flex-direction:column;gap:4px;align-items:center;transition:.18s}
.add-campo-grid button:hover{border-color:var(--rosa);transform:translateY(-2px);color:var(--rosa)}
.add-campo-grid button span{font-size:1.4rem}

/* ───────── EDITOR DE OPÇÕES (estilo Google Forms) ───────── */
.opcoes-editor{display:flex;flex-direction:column;gap:8px;margin-top:4px}
.opcao-row{display:flex;align-items:center;gap:9px}
.opcao-bullet{font-size:1.1rem;color:var(--cinza);width:18px;text-align:center;flex-shrink:0}
.opcao-input{flex:1}
.opcao-row .btn-icon{box-shadow:none;background:transparent;color:var(--cinza)}
.opcao-row .btn-icon:hover{color:var(--vermelho);transform:none}
.add-opcao{align-self:flex-start;color:var(--roxo);font-weight:800;font-size:.86rem;padding:8px 4px;display:flex;align-items:center;gap:6px}
.add-opcao:hover{color:var(--rosa)}
.secao-item{border-left:5px solid var(--amarelo);background:#fffdf5}

/* ───────── BARRA DE PROGRESSO (resposta) ───────── */
.prog-wrap{display:flex;align-items:center;gap:10px;margin:6px 0 14px}
.prog-bar{flex:1;height:12px;background:#f0eaf5;border-radius:99px;overflow:hidden}
.prog-fill{height:100%;border-radius:99px;background:var(--grad-arco);width:0;transition:width .35s cubic-bezier(.2,1,.3,1)}
.prog-label{font-weight:800;color:var(--roxo);font-size:.85rem;min-width:42px;text-align:right}
.resp-secao-tit{font-family:var(--fh);font-size:1.1rem;color:var(--roxo);font-weight:800}

/* botões de ordenação inline */
.sort-btns{display:inline-flex;gap:4px;background:#faf6fe;padding:4px;border-radius:11px}
.sort-btns button{padding:6px 12px;border-radius:8px;font-weight:800;font-size:.78rem;color:var(--cinza)}
.sort-btns button.ativo{background:var(--grad-arco);color:#fff}

/* botão voltar do mapa */
.geo-voltar{display:inline-flex;align-items:center;gap:6px;background:#f3ebfb;color:var(--roxo);font-weight:800;
  padding:8px 14px;border-radius:11px;margin-bottom:12px;font-size:.85rem}
.geo-voltar:hover{background:#e9dcf6}

/* ───────── RESPONSÁVEIS (Riso Kids) ───────── */
.resp-drop{position:absolute;top:100%;left:0;right:0;background:#fff;border:2px solid var(--linha);border-radius:12px;
  box-shadow:var(--sombra);z-index:5;max-height:220px;overflow-y:auto;margin-top:4px;display:none}
.resp-opt{padding:9px 12px;cursor:pointer;font-weight:600;font-size:.88rem}
.resp-opt:hover{background:#faf6fe;color:var(--roxo)}
.resp-chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}
.resp-chip{display:inline-flex;align-items:center;gap:6px;background:#fff;border:2px solid #ffe1b0;color:#9a7400;
  font-weight:800;font-size:.8rem;padding:4px 10px;border-radius:999px}
.resp-chip b{cursor:pointer;color:var(--vermelho);font-size:.9rem}

/* ───────── OPÇÕES (radio/checkbox como cards) ───────── */
.opt-list{display:flex;flex-direction:column;gap:8px;margin-top:4px}
.opt-row{display:flex;align-items:center;gap:12px;padding:11px 14px;border:2px solid var(--linha);border-radius:13px;font-weight:700;cursor:pointer;transition:.15s;background:#fff}
.opt-row:hover{border-color:#e0d4ec;background:#faf6fe}
.opt-row input{width:18px;height:18px;flex-shrink:0;accent-color:var(--rosa);margin:0}
.opt-row span{flex:1}
.opt-row:has(input:checked){border-color:var(--rosa);background:#fdeef8;color:var(--rosa)}

/* ───────── DISPONIBILIDADE SEMANAL ───────── */
.disp-grid{display:flex;flex-direction:column;gap:8px;margin-top:4px}
.disp-dia{border:2px solid var(--linha);border-radius:13px;padding:10px 14px;transition:.15s;background:#fff}
.disp-dia.on{border-color:var(--rosa);background:#fdeef8}
.disp-dia-head{display:flex;align-items:center;gap:10px;font-weight:700;cursor:pointer}
.disp-dia-head input{width:18px;height:18px;accent-color:var(--rosa)}
.disp-det{margin-top:10px;display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.disp-pers{display:flex;gap:6px;flex-wrap:wrap}
.disp-per{display:flex;align-items:center;gap:5px;font-weight:600;font-size:.85rem;background:#fff;border:1.5px solid var(--linha);border-radius:99px;padding:5px 11px;cursor:pointer}
.disp-per input{accent-color:var(--rosa)}
.disp-cen{min-width:200px}

/* ───────── ÁUDIO / MAPA MODO ───────── */
.audio-box{background:#fff;border:2px dashed var(--linha);border-radius:12px;padding:12px;margin-top:8px}
.mapa-modo{display:inline-flex}
.mapa-modo button{white-space:nowrap}

/* ───────── SELETOR UM-A-UM (destino) ───────── */
.sel-box{background:#faf7fe;border:2px solid var(--linha);border-radius:14px;padding:12px;margin-top:4px}
.sel-lista{max-height:240px;overflow-y:auto;display:flex;flex-direction:column;gap:2px;background:#fff;border-radius:10px;padding:6px}
.sel-item{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:8px;font-weight:600;font-size:.86rem;cursor:pointer}
.sel-item:hover{background:#faf6fe}
.sel-item input{width:16px;height:16px;flex-shrink:0}
.sel-item b{color:var(--roxo)}

/* ───────── WIZARD DE CRIAÇÃO ───────── */
.wiz-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:8px}
@media(max-width:480px){.wiz-grid{grid-template-columns:1fr}}
.wiz-card{display:flex;flex-direction:column;align-items:flex-start;gap:3px;padding:14px;border-radius:16px;
  border:2px solid var(--linha);background:#fff;text-align:left;transition:.18s}
.wiz-card:hover{border-color:var(--rosa);transform:translateY(-2px);box-shadow:var(--sombra-sm)}
.wiz-card b{font-family:var(--fh);font-size:1rem}
.wiz-card small{color:var(--cinza);font-weight:600;font-size:.78rem}
.wiz-ico{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;font-size:1.4rem;background:#faf6fe;margin-bottom:4px}

/* ───────── PRIMEIRO ACESSO / ALERTAS VOLUNTÁRIO ───────── */
.link-pa{margin-top:14px;color:var(--roxo);font-weight:800;font-size:.86rem;text-decoration:underline}
.link-pa:hover{color:var(--rosa)}
.vol-alerta{background:#fff3cf;border:2px solid #ffe08a;color:#7a5a00;font-weight:700;padding:12px 16px;
  border-radius:14px;margin-bottom:18px;font-size:.92rem}
.fcard-pend{border:2px solid #ffd966;box-shadow:0 8px 22px rgba(255,180,0,.18)}
.vol-prazo{font-weight:700;font-size:.82rem;color:var(--vermelho);margin:2px 0}

/* ───────── MODAL ───────── */
.modal{position:fixed;inset:0;background:rgba(40,15,50,.55);backdrop-filter:blur(4px);z-index:100;
  display:grid;place-items:center;padding:20px;animation:fade .2s}
.modal-box{background:#fff;border-radius:26px;width:min(94vw,560px);max-height:90vh;overflow-y:auto;
  padding:28px;box-shadow:0 40px 80px rgba(60,20,70,.4);animation:pop .35s cubic-bezier(.2,1.4,.4,1)}
.modal-tit{font-family:var(--fh);font-size:1.4rem;font-weight:800;margin-bottom:4px;color:var(--preto)}
.modal-acoes{display:flex;gap:10px;justify-content:flex-end;margin-top:22px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media(max-width:520px){.grid2{grid-template-columns:1fr}}

/* toast */
.toast{position:fixed;bottom:26px;left:50%;transform:translateX(-50%) translateY(120px);
  background:var(--preto);color:#fff;padding:14px 24px;border-radius:14px;font-weight:700;z-index:200;
  box-shadow:0 14px 30px rgba(0,0,0,.3);transition:.4s cubic-bezier(.2,1.4,.4,1);max-width:90vw}
.toast.show{transform:translateX(-50%) translateY(0)}
.toast.ok{background:linear-gradient(90deg,#39B54A,#2a9c3a)}
.toast.err{background:linear-gradient(90deg,#E63329,#c0271e)}

/* vazio */
.vazio{text-align:center;padding:60px 20px;color:var(--cinza)}
.vazio .emoji{font-size:3.5rem;display:block;margin-bottom:10px;filter:grayscale(.2)}
.vazio b{display:block;font-size:1.1rem;color:var(--tinta);margin-bottom:4px;font-family:var(--fh)}

/* ───────── PORTAL DO VOLUNTÁRIO ───────── */
.app-vol{min-height:100vh;background:radial-gradient(circle at 80% 0%,#FBEFFB,#EAF6FF 60%,#FBF7FF)}
.vol-topo{display:flex;align-items:center;gap:13px;padding:16px 22px;background:#fff;box-shadow:var(--sombra-sm);position:sticky;top:0;z-index:20}
.vol-topo img{width:46px;height:46px;object-fit:contain}
.vol-topo-txt{flex:1}
.vol-topo-txt strong{display:block;font-family:var(--fh);font-size:1.1rem;
  background:var(--grad-arco);-webkit-background-clip:text;background-clip:text;color:transparent}
.vol-topo-txt small{color:var(--cinza);font-weight:700}
#btn-sair-vol,#btn-vol-painel{padding:9px 16px;border-radius:12px;background:#f3ebfb;color:var(--roxo);font-weight:800}
#btn-vol-painel{background:var(--grad-arco);color:#fff;margin-right:8px}
.vol-view{max-width:760px;margin:0 auto;padding:26px 18px 60px}
.vol-hero{text-align:center;margin-bottom:26px}
.vol-hero h1{font-family:var(--fh);font-size:1.8rem;color:var(--preto)}
.vol-hero p{color:var(--cinza);font-weight:600}

/* ───────── VOLUNTÁRIOS: MESTRE-DETALHE ───────── */
.vol-layout{display:grid;grid-template-columns:340px 1fr;gap:18px;align-items:start}
@media(max-width:900px){.vol-layout{grid-template-columns:1fr}}
.vol-list-box{background:#fff;border-radius:var(--rad);padding:14px;box-shadow:var(--sombra-sm);border:1px solid var(--linha);position:sticky;top:90px}
.vol-filtros{display:grid;grid-template-columns:1fr 1fr 1fr;gap:6px;margin-bottom:10px}
.vol-filtros .filtro{padding:8px 6px;font-size:.78rem;border-radius:10px}
.vol-list-rows{display:flex;flex-direction:column;gap:4px;max-height:62vh;overflow-y:auto;padding-right:4px}
.vol-row{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:12px;cursor:pointer;transition:.14s;border:2px solid transparent}
.vol-row:hover{background:#faf6fe}
.vol-row.sel{background:#fdeef8;border-color:var(--rosa)}
.vol-row .id-badge{min-width:30px;height:25px;font-size:.76rem}
.vr-txt{flex:1;min-width:0}
.vr-txt b{display:block;font-size:.88rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.vr-txt small{color:var(--cinza);font-weight:600;font-size:.74rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}
.vr-kids{font-size:.9rem}
.dot{width:11px;height:11px;border-radius:50%;flex-shrink:0}
.dot.on{background:var(--verde);box-shadow:0 0 0 3px #39b54a33}
.dot.off{background:#c7c2d2;box-shadow:0 0 0 3px #c7c2d233}
.vol-count{margin-top:10px;color:var(--cinza);font-weight:700;font-size:.8rem;text-align:center}
.vol-detail{background:#fff;border-radius:var(--rad);padding:24px;box-shadow:var(--sombra-sm);border:1px solid var(--linha);min-height:400px}
.dt-head{display:flex;gap:16px;align-items:flex-start;padding-bottom:18px;border-bottom:2px solid var(--linha);margin-bottom:18px}
.dt-avatar{width:64px;height:64px;border-radius:18px;display:grid;place-items:center;font-weight:800;color:#fff;font-size:1.8rem;background:var(--grad-arco);flex-shrink:0}
.dt-nome{font-family:var(--fh);font-size:1.4rem;font-weight:800;color:var(--preto);line-height:1.1}
.dt-palhaco{color:var(--roxo);font-weight:700;font-size:.95rem}
.dt-acoes{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:20px}
.dt-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media(max-width:560px){.dt-grid{grid-template-columns:1fr}}
.dt-row{display:flex;gap:10px;align-items:center;background:#faf7fe;border-radius:13px;padding:10px 13px}
.dt-ico{font-size:1.2rem;flex-shrink:0}
.dt-cont{min-width:0}
.dt-cont small{display:block;color:var(--cinza);font-weight:800;font-size:.68rem;text-transform:uppercase;letter-spacing:.03em}
.dt-cont b{font-size:.92rem;word-break:break-word}
.dt-obs{margin-top:14px;background:#fff9f0;border-left:4px solid var(--amarelo);border-radius:10px;padding:12px 14px;font-weight:600;font-size:.9rem}
.dt-hist{margin-top:20px;padding-top:12px;border-top:2px solid var(--linha)}
.dt-hist>summary{cursor:pointer;list-style:none;display:flex;align-items:center;gap:8px;font-family:var(--fh);font-weight:800;font-size:1rem;color:var(--preto);padding:4px 0;user-select:none}
.dt-hist>summary::-webkit-details-marker{display:none}
.dt-hist .hist-chevron{margin-left:auto;transition:.2s;color:var(--cinza)}
.dt-hist[open] .hist-chevron{transform:rotate(180deg)}
.dt-hist .hist-list{margin-top:10px}
.hist-list{display:flex;flex-direction:column;gap:8px;margin-top:12px;max-height:300px;overflow-y:auto}
.hist-item{background:#faf7fe;border-radius:12px;padding:11px 14px}
.hist-campo{font-weight:800;color:var(--roxo);font-size:.82rem;text-transform:uppercase;letter-spacing:.02em;margin-bottom:3px}
.hist-vals{font-weight:700;font-size:.9rem}
.hist-old{color:var(--cinza);text-decoration:line-through}
.hist-seta{color:var(--rosa);font-weight:800}
.hist-new{color:var(--verde)}
.hist-meta{color:var(--cinza);font-weight:600;font-size:.74rem;margin-top:4px}

/* ───────── FIX GRÁFICOS (altura fixa) ───────── */
.chart-box{position:relative;height:240px;width:100%}
.chart-box canvas{position:absolute;inset:0}

/* ───────── SUB-ABAS ───────── */
.subtabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:22px;background:#fff;padding:7px;border-radius:18px;
  box-shadow:var(--sombra-sm);border:1px solid var(--linha)}
.subtabs button{padding:10px 18px;border-radius:12px;font-weight:800;font-size:.9rem;color:var(--cinza);transition:.2s;display:flex;align-items:center;gap:7px}
.subtabs button:hover{color:var(--roxo);background:#faf6fe}
.subtabs button.ativo{background:var(--grad-arco);color:#fff;box-shadow:0 6px 16px rgba(236,0,140,.3)}

/* ───────── MAPA DO BRASIL ───────── */
.mapa-wrap{display:grid;grid-template-columns:1.15fr .85fr;gap:20px;align-items:start}
@media(max-width:1000px){.mapa-wrap{grid-template-columns:1fr}}
.mapa-svg-box{background:#fff;border-radius:var(--rad);padding:18px;box-shadow:var(--sombra-sm);border:1px solid var(--linha);position:relative}
.mapa-svg-box svg{width:100%;height:auto;display:block}
.mapa-svg-box svg path,.mapa-svg-box svg polygon{stroke:#fff;stroke-width:.9;transition:.18s;outline:none}
.mapa-svg-box svg .uf-shape{cursor:pointer}
.mapa-svg-box svg .uf-shape:hover{filter:brightness(1.12) drop-shadow(0 3px 6px rgba(0,0,0,.25))}
.mapa-svg-box svg .sel{stroke:#16131A;stroke-width:2}
.uf-label{font-family:'Nunito',sans-serif;font-size:9px;font-weight:800;pointer-events:none;
  paint-order:stroke;stroke:rgba(255,255,255,.45);stroke-width:.4px}
.map-tip{position:fixed;z-index:300;display:none;background:#16131A;color:#fff;padding:9px 13px;border-radius:11px;
  box-shadow:0 10px 26px rgba(0,0,0,.35);font-weight:700;font-size:.8rem;pointer-events:none;line-height:1.45}
.map-tip b{display:block;font-family:'Baloo 2',sans-serif;font-size:.92rem;margin-bottom:2px;
  background:var(--grad-arco);-webkit-background-clip:text;background-clip:text;color:transparent}
.map-tip span{display:block}
.mapa-legenda{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-top:14px;font-size:.78rem;font-weight:700;color:var(--cinza)}
.mapa-legenda .escala{display:flex;height:12px;width:120px;border-radius:99px;overflow:hidden}
.mapa-legenda .escala span{flex:1}
.breadcrumb{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-bottom:14px;font-weight:800;font-size:.92rem}
.breadcrumb a{color:var(--roxo)}.breadcrumb a:hover{color:var(--rosa)}
.breadcrumb span.sep{color:var(--cinza)}
.geo-painel{background:#fff;border-radius:var(--rad);padding:20px;box-shadow:var(--sombra-sm);border:1px solid var(--linha);min-height:300px}
.geo-list{display:flex;flex-direction:column;gap:8px;max-height:560px;overflow-y:auto}
.geo-row{display:flex;align-items:center;gap:12px;padding:11px 14px;border-radius:14px;background:#faf7fe;cursor:pointer;transition:.15s}
.geo-row:hover{background:#f3ebfb;transform:translateX(3px)}
.geo-row .rank{width:30px;height:30px;border-radius:9px;display:grid;place-items:center;font-weight:800;color:#fff;flex-shrink:0;font-size:.85rem}
.geo-row .gnome{flex:1;font-weight:700;font-size:.92rem}
.geo-row .gcount{font-weight:800;color:var(--roxo);background:#f3ebfb;padding:3px 11px;border-radius:99px;font-size:.82rem}
.geo-tot{display:inline-flex;align-items:center;gap:6px;background:var(--grad-arco);color:#fff;padding:6px 14px;border-radius:99px;font-weight:800;font-size:.85rem}

/* ───────── RESPONSIVO ───────── */
@media(max-width:860px){
  .app{grid-template-columns:1fr}
  .sidebar{position:fixed;left:0;top:0;z-index:50;transform:translateX(-100%);transition:.3s;width:260px}
  .sidebar.aberta{transform:none}
  .menu-toggle{display:block}
  .topo{padding:16px 18px}.view{padding:18px}
  .cols-2,.cols-3{grid-template-columns:1fr}
}
.overlay-side{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:49}

/* ───────── REFINAMENTOS MOBILE ───────── */
@media(max-width:600px){
  .topo h2{font-size:1.2rem}
  .topo-acoes .btn{padding:9px 12px;font-size:.82rem}
  .view{padding:14px 12px 50px}
  .modal{padding:8px}
  .modal-box{padding:18px;border-radius:20px}
  .grid2{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}
  .forms-grid{grid-template-columns:1fr}
  .builder{grid-template-columns:1fr}
  .dt-grid{grid-template-columns:1fr}
  .vol-view{padding:18px 12px 50px}
  .login-hero{width:min(60vw,180px)}
  .subtabs{overflow-x:auto;flex-wrap:nowrap}
  .subtabs button{white-space:nowrap}
}
