/* =====================================================
   DERMICS THEME - Responsive Styles
   ===================================================== */

/* ---------- TABLET (max 1200px) ---------- */
@media (max-width: 1200px) {
    .services-grid { grid-template-columns: repeat(2, 1fr); }
    .features-grid { grid-template-columns: repeat(2, 1fr); }
    .testimonials-slider { grid-template-columns: repeat(2, 1fr); }
    .footer-grid { grid-template-columns: repeat(2, 1fr); gap: 40px; }
    .ba-grid { grid-template-columns: repeat(2, 1fr); }
    .contact-grid { grid-template-columns: 1fr; gap: 40px; }
}

/* ---------- TABLET SMALL (max 991px) ---------- */
@media (max-width: 991px) {
    .dermics-section,
    .section-padding { padding: 70px 0; }
    .cta-section { padding: 80px 0; }
    .main-nav { display: none; }
    .header-cta .header-phone { display: none; }
    .mobile-toggle { display: flex; }

    .about-grid { grid-template-columns: 1fr; gap: 40px; }
    .about-images { height: 400px; }

    .benefit-item { grid-template-columns: 1fr; gap: 30px; }
    .benefit-item.reverse { direction: ltr; }
    .benefit-image { height: 300px; }

    .blog-page-grid { grid-template-columns: 1fr; }
    .service-single-grid { grid-template-columns: 1fr; }
    .contact-grid { grid-template-columns: 1fr; }
    .map-grid { grid-template-columns: 1fr; }
    .map-wrap { height: 350px; }

    .benefits-grid { grid-template-columns: repeat(2, 1fr); }
    .blog-grid { grid-template-columns: repeat(2, 1fr); }
}

/* ---------- MOBILE (max 767px) ---------- */
@media (max-width: 767px) {
    .dermics-section,
    .section-padding { padding: 60px 0; }
    .cta-section { padding: 70px 0; }
    .container { padding: 0 15px; }

    .top-bar { display: none; }
    .site-header.has-top-bar { top: 0; }

    h1 { font-size: 2rem; }
    h2 { font-size: 1.75rem; }
    h3 { font-size: 1.35rem; }

    .hero-section { min-height: 85vh; }
    .hero-content { padding: 0 10px; }
    .hero-title { font-size: clamp(2rem, 8vw, 3rem) !important; }
    .hero-description { font-size: 1rem; }
    .hero-buttons { flex-direction: column; width: 100%; }
    .hero-buttons .btn { width: 100%; justify-content: center; }
    .hero-float { display: none; }

    .services-grid { grid-template-columns: 1fr; }
    .features-grid { grid-template-columns: 1fr; }
    .testimonials-slider { grid-template-columns: 1fr; }
    .ba-grid { grid-template-columns: 1fr; }
    .benefits-grid { grid-template-columns: 1fr; }
    .blog-grid { grid-template-columns: 1fr; }

    .about-images { height: 320px; }
    .about-image-main { width: 80%; }
    .about-image-secondary { width: 50%; height: 50%; }
    .about-stats-row { flex-wrap: wrap; gap: 20px; }
    .about-stat { flex: 1; min-width: 100px; }

    .benefit-image { height: 250px; }

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

    .page-hero { padding: 120px 0 80px; }
    .page-hero-content h1 { font-size: 2rem; }

    .blog-post-item { grid-template-columns: 1fr; }
    .contact-info-cards { grid-template-columns: 1fr; }

    .section-subtitle { font-size: 0.75rem; letter-spacing: 0.15em; }

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

    .error-404 h1 { font-size: 5rem; }

    .back-to-top { bottom: 20px; right: 20px; width: 44px; height: 44px; }
}

/* ---------- SMALL MOBILE (max 480px) ---------- */
@media (max-width: 480px) {
    .hero-title { font-size: 1.75rem !important; }
    .hero-description { font-size: 0.9rem; }

    .service-card-body { padding: 20px; }
    .service-card-image { height: 220px; }

    .testimonial-card { padding: 25px; }

    .about-experience-badge { display: none; }

    .feature-card { padding: 25px 20px; }

    .footer-social a { width: 38px; height: 38px; }
}

/* ---------- LARGE SCREENS (min 1600px) ---------- */
@media (min-width: 1600px) {
    .container { max-width: 1400px; }
    .hero-title { font-size: 4.5rem !important; }
}

/* ---- Trust Bar Responsive ---- */
@media (max-width: 991px) {
    .trust-bar { margin-top: -30px; padding: 25px 20px; }
    .trust-bar__grid { grid-template-columns: repeat(2, 1fr); gap: 20px; }
    .trust-item { border-right: none; border-bottom: 1px solid var(--color-border); padding-bottom: 15px; }
    .trust-item:nth-child(3), .trust-item:nth-child(4) { border-bottom: none; }
}
@media (max-width: 480px) {
    .trust-bar { margin-top: -20px; }
    .trust-bar__grid { grid-template-columns: 1fr; }
    .trust-item { border-bottom: 1px solid var(--color-border); }
    .trust-item:last-child { border-bottom: none; }
}

/* ---- Benefits Alternating Responsive ---- */
@media (max-width: 991px) {
    .benefit-item { grid-template-columns: 1fr; gap: 30px; }
    .benefit-item.reverse { direction: ltr; }
    .benefit-image { max-height: 300px; }
}

/* ---- Process Steps Responsive ---- */
@media (max-width: 991px) {
    .process-steps { flex-direction: column; align-items: center; gap: 20px; }
    .process-step { max-width: 100%; }
    .process-step__connector { width: 2px; height: 40px; margin: 0; }
}

/* ---- Contact Grid Responsive ---- */
@media (max-width: 991px) {
    .contact-grid { grid-template-columns: 1fr; gap: 30px; }
}
@media (max-width: 767px) {
    .contact-info-cards { grid-template-columns: 1fr; }
    .contact-form-area .contact-form-wrap { padding: 25px; }
}

/* ---- CTA Buttons Responsive ---- */
@media (max-width: 480px) {
    .cta-buttons { flex-direction: column; align-items: center; }
    .cta-buttons .btn { width: 100%; text-align: center; }
}

/* ---- Testimonials Carousel Responsive ---- */
@media (max-width: 991px) {
    .testimonials-carousel .testimonial-slide { min-width: 50% !important; max-width: 50%; width: 50%; }
}
@media (max-width: 767px) {
    .testimonials-carousel .testimonial-slide { min-width: 100% !important; max-width: 100%; width: 100%; }
    .testimonials-prev, .testimonials-next { width: 42px; height: 42px; font-size: 14px; }
}

/* ---- Contact Home Section Responsive ---- */
@media (max-width: 991px) {
    .contact-home-section .contact-home-grid { grid-template-columns: 1fr !important; }
    .contact-home-info__inner { padding: 35px 30px; }
    .contact-form-box { padding: 35px 30px; }
}
@media (max-width: 480px) {
    .pf-row { grid-template-columns: 1fr; }
    .contact-home-info__inner { padding: 30px 20px; }
    .contact-form-box { padding: 30px 20px; }
}

/* ---- About Page Responsive ---- */
@media (max-width: 1200px) {
    .team-grid { grid-template-columns: repeat(2, 1fr); }
    .values-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 767px) {
    .mv-grid { grid-template-columns: 1fr; }
    .team-grid { grid-template-columns: 1fr; }
    .values-grid { grid-template-columns: 1fr; }
    .team-card__image { height: 220px; }
    .mv-card { padding: 35px 25px; }
    .value-card { padding: 30px 20px; }
}

/* ---- Contact Page Responsive ---- */
@media (max-width: 1200px) {
    .contact-cards-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 991px) {
    .contact-main-grid { grid-template-columns: 1fr; }
}
@media (max-width: 767px) {
    .contact-cards-grid { grid-template-columns: 1fr; }
    .contact-page-card { padding: 30px 20px; }
    .contact-main-form .contact-form-box { padding: 30px 20px; }
    .faq-item__question { font-size: 0.95rem; padding: 16px 20px; }
}

/* ---- Blog Page Responsive ---- */
@media (max-width: 1200px) {
    .blog-page-layout { grid-template-columns: 1fr 300px; gap: 35px; }
}
@media (max-width: 991px) {
    .blog-page-layout { grid-template-columns: 1fr; }
    .blog-page-sidebar { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
}
@media (max-width: 767px) {
    .blog-posts-grid { grid-template-columns: 1fr; }
    .blog-page-sidebar { grid-template-columns: 1fr; }
    .blog-post-card__image { height: 180px; }
    .blog-categories-bar { gap: 6px; }
    .blog-cat-btn { padding: 6px 14px; font-size: 0.8rem; }
}

/* ---- Single Post Responsive ---- */
@media (max-width: 1200px) {
    .single-post-layout { grid-template-columns: 1fr 300px; gap: 35px; }
    .share-float { display: none; }
}
@media (max-width: 991px) {
    .single-post-layout { grid-template-columns: 1fr; }
    .share-float { display: none; }
    .related-posts-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 767px) {
    .post-hero { padding: 140px 0 60px; }
    .post-hero__title { font-size: 1.75rem !important; }
    .post-hero__meta { gap: 12px; }
    .post-hero__meta-item { font-size: 0.8rem; }
    .author-box { flex-direction: column; text-align: center; align-items: center; }
    .post-nav { grid-template-columns: 1fr; }
    .related-posts-grid { grid-template-columns: 1fr; }
    .single-post-share { flex-direction: column; align-items: flex-start; }
    .share-btn { font-size: 0.75rem; }
}
