/**
 * Site-wide responsive layout — Min Børnehave
 */
.site-ui {
    overflow-x: clip;
}

.site-ui main,
.site-ui .launch-content,
.site-ui .launch-section {
    max-width: 100%;
}

.site-ui img:not([width]):not(.nearby-milo):not(.site-brand-logo),
.site-ui video:not(.milo-map-title-video):not(.hero-premium-milo):not(.milo-panel-video) {
    max-width: 100%;
    height: auto;
}

.site-ui .leaflet-marker-icon.user-location-icon {
    width: 40px !important;
    height: 40px !important;
    background: transparent !important;
    border: none !important;
    overflow: visible !important;
}

.site-ui .user-location-marker {
    position: relative;
    width: 40px;
    height: 40px;
    filter: drop-shadow(0 2px 4px rgba(15, 23, 42, 0.22));
}

.site-ui .user-location-face {
    position: absolute;
    inset: 0;
    background-position: center;
    background-size: contain;
    background-repeat: no-repeat;
    transition: opacity 0.2s ease, transform 0.2s ease;
}

.site-ui .user-location-face--base {
    background-image: url(milo.png);
}

.site-ui .user-location-face--hover {
    background-image: url(milo-thumbs-hover.png);
    opacity: 0;
}

.site-ui .leaflet-marker-icon.user-location-icon:hover .user-location-face--base {
    opacity: 0;
    transform: translateY(-2px);
}

.site-ui .leaflet-marker-icon.user-location-icon:hover .user-location-face--hover {
    opacity: 1;
    transform: translateY(-2px);
}

.site-ui .max-w-7xl {
    width: 100%;
    max-width: 80rem;
}

.site-ui .w-full {
    width: 100%;
}

.site-ui .flex-shrink-0 {
    flex-shrink: 0;
}

.site-ui header.sticky {
    padding-left: env(safe-area-inset-left, 0);
    padding-right: env(safe-area-inset-right, 0);
}

.site-ui #mobile-menu {
    max-height: min(72vh, calc(100dvh - 4.5rem));
    overflow-y: auto;
    overscroll-behavior: contain;
}

/* Tailwind-like responsive flex (static HTML) */
.site-ui.app-page main .flex.flex-col,
.site-ui.homepage main .flex.flex-col {
    flex-direction: column;
}

.site-ui.homepage #daycare-list-grid {
    display: grid;
    gap: 1.5rem;
    grid-template-columns: minmax(0, 1fr);
}

@media (min-width: 768px) {
    .site-ui.homepage #daycare-list-grid.md\:grid-cols-2 {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (min-width: 1024px) {
    .site-ui.homepage #daycare-list-grid.lg\:grid-cols-3 {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (min-width: 640px) {
    .site-ui.app-page main .sm\:flex-row,
    .site-ui.homepage main .sm\:flex-row {
        flex-direction: row !important;
    }
}

@media (min-width: 768px) {
    .site-ui.app-page main .md\:flex-row,
    .site-ui.homepage main .md\:flex-row {
        flex-direction: row !important;
    }

    .site-ui.app-page main .md\:items-center,
    .site-ui.homepage main .md\:items-center {
        align-items: center !important;
    }

    .site-ui.app-page main .md\:justify-between,
    .site-ui.homepage main .md\:justify-between {
        justify-content: space-between !important;
    }
}

/* Homepage map filters — horizontal scroll on phones */
@media (max-width: 639px) {
    .site-ui.homepage .map-filter-bar {
        flex-wrap: nowrap !important;
        overflow-x: auto;
        justify-content: flex-start !important;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: thin;
        gap: 0.4rem;
        padding-bottom: 0.4rem;
        margin-left: -0.15rem;
        margin-right: -0.15rem;
        padding-left: 0.15rem;
        padding-right: 0.15rem;
    }

    .site-ui.homepage .map-filter-btn,
    .site-ui.homepage .map-filter-bar .map-counter {
        flex: 0 0 auto;
        white-space: nowrap;
        font-size: 0.78rem;
        padding: 0.4rem 0.75rem;
    }

    .site-ui.homepage .map-section > .text-center {
        padding-left: 0.5rem;
        padding-right: 0.5rem;
    }

    .site-ui.homepage #daycare-map {
        min-height: 280px;
        border-radius: 12px;
    }
}

/* Hero search panel */
@media (max-width: 480px) {
    .hero-premium-types {
        grid-template-columns: 1fr !important;
    }

    .hero-premium-stats {
        flex-direction: column;
    }

    .hero-premium-stat {
        flex: 1 1 auto;
        width: 100%;
    }

    .hero-premium-links {
        flex-direction: column;
        align-items: stretch;
    }

    .hero-premium-links .mb-btn {
        width: 100%;
    }
}

/* Wide tables / compare */
.site-ui main table {
    width: 100%;
    max-width: 100%;
}

.site-ui .favorite-compare-table-wrap,
.site-ui .overflow-x-auto {
    max-width: 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

/* Shop sidebar stacks on mobile */
@media (max-width: 767px) {
    .site-ui.shop-page main > .flex {
        flex-direction: column;
    }

    .site-ui.shop-page aside {
        width: 100% !important;
    }

    .site-ui.product-detail-page main > .flex {
        flex-direction: column;
    }
}

/* Legal / launch content breathing room */
@media (max-width: 640px) {
    .site-ui.launch-page main .launch-content,
    .site-ui.legal-page main .launch-content {
        padding-left: max(0.75rem, env(safe-area-inset-left, 0));
        padding-right: max(0.75rem, env(safe-area-inset-right, 0));
    }

    .site-ui header .max-w-7xl {
        padding-left: max(0.75rem, env(safe-area-inset-left, 0));
        padding-right: max(0.75rem, env(safe-area-inset-right, 0));
    }
}

@media (min-width: 1024px) {
    .site-ui .lg\:gap-16 {
        gap: 4rem;
    }
}

/* Sticky CTA above cookie banner */
body:has(#cookie-consent-overlay) .site-ui .mobile-sticky-cta {
    bottom: max(6.5rem, calc(5rem + env(safe-area-inset-bottom, 0px)));
}

/* Homepage results toolbar */
@media (max-width: 639px) {
    .site-ui.homepage .map-section > .mt-8.bg-white {
        padding: 1rem !important;
    }

    .site-ui.homepage .map-section > .mt-8.bg-white > .flex.flex-col {
        gap: 0.85rem;
    }

    .site-ui.homepage .map-section > .mt-8.bg-white label {
        width: 100%;
        flex-direction: column;
        align-items: stretch !important;
        gap: 0.35rem;
    }

    .site-ui.homepage .map-section #list-sort,
    .site-ui.homepage .map-section #reset-map-btn {
        width: 100%;
        min-height: 44px;
    }
}

/* Institutioner hub city links */
@media (max-width: 639px) {
    .site-ui.institutioner-hub-page .institutioner-hub-grid {
        grid-template-columns: 1fr !important;
    }
}

/* Guide article readable measure */
@media (max-width: 640px) {
    .site-ui.guide-article-page .launch-content,
    .site-ui.guide-article-page .guide-card {
        padding-left: 0;
        padding-right: 0;
    }
}
