/* ============================================================
   Painel interno — Studio Connecta (central de acessos)
   Dark-first + tema claro opt-in. Verde #93D500 como acento
   unico. Space Grotesk + Inter + JetBrains Mono. Fiel ao
   design system SC26.
   ============================================================ */

/* ---------- tokens ---------- */
:root{
  color-scheme:dark;
  --bg:#0A0A0B; --surface:#141418; --surface-2:#1a1a20; --raised:#202028;
  --border:rgba(255,255,255,.08); --border-2:rgba(255,255,255,.14);
  --fg:#EDEDEF; --fg2:#B5B5BF; --fg3:#85858F; --fg4:#5b5b64;
  --verde:#93D500; --verde-deep:#6FA200; --verde-ink:#93D500; --verde-soft:rgba(147,213,0,.12);
  --azul:#3FA7D6; --tutti:#FF4D86; --amarelo:#F6E75E; --lilas:#A87BD6;
  --danger:#FF4D6A; --danger-soft:rgba(255,77,106,.12); --danger-bd:rgba(255,77,106,.4);
  --app-bg:radial-gradient(120% 90% at 85% -10%,#15151c,#0A0A0B 60%);
  --sidebar-bg:linear-gradient(180deg,#101014,#0b0b0e);
  --input-bg:#0e0e12; --topbar-bg:rgba(10,10,11,.82); --drawer-bg:linear-gradient(180deg,#16161b,#101014);
  --grad-card:linear-gradient(180deg,var(--surface),rgba(20,20,24,.6));
  --grad-panel:linear-gradient(180deg,var(--surface),rgba(18,18,22,.7));
  --row-hover:rgba(255,255,255,.03); --cal-filter:invert(.55); --scrim:rgba(4,4,6,.62);
  --mono:'JetBrains Mono',ui-monospace,monospace; --display:'Space Grotesk',sans-serif; --body:'Inter',-apple-system,sans-serif;
  --r:16px; --r-sm:11px; --r-lg:22px; --ease:cubic-bezier(.2,.7,.3,1);
  --shadow:0 40px 90px -30px rgba(0,0,0,.85);
}
html[data-theme="light"]{
  color-scheme:light;
  --bg:#F4F5F7; --surface:#FFFFFF; --surface-2:#F4F5F7; --raised:#ECEDF1;
  --border:rgba(15,17,21,.10); --border-2:rgba(15,17,21,.18);
  --fg:#14151A; --fg2:#3A3D45; --fg3:#6A6E78; --fg4:#9DA1AA;
  --verde-ink:#6FA200; --verde-soft:rgba(147,213,0,.16);
  --app-bg:radial-gradient(120% 90% at 85% -10%,#ffffff,#eef0f4 60%);
  --sidebar-bg:linear-gradient(180deg,#ffffff,#f6f7f9);
  --input-bg:#FFFFFF; --topbar-bg:rgba(255,255,255,.85); --drawer-bg:linear-gradient(180deg,#ffffff,#f4f5f7);
  --grad-card:linear-gradient(180deg,#ffffff,#fafbfc); --grad-panel:linear-gradient(180deg,#ffffff,#fbfcfd);
  --row-hover:rgba(15,17,21,.03); --cal-filter:none; --scrim:rgba(20,24,40,.34);
  --shadow:0 30px 70px -34px rgba(20,24,40,.30);
}

*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%}
body{font-family:var(--body);background:var(--app-bg);color:var(--fg);min-height:100dvh;font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
::selection{background:rgba(147,213,0,.25)}
iconify-icon{display:inline-block;vertical-align:-.125em}
:focus-visible{outline:2px solid var(--verde);outline-offset:2px;border-radius:6px}
@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important;scroll-behavior:auto!important}}

/* ============================================================
   GATE (login)
   ============================================================ */
.gate-body{display:flex;align-items:center;justify-content:center;padding:24px}
.theme-toggle{position:fixed;top:18px;right:18px;width:42px;height:42px;border-radius:12px;border:1px solid var(--border);background:var(--surface);color:var(--fg2);display:grid;place-items:center;cursor:pointer;font-size:1.15rem;transition:.18s var(--ease);z-index:60}
.theme-toggle:hover{color:var(--fg);border-color:var(--border-2)}
html[data-theme="dark"] .ic-sun{display:block}html[data-theme="dark"] .ic-moon{display:none}
html[data-theme="light"] .ic-sun{display:none}html[data-theme="light"] .ic-moon{display:block}
.gate-card{width:100%;max-width:418px;background:var(--grad-card);border:1px solid var(--border);border-radius:var(--r-lg);padding:36px 32px;box-shadow:var(--shadow);text-align:center}
.gate-logo{height:32px;width:auto;margin:0 auto 24px;display:block}
html[data-theme="dark"] .gate-logo.light{display:none}html[data-theme="light"] .gate-logo.dark{display:none}
.gate-eyebrow{font-family:var(--mono);font-size:.66rem;text-transform:uppercase;letter-spacing:.2em;color:var(--verde-ink);margin-bottom:12px;display:inline-flex;align-items:center;gap:8px}
.pulse{width:7px;height:7px;border-radius:50%;background:var(--verde);animation:pulse 2.4s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(147,213,0,.45)}70%{box-shadow:0 0 0 7px rgba(147,213,0,0)}100%{box-shadow:0 0 0 0 rgba(147,213,0,0)}}
.gate-title{font-family:var(--display);font-weight:600;font-size:1.35rem;letter-spacing:-.01em;margin-bottom:6px}
.gate-sub{color:var(--fg3);font-size:.9rem;font-weight:300;margin-bottom:22px}
.gate-msg{padding:10px 13px;border-radius:10px;font-size:.84rem;margin-bottom:15px;text-align:left;line-height:1.45;display:none}
.gate-msg.show{display:block}
.gate-msg.err{background:var(--danger-soft);border:1px solid var(--danger-bd);color:var(--danger)}
.gate-msg.ok{background:var(--verde-soft);border:1px solid rgba(147,213,0,.42);color:var(--verde-ink)}
.gate-hint{color:var(--fg4);font-size:.76rem;margin-top:16px;line-height:1.5}
.fld{position:relative;margin-bottom:11px}
.fld input{width:100%;padding:13px 14px;border-radius:12px;background:var(--input-bg);border:1px solid var(--border-2);color:var(--fg);font-size:.97rem;font-family:var(--body);text-align:left}
.fld input::placeholder{color:var(--fg4)}
.fld input.haspw{padding-right:46px}
.fld input:focus{outline:none;border-color:var(--verde);box-shadow:0 0 0 3px rgba(147,213,0,.18)}
.pwtoggle{position:absolute;right:7px;top:50%;transform:translateY(-50%);width:34px;height:34px;display:grid;place-items:center;background:transparent;border:none;border-radius:9px;color:var(--fg3);cursor:pointer;font-size:1.15rem}
.pwtoggle:hover{color:var(--fg);background:var(--row-hover)}
.pwtoggle .eye{display:block}.pwtoggle .eyeoff{display:none}
.pwtoggle.on .eye{display:none}.pwtoggle.on .eyeoff{display:block;color:var(--verde-ink)}

/* ============================================================
   BOTOES
   ============================================================ */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;height:42px;padding:0 16px;border-radius:var(--r-sm);font-family:var(--display);font-weight:600;font-size:.88rem;cursor:pointer;border:1px solid var(--border-2);background:var(--surface-2);color:var(--fg);transition:.18s var(--ease);white-space:nowrap}
.btn:hover{border-color:var(--border-2);background:var(--raised)}
.btn:disabled{opacity:.55;cursor:default}
.btn-green{background:var(--verde);color:#0A0A0B;border-color:var(--verde)}
.btn-green:hover{background:#a6e815}
.btn-block{width:100%;margin-top:6px;height:46px;font-size:1rem}
.btn-danger{background:var(--danger-soft);color:var(--danger);border-color:var(--danger-bd)}
.btn-danger:hover{background:rgba(255,77,106,.2)}
.btn-ghost{background:transparent}
.btn-sm{height:36px;padding:0 12px;font-size:.82rem}
.btn-icon{width:42px;padding:0}

/* ============================================================
   APP SHELL — sidebar + main
   ============================================================ */
.app{display:grid;grid-template-columns:266px 1fr;min-height:100dvh}
.app[aria-busy="true"]{opacity:0}
.app.ready{opacity:1;transition:opacity .3s var(--ease)}

.sidebar{position:sticky;top:0;height:100dvh;display:flex;flex-direction:column;background:var(--sidebar-bg);border-right:1px solid var(--border);z-index:50}
.side-brand{display:flex;align-items:center;gap:10px;padding:20px 20px 16px}
.side-brand img{height:26px;width:auto}
html[data-theme="dark"] .side-brand img.light{display:none}html[data-theme="light"] .side-brand img.dark{display:none}
.side-tag{font-family:var(--mono);font-size:.58rem;text-transform:uppercase;letter-spacing:.16em;color:var(--fg3);padding-left:11px;margin-left:1px;border-left:1px solid var(--border-2)}
.side-nav{flex:1;overflow-y:auto;padding:6px 12px 12px;scrollbar-width:thin}
.side-nav::-webkit-scrollbar{width:8px}.side-nav::-webkit-scrollbar-thumb{background:var(--border-2);border-radius:8px}
.nav-group{margin-top:16px}
.nav-group:first-child{margin-top:4px}
.nav-group-label{font-family:var(--mono);font-size:.6rem;text-transform:uppercase;letter-spacing:.18em;color:var(--fg4);padding:0 12px 8px;display:flex;align-items:center;gap:7px}
.nav-item{display:flex;align-items:center;gap:11px;width:100%;padding:10px 12px;border-radius:10px;border:none;background:transparent;color:var(--fg2);font-family:var(--body);font-weight:500;font-size:.9rem;cursor:pointer;transition:.15s var(--ease);text-align:left;margin-bottom:2px;position:relative}
.nav-item iconify-icon{font-size:1.2rem;color:var(--fg3);flex-shrink:0;transition:.15s}
.nav-item .lbl{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.nav-item .count{font-family:var(--mono);font-size:.66rem;font-weight:500;padding:.12em .5em;border-radius:999px;background:var(--surface-2);color:var(--fg2);border:1px solid var(--border)}
.nav-item .ext{font-size:.9rem;color:var(--fg4)}
.nav-item:hover{background:var(--row-hover);color:var(--fg)}
.nav-item:hover iconify-icon{color:var(--fg2)}
.nav-item.active{background:var(--verde-soft);color:var(--fg)}
.nav-item.active iconify-icon{color:var(--verde-ink)}
.nav-item.active::before{content:"";position:absolute;left:-12px;top:50%;transform:translateY(-50%);width:3px;height:20px;border-radius:0 3px 3px 0;background:var(--verde)}
.side-foot{border-top:1px solid var(--border);padding:12px;display:flex;flex-direction:column;gap:8px}
.user-chip{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:10px;background:var(--surface)}
.user-av{width:34px;height:34px;border-radius:9px;background:var(--verde);color:#0A0A0B;display:grid;place-items:center;font-family:var(--display);font-weight:700;font-size:.85rem;flex-shrink:0}
.user-meta{min-width:0;flex:1}
.user-meta .nm{font-weight:600;font-size:.85rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.user-meta .rl{font-family:var(--mono);font-size:.6rem;text-transform:uppercase;letter-spacing:.1em;color:var(--fg3)}
.foot-actions{display:flex;gap:8px}
.foot-actions .btn{flex:1;height:38px}

/* topbar (mobile) */
.app-topbar{display:none;position:sticky;top:0;z-index:45;align-items:center;gap:12px;height:58px;padding:0 14px;background:var(--topbar-bg);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid var(--border)}
.app-topbar img{height:22px}
html[data-theme="dark"] .app-topbar img.light{display:none}html[data-theme="light"] .app-topbar img.dark{display:none}
.app-topbar .sp{flex:1}
.hamb{width:40px;height:40px;border-radius:10px;border:1px solid var(--border);background:var(--surface);color:var(--fg);display:grid;place-items:center;font-size:1.3rem;cursor:pointer}
.scrim{display:none;position:fixed;inset:0;background:var(--scrim);z-index:48;backdrop-filter:blur(2px)}
.scrim.show{display:block}

/* main */
.main{min-width:0;display:flex;flex-direction:column}
.main-in{width:100%;max-width:1180px;margin:0 auto;padding:26px clamp(16px,3vw,34px) 90px}
.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;flex-wrap:wrap;margin-bottom:22px}
.eyebrow{font-family:var(--mono);font-size:.66rem;text-transform:uppercase;letter-spacing:.2em;color:var(--verde-ink);margin-bottom:9px;display:flex;align-items:center;gap:7px}
h1.title{font-family:var(--display);font-weight:600;font-size:clamp(1.5rem,3vw,2rem);letter-spacing:-.02em;line-height:1.1}
.title-sub{color:var(--fg3);font-size:.92rem;margin-top:7px;max-width:60ch}
.head-actions{display:flex;gap:9px;flex-wrap:wrap}

/* ============================================================
   VISAO GERAL
   ============================================================ */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:14px;margin-bottom:22px}
.stat{position:relative;background:var(--grad-card);border:1px solid var(--border);border-radius:var(--r);padding:18px;overflow:hidden;text-align:left}
.stat::after{content:"";position:absolute;inset:0;background:radial-gradient(80% 60% at 100% 0,var(--verde-soft),transparent 60%);opacity:0;transition:.4s;pointer-events:none}
.stat:hover::after{opacity:1}
.stat-ic{width:36px;height:36px;border-radius:10px;display:grid;place-items:center;font-size:1.15rem;color:var(--verde-ink);background:var(--verde-soft);border:1px solid rgba(147,213,0,.22);margin-bottom:13px}
.stat.azul .stat-ic{color:var(--azul);background:rgba(63,167,214,.12);border-color:rgba(63,167,214,.22)}
.stat.tutti .stat-ic{color:var(--tutti);background:rgba(255,77,134,.1);border-color:rgba(255,77,134,.22)}
.stat.lilas .stat-ic{color:var(--lilas);background:rgba(168,123,214,.12);border-color:rgba(168,123,214,.22)}
.stat-val{font-family:var(--display);font-weight:600;font-size:2rem;line-height:1;letter-spacing:-.02em;font-variant-numeric:tabular-nums}
.stat-lbl{color:var(--fg3);font-size:.82rem;margin-top:7px}
.stat-foot{font-family:var(--mono);font-size:.68rem;color:var(--fg4);margin-top:9px}
button.stat{cursor:pointer;font:inherit}
button.stat:hover{border-color:var(--border-2)}

.card{background:var(--grad-panel);border:1px solid var(--border);border-radius:var(--r);overflow:hidden}
.card-head{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;padding:16px 18px;border-bottom:1px solid var(--border)}
.card-head h2{font-family:var(--display);font-weight:600;font-size:1.02rem}
.card-body{padding:18px}
.section-label{font-family:var(--mono);font-size:.64rem;text-transform:uppercase;letter-spacing:.16em;color:var(--fg3);margin:26px 0 13px}

/* chart */
.chart-wrap{padding:18px}
.chart{display:flex;align-items:flex-end;gap:3px;height:190px;padding-top:10px}
.chart-col{flex:1;min-width:0;display:flex;flex-direction:column;justify-content:flex-end;gap:2px;height:100%;position:relative;border-radius:5px;transition:.15s}
.chart-col:hover{background:var(--row-hover)}
.chart-seg{width:100%;border-radius:3px;min-height:0;transition:height .4s var(--ease)}
.chart-seg.diagnostico{background:var(--verde)}
.chart-seg.contratacao{background:var(--azul)}
.chart-seg.whatsapp{background:var(--amarelo)}
.chart-seg.briefing{background:var(--lilas)}
.chart-x{display:flex;gap:3px;margin-top:8px}
.chart-x span{flex:1;text-align:center;font-family:var(--mono);font-size:.56rem;color:var(--fg4);overflow:hidden;white-space:nowrap}
.chart-legend{display:flex;gap:16px;flex-wrap:wrap;padding:0 18px 16px}
.chart-legend button{display:inline-flex;align-items:center;gap:7px;background:none;border:none;color:var(--fg2);font-size:.8rem;font-family:var(--body);cursor:pointer}
.chart-legend .sw{width:11px;height:11px;border-radius:3px}
.chart-legend button.off{opacity:.4}
.chart-legend .sw.diagnostico{background:var(--verde)}
.chart-legend .sw.contratacao{background:var(--azul)}
.chart-legend .sw.whatsapp{background:var(--amarelo)}
.chart-legend .sw.briefing{background:var(--lilas)}

/* tiles de acesso rapido */
.tiles{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:14px}
.tile{display:flex;flex-direction:column;gap:12px;background:var(--grad-card);border:1px solid var(--border);border-radius:var(--r);padding:20px;transition:.18s var(--ease);cursor:pointer;text-align:left;min-height:150px}
.tile:hover{border-color:var(--border-2);transform:translateY(-2px)}
.tile-ic{width:42px;height:42px;border-radius:11px;display:grid;place-items:center;font-size:1.35rem;color:var(--verde-ink);background:var(--verde-soft);border:1px solid rgba(147,213,0,.22)}
.tile.azul .tile-ic{color:var(--azul);background:rgba(63,167,214,.12);border-color:rgba(63,167,214,.22)}
.tile.lilas .tile-ic{color:var(--lilas);background:rgba(168,123,214,.12);border-color:rgba(168,123,214,.22)}
.tile.tutti .tile-ic{color:var(--tutti);background:rgba(255,77,134,.1);border-color:rgba(255,77,134,.22)}
.tile h3{font-family:var(--display);font-weight:600;font-size:1.02rem;display:flex;align-items:center;gap:8px}
.tile h3 .ext{font-size:.85rem;color:var(--fg4);margin-left:auto}
.tile p{color:var(--fg3);font-size:.84rem;line-height:1.5;flex:1}
.tile .go{font-family:var(--mono);font-size:.68rem;letter-spacing:.06em;color:var(--verde-ink);display:flex;align-items:center;gap:6px}

/* ============================================================
   TABELA DE LEADS
   ============================================================ */
.toolbar{display:flex;align-items:center;gap:11px;flex-wrap:wrap;padding:15px 18px;border-bottom:1px solid var(--border)}
.search{position:relative;flex:1;min-width:190px}
.search iconify-icon{position:absolute;left:13px;top:50%;transform:translateY(-50%);color:var(--fg3);font-size:1.1rem;pointer-events:none}
.search input{width:100%;height:42px;padding:0 14px 0 40px;border-radius:var(--r-sm);background:var(--input-bg);border:1px solid var(--border);color:var(--fg);font-size:.92rem;font-family:var(--body)}
.search input::placeholder{color:var(--fg4)}
.search input:focus{outline:none;border-color:var(--verde);box-shadow:0 0 0 3px rgba(147,213,0,.16)}
.daterange{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.daterange .dash{color:var(--fg4);font-size:.74rem;font-family:var(--mono)}
.datein{height:42px;padding:0 12px;border-radius:var(--r-sm);background:var(--input-bg);border:1px solid var(--border);color:var(--fg2);font-size:.84rem;font-family:var(--body);cursor:pointer}
.datein:focus{outline:none;border-color:var(--verde);color:var(--fg)}
.datein::-webkit-calendar-picker-indicator{filter:var(--cal-filter);cursor:pointer;opacity:.85}
.count-tag{font-family:var(--mono);font-size:.72rem;color:var(--fg3);letter-spacing:.04em;white-space:nowrap;margin-left:auto}
.tablewrap{overflow-x:auto}
table{width:100%;border-collapse:collapse;font-size:.9rem}
thead th{position:sticky;top:0;text-align:left;font-family:var(--mono);font-size:.64rem;text-transform:uppercase;letter-spacing:.1em;color:var(--fg3);font-weight:600;padding:13px 16px;border-bottom:1px solid var(--border);background:var(--surface);white-space:nowrap;cursor:pointer;user-select:none}
thead th.no-sort{cursor:default}
thead th .th-in{display:inline-flex;align-items:center;gap:6px}
thead th .sort-ic{font-size:.85rem;opacity:0;transition:.15s}
thead th[aria-sort] .sort-ic,thead th:hover .sort-ic{opacity:.6}
thead th[aria-sort="ascending"] .sort-ic,thead th[aria-sort="descending"] .sort-ic{opacity:1;color:var(--verde-ink)}
thead th.col-check{width:44px;cursor:default;text-align:center}
tbody td{padding:13px 16px;border-bottom:1px solid var(--border);color:var(--fg2);vertical-align:middle;max-width:280px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
tbody td.col-check{text-align:center;overflow:visible}
tbody td .strong{color:var(--fg);font-weight:500}
tbody td.num{font-variant-numeric:tabular-nums;font-family:var(--mono);font-size:.82rem;color:var(--fg3)}
tbody tr{cursor:pointer;transition:background .12s}
tbody tr:hover{background:var(--row-hover)}
tbody tr.sel{background:var(--verde-soft)}
.chk{width:18px;height:18px;border-radius:5px;border:1.5px solid var(--border-2);background:var(--input-bg);cursor:pointer;appearance:none;-webkit-appearance:none;position:relative;flex-shrink:0}
.chk:checked{background:var(--verde);border-color:var(--verde)}
.chk:checked::after{content:"";position:absolute;left:5px;top:1.5px;width:5px;height:9px;border:solid #0A0A0B;border-width:0 2px 2px 0;transform:rotate(45deg)}
.chk:focus-visible{outline:2px solid var(--verde);outline-offset:2px}
.empty{padding:60px 20px;text-align:center;color:var(--fg3)}
.empty iconify-icon{font-size:2.4rem;color:var(--fg4);margin-bottom:12px;display:block}
.empty h3{font-family:var(--display);font-weight:600;color:var(--fg2);margin-bottom:6px}
.empty p{font-size:.86rem;max-width:44ch;margin:0 auto}
.bulkbar{display:flex;align-items:center;gap:12px;flex-wrap:wrap;padding:12px 18px;border-top:1px solid var(--border);background:var(--surface)}
.bulkbar .info{font-size:.84rem;color:var(--fg2)}
.bulkbar .sp{flex:1}

/* pill (servico/prioridade etc.) */
.pill{display:inline-flex;align-items:center;gap:5px;font-family:var(--mono);font-size:.66rem;padding:.22em .6em;border-radius:999px;background:var(--surface-2);color:var(--fg2);border:1px solid var(--border);white-space:nowrap}
.pill.g{color:var(--verde-ink);background:var(--verde-soft);border-color:rgba(147,213,0,.25)}

/* ============================================================
   DRAWER
   ============================================================ */
.drawer-scrim{position:fixed;inset:0;background:var(--scrim);z-index:70;opacity:0;pointer-events:none;transition:opacity .25s var(--ease)}
.drawer-scrim.show{opacity:1;pointer-events:auto}
.drawer{position:fixed;top:0;right:0;height:100dvh;width:min(480px,94vw);background:var(--drawer-bg);border-left:1px solid var(--border-2);box-shadow:-30px 0 80px -30px rgba(0,0,0,.7);z-index:71;transform:translateX(100%);transition:transform .28s var(--ease);display:flex;flex-direction:column}
.drawer.show{transform:none}
.drawer-head{display:flex;align-items:center;gap:12px;padding:20px 22px;border-bottom:1px solid var(--border)}
.drawer-head .eyebrow{margin:0}
.drawer-head h2{font-family:var(--display);font-weight:600;font-size:1.1rem;margin-top:2px}
.drawer-close{margin-left:auto;width:38px;height:38px;border-radius:10px;border:1px solid var(--border);background:var(--surface);color:var(--fg2);display:grid;place-items:center;cursor:pointer;font-size:1.15rem;flex-shrink:0}
.drawer-close:hover{color:var(--fg);border-color:var(--border-2)}
.drawer-body{flex:1;overflow-y:auto;padding:20px 22px}
.drawer-foot{border-top:1px solid var(--border);padding:14px 22px;display:flex;gap:10px;flex-wrap:wrap}
.drawer-foot .btn{flex:1;min-width:120px}
.frow{padding:12px 0;border-bottom:1px solid var(--border)}
.frow:last-child{border-bottom:none}
.frow .k{font-family:var(--mono);font-size:.62rem;text-transform:uppercase;letter-spacing:.1em;color:var(--fg4);margin-bottom:5px}
.frow .v{color:var(--fg);font-size:.94rem;word-break:break-word;white-space:pre-wrap}
.frow .v.empty-v{color:var(--fg4);font-style:italic}
.frow .v a{color:var(--verde-ink);text-decoration:underline;text-underline-offset:2px}
.contact-row{display:flex;gap:10px;margin-bottom:18px}
.contact-row .btn{flex:1}
/* edit mode */
.edit-fld{margin-bottom:13px}
.edit-fld label{display:block;font-family:var(--mono);font-size:.62rem;text-transform:uppercase;letter-spacing:.1em;color:var(--fg4);margin-bottom:6px}
.edit-fld input,.edit-fld textarea,.edit-fld select{width:100%;padding:10px 12px;border-radius:10px;background:var(--input-bg);border:1px solid var(--border-2);color:var(--fg);font-size:.9rem;font-family:var(--body)}
.edit-fld textarea{min-height:74px;resize:vertical;line-height:1.5}
.edit-fld input:focus,.edit-fld textarea:focus,.edit-fld select:focus{outline:none;border-color:var(--verde);box-shadow:0 0 0 3px rgba(147,213,0,.16)}

/* ============================================================
   USUARIOS
   ============================================================ */
.badge{display:inline-flex;align-items:center;gap:5px;font-family:var(--mono);font-size:.64rem;text-transform:uppercase;letter-spacing:.08em;padding:.22em .6em;border-radius:6px;border:1px solid var(--border)}
.badge.admin{color:var(--verde-ink);background:var(--verde-soft);border-color:rgba(147,213,0,.3)}
.badge.padrao{color:var(--fg3);background:var(--surface-2)}
.badge.on{color:var(--danger);background:var(--danger-soft);border-color:var(--danger-bd)}
.perm-dots{display:inline-flex;gap:4px}
.perm-dot{width:8px;height:8px;border-radius:50%;background:var(--border-2)}
.perm-dot.on{background:var(--verde)}
.switch{position:relative;display:inline-flex;align-items:center;cursor:pointer;gap:10px}
.switch input{position:absolute;opacity:0;width:0;height:0}
.switch .track{width:40px;height:23px;border-radius:999px;background:var(--surface-2);border:1px solid var(--border-2);transition:.18s;flex-shrink:0;position:relative}
.switch .track::after{content:"";position:absolute;left:2px;top:2px;width:17px;height:17px;border-radius:50%;background:var(--fg3);transition:.18s}
.switch input:checked+.track{background:var(--verde);border-color:var(--verde)}
.switch input:checked+.track::after{transform:translateX(17px);background:#0A0A0B}
.switch input:focus-visible+.track{outline:2px solid var(--verde);outline-offset:2px}
.switch .swlbl{font-size:.88rem;color:var(--fg2)}
.perm-grid{display:grid;gap:10px;margin-top:6px}
.perm-block{border:1px solid var(--border);border-radius:12px;padding:14px}
.perm-block .pb-head{display:flex;align-items:center;gap:9px;margin-bottom:12px}
.perm-block .pb-head iconify-icon{font-size:1.1rem;color:var(--verde-ink)}
.perm-block .pb-head .t{font-family:var(--display);font-weight:600;font-size:.92rem}
.perm-toggles{display:flex;gap:18px;flex-wrap:wrap}
.perm-toggles .switch .swlbl{font-size:.82rem}

/* ============================================================
   MODAL + TOAST
   ============================================================ */
.modal-scrim{position:fixed;inset:0;background:var(--scrim);z-index:80;display:none;align-items:center;justify-content:center;padding:20px}
.modal-scrim.show{display:flex}
.modal{width:100%;max-width:420px;background:var(--grad-card);border:1px solid var(--border-2);border-radius:var(--r);padding:26px;box-shadow:var(--shadow)}
.modal .m-ic{width:46px;height:46px;border-radius:12px;display:grid;place-items:center;font-size:1.4rem;color:var(--danger);background:var(--danger-soft);border:1px solid var(--danger-bd);margin-bottom:15px}
.modal h3{font-family:var(--display);font-weight:600;font-size:1.15rem;margin-bottom:8px}
.modal p{color:var(--fg3);font-size:.9rem;line-height:1.5;margin-bottom:20px}
.modal-actions{display:flex;gap:10px}
.modal-actions .btn{flex:1}
.toast{position:fixed;bottom:22px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--raised);border:1px solid var(--border-2);color:var(--fg);padding:13px 20px;border-radius:12px;font-size:.88rem;box-shadow:var(--shadow);z-index:90;opacity:0;pointer-events:none;transition:.25s var(--ease);display:flex;align-items:center;gap:10px;max-width:92vw}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast iconify-icon{font-size:1.2rem}
.toast.ok iconify-icon{color:var(--verde-ink)}
.toast.err iconify-icon{color:var(--danger)}

/* ============================================================
   RESPONSIVO
   ============================================================ */
@media (max-width:960px){
  .app{grid-template-columns:1fr}
  .app-topbar{display:flex}
  .sidebar{position:fixed;left:0;top:0;width:280px;transform:translateX(-100%);transition:transform .26s var(--ease)}
  .sidebar.open{transform:none;box-shadow:30px 0 80px -30px rgba(0,0,0,.6)}
  .main-in{padding:18px 16px 90px}
}
@media (max-width:520px){
  .stats{grid-template-columns:1fr 1fr}
  .drawer-foot{flex-direction:column}
  .drawer-foot .btn{width:100%}
}
