/* ============================================================
   MVP PEINTURE — RESPONSIVE STYLES
   ============================================================ */

/* --- Large Desktop (1400px+) --- */
@media (min-width: 1400px) {
  :root { --section-pad: 120px 0; }
  .container { width: min(1320px, 92%); }
}

/* --- Tablet Landscape (1024px-) --- */
@media (max-width: 1024px) {
  :root { --section-pad: 80px 0; }

  .nav-links, .nav-cta { display: none; }
  .nav-toggle { display: flex; }

  .hero-inner { grid-template-columns: 1fr; }
  .hero-visual { display: none; }
  .hero-content { padding: 40px 0; max-width: 640px; }
  .hero-stats { gap: 28px; }
  .hero-diagonal { height: 60px; }

  .grid-2 { grid-template-columns: 1fr; gap: 40px; }
  .grid-3 { grid-template-columns: repeat(2, 1fr); }
  .grid-4 { grid-template-columns: repeat(2, 1fr); }

  .why-visual-stack { display: none; }
  .why-inner .grid-2 { grid-template-columns: 1fr; }

  .experience-inner {
    grid-template-columns: 1fr;
    padding: 50px 40px;
    text-align: center;
  }
  .experience-cta { text-align: center; }

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

  .service-full-card {
    grid-template-columns: 1fr;
    gap: 40px;
  }
  .service-full-card.reverse { direction: ltr; }

  .values-grid { grid-template-columns: repeat(2, 1fr); }
  .process-grid { grid-template-columns: 1fr; }
  .numbers-grid { grid-template-columns: repeat(2, 1fr); }
  .gallery-grid { grid-template-columns: 1fr 1fr; }
  .gallery-item.large { grid-column: span 2; }

  .contact-cta-inner { grid-template-columns: 1fr; gap: 48px; }
  .quote-form-wrap .form-card { padding: 40px; }
  .form-row { grid-template-columns: 1fr; }
}

/* --- Tablet Portrait (768px-) --- */
@media (max-width: 768px) {
  :root { --section-pad: 64px 0; }

  h1 { font-size: clamp(2rem, 8vw, 3rem); }
  h2 { font-size: clamp(1.6rem, 5vw, 2.2rem); }

  .nav-inner { height: 68px; }

  .hero { min-height: auto; padding: 100px 0 80px; }
  .hero-diagonal { height: 40px; }
  .hero-stats { flex-wrap: wrap; gap: 20px; }
  .hero-stat-num { font-size: 1.8rem; }

  .section-header { margin-bottom: 40px; }

  .grid-3 { grid-template-columns: 1fr; }
  .grid-4 { grid-template-columns: 1fr 1fr; }

  .gallery-grid { grid-template-columns: 1fr; }
  .gallery-item.large { grid-column: span 1; }
  .gallery-img { height: 240px; }
  .gallery-item.large .gallery-img { height: 280px; }

  .numbers-grid { grid-template-columns: repeat(2, 1fr); }
  .number-item { padding: 32px 20px; }
  .number-val { font-size: 2.2rem; }

  .experience-inner { padding: 40px 28px; }

  .service-card { padding: 28px 24px; }

  .form-card { padding: 32px 24px; }
  .form-row { grid-template-columns: 1fr; gap: 0; }

  .footer-top { grid-template-columns: 1fr; gap: 36px; }
  .footer-bottom { flex-direction: column; gap: 8px; text-align: center; }
  .footer-brand p { max-width: 100%; }

  .page-hero { padding: 130px 0 60px; }
  .page-hero::after { height: 40px; }

  .values-grid { grid-template-columns: 1fr; }
  .service-full-visual { height: 260px; }
  .why-quote { padding: 24px; }

  .quote-form-wrap .form-card { padding: 28px 20px; }
}

/* --- Mobile (480px-) --- */
@media (max-width: 480px) {
  :root { --section-pad: 56px 0; }
  .container { width: 92%; }

  .btn { padding: 14px 28px; font-size: 0.8rem; }

  h1 { font-size: 2rem; }
  h2 { font-size: 1.5rem; }

  .hero { padding: 90px 0 64px; }
  .hero-badge { font-size: 0.65rem; padding: 6px 14px; }
  .hero-desc { font-size: 0.95rem; }
  .hero-actions { flex-direction: column; align-items: flex-start; }
  .hero-actions .btn { width: 100%; justify-content: center; }
  .hero-stats { flex-direction: column; gap: 12px; }

  .section-header { margin-bottom: 32px; }
  .section-header h2 { margin-bottom: 12px; }

  .service-card { padding: 24px 20px; }
  .service-icon { width: 52px; height: 52px; }

  .experience-inner { padding: 32px 20px; border-radius: 10px; }
  .experience-num { font-size: 2.8rem; }

  .gallery-grid { gap: 12px; }
  .gallery-img { height: 200px; }
  .gallery-item.large .gallery-img { height: 220px; }

  .numbers-grid { grid-template-columns: 1fr; }

  .why-quote { padding: 20px; }
  .why-quote p { font-size: 1rem; }

  .form-card { padding: 24px 16px; border-radius: 10px; }
  .form-submit .btn { font-size: 0.78rem; }

  .contact-info-item { flex-direction: column; align-items: flex-start; gap: 8px; }

  .hero-badge-float { right: 0; top: 20px; padding: 14px 18px; }
  .hero-badge-float-icon { width: 36px; height: 36px; }

  .footer-top { padding: 48px 0 36px; gap: 28px; }
  .footer-col { min-width: 0; }

  .nav-mobile { padding: 80px 24px 40px; }
  .nav-mobile a { font-size: 1.2rem; }

  .page-hero h1 { font-size: 1.8rem; }

  .testimonial-card { padding: 24px 20px; }
}

/* --- Focus & Accessibility --- */
:focus-visible {
  outline: 2px solid var(--red);
  outline-offset: 3px;
  border-radius: var(--radius);
}

/* --- Print --- */
@media print {
  .site-nav, .nav-mobile, .hero, .contact-cta-section { display: none; }
  body { font-size: 12pt; }
  h1, h2, h3 { page-break-after: avoid; }
  img { max-width: 100% !important; }
}

/* --- Reduced Motion --- */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
  .reveal, .reveal-left, .reveal-right {
    opacity: 1 !important;
    transform: none !important;
  }
}
