/* =========================================
   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 — v5 ========== */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .5rem;
  padding: .85rem 1.8rem;
  border-radius: 13px;
  font-weight: 700;
  font-size: .92rem;
  letter-spacing: .01em;
  position: relative;
  overflow: hidden;
  isolation: isolate;
  white-space: nowrap;
  cursor: pointer;
  border: 1.5px solid transparent;
  text-decoration: none;
  transition:
    transform .3s cubic-bezier(.22,.68,0,1.3),
    box-shadow .28s ease,
    background .22s ease,
    border-color .22s ease,
    filter .2s ease;
}

/* Liquid sweep on all buttons */
.btn::before {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(105deg,
    transparent 25%,
    rgba(255,255,255,.15) 50%,
    transparent 75%);
  transform: translateX(-120%);
  transition: transform .55s ease;
  pointer-events: none;
}
.btn:hover::before { transform: translateX(120%); }

/* Press feedback */
.btn:active { transform: translateY(-1px) scale(.97) !important; }

/* Primary — rich blue gradient */
.btn-primary {
  background: linear-gradient(135deg, #0369a1 0%, #0ea5e9 50%, #38bdf8 100%);
  color: #fff;
  border-color: rgba(56,189,248,.25);
  box-shadow: 0 4px 18px rgba(14,165,233,.28), inset 0 1px 0 rgba(255,255,255,.15);
}
.btn-primary:hover {
  transform: translateY(-3px) scale(1.01);
  box-shadow: 0 12px 36px rgba(14,165,233,.42), inset 0 1px 0 rgba(255,255,255,.2);
  filter: brightness(1.07);
}

/* WhatsApp — green gradient */
.btn-whatsapp {
  background: linear-gradient(135deg, #166534 0%, #22c55e 60%, #4ade80 100%);
  color: #fff;
  border-color: rgba(34,197,94,.25);
  box-shadow: 0 4px 18px rgba(34,197,94,.25), inset 0 1px 0 rgba(255,255,255,.15);
}
.btn-whatsapp:hover {
  transform: translateY(-3px) scale(1.01);
  box-shadow: 0 12px 36px rgba(34,197,94,.4);
  filter: brightness(1.07);
}

/* Outline — glass */
.btn-outline {
  background: rgba(14,165,233,.06);
  color: rgba(255,255,255,.85);
  border-color: rgba(14,165,233,.32);
  backdrop-filter: blur(8px);
}
.btn-outline:hover {
  background: rgba(14,165,233,.14);
  border-color: rgba(14,165,233,.6);
  color: #fff;
  transform: translateY(-3px);
  box-shadow: 0 8px 28px rgba(14,165,233,.2);
}

/* Ghost / Secondary */
.btn-secondary, .btn-ghost {
  background: rgba(255,255,255,.06);
  color: rgba(255,255,255,.78);
  border-color: rgba(255,255,255,.16);
  backdrop-filter: blur(8px);
}
.btn-secondary:hover, .btn-ghost:hover {
  background: rgba(255,255,255,.12);
  border-color: rgba(255,255,255,.32);
  color: #fff;
  transform: translateY(-2px);
  box-shadow: 0 6px 22px rgba(0,0,0,.3);
}

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

/* Focus */
.btn:focus-visible {
  outline: 2px solid rgba(56,189,248,.7);
  outline-offset: 4px;
}

/* ========== 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 stays horizontal — see hero.css */
  .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; }
}


/* ================================================================
   MOBILE + RESPONSIVE — v5  (WOW on phone)
================================================================ */

/* ── Global image safety ── */
img { max-width: 100%; height: auto; }
svg { max-width: none; }  /* don't squash inline SVGs */

/* ── Prevent horizontal overflow ── */
body, .site-wrapper { overflow-x: hidden; }
.container { padding-left: max(1.1rem, 4vw); padding-right: max(1.1rem, 4vw); }

/* ══════════ SPLIT SECTIONS ══════════════════════════ */
@media (max-width: 1024px) {
  .split-inner,
  .split-inner.is-reverse {
    grid-template-columns: 1fr;
    gap: 2.5rem;
  }
  .split-media__frame,
  .split-inner.is-reverse .split-media__frame { transform: none; }
  .split-media__float,
  .split-inner.is-reverse .split-media__float {
    position: absolute;
    transform: translate(16%, 16%) rotate(5deg) !important;
  }
  .split-inner.is-reverse .split-media__float {
    transform: translate(-16%, 16%) rotate(-5deg) !important;
  }
}

@media (max-width: 768px) {
  /* Section padding reduction */
  :root { --section-padding: 4rem; }
  .split-section { padding: 3.5rem 0; }

  /* Split media sizing */
  .split-media {
    width: 100%;
    max-width: 360px;
    margin: 0 auto;
    aspect-ratio: 4/3;
    position: relative;
    overflow: hidden;
    border-radius: 18px;
  }
  .split-media__frame {
    width: min(200px, 56vw) !important;
    border-radius: 16px;
    transform: none !important;
    position: absolute;
    left: 50%; top: 50%;
    transform: translate(-50%, -50%) !important;
  }
  .split-media__float {
    width: min(150px, 42vw) !important;
    border-radius: 14px;
    transform: translate(0, 20%) rotate(5deg) !important;
    right: 0; left: auto;
    bottom: 0; top: auto;
  }
  .split-inner.is-reverse .split-media__float {
    left: 0; right: auto;
    transform: translate(0, 20%) rotate(-5deg) !important;
  }

  /* Phone mockup pair */
  .phone-mockups { min-height: 280px !important; }
  .phone-mockup  { width: min(160px, 44vw) !important; }

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

  /* Features / cards grids */
  .features-grid { grid-template-columns: 1fr !important; }
  .services-grid { grid-template-columns: 1fr !important; }

  /* Pricing cards on home section */
  .pricing-body { grid-template-columns: 1fr !important; }
  .pricing-sidebar {
    position: static !important;
    width: 100% !important;
  }

  /* Buttons */
  .page-cta {
    flex-direction: column;
    gap: .7rem;
  }
  .page-cta .btn { width: 100%; max-width: 340px; }

  /* Hero visual */
  .hero-visual-wrap { margin-top: 1.5rem; }
  .hero-visual-wrap img {
    width: min(300px, 88vw);
    border-radius: 18px;
    box-shadow: 0 20px 50px rgba(0,0,0,.5);
  }
}

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

/* ══════════ SMOOTH SCROLL REVEAL ══════════════════ */
.reveal {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity .65s cubic-bezier(.22,.68,0,1.2), transform .65s cubic-bezier(.22,.68,0,1.2);
}
.reveal.active {
  opacity: 1;
  transform: translateY(0);
}
.reveal[data-delay="1"] { transition-delay: .1s; }
.reveal[data-delay="2"] { transition-delay: .2s; }
.reveal[data-delay="3"] { transition-delay: .3s; }
.reveal[data-delay="4"] { transition-delay: .4s; }
.reveal[data-delay="5"] { transition-delay: .5s; }

/* data-reveal="up|scale|left|right" */
[data-reveal] {
  transition: opacity .65s cubic-bezier(.22,.68,0,1.2), transform .65s cubic-bezier(.22,.68,0,1.2);
}
[data-reveal="up"]    { opacity:0; transform:translateY(32px); }
[data-reveal="scale"] { opacity:0; transform:scale(.94); }
[data-reveal="left"]  { opacity:0; transform:translateX(-28px); }
[data-reveal="right"] { opacity:0; transform:translateX(28px); }
[data-reveal].revealed {
  opacity:1 !important;
  transform:none !important;
}
[data-reveal][data-delay="1"]{ transition-delay:.1s; }
[data-reveal][data-delay="2"]{ transition-delay:.18s; }
[data-reveal][data-delay="3"]{ transition-delay:.28s; }
[data-reveal][data-delay="4"]{ transition-delay:.38s; }
[data-reveal][data-delay="5"]{ transition-delay:.48s; }

/* Reduce motion */
@media (prefers-reduced-motion: reduce) {
  .reveal, [data-reveal] {
    transition: none !important;
    opacity: 1 !important;
    transform: none !important;
  }
}
