/* Controle de Demandas — identidade visual herdada da versão anterior:
   Space Grotesk (títulos) + Inter (texto) + JetBrains Mono (números),
   teal #0E7C86 para o sistema e violeta #6B4FC0 para tudo que é IA. */
:root{
  --bg:#F2F4F7;
  --surface:#FFFFFF;
  --surface-2:#F8FAFC;
  --ink:#16202E;
  --ink-soft:#5A6677;
  --ink-faint:#8B97A6;
  --line:#E3E8EF;
  --accent:#0E7C86;
  --accent-deep:#0A5A62;
  --ia:#6B4FC0;          /* cor de TODOS os recursos de IA */
  --ia-bg:#EFEAFB;
  --over:#D64545;
  --over-bg:#FCEDEC;
  --today:#C9740A;
  --today-bg:#FBF1E3;
  --soon:#2A6FB0;
  --soon-bg:#EAF2FB;
  --done:#5A8A4A;
  --radius:14px;
  --shadow:0 1px 2px rgba(16,32,46,.04), 0 6px 20px rgba(16,32,46,.06);
}
*{box-sizing:border-box}
/* garante que [hidden] sempre vence regras de display (flex/grid) das classes */
[hidden]{display:none!important}
html,body{margin:0}
body{
  background:var(--bg);
  color:var(--ink);
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  font-size:15px;
  line-height:1.45;
  -webkit-font-smoothing:antialiased;
}
.wrap{max-width:780px;margin:0 auto;padding:22px 18px 80px}
:focus-visible{outline:3px solid rgba(14,124,134,.45);outline-offset:2px}

/* Cabeçalho */
header.top{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:14px}
h1{font-family:"Space Grotesk",sans-serif;font-weight:700;font-size:23px;letter-spacing:-.02em;margin:0;display:flex;align-items:center;gap:9px}
.dot{width:11px;height:11px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 4px rgba(14,124,134,.15)}
.top-right{display:flex;align-items:center;gap:8px}
.today-label{font-size:13px;color:var(--ink-soft);font-weight:500}
.bell{font-size:17px}
.bell.on{color:var(--accent)}

/* Aviso do topo */
.alert{
  border-radius:var(--radius);padding:14px 16px;margin-bottom:12px;display:flex;
  align-items:center;gap:13px;font-weight:500;box-shadow:var(--shadow);
}
.alert.calm{background:linear-gradient(180deg,#fff,#F4FBFB);border:1px solid #D5ECEE;color:var(--accent-deep)}
.alert.warn{background:linear-gradient(180deg,#fff,var(--over-bg));border:1px solid #F3D2CF;color:#9A2E2E}
.alert .big{font-family:"JetBrains Mono",monospace;font-size:26px;line-height:1}
.alert .txt{flex:1}
.alert .txt small{display:block;color:inherit;opacity:.8;font-weight:400;font-size:12.5px;margin-top:2px}

/* Briefing da IA */
.briefing{
  border-radius:var(--radius);padding:12px 15px;margin-bottom:16px;display:flex;gap:11px;align-items:flex-start;
  background:linear-gradient(180deg,#fff,var(--ia-bg));border:1px solid #DCD2F4;color:#3E2E78;font-size:14px;
}
.briefing .spark{font-size:18px;line-height:1.3}

/* Contadores */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:9px;margin-bottom:18px}
.stat{background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:11px 12px;cursor:pointer;transition:transform .08s,border-color .12s}
.stat:hover{transform:translateY(-1px)}
.stat.active{border-color:var(--accent);box-shadow:0 0 0 2px rgba(14,124,134,.12)}
.stat .n{font-family:"JetBrains Mono",monospace;font-size:22px;font-weight:600;line-height:1}
.stat .k{font-size:11.5px;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.04em;margin-top:3px}
.stat.over .n{color:var(--over)} .stat.today .n{color:var(--today)}
.stat.soon .n{color:var(--soon)} .stat.all .n{color:var(--ink)}

/* Adicionar */
.add{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:13px;margin-bottom:12px}
.add-row{display:flex;gap:8px;align-items:stretch}
.add input[type=text]{flex:1;min-width:0}
input,select,textarea{
  font-family:inherit;font-size:14.5px;color:var(--ink);background:var(--surface-2);
  border:1px solid var(--line);border-radius:10px;padding:10px 12px;outline:none;transition:border-color .12s,box-shadow .12s;width:100%
}
input:focus,select:focus,textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(14,124,134,.12);background:#fff}
.btn{
  font-family:inherit;font-weight:600;font-size:14.5px;border:none;border-radius:10px;cursor:pointer;
  padding:10px 16px;background:var(--accent);color:#fff;transition:background .12s,transform .06s;white-space:nowrap;
  min-height:44px; /* alvo de toque confortável no celular */
}
.btn:hover{background:var(--accent-deep)} .btn:active{transform:scale(.98)}
.btn.ghost{background:transparent;color:var(--accent);padding:8px 10px}
.btn.ghost:hover{background:rgba(14,124,134,.08)}
.btn.mic{padding:10px 13px;font-size:16px}
.btn.mic.gravando{background:var(--over);animation:pulse 1.2s infinite}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(214,69,69,.4)}50%{box-shadow:0 0 0 8px rgba(214,69,69,0)}}
.btn.ia-btn{background:var(--ia);padding:10px 13px;font-size:15px}
.btn.ia-btn:hover{background:#57409E}
.mic-status{margin-top:9px;font-size:13px;font-weight:600;color:var(--ia);display:flex;align-items:center;gap:7px}
.more-toggle{margin-top:10px;background:none;border:none;color:var(--accent);font-family:inherit;font-weight:500;font-size:13px;cursor:pointer;padding:6px 0}
.add-details{display:none;grid-template-columns:1fr 1fr;gap:9px;margin-top:11px}
.add-details.open{display:grid}
.add-details label{font-size:11.5px;color:var(--ink-soft);font-weight:600;text-transform:uppercase;letter-spacing:.03em;display:block;margin-bottom:4px}
.add-details .full{grid-column:1/-1}

/* Ferramentas de IA */
.toolbar{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px}
.chip-btn{
  font-family:inherit;font-size:13px;font-weight:600;cursor:pointer;border-radius:20px;padding:9px 14px;min-height:40px;
  background:var(--surface);border:1px solid #DCD2F4;color:var(--ia);transition:background .12s,transform .06s;
}
.chip-btn:hover{background:var(--ia-bg)} .chip-btn:active{transform:scale(.98)}
.chip-btn:disabled{opacity:.55;cursor:wait}

/* Filtros */
.filters{display:flex;gap:8px;margin-bottom:14px;flex-wrap:wrap}
.filters input{flex:1;min-width:150px}
.filters select{width:auto;min-width:130px}

/* Resultado de busca IA */
.busca-ia-banner{
  display:flex;align-items:center;gap:9px;background:var(--ia-bg);border:1px solid #DCD2F4;color:#3E2E78;
  border-radius:10px;padding:8px 12px;margin-bottom:12px;font-size:13.5px;font-weight:500;
}
.busca-ia-banner button{margin-left:auto;background:none;border:none;color:var(--ia);font-weight:700;cursor:pointer;font-size:13px;padding:6px}

/* Seções */
.section{margin-bottom:22px}
.section h2{font-family:"Space Grotesk",sans-serif;font-size:13px;text-transform:uppercase;letter-spacing:.07em;color:var(--ink-soft);margin:0 0 9px;display:flex;align-items:center;gap:8px;cursor:pointer}
.section h2 .count{font-family:"JetBrains Mono",monospace;background:var(--surface);border:1px solid var(--line);border-radius:20px;padding:1px 8px;font-size:11px;color:var(--ink-soft)}
.section.over h2{color:var(--over)} .section.today h2{color:var(--today)} .section.soon h2{color:var(--soon)}
.section h2 .chev{margin-left:auto;color:var(--ink-faint);font-size:12px;transition:transform .15s}
.section.collapsed h2 .chev{transform:rotate(-90deg)}
.section.collapsed .list{display:none}

/* Card de demanda */
.card{
  background:var(--surface);border:1px solid var(--line);border-left:4px solid var(--line);
  border-radius:12px;padding:12px 13px;margin-bottom:8px;display:flex;gap:11px;align-items:flex-start;
  box-shadow:0 1px 2px rgba(16,32,46,.03);transition:box-shadow .12s
}
.card:hover{box-shadow:var(--shadow)}
.card.over{border-left-color:var(--over)} .card.today{border-left-color:var(--today)}
.card.soon{border-left-color:var(--soon)} .card.done{opacity:.62;border-left-color:var(--done)}
.card.destaque{box-shadow:0 0 0 3px rgba(14,124,134,.35)}
.check{appearance:none;-webkit-appearance:none;width:23px;height:23px;min-width:23px;margin-top:1px;border:2px solid var(--ink-faint);border-radius:7px;cursor:pointer;background:#fff;position:relative;transition:all .12s}
.check:hover{border-color:var(--accent)}
.check:checked{background:var(--done);border-color:var(--done)}
.check:checked::after{content:"✓";position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:#fff;font-size:13px;font-weight:700}
.card .body{flex:1;min-width:0}
.card .title{font-weight:600;font-size:15px;word-break:break-word}
.card.done .title{text-decoration:line-through;color:var(--ink-soft)}
.card .meta{display:flex;gap:7px;flex-wrap:wrap;align-items:center;margin-top:5px}
.tag{font-size:11.5px;font-weight:600;border-radius:6px;padding:2px 7px;display:inline-flex;align-items:center;gap:4px;white-space:nowrap}
.tag.prazo-over{background:var(--over-bg);color:var(--over)}
.tag.prazo-today{background:var(--today-bg);color:var(--today)}
.tag.prazo-soon{background:var(--soon-bg);color:var(--soon)}
.tag.prazo-later{background:var(--surface-2);color:var(--ink-soft)}
.tag.prio-alta{background:#FCEDEC;color:var(--over)}
.tag.prio-media{background:#FBF1E3;color:var(--today)}
.tag.prio-baixa{background:#EEF2F6;color:var(--ink-soft)}
.tag.who{background:#EAF2FB;color:var(--soon)}
.tag.rec{background:var(--ia-bg);color:var(--ia)}
.tag.cat{background:#E8F2F0;color:#1E6B5E}
.tag.st-andamento{background:#EAF2FB;color:var(--soon)}
.tag.st-aguardando{background:#F2EDE4;color:#8A6D3B}
.tag.hora{background:var(--surface-2);color:var(--ink-soft)}
.card .notes{font-size:13px;color:var(--ink-soft);margin-top:6px;white-space:pre-wrap;word-break:break-word}
.card .acts{display:flex;gap:2px;margin-top:1px}
.icon-btn{background:none;border:none;color:var(--ink-faint);cursor:pointer;padding:8px;border-radius:7px;font-size:14px;line-height:1;transition:background .12s,color .12s}
.icon-btn:hover{background:var(--surface-2);color:var(--ink)}
.icon-btn.del:hover{background:var(--over-bg);color:var(--over)}

.empty{text-align:center;color:var(--ink-faint);padding:34px 16px;font-size:14px}
.empty .e-icon{font-size:30px;display:block;margin-bottom:8px;opacity:.6}

footer{text-align:center;color:var(--ink-faint);font-size:12px;margin-top:30px}
.foot-links{margin-top:6px}
.foot-links a{color:var(--ink-faint)}

/* Modais */
.overlay{position:fixed;inset:0;background:rgba(16,32,46,.42);display:none;align-items:center;justify-content:center;padding:18px;z-index:50}
.overlay.open{display:flex}
.modal{background:var(--surface);border-radius:16px;box-shadow:0 20px 60px rgba(16,32,46,.3);width:100%;max-width:460px;padding:20px;max-height:90vh;overflow:auto}
.modal h3{font-family:"Space Grotesk",sans-serif;margin:0 0 10px;font-size:18px}
.modal-aviso{font-size:12.5px;color:var(--ia);background:var(--ia-bg);border-radius:8px;padding:7px 10px;margin:0 0 12px;font-weight:500}
.modal .grid{display:grid;grid-template-columns:1fr 1fr;gap:11px}
.modal label{font-size:11.5px;color:var(--ink-soft);font-weight:600;text-transform:uppercase;letter-spacing:.03em;display:block;margin-bottom:4px}
.modal .full{grid-column:1/-1}
.modal .modal-acts{display:flex;gap:9px;justify-content:flex-end;margin-top:16px}

/* Lista de demandas extraídas da foto */
.foto-lista .foto-item{border:1px solid var(--line);border-radius:10px;padding:10px;margin-bottom:9px;display:flex;gap:10px;align-items:flex-start}
.foto-item.fora{opacity:.45}
.foto-item .campos{flex:1;display:grid;grid-template-columns:1fr 1fr;gap:7px}
.foto-item .campos .full{grid-column:1/-1}
.foto-item input,.foto-item select{padding:7px 9px;font-size:13.5px}

/* Priorização */
.prio-lista .prio-item{display:flex;gap:11px;padding:10px 4px;border-bottom:1px solid var(--line);align-items:flex-start}
.prio-item .num{font-family:"JetBrains Mono",monospace;font-weight:600;color:var(--ia);min-width:22px}
.prio-item .motivo{font-size:12.5px;color:var(--ink-soft);margin-top:2px}

/* Resumo da equipe */
.equipe-controles{display:flex;gap:8px;margin-bottom:11px}
.equipe-controles select{flex:1}
#equipeTexto{font-size:13.5px;line-height:1.5;resize:vertical}

/* Toast */
.toast{
  position:fixed;left:50%;bottom:24px;transform:translateX(-50%);z-index:80;
  background:var(--ink);color:#fff;border-radius:12px;padding:11px 18px;font-size:13.5px;font-weight:500;
  box-shadow:0 8px 30px rgba(16,32,46,.35);max-width:90vw;text-align:center;
}

/* Login */
.login-view{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px}
.login-card{background:var(--surface);border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow);padding:26px;width:100%;max-width:360px;display:flex;flex-direction:column;gap:9px}
.login-card h1{font-size:20px;margin-bottom:2px}
.login-sub{margin:0 0 8px;color:var(--ink-soft);font-size:13.5px}
.login-card label{font-size:11.5px;color:var(--ink-soft);font-weight:600;text-transform:uppercase;letter-spacing:.03em}
.login-card .btn{margin-top:8px}
.login-erro{color:var(--over);background:var(--over-bg);border-radius:8px;padding:8px 11px;font-size:13px}

@media (max-width:560px){
  .stats{grid-template-columns:repeat(2,1fr)}
  .add-details,.modal .grid,.foto-item .campos{grid-template-columns:1fr}
  .add-row{flex-wrap:wrap}
  .add-row input[type=text]{flex:1 1 100%}
  .ad