@media (max-width: 1200px) {
  .gallery-grid { columns: 2; }
}

@media (max-width: 1024px) {
  .services-grid { grid-template-columns: repeat(2, 1fr); }
  .difference-grid { grid-template-columns: 1fr; gap: 48px; }
  .projects-grid { grid-template-columns: repeat(2, 1fr); }
  .booking-grid { grid-template-columns: 1fr; }
  .about-grid { grid-template-columns: 1fr; }
  .contact-grid { grid-template-columns: 1fr; }
  .footer-grid { grid-template-columns: 1fr; gap: 32px; }
  .reviews-grid { grid-template-columns: 1fr; }
  .plans-grid { grid-template-columns: repeat(2, 1fr); }
  .navbar-social { display: none !important; }
  .story-layout { grid-template-columns: 1fr; gap: 48px; }
  .story-images { height: 360px; }
  .about-showcase-grid { grid-template-columns: repeat(2, 1fr); }
  .stats-grid { grid-template-columns: repeat(2, 1fr) !important; }
  .founders-portraits { gap: 32px; }
  .founder-profile { flex: 0 1 340px; }
  .founder-portrait { width: 240px; height: 310px; }
  .founders-ampersand { font-size: 90px; }
}

@media (max-width: 768px) {
  .navbar-links { display: none; }
  .navbar-cta { display: none; }
  .navbar-hamburger { display: flex; }
  .section-padding { padding: 72px 0; }

  /* ─ Force inline grids to stack ─ */
  [style*="grid-template-columns: 1fr 1fr"],
  [style*="grid-template-columns:1fr 1fr"] {
    grid-template-columns: 1fr !important;
  }
  [style*="grid-template-columns:repeat(2,1fr)"],
  [style*="grid-template-columns: repeat(2, 1fr)"] {
    grid-template-columns: 1fr !important;
  }

  .navbar-social { display: none !important; }

  .services-grid { grid-template-columns: 1fr !important; max-width: 480px; margin-left: auto; margin-right: auto; }
  .projects-grid { grid-template-columns: 1fr !important; max-width: 480px; margin-left: auto; margin-right: auto; }

  /* ─ Hero video: use 16:9 crop instead of zoomed cover ─ */
  .hero { height: 100vh; height: 100svh; }
  #hero-video {
    object-position: center 30%;
  }
  .hero-logo-icon { width: 100px; height: 100px; }
  .hero-logo-name { font-size: clamp(38px, 12vw, 56px); }
  .hero-logo-sub { font-size: clamp(11px, 2.5vw, 16px); letter-spacing: 0.25em; }
  .hero-cta-btn { font-size: 13px; padding: 16px 40px; }
  .scroll-indicator { display: none; }

  /* ─ Page hero ─ */
  .page-hero { height: 45vh !important; min-height: 300px !important; }
  .page-hero-bg { object-position: center 40%; }
  .page-hero-content h1 { font-size: clamp(36px, 10vw, 56px); }

  .difference-section { padding: 60px 0; }
  .difference-image img { height: 320px; }
  .difference-headline { font-size: clamp(28px, 6vw, 44px); }

  .form-row { grid-template-columns: 1fr; }

  .footer-bottom { flex-direction: column; gap: 8px; text-align: center; }
  .footer-grid { gap: 24px; }
  .footer { padding: 48px 0 0; }

  .testimonial-card-dark { min-width: 300px; padding: 24px; }
  .about-image-wrap img { height: 300px; }

  /* ─ Founders: stack vertically ─ */
  .founders-section { padding: 72px 0 88px; }
  .founders-header { margin-bottom: 48px; }
  .founders-portraits { flex-direction: column; align-items: center; gap: 16px; }
  .founders-ampersand { font-size: 64px; margin: -8px 0; line-height: 0.8; }
  .founder-portrait { width: 220px; height: 285px; margin-bottom: 28px; }
  .founder-portrait-inner { border-radius: 160px 160px 16px 16px; }
  .founder-portrait-frame { border-radius: 164px 164px 20px 20px; }
  .founder-name { font-size: 28px; }
  .founder-bio { font-size: 15px; }

  /* ─ Story section ─ */
  .story-layout { grid-template-columns: 1fr; gap: 40px; }
  .story-images { height: 300px; }
  .story-img-main img { height: 200px; }
  .story-img-secondary img { height: 180px; }

  /* ─ Showcase ─ */
  .about-showcase-grid { grid-template-columns: repeat(2, 1fr); }

  /* ─ Stats ─ */
  .stats-grid { grid-template-columns: repeat(2, 1fr) !important; }
  .stat-number { font-size: clamp(40px, 10vw, 56px); }

  .faq-question { font-size: 15px; padding: 16px 20px; }

  .booking-grid { gap: 32px; }
  .contact-grid { gap: 32px; }
  .about-content p, .booking-info p, .service-detail-content p { font-size: 15px; }
  .review-card-lg { padding: 24px; }

  .service-subnav-inner { gap: 4px; }
  .service-subnav-btn { font-size: 10px; padding: 6px 12px; }
  .plans-grid { grid-template-columns: 1fr; max-width: 300px; margin-left: auto; margin-right: auto; }
  .steps-grid { grid-template-columns: 1fr !important; max-width: 400px; margin-left: auto; margin-right: auto; }
  .bundle-banner { padding: 28px 20px; margin: 40px auto; }
  .bundle-banner h3 { font-size: 22px; }

  .gallery-grid { columns: 2; }

  .mobile-cta-bar { display: flex; }
  body { padding-bottom: 56px; }
  .cookie-bar { bottom: 56px; }
}

@media (max-width: 480px) {
  .gallery-grid { columns: 1; }
  .container { padding: 0 16px; }
  .section-padding { padding: 60px 0; }

  /* ─ Hero ─ */
  .hero-logo { margin-bottom: 28px; }
  .hero-logo-icon { width: 80px; height: 80px; margin-bottom: 16px; }
  .hero-logo-name { font-size: clamp(32px, 13vw, 52px); }
  .hero-logo-sub { font-size: clamp(10px, 2.8vw, 14px); letter-spacing: 0.2em; }
  .hero-cta-btn { font-size: 12px; padding: 14px 36px; }
  .hero-content { padding-top: 60px; }

  .booking-form { padding: 24px; }
  .booking-phone { font-size: 18px; }
  .testimonial-card-dark { min-width: 240px; }
  .about-image-wrap img { height: 220px; }

  /* ─ Founders ─ */
  .founders-section { padding: 60px 0 72px; }
  .founders-header { margin-bottom: 36px; }
  .founders-label { font-size: 11px; letter-spacing: 0.3em; }
  .founders-portraits { gap: 12px; }
  .founders-ampersand { font-size: 48px; }
  .founder-portrait { width: 200px; height: 260px; margin-bottom: 24px; }
  .founder-portrait-inner { border-radius: 140px 140px 14px 14px; }
  .founder-portrait-frame { border-radius: 144px 144px 18px 18px; }
  .founder-name { font-size: 24px; }
  .founder-role { font-size: 10px; letter-spacing: 2px; padding: 5px 12px; }
  .founder-bio { font-size: 14px; line-height: 1.75; }
  .founder-divider { margin: 16px auto; }

  /* ─ Story ─ */
  .story-images { height: 240px; }
  .story-img-main { width: 75%; }
  .story-img-main img { height: 150px; }
  .story-img-secondary { width: 65%; }
  .story-img-secondary img { height: 130px; }
  .about-showcase-grid { grid-template-columns: 1fr 1fr; gap: 3px; }

  /* ─ Page hero ─ */
  .page-hero { height: 40vh !important; min-height: 260px !important; }
  .page-hero-content h1 { font-size: clamp(32px, 11vw, 48px); }
  .page-hero-content p { font-size: 15px; }
  .page-hero-content .label { font-size: 11px; }

  .section-headline { font-size: clamp(28px, 8vw, 48px); }
  .services-heading { font-size: clamp(32px, 8vw, 48px); }
  .projects-heading { font-size: clamp(32px, 8vw, 48px); }

  /* ─ Stats ─ */
  .stat-number { font-size: clamp(36px, 11vw, 48px); }
  .stat-label { font-size: 11px; letter-spacing: 1.5px; }
  .stat-box { padding: 20px 12px; }

  /* ─ Values ─ */
  .step-card .step-number { font-size: 48px !important; }
  .step-card h4 { font-size: 18px !important; }
  .step-card p { font-size: 14px !important; }

  .faq-question { font-size: 14px; padding: 14px 16px; }

  .footer-brand > p { max-width: 100%; }
  .service-card-clean-body { padding: 0; }
  .service-card-clean-body h3 { font-size: 18px; }
  .service-card-clean-img img { height: 220px; }
  .difference-image img { height: 240px; }

  .navbar-logo-badge { width: 44px; height: 44px; padding: 6px; }

  /* ─ Plinko modal ─ */
  .sms-modal.plinko-modal { max-width: 340px; }
  .plinko-title { font-size: 26px; }
  .plinko-header { padding: 22px 16px 12px; }
  .plinko-board-wrap { padding: 0 12px; }
  .plinko-btn { width: calc(100% - 24px); font-size: 14px; }
  .plinko-win-pct { font-size: 44px; }
  .plinko-modal .sms-form { padding: 0 16px; }
  .plinko-trust { padding: 10px 16px 16px; }

  /* ─ CTA buttons on mobile ─ */
  .btn-lg { font-size: 14px; padding: 14px 28px; }
  .btn-ghost.btn-lg { font-size: 13px; }
}

/* ─ Small phones (iPhone SE, Galaxy A) ─ */
@media (max-width: 375px) {
  .hero-logo-icon { width: 70px; height: 70px; }
  .hero-logo-name { font-size: 30px; }
  .hero-logo-sub { font-size: 10px; }
.hero-cta-btn { font-size: 11px; padding: 12px 28px; }
  .founder-portrait { width: 180px; height: 235px; }
  .founder-portrait-inner { border-radius: 120px 120px 12px 12px; }
  .founder-portrait-frame { border-radius: 124px 124px 16px 16px; }
  .founder-name { font-size: 22px; }
  .page-hero-content h1 { font-size: clamp(28px, 10vw, 40px); }
  .section-headline { font-size: clamp(26px, 8vw, 40px); }
  .stat-number { font-size: 32px; }
}
