/* ══════════════════════════════════════════
   SUKIRA AESTHETICS — RESPONSIVE
   Tablet (≤1024px) · Mobile (≤768px) · XS (≤380px)
══════════════════════════════════════════ */

/* ══════════════════════════════════════════
   TABLET (769px – 1024px)
══════════════════════════════════════════ */
@media (max-width: 1024px) {
  .wrap { padding: 0 24px; }
  .section { padding: 72px 0; }
  .hero-content { grid-template-columns: 1fr 360px !important; gap: 48px !important; padding: 130px 24px 80px !important; }
  .hero-cards { display: flex !important; }
  .nav-inner { padding: 0 20px; }
  .nav-logo-name { font-size: 19px; }
  .nav-links { display: none; }
  .nav-socials { display: none; }
  .nav-right .btn-appt { padding: 9px 14px; font-size: 12.5px; gap: 5px; }
  .nav-right .btn-appt svg { width: 14px; height: 14px; }
  .btn-call-nav { padding: 8px 14px; font-size: 12.5px; }
  .why-grid { grid-template-columns: repeat(2, 1fr) !important; gap: 14px; }
  .ba-slider-grid { grid-template-columns: 1fr 1fr; }
  .tc-grid { grid-template-columns: 1fr; }
  .ft-top { grid-template-columns: 1fr 1fr; gap: 28px; }
  .ct-grid { grid-template-columns: 1fr; }
  .tr-layout { grid-template-columns: 1fr; }
  .sidebar { position: static; }
  .branch-buttons { gap: 10px; }
  .clinic-loc-btn, .clinic-loc-hq { padding: 10px 18px !important; font-size: 13px !important; }
  .cta-banner-grid { grid-template-columns: 1fr !important; gap: 28px !important; padding: 48px 36px !important; }
  .cta-banner-grid > div:nth-child(2) { align-items: flex-start !important; }
  .hiw-panel { grid-template-columns: 48px 1fr !important; gap: 20px !important; }
  .hiw-panel-visual { display: none !important; }
  .hiw-tabs { padding: 0 18px; overflow-x: auto; scrollbar-width: none; }
  .hiw-tabs::-webkit-scrollbar { display: none; }
  .hiw-tab { padding: 18px 14px; flex-shrink: 0; }
  .hiw-tab-connector { min-width: 14px; flex: 0 0 auto; }
  .hiw-panels { padding: 32px 26px; }
  .hiw-autoplay { padding: 12px 26px; }
  .g-bar { grid-template-columns: 1fr !important; gap: 18px !important; text-align: center; padding: 22px !important; }
  .g-bar > *:first-child { justify-content: center; }
  .g-bar > *:nth-child(3) { justify-self: center; }
  .guide-desktop { display: none; }
  .guide-mobile { display: block; }
  .g-mcard { aspect-ratio: 3/4; min-height: 440px; }

  /* Carousel: 2 per slide on tablet */
  [data-mcarousel*="tablet"] {
    display: flex !important; grid-template-columns: none !important; grid-template-rows: none !important;
    overflow-x: auto; overflow-y: visible; scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch; scrollbar-width: none;
    gap: 16px !important; padding: 6px 4px 18px; margin: 0 -4px; scroll-behavior: smooth;
  }
  [data-mcarousel*="tablet"]::-webkit-scrollbar { display: none; }
  [data-mcarousel*="tablet"] > * {
    flex: 0 0 calc(50% - 8px) !important; min-width: 0; width: auto !important;
    max-width: none !important; scroll-snap-align: start;
    margin-top: 0 !important; animation: none !important; height: auto !important;
  }
  .m-carousel-wrap[data-mc-active="tablet"] .m-carousel-controls {
    display: flex; align-items: center; gap: 14px; margin-top: 20px;
  }
}

/* ══════════════════════════════════════════
   MOBILE (≤768px)
══════════════════════════════════════════ */
@media (max-width: 768px) {
  .wrap { padding: 0 18px; }
  .section { padding: 56px 0; }
  .section-sm { padding: 36px 0; }

  /* Nav */
  .nav-inner { padding: 0 14px; height: 60px; }
  .nav-logo-name { font-size: 17px; letter-spacing: .3px; }
  .nav-links { display: none; }
  .nav-socials { display: none; }
  .nav-right .btn-appt { display: none; }
  .btn-call-nav { padding: 8px 14px; font-size: 12.5px; gap: 5px; }
  .btn-call-nav svg { width: 12px; height: 12px; }

  /* Typography */
  .h1 { font-size: clamp(32px, 7.5vw, 42px) !important; letter-spacing: -.3px; }
  .h2 { font-size: clamp(26px, 6.5vw, 34px) !important; line-height: 1.18; }
  .h3 { font-size: clamp(20px, 5vw, 26px) !important; }
  .body-text { font-size: 14px; line-height: 1.72; }
  .label-tag { font-size: 10px; padding: 4px 12px; }

  /* Hero */
  .hero { min-height: auto; }
  .hero-content { grid-template-columns: 1fr !important; gap: 0 !important; padding: 110px 18px 56px !important; text-align: left; }
  .hero-title { font-size: clamp(30px, 8vw, 42px) !important; line-height: 1.12 !important; }
  .hero-title em { display: block; margin-top: 4px; }
  .hero-sub { font-size: 14.5px !important; line-height: 1.65 !important; margin: 18px 0 26px !important; max-width: 100% !important; }
  .hero-btns .btn { width: 100%; justify-content: center; padding: 14px 16px !important; font-size: 13.5px !important; }
  .hero-stats { margin-top: 32px !important; padding-top: 24px !important; display: grid !important; grid-template-columns: 1fr 1fr !important; gap: 18px 12px !important; }
  .hero-stats .stat-num { font-size: 28px !important; }
  .hero-cards { display: none !important; }

  /* Strip */
  .strip-inner { padding: 18px 16px; flex-direction: column; align-items: flex-start; gap: 14px; }
  .strip-div { display: none; }
  .strip-item { width: 100%; }

  /* Why */
  .why-grid { grid-template-columns: 1fr !important; gap: 12px !important; margin-top: 32px; }
  .why-card { padding: 22px 20px; }

  /* Branch buttons */
  .branch-buttons { flex-direction: column; width: 100%; gap: 10px !important; align-items: stretch !important; }
  .branch-buttons > a { width: 100%; justify-content: center; transform: none !important; padding: 13px 20px !important; font-size: 14px !important; }

  /* Before/After */
  .ba-slider-section { padding: 64px 0; }
  .ba-slider-grid { grid-template-columns: 1fr !important; }
  .ba-slider-card { aspect-ratio: 3/4; }

  /* Reviews */
  .g-bar { grid-template-columns: 1fr !important; gap: 16px !important; padding: 20px 18px !important; text-align: center; }
  .rev-grid { grid-template-columns: 1fr; }
  .rev-card { padding: 22px 20px; }
  .rev-text { font-size: 13px; line-height: 1.65; }

  /* Team */
  .team-card-clean { padding: 24px 20px; }
  .team-avatar { width: 64px; height: 64px; font-size: 24px; }
  .team-card-name { font-size: 19px; }
  .team-grid { grid-template-columns: 1fr !important; gap: 14px; }
  .vision-grid { grid-template-columns: 1fr !important; }

  /* Videos */
  .vid-card { aspect-ratio: 16/10; height: auto; }
  .vid-grid { grid-template-columns: 1fr; }

  /* HIW */
  .hiw-container { border-radius: 16px; margin: 0 -2px; }
  .hiw-tabs { padding: 0 14px; overflow-x: auto; scrollbar-width: none; -webkit-overflow-scrolling: touch; }
  .hiw-tabs::-webkit-scrollbar { display: none; }
  .hiw-tab { padding: 16px 12px; flex-shrink: 0; min-width: 90px; }
  .hiw-tab-num { font-size: 18px; }
  .hiw-tab-label { font-size: 10.5px; }
  .hiw-tab-connector { display: none; }
  .hiw-panels { padding: 28px 22px; }
  .hiw-panel { grid-template-columns: 1fr !important; gap: 14px !important; }
  .hiw-panel-ico { width: 46px; height: 46px; border-radius: 11px; margin-top: 0; }
  .hiw-panel-title { font-size: 22px; margin-bottom: 10px; }
  .hiw-panel-desc { font-size: 13.5px; line-height: 1.72; margin-bottom: 16px; }
  .hiw-panel-visual { display: none !important; }
  .hiw-autoplay { padding: 12px 22px; }

  /* CTA Banner */
  .cta-banner-grid { grid-template-columns: 1fr !important; gap: 24px !important; padding: 42px 26px !important; margin: 0 -2px !important; border-radius: 20px !important; }
  .cta-banner-grid > div:nth-child(2) { align-items: stretch !important; width: 100%; }
  .cta-banner-grid > div:nth-child(2) > .btn,
  .cta-banner-grid > div:nth-child(2) > a { width: 100%; justify-content: center; text-align: center; }

  /* Final CTA */
  .cta-section { padding: 64px 0; }
  .cta-section .h2 { font-size: clamp(26px, 6.5vw, 32px) !important; line-height: 1.2; }
  .cta-btns { flex-direction: column; gap: 10px !important; align-items: stretch; }
  .cta-btns .btn { width: 100%; justify-content: center; }

  /* Footer */
  .ft-top { grid-template-columns: 1fr !important; gap: 32px !important; }
  .ft-brand p { max-width: 100%; }
  .ft-bottom { flex-direction: column; text-align: center; gap: 8px; }

  /* Floats */
  .wa-wrap { right: 14px; bottom: 72px; }
  .wa-btn { width: 48px; height: 48px; }
  .wa-btn svg { width: 24px; height: 24px; }
  .back-top { right: 14px; bottom: 16px; width: 38px; height: 38px; }

  /* Inner pages */
  .tr-layout { grid-template-columns: 1fr !important; gap: 24px; padding: 28px 18px 56px; }
  .sidebar { position: static; }
  .page-hero { padding-bottom: 36px; }
  .ph-content { padding: 96px 18px 0; }
  .ct-grid { grid-template-columns: 1fr !important; gap: 28px !important; }
  .form-card { padding: 22px 18px; }
  .form-row { grid-template-columns: 1fr !important; }
  .g2 { grid-template-columns: 1fr; gap: 36px; }

  /* Guide mobile */
  .guide-desktop { display: none; }
  .guide-mobile { display: block; }
  .g-mcard { aspect-ratio: 3/4; min-height: 460px; }
  .g-mcard-title { font-size: 28px; }

  /* Carousel: 1 per slide on mobile */
  [data-mcarousel*="mobile"] {
    display: flex !important; grid-template-columns: none !important; grid-template-rows: none !important;
    overflow-x: auto; overflow-y: visible; scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch; scrollbar-width: none;
    gap: 14px !important; padding: 6px 4px 16px; margin: 0 -4px; scroll-behavior: smooth;
  }
  [data-mcarousel*="mobile"]::-webkit-scrollbar { display: none; }
  [data-mcarousel*="mobile"] > * {
    flex: 0 0 calc(100% - 24px) !important; min-width: 0; width: auto !important;
    max-width: none !important; scroll-snap-align: center;
    margin-top: 0 !important; animation: none !important; height: auto !important;
  }
  .m-carousel-wrap[data-mc-active="mobile"] .m-carousel-controls {
    display: flex; align-items: center; gap: 12px; margin-top: 18px; padding: 0 4px;
  }
}

/* ══════════════════════════════════════════
   EXTRA-SMALL (≤380px)
══════════════════════════════════════════ */
@media (max-width: 380px) {
  .h1 { font-size: 28px !important; }
  .h2 { font-size: 24px !important; }
  .hero-stats { grid-template-columns: 1fr 1fr !important; gap: 14px 10px !important; }
  .hero-stats .stat-num { font-size: 24px !important; }
  .nav-logo-name { font-size: 16px; }
  .btn-call-nav { padding: 7px 11px; font-size: 11.5px; }
}

/* ── REDUCED MOTION ── */
@media (prefers-reduced-motion: reduce) {
  [data-mcarousel] { scroll-behavior: auto !important; }
  .ba-slider-card { animation: none !important; }
}
