/* =====================================================================
   GIA — App (painel administrativo do cliente)
   Liquid Glass + acento violeta. Carrega DEPOIS do lg-system.css.
   ===================================================================== */

:root,[data-theme="light"]{
  --bg:linear-gradient(160deg,#ecedfb 0%,#f1ecf8 52%,#fdf0e7 100%);
  --blob-op:.5;
  --g-bg:rgba(255,255,255,0.42); --g-bg-strong:rgba(255,255,255,0.56); --g-brd:rgba(255,255,255,0.62);
  --g-shadow:0 22px 55px -20px rgba(20,40,72,0.4), inset 0 1px 1px rgba(255,255,255,0.92);
  --ins:rgba(255,255,255,0.55); --ins-brd:rgba(255,255,255,0.7); --rim:rgba(255,255,255,0.85);
  --active:rgba(255,255,255,0.72); --panel-solid:#eef1f8;
  --tx:#142848; --tx2:#53607b; --tx3:#69708a; --logo:#1E3A6B;
  --accent:var(--violet); --accent-soft:var(--violet-soft);
}
[data-theme="dark-navy"]{
  --bg:linear-gradient(160deg,#0b1630 0%,#102246 52%,#0d1934 100%);
  --blob-op:.4;
  --g-bg:rgba(17,28,56,0.55); --g-bg-strong:rgba(14,24,50,0.72); --g-brd:rgba(255,255,255,0.12);
  --g-shadow:0 24px 60px -24px rgba(0,0,0,0.62), inset 0 1px 0 rgba(255,255,255,0.10);
  --ins:rgba(255,255,255,0.09); --ins-brd:rgba(255,255,255,0.14); --rim:rgba(255,255,255,0.10);
  --active:rgba(255,255,255,0.13); --panel-solid:#101e3e;
  --tx:#eef2fb; --tx2:rgba(238,242,251,0.86); --tx3:rgba(238,242,251,0.62); --logo:#dbe4f5;
  --accent:var(--violet); --accent-soft:var(--violet-soft);
}
[data-theme="dark-carbon"]{
  --bg:linear-gradient(160deg,#090a0e 0%,#16181f 52%,#0b0c10 100%);
  --blob-op:.32;
  --g-bg:rgba(20,21,28,0.6); --g-bg-strong:rgba(15,16,21,0.74); --g-brd:rgba(255,255,255,0.10);
  --g-shadow:0 24px 60px -24px rgba(0,0,0,0.8), inset 0 1px 0 rgba(255,255,255,0.08);
  --ins:rgba(255,255,255,0.07); --ins-brd:rgba(255,255,255,0.12); --rim:rgba(255,255,255,0.08);
  --active:rgba(255,255,255,0.11); --panel-solid:#121318;
  --tx:#f1f2f5; --tx2:rgba(241,242,245,0.84); --tx3:rgba(241,242,245,0.58); --logo:#e6e8ee;
  --accent:var(--violet); --accent-soft:var(--violet-soft);
}
body{background:var(--bg);color:var(--tx)}
.aurora{background:var(--bg)} .aurora .blob{opacity:var(--blob-op)}

.shell{display:flex;gap:18px;padding:18px;min-height:100vh;max-width:1500px;margin:0 auto}

/* ===== SIDEBAR ===== */
.sidebar{flex:0 0 250px;position:sticky;top:18px;height:calc(100vh - 36px);display:flex;flex-direction:column;
  border-radius:26px;padding:16px 14px;overflow:hidden;
  background:var(--g-bg-strong);backdrop-filter:var(--g-blur);-webkit-backdrop-filter:var(--g-blur);
  border:1px solid var(--g-brd);box-shadow:var(--g-shadow)}
.sb-brand{display:flex;align-items:center;gap:10px;padding:6px 8px 14px}
.sb-brand .wm{font-family:var(--display);font-weight:700;font-size:17px;letter-spacing:-.4px;color:var(--tx)}
.sb-brand .wm .dot{color:var(--orange)}
.sb-brand .tg{display:block;font-size:8px;letter-spacing:1.8px;color:var(--tx3);font-weight:600;margin-top:2px}

.sb-tenant{display:flex;flex-direction:column;gap:6px;padding:11px 12px;border-radius:14px;margin-bottom:14px;
  background:var(--ins);border:1px solid var(--ins-brd);box-shadow:inset 0 1px 0 var(--rim)}
.sb-tenant .nm{font-family:var(--display);font-weight:600;font-size:13.5px;color:var(--tx);line-height:1.1}
.sb-tenant .badge{display:inline-flex;align-items:center;gap:6px;font-family:var(--display);font-size:9.5px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;color:#fff;background:linear-gradient(135deg,var(--violet),var(--violet-soft));padding:3px 8px;border-radius:8px;width:fit-content}
.sb-tenant .meta{font-size:10.5px;color:var(--tx3)}

.sb-nav{flex:1;min-height:0;overflow:auto;display:flex;flex-direction:column;gap:3px;padding:0 2px 0 0}
.sb-nav::-webkit-scrollbar{width:6px}.sb-nav::-webkit-scrollbar-thumb{background:var(--ins-brd);border-radius:3px}
.sb-group{font-family:var(--display);font-size:9px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--tx3);padding:14px 12px 6px}
.sb-link{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:12px;text-decoration:none;color:var(--tx2);font-size:13.5px;font-weight:500;transition:background .15s,color .15s}
.sb-link svg{width:18px;height:18px;flex:0 0 18px;color:var(--tx3)}
.sb-link:hover{background:var(--ins);color:var(--tx)}
.sb-link:hover svg{color:var(--tx2)}
.sb-link.active{background:var(--active);color:var(--tx);font-weight:600;box-shadow:inset 0 1px 0 var(--rim)}
.sb-link.active svg{color:var(--violet)}
.sb-link .badge-new{margin-left:auto;font-family:var(--display);font-size:8px;font-weight:700;letter-spacing:.6px;color:#fff;background:var(--teal);padding:2px 6px;border-radius:8px}
.sb-foot{padding:10px 10px 2px}
.sb-foot a{display:flex;align-items:center;gap:10px;color:var(--tx3);font-size:13px;text-decoration:none}
.sb-foot a svg{width:18px;height:18px;flex:0 0 18px}
/* ---- Menu retrátil / gaveta de ícones (2026-06-13) — botão injetado pelo gia-app.js ---- */
.sb-collapse{align-self:flex-end;flex:0 0 auto;margin:0 2px 8px;width:28px;height:28px;display:grid;place-items:center;
  border-radius:9px;border:1px solid var(--ins-brd);background:var(--ins);color:var(--tx2);cursor:pointer;padding:0;transition:all .15s}
.sb-collapse:hover{border-color:rgba(124,99,235,.45);color:var(--violet)}
.sb-collapse svg{width:15px;height:15px;transition:transform .2s}
@media(max-width:900px){.sb-collapse{display:none}}
@media(min-width:901px){
  .sidebar{transition:flex-basis .2s ease}
  html.sidebar-collapsed .sidebar{flex-basis:64px;padding-left:8px;padding-right:8px}
  html.sidebar-collapsed .sb-collapse{align-self:center}
  html.sidebar-collapsed .sb-collapse svg{transform:rotate(180deg)}
  html.sidebar-collapsed .sb-brand,
  html.sidebar-collapsed .sb-tenant,
  html.sidebar-collapsed .sb-group,
  html.sidebar-collapsed .sb-label,
  html.sidebar-collapsed .sb-link .badge-new{display:none}
  html.sidebar-collapsed .sb-link{justify-content:center;padding:11px 0;gap:0}
  html.sidebar-collapsed .sb-foot{padding:10px 4px 2px}
  html.sidebar-collapsed .sb-foot a{justify-content:center;gap:0}
}

/* ===== MAIN ===== */
.main{flex:1;min-width:0;display:flex;flex-direction:column;gap:18px}
.topbar{position:sticky;top:18px;z-index:20;display:flex;align-items:center;gap:16px;padding:11px 16px;border-radius:22px;overflow:visible;
  background:var(--g-bg-strong);backdrop-filter:var(--g-blur);-webkit-backdrop-filter:var(--g-blur);
  border:1px solid var(--g-brd);box-shadow:var(--g-shadow)}
.topbar .title{font-family:var(--display);font-weight:700;font-size:20px;letter-spacing:-.5px;color:var(--tx)}
.tb-search{margin-left:8px;flex:1;max-width:300px;display:flex;align-items:center;gap:8px;padding:8px 12px;border-radius:12px;
  background:var(--ins);border:1px solid var(--ins-brd);color:var(--tx3);font-size:13px}
.tb-search .kbd{margin-left:auto;font-family:var(--display);font-size:10px;background:var(--ins-brd);padding:2px 6px;border-radius:6px}
.tb-icons{margin-left:auto;display:flex;align-items:center;gap:6px}
.tb-ico{width:36px;height:36px;border-radius:11px;display:flex;align-items:center;justify-content:center;color:var(--tx);position:relative;
  background:var(--ins);border:1px solid var(--ins-brd)}
.tb-ico svg{width:18px;height:18px}
.tb-ico .badge{position:absolute;top:-4px;right:-4px;min-width:17px;height:17px;border-radius:50%;background:var(--violet);color:#fff;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;padding:0 4px;font-family:var(--display)}
.tb-user{display:flex;align-items:center;gap:9px;padding:5px 12px 5px 6px;border-radius:30px;background:var(--ins);border:1px solid var(--ins-brd)}
.tb-user .av{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,var(--violet),var(--violet-soft));color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--display);font-weight:700;font-size:12px}
.tb-user .nm{font-family:var(--display);font-weight:600;font-size:13px;color:var(--tx)}

.content{display:flex;flex-direction:column;gap:18px;padding-bottom:30px}
.greet{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
.greet .lab{font-family:var(--display);font-size:11px;font-weight:600;letter-spacing:1.6px;text-transform:uppercase;color:var(--tx3);margin-bottom:4px}
.greet h1{font-family:var(--display);font-weight:800;font-size:32px;letter-spacing:-1.2px;color:var(--tx)}
.greet .actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}

.mini-btn{display:inline-flex;align-items:center;gap:8px;padding:9px 15px;border-radius:13px;font-family:var(--display);font-weight:600;font-size:13px;color:var(--tx);text-decoration:none;cursor:pointer;
  background:var(--ins);border:1px solid var(--ins-brd);box-shadow:inset 0 1px 0 var(--rim)}
.mini-btn.violet{background:linear-gradient(135deg,var(--violet),var(--violet-soft));color:#fff;border-color:transparent;
  box-shadow:0 8px 22px -6px rgba(124,99,235,.55), inset 0 1px 0 rgba(255,255,255,.45)}
.mini-btn:hover{transform:translateY(-1px)}
/* Estados de feedback do botão (salvar configurações etc.) — 2026-06-05 */
.mini-btn:disabled{cursor:default;opacity:.75;transform:none}
.mini-btn[data-loading]{cursor:wait;opacity:.85;transform:none}
.mini-btn.saved-ok{background:linear-gradient(135deg,#2dd4bf,#10b981)!important;color:#fff!important;border-color:transparent!important;box-shadow:0 6px 18px rgba(16,185,129,.28)!important}

.gcard{position:relative;overflow:hidden;border-radius:24px;padding:24px;
  background:var(--g-bg);backdrop-filter:var(--g-blur);-webkit-backdrop-filter:var(--g-blur);
  border:1px solid var(--g-brd);box-shadow:var(--g-shadow)}
.gcard::after{content:'';position:absolute;top:-70%;left:-25%;width:55%;height:200%;pointer-events:none;
  background:linear-gradient(112deg,transparent,rgba(255,255,255,0.32) 48%,transparent 62%);transform:rotate(6deg)}
[data-theme^="dark"] .gcard::after{background:linear-gradient(112deg,transparent,rgba(255,255,255,0.12) 48%,transparent 62%)}
.row-2{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.row-3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}

.card-head{position:relative;z-index:2;display:flex;align-items:center;gap:12px;margin-bottom:14px}
.card-head .ico{width:42px;height:42px;border-radius:13px;display:flex;align-items:center;justify-content:center;color:#fff;background:linear-gradient(135deg,var(--violet),var(--violet-soft));box-shadow:inset 0 1px 0 rgba(255,255,255,.4)}
.card-head .ico svg{width:20px;height:20px}
.card-head .lab{font-family:var(--display);font-size:10px;font-weight:600;letter-spacing:1.4px;text-transform:uppercase;color:var(--violet)}
.card-head h3{font-family:var(--display);font-weight:700;font-size:21px;letter-spacing:-.5px;color:var(--tx)}
.card-head .right{margin-left:auto}

.kpis{display:grid;grid-template-columns:repeat(5,1fr);gap:14px}
.kpi{position:relative;overflow:hidden;border-radius:20px;padding:18px;background:var(--g-bg);backdrop-filter:var(--g-blur);-webkit-backdrop-filter:var(--g-blur);border:1px solid var(--g-brd);box-shadow:var(--g-shadow)}
.kpi .t{font-family:var(--display);font-size:9.5px;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--tx3);display:flex;align-items:center;gap:7px;margin-bottom:12px;position:relative;z-index:2}
.kpi .t .i{width:24px;height:24px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;background:linear-gradient(135deg,var(--violet),var(--violet-soft))}
.kpi .t .i svg{width:13px;height:13px}
.kpi .n{font-family:var(--display);font-weight:800;font-size:28px;letter-spacing:-1px;color:var(--tx);line-height:1;position:relative;z-index:2}
.kpi .n small{font-size:13px;color:var(--tx3);font-weight:600;margin-left:2px}
.kpi .n .up{font-size:12px;color:var(--teal);font-weight:600}
.kpi .n .down{font-size:12px;color:#d14343;font-weight:600}
.kpi .d{font-size:11.5px;color:var(--tx2);margin-top:6px;line-height:1.4;position:relative;z-index:2}

/* Sparkline (#34) — canto inferior direito do KPI */
.kpi .spark{position:absolute;right:8px;bottom:8px;width:78px;height:22px;opacity:.85;pointer-events:none}
.kpi .spark svg{width:100%;height:100%;display:block}

/* WhatsApp status pill (#35) */
.wa-status-pill{display:inline-flex;align-items:center;gap:8px;padding:6px 12px;border-radius:999px;font-family:var(--display);font-weight:600;font-size:12px;border:1px solid;backdrop-filter:blur(10px)}
.wa-status-pill.on{background:rgba(46,163,124,.08);border-color:rgba(46,163,124,.25);color:var(--teal,#2EA37C)}
.wa-status-pill.warn{background:rgba(194,130,10,.08);border-color:rgba(194,130,10,.25);color:#c2820a}
.wa-status-pill.off{background:rgba(209,67,67,.08);border-color:rgba(209,67,67,.25);color:#d14343}
.wa-status-pill .wa-sub{color:var(--tx2);font-weight:500;font-size:11.5px}
.wa-status-pill a{color:inherit;text-decoration:none;font-weight:700}
.wa-status-pill a:hover{text-decoration:underline}
.wa-dot{width:8px;height:8px;border-radius:50%;background:currentColor;box-shadow:0 0 0 0 currentColor;animation:wa-pulse 2.2s ease-out infinite}
.wa-status-pill.off .wa-dot{animation:none}
.wa-status-pill .wa-dot.warn{background:#c2820a;animation:none}
@keyframes wa-pulse{0%{box-shadow:0 0 0 0 currentColor}70%{box-shadow:0 0 0 6px transparent}100%{box-shadow:0 0 0 0 transparent}}

/* Dashboard alerts card (#36) */
.dash-alerts{display:flex;flex-direction:column;gap:8px;margin-bottom:6px}
.dash-alert{display:flex;align-items:center;gap:14px;padding:14px 18px;border-radius:16px;text-decoration:none;border:1px solid;backdrop-filter:blur(14px);transition:transform .15s ease,box-shadow .15s ease}
.dash-alert:hover{transform:translateY(-1px);box-shadow:0 8px 22px rgba(20,40,72,.06)}
.dash-alert.sev-high{background:linear-gradient(135deg,rgba(242,106,46,.10),rgba(242,106,46,.03));border-color:rgba(242,106,46,.28)}
.dash-alert.sev-med{background:linear-gradient(135deg,rgba(124,99,235,.08),rgba(124,99,235,.02));border-color:rgba(124,99,235,.25)}
.dash-alert.sev-low{background:rgba(255,255,255,.4);border-color:var(--g-brd)}
.da-ico{font-size:22px;flex-shrink:0;width:38px;height:38px;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.55);border-radius:12px;border:1px solid var(--g-brd)}
.da-body{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}
.da-title{font-family:var(--display);font-weight:700;font-size:14px;color:var(--tx);line-height:1.3}
.da-sub{font-size:12.5px;color:var(--tx2);line-height:1.45}
.da-arrow{font-family:var(--display);font-weight:700;color:var(--violet);font-size:18px;flex-shrink:0}

/* Time saved card (#35) */
.time-saved-card{display:none;align-items:center;gap:18px;padding:20px 24px;border-radius:20px;background:linear-gradient(135deg,rgba(46,163,124,.10),rgba(124,99,235,.04));border:1px solid rgba(46,163,124,.22);backdrop-filter:blur(12px);box-shadow:0 8px 22px rgba(46,163,124,.05);position:relative;overflow:hidden}
.time-saved-card::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 100% 50%, rgba(46,163,124,.06), transparent 60%);pointer-events:none}
.ts-ico{flex-shrink:0;width:54px;height:54px;border-radius:16px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--teal,#2EA37C),#3FB890);color:#fff;box-shadow:0 6px 18px rgba(46,163,124,.3);position:relative;z-index:2}
.ts-body{flex:1;display:flex;flex-direction:column;gap:4px;position:relative;z-index:2;min-width:0}
.ts-lab{font-family:var(--display);font-weight:600;font-size:10.5px;letter-spacing:1.2px;text-transform:uppercase;color:var(--teal,#2EA37C)}
.ts-val{font-family:var(--display);font-weight:800;font-size:22px;color:var(--tx);line-height:1.15}
.ts-val small{font-weight:500;font-size:14px;color:var(--tx2);margin-left:4px}
.ts-sub{font-size:12.5px;color:var(--tx2);line-height:1.4}
.ts-meta{font-family:var(--display);font-weight:500;font-size:13px;color:var(--tx2);text-align:right;line-height:1.35;position:relative;z-index:2;flex-shrink:0}
.ts-meta strong{font-weight:800;font-size:16px;color:var(--teal,#2EA37C);display:block}
.ts-meta small{font-size:11px;color:var(--tx3)}

/* ===== CONVERSATIONS LIST ===== */
.conv-list{display:flex;flex-direction:column;gap:6px;position:relative;z-index:2}
.conv-row{display:grid;grid-template-columns:auto 1fr auto auto;gap:14px;align-items:center;padding:11px 12px;border-radius:14px;text-decoration:none;color:inherit;transition:background .15s}
.conv-row:hover{background:var(--ins)}
.conv-row.unread{background:var(--ins);box-shadow:inset 0 1px 0 var(--rim)}
.conv-av{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-family:var(--display);font-weight:700;font-size:13px;flex:0 0 auto}
.conv-av.v{background:linear-gradient(135deg,var(--violet),var(--violet-soft))}
.conv-av.o{background:linear-gradient(135deg,var(--orange),var(--orange-soft))}
.conv-av.n{background:linear-gradient(135deg,var(--navy),var(--navy-soft))}
.conv-av.t{background:linear-gradient(135deg,var(--teal),var(--teal-soft))}
.conv-body{min-width:0}
.conv-name{font-family:var(--display);font-weight:600;font-size:13.5px;color:var(--tx);line-height:1.1;display:flex;align-items:center;gap:8px}
.conv-prev{font-size:12.5px;color:var(--tx3);line-height:1.3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-top:3px}
.conv-time{font-size:11px;color:var(--tx3);font-family:var(--display)}
.conv-tag{font-family:var(--display);font-size:9.5px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;padding:3px 8px;border-radius:8px}
.conv-tag.hot{color:#fff;background:linear-gradient(135deg,#F26A2E,#FB8E5C)}
.conv-tag.ia{color:var(--violet);background:rgba(124,99,235,0.14);border:1px solid rgba(124,99,235,0.3)}
.conv-tag.human{color:var(--teal);background:rgba(29,158,117,0.14);border:1px solid rgba(29,158,117,0.3)}
.conv-tag.done{color:var(--tx3);background:var(--ins);border:1px solid var(--ins-brd)}

/* ===== CHAT VIEWER ===== */
.chat-wrap{display:grid;grid-template-columns:1fr 1.6fr;gap:18px;min-height:600px}
.chat-list{padding:14px;display:flex;flex-direction:column;gap:4px;max-height:760px;overflow:auto}
.chat-detail{padding:0;display:flex;flex-direction:column;overflow:hidden}
.chat-head{padding:18px 22px;border-bottom:1px solid var(--ins-brd);display:flex;align-items:center;gap:14px;position:relative;z-index:2}
.chat-head .who{font-family:var(--display);font-weight:700;font-size:17px;color:var(--tx)}
.chat-head .meta{font-size:11.5px;color:var(--tx3)}
.chat-thread{padding:22px;flex:1;overflow:auto;display:flex;flex-direction:column;gap:12px}
.bubble{max-width:78%;padding:10px 14px;border-radius:16px;font-size:13.5px;line-height:1.45}
.bubble.in{align-self:flex-start;background:var(--ins);color:var(--tx);border:1px solid var(--ins-brd);border-bottom-left-radius:4px}
.bubble.out{align-self:flex-end;background:linear-gradient(135deg,var(--violet),var(--violet-soft));color:#fff;border-bottom-right-radius:4px}
.bubble .ts{display:block;font-size:10px;opacity:.7;margin-top:4px}
.chat-foot{padding:14px 22px;border-top:1px solid var(--ins-brd);display:flex;align-items:center;gap:10px}
.chat-foot .info{flex:1;font-size:12.5px;color:var(--tx2)}

/* ===== LEADS ===== */
.pipeline{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.pipe-col{display:flex;flex-direction:column;gap:10px}
.pipe-h{display:flex;align-items:center;justify-content:space-between;padding:4px 8px;font-family:var(--display);font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--tx2)}
.pipe-h .ct{padding:2px 8px;border-radius:8px;background:var(--ins);color:var(--tx);font-size:10.5px}
.lead{padding:13px;border-radius:14px;background:var(--g-bg);border:1px solid var(--g-brd);box-shadow:var(--g-shadow);display:flex;flex-direction:column;gap:6px;text-decoration:none;color:inherit}
.lead .n{font-family:var(--display);font-weight:600;font-size:13.5px;color:var(--tx)}
.lead .d{font-size:12px;color:var(--tx2);line-height:1.35}
.lead .row{display:flex;align-items:center;justify-content:space-between;font-size:10.5px;color:var(--tx3);font-family:var(--display)}
.lead .row .val{color:var(--tx);font-weight:600}

/* ===== KNOWLEDGE BASE WIZARD ===== */
.kb-progress{display:flex;gap:6px;margin-bottom:6px}
.kb-progress .dot{flex:1;height:4px;border-radius:2px;background:var(--ins);border:1px solid var(--ins-brd)}
.kb-progress .dot.done{background:linear-gradient(90deg,var(--violet),var(--violet-soft));border-color:transparent}
.kb-section{display:flex;flex-direction:column;gap:14px}
.kb-section h3{font-family:var(--display);font-weight:700;font-size:19px;letter-spacing:-.3px;color:var(--tx)}
.kb-section .hint{font-size:13px;color:var(--tx2)}
.kb-field{display:flex;flex-direction:column;gap:5px}
.kb-field label{font-family:var(--display);font-size:11px;font-weight:600;letter-spacing:.5px;text-transform:uppercase;color:var(--tx3)}
.kb-field input,.kb-field select,.kb-field textarea{padding:11px 14px;border-radius:12px;background:var(--ins);border:1px solid var(--ins-brd);color:var(--tx);font-family:var(--body);font-size:13.5px;outline:none}
.kb-field textarea{resize:vertical;min-height:80px;line-height:1.5}
.kb-field input:focus,.kb-field select:focus,.kb-field textarea:focus{border-color:var(--violet);box-shadow:0 0 0 3px rgba(124,99,235,.18)}
.kb-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}

/* ===== SETTINGS / PLAN ===== */
.plan-card{padding:24px;border-radius:24px;background:linear-gradient(135deg,rgba(124,99,235,.16),rgba(168,156,255,.08));border:1.5px solid rgba(124,99,235,.4);position:relative;overflow:hidden}
.plan-card::after{content:'';position:absolute;inset:0;background:linear-gradient(112deg,transparent,rgba(255,255,255,.3) 48%,transparent 62%);pointer-events:none}
.plan-card .h{font-family:var(--display);font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--violet);position:relative;z-index:2}
.plan-card .nm{font-family:var(--display);font-weight:800;font-size:32px;letter-spacing:-1px;color:var(--tx);position:relative;z-index:2;margin-top:4px}
.plan-card .pr{font-family:var(--display);font-size:20px;color:var(--tx2);position:relative;z-index:2;margin-top:8px}
.plan-card .pr b{color:var(--tx);font-weight:700;font-size:26px}
.plan-card .ft{position:relative;z-index:2;display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}
.plan-card .ft span{font-size:11px;color:var(--tx);background:rgba(255,255,255,0.5);padding:5px 10px;border-radius:10px;border:1px solid var(--ins-brd)}

.tile{padding:18px;border-radius:18px;background:var(--ins);border:1px solid var(--ins-brd);display:flex;flex-direction:column;gap:6px}
.tile .t{font-family:var(--display);font-size:10.5px;font-weight:600;letter-spacing:1.2px;text-transform:uppercase;color:var(--tx3)}
.tile .v{font-family:var(--display);font-weight:700;font-size:18px;color:var(--tx)}
.tile .s{font-size:12px;color:var(--tx2)}

/* ===== THEME SWITCH =====
 * Por padrão (em login/signup, fora do topbar): fixed no canto inferior direito.
 * Quando o gia-app.js move o elemento pra dentro do .topbar (em páginas autenticadas),
 * o override .topbar .theme-switch reseta pra inline-flex sem position:fixed,
 * pra ficar in-flow do flex do topbar e não sobrepor o avatar/nome do usuário.
 */
.theme-switch{position:fixed;bottom:18px;right:18px;z-index:100;display:flex;gap:4px;padding:5px;border-radius:16px;
  background:var(--g-bg-strong);backdrop-filter:var(--g-blur);-webkit-backdrop-filter:var(--g-blur);border:1px solid var(--g-brd);box-shadow:var(--g-shadow)}
.theme-switch button{border:none;background:transparent;color:var(--tx2);font-family:var(--display);font-weight:600;font-size:12px;padding:8px 13px;border-radius:12px;cursor:pointer;display:flex;align-items:center;gap:6px}
.theme-switch button.active{background:var(--ins);color:var(--tx)}
.theme-switch .sw-dot{width:11px;height:11px;border-radius:50%;display:inline-block}
.sw-l{background:linear-gradient(135deg,#fdf0e7,#e9eefb);border:1px solid #c9d3ea}
.sw-n{background:#102246} .sw-c{background:#15171f}

/* Override: dentro do topbar (movido via JS pelo gia-app.js) */
.topbar .theme-switch{position:static;bottom:auto;right:auto;background:transparent;border:none;box-shadow:none;backdrop-filter:none;-webkit-backdrop-filter:none;padding:2px;gap:2px;z-index:auto}
.topbar .theme-switch button{padding:6px 10px;font-size:11.5px;background:var(--ins);border:1px solid var(--ins-brd)}
.topbar .theme-switch button.active{background:var(--g-bg-strong);color:var(--tx);border-color:var(--g-brd)}
.topbar .theme-switch .sw-dot{width:9px;height:9px}
/* 2026-06-07 — contraste no modo claro: Navy/Carbon ficavam camuflados */
[data-theme="light"] .theme-switch button{color:#3f4b6e}
[data-theme="light"] .theme-switch button:not(.active):hover{color:#142848}
[data-theme="light"] .topbar .theme-switch button{background:rgba(20,40,72,.07);border-color:rgba(20,40,72,.16)}
[data-theme="light"] .theme-switch button.active{color:#142848;background:#fff;border-color:rgba(20,40,72,.2);box-shadow:0 2px 8px rgba(10,12,30,.1)}
@media(max-width:980px){.topbar .theme-switch button span.lbl{display:none}}
@media(max-width:640px){.topbar .theme-switch{display:none}}

@media(max-width:1400px){.kpis{grid-template-columns:repeat(3,1fr)}}
@media(max-width:1100px){.kpis{grid-template-columns:repeat(2,1fr)}.pipeline{grid-template-columns:repeat(2,1fr)}.row-2,.row-3,.kb-grid-2{grid-template-columns:1fr}.chat-wrap{grid-template-columns:1fr}.time-saved-card{flex-wrap:wrap}.ts-meta{flex-basis:100%;text-align:left;margin-top:6px}}
@media(max-width:560px){.kpis{grid-template-columns:1fr}}
@media(max-width:760px){.shell{padding:12px}.theme-switch button span.lbl{display:none}}

/* ===== LOGIN ===== */
body.gia-login{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:24px}
.login-card{position:relative;overflow:hidden;width:100%;max-width:980px;border-radius:30px;display:grid;grid-template-columns:.95fr 1fr;
  background:var(--g-bg-strong);backdrop-filter:var(--g-blur);-webkit-backdrop-filter:var(--g-blur);
  border:1px solid var(--g-brd);box-shadow:0 44px 100px -30px rgba(20,40,72,.55), inset 0 1px 1px rgba(255,255,255,.92)}
.login-card::after{content:'';position:absolute;top:-70%;left:-25%;width:55%;height:200%;pointer-events:none;
  background:linear-gradient(112deg,transparent,rgba(255,255,255,0.32) 48%,transparent 62%);transform:rotate(6deg)}
.login-brand{position:relative;z-index:2;padding:40px 36px;display:flex;flex-direction:column;justify-content:space-between;
  min-height:560px;overflow:hidden;
  /* Hero da Gia (avatar-login.jpg) com scrim violeta: claro no meio pra mostrar
     a personagem, mais escuro no topo (logo) e na base (texto+selos). O gradiente
     sólido no fim é fallback caso a imagem não carregue. */
  background:
    linear-gradient(160deg,rgba(124,99,235,.62) 0%,rgba(110,84,224,.20) 38%,rgba(74,54,170,.55) 72%,rgba(64,46,150,.94) 100%),
    url('avatar-login.jpg') 50% 16%/cover no-repeat,
    linear-gradient(160deg,rgba(124,99,235,.95) 0%,rgba(88,64,201,.95) 100%);
  color:#fff}
.login-brand .pitch{margin-top:auto;text-shadow:0 2px 14px rgba(40,24,96,.55)}
.login-brand .top .tg,.login-brand .pitch .lab,.login-brand .pitch p{text-shadow:0 1px 10px rgba(40,24,96,.45)}
.login-brand .top{display:flex;align-items:center;gap:10px}
.login-brand .top .wm{font-family:var(--display);font-weight:700;font-size:17px}
.login-brand .top .wm .dot{color:#FB8E5C}
.login-brand .top .tg{display:block;font-size:8px;letter-spacing:1.8px;color:rgba(255,255,255,.7);font-weight:600;margin-top:2px}
.login-brand .pitch{position:relative;z-index:2}
.login-brand .pitch .lab{font-family:var(--display);font-size:10px;letter-spacing:2px;color:rgba(255,255,255,.7);text-transform:uppercase;font-weight:600;margin-bottom:14px;display:block}
.login-brand .pitch h2{font-family:var(--display);font-weight:700;font-size:30px;letter-spacing:-.5px;line-height:1.15;text-wrap:balance}
.login-brand .pitch p{font-size:13.5px;line-height:1.55;color:rgba(255,255,255,.82);margin-top:14px;max-width:340px}
.login-brand .seal{display:flex;align-items:center;gap:12px;font-size:11px;color:rgba(255,255,255,.7);font-family:var(--display)}
.login-brand .seal .s{padding:4px 10px;border-radius:10px;background:rgba(255,255,255,.15);font-weight:600}
.login-form{position:relative;z-index:2;padding:44px 48px;display:flex;flex-direction:column;justify-content:center;gap:14px}
.login-form h1{font-family:var(--display);font-weight:700;font-size:26px;letter-spacing:-.4px;color:var(--tx)}
.login-form .sub{font-size:13.5px;color:var(--tx2);margin-bottom:8px}
.login-form .row{display:flex;flex-direction:column;gap:5px}
.login-form .row label{font-family:var(--display);font-size:11px;font-weight:600;letter-spacing:.5px;text-transform:uppercase;color:var(--tx3)}
.login-form .row input{padding:13px 14px;border-radius:13px;background:var(--ins);border:1px solid var(--ins-brd);color:var(--tx);font-family:var(--body);font-size:14px;outline:none}
.login-form .row input:focus{border-color:var(--violet);box-shadow:0 0 0 3px rgba(124,99,235,.18)}
.login-form .forgot{font-size:12px;color:var(--violet);text-decoration:none;font-weight:600;align-self:flex-end}
.login-form .submit{margin-top:10px;width:100%;padding:14px;border-radius:14px;border:none;cursor:pointer;
  font-family:var(--display);font-weight:600;font-size:14.5px;color:#fff;
  background:linear-gradient(135deg,var(--violet),var(--violet-soft));
  box-shadow:0 14px 30px -10px rgba(124,99,235,.6), inset 0 1px 0 rgba(255,255,255,.45);transition:.2s}
.login-form .submit:hover{transform:translateY(-1px);box-shadow:0 18px 36px -10px rgba(124,99,235,.72), inset 0 1px 0 rgba(255,255,255,.55)}
.login-form .sep{display:flex;align-items:center;gap:12px;margin:8px 0;font-size:11px;color:var(--tx3);font-family:var(--display)}
.login-form .sep::before,.login-form .sep::after{content:'';flex:1;height:1px;background:var(--ins-brd)}
.login-form .sso{display:flex;gap:10px}
.login-form .sso a{flex:1;padding:11px;text-align:center;border-radius:12px;background:var(--ins);border:1px solid var(--ins-brd);font-family:var(--display);font-weight:600;font-size:12.5px;color:var(--tx);text-decoration:none}
.login-form .bottom{margin-top:10px;font-size:12.5px;color:var(--tx2)}
.login-form .bottom a{color:var(--violet);font-weight:600;text-decoration:none}

@media(max-width:780px){.login-card{grid-template-columns:1fr}.login-brand{padding:28px;min-height:300px;background-position:50% 14%, 50% 14%, 0 0}.login-form{padding:32px}}

/* ===== Leads — vista LISTA enriquecida + KANBAN (v3 05/06/2026) ===== */
/* legado .lead-row mantido p/ retrocompat — novo card é .lead-card */
.lead-row{padding:14px;border-radius:14px;background:var(--g-bg);border:1px solid var(--g-brd);box-shadow:var(--g-shadow);display:flex;flex-direction:column;gap:7px;margin-bottom:10px}
.lead-head{display:flex;align-items:center;justify-content:space-between;gap:10px}
.lead-name{font-family:var(--display);font-weight:600;font-size:14px;color:var(--tx)}
.lead-company{font-weight:400;color:var(--tx3);font-size:12px}
.lead-tag{font-family:var(--display);font-weight:700;font-size:9.5px;letter-spacing:.08em;padding:3px 9px;border-radius:999px;text-transform:uppercase}
.lead-tag.orange{background:rgba(242,106,46,.14);color:#f28b54}
.lead-tag.violet{background:rgba(124,99,235,.16);color:#a795f5}
.lead-tag.teal{background:rgba(45,212,191,.14);color:#5eead4}
.lead-tag.gray{background:rgba(148,163,184,.14);color:#94a3b8}
.lead-sub{font-size:12.5px;color:var(--tx2);line-height:1.4}
.lead-meta{display:flex;align-items:center;justify-content:space-between;gap:10px;font-size:11px;color:var(--tx3)}
.lead-status-sel{background:var(--g-bg);border:1px solid var(--g-brd);color:var(--tx);font-family:var(--display);font-size:11.5px;border-radius:9px;padding:5px 8px;outline:none;cursor:pointer}
.lead-status-sel:focus{border-color:#7C63EB}

/* Toggle Lista ↔ Kanban */
.lead-view-toggle{display:inline-flex;background:var(--ins);border:1px solid var(--g-brd);border-radius:10px;padding:3px;gap:2px}
.lead-view-toggle button{background:transparent;border:none;color:var(--tx2);font-family:var(--display);font-weight:600;font-size:12px;padding:6px 11px;border-radius:8px;display:inline-flex;align-items:center;gap:6px;cursor:pointer}
.lead-view-toggle button:hover{color:var(--tx)}
.lead-view-toggle button.active{background:var(--g-bg);color:var(--tx);box-shadow:0 1px 4px rgba(0,0,0,.07)}
.lead-view-toggle button svg{stroke-linecap:round;stroke-linejoin:round}

/* Card de lead RICO (.lead-card) — usado em ambas as vistas */
.lead-card{position:relative;padding:14px 16px;border-radius:16px;background:var(--g-bg);border:1px solid var(--g-brd);box-shadow:var(--g-shadow);display:flex;flex-direction:column;gap:10px;cursor:grab;transition:transform .15s ease, box-shadow .15s ease, border-color .15s ease}
.lead-card:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(124,99,235,.08)}
.lead-card.dragging{opacity:.55;cursor:grabbing}
.lead-card.new{border-color:rgba(242,106,46,.4)}
.lead-card.contacted{border-color:rgba(124,99,235,.32)}
.lead-card.won{border-color:rgba(45,212,191,.32)}
.lead-card.lost{border-color:rgba(148,163,184,.32)}

.lead-card-head{display:flex;align-items:center;gap:10px}
.lead-av{flex-shrink:0;width:34px;height:34px;border-radius:50%;display:grid;place-items:center;font-family:var(--display);font-weight:700;font-size:13.5px;color:#fff;background:linear-gradient(135deg,#7C63EB,#9A84F5)}
.lead-av.orange{background:linear-gradient(135deg,#F26A2E,#FB8E5C)}
.lead-av.violet{background:linear-gradient(135deg,#7C63EB,#9A84F5)}
.lead-av.teal{background:linear-gradient(135deg,#2DD4BF,#5EEAD4)}
.lead-av.gray{background:linear-gradient(135deg,#94A3B8,#CBD5E1)}
.lead-id{flex:1;min-width:0}
.lead-contact{font-size:11.5px;color:var(--tx3);margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

.lead-card-body{display:flex;flex-direction:column;gap:8px}
.lead-interest{margin:0;font-size:13px;color:var(--tx2);line-height:1.45;padding:9px 11px;background:var(--ins);border-radius:10px}
.lead-facts{margin:0;padding-left:0;list-style:none;display:flex;flex-direction:column;gap:4px;font-size:11.5px;color:var(--tx2)}
.lead-facts li{padding:3px 0}
.lead-facts strong{color:var(--tx);font-weight:600}
.lead-tags{display:flex;flex-wrap:wrap;gap:5px}
.lead-tag-pill{font-size:10.5px;background:rgba(124,99,235,.10);color:#a795f5;padding:2px 8px;border-radius:8px;font-family:var(--display);font-weight:500}

.lead-card-foot{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:8px;border-top:1px solid var(--g-brd);padding-top:9px;margin-top:2px}
.lead-stamps{display:flex;flex-wrap:wrap;gap:13px;font-size:10.8px;color:var(--tx3)}
.lead-actions{display:flex;gap:6px;align-items:center;flex-wrap:wrap}

/* KANBAN */
.kanban-board{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-top:6px}
@media(max-width:1100px){.kanban-board{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.kanban-board{grid-template-columns:1fr}}
.kanban-col{display:flex;flex-direction:column;background:var(--g-bg);border:1px solid var(--g-brd);border-radius:14px;overflow:hidden;min-height:240px}
.kanban-col-head{display:flex;align-items:center;gap:8px;padding:11px 14px;font-family:var(--display);font-weight:600;font-size:12.5px;color:var(--tx);background:var(--ins);border-bottom:1px solid var(--g-brd)}
.kanban-dot{width:8px;height:8px;border-radius:50%}
.kanban-dot.orange{background:#F26A2E}
.kanban-dot.violet{background:#7C63EB}
.kanban-dot.teal{background:#2DD4BF}
.kanban-dot.gray{background:#94A3B8}
.kanban-count{margin-left:auto;background:var(--g-bg);color:var(--tx2);font-size:11px;padding:2px 9px;border-radius:999px;border:1px solid var(--g-brd)}
.kanban-col-body{flex:1;padding:10px;display:flex;flex-direction:column;gap:9px;transition:background .15s ease}
.kanban-col-body.drag-over{background:rgba(124,99,235,.06)}
.kanban-empty{text-align:center;font-size:11.5px;color:var(--tx3);padding:24px 8px;opacity:.7}


/* ===== Modal de conversa — estilo landing GIA, light+dark (v2 04/06/2026) ===== */
.convm-overlay{position:fixed;inset:0;background:rgba(10,12,24,.45);backdrop-filter:blur(7px);-webkit-backdrop-filter:blur(7px);display:none;align-items:center;justify-content:center;z-index:1000;padding:20px}
.convm-overlay.open{display:flex}
.convm{width:min(640px,100%);max-height:84vh;display:flex;flex-direction:column;border-radius:20px;background:var(--g-bg-strong);backdrop-filter:blur(22px);-webkit-backdrop-filter:blur(22px);border:1px solid var(--g-brd);box-shadow:0 24px 80px rgba(10,12,30,.35)}
.convm-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:16px 18px;border-bottom:1px solid var(--g-brd)}
.convm-name{font-family:var(--display);font-size:15px;font-weight:700;color:var(--tx);margin:0}
.convm-sub{font-size:11.5px;color:var(--tx3)}
.convm-head-r{display:flex;align-items:center;gap:10px}
.convm-actions{display:flex;gap:8px}
.convm-close{background:none;border:none;color:var(--tx2);font-size:22px;cursor:pointer;line-height:1;padding:2px 9px;border-radius:8px}
.convm-close:hover{background:var(--ins);color:var(--tx)}
.convm-body{overflow-y:auto;padding:18px;display:flex;flex-direction:column;gap:12px}
.convm-msg{display:flex;flex-direction:column;max-width:78%}
.convm-msg.in{align-self:flex-start;align-items:flex-start}
.convm-msg.out{align-self:flex-end;align-items:flex-end}
.convm-bubble{padding:10px 14px;border-radius:16px;font-size:13.5px;line-height:1.5;white-space:pre-wrap;word-break:break-word}
.convm-msg.in .convm-bubble{background:var(--ins);border:1px solid var(--ins-brd);color:var(--tx);border-bottom-left-radius:6px;box-shadow:0 2px 10px rgba(20,30,60,.06)}
.convm-msg.out .convm-bubble{background:linear-gradient(135deg,#7C63EB,#9b87f7);border:none;color:#fff;border-bottom-right-radius:6px;box-shadow:0 4px 14px rgba(124,99,235,.30)}
.convm-time{font-size:10.5px;color:var(--tx3);margin-top:4px}
.convm-loading{color:var(--tx2);font-size:13px;text-align:center;padding:24px}
/* Footer de resposta */
.convm-foot{display:flex;gap:10px;align-items:flex-end;padding:14px 18px;border-top:1px solid var(--g-brd)}
.convm-input{flex:1;resize:none;background:var(--ins);border:1px solid var(--ins-brd);border-radius:13px;color:var(--tx);font-size:13.5px;line-height:1.45;padding:11px 14px;outline:none;font-family:inherit;min-height:42px;max-height:120px}
.convm-input::placeholder{color:var(--tx3)}
.convm-input:focus{border-color:rgba(124,99,235,.6)}
.convm-btn{font-family:var(--display);font-size:12.5px;font-weight:600;border-radius:11px;padding:9px 16px;cursor:pointer;border:1px solid var(--g-brd);background:transparent;color:var(--tx2);transition:all .15s}
.convm-btn:hover{color:var(--tx);border-color:rgba(124,99,235,.5)}
.convm-btn.send{background:linear-gradient(135deg,#7C63EB,#9b87f7);border:none;color:#fff;box-shadow:0 4px 14px rgba(124,99,235,.32)}
.convm-btn.send:disabled{opacity:.6;cursor:wait}
/* "digitando" — bolha clara com pontinhos violeta, igual landing */
.convm-typing{display:inline-flex;gap:5px;align-items:center;min-width:48px;min-height:18px}
.convm-typing .dot{width:7px;height:7px;border-radius:50%;background:#7C63EB;animation:convmBlink 1.2s infinite}
.convm-typing .dot:nth-child(2){animation-delay:.2s;opacity:.7}
.convm-typing .dot:nth-child(3){animation-delay:.4s;opacity:.45}
@keyframes convmBlink{0%,80%,100%{opacity:.25}40%{opacity:1}}
/* Fix overflow listas conv-row */
.conv-list{width:100%}
.conv-row{width:100%;box-sizing:border-box;overflow:hidden}
.conv-row > .conv-body{min-width:0;overflow:hidden}
.conv-prev{min-width:0;max-width:100%}

/* ===== Conectar WhatsApp self-service (04/06/2026) ===== */
.wa-channel{padding:16px;border-radius:16px;background:var(--g-bg);border:1px solid var(--g-brd)}
.wa-ch-head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px}
.wa-ch-head h3{margin:0 0 5px;font-family:var(--display);font-size:14.5px;color:var(--tx);display:flex;align-items:center;gap:8px}
.wa-ch-desc{font-size:12.5px;color:var(--tx2);line-height:1.5;max-width:520px;margin:0}
.wa-ch-tag{font-family:var(--display);font-size:9px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;padding:3px 8px;border-radius:999px;background:rgba(124,99,235,.16);color:#7C63EB}
.wa-ch-tag.gray{background:rgba(148,163,184,.16);color:var(--tx3)}
.wa-ch-actions{margin-top:13px;display:flex;gap:10px}
.badge.violet{background:rgba(124,99,235,.14);color:#7C63EB}

/* ===== Toasts & confirm do app (04/06/2026) ===== */
#gia-toasts{position:fixed;bottom:22px;right:22px;display:flex;flex-direction:column;gap:10px;z-index:1400}
.gia-toast{min-width:230px;max-width:380px;padding:12px 16px;border-radius:13px;background:var(--g-bg-strong);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);border:1px solid var(--g-brd);color:var(--tx);font-size:13px;line-height:1.45;box-shadow:0 12px 36px rgba(10,12,30,.25);opacity:0;transform:translateY(8px);transition:all .25s}
.gia-toast.show{opacity:1;transform:none}
.gia-toast.error{border-left:3px solid #e25563}
.gia-toast.success{border-left:3px solid #2dd4bf}
.gia-toast.info{border-left:3px solid #7C63EB}
/* z-index 100000 (2026-06-05): confirm fica ACIMA de qualquer modal/drawer (etapas=9991, drawer=9990) - antes 1300 e a confirmacao abria POR BAIXO do modal de etapas */
.giac-overlay{position:fixed;inset:0;background:rgba(10,12,24,.45);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:100000;padding:20px}
.giac{width:min(420px,100%);border-radius:18px;background:var(--g-bg-strong);backdrop-filter:blur(22px);-webkit-backdrop-filter:blur(22px);border:1px solid var(--g-brd);box-shadow:0 24px 70px rgba(10,12,30,.4);padding:22px}
.giac-msg{margin:0 0 18px;font-size:14px;color:var(--tx);line-height:1.55}
.giac-actions{display:flex;justify-content:flex-end;gap:10px}
.giac-btn{font-family:var(--display);font-size:12.5px;font-weight:600;border-radius:11px;padding:9px 16px;cursor:pointer;border:1px solid var(--g-brd);background:transparent;color:var(--tx2)}
.giac-btn:hover{color:var(--tx)}
.giac-btn.yes{background:linear-gradient(135deg,#7C63EB,#9b87f7);border:none;color:#fff;box-shadow:0 4px 14px rgba(124,99,235,.3)}

/* ===== Telas largas / zoom-out (2026-06-05) =====
   O design é px-based com shell de 1500px — em monitores grandes (ou zoom do
   navegador <100%) o app flutuava minúsculo no centro. Agora: o shell cresce
   até 1900px e, além disso, a UI INTEIRA escala proporcionalmente via zoom
   (Chrome/Safari/Edge/Firefox 126+). --app-zoom compensa alturas em vh. */
:root{--app-zoom:1}
@media(min-width:1760px){.shell{max-width:1700px}}
@media(min-width:2000px){.shell{max-width:1900px}}
@media(min-width:2300px){body{zoom:1.18}:root{--app-zoom:1.18}}
@media(min-width:2900px){body{zoom:1.38}:root{--app-zoom:1.38}}
@media(min-width:3500px){body{zoom:1.6}:root{--app-zoom:1.6}}
@media(min-width:4200px){body{zoom:1.85}:root{--app-zoom:1.85}}

/* ===================================================================
   RESPONSIVO COMPLETO — telefone + tablet (2026-06-05)
   O gia-app.js injeta hambúrguer (.tb-hamburger), gaveta (body.nav-open)
   e backdrop (.nav-backdrop) — este bloco dá o CSS que faltava pra eles
   existirem de verdade, e densifica o layout em telas pequenas.
   =================================================================== */

/* ---- Tablet paisagem / telas médias (até 1180px): sidebar mais enxuta ---- */
@media(max-width:1180px) and (min-width:901px){
  .sidebar{flex-basis:212px}
  .shell{gap:14px;padding:14px}
}

/* ---- Tablet retrato + celular (≤900px): sidebar vira GAVETA ---- */
.tb-hamburger{display:none}
@media(max-width:900px){
  .tb-hamburger{display:grid;place-items:center;width:40px;height:40px;flex-shrink:0;border-radius:12px;
    background:var(--ins);border:1px solid var(--ins-brd);color:var(--tx);cursor:pointer}
  .tb-hamburger svg{width:20px;height:20px}
  .sidebar{display:flex;position:fixed;top:0;left:0;bottom:0;height:100vh;height:100dvh;width:min(300px,84vw);
    z-index:1200;margin:0;border-radius:0 22px 22px 0;transform:translateX(-105%);transition:transform .26s ease;
    box-shadow:14px 0 40px rgba(8,12,28,.35)}
  body.nav-open .sidebar{transform:translateX(0)}
  .nav-backdrop{position:fixed;inset:0;z-index:1100;background:rgba(8,12,28,.5);backdrop-filter:blur(2px);
    opacity:0;pointer-events:none;transition:opacity .2s}
  body.nav-open .nav-backdrop{opacity:1;pointer-events:auto}
  body.nav-open{overflow:hidden}

  /* topbar compacto: busca vira botão-ícone (o texto some via font-size:0) */
  .topbar{gap:10px;padding:9px 12px;top:10px}
  .topbar .title{font-size:17px;letter-spacing:-.3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .tb-search{flex:none;margin-left:auto;width:40px;height:40px;max-width:40px;padding:0;justify-content:center;font-size:0;gap:0}
  .tb-search .kbd{display:none}
  .tb-search::before{content:"🔍";font-size:16px;line-height:1}
  .tb-user .nm{display:none}
}

/* ---- Celular (≤640px): densidade e toque ---- */
@media(max-width:640px){
  .shell{padding:10px;padding-bottom:max(10px, env(safe-area-inset-bottom))}
  .content{gap:12px}
  .greet h1{font-size:24px}
  .greet{flex-wrap:wrap;gap:10px}
  .greet .actions{width:100%;display:flex;gap:8px}
  .greet .actions .mini-btn{flex:1;justify-content:center;text-align:center}
  .gcard{padding:14px;border-radius:18px}
  /* KPIs em 2 colunas (1 coluna gerava rolagem infinita) */
  .kpis{grid-template-columns:repeat(2,1fr);gap:10px}
  .kpi{padding:12px}
  .kpi .n{font-size:24px}
  /* iOS: inputs <16px causam auto-zoom ao focar — trava em 16px no celular */
  input, select, textarea{font-size:16px !important}
  /* Agenda: células do mês compactas; chips viram pontinho */
  .cal-day{min-height:52px;padding:3px 4px}
  .cal-day .cal-chip{display:none}
  .cal-day:has(.cal-chip)::after{content:"";display:block;width:6px;height:6px;border-radius:50%;
    background:#7C63EB;margin:2px auto 0}
  .cal-more{display:none}
  /* Jornada: colunas com altura menor pra caber 1.5 na tela (incentiva scroll) */
  .jb-col{min-height:240px;max-height:62vh}
  /* drawers/modais ocupam a tela quase toda */
  .jy-drawer{width:100vw;border-left:none;border-radius:0}
  /* tap targets */
  .sb-link{padding:12px 14px;font-size:14.5px}
  a, button{-webkit-tap-highlight-color:rgba(124,99,235,.15)}
}

/* ---- Refinos mobile (2026-06-05, parte 2) ---- */
@media(max-width:900px){
  /* gaveta: scroll interno pro menu inteiro caber */
  .sidebar{overflow-y:auto;-webkit-overflow-scrolling:touch}
}
@media(max-width:640px){
  /* some a busca (afford. de desktop ⌘K) e devolve o seletor de tema como 3 bolinhas */
  .tb-search{display:none}
  .topbar .theme-switch{display:flex;padding:3px;gap:2px}
  /* Alvo de toque (2026-06-07): bolinhas de tema viravam ~23px — abaixo do
     mínimo confortável de 40px no dedo. Mantém o visual de bolinha (dot 11px)
     mas dá um alvo tocável de 40×40. */
  .topbar .theme-switch button{padding:0;min-width:40px;min-height:40px;justify-content:center}
  .topbar .theme-switch button .lbl{display:none}
  /* "Sair" no rodapé da gaveta: alvo maior no toque */
  .sidebar .sb-foot a{display:inline-block;padding:10px 4px;min-height:40px}
}

/* ===== Navegação sem piscada (2026-06-10) =====
   Cross-fade nativo entre páginas (View Transitions MPA). Chrome/Edge 126+ e
   Safari 18.2+ fazem o fade; navegadores antigos simplesmente ignoram. */
@view-transition { navigation: auto; }
@media (prefers-reduced-motion: reduce) {
  ::view-transition-old(root), ::view-transition-new(root) { animation: none; }
}

/* Reveal animation on page load (SPA feel) */
@media (prefers-reduced-motion: no-preference) {
  @keyframes shellReveal {
    from {
      opacity: 0;
      transform: translateY(8px);
    }
    to {
      opacity: 1;
      transform: translateY(0);
    }
  }
  .shell {
    animation: shellReveal 0.28s cubic-bezier(0.16, 1, 0.3, 1) forwards;
  }
}

/* Skeleton & Shimmer loaders */
.shimmer {
  background: linear-gradient(
    90deg,
    rgba(255, 255, 255, 0.05) 25%,
    rgba(255, 255, 255, 0.15) 50%,
    rgba(255, 255, 255, 0.05) 75%
  );
  background-size: 200% 100%;
  animation: shimmer 1.6s infinite linear;
}
[data-theme="light"] .shimmer {
  background: linear-gradient(
    90deg,
    rgba(0, 0, 0, 0.04) 25%,
    rgba(0, 0, 0, 0.09) 50%,
    rgba(0, 0, 0, 0.04) 75%
  );
  background-size: 200% 100%;
}
@keyframes shimmer {
  0% { background-position: -200% 0; }
  100% { background-position: 200% 0; }
}

.skeleton-line {
  height: 12px;
  border-radius: 6px;
  background-color: var(--ins-brd);
  margin-bottom: 8px;
}
.skeleton-circle {
  width: 38px;
  height: 38px;
  border-radius: 50%;
  background-color: var(--ins-brd);
}
.skeleton-row {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 14px;
  border-bottom: 1px solid var(--ins-brd);
}
.skeleton-row:last-child {
  border-bottom: none;
}
.skeleton-row .skeleton-body {
  flex: 1;
}

/* Sidebar collapsed tenant initials avatar */
.sb-tenant-av {
  display: none;
  width: 38px;
  height: 38px;
  border-radius: 10px;
  background: linear-gradient(135deg, var(--violet), var(--violet-soft));
  color: #fff;
  align-items: center;
  justify-content: center;
  font-family: var(--display);
  font-weight: 700;
  font-size: 15px;
  margin: 0 auto 14px;
  box-shadow: 0 4px 10px -2px rgba(124, 99, 235, 0.35);
  cursor: pointer;
  will-change: transform;
}
.sb-tenant-av:hover {
  transform: scale(1.05);
}
html.sidebar-collapsed .sb-tenant-av {
  display: flex;
}

/* Standardized Modals (GPU Accelerated) */
.modal-overlay {
  position: fixed;
  inset: 0;
  z-index: 99999;
  background: rgba(20, 40, 72, 0.45);
  backdrop-filter: blur(0px);
  -webkit-backdrop-filter: blur(0px);
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding: 6vh 16px;
  overflow: auto;
  opacity: 0;
  transition: opacity 0.25s cubic-bezier(0.16, 1, 0.3, 1), 
              backdrop-filter 0.25s cubic-bezier(0.16, 1, 0.3, 1),
              -webkit-backdrop-filter 0.25s cubic-bezier(0.16, 1, 0.3, 1);
  will-change: opacity, backdrop-filter;
}
.modal-overlay.active {
  opacity: 1;
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
}
.modal-overlay .modal-box {
  position: relative;
  width: 100%;
  background: var(--g-bg, rgba(255, 255, 255, 0.96));
  backdrop-filter: blur(26px);
  -webkit-backdrop-filter: blur(26px);
  border: 1px solid var(--g-brd, rgba(255, 255, 255, 0.8));
  border-radius: 18px;
  box-shadow: 0 30px 80px -20px rgba(20, 40, 72, 0.4);
  transform: scale(0.93) translateY(15px);
  transition: transform 0.25s cubic-bezier(0.16, 1, 0.3, 1);
  will-change: transform;
}
.modal-overlay.active .modal-box {
  transform: scale(1) translateY(0);
}

