/**
 * GetPro — application styles (components, layouts, pages).
 * Design tokens: public/theme.css → public/design-system.css (DS V1 aliases). Single link: /styles.css.
 * Spec: docs/DESIGN_SYSTEM.md
 */
/* PERF: Inline formerly-@imported CSS to avoid waterfall requests on first paint. */

/**
 * ========== BEGIN inlined: public/theme.css ==========
 */
/**
 * GetPro — global design tokens (Material Design 3 aligned; DS V1 palette in docs/DESIGN_SYSTEM.md)
 * Single source of truth for colors, typography, spacing, shape, elevation.
 * Imported first by styles.css; design-system.css adds canonical aliases. Do not duplicate :root elsewhere.
 */

:root {
  /* —— Semantic colors (M3 roles) — GetPro Design System V1 (see docs/DESIGN_SYSTEM.md + public/design-system.css) — */
  --color-primary: #6c5ce7;
  --color-on-primary: #ffffff;
  --color-primary-container: #ede9fe;
  --color-on-primary-container: #2e1064;
  --color-secondary: #5a4bd1;
  --color-on-secondary: #ffffff;
  --color-secondary-container: #e8def8;
  --color-on-secondary-container: #1d192b;
  --color-background: #f6f7fb;
  --color-surface: #ffffff;
  /* Alternate / subtle surface (maps to DS --color-surface-alt) */
  --color-surface-variant: #f1f3f9;
  --color-text-primary: #121417;
  --color-text-secondary: #5f6b7a;
  --color-text-tertiary: #8a94a6;
  --color-outline: #e4e8f0;
  --color-outline-strong: #d6dbe6;
  --color-error: #dc2626;
  --color-on-error: #ffffff;
  --color-error-container: #fee2e2;
  --color-on-error-container: #450a0a;
  --color-success: #16a34a;
  --color-warning: #f59e0b;
  --color-focus: #6c5ce7;

  /* Misc palette (marketing / tenant themes — single reference, avoids hex in styles.css) */
  --color-slate-100: #f1f5f9;
  --color-amber-600: #d4a012;
  --color-amber-300: #fbbf24;
  --palette-tenant-green: #198754;
  --palette-tenant-blue: #0066cc;
  --palette-tenant-sky: #6ba3c7;
  --palette-tenant-forest: #1f7a3d;
  --palette-tenant-teal: #007a4d;
  --palette-tenant-navy: #1e3a8a;
  --palette-tenant-violet: #7c3aed;
  --palette-tenant-cyan: #0d9488;

  /* —— Legacy aliases (used across styles.css / views) —— */
  --color-white: #ffffff;
  --color-black: #1c1b1f;
  --bg: var(--color-background);
  --surface: var(--color-surface);
  --text-primary: var(--color-text-primary);
  --text-muted: var(--color-text-secondary);
  --text-muted-soft: var(--color-text-tertiary);
  --border: var(--color-outline);
  --border-strong: var(--color-outline-strong);
  --topbar-bg: var(--color-background);
  --text: var(--color-text-primary);
  --muted: var(--color-text-secondary);
  --muted-soft: var(--color-text-tertiary);
  --wf-primary: var(--color-primary);
  --wf-primary-dark: #5a4bd1;
  --wf-primary-light: #a5b4fc;
  --wf-primary-rgb: 108, 92, 231;
  --wf-secondary: var(--wf-primary-dark);
  --wf-secondary-hover: #4c3d9e;
  --wf-secondary-deep: #312a72;
  --link: var(--color-primary);
  --pro-orange: var(--color-primary);
  --pro-orange-hover: var(--wf-primary-dark);
  --pro-dark: var(--wf-secondary-deep);
  --accent-cyan: #22d3ee;
  --primary-soft-bg: rgba(var(--wf-primary-rgb), 0.08);
  --primary-softer-bg: rgba(var(--wf-primary-rgb), 0.05);
  --focus-ring: rgba(var(--wf-primary-rgb), 0.32);
  --primary-border-hover: rgba(var(--wf-primary-rgb), 0.35);
  --secondary-fill-ghost: var(--primary-softer-bg);
  --elevation-1: 0 2px 6px rgba(0, 0, 0, 0.08);
  --elevation-2: 0 6px 20px rgba(0, 0, 0, 0.12);
  /* DS V1 subtle elevation (prefer for cards / surfaces) */
  --elevation-sm: 0 1px 2px rgba(0, 0, 0, 0.04);
  --elevation-md: 0 4px 12px rgba(0, 0, 0, 0.06);
  --shadow: var(--elevation-2);
  --card-shadow-sm: var(--elevation-1);
  --cta-card-shadow: 0 10px 30px rgba(0, 0, 0, 0.08);
  --footer-btn-shadow: 0 3px 14px rgba(0, 0, 0, 0.18);
  --btn-primary-bg: var(--color-primary);
  --btn-primary-hover: var(--wf-primary-dark);
  --btn-primary-text: var(--color-on-primary);
  --btn-secondary-bg: transparent;
  --btn-secondary-border: var(--color-outline-strong);
  --btn-secondary-hover: var(--primary-soft-bg);
  --cta-gradient: var(--btn-primary-bg);
  --cta-gradient-hover: var(--btn-primary-hover);
  --hero-kicker-bg: var(--primary-softer-bg);
  --article-thumb-gradient: var(--primary-soft-bg);
  --footer-bg: var(--wf-secondary-deep);
  --footer-cta-gradient: var(--footer-bg);
  --footer-main-gradient: var(--footer-bg);
  --footer-on-dark: rgba(255, 255, 255, 0.92);
  --footer-on-dark-muted: rgba(255, 255, 255, 0.72);
  --footer-on-dark-faint: rgba(255, 255, 255, 0.55);
  --footer-on-dark-border: rgba(255, 255, 255, 0.12);
  --footer-cta-lead: rgba(255, 255, 255, 0.88);
  --wf-footer-link-hover: var(--color-white);
  --flash-error-border: color-mix(in srgb, var(--color-error) 35%, transparent);
  --flash-error-bg: color-mix(in srgb, var(--color-error) 8%, transparent);
  --flash-error-text: color-mix(in srgb, var(--color-error) 88%, var(--color-text-primary));
  --flash-success-border: color-mix(in srgb, var(--color-success) 38%, transparent);
  --flash-success-bg: color-mix(in srgb, var(--color-success) 10%, transparent);
  --flash-success-text: color-mix(in srgb, var(--color-success) 82%, var(--color-text-primary));
  --flash-info-border: color-mix(in srgb, var(--color-primary) 30%, transparent);
  --flash-info-bg: color-mix(in srgb, var(--wf-primary) 7%, var(--surface));
  --flash-info-text: var(--color-text-primary);

  /* —— Typography — system stack first (avoid render-blocking webfonts) —— */
  --font-display: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  --font-family-body: var(--font-display);
  --typo-display-small-size: 2.25rem;
  --typo-display-small-line: 1.2;
  --typo-headline-medium-size: 1.75rem;
  --typo-headline-medium-line: 1.25;
  --typo-title-large-size: 1.375rem;
  --typo-title-large-line: 1.3;
  --typo-body-large-size: 1rem;
  --typo-body-large-line: 1.5;
  --typo-body-medium-size: 0.875rem;
  --typo-body-medium-line: 1.45;
  --typo-label-large-size: 0.875rem;
  --typo-label-large-weight: 600;
  --typo-label-small-size: 0.75rem;

  /* —— Spacing: strict 8px grid (8, 16, 24, 32, 40) —— */
  --space-1: 8px;
  --space-2: 16px;
  --space-3: 24px;
  --space-4: 32px;
  --space-5: 40px;
  /** Minimum touch target (outside the 8px content scale). */
  --space-touch: 48px;

  /* Legacy spacing names → map to 8px grid (no raw px outside tokens). */
  --spacing-1: var(--space-1);
  --spacing-2: var(--space-1);
  --spacing-3: var(--space-2);
  --spacing-4: var(--space-2);
  --spacing-5: var(--space-3);
  --spacing-6: var(--space-4);
  --spacing-8: var(--space-touch);

  /* —— Extended spacing (tokenized former raw px; prefer these over literals in components) —— */
  --space-half: 4px;
  --space-0-625: 5px;
  --space-0-75: 6px;
  --space-1-125: 9px;
  --space-1-25: 10px;
  --space-1-375: 11px;
  --space-1-5: 12px;
  --space-1-625: 13px;
  --space-1-75: 14px;
  --space-1-875: 15px;
  --space-2-125: 17px;
  --space-2-25: 18px;
  --space-2-5: 20px;
  --space-2-75: 22px;
  --space-3-25: 26px;
  --space-3-5: 28px;
  --space-3-75: 30px;
  --space-4-25: 34px;
  --space-4-5: 36px;
  --space-4-75: 38px;
  --space-5-25: 42px;
  --space-5-5: 44px;
  --space-5-75: 46px;
  --space-6-25: 50px;
  --space-6-5: 52px;
  --space-6-75: 54px;
  --space-7: 56px;
  --space-7-25: 58px;
  --space-7-5: 60px;
  --space-7-75: 62px;
  --space-8: 64px;
  --space-8-5: 66px;
  --space-9: 72px;
  --space-9-5: 76px;
  --space-10: 80px;
  --space-10-5: 84px;
  --space-11: 88px;
  --space-11-5: 92px;
  --space-12: 96px;
  --space-12-5: 100px;

  /* Layout dimensions (widths / heights — not the core spacing scale) */
  --layout-dim-96: 96px;
  --layout-dim-112: 112px;
  --layout-dim-120: 120px;
  --layout-dim-128: 128px;
  --layout-dim-140: 140px;
  --layout-dim-160: 160px;
  --layout-dim-180: 180px;
  --layout-dim-200: 200px;
  --layout-dim-220: 220px;
  --layout-dim-240: 240px;
  --layout-dim-260: 260px;
  --layout-dim-280: 280px;
  --layout-dim-300: 300px;
  --layout-dim-320: 320px;
  --layout-dim-360: 360px;
  --layout-dim-380: 380px;
  --layout-dim-400: 400px;
  --layout-dim-420: 420px;
  --layout-dim-440: 440px;
  --layout-dim-520: 520px;
  --layout-dim-540: 540px;
  --layout-dim-560: 560px;
  --layout-dim-620: 620px;
  --layout-dim-640: 640px;
  --layout-dim-680: 680px;
  --layout-dim-820: 820px;
  --layout-dim-879: 879px;
  --layout-max-admin: 1140px;

  /* —— Border widths (hairlines may stay 1px per spec) —— */
  --border-width-hairline: 1px;
  --border-width-medium: 2px;
  --border-width-thick: 3px;

  /* Micro-adjustments (replaces raw negative px in components) */
  --motion-nudge-1: -1px;
  --motion-nudge-2: -2px;
  --motion-nudge-3: -3px;
  --motion-nudge-4: -4px;
  --motion-nudge-6: -6px;
  --motion-nudge-8: -8px;
  --motion-nudge-14: -14px;

  /* —— Breakpoints & layout widths (media queries + max-width) —— */
  --bp-xs: 480px;
  --bp-sm: 600px;
  --bp-md: 720px;
  --bp-md-tab: 768px;
  --bp-lg: 860px;
  --bp-lg-2: 880px;
  --bp-xl: 900px;
  --bp-xl-2: 920px;
  --bp-2xl: 960px;
  --bp-3xl: 980px;
  --bp-max-lg: 1100px;
  --bp-max-xl: 1200px;

  /* —— Motion (public surfaces) —— */
  --transition-fast: 150ms;
  --transition-medium: 200ms;
  --transition-slow: 250ms;
  --ease-standard: cubic-bezier(0.2, 0, 0, 1);

  /* —— Typography (sizes often used instead of raw px) —— */
  --typo-size-2xs: 0.6875rem;
  --typo-size-caption: 0.8125rem;
  --typo-size-body-comfort: 0.9375rem;
  --typo-size-title-sm: 1.0625rem;
  --typo-size-hero: 2.125rem;

  /* —— Font stacks —— */
  --font-family-mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;

  /* —— Surfaces & scrims (no raw rgba in components — reference these) —— */
  --color-surface-glass: rgb(255 255 255 / 0.94);
  --color-scrim-strong: rgb(15 23 42 / 0.45);
  --color-scrim-medium: rgb(15 23 42 / 0.35);
  --color-scrim-veil: rgb(15 10 30 / 0.45);
  --color-scrim-drawer: rgb(12 12 18 / 0.9);
  --color-scrim-join-backdrop: rgb(12 12 22 / 0.52);
  --elevation-hairline-bottom: 0 var(--border-width-hairline) 0 rgb(0 0 0 / 0.04);
  --elevation-hairline-on-surface: 0 var(--border-width-hairline) 0 rgb(15 23 42 / 0.04);
  --elevation-admin-nav-hover: 0 var(--space-0-75) var(--space-2-25) rgb(46 10 100 / 0.12);
  --elevation-admin-nav-hover-primary: 0 var(--space-1) var(--space-2-75) rgb(46 10 100 / 0.22);
  --elevation-btn-primary: 0 var(--space-half) var(--space-2-5) rgba(var(--wf-primary-rgb), 0.28);
  --elevation-btn-primary-hover: 0 var(--space-1) var(--space-4) rgba(var(--wf-primary-rgb), 0.38);
  --elevation-card-hover-admin: 0 var(--space-3) var(--space-8) rgb(15 23 42 / 0.1);
  --elevation-dialog: 0 var(--space-4) var(--space-touch) rgb(15 23 42 / 0.2);
  --elevation-busy-panel: 0 var(--space-3) var(--space-10) rgb(15 23 42 / 0.15);
  --elevation-drawer-glow: var(--motion-nudge-8) 0 var(--space-4) rgba(46, 10, 100, 0.12);
  --elevation-inset-highlight: inset 0 var(--border-width-hairline) 0 rgb(255 255 255 / 0.5);
  --elevation-inset-highlight-strong: inset 0 var(--border-width-hairline) 0 rgb(255 255 255 / 0.65);

  /* —— Gradients (styles.css references only; no raw gradient() in component rules) —— */
  --gradient-admin-gate: linear-gradient(180deg, var(--color-surface) 0%, var(--bg) 45%, var(--bg) 100%);
  --gradient-admin-app: linear-gradient(180deg, var(--color-surface) 0%, var(--bg) 32%, var(--bg) 100%);
  --gradient-admin-dashboard-main: linear-gradient(
    180deg,
    color-mix(in srgb, var(--surface) 70%, var(--bg) 30%) 0%,
    var(--bg) var(--layout-dim-220)
  );
  --gradient-dashboard-kpi: linear-gradient(
    145deg,
    var(--surface) 0%,
    color-mix(in srgb, var(--surface) 94%, var(--wf-primary) 6%) 100%
  );
  --gradient-dashboard-kpi-accent: linear-gradient(
    145deg,
    color-mix(in srgb, var(--surface) 92%, var(--wf-primary) 8%) 0%,
    var(--surface) 100%
  );
  --gradient-nav-cta: linear-gradient(145deg, var(--wf-primary) 0%, var(--wf-primary-dark) 100%);
  --gradient-hero-scrim: linear-gradient(
    90deg,
    rgb(0 0 0 / 0.55) 0%,
    rgb(0 0 0 / 0.25) 45%,
    rgb(0 0 0 / 0.35) 100%
  );
  --gradient-home-ambient: linear-gradient(180deg, rgba(var(--wf-primary-rgb), 0.07) 0%, transparent 48%),
    radial-gradient(
      var(--bp-max-lg) var(--layout-dim-420) at 12% -8%,
      rgba(var(--wf-primary-rgb), 0.14),
      transparent 58%
    );
  --gradient-surface-to-primary-soft: linear-gradient(145deg, var(--surface) 0%, rgba(var(--wf-primary-rgb), 0.05) 100%);
  --gradient-primary-vertical: linear-gradient(180deg, var(--primary-softer-bg) 0%, var(--bg) 100%);
  --gradient-join-thanks-ring: linear-gradient(
    160deg,
    rgba(var(--wf-primary-rgb), 0.2) 0%,
    rgba(var(--wf-primary-rgb), 0.06) 100%
  );
  --gradient-dash-bar-fill: linear-gradient(
    180deg,
    color-mix(in srgb, var(--wf-primary) 85%, var(--color-white)) 0%,
    var(--wf-primary) 100%
  );
  --gradient-dash-status-fill: linear-gradient(90deg, var(--wf-primary-light), var(--wf-primary));
  --gradient-dash-crm-fill: linear-gradient(
    90deg,
    color-mix(in srgb, var(--wf-primary) 65%, var(--surface)),
    var(--wf-primary)
  );
  --gradient-settings-hub-card: linear-gradient(
    165deg,
    var(--surface) 0%,
    color-mix(in srgb, var(--surface) 96%, var(--wf-primary) 4%) 100%
  );
  --gradient-settings-hub-card-accent: linear-gradient(
    165deg,
    color-mix(in srgb, var(--surface) 90%, var(--wf-primary) 10%) 0%,
    color-mix(in srgb, var(--surface) 94%, var(--wf-primary) 6%) 100%
  );
  --gradient-pro-dist-fill: linear-gradient(
    90deg,
    color-mix(in srgb, var(--wf-primary) 55%, var(--color-amber-300)),
    var(--wf-primary)
  );
  --gradient-tenant-hero: linear-gradient(180deg, var(--tenant-hero-tint) 0%, var(--bg) 100%);
  --gradient-coming-soon-il: linear-gradient(
    180deg,
    var(--tenant-hero-tint, var(--tenant-theme-il-hero-tint)) 0%,
    var(--bg) 100%
  );

  /* —— RGBA / alpha surfaces (referenced from styles.css only as var) —— */
  --color-on-inverse-12: rgb(255 255 255 / 0.12);
  --color-on-inverse-20: rgb(255 255 255 / 0.2);
  --color-on-inverse-pill: rgb(255 255 255 / 0.22);
  --color-on-inverse-22: rgb(255 255 255 / 0.22);
  --color-on-inverse-35: rgb(255 255 255 / 0.35);
  --color-on-inverse-50: rgb(255 255 255 / 0.5);
  --color-on-inverse-55: rgb(255 255 255 / 0.55);
  --color-glass-hero-search: rgb(255 255 255 / 0.96);
  --color-overlay-dark-90: rgb(12 12 18 / 0.9);
  --color-overlay-purple-45: rgb(15 10 30 / 0.45);
  --color-footer-btn-surface: rgb(255 255 255 / 0.92);
  --color-slate-shadow-035: rgb(15 23 42 / 0.05);
  --color-slate-shadow-06: rgb(15 23 42 / 0.06);
  --color-slate-shadow-1: rgb(15 23 42 / 0.1);
  --color-slate-shadow-12: rgb(15 23 42 / 0.12);
  --color-black-shadow-035: rgb(0 0 0 / 0.35);
  --color-black-shadow-05: rgb(0 0 0 / 0.5);
  --color-black-shadow-065: rgb(0 0 0 / 0.65);
  --color-black-shadow-025: rgb(0 0 0 / 0.25);
  --color-black-shadow-028: rgb(0 0 0 / 0.28);
  --color-black-shadow-012: rgb(0 0 0 / 0.12);
  --color-black-04: rgb(0 0 0 / 0.04);
  --color-black-08: rgb(0 0 0 / 0.08);
  --color-primary-glow-mix: rgba(var(--wf-primary-rgb), 0.06);
  --color-primary-glow-mix-12: color-mix(in srgb, var(--surface) 96%, rgba(var(--wf-primary-rgb), 0.12));
  --elevation-embed-bar: 0 var(--border-width-medium) var(--space-1-25) var(--color-slate-shadow-06);
  --elevation-settings-hub-hover: 0 var(--space-1-5) var(--space-4) var(--color-slate-shadow-1);
  --elevation-lead-pill: 0 var(--space-half) var(--space-1-75) rgba(var(--wf-primary-rgb), 0.28);
  --elevation-slate-xs: 0 var(--border-width-hairline) var(--border-width-thick) var(--color-slate-shadow-035);
  --elevation-slate-sm: 0 var(--border-width-hairline) var(--space-half) var(--color-slate-shadow-035);
  --elevation-slate-md: 0 var(--border-width-medium) var(--space-1-25) var(--color-slate-shadow-06);
  --elevation-slate-lg: 0 var(--border-width-medium) var(--space-1-5) var(--color-slate-shadow-06);
  --elevation-slate-xl: 0 var(--border-width-medium) var(--space-1-5) var(--color-slate-shadow-12);
  --elevation-hero-card: 0 var(--space-1-5) var(--space-5) var(--color-black-shadow-028);
  --elevation-wf-card: 0 var(--space-half) var(--space-1) var(--color-black-shadow-025);
  --elevation-wf-card-strong: 0 var(--border-width-medium) var(--space-1-75) var(--color-black-shadow-035);
  --elevation-pro-card-hover: 0 var(--space-1) var(--space-3-5) var(--color-slate-shadow-1);
  --elevation-cta-stack: 0 var(--space-2) var(--space-5) rgba(46, 10, 100, 0.12), 0 var(--space-half) var(--space-1-5) rgb(0 0 0 / 0.06);
  --text-shadow-hero-strong: 0 var(--border-width-hairline) var(--border-width-thick) var(--color-black-shadow-065),
    0 var(--border-width-medium) var(--space-1-5) var(--color-black-shadow-035);
  --text-shadow-hero-soft: 0 var(--border-width-medium) var(--space-3) var(--color-black-shadow-05);
  --text-shadow-pill: 0 var(--border-width-hairline) var(--border-width-medium) var(--color-black-shadow-035);
  --filter-drop-shadow-sm: drop-shadow(0 var(--border-width-medium) var(--space-0-75) var(--color-black-shadow-012));

  /* Tenant region themes (hero tint + chip — single source) */
  --tenant-theme-zm-hero-tint: rgba(25, 135, 84, 0.14);
  --tenant-theme-zm-chip-bg: rgba(25, 135, 84, 0.12);
  --tenant-theme-il-hero-tint: rgba(0, 102, 204, 0.12);
  --tenant-theme-il-chip-bg: rgba(0, 102, 204, 0.1);
  --tenant-theme-bw-hero-tint: rgba(107, 163, 199, 0.14);
  --tenant-theme-bw-chip-bg: rgba(107, 163, 199, 0.12);
  --tenant-theme-zw-hero-tint: rgba(31, 122, 61, 0.12);
  --tenant-theme-zw-chip-bg: rgba(31, 122, 61, 0.1);
  --tenant-theme-za-hero-tint: rgba(0, 122, 77, 0.12);
  --tenant-theme-za-chip-bg: rgba(0, 122, 77, 0.1);
  --tenant-theme-na-hero-tint: rgba(30, 58, 138, 0.12);
  --tenant-theme-na-chip-bg: rgba(30, 58, 138, 0.1);
  --tenant-theme-global-hero-tint: rgba(108, 92, 231, 0.1);
  --tenant-theme-global-chip-bg: rgba(108, 92, 231, 0.08);
  --tenant-theme-demo-hero-tint: rgba(13, 148, 136, 0.12);
  --tenant-theme-demo-chip-bg: rgba(13, 148, 136, 0.1);
  --tenant-theme-il-border: rgba(0, 102, 204, 0.35);

  /* —— Border radius —— (DS V1 aliases: --radius-sm/md/lg/xl in design-system.css) */
  --radius-small: 8px;
  --radius-medium: 16px;
  --radius-large: 24px;
  --border-radius-xs: var(--space-1);
  --border-radius-sm: var(--radius-small);
  --border-radius-md: var(--space-1-5);
  --border-radius-lg: var(--radius-medium);
  --border-radius-xl: var(--radius-large);
  --border-radius-full: 9999px;
  --radius: var(--border-radius-md);
  --radius-pill: var(--border-radius-full);

  /* Admin layout (see docs/ADMIN_UI.md) */
  --admin-radius: var(--border-radius-md);
  --admin-radius-lg: var(--space-1-75);
  --admin-radius-xl: var(--border-radius-lg);
  --admin-gap: var(--spacing-3);
  --admin-gap-section: var(--space-1-75);
  --admin-main-pad-y: var(--space-2-75);
  --admin-main-pad-x: var(--spacing-4);
  --admin-main-pad-bottom: var(--space-5-5);
  --admin-card-padding: var(--space-1-75) var(--spacing-4);
  --admin-table-cell-padding: var(--space-1-25) var(--spacing-3);
  --admin-container-max: var(--layout-max-admin);
  --admin-modal-max-width: var(--bp-2xl);
  --admin-modal-max-height-vh: 88vh;
  --admin-modal-max-height-px: var(--layout-dim-820);
  /* Modal chrome → use global space scale */
  --modal-space-1: var(--space-1);
  --modal-space-2: var(--space-2);
  --modal-space-3: var(--space-3);
  --modal-header-min-height: var(--space-touch);
  --modal-close-btn-size: var(--space-touch);
  --modal-z-dialog: 10060;
  --m3-modal-duration: 250ms;
  --m3-modal-duration-backdrop: 200ms;
  --m3-modal-ease: cubic-bezier(0.2, 0, 0, 1);

  /* Material Design 3 — system tokens */
  --md-sys-spacing-1: var(--spacing-1);
  --md-sys-spacing-2: var(--spacing-2);
  --md-sys-spacing-3: var(--spacing-3);
  --md-sys-spacing-4: var(--spacing-4);
  --md-sys-spacing-5: var(--spacing-5);
  --md-sys-spacing-6: var(--spacing-6);
  --md-sys-shape-corner-none: 0;
  --md-sys-shape-corner-extra-small: var(--border-radius-xs);
  --md-sys-shape-corner-small: var(--border-radius-sm);
  --md-sys-shape-corner-medium: var(--border-radius-md);
  --md-sys-shape-corner-large: var(--border-radius-lg);
  --md-sys-shape-corner-extra-large: var(--border-radius-xl);
  --md-sys-color-surface: var(--surface);
  --md-sys-color-surface-container: var(--bg);
  --md-sys-color-surface-container-low: color-mix(in srgb, var(--surface) 94%, var(--bg) 6%);
  --md-sys-color-surface-container-high: color-mix(in srgb, var(--surface) 88%, var(--bg) 12%);
  --md-sys-color-surface-container-highest: color-mix(in srgb, var(--surface) 82%, var(--bg) 18%);
  --md-sys-color-surface-container-lowest: var(--surface);
  --md-sys-color-outline-variant: color-mix(in srgb, var(--border-strong) 65%, var(--surface) 35%);
  --md-sys-elevation-level0: none;
  --md-sys-elevation-level1: 0 1px 2px rgba(0, 0, 0, 0.08), 0 1px 3px 1px rgba(0, 0, 0, 0.06);
  --md-sys-elevation-level2: 0 1px 2px rgba(0, 0, 0, 0.1), 0 2px 6px 2px rgba(0, 0, 0, 0.08);
  --md-sys-elevation-level3: 0 4px 8px 3px rgba(0, 0, 0, 0.08), 0 1px 3px rgba(0, 0, 0, 0.1);
  --md-sys-elevation-level4: 0 6px 10px 4px rgba(0, 0, 0, 0.08), 0 2px 3px rgba(0, 0, 0, 0.1);
  --md-sys-elevation-level5: 0 8px 12px 6px rgba(0, 0, 0, 0.1), 0 4px 4px rgba(0, 0, 0, 0.08);
  --md-sys-motion-duration-short1: 150ms;
  --md-sys-motion-duration-medium1: 250ms;
  --md-sys-motion-easing-standard: cubic-bezier(0.2, 0, 0, 1);
}

/* Optional: layout shell for pages that use header / main / footer */
.app-layout {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  background: var(--md-sys-color-surface-container);
}

.app-layout__main {
  flex: 1 0 auto;
  width: 100%;
}

/* Modifier: extra elevation on cards */
.card--elevated {
  box-shadow: var(--md-sys-elevation-level2);
}

/**
 * ========== END inlined: public/theme.css ==========
 */

/**
 * ========== BEGIN inlined: public/design-system.css ==========
 */
/**
 * GetPro Design System V1 — canonical aliases & patterns
 * ========================================================
 * Loaded after public/theme.css via styles.css.
 * Human-readable spec: docs/DESIGN_SYSTEM.md
 *
 * Rules:
 * - Prefer these semantic names in NEW component CSS.
 * - Existing code may still use legacy aliases (--bg, --wf-primary, --space-1…).
 * - App spacing scale uses an 8px rhythm (--space-1 = 8px). DS “4px scale” lives in --gp-ds-*.
 */

:root {
  /* —— Color (canonical DS V1 names → theme tokens) —— */
  --color-bg: var(--color-background);
  --color-surface-alt: var(--color-surface-variant);
  --color-text: var(--color-text-primary);
  --color-text-muted: var(--color-text-secondary);
  --color-text-soft: var(--color-text-tertiary);
  --color-primary-hover: var(--wf-primary-dark);
  --color-primary-soft: rgba(var(--wf-primary-rgb), 0.08);
  --color-border: var(--color-outline);
  --color-border-strong: var(--color-outline-strong);

  /* —— Radius (DS naming — map to existing shape tokens) —— */
  --radius-sm: var(--radius-small);
  --radius-md: var(--border-radius-md);
  --radius-lg: var(--border-radius-lg);
  --radius-xl: var(--border-radius-xl);

  /* —— Typography scale (pixel-aligned labels for design handoff) —— */
  --font-family: var(--font-family-body);
  --text-xs: 0.75rem;
  --text-sm: 0.875rem;
  --text-md: 1rem;
  --text-lg: 1.125rem;
  --text-xl: 1.25rem;
  --font-medium: 500;
  --font-semibold: 600;

  /* —— DS V1 spacing (4px base). Map app tokens where they match. —— */
  --gp-ds-space-1: 4px;
  --gp-ds-space-2: 8px;
  --gp-ds-space-3: 12px;
  --gp-ds-space-4: 16px;
  --gp-ds-space-5: 20px;
  --gp-ds-space-6: 24px;
  --gp-ds-space-8: 32px;
  --gp-ds-space-10: 40px;
  --gp-ds-space-12: 48px;

  /* —— Focus (visible keyboard ring — use on interactive controls) —— */
  --focus-ring-color: color-mix(in srgb, var(--color-focus) 55%, var(--color-text-primary));
  --focus-ring-width: 2px;
  --focus-ring-offset: 2px;
}

/**
 * Focus utility — use for custom interactive surfaces not covered by .btn / links
 */
.gp-focus-ring:focus-visible {
  outline: var(--focus-ring-width) solid var(--focus-ring-color);
  outline-offset: var(--focus-ring-offset);
}

/**
 * Directory “professional card” (BEM: .pro-directory-card*)
 * Structure: header row (title + CTA) → meta → body → footer
 * Do not duplicate; extend these classes only.
 */

/**
 * Search toolbar (BEM: .pro-directory-toolbar*)
 * Compact horizontal filter; stacks on small viewports.
 */

/**
 * Button hierarchy (prefer semantic modifiers):
 * - Primary:   .btn.btn--primary   (legacy alias: .btn.btn-primary)
 * - Secondary: .btn.btn--secondary (legacy alias: .btn.btn-secondary-wf)
 * - Ghost/text:.btn.btn--text
 */

/* ——— Component primitives (buttons / cards / inputs) ——— */

/* Buttons: semantic modifiers layered on top of existing `.btn` */
.btn.btn--primary,
.btn.btn-primary {
  background: var(--btn-primary-bg);
  border: none;
  color: var(--btn-primary-text);
  box-shadow: var(--elevation-btn-primary);
}

.btn.btn--primary:hover,
.btn.btn-primary:hover {
  background: var(--btn-primary-hover);
  color: var(--btn-primary-text);
  box-shadow: var(--elevation-btn-primary-hover);
}

.btn.btn--secondary,
.btn.btn-secondary-wf {
  border-radius: var(--radius-pill);
  padding: var(--space-1-5) var(--space-3);
  font-weight: 700;
  border: var(--border-width-hairline) solid var(--wf-primary);
  background: var(--surface);
  color: var(--wf-primary-dark);
}

.btn.btn--secondary:hover,
.btn.btn-secondary-wf:hover {
  background: var(--primary-softer-bg);
  border-color: var(--wf-primary-dark);
  color: var(--wf-primary-dark);
}

.btn.btn--text {
  background: transparent;
  border: none;
  color: var(--color-primary);
  box-shadow: none;
  min-height: var(--space-touch);
  padding-inline: var(--spacing-3);
}

.btn.btn--text:hover {
  background: var(--primary-softer-bg);
  filter: none;
}

.btn.btn--sm {
  min-height: calc(var(--space-touch) - var(--space-1));
  padding: var(--space-0-75) var(--space-2);
  font-size: var(--space-1-75);
}

.btn.btn--lg {
  min-height: calc(var(--space-touch) + var(--space-1));
  padding: var(--space-1-25) var(--space-3);
}

.btn.btn--icon {
  min-width: var(--space-touch);
  width: var(--space-touch);
  min-height: var(--space-touch);
  padding: 0;
}

.btn__icon {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

/* Accessibility: visible keyboard focus for design-system button variants */
.btn:focus-visible {
  outline: var(--focus-ring-width) solid var(--focus-ring-color);
  outline-offset: var(--focus-ring-offset);
}

.btn.btn--primary:focus-visible,
.btn.btn-primary:focus-visible,
.btn.btn--secondary:focus-visible,
.btn.btn-secondary-wf:focus-visible,
.btn.btn--text:focus-visible {
  outline: var(--focus-ring-width) solid var(--focus-ring-color);
  outline-offset: var(--focus-ring-offset);
}

/* Card structure helpers (pair with existing `.card` styles) */
.card--interactive {
  cursor: pointer;
}

.card__header {
  display: flex;
  flex-direction: column;
  gap: var(--space-0-5);
}

.card__title {
  margin: 0;
  font-size: var(--space-2-25);
  font-weight: 900;
  letter-spacing: -0.02em;
}

.card__meta {
  color: var(--muted);
  font-size: var(--space-1-5);
}

.card__body {
  margin-top: var(--space-1);
}

.card__footer {
  margin-top: var(--space-1-5);
}

.card__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-1-25);
}

/* Input semantics (minimal styling; existing form classes define visuals) */
.input-field__label {
  display: block;
}

.input-field__control {
  box-sizing: border-box;
}

.input-field__help {
  margin: var(--space-0-75) 0 0;
  font-size: var(--space-1-5);
  color: var(--muted);
  line-height: 1.4;
}

.input-field__error {
  margin: var(--space-0-75) 0 0;
  font-size: var(--space-1-5);
  color: var(--flash-error-text);
  line-height: 1.4;
}

/* When a control is inside an error input-field, prefer visible emphasis. */
.input-field--error .input-field__control:focus-visible {
  outline: var(--border-width-medium) solid var(--color-error);
  outline-offset: var(--border-width-hairline);
}

/* Form step rhythm (multi-step flows: join wizard, modals, callback panels) */
.form-step__header {
  margin: 0 0 var(--space-1-5);
}

.form-step__title {
  margin: 0;
}

.form-step__subtitle {
  margin: var(--space-1) 0 0;
  color: var(--muted);
}

.form-step__actions {
  margin-top: var(--space-3);
}

/* Inline status / feedback (submit progress, success, mixed post-submit copy on public forms) */
.form-status-message {
  margin: var(--space-1) 0 0;
  font-size: var(--space-1-5);
  line-height: 1.45;
}

/* —— UI state system: block surfaces + inline status variants —— */
.state-block {
  box-sizing: border-box;
  border-radius: var(--radius-md);
  padding: var(--gp-ds-space-4);
  border: var(--border-width-hairline) solid var(--color-border);
  background: var(--color-bg);
  color: var(--color-text);
}

.state-block--compact {
  padding: var(--gp-ds-space-3);
}

.state-block__title {
  margin: 0 0 var(--gp-ds-space-2);
  font-size: var(--text-lg);
  font-weight: var(--font-semibold);
  line-height: 1.3;
  color: var(--color-text);
}

.state-block__body {
  margin: 0;
  font-size: var(--text-md);
  line-height: 1.45;
}

.state-block__body--muted {
  margin-top: var(--gp-ds-space-2);
}

.state-block__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--gp-ds-space-2);
  margin-top: var(--gp-ds-space-4);
}

.state-block--success {
  border-color: var(--flash-success-border);
  background: var(--flash-success-bg);
  color: var(--flash-success-text);
}

.state-block--error {
  border-color: var(--flash-error-border);
  background: var(--flash-error-bg);
  color: var(--flash-error-text);
}

.state-block--info {
  border-color: var(--flash-info-border);
  background: var(--flash-info-bg);
  color: var(--flash-info-text);
}

.state-block--empty {
  border-style: dashed;
  border-color: var(--color-border-strong);
  background: color-mix(in srgb, var(--color-surface-alt) 55%, var(--color-bg));
  color: var(--color-text-secondary);
}

.state-block--loading {
  border-color: var(--color-border);
  background: color-mix(in srgb, var(--color-surface-alt) 40%, var(--color-bg));
}

.state-block__loading-inner {
  display: inline-flex;
  align-items: center;
  gap: var(--gp-ds-space-3);
}

.state-block__spinner {
  flex-shrink: 0;
  width: 1.1em;
  height: 1.1em;
  border: 2px solid color-mix(in srgb, var(--color-primary) 35%, var(--color-border));
  border-top-color: var(--color-primary);
  border-radius: 50%;
  animation: gp-state-spin 0.75s linear infinite;
}

@keyframes gp-state-spin {
  to {
    transform: rotate(360deg);
  }
}

.state-block__loading-text {
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
}

.state-block--admin-inline {
  margin: 0 auto;
  max-width: 100%;
  text-align: center;
  border: none;
  background: transparent;
  padding: var(--gp-ds-space-2) var(--gp-ds-space-3);
}

.admin-table-empty-cell {
  padding: var(--space-2) var(--space-2);
  vertical-align: middle;
}

/* Inline status modifiers (use with .form-status-message + .status-message) */
.status-message--success {
  color: var(--flash-success-text);
}

.muted.status-message--success,
.status-message.status-message--success {
  color: var(--flash-success-text);
}

.status-message--error {
  color: var(--flash-error-text);
}

.muted.status-message--error,
.status-message.status-message--error {
  color: var(--flash-error-text);
}

.status-message--info,
.status-message--neutral {
  color: var(--muted);
}

.status-message--loading {
  color: var(--muted);
}

/**
 * ========== END inlined: public/design-system.css ==========
 */

/**
 * ========== BEGIN inlined: public/m3-modal.css ==========
 */
/**
 * Material 3 modal shell — single source of truth for overlays / dialogs.
 * Layout: flex only (no absolute positioning for header/body/footer flow).
 * Tokens: theme.css (--space-*, --color-*, --elevation-*, --modal-*).
 */

/* Root overlay: centers the dialog; fades in when .m3-modal-overlay--open is set */
.m3-modal-overlay {
  position: fixed;
  inset: 0;
  z-index: var(--modal-z-dialog);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: max(var(--space-2), env(safe-area-inset-top, 0px)) max(var(--space-2), env(safe-area-inset-right, 0px))
    max(var(--space-2), env(safe-area-inset-bottom, 0px)) max(var(--space-2), env(safe-area-inset-left, 0px));
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition:
    opacity var(--m3-modal-duration-backdrop) var(--m3-modal-ease),
    visibility 0s linear var(--m3-modal-duration-backdrop);
}

.m3-modal-overlay[hidden] {
  display: none !important;
}

.m3-modal-overlay:not([hidden]) {
  display: flex;
}

.m3-modal-overlay.m3-modal-overlay--open {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transition:
    opacity var(--m3-modal-duration-backdrop) var(--m3-modal-ease),
    visibility 0s linear 0s;
}

.m3-modal-overlay__backdrop {
  position: absolute;
  inset: 0;
  background: color-mix(in srgb, var(--color-text-primary) 55%, transparent);
  backdrop-filter: blur(2px);
  opacity: 0;
  transition: opacity var(--m3-modal-duration-backdrop) var(--m3-modal-ease);
}

.m3-modal-overlay.m3-modal-overlay--open .m3-modal-overlay__backdrop {
  opacity: 1;
}

/* Dialog surface: scales + slides in (no absolute children for structure) */
.m3-modal {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  width: min(100%, var(--m3-modal-max-width, 560px));
  max-height: min(90vh, 760px);
  min-height: 0;
  background: var(--color-surface);
  color: var(--color-text-primary);
  border-radius: var(--radius-medium);
  border: 1px solid var(--color-outline);
  box-shadow: var(--elevation-2);
  overflow: hidden;
  transform: scale(0.96) translateY(var(--space-1));
  opacity: 0;
  transition:
    transform var(--m3-modal-duration) var(--m3-modal-ease),
    opacity var(--m3-modal-duration) var(--m3-modal-ease);
}

.m3-modal-overlay.m3-modal-overlay--open .m3-modal {
  transform: scale(1) translateY(0);
  opacity: 1;
}

.m3-modal__header {
  flex: 0 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-2);
  min-height: var(--modal-header-min-height);
  padding: var(--space-1) var(--space-2);
  border-bottom: 1px solid var(--color-outline);
  background: var(--color-surface);
}

.m3-modal__header--end {
  justify-content: flex-end;
}

.m3-modal__title {
  margin: 0;
  flex: 1;
  min-width: 0;
  font-size: var(--typo-title-large-size);
  font-weight: 800;
  letter-spacing: -0.02em;
  color: var(--color-text-primary);
}

.m3-modal__close {
  flex: 0 0 auto;
  width: var(--modal-close-btn-size);
  min-width: var(--modal-close-btn-size);
  height: var(--modal-close-btn-size);
  min-height: var(--modal-close-btn-size);
  border-radius: var(--border-radius-full);
  border: 1px solid var(--color-outline-strong);
  background: var(--color-surface);
  font-size: 1.5rem;
  line-height: 1;
  cursor: pointer;
  font-weight: 700;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  color: var(--color-text-primary);
  box-shadow: var(--elevation-1);
}

.m3-modal__close:hover {
  background: color-mix(in srgb, var(--color-primary) 10%, var(--color-surface));
}

.m3-modal__body {
  flex: 1 1 auto;
  min-height: 0;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  padding: var(--space-2);
}

.m3-modal__body--iframe {
  padding: 0;
  display: flex;
  flex-direction: column;
}

.m3-modal__body--iframe iframe {
  flex: 1;
  min-height: 0;
  width: 100%;
  border: 0;
  background: var(--color-background);
}

.m3-modal__footer {
  flex: 0 0 auto;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  gap: var(--space-2);
  padding: var(--space-2);
  border-top: 1px solid var(--color-outline);
  background: var(--color-surface);
}

.m3-modal__footer--empty {
  display: none;
}

.m3-modal__loading {
  margin: 0;
  padding: var(--space-2);
  color: var(--color-text-secondary);
}

/* Size modifiers */
.m3-modal--settings-iframe {
  --m3-modal-max-width: var(--admin-modal-max-width);
  width: min(100%, var(--admin-modal-max-width));
  height: min(var(--admin-modal-max-height-vh), var(--admin-modal-max-height-px));
  max-height: min(var(--admin-modal-max-height-vh), var(--admin-modal-max-height-px));
}

.m3-modal--crm-task {
  --m3-modal-max-width: var(--layout-dim-640);
}

.m3-modal--join {
  --m3-modal-max-width: 440px;
  max-height: min(85vh, 640px);
}

/* Admin: mini-site workspace — leave confirm + publish busy (same overlay animation as other M3 modals) */
.admin-workspace-leave-m3.m3-modal-overlay {
  z-index: 10055;
}

.admin-workspace-leave-m3 .m3-modal--workspace-confirm {
  --m3-modal-max-width: var(--layout-dim-400);
}

.admin-workspace-busy-m3.m3-modal-overlay {
  z-index: 10058;
}

/* Admin: unsaved changes (discard confirm) */
.admin-form-unsaved-m3.m3-modal-overlay {
  z-index: 10056;
}

.m3-modal--admin-unsaved {
  --m3-modal-max-width: min(100%, var(--layout-dim-400));
}

.admin-workspace-busy-m3 .m3-modal--workspace-busy {
  --m3-modal-max-width: var(--layout-dim-360);
  box-shadow: var(--elevation-busy-panel);
}

.admin-workspace-busy-m3 .m3-modal__body--workspace-busy {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: var(--space-3) var(--space-2);
  gap: var(--space-2);
}

/* Region picker: compact sheet */
.wf-region-m3.m3-modal-overlay {
  z-index: 10003;
}

.wf-region-m3 .m3-modal.wf-region-sheet {
  width: min(92vw, 440px);
  max-height: min(85vh, 560px);
}

.wf-region-m3 .m3-modal__body.wf-region-sheet__body {
  padding: 0 var(--space-2) var(--space-2);
}

/* Join page modals (join.ejs) */
.join-modal-layer.m3-modal-overlay {
  z-index: 10050;
}

.join-modal-layer .m3-modal-overlay__backdrop {
  background: var(--color-scrim-join-backdrop);
  backdrop-filter: blur(var(--space-half));
}

@media (prefers-reduced-motion: reduce) {
  .m3-modal-overlay,
  .m3-modal-overlay__backdrop,
  .m3-modal {
    transition-duration: 0.01ms !important;
  }
}

/**
 * ========== END inlined: public/m3-modal.css ==========
 */

/* ——— Utilities (no inline styles in templates) ——— */
.u-hidden {
  display: none !important;
}

.section-title--flush {
  margin-top: 0;
}

.u-mt-0 {
  margin-top: 0;
}

.u-mt-tight {
  margin-top: var(--space-0-75);
}

.u-mt-sm {
  margin-top: var(--space-1);
}

.u-mb-section {
  margin-bottom: var(--space-2-5);
}

.u-mb-tight {
  margin-bottom: var(--space-1-25);
}

.u-mb-sm {
  margin-bottom: var(--space-1-5);
}

.u-mb-lg {
  margin-bottom: var(--space-2-5);
}

.u-mb-xl {
  margin-bottom: var(--space-3-5);
}

.u-stack-sm {
  margin: var(--space-2-25) 0;
}

.u-pad-y-container {
  padding: var(--space-2-5) 0 var(--space-1);
}

.u-pad-y-notfound {
  padding: var(--space-3-5) 0;
}

.u-text-strong {
  font-weight: 900;
}

.u-text-strong-800 {
  font-weight: 800;
}

.u-font-lead {
  font-size: var(--typo-size-body-comfort);
  line-height: var(--typo-body-large-line);
}

.flex-row-wrap {
  display: flex;
  gap: var(--space-1-25);
  flex-wrap: wrap;
}

.flex-row-wrap--tight {
  display: flex;
  gap: var(--space-1);
  flex-wrap: wrap;
  align-items: center;
}

.flex-row-end {
  display: flex;
  gap: var(--space-1-25);
  flex-wrap: wrap;
  align-items: flex-end;
}

.flex-1-min {
  min-width: var(--layout-dim-260);
  flex: 1;
}

.btn--start {
  justify-content: flex-start;
  width: 100%;
}

.btn--danger-outline {
  border-color: var(--flash-error-border);
  color: var(--flash-error-text);
}

.input-min-200 {
  min-width: var(--layout-dim-200);
}

.input-min-160 {
  min-width: var(--layout-dim-160);
}

.form-check--tight {
  margin: 0;
}

.form--delete {
  margin-top: var(--space-2-75);
}

.form-inline-delete {
  display: inline;
  margin-left: var(--space-1);
}

.super-user-tenant-block {
  margin-top: var(--space-2);
  padding-top: var(--space-2);
  border-top: var(--border-width-hairline) solid var(--border);
}

.super-user-tenant-readonly {
  background: var(--bg);
  color: var(--text);
  cursor: default;
}

.super-user-tenant-extra {
  margin-top: var(--space-1-5);
}

.cta-card--center {
  text-align: center;
  max-width: var(--layout-dim-640);
  margin: 0 auto;
}

.subtitle--cta {
  margin-bottom: var(--space-2-25);
}

.u-mb-2-25 {
  margin-bottom: var(--space-2-25);
}

.u-mt-overlap-tight {
  margin-top: calc(-1 * var(--space-1));
}

.u-mt-note {
  margin-top: var(--space-2);
}

.kbd--spaced {
  margin-left: var(--space-0-75);
}

.muted--relaxed {
  line-height: 1.6;
}

.muted--mt-0 {
  margin-top: 0;
}

.muted--caption {
  font-size: var(--typo-label-small-size);
}

.muted--body-sm {
  font-size: var(--typo-body-medium-size);
}

.muted--lead-caption {
  font-size: var(--typo-size-caption);
  margin-top: 0;
}

.pro-cat-grid__full-span {
  grid-column: 1 / -1;
  margin: 0;
}

.pro-section-head__aside {
  font-size: var(--typo-body-medium-size);
}

.card--mb-md {
  margin-bottom: var(--space-2);
}

.card--mb-lg {
  margin-bottom: var(--space-3);
}

.card--mb-xl {
  margin-bottom: var(--space-3-5);
}

.card--mb-block {
  margin-bottom: var(--space-2-5);
}

.card--mt-block {
  margin-top: var(--space-2-5);
}

.card--max-520 {
  max-width: var(--layout-dim-520);
}

.card--max-640 {
  max-width: var(--layout-dim-640);
}

.admin-toolbar--mb-sm {
  margin-bottom: var(--space-1);
}

.admin-intro--tight-top {
  margin-top: var(--space-0-75);
}

.admin-intro--embed-tight {
  margin-top: var(--space-half);
}

.section-title--form-card {
  margin-top: 0;
  font-size: var(--typo-size-title-sm);
}

.table__strong {
  font-weight: 700;
}

.table__strong-800 {
  font-weight: 800;
}

.admin-lead-message-cell {
  white-space: pre-wrap;
}

.admin-settings-tenant-table__phone {
  font-size: var(--typo-size-caption);
}

.admin-muted-footnote {
  margin-top: var(--space-1-75);
  font-size: var(--typo-label-small-size);
  line-height: 1.5;
}

.directory-toolbar {
  padding: var(--space-2-5) 0 var(--space-1);
}

.directory-page-toolbar {
  padding: var(--space-2-5) 0 var(--space-1);
}

.directory-search {
  max-width: 100%;
  margin-bottom: var(--space-2-5);
}

.pro-search--directory-wide {
  max-width: 100%;
  margin-bottom: var(--space-2-5);
}

.directory-category-link--active {
  border-color: var(--wf-primary);
  background: var(--primary-soft-bg);
}

.directory-section-head {
  margin: 0 0 var(--space-2-25);
}

.directory-cat-title {
  font-weight: 900;
  margin-bottom: var(--space-1-5);
}

.not-found-title {
  font-weight: 900;
  font-size: var(--typo-title-large-size);
  line-height: var(--typo-title-large-line);
}

.not-found-actions {
  margin-top: var(--space-1-75);
}

.admin-mini-site-urls {
  margin-bottom: var(--space-2-5);
  padding: var(--space-1-75) var(--space-2);
  border-radius: var(--border-radius-md);
  background: var(--color-black-04);
  border: var(--border-width-hairline) solid var(--color-black-08);
}

.admin-mini-site-urls__title {
  font-weight: 800;
  font-size: var(--typo-size-caption);
  margin-bottom: var(--space-0-75);
}

.admin-mini-site-urls__line {
  font-size: var(--typo-size-caption);
  line-height: var(--typo-body-large-line);
}

.admin-callout-muted {
  margin-bottom: var(--space-2-5);
  padding: var(--space-1-5) var(--space-1-75);
  border-radius: var(--border-radius-md);
  background: var(--color-black-04);
  font-size: var(--typo-size-caption);
  line-height: var(--typo-body-large-line);
}

.admin-field-hint {
  margin-top: var(--space-0-75);
  font-size: var(--typo-label-small-size);
  line-height: 1.5;
}

.admin-zm-phone-note {
  font-size: var(--typo-size-caption);
  line-height: var(--typo-body-large-line);
  margin: 0 0 var(--space-1-5);
}

/* ——— Admin: read → edit → done (single form, no duplicate fields) ——— */
.admin-form-shell__toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  gap: var(--space-1-25);
  margin-bottom: var(--space-2);
}

.admin-form-shell__toolbar--split {
  justify-content: space-between;
}

.admin-form-shell__toolbar--split .admin-form-shell__toolbar-end {
  margin-left: 0;
}

.admin-form-shell__toolbar-end {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  gap: var(--space-1-25);
  margin-left: auto;
}

.admin-form-shell.is-read-mode .form label,
.admin-form-shell.is-read-mode .form .input-field__label {
  opacity: 0.7;
}

.admin-form-shell.is-read-mode .form input:not([type="hidden"]):not([type="checkbox"]),
.admin-form-shell.is-read-mode .form textarea {
  border: none;
  background: transparent;
  padding-left: 0;
}

.admin-form-shell.is-read-mode .form input:not([type="hidden"]):not([type="checkbox"]),
.admin-form-shell.is-read-mode .form textarea,
.admin-form-shell.is-read-mode .form select {
  box-shadow: none;
  color: var(--text);
  pointer-events: none;
  outline: none;
  padding-inline: 0;
}

.admin-form-shell.is-dirty.is-edit-mode {
  box-shadow: 0 0 0 var(--border-width-medium) rgba(var(--wf-primary-rgb), 0.15);
  transition: box-shadow 0.2s ease;
}

.admin-form-shell__unsaved {
  width: 100%;
  margin: 0 0 var(--space-1) 0;
  font-size: var(--typo-label-small-size);
  line-height: 1.4;
  color: var(--color-primary);
  font-weight: 500;
}

.admin-form-shell__toolbar .admin-form-shell__unsaved {
  flex-basis: 100%;
  order: -1;
  margin-bottom: var(--space-0-75);
}

.admin-form-shell.is-edit-mode .btn--primary.admin-form-shell__btn--done:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.admin-form-shell.is-read-mode .form select:disabled {
  opacity: 1;
  color: var(--text);
  -webkit-text-fill-color: var(--text);
  background: transparent;
  border: none;
  appearance: none;
}

.admin-form-shell.is-read-mode .form input[type="checkbox"]:disabled {
  opacity: 0.88;
}

.hero-grid--2col {
  grid-template-columns: 1fr 1fr;
}

.pro-footer-col__lead {
  margin: 0;
  line-height: 1.55;
  color: var(--footer-on-dark-muted);
}

.pro-footer-col__placeholder {
  color: var(--footer-on-dark-faint);
}

/* Request-contact status: shared form-status-message rhythm, body-sized copy */
.pro-company-profile__lead-status.form-status-message {
  margin-top: var(--space-1-25);
  font-size: var(--typo-body-medium-size, var(--space-1-75));
  line-height: var(--typo-body-large-line, 1.5);
  min-height: 3em;
  box-sizing: border-box;
}

.pro-company-profile__qr-hint {
  font-size: var(--typo-label-small-size);
  line-height: var(--typo-body-large-line);
  margin: 0 0 var(--space-1-25);
}

@media (max-width: 720px) {
  .hero-grid--2col {
    grid-template-columns: 1fr;
  }
}

* {
  box-sizing: border-box;
}

body {
  margin: 0;
  font-family: var(--font-family-body);
  font-size: var(--typo-body-large-size);
  line-height: var(--typo-body-large-line);
  background: var(--md-sys-color-surface-container);
  color: var(--color-text-primary);
  -webkit-font-smoothing: antialiased;
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}

a {
  color: var(--link);
  text-decoration: none;
}

a:hover {
  text-decoration: underline;
}

.container {
  max-width: var(--admin-container-max);
  margin: 0 auto;
  padding: 0 var(--admin-main-pad-x);
}

@media (max-width: 480px) {
  .container {
    padding-left: max(var(--space-1-75), env(safe-area-inset-left, var(--space-1-75)));
    padding-right: max(var(--space-1-75), env(safe-area-inset-right, var(--space-1-75)));
  }
}

/* ——— Admin gate (GetPro admin login / getpro-admin) ——— */
.admin-gate-card .form label,
.admin-gate-card .input-field__label {
  font-weight: 600;
  font-size: var(--space-1-75);
}

/* Admin compact forms: shared form-step + input-field rhythm (gate, user create, CRM create, lead status) */
.form-step--admin .form-step__body {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.form-step--admin .form-step__actions {
  margin-top: var(--space-2);
}

.admin-gate-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-1-5);
  align-items: center;
  margin-top: var(--space-1-25);
}

.admin-gate-page {
  min-height: 100vh;
  background: var(--gradient-admin-gate);
}

.admin-gate-wrap {
  padding: var(--space-touch) var(--space-2-25) var(--space-8);
  max-width: var(--layout-dim-540);
  margin: 0 auto;
}

.admin-gate-card {
  padding: var(--space-4) var(--space-3-5) var(--space-3-5);
  border-radius: var(--space-2);
  border: var(--border-width-hairline) solid var(--border-strong);
  box-shadow: var(--cta-card-shadow);
}

.admin-gate-brand {
  display: flex;
  align-items: flex-start;
  gap: var(--space-1-75);
  text-decoration: none;
  color: var(--text);
  margin-bottom: var(--space-2-75);
}

.admin-gate-brand:hover {
  color: var(--text);
  text-decoration: none;
}

.admin-gate-brand__title {
  font-weight: 900;
  font-size: 1.35rem;
  letter-spacing: -0.02em;
}

.admin-gate-brand__subtitle {
  margin-top: var(--space-0-75);
  font-size: var(--space-1-75);
  line-height: 1.55;
  color: var(--muted);
  font-weight: 650;
}

/* ——— Admin app (aligned with public marketing shell) ——— */
.admin-app {
  min-height: 100vh;
  background: var(--gradient-admin-app);
}

.admin-header {
  position: sticky;
  top: 0;
  z-index: 50;
  background: var(--color-surface-glass);
  backdrop-filter: blur(var(--space-1-5));
  -webkit-backdrop-filter: blur(var(--space-1-5));
  border-bottom: var(--border-width-hairline) solid var(--border-strong);
  box-shadow: var(--elevation-hairline-bottom);
}

.admin-header__inner {
  padding: var(--space-2) var(--space-2-25) var(--space-2-25);
}

.admin-header__top {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--space-1-5) var(--space-2-5);
  margin-bottom: var(--space-1-5);
}

.admin-header__brand {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1-5);
  text-decoration: none;
  color: var(--text);
}

.admin-header__brand:hover {
  text-decoration: none;
  color: var(--text);
}

.admin-header__brand-text {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1-25);
  flex-wrap: wrap;
}

.admin-header__product {
  font-weight: 900;
  font-size: 1.35rem;
  letter-spacing: -0.03em;
}

.admin-header__badge {
  font-size: var(--space-1-25);
  font-weight: 800;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--wf-primary);
  background: var(--primary-softer-bg);
  padding: var(--space-half) var(--space-1-25);
  border-radius: var(--border-radius-full);
}

.admin-header__subtitle {
  margin: 0;
  font-size: var(--space-1-625);
  color: var(--muted);
  font-weight: 650;
  line-height: 1.45;
  max-width: 42rem;
  text-align: right;
}

@media (max-width: 720px) {
  .admin-header__subtitle {
    text-align: left;
    width: 100%;
  }
}

.admin-nav {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-1) var(--space-1);
  padding-top: var(--space-1-75);
  border-top: var(--border-width-hairline) solid var(--border);
}

.admin-nav__link {
  display: inline-flex;
  align-items: center;
  padding: var(--space-1-25) var(--space-2);
  border-radius: var(--radius-pill);
  font-size: var(--space-1-875);
  font-weight: 700;
  color: var(--text);
  text-decoration: none;
  border: var(--border-width-hairline) solid transparent;
  background: transparent;
}

.admin-nav__link:hover {
  color: var(--wf-primary-dark);
  background: var(--primary-softer-bg);
  text-decoration: none;
}

.admin-nav__link--active {
  background: var(--btn-primary-bg);
  color: var(--color-on-primary) !important;
}

.admin-nav__link--active:hover {
  background: var(--btn-primary-hover);
  color: var(--color-on-primary) !important;
}

.admin-nav__logout {
  margin-left: auto;
}

.admin-nav__btn {
  padding: var(--space-1-25) var(--space-2-25);
  font-size: var(--space-1-75);
  border-radius: var(--radius-pill);
}

.admin-app .btn {
  transition:
    background var(--transition-fast) var(--ease-standard),
    border-color var(--transition-fast) var(--ease-standard),
    color var(--transition-fast) var(--ease-standard),
    box-shadow var(--transition-medium) var(--ease-standard),
    transform var(--transition-fast) var(--ease-standard),
    filter var(--transition-fast) var(--ease-standard);
}

.admin-app .btn:hover {
  transform: translateY(var(--motion-nudge-1));
  box-shadow: var(--elevation-admin-nav-hover);
}

.admin-app .btn--primary:hover {
  box-shadow: var(--elevation-admin-nav-hover-primary);
}

.admin-app .table tbody tr {
  transition: background 0.16s ease;
}

.admin-app .table tbody tr:hover {
  background: var(--primary-softer-bg);
}

.admin-app .table a.btn:hover,
.admin-app .table button.btn:hover {
  filter: brightness(1.02);
}

@media (max-width: 720px) {
  .admin-nav__logout {
    margin-left: 0;
    width: 100%;
  }

  .admin-nav__logout .admin-nav__btn {
    width: 100%;
  }
}

.admin-scope-banner {
  width: 100%;
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--space-1-25) var(--space-2);
  margin-bottom: var(--space-1-5);
  padding: var(--space-1-25) var(--space-1-75);
  border-radius: var(--radius);
  border: var(--border-width-hairline) solid var(--border-strong);
  background: var(--primary-softer-bg);
  font-size: var(--space-1-625);
  line-height: 1.45;
}

.admin-scope-banner__text {
  display: flex;
  flex-direction: column;
  gap: var(--space-0-75);
  flex: 1;
  min-width: 0;
}

.admin-scope-banner__hint {
  font-size: var(--space-1-5);
  font-weight: 600;
  color: var(--muted);
  line-height: 1.45;
}

.admin-scope-banner__slug {
  color: var(--muted);
  font-weight: 500;
}

.admin-scope-banner__link {
  font-weight: 700;
  color: var(--wf-primary);
  text-decoration: none;
}

.admin-scope-banner__link:hover {
  text-decoration: underline;
}

.admin-region-switch {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-1) var(--space-1-25);
  width: 100%;
}

.admin-region-switch__label {
  font-weight: 700;
  color: var(--text);
}

.admin-region-switch__select {
  min-width: min(100%, 18rem);
  padding: var(--space-0-75) var(--space-1);
  border-radius: var(--radius);
  border: var(--border-width-hairline) solid var(--border-strong);
  background: var(--surface);
  color: var(--text);
  font-size: var(--space-1-625);
}

.admin-region-switch__btn {
  flex-shrink: 0;
}

.admin-main__pad {
  padding: var(--admin-main-pad-y) var(--admin-main-pad-x) var(--admin-main-pad-bottom);
}

/* Plain admin cards only — form/workspace/dashboard panels keep their own padding */
.admin-main .card:not(.crm-task-hero):not(.crm-task-section):not(.admin-form-card):not(.admin-dashboard-panel):not(.admin-dashboard-table-card) {
  padding: var(--admin-card-padding);
  border-radius: var(--admin-radius-lg);
}

.admin-main .card.admin-dashboard-panel {
  padding: var(--space-2) var(--space-2-25) var(--space-2-25);
}

.admin-main .card.admin-dashboard-table-card {
  padding: 0;
}

.admin-main .section-title:first-of-type {
  margin-top: 0;
}

.admin-intro {
  font-size: var(--space-1-75);
  line-height: 1.6;
  color: var(--muted);
  max-width: 52rem;
  margin: 0 0 var(--space-1);
}

.admin-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: var(--admin-gap);
  align-items: center;
  margin: 0 0 var(--space-2-5);
}

.admin-toolbar--compact {
  margin-bottom: var(--space-1-5);
}

.admin-super-users__topbar {
  display: flex;
  justify-content: flex-end;
  margin-bottom: var(--space-half);
}

.table.table--readonly tbody tr {
  cursor: default;
}

.admin-filter-form {
  margin-bottom: var(--space-2-5);
}

.admin-filter-form__grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(var(--layout-dim-160), 1fr));
  gap: var(--space-1-75) var(--space-2);
  margin-bottom: var(--space-1-5);
}

.admin-filter-form__label {
  display: block;
  font-size: var(--space-1-5);
  font-weight: 600;
  margin-bottom: var(--space-half);
  color: var(--muted);
}

.admin-filter-form__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-1-25);
  align-items: center;
}

.admin-stat-card {
  border-left: var(--border-width-thick) solid var(--wf-primary);
}

.admin-stat-card__value {
  font-weight: 900;
  font-size: 1.75rem;
  margin-top: var(--space-1);
  letter-spacing: -0.02em;
}

/* ——— Admin dashboard (aligned with site purple + card language) ——— */
.admin-dashboard-page .admin-main {
  background: var(--gradient-admin-dashboard-main);
}

.admin-dashboard__header {
  margin-bottom: var(--admin-gap-section);
}

.admin-dashboard__title {
  margin: 0 0 var(--space-0-75);
  font-size: clamp(1.5rem, 2.8vw, 1.85rem);
  font-weight: 900;
  letter-spacing: -0.03em;
  color: var(--text);
}

.admin-dashboard__subtitle {
  margin: 0;
  font-size: var(--space-1-75);
  line-height: 1.45;
  max-width: 40rem;
}

.admin-dashboard__subtitle .kbd {
  margin-left: var(--space-0-75);
}

.admin-dashboard__kpis {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--admin-gap-section);
  margin-bottom: calc(var(--admin-gap-section) + var(--space-0-75));
}

@media (max-width: 900px) {
  .admin-dashboard__kpis {
    grid-template-columns: 1fr;
  }
}

.admin-dashboard-kpi {
  display: flex;
  align-items: flex-start;
  gap: var(--space-1-75);
  padding: var(--space-2) var(--space-2-25);
  border-radius: var(--admin-radius-lg);
  border: var(--border-width-hairline) solid color-mix(in srgb, var(--border-strong) 88%, transparent);
  background: var(--gradient-dashboard-kpi);
  box-shadow: var(--card-shadow-sm);
}

.admin-dashboard-kpi--accent {
  border-color: color-mix(in srgb, var(--wf-primary) 28%, var(--border-strong));
  background: var(--gradient-dashboard-kpi-accent);
}

.admin-dashboard-kpi__icon {
  flex-shrink: 0;
  width: var(--space-5-5);
  height: var(--space-5-5);
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--space-1-5);
  background: color-mix(in srgb, var(--wf-primary) 12%, var(--surface));
  color: var(--wf-primary);
}

.admin-dashboard-kpi--accent .admin-dashboard-kpi__icon {
  background: color-mix(in srgb, var(--wf-primary) 18%, var(--surface));
  color: var(--wf-primary-dark);
}

.admin-dashboard-kpi__body {
  display: flex;
  flex-direction: column;
  gap: var(--border-width-medium);
  min-width: 0;
}

.admin-dashboard-kpi__label {
  font-size: var(--space-1-5);
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--muted);
}

.admin-dashboard-kpi__value {
  font-size: clamp(1.65rem, 3vw, 2rem);
  font-weight: 900;
  letter-spacing: -0.03em;
  line-height: 1.1;
  color: var(--text);
}

a.admin-dashboard-kpi--link {
  text-decoration: none;
  color: inherit;
  cursor: pointer;
  transition: border-color 0.18s ease, box-shadow 0.18s ease;
}

a.admin-dashboard-kpi--link:hover {
  border-color: color-mix(in srgb, var(--wf-primary) 35%, var(--border-strong));
  box-shadow: var(--elevation-slate-md);
}

a.admin-dashboard-kpi--link:focus {
  outline: none;
}

a.admin-dashboard-kpi--link:focus-visible {
  outline: 2px solid color-mix(in srgb, var(--wf-primary) 55%, var(--text));
  outline-offset: 2px;
}

a.admin-dashboard-panel--link {
  display: block;
  text-decoration: none;
  color: inherit;
  cursor: pointer;
  transition: border-color 0.18s ease, box-shadow 0.18s ease;
}

a.admin-dashboard-panel--link:hover {
  border-color: color-mix(in srgb, var(--wf-primary) 32%, var(--border-strong));
  box-shadow: var(--elevation-slate-sm);
}

a.admin-dashboard-panel--link:focus {
  outline: none;
}

a.admin-dashboard-panel--link:focus-visible {
  outline: 2px solid color-mix(in srgb, var(--wf-primary) 55%, var(--text));
  outline-offset: 2px;
}

.admin-dashboard-panel__chevron {
  flex-shrink: 0;
  font-size: var(--space-2);
  font-weight: 700;
  color: var(--wf-primary);
  line-height: 1;
}

.admin-dashboard-click-card {
  position: relative;
}

.admin-dashboard-stretched-link {
  position: absolute;
  inset: 0;
  z-index: 1;
  border-radius: inherit;
}

.admin-dashboard-stretched-link:focus {
  outline: none;
}

.admin-dashboard-stretched-link:focus-visible {
  outline: 2px solid color-mix(in srgb, var(--wf-primary) 55%, var(--text));
  outline-offset: 2px;
}

.admin-dashboard-table-card .table-wrap {
  position: relative;
  z-index: 0;
}

.admin-dashboard__charts {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--admin-gap-section);
  margin-bottom: var(--admin-gap-section);
}

@media (max-width: 960px) {
  .admin-dashboard__charts {
    grid-template-columns: 1fr;
  }
}

.admin-dashboard-panel {
  padding: var(--space-2) var(--space-2-25) var(--space-2-25);
  border-radius: var(--admin-radius-lg);
  border: var(--border-width-hairline) solid color-mix(in srgb, var(--border-strong) 90%, transparent);
  background: var(--surface);
  box-shadow: var(--elevation-slate-xs);
}

.admin-dashboard-panel__head {
  margin-bottom: var(--space-1-75);
}

.admin-dashboard-panel__head--row {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--space-1-5);
}

.admin-dashboard-panel__title {
  margin: 0 0 var(--space-half);
  font-size: var(--space-1-875);
  font-weight: 900;
  letter-spacing: -0.02em;
  color: var(--text);
}

.admin-dashboard-panel__hint {
  font-size: var(--space-1-5);
}

.admin-dashboard-panel--crm {
  margin-bottom: var(--admin-gap-section);
}

.admin-dash-bars {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: var(--space-1);
  min-height: var(--layout-dim-120);
  padding-top: var(--space-1);
}

.admin-dash-bars__col {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-0-75);
  min-width: 0;
}

.admin-dash-bars__value {
  font-size: var(--space-1-375);
  font-weight: 800;
  color: var(--muted);
  min-height: 1.2em;
}

.admin-dash-bars__track {
  width: 100%;
  max-width: var(--space-touch);
  height: var(--space-11);
  margin: 0 auto;
  border-radius: var(--space-1);
  background: color-mix(in srgb, var(--muted) 8%, var(--surface));
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  overflow: hidden;
}

.admin-dash-bars__fill {
  width: 100%;
  border-radius: 0 0 var(--space-1) var(--space-1);
  min-height: 0;
  background: var(--gradient-dash-bar-fill);
  transition: height 0.25s ease;
}

.admin-dash-bars__label {
  font-size: var(--space-1-375);
  font-weight: 700;
  color: var(--muted);
  text-align: center;
}

.admin-dash-status {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-1-5);
}

.admin-dash-status__row {
  margin: 0;
}

.admin-dash-status__top {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: var(--space-1-25);
  margin-bottom: var(--space-0-75);
  font-size: var(--space-1-625);
}

.admin-dash-status__name {
  font-weight: 700;
  color: var(--text);
}

.admin-dash-status__num {
  font-weight: 800;
  font-variant-numeric: tabular-nums;
  color: var(--muted);
  font-size: var(--space-1-5);
}

.admin-dash-status__bar {
  height: var(--space-1);
  border-radius: var(--border-radius-full);
  background: color-mix(in srgb, var(--muted) 10%, var(--surface));
  overflow: hidden;
}

.admin-dash-status__fill {
  display: block;
  height: 100%;
  border-radius: var(--border-radius-full);
  background: var(--gradient-dash-status-fill);
  min-width: 0;
  transition: width 0.25s ease;
}

.admin-dash-crm {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-1-25);
}

.admin-dash-crm__item {
  display: grid;
  grid-template-columns: minmax(var(--space-12-5), 1fr) 1fr auto;
  align-items: center;
  gap: var(--space-1-25) var(--space-1-75);
  font-size: var(--space-1-625);
}

@media (max-width: 600px) {
  .admin-dash-crm__item {
    grid-template-columns: 1fr;
  }
}

.admin-dash-crm__label {
  font-weight: 700;
  color: var(--text);
}

.admin-dash-crm__track {
  height: var(--space-0-75);
  border-radius: var(--border-radius-full);
  background: color-mix(in srgb, var(--muted) 10%, var(--surface));
  overflow: hidden;
  min-width: 0;
}

.admin-dash-crm__fill {
  display: block;
  height: 100%;
  border-radius: var(--border-radius-full);
  background: var(--gradient-dash-crm-fill);
}

.admin-dash-crm__n {
  font-weight: 800;
  font-size: var(--space-1-5);
  font-variant-numeric: tabular-nums;
  color: var(--muted);
  text-align: right;
}

.admin-dashboard__leads-section {
  margin-top: var(--space-1);
}

.admin-dashboard__section-head {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--space-1-25);
  margin-bottom: var(--space-1-5);
}

.admin-dashboard__section-title {
  margin: 0;
  font-size: var(--space-2-125);
  font-weight: 900;
  letter-spacing: -0.02em;
}

.admin-dashboard__section-link {
  font-size: var(--space-1-75);
  font-weight: 700;
  text-decoration: none;
}

.admin-dashboard__section-link:hover {
  text-decoration: underline;
}

.admin-dashboard-table-card {
  padding: 0;
  overflow: hidden;
  border-radius: var(--admin-radius-lg);
}

.admin-dashboard-table {
  font-size: var(--space-1-75);
}

.admin-dashboard-table th {
  font-size: var(--space-1-375);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--muted);
  font-weight: 800;
}

.admin-dashboard-table__company {
  font-weight: 800;
  color: var(--text);
}

.admin-dashboard-table__sub {
  font-size: var(--space-1-5);
  margin-top: var(--border-width-medium);
}

.admin-dashboard-table__msg {
  max-width: min(var(--layout-dim-360), 42vw);
  font-size: var(--space-1-625);
  line-height: 1.45;
  overflow: hidden;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}

.admin-dashboard-table__time {
  font-size: var(--space-1-5);
  white-space: nowrap;
}

.admin-dashboard-table__empty {
  padding: var(--space-2-5) var(--space-2);
  text-align: center;
}

.admin-form-card {
  max-width: var(--layout-dim-560);
  margin-top: var(--space-1);
  padding: var(--space-2-75) var(--space-2-75) var(--space-3);
}

.admin-form-card--wide {
  max-width: var(--bp-xl);
}

.admin-settings-tenant-table__name {
  font-weight: 800;
  color: var(--text);
  text-decoration: none;
}

.admin-settings-tenant-table__name:hover {
  color: var(--wf-primary);
  text-decoration: underline;
}

.admin-settings-tenant-table__row:hover {
  background: color-mix(in srgb, var(--surface) 94%, var(--wf-primary) 6%);
}

.admin-settings-tenant-table__actions {
  text-align: right;
  white-space: nowrap;
  width: 1%;
}

.admin-settings-tenant-table .btn {
  padding: var(--space-0-75) var(--space-1-75);
  font-size: var(--space-1-625);
}

.admin-settings-detail__meta {
  margin: var(--motion-nudge-8) 0 var(--space-2);
  font-size: var(--space-1-75);
}

.admin-embed-bar {
  position: sticky;
  top: 0;
  z-index: 10040;
  background: var(--surface);
  border-bottom: var(--border-width-hairline) solid var(--border-strong);
  padding: var(--space-1-25) var(--space-2);
  box-shadow: var(--elevation-slate-md);
}

.admin-embed-bar__inner {
  max-width: var(--bp-max-xl);
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-1-5);
  flex-wrap: wrap;
}

.admin-embed-bar__label {
  font-size: var(--space-1-625);
  font-weight: 700;
  color: var(--muted);
}

.admin-embed-bar__actions {
  display: flex;
  gap: var(--space-1);
  flex-wrap: wrap;
}

.admin-embed-bar__btn {
  font-size: var(--space-1-625);
  font-weight: 700;
}

/* Embedded admin tools (Settings modal iframe): no top nav; tighter chrome */
.admin-app--embed .admin-main {
  padding-top: 0;
}

.admin-app--embed .admin-main__pad {
  padding-top: var(--space-1-5);
  padding-bottom: var(--space-2);
}

.admin-app--embed .section-title {
  margin-bottom: var(--space-1);
  font-size: 1.35rem;
}

.admin-app--embed .admin-super-users__topbar {
  margin-bottom: var(--space-1);
}

.admin-app--embed .admin-filter-form {
  margin-bottom: var(--space-1-5);
}

.admin-app--embed .admin-filter-form__grid {
  gap: var(--space-1) var(--space-1-5);
}

.admin-app--embed .admin-filter-form__actions {
  margin-top: var(--space-1);
}

.admin-app--embed .admin-intro--embed {
  font-size: var(--space-1-625);
  margin-bottom: var(--space-1-25);
}

.admin-settings-hub__hero {
  margin-bottom: var(--space-3-5);
  padding-bottom: var(--space-2-5);
  border-bottom: var(--border-width-hairline) solid var(--border-strong);
}

.admin-settings-hub__title {
  margin: 0 0 var(--space-1-25);
  font-size: clamp(1.5rem, 2.5vw, 1.85rem);
  font-weight: 800;
  letter-spacing: -0.02em;
  color: var(--text);
}

.admin-settings-hub__lead {
  margin: 0;
  max-width: 52ch;
  font-size: var(--space-1-875);
  line-height: 1.55;
}

.admin-settings-hub__kbd {
  display: inline-block;
  padding: var(--border-width-medium) var(--space-1);
  border-radius: var(--space-0-75);
  border: var(--border-width-hairline) solid var(--border-strong);
  background: color-mix(in srgb, var(--surface) 88%, var(--muted) 12%);
  font-size: var(--space-1-5);
  font-weight: 700;
  font-family: var(--font-family-mono);
}

.admin-settings-hub__grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(var(--layout-dim-220), 1fr));
  gap: var(--admin-gap-section);
}

.admin-settings-hub__card {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  text-align: left;
  padding: var(--space-2-25) var(--space-2);
  border-radius: var(--space-1-5);
  border: var(--border-width-hairline) solid color-mix(in srgb, var(--border-strong) 85%, transparent);
  background: var(--gradient-settings-hub-card);
  box-shadow: var(--elevation-hairline-on-surface), var(--card-shadow-sm);
  cursor: pointer;
  transition: transform 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease;
  font: inherit;
  color: inherit;
}

.admin-settings-hub__card:hover {
  border-color: color-mix(in srgb, var(--wf-primary) 38%, var(--border-strong));
  box-shadow: var(--elevation-settings-hub-hover);
  transform: translateY(var(--motion-nudge-3));
}

.admin-settings-hub__card--accent {
  border-color: color-mix(in srgb, var(--wf-primary) 32%, var(--border-strong));
  background: var(--gradient-settings-hub-card-accent);
}

.admin-settings-hub__card-icon {
  font-size: 1.4rem;
  margin-bottom: var(--space-1-25);
  line-height: 1;
  opacity: 0.95;
}

.admin-settings-hub__card-title {
  font-weight: 800;
  font-size: 1rem;
  margin-bottom: var(--space-0-75);
  color: var(--text);
  letter-spacing: -0.01em;
}

.admin-settings-hub__card-desc {
  font-size: var(--space-1-5);
  line-height: 1.45;
}

/* Settings hub iframe modal: shell lives in public/m3-modal.css (.m3-modal--settings-iframe). */

/* Super admin — regions list: inline region settings (matches settings-hub modal chrome) */
.admin-tenant-settings-card {
  position: relative;
  overflow: hidden;
}

.admin-tenant-settings-inline {
  display: flex;
  flex-direction: column;
  min-height: min(72vh, var(--layout-dim-640));
  background: var(--surface);
}

.admin-tenant-settings-inline[hidden] {
  display: none !important;
}

.admin-tenant-settings-inline__chrome {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--modal-space-2);
  min-height: var(--modal-header-min-height);
  padding: var(--modal-space-1) var(--modal-space-2);
  border-bottom: var(--border-width-hairline) solid var(--border-strong);
  background: color-mix(in srgb, var(--surface) 96%, var(--muted) 4%);
  flex-shrink: 0;
}

.admin-tenant-settings-inline__title {
  margin: 0;
  font-size: 1rem;
  font-weight: 800;
  letter-spacing: -0.02em;
  color: var(--text);
  flex: 1;
  min-width: 0;
  padding-right: var(--modal-space-2);
}

.admin-tenant-settings-inline__close {
  width: var(--modal-close-btn-size);
  min-width: var(--modal-close-btn-size);
  height: var(--modal-close-btn-size);
  min-height: var(--modal-close-btn-size);
  border-radius: var(--border-radius-full);
  border: var(--border-width-hairline) solid var(--border-strong);
  background: var(--surface);
  font-size: var(--space-2-75);
  line-height: 1;
  cursor: pointer;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  color: var(--text);
  flex-shrink: 0;
}

.admin-tenant-settings-inline__close:hover {
  background: color-mix(in srgb, var(--wf-primary) 10%, var(--surface));
}

.admin-tenant-settings-inline__iframe {
  flex: 1;
  min-height: var(--layout-dim-420);
  width: 100%;
  border: 0;
  background: var(--bg);
}

.admin-settings-tenant-table__name-btn {
  background: none;
  border: 0;
  padding: 0;
  font: inherit;
  color: var(--wf-primary);
  font-weight: 700;
  text-decoration: underline;
  text-underline-offset: var(--border-width-medium);
  cursor: pointer;
  text-align: left;
}

.admin-settings-tenant-table__name-btn:hover {
  color: color-mix(in srgb, var(--wf-primary) 82%, var(--text));
}

/* ——— Company mini-site workspace (admin) ——— */
.admin-workspace-page .admin-main {
  padding-top: 0;
}

.admin-workspace {
  min-height: calc(100vh - var(--space-7));
  display: flex;
  flex-direction: column;
}

.admin-workspace__shell-wrap {
  flex: 1;
  min-height: 0;
  display: flex;
  flex-direction: column;
  padding-top: var(--space-1);
  padding-bottom: var(--space-5);
}

.admin-workspace__shell {
  display: flex;
  flex-direction: column;
  flex: 1;
  min-height: 0;
}

.admin-workspace__toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-start;
  gap: var(--space-1-25);
  padding: var(--space-1-25) 0 var(--space-1-75);
  border-bottom: var(--border-width-hairline) solid var(--border-strong);
  margin-bottom: var(--space-1-5);
}

.admin-workspace__toolbar-left {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-1);
}

.admin-workspace__toolbar-meta {
  margin-left: var(--space-half);
  font-size: var(--typo-label-small-size);
}

.admin-workspace__edit-lead {
  margin-top: 0;
  font-size: var(--typo-size-caption);
  line-height: var(--typo-body-large-line);
}

.admin-workspace__form-hint {
  font-size: var(--typo-size-2xs);
  margin-top: var(--space-half);
}

.admin-workspace__stage {
  flex: 1;
  min-height: 0;
  display: flex;
  flex-direction: column;
}

.admin-workspace__preview-wrap {
  flex: 1;
  min-height: min(80vh, var(--bp-xl-2));
  border-radius: var(--space-1-5);
  overflow: hidden;
  border: var(--border-width-hairline) solid var(--border-strong);
  background: var(--surface);
}

.admin-workspace__iframe {
  width: 100%;
  height: min(80vh, var(--bp-xl-2));
  min-height: var(--bp-xs);
  border: 0;
  display: block;
  background: var(--color-surface);
}

.admin-workspace__edit {
  max-width: var(--bp-2xl);
  width: 100%;
  margin-top: 0;
}

.admin-workspace__edit-title {
  margin: 0 0 var(--space-1);
  font-size: 1.25rem;
  font-weight: 900;
}

.admin-workspace__table-wrap {
  overflow-x: auto;
  margin-top: var(--space-1-5);
}

.admin-workspace__table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--space-1-75);
}

.admin-workspace__table th {
  text-align: left;
  vertical-align: top;
  padding: var(--space-1-25) var(--space-1-75) var(--space-1-25) 0;
  width: var(--layout-dim-200);
  font-weight: 700;
  color: var(--muted);
  border-bottom: var(--border-width-hairline) solid var(--border);
}

.admin-workspace__table td {
  padding: var(--space-1) 0;
  border-bottom: var(--border-width-hairline) solid var(--border);
}

.admin-workspace__table .input-grow,
.admin-workspace__table input[type="text"],
.admin-workspace__table input[type="email"],
.admin-workspace__table input[type="number"],
.admin-workspace__table select,
.admin-workspace__table textarea {
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
}

.admin-workspace__reviews-title {
  margin: var(--space-2-75) 0 var(--space-1);
  font-size: 1.05rem;
  font-weight: 900;
}

.admin-workspace__review-row {
  padding: var(--space-1-75);
  margin-bottom: var(--space-1-5);
  border-radius: var(--space-1-25);
  border: var(--border-width-hairline) solid var(--border-strong);
  background: color-mix(in srgb, var(--surface) 96%, var(--border-strong));
}

.admin-workspace__review-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-1-25);
  margin-bottom: var(--space-1-25);
}

@media (max-width: 600px) {
  .admin-workspace__review-grid {
    grid-template-columns: 1fr;
  }
}

.admin-workspace__review-body-label {
  display: block;
  margin-bottom: var(--space-1);
}

.admin-workspace__review-remove {
  margin-top: var(--space-half);
}

/* Mini-site workspace: leave + publish overlays use .m3-modal (see m3-modal.css + .admin-workspace-*-m3). */
.admin-workspace-leave-m3__title {
  margin: 0 0 var(--space-2);
  font-weight: 700;
  font-size: var(--typo-title-large-size);
  line-height: var(--typo-title-large-line);
  color: var(--color-text-primary);
}

.admin-workspace-leave-m3__desc {
  margin: 0;
  font-size: var(--typo-size-caption);
  line-height: var(--typo-body-large-line);
}

.admin-workspace__spinner {
  width: var(--space-touch);
  height: var(--space-touch);
  margin: 0 auto var(--space-1-5);
  border-radius: 50%;
  border: var(--border-width-thick) solid color-mix(in srgb, var(--wf-primary) 25%, var(--border-strong));
  border-top-color: var(--wf-primary);
  animation: admin-workspace-spin 0.85s linear infinite;
}

/* Rotating hourglass inside a circle (publish progress) */
.admin-workspace__hourglass {
  width: var(--space-7);
  height: var(--space-7);
  margin: 0 auto var(--space-1-5);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  border: var(--border-width-medium) solid color-mix(in srgb, var(--wf-primary) 30%, var(--border-strong));
  background: color-mix(in srgb, var(--surface) 94%, var(--wf-primary));
  box-shadow: var(--elevation-inset-highlight);
}

.admin-workspace__hourglass-inner {
  display: inline-block;
  font-size: var(--typo-headline-medium-size);
  line-height: 1;
  animation: admin-workspace-spin 1.1s linear infinite;
}

/* Admin: lead detail + threaded comments */
.admin-lead-detail__h {
  margin: 0 0 var(--space-1-5);
  font-size: 1.1rem;
  font-weight: 900;
}

.admin-lead-detail__meta {
  margin-top: var(--space-1);
}

.admin-lead-comments {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-1-75);
}

.admin-lead-comments__item {
  padding: var(--space-1-5) var(--space-1-75);
  border-radius: var(--space-1-25);
  border: var(--border-width-hairline) solid var(--border-strong);
  background: color-mix(in srgb, var(--surface) 96%, var(--border-strong));
}

.admin-lead-comments__time {
  font-size: var(--space-1-75);
  font-weight: 600;
  color: var(--muted);
  margin-bottom: var(--space-0-75);
}

.admin-lead-comments__body {
  font-size: var(--space-1-75);
  line-height: 1.5;
  white-space: pre-wrap;
  word-break: break-word;
}

/* Admin CRM */
.admin-crm-page__title {
  margin-top: 0;
  letter-spacing: -0.02em;
}

.admin-crm-page .admin-intro {
  margin-bottom: var(--space-2-5);
}

.admin-crm-page .admin-crm-panel.card {
  border-color: var(--border-strong);
}

.admin-crm-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-0-75);
  margin-bottom: var(--space-2-75);
  padding: var(--space-0-75);
  border-radius: var(--space-1-75);
  border: var(--border-width-hairline) solid var(--border-strong);
  background: color-mix(in srgb, var(--surface) 92%, var(--border-strong));
}

.admin-crm-tab {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-1-375) var(--space-2-25);
  border-radius: var(--space-1-25);
  font-weight: 800;
  font-size: var(--space-1-75);
  color: var(--muted);
  text-decoration: none;
  border: var(--border-width-hairline) solid transparent;
  transition:
    background 0.18s ease,
    color 0.18s ease,
    border-color 0.18s ease,
    box-shadow 0.18s ease;
}

.admin-crm-tab:hover {
  color: var(--text);
  background: var(--surface);
  border-color: color-mix(in srgb, var(--wf-primary) 22%, var(--border-strong));
}

.admin-crm-tab--active {
  color: var(--color-on-primary);
  background: var(--btn-primary-bg);
  border-color: var(--btn-primary-bg);
  box-shadow: var(--elevation-lead-pill);
}

.admin-crm-tab--active:hover {
  color: var(--color-on-primary);
  background: var(--btn-primary-hover);
  border-color: var(--btn-primary-hover);
}

.admin-crm-table thead th {
  font-size: var(--space-1-5);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--muted-soft);
  border-bottom-color: var(--border-strong);
}

.admin-crm-table td {
  vertical-align: middle;
}

.admin-crm-table .btn {
  white-space: nowrap;
}

@media (max-width: 640px) {
  .admin-crm-table td:last-child {
    white-space: normal;
  }

  .admin-crm-table td:last-child form {
    display: block;
    margin-top: var(--space-1) !important;
    margin-left: 0 !important;
  }
}

/* CRM Kanban */
.admin-crm-create {
  margin-bottom: 0;
}

.admin-crm-top {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-2);
  margin-bottom: var(--space-3);
  align-items: start;
}

@media (min-width: 900px) {
  .admin-crm-top:has(.admin-crm-create) {
    grid-template-columns: minmax(0, 1fr) minmax(260px, 360px);
  }
}

.admin-crm-unassigned {
  padding: var(--space-2);
}

.admin-crm-unassigned__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-0-75);
  max-height: min(60vh, 28rem);
  overflow-y: auto;
}

.admin-crm-unassigned__item {
  margin: 0;
}

.admin-crm-unassigned__link {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: var(--space-0-25);
  width: 100%;
  text-align: left;
  padding: var(--space-1) var(--space-1-25);
  border-radius: var(--radius);
  border: var(--border-width-hairline) solid var(--border);
  background: var(--surface);
  cursor: pointer;
  font: inherit;
  color: var(--text);
  transition: border-color 0.15s, background 0.15s;
}

.admin-crm-unassigned__link:hover {
  border-color: color-mix(in srgb, var(--wf-primary) 35%, var(--border-strong));
  background: color-mix(in srgb, var(--wf-primary) 6%, var(--surface));
}

.admin-crm-unassigned__item-title {
  font-weight: 700;
  font-size: var(--space-1-75);
  line-height: 1.3;
}

.admin-crm-unassigned__item-snippet {
  font-size: var(--space-1-5);
  line-height: 1.35;
  display: block;
}

.admin-crm-unassigned__empty {
  margin: 0;
  font-size: var(--space-1-625);
}

.admin-partner-source {
  padding: var(--space-2);
}

.admin-dl-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(12rem, 1fr));
  gap: var(--space-1-5);
  margin: 0;
}

.admin-dl-grid dt {
  font-size: var(--space-1-375);
  font-weight: 700;
  color: var(--muted);
  margin: 0 0 var(--space-0-25);
}

.admin-dl-grid dd {
  margin: 0;
  font-size: var(--space-1-75);
}

.admin-crm-section__title {
  margin: 0 0 var(--space-1);
  font-size: 1.1rem;
  font-weight: 900;
  letter-spacing: -0.02em;
  color: var(--text);
  line-height: 1.25;
}

.admin-crm-section__lead {
  margin: 0 0 var(--space-2);
  font-size: var(--space-1-75);
  line-height: 1.55;
}

.admin-crm-kanban {
  display: flex;
  flex-wrap: nowrap;
  gap: var(--space-1-5);
  align-items: flex-start;
  overflow-x: auto;
  padding-bottom: var(--space-1-25);
  margin: 0 var(--motion-nudge-4);
  scroll-snap-type: x proximity;
  -webkit-overflow-scrolling: touch;
}

.admin-crm-kanban__col {
  flex: 0 0 min(var(--layout-dim-280), 88vw);
  scroll-snap-align: start;
  display: flex;
  flex-direction: column;
  min-height: 0;
  max-height: min(72vh, var(--bp-md));
  border-radius: var(--space-1-75);
  border: var(--border-width-hairline) solid var(--border-strong);
  background: color-mix(in srgb, var(--surface) 96%, var(--border-strong));
  box-shadow: var(--card-shadow-sm);
}

.admin-crm-kanban__col-head {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: var(--space-1);
  padding: var(--space-1-25) var(--space-1-5);
  border-bottom: var(--border-width-hairline) solid var(--border-strong);
  background: var(--surface);
  border-radius: var(--space-1-75) var(--space-1-75) 0 0;
}

.admin-crm-kanban__col-toggle {
  border: 0;
  background: transparent;
  padding: var(--space-0-75);
  margin: var(--motion-nudge-4) 0 var(--motion-nudge-4) var(--motion-nudge-4);
  cursor: pointer;
  border-radius: var(--space-1);
  flex-shrink: 0;
  line-height: 0;
}

.admin-crm-kanban__col-toggle:hover {
  background: color-mix(in srgb, var(--wf-primary) 10%, var(--surface));
}

.admin-crm-kanban__col-toggle-icon {
  display: block;
  width: var(--space-1);
  height: var(--space-1);
  border-right: var(--border-width-medium) solid var(--muted);
  border-bottom: var(--border-width-medium) solid var(--muted);
  transform: rotate(45deg);
  transition: transform 0.2s ease;
}

.admin-crm-kanban__col--collapsed .admin-crm-kanban__col-toggle-icon {
  transform: rotate(-135deg);
}

.admin-crm-kanban__col--collapsed .admin-crm-kanban__dropzone {
  display: none;
}

.admin-crm-kanban__col-title {
  flex: 1;
  min-width: 0;
  margin: 0;
  font-size: var(--space-1-625);
  font-weight: 900;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: var(--text);
}

.admin-crm-kanban__col-count {
  font-size: var(--space-1-5);
  font-weight: 800;
  color: var(--muted);
  min-width: 1.5rem;
  text-align: center;
  padding: var(--border-width-medium) var(--space-1);
  border-radius: var(--border-radius-full);
  background: var(--primary-softer-bg);
}

.admin-crm-kanban__dropzone {
  flex: 1;
  min-height: var(--layout-dim-160);
  padding: var(--space-1-25);
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: var(--space-1-25);
}

.admin-crm-kanban__dropzone--dragover {
  outline: var(--border-width-medium) dashed var(--wf-primary);
  outline-offset: var(--motion-nudge-4);
  background: var(--color-primary-glow-mix);
}

.admin-crm-kanban__empty {
  margin: 0;
  padding: var(--space-1-5) var(--space-1);
  font-size: var(--space-1-75);
  text-align: center;
}

.admin-crm-card {
  padding: var(--space-1-5) var(--space-1-5) var(--space-1-75);
  border-radius: var(--space-1-5);
  border: var(--border-width-hairline) solid var(--border-strong);
  background: var(--surface);
  box-shadow: var(--elevation-slate-sm);
}

.admin-crm-card--draggable {
  cursor: grab;
  user-select: none;
}

.admin-crm-card--draggable:active {
  cursor: grabbing;
}

.admin-crm-card--dragging {
  opacity: 0.55;
}

.admin-crm-card__body {
  flex: 1;
  min-width: 0;
  cursor: pointer;
  text-align: left;
  border: 0;
  background: transparent;
  font: inherit;
  padding: var(--border-width-medium) var(--space-half);
  margin: var(--motion-nudge-2) var(--motion-nudge-4);
  border-radius: var(--space-1);
}

.admin-crm-card__body:hover {
  background: color-mix(in srgb, var(--wf-primary) 7%, transparent);
}

.admin-crm-card__body:focus {
  outline: var(--border-width-medium) solid var(--wf-primary);
  outline-offset: var(--border-width-hairline);
}

.admin-crm-card__title-text {
  margin: 0 0 var(--space-0-75);
  font-size: var(--space-1-875);
  font-weight: 800;
  line-height: 1.35;
  color: var(--text);
}

.admin-crm-card__attach {
  margin: var(--space-0-75) 0 0;
  font-size: var(--space-1-5);
  font-weight: 600;
}

.admin-crm-card__meta {
  margin: 0 0 var(--space-0-75);
  font-size: var(--space-1-625);
  line-height: 1.4;
}

.admin-crm-card__snippet {
  margin: 0;
  font-size: var(--space-1-625);
  line-height: 1.45;
}

/* CRM task overlay shell: public/m3-modal.css; z-index below settings hub when both exist */
.admin-crm-overlay.m3-modal-overlay {
  z-index: 10050;
}

.sr-only {
  position: absolute;
  width: var(--border-width-hairline);
  height: var(--border-width-hairline);
  padding: 0;
  margin: var(--motion-nudge-1);
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* CRM task detail — M3 surfaces, elevation, spacing */
.admin-crm-page .admin-main {
  background: var(--md-sys-color-surface-container);
}

.crm-task-shell {
  display: flex;
  flex-direction: column;
  gap: var(--md-sys-spacing-4);
  max-width: min(100%, var(--bp-xl-2));
}

@media (max-width: 879px) {
  .crm-task-shell {
    gap: var(--md-sys-spacing-3);
  }
}

.crm-task-shell--panel {
  max-width: none;
}

.crm-task-layout {
  display: grid;
  gap: var(--md-sys-spacing-4);
  grid-template-columns: 1fr;
  align-items: start;
}

.crm-task-layout__primary,
.crm-task-layout__aside {
  display: flex;
  flex-direction: column;
  gap: var(--md-sys-spacing-4);
  min-width: 0;
}

@media (max-width: 879px) {
  .crm-task-layout {
    gap: var(--md-sys-spacing-3);
  }

  .crm-task-layout__primary,
  .crm-task-layout__aside {
    gap: var(--md-sys-spacing-3);
  }
}

@media (min-width: 880px) {
  .crm-task-layout {
    grid-template-columns: 1fr min(var(--layout-dim-300), 34%);
    gap: var(--md-sys-spacing-5);
    align-items: start;
  }

  .crm-task-layout__aside {
    position: sticky;
    top: max(var(--space-1-5), env(safe-area-inset-top, 0));
  }
}

.crm-task-hero {
  padding: var(--md-sys-spacing-4) var(--md-sys-spacing-4) var(--md-sys-spacing-5);
  border-radius: var(--md-sys-shape-corner-large);
  border: var(--border-width-hairline) solid var(--md-sys-color-outline-variant);
  background: var(--md-sys-color-surface-container-low);
  box-shadow: var(--md-sys-elevation-level2);
}

.crm-task-hero__eyebrow {
  margin: 0 0 var(--space-0-75);
  font-size: var(--space-1-375);
  font-weight: 800;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  color: var(--muted);
}

.crm-task-hero__top {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-1) var(--space-1-5);
  margin-bottom: var(--space-1);
}

.crm-task-pill {
  display: inline-flex;
  align-items: center;
  padding: var(--md-sys-spacing-1) var(--md-sys-spacing-3);
  border-radius: var(--md-sys-shape-corner-extra-large);
  font-size: var(--space-1-375);
  font-weight: 800;
  letter-spacing: 0.02em;
  background: color-mix(in srgb, var(--wf-primary) 14%, var(--md-sys-color-surface-container-lowest));
  color: var(--text);
  border: var(--border-width-hairline) solid color-mix(in srgb, var(--wf-primary) 28%, var(--md-sys-color-outline-variant));
}

.crm-task-hero__assignee {
  font-size: var(--space-1-625);
}

.crm-task-hero__title {
  margin: 0 0 var(--space-1);
  font-size: clamp(1.15rem, 2.6vw, 1.45rem);
  font-weight: 900;
  letter-spacing: -0.03em;
  line-height: 1.25;
  color: var(--text);
}

.crm-task-hero__meta {
  margin: 0;
  font-size: var(--space-1-5);
  line-height: 1.45;
}

.crm-task-section {
  padding: var(--md-sys-spacing-4) var(--md-sys-spacing-4);
  border-radius: var(--md-sys-shape-corner-large);
  border: var(--border-width-hairline) solid var(--md-sys-color-outline-variant);
  background: var(--md-sys-color-surface-container-lowest);
  box-shadow: var(--md-sys-elevation-level1);
}

.crm-task-section--form .crm-task-form > .crm-task-form__actions {
  margin-bottom: 0;
}

.crm-task-section--form {
  padding-bottom: var(--md-sys-spacing-4);
}
.crm-task-section--form:focus-within {
  box-shadow: var(--md-sys-elevation-level2);
}

.crm-task-section--callout {
  background: color-mix(in srgb, var(--wf-primary) 6%, var(--md-sys-color-surface-container-lowest));
  border-color: color-mix(in srgb, var(--wf-primary) 22%, var(--md-sys-color-outline-variant));
  box-shadow: var(--md-sys-elevation-level1);
}

.crm-task-section--history {
  background: var(--md-sys-color-surface-container-low);
  border-color: var(--md-sys-color-outline-variant);
}

.crm-task-aside__title {
  margin: 0 0 var(--space-1-25);
  font-size: var(--space-1-625);
  font-weight: 800;
  color: var(--text);
}

.crm-task-aside__label {
  display: block;
  font-size: var(--space-1-5);
  font-weight: 700;
  margin-bottom: var(--space-0-75);
  color: var(--muted);
}

.crm-task-layout__aside .crm-task-section--form select {
  width: 100%;
  margin-bottom: 0;
}

.crm-task-section__h {
  margin: 0 0 var(--space-1);
  font-size: var(--space-1-375);
  font-weight: 800;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  color: var(--muted);
}

.crm-task-empty {
  margin: 0;
  font-size: var(--space-1-75);
}

.crm-task-prose {
  margin: 0;
  font-size: var(--space-1-75);
  line-height: 1.55;
  white-space: pre-wrap;
  word-break: break-word;
  color: var(--text);
}

.crm-task-attach {
  margin-top: var(--md-sys-spacing-3);
  padding-top: var(--md-sys-spacing-3);
  border-top: var(--border-width-hairline) solid var(--md-sys-color-outline-variant);
  display: flex;
  flex-direction: column;
  gap: var(--md-sys-spacing-1);
}

.crm-task-attach__label {
  font-size: var(--space-1-375);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.crm-task-attach__link {
  font-size: var(--space-1-625);
  font-weight: 600;
  word-break: break-all;
}

.crm-task-form .form label,
.crm-task-form .input-field__label {
  font-weight: 700;
  font-size: var(--space-1-5);
}

.crm-task-form .form > .input-field {
  margin-bottom: var(--md-sys-spacing-3);
}

.crm-task-form__actions {
  margin-top: var(--md-sys-spacing-3);
  padding-top: var(--md-sys-spacing-2);
  display: flex;
  align-items: center;
  gap: var(--md-sys-spacing-2);
}

.crm-task-form--comment textarea {
  margin-top: var(--space-0-75);
}

.crm-task-note {
  margin: 0;
  padding: var(--space-1-25) var(--space-1-5);
  border-radius: var(--admin-radius);
  background: var(--surface);
  border: var(--border-width-hairline) dashed var(--border-strong);
  font-size: var(--space-1-625);
  line-height: 1.45;
}

.crm-task-note--aside {
  padding: var(--space-1-25) var(--space-1-5);
}

.crm-task-comments {
  list-style: none;
  margin: 0 0 var(--md-sys-spacing-3);
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--md-sys-spacing-2);
}

.crm-task-comments__item {
  padding: var(--md-sys-spacing-3);
  border-radius: var(--md-sys-shape-corner-medium);
  background: var(--md-sys-color-surface-container-low);
  border: var(--border-width-hairline) solid var(--md-sys-color-outline-variant);
  box-shadow: var(--md-sys-elevation-level0);
}

/* Relative event time (SSR) + exact time on info icon hover */
.event-time {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  flex-wrap: wrap;
  vertical-align: baseline;
}

.event-time__ago {
  white-space: nowrap;
}

.event-time__info {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--muted);
  cursor: help;
  line-height: 0;
  flex-shrink: 0;
}

.event-time__info:hover,
.event-time__info:focus-visible {
  color: var(--text);
}

.event-time__icon {
  display: block;
}

.crm-task-comments__meta {
  display: flex;
  justify-content: space-between;
  gap: var(--space-1);
  font-size: var(--space-1-375);
  margin-bottom: var(--space-0-75);
}

.crm-task-comments__body {
  font-size: var(--space-1-625);
  line-height: 1.5;
  white-space: pre-wrap;
  word-break: break-word;
}

.crm-task-audit {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--md-sys-spacing-2);
}

.crm-task-audit__row {
  padding: var(--md-sys-spacing-3);
  border-radius: var(--md-sys-shape-corner-medium);
  background: var(--md-sys-color-surface-container-lowest);
  border: var(--border-width-hairline) solid var(--md-sys-color-outline-variant);
  font-size: var(--space-1-5);
  box-shadow: var(--md-sys-elevation-level0);
}

.crm-task-audit__meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-0-75) var(--space-1-25);
  margin-bottom: var(--space-half);
  font-size: var(--space-1-375);
}

.crm-task-audit__time {
  font-weight: 700;
  color: var(--text);
}

.crm-task-audit__badge {
  font-size: var(--space-1-25);
  font-weight: 800;
  padding: var(--border-width-medium) var(--space-0-75);
  border-radius: var(--space-half);
  background: var(--primary-softer-bg);
  color: var(--text);
}

.crm-task-audit__details {
  font-size: var(--space-1-375);
  line-height: 1.4;
  word-break: break-word;
}

@media (max-width: 600px) {
  .crm-task-section .btn,
  .crm-task-layout__aside .btn {
    min-height: var(--space-touch);
  }

  .crm-task-form select {
    min-height: var(--space-touch);
    border-radius: var(--md-sys-shape-corner-small);
  }

  .crm-task-form input:not([type="hidden"]) {
    min-height: var(--space-touch);
    border-radius: var(--md-sys-shape-corner-small);
  }

  .crm-task-form textarea {
    min-height: var(--layout-dim-120);
    padding: var(--md-sys-spacing-3);
    border-radius: var(--md-sys-shape-corner-small);
  }
}

@media (min-width: 1200px) {
  .admin-crm-kanban {
    flex-wrap: wrap;
    overflow-x: visible;
  }

  .admin-crm-kanban__col {
    flex: 1 1 calc(16.66% - var(--space-1-5));
    min-width: var(--layout-dim-180);
    max-height: none;
  }
}

.admin-workspace__overlay-text {
  font-weight: 800;
  font-size: var(--typo-size-body-comfort);
  color: var(--text);
}

@keyframes admin-workspace-spin {
  to {
    transform: rotate(360deg);
  }
}

.admin-inline-form {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-1-25);
  align-items: center;
}

.admin-inline-form select {
  max-width: var(--layout-dim-220);
}

.table-wrap {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  margin: var(--motion-nudge-2) var(--motion-nudge-2) 0;
  padding: var(--border-width-medium);
}

.form-check {
  display: flex;
  align-items: center;
  gap: var(--space-1-25);
  font-size: var(--space-1-75);
  margin-top: var(--space-1);
}

.form-check input[type="checkbox"] {
  width: auto;
  margin: 0;
}

/* ——— Slim top bar (Workfolio-style light strip) ——— */
.wf-topbar {
  background: var(--topbar-bg);
  color: var(--muted);
  font-size: var(--space-1-625);
  border-bottom: var(--border-width-hairline) solid var(--border-strong);
}

.wf-topbar a {
  color: var(--muted);
  text-decoration: none;
}

.wf-topbar a:hover {
  color: var(--wf-primary);
  text-decoration: none;
}

.wf-topbar-inner {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-1-25) var(--space-2-5);
  padding: var(--space-1) 0;
}

.wf-topbar-tag {
  color: var(--muted-soft);
  font-weight: 500;
}

.wf-topbar-links {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-0-75) var(--space-2);
  list-style: none;
  margin: 0;
  padding: 0;
}

.wf-topbar-links li {
  display: inline;
}

.wf-topbar-links li:not(:last-child)::after {
  content: "·";
  margin-left: var(--space-2);
  opacity: 0.35;
  pointer-events: none;
}

.wf-header-wrap {
  background: var(--surface);
  border-bottom: var(--border-width-hairline) solid var(--border-strong);
  position: sticky;
  top: 0;
  z-index: 40;
  box-shadow: 0 1px 0 color-mix(in srgb, var(--border-strong) 55%, transparent);
}

@media (max-width: 767px) {
  .wf-header-wrap--minimal .nav.wf-nav--minimal {
    padding-block: var(--space-1-25);
    gap: var(--space-1) var(--space-1-5);
  }
}

/* ——— Main header ——— */
.nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-2-25) 0;
  background: transparent;
  border-bottom: none;
}

.wf-nav {
  flex-wrap: wrap;
  gap: var(--space-1-75) var(--space-2-5);
}

/* Admin / inner pages: simple top bar without full marketing header */
.container > .nav:not(.wf-nav) {
  padding: var(--space-1-75) 0 var(--space-2-25);
  margin-bottom: var(--space-1);
  border-bottom: var(--border-width-hairline) solid var(--border-strong);
}

.brand {
  display: flex;
  align-items: center;
  gap: var(--space-1-5);
  font-weight: 800;
  font-size: var(--space-2-125);
  letter-spacing: -0.02em;
}

.brand > a,
.brand-primary > a {
  color: var(--text);
  text-decoration: none;
  display: flex;
  align-items: center;
  gap: var(--space-1-25);
}

.brand > a:hover,
.brand-primary > a:hover {
  text-decoration: none;
}

.brand-primary {
  display: flex;
  align-items: center;
  gap: var(--space-1-5);
  flex-wrap: wrap;
}

.brand--with-regions {
  flex-direction: column;
  align-items: flex-start;
  gap: var(--space-1-25);
  flex: 1 1 var(--layout-dim-240);
  min-width: 0;
}

.brand-tagline {
  font-weight: 600;
  font-size: var(--space-1-5);
  color: var(--muted);
  max-width: var(--layout-dim-280);
  line-height: 1.35;
}

@media (max-width: 720px) {
  .brand-tagline {
    display: none;
  }
}

.logo {
  width: var(--space-5);
  height: var(--space-5);
  border-radius: var(--space-1-5);
  background: var(--gradient-nav-cta);
  flex-shrink: 0;
}

/* GetPro + flag + region name (home / join / directory header) */
.wf-brand-lockup-root {
  display: inline-flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-0-75) var(--space-1-25);
}
.wf-brand-lockup-region {
  display: inline-flex;
  align-items: center;
  gap: var(--space-0-625);
  font-weight: 700;
}
.wf-brand-lockup-flag {
  font-size: 1.05em;
  line-height: 1;
}
.wf-brand-lockup-name {
  font-weight: 700;
  letter-spacing: -0.02em;
}

.wf-nav-brand {
  text-decoration: none;
}

.nav-links {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-1-25) var(--space-2-25);
  font-weight: 500;
  font-size: var(--space-2);
}

.nav-links a:not(.btn) {
  color: var(--muted);
  text-decoration: none;
}

.nav-links a:not(.btn):hover {
  color: var(--wf-primary);
  text-decoration: none;
}

.wf-nav-actions {
  gap: var(--space-1-25) var(--space-1-75);
}

.btn-nav-outline {
  padding: var(--space-1-25) var(--space-2-75);
  border-radius: var(--radius-pill);
  font-size: var(--space-1-875);
  font-weight: 700;
  border: var(--border-width-hairline) solid var(--wf-primary);
  background: var(--surface);
  color: var(--wf-primary-dark);
}

.btn-nav-outline:hover {
  background: var(--primary-softer-bg);
  color: var(--wf-primary-dark);
  border-color: var(--wf-primary-dark);
}

.btn-nav-primary {
  padding: var(--space-1-25) var(--space-2-75);
  border-radius: var(--radius-pill);
  font-size: var(--space-1-875);
  font-weight: 700;
  border: none;
  background: var(--btn-primary-bg);
  color: var(--color-white);
  box-shadow: var(--shadow);
}

.btn-nav-primary:hover {
  background: var(--btn-primary-hover);
  color: var(--color-white);
}

@media (max-width: 720px) {
  .btn-nav-outline,
  .btn-nav-primary {
    padding: var(--space-1-125) var(--space-2);
    font-size: var(--space-1-75);
  }
}

/* Minimal header: logo + single “List your business” (no top shortcut strip, no Directory/Browse/admin) */
.wf-header-wrap--minimal .nav.wf-nav--minimal {
  align-items: center;
  justify-content: space-between;
  gap: var(--space-1-5) var(--space-2);
}

.wf-nav-actions--minimal {
  gap: var(--space-1-25);
  flex-shrink: 0;
}

.wf-nav-actions--minimal a {
  font-weight: 700;
  font-size: var(--space-1-875);
  color: var(--wf-primary);
  text-decoration: none;
  white-space: nowrap;
}

.wf-nav-actions--minimal a:hover {
  color: var(--wf-primary-dark);
  text-decoration: underline;
}

@media (max-width: 560px) {
  .wf-header-wrap--minimal .nav.wf-nav--minimal {
    flex-direction: column;
    align-items: stretch;
    padding: var(--space-1-5) 0 var(--space-1-75);
  }

  .wf-nav-actions--minimal {
    width: 100%;
  }

  .wf-nav-actions--minimal a {
    display: block;
    text-align: center;
    padding: var(--space-1-25) var(--space-1-75);
    border-radius: var(--radius-pill);
    border: var(--border-width-hairline) solid color-mix(in srgb, var(--wf-primary) 35%, var(--border-strong));
    background: color-mix(in srgb, var(--wf-primary) 8%, var(--surface));
    white-space: normal;
  }
}

/* ——— Hero + search (Workfolio-style) ——— */
.pro-hero {
  background: var(--surface);
  border-bottom: var(--border-width-hairline) solid var(--border-strong);
  padding: clamp(var(--space-touch), 8vw, var(--space-12-5)) 0 clamp(var(--space-5), 6vw, var(--space-9));
}

.pro-hero-kicker-wrap {
  display: inline-block;
  margin-bottom: var(--space-2);
  padding: var(--border-width-medium) var(--space-1-75);
  border-radius: var(--space-1-875);
  border: var(--border-width-hairline) solid var(--border);
  background: var(--hero-kicker-bg);
}

.pro-hero-kicker {
  font-size: var(--space-1-75);
  font-weight: 600;
  color: var(--muted);
  margin: 0;
}

.pro-hero-kicker span {
  color: var(--wf-primary);
}

.pro-hero-title {
  font-size: clamp(var(--space-4), 5vw, var(--space-7));
  line-height: 1.1;
  margin: 0 0 var(--space-2);
  font-weight: 700;
  letter-spacing: -0.03em;
  max-width: var(--layout-dim-820);
  color: var(--color-black);
}

.pro-hero-lead {
  margin: 0 0 var(--space-3-5);
  font-size: clamp(var(--space-2-125), 2vw, var(--space-2-75));
  font-weight: 400;
  color: var(--muted);
  line-height: 1.45;
  max-width: var(--layout-dim-640);
}

/* Stats row (mirrors Workfolio directory stat strip) */
.wf-stats {
  background: var(--bg);
  border-bottom: var(--border-width-hairline) solid var(--border-strong);
  padding: var(--space-touch) 0;
}

@media (max-width: 520px) {
  .wf-stats {
    padding: var(--space-2-5) 0 var(--space-3);
  }

  .wf-stat-value {
    font-size: clamp(var(--space-2-125), 3.8vw, var(--space-3-25));
    line-height: 1.2;
  }

  .wf-stat-label {
    font-size: var(--space-1-625);
  }
}

.wf-stats-grid {
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;
  justify-content: space-between;
  gap: var(--space-3) var(--space-2);
}

.wf-stat {
  flex: 1 1 var(--layout-dim-160);
  text-align: center;
  min-width: var(--layout-dim-140);
}

.wf-stat-value {
  font-size: clamp(var(--space-3-25), 3.5vw, var(--space-4));
  font-weight: 600;
  color: var(--muted);
  line-height: 1.15;
}

.wf-stat-label {
  margin: var(--space-1-25) 0 0;
  font-size: var(--space-1-75);
  color: var(--muted-soft);
  line-height: 1.45;
}

.wf-stat-divider {
  flex: 0 0 var(--border-width-hairline);
  min-width: var(--border-width-hairline);
  min-height: var(--space-touch);
  align-self: center;
  background: var(--border-strong);
}

@media (max-width: 640px) {
  .wf-stat-divider {
    display: none;
  }
}

.pro-search {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-1-25);
  max-width: var(--layout-dim-560);
}

.pro-search input[type="search"],
.pro-search input[type="text"] {
  flex: 1 1 var(--layout-dim-220);
  min-width: 0;
  padding: var(--space-1-75) var(--space-2-25);
  border-radius: var(--radius-pill);
  border: var(--border-width-hairline) solid var(--border-strong);
  background: var(--surface);
  color: var(--text);
  font-size: var(--space-2);
  box-shadow: var(--card-shadow-sm);
}

.pro-search input:focus {
  outline: var(--border-width-medium) solid var(--focus-ring);
  outline-offset: var(--border-width-hairline);
  border-color: var(--wf-primary);
}

.pro-search button {
  padding: var(--space-1-75) var(--space-3-5);
  border-radius: var(--radius-pill);
  border: none;
  background: var(--btn-primary-bg);
  color: var(--color-white);
  font-weight: 700;
  font-size: var(--space-2);
  cursor: pointer;
  box-shadow: var(--shadow);
}

.pro-search button:hover {
  background: var(--btn-primary-hover);
}

/* ——— Section chrome ——— */
.pro-section {
  padding: clamp(var(--space-touch), 6vw, var(--space-10)) 0;
}

.pro-section:nth-child(even) {
  background: var(--surface);
  border-top: var(--border-width-hairline) solid var(--border-strong);
  border-bottom: var(--border-width-hairline) solid var(--border-strong);
}

.pro-section-head {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--space-1-5);
  margin-bottom: var(--space-2-5);
}

.pro-section-title {
  font-size: clamp(var(--space-2-75), 2.5vw, var(--space-3-5));
  font-weight: 600;
  margin: 0;
  letter-spacing: -0.02em;
  color: var(--wf-primary);
}

.pro-section-title a {
  color: inherit;
  text-decoration: none;
}

.pro-section-title a:hover {
  color: var(--wf-primary-dark);
}

.pro-link-all {
  font-weight: 600;
  font-size: var(--space-1-75);
  white-space: nowrap;
  color: var(--wf-primary);
  text-decoration: none;
}

.pro-link-all:hover {
  color: var(--wf-primary-dark);
  text-decoration: none;
}

/* ——— Homepage categories: responsive grid tiles (calm, scannable — not pill chips) ——— */
.pro-cat-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(min(100%, 10.5rem), 1fr));
  gap: var(--space-1-25) var(--space-1-5);
  align-items: stretch;
}

.pro-cat-grid a {
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  min-height: 3rem;
  padding: var(--space-1-25) var(--space-1-5);
  background: var(--surface);
  border: var(--border-width-hairline) solid color-mix(in srgb, var(--border-strong) 88%, var(--wf-primary) 10%);
  border-radius: var(--radius-md);
  color: var(--text);
  font-size: var(--space-1-625);
  font-weight: 600;
  text-decoration: none;
  box-shadow: none;
  line-height: 1.3;
  overflow-wrap: anywhere;
  hyphens: auto;
  transition: border-color 0.15s ease, background-color 0.15s ease, box-shadow 0.15s ease;
}

.pro-cat-grid a:hover {
  border-color: color-mix(in srgb, var(--wf-primary) 32%, var(--border-strong));
  background: color-mix(in srgb, var(--surface) 94%, var(--wf-primary) 6%);
  box-shadow: var(--elevation-sm);
  text-decoration: none;
}

.pro-cat-grid a:focus-visible {
  outline: 2px solid color-mix(in srgb, var(--wf-primary) 55%, var(--text));
  outline-offset: 2px;
}

.pro-section--leading-categories {
  padding-block: var(--space-1) var(--space-2);
}

.pro-section--leading-categories .container {
  padding: var(--space-2) var(--space-2-25);
  border-radius: var(--radius-lg);
  border: var(--border-width-hairline) solid color-mix(in srgb, var(--border-strong) 88%, var(--wf-primary) 12%);
  background: color-mix(in srgb, var(--surface) 98%, var(--wf-primary) 2%);
  box-shadow: var(--elevation-sm);
}

/* ——— Three pillars ——— */
.pro-pillars {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-2-5);
}

@media (max-width: 900px) {
  .pro-pillars {
    grid-template-columns: 1fr;
  }
}

.pro-pillar {
  padding: var(--space-2-75);
  background: var(--bg);
  border: var(--border-width-hairline) solid var(--border-strong);
  border-radius: var(--space-1-875);
  transition: border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}

@media (hover: hover) and (pointer: fine) {
  .pro-pillar:hover {
    border-color: color-mix(in srgb, var(--wf-primary) 28%, var(--border-strong));
    box-shadow: var(--elevation-md);
    transform: translateY(-3px);
  }
}

.pro-pillar:focus-within {
  outline: 2px solid color-mix(in srgb, var(--wf-primary) 50%, var(--border-strong));
  outline-offset: 3px;
}

.pro-pillar h3 {
  margin: 0 0 var(--space-1-5);
  font-size: var(--space-2-125);
  font-weight: 800;
}

.pro-pillar ul {
  margin: 0;
  padding-left: var(--space-2-25);
  color: var(--muted);
  line-height: 1.6;
  font-size: var(--space-1-75);
}

/* ——— Pricing strip ——— */
.pro-price-row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(var(--layout-dim-240), 1fr));
  gap: var(--space-1-75);
}

.pro-price-card {
  border: var(--border-width-hairline) solid var(--border);
  border-radius: var(--space-1-5);
  padding: var(--space-2);
  background: var(--surface);
}

.pro-price-card h4 {
  margin: 0 0 var(--space-1);
  font-size: var(--space-1-875);
  font-weight: 800;
}

.pro-price-card .amt {
  font-size: var(--space-2-25);
  font-weight: 800;
  color: var(--wf-primary);
  margin: var(--space-1) 0 0;
}

.pro-price-card .desc {
  font-size: var(--space-1-625);
  color: var(--muted);
  margin: var(--space-0-75) 0 0;
  line-height: 1.5;
}

/* ——— Reviews ——— */
.pro-reviews {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(var(--layout-dim-280), 1fr));
  gap: var(--space-2);
}

.pro-review {
  border: var(--border-width-hairline) solid var(--border);
  border-radius: var(--space-1-5);
  padding: var(--space-2-25);
  background: var(--surface);
}

.pro-stars {
  color: var(--wf-primary);
  font-weight: 800;
  font-size: var(--space-1-75);
  margin-bottom: var(--space-1);
  letter-spacing: 0.04em;
}

.pro-review-meta {
  font-size: var(--space-1-625);
  color: var(--muted);
  margin-bottom: var(--space-1-25);
}

.pro-review q {
  display: block;
  font-style: italic;
  color: var(--text);
  line-height: 1.55;
  font-size: var(--space-1-75);
}

/* ——— Article cards ——— */
.pro-articles {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(var(--layout-dim-240), 1fr));
  gap: var(--space-2);
}

.pro-article {
  border: var(--border-width-hairline) solid var(--border);
  border-radius: var(--space-1-5);
  overflow: hidden;
  background: var(--surface);
  display: flex;
  flex-direction: column;
}

.pro-article-thumb {
  height: var(--layout-dim-120);
  background: var(--article-thumb-gradient);
}

.pro-article-body {
  padding: var(--space-1-75) var(--space-2) var(--space-2);
  flex: 1;
  display: flex;
  flex-direction: column;
}

.pro-article h4 {
  margin: 0 0 var(--space-1);
  font-size: var(--space-1-875);
  font-weight: 800;
  line-height: 1.35;
}

.pro-article h4 a {
  color: inherit;
  text-decoration: none;
}

.pro-article h4 a:hover {
  color: var(--wf-primary);
}

.pro-article p {
  margin: 0;
  font-size: var(--space-1-625);
  color: var(--muted);
  line-height: 1.55;
  flex: 1;
}

.pro-readmore {
  margin-top: var(--space-1-5);
  font-size: var(--space-1-625);
  font-weight: 700;
}

/* ——— Q&A list ——— */
.pro-qa-list {
  display: grid;
  gap: var(--space-1-5);
}

.pro-qa-item {
  border: var(--border-width-hairline) solid var(--border);
  border-radius: var(--space-1-5);
  padding: var(--space-1-75) var(--space-2);
  background: var(--surface);
}

.pro-qa-q {
  font-weight: 750;
  font-size: var(--space-1-875);
  margin: 0 0 var(--space-0-75);
}

.pro-qa-q a {
  color: inherit;
  text-decoration: none;
}

.pro-qa-q a:hover {
  color: var(--wf-primary);
}

.pro-qa-a {
  font-size: var(--space-1-625);
  color: var(--muted);
  line-height: 1.5;
  margin: 0;
}

.pro-qa-meta {
  font-size: var(--space-1-5);
  color: var(--muted);
  margin-top: var(--space-1);
}

/* ——— Footer (single sage-dark band, CTA + links) ——— */
.wf-footer {
  margin-top: 0;
}

.wf-footer-cta {
  background: var(--footer-cta-gradient);
  color: var(--color-white);
  padding: clamp(var(--space-7), 8vw, var(--space-12-5)) 0 clamp(var(--space-5), 6vw, var(--space-7-5));
  text-align: center;
}

.wf-footer-cta-inner {
  max-width: var(--bp-md);
  margin: 0 auto;
}

.wf-footer-cta-title {
  margin: 0;
  font-size: clamp(var(--space-4), 4vw, var(--space-6-5));
  font-weight: 600;
  line-height: 1.12;
  letter-spacing: -0.02em;
}

.wf-footer-cta-lead {
  margin: var(--space-2) 0 0;
  font-size: var(--space-2-25);
  line-height: 1.5;
  font-weight: 400;
  color: var(--footer-cta-lead);
}

.btn-footer-solid {
  margin-top: var(--space-3-5);
  display: inline-flex;
  padding: var(--space-1-5) var(--space-3-5) var(--space-1-75);
  border-radius: var(--radius-pill);
  font-size: var(--space-2);
  font-weight: 700;
  background: var(--color-white);
  color: var(--wf-primary-dark);
  border: var(--border-width-hairline) solid var(--color-white);
  text-decoration: none;
  box-shadow: var(--footer-btn-shadow);
}

.btn-footer-solid:hover {
  background: var(--color-footer-btn-surface);
  border-color: var(--color-footer-btn-surface);
  color: var(--wf-primary-dark);
  text-decoration: none;
}

.wf-footer-main {
  background: var(--footer-main-gradient);
  color: var(--footer-on-dark);
  padding: var(--space-touch) 0 var(--space-4);
  font-size: var(--space-1-625);
  border-top: var(--border-width-hairline) solid var(--footer-on-dark-border);
}

.wf-footer-main .pro-footer-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(var(--layout-dim-200), 1fr));
  gap: var(--space-3-5);
  margin-bottom: var(--space-3-5);
}

.wf-footer-main .pro-footer-col strong {
  display: block;
  color: var(--color-white);
  margin-bottom: var(--space-1-5);
  font-size: var(--space-1-75);
  font-weight: 600;
}

.wf-footer-main .pro-footer-col p {
  color: var(--footer-on-dark-muted);
}

.wf-footer-main .pro-footer-col ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: var(--space-1-25);
}

.wf-footer-main a {
  color: var(--footer-cta-lead);
  text-decoration: none;
}

.wf-footer-main a:hover {
  color: var(--wf-footer-link-hover);
  text-decoration: none;
}

.wf-footer-main .pro-footer-bottom {
  padding-top: var(--space-3);
  border-top: var(--border-width-hairline) solid var(--footer-on-dark-border);
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-1-5) var(--space-2-5);
  justify-content: space-between;
  align-items: center;
  font-size: var(--space-1-5);
  color: var(--footer-on-dark-faint);
}

/* ——— Legacy / inner pages ——— */
.title {
  font-size: var(--space-4-25);
  line-height: 1.15;
  margin: 0 0 var(--space-1-75);
}

.subtitle {
  color: var(--muted);
  font-size: var(--space-2);
  margin: 0 0 var(--space-2-75);
  line-height: 1.6;
}

.pill-row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-1-25);
  margin: var(--space-1-75) 0 0;
}

.pill {
  border: var(--border-width-hairline) solid var(--border);
  background: var(--surface);
  padding: var(--space-1) var(--space-1-5);
  border-radius: var(--border-radius-full);
  color: var(--muted);
  font-weight: 650;
  font-size: var(--space-1-625);
}

.card {
  border: var(--border-width-hairline) solid var(--md-sys-color-outline-variant);
  background: var(--md-sys-color-surface-container-lowest);
  padding: var(--md-sys-spacing-4);
  border-radius: var(--md-sys-shape-corner-medium);
  box-shadow: var(--md-sys-elevation-level1);
  transition:
    box-shadow var(--transition-fast) var(--ease-standard),
    border-color var(--transition-fast) var(--ease-standard),
    transform var(--transition-fast) var(--ease-standard);
}

.card:hover {
  box-shadow: var(--md-sys-elevation-level2);
}

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-1);
  padding: var(--space-1-5) var(--space-2-75);
  min-height: var(--space-touch);
  border-radius: var(--radius-pill);
  border: var(--border-width-hairline) solid var(--border-strong);
  background: var(--surface);
  font-weight: 700;
  font-size: var(--typo-size-body-comfort);
  color: var(--text);
  cursor: pointer;
  text-decoration: none;
  transition:
    background var(--transition-fast) var(--ease-standard),
    border-color var(--transition-fast) var(--ease-standard),
    color var(--transition-fast) var(--ease-standard),
    box-shadow var(--transition-medium) var(--ease-standard),
    transform var(--transition-fast) var(--ease-standard),
    filter var(--transition-fast) var(--ease-standard);
}

.btn:hover {
  border-color: var(--primary-border-hover);
  background: var(--primary-softer-bg);
  text-decoration: none;
  filter: none;
}

.btn-block {
  width: 100%;
  justify-content: center;
}

/* M3 text button (low emphasis) */
.btn.btn--text {
  background: transparent;
  border: none;
  color: var(--color-primary);
  box-shadow: none;
  min-height: var(--space-touch);
  padding-inline: var(--spacing-3);
}

.btn.btn--text:hover {
  background: var(--primary-softer-bg);
  filter: none;
}

.wf-cta-card {
  border: var(--border-width-hairline) solid var(--border-strong);
  border-radius: var(--space-2);
  box-shadow: var(--cta-card-shadow);
}

.wf-cta-actions {
  gap: var(--space-1-5);
}

.wf-cta-actions--single {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  width: 100%;
  margin-top: 0;
}

.wf-cta-actions--single .btn {
  min-width: min(var(--layout-dim-280), 100%);
  justify-content: center;
}

.hero-grid {
  display: grid;
  grid-template-columns: 1.2fr 0.8fr;
  gap: var(--space-2-5);
  align-items: start;
}

@media (max-width: 860px) {
  .hero-grid {
    grid-template-columns: 1fr;
  }
}

.grid-3 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-1-75);
}

@media (max-width: 980px) {
  .grid-3 {
    grid-template-columns: 1fr;
  }
}

.section-title {
  margin: var(--space-3-25) 0 var(--space-1-25);
  font-size: var(--space-2-75);
  font-weight: 800;
}

.list {
  display: grid;
  gap: var(--space-1-25);
}

.row-between {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-1-5);
}

.muted {
  color: var(--muted);
}

.footer {
  padding: var(--space-3) 0;
  color: var(--muted);
  font-size: var(--space-1-625);
}

.form {
  display: grid;
  gap: var(--space-1-25);
}

label {
  font-size: var(--space-1-625);
  color: var(--muted);
  font-weight: 650;
}

input,
textarea,
select {
  width: 100%;
  padding: var(--space-1-25) var(--space-1-5);
  border-radius: var(--radius);
  border: var(--border-width-hairline) solid var(--border-strong);
  background: var(--surface);
  color: var(--text);
  outline: none;
}

input:focus-visible,
textarea:focus-visible,
select:focus-visible {
  outline: var(--border-width-medium) solid var(--focus-ring);
  outline-offset: var(--border-width-hairline);
  border-color: var(--wf-primary);
}

textarea {
  min-height: var(--layout-dim-140);
}

.flash {
  margin: var(--space-1-25) 0 0;
  padding: var(--space-1-5) var(--space-1-75);
  border-radius: var(--space-1-5);
  border: var(--border-width-hairline) solid var(--flash-error-border);
  background: var(--flash-error-bg);
  color: var(--flash-error-text);
  font-size: var(--typo-body-medium-size);
  line-height: var(--typo-body-medium-line);
}

/* Admin / app feedback: default `.flash` = error/danger; modifiers for other tones */
.flash.flash--success {
  border-color: var(--flash-success-border);
  background: var(--flash-success-bg);
  color: var(--flash-success-text);
}

.flash.flash--info {
  border-color: var(--flash-info-border);
  background: var(--flash-info-bg);
  color: var(--flash-info-text);
}

/* Admin: separate flash from following title/content */
.admin-main .container.admin-main__pad .flash {
  margin-bottom: var(--space-2);
}

/* Admin project intake: prominent public client / code display */
.admin-intake-code {
  display: inline-block;
  margin: 0 0 var(--space-1);
  padding: var(--space-0-75) var(--space-1-25);
  font-size: var(--typo-size-title-sm, 1.125rem);
  font-weight: 700;
  letter-spacing: 0.03em;
  font-variant-numeric: tabular-nums;
  border-radius: var(--space-1);
  border: var(--border-width-hairline) solid var(--border-strong);
  background: var(--surface);
  color: var(--text);
}

/* Admin intake: checkbox + label on one row, left-aligned */
.admin-intake-inline-check {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: flex-start;
  gap: var(--space-0-75);
  margin-top: var(--space-0-75);
  flex-wrap: nowrap;
}

.admin-intake-inline-check input[type="checkbox"] {
  flex-shrink: 0;
  margin: 0;
}

.admin-intake-inline-check label {
  margin: 0;
  font-size: var(--typo-body-medium-size, 0.9375rem);
  font-weight: 500;
  line-height: 1.3;
  white-space: nowrap;
  cursor: pointer;
}

@media (max-width: 420px) {
  .admin-intake-inline-check {
    flex-wrap: wrap;
  }

  .admin-intake-inline-check label {
    white-space: normal;
  }
}

.table {
  width: 100%;
  border-collapse: collapse;
}

.table th,
.table td {
  text-align: left;
  padding: var(--space-1-25) var(--space-1);
  border-bottom: var(--border-width-hairline) solid var(--border);
  vertical-align: top;
}

.kbd {
  font-family: var(--font-family-mono);
  border: var(--border-width-hairline) solid var(--border);
  background: var(--bg);
  padding: var(--border-width-thick) var(--space-1);
  border-radius: var(--space-1);
  font-size: var(--space-1-5);
  color: var(--muted);
}

.hero-actions {
  margin-top: var(--space-2-25);
  display: flex;
  gap: var(--space-1-5);
  flex-wrap: wrap;
}

.section-block {
  margin-top: var(--space-4-75);
}

.section-block--lg {
  margin-top: var(--space-6-5);
}

.cta-card {
  padding: var(--space-3);
}

/* Home page: surface container (M3-aligned) */
.home-page {
  background: var(--md-sys-color-surface-container);
}

.visually-hidden {
  position: absolute;
  width: var(--border-width-hairline);
  height: var(--border-width-hairline);
  padding: 0;
  margin: var(--motion-nudge-1);
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* ——— Home: hamburger drawer + full-width main ——— */
.wf-home-layout.home-page {
  margin: 0;
}

.home-page .wf-home-topbar-brand {
  position: relative;
  top: auto;
  left: auto;
  display: inline-flex;
  align-items: center;
  gap: var(--space-1-25);
  text-decoration: none;
  color: var(--color-white);
  font-weight: 800;
  font-size: var(--space-2-25);
  letter-spacing: -0.02em;
  text-shadow: var(--text-shadow-hero-strong);
  flex-shrink: 0;
}

.home-page .wf-home-topbar-brand:hover {
  color: var(--color-white);
  text-decoration: none;
  opacity: 0.95;
}

.home-page .wf-home-topbar-brand .logo {
  box-shadow: var(--elevation-wf-card);
}

.home-page .wf-home-topbar-brand .wf-brand-lockup-product {
  line-height: 1.2;
}

.home-page .wf-home-join-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  min-height: var(--space-touch);
  padding: 0 var(--space-2-25);
  border-radius: var(--space-1-5);
  border: var(--border-width-hairline) solid var(--color-on-inverse-22);
  background: var(--btn-primary-bg);
  color: var(--btn-primary-text) !important;
  font-size: var(--space-1-75);
  font-weight: 700;
  letter-spacing: 0.02em;
  text-decoration: none;
  white-space: nowrap;
  box-shadow: var(--elevation-wf-card-strong);
  transition: background 0.15s, border-color 0.15s, transform 0.15s;
}

.home-page .wf-home-join-btn:hover {
  background: var(--btn-primary-hover);
  border-color: var(--color-on-inverse-35);
  color: var(--btn-primary-text) !important;
  text-decoration: none;
}

.home-page .wf-home-join-btn:focus-visible {
  outline: var(--border-width-medium) solid var(--color-on-inverse-55);
  outline-offset: var(--border-width-medium);
}

.home-page .wf-home-dir-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: var(--space-touch);
  padding: 0 var(--space-1-5);
  border-radius: var(--space-1-5);
  border: var(--border-width-hairline) solid color-mix(in srgb, var(--color-white) 40%, transparent);
  background: color-mix(in srgb, var(--color-black) 25%, transparent);
  color: var(--color-white) !important;
  font-size: var(--space-1-625);
  font-weight: 700;
  text-decoration: none;
  white-space: nowrap;
  text-shadow: 0 1px 2px rgb(0 0 0 / 0.35);
}

.home-page .wf-home-dir-link:hover {
  background: color-mix(in srgb, var(--color-black) 40%, transparent);
  color: var(--color-white) !important;
  text-decoration: none;
}

/* Legacy home hamburger drawer styling removed (no longer used). */

.wf-menu-toggle {
  position: fixed;
  top: var(--space-1-75);
  left: var(--space-1-75);
  z-index: 304;
  width: var(--space-touch);
  height: var(--space-touch);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  border: var(--border-width-hairline) solid var(--border-strong);
  border-radius: var(--space-1-5);
  background: var(--surface);
  color: var(--wf-primary-dark);
  box-shadow: var(--card-shadow-sm);
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s, color 0.15s;
}

.wf-menu-toggle:hover {
  border-color: var(--wf-primary);
  background: var(--primary-softer-bg);
  color: var(--wf-primary);
}

/* Home: burger sits on dark hero — hover uses dark fill + light icon (stays visible) */
.home-page .wf-menu-toggle:hover,
.home-page .wf-menu-toggle:focus-visible {
  background: var(--color-overlay-dark-90);
  border-color: var(--color-on-inverse-35);
  color: var(--color-slate-100);
}

.home-page .wf-menu-toggle:focus-visible {
  outline: var(--border-width-medium) solid var(--color-on-inverse-55);
  outline-offset: var(--border-width-medium);
}

.wf-menu-icon {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  pointer-events: none;
}

.wf-menu-icon--close {
  display: none;
}

.wf-home-layout.wf-menu-drawer-open .wf-menu-icon--hamburger {
  display: none;
}

.wf-home-layout.wf-menu-drawer-open .wf-menu-icon--close {
  display: block;
}

.wf-menu-backdrop {
  position: fixed;
  inset: 0;
  z-index: 299;
  background: var(--color-overlay-purple-45);
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.28s ease;
}

.wf-home-layout.wf-menu-drawer-open .wf-menu-backdrop {
  opacity: 1;
  pointer-events: auto;
}

.wf-menu-backdrop[hidden] {
  display: none !important;
}

.wf-home-sidebar-close {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: var(--space-5-5);
  height: var(--space-5-5);
  padding: 0;
  border: none;
  border-radius: var(--space-1-25);
  background: transparent;
  color: var(--text);
  cursor: pointer;
  transition: background 0.15s ease, color 0.15s ease;
}

.wf-home-sidebar-close:hover {
  background: var(--primary-softer-bg);
  color: var(--wf-primary-dark);
}

.wf-home-sidebar-close:focus-visible {
  outline: var(--border-width-medium) solid var(--focus-ring);
  outline-offset: var(--border-width-medium);
}

.wf-home-sidebar-nav {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}

.wf-home-sidebar-nav--secondary {
  margin-top: var(--space-1-75);
  padding-top: var(--space-2);
  border-top: var(--border-width-hairline) solid var(--border);
}

.wf-home-nav-btn {
  display: block;
  width: 100%;
  box-sizing: border-box;
  padding: var(--space-1-375) var(--space-1-75);
  border-radius: var(--radius);
  font-size: var(--space-1-75);
  font-weight: 650;
  text-align: left;
  text-decoration: none;
  color: var(--text);
  border: var(--border-width-hairline) solid var(--border);
  background: var(--surface);
  transition: border-color 0.15s, background 0.15s, color 0.15s;
}

.wf-home-nav-btn:hover {
  border-color: var(--wf-primary);
  color: var(--wf-primary-dark);
  background: var(--primary-softer-bg);
  text-decoration: none;
}

.wf-home-nav-btn--primary {
  background: var(--btn-primary-bg);
  color: var(--color-white);
  border-color: var(--btn-primary-bg);
}

.wf-home-nav-btn--primary:hover {
  background: var(--btn-primary-hover);
  border-color: var(--btn-primary-hover);
  color: var(--color-white);
}

.wf-home-nav-btn--ghost {
  font-weight: 600;
  border-color: transparent;
  background: transparent;
  padding-left: var(--space-1-25);
  color: var(--muted);
}

.wf-home-nav-btn--ghost:hover {
  background: var(--primary-softer-bg);
  border-color: transparent;
}

.wf-home-nav-btn--my-getpro .wf-home-nav-btn__text {
  display: block;
}

.wf-home-nav-btn--my-getpro .wf-home-nav-btn__sub {
  display: block;
  margin-top: 2px;
  font-size: 0.8125rem;
  font-weight: 500;
  color: var(--muted);
  line-height: 1.3;
}

/* NOTE: Homepage hero now uses `.gp-home-*` selectors in `views/index.ejs`. */

.pro-home-search-field {
  display: flex;
  flex-direction: column;
  gap: var(--space-0-5);
  flex: 1 1 min(0, 12rem);
  min-width: 0;
}

.pro-home-field-label {
  font-size: var(--space-1-5);
  font-weight: 700;
  color: var(--muted);
  letter-spacing: 0.02em;
  line-height: 1.2;
  padding-left: var(--space-0-75);
}

/* NOTE: Legacy home hero/search wrap styles removed.
   Home now uses `.gp-home-*` selectors in `views/index.ejs`. */

.pro-home-dual-search {
  display: flex;
  flex-direction: column;
  gap: var(--space-1-25);
  max-width: min(var(--bp-xl-2), 56rem);
}

.pro-search-form__toolbar-row {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  gap: var(--space-1) var(--space-1-25);
  width: 100%;
  min-width: 0;
}

.pro-search-form__toolbar-row .pro-search-form__fields {
  flex: 1 1 min(0, 100%);
  min-width: 0;
}

.pro-search-form__toolbar-row .pro-home-search-submit {
  flex: 0 0 auto;
}

.pro-home-search-fields {
  flex: 1 1 var(--layout-dim-280);
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-1-25);
  min-width: 0;
}

.pro-ac {
  position: relative;
  flex: 1 1 var(--layout-dim-160);
  min-width: 0;
  border-radius: var(--radius-pill);
  border: var(--border-width-hairline) solid var(--border-strong);
  background: var(--surface);
  box-shadow: var(--card-shadow-sm);
}

.pro-ac:focus-within {
  outline: var(--border-width-medium) solid var(--focus-ring);
  outline-offset: var(--border-width-hairline);
  border-color: var(--wf-primary);
}

.pro-ac-input {
  position: relative;
  z-index: 2;
  width: 100%;
  padding: var(--space-1-75) var(--space-2);
  border: none;
  border-radius: var(--radius-pill);
  background: transparent;
  color: var(--text);
  font-size: var(--space-1-875);
  box-shadow: none;
}

.pro-ac-input:focus {
  outline: none;
}

.pro-ac-watermark {
  position: absolute;
  left: var(--space-2);
  right: var(--space-2);
  top: 50%;
  transform: translateY(-50%);
  z-index: 3;
  pointer-events: none;
  font-size: var(--space-1-875);
  line-height: 1.25;
  color: var(--muted);
  opacity: 0.62;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  transition: opacity 0.2s ease, visibility 0.2s ease;
}

.pro-ac-watermark--off {
  opacity: 0;
  visibility: hidden;
}

.pro-ac-dropdown {
  position: absolute;
  left: 0;
  right: 0;
  top: calc(100% + var(--space-half));
  z-index: 50;
  margin: 0;
  padding: var(--space-0-75) 0;
  list-style: none;
  max-height: var(--layout-dim-240);
  overflow-y: auto;
  border-radius: var(--radius);
  border: var(--border-width-hairline) solid var(--border-strong);
  background: var(--surface);
  box-shadow: var(--shadow);
}

.pro-ac-option {
  padding: var(--space-1-25) var(--space-1-75);
  font-size: var(--space-1-75);
  cursor: pointer;
  color: var(--text);
}

.pro-ac-option:hover,
.pro-ac-option.is-active {
  background: var(--primary-softer-bg);
  color: var(--wf-primary-dark);
}

.pro-ac-msg {
  margin: var(--space-0-75) 0 0;
  padding: 0 var(--space-half);
  font-size: var(--space-1-5);
  color: var(--flash-error-text);
}

.pro-home-search-submit {
  flex: 0 0 auto;
  white-space: nowrap;
}

.pro-home-search-icon {
  flex-shrink: 0;
}

/* Directory: dual field search row */
.pro-search--directory {
  max-width: 100%;
  flex-wrap: wrap;
  align-items: flex-start;
}

.pro-search--directory .pro-ac {
  flex: 1 1 var(--layout-dim-200);
  min-width: 0;
}

.pro-search-dir-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-1);
  padding: var(--space-1-75) var(--space-2-5);
  border-radius: var(--radius-pill);
  border: none;
  background: var(--btn-primary-bg);
  color: var(--color-white);
  font-weight: 700;
  font-size: var(--space-1-875);
  cursor: pointer;
  box-shadow: var(--shadow);
}

.pro-search-dir-btn:hover {
  background: var(--btn-primary-hover);
}

@media (hover: hover) and (pointer: fine) {
  .gp-home-search-card .pro-home-dual-search .pro-ac:hover {
    border-color: color-mix(in srgb, var(--wf-primary) 20%, var(--border-strong));
  }
}

/* Directory two-column layout → single column (match .hero-grid @ 860px; avoids 769–860px two-column overflow) */
@media (max-width: 860px) {
  .hero-grid.pro-directory-layout {
    grid-template-columns: 1fr;
    gap: var(--space-2-25);
  }
}

/* Directory / category: professional listing cards (LTR, photo left — pro.co.il–style) */
.pro-directory-layout {
  grid-template-columns: minmax(var(--layout-dim-220), 0.88fr) minmax(0, 1.22fr);
  gap: var(--space-3);
  min-width: 0;
}

/* Directory layout safety: grid/flex children + page column (directory + category share .hero-grid.pro-directory-layout) */
.hero-grid.pro-directory-layout > *,
.hero-grid.pro-directory-layout .card,
.hero-grid.pro-directory-layout .list {
  min-width: 0;
}

.container:has(.hero-grid.pro-directory-layout),
.gp-home-container:has(.pro-directory-toolbar) {
  min-width: 0;
  max-width: 100%;
  overflow-x: hidden;
  overflow-x: clip;
}

.gp-home-container.directory-page {
  min-width: 0;
  max-width: 100%;
  overflow-x: hidden;
  overflow-x: clip;
}

.directory-page-toolbar {
  min-width: 0;
  max-width: 100%;
  overflow-x: hidden;
  overflow-x: clip;
}

/**
 * Top search + results meta: span the same horizontal bounds as listing cards (full .container width).
 */
.pro-directory-top-band {
  width: 100%;
  max-width: none;
  margin-inline: 0;
  box-sizing: border-box;
  min-width: 0;
}

.pro-directory-top-band .pro-directory-results-helper {
  max-width: none;
  padding-inline: 0;
}

/* Directory: compact filter toolbar (replaces sidebar category button list) */
.pro-directory-toolbar {
  display: flex;
  flex-direction: column;
  gap: var(--space-1-25);
  margin-bottom: var(--space-2);
  padding: var(--space-1-5) var(--space-2);
  border-radius: var(--radius-lg);
  border: var(--border-width-hairline) solid color-mix(in srgb, var(--border-strong) 88%, transparent);
  background: color-mix(in srgb, var(--surface) 97%, var(--wf-primary) 3%);
  box-shadow: var(--elevation-sm);
  box-sizing: border-box;
  width: 100%;
  max-width: 100%;
  min-width: 0;
  overflow: visible;
  scroll-margin-top: calc(52px + env(safe-area-inset-top, 0px));
}

/* Homepage-matched search card: toolbar chrome is redundant (card provides shell). */
.pro-directory-toolbar:has(.gp-home-search-card) {
  padding: 0;
  background: transparent;
  border: none;
  box-shadow: none;
}

.pro-directory-toolbar:has(.gp-home-search-card) .pro-directory-toolbar__meta {
  margin-top: var(--space-1);
}

.pro-directory-toolbar .pro-search-form--directory .pro-ac:focus-within {
  z-index: 5;
}

/* Shared search form inside results toolbar (see partials/pro_search_form.ejs) */
.pro-directory-toolbar .pro-search-form--directory {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: var(--space-1-25);
  width: 100%;
  max-width: 100%;
  min-width: 0;
  margin: 0;
  box-sizing: border-box;
}

.pro-directory-toolbar .pro-search-form__toolbar-row {
  display: flex;
  flex-wrap: nowrap;
  align-items: flex-end;
  gap: var(--space-1) var(--space-1-25);
  width: 100%;
  min-width: 0;
}

.pro-directory-toolbar .pro-search-form--directory .pro-search-form__fields {
  display: flex;
  flex-wrap: nowrap;
  align-items: stretch;
  gap: var(--space-1) var(--space-1-25);
  flex: 1 1 0;
  min-width: 0;
  min-height: 0;
}

/* Same grid rhythm as home hero (621px+) — [service][city][Search] */
@media (min-width: 621px) {
  .pro-directory-toolbar .pro-search-form__toolbar-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) auto;
    align-items: end;
    column-gap: var(--space-1-25);
    row-gap: var(--space-1);
  }

  .pro-directory-toolbar .pro-search-form--directory .pro-search-form__fields {
    display: contents;
  }

  .pro-directory-toolbar .pro-search-form--directory .pro-search-form__field {
    min-width: 0;
  }
}

.pro-directory-toolbar .pro-search-form--directory .pro-search-form__field {
  display: flex;
  flex-direction: column;
  gap: var(--space-0-5);
  flex: 1 1 min(0, 12rem);
  min-width: 0;
}

.pro-directory-toolbar .pro-search-form--directory .pro-search-form__field .pro-ac {
  width: 100%;
}

.pro-directory-toolbar .pro-search-form__toolbar-row .pro-home-search-submit {
  flex: 0 0 auto;
  align-self: end;
}

.pro-directory-toolbar--category {
  margin-bottom: var(--space-2);
}

.pro-directory-toolbar__fields {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  gap: var(--space-1-25) var(--space-1-5);
  width: 100%;
  min-width: 0;
}

.pro-directory-toolbar__field {
  display: flex;
  flex-direction: column;
  gap: var(--space-0-5);
  flex: 1 1 min(0, 12rem);
  min-width: 0;
}

.pro-directory-toolbar__field .pro-ac {
  width: 100%;
}

.pro-directory-toolbar__input-label {
  font-size: var(--space-1-5);
  font-weight: 700;
  color: var(--muted);
  letter-spacing: 0.02em;
  line-height: 1.2;
}

.pro-directory-toolbar__ac {
  flex: 1 1 min(0, 12rem);
  min-width: 0;
}

.pro-directory-toolbar__category {
  flex: 0 1 min(100%, 14rem);
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-0-5);
}

.pro-directory-toolbar__category--grow {
  flex: 1 1 min(0, 20rem);
}

.pro-directory-toolbar__label {
  font-size: var(--space-1-5);
  font-weight: 700;
  color: var(--muted);
  letter-spacing: 0.02em;
}

.pro-directory-toolbar__select,
.pro-directory-toolbar .pro-search-form__select {
  width: 100%;
  max-width: 100%;
  min-height: var(--space-touch);
  padding: var(--space-1) var(--space-1-25);
  border-radius: var(--border-radius-md);
  border: var(--border-width-hairline) solid color-mix(in srgb, var(--border-strong) 90%, transparent);
  background: var(--surface);
  color: var(--text);
  font-size: var(--space-1-75);
  font-weight: 600;
  cursor: pointer;
  box-sizing: border-box;
}

.pro-directory-toolbar__select:hover,
.pro-directory-toolbar .pro-search-form__select:hover {
  border-color: color-mix(in srgb, var(--wf-primary) 28%, var(--border-strong));
}

.pro-directory-toolbar__select:focus,
.pro-directory-toolbar .pro-search-form__select:focus {
  outline: none;
}

.pro-directory-toolbar__select:focus-visible,
.pro-directory-toolbar .pro-search-form__select:focus-visible {
  outline: 2px solid color-mix(in srgb, var(--wf-primary) 55%, var(--text));
  outline-offset: 2px;
}

.pro-directory-toolbar .pro-search-form__category {
  flex: 1 1 min(0, 14rem);
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-0-5);
}

.pro-directory-toolbar__submit {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-0-75);
  min-height: var(--space-touch);
  padding: var(--space-1) var(--space-1-75);
  border-radius: var(--border-radius-full);
  border: var(--border-width-hairline) solid color-mix(in srgb, var(--wf-primary) 35%, var(--border-strong));
  background: color-mix(in srgb, var(--surface) 92%, var(--wf-primary) 8%);
  color: var(--wf-primary);
  font-weight: 700;
  font-size: var(--space-1-625);
  cursor: pointer;
  transition: border-color 0.15s ease, background-color 0.15s ease, box-shadow 0.15s ease;
}

.pro-directory-toolbar__submit:hover {
  border-color: color-mix(in srgb, var(--wf-primary) 50%, var(--border-strong));
  background: color-mix(in srgb, var(--surface) 86%, var(--wf-primary) 14%);
}

.pro-directory-toolbar__submit:focus-visible {
  outline: 2px solid color-mix(in srgb, var(--wf-primary) 55%, var(--text));
  outline-offset: 2px;
}

.pro-directory-toolbar__meta {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--space-1) var(--space-2);
  padding-top: var(--space-0-75);
  border-top: var(--border-width-hairline) solid color-mix(in srgb, var(--border-strong) 75%, transparent);
  font-size: var(--space-1-625);
  line-height: 1.45;
  min-width: 0;
}

.pro-directory-toolbar__count strong {
  font-variant-numeric: tabular-nums;
  color: var(--text);
}

.pro-directory-toolbar__filters {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-0-75) var(--space-1);
  min-width: 0;
  justify-content: flex-end;
  flex: 1 1 auto;
}

.pro-directory-toolbar__chip {
  display: inline-block;
  max-width: 100%;
  padding: var(--space-0-5) var(--space-1);
  border-radius: var(--border-radius-full);
  border: var(--border-width-hairline) solid color-mix(in srgb, var(--wf-primary) 22%, var(--border-strong));
  background: color-mix(in srgb, var(--surface) 94%, var(--wf-primary) 6%);
  color: var(--text);
  font-weight: 600;
  font-size: var(--space-1-5);
  overflow-wrap: anywhere;
}

.pro-directory-toolbar__hint {
  font-size: var(--space-1-5);
}

.pro-directory-main {
  min-width: 0;
  width: 100%;
}

@media (min-width: 621px) {
  .pro-directory-toolbar__fields {
    flex-wrap: nowrap;
  }

  .pro-directory-toolbar__ac {
    flex: 1 1 0;
  }

  .pro-directory-toolbar .pro-search-form--directory .pro-search-form__fields {
    flex-wrap: nowrap;
  }
}

@media (max-width: 520px) {
  .pro-directory-toolbar {
    padding: var(--space-1-25) var(--space-1-5);
  }

  .pro-directory-toolbar__fields {
    flex-direction: column;
    align-items: stretch;
  }

  .pro-directory-toolbar__field {
    flex: 1 1 auto;
    width: 100%;
    max-width: 100%;
  }

  .pro-directory-toolbar__category {
    flex: 1 1 auto;
    width: 100%;
    max-width: 100%;
  }

  .pro-directory-toolbar__submit {
    width: 100%;
    justify-content: center;
  }

  .pro-directory-toolbar .pro-search-form--directory .pro-search-form__field {
    flex: 1 1 auto;
    width: 100%;
    max-width: 100%;
  }

  .pro-directory-toolbar .pro-search-form--directory .pro-home-search-submit {
    width: 100%;
    justify-content: center;
  }
}

.pro-directory-results-wrap {
  container-type: inline-size;
  container-name: dirlist;
  min-width: 0;
  max-width: 100%;
}

.pro-directory-results {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: var(--space-2);
  text-align: left;
  min-width: 0;
  max-width: 100%;
  align-items: stretch;
}

@container dirlist (min-width: 560px) {
  .pro-directory-results {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@container dirlist (min-width: 960px) {
  .pro-directory-results {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

.pro-directory-results-helper {
  margin: 0 0 var(--space-1-5);
  padding: 0 var(--space-0-25);
  font-size: var(--space-1-625);
  line-height: 1.45;
  color: var(--muted);
  max-width: 48rem;
}

.pro-directory-card {
  display: flex;
  flex-direction: column;
  margin: 0;
  min-width: 0;
  min-height: 0;
  height: 100%;
  border-radius: var(--radius-lg);
  border: var(--border-width-hairline) solid color-mix(in srgb, var(--border-strong) 92%, var(--text) 8%);
  background: var(--surface);
  box-shadow: var(--elevation-sm);
  overflow: hidden;
  transition: box-shadow 0.2s ease, border-color 0.2s ease, transform 0.2s ease;
}

@media (hover: hover) and (pointer: fine) {
  .pro-directory-card:hover {
    border-color: color-mix(in srgb, var(--wf-primary) 26%, var(--border-strong));
    box-shadow: var(--elevation-md);
    transform: translateY(-2px);
  }
}

.pro-directory-card:has(.pro-directory-card__link:focus-visible) {
  outline: 2px solid color-mix(in srgb, var(--wf-primary) 65%, var(--text));
  outline-offset: 2px;
}

.pro-directory-card__link {
  display: flex;
  flex-direction: row;
  align-items: flex-start;
  flex: 1 1 auto;
  min-width: 0;
  min-height: 0;
  gap: var(--space-2-25);
  padding: var(--space-2-25) var(--space-2-25) var(--space-2-25) var(--space-2);
  text-decoration: none;
  color: inherit;
  text-align: left;
}

.pro-directory-card__link:hover {
  text-decoration: none;
  color: inherit;
}

.pro-directory-card__link:focus {
  outline: none;
}

.pro-directory-card__link:focus-visible {
  outline: none;
}

.pro-directory-card__media {
  flex: 0 0 auto;
  width: var(--layout-dim-112);
  height: var(--layout-dim-112);
}

.pro-directory-card__avatar {
  width: 100%;
  height: 100%;
  border-radius: var(--border-radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  border: var(--border-width-hairline) solid color-mix(in srgb, var(--border-strong) 75%, transparent);
  background: hsl(var(--avatar-hue, 210), 32%, 93%);
  color: hsl(var(--avatar-hue, 210), 36%, 24%);
  box-shadow: var(--elevation-inset-highlight-strong);
}

.pro-directory-card__initials {
  font-size: clamp(var(--space-3-25), 5vw, var(--space-4));
  font-weight: 800;
  letter-spacing: -0.04em;
  line-height: 1;
}

.pro-directory-card__body {
  flex: 1 1 auto;
  min-width: 0;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 0;
}

.pro-directory-card__header {
  display: block;
  width: 100%;
  margin: 0 0 var(--space-1);
}

.pro-directory-card__title {
  margin: 0;
  font-size: 1.125rem;
  font-weight: 800;
  letter-spacing: -0.02em;
  line-height: var(--typo-title-large-line);
  color: var(--text);
  overflow-wrap: anywhere;
}

/* Whole card is the interactive target (.pro-directory-card__link); no nested CTA control. */
@media (min-width: 768px) {
  .pro-directory-card {
    border-radius: 16px;
    box-shadow: var(--elevation-sm);
  }

  .pro-directory-card__link {
    gap: var(--space-2);
    padding: var(--space-2) var(--space-2);
  }
}

.pro-directory-card__headline {
  margin: 0 0 var(--space-1);
  font-size: var(--space-1-625);
  line-height: 1.5;
  color: var(--muted);
  font-weight: 600;
  overflow-wrap: anywhere;
  word-break: break-word;
}

.pro-directory-card__meta-line {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  min-width: 0;
  max-width: 100%;
  gap: var(--space-0-5) var(--space-1);
  margin: 0 0 var(--space-1-25);
  font-size: var(--space-1-5);
  line-height: 1.45;
  color: var(--muted);
}

.pro-directory-card__meta-line > *:not(:last-child)::after {
  content: "·";
  margin-left: var(--space-1);
  font-weight: 400;
  opacity: 0.45;
}

.pro-directory-card__category {
  font-weight: 600;
  color: color-mix(in srgb, var(--text) 72%, var(--muted) 28%);
}

.pro-directory-card__rating-inline {
  display: inline-flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-0-5) var(--space-0-75);
  min-width: 0;
}

.pro-directory-card__rating-score {
  font-weight: 800;
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.02em;
  color: var(--text);
}

.pro-directory-card__rating-star {
  color: var(--color-amber-600);
  font-size: 1.05em;
  line-height: 1;
}

.pro-directory-card__review-count {
  color: var(--muted);
  font-weight: 600;
  font-size: var(--space-1-5);
}

.pro-directory-card__highlight {
  margin: 0 0 var(--space-1-5);
  padding: var(--space-1-25) var(--space-1-5);
  border-radius: var(--space-1-25);
  border: var(--border-width-hairline) solid color-mix(in srgb, var(--border-strong) 85%, transparent);
  background: color-mix(in srgb, var(--wf-primary) 6%, var(--surface));
  width: 100%;
  box-sizing: border-box;
}

.pro-directory-card__highlight-quote {
  margin: 0 0 var(--space-1);
  font-size: var(--space-1-625);
  line-height: 1.5;
  font-style: italic;
  color: var(--text);
  overflow-wrap: anywhere;
  word-break: break-word;
}

.pro-directory-card__highlight-cap {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: var(--space-0-75) var(--space-1-25);
  font-size: var(--space-1-5);
  color: var(--muted);
}

.pro-directory-card__highlight-author {
  font-weight: 600;
  color: var(--text);
}

.pro-directory-card__highlight-badge {
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  font-size: var(--space-1-25);
  opacity: 0.85;
}

.pro-directory-card__loc {
  font-weight: 600;
  color: color-mix(in srgb, var(--text) 78%, var(--muted) 22%);
  overflow-wrap: anywhere;
}

.pro-directory-card__footer {
  margin: var(--space-1) 0 0;
  padding-top: var(--space-1);
  border-top: var(--border-width-hairline) solid color-mix(in srgb, var(--border-strong) 88%, transparent);
  font-size: var(--space-1-5);
  line-height: 1.4;
  color: var(--muted);
  max-width: 100%;
}

.pro-directory-card__host {
  font-weight: 500;
  word-break: break-word;
  overflow-wrap: anywhere;
}

.pro-directory-card__excerpt {
  margin: 0 0 var(--space-1);
  font-size: var(--space-1-625);
  line-height: 1.55;
  color: var(--text);
  display: -webkit-box;
  -webkit-line-clamp: 4;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* After removing card footer: no extra bottom gap from last block margins */
.pro-directory-card__body > :last-child {
  margin-bottom: 0;
}

.pro-directory-empty {
  min-width: 0;
  max-width: 100%;
  padding: var(--space-2-75) var(--space-2-5);
  text-align: center;
  overflow-wrap: anywhere;
}

.hero-grid.pro-directory-layout > div:last-child .pro-directory-empty--rich {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: min(52vh, var(--space-touch) * 9);
  box-sizing: border-box;
}

.pro-directory-empty--rich {
  border-style: dashed;
  border-color: color-mix(in srgb, var(--border-strong) 80%, transparent);
  background: color-mix(in srgb, var(--surface) 96%, var(--wf-primary) 4%);
}

.pro-directory-empty__inner {
  max-width: var(--layout-dim-420);
  margin: 0 auto;
  padding: var(--space-1) 0;
}

.pro-directory-empty__title {
  margin: 0 0 var(--space-1);
  font-size: var(--typo-title-large-size);
  font-weight: 800;
  letter-spacing: -0.02em;
  line-height: var(--typo-title-large-line);
  color: var(--text);
}

.pro-directory-empty__hint {
  margin: 0 0 var(--space-2-5);
  font-size: var(--typo-body-medium-size);
  line-height: var(--typo-body-large-line);
}

.pro-directory-empty__edit-search {
  margin: calc(-1 * var(--space-1)) 0 var(--space-1-5);
  font-size: var(--typo-body-medium-size);
  line-height: var(--typo-body-large-line);
}

.pro-directory-empty__edit-search-link {
  font-weight: 700;
  color: var(--wf-primary);
  text-decoration: underline;
  text-underline-offset: 0.12em;
}

.pro-directory-empty__suggestions {
  margin: 0 0 var(--space-2);
}

.pro-directory-empty__suggestions-label {
  margin: 0 0 var(--space-0-75);
  font-size: var(--space-1-5);
  font-weight: 700;
  letter-spacing: 0.02em;
}

.pro-directory-empty__suggestion-chips {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-0-5) var(--space-0-75);
}

a.pro-directory-empty__chip {
  display: inline-flex;
  align-items: center;
  padding: var(--space-0-5) var(--space-1-125);
  border-radius: var(--border-radius-full);
  border: var(--border-width-hairline) solid color-mix(in srgb, var(--border-strong) 88%, transparent);
  background: color-mix(in srgb, var(--surface) 96%, var(--wf-primary) 4%);
  color: var(--wf-primary);
  font-size: var(--space-1-5);
  font-weight: 600;
  text-decoration: none;
  line-height: 1.35;
}

a.pro-directory-empty__chip:hover {
  border-color: color-mix(in srgb, var(--wf-primary) 35%, var(--border-strong));
}

.pro-directory-empty__actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: var(--space-1-25);
  margin-top: var(--space-2-5);
  padding-top: var(--space-2);
  border-top: 1px solid color-mix(in srgb, var(--border-strong) 55%, transparent);
}

.pro-directory-empty__summary {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--space-1-5) var(--space-2-5);
  margin: 0 0 var(--space-2-5);
  font-size: var(--typo-body-small-size, var(--space-1-625));
  line-height: 1.45;
}

.pro-directory-empty__summary-item {
  display: inline-flex;
  align-items: baseline;
  gap: var(--space-0-75);
  text-align: left;
}

.pro-directory-empty__summary-k {
  font-weight: 600;
  color: var(--text);
  opacity: 0.72;
}

.pro-directory-empty__summary-v {
  color: var(--text);
}

.pro-directory-empty__callback {
  width: 100%;
  max-width: min(100%, var(--layout-dim-400));
  margin: 0 auto var(--space-1);
  text-align: left;
}

.pro-directory-empty__callback .join-modal-fields {
  margin-bottom: var(--space-1);
}

.pro-directory-empty__callback .join-modal-error {
  text-align: left;
}

.pro-directory-empty__callback-actions {
  justify-content: stretch;
  width: 100%;
}

.pro-directory-empty__callback-actions .btn--primary {
  flex: 1 1 auto;
  min-width: min(100%, var(--space-touch) * 5);
}

.pro-directory-empty__callback-loading {
  margin-bottom: var(--space-2);
  width: 100%;
  max-width: min(100%, var(--layout-dim-400));
  margin-left: auto;
  margin-right: auto;
}

.pro-directory-empty__callback-success.state-block--success {
  padding: var(--space-2-5) var(--space-1-5) var(--space-2);
  text-align: center;
  border-radius: var(--radius);
}

.pro-directory-empty__callback-success-title {
  margin: 0 0 var(--space-1-25);
  font-size: 1.2rem;
  font-weight: 800;
  letter-spacing: -0.02em;
  color: var(--text);
  line-height: 1.25;
}

.pro-directory-empty__callback-success-lead {
  margin: 0 0 var(--space-1);
  font-size: var(--typo-body-large-size, var(--space-2));
  font-weight: 600;
  color: var(--text);
  line-height: var(--typo-body-large-line, 1.45);
}

.pro-directory-empty__callback-success-muted {
  margin: 0;
  font-size: var(--typo-body-medium-size, var(--space-1-75));
  line-height: 1.5;
}

.pro-directory-empty__callback-success-text {
  margin: 0;
  font-size: var(--typo-body-large-size, var(--space-2));
  font-weight: 600;
  color: var(--text);
  line-height: var(--typo-body-large-line, 1.45);
}

@media (max-width: 520px) {
  .pro-directory-card__link {
    gap: var(--space-1-75);
    padding: var(--space-1-75);
  }

  .pro-directory-card__media {
    width: var(--space-11);
    height: var(--space-11);
  }

  .pro-directory-card__initials {
    font-size: var(--space-2-75);
  }

}

/* ——— Company directory profile (LTR, English) ——— */
.pro-company-profile__shell {
  background: var(--gradient-home-ambient),
    var(--bg);
  padding-bottom: var(--space-7);
}

.pro-company-profile {
  text-align: left;
  direction: ltr;
  padding: var(--space-1-5) 0 0;
}

.pro-company-profile__inner {
  max-width: var(--bp-max-lg);
}

.pro-company-profile__hero-panel.card {
  margin-bottom: var(--space-2-75);
  padding: var(--space-2-75) var(--space-2-75) var(--space-3);
  border-radius: var(--space-2);
  border-color: var(--border-strong);
  box-shadow: var(--cta-card-shadow);
  background: var(--gradient-surface-to-primary-soft);
}

.pro-company-profile__breadcrumb {
  font-size: var(--space-1-625);
  color: var(--muted);
  margin: 0 0 var(--space-2-5);
  line-height: 1.5;
}

.pro-company-profile__breadcrumb a {
  color: var(--wf-primary);
  font-weight: 700;
  text-decoration: none;
}

.pro-company-profile__breadcrumb a:hover {
  text-decoration: underline;
}

.pro-company-profile__bc-sep {
  margin: 0 var(--space-0-75);
  opacity: 0.55;
}

.pro-company-profile__bc-current {
  color: var(--text);
  font-weight: 700;
}

.pro-company-profile__hero {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--space-2-5);
}

.pro-company-profile__title-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-start;
  gap: var(--space-2) var(--space-2-5);
  width: 100%;
}

.pro-company-profile__title-block {
  flex: 1;
  min-width: min(100%, var(--layout-dim-220));
}

.pro-company-profile__logo-wrap {
  flex-shrink: 0;
  align-self: flex-start;
}

.pro-company-profile__logo {
  display: block;
  width: var(--space-11);
  height: var(--space-11);
  object-fit: contain;
  border-radius: var(--space-1-75);
  background: var(--surface);
  border: var(--border-width-hairline) solid var(--border-strong);
  box-shadow: var(--elevation-slate-md);
}

@media (max-width: 520px) {
  .pro-company-profile__title-row {
    flex-direction: row;
  }
  .pro-company-profile__logo {
    width: var(--space-9);
    height: var(--space-9);
  }
}

.pro-company-profile__badges {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-1);
  margin-bottom: var(--space-1-25);
}

.pro-company-profile__pill {
  display: inline-flex;
  align-items: center;
  padding: var(--space-half) var(--space-1-25);
  border-radius: var(--border-radius-full);
  font-size: var(--space-1-5);
  font-weight: 800;
  background: var(--primary-soft-bg);
  color: var(--text);
  border: var(--border-width-hairline) solid color-mix(in srgb, var(--wf-primary) 25%, var(--border-strong));
}

.pro-company-profile__pill--muted {
  background: var(--surface);
  font-weight: 700;
  opacity: 0.9;
}

.pro-company-profile__title {
  margin: 0 0 var(--space-1);
  font-size: clamp(1.6rem, 4vw, 2.1rem);
  font-weight: 900;
  letter-spacing: -0.03em;
  line-height: 1.15;
  color: var(--text);
}

.pro-company-profile__headline {
  margin: 0 0 var(--space-1);
  font-size: 1.05rem;
  line-height: 1.5;
  color: var(--muted);
  font-weight: 600;
  max-width: 62ch;
}

.pro-company-profile__meta-line {
  margin: 0;
  font-size: var(--space-1-75);
  color: var(--text);
}

.pro-company-profile__hero-contact {
  margin-top: var(--space-2);
  padding: var(--space-1-75) var(--space-2);
  border-radius: var(--space-1-5);
  border: var(--border-width-hairline) solid color-mix(in srgb, var(--wf-primary) 22%, var(--border-strong));
  background: var(--color-primary-glow-mix-12);
  display: flex;
  flex-direction: column;
  gap: var(--space-1-75);
  max-width: 22rem;
}

.pro-company-profile__hero-contact-row {
  display: flex;
  flex-direction: column;
  flex-wrap: wrap;
  gap: var(--space-half);
  align-items: flex-start;
}

.pro-company-profile__hero-contact-label {
  font-size: var(--space-1-375);
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.pro-company-profile__hero-contact-phone {
  font-size: 1.35rem;
  font-weight: 900;
  letter-spacing: -0.02em;
  color: var(--text);
  text-decoration: none;
}

.pro-company-profile__hero-contact-phone:hover {
  color: var(--wf-primary-dark);
  text-decoration: underline;
}

.pro-company-profile__hero-contact-wa {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  font-size: var(--space-1-875);
  font-weight: 800;
  color: var(--wf-primary-dark);
  text-decoration: none;
}

.pro-company-profile__hero-contact-wa:hover {
  text-decoration: underline;
}

.pro-company-profile__score-card {
  flex: 0 0 auto;
  min-width: var(--layout-dim-160);
  padding: var(--space-1-75) var(--space-2-25);
  border-radius: var(--space-1-75);
  border: var(--border-width-hairline) solid var(--border-strong);
  background: var(--surface);
  box-shadow: var(--elevation-slate-lg);
  text-align: center;
}

.pro-company-profile__score-num {
  font-size: 2rem;
  font-weight: 900;
  letter-spacing: -0.04em;
  line-height: 1;
}

.pro-company-profile__score-star {
  color: var(--color-amber-600);
  font-size: 1.25rem;
  margin: var(--space-half) 0 var(--space-0-75);
}

.pro-company-profile__score-count {
  font-size: var(--space-1-625);
  font-weight: 700;
  color: var(--muted);
}

.pro-company-profile__grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) var(--layout-dim-320);
  gap: var(--space-3-5);
  align-items: start;
}

@media (max-width: 900px) {
  .pro-company-profile__grid {
    grid-template-columns: 1fr;
    display: flex;
    flex-direction: column;
  }

  /* Contact / call-to-action first on narrow viewports — conversion path before long copy */
  .pro-company-profile__aside {
    order: -1;
  }
}

/* Profile: reduce aside chrome on phones (sticky bar + hero already surface CTAs) */
@media (max-width: 720px) {
  .page-company-profile .pro-company-profile__aside .pro-company-profile__qr-block,
  .page-company-profile .pro-company-profile__aside .pro-company-profile__support {
    display: none;
  }

  .page-company-profile .pro-company-profile__aside-title {
    font-size: 1.05rem;
  }
}

.pro-company-profile .btn {
  min-height: var(--space-touch);
  box-sizing: border-box;
}

.pro-company-profile__cta.btn--primary {
  width: 100%;
  justify-content: center;
  font-size: var(--space-1-875);
  font-weight: 800;
}

.pro-company-profile__support-actions .btn {
  min-height: var(--space-touch);
}

.pro-company-profile__section {
  margin-bottom: var(--space-3-5);
}

.pro-company-profile__h2 {
  margin: 0 0 var(--space-1-5);
  font-size: 1.15rem;
  font-weight: 900;
  letter-spacing: -0.02em;
  color: var(--text);
}

.pro-company-profile__dist {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  max-width: var(--layout-dim-420);
}

.pro-company-profile__dist-row {
  display: grid;
  grid-template-columns: var(--space-4-5) 1fr var(--space-5);
  align-items: center;
  gap: var(--space-1-25);
  font-size: var(--space-1-625);
}

.pro-company-profile__dist-label {
  font-weight: 800;
  color: var(--muted);
}

.pro-company-profile__dist-bar {
  height: var(--space-1);
  border-radius: var(--border-radius-full);
  background: color-mix(in srgb, var(--border-strong) 70%, transparent);
  overflow: hidden;
}

.pro-company-profile__dist-fill {
  display: block;
  height: 100%;
  border-radius: var(--border-radius-full);
  background: var(--gradient-pro-dist-fill);
}

.pro-company-profile__dist-pct {
  text-align: right;
  font-variant-numeric: tabular-nums;
  font-weight: 700;
  color: var(--muted);
}

.pro-company-profile__reviews {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.pro-company-profile__review {
  padding: var(--space-1-75) var(--space-2);
  border-radius: var(--space-1-5);
  border: var(--border-width-hairline) solid var(--border-strong);
  background: var(--surface);
}

.pro-company-profile__review-top {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: var(--space-1) var(--space-1-75);
  margin-bottom: var(--space-1);
  font-size: var(--space-1-625);
}

.pro-company-profile__review-score {
  font-weight: 900;
  color: var(--text);
}

.pro-company-profile__review-author {
  font-weight: 800;
  color: var(--text);
}

.pro-company-profile__review-date {
  margin-left: auto;
  color: var(--muted);
  font-weight: 600;
}

.pro-company-profile__review-body {
  margin: 0;
  font-size: var(--space-1-875);
  line-height: 1.55;
  color: var(--text);
}

.pro-company-profile__prose {
  font-size: var(--space-1-875);
  line-height: 1.65;
  color: var(--text);
  white-space: pre-wrap;
}

.pro-company-profile__preline {
  white-space: pre-line;
}

.pro-company-profile__bullets {
  margin: 0;
  padding-left: 1.2em;
  font-size: var(--space-1-875);
  line-height: 1.65;
  color: var(--text);
}

.pro-company-profile__bullets li {
  margin-bottom: var(--space-0-75);
}

.pro-company-profile__gallery-intro {
  margin: var(--motion-nudge-4) 0 var(--space-1-5);
  font-size: var(--space-1-625);
}

.pro-company-carousel {
  position: relative;
  margin: 0;
}

.pro-company-carousel__viewport {
  overflow: hidden;
  border-radius: var(--space-1-5);
  border: var(--border-width-hairline) solid var(--border-strong);
  background: var(--surface);
  cursor: grab;
  touch-action: pan-y;
}

.pro-company-carousel__viewport.is-dragging {
  cursor: grabbing;
}

.pro-company-carousel[data-company-carousel]:focus {
  outline: var(--border-width-medium) solid color-mix(in srgb, var(--wf-primary) 55%, var(--border-strong));
  outline-offset: var(--border-width-thick);
}

.pro-company-carousel__slide--logo .pro-company-carousel__img-wrap {
  background: color-mix(in srgb, var(--surface) 92%, var(--border-strong));
}

.pro-company-carousel__slide--logo .pro-company-carousel__img-wrap img {
  object-fit: contain;
  padding: clamp(var(--space-1-5), 3vw, var(--space-3-5));
}

.pro-company-profile__dir-link-block {
  margin-top: var(--space-2);
  padding-top: var(--space-2);
  border-top: var(--border-width-hairline) solid var(--border);
}

.pro-company-profile__dir-link-block .pro-company-profile__mini-url a {
  word-break: break-all;
}

.pro-company-carousel__track {
  display: flex;
  transition: transform 0.38s cubic-bezier(0.25, 0.8, 0.25, 1);
  will-change: transform;
}

.pro-company-carousel__slide {
  flex: 0 0 100%;
  margin: 0;
  min-width: 0;
}

.pro-company-carousel__img-wrap {
  position: relative;
  width: 100%;
  aspect-ratio: 3 / 2;
  background: color-mix(in srgb, var(--border-strong) 35%, var(--surface));
}

.pro-company-carousel__img-wrap img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  user-select: none;
}

.pro-company-carousel__cap {
  margin: 0;
  padding: var(--space-1-25) var(--space-1-75) var(--space-1-75);
  font-size: var(--space-1-625);
  font-weight: 600;
  color: var(--muted);
  line-height: 1.45;
}

.pro-company-carousel__btn {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 2;
  width: var(--space-5);
  height: var(--space-5);
  border-radius: var(--border-radius-full);
  border: var(--border-width-hairline) solid var(--border-strong);
  background: color-mix(in srgb, var(--surface) 92%, transparent);
  color: var(--text);
  font-size: var(--space-2-75);
  line-height: 1;
  font-weight: 700;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: var(--elevation-slate-xl);
  backdrop-filter: blur(var(--space-1));
}

.pro-company-carousel__btn:hover {
  background: var(--surface);
}

.pro-company-carousel__btn--prev {
  left: var(--space-1-25);
}

.pro-company-carousel__btn--next {
  right: var(--space-1-25);
}

.pro-company-carousel__dots {
  display: flex;
  justify-content: center;
  gap: var(--space-1);
  margin-top: var(--space-1-5);
  flex-wrap: wrap;
}

.pro-company-carousel__dot {
  width: var(--space-1);
  height: var(--space-1);
  padding: 0;
  border: 0;
  border-radius: var(--border-radius-full);
  background: color-mix(in srgb, var(--muted) 45%, var(--border-strong));
  cursor: pointer;
}

.pro-company-carousel__dot[aria-current="true"] {
  background: var(--wf-primary);
  transform: scale(1.15);
}

.pro-company-profile__qr-block {
  margin-top: var(--space-2);
  padding-top: var(--space-2);
  border-top: var(--border-width-hairline) solid var(--border);
}

.pro-company-profile__qr-heading {
  font-weight: 900;
  font-size: var(--space-1-75);
  margin-bottom: var(--space-1-25);
}

.pro-company-profile__qr-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-1-5);
}

@media (max-width: 360px) {
  .pro-company-profile__qr-grid {
    grid-template-columns: 1fr;
  }
}

.pro-company-profile__qr-cell {
  text-align: center;
}

.pro-company-profile__qr-label {
  font-size: var(--space-1-375);
  margin-bottom: var(--space-0-75);
}

.pro-company-profile__qr-img {
  display: inline-block;
  vertical-align: top;
  max-width: 100%;
  height: auto;
  border-radius: var(--space-1-25);
  border: var(--border-width-hairline) solid var(--border-strong);
  background: var(--color-surface);
}

.pro-company-profile__qr-single {
  text-align: center;
}

.pro-company-profile__qr-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-1-25);
  margin-top: var(--space-1-5);
  justify-content: center;
}

.pro-company-profile__qr-actions .btn.btn--text {
  /* QR copy is a compact utility action; keep `btn--text` from increasing row height. */
  min-height: 0;
  padding: 0 var(--space-half);
  border: none;
  box-shadow: none;
}

.pro-company-profile__qr-copy {
  font-weight: 800;
}

.pro-company-profile__qr-copy-status {
  font-size: var(--space-1-5);
}

.pro-company-profile__qr-caption {
  margin: var(--space-1) 0 0;
  font-size: var(--space-1-5);
  line-height: 1.45;
}

.pro-company-profile__lead-card {
  padding: var(--space-2-25);
}

.pro-company-profile__aside-title {
  margin: 0 0 var(--space-1-75);
  font-size: 1.05rem;
  font-weight: 900;
}

.pro-company-profile__contact-list {
  list-style: none;
  margin: 0 0 var(--space-2);
  padding: 0;
  font-size: var(--space-1-75);
  line-height: 1.55;
}

.pro-company-profile__contact-list li {
  margin-bottom: var(--space-1-5);
}

.pro-company-profile__contact-list a {
  word-break: break-word;
  overflow-wrap: anywhere;
  hyphens: auto;
}

.pro-company-profile__contact-list .btn.btn--text {
  /* Keep contact rows compact; only use semantic button for focus/hover consistency. */
  min-height: 0;
  padding: 0 var(--space-half);
  border: none;
  box-shadow: none;
}

.pro-company-profile__cta {
  width: 100%;
  justify-content: center;
  margin-bottom: var(--space-2);
}

.pro-company-profile__mini-hint {
  margin: 0 0 var(--space-half);
  font-size: var(--space-1-5);
}

.pro-company-profile__mini-url {
  margin: 0 0 var(--space-1-75);
  font-size: var(--space-1-5);
  word-break: break-all;
  font-weight: 600;
  color: var(--text);
}

.pro-company-profile__mini-url .btn.btn--text {
  /* Keep the mini-site URL link compact and aligned with the surrounding info rows. */
  min-height: 0;
  padding: 0 var(--space-half);
  border: none;
  box-shadow: none;
}

.pro-company-profile__support {
  margin-top: var(--space-2-25);
  padding-top: var(--space-2);
  border-top: var(--border-width-hairline) solid var(--border);
}

.pro-company-profile__support-title {
  font-weight: 900;
  margin-bottom: var(--space-0-75);
  font-size: var(--space-1-75);
}

.pro-company-profile__support-intro {
  line-height: 1.6;
  margin: 0 0 var(--space-half);
  font-size: var(--space-1-625);
}

.pro-company-profile__support-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-1);
  margin-top: var(--space-1-5);
}

.pro-company-profile__support-pill {
  flex: 1 1 5.5rem;
  min-width: min(100%, 5.5rem);
  justify-content: center;
  text-align: center;
  font-weight: 800;
  margin-top: 0 !important;
}

.pro-company-profile__support-call {
  display: inline-flex;
  margin-top: var(--space-1-5);
  width: 100%;
  justify-content: center;
  text-align: center;
  font-weight: 800;
}

/* ——— Join professionals (multi-step) ——— */
.join-page {
  background: var(--bg);
}

.join-top-brand {
  position: fixed;
  top: max(var(--space-1-75), env(safe-area-inset-top, 0));
  left: max(var(--space-1-75), env(safe-area-inset-left, 0));
  z-index: 200;
  display: inline-flex;
  align-items: center;
  gap: var(--space-1-25);
  text-decoration: none;
  color: var(--text);
  font-weight: 800;
  font-size: var(--space-2-25);
  letter-spacing: -0.02em;
}

.join-top-brand:hover {
  color: var(--wf-primary);
  text-decoration: none;
}

.join-top-brand .wf-brand-lockup-product {
  line-height: 1.2;
}

.join-hero {
  padding: clamp(var(--space-7), 10vw, var(--space-11)) 0 clamp(var(--space-5), 6vw, var(--space-9));
  background: var(--gradient-primary-vertical);
  border-bottom: var(--border-width-hairline) solid var(--border-strong);
}

.join-hero-inner {
  max-width: var(--bp-2xl);
}

.join-hero h1 {
  margin: 0 0 var(--space-2);
  font-size: clamp(var(--space-3-5), 4vw, var(--space-5));
  font-weight: 800;
  letter-spacing: -0.03em;
  line-height: 1.15;
  color: var(--text);
}

.join-lead {
  margin: 0 0 var(--space-3-5);
  font-size: var(--space-2-25);
  line-height: 1.55;
  color: var(--muted);
}

.join-tiles {
  margin: 0 0 var(--space-4);
}

.join-tiles-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(var(--layout-dim-240), 1fr));
  gap: var(--space-2-5);
}

.join-tile {
  position: relative;
  background: var(--surface);
  border: var(--border-width-hairline) solid var(--border-strong);
  border-radius: var(--space-1-75);
  padding: var(--space-2-75) var(--space-2-5) var(--space-2-5);
  box-shadow: var(--card-shadow-sm);
  transition:
    transform 0.35s cubic-bezier(0.34, 1.3, 0.64, 1),
    border-color 0.25s ease,
    box-shadow 0.35s ease;
  overflow: hidden;
}

.join-tile:hover,
.join-tile:focus-within {
  transform: translateY(var(--motion-nudge-6)) scale(1.03);
  border-color: var(--primary-border-hover);
  box-shadow:
    var(--elevation-cta-stack);
  z-index: 2;
}

@media (prefers-reduced-motion: reduce) {
  .join-tile:hover,
  .join-tile:focus-within {
    transform: none;
  }
}

.join-tile-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: var(--space-touch);
  height: var(--space-touch);
  margin-bottom: var(--space-1-75);
  border-radius: var(--space-1-5);
  background: var(--primary-softer-bg);
  color: var(--wf-primary);
}

.join-tile-title {
  margin: 0 0 var(--space-1);
  font-size: var(--space-2-125);
  font-weight: 800;
  letter-spacing: -0.02em;
  color: var(--text);
  line-height: 1.25;
}

.join-tile-text {
  margin: 0;
  font-size: var(--space-1-75);
  line-height: 1.55;
  color: var(--muted);
}

.join-tile-more {
  margin: var(--space-1-5) 0 0;
  font-size: var(--space-1-625);
  line-height: 1.5;
  color: var(--muted-soft);
  max-height: 0;
  opacity: 0;
  overflow: hidden;
  transition: max-height 0.4s ease, opacity 0.35s ease, margin 0.35s ease;
}

.join-tile:hover .join-tile-more,
.join-tile:focus-within .join-tile-more {
  max-height: var(--layout-dim-120);
  opacity: 1;
  margin-top: var(--space-1-75);
}

@media (prefers-reduced-motion: reduce) {
  .join-tile-more {
    max-height: none;
    opacity: 1;
    margin-top: var(--space-1-25);
    transition: none;
  }
}

.join-get-started {
  padding: var(--space-2) var(--space-4);
  font-size: var(--space-2-125);
}

.join-wizard {
  padding: clamp(var(--space-4), 5vw, var(--space-7)) 0 var(--space-10);
}

.join-wizard--hidden {
  display: none;
}

.join-hero--hidden {
  display: none;
}

.join-wizard-inner {
  max-width: var(--layout-dim-520);
  margin: 0 auto;
  overflow: visible;
}

.join-progress {
  font-size: var(--space-1-625);
  font-weight: 600;
  color: var(--wf-primary);
  margin-bottom: var(--space-1);
}

.join-progress-track {
  height: var(--space-half);
  border-radius: var(--space-half);
  background: var(--border-strong);
  margin-bottom: var(--space-3-5);
  overflow: hidden;
}

.join-progress-fill {
  height: 100%;
  width: 33.33%;
  background: var(--wf-primary);
  border-radius: var(--space-half);
  transition: width 0.25s ease;
}

.join-step-panel {
  background: var(--surface);
  border: var(--border-width-hairline) solid var(--border-strong);
  border-radius: var(--radius);
  padding: var(--space-3) var(--space-2-75) var(--space-3-5);
  box-shadow: var(--card-shadow-sm);
}

.join-step-panel h2 {
  margin: 0 0 var(--space-1);
  font-size: var(--space-2-5);
  font-weight: 800;
}

/* Join wizard: step intro lines use shared .form-step__subtitle; scoped rhythm below */
.join-wizard .form-step__subtitle {
  margin: var(--space-1) 0 var(--space-2-5);
  font-size: var(--space-1-75);
  line-height: 1.45;
  color: var(--muted);
}

.join-field {
  margin-bottom: var(--space-2);
}

.join-field label {
  display: block;
  font-size: var(--space-1-625);
  font-weight: 600;
  margin-bottom: var(--space-0-75);
  color: var(--text);
}

.join-field .join-plain-input {
  width: 100%;
  padding: var(--space-1-5) var(--space-1-75);
  border-radius: var(--radius);
  border: var(--border-width-hairline) solid var(--border-strong);
  font-size: var(--space-2);
  background: var(--surface);
  color: var(--text);
}

.join-field .join-plain-input:focus {
  outline: var(--border-width-medium) solid var(--focus-ring);
  border-color: var(--wf-primary);
}

.join-field--ac .pro-ac {
  width: 100%;
  max-width: 100%;
}

.join-field--ac .pro-ac-input,
.join-field--ac .pro-ac-watermark {
  font-size: var(--space-2);
}

.join-fieldset {
  border: none;
  margin: 0;
  padding: 0;
}

.join-fieldset legend {
  font-size: var(--space-1-875);
  font-weight: 700;
  margin-bottom: var(--space-1-75);
  color: var(--text);
}

.join-radio-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-1-25);
}

.join-radio-list label {
  display: flex;
  align-items: flex-start;
  gap: var(--space-1-25);
  font-weight: 500;
  font-size: var(--space-1-875);
  cursor: pointer;
  line-height: 1.4;
}

.join-radio-list input {
  margin-top: var(--border-width-thick);
  flex-shrink: 0;
}

.join-wizard-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-1-5);
  margin-top: var(--space-3);
}

.join-wizard-actions--split {
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-1-5);
}

.join-wizard-actions-right {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-1-5);
  align-items: center;
  justify-content: flex-end;
}

/* Join modals: shell in public/m3-modal.css */
.join-modal-layer .join-modal.m3-modal--join {
  max-width: var(--layout-dim-400);
  width: 100%;
  padding: 0;
  border: none;
  box-shadow: var(--elevation-2);
  background: var(--color-surface);
  text-align: left;
}

.join-modal-layer .join-modal.join-modal--wide {
  max-width: min(96vw, var(--layout-dim-440));
}

.join-modal-layer .join-modal__scroll {
  text-align: left;
}

.join-modal-title {
  margin: 0;
  font-size: var(--typo-title-large-size);
  font-weight: 800;
  letter-spacing: -0.02em;
  color: var(--text);
}

.join-modal-text {
  margin: 0 0 var(--space-3);
  font-size: var(--typo-body-medium-size);
  line-height: var(--typo-body-large-line);
  color: var(--muted);
}

.join-modal-panel--form .join-modal-text {
  margin-bottom: var(--space-2);
}

.join-modal-fields {
  margin-bottom: var(--space-1);
}

.join-modal-label {
  display: block;
  font-size: var(--space-1-625);
  font-weight: 600;
  margin-bottom: var(--space-0-75);
  color: var(--text);
  text-align: left;
}

.join-modal-input.join-plain-input {
  margin-bottom: var(--space-1-75);
}

.join-modal-error {
  margin: 0 0 var(--space-1-5);
  font-size: var(--space-1-625);
  color: var(--flash-error-text);
  text-align: center;
}

.join-modal-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-1-5);
  justify-content: center;
}

.join-modal-actions--split {
  justify-content: space-between;
  width: 100%;
  flex-wrap: wrap;
}

.join-modal-panel--form {
  text-align: left;
}

body.join-modal-open {
  overflow: hidden;
}

.join-step-thanks-message {
  margin: 0;
  font-size: clamp(var(--space-2-25), 2.2vw, var(--space-3));
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1.4;
  color: var(--text);
}

.join-wizard-inner--thanks {
  padding-top: var(--space-1);
}

.join-thanks-animation {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-1);
  margin-bottom: var(--space-2-75);
}

.join-thanks-success-ring {
  width: var(--space-9-5);
  height: var(--space-9-5);
  border-radius: 50%;
  background: var(--gradient-join-thanks-ring);
  display: flex;
  align-items: center;
  justify-content: center;
  animation: joinThanksPop 0.55s cubic-bezier(0.34, 1.45, 0.64, 1) forwards;
}

.join-thanks-check {
  width: var(--space-5-25);
  height: var(--space-5-25);
  color: var(--wf-primary);
}

.join-thanks-check-path {
  stroke-dasharray: 40;
  stroke-dashoffset: 40;
  animation: joinThanksDraw 0.55s ease forwards 0.18s;
}

.join-thanks-verify-scene {
  position: relative;
  width: var(--layout-dim-128);
  height: var(--layout-dim-96);
  margin: 0 auto;
  color: var(--muted-soft);
}

.join-thanks-doc {
  width: var(--space-6-5);
  height: var(--space-8-5);
  margin: 0 auto;
  display: block;
  opacity: 0.9;
}

.join-thanks-magnifier {
  position: absolute;
  width: var(--space-5-75);
  height: var(--space-5-75);
  right: var(--space-0-75);
  top: var(--space-1-75);
  color: var(--wf-primary);
  animation: joinThanksMagnify 2.4s ease-in-out 0.65s infinite alternate;
  filter: var(--filter-drop-shadow-sm);
}

@keyframes joinThanksPop {
  from {
    transform: scale(0.35);
    opacity: 0;
  }
  to {
    transform: scale(1);
    opacity: 1;
  }
}

@keyframes joinThanksDraw {
  to {
    stroke-dashoffset: 0;
  }
}

@keyframes joinThanksMagnify {
  from {
    transform: translate(0, 0) rotate(-6deg);
  }
  to {
    transform: translate(var(--motion-nudge-14), var(--space-1-25)) rotate(10deg);
  }
}

.join-wizard-frame .join-step-thanks {
  text-align: center;
  padding: var(--space-2) 0 var(--space-1);
}

#join-panels .join-step-panel {
  overflow: visible;
}

.join-wizard-inner .join-pro-ac {
  width: 100%;
}

/* —— Multi-tenant themes (Zambia default, Israel) —— */
.tenant-zm {
  --tenant-accent: var(--palette-tenant-green);
  --tenant-hero-tint: var(--tenant-theme-zm-hero-tint);
  --tenant-chip-bg: var(--tenant-theme-zm-chip-bg);
}

.tenant-il {
  --tenant-accent: var(--palette-tenant-blue);
  --tenant-hero-tint: var(--tenant-theme-il-hero-tint);
  --tenant-chip-bg: var(--tenant-theme-il-chip-bg);
}

.tenant-bw {
  --tenant-accent: var(--palette-tenant-sky);
  --tenant-hero-tint: var(--tenant-theme-bw-hero-tint);
  --tenant-chip-bg: var(--tenant-theme-bw-chip-bg);
}

.tenant-zw {
  --tenant-accent: var(--palette-tenant-forest);
  --tenant-hero-tint: var(--tenant-theme-zw-hero-tint);
  --tenant-chip-bg: var(--tenant-theme-zw-chip-bg);
}

.tenant-za {
  --tenant-accent: var(--palette-tenant-teal);
  --tenant-hero-tint: var(--tenant-theme-za-hero-tint);
  --tenant-chip-bg: var(--tenant-theme-za-chip-bg);
}

.tenant-na {
  --tenant-accent: var(--palette-tenant-navy);
  --tenant-hero-tint: var(--tenant-theme-na-hero-tint);
  --tenant-chip-bg: var(--tenant-theme-na-chip-bg);
}

.tenant-global {
  --tenant-accent: var(--palette-tenant-violet);
  --tenant-hero-tint: var(--tenant-theme-global-hero-tint);
  --tenant-chip-bg: var(--tenant-theme-global-chip-bg);
}

.tenant-demo {
  --tenant-accent: var(--palette-tenant-cyan);
  --tenant-hero-tint: var(--tenant-theme-demo-hero-tint);
  --tenant-chip-bg: var(--tenant-theme-demo-chip-bg);
}

.home-page.tenant-zm .wf-hero,
.join-page.tenant-zm .join-hero {
  background: var(--gradient-tenant-hero);
}

.home-page.tenant-il .wf-hero,
.join-page.tenant-il .join-hero {
  background: var(--gradient-tenant-hero);
}

.home-page.tenant-bw .wf-hero,
.join-page.tenant-bw .join-hero,
.home-page.tenant-zw .wf-hero,
.join-page.tenant-zw .join-hero,
.home-page.tenant-za .wf-hero,
.join-page.tenant-za .join-hero,
.home-page.tenant-na .wf-hero,
.join-page.tenant-na .join-hero,
.home-page.tenant-demo .wf-hero,
.join-page.tenant-demo .join-hero,
.home-page.tenant-global .wf-hero,
.join-page.tenant-global .join-hero {
  background: var(--gradient-tenant-hero);
}

.tenant-il .wf-home-join {
  border-color: var(--tenant-theme-il-border);
}

.tenant-il .wf-home-join:hover {
  border-color: var(--tenant-accent);
  color: var(--tenant-accent);
}

.wf-home-tenant-flag {
  font-size: var(--space-3-25);
  line-height: 1;
  min-height: var(--space-touch);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  user-select: none;
  flex-shrink: 0;
}

/* Region trigger in sticky app bar (light surface): readable text/icon — not hero “inverse” colors */
.app-top-app-bar .wf-home-region-trigger {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-1);
  flex-shrink: 0;
  min-height: var(--space-touch);
  padding: 0 var(--space-1-75);
  border-radius: var(--space-1-5);
  border: var(--border-width-hairline) solid var(--border-strong);
  background: var(--surface);
  color: var(--text);
  font-size: var(--space-1-75);
  font-weight: 700;
  letter-spacing: 0.02em;
  cursor: pointer;
  box-shadow: var(--elevation-sm);
  transition: background 0.15s, border-color 0.15s, color 0.15s;
}

.app-top-app-bar .wf-home-region-trigger:hover {
  background: color-mix(in srgb, var(--wf-primary) 8%, var(--surface));
  border-color: color-mix(in srgb, var(--wf-primary) 35%, var(--border-strong));
}

.app-top-app-bar .wf-home-region-trigger:focus-visible {
  outline: var(--border-width-medium) solid var(--wf-primary);
  outline-offset: var(--border-width-medium);
}

.app-top-app-bar .wf-home-region-trigger .wf-home-region-globe {
  flex-shrink: 0;
  color: var(--wf-primary);
}

.app-top-app-bar .wf-home-region-trigger .wf-home-region-label {
  max-width: 10rem;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.wf-home-layout.wf-menu-drawer-open .wf-home-region-trigger {
  visibility: hidden;
  pointer-events: none;
}

.wf-home-layout.wf-menu-drawer-open .wf-region-strip--home {
  visibility: hidden;
  pointer-events: none;
}

/* Region pills: country name + flag (home hero overlay) */
.wf-region-strip {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-0-75) var(--space-1);
  max-width: 100%;
}

.wf-region-strip__pill {
  display: inline-flex;
  align-items: center;
  gap: var(--space-0-75);
  padding: var(--space-0-625) var(--space-1-375);
  border-radius: var(--border-radius-full);
  font-size: var(--space-1-5);
  font-weight: 700;
  text-decoration: none;
  border: var(--border-width-hairline) solid var(--color-on-inverse-22);
  background: var(--color-on-inverse-12);
  color: var(--color-on-primary);
  text-shadow: var(--text-shadow-pill);
  white-space: nowrap;
  transition: background 0.15s, border-color 0.15s;
}

.wf-region-strip__pill:hover {
  background: var(--color-on-inverse-pill);
  color: var(--color-on-primary);
  text-decoration: none;
}

.wf-region-strip__pill.is-current {
  border-color: var(--color-on-inverse-55);
  background: var(--color-on-inverse-pill);
}

.wf-region-strip__name {
  letter-spacing: 0.02em;
}

.wf-region-strip__flag {
  font-size: 1.15em;
  line-height: 1;
}

.wf-region-strip--join .wf-region-strip__pill,
.wf-region-strip--nav .wf-region-strip__pill {
  border-color: var(--border-strong);
  background: var(--bg-elevated);
  color: var(--text);
  text-shadow: none;
}

.wf-region-strip--join .wf-region-strip__pill:hover,
.wf-region-strip--nav .wf-region-strip__pill:hover {
  border-color: var(--wf-primary);
  color: var(--wf-primary-dark);
  background: var(--primary-softer-bg);
  text-decoration: none;
}

.wf-region-strip--join .wf-region-strip__pill.is-current,
.wf-region-strip--nav .wf-region-strip__pill.is-current {
  border-color: var(--tenant-accent, var(--wf-primary));
  background: var(--primary-softer-bg);
}

.join-top-admin-link {
  margin-left: auto;
  font-size: var(--space-1-625);
  font-weight: 700;
  color: var(--muted);
  text-decoration: none;
  white-space: nowrap;
}

.join-top-admin-link:hover {
  color: var(--wf-primary);
  text-decoration: none;
}

.join-topbar-row {
  position: fixed;
  top: max(var(--space-1-75), env(safe-area-inset-top, 0));
  left: max(var(--space-1-75), env(safe-area-inset-left, 0));
  z-index: 200;
  display: flex;
  flex-direction: row;
  align-items: flex-start;
  flex-wrap: wrap;
  gap: var(--space-1-25) var(--space-1-75);
  max-width: min(96vw - var(--space-3), var(--bp-xl));
}

.join-topbar-row .join-top-brand {
  position: relative;
  top: auto;
  left: auto;
}

/* Region picker overlay: M3 shell (.wf-region-m3) in m3-modal.css */
.wf-region-m3.m3-modal-overlay {
  z-index: 10003;
}

.wf-region-m3 .m3-modal.wf-region-sheet {
  border-color: var(--border-strong);
  box-shadow: var(--elevation-2);
}

.wf-region-sheet__body {
  padding: 0;
}

/* Title + close in one flex row (replaces absolute × over heading). */
.wf-region-sheet__header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--modal-space-2);
  min-height: var(--modal-header-min-height);
}

.wf-region-close-x {
  flex: 0 0 auto;
  width: var(--modal-close-btn-size);
  min-width: var(--modal-close-btn-size);
  height: var(--modal-close-btn-size);
  min-height: var(--modal-close-btn-size);
  margin: 0;
  padding: 0;
  border: none;
  border-radius: var(--space-1-25);
  background: transparent;
  color: var(--muted);
  font-size: 1.5rem;
  line-height: 1;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: background 0.15s, color 0.15s;
}

.wf-region-close-x:hover {
  background: var(--bg-elevated);
  color: var(--text);
}

.wf-region-title {
  margin: 0;
  font-size: 1.15rem;
  font-weight: 800;
  flex: 1;
  min-width: 0;
}

.wf-region-title--picker {
  padding-right: 0;
}

.wf-region-actions {
  display: flex;
  flex-direction: column;
  gap: var(--space-1-25);
}

.wf-region-actions--grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-1-25);
}

@media (max-width: 380px) {
  .wf-region-actions--grid {
    grid-template-columns: 1fr;
  }
}

.wf-region-btn-label {
  flex: 1;
  min-width: 0;
  text-align: start;
}

.wf-region-btn-flag {
  flex-shrink: 0;
  font-size: 1.35rem;
  line-height: 1;
  margin-inline-start: var(--space-1-25);
}

.wf-region-btn {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  min-height: var(--space-touch);
  padding: 0 var(--space-1-75);
  border-radius: var(--space-1-5);
  font-weight: 700;
  letter-spacing: 0.02em;
  text-decoration: none;
  border: var(--border-width-hairline) solid var(--border-strong);
  background: var(--bg-elevated);
  color: var(--text);
  transition: background 0.15s, border-color 0.15s;
  box-sizing: border-box;
}

.wf-region-btn:hover {
  border-color: var(--wf-primary);
  background: var(--primary-softer-bg);
  color: var(--text);
  text-decoration: none;
}

.wf-region-btn--il {
  font-size: 1.15rem;
}

.wf-region-btn--disabled {
  opacity: 0.5;
  cursor: not-allowed;
  pointer-events: none;
}

/* Israel — coming soon */
.coming-soon-il {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-3);
  background: var(--gradient-coming-soon-il);
}

.coming-soon-il-inner {
  max-width: var(--layout-dim-420);
  text-align: center;
}

.coming-soon-il-icon-wrap {
  margin: 0 auto var(--space-2-5);
  width: var(--layout-dim-120);
  height: var(--layout-dim-120);
  color: var(--tenant-accent, var(--palette-tenant-blue));
}

.coming-soon-il-crane {
  width: 100%;
  height: 100%;
}

.coming-soon-il-hook {
  animation: comingSoonSwing 2.2s ease-in-out infinite;
  transform-origin: var(--space-7-5) var(--space-2-25);
}

.coming-soon-il-block {
  animation: comingSoonBob 2.2s ease-in-out infinite;
  transform-origin: center bottom;
}

@keyframes comingSoonSwing {
  0%,
  100% {
    transform: rotate(-4deg);
  }
  50% {
    transform: rotate(5deg);
  }
}

@keyframes comingSoonBob {
  0%,
  100% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(var(--motion-nudge-6));
  }
}

.coming-soon-il-title {
  margin: 0 0 var(--space-1-25);
  font-size: 1.75rem;
  font-weight: 900;
}

.coming-soon-il-lead {
  margin: 0 0 var(--space-1);
  line-height: 1.55;
  font-size: 1.05rem;
}

.coming-soon-il-en {
  margin: 0 0 var(--space-2-5);
  font-size: 0.95rem;
}

.coming-soon-il-actions .btn {
  min-height: var(--space-touch);
}

/* ——— Public header: Search / Categories / List (compact, M3-inspired) ——— */
.wf-nav--public.wf-nav--minimal {
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-1) var(--space-2);
}

.wf-nav-public {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-0-5) var(--space-1);
  margin: 0;
  padding: 0;
  list-style: none;
}

.wf-nav-public__link {
  display: inline-flex;
  align-items: center;
  min-height: var(--space-touch);
  padding: var(--space-0-5) var(--space-1-25);
  border-radius: var(--radius-pill);
  font-size: var(--space-1-75);
  font-weight: 600;
  color: var(--muted);
  text-decoration: none;
  transition: background-color 0.15s ease, color 0.15s ease;
}

.wf-nav-public__link:hover {
  color: var(--wf-primary);
  background: color-mix(in srgb, var(--wf-primary) 8%, var(--surface));
}

.wf-nav-public__cta {
  font-weight: 700;
  font-size: var(--space-1-875);
  color: var(--wf-primary);
  text-decoration: none;
  white-space: nowrap;
}

.wf-nav-public__cta:hover {
  color: var(--wf-primary-dark);
  text-decoration: underline;
}

/* ——— Material 3 navigation layout (desktop rail + mobile drawer) ——— */
:root {
  --app-nav-rail-width: 240px;
  --app-top-app-bar-height: 56px;
}

.app-top-app-bar {
  position: sticky;
  top: 0;
  z-index: 40;
  background: var(--surface);
  border-bottom: var(--border-width-hairline) solid color-mix(in srgb, var(--border-strong) 78%, transparent);
  min-height: var(--app-top-app-bar-height);
  display: flex;
  align-items: center;
}

.app-top-app-bar__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-1-25);
  flex-wrap: nowrap;
  min-width: 0;
  width: 100%;
}

.app-top-app-bar__brand-block {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: flex-start;
  gap: var(--space-0-5);
  min-width: 0;
  flex: 1 1 0;
  text-align: left;
}

.app-top-app-bar__brand-row {
  display: flex;
  align-items: center;
  min-width: 0;
}

.app-top-app-bar__actions {
  display: flex;
  align-items: center;
  gap: var(--space-1);
  flex-shrink: 0;
  margin-left: auto;
  align-self: center;
}

.app-top-app-bar .wf-nav-brand {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  color: var(--text);
  font-weight: 800;
  font-size: var(--space-2-25);
  letter-spacing: -0.02em;
}

.app-top-app-bar .wf-nav-brand:hover {
  color: var(--wf-primary);
  text-decoration: none;
}

.app-top-app-bar__join {
  flex-shrink: 0;
  min-height: 40px;
  padding: 0 var(--space-1-25);
  font-size: var(--space-1-625);
  font-weight: 700;
  white-space: nowrap;
}

@media (max-width: 380px) {
  .app-top-app-bar__join {
    padding: 0 var(--space-1);
    font-size: var(--space-1-5);
  }
}

.app-top-app-bar__tagline {
  margin: 0;
  font-size: var(--space-1-5);
  font-weight: 600;
  color: var(--muted);
  line-height: 1.2;
  max-width: min(100%, 22rem);
  text-align: left;
}

@media (max-width: 720px) {
  .app-top-app-bar__tagline {
    font-size: var(--space-1-375);
    max-width: calc(100vw - 8rem);
    line-height: 1.25;
  }
}

.app-menu-toggle {
  border: var(--border-width-hairline) solid var(--border-strong);
  background: var(--surface);
  color: var(--wf-primary-dark);
  box-shadow: var(--card-shadow-sm);
  width: var(--space-touch);
  height: var(--space-touch);
  padding: 0;
  border-radius: var(--space-1-25);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
}

.app-menu-icon {
  width: 22px;
  height: 22px;
  pointer-events: none;
}

.app-menu-icon--close {
  display: none;
}

.app-nav-drawer-open .app-menu-icon--hamburger {
  display: none;
}

.app-nav-drawer-open .app-menu-icon--close {
  display: block;
}

/* Desktop rail */
.app-nav-rail {
  display: none;
}

.app-nav-drawer-backdrop,
.app-nav-backdrop {
  position: fixed;
  inset: 0;
  z-index: 59;
  background: var(--color-overlay-purple-45);
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.28s ease;
}

.app-nav-drawer {
  position: fixed;
  top: var(--app-top-app-bar-height);
  right: 0;
  left: auto;
  bottom: 0;
  width: min(var(--app-nav-rail-width), 92vw);
  z-index: 60;
  background: var(--surface);
  border-left: var(--border-width-hairline) solid var(--border-strong);
  border-right: none;
  padding: var(--space-1-5) var(--space-2) var(--space-3-5);
  overflow-y: auto;
  transform: translateX(102%);
  transition: transform 0.28s ease;
}

.app-nav-drawer-top {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  margin: var(--motion-nudge-4) 0 var(--space-half);
}

.app-nav-drawer-close {
  /* reuse existing close button dimensions */
}

.app-nav-drawer-body {
  padding-top: var(--space-0-75);
}

.app-nav-drawer-open .app-nav-drawer {
  transform: translateX(0);
}

.app-nav-drawer-open .app-nav-backdrop {
  opacity: 1;
  pointer-events: auto;
}

/* Wide screens: no persistent side rail — same overlay drawer + menu control as narrow view (M3 navigation drawer). */
@media (min-width: 900px) {
  .app-nav-rail {
    display: none !important;
  }

  .app-layout {
    padding-left: 0;
  }
}

@media (max-width: 560px) {
  .wf-header-wrap--minimal .nav.wf-nav--public.wf-nav--minimal {
    flex-direction: column;
    align-items: stretch;
  }

  .wf-nav--public .brand {
    order: 0;
  }

  .wf-nav-actions--minimal {
    width: 100%;
    order: 1;
  }

  .wf-nav-public {
    justify-content: center;
    width: 100%;
    order: 2;
  }

  .wf-nav-public__cta {
    display: block;
    text-align: center;
    padding: var(--space-1-25) var(--space-1-75);
    border-radius: var(--radius-pill);
    border: var(--border-width-hairline) solid color-mix(in srgb, var(--wf-primary) 35%, var(--border-strong));
    background: color-mix(in srgb, var(--wf-primary) 8%, var(--surface));
    white-space: normal;
    text-decoration: none;
  }

  .wf-nav-public__cta:hover {
    text-decoration: none;
  }
}

/* ——— Homepage: mobile-first — hide marketing-heavy blocks on small screens ——— */
@media (max-width: 767px) {
  .home-page__desktop-only {
    display: none !important;
  }

  .home-m3-cta--help {
    padding: var(--space-2) 0 var(--space-1);
  }

  .home-m3-cta__actions {
    flex-direction: column;
    align-items: stretch;
  }

  .home-m3-cta__btn {
    width: 100%;
    justify-content: center;
    min-height: var(--space-touch);
  }

  /* Leading categories: slightly tighter grid on narrow viewports */
  .home-page .pro-cat-grid {
    grid-template-columns: repeat(auto-fill, minmax(min(100%, 9rem), 1fr));
    gap: var(--space-1) var(--space-1-25);
  }

  .home-page .pro-cat-grid a {
    min-height: var(--space-touch);
    padding: var(--space-1-25) var(--space-1-5);
    font-size: var(--space-1-625);
    line-height: 1.25;
  }
}

.home-m3-cta--help {
  padding: var(--space-2-5) 0;
}

.home-m3-cta__card {
  padding: var(--space-2-25) var(--space-2-5);
  border-radius: var(--radius-lg);
  border: var(--border-width-hairline) solid color-mix(in srgb, var(--border-strong) 88%, transparent);
  background: color-mix(in srgb, var(--surface) 97%, var(--wf-primary) 3%);
  box-shadow: var(--elevation-sm);
  transition: box-shadow 0.2s ease, border-color 0.2s ease, transform 0.2s ease;
}

@media (hover: hover) and (pointer: fine) {
  .home-m3-cta__card:hover {
    border-color: color-mix(in srgb, var(--wf-primary) 22%, var(--border-strong));
    box-shadow: var(--elevation-md);
    transform: translateY(-1px);
  }
}

.home-m3-cta__card:focus-within {
  outline: 2px solid color-mix(in srgb, var(--wf-primary) 55%, var(--text));
  outline-offset: 2px;
}

.home-m3-cta__title {
  margin: 0 0 var(--space-1);
  font-size: 1.1rem;
  font-weight: 800;
  letter-spacing: -0.02em;
  color: var(--text);
}

.home-m3-cta__text {
  margin: 0 0 var(--space-1-5);
  font-size: var(--space-1-75);
  line-height: 1.45;
}

.home-m3-cta__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-1) var(--space-1-25);
  align-items: center;
}

@media (min-width: 768px) {
  .home-m3-cta__actions {
    flex-direction: row;
  }

  .home-m3-cta__btn {
    width: auto;
  }
}

/* ——— Directory: calmer mobile meta row ——— */
@media (max-width: 520px) {
  .pro-directory-toolbar__meta {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--space-0-75);
  }
}

/* ——— Footer: lighter mobile CTA band ——— */
@media (max-width: 767px) {
  .wf-footer-cta-inner {
    padding: var(--space-2-5) 0;
  }

  .wf-footer-cta-title {
    font-size: 1.2rem;
  }

  .wf-footer-cta-lead {
    font-size: var(--space-1-75);
  }
}

/* ——— Company: less chrome on small screens ——— */
@media (max-width: 480px) {
  .pro-company-profile__pill--muted {
    display: none;
  }
}

/* ——— Mobile public UI v2: overflow, directory cards, join, company carousel ——— */
html {
  overflow-x: clip;
}

body.home-page,
body.join-page,
body[class*="tenant-"] {
  overflow-x: clip;
}

.gp-home-container.directory-page {
  padding-left: max(var(--admin-main-pad-x), env(safe-area-inset-left, 0px));
  padding-right: max(var(--admin-main-pad-x), env(safe-area-inset-right, 0px));
}

.pro-directory-main {
  padding-bottom: var(--space-2);
}

@media (max-width: 430px) {
  .pro-directory-toolbar {
    padding: var(--space-1-25) var(--space-1-5);
    gap: var(--space-1);
  }

  .pro-directory-toolbar__count {
    font-size: var(--space-1-625);
  }

  .pro-directory-card__link {
    flex-direction: column;
    align-items: stretch;
    gap: var(--space-1-5);
    padding: var(--space-2) var(--space-1-75);
  }

  .pro-directory-card__media {
    width: var(--space-10);
    height: var(--space-10);
    align-self: flex-start;
  }

  .pro-directory-card__title {
    font-size: 1.05rem;
  }
}

.pro-directory-empty--rich {
  min-width: 0;
  max-width: 100%;
}

.pro-directory-empty__actions {
  flex-wrap: wrap;
  gap: var(--space-1);
}

.pro-directory-empty__actions .btn {
  min-height: var(--space-touch);
}

@media (max-width: 520px) {
  .join-tiles-grid {
    grid-template-columns: 1fr;
    gap: var(--space-2);
  }

  .join-tile {
    padding: var(--space-2) var(--space-1-75);
  }

  .join-hero {
    padding-left: max(var(--space-2), env(safe-area-inset-left, 0px));
    padding-right: max(var(--space-2), env(safe-area-inset-right, 0px));
  }

  .join-topbar-row {
    padding-inline: max(var(--space-1-5), env(safe-area-inset-left, 0px))
      max(var(--space-1-5), env(safe-area-inset-right, 0px));
  }
}

.pro-company-profile__inner {
  padding-inline: max(var(--space-1-5), env(safe-area-inset-left, 0px))
    max(var(--space-1-5), env(safe-area-inset-right, 0px));
}

@media (max-width: 520px) {
  .pro-company-profile__hero {
    gap: var(--space-1-5);
  }

  .pro-company-profile__score-card {
    width: 100%;
    min-width: 0;
  }

  .pro-company-carousel__img-wrap {
    aspect-ratio: 16 / 10;
    max-height: min(52vw, 280px);
  }

  .pro-company-profile__aside.card {
    padding: var(--space-2) var(--space-1-75);
  }

  .pro-company-profile__lead-card .form input,
  .pro-company-profile__lead-card .form textarea {
    min-height: var(--space-touch);
    font-size: 16px;
  }

  .pro-company-profile__lead-card textarea {
    min-height: 7rem;
  }
}

.wf-footer-main .container {
  padding-inline: max(var(--space-1-5), env(safe-area-inset-left, 0px))
    max(var(--space-1-5), env(safe-area-inset-right, 0px));
}

/* Mobile: jump back to shared search after scrolling results */
.pro-refine-search-fab {
  display: none;
}

@media (max-width: 720px) {
  .directory-page .pro-refine-search-fab {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    position: fixed;
    right: max(var(--space-1-25), env(safe-area-inset-right, 0px));
    bottom: max(var(--space-1-25), env(safe-area-inset-bottom, 0px));
    z-index: 25;
    min-height: 40px;
    padding: 0 var(--space-1-5);
    margin: 0;
    border: none;
    border-radius: var(--border-radius-full);
    box-shadow: var(--elevation-md);
    background: color-mix(in srgb, var(--wf-primary) 92%, var(--surface));
    color: var(--on-primary, #fff);
    font-weight: 700;
    font-size: var(--space-1-5);
    letter-spacing: 0.01em;
    cursor: pointer;
    -webkit-tap-highlight-color: transparent;
  }

  .directory-page .pro-refine-search-fab:focus-visible {
    outline: 2px solid color-mix(in srgb, var(--wf-primary) 55%, var(--text));
    outline-offset: 3px;
  }

  .directory-page .pro-refine-search-fab__text {
    white-space: nowrap;
  }
}

#directory-toolbar,
#category-toolbar {
  scroll-margin-top: calc(52px + env(safe-area-inset-top, 0px));
}

/* Company profile: sticky quick contact (mobile) */
.pro-company-sticky-cta {
  display: none;
}

@media (max-width: 720px) {
  .pro-company-sticky-cta {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: var(--space-0-75);
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 35;
    padding: var(--space-1) max(var(--space-1-25), env(safe-area-inset-left, 0px))
      max(var(--space-1-25), env(safe-area-inset-bottom, 0px)) max(var(--space-1-25), env(safe-area-inset-right, 0px));
    background: color-mix(in srgb, var(--surface) 94%, var(--wf-primary) 6%);
    border-top: var(--border-width-hairline) solid color-mix(in srgb, var(--border-strong) 78%, transparent);
    box-shadow: 0 -6px 20px color-mix(in srgb, var(--text) 10%, transparent);
  }

  .pro-company-sticky-cta__btn {
    flex: 1 1 auto;
    min-width: min(100%, 10rem);
    max-width: 14rem;
    justify-content: center;
  }

  .pro-company-sticky-cta__btn--call {
    max-width: min(100%, 18rem);
    font-size: clamp(0.85rem, 2.8vw, 0.95rem);
    font-weight: 800;
    line-height: 1.2;
    text-align: center;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  body:has(.pro-company-sticky-cta) {
    /* PERF NOTE: Include safe-area so content clears the home indicator when sticky CTA uses env(safe-area-inset-bottom). */
    padding-bottom: calc(76px + env(safe-area-inset-bottom, 0px));
  }
}

/* ——— UI Demo / Pattern Library ——— */
.ui-demo-container {
  padding-top: var(--space-3);
  padding-bottom: var(--space-4);
}

.ui-demo-hero {
  margin-bottom: var(--space-3);
}

.ui-demo-section {
  margin-bottom: var(--space-4);
}

.ui-demo-section-title {
  font-size: var(--space-2);
  font-weight: 900;
  margin: 0 0 var(--space-2) 0;
  letter-spacing: -0.02em;
}

.ui-demo-card-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: var(--space-2);
}

@media (min-width: 900px) {
  .ui-demo-card-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.ui-demo-spacer {
  height: var(--space-1-5);
}

.ui-demo-note {
  margin-top: var(--space-1);
  line-height: 1.5;
}

.ui-demo-token-grid {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-1-25);
}

.ui-demo-token {
  display: inline-flex;
  align-items: center;
  gap: var(--space-0-75);
  padding: var(--space-0-75) var(--space-1-25);
  border-radius: var(--radius);
  border: var(--border-width-hairline) solid color-mix(in srgb, var(--border-strong) 80%, transparent);
  background: color-mix(in srgb, var(--surface) 92%, var(--wf-primary) 8%);
}

.ui-demo-swatch {
  width: 16px;
  height: 16px;
  border-radius: 4px;
  border: var(--border-width-hairline) solid var(--border-strong);
  display: inline-block;
}

.ui-demo-swatch--primary {
  background: var(--wf-primary);
}

.ui-demo-swatch--surface {
  background: var(--surface);
}

.ui-demo-swatch--outline {
  background: var(--border-strong);
}

.ui-demo-swatch--error {
  background: var(--flash-error-text);
}

.ui-demo-swatch--radius {
  background: var(--radius-pill);
}

.ui-demo-swatch--focus {
  background: var(--color-focus);
}

.ui-demo-migration-table {
  display: flex;
  flex-direction: column;
  gap: var(--space-1-25);
}

.ui-demo-migration-row {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: var(--space-0-75);
}

.ui-demo-migration-cell code {
  font-size: var(--space-1-5);
}

.ui-demo-migration-arrow {
  color: var(--muted);
  font-weight: 800;
}

/* —— Company personnel portal (drawer from right; scoped to .company-portal-page / .company-portal) —— */
.company-portal-header {
  position: sticky;
  top: 0;
  z-index: 55;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-1-5);
  padding: var(--space-1-25) var(--space-2);
  background: var(--surface);
  border-bottom: var(--border-width-hairline) solid var(--border-strong);
}

.company-portal-header__brand {
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
}

.company-portal-header__title {
  font-weight: 700;
  font-size: var(--typo-size-title-sm, 1.125rem);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.company-portal-header__context {
  margin: 0;
  font-size: 0.8125rem;
  line-height: 1.3;
}

.admin-portal-users__hint {
  margin: var(--space-2) 0 0;
  max-width: 42rem;
}

.company-portal-menu-btn {
  flex-shrink: 0;
  min-height: var(--space-touch);
  padding: 0 var(--space-1-5);
  border-radius: var(--radius);
  border: var(--border-width-hairline) solid var(--border-strong);
  background: var(--surface);
  font-weight: 600;
  cursor: pointer;
}

.company-portal-wrap {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  background: var(--surface);
}

.company-portal-backdrop {
  position: fixed;
  inset: 0;
  z-index: 58;
  background: var(--color-overlay-purple-45);
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.25s ease;
}

.company-portal-drawer-open .company-portal-backdrop {
  opacity: 1;
  pointer-events: auto;
}

.company-portal-drawer {
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  width: min(280px, 88vw);
  z-index: 60;
  background: var(--surface);
  border-left: var(--border-width-hairline) solid var(--border-strong);
  transform: translateX(102%);
  transition: transform 0.28s ease;
  display: flex;
  flex-direction: column;
  padding: var(--space-1-5) var(--space-2) var(--space-3);
  box-sizing: border-box;
}

.company-portal-drawer-open .company-portal-drawer {
  transform: translateX(0);
}

.company-portal-drawer__top {
  display: flex;
  justify-content: flex-end;
  margin-bottom: var(--space-1);
}

.company-portal-drawer__close {
  border: none;
  background: transparent;
  font-size: 1.5rem;
  line-height: 1;
  cursor: pointer;
  padding: var(--space-0-75);
  color: var(--text);
}

.company-portal-drawer__nav {
  display: flex;
  flex-direction: column;
  gap: var(--space-0-5);
}

.company-portal-drawer__link {
  display: block;
  padding: var(--space-1) var(--space-1-25);
  border-radius: var(--radius);
  font-weight: 600;
  color: var(--text);
  text-decoration: none;
}

.company-portal-drawer__link:hover,
.company-portal-drawer__link:focus-visible {
  background: color-mix(in srgb, var(--wf-primary) 8%, var(--surface));
  outline: none;
}

.company-portal-drawer__link--active {
  background: color-mix(in srgb, var(--wf-primary) 12%, var(--surface));
}

.company-portal-drawer__logout {
  margin-top: var(--space-2);
  padding-top: var(--space-1);
  border-top: var(--border-width-hairline) solid var(--border-strong);
}

.company-portal-content {
  flex: 1;
  min-width: 0;
  padding: var(--space-2) var(--space-2) var(--space-4);
  box-sizing: border-box;
}

.company-portal-main,
.company-portal-page .company-portal-main {
  max-width: 42rem;
}

.company-portal-page-title {
  margin: 0 0 var(--space-1);
  font-size: var(--typo-size-title-md, 1.35rem);
  font-weight: 800;
}

.company-portal-intro {
  margin: 0 0 var(--space-2);
}

.company-portal-back {
  margin: 0 0 var(--space-1-5);
}

.company-lead-cards {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-1-25);
}

.company-lead-card {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: var(--space-0-5);
  padding: var(--space-1-5) var(--space-1-75);
  text-decoration: none;
  color: inherit;
}

.company-lead-card__code {
  font-weight: 800;
  font-size: 1.05rem;
}

.company-lead-card__meta {
  color: var(--muted);
  font-size: var(--typo-body-medium-size, 0.9375rem);
}

.company-lead-card__badge {
  display: inline-block;
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.02em;
  padding: 0.2rem 0.45rem;
  border-radius: var(--radius-sm, 4px);
  background: color-mix(in srgb, var(--accent, #2563eb) 12%, transparent);
  color: var(--accent, #1d4ed8);
}

/* Provider portal leads: directory-card–style rows, budget top-right */
.company-portal-lead-card-grid {
  gap: var(--space-1-5);
}

.company-portal-lead-card {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: var(--space-0-75);
  padding: var(--space-1-5) var(--space-1-75);
  text-decoration: none;
  color: inherit;
  border-radius: var(--radius-md, 8px);
  border: 1px solid var(--border, rgba(0, 0, 0, 0.08));
  box-shadow: 0 1px 2px color-mix(in srgb, var(--foreground, #0f172a) 6%, transparent);
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.company-portal-lead-card:hover {
  border-color: color-mix(in srgb, var(--accent, #2563eb) 35%, var(--border, #e2e8f0));
  box-shadow: 0 2px 8px color-mix(in srgb, var(--foreground, #0f172a) 8%, transparent);
}

.company-portal-lead-card--credit-blocked {
  opacity: 0.72;
  filter: grayscale(0.25);
  border-style: dashed;
}

.company-portal-lead-card--credit-blocked:hover {
  border-color: var(--border, rgba(0, 0, 0, 0.12));
  box-shadow: 0 1px 2px color-mix(in srgb, var(--foreground, #0f172a) 5%, transparent);
}

.company-portal-lead-card__top {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--space-1) var(--space-1-5);
  width: 100%;
}

.company-portal-lead-card__title-block {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: var(--space-0-5);
  min-width: 0;
}

.company-portal-lead-card__code {
  font-weight: 800;
  font-size: 1.05rem;
  line-height: 1.25;
}

.company-portal-lead-card__badge {
  margin-top: 0;
}

.company-portal-lead-card__price {
  font-weight: 800;
  font-size: 1rem;
  color: var(--accent, #1d4ed8);
  white-space: nowrap;
  margin-left: auto;
  flex-shrink: 0;
}

.company-portal-lead-card__meta {
  color: var(--muted);
  font-size: var(--typo-body-medium-size, 0.9375rem);
  line-height: 1.35;
}

.company-portal-lead-card__hint {
  font-size: var(--typo-body-medium-size, 0.875rem);
}

.company-portal-credit-hold {
  margin: 0 0 var(--space-1-5);
  padding: var(--space-1) var(--space-1-25);
  border-radius: var(--radius-md, 8px);
  background: color-mix(in srgb, var(--warn, #b45309) 12%, transparent);
  border: 1px solid color-mix(in srgb, var(--warn, #b45309) 28%, transparent);
  color: inherit;
  font-size: var(--typo-body-medium-size, 0.9375rem);
}

.company-lead-detail__masthead {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--space-1) var(--space-2);
  margin: 0 0 var(--space-1-5);
}

.company-lead-detail__title {
  margin: 0;
}

.company-lead-detail__lead-price {
  margin: 0.15rem 0 0;
  font-weight: 800;
  font-size: 1.125rem;
  color: var(--accent, #1d4ed8);
  white-space: nowrap;
}

/* Admin: provider portal credit ledger + unblock dialog */
.admin-company-credit-card {
  margin: 0 0 var(--space-2);
  padding: var(--space-1-5) var(--space-1-75);
}

.admin-company-credit-card__head {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--space-1);
  margin-bottom: var(--space-1);
}

.admin-company-credit-card__title {
  margin: 0;
}

.admin-company-credit-card__balance {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-0-75);
}

.admin-company-credit-card__balance-label {
  font-size: 0.8125rem;
}

.admin-company-credit-card__balance-value {
  font-size: 1.125rem;
}

.admin-company-credit-card__lead {
  margin: 0 0 var(--space-1);
  font-size: var(--typo-body-medium-size, 0.9375rem);
}

.admin-company-credit-card__actions {
  margin: 0 0 var(--space-1-5);
}

.admin-company-credit-card__flash {
  margin: 0 0 var(--space-1);
}

.admin-company-credit-card__ledger-title {
  font-size: 1rem;
  margin: var(--space-1-5) 0 var(--space-0-75);
}

.admin-company-credit-card__empty {
  margin: 0;
  font-size: var(--typo-body-medium-size, 0.9375rem);
}

.admin-company-credit-ledger-table {
  font-size: var(--typo-body-medium-size, 0.875rem);
}

.admin-credit-blocked-badge {
  display: inline-block;
  font-size: 0.6875rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  padding: 0.2rem 0.5rem;
  border-radius: var(--radius-sm, 4px);
  background: color-mix(in srgb, #b91c1c 14%, transparent);
  color: #991b1b;
  margin-right: var(--space-0-5);
}

.admin-credit-ok-badge {
  display: inline-block;
  font-size: 0.6875rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  padding: 0.2rem 0.45rem;
  border-radius: var(--radius-sm, 4px);
  background: color-mix(in srgb, #15803d 12%, transparent);
  color: #166534;
}

.admin-companies-credit-balance {
  font-size: 0.875rem;
}

.admin-credit-dialog {
  border: 1px solid var(--border, #e2e8f0);
  border-radius: var(--radius-md, 8px);
  padding: var(--space-2);
  max-width: 28rem;
  width: calc(100vw - 2rem);
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.18);
}

.admin-credit-dialog::backdrop {
  background: rgba(15, 23, 42, 0.4);
}

.admin-credit-dialog__title {
  margin: 0 0 var(--space-0-75);
  font-size: 1.15rem;
}

.admin-credit-dialog__lead {
  margin: 0 0 var(--space-1-25);
  font-size: var(--typo-body-medium-size, 0.9375rem);
}

.admin-credit-dialog__footer {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-1);
  margin-top: var(--space-1-5);
  justify-content: flex-end;
}

.company-lead-actions__hint {
  margin: 0 0 var(--space-1);
  font-size: var(--typo-body-medium-size, 0.9375rem);
}

.company-lead-actions__note {
  margin-bottom: var(--space-1-25);
  max-width: 32rem;
}

.company-lead-actions__row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-1);
}

.admin-status-active-filters {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-0-75);
  margin: 0 0 var(--space-1-5);
}

.admin-status-chip {
  display: inline-block;
  padding: 0.15rem 0.5rem;
  border-radius: var(--radius-sm, 4px);
  background: color-mix(in srgb, var(--border-strong) 25%, transparent);
  font-size: 0.8125rem;
}

.admin-status-filter-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(14rem, 1fr));
  gap: var(--space-1-25);
  margin-bottom: var(--space-1-5);
}

.admin-status-sort {
  color: inherit;
  text-decoration: none;
  font-weight: 600;
}

.admin-status-sort:hover {
  text-decoration: underline;
}

.admin-status-table {
  font-size: var(--typo-body-medium-size, 0.9375rem);
}

.admin-status-summary {
  max-width: 14rem;
  word-break: break-word;
}

.admin-status-pagination {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-1);
  margin: var(--space-1-5) 0 0;
}

.admin-status-pagination__meta {
  font-size: var(--typo-body-medium-size, 0.9375rem);
}

.company-leads-scope {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-0-5);
  margin: 0 0 var(--space-1-5);
  font-size: var(--typo-body-medium-size, 0.9375rem);
}

.company-leads-scope__sep {
  color: var(--muted);
  user-select: none;
}

.company-leads-scope__link {
  color: var(--accent, #2563eb);
  text-decoration: none;
  font-weight: 600;
}

.company-leads-scope__link:hover {
  text-decoration: underline;
}

.company-leads-scope__link--active {
  color: inherit;
  text-decoration: underline;
  pointer-events: none;
}

.company-leads-section__title {
  font-size: 1rem;
  font-weight: 700;
  margin: var(--space-2) 0 var(--space-1);
}

.company-leads-section__title:first-of-type {
  margin-top: 0;
}

.company-leads-section__empty {
  margin: 0 0 var(--space-1-5);
}

.admin-intake-assignments__lead {
  margin: 0 0 var(--space-1-25);
  font-size: var(--typo-body-medium-size, 0.9375rem);
}

.admin-intake-assignments-table-wrap {
  margin-top: var(--space-1);
}

.admin-intake-assignments-table {
  font-size: var(--typo-body-medium-size, 0.9375rem);
}

.admin-intake-assignments-table__note {
  max-width: 18rem;
  word-break: break-word;
}

.company-lead-detail-card {
  margin-bottom: var(--space-2);
}

.company-lead-detail-dl {
  margin: 0;
  display: grid;
  gap: var(--space-1-25);
}

.company-lead-detail-dl > div {
  display: grid;
  grid-template-columns: minmax(7rem, 34%) 1fr;
  gap: var(--space-1);
  align-items: baseline;
}

.company-lead-detail-dl dt {
  margin: 0;
  font-weight: 600;
  color: var(--muted);
  font-size: var(--typo-body-medium-size, 0.9375rem);
}

.company-lead-detail-dl dd {
  margin: 0;
}

.company-lead-detail__h2 {
  font-size: 1.05rem;
  margin: var(--space-2) 0 var(--space-1);
}

.company-lead-detail__images {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-1);
}

.company-lead-detail__img-link {
  display: block;
  border-radius: var(--radius);
  overflow: hidden;
  border: var(--border-width-hairline) solid var(--border-strong);
}

.company-lead-detail__img {
  display: block;
  width: 160px;
  height: auto;
  vertical-align: middle;
}

.company-login-page {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-2);
  background: color-mix(in srgb, var(--surface) 94%, var(--wf-primary) 6%);
}

.company-login-main {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
}

.company-login-back {
  margin: 0 0 var(--space-1);
  width: 100%;
  max-width: 22rem;
}

.portal-login-hub-page {
  min-height: 100vh;
  padding: var(--space-2);
  background: color-mix(in srgb, var(--surface) 94%, var(--wf-primary) 6%);
}

.portal-login-hub-main {
  display: flex;
  justify-content: center;
  padding-top: var(--space-2);
}

.portal-login-hub-inner {
  width: 100%;
  max-width: 36rem;
}

.portal-login-hub-title {
  margin: 0 0 var(--space-0-75);
  font-size: 1.5rem;
  font-weight: 800;
}

.portal-login-hub-lead {
  margin: 0 0 var(--space-2);
  font-size: var(--typo-body-medium-size, 0.9375rem);
}

.portal-login-hub-cards {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-1-25);
}

.portal-login-hub-card {
  display: flex;
  flex-direction: column;
  gap: var(--space-0-35);
  padding: var(--space-1-5) var(--space-1-75);
  text-decoration: none;
  color: inherit;
  border: 1px solid var(--border, rgba(0, 0, 0, 0.1));
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.portal-login-hub-card:hover {
  border-color: color-mix(in srgb, var(--accent, #2563eb) 40%, var(--border, #e2e8f0));
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.06);
}

.portal-login-hub-card__label {
  font-weight: 800;
  font-size: 1.05rem;
}

.portal-login-hub-card__desc {
  font-size: 0.875rem;
  line-height: 1.35;
}

.portal-login-hub-foot {
  margin: var(--space-2) 0 0;
  font-size: 0.875rem;
}

.client-portal-page {
  min-height: 100vh;
  padding: var(--space-2);
  background: color-mix(in srgb, var(--surface) 96%, var(--wf-primary) 4%);
}

.client-portal-back {
  margin: 0 auto var(--space-1);
  max-width: 28rem;
}

.client-portal-wrap {
  max-width: 28rem;
  margin: 0 auto;
}

.client-portal-header {
  display: flex;
  align-items: center;
  gap: var(--space-0-75);
  margin-bottom: var(--space-1);
  padding-bottom: var(--space-0-75);
  border-bottom: 1px solid var(--border, rgba(0, 0, 0, 0.08));
}

.client-portal-header__title {
  font-weight: 800;
  font-size: 1.05rem;
}

.client-portal-header__badge {
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  font-weight: 700;
}

.client-login-card {
  padding: var(--space-2);
}

.client-login-card__title {
  margin: 0 0 var(--space-1);
  font-size: 1.25rem;
  font-weight: 800;
}

.client-login-card__lead {
  margin: 0 0 var(--space-1);
  font-size: var(--typo-body-medium-size, 0.9375rem);
  line-height: 1.45;
}

.company-login-card {
  width: 100%;
  max-width: 22rem;
  padding: var(--space-2-5) var(--space-2-25);
}

.company-login-card__title {
  margin: 0 0 var(--space-0-75);
  font-size: 1.35rem;
  font-weight: 800;
}

.company-login-card__lead {
  margin: 0 0 var(--space-1-5);
  font-size: var(--typo-body-medium-size, 0.9375rem);
}

.company-portal-profile-embed .pro-company-profile__shell {
  padding-top: 0;
}

.admin-intake-assignments {
  list-style: none;
  margin: 0 0 var(--space-1-5);
  padding: 0;
}

.admin-intake-assignments__row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-1);
  padding: var(--space-1) 0;
  border-bottom: var(--border-width-hairline) solid color-mix(in srgb, var(--border-strong) 70%, transparent);
}

.admin-intake-assignments__body {
  flex: 1;
  min-width: min(100%, 14rem);
}

.admin-intake-assignments__note {
  display: inline;
}

.admin-intake-assign-form {
  margin-top: var(--space-1-5);
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: var(--space-1);
}

.admin-intake-detail-images {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-1);
}

.admin-intake-detail-images__img {
  display: block;
  border-radius: var(--radius);
  object-fit: cover;
  border: var(--border-width-hairline) solid var(--border-strong);
}

.input-field__hint {
  margin: 0.35rem 0 0;
  font-size: 0.8125rem;
  line-height: 1.35;
}

/* =========================
 * Homepage `.gp-home` — Moovit-style layout system (scoped)
 * ========================= */

.gp-home {
  --gp-hp-text: #111827;
  --gp-hp-muted: #6b7280;
  --gp-hp-bg: #f9fafb;
  --gp-hp-surface: #ffffff;
  --gp-hp-border: #e5e7eb;
  --gp-hp-eyebrow: #9ca3af;
  --gp-space-xs: 8px;
  --gp-space-sm: 16px;
  --gp-space-md: 24px;
  --gp-space-lg: 40px;
  --gp-space-xl: 64px;
  --gp-space-xxl: 80px;
  --gp-home-story-overlap: 56px;

  overflow-x: clip;
  background: var(--gp-hp-bg);
  color: var(--gp-hp-text);
  padding: 0 0 var(--gp-space-xl);
}

/* Homepage-only: header brand reads stronger (brand lives outside `<main class="gp-home">`) */
body.home-page .app-top-app-bar .wf-brand-lockup-product {
  font-size: 24px;
  font-weight: 800;
  letter-spacing: -0.03em;
  line-height: 1.1;
}

body.home-page .app-top-app-bar__tagline {
  margin: 4px 0 0;
  font-size: 14px;
  line-height: 1.35;
  color: #6b7280;
}

body.home-page .app-top-app-bar {
  border-bottom: none;
  box-shadow: none;
}

@media (min-width: 768px) {
  body.home-page .app-top-app-bar .wf-brand-lockup-product {
    font-size: 32px;
  }

  body.home-page .app-top-app-bar__tagline {
    font-size: 15px;
  }
}

/* GLOBAL PAGE CONTAINER */
.gp-home-container {
  max-width: 1200px;
  margin: 0 auto;
  padding-left: 24px;
  padding-right: 24px;
  width: 100%;
  box-sizing: border-box;
}

@media (min-width: 768px) {
  .gp-home-container {
    padding-left: 32px;
    padding-right: 32px;
  }
}

/* 2-column section pattern (provider split) */
.gp-home .gp-home-section {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: center;
}

/* ---------- HERO + story top stack (search overlaps story) ---------- */

.gp-home .gp-home-top-stack {
  position: relative;
  z-index: 0;
}

.gp-home .gp-home-hero {
  padding: 0;
  background: var(--gp-hp-bg);
}

.gp-home .gp-home-hero__top {
  padding: calc(var(--app-top-app-bar-height, 56px) + 56px) 0 0;
}

.gp-home .gp-home-hero__search-shell {
  position: relative;
  z-index: 5;
  width: 100%;
  min-width: 0;
  margin-bottom: calc(-1 * var(--gp-home-story-overlap));
}

@media (max-width: 767px) {
  .gp-home .gp-home-hero__top {
    padding: calc(var(--app-top-app-bar-height, 56px) + 32px) 0 0;
  }

  .gp-home .gp-home-story__visual {
    justify-content: center;
  }

  .gp-home .gp-home-story-mock--compare-cards .gp-home-story-mock__compare-grid {
    grid-template-columns: 1fr;
  }
}

@media (min-width: 768px) {
  .gp-home {
    --gp-home-story-overlap: 80px;
  }

  .gp-home .gp-home-hero__top {
    padding: calc(var(--app-top-app-bar-height, 56px) + 56px) 0 0;
  }

  .gp-home .gp-home-hero__search-shell {
    width: 100%;
  }

  .gp-home-search-card {
    position: relative;
    z-index: 6;
  }
}

@media (min-width: 768px) {
  .gp-home {
    background: #ffffff;
  }

  .gp-home .gp-home-hero {
    background: #ffffff;
  }

  .gp-home-search-card {
    background: #ffffff;
    border-radius: 22px;
    border: 1px solid #e5e7eb;
    box-shadow:
      0 10px 25px rgba(0, 0, 0, 0.06),
      0 2px 6px rgba(0, 0, 0, 0.04);
    padding: 18px 22px;
  }

  .gp-home-search-card .pro-home-dual-search .pro-search-form__toolbar-row {
    gap: 10px;
    grid-template-columns: minmax(0, 1.25fr) minmax(0, 1fr) 148px;
  }

  .gp-home-search-card .pro-home-dual-search .pro-ac-input {
    height: 48px;
    border-radius: 17px;
    border: 1px solid #e5e7eb;
    background: #ffffff;
    box-shadow: none;
  }

  .gp-home-search-card .pro-home-dual-search .pro-ac-input:focus {
    border-color: #6366f1;
    box-shadow: 0 0 0 2px rgba(99, 102, 241, 0.15);
  }

  .gp-home-search-card .pro-home-dual-search .pro-home-search-submit.btn {
    height: 48px;
    width: 148px;
    min-width: 148px;
    max-width: 148px;
    border-radius: 999px;
    background: linear-gradient(135deg, #6366f1, #7c3aed);
    color: #ffffff;
    font-weight: 600;
    letter-spacing: 0.01em;
    box-shadow: 0 6px 14px rgba(99, 102, 241, 0.25);
    transition: transform 0.2s ease, box-shadow 0.2s ease;
    border: none;
  }

  .gp-home-search-card .pro-home-dual-search .pro-home-search-submit.btn:hover {
    transform: translateY(-1px);
    box-shadow: 0 10px 20px rgba(99, 102, 241, 0.3);
  }
}

@keyframes gp-home-card-reveal {
  from {
    opacity: 0;
    transform: translateY(10px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* Search card — centerpiece */
.gp-home-search-card {
  position: relative;
  z-index: 6;
  width: 100%;
  max-width: none;
  margin: 0;
  background: #ffffff;
  border: 1px solid #dfe3ea;
  border-radius: 24px;
  box-shadow:
    0 12px 28px rgba(15, 23, 42, 0.1),
    0 2px 6px rgba(15, 23, 42, 0.06);
  padding: 20px 24px;
  animation: gp-home-card-reveal 0.5s ease-out both;
  transition: transform 0.22s ease, box-shadow 0.22s ease;
}

.gp-home-search-card:hover {
  transform: translateY(-2px);
  box-shadow:
    0 16px 34px rgba(15, 23, 42, 0.12),
    0 4px 10px rgba(15, 23, 42, 0.07);
}

.gp-home-search-card .pro-home-field-label {
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-weight: 700;
  color: var(--gp-hp-eyebrow);
}

.gp-home-search-card .pro-home-dual-search {
  width: 100%;
  max-width: 100%;
}

.gp-home-search-card .pro-home-dual-search .pro-search-form__toolbar-row {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(0, 1fr) 148px;
  gap: 12px;
  align-items: end;
}

.gp-home-search-card .pro-home-dual-search .pro-home-search-fields {
  display: grid;
  gap: var(--gp-space-sm);
}

.gp-home-search-card .pro-home-dual-search .input-field__control {
  min-height: 48px;
}

.gp-home-search-card .pro-home-dual-search .pro-search-form__field,
.gp-home-search-card .pro-home-dual-search .pro-ac {
  width: 100%;
  min-width: 0;
}

.gp-home-search-card .pro-home-dual-search .pro-ac,
.gp-home-search-card .pro-home-dual-search .pro-ac-input {
  min-height: 48px;
  height: 48px;
  border-radius: 17px;
}

.gp-home-search-card .pro-home-dual-search .pro-ac {
  flex: 0 1 auto;
  overflow: visible;
  box-shadow: none;
  border-color: var(--gp-hp-border);
}

.gp-home-search-card .pro-home-dual-search .pro-ac-input {
  height: 48px;
  box-sizing: border-box;
  padding-block: 10px;
  font-size: 16px;
  color: var(--gp-hp-text);
}

.gp-home-search-card .pro-home-dual-search .pro-home-search-submit.btn {
  width: 148px;
  min-width: 148px;
  max-width: 148px;
  min-height: 48px;
  height: 48px;
  border-radius: 24px;
  justify-content: center;
  font-weight: 700;
  padding: 0 20px;
  box-shadow: var(--elevation-btn-primary);
  align-self: end;
  box-sizing: border-box;
}

@media (max-width: 767px) {
  .gp-home-search-card {
    padding: 16px;
    border-radius: 20px;
  }

  .gp-home-search-card .pro-home-dual-search .pro-search-form__toolbar-row {
    grid-template-columns: 1fr;
    gap: 12px;
  }

  .gp-home-search-card .pro-home-dual-search .pro-home-search-submit.btn {
    width: 100%;
    min-width: 0;
    max-width: none;
  }
}

/* Section headers */
.gp-home .gp-home-section-head {
  margin: 0 0 var(--gp-space-sm);
}

.gp-home .gp-home-provider .gp-home-section-title {
  font-size: 28px;
  line-height: 1.18;
  font-weight: 800;
  letter-spacing: -0.02em;
  color: var(--gp-hp-text);
}

.gp-home .gp-home-section-subtitle {
  margin: 10px 0 0;
  font-size: 15px;
  line-height: 1.5;
  color: #6b7280;
  max-width: 40ch;
}

/* Provider */
.gp-home .gp-home-provider {
  padding: var(--gp-space-lg) 0;
  border-top: 1px solid color-mix(in srgb, var(--gp-hp-border) 70%, transparent);
  background: #fafafa;
}

.gp-home .gp-home-section--split .gp-home-provider__actions {
  margin-top: 0;
  justify-content: flex-end;
}

.gp-home .gp-home-provider__actions {
  margin-top: var(--gp-space-md);
  display: flex;
  flex-wrap: wrap;
  gap: var(--gp-space-sm);
}

.gp-home .gp-home-provider__actions .btn {
  min-height: 48px;
  border-radius: 9999px;
}

/* ---------- Auto-advancing story (top half) ---------- */
.gp-home .gp-home-story {
  position: relative;
  z-index: 1;
  width: 100%;
  min-height: 420px;
  display: flex;
  align-items: center;
  padding: calc(40px + var(--gp-home-story-overlap)) 0 64px;
  margin-top: 0;
  color: #fff;
  transition: background-color 0.4s ease;
}

.gp-home .gp-home-story[data-story="t1"] {
  background: #f97316;
}

.gp-home .gp-home-story[data-story="t2"] {
  background: #ea580c;
}

.gp-home .gp-home-story[data-story="t3"] {
  background: #dc2626;
}

.gp-home .gp-home-story[data-story="t4"] {
  background: #b91c1c;
}

.gp-home .gp-home-story[data-story="t5"] {
  background: #7c3aed;
}

.gp-home .gp-home-story__frame {
  width: 100%;
  min-width: 0;
}

.gp-home .gp-home-story__inner {
  display: grid;
  grid-template-columns: 1fr;
  gap: 20px;
  align-items: center;
  width: 100%;
  min-width: 0;
}

.gp-home .gp-home-story__eyebrow {
  display: block;
  margin: 0 0 12px;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.82);
}

.gp-home .gp-home-story__title {
  margin: 0;
  font-size: 28px;
  line-height: 1.15;
  font-weight: 800;
  letter-spacing: -0.02em;
  color: #fff;
}

.gp-home .gp-home-story__desc {
  margin: 14px 0 0;
  font-size: 16px;
  line-height: 1.5;
  color: rgba(255, 255, 255, 0.94);
  max-width: 40ch;
}

.gp-home .gp-home-story__visual {
  position: relative;
  width: 100%;
  min-width: 0;
  height: 220px;
  min-height: 220px;
  max-height: 220px;
  overflow: hidden;
}

.gp-home .gp-home-story-panel {
  position: absolute;
  inset: 0;
  display: none;
  width: 100%;
  max-width: 100%;
  margin: 0;
  padding: 0;
  min-height: 0;
  align-items: center;
  justify-content: center;
  box-sizing: border-box;
  background: transparent;
}

.gp-home .gp-home-story-panel.is-active {
  display: flex;
  animation: gp-home-story-fade 0.4s ease;
}

.gp-home .gp-home-story__visual-frame {
  position: relative;
  width: 100%;
  max-width: 420px;
  height: 220px;
  overflow: hidden;
  border-radius: 24px;
  box-shadow: 0 20px 40px rgba(0, 0, 0, 0.2);
  background: #111827;
  box-sizing: border-box;
}

.gp-home .gp-home-story__visual-img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
  pointer-events: none;
}

.gp-home .gp-home-story-mock-layer {
  position: relative;
  z-index: 1;
  width: 100%;
  height: 100%;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  padding: 8px;
  box-sizing: border-box;
  pointer-events: none;
}

.gp-home .gp-home-story-mock-layer .gp-home-story-mock {
  pointer-events: auto;
}

@keyframes gp-home-story-fade {
  from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}

.gp-home .gp-home-story-mock {
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
  background: #fff;
  color: #111827;
  border-radius: 16px;
  padding: 16px 18px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.15);
  transition: box-shadow 0.22s ease;
}

.gp-home .gp-home-story-mock:hover {
  box-shadow: 0 8px 22px rgba(0, 0, 0, 0.2);
}

.gp-home .gp-home-story-mock--in-frame {
  max-height: 168px;
  overflow: hidden;
  padding: 8px 10px;
  border-radius: 14px;
}

.gp-home .gp-home-story-mock--in-frame .gp-home-story-mock__label {
  margin-bottom: 6px;
  font-size: 10px;
}

.gp-home .gp-home-story-mock--in-frame .gp-home-story-mock__list {
  gap: 4px;
}

.gp-home .gp-home-story-mock--in-frame .gp-home-story-mock__list li {
  padding: 5px 8px;
  border-radius: 8px;
}

.gp-home .gp-home-story-mock--in-frame .gp-home-story-mock__name {
  font-size: 12px;
}

.gp-home .gp-home-story-mock--in-frame .gp-home-story-mock__sub {
  font-size: 10px;
}

.gp-home .gp-home-story-mock--in-frame.gp-home-story-mock--reviews .gp-home-story-mock__stars {
  font-size: 11px;
  margin-bottom: 4px;
}

.gp-home .gp-home-story-mock--in-frame.gp-home-story-mock--reviews .gp-home-story-mock__quote {
  font-size: 12px;
  line-height: 1.35;
  margin: 0 0 6px;
}

.gp-home .gp-home-story-mock--in-frame .gp-home-story-mock__chips {
  gap: 4px;
}

.gp-home .gp-home-story-mock--in-frame .gp-home-story-mock__chips span {
  font-size: 9px;
  padding: 2px 6px;
}

.gp-home .gp-home-story-mock--gallery .gp-home-story-mock__gallery {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 4px;
}

.gp-home .gp-home-story-mock__gallery-item {
  position: relative;
  aspect-ratio: 1;
  border-radius: 8px;
  border: 1px solid #e5e7eb;
  overflow: hidden;
  background: #f3f4f6;
}

.gp-home .gp-home-story-mock__gallery-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
}

.gp-home .gp-home-story-mock--in-frame .gp-home-story-mock__gallery-caption {
  margin: 6px 0 0;
  font-size: 10px;
  line-height: 1.3;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.gp-home .gp-home-story-mock--compare-compact {
  padding: 6px 8px;
  max-height: 118px;
}

.gp-home .gp-home-story-mock--compare-compact .gp-home-story-mock__label {
  margin-bottom: 4px;
}

.gp-home .gp-home-story-mock--compare-compact .gp-home-story-mock__compare-grid {
  gap: 4px;
}

.gp-home .gp-home-story-mock--compare-compact .gp-home-story-mock__compare-item {
  gap: 2px;
  padding: 5px 6px;
  border-radius: 8px;
}

.gp-home .gp-home-story-mock--compare-compact .gp-home-story-mock__compare-name {
  font-size: 11px;
}

.gp-home .gp-home-story-mock--compare-compact .gp-home-story-mock__compare-meta {
  font-size: 9px;
  line-height: 1.25;
}

.gp-home .gp-home-story-mock--contact-compact {
  padding: 8px 10px;
  max-height: 132px;
}

.gp-home .gp-home-story-mock--contact-compact .gp-home-story-mock__contact-row {
  gap: 8px;
  margin-bottom: 6px;
}

.gp-home .gp-home-story-mock--contact-compact .gp-home-story-mock__contact-avatar {
  width: 32px;
  height: 32px;
  border-radius: 10px;
}

.gp-home .gp-home-story-mock--contact-compact .gp-home-story-mock__contact-name {
  font-size: 12px;
}

.gp-home .gp-home-story-mock--contact-compact .gp-home-story-mock__contact-sub {
  font-size: 10px;
}

.gp-home .gp-home-story-mock--contact-compact .gp-home-story-mock__contact-body {
  margin-bottom: 6px;
  padding: 8px;
  gap: 5px;
}

.gp-home .gp-home-story-mock--contact-compact .gp-home-story-mock__contact-line {
  height: 6px;
}

.gp-home .gp-home-story-mock--contact-compact .gp-home-story-mock__contact-pill {
  padding: 5px 10px;
  font-size: 10px;
}

.gp-home .gp-home-story-mock__contact-row {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 12px;
}

.gp-home .gp-home-story-mock__contact-avatar {
  width: 40px;
  height: 40px;
  border-radius: 12px;
  border: 1px solid #e5e7eb;
  background: linear-gradient(135deg, #e0e7ff, #ede9fe);
  flex-shrink: 0;
}

.gp-home .gp-home-story-mock__contact-lines {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}

.gp-home .gp-home-story-mock__contact-name {
  font-size: 14px;
  font-weight: 600;
  color: #111827;
}

.gp-home .gp-home-story-mock__contact-sub {
  font-size: 12px;
  color: #6b7280;
}

.gp-home .gp-home-story-mock__contact-body {
  margin-bottom: 12px;
  padding: 12px;
  border-radius: 12px;
  border: 1px solid #e5e7eb;
  background: #f9fafb;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.gp-home .gp-home-story-mock__contact-line {
  display: block;
  height: 8px;
  border-radius: 4px;
  background: #e5e7eb;
}

.gp-home .gp-home-story-mock__contact-line--short {
  width: 72%;
}

.gp-home .gp-home-story-mock__contact-pill {
  display: inline-flex;
  align-self: flex-end;
  align-items: center;
  justify-content: center;
  padding: 8px 14px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 600;
  color: #111827;
  border: 1px solid #e5e7eb;
  background: #fff;
}

.gp-home .gp-home-story-mock__label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #9ca3af;
  margin-bottom: 12px;
}

.gp-home .gp-home-story-mock__list {
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.gp-home .gp-home-story-mock__list li {
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid #e5e7eb;
  background: #f9fafb;
}

.gp-home .gp-home-story-mock__name {
  font-size: 14px;
  font-weight: 600;
}

.gp-home .gp-home-story-mock__sub {
  font-size: 12px;
  color: #6b7280;
}

.gp-home .gp-home-story-mock--reviews .gp-home-story-mock__stars {
  font-size: 14px;
  letter-spacing: 2px;
  color: #f59e0b;
  margin-bottom: 10px;
}

.gp-home .gp-home-story-mock--reviews .gp-home-story-mock__quote {
  margin: 0 0 12px;
  font-size: 15px;
  line-height: 1.45;
  color: #374151;
}

.gp-home .gp-home-story-mock__chips {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.gp-home .gp-home-story-mock__chips span {
  font-size: 11px;
  font-weight: 600;
  padding: 4px 10px;
  border-radius: 999px;
  background: #f3f4f6;
  color: #4b5563;
  border: 1px solid #e5e7eb;
}

.gp-home .gp-home-story-mock--profile {
  text-align: center;
}

.gp-home .gp-home-story-mock__avatar {
  width: 48px;
  height: 48px;
  border-radius: 14px;
  margin: 0 auto 10px;
  border: 1px solid #e5e7eb;
  background: linear-gradient(135deg, #e0e7ff, #ede9fe);
}

.gp-home .gp-home-story-mock__profile-name {
  font-size: 15px;
  font-weight: 700;
}

.gp-home .gp-home-story-mock__profile-meta {
  font-size: 12px;
  color: #6b7280;
  margin-top: 4px;
}

.gp-home .gp-home-story-mock__bar {
  margin-top: 14px;
  height: 6px;
  border-radius: 999px;
  background: #e5e7eb;
  overflow: hidden;
}

.gp-home .gp-home-story-mock__bar span {
  display: block;
  width: 72%;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, #6366f1, #7c3aed);
}

.gp-home .gp-home-story__dots {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 8px;
  grid-column: 1 / -1;
}

.gp-home .gp-home-story__dot {
  width: 10px;
  height: 10px;
  padding: 0;
  border: none;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.35);
  cursor: pointer;
  transition: transform 0.2s ease, background 0.2s ease;
}

.gp-home .gp-home-story__dot.is-active {
  background: #fff;
  transform: scale(1.15);
}

.gp-home .gp-home-story__dot:focus-visible {
  outline: 2px solid #fff;
  outline-offset: 2px;
}

@media (min-width: 768px) {
  .gp-home .gp-home-story {
    min-height: 480px;
  }

  .gp-home .gp-home-story__inner {
    grid-template-columns: 1fr 1fr;
    gap: 48px;
    align-items: center;
  }

  .gp-home .gp-home-story__dots {
    grid-column: 1 / -1;
  }

  .gp-home .gp-home-story__title {
    font-size: 36px;
    line-height: 1.12;
  }

  .gp-home .gp-home-story__visual {
    height: 260px;
    min-height: 260px;
    max-height: 260px;
  }

  .gp-home .gp-home-story__visual-frame {
    height: 260px;
  }

  .gp-home .gp-home-story-mock--in-frame {
    max-height: 198px;
  }

  .gp-home .gp-home-story-mock--compare-compact {
    max-height: 132px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .gp-home .gp-home-story {
    transition: none;
  }

  .gp-home .gp-home-story-panel.is-active {
    animation: none;
  }

  .gp-home .gp-home-story__dot {
    transition: none;
  }

  .gp-home-search-card {
    animation: none;
  }

  .gp-home-search-card:hover {
    transform: none;
  }

  .gp-home .gp-home-story-mock {
    transition: none;
  }

  .gp-home .gp-home-story-mock:hover {
    transform: none;
  }

  .gp-home .gp-home-metric-circle {
    transition: none;
  }

  .gp-home .gp-home-metric-circle:hover {
    transform: none;
  }

  .gp-home .gp-home-metric-circle__ring {
    transition: none;
  }
}

/* ---------- Circular platform metrics ---------- */
@keyframes gp-home-metric-in {
  from {
    opacity: 0;
    transform: translateY(14px) scale(0.96);
  }

  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

.gp-home .gp-home-metrics {
  padding: var(--gp-space-lg) 0 var(--gp-space-xl);
  background: #fafafa;
  border-top: 1px solid color-mix(in srgb, var(--gp-hp-border) 70%, transparent);
}

.gp-home .gp-home-metrics__inner {
  width: 100%;
  min-width: 0;
}

.gp-home .gp-home-metrics__head {
  text-align: center;
  width: 100%;
  max-width: none;
  margin: 0 0 var(--gp-space-lg);
}

.gp-home .gp-home-metrics__eyebrow {
  display: block;
  margin: 0 0 12px;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #9ca3af;
}

.gp-home .gp-home-metrics__title {
  margin: 0;
  font-size: 28px;
  line-height: 1.18;
  font-weight: 800;
  letter-spacing: -0.02em;
  color: var(--gp-hp-text);
}

.gp-home .gp-home-metrics__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--gp-space-md) var(--gp-space-sm);
  justify-items: center;
}

.gp-home .gp-home-metric-circle {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  text-align: center;
  animation: gp-home-metric-in 0.55s ease forwards;
  opacity: 0;
  transition: transform 0.22s ease;
}

.gp-home .gp-home-metric-circle:hover {
  transform: translateY(-3px);
}

.gp-home .gp-home-metric-circle:nth-child(1) {
  animation-delay: 0.05s;
}

.gp-home .gp-home-metric-circle:nth-child(2) {
  animation-delay: 0.12s;
}

.gp-home .gp-home-metric-circle:nth-child(3) {
  animation-delay: 0.19s;
}

.gp-home .gp-home-metric-circle:nth-child(4) {
  animation-delay: 0.26s;
}

.gp-home .gp-home-metric-circle__ring {
  width: 132px;
  height: 132px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #fff;
  border: 2px solid #e5e7eb;
  box-shadow: 0 4px 14px rgba(15, 23, 42, 0.06);
  transition: box-shadow 0.22s ease;
}

.gp-home .gp-home-metric-circle:hover .gp-home-metric-circle__ring {
  box-shadow: 0 8px 22px rgba(15, 23, 42, 0.1);
}

.gp-home .gp-home-metric-circle__value {
  font-size: 26px;
  font-weight: 800;
  letter-spacing: -0.03em;
  line-height: 1;
  color: var(--gp-hp-text);
  font-variant-numeric: tabular-nums;
}

.gp-home .gp-home-metric-circle__label {
  font-size: 14px;
  line-height: 1.35;
  font-weight: 600;
  color: #4b5563;
  max-width: 11rem;
}

@media (min-width: 768px) {
  .gp-home .gp-home-metrics__title {
    font-size: 36px;
  }

  .gp-home .gp-home-metrics__grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: var(--gp-space-md);
  }

  .gp-home .gp-home-metric-circle__ring {
    width: 148px;
    height: 148px;
  }

  .gp-home .gp-home-metric-circle__value {
    font-size: 30px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .gp-home .gp-home-metric-circle {
    animation: none;
    opacity: 1;
    transform: none;
  }

  .gp-home .gp-home-metric-circle:hover .gp-home-metric-circle__ring {
    box-shadow: 0 4px 14px rgba(15, 23, 42, 0.06);
  }
}

/* Homepage buttons — subtle interaction */
.gp-home .btn {
  transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease, background 0.2s ease;
}

.gp-home .btn:hover {
  transform: translateY(-1px);
}

/* =========================
 * Breakpoints
 * ========================= */

@media (max-width: 767px) {
  .gp-home .gp-home-section {
    grid-template-columns: 1fr;
    gap: var(--gp-space-md);
  }

  .gp-home .gp-home-provider {
    padding: var(--gp-space-lg) 0;
  }
}

@media (min-width: 768px) {
  .gp-home {
    padding: 0 0 var(--gp-space-xl);
  }

  .gp-home-search-card .pro-home-dual-search .pro-home-search-fields {
    display: contents;
  }

  .gp-home .gp-home-provider .gp-home-section-title {
    font-size: 36px;
    line-height: 1.15;
  }

  .gp-home .gp-home-provider {
    padding: var(--gp-space-lg) 0 var(--gp-space-xl);
  }
}

/* ---------- `.gp-home` layout safeguards (overflow / narrow viewports) ---------- */

.gp-home {
  max-width: 100%;
}

.gp-home [class$="__inner"] {
  min-width: 0;
  max-width: 100%;
}

.gp-home-search-card {
  min-width: 0;
  max-width: 100%;
  overflow-x: clip;
}

.gp-home-search-card .pro-home-dual-search,
.gp-home-search-card .pro-home-dual-search form {
  min-width: 0;
  max-width: 100%;
}

.gp-home .gp-home-provider__actions .btn {
  max-width: 100%;
  white-space: normal;
  overflow-wrap: anywhere;
}

.gp-home img,
.gp-home video {
  max-width: 100%;
  height: auto;
}

@media (min-width: 768px) {
  .gp-home-search-card .pro-home-dual-search .pro-search-form__toolbar-row > * {
    min-width: 0;
  }

  .gp-home-search-card .pro-home-dual-search .pro-search-form__toolbar-row .pro-home-search-submit.btn {
    flex-shrink: 0;
  }
}
