/* ============================================================
   BestCasinoNZ — Responsive Stylesheet
   Mobile-first breakpoints
   ============================================================ */

/* ── Tablet (max 900px) ── */
@media (max-width: 900px) {
  :root { --container: 100%; }

  .footer-grid {
    grid-template-columns: 1fr 1fr;
    gap: 28px;
  }

  .footer-brand { grid-column: 1 / -1; }

  .main-nav { display: none; }

  .menu-toggle { display: flex; }

  .hero h1 { font-size: clamp(1.5rem, 4.5vw, 2.2rem); }
}

/* ── Mobile (max 640px) ── */
@media (max-width: 640px) {

  /* Header */
  .header-inner { height: 60px; }
  .logo-link img { height: 36px; }
  .btn-header { display: none; }

  /* Hero */
  .hero { padding: 36px 16px 32px; }
  .hero h1 { font-size: 1.5rem; }
  .hero-lead { font-size: .9rem; }
  .hero::after { display: none; }

  /* Hide hero badge on mobile */
  .hero-badge { display: none; }

  /* Hero stats: 2x2 grid, no full-width stretch */
  .hero-stats {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
    width: auto;
    max-width: 320px;
    margin: 18px auto 0;
  }
  .hero-stat {
    background: rgba(255,255,255,0.15);
    border-radius: 10px;
    padding: 12px 10px;
    text-align: center;
    flex: none;
  }
  .hero-stat-num { font-size: 1.3rem; display: block; }
  .hero-stat-label { font-size: .7rem; opacity: .85; display: block; margin-top: 2px; }

  /* Meta bar */
  .meta-bar-inner { gap: 12px; font-size: .75rem; }

  /* Page body */
  .page-body { padding: 0 14px 40px; }

  /* Article typography */
  h2 { font-size: 1.25rem; margin: 40px 0 14px; }
  h3 { font-size: 1.05rem; }
  p, li { font-size: .92rem; }

  /* Author box */
  .author-box { flex-direction: column; gap: 10px; padding: 14px 16px; }
  .author-avatar { width: 48px; height: 48px; font-size: 1.1rem; }

  /* Casino cards */
  .casino-card { padding: 20px 16px 18px; margin: 24px 0; }
  .casino-header { flex-direction: column; gap: 12px; }
  .casino-name { font-size: 1.35rem; }
  .rating-block { align-self: flex-start; padding: 10px 16px; min-width: 80px; }
  .rating-num { font-size: 1.5rem; }

  /* Stats grid */
  .stats-grid { grid-template-columns: 1fr 1fr; gap: 8px; }
  .stat-val { font-size: 1rem; }

  /* Pros/cons */
  .pros-cons { grid-template-columns: 1fr; }

  /* Buttons */
  .btn-play { display: flex; width: 100%; margin: 12px 0 0; padding: 14px 20px; font-size: .95rem; }
  .btn-visit { display: none !important; }

  /* ── COMPARISON TABLE → MOBILE CARDS ── */
  .comparison-wrap { margin: 16px -14px; border-radius: 0; overflow: hidden; }

  /* Hide the desktop table on mobile */
  .comparison-wrap table { display: none; }

  /* Show mobile casino cards instead */
  .comparison-wrap::after {
    content: '';
    display: block;
    clear: both;
  }

  /* Mobile casino cards grid built via JS (see main.js) */

  /* How-to boxes */
  .how-to-box { padding: 18px 16px; margin: 20px 0; }
  .how-to-title { font-size: 1rem; }
  .how-to-box li { font-size: .88rem; margin-bottom: 10px; }

  /* All other tables (not comparison) */
  .comparison-wrap + * table,
  .casino-card table,
  .rg-section table {
    font-size: .78rem;
  }

  /* General table scroll wrapper */
  .comparison-wrap {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }

  /* RG section */
  .rg-section { padding: 22px 16px; margin: 36px 0; }
  .rg-links { gap: 8px; }
  .rg-link-btn { font-size: .8rem; padding: 9px 14px; }

  /* Final CTA */
  .final-cta { padding: 28px 18px; }
  .final-cta h3 { font-size: 1.25rem; }
  .btn-play-lg { padding: 14px 28px; font-size: .95rem; }
  .final-cta::before { display: none; }

  /* FAQ */
  .faq-q { font-size: .88rem; padding: 14px 16px; }
  .faq-a { font-size: .87rem; padding: 14px 16px; }

  /* Footer */
  .footer-grid { grid-template-columns: 1fr; gap: 24px; }
  .footer-brand { grid-column: auto; }
  .footer-bottom { flex-direction: column; gap: 8px; }
  .footer-disclaimer { text-align: left; }
  .site-footer { padding: 36px 16px 0; }

  /* Scroll top */
  .scroll-top { bottom: 16px; right: 16px; width: 40px; height: 40px; }

  /* Section intro */
  .section-intro { padding: 14px 16px; }

  /* Honorable card */
  .honorable-label { font-size: .72rem; }

  /* Hide decorative elements */
  .hero::after, .final-cta::before { display: none; }
}

/* ── Very small (max 380px) ── */
@media (max-width: 380px) {
  .hero h1 { font-size: 1.3rem; }
  .hero-stats { grid-template-columns: 1fr 1fr; max-width: 280px; }
  .casino-badges .badge:nth-child(n+4) { display: none; }
}

/* ── Large screens ── */
@media (min-width: 1200px) {
  .hero { padding: 60px 20px 52px; }
  .hero h1 { font-size: 3rem; }
}

/* ── Print ── */
@media print {
  .site-header, .site-footer, .scroll-top, .btn-play, .btn-visit,
  .btn-header, .menu-toggle, .hero-stats { display: none !important; }
  body { background: #fff; color: #000; font-size: 11pt; }
  h2, h3 { color: #000; }
  .casino-card { box-shadow: none; border: 1px solid #ccc; }
}


@media (max-width: 640px) {
}

/* ────────────────────────────────────────────────────────
   MOBILE CASINO CARDS — site green/gold theme
   Applied when comparison table is hidden (≤640px)
   ──────────────────────────────────────────────────────── */
@media (max-width: 640px) {

  /* Wrapper — transparent so page bg shows through */
  .mobile-casino-cards {
    display: flex;
    flex-direction: column;
    gap: 12px;
    padding: 14px;
    background: transparent;
  }

  /* Individual card — dark forest green + gold border */
  .mobile-casino-card {
    background: linear-gradient(
      145deg,
      #3D0000 0%,
      #5C0A14 60%,
      #2A0008 100%
    );
    border: 1px solid rgba(201, 162, 39, 0.4);
    border-radius: 14px;
    padding: 16px;
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 6px 12px;
    align-items: start;
    box-shadow:
      0 4px 20px rgba(0, 0, 0, 0.35),
      inset 0 1px 0 rgba(201, 162, 39, 0.12);
  }

  /* Rank pill — gold text, small caps */
  .mcc-rank {
    grid-column: 1 / -1;
    font-size: .68rem;
    font-weight: 800;
    color: #c9a227;
    text-transform: uppercase;
    letter-spacing: .09em;
  }

  /* Casino name */
  .mcc-name {
    font-size: 1.05rem;
    font-weight: 700;
    color: #fff;
    font-family: 'Playfair Display', serif;
    align-self: center;
  }

  /* Star rating — gold, right-aligned */
  .mcc-rating {
    font-size: .82rem;
    font-weight: 700;
    color: #c9a227;
    white-space: nowrap;
    align-self: center;
    text-align: right;
  }

  /* Bonus line */
  .mcc-bonus {
    grid-column: 1 / -1;
    font-size: .8rem;
    color: rgba(255, 255, 255, 0.85);
    line-height: 1.4;
  }

  /* Stat pills row */
  .mcc-stats {
    grid-column: 1 / -1;
    display: flex;
    flex-wrap: wrap;
    gap: 5px;
    margin: 2px 0;
  }

  /* Individual pill */
  .mcc-stat {
    font-size: .7rem;
    padding: 3px 9px;
    background: rgba(201, 162, 39, 0.12);
    border: 1px solid rgba(201, 162, 39, 0.28);
    border-radius: 20px;
    color: rgba(255, 255, 255, 0.82);
    white-space: nowrap;
  }

  /* Play button — gold gradient, dark text */
  .mcc-play-btn {
    grid-column: 1 / -1;
    display: block;
    background: linear-gradient(135deg, #c9a227 0%, #a8841a 100%);
    color: #0a2e1f;
    text-align: center;
    padding: 11px;
    border-radius: 8px;
    font-weight: 800;
    font-size: .88rem;
    text-decoration: none;
    margin-top: 6px;
    letter-spacing: .02em;
    box-shadow: 0 3px 12px rgba(201, 162, 39, 0.3);
  }

  .mcc-play-btn:hover {
    background: linear-gradient(135deg, #e0b52c 0%, #c9a227 100%);
  }
}
