/* =========================================
   APOLLO GROUP TV – BASE SYSTEM
   Clean Design Architecture (v2)
========================================= */

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

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

body{
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  background: #0a0a0a;
  color: #ffffff;
  line-height: 1.6;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

img, picture, video, canvas { display:block; max-width:100%; height:auto; }
/* IMPORTANT: do NOT force all SVGs to max-width:100%.
   Inline SVG icons (chat/contact/etc.) will explode to full width.
   We size SVGs via their component classes instead. */
svg{ display:block; }

a{ text-decoration:none; color:inherit; }
ul, ol{ list-style:none; }
button{ font-family:inherit; border:none; background:none; cursor:pointer; }

/* ========== DESIGN TOKENS ========== */
:root {
    /* Primary tokens (new system) */
    --color-primary: #0ea5e9;
    --color-primary-hover: #0284c7;
    --color-accent: #8b5cf6;
    --color-success: #22c55e;
    --color-warning: #f59e0b;

    --color-bg-main: #0a0a0a;
    --color-bg-secondary: #111111;
    --color-bg-tertiary: #1a1a1a;
    --color-bg-card: #171717;

    --color-text-main: #ffffff;
    --color-text-secondary: #a1a1aa;
    --color-text-muted: #71717a;

    --color-border: #262626;

    --shadow-soft: 0 10px 30px rgba(0,0,0,0.45);
    --shadow-card: 0 10px 40px rgba(0,0,0,0.50);
    --shadow-glow: 0 0 40px rgba(14,165,233,0.25);

    --radius-sm: 10px;
    --radius-md: 14px;
    --radius-lg: 20px;
    --radius-xl: 28px;

    --container-width: 1200px;
    --section-padding: 6rem;

    --transition-fast: 0.2s ease;
    --transition-normal: 0.3s ease;
    --transition-slow: 0.5s ease;

    /* Legacy aliases (keep older modules working) */
    --primary-color: var(--color-primary);
    --primary-hover: var(--color-primary-hover);
    --secondary-color: var(--color-success);
    --accent-color: var(--color-accent);

    --dark-bg: var(--color-bg-main);
    --dark-bg-secondary: var(--color-bg-secondary);
    --dark-bg-tertiary: var(--color-bg-tertiary);

    --text-primary: var(--color-text-main);
    --text-secondary: var(--color-text-secondary);
    --text-muted: var(--color-text-muted);

    --border-color: var(--color-border);

    --gradient-primary: linear-gradient(135deg, #0ea5e9 0%, #8b5cf6 100%);
    --gradient-dark: linear-gradient(180deg, #0a0a0a 0%, #111111 100%);
}

/* ========== TYPOGRAPHY SYSTEM ========== */
h1,h2,h3,h4{ font-weight:700; line-height:1.2; margin-bottom:1rem; }
h1{ font-size: clamp(2rem, 5vw, 3.5rem); }
h2{ font-size: clamp(1.75rem, 4vw, 2.5rem); }
h3{ font-size: clamp(1.4rem, 3vw, 1.8rem); }
p{ color: var(--color-text-secondary); margin-bottom:1rem; }

/* ========== LAYOUT SYSTEM ========== */
.container{ width:100%; max-width: var(--container-width); margin: 0 auto; padding: 0 1.5rem; }

.section{ padding: var(--section-padding) 0; position:relative; }
.section-dark{ background: var(--color-bg-main); }
.section-secondary{ background: var(--color-bg-secondary); }
.section-light{ background: #f8fafc; color:#111; }

.section-header{ text-align:center; max-width:700px; margin:0 auto 4rem; }

/* ========== BUTTON SYSTEM ========== */
.btn{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .5rem;
  padding: .82rem 1.8rem;
  border-radius: 12px;
  font-weight: 700;
  font-size: .93rem;
  letter-spacing: .01em;
  transition: transform .22s ease, box-shadow .22s ease, background .22s ease, border-color .22s ease;
  position: relative;
  overflow: hidden;
  white-space: nowrap;
  cursor: pointer;
  border: 1.5px solid transparent;
  text-decoration: none;
}

/* Primary — dark rich gradient, gold tint */
.btn-primary{
  background: linear-gradient(135deg, #1d6fa4 0%, #0ea5e9 50%, #38bdf8 100%);
  color: #fff;
  border-color: rgba(56,189,248,.3);
  box-shadow: 0 4px 16px rgba(14,165,233,.25), inset 0 1px 0 rgba(255,255,255,.15);
}
.btn-primary:hover{
  transform: translateY(-3px);
  box-shadow: 0 10px 32px rgba(14,165,233,.4), inset 0 1px 0 rgba(255,255,255,.2);
  background: linear-gradient(135deg, #1e7ab5 0%, #1ea8eb 50%, #45c6ff 100%);
}

/* Outline — glass border, subtle glow on hover */
.btn-outline{
  background: rgba(14,165,233,.06);
  color: rgba(255,255,255,.88);
  border-color: rgba(14,165,233,.35);
  backdrop-filter: blur(8px);
}
.btn-outline:hover{
  background: rgba(14,165,233,.14);
  border-color: rgba(14,165,233,.65);
  color: #fff;
  transform: translateY(-2px);
  box-shadow: 0 6px 22px rgba(14,165,233,.2);
}

/* WhatsApp green */
.btn-whatsapp{
  background: linear-gradient(135deg, #128c1e 0%, #25d366 60%, #2ee86f 100%);
  color: #fff;
  border-color: rgba(37,211,102,.3);
  box-shadow: 0 4px 16px rgba(37,211,102,.22), inset 0 1px 0 rgba(255,255,255,.15);
}
.btn-whatsapp:hover{
  transform: translateY(-3px);
  box-shadow: 0 10px 32px rgba(37,211,102,.38);
}

/* Secondary — subtle ghost */
.btn-secondary{
  background: rgba(255,255,255,.06);
  color: rgba(255,255,255,.78);
  border-color: rgba(255,255,255,.16);
}
.btn-secondary:hover{
  background: rgba(255,255,255,.11);
  border-color: rgba(255,255,255,.32);
  color: #fff;
  transform: translateY(-2px);
}

/* Sizes */
.btn-sm { padding: .55rem 1.2rem; font-size: .84rem; border-radius: 9px; }
.btn-lg { padding: 1rem 2.2rem; font-size: 1rem; border-radius: 14px; }
.btn-full{ width: 100%; justify-content: center; }

/* Ripple */
.btn::after{
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(255,255,255,.08);
  opacity: 0;
  transition: opacity .18s;
  border-radius: inherit;
}
.btn:active::after{ opacity: 1; }

/* ========== UTILITIES ========== */
.text-center{ text-align:center; }
.hidden{ display:none !important; }
.sr-only{
  position:absolute; width:1px; height:1px; padding:0; margin:-1px;
  overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0;
}

/* ========== RESPONSIVE CORE ========== */
@media (max-width: 992px){ :root {
    /* Primary tokens (new system) */
    --color-primary: #0ea5e9;
    --color-primary-hover: #0284c7;
    --color-accent: #8b5cf6;
    --color-success: #22c55e;
    --color-warning: #f59e0b;

    --color-bg-main: #0a0a0a;
    --color-bg-secondary: #111111;
    --color-bg-tertiary: #1a1a1a;
    --color-bg-card: #171717;

    --color-text-main: #ffffff;
    --color-text-secondary: #a1a1aa;
    --color-text-muted: #71717a;

    --color-border: #262626;

    --shadow-soft: 0 10px 30px rgba(0,0,0,0.45);
    --shadow-card: 0 10px 40px rgba(0,0,0,0.50);
    --shadow-glow: 0 0 40px rgba(14,165,233,0.25);

    --radius-sm: 10px;
    --radius-md: 14px;
    --radius-lg: 20px;
    --radius-xl: 28px;

    --container-width: 1200px;
    --section-padding: 6rem;

    --transition-fast: 0.2s ease;
    --transition-normal: 0.3s ease;
    --transition-slow: 0.5s ease;

    /* Legacy aliases (keep older modules working) */
    --primary-color: var(--color-primary);
    --primary-hover: var(--color-primary-hover);
    --secondary-color: var(--color-success);
    --accent-color: var(--color-accent);

    --dark-bg: var(--color-bg-main);
    --dark-bg-secondary: var(--color-bg-secondary);
    --dark-bg-tertiary: var(--color-bg-tertiary);

    --text-primary: var(--color-text-main);
    --text-secondary: var(--color-text-secondary);
    --text-muted: var(--color-text-muted);

    --border-color: var(--color-border);

    --gradient-primary: linear-gradient(135deg, #0ea5e9 0%, #8b5cf6 100%);
    --gradient-dark: linear-gradient(180deg, #0a0a0a 0%, #111111 100%);
} }
@media (max-width: 600px){ :root {
    /* Primary tokens (new system) */
    --color-primary: #0ea5e9;
    --color-primary-hover: #0284c7;
    --color-accent: #8b5cf6;
    --color-success: #22c55e;
    --color-warning: #f59e0b;

    --color-bg-main: #0a0a0a;
    --color-bg-secondary: #111111;
    --color-bg-tertiary: #1a1a1a;
    --color-bg-card: #171717;

    --color-text-main: #ffffff;
    --color-text-secondary: #a1a1aa;
    --color-text-muted: #71717a;

    --color-border: #262626;

    --shadow-soft: 0 10px 30px rgba(0,0,0,0.45);
    --shadow-card: 0 10px 40px rgba(0,0,0,0.50);
    --shadow-glow: 0 0 40px rgba(14,165,233,0.25);

    --radius-sm: 10px;
    --radius-md: 14px;
    --radius-lg: 20px;
    --radius-xl: 28px;

    --container-width: 1200px;
    --section-padding: 6rem;

    --transition-fast: 0.2s ease;
    --transition-normal: 0.3s ease;
    --transition-slow: 0.5s ease;

    /* Legacy aliases (keep older modules working) */
    --primary-color: var(--color-primary);
    --primary-hover: var(--color-primary-hover);
    --secondary-color: var(--color-success);
    --accent-color: var(--color-accent);

    --dark-bg: var(--color-bg-main);
    --dark-bg-secondary: var(--color-bg-secondary);
    --dark-bg-tertiary: var(--color-bg-tertiary);

    --text-primary: var(--color-text-main);
    --text-secondary: var(--color-text-secondary);
    --text-muted: var(--color-text-muted);

    --border-color: var(--color-border);

    --gradient-primary: linear-gradient(135deg, #0ea5e9 0%, #8b5cf6 100%);
    --gradient-dark: linear-gradient(180deg, #0a0a0a 0%, #111111 100%);
} }


/* ========== SCROLL REVEAL ========== */
.reveal{
  opacity: 0;
  transform: translateY(26px);
  transition: opacity .8s ease, transform .8s ease;
}
.reveal.active{
  opacity: 1;
  transform: translateY(0);
}

/* =========================================
   COVERAGE / KEYWORDS SECTION
========================================= */

.coverage-section{ padding: calc(var(--section-padding) + 1rem) 0; }
.coverage-inner{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap: clamp(1.5rem, 4vw, 3.5rem);
  align-items: start;
}
.coverage-copy .kicker{
  display:inline-flex;
  align-items:center;
  gap:.5rem;
  padding:.45rem .9rem;
  border-radius: 999px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.10);
  color: rgba(255,255,255,.70);
  font-size: .78rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  margin-bottom: 1rem;
}
.coverage-copy h2{
  font-size: clamp(2rem, 3.8vw, 3rem);
  line-height: 1.08;
  letter-spacing: -0.03em;
  margin: 0 0 1rem;
}
.coverage-copy p{ color: rgba(255,255,255,.70); font-size: 1.05rem; line-height: 1.75; max-width: 60ch; }
.coverage-stats{
  display:grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: .85rem;
  margin-top: 1.35rem;
}
.coverage-stat{
  padding: 1rem .95rem;
  border-radius: 16px;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.10);
}
.coverage-stat strong{ display:block; font-size: 1.35rem; letter-spacing: -0.02em; }
.coverage-stat span{ display:block; font-size: .9rem; color: rgba(255,255,255,.60); margin-top: .15rem; }

.coverage-chips{
  display:flex;
  flex-wrap: wrap;
  gap: .65rem;
  padding: 1.25rem;
  border-radius: 22px;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.10);
}

.chip{
  display:inline-flex;
  align-items:center;
  padding: .55rem .85rem;
  border-radius: 999px;
  background: rgba(0,0,0,.35);
  border: 1px solid rgba(255,255,255,.12);
  color: rgba(255,255,255,.78);
  font-size: .9rem;
  transition: transform .2s ease, border-color .2s ease;
}

.chip:hover{ transform: translateY(-2px); border-color: rgba(14,165,233,.45); }

@media (max-width: 1024px){
  .coverage-inner{ grid-template-columns: 1fr; }
  .coverage-stats{ grid-template-columns: repeat(3, minmax(0,1fr)); }
}

@media (max-width: 680px){
  .coverage-stats{ grid-template-columns: 1fr; }
}
/* ================================================================
   MOBILE IMPROVEMENTS v4.2
   - Better images on mobile
   - Proper split section stacking
   - Touch-friendly buttons
   - No overflow
================================================================ */

/* ── Global mobile image fix ── */
@media (max-width: 768px) {
  img { max-width: 100%; height: auto; }

  /* Prevent any image from overflowing */
  .split-media,
  .split-media__frame,
  .visual-wrapper,
  .phone-mockups,
  .hero-visual { overflow: hidden; }

  /* Stack split sections cleanly */
  .split-inner,
  .split-inner.is-reverse {
    grid-template-columns: 1fr !important;
    gap: 2rem;
  }
  /* Always show image BELOW text on mobile */
  .split-inner.is-reverse { direction: ltr; }

  /* Phone mockups on mobile */
  .split-media {
    width: 100%;
    max-width: 380px;
    margin: 0 auto;
    aspect-ratio: 4/3;
    position: relative;
  }
  .split-media__frame {
    width: min(220px, 58vw);
    transform: none !important;
    left: 50%;
    transform: translateX(-50%) !important;
    position: absolute;
    top: 0;
    bottom: 0;
    margin: auto;
  }
  .split-media__float {
    width: min(165px, 44vw) !important;
    right: 0 !important;
    left: auto !important;
    transform: translate(0, 22%) rotate(5deg) !important;
    bottom: 0;
    top: auto;
  }
  .split-inner.is-reverse .split-media__float {
    left: 0 !important;
    right: auto !important;
    transform: translate(0, 22%) rotate(-5deg) !important;
  }

  /* Phone mockup pair */
  .phone-mockups {
    min-height: 300px !important;
    max-width: 100%;
  }
  .phone-mockup {
    width: min(180px, 46vw) !important;
  }

  /* Hero visual on mobile */
  .hero-visual-wrap {
    display: flex;
    justify-content: center;
    margin-top: 1.5rem;
  }
  .hero-visual-wrap img {
    width: min(320px, 90vw);
    border-radius: 18px;
    border: 1px solid rgba(255,255,255,.1);
    box-shadow: 0 20px 50px rgba(0,0,0,.5);
  }

  /* Movie grid on mobile */
  .movies-grid {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: .65rem;
  }
  .movie-card img { height: 180px !important; object-fit: cover; }

  /* Buttons on mobile */
  .btn { padding: .78rem 1.4rem; font-size: .9rem; }
  .btn-lg { padding: .9rem 1.6rem; font-size: .95rem; }
  .hero-cta { flex-direction: column; gap: .75rem; }
  .hero-cta .btn { width: 100%; }
  .page-cta { flex-direction: column; gap: .75rem; }
  .page-cta .btn { width: 100%; max-width: 340px; }

  /* Section padding reduction */
  .split-section { padding: 3.5rem 0; }
  .pricing-section { padding: 3rem 0; }

  /* Card grids */
  .features-grid { grid-template-columns: 1fr !important; }
  .blog-grid { grid-template-columns: 1fr !important; }
}

@media (max-width: 480px) {
  .movies-grid { grid-template-columns: 1fr 1fr !important; }
  .movie-card img { height: 140px !important; }
  .split-media { max-width: 100%; aspect-ratio: auto; min-height: 260px; }
  .split-media__frame { width: min(180px, 52vw) !important; }
  .split-media__float { width: min(140px, 40vw) !important; }
}
