/* NeuralFlux — Site Design System (nf-* + site-* unified) */
:root {
  --bg-dark: #0D1F17;
  --text-on-dark: #FAF8F5;
  --bg-light: #FAF8F5;
  --text-on-light: #0D1F17;
  --bg-accent: #F59E0B;
  --text-on-accent: #0D1F17;
  --bg-moss: #1A3328;
  --text-on-moss: #FAF8F5;
  --font-head: 'Syne', sans-serif;
  --font-body: 'DM Sans', sans-serif;
  --amber: #F59E0B;
  --amber-light: #FCD34D;
  --max-width: 1200px;
  --header-h: 72px;
}

.nf-header{position:fixed;top:0;left:0;right:0;z-index:1000;background:var(--bg-dark);border-bottom:1px solid rgba(245,158,11,.2);height:var(--header-h)}
.nf-header-inner{display:flex;align-items:center;justify-content:space-between;padding:0 1rem;height:100%;max-width:var(--max-width);margin:0 auto}
.nf-logo{display:flex;align-items:center;gap:.75rem;text-decoration:none;color:var(--text-on-dark)}
.nf-logo svg{width:36px;height:36px}
.nf-logo span{font-family:var(--font-head);font-weight:700;font-size:1.25rem}
.overlay-nav{list-style:none;text-align:center}
.overlay-nav a{font-family:var(--font-head);font-size:clamp(1.75rem,5vw,3rem);font-weight:700;text-decoration:none;color:inherit;display:block;padding:.35rem 1rem}
.overlay-nav a:hover{color:var(--amber)}
.overlay-tags{margin-top:2rem;display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap;font-size:.8rem;color:var(--amber)}
.hero-j{min-height:100vh;display:flex;flex-direction:column;margin-top:var(--header-h)}
.hero-j-top{flex:0 0 60%;display:flex;align-items:center;padding:3rem 1rem}
.hero-j-content{max-width:960px;margin:0 auto;width:min(100% - 2rem,var(--max-width))}
.hero-j-content .eyebrow{font-size:10px;margin-bottom:.5rem}
.hero-j-content h1{font-size:clamp(1.35rem,2.8vw,1.85rem);font-weight:700;line-height:1.3;margin:.5rem 0 1rem;max-width:100%}
.hero-serial{font-size:.75rem;opacity:.75;margin-bottom:.5rem}
.btn-flux{display:inline-block;padding:14px 28px;background:var(--amber);color:var(--text-on-accent);text-decoration:none;font-weight:700;border:none;cursor:pointer;font-family:var(--font-head);border-radius:0}
.btn-flux-outline{display:inline-block;padding:14px 28px;background:transparent;color:var(--text-on-dark);border:2px solid var(--amber);text-decoration:none;font-weight:600;border-radius:0}
.hero-j-bands{flex:0 0 40%;overflow:hidden;min-height:280px}
.photo-band{position:relative;overflow:hidden}
.photo-band img{width:100%;height:100%;object-fit:cover;min-height:200px}
.band-label{position:absolute;bottom:0;left:0;right:0;padding:.5rem .75rem;background:rgba(13,31,23,.85);color:var(--text-on-dark);font-size:.75rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;border-top:3px solid var(--amber)}
.marquee-viewport{overflow:hidden;width:100%;height:100%}
.marquee-track{display:flex;width:200%;animation:hero-marquee-pair 20s linear infinite;height:100%}
.marquee-track .photo-band{flex:0 0 12.5%;min-width:0}
@keyframes hero-marquee-pair{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.manifesto{font-family:var(--font-head);font-size:clamp(1.5rem,3.5vw,2.25rem);font-weight:700;line-height:1.25;max-width:900px}
.flux-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:0}
.flux-stat-num{font-family:var(--font-head);font-size:clamp(2.5rem,6vw,3.5rem);font-weight:800}
.surface-accent .flux-stats,.surface-accent .flux-stats div{color:#fff}
.surface-accent .cta-band h2,.surface-accent .cta-band p,.surface-accent .cta-section h2,.surface-accent .cta-section p,.surface-accent .cta-section .disclaimer{color:#fff}
.surface-accent .cta-section .disclaimer{border-color:rgba(255,255,255,.35)}
.nf-card{background:var(--bg-moss);color:var(--text-on-moss);padding:2rem;border-bottom:4px solid var(--amber)}
.flux-panels{display:flex;flex-direction:column}
.flux-panel{border-bottom:1px solid rgba(245,158,11,.2);padding:1rem 0}
.flux-panel-trigger{width:100%;background:none;border:none;color:inherit;font-family:var(--font-head);font-size:1.25rem;font-weight:700;cursor:pointer;text-align:left;display:flex;justify-content:space-between}
.flux-panel-body{margin-top:1rem;padding-bottom:1rem}
.flux-panel-body ul{list-style:none;padding:0}
.js .flux-panel-body{display:none}
.js .flux-panel.is-open .flux-panel-body{display:block}
.int-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0}
.int-cell{padding:2rem;border-bottom:4px solid var(--amber);font-family:var(--font-head);font-weight:700;text-align:center;transition:background .2s,color .2s}
.int-cell:hover{background:var(--bg-dark);color:var(--text-on-dark)}
.faq-acc-item{border-bottom:1px solid rgba(245,158,11,.25)}
.faq-acc-trigger{width:100%;background:none;border:none;color:inherit;padding:1.25rem 0;text-align:left;font-family:var(--font-head);font-size:1.1rem;font-weight:600;cursor:pointer;display:flex;gap:1rem;align-items:flex-start}
.faq-acc-body{padding:0 0 1.25rem 3.25rem}
.js .faq-acc-item:not(.is-open) .faq-acc-body{display:none}
.arch-split{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center}
.arch-frame{border:4px solid var(--amber)}
.nf-footer{padding-top:2rem}
.form-group{margin-bottom:1.25rem}
.form-group label{display:block;font-weight:500;margin-bottom:.35rem}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:.75rem;border:2px solid rgba(13,31,23,.2);border-radius:0;font-family:var(--font-body);font-size:1rem;margin-bottom:0}
.form-group textarea{min-height:140px}
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.consent{display:flex;gap:.65rem;align-items:flex-start}
.prog-row{display:grid;grid-template-columns:220px 1fr;gap:2rem;margin-bottom:2.5rem;padding-bottom:2.5rem;border-bottom:1px solid rgba(13,31,23,.1);align-items:start}
.prog-row img{width:100%;aspect-ratio:4/3;object-fit:cover;border-bottom:4px solid var(--amber)}
.prog-price{font-family:var(--font-head);font-weight:700;margin-top:.75rem}
.mosaic-cell{padding:1.5rem;border-bottom:4px solid var(--amber);text-align:center}
.mosaic-num{font-family:var(--font-head);font-size:2rem;font-weight:800;color:var(--amber);display:block}
.cookie-banner.hidden{display:none}
.cookie-btns{display:flex;gap:.5rem;flex-wrap:wrap}
.btn-accept{background:var(--amber);color:var(--text-on-accent);padding:.55rem 1.1rem;border:none;font-weight:600;cursor:pointer;border-radius:0}
.btn-reject,.btn-customise{background:transparent;border:2px solid var(--amber);color:inherit;padding:.55rem 1.1rem;font-weight:600;cursor:pointer;border-radius:0}
body.menu-open .menu-overlay{clip-path:circle(150% at calc(100% - 3rem) 3rem);pointer-events:auto;visibility:visible;transition:clip-path .55s cubic-bezier(.4,0,.2,1),visibility 0s}
.js .menu-overlay .overlay-nav li{opacity:0;transform:translateY(20px);transition:opacity .35s ease,transform .35s ease;transition-delay:0s}
body.menu-open .menu-overlay .overlay-nav li{opacity:1;transform:none}
body.menu-open .menu-overlay .overlay-nav li:nth-child(1){transition-delay:.08s}
body.menu-open .menu-overlay .overlay-nav li:nth-child(2){transition-delay:.14s}
body.menu-open .menu-overlay .overlay-nav li:nth-child(3){transition-delay:.2s}
body.menu-open .menu-overlay .overlay-nav li:nth-child(4){transition-delay:.26s}
body.menu-open .menu-overlay .overlay-nav li:nth-child(5){transition-delay:.32s}
body.menu-open .menu-overlay .overlay-nav li:nth-child(6){transition-delay:.38s}
body.menu-open .menu-overlay .overlay-nav li:nth-child(7){transition-delay:.44s}
body.menu-closing .menu-overlay .overlay-nav li{opacity:0;transform:translateY(20px)}
body.menu-closing .menu-overlay .overlay-nav li:nth-child(1){transition-delay:.28s}
body.menu-closing .menu-overlay .overlay-nav li:nth-child(2){transition-delay:.24s}
body.menu-closing .menu-overlay .overlay-nav li:nth-child(3){transition-delay:.2s}
body.menu-closing .menu-overlay .overlay-nav li:nth-child(4){transition-delay:.16s}
body.menu-closing .menu-overlay .overlay-nav li:nth-child(5){transition-delay:.12s}
body.menu-closing .menu-overlay .overlay-nav li:nth-child(6){transition-delay:.08s}
body.menu-closing .menu-overlay .overlay-nav li:nth-child(7){transition-delay:.04s}
.js .menu-overlay .overlay-tags{opacity:0;transition:opacity .3s ease;transition-delay:0s}
body.menu-open .menu-overlay .overlay-tags{opacity:1;transition-delay:.45s}
body.menu-closing .menu-overlay .overlay-tags{opacity:0;transition-delay:0s}
@media(max-width:768px){.flux-stats,.footer-cols,.arch-split,.about-split,.prog-row{grid-template-columns:1fr}.int-grid{grid-template-columns:1fr}}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; }

body {
  font-family: var(--font-body);
  font-size: 17px;
  line-height: 1.65;
  color: var(--text-on-light);
  background: var(--bg-light);
  overflow-x: hidden;
}

img { max-width: 100%; height: auto; display: block; }

a { color: inherit; }

h1, h2, h3, h4 {
  font-family: var(--font-head);
  line-height: 1.15;
  font-weight: 700;
}

.surface-dark { background: var(--bg-dark); color: var(--text-on-dark); }
.surface-light { background: var(--bg-light); color: var(--text-on-light); }
.surface-accent { background: var(--bg-accent); color: var(--text-on-accent); }
.surface-moss { background: var(--bg-moss); color: var(--text-on-moss); }
.surface-dark *, .surface-light *, .surface-accent *, .surface-moss * { color: inherit; }
.surface-accent .flux-stats,
.surface-accent .flux-stats > div,
.surface-accent .flux-stat-num,
.surface-accent.cta-section h2,
.surface-accent.cta-section p,
.surface-accent .cta-section h2,
.surface-accent .cta-section p,
.surface-accent .cta-section .disclaimer { color: #fff; }
.surface-dark a, .surface-light a, .surface-moss a { color: currentColor; text-decoration: underline; }

.container {
  width: min(100% - 2rem, var(--max-width));
  margin-inline: auto;
}

.section { padding: 4.5rem 0; }

.eyebrow {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--amber-light);
}

.stream-tag {
  display: inline-block;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.08em;
  color: var(--amber-light);
  text-transform: uppercase;
}

.surface-light .stream-tag,
.surface-light .prog-price {
  color: var(--text-on-light);
}

.slash-divider {
  display: block;
  width: 100%;
  max-width: 120px;
  height: 24px;
  margin: 1.5rem 0;
}

.slash-divider svg { width: 100%; height: 100%; }

/* Header */
.site-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1000;
  height: var(--header-h);
  background: var(--bg-dark);
  color: var(--text-on-dark);
  border-bottom: 1px solid rgba(245, 158, 11, 0.2);
}

.header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 100%;
  padding: 0 1rem;
  max-width: var(--max-width);
  margin: 0 auto;
}

.logo-link {
  display: flex;
  align-items: center;
  gap: 0.65rem;
  text-decoration: none;
  color: inherit;
}

.logo-hex { width: 36px; height: 36px; flex-shrink: 0; }

.logo-text {
  font-family: var(--font-head);
  font-weight: 700;
  font-size: 1.25rem;
  letter-spacing: -0.02em;
}

.menu-trigger {
  background: none;
  border: 2px solid var(--amber);
  color: var(--text-on-dark);
  font-family: var(--font-body);
  font-size: 0.9rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 0.55rem 1.25rem;
  cursor: pointer;
  min-height: 44px;
  min-width: 88px;
  transition: background 0.2s, color 0.2s;
}

.menu-trigger:hover,
.menu-trigger:focus-visible {
  background: var(--amber);
  color: var(--text-on-accent);
  outline: none;
}

.js .menu-trigger .label-close { display: none; }
body.menu-open .menu-trigger .label-menu,
body.menu-closing .menu-trigger .label-menu { display: none; }
body.menu-open .menu-trigger .label-close,
body.menu-closing .menu-trigger .label-close { display: inline; }

.nav-fallback {
  background: var(--bg-moss);
  color: var(--text-on-moss);
  padding: 0.75rem 1rem;
  margin-top: var(--header-h);
}

.nav-fallback ul {
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem 1.25rem;
  justify-content: center;
}

.nav-fallback a {
  text-decoration: none;
  font-weight: 500;
  font-size: 0.95rem;
  padding: 0.35rem 0;
}

.nav-fallback a:hover { color: var(--amber); }

.js .nav-fallback { display: none; }

.desktop-nav { display: none; }
.desktop-nav ul {
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  gap: 0.25rem 1.25rem;
  align-items: center;
}
.desktop-nav a {
  text-decoration: none;
  font-size: 0.9rem;
  font-weight: 500;
  padding: 0.35rem 0;
  color: var(--text-on-dark);
}
.desktop-nav a:hover { color: var(--amber-light); }

.menu-close {
  position: absolute;
  top: 1.25rem;
  right: 1.25rem;
  background: none;
  border: 2px solid var(--amber);
  color: var(--text-on-dark);
  font-size: 1.75rem;
  line-height: 1;
  width: 48px;
  height: 48px;
  cursor: pointer;
  display: none;
}
.menu-close:hover { background: var(--amber); color: var(--text-on-accent); }

.btn-flux-white {
  background: var(--bg-dark) !important;
  color: #fff !important;
  border-color: var(--bg-dark) !important;
  font-weight: 700;
}
.btn-flux-white:hover { background: transparent !important; color: #fff !important; border-color: #fff !important; }

.cta-section h2 {
  font-weight: 800;
  font-size: clamp(1.85rem, 4.5vw, 2.75rem);
}
.cta-section > .container > p:not(.disclaimer) {
  font-weight: 600;
  font-size: 1.125rem;
}
.cta-section .disclaimer {
  font-weight: 600;
}

.mosaic-cell .mosaic-num,
.metric-mosaic .mosaic-num,
.metric-mosaic .mosaic-cell { color: #fff; }

.about-portrait img,
.about-portrait-sm img { max-width: 220px; width: 100%; }
.about-inline-img { max-width: 480px; width: 100%; }
.faq-hero-img { max-width: 320px; width: 100%; margin-bottom: 2.5rem; border-bottom: 4px solid var(--amber); }

@media (min-width: 769px) {
  .desktop-nav { display: block; }
  .menu-trigger { display: none; }
  .menu-overlay { display: none !important; }
  .menu-close { display: none !important; }
}

@media (max-width: 768px) {
  .menu-trigger { display: inline-block; }
  .menu-close { display: flex; align-items: center; justify-content: center; }
  .marquee-track .photo-band { flex: 0 0 25%; }
}

.menu-overlay {
  position: fixed;
  inset: 0;
  z-index: 9998;
  background: var(--bg-dark);
  color: var(--text-on-dark);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  clip-path: circle(0% at calc(100% - 3rem) 3rem);
  transition: clip-path 0.55s cubic-bezier(0.4, 0, 0.2, 1), visibility 0s linear 0.55s;
  pointer-events: none;
  visibility: hidden;
}

body.menu-open .menu-overlay {
  clip-path: circle(150% at calc(100% - 3rem) 3rem);
  pointer-events: auto;
  visibility: visible;
  transition: clip-path 0.55s cubic-bezier(0.4, 0, 0.2, 1), visibility 0s;
}

body.menu-closing .menu-overlay {
  clip-path: circle(0% at calc(100% - 3rem) 3rem);
  pointer-events: none;
  visibility: visible;
  transition: clip-path 0.55s cubic-bezier(0.4, 0, 0.2, 1), visibility 0s linear 0.55s;
}

.menu-overlay-nav { list-style: none; text-align: center; }

.menu-overlay-nav li {
  margin: 0.5rem 0;
  opacity: 1;
  transform: translateY(0);
}

.js .menu-overlay-nav li {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.4s ease, transform 0.4s ease;
}

body.menu-open .menu-overlay-nav li {
  opacity: 1;
  transform: translateY(0);
}

body.menu-open .menu-overlay-nav li:nth-child(1) { transition-delay: 0.08s; }
body.menu-open .menu-overlay-nav li:nth-child(2) { transition-delay: 0.14s; }
body.menu-open .menu-overlay-nav li:nth-child(3) { transition-delay: 0.20s; }
body.menu-open .menu-overlay-nav li:nth-child(4) { transition-delay: 0.26s; }
body.menu-open .menu-overlay-nav li:nth-child(5) { transition-delay: 0.32s; }
body.menu-open .menu-overlay-nav li:nth-child(6) { transition-delay: 0.38s; }
body.menu-open .menu-overlay-nav li:nth-child(7) { transition-delay: 0.44s; }
body.menu-open .menu-overlay-nav li:nth-child(8) { transition-delay: 0.50s; }

.menu-overlay-nav a {
  font-family: var(--font-head);
  font-size: clamp(1.75rem, 5vw, 3rem);
  font-weight: 700;
  text-decoration: none;
  color: inherit;
  display: block;
  padding: 0.35rem 1rem;
  min-height: 48px;
  line-height: 1.3;
}

.menu-overlay-nav a:hover { color: var(--amber); }

.menu-tags {
  margin-top: 2rem;
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  justify-content: center;
}

.menu-tags span {
  font-size: 0.8rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--amber);
  border: 1px solid var(--amber);
  padding: 0.35rem 0.85rem;
}

body.menu-open,
body.menu-closing { overflow: hidden; }

/* Hero Pattern J */
.hero-pattern-j {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  margin-top: var(--header-h);
}

.hero-top {
  flex: 0 0 60%;
  display: flex;
  align-items: center;
  padding: 3rem 1rem;
}

.hero-top-inner { max-width: 720px; }

.hero-top h1 {
  font-size: clamp(2.25rem, 5.5vw, 3.875rem);
  font-weight: 800;
  margin: 1rem 0;
}

.hero-sub {
  font-size: 1.125rem;
  font-weight: 400;
  max-width: 560px;
  margin-bottom: 1.75rem;
  opacity: 0.92;
}

.hero-ctas {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  margin-bottom: 1.5rem;
}

.btn-cta-primary {
  display: inline-block;
  background: var(--amber);
  color: var(--text-on-accent);
  font-weight: 600;
  padding: 14px 28px;
  border-radius: 0;
  text-decoration: none;
  border: 2px solid var(--amber);
  min-height: 48px;
  line-height: 1.2;
  transition: background 0.2s, color 0.2s;
}

.btn-cta-primary:hover {
  background: transparent;
  color: var(--amber);
}

.btn-cta-secondary {
  display: inline-block;
  background: transparent;
  color: var(--text-on-dark);
  font-weight: 600;
  padding: 14px 28px;
  border-radius: 0;
  text-decoration: none;
  border: 2px solid var(--amber);
  min-height: 48px;
  line-height: 1.2;
  transition: background 0.2s;
}

.btn-cta-secondary:hover { background: rgba(245, 158, 11, 0.15); }

.signal-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.85rem;
  font-weight: 500;
}

.signal-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #22c55e;
  animation: pulse 2s ease infinite;
}

@keyframes pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: 0.6; transform: scale(1.2); }
}

.hero-bands {
  flex: 0 0 40%;
  overflow: hidden;
  min-height: 280px;
  position: relative;
}

.hero-bands-static {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  height: 100%;
}

.js .hero-bands-static { display: none; }

.hero-marquee {
  display: none;
  height: 100%;
  overflow: hidden;
}

.js .hero-marquee { display: block; }

.hero-marquee-track {
  display: flex;
  width: max-content;
  height: 100%;
  animation: hero-marquee 28s linear infinite;
}

@keyframes hero-marquee {
  0% { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

.hero-band {
  position: relative;
  overflow: hidden;
}

.hero-marquee .hero-band {
  flex: 0 0 33.333vw;
  max-width: 480px;
}

.hero-band img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  min-height: 200px;
}

.hero-band-label {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  background: rgba(13, 31, 23, 0.85);
  color: var(--text-on-dark);
  padding: 0.5rem 0.75rem;
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  border-top: 3px solid var(--amber);
}

@media (max-width: 767px) {
  .hero-pattern-j { min-height: 82vh; }
  .hero-top { flex: 0 0 55%; padding: 2rem 1rem; }
  .hero-bands { flex: 0 0 45%; min-height: 180px; }
  .hero-band img { min-height: 140px; }
}

@media (prefers-reduced-motion: reduce) {
  .signal-dot { animation: none; }
  .hero-marquee-track { animation: none; }
  .js .hero-marquee { display: none; }
  .js .hero-bands-static { display: grid; }
}

.section-title {
  font-size: clamp(1.75rem, 4vw, 2.5rem);
  margin-bottom: 1.25rem;
}

.manifesto-statement {
  font-family: var(--font-head);
  font-size: clamp(1.5rem, 3.5vw, 2.25rem);
  font-weight: 700;
  line-height: 1.25;
  max-width: 900px;
  margin-bottom: 1.5rem;
}

.flux-counter-strip {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
}

.stat-block {
  padding: 2.5rem 1.5rem;
  text-align: center;
  border-right: 1px solid rgba(13, 31, 23, 0.15);
}

.stat-block:last-child { border-right: none; }

.stat-number {
  font-family: var(--font-head);
  font-size: clamp(2.5rem, 6vw, 3.5rem);
  font-weight: 800;
  line-height: 1;
  display: block;
}

.stat-label {
  font-size: 0.95rem;
  font-weight: 500;
  margin-top: 0.5rem;
  display: block;
}

@media (max-width: 600px) {
  .flux-counter-strip { grid-template-columns: 1fr; }
  .stat-block { border-right: none; border-bottom: 1px solid rgba(13, 31, 23, 0.15); }
  .stat-block:last-child { border-bottom: none; }
}

.streams-scroll {
  display: flex;
  gap: 1.25rem;
  overflow-x: auto;
  padding-bottom: 1rem;
  scroll-snap-type: x mandatory;
}

.flux-panel {
  flex: 0 0 min(300px, 85vw);
  scroll-snap-align: start;
  border-bottom: 4px solid var(--amber);
  padding: 1.75rem;
  background: var(--bg-moss);
  color: var(--text-on-moss);
}

.flux-panel-toggle {
  font-family: var(--font-head);
  font-size: 1.25rem;
  font-weight: 700;
  cursor: pointer;
  list-style: none;
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  background: none;
  border: none;
  color: inherit;
  text-align: left;
}

.flux-panel-details {
  margin-top: 1rem;
  padding-top: 1rem;
  border-top: 1px solid rgba(250, 248, 245, 0.15);
}

.flux-panel-details ul { list-style: none; padding: 0; }

.flux-panel-details li {
  padding: 0.35rem 0 0.35rem 1rem;
  position: relative;
}

.flux-panel-details li::before {
  content: '→';
  position: absolute;
  left: 0;
  color: var(--amber);
}

.js .flux-panel-details { display: none; }
.js .flux-panel.is-open .flux-panel-details { display: block; }

.pipeline-split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 3rem;
  align-items: center;
}

.pipeline-svg { width: 100%; max-width: 480px; }

.pipeline-photo {
  position: relative;
  border: 4px solid var(--amber);
}

@media (max-width: 768px) {
  .pipeline-split { grid-template-columns: 1fr; }
}

.integration-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
}

.integration-cell {
  padding: 2rem 1.5rem;
  border-bottom: 4px solid var(--amber);
  border-right: 1px solid rgba(13, 31, 23, 0.08);
  transition: background 0.25s, color 0.25s;
}

.integration-cell:nth-child(3n) { border-right: none; }

.integration-cell h3 { font-size: 1.1rem; margin-bottom: 0.5rem; }
.integration-cell p { font-size: 0.9rem; }

.integration-cell:hover {
  background: var(--bg-dark);
  color: var(--text-on-dark);
}

@media (max-width: 768px) {
  .integration-grid { grid-template-columns: repeat(2, 1fr); }
  .integration-cell:nth-child(3n) { border-right: 1px solid rgba(13, 31, 23, 0.08); }
  .integration-cell:nth-child(2n) { border-right: none; }
}

@media (max-width: 480px) {
  .integration-grid { grid-template-columns: 1fr; }
  .integration-cell { border-right: none; }
}

.card {
  border-radius: 0;
  border-bottom: 4px solid var(--amber);
  padding: 2rem;
  transition: transform 0.2s;
}

.card:hover { transform: translateY(-3px); }

.card-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 1.5rem;
}

.card img {
  width: 100%;
  aspect-ratio: 16/10;
  object-fit: cover;
  margin-bottom: 1.25rem;
}

.card h3 { font-size: 1.25rem; margin-bottom: 0.75rem; }

.price-tier {
  font-family: var(--font-head);
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--amber-light);
  margin-top: 1rem;
}

.program-code {
  font-size: 0.8rem;
  letter-spacing: 0.1em;
  color: var(--amber-light);
  font-weight: 600;
}

.faq-accordion { max-width: 800px; }

.faq-item { border-bottom: 1px solid rgba(250, 248, 245, 0.15); }

.faq-question {
  width: 100%;
  background: none;
  border: none;
  color: inherit;
  font-family: var(--font-head);
  font-size: 1.1rem;
  font-weight: 600;
  text-align: left;
  padding: 1.25rem 0;
  cursor: pointer;
  display: flex;
  align-items: flex-start;
  gap: 1rem;
  min-height: 48px;
}

.faq-num {
  flex-shrink: 0;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: var(--amber);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.9rem;
  font-weight: 800;
}

.surface-light .faq-num,
.surface-dark .faq-num {
  color: #fff;
  font-weight: 800;
}

.faq-answer { padding: 0 0 1.25rem 3.25rem; }

.js .faq-item:not(.is-open) .faq-answer { display: none; }

.faq-toggle-icon {
  margin-left: auto;
  font-size: 1.25rem;
  color: var(--amber);
}

.cta-band { text-align: center; padding: 4rem 1rem; }

.cta-band h2 {
  font-size: clamp(1.75rem, 4vw, 2.5rem);
  margin-bottom: 1rem;
}

.cta-band p {
  max-width: 560px;
  margin: 0 auto 1.75rem;
}

.disclaimer {
  font-size: 0.85rem;
  line-height: 1.6;
  padding: 1.25rem;
  border-left: 3px solid var(--amber);
  margin: 2rem 0;
  opacity: 0.9;
}

.site-footer { padding-top: 3rem; }

.footer-slash {
  width: 100%;
  height: 24px;
  margin-bottom: 0;
}

.footer-cols {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 3rem;
  padding: 3rem 0;
}

.footer-brand p { margin: 0.75rem 0; font-size: 0.95rem; }

.footer-links {
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem 1.25rem;
  margin-top: 1rem;
}

.footer-links a { text-decoration: none; font-size: 0.9rem; }
.footer-links a:hover { color: var(--amber); }

.footer-programmes h4 {
  font-size: 0.8rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--amber);
  margin-bottom: 0.75rem;
}

.contact-ribbon {
  padding: 1.5rem 0;
  border-top: 1px solid rgba(250, 248, 245, 0.15);
  font-size: 0.9rem;
  line-height: 1.7;
  text-align: center;
}

.footer-bottom {
  padding: 1.5rem 0 2rem;
  font-size: 0.8rem;
  opacity: 0.85;
  text-align: center;
}

@media (max-width: 768px) {
  .footer-cols { grid-template-columns: 1fr; gap: 2rem; }
}

.page-hero {
  padding: calc(var(--header-h) + 3rem) 0 3rem;
}

.page-hero h1 {
  font-size: clamp(2rem, 4.5vw, 3rem);
  margin: 0.75rem 0;
}

.about-split {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: 3rem;
  align-items: start;
}

.metric-mosaic {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1rem;
}

.metric-tile {
  padding: 1.5rem;
  border-bottom: 4px solid var(--amber);
  text-align: center;
}

.metric-tile .num {
  font-family: var(--font-head);
  font-size: 2rem;
  font-weight: 800;
  display: block;
}

.about-portrait img {
  width: 100%;
  aspect-ratio: 3/4;
  object-fit: cover;
  border: 4px solid var(--amber);
}

@media (max-width: 900px) {
  .about-split { grid-template-columns: 1fr; }
}

.contact-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 3rem;
}

.contact-info-block address {
  font-style: normal;
  line-height: 1.8;
  margin: 1rem 0;
}

.contact-photo img {
  width: 100%;
  aspect-ratio: 4/3;
  object-fit: cover;
  border-bottom: 4px solid var(--amber);
}

.contact-form label {
  display: block;
  font-weight: 500;
  margin-bottom: 0.35rem;
  font-size: 0.9rem;
}

.contact-form input,
.contact-form select,
.contact-form textarea {
  width: 100%;
  padding: 0.75rem;
  border: 2px solid rgba(13, 31, 23, 0.2);
  border-radius: 0;
  font-family: var(--font-body);
  font-size: 1rem;
  margin-bottom: 1.25rem;
  background: var(--bg-light);
  color: var(--text-on-light);
}

.contact-form input:focus,
.contact-form select:focus,
.contact-form textarea:focus {
  outline: 2px solid var(--amber);
  outline-offset: 2px;
}

.hp-field {
  position: absolute;
  left: -9999px;
  width: 1px;
  height: 1px;
  overflow: hidden;
}

.consent-label {
  display: flex;
  align-items: flex-start;
  gap: 0.65rem;
  font-size: 0.9rem;
  margin-bottom: 1.5rem;
}

.consent-label input { width: auto; margin-top: 0.2rem; }

.form-success {
  padding: 1rem 1.25rem;
  background: rgba(34, 197, 94, 0.15);
  border-left: 4px solid #22c55e;
  margin-bottom: 1.5rem;
}

.legal-content h2 { font-size: 1.35rem; margin: 2rem 0 0.75rem; }
.legal-content h3 { font-size: 1.1rem; margin: 1.5rem 0 0.5rem; }
.legal-content p, .legal-content li { margin-bottom: 0.85rem; }
.legal-content ul { margin: 0.5rem 0 1rem 1.5rem; }

.legal-meta {
  font-size: 0.9rem;
  opacity: 0.85;
  margin-bottom: 2rem;
}

.legal-hub-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 1.5rem;
  margin-top: 2rem;
}

.legal-hub-card {
  display: block;
  text-decoration: none;
  color: inherit;
  padding: 2rem;
  border-bottom: 4px solid var(--amber);
  transition: transform 0.2s;
}

.legal-hub-card:hover { transform: translateY(-3px); }
.legal-hub-card h2 { font-size: 1.25rem; margin-bottom: 0.5rem; }

.faq-with-image {
  display: grid;
  grid-template-columns: 1fr 380px;
  gap: 3rem;
  align-items: start;
}

.faq-side-image img {
  width: 100%;
  aspect-ratio: 4/5;
  object-fit: cover;
  border-bottom: 4px solid var(--amber);
}

@media (max-width: 900px) {
  .faq-with-image { grid-template-columns: 1fr; }
  .contact-layout { grid-template-columns: 1fr; }
}

.error-page {
  min-height: 70vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 4rem 1rem;
  margin-top: var(--header-h);
}

.error-page h1 { font-size: clamp(1.75rem, 4vw, 2.5rem); margin-bottom: 1rem; }

.cookie-banner {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 10000;
  background: var(--bg-dark);
  color: var(--text-on-dark);
  padding: 1.25rem;
  border-top: 3px solid var(--amber);
  box-shadow: 0 -4px 24px rgba(0,0,0,0.3);
}

.cookie-inner {
  max-width: var(--max-width);
  margin: 0 auto;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}

.cookie-inner p { font-size: 0.9rem; max-width: 600px; }

.cookie-actions { display: flex; flex-wrap: wrap; gap: 0.5rem; }

.cookie-btn {
  padding: 0.55rem 1.1rem;
  border: 2px solid var(--amber);
  background: transparent;
  color: var(--text-on-dark);
  font-family: var(--font-body);
  font-weight: 600;
  font-size: 0.85rem;
  cursor: pointer;
  min-height: 44px;
  border-radius: 0;
}

.cookie-btn-accept {
  background: var(--amber);
  color: var(--text-on-accent);
}

.cookie-customise-panel {
  width: 100%;
  margin-top: 1rem;
  padding-top: 1rem;
  border-top: 1px solid rgba(250,248,245,0.15);
}

.cookie-customise-panel label {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin: 0.5rem 0;
  font-size: 0.9rem;
}

.js .cookie-banner.is-hidden { display: none; }

.js .reveal {
  opacity: 0;
  transform: translateY(16px);
  transition: opacity 0.5s ease, transform 0.5s ease;
}

.js .reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.service-list { list-style: none; }

.service-item {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2rem;
  align-items: center;
  padding: 2.5rem 0;
  border-bottom: 1px solid rgba(13, 31, 23, 0.1);
}

.service-item:nth-child(even) .service-text { order: 2; }
.service-item:nth-child(even) .service-img { order: 1; }

.service-img img {
  width: 100%;
  aspect-ratio: 16/10;
  object-fit: cover;
  border-bottom: 4px solid var(--amber);
}

@media (max-width: 768px) {
  .service-item { grid-template-columns: 1fr; }
  .service-item:nth-child(even) .service-text,
  .service-item:nth-child(even) .service-img { order: unset; }
}

@media (prefers-reduced-motion: reduce) {
  .js .reveal { opacity: 1; transform: none; transition: none; }
  .menu-overlay { transition: none; }
  .marquee-track { animation: none; }
  body.menu-closing .menu-overlay { visibility: hidden; }
}

/* nf-* aliases (index + core pages) */
.nf-header, .site-header {
  position: fixed; top: 0; left: 0; right: 0; z-index: 1000;
  height: var(--header-h); background: var(--bg-dark); color: var(--text-on-dark);
  border-bottom: 1px solid rgba(245, 158, 11, 0.2);
}
.nf-header-inner, .header-inner {
  display: flex; align-items: center; justify-content: space-between;
  height: 100%; padding: 0 1rem; max-width: var(--max-width); margin: 0 auto;
}
.nf-logo, .logo-link {
  display: flex; align-items: center; gap: 0.65rem; text-decoration: none; color: inherit;
  font-family: var(--font-head); font-weight: 700; font-size: 1.25rem;
}
.nf-logo svg, .logo-hex { width: 36px; height: 36px; flex-shrink: 0; }

.hero-j { min-height: 100vh; display: flex; flex-direction: column; margin-top: var(--header-h); }
.hero-j-top { flex: 0 0 60%; display: flex; align-items: center; padding: 3rem 1rem; }
.hero-j-content { max-width: 960px; margin: 0 auto; width: 100%; padding: 0 1rem; }
.hero-j-content h1 { font-size: clamp(1.35rem, 2.8vw, 1.85rem); font-weight: 700; line-height: 1.3; margin: 0.5rem 0 1rem; }
.hero-serial { font-size: 0.75rem; opacity: 0.75; margin-bottom: 0.5rem; }
.hero-sub { font-size: 1.125rem; max-width: 720px; margin-bottom: 1.75rem; }
.hero-ctas { display: flex; flex-wrap: wrap; gap: 1rem; margin-bottom: 1.5rem; }
.hero-j-bands { flex: 0 0 40%; overflow: hidden; min-height: 280px; }
.marquee-viewport { overflow: hidden; width: 100%; height: 100%; }
.marquee-track { display: flex; width: 200%; animation: hero-marquee-pair 20s linear infinite; height: 100%; }
.marquee-track .photo-band { flex: 0 0 12.5%; min-width: 0; }
.photo-band { position: relative; overflow: hidden; }
.photo-band img { width: 100%; height: 100%; object-fit: cover; min-height: 200px; }
.band-label {
  position: absolute; bottom: 0; left: 0; right: 0;
  background: rgba(13, 31, 23, 0.85); padding: 0.5rem 0.75rem;
  font-size: 0.75rem; font-weight: 600; letter-spacing: 0.1em;
  border-top: 3px solid var(--amber);
}
.btn-flux, .btn-cta-primary {
  display: inline-block; background: var(--amber); color: var(--text-on-accent);
  font-weight: 600; padding: 14px 28px; border-radius: 0; text-decoration: none;
  border: 2px solid var(--amber); min-height: 48px;
}
.btn-flux-outline, .btn-cta-secondary {
  display: inline-block; background: transparent; color: var(--text-on-dark);
  font-weight: 600; padding: 14px 28px; border-radius: 0; text-decoration: none;
  border: 2px solid var(--amber); min-height: 48px;
}
.manifesto { font-family: var(--font-head); font-size: clamp(1.5rem, 3.5vw, 2.25rem); font-weight: 700; line-height: 1.25; max-width: 900px; }
.flux-stats { display: grid; grid-template-columns: repeat(3, 1fr); text-align: center; }
.flux-stat-num { font-family: var(--font-head); font-size: clamp(2.5rem, 6vw, 3.5rem); font-weight: 800; }
.nf-card { flex: 0 0 min(280px, 85vw); border-bottom: 4px solid var(--amber); padding: 1.75rem; background: var(--bg-moss); color: var(--text-on-moss); }
.streams-scroll { display: flex; gap: 1.25rem; overflow-x: auto; padding-bottom: 1rem; }
.flux-panels { max-width: 800px; }
.flux-panel-trigger, .flux-panel-toggle {
  width: 100%; background: none; border: none; color: inherit;
  font-family: var(--font-head); font-size: 1.1rem; font-weight: 700;
  text-align: left; padding: 1rem 0; cursor: pointer; display: flex; justify-content: space-between;
}
.flux-panel-body, .flux-panel-details { padding: 0 0 1rem 1rem; }
.flux-panel-body ul, .flux-panel-details ul { list-style: none; }
.flux-panel-body li::before, .flux-panel-details li::before { content: '→ '; color: var(--amber); }
.js .flux-panel:not(.is-open) .flux-panel-body,
.js .flux-panel:not(.is-open) .flux-panel-details { display: none; }
.arch-split, .pipeline-split { display: grid; grid-template-columns: 1fr 1fr; gap: 3rem; align-items: center; }
.arch-frame img { width: 100%; border: 4px solid var(--amber); }
.int-grid, .integration-grid { display: grid; grid-template-columns: repeat(3, 1fr); }
.int-cell, .integration-cell { padding: 2rem 1.5rem; border-bottom: 4px solid var(--amber); font-weight: 600; }
.faq-acc-item, .faq-item { border-bottom: 1px solid rgba(250, 248, 245, 0.15); }
.faq-acc-trigger, .faq-question {
  width: 100%; background: none; border: none; color: inherit;
  font-family: var(--font-head); font-size: 1.1rem; font-weight: 600;
  text-align: left; padding: 1.25rem 0; cursor: pointer;
  display: flex; align-items: flex-start; gap: 1rem; min-height: 48px;
}
.faq-acc-body, .faq-answer { padding: 0 0 1.25rem 3.25rem; }
.js .faq-acc-item:not(.is-open) .faq-acc-body,
.js .faq-item:not(.is-open) .faq-answer { display: none; }
.overlay-nav, .menu-overlay-nav { list-style: none; text-align: center; }
.overlay-nav a, .menu-overlay-nav a {
  font-family: var(--font-head); font-size: clamp(1.75rem, 5vw, 3rem);
  font-weight: 700; text-decoration: none; display: block; padding: 0.35rem 1rem;
}
.overlay-tags, .menu-tags { margin-top: 2rem; display: flex; flex-wrap: wrap; gap: 0.75rem; justify-content: center; }
.overlay-tags span, .menu-tags span { font-size: 0.8rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--amber); }
.nf-footer, .site-footer { padding-top: 3rem; }
.page-hero { padding: calc(var(--header-h) + 3rem) 0 3rem; }
.page-hero h1 { font-size: clamp(2rem, 4.5vw, 3rem); margin: 0.75rem 0; }
.prog-row { display: grid; grid-template-columns: 1fr 1.2fr; gap: 2rem; margin-bottom: 3rem; align-items: start; }
.prog-row img { width: 100%; border-bottom: 4px solid var(--amber); }
.prog-price { font-family: var(--font-head); font-size: 1.35rem; font-weight: 700; margin-top: 1rem; }
.form-group { margin-bottom: 1.25rem; }
.form-group label { display: block; font-weight: 500; margin-bottom: 0.35rem; }
.form-group input, .form-group select, .form-group textarea {
  width: 100%; padding: 0.75rem; border: 2px solid rgba(13, 31, 23, 0.2); border-radius: 0;
  font-family: var(--font-body); background: var(--bg-light); color: var(--text-on-light);
}
.form-group.consent { display: flex; align-items: flex-start; gap: 0.65rem; }
.form-group.consent input { width: auto; margin-top: 0.2rem; }
.hp { position: absolute; left: -9999px; width: 1px; height: 1px; overflow: hidden; }
.disclaimer { font-size: 0.85rem; line-height: 1.6; padding: 1.25rem; border-left: 3px solid var(--amber); margin: 2rem 0; }
.cookie-btns, .cookie-actions { display: flex; flex-wrap: wrap; gap: 0.5rem; }
.btn-accept, .cookie-btn-accept { background: var(--amber); color: var(--text-on-accent); padding: 0.55rem 1.1rem; border: 2px solid var(--amber); cursor: pointer; min-height: 44px; font-weight: 600; }
.btn-reject, .btn-customise, .cookie-btn { padding: 0.55rem 1.1rem; border: 2px solid var(--amber); background: transparent; color: inherit; cursor: pointer; min-height: 44px; font-weight: 600; }
.cookie-banner.hidden { display: block; }
.js .cookie-banner.hidden { display: none; }
.js .cookie-banner:not(.hidden):not(.is-hidden) { display: block; }
@media (max-width: 768px) {
  .arch-split, .pipeline-split, .prog-row { grid-template-columns: 1fr; }
  .flux-stats, .int-grid, .integration-grid { grid-template-columns: 1fr; }
  .marquee-track .photo-band { flex: 0 0 25%; }
  .hero-j { min-height: 82vh; }
}
