:root{
  --bg:#f5f5f7; --card:#ffffff; --ink:#1d1d1f; --muted:#6e6e73; --faint:#8e8e93;
  --line:rgba(0,0,0,.08); --line-2:rgba(0,0,0,.06);
  --brand:#00843d; --brandDk:#006630; --brand-soft:rgba(0,132,61,.10);
  --ai:#13e08a;                  /* verde-neon: o "AI" da marca (presença tech, login) */
  --accent:#C8891B;              /* âmbar/dourado da campanha (tempero, <5% da tela) */
  --accent-soft:rgba(200,137,27,.12);
  --accent-line:rgba(200,137,27,.35);
  --good:#34c759; --warn:#ff9f0a; --bad:#ff3b30; --teal:#30b0c7; --purple:#bf5af2;
  --shadow-sm:0 1px 2px rgba(0,0,0,.04);
  --shadow:0 1px 3px rgba(0,0,0,.05),0 10px 30px rgba(0,0,0,.05);
  --r:18px; --r-sm:12px;
  --sidebar-w:248px;
  --font:-apple-system,BlinkMacSystemFont,"SF Pro Display","SF Pro Text","Inter",system-ui,sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0}
body{font-family:var(--font);background:var(--bg);color:var(--ink);
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;letter-spacing:-.01em}
a{color:var(--brand);text-decoration:none}
button{font-family:inherit}

/* ===================== Layout ===================== */
.layout{display:flex;min-height:100vh}
.sidebar{position:fixed;top:0;left:0;bottom:0;width:var(--sidebar-w);z-index:30;
  display:flex;flex-direction:column;padding:22px 14px;gap:8px;
  background:rgba(255,255,255,.72);backdrop-filter:blur(22px) saturate(180%);
  -webkit-backdrop-filter:blur(22px) saturate(180%);border-right:1px solid var(--line)}
.content{flex:1;margin-left:var(--sidebar-w);min-width:0;display:flex;flex-direction:column}
main{max-width:1180px;width:100%;margin:0 auto;padding:34px 40px 40px}
footer{max-width:1180px;width:100%;margin:0 auto;padding:8px 40px 40px;color:var(--faint);font-size:12px}

/* ===================== Sidebar ===================== */
.brand{display:flex;align-items:center;gap:11px;padding:6px 10px 16px}
.brand-mark{width:38px;height:38px;border-radius:11px;display:grid;place-items:center;
  background:linear-gradient(135deg,var(--brand) 28%,var(--ai));color:#fff;font-weight:800;font-size:15px;
  box-shadow:0 0 0 1px rgba(19,224,138,.35), 0 4px 14px rgba(19,224,138,.30);letter-spacing:0}
.brand-txt{display:flex;flex-direction:column;line-height:1.2}
.brand-txt strong{font-size:16px;font-weight:600;letter-spacing:-.02em}
.brand-txt span{font-size:12px;color:var(--muted)}

#nav{display:flex;flex-direction:column;gap:2px}
#nav a{display:flex;align-items:center;gap:11px;padding:9px 12px;border-radius:10px;
  color:var(--ink);font-size:14.5px;font-weight:500;transition:background .15s,color .15s}
#nav a .ico{width:20px;height:20px;flex:none;color:var(--muted);transition:color .15s}
#nav a:hover{background:rgba(0,0,0,.045)}
#nav a.active{background:var(--brand-soft);color:var(--brand);font-weight:600}
#nav a.active .ico{color:var(--brand)}

.side-foot{margin-top:auto;padding-top:10px;display:flex;flex-direction:column;gap:8px}
.lockbtn{width:100%;display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;
  border:1px solid var(--line);background:rgba(255,255,255,.6);color:var(--muted);font-size:13px;
  font-weight:500;cursor:pointer;transition:.15s}
.lockbtn .ico{width:18px;height:18px}
.lockbtn:hover{border-color:rgba(0,0,0,.16);color:var(--ink)}
.lockbtn.ok{background:rgba(52,199,89,.12);border-color:rgba(52,199,89,.3);color:#1f8f3c}

/* ícones (stroke) */
.ico{fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}

.menu-toggle{display:none}

/* ===================== Tipografia ===================== */
h2.page-title{font-size:30px;line-height:1.1;margin:0 0 22px;font-weight:800;letter-spacing:-.03em}
.muted{color:var(--muted)} .right{text-align:right}
.section{margin:34px 0}
.section h3.sec{font-size:11.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  color:var(--muted);margin:0 0 12px;display:flex;align-items:center;gap:8px}
.section h3.sec::before{content:"";width:18px;height:3px;border-radius:2px;background:linear-gradient(90deg,var(--brand),var(--ai));flex:none}

/* ===================== KPIs ===================== */
.kpi-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;margin-bottom:8px}
.kpi{position:relative;overflow:hidden;background:var(--card);border:1px solid var(--line-2);border-radius:var(--r);padding:20px;
  box-shadow:var(--shadow-sm);transition:transform .18s,box-shadow .18s}
.kpi:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.kpi::after{content:"";position:absolute;right:-24px;top:-24px;width:92px;height:92px;border-radius:50%;filter:blur(28px);opacity:.26;background:var(--brand)}
[data-theme="dark"] .kpi::after{opacity:.36}
.kpi .ico{position:relative;z-index:1;width:36px;height:36px;border-radius:11px;display:grid;place-items:center;font-size:18px;margin-bottom:10px}
.kpi .lab{font-size:13px;color:var(--muted);font-weight:500}
.kpi .val{font-size:32px;font-weight:800;margin-top:8px;line-height:1;letter-spacing:-.03em}
.kpi .sub{font-size:12.5px;color:var(--faint);margin-top:7px}
.kpi .val.good{color:var(--good)} .kpi .val.warn{color:var(--warn)} .kpi .val.brand{color:var(--brand)}
/* KPIs coloridos (vibração — vale nos 2 temas; tint de fundo dá cor também no claro) */
.kpi.k-brand{background:linear-gradient(155deg,color-mix(in srgb,var(--brand) 14%,var(--card)),var(--card) 66%)}
.kpi.k-brand::after{background:var(--brand)} .kpi.k-brand .ico{background:var(--brand-soft);color:var(--brand)} .kpi.k-brand .val{color:var(--brand)}
.kpi.k-teal{background:linear-gradient(155deg,color-mix(in srgb,var(--teal) 16%,var(--card)),var(--card) 66%)}
.kpi.k-teal::after{background:var(--teal)} .kpi.k-teal .ico{background:rgba(48,176,199,.16);color:var(--teal)} .kpi.k-teal .val{color:var(--teal)}
.kpi.k-amber{background:linear-gradient(155deg,color-mix(in srgb,var(--warn) 16%,var(--card)),var(--card) 66%)}
.kpi.k-amber::after{background:var(--warn)} .kpi.k-amber .ico{background:rgba(255,159,10,.16);color:var(--warn)} .kpi.k-amber .val{color:var(--warn)}
.kpi.k-purple{background:linear-gradient(155deg,color-mix(in srgb,var(--purple) 15%,var(--card)),var(--card) 66%)}
.kpi.k-purple::after{background:var(--purple)} .kpi.k-purple .ico{background:rgba(191,90,242,.16);color:var(--purple)} .kpi.k-purple .val{color:var(--purple)}

/* ===================== Cards / grid ===================== */
.cardgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}
.card{background:var(--card);border:1px solid var(--line-2);border-radius:var(--r);padding:20px;box-shadow:var(--shadow-sm)}
.card h3{margin:0 0 12px;font-size:16px;font-weight:600;letter-spacing:-.02em}
.card.hero-accent{border-top:2px solid var(--accent)}  /* realça o KPI mais importante (cobertura da meta) */
.two-col{display:grid;grid-template-columns:1.4fr .9fr;gap:22px;align-items:start}
@media(max-width:900px){.two-col{grid-template-columns:1fr}}

/* ===================== Tabelas ===================== */
table.tbl{width:100%;border-collapse:separate;border-spacing:0;background:var(--card);
  border:1px solid var(--line-2);border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow-sm);font-size:14px}
.tbl th,.tbl td{padding:13px 16px;text-align:left;border-bottom:1px solid var(--line-2)}
.tbl th{background:rgba(0,0,0,.015);font-size:12px;font-weight:600;color:var(--muted);letter-spacing:0}
.tbl tr:last-child td{border-bottom:0}
.tbl tbody tr{transition:background .12s}
.tbl tbody tr:hover td{background:rgba(0,132,61,.04)}
.tbl td.num,.tbl th.num{text-align:right;font-variant-numeric:tabular-nums}
.rowlink{cursor:pointer}

/* ===================== Badges ===================== */
.badge{display:inline-block;padding:3px 10px;border-radius:99px;font-size:12px;font-weight:600;letter-spacing:0}
.badge.good{background:rgba(52,199,89,.14);color:#1f8f3c}
.badge.warn{background:rgba(255,159,10,.16);color:#b06f00}
.badge.bad{background:rgba(255,59,48,.13);color:#cc2a21}
.badge.brand{background:var(--brand-soft);color:var(--brandDk)}
.badge.mut{background:rgba(0,0,0,.05);color:var(--muted)}

/* ===================== Botões / form ===================== */
.btn{border:1px solid var(--line);background:var(--card);border-radius:99px;padding:9px 18px;font-weight:500;
  cursor:pointer;font-size:14px;color:var(--ink);transition:.15s}
.btn:hover{background:rgba(0,0,0,.03);border-color:rgba(0,0,0,.16)}
.btn.primary{background:linear-gradient(135deg,var(--brand),var(--ai));border-color:transparent;color:#fff;
  box-shadow:0 4px 14px color-mix(in srgb,var(--brand) 30%,transparent)}
.btn.primary:hover{filter:brightness(1.06);border-color:transparent}
[data-theme="dark"] .btn.primary{background:linear-gradient(135deg,var(--brand),var(--ai));border-color:transparent;color:#06210f}
.btn.danger{color:var(--bad);border-color:transparent;background:transparent;padding:6px 10px}
.btn.danger:hover{background:rgba(255,59,48,.1)}
.btn.sm{padding:6px 13px;font-size:13px}
.toolbar{display:flex;gap:12px;align-items:center;margin-bottom:16px;flex-wrap:wrap}
.toolbar .grow{flex:1}
input,select,textarea{font-family:inherit;font-size:15px;padding:11px 13px;border:1px solid var(--line);
  border-radius:var(--r-sm);background:#fbfbfd;color:var(--ink);width:100%;transition:.15s}
input:focus,select:focus,textarea:focus{outline:0;border-color:var(--brand);background:#fff;box-shadow:0 0 0 4px var(--brand-soft)}
.field{margin-bottom:14px}
.field label{display:block;font-size:13px;font-weight:500;color:var(--muted);margin-bottom:6px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}

/* ===================== Mapa ===================== */
.map-card{background:var(--card);border:1px solid var(--line-2);border-radius:var(--r);box-shadow:var(--shadow-sm);padding:18px}
.mapwrap{position:relative;width:100%;min-height:540px;height:64vh}
.mapwrap svg{width:100%;height:100%}
.regpath{cursor:pointer;transition:fill-opacity .15s,stroke-width .15s}
.regpath:hover{fill-opacity:1 !important;stroke:var(--brand) !important;stroke-width:1 !important}
.tip{position:absolute;top:12px;left:12px;background:rgba(28,28,30,.92);color:#fff;font-size:12.5px;
  padding:9px 13px;border-radius:12px;display:none;max-width:280px;line-height:1.45;
  backdrop-filter:blur(8px);box-shadow:0 8px 24px rgba(0,0,0,.2)}
.tip .muted{color:rgba(255,255,255,.6)}
.mapnote{position:absolute;bottom:6px;right:10px;font-size:11px;color:var(--faint)}
.zoomctl{position:absolute;top:12px;right:12px;display:flex;flex-direction:column;gap:6px;z-index:5}
.zoomctl button{width:34px;height:34px;border:1px solid var(--line);background:rgba(255,255,255,.85);
  backdrop-filter:blur(8px);border-radius:10px;cursor:pointer;font-size:17px;font-weight:600;color:var(--ink);line-height:1;transition:.12s}
.zoomctl button:hover{background:#fff;border-color:var(--brand);color:var(--brand)}
.zoomctl button:active{transform:scale(.92)}
.fsel{width:auto;min-width:130px;padding:7px 11px;font-size:13px;border-radius:10px}
/* Pessoas / rede de lideranças */
.pcards{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:14px}
.pcard{background:var(--card);border:1px solid var(--line-2);border-radius:14px;padding:14px;box-shadow:var(--shadow-sm);cursor:pointer;transition:transform .15s,box-shadow .15s}
.pcard:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.pav{width:38px;height:38px;border-radius:99px;display:grid;place-items:center;color:#fff;font-weight:700;font-size:13px;flex:none;background:linear-gradient(150deg,var(--brand),#2eb85c)}
.pav.sm{width:28px;height:28px;font-size:11px}
.pgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:12px;text-align:center}
.pgrid .pn{font-size:16px;font-weight:700;line-height:1}
.pgrid .pl{font-size:10px;color:var(--faint);margin-top:2px}
.pnode{display:flex;align-items:center;gap:9px;padding:8px 10px;border:1px solid var(--line-2);border-radius:10px;background:var(--card);margin:5px 0;cursor:pointer;transition:.12s}
.pnode:hover{border-color:var(--brand)}
.viewseg{display:inline-flex;border:1px solid var(--line);border-radius:99px;overflow:hidden}
.viewseg button{border:0;background:var(--card);padding:7px 14px;font-size:13px;cursor:pointer;color:var(--muted)}
.viewseg button.on{background:var(--brand);color:#fff;font-weight:600}
/* WhatsApp preview (mockup celular) */
.phone{width:270px;max-width:100%;margin:0 auto;background:#0b141a;border-radius:26px;padding:9px;box-shadow:0 12px 40px rgba(0,0,0,.28)}
.phone-screen{border-radius:18px;overflow:hidden}
.phone-top{background:#1f2c34;color:#e9edef;padding:9px 13px;display:flex;align-items:center;gap:9px}
.phone-av{width:30px;height:30px;border-radius:99px;background:linear-gradient(150deg,#00843d,#2eb85c);display:grid;place-items:center;color:#fff;font-weight:700;font-size:12px}
.phone-body{background:#0b141a;min-height:230px;max-height:340px;overflow:auto;padding:14px 12px;display:flex;flex-direction:column;justify-content:flex-end;
  background-image:radial-gradient(rgba(255,255,255,.025) 1px,transparent 1px);background-size:18px 18px}
.wa-bubble{background:#005c4b;color:#e9edef;padding:7px 9px 5px;border-radius:9px;border-top-right-radius:3px;max-width:88%;align-self:flex-end;font-size:13px;line-height:1.45;white-space:pre-wrap;word-wrap:break-word;box-shadow:0 1px 1px rgba(0,0,0,.25)}
.wa-time{font-size:10px;color:rgba(233,237,239,.55);text-align:right;margin-top:2px}
.wa-vchip{padding:2px 9px !important;font-size:11.5px !important;font-family:ui-monospace,monospace}
/* Agenda */
.cal-nav{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.cal-head{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;margin-bottom:6px}
.cal-head span{text-align:center;font-size:11px;font-weight:600;color:var(--faint)}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}
.cal-cell{min-height:60px;border:1px solid var(--line-2);border-radius:10px;padding:6px;background:var(--card);cursor:pointer;transition:.12s;display:flex;flex-direction:column;gap:3px}
.cal-cell.empty{border:0;background:transparent;cursor:default}
.cal-cell:hover:not(.empty){border-color:var(--brand)}
.cal-cell.today{box-shadow:0 0 0 1.5px var(--brand) inset}
.cal-cell.sel{background:var(--brand-soft)}
.cal-cell>span{font-size:12px;font-weight:600;color:var(--muted)}
.cal-dots{display:flex;flex-wrap:wrap;gap:3px;margin-top:auto}
.cal-dots i{width:7px;height:7px;border-radius:99px;display:inline-block}
.ag-card{display:flex;gap:13px;align-items:flex-start;padding:12px 14px;border:1px solid var(--line-2);border-radius:12px;background:var(--card);margin-bottom:8px;box-shadow:var(--shadow-sm)}
.ag-time{font-weight:700;font-size:13px;min-width:50px;color:var(--ink)}
.ag-chip{display:inline-block;font-size:11.5px;padding:2px 9px;border-radius:99px;background:rgba(0,0,0,.05);color:var(--muted);margin:3px 5px 0 0;cursor:pointer}
.ag-chip:hover{background:var(--brand-soft);color:var(--brandDk)}
.ag-daygroup{font-size:12px;font-weight:700;color:var(--faint);text-transform:uppercase;margin:16px 0 8px;letter-spacing:.03em}
.muni-map{height:440px;border-radius:14px;overflow:hidden;border:1px solid var(--line-2)}
.muni-map.lvtmap{z-index:0}
.leaflet-container{font-family:var(--font)}
.lvt-pop b{font-size:13.5px} .lvt-pop .muted{color:var(--muted);font-size:12px}
.metric-pick{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}
.metric-pick button{border:1px solid var(--line);background:var(--card);border-radius:99px;padding:7px 15px;
  font-size:13px;font-weight:500;cursor:pointer;color:var(--muted);transition:.15s}
.metric-pick button:hover{border-color:rgba(0,0,0,.18);color:var(--ink)}
.metric-pick button.on{background:var(--brand);border-color:var(--brand);color:#fff;font-weight:600}
.legend{display:flex;align-items:center;gap:9px;font-size:12.5px;color:var(--muted);margin-top:14px;flex-wrap:wrap}
.legend .scale{display:flex;height:10px;border-radius:99px;overflow:hidden;width:200px}
.legend .scale i{flex:1}

/* botão flutuante sobre o mapa (acima dos controles do Leaflet, ~1000) */
.mapselbtn{position:absolute;top:12px;right:12px;z-index:1100;
  box-shadow:0 4px 16px rgba(0,0,0,.18);background:var(--card)}
.mapselbtn.primary{background:var(--brand);color:#fff}

/* barra de info do heatmap por candidato (canto inferior esquerdo do mapa) */
.mapheatinfo{position:absolute;left:12px;bottom:12px;z-index:1100;display:flex;align-items:center;gap:5px;
  background:var(--card);border:1px solid var(--line);border-radius:12px;padding:7px 12px;
  font-size:12.5px;box-shadow:0 4px 16px rgba(0,0,0,.18)}

/* ===================== Modal ===================== */
/* z-index acima dos panes/controles do Leaflet (que vão até 1000) —
   senão o mapa renderiza POR CIMA do modal */
.modal-bg{position:fixed;inset:0;background:rgba(0,0,0,.32);display:grid;place-items:center;z-index:2000;padding:20px;
  backdrop-filter:blur(6px);animation:fade .2s ease}
.modal{background:var(--card);border-radius:22px;max-width:520px;width:100%;padding:26px;
  box-shadow:0 24px 70px rgba(0,0,0,.28);max-height:90vh;overflow:auto;animation:pop .2s ease}
.modal h3{margin:0 0 20px;font-size:20px;font-weight:600;letter-spacing:-.02em}
.modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:6px}
@keyframes fade{from{opacity:0}to{opacity:1}}
@keyframes pop{from{opacity:0;transform:scale(.97) translateY(6px)}to{opacity:1;transform:none}}

/* ===================== Diversos ===================== */
.empty{padding:48px;text-align:center;color:var(--muted);font-size:14px}
.loading{padding:60px;text-align:center;color:var(--faint)}
.barrow{display:flex;align-items:center;gap:10px;margin:8px 0}
.bar{flex:1;height:8px;background:rgba(0,0,0,.06);border-radius:99px;overflow:hidden}
.bar i{display:block;height:100%;background:var(--brand);border-radius:99px;transition:width .4s ease}
.bar i.good{background:var(--good)} .bar i.warn{background:var(--warn)}

/* ===================== Responsivo ===================== */
.nav-scrim{display:none}
@media(max-width:820px){
  .sidebar{transform:translateX(-100%);transition:transform .25s ease;box-shadow:0 0 40px rgba(0,0,0,.18)}
  .sidebar.open{transform:none}
  .content{margin-left:0}
  main{padding:64px 18px 40px}
  .menu-toggle{display:grid;place-items:center;position:fixed;top:14px;left:14px;z-index:20;
    width:42px;height:42px;border-radius:12px;border:1px solid var(--line);
    background:rgba(255,255,255,.8);backdrop-filter:blur(10px);font-size:18px;cursor:pointer}
  h2.page-title{font-size:24px}
  /* backdrop do menu off-canvas */
  .nav-scrim.show{display:block;position:fixed;inset:0;background:rgba(0,0,0,.42);z-index:25}
  /* uso em campo: a PRÓPRIA tabela rola (só 2 de 19 ficam em .card) — assim nenhuma
     versão estoura a largura da página, com ou sem card ao redor */
  .card{overflow-x:auto;-webkit-overflow-scrolling:touch}
  table.tbl{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch;white-space:nowrap}
  .tbl th,.tbl td{padding:10px 12px;font-size:13.5px}
  /* formulários e modais empilham e cabem na tela */
  .field-row{grid-template-columns:1fr}
  .modal{padding:20px;border-radius:18px}
  .modal h3{font-size:18px;margin-bottom:16px}
  .toolbar{gap:8px}
  /* mapa não toma a tela inteira no celular */
  .mapwrap{min-height:360px;height:58vh}
  .muni-map{height:340px}
}

/* ===================== Modo escuro (telão de guerra) ===================== */
[data-theme="dark"]{
  --bg:#0c0f0e; --card:#161a18; --ink:#f4f6f5; --muted:#a7adab; --faint:#7c8482;
  --line:rgba(255,255,255,.10); --line-2:rgba(255,255,255,.07);
  --brand:#2fbf6a; --brandDk:#28a85c; --brand-soft:rgba(47,191,106,.15);
  --accent:#E6B23E; --accent-soft:rgba(230,178,62,.16); --accent-line:rgba(230,178,62,.40);
  --shadow-sm:0 1px 2px rgba(0,0,0,.4);
  --shadow:0 1px 3px rgba(0,0,0,.5),0 10px 30px rgba(0,0,0,.45);
}
[data-theme="dark"] .sidebar{ background:rgba(20,24,22,.72); }
[data-theme="dark"] input,
[data-theme="dark"] select,
[data-theme="dark"] textarea{ background:#1c211e; }
[data-theme="dark"] input:focus,
[data-theme="dark"] select:focus,
[data-theme="dark"] textarea:focus{ background:#20251f; }
[data-theme="dark"] .btn{ background:#1c211e; }
[data-theme="dark"] .tbl th{ background:rgba(255,255,255,.03); }
[data-theme="dark"] .tbl tbody tr:hover td{ background:rgba(47,191,106,.06); }
[data-theme="dark"] .menu-toggle{ background:rgba(20,24,22,.8); }
[data-theme="dark"] .map-card{ background:#161a18; }

/* ===================== Equipe — 2º step do Orçamento (valores sensíveis) ===================== */
.priv-note{font-size:12.5px;color:var(--muted);background:var(--accent-soft);border:1px solid var(--accent-line);
  border-radius:12px;padding:9px 13px;margin:0 0 16px}
.sensit{transition:filter .18s ease}
.ocultar .sensit{filter:blur(8px);-webkit-filter:blur(8px);user-select:none;pointer-events:none}
.ped-chip{display:inline-block;font-size:12px;padding:3px 10px;border-radius:99px;cursor:pointer;line-height:1.5;
  background:rgba(255,159,10,.14);color:#b06f00;border:1px solid transparent;transition:.12s}
.ped-chip:hover{border-color:var(--warn)}
.ped-chip.done{background:var(--brand-soft);color:var(--brandDk);text-decoration:line-through;opacity:.75}
[data-theme="dark"] .ped-chip{color:#e6b23e}

/* ===================== Telas de autenticação (SaaS) ===================== */
/* ===== LOGIN — imersivo / futurista ===== */
.authwrap{position:fixed;inset:0;z-index:60;display:grid;grid-template-columns:1.15fr .85fr;
  background:#070b09;overflow:hidden;color:#fff}
/* painel visual (esquerda) */
.auth-visual{position:relative;overflow:hidden;display:flex;align-items:flex-end;padding:52px;perspective:1200px;perspective-origin:50% 40%}
.auth-slides,.auth-slides .slide{position:absolute;inset:0}
.auth-slides .slide{background-size:cover;background-position:center;opacity:0;animation:authslide 21s infinite}
.auth-slides .s1{background:linear-gradient(135deg,#0a3a25,#06140e)}
.auth-slides .s2{animation-delay:7s;background:linear-gradient(135deg,#063a33,#08160f)}
.auth-slides .s3{animation-delay:14s;background:linear-gradient(135deg,#0d3a1c,#05120c)}
@keyframes authslide{0%{opacity:0}4%{opacity:1}29%{opacity:1}33%,100%{opacity:0}}
.auth-visual::after{content:"";position:absolute;inset:0;pointer-events:none;z-index:2;
  background:linear-gradient(115deg,rgba(7,11,9,.80),rgba(6,22,15,.50) 55%,rgba(7,11,9,.88)),
    radial-gradient(720px 380px at 18% 16%,rgba(19,224,138,.20),transparent 70%)}
.auth-grid{position:absolute;inset:0;z-index:1;opacity:.16;animation:authgrid 22s linear infinite;
  background-image:linear-gradient(rgba(19,224,138,.6) 1px,transparent 1px),linear-gradient(90deg,rgba(19,224,138,.6) 1px,transparent 1px);
  background-size:46px 46px;-webkit-mask-image:radial-gradient(circle at 28% 42%,#000,transparent 72%);mask-image:radial-gradient(circle at 28% 42%,#000,transparent 72%)}
@keyframes authgrid{to{background-position:46px 46px}}
.auth-orb{position:absolute;border-radius:50%;filter:blur(60px);opacity:.55;z-index:1;animation:authfloat 16s ease-in-out infinite}
.auth-orb.o1{width:340px;height:340px;left:-60px;top:6%;background:radial-gradient(circle,rgba(19,224,138,.6),transparent 65%)}
.auth-orb.o2{width:260px;height:260px;right:5%;bottom:-50px;background:radial-gradient(circle,rgba(0,132,61,.75),transparent 65%);animation-delay:5s}
@keyframes authfloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-26px)}}
/* piso 3D em perspectiva + globo de nós (login imersivo) */
.auth-scene{position:absolute;inset:0;z-index:1;transform-style:preserve-3d;transform:rotateX(calc(var(--my,0)*-2deg)) rotateY(calc(var(--mx,0)*4deg));transition:transform .25s cubic-bezier(.2,.7,.2,1)}
.auth-floor{position:absolute;left:-50%;right:-50%;bottom:-6%;height:120%;transform:rotateX(75deg);transform-origin:bottom center;background:linear-gradient(rgba(19,224,138,.11) 1.2px,transparent 1.2px) 0 0/100% 48px,linear-gradient(90deg,rgba(19,224,138,.11) 1.2px,transparent 1.2px) 0 0/48px 100%;-webkit-mask-image:linear-gradient(to top,#000 2%,rgba(0,0,0,.5) 26%,transparent 64%);mask-image:linear-gradient(to top,#000 2%,rgba(0,0,0,.5) 26%,transparent 64%);animation:authFloor 7s linear infinite}
@keyframes authFloor{to{background-position:0 48px,0 0}}
.auth-horizon{position:absolute;left:0;right:0;top:40%;height:1px;background:linear-gradient(90deg,transparent,rgba(19,224,138,.7),transparent);box-shadow:0 0 24px 4px rgba(19,224,138,.35);opacity:.7}
#authNet{position:absolute;inset:0;width:100%;height:100%;z-index:3}
@media(prefers-reduced-motion:reduce){.auth-floor{animation:none}.auth-scene{transition:none}}
.auth-visual-in{position:relative;z-index:4;max-width:470px}
.auth-visual-in h1{font-size:36px;line-height:1.12;font-weight:800;letter-spacing:-.025em;margin:20px 0 24px}
.auth-feats{list-style:none;padding:0;margin:0;display:grid;gap:11px}
.auth-feats li{display:flex;align-items:center;gap:10px;color:#c4ecd7;font-size:15px}
.auth-feats li::before{content:"";width:8px;height:8px;border-radius:2px;background:var(--ai);box-shadow:0 0 12px var(--ai);flex:none}
/* logo wordmark — SEM quadrado */
.logo-fai{display:inline-flex;align-items:center;gap:9px;font-weight:800;letter-spacing:-.04em;color:#fff;font-size:27px}
.logo-fai::before{content:"";width:0;height:0;border-left:10px solid var(--ai);border-top:7px solid transparent;border-bottom:7px solid transparent;filter:drop-shadow(0 0 8px rgba(19,224,138,.85))}
.logo-fai.lg{font-size:34px}
/* painel do form (direita) */
.auth-panel{position:relative;display:grid;place-items:center;padding:30px;border-left:1px solid rgba(19,224,138,.14);
  background:linear-gradient(180deg,rgba(10,16,13,.72),rgba(7,11,9,.94))}
.auth-form{width:100%;max-width:340px}
.auth-form h2{font-size:24px;font-weight:800;letter-spacing:-.02em;margin:22px 0 3px}
.auth-form .muted{color:#8fa89b;font-size:13.5px;margin:0 0 18px}
.auth-form label{color:#b9cfc4;font-size:12px;display:block;margin-bottom:5px}
.auth-form .field{margin:14px 0}
.auth-form input{width:100%;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.14);color:#fff;border-radius:12px;padding:13px;font-size:15px}
.auth-form input::placeholder{color:rgba(120,140,130,.6)}
.auth-form input:focus{outline:none;border-color:var(--ai);box-shadow:0 0 0 3px rgba(19,224,138,.18)}
.auth-form .btn.primary{width:100%;margin-top:8px;background:linear-gradient(135deg,var(--brand),var(--ai));border:0;color:#04130c;font-weight:800;padding:13px;box-shadow:0 8px 26px rgba(19,224,138,.34)}
.auth-note{color:#7e948a;font-size:12px;text-align:center;margin-top:16px}
.ai-neon{color:var(--ai);text-shadow:0 0 22px rgba(19,224,138,.7)}
@media(max-width:860px){
  .authwrap{grid-template-columns:1fr}
  .auth-visual{display:none}
  .auth-panel{border:0;background:radial-gradient(900px 480px at 50% -10%,#0f4329,#070b09 60%)}
}
