/* ==========================================================================
   Yes Madam Beautician Services - Responsive Style Overrides
   ========================================================================== */

/* --- Tablet Media Queries (max-width: 991px) --- */
@media (max-width: 991px) {
    .section-padding {
        padding: 90px 0;
    }
    
    .section-title h2 {
        font-size: 2.6rem;
    }
    
    /* Navbar collapse styles — dark glass on dark hero */
    .luxury-navbar .navbar-collapse {
        background-color: rgba(15, 13, 14, 0.95);
        backdrop-filter: blur(20px);
        -webkit-backdrop-filter: blur(20px);
        box-shadow: 0 15px 35px rgba(0, 0, 0, 0.3);
        border-radius: 20px;
        padding: 25px;
        margin-top: 15px;
        border: 1px solid rgba(212, 163, 115, 0.15);
    }

    .luxury-navbar.scrolled .navbar-collapse {
        background-color: rgba(255, 255, 255, 0.98);
        box-shadow: 0 15px 35px rgba(34, 34, 34, 0.08);
        border: 1px solid rgba(212, 163, 115, 0.2);
    }

    .luxury-navbar.scrolled .navbar-collapse .nav-link {
        color: var(--charcoal) !important;
    }
    
    .nav-link {
        margin: 10px 0;
        display: block;
        text-align: center;
        font-size: 0.95rem;
    }
    
    .nav-link::after {
        display: none;
    }
    
    /* Hero — stacked layout on tablet */
    .hero-dark {
        min-height: auto;
        padding-top: 130px;
        padding-bottom: 80px;
    }

    .hero-dark .row {
        flex-direction: column;
        text-align: center;
    }

    .hero-content {
        max-width: 100%;
        text-align: center !important;
        margin: 0 auto;
    }

    .hero-tagline-pill {
        justify-content: center;
    }

    .hero-title-dark {
        font-size: 3rem;
    }

    .hero-subtitle-dark {
        max-width: 100%;
        margin-left: auto;
        margin-right: auto;
    }

    .hero-buttons {
        justify-content: center;
        display: flex;
        flex-wrap: wrap;
        gap: 12px;
    }

    .hero-trust-strip {
        justify-content: center;
    }

    /* Model wrapper — centered below text */
    .hero-model-wrapper {
        width: 320px;
        height: 430px;
        margin: 50px auto 0;
    }

    .hero-badge-rating {
        left: -15px;
        top: 5%;
    }

    .hero-badge-safety {
        right: -20px;
        bottom: 8%;
    }

    /* Hide decorative corners and deco ring on tablet */
    .hero-corner,
    .hero-deco-ring {
        display: none;
    }

    /* Services Filter Nav */
    .services-filter-nav {
        gap: 10px 12px;
        margin-bottom: 40px;
    }

    /* Why Choose Us - stack branding visual */
    .why-visual-wrapper {
        margin-bottom: 30px;
    }

    /* Slider mobile container */
    .slider-container {
        height: 420px;
    }
    
    /* Appointment form */
    .appointment-card {
        padding: 50px 35px;
    }
    
    /* Luxury CTA tablet adjustments */
    .cta-banner-glass {
        padding: 60px 40px;
    }
    .cta-title {
        font-size: 2.5rem;
    }
}

/* --- Mobile Media Queries (max-width: 767px) --- */
@media (max-width: 767px) {
    .section-padding {
        padding: 70px 0;
    }
    
    .section-title {
        margin-bottom: 45px;
    }
    
    .section-title h2 {
        font-size: 2.2rem;
    }
    
    /* Hero mobile sizing */
    .hero-section {
        padding-top: 120px;
        padding-bottom: 60px;
    }
    
    .hero-model-container {
        width: 270px;
        height: 360px;
        margin: 35px auto 0;
        border-radius: 170px 170px 20px 20px;
    }
    
    .hero-title {
        font-size: 2.4rem;
    }
    
    .hero-subtitle {
        font-size: 1.05rem;
        margin-bottom: 30px;
    }
    
    .btn-premium {
        padding: 14px 28px;
        font-size: 0.85rem;
        width: 100%;
        margin-bottom: 12px;
    }
    
    .hero-content .btn-premium {
        margin-bottom: 15px;
        margin-right: 0 !important;
    }

    /* Services Filter Nav on mobile */
    .services-filter-nav {
        gap: 8px 10px;
        margin-bottom: 35px;
    }

    .filter-btn {
        padding: 10px 20px;
        font-size: 0.78rem;
        letter-spacing: 1px;
    }

    /* Why Choose Us mobile logo/stats */
    .why-visual-box {
        padding: 35px 20px;
    }

    .why-visual-title {
        font-size: 1.45rem;
    }

    .why-visual-desc {
        margin-bottom: 25px;
        font-size: 0.92rem;
    }

    .visual-brand {
        font-size: 1.8rem;
    }

    /* Slider mobile adjustment */
    .slider-wrapper-luxury {
        padding: 8px;
    }

    .slider-wrapper-inner-border {
        top: 2px;
        left: 2px;
        width: calc(100% - 4px);
        height: calc(100% - 4px);
        border-radius: 20px;
    }

    .slider-container {
        height: 320px;
        border-radius: 16px;
    }
    
    .label-badge {
        font-size: 0.75rem;
        padding: 8px 16px;
        bottom: 20px;
    }
    
    .label-before { left: 20px; }
    .label-after { right: 20px; }
    
    .slider-resize-handle {
        width: 48px;
        height: 48px;
        font-size: 1rem;
    }

    .handle-sparkle {
        display: none; /* Hide particles on small touchscreens */
    }
    
    /* Counter glass card stacks */
    .counter-grid-glass {
        padding: 35px 15px;
        border-radius: 20px;
    }

    .counter-item-glass {
        margin-bottom: 35px;
    }
    
    .counter-item-glass:last-child {
        margin-bottom: 0;
    }
    
    .counter-number {
        font-size: 3rem;
    }
    
    /* Testimonial adjustments */
    .testimonial-card {
        padding: 35px 25px;
    }
    
    .testimonial-card::before {
        font-size: 6rem;
        top: 15px;
        left: 20px;
    }
    
    .testimonial-text {
        font-size: 1rem;
        margin-bottom: 25px;
    }
    
    /* Luxury CTA mobile styling */
    .luxury-cta-section {
        padding: 60px 0;
    }
    
    .cta-banner-glass {
        padding: 50px 25px;
        border-radius: 30px;
    }
    
    .cta-title {
        font-size: 2rem;
        margin-bottom: 18px;
    }
    
    .cta-text {
        font-size: 0.95rem;
        margin-bottom: 30px;
    }
    
    .cta-buttons {
        gap: 15px;
    }
    
    .cta-buttons .btn-premium {
        width: 100%;
        margin-bottom: 0;
    }

    /* FAQ mobile styling */
    .faq-accordion .accordion-button {
        font-size: 1.15rem;
        padding: 18px 22px;
    }
    
    .faq-accordion .accordion-body {
        padding: 20px 22px;
        font-size: 0.95rem;
    }
    
    /* Form card mobile */
    .appointment-card {
        padding: 40px 20px;
        border-radius: 20px;
    }
    
    .appointment-header h3 {
        font-size: 2rem;
    }
    
    /* Map and Info Layout */
    .map-wrapper {
        height: 320px;
    }
    
    .contact-info-box {
        padding: 25px;
    }
    
    /* Footer widget spacing */
    .footer-widget {
        margin-bottom: 45px;
    }
    
    .footer-widget:last-child {
        margin-bottom: 0;
    }
    
    /* Sticky Actions for Mobile view */
    body {
        padding-bottom: 65px; /* Leave space for sticky CTA bar */
    }
    
    .mobile-sticky-cta {
        display: flex;
    }
    
    .whatsapp-float {
        bottom: 85px; /* Push WhatsApp button above call bar */
        right: 20px;
        width: 55px;
        height: 55px;
        font-size: 1.8rem;
    }

    .call-float {
        bottom: 85px; /* Push Call button above call bar */
        left: 20px;
        width: 55px;
        height: 55px;
        font-size: 1.5rem;
    }
}

/* --- Small Mobile Media Queries (max-width: 480px) --- */
@media (max-width: 480px) {
    .section-title h2 {
        font-size: 1.9rem;
    }
    
    .hero-title {
        font-size: 2.1rem;
    }
    
    .appointment-header h3 {
        font-size: 1.7rem;
    }
}
