/* ==========================================================================
   The Blue Vault — main.css
   Shared stylesheet across all pages. Tokens → reset → layout → components.
   ========================================================================== */

:root{
  /* palette */
  --ink:#05080F;
  --abyss:#0A1428;
  --tide:#11253F;
  --signal:#FFD27D;
  --coast:#D8D2C2;
  --sun:#F4B860;
  --bone:#ECE9E2;

  /* easing */
  --ease:cubic-bezier(.65,0,.35,1);
  --ease-out:cubic-bezier(.16,1,.3,1);

  /* typography */
  --display:"Fraunces","Times New Roman",Georgia,serif;
  --body:"Inter",system-ui,-apple-system,"Segoe UI",sans-serif;
  --mono:"JetBrains Mono",ui-monospace,"SF Mono",Menlo,monospace;

  /* spacing */
  --pad:clamp(24px,6vw,96px);
  --maxw:1480px;
  --nav-h:72px;
}

/* ──────────────── reset ──────────────── */
*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
html{
  background:var(--ink);
  color:var(--bone);
  font-family:var(--body);
  font-size:16px;line-height:1.55;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
body{overflow-x:hidden;cursor:none;background:transparent;min-height:100vh}
::selection{background:var(--signal);color:var(--ink)}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:0;cursor:none;padding:0}
img{display:block;max-width:100%}
:focus-visible{outline:2px solid var(--signal);outline-offset:3px;border-radius:2px}

/* ──────────────── BACKGROUND ──────────────── */
.bg-canvas{
  position:fixed;inset:0;z-index:-3;
  width:100%;height:100%;
  display:block;
  background:transparent;
}
.bg-fallback{
  position:fixed;inset:0;z-index:-4;
  background:
    linear-gradient(180deg, rgba(5,8,15,.72) 0%, rgba(5,8,15,.38) 45%, rgba(5,8,15,.78) 100%),
    radial-gradient(60% 50% at 22% 30%, rgba(255,210,125,.22), transparent 58%),
    radial-gradient(70% 55% at 78% 70%, rgba(244,184,96,.16), transparent 62%),
    url("../img/fiber-grid.png") center/cover no-repeat var(--abyss);
  background-attachment: fixed, fixed, fixed, fixed;
  background-size: auto, 220% 220%, 240% 240%, 112% 112%;
  background-position: center, 0% 0%, 100% 100%, 50% 50%;
  animation:drift 36s ease-in-out infinite alternate;
}
@keyframes drift{
  0%  { background-size: auto, 220% 220%, 240% 240%, 112% 112%;
        background-position: center, 0% 0%, 100% 100%, 48% 50%; }
  100%{ background-size: auto, 280% 280%, 220% 220%, 120% 120%;
        background-position: center, 100% 60%, 20% 30%, 56% 52%; }
}
.bg-vignette{
  position:fixed;inset:0;z-index:-2;pointer-events:none;
  background:radial-gradient(160% 100% at 50% 45%, rgba(0,0,0,0) 55%, rgba(5,8,15,.45) 100%);
}
.bg-grain{
  position:fixed;inset:0;z-index:-1;pointer-events:none;
  opacity:.07;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='220' height='220'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.92  0 0 0 0 0.91  0 0 0 0 0.88  0 0 0 0.55 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
}

/* ──────────────── CURSOR ──────────────── */
.cursor-dot,.cursor-ring{position:fixed;top:0;left:0;pointer-events:none;z-index:9999;transform:translate(-50%,-50%)}
.cursor-dot{
  width:7px;height:7px;border-radius:50%;
  background:var(--sun);
  box-shadow:0 0 10px rgba(255,210,125,.75);
  transition:opacity .15s var(--ease),transform .1s var(--ease);
}
.cursor-ring{
  width:30px;height:30px;border-radius:50%;
  border:1.8px solid rgba(236,233,226,.95);
  box-shadow:
    0 0 14px rgba(255,210,125,.45),
    inset 0 0 6px rgba(255,255,255,.10);
  transition:width .18s var(--ease),height .18s var(--ease),border-color .2s var(--ease),box-shadow .2s var(--ease),opacity .15s var(--ease);
}
.cursor-ring.is-hover{width:54px;height:54px;border-color:var(--sun);box-shadow:0 0 24px rgba(255,210,125,.75),inset 0 0 8px rgba(255,210,125,.15)}
.cursor-dot.is-hover{opacity:0}

/* ──────────────── DEFENSE-IN-DEPTH (hero footer) ──────────────── */
.defenseFrame{
  position:relative;width:100%;
  padding:clamp(28px,3.6vw,52px) clamp(28px,4vw,72px) clamp(24px,3vw,40px);
  border:1px solid rgba(236,233,226,.05);
  border-radius:8px;
  background:rgba(8,14,28,.18);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
}
.corner{
  position:absolute;width:clamp(16px,1.4vw,22px);height:clamp(16px,1.4vw,22px);
  pointer-events:none;
}
.corner--tl{top:clamp(8px,.8vw,14px);left:clamp(8px,.8vw,14px);border-top:1.6px solid var(--sun);border-left:1.6px solid var(--sun)}
.corner--tr{top:clamp(8px,.8vw,14px);right:clamp(8px,.8vw,14px);border-top:1.6px solid var(--sun);border-right:1.6px solid var(--sun)}
.corner--bl{bottom:clamp(8px,.8vw,14px);left:clamp(8px,.8vw,14px);border-bottom:1.6px solid var(--sun);border-left:1.6px solid var(--sun)}
.corner--br{bottom:clamp(8px,.8vw,14px);right:clamp(8px,.8vw,14px);border-bottom:1.6px solid var(--sun);border-right:1.6px solid var(--sun)}

.defenseHead{
  display:flex;align-items:center;justify-content:center;
  gap:clamp(10px,1.4vw,18px);
  font-family:var(--mono);font-size:clamp(11px,.95vw,13px);
  letter-spacing:.3em;text-transform:uppercase;color:var(--sun);
  margin-bottom:clamp(22px,2.6vh,36px);
}
.defenseHead__dash{
  display:inline-block;width:clamp(36px,5vw,72px);height:1px;
  background:rgba(255,210,125,.55);
}

.defenseRow{
  display:flex;align-items:center;justify-content:space-between;
  gap:clamp(6px,1vw,18px);
}
.hexCell{
  flex:1;display:flex;flex-direction:column;align-items:center;
  gap:5px;text-decoration:none;color:inherit;
  transition:transform .35s var(--ease);
  min-width:0;
}
.hexCell:hover{transform:translateY(-4px)}
.hexCell:hover .hexShape polygon{fill:rgba(255,210,125,.10);stroke:rgba(255,210,125,.95)}
.hexCell:hover .hexIco{transform:scale(1.06);filter:drop-shadow(0 0 14px rgba(255,210,125,.75))}

.hexWrap{
  position:relative;
  width:clamp(70px,7.2vw,96px);
  height:clamp(78px,8vw,106px);
  display:flex;align-items:center;justify-content:center;
}
.hexShape{
  position:absolute;inset:0;width:100%;height:100%;
  transition:fill .3s var(--ease),stroke .3s var(--ease);
  filter:drop-shadow(0 0 10px rgba(255,210,125,.18));
}
.hexIco{
  position:relative;z-index:1;
  width:clamp(28px,3vw,40px);height:clamp(28px,3vw,40px);
  color:var(--sun);
  filter:drop-shadow(0 0 6px rgba(255,210,125,.45));
  transition:transform .35s var(--ease),filter .35s var(--ease);
}

.hexArrow{
  flex:0 0 auto;
  width:clamp(18px,1.9vw,30px);height:auto;
  color:rgba(255,210,125,.55);
}

.hexNum{
  font-family:var(--mono);font-size:clamp(9.5px,.78vw,11px);
  letter-spacing:.16em;color:var(--sun);margin-top:8px;
}
.hexTitle{
  font-family:var(--display);font-weight:400;
  font-size:clamp(15px,1.35vw,21px);
  color:var(--bone);letter-spacing:-.01em;line-height:1.1;
}
.hexSub{
  font-family:var(--body);font-size:clamp(11px,.85vw,13px);
  color:var(--coast);margin-top:2px;text-align:center;
}

@media (max-width: 760px){
  .defenseFrame{padding:24px 20px 18px}
  .defenseRow{flex-wrap:wrap;justify-content:center;row-gap:24px;column-gap:14px}
  .hexCell{flex:0 1 calc(50% - 18px)}
  .hexArrow{display:none}
  .defenseHead{font-size:10.5px;letter-spacing:.24em}
  .defenseHead__dash{width:24px}
}

/* ──────────────── NAV ──────────────── */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:80;
  height:var(--nav-h);
  padding:0 var(--pad);
  display:flex;align-items:center;justify-content:space-between;gap:24px;
  background:linear-gradient(180deg, rgba(5,8,15,.7), rgba(5,8,15,0));
  backdrop-filter:blur(18px) saturate(150%);-webkit-backdrop-filter:blur(18px) saturate(150%);
  border-bottom:1px solid rgba(236,233,226,.06);
  transition:background .35s var(--ease), border-color .35s var(--ease);
}
.nav.is-scrolled{
  background:rgba(5,8,15,.62);
  border-bottom-color:rgba(236,233,226,.1);
}
.nav__brand{
  display:flex;align-items:center;gap:12px;
  font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--bone);
  font-weight:500;
}
.nav__brand .mark{
  width:22px;height:22px;display:block;
}
.nav__brand .mark path{stroke:var(--signal);stroke-width:1.6;fill:none}
.nav__brand .mark circle{fill:var(--sun)}
.nav__links{display:flex;align-items:center;gap:clamp(14px,1.6vw,28px);font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--coast)}
.nav__links a{position:relative;padding:8px 0;transition:color .25s var(--ease)}
.nav__links a:hover{color:var(--bone)}
.nav__links a::after{content:"";position:absolute;left:0;right:100%;bottom:2px;height:1px;background:var(--signal);transition:right .3s var(--ease)}
.nav__links a:hover::after{right:0}
.nav__links a.is-current{color:var(--bone)}
.nav__links a.is-current::after{right:0;background:var(--sun)}
.nav__cta{
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 16px;
  border:1px solid var(--sun);border-radius:6px;
  font-family:var(--mono);font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--bone);
  background:rgba(244,184,96,.05);
  transition:background .3s var(--ease), color .3s var(--ease);
}
.nav__cta:hover{background:rgba(244,184,96,.14);color:var(--sun)}
.nav__menu{
  display:none;width:36px;height:36px;align-items:center;justify-content:center;
  border:1px solid rgba(236,233,226,.16);border-radius:6px;color:var(--bone);
}
.nav__menu svg{width:16px;height:16px;display:block}

/* mobile menu (full-screen overlay) */
.menu{position:fixed;inset:0;z-index:90;display:none;flex-direction:column;background:rgba(5,8,15,.96);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);padding:96px var(--pad) 48px}
.menu.is-open{display:flex}
.menu__close{position:absolute;top:18px;right:18px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;color:var(--bone);font-size:22px;border:1px solid rgba(236,233,226,.2);border-radius:50%}
.menu ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:18px}
.menu a{font-family:var(--display);font-weight:300;font-size:clamp(28px,8vw,52px);color:var(--bone);letter-spacing:-.02em;line-height:1}
.menu a.is-current{color:var(--sun)}

/* ──────────────── PROGRESS RAIL (single-page sections) ──────────────── */
.progress{
  position:fixed;right:clamp(14px,1.8vw,28px);top:50%;transform:translateY(-50%);z-index:50;
  font-family:var(--mono);font-size:11px;letter-spacing:.18em;color:var(--coast);
  display:flex;flex-direction:column;align-items:flex-end;gap:18px;mix-blend-mode:difference;
}
.progress__count{color:var(--bone);opacity:.95}
.progress__count em{font-style:normal;color:var(--signal)}
.progress__bar{width:1px;height:160px;background:rgba(236,233,226,.15);position:relative;overflow:hidden}
.progress__fill{position:absolute;top:0;left:0;width:1px;height:0%;background:var(--signal);box-shadow:0 0 8px var(--signal);transition:height .12s linear}
.progress__label{writing-mode:vertical-rl;transform:rotate(180deg);color:var(--coast);opacity:.7;font-size:10px;letter-spacing:.32em}

/* ──────────────── PAGE FRAME ──────────────── */
.page{position:relative;z-index:1;padding-top:var(--nav-h)}
section,.foot{position:relative;padding:clamp(56px,8vh,100px) var(--pad)}
.inner{max-width:var(--maxw);width:100%;margin:0 auto}

.label{font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--coast)}
.label em{font-style:normal;color:var(--sun)}
.label .dot{padding:0 .5em;color:var(--coast);opacity:.6}

.display{font-family:var(--display);font-weight:300;line-height:.96;letter-spacing:-.035em;color:var(--bone);margin:0}
.display--xxl{font-size:clamp(56px,8.5vw,156px);line-height:.94;letter-spacing:-.04em}
.display--xl{font-size:clamp(44px,6vw,96px)}
.display--l{font-size:clamp(34px,4.5vw,68px)}
.display--m{font-size:clamp(26px,3vw,40px);letter-spacing:-.02em;line-height:1.05}
.display--s{font-size:clamp(20px,2vw,28px);letter-spacing:-.01em;line-height:1.1}

p{margin:0 0 1em}
.lede{color:var(--coast);font-size:clamp(15px,1.15vw,18px);line-height:1.55;max-width:62ch}

/* ──────────────── REVEAL ──────────────── */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .9s var(--ease-out),transform .9s var(--ease-out)}
.reveal.in{opacity:1;transform:none}
.reveal--d1{transition-delay:.08s}.reveal--d2{transition-delay:.16s}
.reveal--d3{transition-delay:.24s}.reveal--d4{transition-delay:.32s}
.reveal--d5{transition-delay:.4s}.reveal--d6{transition-delay:.48s}

/* ──────────────── BUTTON ──────────────── */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 22px;border:1px solid rgba(236,233,226,.22);border-radius:6px;
  background:rgba(10,20,40,.28);
  backdrop-filter:blur(18px) saturate(140%);-webkit-backdrop-filter:blur(18px) saturate(140%);
  color:var(--bone);font-family:var(--mono);font-size:12px;letter-spacing:.18em;text-transform:uppercase;
  transition:border-color .3s var(--ease),color .3s var(--ease),background .3s var(--ease),transform .3s var(--ease);
  position:relative;overflow:hidden;
}
.btn .arrow{transition:transform .35s var(--ease)}
.btn:hover .arrow{transform:translateX(4px)}
.btn:hover{border-color:var(--signal);color:var(--signal)}
.btn--primary{border-color:var(--sun)}
.btn--primary:hover{background:rgba(244,184,96,.08);border-color:var(--sun);color:var(--sun)}
.btn--ghost{background:transparent}

/* ──────────────── LIQUID GLASS ──────────────── */
.glass{
  position:relative;
  background:rgba(8,14,28,.30);
  backdrop-filter:blur(22px) saturate(155%);
  -webkit-backdrop-filter:blur(22px) saturate(155%);
  border:1px solid rgba(236,233,226,.10);
  border-radius:clamp(16px,1.8vw,28px);
  padding:clamp(20px,4.5vw,72px);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.12),
    inset 0 -1px 0 rgba(0,0,0,.28),
    0 24px 60px rgba(0,0,0,.42);
  overflow:hidden;
}
.glass::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  border-radius:inherit;
  background:
    linear-gradient(180deg, rgba(255,255,255,.08) 0%, rgba(255,255,255,0) 32%),
    radial-gradient(140% 80% at 50% 0%, rgba(255,210,125,.05), transparent 55%);
}
.glass > *{ position:relative; z-index:1 }

/* ──────────────── HERO (page-level) ──────────────── */
.pageHero{
  padding:clamp(110px,14vh,170px) var(--pad) clamp(56px,7vh,96px);
  display:flex;flex-direction:column;justify-content:center;
  min-height:62vh;
}
.pageHero__brand{font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--bone);opacity:.92;margin-bottom:32px}
.pageHero__brand .dot{color:var(--sun);padding:0 .5em}
.pageHero__title{margin:0 0 24px;max-width:18ch}
.pageHero__sub{color:var(--coast);max-width:60ch;font-size:clamp(15px,1.2vw,18px);margin:0 0 36px}

/* HOME hero (taller, special) */
.hero{justify-content:space-between;min-height:100vh;padding:clamp(120px,16vh,200px) var(--pad) clamp(56px,7vh,96px)}
.hero__center{flex:1;display:flex;flex-direction:column;justify-content:center;max-width:var(--maxw);width:100%;margin:0 auto}
.hero__headline span.w{display:inline-block;opacity:0;transform:translateY(36px);transition:opacity .9s var(--ease-out),transform .9s var(--ease-out)}
.hero__headline.in span.w{opacity:1;transform:none}
.hero__sub{max-width:640px;color:var(--coast);font-size:clamp(15px,1.15vw,18px);line-height:1.5;margin:clamp(28px,4vh,48px) 0 clamp(36px,5vh,64px)}
.ctas{display:flex;gap:14px;flex-wrap:wrap}

.hero__bottom{
  display:flex;flex-direction:column;align-items:stretch;gap:clamp(14px,2vh,28px);
  width:100%;max-width:var(--maxw);margin:clamp(48px,7vh,112px) auto 0;
  font-family:var(--mono);letter-spacing:.2em;text-transform:uppercase;color:var(--coast);
}
.hero__bottom .scrollHint{align-self:flex-end}
.ticker{display:flex;align-items:center;gap:14px;color:var(--bone);opacity:.92;flex-wrap:wrap}
.ticker .dot{width:7px;height:7px;border-radius:50%;background:var(--sun);box-shadow:0 0 12px var(--sun);animation:pulse 2.4s ease-in-out infinite}
.ticker .sep{color:var(--coast);opacity:.6}
@keyframes pulse{0%,100%{transform:scale(1);box-shadow:0 0 8px var(--sun)}50%{transform:scale(1.25);box-shadow:0 0 18px var(--sun)}}

.scrollHint{display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--coast);font-size:10px;letter-spacing:.32em}
.scrollHint::after{content:"";width:1px;height:36px;background:linear-gradient(180deg,var(--coast),transparent);animation:drop 2.4s ease-in-out infinite}
@keyframes drop{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}51%{transform:scaleY(1);transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* ──────────────── STATS ──────────────── */
.stats{padding-top:clamp(56px,8vh,100px);padding-bottom:clamp(56px,8vh,100px)}
.stats__intro{max-width:560px;color:var(--coast);margin-bottom:clamp(40px,5vh,72px)}
.stats__intro h2{margin:14px 0 0}
.stats__grid{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:0;align-items:end;
  border-top:1px solid rgba(236,233,226,.10);
  padding-top:clamp(36px,4.5vh,64px);
}
.stats__grid .stat{position:relative;padding:0 clamp(14px,2vw,32px)}
.stats__grid .stat:first-child{padding-left:0}
.stats__grid .stat:last-child{padding-right:0}
.stats__grid .stat:not(:last-child)::after{
  content:"";position:absolute;right:0;top:8px;bottom:8px;width:1px;
  background:linear-gradient(180deg,transparent 0%,rgba(236,233,226,.18) 30%,rgba(236,233,226,.18) 70%,transparent 100%);
}
.stat__num{font-family:var(--display);font-weight:300;font-size:clamp(48px,7vw,120px);line-height:.9;letter-spacing:-.045em;color:var(--sun);display:block}
.stat__num em{font-style:normal;color:var(--signal);font-size:.55em;vertical-align:.18em;letter-spacing:0;padding-left:.05em}
.stat__cap{margin-top:18px;font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--coast);max-width:24ch}
.stat--accent .stat__num{color:var(--sun)}

/* ──────────────── SECTION HEAD ──────────────── */
.secHead{
  display:grid;
  grid-template-columns:minmax(0,1.4fr) minmax(0,1fr);
  gap:clamp(28px,4vw,72px);
  align-items:end;
  margin-bottom:clamp(36px,5vh,64px);
}
.secHead__title{max-width:18ch;margin:14px 0 0}
.secHead__lede{
  max-width:50ch;color:var(--coast);margin:0 0 6px;
  font-size:clamp(14px,1.1vw,17px);line-height:1.55;
}
@media (max-width:960px){
  .secHead{grid-template-columns:1fr;gap:18px;align-items:start}
  .secHead__lede{margin:0}
}

/* ──────────────── PILLARS ──────────────── */
.pillars{display:grid;grid-template-columns:1fr 1fr;gap:clamp(24px,3vw,48px);align-items:stretch}
.pillar{
  position:relative;
  padding:clamp(28px,3vw,44px);
  border:1px solid rgba(236,233,226,.08);
  border-radius:16px;
  background:rgba(8,14,28,.32);
  display:flex;flex-direction:column;
  overflow:hidden;
  will-change:transform,opacity;
  transition:opacity .5s var(--ease),transform .45s var(--ease),
    border-color .45s var(--ease),background .45s var(--ease),box-shadow .45s var(--ease);
}
.pillar::before{
  content:"";position:absolute;left:0;top:0;bottom:0;width:3px;
  background:linear-gradient(180deg,rgba(255,210,125,.85) 0%,rgba(255,210,125,0) 70%);
  opacity:.5;transition:opacity .45s var(--ease);
}
.pillars:hover .pillar{opacity:.4}
.pillars .pillar:hover{
  opacity:1;transform:translateY(-10px);
  border-color:rgba(255,210,125,.42);
  background:rgba(8,14,28,.48);
  box-shadow:0 18px 50px rgba(0,0,0,.42);
}
.pillars .pillar:hover::before{opacity:1}
.pillar__head{
  display:flex;align-items:center;gap:18px;
  margin-bottom:20px;flex-wrap:wrap;
}
.pillar__num{
  font-family:var(--display);font-weight:300;
  font-size:clamp(36px,3.8vw,52px);line-height:.9;
  color:var(--sun);letter-spacing:-.035em;
}
.pillar__label{margin:0}
.pillar h3{margin:0 0 18px;font-size:clamp(28px,3.4vw,48px);line-height:1}
.pillar p{color:var(--coast);max-width:46ch;margin:0 0 24px;font-size:clamp(14px,1.05vw,16px);line-height:1.55}
.pillar__list{
  list-style:none;padding:0;margin:0 0 28px;
  border-top:1px solid rgba(236,233,226,.08);
}
.pillar__list li{
  display:flex;gap:14px;align-items:baseline;
  padding:12px 0;border-bottom:1px solid rgba(236,233,226,.06);
  font-size:13.5px;color:var(--bone);opacity:.92;line-height:1.4;
}
.pillar__list .num{
  font-family:var(--mono);font-size:14px;
  color:var(--sun);min-width:14px;flex-shrink:0;
  text-align:center;line-height:1;
}
.pillar .btn{align-self:flex-start;margin-top:auto}

/* ──────────────── SECURITY ──────────────── */
.security__diagram{
  display:grid;grid-template-columns:repeat(6,1fr);gap:clamp(12px,1.4vw,20px);
  margin:clamp(40px,5vh,72px) 0 clamp(48px,6vh,80px);
  align-items:stretch;
}
.layer{
  position:relative;padding:24px 18px;
  border:1px solid rgba(236,233,226,.08);border-radius:6px;
  background:rgba(10,20,40,.32);
  backdrop-filter:blur(18px) saturate(140%);-webkit-backdrop-filter:blur(18px) saturate(140%);
  transition:border-color .35s var(--ease),background .35s var(--ease),transform .35s var(--ease);
  overflow:hidden;
}
.layer::before{content:"";position:absolute;left:0;top:0;width:100%;height:1px;background:linear-gradient(90deg,transparent,var(--signal),transparent);opacity:0;transition:opacity .4s var(--ease)}
.layer:hover{border-color:rgba(255,210,125,.35);transform:translateY(-6px);background:rgba(10,20,40,.5)}
.layer:hover::before{opacity:.8}
.layer__num{font-family:var(--mono);font-size:10px;letter-spacing:.2em;color:var(--coast);margin-bottom:18px;display:block}
.layer__name{font-family:var(--display);font-weight:300;font-size:clamp(18px,1.6vw,24px);letter-spacing:-.01em;line-height:1.1;color:var(--bone);margin:0 0 14px}
.layer__tags{font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--coast);line-height:1.7}
.layer__tags span{display:block}

.frameworks{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,5vw,96px);border-top:1px solid rgba(236,233,226,.08);padding-top:clamp(40px,5vh,64px)}
.frameworks h3{margin:14px 0 18px}
.frameworks p{color:var(--coast);max-width:46ch;margin:0}
.frameworks__list{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(160px,1fr));
  gap:10px;margin-top:24px;
}
.chip{
  display:inline-flex;align-items:center;gap:8px;padding:8px 14px;
  font-family:var(--mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--bone);
  border:1px solid rgba(236,233,226,.16);border-radius:4px;
  background:rgba(10,20,40,.25);
  backdrop-filter:blur(14px) saturate(140%);-webkit-backdrop-filter:blur(14px) saturate(140%);
  transition:border-color .3s var(--ease),color .3s var(--ease);
}
.chip:hover{border-color:var(--signal);color:var(--signal)}
.chip__dot{width:6px;height:6px;border-radius:50%;background:var(--signal);box-shadow:0 0 8px var(--signal)}

/* ──────────────── INDUSTRIES ──────────────── */
.indGrid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid rgba(236,233,226,.08)}
.ind{
  border-bottom:1px solid rgba(236,233,226,.08);border-right:1px solid rgba(236,233,226,.08);
  padding:clamp(28px,3vw,40px) clamp(20px,2vw,32px);
  transition:background .35s var(--ease);
  min-height:240px;display:flex;flex-direction:column;justify-content:space-between;gap:24px;
  position:relative;overflow:hidden;
}
.indGrid .ind:nth-child(3n){border-right:0}
.ind:hover{background:rgba(255,210,125,.04)}
.ind__head{display:flex;justify-content:space-between;align-items:flex-start;gap:18px}
.ind__num{font-family:var(--mono);font-size:10px;letter-spacing:.2em;color:var(--coast)}
.ind__icon{width:32px;height:32px;color:var(--signal);opacity:.8}
.ind h3{font-family:var(--display);font-weight:300;font-size:clamp(22px,2vw,30px);letter-spacing:-.01em;line-height:1.05;color:var(--bone);margin:8px 0 14px}
.ind p{color:var(--coast);font-size:14px;margin:0 0 14px;max-width:42ch}
.ind__regs{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--bone);opacity:.7}

/* deep industry list (industries.html) */
.indDeep{display:flex;flex-direction:column;gap:0;border-top:1px solid rgba(236,233,226,.08)}
.indRow{
  display:grid;grid-template-columns:1fr 2fr;gap:clamp(32px,4vw,72px);
  border-bottom:1px solid rgba(236,233,226,.08);
  padding:clamp(40px,5vh,72px) 0;
  align-items:start;
}
.indRow__head h3{font-family:var(--display);font-weight:300;font-size:clamp(28px,3vw,48px);line-height:1;letter-spacing:-.025em;color:var(--bone);margin:14px 0 18px;max-width:14ch}
.indRow__head .indRow__num{font-family:var(--mono);font-size:10px;letter-spacing:.2em;color:var(--coast)}
.indRow__head .indRow__regs{font-family:var(--mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--sun);margin-top:8px;opacity:.9}
.indRow__body p{color:var(--bone);opacity:.9;font-size:15px;margin:0 0 16px;max-width:62ch}
.indRow__body ul{margin:0;padding-left:18px;color:var(--coast);font-size:14.5px}
.indRow__body li{margin-bottom:6px}

/* ──────────────── PRICING ──────────────── */
.tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(18px,2vw,28px);margin-bottom:clamp(48px,6vh,72px)}
.tier{
  position:relative;padding:clamp(28px,2.4vw,40px) clamp(22px,2vw,32px);
  border:1px solid rgba(236,233,226,.1);border-radius:6px;
  background:rgba(10,20,40,.36);
  backdrop-filter:blur(18px) saturate(140%);-webkit-backdrop-filter:blur(18px) saturate(140%);
  display:flex;flex-direction:column;gap:18px;
  transition:border-color .35s var(--ease),transform .35s var(--ease);
  overflow:hidden;
}
.tier:hover{border-color:var(--signal);transform:translateY(-6px)}
.tier--featured{border-color:rgba(244,184,96,.6)}
.tier--featured .tier__name{color:var(--sun)}
.tier__name{font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--bone)}
.tier__price{font-family:var(--display);font-weight:300;font-size:clamp(40px,4.5vw,72px);line-height:.96;letter-spacing:-.03em;color:var(--bone);display:flex;align-items:baseline;gap:8px}
.tier__price em{font-style:normal;font-family:var(--mono);font-size:11px;letter-spacing:.18em;color:var(--coast);text-transform:uppercase}
.tier__lede{color:var(--coast);font-size:14px;margin:0;max-width:32ch}
.tier__inc{list-style:none;padding:0;margin:0;border-top:1px solid rgba(236,233,226,.08);padding-top:18px;display:flex;flex-direction:column;gap:12px}
.tier__inc li{display:flex;gap:12px;align-items:flex-start;font-size:13.5px;color:var(--bone);opacity:.92;line-height:1.5}
.tier__inc li::before{content:"+";font-family:var(--mono);color:var(--signal);font-size:11px;margin-top:2px}
.tier__cta{margin-top:auto}

.ratecard{border-top:1px solid rgba(236,233,226,.08);padding-top:clamp(40px,5vh,64px);display:grid;grid-template-columns:1fr 1.4fr;gap:clamp(40px,5vw,80px)}
.ratecard h3{margin:14px 0 18px}
.ratecard p{color:var(--coast);max-width:46ch;margin:0}
.rates{display:grid;grid-template-columns:repeat(2,1fr);gap:12px 32px}
.rate{display:flex;justify-content:space-between;align-items:baseline;gap:18px;padding:14px 0;border-bottom:1px solid rgba(236,233,226,.08)}
.rate__name{color:var(--bone);font-size:14px}
.rate__amt{font-family:var(--mono);font-size:13px;color:var(--signal);letter-spacing:.06em;white-space:nowrap}

.notInc{border-top:1px solid rgba(236,233,226,.08);padding-top:clamp(40px,5vh,64px);margin-top:clamp(40px,5vh,64px);display:grid;grid-template-columns:1fr 2fr;gap:clamp(32px,4vw,72px)}
.notInc__list{display:grid;grid-template-columns:1fr 1fr;gap:14px 28px;color:var(--coast);font-size:14px}
.notInc__list span{display:flex;align-items:baseline;gap:10px}
.notInc__list span::before{content:"−";font-family:var(--mono);color:var(--sun);font-size:13px}

/* ──────────────── PROCESS / STEPS ──────────────── */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(24px,2.5vw,40px)}
.step{border-top:1px solid rgba(236,233,226,.12);padding-top:24px;position:relative;transition:border-color .4s var(--ease)}
.step:hover{border-top-color:var(--signal)}
.step__num{font-family:var(--mono);font-size:11px;letter-spacing:.18em;color:var(--coast);margin-bottom:24px;display:flex;justify-content:space-between;align-items:center}
.step__num em{color:var(--bone);font-style:normal;opacity:.6}
.step h3{font-family:var(--display);font-weight:300;font-size:clamp(28px,2.6vw,40px);letter-spacing:-.02em;line-height:1;margin:0 0 18px;color:var(--bone)}
.step p{color:var(--coast);font-size:14.5px;margin:0}

/* deep step (approach.html) */
.stepRow{
  display:grid;grid-template-columns:1fr 2fr;gap:clamp(32px,4vw,72px);
  border-top:1px solid rgba(236,233,226,.08);
  padding:clamp(40px,5vh,72px) 0;
}
.stepRow:last-child{border-bottom:1px solid rgba(236,233,226,.08)}
.stepRow__head h3{font-family:var(--display);font-weight:300;font-size:clamp(36px,4vw,64px);line-height:1;letter-spacing:-.03em;color:var(--bone);margin:14px 0 0;max-width:8ch}
.stepRow__head .stepRow__num{font-family:var(--mono);font-size:11px;letter-spacing:.2em;color:var(--coast)}
.stepRow__head .stepRow__time{margin-top:14px;font-family:var(--mono);font-size:11px;letter-spacing:.18em;color:var(--sun);text-transform:uppercase}
.stepRow__body p{color:var(--bone);opacity:.9;font-size:15px;margin:0 0 14px;max-width:62ch}
.stepRow__body ul{margin:0 0 18px;padding-left:18px;color:var(--coast);font-size:14.5px}
.stepRow__body li{margin-bottom:6px}

/* ──────────────── LOCAL / MAP ──────────────── */
.local{display:grid;grid-template-columns:1.05fr 1fr;gap:clamp(40px,6vw,96px);align-items:center;padding-top:clamp(56px,9vh,120px);padding-bottom:clamp(56px,9vh,120px)}
.map{aspect-ratio:1/1;width:100%;max-width:560px;position:relative;margin:0 auto}
.map__svg{width:100%;height:100%;display:block}
.map__pin{position:absolute;left:21%;top:50%;width:14px;height:14px;border-radius:50%;background:var(--sun);box-shadow:0 0 14px var(--sun);transform:translate(-50%,-50%)}
.map__pin::before{content:"";position:absolute;inset:-10px;border-radius:50%;border:1px solid var(--sun);animation:ping 3s ease-out infinite}
.map__pin::after{content:"";position:absolute;inset:-22px;border-radius:50%;border:1px solid rgba(244,184,96,.35);animation:ping 3s ease-out 1.4s infinite}
.map__pinLabel{position:absolute;left:21%;top:50%;transform:translate(14px,12px);font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--sun);white-space:nowrap}
@keyframes ping{0%{transform:scale(.6);opacity:.9}100%{transform:scale(2.2);opacity:0}}
.local__copy h2{margin:18px 0 28px;max-width:14ch}
.local__copy p{color:var(--coast);max-width:48ch;margin:0 0 40px}
.address{font-family:var(--mono);font-size:13px;line-height:1.7;color:var(--bone);opacity:.92;border-left:1px solid var(--sun);padding:6px 0 6px 18px}

/* ──────────────── CONTACT FORM ──────────────── */
.contact{display:grid;grid-template-columns:1fr 1.4fr;gap:clamp(40px,6vw,96px);align-items:start}
.contact__left h2{margin:18px 0 36px;max-width:14ch}
.contact__direct{font-family:var(--mono);font-size:13px;line-height:2;color:var(--bone)}
.contact__direct a{border-bottom:1px solid transparent;transition:border-color .3s var(--ease),color .3s var(--ease)}
.contact__direct a:hover{color:var(--signal);border-bottom-color:var(--signal)}
.contact__direct .small{color:var(--coast);font-size:11px;letter-spacing:.18em;text-transform:uppercase;margin-top:32px;display:block;line-height:1.6}

.form{display:flex;flex-direction:column;gap:32px;max-width:680px;width:100%}
.field{position:relative}
.field label{position:absolute;left:0;top:14px;font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--coast);pointer-events:none;transition:transform .3s var(--ease),color .3s var(--ease),font-size .3s var(--ease)}
.field input,.field textarea,.field select{
  width:100%;background:transparent;border:0;
  border-bottom:1px solid rgba(216,210,194,.4);
  padding:36px 0 14px;color:var(--bone);font:inherit;font-size:16px;outline:none;border-radius:0;cursor:none;
  transition:border-color .35s var(--ease);
}
.field textarea{resize:vertical;min-height:140px;padding-top:36px}
.field select{appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path fill='none' stroke='%236FA8B5' stroke-width='1.5' d='M1 1.5 L6 6.5 L11 1.5'/></svg>");background-repeat:no-repeat;background-position:right 4px center;padding-right:24px}
.field select option{background:var(--ink);color:var(--bone)}
.field input:focus,.field textarea:focus,.field select:focus{border-bottom-color:var(--signal)}
.field input:focus+label,.field textarea:focus+label,.field select:focus+label,
.field input:not(:placeholder-shown)+label,.field textarea:not(:placeholder-shown)+label,
.field select.has-value+label{transform:translateY(-22px);color:var(--signal);font-size:10px}
.form__row{display:grid;grid-template-columns:1fr 1fr;gap:32px}
.form__actions{display:flex;align-items:center;justify-content:space-between;gap:18px;margin-top:8px;flex-wrap:wrap}
.form__note{font-family:var(--mono);font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--coast)}

/* ──────────────── FOOTER ──────────────── */
.foot{padding:clamp(56px,7vh,96px) var(--pad) clamp(32px,3.5vh,48px);position:relative;overflow:hidden}
.foot__mark{
  font-family:var(--display);font-weight:300;
  font-size:clamp(36px,11.8vw,200px);
  letter-spacing:-.045em;line-height:.92;
  color:rgba(236,233,226,.72);
  margin:0 0 clamp(40px,6vh,72px);user-select:none;
  white-space:nowrap;overflow:hidden;text-overflow:clip;
  text-align:center;
}
.foot__cols{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:clamp(24px,3vw,56px);margin-bottom:48px;font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--coast)}
.foot__col h4{margin:0 0 18px;color:var(--bone);font-weight:500;font-size:11px;letter-spacing:.22em}
.foot__col ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
.foot__col a{transition:color .3s var(--ease)}
.foot__col a:hover{color:var(--signal)}
.foot__address{color:var(--bone);font-size:11px;letter-spacing:.18em;line-height:1.9;text-transform:none}
.foot__addressTitle{display:block;font-weight:500;letter-spacing:.22em;text-transform:uppercase;margin-bottom:8px}
.foot__row{display:flex;justify-content:space-between;align-items:center;gap:18px;font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--coast);border-top:1px solid rgba(236,233,226,.08);padding-top:24px;flex-wrap:wrap}
.foot__row a{transition:color .3s var(--ease)}
.foot__row a:hover{color:var(--signal)}
.foot__links{display:flex;gap:22px;flex-wrap:wrap;align-items:center}
.foot__sig{display:flex;gap:18px;align-items:center}
.foot__sig em{font-style:normal;color:var(--bone);opacity:.7}
.foot__live{display:inline-flex;align-items:center;gap:8px}
.foot__live .pip{width:8px;height:8px;border-radius:50%;background:var(--signal);box-shadow:0 0 10px var(--signal)}

/* ──────────────── STATUS PAGE ──────────────── */
.statusOverall{display:flex;align-items:center;gap:14px;padding:18px 0;border-top:1px solid rgba(236,233,226,.08);border-bottom:1px solid rgba(236,233,226,.08);margin:32px 0}
.statusOverall .dot{width:10px;height:10px;border-radius:50%;background:var(--signal);box-shadow:0 0 12px var(--signal)}
.statusOverall .text{font-family:var(--mono);font-size:13px;letter-spacing:.18em;text-transform:uppercase;color:var(--bone)}
.statusOverall .sub{font-family:var(--mono);font-size:11px;letter-spacing:.18em;color:var(--coast);margin-left:auto}
.statusList{list-style:none;padding:0;margin:0}
.statusList li{display:flex;justify-content:space-between;align-items:center;padding:18px 0;border-bottom:1px solid rgba(236,233,226,.06)}
.statusList .name{display:flex;align-items:center;gap:12px;color:var(--bone);font-size:14.5px}
.statusList .pip{width:8px;height:8px;border-radius:50%;background:var(--signal);box-shadow:0 0 10px var(--signal)}
.statusList .met{font-family:var(--mono);font-size:11px;letter-spacing:.14em;color:var(--coast)}
.uptimeBars{display:flex;gap:2px;align-items:flex-end;height:36px;margin-top:32px}
.uptimeBars .b{flex:1;background:var(--signal);opacity:.8;height:80%;transition:opacity .3s var(--ease),height .3s var(--ease)}
.uptimeBars .b.warn{background:var(--sun);height:65%}
.uptimeBars .b:hover{opacity:1}

/* ──────────────── LEGAL/PROSE PAGE ──────────────── */
.prose{max-width:72ch;margin:0 auto}
.prose h2{font-family:var(--display);font-weight:300;font-size:clamp(26px,2.4vw,36px);letter-spacing:-.015em;color:var(--bone);margin:48px 0 16px}
.prose h3{font-family:var(--display);font-weight:400;font-size:clamp(18px,1.6vw,22px);color:var(--bone);margin:36px 0 10px}
.prose p,.prose ul,.prose ol{color:var(--bone);opacity:.9;font-size:15px;line-height:1.65;margin:0 0 16px}
.prose ul,.prose ol{padding-left:20px}
.prose li{margin-bottom:6px}
.prose code{font-family:var(--mono);font-size:.9em;background:rgba(255,210,125,.08);padding:2px 6px;border-radius:3px;color:var(--signal)}
.prose a{color:var(--signal);border-bottom:1px solid rgba(255,210,125,.4)}
.prose a:hover{border-bottom-color:var(--signal)}
.prose__meta{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--coast);margin-bottom:32px}

/* ──────────────── CTA BAND ──────────────── */
.ctaBand{
  padding:clamp(48px,7vh,96px) var(--pad);
  border-top:1px solid rgba(236,233,226,.08);
  border-bottom:1px solid rgba(236,233,226,.08);
}
.ctaBand .inner{display:grid;grid-template-columns:1.4fr 1fr;gap:clamp(40px,5vw,96px);align-items:center}
.ctaBand h2{margin:14px 0 0;max-width:18ch}
.ctaBand .ctaBand__right{display:flex;flex-direction:column;gap:18px;align-items:flex-start}
.ctaBand p{color:var(--coast);max-width:42ch;margin:0}

/* ──────────────── RESPONSIVE ──────────────── */
@media (max-width:1100px){
  .security__diagram{grid-template-columns:repeat(3,1fr)}
  .indGrid{grid-template-columns:repeat(2,1fr)}
  .indGrid .ind:nth-child(3n){border-right:1px solid rgba(236,233,226,.08)}
  .indGrid .ind:nth-child(2n){border-right:0}
  .ratecard,.notInc,.indRow,.stepRow,.ctaBand .inner{grid-template-columns:1fr}
  .nav__links{display:none}
  .nav__cta{display:none}
  .nav__menu{display:flex}
}
@media (max-width:960px){
  .stats__grid{grid-template-columns:1fr 1fr}
  .pillars{grid-template-columns:1fr;gap:64px}
  .pillars:hover .pillar{opacity:1}
  .steps{grid-template-columns:1fr 1fr}
  .local,.contact,.tiers,.frameworks,.foot__cols{grid-template-columns:1fr}
  .foot__cols{gap:32px}
  .form__row{grid-template-columns:1fr}
  .progress{display:none}
}
@media (max-width:640px){
  .stats__grid,.steps,.indGrid{grid-template-columns:1fr}
  .stats__grid .stat{padding:18px 0;border-bottom:1px solid rgba(236,233,226,.08)}
  .stats__grid .stat:last-child{border-bottom:0}
  .stats__grid .stat:not(:last-child)::after{display:none}
  .indGrid .ind{border-right:0 !important}
  .security__diagram{grid-template-columns:1fr 1fr}
  .rates,.notInc__list{grid-template-columns:1fr}
  body{cursor:auto}
  .cursor-dot,.cursor-ring{display:none}
  input,textarea,button,a,select{cursor:auto !important}
  .hero__bottom{flex-direction:column;align-items:stretch;gap:18px}
  .foot__mark{font-size:clamp(40px,14vw,90px);letter-spacing:-.03em}
  .glass{padding:24px 20px;border-radius:18px}
}

@media (prefers-reduced-motion: reduce){
  .ticker .dot,.map__pin::before,.map__pin::after,.scrollHint::after,.bg-fallback{animation:none}
  .reveal{opacity:1;transform:none;transition:none}
  .hero__headline span.w{opacity:1;transform:none;transition:none}
}
