/* ===================================================================
   OSAC v2 - PRODUCT PAGES (Accommodation Detail)
   ===================================================================

   Component classes for the accommodation detail page.
   Built on the OSAC Design System (variables.css).

   Used selectors verified against accommodation-detail.php template
   and its template-parts (gallery, amenities, FAQ, room-features).

   Dead code removed 2026-03-26 (was 43% unused — timeline, cards,
   mobile bar, gallery grid, cross-sell, trust bar, booking box,
   scroll row, grain texture, availability widget).

   =================================================================== */

/* ─────────────────────────────────────────────
   1. PAGE LAYOUT
   ───────────────────────────────────────────── */

.osb-product-page {
    background: var(--osb-surface-bg, #f8f6f2);
    color: var(--osb-text-main);
    line-height: var(--osb-leading-normal);
}

.osb-product-page *,
.osb-product-page *::before,
.osb-product-page *::after {
    box-sizing: border-box;
}

.osb-container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 var(--osb-space-6);
}

.osb-container--narrow {
    max-width: 960px;
}

/* Section spacing */
.osb-section {
    padding: var(--osb-space-16) 0;
}

.osb-section--alt {
    background: var(--osb-surface-bg-alt, #f2efe9);
}

.osb-section--deep {
    background: var(--osb-deep, #132a3e);
    color: var(--osb-text-white);
}

.osb-section--deep .osb-section-label {
    color: rgba(255, 255, 255, 0.6);
}

/* ─────────────────────────────────────────────
   2. HERO SECTION
   ───────────────────────────────────────────── */

.osb-hero {
    position: relative;
    min-height: 60vh;
    display: flex;
    align-items: flex-end;
    padding: var(--osb-space-16) 0 var(--osb-space-10);
    overflow: hidden;
    background: var(--osb-deep);
    color: var(--osb-text-white);
}

.osb-hero__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(
        to top,
        rgba(19, 42, 62, 0.95) 0%,
        rgba(19, 42, 62, 0.6) 40%,
        rgba(19, 42, 62, 0.3) 100%
    );
    z-index: 1;
}

.osb-hero__content {
    position: relative;
    z-index: 2;
    max-width: 720px;
}

.osb-hero__title {
    font-family: var(--osb-font-display);
    font-size: clamp(2rem, 5vw, var(--osb-text-5xl));
    font-weight: var(--osb-font-normal);
    line-height: var(--osb-leading-tight);
    letter-spacing: var(--osb-tracking-tight);
    margin-bottom: var(--osb-space-4);
}

/* ─────────────────────────────────────────────
   3. TYPOGRAPHY (Product Pages)
   ───────────────────────────────────────────── */

.osb-product-page h1,
.osb-product-page h2,
.osb-product-page h3 {
    font-family: var(--osb-font-display);
    font-weight: var(--osb-font-normal);
    color: var(--osb-text-dark);
    line-height: var(--osb-leading-snug);
}

.osb-product-page h1 {
    font-size: clamp(2rem, 5vw, var(--osb-text-4xl));
    letter-spacing: var(--osb-tracking-tight);
}

.osb-product-page h2 {
    font-size: clamp(1.5rem, 3.5vw, var(--osb-text-3xl));
    margin-bottom: var(--osb-space-6);
}

.osb-product-page h3 {
    font-size: var(--osb-text-2xl);
    margin-bottom: var(--osb-space-4);
}

.osb-product-page h5,
.osb-product-page h6 {
    font-family: var(--osb-font-primary);
    font-weight: var(--osb-font-semibold);
    color: var(--osb-text-dark);
}

.osb-product-page p {
    margin-bottom: var(--osb-space-4);
    color: var(--osb-text-main);
}

/* Section eyebrow label */
.osb-section-label {
    display: inline-block;
    font-family: var(--osb-font-primary);
    font-size: 0.6875rem;
    font-weight: var(--osb-font-semibold);
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--osb-brand-primary);
    margin-bottom: var(--osb-space-3);
}

/* ─────────────────────────────────────────────
   6. BADGES
   ───────────────────────────────────────────── */

.osb-badge {
    display: inline-flex;
    align-items: center;
    gap: var(--osb-space-1);
    padding: var(--osb-space-1) var(--osb-space-3);
    font-size: 0.75rem;
    font-weight: var(--osb-font-semibold);
    border-radius: var(--osb-radius-full);
    white-space: nowrap;
}

.osb-badge--primary {
    background: var(--osb-brand-primary-light);
    color: var(--osb-brand-primary);
}

.osb-badge--sand {
    background: var(--osb-brand-sand-light);
    color: var(--osb-brand-sand-dark);
}

/* ─────────────────────────────────────────────
   7. HIGHLIGHT BOX
   ───────────────────────────────────────────── */

.osb-highlight-box {
    background: var(--osb-brand-accent-light);
    border: 1px solid color-mix(in oklch, var(--osb-brand-accent) 20%, transparent);
    border-radius: var(--osb-radius-lg);
    padding: var(--osb-space-6);
}

.osb-highlight-box__text {
    font-size: var(--osb-text-sm);
    color: var(--osb-text-main);
}

/* ─────────────────────────────────────────────
   8. BENTO GRID (Amenity Cards)
   ───────────────────────────────────────────── */

.osb-bento {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--osb-space-4);
}

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

.osb-bento__item {
    background: var(--osb-surface);
    border: 1px solid var(--osb-border);
    border-radius: var(--osb-radius-lg);
    padding: var(--osb-space-6);
    transition: box-shadow var(--osb-transition-normal);
}

.osb-bento__item:hover {
    box-shadow: var(--osb-shadow-card);
}

.osb-bento__icon {
    font-size: 1.5rem;
    margin-bottom: var(--osb-space-3);
}

.osb-bento__title {
    font-family: var(--osb-font-primary);
    font-size: var(--osb-text-base);
    font-weight: var(--osb-font-semibold);
    margin-bottom: var(--osb-space-1);
}

@media (max-width: 768px) {
    .osb-bento {
        grid-template-columns: 1fr 1fr;
    }
}

@media (max-width: 480px) {
    .osb-bento {
        grid-template-columns: 1fr;
    }
}

/* ─────────────────────────────────────────────
   10. PHOTO MOSAIC
   ───────────────────────────────────────────── */

.osb-mosaic {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    grid-template-rows: auto auto;
    gap: var(--osb-space-3);
}

.osb-mosaic__item {
    border-radius: var(--osb-radius-md);
    overflow: hidden;
}

.osb-mosaic__item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--osb-transition-slow);
}

.osb-mosaic__item:hover img {
    transform: scale(1.05);
}

.osb-mosaic__item--wide {
    grid-column: span 2;
}

@media (max-width: 768px) {
    .osb-mosaic {
        grid-template-columns: 1fr 1fr;
    }
    .osb-mosaic__item--wide {
        grid-column: span 1;
    }
}

/* ─────────────────────────────────────────────
   11. FAQ ACCORDION
   ───────────────────────────────────────────── */

.osb-faq {
    border-top: 1px solid var(--osb-border);
}

.osb-faq__item {
    border-bottom: 1px solid var(--osb-border);
}

.osb-faq__question {
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 100%;
    padding: var(--osb-space-5) 0;
    background: none;
    border: none;
    cursor: pointer;
    text-align: left;
    font-family: var(--osb-font-primary);
    font-size: var(--osb-text-base);
    font-weight: var(--osb-font-semibold);
    color: var(--osb-text-dark);
    transition: color var(--osb-transition-fast);
}

.osb-faq__question:hover {
    color: var(--osb-brand-primary);
}

.osb-faq__icon {
    width: 20px;
    height: 20px;
    flex-shrink: 0;
    transition: transform var(--osb-transition-normal);
    color: var(--osb-text-muted);
}

.osb-faq__item.is-open .osb-faq__icon {
    transform: rotate(45deg);
    color: var(--osb-brand-primary);
}

.osb-faq__answer {
    overflow: hidden;
    max-height: 0;
    transition: max-height var(--osb-transition-slow),
                padding var(--osb-transition-slow);
}

.osb-faq__item.is-open .osb-faq__answer {
    max-height: 500px;
    padding-bottom: var(--osb-space-5);
}

.osb-faq__answer p {
    font-size: var(--osb-text-sm);
    color: var(--osb-text-muted);
    line-height: var(--osb-leading-relaxed);
}

/* ─────────────────────────────────────────────
   12. BOOKING BOX CTA
   ───────────────────────────────────────────── */

.osb-booking-box__cta {
    display: block;
    width: 100%;
    padding: var(--osb-space-4);
    text-align: center;
    font-family: var(--osb-font-primary);
    font-size: var(--osb-text-base);
    font-weight: var(--osb-font-semibold);
    color: var(--osb-btn-cta-text);
    background: var(--osb-btn-cta-bg);
    border: none;
    border-radius: var(--osb-radius-lg);
    cursor: pointer;
    transition: background var(--osb-transition-fast),
                box-shadow var(--osb-transition-fast);
    text-decoration: none;
}

.osb-booking-box__cta:hover {
    background: var(--osb-btn-cta-bg-hover);
    box-shadow: var(--osb-shadow-button);
}

/* ─────────────────────────────────────────────
   16. CTA SECTION (Final Call-to-Action)
   ───────────────────────────────────────────── */

.osb-cta-section {
    background: var(--osb-deep);
    color: var(--osb-text-white);
    text-align: center;
    padding: var(--osb-space-16) var(--osb-space-6);
    border-radius: var(--osb-radius-xl);
}

.osb-cta-section h2 {
    color: var(--osb-text-white);
    margin-bottom: var(--osb-space-4);
}

.osb-cta-section p {
    color: rgba(255, 255, 255, 0.7);
    max-width: 560px;
    margin: 0 auto var(--osb-space-8);
}

/* ─────────────────────────────────────────────
   17. ROOM DETAILS
   ───────────────────────────────────────────── */

.osb-room-features {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: var(--osb-space-4);
}

.osb-room-feature {
    display: flex;
    align-items: center;
    gap: var(--osb-space-3);
    padding: var(--osb-space-4);
    background: var(--osb-surface);
    border: 1px solid var(--osb-border);
    border-radius: var(--osb-radius-md);
}

.osb-room-feature__icon {
    font-size: 1.25rem;
    color: var(--osb-brand-primary);
    flex-shrink: 0;
}

.osb-room-feature__label {
    font-size: var(--osb-text-sm);
    font-weight: var(--osb-font-medium);
    color: var(--osb-text-main);
}

.osb-room-feature__value {
    display: block;
    font-size: var(--osb-text-xs);
    color: var(--osb-text-muted);
    font-weight: var(--osb-font-normal);
}
