/* =====================================================
   PrintShubh — Responsive Breakpoints
   ===================================================== */

@media (max-width: 1100px) {
    h1.headline { font-size: 56px; letter-spacing: -1.5px; }
    .hero-grid { gap: 48px; }
  }

@media (max-width: 880px) {
    .nav { padding: 22px 5vw; }
    .nav-links { display: none; }

    .hero {
      padding: 130px 5vw 80px;
      text-align: center;
      min-height: auto;
    }
    .hero-grid {
      grid-template-columns: 1fr;
      gap: 56px;
    }
    .content {
      max-width: 100%;
      margin: 0 auto;
      order: 1;
    }
    .visual { order: 2; aspect-ratio: 4 / 4.6; }

    .badge { margin-bottom: 22px; }
    h1.headline {
      font-size: 44px;
      letter-spacing: -1px;
      line-height: 1.1;
    }
    .description {
      font-size: 16px;
      line-height: 1.75;
      margin: 0 auto 30px;
    }
    .cta-row {
      flex-direction: column;
      align-items: stretch;
      width: 100%;
      max-width: 320px;
      margin: 0 auto 30px;
    }
    .btn { width: 100%; padding: 16px 24px; }
    .trust { justify-content: center; }

    .review-card {
      left: 16px;
      bottom: 18px;
      padding: 14px 16px;
      min-width: auto;
      max-width: calc(100% - 32px);
    }
    .premium-tag { right: 12px; top: 14px; padding: 10px 12px; }
  }

@media (max-width: 480px) {
    h1.headline { font-size: 36px; }
    .badge { font-size: 12px; padding: 8px 14px; }
    .review-card .customers { font-size: 12px; }
    .review-card .stars { font-size: 14px; }
  }

@media (prefers-reduced-motion: reduce) {
    .on-scroll, .reveal { opacity: 1 !important; transform: none !important; animation: none !important; }
    .visual-frame video { display: none; }
  }

@media (max-width: 1100px) {
    .why-grid { grid-template-columns: repeat(2, 1fr); gap: 24px; }
    .why-title { font-size: 44px; }
  }

@media (max-width: 880px) {
    .why { padding: 80px 5vw; }
    .why-header { margin-bottom: 56px; }
    .why-title { font-size: 36px; letter-spacing: -1px; }
    .why-desc { font-size: 16px; }
    .feature-card { padding: 36px 28px 32px; }
  }

@media (max-width: 560px) {
    .why-grid { grid-template-columns: 1fr; gap: 20px; }
    .why-title { font-size: 30px; }
    .feature-icon { width: 56px; height: 56px; border-radius: 16px; margin-bottom: 22px; }
    .feature-title { font-size: 20px; }
  }

@media (max-width: 1100px) {
    .collection-title { font-size: 42px; }
    .cat-card.large .cat-title { font-size: 30px; }
  }

@media (max-width: 880px) {
    .collection { padding: 80px 5vw; }
    .collection-header { margin-bottom: 48px; }
    .collection-title { font-size: 34px; letter-spacing: -1px; }
    .collection-desc { font-size: 16px; }

    .collection-top,
    .collection-bottom {
      grid-template-columns: 1fr;
      gap: 22px;
    }
    .collection-top { margin-bottom: 22px; }

    .cat-card.large,
    .cat-card.small { aspect-ratio: 16 / 11; }

    .cat-card.large .cat-title,
    .cat-card.small .cat-title { font-size: 26px; }

    .cat-card .floating { left: 22px; right: 22px; bottom: 22px; }
  }

@media (max-width: 480px) {
    .collection-title { font-size: 28px; }
    .cat-card.large,
    .cat-card.small { aspect-ratio: 4 / 4.2; }
    .cat-card.large .cat-title,
    .cat-card.small .cat-title { font-size: 22px; }
    .cat-card .cat-text { font-size: 13px; }
  }

@media (max-width: 1100px) {
    .masonry { column-count: 2; }
  }

@media (max-width: 600px) {
    .masonry { column-count: 1; }
    .masonry-item, .masonry-overlay { border-radius: 20px; }
  }

@media (max-width: 1100px) {
    .sec-title { font-size: 42px; }
    .hw-timeline { grid-template-columns: repeat(2, 1fr); gap: 40px 28px; }
    .hw-timeline::before { display: none; }
    .best-grid { grid-template-columns: repeat(2, 1fr); }
    .t-grid { grid-template-columns: 1fr; max-width: 620px; margin: 0 auto; }
    .studio-gallery {
      grid-template-columns: 1fr 1fr;
      grid-template-rows: 260px 220px 220px;
    }
    .studio-tile.large { grid-row: span 1; grid-column: span 2; }
    .footer-grid { grid-template-columns: 1.5fr 1fr 1fr; }
    .footer-grid .footer-col-brand { grid-column: 1 / -1; }
    .cta-title { font-size: 44px; }
  }

@media (max-width: 880px) {
    .how-works,
    .best,
    .testimonials,
    .studio-bts,
    .faq { padding: 80px 5vw; }
    .inspiration { padding: 100px 5vw; }
    .final-cta { padding: 70px 5vw; }
    .sec-title { font-size: 34px; letter-spacing: -1px; }
    .sec-header-center { margin-bottom: 50px; }

    .hw-timeline { grid-template-columns: 1fr; gap: 36px; }
    .best-header { margin-bottom: 40px; }
    .inspiration-header { margin-bottom: 50px; }
    .studio-gallery {
      grid-template-columns: 1fr;
      grid-template-rows: 240px 240px 240px 240px;
    }
    .studio-tile.large { grid-column: span 1; }

    .cta-card { padding: 60px 28px; border-radius: 24px; }
    .cta-title { font-size: 32px; }
    .cta-text { font-size: 15.5px; }

    .footer-grid {
      grid-template-columns: 1fr 1fr;
      gap: 40px 30px;
    }
    .footer-grid .footer-col-brand { grid-column: 1 / -1; }
    .footer-bottom { flex-direction: column; text-align: center; }
    .footer-bottom .legal a { margin: 0 10px; }
  }

@media (max-width: 560px) {
    .best-grid { grid-template-columns: 1fr; max-width: 360px; margin: 0 auto; }
    .footer-grid { grid-template-columns: 1fr; }
    .cta-title { font-size: 28px; }
    .faq-item summary { padding: 18px 20px; font-size: 15px; }
    .faq-answer { padding: 0 20px 20px; font-size: 14px; }
  }

@media (max-width: 1100px) {
    .shop-grid { grid-template-columns: repeat(3, 1fr); }
    .cat-banner { grid-template-columns: 1fr; min-height: auto; }
    .cat-banner-text h3 { font-size: 32px; }
  }

@media (max-width: 760px) {
    .shop-grid { grid-template-columns: repeat(2, 1fr); gap: 18px; }
    .tab { padding: 12px 16px; font-size: 13px; }
    .cat-banner-text { padding: 36px 28px; }
    .cat-banner-text h3 { font-size: 26px; }
    .cat-banner-image { min-height: 220px; }
  }

@media (max-width: 480px) {
    .shop-grid { grid-template-columns: 1fr; max-width: 360px; margin: 0 auto; }
  }

@media (max-width: 1100px) {
    .studio-board { grid-template-columns: 1fr; gap: 18px; }
    .studio-header-block h2 { font-size: 38px; }
    .preview-stage { min-height: 460px; }
  }

@media (max-width: 760px) {
    .studio { padding: 80px 5vw; }
    .studio-board { padding: 16px; border-radius: 24px; }
    .studio-panel { padding: 20px 16px; border-radius: 16px; }
    .studio-header-block h2 { font-size: 28px; letter-spacing: -0.8px; }
    .studio-header-block p { font-size: 15px; }
    .preview-stage { padding: 24px 16px; min-height: 380px; }
    .summary-total .val { font-size: 26px; }
    .size-label { top: 80px; right: 16px; font-size: 10.5px; padding: 6px 10px; }
  }

@media (max-width: 1100px) {
    .detail-grid { grid-template-columns: 1fr; gap: 50px; }
    .detail-gallery, .detail-info { position: static; }
    .detail-title { font-size: 34px; }
    .timeline-grid { grid-template-columns: repeat(2, 1fr); gap: 32px; }
    .timeline-grid::before { display: none; }
  }

@media (max-width: 760px) {
    .detail { padding: 80px 5vw; }
    .detail-gallery { grid-template-columns: 70px 1fr; gap: 12px; }
    .detail-title { font-size: 28px; }
    .detail-price .now { font-size: 30px; }
    .delivery-timeline { padding: 40px 24px; border-radius: 22px; }
    .timeline-grid { grid-template-columns: 1fr; gap: 28px; }
  }

@media (max-width: 1100px) {
    .nav-links li:not(.has-mega) { display: none; }
    .nav-phone { display: none; }
    .search-wrap { display: none; }
    .icon-btn[data-tip="wishlist"] { display: none; }
    .has-mega .mega-trigger { display: none; }
    .has-mega .mega-panel { display: none; }
  }

@media (max-width: 760px) {
    .nav-cta { display: none; }
    .nav-wa span { display: none; }
    .nav-wa { padding: 10px 12px; }
    .burger { display: flex; }
  }

@media (max-width: 1100px) { .cats-grid { grid-template-columns: repeat(4, 1fr); } }

@media (max-width: 760px)  { .cats-grid { grid-template-columns: repeat(3, 1fr); gap: 14px; } .cat-tile-name { font-size: 15px; } }

@media (max-width: 460px)  { .cats-grid { grid-template-columns: repeat(2, 1fr); } }

@media (max-width: 1100px) { .printcat-grid { grid-template-columns: repeat(3, 1fr); } }

@media (max-width: 760px)  {
    .printcat { padding: 80px 5vw; }
    .printcat-grid { grid-template-columns: repeat(2, 1fr); gap: 16px; }
    .printcat-header { grid-template-columns: 1fr; gap: 18px; padding-bottom: 22px; margin-bottom: 30px; }
    .pc-card-name { font-size: 15px; }
    .pc-card-price { font-size: 17px; }
  }

@media (max-width: 460px) { .printcat-grid { grid-template-columns: 1fr; max-width: 360px; margin: 0 auto; } }

@media (max-width: 760px) {
    .qv-panel { grid-template-columns: 1fr; max-height: 92vh; border-radius: 22px; }
    .qv-image { min-height: 280px; }
    .qv-info { padding: 30px 26px; }
    .qv-title { font-size: 24px; }
    .qv-price .now { font-size: 24px; }
  }

@media (max-width: 760px) {
    .wa-float { bottom: 18px; right: 18px; width: 54px; height: 54px; }
  }

@media (max-width: 1100px) {
    .hero-grid { grid-template-columns: 1fr !important; }
    .visual { min-height: 480px; }
  }

@media (prefers-reduced-motion: reduce) {
    .hero-video { animation: none; transform: scale(1.04); }
    .visual::before { animation: none; }
  }

@media (max-width: 1100px) {
    .hero-float-cards { display: none; }
  }

@media (max-width: 880px) {
    .search-wrap.expanded {
      position: fixed !important;
      top: 0; left: 0; right: 0;
      width: 100% !important;
      height: 64px;
      background: #fff;
      padding: 12px 16px;
      z-index: 200;
      box-shadow: 0 8px 24px rgba(0,0,0,0.08);
      display: flex;
      align-items: center;
      gap: 10px;
    }
    .search-wrap.expanded .search-input {
      flex: 1;
      width: 100% !important;
      font-size: 16px;
      padding: 12px 16px;
    }
    .search-wrap.expanded .search-toggle {
      order: 2;
    }
  }

@media (max-width: 760px) {
    .why, .collection, .how-works, .best, .printcat,
    .testimonials, .contact-section, .final-cta,
    .cats-overview {
      padding-top: 60px !important;
      padding-bottom: 60px !important;
    }
  }

@media (max-width: 1024px) {
    .cat5-grid { grid-template-columns: 1fr 1fr; gap: 14px; }
    .cat5-tile.cat5-tall { grid-column: 1 / -1; min-height: 320px; }
    .cat5-stack { flex-direction: row; }
    .cat5-stack .cat5-tile { min-height: 220px; }
  }