/* ============================================================
   CLOUTYX DESIGN SYSTEM — Colors & Type
   Dutch modular business software. Two themes:
   - DARK (marketing site, product-page variants): glassmorphic
   - LIGHT (default app surface): clean enterprise ERP
   Always import Inter (300–800).
   ============================================================ */

@import url("https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&family=Exo+2:wght@500;600;700;800;900&family=Space+Grotesk:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500;600&display=swap");

:root {
  /* ── FONTS ────────────────────────────────────────────── */
  --font-sans: "Inter", system-ui, -apple-system, "Segoe UI", sans-serif;
  --font-head: "Exo 2", "Inter", system-ui, sans-serif;       /* display headings — matches app */
  --font-sub:  "Space Grotesk", "Inter", system-ui, sans-serif; /* UI labels, eyebrows */
  --font-mono: "JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;

  /* ── BRAND COLOR (module-agnostic, used everywhere) ──── */
  --brand-orange:        #E07000;
  --brand-orange-hi:     #F57C00;
  --brand-orange-lo:     #FFB74D;
  --grad-brand:          linear-gradient(135deg, #E07000, #F57C00, #FFB74D);
  --grad-indigo:         linear-gradient(135deg, #6366f1, #a855f7, #ec4899);
  /* Master-gradient: spiegelt de login-knop (purple → blue → teal → green) */
  --grad-master:         linear-gradient(135deg, #9B45B0 0%, #2B7FBF 35%, #1E8C82 65%, #4CAF50 100%);
  --grad-master-soft:    linear-gradient(90deg,  #9B45B0, #2B7FBF, #1E8C82, #4CAF50);
  --shadow-master:       0 8px 24px rgba(155,69,176,0.25), 0 4px 12px rgba(76,175,80,0.18);
  --shadow-master-hi:    0 10px 28px rgba(155,69,176,0.35), 0 6px 16px rgba(76,175,80,0.25);

  /* ── MODULE ACCENTS — exact match met de in-app waarden ─ */
  --mod-warehouse:       #E07000; /* 📦 oranje — default module */
  --mod-warehouse-hi:    #F57C00;
  --mod-purchasing:      #2B7FBF; /* 🛒 blauw */
  --mod-purchasing-hi:   #3A9BD5;
  --mod-production:      #7B2D8E; /* 🏭 paars */
  --mod-production-hi:   #9B45B0;
  --mod-finance:         #4CAF50; /* 💰 groen */
  --mod-finance-hi:      #66BB6A;
  --mod-support:         #1E8C82; /* 🎧 teal */
  --mod-support-hi:      #26A69A;

  /* ── SEMANTIC STATUS ─────────────────────────────────── */
  --status-success:      #34D399;
  --status-success-bg:   rgba(52, 211, 153, 0.12);
  --status-warning:      #F59E0B;
  --status-warning-bg:   rgba(245, 158, 11, 0.12);
  --status-danger:       #EF4444;
  --status-danger-bg:    rgba(239, 68, 68, 0.12);
  --status-info:         #3B82F6;
  --status-info-bg:      rgba(59, 130, 246, 0.12);

  /* ── DARK THEME — uitgelijnd met login-pagina (warm cream op donker) ── */
  --bg:                  #0a0a0d;
  --bg2:                 #141210;
  --bg3:                 #1c1916;
  --fg1:                 #f0ebe0; /* primary text — warm cream */
  --fg2:                 rgba(240, 235, 224, 0.62); /* secondary text */
  --fg3:                 rgba(240, 235, 224, 0.42); /* tertiary / captions */
  --glass:               rgba(255, 255, 255, 0.04);
  --glass-2:             rgba(255, 255, 255, 0.07);
  --glass-3:             rgba(255, 255, 255, 0.10);
  --border:              rgba(255, 255, 255, 0.08);
  --border-2:            rgba(255, 255, 255, 0.14);

  /* ── LIGHT THEME (app, data-dense ERP surfaces) ──────── */
  --light-bg:            #F7F7FA;
  --light-surface:       #FFFFFF;
  --light-surface-2:     #FAFAFC;
  --light-fg1:           #1A1736;
  --light-fg2:           #5A5678;
  --light-fg3:           #9490B0;
  --light-border:        #E8E6F0;
  --light-border-2:      #D4D1E4;

  /* ── RADIUS ──────────────────────────────────────────── */
  --r-4:   4px;
  --r-8:   8px;
  --r-12:  12px;
  --r-16:  16px;
  --r-20:  20px;
  --r-24:  24px;
  --r-full: 9999px;

  /* ── SPACING (4-based) ───────────────────────────────── */
  --sp-1:  4px;
  --sp-2:  8px;
  --sp-3:  12px;
  --sp-4:  16px;
  --sp-5:  20px;
  --sp-6:  24px;
  --sp-8:  32px;
  --sp-10: 40px;
  --sp-12: 48px;
  --sp-16: 64px;
  --sp-24: 96px;

  /* ── SHADOWS ─────────────────────────────────────────── */
  --shadow-sm:   0 1px 2px rgba(17, 14, 36, 0.06);
  --shadow-md:   0 4px 12px rgba(17, 14, 36, 0.08);
  --shadow-lg:   0 12px 32px rgba(17, 14, 36, 0.12);
  --shadow-xl:   0 20px 50px rgba(0, 0, 0, 0.30);         /* dark-theme lift */
  --shadow-brand: 0 12px 32px rgba(224, 112, 0, 0.30);    /* orange glow */
  --shadow-indigo: 0 12px 32px rgba(99, 102, 241, 0.25);

  /* ── BLUR TOKENS ─────────────────────────────────────── */
  --blur-sm: blur(10px);
  --blur-md: blur(20px);
  --blur-lg: blur(30px);

  /* ── MOTION ──────────────────────────────────────────── */
  --ease:          cubic-bezier(0.4, 0, 0.2, 1);
  --ease-spring:   cubic-bezier(0.34, 1.56, 0.64, 1);
  --dur-fast:      150ms;
  --dur-base:      300ms;
  --dur-slow:      600ms;

  /* ── TYPE SCALE (base = 16px) ────────────────────────── */
  --fs-xs:    0.70rem;   /* 11.2 — captions, badges, eyebrow */
  --fs-sm:    0.80rem;   /* 12.8 — small body, table cells */
  --fs-base:  0.90rem;   /* 14.4 — body */
  --fs-md:    1.00rem;   /* 16   — body lg */
  --fs-lg:    1.15rem;   /* 18.4 — lede */
  --fs-xl:    1.50rem;   /* 24   — h3 */
  --fs-2xl:   1.70rem;   /* 27.2 — h2 */
  --fs-3xl:   2.20rem;   /* 35.2 — section title */
  --fs-4xl:   clamp(2.6rem, 6vw, 4.5rem); /* hero */

  --lh-tight:  1.12;
  --lh-snug:   1.35;
  --lh-body:   1.6;
  --lh-loose:  1.7;

  --tr-tight:  -0.04em;   /* hero, H1 */
  --tr-snug:   -0.03em;   /* section titles */
  --tr-normal: -0.01em;
  --tr-wide:   2px;       /* eyebrow tags */
  --tr-caps:   1.5px;     /* footer column heads */
}

/* ============================================================
   BASE ELEMENTS
   ============================================================ */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; overflow-x: hidden; }
body {
  font-family: var(--font-sans);
  font-size: var(--fs-base);
  line-height: var(--lh-body);
  color: var(--fg1);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
  width: 100%;
}

/* All heading elements inherit the display font (matches in-app design system) */
h1, h2, h3, h4 { font-family: var(--font-head); }

/* ── TYPE ROLES ─────────────────────────────────────────── */
.t-hero {
  font-family: var(--font-head);
  font-size: var(--fs-4xl);
  font-weight: 800;
  line-height: var(--lh-tight);
  letter-spacing: var(--tr-tight);
}
.t-h1 {
  font-family: var(--font-head);
  font-size: var(--fs-3xl);
  font-weight: 800;
  line-height: var(--lh-tight);
  letter-spacing: var(--tr-snug);
}
.t-h2 {
  font-family: var(--font-head);
  font-size: var(--fs-2xl);
  font-weight: 800;
  line-height: 1.2;
  letter-spacing: -0.02em;
}
.t-h3 {
  font-family: var(--font-head);
  font-size: var(--fs-xl);
  font-weight: 700;
  line-height: var(--lh-snug);
  letter-spacing: var(--tr-normal);
}
.t-body {
  font-size: var(--fs-base);
  line-height: var(--lh-loose);
  color: var(--fg2);
}
.t-small {
  font-size: var(--fs-sm);
  line-height: var(--lh-body);
  color: var(--fg2);
}
.t-caption {
  font-size: var(--fs-xs);
  color: var(--fg3);
  line-height: var(--lh-body);
}
.t-eyebrow {
  font-family: var(--font-sub);
  font-size: var(--fs-xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: var(--tr-wide);
  color: var(--fg2);
}
.t-eyebrow-grad {
  font-family: var(--font-sub);
  font-size: var(--fs-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.22em;
  background: var(--grad-master-soft);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.t-grad {
  background: var(--grad-brand);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.t-mono {
  font-family: var(--font-mono);
  font-size: var(--fs-sm);
}

/* ── GLASS UTILITIES ────────────────────────────────────── */
.glass {
  background: var(--glass);
  backdrop-filter: var(--blur-md);
  -webkit-backdrop-filter: var(--blur-md);
  border: 1px solid var(--border);
  border-radius: var(--r-16);
}
.glass-strong {
  background: var(--glass-2);
  backdrop-filter: var(--blur-lg);
  -webkit-backdrop-filter: var(--blur-lg);
  border: 1px solid var(--border-2);
  border-radius: var(--r-16);
}

/* ── PRIMARY BUTTON — spiegelt de login-knop ─────────────── */
.cx-btn-master {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 14px 30px;
  background: var(--grad-master);
  background-size: 200% 200%;
  background-position: 0% 50%;
  color: #fff;
  border: none;
  border-radius: var(--r-full);
  font-family: var(--font-head);
  font-size: 13.5px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  cursor: pointer;
  box-shadow: var(--shadow-master);
  transition: background-position .4s var(--ease), box-shadow .2s var(--ease), transform .1s var(--ease);
}
.cx-btn-master:hover {
  background-position: 100% 50%;
  box-shadow: var(--shadow-master-hi);
}
.cx-btn-master:active { transform: scale(0.98); }

.cx-btn-ghost {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 14px 28px;
  background: var(--glass);
  backdrop-filter: var(--blur-md);
  border: 1px solid var(--border-2);
  color: var(--fg1);
  border-radius: var(--r-full);
  font-family: var(--font-head);
  font-size: 13.5px;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  cursor: pointer;
  transition: background .2s var(--ease), border-color .2s var(--ease);
}
.cx-btn-ghost:hover { background: var(--glass-2); border-color: rgba(255,255,255,0.22); }

/* ── PAGE BACKGROUND — login-style: 4 orbs + hexagons ────── */
@keyframes cx-orb-1 { 0%,100% { transform: translate(0,0) scale(1) } 50% { transform: translate(60px,-40px) scale(1.15) } }
@keyframes cx-orb-2 { 0%,100% { transform: translate(0,0) scale(1) } 50% { transform: translate(-50px,50px) scale(1.1) } }
@keyframes cx-orb-3 { 0%,100% { transform: translate(0,0) scale(1) } 50% { transform: translate(40px,30px) scale(1.2) } }
@keyframes cx-orb-4 { 0%,100% { transform: translate(0,0) scale(1) } 50% { transform: translate(-40px,-50px) scale(1.05) } }
.cx-page-bg { position: fixed; inset: 0; z-index: 0; pointer-events: none; overflow: hidden; }
.cx-orb { position: absolute; border-radius: 50%; }
.cx-orb-1 { left: -10%; top: -10%; width: 60vw; height: 60vw; max-width: 600px; max-height: 600px;
  background: radial-gradient(circle, rgba(155,69,176,0.42) 0%, transparent 65%);
  filter: blur(40px); animation: cx-orb-1 18s ease-in-out infinite; }
.cx-orb-2 { right: -15%; top: 30%; width: 55vw; height: 55vw; max-width: 520px; max-height: 520px;
  background: radial-gradient(circle, rgba(38,166,154,0.36) 0%, transparent 65%);
  filter: blur(45px); animation: cx-orb-2 22s ease-in-out infinite; }
.cx-orb-3 { left: 20%; bottom: -15%; width: 65vw; height: 65vw; max-width: 640px; max-height: 640px;
  background: radial-gradient(circle, rgba(76,175,80,0.30) 0%, transparent 65%);
  filter: blur(50px); animation: cx-orb-3 25s ease-in-out infinite; }
.cx-orb-4 { right: 10%; top: 5%; width: 40vw; height: 40vw; max-width: 400px; max-height: 400px;
  background: radial-gradient(circle, rgba(43,127,191,0.32) 0%, transparent 65%);
  filter: blur(40px); animation: cx-orb-4 20s ease-in-out infinite; }
.cx-hex-overlay { position: fixed; inset: 0; width: 100%; height: 100%;
  opacity: 0.05; pointer-events: none; z-index: 0; }

/* ── 5-ITEM FEATURE GRID — 3 boven, 2 gecentreerd onder ──── */
.cx-grid-feat5 { grid-template-columns: repeat(6, 1fr) !important; }
.cx-grid-feat5 > * { grid-column: span 2; }
.cx-grid-feat5 > *:nth-child(4) { grid-column: 2 / 4; }
.cx-grid-feat5 > *:nth-child(5) { grid-column: 4 / 6; }

/* ============================================================
   RESPONSIVE — mobile-first overrides
   ============================================================ */
/* Hamburger toggle — desktop hides it, mobile shows */
.cx-nav-burger { display: none; }
.cx-nav-mobile { display: none; }

@media (max-width: 900px) {
  main { padding: 0 20px !important; }

  /* Nav: collapse to logo + burger + CTA */
  .cx-nav { padding: 0 10px 0 14px !important; gap: 10px !important; height: 60px !important; width: calc(100% - 20px) !important; }
  .cx-nav-menu, .cx-nav-login { display: none !important; }
  .cx-nav-tag { display: none !important; }
  .cx-nav-cta { padding: 8px 14px !important; font-size: 11.5px !important; }
  .cx-nav-burger {
    display: inline-flex !important; align-items: center; justify-content: center;
    width: 38px; height: 38px; margin-left: auto;
    background: var(--glass-2); border: 1px solid var(--border-2);
    border-radius: var(--r-full); cursor: pointer; color: var(--fg1);
    padding: 0;
  }
  .cx-nav-cta { margin-left: 0 !important; }
  .cx-nav-mobile {
    display: block; position: absolute; top: calc(100% + 8px); left: 0; right: 0;
    margin: 0 10px; padding: 14px;
    background: rgba(12,10,26,0.95); backdrop-filter: var(--blur-md);
    border: 1px solid var(--border-2); border-radius: var(--r-20);
    box-shadow: 0 12px 40px rgba(0,0,0,0.5);
  }
  .cx-nav-mobile ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 2px; }
  .cx-nav-mobile a {
    display: block; padding: 12px 14px; border-radius: var(--r-12);
    color: var(--fg1); text-decoration: none; font-size: 14px; font-weight: 500;
  }
  .cx-nav-mobile a:hover, .cx-nav-mobile a:active { background: var(--glass-2); }
  .cx-nav-mobile .cx-nav-mobile-section {
    margin-top: 8px; padding: 8px 14px 4px;
    font-size: 10.5px; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase;
    color: var(--fg3);
  }

  /* Founding banner: wrap, smaller */
  .cx-foundbar { flex-wrap: wrap !important; white-space: normal !important; padding: 8px 12px !important; font-size: 11.5px !important; gap: 8px !important; line-height: 1.35 !important; text-align: center !important; }
  .cx-foundbar-claim { display: none !important; }
  .cx-foundbar-claim-short { display: inline !important; }

  /* Generic grid collapses */
  .cx-grid-2 { grid-template-columns: 1fr !important; gap: 16px !important; }
  .cx-grid-3 { grid-template-columns: 1fr !important; gap: 12px !important; }
  .cx-grid-5 { grid-template-columns: 1fr 1fr !important; gap: 12px !important; }
  .cx-grid-feat5 { grid-template-columns: 1fr !important; gap: 16px !important; }
  .cx-grid-feat5 > *,
  .cx-grid-feat5 > *:nth-child(4),
  .cx-grid-feat5 > *:nth-child(5) { grid-column: auto !important; }
  .cx-logo-wall { grid-template-columns: repeat(4, 1fr) !important; }

  /* Footer */
  .cx-footer-grid { grid-template-columns: 1fr 1fr !important; gap: 28px !important; }
  .cx-footer-bottom { flex-direction: column !important; gap: 12px !important; align-items: flex-start !important; }

  /* HowItWorks: stack */
  .cx-step-row { grid-template-columns: 1fr !important; gap: 14px !important; padding: 24px 22px !important; }
  .cx-step-num { font-size: 44px !important; }

  /* Feature spots: image always on top, single column */
  .cx-feat-spot { grid-template-columns: 1fr !important; gap: 24px !important; padding: 56px 0 !important; }
  .cx-feat-spot > div:first-child { order: 2 !important; }
  .cx-feat-spot > div:last-child { order: 1 !important; }

  /* PricingV2 Suite hero: stack */
  .cx-suitecard { padding: 28px 22px !important; }
  .cx-suite-grid { grid-template-columns: 1fr !important; gap: 24px !important; }

  /* PricingV2 v3.5 bundle-builder: stack columns, unstick summary */
  .cx-bundle-grid { grid-template-columns: 1fr !important; gap: 22px !important; }
  .cx-bundle-grid > div:last-child { position: static !important; top: auto !important; }

  /* Suite Plus card: stack into single column */
  .cx-suiteplus { grid-template-columns: 1fr !important; gap: 18px !important; padding: 22px 20px !important; text-align: left !important; }
  .cx-suiteplus > div:last-child { text-align: left !important; }
  .cx-suiteplus > div:last-child > div:first-child { justify-content: flex-start !important; }

  /* Compare-table inner rows wrap */
  .cx-cmp-row,
  .cx-cmp-save { grid-template-columns: 1fr !important; gap: 6px !important; }
  .cx-cmp-row > div,
  .cx-cmp-save > div { text-align: left !important; min-width: 0 !important; }

  /* CTA: kleinere padding */
  .cx-cta-pad { padding: 44px 22px !important; }

  /* Module-detail page: stats 2×2, sections 1-col met beeld bovenaan, integraties wrap */
  .cx-mod-hero { padding: 40px 0 16px !important; }
  .cx-mod-hero-cta { margin-bottom: 36px !important; }
  .cx-mod-stats { grid-template-columns: 1fr 1fr !important; gap: 10px !important; }
  .cx-mod-stats > div { padding: 18px 12px !important; }
  .cx-mod-stats .cx-mod-stat-v { font-size: 1.55rem !important; }
  .cx-mod-section-grid { grid-template-columns: 1fr !important; gap: 28px !important; padding: 0 !important; }
  .cx-mod-section-grid > div:first-child,
  .cx-mod-section-grid > div:last-child { order: 0 !important; }
  .cx-mod-section-grid > .cx-mod-section-img { order: 1 !important; }
  .cx-mod-section-grid > .cx-mod-section-text { order: 2 !important; }
  .cx-mod-section { padding: 32px 0 !important; }
  .cx-mod-integrations { padding: 40px 0 28px !important; }
  .cx-mod-integrations > div:last-child > div { min-width: 140px !important; padding: 12px 16px !important; }
  .cx-mod-features-section { padding: 56px 0 !important; }
  .cx-mod-features-feature { padding: 22px !important; gap: 14px !important; }
  .cx-mod-features-feature > div:first-child { width: 42px !important; height: 42px !important; font-size: 20px !important; }
  .cx-mod-pricing-section { padding: 30px 0 56px !important; }
}

@media (max-width: 540px) {
  main { padding: 0 14px !important; }
  .cx-grid-5 { grid-template-columns: 1fr !important; }
  .cx-logo-wall { grid-template-columns: repeat(3, 1fr) !important; }
  .cx-step-row { padding: 22px 18px !important; }

  /* Module-detail page: tighter on small phones */
  .cx-mod-stats { grid-template-columns: 1fr 1fr !important; gap: 8px !important; }
  .cx-mod-stats .cx-mod-stat-v { font-size: 1.35rem !important; }
  .cx-mod-integrations > div:last-child { gap: 8px !important; }
  .cx-mod-integrations > div:last-child > div { min-width: 0 !important; flex: 1 1 calc(50% - 8px) !important; padding: 10px 12px !important; }
}
