/**
 * HAVEN THEME CSS
 * Industry: Hospitality/Rentals (Airbnb, hotels, vacation rentals, property)
 * Design: Warm, serene, elegant — Georgia serif, cream backgrounds, orange accent
 * Palette: Warm stone (#44403c), warm gray (#78716c), cream (#faf5f0), orange accent
 */

:root {
    /* Connect to K3 color system with fallbacks */
    --bpage-font-body: Georgia, 'Times New Roman', serif;
    --bpage-font-display: Georgia, 'Times New Roman', serif;
    --haven-primary: var(--k3-primary, #f97316);
    --haven-primary-light: var(--k3-primary-light, #FB923C);
    --haven-primary-dark: var(--k3-primary-dark, #ea580c);
    --haven-accent: var(--k3-primary, #f97316);
    --haven-book: var(--k3-primary, #f97316);
    --haven-dark: #292524;
    --haven-light: #faf5f0;
    --haven-warm: #faf5f0;
    --haven-gray: #78716c;
    --haven-border: #e7e0d8;
    --haven-gradient: linear-gradient(135deg, var(--k3-primary, #f97316) 0%, var(--k3-primary-light, #FB923C) 100%);
    --haven-shadow: 0 20px 60px rgba(var(--k3-shadow-rgb, 249, 115, 22), 0.12);
    --haven-shadow-rgb: var(--k3-shadow-rgb, 249, 115, 22);
    --haven-radius: 12px;
    --haven-transition: all 0.3s ease;

    /* Nav base contract tokens */
    --nav-gap: 6px;
    --nav-transition: all 0.2s ease;
    --nav-focus-color: var(--haven-primary);
    --nav-cta-lift: -1px;
    --nav-active-weight: 500;
}

/* Color system integration for per-section colors */
.section-color-wrapper .haven-header,
.section-color-wrapper [class*="haven-"] {
    --haven-primary: var(--k3-primary);
    --haven-primary-light: var(--k3-primary-light);
    --haven-primary-dark: var(--k3-primary-dark);
    --haven-gradient: linear-gradient(135deg, var(--k3-primary) 0%, var(--k3-primary-light) 100%);
    --haven-shadow: 0 20px 60px rgba(var(--k3-shadow-rgb), 0.12);
    --haven-shadow-rgb: var(--k3-shadow-rgb);
}

/* ============================================
   ACCENT UTILITY CLASSES (for replacing inline styles)
   ============================================ */
.haven-gradient-bg {
    background: var(--haven-gradient) !important;
}
.haven-accent-icon {
    background: var(--haven-gradient);
    color: white;
}
.haven-icon-box {
    width: 60px;
    height: 60px;
    background: var(--haven-gradient);
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
}
.haven-icon-box-sm {
    width: 50px;
    height: 50px;
    background: var(--haven-gradient);
    border-radius: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    flex-shrink: 0;
}
.haven-icon-circle {
    width: 100px;
    height: 100px;
    background: var(--haven-gradient);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
}
.haven-icon-badge {
    width: 40px;
    height: 40px;
    background: var(--haven-gradient);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    border: 3px solid #fff;
    box-shadow: 0 5px 15px rgba(var(--haven-shadow-rgb), 0.3);
}
.haven-cta-btn {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 16px 35px;
    background: var(--haven-gradient);
    color: #fff;
    text-decoration: none;
    border-radius: 8px;
    font-weight: 600;
    box-shadow: 0 10px 30px rgba(var(--haven-shadow-rgb), 0.3);
    transition: all 0.3s;
}
.haven-cta-btn:hover {
    transform: translateY(-3px);
}

/* Header, hero, nav, booking widget, scroll indicator:
   Now in haven-sections.css (extracted 2026-02-13) */

/* Buttons — shared utility (kept here as base; sections override as needed) */
.haven-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.875rem 1.75rem;
    border-radius: var(--haven-radius);
    font-weight: 600;
    text-decoration: none;
    transition: var(--haven-transition);
    border: 2px solid transparent;
    cursor: pointer;
}

.haven-btn-outline {
    border-color: var(--haven-primary);
    color: var(--haven-primary);
    background: transparent;
}

.haven-btn-outline:hover {
    background: var(--haven-primary);
    color: white;
}

.haven-btn-full {
    width: 100%;
    justify-content: center;
}

/* Hero Stats — used by editorial/other themes, not duplicated in sections */
.haven-hero-stats {
    display: flex;
    justify-content: center;
    gap: 2rem;
    margin-bottom: 2.5rem;
    flex-wrap: wrap;
}

.haven-stat {
    text-align: center;
    padding: 1rem 1.5rem;
    background: rgba(255, 255, 255, 0.1);
    backdrop-filter: blur(10px);
    border: 1px solid rgba(255, 255, 255, 0.15);
    border-radius: var(--haven-radius);
    min-width: 100px;
    transition: var(--haven-transition);
}

.haven-stat:hover {
    background: rgba(255, 255, 255, 0.15);
    transform: translateY(-3px);
}

.haven-stat-value {
    display: block;
    font-size: 1.5rem;
    font-weight: 800;
    color: white;
    line-height: 1.2;
}

.haven-stat-value i {
    font-size: 1rem;
    color: #fbbf24;
    margin-left: 4px;
}

.haven-stat-label {
    display: block;
    font-size: 0.75rem;
    color: rgba(255, 255, 255, 0.7);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-top: 4px;
}

/* Hero Actions */
.haven-hero-actions {
    display: flex;
    justify-content: center;
    gap: 1rem;
    flex-wrap: wrap;
}

/* ============================================
   CONTAINER
   ============================================ */
.haven-container {
    max-width: 1300px;
    margin: 0 auto;
    padding: 0 2rem;
}

/* ============================================
   SECTIONS COMMON
   ============================================ */
.haven-section-header {
    text-align: center;
    margin-bottom: 4rem;
}

.haven-section-tag {
    display: inline-block;
    color: var(--haven-primary);
    font-size: 0.8125rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 3px;
    margin-bottom: 1rem;
    font-family: Georgia, serif;
}

.haven-section-title {
    font-size: 34px;
    font-weight: 400;
    color: #44403c;
    line-height: 1.2;
    margin-bottom: 1rem;
    font-family: Georgia, 'Times New Roman', serif;
}

.haven-section-desc {
    font-size: 1.125rem;
    color: var(--haven-gray);
    max-width: 600px;
    margin: 0 auto;
}

/* ============================================
   ABOUT/AMENITIES SECTION
   ============================================ */
.haven-about {
    padding: 80px 0;
    background: white;
}

.haven-about-grid {
    display: grid;
    grid-template-columns: 1fr 400px;
    gap: 4rem;
    align-items: start;
}

.haven-about-text {
    font-size: 1.1rem;
    line-height: 1.8;
    color: var(--haven-gray);
    margin-bottom: 2rem;
}

.haven-quick-info {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1rem;
}

.haven-info-item {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 1rem;
    background: var(--haven-light);
    border-radius: var(--haven-radius);
}

.haven-info-item i {
    color: var(--haven-primary);
    font-size: 1.25rem;
}

.haven-amenities-card {
    background: var(--haven-light);
    border-radius: var(--haven-radius);
    padding: 2rem;
}

.haven-amenities-card h3 {
    font-size: 1.25rem;
    font-weight: 400;
    color: var(--haven-dark);
    margin-bottom: 1.5rem;
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-family: Georgia, 'Times New Roman', serif;
}

.haven-amenities-card h3 i {
    color: var(--haven-primary);
}

.haven-amenities-list {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1rem;
}

.haven-amenity {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    font-size: 0.95rem;
    color: var(--haven-gray);
}

.haven-amenity i {
    color: var(--haven-primary);
    width: 20px;
}

/* Highlights */
.haven-highlights {
    padding: 60px 0;
    background: var(--haven-light);
}

.haven-highlights-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 2rem;
}

.haven-highlight-card {
    text-align: center;
    padding: 2rem;
    background: white;
    border-radius: var(--haven-radius);
    transition: var(--haven-transition);
}

.haven-highlight-card:hover {
    transform: translateY(-5px);
    box-shadow: var(--haven-shadow);
}

.haven-highlight-icon {
    width: 60px;
    height: 60px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--haven-gradient);
    color: white;
    border-radius: 50%;
    font-size: 1.5rem;
    margin: 0 auto 1rem;
}

.haven-highlight-card h4 {
    font-size: 1.1rem;
    font-weight: 400;
    color: var(--haven-dark);
    margin-bottom: 0.5rem;
    font-family: Georgia, 'Times New Roman', serif;
}

.haven-highlight-card p {
    font-size: 0.875rem;
    color: var(--haven-gray);
    margin: 0;
}

/* ============================================
   ROOMS SECTION
   ============================================ */
.haven-rooms {
    padding: 80px 0;
    background: white;
}

.haven-rooms-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
    gap: 2rem;
}

.haven-room-card {
    background: white;
    border-radius: var(--haven-radius);
    overflow: hidden;
    border: 1px solid var(--haven-border);
    transition: var(--haven-transition);
}

.haven-room-card:hover {
    transform: translateY(-10px);
    box-shadow: var(--haven-shadow);
}

.haven-room-image {
    position: relative;
    height: 220px;
    background: var(--haven-light);
    display: flex;
    align-items: center;
    justify-content: center;
}

.haven-room-badge {
    position: absolute;
    top: 1rem;
    left: 1rem;
    background: var(--haven-primary);
    color: white;
    padding: 0.25rem 0.75rem;
    border-radius: 50px;
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
}

.haven-room-overlay {
    position: absolute;
    inset: 0;
    background: rgba(41, 37, 36, 0.5);
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transition: var(--haven-transition);
}

.haven-room-card:hover .haven-room-overlay {
    opacity: 1;
}

.haven-room-content {
    padding: 1.5rem;
}

.haven-room-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 0.75rem;
}

.haven-room-title {
    font-size: 1.25rem;
    font-weight: 400;
    color: var(--haven-dark);
    margin: 0;
    font-family: Georgia, 'Times New Roman', serif;
}

.haven-room-rating {
    display: flex;
    align-items: center;
    gap: 0.25rem;
    font-weight: 600;
    color: var(--haven-dark);
}

.haven-room-rating i {
    color: #FBBF24;
}

.haven-room-desc {
    font-size: 0.95rem;
    color: var(--haven-gray);
    line-height: 1.6;
    margin-bottom: 1rem;
}

.haven-room-features {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    margin-bottom: 1.5rem;
}

.haven-room-features span {
    display: flex;
    align-items: center;
    gap: 0.25rem;
    font-size: 0.875rem;
    color: var(--haven-gray);
    background: var(--haven-light);
    padding: 0.5rem 0.75rem;
    border-radius: 50px;
}

.haven-room-features i {
    color: var(--haven-primary);
}

.haven-room-footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-top: 1rem;
    border-top: 1px solid var(--haven-border);
}

.haven-room-price {
    display: flex;
    flex-direction: column;
}

.haven-price-label {
    font-size: 0.75rem;
    color: var(--haven-gray);
    text-transform: uppercase;
}

.haven-price-amount {
    font-size: 1.5rem;
    font-weight: 800;
    color: var(--haven-dark);
}

.haven-price-amount .currency {
    font-size: 1rem;
    color: var(--haven-gray);
}

.haven-price-period {
    font-size: 0.875rem;
    color: var(--haven-gray);
}

/* Gallery section: Now in haven-sections.css (extracted 2026-02-13)
   Uses .haven-gal-* classes from gallery_section.php */

/* ============================================
   CONTACT SECTION
   ============================================ */
.haven-contact {
    padding: 80px 0;
    background: white;
}

.haven-contact-grid {
    display: grid;
    grid-template-columns: 1fr 500px;
    gap: 4rem;
    align-items: start;
}

.haven-contact-intro {
    font-size: 1.1rem;
    color: var(--haven-gray);
    line-height: 1.7;
    margin-bottom: 2.5rem;
}

.haven-contact-details {
    display: grid;
    gap: 1.5rem;
}

.haven-contact-item {
    display: flex;
    gap: 1rem;
}

.haven-contact-icon {
    width: 50px;
    height: 50px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--haven-gradient);
    color: white;
    border-radius: var(--haven-radius);
    font-size: 1.25rem;
    flex-shrink: 0;
}

.haven-contact-item.haven-whatsapp .haven-contact-icon {
    background: #25D366 !important;
}

.haven-contact-item strong {
    display: block;
    color: var(--haven-dark);
    margin-bottom: 0.25rem;
}

.haven-contact-item p {
    margin: 0;
    color: var(--haven-gray);
}

.haven-contact-item a {
    color: var(--haven-gray);
    text-decoration: none;
}

.haven-contact-item a:hover {
    color: var(--haven-book);
}

.haven-policies {
    margin-top: 2.5rem;
    padding: 1.5rem;
    background: var(--haven-light);
    border-radius: var(--haven-radius);
}

.haven-policies h4 {
    font-size: 1rem;
    font-weight: 400;
    color: var(--haven-dark);
    margin-bottom: 1rem;
    font-family: Georgia, 'Times New Roman', serif;
}

.haven-policies ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.haven-policies li {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.5rem 0;
    font-size: 0.95rem;
    color: var(--haven-gray);
}

.haven-policies i {
    color: var(--haven-primary);
    width: 20px;
}

.haven-form-card {
    background: var(--haven-light);
    border-radius: var(--haven-radius);
    padding: 2.5rem;
}

.haven-form-card h3 {
    font-size: 1.5rem;
    font-weight: 400;
    color: var(--haven-dark);
    margin-bottom: 0.5rem;
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-family: Georgia, 'Times New Roman', serif;
}

.haven-form-card h3 i {
    color: var(--haven-primary);
}

.haven-form-card > p {
    color: var(--haven-gray);
    margin-bottom: 2rem;
}

.haven-form {
    display: grid;
    gap: 1rem;
}

.haven-form-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
}

.haven-form-group label {
    display: block;
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--haven-dark);
    margin-bottom: 0.5rem;
}

.haven-form-group input,
.haven-form-group select,
.haven-form-group textarea {
    width: 100%;
    padding: 1rem;
    border: 1px solid var(--haven-border);
    border-radius: var(--haven-radius);
    font-size: 1rem;
    background: white;
    transition: var(--haven-transition);
}

.haven-form-group input:focus,
.haven-form-group select:focus,
.haven-form-group textarea:focus {
    outline: none;
    border-color: var(--haven-primary);
}

.haven-form-note {
    text-align: center;
    font-size: 0.875rem;
    color: var(--haven-gray);
    margin-top: 1rem;
}

.haven-form-note i {
    color: var(--haven-primary);
}

/* ============================================
   RESPONSIVE (about, rooms, contact, highlights, form)
   Header/nav/hero/gallery responsive: now in haven-sections.css
   ============================================ */
@media (max-width: 1024px) {
    .haven-about-grid,
    .haven-contact-grid {
        grid-template-columns: 1fr;
    }

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

@media (max-width: 768px) {
    .haven-hero-stats {
        gap: 1rem;
    }

    .haven-stat {
        min-width: 80px;
        padding: 0.75rem 1rem;
    }

    .haven-stat-value {
        font-size: 1.25rem;
    }

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

    .haven-hero-actions .haven-btn {
        width: 100%;
        justify-content: center;
    }

    .haven-highlights-grid {
        grid-template-columns: 1fr;
    }

    .haven-rooms-grid {
        grid-template-columns: 1fr;
    }

    .haven-form-row {
        grid-template-columns: 1fr;
    }

    .haven-quick-info {
        grid-template-columns: 1fr;
    }

    .haven-amenities-list {
        grid-template-columns: 1fr;
    }
}

/* Enhanced Header & Hero v2: Now in haven-sections.css (extracted 2026-02-13) */

/* Mobile: section padding adjustments (not duplicated in sections) */
@media (max-width: 768px) {
    .haven-about,
    .haven-rooms,
    .haven-contact {
        padding: 50px 0;
    }

    .haven-section-title {
        font-size: 27px;
    }
}

/* ============================================
   HAVEN SECTION DESIGN SYSTEM (2026-02-12)
   Shared tokens for consistent section feel
   ============================================ */

/* Standard section rhythm */
[class*="haven-"][class*="-section"],
.hvn-pf-section,
.hvn-team,
.hvn-testi,
.hvn-qual-section {
    font-family: Georgia, 'Times New Roman', serif;
}

/* Section header ornament — reusable divider line */
.haven-ornament {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
    margin-top: 1rem;
}
.haven-ornament::before,
.haven-ornament::after {
    content: '';
    width: 36px;
    height: 1px;
    background: #d6cfc5;
}
.haven-ornament i {
    font-size: 10px;
    color: var(--haven-primary, #f97316);
}

/* Smooth section transitions — subtle top border */
[class*="haven-"][class*="-section"] + [class*="haven-"][class*="-section"],
.hvn-pf-section + [class*="haven-"],
.hvn-team + [class*="haven-"],
.hvn-testi + [class*="haven-"],
.hvn-qual-section + [class*="haven-"] {
    border-top: 1px solid rgba(231, 224, 216, 0.5);
}

/* ============================================
   COMPATIBILITY HOOKS (2026-02-11)
   Added for new bpages templates
   ============================================ */
.haven-about-content {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}
.haven-contact-info {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}
.haven-inquiry-form {
    width: 100%;
}
.haven-cta-section {
    padding: 80px 0;
    background: var(--haven-light);
}
.haven-faq-list {
    display: grid;
    gap: 1rem;
}
.haven-textgal-section {
    padding: 80px 0;
    background: var(--haven-light);
}
.haven-playlist-item {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 1rem;
    border-radius: 14px;
    transition: var(--haven-transition);
}
.haven-playlist-item:hover {
    background: var(--haven-warm);
}
.haven-accent-bar {
    width: 48px;
    height: 3px;
    background: var(--haven-primary);
    border-radius: 999px;
}

/* ============================================
   ACCESSIBILITY (focus-visible, reduced-motion, print)
   ============================================ */

/* Focus-visible — warm ring for all interactive elements */
.haven-nav-link:focus-visible,
.haven-btn:focus-visible,
.haven-btn-book:focus-visible,
.haven-btn-outline:focus-visible,
.haven-cta-btn:focus-visible,
.haven-gallery-btn:focus-visible,
.haven-phone:focus-visible,
.haven-room-card a:focus-visible,
.haven-form-group input:focus-visible,
.haven-form-group select:focus-visible,
.haven-form-group textarea:focus-visible {
    outline: 2px solid var(--haven-primary, #f97316);
    outline-offset: 2px;
}

/* White focus ring on dark backgrounds */
.haven-hero .haven-btn:focus-visible,
.haven-hero .haven-btn-book:focus-visible,
.haven-hero a:focus-visible,
.haven-hero input:focus-visible,
.haven-hero select:focus-visible {
    outline-color: rgba(255, 255, 255, 0.9);
}

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

/* Print */
@media print {
    .haven-header,
    .haven-nav-section,
    .haven-scroll-indicator,
    .haven-booking-widget,
    .haven-hero-video {
        display: none !important;
    }
    .haven-hero {
        min-height: auto;
        background: none;
        color: #000;
        padding: 2rem 0;
    }
    .haven-hero-overlay,
    .haven-hero::before {
        display: none;
    }
    .haven-section-title,
    .haven-hero-title {
        color: #000;
    }
}
