/* =========================================================
   HAMIDUN · NomadNet — landing system  v2
   CREAM premium base. Navy used only as dark "islands"
   (hero · §02 Подход · final CTA). Blue = primary accent,
   terracotta (#CC785C) = warm secondary accent.
   ========================================================= */
:root{
  /* ---- light base (default) ---- */
  --bg:#F6F4EF;          /* warm cream base */
  --surface:#FFFFFF;     /* white cards */
  --surface-2:#FBFAF6;   /* cream elevated */
  --surface-3:#ECEAE3;   /* deeper cream (footer / bands) */
  --navy:#010334;        /* dark island bg */
  --ink:#0A0A12;         /* working canvas (WebGL clears) */

  --text:#14151C;        /* near-black on cream */
  --muted:rgba(20,21,28,.60);
  --faint:rgba(20,21,28,.40);

  --line:rgba(20,21,28,.10);
  --line-strong:rgba(20,21,28,.18);

  /* ---- brand ---- */
  --brand:#CC7357;       /* coral — primary CTA, rationed */
  --brand-600:#B5613F;
  --indigo:#1779C9;      /* accent cyan (eyebrows/links, AA on cream) */
  --accent:#1779C9;      /* token: section accent (cyan on light) */
  --terra:#CC785C;       /* warm secondary accent */
  --terra-ink:#B5613F;   /* terracotta text on cream (AA) */
  --cyan:#29A9FF;        /* glow/metrics — used on dark islands */
  --cyan-2:#5CB3FF;

  /* ---- type ---- */
  /* Swap to licensed face later: add @font-face for "Suisse Intl Condensed"
     then set --font-display-cond:'Suisse Intl Condensed',... — nothing else changes. */
  --font-display-cond:'Oswald','Inter Tight',-apple-system,sans-serif;
  --f-display:'Inter Tight',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --f-ui:'Onest',-apple-system,BlinkMacSystemFont,sans-serif;
  --f-body:'Manrope',-apple-system,BlinkMacSystemFont,sans-serif;
  --f-mono:'JetBrains Mono',ui-monospace,'SF Mono',Menlo,monospace;

  /* fluid scale */
  --fs-display:clamp(42px,7.8vw,112px);
  --fs-h2:clamp(34px,5.4vw,82px);
  --fs-h3:clamp(20px,2.4vw,28px);
  --fs-lead:clamp(17px,1.8vw,22px);
  --fs-body:clamp(15px,1.2vw,17px);
  --fs-eyebrow:clamp(11px,1vw,12.5px);
  --fs-meta:clamp(11px,1vw,13px);

  /* layout */
  --container:1320px;
  --gutter:clamp(20px,4vw,56px);
  --section-y:clamp(64px,9vw,140px);
  --radius:18px;
  --radius-lg:26px;
  --pill:999px;
  --ease:cubic-bezier(.22,.61,.36,1);
  --ease-out:cubic-bezier(.19,1,.22,1);   /* dayos reveal */
}

/* ---- dark island scope ---- */
.tone-dark{
  --bg:var(--navy);
  --surface:rgba(255,255,255,.045);
  --surface-2:#0F1124;
  --surface-3:#0F1124;
  --text:#EEF1FB;
  --muted:#A6AAC6;
  --faint:rgba(238,241,251,.42);
  --line:rgba(255,255,255,.08);
  --line-strong:rgba(255,255,255,.14);
  --accent:#29A9FF;      /* cyan accent on dark */
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  font-family:var(--f-body);
  background:var(--bg);
  color:var(--text);
  font-size:var(--fs-body);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}
ul{list-style:none}
::selection{background:var(--brand);color:#fff}
:focus-visible{outline:2px solid var(--brand);outline-offset:3px;border-radius:4px}
.tone-dark :focus-visible{outline-color:var(--cyan)}

/* ---------- primitives ---------- */
.container{width:100%;max-width:var(--container);margin-inline:auto;padding-inline:var(--gutter)}
.section{padding-block:var(--section-y)}
.section--base{background:var(--bg)}
.section--surface{background:var(--surface)}
.section--cream2{background:var(--surface-2)}

.eyebrow{
  font-family:var(--f-mono);
  font-size:var(--fs-eyebrow);
  font-weight:500;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--accent);
  display:inline-flex;align-items:center;gap:.7em;
}
.eyebrow::before{
  content:"";width:22px;height:2px;background:var(--terra);border-radius:2px;
}
.tone-dark .eyebrow::before{background:var(--cyan);opacity:.85}

/* big dayos-style condensed display heading */
.h2{
  font-family:var(--font-display-cond);
  font-size:var(--fs-h2);
  font-weight:700;
  line-height:1.04;
  letter-spacing:.005em;
  text-transform:uppercase;
}
.h3{
  font-family:var(--f-display);
  font-size:var(--fs-h3);
  font-weight:640;
  line-height:1.12;
  letter-spacing:-.015em;
}
.lead{
  font-size:var(--fs-lead);
  line-height:1.5;
  color:var(--muted);
  max-width:60ch;
  font-weight:450;
}
.section-head{
  display:flex;flex-direction:column;gap:clamp(20px,2.4vw,32px);
  margin-bottom:clamp(36px,5vw,72px);
  max-width:980px;
}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.6em;
  font-family:var(--f-ui);font-weight:600;
  font-size:clamp(14px,1.1vw,16px);line-height:1;
  padding:clamp(14px,1.4vw,17px) clamp(22px,2.2vw,30px);
  border-radius:var(--pill);white-space:nowrap;
  transition:background .25s var(--ease),color .25s var(--ease),
             border-color .25s var(--ease),transform .2s var(--ease),
             box-shadow .25s var(--ease);
}
.btn:active{transform:translateY(1px) scale(.99)}
.btn__arrow{display:inline-block;transition:transform .3s var(--ease)}
.btn:hover .btn__arrow{transform:translateX(5px)}
.btn--primary{
  background:var(--brand);color:#fff;
  box-shadow:0 10px 30px -12px rgba(0,40,245,.7),inset 0 0 0 1px rgba(255,255,255,.12);
}
.btn--primary:hover{background:var(--brand-600);box-shadow:0 14px 40px -12px rgba(0,40,245,.85),inset 0 0 0 1px rgba(255,255,255,.2)}
.btn--ghost{background:transparent;color:inherit;box-shadow:inset 0 0 0 1.5px var(--line-strong)}
.btn--ghost:hover{box-shadow:inset 0 0 0 1.5px var(--brand);color:var(--brand)}
.tone-dark .btn--ghost:hover{box-shadow:inset 0 0 0 1.5px var(--cyan);color:var(--cyan)}

/* =========================================================
   HEADER
   ========================================================= */
.header{
  position:fixed;inset:0 0 auto 0;z-index:100;
  border-bottom:1px solid transparent;
  transition:background .4s var(--ease),box-shadow .4s var(--ease),border-color .4s var(--ease);
}
.header__inner{display:flex;align-items:center;gap:clamp(14px,1.8vw,28px);height:clamp(62px,7vw,82px)}
.brand{display:flex;align-items:center;gap:8px;flex-shrink:0}
.brand__word{font-family:'Inter Tight',sans-serif;font-weight:700;font-size:clamp(19px,1.9vw,23px);letter-spacing:-.025em;color:currentColor;line-height:1.2}
.brand__tag{font-family:var(--f-mono);font-size:11px;letter-spacing:.05em;color:var(--muted);white-space:nowrap}
.brand__mark{
  width:34px;height:34px;border-radius:10px;flex-shrink:0;
  background:linear-gradient(145deg,#3B6BFF 0%,#1B3AE0 48%,#0A0E5C 100%);
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 6px 20px -6px rgba(0,40,245,.6),inset 0 0 0 1px rgba(255,255,255,.18);
}
.brand__mark svg{display:block}
.brand__name{font-size:clamp(15px,1.4vw,17px);white-space:nowrap}
.brand__name .sep{color:var(--terra);margin-inline:.18em;font-weight:600}
.brand__name .nn{color:var(--muted);font-weight:500}

.nav{display:none;align-items:center;gap:clamp(12px,1.4vw,24px);margin-left:auto}
.nav a{font-family:var(--f-ui);font-size:14px;font-weight:500;color:inherit;opacity:.74;transition:opacity .2s;white-space:nowrap}
.nav a:hover{opacity:1}

.header__tools{margin-left:auto;display:flex;align-items:center;gap:12px}
@media(min-width:1025px){.header__tools{margin-left:0}.nav{display:flex}}

/* language switcher */
.lang{display:none;align-items:center;gap:2px;padding:3px;border-radius:var(--pill);border:1px solid var(--line);}
.lang button{
  font-family:var(--f-mono);font-size:11px;font-weight:500;letter-spacing:.05em;
  padding:5px 8px;border-radius:var(--pill);color:var(--muted);transition:color .2s,background .2s;
}
.lang button:hover{color:var(--text)}
.lang button[aria-pressed="true"]{background:var(--brand);color:#fff}
@media(min-width:1024px){.lang{display:inline-flex}}

.burger{display:flex;flex-direction:column;gap:5px;width:42px;height:42px;align-items:center;justify-content:center;border-radius:10px;border:1px solid var(--line)}
.burger span{display:block;width:18px;height:1.5px;background:currentColor;transition:.3s}
@media(min-width:1025px){.burger{display:none}}
@media(max-width:1024px){.header__tools .btn--primary{display:none}}

.header .btn--primary{padding:clamp(10px,1vw,13px) clamp(16px,1.6vw,22px)}
/* tone: over dark sections (hero/atoms/final) */
.header[data-tone="dark"]{color:#EEF1FB}
.header[data-tone="dark"] .lang{border-color:rgba(255,255,255,.14)}
.header[data-tone="dark"] .lang button{color:#A6AAC6}
.header[data-tone="dark"] .lang button:hover{color:#fff}
.header[data-tone="dark"] .burger{border-color:rgba(255,255,255,.18)}
.header[data-tone="dark"] .brand__name .nn{color:#A6AAC6}
.header[data-tone="dark"].is-scrolled{
  background:rgba(5,6,26,.72);
  backdrop-filter:blur(18px) saturate(140%);-webkit-backdrop-filter:blur(18px) saturate(140%);
  border-bottom-color:rgba(255,255,255,.1);
}
/* tone: over light sections */
.header[data-tone="light"]{color:var(--text)}
.header[data-tone="dark"] .brand__tag{color:#A6AAC6}
.header[data-tone="light"].is-scrolled{
  background:rgba(246,244,239,.85);
  backdrop-filter:blur(18px) saturate(140%);-webkit-backdrop-filter:blur(18px) saturate(140%);
  border-bottom-color:var(--line);
}

/* drawer (tablet/mobile) */
.drawer{
  position:fixed;inset:0;z-index:99;
  background:rgba(5,6,26,.97);backdrop-filter:blur(22px);color:#EEF1FB;
  display:flex;flex-direction:column;
  padding:calc(clamp(62px,7vw,82px) + 28px) var(--gutter) 36px;gap:4px;
  transform:translateY(-100%);opacity:0;visibility:hidden;
  transition:transform .45s var(--ease),opacity .35s,visibility .35s;
}
.drawer.is-open{transform:translateY(0);opacity:1;visibility:visible}
.drawer a{
  font-family:var(--font-display-cond);text-transform:uppercase;
  font-size:clamp(28px,8vw,42px);font-weight:700;letter-spacing:.01em;
  padding-block:11px;border-bottom:1px solid rgba(255,255,255,.1);
  display:flex;justify-content:space-between;align-items:center;
}
.drawer__lang{display:flex;gap:6px;flex-wrap:wrap;margin-top:22px}
.drawer__lang button{font-family:var(--f-mono);font-size:13px;padding:8px 13px;border-radius:var(--pill);border:1px solid rgba(255,255,255,.14);color:#A6AAC6}
.drawer__lang button[aria-pressed="true"]{background:var(--brand);color:#fff;border-color:var(--brand)}
.drawer .drawer__cta{margin-top:auto;padding-top:22px;border:none}

/* =========================================================
   HERO  (dark island)
   ========================================================= */
.hero{
  position:relative;background:var(--navy);color:#EEF1FB;
  min-height:100svh;display:flex;align-items:center;overflow:hidden;
  padding-top:clamp(110px,15vh,170px);padding-bottom:clamp(48px,7vh,84px);
}
.hero__canvas{position:absolute;inset:0;width:100%;height:100%;z-index:0;display:block}
.hero__brain{
  position:absolute;top:0;right:0;height:100%;width:100%;z-index:2;pointer-events:none;display:none;
  background:radial-gradient(46% 50% at 74% 46%,rgba(1,2,30,.5) 0%,rgba(1,2,30,.26) 42%,transparent 72%);
  -webkit-mask-image:linear-gradient(90deg,transparent 0%,#000 40%,#000 100%);
          mask-image:linear-gradient(90deg,transparent 0%,#000 40%,#000 100%);
}
@media(min-width:880px){.hero__brain{display:block}}
.hero__inner{position:relative;z-index:3;width:100%}
.hero__veil{
  position:absolute;inset:0;z-index:1;pointer-events:none;
  background:
    radial-gradient(120% 85% at 78% 32%,transparent 0%,rgba(1,3,52,.4) 66%,rgba(1,3,52,.9) 100%),
    linear-gradient(180deg,rgba(1,3,52,.55) 0%,transparent 24%,transparent 58%,rgba(1,3,52,.7) 100%);
}
.hero__inner{position:relative;z-index:2;width:100%}
.hero__copy{max-width:none}
.hero__wm{
  position:absolute;z-index:1;top:auto;bottom:clamp(10px,5vh,56px);right:clamp(70px,13vw,210px);transform:none;
  display:none;flex-direction:column;align-items:flex-end;text-align:right;gap:14px;pointer-events:none;
  max-width:42vw;
}
.hero__wm b{
  font-family:var(--font-display-cond);font-weight:700;line-height:.82;letter-spacing:.01em;
  font-size:clamp(120px,13vw,200px);white-space:nowrap;
  color:transparent;-webkit-text-stroke:1.4px rgba(92,179,255,.42);
}
.hero__wm b em{font-style:normal;-webkit-text-stroke:0;color:rgba(92,179,255,.85)}
.hero__wm span{
  font-family:var(--f-mono);font-size:var(--fs-meta);letter-spacing:.08em;
  color:#A6AAC6;max-width:14ch;text-align:right;
}
@media(min-width:880px){.hero__wm{display:flex}.hero__copy{max-width:74%}}
@media(min-width:1100px){.hero__copy{max-width:66%}}

.hero__eyebrow{margin-bottom:clamp(20px,2.6vw,30px)}
.hero h1{
  font-family:var(--font-display-cond);font-size:var(--fs-display);font-weight:700;
  line-height:1.0;letter-spacing:.005em;text-transform:uppercase;text-wrap:balance;margin-bottom:clamp(22px,2.6vw,30px);
  overflow-wrap:normal;word-break:keep-all;hyphens:none;
}
.hero h1 .grad{
  background:linear-gradient(100deg,var(--cyan-2),var(--cyan) 55%,var(--indigo));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.hero__sub{font-size:var(--fs-lead);font-weight:500;line-height:1.42;max-width:46ch;margin-bottom:clamp(20px,2.4vw,28px);color:#EEF1FB}
.hero__sub b{color:var(--cyan-2);font-weight:600}
.metricpill{
  display:inline-flex;align-items:center;gap:clamp(10px,1.4vw,18px);flex-wrap:wrap;
  font-family:var(--f-mono);font-size:var(--fs-meta);letter-spacing:.02em;color:#A6AAC6;
  padding:11px 18px;border:1px solid rgba(255,255,255,.14);border-radius:var(--pill);
  margin-bottom:clamp(24px,2.8vw,34px);
  background:rgba(10,12,40,.4);backdrop-filter:blur(6px);
}
.metricpill b{color:#EEF1FB;font-weight:600}
.metricpill .x{color:var(--cyan);font-weight:600}
.metricpill .dot{width:5px;height:5px;border-radius:50%;background:rgba(255,255,255,.14)}
.hero__actions{display:flex;flex-wrap:wrap;gap:12px;align-items:center}

/* =========================================================
   PROOF — logo wall (light)
   ========================================================= */
.proof{background:var(--surface);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.proof__label{
  font-family:var(--f-mono);font-size:var(--fs-meta);letter-spacing:.14em;text-transform:uppercase;
  color:var(--faint);text-align:center;margin-bottom:clamp(26px,3vw,40px);
}
.logowall{
  display:grid;grid-template-columns:repeat(2,1fr);
  border-top:1px solid var(--line);border-left:1px solid var(--line);
}
@media(min-width:560px){.logowall{grid-template-columns:repeat(4,1fr)}}
@media(min-width:960px){.logowall{grid-template-columns:repeat(8,1fr)}}
.logoplate{
  display:flex;align-items:center;justify-content:center;
  min-height:clamp(74px,8vw,104px);padding:18px 12px;
  border-right:1px solid var(--line);border-bottom:1px solid var(--line);
  font-family:var(--f-display);font-weight:640;letter-spacing:-.01em;
  font-size:clamp(13px,1.3vw,16px);color:var(--muted);text-align:center;
  transition:color .25s var(--ease),background .25s var(--ease);
  position:relative;
}
.logoplate:hover{color:var(--text);background:var(--surface-2)}
.logoplate[data-case]::after{
  content:"кейс ↗";position:absolute;bottom:9px;left:50%;transform:translateX(-50%);
  font-family:var(--f-mono);font-size:9.5px;letter-spacing:.08em;color:var(--terra-ink);
  opacity:0;transition:opacity .25s;white-space:nowrap;
}
.logoplate[data-case]:hover::after{opacity:1}
.logoplate[data-case]{cursor:pointer}

/* =========================================================
   SERVICES (light) — 3D stage + expandable cards
   ========================================================= */
.stage3d{
  position:relative;border-radius:var(--radius-lg);overflow:hidden;
  height:clamp(360px,42vw,520px);margin-bottom:clamp(36px,5vw,64px);
  background:
    radial-gradient(120% 120% at 70% 10%, #FFFFFF 0%, var(--surface-2) 46%, var(--surface-3) 100%);
  border:1px solid var(--line);
  box-shadow:0 30px 70px -46px rgba(20,21,28,.4);
}
.stage3d__canvas{position:absolute;inset:0;width:100%;height:100%;display:block;z-index:1}
.stage3d__cap{
  position:absolute;left:clamp(18px,2vw,28px);bottom:clamp(16px,2vw,24px);z-index:2;
  font-family:var(--f-mono);font-size:var(--fs-meta);letter-spacing:.04em;color:var(--muted);
  max-width:30ch;line-height:1.5;text-wrap:pretty;pointer-events:none;
}
.stage3d__cap b{color:var(--text);font-weight:600}
.stage3d__models{
  position:absolute;right:clamp(18px,2vw,28px);top:clamp(16px,2vw,24px);z-index:2;
  display:flex;flex-wrap:wrap;gap:7px;justify-content:flex-end;max-width:46%;pointer-events:none;
}
.stage3d__models span{
  font-family:var(--f-mono);font-size:11px;letter-spacing:.03em;color:var(--muted);
  padding:5px 10px;border:1px solid var(--line);border-radius:7px;background:rgba(255,255,255,.6);backdrop-filter:blur(4px);
}

.services{display:flex;flex-direction:column;border-top:1px solid var(--line)}
.svc{
  border-bottom:1px solid var(--line);
  border-radius:18px;
  transition:background .35s var(--ease),box-shadow .4s var(--ease),margin .35s var(--ease);
}
.svc[open]{
  background:var(--surface);
  box-shadow:0 28px 64px -44px rgba(20,21,28,.45),inset 0 0 0 1px var(--line);
  border-bottom-color:transparent;
  margin-block:12px;
}
.svc[open]+.svc{border-top:1px solid transparent}
.svc:not([open]) summary:hover{background:var(--surface-2);border-radius:18px}
.svc summary{
  list-style:none;cursor:pointer;display:grid;
  grid-template-columns:auto 1fr auto;align-items:center;gap:clamp(16px,2.4vw,40px);
  padding:clamp(26px,3.2vw,42px) clamp(18px,2vw,32px);
}
.svc summary::-webkit-details-marker{display:none}
.svc__n{font-family:var(--f-mono);font-size:var(--fs-meta);font-weight:500;letter-spacing:.1em;color:var(--terra-ink)}
.svc__t{font-family:var(--f-display);font-size:clamp(22px,3vw,40px);font-weight:660;letter-spacing:-.025em;line-height:1.04;text-wrap:balance}
.svc__plus{
  flex-shrink:0;width:clamp(36px,3.6vw,46px);height:clamp(36px,3.6vw,46px);border-radius:50%;
  border:1px solid var(--line-strong);display:flex;align-items:center;justify-content:center;
  font-size:22px;line-height:1;color:var(--text);
  transition:transform .35s var(--ease),background .3s,border-color .3s,color .3s;
}
.svc[open] .svc__plus{transform:rotate(45deg);background:var(--brand);border-color:var(--brand);color:#fff}
.svc summary:hover .svc__plus{border-color:var(--brand)}
.svc__body{
  display:grid;grid-template-columns:1.2fr 1fr;gap:clamp(24px,4vw,64px);
  padding:0 clamp(18px,2vw,32px) clamp(34px,4vw,56px);
}
@media(max-width:760px){.svc__body{grid-template-columns:1fr;gap:24px}}
.svc__desc{font-size:var(--fs-body);line-height:1.6;color:var(--muted);max-width:54ch}
.svc__desc strong{color:var(--text);font-weight:600}
.svc__tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:22px}
.svc__tags span{
  font-family:var(--f-mono);font-size:11px;letter-spacing:.02em;color:var(--muted);
  padding:6px 11px;border:1px solid var(--line);border-radius:7px;transition:.2s;
}
.svc__tags span:hover{border-color:var(--terra);color:var(--terra-ink)}
.svc__proof{display:flex;flex-direction:column;gap:14px}
.svc__proof li{display:flex;gap:13px;align-items:flex-start;font-size:var(--fs-body);line-height:1.5;color:var(--muted)}
.svc__proof li::before{content:"";margin-top:.55em;width:6px;height:6px;border-radius:50%;background:var(--terra);flex-shrink:0}
.svc__proof b{color:var(--text);font-weight:600}

/* =========================================================
   §02 ПОДХОД — WebGL wave w/ baked text (dark island)
   ========================================================= */
.atoms{position:relative;background:var(--navy);overflow:hidden;min-height:88svh;display:flex;align-items:stretch}
.atoms__canvas{position:absolute;inset:0;width:100%;height:100%;z-index:0;display:block}
.atoms__veil{position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(180deg, var(--navy) 0%, transparent 16%, transparent 84%, var(--navy) 100%)}
.atoms__inner{position:relative;z-index:2;width:100%;display:flex;flex-direction:column;justify-content:space-between;
  padding-block:clamp(40px,6vw,84px);gap:24px;text-align:center;color:#EEF1FB}
.atoms__inner .eyebrow{justify-content:center;color:var(--cyan)}
.atoms__inner .eyebrow::before{background:var(--cyan)}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;
  clip:rect(0,0,0,0);white-space:nowrap;border:0}
.atoms__steps{display:flex;flex-wrap:wrap;justify-content:center;gap:clamp(12px,2vw,22px)}
.atoms__step{
  display:flex;align-items:center;gap:10px;font-family:var(--f-mono);font-size:var(--fs-meta);color:#A6AAC6;
  padding:10px 16px;border:1px solid rgba(255,255,255,.1);border-radius:var(--pill);background:rgba(10,12,40,.35);backdrop-filter:blur(4px);
}
.atoms__step b{color:var(--cyan)}

/* =========================================================
   CASES (light) — metric-first
   ========================================================= */
.cases{background:var(--bg)}
.cases__grid{display:grid;grid-template-columns:1fr;gap:clamp(18px,2vw,26px)}
@media(min-width:780px){.cases__grid{grid-template-columns:repeat(3,1fr)}}
.case{
  display:flex;flex-direction:column;
  border:1px solid var(--line);border-radius:var(--radius);
  padding:clamp(24px,2.8vw,34px);background:var(--surface);
  transition:transform .35s var(--ease),border-color .35s var(--ease),box-shadow .35s var(--ease);
}
.case:hover{transform:translateY(-5px);border-color:rgba(0,40,245,.32);box-shadow:0 26px 60px -38px rgba(0,40,245,.4)}
.case__client{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  font-family:var(--f-mono);font-size:var(--fs-meta);letter-spacing:.04em;color:var(--muted);
  padding-bottom:18px;margin-bottom:20px;border-bottom:1px solid var(--line);
}
.case__client .tag{color:var(--terra-ink)}
.case__metric{
  font-family:var(--font-display-cond);font-size:clamp(46px,5.6vw,72px);font-weight:700;letter-spacing:.005em;line-height:.9;
  text-transform:uppercase;color:var(--text);
}
.case__metric .u{
  display:block;font-family:var(--f-mono);font-size:13px;font-weight:500;letter-spacing:.04em;
  color:var(--brand);margin-top:12px;text-transform:none;
}
.case__desc{font-size:var(--fs-body);line-height:1.55;color:var(--muted);margin-top:18px;text-wrap:pretty}
.case__tags{display:flex;flex-wrap:wrap;gap:7px;margin-top:22px}
.case__tags span{font-family:var(--f-mono);font-size:11px;color:var(--muted);padding:5px 10px;border:1px solid var(--line);border-radius:6px}
.case__link{
  margin-top:24px;display:inline-flex;align-items:center;gap:.5em;align-self:flex-start;
  font-family:var(--f-ui);font-weight:600;font-size:14px;color:var(--brand);
}
.case__link .btn__arrow{transition:transform .3s var(--ease)}
.case:hover .case__link .btn__arrow{transform:translateX(5px)}

/* =========================================================
   FOUNDER (light)
   ========================================================= */
.founder{background:var(--surface)}
.founder__grid{display:grid;grid-template-columns:1fr;gap:clamp(32px,5vw,72px);align-items:start}
@media(min-width:900px){.founder__grid{grid-template-columns:1fr 1.1fr}}
.founder__photo{
  position:relative;border-radius:var(--radius-lg);overflow:hidden;
  aspect-ratio:4/5;background:linear-gradient(155deg,var(--indigo),#06093a 58%,var(--cyan));
  display:flex;align-items:flex-end;justify-content:center;
  border:1px solid var(--line);
}
.founder__photo .mono{
  font-family:var(--font-display-cond);font-weight:700;font-size:clamp(100px,15vw,180px);
  color:rgba(255,255,255,.94);letter-spacing:.01em;line-height:1;margin-bottom:6%;text-transform:uppercase;
}
.founder__photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 12%}
.founder__photo .glow{position:absolute;inset:0;background:radial-gradient(110% 70% at 50% 0%,rgba(255,255,255,.18),transparent 58%)}
.founder__badge{
  position:absolute;left:20px;top:20px;z-index:2;
  font-family:var(--f-mono);font-size:11px;letter-spacing:.05em;color:#fff;
  padding:8px 13px;border-radius:var(--pill);background:rgba(0,0,0,.32);border:1px solid rgba(255,255,255,.22);backdrop-filter:blur(6px);
}
.founder__name{font-family:var(--f-display);font-size:clamp(30px,4vw,52px);font-weight:700;letter-spacing:-.03em;line-height:1.02;margin-top:14px}
.founder__role{font-family:var(--f-mono);font-size:var(--fs-meta);letter-spacing:.04em;color:var(--terra-ink);margin-top:14px}
.founder__regalia{display:flex;flex-direction:column;margin-top:clamp(26px,3vw,38px);border-top:1px solid var(--line)}
.regalia{display:grid;grid-template-columns:auto 1fr;gap:clamp(14px,2vw,26px);align-items:baseline;padding:clamp(16px,2vw,22px) 0;border-bottom:1px solid var(--line)}
.regalia__n{font-family:var(--f-mono);font-size:13px;color:var(--terra-ink);font-weight:500}
.regalia__t{font-size:var(--fs-body);line-height:1.45;color:var(--muted)}
.regalia__t b{color:var(--text);font-weight:600}
.founder__quote{
  margin-top:clamp(26px,3vw,36px);padding:clamp(22px,2.6vw,30px);
  border:1px solid var(--line);border-radius:var(--radius);background:var(--surface-2);
}
.founder__quote p{font-family:var(--f-display);font-size:clamp(18px,1.9vw,23px);font-weight:560;line-height:1.35;letter-spacing:-.01em;color:var(--text);text-wrap:pretty}
.founder__quote p em{color:var(--brand);font-style:normal}
.founder__quote footer{display:flex;align-items:center;gap:12px;margin-top:20px;font-family:var(--f-mono);font-size:12px;color:var(--muted)}
.founder__quote .av{width:40px;height:40px;border-radius:50%;background:linear-gradient(140deg,var(--brand),var(--terra));display:flex;align-items:center;justify-content:center;font-family:var(--f-display);font-weight:700;font-size:13px;color:#fff;flex-shrink:0}
.founder__quote footer b{color:var(--text);font-weight:600;display:block;font-family:var(--f-body)}

/* =========================================================
   GIFTS / ACADEMY LEAD (light editorial)
   ========================================================= */
.gifts{background:var(--surface-2)}
.gifts__head{display:flex;flex-direction:column;gap:clamp(16px,2vw,24px);max-width:820px;margin-bottom:clamp(36px,4.5vw,60px)}
.gifts__grid{display:grid;grid-template-columns:1fr;gap:clamp(16px,2vw,24px)}
@media(min-width:780px){.gifts__grid{grid-template-columns:repeat(3,1fr)}}
.gift{
  display:flex;flex-direction:column;gap:14px;
  border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:clamp(26px,3vw,36px);background:var(--surface);
  transition:transform .35s var(--ease),box-shadow .35s var(--ease),border-color .35s var(--ease);
}
.gift:hover{transform:translateY(-5px);box-shadow:0 28px 60px -40px rgba(20,21,28,.4);border-color:rgba(0,40,245,.28)}
.gift__n{
  width:46px;height:46px;border-radius:13px;flex-shrink:0;display:flex;align-items:center;justify-content:center;
  font-family:var(--font-display-cond);font-weight:700;font-size:22px;color:#fff;background:var(--brand);
}
.gift:nth-child(2) .gift__n{background:var(--terra)}
.gift:nth-child(3) .gift__n{background:var(--indigo)}
.gift__t{font-family:var(--f-display);font-size:clamp(19px,2vw,23px);font-weight:660;letter-spacing:-.02em;line-height:1.1}
.gift__d{font-size:14.5px;line-height:1.55;color:var(--muted);text-wrap:pretty}
.gift__tag{margin-top:auto;font-family:var(--f-mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--terra-ink)}

/* capture row */
.capture{
  margin-top:clamp(28px,3.4vw,44px);
  display:grid;grid-template-columns:1fr;gap:clamp(20px,3vw,40px);align-items:center;
  border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--surface);
  padding:clamp(24px,3vw,40px);
}
@media(min-width:880px){.capture{grid-template-columns:1.1fr 1fr}}
.capture__copy h3{font-family:var(--f-display);font-size:clamp(22px,2.6vw,30px);font-weight:680;letter-spacing:-.02em;line-height:1.1}
.capture__copy p{margin-top:12px;color:var(--muted);font-size:var(--fs-body);line-height:1.5;max-width:42ch}
.capture__form{display:flex;flex-direction:column;gap:12px}
.field{display:flex;gap:10px;flex-wrap:wrap}
.field input{
  flex:1 1 220px;min-height:52px;padding:0 18px;border-radius:var(--pill);
  border:1px solid var(--line-strong);background:var(--surface-2);color:var(--text);
  font-family:var(--f-ui);font-size:15px;transition:border-color .2s,box-shadow .2s;
}
.field input::placeholder{color:var(--faint)}
.field input:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px rgba(0,40,245,.14)}
.field .btn{flex:0 0 auto}
.capture__note{font-family:var(--f-mono);font-size:11.5px;letter-spacing:.02em;color:var(--faint)}
.capture__note.ok{color:var(--terra-ink)}

/* WhatsApp diagnostic band */
.diag{
  margin-top:clamp(20px,2.4vw,30px);
  display:flex;flex-wrap:wrap;align-items:center;gap:clamp(16px,2vw,28px);justify-content:space-between;
  border:1px dashed var(--line-strong);border-radius:var(--radius-lg);
  padding:clamp(24px,3vw,38px);background:
    linear-gradient(120deg, rgba(0,40,245,.05), rgba(204,120,92,.06));
}
.diag__copy{max-width:46ch}
.diag__copy h3{font-family:var(--font-display-cond);text-transform:uppercase;font-size:clamp(26px,3.4vw,44px);font-weight:700;line-height:.95;letter-spacing:.005em}
.diag__copy p{margin-top:12px;color:var(--muted);font-size:var(--fs-body);line-height:1.5}
.diag .btn{font-size:clamp(15px,1.3vw,18px);padding:clamp(16px,1.8vw,22px) clamp(26px,2.6vw,38px)}

/* =========================================================
   FINAL CTA (dark island)
   ========================================================= */
.final{position:relative;background:var(--navy);color:#EEF1FB;overflow:hidden;text-align:center}
.final__canvas{position:absolute;inset:0;width:100%;height:100%;z-index:0;display:block}
/* ---- rebuild (globe) section: full-block canvas, text overlaid left ---- */
.rebuild{position:relative;overflow:hidden;background:var(--navy);color:#EEF1FB;min-height:min(94vh,840px);display:flex;align-items:center}
.rebuild__fx{position:absolute;inset:0;width:100%;height:100%;z-index:1;pointer-events:none}
.rebuild__cont{position:relative;z-index:2}
.rebuild__inner{max-width:480px;margin:0;display:flex;flex-direction:column;gap:clamp(16px,2vw,24px);align-items:flex-start;text-align:left}
.rebuild .eyebrow{justify-content:flex-start;color:var(--cyan)}
.rebuild .eyebrow::before{background:var(--cyan)}
.rebuild .h2{color:#fff;text-wrap:balance}
.rebuild .lead{color:#A6AAC6;max-width:42ch}
@media(max-width:860px){
  .rebuild{min-height:auto;padding-block:clamp(60px,12vw,96px)}
  .rebuild__fx{opacity:.5}
  .rebuild__inner{max-width:none;align-items:center;text-align:center;margin-inline:auto}
  .rebuild .eyebrow{justify-content:center}
  .rebuild .lead{margin-inline:auto}
}
[dir="rtl"] .rebuild__inner{margin-left:auto;align-items:flex-end;text-align:right}
[dir="rtl"] .rebuild .eyebrow{justify-content:flex-end}
@media(max-width:860px){[dir="rtl"] .rebuild__inner{align-items:center;text-align:center}}
/* RTL hero: mirror the brain canvas fade + backing to the LEFT (JS flips the figure offset) */
[dir="rtl"] .hero__brain{
  -webkit-mask-image:linear-gradient(270deg,transparent 0%,#000 40%,#000 100%);
          mask-image:linear-gradient(270deg,transparent 0%,#000 40%,#000 100%);
  background:radial-gradient(46% 50% at 26% 46%,rgba(1,2,30,.5) 0%,rgba(1,2,30,.26) 42%,transparent 72%)}
[dir="rtl"] .hero__copy{margin-left:0;margin-right:0}
.final__fx{position:absolute;top:0;height:100%;width:50%;z-index:1;pointer-events:none;display:none}
.final__fx--l{left:0;-webkit-mask-image:linear-gradient(90deg,#000 50%,transparent 88%);mask-image:linear-gradient(90deg,#000 50%,transparent 88%)}
.final__fx--r{right:0;-webkit-mask-image:linear-gradient(270deg,#000 50%,transparent 88%);mask-image:linear-gradient(270deg,#000 50%,transparent 88%)}
@media(min-width:1080px){.final__fx{display:block}}

/* ---- preloader ---- */
body.preloading{overflow:hidden}
.preloader{position:fixed;inset:0;z-index:9999;background:var(--navy);display:grid;place-items:center;transition:opacity .7s var(--ease),visibility .7s}
.preloader.is-done{opacity:0;visibility:hidden}
.preloader__inner{display:flex;flex-direction:column;align-items:center;gap:22px;width:min(360px,68vw)}
.preloader__logo{display:flex;align-items:center;gap:10px;color:#EEF1FB;font-family:var(--font-display-cond);text-transform:uppercase;font-size:20px;letter-spacing:.05em}
.preloader__logo .brand__mark{width:30px;height:30px}
.preloader__count{font-family:var(--font-display-cond);font-size:clamp(64px,12vw,118px);color:#fff;line-height:1;letter-spacing:.01em}
.preloader__count i{color:var(--cyan);font-style:normal;font-size:.34em;vertical-align:super;margin-left:.08em}
.preloader__track{width:100%;height:2px;background:rgba(255,255,255,.12);overflow:hidden;border-radius:2px}
.preloader__track span{display:block;height:100%;background:linear-gradient(90deg,var(--cyan),var(--brand));transform:scaleX(0);transform-origin:left;will-change:transform}
@media(prefers-reduced-motion:reduce){.preloader{display:none!important}body.preloading{overflow:auto}}
.final__veil{position:absolute;inset:0;z-index:1;pointer-events:none;background:radial-gradient(100% 100% at 50% 40%,transparent 20%,rgba(1,3,52,.78) 100%)}
.final__inner{position:relative;z-index:2;max-width:880px;margin-inline:auto}
.final .eyebrow{justify-content:center;color:var(--cyan)}
.final .eyebrow::before{background:var(--cyan)}
.final h2{font-family:var(--font-display-cond);font-size:var(--fs-h2);font-weight:700;line-height:.95;letter-spacing:.005em;text-transform:uppercase;text-wrap:balance;margin:24px auto clamp(20px,2.4vw,28px);max-width:16ch}
.final h2 em{font-style:normal;color:var(--cyan)}
.final__lead{font-size:var(--fs-lead);color:#A6AAC6;line-height:1.45;max-width:48ch;margin:0 auto clamp(28px,3vw,38px)}
.final__actions{display:flex;flex-wrap:wrap;gap:14px;justify-content:center}
.final__meta{margin-top:clamp(26px,3vw,38px);font-family:var(--f-mono);font-size:var(--fs-meta);color:rgba(238,241,251,.42);letter-spacing:.04em}

/* =========================================================
   FOOTER (light)
   ========================================================= */
.footer{background:var(--surface-3);color:var(--text);border-top:1px solid var(--line);padding-block:clamp(48px,6vw,80px)}
.footer__grid{display:grid;grid-template-columns:1fr;gap:clamp(32px,4vw,48px)}
@media(min-width:640px){.footer__grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:960px){.footer__grid{grid-template-columns:1.6fr 1fr 1fr 1fr}}
.footer__brand .brand{margin-bottom:18px}
.footer__brand p{font-size:14px;color:var(--muted);line-height:1.6;max-width:34ch}
.footer__col h5{font-family:var(--f-mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--faint);margin-bottom:18px}
.footer__col a{display:block;font-family:var(--f-ui);font-size:15px;color:var(--muted);padding:6px 0;transition:color .2s}
.footer__col a:hover{color:var(--text)}
.footer__bottom{
  display:flex;flex-wrap:wrap;justify-content:space-between;gap:14px 24px;align-items:center;
  margin-top:clamp(40px,5vw,64px);padding-top:24px;border-top:1px solid var(--line);
  font-family:var(--f-mono);font-size:12px;color:var(--faint);
}
.footer__langs{display:flex;gap:6px;flex-wrap:wrap}
.footer__langs button{font-family:var(--f-mono);font-size:11px;padding:5px 9px;border-radius:var(--pill);border:1px solid var(--line);color:var(--muted);transition:.2s}
.footer__langs button:hover{color:var(--text)}
.footer__langs button[aria-pressed="true"]{background:var(--brand);color:#fff;border-color:var(--brand)}
@media(min-width:1025px){.footer__bottom{padding-right:200px}}

/* =========================================================
   CURSOR SPOTLIGHT — soft frosted-blue glow on cream cards
   ========================================================= */
.spot{position:relative;isolation:isolate}
.spot::after{
  content:"";position:absolute;inset:0;border-radius:inherit;z-index:0;pointer-events:none;
  background:
    radial-gradient(220px circle at var(--mx,50%) var(--my,50%), rgba(56,116,242,.22), transparent 60%),
    radial-gradient(440px circle at var(--mx,50%) var(--my,50%), rgba(41,169,255,.11), transparent 74%);
  opacity:0;transition:opacity .4s var(--ease);
}
.spot:hover::after{opacity:1}
.spot > *{position:relative;z-index:1}
@media(prefers-reduced-motion:reduce){.spot::after{transition:none}}

/* =========================================================
   REVEAL — block (cards/chips)
   ========================================================= */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .8s var(--ease-out),transform .8s var(--ease-out)}
.reveal.is-in{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.08s}
.reveal[data-d="2"]{transition-delay:.16s}
.reveal[data-d="3"]{transition-delay:.24s}
.reveal[data-d="4"]{transition-delay:.32s}

/* REVEAL — dayos-style per-line text mask */
[data-reveal-lines]{}
.rl-line{display:block;overflow:hidden;padding-bottom:.2em;margin-bottom:-.2em}
.rl-inner{
  display:block;transform:translateY(120%);opacity:0;
  transition:transform 1s var(--ease-out),opacity 1s var(--ease-out);
  transition-delay:var(--rl-delay,0s);
}
[data-reveal-lines].is-in .rl-inner{transform:none;opacity:1}

/* =========================================================
   RESPONSIVE — TABLET (≤960) & MOBILE (≤640)
   ========================================================= */
@media(max-width:960px){
  .founder__photo{aspect-ratio:16/11;max-height:420px}
  .founder__photo .mono{font-size:clamp(80px,15vw,140px);margin-bottom:5%}
  .hero__copy{max-width:80%}
  .stage3d{height:clamp(320px,46vw,440px)}
  .stage3d__models{max-width:60%}
}

@media(max-width:640px){
  :root{
    --fs-display:clamp(38px,11vw,58px);
    --fs-h2:clamp(34px,10vw,54px);
    --fs-lead:17px;
    --fs-body:16px;
    --section-y:clamp(60px,13vw,88px);
    --gutter:20px;
  }
  .btn{min-height:48px}
  .nav a,.case__link{min-height:44px;display:inline-flex;align-items:center}

  .header__inner{height:64px}
  .brand__name{font-size:15px}
  .drawer{padding-top:96px}
  .drawer__lang button,.footer__langs button{min-height:44px;padding-inline:14px;display:inline-flex;align-items:center}

  /* HERO */
  .hero{min-height:auto;padding-top:108px;padding-bottom:60px;align-items:flex-start}
  .hero__copy{max-width:100%}
  .hero h1 br{display:none}
  .hero__sub{max-width:100%}
  .metricpill{width:100%;justify-content:flex-start;gap:8px 12px;padding:12px 16px}
  .hero__actions{width:100%}
  .hero__actions .btn{flex:1 1 auto;justify-content:center}

  /* PROOF */
  .logowall{grid-template-columns:repeat(2,1fr)}
  .logoplate{min-height:72px;font-size:14px}
  .logoplate[data-case]::after{opacity:1}

  /* SERVICES */
  .stage3d{height:clamp(280px,72vw,360px);margin-bottom:32px}
  .stage3d__models{display:none}
  .stage3d__cap{max-width:24ch}
  .svc summary{padding:22px 0;gap:14px}
  .svc__t{font-size:clamp(20px,6vw,26px)}
  .svc__plus{width:44px;height:44px}
  .svc__body{grid-template-columns:1fr;gap:22px;padding-bottom:30px}

  /* §02 */
  .atoms{min-height:78svh;padding-block:clamp(72px,18vw,110px)}
  .atoms__steps{gap:10px}
  .atoms__step{padding:10px 14px}

  /* CASES */
  .cases__grid{grid-template-columns:1fr}
  .case__metric{font-size:clamp(46px,15vw,62px)}

  /* FOUNDER */
  .founder__photo{aspect-ratio:4/3;max-height:340px}
  .founder__photo .mono{font-size:clamp(72px,22vw,120px)}
  .founder__name{font-size:clamp(28px,8vw,38px)}

  /* GIFTS */
  .gifts__grid{grid-template-columns:1fr}
  .gift{padding:24px 22px}
  .capture{grid-template-columns:1fr;padding:24px 20px}
  .field input{min-height:50px}
  .field .btn{width:100%;justify-content:center}
  .diag{flex-direction:column;align-items:flex-start;padding:24px 20px}
  .diag .btn{width:100%;justify-content:center}

  /* FOOTER */
  .footer__bottom{flex-direction:column;align-items:flex-start;gap:18px}
}

@media(max-width:380px){
  :root{--fs-display:clamp(34px,12vw,46px)}
  .brand__name .nn{display:none}
}

@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  .rl-inner{transform:none;opacity:1;transition:none}
  *{animation:none!important}
  html{scroll-behavior:auto}
}

/* =========================================================
   FLOATING: Ask-AI pulse button + talking-avatar card + modal
   ========================================================= */
/* collapsible right dock */
.dock{position:fixed;right:clamp(14px,1.6vw,24px);bottom:clamp(14px,1.6vw,24px);z-index:130;display:flex;flex-direction:column;align-items:flex-end;gap:10px}
.dock__panel{position:relative;display:flex;flex-direction:column;align-items:flex-end;gap:10px;transform-origin:bottom right;transition:opacity .3s var(--ease),transform .3s var(--ease)}
.dock[data-open="false"] .dock__panel{opacity:0;transform:translateY(8px) scale(.9);pointer-events:none;position:absolute;bottom:0;right:0}
.dock__min{position:absolute;left:-7px;top:-16px;z-index:3;width:24px;height:24px;border-radius:50%;background:var(--surface);color:var(--text);border:1px solid var(--line-strong);display:grid;place-items:center;box-shadow:0 6px 16px -6px rgba(20,21,28,.4);transition:.2s}
.dock__min:hover{background:var(--brand);color:#fff;border-color:var(--brand)}
.dock__fab{position:relative;width:52px;height:52px;border-radius:50%;background:var(--brand);color:#fff;display:none;place-items:center;cursor:pointer;box-shadow:0 14px 34px -10px rgba(0,40,245,.8),inset 0 0 0 1px rgba(255,255,255,.16);transition:transform .25s var(--ease),background .25s var(--ease)}
.dock__fab svg{width:22px;height:22px}
.dock__fab:hover{transform:scale(1.06);background:var(--brand-600)}
.dock[data-open="false"] .dock__fab{display:grid}
.dock__fab-ring{position:absolute;inset:0;border-radius:50%;border:2px solid var(--brand);animation:askring 3s var(--ease) infinite;pointer-events:none}
body.modal-open .dock{display:none}
.askai__btn{
  position:relative;display:inline-flex;align-items:center;gap:.55em;
  background:var(--brand);color:#fff;border-radius:var(--pill);
  font-family:var(--f-ui);font-weight:600;font-size:12.5px;letter-spacing:.04em;text-transform:uppercase;
  padding:11px 17px;cursor:pointer;white-space:nowrap;
  box-shadow:0 14px 38px -12px rgba(0,40,245,.8),inset 0 0 0 1px rgba(255,255,255,.16);
  transition:transform .25s var(--ease),background .25s var(--ease),box-shadow .25s var(--ease);
  animation:askbreathe 3.6s var(--ease) infinite;
}
.askai__btn:hover{background:var(--brand-600);transform:translateY(-2px);box-shadow:0 20px 48px -12px rgba(0,40,245,.95),inset 0 0 0 1px rgba(255,255,255,.24)}
.askai__btn:active{transform:translateY(0) scale(.98)}
.askai__btn svg{width:15px;height:15px;flex-shrink:0}
.askai__ring{position:absolute;inset:0;border-radius:var(--pill);border:2px solid var(--brand);pointer-events:none;animation:askring 3.6s var(--ease) infinite}
.askai__ring:nth-of-type(2){animation-delay:1.8s}
@keyframes askring{0%{transform:scale(1);opacity:.55}70%{transform:scale(1.32);opacity:0}100%{transform:scale(1.32);opacity:0}}
@keyframes askbreathe{0%,88%,100%{box-shadow:0 14px 38px -12px rgba(0,40,245,.8),inset 0 0 0 1px rgba(255,255,255,.16)}44%{box-shadow:0 18px 50px -10px rgba(0,40,245,1),inset 0 0 0 1px rgba(255,255,255,.24)}}

.avwidget{width:clamp(128px,13vw,150px);cursor:pointer;border:none;background:none;padding:0;display:block}
.avwidget__card{
  position:relative;border-radius:18px;overflow:hidden;aspect-ratio:140/176;
  background:radial-gradient(120% 90% at 60% 10%,#10204f 0%,#050726 55%,#02030f 100%);
  box-shadow:0 18px 46px -18px rgba(0,0,0,.6),inset 0 0 0 1px rgba(255,255,255,.1);
  transition:transform .24s cubic-bezier(.34,1.56,.64,1),box-shadow .32s var(--ease);
}
.avwidget:hover .avwidget__card,.avwidget:focus-visible .avwidget__card{transform:scale(1.1);box-shadow:0 28px 60px -18px rgba(0,40,245,.55),inset 0 0 0 1px rgba(92,179,255,.35)}
/* orbit motif + avatar silhouette placeholder (swap .avwidget__poster background-image for a real still) */
.avwidget__card{display:block}
.avwidget__vid{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;display:block}
.avwidget__orbit{position:absolute;inset:0;opacity:.5}
.avwidget__orbit::before,.avwidget__orbit::after{content:"";position:absolute;border:1px solid rgba(92,179,255,.28);border-radius:50%}
.avwidget__orbit::before{inset:18% -30% 30% 12%;transform:rotate(-18deg)}
.avwidget__orbit::after{inset:30% 14% 12% -28%;transform:rotate(22deg)}
.avwidget__mono{position:absolute;left:0;right:0;top:30%;text-align:center;font-family:var(--font-display-cond);font-weight:700;font-size:40px;color:rgba(238,241,251,.5);letter-spacing:.02em}
.avwidget__mode{position:absolute;left:8px;top:8px;z-index:2;display:inline-flex;align-items:center;gap:4px;
  font-family:var(--f-mono);font-size:8.5px;letter-spacing:.06em;text-transform:uppercase;color:#fff;
  padding:4px 7px 4px 5px;border-radius:var(--pill);background:rgba(0,40,245,.92);box-shadow:0 4px 12px -4px rgba(0,40,245,.9)}
.avwidget__mode svg{width:13px;height:13px}
.avwidget__play{position:absolute;inset:0;z-index:2;display:grid;place-items:center;opacity:0;transition:opacity .25s var(--ease)}
.avwidget__play svg{width:34px;height:34px;color:#fff;padding:11px;border-radius:50%;
  background:rgba(0,40,245,.92);box-shadow:0 8px 22px -6px rgba(0,40,245,.95),0 0 0 6px rgba(255,255,255,.12);
  transform:scale(.8);transition:transform .25s cubic-bezier(.34,1.56,.64,1)}
.avwidget:hover .avwidget__play,.avwidget:focus-visible .avwidget__play{opacity:1}
.avwidget:hover .avwidget__play svg{transform:scale(1)}
.avwidget__cap{position:absolute;left:0;right:0;bottom:0;padding:22px 8px 8px;text-align:center;
  background:linear-gradient(transparent,rgba(1,3,52,.72) 52%,rgba(1,3,52,.94))}
.avwidget__cap b{display:block;font-family:var(--f-display);font-weight:680;font-size:11px;line-height:1.12;color:#fff;letter-spacing:-.01em}
.avwidget__cap span{display:block;margin-top:1px;font-family:var(--f-mono);font-size:8px;letter-spacing:.02em;color:var(--cyan)}
.avwidget__live{position:absolute;right:9px;top:11px;display:flex;align-items:center;gap:4px;font-family:var(--f-mono);font-size:8.5px;letter-spacing:.08em;color:#fff;text-transform:uppercase}
.avwidget__live i{width:6px;height:6px;border-radius:50%;background:#2bd47a;box-shadow:0 0 0 0 rgba(43,212,122,.7);animation:livedot 2s infinite}
@keyframes livedot{0%{box-shadow:0 0 0 0 rgba(43,212,122,.6)}70%{box-shadow:0 0 0 7px rgba(43,212,122,0)}100%{box-shadow:0 0 0 0 rgba(43,212,122,0)}}

.avmodal{position:fixed;inset:0;z-index:200;display:grid;place-items:center;padding:clamp(14px,3vw,32px);
  background:rgba(2,4,18,.74);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  opacity:0;visibility:hidden;transition:opacity .35s var(--ease),visibility .35s}
.avmodal.is-open{opacity:1;visibility:visible}
.avmodal__panel{width:min(940px,100%);background:#04061a;border:1px solid var(--line-strong);
  border-radius:24px;overflow:hidden;box-shadow:0 50px 120px -40px rgba(0,0,0,.8);
  transform:scale(.95) translateY(10px);transition:transform .4s var(--ease-out)}
.avmodal.is-open .avmodal__panel{transform:none}
.avmodal__head{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:15px 18px;border-bottom:1px solid rgba(255,255,255,.08)}
.avmodal__id{display:flex;align-items:center;gap:11px;color:#EEF1FB}
.avmodal__id .av{width:38px;height:38px;border-radius:11px;background:linear-gradient(140deg,var(--brand),var(--cyan));display:grid;place-items:center;font-family:var(--font-display-cond);font-weight:700;font-size:15px;color:#fff}
.avmodal__id b{font-family:var(--f-display);font-weight:680;font-size:15px;display:block;line-height:1.1}
.avmodal__id span{font-family:var(--f-mono);font-size:11px;color:var(--cyan);display:flex;align-items:center;gap:6px}
.avmodal__id span i{width:7px;height:7px;border-radius:50%;background:#2bd47a}
.avmodal__close{width:40px;height:40px;border-radius:11px;border:1px solid rgba(255,255,255,.14);color:#EEF1FB;display:grid;place-items:center;transition:.2s;flex-shrink:0}
.avmodal__close:hover{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.3)}
.avmodal__stage{position:relative;aspect-ratio:16/9;background:#000}
.avmodal__stage iframe{position:absolute;inset:0;width:100%;height:100%;border:0;display:block}
.avmodal__state{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;text-align:center;padding:32px;color:#EEF1FB;
  background:radial-gradient(120% 100% at 50% 30%,#0c1640,#03040f)}
.avmodal__state.hidden{display:none}
.avmodal__spin{width:38px;height:38px;border-radius:50%;border:3px solid rgba(255,255,255,.18);border-top-color:var(--cyan);animation:avspin .9s linear infinite}
@keyframes avspin{to{transform:rotate(360deg)}}
.avmodal__state p{font-family:var(--f-ui);font-size:15px;color:var(--muted);max-width:42ch;line-height:1.5}
.avmodal__state .btn{margin-top:4px}

@media(max-width:560px){
  .askai__btn{padding:14px 18px;font-size:0}
  .askai__btn svg{width:22px;height:22px}
  .askai__btn .askai__lbl{display:none}
  .avwidget{width:128px}
  .avwidget__mono{font-size:40px}
}

@media(prefers-reduced-motion:reduce){
  .askai__btn,.askai__ring,.avwidget__live i{animation:none}
}

/* =========================================================
   CLIENT-LOGO MARQUEE (Proof)
   ========================================================= */
.lmq{position:relative;overflow:hidden;display:flex;flex-direction:column;gap:clamp(12px,1.4vw,18px);
  direction:ltr;   /* ticker is direction-neutral — keep LTR flow even in RTL locales */
  margin-bottom:clamp(36px,5vw,68px);
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);
          mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);}
.lmq__row{display:flex;width:max-content}
.lmq__track{display:flex;animation:lmqmove 46s linear infinite;will-change:transform}
.lmq__row--rev .lmq__track{animation-duration:58s;animation-direction:reverse}
.lmq:hover .lmq__track{animation-play-state:paused}
@keyframes lmqmove{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.lmq__item{
  flex:0 0 auto;width:clamp(140px,14vw,184px);height:clamp(72px,7.5vw,96px);
  margin-right:clamp(12px,1.4vw,18px);
  background:#fff;border:1px solid var(--line);border-radius:14px;
  display:grid;place-items:center;padding:14px 18px;transition:border-color .25s,box-shadow .25s,transform .25s;
}
.lmq__item img{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain}
.lmq__item:hover{border-color:rgba(0,40,245,.32);box-shadow:0 14px 30px -20px rgba(0,40,245,.5);transform:translateY(-2px)}

/* =========================================================
   БЛАГОДАРНОСТИ — drag/arrow carousel
   ========================================================= */
.thanks{background:var(--surface-2)}
.thanks__head{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;margin-bottom:clamp(28px,3.4vw,46px)}
.thanks__head .section-head{margin-bottom:0}
.thanks__nav{display:flex;gap:10px;flex-shrink:0}
.thanks__nav button{
  width:clamp(48px,4vw,56px);height:clamp(48px,4vw,56px);border-radius:14px;border:1px solid var(--line-strong);
  display:grid;place-items:center;color:var(--text);transition:.2s;background:var(--surface);
}
.thanks__nav button:hover{background:var(--brand);border-color:var(--brand);color:#fff}
.thanks__nav button:disabled{opacity:.3;cursor:not-allowed;background:transparent;color:var(--text);border-color:var(--line)}
.thanks__viewport{direction:ltr;overflow-x:auto;overflow-y:hidden;cursor:grab;scroll-snap-type:x mandatory;scrollbar-width:none;-ms-overflow-style:none;-webkit-overflow-scrolling:touch}
.thanks__viewport::-webkit-scrollbar{display:none}
.thanks__viewport.dragging{cursor:grabbing;scroll-snap-type:none}
.thanks__track{display:flex;gap:clamp(16px,1.8vw,24px);width:max-content}
.thanks__card{
  flex:0 0 auto;height:clamp(300px,34vw,440px);width:auto;border-radius:16px;overflow:hidden;
  background:#fff;border:1px solid var(--line);box-shadow:0 18px 44px -30px rgba(20,21,28,.4);
  transition:transform .35s var(--ease),box-shadow .35s var(--ease);scroll-snap-align:start}
.thanks__card img{height:100%;width:auto;display:block;pointer-events:none}
.thanks__card:hover{transform:translateY(-5px);box-shadow:0 28px 60px -34px rgba(20,21,28,.55)}

/* =========================================================
   FOOTER giant background wordmark
   ========================================================= */
.footer{position:relative;overflow:hidden}
.footer__bg{
  position:absolute;left:50%;bottom:-0.14em;transform:translateX(-50%);z-index:0;pointer-events:none;
  font-family:var(--font-display-cond);font-weight:700;text-transform:lowercase;letter-spacing:.01em;
  font-size:clamp(96px,21vw,320px);line-height:.78;white-space:nowrap;
  color:rgba(20,21,28,.045);
}
.footer .container{position:relative;z-index:1}

/* =========================================================
   ASK-AI CHAT WIDGET (opened by "Написать AI")
   ========================================================= */
.chat{position:fixed;right:clamp(14px,1.6vw,24px);bottom:clamp(80px,9vw,96px);z-index:140;
  width:min(370px,calc(100vw - 28px));
  background:var(--surface);border:1px solid var(--line);border-radius:24px;
  box-shadow:0 40px 90px -36px rgba(20,21,28,.5),0 8px 24px -16px rgba(20,21,28,.3);
  display:flex;flex-direction:column;overflow:hidden;
  opacity:0;visibility:hidden;transform:translateY(14px) scale(.96);transform-origin:bottom right;
  transition:opacity .3s var(--ease),transform .3s var(--ease),visibility .3s}
.chat.is-open{opacity:1;visibility:visible;transform:none}
.chat__head{display:flex;align-items:center;gap:12px;padding:16px 18px}
.chat__av{width:46px;height:46px;border-radius:50%;flex-shrink:0;background:var(--brand);display:grid;place-items:center;color:#fff;font-family:var(--font-display-cond);font-weight:700;font-size:20px;box-shadow:0 8px 20px -8px rgba(0,40,245,.8)}
.chat__id{flex:1;min-width:0}
.chat__id b{display:block;font-family:var(--f-display);font-weight:680;font-size:16px;letter-spacing:-.01em}
.chat__id span{display:flex;align-items:center;gap:6px;font-family:var(--f-ui);font-size:12.5px;color:var(--muted)}
.chat__id span::before{content:"";width:7px;height:7px;border-radius:50%;background:#2bd47a}
.chat__close{width:34px;height:34px;border-radius:50%;display:grid;place-items:center;color:var(--muted);transition:.2s;flex-shrink:0}
.chat__close:hover{background:var(--surface-3);color:var(--text)}
.chat__body{display:flex;flex-direction:column;gap:12px;padding:6px 18px 4px;max-height:46vh;overflow-y:auto}
.chat__msg{max-width:84%;padding:13px 16px;border-radius:16px;font-size:14.5px;line-height:1.45;white-space:pre-wrap;word-wrap:break-word}
.chat__msg--bot{align-self:flex-start;background:var(--surface-3);color:var(--text);border-bottom-left-radius:5px}
.chat__msg--me{align-self:flex-end;background:var(--brand);color:#fff;border-bottom-right-radius:5px}
.chat__msg--typing{display:flex;gap:4px;align-items:center}
.chat__msg--typing i{width:7px;height:7px;border-radius:50%;background:var(--muted);animation:chattype 1.2s infinite}
.chat__msg--typing i:nth-child(2){animation-delay:.2s}.chat__msg--typing i:nth-child(3){animation-delay:.4s}
@keyframes chattype{0%,60%,100%{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-3px)}}
.chat__chips{display:flex;flex-wrap:wrap;gap:8px;padding:10px 18px 4px}
.chat__chip{font-family:var(--f-ui);font-size:13px;font-weight:500;color:var(--brand);padding:9px 15px;border-radius:var(--pill);border:1px solid rgba(0,40,245,.28);background:rgba(0,40,245,.04);transition:.2s}
.chat__chip:hover{background:var(--brand);color:#fff;border-color:var(--brand)}
.chat__form{display:flex;align-items:center;gap:8px;margin:12px 18px;padding:6px 6px 6px 18px;border:1.5px solid var(--line-strong);border-radius:var(--pill);transition:border-color .2s,box-shadow .2s}
.chat__form:focus-within{border-color:var(--brand);box-shadow:0 0 0 3px rgba(0,40,245,.12)}
.chat__form input{flex:1;min-width:0;border:none;background:none;font-family:var(--f-ui);font-size:14.5px;color:var(--text);padding:8px 0}
.chat__form input:focus{outline:none}
.chat__form input::placeholder{color:var(--faint)}
.chat__send{width:42px;height:42px;border-radius:50%;flex-shrink:0;background:var(--brand);color:#fff;display:grid;place-items:center;transition:.2s}
.chat__send:hover{background:var(--brand-600)}
.chat__send:disabled{opacity:.5;cursor:not-allowed}
.chat__note{font-family:var(--f-mono);font-size:11px;letter-spacing:.02em;color:var(--faint);text-align:center;padding:0 18px 16px;line-height:1.5}
.chat__note a{color:var(--brand-600);text-decoration:underline}
@media(max-width:560px){.chat{bottom:74px;right:8px;left:8px;width:auto}}

/* =========================================================
   i18n — Arabic typography + RTL mirroring + flexible sizing
   ========================================================= */
/* Arabic glyph coverage (Latin display faces lack Arabic) */
[dir="rtl"] body{font-family:'Noto Sans Arabic','Manrope',sans-serif}
[dir="rtl"] .h2,[dir="rtl"] .h3,[dir="rtl"] h1,[dir="rtl"] .hero h1,[dir="rtl"] .display,
[dir="rtl"] .svc__t,[dir="rtl"] .case__metric,[dir="rtl"] .founder__name,[dir="rtl"] .founder__quote p,
[dir="rtl"] .final h2,[dir="rtl"] .gift__t,[dir="rtl"] .diag__copy h3,[dir="rtl"] .capture__copy h3,
[dir="rtl"] .drawer a,[dir="rtl"] .thanks__h2,[dir="rtl"] .footer__col h5{
  font-family:'Noto Sans Arabic','Inter Tight',sans-serif;letter-spacing:0;text-transform:none;line-height:1.2;
}
[dir="rtl"] .eyebrow,[dir="rtl"] .svc__n,[dir="rtl"] .case__client,[dir="rtl"] .case__metric .u,
[dir="rtl"] .metricpill,[dir="rtl"] .atoms__step,[dir="rtl"] .gift__tag,[dir="rtl"] .svc__tags span,
[dir="rtl"] .case__tags span,[dir="rtl"] .proof__label,[dir="rtl"] .final__meta,[dir="rtl"] .capture__note,
[dir="rtl"] .chat__note,[dir="rtl"] .avwidget__cap span,[dir="rtl"] .dock_chat{
  font-family:'Noto Sans Arabic','JetBrains Mono',monospace;letter-spacing:.02em;
}
/* keep the big condensed display numbers/Latin marks legible */
[dir="rtl"] .hero__wm b,[dir="rtl"] .footer__bg,[dir="rtl"] .avwidget__mono,[dir="rtl"] .founder__photo .mono{font-family:var(--font-display-cond)}

/* RTL: flip directional arrows */
[dir="rtl"] .btn__arrow{transform:scaleX(-1)}
[dir="rtl"] .btn:hover .btn__arrow{transform:scaleX(-1) translateX(5px)}
[dir="rtl"] .case:hover .case__link .btn__arrow{transform:scaleX(-1) translateX(5px)}

/* RTL: hero watermark moves to the left edge */
[dir="rtl"] .hero__wm{right:auto;left:calc(-1*var(--gutter));align-items:flex-start;text-align:left}
[dir="rtl"] .hero__wm span{text-align:left}

/* RTL: floating dock + chat mirror to the bottom-left */
[dir="rtl"] .dock{right:auto;left:clamp(14px,1.6vw,24px);align-items:flex-start}
[dir="rtl"] .dock__panel{align-items:flex-start;transform-origin:bottom left}
[dir="rtl"] .dock[data-open="false"] .dock__panel{left:0;right:auto}
[dir="rtl"] .dock__min{left:auto;right:-7px}
[dir="rtl"] .chat{right:auto;left:clamp(14px,1.6vw,24px);transform-origin:bottom left}
[dir="rtl"] .avwidget__mode{left:auto;right:8px}
[dir="rtl"] .avwidget__live{right:auto;left:9px}
[dir="rtl"] .avwidget__eye{left:auto;right:9px}
@media(min-width:1025px){[dir="rtl"] .footer__bottom{padding-right:0;padding-left:200px}}
@media(max-width:560px){[dir="rtl"] .chat{left:8px;right:8px}}

/* RTL: carousel arrows keep visual order; chat send icon flips */
[dir="rtl"] .chat__send svg{transform:scaleX(-1)}

/* Flexible sizing — let labels of different lengths breathe */
.btn{white-space:nowrap}
.nav a{white-space:nowrap}
.askai__btn .askai__lbl{white-space:nowrap}
.svc__t,.gift__t,.case__metric,.h2{overflow-wrap:break-word}
.hero h1{overflow-wrap:normal;word-break:keep-all}
.diag .btn,.capture__form .btn{white-space:normal;text-align:center;line-height:1.25}
@media(min-width:1025px){
  /* a touch more room between nav items for longer locales */
  .nav{gap:clamp(14px,1.5vw,26px)}
}

@media(max-width:640px){
  .thanks__head{flex-direction:column;align-items:flex-start;gap:20px}
  .thanks__card{height:clamp(260px,68vw,340px)}
}

/* ---- film grain overlay (subtle depth on dark sections) ---- */
.grain{position:fixed;inset:0;z-index:120;pointer-events:none;opacity:.045;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:160px 160px}
@media(prefers-reduced-motion:reduce){.grain{display:none}}

/* ===== MOBILE: show + centre all particle figures (desktop keeps them right-offset) ===== */
@media(max-width:879px){
  .hero__brain{display:block!important;-webkit-mask-image:none!important;mask-image:none!important;background:none!important;opacity:.7;z-index:0}
}
@media(max-width:1079px){
  .final__fx{display:block!important;-webkit-mask-image:none!important;mask-image:none!important;opacity:.6}
}
