/* ════════════════════════════════════════════════════════════════
   CPGenerator — cpg.css
   Consolidated design system for the redesign mocks.
   In production this is the single <style> block in inc/layout.php.
   Tokens (both themes) · frozen shell · shared components · mobile.
   ════════════════════════════════════════════════════════════════ */

/* ── 1 · THEME-INDEPENDENT TOKENS ── */
:root{
  --primary:#28AFB0;--c-teal:var(--primary);--c-blue:#5B8DEF;--c-green:#10B981;--c-amber:#F6AE2D;
  --c-red:#EF4444;--c-violet:#8B5CF6;--c-indigo:#6366F1;--c-slate:#64748B;
  --primary-hover:color-mix(in oklab,var(--primary),#000 14%);--primary-active:color-mix(in oklab,var(--primary),#000 26%);--primary-contrast:#fff;
  --success:var(--c-green);--warning:var(--c-amber);--danger:var(--c-red);--info:var(--c-blue);--purple:var(--c-violet);
  --font:'Inter',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;--font-rtl:'Cairo','Inter',system-ui,sans-serif;--font-mono:'SF Mono','Cascadia Code',Menlo,Consolas,monospace;
  --fs-xs:.75rem;--fs-sm:.8125rem;--fs-base:.9375rem;--fs-md:1.0625rem;--fs-lg:1.25rem;--fs-xl:1.5625rem;--fs-2xl:2rem;--fs-3xl:2.5rem;
  --lh-tight:1.25;--lh-snug:1.4;--lh-normal:1.6;--fw-normal:400;--fw-medium:500;--fw-semibold:600;--fw-bold:700;--fw-heavy:800;
  --sp-1:4px;--sp-2:8px;--sp-3:12px;--sp-4:16px;--sp-5:20px;--sp-6:24px;--sp-8:32px;--sp-10:40px;--sp-12:48px;
  --radius-sm:8px;--radius:12px;--radius-lg:16px;--radius-pill:999px;--control-h:42px;--control-h-sm:34px;--control-h-lg:50px;
  --container-max:1400px;--container-narrow:720px;--container-auth:480px;--sidebar-w:260px;--sidebar-w-collapsed:72px;
  --dur-fast:.12s;--dur:.2s;--dur-slow:.32s;--ease:cubic-bezier(.4,0,.2,1);
  --z-sticky-cta:90;--z-header:100;--z-overlay:999;--z-sidebar:1000;--z-dropdown:1001;--z-modal:2000;--z-toast:3000;--z-loading:9999;
  --gradient-brand:linear-gradient(135deg,color-mix(in oklab,var(--primary),#000 34%),var(--primary));
}
/* ── 2 · LIGHT ── */
[data-theme="light"]{--bg-body:#F4F5F7;--bg-sidebar:#FFFFFF;--bg-card:#FFFFFF;--bg-card-hover:#F9FAFB;--bg-input:#FFFFFF;--bg-subtle:#F6F7F9;--border:#E6E8EC;--border-strong:#D5D9DF;--text-heading:#111827;--text:#1F2937;--text-secondary:#5B6472;--text-muted:#8A93A2;--shadow-sm:0 1px 2px rgba(16,24,40,.06);--shadow:0 1px 3px rgba(16,24,40,.08),0 1px 2px rgba(16,24,40,.04);--shadow-md:0 4px 12px rgba(16,24,40,.08);--shadow-lg:0 12px 32px rgba(16,24,40,.12);--primary-tint:color-mix(in srgb,var(--primary) 12%,#fff);--primary-tint-strong:color-mix(in srgb,var(--primary) 20%,#fff);--focus-glow:0 0 0 3px color-mix(in srgb,var(--primary) 28%,transparent);color-scheme:light}
/* ── 3 · DARK ── */
[data-theme="dark"]{--bg-body:#0A0F1A;--bg-sidebar:#0D1117;--bg-card:#111827;--bg-card-hover:#161F30;--bg-input:#0D1420;--bg-subtle:#0D1420;--border:#1F2E40;--border-strong:#2B3C52;--text-heading:#FFFFFF;--text:#E5E7EB;--text-secondary:#9CA3AF;--text-muted:#6B7280;--shadow-sm:0 1px 2px rgba(0,0,0,.4);--shadow:0 2px 8px rgba(0,0,0,.4);--shadow-md:0 6px 16px rgba(0,0,0,.5);--shadow-lg:0 16px 40px rgba(0,0,0,.6);--primary-tint:color-mix(in srgb,var(--primary) 16%,var(--bg-card));--primary-tint-strong:color-mix(in srgb,var(--primary) 26%,var(--bg-card));--focus-glow:0 0 0 3px color-mix(in srgb,var(--primary) 40%,transparent);color-scheme:dark}

/* ── 4 · STATUS CHIPS (one system) ── */
.chip{--chip:var(--c-slate);display:inline-flex;align-items:center;gap:var(--sp-1);padding-block:3px;padding-inline:10px;font:var(--fw-semibold) var(--fs-xs)/1.4 var(--font);letter-spacing:.01em;white-space:nowrap;border-radius:var(--radius-pill);background:color-mix(in srgb,var(--chip) 15%,var(--bg-card));color:color-mix(in srgb,var(--chip) 76%,var(--text-heading));border:1px solid color-mix(in srgb,var(--chip) 30%,transparent)}
.chip::before{content:"";inline-size:6px;block-size:6px;border-radius:50%;background:var(--chip);flex:none}
.chip.no-dot::before{display:none}
.chip.solid{background:var(--chip);color:#fff;border-color:transparent}.chip.solid::before{background:rgba(255,255,255,.85)}
.chip.lg{font-size:var(--fs-sm);padding:5px 14px}
[dir="rtl"] .chip{font-family:var(--font-rtl)}
.chip.s-pending,.chip.s-follow_up,.chip.s-low_budget{--chip:var(--c-amber)}
.chip.s-approved,.chip.s-new,.chip.s-open{--chip:var(--c-blue)}
.chip.s-active,.chip.s-deal,.chip.s-won{--chip:var(--c-green)}
.chip.s-completed,.chip.s-interested{--chip:var(--c-teal)}
.chip.s-rejected,.chip.s-not_interested,.chip.s-lost{--chip:var(--c-red)}
.chip.s-meeting{--chip:var(--c-violet)}.chip.s-offer_sent{--chip:var(--c-indigo)}
.chip.s-paused,.chip.s-no_answer,.chip.s-wrong_number,.chip.s-by_mistake{--chip:var(--c-slate)}
.chip.plat-fb{--chip:var(--c-blue)}.chip.plat-ig{--chip:var(--c-violet)}.chip.warn{--chip:var(--c-amber)}
.chip.role-admin{--chip:var(--c-violet)}.chip.role-broker{--chip:var(--c-teal)}
/* .badge — used by shared crm_stage_badge()/crm_status_badge() (which can't be changed). Pill-styled
   like .chip; stage badges carry an inline bg/color that overrides the slate base, status badges use b-*. */
.badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:var(--radius-pill);font:var(--fw-semibold) var(--fs-xs)/1.4 var(--font);white-space:nowrap;background:color-mix(in srgb,var(--c-slate) 15%,var(--bg-card));color:color-mix(in srgb,var(--c-slate) 78%,var(--text-heading));border:1px solid color-mix(in srgb,var(--c-slate) 30%,transparent)}
[dir="rtl"] .badge{font-family:var(--font-rtl)}
.badge.b-accent{background:var(--primary-tint);color:var(--primary);border-color:transparent}
.badge.b-success{background:color-mix(in srgb,var(--success) 15%,var(--bg-card));color:color-mix(in srgb,var(--success) 80%,var(--text-heading));border-color:transparent}
.badge.b-warning{background:color-mix(in srgb,var(--warning) 16%,var(--bg-card));color:color-mix(in srgb,var(--warning) 80%,var(--text-heading));border-color:transparent}
.badge.b-danger{background:color-mix(in srgb,var(--danger) 15%,var(--bg-card));color:color-mix(in srgb,var(--danger) 80%,var(--text-heading));border-color:transparent}
.badge.b-purple{background:color-mix(in srgb,var(--purple) 16%,var(--bg-card));color:color-mix(in srgb,var(--purple) 80%,var(--text-heading));border-color:transparent}

/* ── 5 · BASE / SHELL ── */
*{box-sizing:border-box}
/* Reset the UA default body margin (8px) so the shell sits FLUSH to the viewport
   top-left (no exposed page-background strip). overflow-x:clip (not hidden) prevents
   horizontal scroll WITHOUT making body a scroll container — so .top-header /
   .sidebar position:sticky actually pins. */
html,body{margin:0;padding:0;overflow-x:clip;max-inline-size:100%}
.drawer-scrim{display:none}
.collapse-btn{display:inline-flex}
.sidebar-close{display:none;margin-inline-start:auto;border:0;background:var(--bg-subtle);color:var(--text-secondary);cursor:pointer;font-size:16px;inline-size:32px;block-size:32px;border-radius:var(--radius-sm);align-items:center;justify-content:center}
.app{font-family:var(--font);background:var(--bg-body);color:var(--text);font-size:var(--fs-base);line-height:var(--lh-normal);-webkit-font-smoothing:antialiased;min-block-size:100vh;display:flex}
.app[dir="rtl"]{font-family:var(--font-rtl)}
/* Components below set the `font:` SHORTHAND (which pins var(--font)=Inter), so the
   inherited .app[dir=rtl] Cairo is overridden. Re-assert Cairo for them in RTL so ALL
   text-bearing UI uses the Arabic webfont, not just inherited body/heading text. */
[dir="rtl"] .btn,[dir="rtl"] input,[dir="rtl"] select,[dir="rtl"] textarea,
[dir="rtl"] .qa-btn,[dir="rtl"] .nav-link,[dir="rtl"] .install-btn,
[dir="rtl"] .lang-switch button,[dir="rtl"] .role-seg button,
[dir="rtl"] .view-toggle button,[dir="rtl"] .status-tabs button,[dir="rtl"] .status-tabs a,
[dir="rtl"] .settings-tabs a,[dir="rtl"] .admin-subtabs a,[dir="rtl"] .menu-item,
[dir="rtl"] .continent-btn{font-family:var(--font-rtl)}
.app h1,.app h2,.app h3,.app h4{margin:0;color:var(--text-heading);line-height:var(--lh-tight);font-weight:var(--fw-bold)}
.app a{color:inherit;text-decoration:none}.app button{font-family:inherit}
.sidebar{inline-size:var(--sidebar-w);flex:none;background:var(--bg-sidebar);border-inline-end:1px solid var(--border);display:flex;flex-direction:column;position:sticky;inset-block-start:0;block-size:100vh}
.sidebar-brand{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-5);border-block-end:1px solid var(--border)}
.sidebar-brand b{font-size:var(--fs-md);font-weight:var(--fw-heavy);color:var(--text-heading);letter-spacing:-.02em;white-space:nowrap}
.sidebar-nav{flex:1;overflow-y:auto;padding:var(--sp-4) var(--sp-3)}
.nav-section{margin-block-end:var(--sp-5)}
.nav-section>span{display:block;font-size:var(--fs-xs);font-weight:var(--fw-bold);letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted);padding:0 var(--sp-3) var(--sp-2)}
.nav-link{display:flex;align-items:center;gap:var(--sp-3);padding:9px var(--sp-3);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:var(--fs-sm);font-weight:var(--fw-medium);margin-block-end:2px;transition:all var(--dur) var(--ease);white-space:nowrap}
.nav-link svg{inline-size:18px;block-size:18px;flex:none}
.nav-link:hover{background:var(--bg-card-hover);color:var(--text-heading)}
.nav-link.active{background:var(--primary-tint);color:var(--primary);font-weight:var(--fw-semibold)}
.nav-link .nl-badge{margin-inline-start:auto;font-size:var(--fs-xs);font-weight:var(--fw-bold);background:var(--primary);color:#fff;border-radius:var(--radius-pill);padding:1px 7px}
.sidebar-foot{border-block-start:1px solid var(--border);padding:var(--sp-4)}
.lang-switch{display:flex;background:var(--bg-subtle);border:1px solid var(--border);border-radius:var(--radius-sm);padding:3px;margin-block-end:var(--sp-3)}
.lang-switch button{flex:1;border:0;background:transparent;color:var(--text-secondary);font:var(--fw-semibold) var(--fs-sm)/1 var(--font);cursor:pointer;padding:7px;border-radius:6px}
.lang-switch button.on{background:var(--bg-card);color:var(--primary);box-shadow:var(--shadow-sm)}
.user-card{display:flex;align-items:center;gap:var(--sp-3)}
.avatar{inline-size:38px;block-size:38px;flex:none;border-radius:var(--radius-pill);background:var(--gradient-brand);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:var(--fw-bold);font-size:var(--fs-sm)}
.user-card .u-name{font-size:var(--fs-sm);font-weight:var(--fw-semibold);color:var(--text-heading);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.user-card .u-role{font-size:var(--fs-xs);color:var(--text-muted)}
.main{flex:1;min-inline-size:0;display:flex;flex-direction:column}
.top-header{position:sticky;inset-block-start:0;z-index:var(--z-header);display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-4) var(--sp-6);background:color-mix(in srgb,var(--bg-sidebar) 90%,transparent);backdrop-filter:blur(10px);border-block-end:1px solid var(--border)}
.hamburger{display:none}
.page-title{font-size:var(--fs-xl);font-weight:var(--fw-bold);letter-spacing:-.02em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-inline-size:0}
.header-actions{margin-inline-start:auto;display:flex;align-items:center;gap:var(--sp-2)}
.role-seg{display:inline-flex;align-items:center;gap:6px;background:var(--bg-subtle);border:1px dashed var(--border-strong);border-radius:var(--radius-sm);padding:3px;margin-inline-end:var(--sp-2)}
.role-seg .pv{font-size:9px;font-weight:var(--fw-bold);letter-spacing:.1em;color:var(--text-muted);padding-inline:6px;text-transform:uppercase}
.role-seg button{border:0;background:transparent;color:var(--text-secondary);font:var(--fw-semibold) var(--fs-xs)/1 var(--font);cursor:pointer;padding:6px 10px;border-radius:6px}
.role-seg button.on{background:var(--primary);color:#fff}
.header-btn{inline-size:var(--control-h);block-size:var(--control-h);flex:none;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--border);background:var(--bg-card);color:var(--text-secondary);border-radius:var(--radius-sm);cursor:pointer;position:relative;transition:all var(--dur) var(--ease)}
.header-btn:hover{color:var(--text-heading);border-color:var(--border-strong)}.header-btn svg{inline-size:19px;block-size:19px}
.notif-badge{position:absolute;inset-block-start:-4px;inset-inline-end:-4px;min-inline-size:18px;block-size:18px;padding:0 5px;border-radius:var(--radius-pill);background:var(--danger);color:#fff;font-size:10px;font-weight:var(--fw-bold);display:flex;align-items:center;justify-content:center;border:2px solid var(--bg-sidebar)}
.install-btn{display:inline-flex;align-items:center;gap:var(--sp-2);block-size:var(--control-h);padding-inline:var(--sp-4);border:1px solid var(--border);background:var(--bg-card);color:var(--text);border-radius:var(--radius-sm);font:var(--fw-semibold) var(--fs-sm)/1 var(--font);cursor:pointer;white-space:nowrap}
.container{padding:var(--sp-6) var(--sp-8) var(--sp-12);max-inline-size:var(--container-max);inline-size:100%;margin-inline:auto}
.container.narrow{max-inline-size:var(--container-narrow)}
.collapse-btn svg{transition:transform var(--dur) var(--ease)}
.app[data-collapsed="yes"] .collapse-btn svg{transform:rotate(180deg)}
.app[data-collapsed="yes"] .sidebar{inline-size:var(--sidebar-w-collapsed)}
.app[data-collapsed="yes"] .sidebar-brand b,.app[data-collapsed="yes"] .nav-section>span,.app[data-collapsed="yes"] .nl-badge,.app[data-collapsed="yes"] .sidebar-foot .lang-switch,.app[data-collapsed="yes"] .user-card>div{display:none}
.app[data-collapsed="yes"] .nav-link{justify-content:center;font-size:0;padding-inline:0}
.app[data-collapsed="yes"] .nav-link svg{inline-size:20px;block-size:20px}
.app[data-collapsed="yes"] .sidebar-brand,.app[data-collapsed="yes"] .user-card{justify-content:center}

/* ── 6 · BUTTONS / CARDS / ALERTS ── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--sp-2);block-size:var(--control-h);padding-inline:var(--sp-4);font:var(--fw-semibold) var(--fs-sm)/1 var(--font);border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-card);color:var(--text);cursor:pointer;transition:all var(--dur) var(--ease);white-space:nowrap}
.btn svg{inline-size:16px;block-size:16px}.btn:hover{border-color:var(--border-strong)}
.btn.primary{background:var(--primary);color:var(--primary-contrast);border-color:transparent}.btn.primary:hover{background:var(--primary-hover)}
.btn.success{background:var(--success);color:#fff;border-color:transparent}
.btn.warning{background:var(--warning);color:#221603;border-color:transparent}
.btn.danger{background:var(--danger);color:#fff;border-color:transparent}
.btn.danger-soft{background:transparent;color:var(--danger);border-color:color-mix(in srgb,var(--danger) 35%,transparent)}
.btn.ghost{background:transparent}.btn.block{inline-size:100%}
.btn.sm{block-size:var(--control-h-sm);padding-inline:var(--sp-3);font-size:var(--fs-xs)}
.btn.lg{block-size:var(--control-h-lg);padding-inline:var(--sp-6);font-size:var(--fs-base)}
.btn:focus-visible{outline:none;box-shadow:var(--focus-glow)}
.btn[disabled],.btn.disabled{opacity:.5;cursor:not-allowed}
.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow)}
.card.pad{padding:var(--sp-5)}
/* Vertical rhythm for stacked top-level cards (grid-child cards keep their grid gap). */
.container>.card{margin-block-end:var(--sp-6)}
.card-head{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-3);padding:var(--sp-5) var(--sp-5) 0}
.card-head h3{font-size:var(--fs-lg);letter-spacing:-.01em}
.card-head a{font-size:var(--fs-sm);font-weight:var(--fw-semibold);color:var(--primary)}
.card-title{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-3);margin-block-end:var(--sp-4)}
.card-title h3{font-size:var(--fs-md)}.card-title .ico-t{display:flex;align-items:center;gap:var(--sp-2)}
.card-body{padding:var(--sp-5)}
.alert{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-3) var(--sp-4);border-radius:var(--radius);font-size:var(--fs-sm);font-weight:var(--fw-medium);margin-block-end:var(--sp-3);border:1px solid transparent}
.alert svg{inline-size:18px;block-size:18px;flex:none}
.alert.success{background:color-mix(in srgb,var(--success) 13%,var(--bg-card));color:color-mix(in srgb,var(--success) 72%,var(--text-heading));border-color:color-mix(in srgb,var(--success) 30%,transparent)}
.alert.warning{background:color-mix(in srgb,var(--warning) 14%,var(--bg-card));color:color-mix(in srgb,var(--warning) 72%,var(--text-heading));border-color:color-mix(in srgb,var(--warning) 30%,transparent)}
.alert.error{background:color-mix(in srgb,var(--danger) 13%,var(--bg-card));color:color-mix(in srgb,var(--danger) 72%,var(--text-heading));border-color:color-mix(in srgb,var(--danger) 30%,transparent)}
.alert.info{background:color-mix(in srgb,var(--info) 12%,var(--bg-card));color:color-mix(in srgb,var(--info) 74%,var(--text-heading));border-color:color-mix(in srgb,var(--info) 28%,transparent)}
.alert .a-act{margin-inline-start:auto;font-weight:var(--fw-bold);text-decoration:underline;white-space:nowrap}

/* ── 7 · PAGE HEADER / TABS / TOGGLES ── */
.page-head{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-4);flex-wrap:wrap;margin-block-end:var(--sp-5)}
.page-head h2{font-size:var(--fs-2xl);letter-spacing:-.02em;word-break:break-word}
.head-actions{display:flex;align-items:center;gap:var(--sp-2);flex-wrap:wrap}
.back-link{display:inline-flex;align-items:center;gap:6px;color:var(--text-secondary);font-size:var(--fs-sm);font-weight:var(--fw-medium);margin-block-end:var(--sp-3)}
.view-toggle{display:inline-flex;background:var(--bg-subtle);border:1px solid var(--border);border-radius:var(--radius-sm);padding:3px}
.view-toggle button,.view-toggle a{display:inline-flex;align-items:center;gap:6px;border:0;background:transparent;color:var(--text-secondary);font:var(--fw-semibold) var(--fs-sm)/1 var(--font);cursor:pointer;padding:8px 14px;border-radius:6px}
.view-toggle button svg,.view-toggle a svg{inline-size:16px;block-size:16px}
.view-toggle button.on,.view-toggle a.on{background:var(--bg-card);color:var(--primary);box-shadow:var(--shadow-sm)}
[dir="rtl"] .view-toggle a{font-family:var(--font-rtl)}
.status-tabs{display:flex;gap:var(--sp-1);overflow-x:auto;border-block-end:1px solid var(--border);margin-block-end:var(--sp-5);padding-block-end:0}
.status-tabs button,.status-tabs a{--chip:var(--c-slate);display:inline-flex;align-items:center;gap:6px;border:0;background:transparent;color:var(--text-secondary);font:var(--fw-semibold) var(--fs-sm)/1 var(--font);cursor:pointer;padding:11px 14px;border-block-end:2px solid transparent;white-space:nowrap}
.status-tabs button .cnt,.status-tabs a .cnt{font-size:var(--fs-xs);color:var(--text-muted)}
.status-tabs button.on,.status-tabs a.on{color:var(--chip);border-block-end-color:var(--chip)}
.status-tabs button.on .cnt,.status-tabs a.on .cnt{color:color-mix(in srgb,var(--chip) 70%,var(--text))}
.admin-subtabs{display:flex;gap:var(--sp-2);overflow-x:auto;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:var(--sp-1);margin-block-end:var(--sp-5)}
.admin-subtabs a{display:inline-flex;align-items:center;gap:6px;color:var(--text-secondary);font:var(--fw-semibold) var(--fs-sm)/1 var(--font);padding:9px 14px;border-radius:var(--radius-sm);white-space:nowrap}
.admin-subtabs a.on{background:var(--primary-tint);color:var(--primary)}
.settings-tabs{display:flex;gap:var(--sp-1);overflow-x:auto;border-block-end:1px solid var(--border);margin-block-end:var(--sp-5)}
.settings-tabs a{color:var(--text-secondary);font:var(--fw-semibold) var(--fs-sm)/1 var(--font);padding:11px 14px;border-block-end:2px solid transparent;white-space:nowrap}
.settings-tabs a.on{color:var(--primary);border-block-end-color:var(--primary)}

/* ── 8 · FORMS ── */
label{display:block;font-size:var(--fs-sm);font-weight:var(--fw-semibold);color:var(--text-secondary);margin-block-end:6px}
label.req::after,.required::after{content:" *";color:var(--danger)}
input,select,textarea{inline-size:100%;block-size:var(--control-h);padding-inline:var(--sp-3);background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font:var(--fw-normal) var(--fs-sm)/1 var(--font)}
textarea{block-size:auto;padding:var(--sp-3);line-height:var(--lh-normal);resize:vertical;min-block-size:84px}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--primary);box-shadow:var(--focus-glow)}
input[type=checkbox],input[type=radio]{inline-size:auto;block-size:auto;min-block-size:0;accent-color:var(--primary);cursor:pointer;flex:none}
input[readonly],textarea[readonly],input:disabled,select:disabled{background:var(--bg-subtle);color:var(--text-secondary)}
.field label{font-size:var(--fs-xs)}
.fld{margin-block-end:var(--sp-3)}
.form-help{font-size:var(--fs-xs);color:var(--text-muted);margin-block-start:6px}
.field-error,.input-error{border-color:var(--danger)!important}
.error-text{font-size:var(--fs-xs);color:var(--danger);margin-block-start:6px}
.form-row2,.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-3)}
.form-row3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:var(--sp-3)}
.lead-filter-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:var(--sp-3);align-items:end;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--sp-4);box-shadow:var(--shadow);margin-block-end:var(--sp-5)}
.filter-actions{display:flex;gap:var(--sp-2)}
.subhead{font-size:var(--fs-xs);font-weight:var(--fw-bold);letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);margin-block:var(--sp-5) var(--sp-3)}
.section-header{display:flex;align-items:center;gap:var(--sp-3);margin-block:var(--sp-6) var(--sp-4)}
.section-number{inline-size:28px;block-size:28px;flex:none;border-radius:var(--radius-pill);background:var(--primary-tint);color:var(--primary);display:flex;align-items:center;justify-content:center;font-weight:var(--fw-bold);font-size:var(--fs-sm)}
.section-header h3{font-size:var(--fs-md)}
.pill-readonly{display:inline-flex;align-items:center;gap:6px;background:var(--bg-subtle);border:1px solid var(--border);border-radius:var(--radius-pill);padding:5px 12px;font-size:var(--fs-sm);font-weight:var(--fw-medium);color:var(--text-secondary)}
.contact-pills{display:flex;flex-wrap:wrap;gap:var(--sp-2)}
.help-box{background:var(--bg-subtle);border:1px solid var(--border);border-radius:var(--radius-sm);padding:var(--sp-3);font-size:var(--fs-xs);color:var(--text-secondary);line-height:var(--lh-snug)}
.file-drop{border:1.5px dashed var(--border-strong);border-radius:var(--radius);padding:var(--sp-6);text-align:center;color:var(--text-muted);font-size:var(--fs-sm);background:var(--bg-subtle)}
.code-chip,.var-chip{display:inline-flex;align-items:center;font-family:var(--font-mono);font-size:var(--fs-xs);background:var(--bg-subtle);border:1px solid var(--border);border-radius:6px;padding:3px 8px;color:var(--primary);cursor:pointer}
.var-chip:hover{border-color:var(--primary)}

/* ── 9 · TABLES ── */
.table-wrap{overflow-x:auto;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow)}
.table-wrap.flush{border:0;box-shadow:none;background:transparent}
table{inline-size:100%;border-collapse:collapse;font-size:var(--fs-sm)}
th{text-align:start;font-size:var(--fs-xs);font-weight:var(--fw-bold);letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted);padding:var(--sp-3) var(--sp-4);background:var(--bg-subtle);white-space:nowrap}
th.num,td.num{text-align:end}
td{padding:var(--sp-3) var(--sp-4);border-block-start:1px solid var(--border);color:var(--text);vertical-align:middle}
tbody tr:hover td{background:var(--bg-card-hover)}
tbody tr.clickable{cursor:pointer}
.ck{inline-size:16px;block-size:16px;accent-color:var(--primary);cursor:pointer}
.cell-name{min-inline-size:0;display:flex;align-items:center;gap:8px}
.cell-name b{font-weight:var(--fw-semibold);color:var(--text-heading);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-inline-size:200px;display:inline-block}
.cell-ellipsis{max-inline-size:180px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:inline-block}
.sub{display:block;font-size:var(--fs-xs);color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-inline-size:180px}
.muted{color:var(--text-muted)}.mono{font-family:var(--font-mono);font-size:var(--fs-xs)}
.flag{font-size:var(--fs-md);flex:none}
.aed{font-weight:var(--fw-semibold);color:var(--text-heading);white-space:nowrap}
.aed small{color:var(--text-muted);font-weight:var(--fw-medium);font-size:.8em}
.borderless td{border:0;padding-block:var(--sp-2)}.borderless tbody tr:hover td{background:transparent}
.status-dot{display:inline-flex;align-items:center;gap:6px}.status-dot::before{content:"";inline-size:8px;block-size:8px;border-radius:50%;background:var(--chip,var(--c-slate))}
.bulkbar{display:flex;align-items:center;gap:var(--sp-3);background:var(--primary-tint);border:1px solid color-mix(in srgb,var(--primary) 30%,var(--border));border-radius:var(--radius);padding:var(--sp-2) var(--sp-4);margin-block-end:var(--sp-3);flex-wrap:wrap}
.bulkbar b{color:var(--text-heading);font-size:var(--fs-sm)}.bulkbar .spacer{flex:1}
.pagination{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-3);margin-block-start:var(--sp-4);flex-wrap:wrap}
.pagination .pg-info{font-size:var(--fs-sm);color:var(--text-muted)}.pagination .pg-btns{display:flex;gap:var(--sp-2)}

/* ── 10 · MODALS ── */
.modal-backdrop{position:fixed;inset:0;z-index:var(--z-modal);background:rgba(8,12,20,.55);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;padding:var(--sp-4)}
.modal{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);inline-size:100%;max-inline-size:460px;max-block-size:90vh;display:flex;flex-direction:column;overflow:hidden}
.modal.modal-lg{max-inline-size:600px}.modal.modal-xl{max-inline-size:820px}
.modal-head{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-4) var(--sp-5);border-block-end:1px solid var(--border)}
.modal-head h3{font-size:var(--fs-lg)}
.modal-x{inline-size:32px;block-size:32px;border:0;background:var(--bg-subtle);color:var(--text-secondary);border-radius:var(--radius-sm);cursor:pointer;font-size:var(--fs-lg);line-height:1}
.modal-body{padding:var(--sp-5);overflow-y:auto}
.modal-foot{display:flex;justify-content:flex-end;gap:var(--sp-2);padding:var(--sp-4) var(--sp-5);border-block-start:1px solid var(--border)}
.modal label{margin-block-top:var(--sp-3)}

/* ── 11 · DASHBOARD bits ── */
.welcome{display:flex;align-items:flex-end;justify-content:space-between;gap:var(--sp-4);flex-wrap:wrap;margin-block-end:var(--sp-6)}
.welcome h2{font-size:var(--fs-2xl);letter-spacing:-.02em}.welcome p{margin:var(--sp-1) 0 0;color:var(--text-secondary);font-size:var(--fs-md)}
.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--sp-5);margin-block-end:var(--sp-6)}
.hero-card{grid-column:span 4;background:var(--gradient-brand);color:#fff;border-radius:var(--radius-lg);padding:var(--sp-6);position:relative;overflow:hidden;box-shadow:var(--shadow-md);display:flex;justify-content:space-between;gap:var(--sp-6);flex-wrap:wrap}
.hero-card::after{content:"";position:absolute;inset-block-start:-40%;inset-inline-end:-6%;inline-size:320px;block-size:320px;background:radial-gradient(circle,rgba(255,255,255,.16),transparent 70%);pointer-events:none}
.hero-card .h-label{font-size:var(--fs-sm);font-weight:var(--fw-semibold);opacity:.9;display:flex;align-items:center;gap:var(--sp-2)}
.hero-card .h-value{font-size:var(--fs-3xl);font-weight:var(--fw-heavy);letter-spacing:-.02em;margin-block-start:var(--sp-2);color:#fff}
.hero-card .h-value small{font-size:var(--fs-lg);font-weight:var(--fw-semibold);opacity:.8}
.hero-main{min-inline-size:0;display:flex;flex-direction:column;gap:var(--sp-2)}
.hero-warn{display:inline-flex;align-items:center;gap:var(--sp-2);margin-block-start:var(--sp-3);background:rgba(0,0,0,.18);border:1px solid rgba(255,255,255,.25);border-radius:var(--radius-sm);padding:6px 12px;font-size:var(--fs-sm);font-weight:var(--fw-semibold)}
.hero-sub{display:flex;gap:var(--sp-8);align-items:flex-end}
.hero-sub div span{display:block;font-size:var(--fs-xs);opacity:.85}.hero-sub div b{font-size:var(--fs-lg);font-weight:var(--fw-bold);color:#fff;white-space:nowrap}
.hero-div{inline-size:1px;align-self:stretch;background:rgba(255,255,255,.2)}
.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:var(--sp-5);display:flex;flex-direction:column;gap:var(--sp-2)}
.stat-card .label{font-size:var(--fs-sm);color:var(--text-secondary);font-weight:var(--fw-medium)}
.stat-card .s-label{font-size:var(--fs-sm);color:var(--text-secondary);font-weight:var(--fw-medium)}
.stat-card .value,.stat-card .s-value{font-size:var(--fs-2xl);font-weight:var(--fw-heavy);letter-spacing:-.02em;color:var(--text-heading)}
.stat-card .s-value.success,.stat-card .value.success{color:var(--success)}.stat-card .s-value.warning,.stat-card .value.warning{color:var(--warning)}
.stat-icon{inline-size:34px;block-size:34px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;background:var(--primary-tint);color:var(--primary)}.stat-icon svg{inline-size:18px;block-size:18px}
.section-strip{display:flex;align-items:center;gap:var(--sp-3);margin-block:var(--sp-2) var(--sp-5)}
.section-strip h3{font-size:var(--fs-lg);letter-spacing:-.01em;white-space:nowrap}.section-strip .line{flex:1;block-size:1px;background:var(--border)}.section-strip .meta{font-size:var(--fs-sm);color:var(--text-muted);white-space:nowrap}
.pipeline{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(112px,1fr);gap:var(--sp-3);overflow-x:auto;padding-block-end:var(--sp-1)}
.pipe-item{--chip:var(--c-slate);background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:var(--sp-3) var(--sp-4);display:flex;flex-direction:column;gap:2px;position:relative;overflow:hidden;transition:all var(--dur) var(--ease);cursor:pointer}
.pipe-item::before{content:"";position:absolute;inset-block-start:0;inset-inline-start:0;inline-size:100%;block-size:3px;background:var(--chip)}
.pipe-item:hover{border-color:color-mix(in srgb,var(--chip) 45%,var(--border));box-shadow:var(--shadow-sm);transform:translateY(-1px)}
.pipe-item .p-count{font-size:var(--fs-xl);font-weight:var(--fw-heavy);color:var(--text-heading);letter-spacing:-.02em}
.pipe-item .p-label{font-size:var(--fs-xs);font-weight:var(--fw-semibold);color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pipe-item.s-new{--chip:var(--c-blue)}.pipe-item.s-no_answer,.pipe-item.s-wrong_number,.pipe-item.s-by_mistake,.pipe-item.s-paused{--chip:var(--c-slate)}.pipe-item.s-follow_up,.pipe-item.s-low_budget{--chip:var(--c-amber)}.pipe-item.s-interested{--chip:var(--c-teal)}.pipe-item.s-meeting{--chip:var(--c-violet)}.pipe-item.s-offer_sent{--chip:var(--c-indigo)}.pipe-item.s-deal{--chip:var(--c-green)}.pipe-item.s-not_interested{--chip:var(--c-red)}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-5);margin-block-end:var(--sp-6)}
.rec-list{display:flex;flex-direction:column}
.rec-row{display:flex;align-items:center;gap:var(--sp-3);padding:10px var(--sp-2);border-block-start:1px solid var(--border);transition:background var(--dur) var(--ease);border-radius:var(--radius-sm)}
.rec-row:first-child{border-block-start:0}.rec-row:hover{background:var(--bg-card-hover)}
.rec-main{flex:1;min-inline-size:0}
.rec-main b{display:block;font-weight:var(--fw-semibold);color:var(--text-heading);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rec-main span{display:block;font-size:var(--fs-xs);color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rec-date{font-size:var(--fs-xs);color:var(--text-muted);white-space:nowrap;flex:none}
.quick-actions{display:flex;flex-wrap:wrap;gap:var(--sp-3);margin-block-end:var(--sp-8)}
.charts-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:var(--sp-5);margin-block-end:var(--sp-6)}
.chart-svg{inline-size:100%;block-size:auto;display:block;overflow:visible}
.kpi-tiles{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--sp-4);margin-block-end:var(--sp-6)}
.kpi-tile{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:var(--sp-4);box-shadow:var(--shadow-sm)}
.kpi-tile .k-label{font-size:var(--fs-xs);font-weight:var(--fw-semibold);color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}
.kpi-tile .k-value{font-size:var(--fs-xl);font-weight:var(--fw-heavy);color:var(--text-heading);letter-spacing:-.02em;margin-block:2px}
.kpi-tile .k-value small{font-size:var(--fs-sm);color:var(--text-muted);font-weight:var(--fw-semibold)}.kpi-tile .k-sub{font-size:var(--fs-xs);color:var(--text-secondary)}
.breakdown{margin-block-end:var(--sp-5)}
.bk-grid{display:grid;grid-template-columns:248px 1fr;gap:var(--sp-6);align-items:center;padding:var(--sp-5)}
.donut-wrap{position:relative;display:flex;align-items:center;justify-content:center}
.donut-center{position:absolute;text-align:center}.donut-center b{display:block;font-size:var(--fs-2xl);font-weight:var(--fw-heavy);color:var(--text-heading);letter-spacing:-.02em}.donut-center span{font-size:var(--fs-xs);color:var(--text-muted)}
.legend{display:flex;flex-direction:column;gap:6px;margin-block-start:var(--sp-3)}
.legend div{display:flex;align-items:center;gap:var(--sp-2);font-size:var(--fs-sm)}.legend i{inline-size:10px;block-size:10px;border-radius:3px;flex:none}
.legend .lg-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-inline-size:120px}.legend .lg-val{margin-inline-start:auto;font-weight:var(--fw-semibold);color:var(--text-heading)}
.donut-side{min-inline-size:0}
.bar-mini{block-size:6px;border-radius:var(--radius-pill);background:var(--bg-subtle);overflow:hidden;min-inline-size:60px}.bar-mini i{display:block;block-size:100%;border-radius:var(--radius-pill)}
.sys-health{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--sp-4)}

/* ── 12 · LEAD VIEW / DETAIL bits ── */
.lead-detail-layout{display:grid;grid-template-columns:1fr 320px;gap:var(--sp-5);align-items:start}
.aside{display:flex;flex-direction:column}.aside .card{margin-block-end:var(--sp-4)}
.stage-pill-lg{--chip:var(--c-green);display:inline-flex;align-items:center;gap:var(--sp-2);font-size:var(--fs-md);font-weight:var(--fw-bold);padding:8px 18px;border-radius:var(--radius-pill);background:color-mix(in srgb,var(--chip) 16%,var(--bg-card));color:color-mix(in srgb,var(--chip) 78%,var(--text-heading));border:1px solid color-mix(in srgb,var(--chip) 32%,transparent)}
.stage-pill-lg::before{content:"";inline-size:9px;block-size:9px;border-radius:50%;background:var(--chip)}
.deal-card{border-inline-start:3px solid var(--success);background:color-mix(in srgb,var(--success) 6%,var(--bg-card))}
.deal-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-3)}
.with-call{display:flex;gap:var(--sp-2)}.with-call input{flex:1}
.call-btn{flex:none;inline-size:var(--control-h);block-size:var(--control-h);display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-card);color:var(--primary);cursor:pointer}
.voice-row{display:flex;align-items:center;gap:var(--sp-2);margin-block-start:var(--sp-3);flex-wrap:wrap}
.voice-row select{inline-size:auto;flex:1;max-inline-size:220px}
.mic-btn{flex:none;inline-size:var(--control-h);block-size:var(--control-h);display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-card);color:var(--text-secondary);cursor:pointer}
.mic-btn.rec{background:color-mix(in srgb,var(--danger) 15%,var(--bg-card));border-color:var(--danger);color:var(--danger)}
.voice-indicator{display:inline-flex;align-items:center;gap:6px;font-size:var(--fs-xs);font-weight:var(--fw-semibold);color:var(--danger)}
.voice-indicator i{inline-size:8px;block-size:8px;border-radius:50%;background:var(--danger);animation:pulse 1s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}
.note-card{background:var(--bg-subtle);border:1px solid var(--border);border-radius:var(--radius);padding:var(--sp-3) var(--sp-4);margin-block-end:var(--sp-3)}
.note-card .nc-head{display:flex;align-items:baseline;gap:var(--sp-2);margin-block-end:6px}
.note-card .nc-meta{flex:1;min-inline-size:0;display:flex;align-items:baseline;gap:6px;overflow:hidden}
.note-card .nc-author{font-size:var(--fs-sm);font-weight:var(--fw-semibold);color:var(--text-heading);white-space:nowrap}
.note-card .nc-time{font-size:var(--fs-xs);color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.note-card .nc-actions{margin-inline-start:auto;display:flex;gap:var(--sp-2);flex:none}
.note-card .nc-actions button{border:0;background:transparent;color:var(--text-muted);font-size:var(--fs-xs);font-weight:var(--fw-semibold);cursor:pointer;padding:2px 4px}
.note-card .nc-actions button:hover{color:var(--text-heading)}
.note-card .nc-body{font-size:var(--fs-sm);color:var(--text);word-break:break-word}
.qa-list{display:flex;flex-direction:column;gap:var(--sp-2)}
.qa-btn{display:flex;align-items:center;gap:var(--sp-3);inline-size:100%;padding:10px var(--sp-3);border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-card);color:var(--text);font:var(--fw-semibold) var(--fs-sm)/1 var(--font);cursor:pointer}
.qa-btn:hover{border-color:var(--border-strong);background:var(--bg-card-hover)}.qa-btn svg{inline-size:18px;block-size:18px}
.qa-btn.wa{color:#1FA855}.qa-btn.call{color:var(--primary)}.qa-btn.mail{color:var(--c-violet)}
.deflist{display:flex;flex-direction:column;gap:var(--sp-3)}
.deflist .row{display:flex;align-items:baseline;justify-content:space-between;gap:var(--sp-3);font-size:var(--fs-sm)}
.deflist .row .k{color:var(--text-muted);flex:none;white-space:nowrap}.deflist .row .v{color:var(--text-heading);font-weight:var(--fw-medium);text-align:end;word-break:break-word}.deflist .row .v a{color:var(--primary)}
.status-line{display:flex;flex-direction:column;gap:var(--sp-2)}.status-line .when{font-size:var(--fs-xs);color:var(--text-muted)}
.timeline{display:flex;flex-direction:column}
.timeline-event{display:flex;gap:var(--sp-3);padding-block:var(--sp-2);position:relative}
.timeline-event .te-dot{flex:none;inline-size:10px;block-size:10px;border-radius:50%;margin-block-start:5px;background:var(--c-slate)}
.timeline-event .te-body{min-inline-size:0}.timeline-event .te-text{font-size:var(--fs-sm);color:var(--text)}.timeline-event .te-text .frm{color:var(--text-muted)}.timeline-event .te-time{font-size:var(--fs-xs);color:var(--text-muted)}
.lv-head{margin-block-end:var(--sp-5)}.lv-head h2{font-size:var(--fs-2xl);letter-spacing:-.02em;word-break:break-word}
.lv-sub{display:flex;align-items:center;gap:var(--sp-2);flex-wrap:wrap;margin-block-start:var(--sp-2);color:var(--text-muted);font-size:var(--fs-sm)}
.lv-sub .dot{inline-size:3px;block-size:3px;border-radius:50%;background:var(--text-muted)}
.click-to-call-cta{display:none}

/* ── 13 · KANBAN ── */
.kanban{display:grid;grid-auto-flow:column;grid-auto-columns:264px;gap:var(--sp-4);overflow-x:auto;padding-block-end:var(--sp-3);align-items:start;scroll-snap-type:x proximity}
.kanban-col{--chip:var(--c-slate);background:var(--bg-subtle);border:1px solid var(--border);border-radius:var(--radius);display:flex;flex-direction:column;max-block-size:72vh;scroll-snap-align:start}
.kanban-col.drop{outline:2px dashed var(--chip);outline-offset:-3px}
.kanban-col-head{display:flex;align-items:center;gap:var(--sp-2);padding:var(--sp-3) var(--sp-4);border-block-start:3px solid var(--chip);border-start-start-radius:var(--radius);border-start-end-radius:var(--radius)}
.kanban-col-head b{font-size:var(--fs-sm);font-weight:var(--fw-bold);color:var(--text-heading)}
.kanban-col-head .kc-count{margin-inline-start:auto;font-size:var(--fs-xs);font-weight:var(--fw-bold);color:color-mix(in srgb,var(--chip) 76%,var(--text-heading));background:color-mix(in srgb,var(--chip) 16%,var(--bg-card));border-radius:var(--radius-pill);padding:1px 9px}
.kanban-cards{display:flex;flex-direction:column;gap:var(--sp-2);padding:var(--sp-2) var(--sp-3) var(--sp-3);overflow-y:auto}
.kanban-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:var(--sp-3);box-shadow:var(--shadow-sm);cursor:grab}
.kanban-card:active{cursor:grabbing}.kanban-card.dragging{opacity:.4}
.kanban-card .kc-name{display:flex;align-items:center;gap:6px;font-weight:var(--fw-semibold);color:var(--text-heading);font-size:var(--fs-sm)}
.kanban-card .kc-name b{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.kanban-card .kc-meta{font-size:var(--fs-xs);color:var(--text-muted);margin-block-start:4px;display:flex;flex-direction:column;gap:2px}
.kanban-card .kc-meta span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.kanban-card select{margin-block-start:var(--sp-2);block-size:var(--control-h-sm);font-size:var(--fs-xs);padding-inline:8px}
.kanban-empty{font-size:var(--fs-xs);color:var(--text-muted);text-align:center;padding:var(--sp-4)}
.kanban-help{font-size:var(--fs-sm);color:var(--text-muted);margin-block-end:var(--sp-3)}
/* Aliases for the leads-page kanban JS class names (.kanban-list/.kanban-count/.drop-hover)
   so they get the cpg kanban styling without rewriting the drag/drop JS. */
.kanban-list{display:flex;flex-direction:column;gap:var(--sp-2);padding:var(--sp-2) var(--sp-3) var(--sp-3);overflow-y:auto}
.kanban-col-head .kanban-count{margin-inline-start:auto;font-size:var(--fs-xs);font-weight:var(--fw-bold);color:color-mix(in srgb,var(--c-slate) 76%,var(--text-heading));background:color-mix(in srgb,var(--c-slate) 16%,var(--bg-card));border-radius:var(--radius-pill);padding:1px 9px}
.kanban-list.drop-hover{outline:2px dashed var(--primary);outline-offset:-3px;background:var(--primary-tint)}

/* ── 14 · WIZARD / AUTH / ADSCOPE / MISC ── */
.wizard-steps{display:flex;align-items:center;gap:var(--sp-2);margin-block-end:var(--sp-6)}
.wizard-step-dot{display:flex;align-items:center;gap:var(--sp-2);font-size:var(--fs-sm);font-weight:var(--fw-semibold);color:var(--text-muted)}
.wizard-step-dot .n{inline-size:30px;block-size:30px;flex:none;border-radius:var(--radius-pill);background:var(--bg-subtle);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-weight:var(--fw-bold)}
.wizard-step-dot.active{color:var(--primary)}.wizard-step-dot.active .n{background:var(--primary);color:#fff;border-color:transparent}
.wizard-step-dot.done .n{background:var(--primary-tint);color:var(--primary);border-color:transparent}
.wizard-line{flex:1;block-size:2px;background:var(--border);min-inline-size:20px}
.wizard-line.done{background:var(--primary)}
.question-box,.ad-box{background:var(--bg-subtle);border:1px solid var(--border);border-radius:var(--radius);padding:var(--sp-4);margin-block-end:var(--sp-3)}
.budget-summary{background:var(--primary-tint);border:1px solid color-mix(in srgb,var(--primary) 28%,var(--border));border-radius:var(--radius);padding:var(--sp-4);display:flex;align-items:center;justify-content:space-between;gap:var(--sp-3);flex-wrap:wrap}
.budget-summary .bs-val{font-size:var(--fs-xl);font-weight:var(--fw-heavy);color:var(--text-heading)}
.continent-select,.form-source-toggle{display:flex;flex-wrap:wrap;gap:var(--sp-2)}
.continent-btn{padding:8px 14px;border:1px solid var(--border);border-radius:var(--radius-pill);background:var(--bg-card);color:var(--text-secondary);font:var(--fw-semibold) var(--fs-sm)/1 var(--font);cursor:pointer}
.continent-btn.on{background:var(--primary-tint);color:var(--primary);border-color:color-mix(in srgb,var(--primary) 35%,transparent)}
.check-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:var(--sp-2)}
.check-item{display:flex;align-items:center;gap:var(--sp-2);padding:9px var(--sp-3);border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-card);font-size:var(--fs-sm);cursor:pointer}
.check-item input{inline-size:16px;block-size:16px;accent-color:var(--primary);flex:none}
.radio-card{display:flex;align-items:flex-start;gap:var(--sp-3);padding:var(--sp-3) var(--sp-4);border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-card);cursor:pointer}
.radio-card.on{border-color:var(--primary);background:var(--primary-tint)}
.radio-card.disabled{opacity:.5;cursor:not-allowed}
.auth-wrap{min-block-size:100vh;display:flex;align-items:center;justify-content:center;padding:var(--sp-5);background:var(--bg-body)}
.auth-card{inline-size:100%;max-inline-size:var(--container-auth);background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:var(--sp-8)}
.auth-brand{display:flex;flex-direction:column;align-items:center;gap:var(--sp-3);margin-block-end:var(--sp-6);text-align:center}
.auth-brand h1{font-size:var(--fs-2xl);letter-spacing:-.02em}.auth-brand p{color:var(--text-secondary);font-size:var(--fs-sm)}
.auth-hr{border:0;border-block-start:1px solid var(--border);margin-block:var(--sp-5)}
.auth-foot{text-align:center;font-size:var(--fs-sm);color:var(--text-secondary)}.auth-foot a{color:var(--primary);font-weight:var(--fw-semibold)}
.ad-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column}
.ad-card .ac-media{aspect-ratio:1.6;background:repeating-linear-gradient(45deg,var(--bg-subtle),var(--bg-subtle) 10px,var(--bg-card-hover) 10px,var(--bg-card-hover) 20px);display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-family:var(--font-mono);font-size:var(--fs-xs)}
.ad-card .ac-body{padding:var(--sp-4);display:flex;flex-direction:column;gap:var(--sp-2);flex:1}
.chip-row{display:flex;flex-wrap:wrap;gap:var(--sp-2);align-items:center}
.notif-row{display:flex;align-items:flex-start;gap:var(--sp-3);padding:var(--sp-4);border-block-start:1px solid var(--border)}
.notif-row:first-child{border-block-start:0}
.notif-row.unread{background:var(--primary-tint)}
.notif-ico{inline-size:38px;block-size:38px;flex:none;border-radius:var(--radius-pill);background:var(--primary-tint);color:var(--primary);display:flex;align-items:center;justify-content:center}
.notif-row .nr-body{flex:1;min-inline-size:0}.notif-row .nr-title{font-size:var(--fs-sm);font-weight:var(--fw-semibold);color:var(--text-heading)}.notif-row .nr-msg{font-size:var(--fs-sm);color:var(--text-secondary)}.notif-row .nr-time{font-size:var(--fs-xs);color:var(--text-muted);margin-block-start:2px}
.unread-dot{inline-size:9px;block-size:9px;border-radius:50%;background:var(--primary);flex:none;margin-block-start:6px}
.empty{padding:var(--sp-12) var(--sp-6);text-align:center;color:var(--text-muted)}.empty .ico{font-size:2rem;display:block;margin-block-end:var(--sp-2)}
.pre{background:var(--bg-subtle);border:1px solid var(--border);border-radius:var(--radius-sm);padding:var(--sp-4);font-family:var(--font-mono);font-size:var(--fs-xs);color:var(--text);overflow-x:auto;white-space:pre-wrap;word-break:break-word;line-height:var(--lh-snug)}
.col8{grid-column:span 8}.col6{grid-column:span 6}.col4{grid-column:span 4}.col3{grid-column:span 3}
.grid12{display:grid;grid-template-columns:repeat(12,1fr);gap:var(--sp-5)}

/* ── 14b · TOGGLE SWITCH · TOASTS · DROPDOWNS · SORT/DENSITY · SECRET · LOADING ── */
/* Toggle switch (distinct from checkbox) — PHP: <label class="switch"><input type=checkbox><span class=track></span> Label</label> */
.switch{display:inline-flex;align-items:center;gap:var(--sp-3);cursor:pointer;font-size:var(--fs-sm);color:var(--text);font-weight:var(--fw-medium)}
.switch>input{position:absolute;opacity:0;inline-size:1px;block-size:1px;margin:0}
.switch .track{inline-size:42px;block-size:24px;flex:none;border-radius:var(--radius-pill);background:var(--border-strong);position:relative;transition:background var(--dur) var(--ease)}
.switch .track::after{content:"";position:absolute;inset-block-start:2px;inset-inline-start:2px;inline-size:20px;block-size:20px;border-radius:50%;background:#fff;box-shadow:var(--shadow-sm);transition:transform var(--dur) var(--ease)}
.switch>input:checked+.track{background:var(--primary)}
.switch>input:checked+.track::after{transform:translateX(18px)}
[dir="rtl"] .switch>input:checked+.track::after{transform:translateX(-18px)}
.switch>input:focus-visible+.track{box-shadow:var(--focus-glow)}
.switch>input:disabled+.track{opacity:.5;cursor:not-allowed}

/* Toasts — floating, auto-stack bottom-end. <div class="toast-stack"><div class="toast success">…</div></div> */
.toast-stack{position:fixed;inset-block-end:var(--sp-5);inset-inline-end:var(--sp-5);z-index:var(--z-toast);display:flex;flex-direction:column;gap:var(--sp-2);max-inline-size:380px}
.toast{--chip:var(--c-slate);display:flex;align-items:flex-start;gap:var(--sp-3);background:var(--bg-card);border:1px solid var(--border);border-inline-start:3px solid var(--chip);border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:var(--sp-3) var(--sp-4);animation:toast-in var(--dur) var(--ease)}
.toast.success{--chip:var(--success)}.toast.error{--chip:var(--danger)}.toast.warning{--chip:var(--warning)}.toast.info{--chip:var(--info)}
.toast .t-ico{flex:none;color:var(--chip);margin-block-start:1px}.toast .t-ico svg{inline-size:18px;block-size:18px;display:block}
.toast .t-body{flex:1;min-inline-size:0}.toast .t-title{font-size:var(--fs-sm);font-weight:var(--fw-semibold);color:var(--text-heading)}.toast .t-msg{font-size:var(--fs-xs);color:var(--text-secondary)}
.toast .t-x{flex:none;border:0;background:transparent;color:var(--text-muted);cursor:pointer;font-size:var(--fs-md);line-height:1;padding:0}.toast .t-x:hover{color:var(--text-heading)}
@keyframes toast-in{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* Dropdown / menu (user menu + generic). Parent .dropdown is position:relative; .menu is the panel. */
.dropdown{position:relative}
.menu{position:absolute;inset-block-start:calc(100% + 6px);inset-inline-end:0;z-index:var(--z-dropdown);min-inline-size:220px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:var(--sp-2)}
[dir="rtl"] .menu{inset-inline-end:auto;inset-inline-start:0}
.menu-head{padding:var(--sp-2) var(--sp-3);font-size:var(--fs-xs);font-weight:var(--fw-bold);letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted)}
.menu-item{display:flex;align-items:center;gap:var(--sp-3);inline-size:100%;padding:9px var(--sp-3);border:0;background:transparent;color:var(--text);font:var(--fw-medium) var(--fs-sm)/1.2 var(--font);border-radius:var(--radius-sm);cursor:pointer;text-align:start;white-space:nowrap}
.menu-item:hover{background:var(--bg-card-hover);color:var(--text-heading)}
.menu-item svg{inline-size:16px;block-size:16px;flex:none;color:var(--text-muted)}
.menu-item.danger{color:var(--danger)}.menu-item.danger svg{color:var(--danger)}
.menu-sep{block-size:1px;background:var(--border);margin:var(--sp-2) calc(var(--sp-2) * -1)}
/* Notifications dropdown — wider, header + scrollable list + footer */
.notif-dropdown{inline-size:360px;max-inline-size:calc(100vw - var(--sp-8));padding:0}
.notif-dropdown .nd-head{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-3);padding:var(--sp-3) var(--sp-4);border-block-end:1px solid var(--border)}
.notif-dropdown .nd-head b{font-size:var(--fs-sm);color:var(--text-heading)}
.notif-dropdown .nd-head a{font-size:var(--fs-xs);font-weight:var(--fw-semibold);color:var(--primary)}
.notif-dropdown .nd-list{max-block-size:340px;overflow-y:auto}
.notif-dropdown .notif-row{padding:var(--sp-3) var(--sp-4)}
.notif-dropdown .nd-foot{border-block-start:1px solid var(--border)}
.notif-dropdown .nd-foot a{display:block;padding:11px;font-size:var(--fs-sm);font-weight:var(--fw-semibold);color:var(--primary);text-align:center}
.notif-dropdown .nd-foot a:hover{background:var(--bg-card-hover)}

/* Sortable table headers + density */
th.sortable{cursor:pointer;user-select:none}
th.sortable:hover{color:var(--text-secondary)}
th.sortable .sort-ico{display:inline-block;margin-inline-start:4px;opacity:.4;font-size:9px}
th.sortable.asc .sort-ico,th.sortable.desc .sort-ico{opacity:1;color:var(--primary)}
.table-wrap.compact td,.table-wrap.compact th{padding-block:6px}

/* Masked-secret field with reveal toggle. <div class="input-group"><input type=password><button class=ig-btn>👁</button></div> */
.input-group{position:relative;display:flex}
.input-group>input{padding-inline-end:42px}
.input-group .ig-btn{position:absolute;inset-inline-end:0;inset-block:0;inline-size:42px;display:inline-flex;align-items:center;justify-content:center;border:0;background:transparent;color:var(--text-muted);cursor:pointer}
.input-group .ig-btn:hover{color:var(--text-heading)}.input-group .ig-btn svg{inline-size:16px;block-size:16px}
.secret-static{display:inline-flex;align-items:center;gap:var(--sp-2);font-family:var(--font-mono);font-size:var(--fs-sm);letter-spacing:2px;color:var(--text-secondary)}

/* Loading states — skeleton shimmer + spinner */
.skeleton{background:linear-gradient(90deg,var(--bg-subtle) 25%,var(--bg-card-hover) 37%,var(--bg-subtle) 63%);background-size:400% 100%;border-radius:var(--radius-sm);animation:skeleton 1.4s ease infinite}
.skeleton-line{block-size:12px;margin-block-end:8px}.skeleton-line.w60{inline-size:60%}.skeleton-line.w40{inline-size:40%}
@keyframes skeleton{0%{background-position:100% 0}100%{background-position:-100% 0}}
.spinner{inline-size:26px;block-size:26px;flex:none;border-radius:50%;border:3px solid var(--border);border-block-start-color:var(--primary);animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.loading-row{display:flex;align-items:center;gap:var(--sp-3);justify-content:center;padding:var(--sp-10) var(--sp-6);color:var(--text-muted);font-size:var(--fs-sm)}

/* ── 15 · RESPONSIVE / MOBILE ── */
@media(max-width:1100px){.kpi-tiles{grid-template-columns:repeat(2,1fr)}.sys-health{grid-template-columns:repeat(2,1fr)}.bk-grid{grid-template-columns:1fr}.donut-wrap{justify-content:flex-start}}
@media(max-width:1024px){
  .sidebar{position:fixed;inset-block:0;inset-inline-start:0;z-index:var(--z-sidebar);transform:translateX(-100%);transition:transform var(--dur) var(--ease)}
  [dir="rtl"] .sidebar{transform:translateX(100%)}
  .app[data-drawer="open"] .sidebar{transform:none;box-shadow:var(--shadow-lg)}
  .app[data-drawer="open"] .drawer-scrim{display:block;position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:calc(var(--z-sidebar) - 1)}
  .hamburger{display:inline-flex}
  .collapse-btn{display:none}
  .sidebar-close{display:inline-flex}
  .app[data-collapsed="yes"] .sidebar{inline-size:var(--sidebar-w)}
  .app[data-collapsed="yes"] .nav-link{font-size:var(--fs-sm);padding-inline:var(--sp-3);justify-content:flex-start}
  .app[data-collapsed="yes"] .sidebar-brand b,.app[data-collapsed="yes"] .nav-section>span,.app[data-collapsed="yes"] .nl-badge,.app[data-collapsed="yes"] .sidebar-foot .lang-switch,.app[data-collapsed="yes"] .user-card>div{display:revert}
  .kpi-grid{grid-template-columns:repeat(2,1fr)}.hero-card{grid-column:span 2}
  .two-col,.lead-detail-layout{grid-template-columns:1fr}
  .grid12>.col8,.grid12>.col6,.grid12>.col4,.grid12>.col3{grid-column:span 12}
}
@media(max-width:640px){
  .container{padding:var(--sp-4) var(--sp-4) var(--sp-12)}
  .top-header{padding:var(--sp-3) var(--sp-4)}
  .role-seg .pv{display:none}
  .install-btn{display:none}
  .kpi-grid{grid-template-columns:1fr}.hero-card{grid-column:span 1}
  .kpi-tiles,.sys-health,.charts-row{grid-template-columns:1fr}
  .form-grid,.form-row2,.form-row3,.deal-grid,.check-grid{grid-template-columns:1fr}
  .hero-sub{gap:var(--sp-5)}
  /* inputs ≥16px to stop iOS zoom */
  input,select,textarea{font-size:16px;block-size:46px}
  textarea{block-size:auto}
  .btn{block-size:46px}
  /* tables → cards */
  /* Neutralise any inline min-width so card mode fills the container (else the table
     stays its desktop min-width and the value column is pushed off-screen). */
  .table-as-cards{min-width:0!important;display:block}
  .table-as-cards thead{display:none}
  .table-as-cards tbody{display:block}
  .table-as-cards tr{display:block;border:1px solid var(--border);border-radius:var(--radius);margin:var(--sp-3);padding:var(--sp-2);background:var(--bg-card)}
  .table-as-cards td{display:flex;justify-content:space-between;gap:var(--sp-4);border:0;padding:var(--sp-2) var(--sp-3);text-align:end}
  .table-as-cards td::before{content:attr(data-label);font-size:var(--fs-xs);font-weight:var(--fw-bold);text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);text-align:start;flex:none}
  .table-as-cards .cell-name b{max-inline-size:none}
  /* full-screen modals */
  .modal-backdrop{padding:0;align-items:stretch}
  .modal,.modal.modal-lg,.modal.modal-xl{max-inline-size:none;max-block-size:none;block-size:100%;border-radius:0;border:0}
  /* kanban swipe */
  .kanban{grid-auto-columns:86vw;scroll-snap-type:x mandatory;gap:var(--sp-3)}
  .kanban-col{max-block-size:none}
  /* sticky CTA visible */
  .click-to-call-cta{display:flex;gap:var(--sp-3);position:fixed;inset-inline:0;inset-block-end:0;z-index:var(--z-sticky-cta);padding:var(--sp-3);background:var(--bg-sidebar);border-block-start:1px solid var(--border);box-shadow:var(--shadow-lg)}
  .click-to-call-cta .btn{flex:1}
  .has-sticky-cta{padding-block-end:84px}
  /* floating components reflow */
  .toast-stack{inset-inline:var(--sp-3);inset-block-end:var(--sp-3);max-inline-size:none}
  .notif-dropdown{position:fixed;inset-block-start:64px;inset-inline:var(--sp-3);inline-size:auto;max-inline-size:none}
  .menu{position:fixed;inset-block-start:auto;inset-block-end:0;inset-inline:0;min-inline-size:0;border-start-start-radius:var(--radius-lg);border-start-end-radius:var(--radius-lg);border-end-start-radius:0;border-end-end-radius:0;padding:var(--sp-3)}
}
