*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
:root{--red:#E8163A;--red-d:#C0102E;--navy:#1A2B8F;--nvy-l:#2A4CC8;--white:#FFFFFF;--off:#B8BEDD;--bg:#0B0D18;--card:#0A0D1A;}
html{scroll-behavior:smooth;}
body{background:var(--bg);color:#fff;font-family:'Barlow',sans-serif;overflow-x:hidden;cursor:none;}

/* CURSOR */
.cur-dot{position:fixed;width:10px;height:10px;background:var(--red);border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);transition:width .15s,height .15s;box-shadow:0 0 8px rgba(232,22,58,.8);}
.cur-ring{position:fixed;width:36px;height:36px;border:2px solid rgba(232,22,58,.8);border-radius:50%;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);transition:width .25s,height .25s,border-color .25s;}


/* BG */
.bg-grid{
  position:fixed;inset:0;pointer-events:none;z-index:0;
  background-image:
    linear-gradient(rgba(232,22,58,.028) 1px,transparent 1px),
    linear-gradient(90deg,rgba(232,22,58,.028) 1px,transparent 1px);
  background-size:72px 72px;
  mask-image:radial-gradient(ellipse 80% 80% at 50% 40%,black 30%,transparent 100%);
}
/* warm ambient light — sits behind everything */
.bg-light{
  position:fixed;inset:0;pointer-events:none;z-index:0;
  background:
    /* top-center strong red bloom — primary light */
    radial-gradient(ellipse 90% 55% at 50% -10%,
      rgba(232,22,58,.22) 0%,
      rgba(232,22,58,.08) 45%,
      transparent 70%),
    /* center white-ish lift — the key brightness change */
    radial-gradient(ellipse 60% 50% at 50% 40%,
      rgba(255,220,200,.06) 0%,
      transparent 70%),
    /* left navy accent */
    radial-gradient(ellipse 60% 45% at -5% 50%,
      rgba(26,43,143,.25) 0%,
      transparent 65%),
    /* bottom-right ember */
    radial-gradient(ellipse 55% 40% at 105% 100%,
      rgba(192,16,46,.18) 0%,
      transparent 65%);
}
/* orbs removed */

/* NAV */
/* NAV */
.nav{position:fixed;top:0;left:0;right:0;z-index:900;height:68px;display:flex;align-items:center;justify-content:center;background:rgba(5,7,18,0);backdrop-filter:blur(24px) saturate(180%);border-bottom:1px solid rgba(255,255,255,.07);}
.nav-inner{width:100%;max-width:1280px;display:flex;align-items:center;justify-content:space-between;padding:0 clamp(20px,3vw,48px);gap:20px;}
.nav-logo{display:flex;align-items:center;text-decoration:none;flex-shrink:0;}
.nav-logo-img{height:38px;width:auto;object-fit:contain;mix-blend-mode:screen;transition:filter .2s,transform .2s;}
.nav-logo:hover .nav-logo-img{transform:scale(1.05);}
.nav-links{display:flex;align-items:center;list-style:none;gap:0;flex:1;justify-content:center;}
.nav-links a{font-family:'Barlow Condensed',sans-serif;font-weight:600;font-size:12px;letter-spacing:3px;text-transform:uppercase;color:rgba(255,255,255,.55);text-decoration:none;padding:8px 20px;position:relative;transition:color .2s;}
.nav-links a::after{content:'';position:absolute;bottom:-2px;left:50%;transform:translateX(-50%) scaleX(0);width:18px;height:2px;background:var(--red);border-radius:2px;transition:transform .28s cubic-bezier(.34,1.56,.64,1);}
.nav-links a:hover,.nav-links a.active{color:#fff;}
.nav-links a:hover::after,.nav-links a.active::after{transform:translateX(-50%) scaleX(1);}
.nav-cta{display:inline-flex;align-items:center;gap:9px;padding:11px 24px;color:#fff;text-decoration:none;font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:12px;letter-spacing:2.5px;text-transform:uppercase;border:none;background:var(--red);border-radius:3px;transition:background .2s,transform .15s,box-shadow .2s;flex-shrink:0;}
.nav-cta-icon{width:16px;height:16px;object-fit:contain;flex-shrink:0;filter:brightness(0) invert(1);}
.nav-cta:hover{background:var(--red-d);transform:translateY(-1px);box-shadow:0 6px 20px rgba(232,22,58,.45);}
.nav-burger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:6px;background:none;border:none;}
.nav-burger span{display:block;width:22px;height:1.5px;background:#fff;transition:all .3s;}
.nav-burger.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg);}
.nav-burger.open span:nth-child(2){opacity:0;}
.nav-burger.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg);}
.mobile-nav{position:fixed;top:76px;left:16px;right:16px;background:rgba(5,7,18,.97);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.07);border-radius:14px;padding:10px;z-index:890;transform:translateY(-8px) scale(.98);opacity:0;pointer-events:none;transition:all .3s;display:flex;flex-direction:column;gap:2px;}
.mobile-nav.open{transform:none;opacity:1;pointer-events:all;}
.mobile-nav a{font-family:'Barlow Condensed',sans-serif;font-weight:600;font-size:15px;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,.55);text-decoration:none;padding:13px 16px;border-radius:8px;border-left:2px solid transparent;transition:all .2s;}
.mobile-nav a:hover{color:#fff;background:rgba(255,255,255,.05);border-left-color:var(--red);}
@media(max-width:900px){.nav-links,.nav-cta{display:none;}.nav-burger{display:flex;}}

/* ANIMATIONS */
@keyframes fadeUp{from{opacity:0;transform:translateY(28px);}to{opacity:1;transform:translateY(0);}}
@keyframes fadeIn{from{opacity:0;}to{opacity:1;}}
.reveal{opacity:0;transform:translateY(32px);transition:opacity .75s ease,transform .75s ease;}
.reveal.in{opacity:1;transform:translateY(0);}

/* ══════════════════════════
   HERO — centered frame
══════════════════════════ */
.about-hero{
  position:relative;
  height:100vh;
  max-height:100vh;
  display:flex;align-items:center;justify-content:center;
  padding-top:68px;
  overflow:hidden;
  clip-path:inset(0 0 0 0);
  background:radial-gradient(ellipse 80% 60% at 50% 50%,rgba(255,255,255,.028) 0%,transparent 70%);
}
.hero-diag{position:absolute;inset:0;pointer-events:none;z-index:1;overflow:hidden;}
.hero-diag svg{width:100%;height:100%;opacity:.08;}

.hero-centre{
  position:relative;z-index:3;width:100%;height:100%;
  display:flex;align-items:center;justify-content:center;
  padding:32px clamp(32px,5vw,80px);overflow:visible;
}

.hero-text-frame{
  position:relative;width:100%;max-width:900px;
  padding:clamp(32px,4vh,52px) clamp(40px,5vw,72px);
  display:flex;flex-direction:column;align-items:center;
  text-align:center;overflow:visible;
}
.hero-text-frame::before{
  content:'';position:absolute;inset:0;
  border:1px solid rgba(232,22,58,.3);pointer-events:none;
  transition:border-color .5s;z-index:1;
}
.hero-text-frame::after{
  content:'';position:absolute;inset:-2px;z-index:0;
  opacity:0;pointer-events:none;transition:opacity .4s;
  box-shadow:0 0 0 1px rgba(232,22,58,.0),0 0 20px 2px rgba(232,22,58,.0);
}
.hero-text-frame:hover::before{border-color:rgba(232,22,58,.0);}
.hero-text-frame:hover::after{opacity:1;animation:auroraRing 3s linear infinite;}
@keyframes auroraRing{
  0%{box-shadow:0 0 0 1px rgba(232,22,58,.5),0 0 18px 1px rgba(232,22,58,.18),inset 0 0 0 1px rgba(232,22,58,.08);}
  25%{box-shadow:0 0 0 1px rgba(232,22,58,.3),0 0 28px 4px rgba(232,22,58,.12),inset 0 0 0 1px rgba(26,43,143,.08);}
  50%{box-shadow:0 0 0 1px rgba(232,22,58,.6),0 0 22px 2px rgba(232,22,58,.22),inset 0 0 0 1px rgba(232,22,58,.1);}
  75%{box-shadow:0 0 0 1px rgba(232,22,58,.3),0 0 32px 6px rgba(232,22,58,.1),inset 0 0 0 1px rgba(26,43,143,.06);}
  100%{box-shadow:0 0 0 1px rgba(232,22,58,.5),0 0 18px 1px rgba(232,22,58,.18),inset 0 0 0 1px rgba(232,22,58,.08);}
}
.hf-corner{
  position:absolute;width:14px;height:14px;background:var(--red);z-index:5;
  transition:box-shadow .4s ease,background .3s ease;
}
.hf-corner.tl{top:-7px;left:-7px;transform-origin:top left;}
.hf-corner.tr{top:-7px;right:-7px;transform-origin:top right;}
.hf-corner.bl{bottom:-7px;left:-7px;transform-origin:bottom left;}
.hf-corner.br{bottom:-7px;right:-7px;transform-origin:bottom right;}
.hero-text-frame:hover .hf-corner{background:#ff2a4a;box-shadow:0 0 0 2px rgba(232,22,58,.3),0 0 12px 3px rgba(232,22,58,.6),0 0 28px 6px rgba(232,22,58,.25);}
.hero-text-frame:hover .hf-corner.tl{transition-delay:0s;}
.hero-text-frame:hover .hf-corner.tr{transition-delay:.07s;}
.hero-text-frame:hover .hf-corner.bl{transition-delay:.07s;}
.hero-text-frame:hover .hf-corner.br{transition-delay:.14s;}
.hf-arm{display:none;}

.hero-eyebrow{
  display:inline-flex;align-items:center;
  font-family:'Barlow Condensed',sans-serif;font-size:10px;font-weight:600;
  letter-spacing:5px;text-transform:uppercase;color:var(--red);
  line-height:1.2;margin:0 0 8px;padding:6px 14px;
  border:1px solid rgba(232,22,58,.35);background:rgba(232,22,58,.06);
  position:relative;z-index:2;
  opacity:0;animation:fadeUp .6s ease .2s forwards;
}
.hero-pre{
  font-family:'Barlow Condensed',sans-serif;
  font-size:clamp(12px,1.2vw,16px);font-weight:400;
  letter-spacing:4px;text-transform:uppercase;color:rgba(184,190,221,.38);
  line-height:1.3;margin:0 0 12px;position:relative;z-index:2;
  opacity:0;animation:fadeUp .6s ease .3s forwards;
}
.hero-name{
  font-family:'Oswald',sans-serif;font-weight:700;
  font-size:clamp(48px,7vw,96px);line-height:.95;
  text-transform:uppercase;letter-spacing:-2px;margin:0 0 22px;
  position:relative;z-index:2;white-space:nowrap;
  opacity:0;animation:fadeUp .7s ease .42s forwards;
}
.hero-name em{color:var(--red);font-style:normal;}
.hero-role-wrap{
  display:flex;flex-wrap:wrap;gap:8px;justify-content:center;
  margin:0 0 24px;position:relative;z-index:2;
  opacity:0;animation:fadeUp .6s ease .56s forwards;
}
.role-pill{
  display:inline-flex;align-items:center;gap:6px;padding:6px 14px;
  font-family:'Barlow Condensed',sans-serif;font-size:11px;font-weight:600;
  letter-spacing:2px;text-transform:uppercase;border-radius:3px;
  position:relative;overflow:hidden;cursor:default;line-height:1;transition:transform .2s;
}
.role-pill:hover{transform:translateY(-2px);}
.role-pill.p1{background:rgba(232,22,58,.1);border:1px solid rgba(232,22,58,.3);color:#E8163A;}
.role-pill.p2{background:rgba(26,43,143,.12);border:1px solid rgba(42,76,200,.3);color:#7B9EFF;}
.role-pill.p3{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);color:rgba(184,190,221,.75);}
.pill-icon{width:12px;height:12px;flex-shrink:0;}
.hero-intro{
  font-size:clamp(14px,1.25vw,16px);line-height:1.75;letter-spacing:.2px;
  color:rgba(184,190,221,.62);max-width:460px;margin:0 0 30px;
  position:relative;z-index:2;
  opacity:0;animation:fadeUp .6s ease .78s forwards;
}
.hero-actions{
  display:flex;gap:12px;flex-wrap:wrap;justify-content:center;
  position:relative;z-index:2;
  opacity:0;animation:fadeUp .6s ease .9s forwards;
}
.h-btn-primary{
  display:inline-flex;align-items:center;gap:8px;
  padding:12px 28px;background:var(--red);color:#fff;
  text-decoration:none;font-family:'Barlow Condensed',sans-serif;
  font-weight:700;font-size:11px;letter-spacing:2.5px;text-transform:uppercase;
  border:1.5px solid var(--red);position:relative;overflow:hidden;
  transition:background .2s,transform .15s,box-shadow .2s;
}
.h-btn-primary:hover{background:var(--red-d);transform:translateY(-2px);box-shadow:0 8px 28px rgba(232,22,58,.4);}
.h-btn-secondary{
  display:inline-flex;align-items:center;gap:8px;
  padding:12px 28px;background:transparent;color:#fff;
  text-decoration:none;font-family:'Barlow Condensed',sans-serif;
  font-weight:700;font-size:11px;letter-spacing:2.5px;text-transform:uppercase;
  border:1.5px solid rgba(255,255,255,.15);position:relative;overflow:hidden;
  transition:border-color .2s,transform .15s,background .2s;
}
.h-btn-secondary:hover{border-color:rgba(232,22,58,.5);transform:translateY(-2px);}

/* ── ABOUT SPLIT SECTION (below hero) ── */
.about-split{
  position:relative;
  background:rgba(6,8,15,.6);
}
.about-split::before{
  content:'';position:absolute;left:0;right:0;top:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(232,22,58,.25),transparent);
}
.about-split-grid{
  max-width:1200px;margin:0 auto;
  padding:clamp(36px,4vw,52px) clamp(24px,4vw,64px);
  display:grid;grid-template-columns:1fr 1fr;
  align-items:center;gap:clamp(40px,6vw,100px);
}
.asl-name{
  font-family:'Oswald',sans-serif;font-weight:700;
  font-size:clamp(60px,8vw,120px);
  line-height:.88;text-transform:uppercase;letter-spacing:-3px;margin:0;
}
.asl-name .n1{color:#fff;display:block;}
.asl-name .n2{color:var(--red);display:block;}
.asl-name .n3{color:#fff;display:block;}
.asl-right{display:flex;flex-direction:column;gap:24px;}
.asl-tag{
  display:inline-flex;align-items:center;
  font-family:'Barlow Condensed',sans-serif;font-size:10px;font-weight:600;
  letter-spacing:5px;text-transform:uppercase;color:var(--red);
  border:1px solid rgba(232,22,58,.35);background:rgba(232,22,58,.06);
  padding:6px 14px;width:fit-content;
}
.asl-mission-label{
  font-family:'Barlow Condensed',sans-serif;font-size:10px;font-weight:600;
  letter-spacing:5px;text-transform:uppercase;color:rgba(184,190,221,.35);
  display:flex;align-items:center;gap:8px;margin:0;
}
.asl-mission-label::before{content:'—';color:rgba(232,22,58,.45);}
.asl-body{
  font-size:clamp(14px,1.3vw,16px);line-height:1.9;
  color:rgba(184,190,221,.7);margin:0;
}
.asl-body strong{color:#fff;font-weight:600;}
.asl-roles{display:flex;flex-wrap:wrap;gap:8px;}
.asl-role-tag{
  font-family:'Barlow Condensed',sans-serif;
  font-size:10px;font-weight:600;letter-spacing:3px;text-transform:uppercase;
  color:rgba(184,190,221,.5);border:1px solid rgba(255,255,255,.1);padding:5px 12px;
}
/* vertical divider */
.about-split-grid::before{
  content:'';position:absolute;
  left:50%;top:15%;bottom:15%;width:1px;
  background:linear-gradient(to bottom,transparent,rgba(232,22,58,.18) 30%,rgba(232,22,58,.18) 70%,transparent);
  pointer-events:none;
}
.about-split-grid{position:relative;}
@media(max-width:768px){
  .about-split-grid{grid-template-columns:1fr;}
  .about-split-grid::before{display:none;}
  .asl-name{font-size:clamp(56px,14vw,90px);}
}

/* ══════════════════════════
   SECTION WRAPPER
══════════════════════════ */
section{position:relative;z-index:1;}
.section-inner{max-width:1200px;margin:0 auto;padding:clamp(80px,10vw,140px) clamp(20px,4vw,60px);}
.section-label{display:inline-flex;align-items:center;gap:10px;font-family:'Barlow Condensed',sans-serif;font-size:11px;font-weight:600;letter-spacing:5px;text-transform:uppercase;color:var(--red);margin:0 0 clamp(36px,5vw,60px);}
.section-label-line{display:inline-block;width:16px;height:1.5px;background:var(--red);}
.section-title{font-family:'Oswald',sans-serif;font-weight:700;font-size:clamp(40px,5.5vw,72px);text-transform:uppercase;letter-spacing:2px;line-height:1;}
.section-title em{color:var(--red);font-style:normal;}

/* ══════════════════════════
   ORIGIN STORY
══════════════════════════ */
.origin{background:transparent;}
.origin-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,5vw,80px);align-items:start;}
.origin-body{font-size:clamp(15px,1.5vw,17px);line-height:1.85;color:rgba(184,190,221,.72);}
.origin-body p+p{margin-top:20px;}
.origin-body strong{color:#fff;font-weight:600;}
.stat-strip{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;margin-top:clamp(40px,5vw,64px);border:1px solid rgba(255,255,255,.06);}
.stat-item{padding:clamp(24px,3vw,36px) clamp(20px,2.5vw,30px);background:rgba(10,13,26,.6);position:relative;overflow:hidden;}
.stat-item::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(232,22,58,.06) 0%,transparent 60%);pointer-events:none;}
.stat-num{font-family:'Oswald',sans-serif;font-weight:700;font-size:clamp(40px,5vw,60px);color:#fff;line-height:1;display:flex;align-items:flex-start;gap:3px;}
.stat-num span.plus{color:var(--red);font-size:.85em;}
.stat-sub{font-family:'Barlow Condensed',sans-serif;font-size:clamp(11px,1.1vw,13px);letter-spacing:3px;text-transform:uppercase;color:rgba(184,190,221,.45);margin-top:6px;}
@media(max-width:820px){.origin-grid{grid-template-columns:1fr;}.stat-strip{grid-template-columns:repeat(3,1fr);}}
@media(max-width:520px){.stat-strip{grid-template-columns:1fr 1fr;}}

/* ══════════════════════════
   HOW WE OPERATE — WHEEL
══════════════════════════ */

/* CSS variables for glow system */
:root{
  --glow-core:rgba(232,22,58,1);
  --glow-mid:rgba(232,22,58,.35);
  --glow-soft:rgba(232,22,58,.12);
  --glow-faint:rgba(232,22,58,.05);
}

.operate{background:rgba(6,8,15,.6);}
.operate .section-inner{padding-top:clamp(40px,5vw,64px);padding-bottom:clamp(20px,3vw,36px);}
.operate::before{content:'';position:absolute;left:0;right:0;top:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(232,22,58,.3),transparent);}

/* "How We Work" — plain label above */
.operate .section-label{margin-bottom:10px;}

/* ── BRACKET TITLE BOX ── */
.process-title-wrap{
  display:flex;
  justify-content:center;
  margin-bottom:clamp(40px,5vw,60px);
  overflow:visible;
  padding:12px;
}
.process-title-box{
  position:relative;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:20px 52px;
  background:rgba(26,43,143,.18);
  border:1px solid rgba(232,22,58,.35);
  text-align:center;
  overflow:visible;
}
.process-title-box .section-title{margin:0;position:relative;z-index:1;}

/* hide the ptb-sq divs — all 4 corners handled via SVG outline */
.process-title-box .ptb-sq{ display:none; }

/* draws all 4 corner brackets outside the box with a small gap */
.process-title-box::before{
  content:'';
  position:absolute;
  pointer-events:none;
  top:-8px;left:-8px;right:-8px;bottom:-8px;
  background:
    /* TL horizontal */
    linear-gradient(var(--red),var(--red)) top left / 28px 1.5px no-repeat,
    /* TL vertical */
    linear-gradient(var(--red),var(--red)) top left / 1.5px 28px no-repeat,
    /* TR horizontal */
    linear-gradient(var(--red),var(--red)) top right / 28px 1.5px no-repeat,
    /* TR vertical */
    linear-gradient(var(--red),var(--red)) top right / 1.5px 28px no-repeat,
    /* BL horizontal */
    linear-gradient(var(--red),var(--red)) bottom left / 28px 1.5px no-repeat,
    /* BL vertical */
    linear-gradient(var(--red),var(--red)) bottom left / 1.5px 28px no-repeat,
    /* BR horizontal */
    linear-gradient(var(--red),var(--red)) bottom right / 28px 1.5px no-repeat,
    /* BR vertical */
    linear-gradient(var(--red),var(--red)) bottom right / 1.5px 28px no-repeat;
}
.process-title-box::after{ display:none; }

/* layout grid */
.process-wheel-wrap{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:clamp(32px,4vw,64px);
  align-items:center;
}
@media(max-width:860px){.process-wheel-wrap{grid-template-columns:1fr;}}

/* ─────────────────────────
   ORBIT SYSTEM
   Container: 440×440
   Center: (220,220)
   Main ring radius: 170px  → inset = 220-170 = 50px
   Node dot: 54px (radius 27px)
   Node centers sit at r=170 from center:
     Discovery  (top)      x=220, y=50
     Strategy   (upper-R)  x=382, y=161
     Design     (lower-R)  x=323, y=340
     Development(lower-L)  x=117, y=340
     Launch     (upper-L)  x=58,  y=161
───────────────────────── */
.pw-orbit-col{display:flex;align-items:center;justify-content:center;}
.pw-orbit{
  position:relative;
  width:440px;height:440px;
  flex-shrink:0;
}

/* Layer 1: blurred radial depth glow behind everything */
.pw-orbit::before{
  content:'';
  position:absolute;
  inset:-30px;
  border-radius:50%;
  background:radial-gradient(circle at 50% 50%,
    rgba(232,22,58,.09) 0%,
    rgba(232,22,58,.04) 35%,
    transparent 65%);
  filter:blur(18px);
  pointer-events:none;
  z-index:0;
}

/* Layer 2: faint outer orbit ring (slow rotate) */
.pw-outer-ring{
  position:absolute;
  /* radius 200 → inset = 220-200 = 20 */
  inset:20px;
  border-radius:50%;
  border:1px dotted rgba(232,22,58,.18);
  animation:orbitSpin 32s linear infinite reverse;
  pointer-events:none;
  z-index:1;
}

/* Layer 3: main dashed ring — r=170, inset=50 */
.pw-ring{
  position:absolute;
  inset:50px;
  border-radius:50%;
  /* gradient border via border + box-shadow layering */
  border:1.5px dashed rgba(232,22,58,.5);
  box-shadow:
    0 0 0 1px rgba(232,22,58,.06),
    inset 0 0 0 1px rgba(232,22,58,.04),
    0 0 24px 2px rgba(232,22,58,.08);
  animation:orbitSpin 24s linear infinite;
  pointer-events:none;
  z-index:2;
}

@keyframes orbitSpin{to{transform:rotate(360deg);}}

/* Layer 4: connecting lines from center to each node (drawn in JS via SVG overlay) */
.pw-lines{
  position:absolute;inset:0;
  pointer-events:none;
  z-index:2;
  opacity:.22;
}

/* Layer 5: floating particles */
.pw-particle{
  position:absolute;
  width:3px;height:3px;
  border-radius:50%;
  background:var(--red);
  box-shadow:0 0 6px 2px rgba(232,22,58,.6);
  pointer-events:none;
  z-index:3;
  animation:particleFloat 3s ease-in-out infinite alternate;
}
@keyframes particleFloat{
  from{transform:translateY(0) scale(1);opacity:.7;}
  to{transform:translateY(-8px) scale(1.3);opacity:.2;}
}

/* center hub */
.pw-center{
  position:absolute;
  left:220px;top:220px;
  transform:translate(-50%,-50%);
  width:126px;height:126px;
  border-radius:50%;
  background:radial-gradient(circle at 40% 35%,rgba(232,22,58,.28) 0%,rgba(10,13,26,.97) 58%);
  border:1.5px solid rgba(232,22,58,.55);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  z-index:5;
  box-shadow:
    0 0 0 6px rgba(232,22,58,.06),
    0 0 0 14px rgba(232,22,58,.03),
    0 0 40px rgba(232,22,58,.2),
    inset 0 0 20px rgba(232,22,58,.06);
}
/* pulse ring on center */
.pw-center::before{
  content:'';
  position:absolute;
  inset:-10px;
  border-radius:50%;
  border:1px solid rgba(232,22,58,.3);
  animation:centerPulse 2.8s ease-out infinite;
  pointer-events:none;
}
.pw-center::after{
  content:'';
  position:absolute;
  inset:-22px;
  border-radius:50%;
  border:1px solid rgba(232,22,58,.12);
  animation:centerPulse 2.8s ease-out .7s infinite;
  pointer-events:none;
}
@keyframes centerPulse{
  0%{transform:scale(.92);opacity:.8;}
  60%{opacity:.25;}
  100%{transform:scale(1.18);opacity:0;}
}
.pw-center-label{font-family:'Oswald',sans-serif;font-weight:700;font-size:20px;letter-spacing:5px;text-transform:uppercase;color:#fff;line-height:1;text-shadow:0 0 20px rgba(232,22,58,.4);}
.pw-center-sub{font-family:'Barlow Condensed',sans-serif;font-size:9px;letter-spacing:5px;text-transform:uppercase;color:rgba(232,22,58,.9);margin-top:5px;}

/* ── NODES ──
   transform:translate(-50%,-50%) so left/top = dot CENTER coords
*/
.pw-node{
  position:absolute;
  display:flex;flex-direction:column;align-items:center;gap:0;
  cursor:pointer;
  z-index:6;
  transform:translate(-50%,-50%);
  animation:nodeFloat 3.2s ease-in-out infinite alternate;
  transition:filter .3s;
}
/* stagger floats per node */
.pw-node[data-index="0"]{animation-delay:0s;}
.pw-node[data-index="1"]{animation-delay:.6s;}
.pw-node[data-index="2"]{animation-delay:1.2s;}
.pw-node[data-index="3"]{animation-delay:1.8s;}
.pw-node[data-index="4"]{animation-delay:2.4s;}

@keyframes nodeFloat{
  from{transform:translate(-50%,-50%) translateY(0);}
  to{transform:translate(-50%,-50%) translateY(-5px);}
}

/* hardcoded positions — dot centers on ring r=170 from center(220,220) */
.pw-node[data-index="0"]{left:220px;top:50px;}
.pw-node[data-index="1"]{left:382px;top:161px;}
.pw-node[data-index="2"]{left:323px;top:340px;}
.pw-node[data-index="3"]{left:117px;top:340px;}
.pw-node[data-index="4"]{left:58px; top:161px;}

/* dot */
.pw-node-dot{
  width:54px;height:54px;border-radius:50%;
  background:linear-gradient(135deg,rgba(20,12,26,.98) 0%,rgba(10,13,26,.98) 100%);
  border:1.5px solid rgba(232,22,58,.4);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
  transition:all .35s cubic-bezier(.22,1,.36,1);
  box-shadow:
    0 0 0 5px rgba(10,13,26,.95),   /* dark isolating halo */
    0 0 12px rgba(232,22,58,.15);
}
.pw-node-dot svg{width:22px;height:22px;stroke:rgba(232,22,58,.7);transition:all .3s;flex-shrink:0;}

/* label */
.pw-node-label{
  margin-top:9px;
  font-family:'Barlow Condensed',sans-serif;font-size:10px;font-weight:700;
  letter-spacing:3.5px;text-transform:uppercase;
  color:rgba(184,190,221,.5);
  white-space:nowrap;
  background:rgba(8,10,20,.92);
  padding:4px 10px;
  border:1px solid rgba(255,255,255,.07);
  transition:color .3s,border-color .3s;
}

/* bottom nodes: label above dot */
.pw-node[data-index="2"],.pw-node[data-index="3"]{flex-direction:column-reverse;}
.pw-node[data-index="2"] .pw-node-label,.pw-node[data-index="3"] .pw-node-label{margin-top:0;margin-bottom:9px;}

/* hover */
.pw-node:hover .pw-node-dot{
  border-color:var(--red);
  transform:scale(1.08);
  box-shadow:
    0 0 0 5px rgba(10,13,26,.95),
    0 0 0 7px rgba(232,22,58,.18),
    0 0 24px rgba(232,22,58,.55);
}
.pw-node:hover .pw-node-dot svg{stroke:#fff;filter:drop-shadow(0 0 6px rgba(232,22,58,.8));}
.pw-node:hover .pw-node-label{color:rgba(255,255,255,.85);border-color:rgba(232,22,58,.3);}

/* active */
.pw-node.active .pw-node-dot{
  background:var(--red);
  border-color:var(--red);
  transform:scale(1.08);
  box-shadow:
    0 0 0 5px rgba(10,13,26,.95),
    0 0 0 8px rgba(232,22,58,.2),
    0 0 32px rgba(232,22,58,.7);
}
.pw-node.active .pw-node-dot svg{stroke:#fff;filter:drop-shadow(0 0 8px rgba(255,255,255,.6));}
.pw-node.active .pw-node-label{color:#fff;border-color:rgba(232,22,58,.5);background:rgba(232,22,58,.08);}

/* ── DETAIL PANEL ── */
.pw-detail-col{display:flex;flex-direction:column;justify-content:center;}
.pw-detail-panel{
  position:relative;
  border:1px solid rgba(232,22,58,.25);
  background:rgba(10,13,26,.7);
  padding:clamp(28px,3vw,44px);
  transition:border-color .3s;
}
.pw-detail-panel:hover{border-color:rgba(232,22,58,.45);}
.pw-c{position:absolute;width:8px;height:8px;background:var(--red);}
.pw-c.tl{top:-4px;left:-4px;}.pw-c.tr{top:-4px;right:-4px;}
.pw-c.bl{bottom:-4px;left:-4px;}.pw-c.br{bottom:-4px;right:-4px;}
.pw-detail-content{display:flex;flex-direction:column;gap:14px;}
.pw-step-counter{font-family:'Barlow Condensed',sans-serif;font-size:11px;font-weight:600;letter-spacing:4px;text-transform:uppercase;color:var(--red);}
.pw-detail-title{font-family:'Oswald',sans-serif;font-weight:700;font-size:clamp(26px,3vw,36px);text-transform:uppercase;letter-spacing:1px;color:#fff;line-height:1;}
.pw-detail-desc{font-size:clamp(13px,1.3vw,15px);line-height:1.85;color:rgba(184,190,221,.65);}
.pw-detail-tags{display:flex;flex-wrap:wrap;gap:8px;}
.pw-detail-tags span{font-family:'Barlow Condensed',sans-serif;font-size:11px;letter-spacing:2px;text-transform:uppercase;padding:4px 12px;border:1px solid rgba(232,22,58,.25);color:rgba(232,22,58,.75);}
.pw-dots{display:flex;gap:8px;margin-top:4px;}
.pw-dot-item{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,.15);transition:background .3s,transform .3s;cursor:pointer;}
.pw-dot-item.active{background:var(--red);transform:scale(1.5);}
.pw-detail-content.fade-out{opacity:0;transform:translateY(8px);transition:opacity .15s,transform .15s;}
.pw-detail-content.fade-in{opacity:1;transform:translateY(0);transition:opacity .25s .05s,transform .25s .05s;}

/* ══════════════════════════
   SKILLS
══════════════════════════ */
.skills-frame{
  position:relative;
  margin-top:clamp(40px,5vw,64px);
  border:1px solid rgba(232,22,58,.25);
  padding:clamp(24px,2.5vw,36px) clamp(28px,3.5vw,48px) clamp(20px,2vw,28px);
  background:rgba(10,13,26,.45);
  transition:border-color .35s;
}
.skills-frame:hover{border-color:rgba(232,22,58,.45);}
.sf-corner{
  position:absolute;width:10px;height:10px;background:var(--red);
  transition:box-shadow .35s;
}
.skills-frame:hover .sf-corner{box-shadow:0 0 0 2px rgba(232,22,58,.2),0 0 10px 2px rgba(232,22,58,.5);}
.sf-corner.tl{top:-5px;left:-5px;}
.sf-corner.tr{top:-5px;right:-5px;}
.sf-corner.bl{bottom:-5px;left:-5px;}
.sf-corner.br{bottom:-5px;right:-5px;}
.skills-layout{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,5vw,80px);}
.skill-category{margin-bottom:clamp(20px,2.5vw,28px);}.skill-category:last-child{margin-bottom:0;}
.skill-cat-title{font-family:'Barlow Condensed',sans-serif;font-weight:600;font-size:11px;letter-spacing:4px;text-transform:uppercase;color:rgba(184,190,221,.45);margin-bottom:20px;display:flex;align-items:center;gap:8px;}
.skill-cat-title::after{content:'';flex:1;height:1px;background:rgba(255,255,255,.07);}
.skill-bar-row{margin-bottom:14px;}
.skill-bar-head{display:flex;justify-content:space-between;margin-bottom:7px;}
.skill-bar-name{font-family:'Barlow',sans-serif;font-weight:500;font-size:clamp(13px,1.3vw,15px);color:#fff;}
.skill-bar-pct{font-family:'JetBrains Mono',monospace;font-size:12px;color:var(--red);}
.skill-bar-track{height:3px;background:rgba(255,255,255,.06);overflow:hidden;}
.skill-bar-fill{height:100%;background:linear-gradient(90deg,var(--navy),var(--red));transform-origin:left;transform:scaleX(0);transition:transform 1.2s cubic-bezier(.22,1,.36,1);}
.tools-cloud{display:flex;flex-wrap:wrap;gap:10px;margin-top:8px;}
.tool-chip{font-family:'Barlow Condensed',sans-serif;font-size:12px;letter-spacing:2px;text-transform:uppercase;padding:7px 16px;background:rgba(26,43,143,.12);border:1px solid rgba(26,43,143,.3);color:rgba(184,190,221,.75);transition:all .2s;}
.tool-chip:hover{background:rgba(26,43,143,.3);border-color:var(--nvy-l);color:#fff;transform:translateY(-2px);}
@media(max-width:820px){.skills-layout{grid-template-columns:1fr;}}

/* ══════════════════════════
   TEAM
══════════════════════════ */
.team{background:rgba(6,8,15,.6);}
.team::before{content:'';position:absolute;left:0;right:0;top:0;height:1px;background:linear-gradient(90deg,transparent,rgba(26,43,143,.4),transparent);}
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(16px,2vw,24px);margin-top:clamp(40px,5vw,64px);}
.team-card{position:relative;overflow:hidden;background:var(--card);border:1px solid rgba(255,255,255,.06);cursor:none;transition:border-color .3s,transform .3s;}
.team-card:hover{border-color:rgba(232,22,58,.35);transform:translateY(-6px);}
.team-photo-placeholder{width:100%;aspect-ratio:3/4;background:linear-gradient(135deg,rgba(26,43,143,.4) 0%,rgba(10,13,26,.8) 100%);display:flex;align-items:center;justify-content:center;}
.team-photo-placeholder span{font-family:'Oswald',sans-serif;font-weight:700;font-size:40px;color:rgba(255,255,255,.15);}
.team-info{padding:16px 18px 20px;}
.team-name{font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:17px;letter-spacing:1px;text-transform:uppercase;color:#fff;margin-bottom:4px;}
.team-role{font-family:'Barlow Condensed',sans-serif;font-size:11px;letter-spacing:3px;text-transform:uppercase;color:var(--red);}
.team-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--red),var(--navy));transform:scaleX(0);transform-origin:left;transition:transform .4s cubic-bezier(.22,1,.36,1);}
.team-card:hover::after{transform:scaleX(1);}
@media(max-width:1000px){.team-grid{grid-template-columns:repeat(3,1fr);}}
@media(max-width:680px){.team-grid{grid-template-columns:repeat(2,1fr);}}

/* ══════════════════════════
   VALUES
══════════════════════════ */
.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2vw,24px);margin-top:clamp(40px,5vw,64px);}
.val-card{padding:clamp(28px,3vw,40px);background:var(--card);border:1px solid rgba(255,255,255,.06);position:relative;overflow:hidden;transition:border-color .3s,transform .3s;}
.val-card:hover{border-color:rgba(232,22,58,.25);transform:translateY(-4px);}
.val-icon{width:42px;height:42px;margin-bottom:20px;display:flex;align-items:center;justify-content:center;border:1.5px solid rgba(232,22,58,.3);}
.val-icon svg{width:20px;height:20px;stroke:var(--red);fill:none;stroke-width:1.5;}
.val-title{font-family:'Oswald',sans-serif;font-weight:700;font-size:clamp(18px,2vw,22px);text-transform:uppercase;letter-spacing:1px;margin-bottom:12px;}
.val-desc{font-size:clamp(13px,1.3vw,15px);color:rgba(184,190,221,.6);line-height:1.8;}
.val-card::before{content:'';position:absolute;top:0;left:0;width:3px;height:0;background:var(--red);transition:height .4s cubic-bezier(.22,1,.36,1);}
.val-card:hover::before{height:100%;}
@media(max-width:900px){.values-grid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:580px){.values-grid{grid-template-columns:1fr;}}

/* ══════════════════════════
   CTA BANNER
══════════════════════════ */
.cta-banner{position:relative;z-index:1;}
.cta-inner{max-width:1200px;margin:0 auto;padding:clamp(60px,8vw,100px) clamp(20px,4vw,60px);}

.cta-frame{
  position:relative;
  padding:10px;
  transition:transform .35s cubic-bezier(.25,.46,.45,.94);
}

/* L-bracket corners — use box-shadow glow on hover, not filter */
.cta-bracket{
  position:absolute;
  width:24px;height:24px;
  opacity:.45;
  transition:opacity .3s ease, box-shadow .3s ease;
}
.cta-bracket.tl{top:0;left:0;   border-top:2px solid var(--red);border-left:2px solid var(--red);}
.cta-bracket.tr{top:0;right:0;  border-top:2px solid var(--red);border-right:2px solid var(--red);}
.cta-bracket.bl{bottom:0;left:0; border-bottom:2px solid var(--red);border-left:2px solid var(--red);}
.cta-bracket.br{bottom:0;right:0;border-bottom:2px solid var(--red);border-right:2px solid var(--red);}

.cta-frame:hover{transform:translateY(-4px);}
.cta-frame:hover .cta-bracket{opacity:1;}

/* Inner card */
.cta-box{
  position:relative;
  background:linear-gradient(135deg,rgba(26,43,143,.22) 0%,rgba(10,13,26,.85) 50%,rgba(192,16,46,.18) 100%);
  border:1px solid rgba(232,22,58,.2);
  padding:clamp(40px,5vw,72px);
  display:flex;align-items:center;justify-content:space-between;gap:32px;flex-wrap:wrap;
  overflow:hidden;
  transition:border-color .35s ease,box-shadow .35s ease;
}

/* Hover — border brightens + deep shadow lift only, clean and minimal */
.cta-frame:hover .cta-box{
  border-color:rgba(232,22,58,.55);
  box-shadow:
    0 0 0 1px rgba(232,22,58,.08),
    0 8px 32px rgba(0,0,0,.5),
    0 0 60px rgba(232,22,58,.08);
}

.cta-eyebrow{font-family:'Barlow Condensed',sans-serif;font-size:11px;letter-spacing:5px;text-transform:uppercase;color:var(--red);margin-bottom:10px;}
.cta-title{font-family:'Oswald',sans-serif;font-weight:700;font-size:clamp(32px,4vw,54px);text-transform:uppercase;letter-spacing:-1px;line-height:1.1;}
.cta-title em{color:var(--red);font-style:normal;}
.cta-sub{font-size:clamp(14px,1.4vw,16px);color:rgba(184,190,221,.6);margin-top:12px;max-width:440px;line-height:1.7;}
.cta-actions{display:flex;gap:12px;flex-wrap:wrap;flex-shrink:0;}
.btn-primary{display:inline-flex;align-items:center;gap:8px;padding:14px 28px;background:var(--red);color:#fff;text-decoration:none;font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:12px;letter-spacing:2.5px;text-transform:uppercase;border:1.5px solid var(--red);transition:background .2s,transform .15s,box-shadow .2s;white-space:nowrap;}
.btn-primary:hover{background:var(--red-d);transform:translateY(-2px);box-shadow:0 6px 24px rgba(232,22,58,.4);}
.btn-secondary{display:inline-flex;align-items:center;gap:8px;padding:14px 28px;background:transparent;color:#fff;text-decoration:none;font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:12px;letter-spacing:2.5px;text-transform:uppercase;border:1.5px solid rgba(255,255,255,.2);transition:all .2s;white-space:nowrap;}
.btn-secondary:hover{border-color:rgba(255,255,255,.5);transform:translateY(-2px);}


/* ══════════════════════════
   VALUES NODE MAP
══════════════════════════ */
.vmap-section{ background:rgba(6,8,15,.5); }
.vmap-section .section-inner{ padding-top:clamp(36px,4vw,52px);padding-bottom:clamp(36px,4vw,52px); }
.vmap-section::before{content:'';position:absolute;left:0;right:0;top:0;height:1px;background:linear-gradient(90deg,transparent,rgba(26,43,143,.4),transparent);}

.vmap-outer{
  position:relative;
  width:100%;
  margin-top:clamp(40px,5vw,64px);
}
.vmap-canvas{
  position:absolute;
  top:0;left:0;
  width:100%;height:100%;
  pointer-events:none;
  z-index:0;
  overflow:visible;
}
.vmap-layout{
  display:grid;
  grid-template-columns:1fr 120px 1fr;
  align-items:center;
  gap:0;
  position:relative;
  z-index:2;
}
/* LEFT & RIGHT columns */
.vmap-col{
  display:flex;
  flex-direction:column;
  gap:14px;
}
.vmap-col-left{ padding-right:32px; }
.vmap-col-right{ padding-left:32px; }

/* CENTER hub */
.vmap-center{
  display:flex;
  align-items:center;
  justify-content:center;
}
.vmap-hub{
  position:relative;
  width:110px;height:110px;
  display:flex;align-items:center;justify-content:center;
}
/* deep ambient glow */
.vmap-hub-glow{
  position:absolute;inset:-30px;
  border-radius:50%;
  background:radial-gradient(circle,rgba(26,43,143,.55) 0%,rgba(232,22,58,.1) 40%,transparent 70%);
  animation:hubPulse 3s ease-in-out infinite;
  pointer-events:none;
}
@keyframes hubPulse{
  0%,100%{opacity:.6;transform:scale(1);}
  50%{opacity:1;transform:scale(1.15);}
}
/* outer slow ring with tick marks */
.vmap-hub-ring-outer{
  position:absolute;inset:-18px;
  border-radius:50%;
  border:1px solid rgba(232,22,58,.15);
  animation:orbitSpin 28s linear infinite;
  pointer-events:none;
}
/* tick marks on outer ring */
.vmap-hub-ring-outer::before,.vmap-hub-ring-outer::after{
  content:'';
  position:absolute;
  background:var(--red);
  border-radius:2px;
}
.vmap-hub-ring-outer::before{ width:6px;height:2px;top:50%;left:-1px;transform:translateY(-50%); }
.vmap-hub-ring-outer::after{ width:6px;height:2px;top:50%;right:-1px;transform:translateY(-50%); }
/* fast dashed inner ring */
.vmap-hub-ring{
  position:absolute;inset:-6px;
  border-radius:50%;
  border:1.5px dashed rgba(232,22,58,.45);
  animation:orbitSpin 8s linear infinite reverse;
  pointer-events:none;
}
/* orbiting particle dots */
.vmap-hub-orbit{
  position:absolute;inset:-14px;
  border-radius:50%;
  animation:orbitSpin 5s linear infinite;
  pointer-events:none;
}
.vmap-hub-orbit::before,.vmap-hub-orbit::after{
  content:'';
  position:absolute;
  width:5px;height:5px;
  border-radius:50%;
  background:var(--red);
  box-shadow:0 0 6px rgba(232,22,58,.8);
}
.vmap-hub-orbit::before{ top:0;left:50%;transform:translateX(-50%); }
.vmap-hub-orbit::after{ bottom:0;left:50%;transform:translateX(-50%);background:rgba(42,76,200,1);box-shadow:0 0 6px rgba(42,76,200,.9); }
/* second orbit at 90deg offset */
.vmap-hub-orbit2{
  position:absolute;inset:-14px;
  border-radius:50%;
  animation:orbitSpin 5s linear infinite;
  animation-delay:-2.5s;
  pointer-events:none;
}
.vmap-hub-orbit2::before,.vmap-hub-orbit2::after{
  content:'';
  position:absolute;
  width:4px;height:4px;
  border-radius:50%;
  background:rgba(42,76,200,.8);
  box-shadow:0 0 5px rgba(42,76,200,.7);
}
.vmap-hub-orbit2::before{ top:0;left:50%;transform:translateX(-50%); }
.vmap-hub-orbit2::after{ bottom:0;left:50%;transform:translateX(-50%);background:rgba(232,22,58,.7); }
/* main sphere */
.vmap-hub-body{
  width:80px;height:80px;
  border-radius:50%;
  background:
    radial-gradient(circle at 30% 30%,rgba(80,110,255,.9) 0%,rgba(26,43,143,.8) 35%,rgba(10,13,26,1) 70%);
  border:1.5px solid rgba(232,22,58,.6);
  display:flex;align-items:center;justify-content:center;
  box-shadow:
    0 0 0 1px rgba(232,22,58,.1),
    0 0 20px rgba(232,22,58,.25),
    0 0 50px rgba(26,43,143,.4),
    inset 0 0 24px rgba(26,43,143,.5),
    inset 0 2px 4px rgba(255,255,255,.08);
  position:relative;z-index:1;
  animation:hubCorePulse 4s ease-in-out infinite;
}
.vmap-hub-body svg{width:36px;height:36px;stroke:#fff;opacity:.95;fill:none;stroke-width:1.4;}
@keyframes hubCorePulse{
  0%,100%{box-shadow:0 0 0 1px rgba(232,22,58,.1),0 0 20px rgba(232,22,58,.25),0 0 50px rgba(26,43,143,.4),inset 0 0 24px rgba(26,43,143,.5);}
  50%{box-shadow:0 0 0 1px rgba(232,22,58,.2),0 0 32px rgba(232,22,58,.4),0 0 70px rgba(26,43,143,.55),inset 0 0 32px rgba(26,43,143,.65);}
}
/* PRSN wordmark inside hub */
.vmap-hub-body .hub-label{
  font-family:'Oswald',sans-serif;
  font-weight:700;
  font-size:13px;
  letter-spacing:3px;
  color:#fff;
  text-transform:uppercase;
  pointer-events:none;
  text-shadow:0 0 10px rgba(255,255,255,.4);
}
.vmap-hub-body .hub-label em{
  color:var(--red);
  font-style:normal;
}

/* NODE CARDS — no overflow:hidden so tooltip isn't clipped */
.vmap-node{
  position:relative;
  display:flex;
  align-items:center;
  gap:12px;
  padding:12px 14px;
  background:rgba(8,11,24,.9);
  border:1px solid rgba(255,255,255,.07);
  border-radius:10px;
  cursor:pointer;
  transition:border-color .25s,box-shadow .25s,transform .2s;
  min-height:60px;
  z-index:1;
}
.vmap-node:hover{
  border-color:rgba(232,22,58,.45);
  box-shadow:0 6px 28px rgba(232,22,58,.14),inset 0 0 0 1px rgba(232,22,58,.08);
  transform:translateY(-3px);
  z-index:100;
}
/* icon circle */
.vmap-node-icon{
  width:38px;height:38px;flex-shrink:0;
  border-radius:50%;
  background:rgba(26,43,143,.28);
  border:1.5px solid rgba(42,76,200,.38);
  display:flex;align-items:center;justify-content:center;
  transition:background .25s,border-color .25s,box-shadow .25s;
}
.vmap-node:hover .vmap-node-icon{
  background:rgba(232,22,58,.14);
  border-color:rgba(232,22,58,.5);
  box-shadow:0 0 14px rgba(232,22,58,.22);
}
.vmap-node-icon svg{
  width:16px;height:16px;stroke:rgba(184,190,221,.7);
  transition:stroke .25s;fill:none;stroke-width:1.5;
}
.vmap-node:hover .vmap-node-icon svg{ stroke:#fff; }

/* text */
.vmap-node-info{ flex:1;min-width:0; }
.vmap-node-label{
  font-family:'Barlow Condensed',sans-serif;
  font-size:9px;font-weight:600;letter-spacing:3px;
  text-transform:uppercase;color:rgba(232,22,58,.55);
  display:block;margin-bottom:2px;
}
.vmap-node-title{
  font-family:'Barlow Condensed',sans-serif;
  font-size:13px;font-weight:700;letter-spacing:1px;
  text-transform:uppercase;color:#fff;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
/* + button */
.vmap-node-btn{
  width:22px;height:22px;flex-shrink:0;
  border:1px solid rgba(255,255,255,.13);
  border-radius:5px;
  display:flex;align-items:center;justify-content:center;
  color:rgba(255,255,255,.3);
  font-size:15px;line-height:1;
  transition:all .2s;
  font-family:'Barlow',sans-serif;font-weight:300;
}
.vmap-node:hover .vmap-node-btn{
  border-color:rgba(232,22,58,.5);
  color:var(--red);
  background:rgba(232,22,58,.08);
}

/* ── TOOLTIP — elegant panel that appears below the node ── */
.vmap-tooltip{
  position:absolute;
  top:calc(100% + 8px);
  left:0;right:0;
  background:rgba(4,6,18,.98);
  border:1px solid rgba(232,22,58,.3);
  border-top:2px solid var(--red);
  border-radius:0 0 10px 10px;
  padding:14px 16px;
  pointer-events:none;
  opacity:0;
  transform:translateY(-4px);
  transition:opacity .22s,transform .22s;
  z-index:200;
  box-shadow:0 16px 40px rgba(0,0,0,.8),0 0 0 1px rgba(0,0,0,.5);
}
.vmap-tooltip p{
  font-family:'Barlow',sans-serif;
  font-size:13px;
  line-height:1.75;
  color:#d0d4ec;
  margin:0;
  font-weight:400;
}
.vmap-node:hover .vmap-tooltip{
  opacity:1;
  transform:translateY(0);
}

@media(max-width:860px){
  .vmap-layout{grid-template-columns:1fr;gap:32px;}
  .vmap-col-left,.vmap-col-right{padding:0;}
  .vmap-canvas{display:none;}
  .vmap-center{order:-1;}
}
/* PAGE NAV DOTS */
.pg-dot{display:none;}

/* ══════════════════════════
   FOOTER
══════════════════════════ */
.footer{position:relative;z-index:1;border-top:1px solid rgba(255,255,255,.07);}
.footer-inner{max-width:1280px;margin:0 auto;padding:clamp(52px,6vw,80px) clamp(20px,4vw,60px) clamp(28px,3vw,40px);}
.footer-top{display:grid;grid-template-columns:260px 1fr;align-items:flex-start;gap:clamp(40px,6vw,100px);margin-bottom:clamp(36px,4vw,52px);}
.footer-logo-img{height:42px;width:auto;margin-bottom:20px;display:block;mix-blend-mode:screen;}
.footer-tagline{font-family:'Barlow',sans-serif;font-size:13px;color:rgba(184,190,221,.42);line-height:1.75;margin-bottom:24px;max-width:250px;}
.footer-socials{display:flex;gap:20px;align-items:center;}
.footer-socials a{display:flex;align-items:center;justify-content:center;text-decoration:none;background:none;border:none;padding:0;width:22px;height:22px;flex-shrink:0;transition:transform .22s,filter .22s;}
.footer-socials a img{width:100%;height:100%;object-fit:contain;display:block;filter:brightness(0) invert(1);opacity:.45;transition:opacity .22s,transform .22s;}
.footer-socials a:hover img{opacity:1;transform:scale(1.2);}
.footer-socials a:hover{filter:drop-shadow(0 0 5px rgba(232,22,58,.65));}
.footer-links{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,3vw,48px);}
.footer-col-title{font-family:'Barlow Condensed',sans-serif;font-size:10px;letter-spacing:4.5px;text-transform:uppercase;color:rgba(184,190,221,.32);margin-bottom:20px;padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,.06);}
.footer-col a{display:block;font-family:'Barlow',sans-serif;font-size:14px;color:rgba(184,190,221,.5);text-decoration:none;margin-bottom:13px;transition:color .2s;}
.footer-col a:hover{color:#fff;}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:24px;border-top:1px solid rgba(255,255,255,.05);flex-wrap:wrap;gap:12px;}
.footer-copy{font-family:'Barlow Condensed',sans-serif;font-size:11px;letter-spacing:1.5px;color:rgba(184,190,221,.28);text-transform:uppercase;}
.footer-made{display:flex;align-items:center;gap:6px;font-family:'Barlow Condensed',sans-serif;font-size:11px;letter-spacing:2px;text-transform:uppercase;color:rgba(184,190,221,.22);}
.footer-made svg{color:rgba(184,190,221,.28);}
.footer-made span{color:var(--red);}
@media(max-width:900px){.footer-top{grid-template-columns:1fr;}.footer-links{grid-template-columns:repeat(2,1fr);}}

/* ══════════════════════════════════════════════════════════
   MOBILE RESPONSIVE — complete rewrite
══════════════════════════════════════════════════════════ */

/* ── ≤ 1024px: large tablet ── */
@media(max-width:1024px){
  .team-grid{grid-template-columns:repeat(3,1fr);}
  .values-grid{grid-template-columns:repeat(2,1fr);}
  .process-wheel-wrap{gap:40px;}
}

/* ── ≤ 860px: tablet ── */
@media(max-width:860px){
  .process-wheel-wrap{grid-template-columns:1fr;}
  .pw-orbit-col{display:flex;justify-content:center;}
  .pw-orbit{width:320px;height:320px;}
  .pw-detail-panel{margin-top:0;}

  .origin-grid{grid-template-columns:1fr;}
  .stat-strip{grid-template-columns:repeat(3,1fr);}

  .footer-top{grid-template-columns:1fr;gap:32px;}
  .footer-links{grid-template-columns:repeat(3,1fr);}
}

/* ── ≤ 768px: mobile ── */
@media(max-width:768px){
  /* About split */
  .about-split-grid{grid-template-columns:1fr;gap:32px;}
  .about-split-grid::before{display:none;}
  .asl-name{font-size:clamp(52px,14vw,88px);}

  /* Hero name wrap */
  .hero-name{font-size:clamp(38px,10vw,64px);white-space:normal;}

  /* Skills */
  .skills-layout{grid-template-columns:1fr;}

  /* Team */
  .team-grid{grid-template-columns:repeat(2,1fr);}

  /* Values */
  .values-grid{grid-template-columns:repeat(2,1fr);}

  /* CTA — stack vertically */
  .cta-box{flex-direction:column;align-items:flex-start;gap:28px;}
  .cta-actions{width:100%;}

  /* Footer links */
  .footer-links{grid-template-columns:repeat(2,1fr);}
}

/* ── ≤ 580px: small mobile ── */
@media(max-width:580px){
  /* Cursor — useless on touch */
  .cur-dot,.cur-ring{display:none;}
  body{cursor:auto;}

  /* Nav */
  .nav{height:60px;}
  .nav-inner{padding:0 16px;}
  .nav-logo-img{height:30px;}

  /* Hero */
  .hero-text-frame{padding:20px 16px;}
  .hero-name{font-size:clamp(34px,11vw,52px);letter-spacing:-1px;}
  .hero-eyebrow{font-size:9px;letter-spacing:3px;padding:5px 10px;}
  .hero-intro{font-size:14px;max-width:100%;}
  .hero-actions{flex-direction:column;width:100%;}
  .h-btn-primary,.h-btn-secondary{width:100%;justify-content:center;padding:13px 20px;}
  .role-pill{font-size:10px;padding:4px 10px;}
  .hf-corner{width:10px;height:10px;}
  .hf-corner.tl{top:-5px;left:-5px;}
  .hf-corner.tr{top:-5px;right:-5px;left:auto;}
  .hf-corner.bl{bottom:-5px;left:-5px;top:auto;}
  .hf-corner.br{bottom:-5px;right:-5px;top:auto;left:auto;}

  /* About split */
  .about-split-grid{padding:32px 16px;}
  .asl-name{font-size:clamp(46px,14vw,72px);letter-spacing:-2px;}
  .asl-body{font-size:14px;}
  .asl-right{gap:16px;}

  /* Section */
  .section-inner{padding:clamp(48px,8vw,72px) 16px;}
  .section-title{font-size:clamp(28px,9vw,44px);}

  /* Stat strip */
  .stat-strip{grid-template-columns:1fr;}
  .stat-item{padding:20px 16px;}

  /* Process wheel */
  .pw-orbit{width:260px;height:260px;}
  .pw-detail-panel{padding:20px 16px;}

  /* Skills */
  .skills-frame{padding:20px 16px;}
  .tool-chip{font-size:10px;padding:5px 10px;letter-spacing:1px;}

  /* Team */
  .team-grid{grid-template-columns:1fr 1fr;}

  /* Values */
  .values-grid{grid-template-columns:1fr;}

  /* Values map */
  .vmap-layout{grid-template-columns:1fr;gap:12px;}
  .vmap-canvas{display:none;}
  .vmap-center{display:flex;justify-content:center;margin-bottom:4px;}
  .vmap-col-left,.vmap-col-right{gap:10px;}

  /* CTA */
  .cta-inner{padding:40px 16px;}
  .cta-frame{padding:8px;}
  .cta-box{padding:28px 20px;gap:24px;}
  .cta-title{font-size:clamp(26px,9vw,38px);}
  .cta-sub{font-size:13px;}
  .cta-actions{flex-direction:column;gap:10px;}
  .btn-primary,.btn-secondary{width:100%;justify-content:center;padding:13px 20px;}

  /* Footer */
  .footer-inner{padding:40px 16px 24px;}
  .footer-links{grid-template-columns:1fr 1fr;}
  .footer-bottom{flex-direction:column;align-items:flex-start;gap:8px;text-align:left;}

  /* Vmap section */
  .vmap-section .section-inner{padding:32px 16px;}
}

/* ── ≤ 400px: very small phones ── */
@media(max-width:400px){
  .hero-name{font-size:clamp(30px,12vw,44px);}
  .asl-name{font-size:clamp(40px,14vw,60px);}
  .team-grid{grid-template-columns:1fr;}
  .footer-links{grid-template-columns:1fr;}
  .stat-strip{grid-template-columns:1fr;}
  .cta-title{font-size:clamp(24px,9vw,34px);}
}

/* ══════════════════════════════════════════
   FAQ / YOU ASK WE ANSWER
══════════════════════════════════════════ */
.faq-section{
  position:relative;z-index:1;
  padding:clamp(80px,10vw,130px) clamp(24px,6vw,100px);
  background:rgba(6,7,14,.6);
  border-top:1px solid rgba(255,255,255,.05);
}
.faq-inner{max-width:760px;margin:0 auto;}
.faq-right{display:flex;flex-direction:column;gap:0;}
.faq-item{border-bottom:1px solid rgba(255,255,255,.07);overflow:hidden;}
.faq-item:first-child{border-top:1px solid rgba(255,255,255,.07);}
.faq-q{
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:20px 0;cursor:pointer;
  font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:clamp(15px,1.6vw,18px);
  letter-spacing:.5px;text-transform:uppercase;color:rgba(255,255,255,.65);
  transition:color .2s;user-select:none;
}
.faq-q:hover,.faq-item.open .faq-q{color:#fff;}
.faq-icon{
  width:28px;height:28px;flex-shrink:0;
  border:1px solid rgba(255,255,255,.1);
  display:flex;align-items:center;justify-content:center;
  transition:border-color .25s,background .25s,transform .35s cubic-bezier(.22,1,.36,1);
}
.faq-item.open .faq-icon{border-color:rgba(232,22,58,.5);background:rgba(232,22,58,.08);transform:rotate(45deg);}
.faq-icon svg{width:12px;height:12px;stroke:#fff;fill:none;stroke-width:2;}
.faq-a{
  max-height:0;overflow:hidden;
  transition:max-height .45s cubic-bezier(.22,1,.36,1),padding .35s ease;
  font-size:clamp(13px,1.1vw,14px);font-weight:300;line-height:1.8;
  color:rgba(255,255,255,.45);padding:0;
}
.faq-item.open .faq-a{max-height:200px;padding-bottom:20px;}
.faq-heading{
  font-family:'Oswald',sans-serif;font-weight:700;
  font-size:clamp(38px,5vw,64px);text-transform:uppercase;
  letter-spacing:-2px;line-height:.92;color:#fff;margin-bottom:20px;
}
.faq-heading em{color:#E8163A;font-style:normal;}
.faq-label{
  font-family:'Barlow Condensed',sans-serif;font-size:10px;font-weight:600;
  letter-spacing:5px;text-transform:uppercase;color:rgba(232,22,58,.8);
  display:flex;align-items:center;gap:8px;margin-bottom:12px;
}

/* ── MOBILE SAFE-AREA & TOUCH FIXES ── */
@media(max-width:640px){
  .back-to-top{
    bottom:calc(20px + env(safe-area-inset-bottom,0px));
    right:20px;
  }
  .footer-bottom{
    padding-bottom:calc(24px + env(safe-area-inset-bottom,0px));
  }
  /* hide custom cursor on touch */
  .cur-dot,.cur-ring{display:none;}
  body{cursor:auto;}
}
