/* ===== RESPONSIVE STYLES ===== */

/* Tablet Landscape */
@media (max-width: 1024px) {
    .services-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .layout-types-grid {
        grid-template-columns: repeat(3, 1fr);
    }

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

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

    .portfolio-large {
        grid-column: 1 / 2;
        grid-row: 1 / 2;
    }

    .portfolio-large .portfolio-image {
        min-height: 280px;
    }

    .process-grid {
        flex-wrap: wrap;
        gap: 24px;
    }

    .process-connector {
        display: none;
    }

    .process-step {
        flex: 1 1 calc(50% - 24px);
        min-width: 200px;
    }
}

/* Tablet Portrait */
@media (max-width: 768px) {
    .section {
        padding: 80px 0;
    }

    /* Navigation */
    .hamburger {
        display: flex;
    }

    .nav-menu {
        position: fixed;
        top: 0;
        right: -100%;
        width: 100%;
        height: 100vh;
        background: var(--white);
        flex-direction: column;
        align-items: center;
        justify-content: center;
        gap: 0;
        transition: right 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
        z-index: 999;
    }

    .nav-menu.open {
        right: 0;
    }

    .nav-link {
        font-size: 24px;
        font-weight: 400;
        font-family: 'Playfair Display', serif;
        padding: 12px 0;
    }

    .nav-link::after {
        display: none;
    }

    .nav-cta {
        font-size: 16px;
        font-family: 'Inter', sans-serif;
        margin-top: 16px;
        padding: 14px 32px;
    }

    /* Hero */
    .hero {
        min-height: auto;
        padding: 140px 24px 80px;
    }

    .hero-subtitle {
        font-size: 16px;
    }

    .hero-scroll-indicator {
        display: none;
    }

    /* Stats */
    .stats-grid {
        flex-wrap: wrap;
        gap: 24px;
    }

    .stat-item {
        flex: 1 1 calc(50% - 24px);
        padding: 12px 0;
    }

    .stat-divider {
        display: none;
    }

    .stat-number {
        font-size: 40px;
    }

    /* Services */
    .services-grid {
        grid-template-columns: 1fr;
        gap: 16px;
    }

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

    .service-arrow {
        opacity: 1;
    }

    /* Portfolio */
    .portfolio-showcase {
        grid-template-columns: 1fr;
    }

    .portfolio-large .portfolio-image {
        min-height: 240px;
    }

    .portfolio-image {
        min-height: 220px !important;
    }

    .portfolio-overlay {
        opacity: 1;
    }

    /* Process */
    .process-step {
        flex: 1 1 100%;
    }

    .process-number {
        font-size: 36px;
    }

    /* Testimonials */
    .testimonial-card {
        padding: 32px 24px;
    }

    .testimonial-text {
        font-size: 16px;
    }

    /* CTA */
    .cta-actions {
        flex-direction: column;
        align-items: center;
    }

    /* Footer */
    .footer-grid {
        grid-template-columns: 1fr;
        gap: 32px;
    }

    .footer-bottom {
        flex-direction: column;
        gap: 16px;
        text-align: center;
    }

    /* Forms */
    .form-row {
        grid-template-columns: 1fr;
    }

    .option-cards {
        grid-template-columns: 1fr;
    }

    /* iOS input zoom prevention — keep font-size >= 16px so Safari doesn't auto-zoom */
    .form-group input,
    .form-group select,
    .form-group textarea,
    button {
        font-size: 16px;
    }

    /* Packages Grid */
    .packages-grid {
        grid-template-columns: 1fr !important;
        gap: 20px;
    }

    /* Services Detail */
    .service-detail {
        flex-direction: column !important;
    }

    .service-detail-image {
        min-height: 240px !important;
    }

    .service-detail:nth-child(even) {
        flex-direction: column !important;
    }

    /* Kitchen & Wardrobe layout-type sub-grids */
    .layout-types-grid {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 12px !important;
    }

    .layout-type-card {
        padding: 20px 16px !important;
    }

    /* Contact Grid */
    .contact-grid {
        grid-template-columns: 1fr !important;
    }

    /* Blog Grid */
    .blog-grid {
        grid-template-columns: 1fr !important;
    }

    /* Careers */
    .job-card {
        flex-direction: column !important;
        gap: 16px !important;
    }

    .job-card .btn {
        align-self: flex-start;
    }
}

/* Hero buttons — stack at 600px before they become cramped side-by-side */
@media (max-width: 600px) {
    .hero-actions {
        flex-direction: column;
        align-items: stretch;
    }

    .hero-actions .btn {
        width: 100%;
        text-align: center;
    }
}

/* Mobile */
@media (max-width: 480px) {
    .section {
        padding: 60px 0;
    }

    .container {
        padding: 0 16px;
    }

    .hero {
        padding: 120px 16px 60px;
    }

    .hero-title {
        font-size: 36px;
    }

    .hero-actions {
        flex-direction: column;
        align-items: center;
    }

    .btn {
        width: 100%;
        text-align: center;
    }

    .btn-large {
        padding: 16px 32px;
    }

    .section-title {
        font-size: 28px;
    }

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

    .stat-item {
        flex: 1 1 100%;
    }

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

    .cta-content h2 {
        font-size: 28px;
    }

    .page-hero {
        padding: 120px 16px 60px;
    }

    .page-hero .hero-title {
        font-size: 32px;
    }

    /* Nav mobile adjustments */
    .nav-link {
        font-size: 20px;
    }
}

/* Very small screens */
@media (max-width: 360px) {
    .hero-title {
        font-size: 30px;
    }

    .section-title {
        font-size: 24px;
    }

    .stat-number {
        font-size: 32px;
    }
}

/* Print Styles */
@media print {
    .navbar,
    .hamburger,
    #preloader,
    .hero-scroll-indicator,
    .testimonial-controls,
    .cta-section,
    .footer-social {
        display: none !important;
    }

    .hero {
        min-height: auto;
        padding-top: 40px;
    }

    body {
        font-size: 12pt;
    }

    .section {
        padding: 40px 0;
        page-break-inside: avoid;
    }
}