/* ═══════════════════════════════════════════════════════════════════════════
   BenSeg — Design System (mock dos sonhos)
   Identidade BenDash: cósmico roxo/azul · wordmark prata · command-center.
   Camada funcional de segurança: armado/atenção/alarme/info.
   ═══════════════════════════════════════════════════════════════════════════ */
:root{
  --bg-primary:#080719; --bg-secondary:#0C0C16; --panel:#12101F; --panel-2:#17142A;
  --panel-shadow:#1E1556; --border:#2A2342; --border-soft:#211b36;
  --purple-strong:#5C24F6; --purple:#9135F9; --purple-light:#A74FF5; --purple-hi:#CB5EF9;
  --blue-mid:#2A51F4; --blue:#1E50F3; --blue-electric:#192AE9;
  --silver-dark:#9B9CAA; --silver-mid:#CFCBDB; --silver-light:#EAD3FB;
  --text:#F3F0FB; --text-soft:#A9A4C2; --text-dim:#6E6890;
  --armed:#22C77E; --armed-glow:#33E08E; --warn:#F5A524; --alarm:#FF3B57; --info:#2BD9D9;
  --grad-symbol:linear-gradient(180deg,#CB5EF9 0%,#9135F9 22%,#5C24F6 45%,#2A51F4 72%,#192AE9 100%);
  --grad-seg:linear-gradient(135deg,#A74FF5 0%,#9135F9 30%,#5C24F6 55%,#2A51F4 80%,#1E50F3 100%);
  --grad-ben:linear-gradient(180deg,#EAD3FB 0%,#CFCBDB 18%,#B3A8D1 35%,#9B9CAA 65%,#7C7D8E 100%);
  --grad-hero:linear-gradient(135deg,#080719 0%,#1E1556 42%,#5C24F6 72%,#2A51F4 100%);
  --radius:16px; --radius-sm:11px; --shadow-glow:0 0 40px rgba(145,53,249,.28);
  --shadow-card:0 14px 34px -12px rgba(0,0,0,.6);
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  font-family:'Inter',system-ui,sans-serif; background:var(--bg-primary); color:var(--text);
  -webkit-font-smoothing:antialiased; font-feature-settings:"cv11","ss01";
  background-image:radial-gradient(1200px 600px at 78% -10%,rgba(92,36,246,.18),transparent 60%),radial-gradient(900px 500px at -5% 110%,rgba(30,80,243,.14),transparent 60%);
  overflow:hidden;
}
.mono{font-family:'JetBrains Mono',monospace}
.hidden{display:none!important}

/* ═══════════════ Login ═══════════════ */
.login{position:fixed;inset:0;z-index:100;display:grid;grid-template-columns:1.1fr .9fr;background:var(--bg-primary)}
.login .pane-art{position:relative;overflow:hidden;background:var(--grad-hero);display:flex;flex-direction:column;justify-content:space-between;padding:46px}
.login .pane-art::before{content:"";position:absolute;inset:0;background-image:radial-gradient(760px 460px at 36% 44%,rgba(203,94,249,.30),transparent 60%),radial-gradient(600px 500px at 90% 90%,rgba(30,80,243,.35),transparent 55%)}
.login .pane-art::after{content:"";position:absolute;inset:0;background-image:repeating-linear-gradient(0deg,transparent 0 38px,rgba(255,255,255,.025) 39px),repeating-linear-gradient(90deg,transparent 0 38px,rgba(255,255,255,.025) 39px);mask-image:linear-gradient(180deg,transparent,#000 40%,#000 70%,transparent)}
.login .art-top,.login .art-bot{position:relative;z-index:2}
.login .art-quote{font-size:30px;font-weight:800;line-height:1.18;letter-spacing:-.6px;max-width:13ch}
.login .art-quote .hl{background:linear-gradient(135deg,#EAD3FB,#CB5EF9);-webkit-background-clip:text;background-clip:text;color:transparent}
.login .art-sub{margin-top:16px;font-size:14px;color:rgba(243,240,251,.78);max-width:42ch;line-height:1.55}
.login .art-stats{display:flex;gap:30px;margin-top:30px}
.login .art-stats .n{font-size:26px;font-weight:800;font-variant-numeric:tabular-nums}
.login .art-stats .l{font-size:11.5px;color:rgba(243,240,251,.65);margin-top:2px}
.login .pane-form{display:grid;place-items:center;padding:40px}
.login .form-inner{width:100%;max-width:340px}
.login .form-inner h2{font-size:23px;font-weight:800;letter-spacing:-.4px}
.login .form-inner .lead{font-size:13px;color:var(--text-soft);margin:6px 0 26px}
.field{margin-bottom:14px}
.field label{display:block;font-size:11.5px;font-weight:600;color:var(--text-soft);margin-bottom:6px;letter-spacing:.2px}
.field input{width:100%;background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:11px;padding:12px 14px;color:var(--text);font-size:13.5px;font-family:inherit;transition:border .18s,box-shadow .18s}
.field input:focus{outline:none;border-color:var(--purple-light);box-shadow:0 0 0 3px rgba(167,79,245,.18)}
.login .form-foot{margin-top:22px;font-size:11px;color:var(--text-dim);text-align:center;line-height:1.6}

/* ═══════════════ App shell ═══════════════ */
.app{display:grid;grid-template-columns:248px 1fr;height:100vh}
.sidebar{background:linear-gradient(180deg,#070512 0%,#0A0820 100%);border-right:1px solid var(--border-soft);display:flex;flex-direction:column;padding:18px 14px;gap:4px;overflow-y:auto}
.sidebar::-webkit-scrollbar{width:0}
.brand{display:flex;align-items:center;gap:11px;padding:6px 8px 16px}
.brand .mark{filter:drop-shadow(0 0 10px rgba(167,79,245,.55))}
.login .brand .mark{filter:drop-shadow(0 0 11px rgba(167,79,245,.5)) drop-shadow(0 2px 4px rgba(0,0,0,.55))}
.brand .wm{font-weight:800;font-size:21px;letter-spacing:-.5px;line-height:1}
.brand .wm .ben{background:var(--grad-ben);-webkit-background-clip:text;background-clip:text;color:transparent}
.brand .wm .seg{background:var(--grad-seg);-webkit-background-clip:text;background-clip:text;color:transparent}
.brand .sub{font-size:8.5px;letter-spacing:3px;color:var(--purple-light);opacity:.85;font-weight:600;margin-top:3px}
.navlabel{font-size:10px;letter-spacing:1.5px;color:var(--text-dim);text-transform:uppercase;font-weight:600;padding:14px 10px 6px}
.nav{display:flex;align-items:center;gap:11px;padding:9px 11px;border-radius:11px;color:var(--text-soft);font-size:13.5px;font-weight:500;cursor:pointer;transition:all .18s;border:1px solid transparent}
.nav svg{width:17px;height:17px;flex-shrink:0;opacity:.85}
.nav:hover{background:rgba(145,53,249,.10);color:var(--text)}
.nav.active{background:linear-gradient(135deg,rgba(145,53,249,.22),rgba(30,80,243,.14));color:#fff;border-color:rgba(167,79,245,.35);box-shadow:inset 0 0 0 1px rgba(167,79,245,.12)}
.nav.active svg{opacity:1}
.nav .badge{margin-left:auto;font-size:10.5px;font-weight:700;background:var(--alarm);color:#fff;padding:1px 7px;border-radius:20px}
.nav .badge.amber{background:var(--warn);color:#1a1205}
.nav .badge.info{background:var(--info);color:#04201f}
.userbox{margin-top:auto;display:flex;align-items:center;gap:10px;padding:10px;border-radius:12px;background:rgba(255,255,255,.03);border:1px solid var(--border-soft)}
.avatar{width:34px;height:34px;border-radius:10px;background:var(--grad-seg);display:grid;place-items:center;font-weight:700;font-size:13px;color:#fff;flex-shrink:0}
.userbox .nm{font-size:12.5px;font-weight:600}.userbox .rl{font-size:10.5px;color:var(--text-dim)}

/* ═══════════════ Main / topbar ═══════════════ */
.main{overflow-y:auto;padding:0}
.topbar{position:sticky;top:0;z-index:20;display:flex;align-items:center;gap:16px;padding:16px 26px;background:rgba(8,7,25,.78);backdrop-filter:blur(14px);border-bottom:1px solid var(--border-soft)}
.topbar h1{font-size:19px;font-weight:700;letter-spacing:-.3px}
.topbar .crumb{font-size:11.5px;color:var(--text-dim);margin-top:2px}
.tenant{display:flex;align-items:center;gap:8px;margin-left:auto;background:rgba(255,255,255,.04);border:1px solid var(--border);padding:7px 13px;border-radius:11px;font-size:12.5px;font-weight:600;cursor:pointer}
.tenant .dot{width:7px;height:7px;border-radius:50%;background:var(--armed);box-shadow:0 0 8px var(--armed-glow)}
.sys{display:flex;align-items:center;gap:7px;font-size:12px;color:var(--armed);font-weight:600}
.iconbtn{width:38px;height:38px;border-radius:11px;border:1px solid var(--border);background:rgba(255,255,255,.03);display:grid;place-items:center;cursor:pointer;position:relative;color:var(--text-soft)}
.iconbtn:hover{color:#fff;border-color:rgba(167,79,245,.4)}
.iconbtn .pip{position:absolute;top:8px;right:9px;width:7px;height:7px;border-radius:50%;background:var(--alarm)}
.content{padding:24px 26px 48px;animation:fade .35s ease}
@keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

/* ═══════════════ Primitives ═══════════════ */
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:22px}
.kpi{background:linear-gradient(135deg,var(--panel),var(--panel-2));border:1px solid var(--border);border-radius:var(--radius);padding:18px;position:relative;overflow:hidden;transition:transform .2s,box-shadow .2s}
.kpi:hover{transform:translateY(-3px);box-shadow:var(--shadow-card)}
.kpi .lbl{font-size:11px;letter-spacing:.6px;text-transform:uppercase;color:var(--text-dim);font-weight:600;display:flex;align-items:center;gap:7px}
.kpi .val{font-size:31px;font-weight:800;margin:9px 0 3px;font-variant-numeric:tabular-nums;letter-spacing:-1px}
.kpi .chg{font-size:11.5px;font-weight:600}
.kpi .ring{position:absolute;right:-22px;top:-22px;width:92px;height:92px;border-radius:50%;opacity:.16;filter:blur(6px)}
.pulse-dot{width:8px;height:8px;border-radius:50%;display:inline-block;animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.45}}
.grid2{display:grid;grid-template-columns:1.35fr 1fr;gap:16px;margin-bottom:16px}
.grid2b{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:16px}
.card{background:linear-gradient(135deg,var(--panel),var(--panel-2));border:1px solid var(--border);border-radius:var(--radius);padding:18px}
.card.flush{padding:0;overflow:hidden}
.card h3{font-size:14px;font-weight:700;display:flex;align-items:center;gap:9px;margin-bottom:3px}
.card .ch-sub{font-size:11.5px;color:var(--text-dim);margin-bottom:14px}
.chead{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;gap:12px}
.chead .right{font-size:11px;color:var(--purple-light);font-weight:600;cursor:pointer}
.sectitle{font-size:12px;letter-spacing:1px;text-transform:uppercase;color:var(--text-dim);font-weight:700;margin:6px 0 12px}
.btn{font-family:inherit;font-size:12.5px;font-weight:700;padding:9px 15px;border-radius:11px;border:none;cursor:pointer;background:var(--grad-seg);color:#fff;box-shadow:var(--shadow-glow);transition:transform .15s,filter .15s;display:inline-flex;align-items:center;gap:8px}
.btn:hover{transform:translateY(-2px);filter:brightness(1.08)}
.btn:disabled{opacity:.45;cursor:not-allowed;filter:grayscale(.4);box-shadow:none;transform:none}
.btn.ghost{background:rgba(255,255,255,.04);border:1px solid var(--border);color:var(--text);box-shadow:none}
.btn.sm{padding:6px 11px;font-size:11.5px}
.btn.armed{background:linear-gradient(135deg,#1f8f5e,#22C77E);box-shadow:0 0 30px rgba(34,199,126,.35)}
.note{margin-bottom:22px;background:linear-gradient(135deg,rgba(145,53,249,.10),rgba(30,80,243,.06));border:1px solid rgba(167,79,245,.25);border-radius:14px;padding:13px 16px;font-size:12px;color:var(--text-soft);display:flex;gap:11px;align-items:center}
.note b{color:var(--text)}
.main::-webkit-scrollbar{width:9px}.main::-webkit-scrollbar-thumb{background:rgba(145,53,249,.3);border-radius:5px}

/* pills / tags */
.pill{font-size:10.5px;font-weight:700;padding:3px 9px;border-radius:20px;display:inline-flex;align-items:center;gap:5px}
.pill.exec{background:rgba(43,217,217,.14);color:var(--info)}
.pill.wait{background:rgba(245,165,36,.14);color:var(--warn)}
.pill.done{background:rgba(34,199,126,.14);color:var(--armed)}
.pill.crit{background:rgba(255,59,87,.14);color:var(--alarm)}
.pill.purple{background:rgba(167,79,245,.16);color:var(--purple-light)}
.pill.muted{background:rgba(255,255,255,.05);color:var(--text-soft)}

/* tables */
table{width:100%;border-collapse:collapse}
th{text-align:left;font-size:10px;letter-spacing:.6px;text-transform:uppercase;color:var(--text-dim);font-weight:600;padding:0 8px 10px}
td{padding:11px 8px;border-top:1px solid var(--border-soft);font-size:12.5px;vertical-align:middle}
tr.clickrow{cursor:pointer;transition:background .14s}
tr.clickrow:hover td{background:rgba(255,255,255,.025)}

/* live feed / events */
.ev{display:flex;gap:12px;padding:11px;border-radius:11px;transition:background .15s;align-items:flex-start}
.ev:hover{background:rgba(255,255,255,.03)}
.ev .ic{width:30px;height:30px;border-radius:9px;display:grid;place-items:center;flex-shrink:0}
.ev .t{font-size:13px;font-weight:600}.ev .d{font-size:11.5px;color:var(--text-soft);margin-top:2px}
.ev .time{margin-left:auto;font-size:10.5px;color:var(--text-dim);font-family:'JetBrains Mono',monospace;white-space:nowrap}
.ev.new{animation:flash 1.4s ease}
@keyframes flash{0%{background:rgba(255,59,87,.22)}100%{background:transparent}}

/* AI chat */
.chat{display:flex;flex-direction:column;gap:11px}
.msg{max-width:86%;padding:10px 13px;border-radius:13px;font-size:12.8px;line-height:1.5}
.msg.in{align-self:flex-start;background:rgba(255,255,255,.05);border:1px solid var(--border);border-bottom-left-radius:4px}
.msg.bot{align-self:flex-end;background:linear-gradient(135deg,rgba(145,53,249,.30),rgba(30,80,243,.22));border:1px solid rgba(167,79,245,.35);border-bottom-right-radius:4px}
.msg .who{font-size:10px;letter-spacing:.5px;text-transform:uppercase;color:var(--text-dim);font-weight:700;margin-bottom:4px}
.photo-chip{display:inline-flex;align-items:center;gap:6px;margin-top:7px;background:rgba(0,0,0,.3);border:1px solid var(--border);padding:5px 9px;border-radius:8px;font-size:11px;color:var(--text-soft)}
.os-made{margin-top:5px;align-self:stretch;background:rgba(34,199,126,.10);border:1px solid rgba(34,199,126,.35);border-radius:11px;padding:11px 13px;display:flex;align-items:center;gap:11px}
.os-made.info{background:rgba(43,217,217,.10);border-color:rgba(43,217,217,.35)}
.os-made .tag{font-size:10px;font-weight:700;color:var(--armed);letter-spacing:.5px}
.os-made.info .tag{color:var(--info)}
.typing{align-self:flex-end;display:flex;gap:4px;padding:11px 14px;background:rgba(145,53,249,.16);border-radius:13px;border:1px solid rgba(167,79,245,.3)}
.typing span{width:6px;height:6px;border-radius:50%;background:var(--purple-light);animation:bob 1s infinite}
.typing span:nth-child(2){animation-delay:.15s}.typing span:nth-child(3){animation-delay:.3s}
@keyframes bob{0%,60%,100%{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-4px)}}
.composer{display:flex;gap:9px;margin-top:14px;padding-top:14px;border-top:1px solid var(--border-soft)}
.composer input{flex:1;background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:11px;padding:10px 13px;color:var(--text);font-size:13px;font-family:inherit}
.composer input:focus{outline:none;border-color:var(--purple-light)}

/* camera grid */
.cams{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.cam{aspect-ratio:16/10;border-radius:12px;background:linear-gradient(135deg,#0a0a16,#141228);border:1px solid var(--border);position:relative;overflow:hidden;display:grid;place-items:center}
.cam .scan{position:absolute;inset:0;background:repeating-linear-gradient(0deg,transparent,transparent 3px,rgba(167,79,245,.04) 4px)}
.cam .live{position:absolute;top:8px;left:8px;font-size:9px;font-weight:800;letter-spacing:1px;color:#fff;background:rgba(255,59,87,.85);padding:2px 7px;border-radius:5px;display:flex;align-items:center;gap:5px}
.cam .live .bl{width:5px;height:5px;border-radius:50%;background:#fff;animation:blink 1.1s infinite}
@keyframes blink{50%{opacity:.2}}
.cam .nm{position:absolute;bottom:8px;left:8px;font-size:10px;color:var(--text-soft);font-family:'JetBrains Mono',monospace}
.cam svg{width:34px;height:34px;opacity:.22}

/* pipeline (mini) */
.pipe{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.stage{background:rgba(255,255,255,.025);border:1px solid var(--border-soft);border-radius:12px;padding:12px}
.stage .sname{font-size:11px;color:var(--text-soft);font-weight:600;display:flex;justify-content:space-between}
.stage .scount{font-size:23px;font-weight:800;margin-top:6px;font-variant-numeric:tabular-nums}
.stage .bar{height:3px;border-radius:3px;margin-top:9px;background:var(--grad-seg)}

/* ═══════════════ CRM kanban ═══════════════ */
.kanban{display:grid;grid-template-columns:repeat(5,1fr);gap:13px;align-items:start;overflow-x:auto;padding-bottom:6px}
.col{background:rgba(255,255,255,.02);border:1px solid var(--border-soft);border-radius:14px;padding:11px;min-width:0}
.col-h{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;font-size:12px;font-weight:700}
.col-h .cnt{font-size:11px;color:var(--text-dim);background:rgba(255,255,255,.05);padding:1px 8px;border-radius:20px}
.col-h .dotline{width:100%;height:3px;border-radius:3px;margin-top:8px}
.lead{background:linear-gradient(135deg,var(--panel),var(--panel-2));border:1px solid var(--border);border-radius:12px;padding:12px;margin-bottom:9px;cursor:pointer;transition:transform .15s,border .15s}
.lead:hover{transform:translateY(-2px);border-color:rgba(167,79,245,.4)}
.lead .lname{font-size:13px;font-weight:700;letter-spacing:-.2px}
.lead .lmeta{font-size:11px;color:var(--text-soft);margin-top:3px;display:flex;align-items:center;gap:6px}
.lead .lfoot{display:flex;align-items:center;justify-content:space-between;margin-top:10px}
.lead .lval{font-size:12.5px;font-weight:700;font-variant-numeric:tabular-nums}
.score{font-size:10px;font-weight:800;padding:2px 8px;border-radius:20px;display:inline-flex;align-items:center;gap:4px}
.score.hot{background:rgba(255,59,87,.16);color:#ff7088}
.score.warm{background:rgba(245,165,36,.16);color:var(--warn)}
.score.cold{background:rgba(155,156,170,.14);color:var(--silver-dark)}
.assignee{width:24px;height:24px;border-radius:7px;background:var(--grad-seg);display:grid;place-items:center;font-size:10px;font-weight:700;color:#fff}

/* round-robin badge */
.rr{display:inline-flex;align-items:center;gap:7px;font-size:11px;color:var(--purple-light);font-weight:600;background:rgba(167,79,245,.10);border:1px solid rgba(167,79,245,.25);padding:5px 10px;border-radius:20px}

/* ═══════════════ Progress / rings / gauges ═══════════════ */
.ring-prog{--p:0;--c:var(--purple);width:118px;height:118px;border-radius:50%;display:grid;place-items:center;background:conic-gradient(var(--c) calc(var(--p)*1%),rgba(255,255,255,.06) 0);position:relative}
.ring-prog::before{content:"";position:absolute;inset:9px;border-radius:50%;background:var(--panel)}
.ring-prog .pv{position:relative;z-index:2;font-size:26px;font-weight:800;font-variant-numeric:tabular-nums}
.ring-prog .pl{position:relative;z-index:2;font-size:10px;color:var(--text-dim);margin-top:1px}
.bars{display:flex;flex-direction:column;gap:13px}
.barrow .bl{display:flex;justify-content:space-between;font-size:12px;font-weight:600;margin-bottom:6px}
.barrow .bl .pct{font-variant-numeric:tabular-nums;color:var(--text-soft)}
.track{height:8px;border-radius:8px;background:rgba(255,255,255,.06);overflow:hidden}
.track .fill{height:100%;border-radius:8px;background:var(--grad-seg);transition:width .8s cubic-bezier(.3,1,.4,1)}
.track .fill.armed{background:linear-gradient(135deg,#1f8f5e,#33E08E)}
.track .fill.warn{background:linear-gradient(135deg,#b9791a,#F5A524)}
.track .fill.alarm{background:linear-gradient(135deg,#b32437,#FF3B57)}

/* checklist */
.checklist{display:flex;flex-direction:column;gap:8px}
.cl-item{display:flex;align-items:center;gap:12px;padding:12px;border-radius:11px;background:rgba(255,255,255,.02);border:1px solid var(--border-soft)}
.cl-item .ck{width:24px;height:24px;border-radius:7px;display:grid;place-items:center;flex-shrink:0;border:1.5px solid var(--border)}
.cl-item.ok .ck{background:rgba(34,199,126,.18);border-color:var(--armed);color:var(--armed)}
.cl-item.warn .ck{background:rgba(245,165,36,.18);border-color:var(--warn);color:var(--warn)}
.cl-item.bad .ck{background:rgba(255,59,87,.18);border-color:var(--alarm);color:var(--alarm)}
.cl-item .tx{font-size:13px;font-weight:600}
.cl-item .sx{font-size:11px;color:var(--text-dim);margin-top:1px}
.cl-item .meta{margin-left:auto;font-size:10.5px;color:var(--text-dim);font-family:'JetBrains Mono',monospace}

/* gate */
.gate{background:linear-gradient(135deg,rgba(34,199,126,.08),rgba(30,80,243,.05));border:1px solid rgba(34,199,126,.3);border-radius:var(--radius);padding:20px;display:flex;align-items:center;gap:18px}
.gate.locked{background:linear-gradient(135deg,rgba(245,165,36,.08),rgba(255,59,87,.05));border-color:rgba(245,165,36,.3)}
.gate .glabel{font-size:13px;font-weight:700}
.gate .gsub{font-size:11.5px;color:var(--text-soft);margin-top:3px;max-width:50ch}

/* score gauge (risco) */
.gauge{position:relative;width:170px;height:96px;margin:6px auto 0;overflow:hidden}
.gauge .semi{width:170px;height:170px;border-radius:50%;background:conic-gradient(from -90deg,var(--armed) 0 33%,var(--warn) 33% 66%,var(--alarm) 66% 100%);mask:radial-gradient(circle at 50% 100%,transparent 56px,#000 57px);-webkit-mask:radial-gradient(circle at 50% 100%,transparent 56px,#000 57px)}
.gauge .needle{position:absolute;bottom:0;left:50%;width:3px;height:78px;background:var(--text);transform-origin:bottom center;border-radius:3px;transition:transform 1s cubic-bezier(.3,1,.4,1)}
.gauge .hub{position:absolute;bottom:-5px;left:50%;width:14px;height:14px;border-radius:50%;background:var(--text);transform:translateX(-50%)}
.gauge-val{text-align:center;margin-top:8px;font-size:22px;font-weight:800}

/* phone (app do morador teaser) */
.phone{width:280px;border-radius:38px;border:9px solid #1a1730;background:#05040f;box-shadow:0 30px 70px -20px rgba(0,0,0,.7),0 0 60px rgba(145,53,249,.2);overflow:hidden;position:relative}
.phone .notch{position:absolute;top:0;left:50%;transform:translateX(-50%);width:120px;height:22px;background:#1a1730;border-radius:0 0 14px 14px;z-index:5}
.phone .pscreen{height:560px;overflow-y:auto;background:var(--bg-primary);background-image:radial-gradient(500px 300px at 80% -10%,rgba(92,36,246,.25),transparent 60%)}
.phone .pscreen::-webkit-scrollbar{width:0}
.phone .ptop{padding:30px 18px 14px;display:flex;align-items:center;justify-content:space-between}
.phone .ptop .hi{font-size:12px;color:var(--text-soft)}.phone .ptop .nm{font-size:16px;font-weight:800}
.phone .pstatus{margin:0 18px;border-radius:16px;padding:16px;background:linear-gradient(135deg,rgba(34,199,126,.16),rgba(30,80,243,.10));border:1px solid rgba(34,199,126,.3);text-align:center}
.phone .pstatus .big{font-size:18px;font-weight:800;color:var(--armed);display:flex;align-items:center;justify-content:center;gap:8px}
.phone .pstatus .sm{font-size:11px;color:var(--text-soft);margin-top:3px}
.phone .pactions{display:grid;grid-template-columns:1fr 1fr;gap:10px;padding:16px 18px}
.phone .pact{background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:14px;padding:14px 12px;text-align:center;font-size:11.5px;font-weight:600}
.phone .pact svg{width:22px;height:22px;margin-bottom:7px;color:var(--purple-light)}
.phone .pfeed{padding:4px 18px 24px}
.phone .pfeed .fi{display:flex;gap:10px;padding:10px 0;border-top:1px solid var(--border-soft);font-size:11.5px}
.phone .pfeed .fi .fic{width:30px;height:30px;border-radius:9px;display:grid;place-items:center;flex-shrink:0}

/* misc */
.split{display:grid;grid-template-columns:1.2fr 1fr;gap:20px;align-items:center}
.feature-list{display:flex;flex-direction:column;gap:13px}
.feature-list .fl{display:flex;gap:13px;align-items:flex-start}
.feature-list .fl .fi{width:36px;height:36px;border-radius:11px;background:rgba(167,79,245,.12);border:1px solid rgba(167,79,245,.25);display:grid;place-items:center;flex-shrink:0;color:var(--purple-light)}
.feature-list .fl .ft{font-size:13.5px;font-weight:700}
.feature-list .fl .fd{font-size:12px;color:var(--text-soft);margin-top:2px;line-height:1.5}
.tag-ai{font-size:9.5px;font-weight:800;letter-spacing:.5px;color:var(--purple-hi);background:rgba(203,94,249,.14);border:1px solid rgba(203,94,249,.3);padding:2px 7px;border-radius:6px}

/* ── icon sizing (helper SVGs sem width/height próprios) ── */
/* rede de segurança: qualquer SVG sem atributo width ganha um tamanho sensato.
   :where() = especificidade 0, então qualquer regra de classe/pai abaixo vence. */
svg:where(:not([width])){width:18px;height:18px}
:not(button)[style*="width:"]>svg{width:100%;height:100%}
.btn svg{width:16px;height:16px}
.feature-list .fi svg{width:19px;height:19px}
.cl-item .ck svg{width:14px;height:14px}
.phone .pfeed .fic svg{width:14px;height:14px}
.iconbtn svg{width:18px;height:18px}
#gateIcon svg{width:22px;height:22px}
svg{flex-shrink:0}

/* ═══════════════ Monitoramento (central de alarmes) ═══════════════ */
.alarmq{display:flex;flex-direction:column;gap:9px}
.aq{display:flex;align-items:center;gap:12px;padding:11px 12px;border-radius:12px;background:rgba(255,255,255,.02);border:1px solid var(--border-soft);transition:background .15s}
.aq:hover{background:rgba(255,255,255,.04)}
.aq.crit{background:rgba(255,59,87,.07);border-color:rgba(255,59,87,.3)}
.aq-ic{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;flex-shrink:0}
.aq-ic svg{width:16px;height:16px}
.aq-main{flex:1;min-width:0}
.aq-t{font-size:13px;font-weight:700}.aq-d{font-size:11px;color:var(--text-soft);margin-top:2px}
.aq-timer{font-size:13px;font-weight:700;font-variant-numeric:tabular-nums;min-width:42px;text-align:right}
.mosaic{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.opsmap{position:relative;height:262px;border-radius:14px;overflow:hidden;background:radial-gradient(120% 120% at 30% 18%,#15122a,#0a0a16);border:1px solid var(--border)}
.opsmap-grid{position:absolute;inset:0;width:100%;height:100%;opacity:.9}
.pin{position:absolute;width:12px;height:12px;border-radius:50%;transform:translate(-50%,-50%);box-shadow:0 0 0 4px rgba(255,255,255,.04)}
.pin::after{content:"";position:absolute;inset:-6px;border-radius:50%;border:1.5px solid currentColor;opacity:.5;animation:ping 2.6s infinite}
.pin.armed{background:var(--armed);color:var(--armed)}
.pin.alarm{background:var(--alarm);color:var(--alarm);animation:pulse 1.2s infinite}
.pin.warn{background:var(--warn);color:var(--warn)}
.pin.info{background:var(--info);color:var(--info)}
@keyframes ping{0%{transform:scale(.5);opacity:.7}100%{transform:scale(1.7);opacity:0}}
.maplegend{display:flex;flex-wrap:wrap;gap:16px;margin-top:12px;font-size:11px;color:var(--text-soft)}
.maplegend span{display:flex;align-items:center;gap:6px}
.maplegend i{width:9px;height:9px;border-radius:50%;display:inline-block}

/* ═══════════════ Financeiro / BI — gráficos ═══════════════ */
.barchart{display:flex;align-items:flex-end;gap:12px;height:204px;padding-top:24px}
.bc{flex:1;display:flex;flex-direction:column;align-items:center;height:100%;justify-content:flex-end;gap:8px}
.bc-bar{width:100%;max-width:46px;border-radius:8px 8px 3px 3px;background:linear-gradient(180deg,var(--purple-hi),var(--purple-strong) 58%,var(--blue));position:relative;transition:height .9s cubic-bezier(.3,1,.4,1);min-height:6px}
.bc-bar .bc-val{position:absolute;top:-20px;left:50%;transform:translateX(-50%);font-size:11px;font-weight:700;color:var(--text-soft);white-space:nowrap}
.bc-lbl{font-size:11px;color:var(--text-dim);font-weight:600}
.areachart{height:190px;margin-top:8px;border-radius:12px;background:linear-gradient(180deg,rgba(167,79,245,.05),transparent);overflow:hidden}
.donutwrap{display:flex;align-items:center;gap:22px;padding:6px 0}
.donut{width:150px;height:150px;border-radius:50%;position:relative;flex-shrink:0}
.donut-h{position:absolute;inset:26px;border-radius:50%;background:var(--panel);display:grid;place-items:center;text-align:center}
.donut .dv{font-size:18px;font-weight:800}.donut .dl{font-size:10px;color:var(--text-dim);letter-spacing:1px}
.legend{display:flex;flex-direction:column;gap:9px;font-size:12px;color:var(--text-soft);min-width:190px}
.legend>div{display:flex;align-items:center;gap:8px}
.legend .lg{width:11px;height:11px;border-radius:3px;display:inline-block;flex-shrink:0}
.legend b{color:var(--text);margin-left:auto;font-variant-numeric:tabular-nums}

/* ═══════════════ Régua de cobrança (timeline) ═══════════════ */
.timeline{display:flex;flex-direction:column}
.tl{display:grid;grid-template-columns:46px 22px 1fr;gap:10px;align-items:start}
.tl-day{font-size:11px;font-weight:700;color:var(--text-soft);padding-top:1px;text-align:right;font-family:'JetBrains Mono',monospace}
.tl-line{display:flex;justify-content:center;position:relative}
.tl-line span{width:12px;height:12px;border-radius:50%;margin-top:3px;z-index:2;box-shadow:0 0 0 4px rgba(255,255,255,.03)}
.tl:not(:last-child) .tl-line::after{content:"";position:absolute;top:13px;bottom:-8px;width:2px;background:var(--border);left:50%;transform:translateX(-50%)}
.tl-body{padding-bottom:16px}
.tl-t{font-size:13px;font-weight:700}.tl-d{font-size:11.5px;color:var(--text-soft);margin-top:2px}

/* ═══════════════ Modal de lançamento ═══════════════ */
.ovl{position:fixed;inset:0;z-index:200;display:flex;align-items:flex-start;justify-content:center;padding:48px 18px;overflow-y:auto;background:rgba(6,5,16,.66);backdrop-filter:blur(7px);animation:ovlIn .18s ease}
@keyframes ovlIn{from{opacity:0}to{opacity:1}}
.modal{width:100%;max-width:600px;background:linear-gradient(135deg,var(--panel),var(--panel-2));border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-card),var(--shadow-glow);overflow:hidden;animation:modalIn .22s cubic-bezier(.2,.8,.25,1)}
.modal.wide{max-width:720px}
@keyframes modalIn{from{opacity:0;transform:translateY(14px) scale(.985)}to{opacity:1;transform:none}}
.modal-h{display:flex;align-items:flex-start;gap:12px;padding:20px 22px 16px;border-bottom:1px solid var(--border-soft)}
.modal-h .mh-ic{width:40px;height:40px;border-radius:12px;display:grid;place-items:center;flex:none;background:rgba(145,53,249,.14);color:var(--purple-light)}
.modal-h .mh-ic svg{width:21px;height:21px}
.modal-h h3{font-size:16px;font-weight:800;letter-spacing:-.3px}
.modal-h .mh-sub{font-size:11.5px;color:var(--text-soft);margin-top:3px}
.modal-h .mh-x{margin-left:auto;width:32px;height:32px;border-radius:9px;border:1px solid var(--border);background:rgba(255,255,255,.03);color:var(--text-soft);display:grid;place-items:center;cursor:pointer;flex:none}
.modal-h .mh-x svg{width:16px;height:16px}
.modal-h .mh-x:hover{color:var(--text);border-color:var(--purple-light)}
.modal-b{padding:20px 22px;max-height:62vh;overflow-y:auto}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:0 16px}
.frow.f3{grid-template-columns:1.4fr .8fr .8fr}
.frow.f1{grid-template-columns:1fr}
.field select,.field textarea{width:100%;background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:11px;padding:12px 14px;color:var(--text);font-size:13.5px;font-family:inherit;transition:border .18s,box-shadow .18s}
.field select:focus,.field textarea:focus{outline:none;border-color:var(--purple-light);box-shadow:0 0 0 3px rgba(167,79,245,.18)}
.field textarea{resize:vertical;min-height:62px;line-height:1.5}
.field select option{background:var(--panel-2);color:var(--text)}
.lhead{display:flex;align-items:center;justify-content:space-between;margin:6px 0 8px}
.lhead .lh-t{font-size:11.5px;font-weight:700;color:var(--text-soft);letter-spacing:.3px;text-transform:uppercase}
.litem{display:grid;grid-template-columns:1fr 64px 96px 30px;gap:8px;align-items:center;margin-bottom:8px}
.litem input{background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:9px;padding:9px 11px;color:var(--text);font-size:12.5px;font-family:inherit}
.litem input:focus{outline:none;border-color:var(--purple-light)}
.litem .li-del{border:1px solid var(--border);background:rgba(255,255,255,.03);color:var(--text-dim);border-radius:8px;height:34px;cursor:pointer;display:grid;place-items:center}
.litem .li-del:hover{color:var(--alarm);border-color:var(--alarm)}
.litem .li-del svg{width:14px;height:14px}
.ltot{display:flex;align-items:center;justify-content:space-between;margin-top:6px;padding-top:12px;border-top:1px dashed var(--border);font-size:13px}
.ltot b{font-size:16px;font-weight:800;color:var(--armed);font-family:'JetBrains Mono',monospace}
.modal-f{display:flex;align-items:center;gap:10px;padding:16px 22px;border-top:1px solid var(--border-soft);background:rgba(0,0,0,.16)}
.modal-f .mf-note{font-size:11px;color:var(--text-dim);margin-right:auto;max-width:46ch;line-height:1.45}
.modal-f .mf-note b{color:var(--text-soft)}
.toast{position:fixed;bottom:26px;left:50%;transform:translate(-50%,140%);z-index:300;display:flex;align-items:center;gap:9px;background:linear-gradient(135deg,var(--panel-2),var(--panel));border:1px solid var(--border);border-left:3px solid var(--armed);border-radius:12px;padding:12px 18px;font-size:12.5px;font-weight:600;color:var(--text);box-shadow:var(--shadow-card);transition:transform .32s cubic-bezier(.2,.9,.3,1.2);max-width:90vw}
.toast.show{transform:translate(-50%,0)}

/* ═══════════════ Drawer de detalhe ═══════════════ */
.drw-ovl{position:fixed;inset:0;z-index:210;background:rgba(6,5,16,.5);backdrop-filter:blur(4px);animation:ovlIn .18s ease}
.drw{position:fixed;top:0;right:0;bottom:0;width:430px;max-width:94vw;background:linear-gradient(180deg,var(--panel),var(--panel-2));border-left:1px solid var(--border);box-shadow:-26px 0 70px -24px rgba(0,0,0,.75);display:flex;flex-direction:column;animation:drwIn .28s cubic-bezier(.2,.8,.25,1)}
@keyframes drwIn{from{transform:translateX(44px);opacity:.3}to{transform:none;opacity:1}}
.drw-h{display:flex;align-items:flex-start;gap:12px;padding:20px 20px 16px;border-bottom:1px solid var(--border-soft)}
.drw-h .mh-ic{width:40px;height:40px;border-radius:12px;display:grid;place-items:center;flex:none;background:rgba(145,53,249,.14);color:var(--purple-light)}
.drw-h .mh-ic svg{width:21px;height:21px}
.drw-h h3{font-size:16px;font-weight:800;letter-spacing:-.3px;margin-top:2px}
.drw-h .drw-kind{font-size:10px;font-weight:700;letter-spacing:.6px;text-transform:uppercase;color:var(--purple-light)}
.drw-h .mh-sub{font-size:11.5px;color:var(--text-soft);margin-top:3px}
.drw-h .mh-x{margin-left:auto;width:32px;height:32px;border-radius:9px;border:1px solid var(--border);background:rgba(255,255,255,.03);color:var(--text-soft);display:grid;place-items:center;cursor:pointer;flex:none}
.drw-h .mh-x svg{width:16px;height:16px}.drw-h .mh-x:hover{color:var(--text);border-color:var(--purple-light)}
.drw-b{padding:18px 20px;overflow-y:auto;flex:1}
.kvlist{border:1px solid var(--border-soft);border-radius:12px;overflow:hidden}
.kv{display:flex;justify-content:space-between;gap:14px;padding:11px 13px;font-size:12.5px;border-top:1px solid var(--border-soft)}
.kv:first-child{border-top:none}.kv .k{color:var(--text-soft);font-weight:600}.kv .v{text-align:right;font-weight:600;color:var(--text)}
.drw-note{display:flex;gap:10px;margin-top:16px;padding:13px;border-radius:11px;background:rgba(145,53,249,.07);border:1px solid var(--border-soft);font-size:11.5px;color:var(--text-soft);line-height:1.5}
.drw-note svg{flex:none;margin-top:1px}
.drw-f{display:flex;gap:10px;padding:15px 20px;border-top:1px solid var(--border-soft);background:rgba(0,0,0,.16)}
.drw-f .btn{flex:1;justify-content:center}

/* ═══════════════ Popovers topbar (tenant/sino) ═══════════════ */
.pop{position:absolute;top:46px;right:0;z-index:60;min-width:230px;background:linear-gradient(135deg,var(--panel-2),var(--panel));border:1px solid var(--border);border-radius:13px;box-shadow:var(--shadow-card);padding:7px;animation:modalIn .16s ease}
.pop.wide{min-width:320px}
.pop-h{display:flex;align-items:center;justify-content:space-between;font-size:10.5px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;color:var(--text-dim);padding:7px 9px 9px}
.pop-h .right{color:var(--purple-light);cursor:pointer;text-transform:none;letter-spacing:0;font-size:11px}
.pop-i{display:flex;align-items:center;gap:9px;padding:10px 9px;border-radius:9px;font-size:12.5px;font-weight:600;cursor:pointer}
.pop-i:hover{background:rgba(255,255,255,.05)}.pop-i.on{background:rgba(34,199,126,.08)}
.notif{display:flex;align-items:flex-start;gap:10px;padding:10px 9px;border-radius:9px;cursor:default}
.notif:hover{background:rgba(255,255,255,.04)}
.notif .nd{width:8px;height:8px;border-radius:50%;flex:none;margin-top:5px}
.notif .t{font-size:12.5px;font-weight:600}.notif .d{font-size:11px;color:var(--text-soft);margin-top:1px}
.notif .time{margin-left:auto;font-size:10px;color:var(--text-dim);white-space:nowrap}

/* ═══════════════ Logout · hamburger · scrim ═══════════════ */
.userbox .logout{margin-left:auto;width:34px;height:34px;border-radius:10px;border:1px solid var(--border);background:rgba(255,255,255,.03);color:var(--text-dim);display:grid;place-items:center;cursor:pointer;flex:none;transition:color .15s,border-color .15s}
.userbox .logout:hover{color:var(--alarm);border-color:var(--alarm)}
.menubtn{display:none;width:38px;height:38px;border-radius:11px;border:1px solid var(--border);background:rgba(255,255,255,.03);color:var(--text-soft);place-items:center;cursor:pointer;flex:none}
.nav-scrim{display:none;position:fixed;inset:0;z-index:39;background:rgba(6,5,16,.55);backdrop-filter:blur(3px)}

/* ═══════════════ Tour guiado ═══════════════ */
.modal.tour{max-width:440px;text-align:center}
.tour-top{display:flex;align-items:flex-start;justify-content:space-between;padding:18px 18px 0}
.tour-ic{font-size:40px;line-height:1;margin:6px auto 0;filter:drop-shadow(0 6px 16px rgba(145,53,249,.5))}
.tour-top .mh-x{width:30px;height:30px;border-radius:9px;border:1px solid var(--border);background:rgba(255,255,255,.03);color:var(--text-soft);display:grid;place-items:center;cursor:pointer}
.tour-top .mh-x svg{width:15px;height:15px}
.tour-h{font-size:21px;font-weight:800;letter-spacing:-.4px;padding:14px 30px 0}
.tour-d{font-size:13px;color:var(--text-soft);line-height:1.6;padding:12px 32px 0}
.tour-dots{display:flex;gap:7px;justify-content:center;padding:20px 0 4px}
.tour-dots span{width:7px;height:7px;border-radius:50%;background:var(--border)}
.tour-dots span.on{background:var(--purple-light);width:22px;border-radius:4px;transition:width .2s}
.tour-f{display:flex;gap:10px;justify-content:center;padding:14px 30px 26px}
.tour-f .btn{min-width:120px;justify-content:center}

@media(max-width:1180px){.kpis{grid-template-columns:1fr 1fr}.grid2,.grid2b,.grid3{grid-template-columns:1fr}.kanban{grid-template-columns:repeat(2,minmax(220px,1fr))}.login{grid-template-columns:1fr}.login .pane-art{display:none}.split{grid-template-columns:1fr}.mosaic{grid-template-columns:1fr 1fr}}

/* ═══════════════ Sidebar off-canvas (tablet/celular) ═══════════════ */
@media(max-width:900px){
  .app{grid-template-columns:1fr}
  .sidebar{position:fixed;top:0;left:0;bottom:0;width:262px;z-index:40;transform:translateX(-100%);transition:transform .26s cubic-bezier(.2,.8,.25,1)}
  .app.nav-open .sidebar{transform:none;box-shadow:24px 0 60px -20px rgba(0,0,0,.7)}
  .app.nav-open .nav-scrim{display:block}
  .menubtn{display:grid}
  .topbar{padding:14px 16px;gap:12px}
  .sys{display:none}
  .tenant{max-width:180px;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}
}
@media(max-width:680px){
  .kpis{grid-template-columns:1fr 1fr;gap:11px;margin-bottom:16px}
  .content{padding:16px!important}
  .kanban{grid-template-columns:1fr;gap:12px}
  .tenant .tname{display:none}.tenant{max-width:none}
  .topbar h1{font-size:18px}.crumb{font-size:10.5px}
  .card{overflow-x:auto}
  table{min-width:480px}
  .drw{width:100%;max-width:100%}
  .pop{position:fixed;top:64px;left:12px;right:12px;min-width:0}
  .modal-f{flex-wrap:wrap}.modal-f .mf-note{flex-basis:100%;margin-bottom:4px}
  .litem{grid-template-columns:1fr 52px 80px 28px;gap:6px}
}
@media(max-width:430px){.kpis{grid-template-columns:1fr}}
