:root{
  --bg:#f1f5f9; --card:#fff; --ink:#0f172a; --muted:#64748b; --line:#e2e8f0;
  --brand:#0f766e; --brand2:#0d9488; --ok:#16a34a; --okbg:#dcfce7;
  --wait:#b45309; --waitbg:#fef3c7; --danger:#dc2626; --shadow:0 1px 3px rgba(0,0,0,.08);
}
*{box-sizing:border-box}
body{margin:0;font-family:-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:var(--bg);color:var(--ink);font-size:15px}
h1{font-size:1.4rem;margin:0}
h3{margin:0 0 .6rem}
small{color:var(--muted)}
a{color:var(--brand)}

/* sidebar */
.sidebar{position:fixed;top:0;left:0;height:100vh;width:236px;background:linear-gradient(180deg,#0e6f68 0%,#0a4f49 100%);color:#fff;display:flex;flex-direction:column;padding:1.1rem .8rem 1rem;overflow-y:auto;z-index:40;transition:transform .25s ease;box-shadow:inset -1px 0 0 rgba(255,255,255,.06)}
.brand{display:flex;align-items:center;gap:.7rem;padding:.1rem .3rem 1rem;border-bottom:1px solid rgba(255,255,255,.12);margin-bottom:1rem}
.brand strong{display:block;line-height:1.15;color:#fff;font-size:1rem;letter-spacing:.01em}
.logo{background:linear-gradient(135deg,#2dd4bf 0%,#0d9488 55%,#0f766e 100%);border-radius:12px;width:42px;height:42px;display:grid;place-items:center;flex:0 0 auto;color:#fff;box-shadow:0 4px 12px rgba(0,0,0,.28),inset 0 1px 0 rgba(255,255,255,.3)}
.logo svg{width:22px;height:22px}
.badge{font-size:.62rem;padding:.12rem .45rem;border-radius:999px;vertical-align:middle;font-weight:700;letter-spacing:.02em}
.badge-local{background:rgba(255,255,255,.22)}
.badge-cloud{background:#22c55e;box-shadow:0 0 8px rgba(34,197,94,.45)}
.side-nav{display:flex;flex-direction:column;gap:1.15rem}
.nav-group{display:flex;flex-direction:column;gap:.2rem}
.nav-group-title{font-size:.68rem;text-transform:uppercase;letter-spacing:.16em;color:#99f6e4;padding:.2rem .75rem .35rem;font-weight:800;text-shadow:0 1px 2px rgba(0,0,0,.25)}
.tab{display:flex;align-items:center;gap:.65rem;background:transparent;color:rgba(255,255,255,.8);border:0;padding:.6rem .75rem;border-radius:10px;font-size:.9rem;cursor:pointer;text-align:left;width:100%;transition:background .15s,color .15s}
.tab:hover{background:rgba(255,255,255,.09);color:#fff}
.tab.active{background:#fff;color:#0d5f58;font-weight:700;box-shadow:0 6px 16px rgba(0,0,0,.22)}
.nav-ic{width:1.4rem;text-align:center;flex:0 0 auto;display:inline-grid;place-items:center;opacity:.9}
.tab.active .nav-ic{opacity:1}

.nav-toggle{display:none;position:fixed;top:.6rem;left:.6rem;z-index:50;background:var(--brand);color:#fff;border:0;width:44px;height:44px;border-radius:12px;font-size:1.3rem;cursor:pointer;box-shadow:var(--shadow)}
.sidebar-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:35}

main{max-width:1600px;padding:1rem 1.5rem 1rem;margin-left:236px}
/* só o Dashboard ocupa a página inteira; as demais telas usam uma largura de
   leitura confortável para as colunas não ficarem esparramadas */
.screen{display:none;animation:fade .2s;max-width:1160px}
#screen-dashboard{max-width:none}
.screen.active{display:block}
@keyframes fade{from{opacity:0;transform:translateY(4px)}to{opacity:1}}

.screen-head{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;margin-bottom:.5rem}
#dashIntro{margin:-.2rem 0 .9rem}
.hint{color:var(--muted);font-size:.85rem;margin:.2rem 0 1rem}

/* buttons */
.btn{background:#fff;border:1px solid var(--line);padding:.55rem .9rem;border-radius:10px;cursor:pointer;font-size:.9rem;font-weight:600;color:var(--ink)}
.btn:hover{border-color:var(--brand)}
.btn-primary{background:var(--brand);color:#fff;border-color:var(--brand)}
.btn-danger{background:var(--danger);color:#fff;border-color:var(--danger)}
.row-btns{display:flex;gap:.5rem;flex-wrap:wrap}

/* filters */
.filters{display:flex;gap:.8rem;flex-wrap:wrap;align-items:flex-end}
.filters-wrap{background:var(--card);padding:.8rem;border-radius:12px;box-shadow:var(--shadow);margin-bottom:1rem}
.filters label,.modal-body label{display:flex;flex-direction:column;font-size:.75rem;color:var(--muted);gap:.25rem;font-weight:600}
.filters input,.filters select{padding:.45rem .5rem;border:1px solid var(--line);border-radius:8px;font-size:.9rem;background:#fff}

/* cards */
.card{background:var(--card);border-radius:14px;padding:.85rem;box-shadow:var(--shadow);margin-bottom:1rem}
.card.danger{border:1px solid #fecaca}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
/* dashboard em página única: 2 gráficos + cards, com "Próximos recebimentos" como coluna alta à direita */
.dash-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr) minmax(280px,340px);grid-template-areas:"bars line rail" "comp dest rail";gap:.8rem;align-items:start;margin-bottom:.8rem}
.dash-grid .card{margin-bottom:0}
.ga-bars{grid-area:bars}.ga-line{grid-area:line}.ga-rail{grid-area:rail}.ga-comp{grid-area:comp}.ga-dest{grid-area:dest}
.ga-rail{max-height:660px;overflow:auto}
.dash-dica{display:flex;gap:.5rem;align-items:baseline;background:#f0fdf4;border:1px solid #bbf7d0;color:#166534;border-radius:12px;padding:.7rem 1rem;font-size:.85rem;margin:0}
.dash-dica b{color:#166534}
@media(max-width:1024px){.dash-grid{grid-template-columns:1fr 1fr;grid-template-areas:"bars line" "comp dest" "rail rail"}.ga-rail{max-height:none}}
@media(max-width:600px){.dash-grid{grid-template-columns:1fr;grid-template-areas:"bars" "line" "comp" "dest" "rail"}.kpis{grid-template-columns:1fr}}

/* kpis */
.kpis{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:.8rem;margin-bottom:.8rem}
.kpi{background:var(--card);border-radius:14px;padding:.9rem 1rem;box-shadow:var(--shadow);display:flex;align-items:flex-start;gap:.75rem}
.kpi-ic{flex:0 0 auto;width:44px;height:44px;border-radius:50%;display:grid;place-items:center;color:#fff}
.kpi-ic svg{width:22px;height:22px}
.kpi-body{display:flex;flex-direction:column;gap:.12rem;min-width:0;flex:1}
.kt{font-size:.75rem;color:var(--muted);font-weight:600}
.kv{font-size:1.3rem;font-weight:800;color:var(--brand);line-height:1.15}
.ks{font-size:.7rem;color:var(--muted)}
/* tons dos KPIs */
.kpi-green .kpi-ic{background:var(--ok)} .kpi-green .kv{color:var(--ok)}
.kpi-amber .kpi-ic{background:#f59e0b} .kpi-amber .kv{color:#d97706}
.kpi-blue .kpi-ic{background:#2563eb} .kpi-blue .kv{color:#2563eb}
.kpi-purple .kpi-ic{background:#7c3aed} .kpi-purple .kv{color:#7c3aed}
/* barra de meta */
.kpi-metatxt{display:flex;justify-content:space-between;font-size:.7rem;color:var(--muted);margin-top:.25rem}
.kpi-bar{height:7px;border-radius:99px;background:#e5e7eb;overflow:hidden;margin-top:.15rem}
.kpi-bar>span{display:block;height:100%;border-radius:99px;background:linear-gradient(90deg,#3b82f6,#2563eb)}
.kpi-editmeta,.kpi-setmeta{background:none;border:0;color:var(--brand);font-size:.7rem;font-weight:600;cursor:pointer;padding:.25rem 0 0;text-align:left}
.kpi-setmeta{color:#2563eb}
/* destaques do mês */
.destaques{display:flex;flex-direction:column;gap:.2rem}
.dst{display:flex;align-items:center;gap:.7rem;padding:.55rem 0;border-bottom:1px dashed var(--line)}
.dst:last-child{border-bottom:0}
.dst-ic{flex:0 0 auto;width:40px;height:40px;border-radius:50%;display:grid;place-items:center;color:#fff}
.dst-ic svg{width:20px;height:20px}
.dst-info{display:flex;flex-direction:column;line-height:1.3;flex:1;min-width:0}
.dst-t{font-weight:700;font-size:.9rem}
.dst-sub{font-size:.76rem;color:var(--muted)}
.dst-v{font-variant-numeric:tabular-nums;white-space:nowrap;font-weight:700}
.dst-pos .dst-ic{background:var(--ok)} .dst-pos .dst-v{color:var(--ok)}
.dst-neg .dst-ic{background:var(--danger)} .dst-neg .dst-v{color:var(--danger)}
.dst-neu .dst-ic{background:#2563eb}

/* bar chart */
.chart-legend{display:flex;gap:1rem;font-size:.72rem;color:var(--muted);margin-bottom:.6rem}
.chart-legend span{display:flex;align-items:center;gap:.35rem}
.chart-legend i{width:12px;height:12px;border-radius:3px;display:inline-block}
.chart-legend .lg-rec{background:var(--brand2)}
.chart-legend .lg-prev{background:repeating-linear-gradient(45deg,#f59e0b,#f59e0b 4px,#fbbf24 4px,#fbbf24 8px)}
.chart-bars{display:flex;flex-direction:column;gap:.35rem}
.barrow{display:grid;grid-template-columns:34px 1fr auto;align-items:center;gap:.5rem;font-size:.8rem}
.bl{color:var(--muted);font-weight:600}
.bt{background:#eef2f7;border-radius:6px;height:16px;overflow:hidden;display:flex}
.bf{display:block;height:100%;background:linear-gradient(90deg,var(--brand),var(--brand2))}
.bf.prev{background:repeating-linear-gradient(45deg,#f59e0b,#f59e0b 5px,#fbbf24 5px,#fbbf24 10px);cursor:pointer}
.bv{font-variant-numeric:tabular-nums;color:var(--ink);white-space:nowrap;font-size:.75rem}
.barrow.now .bl{color:var(--brand);font-weight:800}
/* charts SVG (barras verticais + linha) */
.linechart{width:100%;height:auto;display:block;max-height:230px}
.vb-rec{fill:var(--brand2)}
.vb-prev{fill:#f59e0b;cursor:pointer}
.vb-lab{fill:var(--muted);font-size:9px;text-anchor:middle;font-weight:600}
.vb-lab.now,.lc-xlab.now{fill:var(--brand);font-weight:800}
.lc-grid{stroke:var(--line);stroke-width:1}
.lc-ylab{fill:var(--muted);font-size:9px;text-anchor:end}
.lc-xlab{fill:var(--muted);font-size:9px;text-anchor:middle}
.lc-area{fill:rgba(15,118,110,.10);stroke:none}
.lc-line{fill:none;stroke:var(--brand);stroke-width:2.5;stroke-linejoin:round;stroke-linecap:round}
.lc-dot{fill:var(--brand);stroke:#fff;stroke-width:1.5;pointer-events:none}
.lc-hit{fill:transparent;cursor:pointer}
.lc-cur rect{fill:var(--brand)}
.lc-cur text{fill:#fff;font-size:9px;font-weight:700}
.barrow.now .bl:after{content:" •"}

/* composição */
.comporow{margin-bottom:.7rem}
.compohead{display:flex;justify-content:space-between;font-size:.8rem;margin-bottom:.2rem}
.compobar{background:#eef2f7;border-radius:6px;height:10px;overflow:hidden}
.compobar span{display:block;height:100%;background:linear-gradient(90deg,#0ea5e9,#6366f1)}

/* a receber */
.areceber .arrow{display:flex;justify-content:space-between;padding:.5rem 0;border-bottom:1px dashed var(--line)}
.arrow.atrasado strong{color:var(--danger)}
/* Próximos recebimentos (blocos por urgência) */
.areceber{display:flex;flex-direction:column;gap:.8rem}
.rc-sec{border:1px solid var(--line);border-radius:12px;overflow:hidden}
.rc-head{display:flex;justify-content:space-between;align-items:center;gap:.6rem;padding:.55rem .85rem;font-weight:700;font-size:.9rem}
.rc-badge{display:inline-flex;align-items:center;gap:.5rem}
.rc-badge::before{content:"";width:10px;height:10px;border-radius:50%;background:currentColor}
.rc-tot{font-variant-numeric:tabular-nums;opacity:.85}
.rc-item{display:flex;justify-content:space-between;align-items:center;gap:.7rem;padding:.6rem .85rem;border-top:1px dashed var(--line);background:#fff}
.rc-info{display:flex;flex-direction:column;line-height:1.35}
.rc-sub{font-size:.76rem;color:var(--muted)}
.rc-val{font-variant-numeric:tabular-nums;white-space:nowrap}
.rc-atr .rc-head{background:#fef2f2;color:var(--danger)}
.rc-atr .rc-val{color:var(--danger)}
.rc-soon .rc-head{background:var(--waitbg);color:var(--wait)}
.rc-far .rc-head{background:var(--okbg);color:var(--ok)}
.rc-all{width:100%;margin-top:.1rem;text-align:center}

/* resumo lista */
.resumo-lista{display:flex;gap:1.2rem;flex-wrap:wrap;background:#ecfdf5;border:1px solid #a7f3d0;border-radius:10px;padding:.6rem .9rem;margin-bottom:.8rem;font-size:.85rem}

/* tables */
.table-wrap{overflow-x:auto;background:var(--card);border-radius:14px;box-shadow:var(--shadow)}
table{width:100%;border-collapse:collapse;font-size:.85rem}
th,td{padding:.6rem .7rem;text-align:left;border-bottom:1px solid var(--line);white-space:nowrap}
th{background:#f8fafc;color:var(--muted);font-size:.72rem;text-transform:uppercase;letter-spacing:.03em;position:sticky;top:0}
td.num,th.num{text-align:right;font-variant-numeric:tabular-nums}
.empty{text-align:center;color:var(--muted);padding:2rem}
.acts{display:flex;gap:.2rem;justify-content:flex-end}
.ic{background:#f1f5f9;border:0;border-radius:8px;width:30px;height:30px;cursor:pointer;font-size:.9rem}
.ic:hover{background:#e2e8f0}
.ic.danger:hover{background:#fee2e2}
.pill{font-size:.7rem;font-weight:700;padding:.15rem .5rem;border-radius:999px}
.pill.ok{background:var(--okbg);color:var(--ok)}
.pill.wait{background:var(--waitbg);color:var(--wait)}
.pill.part{background:#e0e7ff;color:#3730a3}
.pill.off{background:#f1f5f9;color:var(--muted)}

/* situação inline + linha excluída */
.sit-sel{border:1px solid var(--line);border-radius:8px;padding:.25rem .4rem;font-size:.78rem;font-weight:700;background:#fff;cursor:pointer}
.sit-sel.sit-realizada{color:var(--ok);border-color:#86efac;background:var(--okbg)}
.sit-sel.sit-agendado{color:var(--wait);border-color:#fcd34d;background:var(--waitbg)}
.sit-sel.sit-exclusao{color:var(--muted);background:#f1f5f9}
tr.row-excl td{opacity:.55}
tr.row-excl td[data-l="Tipo"],tr.row-excl td[data-l="Modalidade"],tr.row-excl td[data-l="Valor"]{text-decoration:line-through}
.num.dif-bad{color:var(--danger);font-weight:700}
small.late{color:var(--danger);font-weight:700}
.obs-ic{cursor:pointer}
tr.has-obs{cursor:pointer}
#modalForm [name="obs"],#obsText{text-transform:uppercase}

.hidden{display:none}
.btn-small{padding:.35rem .7rem;font-size:.8rem}

/* pagamentos */
.pgmonth{background:var(--card);border-radius:14px;box-shadow:var(--shadow);margin-bottom:1rem;overflow:hidden}
.pgmonth-head{display:flex;justify-content:space-between;align-items:center;gap:.6rem;flex-wrap:wrap;padding:.8rem 1rem;background:#f8fafc;border-bottom:1px solid var(--line)}
.pgmonth-head h3{margin:0}
.pgtotals{display:flex;gap:.4rem;flex-wrap:wrap}
.pgmonth .table-wrap{box-shadow:none;border-radius:0}
/* larguras fixas (só no desktop): alinha as colunas entre um mês e outro.
   No celular as tabelas viram cartões empilhados, então estas regras não valem. */
@media(min-width:761px){
  .pgmonth table{table-layout:fixed}
  .pgmonth th:nth-child(1),.pgmonth td:nth-child(1){width:28%;white-space:normal}
  .pgmonth th:nth-child(2),.pgmonth td:nth-child(2){width:12%}
  .pgmonth th:nth-child(3),.pgmonth td:nth-child(3){width:14%;text-align:center}
  .pgmonth th:nth-child(4),.pgmonth td:nth-child(4){width:20%;white-space:normal}
  .pgmonth th:nth-child(5),.pgmonth td:nth-child(5){width:12%}
  .pgmonth th:nth-child(6),.pgmonth td:nth-child(6){width:14%}
  /* a célula de ação NÃO pode ser flex aqui: display:flex tira o td do modelo de
     tabela e quebra as larguras fixas. Mantém como table-cell e alinha à direita. */
  .pgmonth td.acts{display:table-cell;text-align:right}
}

/* salário / descontos */
.subh{margin:.9rem 0 .4rem;font-size:.78rem;color:var(--muted);text-transform:uppercase;letter-spacing:.03em}
.desc-grp{margin:.6rem 0 .2rem;font-size:.95rem;color:var(--brand);border-bottom:2px solid var(--line);padding-bottom:.3rem}
.desc-grp.desc-13{margin-top:1.4rem;color:#3730a3;border-bottom-color:#c7d2fe}
.desc-grp.desc-bonif{margin-top:1.4rem;color:#166534;border-bottom-color:#bbf7d0}
#descontosResumo .arrow{display:flex;justify-content:space-between;padding:.45rem 0;border-bottom:1px dashed var(--line)}

/* lags */
.lags{display:flex;flex-direction:column;gap:.5rem}
.lagrow{display:flex;align-items:center;gap:.6rem;background:#f8fafc;border:1px solid var(--line);border-radius:10px;padding:.4rem .7rem;font-weight:600;font-size:.85rem}
.lagrow>span{flex:1}
.lagrow input{width:56px;padding:.3rem;border:1px solid var(--line);border-radius:6px;text-align:center}
.lagrow .unit{flex:none;color:var(--muted);font-weight:400}

/* modal */
.modal-overlay{position:fixed;inset:0;background:rgba(15,23,42,.5);display:grid;place-items:center;z-index:50;padding:1rem}
.modal-overlay[hidden]{display:none}
.modal{background:#fff;border-radius:16px;width:100%;max-width:440px;max-height:92vh;display:flex;flex-direction:column;overflow:hidden}
.modal-head{display:flex;justify-content:space-between;align-items:center;padding:1rem;border-bottom:1px solid var(--line)}
.modal-head h2{margin:0;font-size:1.1rem}
.modal-close{background:none;border:0;font-size:1.6rem;cursor:pointer;color:var(--muted);line-height:1}
.modal-body{padding:1rem;overflow-y:auto;display:flex;flex-direction:column;gap:.7rem}
.modal-body input,.modal-body select{padding:.55rem;border:1px solid var(--line);border-radius:8px;font-size:1rem;background:#fff}
.modal-body label{font-size:.78rem}
.modal-body .chk{flex-direction:row;align-items:center;gap:.5rem;font-size:.9rem;color:var(--ink)}
.modal-body .chk input{width:auto}
.info-pag{background:#ecfeff;border:1px solid #a5f3fc;border-radius:8px;padding:.5rem .7rem;font-size:.8rem;color:#155e75}
.modal-foot{display:flex;justify-content:flex-end;gap:.5rem;padding:1rem;border-top:1px solid var(--line)}

/* toast */
.toast{position:fixed;bottom:1rem;left:50%;transform:translateX(-50%);background:var(--ink);color:#fff;padding:.7rem 1.1rem;border-radius:999px;font-size:.85rem;z-index:60;box-shadow:0 4px 12px rgba(0,0,0,.2)}

/* sidebar: fixa no desktop, retrátil no celular */
@media(min-width:761px){
  .sidebar-overlay{display:none}
}
@media(max-width:760px){
  .sidebar{transform:translateX(-100%);width:260px;box-shadow:2px 0 16px rgba(0,0,0,.35)}
  .sidebar.open{transform:translateX(0)}
  .nav-toggle{display:block}
  main{margin-left:0;padding:3.8rem 1rem 3rem}
}

/* responsivo */
@media(max-width:760px){
  .kpis{grid-template-columns:repeat(2,minmax(0,1fr))}
  .grid-2{grid-template-columns:1fr}
  .screen-head h1{font-size:1.2rem}
  /* tabelas viram cartões */
  table,thead,tbody,th,td,tr{display:block}
  thead{display:none}
  tr{background:#fff;border-radius:12px;margin-bottom:.6rem;box-shadow:var(--shadow);padding:.4rem .2rem}
  td{border:none;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:center;white-space:normal;gap:1rem}
  td:last-child{border-bottom:0}
  td[data-l]:before{content:attr(data-l);color:var(--muted);font-size:.7rem;font-weight:700;text-transform:uppercase}
  td.num{text-align:right}
  .acts{justify-content:flex-end}
  .empty{display:block}
}

/* ============ ícones SVG (nav e botões) ============ */
.nav-ic svg{width:18px;height:18px;display:block;margin:0 auto}
.ic{display:inline-grid;place-items:center}
.ic svg{width:15px;height:15px;pointer-events:none}
.ic.danger{color:var(--danger)}
.bic{display:inline-flex;vertical-align:-2px;margin-right:.4rem}
.bic svg{width:15px;height:15px}
.obs-ic{cursor:pointer;display:inline-flex;vertical-align:-2px}
.obs-ic svg{width:13px;height:13px;color:var(--brand)}

/* ============ rodapé da sidebar: usuário logado / entrar ============ */
.side-foot{margin-top:auto;padding:.8rem .2rem 0;border-top:1px solid rgba(255,255,255,.12)}
.user-chip{display:flex;align-items:center;gap:.55rem;background:rgba(255,255,255,.14);border-radius:10px;padding:.5rem .65rem;color:#fff;font-size:.85rem;font-weight:600}
.user-chip .dot{width:9px;height:9px;border-radius:50%;background:#4ade80;flex:none;box-shadow:0 0 6px rgba(74,222,128,.8)}
.user-chip .dot.off{background:#fbbf24;box-shadow:none}
.user-chip .user-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.user-chip.chip-re{cursor:pointer}
.chip-out{background:transparent;border:0;color:rgba(255,255,255,.75);cursor:pointer;display:inline-grid;place-items:center;padding:.2rem;border-radius:6px}
.chip-out:hover{background:rgba(255,255,255,.15);color:#fff}
.chip-out svg{width:15px;height:15px}
.btn-side-login{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;background:rgba(255,255,255,.14);border:0;border-radius:10px;padding:.55rem .7rem;color:#fff;font-size:.85rem;font-weight:600;cursor:pointer}
.btn-side-login:hover{background:rgba(255,255,255,.22)}
.btn-side-login svg{width:16px;height:16px}

/* ============ acessibilidade: foco visível no teclado ============ */
:where(button,select,input,textarea,a):focus-visible{outline:2px solid var(--brand2);outline-offset:2px}

/* ============ splash de carregamento (boot) ============ */
#boot{position:fixed;inset:0;background:var(--bg);display:grid;place-items:center;z-index:100;transition:opacity .3s}
#boot.done{opacity:0;pointer-events:none}
.boot-box{display:flex;flex-direction:column;align-items:center;gap:.9rem}
.boot-spin{width:26px;height:26px;border:3px solid var(--line);border-top-color:var(--brand);border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* ============ modal de confirmação ============ */
.confirm-msg{margin:0;font-size:.95rem;line-height:1.5}

/* ============ utilitárias (CSP sem estilo inline) ============ */
.m0{margin:0}
.mt1{margin-top:1rem}
.obs-meta{margin:0 0 .5rem}
.pre-wrap{white-space:pre-wrap;margin:0}
.btn-addlag{align-self:flex-start;margin-top:.3rem}
.txt-ok{color:var(--ok);font-weight:700}
.txt-bad{color:var(--danger);font-weight:700}

/* ============ tela de login (portão de entrada) ============ */
#loginScreen{position:fixed;inset:0;z-index:95;display:grid;place-items:center;padding:1.5rem;background:radial-gradient(900px 500px at 50% 18%,#0d4f49 0%,#072e2a 45%,#04201d 100%)}
.login-box{display:flex;flex-direction:column;align-items:center;text-align:center;width:100%;max-width:400px}
.login-logo{width:64px;height:64px;border-radius:18px;box-shadow:0 0 44px rgba(45,212,191,.45),0 8px 22px rgba(0,0,0,.4),inset 0 1px 0 rgba(255,255,255,.3)}
.login-logo svg{width:32px;height:32px}
.login-title{color:#fff;font-size:1.9rem;margin:.9rem 0 .15rem;letter-spacing:.01em}
.login-sub{color:rgba(255,255,255,.55);font-size:.85rem;margin:0 0 1.4rem}
.login-card{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:1.3rem 1.2rem;width:100%;box-shadow:0 12px 34px rgba(0,0,0,.35)}
.login-txt{color:rgba(255,255,255,.8);font-size:.9rem;line-height:1.55;margin:0 0 1rem}
.login-txt b{color:#5eead4}
.btn-google{display:flex;align-items:center;justify-content:center;gap:.6rem;width:100%;background:#fff;color:#1f2937;border:0;border-radius:10px;padding:.75rem 1rem;font-size:.95rem;font-weight:700;cursor:pointer;transition:transform .12s,box-shadow .12s}
.btn-google:hover{transform:translateY(-1px);box-shadow:0 6px 18px rgba(0,0,0,.35)}
.btn-google:disabled{opacity:.6;cursor:wait;transform:none}
.btn-google svg{width:19px;height:19px;flex:0 0 auto}
.login-note{color:rgba(255,255,255,.45);font-size:.75rem;margin:.9rem 0 0}

/* ============ mobile/iOS: viewport dinâmico e safe areas ============ */
.sidebar{height:100dvh} /* navegadores antigos ignoram e ficam com o 100vh acima */
.modal{max-height:92dvh}
@media(max-width:760px){
  /* fonte >=16px evita o zoom automático do iOS ao focar campos */
  input,select,textarea{font-size:16px}
  .filters input,.filters select{font-size:16px}
  /* recorte da Dynamic Island / barra de gesto (viewport-fit=cover) */
  .nav-toggle{top:calc(.6rem + env(safe-area-inset-top))}
  main{padding-top:calc(3.8rem + env(safe-area-inset-top));padding-bottom:calc(3rem + env(safe-area-inset-bottom))}
  .sidebar{padding-top:calc(1rem + env(safe-area-inset-top));padding-left:calc(.7rem + env(safe-area-inset-left))}
  .toast{bottom:calc(1rem + env(safe-area-inset-bottom))}
}

/* ============ tema escuro (segue o sistema) ============ */
@media (prefers-color-scheme: dark){
  :root{
    --bg:#0b1220; --card:#111a2c; --ink:#e2e8f0; --muted:#8fa3bd; --line:#243147;
    --brand:#0f766e; --brand2:#14b8a6; --ok:#34d399; --okbg:#0b3524;
    --wait:#fbbf24; --waitbg:#3b2a08; --danger:#f87171; --shadow:0 1px 3px rgba(0,0,0,.5);
  }
  .filters input,.filters select,.modal-body input,.modal-body select,.modal-body textarea,.lagrow input{background:#0e1626;color:var(--ink);border-color:var(--line)}
  .btn{background:#16233a;color:var(--ink)}
  .btn-primary{background:var(--brand);border-color:var(--brand);color:#fff}
  .btn-danger{background:#b91c1c;border-color:#b91c1c;color:#fff}
  th{background:#0e1626}
  .pgmonth-head{background:#0e1626}
  .lagrow{background:#0e1626}
  .ic{background:#1c2a44;color:var(--ink)}
  .ic:hover{background:#27395c}
  .ic.danger{color:var(--danger)}
  .ic.danger:hover{background:#4c1d1d}
  .bt,.compobar,.kpi-bar{background:#1c2a44}
  .resumo-lista{background:#0b2b22;border-color:#155e4c}
  .dash-dica{background:#0b2b16;border-color:#14532d;color:#86efac}
  .dash-dica b{color:#86efac}
  .rc-item{background:var(--card)}
  .rc-atr .rc-head{background:#3b0d0d}
  .pill.part{background:#26264f;color:#a5b4fc}
  .pill.off{background:#1c2a44;color:var(--muted)}
  .sit-sel{background:#0e1626;color:var(--ink)}
  .sit-sel.sit-realizada{background:var(--okbg);border-color:#166534}
  .sit-sel.sit-agendado{background:var(--waitbg);border-color:#92600a}
  .sit-sel.sit-exclusao{background:#1c2a44;color:var(--muted)}
  .modal{background:var(--card)}
  .info-pag{background:#082f3a;border-color:#0e5e75;color:#7dd3fc}
  .toast{background:#334155;color:#fff}
  .card.danger{border-color:#7f1d1d}
  .kpi-amber .kv{color:#fbbf24}
  .kpi-blue .kv{color:#60a5fa}
  .kpi-purple .kv{color:#a78bfa}
  .desc-grp.desc-13{color:#a5b4fc;border-bottom-color:#26264f}
  .desc-grp.desc-bonif{color:#86efac;border-bottom-color:#14532d}
  @media(max-width:760px){
    tr{background:var(--card)}
  }
}
