/* =========================================================
   TRINETRA — Shared design system
   Palette: #161619 base · #FFFFFF ink · #2D2DC3 brand · #FF66FF signal
   ========================================================= */
:root{
  --bg-void:        #161619;
  --bg-surface:     #1d1d22;
  --bg-panel:       #1f1f26;
  --bg-deep:        #0e0e10;

  --brand:          #2D2DC3;   /* structural — CTAs, deep accents */
  --brand-bright:   #4747e0;   /* hover lift */
  --signal:         #FF66FF;   /* energetic — live, glows, highlights */
  --signal-dim:     rgba(255, 102, 255, 0.14);
  --signal-glow:    rgba(255, 102, 255, 0.5);

  --ink-primary:    #FFFFFF;
  --ink-secondary:  rgba(255, 255, 255, 0.58);
  --ink-ghost:      rgba(255, 255, 255, 0.16);
  --ink-faint:      rgba(255, 255, 255, 0.08);

  --threat-red:     #FF2B2B;
  --trace-line:     rgba(255, 102, 255, 0.28);
  --border-dim:     rgba(255, 255, 255, 0.07);

  --font-display:   'Bebas Neue', sans-serif;
  --font-editorial: 'DM Serif Display', serif;
  --font-mono:      'IBM Plex Mono', monospace;
  --font-body:      'Syne', sans-serif;

  --fs-display-xl:  clamp(5rem, 11vw, 13rem);
  --fs-display-lg:  clamp(3rem, 6vw, 7rem);
  --fs-display-md:  clamp(2rem, 3vw, 3.5rem);
  --fs-body-lg:     clamp(1rem, 1.2vw, 1.2rem);
  --fs-body-sm:     .85rem;
  --fs-mono:        .78rem;

  --lh-display:     .9;
  --lh-body:        1.65;
  --ls-mono:        .15em;

  --ease-out-expo:  cubic-bezier(.16,1,.3,1);
  --ease-in-out:    cubic-bezier(.76,0,.24,1);
  --spring:         cubic-bezier(.34,1.56,.64,1);
  --duration-fast:  180ms;
  --duration-base:  400ms;
  --duration-slow:  800ms;
  --duration-crawl: 1400ms;

  --container:      1440px;
  --pad-x:          48px;
}
@media (max-width:768px){ :root{ --pad-x:24px; } }

/* Reset */
*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; }
body{
  background:var(--bg-void);
  color:var(--ink-primary);
  font-family:var(--font-body);
  font-size:var(--fs-body-lg);
  line-height:var(--lh-body);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
  cursor:none;
}
a{ color:inherit; text-decoration:none; }
button{ background:none; border:none; color:inherit; font:inherit; cursor:pointer; }
img,svg{ display:block; max-width:100%; }
ul{ list-style:none; }
::selection{ background:var(--signal); color:var(--bg-void); }

/* =========================================================
   Custom Cursor
   ========================================================= */
.cursor-dot, .cursor-ring{
  position:fixed; top:0; left:0; pointer-events:none; z-index:9999;
  transform:translate(-50%,-50%);
  mix-blend-mode:difference;
  transition: width var(--duration-base) var(--ease-out-expo),
              height var(--duration-base) var(--ease-out-expo),
              background var(--duration-base) var(--ease-out-expo),
              border-color var(--duration-base) var(--ease-out-expo),
              opacity var(--duration-base) var(--ease-out-expo);
}
.cursor-dot{ width:6px; height:6px; background:var(--ink-primary); border-radius:50%; }
.cursor-ring{ width:36px; height:36px; border:1px solid var(--ink-primary); border-radius:50%; }
.cursor-ring.is-hover{ width:72px; height:72px; }
.cursor-ring.is-cta{ background:var(--signal); border-color:var(--signal); mix-blend-mode:normal; opacity:.85; }
.cursor-dot.is-cta{ background:var(--bg-void); mix-blend-mode:normal; }
@media (hover:none), (max-width:768px){
  .cursor-dot, .cursor-ring{ display:none; }
  body{ cursor:auto; }
}

/* =========================================================
   Page intro overlay
   ========================================================= */
.intro{
  position:fixed; inset:0; z-index:10000; background:var(--bg-void);
  display:flex; align-items:center; justify-content:center; flex-direction:column;
  transition: transform var(--duration-crawl) var(--ease-out-expo);
}
.intro.is-out{ transform:translateY(-100%); }
.intro-mark{
  font-family:var(--font-display); font-size:clamp(3rem,8vw,7rem); letter-spacing:.08em;
  color:var(--ink-primary); opacity:0; animation: introFade 600ms 200ms var(--ease-out-expo) forwards;
}
.intro-status{
  font-family:var(--font-mono); font-size:.8rem; letter-spacing:var(--ls-mono);
  color:var(--signal); margin-top:24px; min-height:1.2em;
}
.intro-status::after{ content:'_'; animation: blink 700ms infinite; }
@keyframes introFade{ to{ opacity:1; } }
@keyframes blink{ 50%{ opacity:0; } }

/* =========================================================
   Scroll progress
   ========================================================= */
.scroll-progress{
  position:fixed; top:0; left:0; height:2px; width:100%;
  transform:scaleX(0); transform-origin:left center;
  background:linear-gradient(90deg, var(--brand), var(--signal));
  z-index:200; transition: width 80ms linear;
}

/* =========================================================
   NAV
   ========================================================= */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:100;
  height:72px;
  display:flex; align-items:center;
  padding:0 var(--pad-x);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  background: rgba(22,22,25,0.55);
  transition: background var(--duration-base) var(--ease-out-expo),
              border-color var(--duration-base) var(--ease-out-expo);
  border-bottom: 1px solid transparent;
}
.nav.is-scrolled{
  background: rgba(15,15,17,0.92);
  border-bottom: 1px solid var(--trace-line);
}
.nav-inner{
  width:100%; max-width:var(--container); margin:0 auto;
  display:flex; align-items:center; justify-content:space-between; gap:32px;
}
.nav-brand{
  font-family:var(--font-display); font-size:1.6rem; letter-spacing:.12em;
  color:var(--ink-primary); display:flex; align-items:center; gap:10px;
}
.nav-brand-logo{ height:30px; width:auto; object-fit:contain; display:block; }
.nav-brand .dot{ color:var(--signal); }
.nav-links{ display:flex; align-items:center; gap:28px; }
.nav-links a{
  font-family:var(--font-body); font-size:.82rem; font-weight:500;
  color:var(--ink-secondary);
  position:relative; padding:6px 0; letter-spacing:.02em;
  transition: color var(--duration-fast) var(--ease-out-expo);
}
.nav-links a::after{
  content:''; position:absolute; bottom:0; left:0; right:0; height:1px;
  background:var(--signal); transform:scaleX(0); transform-origin:left;
  transition: transform var(--duration-base) var(--ease-out-expo);
}
.nav-links a:hover, .nav-links a.is-active{ color:var(--ink-primary); }
.nav-links a:hover::after, .nav-links a.is-active::after{ transform:scaleX(1); }
.nav-more{ position:relative; }
.nav-more-btn{
  display:flex; align-items:center; gap:6px;
  font-family:var(--font-body); font-size:.82rem; font-weight:500; color:var(--ink-secondary);
  padding:6px 0;
}
.nav-more-btn::after{
  content:''; width:6px; height:6px; border-right:1px solid currentColor; border-bottom:1px solid currentColor;
  transform:rotate(45deg) translate(-2px,-2px);
}
.nav-more:hover .nav-more-btn{ color:var(--ink-primary); }
.nav-more-menu{
  position:absolute; top:calc(100% + 12px); right:0; min-width:240px;
  background:var(--bg-panel); border:1px solid var(--border-dim);
  padding:8px 0;
  opacity:0; pointer-events:none; transform:translateY(-6px);
  transition: opacity var(--duration-base) var(--ease-out-expo),
              transform var(--duration-base) var(--ease-out-expo);
}
.nav-more:hover .nav-more-menu{ opacity:1; pointer-events:auto; transform:translateY(0); }
.nav-more-menu a{
  display:block; padding:10px 18px; font-size:.78rem; color:var(--ink-secondary);
  font-family:var(--font-mono); letter-spacing:.06em;
}
.nav-more-menu a:hover{ color:var(--signal); background:var(--signal-dim); }

/* Buttons */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  font-family:var(--font-display); font-size:1.1rem; letter-spacing:.08em;
  padding:14px 24px; border:1px solid transparent; border-radius:2px;
  transition: background var(--duration-base) var(--ease-out-expo),
              color var(--duration-base) var(--ease-out-expo),
              border-color var(--duration-base) var(--ease-out-expo),
              box-shadow var(--duration-base) var(--ease-out-expo),
              transform var(--duration-base) var(--spring);
  cursor:none; white-space:nowrap; position:relative; overflow:hidden;
}
.btn-primary{
  background:var(--brand); color:var(--ink-primary);
  box-shadow: 0 0 0 0 var(--signal-glow);
}
.btn-primary:hover{
  background:var(--brand-bright);
  box-shadow: 0 0 40px var(--signal-glow), 0 0 0 1px var(--signal);
}
.btn-ghost{
  background:transparent; color:var(--ink-primary); border-color:var(--border-dim);
}
.btn-ghost:hover{ border-color:var(--signal); color:var(--signal); }
.btn .arrow{ display:inline-block; transition: transform var(--duration-base) var(--ease-out-expo); }
.btn:hover .arrow{ transform: translateX(4px); }

.nav-cta{ font-size:.85rem; padding:10px 18px; }
.nav-toggle{ display:none; }

@media (max-width:1100px){
  .nav-links{ display:none; }
  .nav-toggle{ display:flex; flex-direction:column; gap:5px; width:28px; }
  .nav-toggle span{ display:block; height:1px; background:var(--ink-primary); transition:transform var(--duration-base); }
  .nav-toggle.is-open span:nth-child(1){ transform:translateY(6px) rotate(45deg); }
  .nav-toggle.is-open span:nth-child(2){ opacity:0; }
  .nav-toggle.is-open span:nth-child(3){ transform:translateY(-6px) rotate(-45deg); }
  .mobile-menu{
    position:fixed; inset:72px 0 0 0; background:var(--bg-void);
    transform:translateY(-100%); transition:transform var(--duration-slow) var(--ease-out-expo);
    z-index:99; padding:48px var(--pad-x); display:flex; flex-direction:column; gap:8px;
    overflow-y:auto;
  }
  .mobile-menu.is-open{ transform:translateY(0); }
  .mobile-menu a{
    font-family:var(--font-display); font-size:2.4rem; letter-spacing:.04em; color:var(--ink-primary);
    padding:12px 0; border-bottom:1px solid var(--border-dim);
    opacity:0; transform:translateY(20px);
    transition: opacity var(--duration-base) var(--ease-out-expo) calc(60ms * var(--i,0)),
                transform var(--duration-base) var(--ease-out-expo) calc(60ms * var(--i,0));
  }
  .mobile-menu.is-open a{ opacity:1; transform:translateY(0); }
}

/* =========================================================
   Shared layout primitives
   ========================================================= */
.wrap{ max-width:var(--container); margin:0 auto; padding:0 var(--pad-x); }
section{ position:relative; }
.section-pad{ padding:140px 0; }
@media (max-width:768px){ .section-pad{ padding:90px 0; } }

.label{
  font-family:var(--font-mono); font-size:var(--fs-mono); letter-spacing:var(--ls-mono);
  color:var(--ink-secondary); text-transform:uppercase;
  display:inline-flex; align-items:center; gap:10px;
}
.label::before{ content:''; width:24px; height:1px; background:var(--signal); }

.h-display{
  font-family:var(--font-display); font-size:var(--fs-display-lg); line-height:var(--lh-display);
  letter-spacing:.01em;
}
.h-section{
  font-family:var(--font-display); font-size:var(--fs-display-lg); line-height:.95;
  letter-spacing:.005em;
}
.h-section .accent, .h-display .accent{ color:var(--signal); }
.intro-line{
  font-family:var(--font-editorial); font-style:italic;
  font-size:clamp(1.4rem,2.2vw,2rem); line-height:1.3; color:var(--ink-primary);
  max-width:60ch;
}
.body-text{ font-family:var(--font-body); color:var(--ink-secondary); font-size:var(--fs-body-lg); max-width:64ch; }
.inline-link{
  color:var(--signal); border-bottom:1px solid var(--trace-line); padding-bottom:2px;
  transition: border-color var(--duration-base);
}
.inline-link:hover{ border-color:var(--signal); }

/* Reveals */
[data-reveal]{ opacity:0; transform:translateY(40px); transition: opacity 800ms var(--ease-out-expo), transform 800ms var(--ease-out-expo); }
[data-reveal].is-in{ opacity:1; transform:translateY(0); }
[data-reveal-clip]{ display:inline-block; clip-path: inset(0 0 100% 0); transition: clip-path 900ms var(--ease-out-expo); }
[data-reveal-clip].is-in{ clip-path: inset(0 0 0 0); }
[data-reveal-line]{ transform:scaleX(0); transform-origin:left; transition: transform 1000ms var(--ease-out-expo); }
[data-reveal-line].is-in{ transform:scaleX(1); }

/* =========================================================
   HERO (home + page heroes)
   ========================================================= */
.hero{
  position:relative; min-height:100dvh;
  padding:120px var(--pad-x) 80px;
  display:flex; flex-direction:column; justify-content:space-between;
  overflow:hidden;
}
.hero-bg{ position:absolute; inset:0; pointer-events:none; z-index:0; }
.hero-grid{
  position:absolute; inset:0; opacity:.06;
  background-image:
    linear-gradient(to right, var(--ink-primary) 1px, transparent 1px),
    linear-gradient(to bottom, var(--ink-primary) 1px, transparent 1px);
  background-size: 80px 80px;
  mask-image: radial-gradient(ellipse at center, black 30%, transparent 80%);
}
.hero-glow{
  position:absolute; left:50%; top:50%; transform:translate(-50%,-50%);
  width:1000px; height:1000px;
  background: radial-gradient(circle, var(--signal-dim) 0%, transparent 60%);
  filter: blur(20px); pointer-events:none;
}
.hero-glow-2{
  position:absolute; right:-10%; top:20%;
  width:600px; height:600px;
  background: radial-gradient(circle, rgba(45,45,195,0.3) 0%, transparent 60%);
  filter: blur(20px); pointer-events:none;
}
.hero-noise{ position:absolute; inset:0; opacity:.05; mix-blend-mode:overlay; }
.hero-scan{
  position:absolute; top:0; left:-30%; width:200%; height:2px;
  background:linear-gradient(90deg, transparent, var(--signal), transparent);
  transform: rotate(20deg) translateY(-100vh);
  animation: scanSweep 1400ms 1.6s var(--ease-out-expo) forwards;
  pointer-events:none;
  box-shadow:0 0 20px var(--signal);
}
@keyframes scanSweep{
  0%{ transform: rotate(20deg) translate(-50%, -50vh); opacity:0; }
  20%{ opacity:1; }
  100%{ transform: rotate(20deg) translate(20%, 100vh); opacity:0; }
}
.hero-inner{
  position:relative; z-index:1;
  width:100%; max-width:var(--container); margin:0 auto;
  display:flex; flex-direction:column; justify-content:space-between; flex:1;
  gap:64px;
}
.hero-top{ display:flex; justify-content:space-between; gap:24px; flex-wrap:wrap; }
.hero-top .label{ color:var(--signal); }
.hero-top .label::before{ background:var(--signal); }
.hero-coords{
  font-family:var(--font-mono); font-size:var(--fs-mono); letter-spacing:.1em;
  color:var(--ink-secondary); display:flex; gap:18px;
}
.hero-coords span b{ color:var(--ink-primary); font-weight:500; }
.hero-headline{
  font-family:var(--font-display);
  font-size:var(--fs-display-xl);
  line-height:.85;
  letter-spacing:-.005em;
  color:var(--ink-primary);
}
.hero-headline .line{ display:block; overflow:hidden; }
.hero-headline .word{ display:inline-block; }
.hero-headline .ltr{
  display:inline-block;
  transform: translateY(110%);
  animation: letterRise 900ms var(--ease-out-expo) forwards;
  animation-delay: calc(2.0s + (30ms * var(--i,0)));
}
.hero-headline .line.l2 .ltr{ animation-delay: calc(2.9s + (30ms * var(--i,0))); }
@keyframes letterRise{ to{ transform: translateY(0); } }
.hero-headline .accent{ color:var(--signal); }

.hero-bottom{
  display:grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1.2fr);
  gap:48px; align-items:end;
}
@media (max-width:900px){ .hero-bottom{ grid-template-columns:1fr; gap:36px; } }
.hero-sub{
  font-family:var(--font-editorial); font-style:italic;
  font-size:clamp(1.4rem, 2.2vw, 2rem); line-height:1.25;
  color:var(--ink-primary);
  opacity:0; transform:translateY(20px);
  animation: fadeRise 800ms var(--ease-out-expo) 3.6s forwards;
}
.hero-body{
  font-family:var(--font-body); font-size:1rem; color:var(--ink-secondary); line-height:1.6;
  max-width:48ch;
  opacity:0; animation: fadeIn 800ms 3.8s forwards;
}
.hero-body + .hero-body{ margin-top:14px; animation-delay:4.0s; }
@keyframes fadeIn{ to{ opacity:1; } }
@keyframes fadeRise{ to{ opacity:1; transform:translateY(0); } }
.hero-badges{ display:flex; flex-wrap:wrap; gap:8px; opacity:0; animation: fadeIn 700ms 4.2s forwards; }
.hero-badges span{
  font-family:var(--font-mono); font-size:.72rem; letter-spacing:var(--ls-mono);
  text-transform:uppercase;
  padding:6px 12px; border:1px solid var(--border-dim); color:var(--ink-secondary);
}
.hero-ctas{ margin-top:24px; display:flex; flex-wrap:wrap; gap:14px; opacity:0; animation: fadeIn 700ms 4.4s forwards; }
.hero-bottom-meta{ display:flex; flex-direction:column; gap:18px; }

/* Slim page header (for non-home pages) */
.page-head{
  position:relative; padding:200px var(--pad-x) 120px;
  background:var(--bg-void); overflow:hidden;
  border-bottom:1px solid var(--border-dim);
}
.page-head .hero-grid{ opacity:.05; }
.page-head .hero-glow{ filter: blur(40px); }
.page-head-inner{
  position:relative; z-index:1;
  max-width:var(--container); margin:0 auto;
  display:grid; grid-template-columns: minmax(0,1.2fr) minmax(0,1fr); gap:64px; align-items:end;
}
@media (max-width:900px){ .page-head-inner{ grid-template-columns:1fr; gap:32px; } }
.page-head h1{
  font-family:var(--font-display); font-size:var(--fs-display-lg); line-height:.92;
  color:var(--ink-primary); letter-spacing:.005em;
}
.page-head .label{ margin-bottom:28px; color:var(--signal); }
.page-head .label::before{ background:var(--signal); }
.page-head .breadcrumbs{
  font-family:var(--font-mono); font-size:.72rem; letter-spacing:var(--ls-mono);
  color:var(--ink-ghost); text-transform:uppercase; margin-bottom:36px;
  display:flex; gap:10px; align-items:center;
}
.page-head .breadcrumbs a{ color:var(--ink-secondary); }
.page-head .breadcrumbs a:hover{ color:var(--signal); }
.page-head .breadcrumbs .sep{ color:var(--signal); }

/* =========================================================
   Trust strip
   ========================================================= */
.trust{
  border-top:1px solid var(--border-dim); border-bottom:1px solid var(--border-dim);
  background:var(--bg-panel);
}
.trust-grid{ display:grid; grid-template-columns:repeat(4,1fr); max-width:var(--container); margin:0 auto; }
@media (max-width:768px){ .trust-grid{ grid-template-columns:repeat(2,1fr); } }
.trust-item{
  padding:36px 28px; border-right:1px solid var(--border-dim);
  display:flex; flex-direction:column; gap:8px;
}
.trust-item:last-child{ border-right:none; }
@media (max-width:768px){
  .trust-item:nth-child(2n){ border-right:none; }
  .trust-item:nth-child(-n+2){ border-bottom:1px solid var(--border-dim); }
}
.trust-num{ font-family:var(--font-display); font-size:clamp(2.4rem, 4vw, 3.4rem); line-height:1; letter-spacing:.02em; color:var(--ink-primary); }
.trust-num .unit{ color:var(--signal); }
.trust-label{ font-family:var(--font-mono); font-size:var(--fs-mono); letter-spacing:var(--ls-mono); color:var(--ink-secondary); text-transform:uppercase; }

/* =========================================================
   Section head (label + title + lede)
   ========================================================= */
.section-head{
  display:grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1.4fr);
  gap:48px; margin-bottom:80px; align-items:end;
}
@media (max-width:900px){ .section-head{ grid-template-columns:1fr; gap:24px; margin-bottom:56px; } }

/* =========================================================
   Generic card grid
   ========================================================= */
.vp-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:2px; background:var(--bg-void); }
@media (max-width:900px){ .vp-grid{ grid-template-columns:1fr; } }
.vp-card{
  background:var(--bg-surface);
  padding:48px 36px 56px;
  position:relative; display:flex; flex-direction:column; gap:20px;
  min-height:360px; overflow:hidden;
  transition: background var(--duration-base) var(--ease-out-expo);
}
.vp-card::before{
  content:''; position:absolute; bottom:0; left:0; height:1px; width:0;
  background:var(--signal); transition: width var(--duration-slow) var(--ease-out-expo);
}
.vp-card:hover{ background:#23232a; }
.vp-card:hover::before{ width:100%; }
.vp-num{ font-family:var(--font-mono); font-size:var(--fs-mono); letter-spacing:var(--ls-mono); color:var(--ink-ghost); }
.vp-icon{ width:28px; height:28px; color:var(--signal); }
.vp-title{ font-family:var(--font-editorial); font-size:clamp(1.5rem,2vw,1.9rem); line-height:1.15; color:var(--ink-primary); }
.vp-body{ color:var(--ink-secondary); font-size:.95rem; line-height:1.6; }

.vp-card[data-reveal-card]{
  transform: translateY(60px); opacity:0;
  transition: opacity 700ms var(--ease-out-expo), transform 700ms var(--ease-out-expo);
  transition-delay: calc(100ms * var(--i,0));
}
.vp-card[data-reveal-card].is-in{ opacity:1; transform:translateY(0); }

/* =========================================================
   Marquee
   ========================================================= */
.logos{
  padding:80px 0;
  border-top:1px solid var(--border-dim);
  border-bottom:1px solid var(--border-dim);
  overflow:hidden;
}
.logos .label{ display:flex; justify-content:center; margin-bottom:36px; }
.marquee{ display:flex; gap:80px; width:max-content; animation: marquee 32s linear infinite; }
.marquee:hover{ animation-play-state:paused; }
@keyframes marquee{ to{ transform: translateX(-50%); } }
.marquee-item{
  font-family:var(--font-display); font-size:2.4rem; letter-spacing:.04em;
  color:var(--ink-secondary); border-bottom:1px solid var(--trace-line);
  padding:8px 0; transition: color var(--duration-base); flex-shrink:0;
}
.marquee-item:hover{ color:var(--ink-primary); }
.marquee-logo{ border-bottom:none; padding:0; display:flex; align-items:center; }
.client-logo-img{
  height:72px; width:auto; max-width:200px; object-fit:contain;
  filter:grayscale(1) brightness(2); opacity:.65;
  transition:filter .3s, opacity .3s;
}
.marquee-logo:hover .client-logo-img{ filter:none; opacity:1; }

/* =========================================================
   Testimonials
   ========================================================= */
.testimonials{ background:var(--bg-panel); padding:160px 0; position:relative; overflow:hidden; }
.test-wrap{ max-width:var(--container); margin:0 auto; padding:0 var(--pad-x); position:relative; }
.quote-mark{
  position:absolute; top:-30px; left:-12px;
  font-family:var(--font-display); font-size:clamp(12rem, 22vw, 26rem);
  line-height:.7; color:var(--signal); opacity:.16; pointer-events:none; user-select:none;
}
.test-inner{ position:relative; z-index:1; }
.test-track{ position:relative; min-height:260px; }
.test-slide{
  position:absolute; inset:0;
  opacity:0; transform:translateX(20px);
  transition: opacity 500ms var(--ease-out-expo), transform 500ms var(--ease-out-expo);
  pointer-events:none;
}
.test-slide.is-active{ opacity:1; transform:translateX(0); pointer-events:auto; position:relative; }
.test-slide-inner{ display:flex; gap:64px; align-items:center; }
.test-logo-col{
  flex-shrink:0; width:180px; height:160px;
  display:flex; align-items:center; justify-content:center;
  border:1px solid var(--border-dim); background:var(--bg-void);
  padding:24px;
}
.test-client-logo-big{
  height:90px; width:auto; max-width:160px; object-fit:contain;
  filter:grayscale(1) brightness(2); opacity:.7;
  transition:filter .4s, opacity .4s;
}
.test-slide.is-active .test-client-logo-big{ filter:grayscale(0) brightness(1.1); opacity:1; }
.test-quote-col{ flex:1; }
.test-quote{
  font-family:var(--font-editorial); font-style:italic;
  font-size:clamp(1.4rem, 2.5vw, 2.2rem); line-height:1.35;
  color:var(--ink-primary);
}
.test-author{ margin-top:28px; display:flex; align-items:center; gap:16px;
  font-family:var(--font-mono); font-size:.85rem; letter-spacing:.04em; }
.test-author b{ color:var(--ink-primary); font-weight:600; }
.test-author span{ color:var(--ink-secondary); }
.test-author::before{ content:''; width:48px; height:1px; background:var(--signal); }
@media(max-width:768px){
  .test-slide-inner{ flex-direction:column; gap:32px; }
  .test-logo-col{ width:100%; height:100px; }
}
.test-tabs{ display:flex; gap:24px; margin-top:64px; border-top:1px solid var(--border-dim); padding-top:24px; }
.test-tab{
  font-family:var(--font-mono); font-size:.78rem; letter-spacing:var(--ls-mono);
  color:var(--ink-secondary); padding:6px 0; position:relative; cursor:none;
}
.test-tab.is-active{ color:var(--signal); }
.test-tab .bar{
  position:absolute; left:0; bottom:-25px; width:0; height:1px; background:var(--signal);
  transition: width var(--duration-slow) linear;
}
.test-tab.is-active .bar{ width:100%; }

/* =========================================================
   Services cards
   ========================================================= */
.services-grid{ display:grid; grid-template-columns:repeat(2, 1fr); gap:2px; background:var(--bg-void); }
@media (max-width:900px){ .services-grid{ grid-template-columns:1fr; } }
.service-card{
  background:var(--bg-surface);
  padding:56px 44px 48px;
  min-height:420px;
  display:flex; flex-direction:column; gap:18px;
  position:relative; overflow:hidden;
  transition: background var(--duration-base) var(--ease-out-expo);
}
.service-card::before{
  content:''; position:absolute; top:0; left:0; height:1px; width:0;
  background:var(--signal); transition: width var(--duration-slow) var(--ease-out-expo);
}
.service-card:hover{ background:linear-gradient(180deg, var(--signal-dim) 0%, var(--bg-surface) 60%); }
.service-card:hover::before{ width:100%; }
.service-num{ font-family:var(--font-mono); font-size:.85rem; letter-spacing:var(--ls-mono); color:var(--ink-secondary); }
.service-title{ font-family:var(--font-editorial); font-size:clamp(1.8rem, 2.6vw, 2.6rem); line-height:1.1; color:var(--ink-primary); margin-top:8px; }
.service-body{ color:var(--ink-secondary); font-size:.96rem; max-width:42ch; }
.service-cta{
  margin-top:auto; padding-top:24px;
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--font-mono); font-size:.85rem; letter-spacing:.06em;
  color:var(--signal); text-transform:uppercase;
}
.service-cta .arrow{ display:inline-block; transition: transform var(--duration-base) var(--ease-out-expo); }
.service-card:hover .service-cta .arrow{ transform:translateX(6px); }
.service-feed{
  margin-top:auto;
  border:1px solid var(--border-dim);
  padding:14px 16px;
  font-family:var(--font-mono); font-size:.72rem; line-height:1.7;
  color:var(--ink-secondary); background:rgba(0,0,0,0.3);
}
.service-feed .row{ display:flex; gap:8px; }
.service-feed .pulse{ color:var(--signal); }
.service-feed .pulse::after{ content:'_'; animation: blink 700ms infinite; }

/* =========================================================
   Threat intel section
   ========================================================= */
.threat{ background:var(--bg-void); padding:160px 0; position:relative; overflow:hidden; }
.threat::before{
  content:''; position:absolute; inset:0;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 60 52' fill='none' stroke='%23FF66FF' stroke-opacity='0.6' stroke-width='0.5'><polygon points='30,2 58,17 58,37 30,52 2,37 2,17'/></svg>");
  background-size:60px 52px; opacity:.05;
}
.threat::after{
  content:''; position:absolute; top:50%; left:50%; width:1200px; height:1200px;
  transform:translate(-50%,-50%);
  background: radial-gradient(circle, var(--signal-dim) 0%, transparent 60%);
  animation: pulse 4s ease-out infinite;
  pointer-events:none;
}
@keyframes pulse{
  0%{ opacity:.6; transform:translate(-50%,-50%) scale(1); }
  100%{ opacity:0; transform:translate(-50%,-50%) scale(2.4); }
}
.threat-grid{
  display:grid; grid-template-columns: minmax(0,1fr) minmax(0,1fr); gap:80px;
  align-items:start; position:relative; z-index:1;
}
@media (max-width:900px){ .threat-grid{ grid-template-columns:1fr; gap:48px; } }
.threat-stats{ display:grid; grid-template-columns:repeat(2,1fr); gap:2px; background:var(--border-dim); }
.threat-stat{ background:var(--bg-void); padding:32px 24px; display:flex; flex-direction:column; gap:8px; }
.threat-stat-num{
  font-family:var(--font-display); font-size:clamp(3rem,5vw,5rem); line-height:1;
  color:var(--signal); letter-spacing:.02em;
  text-shadow: 0 0 30px var(--signal-glow);
}
.threat-stat-num.flicker{ animation: flicker 800ms steps(8) 1; }
@keyframes flicker{
  0%,30%,50%,70%,100%{ opacity:1; }
  10%,40%,60%{ opacity:.3; }
}
.threat-stat-label{ font-family:var(--font-mono); font-size:var(--fs-mono); letter-spacing:var(--ls-mono); color:var(--ink-secondary); text-transform:uppercase; }
.threat-feed{
  border:1px solid var(--trace-line);
  background:rgba(14,14,16,0.6);
  font-family:var(--font-mono); font-size:.78rem;
}
.threat-feed-head{
  padding:10px 14px;
  border-bottom:1px solid var(--trace-line);
  display:flex; align-items:center; justify-content:space-between;
  font-size:.7rem; letter-spacing:var(--ls-mono); color:var(--ink-secondary);
  text-transform:uppercase;
}
.threat-feed-head .live{ display:inline-flex; align-items:center; gap:6px; color:var(--signal); }
.threat-feed-head .live::before{
  content:''; width:6px; height:6px; border-radius:50%; background:var(--signal);
  box-shadow:0 0 10px var(--signal); animation: blink 1.2s infinite;
}
.threat-feed ul{ padding:8px 0; }
.threat-feed li{
  display:grid; grid-template-columns: auto 1fr auto; gap:14px;
  padding:10px 14px; color:var(--ink-secondary);
  border-bottom:1px dashed var(--border-dim); align-items:center;
}
.threat-feed li:last-child{ border-bottom:none; }
.threat-feed li .gt{ color:var(--signal); }
.threat-feed li .target{ color:var(--ink-primary); }
.threat-feed li .meta{ color:var(--ink-ghost); font-size:.7rem; }
.threat-callout{
  margin-top:64px;
  display:grid; grid-template-columns: 2fr 1fr; gap:48px;
  align-items:center;
  border-top:1px solid var(--border-dim); padding-top:48px;
  position:relative; z-index:1;
}
@media (max-width:900px){ .threat-callout{ grid-template-columns:1fr; gap:24px; } }

/* =========================================================
   Operations deck iframe
   ========================================================= */
.ops-iframe{ border:1px solid var(--trace-line); background:var(--bg-surface); margin-top:48px; position:relative; }
.ops-iframe-head{
  display:flex; align-items:center; gap:14px; padding:12px 16px;
  border-bottom:1px solid var(--trace-line);
  font-family:var(--font-mono); font-size:var(--fs-mono); letter-spacing:.04em;
  color:var(--ink-secondary);
}
.ops-iframe-head .dots{ display:flex; gap:6px; }
.ops-iframe-head .dots span{ width:8px; height:8px; border-radius:50%; background:var(--ink-ghost); }
.ops-iframe-head .dots span:first-child{ background:var(--signal); }
.ops-iframe-body{
  position:relative; aspect-ratio: 16/9; background:var(--bg-void);
  display:flex; align-items:center; justify-content:center; overflow:hidden;
}
.ops-iframe-body iframe{ position:absolute; inset:0; width:100%; height:100%; border:none; }
.ops-fallback{
  position:absolute; inset:0;
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:18px;
  font-family:var(--font-mono); color:var(--ink-secondary); pointer-events:none;
}
.ops-fallback svg{ color:var(--signal); opacity:.5; }
.ops-fallback a{ color:var(--signal); pointer-events:auto; }
.ops-tags{ display:flex; gap:12px; flex-wrap:wrap; margin-top:24px; }
.ops-tag{
  font-family:var(--font-mono); font-size:.72rem; letter-spacing:var(--ls-mono);
  text-transform:uppercase; color:var(--ink-secondary);
  padding:8px 14px; border:1px solid var(--border-dim);
}

/* =========================================================
   Three nets
   ========================================================= */
.nets{ background:var(--bg-panel); }
.nets-list{ display:flex; flex-direction:column; gap:2px; background:var(--border-dim); margin-top:64px; }
.nets-item{
  background:var(--bg-panel);
  padding:56px var(--pad-x) 56px;
  position:relative;
  display:grid; grid-template-columns: minmax(0,1fr) minmax(0,2fr) auto;
  gap:48px; align-items:center;
  overflow:hidden; transition: background var(--duration-base);
}
.nets-item:hover{ background:#27272f; }
.nets-bgnum{
  position:absolute; right:48px; bottom:-30px;
  font-family:var(--font-display); font-size:clamp(8rem, 14vw, 16rem); line-height:.8;
  color:var(--ink-ghost); pointer-events:none; letter-spacing:.02em;
}
.nets-num{
  font-family:var(--font-mono); font-size:var(--fs-mono); letter-spacing:var(--ls-mono);
  color:var(--signal); text-transform:uppercase;
  display:flex; align-items:center; gap:14px;
}
.nets-num::before{ content:''; width:24px; height:1px; background:var(--signal); }
.nets-title{ font-family:var(--font-editorial); font-size:clamp(1.6rem, 2.4vw, 2.4rem); line-height:1.15; color:var(--ink-primary); }
.nets-body{ color:var(--ink-secondary); font-size:1rem; line-height:1.5; max-width:60ch; }
.nets-meta{ font-family:var(--font-mono); font-size:.7rem; letter-spacing:var(--ls-mono); color:var(--ink-secondary); text-transform:uppercase; white-space:nowrap; }
@media (max-width:900px){
  .nets-item{ grid-template-columns:1fr; gap:18px; }
  .nets-meta{ display:none; }
}

/* =========================================================
   Industry / Geography
   ========================================================= */
.geo-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:96px; }
@media (max-width:900px){ .geo-grid{ grid-template-columns:1fr; gap:48px; } }
.geo-h{
  font-family:var(--font-mono); font-size:var(--fs-mono); letter-spacing:var(--ls-mono);
  text-transform:uppercase; color:var(--ink-secondary);
  margin-bottom:24px; display:flex; align-items:center; gap:10px;
}
.geo-h::before{ content:''; width:24px; height:1px; background:var(--signal); }
.sector-list{ display:flex; flex-direction:column; }
.sector-list li{
  padding:20px 0;
  border-bottom:1px solid var(--border-dim);
  font-family:var(--font-editorial); font-size:clamp(1.2rem,1.6vw,1.6rem);
  color:var(--ink-primary); position:relative;
  transition: padding-left var(--duration-base) var(--ease-out-expo), color var(--duration-base);
}
.sector-list li::before{
  content:''; position:absolute; left:-4px; top:50%; width:0; height:2px;
  background:var(--signal); transform:translateY(-50%);
  transition: width var(--duration-base) var(--ease-out-expo);
}
.sector-list li:hover{ padding-left:36px; color:var(--signal); }
.sector-list li:hover::before{ width:24px; }
.delivery-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:2px; background:var(--border-dim); }
.delivery-card{
  background:var(--bg-surface); padding:24px 20px;
  display:flex; flex-direction:column; gap:8px; min-height:140px;
}
.delivery-card h3{ font-family:var(--font-display); font-size:1.4rem; letter-spacing:.04em; color:var(--ink-primary); }
.delivery-card p{ font-size:.82rem; color:var(--ink-secondary); line-height:1.5; }

.cities-strip{
  margin-top:96px;
  border-top:1px solid var(--border-dim); border-bottom:1px solid var(--border-dim);
  padding:48px 0;
  display:grid; grid-template-columns:repeat(3,1fr); gap:0;
}
@media (max-width:768px){ .cities-strip{ grid-template-columns:1fr; gap:24px; } }
.city{ padding:0 32px; border-right:1px solid var(--border-dim); cursor:none; }
.city:last-child{ border-right:none; }
.city-name{
  font-family:var(--font-display); font-size:clamp(2.4rem, 4vw, 4.2rem); line-height:1;
  letter-spacing:.02em; color:var(--ink-primary);
  transition: color var(--duration-base);
}
.city:hover .city-name{ color:var(--signal); }
.city-desc{
  font-family:var(--font-mono); font-size:.74rem; letter-spacing:.05em;
  color:var(--ink-secondary); text-transform:uppercase;
  margin-top:8px;
  max-height:0; opacity:0; overflow:hidden;
  transition: max-height var(--duration-base) var(--ease-out-expo), opacity var(--duration-base), margin var(--duration-base);
}
.city:hover .city-desc, .city.is-open .city-desc{ max-height:40px; opacity:1; margin-top:12px; }

/* =========================================================
   Process Timeline
   ========================================================= */
.process{ background:var(--bg-void); }
.timeline{ position:relative; margin-top:80px; display:grid; grid-template-columns:repeat(4,1fr); gap:32px; }
@media (max-width:900px){ .timeline{ grid-template-columns:1fr; gap:48px; } }
.timeline-line{
  position:absolute; top:50px; left:0; right:0; height:1px;
  background:var(--trace-line);
  transform-origin:left; transform:scaleX(0);
  transition: transform 1400ms var(--ease-out-expo);
}
.timeline.is-in .timeline-line{ transform:scaleX(1); }
@media (max-width:900px){
  .timeline-line{ left:24px; right:auto; top:0; bottom:0; width:1px; height:auto; transform:scaleY(0); transform-origin:top; }
  .timeline.is-in .timeline-line{ transform:scaleY(1); }
}
.step{
  position:relative; opacity:0; transform:translateY(20px);
  transition: opacity 700ms var(--ease-out-expo), transform 700ms var(--ease-out-expo);
  transition-delay: calc(150ms * var(--i,0));
  padding-top:60px;
}
.timeline.is-in .step{ opacity:1; transform:translateY(0); }
.step::before{
  content:''; position:absolute; top:46px; left:0; width:10px; height:10px;
  background:var(--signal); border-radius:50%;
  box-shadow:0 0 0 4px var(--bg-void), 0 0 12px var(--signal);
}
@media (max-width:900px){
  .step{ padding:0 0 0 60px; }
  .step::before{ top:8px; left:20px; }
}
.step-num{ font-family:var(--font-mono); font-size:.78rem; letter-spacing:var(--ls-mono); color:var(--ink-secondary); text-transform:uppercase; margin-bottom:12px; }
.step-title{ font-family:var(--font-editorial); font-size:1.3rem; line-height:1.2; color:var(--ink-primary); margin-bottom:8px; }
.step-body{ font-size:.9rem; color:var(--ink-secondary); line-height:1.5; }

.deliverables{ margin-top:96px; display:grid; grid-template-columns: 1fr 2fr; gap:64px; align-items:start; }
@media (max-width:900px){ .deliverables{ grid-template-columns:1fr; gap:32px; } }
.deliverables h3{ font-family:var(--font-display); font-size:clamp(2rem,3vw,3rem); line-height:1; letter-spacing:.02em; color:var(--ink-primary); }
.deliverables ul{ display:flex; flex-direction:column; gap:0; }
.deliverables li{
  padding:20px 0;
  border-top:1px solid var(--border-dim);
  display:grid; grid-template-columns:auto 1fr; gap:24px; align-items:start;
  font-size:.98rem; color:var(--ink-secondary);
}
.deliverables li:last-child{ border-bottom:1px solid var(--border-dim); }
.deliverables li .idx{ font-family:var(--font-mono); color:var(--signal); font-size:.78rem; padding-top:4px; letter-spacing:.06em; }
.process-ctas{ display:flex; gap:14px; margin-top:48px; flex-wrap:wrap; }

/* =========================================================
   FAQ
   ========================================================= */
.faq{ background:var(--bg-panel); }
.faq-grid{ display:grid; grid-template-columns: 1fr 1.6fr; gap:96px; align-items:start; }
@media (max-width:900px){ .faq-grid{ grid-template-columns:1fr; gap:48px; } }
.faq-list{ display:flex; flex-direction:column; }
.faq-item{ border-top:1px solid var(--border-dim); padding:8px 0; position:relative; }
.faq-item:last-child{ border-bottom:1px solid var(--border-dim); }
.faq-item::before{
  content:''; position:absolute; left:0; top:0; bottom:0; width:2px;
  background:var(--signal); transform:scaleY(0); transform-origin:top;
  transition: transform var(--duration-base) var(--ease-out-expo);
}
.faq-item.is-open::before{ transform:scaleY(1); }
.faq-q{
  display:flex; align-items:center; justify-content:space-between; gap:24px;
  padding:24px 16px; width:100%; text-align:left;
  font-family:var(--font-body); font-weight:600;
  font-size:clamp(1.05rem,1.4vw,1.25rem); color:var(--ink-primary);
  cursor:none; transition: padding-left var(--duration-base);
}
.faq-item.is-open .faq-q{ padding-left:24px; }
.faq-toggle{ width:24px; height:24px; position:relative; flex-shrink:0; transition: transform var(--duration-base) var(--ease-out-expo); }
.faq-toggle::before, .faq-toggle::after{
  content:''; position:absolute; left:50%; top:50%; width:14px; height:1px;
  background:var(--signal); transform:translate(-50%,-50%);
}
.faq-toggle::after{ transform:translate(-50%,-50%) rotate(90deg); }
.faq-item.is-open .faq-toggle{ transform:rotate(45deg); }
.faq-a{ max-height:0; overflow:hidden; transition: max-height 600ms var(--ease-out-expo); }
.faq-a-inner{
  padding:0 16px 28px 24px;
  color:var(--ink-secondary); font-size:.96rem; line-height:1.7; max-width:64ch;
}

/* =========================================================
   Contact Form
   ========================================================= */
.contact{ background:var(--bg-void); position:relative; overflow:hidden; }
.contact::before{
  content:''; position:absolute; inset:0; opacity:.04;
  background-image:
    linear-gradient(to right, var(--ink-primary) 1px, transparent 1px),
    linear-gradient(to bottom, var(--ink-primary) 1px, transparent 1px);
  background-size: 100px 100px;
  mask-image: radial-gradient(ellipse at center, black 0%, transparent 70%);
}
.contact-wrap{ position:relative; z-index:1; max-width:720px; margin:0 auto; }
.contact .section-head{ grid-template-columns:1fr; text-align:left; }
.form{ display:flex; flex-direction:column; gap:28px; margin-top:48px; }
.field{ display:flex; flex-direction:column; gap:10px; position:relative; }
.field label{
  font-family:var(--font-mono); font-size:.72rem; letter-spacing:var(--ls-mono);
  text-transform:uppercase; color:var(--ink-ghost);
}
.field input, .field textarea{
  background:transparent; border:none;
  border-bottom:1px solid var(--border-dim);
  padding:12px 0;
  font-family:var(--font-body); font-size:1.05rem;
  color:var(--ink-primary);
  outline:none;
  transition: border-color var(--duration-base) var(--ease-out-expo);
  resize:vertical;
}
.field input:focus, .field textarea:focus{
  border-color:var(--signal);
  box-shadow: 0 1px 0 0 var(--signal);
}
.field input::placeholder, .field textarea::placeholder{ color:var(--ink-ghost); }
.submit{
  margin-top:14px;
  background:var(--brand); color:var(--ink-primary);
  font-family:var(--font-display); font-size:1.3rem; letter-spacing:.1em;
  padding:18px 24px; cursor:none;
  position:relative; overflow:hidden; border-radius:2px;
  transition: transform var(--duration-base) var(--spring), box-shadow var(--duration-base), background var(--duration-base);
}
.submit:hover{ box-shadow:0 0 50px var(--signal-glow); background:var(--brand-bright); transform:scale(1.01); }
.submit.is-sending{ background:var(--bg-panel); color:var(--signal); border:1px solid var(--signal); }
.submit.is-sent{ background:var(--bg-panel); color:var(--signal); border:1px solid var(--signal); }

/* =========================================================
   Footer
   ========================================================= */
.footer{
  background:var(--bg-panel);
  border-top:1px solid var(--signal);
  padding:96px var(--pad-x) 36px;
  position:relative; overflow:hidden;
}
.footer::before{
  content:''; position:absolute; inset:0; opacity:.03;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence baseFrequency='0.9' numOctaves='2' /></filter><rect width='200' height='200' filter='url(%23n)' opacity='0.5'/></svg>");
}
.footer-inner{ position:relative; max-width:var(--container); margin:0 auto; }
.footer-top{ display:grid; grid-template-columns: 1.4fr 1fr 1fr; gap:64px; align-items:start; }
@media (max-width:900px){ .footer-top{ grid-template-columns:1fr; gap:48px; } }
.footer-brand-mark{
  font-family:var(--font-display); font-size:clamp(4rem, 9vw, 8rem); line-height:.85; letter-spacing:.03em;
  color:var(--ink-primary);
}
.footer-meta{ margin-top:18px; display:flex; gap:18px; align-items:center; flex-wrap:wrap;
  font-family:var(--font-mono); font-size:.78rem; letter-spacing:.05em; }
.footer-meta .ver{ color:var(--ink-secondary); }
.footer-meta .status{ color:var(--signal); display:inline-flex; align-items:center; gap:8px; }
.footer-meta .status::before{
  content:''; width:8px; height:8px; border-radius:50%; background:var(--signal);
  box-shadow:0 0 10px var(--signal); animation: blink 1.4s infinite;
}
.footer-tag{ margin-top:28px; max-width:42ch;
  font-family:var(--font-editorial); font-style:italic;
  font-size:1.1rem; line-height:1.4; color:var(--ink-primary); }
.footer-col h3{
  font-family:var(--font-mono); font-size:.72rem; letter-spacing:var(--ls-mono);
  color:var(--ink-secondary); text-transform:uppercase; margin-bottom:18px;
}
.footer-col ul{ display:flex; flex-direction:column; gap:10px; }
.footer-col a{ font-family:var(--font-body); font-size:.92rem; color:var(--ink-primary); transition: color var(--duration-fast); }
.footer-col a:hover{ color:var(--signal); }
.footer-bottom{
  margin-top:96px; padding-top:24px;
  border-top:1px solid var(--border-dim);
  display:flex; justify-content:space-between; align-items:center; gap:24px; flex-wrap:wrap;
  font-family:var(--font-mono); font-size:.72rem; letter-spacing:.05em; color:var(--ink-ghost);
  text-transform:uppercase;
}
.footer-bottom .tokens{ display:flex; gap:12px; align-items:center; }
.footer-bottom .tokens span{ font-size:1rem; color:var(--signal); }
.footer-bottom a:hover{ color:var(--signal); }

[data-parallax]{ will-change: transform; }

/* =========================================================
   Page-specific shared primitives
   ========================================================= */

/* Generic dense list (case-study list, blog list, tools list) */
.entry-list{ display:flex; flex-direction:column; border-top:1px solid var(--border-dim); }
.entry{
  display:grid; grid-template-columns: 80px minmax(0, 3fr) minmax(0,1.5fr) auto;
  align-items:center; gap:32px;
  padding:32px 0;
  border-bottom:1px solid var(--border-dim);
  position:relative;
  transition: padding-left var(--duration-base) var(--ease-out-expo), background var(--duration-base);
}
.entry::before{
  content:''; position:absolute; left:-4px; top:0; bottom:0; width:2px;
  background:var(--signal); transform:scaleY(0); transform-origin:center;
  transition: transform var(--duration-base) var(--ease-out-expo);
}
.entry:hover{ padding-left:24px; background:linear-gradient(90deg, var(--signal-dim), transparent 50%); }
.entry:hover::before{ transform:scaleY(1); }
.entry-num{ font-family:var(--font-mono); font-size:.78rem; letter-spacing:var(--ls-mono); color:var(--ink-ghost); }
.entry-title{
  font-family:var(--font-editorial); font-size:clamp(1.3rem,1.8vw,1.8rem); line-height:1.2;
  color:var(--ink-primary);
}
.entry-desc{ font-size:.88rem; color:var(--ink-secondary); margin-top:6px; max-width:64ch; }
.entry-tags{ display:flex; gap:8px; flex-wrap:wrap; }
.entry-tags span{
  font-family:var(--font-mono); font-size:.7rem; letter-spacing:.08em;
  color:var(--ink-secondary); padding:4px 10px;
  border:1px solid var(--border-dim); text-transform:uppercase;
}
.entry-arrow{
  width:36px; height:36px; border:1px solid var(--border-dim);
  display:flex; align-items:center; justify-content:center;
  color:var(--ink-secondary); transition: all var(--duration-base);
}
.entry:hover .entry-arrow{ background:var(--signal); color:var(--bg-void); border-color:var(--signal); }
@media (max-width:768px){
  .entry{ grid-template-columns: 50px 1fr auto; }
  .entry-tags{ display:none; }
}

/* Stat card grid (used on Threat Intel page, tools) */
.stat-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:2px; background:var(--border-dim); border:1px solid var(--border-dim); }
@media (max-width:900px){ .stat-grid{ grid-template-columns:repeat(2,1fr); } }
.stat-cell{ background:var(--bg-surface); padding:28px 22px; display:flex; flex-direction:column; gap:10px; }
.stat-cell .num{ font-family:var(--font-display); font-size:clamp(2.4rem,4vw,3.6rem); line-height:1; color:var(--signal); }
.stat-cell .label{ color:var(--ink-secondary); }

/* Code/terminal block */
.term{
  font-family:var(--font-mono); font-size:.8rem; line-height:1.7;
  background:var(--bg-deep); border:1px solid var(--trace-line);
  padding:20px 22px; color:var(--ink-secondary);
}
.term .gt{ color:var(--signal); }
.term .ok{ color:var(--signal); }
.term .warn{ color:#FFD15A; }
.term .err{ color:var(--threat-red); }
.term .accent{ color:var(--ink-primary); }
.term .blink::after{ content:'_'; animation: blink 700ms infinite; color:var(--signal); }

/* Two-up split */
.split-2{ display:grid; grid-template-columns:1fr 1fr; gap:64px; }
@media (max-width:900px){ .split-2{ grid-template-columns:1fr; gap:32px; } }

/* Page CTA strip */
.cta-strip{
  position:relative; background:var(--bg-panel); border-top:1px solid var(--trace-line); border-bottom:1px solid var(--trace-line);
  padding:96px var(--pad-x); overflow:hidden;
}
.cta-strip::before{
  content:''; position:absolute; right:-100px; top:50%; transform:translateY(-50%);
  width:500px; height:500px;
  background:radial-gradient(circle, var(--signal-dim) 0%, transparent 60%);
  filter:blur(20px); pointer-events:none;
}
.cta-strip-inner{
  position:relative; max-width:var(--container); margin:0 auto;
  display:grid; grid-template-columns: 1fr auto; gap:48px; align-items:center;
}
@media (max-width:900px){ .cta-strip-inner{ grid-template-columns:1fr; gap:24px; } }
.cta-strip h3{
  font-family:var(--font-display); font-size:clamp(2.4rem,4vw,4.2rem); line-height:.95;
  color:var(--ink-primary); letter-spacing:.005em;
}
.cta-strip p{ color:var(--ink-secondary); margin-top:14px; max-width:54ch; }


/* =========================================================
   PAGE-SPECIFIC WIREFRAMES
   ========================================================= */

/* ---------- SERVICES · Ledger / sticky index ---------- */
.svc-ledger{
  display:grid; grid-template-columns: 320px 1fr; gap:0;
  border-top:1px solid var(--border-dim);
}
@media (max-width:900px){ .svc-ledger{ grid-template-columns:1fr; } }
.svc-index{
  position:sticky; top:72px; align-self:start;
  padding:64px 0 64px 0;
  border-right:1px solid var(--border-dim);
  min-height:calc(100vh - 72px);
}
@media (max-width:900px){ .svc-index{ position:relative; top:auto; min-height:auto; border-right:none; border-bottom:1px solid var(--border-dim); padding:32px 0; } }
.svc-index-label{
  font-family:var(--font-mono); font-size:.7rem; letter-spacing:var(--ls-mono);
  color:var(--ink-ghost); text-transform:uppercase;
  padding:0 var(--pad-x) 18px;
}
.svc-index-list{ display:flex; flex-direction:column; }
.svc-index-list a{
  display:flex; align-items:baseline; gap:14px;
  padding:18px var(--pad-x);
  border-top:1px solid var(--border-dim);
  font-family:var(--font-display); font-size:1.7rem; letter-spacing:.04em;
  color:var(--ink-secondary);
  transition: color var(--duration-base), background var(--duration-base), padding-left var(--duration-base);
  position:relative;
}
.svc-index-list a::before{
  content:''; position:absolute; left:0; top:0; bottom:0; width:2px;
  background:var(--signal); transform:scaleY(0); transform-origin:center;
  transition: transform var(--duration-base) var(--ease-out-expo);
}
.svc-index-list a .num{ font-family:var(--font-mono); font-size:.7rem; color:var(--ink-ghost); letter-spacing:.08em; }
.svc-index-list a:hover, .svc-index-list a.is-active{ color:var(--ink-primary); background:rgba(255,102,255,0.04); padding-left:calc(var(--pad-x) + 12px); }
.svc-index-list a:hover::before, .svc-index-list a.is-active::before{ transform:scaleY(1); }

.svc-blocks{ display:flex; flex-direction:column; }
.svc-block{
  padding:120px var(--pad-x);
  border-bottom:1px solid var(--border-dim);
  position:relative;
  scroll-margin-top:72px;
}
.svc-block:nth-child(even){ background:var(--bg-panel); }
.svc-block-num{
  font-family:var(--font-display);
  font-size:clamp(8rem, 18vw, 22rem); line-height:.8;
  color:transparent;
  -webkit-text-stroke: 1px var(--ink-ghost);
  position:absolute; right:48px; top:48px;
  pointer-events:none; user-select:none;
  letter-spacing:.02em;
}
.svc-block-tag{
  font-family:var(--font-mono); font-size:.72rem; letter-spacing:.15em; color:var(--signal);
  text-transform:uppercase; margin-bottom:24px;
}
.svc-block-title{
  font-family:var(--font-display); font-size:clamp(3rem, 6vw, 6rem); line-height:.95;
  letter-spacing:.005em; color:var(--ink-primary); margin-bottom:32px;
  position:relative; z-index:1;
}
.svc-block-lede{
  font-family:var(--font-editorial); font-style:italic;
  font-size:clamp(1.4rem, 2vw, 1.8rem); line-height:1.3;
  color:var(--ink-primary); max-width:24ch;
  margin-bottom:48px; position:relative; z-index:1;
}
.svc-block-body{
  display:grid; grid-template-columns: 1.4fr 1fr; gap:64px;
  position:relative; z-index:1;
}
@media (max-width:900px){ .svc-block-body{ grid-template-columns:1fr; gap:32px; } }
.svc-deliverables{
  display:flex; flex-direction:column;
  border-top:1px solid var(--border-dim);
}
.svc-deliverables li{
  padding:14px 0;
  border-bottom:1px solid var(--border-dim);
  display:grid; grid-template-columns: 40px 1fr; gap:18px;
  font-family:var(--font-body); font-size:.95rem; color:var(--ink-secondary);
}
.svc-deliverables .marker{ font-family:var(--font-mono); font-size:.78rem; color:var(--signal); padding-top:2px; }
.svc-spec{
  background:var(--bg-deep);
  border:1px solid var(--trace-line);
  padding:24px;
  font-family:var(--font-mono); font-size:.8rem; line-height:1.9;
  color:var(--ink-secondary);
}
.svc-spec .key{ color:var(--ink-ghost); }
.svc-spec .val{ color:var(--ink-primary); }
.svc-spec .row-pair{ display:grid; grid-template-columns:auto 1fr; gap:18px; padding:4px 0; border-bottom:1px dashed var(--border-dim); }
.svc-spec .row-pair:last-child{ border-bottom:none; }

/* ---------- CITIES · Atlas / chapter layout ---------- */
.atlas-hero{
  position:relative; min-height:90vh;
  padding:160px var(--pad-x) 100px;
  overflow:hidden;
  display:flex; flex-direction:column; justify-content:flex-end;
}
.atlas-hero-bg{ position:absolute; inset:0; pointer-events:none; }
.atlas-hero-bg .india{
  position:absolute; top:0; right:-10%; height:100%; width:auto; opacity:.08;
  filter: drop-shadow(0 0 60px var(--signal-glow));
}
.atlas-hero-inner{ position:relative; max-width:var(--container); margin:0 auto; width:100%; z-index:1; }
.atlas-ticker{
  display:flex; align-items:center; gap:32px;
  padding:14px 0;
  border-top:1px solid var(--trace-line); border-bottom:1px solid var(--trace-line);
  font-family:var(--font-mono); font-size:.72rem; letter-spacing:.12em; color:var(--ink-secondary);
  text-transform:uppercase;
  overflow:hidden;
  margin-top:48px;
}
.atlas-ticker-inner{
  display:flex; gap:48px; white-space:nowrap;
  animation: marquee 40s linear infinite;
}
.atlas-ticker .lat{ color:var(--signal); }
.atlas-coords-grid{
  margin-top:48px;
  display:grid; grid-template-columns:repeat(3,1fr); gap:48px;
}
@media (max-width:768px){ .atlas-coords-grid{ grid-template-columns:1fr; gap:24px; } }
.atlas-coords-grid .coord{
  font-family:var(--font-mono); font-size:.8rem; color:var(--ink-secondary); letter-spacing:.05em;
}
.atlas-coords-grid .coord b{
  display:block; font-family:var(--font-display); font-size:2rem; color:var(--ink-primary);
  letter-spacing:.04em; margin-bottom:6px;
}

.chapter{
  position:relative; padding:160px var(--pad-x);
  border-top:1px solid var(--border-dim);
  overflow:hidden;
}
.chapter:nth-child(odd){ background:var(--bg-panel); }
.chapter-grid{
  max-width:var(--container); margin:0 auto;
  display:grid; grid-template-columns: 1fr 1.4fr; gap:80px;
  align-items:start;
}
@media (max-width:900px){ .chapter-grid{ grid-template-columns:1fr; gap:40px; } }
.chapter-meta{ position:sticky; top:100px; align-self:start; }
@media (max-width:900px){ .chapter-meta{ position:relative; top:auto; } }
.chapter-cidx{
  font-family:var(--font-mono); font-size:.78rem; letter-spacing:var(--ls-mono);
  color:var(--ink-ghost); text-transform:uppercase; margin-bottom:18px;
}
.chapter-name{
  font-family:var(--font-display); font-size:clamp(5rem, 12vw, 12rem); line-height:.85;
  letter-spacing:.005em; color:var(--ink-primary);
}
.chapter-name .accent{ color:var(--signal); }
.chapter-tag{
  margin-top:24px; padding-top:18px; border-top:1px solid var(--border-dim);
  font-family:var(--font-editorial); font-style:italic;
  font-size:1.3rem; line-height:1.3; color:var(--ink-primary);
}
.chapter-body{
  display:flex; flex-direction:column; gap:48px;
}
.chapter-narrative{ color:var(--ink-secondary); font-size:1.05rem; line-height:1.7; }
.chapter-narrative p + p{ margin-top:18px; }
.chapter-stats{
  display:grid; grid-template-columns:repeat(4,1fr); gap:2px; background:var(--border-dim);
}
@media (max-width:768px){ .chapter-stats{ grid-template-columns:repeat(2,1fr); } }
.chapter-stats .cell{
  background:var(--bg-void); padding:20px 18px;
  display:flex; flex-direction:column; gap:6px;
}
.chapter-stats .n{ font-family:var(--font-display); font-size:2rem; color:var(--signal); line-height:1; }
.chapter-stats .l{ font-family:var(--font-mono); font-size:.66rem; letter-spacing:.1em; color:var(--ink-secondary); text-transform:uppercase; }
.chapter-services{
  display:grid; grid-template-columns:repeat(2,1fr); gap:0; border:1px solid var(--border-dim);
}
@media (max-width:600px){ .chapter-services{ grid-template-columns:1fr; } }
.chapter-services li{
  padding:18px 22px;
  display:flex; gap:14px; align-items:start;
  font-size:.92rem; color:var(--ink-secondary);
  border-right:1px solid var(--border-dim); border-bottom:1px solid var(--border-dim);
}
.chapter-services li:nth-child(2n){ border-right:none; }
.chapter-services li:nth-last-child(-n+2){ border-bottom:none; }
.chapter-services li .check{ color:var(--signal); font-family:var(--font-mono); font-size:.8rem; padding-top:2px; }

/* ---------- CASE STUDIES · Editorial newsprint ---------- */
.press-mast{
  position:relative;
  padding:140px var(--pad-x) 60px;
  border-bottom:1px solid var(--signal);
  background:var(--bg-void);
  overflow:hidden;
}
.press-mast::before{
  content:''; position:absolute; inset:0; opacity:.04;
  background-image: linear-gradient(to right, var(--ink-primary) 1px, transparent 1px);
  background-size: 16.6666% 100%;
}
.press-mast-inner{ position:relative; max-width:var(--container); margin:0 auto; }
.press-meta{
  display:flex; justify-content:space-between; gap:24px;
  padding-bottom:14px; border-bottom:1px solid var(--border-dim);
  font-family:var(--font-mono); font-size:.7rem; letter-spacing:.15em; color:var(--ink-secondary);
  text-transform:uppercase; flex-wrap:wrap;
}
.press-meta .vol{ color:var(--signal); }
.press-masthead{
  margin-top:32px;
  font-family:var(--font-display); font-size:clamp(4rem, 14vw, 16rem); line-height:.85;
  letter-spacing:-.01em; color:var(--ink-primary);
}
.press-tagline{
  margin-top:24px;
  font-family:var(--font-editorial); font-style:italic;
  font-size:clamp(1.4rem, 2vw, 1.8rem); line-height:1.3;
  color:var(--ink-primary); max-width:50ch;
}
.press-byline{
  margin-top:36px; padding-top:18px; border-top:1px solid var(--border-dim);
  display:flex; gap:32px; flex-wrap:wrap;
  font-family:var(--font-mono); font-size:.7rem; letter-spacing:.1em; color:var(--ink-secondary);
  text-transform:uppercase;
}
.press-byline b{ color:var(--ink-primary); font-weight:500; }

.dossier{
  border-bottom:1px solid var(--border-dim);
  padding:120px 0;
  position:relative;
}
.dossier:nth-child(even){ background:var(--bg-panel); }
.dossier-inner{
  max-width:var(--container); margin:0 auto; padding:0 var(--pad-x);
  display:grid; grid-template-columns: 200px 1fr 240px; gap:48px;
}
@media (max-width:1100px){ .dossier-inner{ grid-template-columns:1fr; gap:32px; } }
.dossier-folio{
  position:sticky; top:100px; align-self:start;
}
@media (max-width:1100px){ .dossier-folio{ position:relative; top:auto; display:flex; gap:24px; align-items:baseline; } }
.dossier-folio .nr{
  font-family:var(--font-display); font-size:clamp(4rem, 6vw, 6rem); line-height:.8;
  color:var(--signal); letter-spacing:.02em;
}
.dossier-folio .file{
  font-family:var(--font-mono); font-size:.72rem; letter-spacing:.15em; color:var(--ink-ghost);
  text-transform:uppercase; margin-top:18px;
}
.dossier-body h2{
  font-family:var(--font-editorial);
  font-size:clamp(2rem, 3.4vw, 3.4rem); line-height:1.1; color:var(--ink-primary);
  letter-spacing:.005em;
}
.dossier-lede{
  margin-top:18px; font-family:var(--font-editorial); font-style:italic;
  font-size:1.25rem; line-height:1.45; color:var(--ink-primary);
  max-width:62ch;
}
.dossier-body p{ color:var(--ink-secondary); font-size:1rem; line-height:1.7; max-width:60ch; }
.dossier-body .col-2{
  margin-top:32px;
  column-count:2; column-gap:48px;
  color:var(--ink-secondary); font-size:.96rem; line-height:1.7;
}
.dossier-body .col-2 p{ break-inside:avoid; margin-bottom:14px; }
@media (max-width:768px){ .dossier-body .col-2{ column-count:1; } }
.dossier-side{
  border-left:1px solid var(--trace-line);
  padding:0 0 0 24px;
  display:flex; flex-direction:column; gap:24px;
}
@media (max-width:1100px){ .dossier-side{ border-left:none; border-top:1px solid var(--trace-line); padding:24px 0 0 0; } }
.dossier-side .side-h{
  font-family:var(--font-mono); font-size:.66rem; letter-spacing:.15em; color:var(--ink-ghost);
  text-transform:uppercase; margin-bottom:6px;
}
.dossier-side .side-v{
  font-family:var(--font-display); font-size:1.6rem; color:var(--ink-primary); letter-spacing:.04em; line-height:1;
}
.dossier-side .side-v.small{ font-family:var(--font-body); font-size:.92rem; font-weight:500; line-height:1.4; }
.dossier-pull{
  margin-top:48px;
  font-family:var(--font-display); font-size:clamp(2rem, 4vw, 4rem); line-height:1; letter-spacing:.005em;
  color:var(--ink-primary);
  border-top:1px solid var(--trace-line); border-bottom:1px solid var(--trace-line);
  padding:32px 0; max-width:90%;
}
.dossier-pull .accent{ color:var(--signal); }

/* ---------- THREAT INTEL · SOC console grid ---------- */
.console{
  padding:120px var(--pad-x) 0;
  background:var(--bg-deep);
  border-bottom:1px solid var(--trace-line);
  position:relative; overflow:hidden;
}
.console::before{
  content:''; position:absolute; inset:0; opacity:.05;
  background-image:
    linear-gradient(to right, var(--signal) 1px, transparent 1px),
    linear-gradient(to bottom, var(--signal) 1px, transparent 1px);
  background-size: 60px 60px;
  mask-image: radial-gradient(ellipse at 70% 30%, black 0%, transparent 70%);
}
.console-inner{ position:relative; max-width:var(--container); margin:0 auto; }
.console-statusbar{
  display:grid; grid-template-columns: auto 1fr auto auto; gap:24px;
  padding:14px 18px;
  border:1px solid var(--trace-line);
  font-family:var(--font-mono); font-size:.72rem; letter-spacing:.1em;
  color:var(--ink-secondary); text-transform:uppercase;
  align-items:center;
  background:rgba(0,0,0,.4);
}
.console-statusbar .live{ display:inline-flex; align-items:center; gap:8px; color:var(--signal); }
.console-statusbar .live::before{
  content:''; width:8px; height:8px; background:var(--signal); border-radius:50%;
  box-shadow:0 0 12px var(--signal); animation:blink 1.2s infinite;
}
.console-statusbar b{ color:var(--ink-primary); font-weight:500; }

.console-hero{
  display:grid; grid-template-columns: 1.4fr 1fr; gap:48px; align-items:end;
  padding:80px 0 60px;
}
@media (max-width:900px){ .console-hero{ grid-template-columns:1fr; gap:32px; } }
.console-hero h1{
  font-family:var(--font-display);
  font-size:clamp(4rem, 9vw, 10rem); line-height:.85; letter-spacing:.005em;
}
.console-hero h1 .accent{ color:var(--signal); }
.console-hero .lede{
  font-family:var(--font-editorial); font-style:italic;
  font-size:1.4rem; line-height:1.35; color:var(--ink-primary);
}

.console-grid{
  display:grid; grid-template-columns: repeat(12, 1fr);
  gap:2px; background:var(--border-dim);
  border:1px solid var(--border-dim);
  margin-bottom:120px;
}
.cg-panel{
  background:var(--bg-deep);
  padding:24px;
  display:flex; flex-direction:column; gap:14px;
  position:relative; min-height:220px;
}
.cg-panel.span-4{ grid-column: span 4; }
.cg-panel.span-6{ grid-column: span 6; }
.cg-panel.span-8{ grid-column: span 8; }
.cg-panel.span-12{ grid-column: span 12; }
@media (max-width:1100px){
  .cg-panel.span-4, .cg-panel.span-6, .cg-panel.span-8{ grid-column: span 12; }
}
.cg-head{
  display:flex; justify-content:space-between; align-items:center;
  padding-bottom:10px; border-bottom:1px dashed var(--border-dim);
  font-family:var(--font-mono); font-size:.66rem; letter-spacing:.15em; color:var(--ink-secondary);
  text-transform:uppercase;
}
.cg-head .live-dot{ width:6px; height:6px; border-radius:50%; background:var(--signal); box-shadow:0 0 10px var(--signal); animation:blink 1.2s infinite; }
.cg-num{
  font-family:var(--font-display); font-size:clamp(2.8rem, 4vw, 4rem); line-height:1; color:var(--signal);
  letter-spacing:.02em;
  text-shadow: 0 0 30px var(--signal-glow);
}
.cg-label{ font-family:var(--font-mono); font-size:.7rem; letter-spacing:.12em; color:var(--ink-secondary); text-transform:uppercase; }
.cg-row{ display:flex; justify-content:space-between; align-items:baseline; gap:10px; padding:8px 0; border-bottom:1px dashed var(--border-dim); font-family:var(--font-mono); font-size:.78rem; }
.cg-row:last-child{ border-bottom:none; }
.cg-row .name{ color:var(--ink-primary); }
.cg-row .v{ color:var(--signal); }
.cg-bar{ height:4px; background:var(--bg-surface); position:relative; margin-top:6px; }
.cg-bar > div{ position:absolute; inset:0 auto 0 0; background:linear-gradient(90deg, var(--brand), var(--signal)); box-shadow:0 0 8px var(--signal-glow); }

/* sparkline */
.cg-spark{ width:100%; height:60px; }
.cg-spark path{ fill:none; stroke:var(--signal); stroke-width:1.5; filter: drop-shadow(0 0 4px var(--signal-glow)); }
.cg-spark .area{ fill:var(--signal-dim); stroke:none; }

/* ---------- BLOG · Editorial front page ---------- */
.fp{
  padding:140px var(--pad-x) 60px;
  border-bottom:1px solid var(--signal);
  background:var(--bg-void);
  position:relative; overflow:hidden;
}
.fp-inner{ max-width:var(--container); margin:0 auto; }
.fp-issue{
  display:flex; justify-content:space-between; gap:24px;
  padding-bottom:12px; border-bottom:1px solid var(--border-dim);
  font-family:var(--font-mono); font-size:.72rem; letter-spacing:.15em; color:var(--ink-secondary);
  text-transform:uppercase; flex-wrap:wrap;
}
.fp-issue .iss{ color:var(--signal); }
.fp-mast{
  margin-top:28px;
  font-family:var(--font-display); font-size:clamp(4rem, 14vw, 18rem); line-height:.85;
  letter-spacing:-.01em; color:var(--ink-primary);
}
.fp-strap{
  margin-top:24px; padding:16px 0 0;
  border-top:1px solid var(--border-dim);
  display:flex; justify-content:space-between; flex-wrap:wrap; gap:24px;
  font-family:var(--font-editorial); font-style:italic; font-size:1.2rem; color:var(--ink-primary);
}
.fp-strap .auth{ font-family:var(--font-mono); font-size:.72rem; letter-spacing:.1em; color:var(--ink-secondary); text-transform:uppercase; font-style:normal; }

.fp-feature{
  padding:80px var(--pad-x);
  border-bottom:1px solid var(--border-dim);
  position:relative;
}
.fp-feature-inner{
  max-width:var(--container); margin:0 auto;
  display:grid; grid-template-columns: 1fr 1.4fr; gap:64px;
}
@media (max-width:1000px){ .fp-feature-inner{ grid-template-columns:1fr; gap:32px; } }
.fp-feature-art{
  aspect-ratio:4/5;
  background:var(--bg-deep);
  border:1px solid var(--trace-line);
  position:relative; overflow:hidden;
  display:flex; align-items:flex-end; padding:40px;
}
.fp-feature-art::before{
  content:''; position:absolute; inset:0;
  background: radial-gradient(circle at 30% 30%, var(--signal-dim) 0%, transparent 60%);
  filter:blur(30px);
}
.fp-feature-art .glyph{
  position:absolute; top:30px; right:30px;
  font-family:var(--font-mono); font-size:.72rem; letter-spacing:.12em; color:var(--signal); text-transform:uppercase;
}
.fp-feature-art .ascii{
  position:relative; font-family:var(--font-mono); font-size:.74rem; line-height:1.4; color:var(--ink-primary); opacity:.5;
  white-space:pre;
}
.fp-feature-text .kicker{
  font-family:var(--font-mono); font-size:.72rem; letter-spacing:.15em; color:var(--signal);
  text-transform:uppercase;
}
.fp-feature-text h2{
  margin-top:18px;
  font-family:var(--font-display); font-size:clamp(2.8rem, 6vw, 6rem); line-height:.92;
  letter-spacing:.005em; color:var(--ink-primary);
}
.fp-feature-text .deck{
  margin-top:18px; font-family:var(--font-editorial); font-style:italic;
  font-size:1.3rem; line-height:1.4; color:var(--ink-primary); max-width:48ch;
}
.fp-feature-text .by{
  margin-top:32px; padding:14px 0; border-top:1px solid var(--border-dim); border-bottom:1px solid var(--border-dim);
  display:flex; justify-content:space-between; flex-wrap:wrap; gap:14px;
  font-family:var(--font-mono); font-size:.7rem; letter-spacing:.1em; color:var(--ink-secondary); text-transform:uppercase;
}
.fp-feature-text .by b{ color:var(--ink-primary); font-weight:500; }
.fp-feature-text .body{ margin-top:24px; color:var(--ink-secondary); font-size:1rem; line-height:1.7; max-width:54ch; }

.fp-grid{
  padding:80px var(--pad-x);
  border-bottom:1px solid var(--border-dim);
}
.fp-grid-inner{
  max-width:var(--container); margin:0 auto;
  display:grid; grid-template-columns: 2.4fr 1fr; gap:64px; align-items:start;
}
@media (max-width:1000px){ .fp-grid-inner{ grid-template-columns:1fr; gap:48px; } }

.fp-stack{ display:flex; flex-direction:column; gap:0; border-top:1px solid var(--border-dim); }
.fp-stack .post{
  padding:32px 0;
  border-bottom:1px solid var(--border-dim);
  display:grid; grid-template-columns: 80px 1fr auto; gap:32px;
  align-items:start;
  transition: padding-left var(--duration-base) var(--ease-out-expo);
}
.fp-stack .post:hover{ padding-left:18px; }
.fp-stack .post:hover .post-title{ color:var(--signal); }
.fp-stack .date{ font-family:var(--font-mono); font-size:.7rem; letter-spacing:.08em; color:var(--ink-ghost); padding-top:6px; }
.fp-stack .post-title{
  font-family:var(--font-editorial); font-size:clamp(1.3rem, 1.8vw, 1.7rem); line-height:1.25;
  color:var(--ink-primary); transition:color var(--duration-base);
}
.fp-stack .post-deck{ margin-top:6px; font-size:.88rem; color:var(--ink-secondary); max-width:60ch; }
.fp-stack .post-cat{
  font-family:var(--font-mono); font-size:.66rem; letter-spacing:.1em; color:var(--signal); text-transform:uppercase;
  padding:4px 10px; border:1px solid var(--trace-line);
  white-space:nowrap;
}

.fp-side{
  border:1px solid var(--border-dim);
  padding:24px;
  display:flex; flex-direction:column; gap:32px;
  position:sticky; top:100px;
  align-self:start;
}
@media (max-width:1000px){ .fp-side{ position:relative; top:auto; } }
.fp-side h4{
  font-family:var(--font-mono); font-size:.7rem; letter-spacing:.15em; color:var(--signal);
  text-transform:uppercase; padding-bottom:10px; border-bottom:1px solid var(--trace-line);
}
.fp-side .cats{ display:flex; flex-direction:column; gap:6px; }
.fp-side .cats a{
  display:flex; justify-content:space-between; align-items:baseline;
  padding:6px 0;
  font-family:var(--font-body); font-size:.9rem; color:var(--ink-primary);
  border-bottom:1px dashed var(--border-dim);
}
.fp-side .cats a span{ font-family:var(--font-mono); font-size:.7rem; color:var(--ink-ghost); letter-spacing:.05em; }
.fp-side .cats a:hover{ color:var(--signal); }
.fp-side .read{ display:flex; flex-direction:column; gap:14px; }
.fp-side .read a{ font-family:var(--font-editorial); font-size:1.05rem; line-height:1.3; color:var(--ink-primary); }
.fp-side .read a:hover{ color:var(--signal); }

/* ---------- ABOUT · Manifesto statement ---------- */
.manifesto{
  padding:200px var(--pad-x) 140px;
  border-bottom:1px solid var(--border-dim);
  position:relative; overflow:hidden;
}
.manifesto::before{
  content:''; position:absolute; left:-10%; top:30%;
  width:60%; height:60%;
  background: radial-gradient(circle, rgba(45,45,195,0.25) 0%, transparent 60%);
  filter:blur(80px); pointer-events:none;
}
.manifesto::after{
  content:''; position:absolute; right:-5%; bottom:0;
  width:50%; height:50%;
  background: radial-gradient(circle, var(--signal-dim) 0%, transparent 60%);
  filter:blur(80px); pointer-events:none;
}
.manifesto-inner{ position:relative; max-width:var(--container); margin:0 auto; }
.manifesto-meta{
  display:flex; justify-content:space-between; gap:24px; flex-wrap:wrap;
  padding-bottom:14px; border-bottom:1px solid var(--border-dim);
  font-family:var(--font-mono); font-size:.72rem; letter-spacing:.15em;
  color:var(--ink-secondary); text-transform:uppercase;
}
.manifesto-meta .a{ color:var(--signal); }
.manifesto-statement{
  margin-top:80px;
  font-family:var(--font-display);
  font-size:clamp(3rem, 8vw, 9rem); line-height:.92;
  letter-spacing:.005em; color:var(--ink-primary);
  max-width:18ch;
}
.manifesto-statement .accent{ color:var(--signal); }
.manifesto-statement .ghost{ color:var(--ink-ghost); -webkit-text-stroke:1px var(--ink-secondary); color:transparent; }
.manifesto-sign{
  margin-top:80px; padding-top:24px; border-top:1px solid var(--border-dim);
  display:grid; grid-template-columns: 1fr 1fr 1fr; gap:48px;
}
@media (max-width:768px){ .manifesto-sign{ grid-template-columns:1fr; gap:24px; } }
.manifesto-sign .b{
  font-family:var(--font-editorial); font-style:italic; font-size:1.15rem; line-height:1.4;
  color:var(--ink-primary);
}
.manifesto-sign .l{
  font-family:var(--font-mono); font-size:.7rem; letter-spacing:.12em; color:var(--ink-ghost);
  text-transform:uppercase; margin-bottom:8px;
}

.principle{
  padding:120px var(--pad-x);
  border-bottom:1px solid var(--border-dim);
  position:relative;
}
.principle:nth-child(odd){ background:var(--bg-panel); }
.principle-inner{
  max-width:var(--container); margin:0 auto;
  display:grid; grid-template-columns: 120px 1fr; gap:64px; align-items:start;
}
@media (max-width:900px){ .principle-inner{ grid-template-columns:1fr; gap:24px; } }
.principle-n{
  font-family:var(--font-display); font-size:clamp(4rem, 6vw, 6rem); line-height:.8;
  color:var(--signal); letter-spacing:.02em;
  position:sticky; top:100px;
}
@media (max-width:900px){ .principle-n{ position:relative; top:auto; } }
.principle-body h2{
  font-family:var(--font-display); font-size:clamp(2.4rem, 4vw, 4.4rem); line-height:.95;
  color:var(--ink-primary); letter-spacing:.005em; margin-bottom:24px;
}
.principle-body .lede{
  font-family:var(--font-editorial); font-style:italic; font-size:clamp(1.4rem, 2vw, 1.8rem); line-height:1.35;
  color:var(--ink-primary); max-width:48ch; margin-bottom:24px;
}
.principle-body p{ color:var(--ink-secondary); font-size:1rem; line-height:1.7; max-width:62ch; }

/* ---------- BRAND · Spec sheet manual ---------- */
.spec-doc{
  padding:200px var(--pad-x) 80px;
  border-bottom:1px solid var(--signal);
  background:var(--bg-deep);
  position:relative;
}
.spec-doc::before{
  content:''; position:absolute; inset:0; opacity:.04;
  background-image: linear-gradient(to right, var(--ink-primary) 1px, transparent 1px);
  background-size: calc(100% / 12) 100%;
}
.spec-doc-inner{ position:relative; max-width:var(--container); margin:0 auto; }
.spec-doc-head{
  display:grid; grid-template-columns: 2fr 1fr; gap:48px;
  padding-bottom:48px; border-bottom:1px solid var(--border-dim);
}
@media (max-width:768px){ .spec-doc-head{ grid-template-columns:1fr; } }
.spec-doc h1{
  font-family:var(--font-display); font-size:clamp(3rem, 6vw, 6rem); line-height:.95;
  color:var(--ink-primary); letter-spacing:.005em;
}
.spec-doc h1 small{ display:block; font-size:.3em; color:var(--signal); letter-spacing:.2em; }
.spec-doc-meta{
  display:flex; flex-direction:column; gap:6px;
  font-family:var(--font-mono); font-size:.72rem; letter-spacing:.08em;
  color:var(--ink-secondary); text-transform:uppercase;
}
.spec-doc-meta .pair{ display:flex; justify-content:space-between; padding:6px 0; border-bottom:1px dashed var(--border-dim); gap:14px; }
.spec-doc-meta .pair b{ color:var(--ink-primary); font-weight:500; }
.spec-toc{
  margin-top:48px;
  display:grid; grid-template-columns:repeat(4,1fr); gap:0;
  border:1px solid var(--border-dim);
}
@media (max-width:768px){ .spec-toc{ grid-template-columns:repeat(2,1fr); } }
.spec-toc a{
  padding:18px 22px;
  border-right:1px solid var(--border-dim);
  display:flex; flex-direction:column; gap:6px;
  transition: background var(--duration-base);
}
.spec-toc a:last-child{ border-right:none; }
.spec-toc a:hover{ background:var(--signal-dim); }
.spec-toc a .n{ font-family:var(--font-mono); font-size:.7rem; letter-spacing:.12em; color:var(--signal); text-transform:uppercase; }
.spec-toc a .l{ font-family:var(--font-display); font-size:1.4rem; color:var(--ink-primary); letter-spacing:.04em; }

.spec-sec{
  padding:120px var(--pad-x);
  border-bottom:1px solid var(--border-dim);
  scroll-margin-top:80px;
}
.spec-sec:nth-child(even){ background:var(--bg-panel); }
.spec-sec-head{
  display:grid; grid-template-columns: 240px 1fr; gap:48px; align-items:end;
  margin-bottom:64px;
}
@media (max-width:900px){ .spec-sec-head{ grid-template-columns:1fr; gap:14px; margin-bottom:40px; } }
.spec-sec-n{
  font-family:var(--font-display); font-size:clamp(5rem, 8vw, 9rem); line-height:.8; color:var(--signal); letter-spacing:.02em;
}
.spec-sec-h{
  font-family:var(--font-display); font-size:clamp(2.4rem, 4vw, 4rem); line-height:.95; color:var(--ink-primary);
}

/* ---------- TOOL pages ---------- */
.tool-shell{
  padding:140px var(--pad-x) 80px;
  position:relative; overflow:hidden;
}
.tool-shell::before{
  content:''; position:absolute; inset:0; opacity:.03;
  background-image:
    linear-gradient(to right, var(--signal) 1px, transparent 1px),
    linear-gradient(to bottom, var(--signal) 1px, transparent 1px);
  background-size:40px 40px;
}
.tool-head{
  display:grid; grid-template-columns: 1.4fr 1fr; gap:64px;
  padding-bottom:48px; border-bottom:1px solid var(--trace-line);
  position:relative; max-width:var(--container); margin:0 auto;
}
@media (max-width:900px){ .tool-head{ grid-template-columns:1fr; gap:24px; } }
.tool-meta{
  font-family:var(--font-mono); font-size:.72rem; letter-spacing:.12em; color:var(--ink-ghost);
  text-transform:uppercase; margin-bottom:18px;
  display:flex; gap:16px; flex-wrap:wrap;
}
.tool-meta .live{ color:var(--signal); display:inline-flex; align-items:center; gap:8px; }
.tool-meta .live::before{ content:''; width:6px; height:6px; border-radius:50%; background:var(--signal); box-shadow:0 0 10px var(--signal); animation:blink 1.2s infinite; }
.tool-head h1{
  font-family:var(--font-display); font-size:clamp(3rem, 7vw, 7rem); line-height:.92;
  letter-spacing:.005em; color:var(--ink-primary);
}
.tool-head h1 .accent{ color:var(--signal); }
.tool-head .lede{
  font-family:var(--font-editorial); font-style:italic;
  font-size:1.2rem; line-height:1.4; color:var(--ink-primary); max-width:48ch;
}

/* Heatmap grid for CVE / breach pages */
.heat-row{
  display:grid; grid-template-columns: 200px 1fr;
  border-bottom:1px solid var(--border-dim);
}
.heat-row .name{
  font-family:var(--font-mono); font-size:.78rem; letter-spacing:.06em;
  color:var(--ink-primary); text-transform:uppercase;
  padding:14px 18px; border-right:1px solid var(--border-dim);
  display:flex; align-items:center;
}
.heat-cells{ display:grid; grid-template-columns: repeat(12, 1fr); }
.heat-cell{
  aspect-ratio:1;
  background:var(--bg-surface);
  border-right:1px solid var(--bg-void);
  transition: transform var(--duration-fast);
  position:relative;
}
.heat-cell:last-child{ border-right:none; }
.heat-cell[data-v="1"]{ background:rgba(255,102,255,0.18); }
.heat-cell[data-v="2"]{ background:rgba(255,102,255,0.40); }
.heat-cell[data-v="3"]{ background:rgba(255,102,255,0.65); }
.heat-cell[data-v="4"]{ background:rgba(255,102,255,0.95); box-shadow: inset 0 0 0 1px var(--signal); }
.heat-cell:hover{ transform:scale(1.4); z-index:1; }

/* ASCII map (cities / breach) */
.ascii-block{
  font-family:var(--font-mono); font-size:.7rem; line-height:1.05;
  color:var(--ink-primary); white-space:pre;
  text-shadow:0 0 8px var(--signal-glow);
  letter-spacing:.05em;
}

/* tighter ruled list */
.ruled{ display:flex; flex-direction:column; }
.ruled li{
  padding:18px 0;
  border-top:1px solid var(--border-dim);
  display:grid; grid-template-columns: 50px 1fr auto; gap:18px; align-items:baseline;
}
.ruled li:last-child{ border-bottom:1px solid var(--border-dim); }
.ruled li .k{ font-family:var(--font-mono); font-size:.7rem; color:var(--signal); letter-spacing:.06em; }
.ruled li .n{ font-family:var(--font-body); color:var(--ink-primary); font-size:1rem; }
.ruled li .d{ font-family:var(--font-mono); font-size:.72rem; color:var(--ink-ghost); letter-spacing:.05em; }
