/* ============================================================
   KNOPKA — SHARED DESIGN SYSTEM
   Light tech aesthetic · Geist · Orange #FF5A1F accent
   ============================================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
:root{
  --bg:#F2F3F5;
  --bg-2:#ECEEF2;
  --bg-soft:#F7F8FA;
  --surface:#FFFFFF;
  --ink:#0A0B0D;
  --ink-2:#1F2125;
  --ink-m:#5C616B;
  --ink-d:#8A8F99;
  --line:#E4E6EA;
  --line-2:#D8DBE0;
  --line-3:#C5C9D1;

  --pop:#FF5A1F;
  --pop-2:#FF6F39;
  --pop-d:#E04510;
  --pop-soft:#FFF1EB;
  --pop-line:#FFD4BF;

  --blue:#2D5BFF;
  --mint:#00C779;
  --red:#EF4444;
  --violet:#7C5CFF;
  --amber:#F0B000;

  /* Product accents */
  --lms:#6366F1;
  --lms-soft:#EEF2FF;
  --lms-line:#C7D2FE;
  --lms-d:#4338CA;

  --erp:#0E9F6E;
  --erp-soft:#E7FBF3;
  --erp-line:#A6E9D0;
  --erp-d:#066F4D;

  /* CRM = brand orange (shared with --pop, that's intentional) */
  --crm:#FF5A1F;
  --crm-soft:#FFF1EB;
  --crm-line:#FFD4BF;
  --crm-d:#E04510;

  --dark:#0A0B0D;
  --dark-2:#16181C;

  --font:'Geist',-apple-system,Inter,system-ui,sans-serif;
  --mono:'Geist Mono',ui-monospace,monospace;

  --r:18px; --r-sm:12px; --r-lg:28px; --r-xl:36px;
  --maxw:1280px; --pad:48px;
}

html{scroll-behavior:smooth;}
html{overflow-x:clip;} /* modern browsers — clips overflow without blocking inner scroll */
body{
  background:var(--bg); color:var(--ink);
  font-family:var(--font); font-size:16px; line-height:1.55;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
  /* NOTE: 'overflow-x:hidden' on body breaks horizontal touch-scroll for children
     (iOS Safari + Chrome Android bug). Use overflow-x:clip on html instead. */
  overflow-x:clip;
  font-feature-settings:"ss01" on,"ss02" on,"cv11" on;
}
::selection{background:var(--pop);color:#fff;}
a{color:inherit;text-decoration:none;}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer;}
input,textarea,select{font:inherit;color:inherit;}
img,svg{display:block;max-width:100%;}

/* Theme toggle (dark) */
body.dark{
  --bg:#0A0B0D; --bg-2:#16181C; --bg-soft:#101216;
  --surface:#16181C; --ink:#F5F6F8; --ink-2:#E1E3E8;
  --ink-m:#CDD2DB; --ink-d:#9DA3AE;
  --line:#23262C; --line-2:#2A2D34; --line-3:#3A3D45;
  --pop-soft:#2A1810; --pop-line:#5A2A14;
  --lms-soft:#1A1B3A; --lms-line:#3A2D8A;
  --erp-soft:#0F2A20; --erp-line:#1F5A40;
  --crm-soft:#2A1810; --crm-line:#5A2A14;
}
/* Dark-mode specific overrides for readability */
/* Dark theme — white-bg buttons MUST have dark text (var(--ink) becomes light in dark) */
body.dark .nav-cta{background:#fff;color:#0A0B0D !important;}
body.dark .nav-cta:hover{background:#E1E3E8;color:#0A0B0D !important;}
body.dark .nav-cta .arr{background:var(--pop);color:#fff !important;}
body.dark .btn-primary{background:#F5F6F8;color:#0A0B0D !important;}
body.dark .btn-primary:hover{background:#fff;color:#0A0B0D !important;}
body.dark .btn-primary .arr,
body.dark .nav-cta .arr,
body.dark .footer-cta-btn .arr,
body.dark .wl-submit .arr{color:#fff !important;}

/* Catch-all: any button-like with light background in dark mode → dark text */
body.dark .footer-cta-btn{background:#fff;color:#0A0B0D !important;}
body.dark .footer-cta-btn:hover{background:#E1E3E8;color:#0A0B0D !important;}
body.dark .btn-cta-tile,
body.dark .magnetic[style*="background:#fff"],
body.dark .magnetic[style*="background: #fff"]{color:#0A0B0D !important;}
body.dark .wl-submit{color:#fff;}
body.dark .wl-close:hover{background:#fff;color:#0A0B0D !important;}
body.dark .nav-links a.active{background:#fff;color:#0A0B0D;}
body.dark .nav-lang button.active{background:#fff;color:#0A0B0D;}
body.dark .pre-tile .px{background:rgba(255,90,31,.06);}
body.dark .status-tag.beta{background:rgba(176,38,255,.15);color:#C46AFF;}
body.dark .status-tag.dev{background:rgba(0,230,118,.15);color:#3CE891;}
body.dark .status-tag.soon{background:rgba(255,90,31,.15);color:#FF8857;}
body.dark .chrome{background:#0F1115;}
body.dark .chrome .url{background:#1A1D24;border-color:#2A2D34;color:#8A8F99;}
body.dark .chrome .url .domain{color:#E1E3E8;}
body.dark .chrome .url .path{color:#F5F6F8;}
body.dark .scr-erp-kpi{background:#1A1D24;border-color:#2A2D34;}
body.dark .scr-erp-kpi .lab{color:#B5BAC4;}
body.dark .scr-erp-kpi .val{color:#F5F6F8;}
body.dark .scr-erp-kpi .delta{color:#9DA3AE;}
/* Carousel mock — readable in dark */
body.dark .scr-erp-h h3{color:#F5F6F8;}
body.dark .scr-erp-h .meta{color:#9DA3AE;}
body.dark .scr-lms-list{background:transparent;}
body.dark .scr-lb-row{background:#1A1D24;border:1px solid #2A2D34;}
body.dark .scr-lb-row.me{background:rgba(255,90,31,.1);border-color:rgba(255,90,31,.3);}
body.dark .scr-lb-row .nm{color:#F5F6F8;font-weight:600;}
body.dark .scr-lb-row .rk{color:#9DA3AE;}
body.dark .scr-lb-row .xp{color:#E1E3E8;font-weight:700;}
body.dark .scr-lms-h .meta{color:#9DA3AE;}
/* Notes block (CRM client card right column) */
body.dark .scr-lms-card > div[style*="background:var(--bg-soft)"]{background:#1A1D24 !important;}
body.dark .scr-lms-card span[style*="color:var(--ink-d)"]{color:#9DA3AE !important;}
body.dark .scr-erp-chart,
body.dark .scr-lms-card,
body.dark .scr-crm-side,
body.dark .scr-crm-main{background:#0F1115;border-color:#2A2D34;}
body.dark .scr-erp-h{border-color:#2A2D34;}
body.dark .scr-erp-h h3{color:#F5F6F8;}
body.dark .scr-course{border-color:#2A2D34;}
body.dark .scr-lms-list{background:#1A1D24;}

/* Hero eyebrow/chips */
body.dark .hero-eye{background:rgba(22,24,28,.7);color:#E1E3E8;border-color:#2A2D34;}
body.dark .hero-eye-tag{color:#fff;}

/* Buttons */
body.dark .btn-ghost-sticky{color:#F5F6F8;border-color:#3A3D45;background:transparent;}
body.dark .btn-ghost-sticky:hover{border-color:#fff;background:rgba(255,255,255,.04);}
body.dark .btn-ghost-sticky .arr-out{color:#F5F6F8;border-color:#3A3D45;}

/* Carousel chrome */
body.dark .chrome{background:#0A0B0D;border-color:#23262C;}
body.dark .chrome .url{background:#16181C;border-color:#2A2D34;color:#8A8F99;}
body.dark .screen{background:#16181C;border-color:#2A2D34;box-shadow:0 60px 120px -30px rgba(0,0,0,.6),0 25px 50px -20px rgba(0,0,0,.35);}
body.dark .screen[data-active="true"]{box-shadow:0 80px 140px -30px rgba(0,0,0,.7),0 35px 60px -20px rgba(0,0,0,.45);}
body.dark .screens-arrow{background:#16181C;border-color:#2A2D34;color:#F5F6F8;}
body.dark .screens-arrow:hover{background:#fff;color:#0A0B0D;}
body.dark .screens-dots-row .dot{background:#3A3D45;}

/* Mockup internal text */
body.dark .scr-erp-kpi.acc{background:linear-gradient(135deg,#2A1810 0%,#1A1D24 100%);border-color:#5A2A14;}
body.dark .scr-erp-kpi.acc .val{color:#FFB088;}
body.dark .scr-erp-kpi.acc .lab{color:#FF8857;}
body.dark .scr-erp-kpi.acc .delta{color:#FF8857;}
/* Master's note callout (CRM client card) — dark variant */
body.dark .scr-lms-card div[style*="linear-gradient(135deg,#FFF1EB"]{background:linear-gradient(135deg,rgba(255,90,31,.15),rgba(255,90,31,.05)) !important;border-color:rgba(255,90,31,.35) !important;}
body.dark .scr-lms-card div[style*="linear-gradient(135deg,#FFF1EB"] div[style*="color:var(--ink-2)"]{color:#E1E3E8 !important;}
body.dark .scr-lms-stat{background:#1A1D24;border-color:#2A2D34;}
body.dark .scr-lms-stat .num{color:#C084FC;}
body.dark .scr-lms-stat .lab{color:#8A8F99;}
body.dark .scr-lms-h{color:#F5F6F8;}
body.dark .scr-course .top .nm{color:#F5F6F8;}
body.dark .scr-course .top .pct{color:#8A8F99;}
body.dark .scr-lb-row{color:#E1E3E8;}
body.dark .scr-lb-row .nm{color:#E1E3E8;}
body.dark .scr-lb-row .rk{color:#8A8F99;}
body.dark .scr-lb-row.me{background:rgba(168,85,247,.12);}
body.dark .scr-crm-side h4{color:#8A8F99;}
body.dark .scr-crm-client{color:#E1E3E8;}
body.dark .scr-crm-client:hover,
body.dark .scr-crm-client.active{background:#23262C;}
body.dark .scr-crm-client .sub{color:#8A8F99;}
body.dark .scr-crm-funnel-row .top span:first-child{color:#E1E3E8;}
body.dark .scr-crm-funnel-row .bar{background:#23262C;}

/* Eyebrows */
body.dark .eyebrow{background:rgba(255,90,31,.15);border-color:rgba(255,90,31,.3);color:#FF8857;}
body.dark .eyebrow.gray{background:#16181C;border-color:#2A2D34;color:#B5BAC4;}

/* Section titles */
body.dark .s-title{color:#F5F6F8;}
body.dark .s-title em{color:#B5BAC4;}
body.dark .s-sub{color:#9BA1AC;}

/* Product cards */
body.dark .product-card{background:#16181C;border-color:#2A2D34;}
body.dark .product-card .pname{color:#F5F6F8;}
body.dark .product-card .pname em{color:#8A8F99;}
body.dark .product-card .ptag{color:#8A8F99;}
body.dark .product-card .pdesc{color:#B5BAC4;}
body.dark .product-card .plist li{color:#E1E3E8;}
body.dark .product-card .pbottom{border-color:#2A2D34;}
body.dark .product-card .pcta{color:#F5F6F8;}

/* Competition cards (block 3) */
body.dark .compete-card{background:#16181C;border-color:#2A2D34;}
body.dark .compete-card .hd{color:#8A8F99;}
body.dark .compete-card .tt{color:#F5F6F8;}
body.dark .compete-card .desc{color:#B5BAC4;}
body.dark .compete-card .integ{border-color:#2A2D34;}
body.dark .compete-card .integ .pill{background:#23262C;border-color:#2A2D34;color:#E1E3E8;}

/* Partnership status cards */
body.dark .partnership-card{background:linear-gradient(180deg,#16181C 0%,#0F1115 100%);border-color:#2A2D34;}
body.dark .partnership-title{color:#F5F6F8;}
body.dark .partnership-body{color:#B5BAC4;}
body.dark .partnership-body strong{color:#E1E3E8;}
body.dark .status-card{background:#0F1115;border-color:#2A2D34;}
body.dark .status-card .num{color:#F5F6F8;}
body.dark .status-card.beta .num{color:#C084FC;}
body.dark .status-card.dev .num{color:#34D399;}
body.dark .status-card.concept .num{color:#FF8857;}
body.dark .status-card .ttag{color:#8A8F99;}
body.dark .status-card .lab{color:#E1E3E8;}
body.dark .status-card .lab strong{color:#fff;}

/* Manifesto is already dark — make sure works in both modes */
body.dark .manifesto{background:#000;}

/* Footer */
body.dark .footer-hero{background:#000;}

/* ============================================================
   REVEAL + ANIMATIONS
   ============================================================ */
.reveal{opacity:0;transform:translateY(28px);transition:opacity 1s cubic-bezier(.2,.8,.2,1),transform 1s cubic-bezier(.2,.8,.2,1);}
.reveal.in{opacity:1;transform:none;}
.d1{transition-delay:.08s;} .d2{transition-delay:.16s;}
.d3{transition-delay:.24s;} .d4{transition-delay:.32s;}
.d5{transition-delay:.4s;}  .d6{transition-delay:.48s;}
@media (prefers-reduced-motion: reduce){
  .reveal{opacity:1;transform:none;transition:none;}
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important;}
}

.magnetic{transition:transform .4s cubic-bezier(.2,.8,.2,1);will-change:transform;}

.scroll-progress{position:fixed;top:0;left:0;right:0;height:2px;z-index:300;background:transparent;pointer-events:none;}
.scroll-progress::after{content:"";display:block;height:100%;width:var(--p,0%);background:linear-gradient(90deg,var(--pop),var(--pop-2));transition:width .12s linear;box-shadow:0 0 12px var(--pop);}

/* ============================================================
   NAV
   ============================================================ */
nav.knop-nav{
  position:fixed;top:0;left:0;right:0;z-index:200;
  display:flex;align-items:center;justify-content:center;
  padding:16px 24px;transition:padding .3s;
}
.nav-shell{
  width:100%;max-width:1240px;
  display:flex;align-items:center;gap:24px;
  background:rgba(255,255,255,.78);
  backdrop-filter:blur(20px) saturate(160%);
  -webkit-backdrop-filter:blur(20px) saturate(160%);
  border:1px solid var(--line);
  border-radius:99px;padding:8px 8px 8px 20px;
  box-shadow:0 4px 24px -8px rgba(10,11,13,.06),0 1px 0 0 rgba(255,255,255,.6) inset;
  transition:box-shadow .3s,border-color .3s;
}
body.dark .nav-shell{
  background:rgba(18,20,24,.62);
  backdrop-filter:blur(24px) saturate(140%);
  -webkit-backdrop-filter:blur(24px) saturate(140%);
  border-color:rgba(255,255,255,.06);
  /* NO inset highlight in dark — pure frosted glass, no glossy reflection */
  box-shadow:0 8px 32px -12px rgba(0,0,0,.5);
}
nav.knop-nav.scrolled .nav-shell{box-shadow:0 10px 30px -10px rgba(10,11,13,.12),0 1px 0 0 rgba(255,255,255,.7) inset;}
body.dark nav.knop-nav.scrolled .nav-shell{
  background:rgba(14,16,20,.78);
  box-shadow:0 14px 40px -14px rgba(0,0,0,.65);
  border-color:rgba(255,255,255,.08);
}

/* Frosted-glass surface utility — use anywhere in dark mode that should look like matte glass */
body.dark .glass{
  background:rgba(22,24,28,.55);
  backdrop-filter:blur(20px) saturate(140%);
  -webkit-backdrop-filter:blur(20px) saturate(140%);
  border:1px solid rgba(255,255,255,.06);
  box-shadow:0 12px 32px -14px rgba(0,0,0,.5);
}
body.dark .glass-strong{
  background:rgba(16,18,22,.72);
  backdrop-filter:blur(28px) saturate(150%);
  -webkit-backdrop-filter:blur(28px) saturate(150%);
  border:1px solid rgba(255,255,255,.07);
}

.logo{display:flex;align-items:center;gap:10px;flex-shrink:0;}

/* ── PIXEL K logo (07) — main brand mark ── */
.logo-mark{
  position:relative;width:32px;height:32px;border-radius:9px;
  background:var(--ink);
  display:grid;grid-template-columns:repeat(5,1fr);gap:2px;padding:7px;
  box-shadow:inset 0 -2px 0 rgba(255,255,255,.08),inset 0 1px 0 rgba(255,255,255,.06),0 4px 12px rgba(10,11,13,.14);
}
.logo-mark::before,
.logo-mark::after{display:none;} /* kill previous pseudo-element artwork */
.logo-mark .px{background:transparent;border-radius:1px;transition:background .25s;}
.logo-mark .px.on{background:var(--pop);box-shadow:0 0 3px rgba(255,90,31,.6);}

/* Bigger logo variant for hero / footer */
.logo-mark.lg{width:46px;height:46px;border-radius:12px;padding:7px;gap:2px;}
.logo-mark.lg .px.on{box-shadow:0 0 5px rgba(255,90,31,.6);}

.logo-text{
  font-family:'Unbounded','Geist',sans-serif;
  font-weight:800;font-size:14px;letter-spacing:-.4px;color:var(--ink);
}
.logo-text .dot{color:var(--pop);}

/* ============================================================
   PIXEL PRELOADER — chaotic flicker + letter reveals + progress
   ============================================================ */
.knop-preloader{
  position:fixed;inset:0;z-index:9999;
  background:#0A0B0D;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:36px;
  opacity:1;transition:opacity .6s ease, visibility .6s ease;
}
.knop-preloader.done{opacity:0;visibility:hidden;pointer-events:none;}
@media (prefers-reduced-motion: reduce){
  .knop-preloader{display:none;}
}

.pre-tile{
  position:relative;
  width:180px;height:180px;border-radius:34px;
  background:linear-gradient(165deg,#25282E 0%,#15171C 50%,#050608 100%);
  display:grid;grid-template-columns:repeat(5,1fr);gap:7px;padding:26px;
  box-shadow:
    inset 0 -3px 0 rgba(255,255,255,.05),
    inset 0 1.5px 0 rgba(255,255,255,.1),
    0 36px 70px -14px rgba(255,90,31,.18),
    0 0 80px rgba(255,90,31,.1);
}
.pre-tile .px{
  background:rgba(255,90,31,.06);border-radius:3px;
}
.pre-tile .px.on{
  background:var(--pop);
  box-shadow:0 0 8px rgba(255,90,31,.6);
  animation:none;
}
/* Chaotic flicker mode — each cell pulses independently with random delay */
.pre-tile.flicker .px{
  animation:flickerCell 1.2s ease-in-out infinite;
}
@keyframes flickerCell{
  0%,100%{background:rgba(255,255,255,.06);box-shadow:none;}
  50%{background:var(--pop);box-shadow:0 0 8px rgba(255,90,31,.55);}
}
.pre-tile.flicker.fast .px{animation-duration:.45s;}

/* Progress bar — slim, at bottom of preloader area */
.pre-progress{
  position:relative;width:240px;height:3px;border-radius:99px;
  background:rgba(255,255,255,.06);overflow:hidden;
}
.pre-progress::after{
  content:"";position:absolute;left:0;top:0;bottom:0;width:0%;
  background:linear-gradient(90deg,var(--pop) 0%,#FF8857 100%);
  box-shadow:0 0 12px rgba(255,90,31,.7);
  transition:width .12s linear;
}
.pre-progress[data-progress]::after{width:var(--w, 0%);}

.pre-label{
  font-family:'Geist Mono',monospace;font-size:11px;color:rgba(255,255,255,.45);
  letter-spacing:.3em;text-transform:uppercase;
}
.pre-label .pct{color:var(--pop);margin-left:6px;}

/* ============================================================
   A4 × A6 — RIPPLE INVERSE EFFECT
   Wave goes orange in center, turns dark at boundary
   ============================================================ */
.ripple-tile{
  position:relative;
  width:160px;height:160px;border-radius:30px;
  background:linear-gradient(165deg,#25282E 0%,#15171C 50%,#050608 100%);
  transform:perspective(800px) rotateX(12deg);
  overflow:hidden;
  box-shadow:
    inset 0 -3px 0 rgba(255,255,255,.05),
    inset 0 1.5px 0 rgba(255,255,255,.08),
    0 30px 60px -10px rgba(10,11,13,.5);
}
.ripple-tile .core{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:18px;height:18px;border-radius:50%;
  background:radial-gradient(circle at 30% 28%,#FF8857 0%,var(--pop) 60%,var(--pop-d) 100%);
  box-shadow:0 0 24px rgba(255,90,31,.6),inset 0 1px 0 rgba(255,255,255,.3);
  z-index:5;
}
.ripple-tile .wave{
  position:absolute;top:50%;left:50%;
  width:18px;height:18px;border-radius:50%;
  border:2px solid var(--pop);
  transform:translate(-50%,-50%);
  animation:rippleInverse 2.4s cubic-bezier(.25,.6,.35,1) infinite;
  opacity:0;
}
.ripple-tile .wave:nth-child(2){animation-delay:.6s;}
.ripple-tile .wave:nth-child(3){animation-delay:1.2s;}
.ripple-tile .wave:nth-child(4){animation-delay:1.8s;}
@keyframes rippleInverse{
  0%{
    width:18px;height:18px;
    opacity:.9;
    border-color:var(--pop);
    border-width:3px;
  }
  40%{
    opacity:.7;
    border-color:var(--pop);
  }
  70%{
    opacity:.5;
    border-color:#3A3D44; /* dark at boundary */
  }
  100%{
    width:200px;height:200px;
    opacity:0;
    border-color:#0A0B0D;
    border-width:1px;
  }
}

.nav-links{display:flex;list-style:none;gap:4px;margin-left:8px;}
.nav-links a{
  display:inline-flex;align-items:center;gap:6px;
  padding:8px 14px;border-radius:99px;
  font-size:14px;font-weight:500;color:var(--ink-2);
  transition:background .2s,color .2s;
  position:relative;
}
.nav-links a:hover{background:var(--bg-2);color:var(--ink);}
.nav-links a.active{background:var(--ink);color:#fff;}
.nav-links a.active:hover{background:var(--ink);color:#fff;}
.nav-spacer{flex:1;}
.nav-cta{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--ink);color:#fff;
  padding:10px 18px 10px 20px;border-radius:99px;
  font-size:14px;font-weight:600;letter-spacing:-.1px;
  transition:transform .25s cubic-bezier(.5,1.6,.4,1),box-shadow .3s,background .2s;
}
.nav-cta:hover{transform:translateY(-1px);background:#1A1C20;box-shadow:0 12px 28px -8px rgba(10,11,13,.35);}
.nav-cta .arr{
  display:inline-flex;align-items:center;justify-content:center;
  width:18px;height:18px;border-radius:50%;background:var(--pop);
  font-size:10px;color:#fff;font-weight:800;transition:transform .3s;
}
.nav-cta:hover .arr{transform:translateX(2px);}
.nav-theme{
  width:36px;height:36px;border-radius:50%;
  border:1px solid var(--line);background:var(--surface);
  display:inline-flex;align-items:center;justify-content:center;
  color:var(--ink-2);transition:background .2s,border-color .2s,color .2s;
}
.nav-theme:hover{background:var(--bg-2);color:var(--ink);}
.nav-theme svg{width:16px;height:16px;}

/* Language switcher — sits left of theme */
.nav-lang{
  display:inline-flex;align-items:center;
  background:var(--surface);border:1px solid var(--line);
  border-radius:99px;padding:3px;gap:0;
  font-family:var(--mono);font-size:11px;font-weight:600;
  letter-spacing:.05em;
}
.nav-lang button{
  padding:5px 10px;border-radius:99px;color:var(--ink-d);
  transition:background .2s,color .2s;line-height:1;
}
.nav-lang button.active{background:var(--ink);color:#fff;}
.nav-lang button:hover:not(.active){background:var(--bg-2);color:var(--ink);}

/* Mobile burger button — pop-ink filled so it's clearly visible */
.nav-mobile{
  display:none;
  width:42px;height:42px;border-radius:50%;
  border:none;background:var(--ink);
  align-items:center;justify-content:center;flex-shrink:0;
  color:#fff;
  transition:background .2s,transform .2s,box-shadow .2s;
  position:relative;
  -webkit-tap-highlight-color:transparent;
  box-shadow:0 4px 12px -2px rgba(10,11,13,.25);
}
.nav-mobile:hover{transform:scale(1.05);box-shadow:0 6px 16px -2px rgba(10,11,13,.3);}
.nav-mobile:active{transform:scale(.95);}
body.dark .nav-mobile{background:#fff;color:#0A0B0D;box-shadow:0 4px 12px -2px rgba(0,0,0,.5);}
.nav-mobile .bars{
  position:relative;width:18px;height:14px;display:block;
}
.nav-mobile .bars::before,
.nav-mobile .bars::after,
.nav-mobile .bars i{
  content:"";position:absolute;left:0;right:0;height:2px;
  background:currentColor;border-radius:2px;
  transition:transform .3s cubic-bezier(.25,.85,.25,1),opacity .2s,top .3s;
}
.nav-mobile .bars::before{top:0;}
.nav-mobile .bars i{top:6px;display:block;}
.nav-mobile .bars::after{top:12px;}
.nav-mobile[aria-expanded="true"] .bars::before{top:6px;transform:rotate(45deg);}
.nav-mobile[aria-expanded="true"] .bars::after{top:6px;transform:rotate(-45deg);}
.nav-mobile[aria-expanded="true"] .bars i{opacity:0;}

/* Mobile menu overlay */
.nav-mobile-menu{
  position:fixed;inset:0;z-index:199;
  background:rgba(10,11,13,.55);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  opacity:0;visibility:hidden;pointer-events:none;
  transition:opacity .3s,visibility .3s;
  display:flex;flex-direction:column;align-items:stretch;
  padding:88px 20px 32px;
}
.nav-mobile-menu.open{opacity:1;visibility:visible;pointer-events:auto;}
.nav-mobile-menu .nm-panel{
  background:var(--surface);border:1px solid var(--line);
  border-radius:22px;padding:14px;
  box-shadow:0 30px 70px -20px rgba(10,11,13,.35);
  transform:translateY(-10px);opacity:0;
  transition:transform .35s cubic-bezier(.25,.85,.25,1),opacity .3s;
}
.nav-mobile-menu.open .nm-panel{transform:none;opacity:1;}
body.dark .nav-mobile-menu .nm-panel{background:#16181C;border-color:#2A2D34;}
.nav-mobile-menu a{
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 18px;border-radius:14px;
  font-size:17px;font-weight:600;color:var(--ink);
  letter-spacing:-.3px;
  transition:background .2s,color .2s;
  min-height:52px;
}
.nav-mobile-menu a + a{margin-top:2px;}
.nav-mobile-menu a:active,
.nav-mobile-menu a:focus-visible{background:var(--bg-2);}
.nav-mobile-menu a.active{background:var(--ink);color:#fff;}
body.dark .nav-mobile-menu a.active{background:#fff;color:#0A0B0D;}
.nav-mobile-menu a .arr{
  width:22px;height:22px;border-radius:50%;background:var(--bg-2);
  display:inline-flex;align-items:center;justify-content:center;
  color:var(--ink-m);font-size:11px;
}
.nav-mobile-menu a.active .arr{background:var(--pop);color:#fff;}

/* Sticky CTA inside burger menu */
.nm-cta-wrap{margin-top:14px;padding-top:14px;border-top:1px solid var(--line);}
body.dark .nm-cta-wrap{border-top-color:#2A2D34;}
.nm-cta{
  display:flex !important;align-items:center;justify-content:center !important;gap:10px;
  padding:16px 20px !important;min-height:56px;
  background:var(--pop) !important;color:#fff !important;
  border-radius:99px;
  font-size:16px !important;font-weight:600;letter-spacing:-.2px;
  box-shadow:0 8px 20px -6px rgba(255,90,31,.4);
  transition:transform .2s,box-shadow .2s;
}
.nm-cta:active{transform:scale(.97);}
.nm-cta .arr{
  background:rgba(255,255,255,.2) !important;color:#fff !important;
  width:24px !important;height:24px !important;
}
body.dark .nav-mobile-menu a .arr{background:#23262C;color:#B5BAC4;}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn-primary,.btn-ghost,.btn-product{
  display:inline-flex;align-items:center;gap:10px;
  padding:15px 24px;border-radius:99px;
  font-size:14px;font-weight:600;letter-spacing:-.1px;
  transition:transform .25s cubic-bezier(.5,1.6,.4,1),box-shadow .3s,background .2s,color .2s,border-color .2s;
}
.btn-primary{background:var(--ink);color:#fff;}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 16px 36px -10px rgba(10,11,13,.4);background:#1A1C20;}
.btn-primary .arr,.btn-product .arr{
  width:22px;height:22px;border-radius:50%;background:var(--pop);
  display:inline-flex;align-items:center;justify-content:center;color:#fff;font-size:11px;font-weight:800;transition:transform .3s;
}
.btn-primary:hover .arr,.btn-product:hover .arr{transform:translateX(2px);}
.btn-ghost{background:transparent;color:var(--ink);border:1px solid var(--line-2);}
.btn-ghost:hover{border-color:var(--ink);background:var(--surface);}
.btn-product{background:var(--surface);color:var(--ink);border:1px solid var(--line);}
.btn-product:hover{transform:translateY(-2px);border-color:var(--ink);box-shadow:0 16px 36px -10px rgba(10,11,13,.18);}

/* ============================================================
   SECTION + TITLES
   ============================================================ */
.section{padding:120px var(--pad);}
.container{max-width:var(--maxw);margin:0 auto;}
.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--mono);font-size:12px;color:var(--pop);
  background:var(--pop-soft);border:1px solid var(--pop-line);
  border-radius:99px;padding:6px 14px;margin-bottom:24px;
}
.eyebrow.gray{color:var(--ink-m);background:var(--surface);border-color:var(--line);}
.eyebrow .dot{width:6px;height:6px;border-radius:50%;background:currentColor;}
.eyebrow .led{width:6px;height:6px;border-radius:50%;background:var(--pop);box-shadow:0 0 8px var(--pop);animation:ledPulse 2s ease-in-out infinite;}
@keyframes ledPulse{0%,100%{opacity:1;}50%{opacity:.4;}}

.s-title{
  font-size:clamp(36px,4.6vw,68px);
  font-weight:600;line-height:1.02;letter-spacing:-2.6px;
  color:var(--ink);max-width:16ch;
}
.s-title.center{text-align:center;margin:0 auto;}
.s-title .pop{color:var(--pop);}
.s-title .light{font-weight:300;}
.s-title em{font-style:italic;font-weight:500;}

.s-sub{font-size:18px;color:var(--ink-m);line-height:1.55;max-width:48ch;}
.s-sub.center{margin-left:auto;margin-right:auto;text-align:center;}

.section-head-row{display:flex;justify-content:space-between;align-items:flex-end;gap:48px;margin-bottom:56px;}
.section-head-center{display:flex;flex-direction:column;align-items:center;text-align:center;margin-bottom:56px;gap:18px;}

/* ============================================================
   STATUS BADGE
   ============================================================ */
.status-badge{
  display:inline-flex;align-items:center;gap:10px;
  background:var(--surface);border:1px solid var(--line);
  border-radius:99px;padding:8px 16px 8px 10px;
  font-family:var(--mono);font-size:12px;color:var(--ink-2);
  letter-spacing:-.1px;
}
.status-badge .tag{
  border-radius:99px;padding:3px 10px;font-weight:600;
  font-family:var(--font);font-size:11px;letter-spacing:.2px;text-transform:uppercase;
}
.status-badge .tag.pilot{background:var(--pop-soft);color:var(--pop-d);}
.status-badge .tag.alpha{background:#FFF6E1;color:#A77900;}
.status-badge .tag.soon{background:var(--bg-2);color:var(--ink-m);}
.status-badge .tag.live{background:#E8FAF0;color:var(--mint);}

/* ============================================================
   FOOTER
   ============================================================ */
.footer-hero{
  position:relative;padding:80px var(--pad) 60px;
  background:
    radial-gradient(ellipse 70% 50% at 80% 30%,rgba(255,90,31,.18) 0%,transparent 60%),
    radial-gradient(ellipse 60% 60% at 20% 70%,rgba(45,91,255,.1) 0%,transparent 70%),
    var(--dark);
  color:#fff;
}
.footer-hero::before{
  content:"";position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);
  background-size:80px 80px;
  mask-image:radial-gradient(ellipse 60% 60% at 50% 50%,#000,transparent 80%);
  -webkit-mask-image:radial-gradient(ellipse 60% 60% at 50% 50%,#000,transparent 80%);
}
.footer-hero-inner{max-width:var(--maxw);margin:0 auto;position:relative;z-index:1;}
.footer-cta{
  display:flex;justify-content:space-between;align-items:center;gap:48px;
  padding-bottom:60px;border-bottom:1px solid rgba(255,255,255,.08);
}
.footer-cta h3{font-size:clamp(36px,4.5vw,64px);font-weight:600;letter-spacing:-2px;line-height:1;max-width:14ch;color:#fff;}
.footer-cta h3 em{font-style:italic;font-weight:500;color:var(--pop);}
.footer-cta-btn{
  background:#fff;color:var(--ink);padding:16px 28px;border-radius:99px;
  font-size:14px;font-weight:600;display:inline-flex;align-items:center;gap:10px;flex-shrink:0;
  transition:transform .25s,box-shadow .3s;
}
.footer-cta-btn:hover{transform:translateY(-2px);box-shadow:0 16px 40px -10px rgba(255,255,255,.2);}
.footer-cta-btn .arr{width:22px;height:22px;border-radius:50%;background:var(--pop);color:#fff;font-size:11px;display:inline-flex;align-items:center;justify-content:center;}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:48px;padding:60px 0 40px;}
.footer-brand{display:flex;flex-direction:column;gap:24px;max-width:340px;}
.footer-brand .logo-text{color:#fff;}
.footer-brand-text{font-size:14px;color:rgba(255,255,255,.55);line-height:1.6;}
.footer-stamp{
  display:inline-flex;align-items:center;gap:10px;
  background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);
  border-radius:99px;padding:6px 14px;font-family:var(--mono);font-size:11px;
  color:rgba(255,255,255,.7);align-self:flex-start;
}
.footer-stamp .led{width:6px;height:6px;border-radius:50%;background:var(--pop);box-shadow:0 0 8px var(--pop);}
.footer-col h5{font-family:var(--mono);font-size:11px;color:rgba(255,255,255,.4);letter-spacing:.3px;text-transform:uppercase;margin-bottom:18px;}
.footer-col a{display:block;font-size:14px;color:rgba(255,255,255,.7);padding:6px 0;transition:color .2s;}
.footer-col a:hover{color:#fff;}
.footer-bottom{
  display:flex;justify-content:space-between;align-items:center;
  padding:24px 0;border-top:1px solid rgba(255,255,255,.08);
  font-family:var(--mono);font-size:11px;color:rgba(255,255,255,.4);letter-spacing:.2px;
}

/* ============================================================
   FAQ
   ============================================================ */
.faq-section{background:var(--bg-soft);border-top:1px solid var(--line);padding:120px var(--pad);}
.faq-list{max-width:820px;margin:0 auto;}
.faq-item{border-bottom:1px solid var(--line);}
.faq-q{
  width:100%;display:flex;justify-content:space-between;align-items:center;
  padding:22px 0;background:none;border:none;cursor:pointer;
  font:600 17px/1.2 var(--font);color:var(--ink);letter-spacing:-.3px;
  text-align:left;gap:24px;transition:color .2s;
}
.faq-q:hover{color:var(--pop);}
.faq-icon{
  width:30px;height:30px;border-radius:50%;border:1px solid var(--line-2);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  transition:transform .3s,background .2s,border-color .2s;
  color:var(--ink-m);font-size:16px;line-height:1;
}
.faq-item.open .faq-icon{transform:rotate(45deg);background:var(--ink);border-color:var(--ink);color:#fff;}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s cubic-bezier(.2,.8,.2,1),padding .3s;font-size:14px;color:var(--ink-m);line-height:1.65;}
.faq-item.open .faq-a{max-height:400px;padding-bottom:22px;}

/* ============================================================
   CARDS / FEATURE GRID
   ============================================================ */
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;}
.feat-grid.four{grid-template-columns:repeat(4,1fr);}
.feat-card{
  background:var(--surface);border:1px solid var(--line);border-radius:20px;
  padding:28px;display:flex;flex-direction:column;gap:14px;
  transition:transform .3s,box-shadow .3s,border-color .25s;
  position:relative;overflow:hidden;
}
.feat-card:hover{transform:translateY(-4px);box-shadow:0 30px 60px -20px rgba(10,11,13,.12);border-color:var(--line-2);}
.feat-ic{
  width:48px;height:48px;border-radius:14px;background:var(--bg-soft);border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;color:var(--ink);
  transition:background .25s,border-color .25s,color .25s;
}
.feat-card:hover .feat-ic{background:var(--pop-soft);border-color:var(--pop-line);color:var(--pop-d);}
.feat-ic svg{width:22px;height:22px;stroke-width:1.6;fill:none;stroke:currentColor;}
.feat-title{font-size:17px;font-weight:600;letter-spacing:-.4px;}
.feat-desc{font-size:13.5px;color:var(--ink-m);line-height:1.55;}
.feat-card .num{position:absolute;top:24px;right:24px;font-family:var(--mono);font-size:11px;color:var(--ink-d);}

/* ============================================================
   PRODUCT ACCENT CLASSES
   ============================================================ */
.pop-lms{--pop:var(--lms);--pop-d:var(--lms-d);--pop-soft:var(--lms-soft);--pop-line:var(--lms-line);--pop-2:#818CF8;}
.pop-erp{--pop:var(--erp);--pop-d:var(--erp-d);--pop-soft:var(--erp-soft);--pop-line:var(--erp-line);--pop-2:#34D399;}
.pop-crm{--pop:var(--crm);--pop-d:var(--crm-d);--pop-soft:var(--crm-soft);--pop-line:var(--crm-line);--pop-2:#B968F7;}

/* Product logo marks */
.plogo{position:relative;display:inline-flex;align-items:center;justify-content:center;width:64px;height:64px;border-radius:18px;background:var(--ink);box-shadow:inset 0 -2px 0 rgba(255,255,255,.08),inset 0 1px 0 rgba(255,255,255,.05),0 8px 24px rgba(10,11,13,.18);}
.plogo svg{width:32px;height:32px;color:#fff;}
/* Brand mark on top of icon — coloured stripe (matches Pixel-K design) */
.plogo .dotmark{position:absolute;top:8px;left:50%;transform:translateX(-50%);width:18px;height:3px;border-radius:99px;background:var(--pop);box-shadow:0 0 8px rgba(255,90,31,.5);}
.plogo.lg{width:96px;height:96px;border-radius:26px;}
.plogo.lg svg{width:48px;height:48px;}
.plogo.lg .dotmark{width:26px;height:4px;top:12px;}

/* Per-product stripe colour — applied via .pop-{lms|erp|crm} on .plogo or its parent card */
.pop-lms .plogo .dotmark,
.plogo.lms .dotmark{background:#B026FF;box-shadow:0 0 8px rgba(176,38,255,.6);}
.pop-erp .plogo .dotmark,
.plogo.erp .dotmark{background:#00E676;box-shadow:0 0 8px rgba(0,230,118,.6);}
.pop-crm .plogo .dotmark,
.plogo.crm .dotmark{background:#FF5A1F;box-shadow:0 0 8px rgba(255,90,31,.65);}

/* ============================================================
   HERO BASE
   ============================================================ */
.hero{
  position:relative;padding:140px var(--pad) 80px;
  background:
    radial-gradient(ellipse 80% 50% at 50% 0%,rgba(255,90,31,.06) 0%,transparent 60%),
    linear-gradient(180deg,#EEF1F5 0%,#F2F3F5 38%,#F2F3F5 100%);
  overflow:hidden;
}
body.dark .hero{background:radial-gradient(ellipse 80% 50% at 50% 0%,rgba(255,90,31,.08) 0%,transparent 60%),var(--bg);}
.hero-inner{max-width:var(--maxw);margin:0 auto;position:relative;z-index:2;}
.hero-top-bar{display:flex;justify-content:center;margin-bottom:36px;}
.hero-h1{
  font-size:clamp(48px,7.2vw,108px);
  font-weight:600;line-height:.96;letter-spacing:-3.5px;
  color:var(--ink);text-align:center;max-width:14ch;margin:0 auto;
}
.hero-h1 .pop{color:var(--pop);}
.hero-h1 .light{font-weight:300;}
.hero-h1 em{font-style:italic;font-weight:500;}
.hero-sub{margin:28px auto 0;max-width:620px;text-align:center;font-size:18px;color:var(--ink-m);line-height:1.55;}
.hero-actions{display:flex;justify-content:center;gap:12px;margin-top:36px;flex-wrap:wrap;}

/* ============================================================
   MOCKUP CHROME (reusable)
   ============================================================ */
.mockup{
  background:var(--surface);border:1px solid var(--line);border-radius:20px;overflow:hidden;
  box-shadow:0 50px 100px -20px rgba(10,11,13,.18),0 20px 40px -20px rgba(10,11,13,.1);
}
.m-bar{height:46px;display:flex;align-items:center;padding:0 16px;border-bottom:1px solid var(--line);gap:8px;background:var(--bg-soft);}
.m-traffic{display:flex;gap:6px;}
.m-tl{width:11px;height:11px;border-radius:50%;}
.m-tl.r{background:#FF5F57;} .m-tl.y{background:#FEBC2E;} .m-tl.g{background:#28C840;}
.m-url{margin-left:14px;background:var(--surface);border:1px solid var(--line);border-radius:7px;height:24px;display:flex;align-items:center;padding:0 10px;gap:6px;font-family:var(--mono);font-size:11px;color:var(--ink-d);min-width:200px;}
.m-url .lock{width:8px;height:8px;border-radius:50%;border:1.5px solid var(--ink-d);border-bottom-color:transparent;}

/* KPI tiles */
.kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;}
.kpi-row.three{grid-template-columns:repeat(3,1fr);}
.kpi-row.two{grid-template-columns:repeat(2,1fr);}
.kpi{background:var(--bg-soft);border:1px solid var(--line);border-radius:14px;padding:14px;position:relative;overflow:hidden;}
.kpi-l{font-family:var(--mono);font-size:10px;color:var(--ink-d);letter-spacing:.3px;text-transform:uppercase;}
.kpi-v{font-size:22px;font-weight:700;letter-spacing:-.6px;margin-top:6px;line-height:1;}
.kpi-d{display:inline-flex;align-items:center;gap:4px;margin-top:6px;font-family:var(--mono);font-size:10px;font-weight:600;}
.kpi-d.up{color:var(--mint);} .kpi-d.dn{color:var(--red);}
.kpi.acc{background:linear-gradient(135deg,#FFF1EB 0%,#FFF7F2 100%);border-color:var(--pop-line);}
.kpi.acc .kpi-v{color:var(--pop-d);}

.badge{display:inline-flex;align-items:center;gap:4px;font-family:var(--mono);font-size:10px;font-weight:600;padding:3px 8px;border-radius:99px;}
.badge.live{background:#E8FAF0;color:var(--mint);}
.badge.idle{background:var(--bg-soft);color:var(--ink-m);}
.badge.warn{background:#FFF6E1;color:#A77900;}
.badge.up{background:var(--pop-soft);color:var(--pop-d);}

/* ============================================================
   RESPONSIVE
   ============================================================ */
/* Tablet & below — collapse heavy grids, shrink padding */
@media (max-width:1100px){
  :root{--pad:32px;}
  .footer-grid{grid-template-columns:1fr 1fr;}
  .feat-grid,.feat-grid.four{grid-template-columns:repeat(2,1fr);}
  .section{padding:90px var(--pad);}
}

/* Tablet portrait — hide desktop nav links earlier so they don't wrap */
@media (max-width:1024px){
  .nav-links{display:none;}
  .nav-mobile{display:inline-flex;}
  .nav-shell{gap:10px;}
}

/* Mobile (standard phones) */
@media (max-width:640px){
  :root{--pad:20px;}
  nav.knop-nav{padding:10px 12px;}
  .nav-shell{padding:6px 6px 6px 12px;gap:8px;border-radius:99px;}
  .logo-text{font-size:13px;}
  .logo-mark{width:28px;height:28px;border-radius:8px;padding:5px;}
  .nav-lang{padding:2px;}
  .nav-lang button{padding:4px 7px;font-size:10px;}
  .nav-theme{width:34px;height:34px;}
  .nav-theme svg{width:14px;height:14px;}
  /* Hide nav-cta on mobile — moved inside burger menu, only logo + lang + theme + burger remain */
  .nav-cta{display:none !important;}
  .nav-mobile{width:42px;height:42px;}

  .hero{padding:100px var(--pad) 56px;}
  .hero-h1{font-size:clamp(36px,11vw,56px);letter-spacing:-2px;line-height:1;}
  .hero-sub{font-size:15.5px;margin-top:20px;}
  .hero-actions{flex-direction:column;align-items:stretch;gap:10px;margin-top:28px;}
  .hero-actions .btn-primary,
  .hero-actions .btn-ghost,
  .hero-actions .btn-ghost-sticky,
  .hero-actions .btn-product{width:100%;justify-content:center;padding:14px 20px;}

  .section{padding:60px var(--pad);}
  .s-title{font-size:clamp(28px,7.5vw,40px);letter-spacing:-1.4px;}
  .s-sub{font-size:15px;}
  .section-head-row{flex-direction:column;align-items:flex-start;gap:16px;margin-bottom:36px;}
  .section-head-center{margin-bottom:36px;gap:14px;}

  .footer-hero{padding:60px var(--pad) 40px;}
  .footer-grid{grid-template-columns:1fr;gap:28px;padding:40px 0 24px;}
  .footer-cta{flex-direction:column;align-items:flex-start;gap:20px;padding-bottom:40px;}
  .footer-cta h3{font-size:clamp(30px,8vw,44px);letter-spacing:-1.4px;}
  .footer-cta-btn{width:100%;justify-content:center;padding:14px 22px;}
  .footer-bottom{flex-direction:column;align-items:flex-start;gap:10px;text-align:left;}

  .feat-grid,.feat-grid.four{grid-template-columns:1fr;gap:10px;}
  .feat-card{padding:22px;}
  .kpi-row,.kpi-row.three,.kpi-row.two{grid-template-columns:1fr 1fr;}

  .faq-section{padding:64px var(--pad);}
  .faq-q{font-size:15.5px;gap:14px;padding:18px 0;}

  .btn-primary,.btn-ghost,.btn-product,.btn-ghost-sticky{padding:13px 20px;font-size:13.5px;}

  /* Touch targets — make sure interactives are at least 44px tall */
  .nav-cta,.btn-primary,.btn-ghost,.btn-product,.btn-ghost-sticky{min-height:44px;}

  .plogo{width:54px;height:54px;border-radius:14px;}
  .plogo svg{width:26px;height:26px;}
  .plogo.lg{width:72px;height:72px;border-radius:18px;}
  .plogo.lg svg{width:34px;height:34px;}
}

/* Mobile S — iPhone SE / very narrow */
@media (max-width:380px){
  :root{--pad:16px;}
  nav.knop-nav{padding:8px 10px;}
  .nav-shell{padding:5px 5px 5px 10px;gap:6px;}
  .logo-text{font-size:12px;}
  .nav-cta{padding:7px 10px 7px 12px;font-size:11.5px;}
  .nav-cta .arr{width:14px;height:14px;}
  .nav-lang button{padding:4px 6px;font-size:9.5px;}
  .nav-theme{width:32px;height:32px;}
  .nav-mobile{width:34px;height:34px;}

  .hero{padding:92px var(--pad) 48px;}
  .hero-h1{font-size:clamp(30px,9vw,42px);letter-spacing:-1.4px;}
  .hero-sub{font-size:14.5px;}
  .s-title{font-size:clamp(24px,7vw,32px);letter-spacing:-1px;}
}

/* ============================================================
   UNIVERSAL WAITLIST MODAL
   ============================================================ */
.wl-modal{
  position:fixed;inset:0;z-index:9999;
  display:flex;align-items:center;justify-content:center;
  visibility:hidden;pointer-events:none;
}
.wl-modal.open{visibility:visible;pointer-events:auto;}
.wl-overlay{
  position:absolute;inset:0;
  background:rgba(10,11,13,.55);backdrop-filter:blur(6px);
  opacity:0;transition:opacity .35s ease;
  cursor:pointer;
}
.wl-modal.open .wl-overlay{opacity:1;}
.wl-dialog{
  position:relative;z-index:1;width:min(540px, calc(100vw - 32px));
  max-height:calc(100vh - 48px);overflow-y:auto;
  background:var(--surface);border:1px solid var(--line);
  border-radius:24px;
  box-shadow:0 40px 100px -20px rgba(10,11,13,.4),0 12px 30px -10px rgba(10,11,13,.18);
  padding:36px;
  transform:translateY(20px) scale(.97);opacity:0;
  transition:transform .4s cubic-bezier(.25,.85,.25,1),opacity .35s;
}
.wl-modal.open .wl-dialog{transform:translateY(0) scale(1);opacity:1;}
body.dark .wl-dialog{
  background:rgba(18,20,24,.78);
  backdrop-filter:blur(32px) saturate(150%);
  -webkit-backdrop-filter:blur(32px) saturate(150%);
  border-color:rgba(255,255,255,.07);
  box-shadow:0 40px 100px -20px rgba(0,0,0,.7),0 12px 30px -10px rgba(0,0,0,.4);
}

.wl-close{
  position:absolute;top:16px;right:16px;
  width:34px;height:34px;border-radius:50%;
  background:var(--bg-soft);border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;color:var(--ink);font-size:20px;line-height:1;
  transition:background .2s,transform .2s,color .2s;
}
.wl-close:hover{background:var(--ink);color:#fff;transform:rotate(90deg);}
body.dark .wl-close{
  background:rgba(255,255,255,.06);
  border-color:rgba(255,255,255,.08);
  color:#fff;
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
}
body.dark .wl-close:hover{background:#fff;color:#0A0B0D;}

/* Article drawer (blog) — matte glass in dark */
body.dark .article-drawer{
  background:rgba(18,20,24,.92);
  border-left:1px solid rgba(255,255,255,.06);
  box-shadow:-30px 0 80px -20px rgba(0,0,0,.6);
}
body.dark .article-drawer-overlay{background:rgba(0,0,0,.72);backdrop-filter:blur(8px);}
body.dark .article-drawer-close{
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.08);
  color:#fff;
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
}

/* Mobile nav drawer — matte glass in dark */
body.dark .nav-mobile-menu,
body.dark .mobile-menu,
body.dark .nav-drawer{
  background:rgba(14,16,20,.78);
  backdrop-filter:blur(28px) saturate(150%);
  -webkit-backdrop-filter:blur(28px) saturate(150%);
  border-color:rgba(255,255,255,.06);
}

.wl-head{margin-bottom:22px;}
.wl-eye{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--mono);font-size:11px;color:var(--ink-d);letter-spacing:.05em;
  margin-bottom:14px;
}
.wl-eye-dot{
  width:7px;height:7px;border-radius:50%;background:var(--pop);
  animation:wlPulse 1.6s ease-in-out infinite;box-shadow:0 0 8px var(--pop);
}
@keyframes wlPulse{0%,100%{opacity:1;}50%{opacity:.4;}}
.wl-head h2{
  font-family:var(--f-soft,'Bricolage Grotesque',sans-serif);
  font-size:28px;font-weight:600;letter-spacing:-.8px;line-height:1.05;
  color:var(--ink);margin-bottom:8px;
}
.wl-head p{
  font-size:14.5px;line-height:1.55;color:var(--ink-2);max-width:42ch;
}

.wl-form{
  display:grid;grid-template-columns:1fr 1fr;gap:14px 12px;
}
.wl-form label{
  display:flex;flex-direction:column;gap:6px;
  font-family:var(--mono);font-size:10.5px;color:var(--ink-d);
  text-transform:uppercase;letter-spacing:.04em;font-weight:600;
}
.wl-form .wl-full{grid-column:1 / -1;}
.wl-form input,
.wl-form textarea{
  background:var(--bg-soft);border:1px solid var(--line);
  border-radius:10px;padding:10px 14px;
  font-family:var(--font,inherit);font-size:14px;color:var(--ink) !important;
  outline:none;transition:border-color .2s,background .2s;
  width:100%;
}
.wl-form input::placeholder,
.wl-form textarea::placeholder{color:var(--ink-d);opacity:.7;}
body.dark .wl-form input,
body.dark .wl-form textarea{background:rgba(255,255,255,.04);border-color:rgba(255,255,255,.1);color:#F5F6F8 !important;}
body.dark .wl-form input::placeholder,
body.dark .wl-form textarea::placeholder{color:rgba(245,246,248,.45);}
.wl-form input:focus,
.wl-form textarea:focus{border-color:var(--pop);background:var(--surface);color:var(--ink) !important;}
body.dark .wl-form input:focus,
body.dark .wl-form textarea:focus{background:rgba(255,255,255,.08);border-color:var(--pop);color:#F5F6F8 !important;}
.wl-form textarea{resize:vertical;min-height:60px;font-family:var(--font,inherit);}

.wl-submit{
  grid-column:1 / -1;margin-top:6px;
  background:var(--pop);color:#fff;
  border:none;border-radius:99px;padding:14px 22px;
  font-size:14px;font-weight:600;letter-spacing:-.1px;
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  cursor:pointer;transition:transform .2s,box-shadow .25s,background .25s;
}
.wl-submit:hover{transform:translateY(-2px);box-shadow:0 12px 28px -8px var(--pop);}
.wl-submit .arr{transition:transform .25s;}
.wl-submit:hover .arr{transform:translateX(4px);}

.wl-status{
  grid-column:1 / -1;font-family:var(--mono);font-size:12px;
  text-align:center;color:var(--ink-d);min-height:1.2em;
}
.wl-status.ok{color:#10B981;}
.wl-status.err{color:#EF4444;}

@media (max-width:520px){
  .wl-dialog{padding:28px 22px;border-radius:18px;}
  .wl-form{grid-template-columns:1fr;}
  .wl-head h2{font-size:22px;}
}

/* ============================================================
   DARK THEME — readability boosters
   ============================================================ */
body.dark .s-sub,
body.dark .hero-sub,
body.dark .hero-sub-rich,
body.dark .manifesto p,
body.dark .manif-b,
body.dark .feat-card p,
body.dark .lms-why p,
body.dark .erp-why p,
body.dark .crm-why p,
body.dark .why-card p,
body.dark .partnership-body{
  color:#CDD2DB;
}
body.dark .s-title,
body.dark .feat-card h3,
body.dark .why-card h3,
body.dark .manif-h{
  color:#F5F6F8;
}
