/* Stark-Gate / Starktronix — styles */

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }

/* =============================================================
   THEME TOKENS
   ============================================================= */
:root, html[data-theme="light"] {
  --c-bg: 255 255 255;
  --c-bg-alt: 246 248 251;
  --c-surface: 255 255 255;
  --c-surface-2: 240 243 248;
  --c-border: 224 229 237;
  --c-text: 13 21 38;
  --c-text2: 71 85 105;
  --c-text3: 113 124 143;
  --c-gold: 198 150 45;
  --c-gold2: 212 168 67;
  --c-accent: 146 96 18;
}
html[data-theme="dark"] {
  --c-bg: 10 15 28;
  --c-bg-alt: 13 19 35;
  --c-surface: 15 23 42;
  --c-surface-2: 20 32 54;
  --c-border: 30 43 68;
  --c-text: 241 245 249;
  --c-text2: 148 163 184;
  --c-text3: 100 116 139;
  --c-gold: 212 168 67;
  --c-gold2: 224 185 78;
  --c-accent: 224 185 78;
}
/* Sections / surfaces that stay dark regardless of theme */
.always-dark,
#view-dashboard, #view-admin, #view-mfa, #view-device-pending,
#view-project, #login-modal, #loading-overlay, #intro-curtain {
  --c-bg: 10 15 28;
  --c-bg-alt: 13 19 35;
  --c-surface: 15 23 42;
  --c-surface-2: 20 32 54;
  --c-border: 30 43 68;
  --c-text: 241 245 249;
  --c-text2: 148 163 184;
  --c-text3: 100 116 139;
  --c-gold: 212 168 67;
  --c-gold2: 224 185 78;
  --c-accent: 224 185 78;
  color: rgb(var(--c-text));
}
#view-admin, #view-mfa, #view-device-pending {
  background-color: rgb(var(--c-bg));
}

::-webkit-scrollbar { width: 8px; height: 8px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: rgb(var(--c-border)); border-radius: 4px; }

.view { display: none; }
.view.active { display: block; }
#view-mfa.active, #view-device-pending.active { display: flex; }
#view-admin.active { display: flex; }
#view-project.active { display: flex; }

/* STARK brand logo — artwork is black; invert to silver-white on dark headers */
.brand-logo { filter: invert(1) brightness(1.9) contrast(1.05); }

/* Access portal cards (post-login tiers) */
.portal-card { box-shadow: 0 1px 3px rgba(0,0,0,.45); transition: transform .2s ease, box-shadow .2s ease; }
.portal-card:not(.portal-locked):hover { transform: translateY(-3px); box-shadow: 0 14px 34px rgba(0,0,0,.55); }
.portal-locked { opacity: .5; filter: grayscale(.5); }
.portal-locked .portal-badge { background: #9ca3af; }

body { transition: background-color 0.3s ease; }

/* =============================================================
   GATED APP (always dark)
   ============================================================= */
#shader-container { position: absolute; inset: 0; z-index: 0; }
#shader-container canvas { display: block; width: 100%; height: 100%; }

.link-card { will-change: transform, box-shadow; }
.link-card:hover {
  transform: translateY(-4px);
  border-color: var(--ind-color) !important;
  box-shadow: 0 12px 40px rgba(0,0,0,0.5), 0 0 20px color-mix(in srgb, var(--ind-color) 15%, transparent);
}
.project-card { transition: all 0.2s ease; cursor: pointer; }
.project-card:hover { transform: translateY(-1px); border-color: #d4a843; }
.mfa-digit:focus { outline: none; }

@keyframes fadeIn { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: translateY(0); } }
.animate-in { animation: fadeIn 0.3s ease forwards; }

.status-success { color: #22c55e; }
.status-error { color: #ef4444; }
.status-info { color: #3b82f6; }

.role-badge {
  display: inline-flex; align-items: center; padding: 2px 8px; border-radius: 9999px;
  font-size: 0.625rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.05em;
}
.role-superadmin { background: #d4a84320; color: #d4a843; }
.role-manager { background: #3b82f620; color: #3b82f6; }
.role-staff { background: #22c55e20; color: #22c55e; }
.role-client { background: #8b5cf620; color: #8b5cf6; }
.role-tester { background: #f59e0b20; color: #f59e0b; }

.activity-row {
  display: flex; align-items: center; gap: 1rem; padding: 0.75rem 1rem;
  background: #0f172a; border: 1px solid #1e2b44; border-radius: 0.75rem;
  font-size: 0.875rem; transition: background 0.15s;
}
.activity-row:hover { background: #142036; }

.admin-input {
  width: 100%; padding: 0.5rem 0.75rem; background: #0f172a; border: 1px solid #1e2b44;
  border-radius: 0.5rem; color: #e2e8f0; font-size: 0.875rem; transition: border-color 0.15s;
}
.admin-input:focus { outline: none; border-color: #d4a843; }
.admin-input::placeholder { color: #64748b; }
select.admin-input {
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 0.75rem center; padding-right: 2rem;
}

/* =============================================================
   PUBLIC WEBSITE
   ============================================================= */
html { scroll-behavior: smooth; scroll-padding-top: 4.5rem; }
#view-home img, #view-platform img, #view-industries img,
#view-insights img, #view-company img, #view-careers img { display: block; }

/* ---- Intro curtain ---------------------------------------- */
#intro-curtain {
  position: fixed; inset: 0; z-index: 300; display: none;
  align-items: center; justify-content: center; background: #0a0f1c; overflow: hidden;
  transition: opacity 1s ease, transform 1s ease;
}
#intro-curtain.intro-done { opacity: 0; transform: scale(1.04); pointer-events: none; }
#intro-curtain .intro-scrim {
  position: absolute; inset: 0; z-index: 1;
  background: radial-gradient(ellipse at center, rgba(10,15,28,0.45) 0%, rgba(10,15,28,0.92) 70%, #0a0f1c 100%);
}
.intro-content { position: relative; z-index: 2; text-align: center; }
.intro-mark {
  width: 72px; height: 72px; margin: 0 auto 1.5rem; border-radius: 16px; background: #d4a843;
  display: flex; align-items: center; justify-content: center; box-shadow: 0 0 60px rgba(212,168,67,0.5);
  animation: introMark 0.9s cubic-bezier(0.2,0.8,0.2,1) both;
}
.intro-mark span { color: #0a0f1c; font-family: Manrope, sans-serif; font-weight: 800; font-size: 2rem; }
.intro-word {
  font-family: Manrope, sans-serif; font-weight: 800; font-size: clamp(1.5rem, 5vw, 2.5rem);
  letter-spacing: 0.5em; color: #f8fafc; padding-left: 0.5em; animation: introWord 1s ease 0.35s both;
}
.intro-sub {
  font-family: 'JetBrains Mono', monospace; font-size: 0.7rem; letter-spacing: 0.34em;
  color: #d4a843; margin-top: 0.85rem; animation: introWord 1s ease 0.7s both;
}
.intro-bar { width: 180px; height: 2px; margin: 1.75rem auto 0; background: #1e2b44; border-radius: 2px; overflow: hidden; }
.intro-bar span {
  display: block; height: 100%; width: 0;
  background: linear-gradient(90deg, #d4a843, #ecd06a);
  animation: introBar 2.3s cubic-bezier(0.5,0,0.2,1) 0.4s both;
}
@keyframes introMark { from { opacity: 0; transform: scale(0.4) rotate(-12deg); } to { opacity: 1; transform: scale(1) rotate(0); } }
@keyframes introWord { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: translateY(0); } }
@keyframes introBar { from { width: 0; } to { width: 100%; } }

/* ---- Navigation ------------------------------------------- */
#home-nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 40;
  border-bottom: 1px solid transparent;
  transition: background 0.3s ease, border-color 0.3s ease, backdrop-filter 0.3s ease;
}
#home-nav.nav-scrolled, #home-nav.nav-solid {
  background: rgb(var(--c-bg) / 0.92); backdrop-filter: blur(14px);
  border-bottom-color: rgb(var(--c-border));
}
.nav-word { color: #f1f5f9; transition: color 0.2s ease; }
#home-nav.nav-scrolled .nav-word, #home-nav.nav-solid .nav-word { color: rgb(var(--c-text)); }
.nav-link {
  padding: 0.5rem 0.85rem; font-size: 0.875rem; font-weight: 500;
  color: #c3ccd9; border-radius: 0.375rem; transition: color 0.15s, background 0.15s;
}
.nav-link:hover { color: #ffffff; background: rgba(255,255,255,0.08); }
#home-nav.nav-scrolled .nav-link, #home-nav.nav-solid .nav-link { color: rgb(var(--c-text2)); }
#home-nav.nav-scrolled .nav-link:hover, #home-nav.nav-solid .nav-link:hover {
  color: rgb(var(--c-text)); background: rgb(var(--c-surface-2));
}
.theme-toggle {
  padding: 0.5rem; border-radius: 0.375rem; color: #c3ccd9;
  transition: color 0.15s, background 0.15s; display: inline-flex;
}
.theme-toggle:hover { color: #ffffff; background: rgba(255,255,255,0.08); }
#home-nav.nav-scrolled .theme-toggle, #home-nav.nav-solid .theme-toggle { color: rgb(var(--c-text2)); }
#home-nav.nav-scrolled .theme-toggle:hover, #home-nav.nav-solid .theme-toggle:hover {
  color: rgb(var(--c-text)); background: rgb(var(--c-surface-2));
}
#home-mobile-menu {
  background: rgb(var(--c-bg)); border-top: 1px solid rgb(var(--c-border));
}
.mobile-link {
  padding: 0.7rem 0.25rem; font-size: 0.95rem; font-weight: 500; color: rgb(var(--c-text2));
  border-bottom: 1px solid rgb(var(--c-border)); transition: color 0.15s;
}
.mobile-link:hover { color: rgb(var(--c-accent)); }

/* ---- Shared elements -------------------------------------- */
.section { padding: 5.5rem 0; background: rgb(var(--c-bg)); color: rgb(var(--c-text)); border-top: 1px solid rgb(var(--c-border)); }
.section-alt { background: rgb(var(--c-bg-alt)); }
@media (min-width: 640px) { .section { padding: 7rem 0; } }
.section-title {
  font-family: Manrope, sans-serif; font-weight: 800; letter-spacing: -0.02em;
  font-size: clamp(1.75rem, 3.4vw, 2.5rem); line-height: 1.12; color: rgb(var(--c-text));
}
.page-title {
  font-family: Manrope, sans-serif; font-weight: 800; letter-spacing: -0.025em;
  font-size: clamp(2.25rem, 5.2vw, 3.6rem); line-height: 1.05; color: #f8fafc; margin: 0 0 1.25rem;
}
.page-lead { color: #cbd5e1; font-size: 1.125rem; line-height: 1.7; max-width: 42rem; }
.eyebrow {
  display: flex; align-items: center; gap: 0.65rem;
  font-family: 'JetBrains Mono', monospace; font-size: 0.72rem;
  letter-spacing: 0.18em; text-transform: uppercase; color: rgb(var(--c-accent));
}
.eyebrow::before { content: ''; width: 28px; height: 1px; background: rgb(var(--c-accent)); flex-shrink: 0; }
.eyebrow-center { justify-content: center; }
.accent { color: rgb(var(--c-accent)); }
.hr-sep { color: rgba(255,255,255,0.25); }
.status-dot {
  width: 7px; height: 7px; border-radius: 50%; background: #22c55e; flex-shrink: 0;
  box-shadow: 0 0 0 0 rgba(34,197,94,0.5); animation: statusPulse 2.4s ease-out infinite;
}
@keyframes statusPulse {
  0% { box-shadow: 0 0 0 0 rgba(34,197,94,0.5); }
  70%,100% { box-shadow: 0 0 0 7px rgba(34,197,94,0); }
}
.btn-primary {
  display: inline-flex; align-items: center; gap: 0.5rem; padding: 0.85rem 1.5rem;
  border-radius: 0.5rem; background: rgb(var(--c-gold)); color: #0a0f1c;
  font-family: Manrope, sans-serif; font-weight: 700;
  transition: background 0.18s ease, transform 0.18s ease;
}
.btn-primary:hover { background: rgb(var(--c-gold2)); transform: translateY(-2px); }
.btn-ghost {
  display: inline-flex; align-items: center; gap: 0.5rem; padding: 0.85rem 1.5rem;
  border-radius: 0.5rem; border: 1px solid rgb(var(--c-border)); color: rgb(var(--c-text));
  font-family: Manrope, sans-serif; font-weight: 600;
  transition: border-color 0.18s ease, background 0.18s ease;
}
.btn-ghost:hover { border-color: rgb(var(--c-gold)); background: rgb(var(--c-surface-2)); }
.link-arrow {
  display: inline-flex; align-items: center; gap: 0.4rem;
  font-family: 'JetBrains Mono', monospace; font-size: 0.78rem; letter-spacing: 0.04em;
  color: rgb(var(--c-accent)); transition: gap 0.18s ease, color 0.15s;
}
.link-arrow:hover { color: rgb(var(--c-gold)); gap: 0.65rem; }

/* ---- Hero ------------------------------------------------- */
.hero-section {
  position: relative; min-height: 100vh; display: flex; align-items: center;
  overflow: hidden; background: #0a0f1c;
}
.hero-media { position: absolute; inset: 0; z-index: 0; }
.hero-img { width: 100%; height: 100%; object-fit: cover; opacity: 0.42; filter: saturate(0.85) contrast(1.05); }
.hero-tint {
  position: absolute; inset: 0;
  background:
    linear-gradient(90deg, rgba(10,15,28,0.97) 0%, rgba(10,15,28,0.78) 45%, rgba(10,15,28,0.5) 100%),
    linear-gradient(0deg, #0a0f1c 2%, rgba(10,15,28,0) 45%);
}
.hero-grid {
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(120,140,170,0.14) 1px, transparent 1px),
    linear-gradient(90deg, rgba(120,140,170,0.14) 1px, transparent 1px);
  background-size: 66px 66px;
  mask-image: radial-gradient(ellipse 70% 65% at 65% 45%, #000 0%, transparent 80%);
  -webkit-mask-image: radial-gradient(ellipse 70% 65% at 65% 45%, #000 0%, transparent 80%);
}
.hero-glow {
  position: absolute; width: 60vw; height: 60vw; max-width: 820px; max-height: 820px;
  top: -16%; right: -8%;
  background: radial-gradient(circle, rgba(212,168,67,0.18) 0%, transparent 65%); filter: blur(14px);
}
.hero-scan {
  position: absolute; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(212,168,67,0.5), transparent);
  animation: heroScan 9s linear infinite;
}
@keyframes heroScan { 0% { top: 8%; opacity: 0; } 10%,90% { opacity: 1; } 100% { top: 94%; opacity: 0; } }
.hero-cue {
  position: absolute; bottom: 1.75rem; left: 50%; transform: translateX(-50%);
  z-index: 10; color: #64748b; animation: heroCue 2.2s ease-in-out infinite;
}
.hero-cue:hover { color: #d4a843; }
@keyframes heroCue { 0%,100% { transform: translate(-50%,0); } 50% { transform: translate(-50%,7px); } }

/* ---- Page header (sub-pages) ------------------------------ */
.page-head {
  position: relative; overflow: hidden; background: #0a0f1c;
  padding: 9.5rem 0 4.5rem;
}
@media (min-width: 640px) { .page-head { padding: 11rem 0 5.5rem; } }
.page-head-bg { position: absolute; inset: 0; z-index: 0; }

/* ---- Positioning band + marquee --------------------------- */
.band-positioning { background: rgb(var(--c-bg)); overflow: hidden; }
.marquee { border-top: 1px solid #1e2b44; border-bottom: 1px solid #1e2b44; background: #0c1322; overflow: hidden; padding: 1rem 0; }
.marquee-track { display: flex; align-items: center; gap: 1.5rem; width: max-content; animation: marquee 48s linear infinite; }
.marquee-track span {
  font-family: 'JetBrains Mono', monospace; font-size: 0.8rem; letter-spacing: 0.12em;
  text-transform: uppercase; color: #64748b; white-space: nowrap;
}
.marquee-track .marquee-dot { color: #d4a843; }
@keyframes marquee { from { transform: translateX(0); } to { transform: translateX(-50%); } }

/* ---- Scroll reveal ---------------------------------------- */
.reveal { opacity: 0; transform: translateY(24px); transition: opacity 0.7s ease, transform 0.7s ease; }
.reveal.is-visible { opacity: 1; transform: none; }

/* ---- Media frame ------------------------------------------ */
.media-frame {
  position: relative; border-radius: 1rem; overflow: hidden;
  border: 1px solid rgb(var(--c-border)); background: rgb(var(--c-surface));
}
.media-frame img { width: 100%; height: 100%; min-height: 340px; object-fit: cover; }
.media-net { position: absolute; top: 0; right: 0; width: 45%; height: auto; opacity: 0.7; }
.media-tag {
  position: absolute; left: 1rem; bottom: 1rem; display: flex; align-items: center; gap: 0.45rem;
  font-family: 'JetBrains Mono', monospace; font-size: 0.66rem; letter-spacing: 0.1em;
  text-transform: uppercase; color: rgb(var(--c-text));
  background: rgb(var(--c-surface) / 0.92); border: 1px solid rgb(var(--c-border));
  padding: 0.4rem 0.7rem; border-radius: 0.5rem; backdrop-filter: blur(4px);
}

/* ---- Industry cards --------------------------------------- */
.ind-card {
  display: block; background: rgb(var(--c-surface)); border: 1px solid rgb(var(--c-border));
  border-radius: 0.85rem; overflow: hidden; transition: transform 0.2s ease, border-color 0.2s ease;
}
.ind-card:hover { transform: translateY(-4px); border-color: color-mix(in srgb, var(--ind-color) 60%, transparent); }
.ind-card-media { position: relative; aspect-ratio: 16 / 11; overflow: hidden; }
.ind-card-media img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.5s ease; }
.ind-card:hover .ind-card-media img { transform: scale(1.08); }
.ind-card-tint { position: absolute; inset: 0; background: linear-gradient(0deg, rgb(var(--c-surface)) 2%, rgba(10,15,28,0.1) 65%); }
.ind-card-icon {
  position: absolute; top: 0.6rem; left: 0.6rem; width: 32px; height: 32px; border-radius: 0.5rem;
  display: flex; align-items: center; justify-content: center;
  background: rgba(10,15,28,0.82); border: 1px solid rgba(255,255,255,0.12); color: var(--ind-color);
}
.ind-card-tag {
  position: absolute; top: 0.65rem; right: 0.65rem;
  font-family: 'JetBrains Mono', monospace; font-size: 0.56rem; letter-spacing: 0.1em;
  text-transform: uppercase; color: #ecd06a;
  background: rgba(10,15,28,0.82); border: 1px solid rgba(212,168,67,0.4);
  padding: 2px 7px; border-radius: 999px;
}
.ind-card-body { padding: 0.9rem 1rem 1.1rem; }
.ind-card-body h3 { color: rgb(var(--c-text)); }
.ind-card-body p { color: rgb(var(--c-text3)); }
.ind-card-focus { border-color: rgb(var(--c-gold) / 0.4); }

/* ---- Capability feature blocks ---------------------------- */
.cap-feature {
  display: grid; grid-template-columns: 1fr 1fr; background: rgb(var(--c-surface));
  border: 1px solid rgb(var(--c-border)); border-radius: 1.1rem; overflow: hidden;
  transition: border-color 0.2s ease;
}
.cap-feature:hover { border-color: rgb(var(--c-gold) / 0.4); }
.cap-feature-media { position: relative; min-height: 380px; }
.cap-feature-media img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.cap-feature-media::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(90deg, transparent 38%, rgb(var(--c-surface)) 100%);
}
.cap-feature-rev .cap-feature-media::after { background: linear-gradient(270deg, transparent 38%, rgb(var(--c-surface)) 100%); }
.cap-feature-rev .cap-feature-media { order: 2; }
.cap-feature-badge {
  position: absolute; top: 1rem; left: 1rem; z-index: 1; display: flex; align-items: center; gap: 0.4rem;
  font-family: 'JetBrains Mono', monospace; font-size: 0.6rem; letter-spacing: 0.1em;
  text-transform: uppercase; color: #22c55e;
  background: rgba(10,15,28,0.82); border: 1px solid rgba(255,255,255,0.12);
  padding: 0.35rem 0.65rem; border-radius: 999px;
}
.cap-feature-body { padding: 2.5rem; display: flex; flex-direction: column; }
.cap-feature-body h3 { color: rgb(var(--c-text)); }
.cap-feature-body > p { color: rgb(var(--c-text2)); }
.cap-points { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 0.55rem; }
.cap-points li { display: flex; gap: 0.6rem; font-size: 0.875rem; color: rgb(var(--c-text2)); }
.cap-points li i { color: rgb(var(--c-accent)); flex-shrink: 0; margin-top: 2px; }

/* ---- Capability cards ------------------------------------- */
.cap-card {
  display: flex; flex-direction: column; height: 100%; background: rgb(var(--c-surface));
  border: 1px solid rgb(var(--c-border)); border-radius: 1rem; padding: 1.6rem;
  transition: transform 0.2s ease, border-color 0.2s ease;
}
.cap-card:hover { transform: translateY(-4px); border-color: rgb(var(--c-gold) / 0.4); }
.cap-card h3 { color: rgb(var(--c-text)); }
.cap-card p { color: rgb(var(--c-text2)); }
.cap-icon {
  width: 48px; height: 48px; border-radius: 0.7rem; background: rgb(var(--c-accent) / 0.12);
  border: 1px solid rgb(var(--c-accent) / 0.28); color: rgb(var(--c-accent));
  display: flex; align-items: center; justify-content: center;
}
.cap-status {
  font-family: 'JetBrains Mono', monospace; font-size: 0.58rem; letter-spacing: 0.12em;
  color: #22c55e; background: rgba(34,197,94,0.12); padding: 3px 9px; border-radius: 999px;
}
.cap-code {
  font-family: 'JetBrains Mono', monospace; font-size: 0.74rem; letter-spacing: 0.16em;
  color: rgb(var(--c-accent)); margin-bottom: 0.35rem;
}
.cap-tag {
  font-family: 'JetBrains Mono', monospace; font-size: 0.62rem; letter-spacing: 0.03em;
  color: rgb(var(--c-text2)); background: rgb(var(--c-surface-2));
  border: 1px solid rgb(var(--c-border)); padding: 3px 8px; border-radius: 0.375rem;
}

/* ---- Mini / standard / value cards ------------------------ */
.mini-card, .value-card, .standard-card {
  background: rgb(var(--c-surface)); border: 1px solid rgb(var(--c-border));
  border-radius: 1rem; padding: 1.75rem; transition: transform 0.2s ease, border-color 0.2s ease;
}
.mini-card:hover, .value-card:hover, .standard-card:hover {
  transform: translateY(-4px); border-color: rgb(var(--c-gold) / 0.4);
}
.mini-card h3, .value-card h3, .standard-card h3 { color: rgb(var(--c-text)); }
.mini-card p, .value-card p, .standard-card p { color: rgb(var(--c-text2)); }
.card-icon {
  width: 46px; height: 46px; border-radius: 0.7rem; margin-bottom: 1.1rem;
  background: rgb(var(--c-accent) / 0.12); border: 1px solid rgb(var(--c-accent) / 0.28);
  color: rgb(var(--c-accent)); display: flex; align-items: center; justify-content: center;
}

/* ---- Approach / process steps ----------------------------- */
.approach-step {
  position: relative; background: rgb(var(--c-surface)); border: 1px solid rgb(var(--c-border));
  border-radius: 1rem; padding: 1.75rem; transition: transform 0.2s ease, border-color 0.2s ease;
}
.approach-step:hover { transform: translateY(-4px); border-color: rgb(var(--c-gold) / 0.4); }
.approach-step h3 { color: rgb(var(--c-text)); }
.approach-step p { color: rgb(var(--c-text2)); }
.approach-num {
  position: absolute; top: 1.4rem; right: 1.5rem;
  font-family: 'JetBrains Mono', monospace; font-size: 1rem; font-weight: 600;
  color: rgb(var(--c-border));
}
.approach-icon {
  width: 48px; height: 48px; border-radius: 0.7rem; margin-bottom: 1.1rem;
  background: rgb(var(--c-accent) / 0.12); border: 1px solid rgb(var(--c-accent) / 0.28);
  color: rgb(var(--c-accent)); display: flex; align-items: center; justify-content: center;
}

/* ---- Programs (codenamed) --------------------------------- */
.programs-section { position: relative; overflow: hidden; background: rgb(var(--c-bg)); }
.programs-bg { position: absolute; inset: 0; z-index: 0; }
.programs-bg img { width: 100%; height: 100%; object-fit: cover; opacity: 0.14; }
.programs-section::before {
  content: ''; position: absolute; inset: 0; z-index: 1;
  background: linear-gradient(180deg, #0a0f1c 0%, rgba(10,15,28,0.7) 50%, #0a0f1c 100%);
}
.prog-card {
  position: relative; overflow: hidden; background: #0c1322; border: 1px solid #1e2b44;
  border-radius: 1rem; padding: 1.6rem; transition: border-color 0.2s ease, transform 0.2s ease;
}
.prog-card::before {
  content: ''; position: absolute; inset: 0;
  background: repeating-linear-gradient(45deg, rgba(212,168,67,0.045) 0 10px, transparent 10px 20px);
  pointer-events: none;
}
.prog-card:hover { transform: translateY(-4px); border-color: rgba(212,168,67,0.35); }
.prog-icon {
  width: 48px; height: 48px; border-radius: 0.7rem; background: #142036;
  border: 1px solid #1e2b44; color: #94a3b8; display: flex; align-items: center; justify-content: center;
}
.prog-status {
  font-family: 'JetBrains Mono', monospace; font-size: 0.58rem; letter-spacing: 0.12em;
  color: #f59e0b; background: rgba(245,158,11,0.12); padding: 3px 9px; border-radius: 999px;
}
.prog-code {
  font-family: 'JetBrains Mono', monospace; font-size: 0.82rem; letter-spacing: 0.14em;
  color: #ecd06a; margin-bottom: 0.4rem;
}

/* ---- Metrics band ----------------------------------------- */
.band-metrics { background: rgb(var(--c-bg)); border-top: 1px solid rgb(var(--c-border)); }
.js-metrics, .metric-grid { background: rgb(var(--c-border)); border-radius: 0.9rem; overflow: hidden; }
.metric-cell {
  background: rgb(var(--c-surface)); padding: 2.25rem 1.5rem; text-align: center;
  display: flex; flex-direction: column; gap: 0.5rem;
}
.metric-v {
  font-family: Manrope, sans-serif; font-weight: 800;
  font-size: clamp(1.9rem, 4vw, 2.75rem); color: rgb(var(--c-accent)); line-height: 1;
}
.metric-k { font-size: 0.8rem; color: rgb(var(--c-text2)); }

/* ---- Convictions ------------------------------------------ */
.js-convictions { background: rgb(var(--c-border)); border-radius: 0.9rem; overflow: hidden; }
.conviction { background: rgb(var(--c-surface)); padding: 1.75rem; transition: background 0.2s ease; }
.conviction:hover { background: rgb(var(--c-surface-2)); }
.conviction h3 { color: rgb(var(--c-text)); }
.conviction p { color: rgb(var(--c-text2)); }
.conviction-num {
  font-family: 'JetBrains Mono', monospace; font-size: 0.72rem; letter-spacing: 0.1em;
  color: rgb(var(--c-accent)); display: block; margin-bottom: 0.85rem;
}

/* ---- Insight cards ---------------------------------------- */
.insight-card {
  display: flex; flex-direction: column; height: 100%; overflow: hidden;
  background: rgb(var(--c-surface)); border: 1px solid rgb(var(--c-border));
  border-radius: 0.9rem; cursor: pointer; transition: transform 0.2s ease, border-color 0.2s ease;
}
.insight-card:hover { transform: translateY(-4px); border-color: rgb(var(--c-gold) / 0.4); }
.insight-media { position: relative; aspect-ratio: 16 / 9; overflow: hidden; }
.insight-media img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.5s ease; }
.insight-card:hover .insight-media img { transform: scale(1.07); }
.insight-tag {
  position: absolute; top: 0.7rem; left: 0.7rem;
  font-family: 'JetBrains Mono', monospace; font-size: 0.58rem; letter-spacing: 0.08em;
  text-transform: uppercase; color: #ecd06a;
  background: rgba(10,15,28,0.82); border: 1px solid rgba(255,255,255,0.12);
  padding: 2px 8px; border-radius: 999px;
}
.insight-body { display: flex; flex-direction: column; height: 100%; padding: 1.25rem; }
.insight-body h3 { color: rgb(var(--c-text)); }
.insight-body p { color: rgb(var(--c-text3)); }
.insight-date { font-family: 'JetBrains Mono', monospace; font-size: 0.66rem; color: rgb(var(--c-text3)); margin-bottom: 0.5rem; }
.insight-more {
  display: inline-flex; align-items: center; gap: 0.35rem;
  font-size: 0.78rem; font-weight: 600; color: rgb(var(--c-accent)); margin-top: auto;
}
.insight-card:hover .insight-more { color: rgb(var(--c-gold)); }

/* ---- Role cards (careers) --------------------------------- */
.role-card {
  display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: 1rem;
  background: rgb(var(--c-surface)); border: 1px solid rgb(var(--c-border));
  border-radius: 0.85rem; padding: 1.4rem 1.6rem; transition: border-color 0.2s ease, transform 0.2s ease;
}
.role-card:hover { border-color: rgb(var(--c-gold) / 0.4); transform: translateY(-2px); }
.role-card h3 { color: rgb(var(--c-text)); }
.role-meta {
  display: flex; flex-wrap: wrap; gap: 0.4rem; align-items: center;
  font-family: 'JetBrains Mono', monospace; font-size: 0.68rem; color: rgb(var(--c-text3));
}
.role-meta .dot { width: 3px; height: 3px; border-radius: 50%; background: rgb(var(--c-text3)); }
.role-apply {
  display: inline-flex; align-items: center; gap: 0.4rem; flex-shrink: 0;
  font-family: 'JetBrains Mono', monospace; font-size: 0.74rem; color: rgb(var(--c-accent));
}
.role-card:hover .role-apply { color: rgb(var(--c-gold)); }

/* ---- Founder note ----------------------------------------- */
.founder-note {
  background: rgb(var(--c-surface)); border: 1px solid rgb(var(--c-border));
  border-left: 3px solid rgb(var(--c-gold)); border-radius: 0.9rem; padding: 2rem;
}
.founder-note p { color: rgb(var(--c-text2)); }
.founder-sign { border-top: 1px solid rgb(var(--c-border)); }
.founder-sign p:first-child { color: rgb(var(--c-text)); }

/* ---- CTA final band --------------------------------------- */
.cta-final { position: relative; overflow: hidden; background: rgb(var(--c-bg)); }
.cta-final-bg { position: absolute; inset: 0; z-index: 0; }
.cta-final-bg img { width: 100%; height: 100%; object-fit: cover; opacity: 0.22; }
.cta-final::before {
  content: ''; position: absolute; inset: 0; z-index: 1;
  background: linear-gradient(180deg, rgba(10,15,28,0.9) 0%, rgba(10,15,28,0.82) 100%);
}

/* ---- Contact cards ---------------------------------------- */
.cta-band { position: relative; overflow: hidden; background: rgb(var(--c-bg)); }
.cta-bg { position: absolute; inset: 0; z-index: 0; }
.cta-bg img { width: 100%; height: 100%; object-fit: cover; opacity: 0.3; }
.cta-band::before {
  content: ''; position: absolute; inset: 0; z-index: 1;
  background: linear-gradient(180deg, rgba(10,15,28,0.92) 0%, rgba(10,15,28,0.8) 100%);
}
.contact-card {
  display: block; background: rgb(var(--c-surface)); border: 1px solid rgb(var(--c-border));
  border-radius: 1rem; padding: 2rem; transition: transform 0.2s ease, border-color 0.2s ease;
}
.contact-card:hover { transform: translateY(-4px); border-color: rgb(var(--c-gold) / 0.45); }
.contact-card h3 { color: rgb(var(--c-text)); }
.contact-icon {
  width: 52px; height: 52px; border-radius: 0.75rem; margin-bottom: 1.25rem;
  background: rgb(var(--c-accent) / 0.12); border: 1px solid rgb(var(--c-accent) / 0.28);
  color: rgb(var(--c-accent)); display: flex; align-items: center; justify-content: center;
}
.contact-mail {
  display: inline-flex; align-items: center; gap: 0.4rem;
  font-family: 'JetBrains Mono', monospace; font-size: 0.78rem; color: rgb(var(--c-accent));
}
.contact-card:hover .contact-mail { color: rgb(var(--c-gold)); }

/* ---- Footer ----------------------------------------------- */
.site-footer { background: rgb(var(--c-bg)); border-top: 1px solid rgb(var(--c-border)); }
.footer-h {
  font-family: 'JetBrains Mono', monospace; font-size: 0.7rem; letter-spacing: 0.12em;
  text-transform: uppercase; color: rgb(var(--c-text3)); margin-bottom: 0.9rem;
}
.footer-link {
  display: block; font-size: 0.875rem; color: rgb(var(--c-text2));
  padding: 0.3rem 0; transition: color 0.15s; background: none; border: none; cursor: pointer;
}
.footer-link:hover { color: rgb(var(--c-gold)); }
.footer-rule { border-top: 1px solid rgb(var(--c-border)); }

/* ---- Login modal ------------------------------------------ */
#login-modal { position: fixed; inset: 0; z-index: 120; display: flex; align-items: center; justify-content: center; padding: 1rem; }
#login-modal.hidden { display: none; }
.login-modal-backdrop {
  position: absolute; inset: 0; background: rgba(5,8,16,0.82);
  backdrop-filter: blur(6px); opacity: 0; transition: opacity 0.22s ease;
}
#login-modal.modal-open .login-modal-backdrop { opacity: 1; }
.login-modal-card {
  position: relative; z-index: 1; width: 100%; max-width: 26rem;
  background: #0f172a; border: 1px solid #1e2b44; border-radius: 1.25rem;
  padding: 2.25rem; box-shadow: 0 30px 80px rgba(0,0,0,0.6);
  opacity: 0; transform: translateY(16px) scale(0.97);
  transition: opacity 0.22s ease, transform 0.22s ease;
}
#login-modal.modal-open .login-modal-card { opacity: 1; transform: translateY(0) scale(1); }
.login-modal-close {
  position: absolute; top: 1rem; right: 1rem; width: 34px; height: 34px; border-radius: 0.5rem;
  display: flex; align-items: center; justify-content: center; color: #64748b;
  transition: color 0.15s, background 0.15s;
}
.login-modal-close:hover { color: #f8fafc; background: #142036; }

/* ---- Statement bands -------------------------------------- */
.statement-band {
  padding: 6.5rem 0; text-align: center; background: rgb(var(--c-bg));
  border-top: 1px solid rgb(var(--c-border));
}
@media (min-width: 640px) { .statement-band { padding: 8.5rem 0; } }
.statement-band.section-alt { background: rgb(var(--c-bg-alt)); }
.statement-rule {
  display: block; width: 46px; height: 2px; margin-bottom: 2rem;
  background: rgb(var(--c-accent));
}
.statement-rule.mx-auto { margin-left: auto; margin-right: auto; }
.statement-text {
  font-family: Manrope, sans-serif; font-weight: 800; letter-spacing: -0.025em;
  font-size: clamp(1.9rem, 4.4vw, 3.5rem); line-height: 1.12; color: rgb(var(--c-text));
  margin: 0 auto; max-width: 62rem;
}
.statement-xl .statement-text { font-size: clamp(3rem, 9vw, 7rem); line-height: 1.02; }
.statement-band-sm { padding: 4rem 0; border-top: none; }
.statement-band-sm .statement-text { font-size: clamp(1.6rem, 3.4vw, 2.6rem); }
.statement-band-sm .statement-rule { margin-bottom: 1.5rem; }

/* ---- Build statement (Programs) --------------------------- */
.build-statement {
  margin-top: 5rem; text-align: center;
  font-family: Manrope, sans-serif; font-weight: 800; letter-spacing: -0.03em;
  font-size: clamp(2.5rem, 7vw, 5.5rem); line-height: 1; color: rgb(var(--c-text));
}

/* ---- Request a demo button -------------------------------- */
.btn-demo {
  display: inline-flex; align-items: center; gap: 0.45rem; align-self: flex-start;
  padding: 0.6rem 1.1rem; border-radius: 0.5rem;
  background: rgb(var(--c-accent) / 0.1); border: 1px solid rgb(var(--c-accent) / 0.35);
  color: rgb(var(--c-accent)); font-family: 'JetBrains Mono', monospace;
  font-size: 0.74rem; letter-spacing: 0.04em; font-weight: 500;
  transition: background 0.18s ease, border-color 0.18s ease;
}
.btn-demo:hover { background: rgb(var(--c-accent) / 0.18); border-color: rgb(var(--c-accent) / 0.6); }

/* ---- Gated section (login pop-up placeholder) ------------- */
.gated-section {
  position: relative; overflow: hidden; cursor: pointer; text-align: center;
  background: rgb(var(--c-surface)); border: 1px dashed rgb(var(--c-gold) / 0.5);
  border-radius: 1.25rem; padding: 3.5rem 2rem;
  transition: border-color 0.2s ease, transform 0.2s ease;
}
.gated-section::before {
  content: ''; position: absolute; inset: 0; pointer-events: none;
  background: repeating-linear-gradient(45deg, rgb(var(--c-gold) / 0.04) 0 12px, transparent 12px 24px);
}
.gated-section:hover { transform: translateY(-3px); border-color: rgb(var(--c-gold) / 0.85); }
.gated-section > * { position: relative; }
.gated-lock {
  width: 60px; height: 60px; margin: 0 auto 1.5rem; border-radius: 1rem;
  display: flex; align-items: center; justify-content: center;
  background: rgb(var(--c-gold) / 0.14); border: 1px solid rgb(var(--c-gold) / 0.35);
  color: rgb(var(--c-accent));
}
.gated-section h3 { color: rgb(var(--c-text)); }

/* ---- Domain page header ----------------------------------- */
.domain-head { padding-bottom: 5.5rem; }
.domain-head-bg { position: absolute; inset: 0; z-index: 0; }
.domain-head-bg img { width: 100%; height: 100%; object-fit: cover; opacity: 0.38; }
.domain-head-tint {
  position: absolute; inset: 0;
  background:
    linear-gradient(90deg, rgba(10,15,28,0.96) 0%, rgba(10,15,28,0.74) 55%, rgba(10,15,28,0.45) 100%),
    linear-gradient(0deg, #0a0f1c 3%, rgba(10,15,28,0) 50%);
}

/* ---- Industry card link ----------------------------------- */
.ind-card-link {
  display: inline-flex; align-items: center; gap: 0.3rem; margin-top: 0.8rem;
  font-family: 'JetBrains Mono', monospace; font-size: 0.66rem; letter-spacing: 0.05em;
  text-transform: uppercase; color: rgb(var(--c-accent)); transition: gap 0.18s ease;
}
.ind-card:hover .ind-card-link { gap: 0.55rem; }

/* ---- Responsive ------------------------------------------- */
@media (max-width: 860px) {
  .cap-feature { grid-template-columns: 1fr; }
  .cap-feature-media { min-height: 240px; }
  .cap-feature-rev .cap-feature-media { order: 0; }
  .cap-feature-media::after,
  .cap-feature-rev .cap-feature-media::after {
    background: linear-gradient(0deg, rgb(var(--c-surface)) 4%, transparent 60%);
  }
  .cap-feature-body { padding: 1.75rem; }
}

/* ---- Reduced motion --------------------------------------- */
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  .reveal { opacity: 1; transform: none; transition: none; }
  .hero-scan, .hero-cue, .status-dot, .marquee-track { animation: none; }
  .intro-mark, .intro-word, .intro-sub, .intro-bar span { animation: none; opacity: 1; }
}
