/* ─────────────────────────────────────────────────
   AKI Collector — Redesign
   Editorial-tech · Brand-true palette · Bold type
   ───────────────────────────────────────────────── */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  /* brand palette (from guidelines) */
  --cyan:#01E5F1;
  --blue-d:#0D9DF5;
  --blue-m:#29ABE2;
  --blue-l:#68C5ED;
  --navy:#0A1628;
  --midnight:#07101F;
  --bg:#05080E;
  --ink:#E7EEF5;
  --ink-strong:#ffffff;
  --ink-on-accent:#051320;
  --ink-soft:rgba(231,238,245,.62);
  --ink-mute:rgba(231,238,245,.38);
  --ink-border:rgba(231,238,245,.22);
  --line:rgba(104,197,237,.14);
  --line-strong:rgba(104,197,237,.28);
  --glass:rgba(10,22,40,.82);
  --glass-strong:rgba(10,22,40,.82);

  /* surface scales (same hue, varying alpha) */
  --glass-40:rgba(10,22,40,.4);
  --glass-50:rgba(10,22,40,.5);
  --glass-55:rgba(10,22,40,.55);
  --glass-60:rgba(10,22,40,.6);
  --glass-75:rgba(10,22,40,.75);
  --glass-80:rgba(10,22,40,.8);
  --glass-94:rgba(10,22,40,.94);
  --midnight-80:rgba(7,16,31,.8);
  --midnight-85:rgba(7,16,31,.85);
  --bg-58:rgba(5,8,14,.58);
  --bg-60:rgba(5,8,14,.6);
  --bg-70:rgba(5,8,14,.7);
  --bg-75:rgba(5,8,14,.75);
  --bg-80:rgba(5,8,14,.8);
  --bg-85:rgba(5,8,14,.85);
  --bg-88:rgba(5,8,14,.88);
  --bg-92:rgba(5,8,14,.92);
  --bg-94:rgba(5,8,14,.94);
  --scrim:rgba(3,6,12,.86);

  /* accent alphas — cyan */
  --accent:var(--cyan);
  --accent-05:rgba(1,229,241,.05);
  --accent-08:rgba(1,229,241,.08);
  --accent-10:rgba(1,229,241,.10);
  --accent-14:rgba(1,229,241,.14);
  --accent-15:rgba(1,229,241,.15);
  --accent-18:rgba(1,229,241,.18);
  --accent-22:rgba(1,229,241,.22);
  --accent-25:rgba(1,229,241,.25);
  --accent-30:rgba(1,229,241,.30);
  --accent-32:rgba(1,229,241,.32);
  --accent-35:rgba(1,229,241,.35);
  --accent-40:rgba(1,229,241,.40);
  --accent-50:rgba(1,229,241,.50);
  --accent-55:rgba(1,229,241,.55);
  --accent-60:rgba(1,229,241,.60);
  --accent-70:rgba(1,229,241,.70);
  --accent-75:rgba(1,229,241,.75);

  /* blue-l family */
  --blue-l-05:rgba(104,197,237,.05);
  --blue-l-06:rgba(104,197,237,.06);
  --blue-l-10:rgba(104,197,237,.10);
  --blue-l-14:rgba(104,197,237,.14);
  --blue-l-18:rgba(104,197,237,.18);
  --blue-l-28:rgba(104,197,237,.28);
  --blue-d-10:rgba(13,157,245,.10);

  --grad:linear-gradient(120deg,#01E5F1 0%,#0D9DF5 55%,#29ABE2 100%);
  --grad-soft:linear-gradient(135deg,rgba(1,229,241,.18),rgba(13,157,245,.10) 60%,transparent);

  --ease:cubic-bezier(.16,1,.3,1);
  --ease2:cubic-bezier(.4,0,.2,1);

  --h-display:'Archivo',ui-sans-serif,system-ui,sans-serif;
  --h-sans:'Inter','Helvetica Neue',system-ui,sans-serif;
  --h-mono:'JetBrains Mono',ui-monospace,monospace;

  color-scheme:dark;
}

/* ───────── LIGHT THEME — "Clinical Tech" ─────────
   Clean whites, deeper teal/blue accents, soft shadows instead of glows.
*/
[data-theme="light"]{
  --cyan:#0891B2;
  --blue-d:#0369A1;
  --blue-m:#0284C7;
  --blue-l:#0369A1;
  --navy:#E8EEF5;
  --midnight:#F1F5FA;
  --bg:#FAFBFD;

  --ink:#0B1220;
  --ink-strong:#05070C;
  --ink-on-accent:#FFFFFF;
  --ink-soft:rgba(11,18,32,.68);
  --ink-mute:rgba(11,18,32,.45);
  --ink-border:rgba(11,18,32,.18);

  --line:rgba(11,18,32,.08);
  --line-strong:rgba(11,18,32,.16);

  --glass:rgba(255,255,255,.82);
  --glass-strong:rgba(255,255,255,.94);
  --glass-40:rgba(240,245,251,.5);
  --glass-50:rgba(240,245,251,.65);
  --glass-55:rgba(240,245,251,.7);
  --glass-60:rgba(240,245,251,.78);
  --glass-75:rgba(240,245,251,.88);
  --glass-80:rgba(240,245,251,.92);
  --glass-94:rgba(248,250,253,.97);
  --midnight-80:rgba(232,238,245,.85);
  --midnight-85:rgba(232,238,245,.92);

  --bg-58:rgba(250,251,253,.7);
  --bg-60:rgba(250,251,253,.72);
  --bg-70:rgba(250,251,253,.8);
  --bg-75:rgba(250,251,253,.85);
  --bg-80:rgba(250,251,253,.88);
  --bg-85:rgba(250,251,253,.92);
  --bg-88:rgba(250,251,253,.94);
  --bg-92:rgba(250,251,253,.96);
  --bg-94:rgba(250,251,253,.98);
  --scrim:rgba(11,18,32,.45);

  --accent:var(--cyan);
  --accent-05:rgba(8,145,178,.05);
  --accent-08:rgba(8,145,178,.08);
  --accent-10:rgba(8,145,178,.12);
  --accent-14:rgba(8,145,178,.14);
  --accent-15:rgba(8,145,178,.15);
  --accent-18:rgba(8,145,178,.18);
  --accent-22:rgba(8,145,178,.22);
  --accent-25:rgba(8,145,178,.24);
  --accent-30:rgba(8,145,178,.3);
  --accent-32:rgba(8,145,178,.32);
  --accent-35:rgba(8,145,178,.38);
  --accent-40:rgba(8,145,178,.45);
  --accent-50:rgba(8,145,178,.55);
  --accent-55:rgba(8,145,178,.6);
  --accent-60:rgba(8,145,178,.68);
  --accent-70:rgba(8,145,178,.8);
  --accent-75:rgba(8,145,178,.85);

  --blue-l-05:rgba(3,105,161,.04);
  --blue-l-06:rgba(3,105,161,.06);
  --blue-l-10:rgba(3,105,161,.1);
  --blue-l-14:rgba(3,105,161,.14);
  --blue-l-18:rgba(3,105,161,.2);
  --blue-l-28:rgba(3,105,161,.3);
  --blue-d-10:rgba(3,105,161,.1);

  --grad:linear-gradient(120deg,#0891B2 0%,#0369A1 55%,#1E40AF 100%);
  --grad-soft:linear-gradient(135deg,rgba(8,145,178,.08),rgba(3,105,161,.05) 60%,transparent);

  color-scheme:light;
}

html{transition:background-color .4s ease,color .4s ease}
body{transition:background-color .4s ease,color .4s ease}

html{scroll-behavior:smooth;font-size:16px}
body{
  font-family:var(--h-sans);
  background:var(--bg);
  color:var(--ink);
  overflow-x:hidden;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  font-feature-settings:"ss01","cv11";
}

::selection{background:var(--accent-30);color:var(--ink-strong)}

img{max-width:100%;display:block}
button{font-family:inherit}

/* ── LAYOUT PRIMITIVES ── */
.container{max-width:1320px;margin:0 auto;padding:0 clamp(1.2rem,4vw,2.4rem)}
section{position:relative;z-index:1}
[data-lang="es"] .en{display:none!important}
[data-lang="en"] .es{display:none!important}

/* ── CANVAS BG ── */
#bg{position:fixed;inset:0;z-index:0;pointer-events:none}
.grain{
  position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.06;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1  0 0 0 0 1  0 0 0 0 1  0 0 0 .6 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
}

/* ─────────────── NAV ─────────────── */
nav#nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:1rem clamp(1.2rem,4vw,2.4rem);
  background:var(--bg-58);
  backdrop-filter:saturate(140%) blur(22px);
  -webkit-backdrop-filter:saturate(140%) blur(22px);
  border-bottom:1px solid transparent;
  transition:background .3s,border-color .3s;
}
nav#nav.scrolled{background:var(--bg-88);border-bottom-color:var(--line)}
.nav-logo{display:inline-block;align-items:center;gap:.6rem;text-decoration:none;color:var(--ink-strong)}
.nav-logo img{width:110px}
.nav-logo img {
  position: absolute;
  top: 1em;
  left: 3em;
   transition: transform 0.4s ease, opacity 0.4s ease;
}



.nav-links{display:flex;align-items:center;gap:2rem;list-style:none}
.nav-links a{
  color:var(--ink-soft);text-decoration:none;font-size:.88rem;font-weight:500;
  letter-spacing:.005em;transition:color .2s;position:relative;
}
.nav-links a::after{
  content:'';position:absolute;left:0;right:0;bottom:-6px;height:1px;
  background:var(--cyan);transform:scaleX(0);transform-origin:left;transition:transform .25s var(--ease);
}
.nav-links a:hover{color:var(--ink-strong)}
.nav-links a:hover::after{transform:scaleX(1)}

.nav-right{display:flex;align-items:center;gap:1rem}

.lang-switch{
  display:flex;align-items:center;gap:.5rem;cursor:pointer;
  font-family:var(--h-mono);font-size:.72rem;font-weight:500;letter-spacing:.08em;
}
.ls-label{color:var(--ink-mute);transition:color .25s;user-select:none}
[data-lang="es"] .ls-label.ls-es,[data-lang="en"] .ls-label.ls-en{color:var(--ink-strong)}
.ls-track{
  width:34px;height:18px;border-radius:10px;position:relative;
  background:var(--accent-14);border:1px solid var(--accent-35);
  transition:background .25s;flex-shrink:0;
}
[data-lang="en"] .ls-track{background:var(--accent-32)}
.ls-thumb{
  position:absolute;top:2px;left:2px;width:12px;height:12px;border-radius:50%;
  background:var(--cyan);box-shadow:0 0 8px var(--accent-70);
  transition:transform .28s var(--ease);
}
[data-lang="en"] .ls-thumb{transform:translateX(16px)}

/* ── BUTTONS ── */
.btn{
  display:inline-flex;align-items:center;gap:.5rem;
  font-family:var(--h-sans);font-weight:600;font-size:.92rem;
  padding:.7rem 1.3rem;border-radius:0;border:1px solid transparent;
  cursor:pointer;text-decoration:none;white-space:nowrap;
  transition:transform .2s var(--ease),box-shadow .25s var(--ease),background .25s,border-color .25s,color .25s;
  position:relative;overflow:hidden;
}
.btn svg{flex-shrink:0}
.btn-primary{
  background:var(--cyan);color:var(--ink-on-accent);
  box-shadow:0 0 0 1px var(--accent-40),0 8px 32px -10px var(--accent-55);
}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 0 0 1px var(--accent-60),0 14px 42px -10px var(--accent-75)}
.btn-primary::after{
  content:'';position:absolute;inset:0;background:linear-gradient(120deg,transparent 0%,rgba(255,255,255,.4) 50%,transparent 100%);
  transform:translateX(-120%);transition:transform .6s var(--ease);
}
.btn-primary:hover::after{transform:translateX(120%)}
.btn-ghost{
  background:transparent;border-color:var(--ink-border);color:var(--ink);
}
.btn-ghost:hover{border-color:var(--cyan);color:var(--cyan)}
.btn-sm{padding:.52rem 1.1rem;font-size:.85rem}

/* ─────────────── HERO ─────────────── */
#hero{
  min-height:92vh;
  padding:140px 0 72px;
  display:flex;align-items:center;
  position:relative;overflow:hidden;
}
.hero-inner{
  display:grid;grid-template-columns:1.15fr .85fr;gap:4rem;align-items:center;
  width:100%;max-width:1320px;margin:0 auto;padding:0 clamp(1.2rem,4vw,2.4rem);
}
.hero-inner.hero-centered{
  display:flex;flex-direction:column;align-items:center;text-align:center;
  max-width:980px;gap:0;
}
.hero-centered .hero-p{max-width:640px;margin-left:auto;margin-right:auto}
.hero-centered .hero-ctas{justify-content:center}
.hero-centered .hero-stats{
  margin:0 auto;max-width:640px;
}

.hero-eyebrow{
  display:inline-flex;align-items:center;gap:.8rem;
  font-family:var(--h-mono);font-size:.72rem;font-weight:500;
  letter-spacing:.14em;text-transform:uppercase;color:var(--blue-l);
  margin-bottom:1.8rem;
}
.hero-eyebrow .line{height:1px;width:48px;background:linear-gradient(90deg,var(--cyan),transparent)}
.hero-eyebrow .dot{
  width:6px;height:6px;border-radius:50%;background:var(--cyan);
  box-shadow:0 0 10px var(--cyan);animation:pulse 2.6s ease-in-out infinite;
}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.28}}
@keyframes wu{
  0%{transform:translateY(105%);opacity:0}
  100%{transform:translateY(0);opacity:1}
}

.hero-h1{
  font-family:var(--h-display);
  font-size:clamp(1.9rem,3.6vw,3.4rem);
  font-weight:700;line-height:1.04;letter-spacing:-.035em;color:var(--ink-strong);
  margin-bottom:1.6rem;
  max-width:16ch;
}
.hero-centered .hero-h1{max-width:22ch;margin-left:auto;margin-right:auto}
.hero-h1 .row{overflow:hidden;display:block}
.hero-h1 .w{
  display:block;transform:translateY(105%);opacity:0;
  animation:wu 1s var(--ease) forwards;
}
.hero-h1 .a1{animation-delay:.10s}
.hero-h1 .a2{animation-delay:.26s}
.hero-h1 .a3{animation-delay:.42s}
.hero-h1 .a4{animation-delay:.58s}

.grad{
  background:var(--grad);
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;
}
.italic-display{font-style:italic;font-weight:400;letter-spacing:-.03em}

.hero-p{
  color:var(--ink-soft);font-size:clamp(1rem,1.15vw,1.1rem);line-height:1.65;
  margin-bottom:2.4rem;max-width:540px;
}

.hero-ctas{display:flex;gap:.8rem;flex-wrap:wrap;align-items:center;margin-bottom:3rem}

.hero-stats{
  display:grid;grid-template-columns:repeat(3,1fr);gap:0;
  border-top:1px solid var(--line);padding-top:1.6rem;max-width:580px;
}
.hero-stat{position:relative;padding-right:1rem}
.hero-stat + .hero-stat{padding-left:1.2rem;border-left:1px solid var(--line)}
.hero-stat strong{
  display:block;
  font-family:var(--h-display);font-weight:700;
  font-size:clamp(2rem,3vw,2.7rem);line-height:1;letter-spacing:-.03em;
  color:var(--ink-strong);margin-bottom:.45rem;
}
.hero-stat strong span.accent,
.hero-stat strong .accent{
  color:var(--cyan)!important;
  font-size:inherit!important;
  font-family:inherit!important;
  font-weight:inherit!important;
  line-height:inherit!important;
  letter-spacing:inherit!important;
  text-transform:none!important;
}
.hero-stat > span{
  font-family:var(--h-mono);font-size:.78rem;
  color:var(--ink-mute);letter-spacing:.08em;text-transform:uppercase;line-height:1.35;
  display:block;
}

/* ─── HERO ANIMATION — From Chaos to Database ─── */
.hero-anim{
  position:relative;aspect-ratio:1/1;max-width:540px;width:100%;margin-left:auto;
}
.ha-frame{
  position:absolute;inset:0;
  background:linear-gradient(160deg,var(--glass-50),var(--midnight-85));
  border:1px solid var(--line);
  overflow:hidden;
  display:flex;flex-direction:column;
}
.ha-frame::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--cyan),transparent);
  opacity:.5;
}

/* top tag */
.ha-tag{
  position:absolute;top:.9rem;left:.9rem;z-index:5;
  display:flex;align-items:center;gap:.5rem;
  background:var(--bg-80);border:1px solid var(--line-strong);
  padding:.35rem .7rem;
  font-family:var(--h-mono);font-size:.66rem;letter-spacing:.12em;
  text-transform:uppercase;color:var(--cyan);
}
.ha-tag .dot{width:5px;height:5px;border-radius:50%;background:var(--cyan);box-shadow:0 0 8px var(--cyan);animation:pulse 1.8s ease-in-out infinite}

/* timeline pips top-right */
.ha-timeline{
  position:absolute;top:.9rem;right:.9rem;z-index:5;
  display:flex;gap:.3rem;
}
.ha-tl-step{
  width:38px;height:20px;
  border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--h-mono);font-size:.56rem;color:var(--ink-mute);
  letter-spacing:.08em;
  transition:all .4s var(--ease);
}
.ha-tl-step em{display:none}
.ha-tl-step.active{
  background:var(--accent-18);border-color:var(--cyan);color:var(--cyan);
}

/* stage */
.ha-stage{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
}

/* ─ Phase 1: files ─ */
.ha-files{position:absolute;inset:0;pointer-events:none}
.ha-file{
  position:absolute;
  width:26%;aspect-ratio:.78/1;
  background:var(--glass-94);
  border:1px solid var(--line-strong);
  padding:.55rem .55rem .4rem;
  font-family:var(--h-mono);font-size:.56rem;color:var(--ink-soft);
  box-shadow:0 10px 30px rgba(0,0,0,.6);
  opacity:0;
  display:flex;flex-direction:column;gap:.3rem;
  transition:opacity .5s var(--ease),transform .7s var(--ease);
}
.ha-file-ext{
  color:var(--cyan);font-weight:600;letter-spacing:.12em;
  font-size:.54rem;
}
.ha-file-name{
  color:var(--ink);font-size:.62rem;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
.ha-file-grid{
  flex:1;margin-top:.2rem;
  background-image:
    linear-gradient(to right,var(--blue-l-18) 1px,transparent 1px),
    linear-gradient(to bottom,var(--blue-l-18) 1px,transparent 1px);
  background-size:22% 18%;
}
.ha-file.f1{top:14%;left:8%;transform:rotate(-10deg)}
.ha-file.f2{top:20%;right:10%;transform:rotate(12deg)}
.ha-file.f3{bottom:18%;left:12%;transform:rotate(-6deg)}
.ha-file.f4{bottom:14%;right:14%;transform:rotate(8deg)}
.ha-file.f5{top:42%;left:38%;transform:rotate(-3deg);z-index:2}

.phase-0 .ha-file{opacity:1}
.phase-0 .ha-file.f1{animation:float1 4s ease-in-out infinite}
.phase-0 .ha-file.f2{animation:float2 5s ease-in-out infinite}
.phase-0 .ha-file.f3{animation:float1 4.5s ease-in-out infinite reverse}
.phase-0 .ha-file.f4{animation:float2 5.5s ease-in-out infinite reverse}
.phase-0 .ha-file.f5{animation:float1 4.2s ease-in-out infinite}
@keyframes float1{0%,100%{translate:0 0}50%{translate:0 -6px}}
@keyframes float2{0%,100%{translate:0 0}50%{translate:0 4px}}

/* Phase 1 — files converging/breaking */
.phase-1 .ha-file{
  opacity:.35;
  transform:translate(var(--tx,0),var(--ty,0)) rotate(0deg) scale(.7);
  filter:blur(2px);
}
.phase-1 .ha-file.f1{--tx:28%;--ty:24%}
.phase-1 .ha-file.f2{--tx:-28%;--ty:20%}
.phase-1 .ha-file.f3{--tx:26%;--ty:-20%}
.phase-1 .ha-file.f4{--tx:-22%;--ty:-18%}
.phase-1 .ha-file.f5{--tx:0;--ty:0;opacity:0}

.phase-2 .ha-file,.phase-3 .ha-file{opacity:0;transform:scale(0);transition:all .4s}

/* ─ Cells (Phase 1-2) ─ */
.ha-cells{position:absolute;inset:0;pointer-events:none;opacity:0;transition:opacity .3s}
.phase-1 .ha-cells,.phase-2 .ha-cells{opacity:1}
.ha-cell{
  position:absolute;
  width:14px;height:10px;
  background:var(--accent-22);
  border:1px solid var(--accent-50);
  top:50%;left:50%;
  transform:translate(var(--sx),var(--sy)) scale(0);
  animation:cellFly 1.4s var(--ease) forwards;
  animation-delay:var(--delay,0s);
}
@keyframes cellFly{
  0%{transform:translate(var(--sx),var(--sy)) scale(0);opacity:0}
  15%{opacity:1;transform:translate(var(--sx),var(--sy)) scale(1)}
  70%{opacity:1;transform:translate(calc(var(--sx)*.15),calc(var(--sy)*.15)) scale(.9)}
  100%{opacity:.8;transform:translate(-50%,-50%) scale(.6)}
}

/* ─ Core glow ─ */
.ha-core{
  position:absolute;top:50%;left:50%;
  width:40px;height:40px;border-radius:50%;
  transform:translate(-50%,-50%) scale(0);
  background:radial-gradient(circle,var(--cyan),transparent 65%);
  filter:blur(8px);
  opacity:0;
  transition:all .5s var(--ease);
}
.phase-1 .ha-core,.phase-2 .ha-core{opacity:.8;transform:translate(-50%,-50%) scale(1)}
.phase-3 .ha-core{opacity:0;transform:translate(-50%,-50%) scale(2.5)}

/* ─ Phase 3: table ─ */
.ha-table{
  position:relative;z-index:3;
  width:84%;max-height:68%;
  background:var(--bg-94);
  border:1px solid var(--line-strong);
  font-family:var(--h-mono);font-size:.6rem;
  opacity:0;transform:scale(.9) translateY(10px);
  transition:opacity .5s var(--ease),transform .6s var(--ease);
  overflow:hidden;
}
.phase-2 .ha-table{opacity:.3;transform:scale(.95)}
.phase-3 .ha-table{opacity:1;transform:scale(1) translateY(0)}
.ha-table-head{
  display:grid;grid-template-columns:.55fr 1.5fr .9fr .85fr;gap:.5rem;
  background:var(--grad);color:var(--ink-on-accent);
  padding:.45rem .7rem;font-weight:600;letter-spacing:.1em;
  text-transform:uppercase;font-size:.52rem;
}
.ha-table-body{position:relative}
.ha-row{
  display:grid;grid-template-columns:.55fr 1.5fr .9fr .85fr;gap:.5rem;
  padding:.4rem .7rem;
  border-bottom:1px solid var(--blue-l-10);
  color:var(--ink-soft);
  opacity:0;transform:translateX(-10px);
  animation:rowIn .3s var(--ease) forwards;
}
.ha-row:last-child{border-bottom:none}
.ha-row > div{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ha-row > div:first-child{color:var(--cyan)}
@keyframes rowIn{to{opacity:1;transform:translateX(0)}}

/* scan line */
.ha-scan{
  position:absolute;left:0;right:0;top:0;height:2px;
  background:linear-gradient(90deg,transparent,var(--cyan),transparent);
  box-shadow:0 0 12px var(--cyan);
  opacity:0;pointer-events:none;
}
.phase-3 .ha-scan{opacity:1;animation:scan 2.5s linear infinite}
@keyframes scan{0%{top:0}100%{top:100%}}

/* bottom status bar */
.ha-status{
  position:absolute;bottom:0;left:0;right:0;z-index:5;
  display:flex;align-items:center;gap:.8rem;
  padding:.55rem .9rem;
  background:var(--bg-92);
  border-top:1px solid var(--line);
}
.ha-status-left{display:flex;align-items:center;gap:.4rem}
.ha-dot{width:5px;height:5px;border-radius:50%;background:var(--cyan);box-shadow:0 0 6px var(--cyan);animation:pulse 1.5s ease-in-out infinite}
.ha-mono{font-family:var(--h-mono);font-size:.6rem;color:var(--ink-mute);letter-spacing:.12em;text-transform:uppercase}
.ha-progress{flex:1;height:2px;background:var(--blue-l-14);position:relative;overflow:hidden}
.ha-progress-fill{position:absolute;inset:0 100% 0 0;background:var(--grad);transition:right .4s linear}
.ha-status-right{color:var(--cyan);min-width:42px;text-align:right}

/* ─── MARQUEE ─── */
.mq{
  padding:1.2rem 0;overflow:hidden;position:relative;z-index:2;
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  background:var(--bg-60);
}
.mq::before,.mq::after{
  content:'';position:absolute;top:0;bottom:0;width:120px;z-index:2;pointer-events:none;
}
.mq::before{left:0;background:linear-gradient(90deg,var(--bg),transparent)}
.mq::after{right:0;background:linear-gradient(-90deg,var(--bg),transparent)}
.mq-track{
  display:flex;gap:3rem;width:max-content;
  animation:mq 44s linear infinite;white-space:nowrap;
}
.mq-item{
  display:flex;align-items:center;gap:.7rem;
  font-family:var(--h-mono);font-size:.78rem;font-weight:500;
  color:var(--ink-mute);letter-spacing:.12em;text-transform:uppercase;
}
.mq-item .sep{width:5px;height:5px;background:var(--cyan);border-radius:50%;flex-shrink:0}
@keyframes mq{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ─── SECTION HEADING ─── */
.sec-head{margin-bottom:3.5rem}
.sec-head.center{text-align:center;max-width:820px;margin-left:auto;margin-right:auto}

.sec-num{
  font-family:var(--h-mono);font-size:.9rem;font-weight:500;
  color:var(--cyan);letter-spacing:.18em;text-transform:uppercase;
  display:inline-flex;align-items:center;gap:.8rem;margin-bottom:1.4rem;
}
.sec-num::before{content:'';width:36px;height:1px;background:var(--cyan)}

.sec-h2{
  font-family:var(--h-display);
  font-size:clamp(1.85rem,3.3vw,2.95rem);
  font-weight:700;letter-spacing:-.028em;color:var(--ink-strong);
  line-height:1.08;margin-bottom:1.1rem;
}
.sec-h2 em{font-style:italic;font-weight:400;color:var(--blue-l)}

.sec-p{
  color:var(--ink-soft);font-size:clamp(1.08rem,1.2vw,1.18rem);
  line-height:1.7;max-width:640px;
}
.sec-head.center .sec-p{margin-left:auto;margin-right:auto}

/* ── REVEAL ── */
.rv,.rvl,.rvr{opacity:0;transition:opacity .9s var(--ease),transform .9s var(--ease)}
.rv{transform:translateY(36px)}
.rvl{transform:translateX(-40px)}
.rvr{transform:translateX(40px)}
.rv.visible,.rvl.visible,.rvr.visible{opacity:1;transform:none}

/* ─── PROBLEM ─── */
#problem{padding:8rem 0 5rem}
.prob-grid{
  display:grid;grid-template-columns:repeat(12,1fr);gap:1px;
  background:var(--line);
  border:1px solid var(--line);
}
.prob-card{
  background:var(--bg);
  padding:2.4rem 2rem;
  position:relative;overflow:hidden;
  transition:background .3s;
}
.prob-card:nth-child(1){grid-column:span 7}
.prob-card:nth-child(2){grid-column:span 5}
.prob-card:nth-child(3){grid-column:span 5}
.prob-card:nth-child(4){grid-column:span 7}
.prob-card:hover{background:var(--glass-55)}
.prob-card::before{
  content:'';position:absolute;top:0;left:0;width:0;height:2px;
  background:var(--grad);transition:width .5s var(--ease);
}
.prob-card:hover::before{width:100%}

.prob-index{
  font-family:var(--h-mono);font-size:.7rem;color:var(--cyan);
  letter-spacing:.14em;margin-bottom:1.2rem;display:block;
}
.prob-card h3{
  font-family:var(--h-display);font-size:1.4rem;font-weight:600;letter-spacing:-.02em;
  color:var(--ink-strong);margin-bottom:.7rem;line-height:1.15;
}
.prob-card p{font-size:.95rem;color:var(--ink-soft);line-height:1.65;max-width:52ch}
.prob-icon{
  width:44px;height:44px;margin-bottom:1.4rem;
  border:1px solid var(--line-strong);
  display:flex;align-items:center;justify-content:center;
  color:var(--cyan);
}
.prob-icon svg{width:22px;height:22px;fill:none;stroke:currentColor;stroke-width:1.6}

/* ─── BRIDGE ─── */
#bridge{
  padding:10rem 0;text-align:center;position:relative;overflow:hidden;
}
#bridge::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse at center,var(--accent-08),transparent 55%);
  pointer-events:none;
}
.bridge-mark{
  font-family:var(--h-display);font-size:6rem;line-height:1;color:var(--cyan);
  opacity:.6;margin-bottom:1.4rem;
}
.bridge-quote{
  font-family:var(--h-display);font-weight:400;
  font-size:clamp(1.3rem,2.3vw,2rem);
  line-height:1.25;color:var(--ink-strong);max-width:780px;margin:0 auto;
  letter-spacing:-.018em;
}
.bridge-quote em{
  font-style:italic;font-weight:400;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;
}
.bridge-line{
  width:1px;height:72px;background:linear-gradient(180deg,var(--cyan),transparent);
  margin:2rem auto 0;
}

/* ─── SOLUTION FLOW ─── */
#solution{padding:6rem 0}
.sol-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:1px;
  background:var(--line);border:1px solid var(--line);
  margin-top:3.5rem;
}
.sol-step{
  background:var(--bg);padding:2.4rem 1.8rem;position:relative;
  transition:background .3s;
}
.sol-step:hover{background:var(--glass-55)}
.sol-num{
  font-family:var(--h-mono);font-size:.74rem;font-weight:500;
  color:var(--cyan);letter-spacing:.16em;margin-bottom:2rem;
  display:flex;align-items:center;justify-content:space-between;
}
.sol-num .arrow{color:var(--ink-mute);font-size:1rem}
.sol-step h3{
  font-family:var(--h-display);font-weight:600;
  font-size:1.35rem;letter-spacing:-.02em;color:var(--ink-strong);margin-bottom:.6rem;
}
.sol-step p{font-size:.92rem;color:var(--ink-soft);line-height:1.6}
.sol-icon{
  width:44px;height:44px;margin-bottom:1.4rem;
  color:var(--cyan);
}
.sol-icon svg{width:100%;height:100%;stroke:currentColor;fill:none;stroke-width:1.5}

/* ─── FEATURES / TABS ─── */
#features{padding:8rem 0}
.tab-nav{
  display:grid;grid-template-columns:1fr 1fr;gap:0;
  border:1px solid var(--line);
  margin:3rem 0;
}
.tab-btn{
  display:flex;align-items:flex-start;gap:1.2rem;
  padding:1.8rem 1.6rem;border:none;background:transparent;
  color:var(--ink-soft);cursor:pointer;text-align:left;
  position:relative;overflow:hidden;transition:background .25s;
}
.tab-btn + .tab-btn{border-left:1px solid var(--line)}
.tab-btn::before{
  content:'';position:absolute;bottom:0;left:0;height:2px;width:0;
  background:var(--grad);transition:width .4s var(--ease);
}
.tab-btn:hover{background:var(--glass-40)}
.tab-btn.active{background:var(--glass-60);color:var(--ink-strong)}
.tab-btn.active::before{width:100%}

.tab-ico{
  width:44px;height:44px;flex-shrink:0;
  border:1px solid var(--line-strong);color:var(--cyan);
  display:flex;align-items:center;justify-content:center;
}
.tab-ico svg{width:22px;height:22px;fill:none;stroke:currentColor;stroke-width:1.6}
.tab-btn.active .tab-ico{background:var(--accent-14)}
.tab-body{flex:1;display:flex;flex-direction:column;gap:.35rem}
.tab-body strong{
  font-family:var(--h-display);font-weight:600;font-size:1.1rem;
  letter-spacing:-.01em;color:var(--ink-strong);display:block;
}
.tab-body .desc{font-size:.88rem;line-height:1.5;color:var(--ink-soft)}
.tab-body .cta{
  font-family:var(--h-mono);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;
  color:var(--cyan);display:inline-flex;align-items:center;gap:.4rem;margin-top:.4rem;
  opacity:.6;transition:opacity .2s;
}
.tab-btn.active .tab-body .cta{opacity:1}

.tab-panel{display:none}
.tab-panel.active{display:grid}
.feat-grid{grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.feat-card{
  background:var(--bg);padding:2rem 1.8rem;
  transition:background .3s;position:relative;
}
.feat-card:hover{background:var(--glass-55)}
.feat-card .num{
  font-family:var(--h-mono);font-size:.68rem;color:var(--ink-mute);
  letter-spacing:.14em;margin-bottom:1.2rem;display:block;
}
.feat-ico{
  width:40px;height:40px;margin-bottom:1.2rem;color:var(--cyan);
}
.feat-ico svg{width:100%;height:100%;fill:none;stroke:currentColor;stroke-width:1.6}
.feat-card h4{
  font-family:var(--h-display);font-weight:600;font-size:1.15rem;
  letter-spacing:-.01em;color:var(--ink-strong);margin-bottom:.5rem;line-height:1.2;
}
.feat-card p{font-size:.9rem;color:var(--ink-soft);line-height:1.62}

/* ─── GOVERNANCE ─── */
#governance{padding:6rem 0}
.gov-grid{
  display:grid;grid-template-columns:1.1fr .9fr;gap:3rem;
  border:1px solid var(--line);
  background:linear-gradient(135deg,var(--glass-55),var(--midnight-80));
  padding:3rem;position:relative;overflow:hidden;
}
.gov-grid::before{
  content:'';position:absolute;top:-100px;right:-100px;width:360px;height:360px;
  background:radial-gradient(circle,var(--accent-15),transparent 70%);
  pointer-events:none;
}
.gov-list{list-style:none;margin-top:2rem}
.gov-list li{
  display:flex;align-items:flex-start;gap:.9rem;
  padding:1rem 0;border-bottom:1px solid var(--line);
  font-size:.95rem;color:var(--ink-soft);line-height:1.5;
}
.gov-list li:last-child{border-bottom:none}
.gov-check{
  width:22px;height:22px;flex-shrink:0;
  border:1px solid var(--cyan);color:var(--cyan);
  display:flex;align-items:center;justify-content:center;margin-top:1px;
}
.gov-check svg{width:10px;height:10px;fill:none;stroke:currentColor;stroke-width:2.4}

.gov-right{display:flex;flex-direction:column;gap:1rem;position:relative;z-index:1}
.gov-certs{display:grid;grid-template-columns:1fr 1fr;gap:.6rem}
.gov-cert{
  background:var(--bg-75);border:1px solid var(--line);
  padding:1rem;display:flex;align-items:center;gap:.8rem;
  transition:border-color .25s,background .25s;
}
.gov-cert:hover{border-color:var(--line-strong);background:var(--glass-80)}
.gov-cert-ico{
  width:36px;height:36px;border:1px solid var(--line-strong);color:var(--cyan);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.gov-cert-ico svg{width:18px;height:18px;fill:none;stroke:currentColor;stroke-width:1.6}
.gov-cert strong{
  display:block;font-family:var(--h-display);font-weight:600;font-size:.95rem;color:var(--ink-strong);
  letter-spacing:-.01em;
}
.gov-cert span{
  font-family:var(--h-mono);font-size:.68rem;color:var(--blue-l);letter-spacing:.08em;
}

.gov-audit{
  background:var(--bg-85);border:1px solid var(--line);overflow:hidden;
}
.gov-audit-head{
  display:flex;align-items:center;gap:.6rem;
  padding:.8rem 1rem;border-bottom:1px solid var(--line);
  background:var(--accent-05);
}
.gov-audit-head .live{width:7px;height:7px;border-radius:50%;background:var(--cyan);box-shadow:0 0 10px var(--cyan);animation:pulse 2s ease-in-out infinite;flex-shrink:0}
.gov-audit-head span{font-family:var(--h-mono);font-size:.7rem;color:var(--ink-soft);letter-spacing:.14em;text-transform:uppercase}
.gov-feed{padding:.4rem 0;min-height:148px;max-height:148px;overflow:hidden}
.log-entry{
  display:flex;align-items:baseline;gap:.7rem;padding:.32rem 1rem;
  font-family:var(--h-mono);font-size:.72rem;
  border-bottom:1px solid var(--blue-l-06);
  animation:logIn .4s ease forwards;
}
@keyframes logIn{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}
.log-time{color:var(--ink-mute);flex-shrink:0}
.log-user{color:var(--blue-l);flex-shrink:0}
.log-act{color:var(--ink-soft);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* ─── INDUSTRIES ─── */
#industries{padding:6rem 0}
.ind-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1px;
  background:var(--line);border:1px solid var(--line);margin-top:3.5rem;
}
.ind-card{
  background:var(--bg);padding:2.2rem 1.8rem;
  position:relative;overflow:hidden;transition:background .3s;
  min-height:260px;display:flex;flex-direction:column;justify-content:space-between;
}
.ind-card:hover{background:var(--glass-60)}
.ind-ico{
  width:44px;height:44px;color:var(--cyan);margin-bottom:1rem;
}
.ind-ico svg{width:100%;height:100%;fill:none;stroke:currentColor;stroke-width:1.5}
.ind-card h4{
  font-family:var(--h-display);font-weight:600;font-size:1.2rem;letter-spacing:-.015em;
  color:var(--ink-strong);margin-bottom:.6rem;
}
.ind-card p{font-size:.9rem;color:var(--ink-soft);line-height:1.6}
.ind-tag{
  font-family:var(--h-mono);font-size:.65rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--ink-mute);margin-top:1rem;
}

/* ─── CTA MID ─── */
#cta-mid{
  padding:6rem 0;text-align:center;position:relative;overflow:hidden;
}
#cta-mid::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 50% 60% at 50% 50%,var(--accent-08),transparent 70%);
}

/* ─── PRICING ─── */
#pricing{padding:8rem 0}
.pt-wrap{display:flex;align-items:center;justify-content:center;gap:1rem;margin:2rem 0 3rem}
.pt-label{font-family:var(--h-mono);font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-mute);font-weight:500}
.pt-label.active{color:var(--ink-strong)}
.pt-track{
  width:44px;height:22px;border-radius:12px;cursor:pointer;
  background:var(--accent-18);border:1px solid var(--accent-40);
  position:relative;transition:background .25s;flex-shrink:0;
}
.pt-track.on{background:var(--accent-40)}
.pt-thumb{
  position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;
  background:var(--cyan);box-shadow:0 0 10px var(--accent-70);
  transition:transform .3s var(--ease);
}
.pt-track.on .pt-thumb{transform:translateX(22px)}
.pt-save{
  font-family:var(--h-mono);font-size:.68rem;letter-spacing:.12em;font-weight:600;
  background:var(--accent-14);border:1px solid var(--line-strong);
  color:var(--cyan);padding:.22rem .6rem;
}

.pricing-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:1px;
  background:var(--line);border:1px solid var(--line);
}
.price-card{
  background:var(--bg);padding:2.4rem 1.8rem;
  position:relative;display:flex;flex-direction:column;
  transition:background .3s;
}
.price-card:hover{background:var(--glass-50)}
.price-card.featured{
  background:linear-gradient(180deg,var(--accent-10),var(--glass-75));
  box-shadow:inset 0 0 0 1px var(--line-strong);
}
.price-badge{
  position:absolute;top:0;left:1.8rem;transform:translateY(-50%);
  background:var(--cyan);color:var(--ink-on-accent);
  font-family:var(--h-mono);font-size:.66rem;font-weight:700;letter-spacing:.14em;
  padding:.3rem .8rem;
}
.price-tier{
  font-family:var(--h-mono);font-size:.74rem;font-weight:600;letter-spacing:.16em;
  text-transform:uppercase;color:var(--blue-l);margin-bottom:1.6rem;
}
.price-amount{
  font-family:var(--h-display);font-size:3.4rem;font-weight:700;
  letter-spacing:-.04em;color:var(--ink-strong);line-height:1;margin-bottom:.3rem;
  display:flex;align-items:flex-start;gap:.1rem;
}
.price-amount sup{font-size:1.2rem;margin-top:.6rem;color:var(--ink-soft);font-weight:500}
.price-amount .pa-num{transition:opacity .2s}
.price-period{
  font-family:var(--h-sans);font-size:.92rem;font-weight:400;
  color:var(--ink-mute);align-self:flex-end;margin-bottom:.5rem;
}
.price-custom{
  font-family:var(--h-display);font-size:2rem;font-weight:600;
  letter-spacing:-.02em;color:var(--ink-strong);margin-bottom:.6rem;
}
.price-desc{font-size:.88rem;color:var(--ink-soft);line-height:1.55;margin:.6rem 0 1.6rem}
.price-divider{height:1px;background:var(--line);margin:1.2rem 0}
.price-features{list-style:none;flex:1}
.price-features li{
  display:flex;align-items:flex-start;gap:.6rem;
  font-size:.88rem;color:var(--ink-soft);padding:.42rem 0;line-height:1.45;
}
.pf-check{width:14px;height:14px;flex-shrink:0;color:var(--cyan);margin-top:3px}
.price-cta{
  margin-top:1.8rem;padding:.8rem 1rem;border-radius:0;border:1px solid var(--line-strong);
  background:transparent;color:var(--ink);font-family:var(--h-sans);
  font-weight:600;font-size:.9rem;cursor:pointer;
  transition:background .25s,color .25s,border-color .25s;
}
.price-cta:hover,.price-card.featured .price-cta{background:var(--cyan);color:var(--ink-on-accent);border-color:var(--cyan)}

/* ─── FAQ ─── */
#faq{padding:7rem 0}
.faq-list{max-width:860px;margin:3rem auto 0;border-top:1px solid var(--line)}
.faq-item{border-bottom:1px solid var(--line)}
.faq-q{
  width:100%;background:none;border:none;color:var(--ink-strong);
  font-family:var(--h-display);font-size:1.15rem;font-weight:500;letter-spacing:-.01em;
  text-align:left;padding:1.6rem 0;cursor:pointer;
  display:flex;justify-content:space-between;align-items:center;gap:1rem;
  transition:color .2s;
  min-height:calc(1.6rem * 2 + 1.15rem * 1.4); /* stable height across ES/EN */
}
.faq-q > span:not(.faq-icon){flex:1;min-width:0;line-height:1.4}
.faq-q:hover{color:var(--blue-l)}
.faq-icon{
  width:26px;height:26px;flex-shrink:0;border:1px solid var(--line-strong);
  color:var(--cyan);display:flex;align-items:center;justify-content:center;
  font-family:var(--h-mono);font-size:.9rem;transition:transform .35s var(--ease),background .25s;
}
.faq-item.open .faq-icon{transform:rotate(45deg);background:var(--accent-14)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .5s var(--ease)}
.faq-a-inner{padding:0 0 1.6rem;color:var(--ink-soft);font-size:.98rem;line-height:1.72;max-width:72ch}

/* ─── PARTNERS ─── */
#partners{padding:6rem 0}
.partners-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-top:3rem}
.partner-card{
  background:var(--glass);border:1px solid var(--line);
  padding:2.2rem;display:flex;gap:1.6rem;align-items:flex-start;
  transition:border-color .3s,background .3s;
}
.partner-card:hover{border-color:var(--line-strong);background:var(--glass-75)}
.partner-logo{
  
  width:80px;height:80px;flex-shrink:0;
  border:1px solid var(--line-strong);background:var(--bg-60);
  display:flex;align-items:center;justify-content:center;text-align:center;padding:.1rem;
  font-family:var(--h-display);font-weight:700;color:var(--ink-strong);
}
.partner-logo img{
  position: absolute;
  width: 4.5rem;
    /* margin-top: 1em; */
  transition: transform 0.4s ease, opacity 0.4s ease;
}
.partner-body h4{
  font-family:var(--h-display);font-weight:600;font-size:1.25rem;letter-spacing:-.02em;
  color:var(--ink-strong);margin-bottom:.6rem;
}
.partner-body p{font-size:.92rem;color:var(--ink-soft);line-height:1.62;margin-bottom:1rem}
.partner-tag{
  font-family:var(--h-mono);font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--cyan);border:1px solid var(--line-strong);padding:.25rem .7rem;
  display:inline-block;
}

/* ─── CTA FINAL ─── */
#cta-final{padding:9rem 0;text-align:center;position:relative;overflow:hidden}
.cta-glow{
  position:absolute;top:50%;left:50%;width:700px;height:380px;
  transform:translate(-50%,-50%);pointer-events:none;
  background:radial-gradient(ellipse,var(--accent-18),transparent 65%);z-index:0;
}
#cta-final .container{position:relative;z-index:1}

/* ─── FOOTER ─── */
footer{padding:4rem 0 2rem;border-top:1px solid var(--line);position:relative;z-index:1}
.footer-top{
  display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:3rem;margin-bottom:3rem;
}
.footer-brand img{height:60px;width:auto;margin-bottom:1rem}
.footer-brand p{font-size:.9rem;color:var(--ink-soft);line-height:1.65;margin-bottom:1.2rem;max-width:34ch}
.social-links{display:flex;gap:.6rem}
.social-link{
  width:36px;height:36px;border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;
  color:var(--ink-soft);text-decoration:none;transition:all .2s;
}
.social-link:hover{border-color:var(--cyan);color:var(--cyan)}
.footer-col h5{
  font-family:var(--h-mono);font-size:.72rem;font-weight:600;color:var(--ink-strong);
  margin-bottom:1.1rem;letter-spacing:.16em;text-transform:uppercase;
}
.footer-col ul{list-style:none}
.footer-col ul li{margin-bottom:.55rem}
.footer-col ul li a{font-size:.9rem;color:var(--ink-soft);text-decoration:none;transition:color .2s}
.footer-col ul li a:hover{color:var(--cyan)}
.footer-bottom{
  border-top:1px solid var(--line);padding-top:1.4rem;
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;
  font-family:var(--h-mono);font-size:.72rem;color:var(--ink-mute);letter-spacing:.08em;
}
.footer-bottom a{color:var(--ink-mute);text-decoration:none;transition:color .2s}
.footer-bottom a:hover{color:var(--cyan)}
.footer-bottom .lnks{display:flex;gap:1.5rem;flex-wrap:wrap}

/* ─── MODAL ─── */
.modal-overlay{
  position:fixed;inset:0;z-index:200;
  background:var(--scrim);backdrop-filter:blur(14px);
  display:flex;align-items:center;justify-content:center;padding:1.5rem;
  opacity:0;pointer-events:none;transition:opacity .3s;
}
.modal-overlay.open{opacity:1;pointer-events:all}
.modal{
  background:var(--navy);border:1px solid var(--line-strong);
  padding:2.6rem;width:100%;max-width:560px;position:relative;
  transform:translateY(28px);transition:transform .35s var(--ease);
}
.modal-overlay.open .modal{transform:translateY(0)}
.modal-close{
  position:absolute;top:1.2rem;right:1.2rem;width:34px;height:34px;
  border:1px solid var(--line);background:transparent;
  color:var(--ink-soft);cursor:pointer;font-size:1rem;
  display:flex;align-items:center;justify-content:center;transition:all .2s;
}
.modal-close:hover{border-color:var(--cyan);color:var(--cyan)}
.modal h2{
  font-family:var(--h-display);font-size:1.6rem;font-weight:700;letter-spacing:-.02em;
  color:var(--ink-strong);margin-bottom:.4rem;
}
.modal > p{font-size:.95rem;color:var(--ink-soft);margin-bottom:1.8rem;line-height:1.6}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form-group{margin-bottom:1.1rem}
.form-group label{
  display:block;font-family:var(--h-mono);font-size:.68rem;font-weight:500;
  color:var(--ink-soft);margin-bottom:.5rem;letter-spacing:.12em;text-transform:uppercase;
}
.form-group input,.form-group select,.form-group textarea{
  width:100%;background:var(--bg-70);border:1px solid var(--line);
  padding:.72rem 1rem;color:var(--ink-strong);font-size:.93rem;font-family:var(--h-sans);
  transition:border-color .2s;outline:none;
}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--cyan)}
.form-group select option{background:var(--navy);color:var(--ink-strong)}
.form-group textarea{resize:vertical;min-height:92px}
.form-submit{
  width:100%;padding:.82rem;border:none;background:var(--cyan);color:var(--ink-on-accent);
  font-family:var(--h-sans);font-size:.98rem;font-weight:600;cursor:pointer;
  margin-top:.4rem;transition:background .2s,transform .2s;letter-spacing:.01em;
}
.form-submit:hover{background:var(--ink-strong);transform:translateY(-1px)}

/* ─── RESPONSIVE ─── */
@media(max-width:1100px){
  .hero-inner{grid-template-columns:1fr;gap:3rem}
  .hero-anim{margin:0 auto;max-width:420px}
  .pricing-grid{grid-template-columns:repeat(2,1fr)}
  .prob-card:nth-child(n){grid-column:span 12}
  .prob-card{border-bottom:1px solid var(--line)}
  .sol-grid{grid-template-columns:repeat(2,1fr)}
  .feat-grid{grid-template-columns:repeat(2,1fr)}
  .ind-grid{grid-template-columns:repeat(2,1fr)}
  .footer-top{grid-template-columns:1fr 1fr}
}
@media(max-width:680px){
  .nav-links{display:none}
  .hero-stats{grid-template-columns:1fr;gap:1rem}
  .hero-stat + .hero-stat{border-left:none;border-top:1px solid var(--line);padding-left:0;padding-top:1rem}
  .sol-grid,.feat-grid,.ind-grid,.pricing-grid{grid-template-columns:1fr}
  .gov-grid{grid-template-columns:1fr;padding:1.8rem}
  .tab-nav{grid-template-columns:1fr}
  .tab-btn + .tab-btn{border-left:none;border-top:1px solid var(--line)}
  .partners-grid{grid-template-columns:1fr}
  .partner-card{flex-direction:column}
  .footer-top{grid-template-columns:1fr 1fr;gap:2rem}
  #hero{padding-top:110px}
  .form-row{grid-template-columns:1fr}
}

/* ─── TWEAKS PANEL ─── */
.tweaks-panel{
  position:fixed;right:18px;bottom:18px;z-index:99999;
  width:280px;background:var(--bg-94);
  border:1px solid var(--line-strong);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  font-family:var(--h-display);color:var(--ink);
  box-shadow:0 20px 60px rgba(0,0,0,.6),0 0 0 1px var(--accent-08) inset;
  animation:tkIn .3s var(--ease);
}
@keyframes tkIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
.tweaks-panel[hidden]{display:none}
.tk-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:.7rem .9rem;border-bottom:1px solid var(--line);
  font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--cyan);
  font-family:var(--h-mono);
}
.tk-close{
  background:none;border:none;color:var(--ink-soft);font-size:1.3rem;
  cursor:pointer;line-height:1;padding:0 .2rem;transition:color .2s;
}
.tk-close:hover{color:var(--cyan)}
.tk-body{padding:.9rem}
.tk-row + .tk-row{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--line)}
.tk-label{
  display:block;font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--ink-mute);font-family:var(--h-mono);margin-bottom:.5rem;
}
.tk-seg{
  display:grid;grid-template-columns:1fr 1fr;gap:0;
  border:1px solid var(--line-strong);border-radius:2px;overflow:hidden;
}
.tk-seg button{
  background:transparent;border:none;color:var(--ink-soft);
  padding:.55rem .5rem;font-family:var(--h-display);font-size:.78rem;font-weight:500;
  cursor:pointer;transition:all .2s;letter-spacing:.02em;
}
.tk-seg button + button{border-left:1px solid var(--line-strong)}
.tk-seg button:hover{color:var(--ink);background:var(--blue-l-05)}
.tk-seg button.is-active{
  background:var(--grad);color:var(--ink-on-accent);font-weight:600;
}
.tk-hint{
  font-size:.7rem;color:var(--ink-mute);margin-top:.55rem;line-height:1.35;
  font-family:var(--h-display);
}


/* ─────────── THEME TOGGLE ─────────── */
.theme-toggle{
  width:34px;height:34px;display:flex;align-items:center;justify-content:center;
  background:transparent;border:1px solid var(--line);color:var(--ink-soft);
  cursor:pointer;transition:color .2s;border-color: .2s;background: .2s;
  position:relative;
}
.theme-toggle:hover{border-color:var(--line-strong);color:var(--cyan)}
.theme-toggle svg{position:absolute;transition:opacity .25s;transform: .35s var(--ease);}
.theme-toggle .tt-moon{opacity:1;transform:rotate(0)}
.theme-toggle .tt-sun{opacity:0;transform:rotate(-90deg)}
[data-theme="light"] .theme-toggle .tt-moon{opacity:0;transform:rotate(90deg)}
[data-theme="light"] .theme-toggle .tt-sun{opacity:1;transform:rotate(0)}

[data-theme="light"] .sun{opacity: 1;transform:rotate(0deg)}
[data-theme="dark"] .sun{opacity: 0;transform:scale(0.5) rotate(-15deg)}
[data-theme="light"] .moon{opacity: 0;transform:rotate(180deg)}
[data-theme="dark"] .moon{opacity: 1; transform:scale(1) rotate(0deg)}



/* ─────────── LIGHT-THEME COMPONENT TWEAKS ─────────── */
[data-theme="light"]{
  /* grain overlay too strong on white — dial down */
}
[data-theme="light"] .grain{opacity:.025;mix-blend-mode:multiply}



/* Nav — opaque white on scroll */
[data-theme="light"] nav#nav{
  background:rgba(255,255,255,.85);
  backdrop-filter:saturate(160%) blur(18px);
  -webkit-backdrop-filter:saturate(160%) blur(18px);
}
[data-theme="light"] nav#nav.scrolled{
  background:rgba(255,255,255,.96);
  border-bottom-color:var(--line);
  box-shadow:0 1px 0 var(--line),0 8px 24px -16px rgba(11,18,32,.12);
}
[data-theme="light"] .nav-links a{color:var(--ink-soft)}
[data-theme="light"] .nav-links a:hover{color:var(--cyan)}
[data-theme="light"] .nav-logo img{box-shadow:none}
[data-theme="light"] .nav-logo .wordmark em{color:var(--blue-d)}

/* Lang switch — rework glows */
[data-theme="light"] .ls-track{background:rgba(8,145,178,.08);border-color:rgba(8,145,178,.25)}
[data-theme="light"] [data-lang="en"] .ls-track{background:rgba(8,145,178,.2)}
[data-theme="light"] .ls-thumb{box-shadow:0 1px 3px rgba(8,145,178,.4)}

/* Buttons — remove neon glow, use elevation shadow */
[data-theme="light"] .btn-primary{
  box-shadow:0 1px 2px rgba(8,145,178,.2),0 4px 14px -4px rgba(8,145,178,.35);
}
[data-theme="light"] .btn-primary:hover{
  box-shadow:0 2px 4px rgba(8,145,178,.25),0 8px 24px -6px rgba(8,145,178,.5);
}

/* Hero eyebrow dot glow → soft */
[data-theme="light"] .hero-eyebrow .dot,
[data-theme="light"] .ha-tag .dot,
[data-theme="light"] .ha-dot,
[data-theme="light"] .gov-audit-head .live{
  box-shadow:0 0 0 3px rgba(8,145,178,.15);
}

/* Hero grad text stays colored (now blue gradient) */

/* Hero animation frame — white with soft border/shadow */
[data-theme="light"] .ha-frame{
  background:linear-gradient(160deg,rgba(255,255,255,.9),rgba(240,245,251,.95));
  box-shadow:0 1px 0 rgba(255,255,255,.9) inset,0 20px 60px -24px rgba(11,18,32,.18);
}
[data-theme="light"] .ha-file{
  background:#fff;
  box-shadow:0 6px 18px -4px rgba(11,18,32,.12),0 1px 0 rgba(11,18,32,.03);
}
[data-theme="light"] .ha-file-name{color:var(--ink)}
[data-theme="light"] .ha-file-grid{
  background-image:
    linear-gradient(to right,rgba(11,18,32,.08) 1px,transparent 1px),
    linear-gradient(to bottom,rgba(11,18,32,.08) 1px,transparent 1px);
}
[data-theme="light"] .ha-core{filter:blur(12px);opacity:.5!important}
[data-theme="light"] .ha-scan{box-shadow:0 0 8px rgba(8,145,178,.5)}
[data-theme="light"] .ha-table{background:#fff;box-shadow:0 1px 0 rgba(11,18,32,.03)}
[data-theme="light"] .ha-table-head{color:#fff}
[data-theme="light"] .ha-row > div:first-child{color:var(--blue-d)}

/* Marquee edges — fade to light */
[data-theme="light"] .mq::before{background:linear-gradient(90deg,var(--bg),transparent)}
[data-theme="light"] .mq::after{background:linear-gradient(-90deg,var(--bg),transparent)}

/* Problem/Solution/Features grid cells — soft white cards */
[data-theme="light"] .prob-card,
[data-theme="light"] .sol-step,
[data-theme="light"] .feat-card,
[data-theme="light"] .ind-card,
[data-theme="light"] .price-card{
  background:#fff;
}
[data-theme="light"] .prob-card:hover,
[data-theme="light"] .sol-step:hover,
[data-theme="light"] .feat-card:hover,
[data-theme="light"] .ind-card:hover,
[data-theme="light"] .price-card:hover{
  background:#F6F9FC;
}
[data-theme="light"] .price-card.featured{
  background:linear-gradient(180deg,rgba(8,145,178,.06),#fff);
  box-shadow:inset 0 0 0 1px var(--line-strong),0 20px 50px -20px rgba(8,145,178,.25);
}

/* Tabs — active state */
[data-theme="light"] .tab-btn.active{background:#F0F6FC}
[data-theme="light"] .tab-btn:hover{background:#F6F9FC}
[data-theme="light"] .tab-ico{background:#fff}
[data-theme="light"] .tab-btn.active .tab-ico{background:rgba(8,145,178,.1)}

/* Governance panel — lift with shadow instead of dark glass */
[data-theme="light"] .gov-grid{
  background:linear-gradient(135deg,#fff,#F6F9FC);
  box-shadow:0 30px 70px -40px rgba(11,18,32,.15);
}
[data-theme="light"] .gov-cert{background:#fff;box-shadow:0 1px 2px rgba(11,18,32,.04)}
[data-theme="light"] .gov-cert:hover{background:#F6F9FC;box-shadow:0 4px 10px rgba(11,18,32,.08)}
[data-theme="light"] .gov-cert-ico{background:rgba(8,145,178,.06)}
[data-theme="light"] .gov-audit{background:#fff;box-shadow:0 1px 2px rgba(11,18,32,.04)}
[data-theme="light"] .gov-audit-head{background:rgba(8,145,178,.04)}
[data-theme="light"] .gov-check{background:rgba(8,145,178,.08)}

/* Bridge glow → subtle wash */
[data-theme="light"] #bridge::before{
  background:radial-gradient(ellipse at center,rgba(8,145,178,.05),transparent 55%);
}
[data-theme="light"] .bridge-mark{color:var(--cyan);opacity:.5}

/* CTA-mid glow */
[data-theme="light"] #cta-mid::before{
  background:radial-gradient(ellipse 50% 60% at 50% 50%,rgba(8,145,178,.05),transparent 70%);
}

/* CTA-final glow */
[data-theme="light"] .cta-glow{
  background:radial-gradient(ellipse,rgba(8,145,178,.08),transparent 65%);
}

/* Pricing toggle */
[data-theme="light"] .pt-track{background:rgba(8,145,178,.08);border-color:rgba(8,145,178,.25)}
[data-theme="light"] .pt-track.on{background:rgba(8,145,178,.25)}
[data-theme="light"] .pt-thumb{box-shadow:0 1px 3px rgba(8,145,178,.4)}
[data-theme="light"] .price-badge{color:#fff}

/* FAQ — stronger dividers work better on white */
[data-theme="light"] .faq-q:hover{color:var(--cyan)}
[data-theme="light"] .faq-item.open .faq-q{color:var(--cyan)}
[data-theme="light"] .faq-icon{background:#fff}
[data-theme="light"] .faq-item.open .faq-icon{background:rgba(8,145,178,.08)}

/* Partners cards */
[data-theme="light"] .partner-card{background:#fff}
[data-theme="light"] .partner-card:hover{background:#F6F9FC;border-color:var(--line-strong)}
[data-theme="light"] .partner-logo{background:#F6F9FC;color:var(--ink)}

/* Modal */
[data-theme="light"] .modal{background:#fff;box-shadow:0 30px 80px -20px rgba(11,18,32,.3)}
[data-theme="light"] .form-group input,
[data-theme="light"] .form-group select,
[data-theme="light"] .form-group textarea{
  background:#F6F9FC;color:var(--ink);
}
[data-theme="light"] .form-group select option{background:#fff;color:var(--ink)}
[data-theme="light"] .form-submit{color:#fff}
[data-theme="light"] .form-submit:hover{background:var(--blue-d);color:#fff;transform:translateY(-1px)}

/* Selection */
[data-theme="light"] ::selection{background:rgba(8,145,178,.18);color:var(--ink-strong)}

/* Tweaks panel */
[data-theme="light"] .tweaks-panel{
  background:rgba(255,255,255,.96);
  box-shadow:0 20px 60px rgba(11,18,32,.12),0 0 0 1px rgba(8,145,178,.08) inset;
}
[data-theme="light"] .tk-seg button.is-active{color:#fff}
