/* Jolie · Responsive overrides for Option B
 *
 * The desktop design is composed at fixed pixel sizes (heroSize 280, atlas
 * grid at 6 columns, etc.) — that's the look. This file provides explicit
 * mobile/tablet breakpoints so it doesn't break on a phone. We target the
 * data-jolie hooks added throughout the JSX. !important is used because
 * the inline React styles otherwise win.
 */

/* ─── TABLET: ≤ 1100px ─────────────────────────────────────────── */
@media (max-width: 1100px) {
  /* Atlas: 6 → 4 columns */
  [data-jolie="atlas-grid"] {
    grid-template-columns: repeat(4, 1fr) !important;
  }
  /* Hero title scales down */
  [data-jolie="hero-title"] {
    font-size: clamp(80px, 18vw, 200px) !important;
  }
  [data-jolie="hero-photo"] {
    height: 140px !important;
  }
  /* Big section headlines */
  [data-jolie="atlas-h"],
  [data-jolie="gallery-h"],
  [data-jolie="ep-h"] {
    font-size: clamp(64px, 14vw, 160px) !important;
  }
  [data-jolie="footer-h"] {
    font-size: clamp(80px, 16vw, 180px) !important;
  }
  /* Stats: numerals down */
  [data-jolie="stat-num"] {
    font-size: clamp(96px, 18vw, 180px) !important;
  }
  [data-jolie="stat-label"] {
    font-size: clamp(28px, 5vw, 48px) !important;
  }
  /* About headline */
  [data-jolie="about-h"] {
    font-size: clamp(56px, 9vw, 80px) !important;
  }
}

/* ─── MOBILE: ≤ 720px ─────────────────────────────────────────── */
@media (max-width: 720px) {
  /* Hide the desktop nav links + coords, keep just logo */
  [data-jolie="nav"] {
    padding: 12px 16px !important;
  }
  [data-jolie="nav"] nav {
    display: none !important;
  }
  [data-jolie="nav"] > div:last-child {
    display: none !important;
  }

  /* Hero: stack everything */
  [data-jolie="hero"] {
    padding: 20px 16px 0 !important;
  }
  [data-jolie="hero-eyebrow"] {
    flex-wrap: wrap !important;
    gap: 6px !important;
    font-size: 10px !important;
    margin-bottom: 16px !important;
  }
  [data-jolie="hero-eyebrow"] > span {
    flex: 1 1 100% !important;
  }
  [data-jolie="hero-title"] {
    font-size: clamp(56px, 16vw, 96px) !important;
    line-height: 0.9 !important;
  }
  [data-jolie="hero-row"] {
    flex-wrap: wrap !important;
    gap: 12px !important;
    margin: 6px 0 !important;
  }
  [data-jolie="hero-photo"] {
    flex: 1 1 100% !important;
    height: 180px !important;
    order: 99 !important;  /* photo drops below the row of words */
  }
  [data-jolie="hero-foot"] {
    grid-template-columns: 1fr !important;
    gap: 24px !important;
    text-align: left !important;
  }
  [data-jolie="hero-foot"] > div {
    text-align: left !important;
    align-self: flex-start !important;
    justify-content: flex-start !important;
    max-width: none !important;
  }

  /* Now-parked banner: stack into rows */
  [data-jolie="now"] {
    grid-template-columns: 1fr !important;
    gap: 8px !important;
    padding: 16px !important;
    text-align: left !important;
  }

  /* Marquee: smaller type so it ticks faster relative to width */
  [data-jolie="marquee"] {
    font-size: 18px !important;
  }

  /* Stats: stack to single column per row */
  [data-jolie="stat-row"] {
    grid-template-columns: 1fr !important;
    gap: 12px !important;
    padding: 32px 16px !important;
  }
  [data-jolie="stat-num"] {
    font-size: clamp(96px, 30vw, 160px) !important;
  }
  [data-jolie="stat-label"] {
    font-size: clamp(28px, 8vw, 44px) !important;
  }
  [data-jolie="stat-side"] {
    text-align: left !important;
    font-size: 12px !important;
  }

  /* About: stack */
  [data-jolie="about"] {
    padding: 56px 16px !important;
  }
  [data-jolie="about-grid"] {
    grid-template-columns: 1fr !important;
    gap: 32px !important;
  }
  [data-jolie="about-h"] {
    font-size: clamp(40px, 11vw, 64px) !important;
  }

  /* Atlas: 4 → 2 columns */
  [data-jolie="atlas"] {
    padding: 56px 0 !important;
  }
  [data-jolie="atlas"] > div:first-child {
    padding: 0 16px !important;
  }
  [data-jolie="atlas-h"] {
    font-size: clamp(56px, 14vw, 96px) !important;
  }
  [data-jolie="atlas-grid"] {
    grid-template-columns: repeat(2, 1fr) !important;
  }
  [data-jolie="atlas-foot"] {
    flex-wrap: wrap !important;
    gap: 8px !important;
    padding: 24px 16px !important;
    font-size: 11px !important;
  }

  /* Latest Episode: stack thumb + side panel */
  [data-jolie="ep"] {
    padding: 56px 16px !important;
  }
  [data-jolie="ep-grid"] {
    grid-template-columns: 1fr !important;
  }
  [data-jolie="ep-grid"] > a {
    border-right: none !important;
    border-bottom: 2px solid #0d0c0a !important;
  }

  /* Gallery: stack */
  [data-jolie="gallery"] > div:first-child {
    padding: 56px 16px 24px !important;
  }
  [data-jolie="gallery-grid"] {
    grid-template-columns: 1fr !important;
    grid-template-rows: 320px 220px 220px !important;
  }
  [data-jolie="gallery-grid"] > div:first-child {
    grid-row: 1 / 2 !important;
    border-right: none !important;
    border-bottom: 2px solid #0d0c0a !important;
  }

  /* Fan Mail: stack */
  [data-jolie="mail"] {
    padding: 56px 16px !important;
  }
  [data-jolie="mail-grid"] {
    grid-template-columns: 1fr !important;
    gap: 32px !important;
  }

  /* Footer */
  [data-jolie="footer"] {
    padding: 48px 16px 16px !important;
  }
  [data-jolie="footer-h"] {
    font-size: clamp(56px, 18vw, 120px) !important;
  }
  [data-jolie="footer-grid"] {
    grid-template-columns: 1fr 1fr !important;
    gap: 24px !important;
    padding-top: 24px !important;
  }
  [data-jolie="footer-grid"] > div:last-child {
    grid-column: 1 / -1 !important;
  }
  [data-jolie="footer-fine"] {
    flex-wrap: wrap !important;
    gap: 6px !important;
    margin-top: 32px !important;
    font-size: 10px !important;
  }
  [data-jolie="footer-fine"] > span {
    flex: 1 1 100% !important;
  }
}

/* ─── EXTRA SMALL: ≤ 420px ─────────────────────────────────────── */
@media (max-width: 420px) {
  [data-jolie="hero-title"] {
    font-size: clamp(40px, 14vw, 64px) !important;
  }
  [data-jolie="hero-photo"] {
    height: 140px !important;
  }
  [data-jolie="atlas-h"],
  [data-jolie="gallery-h"],
  [data-jolie="ep-h"] {
    font-size: clamp(40px, 11vw, 64px) !important;
  }
  [data-jolie="footer-h"] {
    font-size: clamp(48px, 16vw, 80px) !important;
  }
}
