/* ============================================================
   PT Karya Guna Pandapotan (KGP) — editorial / parallax rebuild
   Azure #0060A8 + deep navy. Space Grotesk display, Plus Jakarta
   Sans body, Newsreader italic accents, IBM Plex Mono labels.
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=Plus+Jakarta+Sans:wght@400;500;600;700&family=Newsreader:ital,opsz,wght@1,18..72,400;1,18..72,500&family=IBM+Plex+Mono:wght@400;500&display=swap');

:root{
  --blue-50:#EAF3FB; --blue-100:#CFE4F4; --blue-200:#A1CBE9; --blue-300:#6BACDA;
  --blue-400:#338AC6; --blue-500:#0F72B2; --blue-600:#0060A8; --blue-700:#0A4E8B;
  --blue-800:#073C6C; --blue-900:#052B4E; --blue-950:#031C33;
  --cyan-300:#6FE0EC; --cyan-400:#2BC4D8; --cyan-500:#12A7BE;

  --white:#FFFFFF;
  --ink-50:#F5F8FC; --ink-100:#ECF1F8; --ink-200:#DCE4EF; --ink-300:#C0CCDD;
  --ink-400:#8E9BB2; --ink-500:#66738D; --ink-600:#475571; --ink-700:#303C56;
  --ink-800:#1C2740; --ink-900:#101A30; --ink-950:#070E1C;

  --text-strong:var(--ink-900); --text-body:var(--ink-700); --text-muted:var(--ink-500);
  --on-dark:rgba(255,255,255,.92); --on-dark-muted:rgba(208,224,243,.66);

  --font-display:'Space Grotesk',system-ui,sans-serif;
  --font-body:'Plus Jakarta Sans',system-ui,sans-serif;
  --font-serif:'Newsreader',Georgia,serif;
  --font-mono:'IBM Plex Mono',ui-monospace,monospace;

  --container:1280px;
  --ease:cubic-bezier(.16,1,.3,1);
  --ease-std:cubic-bezier(.2,.6,.2,1);

  --shadow-md:0 8px 22px rgba(12,28,55,.10),0 2px 6px rgba(12,28,55,.06);
  --shadow-lg:0 24px 50px rgba(7,28,55,.16),0 8px 18px rgba(7,28,55,.08);
  --shadow-primary:0 16px 36px rgba(0,96,168,.28);
}

*,*::before,*::after{box-sizing:border-box;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{
  margin:0;font-family:var(--font-body);color:var(--text-body);background:var(--white);
  font-size:1rem;line-height:1.55;-webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;overflow-x:hidden;
}
h1,h2,h3,h4,p{margin:0;}
a{color:inherit;text-decoration:none;}
img{max-width:100%;display:block;}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit;}
ul,ol{margin:0;padding:0;list-style:none;}
::selection{background:var(--blue-600);color:#fff;}

.container{width:100%;max-width:var(--container);margin-inline:auto;padding-inline:clamp(1.25rem,4vw,2.75rem);}

h1,h2,h3{font-family:var(--font-display);color:var(--text-strong);line-height:1.02;letter-spacing:-.03em;font-weight:700;}

/* label / eyebrow — mono, wide tracked */
.label{
  font-family:var(--font-mono);font-size:.72rem;font-weight:500;
  letter-spacing:.28em;text-transform:uppercase;color:var(--blue-600);
  display:inline-flex;align-items:center;gap:.6rem;
}
.label::before{content:"";width:1.5rem;height:1px;background:currentColor;opacity:.6;}
.label.light{color:var(--cyan-300);}
.serif-accent{font-family:var(--font-serif);font-style:italic;font-weight:400;}

.section{position:relative;padding-block:clamp(5rem,11vw,9rem);}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.6rem;
  font-family:var(--font-display);font-weight:600;font-size:.9rem;letter-spacing:-.01em;
  padding:.95rem 1.7rem;border-radius:2px;
  transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .2s,color .2s,border-color .2s;
  white-space:nowrap;
}
.btn svg{width:1.05em;height:1.05em;}
.btn-primary{background:var(--blue-600);color:#fff;box-shadow:var(--shadow-primary);}
.btn-primary:hover{background:var(--blue-700);transform:translateY(-2px);box-shadow:0 22px 44px rgba(0,96,168,.36);}
.btn-ghost{background:transparent;color:var(--blue-700);border:1.5px solid var(--ink-300);}
.btn-ghost:hover{border-color:var(--blue-600);color:var(--blue-600);background:var(--blue-50);}
.btn-line-light{border:1.5px solid rgba(255,255,255,.34);color:#fff;}
.btn-line-light:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.65);}
.btn-white{background:#fff;color:var(--blue-800);}
.btn-white:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);}
.btn-lg{padding:1.1rem 2.1rem;font-size:1rem;}

/* ============================================================
   HEADER
   ============================================================ */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:60;
  transition:background .35s var(--ease-std),box-shadow .35s,border-color .35s;
  border-bottom:1px solid transparent;
}
.site-header.scrolled{
  background:rgba(255,255,255,.85);backdrop-filter:saturate(180%) blur(18px);
  -webkit-backdrop-filter:saturate(180%) blur(18px);
  border-bottom-color:var(--ink-200);box-shadow:0 6px 22px rgba(8,16,31,.05);
}
.nav{display:flex;align-items:center;justify-content:space-between;height:76px;gap:2rem;}
.brand{display:flex;align-items:center;gap:.7rem;flex-shrink:0;}
.brand img{height:40px;width:auto;}
.brand .bt{display:flex;flex-direction:column;line-height:1.05;}
.brand .bn{font-family:var(--font-display);font-weight:700;font-size:.98rem;color:var(--blue-900);letter-spacing:-.02em;}
.brand .bs{font-family:var(--font-mono);font-size:.6rem;font-weight:400;letter-spacing:.22em;color:var(--text-muted);text-transform:uppercase;}
.logo-white{display:none;}

.nav-links{display:flex;align-items:center;gap:.25rem;}
.nav-links a{
  font-family:var(--font-display);font-weight:500;font-size:.85rem;color:var(--ink-700);
  padding:.55rem .9rem;border-radius:2px;transition:color .18s,background .18s;
}
.nav-links a:hover{color:var(--blue-700);background:var(--blue-50);}
.nav-cta{display:flex;align-items:center;gap:.6rem;}
.hamburger{display:none;width:44px;height:44px;border-radius:4px;align-items:center;justify-content:center;color:var(--blue-900);}
.hamburger svg{width:26px;height:26px;}

/* over-hero (transparent) → light text */
.site-header:not(.scrolled) .nav-links a{color:rgba(255,255,255,.85);}
.site-header:not(.scrolled) .nav-links a:hover{color:#fff;background:rgba(255,255,255,.12);}
.site-header:not(.scrolled) .brand .bn{color:#fff;}
.site-header:not(.scrolled) .brand .bs{color:rgba(208,224,243,.7);}
.site-header:not(.scrolled) .logo-dark{display:none;}
.site-header:not(.scrolled) .logo-white{display:block;}
.site-header:not(.scrolled) .hamburger{color:#fff;}
.site-header:not(.scrolled) .btn-ghost{border-color:rgba(255,255,255,.34);color:#fff;}
.site-header:not(.scrolled) .btn-ghost:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.6);}

/* ============================================================
   HERO — full-bleed video background only
   ============================================================ */
.hero{
  position:relative;height:100svh;min-height:600px;width:100%;overflow:hidden;
  background:var(--blue-950);color:#fff;
}
.hero-media{position:absolute;inset:0;z-index:0;overflow:hidden;}
/* animated fallback shown until/unless a real video loads */
.hero-fallback{
  position:absolute;inset:-10% -5%;z-index:0;
  background:
    radial-gradient(60% 55% at 72% 18%,rgba(0,96,168,.62),transparent 62%),
    radial-gradient(45% 45% at 14% 30%,rgba(43,196,216,.30),transparent 60%),
    radial-gradient(55% 60% at 50% 110%,rgba(15,114,178,.45),transparent 65%),
    linear-gradient(160deg,#041f39,#031c33 55%,#02101f);
  animation:meshDrift 22s ease-in-out infinite alternate;
  transition:opacity .8s var(--ease);
}
.hero-media.video-active .hero-fallback{opacity:0;}
@keyframes meshDrift{0%{transform:scale(1.05) translate(0,0);}50%{transform:scale(1.12) translate(-2%,1.5%);}100%{transform:scale(1.05) translate(1.5%,-1%);}}
.hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1;}
.hero-grain{position:absolute;inset:0;z-index:2;opacity:.5;mix-blend-mode:overlay;pointer-events:none;
  background-image:radial-gradient(rgba(255,255,255,.10) 1px,transparent 1px);background-size:3px 3px;}
.hero-scrim{position:absolute;inset:0;z-index:3;
  background:
    linear-gradient(180deg,rgba(3,20,38,.72) 0%,rgba(3,20,38,.28) 38%,rgba(3,20,38,.45) 68%,rgba(3,20,38,.88) 100%);}
.hero-copy{
  position:absolute;inset:0;z-index:5;display:flex;align-items:flex-end;
  padding-bottom:clamp(5.5rem,10vw,7rem);pointer-events:none;
}
.hero-lead-grid{
  display:grid;grid-template-columns:minmax(0,4fr) minmax(0,2.4fr);
  gap:clamp(2rem,5vw,5rem);align-items:end;width:100%;pointer-events:auto;
}
.hero-headline{
  font-family:var(--font-display);font-size:clamp(2.2rem,5.2vw,4.4rem);font-weight:700;
  line-height:1.02;letter-spacing:-.03em;color:#fff;margin:0;
}
.hero-headline .em{color:var(--cyan-300);}
.hero-headline .it{font-family:var(--font-serif);font-style:italic;font-weight:400;color:rgba(208,224,243,.88);}
.hero-aside{
  font-size:1.02rem;line-height:1.7;color:var(--on-dark-muted);text-wrap:pretty;
  border-top:1px solid rgba(255,255,255,.22);padding-top:1.4rem;margin:0;
}
.hero-aside strong{color:#fff;font-weight:600;}
.hero-scroll{
  position:absolute;z-index:5;left:50%;bottom:clamp(26px,3.4vw,46px);transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:.5rem;
  font-family:var(--font-mono);font-size:.62rem;letter-spacing:.28em;color:rgba(255,255,255,.7);text-transform:uppercase;
}
.hero-scroll .line{width:1px;height:42px;background:linear-gradient(180deg,rgba(255,255,255,.7),transparent);position:relative;overflow:hidden;}
.hero-scroll .line::after{content:"";position:absolute;top:0;left:0;width:100%;height:40%;background:#fff;animation:scrollDot 2.2s var(--ease) infinite;}
@keyframes scrollDot{0%{transform:translateY(-100%);}100%{transform:translateY(260%);}}

/* ============================================================
   SERVICES — staggered editorial list
   ============================================================ */
.svc-head{display:flex;justify-content:space-between;align-items:flex-end;gap:2rem;flex-wrap:wrap;margin-bottom:clamp(2.5rem,5vw,4rem);}
.svc-head h2{font-size:clamp(2rem,4.4vw,3.3rem);letter-spacing:-.03em;max-width:16ch;text-wrap:balance;}
.svc-head .label{margin-bottom:1.1rem;}
.svc-spectrum{font-family:var(--font-mono);font-size:.72rem;color:var(--text-muted);display:flex;align-items:center;gap:.6rem;}
.svc-spectrum .sw{width:9px;height:9px;border-radius:2px;}

.svc-list{border-top:1px solid var(--ink-200);}
.svc-row{
  position:relative;display:grid;grid-template-columns:7rem minmax(0,1fr) 16rem auto;
  gap:clamp(1rem,3vw,2.5rem);align-items:center;padding:clamp(1.6rem,3vw,2.4rem) 0;
  border-bottom:1px solid var(--ink-200);transition:background .3s var(--ease),padding .3s var(--ease);
}
.svc-row::before{content:"";position:absolute;left:0;top:0;height:100%;width:0;background:var(--blue-600);transition:width .35s var(--ease);}
.svc-row:hover{background:var(--ink-50);}
.svc-row:hover{padding-left:clamp(1rem,2vw,1.6rem);}
.svc-row:hover::before{width:3px;}
.svc-n{font-family:var(--font-display);font-weight:700;font-size:clamp(2.4rem,5vw,3.6rem);letter-spacing:-.04em;
  color:transparent;-webkit-text-stroke:1.4px var(--ink-300);transition:-webkit-text-stroke .3s,color .3s;}
.svc-row:hover .svc-n{color:var(--blue-600);-webkit-text-stroke:1.4px var(--blue-600);}
.svc-main h3{font-size:clamp(1.3rem,2.4vw,1.85rem);letter-spacing:-.025em;color:var(--ink-900);}
.svc-main .it{font-family:var(--font-serif);font-style:italic;font-weight:400;color:var(--blue-500);}
.svc-desc{font-size:.95rem;line-height:1.6;color:var(--text-muted);text-wrap:pretty;}
.svc-tags{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.85rem;}
.svc-tags span{font-family:var(--font-mono);font-size:.66rem;letter-spacing:.04em;color:var(--blue-700);background:var(--blue-50);border:1px solid var(--blue-100);padding:.28rem .55rem;border-radius:2px;}
.svc-arrow{width:48px;height:48px;border:1.5px solid var(--ink-200);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--ink-400);transition:all .3s var(--ease);flex-shrink:0;}
.svc-arrow svg{width:20px;height:20px;}
.svc-row:hover .svc-arrow{background:var(--blue-600);border-color:var(--blue-600);color:#fff;transform:rotate(-45deg);}

/* ============================================================
   WHY — dark, parallax watermark, principle cards
   ============================================================ */
.why{position:relative;background:var(--blue-950);color:#fff;overflow:hidden;}
.why .grid-lines{position:absolute;inset:0;z-index:0;opacity:.4;
  background-image:linear-gradient(rgba(120,170,220,.08) 1px,transparent 1px),linear-gradient(90deg,rgba(120,170,220,.08) 1px,transparent 1px);
  background-size:72px 72px;mask-image:radial-gradient(120% 100% at 70% 0%,#000 30%,transparent 78%);
  -webkit-mask-image:radial-gradient(120% 100% at 70% 0%,#000 30%,transparent 78%);}
.why .wm{position:absolute;left:-8%;bottom:-12%;width:min(42vw,520px);opacity:.06;z-index:0;pointer-events:none;}
.why .container{position:relative;z-index:2;}
.why-top{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:clamp(2rem,5vw,4rem);align-items:end;margin-bottom:clamp(3rem,6vw,4.5rem);}
.why h2{color:#fff;font-size:clamp(2rem,4.4vw,3.4rem);letter-spacing:-.03em;text-wrap:balance;}
.why h2 .it{font-family:var(--font-serif);font-style:italic;font-weight:400;color:var(--cyan-300);}
.why-lead{color:var(--on-dark-muted);font-size:1.05rem;line-height:1.7;text-wrap:pretty;}
.why-points{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.5rem,3vw,2.5rem);}
.why-point{border-top:1px solid rgba(255,255,255,.16);padding-top:1.6rem;}
.why-point .pn{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.2em;color:var(--cyan-300);}
.why-point h4{font-family:var(--font-display);font-size:1.3rem;font-weight:600;color:#fff;margin-top:.9rem;letter-spacing:-.02em;}
.why-point p{font-size:.95rem;color:var(--on-dark-muted);margin-top:.6rem;line-height:1.6;}

/* ============================================================
   PORTFOLIO / AQUADATA
   ============================================================ */
.pf-head{margin-bottom:clamp(2.5rem,5vw,4rem);max-width:640px;}
.pf-head h2{font-size:clamp(2rem,4.4vw,3.3rem);letter-spacing:-.03em;margin-top:1.1rem;text-wrap:balance;}
.pf-head p{margin-top:1.1rem;font-size:1.05rem;color:var(--text-muted);line-height:1.7;text-wrap:pretty;}

.pf-feature{
  position:relative;display:grid;grid-template-columns:minmax(0,1.05fr) minmax(0,.95fr);
  gap:clamp(2rem,5vw,4.5rem);align-items:center;
  border:1px solid var(--ink-200);border-radius:4px;overflow:hidden;background:var(--white);box-shadow:var(--shadow-md);
}
.pf-feature .pf-copy{padding:clamp(1.8rem,4vw,3.4rem);}
.pf-tag{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--font-mono);font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--blue-700);background:var(--blue-50);border:1px solid var(--blue-100);padding:.35rem .7rem;border-radius:2px;}
.pf-feature h3{font-size:clamp(2.2rem,4.5vw,3.4rem);letter-spacing:-.035em;margin-top:1.2rem;color:var(--ink-900);}
.pf-domain{font-family:var(--font-mono);font-size:.85rem;color:var(--blue-600);margin-top:.5rem;}
.pf-feature .desc{margin-top:1.3rem;font-size:1rem;color:var(--text-body);line-height:1.7;text-wrap:pretty;}
.pf-feats{display:grid;grid-template-columns:1fr 1fr;gap:.7rem 1.4rem;margin-top:1.8rem;}
.pf-feat{display:flex;gap:.55rem;align-items:flex-start;font-size:.9rem;font-weight:500;color:var(--ink-800);}
.pf-feat svg{width:17px;height:17px;color:var(--blue-600);flex-shrink:0;margin-top:2px;}
.pf-actions{display:flex;gap:.8rem;margin-top:2rem;flex-wrap:wrap;}

/* aquadata visual — no fabricated telemetry, clean brand motif */
.aqua-visual{position:relative;align-self:stretch;min-height:340px;overflow:hidden;
  background:linear-gradient(165deg,#06243f,#04192e);border-left:1px solid var(--blue-800);}
.aqua-visual .rings{position:absolute;inset:0;}
.aqua-visual .rings span{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);border:1px solid rgba(43,196,216,.18);border-radius:50%;}
.aqua-visual .rings span:nth-child(1){width:120px;height:120px;}
.aqua-visual .rings span:nth-child(2){width:240px;height:240px;}
.aqua-visual .rings span:nth-child(3){width:380px;height:380px;}
.aqua-visual .rings span:nth-child(4){width:540px;height:540px;}
.aqua-wave{position:absolute;left:0;right:0;bottom:0;height:60%;}
.aqua-wave svg{width:100%;height:100%;}
.aqua-drop{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:78px;height:78px;border-radius:22px;
  background:linear-gradient(135deg,#2BC4D8,#0F72B2);display:flex;align-items:center;justify-content:center;
  box-shadow:0 18px 40px rgba(43,196,216,.4);}
.aqua-drop svg{width:40px;height:40px;color:#fff;}
.aqua-node{position:absolute;width:10px;height:10px;border-radius:50%;background:var(--cyan-400);box-shadow:0 0 0 4px rgba(43,196,216,.22);}
.aqua-node::after{content:"";position:absolute;inset:-4px;border-radius:50%;border:1px solid rgba(43,196,216,.5);animation:ping 2.6s ease-out infinite;}
@keyframes ping{0%{transform:scale(.6);opacity:.9;}100%{transform:scale(2.4);opacity:0;}}

.pf-mini{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:1.5rem;}
.pf-card{border:1px solid var(--ink-200);border-radius:4px;padding:2rem;background:var(--white);transition:transform .3s var(--ease),box-shadow .3s,border-color .3s;}
.pf-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-md);border-color:transparent;}
.pf-card .ic{width:46px;height:46px;border-radius:4px;display:flex;align-items:center;justify-content:center;color:#fff;margin-bottom:1.3rem;}
.pf-card .ic svg{width:23px;height:23px;}
.pf-card .sector{font-family:var(--font-mono);font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:var(--text-muted);}
.pf-card h4{font-family:var(--font-display);font-size:1.15rem;font-weight:600;margin-top:.5rem;color:var(--ink-900);letter-spacing:-.02em;}
.pf-card p{font-size:.9rem;color:var(--text-muted);margin-top:.6rem;line-height:1.6;}

/* ============================================================
   CTA + FOOTER
   ============================================================ */
.cta-wrap{padding-block:clamp(4rem,8vw,6rem);}
.cta-card{position:relative;overflow:hidden;border-radius:6px;
  background:linear-gradient(135deg,var(--blue-700),var(--blue-900) 55%,var(--blue-950));
  padding:clamp(2.5rem,6vw,5rem);color:#fff;box-shadow:var(--shadow-lg);}
.cta-card .glow{position:absolute;width:480px;height:480px;border-radius:50%;background:radial-gradient(circle,rgba(43,196,216,.4),transparent 65%);top:-160px;right:-120px;filter:blur(20px);}
.cta-inner{position:relative;z-index:2;display:grid;grid-template-columns:1.25fr .75fr;gap:3rem;align-items:center;}
.cta-card .label{margin-bottom:1.1rem;}
.cta h2{color:#fff;font-size:clamp(1.9rem,4vw,3rem);letter-spacing:-.03em;text-wrap:balance;}
.cta h2 .it{font-family:var(--font-serif);font-style:italic;font-weight:400;color:var(--cyan-300);}
.cta p{margin-top:1.2rem;color:var(--on-dark-muted);font-size:1.05rem;line-height:1.7;}
.cta-actions{display:flex;flex-direction:column;gap:.8rem;}
.cta-actions .btn{width:100%;}
.cta-contact{margin-top:1.2rem;display:grid;gap:.6rem;}
.cta-contact a{display:flex;align-items:center;gap:.6rem;font-size:.9rem;color:var(--on-dark);font-weight:500;}
.cta-contact a svg{width:17px;height:17px;color:var(--cyan-300);}

.footer{background:var(--ink-950);color:rgba(255,255,255,.7);padding-top:clamp(3.5rem,7vw,5rem);}
.footer-top{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:2rem;padding-bottom:3rem;}
.footer-brand img{
  height:auto;width:auto;max-height:48px;max-width:160px;
  margin-bottom:1.5rem;object-fit:contain;
}
.footer-brand p{font-size:.9rem;line-height:1.7;max-width:24rem;color:rgba(255,255,255,.6);}
.footer-soc{display:flex;gap:.6rem;margin-top:1.5rem;}
.footer-soc a{width:38px;height:38px;border-radius:4px;background:rgba(255,255,255,.07);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.7);transition:background .2s,color .2s,transform .2s;}
.footer-soc a:hover{background:var(--blue-600);color:#fff;transform:translateY(-2px);}
.footer-soc svg{width:18px;height:18px;}
.footer-col h5{font-family:var(--font-mono);font-size:.7rem;font-weight:500;text-transform:uppercase;letter-spacing:.2em;color:#fff;margin-bottom:1.3rem;}
.footer-col a{display:block;font-size:.9rem;padding:.32rem 0;color:rgba(255,255,255,.62);transition:color .18s,padding .18s;}
.footer-col a:hover{color:#fff;padding-left:.25rem;}
.footer-bottom{border-top:1px solid rgba(255,255,255,.09);padding-block:1.5rem;display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;}
.footer-bottom p{font-size:.75rem;color:rgba(255,255,255,.5);font-family:var(--font-mono);letter-spacing:.04em;}
.footer-bottom .links{display:flex;gap:1.5rem;}
.footer-bottom .links a{font-size:.75rem;color:rgba(255,255,255,.5);}
.footer-bottom .links a:hover{color:#fff;}

/* ============================================================
   PARALLAX + REVEAL
   ============================================================ */
[data-par]{will-change:transform;}
.reveal{opacity:0;transform:translateY(28px);transition:opacity .8s var(--ease),transform .8s var(--ease);}
.reveal.in{opacity:1;transform:none;}
.reveal.d1{transition-delay:.08s;}.reveal.d2{transition-delay:.16s;}.reveal.d3{transition-delay:.24s;}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none;}
  [data-par]{transform:none !important;}
  *{animation:none !important;}
}

/* ============================================================
   MOBILE MENU
   ============================================================ */
.mobile-menu{position:fixed;inset:0;z-index:70;background:var(--blue-950);color:#fff;
  display:flex;flex-direction:column;padding:1.5rem clamp(1.25rem,5vw,2rem) 2rem;
  transform:translateX(100%);transition:transform .4s var(--ease);visibility:hidden;}
.mobile-menu.open{transform:none;visibility:visible;}
.mm-top{display:flex;align-items:center;justify-content:space-between;height:54px;}
.mm-top img{height:38px;}
.mm-close{width:44px;height:44px;color:#fff;display:flex;align-items:center;justify-content:center;}
.mm-close svg{width:28px;height:28px;}
.mm-links{display:flex;flex-direction:column;gap:.25rem;margin-top:2.5rem;}
.mm-links a{font-family:var(--font-display);font-size:1.7rem;font-weight:600;color:#fff;padding:.7rem 0;border-bottom:1px solid rgba(255,255,255,.08);letter-spacing:-.02em;}
.mm-links a:active{color:var(--cyan-300);}
.mm-cta{margin-top:auto;display:grid;gap:.8rem;padding-top:2rem;}
.mm-cta .btn{width:100%;}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1080px){
  .hero-lead-grid{grid-template-columns:1fr;align-items:start;gap:2rem;}
  .hero-aside{max-width:46ch;}
  .why-top{grid-template-columns:1fr;}
  .why-points{grid-template-columns:1fr;gap:0;}
  .why-point{padding-block:1.4rem;}
  .pf-feature{grid-template-columns:1fr;}
  .aqua-visual{min-height:300px;border-left:none;border-top:1px solid var(--blue-800);order:2;}
  .pf-feature .pf-copy{order:1;}
  .pf-mini{grid-template-columns:1fr;}
  .cta-inner{grid-template-columns:1fr;}
  .footer-top{grid-template-columns:1fr 1fr;}
  /* services row collapses */
  .svc-row{grid-template-columns:4.5rem minmax(0,1fr);grid-template-areas:"n main" "n desc";gap:.4rem 1.2rem;}
  .svc-n{grid-area:n;align-self:start;}
  .svc-main{grid-area:main;}
  .svc-desc{grid-area:desc;}
  .svc-arrow{display:none;}
}
@media (max-width:760px){
  .nav-links,.nav-cta .btn{display:none;}
  .hamburger{display:flex;}
  .footer-top{grid-template-columns:1fr;gap:2.5rem;}
  .pf-feats{grid-template-columns:1fr;}
}
@media (max-width:520px){
  .svc-row{grid-template-columns:1fr;grid-template-areas:"n" "main" "desc";gap:.5rem;}
  .svc-n{font-size:2.6rem;}
  .hero-copy{padding-bottom:clamp(4.5rem,12vw,6rem);}
}

/* ---------- legal pages ---------- */
.legal-page{background:var(--ink-50);}
.legal-main{padding-block:clamp(7rem,12vw,9rem) clamp(3rem,8vw,5rem);max-width:760px;}
.legal-main h1{font-size:clamp(2rem,4vw,2.75rem);margin-bottom:1rem;}
.legal-main h2{font-size:1.25rem;margin:2rem 0 .75rem;}
.legal-main p,.legal-main li{color:var(--text-body);margin-bottom:1rem;line-height:1.7;}
.legal-main a{color:var(--blue-700);text-decoration:underline;text-underline-offset:3px;}
.legal-main a:hover{color:var(--blue-600);}
