  :root{
    --ink:#0A1628;
    --ink-2:#11203A;
    --paper:#F1F2F4;
    --paper-2:#FFFFFF;
    --line:#1d2b46;
    --line-light:#0a16281a;
    --green:#1F6F4A;
    --green-2:#2A8E5F;
    --blue:#2C5AA0;
    --blue-2:#3F73C2;
    --muted:#5b6678;
    --maxw:1320px;
    --nav-h:87px;
    /* surfaces • themed (default = light) */
    --surface:#F1F2F4;
    --surface-2:#FFFFFF;
    --text:#0A1628;
    --text-soft:#1f2a40;
    --text-muted:#5b6678;
    --border:#0a16281a;
    --nav-bg:rgba(255,255,255,.6);
  }
  html[data-theme="dark"]{
    --surface:#0A1628;
    --surface-2:#11203A;
    --text:#F1F2F4;
    --text-soft:#dde3ee;
    --text-muted:#a8b2c4;
    --border:rgba(255,255,255,.10);
    --nav-bg:rgba(10,22,40,.65);
    --line-light:rgba(255,255,255,.10);
    --muted:#a8b2c4;
  }
  html[data-theme="dark"] body{background:var(--surface);color:var(--text)}
  html[data-theme="dark"] .hero{background:var(--surface)}
  html[data-theme="dark"] .hero h1 .ink{color:var(--text)}
  html[data-theme="dark"] .hero h1 .stripes{background:repeating-linear-gradient(90deg,var(--text) 0 6px,transparent 6px 12px);-webkit-background-clip:text;background-clip:text;color:transparent}
  html[data-theme="dark"] .hero-sub{color:var(--text-soft)}
  html[data-theme="dark"] .hero-bg .grid-lines{background-image:linear-gradient(to right,rgba(255,255,255,.05) 1px,transparent 1px),linear-gradient(to bottom,rgba(255,255,255,.05) 1px,transparent 1px)}
  html[data-theme="dark"] .page-blob{mix-blend-mode:screen}
  html[data-theme="dark"] .page-blob.pb1{background:radial-gradient(circle,#3F73C2 0%,transparent 65%);opacity:.55}
  html[data-theme="dark"] .page-blob.pb2{background:radial-gradient(circle,#1F6F4A 0%,transparent 65%);opacity:.5}
  html[data-theme="dark"] .page-blob.pb3{background:radial-gradient(circle,#5B2C8C 0%,transparent 65%);opacity:.45}
  html[data-theme="dark"] .page-blob.pb4{background:radial-gradient(circle,#2A8E5F 0%,transparent 65%);opacity:.45}
  html[data-theme="dark"] .page-particles span{background:#9DB1D4}
  html[data-theme="dark"] .page-particles span:nth-child(2),
  html[data-theme="dark"] .page-particles span:nth-child(6),
  html[data-theme="dark"] .page-particles span:nth-child(10){background:#3F73C2}
  html[data-theme="dark"] .page-particles span:nth-child(4),
  html[data-theme="dark"] .page-particles span:nth-child(8),
  html[data-theme="dark"] .page-particles span:nth-child(12){background:#2A8E5F}
  html[data-theme="dark"] .page-particles span:nth-child(6),
  html[data-theme="dark"] .page-particles span:nth-child(11){background:#5B2C8C}
  html[data-theme="dark"] .ill{color:var(--text)}
  html[data-theme="dark"] .nav{background:var(--nav-bg);border-bottom-color:rgba(255,255,255,.08)}
  html[data-theme="dark"] .nav-links a:hover{color:var(--green-2)}
  html[data-theme="dark"] .lang{border-color:rgba(255,255,255,.18);color:var(--text-muted)}
  html[data-theme="dark"] .lang b{color:var(--text)}
  /* Solid .btn — base uses --ink (always navy) which becomes invisible on the
     dark surface (also navy). Re-paint border/bg/color with theme-aware tokens. */
  html[data-theme="dark"] .btn{
    background:var(--text);color:var(--surface);border-color:var(--text);
  }
  html[data-theme="dark"] .btn:hover{
    background:var(--green-2);border-color:var(--green-2);color:var(--surface);
  }
  html[data-theme="dark"] .btn.ghost{
    background:transparent;color:var(--text);border-color:var(--text);
  }
  html[data-theme="dark"] .btn.ghost:hover{background:var(--text);color:var(--surface)}
  html[data-theme="dark"] .sec{background:var(--surface);border-bottom-color:var(--border)}
  html[data-theme="dark"] .sec-head{background:#11203A;border-color:rgba(255,255,255,.08)}
  html[data-theme="dark"] .sec[id="about"] .sec-head{background:#11203A}
  html[data-theme="dark"] .sec[id="about"] .sec-head .sec-title,
  html[data-theme="dark"] .sec[id="platform"] .sec-head .sec-title,
  html[data-theme="dark"] .sec[id="extend"] .sec-head .sec-title,
  html[data-theme="dark"] .sec[id="clients"] .sec-head .sec-title,
  html[data-theme="dark"] .sec[id="product"] .sec-head .sec-title{color:var(--text)}
  html[data-theme="dark"] .sec[id="about"] .sec-head .sec-num,
  html[data-theme="dark"] .sec[id="platform"] .sec-head .sec-num,
  html[data-theme="dark"] .sec[id="extend"] .sec-head .sec-num,
  html[data-theme="dark"] .sec[id="clients"] .sec-head .sec-num{color:var(--text-muted)}
  html[data-theme="dark"] .sec[id="about"] .sec-head .sec-num b,
  html[data-theme="dark"] .sec[id="platform"] .sec-head .sec-num b,
  html[data-theme="dark"] .sec[id="extend"] .sec-head .sec-num b,
  html[data-theme="dark"] .sec[id="clients"] .sec-head .sec-num b{color:var(--text)}
  html[data-theme="dark"] .sec[id="platform"] .sec-head{background:#0e2746}
  html[data-theme="dark"] .sec[id="extend"] .sec-head{background:#0e2746}
  html[data-theme="dark"] .sec[id="clients"] .sec-head{background:#1a1714}
  html[data-theme="dark"] .eam-text p{color:var(--text-soft)}
  html[data-theme="dark"] .eam-text p.lead{color:var(--text)}
  html[data-theme="dark"] .eam-list{border-top-color:var(--border)}
  html[data-theme="dark"] .eam-list li{border-bottom-color:var(--border)}
  html[data-theme="dark"] .eam-list .t{color:var(--text)}
  html[data-theme="dark"] .modules{border-color:var(--border)}
  html[data-theme="dark"] .mod{background:var(--surface-2);border-color:var(--border);color:var(--text)}
  html[data-theme="dark"] .mod:hover{background:#0e2746}
  html[data-theme="dark"] .mod-desc{color:var(--text-muted)}
  html[data-theme="dark"] .mod-num{color:var(--text-muted)}
  html[data-theme="dark"] .trusted{border-color:var(--border)}
  html[data-theme="dark"] .logo-cell{border-color:var(--border);color:var(--text-muted)}
  html[data-theme="dark"] .logo-cell:hover{color:var(--text);background:var(--surface-2)}
  html[data-theme="dark"] .logo-cell.placeholder{background:repeating-linear-gradient(45deg,#11203A 0 12px,#162a48 12px 24px);color:#5b6678}
  html[data-theme="dark"] .logo-cell.placeholder:hover{color:#5b6678;background:repeating-linear-gradient(45deg,#11203A 0 12px,#162a48 12px 24px)}
  html[data-theme="dark"] .trusted-overlay span{
    color:var(--text);background:rgba(11,21,38,.75);border-color:var(--border);
  }
  html[data-theme="dark"] .cta{background:var(--surface)}
  html[data-theme="dark"] .cta h2{color:var(--text)}
  html[data-theme="dark"] .cta h2 em{color:var(--blue-2)}
  html[data-theme="dark"] .cta-form{background:var(--surface-2);border-color:var(--border)}
  html[data-theme="dark"] .cta-form input{color:var(--text);border-bottom-color:var(--text)}
  html[data-theme="dark"] .cta-form input::placeholder{color:var(--text-muted)}
  html[data-theme="dark"] .cta .paper .pg{fill:#1a2b48;stroke:rgba(255,255,255,.20)}
  html[data-theme="dark"] .cta .paper .ln{stroke:rgba(255,255,255,.10)}
  html[data-theme="dark"] .meta-item .lbl{color:var(--text-muted)}
  html[data-theme="dark"] .step .d{color:var(--text-soft)}
  html[data-theme="dark"] .ind{background:var(--surface-2)}
  html[data-theme="dark"] .ind:hover{background:#0e2746}
  html[data-theme="dark"] .industries{border-color:var(--border);background:var(--border)}
  html[data-theme="dark"] .ind .tag{color:var(--text-muted)}
  html[data-theme="dark"] .nav-links a{color:var(--text)}
  *{box-sizing:border-box}
  html,body{margin:0;padding:0}
  body{
    font-family:'Inter',sans-serif;
    background:#dde3ed;
    color:var(--ink);
    -webkit-font-smoothing:antialiased;
    font-size:16px;
    line-height:1.55;
    width:100%;
    max-width:100vw;
    overflow-x:clip;
  }
  a{color:inherit;text-decoration:none}

  /* ---------- ANIMATIONS ---------- */
  @keyframes fadeUp{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}
  @keyframes fadeIn{from{opacity:0}to{opacity:1}}
  @keyframes slideRight{from{opacity:0;transform:translateX(-30px)}to{opacity:1;transform:translateX(0)}}
  @keyframes slideLeft{from{opacity:0;transform:translateX(30px)}to{opacity:1;transform:translateX(0)}}
  @keyframes scaleIn{from{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}
  @keyframes pulseDot{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.3)}}
  @keyframes barGrow{from{transform:scaleX(0)}to{transform:scaleX(1)}}
  @keyframes spinSlow{from{transform:rotate(0)}to{transform:rotate(360deg)}}

  [data-anim]{opacity:0;will-change:transform,opacity}
  [data-anim].in{animation:fadeUp .9s cubic-bezier(.2,.7,.2,1) both}
  [data-anim="fade"].in{animation:fadeIn 1.1s ease both}
  [data-anim="right"].in{animation:slideRight .9s cubic-bezier(.2,.7,.2,1) both}
  [data-anim="left"].in{animation:slideLeft .9s cubic-bezier(.2,.7,.2,1) both}
  [data-anim="scale"].in{animation:scaleIn .9s cubic-bezier(.2,.7,.2,1) both}
  [data-delay="1"]{animation-delay:.08s !important}
  [data-delay="2"]{animation-delay:.16s !important}
  [data-delay="3"]{animation-delay:.24s !important}
  [data-delay="4"]{animation-delay:.32s !important}
  [data-delay="5"]{animation-delay:.40s !important}
  [data-delay="6"]{animation-delay:.48s !important}
  [data-delay="7"]{animation-delay:.56s !important}
  [data-delay="8"]{animation-delay:.64s !important}

  html{scroll-behavior:smooth;scroll-padding-top:var(--nav-h)}
  /* anchor target sections clear the sticky header */
  section[id]{scroll-margin-top:var(--nav-h)}
  /* sections with intrinsic top padding need the offset pulled back so the
     visible content (header band, eyebrow) lands at the nav bottom */
  section#mobile{scroll-margin-top:calc(var(--nav-h) - 120px)}
  section#ai{scroll-margin-top:calc(var(--nav-h) - 140px)}
  section#contact{scroll-margin-top:calc(var(--nav-h) - 120px)}
  @media(max-width:1100px){
    section#mobile,section#contact{scroll-margin-top:calc(var(--nav-h) - 80px)}
    section#ai{scroll-margin-top:calc(var(--nav-h) - 80px)}
  }
  @media (prefers-reduced-motion:reduce){
    [data-anim],[data-anim].in{animation:none !important;opacity:1 !important;transform:none !important}
    html{scroll-behavior:auto}
  }

  /* RTL ---------- */
  html[dir="rtl"] body, html[dir="rtl"] body *{font-family:'Cairo',sans-serif !important;letter-spacing:0 !important}
  /* keep monospace + the EN/AR pill itself in their own faces */
  html[dir="rtl"] .mono, html[dir="rtl"] code, html[dir="rtl"] pre, html[dir="rtl"] .lang, html[dir="rtl"] .lang *{font-family:'JetBrains Mono',monospace !important;letter-spacing:.12em !important}
  /* keep the logo SVG in Poppins (Latin), not Cairo */
  html[dir="rtl"] .brand svg, html[dir="rtl"] .brand svg *,
  html[dir="rtl"] .foot-brand svg, html[dir="rtl"] .foot-brand svg *{font-family:'Poppins',sans-serif !important;letter-spacing:normal !important}
  html[dir="rtl"] .btn .arrow{transform:scaleX(-1)}
  html[dir="rtl"] .btn:hover .arrow{transform:scaleX(-1) translateX(4px)}
  html[dir="rtl"] .mod-arrow svg{transform:scaleX(-1)}
  html[dir="rtl"] .mod:hover .mod-arrow{transform:translate(-4px,-4px)}
  html[dir="rtl"] .hero-side{border-left:none;border-right:1px solid var(--line-light);padding-left:0;padding-right:40px}
  @media(max-width:1000px){html[dir="rtl"] .hero-side{border-right:none;padding-right:0}}
  /* keep the section accent strip on the visual left in both LTR and RTL */
  html[dir="rtl"] .step{border-top:2px solid var(--ink)}
  html[dir="rtl"] .ticker-track{animation-direction:reverse}
  html[dir="rtl"] .lang{direction:ltr}
  /* Arabic-only: shrink hero headline (Cairo runs ~10% larger than Space Grotesk at the same size) */
  html[dir="rtl"] .hero h1{font-size:clamp(24px,4.6vw,76px);line-height:1.25}
  /* Arabic glyphs (Cairo) are taller than Space Grotesk • let them breathe and stop clipping descenders/diacritics */
  html[dir="rtl"] .hero h1 .line{overflow:visible;line-height:1.25;padding-bottom:.18em}
  /* Arabic-only: footer brand block right-aligned */
  html[dir="rtl"] .foot-brand{text-align:right;display:flex;flex-direction:column;align-items:flex-end;width:100%}
  html[dir="rtl"] .foot-brand img,html[dir="rtl"] .foot-brand svg{display:block;margin-left:auto;margin-right:0;align-self:flex-end}
  html[dir="rtl"] .foot-brand p{margin:18px 0 0;max-width:340px;align-self:flex-end;text-align:right}
  .wrap{max-width:var(--maxw);margin:0 auto;padding:0 32px}
  .mono{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
  .display{font-family:'Space Grotesk',sans-serif;font-weight:700;letter-spacing:-0.02em;line-height:1}
  .h-section{font-family:'Space Grotesk',sans-serif;font-weight:600;letter-spacing:-0.015em;line-height:1.05}
  .rule{height:1px;background:var(--line-light)}
  .btn{
    display:inline-flex;align-items:center;gap:10px;
    padding:14px 22px;border:1px solid var(--ink);background:var(--ink);color:var(--paper);
    font-family:'Space Grotesk',sans-serif;font-weight:500;font-size:14px;letter-spacing:.02em;
    transition:transform .2s ease, background .2s ease;
  }
  .btn:hover{background:var(--green);border-color:var(--green);transform:translateY(-1px)}
  .btn.ghost{background:transparent;color:var(--ink)}
  .btn.ghost:hover{background:var(--ink);color:var(--paper)}
  .btn .arrow{display:inline-block;transition:transform .2s ease}
  .btn:hover .arrow{transform:translateX(4px)}

  /* ---------- NAV ---------- */
  .nav{
    position:sticky;top:0;z-index:50;
    background:rgba(255,255,255,.6);
    backdrop-filter:saturate(160%) blur(14px);
    -webkit-backdrop-filter:saturate(160%) blur(14px);
    border-bottom:1px solid rgba(10,22,40,.08);
  }
  .nav-inner{display:flex;align-items:center;justify-content:space-between;padding:18px 32px;max-width:var(--maxw);margin:0 auto}
  .brand{display:flex;align-items:center;gap:12px;direction:ltr}
  .brand img,.brand svg{height:50px;width:auto;direction:ltr}
  .brand svg text{direction:ltr;unicode-bidi:bidi-override}
  .brand .logo-light{display:block}
  .brand .logo-dark{display:none}
  html[data-theme="dark"] .brand .logo-light{display:none}
  html[data-theme="dark"] .brand .logo-dark{display:block}
  .nav-links{display:flex;gap:34px;font-size:14px;font-weight:500}
  .nav-links a{position:relative;padding:6px 0}
  .nav-links a:hover{color:var(--green)}
  .nav-cta{display:flex;align-items:center;gap:18px}
  .lang{font-family:'JetBrains Mono',monospace;font-size:12px;color:var(--muted);border:1px solid var(--line-light);padding:6px 10px}
  .lang b{color:var(--ink)}
  /* Force the Arabic word in the language pill to render in Cairo, even in RTL mode where .lang is mono'd */
  .lang .ar, html[dir="rtl"] .lang .ar{font-family:'Cairo',sans-serif !important;letter-spacing:0 !important;font-size:13px;font-weight:600}
  .theme-toggle{
    width:34px;height:34px;border-radius:50%;border:1px solid var(--line-light);
    background:transparent;color:var(--ink);cursor:pointer;
    display:inline-flex;align-items:center;justify-content:center;padding:0;
    transition:background .2s ease, color .2s ease, border-color .2s ease;
  }
  .theme-toggle:hover{background:var(--ink);color:var(--paper);border-color:var(--ink)}
  .theme-toggle svg{width:16px;height:16px}
  .theme-toggle .ic-moon{display:none}
  html[data-theme="dark"] .theme-toggle{color:var(--text);border-color:var(--border)}
  html[data-theme="dark"] .theme-toggle:hover{background:var(--text);color:var(--surface);border-color:var(--text)}
  html[data-theme="dark"] .theme-toggle .ic-sun{display:none}
  html[data-theme="dark"] .theme-toggle .ic-moon{display:block}
  @media(max-width:900px){.nav-links{display:none}}

  /* ---------- MOBILE NAV ---------- */
  .nav-burger{
    display:none;
    width:38px;height:38px;border:1px solid var(--line-light);border-radius:50%;
    background:transparent;color:var(--ink);cursor:pointer;padding:0;
    flex-direction:column;align-items:center;justify-content:center;gap:4px;
    transition:background .2s ease, color .2s ease, border-color .2s ease;
  }
  .nav-burger span{width:16px;height:2px;background:currentColor;border-radius:2px;transition:transform .25s ease, opacity .25s ease}
  .nav-burger:hover{background:var(--ink);color:var(--paper);border-color:var(--ink)}
  .nav-burger[aria-expanded="true"] span:nth-child(1){transform:translateY(6px) rotate(45deg)}
  .nav-burger[aria-expanded="true"] span:nth-child(2){opacity:0}
  .nav-burger[aria-expanded="true"] span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}
  html[data-theme="dark"] .nav-burger{color:var(--text);border-color:var(--border)}
  html[data-theme="dark"] .nav-burger:hover{background:var(--text);color:var(--surface);border-color:var(--text)}

  .mobile-menu{
    display:none;
    background:var(--paper-2);
    border-bottom:1px solid var(--line-light);
    padding:8px 24px 16px;
    flex-direction:column;
  }
  .mobile-menu[hidden]{display:none !important}
  .mobile-menu a{
    display:block;padding:14px 4px;
    font-family:'Space Grotesk',sans-serif;font-weight:500;font-size:16px;
    color:var(--ink);
    border-bottom:1px solid var(--line-light);
  }
  .mobile-menu a:last-child{border-bottom:none}
  .mobile-menu .mobile-menu-cta{
    margin-top:10px;background:var(--ink);color:var(--paper);
    text-align:center;border:none;padding:14px;letter-spacing:.02em;
  }
  .mobile-menu .mobile-menu-lang{
    display:flex;align-items:center;justify-content:center;
    margin:6px 0 0;padding:12px;
    font-family:'JetBrains Mono',monospace;font-size:13px;letter-spacing:.12em;
    background:transparent;color:var(--ink);
    border:1px solid var(--line-light);border-radius:0;cursor:pointer;
  }
  .mobile-menu .mobile-menu-lang:hover{background:var(--ink);color:var(--paper);border-color:var(--ink)}
  .mobile-menu .mobile-menu-lang .ar{font-family:'Cairo',sans-serif !important;letter-spacing:0 !important;font-size:14px;font-weight:600;margin-left:4px}
  html[dir="rtl"] .mobile-menu .mobile-menu-lang{direction:ltr}
  html[data-theme="dark"] .mobile-menu .mobile-menu-lang{color:var(--text);border-color:var(--border)}
  html[data-theme="dark"] .mobile-menu .mobile-menu-lang:hover{background:var(--text);color:var(--surface);border-color:var(--text)}
  html[data-theme="dark"] .mobile-menu{background:var(--surface-2);border-bottom-color:var(--border)}
  html[data-theme="dark"] .mobile-menu a{color:var(--text);border-bottom-color:var(--border)}
  html[data-theme="dark"] .mobile-menu .mobile-menu-cta{background:var(--text);color:var(--surface)}

  @media(max-width:900px){
    .nav-burger{display:flex}
    .mobile-menu.open{display:flex}
  }

  /* ---------- HERO ---------- */
  .hero{
    position:relative;
    padding:90px 0 70px;
    border-bottom:1px solid var(--line-light);
    overflow:hidden;
  }
  .hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:60px;align-items:end}
  @media(max-width:1000px){.hero-grid{grid-template-columns:1fr;gap:40px}}
  .eyebrow{display:flex;align-items:center;gap:14px;margin-bottom:32px}
  .eyebrow .dot{width:8px;height:8px;background:var(--green);border-radius:50%}
  .hero h1{
    font-family:'Space Grotesk',sans-serif;font-weight:700;
    font-size:clamp(34px,5.6vw,86px);
    line-height:.94;letter-spacing:-0.03em;
    margin:0 0 24px;
  }
  .hero h1 .ink{color:var(--ink)}
  .hero h1 .accent{color:var(--green);font-style:italic;font-weight:500}
  .hero h1 .stripes{
    background:repeating-linear-gradient(90deg, var(--ink) 0 6px, transparent 6px 12px);
    -webkit-background-clip:text;background-clip:text;color:transparent;
  }
  .hero-sub{max-width:560px;font-size:18px;color:#28344a;margin:0 0 36px;line-height:1.5}
  .hero-actions{display:flex;gap:14px;flex-wrap:wrap}
  .hero-side{
    border-left:1px solid var(--line-light);padding-left:40px;
  }
  @media(max-width:1000px){.hero-side{border-left:none;padding-left:0;border-top:1px solid var(--line-light);padding-top:30px}}
  .hero-meta{display:grid;grid-template-columns:1fr 1fr;gap:24px 30px;margin-bottom:30px}
  .meta-item .num{font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:42px;letter-spacing:-0.02em;line-height:1}
  .meta-item .lbl{margin-top:8px;font-size:13px;color:var(--muted);max-width:180px}
  .hero-card{
    background:var(--ink);color:var(--paper);
    padding:24px;
    display:flex;flex-direction:column;gap:14px;
  }
  .hero-card .row{display:flex;justify-content:space-between;align-items:center;font-family:'JetBrains Mono',monospace;font-size:12px}
  .hero-card .row span:last-child{color:var(--green-2)}
  .hero-card .bar{height:4px;background:#1c2c4a;position:relative;overflow:hidden}
  .hero-card .bar i{position:absolute;left:0;top:0;bottom:0;background:var(--green-2)}

  /* hero animated background • asset / meter / work-order illustrations */
  .hero{position:relative;isolation:isolate;background:transparent}
  .hero-bg{position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:0}
  .hero-grid{position:relative;z-index:2}
  .hero-bg .grid-lines{position:absolute;inset:0;background-image:linear-gradient(to right,rgba(10,22,40,.05) 1px,transparent 1px),linear-gradient(to bottom,rgba(10,22,40,.05) 1px,transparent 1px);background-size:80px 80px;mask-image:radial-gradient(ellipse at 70% 40%,#000 30%,transparent 80%);-webkit-mask-image:radial-gradient(ellipse at 70% 40%,#000 30%,transparent 80%);animation:gridShift 60s linear infinite}
  @keyframes gridShift{from{background-position:0 0}to{background-position:80px 80px}}

  /* ====== Site-wide aurora (fixed, sits behind every section) ====== */
  .page-aurora{position:fixed;inset:0;z-index:-1;pointer-events:none;overflow:hidden}
  .page-blob{position:absolute;border-radius:50%;filter:blur(80px);mix-blend-mode:multiply;will-change:transform}
  .page-blob.pb1{width:55vw;height:55vw;background:radial-gradient(circle,#7ea4d6 0%,transparent 65%);
    top:-10%;left:-10%;opacity:.85;animation:pbDrift1 22s ease-in-out infinite alternate}
  .page-blob.pb2{width:50vw;height:50vw;background:radial-gradient(circle,#7fbf9c 0%,transparent 65%);
    bottom:-15%;right:-10%;opacity:.75;animation:pbDrift2 26s ease-in-out infinite alternate}
  .page-blob.pb3{width:42vw;height:42vw;background:radial-gradient(circle,#b491cf 0%,transparent 65%);
    top:30%;right:15%;opacity:.7;animation:pbDrift3 30s ease-in-out infinite alternate}
  .page-blob.pb4{width:38vw;height:38vw;background:radial-gradient(circle,#9bc7b0 0%,transparent 65%);
    bottom:15%;left:10%;opacity:.7;animation:pbDrift4 28s ease-in-out infinite alternate}
  @keyframes pbDrift1{0%{transform:translate(0,0) scale(1)}100%{transform:translate(15vw,8vh) scale(1.15)}}
  @keyframes pbDrift2{0%{transform:translate(0,0) scale(1)}100%{transform:translate(-12vw,-10vh) scale(1.1)}}
  @keyframes pbDrift3{0%{transform:translate(0,0)}100%{transform:translate(-18vw,12vh)}}
  @keyframes pbDrift4{0%{transform:translate(0,0)}100%{transform:translate(20vw,-15vh)}}

  .page-particles{position:absolute;inset:0;pointer-events:none}
  .page-particles span{position:absolute;width:4px;height:4px;border-radius:50%;background:#0A1628;opacity:0;animation:pbFloat 14s linear infinite}
  .page-particles span:nth-child(1){left:5%;animation-delay:0s;animation-duration:16s}
  .page-particles span:nth-child(2){left:15%;animation-delay:2s;animation-duration:18s;background:#2C5AA0}
  .page-particles span:nth-child(3){left:23%;animation-delay:5s;animation-duration:14s}
  .page-particles span:nth-child(4){left:32%;animation-delay:1s;animation-duration:20s;background:#1F6F4A}
  .page-particles span:nth-child(5){left:41%;animation-delay:7s;animation-duration:15s}
  .page-particles span:nth-child(6){left:50%;animation-delay:3s;animation-duration:17s;background:#5B2C8C}
  .page-particles span:nth-child(7){left:59%;animation-delay:9s;animation-duration:19s}
  .page-particles span:nth-child(8){left:68%;animation-delay:4s;animation-duration:14s;background:#1F6F4A}
  .page-particles span:nth-child(9){left:77%;animation-delay:11s;animation-duration:18s}
  .page-particles span:nth-child(10){left:86%;animation-delay:6s;animation-duration:16s;background:#2C5AA0}
  .page-particles span:nth-child(11){left:38%;animation-delay:13s;animation-duration:17s;background:#5B2C8C}
  .page-particles span:nth-child(12){left:72%;animation-delay:8s;animation-duration:15s;background:#1F6F4A}
  @keyframes pbFloat{
    0%{transform:translateY(105vh) scale(0);opacity:0}
    10%{opacity:.5}
    90%{opacity:.5}
    100%{transform:translateY(-10vh) scale(1.2);opacity:0}
  }
  @media(prefers-reduced-motion:reduce){
    .page-blob,.page-particles span{animation:none}
  }

  /* illustration tile base */
  .ill{position:absolute;color:var(--ink);opacity:.10;pointer-events:none}
  .ill svg{width:100%;height:100%;display:block;overflow:visible}
  .ill svg *{vector-effect:non-scaling-stroke}

  /* placements */
  .ill.gauge   {top:8%; right:6%; width:230px; height:230px; opacity:.13;animation:floatA 14s ease-in-out infinite alternate}
  .ill.wo      {top:54%;right:14%;width:280px; height:200px; opacity:.10;animation:floatB 18s ease-in-out infinite alternate}
  .ill.gear-a  {top:16%;right:38%;width:160px; height:160px; opacity:.07;animation:spinSlow 32s linear infinite}
  .ill.gear-b  {top:74%;right:34%;width:110px; height:110px; opacity:.06;animation:spinSlowR 26s linear infinite}
  .ill.wave    {top:38%;left:0;   width:62%;   height:120px; opacity:.18}
  .ill.pipe    {bottom:0; left:6%; width:46%;  height:160px; opacity:.10}
  .ill.hexchip {top:64%;left:8%; width:140px;height:140px; opacity:.10;animation:floatA 16s ease-in-out infinite alternate-reverse}
  .ill.tag     {top:22%;left:6%; width:230px;height:80px; opacity:.12;animation:floatB 20s ease-in-out infinite alternate}

  @keyframes floatA{from{transform:translate(0,0)}to{transform:translate(-12px,18px)}}
  @keyframes floatB{from{transform:translate(0,0)}to{transform:translate(16px,-14px)}}
  @keyframes spinSlow{from{transform:rotate(0)}to{transform:rotate(360deg)}}
  @keyframes spinSlowR{from{transform:rotate(0)}to{transform:rotate(-360deg)}}

  /* animated dash on wave + pipe */
  .ill .flow{stroke-dasharray:6 10;animation:dash 6s linear infinite}
  @keyframes dash{from{stroke-dashoffset:0}to{stroke-dashoffset:-160}}

  /* gauge needle sweep */
  .ill .needle{transform-origin:100px 100px;animation:needle 8s ease-in-out infinite alternate}
  @keyframes needle{from{transform:rotate(-50deg)}to{transform:rotate(60deg)}}

  /* signal blip on hexchip */
  .ill .blip{animation:blink 2.4s ease-in-out infinite}
  @keyframes blink{0%,100%{opacity:.2}50%{opacity:1}}

  /* WO progress fill */
  .ill .progress{stroke-dasharray:120;stroke-dashoffset:120;animation:fill 7s ease-in-out infinite alternate}
  @keyframes fill{to{stroke-dashoffset:24}}

  /* ===== animated hero headline ===== */
  .hero h1 .line{display:inline-block;overflow:hidden;line-height:.95;padding-bottom:.04em}
  .hero h1 .line > span{display:inline-block;transform:translateY(110%);opacity:0;animation:lineUp .9s cubic-bezier(.2,.7,.2,1) forwards}
  .hero h1 .line.l1 > span{animation-delay:.10s}
  .hero h1 .line.l2 > span{animation-delay:.30s}
  .hero h1 .line.l3 > span{animation-delay:.50s}
  .hero h1 .line.l4 > span{animation-delay:.70s}
  @keyframes lineUp{to{transform:translateY(0);opacity:1}}
  /* a soft cursor sweeping the last line */
  .hero h1 .line.l4 > span{position:relative}
  .hero h1 .line.l4 > span::after{content:"";position:absolute;right:-.2em;top:8%;bottom:14%;width:.06em;background:var(--green);animation:caret 1.2s steps(2) 1.4s infinite}
  @keyframes caret{50%{opacity:0}}

  @media(max-width:900px){.ill.gear-a,.ill.gear-b,.ill.wave,.ill.tag{display:none}.ill.gauge,.ill.wo,.ill.hexchip{width:38vw;height:auto;aspect-ratio:1}}
  @media (prefers-reduced-motion:reduce){.ill,.ill *,.hero h1 .line > span{animation:none !important;transform:none !important;opacity:1 !important}.hero h1 .line.l4 > span::after{display:none}}

  /* ---------- ANIMATED BG (ai-core + cta) ---------- */
  .anim-bg{position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:0}
  .anim-bg .grid-lines{position:absolute;inset:0;background-image:linear-gradient(to right,rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(to bottom,rgba(255,255,255,.04) 1px,transparent 1px);background-size:80px 80px;animation:gridShift 40s linear infinite;pointer-events:none}
  .cta .anim-bg .grid-lines{background-image:linear-gradient(to right,rgba(10,22,40,.04) 1px,transparent 1px),linear-gradient(to bottom,rgba(10,22,40,.04) 1px,transparent 1px)}
  .ai-core, .cta{position:relative;isolation:isolate;overflow:hidden}
  .ai-core > .wrap, .cta > .wrap{position:relative;z-index:2}

  /* ===== AI-section illustrations ===== */
  .ai-core .ai-ill{position:absolute;color:#FFFFFF;pointer-events:none}
  .ai-core .ai-ill svg{width:100%;height:100%;display:block;overflow:visible}
  .ai-core .ai-ill svg *{vector-effect:non-scaling-stroke}

  /* neural net top-right */
  .ai-core .ai-ill.neural{top:6%;right:4%;width:280px;height:240px;opacity:.18}
  .ai-core .ai-ill.neural .node{fill:var(--green-2);animation:nodePulse 2.6s ease-in-out infinite}
  .ai-core .ai-ill.neural .node:nth-child(2){animation-delay:.2s}
  .ai-core .ai-ill.neural .node:nth-child(3){animation-delay:.4s}
  .ai-core .ai-ill.neural .node:nth-child(4){animation-delay:.6s}
  .ai-core .ai-ill.neural .node:nth-child(5){animation-delay:.8s}
  .ai-core .ai-ill.neural .node:nth-child(6){animation-delay:1.0s}
  .ai-core .ai-ill.neural .node:nth-child(7){animation-delay:1.2s}
  .ai-core .ai-ill.neural .node:nth-child(8){animation-delay:1.4s}
  .ai-core .ai-ill.neural .node:nth-child(9){animation-delay:1.6s}
  .ai-core .ai-ill.neural .link{stroke:#FFFFFF;stroke-width:.8;opacity:.4}
  .ai-core .ai-ill.neural .pulse-line{stroke:var(--green-2);stroke-width:1.4;stroke-dasharray:6 60;animation:dash 4s linear infinite}
  @keyframes nodePulse{0%,100%{opacity:.5;r:3}50%{opacity:1;r:5}}

  /* digital twin (3D wireframe) bottom-left */
  .ai-core .ai-ill.twin{bottom:8%;left:4%;width:340px;height:240px;opacity:.16;animation:twinFloat 12s ease-in-out infinite alternate}
  .ai-core .ai-ill.twin .struct{stroke:#FFFFFF;stroke-width:1.2;fill:none}
  .ai-core .ai-ill.twin .struct-accent{stroke:var(--green-2);stroke-width:1.4;fill:none;stroke-dasharray:4 6;animation:dash 6s linear infinite}
  .ai-core .ai-ill.twin .scan{stroke:var(--green-2);stroke-width:1.5;animation:scanSweep 5s ease-in-out infinite}
  @keyframes twinFloat{from{transform:translateY(0) rotateX(0)}to{transform:translateY(-10px)}}
  @keyframes scanSweep{0%,100%{opacity:0;transform:translateY(0)}50%{opacity:.9;transform:translateY(180px)}}

  /* dashboard panel mid-right */
  .ai-core .ai-ill.dash{top:46%;right:8%;width:260px;height:180px;opacity:.16}
  .ai-core .ai-ill.dash .frame{fill:none;stroke:#FFFFFF;stroke-width:1}
  .ai-core .ai-ill.dash .bar{fill:#FFFFFF;opacity:.55;animation:barGrow 4s ease-in-out infinite alternate;transform-origin:bottom}
  .ai-core .ai-ill.dash .bar:nth-child(odd){animation-delay:.3s}
  .ai-core .ai-ill.dash .bar.accent{fill:var(--green-2);opacity:.9}
  .ai-core .ai-ill.dash .trend{fill:none;stroke:var(--green-2);stroke-width:1.5;stroke-dasharray:4 6;animation:dash 5s linear infinite}
  @keyframes barGrow{from{transform:scaleY(.5)}to{transform:scaleY(1)}}

  /* binary stream behind */
  .ai-core .ai-ill.binary{top:22%;left:8%;width:220px;height:120px;opacity:.10;font-family:'JetBrains Mono',monospace;font-size:11px;color:#fff;letter-spacing:1px;line-height:1.5;overflow:hidden;animation:binFlow 14s linear infinite}
  @keyframes binFlow{from{transform:translateY(0)}to{transform:translateY(-30%)}}

  /* AI orbit center */
  .ai-core .ai-ill.orbit{top:38%;left:38%;width:300px;height:300px;opacity:.12;transform:translate(-50%,-50%);animation:orbitSpin 40s linear infinite}
  .ai-core .ai-ill.orbit .ring{fill:none;stroke:#FFFFFF;stroke-width:.8;stroke-dasharray:2 8}
  .ai-core .ai-ill.orbit .core-c{fill:var(--green-2);animation:nodePulse 3s ease-in-out infinite}
  @keyframes orbitSpin{from{transform:translate(-50%,-50%) rotate(0)}to{transform:translate(-50%,-50%) rotate(360deg)}}

  /* ===== CTA-section: paper plane / floating documents ===== */
  .cta .paper-ill{position:absolute;color:var(--ink);pointer-events:none}
  .cta .paper-ill svg{width:100%;height:100%;display:block;overflow:visible}
  .cta .paper{position:absolute;width:140px;height:180px;animation:paperFly 18s linear infinite}
  .cta .paper svg{width:100%;height:100%}
  .cta .paper .pg{fill:#FFFFFF;stroke:rgba(10,22,40,.35);stroke-width:1}
  .cta .paper .ln{stroke:rgba(10,22,40,.18);stroke-width:1}
  .cta .paper .accent{stroke:var(--green);stroke-width:1.5}
  .cta .paper.p1{top:8%;  left:-12%; animation-duration:22s;animation-delay:0s;  transform:rotate(-12deg)}
  .cta .paper.p2{top:38%; left:-18%; animation-duration:26s;animation-delay:-6s; transform:rotate(8deg);  width:120px;height:154px}
  .cta .paper.p3{top:62%; left:-10%; animation-duration:24s;animation-delay:-14s;transform:rotate(-4deg); width:100px;height:130px;opacity:.7}
  .cta .paper.p4{top:18%; left:-15%; animation-duration:28s;animation-delay:-9s; transform:rotate(15deg); width:130px;height:168px;opacity:.6}
  .cta .paper.p5{top:78%; left:-8%;  animation-duration:30s;animation-delay:-18s;transform:rotate(-18deg);width:90px; height:118px;opacity:.5}
  @keyframes paperFly{
    0%   {transform:translate(0,0) rotate(-12deg);}
    25%  {transform:translate(28vw,-18px) rotate(-4deg);}
    50%  {transform:translate(56vw,12px) rotate(6deg);}
    75%  {transform:translate(84vw,-10px) rotate(-2deg);}
    100% {transform:translate(120vw,0) rotate(8deg);opacity:0;}
  }
  .cta .paper-plane{
    position:absolute;top:30%;left:-10%;width:80px;height:80px;
    color:var(--green);opacity:.6;
    animation:planeFly 16s linear infinite;
  }
  .cta .paper-plane svg{width:100%;height:100%}
  .cta .paper-plane .body{fill:none;stroke:currentColor;stroke-width:1.6;stroke-linejoin:round}
  .cta .paper-plane .trail{stroke:currentColor;stroke-width:1;stroke-dasharray:2 8;opacity:.5;fill:none}
  @keyframes planeFly{
    0%   {transform:translate(0,0) rotate(-8deg);}
    50%  {transform:translate(60vw,-40px) rotate(2deg);}
    100% {transform:translate(120vw,20px) rotate(-4deg);opacity:0;}
  }
  .cta .paper-plane.pl2{top:65%;animation-duration:20s;animation-delay:-8s;width:60px;height:60px;opacity:.4}

  @media(max-width:900px){
    .ai-core .ai-ill.dash,.ai-core .ai-ill.binary,.ai-core .ai-ill.orbit{display:none}
    .ai-core .ai-ill.neural,.ai-core .ai-ill.twin{width:55vw;height:auto;aspect-ratio:1.2/1}
    .cta .paper.p3,.cta .paper.p4,.cta .paper.p5,.cta .paper-plane.pl2{display:none}
  }
  @media (prefers-reduced-motion:reduce){
    .ai-core .ai-ill *,.cta .paper,.cta .paper-plane{animation:none !important;transform:none !important}
  }

  /* ---------- AI AT CORE ---------- */
  .ai-core{
    position:relative;overflow:hidden;
    padding:140px 0 120px;
    background:#0A1628;color:var(--paper);
    border-bottom:1px solid var(--line);
  }
  .ai-core::before{
    content:"";position:absolute;inset:0;
    background:
      radial-gradient(circle at 80% 20%, rgba(31,111,74,.28), transparent 50%),
      radial-gradient(circle at 15% 85%, rgba(44,90,160,.22), transparent 55%);
    pointer-events:none;
  }
  .ai-core .grid-bg{
    position:absolute;inset:0;
    background-image:linear-gradient(to right,rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(to bottom,rgba(255,255,255,.04) 1px,transparent 1px);
    background-size:60px 60px;
    mask-image:radial-gradient(ellipse at center, #000 30%, transparent 80%);
    -webkit-mask-image:radial-gradient(ellipse at center, #000 30%, transparent 80%);
    pointer-events:none;
  }
  .ai-core .wrap{position:relative;z-index:2}
  .ai-eyebrow{
    display:inline-flex;align-items:center;gap:14px;
    padding:8px 16px;border:1px solid rgba(255,255,255,.2);
    border-radius:100px;
    font-family:'JetBrains Mono',monospace;font-size:12px;letter-spacing:.18em;text-transform:uppercase;
    color:#a8b2c4;margin-bottom:32px;
  }
  .ai-eyebrow .pulse{width:8px;height:8px;border-radius:50%;background:var(--green-2);box-shadow:0 0 0 0 rgba(42,142,95,.7);animation:pulse 2.4s ease-out infinite}
  @keyframes pulse{0%{box-shadow:0 0 0 0 rgba(42,142,95,.7)}70%{box-shadow:0 0 0 10px rgba(42,142,95,0)}100%{box-shadow:0 0 0 0 rgba(42,142,95,0)}}
  .ai-core h2{
    font-family:'Space Grotesk',sans-serif;font-weight:600;
    font-size:clamp(36px,5.3vw,80px);line-height:.98;letter-spacing:-0.025em;
    margin:0 0 28px;max-width:1100px;
  }
  .ai-core h2 em{font-style:italic;font-weight:400;color:var(--green-2)}
  .ai-core h2 .stripes{
    background:repeating-linear-gradient(90deg,#fff 0 6px,transparent 6px 12px);
    -webkit-background-clip:text;background-clip:text;color:transparent;
  }
  .ai-core .lead{font-size:21px;line-height:1.5;color:#c8cfdc;max-width:760px;margin:0 0 64px}
  .ai-pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.10)}
  /* If the last row has a lone orphan, span it across all 3 columns so the
     grid still feels intentional rather than left-aligned with empty cells. */
  .ai-pillars .ai-pillar:last-child:nth-child(3n+1){grid-column:1 / -1}
  /* If the last row has 2 orphans (10 → 3+3+3+1 not affected; 11 → 3+3+3+2),
     the second-to-last centers via spanning the 1st two cols and the last
     spans the 3rd. Default grid order handles this fine; no extra rule. */
  @media(max-width:1000px){
    .ai-pillars{grid-template-columns:1fr 1fr}
    .ai-pillars .ai-pillar:last-child:nth-child(3n+1){grid-column:auto}
  }
  @media(max-width:600px){
    .ai-pillars{grid-template-columns:1fr}
    .ai-pillars .ai-pillar:last-child:nth-child(3n+1){grid-column:auto}
  }
  .ai-pillar{
    background:#0A1628;padding:36px 30px 32px;
    display:flex;flex-direction:column;gap:18px;
    transition:background .25s ease;
  }
  .ai-pillar:hover{background:#11203A}
  .ai-pillar .ico{width:44px;height:44px;border:1px solid rgba(255,255,255,.18);display:grid;place-items:center;color:var(--green-2)}
  .ai-pillar .ico svg{width:22px;height:22px}
  .ai-pillar .num{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.16em;color:#7e8aa1;text-transform:uppercase}
  .ai-pillar .name{font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:24px;letter-spacing:-0.01em;line-height:1.15}
  .ai-pillar .desc{font-size:14px;line-height:1.55;color:#a8b2c4}
  .ai-foot{
    display:flex;justify-content:space-between;align-items:flex-end;
    margin-top:64px;padding-top:32px;border-top:1px solid rgba(255,255,255,.10);
    gap:40px;flex-wrap:wrap;
  }
  .ai-foot .stamp{font-family:'JetBrains Mono',monospace;font-size:12px;letter-spacing:.16em;color:#7e8aa1;text-transform:uppercase}
  .ai-foot .stamp b{color:#fff}

  /* ---------- TICKER ---------- */
  .ticker{
    background:var(--ink);color:var(--paper);
    padding:18px 0;overflow:hidden;border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  }
  .ticker-track{display:flex;gap:60px;white-space:nowrap;animation:scroll 40s linear infinite;font-family:'Space Grotesk',sans-serif;font-weight:500;font-size:18px;letter-spacing:.02em}
  .ticker-track span{display:inline-flex;align-items:center;gap:14px}
  .ticker-track i{display:inline-block;width:6px;height:6px;background:var(--green-2);transform:rotate(45deg);font-style:normal}
  html[data-theme="dark"] .ticker{background:#11203A;color:#F1F2F4;border-color:rgba(255,255,255,.10)}
  html[data-theme="dark"] .mobile,
  html[data-theme="dark"] .why,
  html[data-theme="dark"] footer{background:#11203A;color:#F1F2F4}
  html[data-theme="dark"] .mobile .sec-num b,
  html[data-theme="dark"] .mobile .sec-title,
  html[data-theme="dark"] .why .sec-num b,
  html[data-theme="dark"] .why .sec-title{color:#F1F2F4}
  @keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

  /* ---------- SECTION HEADER ---------- */
  .sec{padding:0 0 110px;border-bottom:1px solid var(--line-light);background:#FFFFFF}
  .sec-head{
    display:grid;grid-template-columns:240px 1fr;gap:60px;
    margin:0 calc(50% - 50vw) 64px;
    padding:44px max(32px, calc(50vw - var(--maxw)/2 + 32px));
    background:#EAE6DD;
    border-top:1px solid rgba(10,22,40,.08);
    border-bottom:1px solid rgba(10,22,40,.08);
    align-items:center;
    position:relative;
  }
  .sec-head::before{
    content:"";position:absolute;left:0;top:0;bottom:0;width:6px;background:var(--green);
  }
  /* per-section accent colors */
  .sec[id="about"]    .sec-head{background:#E8EFE9}
  .sec[id="about"]    .sec-head::before{background:#1F6F4A}
  .sec[id="platform"] .sec-head{background:#E6EDF5}
  .sec[id="platform"] .sec-head::before{background:#2C5AA0}
  .sec[id="product"]  .sec-head{background:#2A2D33;color:#FFFFFF}
  .sec[id="product"]  .sec-head .sec-num{color:rgba(255,255,255,.55)}
  .sec[id="product"]  .sec-head .sec-num b{color:#FFFFFF}
  .sec[id="product"]  .sec-head .sec-title{color:#FFFFFF}
  .sec[id="product"]  .sec-head .sec-title em{color:var(--green-2)}
  .sec[id="product"]  .sec-head::before{background:#B07A2A}
  .sec[id="clients"]  .sec-head{background:#EDE8E2}
  .sec[id="clients"]  .sec-head::before{background:#0A1628}
  .mobile{padding-top:0}
  .mobile .sec-head{
    background:#11203A;border-color:rgba(255,255,255,.10);
  }
  .mobile .sec-head::before{background:var(--green-2)}
  @media(max-width:800px){.sec-head{grid-template-columns:1fr;gap:14px;padding:32px 24px}}
  .sec-num{font-family:'JetBrains Mono',monospace;font-size:12px;letter-spacing:.16em;color:var(--muted)}
  .sec-num b{color:var(--ink)}
  .sec-title{font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:clamp(20px,2.1vw,30px);line-height:1.15;letter-spacing:-0.015em;margin:0;max-width:1100px}
  .sec-title em{font-style:italic;font-weight:400;color:var(--green)}

  /* ---------- WHAT IS EAM ---------- */
  .eam-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}
  @media(max-width:900px){.eam-grid{grid-template-columns:1fr;gap:40px}}
  .eam-text p{font-size:18px;line-height:1.55;margin:0 0 18px;color:#1f2a40}
  .eam-text p.lead{font-size:22px;line-height:1.4;color:var(--ink);font-weight:400}
  .eam-list{list-style:none;padding:0;margin:30px 0 0;border-top:1px solid var(--line-light)}
  .eam-list li{display:grid;grid-template-columns:60px 1fr auto;gap:20px;padding:20px 0;border-bottom:1px solid var(--line-light);align-items:center}
  .eam-list .k{font-family:'JetBrains Mono',monospace;font-size:12px;color:var(--muted)}
  .eam-list .t{font-family:'Space Grotesk',sans-serif;font-weight:500;font-size:18px}
  .eam-list .v{font-family:'JetBrains Mono',monospace;font-size:12px;color:var(--green);display:inline-flex;align-items:center;gap:6px}
  .eam-list .v::before{content:"";width:12px;height:12px;background:currentColor;-webkit-mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'><line x1='7' y1='17' x2='17' y2='7'/><polyline points='8 7 17 7 17 16'/></svg>") no-repeat center / contain;mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'><line x1='7' y1='17' x2='17' y2='7'/><polyline points='8 7 17 7 17 16'/></svg>") no-repeat center / contain}
  html[dir="rtl"] .eam-list .v::before{transform:scaleX(-1)}

  /* ---------- MODULES ---------- */
  .modules{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid var(--line-light);border-left:1px solid var(--line-light)}
  @media(max-width:900px){.modules{grid-template-columns:1fr 1fr}}
  @media(max-width:600px){.modules{grid-template-columns:1fr}}
  .mod{
    border-right:1px solid var(--line-light);border-bottom:1px solid var(--line-light);
    padding:36px 32px 40px;min-height:280px;
    display:flex;flex-direction:column;justify-content:space-between;gap:30px;
    position:relative;background:var(--paper);
    transition:background .25s ease, color .25s ease;
  }
  .mod:hover{background:var(--ink);color:var(--paper)}
  .mod:hover .mod-num,.mod:hover .mod-desc{color:#a8b2c4}
  .mod:hover .mod-arrow{color:var(--green-2);transform:translate(4px,-4px)}
  .mod-top{display:flex;justify-content:space-between;align-items:flex-start}
  .mod-num{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.14em;color:var(--muted);transition:color .25s ease}
  .mod-arrow{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;color:currentColor;transition:transform .25s ease, color .25s ease}
  .mod-arrow svg{width:100%;height:100%;display:block}
  .mod-title{font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:26px;letter-spacing:-0.01em;line-height:1.1}
  .mod-desc{font-size:14px;line-height:1.5;color:#3a455c;transition:color .25s ease}
  .mod-icon{width:36px;height:36px;display:flex;align-items:center;justify-content:center}

  /* ---------- MOBILE APP SECTION ---------- */
  .mobile{background:var(--ink);color:var(--paper);padding:120px 0;border-bottom:1px solid var(--line)}
  .mobile .sec-num b{color:var(--paper)}
  .mobile .sec-title{color:var(--paper)}
  .mobile .sec-title em{color:var(--green-2)}
  .phones{display:grid;grid-template-columns:repeat(3,1fr);gap:40px}
  @media(max-width:1000px){.phones{grid-template-columns:1fr;gap:32px;max-width:560px;margin:0 auto}}
  .phone-col{display:flex;flex-direction:column}
  .phone-cap{padding:28px 26px;border:1px solid #1f3055;background:#11203A;display:flex;flex-direction:column;gap:10px;border-radius:6px}
  .app-num{font-family:'JetBrains Mono',monospace;font-size:11px;color:#7e8aa1;letter-spacing:.14em}
  .app-name{font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:26px;letter-spacing:-0.01em}
  .phone-cap p{margin:4px 0 6px;font-size:14px;color:#a8b2c4;line-height:1.55}
  .app-feats{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:6px}
  .app-feats li{font-size:13px;color:#dde3ee;padding-left:18px;position:relative}
  .app-feats li:before{content:"";position:absolute;left:0;top:7px;width:8px;height:8px;background:var(--green-2);transform:rotate(45deg)}
  html[dir="rtl"] .app-feats li{padding-left:0;padding-right:18px}
  html[dir="rtl"] .app-feats li:before{left:auto;right:0}

  .app-stores{margin-top:60px;display:flex;gap:24px;align-items:center;flex-wrap:wrap;padding-top:24px;border-top:1px solid #1f3055}
  .app-stores .store{font-family:'Space Grotesk',sans-serif;font-weight:500;font-size:15px;border:1px solid #1f3055;padding:10px 18px;color:#dde3ee;display:inline-flex;align-items:center;gap:8px}
  .app-stores .store .store-ico{width:18px;height:18px;flex-shrink:0}

  /* ---------- WHY HEXA / STATS ---------- */
  .why{background:var(--ink);color:var(--paper);padding:120px 0;position:relative;overflow:hidden}
  .why .sec-num b{color:var(--paper)}
  .why .sec-title{color:var(--paper)}
  .why .sec-title em{color:var(--green-2)}
  .stats{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-top:1px solid #1f3055}
  @media(max-width:900px){.stats{grid-template-columns:1fr 1fr}}
  .stat{padding:36px 28px;border-right:1px solid #1f3055;border-bottom:1px solid #1f3055}
  .stat:last-child{border-right:none}
  @media(max-width:900px){.stat{border-right:1px solid #1f3055}.stat:nth-child(2n){border-right:none}}
  .stat .num{font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:64px;letter-spacing:-0.03em;line-height:1}
  .stat .num .unit{font-size:28px;color:var(--green-2);margin-left:4px}
  .stat .lbl{margin-top:14px;font-size:13px;color:#a8b2c4;line-height:1.5}
  .why-foot{margin-top:60px;display:grid;grid-template-columns:1.3fr .7fr;gap:60px;align-items:end}
  @media(max-width:900px){.why-foot{grid-template-columns:1fr}}
  .why-foot p{font-family:'Space Grotesk',sans-serif;font-weight:400;font-size:30px;line-height:1.25;letter-spacing:-0.01em;margin:0;color:#dde3ee}
  .why-foot p em{font-style:italic;color:var(--green-2);font-weight:300}

  /* ---------- INDUSTRIES ---------- */
  .industries{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line-light);border:1px solid var(--line-light)}
  @media(max-width:700px){.industries{grid-template-columns:1fr}}
  .ind{background:var(--paper);padding:32px;display:flex;justify-content:space-between;align-items:center;gap:20px;transition:background .2s ease}
  .ind:hover{background:var(--paper-2)}
  .ind .left{display:flex;align-items:baseline;gap:18px}
  .ind .num{font-family:'JetBrains Mono',monospace;font-size:12px;color:var(--muted)}
  .ind .name{font-family:'Space Grotesk',sans-serif;font-weight:500;font-size:24px;letter-spacing:-0.01em}
  .ind .tag{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.1em}

  /* ---------- HOW IT WORKS ---------- */
  .steps{display:grid;grid-template-columns:repeat(3,1fr);gap:40px;position:relative}
  @media(max-width:900px){.steps{grid-template-columns:1fr}}
  .step{padding-top:30px;border-top:2px solid var(--ink);position:relative}
  .step .n{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:80px;line-height:.85;letter-spacing:-0.04em}
  .step .n span{color:var(--green)}
  .step .t{font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:24px;margin:24px 0 12px;letter-spacing:-0.01em}
  .step .d{font-size:15px;color:#3a455c;line-height:1.55}

  /* ---------- TRUSTED ---------- */
  .trusted{display:grid;grid-template-columns:repeat(6,1fr);gap:0;border-top:1px solid var(--line-light);border-left:1px solid var(--line-light)}
  @media(max-width:1000px){.trusted{grid-template-columns:repeat(3,1fr)}}
  @media(max-width:600px){.trusted{grid-template-columns:repeat(2,1fr)}}
  .logo-cell{
    border-right:1px solid var(--line-light);border-bottom:1px solid var(--line-light);
    aspect-ratio:1.6/1;display:flex;align-items:center;justify-content:center;
    font-family:'Space Grotesk',sans-serif;font-weight:600;color:var(--muted);
    letter-spacing:-0.01em;font-size:18px;
    transition:color .2s ease, background .2s ease;
  }
  .logo-cell:hover{color:var(--ink);background:var(--paper-2)}
  .logo-cell.placeholder{
    background:repeating-linear-gradient(45deg,#f4f2ed 0 12px,#eae6dd 12px 24px);
    color:#9aa3b3;font-size:13px;letter-spacing:.18em;
  }
  .logo-cell.placeholder:hover{color:#9aa3b3;background:repeating-linear-gradient(45deg,#f4f2ed 0 12px,#eae6dd 12px 24px)}

  /* Coming-soon: blur the placeholder grid + center a notice on top */
  .trusted-wrap{position:relative}
  .trusted-wrap .trusted{filter:blur(6px);pointer-events:none;user-select:none}
  .trusted-overlay{
    position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
    pointer-events:none;
  }
  .trusted-overlay span{
    font-family:'Space Grotesk',sans-serif;font-weight:600;
    font-size:18px;letter-spacing:.08em;text-transform:uppercase;
    color:var(--ink);
    background:rgba(241,242,244,.85);
    border:1px solid var(--line-light);
    padding:14px 28px;border-radius:999px;
    backdrop-filter:blur(4px);
    -webkit-backdrop-filter:blur(4px);
  }

  /* ---------- CTA ---------- */
  .cta{
    background:var(--paper-2);
    padding:120px 0;border-bottom:1px solid var(--line-light);
    position:relative;overflow:hidden;
  }
  .cta-inner{display:grid;grid-template-columns:1.4fr .6fr;gap:60px;align-items:end}
  @media(max-width:900px){.cta-inner{grid-template-columns:1fr;gap:40px}}
  .cta h2{
    font-family:'Space Grotesk',sans-serif;font-weight:600;
    font-size:clamp(36px,5.7vw,80px);letter-spacing:-0.03em;line-height:.98;margin:0;
  }
  .cta h2 em{font-style:italic;font-weight:400;color:var(--blue)}
  .cta-form{display:flex;flex-direction:column;gap:14px;background:var(--paper);padding:28px;border:1px solid var(--line-light)}
  .cta-form label{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.14em;color:var(--muted);text-transform:uppercase}
  .cta-form input{
    border:none;border-bottom:1px solid var(--ink);background:transparent;padding:10px 0;
    font-family:'Inter',sans-serif;font-size:16px;color:var(--ink);outline:none;
  }
  .cta-form input:focus{border-color:var(--green)}
  .cta-form button{margin-top:14px;cursor:pointer}
  .cta-form .hp-field{position:absolute;left:-9999px;top:-9999px;width:1px;height:1px;opacity:0}
  /* Captcha row • operands + operator on the left, narrow answer input on the right */
  .cta-captcha{display:flex;flex-direction:column;gap:6px}
  .cta-captcha-row{display:flex;align-items:flex-end;gap:18px}
  .cta-captcha-prompt{
    font-family:'JetBrains Mono',monospace;
    font-size:22px;color:var(--ink);
    display:inline-flex;align-items:center;gap:10px;
    padding:8px 14px;border:1px solid var(--line-light);background:var(--paper-2);
    user-select:none;-webkit-user-select:none;
  }
  .cta-captcha-prompt b{font-weight:600}
  .cta-captcha-prompt span{color:var(--muted)}
  .cta-captcha #cf-captcha{flex:1;max-width:120px;font-family:'JetBrains Mono',monospace;font-size:18px;text-align:center}
  html[data-theme="dark"] .cta-captcha-prompt{background:var(--surface);color:var(--text);border-color:var(--border)}
  html[data-theme="dark"] .cta-captcha-prompt span{color:var(--text-muted)}
  .cta-form-status{font-family:'JetBrains Mono',monospace;font-size:12px;letter-spacing:.06em;min-height:18px;margin-top:6px}
  .cta-form-status.ok{color:var(--green)}
  .cta-form-status.err{color:#c24545}
  .cta-form.is-sent input,.cta-form.is-sent button{pointer-events:none;opacity:.55}

  /* ---------- FOOTER ---------- */
  footer{background:var(--ink);color:var(--paper);padding:80px 0 30px}
  .foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px}
  @media(max-width:900px){.foot-grid{grid-template-columns:1fr 1fr}}
  @media(max-width:500px){.foot-grid{grid-template-columns:1fr}}
  .foot h4{font-family:'Space Grotesk',sans-serif;font-size:16px;letter-spacing:.02em;color:#fff;text-transform:none;margin:0 0 18px;font-weight:600}
  .foot a{display:block;padding:6px 0;font-size:14px;color:#dde3ee}
  .foot a:hover{color:var(--green-2)}
  /* Icon-only social links — inline-flex so the SVG sits on its own line
     in the stack but doesn't stretch to full width like a text link. */
  .foot a.foot-social{display:inline-flex;align-items:center;color:#dde3ee;transition:color .15s ease}
  .foot a.foot-social:hover{color:var(--green-2)}
  .foot a.foot-social svg{display:block}
  .foot-brand p{font-size:14px;color:#a8b2c4;max-width:340px;line-height:1.55;margin:18px 0 0}
  .foot-brand img,.foot-brand svg{height:125px;width:auto;opacity:.98;direction:ltr}
  .foot-brand svg text{direction:ltr;unicode-bidi:bidi-override}
  .foot-bottom{margin-top:60px;padding-top:24px;border-top:1px solid #1f3055;display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;font-family:'JetBrains Mono',monospace;font-size:12px;color:#7e8aa1}
  .foot-copy{display:inline-flex;align-items:center;gap:14px;flex-wrap:wrap}
  .ksa-mark{display:inline-flex;align-items:center;gap:8px;padding:4px 10px;border:1px solid #1f3055;border-radius:100px;background:rgba(255,255,255,.02)}
  .ksa-flag{width:22px;height:14px;display:block;border-radius:2px}
  .ksa-text{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.14em;color:#a8b2c4}
  .legal-link{background:transparent;border:none;padding:0;color:inherit;font:inherit;cursor:pointer;text-decoration:underline;text-underline-offset:3px;text-decoration-color:rgba(126,138,161,.4)}
  .legal-link:hover{color:var(--green-2);text-decoration-color:var(--green-2)}
  .foot-addr{display:block;padding:6px 0;font-size:14px;color:#a8b2c4}
  .foot-legal{color:#7e8aa1}
  .foot-legal:hover{color:var(--green-2)}

  /* tiny inline icons */
  .ic{width:22px;height:22px;display:inline-block;vertical-align:middle}

  /* ---------- SCROLL TO TOP ---------- */
  .to-top{position:fixed;right:24px;bottom:24px;z-index:60;width:48px;height:48px;border-radius:50%;border:2px solid var(--paper);background:var(--green);color:#FFFFFF;display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:0;transform:translateY(8px);transition:opacity .25s ease, transform .25s ease, background .2s ease, border-color .2s ease, box-shadow .2s ease;box-shadow:0 6px 18px rgba(0,0,0,.35), 0 0 0 1px rgba(255,255,255,.15);padding:0}
  .to-top.show{opacity:1;transform:translateY(0)}
  .to-top:hover{background:var(--ink);border-color:#FFFFFF;box-shadow:0 8px 22px rgba(0,0,0,.45), 0 0 0 1px rgba(255,255,255,.25)}
  .to-top svg{width:20px;height:20px}
  html[dir="rtl"] .to-top{right:auto;left:24px}
  @media (prefers-reduced-motion:reduce){.to-top{transition:opacity .15s linear}}

  /* ---------- MOBILE POLISH (≤640px) ---------- */
  @media(max-width:640px){
    :root{--nav-h:67px}
    .wrap{padding:0 18px}
    .nav-inner{padding:14px 18px}
    .brand img,.brand svg{height:38px}
    /* Tighten the nav controls • hide the Book-a-demo on phones, keep theme + lang reachable */
    .nav-cta{gap:10px}
    .nav-cta .btn.ghost{display:none}
    .lang{font-size:11px;padding:5px 8px}
    .theme-toggle{width:32px;height:32px}

    /* Hero */
    .hero{padding:54px 0 50px}
    .hero h1{font-size:clamp(32px,9vw,48px)}
    .hero-sub{font-size:16px;margin-bottom:24px}
    .hero-actions{gap:10px}
    .hero-actions .btn{padding:12px 18px;font-size:13px}
    .hero-meta{grid-template-columns:1fr 1fr;gap:18px 16px}
    .meta-item .num{font-size:32px}
    .meta-item .lbl{font-size:12px;max-width:none}
    .hero-card{padding:18px}
    .hero-side{padding-top:24px;margin-top:6px}

    /* Section headers */
    .sec{padding:0 0 70px}
    .sec-head{padding:24px 18px;margin-bottom:36px;gap:10px}
    .sec-num{font-size:11px}
    .sec-title{font-size:clamp(20px,5.4vw,26px) !important}

    /* AI core */
    .ai-core{padding:80px 0 70px}
    .ai-core h2{font-size:clamp(34px,8.5vw,44px)}
    .ai-core .lead{font-size:16px;margin-bottom:40px}
    .ai-pillar{padding:28px 22px 26px}
    .ai-pillar .name{font-size:20px}
    .ai-foot{flex-direction:column;align-items:flex-start;gap:12px;margin-top:40px}

    /* Modules / platform tiles */
    .mod{padding:26px 22px 28px;min-height:auto;gap:18px}
    .mod-title{font-size:22px}

    /* About / EAM */
    .eam-text p{font-size:16px}
    .eam-text p.lead{font-size:18px}
    .eam-list li{grid-template-columns:50px 1fr;gap:8px 14px;padding:14px 0}
    .eam-list .v{grid-column:1 / -1;justify-self:end;font-size:11px;margin-top:-4px}

    /* Mobile section */
    .mobile{padding:80px 0}
    .phone-cap p{font-size:13px}
    .app-stores{margin-top:36px;gap:14px}
    .app-stores .store{font-size:13px;padding:8px 14px}

    /* Why / stats */
    .why{padding:80px 0}
    .stat{padding:24px 18px}
    .stat .num{font-size:44px}
    .stat .num .unit{font-size:20px}
    .why-foot p{font-size:22px}

    /* Trusted / placeholders */
    .logo-cell{font-size:14px}
    .logo-cell.placeholder{font-size:11px;letter-spacing:.14em}

    /* CTA / contact */
    .cta{padding:80px 0}
    .cta h2{font-size:clamp(34px,8.5vw,44px)}
    .cta-form{padding:20px}
    .cta-form input{font-size:15px}
    .cta-inner > div > p{font-size:16px !important}

    /* Footer */
    footer{padding:60px 0 24px}
    .foot-grid{gap:32px}
    .foot-brand img,.foot-brand svg{height:90px}
    .foot-brand p{font-size:13px}
    .foot-bottom{margin-top:36px;font-size:11px;flex-direction:column;align-items:flex-start;gap:8px}

    /* Scroll-to-top • lift higher so it doesn't sit on top of footer/buttons */
    .to-top{right:14px;bottom:14px;width:42px;height:42px}
    html[dir="rtl"] .to-top{left:14px}

    /* Hero illustrations • more aggressive hide on phones */
    .ill.gauge,.ill.wo,.ill.hexchip{opacity:.07}
    .ill.pipe{display:none}

    /* Animated background paper-planes / papers • keep but lower opacity */
    .cta .paper-plane,.cta .paper{opacity:.45}
  }

  /* ---------- LEGAL MODAL ---------- */
  .modal{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;padding:24px;animation:modalFade .2s ease-out}
  .modal[hidden]{display:none !important}
  @keyframes modalFade{from{opacity:0}to{opacity:1}}
  .modal-backdrop{position:absolute;inset:0;background:rgba(10,22,40,.65);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}
  .modal-panel{
    position:relative;z-index:1;
    background:var(--paper-2);
    width:100%;max-width:720px;max-height:88vh;
    display:flex;flex-direction:column;
    border:1px solid var(--line-light);
    box-shadow:0 30px 80px -20px rgba(0,0,0,.45), 0 0 0 1px rgba(255,255,255,.04);
    animation:modalRise .25s cubic-bezier(.2,.7,.2,1) both;
  }
  @keyframes modalRise{from{opacity:0;transform:translateY(20px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}
  .modal-close{
    position:absolute;top:14px;right:14px;z-index:2;
    width:36px;height:36px;border:1px solid var(--line-light);border-radius:50%;
    background:var(--paper-2);color:var(--ink);font-size:22px;line-height:1;
    cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;
    transition:background .2s, color .2s, border-color .2s;
  }
  .modal-close:hover{background:var(--ink);color:var(--paper);border-color:var(--ink)}
  html[dir="rtl"] .modal-close{right:auto;left:14px}
  .modal-content{padding:48px 56px 48px;overflow-y:auto;color:var(--ink)}
  .modal-eyebrow{margin:0 0 12px}
  .modal-content h2{font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:34px;letter-spacing:-0.02em;line-height:1.1;margin:0 0 8px}
  .modal-meta{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.12em;color:var(--muted);margin:0 0 32px;text-transform:uppercase}
  .modal-content h3{font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:18px;letter-spacing:-0.01em;margin:28px 0 10px;color:var(--ink)}
  .modal-content p{font-size:15px;line-height:1.65;color:#1f2a40;margin:0 0 14px}
  .modal-content ul{margin:0 0 14px;padding-left:22px}
  html[dir="rtl"] .modal-content ul{padding-left:0;padding-right:22px}
  .modal-content li{font-size:15px;line-height:1.65;color:#1f2a40;margin-bottom:6px}
  .modal-content a{color:var(--green);text-decoration:underline;text-underline-offset:3px}
  .modal-content a:hover{color:var(--green-2)}
  body.modal-open{overflow:hidden}

  html[data-theme="dark"] .modal-panel{background:var(--surface-2);border-color:var(--border)}
  html[data-theme="dark"] .modal-close{background:var(--surface-2);color:var(--text);border-color:var(--border)}
  html[data-theme="dark"] .modal-close:hover{background:var(--text);color:var(--surface);border-color:var(--text)}
  html[data-theme="dark"] .modal-content,
  html[data-theme="dark"] .modal-content h2,
  html[data-theme="dark"] .modal-content h3{color:var(--text)}
  html[data-theme="dark"] .modal-content p,
  html[data-theme="dark"] .modal-content li{color:var(--text-soft)}
  html[data-theme="dark"] .modal-content a{color:var(--green-2)}

  @media(max-width:640px){
    .modal{padding:0;align-items:flex-end}
    .modal-panel{max-height:92vh;border:none}
    .modal-content{padding:40px 22px 32px}
    .modal-content h2{font-size:26px}
    .modal-close{top:10px;right:10px;width:32px;height:32px;font-size:20px}
    html[dir="rtl"] .modal-close{right:auto;left:10px}
    .foot-copy{flex-direction:column;align-items:flex-start;gap:8px}
  }

  /* ---------- VERY NARROW (≤380px) ---------- */
  @media(max-width:380px){
    .hero-meta{grid-template-columns:1fr}
    .meta-item{padding-bottom:14px;border-bottom:1px solid var(--line-light)}
    .meta-item:last-child{border-bottom:none}
    .ticker-track{font-size:14px;gap:32px}
    .nav-cta .lang{display:none}
    .ai-eyebrow{font-size:10px;padding:6px 12px}
  }

