/*
Theme Name: Out of Network
Theme URI: https://outofnetworkpod.com
Author: Flavor Studio
Author URI: https://flavor.studio
Description: A premium dark theme for the Out of Network podcast - honest conversations between concierge physicians about practicing medicine on your own terms.
Version: 2.0.0
Requires at least: 6.0
Tested up to: 6.4
Requires PHP: 8.0
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: flavor-oon
Tags: podcast, dark-mode, custom-logo, custom-menu, featured-images
*/

/* ========================================================================
   CSS CUSTOM PROPERTIES (Design Tokens)
   ======================================================================== */

:root {
  /* Colors - Dark Cinematic Palette */
  --oon-bg-primary: #050508;
  --oon-bg-secondary: #0a0a0f;
  --oon-bg-card: rgba(255, 255, 255, 0.03);
  --oon-bg-card-hover: rgba(255, 255, 255, 0.05);
  --oon-bg-card-elevated: linear-gradient(145deg, rgba(255, 255, 255, 0.05) 0%, rgba(255, 255, 255, 0.01) 100%);
  
  /* Text Colors */
  --oon-text-primary: #ffffff;
  --oon-text-secondary: rgba(255, 255, 255, 0.85);
  --oon-text-tertiary: rgba(255, 255, 255, 0.5);
  --oon-text-muted: rgba(255, 255, 255, 0.35);
  --oon-text-faint: rgba(255, 255, 255, 0.2);
  
  /* Brand Colors - Purple/Blue Gradient System */
  --oon-purple-600: #7c3aed;
  --oon-purple-500: #8b5cf6;
  --oon-purple-400: #a78bfa;
  --oon-purple-300: #c4b5fd;
  --oon-blue-500: #3b82f6;
  --oon-blue-400: #60a5fa;
  
  /* Gradients */
  --oon-gradient-primary: linear-gradient(135deg, #7c3aed 0%, #8b5cf6 100%);
  --oon-gradient-text: linear-gradient(90deg, rgba(255, 255, 255, 0.85) 0%, rgba(167, 139, 250, 0.6) 100%);
  --oon-gradient-logo: linear-gradient(135deg, rgba(139, 92, 246, 0.35) 0%, rgba(59, 130, 246, 0.25) 100%);
  --oon-gradient-button-ghost: linear-gradient(135deg, rgba(139, 92, 246, 0.4) 0%, rgba(139, 92, 246, 0.2) 100%);
  
  /* Borders */
  --oon-border-subtle: rgba(255, 255, 255, 0.06);
  --oon-border-light: rgba(255, 255, 255, 0.08);
  --oon-border-medium: rgba(255, 255, 255, 0.1);
  --oon-border-accent: rgba(139, 92, 246, 0.3);
  --oon-border-accent-strong: rgba(139, 92, 246, 0.4);
  
  /* Shadows */
  --oon-shadow-button: 0 4px 24px rgba(139, 92, 246, 0.35), 0 0 0 1px rgba(139, 92, 246, 0.1);
  --oon-shadow-glow: 0 0 16px rgba(167, 139, 250, 0.6);
  
  /* Platform Colors */
  --oon-apple: #fc3c44;
  --oon-spotify: #1db954;
  --oon-youtube: #ff0000;
  --oon-rss: #f78422;
  
  /* Typography */
  --oon-font-sans: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
  --oon-font-mono: ui-monospace, SFMono-Regular, "SF Mono", Menlo, Consolas, monospace;
  
  /* Font Sizes - Fluid */
  --oon-text-xs: 0.6875rem;
  --oon-text-sm: 0.8125rem;
  --oon-text-base: 0.9375rem;
  --oon-text-lg: 1.125rem;
  --oon-text-xl: 1.3125rem;
  --oon-text-2xl: 1.5rem;
  --oon-text-3xl: 2rem;
  --oon-text-4xl: clamp(2.75rem, 5.5vw, 4.5rem);
  
  /* Spacing */
  --oon-space-1: 0.25rem;
  --oon-space-2: 0.5rem;
  --oon-space-3: 0.75rem;
  --oon-space-4: 1rem;
  --oon-space-5: 1.25rem;
  --oon-space-6: 1.5rem;
  --oon-space-8: 2rem;
  --oon-space-10: 2.5rem;
  --oon-space-12: 3rem;
  --oon-space-14: 3.5rem;
  --oon-space-16: 4rem;
  --oon-space-20: 5rem;
  --oon-space-24: 6rem;
  
  /* Border Radius */
  --oon-radius-sm: 0.5rem;
  --oon-radius-md: 0.625rem;
  --oon-radius-lg: 0.75rem;
  --oon-radius-xl: 0.875rem;
  --oon-radius-2xl: 1rem;
  --oon-radius-3xl: 1.75rem;
  --oon-radius-full: 100px;
  
  /* Transitions */
  --oon-transition-fast: 0.15s ease;
  --oon-transition-base: 0.2s ease;
  --oon-transition-slow: 0.3s ease;
  
  /* Z-index */
  --oon-z-base: 1;
  --oon-z-player: 50;
  --oon-z-header: 100;
  
  /* Layout */
  --oon-container-max: 1400px;
  --oon-container-padding: 3.5rem;
  --oon-player-height: 80px;
}

@media (max-width: 1024px) {
  :root {
    --oon-container-padding: 2rem;
  }
}

@media (max-width: 768px) {
  :root {
    --oon-container-padding: 1.5rem;
    --oon-player-height: 72px;
  }
}

/* ========================================================================
   RESET & BASE
   ======================================================================== */

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

html { 
  scroll-behavior: smooth; 
  -webkit-text-size-adjust: 100%; 
}

body {
  font-family: var(--oon-font-sans);
  font-size: var(--oon-text-base);
  line-height: 1.6;
  color: var(--oon-text-primary);
  background-color: var(--oon-bg-primary);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow-x: hidden;
}

body.has-player { padding-bottom: var(--oon-player-height); }

img, picture, video, canvas, svg { display: block; max-width: 100%; height: auto; }
input, button, textarea, select { font: inherit; color: inherit; }
button { cursor: pointer; border: none; background: none; }
a { color: inherit; text-decoration: none; }
ul, ol { list-style: none; }

/* ========================================================================
   BACKGROUND EFFECTS
   ======================================================================== */

.oon-bg-effects {
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  overflow: hidden;
}

.oon-bg-orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(80px);
}

.oon-bg-orb--blue {
  top: -20%;
  left: 5%;
  width: 900px;
  height: 900px;
  background: radial-gradient(circle, rgba(59, 130, 246, 0.07) 0%, transparent 55%);
}

.oon-bg-orb--purple {
  bottom: -30%;
  right: -5%;
  width: 800px;
  height: 800px;
  background: radial-gradient(circle, rgba(168, 85, 247, 0.06) 0%, transparent 55%);
  filter: blur(100px);
}

.oon-bg-orb--accent {
  top: 30%;
  right: 20%;
  width: 400px;
  height: 400px;
  background: radial-gradient(circle, rgba(139, 92, 246, 0.05) 0%, transparent 50%);
  filter: blur(60px);
}

.oon-bg-noise {
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");
  opacity: 0.02;
}

/* ========================================================================
   LAYOUT
   ======================================================================== */

.oon-container {
  width: 100%;
  max-width: var(--oon-container-max);
  margin: 0 auto;
  padding-left: var(--oon-container-padding);
  padding-right: var(--oon-container-padding);
}

.oon-main { position: relative; z-index: var(--oon-z-base); }

.oon-section {
  padding-top: var(--oon-space-16);
  padding-bottom: var(--oon-space-16);
}

.oon-section--border-top {
  border-top: 1px solid var(--oon-border-subtle);
}

.oon-grid { display: grid; gap: var(--oon-space-8); }
.oon-grid--2 { grid-template-columns: repeat(2, 1fr); }
.oon-grid--3 { grid-template-columns: repeat(3, 1fr); }
.oon-grid--4 { grid-template-columns: repeat(4, 1fr); }

.oon-grid--hero {
  grid-template-columns: 1.25fr 0.75fr;
  gap: var(--oon-space-20);
  align-items: start;
}

.oon-grid--bottom {
  grid-template-columns: 1.1fr 0.9fr;
  gap: var(--oon-space-24);
}

@media (max-width: 1024px) {
  .oon-grid--hero,
  .oon-grid--bottom {
    grid-template-columns: 1fr;
    gap: var(--oon-space-12);
  }
}

@media (max-width: 768px) {
  .oon-grid--2,
  .oon-grid--3,
  .oon-grid--4 {
    grid-template-columns: 1fr;
  }
}

/* ========================================================================
   TYPOGRAPHY
   ======================================================================== */

.oon-heading-hero {
  font-size: var(--oon-text-4xl);
  font-weight: 700;
  letter-spacing: -0.03em;
  line-height: 1.05;
}

.oon-heading-hero__line { display: block; }

.oon-heading-hero__line--gradient {
  background: var(--oon-gradient-text);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.oon-heading-xl { font-size: var(--oon-text-xl); font-weight: 600; line-height: 1.35; }
.oon-heading-lg { font-size: var(--oon-text-lg); font-weight: 600; line-height: 1.4; }
.oon-text-body { font-size: var(--oon-text-lg); line-height: 1.7; color: var(--oon-text-tertiary); }
.oon-text-small { font-size: var(--oon-text-sm); color: var(--oon-text-tertiary); }
.oon-text-muted { color: var(--oon-text-muted); }

.oon-label {
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--oon-text-muted);
}

.oon-label--accent { color: var(--oon-purple-400); }
.oon-mono { font-family: var(--oon-font-mono); }

/* ========================================================================
   BUTTONS
   ======================================================================== */

.oon-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--oon-space-3);
  padding: 18px 36px;
  font-size: var(--oon-text-base);
  font-weight: 600;
  border-radius: var(--oon-radius-xl);
  transition: all var(--oon-transition-base);
  white-space: nowrap;
}

.oon-btn--primary {
  background: var(--oon-gradient-primary);
  color: var(--oon-text-primary);
  box-shadow: var(--oon-shadow-button);
}

.oon-btn--primary:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 28px rgba(139, 92, 246, 0.45);
}

.oon-btn--secondary {
  background: var(--oon-bg-card);
  border: 1px solid var(--oon-border-medium);
  color: var(--oon-text-secondary);
}

.oon-btn--secondary:hover {
  background: var(--oon-bg-card-hover);
}

.oon-btn--ghost {
  background: var(--oon-gradient-button-ghost);
  border: 1px solid var(--oon-border-accent-strong);
  color: var(--oon-text-primary);
}

.oon-btn--small {
  padding: 12px 24px;
  font-size: var(--oon-text-sm);
  border-radius: var(--oon-radius-md);
}

.oon-btn--play {
  background: rgba(139, 92, 246, 0.2);
  border: 1px solid rgba(139, 92, 246, 0.35);
  padding: 12px 24px;
  border-radius: var(--oon-radius-lg);
}

.oon-btn--play:hover { background: rgba(139, 92, 246, 0.3); }
.oon-btn__icon { font-size: 1rem; }
.oon-btn-group { display: flex; gap: var(--oon-space-4); flex-wrap: wrap; }

/* ========================================================================
   BADGES & PILLS
   ======================================================================== */

.oon-badge {
  display: inline-flex;
  align-items: center;
  gap: var(--oon-space-3);
  padding: 10px 18px;
  background: rgba(139, 92, 246, 0.1);
  border: 1px solid rgba(139, 92, 246, 0.2);
  border-radius: var(--oon-radius-full);
  font-size: var(--oon-text-xs);
  font-weight: 600;
  letter-spacing: 0.08em;
  color: var(--oon-purple-400);
}

.oon-badge__dot {
  width: 8px;
  height: 8px;
  background: var(--oon-purple-400);
  border-radius: 50%;
  box-shadow: var(--oon-shadow-glow);
}

.oon-badge__divider { color: var(--oon-text-faint); }
.oon-badge__text--muted { color: var(--oon-text-muted); font-weight: 500; letter-spacing: 0; }

.oon-pill {
  display: inline-flex;
  align-items: center;
  padding: 11px 20px;
  background: rgba(139, 92, 246, 0.08);
  border: 1px solid rgba(139, 92, 246, 0.15);
  border-radius: var(--oon-radius-md);
  font-size: var(--oon-text-sm);
  font-weight: 500;
  color: rgba(255, 255, 255, 0.7);
  transition: all var(--oon-transition-base);
}

.oon-pill:hover {
  background: rgba(139, 92, 246, 0.15);
  border-color: rgba(139, 92, 246, 0.25);
  color: var(--oon-text-primary);
}

.oon-pills { display: flex; flex-wrap: wrap; gap: var(--oon-space-3); }

/* ========================================================================
   PLATFORM LINKS
   ======================================================================== */

.oon-platforms { display: flex; flex-wrap: wrap; gap: var(--oon-space-3); }

.oon-platform {
  display: flex;
  align-items: center;
  gap: 9px;
  padding: 11px 18px;
  background: var(--oon-bg-card);
  border: 1px solid var(--oon-border-light);
  border-radius: var(--oon-radius-md);
  font-size: 12px;
  font-weight: 500;
  color: rgba(255, 255, 255, 0.6);
  transition: all var(--oon-transition-base);
}

.oon-platform:hover {
  background: var(--oon-bg-card-hover);
  color: var(--oon-text-primary);
}

.oon-platform__dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  flex-shrink: 0;
}

.oon-platform__dot--apple { background: var(--oon-apple); box-shadow: 0 0 8px rgba(252, 60, 68, 0.4); }
.oon-platform__dot--spotify { background: var(--oon-spotify); box-shadow: 0 0 8px rgba(29, 185, 84, 0.4); }
.oon-platform__dot--youtube { background: var(--oon-youtube); box-shadow: 0 0 8px rgba(255, 0, 0, 0.4); }
.oon-platform__dot--rss { background: var(--oon-rss); box-shadow: 0 0 8px rgba(247, 132, 34, 0.4); }

/* ========================================================================
   CARDS
   ======================================================================== */

.oon-card {
  background: var(--oon-bg-card-elevated);
  border: 1px solid rgba(255, 255, 255, 0.07);
  border-radius: var(--oon-radius-3xl);
  padding: var(--oon-space-10);
  position: relative;
  overflow: hidden;
}

.oon-card__glow {
  position: absolute;
  top: -50%;
  right: -50%;
  width: 200px;
  height: 200px;
  background: radial-gradient(circle, rgba(139, 92, 246, 0.15) 0%, transparent 70%);
  filter: blur(40px);
  pointer-events: none;
}

.oon-card__header {
  display: flex;
  align-items: center;
  gap: var(--oon-space-3);
  margin-bottom: var(--oon-space-6);
}

.oon-card__label {
  font-size: var(--oon-text-xs);
  font-weight: 700;
  letter-spacing: 0.12em;
  color: var(--oon-purple-400);
}

.oon-card__title {
  font-size: var(--oon-text-xl);
  font-weight: 600;
  line-height: 1.35;
  margin-bottom: var(--oon-space-4);
}

.oon-card__description {
  font-size: var(--oon-text-sm);
  line-height: 1.65;
  color: rgba(255, 255, 255, 0.45);
  margin-bottom: var(--oon-space-8);
}

.oon-card__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-top: var(--oon-space-6);
  border-top: 1px solid var(--oon-border-subtle);
}

.oon-card__meta {
  display: flex;
  align-items: center;
  gap: var(--oon-space-4);
  font-size: var(--oon-text-sm);
  color: var(--oon-text-tertiary);
}

/* Episode Card - Grid */
.oon-episode-card {
  display: flex;
  flex-direction: column;
  background: var(--oon-bg-card);
  border: 1px solid var(--oon-border-subtle);
  border-radius: var(--oon-radius-2xl);
  padding: var(--oon-space-6);
  transition: all var(--oon-transition-base);
}

.oon-episode-card:hover {
  background: var(--oon-bg-card-hover);
  border-color: var(--oon-border-light);
  transform: translateY(-2px);
}

.oon-episode-card__number {
  font-size: var(--oon-text-xs);
  font-weight: 700;
  letter-spacing: 0.1em;
  color: var(--oon-purple-400);
  margin-bottom: var(--oon-space-3);
}

.oon-episode-card__title {
  font-size: var(--oon-text-base);
  font-weight: 600;
  line-height: 1.4;
  margin-bottom: var(--oon-space-3);
  flex: 1;
}

.oon-episode-card__meta {
  font-size: 12px;
  color: var(--oon-text-muted);
}

/* Host Card */
.oon-host-card {
  display: flex;
  align-items: center;
  gap: var(--oon-space-5);
  padding: var(--oon-space-4) var(--oon-space-5);
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid rgba(255, 255, 255, 0.05);
  border-radius: var(--oon-radius-2xl);
  transition: all var(--oon-transition-base);
}

.oon-host-card:hover {
  background: var(--oon-bg-card-hover);
  border-color: var(--oon-border-light);
}

.oon-host-card__avatar {
  width: 56px;
  height: 56px;
  border-radius: var(--oon-radius-xl);
  border: 2px solid rgba(139, 92, 246, 0.25);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 22px;
  flex-shrink: 0;
  overflow: hidden;
}

.oon-host-card__avatar--parker { background: linear-gradient(135deg, #1e3a5f 0%, #312e81 100%); }
.oon-host-card__avatar--seth { background: linear-gradient(135deg, #065f46 0%, #1e3a5f 100%); }
.oon-host-card__avatar img { width: 100%; height: 100%; object-fit: cover; }
.oon-host-card__content { flex: 1; min-width: 0; }
.oon-host-card__name { font-size: var(--oon-text-base); font-weight: 600; margin-bottom: 4px; }
.oon-host-card__meta { font-size: var(--oon-text-sm); color: var(--oon-text-muted); }

.oon-host-card__arrow {
  font-size: 18px;
  color: var(--oon-text-faint);
  transition: transform var(--oon-transition-base);
}

.oon-host-card:hover .oon-host-card__arrow {
  transform: translateX(4px);
  color: var(--oon-text-muted);
}

/* ========================================================================
   STATS
   ======================================================================== */

.oon-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--oon-space-5);
}

.oon-stat { text-align: center; }

.oon-stat__value {
  font-size: var(--oon-text-2xl);
  font-weight: 700;
  margin-bottom: 4px;
  background: linear-gradient(135deg, #fff 0%, rgba(167, 139, 250, 0.8) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.oon-stat__label {
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--oon-text-muted);
}

/* ========================================================================
   WAVEFORM
   ======================================================================== */

.oon-waveform {
  display: flex;
  align-items: center;
  gap: 2px;
  height: 40px;
}

.oon-waveform__bar {
  width: 4px;
  border-radius: 2px;
  background: rgba(255, 255, 255, 0.12);
  transition: background var(--oon-transition-fast);
}

.oon-waveform__bar--played {
  background: linear-gradient(180deg, var(--oon-purple-400) 0%, var(--oon-purple-600) 100%);
}

/* ========================================================================
   HEADER
   ======================================================================== */

.oon-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--oon-space-6) var(--oon-container-padding);
  position: relative;
  z-index: var(--oon-z-header);
}

.oon-logo { display: flex; align-items: center; gap: var(--oon-space-4); }

.oon-logo__mark {
  width: 42px;
  height: 42px;
  background: var(--oon-gradient-logo);
  border: 1px solid var(--oon-border-accent);
  border-radius: var(--oon-radius-lg);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all var(--oon-transition-slow);
}

.oon-logo__mark-text {
  font-size: var(--oon-text-xs);
  font-weight: 800;
  background: linear-gradient(135deg, #fff 0%, rgba(255, 255, 255, 0.8) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.oon-logo__text { font-size: var(--oon-text-base); font-weight: 600; }

.oon-nav { display: flex; align-items: center; gap: var(--oon-space-2); }

.oon-nav__link {
  padding: 10px 18px;
  font-size: var(--oon-text-sm);
  font-weight: 500;
  color: var(--oon-text-tertiary);
  border-radius: var(--oon-radius-sm);
  transition: all var(--oon-transition-base);
}

.oon-nav__link:hover,
.oon-nav__link--active {
  color: var(--oon-text-secondary);
  background: rgba(255, 255, 255, 0.03);
}

.oon-nav__cta { margin-left: var(--oon-space-2); }
.oon-menu-toggle { display: none; padding: var(--oon-space-2); color: var(--oon-text-primary); }

@media (max-width: 768px) {
  .oon-nav { display: none; }
  .oon-nav--open {
    display: flex;
    flex-direction: column;
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: var(--oon-bg-secondary);
    border-top: 1px solid var(--oon-border-subtle);
    padding: var(--oon-space-4);
  }
  .oon-menu-toggle { display: block; }
}

/* ========================================================================
   HERO SECTION
   ======================================================================== */

.oon-hero { padding: var(--oon-space-8) 0 var(--oon-space-20); }
.oon-hero__badge { margin-bottom: var(--oon-space-10); }
.oon-hero__badge-group { display: inline-flex; align-items: center; gap: var(--oon-space-3); }
.oon-hero__headline { margin-bottom: var(--oon-space-7); }
.oon-hero__description { max-width: 520px; margin-bottom: var(--oon-space-5); }
.oon-hero__hosts { font-size: var(--oon-text-sm); color: var(--oon-text-muted); margin-bottom: var(--oon-space-10); }
.oon-hero__actions { margin-bottom: var(--oon-space-10); }
.oon-hero__platforms-label { margin-bottom: var(--oon-space-4); }
.oon-hero__sidebar { margin-top: var(--oon-space-24); }

@media (max-width: 1024px) {
  .oon-hero__sidebar { margin-top: var(--oon-space-8); }
}

/* ========================================================================
   PLAYER BAR
   ======================================================================== */

.oon-player {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  height: var(--oon-player-height);
  background: rgba(8, 8, 12, 0.95);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  border-top: 1px solid var(--oon-border-subtle);
  padding: 0 var(--oon-container-padding);
  display: flex;
  align-items: center;
  justify-content: space-between;
  z-index: var(--oon-z-player);
}

.oon-player__left {
  display: flex;
  align-items: center;
  gap: var(--oon-space-5);
  min-width: 340px;
}

.oon-player__play {
  width: 52px;
  height: 52px;
  background: var(--oon-gradient-primary);
  border-radius: var(--oon-radius-xl);
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 20px rgba(139, 92, 246, 0.35);
  transition: all var(--oon-transition-base);
  flex-shrink: 0;
}

.oon-player__play:hover { transform: scale(1.05); }
.oon-player__play-icon { color: var(--oon-text-primary); font-size: 16px; margin-left: 2px; }
.oon-player__info { min-width: 0; }

.oon-player__episode {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.1em;
  margin-bottom: 5px;
  display: flex;
  align-items: center;
  gap: var(--oon-space-2);
}

.oon-player__episode-num { color: var(--oon-purple-400); }
.oon-player__episode-duration { color: var(--oon-text-muted); font-weight: 500; }

.oon-player__title {
  font-size: var(--oon-text-sm);
  font-weight: 500;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 280px;
}

.oon-player__center {
  flex: 1;
  max-width: 460px;
  margin: 0 var(--oon-space-12);
  padding: 0 var(--oon-space-2);
}

.oon-player__progress {
  position: relative;
  height: 6px;
  background: rgba(255, 255, 255, 0.1);
  border-radius: 3px;
  cursor: pointer;
  transition: height var(--oon-transition-fast);
}

.oon-player__progress:hover {
  height: 8px;
}

.oon-player__progress-bar {
  position: absolute;
  left: 0;
  top: 0;
  height: 100%;
  background: var(--oon-gradient-primary);
  border-radius: 3px;
  width: 0%;
  transition: width 0.1s linear;
}

.oon-player__progress-handle {
  position: absolute;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 14px;
  height: 14px;
  background: var(--oon-text-primary);
  border-radius: 50%;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
  opacity: 0;
  left: 0%;
  transition: opacity var(--oon-transition-fast);
}

.oon-player__progress:hover .oon-player__progress-handle,
.oon-player.is-playing .oon-player__progress-handle {
  opacity: 1;
}

.oon-player__play:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.oon-player__right {
  display: flex;
  align-items: center;
  gap: var(--oon-space-5);
  min-width: 160px;
  justify-content: flex-end;
}

.oon-player__time {
  font-size: var(--oon-text-sm);
  color: var(--oon-text-tertiary);
  font-family: var(--oon-font-mono);
}

.oon-player__time-divider { color: var(--oon-text-faint); }

.oon-player__speed {
  padding: 7px 14px;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid var(--oon-border-light);
  border-radius: var(--oon-radius-sm);
  font-size: 12px;
  font-weight: 600;
  color: rgba(255, 255, 255, 0.6);
  transition: all var(--oon-transition-base);
}

.oon-player__speed:hover { background: rgba(255, 255, 255, 0.1); }

@media (max-width: 1024px) {
  .oon-player__center { display: none; }
  .oon-player__left { min-width: auto; flex: 1; }
  .oon-player__title { max-width: none; }
}

@media (max-width: 768px) {
  .oon-player__right { min-width: auto; }
  .oon-player__speed { display: none; }
}

/* ========================================================================
   FOOTER
   ======================================================================== */

.oon-footer {
  padding: var(--oon-space-16) 0;
  border-top: 1px solid var(--oon-border-subtle);
}

.oon-footer__grid {
  display: grid;
  grid-template-columns: 1.5fr 1fr 1fr 1fr;
  gap: var(--oon-space-12);
}

.oon-footer__brand { max-width: 280px; }

.oon-footer__tagline {
  margin-top: var(--oon-space-4);
  font-size: var(--oon-text-sm);
  color: var(--oon-text-muted);
  line-height: 1.6;
}

.oon-footer__heading {
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--oon-text-muted);
  margin-bottom: var(--oon-space-5);
}

.oon-footer__links { display: flex; flex-direction: column; gap: var(--oon-space-3); }

.oon-footer__link {
  font-size: var(--oon-text-sm);
  color: var(--oon-text-tertiary);
  transition: color var(--oon-transition-base);
}

.oon-footer__link:hover { color: var(--oon-text-primary); }

.oon-footer__platforms {
  display: flex;
  gap: var(--oon-space-4);
  flex-wrap: wrap;
}

.oon-footer__platform-logo {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  background: var(--oon-bg-card);
  border: 1px solid var(--oon-border-subtle);
  border-radius: var(--oon-radius-md);
  color: var(--oon-text-muted);
  transition: all var(--oon-transition-base);
}

.oon-footer__platform-logo:hover {
  background: var(--oon-bg-card-hover);
  border-color: var(--oon-border-light);
  color: var(--oon-text-primary);
  transform: translateY(-2px);
}

.oon-footer__platform-logo svg {
  width: 22px;
  height: 22px;
}

.oon-footer__bottom {
  margin-top: var(--oon-space-12);
  padding-top: var(--oon-space-8);
  border-top: 1px solid var(--oon-border-subtle);
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.oon-footer__copyright { font-size: var(--oon-text-sm); color: var(--oon-text-muted); }
.oon-footer__legal { display: flex; gap: var(--oon-space-6); }

@media (max-width: 1024px) {
  .oon-footer__grid { grid-template-columns: 1fr 1fr; gap: var(--oon-space-8); }
  .oon-footer__brand { grid-column: span 2; max-width: none; }
}

@media (max-width: 768px) {
  .oon-footer__grid { grid-template-columns: 1fr; }
  .oon-footer__brand { grid-column: span 1; }
  .oon-footer__bottom { flex-direction: column; gap: var(--oon-space-4); text-align: center; }
}

/* ========================================================================
   UTILITIES
   ======================================================================== */

.oon-sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  border: 0;
}

.screen-reader-text {
  border: 0;
  clip: rect(1px, 1px, 1px, 1px);
  clip-path: inset(50%);
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  width: 1px;
}

.skip-link {
  background: var(--oon-purple-500);
  color: var(--oon-text-primary);
  padding: var(--oon-space-4) var(--oon-space-6);
  position: absolute;
  top: -100%;
  left: 50%;
  transform: translateX(-50%);
  z-index: 999999;
  border-radius: var(--oon-radius-md);
}

.skip-link:focus { top: var(--oon-space-4); }

/* Admin bar adjustment */
.admin-bar .oon-header { top: 32px; }
@media (max-width: 782px) {
  .admin-bar .oon-header { top: 46px; }
}
