/* ============================================================================
   MAKRR INDIA — unified design system  ·  "datasheet / live-feed" direction
   One stylesheet for the whole multi-page site. Load it alone:
     <link rel="stylesheet" href="makrr.css">
   Dark canvas · brand magenta · one switchable per-vertical accent.
   Set the accent with  data-vertical="brand|robotics|logistics|defence|
   healthcare|research"  on <html>.
   ============================================================================ */

/* Self-hosted fonts — no third-party (Google) requests; privacy-clean + faster */
@font-face{font-family:'JetBrains Mono';font-style:normal;font-weight:400;font-display:swap;src:url('fonts/jetbrainsmono-400.woff2') format('woff2')}
@font-face{font-family:'JetBrains Mono';font-style:normal;font-weight:500;font-display:swap;src:url('fonts/jetbrainsmono-500.woff2') format('woff2')}
@font-face{font-family:'JetBrains Mono';font-style:normal;font-weight:600;font-display:swap;src:url('fonts/jetbrainsmono-600.woff2') format('woff2')}
@font-face{font-family:'Jost';font-style:normal;font-weight:400;font-display:swap;src:url('fonts/jost-400.woff2') format('woff2')}
@font-face{font-family:'Jost';font-style:normal;font-weight:500;font-display:swap;src:url('fonts/jost-500.woff2') format('woff2')}
@font-face{font-family:'Jost';font-style:normal;font-weight:600;font-display:swap;src:url('fonts/jost-600.woff2') format('woff2')}
@font-face{font-family:'Jost';font-style:normal;font-weight:700;font-display:swap;src:url('fonts/jost-700.woff2') format('woff2')}

@font-face{
  font-family:'Avenir';
  src:url('fonts/Avenir_Regular.ttf') format('opentype');
  font-weight:400; font-style:normal; font-display:swap;
}

:root{
  /* surfaces — near-black, faintly cool */
  --bg:#0B0A0F; --s1:#121019; --s2:#1A1825; --s3:#232031;
  --line:#272434; --line2:#1B1926;

  /* foreground */
  --fg:#E7E4F0;        /* primary / emphasis */
  --fg2:#9E99AD;       /* body copy (AA on --bg) */
  --fg3:#878299;       /* mono meta / tracked labels */
  --fgm:#ABA6BA;       /* mono readouts */
  --hd:color-mix(in srgb, var(--accent) 12%, #ECEAF4);  /* display headings */

  /* MAKRR master brand */
  --brand:#F82587;

  /* switchable vertical accent (default = brand) */
  --accent:#F82587; --accent-ink:#1d0410;
  --accent-soft:color-mix(in srgb, var(--accent) 14%, transparent);
  --accent-line:color-mix(in srgb, var(--accent) 42%, var(--line));
  --accent-glow:color-mix(in srgb, var(--accent) 24%, transparent);

  /* type families */
  --fd:'Jost', system-ui, sans-serif;          /* display (uppercase grotesk) */
  --fb:'Avenir','Jost', system-ui, sans-serif; /* body */
  --fm:'JetBrains Mono', ui-monospace, monospace;

  /* motion */
  --ez:cubic-bezier(.16,1,.3,1);          /* ease-out-expo-ish */
  --ezq:cubic-bezier(.25,.46,.45,.94);
  --dur:.22s;

  /* z-scale */
  --z-nav:400; --z-hud:5; --z-drop:420;
}

/* ── vertical themes — the single swappable color ───────────────────────── */
[data-vertical="brand"]      {--accent:#F82587;--accent-ink:#1d0410;--hd:#ECEAF4}
[data-vertical="robotics"]   {--accent:#5285F0;--accent-ink:#050e22}
[data-vertical="logistics"]  {--accent:#FF7E5E;--accent-ink:#200a04}
[data-vertical="defence"]    {--accent:#8468F0;--accent-ink:#0d0722}
[data-vertical="healthcare"] {--accent:#7FA6C9;--accent-ink:#0a1420}
[data-vertical="research"]   {--accent:#1FB6A6;--accent-ink:#03201c}

/* ============================================================================
   BASE
   ============================================================================ */
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scrollbar-width:thin;scrollbar-color:var(--s3) var(--bg)}
body{
  background:var(--bg); color:var(--fg);
  font-family:var(--fb); font-size:16px; line-height:1.6;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
img,video{max-width:100%;display:block}
::selection{background:var(--accent);color:var(--accent-ink)}
:focus-visible{outline:1.5px solid var(--accent);outline-offset:3px;border-radius:2px}

.wrap{max-width:1280px;margin:0 auto;padding:0 32px}
.m{font-family:var(--fm)}

/* micro type */
.tag{font-family:var(--fm);font-size:13px;font-weight:600;letter-spacing:.32em;text-transform:uppercase;color:var(--accent)}
.meta{font-family:var(--fm);font-size:13px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--fg3)}
.note{font-family:var(--fm);font-size:13px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--fg3)}
.eyebrow{font-family:var(--fm);font-size:13px;font-weight:600;letter-spacing:.32em;text-transform:uppercase;color:var(--accent)}

.lead{font-size:clamp(16px,1.55vw,18.5px);color:var(--fg2);max-width:58ch;line-height:1.65}
p{color:var(--fg2);max-width:64ch;text-wrap:pretty}
strong,b{color:var(--fg);font-weight:600}

/* display scale (uppercase grotesk) */
.disp{font-family:var(--fd);font-weight:600;text-transform:uppercase;letter-spacing:-.014em;line-height:1.05;color:var(--hd);text-wrap:balance}
.d1{font-size:clamp(40px,6.8vw,84px)}
.d2{font-size:clamp(30px,4.2vw,54px)}
.d3{font-size:clamp(17px,1.9vw,22px)}

/* ============================================================================
   NAV  (injected by nav.js)
   ============================================================================ */
header.site{
  position:fixed;top:0;left:0;right:0;z-index:var(--z-nav);
  background:color-mix(in srgb, var(--bg) 82%, transparent);
  backdrop-filter:blur(14px) saturate(140%);
  -webkit-backdrop-filter:blur(14px) saturate(140%);
  border-bottom:1px solid var(--line2);
}
/* scroll-progress hairline */
.nav-prog{position:absolute;left:0;bottom:-1px;height:2px;width:100%;transform-origin:0 50%;
  background:linear-gradient(90deg, var(--accent), color-mix(in srgb,var(--accent) 40%, transparent));
  transform:scaleX(var(--sp,0));}
@supports (animation-timeline: scroll()){
  .nav-prog{transform:scaleX(0);animation:navprog linear both;animation-timeline:scroll(root)}
}
@keyframes navprog{to{transform:scaleX(1)}}

.navbar{display:flex;align-items:stretch;height:64px;max-width:1280px;margin:0 auto;padding:0 32px}
.navbar .logo{display:flex;align-items:center;gap:12px;margin-right:auto}
.navbar .logo img{height:31px}
.navbar .logo .entity{font-family:var(--fm);font-size:12.5px;letter-spacing:.32em;color:var(--fg3);text-transform:uppercase;border-left:1px solid var(--line);padding-left:12px}
nav.main{display:flex;align-items:stretch}
nav.main > a, nav.main .drop > button{
  display:flex;align-items:center;gap:7px;padding:0 14px;border:none;background:none;cursor:pointer;
  font-family:var(--fm);font-size:13px;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--fg2);
  border-left:1px solid var(--line2);transition:color 150ms var(--ezq),background 150ms var(--ezq);
}
nav.main > a:hover, nav.main .drop > button:hover{color:var(--fg);background:var(--s1)}
nav.main > a.active{color:var(--accent)}
nav.main > a .n, nav.main .drop .n{color:var(--fg3);font-size:12px}
.drop{position:relative;display:flex}
.drop .caret{font-size:8px;color:var(--fg3);transition:transform 200ms var(--ez)}
.drop.open .caret{transform:rotate(180deg)}
.drop-menu{position:absolute;top:100%;left:-1px;min-width:300px;background:var(--bg);border:1px solid var(--line);display:none;flex-direction:column;z-index:var(--z-drop);box-shadow:0 24px 60px rgba(0,0,0,.55)}
.drop.open .drop-menu{display:flex}
.drop-menu a{display:flex;align-items:center;gap:12px;padding:14px 18px;font-family:var(--fm);font-size:13px;letter-spacing:.18em;text-transform:uppercase;color:var(--fg2);border-bottom:1px solid var(--line2);transition:all 150ms var(--ezq)}
.drop-menu a:last-child{border-bottom:none}
.drop-menu a:hover{background:var(--s1);color:var(--fg);padding-left:24px}
.drop-menu .vdot{width:7px;height:7px;flex:none}
.nav-cta{display:flex;align-items:center;padding:0 22px;background:var(--accent);color:var(--accent-ink)!important;font-family:var(--fm);font-size:13px;font-weight:600;letter-spacing:.2em;text-transform:uppercase;transition:filter 150ms var(--ezq)}
.nav-cta:hover{filter:brightness(1.12)}
.nav-burger{display:none;background:none;border:none;border-left:1px solid var(--line2);color:var(--fg2);font-size:17px;padding:0 16px;cursor:pointer}
@media(max-width:1080px){
  nav.main{display:none;position:absolute;top:64px;left:0;right:0;flex-direction:column;align-items:stretch;background:var(--bg);border-bottom:1px solid var(--line)}
  nav.main.open{display:flex}
  nav.main > a, nav.main .drop > button{height:52px;border-left:none;border-bottom:1px solid var(--line2);width:100%}
  .drop{flex-direction:column}
  .drop-menu{position:static;border:none;background:var(--s1);box-shadow:none}
  .nav-cta{height:52px;justify-content:center}
  .nav-burger{display:block}
}
main{padding-top:64px}

/* ============================================================================
   BUTTONS  (+ magnetic hook on .b-acc)
   ============================================================================ */
.b{position:relative;overflow:hidden;display:inline-flex;align-items:center;gap:10px;padding:15px 26px;border-radius:2px;cursor:pointer;
  font-family:var(--fm);font-size:13px;font-weight:600;letter-spacing:.2em;text-transform:uppercase;
  border:1px solid transparent;transition:transform 200ms var(--ez),filter 150ms var(--ezq),border-color 150ms var(--ezq),color 150ms var(--ezq);line-height:1;
  will-change:transform}
.b > *{position:relative;z-index:1}
.b:active{transform:translateY(1px) scale(.99)}
.b-acc{background:var(--accent);color:var(--accent-ink);box-shadow:0 0 0 0 var(--accent-glow)}
.b-acc:hover{filter:brightness(1.1);box-shadow:0 14px 38px var(--accent-glow)}
.b-line{border-color:var(--line);color:var(--fg);background:transparent}
.b-line:hover{border-color:var(--accent);color:var(--accent)}
.cta-row{display:flex;gap:14px;flex-wrap:wrap;align-items:center}

/* ============================================================================
   HERO  (full-bleed live feed) + HUD overlay
   ============================================================================ */
.hero-video{position:relative;min-height:92vh;min-height:92svh;display:flex;align-items:flex-end;overflow:hidden;border-bottom:1px solid var(--line)}
.hero-video video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero-video .shade{position:absolute;inset:0;z-index:2;
  background:
    linear-gradient(to top, rgba(11,10,15,.97) 3%, rgba(11,10,15,.55) 42%, rgba(11,10,15,.20) 78%, rgba(11,10,15,.45) 100%),
    radial-gradient(120% 90% at 80% 10%, transparent 40%, rgba(11,10,15,.5) 100%);}
.hv-content{position:relative;z-index:var(--z-hud);width:100%;max-width:1280px;margin:0 auto;padding:120px 32px 64px}

/* generative feature-tracking canvas (motion.js) */
.hero-fx{position:absolute;inset:0;z-index:3;pointer-events:none}
/* camera-feed scanline + vignette artifact */
.feed-fx{position:absolute;inset:0;z-index:2;pointer-events:none;mix-blend-mode:overlay;opacity:.55;
  background:repeating-linear-gradient(to bottom, rgba(255,255,255,.05) 0 1px, transparent 1px 3px);
  animation:feedscan 7s linear infinite}
@keyframes feedscan{to{background-position:0 60px}}

/* HUD frame — corner brackets, scan sweep, status + telemetry readouts */
.hud{position:absolute;inset:0;z-index:3;pointer-events:none;overflow:hidden}
.hud .corner{position:absolute;width:30px;height:30px;border:1.5px solid color-mix(in srgb,var(--accent) 70%, transparent);opacity:.8}
.hud .corner.tl{top:78px;left:30px;border-right:0;border-bottom:0}
.hud .corner.tr{top:78px;right:30px;border-left:0;border-bottom:0}
.hud .corner.bl{bottom:26px;left:30px;border-right:0;border-top:0}
.hud .corner.br{bottom:26px;right:30px;border-left:0;border-top:0}
.hud .readout{position:absolute;display:flex;align-items:center;gap:9px;
  font-family:var(--fm);font-size:13px;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:var(--fgm)}
.hud .readout.tl{top:84px;left:48px}
.hud .readout.tr{top:84px;right:48px;color:var(--fg3)}
.hud .live-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);box-shadow:0 0 10px var(--accent);animation:blink 1.6s steps(1,end) infinite}
.hud .scan{position:absolute;left:0;right:0;height:140px;top:-160px;
  background:linear-gradient(to bottom, transparent, color-mix(in srgb,var(--accent) 9%, transparent) 60%, color-mix(in srgb,var(--accent) 22%, transparent) 96%, var(--accent) 100%);
  mix-blend-mode:screen;opacity:.5;animation:scan 5.5s var(--ezq) infinite}
@keyframes scan{0%{top:-160px;opacity:0}10%{opacity:.5}90%{opacity:.5}100%{top:100%;opacity:0}}
@keyframes blink{0%,60%{opacity:1}61%,100%{opacity:.25}}

/* hero content reveal — decode / blur-in */
@keyframes rise{from{opacity:0;transform:translateY(22px);filter:blur(9px)}to{opacity:1;transform:none;filter:blur(0)}}
@keyframes heroline{from{opacity:0;transform:translateY(28px);clip-path:inset(0 0 102% 0);filter:blur(12px)}to{opacity:1;transform:none;clip-path:inset(0 0 -14% 0);filter:blur(0)}}
.hv-content > *{animation:rise 760ms var(--ez) both}
.hv-content > *:nth-child(2){animation-delay:120ms}
.hv-content > *:nth-child(3){animation-delay:260ms}
.hv-content > *:nth-child(4){animation-delay:380ms}
.hv-content .d1{animation:heroline 1000ms var(--ez) 120ms both;clip-path:inset(0 0 -14% 0)}

/* live telemetry panel (top-right) */
.hud-panel{position:absolute;right:48px;top:126px;z-index:4;display:flex;flex-direction:column;gap:9px;
  min-width:172px;padding:14px 16px;
  font-family:var(--fm);font-size:12.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--fg3);
  border:1px solid color-mix(in srgb,var(--accent) 26%, var(--line));
  background:color-mix(in srgb,var(--bg) 50%, transparent);
  backdrop-filter:blur(9px) saturate(140%);-webkit-backdrop-filter:blur(9px) saturate(140%);
  animation:rise 760ms var(--ez) 460ms both}
.hud-panel .hp-title{color:var(--fgm);border-bottom:1px solid var(--line);padding-bottom:9px}
.hud-panel .r{display:flex;justify-content:space-between;gap:20px;align-items:baseline}
.hud-panel b{color:var(--accent);font-weight:600;font-size:15px;letter-spacing:.02em;font-variant-numeric:tabular-nums}
@media(max-width:820px){.hud-panel{display:none}}


/* ============================================================================
   DETECTION TICKER
   ============================================================================ */
.tick{display:flex;align-items:stretch;overflow:hidden;border-bottom:1px solid var(--line);background:var(--bg)}
.tick-label{flex:none;display:flex;align-items:center;gap:9px;padding:0 22px;border-right:1px solid var(--line);font-family:var(--fm);font-size:13px;font-weight:600;letter-spacing:.26em;color:var(--accent);text-transform:uppercase;background:var(--bg);z-index:2}
.tick-label::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--accent);box-shadow:0 0 8px var(--accent);animation:blink 1.6s steps(1,end) infinite}
.tick-body{overflow:hidden;flex:1}
.tick-track{display:flex;white-space:nowrap;animation:tick 40s linear infinite;width:max-content}
.tick span{font-family:var(--fm);font-size:13px;letter-spacing:.18em;color:var(--fg3);padding:13px 26px;border-right:1px solid var(--line2);text-transform:uppercase}
.tick span b{color:var(--accent);font-weight:500}
@keyframes tick{to{transform:translateX(-50%)}}
.tick:hover .tick-track{animation-play-state:paused}

/* ============================================================================
   SECTIONS — ruled, indexed
   ============================================================================ */
section.sec{border-bottom:1px solid var(--line);padding:clamp(56px,8vw,96px) 0}
.sec-id{display:flex;align-items:baseline;gap:22px;margin-bottom:48px}
.sec-id .ix{font-family:var(--fm);font-weight:500;font-size:clamp(38px,4.6vw,64px);color:transparent;-webkit-text-stroke:1px var(--fg3);line-height:1}
.sec-id .tag{font-size:16px;padding-bottom:8px}
.split{display:grid;grid-template-columns:5fr 7fr;gap:64px;align-items:center}
.split.rev{grid-template-columns:7fr 5fr}
@media(max-width:880px){.split,.split.rev{grid-template-columns:1fr;gap:36px}}

/* media frames + corner marks */
.frame{position:relative;border:1px solid var(--line);background:var(--s1);overflow:hidden}
.frame img,.frame video{width:100%;height:100%;object-fit:cover;display:block}
.frame::before,.frame::after{font-family:var(--fm);color:var(--accent);font-size:15px;position:absolute;line-height:1;z-index:2}
.frame::before{content:"+";top:7px;left:9px}
.frame::after{content:"+";bottom:7px;right:9px}
figure.shot{margin:0}
figure.shot figcaption{display:flex;justify-content:space-between;gap:14px;padding:10px 2px 0;font-family:var(--fm);font-size:13px;font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:var(--fg3)}
figure.shot figcaption b{color:var(--fgm);font-weight:500}
figure.shot .frame{transition:border-color 250ms var(--ez)}
figure.shot:hover .frame{border-color:var(--accent)}
/* side-by-side shots (.g2) share one aspect so frames + captions align */
.g2 figure.shot .frame{aspect-ratio:1/1}

/* stats */
.stats{display:grid;grid-template-columns:repeat(4,1fr)}
.stats > div{padding:34px 26px;border-left:1px solid var(--line)}
.stats > div:first-child{border-left:none}
.stats .v{font-family:var(--fd);font-weight:600;font-size:clamp(24px,2.9vw,42px);line-height:1.05;letter-spacing:.01em;color:var(--hd);text-transform:uppercase}
.stats .v em{color:var(--accent);font-style:normal}
.stats .k{font-family:var(--fm);font-size:14.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--fg3);margin-top:12px;line-height:1.5}
@media(max-width:820px){.stats{grid-template-columns:1fr 1fr}.stats > div{border-left:none;border-top:1px solid var(--line2)}.stats > div:nth-child(-n+2){border-top:none}}

/* timeline steps */
.tline{display:flex;flex-direction:column}
.tline .st{display:grid;grid-template-columns:110px 220px 1fr;gap:28px;padding:30px 0;border-top:1px solid var(--line);align-items:baseline}
.tline .st:last-child{border-bottom:1px solid var(--line)}
.tline .ix{font-family:var(--fm);font-size:30px;font-weight:500;color:var(--accent)}
.tline .t{font-family:var(--fd);font-size:17px;font-weight:600;text-transform:uppercase;letter-spacing:.03em;color:var(--hd)}
.tline .d{color:var(--fg2);font-size:16px;max-width:54ch}
@media(max-width:760px){.tline .st{grid-template-columns:64px 1fr;gap:14px 20px}.tline .d{grid-column:2}}

/* sector index rows — accent flood on hover */
.xrows{border-top:1px solid var(--line)}
a.xrow{display:grid;grid-template-columns:96px 1fr auto;gap:8px 24px;align-items:center;padding:30px 18px;border-bottom:1px solid var(--line);transition:background 200ms var(--ezq),padding-left 200ms var(--ez);position:relative;overflow:hidden}
a.xrow .ix{font-family:var(--fm);font-size:14px;letter-spacing:.2em;color:var(--fg3)}
a.xrow .t{font-family:var(--fd);font-size:clamp(16px,2vw,24px);font-weight:600;text-transform:uppercase;color:var(--hd);line-height:1.15}
a.xrow .d{font-family:var(--fm);font-size:13px;letter-spacing:.16em;text-transform:uppercase;color:var(--fg3);grid-column:2;margin-top:2px}
a.xrow .go{font-family:var(--fm);font-size:15px;color:var(--fg3);grid-row:1 / span 2;align-self:center;transition:transform 220ms var(--ez)}
a.xrow:hover{background:var(--accent);padding-left:30px}
a.xrow:hover .t,a.xrow:hover .ix,a.xrow:hover .d,a.xrow:hover .go{color:var(--accent-ink)}
a.xrow:hover .go{transform:translateX(6px)}
@media(max-width:640px){a.xrow{grid-template-columns:54px 1fr auto;padding:22px 8px}a.xrow:hover{padding-left:16px}}

/* spec list + marquee */
.specline{display:flex;flex-wrap:wrap;gap:0;border-block:1px solid var(--line)}
.specline span{font-family:var(--fm);font-size:13px;letter-spacing:.2em;text-transform:uppercase;color:var(--fg2);padding:14px 22px;border-right:1px solid var(--line2)}
.spec-tick{overflow:hidden;border-block:1px solid var(--line)}
.spec-track{display:flex;white-space:nowrap;width:max-content;animation:tick 28s linear infinite}
.spec-track span{font-family:var(--fm);font-size:13px;letter-spacing:.2em;text-transform:uppercase;color:var(--fg2);padding:14px 26px;border-right:1px solid var(--line2)}
.spec-track span b{color:var(--accent);font-weight:500}
.spec-tick:hover .spec-track{animation-play-state:paused}

/* compare: today / with makrr */
.cmp{display:grid;grid-template-columns:1fr 1fr;border:1px solid var(--line)}
.cmp .col{padding:34px 30px}
.cmp .col + .col{border-left:1px solid var(--line)}
.cmp .col.aft{background:linear-gradient(180deg, color-mix(in srgb,var(--accent) 6%, transparent), transparent 60%)}
.cmp h6{font-family:var(--fm);font-size:16px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--fg3);margin-bottom:24px}
.cmp .col.aft h6{color:var(--accent)}
.cmp ul{list-style:none;display:flex;flex-direction:column;gap:14px}
.cmp li{color:var(--fg2);font-size:16px;display:flex;gap:12px}
.cmp li::before{content:"·";color:var(--fg3)}
.cmp .aft li::before{content:"→";color:var(--accent)}
@media(max-width:760px){.cmp{grid-template-columns:1fr}.cmp .col + .col{border-left:none;border-top:1px solid var(--line)}}

/* checks */
ul.checks{list-style:none;display:flex;flex-direction:column;gap:0;border-top:1px solid var(--line2)}
ul.checks li{display:grid;grid-template-columns:18px minmax(120px,1fr) 1.5fr;gap:0 20px;align-items:start;color:var(--fg2);font-size:16px;padding:18px 0;border-bottom:1px solid var(--line2);line-height:1.55}
ul.checks li::before{content:"→";color:var(--accent);margin-top:2px}
ul.checks li b{display:block;color:var(--fg);line-height:1.4;font-size:15px}
ul.checks li span{display:block;line-height:1.55}
@media(max-width:560px){ul.checks li{grid-template-columns:18px 1fr;gap:4px 14px}ul.checks li span{grid-column:2}}

/* quote */
.quote{padding:clamp(70px,11vw,110px) 0;border-bottom:1px solid var(--line);position:relative;overflow:hidden}
.quote blockquote{font-family:var(--fd);font-weight:600;text-transform:uppercase;font-size:clamp(22px,3.4vw,44px);line-height:1.22;letter-spacing:.01em;color:var(--hd);max-width:26ch}
.quote blockquote em{font-style:normal;color:var(--accent)}
.quote .meta{display:block;margin-top:28px}

/* CTA block */
.ctab{display:grid;grid-template-columns:1fr auto;gap:40px;align-items:center;padding-block:clamp(56px,8vw,80px)}
.ctab h2{font-family:var(--fd);font-weight:600;text-transform:uppercase;font-size:clamp(20px,2.4vw,32px);line-height:1.22;color:var(--hd)}
.ctab p{margin-top:14px}
@media(max-width:760px){.ctab{grid-template-columns:1fr}}

/* inner page hero */
.phero{padding:clamp(72px,10vw,108px) 0 64px;border-bottom:1px solid var(--line);position:relative;overflow:hidden}
.phero .ghost{position:absolute;right:0;bottom:-.1em;font-family:var(--fd);font-weight:700;font-size:clamp(110px,17vw,240px);line-height:.82;color:transparent;-webkit-text-stroke:1px var(--line);pointer-events:none;user-select:none;max-width:60%;text-align:right;overflow:hidden;z-index:0}
.phero > .wrap{position:relative;z-index:1}
.phero .crumb{display:block;margin-bottom:26px}
.phero .crumb a:hover{color:var(--accent)}
.phero .lead{margin-top:26px}
.phero .cta-row{margin-top:36px}
.phero h1{position:relative}
/* industry hero with looping video background (sits under the injected .phero-hud) */
.phero.has-bg{display:flex;align-items:center;min-height:clamp(460px,66vh,640px)}
.phero.has-bg > .wrap{width:100%}
.phero.has-bg .ghost{display:none}
.phero-bg{position:absolute;inset:0;z-index:0;overflow:hidden}
.phero-bg video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.phero-shade{position:absolute;inset:0;
  background:
    linear-gradient(180deg, rgba(11,10,15,.80) 0%, rgba(11,10,15,.60) 45%, rgba(11,10,15,.85) 100%),
    radial-gradient(120% 100% at 78% 6%, transparent 36%, rgba(11,10,15,.5) 100%);}

/* schematic diagram */
.schem{border:1px solid var(--line);padding:40px 32px;position:relative;background:var(--s1)}
.schem .bound{border:1px dashed var(--accent);padding:30px 22px 22px;position:relative;display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.schem .bound .blabel{position:absolute;top:-8px;left:16px;background:var(--s1);padding:0 10px;font-family:var(--fm);font-size:12.5px;letter-spacing:.28em;color:var(--accent)}
.schem .node{flex:1;min-width:120px;text-align:center;border:1px solid var(--line);padding:16px 10px;background:var(--bg);transition:border-color 220ms var(--ez)}
.schem:hover .node{border-color:var(--accent-line)}
.schem .node .nt{font-family:var(--fm);font-size:13px;letter-spacing:.16em;color:var(--fg);text-transform:uppercase}
.schem .node .nd{font-family:var(--fm);font-size:13px;color:var(--fg3);margin-top:5px;letter-spacing:.06em}
.schem .arrow{font-family:var(--fm);color:var(--accent);font-size:15px;flex:none}
.schem .outside{display:flex;justify-content:space-between;margin-top:16px;font-family:var(--fm);font-size:13px;letter-spacing:.18em;color:var(--fg3);text-transform:uppercase;flex-wrap:wrap;gap:8px}
.schem .outside b{color:var(--fgm);font-weight:500}

/* grids */
.g2{display:grid;grid-template-columns:1fr 1fr;gap:28px}
.g3{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
@media(max-width:880px){.g2,.g3{grid-template-columns:1fr}}

/* leadership */
.person{border:1px solid var(--line);padding:34px 30px;transition:border-color 250ms var(--ez)}
.person:hover{border-color:var(--accent-line)}
.person .ph{width:110px;height:110px;object-fit:cover;border:1px solid var(--line);filter:grayscale(1) contrast(1.05);margin-bottom:22px;transition:filter 350ms var(--ez)}
.person:hover .ph{filter:grayscale(0)}
.person h3{font-family:var(--fd);font-size:17px;font-weight:600;text-transform:uppercase;color:var(--hd)}
.person .role{font-family:var(--fm);font-size:13px;letter-spacing:.24em;text-transform:uppercase;color:var(--accent);margin:8px 0 16px;display:block}
.person p{font-size:15.5px}
.person a{font-family:var(--fm);font-size:14px;color:var(--accent);display:inline-block;margin-top:14px}

/* form */
.cform{display:flex;flex-direction:column;gap:26px}
.cform .frow{display:grid;grid-template-columns:1fr 1fr;gap:26px}
@media(max-width:640px){.cform .frow{grid-template-columns:1fr}}
.cform label{font-family:var(--fm);font-size:13px;font-weight:500;letter-spacing:.24em;text-transform:uppercase;color:var(--fg3);display:block;margin-bottom:9px}
.field{width:100%;background:transparent;border:none;border-bottom:1px solid var(--line);color:var(--fg);font-family:var(--fb);font-size:16px;padding:9px 2px;transition:border-color 220ms var(--ez)}
.field::placeholder{color:var(--fg3)}
.field:focus{outline:none;border-bottom-color:var(--accent)}
textarea.field{resize:vertical;min-height:110px}
.cform .form-status{font-family:var(--fm);font-size:14px;letter-spacing:.04em;margin:-6px 0 0}
.cform button[disabled]{opacity:.6;cursor:default}

/* footer */
footer.site{padding:72px 0 0;overflow:hidden}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px;padding-bottom:56px}
@media(max-width:860px){.foot-grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.foot-grid{grid-template-columns:1fr}}
footer .logo img{height:31px}
footer p{font-size:14.5px;color:var(--fg3);margin-top:16px;max-width:34ch}
footer h5{font-family:var(--fm);font-size:13px;font-weight:500;letter-spacing:.28em;text-transform:uppercase;color:var(--fg3);height:31px;display:flex;align-items:center;margin-bottom:16px}
footer ul{list-style:none;display:flex;flex-direction:column;gap:11px}
footer ul a{font-family:var(--fm);font-size:13.5px;letter-spacing:.08em;color:var(--fg2);transition:color 150ms var(--ezq)}
footer ul a:hover{color:var(--accent)}
.foot-rail{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;padding:20px 0;border-top:1px solid var(--line);font-family:var(--fm);font-size:13px;letter-spacing:.2em;text-transform:uppercase;color:var(--fg3)}
.foot-rail .brand-rail{display:flex;align-items:center;gap:10px}
.foot-rail img{height:17px}
.foot-legal{display:flex;align-items:center;gap:22px;flex-wrap:wrap}
.foot-legal a{transition:color 150ms var(--ezq)}
.foot-legal a:hover{color:var(--accent)}
.foot-ghost{font-family:var(--fd);font-weight:700;text-transform:uppercase;font-size:clamp(56px,12vw,170px);line-height:.82;letter-spacing:.02em;color:transparent;-webkit-text-stroke:1px var(--line);text-align:center;user-select:none;pointer-events:none;transform:translateY(20%)}

/* legal */
.legal h2{font-family:var(--fd);font-size:16px;font-weight:600;text-transform:uppercase;margin:38px 0 12px;color:var(--hd)}
.legal p,.legal li{color:var(--fg2);font-size:15.5px}
.legal ul{padding-left:20px;margin:8px 0}
.legal a{color:var(--accent)}

.page-hero{padding:clamp(80px,10vw,108px) 0 48px;border-bottom:1px solid var(--line)}
.page-hero h1{font-family:var(--fd);font-weight:600;text-transform:uppercase;font-size:clamp(28px,3.6vw,48px);line-height:1.12;margin-top:18px;color:var(--hd)}
section.tight{padding:56px 0}

/* ============================================================================
   FUTURE / HUD MOTION LAYER  (driven by motion.js)
   ============================================================================ */

/* scroll reveal — decode / blur-in */
.rv{opacity:0;transform:translateY(22px);filter:blur(7px);transition:opacity 660ms var(--ez),transform 660ms var(--ez),filter 660ms var(--ez)}
.rv.on{opacity:1;transform:none;filter:blur(0)}

/* clip-reveal for standalone display headings (cinematic wipe-up) */
.rvc{opacity:0;clip-path:inset(0 0 102% 0);filter:blur(8px);transition:opacity 620ms var(--ez),clip-path 880ms var(--ez),filter 620ms var(--ez)}
.rvc.on{opacity:1;clip-path:inset(0 0 -14% 0);filter:blur(0)}

/* primary CTA: light sheen sweep on hover */
.b-acc::after{content:"";position:absolute;top:0;left:0;height:100%;width:55%;pointer-events:none;
  background:linear-gradient(100deg,transparent,rgba(255,255,255,.5),transparent);
  transform:translateX(-200%) skewX(-14deg);transition:transform 760ms var(--ez)}
.b-acc:hover::after{transform:translateX(320%) skewX(-14deg)}

/* schematic: data packet flows through the pipeline */
.schem .pkt{position:absolute;top:50%;left:0;width:7px;height:7px;border-radius:50%;z-index:3;
  background:var(--accent);box-shadow:0 0 16px 3px var(--accent);transform:translateY(-50%);opacity:0;
  animation:pkt 3.6s var(--ezq) infinite}
@keyframes pkt{0%{left:5%;opacity:0}9%{opacity:1}88%{opacity:1}100%{left:95%;opacity:0}}
@media(max-width:760px){.schem .pkt{display:none}}

/* cursor spotlight on panels that don't flood on hover */
.person,.cmp .col{position:relative;overflow:hidden;isolation:isolate}
.person::after,.cmp .col::after{content:"";position:absolute;inset:0;z-index:-1;pointer-events:none;opacity:0;
  background:radial-gradient(220px circle at var(--mx,50%) var(--my,50%), color-mix(in srgb,var(--accent) 16%, transparent), transparent 68%);
  transition:opacity 240ms var(--ez)}
.person:hover::after,.cmp .col:hover::after{opacity:1}

/* kinetic "trained to see ___" word-cycler */
.kine{border-bottom:1px solid var(--line);padding:clamp(48px,7vw,88px) 0;position:relative;overflow:hidden}
.kine-row{display:flex;flex-wrap:wrap;align-items:baseline;gap:.1em .45em}
.kine-pre{font-size:clamp(30px,5.4vw,74px);color:var(--hd)}
.kine-word{font-size:clamp(30px,5.4vw,74px);color:var(--accent);position:relative;display:inline-block;
  text-shadow:0 0 30px var(--accent-glow);font-variant-numeric:tabular-nums}
.kine-word::after{content:"";display:inline-block;width:.46ch;height:.86em;margin-left:.1em;
  background:var(--accent);vertical-align:-.06em;box-shadow:0 0 12px var(--accent);
  animation:blink 1.1s steps(1,end) infinite}

/* sector rows: a scan flicker line that sweeps on hover */
a.xrow::before{content:"";position:absolute;left:0;top:0;bottom:0;width:2px;background:var(--accent);
  transform:scaleY(0);transform-origin:50% 0;transition:transform 260ms var(--ez)}
a.xrow:hover::before{transform:scaleY(1);background:var(--accent-ink)}

/* FAQ accordion (native details/summary) */
.faq{border-top:1px solid var(--line)}
.faq details{border-bottom:1px solid var(--line)}
.faq summary{cursor:pointer;list-style:none;display:flex;justify-content:space-between;gap:24px;align-items:center;
  padding:26px 4px;font-family:var(--fd);font-size:clamp(16px,2vw,22px);font-weight:600;text-transform:uppercase;
  letter-spacing:.01em;color:var(--hd);transition:color 160ms var(--ezq)}
.faq summary:hover{color:var(--accent)}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-family:var(--fm);color:var(--accent);font-size:22px;line-height:1;transition:transform 300ms var(--ez)}
.faq details[open] summary::after{content:"-";transform:scale(1.1)}
.faq .ans{padding:0 4px 28px;color:var(--fg2);font-size:16px;max-width:72ch;line-height:1.65}

/* skip link (injected by nav.js) */
.skip{position:fixed;top:10px;left:10px;z-index:500;transform:translateY(-220%);
  background:var(--accent);color:var(--accent-ink);font-family:var(--fm);font-size:13px;font-weight:600;
  letter-spacing:.18em;text-transform:uppercase;padding:11px 18px;border-radius:2px;transition:transform 180ms var(--ez)}
.skip:focus{transform:none}
main:focus{outline:none}

/* inner-page hero HUD (injected by motion.js) — frames every page as a live feed */
.phero-hud{position:absolute;inset:0;z-index:2;pointer-events:none;overflow:hidden}
.phero-hud .corner{position:absolute;width:26px;height:26px;border:1.5px solid color-mix(in srgb,var(--accent) 50%, transparent);opacity:.7}
.phero-hud .corner.tl{top:26px;left:30px;border-right:0;border-bottom:0}
.phero-hud .corner.tr{top:26px;right:30px;border-left:0;border-bottom:0}
.phero-hud .corner.bl{bottom:24px;left:30px;border-right:0;border-top:0}
.phero-hud .corner.br{bottom:24px;right:30px;border-left:0;border-top:0}
.phero-hud .pstatus{position:absolute;top:30px;right:48px;display:flex;align-items:center;gap:9px;
  font-family:var(--fm);font-size:13px;letter-spacing:.22em;text-transform:uppercase;color:var(--fgm)}
.phero-hud .live-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);box-shadow:0 0 10px var(--accent);animation:blink 1.6s steps(1,end) infinite}
.phero-hud .pscan{position:absolute;left:0;right:0;height:120px;top:-140px;
  background:linear-gradient(to bottom, transparent, color-mix(in srgb,var(--accent) 11%, transparent) 88%, var(--accent));
  mix-blend-mode:screen;opacity:.32;animation:pscan 7s var(--ezq) infinite}
@keyframes pscan{0%{top:-140px;opacity:0}10%{opacity:.32}90%{opacity:.32}100%{top:100%;opacity:0}}
@media(max-width:640px){.phero-hud .pstatus{display:none}.phero-hud .corner{width:18px;height:18px;top:18px;bottom:18px;left:18px;right:18px}}

/* ============================================================================
   REDUCED MOTION
   ============================================================================ */
@media(prefers-reduced-motion:reduce){
  *{transition-duration:.001ms!important;animation-duration:.001ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important}
  .rv,.rvc{opacity:1!important;transform:none!important;filter:none!important;clip-path:none!important}
  .hud .scan,.hud .live-dot,.tick-label::before,.schem .pkt,.feed-fx,.kine-word::after,.phero-hud .pscan,.phero-hud .live-dot{animation:none}
  .feed-fx,.phero-hud .pscan{display:none}
  .tick-track,.spec-track{animation:none}
  .nav-prog{animation:none}
  .b-acc::after{display:none}
}
