/* ============================================================
   ORION'S GALACTIC LIFE — "Industrial Salvage" landing
   Warm charcoal asphalt, brushed steel panels, riveted edges,
   ember-orange signal accents pulled from the cataclysm fire.
   Engineering stencil display + terminal mono labels.
   No neon. No glassmorphism. No purple/cyan AI gradients.
   ============================================================ */

:root {
  --asphalt:   #14110d;   /* warm near-black */
  --asphalt-2: #1b1712;
  --steel:     #241f19;   /* panel face */
  --steel-2:   #2c2620;
  --line:      #3a322a;   /* hairline rules */
  --line-2:    #4a4036;
  --ash:       #e4dccb;   /* bone text */
  --ash-2:     #c3b9a4;
  --ash-dim:   #8c8271;   /* muted metadata */
  --ember:     #ff6a1a;   /* primary signal */
  --ember-2:   #ff8a3d;
  --ember-deep:#cf3f12;
  --amber:     #f2b134;   /* warning secondary */
  --rust:      #8f3a1f;

  --display: 'Saira Condensed', 'Arial Narrow', sans-serif;
  --body:    'Saira', system-ui, sans-serif;
  --mono:    'IBM Plex Mono', ui-monospace, monospace;
  --gut:     clamp(20px, 5vw, 88px);
  --maxw:    1280px;

  --hazard: repeating-linear-gradient(-45deg,
              var(--ember) 0 14px, #1a1610 14px 28px);
}

* { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }

body {
  margin: 0;
  background: var(--asphalt);
  color: var(--ash);
  font-family: var(--body);
  font-size: 18px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
  background-image:
    radial-gradient(120% 70% at 50% -10%, #221b14 0%, var(--asphalt) 60%);
}

img { display: block; max-width: 100%; }
a { color: var(--ash); text-decoration: none; }
em { font-style: italic; color: var(--ash-2); }
strong { font-weight: 700; color: #fff; }
h1, h2, h3 { margin: 0; }

.skip { position: absolute; left: -9999px; }
.skip:focus { left: 12px; top: 12px; background: var(--ember); color: #000; padding: 8px 14px; z-index: 200; }

/* ---------- Texture overlays ---------- */
.fx-grain {
  position: fixed; inset: 0; z-index: 1; pointer-events: none;
  opacity: .05; mix-blend-mode: overlay;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
.fx-scan {
  position: fixed; inset: 0; z-index: 2; pointer-events: none;
  opacity: .35;
  background: repeating-linear-gradient(to bottom,
    rgba(0,0,0,0) 0 2px, rgba(0,0,0,.18) 2px 3px);
}

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--display);
  font-weight: 800;
  letter-spacing: .05em;
  text-transform: uppercase;
  cursor: pointer;
  transition: transform .14s ease, background .18s, color .18s, box-shadow .18s;
}
.btn .arr { transition: transform .18s ease; }
.btn:hover .arr { transform: translateX(4px); }

.btn-ember {
  background: var(--ember);
  color: #160d05;
  font-size: 1.02rem;
  padding: 15px 26px;
  border: 0;
  clip-path: polygon(0 0, 100% 0, 100% calc(100% - 10px), calc(100% - 10px) 100%, 0 100%);
  box-shadow: 0 0 0 1px var(--ember-deep) inset, 0 14px 40px -16px rgba(255,106,26,.8);
}
.btn-ember:hover { background: var(--ember-2); transform: translateY(-2px); }
.btn-ember.big { font-size: 1.25rem; padding: 20px 36px; }

.btn-ghost {
  background: transparent;
  color: var(--ash);
  font-size: 1rem;
  padding: 14px 24px;
  border: 1px solid var(--line-2);
}
.btn-ghost:hover { border-color: var(--ember); color: var(--ember); }

.btn-play {
  background: var(--ember);
  color: #160d05;
  font-size: .82rem;
  padding: 10px 18px;
  clip-path: polygon(0 0, 100% 0, 100% calc(100% - 7px), calc(100% - 7px) 100%, 0 100%);
}
.btn-play:hover { background: var(--ember-2); }

/* ---------- Nav ---------- */
.nav {
  position: sticky; top: 0; z-index: 60;
  display: flex; align-items: center; justify-content: space-between;
  gap: 18px;
  padding: 12px var(--gut);
  background: rgba(20,17,13,.82);
  -webkit-backdrop-filter: blur(8px);
  backdrop-filter: blur(8px);
  border-bottom: 1px solid var(--line);
}
.nav-brand img { height: 40px; width: auto; filter: drop-shadow(0 2px 8px rgba(0,0,0,.6)); }
.nav-links {
  display: flex; gap: 30px; margin-left: auto; margin-right: 10px;
  font-family: var(--mono);
  font-size: .76rem; letter-spacing: .08em; text-transform: uppercase;
}
.nav-links a { color: var(--ash-2); position: relative; padding: 4px 0; }
.nav-links a::after {
  content: ""; position: absolute; left: 0; bottom: -2px; width: 0; height: 2px;
  background: var(--ember); transition: width .2s ease;
}
.nav-links a:hover { color: var(--ash); }
.nav-links a:hover::after { width: 100%; }
.nav-actions { display: flex; align-items: center; gap: 14px; }
.nav-toggle { display: none; background: none; border: 0; width: 34px; height: 26px; padding: 0; cursor: pointer; }
.nav-toggle span { display: block; height: 2px; background: var(--ash); margin: 5px 0; transition: .25s; }

/* ---------- Floating play ---------- */
.floating-play {
  position: fixed; right: 22px; bottom: 22px; z-index: 70;
  display: inline-flex; align-items: center; gap: 10px;
  background: var(--ember); color: #160d05;
  font-family: var(--display); font-weight: 800; font-size: 1rem;
  letter-spacing: .04em; text-transform: uppercase;
  padding: 15px 22px;
  clip-path: polygon(0 0, 100% 0, 100% calc(100% - 10px), calc(100% - 10px) 100%, 0 100%);
  box-shadow: 0 16px 44px -14px rgba(255,106,26,.85);
  transition: transform .15s, background .15s;
}
.floating-play:hover { color: #160d05; background: var(--ember-2); transform: translateY(-3px); }
.fp-tri { font-size: .78rem; }

/* ---------- Corner brackets ---------- */
.corner { position: absolute; width: 30px; height: 30px; z-index: 5; pointer-events: none; }
.corner.tl { top: 18px; left: 18px; border-top: 2px solid var(--ember); border-left: 2px solid var(--ember); }
.corner.tr { top: 18px; right: 18px; border-top: 2px solid var(--ember); border-right: 2px solid var(--ember); }
.corner.bl { bottom: 18px; left: 18px; border-bottom: 2px solid var(--ember); border-left: 2px solid var(--ember); }
.corner.br { bottom: 18px; right: 18px; border-bottom: 2px solid var(--ember); border-right: 2px solid var(--ember); }

/* ---------- Hero ---------- */
.hero {
  position: relative;
  min-height: 92vh;
  display: flex; align-items: center;
  padding: clamp(40px, 9vw, 120px) var(--gut);
  overflow: hidden;
  border-bottom: 1px solid var(--line);
}
.hero-bg {
  position: absolute; inset: 0; z-index: 0;
  background: url("assets/images/lead_flame.jpg") center 38% / cover no-repeat;
  transform: scale(1.06);
  animation: heroDrift 24s ease-in-out infinite alternate;
}
@keyframes heroDrift { from { transform: scale(1.06) translateY(0); } to { transform: scale(1.12) translateY(-2%); } }
.hero-vignette {
  position: absolute; inset: 0; z-index: 1;
  background:
    linear-gradient(to top, var(--asphalt) 2%, rgba(20,17,13,.55) 38%, rgba(20,17,13,.35) 70%, rgba(20,17,13,.6) 100%),
    linear-gradient(105deg, rgba(20,17,13,.92) 0%, rgba(20,17,13,.45) 45%, rgba(20,17,13,.1) 75%);
}
.hero-inner { position: relative; z-index: 6; max-width: 880px; width: 100%; }

.eyebrow {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--mono); font-size: .78rem; letter-spacing: .16em;
  color: var(--amber); text-transform: uppercase;
  margin: 0 0 22px;
}
.blip { width: 9px; height: 9px; background: var(--ember); border-radius: 50%; box-shadow: 0 0 12px var(--ember); animation: blink 1.4s steps(2) infinite; }
@keyframes blink { 50% { opacity: .25; } }

.hero-title {
  font-family: var(--display);
  font-weight: 900;
  font-size: clamp(3rem, 11vw, 8.5rem);
  line-height: 0.9;
  letter-spacing: -0.01em;
  text-transform: uppercase;
  text-shadow: 0 6px 30px rgba(0,0,0,.7);
}
.hero-title span { display: block; }
.hero-title .ember { color: var(--ember); text-shadow: 0 0 40px rgba(255,106,26,.45); }

.hero-sub {
  font-size: clamp(1.05rem, 1.9vw, 1.4rem);
  line-height: 1.55;
  color: var(--ash-2);
  max-width: 46ch;
  margin: 26px 0 0;
}
.hero-cta { display: flex; flex-wrap: wrap; gap: 16px; margin-top: 34px; }
.hero-specs {
  list-style: none; display: flex; flex-wrap: wrap; gap: 10px 26px;
  margin: 34px 0 0; padding: 18px 0 0;
  border-top: 1px solid var(--line-2);
  font-family: var(--mono); font-size: .72rem; letter-spacing: .1em;
  color: var(--ash-dim); text-transform: uppercase;
}
.hero-specs li { position: relative; padding-left: 18px; }
.hero-specs li::before { content: "▸"; position: absolute; left: 0; color: var(--ember); }

.scroll-cue {
  position: absolute; left: 50%; bottom: 22px; transform: translateX(-50%); z-index: 6;
  display: flex; flex-direction: column; align-items: center; gap: 8px;
  font-family: var(--mono); font-size: .64rem; letter-spacing: .25em; color: var(--ash-dim);
}
.scroll-line { width: 1px; height: 40px; background: linear-gradient(var(--ember), transparent); animation: cue 1.8s ease-in-out infinite; }
@keyframes cue { 0%,100% { transform: scaleY(.4); opacity: .4; transform-origin: top; } 50% { transform: scaleY(1); opacity: 1; transform-origin: top; } }

/* rise-in load animation */
.rise { opacity: 0; transform: translateY(26px); animation: rise .8s cubic-bezier(.2,.7,.2,1) forwards; animation-delay: var(--d, 0ms); }
@keyframes rise { to { opacity: 1; transform: none; } }

/* ---------- Ticker ---------- */
.ticker {
  background: var(--ember);
  color: #160d05;
  overflow: hidden;
  border-bottom: 3px solid var(--asphalt);
  padding: 9px 0;
}
.ticker-track {
  display: inline-flex; align-items: center; gap: 22px;
  white-space: nowrap;
  font-family: var(--display); font-weight: 800; font-size: .92rem;
  letter-spacing: .08em; text-transform: uppercase;
  animation: marquee 26s linear infinite;
}
.ticker-track .sep { opacity: .5; }
@keyframes marquee { from { transform: translateX(0); } to { transform: translateX(-50%); } }

/* ---------- Section primitives ---------- */
.sec-kicker {
  font-family: var(--mono); font-size: .76rem; letter-spacing: .18em;
  text-transform: uppercase; color: var(--ash-dim);
  margin: 0 0 18px; display: flex; align-items: center; gap: 10px;
}
.sec-kicker .num {
  color: var(--ember); font-weight: 600;
  border: 1px solid var(--ember); padding: 1px 7px;
}
.sec-title {
  font-family: var(--display); font-weight: 800;
  font-size: clamp(2.1rem, 5vw, 4rem);
  line-height: 0.96; letter-spacing: -0.01em; text-transform: uppercase;
}
.sec-title .ember { color: var(--ember); }
.sec-head { max-width: var(--maxw); margin: 0 auto; padding: 0 0 clamp(28px,4vw,48px); }

/* ---------- The World ---------- */
.world {
  max-width: var(--maxw); margin: 0 auto;
  padding: clamp(60px, 9vw, 120px) var(--gut);
  display: grid; grid-template-columns: 1.05fr .95fr; gap: clamp(28px, 5vw, 72px);
  align-items: center;
}
.world-media { position: relative; }
.world-media img {
  width: 100%; aspect-ratio: 16/10; object-fit: cover;
  border: 1px solid var(--line-2);
  box-shadow: 0 30px 80px -30px #000, 0 0 0 6px var(--asphalt-2);
}
.media-tag {
  position: absolute; left: 14px; bottom: 14px;
  font-family: var(--mono); font-size: .66rem; letter-spacing: .14em;
  background: var(--asphalt); color: var(--ember);
  border: 1px solid var(--line-2); padding: 5px 10px;
}
.world-copy p { color: var(--ash-2); margin: 0 0 1.1em; }
.world-copy .sec-title { margin-bottom: .5em; }

/* ---------- Features ---------- */
.features { padding: clamp(40px, 7vw, 90px) var(--gut); border-top: 1px solid var(--line); }
.feature-grid {
  max-width: var(--maxw); margin: 0 auto;
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px;
  background: var(--line);
  border: 1px solid var(--line);
}
.feat {
  position: relative;
  background: var(--steel);
  padding: 34px 26px 30px;
  transition: background .2s, transform .2s;
}
.feat::before {
  content: ""; position: absolute; left: 0; top: 0; width: 100%; height: 3px;
  background: var(--ember); transform: scaleX(0); transform-origin: left; transition: transform .25s ease;
}
.feat:hover { background: var(--steel-2); }
.feat:hover::before { transform: scaleX(1); }
.feat-no {
  font-family: var(--mono); font-size: .72rem; letter-spacing: .12em;
  color: var(--ember); display: block; margin-bottom: 18px;
}
.feat h3 {
  font-family: var(--display); font-weight: 700; font-size: 1.45rem;
  text-transform: uppercase; letter-spacing: .01em; line-height: 1.05; margin-bottom: 12px;
}
.feat p { font-size: .98rem; color: var(--ash-dim); margin: 0; }

/* ---------- Crafting chain ---------- */
.chain-strip {
  max-width: var(--maxw); margin: 0 auto;
  display: flex; align-items: center; gap: 22px; flex-wrap: wrap;
  padding: clamp(24px,3vw,34px) var(--gut);
  border-top: 1px solid var(--line); border-bottom: 1px solid var(--line);
}
.chain-lbl {
  font-family: var(--mono); font-size: .72rem; letter-spacing: .16em;
  color: var(--ash-dim); text-transform: uppercase;
}
.chain { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.chain .node {
  font-family: var(--display); font-weight: 800; font-size: clamp(.95rem,2vw,1.4rem);
  text-transform: uppercase; letter-spacing: .03em;
  border: 1px solid var(--line-2); padding: 6px 14px;
}
.chain .arrow { color: var(--ember); font-size: 1rem; }
.chain .node-loop { border-color: var(--ember); color: var(--ember); }

/* ---------- Oracle ---------- */
.oracle {
  max-width: var(--maxw); margin: 0 auto;
  padding: clamp(60px, 9vw, 120px) var(--gut);
  display: grid; grid-template-columns: 1fr 1.05fr; gap: clamp(28px,5vw,72px);
  align-items: center;
}
.oracle-copy p { color: var(--ash-2); margin: 0 0 1.1em; }
.oracle-copy .sec-title { margin-bottom: .5em; }
.quote {
  margin: 28px 0 0; padding: 22px 26px;
  border-left: 3px solid var(--ember);
  background: var(--asphalt-2);
  font-family: var(--display); font-weight: 600; font-size: 1.5rem;
  line-height: 1.15; color: var(--ash);
}
.quote cite {
  display: block; margin-top: 14px;
  font-family: var(--mono); font-style: normal; font-size: .72rem;
  letter-spacing: .08em; text-transform: uppercase; color: var(--ash-dim);
}
.oracle-media { position: relative; }
.embed-frame {
  position: relative; aspect-ratio: 16/9; overflow: hidden; background: #000;
  border: 1px solid var(--line-2);
  box-shadow: 0 30px 80px -30px #000;
}
.embed-frame iframe { width: 100%; height: 100%; border: 0; display: block; }
.oracle-still {
  position: absolute; right: -10px; bottom: -34px; width: 38%;
  border: 1px solid var(--line-2);
  box-shadow: 0 20px 50px -18px #000;
}

/* ---------- Gallery ---------- */
.gallery { padding: clamp(40px, 7vw, 90px) var(--gut); border-top: 1px solid var(--line); }
.shots {
  max-width: var(--maxw); margin: 0 auto;
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px;
}
.shot { margin: 0; position: relative; grid-column: span 2; }
.shot.shot-wide { grid-column: span 4; }
.shot.shot-wide img { aspect-ratio: 21/9; }
.shot img {
  width: 100%; aspect-ratio: 16/9; object-fit: cover;
  border: 1px solid var(--line-2); cursor: zoom-in;
  transition: border-color .2s, transform .25s;
}
.shot:hover img { border-color: var(--ember); }
.shot figcaption {
  font-family: var(--mono); font-size: .72rem; color: var(--ash-dim);
  margin-top: 10px; padding-left: 12px; border-left: 2px solid var(--ember);
}

/* ---------- Seasons timeline ---------- */
.seasons { padding: clamp(40px, 7vw, 90px) var(--gut); border-top: 1px solid var(--line); }
.timeline {
  max-width: var(--maxw); margin: 0 auto; padding: 0; list-style: none;
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px;
  background: var(--line); border: 1px solid var(--line);
}
.timeline li { background: var(--steel); padding: 32px 26px; position: relative; }
.tl-no {
  font-family: var(--display); font-weight: 900; font-size: 3.4rem; line-height: 1;
  color: transparent; -webkit-text-stroke: 1px var(--line-2);
  display: block; margin-bottom: 14px;
}
.timeline li h3 {
  font-family: var(--display); font-weight: 700; font-size: 1.5rem;
  text-transform: uppercase; margin-bottom: 10px;
}
.timeline li p { font-size: .96rem; color: var(--ash-dim); margin: 0 0 18px; }
.tl-status {
  font-family: var(--mono); font-size: .7rem; letter-spacing: .12em;
  color: var(--ash-dim); border: 1px solid var(--line-2); padding: 4px 10px; display: inline-block;
}
.tl-status.live { color: var(--ember); border-color: var(--ember); animation: blink 1.6s steps(2) infinite; }

/* ---------- Final CTA ---------- */
.cta {
  position: relative; margin: clamp(40px,6vw,80px) var(--gut) 0;
  padding: clamp(54px, 9vw, 120px) clamp(24px,5vw,80px);
  text-align: center;
  background:
    linear-gradient(rgba(20,17,13,.6), rgba(20,17,13,.78)),
    url("assets/images/lead_flame.jpg") center 30% / cover no-repeat;
  border: 1px solid var(--line-2);
  overflow: hidden;
}
.cta::after {
  content: ""; position: absolute; left: 0; right: 0; bottom: 0; height: 8px;
  background: var(--hazard); opacity: .9;
}
.cta-inner { position: relative; z-index: 2; max-width: 760px; margin: 0 auto; }
.cta-label { font-family: var(--mono); font-size: .8rem; letter-spacing: .16em; color: var(--amber); margin: 0 0 18px; }
.cta-title {
  font-family: var(--display); font-weight: 900;
  font-size: clamp(2.4rem, 7vw, 5.4rem); line-height: 0.92;
  text-transform: uppercase; margin: 0 0 18px;
  text-shadow: 0 6px 30px rgba(0,0,0,.6);
}
.cta-meta { font-family: var(--mono); font-size: .78rem; letter-spacing: .08em; color: var(--ash-2); margin: 0 0 30px; }
.cta-actions { display: flex; justify-content: center; }
.cta-second {
  display: inline-block; margin-top: 22px;
  font-family: var(--mono); font-size: .82rem; color: var(--ash-2);
  border-bottom: 1px solid var(--line-2); padding-bottom: 3px;
}
.cta-second:hover { color: var(--ember); border-color: var(--ember); }

/* ---------- Footer ---------- */
.foot { padding: clamp(40px,5vw,64px) var(--gut); border-top: 1px solid var(--line); margin-top: clamp(40px,6vw,80px); }
.foot-row {
  max-width: var(--maxw); margin: 0 auto;
  display: flex; justify-content: space-between; align-items: baseline;
  font-family: var(--mono); font-size: .74rem; letter-spacing: .08em; color: var(--ash-dim);
  padding-bottom: 18px; margin-bottom: 18px; border-bottom: 1px solid var(--line);
}
.foot-brand { font-family: var(--display); font-weight: 800; color: var(--ash); letter-spacing: .04em; font-size: 1rem; }
.foot-note { max-width: 78ch; color: var(--ash-dim); font-size: .9rem; line-height: 1.65; margin: 0 auto 12px; }
.foot-note, .foot-fine { max-width: var(--maxw); margin-left: auto; margin-right: auto; }
.foot-fine { font-family: var(--mono); font-size: .7rem; color: #5f574a; margin: 0 auto; }

/* ---------- Lightbox ---------- */
.lightbox {
  position: fixed; inset: 0; z-index: 150;
  background: rgba(8,6,4,.96);
  display: none; align-items: center; justify-content: center;
  padding: 40px; cursor: zoom-out;
}
.lightbox.open { display: flex; }
.lightbox img { max-width: 94vw; max-height: 90vh; border: 1px solid var(--ember); }

/* ---------- Scroll reveal ---------- */
.reveal { opacity: 0; transform: translateY(34px); transition: opacity .7s ease, transform .7s cubic-bezier(.2,.7,.2,1); }
.reveal.in { opacity: 1; transform: none; }

/* ---------- Responsive ---------- */
@media (max-width: 960px) {
  .world, .oracle { grid-template-columns: 1fr; }
  .feature-grid { grid-template-columns: repeat(2, 1fr); }
  .oracle-still { position: static; width: 55%; margin-top: 16px; }
}
@media (max-width: 760px) {
  .nav-links {
    position: fixed; inset: 56px 0 auto 0; flex-direction: column; gap: 0;
    background: var(--asphalt-2); border-bottom: 1px solid var(--line);
    padding: 0; max-height: 0; overflow: hidden; transition: max-height .3s ease; margin: 0;
  }
  .nav-links.open { max-height: 320px; }
  .nav-links a { padding: 16px var(--gut); border-bottom: 1px solid var(--line); font-size: .9rem; }
  .nav-toggle { display: block; }
  .timeline { grid-template-columns: 1fr; }
  .shots { grid-template-columns: 1fr; }
  .shot, .shot.shot-wide { grid-column: span 1; }
  .floating-play { right: 0; left: 0; bottom: 0; justify-content: center; clip-path: none; padding: 16px; border-radius: 0; }
  body { padding-bottom: 56px; }
}
@media (max-width: 480px) {
  body { font-size: 17px; }
  .feature-grid { grid-template-columns: 1fr; }
  .hero-specs { gap: 8px 18px; }
  .btn-ghost { display: none; }
}

@media (prefers-reduced-motion: reduce) {
  * { scroll-behavior: auto !important; animation: none !important; transition: none !important; }
  .reveal { opacity: 1; transform: none; }
  .rise { opacity: 1; transform: none; }
}
