/* ============================================================================
   GROWBRIX — DESIGN SYSTEM
   ----------------------------------------------------------------------------
   The single source of visual truth. Brand tokens (colours, fonts) are
   injected from config.yml at runtime (see js/core.js -> applyBranding); the
   :root fallbacks below guarantee the page is never unstyled.

   CONTENTS
     1.  Tokens               8.  Forms
     2.  Reset & base         9.  Cards
     3.  Typography          10.  Header / navigation
     4.  Layout              11.  Footer
     5.  Buttons             12.  Modal
     6.  Badges & status     13.  Product UI primitives (charts, app windows)
     7.  Tabs & filters      14.  Empty states · 15. Motion · 16. Utilities
   ========================================================================== */

/* =============================== 1. TOKENS ============================== */
:root {
  /* — Brand (overridden from config) — Altare-style editorial monochrome — */
  --primary: #0A0A0A;        /* near-black — primary actions             */
  --secondary: #0A0A0A;      /* ink black — headings, depth              */
  --accent: #171717;         /* graphite — highlights                    */
  --bg: #FFFFFF;             /* pure white — page background              */
  --surface: #FFFFFF;        /* cards & panels                           */
  --surface-2: #F4F4F4;      /* recessed surfaces                        */
  --text: #111111;           /* body text                                */
  --muted: #6B6B6B;          /* secondary text                           */
  --border: #E6E6E6;         /* hairlines                                */
  --ink: #0A0A0A;            /* dedicated dark-surface colour (footers,   */
                             /* sidebars, CTA/stat bands) — stays dark in */
                             /* dark mode while --secondary flips light   */

  --font-heading: 'Sora', system-ui, -apple-system, 'Segoe UI', sans-serif;
  --font-body: 'Plus Jakarta Sans', system-ui, -apple-system, 'Segoe UI', sans-serif;

  /* — Semantic — */
  --success: #16A36B;
  --warning: #B7791F;
  --danger:  #C0492F;
  --info:    #2F6FB0;

  /* — Derived tints (color-mix keeps them in sync with brand) — */
  --primary-04: color-mix(in srgb, var(--primary) 4%, transparent);
  --primary-08: color-mix(in srgb, var(--primary) 8%, transparent);
  --primary-12: color-mix(in srgb, var(--primary) 12%, transparent);
  --primary-18: color-mix(in srgb, var(--primary) 18%, transparent);
  --accent-14:  color-mix(in srgb, var(--accent) 14%, transparent);
  --accent-24:  color-mix(in srgb, var(--accent) 24%, transparent);
  --warning-12: color-mix(in srgb, var(--warning) 14%, #FFF8EC);
  --danger-12:  color-mix(in srgb, var(--danger) 12%, #FDF1EE);
  --info-12:    color-mix(in srgb, var(--info) 12%, #EEF4FB);
  --ink-soft:   color-mix(in srgb, var(--secondary) 70%, var(--text));
  --on-ink-70:  rgba(255, 255, 255, .72);
  --on-ink-50:  rgba(255, 255, 255, .5);
  --on-ink-bd:  rgba(255, 255, 255, .12);

  /* — Typographic scale (1.2 minor third, fluid where useful) — */
  --fs-display: clamp(2.8rem, 6vw, 4.4rem);
  --fs-h1: clamp(2.4rem, 5vw, 3.6rem);
  --fs-h2: clamp(1.9rem, 4vw, 2.85rem);
  --fs-h3: clamp(1.35rem, 2.2vw, 1.7rem);
  --fs-h4: 1.15rem;
  --fs-lg: 1.15rem;
  --fs-base: 1.0625rem;       /* 17px */
  --fs-sm: 0.9375rem;         /* 15px */
  --fs-xs: 0.8125rem;         /* 13px */
  --fs-2xs: 0.72rem;

  /* — Spacing scale (luxury rhythm) — */
  --space-0: 0.25rem;
  --space-1: 0.5rem;
  --space-2: 0.75rem;
  --space-3: 1rem;
  --space-4: 1.5rem;
  --space-5: 2rem;
  --space-6: 3rem;
  --space-7: 4.5rem;
  --space-8: 7rem;
  --space-9: 9rem;

  /* — Radius — editorial: sharp, square corners everywhere — */
  --radius-xs: 0;
  --radius-sm: 0;
  --radius: 0;
  --radius-md: 0;
  --radius-lg: 0;
  --radius-xl: 0;
  --radius-2xl: 0;
  --radius-pill: 0;

  /* — Borders — */
  --bd: 1px solid var(--border);
  --bd-strong: 1px solid color-mix(in srgb, var(--secondary) 14%, var(--border));

  /* — Elevation (layered, soft, premium) — */
  --shadow-xs: 0 1px 2px rgba(10, 37, 64, 0.06);
  --shadow-sm: 0 2px 8px rgba(10, 37, 64, 0.06), 0 1px 2px rgba(10, 37, 64, 0.04);
  --shadow-md: 0 8px 24px rgba(10, 37, 64, 0.08), 0 2px 6px rgba(10, 37, 64, 0.05);
  --shadow-lg: 0 24px 60px rgba(10, 37, 64, 0.12), 0 8px 20px rgba(10, 37, 64, 0.06);
  --shadow-xl: 0 40px 90px -28px rgba(10, 37, 64, 0.30), 0 12px 28px rgba(10, 37, 64, 0.10);
  --shadow-glow: 0 30px 80px -20px color-mix(in srgb, var(--primary) 30%, transparent);
  --shadow-inset-hi: inset 0 1px 0 rgba(255, 255, 255, .5);

  /* — Glassmorphism — */
  --glass-blur: 16px;
  --glass-bg: color-mix(in srgb, var(--surface) 62%, transparent);
  --glass-bd: 1px solid color-mix(in srgb, #fff 55%, var(--border));
  --glass-hi: inset 0 1px 0 rgba(255, 255, 255, .45);

  /* — Claymorphism (soft 3D) — */
  --clay-radius: 22px;
  --clay-bg: var(--surface);
  --clay-shadow:
    8px 8px 22px color-mix(in srgb, var(--secondary) 14%, transparent),
    -6px -6px 18px rgba(255, 255, 255, .8),
    inset 0 1px 0 rgba(255, 255, 255, .6);
  --clay-shadow-sm:
    5px 5px 14px color-mix(in srgb, var(--secondary) 12%, transparent),
    -4px -4px 12px rgba(255, 255, 255, .75),
    inset 0 1px 0 rgba(255, 255, 255, .55);
  --clay-press: inset 3px 3px 8px color-mix(in srgb, var(--secondary) 16%, transparent), inset -3px -3px 8px rgba(255, 255, 255, .7);

  /* — Layout — */
  --maxw: 1200px;
  --maxw-wide: 1320px;
  --maxw-prose: 720px;
  --header-h: 74px;
  --sidebar-w: 264px;

  /* — Motion — */
  --ease: cubic-bezier(0.22, 1, 0.36, 1);
  --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
  --ease-in-out: cubic-bezier(0.65, 0, 0.35, 1);
  --t-fast: .18s;
  --t: .28s;
  --t-slow: .6s;
}

/* ----------------------------- DARK THEME ------------------------------ */
:root[data-theme="dark"] {
  --primary: #FFFFFF;         /* white — primary actions on black          */
  --accent: #E5E5E5;
  --secondary: #FAFAFA;       /* light ink — headings & body text          */
  --ink: #050505;             /* dark surfaces stay dark                   */
  --bg: #060606;              /* near-pure black page                       */
  --surface: #0E0E0E;
  --surface-2: #161616;
  --text: #EDEDED;
  --muted: #9A9A9A;
  --border: #262626;
  color-scheme: dark;

  /* brighter semantic colours + dark-friendly tint bases (legible on dark) */
  --success: var(--accent);
  --warning: #E6AA4D;
  --danger:  #EC8A72;
  --info:    #6FA8E0;
  --warning-12: color-mix(in srgb, var(--warning) 20%, transparent);
  --danger-12:  color-mix(in srgb, var(--danger) 20%, transparent);
  --info-12:    color-mix(in srgb, var(--info) 20%, transparent);

  /* brighter brand tints so accents read on dark */
  --primary-04: color-mix(in srgb, var(--primary) 8%, transparent);
  --primary-08: color-mix(in srgb, var(--primary) 14%, transparent);
  --primary-12: color-mix(in srgb, var(--primary) 18%, transparent);
  --primary-18: color-mix(in srgb, var(--primary) 26%, transparent);
  --accent-14: color-mix(in srgb, var(--accent) 20%, transparent);
  --accent-24: color-mix(in srgb, var(--accent) 30%, transparent);

  --shadow-xs: 0 1px 2px rgba(0, 0, 0, .4);
  --shadow-sm: 0 2px 10px rgba(0, 0, 0, .45), 0 1px 2px rgba(0, 0, 0, .35);
  --shadow-md: 0 12px 30px rgba(0, 0, 0, .5), 0 3px 8px rgba(0, 0, 0, .4);
  --shadow-lg: 0 26px 64px rgba(0, 0, 0, .55), 0 10px 24px rgba(0, 0, 0, .4);
  --shadow-xl: 0 44px 96px -28px rgba(0, 0, 0, .75), 0 14px 32px rgba(0, 0, 0, .5);
  --shadow-glow: 0 30px 80px -20px color-mix(in srgb, var(--primary) 28%, transparent);

  /* glass + clay tuned for dark */
  --glass-bg: color-mix(in srgb, var(--surface) 58%, transparent);
  --glass-bd: 1px solid color-mix(in srgb, #fff 12%, var(--border));
  --glass-hi: inset 0 1px 0 rgba(255, 255, 255, .08);
  --clay-shadow:
    8px 8px 22px rgba(0, 0, 0, .55),
    -5px -5px 16px rgba(255, 255, 255, .04),
    inset 0 1px 0 rgba(255, 255, 255, .06);
  --clay-shadow-sm:
    5px 5px 14px rgba(0, 0, 0, .5),
    -3px -3px 10px rgba(255, 255, 255, .035),
    inset 0 1px 0 rgba(255, 255, 255, .05);
  --clay-press: inset 3px 3px 8px rgba(0, 0, 0, .55), inset -3px -3px 8px rgba(255, 255, 255, .04);
}
/* subtle depth backdrop */
:root[data-theme="dark"] body {
  -webkit-font-smoothing: antialiased;
  background:
    radial-gradient(60% 45% at 88% -8%, rgba(255, 255, 255, .05), transparent 60%),
    var(--bg);
  background-attachment: fixed;
}
:root[data-theme="dark"] .cursor-glow { mix-blend-mode: screen; background: radial-gradient(circle, color-mix(in srgb, var(--primary) 16%, transparent), transparent 65%); }
:root[data-theme="dark"] .grid-texture::before { opacity: .28; }
/* a hairline top-light on raised surfaces for material depth */
:root[data-theme="dark"] .card, :root[data-theme="dark"] .feature-card, :root[data-theme="dark"] .kpi,
:root[data-theme="dark"] .widget, :root[data-theme="dark"] .opp-card, :root[data-theme="dark"] .price-card,
:root[data-theme="dark"] .panel, :root[data-theme="dark"] .value-card, :root[data-theme="dark"] .admin-item {
  background-image: linear-gradient(180deg, rgba(255, 255, 255, .03), transparent 42%);
}
:root[data-theme="dark"] .card--glass, :root[data-theme="dark"] .panel-glass { background: color-mix(in srgb, var(--surface) 70%, transparent); border-color: color-mix(in srgb, #fff 12%, var(--border)); }
:root[data-theme="dark"] .site-header.is-stuck { background: color-mix(in srgb, var(--bg) 72%, transparent); border-bottom-color: var(--border); }
:root[data-theme="dark"] .btn--accent { color: #0A0A0A; }
:root[data-theme="dark"] .btn--ghost { background: color-mix(in srgb, var(--surface) 82%, transparent); }
:root[data-theme="dark"] .field input, :root[data-theme="dark"] .field select, :root[data-theme="dark"] .field textarea,
:root[data-theme="dark"] .input, :root[data-theme="dark"] .search-box input { background: var(--surface-2); }
:root[data-theme="dark"] .select {
  background-color: var(--surface-2);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%238B99AE' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
}
:root[data-theme="dark"] .status--review, :root[data-theme="dark"] .badge--warning { background: color-mix(in srgb, var(--warning) 24%, transparent); color: #F2C879; }
:root[data-theme="dark"] .status--declined, :root[data-theme="dark"] .status--closed, :root[data-theme="dark"] .badge--danger { background: color-mix(in srgb, var(--danger) 26%, transparent); color: #F0A091; }
:root[data-theme="dark"] .status--new, :root[data-theme="dark"] .badge--info { background: color-mix(in srgb, var(--info) 28%, transparent); color: #A9CBF0; }
:root[data-theme="dark"] .status--draft, :root[data-theme="dark"] .badge--neutral, :root[data-theme="dark"] .pill--soft, :root[data-theme="dark"] .tag, :root[data-theme="dark"] .chip { background: var(--surface-2); }
:root[data-theme="dark"] .demo-banner { background: color-mix(in srgb, var(--warning) 18%, transparent); color: #F2C879; border-color: color-mix(in srgb, var(--warning) 32%, transparent); }
:root[data-theme="dark"] .empty { background: radial-gradient(80% 100% at 50% 0%, var(--primary-04), transparent 70%), var(--surface); border-color: var(--border); }
:root[data-theme="dark"] .bubble--in { background: var(--surface-2); }
:root[data-theme="dark"] .metric, :root[data-theme="dark"] .row, :root[data-theme="dark"] .kanban__col { background: var(--surface-2); }
/* surfaces built from color-mix(...secondary) would lighten in dark — pin them */
:root[data-theme="dark"] .app-bar, :root[data-theme="dark"] .pf-side, :root[data-theme="dark"] .pf-table .tr.th,
:root[data-theme="dark"] .data-table .thead, :root[data-theme="dark"] .compare-table thead th { background: var(--surface-2); }
:root[data-theme="dark"] .app-search { background: var(--bg); }
:root[data-theme="dark"] .modal { background: var(--surface); }
:root[data-theme="dark"] .chat__item.is-active, :root[data-theme="dark"] .list-row:hover, :root[data-theme="dark"] .data-table .trow:hover { background: color-mix(in srgb, var(--surface) 70%, #fff 4%); }

/* =========================== 2. RESET & BASE =========================== */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; }
html {
  -webkit-text-size-adjust: 100%;
  scroll-behavior: smooth;
  scroll-padding-top: calc(var(--header-h) + 16px);
}
body {
  font-family: var(--font-body);
  color: var(--text);
  background: var(--bg);
  line-height: 1.6;
  font-size: var(--fs-base);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
  font-feature-settings: "ss01", "cv11";
}
img, svg, video { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; color: inherit; background: none; border: none; }
ul, ol { list-style: none; padding: 0; }
input, select, textarea, button { font-family: inherit; }
::selection { background: var(--accent-24); color: var(--secondary); }

:focus-visible { outline: 2px solid var(--primary); outline-offset: 3px; border-radius: 0; }
:focus:not(:focus-visible) { outline: none; }

/* Custom scrollbar (subtle, premium) */
@supports (scrollbar-width: thin) {
  * { scrollbar-width: thin; scrollbar-color: color-mix(in srgb, var(--secondary) 22%, transparent) transparent; }
}
*::-webkit-scrollbar { width: 10px; height: 10px; }
*::-webkit-scrollbar-thumb { background: color-mix(in srgb, var(--secondary) 18%, transparent); border-radius: 0; border: 3px solid transparent; background-clip: content-box; }
*::-webkit-scrollbar-thumb:hover { background: color-mix(in srgb, var(--secondary) 32%, transparent); background-clip: content-box; }

.skip-link {
  position: fixed; left: 50%; top: -80px; transform: translateX(-50%);
  background: var(--secondary); color: #fff; padding: 10px 18px;
  border-radius: 0; z-index: 2000; font-weight: 600; font-size: var(--fs-sm);
  transition: top var(--t) var(--ease);
}
.skip-link:focus { top: 0; }

.noscript-banner { position: fixed; inset: 0; display: grid; place-items: center; background: var(--bg); padding: 2rem; text-align: center; z-index: 9999; }

/* App boot splash (removed once first route paints) */
.boot {
  position: fixed; inset: 0; z-index: 1500; display: grid; place-items: center;
  background: var(--bg); transition: opacity .5s var(--ease), visibility .5s;
}
.boot.is-hidden { opacity: 0; visibility: hidden; pointer-events: none; }
.boot-lockup { display: grid; justify-items: center; gap: 1rem; }
.boot-word { font-family: var(--font-heading); font-weight: 800; font-size: 1.35rem; letter-spacing: -.03em; color: var(--secondary); opacity: .9; }
.boot-mark {
  width: 64px; height: 64px; border-radius: 0;
  background: var(--ink); border: 1px solid color-mix(in srgb, #fff 16%, transparent);
  display: grid; place-items: center; color: #fff;
  box-shadow: var(--shadow-lg); animation: boot-pulse 1.4s var(--ease-in-out) infinite;
}
@keyframes boot-pulse { 0%, 100% { transform: scale(1); opacity: 1; } 50% { transform: scale(.9); opacity: .65; } }

/* =========================== 3. TYPOGRAPHY ============================= */
/* Editorial: heavier weight + tighter tracking for a high-contrast, magazine feel. */
h1, h2, h3, h4, h5 { font-family: var(--font-heading); color: var(--secondary); line-height: 1.04; letter-spacing: -0.04em; font-weight: 800; }
h1 { font-size: var(--fs-h1); letter-spacing: -0.045em; }
h2 { font-size: var(--fs-h2); }
h3 { font-size: var(--fs-h3); letter-spacing: -0.035em; }
h4, h5 { font-weight: 700; }
p { text-wrap: pretty; }
.balance { text-wrap: balance; }
.accent-word { color: var(--primary); font-style: normal; }

.eyebrow {
  display: inline-flex; align-items: center; gap: .55rem;
  font-family: var(--font-body); font-size: var(--fs-xs); font-weight: 600;
  letter-spacing: .18em; text-transform: uppercase; color: var(--muted);
}
.eyebrow::before { content: ""; width: 18px; height: 1.5px; background: currentColor; opacity: .55; }
.eyebrow.is-center::before, .eyebrow.no-rule::before { display: none; }
.eyebrow--pill {
  background: var(--primary-08); border: 1px solid var(--primary-12);
  padding: .4rem .85rem; border-radius: var(--radius-pill); letter-spacing: .08em;
}
.eyebrow--pill::before { display: none; }

.section-head { max-width: 720px; margin-bottom: clamp(2rem, 4vw, 3.25rem); }
.section-head h2 { margin-top: .85rem; font-size: clamp(2rem, 4.2vw, 3.4rem); }
.section-head .lede, .section-head > p { color: var(--muted); font-size: var(--fs-lg); margin-top: 1rem; }
.section-head.is-center { margin-inline: auto; text-align: center; }
.section-head.is-center .eyebrow { justify-content: center; }

.lede { color: var(--muted); font-size: var(--fs-lg); }
.muted { color: var(--muted); }
.prose { max-width: var(--maxw-prose); }
.prose p + p { margin-top: 1.1rem; }
.prose h2 { margin: 2.5rem 0 1rem; }
.prose h3 { margin: 2rem 0 .75rem; font-family: var(--font-body); font-weight: 600; }
.prose ul { display: grid; gap: .5rem; margin: 1rem 0; }
.prose ul li { position: relative; padding-left: 1.5rem; color: var(--muted); }
.prose ul li::before { content: ""; position: absolute; left: 2px; top: .65em; width: 7px; height: 7px; border-radius: 0; background: var(--primary); }

/* ============================= 4. LAYOUT ============================== */
.container { width: 100%; max-width: var(--maxw); margin-inline: auto; padding-inline: clamp(1.25rem, 4vw, 2.5rem); }
.container--wide { max-width: var(--maxw-wide); }
.container--prose { max-width: var(--maxw-prose); }
.section { padding-block: clamp(3.5rem, 8vw, var(--space-8)); position: relative; }
.section--tight { padding-block: clamp(2.5rem, 5vw, 4rem); }
.section--flush-top { padding-top: 0; }
.section--alt { background: var(--surface-2); }
.section--ink { background: var(--ink); color: var(--on-ink-70); }
.section--ink h2, .section--ink h3 { color: #fff; }

.grid { display: grid; gap: var(--space-4); }
.cols-2 { grid-template-columns: repeat(2, 1fr); }
.cols-3 { grid-template-columns: repeat(3, 1fr); }
.cols-4 { grid-template-columns: repeat(4, 1fr); }
.cols-auto { grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); }
.stack { display: grid; gap: var(--space-3); }
.cluster { display: flex; flex-wrap: wrap; gap: var(--space-2); align-items: center; }
.between { display: flex; align-items: center; justify-content: space-between; gap: var(--space-3); }

/* Page intro band (shared across inner pages) */
.page-hero { padding-top: clamp(3rem, 6vw, 5rem); padding-bottom: clamp(2rem, 4vw, 3rem); position: relative; }
.page-hero .eyebrow { margin-bottom: 1rem; }
.page-hero h1 { font-size: var(--fs-h1); max-width: 16ch; }
.page-hero .lede { margin-top: 1.25rem; max-width: 56ch; }
.page-hero__actions { margin-top: 2rem; display: flex; flex-wrap: wrap; gap: .85rem; }
.page-hero--center { text-align: center; }
.page-hero--center h1, .page-hero--center .lede { margin-inline: auto; }
.page-hero--center .eyebrow { justify-content: center; }
.page-hero--center .page-hero__actions { justify-content: center; }

/* The grid/glow texture used behind heroes (editorial, not a blob) */
.grid-texture::before {
  content: ""; position: absolute; inset: 0; z-index: -1; pointer-events: none;
  background-image:
    radial-gradient(60% 50% at 78% 12%, var(--primary-08), transparent 70%),
    linear-gradient(var(--border) 1px, transparent 1px),
    linear-gradient(90deg, var(--border) 1px, transparent 1px);
  background-size: auto, 46px 46px, 46px 46px;
  -webkit-mask-image: radial-gradient(130% 90% at 75% 0%, #000 28%, transparent 78%);
  mask-image: radial-gradient(130% 90% at 75% 0%, #000 28%, transparent 78%);
  opacity: .55;
}

/* ============================= 5. BUTTONS ============================= */
.btn {
  --btn-bg: var(--primary); --btn-fg: #fff;
  display: inline-flex; align-items: center; justify-content: center; gap: .5rem;
  padding: .85rem 1.5rem; border-radius: 0; font-weight: 600; font-size: var(--fs-sm);
  border: 1px solid transparent; position: relative; white-space: nowrap; will-change: transform;
  transition: transform var(--t) var(--ease), box-shadow var(--t) var(--ease), background var(--t), border-color var(--t), color var(--t);
}
.btn:active { transform: translateY(1px) scale(.99); }
.btn .arrow { transition: transform var(--t) var(--ease); }
.btn:hover .arrow { transform: translateX(3px); }
.btn:hover .arrow--ne { transform: translate(2px, -2px); }
.btn svg { flex: none; }

.btn--primary { background: var(--primary); color: var(--bg); box-shadow: var(--shadow-sm); }
.btn--primary:hover { transform: translateY(-2px); background: color-mix(in srgb, var(--primary) 86%, var(--bg)); box-shadow: var(--shadow-md); }
.btn--primary:active { box-shadow: var(--shadow-xs); }
.btn--accent { background: var(--accent); color: #04231a; box-shadow: var(--shadow-sm); }
.btn--accent:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); }
.btn--ghost { background: var(--surface); color: var(--secondary); border-color: var(--border); box-shadow: var(--shadow-xs); }
.btn--ghost:hover { transform: translateY(-2px); border-color: color-mix(in srgb, var(--primary) 40%, var(--border)); box-shadow: var(--shadow-sm); }
.btn--ink { background: var(--ink); color: #fff; }
.btn--ink:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); background: color-mix(in srgb, var(--ink) 88%, #000); }
.btn--on-ink { background: rgba(255,255,255,.10); color: #fff; border-color: var(--on-ink-bd); backdrop-filter: blur(6px); }
.btn--on-ink:hover { background: rgba(255,255,255,.18); transform: translateY(-2px); }
.btn--soft { background: var(--primary-12); color: var(--primary); }
.btn--soft:hover { background: var(--primary-18); transform: translateY(-2px); }
.btn--link { padding: 0; background: none; color: var(--primary); font-weight: 600; }
.btn--link:hover .arrow { transform: translateX(4px); }
.btn--sm { padding: .55rem 1rem; font-size: var(--fs-xs); }
.btn--lg { padding: 1rem 1.85rem; font-size: var(--fs-base); }
.btn--block { width: 100%; }
.btn--icon { padding: .6rem; aspect-ratio: 1; border-radius: 0; }
.btn[disabled], .btn.is-loading { opacity: .6; pointer-events: none; }
.btn.is-loading { color: transparent !important; }
.btn.is-loading::after { content: ""; position: absolute; width: 16px; height: 16px; border-radius: 50%; border: 2px solid rgba(255,255,255,.4); border-top-color: #fff; animation: spin .7s linear infinite; }
.btn--ghost.is-loading::after, .btn--soft.is-loading::after { border-color: var(--primary-18); border-top-color: var(--primary); }
@keyframes spin { to { transform: rotate(360deg); } }

/* ======================== 6. BADGES & STATUS ========================= */
.pill { font-size: var(--fs-2xs); font-weight: 600; padding: .25rem .6rem; border-radius: var(--radius-pill); background: var(--primary-12); color: var(--primary); display: inline-flex; align-items: center; gap: .3rem; }
.pill--soft { background: var(--surface-2); color: var(--muted); border: 1px solid var(--border); }
.pill--accent { background: var(--accent-14); color: var(--primary); }
.pill--live { background: var(--accent-14); color: var(--primary); }
.pill--live .dot, .pulse-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--accent); position: relative; }
.pulse-dot::after { content: ""; position: absolute; inset: -4px; border-radius: 50%; border: 1.5px solid var(--accent); animation: pulse-ring 1.8s ease-out infinite; }
@keyframes pulse-ring { 0% { transform: scale(.6); opacity: .8; } 100% { transform: scale(1.8); opacity: 0; } }

.badge { display: inline-flex; align-items: center; gap: .35rem; font-size: var(--fs-2xs); font-weight: 600; padding: .25rem .6rem; border-radius: var(--radius-pill); letter-spacing: .01em; }
.badge svg { width: 13px; height: 13px; }
.badge--success, .status--live, .status--active, .status--approved, .status--open { background: var(--accent-14); color: var(--primary); }
.badge--warning, .status--review, .status--pending, .status--shortlisted { background: var(--warning-12); color: var(--warning); }
.badge--danger, .status--closed, .status--declined { background: var(--danger-12); color: var(--danger); }
.badge--info, .status--draft, .status--new { background: var(--info-12); color: var(--info); }
.badge--neutral { background: var(--surface-2); color: var(--muted); border: 1px solid var(--border); }
.status { font-size: var(--fs-2xs); font-weight: 600; padding: .25rem .65rem; border-radius: var(--radius-pill); white-space: nowrap; display: inline-flex; align-items: center; gap: .3rem; }
.status--draft { background: var(--surface-2); color: var(--muted); border: 1px solid var(--border); }

.chip {
  font-size: var(--fs-xs); font-weight: 600; padding: .45rem .85rem; border-radius: var(--radius-pill);
  background: var(--surface); border: 1px solid var(--border); color: var(--ink-soft);
  display: inline-flex; align-items: center; gap: .4rem; cursor: pointer;
  transition: all var(--t-fast) var(--ease);
}
.chip:hover { border-color: color-mix(in srgb, var(--primary) 40%, var(--border)); color: var(--secondary); transform: translateY(-1px); }
.chip.is-active { background: var(--primary); color: #fff; border-color: var(--primary); box-shadow: var(--shadow-sm); }
.chip .count { opacity: .6; font-weight: 500; }

.tag-list { display: flex; flex-wrap: wrap; gap: .4rem; }
.tag { font-size: var(--fs-xs); font-weight: 600; padding: .25rem .65rem; border-radius: var(--radius-pill); background: var(--surface-2); border: 1px solid var(--border); color: var(--ink-soft); }

/* ======================== 7. TABS & FILTERS ========================== */
.tabs { display: inline-flex; gap: .25rem; padding: .3rem; background: var(--surface-2); border: 1px solid var(--border); border-radius: var(--radius-pill); position: relative; }
.tabs__btn { padding: .5rem 1.1rem; border-radius: var(--radius-pill); font-weight: 600; font-size: var(--fs-sm); color: var(--muted); position: relative; z-index: 1; transition: color var(--t); white-space: nowrap; }
.tabs__btn.is-active { color: var(--secondary); }
.tabs__glider { position: absolute; top: .3rem; bottom: .3rem; border-radius: var(--radius-pill); background: var(--surface); box-shadow: var(--shadow-sm); transition: transform var(--t) var(--ease), width var(--t) var(--ease); z-index: 0; }
.tab-panel { animation: fade-up .4s var(--ease) backwards; }
.tab-panel[hidden] { display: none; }

.toolbar { display: flex; flex-wrap: wrap; align-items: center; gap: .75rem; }
.search-box { position: relative; flex: 1; min-width: 200px; }
.search-box svg { position: absolute; left: .9rem; top: 50%; transform: translateY(-50%); color: var(--muted); width: 16px; height: 16px; }
.search-box input { width: 100%; padding: .75rem 1rem .75rem 2.4rem; border: 1px solid var(--border); border-radius: var(--radius-pill); background: var(--surface); font-size: var(--fs-sm); transition: border-color var(--t), box-shadow var(--t); }
.search-box input:focus { outline: none; border-color: var(--primary); box-shadow: 0 0 0 4px var(--primary-12); }

.select {
  appearance: none; padding: .72rem 2.4rem .72rem 1rem; border: 1px solid var(--border); border-radius: var(--radius-pill);
  background: var(--surface) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%235B6675' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E") no-repeat right .9rem center;
  font-size: var(--fs-sm); font-weight: 500; color: var(--secondary); cursor: pointer; transition: border-color var(--t), box-shadow var(--t);
}
.select:focus { outline: none; border-color: var(--primary); box-shadow: 0 0 0 4px var(--primary-12); }

.filter-bar { display: flex; flex-wrap: wrap; gap: .5rem; align-items: center; }

/* ============================== 8. FORMS ============================== */
.field { display: grid; gap: .45rem; }
.field + .field { margin-top: 1.1rem; }
.field > label, .field-label { font-size: var(--fs-sm); font-weight: 600; color: var(--secondary); }
.field .hint { font-size: var(--fs-xs); color: var(--muted); }
.field input, .field select, .field textarea, .input {
  width: 100%; padding: .82rem 1rem; border: 1px solid var(--border); border-radius: var(--radius);
  background: var(--bg); font-size: var(--fs-sm); color: var(--text);
  box-shadow: inset 2px 2px 5px color-mix(in srgb, var(--secondary) 7%, transparent), inset -2px -2px 5px rgba(255,255,255,.5);
  transition: border-color var(--t), box-shadow var(--t), background var(--t);
}
:root[data-theme="dark"] .field input, :root[data-theme="dark"] .field select, :root[data-theme="dark"] .field textarea, :root[data-theme="dark"] .input, :root[data-theme="dark"] .search-box input {
  box-shadow: inset 2px 2px 6px rgba(0,0,0,.45), inset -1px -1px 3px rgba(255,255,255,.03);
}
.field textarea { resize: vertical; min-height: 130px; line-height: 1.6; }
.field input:focus, .field select:focus, .field textarea:focus, .input:focus {
  outline: none; border-color: var(--primary); background: var(--surface); box-shadow: 0 0 0 4px var(--primary-12);
}
.field input::placeholder, .field textarea::placeholder { color: color-mix(in srgb, var(--muted) 75%, transparent); }
.field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1.1rem; }
.field-row > .field + .field { margin-top: 0; }

.input-group { position: relative; display: flex; align-items: center; }
.input-group .leading { position: absolute; left: .9rem; color: var(--muted); display: grid; place-items: center; pointer-events: none; }
.input-group .leading + input { padding-left: 2.5rem; }
.input-group .trailing { position: absolute; right: .5rem; }

.check { display: flex; align-items: flex-start; gap: .65rem; font-size: var(--fs-sm); color: var(--ink-soft); cursor: pointer; }
.check input { width: 18px; height: 18px; margin-top: 2px; accent-color: var(--primary); flex: none; }

.form-success { display: none; align-items: center; gap: .6rem; margin-top: 1rem; padding: .85rem 1rem; border-radius: var(--radius-sm); background: var(--accent-14); color: var(--primary); font-weight: 600; font-size: var(--fs-sm); }
.form-success.show { display: flex; animation: fade-up .4s var(--ease); }

.segmented { display: inline-flex; padding: .25rem; gap: .25rem; background: var(--surface-2); border: 1px solid var(--border); border-radius: var(--radius); width: 100%; }
.segmented label { flex: 1; }
.segmented input { position: absolute; opacity: 0; pointer-events: none; }
.segmented .seg { display: flex; align-items: center; justify-content: center; gap: .5rem; padding: .7rem 1rem; border-radius: 0; font-weight: 600; font-size: var(--fs-sm); color: var(--muted); cursor: pointer; transition: all var(--t); }
.segmented input:checked + .seg { background: var(--surface); color: var(--secondary); box-shadow: var(--shadow-sm); }

/* ============================== 9. CARDS ============================= */
.card {
  background: var(--surface); border: var(--bd); border-radius: var(--radius-lg);
  padding: var(--space-4); box-shadow: var(--shadow-xs);
  transition: transform var(--t) var(--ease), box-shadow var(--t) var(--ease), border-color var(--t);
}
.card--pad-lg { padding: clamp(1.5rem, 3vw, 2.25rem); }
.card--hover:hover, .card-lift:hover { transform: translateY(-5px); box-shadow: var(--shadow-lg); border-color: color-mix(in srgb, var(--primary) 26%, var(--border)); }
.card--glass, .glass {
  background: var(--glass-bg);
  backdrop-filter: blur(var(--glass-blur)) saturate(155%); -webkit-backdrop-filter: blur(var(--glass-blur)) saturate(155%);
  border: var(--glass-bd); box-shadow: var(--shadow-md), var(--glass-hi);
}
.card--ink { background: var(--secondary); color: var(--on-ink-70); border-color: var(--on-ink-bd); }
.card--feature { display: grid; gap: .85rem; }

/* Claymorphism — soft 3D surfaces (opt-in via .clay, applied to key cards) */
.clay { background: var(--clay-bg); border: none; border-radius: var(--clay-radius); box-shadow: var(--clay-shadow); }
.feature-card, .price-card, .kpi, .value-card, .empty, .stat-pill {
  box-shadow: var(--clay-shadow-sm);
}
.feature-card:hover, .price-card:hover, .kpi:hover { box-shadow: var(--clay-shadow); }

.feature-ic, .icon-tile {
  width: 52px; height: 52px; border-radius: 0; flex: none;
  background: linear-gradient(145deg, color-mix(in srgb, var(--primary) 20%, var(--surface)), var(--primary-12));
  color: var(--primary); display: grid; place-items: center;
  box-shadow: 4px 4px 10px color-mix(in srgb, var(--secondary) 10%, transparent), -3px -3px 9px rgba(255,255,255,.7), inset 0 1px 0 rgba(255,255,255,.5);
  transition: transform var(--t) var(--ease), background var(--t), box-shadow var(--t);
}
:root[data-theme="dark"] .feature-ic, :root[data-theme="dark"] .icon-tile, :root[data-theme="dark"] .kpi__ic, :root[data-theme="dark"] .empty__ic, :root[data-theme="dark"] .a-ic {
  background: linear-gradient(145deg, color-mix(in srgb, var(--primary) 28%, var(--surface)), var(--surface-2));
  box-shadow: 4px 4px 10px rgba(0,0,0,.5), -2px -2px 7px rgba(255,255,255,.04), inset 0 1px 0 rgba(255,255,255,.05);
}
.card--hover:hover .feature-ic, .feature-card:hover .feature-ic { transform: scale(1.06) rotate(-3deg); }
.icon-tile--accent { background: var(--accent-14); }
.icon-tile--lg { width: 56px; height: 56px; border-radius: var(--radius-md); }
.feature-ic svg, .icon-tile svg { width: 23px; height: 23px; }
.icon-tile--lg svg, .empty__ic svg { width: 28px; height: 28px; }
.kpi__ic svg, .a-ic svg, .activity .a-ic svg { width: 18px; height: 18px; }
.contact-meta .ic svg { width: 20px; height: 20px; }

.feature-card { background: var(--surface); border: var(--bd); border-radius: var(--radius-lg); padding: var(--space-4); box-shadow: var(--shadow-xs); transition: transform var(--t) var(--ease), box-shadow var(--t), border-color var(--t); }
.feature-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); border-color: color-mix(in srgb, var(--primary) 26%, var(--border)); }
.feature-card h3 { font-family: var(--font-body); font-size: var(--fs-h4); font-weight: 600; color: var(--secondary); margin-top: 1rem; }
.feature-card p { color: var(--muted); font-size: var(--fs-sm); margin-top: .4rem; }

.benefit-list { display: grid; gap: .1rem; }
.benefit-list li { display: flex; align-items: flex-start; gap: .8rem; padding: .75rem 0; border-bottom: 1px solid color-mix(in srgb, var(--border) 70%, transparent); font-weight: 500; color: var(--secondary); }
.benefit-list li:last-child { border-bottom: none; }
.benefit-list .tick { width: 24px; height: 24px; border-radius: 50%; flex: none; margin-top: 1px; background: var(--primary-12); color: var(--primary); display: grid; place-items: center; }

.avatar { border-radius: 50%; flex: none; background: linear-gradient(135deg, var(--accent), var(--primary)); display: grid; place-items: center; color: #fff; font-weight: 600; box-shadow: var(--shadow-inset-hi); }
.avatar--sm { width: 32px; height: 32px; font-size: var(--fs-xs); }
.avatar--md { width: 44px; height: 44px; font-size: var(--fs-sm); }
.avatar--lg { width: 64px; height: 64px; font-size: var(--fs-lg); }

/* ====================== 10. HEADER / NAVIGATION ====================== */
.site-header {
  position: sticky; top: 0; z-index: 100;
  transition: background var(--t) var(--ease), box-shadow var(--t) var(--ease), border-color var(--t);
  border-bottom: 1px solid transparent;
}
.site-header.is-stuck {
  background: color-mix(in srgb, var(--bg) 72%, transparent);
  backdrop-filter: saturate(180%) blur(18px); -webkit-backdrop-filter: saturate(180%) blur(18px);
  border-bottom-color: var(--border); box-shadow: var(--shadow-xs);
}
body[data-layout="app"] .site-header, body[data-layout="auth"] .site-header,
body[data-layout="app"] .site-footer, body[data-layout="auth"] .site-footer { display: none; }

.header-inner { display: flex; align-items: center; gap: 1.5rem; height: var(--header-h); }
.brand { display: inline-flex; align-items: center; gap: .6rem; font-family: var(--font-heading); font-weight: 700; font-size: 1.32rem; color: var(--secondary); letter-spacing: -.03em; }
.brand-mark {
  width: 38px; height: 38px; border-radius: 0; flex: none;
  background: var(--ink); border: 1px solid color-mix(in srgb, #fff 14%, transparent);
  display: grid; place-items: center; color: #fff;
  box-shadow: var(--shadow-sm);
  transition: transform var(--t) var(--ease), box-shadow var(--t);
}
.brand-mark .gbx-glyph { width: 24px; height: 24px; }
.brand:hover .brand-mark { transform: rotate(-5deg) scale(1.06); box-shadow: var(--shadow-md), 0 0 0 3px color-mix(in srgb, var(--secondary) 12%, transparent); }
.brand img { height: 32px; width: auto; }

.nav-desktop { display: flex; gap: .15rem; margin-inline: auto; }
.nav-desktop a { padding: .5rem .8rem; border-radius: var(--radius-xs); color: var(--ink-soft); font-weight: 500; font-size: var(--fs-sm); position: relative; transition: color var(--t-fast), background var(--t-fast); }
.nav-desktop a:hover { color: var(--secondary); background: var(--primary-08); }
.nav-desktop a.is-active { color: var(--primary); }
.nav-desktop a.is-active::after { content: ""; position: absolute; left: .8rem; right: .8rem; bottom: 2px; height: 2px; border-radius: 0; background: var(--primary); }

.header-actions { display: flex; align-items: center; gap: .6rem; }
.header-actions .login { padding: .5rem .85rem; border-radius: var(--radius-xs); font-weight: 600; font-size: var(--fs-sm); color: var(--secondary); transition: background var(--t-fast); }
.header-actions .login:hover { background: var(--primary-08); }

.nav-toggle { display: none; flex-direction: column; gap: 5px; width: 44px; height: 44px; border: 1px solid var(--border); border-radius: var(--radius-sm); background: var(--surface); align-items: center; justify-content: center; }
.nav-toggle span { width: 18px; height: 2px; background: var(--secondary); border-radius: 0; transition: transform var(--t) var(--ease), opacity var(--t-fast); }
.nav-toggle[aria-expanded="true"] span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.nav-toggle[aria-expanded="true"] span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

.mobile-nav { display: none; flex-direction: column; gap: .2rem; padding: 1rem clamp(1.25rem, 4vw, 2.5rem) 1.5rem; background: color-mix(in srgb, var(--bg) 94%, transparent); backdrop-filter: blur(18px); border-bottom: 1px solid var(--border); }
.mobile-nav a { padding: .85rem .5rem; border-radius: var(--radius-sm); font-weight: 500; color: var(--ink-soft); border-bottom: 1px solid color-mix(in srgb, var(--border) 60%, transparent); }
.mobile-nav .mobile-cta { margin-top: .75rem; display: grid; gap: .6rem; }

/* ============================= 11. FOOTER ============================ */
.site-footer { background: var(--ink); color: var(--on-ink-70); padding-block: clamp(3rem, 6vw, 4.5rem) 2rem; margin-top: clamp(3rem, 6vw, 5rem); position: relative; overflow: hidden; }
.site-footer::before { content: ""; position: absolute; inset: 0; pointer-events: none; background: radial-gradient(60% 80% at 88% 0%, color-mix(in srgb, var(--accent) 18%, transparent), transparent 60%); }
.footer-top { display: grid; grid-template-columns: 1.5fr repeat(4, 1fr); gap: 2rem; position: relative; }
.footer-brand .brand { color: #fff; margin-bottom: 1rem; }
.footer-brand p { font-size: var(--fs-sm); max-width: 30ch; }
.footer-cta { margin-top: 1.4rem; }
.footer-socials { display: flex; gap: .6rem; margin-top: 1.4rem; }
.footer-socials a { width: 40px; height: 40px; border-radius: var(--radius-sm); border: 1px solid var(--on-ink-bd); display: grid; place-items: center; color: rgba(255,255,255,.8); transition: background var(--t), transform var(--t), border-color var(--t); }
.footer-socials a:hover { background: rgba(255,255,255,.1); transform: translateY(-3px); border-color: rgba(255,255,255,.3); color: #fff; }
.footer-col h4 { font-family: var(--font-body); color: #fff; font-size: var(--fs-2xs); text-transform: uppercase; letter-spacing: .08em; font-weight: 600; margin-bottom: 1.1rem; }
.footer-col a { display: block; padding: .35rem 0; color: rgba(255,255,255,.7); font-size: var(--fs-sm); transition: color var(--t-fast), padding-left var(--t-fast); }
.footer-col a:hover { color: #fff; padding-left: 5px; }
.footer-bottom { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 1rem; margin-top: clamp(2.5rem, 5vw, 4rem); padding-top: 1.75rem; border-top: 1px solid var(--on-ink-bd); font-size: var(--fs-sm); position: relative; }
.footer-bottom .made { display: flex; align-items: center; gap: .5rem; }
.footer-bottom .made .dot { width: 7px; height: 7px; border-radius: 50%; background: var(--accent); }

/* ============================== 12. MODAL =========================== */
.modal-root { position: fixed; inset: 0; z-index: 1000; display: grid; place-items: center; padding: 1.5rem; }
.modal-backdrop { position: absolute; inset: 0; background: color-mix(in srgb, var(--ink) 58%, transparent); backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px); opacity: 0; transition: opacity var(--t); }
.modal-root.is-open .modal-backdrop { opacity: 1; }
.modal {
  position: relative; width: 100%; max-width: 480px;
  max-height: min(88dvh, 760px); overflow-y: auto; -webkit-overflow-scrolling: touch;
  background: var(--glass-bg); backdrop-filter: blur(var(--glass-blur)) saturate(150%);
  -webkit-backdrop-filter: blur(var(--glass-blur)) saturate(150%);
  border: var(--glass-bd); border-radius: var(--radius-xl);
  box-shadow: var(--shadow-xl), var(--glass-hi); padding: clamp(1.35rem, 3.5vw, 2.25rem);
  transform: translateY(18px) scale(.98); opacity: 0; transition: transform var(--t) var(--ease), opacity var(--t);
}
.modal-root.is-open .modal { transform: none; opacity: 1; }
.modal__close { position: absolute; top: .85rem; right: .85rem; width: 40px; height: 40px; border-radius: var(--radius-sm); display: grid; place-items: center; color: var(--muted); background: color-mix(in srgb, var(--surface) 50%, transparent); transition: background var(--t-fast), color var(--t-fast); z-index: 2; }
.modal__close:hover { background: var(--surface-2); color: var(--secondary); }
.modal h3 { margin-bottom: .5rem; padding-right: 2.5rem; }
body.modal-open { overflow: hidden; }

/* Mobile: dock the modal to the bottom as a sheet with a grab handle */
@media (max-width: 560px) {
  .modal-root { place-items: end stretch; padding: 0; }
  .modal {
    max-width: none; max-height: 92dvh; border-radius: var(--radius-xl) var(--radius-xl) 0 0;
    padding: 1.5rem 1.25rem calc(1.25rem + env(safe-area-inset-bottom, 0px));
    transform: translateY(100%);
  }
  .modal::before { content: ""; position: sticky; top: 0; display: block; width: 42px; height: 4px; margin: -.25rem auto 1rem; border-radius: 0; background: color-mix(in srgb, var(--muted) 45%, transparent); }
  .modal-root.is-open .modal { transform: none; }
}

/* Toast */
.toast-wrap { position: fixed; bottom: 1.5rem; left: 50%; transform: translateX(-50%); z-index: 1200; display: grid; gap: .5rem; width: min(92vw, 420px); }
.toast { display: flex; align-items: center; gap: .7rem; padding: .85rem 1.1rem; border-radius: var(--radius); background: var(--ink); color: #fff; box-shadow: var(--shadow-lg); font-size: var(--fs-sm); font-weight: 500; animation: toast-in .4s var(--ease); }
.toast .ic { color: var(--accent); display: grid; place-items: center; }
@keyframes toast-in { from { opacity: 0; transform: translateY(12px); } }

/* ==================== 13. PRODUCT UI PRIMITIVES ===================== */
.panel { background: var(--surface); border: var(--bd); border-radius: var(--radius-lg); box-shadow: var(--shadow-lg); overflow: hidden; }
.panel-glass { background: color-mix(in srgb, var(--surface) 82%, transparent); backdrop-filter: blur(20px) saturate(160%); -webkit-backdrop-filter: blur(20px) saturate(160%); border: 1px solid color-mix(in srgb, #fff 60%, var(--border)); }

.app-window { border-radius: var(--radius-lg); }
.app-bar { display: flex; align-items: center; gap: .8rem; padding: .85rem 1.1rem; border-bottom: var(--bd); background: color-mix(in srgb, var(--surface) 96%, var(--secondary)); }
.app-dots { display: flex; gap: 6px; }
.app-dots i { width: 11px; height: 11px; border-radius: 50%; background: var(--border); }
.app-dots i:nth-child(1) { background: #F3A8A0; } .app-dots i:nth-child(2) { background: #F3D6A0; } .app-dots i:nth-child(3) { background: #A8D9B5; }
.app-search { flex: 1; height: 30px; border-radius: 0; background: var(--bg); border: var(--bd); display: flex; align-items: center; padding: 0 .7rem; gap: .5rem; color: var(--muted); font-size: var(--fs-2xs); }
.app-body { padding: 1.1rem; display: grid; gap: .9rem; }

.dash-head { display: flex; justify-content: space-between; align-items: center; gap: .75rem; }
.dash-head h4 { font-family: var(--font-body); font-size: var(--fs-sm); font-weight: 600; color: var(--secondary); }

.metric-row { display: grid; grid-template-columns: repeat(3, 1fr); gap: .7rem; }
.metric { background: var(--bg); border: var(--bd); border-radius: var(--radius); padding: .85rem; }
.metric .label { font-size: var(--fs-2xs); color: var(--muted); }
.metric .value { font-family: var(--font-heading); font-size: 1.4rem; color: var(--secondary); margin-top: .2rem; }
.metric .trend { font-size: var(--fs-2xs); font-weight: 600; color: var(--accent); display: inline-flex; align-items: center; gap: 3px; margin-top: .15rem; }
.metric .trend--down { color: var(--danger); }

/* mini bar chart */
.chart { display: flex; align-items: flex-end; gap: 7px; height: 80px; padding-top: .4rem; }
.chart span { flex: 1; background: linear-gradient(var(--accent), var(--primary)); border-radius: 0; opacity: .9; transform-origin: bottom; animation: grow-bar .9s var(--ease) backwards; }
@keyframes grow-bar { from { transform: scaleY(.12); opacity: .2; } }

/* line/area chart (SVG) */
.spark { width: 100%; height: auto; display: block; overflow: visible; }
.spark .area { opacity: .14; }
.spark .line { fill: none; stroke: var(--primary); stroke-width: 2.5; stroke-linecap: round; stroke-linejoin: round; }
.spark .line.draw { stroke-dasharray: var(--len); stroke-dashoffset: var(--len); animation: draw 1.4s var(--ease) forwards; }
@keyframes draw { to { stroke-dashoffset: 0; } }
.spark .dot { fill: var(--primary); }

/* list rows (creator/opportunity/application) */
.row { display: flex; align-items: center; gap: .7rem; padding: .65rem; border-radius: var(--radius); background: var(--bg); border: var(--bd); transition: border-color var(--t-fast), background var(--t-fast); }
.row + .row { margin-top: .1rem; }
.row.is-clickable:hover { border-color: color-mix(in srgb, var(--primary) 30%, var(--border)); background: var(--surface); }
.row .avatar, .row .logo-sq { width: 36px; height: 36px; flex: none; }
.row .logo-sq { border-radius: 0; background: linear-gradient(135deg, var(--primary), var(--accent)); display: grid; place-items: center; color: #fff; font-weight: 600; font-size: var(--fs-xs); }
.row .who { flex: 1; min-width: 0; }
.row .who b { display: block; font-size: var(--fs-sm); color: var(--secondary); font-weight: 600; }
.row .who small { color: var(--muted); font-size: var(--fs-2xs); }

/* progress ring + bar */
.ring { --p: 72; width: 56px; height: 56px; border-radius: 50%; display: grid; place-items: center; flex: none; background: conic-gradient(var(--primary) calc(var(--p) * 1%), var(--border) 0); }
.ring::after { content: attr(data-label); width: 42px; height: 42px; border-radius: 50%; background: var(--surface); display: grid; place-items: center; font-size: var(--fs-xs); font-weight: 700; color: var(--secondary); }
.progress { height: 8px; border-radius: 0; background: var(--surface-2); overflow: hidden; }
.progress > i { display: block; height: 100%; border-radius: 0; background: linear-gradient(90deg, var(--accent), var(--primary)); width: 0; transition: width 1s var(--ease); }

/* floating dashboard card (hero) */
.float-card { position: absolute; padding: 1rem; border-radius: var(--radius-md); box-shadow: var(--shadow-lg); animation: float 6s ease-in-out infinite; }
@keyframes float { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(-12px); } }
.float-card .fc-top { display: flex; align-items: center; gap: .6rem; margin-bottom: .7rem; }
.float-card .fc-ic { width: 32px; height: 32px; border-radius: 0; background: var(--primary-12); color: var(--primary); display: grid; place-items: center; }
.float-card .fc-top b { font-size: var(--fs-sm); color: var(--secondary); }
.float-card .fc-top small { display: block; color: var(--muted); font-size: var(--fs-2xs); }
.fc-stat { display: flex; align-items: center; gap: .8rem; }
.fc-stat .fc-meta b { font-family: var(--font-heading); font-size: 1.1rem; color: var(--secondary); }
.fc-stat .fc-meta small { color: var(--muted); font-size: var(--fs-2xs); }

/* ========================= 14. EMPTY STATES ========================= */
.empty {
  display: grid; justify-items: center; text-align: center; gap: .85rem;
  padding: clamp(2.5rem, 6vw, 4.5rem) 1.5rem; border: 1.5px dashed color-mix(in srgb, var(--border) 100%, transparent);
  border-radius: var(--radius-lg); background:
    radial-gradient(80% 100% at 50% 0%, var(--primary-04), transparent 70%), var(--surface);
}
.empty__ic { width: 66px; height: 66px; border-radius: 0; background: linear-gradient(145deg, color-mix(in srgb, var(--primary) 20%, var(--surface)), var(--primary-12)); color: var(--primary); display: grid; place-items: center; box-shadow: 5px 5px 12px color-mix(in srgb, var(--secondary) 10%, transparent), -4px -4px 11px rgba(255,255,255,.7), inset 0 1px 0 rgba(255,255,255,.5); }
.empty h3 { font-size: var(--fs-h3); }
.empty p { color: var(--muted); max-width: 44ch; }
.empty__actions { display: flex; flex-wrap: wrap; gap: .6rem; justify-content: center; margin-top: .5rem; }

.demo-banner {
  display: inline-flex; align-items: center; gap: .5rem; font-size: var(--fs-xs); font-weight: 600;
  color: var(--warning); background: var(--warning-12); border: 1px solid color-mix(in srgb, var(--warning) 25%, transparent);
  padding: .4rem .85rem; border-radius: var(--radius-pill);
}

/* ============================== 15. MOTION ========================== */
[data-reveal] { opacity: 0; transform: translateY(24px); transition: opacity var(--t-slow) var(--ease-out), transform var(--t-slow) var(--ease-out); transition-delay: var(--d, 0ms); }
[data-reveal].is-visible { opacity: 1; transform: none; }
[data-reveal="fade"] { transform: none; }
[data-reveal="left"] { transform: translateX(-28px); }
[data-reveal="right"] { transform: translateX(28px); }
[data-reveal="scale"] { transform: scale(.96); }

.reveal-text { display: inline-block; }
.reveal-text .word { display: inline-block; opacity: 0; transform: translateY(0.5em); transition: opacity .6s var(--ease-out), transform .6s var(--ease-out); transition-delay: calc(var(--i, 0) * 55ms); }
.is-visible .reveal-text .word { opacity: 1; transform: none; }

@keyframes fade-up { from { opacity: 0; transform: translateY(14px); } }
@keyframes fade-in { from { opacity: 0; } }
.page-enter { animation: page-enter .5s var(--ease); }
@keyframes page-enter { from { opacity: 0; transform: translateY(8px); } }

/* View Transitions (smooth cross-page) */
::view-transition-old(root) { animation: vt-out .28s var(--ease) both; }
::view-transition-new(root) { animation: vt-in .42s var(--ease) both; }
@keyframes vt-out { to { opacity: 0; transform: translateY(-6px); } }
@keyframes vt-in { from { opacity: 0; transform: translateY(10px); } }

.cursor-glow { position: fixed; top: 0; left: 0; width: 380px; height: 380px; border-radius: 50%; background: radial-gradient(circle, var(--primary-08), transparent 65%); pointer-events: none; z-index: 0; transform: translate(-50%, -50%); opacity: 0; transition: opacity .4s ease; mix-blend-mode: multiply; }
@media (hover: none) { .cursor-glow { display: none; } }
.parallax { will-change: transform; }

@media (hover: hover) and (prefers-reduced-motion: no-preference) {
  .tilt-stack { transition: transform .4s var(--ease); transform-style: preserve-3d; }
}

/* ====================== 17. PREMIUM POLISH ========================= */
/* scroll progress bar (top of viewport) */
#scroll-progress { position: fixed; top: 0; left: 0; height: 3px; width: 0; z-index: 300; background: linear-gradient(90deg, var(--primary), var(--accent)); box-shadow: 0 0 12px color-mix(in srgb, var(--accent) 60%, transparent); transition: width .1s linear; pointer-events: none; }

/* animated gradient accent word in headings */
.accent-word {
  background: linear-gradient(100deg, var(--primary), var(--accent), color-mix(in srgb, var(--accent) 60%, #6fe9b8), var(--primary));
  background-size: 250% 100%; -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent; color: transparent; font-style: normal;
  animation: accent-flow 6s ease-in-out infinite;
}
@keyframes accent-flow { 0%,100% { background-position: 0% 50%; } 50% { background-position: 100% 50%; } }

/* aurora background blobs for heroes / ink sections */
.aurora { position: relative; isolation: isolate; }
.aurora::after {
  content: ""; position: absolute; inset: -10% -5% auto -5%; height: 120%; z-index: -1; pointer-events: none;
  background:
    radial-gradient(46% 55% at 85% 8%, color-mix(in srgb, var(--secondary) 7%, transparent), transparent 72%);
  filter: blur(26px); opacity: .8; animation: aurora-drift 18s ease-in-out infinite alternate;
}
@keyframes aurora-drift { 0% { transform: translate3d(0,0,0) scale(1); } 100% { transform: translate3d(-3%, 2%, 0) scale(1.08); } }

/* shimmer sweep on premium buttons */
.btn--primary { overflow: hidden; }
.btn--primary::after {
  content: ""; position: absolute; top: 0; left: -120%; width: 60%; height: 100%;
  background: linear-gradient(100deg, transparent, rgba(255,255,255,.28), transparent); transform: skewX(-18deg);
}
.btn--primary:hover::after { animation: btn-sheen .9s ease; }
@keyframes btn-sheen { to { left: 140%; } }

/* gradient hairline at the top of raised cards on hover */
.card-lift, .feature-card, .opp-card, .kpi, .price-card { position: relative; }
.feature-card::before, .opp-card::before, .price-card::before {
  content: ""; position: absolute; inset: 0 0 auto 0; height: 2px; border-radius: 0 0 0;
  background: linear-gradient(90deg, transparent, var(--accent), transparent); opacity: 0; transition: opacity var(--t);
}
.feature-card:hover::before, .opp-card:hover::before, .price-card:hover::before { opacity: .9; }

/* section eyebrow gets a subtle live dot */
.eyebrow--pill { position: relative; }

/* nicer focus ring on dark */
:root[data-theme="dark"] :focus-visible { outline-color: var(--accent); }

/* count-up numbers use tabular figures so they don't jitter */
.value, .kpi .value, .stat-block .value, [data-count] { font-variant-numeric: tabular-nums; }

/* ============================= 16. UTILITIES ======================== */
.mt-1 { margin-top: var(--space-1); } .mt-2 { margin-top: var(--space-2); } .mt-3 { margin-top: var(--space-3); }
.mt-4 { margin-top: var(--space-4); } .mt-5 { margin-top: var(--space-5); } .mt-6 { margin-top: var(--space-6); }
.mb-0 { margin-bottom: 0; } .mb-4 { margin-bottom: var(--space-4); }
.text-center { text-align: center; }
.hide { display: none !important; }
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }
.divider { height: 1px; background: var(--border); border: none; }
.full-bleed { width: 100%; }
.nowrap { white-space: nowrap; }
.gap-sm { gap: .5rem; } .gap-md { gap: 1rem; }
.flex { display: flex; } .items-center { align-items: center; } .justify-between { justify-content: space-between; }
.grow { flex: 1; }

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { animation-duration: .001ms !important; animation-iteration-count: 1 !important; transition-duration: .001ms !important; }
  [data-reveal] { opacity: 1 !important; transform: none !important; }
  .reveal-text .word { opacity: 1 !important; transform: none !important; }
  .float-card { animation: none !important; }
}
