/* ═══════════════════════════════════════════════════════════
   MXTV — Teenage Engineering Inspired Design System v3
   Palette  : #ff6600 · #000 · #fff · #f0f0ec
   Font     : Space Mono (Google Fonts — free)
   ═══════════════════════════════════════════════════════════ */

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

/* ── TOKENS ───────────────────────────────────────────────── */
:root {
  --te-orange:    #ff6600;
  --te-orange-dk: #cc5200;
  --te-black:     #000000;
  --te-white:     #ffffff;
  --te-off-white: #f0f0ec;
  --te-gray-lt:   #d0d0cc;
  --te-gray-md:   #888888;
  --te-gray-dk:   #444444;
  --te-green:     #00cc66;
  --font:         'Space Mono', 'SF Mono', 'Courier New', monospace;
  --header-h:     56px;
  --max-w:        1200px;
  --gap:          1px;
}

/* ── BASE ─────────────────────────────────────────────────── */
html { font-size: 14px; -webkit-font-smoothing: antialiased; }
body { font-family: var(--font); background: var(--te-off-white); color: var(--te-black); min-height: 100vh; display: flex; flex-direction: column; }
a    { color: inherit; text-decoration: none; }
img, svg { display: block; }

/* ── UTILITY ──────────────────────────────────────────────── */
.orange { color: var(--te-orange); }

.dot-live {
  display: inline-block; width: 8px; height: 8px;
  border-radius: 50%; background: var(--te-green);
  margin-right: 5px;
  animation: pulse 1.8s ease-in-out infinite;
}
@keyframes pulse { 0%,100%{opacity:1} 50%{opacity:.3} }

/* ── SCROLL PROGRESS BAR ──────────────────────────────────── */
#scroll-progress {
  position: fixed; top: 0; left: 0; z-index: 9999;
  height: 2px; width: 0%;
  background: var(--te-orange);
  transition: width 80ms linear;
}

/* ── BUTTONS ──────────────────────────────────────────────── */
.btn-primary, .btn-secondary {
  display: inline-block; font-family: var(--font);
  font-size: .82rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: .08em;
  padding: 13px 26px; border: none; border-radius: 0; cursor: pointer;
  transition: background 100ms;
}
.btn-primary  { background: var(--te-orange); color: var(--te-white); }
.btn-primary:hover  { background: var(--te-orange-dk); }
.btn-secondary { background: var(--te-black); color: var(--te-white); }
.btn-secondary:hover { background: var(--te-gray-dk); }

/* ── HEADER ───────────────────────────────────────────────── */
.site-header {
  position: sticky; top: 2px; z-index: 100;
  background: var(--te-black);
  border-bottom: 2px solid var(--te-orange);
  height: var(--header-h);
}
.header-inner {
  max-width: var(--max-w); margin: 0 auto; padding: 0 24px;
  height: 100%; display: flex; align-items: center; gap: 32px;
}

/* ── LOGO ─────────────────────────────────────────────────── */
.logo { display: flex; align-items: baseline; flex-shrink: 0; }
.logo-main {
  font-family: var(--font); font-size: 1.45rem; font-weight: 700;
  color: var(--te-white); letter-spacing: .02em; text-transform: uppercase;
}

/* ── NAV ──────────────────────────────────────────────────── */
.main-nav { display: flex; align-items: center; flex: 1; }
.nav-link {
  font-family: var(--font); font-size: .72rem; font-weight: 400;
  text-transform: uppercase; letter-spacing: .1em; color: var(--te-gray-md);
  padding: 0 14px; height: var(--header-h);
  display: flex; align-items: center;
  border-right: 1px solid #222;
  transition: color 80ms, background 80ms;
}
.nav-link:first-child { border-left: 1px solid #222; }
.nav-link:hover  { color: var(--te-white); background: #111; }
.nav-link.active { color: var(--te-white); background: var(--te-orange); }

.header-status { margin-left: auto; display: flex; align-items: center; gap: 6px; }
.status-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--te-green); animation: pulse 1.8s ease-in-out infinite; }
.status-text { font-size: .68rem; font-weight: 700; letter-spacing: .15em; color: var(--te-green); text-transform: uppercase; }

/* ── PLAYER SECTION ───────────────────────────────────────── */
.player-section-full { width: 100%; background: var(--te-black); }

/* ONE single bar above the player — no extra rows */
.player-bar {
  display: flex; align-items: center; justify-content: space-between;
  padding: 7px 18px; background: var(--te-black);
  border-bottom: 1px solid #1a1a1a;
  flex-wrap: wrap; gap: 8px;
}
.player-bar-left  { display: flex; align-items: center; gap: 8px; }
.player-bar-right { display: flex; align-items: center; gap: 6px; }
.bar-label { font-size: .72rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--te-white); }
.bar-dim   { font-size: .65rem; color: var(--te-gray-md); letter-spacing: .06em; }
.bar-divider { color: #333; font-size: .7rem; }

/* Share buttons */
.share-btn {
  display: inline-flex; align-items: center; gap: 4px;
  font-family: var(--font); font-size: .62rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: .08em;
  color: var(--te-gray-md); background: #111;
  border: 1px solid #333; padding: 4px 8px; cursor: pointer;
  transition: color 80ms, border-color 80ms;
}
.share-btn:hover { color: var(--te-orange); border-color: var(--te-orange); }

/* 16:9 full-width player */
.player-wrapper-full { position: relative; width: 100%; padding-top: 56.25%; background: var(--te-black); }
.player-wrapper-full iframe { position: absolute; top: 0; left: 0; width: 100%; height: 100%; border: none; }

/* Unmute nudge */
.unmute-nudge {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 18px; background: #111;
  border-top: 1px solid #222;
  font-size: .65rem; color: var(--te-gray-md);
  letter-spacing: .04em;
}
.unmute-nudge button {
  margin-left: auto; background: none; border: none;
  color: var(--te-gray-md); cursor: pointer; font-size: .8rem;
  padding: 2px 6px;
}
.unmute-nudge button:hover { color: var(--te-white); }

/* ── SPEC GRID ────────────────────────────────────────────── */
.spec-grid {
  display: grid; grid-template-columns: repeat(6,1fr);
  gap: var(--gap); background: var(--te-black);
  border: var(--gap) solid var(--te-black); margin: 24px 0;
}
.spec-grid--full { margin: 0; border-top: 2px solid var(--te-orange); }

.spec-cell { background: var(--te-white); padding: 18px 14px; display: flex; flex-direction: column; gap: 5px; }
.spec-label { font-size: .58rem; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; color: var(--te-gray-md); }
.spec-value { font-size: .82rem; font-weight: 700; color: var(--te-black); }
.spec-live  { color: var(--te-green); display: flex; align-items: center; }

/* Scroll-reveal */
.spec-reveal-section { opacity: 0; transform: translateY(28px); transition: opacity .6s ease, transform .6s ease; pointer-events: none; }
.spec-reveal-section.spec-visible { opacity: 1; transform: translateY(0); pointer-events: auto; }

/* ── PAGE HERO ────────────────────────────────────────────── */
.page-main { flex: 1; }
.page-hero { background: var(--te-black); color: var(--te-white); padding: 60px 24px 44px; border-bottom: 3px solid var(--te-orange); }
.page-hero-inner { max-width: var(--max-w); margin: 0 auto; }
.page-eyebrow { font-size: .62rem; font-weight: 700; letter-spacing: .2em; text-transform: uppercase; color: var(--te-orange); margin-bottom: 14px; }
.page-title { font-size: clamp(2.4rem,6vw,4.8rem); font-weight: 700; line-height: 1.05; letter-spacing: -.02em; text-transform: uppercase; margin-bottom: 18px; }
.page-subtitle { font-size: .88rem; line-height: 1.7; color: var(--te-gray-lt); max-width: 540px; }

/* ── ABOUT ────────────────────────────────────────────────── */
.about-specs { max-width: var(--max-w); margin: 0 auto; padding: 0 24px; }
.about-specs .spec-grid { margin-top: 28px; }
.about-body { max-width: var(--max-w); margin: 0 auto; padding: 44px 24px; }
.about-body-inner { display: grid; grid-template-columns: repeat(auto-fit,minmax(260px,1fr)); gap: 0; background: var(--te-black); border: var(--gap) solid var(--te-black); }
.about-block { background: var(--te-off-white); padding: 28px 24px; }
.about-heading { font-size: .62rem; font-weight: 700; letter-spacing: .2em; text-transform: uppercase; color: var(--te-orange); margin-bottom: 14px; }
.about-text { font-size: .82rem; line-height: 1.75; color: var(--te-gray-dk); }
.about-cta { max-width: var(--max-w); margin: 0 auto; padding: 0 24px 56px; display: flex; gap: 14px; flex-wrap: wrap; }

/* ── SUBSCRIBE ────────────────────────────────────────────── */
.subscribe-block { max-width: var(--max-w); margin: 0 auto; padding: 44px 24px 56px; }
.subscribe-inner { display: flex; flex-direction: column; gap: 20px; max-width: 660px; }
.subscribe-card { background: var(--te-white); border: 2px solid var(--te-black); }
.sub-card-header { display: flex; justify-content: space-between; align-items: center; padding: 12px 18px; border-bottom: 1px solid var(--te-gray-lt); background: var(--te-black); }
.sub-card-label { font-size: .62rem; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; color: var(--te-gray-md); }
.sub-card-badge { font-size: .62rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--te-white); background: var(--te-orange); padding: 3px 7px; }
.sub-card-badge--live { background: transparent; color: var(--te-green); display: flex; align-items: center; }
.sub-card-body { padding: 20px 18px; }
.sub-card-desc { font-size: .82rem; line-height: 1.75; color: var(--te-gray-dk); margin-bottom: 16px; }
.sub-features { list-style: none; display: flex; flex-direction: column; gap: 7px; }
.sub-features li { font-size: .78rem; color: var(--te-black); display: flex; align-items: center; gap: 8px; }
.check { color: var(--te-orange); font-weight: 700; }
.sub-card-footer { padding: 18px; border-top: 1px solid var(--te-gray-lt); display: flex; flex-direction: column; gap: 8px; }
.sub-note { font-size: .62rem; color: var(--te-gray-md); }
.sub-divider-label { font-size: .62rem; font-weight: 700; letter-spacing: .2em; text-transform: uppercase; color: var(--te-gray-md); text-align: center; padding: 6px 0; }

/* Email form */
.email-form { display: flex; flex-direction: column; gap: 8px; }
.email-form-row { display: flex; gap: 0; }
.email-input {
  flex: 1; font-family: var(--font); font-size: .82rem;
  padding: 13px 14px; border: 2px solid var(--te-black); border-right: none;
  background: var(--te-off-white); color: var(--te-black);
  outline: none;
}
.email-input:focus { border-color: var(--te-orange); }
.email-submit { flex-shrink: 0; }

/* ── SCHEDULE ─────────────────────────────────────────────── */
.schedule-live-banner { background: var(--te-black); border-bottom: 1px solid #222; padding: 14px 24px; }
.schedule-live-inner { max-width: var(--max-w); margin: 0 auto; display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }
.live-now-label { font-size: .65rem; font-weight: 700; letter-spacing: .16em; text-transform: uppercase; color: var(--te-green); }
.live-now-title { font-size: .82rem; color: var(--te-white); flex: 1; }
.live-watch-btn { padding: 8px 18px; font-size: .72rem; }

.schedule-section { max-width: var(--max-w); margin: 0 auto; padding: 36px 24px 56px; }
.schedule-inner { display: flex; flex-direction: column; gap: 36px; }
.schedule-day { display: flex; flex-direction: column; gap: 0; }
.schedule-day-header { display: flex; align-items: center; justify-content: space-between; padding: 10px 0; border-bottom: 2px solid var(--te-black); margin-bottom: 0; }
.schedule-day-label { font-size: .65rem; font-weight: 700; letter-spacing: .2em; text-transform: uppercase; color: var(--te-orange); }
.schedule-day-date  { font-size: .65rem; color: var(--te-gray-md); }
.schedule-grid { display: flex; flex-direction: column; gap: var(--gap); background: var(--te-black); border: var(--gap) solid var(--te-black); }
.schedule-row { display: grid; grid-template-columns: 80px 1fr auto; align-items: center; gap: 20px; padding: 16px 18px; background: var(--te-white); }
.schedule-row--live { background: #fffaf5; }
.schedule-time { font-size: .72rem; font-weight: 700; color: var(--te-gray-md); letter-spacing: .06em; display: flex; align-items: center; }
.schedule-title { font-size: .82rem; font-weight: 700; color: var(--te-black); margin-bottom: 3px; }
.schedule-desc  { font-size: .72rem; color: var(--te-gray-md); }
.schedule-tag { font-size: .58rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--te-gray-md); background: var(--te-off-white); padding: 3px 7px; border: 1px solid var(--te-gray-lt); }
.schedule-note { font-size: .72rem; color: var(--te-gray-md); line-height: 1.6; border-left: 2px solid var(--te-orange); padding-left: 12px; }
.schedule-cta  { display: flex; gap: 14px; flex-wrap: wrap; }

/* ── CONNECT ──────────────────────────────────────────────── */
.connect-section { max-width: var(--max-w); margin: 0 auto; padding: 44px 24px 56px; }
.connect-inner { max-width: 800px; }
.connect-heading { font-size: .62rem; font-weight: 700; letter-spacing: .2em; text-transform: uppercase; color: var(--te-gray-md); margin-bottom: 18px; padding-bottom: 7px; border-bottom: 1px solid var(--te-gray-lt); }
.connect-heading--donate { margin-top: 44px; }
.social-grid { display: grid; grid-template-columns: repeat(auto-fit,minmax(260px,1fr)); gap: var(--gap); background: var(--te-black); border: var(--gap) solid var(--te-black); }
.social-card { background: var(--te-white); padding: 18px; display: flex; align-items: center; gap: 14px; transition: background 100ms; cursor: pointer; }
.social-card:hover { background: var(--te-off-white); }
.social-card--youtube:hover .social-icon  { color: #ff0000; }
.social-card--x:hover .social-icon        { color: var(--te-black); }
.social-card--instagram:hover .social-icon{ color: #e1306c; }
.social-card--tiktok:hover .social-icon   { color: var(--te-black); }
.social-icon { color: var(--te-black); flex-shrink: 0; transition: color 100ms; }
.social-info { flex: 1; display: flex; flex-direction: column; gap: 3px; }
.social-platform { font-size: .72rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; }
.social-handle   { font-size: .68rem; color: var(--te-gray-md); }
.social-arrow    { font-size: .95rem; color: var(--te-orange); font-weight: 700; }
.donate-desc { font-size: .82rem; line-height: 1.75; color: var(--te-gray-dk); margin-bottom: 20px; max-width: 540px; }
.donate-grid { display: grid; grid-template-columns: repeat(auto-fit,minmax(260px,1fr)); gap: var(--gap); background: var(--te-black); border: var(--gap) solid var(--te-black); }
.donate-card { background: var(--te-white); padding: 20px 18px; display: flex; align-items: center; gap: 14px; transition: background 100ms; cursor: pointer; }
.donate-card:hover { background: var(--te-off-white); }
.donate-card--paypal .donate-icon { color: #003087; }
.donate-card--stripe .donate-icon { color: #635bff; }
.donate-icon { flex-shrink: 0; }
.donate-info { flex: 1; display: flex; flex-direction: column; gap: 3px; }
.donate-platform   { font-size: .78rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; }
.donate-desc-short { font-size: .68rem; color: var(--te-gray-md); }
.donate-arrow { font-size: .95rem; color: var(--te-orange); font-weight: 700; }
.donate-note { font-size: .62rem; color: var(--te-gray-md); margin-top: 14px; line-height: 1.6; max-width: 540px; border-left: 2px solid var(--te-orange); padding-left: 10px; }

/* ── FOOTER ───────────────────────────────────────────────── */
.site-footer { position: relative; overflow: hidden; background: transparent; border-top: none; padding: 0; margin-top: auto; min-height: 140px; }
#footer-canvas { position: absolute; top: 0; left: 0; width: 100%; height: 100%; display: block; z-index: 0; }
.footer-inner { position: relative; z-index: 1; max-width: var(--max-w); margin: 0 auto; padding: 32px 24px; display: flex; align-items: center; gap: 28px; flex-wrap: wrap; }
.footer-brand { display: flex; align-items: baseline; gap: 6px; }
.footer-brand .logo-main { text-shadow: 0 0 12px rgba(0,0,0,.9); }
.footer-tagline { font-size: .62rem; color: var(--te-gray-md); letter-spacing: .06em; text-shadow: 0 0 8px rgba(0,0,0,.9); }
.footer-nav { display: flex; gap: 20px; flex-wrap: wrap; }
.footer-nav a { font-size: .62rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--te-gray-md); transition: color 80ms; text-shadow: 0 0 6px rgba(0,0,0,.9); }
.footer-nav a:hover { color: var(--te-white); }
.footer-copy { margin-left: auto; font-size: .62rem; color: var(--te-gray-md); text-shadow: 0 0 6px rgba(0,0,0,.9); }

/* ── MOBILE NAV ───────────────────────────────────────────── */
.mobile-nav-toggle { display: none; background: none; border: none; cursor: pointer; padding: 8px; flex-direction: column; gap: 5px; }
.mobile-nav-toggle span { display: block; width: 22px; height: 2px; background: var(--te-white); }

/* ── SOUND OVERLAY ───────────────────────────────────────── */
#sound-overlay {
  position: absolute;
  /* Sit just above the two tickers (48px news + 44px prayer = 92px) */
  bottom: 100px; left: 50%;
  transform: translateX(-50%);
  z-index: 25;
  pointer-events: auto;
}
#sound-btn {
  display: flex; align-items: center; gap: 10px;
  font-family: var(--font); font-size: .72rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: .1em;
  color: var(--te-white); background: rgba(0,0,0,.72);
  border: 1px solid var(--te-orange); padding: 10px 20px;
  cursor: pointer; transition: background 120ms, border-color 120ms;
  white-space: nowrap;
}
#sound-btn:hover { background: var(--te-orange); border-color: var(--te-orange); }

/* ── RESPONSIVE ───────────────────────────────────────────── */
@media (max-width: 900px) {
  .spec-grid, .spec-grid--full { grid-template-columns: repeat(3,1fr); }
}
@media (max-width: 768px) {
  .main-nav { display: none; }
  .mobile-nav-toggle { display: flex; }
  .main-nav.open { display: flex; flex-direction: column; position: absolute; top: var(--header-h); left: 0; right: 0; background: var(--te-black); border-bottom: 2px solid var(--te-orange); z-index: 200; }
  .main-nav.open .nav-link { height: 48px; border-right: none; border-bottom: 1px solid #222; padding: 0 24px; }
  .page-title { font-size: 2.1rem; }
  .spec-grid, .spec-grid--full { grid-template-columns: repeat(2,1fr); }
  .footer-inner { flex-direction: column; align-items: flex-start; gap: 14px; }
  .footer-copy { margin-left: 0; }
  .schedule-row { grid-template-columns: 60px 1fr; }
  .schedule-action { display: none; }
}
@media (max-width: 480px) {
  .social-grid, .donate-grid { grid-template-columns: 1fr; }
  .about-cta, .schedule-cta { flex-direction: column; }
  .btn-primary, .btn-secondary { width: 100%; text-align: center; }
  .email-form-row { flex-direction: column; }
  .email-input { border-right: 2px solid var(--te-black); }
  .player-bar { flex-direction: column; align-items: flex-start; }
}

/* ── LOGO BLINKING CURSOR ─────────────────────────────────── */
/*
  A single | character positioned at the top-left shoulder of
  the MXTV wordmark. Pure CSS — no JavaScript, no interference
  with OBS lower thirds which operate at the video/canvas layer.
  The cursor lives entirely inside the header (z-index 100),
  completely above and separate from the player iframe.
*/
.logo-cursor {
  font-family: var(--font);
  font-size: 1.05rem;
  font-weight: 400;
  color: var(--te-orange);
  /* Raised to top-left shoulder — sits above the baseline */
  align-self: flex-start;
  margin-top: 3px;
  margin-right: 2px;
  /* Authentic text-cursor blink: hard on/off, not a fade */
  animation: cursor-blink 1.1s step-start infinite;
  pointer-events: none;
  user-select: none;
}
@keyframes cursor-blink {
  0%, 49% { opacity: 1; }
  50%, 100% { opacity: 0; }
}
