/* ==========================================================================
   MEDIACHROME — shared stylesheet
   Pages: index.html · medialive.html · knox-streaming.html · knox-storage.html
   Accent is set per page via body[data-accent] → var(--ac)
   ========================================================================== */

/* ---------- tokens ---------- */
:root{
  --bg:#050608;
  --panel:#0B0D11;
  --panel-2:#10141B;
  --line:rgba(255,255,255,.09);
  --line-soft:rgba(255,255,255,.05);
  --white:#F4F6F8;
  --grey:#9AA1AB;
  --grey-2:#646B76;
  --blue:#1E9BF0;
  --red:#FF3B30;
  --storage:#8AB8FF;
  --green:#2ECC71;
  --ac:var(--blue);            /* page accent (overridden below) */
  --ac-ink:#001523;
  --ac-dim:rgba(30,155,240,.13);
  --display:'Archivo',system-ui,sans-serif;
  --body:'Inter',system-ui,sans-serif;
  --mono:'JetBrains Mono',ui-monospace,monospace;
  --pad:clamp(20px,5vw,72px);
  --maxw:1280px;
}
body[data-accent="red"]{--ac:var(--red);--ac-ink:#1d0503;--ac-dim:rgba(255,59,48,.12)}
body[data-accent="storage"]{--ac:var(--storage);--ac-ink:#0a1220;--ac-dim:rgba(138,184,255,.13)}

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

/* ---------- type utilities ---------- */
.mono{font-family:var(--mono)}
.eyebrow{font-family:var(--mono);font-size:11px;font-weight:500;letter-spacing:.22em;
  text-transform:uppercase;color:var(--grey)}
.eyebrow b{color:var(--ac);font-weight:700}
.eyebrow a:hover{color:var(--white)}

.sec-head{display:flex;align-items:center;gap:24px;margin-bottom:clamp(36px,6vw,64px)}
.sec-head h2{font-family:var(--mono);font-size:12px;font-weight:700;letter-spacing:.26em;
  text-transform:uppercase;color:var(--white);white-space:nowrap}
.sec-head h2 span{color:var(--ac)}
.sec-head::after{content:"";flex:1;height:1px;background:var(--line)}

.sec-lede{font-family:var(--display);font-weight:200;font-variation-settings:'wdth' 106;
  font-size:clamp(28px,4.2vw,52px);line-height:1.12;letter-spacing:-.01em;max-width:18em;
  margin-bottom:clamp(28px,4vw,48px)}
.sec-lede em{font-style:normal;color:var(--grey)}
.sec-lede strong{font-weight:200;color:var(--ac)}

/* ---------- layout ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding-left:var(--pad);padding-right:var(--pad)}
section{position:relative;padding:clamp(72px,11vw,140px) 0}
.hairline-top{border-top:1px solid var(--line-soft)}
.tight{padding-top:clamp(48px,7vw,84px)}

.ghost-m{position:absolute;pointer-events:none;user-select:none;font-family:var(--display);
  font-weight:900;font-variation-settings:'wdth' 75;color:rgba(255,255,255,.028);
  line-height:.72;z-index:0}

/* ---------- nav ---------- */
header{position:fixed;top:0;left:0;right:0;z-index:100;background:rgba(5,6,8,.72);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line-soft)}
.nav{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad);height:68px;
  display:flex;align-items:center;justify-content:space-between;gap:24px}
.wordmark{font-family:var(--display);font-weight:200;font-variation-settings:'wdth' 104;
  font-size:24px;letter-spacing:.01em;display:flex;align-items:baseline}
.wordmark span{color:var(--grey-2)}
.wordmark small{font-family:var(--mono);font-size:9px;letter-spacing:.2em;color:var(--ac);
  margin-left:12px;text-transform:uppercase;transform:translateY(-2px)}
.nav-links{display:flex;gap:32px;align-items:center;list-style:none}
.nav-links a{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--grey);transition:color .2s}
.nav-links a:hover,.nav-links a[aria-current]{color:var(--white)}
.nav-cta{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--white);border:1px solid var(--line);padding:10px 18px;border-radius:2px;
  transition:border-color .2s,color .2s;white-space:nowrap}
.nav-cta:hover{border-color:var(--ac);color:var(--ac)}
.burger{display:none;background:none;border:1px solid var(--line);border-radius:2px;
  width:42px;height:42px;cursor:pointer;position:relative}
.burger span{position:absolute;left:11px;right:11px;height:1.5px;background:var(--white);
  transition:transform .25s,opacity .2s}
.burger span:nth-child(1){top:15px}
.burger span:nth-child(2){top:20.5px}
.burger span:nth-child(3){top:26px}
.nav-open .burger span:nth-child(1){transform:translateY(5.5px) rotate(45deg)}
.nav-open .burger span:nth-child(2){opacity:0}
.nav-open .burger span:nth-child(3){transform:translateY(-5.5px) rotate(-45deg)}

/* ---------- buttons / tallies ---------- */
.btn{font-family:var(--mono);font-size:12px;font-weight:500;letter-spacing:.14em;
  text-transform:uppercase;padding:15px 26px;border-radius:2px;display:inline-flex;
  align-items:center;gap:10px;transition:transform .2s,filter .2s,border-color .2s,color .2s}
.btn-primary{background:var(--ac);color:var(--ac-ink)}
.btn-primary:hover{transform:translateY(-2px);filter:brightness(1.12)}
.btn-ghost{border:1px solid var(--line);color:var(--white)}
.btn-ghost:hover{border-color:var(--ac);color:var(--ac);transform:translateY(-2px)}
.cta-row{display:flex;gap:14px;flex-wrap:wrap}

.onair{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.tally{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:11px;
  font-weight:700;letter-spacing:.24em;color:var(--red)}
.tally i{width:8px;height:8px;border-radius:50%;background:var(--red);animation:pulse 1.6s infinite}
@keyframes pulse{0%,100%{opacity:1;box-shadow:0 0 0 0 rgba(255,59,48,.5)}
  50%{opacity:.55;box-shadow:0 0 0 6px rgba(255,59,48,0)}}
.tally--standby{color:var(--green)}
.tally--standby i{background:var(--green);animation-name:pulseG}
@keyframes pulseG{0%,100%{opacity:1;box-shadow:0 0 0 0 rgba(46,204,113,.5)}
  50%{opacity:.55;box-shadow:0 0 0 6px rgba(46,204,113,0)}}
.tally--ac{color:var(--ac)}
.tally--ac i{background:var(--ac);animation:none}

/* ---------- hero (index) ---------- */
.hero{min-height:100svh;display:flex;align-items:center;padding-top:120px;padding-bottom:80px;overflow:hidden}
.hero .ghost-m{top:-4vw;right:-6vw;font-size:clamp(360px,52vw,860px)}
.hero-grid{position:relative;z-index:1;display:grid;
  grid-template-columns:minmax(0,1.05fr) minmax(0,1fr);
  gap:clamp(40px,6vw,88px);align-items:center;width:100%}
.hero h1{font-family:var(--display);font-weight:150;font-variation-settings:'wdth' 108;
  font-size:clamp(54px,7.6vw,118px);line-height:1.02;letter-spacing:-.015em;margin:26px 0 28px}
.hero h1 span{color:var(--grey-2)}
.hero-sub{color:var(--grey);font-size:clamp(16px,1.35vw,18px);max-width:34em;margin-bottom:40px}
.hero-sub b{color:var(--white);font-weight:500}

/* ---------- monitor (signature) ---------- */
.monitor-zone{position:relative;padding:34px 0 54px}
.monitor{position:relative;aspect-ratio:16/9;border-radius:6px;
  border:1px solid rgba(255,255,255,.14);background:#06080C;
  box-shadow:0 30px 80px rgba(0,0,0,.55),0 0 0 1px rgba(0,0,0,.6),0 0 64px var(--ac-dim);
  overflow:hidden}
.monitor video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.92}
.monitor::before{content:"";position:absolute;inset:0;z-index:2;pointer-events:none;
  background:
    linear-gradient(to top,rgba(4,6,9,.82) 0%,transparent 34%),
    linear-gradient(to bottom,rgba(4,6,9,.55) 0%,transparent 22%),
    repeating-linear-gradient(to bottom,rgba(255,255,255,.015) 0 1px,transparent 1px 4px)}
.mon-top{position:absolute;z-index:3;top:14px;left:16px;right:16px;display:flex;
  justify-content:space-between;align-items:center}
.timecode{font-family:var(--mono);font-size:clamp(11px,1.1vw,13px);letter-spacing:.14em;
  color:#C8CDD4;display:flex;gap:10px;align-items:center;text-shadow:0 1px 6px rgba(0,0,0,.8)}
.timecode b{color:var(--white);font-weight:500}
.mon-meters{position:absolute;z-index:3;right:16px;bottom:58px;display:flex;gap:4px;
  align-items:flex-end;height:64px}
.mon-meters i{width:4px;background:linear-gradient(to top,var(--ac),#9FDBFF);border-radius:1px;
  animation:vu 1.1s ease-in-out infinite alternate;transform-origin:bottom}
.mon-meters i:nth-child(1){height:58%;animation-duration:.9s}
.mon-meters i:nth-child(2){height:84%;animation-duration:1.25s;animation-delay:.1s}
.mon-meters i:nth-child(3){height:42%;animation-duration:.8s;animation-delay:.22s}
.mon-meters i:nth-child(4){height:70%;animation-duration:1.05s;animation-delay:.05s}
.mon-meters i:nth-child(5){height:52%;animation-duration:1.35s;animation-delay:.3s}
@keyframes vu{from{transform:scaleY(.35)}to{transform:scaleY(1)}}
.lower-third{position:absolute;z-index:3;left:16px;right:88px;bottom:16px;
  border-left:3px solid var(--ac);
  background:linear-gradient(90deg,rgba(7,12,18,.92),rgba(7,12,18,.35));
  padding:10px 16px;border-radius:2px;backdrop-filter:blur(4px)}
.lt-tag{font-family:var(--mono);font-size:9px;letter-spacing:.26em;color:var(--ac);
  text-transform:uppercase;margin-bottom:3px}
.lt-text{font-family:var(--display);font-weight:300;font-size:clamp(14px,1.5vw,19px);
  letter-spacing:.01em;min-height:1.4em;transition:opacity .45s}
.lt-text.fade{opacity:0}

/* deck-style callouts with leader lines */
.callout{position:absolute;z-index:4;font-family:var(--mono);font-size:9.5px;font-weight:500;
  letter-spacing:.18em;text-transform:uppercase;background:#272B33;color:#E8EBEF;
  padding:7px 11px;border-radius:2px;white-space:nowrap;box-shadow:0 8px 24px rgba(0,0,0,.45)}
.callout::after{content:"";position:absolute;width:7px;height:7px;border-radius:50%;
  background:var(--ac);box-shadow:0 0 0 3px var(--ac-dim)}
.callout::before{content:"";position:absolute;background:var(--ac);opacity:.85}
.co-1{top:-16px;left:6%}
.co-1::after{left:24px;bottom:-37px}
.co-1::before{left:27px;bottom:-30px;width:1.5px;height:30px}
.co-2{right:-14px;top:34%}
.co-2::after{left:-37px;top:50%;margin-top:-3.5px}
.co-2::before{left:-30px;top:50%;height:1.5px;width:30px}
.co-3{bottom:-16px;left:14%}
.co-3::after{left:30px;top:-37px}
.co-3::before{left:33px;top:-30px;width:1.5px;height:30px}
.callout-row{display:none}

/* ---------- ticker ---------- */
.ticker{border-top:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft);
  background:#07090D;overflow:hidden;padding:14px 0;position:relative}
.ticker-inner{display:flex;width:max-content;animation:tick 46s linear infinite}
.ticker span{font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--grey);padding:0 28px;white-space:nowrap}
.ticker span b{color:var(--ac);font-weight:700;padding-right:28px}
@keyframes tick{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ---------- media frame ---------- */
.media{position:relative;border-radius:4px;overflow:hidden;border:1px solid var(--line);
  background:#07090D;aspect-ratio:16/9}
.media>img,.media>video{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.media::after{content:"";position:absolute;inset:0;
  background:linear-gradient(to top,rgba(4,6,9,.45),transparent 45%);pointer-events:none}
.media .tag{position:absolute;z-index:2;left:12px;bottom:10px;font-family:var(--mono);
  font-size:9px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:#DDE2E8;
  background:rgba(10,13,18,.72);border:1px solid rgba(255,255,255,.12);
  padding:5px 9px;border-radius:2px;backdrop-filter:blur(4px)}
.media .tag b{color:var(--ac)}

/* ---------- signal chain + solution cards ---------- */
.chain{display:flex;align-items:center;margin-bottom:clamp(36px,5vw,56px);
  overflow-x:auto;padding-bottom:6px;scrollbar-width:none}
.chain::-webkit-scrollbar{display:none}
.chain-node{display:flex;align-items:center;flex:1;min-width:max-content}
.chain-node a{font-family:var(--mono);font-size:10.5px;font-weight:700;letter-spacing:.22em;
  color:var(--grey);display:flex;align-items:center;gap:9px;padding:6px 2px;transition:color .2s}
.chain-node a:hover,.chain-node a.active{color:var(--ac)}
.chain-node a i{width:7px;height:7px;border-radius:50%;border:1.5px solid currentColor;flex:none}
.chain-node::after{content:"";flex:1;height:1px;background:var(--line);margin:0 14px;min-width:18px}
.chain-node:last-child::after{display:none}

.sol-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.sol-card{position:relative;border:1px solid var(--line);border-radius:4px;
  background:linear-gradient(170deg,var(--panel-2),var(--panel));
  display:flex;flex-direction:column;overflow:hidden;
  transition:border-color .25s,transform .25s,box-shadow .25s;scroll-margin-top:110px}
.sol-card:hover{border-color:rgba(30,155,240,.45);transform:translateY(-3px);
  box-shadow:0 20px 50px rgba(0,0,0,.45),0 0 40px var(--ac-dim)}
.sol-card:hover .media>img{transform:scale(1.04)}
.sol-card .media{border:none;border-bottom:1px solid var(--line);border-radius:0;aspect-ratio:16/8.4}
.sol-body{padding:24px 26px 26px;display:flex;flex-direction:column;gap:13px;flex:1}
.sol-verb{font-family:var(--mono);font-size:10px;font-weight:700;letter-spacing:.26em;
  color:var(--ac);display:flex;align-items:center;gap:9px}
.sol-verb i{width:7px;height:7px;border-radius:50%;background:var(--ac);flex:none;
  box-shadow:0 0 0 3px var(--ac-dim)}
.sol-card h3{font-family:var(--display);font-weight:250;font-variation-settings:'wdth' 104;
  font-size:clamp(21px,1.9vw,25px);line-height:1.15}
.sol-card p{color:var(--grey);font-size:14px;flex:1}
.chips{display:flex;flex-wrap:wrap;gap:7px;list-style:none}
.chips li{font-family:var(--mono);font-size:9.5px;letter-spacing:.1em;text-transform:uppercase;
  color:#C9CED6;background:#1A1F27;border:1px solid rgba(255,255,255,.06);
  padding:5px 9px;border-radius:2px}

/* CSS signage totems (used where no photo exists) */
.totems{position:relative;width:100%;height:100%;
  background:radial-gradient(90% 90% at 70% 10%,var(--ac-dim),transparent 60%),#0A0E14;
  display:flex;align-items:flex-end;justify-content:center;gap:7%;padding:9% 10% 0}
.totem{width:21%;height:96%;border:1px solid rgba(255,255,255,.18);border-bottom:none;
  border-radius:5px 5px 0 0;background:linear-gradient(165deg,#13335a,#0a1626 70%);
  position:relative;overflow:hidden;box-shadow:0 14px 34px rgba(0,0,0,.5)}
.totem::before{content:"";position:absolute;inset:6% 8% auto;height:46%;border-radius:3px;
  background:linear-gradient(150deg,var(--ac) 0%,#7FD0FF 60%,#16365c 100%);opacity:.85}
.totem::after{content:"";position:absolute;left:8%;right:8%;bottom:10%;height:5px;border-radius:2px;
  background:rgba(255,255,255,.35);box-shadow:0 -11px 0 rgba(255,255,255,.22),0 -22px 0 rgba(255,255,255,.12)}
.totem:nth-child(2){height:88%;background:linear-gradient(165deg,#3c1430,#160a16 70%)}
.totem:nth-child(2)::before{background:linear-gradient(150deg,#ff7ab0,#b03070 70%,#3a0f28)}
.totem:nth-child(3){height:92%;background:linear-gradient(165deg,#0f3d33,#08160f 70%)}
.totem:nth-child(3)::before{background:linear-gradient(150deg,#39d98a,#1b8a57 70%,#0a2e1d)}

/* ---------- AI band ---------- */
.ai-band{background:#07090D}
.ai-band .ghost-m{bottom:-12vw;left:-8vw;font-size:clamp(300px,40vw,640px)}
.ai-flex{position:relative;z-index:1;display:grid;
  grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr);gap:clamp(36px,6vw,80px);align-items:start}
.ai-chips{display:flex;flex-wrap:wrap;gap:9px;list-style:none}
.ai-chips li{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--white);border:1px solid var(--line);padding:11px 15px;border-radius:2px;
  display:flex;align-items:center;gap:10px;background:rgba(255,255,255,.015);
  transition:border-color .2s,background .2s}
.ai-chips li:hover{border-color:var(--ac);background:var(--ac-dim)}
.ai-chips li::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--ac);flex:none}
.ai-note{color:var(--grey);font-size:15px;max-width:30em;margin-top:22px}
.ai-note b{color:var(--white);font-weight:500}

/* ---------- platform cards ---------- */
.plat-grid{display:grid;grid-template-columns:1.25fr 1fr 1fr;gap:16px}
.plat-card{position:relative;border:1px solid var(--line);border-radius:4px;background:var(--panel);
  padding:32px 30px;display:flex;flex-direction:column;gap:16px;overflow:hidden;
  transition:transform .25s,border-color .25s}
.plat-card::before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--pc,var(--ac))}
.plat-card:hover{transform:translateY(-3px);border-color:rgba(255,255,255,.2)}
.plat-name{font-family:var(--display);font-weight:600;font-size:clamp(22px,2vw,26px);letter-spacing:-.01em}
.plat-name span{color:var(--pc,var(--ac))}
.plat-kicker{font-family:var(--mono);font-size:10px;letter-spacing:.24em;text-transform:uppercase;color:var(--grey-2)}
.plat-card p{color:var(--grey);font-size:14.5px;flex:1}
.modules{display:flex;flex-wrap:wrap;gap:7px;list-style:none}
.modules li{font-family:var(--mono);font-size:9.5px;letter-spacing:.1em;color:#C9CED6;
  border:1px solid rgba(255,255,255,.1);padding:5px 9px;border-radius:999px}
.plat-link{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--pc,var(--ac));display:inline-flex;gap:9px;align-items:center}
.plat-link svg{transition:transform .2s}
.plat-card:hover .plat-link svg{transform:translateX(4px)}
.plat-sub{font-family:var(--mono);font-size:10px;letter-spacing:.12em;color:var(--grey-2)}
.plat-sub a:hover{color:var(--white)}

/* ---------- cases ---------- */
.cases{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.case{border:1px solid var(--line);border-radius:4px;background:var(--panel);overflow:hidden;
  display:flex;flex-direction:column;transition:border-color .25s,background .25s,transform .25s;position:relative}
.case:hover{border-color:rgba(30,155,240,.4);background:var(--panel-2);transform:translateY(-3px)}
.case:hover .media>img{transform:scale(1.04)}
.case .media{border:none;border-bottom:1px solid var(--line);border-radius:0;aspect-ratio:16/7.6}
.case-body{padding:24px 28px 26px;display:grid;gap:10px;position:relative}
.case-body::after{content:attr(data-n);position:absolute;right:18px;top:16px;
  font-family:var(--display);font-weight:100;font-size:50px;color:rgba(255,255,255,.05);line-height:1}
.case-sector{font-family:var(--mono);font-size:9.5px;font-weight:700;letter-spacing:.26em;
  text-transform:uppercase;color:var(--ac)}
.case h3{font-family:var(--display);font-weight:250;font-size:clamp(21px,2vw,26px)}
.case p{color:var(--grey);font-size:14.5px}
.case .chips{margin-top:6px}
.case-note{margin-top:28px;color:var(--grey-2);font-size:13px;font-family:var(--mono);letter-spacing:.04em}

/* ---------- skyline band ---------- */
.skyline{position:relative;min-height:46vh;display:flex;align-items:center;overflow:hidden;
  border-top:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft)}
.skyline img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.5}
.skyline::after{content:"";position:absolute;inset:0;
  background:linear-gradient(90deg,rgba(5,6,8,.92) 0%,rgba(5,6,8,.55) 55%,rgba(5,6,8,.25) 100%)}
.skyline .wrap{position:relative;z-index:2;padding-top:64px;padding-bottom:64px}
.skyline h2{font-family:var(--display);font-weight:150;font-variation-settings:'wdth' 108;
  font-size:clamp(34px,5vw,68px);line-height:1.05;letter-spacing:-.012em;max-width:14em;margin-top:18px}
.skyline h2 span{color:var(--grey)}

/* ---------- industries ---------- */
.ind-grid{display:grid;grid-template-columns:repeat(4,1fr);border:1px solid var(--line);
  border-radius:4px;overflow:hidden}
.ind{padding:30px 26px;border-left:1px solid var(--line);background:var(--panel)}
.ind:first-child{border-left:none}
.ind h3{font-family:var(--display);font-weight:300;font-size:19px;margin:12px 0 8px}
.ind p{color:var(--grey);font-size:13.5px}
.ind .eyebrow{font-size:9.5px}

/* ---------- contact ---------- */
.contact{overflow:hidden}
.contact .ghost-m{bottom:-16vw;right:-7vw;font-size:clamp(340px,46vw,760px)}
.contact-grid{position:relative;z-index:1;display:grid;grid-template-columns:1.2fr .8fr;
  gap:clamp(40px,6vw,90px);align-items:end}
.contact h2.big{font-family:var(--display);font-weight:150;font-variation-settings:'wdth' 108;
  font-size:clamp(44px,6.4vw,96px);line-height:1.02;letter-spacing:-.015em;margin:18px 0 26px}
.contact h2.big span{color:var(--grey-2)}
.contact-info{display:flex;flex-direction:column;gap:18px}
.ci{border-top:1px solid var(--line);padding-top:14px}
.ci .eyebrow{font-size:9.5px;margin-bottom:6px;display:block}
.ci a,.ci div{font-size:15px;color:var(--white)}
.ci a:hover{color:var(--ac)}

/* ---------- footer ---------- */
footer{border-top:1px solid var(--line-soft);padding:40px 0;background:#040507}
.foot{display:flex;justify-content:space-between;gap:24px;align-items:center;flex-wrap:wrap}
.foot-links{display:flex;gap:26px;flex-wrap:wrap;list-style:none}
.foot-links a{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--grey-2);transition:color .2s}
.foot-links a:hover{color:var(--ac)}
.copy{font-family:var(--mono);font-size:10px;letter-spacing:.1em;color:var(--grey-2)}

/* ==========================================================================
   PRODUCT LANDING COMPONENTS
   ========================================================================== */

/* video / image page hero */
.vhero{position:relative;min-height:88svh;display:flex;align-items:flex-end;overflow:hidden;
  padding-top:120px}
.vhero .bg{position:absolute;inset:0;z-index:0}
.vhero .bg video,.vhero .bg img{width:100%;height:100%;object-fit:cover;opacity:.55}
.vhero::before{content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(to top,var(--bg) 4%,rgba(5,6,8,.55) 45%,rgba(5,6,8,.35) 100%)}
.vhero .wrap{position:relative;z-index:2;padding-bottom:clamp(56px,8vw,96px);width:100%}
.vhero h1{font-family:var(--display);font-weight:150;font-variation-settings:'wdth' 108;
  font-size:clamp(46px,7vw,108px);line-height:1.0;letter-spacing:-.015em;margin:22px 0 22px}
.vhero h1 .thin{color:var(--grey-2)}
.vhero h1 .ac{color:var(--ac);font-weight:500}
.vhero .hero-sub{margin-bottom:34px}
.crumbs{display:flex;gap:10px;align-items:center;font-family:var(--mono);font-size:10.5px;
  letter-spacing:.2em;text-transform:uppercase;color:var(--grey)}
.crumbs a:hover{color:var(--white)}
.crumbs i{color:var(--grey-2);font-style:normal}
.crumbs b{color:var(--ac)}

/* alternating feature rows */
.feature{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(34px,5vw,72px);
  align-items:center;padding:clamp(40px,6vw,72px) 0;border-top:1px solid var(--line-soft)}
.feature:first-of-type{border-top:none;padding-top:0}
.feature.flip .f-media{order:2}
.feature h3{font-family:var(--display);font-weight:200;font-variation-settings:'wdth' 106;
  font-size:clamp(26px,3.2vw,40px);line-height:1.12;margin:14px 0 16px}
.feature h3 span{color:var(--ac)}
.feature p{color:var(--grey);font-size:15.5px;max-width:32em}
.feature .chips{margin-top:20px}
.f-media{display:grid;gap:12px}
.f-media .duo{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.f-media .duo .media{aspect-ratio:16/10}
.f-kicker{font-family:var(--mono);font-size:10px;font-weight:700;letter-spacing:.26em;
  text-transform:uppercase;color:var(--ac);display:flex;align-items:center;gap:9px}
.f-kicker i{width:7px;height:7px;border-radius:50%;background:var(--ac);flex:none;
  box-shadow:0 0 0 3px var(--ac-dim)}

/* pillar cards (medialive) */
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.pillar{border:1px solid var(--line);border-radius:4px;background:var(--panel);overflow:hidden;
  display:flex;flex-direction:column;transition:transform .25s,border-color .25s}
.pillar:hover{transform:translateY(-3px);border-color:rgba(255,255,255,.22)}
.pillar:hover .media>img{transform:scale(1.04)}
.pillar .media{border:none;border-bottom:1px solid var(--line);border-radius:0}
.pillar-body{padding:24px 26px 26px;display:flex;flex-direction:column;gap:12px;flex:1}
.pillar-logo{height:20px;width:auto;align-self:flex-start;filter:brightness(0) invert(1);opacity:.92}
.pillar p{color:var(--grey);font-size:14px;flex:1}
.pillar .plat-link{font-size:10.5px}

/* stats (counters) */
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:clamp(30px,5vw,52px)}
.stat{border:1px solid var(--line);border-radius:4px;background:var(--panel);padding:26px 26px 22px;
  position:relative;overflow:hidden}
.stat::before{content:"";position:absolute;top:0;left:0;width:34px;height:2px;background:var(--ac)}
.stat b{font-family:var(--display);font-weight:150;font-variation-settings:'wdth' 110;
  font-size:clamp(40px,4.6vw,64px);line-height:1;display:block;letter-spacing:-.01em}
.stat b sup{font-size:.45em;color:var(--ac);font-weight:300}
.stat span{font-family:var(--mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--grey);display:block;margin-top:10px}

/* steps (how it works) */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;counter-reset:step}
.step{border:1px solid var(--line);border-radius:4px;background:var(--panel);padding:26px;position:relative}
.step::before{counter-increment:step;content:"0" counter(step);
  font-family:var(--display);font-weight:100;font-size:46px;color:rgba(255,255,255,.08);
  position:absolute;top:12px;right:16px;line-height:1}
.step h3{font-family:var(--display);font-weight:300;font-size:19px;margin-bottom:8px}
.step p{color:var(--grey);font-size:13.5px}
.step .f-kicker{margin-bottom:14px}

/* plan tiers (knox storage) */
.tiers{display:flex;gap:12px;flex-wrap:wrap}
.tier{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  border:1px solid var(--line);border-radius:2px;padding:13px 18px;color:var(--white);
  display:flex;align-items:center;gap:10px;background:rgba(255,255,255,.015)}
.tier::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--ac)}
.tier.hot{border-color:var(--ac);background:var(--ac-dim)}

/* CTA band on product pages */
.cta-band{border-top:1px solid var(--line-soft);background:#07090D;overflow:hidden;position:relative}
.cta-band .ghost-m{bottom:-14vw;right:-6vw;font-size:clamp(280px,38vw,600px)}
.cta-flex{position:relative;z-index:1;display:flex;align-items:center;justify-content:space-between;
  gap:32px;flex-wrap:wrap}
.cta-flex h2{font-family:var(--display);font-weight:150;font-variation-settings:'wdth' 108;
  font-size:clamp(32px,4.6vw,60px);line-height:1.05;letter-spacing:-.012em;max-width:14em}
.cta-flex h2 span{color:var(--grey-2)}

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

/* ---------- responsive ---------- */
@media (max-width:1080px){
  .sol-grid{grid-template-columns:repeat(2,1fr)}
  .plat-grid{grid-template-columns:1fr 1fr}
  .plat-card:first-child{grid-column:1/-1}
  .ind-grid{grid-template-columns:repeat(2,1fr)}
  .ind:nth-child(3){border-left:none}
  .ind:nth-child(3),.ind:nth-child(4){border-top:1px solid var(--line)}
  .pillars,.stats,.steps{grid-template-columns:1fr 1fr}
}
@media (max-width:920px){
  .hero{padding-top:110px;min-height:0}
  .hero-grid{grid-template-columns:1fr;gap:48px}
  .ai-flex{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr;align-items:start}
  .feature{grid-template-columns:1fr}
  .feature.flip .f-media{order:0}
  .vhero{min-height:74svh}
}
@media (max-width:760px){
  .nav-links{position:fixed;inset:68px 0 auto 0;flex-direction:column;align-items:flex-start;
    background:rgba(5,6,8,.97);border-bottom:1px solid var(--line);
    padding:26px var(--pad) 30px;gap:22px;
    transform:translateY(-12px);opacity:0;pointer-events:none;transition:opacity .25s,transform .25s}
  .nav-open .nav-links{opacity:1;transform:none;pointer-events:auto}
  .burger{display:block}
  .nav-cta{display:none}
  .wordmark small{display:none}
  .sol-grid,.cases,.pillars,.stats,.steps{grid-template-columns:1fr}
  .callout{display:none}
  .callout-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:18px}
  .callout-row span{font-family:var(--mono);font-size:9.5px;letter-spacing:.16em;
    text-transform:uppercase;background:#272B33;color:#E8EBEF;padding:7px 11px;border-radius:2px;
    display:inline-flex;align-items:center;gap:8px}
  .callout-row span::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--ac)}
  .monitor-zone{padding:6px 0 0}
  .vhero h1{font-size:clamp(34px,10.5vw,46px)}
  .vhero{min-height:0;padding-top:108px}
}
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation:none !important;transition:none !important}
  .reveal{opacity:1;transform:none}
}

/* ---------- tier cards (knox storage) ---------- */
.tiers5{display:grid;grid-template-columns:repeat(5,1fr);gap:12px}
.tier-card{border:1px solid var(--line);border-radius:4px;background:var(--panel);
  padding:20px 18px;display:flex;flex-direction:column;gap:8px}
.tier-card.hot{border-color:var(--ac);box-shadow:0 0 34px var(--ac-dim)}
.tier-card h3{font-family:var(--display);font-weight:300;font-size:18px}
.tier-card .tc-fig{font-family:var(--mono);font-size:10px;letter-spacing:.16em;color:var(--ac);text-transform:uppercase}
.tier-card p{color:var(--grey);font-size:12.5px;flex:1}
@media (max-width:1080px){.tiers5{grid-template-columns:repeat(2,1fr)}}
@media (max-width:760px){.tiers5{grid-template-columns:1fr}}
/* ---------- plain product hero ---------- */
.vhero--plain{min-height:54svh;background:radial-gradient(70% 60% at 72% 14%,var(--ac-dim),transparent 62%)}
.vhero--plain .bg{display:none}
