/**
 * SuiteTheme Demo - Responsive Stylesheet
 * Mobile-first responsive breakpoints
 * @package SuiteTheme_Demo
 */

/* ========================================
   Tablet Landscape (max-width: 1200px)
   ======================================== */
@media (max-width: 1200px) {
    :root {
        --section-spacing: 80px;
    }

    .accommodation-layout {
        grid-template-columns: 1fr;
    }

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

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

    .features-grid {
        grid-template-columns: repeat(3, 1fr);
        gap: 20px;
    }

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

    .about-grid {
        gap: 50px;
    }
}

/* ========================================
   Tablet Portrait (max-width: 992px)
   ======================================== */
@media (max-width: 992px) {
    :root {
        --section-spacing: 70px;
        --container-padding: 24px;
    }

    /* Header */
    .header-nav { display: none; }
    .hamburger { display: flex; }
    .btn-book-now { display: none; }

    /* Hero */
    .hero-title {
        font-size: clamp(2rem, 5vw, 3rem);
    }

    .hero-search-widget {
        max-width: 100%;
    }

    .std-search-form {
        flex-direction: column;
    }

    .search-field { min-width: 100%; }
    .search-submit { width: 100%; }
    .btn-search { width: 100%; justify-content: center; }

    /* About */
    .about-grid {
        grid-template-columns: 1fr;
        gap: 40px;
    }

    .about-images { order: -1; }

    .about-stat-card {
        right: 20px;
        bottom: -10px;
    }

    /* Features */
    .features-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    /* Accommodation */
    .accommodation-layout {
        grid-template-columns: 1fr;
    }

    .accommodation-sidebar {
        position: static;
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 20px;
    }

    .gallery-slide img {
        height: 350px;
    }

    /* Gallery */
    .gallery-preview-grid {
        grid-template-columns: repeat(3, 1fr);
    }

    .gallery-preview-item.gallery-large {
        grid-column: span 1;
        grid-row: span 1;
    }

    /* Blog */
    .blog-layout {
        grid-template-columns: 1fr;
    }

    /* Confirmation */
    .confirmation-grid {
        grid-template-columns: 1fr;
    }
}

/* ========================================
   Mobile Large (max-width: 768px)
   ======================================== */
@media (max-width: 768px) {
    :root {
        --section-spacing: 60px;
    }

    /* Header */
    .header-top-bar {
        display: none;
    }

    .header-main-inner {
        height: 65px;
    }

    /* Page Hero */
    .page-hero {
        padding: 120px 0 60px;
    }

    .page-hero-compact {
        padding: 100px 0 40px;
    }

    .page-hero-title {
        font-size: clamp(1.5rem, 5vw, 2.2rem);
    }

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

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

    .feature-icon {
        width: 56px;
        height: 56px;
        font-size: 1.2rem;
    }

    /* Accommodation cards */
    .accommodation-carousel,
    .accommodation-grid {
        grid-template-columns: 1fr;
        gap: 24px;
    }

    .card-image,
    .room-card-image {
        height: 200px;
    }

    /* Single accommodation */
    .accommodation-hero {
        height: 40vh;
        min-height: 280px;
    }

    .gallery-slide img {
        height: 280px;
    }

    .accommodation-sidebar {
        grid-template-columns: 1fr;
    }

    /* Gallery */
    .gallery-preview-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 10px;
    }

    /* Parallax */
    .parallax-divider {
        padding: 80px 0;
        background-attachment: scroll;
    }

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

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

    /* Back to top */
    .back-to-top {
        bottom: 20px;
        right: 20px;
        width: 42px;
        height: 42px;
    }

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

    /* Breadcrumb */
    .breadcrumb {
        flex-wrap: wrap;
        font-size: 0.8rem;
    }
}

/* ========================================
   Mobile Small (max-width: 576px)
   ======================================== */
@media (max-width: 576px) {
    :root {
        --section-spacing: 50px;
        --container-padding: 16px;
    }

    body {
        font-size: 15px;
    }

    /* Hero */
    .hero-section {
        min-height: 100vh;
    }

    .hero-content {
        padding: 110px 0 40px;
    }

    .hero-subtitle {
        font-size: 0.9rem;
        letter-spacing: 2px;
    }

    .hero-description {
        font-size: 1rem;
    }

    .hero-search-widget {
        border-radius: var(--radius-md);
    }

    .search-widget-header {
        padding: 12px 20px;
    }

    .search-widget-body {
        padding: 16px 20px;
    }

    /* Section headers */
    .section-header {
        margin-bottom: 40px;
    }

    .section-label {
        font-size: 0.72rem;
        letter-spacing: 2px;
    }

    .section-title {
        font-size: clamp(1.5rem, 5vw, 2rem);
    }

    /* Features */
    .features-grid {
        grid-template-columns: 1fr;
    }

    .feature-card {
        display: flex;
        align-items: center;
        text-align: left;
        padding: 20px;
        gap: 20px;
    }

    .feature-icon {
        margin: 0;
        flex-shrink: 0;
        width: 50px;
        height: 50px;
        font-size: 1.1rem;
    }

    .feature-card h3 {
        font-size: 1.05rem;
        margin-bottom: 4px;
    }

    .feature-card p {
        font-size: 0.85rem;
        margin: 0;
    }

    /* Blog */
    .blog-card-image img {
        height: 180px;
    }

    .blog-card-body {
        padding: 18px;
    }

    /* Gallery */
    .gallery-preview-grid {
        grid-template-columns: 1fr 1fr;
        gap: 8px;
    }

    /* About stat */
    .about-stat-card {
        position: static;
        margin-top: -20px;
        margin-left: auto;
        margin-right: auto;
        width: fit-content;
    }

    .about-img-main img {
        height: 300px;
    }

    /* Card actions */
    .card-actions,
    .room-card-actions {
        flex-direction: column;
    }

    .btn-details, .btn-book {
        text-align: center;
        justify-content: center;
    }

    /* Buttons */
    .btn-primary, .btn-outline, .btn-white, .btn-outline-white {
        padding: 12px 24px;
        font-size: 0.85rem;
    }

    /* Parallax */
    .parallax-divider {
        padding: 60px 0;
    }

    .parallax-content h2 {
        font-size: 1.5rem;
    }

    /* Confirmation */
    .confirmation-header {
        padding: 30px 20px;
    }

    .confirmation-body {
        padding: 20px;
    }

    .confirmation-code {
        font-size: 1.4rem !important;
    }

    .confirmation-footer {
        flex-direction: column;
        padding: 16px 20px;
    }

    /* Section CTA */
    .section-cta .btn-primary,
    .section-cta .btn-outline {
        display: block;
        width: 100%;
        text-align: center;
        justify-content: center;
    }

    /* Mobile menu wider */
    .mobile-menu {
        width: 85vw;
        max-width: 320px;
    }

    /* Accommodation detail */
    .accommodation-hero-content .container {
        padding: 0 16px;
    }

    .accommodation-title {
        font-size: 1.6rem;
    }

    .gallery-thumbnails {
        gap: 6px;
    }

    .gallery-thumb {
        width: 56px;
        height: 42px;
    }

    .gallery-nav {
        width: 36px;
        height: 36px;
        font-size: 0.8rem;
    }
}

/* ========================================
   Extra Small (max-width: 400px)
   ======================================== */
@media (max-width: 400px) {
    .hero-title {
        font-size: 1.8rem;
    }

    .header-logo .site-title {
        font-size: 1.2rem;
    }

    .btn-primary, .btn-outline {
        padding: 10px 20px;
    }

    .gallery-preview-grid {
        grid-template-columns: 1fr;
    }
}

/* ========================================
   Landscape Orientation
   ======================================== */
@media (max-height: 500px) and (orientation: landscape) {
    .hero-section {
        min-height: 100vh;
    }

    .hero-content {
        padding: 80px 0 20px;
    }

    .hero-title {
        font-size: 2rem;
    }

    .scroll-indicator {
        display: none;
    }
}

/* ========================================
   High DPI / Retina
   ======================================== */
@media (-webkit-min-device-pixel-ratio: 2), (min-resolution: 192dpi) {
    .hamburger-line {
        height: 1.5px;
    }
}

/* ========================================
   Reduced Motion
   ======================================== */
@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }

    html {
        scroll-behavior: auto;
    }

    [data-animate] {
        opacity: 1;
        transform: none;
    }
}
