/* ═══════════════════════════════════════════════════════════════════════════
   GoLock Admin — Design System Centralizado
   Todas as variáveis, shell, sidebar, topbar e estilos de página em um único
   arquivo. Elimina conflitos de especificidade entre index.php e sessions.php.
   ═══════════════════════════════════════════════════════════════════════════ */

/* ── Reset base ──────────────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0;min-height:100%}

/* ── Tokens globais ──────────────────────────────────────────────────────── */
:root{
  /* Paleta principal */
  --navy:#0F2747;
  --navy-2:#162D53;
  --blue:#1648e8;
  --blue-2:#2563eb;
  --blue-lt:#EEF4FF;
  --blue-bd:#D4E2F7;
  --cyan:#0ea5e9;

  /* UI surface */
  --bg:#F4F7FB;
  --surface:#ffffff;
  --surface-2:#F8FBFF;
  --line:#D9E2EC;
  --line-2:#C8D8EE;

  /* Texto */
  --text:#0F172A;
  --text-2:#475569;
  --text-3:#64748B;
  --muted:#94A3B8;

  /* Status */
  --green:#1E7A46;
  --green-lt:#EEF8F1;
  --green-bd:#CFE8D6;
  --amber:#A16207;
  --amber-lt:#FFF7E8;
  --amber-bd:#F3D9A2;
  --red:#B42318;
  --red-lt:#FFF1F1;
  --red-bd:#F0C5C2;

  /* Formas */
  --radius:18px;
  --radius-sm:12px;
  --r-btn:12px;

  /* Sombras — discretas e de confiança */
  --shadow:0 1px 3px rgba(15,23,42,.04),0 6px 20px rgba(15,23,42,.06);
  --shadow-sm:0 1px 2px rgba(15,23,42,.03),0 3px 10px rgba(15,23,42,.05);
  --shadow-md:0 4px 16px rgba(15,23,42,.08),0 12px 36px rgba(15,23,42,.07);

  /* Shell */
  --sidebar-w:250px;
  --sidebar-collapsed:72px;
  --topbar-h:58px;
}

/* ── Tipografia base ─────────────────────────────────────────────────────── */
body{
  background:var(--bg);
  color:var(--text);
  font-family:'Inter',system-ui,-apple-system,sans-serif;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}

/* ═══════════════════════════════════════════════════════════════════════════
   SHELL
   ═══════════════════════════════════════════════════════════════════════════ */
.admin-shell{
  min-height:100vh;
  background:linear-gradient(180deg,#f8fbff 0,#f3f7fc 240px,var(--bg) 100%);
}
body.admin-nav-open{overflow:hidden}

/* ═══════════════════════════════════════════════════════════════════════════
   SIDEBAR
   ═══════════════════════════════════════════════════════════════════════════ */
.sidebar{
  position:fixed;
  inset:0 auto 0 0;
  width:var(--sidebar-w);
  background:#fff;
  border-right:1px solid var(--line);
  display:flex;
  flex-direction:column;
  z-index:1040;
  transition:width .22s cubic-bezier(.4,0,.2,1), transform .22s cubic-bezier(.4,0,.2,1);
  box-shadow:2px 0 16px rgba(15,23,42,.04);
}
.admin-shell.is-collapsed .sidebar{width:var(--sidebar-collapsed)}

/* Cabeçalho da sidebar */
.sidebar-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  min-height:68px;
  padding:14px 14px 12px;
  border-bottom:1px solid #EEF3F9;
}

/* Brand — logo expandida */
.brand{display:flex;align-items:center;gap:12px;min-width:0;overflow:hidden}
.brand-mark{
  width:40px;height:40px;
  border-radius:13px;
  display:grid;place-items:center;
  font-family:'Outfit',sans-serif;font-weight:800;font-size:15px;color:#fff;
  background:linear-gradient(135deg,var(--navy) 0%,var(--blue-2) 100%);
  flex:0 0 40px;
  box-shadow:0 4px 14px rgba(22,72,232,.20);
}

/* Logo mark reduzido (ícone) visível apenas quando colapsado */
.brand-mark-icon{
  width:40px;height:40px;
  border-radius:13px;
  display:none;
  place-items:center;
  font-family:'Outfit',sans-serif;font-weight:900;font-size:16px;color:#fff;
  background:linear-gradient(135deg,var(--navy) 0%,var(--blue-2) 100%);
  flex:0 0 40px;
  box-shadow:0 4px 14px rgba(22,72,232,.20);
  letter-spacing:-.02em;
}

.brand-copy{
  min-width:0;
  transition:opacity .18s ease, transform .18s ease, width .18s ease;
  overflow:hidden;
}
.brand-title{
  font-family:'Outfit',sans-serif;font-size:15px;font-weight:700;
  color:var(--navy);line-height:1.1;
  white-space:nowrap;
}
.brand-subtitle{
  margin-top:3px;font-size:11px;color:var(--text-3);white-space:nowrap;
}

/* Colapso do brand */
.admin-shell.is-collapsed .brand-copy{
  opacity:0;transform:translateX(-8px);pointer-events:none;width:0;
}
.admin-shell.is-collapsed .brand-mark{display:none}
.admin-shell.is-collapsed .brand-mark-icon{display:grid}

/* Botões de controle da sidebar */
.sidebar-toggle,
.sidebar-mobile-close,
.mobile-menu-btn{
  appearance:none;
  border:1px solid var(--line);
  background:#fff;
  color:var(--navy);
  width:36px;height:36px;
  border-radius:10px;
  display:grid;place-items:center;
  cursor:pointer;
  transition:background .15s, border-color .15s, box-shadow .15s;
  flex:0 0 auto;
}
.sidebar-toggle:hover,
.sidebar-mobile-close:hover,
.mobile-menu-btn:hover{
  background:#F0F5FF;
  border-color:#BDD0F2;
  box-shadow:0 2px 8px rgba(22,72,232,.08);
}
.sidebar-toggle i,
.sidebar-mobile-close i,
.mobile-menu-btn i{font-size:16px}

/* Navegação */
.nav-wrap{padding:14px 10px;overflow:auto;min-height:0;flex:1}
.nav{display:grid;gap:4px}

.nav-link{
  position:relative;
  display:flex;align-items:center;gap:12px;
  min-height:46px;padding:0 12px;
  border-radius:12px;
  text-decoration:none;
  color:var(--text-3);
  font-size:13.5px;font-weight:600;
  transition:background .16s ease, color .16s ease, box-shadow .16s ease;
}

/* Hover — efeito azul suave com degradê saindo a 0 */
.nav-link:hover{
  background:linear-gradient(90deg,rgba(37,99,235,.07) 0%,rgba(37,99,235,.03) 60%,rgba(37,99,235,0) 100%);
  color:var(--navy);
  box-shadow:inset 0 0 0 1px rgba(37,99,235,.10);
}
.nav-link.active{
  background:linear-gradient(90deg,rgba(37,99,235,.10) 0%,rgba(37,99,235,.04) 70%,rgba(37,99,235,0) 100%);
  color:var(--navy);
  box-shadow:inset 0 0 0 1px rgba(37,99,235,.14);
}
.nav-link.active::before{
  content:"";
  position:absolute;left:0;top:10px;bottom:10px;
  width:3px;border-radius:99px;
  background:var(--blue-2);
}
.nav-link i{width:20px;text-align:center;font-size:17px;flex:0 0 20px;color:inherit}
.nav-label{white-space:nowrap;transition:opacity .18s ease, transform .18s ease, width .18s ease;overflow:hidden}

/* Colapso da nav */
.admin-shell.is-collapsed .nav-link{
  justify-content:center;padding:0;
}
.admin-shell.is-collapsed .nav-label{
  opacity:0;transform:translateX(-8px);pointer-events:none;width:0;
}

/* Rodapé da sidebar */
.sidebar-foot{border-top:1px solid #EEF3F9;padding:12px 10px 14px}
.sidebar-mini{
  font-size:11px;color:var(--text-3);line-height:1.4;
  padding:10px 12px;
  background:#F8FBFF;border:1px solid #E2EDF7;border-radius:12px;
  transition:opacity .18s ease, height .18s ease;
}
.admin-shell.is-collapsed .sidebar-mini{
  opacity:0;height:0;padding:0;overflow:hidden;border:0;
}

/* ═══════════════════════════════════════════════════════════════════════════
   MAIN CONTENT AREA
   ═══════════════════════════════════════════════════════════════════════════ */
.main{
  min-height:100vh;
  margin-left:var(--sidebar-w);
  transition:margin-left .22s cubic-bezier(.4,0,.2,1);
}
.admin-shell.is-collapsed .main{margin-left:var(--sidebar-collapsed)}

/* ═══════════════════════════════════════════════════════════════════════════
   TOPBAR
   ═══════════════════════════════════════════════════════════════════════════ */
.topbar{
  min-height:var(--topbar-h);
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:10px 24px;
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);
  position:sticky;top:0;z-index:100;
}
.page-sessions .topbar{display:none}

.topbar-left{display:flex;align-items:center;gap:12px;min-width:0}
.topbar-kicker{font-size:10px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:2px}
.topbar-title{font-family:'Outfit',sans-serif;font-size:18px;font-weight:700;color:var(--navy);line-height:1.1}
.topbar-right{font-size:12px;color:var(--text-3);font-weight:600}

/* ═══════════════════════════════════════════════════════════════════════════
   PAGE WRAP
   ═══════════════════════════════════════════════════════════════════════════ */
.page-wrap{padding:22px 24px 40px}
.page-sessions .page-wrap{padding:20px 24px 48px}
.page-panel{width:100%;max-width:none;overflow:visible}

/* ═══════════════════════════════════════════════════════════════════════════
   COMPONENTES GERAIS
   ═══════════════════════════════════════════════════════════════════════════ */

/* KPI Grid */
.kpi-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:16px;margin-bottom:22px}
.kpi-card{
  background:var(--surface);border:1px solid var(--line);
  border-radius:var(--radius);box-shadow:var(--shadow-sm);
  padding:18px 20px;
  transition:box-shadow .18s ease, transform .18s ease;
}
.kpi-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}
.kpi-card span{display:block;color:var(--muted);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.07em}
.kpi-card strong{display:block;margin-top:10px;font-family:'Outfit',sans-serif;font-size:30px;letter-spacing:-.04em;color:var(--navy)}

/* Cards */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px}
.card-head{padding:22px 24px 0}
.card-head h2{margin:0;font-family:'Outfit',sans-serif;font-size:20px;letter-spacing:-.03em;color:var(--navy)}
.card-head p{margin:8px 0 0;color:var(--muted);font-size:13px}
.card-body{padding:20px 24px 24px}

/* Botões principais */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  min-height:44px;padding:0 18px;
  border-radius:var(--r-btn);
  background:linear-gradient(135deg,var(--blue),var(--blue-2));
  color:#fff;font-weight:700;font-size:13px;
  border:none;cursor:pointer;
  box-shadow:0 4px 14px rgba(22,72,232,.18);
  transition:box-shadow .20s ease, transform .16s ease, background .16s ease;
  text-decoration:none;
  position:relative;overflow:hidden;
}
.btn::after{
  content:'';
  position:absolute;inset:0;
  background:radial-gradient(circle at center, rgba(255,255,255,.18) 0%, rgba(37,99,235,0) 72%);
  opacity:0;
  transition:opacity .22s ease;
  border-radius:inherit;
}
.btn:hover{
  box-shadow:0 0 0 4px rgba(37,99,235,.12), 0 6px 20px rgba(22,72,232,.22);
  transform:translateY(-1px);
  background:linear-gradient(135deg,var(--navy-2, #162D53),var(--blue));
}
.btn:hover::after{opacity:1}
.btn:active{transform:translateY(0);box-shadow:0 2px 8px rgba(22,72,232,.14)}

.btn-soft{
  background:var(--blue-lt);color:var(--blue);
  box-shadow:none;
  border:1px solid var(--blue-bd);
}
.btn-soft:hover{
  background:#E0ECFF;
  box-shadow:0 0 0 4px rgba(37,99,235,.08), 0 4px 14px rgba(22,72,232,.10);
}

/* Tabela */
.table{width:100%;border-collapse:collapse}
.table th,.table td{padding:13px 12px;border-bottom:1px solid var(--line);text-align:left;font-size:13px;vertical-align:middle}
.table th{color:var(--text-2);font-size:11px;text-transform:uppercase;letter-spacing:.07em;font-weight:700;background:#FAFBFD}
.table-link{color:var(--blue);font-weight:700}

/* Badges */
.badge{display:inline-flex;align-items:center;gap:5px;min-height:28px;padding:0 10px;border-radius:999px;background:#edf4ff;border:1px solid var(--line-2);color:var(--blue);font-size:11px;font-weight:700}
.badge-ok{background:var(--green-lt);color:var(--green);border-color:var(--green-bd)}

/* Outros elementos legados */
.funnel-row{display:flex;justify-content:space-between;align-items:center;padding:12px 14px;border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--surface-2)}
.funnel-row+.funnel-row{margin-top:10px}
.info-box,.alert{padding:15px 18px;border-radius:14px;background:#eef5ff;border:1px solid var(--line-2);color:var(--text-2);font-size:13px}
.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.detail-block{border:1px solid var(--line);border-radius:14px;background:var(--surface-2);overflow:hidden}
.detail-block h3,.subhead{margin:0;padding:13px 16px;border-bottom:1px solid var(--line);font-size:13px;color:var(--text-2);font-weight:700}
.detail-block pre,.log-item pre{margin:0;padding:16px;white-space:pre-wrap;word-break:break-word;font:11.5px/1.6 "JetBrains Mono",ui-monospace,monospace;color:var(--text)}
.log-item{border:1px solid var(--line);border-radius:14px;background:var(--surface-2);padding:12px 14px;margin-bottom:12px}
.log-item strong{display:block;margin-bottom:6px;font-size:13px}
.integration-card{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;border:1px solid var(--line);border-radius:14px;background:var(--surface-2)}
.integration-card+.integration-card{margin-top:10px}
.muted{color:var(--muted)}
.plain-list{margin:0;padding-left:18px}
.plain-list li{margin:10px 0;color:var(--text-2);font-size:13px}

/* ═══════════════════════════════════════════════════════════════════════════
   OVERLAY & FAB MOBILE
   ═══════════════════════════════════════════════════════════════════════════ */
.mobile-fab{
  position:fixed;left:14px;top:14px;
  z-index:1020;display:none;
  box-shadow:0 6px 20px rgba(15,23,42,.12);
}
.sidebar-overlay{
  position:fixed;inset:0;
  background:rgba(15,23,42,.30);
  opacity:0;pointer-events:none;
  transition:opacity .18s ease;
  z-index:1030;
}
body.admin-nav-open .sidebar-overlay{opacity:1;pointer-events:auto}
.sidebar-mobile-close{display:none}

/* ═══════════════════════════════════════════════════════════════════════════
   SESSIONS PAGE — overrides de layout fullwidth
   ═══════════════════════════════════════════════════════════════════════════ */
.page-sessions .page-panel,
.page-sessions .page-panel>*{width:100%;max-width:none !important}
.page-sessions .gl-wrap,
.page-sessions .gl-shell,
.page-sessions .gl-page,
.page-sessions .gl-container,
.page-sessions .gl-root{width:100% !important;max-width:none !important}
.page-sessions .gl-cols{grid-template-columns:minmax(0,1fr) !important;width:100% !important}
.page-sessions .gl-stack,
.page-sessions .gl-card,
.page-sessions .gl-hero,
.page-sessions .gl-client-spot,
.page-sessions .gl-kpis,
.page-sessions .gl-grid2,
.page-sessions .gl-grid3{width:100% !important;max-width:none !important}
.page-sessions .gl-grid2{grid-template-columns:repeat(2,minmax(0,1fr)) !important}
.page-sessions .gl-grid3{grid-template-columns:repeat(3,minmax(0,1fr)) !important}
.page-sessions .gl-hero,.page-sessions .gl-card{border-radius:16px !important}
.page-sessions .gl-card-bd,.page-sessions .gl-card-hd{padding-left:22px !important;padding-right:22px !important}
.page-sessions .gl-hero{padding-left:22px !important;padding-right:22px !important}
.page-sessions .gl-tabs{flex-wrap:wrap}

/* ═══════════════════════════════════════════════════════════════════════════
   SESSIONS — Componentes internos (anteriormente inline em sessions.php)
   ═══════════════════════════════════════════════════════════════════════════ */
:root{
  --em:var(--green);--em-lt:var(--green-lt);--em-bd:var(--green-bd);
  --amb:var(--amber);--amb-lt:var(--amber-lt);--amb-bd:var(--amber-bd);
  --r-card:16px;
}

.gl-wrap{display:grid;gap:20px;font-family:'Inter',sans-serif;color:var(--text);width:100%}
.gl-cols{display:grid;grid-template-columns:minmax(0,1fr);gap:20px;align-items:start;width:100%}
.gl-stack{display:grid;gap:20px;align-content:start;min-width:0}
.gl-grid2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.gl-grid3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}

.gl-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-card);box-shadow:var(--shadow)}
.gl-card-hd{padding:18px 22px 14px;border-bottom:1px solid var(--line);background:#fff}
.gl-card-hd h2{margin:0 0 4px;font-size:15px;font-weight:700;color:var(--navy);letter-spacing:-.01em}
.gl-card-hd p{margin:0;font-size:12px;color:var(--text-3)}
.gl-card-bd{padding:20px 22px;background:#fff;overflow:visible}

.gl-hero{
  background:#F8FBFF;border:1px solid #DCE7F3;
  border-radius:16px;padding:14px 20px 16px;
  color:var(--text);position:relative;overflow:hidden;
  box-shadow:var(--shadow-sm);
}
.gl-hero::before{content:'';position:absolute;left:0;right:0;top:0;height:2px;background:linear-gradient(90deg,var(--navy),var(--blue-2));opacity:.8}
.gl-hero-top{display:flex;justify-content:space-between;align-items:flex-start;gap:14px;flex-wrap:wrap}
.gl-hero-main{min-width:0}
.gl-hero-id{font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#75859A;margin-bottom:3px}
.gl-hero h1{margin:0 0 3px;font-size:16px;font-weight:800;letter-spacing:-.015em;color:#183153;line-height:1.14;text-transform:uppercase}
.gl-hero-sub{font-size:11px;color:#66758B;margin-top:0}
.gl-hero-acts{display:flex;gap:10px;flex-wrap:wrap;flex-shrink:0}

.gl-client-spot{
  background:#fff;border:1px solid var(--line);border-radius:12px;
  padding:10px 14px;margin-top:10px;
  display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px 14px;
}
.gl-cs-item span{display:block;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:#75859A;margin-bottom:3px}
.gl-cs-item strong{display:block;font-size:13px;font-weight:700;color:#16304F;line-height:1.32}
.gl-cs-item a{color:#275BB0;text-decoration:none}
.gl-cs-item a:hover{text-decoration:underline}

.gl-kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:9px;margin-top:10px}
.gl-kpi{background:#fff;border:1px solid var(--line);border-radius:12px;padding:10px 12px}
.gl-kpi span{display:block;font-size:10px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:#75859A;margin-bottom:4px}
.gl-kpi strong{font-size:17px;font-weight:800;line-height:1.08;color:#183153}
.gl-kpi.kpi-price strong{color:#275BB0}
.gl-kpi.kpi-alert strong{color:#8F5A11}

/* Mini header fixo */
.gl-minihead{position:fixed;top:14px;left:calc(var(--sidebar-w) + 20px);right:20px;z-index:80;display:none;pointer-events:none;transition:left .22s ease}
.admin-shell.is-collapsed .gl-minihead{left:calc(var(--sidebar-collapsed) + 20px)}
.gl-minihead.show{display:block}
.gl-minihead-inner{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:10px 16px;
  background:rgba(240,247,255,.97);backdrop-filter:blur(12px);
  border:1px solid #C8DCF6;border-radius:14px;
  box-shadow:0 8px 24px rgba(22,72,232,.09);
  pointer-events:auto;
}
.gl-minihead-meta{min-width:0}
.gl-minihead-id{font-size:9px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#5F7691}
.gl-minihead-title{font-size:13px;font-weight:800;color:#16304F;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}
.gl-minihead-sub{font-size:11px;color:#49627E;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.gl-minihead-pill{display:inline-flex;align-items:center;justify-content:center;min-height:32px;padding:0 12px;border-radius:999px;border:1px solid #AFCBF0;background:#F6FBFF;font-size:12px;font-weight:800;color:#16304F}
.gl-minihead-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end}

/* Proposal lock */
.gl-proposal-lock{opacity:.5;pointer-events:none !important;cursor:not-allowed !important}

/* Dirty banner */
.gl-dirty-banner{display:none;margin-top:10px;padding:10px 13px;border-radius:12px;border:1px solid #E8C7C9;background:#FFF7F7;color:#8B3A3E;font-size:12px;font-weight:600}
.gl-dirty-banner.show{display:flex;align-items:flex-start;gap:10px}
.gl-dirty-banner strong{font-weight:800;color:#7B2B31}
.gl-dirty-banner .dot{width:8px;height:8px;border-radius:50%;background:#C95B61;flex:0 0 8px;margin-top:4px}

/* Badges GL */
.gl-badge{display:inline-flex;align-items:center;gap:6px;padding:5px 10px;border-radius:999px;font-size:11px;font-weight:700;border:1px solid transparent}
.gl-badge.success{background:var(--green-lt);color:var(--green);border-color:var(--green-bd)}
.gl-badge.warning{background:var(--amber-lt);color:var(--amber);border-color:var(--amber-bd)}
.gl-badge.danger{background:var(--red-lt);color:var(--red);border-color:var(--red-bd)}
.gl-badge.neutral{background:#F8FAFC;color:#334155;border-color:#E2E8F0}
.gl-badge .dot{width:6px;height:6px;border-radius:50%;background:currentColor;flex-shrink:0}

/* Painel operacional */
.gl-op-panel{background:var(--surface);border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow)}
.gl-op-hd{padding:18px 22px 0}
.gl-op-hd h2{margin:0;font-size:15px;font-weight:700;color:var(--navy)}
.gl-op-hd p{margin:4px 0 0;font-size:12px;color:var(--text-3)}
.gl-tabs{display:flex;gap:0;border-bottom:1px solid var(--line);margin:0 22px;overflow-x:auto}
.gl-tab{padding:13px 16px;font-weight:700;font-size:12px;color:var(--text-3);cursor:pointer;border:none;background:transparent;border-bottom:2px solid transparent;margin-bottom:-1px;white-space:nowrap;transition:all .15s}
.gl-tab:hover{color:var(--text-2)}
.gl-tab.active{color:var(--blue-2);border-bottom-color:var(--blue-2)}
.gl-tab-body{display:none;padding:20px 22px 22px}
.gl-tab-body.active{display:block}

/* Form fields */
.gl-fg{display:flex;flex-direction:column;gap:7px}
.gl-lbl{font-size:12px;font-weight:600;color:var(--text-2)}
.gl-ctrl{
  min-height:44px;padding:10px 13px;
  border:1px solid var(--line);border-radius:11px;
  font-size:13px;font-weight:500;color:var(--text);
  background:#fff;outline:none;width:100%;
  transition:border-color .15s, box-shadow .15s, background .15s;
}
.gl-ctrl:focus{border-color:#7AA7E8;box-shadow:0 0 0 4px rgba(31,95,191,.08)}
.gl-ctrl[readonly]{background:#F8FAFC;color:var(--text-2)}
.gl-help{font-size:11px;line-height:1.45;color:var(--text-3)}
.gl-sec-ttl{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-3);padding-bottom:8px;border-bottom:1px solid var(--line);margin-bottom:12px;display:flex;align-items:center;gap:8px}

/* Combos */
.gl-combos{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.gl-combo-card{padding:12px 14px;border:1px solid var(--line);border-radius:12px;cursor:pointer;transition:all .16s;background:#fff}
.gl-combo-card:hover,.gl-combo-card.on{border-color:#9FC2F3;background:var(--blue-lt)}
.gl-combo-card input{display:none}
.gl-combo-card strong{display:block;font-size:12px;font-weight:700;color:var(--text);margin-bottom:4px;line-height:1.35}
.gl-combo-ct{display:inline-flex;margin-top:4px;padding:3px 8px;border-radius:999px;font-size:10px;font-weight:700;text-transform:uppercase;border:1px solid transparent}
.gl-combo-ct.exclusive{background:var(--blue-lt);color:var(--blue-2);border-color:#D7E6F8}
.gl-combo-ct.basic{background:#F8FAFC;color:#334155;border-color:#E2E8F0}

/* Serviços */
.gl-svc-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text-3);margin:16px 0 8px;display:flex;align-items:center;gap:8px}
.gl-svc-title::after{content:'';flex:1;height:1px;background:var(--line)}
.gl-svc-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.gl-svc-card{padding:10px 12px;border:1px solid var(--line);border-radius:11px;cursor:pointer;transition:all .16s;background:#fff;display:flex;align-items:center;gap:9px}
.gl-svc-card:hover,.gl-svc-card.on{border-color:#9FC2F3;background:var(--blue-lt)}
.gl-svc-card input{display:none}
.gl-svc-dot{width:8px;height:8px;border-radius:50%;background:#CBD5E1;flex-shrink:0;transition:.16s}
.gl-svc-card.on .gl-svc-dot{background:var(--blue-2)}
.gl-svc-name{font-size:12px;font-weight:600;color:var(--text);line-height:1.35}
.gl-svc-price{font-size:11px;font-weight:700;color:var(--blue-2)}
.gl-svc-none{font-size:12px;color:var(--text-3);font-style:italic}

/* ── Botões GL — hover azul suave com halo ─────────────────────────────── */
.gl-btn{
  display:inline-flex;align-items:center;justify-content:center;gap:7px;
  min-height:42px;padding:0 16px;
  border-radius:var(--r-btn);
  font-weight:700;font-size:13px;
  border:1px solid transparent;
  cursor:pointer;
  transition:background .18s ease, box-shadow .20s ease, transform .15s ease, border-color .18s ease;
  text-decoration:none;white-space:nowrap;
  position:relative;overflow:hidden;
}
.gl-btn::after{
  content:'';
  position:absolute;inset:0;border-radius:inherit;
  background:radial-gradient(circle at 50% 110%, rgba(255,255,255,.16) 0%, rgba(37,99,235,0) 70%);
  opacity:0;transition:opacity .22s ease;
}
.gl-btn:hover::after{opacity:1}

.gl-btn.primary{background:var(--blue-2);color:#fff;border-color:var(--blue-2)}
.gl-btn.primary:hover{
  background:var(--blue);border-color:var(--blue);
  box-shadow:0 0 0 4px rgba(37,99,235,.12), 0 6px 18px rgba(22,72,232,.20);
  transform:translateY(-1px);
}
.gl-btn.ghost-w{background:#fff;border:1px solid var(--line);color:var(--navy)}
.gl-btn.ghost-w:hover{
  background:#F4F8FF;border-color:#BDD0F2;
  box-shadow:0 0 0 3px rgba(37,99,235,.08), 0 4px 12px rgba(15,23,42,.06);
  transform:translateY(-1px);
}
.gl-btn.secondary{background:#fff;border:1px solid var(--line);color:var(--navy)}
.gl-btn.secondary:hover{
  background:#F4F8FF;border-color:#BDD0F2;
  box-shadow:0 0 0 3px rgba(37,99,235,.07);
}
.gl-btn.success-s{background:var(--green-lt);border:1px solid var(--green-bd);color:var(--green)}
.gl-btn.success-s:hover{box-shadow:0 0 0 3px rgba(30,122,70,.09)}
.gl-btn.danger-s{background:var(--red-lt);border:1px solid var(--red-bd);color:var(--red)}
.gl-btn.danger-s:hover{box-shadow:0 0 0 3px rgba(180,35,24,.09)}
.gl-btn.sm{min-height:34px;padding:0 12px;font-size:12px;border-radius:10px}
.gl-btn:disabled,.gl-btn[disabled]{opacity:.5;cursor:not-allowed;transform:none !important;box-shadow:none !important}

/* Botão Emitir Proposta — destaque máximo */
.gl-btn.proposal{
  background:linear-gradient(135deg,var(--navy) 0%,var(--navy-2) 100%);
  color:#fff;border-color:transparent;
  box-shadow:0 4px 14px rgba(15,39,71,.18);
}
.gl-btn.proposal:hover{
  background:linear-gradient(135deg,#112C51 0%,#1A3B6E 100%);
  box-shadow:0 0 0 4px rgba(22,72,232,.14), 0 8px 22px rgba(15,39,71,.22);
  transform:translateY(-1px);
}
.gl-btn.proposal:disabled,.gl-btn.proposal.gl-proposal-lock{
  opacity:.5;cursor:not-allowed;
  transform:none;box-shadow:none;
}

/* Tooltip nativo em botão bloqueado */
.gl-btn[title]:disabled{pointer-events:auto;cursor:not-allowed}

/* Recalc actions */
.gl-recalc-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:16px}
.gl-recalc-actions .gl-btn{min-width:160px}
.gl-preview-note{margin-top:10px;font-size:12px;line-height:1.5;color:#6B7C93}
.gl-preview-note strong{color:#183153}

.gl-calc-res{display:none;margin-top:16px;padding:16px;border-radius:14px;border:1px solid #D7E6F8;background:#F8FBFF}
.gl-calc-res.err{border-color:var(--red-bd);background:#FFF6F5}
.gl-calc-msg{font-size:13px;font-weight:700;color:var(--navy)}
.gl-calc-kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:12px}
.gl-calc-kpi{background:#fff;border:1px solid #E6EDF5;border-radius:12px;padding:12px}
.gl-calc-kpi span{display:block;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-3);margin-bottom:4px}
.gl-calc-kpi strong{font-size:16px;font-weight:800;color:var(--navy)}
.gl-suhai-warn{display:none;margin-top:10px;padding:10px 13px;background:var(--amber-lt);border:1px solid var(--amber-bd);border-radius:10px;font-size:12px;font-weight:700;color:var(--amber)}

/* Key-value */
.gl-kv{display:grid;gap:8px}
.gl-kv-row{display:grid;grid-template-columns:140px 1fr;gap:10px;align-items:start;padding:8px 0;border-bottom:1px solid #EEF2F7}
.gl-kv-row:last-child{border-bottom:none}
.gl-kv-lbl{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-3);padding-top:2px}
.gl-kv-val{font-size:13px;font-weight:600;color:var(--text);word-break:break-word}

/* Status row */
.gl-status-row{display:flex;gap:8px;flex-wrap:wrap}
.gl-stat-btn{padding:9px 15px;border-radius:10px;border:1px solid var(--line);background:#fff;font-size:12px;font-weight:700;cursor:pointer;transition:all .15s;color:var(--text-2)}
.gl-stat-btn.active{border-color:var(--blue-2);background:var(--blue-2);color:#fff}
.gl-stat-btn:hover:not(.active){border-color:#9FC2F3;color:var(--blue-2);background:#F4F8FF}

/* Log items */
.gl-log-item{padding:12px 14px;border:1px solid var(--line);border-radius:12px;margin-bottom:8px;background:#fff}
.gl-log-hd{display:flex;justify-content:space-between;align-items:center;margin-bottom:7px;gap:8px;flex-wrap:wrap}
.gl-log-ttl{font-size:12px;font-weight:700;color:var(--text)}
.gl-log-dt{font-size:11px;color:var(--text-3)}

/* Histórico */
.gl-hist-item{border:1px solid var(--line);border-radius:14px;overflow:hidden;margin-bottom:8px;background:#fff}
.gl-hist-hd{padding:12px 15px;background:#F8FAFC;display:flex;justify-content:space-between;align-items:center;cursor:pointer;gap:8px;flex-wrap:wrap}
.gl-hist-hd:hover{background:var(--blue-lt)}
.gl-hist-title{font-size:13px;font-weight:700;color:var(--text);display:flex;align-items:center;gap:8px}
.gl-hist-meta{font-size:11px;color:var(--text-3);display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.gl-hist-body{display:none;padding:14px 15px;border-top:1px solid var(--line)}
.gl-hist-item.open .gl-hist-body{display:block}
.gl-hist-vals{display:grid;grid-template-columns:repeat(3,1fr);gap:9px;margin-bottom:11px}
.gl-hist-val span{display:block;font-size:10px;font-weight:700;text-transform:uppercase;color:var(--text-3);margin-bottom:2px}
.gl-hist-val strong{font-size:16px;font-weight:800;color:var(--navy)}

/* Accordion */
.gl-acc-wrap{border:1px solid var(--line);border-radius:10px;overflow:hidden;background:#fff}
.gl-acc-trigger{width:100%;padding:10px 13px;background:transparent;border:none;display:flex;justify-content:space-between;align-items:center;cursor:pointer;font-size:12px;font-weight:700;color:var(--text-2)}
.gl-acc-trigger:hover{background:#F8FAFC}
.gl-acc-content{display:none;padding:0 13px 11px}
.gl-acc-wrap.open .gl-acc-content{display:block}
pre.gl-raw{margin:0;white-space:pre-wrap;word-break:break-word;background:#0F172A;color:#D6EAFB;border-radius:8px;padding:11px;font-size:11px;line-height:1.6;overflow:auto;max-height:200px}

/* Audit timeline */
.gl-audit-timeline{display:grid;gap:0}
.gl-audit-item{display:flex;gap:12px;padding:11px 0}
.gl-audit-item:not(:last-child){border-bottom:1px solid var(--line)}
.gl-audit-dot{width:28px;height:28px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:12px;margin-top:1px}
.gl-audit-dot.recalc{background:#DBEAFE;color:var(--blue-2)}
.gl-audit-dot.status{background:var(--green-lt);color:var(--green)}
.gl-audit-dot.crm{background:var(--blue-lt);color:var(--blue-2)}
.gl-audit-dot.judicial{background:var(--amber-lt);color:var(--amber)}
.gl-audit-dot.token{background:var(--red-lt);color:var(--red)}
.gl-audit-dot.customer{background:#F0FDF4;color:var(--green)}
.gl-audit-dot.default{background:var(--bg);color:var(--text-3)}
.gl-audit-body{flex:1;min-width:0}
.gl-audit-action{font-size:13px;font-weight:700;color:var(--text)}
.gl-audit-who{font-size:11px;color:var(--text-3);margin-top:2px}
.gl-audit-detail{font-size:11px;color:var(--text-2);margin-top:4px;background:#F8FAFC;border-radius:8px;padding:6px 9px;display:inline-block}

/* Tabela GL */
.gl-table-wrap{overflow-x:auto}
.gl-table{width:100%;border-collapse:separate;border-spacing:0 6px}
.gl-table th{text-align:left;font-size:10px;text-transform:uppercase;letter-spacing:.07em;color:var(--text-3);padding:0 12px 4px;font-weight:700}
.gl-table td{background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:11px 12px;color:var(--text);font-size:13px;font-weight:600;vertical-align:middle}
.gl-table td:first-child{border-left:1px solid var(--line);border-radius:12px 0 0 12px}
.gl-table td:last-child{border-right:1px solid var(--line);border-radius:0 12px 12px 0}
.gl-table tr:hover td{background:#F8FBFF}

/* Vehicle card */
.gl-vehicle-card{background:#F8FBFF;color:var(--text);border:1px solid #D7E6F8;border-radius:14px;padding:13px 16px;margin-bottom:13px}
.gl-vehicle-card .make{font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-3)}
.gl-vehicle-card .model{font-size:17px;font-weight:800;margin:4px 0;color:var(--navy)}
.gl-vehicle-card .meta{font-size:12px;color:var(--text-2);display:flex;gap:13px;flex-wrap:wrap;margin-top:4px}
.gl-vehicle-card .meta span{white-space:nowrap}

/* Financeiro */
.gl-fin-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid var(--line);gap:12px}
.gl-fin-row:last-child{border-bottom:none}
.gl-fin-lbl{font-size:12px;font-weight:600;color:var(--text-3)}
.gl-fin-val{font-size:14px;font-weight:800;color:var(--text)}
.gl-fin-val.hl{color:var(--blue-2);font-size:16px}
.gl-adj{display:flex;justify-content:space-between;padding:7px 10px;border-radius:8px;border:1px solid var(--line);background:#F8FAFC;font-size:12px;margin-bottom:6px;gap:8px}
.gl-adj-lbl{font-weight:600;color:var(--text-2)}
.gl-adj-pct.pos{color:var(--amber);font-weight:800}
.gl-adj-pct.neg{color:var(--green);font-weight:800}

/* CRM pills */
.gl-crm-pill{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:9px;font-size:12px;font-weight:700}
.gl-crm-pill.piperun{background:var(--blue-lt);color:var(--blue-2)}
.gl-crm-pill.infvest{background:var(--green-lt);color:var(--green)}
.gl-crm-pill.custom{background:#F8FAFC;color:#334155}
.gl-crm-pill.pending{background:var(--amber-lt);color:var(--amber)}

/* Token */
.gl-token-box{background:#F8FAFC;border:1px solid var(--line);border-radius:11px;padding:11px 15px;font-family:monospace;font-size:12px;color:var(--text-2);word-break:break-all}
.gl-link-row{display:flex;gap:8px;align-items:center;flex-wrap:wrap}

/* Misc */
.gl-sep{border:none;border-top:1px solid var(--line);margin:16px 0}
.gl-empty{padding:14px;border:1px dashed var(--line);border-radius:11px;color:var(--text-3);font-size:13px;text-align:center;background:#fff}
.gl-spin{display:inline-block;width:13px;height:13px;border:2px solid rgba(255,255,255,.35);border-top-color:#fff;border-radius:50%;animation:_spin .65s linear infinite;flex-shrink:0}
@keyframes _spin{to{transform:rotate(360deg)}}
.gl-role-lock{background:#F8FAFC;border:1px dashed var(--line);border-radius:11px;padding:13px;color:var(--text-3);font-size:13px;text-align:center}

/* Toast */
/* Toast — canto inferior direito, acima de sidebar e proposal overlay */
#gl-toast{
  position:fixed;
  bottom:28px;
  right:28px;
  left:auto;
  z-index:10500;
  display:flex;
  flex-direction:column;
  align-items:flex-end;
  gap:8px;
  pointer-events:none;
  max-width:340px;
}
.gl-toast{
  padding:12px 18px;
  border-radius:12px;
  font-weight:700;
  font-size:13px;
  line-height:1.4;
  box-shadow:0 8px 28px rgba(0,0,0,.18),0 2px 8px rgba(0,0,0,.08);
  opacity:0;
  transform:translateY(10px) scale(.97);
  transition:opacity .22s ease,transform .22s ease;
  pointer-events:auto;
  width:max-content;
  max-width:320px;
}
.gl-toast.show{opacity:1;transform:translateY(0) scale(1)}
.gl-toast.ok{background:var(--navy);color:#fff}
.gl-toast.err{background:#B42318;color:#fff}

/* Sidebar collapsed + sessions */
body.sidebar-collapsed .gl-minihead{top:8px}
body.sidebar-collapsed .gl-minihead-inner{padding:9px 12px;border-radius:12px}

/* Print */
@media print{
  body>*:not(#gl-proposal-win){display:none !important}
  #gl-proposal-win{display:block !important;position:static !important;inset:auto !important;box-shadow:none !important}
}

/* ═══════════════════════════════════════════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════════════════════════════════════════ */
@media (max-width:1280px){
  .gl-cols{grid-template-columns:1fr}
  body.sidebar-collapsed .gl-cols{grid-template-columns:1fr}
}
@media (max-width:1200px){
  .kpi-grid{grid-template-columns:repeat(3,1fr)}
  .grid-2,.detail-grid{grid-template-columns:1fr}
  .page-sessions .gl-grid3{grid-template-columns:repeat(2,minmax(0,1fr)) !important}
}
@media (max-width:1100px){
  .gl-cols{grid-template-columns:1fr}
  .gl-kpis{grid-template-columns:repeat(2,1fr)}
  .gl-client-spot{grid-template-columns:1fr 1fr}
  .gl-minihead{left:16px;right:16px;top:10px}
  .admin-shell.is-collapsed .gl-minihead{left:16px}
}
@media (max-width:920px){
  .sidebar{
    transform:translateX(-100%);
    width:min(88vw,320px);
    box-shadow:0 20px 50px rgba(15,23,42,.16);
  }
  body.admin-nav-open .sidebar{transform:translateX(0)}
  .main,.admin-shell.is-collapsed .main{margin-left:0}
  .sidebar-toggle{display:none}
  .sidebar-mobile-close{display:grid}
  .topbar{display:none}
  .mobile-fab{display:grid}
  .page-wrap,.page-sessions .page-wrap{padding:16px 14px 28px}
  .kpi-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:768px){
  .gl-grid2,.gl-grid3,.gl-combos,.gl-svc-grid,.gl-calc-kpis,.gl-hist-vals{grid-template-columns:1fr}
  .gl-kv-row{grid-template-columns:1fr;gap:4px}
  .gl-hero h1{font-size:15px}
  .gl-client-spot,.gl-kpis{grid-template-columns:1fr}
  .gl-card-hd,.gl-card-bd,.gl-tab-body,.gl-op-hd,.gl-hero{padding-left:16px;padding-right:16px}
  .gl-tabs{margin:0 16px}
  .gl-minihead-inner{padding:9px 12px;align-items:flex-start}
  .gl-minihead-actions{width:100%;justify-content:flex-start}
  .gl-minihead-title{font-size:12px}
  .gl-minihead-sub{font-size:10px}
  .gl-recalc-actions .gl-btn{width:100%;min-width:0}
  .page-sessions .gl-grid2,.page-sessions .gl-grid3{grid-template-columns:1fr !important}
}
@media (max-width:640px){
  .kpi-grid{grid-template-columns:1fr}
  .table{display:block;overflow:auto}
}
@media (min-width:921px){
  .mobile-menu-btn{display:none}
}


/* =========================
   PRINT DA PROPOSTA REAL
   ========================= */

body.gl-print-proposal-mode {
  overflow: hidden;
}

@media print {
  @page {
    size: A4 portrait;
    margin: 10mm;
  }

  html,
  body {
    background: #ffffff !important;
    margin: 0 !important;
    padding: 0 !important;
    -webkit-print-color-adjust: exact !important;
    print-color-adjust: exact !important;
  }

  * {
    -webkit-print-color-adjust: exact !important;
    print-color-adjust: exact !important;
  }

  /* esconde tudo da página */
  body * {
    visibility: hidden !important;
  }

  /* mostra só a proposta e o conteúdo dela */
  #gl-proposal-win,
  #gl-proposal-win * {
    visibility: visible !important;
  }

  #gl-proposal-win {
    display: block !important;
    position: static !important;
    inset: auto !important;
    width: 100% !important;
    min-height: auto !important;
    overflow: visible !important;
    background: #ffffff !important;
    padding: 0 !important;
    margin: 0 !important;
    z-index: auto !important;
  }

  #gl-proposal-content {
    display: block !important;
    position: static !important;
    width: 100% !important;
    max-width: 800px !important;
    margin: 0 auto !important;
    padding: 0 !important;
    background: #ffffff !important;
    transform: none !important;
  }

  /* barra flutuante de botões não imprime */
  #gl-proposal-toolbar {
    display: none !important;
  }

  /* evita quebra feia dentro dos blocos */
  #gl-proposal-content section,
  #gl-proposal-content .card,
  #gl-proposal-content .box,
  #gl-proposal-content .row,
  #gl-proposal-content .item,
  #gl-proposal-content table,
  #gl-proposal-content tr {
    break-inside: avoid !important;
    page-break-inside: avoid !important;
  }

  /* remove sombras/efeitos que costumam distorcer no print */
  #gl-proposal-content,
  #gl-proposal-content * {
    box-shadow: none !important;
    filter: none !important;
  }
}

/* ═══════════════════════════════════════════════════════════════════════════
   DASHBOARD — versão moderna clean
   Adicionar ao final do assets/admin.css
   ═══════════════════════════════════════════════════════════════════════════ */

.page-dashboard-modern .gl-op-panel,
.page-dashboard-modern .gl-card,
.page-dashboard-modern .gl-hero{width:100%;max-width:none}

.gdm-hero{
  background:#f8fbff;
  border:1px solid #dce7f3;
  border-radius:16px;
  padding:16px 20px 18px;
  box-shadow:var(--shadow-sm);
}
.gdm-hero__top{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:16px;
  flex-wrap:wrap;
}
.gdm-hero__eyebrow{
  font-size:10px;
  font-weight:800;
  letter-spacing:.08em;
  color:#7283a4;
  margin-bottom:8px;
}
.gdm-hero__head h1{
  margin:0;
  font-size:28px;
  line-height:1;
  font-weight:900;
  color:var(--navy);
  letter-spacing:-.03em;
}
.gdm-hero__actions{display:flex;gap:10px;flex-wrap:wrap}

.gdm-metrics{
  margin-top:16px;
  display:grid;
  grid-template-columns:repeat(5,minmax(0,1fr));
  gap:12px;
}
.gdm-metric-card,
.gdm-mini-stat{
  background:#fff;
  border:1px solid var(--line);
  border-radius:14px;
  padding:16px 18px;
  box-shadow:0 8px 22px rgba(15,23,42,.04);
}
.gdm-metric-card span,
.gdm-mini-stat span{
  display:block;
  font-size:12px;
  color:#74839d;
  font-weight:700;
  margin-bottom:8px;
}
.gdm-metric-card strong,
.gdm-mini-stat strong{
  display:block;
  font-size:24px;
  line-height:1.05;
  letter-spacing:-.03em;
  color:#10203f;
  font-weight:900;
}

.gdm-notice-card{border-style:dashed;background:#fbfdff}
.gdm-notice-line{font-size:13px;color:#6d7d9d}
.gdm-notice-line + .gdm-notice-line{margin-top:8px}

.gdm-panel .gl-op-hd p{margin:0;color:#70809c;font-size:12px}
.gdm-tabs{margin:0 22px}
.gdm-tabs .gl-tab{position:relative}
.gdm-tabs .gl-tab.active::after{
  content:'';
  position:absolute;
  left:0;right:0;bottom:-1px;
  height:2px;
  background:#2f5fe3;
  border-radius:999px;
}

.gdm-op-grid{
  display:grid;
  grid-template-columns:minmax(0,1.55fr) minmax(320px,.85fr);
  gap:18px;
}
.gdm-side-stack{display:grid;gap:18px;align-content:start}
.gdm-card--table .gl-card-bd{padding-top:8px}

.gdm-table-wrap{overflow:auto}
.gdm-table{width:100%;border-collapse:separate;border-spacing:0}
.gdm-table thead th{
  text-align:left;
  font-size:11px;
  letter-spacing:.04em;
  text-transform:uppercase;
  color:#7b89a4;
  padding:0 0 12px;
  border-bottom:1px solid #e8eef8;
}
.gdm-table tbody td{
  padding:14px 0;
  border-bottom:1px solid #edf2fa;
  vertical-align:middle;
  color:#15284a;
  font-size:13px;
}
.gdm-table tbody tr:last-child td{border-bottom:none}
.gdm-mini-btn{min-height:34px;padding:0 12px;font-size:12px}

.gdm-stat-list{display:grid;gap:12px}
.gdm-stat-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding:12px 0;
  border-bottom:1px solid #edf2fa;
}
.gdm-stat-row:last-child{border-bottom:none;padding-bottom:0}
.gdm-stat-row span{font-size:13px;color:#667791}
.gdm-stat-row strong{font-size:17px;color:#11213f;letter-spacing:-.02em}

.gdm-quick-actions{display:grid;gap:10px}
.gdm-quick-link{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  padding:14px 15px;
  border:1px solid #e6edf8;
  border-radius:14px;
  background:#fbfdff;
  transition:border-color .18s ease, transform .18s ease, box-shadow .18s ease;
}
.gdm-quick-link:hover{border-color:#c8d8f8;transform:translateY(-1px);box-shadow:0 8px 20px rgba(15,23,42,.05)}
.gdm-quick-link strong{display:block;font-size:13px;color:#11213f}
.gdm-quick-link span{display:block;font-size:12px;color:#6f7f9a}

.gdm-admin-kpis{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:12px;
  margin-bottom:16px;
}
.gdm-admin-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:18px;
}
.gdm-chart-card--wide{grid-column:span 2}
.gdm-chart-card .gl-card-hd h2{font-size:15px}
.gdm-chart-card .gl-card-hd p{font-size:12px}
.gdm-chart{width:100%;min-height:300px}
.gdm-chart--sm{min-height:280px}

.page-dashboard-modern .apexcharts-canvas,
.page-dashboard-modern .apexcharts-svg{max-width:100% !important}
.page-dashboard-modern .apexcharts-tooltip{
  border:1px solid #e4ebf6 !important;
  box-shadow:0 14px 32px rgba(15,23,42,.10) !important;
  border-radius:12px !important;
}
.page-dashboard-modern .apexcharts-legend-text{font-weight:600 !important}
.page-dashboard-modern .apexcharts-xaxistooltip,
.page-dashboard-modern .apexcharts-yaxistooltip{display:none !important}

@media (max-width:1280px){
  .gdm-metrics{grid-template-columns:repeat(3,minmax(0,1fr))}
  .gdm-op-grid{grid-template-columns:1fr}
}
@media (max-width:1024px){
  .gdm-admin-grid{grid-template-columns:1fr}
  .gdm-chart-card--wide{grid-column:auto}
  .gdm-admin-kpis{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width:768px){
  .gdm-hero{padding:14px 16px 16px}
  .gdm-hero__head h1{font-size:22px}
  .gdm-metrics{grid-template-columns:repeat(2,minmax(0,1fr))}
  .gdm-tabs{margin:0 16px}
}
@media (max-width:560px){
  .gdm-metrics,
  .gdm-admin-kpis{grid-template-columns:1fr}
  .gdm-chart{min-height:260px}
}



