/* ══════════════════════════════════════════════════════════
   LiminalX — Main Stylesheet
   ══════════════════════════════════════════════════════════ */

/* ── TOKENS ──────────────────────────────────────────────── */
:root {
  --ice:    #e6f5f8;
  --teal:   #7ae5eb;
  --blue:   #204ccf;
  --bg:     #030b14;
  --mid:    #0a1628;
  --dim:    #1a2e50;
  --dim2:   #0d1e36;
  --locked: #081120;

  --font-display: 'Orbitron', sans-serif;
  --font-ui:      'Rajdhani', sans-serif;
  --font-serif:   'DM Serif Display', Georgia, serif;
  --font-mono:    'Space Mono', monospace;

  --nav-h: 64px;
  --max-w: 1160px;
  --radius: 12px;
}

/* ── RESET ───────────────────────────────────────────────── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; font-size:16px; }
body {
  background: var(--bg);
  color: var(--ice);
  font-family: var(--font-ui);
  line-height: 1.6;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}
a { color: inherit; text-decoration: none; }
img { display:block; max-width:100%; }

/* ── UTILITIES ───────────────────────────────────────────── */
.container { max-width: var(--max-w); margin:0 auto; padding:0 32px; }
.sr-only { position:absolute; width:1px; height:1px; overflow:hidden; clip:rect(0,0,0,0); }

.eyebrow {
  display: block;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.4em;
  color: var(--teal);
  opacity: 0.6;
  text-transform: uppercase;
  margin-bottom: 14px;
}

.rule {
  width: 48px; height: 1px;
  background: linear-gradient(90deg, var(--teal), transparent);
  margin: 18px 0;
}
.rule-c {
  background: linear-gradient(90deg, transparent, var(--teal), transparent);
  margin-left: auto; margin-right: auto;
}

.tag {
  display: inline-flex;
  align-items: center;
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  padding: 4px 10px;
  border-radius: 3px;
  background: #7ae5eb12;
  border: 1px solid #7ae5eb22;
  color: var(--teal);
}

.locked-el {
  opacity: 0.25;
  pointer-events: none;
  cursor: default;
  user-select: none;
}

/* ── PAGE BACKGROUND ─────────────────────────────────────── */
.page-bg {
  position: fixed; inset:0; z-index:0; pointer-events:none;
  background:
    radial-gradient(ellipse at 65% 30%, #204ccf18 0%, transparent 55%),
    radial-gradient(ellipse at 15% 70%, #7ae5eb0a 0%, transparent 50%),
    var(--bg);
}
.page-grid {
  position: fixed; inset:0; z-index:0; pointer-events:none;
  background:
    repeating-linear-gradient(90deg, transparent, transparent 79px, #7ae5eb06 79px, #7ae5eb06 80px),
    repeating-linear-gradient(0deg,  transparent, transparent 79px, #7ae5eb06 79px, #7ae5eb06 80px);
}
.page-content { position:relative; z-index:1; }

/* ── NAV ─────────────────────────────────────────────────── */
.site-nav {
  position: fixed; top:0; left:0; right:0; z-index:100;
  height: var(--nav-h);
  background: rgba(3,11,20,0.92);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-bottom: 1px solid #7ae5eb18;
  display: flex; align-items: center;
}

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

/* Logo */
.nav-logo {
  display: flex; align-items: center; gap: 10px;
  text-decoration: none; flex-shrink: 0;
}
.nav-wordmark {
  font-family: var(--font-display);
  font-size: 19px;
  font-weight: 700;
  letter-spacing: -0.5px;
  background: linear-gradient(135deg, var(--ice) 0%, var(--teal) 55%, var(--blue) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* Desktop menu */
.nav-menu {
  display: flex; align-items: center; gap: 4px;
  list-style: none;
  height: 100%;
}

.nav-item {
  position: relative;
  height: 100%;
  display: flex; align-items: center;
}

.nav-item > a,
.nav-item > button {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.18em;
  color: var(--ice);
  opacity: 0.5;
  text-transform: uppercase;
  padding: 0 14px;
  height: 100%;
  display: flex; align-items: center; gap: 5px;
  background: none; border: none; cursor: pointer;
  transition: opacity 0.2s;
  white-space: nowrap;
}
.nav-item > a:hover,
.nav-item > button:hover { opacity: 1; }
.nav-item > a.active    { opacity: 1; color: var(--teal); }

.nav-chevron {
  font-size: 8px;
  opacity: 0.5;
  transition: transform 0.2s;
}
.nav-item:hover .nav-chevron { transform: rotate(180deg); }

/* Dropdown */
.nav-dropdown {
  position: absolute;
  top: calc(100% + 1px);
  left: 50%;
  transform: translateX(-50%);
  min-width: 180px;
  background: rgba(10,22,40,0.97);
  backdrop-filter: blur(12px);
  border: 1px solid var(--dim);
  border-radius: 8px;
  overflow: hidden;
  opacity: 0;
  pointer-events: none;
  transform: translateX(-50%) translateY(-6px);
  transition: opacity 0.18s, transform 0.18s;
  z-index: 200;
}

.nav-item:hover .nav-dropdown,
.nav-item:focus-within .nav-dropdown {
  opacity: 1;
  pointer-events: auto;
  transform: translateX(-50%) translateY(0);
}

.nav-dropdown a {
  display: flex; align-items: center; justify-content: space-between;
  padding: 11px 18px;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--ice);
  opacity: 0.6;
  border-bottom: 1px solid #7ae5eb10;
  transition: background 0.15s, opacity 0.15s;
}
.nav-dropdown a:last-child { border-bottom: none; }
.nav-dropdown a:hover { background: #7ae5eb0e; opacity: 1; }
.nav-dropdown a.locked-el { opacity: 0.2; }

/* CTA button */
.nav-cta {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--teal);
  border: 1px solid #7ae5eb44;
  padding: 8px 18px;
  border-radius: 4px;
  text-decoration: none;
  transition: background 0.2s, border-color 0.2s;
  white-space: nowrap;
  margin-left: 8px;
}
.nav-cta:hover { background: #7ae5eb18; border-color: var(--teal); }

/* Mobile hamburger */
.nav-mobile-btn {
  display: none;
  background: none; border: none; cursor: pointer;
  padding: 8px; color: var(--ice); opacity: 0.7;
  flex-direction: column; gap: 5px;
}
.nav-mobile-btn span {
  display: block; width: 22px; height: 1.5px;
  background: var(--ice);
  transition: transform 0.25s, opacity 0.25s;
}
.nav-mobile-btn.open span:nth-child(1) { transform: translateY(6.5px) rotate(45deg); }
.nav-mobile-btn.open span:nth-child(2) { opacity: 0; }
.nav-mobile-btn.open span:nth-child(3) { transform: translateY(-6.5px) rotate(-45deg); }

/* Mobile menu */
.mobile-menu {
  display: none;
  position: fixed; top: var(--nav-h); left:0; right:0; z-index:99;
  background: rgba(3,11,20,0.98);
  backdrop-filter: blur(16px);
  border-bottom: 1px solid var(--dim);
  padding: 16px 0 24px;
  max-height: calc(100vh - var(--nav-h));
  overflow-y: auto;
}
.mobile-menu.open { display: block; }

.mobile-section { padding: 0 24px; }
.mobile-section-label {
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--teal);
  opacity: 0.4;
  padding: 16px 0 8px;
  border-top: 1px solid var(--dim);
  margin-top: 8px;
  display: block;
}
.mobile-section:first-child .mobile-section-label { border-top: none; margin-top: 0; }

.mobile-link {
  display: flex; align-items: center; justify-content: space-between;
  padding: 11px 0;
  font-family: var(--font-ui);
  font-size: 16px;
  font-weight: 500;
  color: var(--ice);
  opacity: 0.7;
  border-bottom: 1px solid #7ae5eb08;
  transition: opacity 0.15s;
}
.mobile-link:hover { opacity: 1; }
.mobile-link.locked-el { opacity: 0.2; }

/* ── SPLIT LISTEN BUTTON ─────────────────────────────────── */
.listen-split {
  display: inline-flex; align-items: stretch;
  border-radius: 4px; overflow: hidden;
  border: 1px solid #7ae5eb55;
  font-family: var(--font-mono);
  font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase;
}
.listen-split-label {
  background: linear-gradient(135deg, var(--teal), #5dd8de);
  color: #000; font-weight: 700;
  padding: 13px 16px;
  display: flex; align-items: center;
  white-space: nowrap;
  pointer-events: none;
}
.listen-split-divider { width:1px; background:#00000033; flex-shrink:0; }
.listen-split a {
  background: linear-gradient(135deg, var(--teal), #5dd8de);
  color: #000; padding: 13px 16px;
  display: flex; align-items: center; gap: 6px;
  transition: opacity 0.2s;
  text-decoration: none;
}
.listen-split a:hover { opacity: 0.8; }
.listen-split a svg { width:18px; height:18px; flex-shrink:0; }

/* ── BUTTONS ─────────────────────────────────────────────── */
.btn-primary {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: #000;
  background: linear-gradient(135deg, var(--teal), #5dd8de);
  padding: 14px 28px;
  border-radius: 4px;
  text-decoration: none;
  font-weight: 700;
  transition: opacity 0.2s, transform 0.15s;
  border: none; cursor: pointer;
}
.btn-primary:hover { opacity: 0.88; transform: translateY(-1px); }

.btn-ghost {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: var(--ice);
  opacity: 0.6;
  padding: 14px 0;
  text-decoration: none;
  transition: opacity 0.2s, gap 0.2s;
  background: none; border: none; cursor: pointer;
}
.btn-ghost:hover { opacity: 1; gap: 14px; }

.btn-outline {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--teal);
  border: 1px solid #7ae5eb44;
  padding: 10px 20px;
  border-radius: 4px;
  text-decoration: none;
  transition: background 0.2s, border-color 0.2s;
  cursor: pointer; background: none;
}
.btn-outline:hover { background: #7ae5eb18; border-color: var(--teal); }

/* ── PAGE HEADER (inner pages) ───────────────────────────── */
.page-hero {
  padding: calc(var(--nav-h) + 80px) 0 80px;
  border-bottom: 1px solid var(--dim);
}
.page-hero h1 {
  font-family: var(--font-serif);
  font-size: clamp(32px, 4vw, 56px);
  color: var(--ice);
  line-height: 1.15;
  margin-bottom: 20px;
}
.page-hero h1 em {
  font-style: italic;
  background: linear-gradient(135deg, var(--teal), var(--blue));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.page-hero p {
  font-size: 17px;
  font-weight: 300;
  color: var(--ice);
  opacity: 0.55;
  max-width: 560px;
  line-height: 1.75;
}

/* ── SECTION SPACING ─────────────────────────────────────── */
.section { padding: 96px 0; }
.section-sm { padding: 64px 0; }
.section + .section { border-top: 1px solid var(--dim); }

.section-head { margin-bottom: 56px; }
.section-head h2 {
  font-family: var(--font-serif);
  font-size: clamp(26px, 3vw, 40px);
  color: var(--ice);
  line-height: 1.2;
  margin-bottom: 14px;
}
.section-head p {
  font-size: 15px;
  font-weight: 300;
  color: var(--ice);
  opacity: 0.5;
  max-width: 480px;
  line-height: 1.75;
}
.section-head.centered { text-align: center; }
.section-head.centered p { margin: 0 auto; }

/* ── PLATFORM BADGES ─────────────────────────────────────── */
.platform-strip {
  display: flex; align-items: center; gap: 12px; flex-wrap: wrap;
}
.platform-btn {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 11px 20px;
  border: 1px solid var(--dim);
  border-radius: 8px;
  font-family: var(--font-ui);
  font-size: 14px;
  font-weight: 600;
  color: var(--ice);
  text-decoration: none;
  transition: border-color 0.2s, background 0.2s;
  background: var(--mid);
}
.platform-btn:hover { background: var(--dim2); border-color: var(--teal); }
.platform-btn .p-icon { width:20px; height:20px; border-radius:4px; flex-shrink:0; }

/* ── EPISODE TILES ───────────────────────────────────────── */
.episode-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 1px;
  background: var(--dim);
  border: 1px solid var(--dim);
  border-radius: var(--radius);
  overflow: hidden;
}

.ep-tile {
  background: var(--mid);
  padding: 32px 36px;
  display: flex; flex-direction: column;
  gap: 14px;
  text-decoration: none;
  color: inherit;
  transition: background 0.2s;
  position: relative;
}
.ep-tile:hover { background: var(--dim2); }
.ep-tile.coming { opacity: 0.45; pointer-events: none; }

.ep-num {
  font-family: var(--font-display);
  font-size: 32px;
  font-weight: 900;
  color: var(--blue);
  opacity: 0.35;
  line-height: 1;
}

.ep-meta {
  display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
}

.ep-date {
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.2em;
  color: var(--ice);
  opacity: 0.35;
  text-transform: uppercase;
}

.ep-title {
  font-family: var(--font-serif);
  font-size: 19px;
  color: var(--ice);
  line-height: 1.3;
  font-weight: 400;
}

.ep-desc {
  font-size: 13px;
  font-weight: 300;
  color: var(--ice);
  opacity: 0.5;
  line-height: 1.7;
  flex: 1;
}

.ep-links {
  display: flex; align-items: center; gap: 10px;
  margin-top: 4px;
}

.ep-platform-btn {
  display: inline-flex; align-items: center; gap: 7px;
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  padding: 6px 12px;
  border-radius: 4px;
  border: 1px solid;
  text-decoration: none;
  transition: opacity 0.2s;
}
.ep-platform-btn.spotify { color: #1DB954; border-color: #1DB95433; background: #1DB95412; }
.ep-platform-btn.apple   { color: #B150FF; border-color: #B150FF33; background: #B150FF12; }
.ep-platform-btn.spotify:hover { background: #1DB95422; }
.ep-platform-btn.apple:hover   { background: #B150FF22; }

.ep-companion {
  display: inline-flex; align-items: center; gap: 7px;
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--teal);
  opacity: 0.7;
  text-decoration: none;
  transition: opacity 0.2s;
  margin-top: 4px;
}
.ep-companion:hover { opacity: 1; }
.ep-companion::after { content: '→'; }

/* ── PILLARS ─────────────────────────────────────────────── */
.pillars-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--dim);
  border: 1px solid var(--dim);
  border-radius: var(--radius);
  overflow: hidden;
}

.pillar {
  background: var(--mid);
  padding: 44px 36px;
  transition: background 0.2s;
}
.pillar:hover { background: var(--dim2); }

.pillar-num {
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.4em;
  color: var(--teal);
  opacity: 0.4;
  text-transform: uppercase;
  display: block;
  margin-bottom: 20px;
}

.pillar-icon {
  width: 38px; height: 38px;
  border: 1px solid #7ae5eb44;
  border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  color: var(--teal);
  font-size: 15px;
  margin-bottom: 20px;
}

.pillar h3 {
  font-family: var(--font-serif);
  font-size: 21px;
  color: var(--ice);
  line-height: 1.25;
  margin-bottom: 12px;
  font-weight: 400;
}

.pillar p {
  font-size: 13px;
  font-weight: 300;
  color: var(--ice);
  opacity: 0.5;
  line-height: 1.75;
}

.pillar-status {
  display: inline-flex; align-items: center; gap: 6px;
  margin-top: 24px;
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  padding: 5px 11px;
  border-radius: 4px;
}
.status-live {
  background: #7ae5eb1a; color: var(--teal); border: 1px solid #7ae5eb33;
}
.status-live::before {
  content: ''; width: 5px; height: 5px; border-radius: 50%;
  background: var(--teal);
  animation: blink 2s ease-in-out infinite;
}
@keyframes blink { 0%,100%{opacity:1} 50%{opacity:0.3} }
.status-soon { background: #1a2035; color: var(--dim); border: 1px solid var(--dim); }

/* ── SUBSCRIBE STRIP ─────────────────────────────────────── */
.subscribe-panel {
  background: var(--mid);
  border: 1px solid var(--dim);
  border-radius: var(--radius);
  padding: 64px 72px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 72px;
  align-items: center;
  position: relative;
  overflow: hidden;
}
.subscribe-panel::before {
  content: '';
  position: absolute; top:-80px; right:-80px;
  width:320px; height:320px; border-radius:50%;
  background: radial-gradient(circle, #204ccf14 0%, transparent 65%);
  pointer-events: none;
}
.subscribe-panel h2 {
  font-family: var(--font-serif);
  font-size: 30px;
  color: var(--ice);
  margin-bottom: 14px;
  line-height: 1.2;
}
.subscribe-panel p {
  font-size: 14px; font-weight:300;
  color: var(--ice); opacity: 0.5; line-height: 1.75;
}

.platform-list { display:flex; flex-direction:column; gap:10px; }

.platform-row {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 18px;
  background: var(--bg);
  border: 1px solid var(--dim);
  border-radius: 8px;
  text-decoration: none;
  color: var(--ice);
  transition: border-color 0.2s, background 0.2s;
}
.platform-row:hover { border-color: var(--teal); background: var(--dim2); }

.platform-row-left { display:flex; align-items:center; gap:13px; }
.p-icon-lg { width:36px; height:36px; border-radius:8px; flex-shrink:0; }
.platform-row-name { font-size:15px; font-weight:600; color:var(--ice); display:block; }
.platform-row-desc { font-family:var(--font-mono); font-size:9px; letter-spacing:0.15em; text-transform:uppercase; color:var(--ice); opacity:0.35; display:block; margin-top:2px; }
.platform-row-arrow { color:var(--teal); opacity:0.4; font-size:14px; transition:opacity 0.2s; }
.platform-row:hover .platform-row-arrow { opacity:1; }

/* ── VALUE ROWS ──────────────────────────────────────────── */
.values-list {
  display: flex; flex-direction: column;
  gap: 1px;
  background: var(--dim);
  border: 1px solid var(--dim);
  border-radius: var(--radius);
  overflow: hidden;
}
.value-row {
  background: var(--mid);
  padding: 26px 30px;
  display: flex; gap: 18px;
  transition: background 0.2s;
}
.value-row:hover { background: var(--dim2); }
.value-row-num {
  font-family: var(--font-mono);
  font-size: 9px; letter-spacing:0.3em;
  color: var(--teal); opacity:0.4;
  min-width:26px; padding-top:3px;
}
.value-row h4 {
  font-size:15px; font-weight:600; color:var(--ice);
  margin-bottom:5px; letter-spacing:0.02em;
}
.value-row p {
  font-size:13px; font-weight:300; color:var(--ice); opacity:0.45; line-height:1.65;
}

/* ── QUOTE BLOCK ─────────────────────────────────────────── */
.quote-block {
  background: var(--mid);
  border: 1px solid var(--dim);
  border-left: 3px solid var(--teal);
  border-radius: 0 var(--radius) var(--radius) 0;
  padding: 28px 32px;
  margin-top: 32px;
}
.quote-block p {
  font-family: var(--font-serif);
  font-size: 17px;
  font-style: italic;
  color: var(--ice);
  opacity: 0.8;
  line-height: 1.65;
}

/* ── FOOTER ──────────────────────────────────────────────── */
.site-footer {
  background: var(--bg);
  border-top: 1px solid var(--dim);
  padding: 64px 0 40px;
}

.footer-grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 56px;
  margin-bottom: 56px;
}

.footer-wordmark {
  font-family: var(--font-display);
  font-size: 20px;
  font-weight: 700;
  background: linear-gradient(135deg, var(--ice) 0%, var(--teal) 55%, var(--blue) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  display: block;
  margin-bottom: 14px;
}

.footer-brand-p {
  font-size:13px; font-weight:300; color:var(--ice); opacity:0.4;
  line-height:1.75; max-width:260px;
}

.footer-col h5 {
  font-family: var(--font-mono);
  font-size: 9px; letter-spacing:0.35em; text-transform:uppercase;
  color: var(--teal); opacity:0.5; margin-bottom:18px;
}
.footer-col ul { list-style:none; display:flex; flex-direction:column; gap:9px; }
.footer-col ul li a {
  font-size:13px; color:var(--ice); opacity:0.45; transition:opacity 0.2s;
}
.footer-col ul li a:hover { opacity:0.9; }

.footer-bottom {
  display:flex; align-items:center; justify-content:space-between;
  padding-top:28px; border-top:1px solid var(--dim); flex-wrap:wrap; gap:10px;
}
.footer-bottom p {
  font-family:var(--font-mono); font-size:9px; letter-spacing:0.18em;
  color:var(--ice); opacity:0.2; text-transform:uppercase;
}

/* ── FADE-IN ANIMATION ───────────────────────────────────── */
.fade-up {
  opacity:0; transform:translateY(24px);
  transition: opacity 0.7s ease, transform 0.7s ease;
}
.fade-up.visible { opacity:1; transform:translateY(0); }

/* ── RESPONSIVE ──────────────────────────────────────────── */
@media (max-width: 900px) {
  .container { padding:0 20px; }

  .nav-menu, .nav-cta { display:none; }
  .nav-mobile-btn { display:flex; }

  .pillars-grid,
  .subscribe-panel,
  .footer-grid { grid-template-columns:1fr; }

  .subscribe-panel { padding:40px 28px; gap:36px; }
  .footer-grid { gap:32px; }

  .episode-grid { grid-template-columns:1fr; }
  .page-hero { padding: calc(var(--nav-h) + 48px) 0 48px; }
}

@media (max-width: 480px) {
  .ep-tile { padding:24px; }
  .section { padding:64px 0; }
  .pillar { padding:32px 24px; }
}
