/* ==========================================================================
   DESTAWED RESORTS DIRECTORY: CORE STYLES
========================================================================== */

.dw-resorts-wrapper {
    display: grid;
    grid-template-columns: 320px 1fr;
    gap: 40px;
    max-width: 1300px;
    margin: 60px auto;
    font-family: 'poppins', sans-serif;
    color: #1a1a1a;
}

.dw-resorts-sidebar {
    background: #ffffff; padding: 35px 30px; border-radius: 16px;
    box-shadow: 0 15px 40px rgba(0,0,0,0.03);
    position: sticky; top: 120px; max-height: calc(100vh - 140px); overflow-y: auto;
}

.dw-filter-group { margin-bottom: 30px; }
.dw-filter-header, .dw-filter-group h4 { font-family: 'Libre Baskerville', Georgia, serif; font-size: 18px; font-weight: 600; margin-bottom: 15px; text-transform: uppercase; }

.dw-search-wrap { position: relative; }
.dw-search-wrap svg { position: absolute; left: 15px; top: 50%; transform: translateY(-50%); color: #aaaaaa; }
.dw-search-wrap input { width: 100% !important; padding: 14px 15px 14px 45px !important; border: 1px solid #eaeaea !important; border-radius: 8px !important; background: #FDFBF9 !important; }
.dw-search-wrap input:focus { border-color: var(--dw-green, #7e8460) !important; background: #ffffff !important; box-shadow: 0 0 0 3px rgba(126, 132, 96, 0.1) !important; outline: none !important;}

.dw-accordion-head { display: flex; justify-content: space-between; align-items: center; font-family: 'Libre Baskerville', Georgia, serif; font-weight: 600; font-size: 14px; padding: 15px 0; border-top: 1px solid #eaeaea; cursor: pointer; text-transform: uppercase; }
.dw-accordion-head span::before { content: '+'; font-size: 20px; }
.dw-accordion.active .dw-accordion-head span::before { content: '-'; }
.dw-accordion-body { display: none; padding-bottom: 15px; }
.dw-accordion.active .dw-accordion-body { display: block; }

.dw-checkbox { display: flex; align-items: center; gap: 12px; margin-bottom: 14px; cursor: pointer; font-size: 15px; color: #555555; }
.dw-checkbox input { display: none; }
.dw-check-custom { width: 20px; height: 20px; border: 1px solid #cccccc; border-radius: 4px; position: relative; }
.dw-checkbox input:checked + .dw-check-custom { background: var(--dw-green, #7e8460); border-color: var(--dw-green, #7e8460); }
.dw-checkbox input:checked + .dw-check-custom::after { content: ''; position: absolute; left: 6px; top: 2px; width: 5px; height: 10px; border: solid white; border-width: 0 2px 2px 0; transform: rotate(45deg); }

/* Grid & Cards */
.dw-resorts-topbar { display: flex; justify-content: space-between; margin-bottom: 25px; padding-bottom: 15px; border-bottom: 1px solid #eaeaea; }
#dw-results-count { font-weight: 500; font-size: 16px; margin: 0; }
.dw-resorts-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 30px; }

.dw-resort-card { background: #ffffff; border-radius: 16px; overflow: hidden; box-shadow: 0 10px 30px rgba(0,0,0,0.04); display: flex; flex-direction: column; transition: transform 0.3s, box-shadow 0.3s; }
.dw-resort-card:hover { transform: translateY(-8px); box-shadow: 0 20px 50px rgba(0,0,0,0.08); }

.dw-resort-img-wrap { display: block; position: relative; height: 280px; overflow: hidden; }
.dw-resort-img-wrap img { width: 100%; height: 100% !important; object-fit: cover; transition: transform 0.8s; }
.dw-resort-card:hover .dw-resort-img-wrap img { transform: scale(1.05); }

.dw-badges-wrap { position: absolute; top: 15px; right: 15px; display: flex; gap: 8px; z-index: 2; }
.dw-resort-badge { background: #1a1a1a; color: #fff; padding: 5px 18px; border-radius: 30px; font-family: 'Libre Baskerville', Georgia, serif; font-size: 12px; font-weight: 600; text-transform: uppercase; }
.dw-capacity-badge { background: var(--dw-green, #7e8460); color: #fff; padding: 6px 14px; border-radius: 30px; font-family: 'Libre Baskerville', Georgia, serif; font-size: 11px; font-weight: 600; text-transform: uppercase; }

.dw-card-content { padding: 30px; display: flex; flex-direction: column; flex-grow: 1; }
.dw-title-link { color: #1a1a1a; text-decoration: none; transition: color 0.3s; }
.dw-title-link:hover { color: var(--dw-green, #7e8460); }
.dw-card-content h3 { font-family: 'Libre Baskerville', Georgia, serif; font-size: 22px; margin: 0 0 5px 0; font-weight: 600; }
.dw-resort-location { font-size: 13px; color: #888888; font-weight: 600; letter-spacing: 1.5px; margin: 0 0 25px 0; text-transform: uppercase; }

.dw-resort-meta-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 15px; margin-bottom: 30px; border-top: 1px solid #eaeaea; padding-top: 20px; }
.dw-meta-item { display: flex; align-items: center; gap: 10px; font-size: 14px; color: #555555; }

.dw-resort-actions { margin-top: auto; }
.dw-card-btn { display: block; text-align: center; padding: 16px; border-radius: 8px; font-family: 'Libre Baskerville', Georgia, serif; font-size: 13px; font-weight: 600; text-transform: uppercase; letter-spacing: 1px; text-decoration: none; transition: all 0.3s; }
.dw-btn-primary { background: var(--dw-green, #7e8460); color: #fff !important; }
.dw-btn-primary:hover { background: #1a1a1a; box-shadow: 0 5px 15px rgba(0,0,0,0.1); transform: translateY(-2px); }

/* Skeletons & Utilities */
.dw-skeleton { animation: dwPulse 1.5s infinite; background: #fff; border: 1px solid #f5f5f5; box-shadow: none; }
@keyframes dwPulse { 0% { opacity: 1; } 50% { opacity: 0.5; } 100% { opacity: 1; } }
.dw-skeleton-img { height: 280px; background: #eee; }
.dw-skeleton-title { height: 28px; background: #eee; width: 70%; margin-bottom: 10px; }
.dw-skeleton-text { height: 14px; background: #eee; width: 40%; margin-bottom: 30px; }
.dw-skeleton-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 15px; margin-bottom: 30px; }
.dw-skeleton-box { height: 20px; background: #eee; width: 80%; }
.dw-skeleton-btn { height: 48px; background: #eee; width: 100%; border-radius: 8px; }

.dw-no-results { text-align: center; padding: 50px; background: #fff; border-radius: 16px; grid-column: 1 / -1; }
.dw-pagination-wrap { text-align: center; margin-top: 50px; }
.dw-load-more-btn { background: transparent; border: 2px solid #1a1a1a; color: #1a1a1a; padding: 16px 40px; border-radius: 50px; font-family: 'Libre Baskerville', Georgia, serif; font-weight: 600; text-transform: uppercase; letter-spacing: 2px; cursor: pointer; transition: all 0.3s; }
.dw-load-more-btn:hover { background: #1a1a1a; color: #fff; }

/* Mobile logic */
.dw-filter-overlay, .dw-mobile-filter-header, .dw-apply-filters-btn, .dw-mobile-filter-trigger { display: none; }

@media (max-width: 1024px) {
    .dw-resorts-wrapper { grid-template-columns: 1fr; padding: 0 5%; }
    .dw-resorts-topbar { position: fixed; bottom: 0; left: 0; width: 100%; background: rgba(255,255,255,0.95); z-index: 9998; padding: 15px 5%; border-radius: 20px 20px 0 0; box-shadow: 0 -10px 40px rgba(0,0,0,0.06); }
    .dw-resorts-main { padding-bottom: 100px; }
    .dw-mobile-filter-trigger { display: flex; gap: 8px; background: #1a1a1a; color: #fff; padding: 14px 24px; border-radius: 50px; font-family: 'Libre Baskerville', Georgia, serif; font-weight: 600; text-transform: uppercase; border: none; cursor: pointer; }
    
    .dw-filter-overlay { display: block; position: fixed; inset: 0; background: rgba(0,0,0,0.6); z-index: 10000; opacity: 0; pointer-events: none; transition: opacity 0.3s; }
    .dw-filter-overlay.active { opacity: 1; pointer-events: auto; }

    .dw-resorts-sidebar { position: fixed; bottom: 0; left: 0; width: 100%; height: 85vh; z-index: 10001; background: #fff; border-radius: 24px 24px 0 0; padding: 25px; transform: translateY(100%); transition: transform 0.4s; }
    .dw-resorts-sidebar.active { transform: translateY(0); }
    .dw-mobile-filter-header { display: flex; justify-content: space-between; margin-bottom: 25px; border-bottom: 1px solid #eaeaea; padding-bottom: 15px; }
    .dw-close-filters { font-size: 36px; cursor: pointer; }
    .dw-apply-filters-btn { display: block; position: sticky; bottom: 20px; width: 100%; background: var(--dw-green, #7e8460); color: #fff; padding: 18px; border-radius: 8px; font-weight: 600; text-transform: uppercase; border: none; margin-top: 30px; z-index: 100; cursor: pointer;}
}
@media (max-width: 768px) {
    .dw-resorts-grid { grid-template-columns: 1fr; }
}


/* ==========================================================================
   DESTAWED SINGLE RESORT PAGE STYLES
========================================================================== */

.dw-single-resort-wrapper {
    background-color: #FDFBF9;
    font-family: 'poppins', sans-serif;
    color: #1a1a1a;
}

/* 1. HERO SECTION (UPGRADED) */
.dw-hero-section {
    position: relative;
    height: 80vh; /* Kept your 80vh height */
    background-size: cover;
    background-position: center;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    color: #fff;
}

.dw-hero-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(0,0,0,0.98) 0%, rgba(0,0,0,0.78) 34%, rgba(0,0,0,0.48) 68%, rgba(0,0,0,0.28) 100%);
    z-index: 1;
}

.dw-hero-content {
    position: relative;
    z-index: 2;
    max-width: 1000px; 
    width: 100%;
    padding: 0 20px;
    margin-top: 40px;
}

/* --- UPGRADED: Frosted Glass Meta Line --- */
.dw-hero-meta-wrapper {
    display: flex;
    justify-content: center;
    margin-bottom: 25px;
}

.dw-hero-meta-line {
    display: inline-flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 15px;
    padding: 10px 24px;
    background: rgba(0, 0, 0, 0.19); /* Dark translucent background */
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    border: 1px solid rgba(255, 255, 255, 0.15);
    border-radius: 50px;
}

.dw-hero-location, .dw-hero-stat {
    font-family: 'poppins', sans-serif;
    font-size: 9px;
    font-weight: 700;
    letter-spacing: 3px;
    text-transform: uppercase;
    color: #ffffff;
}

.dw-hero-location { color: #FFD183; }

/* Changed from a dot to an elegant vertical line */
.dw-meta-divider {
    width: 1px; 
    height: 12px;
    background-color: rgba(255, 255, 255, 0.3);
}

.dw-hero-title {
    max-width: 620px;
    margin: 0 auto 34px;
    font-family: 'Libre Baskerville', Georgia, serif;
    font-size: clamp(24px, 2.3vw, 30px) !important;
    font-weight: 400;
    line-height: 1.14;
    letter-spacing: 0.005em;
    color: #ffffff;
    text-align: center;
    text-shadow: 0 4px 28px rgba(0, 0, 0, 0.45);
    background: transparent;
}

/* --- Compact Planner Bar --- */
.dw-hero-planner-bar {
    display: grid;
    grid-template-columns: 1fr 1fr 240px; 
    align-items: stretch;
    max-width: 900px;
    margin: 0 auto;
    border-radius: 5px; /* Kept your 5px radius */
    background: #ffffff;
    box-shadow: 0 20px 50px rgba(0,0,0,0.15);
    position: relative;
}

.dw-hero-planner-col {
    position: relative;
    padding: 12px 30px;
    text-align: left;
    display: flex;
    align-items: center;
    gap: 16px; /* Added gap to fit the new icons perfectly */
}

/* Divider line between columns */
.dw-hero-planner-col:first-child::after {
    content: ''; position: absolute;
    right: 0; top: 20%; height: 60%; width: 1px;
    background: #eaeaea;
}

/* --- NEW: Planner Icons --- */
.dw-planner-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--dw-green, #7e8460); 
    background: rgba(126, 132, 96, 0.1); /* Soft brand color tint */
    width: 44px;
    height: 44px;
    border-radius: 50%;
    flex-shrink: 0;
}

.dw-planner-icon svg {
    width: 22px;
    height: 22px;
}

.dw-hero-planner-text { width: 100%; }

.dw-hero-planner-text label {
    display: block;
    font-family: 'Libre Baskerville', Georgia, serif;
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 1px;
    text-transform: uppercase;
    color: #1a1a1a;
    margin-bottom: 2px;
}

/* --- Custom Select UI --- */
.dw-hidden-select { display: none !important; }

.dw-custom-select {
    display: flex;
    justify-content: space-between;
    align-items: center;
    cursor: pointer;
    font-family: 'poppins', sans-serif;
    font-size: 16px;
    color: #666;
    padding: 4px 0;
    transition: color 0.3s;
}

.dw-custom-select:hover { color: #1a1a1a; }
.dw-custom-select.active svg { transform: rotate(180deg); }
.dw-custom-select svg { transition: transform 0.3s; color: #1a1a1a; }

.dw-custom-options {
    position: absolute;
    top: calc(100% + 5px);
    left: 0;
    width: 100%;
    min-width: 220px;
    background: #ffffff;
    border-radius: 5px; /* Kept your 5px radius */
    box-shadow: 0 15px 40px rgba(0,0,0,0.12);
    opacity: 0;
    visibility: hidden;
    transform: translateY(-10px);
    transition: all 0.3s cubic-bezier(0.19, 1, 0.22, 1);
    z-index: 10;
    overflow-y: auto; /* Kept your scrolling layout */
    height: 200px; /* Kept your 200px height */
}

.dw-custom-options.active {
    opacity: 1; visibility: visible; transform: translateY(0);
}

.dw-option {
    padding: 14px 20px;
    font-family: 'poppins', sans-serif;
    font-size: 15px;
    color: #444;
    cursor: pointer;
    transition: background 0.2s, color 0.2s;
    border-bottom: 1px solid #f5f5f5;
}
.dw-option:last-child { border-bottom: none; }
.dw-option:hover { background: #fdfdfd; color: var(--dw-green, #7e8460); }

/* --- Sleek Button --- */
.dw-hero-quote-btn {
    border: 0; outline: none; cursor: pointer;
    background: var(--dw-green, #7e8460); 
    color: #fff;
    font-family: 'Libre Baskerville', Georgia, serif;
    font-size: 15px;
    font-weight: 700;
    letter-spacing: 2px;
    text-transform: uppercase;
    border-radius: 0px; /* Kept your button rounding */
    margin: 0px; /* Kept your margin inset */
    transition: background 0.3s ease;
}
.dw-hero-quote-btn:hover { background: #1a1a1a; }

/* Mobile Adjustments */
@media (max-width: 1024px) {
    .dw-hero-planner-bar {
        grid-template-columns: 1fr;
        border-radius: 16px;
        max-width: 400px;
        margin: 0 auto;
    }
    .dw-hero-planner-col { padding: 20px; border-bottom: 1px solid #eaeaea; }
    .dw-hero-planner-col:first-child::after { display: none; }
    .dw-hero-quote-btn { padding: 20px; margin: 0; border-radius: 0 0 16px 16px; }
    .dw-custom-options { top: 100%; border-radius: 0 0 5px 5px; }
}
@media (max-width: 768px) {
    .dw-hero-title { font-size: 20px !important; margin-bottom: 26px; }
    
    /* Ensure the pill looks good on mobile */
    .dw-hero-meta-wrapper { margin-bottom: 15px; }
    .dw-hero-meta-line { padding: 8px 16px; gap: 10px; flex-direction: row; border-radius: 12px; }
}

/* 2. STICKY NAV BAR (UPGRADED) */
.dw-sticky-nav-wrapper {
    position: sticky; 
    top: 80px; 
    z-index: 99; /* Boosted z-index so it doesn't get covered by anything */
    background: rgba(255,255,255,0.98);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border-bottom: 1px solid #eaeaea;
    box-shadow: 0 5px 20px rgba(0,0,0,0.03);
}

.dw-sticky-container {
    max-width: 1300px; 
    margin: 0 auto; 
    padding: 0 20px;
    display: flex; 
    justify-content: space-between; 
    align-items: center; 
    height: 70px; 
    gap: 20px;
}

/* Scroll Mask Wrapper - Proves to mobile users it can be scrolled */
.dw-nav-scroll-wrapper {
    position: relative;
    flex-grow: 1;
    height: 100%;
    display: flex;
    align-items: center;
    overflow: hidden;
}

/* The visual fade on the right side */
.dw-nav-scroll-wrapper::after {
    content: '';
    position: absolute;
    top: 0; right: 0;
    width: 60px; height: 100%;
    background: linear-gradient(to right, rgba(255,255,255,0), rgba(255,255,255,1));
    pointer-events: none;
}

.dw-nav-links {
    display: flex; 
    gap: 35px; 
    list-style: none; 
    margin: 0; 
    padding: 0 60px 0 0; /* Padding allows the last item to scroll past the fade */
    overflow-x: auto; 
    white-space: nowrap;
    height: 100%; 
    align-items: center;
    scroll-behavior: smooth;
    -ms-overflow-style: none;  /* Hide scrollbar IE/Edge */
    scrollbar-width: none;  /* Hide scrollbar Firefox */
}

.dw-nav-links::-webkit-scrollbar { display: none; /* Hide scrollbar Chrome/Safari */ }

.dw-nav-links a {
    font-family: 'Poppins', system-ui, -apple-system, sans-serif;
    font-size: 12px;
    font-weight: 400;
    color: #888888;
    text-transform: uppercase;
    letter-spacing: 0.22em;
    text-decoration: none;
    transition: color 0.3s;
    position: relative;
    display: flex;
    align-items: center;
    height: 70px;
}

/* Sleek bottom border indicator */
.dw-nav-links a::after {
    content: '';
    position: absolute;
    bottom: 0; left: 0;
    width: 100%; height: 3px;
    background: var(--dw-green, #7e8460);
    transform: scaleX(0);
    transition: transform 0.3s cubic-bezier(0.19, 1, 0.22, 1);
    transform-origin: left;
}

/* Brand colors on hover/active */
.dw-nav-links a:hover, .dw-nav-links a.active { color: var(--dw-text, #1a1a1a); }
.dw-nav-links a.active::after { transform: scaleX(1); }

/* Brand Outline Button (Sharp & Premium) */
.dw-nav-action { flex-shrink: 0; }

.dw-nav-quote-btn {
    position: relative;
    overflow: hidden;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    background: transparent;
    color: var(--dw-green, #7e8460);
    border: 1px solid var(--dw-green, #7e8460);
    padding: 14px 30px;
    border-radius: 0;
    font-family: 'Poppins', system-ui, -apple-system, sans-serif;
    font-size: 12px;
    font-weight: 400;
    text-transform: uppercase;
    letter-spacing: 0.24em;
    cursor: pointer;
    transition: color 0.55s ease, border-color 0.55s ease, background-color 0.55s ease;
    box-shadow: none;
}
.dw-nav-quote-btn .dw-btn-fill,
.dw-view-all-btn .dw-btn-fill {
    position: absolute;
    inset: 0;
    background: var(--dw-green, #7e8460);
    transform: translateX(-101%);
    transition: transform 0.65s cubic-bezier(0.77, 0, 0.175, 1);
    z-index: 0;
}
.dw-nav-quote-btn .dw-btn-text,
.dw-view-all-btn .dw-btn-text {
    position: relative;
    z-index: 1;
}
.dw-nav-quote-btn:hover,
.dw-nav-quote-btn:focus {
    background: transparent;
    color: #ffffff;
    border-color: var(--dw-green, #7e8460);
    outline: 0;
}
.dw-nav-quote-btn:hover .dw-btn-fill,
.dw-nav-quote-btn:focus .dw-btn-fill,
.dw-view-all-btn:hover .dw-btn-fill,
.dw-view-all-btn:focus .dw-btn-fill {
    transform: translateX(0);
}

/* Mobile Adjustments */
@media (max-width: 768px) {
    .dw-sticky-container { padding: 0 0 0 20px; gap: 10px; }
    .dw-nav-links { gap: 25px; padding-right: 40px; }
    .dw-nav-quote-btn { padding: 10px 16px; font-size: 12px; }
    .dw-nav-action { padding-right: 15px; }
    .dw-nav-scroll-wrapper::after { width: 30px; } 
}
/* 3. MAIN CONTENT LAYOUT (FULL WIDTH SECTIONS) */
.dw-main-content {
    width: 100%;
    display: block;
    padding-top: 0;
}

.dw-section {
    width: 100vw !important;
    margin-left: calc(-50vw + 50%) !important;
    padding: 80px 20px; 
    box-sizing: border-box;
    scroll-margin-top: 100px; /* Accounts for sticky nav */
    background-color: transparent; /* Ready for custom backgrounds per section */
    border-bottom: 1px solid #eaeaea; /* Optional global divider */
}

/* The proper way to keep content at 1300px while BG goes full width */
.dw-section-inner {
    max-width: 1300px;
    margin: 0 auto;
    width: 100%;
}

.dw-small-hed{
    display: block;
    font-family: 'poppins', sans-serif;
    font-size: 13px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 3px;
    color: var(--dw-green, #7e8460);
    margin-bottom: 20px;
}

/* ==========================================
   OVERVIEW & HIGHLIGHTS SECTION
========================================== */

/* The New Tinted Inner Wrapper */
.dw-overview-inner-box {
    background-color: #F8F6F0; /* Soft cream background from screenshot */
    border-radius: 24px;
    padding: 80px 60px;
    width: 100%;
    box-sizing: border-box;
}

.dw-overview-split-layout {
    display: grid;
    grid-template-columns: 1.3fr 1fr; /* 60/40 Split */
    gap: 80px;
    align-items: start;
}

/* --- LEFT SIDE: Narrative --- */
.dw-ov-heading {
    font-family: 'Libre Baskerville', Georgia, serif;
    font-size: clamp(2.5rem, 4vw, 4rem);
    font-weight: 800;
    line-height: 1.1;
    color: var(--dw-text, #1a1a1a);
    margin: 0 0 35px 0;
    letter-spacing: -1px;
}

.dw-ov-text p {
    font-family: 'poppins', sans-serif;
    font-size: 13px;
    font-weight: 300;
    line-height: 1.8;
    color: #555555;
    margin: 0 0 25px 0;
}

/* The Fixed GSAP Text Fill Class */
.dw-text-fill {
    background-image: linear-gradient(to right, var(--dw-text, #1a1a1a) 50%, rgba(26, 26, 26, 0.15) 50%) !important;
    background-size: 200% 100% !important;
    background-position-x: 100%; 
    -webkit-background-clip: text !important;
    background-clip: text !important;
    -webkit-text-fill-color: transparent !important; 
    color: transparent !important;
    will-change: background-position-x;
}

/* --- RIGHT SIDE: Sticky Offset Card --- */
.dw-ov-right {
    position: sticky;
    top: 180px; 
}

/* Highlights card wrapper */
.dw-highlights-card-wrap {
    filter: none;
    margin-bottom: 25px;
    background: transparent;
    box-shadow: none;
}


.dw-highlights-card {
    background: #F7F7F3;
    border: 0;
    border-radius: 0;
    padding: 32px;
    clip-path: none;
    box-shadow: none;
}

.dw-hc-header {
    text-align: center;
    font-family: 'Libre Baskerville', Georgia, serif;
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: var(--dw-text, #1a1a1a);
    margin-bottom: 20px;
}

/* --- THE "PLUS" DIVIDER GRID --- */
.dw-hc-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0; /* Remove gap so borders touch to create the Plus */
}

.dw-hc-item {
    display: flex;
    align-items: center;
    gap: 12px;
    font-family: 'poppins', sans-serif;
    font-size: 13px; /* Slightly smaller for perfect fit */
    font-weight: 600;
    color: #444;
    padding: 20px 10px; /* Padding creates the breathing room */
}

/* Top Left Item: Bottom & Right Border */
.dw-hc-item:nth-child(1) {
    border-right: 1px solid rgba(0,0,0,0.08);
    border-bottom: 1px solid rgba(0,0,0,0.08);
}
/* Top Right Item: Bottom Border */
.dw-hc-item:nth-child(2) {
    border-bottom: 1px solid rgba(0,0,0,0.08);
}
/* Bottom Left Item: Right Border */
.dw-hc-item:nth-child(3) {
    border-right: 1px solid rgba(0,0,0,0.08);
}

.dw-hc-item svg {
    width: 20px;
    height: 20px;
    color: var(--dw-green, #7e8460); 
    flex-shrink: 0;
}

.dw-hc-divider { display: none; }

.dw-hc-offer {
    text-align: center;
    margin: 24px 0 0;
    padding: 28px 22px;
    background: #806052;
    border: 0;
    border-top: 0;
    border-radius: 0;
    box-shadow: none;
}

.dw-hc-offer-eyebrow {
    display: block;
    font-family: 'Poppins', system-ui, -apple-system, sans-serif;
    font-size: 10px;
    font-weight: 400;
    letter-spacing: 0.34em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.72);
    margin-bottom: 10px;
}

.dw-hc-offer h4 {
    font-family: 'Libre Baskerville', Georgia, serif;
    font-size: 24px;
    font-weight: 400;
    line-height: 1.2;
    color: #ffffff;
    margin: 0 0 14px 0;
}

/* Theme-Proofed Button Link */
button.dw-link-arrow {
    background: transparent !important; 
    border: none !important; 
    cursor: pointer; 
    padding: 0;
    color: var(--dw-green, #7e8460) !important;
    font-family: 'Libre Baskerville', Georgia, serif;
    font-size: 13px; 
    font-weight: 700; 
    letter-spacing: 1px; 
    text-transform: uppercase;
    transition: color 0.3s ease !important;
}
button.dw-link-arrow:hover { 
    color: var(--dw-text, #1a1a1a) !important; 
    background: transparent !important; /* Stops theme from adding background */
}

.dw-hc-footer-text {
    font-family: 'poppins', sans-serif;
    font-size: 14px;
    line-height: 1.6;
    color: #555;
    text-align: center;
    padding: 0 10px;
}

/* Theme-Proofed Footer Link */
.dw-hc-footer-text a {
    color: var(--dw-green, #7e8460) !important;
    font-weight: 600;
    text-decoration: underline;
    text-underline-offset: 3px;
    transition: color 0.3s ease;
}
.dw-hc-footer-text a:hover {
    color: var(--dw-text, #1a1a1a) !important; /* Enforces dark text instead of white */
}

/* --- RESPONSIVE --- */
@media (max-width: 991px) {
    .dw-overview-inner-box { padding: 60px 40px; }
    .dw-overview-split-layout { grid-template-columns: 1fr; gap: 50px; }
    .dw-ov-right { position: relative; top: 0; }
    /* Turn off text fill on mobile for readability */
    .dw-text-fill { -webkit-text-fill-color: var(--dw-text, #1a1a1a) !important; text-fill-color: var(--dw-text, #1a1a1a) !important; background-image: none !important; }
}

@media (max-width: 768px) {
    .dw-overview-inner-box { padding: 40px 20px; border-radius: 16px; }
    .dw-highlights-card { padding: 30px 15px; }
    .dw-hc-item { font-size: 12px; padding: 15px 8px; }
    .dw-hc-item svg { width: 16px; height: 16px; }
}

/* ==========================================
   VENUES SECTION (SLIDER WITH RIGHT BLEED)
========================================== */
.dw-venues-section {
    overflow: hidden; /* Prevents horizontal scrollbar on body */
    padding-bottom: 40px;
}

.dw-venues-top-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 36px;
    gap: 24px;
}

.dw-venues-row {
    display: flex;
    justify-content: flex-start;
    flex-direction: column;
    gap: 0;
}


.dw-venues-top-row .dw-section-title {
    margin: 0 !important;
    font-family: 'Libre Baskerville', Georgia, serif !important;
    font-size: clamp(23px, 2.65vw, 35px) !important;
    font-weight: 400 !important;
    line-height: 1.12 !important;
    letter-spacing: 0.005em !important;
    text-transform: none !important;
    text-align: left !important;
}


/* Custom Nav Arrows */
.dw-venues-nav {
    display: flex;
    align-items: center;
    gap: 14px;
    margin-bottom: 0;
    padding-bottom: 0;
    flex-shrink: 0;
}


.dw-venue-prev, .dw-venue-next {
    width: 50px;
    height: 50px;
    border: 1px solid #eaeaea;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    color: var(--dw-text, #1a1a1a);
    transition: all 0.4s ease;
    background: #ffffff;
}

.dw-venue-prev:hover, .dw-venue-next:hover {
    background: var(--dw-green, #7e8460);
    border-color: var(--dw-green, #7e8460);
    color: #ffffff;
}

/* Swiper auto-adds this class when at the start/end */
.dw-venue-prev.swiper-button-disabled, .dw-venue-next.swiper-button-disabled {
    opacity: 0.3;
    cursor: not-allowed;
    pointer-events: none;
}

/* Edge-to-Edge Slider Wrapper */
.dw-venues-slider-wrapper {
    width: 100vw;
    margin-left: calc(-50vw + 50%);
    /* This calculation perfectly aligns the first slide to your 1300px container */
    padding-left: calc((100vw - 1300px) / 2);
    padding-bottom: 80px ;
}

.dw-venues-swiper {
    width: 100%;
    overflow: visible !important; /* Allows the cards to bleed off the right screen */
}

.dw-venues-swiper .swiper-wrapper,
.dw-rooms-swiper .swiper-wrapper {
    align-items: stretch;
}

.dw-venues-swiper .swiper-slide,
.dw-rooms-swiper .swiper-slide {
    height: auto;
    display: flex;
}

.dw-venues-swiper .swiper-slide > *,
.dw-rooms-swiper .swiper-slide > * {
    width: 100%;
}

/* Editorial Venue Card (Sharp & Clean) */
.dw-venue-card-editorial {
    background: #f8f6f0;
    display: flex;
    flex-direction: column;
    gap: 0;
    height: 100%;
    min-height: 100%;
}


.dw-venue-img-wrap {
    width: 100%;
    aspect-ratio: 4/3;
    overflow: hidden;
    position: relative;
}

.dw-venue-img-wrap img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.8s cubic-bezier(0.19, 1, 0.22, 1);
}

.dw-venue-card-editorial:hover .dw-venue-img-wrap img {
    transform: scale(1.05); /* Premium slow zoom on hover */
}
.dw-venue-info {
    padding: 22px 20px 24px;
    display: flex;
    flex-direction: column;
    flex: 1;
}


.dw-venue-info h3 {
    font-family: 'Libre Baskerville', Georgia, serif;
    font-size: 16px;
    font-weight: 400;
    line-height: 1.35;
    color: var(--dw-text, #1a1a1a);
    margin: 0 0 14px 0;
    text-transform: none;
}


.dw-venue-meta {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 12px;
    font-family: 'poppins', sans-serif;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: var(--dw-green, #7e8460);
    margin-bottom: 15px;
}

.dw-venue-meta strong { color: #888; }

.dw-venue-info p {
    font-family: 'poppins', sans-serif;
    font-size: 13px;
    font-weight: 300;
    line-height: 1.75;
    color: #555;
    margin: 0;
}

.dw-venue-info .dw-text-truncate {
    min-height: calc(1.75em * 3);
}

.dw-room-readmore-wrap {
    margin-top: auto !important;
    padding-top: 18px !important;
}

/* Responsive Breakpoints */
@media (max-width: 1340px) {
    /* Fallback padding for screens smaller than 1300px */
    .dw-venues-slider-wrapper { padding-left: 20px; } 
}

@media (max-width: 768px) {
    .dw-venues-top-row { align-items: center; margin-bottom: 30px; }
    .dw-venues-nav { gap: 10px; }
    .dw-venue-prev, .dw-venue-next { width: 40px; height: 40px; } /* Smaller arrows on mobile */
    .dw-venue-info h3 { font-size: 15px; }
    .dw-venue-meta { font-size: 10px; gap: 8px; }
}


/* ==========================================
   PACKAGES SECTION (TABBED LAYOUT)
========================================== */
.dw-bg-brand-green {
    /*background-color: var(--dw-green, #7e8460) !important;*/
    /*border-bottom: none !important;*/
}
.dw-packages-inner-box span{
    text-align: center;
}

.dw-packages-inner-box .dw-section-title {
    color: var(--dw-text, #1a1a1a);
    border-bottom-color: var(--dw-green, #7e8460);
    margin-top: 0px;
    margin-bottom: 40px;
    font-size: clamp(20px, 6vw, 40px) !important;
    font-weight: 600;
    letter-spacing: -1px;
    text-transform: capitalize;
    text-align: center;
}

/* --- Swipeable Tabs Container --- */
.dw-pkg-tabs-container {
    position: relative;
    margin-bottom: 50px;
    border-bottom: 1px solid #eaeaea;
}

/* Fade Mask for Mobile Swiping */
.dw-pkg-tabs-container::after {
    content: '';
    position: absolute;
    top: 0; right: 0;
    width: 80px; height: 100%;
    background: linear-gradient(to right, rgba(255,255,255,0), #ffffff);
    pointer-events: none;
}

.dw-pkg-tabs {
    display: flex;
    gap: 40px;
    list-style: none;
    margin: 0;
    padding: 0 80px 0 0; /* Padding allows the last item to scroll past the fade mask */
    overflow-x: auto;
    white-space: nowrap;
    scrollbar-width: none;
    -ms-overflow-style: none;
    justify-content: center;
}
.dw-pkg-tabs::-webkit-scrollbar { display: none; }

.dw-pkg-tab {
    font-family: 'Poppins', Georgia, serif;
    font-size: 13px;
    font-weight: 500;
    color: #aaaaaa;
    cursor: pointer;
    padding-bottom: 15px;
    position: relative;
    transition: color 0.3s;
    text-transform: uppercase;
    letter-spacing: 1px;
}

.dw-pkg-tab:hover { color: var(--dw-text, #1a1a1a); }
.dw-pkg-tab.active { color: var(--dw-green, #7e8460); }

/* Animated Bottom Line */
.dw-pkg-tab::after {
    content: ''; position: absolute;
    bottom: -1px; left: 0;
    width: 100%; height: 3px;
    background: var(--dw-green, #7e8460);
    transform: scaleX(0);
    transition: transform 0.3s cubic-bezier(0.19, 1, 0.22, 1);
    transform-origin: left;
}
.dw-pkg-tab.active::after { transform: scaleX(1); }

/* --- Split Layout --- */
.dw-pkg-split {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 60px;
    align-items: start;
}

/* Left Image */
.dw-pkg-image-col {
    position: relative;
    height: 100%;
}
.dw-pkg-sticky-img {
    position: sticky;
    top: 22vh;
    height: 70vh;
    min-height: 400px;
    max-height: 600px;
    width: 100%;
    border-radius: 12px;
    overflow: hidden;
}
.dw-pkg-sticky-img img {
    width: 100%; height: 100%; object-fit: cover;
    transition: opacity 0.4s ease;
}

/* Right Content Panes */
.dw-pkg-pane {
    display: none;
    animation: dwFadeInUp 0.5s ease forwards;
}
.dw-pkg-pane.active { display: block; }

.dw-pkg-meta-row {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 12px;
    font-family: 'poppins', sans-serif;
    font-size: 13px;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: #888;
    margin-bottom: 25px;
    padding-bottom: 20px;
    border-bottom: 1px solid #eaeaea;
}
.dw-pkg-meta-row strong { color: var(--dw-text, #1a1a1a); }
.dw-meta-dot { width: 4px; height: 4px; background: #ccc; border-radius: 50%; }

.dw-pkg-inclusions { margin: 0 0 30px 0; padding: 0; list-style: none; }
.dw-pkg-inclusions li {
    font-family: 'poppins', sans-serif;
    font-size: 13px;
    line-height: 1.8;
    color: #555555;
    margin-bottom: 12px;
    padding-left: 28px;
    position: relative;
}
.dw-pkg-inclusions li::before {
    content: '✓';
    position: absolute;
    left: 0; top: 0;
    color: var(--dw-green, #7e8460);
    font-weight: 700;
}

/* Mobile Adjustments */
@media (max-width: 1024px) {
    .dw-pkg-split { grid-template-columns: 1fr; gap: 0px; }
    .dw-pkg-sticky-img { position: relative; top: 0; height: 0vh; min-height: 300px; display: none;}
    .dw-pkg-tabs-container {
    position: relative;
    margin-bottom: 30px;
    border-bottom: 1px solid #eaeaea;}
}
@media (max-width: 768px) {
    .dw-packages-inner-box { padding: 0px 0px; border-radius: 16px; }
    .dw-pkg-tabs-container::after { width: 30px; }
    .dw-pkg-tab { font-size: 13px; gap: 20px; }
    .dw-pkg-meta-row { flex-direction: column; align-items: flex-start; gap: 8px; }
    .dw-pkg-meta-row .dw-meta-dot { display: none; }
    .dw-sticky-nav-wrapper {
    position: sticky;
    top: 70px;
    z-index: 99;
}
}

/* ==========================================
   ROOMS & SUITES (ARROWS & READ MORE MODAL)
========================================== */

/* Independent Arrows for Rooms (Prevents Venues conflict) */
.dw-room-prev, .dw-room-next {
    width: 50px;
    height: 50px;
    border: 1px solid #eaeaea;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    color: var(--dw-text, #1a1a1a);
    transition: all 0.4s ease;
    background: #ffffff;
    flex-shrink: 0;
}

.dw-room-prev:hover, .dw-room-next:hover {
    background: var(--dw-green, #7e8460); border-color: var(--dw-green, #7e8460); color: #ffffff;
}
.dw-room-prev.swiper-button-disabled, .dw-room-next.swiper-button-disabled {
    opacity: 0.3; cursor: not-allowed; pointer-events: none; display: none; /* Hides completely if useless */
}

/* 3-Line Text Truncation */
.dw-text-truncate {
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.dw-read-more-trigger {
    display: inline-flex !important;
    align-items: center;
    gap: 8px;
    background: transparent !important;
    border: 0 !important;
    border-bottom: 1px solid rgba(126, 132, 96, 0.45) !important;
    border-radius: 0 !important;
    padding: 0 0 5px 0 !important;
    font-family: 'poppins', sans-serif !important;
    font-size: 10px !important;
    font-weight: 400 !important;
    letter-spacing: 0.28em !important;
    line-height: 1 !important;
    text-transform: uppercase !important;
    color: var(--dw-green, #7e8460) !important;
    cursor: pointer;
}

.dw-read-more-trigger:hover {
    color: var(--dw-text, #1a1a1a) !important;
    border-bottom-color: var(--dw-text, #1a1a1a) !important;
}

.dw-read-more-trigger svg {
    width: 13px;
    height: 13px;
    transition: transform 0.25s ease;
}

.dw-read-more-trigger:hover svg {
    transform: translateX(3px);
}

/* Bottom Sheet Modal */
.dw-room-modal-overlay {
    position: fixed; inset: 0; background: rgba(0,0,0,0.6);
    z-index: 100000; opacity: 0; pointer-events: none; transition: opacity 0.3s ease;
}
.dw-room-modal-overlay.active { opacity: 1; pointer-events: auto; }

.dw-room-modal-sheet {
    position: fixed; bottom: 0; left: 50%; transform: translateX(-50%) translateY(100%);
    width: 100%; max-width: 500px; max-height: 85vh; background: #ffffff;
    border-radius: 24px 24px 0 0; z-index: 100001;
    display: flex; flex-direction: column;
    transition: transform 0.4s cubic-bezier(0.19, 1, 0.22, 1);
    box-shadow: 0 -10px 40px rgba(0,0,0,0.1);
}
.dw-room-modal-overlay.active .dw-room-modal-sheet { transform: translateX(-50%) translateY(0); }

.dw-rm-header {
    display: flex; justify-content: space-between; align-items: center;
    padding: 25px 30px; border-bottom: 1px solid #eaeaea;
}
.dw-rm-header h3 {
    margin: 0; font-family: 'Libre Baskerville', Georgia, serif; font-size: 24px; color: var(--dw-text, #1a1a1a);
}
.dw-rm-close {
    font-size: 32px; font-weight: 300; cursor: pointer; color: #888; line-height: 1; transition: color 0.3s;
}
.dw-rm-close:hover { color: var(--dw-green, #7e8460); }

.dw-rm-body {
    padding: 30px;
    overflow-y: auto;
    font-family: 'poppins', sans-serif;
    font-size: 13px;
    font-weight: 300;
    line-height: 1.8;
    color: #555 !important;
    -webkit-text-fill-color: #555 !important;
}


.dw-room-modal-sheet,
.dw-room-modal-sheet * {
    visibility: visible !important;
}

.dw-room-modal-sheet .dw-rm-body,
.dw-room-modal-sheet .dw-rm-body p,
.dw-room-modal-sheet .dw-rm-body div,
.dw-room-modal-sheet .dw-rm-body span,
.dw-room-modal-sheet .dw-rm-body li,
.dw-room-modal-sheet .dw-rm-body .dw-text-fill {
    color: #555 !important;
    opacity: 1 !important;
    visibility: visible !important;
    -webkit-text-fill-color: #555 !important;
    text-fill-color: #555 !important;
    background-image: none !important;
    background: transparent !important;
}

@media (max-width: 768px) {
    .dw-room-prev, .dw-room-next { width: 40px; height: 40px; }
    .dw-rm-header { padding: 20px 25px; }
    .dw-rm-header h3 { font-size: 20px; }
    .dw-rm-body { padding: 25px; font-size: 13px; }
}

/* ==========================================
   AMENITIES & ACTIVITIES SECTION
========================================== */

.dw-amenities-split-layout {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 60px;
    align-items: start;
    margin-top: 40px;
}

.dw-am-heading {
    font-family: 'Libre Baskerville', Georgia, serif;
    font-size: 22px;
    font-weight: 400;
    line-height: 1.25;
    color: var(--dw-text, #1a1a1a);
    margin: 0 0 25px 0;
    text-transform: none;
    letter-spacing: 0.005em;
}


.dw-am-grid {
    display: grid;
    grid-template-columns: 1fr 1fr; /* 2 items per row inside the column */
    gap: 15px;
}

/* The Premium Pill Card */
.dw-am-card {
    display: flex;
    align-items: center;
    gap: 15px;
    padding: 16px 20px;
    background: #ffffff;
    border: 1px solid #eaeaea;
    border-radius: 12px;
    transition: all 0.3s cubic-bezier(0.19, 1, 0.22, 1);
    box-shadow: 0 4px 15px rgba(0,0,0,0.01);
}

.dw-am-card:hover {
    border-color: var(--dw-green, #7e8460);
    box-shadow: 0 8px 25px rgba(126, 132, 96, 0.1);
    transform: translateY(-2px);
}

.dw-am-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--dw-green, #7e8460);
    flex-shrink: 0;
}

.dw-am-icon svg {
    width: 20px;
    height: 20px;
}

.dw-am-text {
    font-family: 'poppins', sans-serif;
    font-size: 13px;
    font-weight: 300;
    line-height: 1.45;
    color: #555555;
}


/* Responsive Adjustments */
@media (max-width: 1024px) {
    .dw-amenities-split-layout { grid-template-columns: 1fr; gap: 50px; }
    .dw-am-grid { grid-template-columns: repeat(3, 1fr); }
}

@media (max-width: 768px) {
    .dw-am-grid { grid-template-columns: 1fr; } /* Stacks to 1 column on mobile */
    .dw-am-card { padding: 14px 18px; }
    .dw-am-text { font-size: 13px; }
    /* NEW: Hides the activities column on phones */
    .dw-hide-on-mobile { display: none !important; }
}
/*.dw-section-inner span {*/
/*    text-align: center;*/
#amenities span.dw-small-hed.dw-aw-anim {
    text-align: center;
}

#dining span.dw-small-hed.dw-aw-anim{
     text-align: center;
}
.dw-section-inner .dw-section-title {
    font-family: 'Libre Baskerville', Georgia, serif !important;
    border-bottom-color: var(--dw-green, #7e8460);
    margin-top: 0px;
    margin-bottom: 40px;
    font-size: clamp(20px, 2.65vw, 30px) !important;
    font-weight: 400 !important;
    line-height: 1.18 !important;
    letter-spacing: 0.005em !important;
    text-transform: none !important;
    text-align: center;
}

/* ==========================================
   AMENITIES SLIDE-OUT SIDEBAR
========================================== */

.dw-am-modal-overlay {
    position: fixed; inset: 0; background: rgba(0,0,0,0.6);
    z-index: 100002; opacity: 0; pointer-events: none;
    transition: opacity 0.4s ease;
}
.dw-am-modal-overlay.active { opacity: 1; pointer-events: auto; }

.dw-am-sidebar {
    position: fixed; top: 0; right: 0; width: 100%; max-width: 480px; height: 100vh;
    background: #FDFBF9; z-index: 100003;
    transform: translateX(100%); transition: transform 0.4s cubic-bezier(0.25, 1, 0.5, 1);
    display: flex; flex-direction: column;
    box-shadow: -10px 0 40px rgba(0,0,0,0.1);
    font-family: 'poppins', sans-serif;
}
.dw-am-sidebar.active { transform: translateX(0); }

.dw-am-header {
    display: flex; justify-content: space-between; align-items: center;
    padding: 30px; border-bottom: 1px solid #eaeaea; background: #ffffff;
}
.dw-am-header h3 {
    font-family: 'Libre Baskerville', Georgia, serif; font-size: 22px; line-height: 1.15; margin: 0; color: #1a1a1a; text-transform: none;
}
.dw-am-close {
    font-size: 38px; cursor: pointer; color: #888; line-height: 1; transition: color 0.3s ease;
}
.dw-am-close:hover { color: var(--dw-green, #7e8460); }

.dw-am-body {
    padding: 30px; overflow-y: auto; flex-grow: 1;
}

.dw-am-sidebar-title {
    font-family: 'Libre Baskerville', Georgia, serif;
    font-size: 17px;
    font-weight: 400;
    text-transform: none;
    letter-spacing: 0.01em;
    color: var(--dw-green, #7e8460);
    margin: 0 0 22px 5px;
}

/* Inside the sidebar, we stack them 1 column to give the text room */
.dw-am-sidebar-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 12px;
}

@media (max-width: 768px) {
    .dw-am-sidebar { max-width: 100%; }
    .dw-am-header { padding: 20px; }
    .dw-am-body { padding: 20px; }
}

/* ==========================================
   DINING & DRINKS SECTION
========================================== */

.dw-dining-split {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 60px;
    align-items: start;
}

.dw-dining-image-col {
    position: relative;
    height: 100%;
}

.dw-dining-sticky-img {
    position: sticky;
    top: 24vh;
    bottom: 5vh;
    height: 70vh;
    min-height: 400px;
    /* max-height: 600px; */
    width: 100%;
    border-radius: 16px;
    overflow: hidden;
    box-shadow: 0 20px 40px rgba(0,0,0,0.06);
}

.dw-dining-sticky-img img {
    width: 100%; height: 100%; object-fit: cover;
    transition: opacity 0.4s ease;
}

/* Dining Accordion Structure */
.dw-dining-accordion {
    border-bottom: 1px solid rgba(0,0,0,0.08);
    overflow: hidden;
}

.dw-dining-accordion:first-child {
    border-top: 1px solid rgba(0,0,0,0.08);
}

.dw-dining-head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 30px 0;
    cursor: pointer;
    transition: all 0.3s ease;
}

.dw-dining-head h3 {
    font-family: 'poppins', sans-serif;
    font-size: 15px;
    font-weight: 500;
    line-height: 1.45;
    color: var(--dw-text, #1a1a1a);
    margin: 0;
    transition: color 0.3s ease;
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
}


/* Premium Badge for Cuisine Type */
.dw-dining-type {
    font-family: 'poppins', sans-serif;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: var(--dw-green, #7e8460);
    background: rgba(126, 132, 96, 0.1);
    padding: 6px 14px;
    border-radius: 30px;
}

.dw-dining-accordion.active .dw-dining-head h3 {
    color: var(--dw-green, #7e8460);
}

/* Custom Animated Plus/Minus Icon */
.dw-dining-icon {
    position: relative;
    width: 20px;
    height: 20px;
    flex-shrink: 0;
}

.dw-d-line-h, .dw-d-line-v {
    position: absolute;
    background-color: var(--dw-text, #1a1a1a);
    transition: transform 0.4s cubic-bezier(0.19, 1, 0.22, 1), background-color 0.3s ease;
}

.dw-d-line-h { top: 9px; left: 0; width: 20px; height: 2px; }
.dw-d-line-v { top: 0; left: 9px; width: 2px; height: 20px; }

.dw-dining-accordion.active .dw-d-line-v { transform: rotate(90deg); }

.dw-dining-accordion.active .dw-d-line-h,
.dw-dining-accordion.active .dw-d-line-v {
    background-color: var(--dw-green, #7e8460);
}

/* Accordion Body */
.dw-dining-body {
    display: none; 
    padding-bottom: 30px;
}

.dw-dining-accordion.active .dw-dining-body {
    display: block;
    animation: dwFadeInUp 0.5s ease forwards;
}

.dw-dining-body p {
    font-family: 'poppins', sans-serif;
    font-size: 13px;
    font-weight: 300;
    line-height: 1.8;
    color: #555555;
    margin: 0;
}


/* Responsive Breakpoints */
@media (max-width: 1024px) {
    .dw-dining-split { grid-template-columns: 1fr; gap: 40px; }
    .dw-dining-sticky-img { position: relative; top: 0; height: 45vh; min-height: 350px; }
}

@media (max-width: 768px) {
    .dw-dining-head h3 { font-size: 15px; gap: 10px; }
    .dw-dining-type { font-size: 10px; padding: 4px 10px; }
    .dw-dining-head { padding: 20px 0; }
    .dw-dining-body p { font-size: 13px; }
}

/* ==========================================================================
   DESTAWED SLIDE-OUT QUOTE FORM
========================================================================== */

.dw-quote-overlay {
    position: fixed; inset: 0; background: rgba(0,0,0,0.6);
    z-index: 99998; opacity: 0; pointer-events: none;
    transition: opacity 0.4s ease;
}
.dw-quote-overlay.active { opacity: 1; pointer-events: auto; }

.dw-quote-sidebar {
    position: fixed; top: 0; right: 0; width: 100%; max-width: 450px; height: 100vh;
    background: #ffffff; z-index: 99999;
    transform: translateX(100%); transition: transform 0.4s cubic-bezier(0.25, 1, 0.5, 1);
    display: flex; flex-direction: column;
    box-shadow: -10px 0 40px rgba(0,0,0,0.1);
    font-family: 'poppins', sans-serif;
}
.dw-quote-sidebar.active { transform: translateX(0); }

.dw-quote-header {
    display: flex; justify-content: space-between; align-items: center;
    padding: 30px; border-bottom: 1px solid #eaeaea; background: #FDFBF9;
}
.dw-quote-header h3 {
    font-family: 'Libre Baskerville', Georgia, serif; font-size: 26px; margin: 0; color: #1a1a1a;
}
.dw-close-quote { font-size: 38px; cursor: pointer; color: #1a1a1a; line-height: 1; }

.dw-quote-body {
    padding: 30px; overflow-y: auto; flex-grow: 1;
}
.dw-quote-body p { color: #666; margin-top: 0; margin-bottom: 25px; line-height: 1.6; }

.dw-form-group { margin-bottom: 20px; }
.dw-form-group label { display: block; font-family: 'Libre Baskerville', Georgia, serif; font-size: 14px; font-weight: 600; margin-bottom: 8px; text-transform: uppercase; letter-spacing: 1px; color: #1a1a1a; }
.dw-form-group input, .dw-form-group select {
    width: 100%; padding: 15px; border: 1px solid #ddd; border-radius: 8px;
    font-family: 'poppins', sans-serif; font-size: 16px; background: #fff;
    transition: border-color 0.3s, box-shadow 0.3s; box-sizing: border-box;
}
.dw-form-group input:focus, .dw-form-group select:focus {
    border-color: #FF6B64; outline: none; box-shadow: 0 0 0 3px rgba(255,107,100,0.1);
}

.dw-submit-btn { width: 100%; justify-content: center; margin-top: 10px; border: none; cursor: pointer; }
.dw-submit-btn.loading { opacity: 0.7; pointer-events: none; }

.dw-form-response { margin-top: 20px; padding: 15px; border-radius: 8px; font-size: 15px; font-weight: 500; display: none; }
.dw-form-response.success { background: #e8f5e9; color: #2e7d32; border: 1px solid #c8e6c9; display: block; }
.dw-form-response.error { background: #ffebee; color: #c62828; border: 1px solid #ffcdd2; display: block; }

@media (max-width: 768px) {
    .dw-quote-sidebar { max-width: 100%; } /* Full width on mobile */
}


/* ==========================================
   FAQS SECTION — TRAVEL MANAGEMENT STYLE
========================================== */

.dw-faq-split-layout,
.dw-faq-split-layout *,
.dw-faq-split-layout *::before,
.dw-faq-split-layout *::after {
    box-sizing: border-box !important;
}

.dw-section#faqs {
    background-color: #F7F7F3 !important;
    padding-top: 110px !important;
    padding-bottom: 110px !important;
    border-bottom: 0 !important;
}

.dw-faq-split-layout {
    --dwc-dark: #1a1a1a;
    --dwc-brown: #413225;
    --dwc-olive: #7E8460;
    --dwc-muted: #756050;
    --dwc-cream: #E9E0CF;
    --dwc-sand: #BFB198;
    --dwc-offwhite: #F7F7F3;
    --dwc-white: #FFFFFF;
    --dwc-sans: 'Poppins', system-ui, -apple-system, sans-serif;
    --dwc-serif: 'Libre Baskerville', Georgia, serif;

    display: grid !important;
    grid-template-columns: 0.85fr 1fr !important;
    gap: 80px !important;
    align-items: start !important;
    margin-top: 0 !important;
}

.dw-faq-left {
    position: sticky !important;
    top: 110px !important;
}

.dw-faq-left-stack {
    padding-top: 8px !important;
}

.dw-faq-left .dw-small-hed,
.dw-faq-left .dw-aw-anim {
    display: inline-block !important;
    font-family: var(--dwc-sans) !important;
    font-size: 11px !important;
    font-weight: 400 !important;
    letter-spacing: 0.34em !important;
    text-transform: uppercase !important;
    color: var(--dwc-olive) !important;
    margin: 0 0 20px !important;
    text-align: left !important;
}

.dw-faq-left .dw-faq-rule {
    display: block !important;
    width: 44px !important;
    height: 1px !important;
    background-color: rgba(126, 132, 96, 0.45) !important;
    margin: 0 0 26px !important;
}

.dw-faq-left .dw-section-title,
.dw-faq-left .dw-faq-title {
    font-family: var(--dwc-serif) !important;
    font-size: clamp(28px, 3.2vw, 44px) !important;
    font-weight: 400 !important;
    line-height: 1.16 !important;
    letter-spacing: 0.005em !important;
    color: var(--dwc-dark) !important;
    margin: 0 0 22px !important;
    text-transform: none !important;
    background-image: none !important;
    background-size: auto !important;
    background-position: initial !important;
    -webkit-background-clip: initial !important;
    background-clip: initial !important;
    -webkit-text-fill-color: var(--dwc-dark) !important;
}

.dw-faq-subtitle {
    font-family: var(--dwc-sans) !important;
    font-size: 14px !important;
    font-weight: 300 !important;
    line-height: 1.85 !important;
    color: var(--dwc-muted) !important;
    margin: 0 0 40px !important;
    max-width: 380px !important;
}

.dw-faq-cta-card {
    background-color: var(--dwc-white) !important;
    border: 1px solid rgba(126, 132, 96, 0.18) !important;
    padding: 32px 30px !important;
    max-width: 420px !important;
}

.dw-faq-cta-eyebrow {
    display: inline-block !important;
    font-family: var(--dwc-sans) !important;
    font-size: 10.5px !important;
    font-weight: 500 !important;
    letter-spacing: 0.28em !important;
    text-transform: uppercase !important;
    color: var(--dwc-olive) !important;
    margin-bottom: 14px !important;
}

.dw-faq-cta-text {
    font-family: var(--dwc-sans) !important;
    font-size: 13px !important;
    font-weight: 300 !important;
    line-height: 1.75 !important;
    color: var(--dwc-muted) !important;
    margin: 0 0 24px !important;
}

.dw-faq-cta-btn {
    position: relative !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 10px !important;
    padding: 14px 28px !important;
    font-family: var(--dwc-sans) !important;
    font-size: 10.5px !important;
    font-weight: 500 !important;
    letter-spacing: 0.28em !important;
    text-transform: uppercase !important;
    text-decoration: none !important;
    color: var(--dwc-dark) !important;
    border: 1px solid rgba(26, 26, 26, 0.85) !important;
    background: transparent !important;
    border-radius: 0 !important;
    overflow: hidden !important;
    cursor: pointer !important;
    transition: color 0.55s ease, border-color 0.55s ease !important;
    box-shadow: none !important;
}

.dw-faq-cta-btn .dw-faq-btn-fill {
    position: absolute !important;
    inset: 0 !important;
    background: var(--dwc-dark) !important;
    transform: translateX(-101%) !important;
    transition: transform 0.65s cubic-bezier(0.77, 0, 0.175, 1) !important;
    z-index: 0 !important;
}

.dw-faq-cta-btn .dw-faq-btn-text {
    position: relative !important;
    z-index: 1 !important;
}

.dw-faq-cta-btn:hover,
.dw-faq-cta-btn:focus {
    color: var(--dwc-white) !important;
    border-color: var(--dwc-dark) !important;
    background: transparent !important;
}

.dw-faq-cta-btn:hover .dw-faq-btn-fill,
.dw-faq-cta-btn:focus .dw-faq-btn-fill {
    transform: translateX(0) !important;
}

.dw-faq-right {
    width: 100% !important;
}

.dw-faq-wrapper {
    display: flex !important;
    flex-direction: column !important;
    border-top: 0 !important;
}

.dw-faq-item {
    border-top: 1px solid rgba(26, 26, 26, 0.10) !important;
    border-bottom: 0 !important;
    overflow: hidden !important;
}

.dw-faq-item:last-child {
    border-bottom: 1px solid rgba(26, 26, 26, 0.10) !important;
}

.dw-faq-head {
    width: 100% !important;
    background: transparent !important;
    border: 0 !important;
    padding: 26px 0 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 24px !important;
    cursor: pointer !important;
    text-align: left !important;
    box-shadow: none !important;
    border-radius: 0 !important;
    transition: none !important;
}

.dw-faq-head h4 {
    font-family: var(--dwc-serif) !important;
    font-size: clamp(15px, 1.4vw, 18px) !important;
    font-weight: 400 !important;
    line-height: 1.35 !important;
    color: var(--dwc-dark) !important;
    transition: color 0.3s ease !important;
    flex: 1 !important;
    letter-spacing: 0.005em !important;
    margin: 0 !important;
    padding: 0 !important;
}

.dw-faq-head:hover h4,
.dw-faq-item.active .dw-faq-head h4 {
    color: var(--dwc-olive) !important;
}

.dw-faq-icon {
    position: relative !important;
    width: 34px !important;
    height: 34px !important;
    border-radius: 50% !important;
    border: 1px solid rgba(26, 26, 26, 0.18) !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    flex-shrink: 0 !important;
    color: var(--dwc-dark) !important;
    transition: transform 0.35s ease, background-color 0.35s ease, border-color 0.35s ease, color 0.35s ease !important;
}

.dw-f-line-h,
.dw-f-line-v {
    position: absolute !important;
    background-color: currentColor !important;
    transition: none !important;
}

.dw-f-line-h {
    top: 16px !important;
    left: 10px !important;
    width: 14px !important;
    height: 1.5px !important;
}

.dw-f-line-v {
    top: 10px !important;
    left: 16px !important;
    width: 1.5px !important;
    height: 14px !important;
}

.dw-faq-item.active .dw-faq-icon {
    transform: rotate(45deg) !important;
    background-color: var(--dwc-olive) !important;
    border-color: var(--dwc-olive) !important;
    color: var(--dwc-white) !important;
}

.dw-faq-item.active .dw-f-line-h,
.dw-faq-item.active .dw-f-line-v {
    background-color: currentColor !important;
}

.dw-faq-body {
    display: block !important;
    overflow: hidden !important;
    max-height: 0 !important;
    padding-bottom: 0 !important;
    transition: max-height 0.5s cubic-bezier(0.22, 1, 0.36, 1) !important;
}

.dw-faq-item.active .dw-faq-body {
    max-height: 700px !important;
    animation: none !important;
}

.dw-faq-body-inner {
    padding: 0 0 28px !important;
    max-width: 640px !important;
}

.dw-faq-body p {
    font-family: var(--dwc-sans) !important;
    font-size: 14px !important;
    font-weight: 300 !important;
    line-height: 1.85 !important;
    color: var(--dwc-muted) !important;
    margin: 0 0 14px !important;
}

.dw-faq-body p:last-child {
    margin-bottom: 0 !important;
}

@media (max-width: 1024px) {
    .dw-section#faqs {
        padding-top: 90px !important;
        padding-bottom: 90px !important;
    }

    .dw-faq-split-layout {
        grid-template-columns: 1fr !important;
        gap: 50px !important;
    }

    .dw-faq-left {
        position: static !important;
        top: auto !important;
    }
}

@media (max-width: 600px) {
    .dw-section#faqs {
        padding-top: 70px !important;
        padding-bottom: 70px !important;
    }

    .dw-faq-cta-card {
        padding: 26px 22px !important;
    }

    .dw-faq-head {
        padding: 22px 0 !important;
    }

    .dw-faq-head h4 {
        font-size: 15px !important;
    }

    .dw-faq-body p {
        font-size: 13px !important;
    }
}
/* ==========================================
   FINAL CTA SECTION — BROWN BAND
========================================== */
.dw-expanding-cta,
.dw-expanding-cta *,
.dw-expanding-cta *::before,
.dw-expanding-cta *::after {
    box-sizing: border-box !important;
}

.dw-expanding-cta {
    --dwc-dark: #1a1a1a;
    --dwc-brown: #413225;
    --dwc-olive: #7E8460;
    --dwc-muted: #756050;
    --dwc-cream: #E9E0CF;
    --dwc-white: #FFFFFF;
    --dwc-sans: 'Poppins', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    --dwc-serif: 'Libre Baskerville', Georgia, serif;

    position: relative !important;
    width: 100vw !important;
    margin-left: calc(-50vw + 50%) !important;
    min-height: auto !important;
    padding: 110px 24px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    overflow: hidden !important;
    isolation: isolate !important;
    background: var(--dwc-brown) !important;
    border: 0 !important;
    border-bottom: 0 !important;
    text-align: center !important;
    font-family: var(--dwc-sans) !important;
    color: var(--dwc-white) !important;
}

.dw-cta-content-wrapper {
    position: relative !important;
    z-index: 2 !important;
    width: 100% !important;
    max-width: 760px !important;
    margin: 0 auto !important;
    padding: 0 !important;
    text-align: center !important;
    color: var(--dwc-white) !important;
    perspective: none !important;
}

.dw-cta-eyebrow {
    display: inline-block !important;
    font-family: var(--dwc-sans) !important;
    font-size: 11px !important;
    font-weight: 400 !important;
    letter-spacing: 0.34em !important;
    text-transform: uppercase !important;
    color: var(--dwc-cream) !important;
    margin: 0 0 22px !important;
}

.dw-cta-rule {
    display: block !important;
    width: 44px !important;
    height: 1px !important;
    background-color: rgba(233, 224, 207, 0.55) !important;
    margin: 0 auto 28px !important;
}

.dw-cta-heading,
.dw-expanding-cta h2.dw-cta-heading {
    display: block !important;
    font-family: var(--dwc-serif) !important;
    font-size: clamp(28px, 3.4vw, 48px) !important;
    font-weight: 400 !important;
    line-height: 1.18 !important;
    letter-spacing: 0.005em !important;
    color: var(--dwc-white) !important;
    text-transform: none !important;
    text-align: center !important;
    margin: 0 0 22px !important;
    padding: 0 !important;
    border: 0 !important;
    background: transparent !important;
    text-shadow: none !important;
}

.dw-expanding-cta .dw-word {
    display: inline !important;
    white-space: normal !important;
    transform: none !important;
    opacity: 1 !important;
    filter: none !important;
}

.dw-cta-sub,
.dw-expanding-cta p.dw-cta-sub {
    font-family: var(--dwc-sans) !important;
    font-size: 14px !important;
    font-weight: 300 !important;
    line-height: 1.85 !important;
    color: rgba(255, 255, 255, 0.78) !important;
    margin: 0 auto 40px !important;
    max-width: 540px !important;
    padding: 0 !important;
    background: transparent !important;
    text-align: center !important;
}

.dw-crazy-btn {
    display: flex !important;
    justify-content: center !important;
    margin: 0 !important;
    padding: 0 !important;
}

.dw-cta-outline-btn,
.dw-expanding-cta button.dw-cta-outline-btn {
    position: relative !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 12px !important;
    min-height: auto !important;
    padding: 16px 36px !important;
    font-family: var(--dwc-sans) !important;
    font-size: 11px !important;
    font-weight: 500 !important;
    line-height: 1 !important;
    letter-spacing: 0.28em !important;
    text-transform: uppercase !important;
    text-decoration: none !important;
    color: var(--dwc-white) !important;
    border: 1px solid rgba(255, 255, 255, 0.85) !important;
    background: transparent !important;
    border-radius: 0 !important;
    overflow: hidden !important;
    cursor: pointer !important;
    box-shadow: none !important;
    appearance: none !important;
    -webkit-appearance: none !important;
    transition: color 0.55s ease, border-color 0.55s ease !important;
}

.dw-cta-btn-fill {
    position: absolute !important;
    inset: 0 !important;
    background: var(--dwc-white) !important;
    transform: translateX(-101%) !important;
    transition: transform 0.65s cubic-bezier(0.77, 0, 0.175, 1) !important;
    z-index: 0 !important;
    pointer-events: none !important;
}

.dw-cta-btn-text,
.dw-cta-outline-btn svg {
    position: relative !important;
    z-index: 1 !important;
}

.dw-cta-outline-btn svg {
    width: 14px !important;
    height: 14px !important;
    flex-shrink: 0 !important;
    display: block !important;
    color: currentColor !important;
    transition: transform 0.35s ease !important;
}

.dw-cta-outline-btn:hover,
.dw-cta-outline-btn:focus,
.dw-expanding-cta button.dw-cta-outline-btn:hover,
.dw-expanding-cta button.dw-cta-outline-btn:focus {
    color: var(--dwc-brown) !important;
    background: transparent !important;
    border-color: var(--dwc-white) !important;
    outline: none !important;
    box-shadow: none !important;
}

.dw-cta-outline-btn:hover .dw-cta-btn-fill,
.dw-cta-outline-btn:focus .dw-cta-btn-fill {
    transform: translateX(0) !important;
}

.dw-cta-outline-btn:hover svg,
.dw-cta-outline-btn:focus svg {
    transform: translateX(3px) !important;
}

.dw-canvas-absolute-center,
.dw-canvas-wrapper,
.dw-canvas-img,
.dw-canvas-overlay {
    display: none !important;
}

@media (max-width: 991px) {
    .dw-expanding-cta {
        padding: 90px 20px !important;
    }
}

@media (max-width: 600px) {
    .dw-expanding-cta {
        padding: 70px 16px !important;
    }

    .dw-cta-heading,
    .dw-expanding-cta h2.dw-cta-heading {
        font-size: clamp(26px, 8vw, 34px) !important;
    }

    .dw-cta-sub,
    .dw-expanding-cta p.dw-cta-sub {
        font-size: 13px !important;
        line-height: 1.8 !important;
        margin-bottom: 34px !important;
    }

    .dw-cta-outline-btn,
    .dw-expanding-cta button.dw-cta-outline-btn {
        width: auto !important;
        max-width: 100% !important;
        padding: 14px 26px !important;
        font-size: 10.5px !important;
        letter-spacing: 0.24em !important;
    }
}

/* ==========================================================================
   HERO RESORT SEARCH — v3 (matches actual PHP HTML structure)
   PHP outputs:
     .dw-hero-suggestion-item > img + span > (strong + small)
   ========================================================================== */

.dw-hero-resort-search,
.dw-hero-resort-search * { box-sizing: border-box; }

.dw-hero-resort-search {
    width: 100% !important;
    max-width: 880px !important;
    margin: 0 auto !important;
    padding: 0 !important;
    text-align: center !important;
    color: #fff !important;
    font-family: 'Poppins', system-ui, -apple-system, sans-serif !important;
}

/* Reveal init state */
.dw-hero-resort-search > * {
    opacity: 0;
    transform: translateY(22px);
    transition: opacity 0.9s cubic-bezier(0.22, 1, 0.36, 1),
                transform 0.9s cubic-bezier(0.22, 1, 0.36, 1);
}
.dw-hero-resort-search.is-revealed > * { opacity: 1; transform: translateY(0); }
.dw-hero-resort-search.is-revealed > .dw-hero-search-eyebrow-rule { transition-delay: 0ms; }
.dw-hero-resort-search.is-revealed > .dw-hero-search-eyebrow      { transition-delay: 80ms; }
.dw-hero-resort-search.is-revealed > .dw-hero-search-title        { transition-delay: 180ms; }
.dw-hero-resort-search.is-revealed > .dw-hero-search-sub          { transition-delay: 300ms; }
.dw-hero-resort-search.is-revealed > .dw-hero-search-shell        { transition-delay: 440ms; }

.dw-hero-resort-search .dw-hero-search-eyebrow-rule {
    display: block !important;
    width: 48px !important;
    height: 1px !important;
    margin: 0 auto 18px !important;
    background-color: rgba(255, 255, 255, 0.55) !important;
    padding: 0 !important;
    border: 0 !important;
}

.dw-hero-resort-search .dw-hero-search-eyebrow {
    display: block !important;
    font-family: 'Poppins', system-ui, -apple-system, sans-serif !important;
    font-size: 11px !important;
    font-weight: 500 !important;
    letter-spacing: 0.36em !important;
    text-transform: uppercase !important;
    color: rgba(255, 255, 255, 0.9) !important;
    margin: 0 0 22px !important;
    line-height: 1.4 !important;
    padding: 0 !important;
    background: transparent !important;
    text-shadow: none !important;
}

.dw-hero-resort-search h1.dw-hero-search-title,
.dw-hero-resort-search .dw-hero-search-title {
    font-family: 'Libre Baskerville', Georgia, serif !important;
    font-size: clamp(38px, 3.4vw, 40px) !important;
    font-weight: 400 !important;
    line-height: 1.08 !important;
    letter-spacing: 0.005em !important;
    color: #fff !important;
    margin: 0 0 22px !important;
    padding: 0 !important;
    text-transform: none !important;
    text-shadow: 0 2px 24px rgba(0, 0, 0, 0.22) !important;
    background: transparent !important;
}

.dw-hero-resort-search p.dw-hero-search-sub,
.dw-hero-resort-search .dw-hero-search-sub {
    max-width: 580px !important;
    margin: 0 auto 44px !important;
    font-family: 'Poppins', system-ui, -apple-system, sans-serif !important;
    font-size: 14px !important;
    line-height: 1.85 !important;
    font-weight: 300 !important;
    color: rgba(255, 255, 255, 0.82) !important;
    letter-spacing: 0.005em !important;
    padding: 0 !important;
    background: transparent !important;
    text-shadow: none !important;
}

/* Bar shell */
.dw-hero-resort-search form.dw-hero-search-shell,
.dw-hero-resort-search .dw-hero-search-shell {
    position: relative !important;
    display: grid !important;
    grid-template-columns: 1fr auto !important;
    align-items: stretch !important;
    background: #ffffff !important;
    box-shadow: 0 24px 60px rgba(0, 0, 0, 0.18) !important;
    border: 0 !important;
    border-radius: 0 !important;
    padding: 0 !important;
    margin: 0 !important;
    text-align: left !important;
    gap: 0 !important;
}

/* Input */
.dw-hero-resort-search input#dw-search-input,
.dw-hero-resort-search .dw-hero-search-input {
    width: 100% !important;
    height: 64px !important;
    padding: 0 26px !important;
    margin: 0 !important;
    border: 0 !important;
    outline: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    border-radius: 0 !important;
    font-family: 'Libre Baskerville', Georgia, serif !important;
    font-size: 16px !important;
    font-weight: 400 !important;
    color: #1a1a1a !important;
    letter-spacing: 0.005em !important;
    line-height: 1.4 !important;
    -webkit-appearance: none !important;
    appearance: none !important;
    font-style: normal !important;
}
.dw-hero-resort-search input#dw-search-input::placeholder,
.dw-hero-resort-search .dw-hero-search-input::placeholder {
    color: #aa9b86 !important;
    opacity: 1 !important;
    font-style: normal !important;
}
.dw-hero-resort-search input#dw-search-input:focus,
.dw-hero-resort-search .dw-hero-search-input:focus {
    outline: 0 !important;
    box-shadow: none !important;
}

/* Submit */
.dw-hero-resort-search button.dw-hero-search-submit,
.dw-hero-resort-search .dw-hero-search-submit {
    position: relative !important;
    overflow: hidden !important;
    display: inline-flex !important;
    align-items: center !important;
    gap: 10px !important;
    height: 64px !important;
    padding: 0 32px !important;
    margin: 0 !important;
    background-color: #7E8460 !important;
    color: #ffffff !important;
    border: 0 !important;
    border-radius: 0 !important;
    cursor: pointer !important;
    font-family: 'Poppins', system-ui, -apple-system, sans-serif !important;
    font-size: 11px !important;
    font-weight: 500 !important;
    letter-spacing: 0.28em !important;
    text-transform: uppercase !important;
    line-height: 1 !important;
    box-shadow: none !important;
    text-shadow: none !important;
    background-image: none !important;
    transition: background-color 0.5s ease, color 0.5s ease !important;
    -webkit-appearance: none !important;
    appearance: none !important;
    white-space: nowrap !important;
}
.dw-hero-resort-search button.dw-hero-search-submit:hover,
.dw-hero-resort-search button.dw-hero-search-submit:focus,
.dw-hero-resort-search .dw-hero-search-submit:hover,
.dw-hero-resort-search .dw-hero-search-submit:focus {
    background-color: #1a1a1a !important;
    color: #ffffff !important;
    background-image: none !important;
    box-shadow: none !important;
    outline: 0 !important;
    border: 0 !important;
}
.dw-hero-resort-search .dw-hero-search-submit-text {
    position: relative !important;
    z-index: 1 !important;
    color: inherit !important;
}
.dw-hero-resort-search .dw-hero-search-submit-icon {
    width: 14px !important;
    height: 14px !important;
    color: currentColor !important;
    transition: transform 0.45s cubic-bezier(0.22, 1, 0.36, 1) !important;
}
.dw-hero-resort-search .dw-hero-search-submit:hover .dw-hero-search-submit-icon {
    transform: translateX(4px) !important;
}

/* ============== SUGGESTIONS DROPDOWN ============== */
.dw-hero-resort-search .dw-hero-search-suggestions,
.dw-hero-search-suggestions {
    position: fixed !important;
    background: #ffffff !important;
    box-shadow: 0 30px 60px rgba(26, 26, 26, 0.22) !important;
    max-height: 460px !important;
    overflow-y: auto !important;
    z-index: 99999 !important;
    display: none !important;
    text-align: left !important;
    padding: 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
}
.dw-hero-resort-search .dw-hero-search-suggestions.active,
.dw-hero-search-suggestions.active { display: block !important; }

/* Suggestion item — works both inside wrapper AND when portaled to body */
.dw-hero-resort-search button.dw-hero-suggestion-item,
.dw-hero-resort-search .dw-hero-suggestion-item,
.dw-hero-search-suggestions .dw-hero-suggestion-item,
button.dw-hero-suggestion-item {
    display: grid !important;
    grid-template-columns: 64px 1fr !important;
    gap: 18px !important;
    align-items: center !important;
    width: 100% !important;
    padding: 14px 20px !important;
    margin: 0 !important;
    background: #ffffff !important;
    border: 0 !important;
    border-bottom: 1px solid rgba(126, 132, 96, 0.18) !important;
    text-align: left !important;
    cursor: pointer !important;
    text-decoration: none !important;
    transition: background-color 0.3s ease !important;
    font-family: 'Poppins', system-ui, -apple-system, sans-serif !important;
    box-shadow: none !important;
    text-shadow: none !important;
    border-radius: 0 !important;
    color: #1a1a1a !important;
    -webkit-appearance: none !important;
    appearance: none !important;
}
.dw-hero-search-suggestions .dw-hero-suggestion-item:last-of-type,
.dw-hero-resort-search .dw-hero-suggestion-item:last-of-type { border-bottom: 0 !important; }
.dw-hero-search-suggestions .dw-hero-suggestion-item:hover,
.dw-hero-search-suggestions .dw-hero-suggestion-item:focus,
.dw-hero-resort-search .dw-hero-suggestion-item:hover,
.dw-hero-resort-search .dw-hero-suggestion-item:focus {
    background-color: #F7F7F3 !important;
    color: #1a1a1a !important;
    outline: 0 !important;
}

/* Image */
.dw-hero-search-suggestions .dw-hero-suggestion-item > img,
.dw-hero-resort-search .dw-hero-suggestion-item > img {
    width: 64px !important;
    height: 64px !important;
    object-fit: cover !important;
    display: block !important;
    border-radius: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    flex-shrink: 0 !important;
}

/* Inner span */
.dw-hero-search-suggestions .dw-hero-suggestion-item > span,
.dw-hero-resort-search .dw-hero-suggestion-item > span {
    display: flex !important;
    flex-direction: column !important;
    gap: 4px !important;
    min-width: 0 !important;
    color: #1a1a1a !important;
    background: transparent !important;
    text-align: left !important;
    font-style: normal !important;
}

/* Title */
.dw-hero-search-suggestions .dw-hero-suggestion-item strong,
.dw-hero-resort-search .dw-hero-suggestion-item strong,
.dw-hero-search-suggestions .dw-hero-suggestion-item > span > strong,
.dw-hero-resort-search .dw-hero-suggestion-item > span > strong {
    display: block !important;
    font-family: 'Libre Baskerville', Georgia, serif !important;
    font-size: 15px !important;
    font-weight: 400 !important;
    color: #1a1a1a !important;
    letter-spacing: 0.005em !important;
    line-height: 1.3 !important;
    text-transform: none !important;
    text-decoration: none !important;
    background: transparent !important;
    text-shadow: none !important;
    margin: 0 !important;
    padding: 0 !important;
    font-style: normal !important;
}

/* Location (small) */
.dw-hero-search-suggestions .dw-hero-suggestion-item small,
.dw-hero-resort-search .dw-hero-suggestion-item small,
.dw-hero-search-suggestions .dw-hero-suggestion-item > span > small,
.dw-hero-resort-search .dw-hero-suggestion-item > span > small {
    display: block !important;
    font-family: 'Poppins', system-ui, -apple-system, sans-serif !important;
    font-size: 10px !important;
    font-weight: 500 !important;
    letter-spacing: 0.26em !important;
    text-transform: uppercase !important;
    color: #7E8460 !important;
    line-height: 1.4 !important;
    text-decoration: none !important;
    background: transparent !important;
    text-shadow: none !important;
    margin: 0 !important;
    padding: 0 !important;
    font-style: normal !important;
}

/* "View matching resorts" button */
.dw-hero-search-suggestions .dw-hero-suggestion-view-all,
.dw-hero-resort-search .dw-hero-suggestion-view-all,
button.dw-hero-suggestion-view-all {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 10px !important;
    width: 100% !important;
    padding: 16px 18px !important;
    margin: 0 !important;
    background-color: #F7F7F3 !important;
    border: 0 !important;
    cursor: pointer !important;
    font-family: 'Poppins', system-ui, -apple-system, sans-serif !important;
    font-size: 10.5px !important;
    font-weight: 500 !important;
    letter-spacing: 0.28em !important;
    text-transform: uppercase !important;
    color: #7E8460 !important;
    transition: background-color 0.3s ease, color 0.3s ease !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    text-shadow: none !important;
    text-decoration: none !important;
    -webkit-appearance: none !important;
    appearance: none !important;
}
.dw-hero-search-suggestions .dw-hero-suggestion-view-all:hover,
.dw-hero-search-suggestions .dw-hero-suggestion-view-all:focus,
.dw-hero-resort-search .dw-hero-suggestion-view-all:hover,
.dw-hero-resort-search .dw-hero-suggestion-view-all:focus {
    background-color: #E9E0CF !important;
    color: #413225 !important;
    outline: 0 !important;
}

.dw-hero-search-suggestions .dw-hero-suggestion-empty,
.dw-hero-resort-search .dw-hero-suggestion-empty {
    padding: 30px 20px !important;
    text-align: center !important;
    font-family: 'Poppins', system-ui, -apple-system, sans-serif !important;
    font-size: 13px !important;
    color: #756050 !important;
    background: transparent !important;
}

/* Responsive */
@media (max-width: 720px) {
    .dw-hero-resort-search .dw-hero-search-sub { margin-bottom: 32px !important; font-size: 13px !important; }
    .dw-hero-resort-search .dw-hero-search-shell { grid-template-columns: 1fr !important; }
    .dw-hero-resort-search .dw-hero-search-input { height: 56px !important; font-size: 15px !important; padding: 0 18px !important; }
    .dw-hero-resort-search .dw-hero-search-submit { width: 100% !important; justify-content: center !important; height: 54px !important; border-top: 1px solid rgba(126, 132, 96, 0.18) !important; }
    .dw-hero-resort-search .dw-hero-suggestion-item { grid-template-columns: 56px 1fr !important; gap: 14px !important; padding: 12px 16px !important; }
    .dw-hero-resort-search .dw-hero-suggestion-item > img { width: 56px !important; height: 56px !important; }
}

@media (prefers-reduced-motion: reduce) {
    .dw-hero-resort-search > * { opacity: 1 !important; transform: none !important; transition: none !important; }
}

/* ==========================================================================
   RESORT CARDS + LOAD MORE — brand patch
   Targets .dw-resort-card and children + .dw-load-more-btn
   Defeats Elementor with high specificity + !important on every key declaration.
   ========================================================================== */

/* ============== CARD CONTAINER ============== */
.dw-resorts-grid .dw-resort-card,
.dw-resorts-grid > .dw-resort-card {
    display: flex !important;
    flex-direction: column !important;
    background: #ffffff !important;
    border: 1px solid rgba(186, 170, 140, 0.22) !important;
    border-radius: 0 !important;
    overflow: hidden !important;
    box-shadow: none !important;
    transition: border-color 0.45s ease, transform 0.45s ease, box-shadow 0.45s ease !important;
    padding: 0 !important;
    margin: 0 !important;
    font-family: 'Poppins', system-ui, -apple-system, sans-serif !important;
}
.dw-resorts-grid .dw-resort-card:hover {
    border-color: rgba(186, 170, 140, 0.55) !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 14px 32px rgba(26, 26, 26, 0.05) !important;
}

/* ============== IMAGE ============== */
.dw-resorts-grid .dw-resort-img-wrap,
.dw-resort-card .dw-resort-img-wrap {
    position: relative !important;
    display: block !important;
    width: 100% !important;
    aspect-ratio: 4 / 3 !important;
    overflow: hidden !important;
    background: #F7F7F3 !important;
    border-radius: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    line-height: 0 !important;
}
.dw-resorts-grid .dw-resort-img-wrap > img,
.dw-resort-card .dw-resort-img-wrap > img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    display: block !important;
    border-radius: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    transition: transform 0.85s cubic-bezier(0.22, 1, 0.36, 1) !important;
}
.dw-resorts-grid .dw-resort-card:hover .dw-resort-img-wrap > img {
    transform: scale(1.05) !important;
}

/* ============== BADGES (top of image) ============== */
.dw-resort-card .dw-badges-wrap {
    position: absolute !important;
    top: 14px !important;
    left: 14px !important;
    right: 14px !important;
    display: flex !important;
    justify-content: space-between !important;
    align-items: flex-start !important;
    gap: 8px !important;
    pointer-events: none !important;
    flex-wrap: wrap !important;
    z-index: 2 !important;
}
.dw-resort-card .dw-resort-badge,
.dw-resort-card .dw-capacity-badge {
    display: inline-flex !important;
    align-items: center !important;
    padding: 6px 12px !important;
    margin: 0 !important;
    background-color: rgba(26, 26, 26, 0.84) !important;
    color: #ffffff !important;
    font-family: 'Poppins', system-ui, -apple-system, sans-serif !important;
    font-size: 9.5px !important;
    font-weight: 500 !important;
    letter-spacing: 0.22em !important;
    text-transform: uppercase !important;
    line-height: 1.3 !important;
    white-space: nowrap !important;
    max-width: 100% !important;
    border: 0 !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    text-shadow: none !important;
    backdrop-filter: blur(6px) !important;
    -webkit-backdrop-filter: blur(6px) !important;
}
.dw-resort-card .dw-capacity-badge {
    margin-left: auto !important;
    background-color: rgba(126, 132, 96, 0.92) !important;
}

/* ============== CONTENT BODY ============== */
.dw-resort-card .dw-card-content {
    display: flex !important;
    flex-direction: column !important;
    flex-grow: 1 !important;
    padding: 22px 24px 24px !important;
    background: #ffffff !important;
}

/* Title — smaller, one line with ellipsis */
.dw-resort-card .dw-card-content h3,
.dw-resort-card .dw-card-title {
    margin: 0 0 6px !important;
    padding: 0 !important;
    font-family: 'Libre Baskerville', Georgia, serif !important;
    font-size: 16px !important;
    font-weight: 400 !important;
    line-height: 1.3 !important;
    color: #1a1a1a !important;
    letter-spacing: 0.005em !important;
    text-transform: none !important;
    text-shadow: none !important;
    background: transparent !important;
    display: block !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    max-width: 100% !important;
}
.dw-resort-card .dw-card-title .dw-title-link,
.dw-resort-card .dw-card-content h3 a {
    color: #1a1a1a !important;
    text-decoration: none !important;
    background: transparent !important;
    text-shadow: none !important;
    transition: color 0.35s ease !important;
    display: inline-block !important;
    max-width: 100% !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
    vertical-align: bottom !important;
}
.dw-resort-card .dw-card-title .dw-title-link:hover,
.dw-resort-card .dw-card-content h3 a:hover {
    color: #7E8460 !important;
    text-decoration: none !important;
}

/* Location — olive uppercase Poppins */
.dw-resort-card .dw-resort-location {
    margin: 0 !important;
    padding: 0 !important;
    font-family: 'Poppins', system-ui, -apple-system, sans-serif !important;
    font-size: 10px !important;
    font-weight: 500 !important;
    letter-spacing: 0.28em !important;
    text-transform: uppercase !important;
    color: #7E8460 !important;
    line-height: 1.4 !important;
    background: transparent !important;
}

/* Buttery divider removed — cross dividers between meta items handle separation */
.dw-resort-card .dw-card-rule {
    display: none !important;
}
.dw-resort-card .dw-resort-location {
    margin-bottom: 22px !important;
}

/* Kill any phantom border/shadow on neighbours that could look like a 2nd line */
.dw-resort-card .dw-card-content h3,
.dw-resort-card .dw-card-title,
.dw-resort-card .dw-resort-location,
.dw-resort-card .dw-resort-meta-grid,
.dw-resort-card .dw-resort-actions {
    border: 0 !important;
    border-top: 0 !important;
    border-bottom: 0 !important;
    box-shadow: none !important;
    text-shadow: none !important;
    background-image: none !important;
}
/* Restore location bottom-spacing now that divider is gone */
.dw-resort-card p.dw-resort-location {
    margin: 0 0 22px !important;
}

/* ============== META GRID ============== */
.dw-resort-card .dw-resort-meta-grid {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 0 !important;
    margin: 0 0 26px !important;
    padding: 0 !important;
}
.dw-resort-card .dw-meta-item {
    display: inline-flex !important;
    align-items: center !important;
    gap: 10px !important;
    margin: 0 !important;
    padding: 14px 18px 14px 0 !important;
    background: transparent !important;
    font-family: 'Poppins', system-ui, -apple-system, sans-serif !important;
    font-size: 12.5px !important;
    font-weight: 400 !important;
    color: #1a1a1a !important;
    line-height: 1.35 !important;
    position: relative !important;
}
/* Vertical hairline between columns (right edge of left-column items) */
.dw-resort-card .dw-meta-item:nth-child(odd) {
    padding-right: 18px !important;
    border-right: 1px solid #E9E0CF !important;
}
.dw-resort-card .dw-meta-item:nth-child(even) {
    padding-left: 18px !important;
}
/* Horizontal hairline between rows (bottom edge of first row items) */
.dw-resort-card .dw-meta-item:nth-child(1),
.dw-resort-card .dw-meta-item:nth-child(2) {
    border-bottom: 1px solid #E9E0CF !important;
}
.dw-resort-card .dw-meta-item:nth-child(3),
.dw-resort-card .dw-meta-item:nth-child(4) {
    padding-top: 14px !important;
}
.dw-resort-card .dw-meta-item > span:last-child {
    color: #1a1a1a !important;
    font-family: 'Poppins', system-ui, -apple-system, sans-serif !important;
    font-size: 12.5px !important;
    font-weight: 400 !important;
    letter-spacing: 0.005em !important;
}
.dw-resort-card .dw-meta-icon {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 26px !important;
    height: 26px !important;
    flex-shrink: 0 !important;
    border-radius: 50% !important;
    background-color: rgba(126, 132, 96, 0.10) !important;
    color: #7E8460 !important;
    margin: 0 !important;
    padding: 0 !important;
    font-size: 0 !important;
}
.dw-resort-card .dw-meta-icon svg {
    width: 13px !important;
    height: 13px !important;
    color: currentColor !important;
}

/* ============== ACTIONS / CTA BUTTON ============== */
.dw-resort-card .dw-resort-actions {
    margin: auto 0 0 !important;
    padding: 4px 0 0 !important;
}

/* Brand slide-fill CTA — defeats Elementor */
.dw-resort-card a.dw-card-cta,
.dw-resort-card .dw-card-cta,
a.dw-card-cta {
    position: relative !important;
    overflow: hidden !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 10px !important;
    width: 100% !important;
    padding: 14px 22px !important;
    margin: 0 !important;
    background-color: transparent !important;
    background-image: none !important;
    color: #1a1a1a !important;
    border: 1px solid #1a1a1a !important;
    border-radius: 0 !important;
    font-family: 'Poppins', system-ui, -apple-system, sans-serif !important;
    font-size: 11px !important;
    font-weight: 500 !important;
    letter-spacing: 0.28em !important;
    text-transform: uppercase !important;
    line-height: 1 !important;
    text-decoration: none !important;
    box-shadow: none !important;
    text-shadow: none !important;
    cursor: pointer !important;
    transition: color 0.5s ease !important;
    -webkit-appearance: none !important;
    appearance: none !important;
}
.dw-card-cta-fill {
    position: absolute !important;
    inset: 0 !important;
    background-color: #1a1a1a !important;
    transform: translateX(-101%) !important;
    transition: transform 0.6s cubic-bezier(0.77, 0, 0.175, 1) !important;
    z-index: 0 !important;
    pointer-events: none !important;
}
.dw-card-cta-text {
    position: relative !important;
    z-index: 1 !important;
    color: inherit !important;
}
.dw-card-cta-icon {
    width: 14px !important;
    height: 14px !important;
    position: relative !important;
    z-index: 1 !important;
    color: currentColor !important;
    transition: transform 0.45s cubic-bezier(0.22, 1, 0.36, 1) !important;
}
.dw-resort-card a.dw-card-cta:hover,
.dw-resort-card a.dw-card-cta:focus,
.dw-resort-card .dw-card-cta:hover,
.dw-resort-card .dw-card-cta:focus,
a.dw-card-cta:hover,
a.dw-card-cta:focus {
    color: #ffffff !important;
    background-color: transparent !important;
    background-image: none !important;
    border-color: #1a1a1a !important;
    text-decoration: none !important;
    outline: 0 !important;
    box-shadow: none !important;
}
.dw-resort-card a.dw-card-cta:hover .dw-card-cta-fill,
.dw-resort-card .dw-card-cta:hover .dw-card-cta-fill,
a.dw-card-cta:hover .dw-card-cta-fill {
    transform: translateX(0) !important;
}
.dw-resort-card a.dw-card-cta:hover .dw-card-cta-icon,
.dw-resort-card .dw-card-cta:hover .dw-card-cta-icon,
a.dw-card-cta:hover .dw-card-cta-icon {
    transform: translateX(4px) !important;
}

/* ============== LOAD MORE BUTTON ============== */
.dw-pagination-wrap {
    display: flex !important;
    justify-content: center !important;
    margin: 50px 0 0 !important;
    padding: 0 !important;
}
button.dw-load-more-btn,
.dw-pagination-wrap .dw-load-more-btn,
#dw-load-more {
    position: relative !important;
    overflow: hidden !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 12px !important;
    padding: 16px 38px !important;
    margin: 0 !important;
    background-color: transparent !important;
    background-image: none !important;
    color: #1a1a1a !important;
    border: 1px solid #1a1a1a !important;
    border-radius: 0 !important;
    cursor: pointer !important;
    font-family: 'Poppins', system-ui, -apple-system, sans-serif !important;
    font-size: 11px !important;
    font-weight: 500 !important;
    letter-spacing: 0.28em !important;
    text-transform: uppercase !important;
    line-height: 1 !important;
    box-shadow: none !important;
    text-shadow: none !important;
    text-decoration: none !important;
    transition: color 0.5s ease !important;
    -webkit-appearance: none !important;
    appearance: none !important;
}
.dw-load-more-fill {
    position: absolute !important;
    inset: 0 !important;
    background-color: #1a1a1a !important;
    transform: translateX(-101%) !important;
    transition: transform 0.6s cubic-bezier(0.77, 0, 0.175, 1) !important;
    z-index: 0 !important;
    pointer-events: none !important;
}
.dw-load-more-text {
    position: relative !important;
    z-index: 1 !important;
    color: inherit !important;
}
.dw-load-more-icon {
    width: 14px !important;
    height: 14px !important;
    position: relative !important;
    z-index: 1 !important;
    color: currentColor !important;
    transition: transform 0.45s cubic-bezier(0.22, 1, 0.36, 1) !important;
}
button.dw-load-more-btn:hover,
button.dw-load-more-btn:focus,
#dw-load-more:hover,
#dw-load-more:focus {
    color: #ffffff !important;
    background-color: transparent !important;
    background-image: none !important;
    border-color: #1a1a1a !important;
    outline: 0 !important;
    box-shadow: none !important;
}
button.dw-load-more-btn:hover .dw-load-more-fill,
#dw-load-more:hover .dw-load-more-fill {
    transform: translateX(0) !important;
}
button.dw-load-more-btn:hover .dw-load-more-icon,
#dw-load-more:hover .dw-load-more-icon {
    transform: translateY(3px) !important;
}

/* Responsive */
@media (max-width: 640px) {
    .dw-resort-card .dw-card-content { padding: 18px 20px 22px !important; }
    .dw-resort-card .dw-card-title { font-size: 17px !important; }
    .dw-resort-card .dw-resort-meta-grid { grid-template-columns: 1fr 1fr !important; gap: 0 !important; }
    .dw-resort-card .dw-meta-item { font-size: 11.5px !important; gap: 8px !important; padding: 12px 14px 12px 0 !important; }
    .dw-resort-card .dw-meta-item:nth-child(odd) { padding-right: 14px !important; }
    .dw-resort-card .dw-meta-item:nth-child(even) { padding-left: 14px !important; }
    .dw-resort-card .dw-meta-item:nth-child(3),
    .dw-resort-card .dw-meta-item:nth-child(4) { padding-top: 12px !important; }
    .dw-resort-card .dw-meta-item > span:last-child { font-size: 11.5px !important; }
    .dw-resort-card .dw-meta-icon { width: 24px !important; height: 24px !important; }
    .dw-resort-card .dw-meta-icon svg { width: 12px !important; height: 12px !important; }
    .dw-resort-card .dw-resort-badge,
    .dw-resort-card .dw-capacity-badge { font-size: 9px !important; padding: 5px 10px !important; letter-spacing: 0.18em !important; }
    button.dw-load-more-btn,
    #dw-load-more { padding: 14px 28px !important; }
}

/* ==========================================================================
   FILTER SIDEBAR + TOPBAR — brand patch
   Defeats Elementor button colours, brand typography, mobile drawer with
   safe-area-inset for browser bottom nav (Chrome/Safari/Edge mobile).
   ========================================================================== */

/* ============== WRAPPER ============== */
.dw-resorts-wrapper {
    font-family: 'Poppins', system-ui, -apple-system, sans-serif !important;
}

/* ============== SIDEBAR PANEL (desktop) ============== */
.dw-resorts-sidebar {
    background: transparent !important;
    padding: 0 !important;
    border-radius: 0 !important;
    box-shadow: none !important;
}

/* "Filter by" header — eyebrow style */
.dw-resorts-sidebar .dw-filter-header {
    font-family: 'Libre Baskerville', Georgia, serif !important;
    font-size: 20px !important;
    font-weight: 400 !important;
    color: #1a1a1a !important;
    letter-spacing: 0.005em !important;
    text-transform: none !important;
    margin: 0 0 22px !important;
    padding: 0 0 18px !important;
    border-bottom: 1px solid rgba(186, 170, 140, 0.32) !important;
    background: transparent !important;
    text-shadow: none !important;
}

/* Filter group */
.dw-resorts-sidebar .dw-filter-group {
    margin: 0 !important;
    padding: 0 !important;
    border: 0 !important;
    border-bottom: 1px solid rgba(186, 170, 140, 0.22) !important;
    background: transparent !important;
}
.dw-resorts-sidebar .dw-filter-group:last-of-type {
    border-bottom: 0 !important;
}

/* Section header (DESTINATION, RESORT CATEGORIES, etc) */
.dw-resorts-sidebar .dw-accordion-head {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    gap: 12px !important;
    padding: 16px 0 !important;
    margin: 0 !important;
    font-family: 'Poppins', system-ui, -apple-system, sans-serif !important;
    font-size: 11px !important;
    font-weight: 500 !important;
    letter-spacing: 0.26em !important;
    text-transform: uppercase !important;
    color: #1a1a1a !important;
    cursor: pointer !important;
    background: transparent !important;
    border: 0 !important;
    text-shadow: none !important;
    line-height: 1.4 !important;
}

/* Replace +/- with clean plus/minus icon via span */
.dw-resorts-sidebar .dw-accordion-head > span {
    position: relative !important;
    display: inline-block !important;
    width: 12px !important;
    height: 12px !important;
    flex-shrink: 0 !important;
    color: #1a1a1a !important;
}
.dw-resorts-sidebar .dw-accordion-head > span::before {
    content: '' !important;
    position: absolute !important;
    top: 5.5px !important;
    left: 0 !important;
    width: 12px !important;
    height: 1px !important;
    background-color: #1a1a1a !important;
    font-size: 0 !important;
}
.dw-resorts-sidebar .dw-accordion-head > span::after {
    content: '' !important;
    position: absolute !important;
    top: 0 !important;
    left: 5.5px !important;
    width: 1px !important;
    height: 12px !important;
    background-color: #1a1a1a !important;
    transition: transform 0.35s ease !important;
}
.dw-resorts-sidebar .dw-accordion.active .dw-accordion-head > span::after {
    transform: scaleY(0) !important;
}

/* Accordion body */
.dw-resorts-sidebar .dw-accordion-body {
    display: none !important;
    padding: 4px 0 18px !important;
}
.dw-resorts-sidebar .dw-accordion.active .dw-accordion-body {
    display: block !important;
}

/* Checkbox row */
.dw-resorts-sidebar .dw-checkbox {
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
    margin: 0 !important;
    padding: 7px 0 !important;
    cursor: pointer !important;
    font-family: 'Poppins', system-ui, -apple-system, sans-serif !important;
    font-size: 13px !important;
    font-weight: 400 !important;
    color: #1a1a1a !important;
    line-height: 1.4 !important;
    background: transparent !important;
    border: 0 !important;
    text-shadow: none !important;
    transition: color 0.3s ease !important;
}
.dw-resorts-sidebar .dw-checkbox:hover {
    color: #7E8460 !important;
}
.dw-resorts-sidebar .dw-checkbox input {
    display: none !important;
}

/* Custom checkbox box */
.dw-resorts-sidebar .dw-check-custom {
    position: relative !important;
    display: inline-block !important;
    width: 16px !important;
    height: 16px !important;
    border: 1px solid rgba(126, 132, 96, 0.45) !important;
    background: #ffffff !important;
    border-radius: 0 !important;
    flex-shrink: 0 !important;
    transition: background-color 0.3s ease, border-color 0.3s ease !important;
}
.dw-resorts-sidebar .dw-check-custom::after {
    content: '' !important;
    position: absolute !important;
    left: 4px !important;
    top: 1px !important;
    width: 5px !important;
    height: 9px !important;
    border: solid #ffffff !important;
    border-width: 0 1.5px 1.5px 0 !important;
    transform: rotate(45deg) scale(0) !important;
    transition: transform 0.25s ease !important;
}
.dw-resorts-sidebar .dw-checkbox input:checked + .dw-check-custom {
    background-color: #7E8460 !important;
    border-color: #7E8460 !important;
}
.dw-resorts-sidebar .dw-checkbox input:checked + .dw-check-custom::after {
    transform: rotate(45deg) scale(1) !important;
}

/* ============== DESKTOP TOPBAR (count + filters) ============== */
.dw-resorts-main .dw-resorts-topbar {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 16px !important;
    margin: 0 0 28px !important;
    padding: 0 0 20px !important;
    border-bottom: 1px solid rgba(186, 170, 140, 0.32) !important;
    background: transparent !important;
    box-shadow: none !important;
    border-radius: 0 !important;
    position: static !important;
    width: auto !important;
    z-index: auto !important;
}
.dw-resorts-main #dw-results-count {
    margin: 0 !important;
    padding: 0 !important;
    font-family: 'Libre Baskerville', Georgia, serif !important;
    font-size: 16px !important;
    font-weight: 400 !important;
    color: #1a1a1a !important;
    letter-spacing: 0.005em !important;
    line-height: 1.4 !important;
    background: transparent !important;
    text-shadow: none !important;
}

/* ============== MOBILE FILTER BUTTON ============== */
button.dw-mobile-filter-trigger,
.dw-mobile-filter-trigger {
    display: none;
    align-items: center !important;
    justify-content: center !important;
    gap: 10px !important;
    padding: 12px 22px !important;
    margin: 0 !important;
    background-color: #1a1a1a !important;
    background-image: none !important;
    color: #ffffff !important;
    border: 1px solid #1a1a1a !important;
    border-radius: 0 !important;
    cursor: pointer !important;
    font-family: 'Poppins', system-ui, -apple-system, sans-serif !important;
    font-size: 11px !important;
    font-weight: 500 !important;
    letter-spacing: 0.28em !important;
    text-transform: uppercase !important;
    line-height: 1 !important;
    box-shadow: none !important;
    text-shadow: none !important;
    text-decoration: none !important;
    transition: background-color 0.45s ease, color 0.45s ease, border-color 0.45s ease !important;
    -webkit-appearance: none !important;
    appearance: none !important;
}
button.dw-mobile-filter-trigger:hover,
button.dw-mobile-filter-trigger:focus,
.dw-mobile-filter-trigger:hover,
.dw-mobile-filter-trigger:focus {
    background-color: #7E8460 !important;
    background-image: none !important;
    color: #ffffff !important;
    border-color: #7E8460 !important;
    outline: 0 !important;
    box-shadow: none !important;
}
.dw-mobile-filter-trigger svg {
    width: 14px !important;
    height: 14px !important;
    color: currentColor !important;
}

/* ============== MOBILE DRAWER ============== */
.dw-filter-overlay {
    display: none;
    position: fixed !important;
    inset: 0 !important;
    background-color: rgba(26, 26, 26, 0.55) !important;
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
    z-index: 10000 !important;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.35s ease !important;
}
.dw-filter-overlay.active {
    opacity: 1 !important;
    pointer-events: auto !important;
}

.dw-mobile-filter-header { display: none; }
.dw-mobile-filter-header .dw-close-filters {
    background: transparent !important;
    border: 1px solid rgba(186, 170, 140, 0.45) !important;
    width: 36px !important;
    height: 36px !important;
    border-radius: 0 !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    cursor: pointer !important;
    color: #1a1a1a !important;
    font-family: 'Poppins', system-ui, -apple-system, sans-serif !important;
    font-size: 22px !important;
    line-height: 1 !important;
    padding: 0 !important;
    transition: background-color 0.35s ease, color 0.35s ease !important;
}
.dw-mobile-filter-header .dw-close-filters:hover {
    background-color: #1a1a1a !important;
    color: #ffffff !important;
}

/* Apply button (mobile drawer only) */
button.dw-apply-filters-btn,
.dw-apply-filters-btn {
    display: none;
    align-items: center !important;
    justify-content: center !important;
    gap: 10px !important;
    width: 100% !important;
    padding: 16px 22px !important;
    margin: 24px 0 0 !important;
    background-color: #7E8460 !important;
    background-image: none !important;
    color: #ffffff !important;
    border: 1px solid #7E8460 !important;
    border-radius: 0 !important;
    cursor: pointer !important;
    font-family: 'Poppins', system-ui, -apple-system, sans-serif !important;
    font-size: 11px !important;
    font-weight: 500 !important;
    letter-spacing: 0.28em !important;
    text-transform: uppercase !important;
    line-height: 1 !important;
    box-shadow: none !important;
    text-shadow: none !important;
    transition: background-color 0.45s ease, border-color 0.45s ease !important;
    -webkit-appearance: none !important;
    appearance: none !important;
}
button.dw-apply-filters-btn:hover,
button.dw-apply-filters-btn:focus {
    background-color: #1a1a1a !important;
    background-image: none !important;
    color: #ffffff !important;
    border-color: #1a1a1a !important;
    outline: 0 !important;
}

/* ============== MOBILE BREAKPOINT ============== */
@media (max-width: 1024px) {
    .dw-resorts-wrapper {
        grid-template-columns: 1fr !important;
        padding: 0 5% !important;
    }
    .dw-resorts-main {
        padding-bottom: calc(90px + env(safe-area-inset-bottom, 0px)) !important;
    }

    /* Topbar pinned to bottom — properly centered */
    .dw-resorts-main .dw-resorts-topbar {
        position: fixed !important;
        bottom: 0 !important;
        left: 0 !important;
        right: 0 !important;
        width: 100% !important;
        display: flex !important;
        align-items: center !important;
        justify-content: space-between !important;
        gap: 16px !important;
        padding: 14px 20px calc(14px + env(safe-area-inset-bottom, 0px)) !important;
        margin: 0 !important;
        background: rgba(255, 255, 255, 0.97) !important;
        backdrop-filter: blur(12px) !important;
        -webkit-backdrop-filter: blur(12px) !important;
        border: 0 !important;
        border-top: 1px solid rgba(186, 170, 140, 0.32) !important;
        border-radius: 0 !important;
        box-shadow: 0 -8px 28px rgba(26, 26, 26, 0.06) !important;
        z-index: 9998 !important;
    }
    .dw-resorts-main #dw-results-count {
        font-size: 13px !important;
    }
    .dw-mobile-filter-trigger {
        display: inline-flex !important;
    }

    /* Drawer overlay */
    .dw-filter-overlay {
        display: block;
    }

    /* Sidebar becomes bottom drawer with safe-area aware height */
    .dw-resorts-sidebar {
        position: fixed !important;
        bottom: 0 !important;
        left: 0 !important;
        right: 0 !important;
        width: 100% !important;
        height: auto !important;
        max-height: 88vh !important;
        max-height: 88svh !important;
        max-height: 88dvh !important;
        z-index: 10001 !important;
        background-color: #ffffff !important;
        border-radius: 0 !important;
        padding: 22px 22px calc(22px + env(safe-area-inset-bottom, 0px)) !important;
        transform: translateY(100%) !important;
        transition: transform 0.4s cubic-bezier(0.7, 0, 0.2, 1) !important;
        overflow-y: auto !important;
        -webkit-overflow-scrolling: touch !important;
        box-shadow: 0 -20px 50px rgba(26, 26, 26, 0.18) !important;
    }
    .dw-resorts-sidebar.active {
        transform: translateY(0) !important;
    }

    /* Drawer header */
    .dw-mobile-filter-header {
        display: flex !important;
        justify-content: space-between !important;
        align-items: center !important;
        gap: 16px !important;
        margin: 0 0 22px !important;
        padding: 0 0 16px !important;
        border-bottom: 1px solid rgba(186, 170, 140, 0.32) !important;
    }
    .dw-mobile-filter-header h3 {
        margin: 0 !important;
        padding: 0 !important;
        font-family: 'Libre Baskerville', Georgia, serif !important;
        font-size: 18px !important;
        font-weight: 400 !important;
        color: #1a1a1a !important;
        letter-spacing: 0.005em !important;
        line-height: 1.3 !important;
        text-transform: none !important;
        text-shadow: none !important;
        background: transparent !important;
    }
    .dw-resorts-sidebar > .dw-filter-header { display: none !important; }

    /* Apply button shows on mobile */
    .dw-apply-filters-btn {
        display: inline-flex !important;
    }
}

@media (max-width: 768px) {
    .dw-resorts-grid { grid-template-columns: 1fr !important; }
}

/* ==========================================================================
   EMPTY STATE — no resorts found (Lottie + heading + clear button)
   ========================================================================== */
.dw-no-results {
    grid-column: 1 / -1 !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    text-align: center !important;
    padding: 60px 24px 80px !important;
    margin: 0 !important;
    background: transparent !important;
    border: 0 !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    font-family: 'Poppins', system-ui, -apple-system, sans-serif !important;
}
.dw-no-results-anim {
    width: 260px !important;
    max-width: 70% !important;
    margin: 0 0 18px !important;
    line-height: 0 !important;
}
.dw-no-results-anim lottie-player {
    width: 100% !important;
    height: auto !important;
    display: block !important;
}
.dw-no-results h3.dw-no-results-title,
.dw-no-results .dw-no-results-title {
    margin: 0 0 12px !important;
    padding: 0 !important;
    font-family: 'Libre Baskerville', Georgia, serif !important;
    font-size: 22px !important;
    font-weight: 400 !important;
    color: #1a1a1a !important;
    letter-spacing: 0.005em !important;
    line-height: 1.25 !important;
    text-transform: none !important;
    text-shadow: none !important;
    background: transparent !important;
}
.dw-no-results p.dw-no-results-text,
.dw-no-results .dw-no-results-text {
    max-width: 420px !important;
    margin: 0 auto 28px !important;
    padding: 0 !important;
    font-family: 'Poppins', system-ui, -apple-system, sans-serif !important;
    font-size: 13px !important;
    font-weight: 300 !important;
    line-height: 1.75 !important;
    color: #756050 !important;
    background: transparent !important;
    text-shadow: none !important;
}

/* Small clear button — no arrow, minimal */
button.dw-clear-filters-btn,
.dw-clear-filters-btn,
.dw-no-results .dw-clear-filters-btn {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 10px 22px !important;
    margin: 0 !important;
    background-color: transparent !important;
    background-image: none !important;
    color: #1a1a1a !important;
    border: 1px solid #1a1a1a !important;
    border-radius: 0 !important;
    cursor: pointer !important;
    font-family: 'Poppins', system-ui, -apple-system, sans-serif !important;
    font-size: 10.5px !important;
    font-weight: 500 !important;
    letter-spacing: 0.28em !important;
    text-transform: uppercase !important;
    line-height: 1 !important;
    box-shadow: none !important;
    text-shadow: none !important;
    text-decoration: none !important;
    transition: background-color 0.45s ease, color 0.45s ease, border-color 0.45s ease !important;
    -webkit-appearance: none !important;
    appearance: none !important;
}
button.dw-clear-filters-btn:hover,
button.dw-clear-filters-btn:focus,
.dw-clear-filters-btn:hover,
.dw-clear-filters-btn:focus {
    background-color: #1a1a1a !important;
    background-image: none !important;
    color: #ffffff !important;
    border-color: #1a1a1a !important;
    outline: 0 !important;
}

@media (max-width: 640px) {
    .dw-no-results { padding: 40px 18px 60px !important; }
    .dw-no-results-anim { width: 200px !important; }
    .dw-no-results h3.dw-no-results-title { font-size: 20px !important; }
    .dw-no-results p.dw-no-results-text { font-size: 12.5px !important; }
}

/* ==========================================================================
   SINGLE RESORT — hero, planner bar, quote form, overview, highlights card
   ========================================================================== */

/* ============== HERO ============== */
.dw-hero-section {
    position: relative !important;
    min-height: 100vh !important;
    min-height: 100svh !important;
    background-size: cover !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 120px 24px 110px !important;
    color: #ffffff !important;
}
.dw-hero-section .dw-hero-overlay {
    position: absolute !important;
    inset: 0 !important;
    background: linear-gradient(to top, rgba(0,0,0,0.96) 0%, rgba(0,0,0,0.78) 34%, rgba(0,0,0,0.46) 68%, rgba(0,0,0,0.26) 100%) !important;
    z-index: 1 !important;
}
.dw-hero-section .dw-hero-content {
    position: relative !important;
    z-index: 2 !important;
    width: 100% !important;
    max-width: 1240px !important;
    text-align: center !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
}
.dw-hero-section .dw-hero-meta-wrapper {
    margin-bottom: 22px !important;
}
.dw-hero-section .dw-hero-meta-line {
    display: inline-flex !important;
    align-items: center !important;
    gap: 14px !important;
    padding: 9px 22px !important;
    background-color: rgba(255, 255, 255, 0.08) !important;
    border: 1px solid rgba(255, 255, 255, 0.24) !important;
    backdrop-filter: blur(8px) !important;
    -webkit-backdrop-filter: blur(8px) !important;
    border-radius: 0 !important;
}
.dw-hero-section .dw-hero-location,
.dw-hero-section .dw-hero-stat {
    font-family: 'Poppins', system-ui, -apple-system, sans-serif !important;
    font-size: 10px !important;
    font-weight: 500 !important;
    letter-spacing: 0.34em !important;
    text-transform: uppercase !important;
    color: #E9E0CF !important;
    line-height: 1.4 !important;
    background: transparent !important;
}
.dw-hero-section .dw-meta-divider {
    display: inline-block !important;
    width: 3px !important;
    height: 3px !important;
    background-color: rgba(233, 224, 207, 0.7) !important;
    border-radius: 50% !important;
}

/* Title — final two-line style */
.dw-hero-section h1.dw-hero-title,
.dw-hero-section .dw-hero-title {
    max-width: 620px !important;
    margin: 0 auto 34px !important;
    font-family: 'Libre Baskerville', Georgia, serif !important;
    font-size: clamp(24px, 2.3vw, 30px) !important;
    font-weight: 400 !important;
    line-height: 1.14 !important;
    letter-spacing: 0.005em !important;
    color: #ffffff !important;
    text-align: center !important;
    padding: 0 !important;
    text-transform: none !important;
    text-shadow: 0 4px 28px rgba(0, 0, 0, 0.45) !important;
    background: transparent !important;
}

/* ============== PLANNER BAR ============== */
.dw-hero-section .dw-hero-planner-bar {
    display: grid !important;
    grid-template-columns: 1fr 1fr auto !important;
    gap: 0 !important;
    width: 100% !important;
    max-width: 880px !important;
    margin: 0 auto !important;
    background: rgba(255, 255, 255, 0.97) !important;
    backdrop-filter: blur(12px) !important;
    -webkit-backdrop-filter: blur(12px) !important;
    color: #1a1a1a !important;
    border: 0 !important;
    outline: 0 !important;
    border-radius: 0 !important;
    box-shadow: 0 24px 60px rgba(0, 0, 0, 0.22) !important;
}
.dw-hero-section .dw-hero-planner-col {
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
    padding: 14px 20px !important;
    margin: 0 !important;
    border-right: 1px solid rgba(126, 132, 96, 0.18) !important;
    background: transparent !important;
    text-align: left !important;
    position: relative !important;
}
.dw-hero-section .dw-planner-icon {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 38px !important;
    height: 38px !important;
    border-radius: 50% !important;
    background-color: rgba(126, 132, 96, 0.10) !important;
    color: #7E8460 !important;
    flex-shrink: 0 !important;
}
.dw-hero-section .dw-planner-icon svg {
    width: 16px !important;
    height: 16px !important;
}
.dw-hero-section .dw-hero-planner-text {
    flex-grow: 1 !important;
    min-width: 0 !important;
}
.dw-hero-section .dw-hero-planner-text label {
    display: block !important;
    font-family: 'Poppins', system-ui, -apple-system, sans-serif !important;
    font-size: 9.5px !important;
    font-weight: 500 !important;
    letter-spacing: 0.28em !important;
    text-transform: uppercase !important;
    color: #7E8460 !important;
    margin: 0 0 3px !important;
    background: transparent !important;
    line-height: 1.4 !important;
}
.dw-hero-section .dw-custom-select {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    cursor: pointer !important;
    font-family: 'Libre Baskerville', Georgia, serif !important;
    font-size: 13px !important;
    color: #1a1a1a !important;
    letter-spacing: 0.005em !important;
    margin: 0 !important;
    padding: 0 !important;
}
.dw-hero-section .dw-custom-select svg {
    color: #aa9b86 !important;
    width: 13px !important;
    height: 13px !important;
    transition: transform 0.35s ease !important;
}
.dw-hero-section .dw-custom-select.active svg {
    transform: rotate(180deg) !important;
}

/* Dropdown z-index — higher than sticky nav */
.dw-hero-section .dw-custom-options {
    position: absolute !important;
    top: calc(100% + 8px) !important;
    left: 0 !important;
    right: 0 !important;
    background: #ffffff !important;
    border: 1px solid rgba(126, 132, 96, 0.22) !important;
    box-shadow: 0 20px 40px rgba(0, 0, 0, 0.18) !important;
    z-index: 9999 !important;
    max-height: 280px !important;
    overflow-y: auto !important;
    display: none !important;
    border-radius: 0 !important;
    padding: 0 !important;
    text-align: left !important;
}
.dw-hero-section .dw-custom-options.active {
    display: block !important;
}
.dw-hero-section .dw-option {
    padding: 10px 18px !important;
    margin: 0 !important;
    font-family: 'Poppins', system-ui, -apple-system, sans-serif !important;
    font-size: 12.5px !important;
    color: #1a1a1a !important;
    cursor: pointer !important;
    border-bottom: 1px solid rgba(126, 132, 96, 0.12) !important;
    transition: background-color 0.3s ease, color 0.3s ease !important;
    background: #ffffff !important;
    line-height: 1.4 !important;
}
.dw-hero-section .dw-option:last-child { border-bottom: 0 !important; }
.dw-hero-section .dw-option:hover {
    background-color: #F7F7F3 !important;
    color: #7E8460 !important;
}
.dw-hero-section .dw-hidden-select { display: none !important; }

/* Get a Quote button — hero */
.dw-hero-section button.dw-hero-quote-btn,
.dw-hero-section .dw-hero-quote-btn {
    position: relative !important;
    overflow: hidden !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    height: auto !important;
    padding: 20px 30px !important;
    margin: 0 !important;
    background-color: #7E8460 !important;
    background-image: none !important;
    color: #ffffff !important;
    border: 0 !important;
    border-radius: 0 !important;
    cursor: pointer !important;
    font-family: 'Poppins', system-ui, -apple-system, sans-serif !important;
    font-size: 11px !important;
    font-weight: 500 !important;
    letter-spacing: 0.28em !important;
    text-transform: uppercase !important;
    line-height: 1 !important;
    box-shadow: none !important;
    text-shadow: none !important;
    text-decoration: none !important;
    transition: background-color 0.5s ease !important;
    -webkit-appearance: none !important;
    appearance: none !important;
}
.dw-hero-section .dw-hero-quote-btn:hover,
.dw-hero-section .dw-hero-quote-btn:focus,
.dw-hero-section .dw-hero-quote-btn:active {
    background-color: #1a1a1a !important;
    background-image: none !important;
    color: #ffffff !important;
    outline: 0 !important;
    box-shadow: none !important;
}

/* Begin arrow at bottom, horizontally centered */
.dw-hero-section .dw-hero-discover,
.dw-hero-discover {
    position: absolute !important;
    bottom: 34px !important;
    left: 50% !important;
    transform: translateX(-50%) !important;
    z-index: 3 !important;
    display: inline-flex !important;
    flex-direction: column !important;
    align-items: center !important;
    gap: 8px !important;
    color: rgba(255, 255, 255, 0.82) !important;
    text-decoration: none !important;
    transition: color 0.3s ease !important;
}
.dw-hero-discover:hover { color: #ffffff !important; }
.dw-hero-discover-label {
    font-family: 'Poppins', system-ui, -apple-system, sans-serif !important;
    font-size: 10px !important;
    font-weight: 400 !important;
    letter-spacing: 0.34em !important;
    text-transform: uppercase !important;
    color: currentColor !important;
}
.dw-hero-discover-line { display: none !important; }
.dw-hero-discover-icon {
    width: 24px !important;
    height: 24px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    animation: dwHeroBeginBounce 2.4s ease-in-out infinite !important;
}
.dw-hero-discover-icon svg {
    width: 16px !important;
    height: 16px !important;
    display: block !important;
}
@keyframes dwHeroBeginBounce {
    0%, 100% { transform: translateY(0); opacity: 1; }
    50% { transform: translateY(6px); opacity: 0.5; }
}


.dw-sticky-nav-wrapper .dw-nav-links a {
    font-family: 'Poppins', system-ui, -apple-system, sans-serif !important;
    font-size: 12px !important;
    font-weight: 400 !important;
    letter-spacing: 0.22em !important;
    text-transform: uppercase !important;
}


/* ============== QUOTE FORM MODAL ============== */
.dw-quote-overlay {
    position: fixed !important;
    inset: 0 !important;
    background-color: rgba(26, 26, 26, 0.55) !important;
    backdrop-filter: blur(4px) !important;
    -webkit-backdrop-filter: blur(4px) !important;
    z-index: 10001 !important;
    opacity: 0 !important;
    visibility: hidden !important;
    transition: opacity 0.4s ease, visibility 0.4s ease !important;
}
.dw-quote-overlay.active {
    opacity: 1 !important;
    visibility: visible !important;
}
.dw-quote-sidebar {
    position: fixed !important;
    top: 0 !important;
    right: 0 !important;
    width: 480px !important;
    max-width: 100% !important;
    height: 100vh !important;
    height: 100svh !important;
    background: #ffffff !important;
    z-index: 10002 !important;
    transform: translateX(100%) !important;
    transition: transform 0.5s cubic-bezier(0.7, 0, 0.2, 1) !important;
    display: flex !important;
    flex-direction: column !important;
    border-radius: 0 !important;
    box-shadow: -30px 0 60px rgba(0, 0, 0, 0.18) !important;
}
.dw-quote-sidebar.active {
    transform: translateX(0) !important;
}

/* Header */
.dw-quote-sidebar .dw-quote-header {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    gap: 16px !important;
    padding: 26px 30px !important;
    border-bottom: 1px solid rgba(186, 170, 140, 0.32) !important;
    background: transparent !important;
}
.dw-quote-sidebar .dw-quote-header h3 {
    margin: 0 !important;
    padding: 0 !important;
    font-family: 'Libre Baskerville', Georgia, serif !important;
    font-size: 20px !important;
    font-weight: 400 !important;
    color: #1a1a1a !important;
    letter-spacing: 0.005em !important;
    line-height: 1.3 !important;
    text-transform: none !important;
    background: transparent !important;
    text-shadow: none !important;
}

/* Close button */
.dw-quote-sidebar .dw-close-quote {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 38px !important;
    height: 38px !important;
    padding: 0 !important;
    margin: 0 !important;
    background: transparent !important;
    border: 1px solid rgba(186, 170, 140, 0.45) !important;
    border-radius: 0 !important;
    color: #1a1a1a !important;
    font-family: 'Poppins', system-ui, -apple-system, sans-serif !important;
    font-size: 22px !important;
    line-height: 1 !important;
    cursor: pointer !important;
    transition: background-color 0.35s ease, color 0.35s ease !important;
}
.dw-quote-sidebar .dw-close-quote:hover {
    background-color: #1a1a1a !important;
    color: #ffffff !important;
}

/* Body */
.dw-quote-sidebar .dw-quote-body {
    flex: 1 !important;
    overflow-y: auto !important;
    padding: 26px 30px 32px !important;
    background: #ffffff !important;
}
.dw-quote-sidebar .dw-quote-body > p {
    margin: 0 0 24px !important;
    padding: 0 !important;
    font-family: 'Poppins', system-ui, -apple-system, sans-serif !important;
    font-size: 13px !important;
    line-height: 1.75 !important;
    color: #756050 !important;
    font-weight: 300 !important;
    background: transparent !important;
}

/* Form */
.dw-quote-sidebar .dw-quote-form {
    display: flex !important;
    flex-direction: column !important;
    gap: 18px !important;
}
.dw-quote-sidebar .dw-form-group {
    display: flex !important;
    flex-direction: column !important;
    gap: 8px !important;
}
.dw-quote-sidebar .dw-form-group label {
    font-family: 'Poppins', system-ui, -apple-system, sans-serif !important;
    font-size: 10.5px !important;
    font-weight: 500 !important;
    letter-spacing: 0.28em !important;
    text-transform: uppercase !important;
    color: #7E8460 !important;
    line-height: 1.4 !important;
    background: transparent !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* Form inputs — defeat Elementor pink focus */
.dw-quote-sidebar .dw-form-group input,
.dw-quote-sidebar .dw-form-group select,
.dw-quote-sidebar .dw-form-group textarea,
.dw-quote-sidebar input[type="text"],
.dw-quote-sidebar input[type="email"],
.dw-quote-sidebar input[type="tel"],
.dw-quote-sidebar select {
    width: 100% !important;
    padding: 13px 14px !important;
    margin: 0 !important;
    background: #ffffff !important;
    background-image: none !important;
    border: 1px solid rgba(126, 132, 96, 0.32) !important;
    border-radius: 0 !important;
    color: #1a1a1a !important;
    font-family: 'Poppins', system-ui, -apple-system, sans-serif !important;
    font-size: 13.5px !important;
    font-weight: 400 !important;
    line-height: 1.4 !important;
    outline: 0 !important;
    box-shadow: none !important;
    text-shadow: none !important;
    transition: border-color 0.3s ease !important;
    -webkit-appearance: none !important;
    appearance: none !important;
}
.dw-quote-sidebar .dw-form-group input:focus,
.dw-quote-sidebar .dw-form-group input:focus-visible,
.dw-quote-sidebar .dw-form-group select:focus,
.dw-quote-sidebar .dw-form-group select:focus-visible,
.dw-quote-sidebar .dw-form-group textarea:focus,
.dw-quote-sidebar input:focus,
.dw-quote-sidebar input:focus-visible,
.dw-quote-sidebar select:focus,
.dw-quote-sidebar select:focus-visible {
    border-color: #7E8460 !important;
    outline: 0 !important;
    box-shadow: none !important;
    background: #ffffff !important;
    background-image: none !important;
}
.dw-quote-sidebar input[readonly] {
    background-color: #F7F7F3 !important;
    color: #aa9b86 !important;
    cursor: not-allowed !important;
}
.dw-quote-sidebar select {
    background-image: url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23aa9b86' stroke-width='1.6'%3e%3cpath d='M6 9l6 6 6-6'/%3e%3c/svg%3e") !important;
    background-repeat: no-repeat !important;
    background-position: right 14px center !important;
    background-size: 14px !important;
    padding-right: 38px !important;
}

/* Submit button — brand slide-fill */
.dw-quote-sidebar button.dw-submit-btn,
.dw-quote-sidebar .dw-submit-btn {
    position: relative !important;
    overflow: hidden !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 10px !important;
    width: 100% !important;
    margin-top: 8px !important;
    padding: 16px 24px !important;
    background-color: #1a1a1a !important;
    background-image: none !important;
    color: #ffffff !important;
    border: 1px solid #1a1a1a !important;
    border-radius: 0 !important;
    cursor: pointer !important;
    font-family: 'Poppins', system-ui, -apple-system, sans-serif !important;
    font-size: 11px !important;
    font-weight: 500 !important;
    letter-spacing: 0.28em !important;
    text-transform: uppercase !important;
    line-height: 1 !important;
    box-shadow: none !important;
    text-shadow: none !important;
    transition: background-color 0.5s ease, border-color 0.5s ease !important;
    -webkit-appearance: none !important;
    appearance: none !important;
}
.dw-quote-sidebar .dw-submit-btn:hover,
.dw-quote-sidebar .dw-submit-btn:focus,
.dw-quote-sidebar .dw-submit-btn:active {
    background-color: #7E8460 !important;
    border-color: #7E8460 !important;
    color: #ffffff !important;
    outline: 0 !important;
    box-shadow: none !important;
}
.dw-quote-sidebar .dw-btn-text {
    position: relative !important;
    z-index: 1 !important;
    color: inherit !important;
}

/* Form response message */
.dw-quote-sidebar .dw-form-response {
    margin: 8px 0 0 !important;
    padding: 12px 16px !important;
    font-family: 'Poppins', system-ui, -apple-system, sans-serif !important;
    font-size: 12.5px !important;
    line-height: 1.55 !important;
    border-left: 2px solid transparent !important;
    background: transparent !important;
}
.dw-quote-sidebar .dw-form-response.success {
    background-color: rgba(126, 132, 96, 0.10) !important;
    color: #7E8460 !important;
    border-left-color: #7E8460 !important;
}
.dw-quote-sidebar .dw-form-response.error {
    background-color: rgba(176, 122, 72, 0.10) !important;
    color: #b07a48 !important;
    border-left-color: #b07a48 !important;
}

/* Mobile quote sidebar — full width */
@media (max-width: 600px) {
    .dw-quote-sidebar {
        width: 100% !important;
    }
    .dw-quote-sidebar .dw-quote-header { padding: 22px 20px !important; }
    .dw-quote-sidebar .dw-quote-body { padding: 22px 20px 28px !important; }
}

/* ============== OVERVIEW SECTION ============== */
.dw-main-content #overview .dw-overview-inner-box {
    background: transparent !important;
    padding: 0 !important;
    margin: 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    box-shadow: none !important;
}
.dw-main-content #overview .dw-overview-split-layout {
    display: grid !important;
    grid-template-columns: 1.4fr 1fr !important;
    gap: 70px !important;
    align-items: start !important;
}
.dw-main-content #overview .dw-ov-left {
    min-width: 0 !important;
}

/* Overview heading — smaller */
.dw-main-content #overview h2.dw-ov-heading,
.dw-main-content #overview .dw-ov-heading {
    font-family: 'Libre Baskerville', Georgia, serif !important;
    font-size: clamp(22px, 2.4vw, 32px) !important;
    font-weight: 400 !important;
    line-height: 1.2 !important;
    letter-spacing: 0.005em !important;
    color: #1a1a1a !important;
    margin: 0 0 26px !important;
    padding: 0 !important;
    text-transform: none !important;
    text-shadow: none !important;
    background: transparent !important;
    -webkit-background-clip: initial !important;
    background-clip: initial !important;
    -webkit-text-fill-color: #1a1a1a !important;
}

/* Keep “Experience + resort name” together when the template injects a span/br */
.dw-main-content #overview .dw-ov-heading br {
    display: none !important;
}
.dw-main-content #overview .dw-ov-heading br::after {
    content: ' ' !important;
    white-space: pre !important;
}
.dw-main-content #overview .dw-ov-heading span,
.dw-main-content #overview .dw-ov-heading strong {
    display: inline !important;
}


/* Overview paragraph */
.dw-main-content #overview .dw-ov-text {
    font-family: 'Poppins', system-ui, -apple-system, sans-serif !important;
    font-size: 14.5px !important;
    line-height: 1.85 !important;
    color: #756050 !important;
    font-weight: 300 !important;
}
.dw-main-content #overview .dw-ov-text p {
    margin: 0 0 18px !important;
    padding: 0 !important;
    color: inherit !important;
    font-family: inherit !important;
    font-size: inherit !important;
    line-height: inherit !important;
    font-weight: inherit !important;
    background: transparent !important;
    text-shadow: none !important;
}
.dw-main-content #overview .dw-ov-text p:last-child {
    margin-bottom: 0 !important;
}

/* ============== TOP HIGHLIGHTS CARD (right side) — 2x2 cross dividers ============== */
.dw-main-content #overview .dw-ov-right {
    position: sticky !important;
    top: 90px !important;
}
.dw-main-content #overview .dw-highlights-card-wrap {
    margin: 0 !important;
    padding: 0 !important;
    filter: none !important;
    background: transparent !important;
    box-shadow: none !important;
    border: 0 !important;
}
.dw-main-content #overview .dw-highlights-card {
    position: relative !important;
    background: #F7F7F3 !important;
    padding: 32px !important;
    border: 0 !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    outline: 0 !important;
}
.dw-main-content #overview .dw-hc-header {
    display: block !important;
    margin: 0 0 22px !important;
    padding: 0 0 18px !important;
    font-family: 'Poppins', system-ui, -apple-system, sans-serif !important;
    font-size: 10.5px !important;
    font-weight: 500 !important;
    letter-spacing: 0.34em !important;
    text-transform: uppercase !important;
    color: #7E8460 !important;
    text-align: center !important;
    border-bottom: 1px solid rgba(126, 132, 96, 0.22) !important;
    background: transparent !important;
    text-shadow: none !important;
    line-height: 1.4 !important;
}
/* 2x2 grid with cross dividers — same pattern as resort cards */
.dw-main-content #overview .dw-hc-grid {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
}
.dw-main-content #overview .dw-hc-item {
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
    padding: 16px 14px 16px 0 !important;
    margin: 0 !important;
    background: transparent !important;
    font-family: 'Libre Baskerville', Georgia, serif !important;
    font-size: 13.5px !important;
    font-weight: 400 !important;
    color: #1a1a1a !important;
    letter-spacing: 0.005em !important;
    line-height: 1.3 !important;
    border: 0 !important;
    box-shadow: none !important;
}
/* Vertical hairline between cols */
.dw-main-content #overview .dw-hc-item:nth-child(odd) {
    padding-right: 14px !important;
    border-right: 1px solid #E9E0CF !important;
}
.dw-main-content #overview .dw-hc-item:nth-child(even) {
    padding-left: 14px !important;
}
/* Horizontal hairline between rows */
.dw-main-content #overview .dw-hc-item:nth-child(1),
.dw-main-content #overview .dw-hc-item:nth-child(2) {
    border-bottom: 1px solid #E9E0CF !important;
}
.dw-main-content #overview .dw-hc-item:nth-child(3),
.dw-main-content #overview .dw-hc-item:nth-child(4) {
    padding-top: 16px !important;
}
.dw-main-content #overview .dw-hc-item svg {
    display: inline-flex !important;
    width: 14px !important;
    height: 14px !important;
    color: #7E8460 !important;
    flex-shrink: 0 !important;
    padding: 0 !important;
    background: transparent !important;
    border-radius: 0 !important;
    box-shadow: none !important;
}
.dw-main-content #overview .dw-hc-item span {
    color: #1a1a1a !important;
    font-family: 'Libre Baskerville', Georgia, serif !important;
    font-size: 13.5px !important;
    background: transparent !important;
    line-height: 1.3 !important;
}

/* Featured Offer block (inside highlights card) */
.dw-main-content #overview .dw-hc-divider { display: none !important; }
.dw-main-content #overview .dw-hc-offer {
    text-align: center !important;
    margin: 24px 0 0 !important;
    padding: 28px 22px !important;
    background: #806052 !important;
    box-shadow: none !important;
    border: 0 !important;
    border-top: 0 !important;
    border-radius: 0 !important;
}
.dw-main-content #overview .dw-hc-offer-eyebrow {
    display: inline-block !important;
    font-family: 'Poppins', system-ui, -apple-system, sans-serif !important;
    font-size: 10px !important;
    font-weight: 400 !important;
    letter-spacing: 0.34em !important;
    text-transform: uppercase !important;
    color: rgba(255, 255, 255, 0.72) !important;
    margin: 0 0 10px !important;
    background: transparent !important;
}
.dw-main-content #overview .dw-hc-offer h4 {
    font-family: 'Libre Baskerville', Georgia, serif !important;
    font-size: 24px !important;
    font-weight: 400 !important;
    color: #ffffff !important;
    margin: 0 0 14px !important;
    padding: 0 !important;
    letter-spacing: 0.005em !important;
    line-height: 1.2 !important;
    text-transform: none !important;
    background: transparent !important;
    text-shadow: none !important;
}


.dw-main-content #overview .dw-hc-offer button.dw-link-arrow,
.dw-main-content #overview .dw-hc-offer .dw-link-arrow {
    color: rgba(255, 255, 255, 0.78) !important;
    border-bottom-color: rgba(255, 255, 255, 0.35) !important;
}
.dw-main-content #overview .dw-hc-offer button.dw-link-arrow:hover,
.dw-main-content #overview .dw-hc-offer .dw-link-arrow:hover {
    color: #ffffff !important;
    border-bottom-color: #ffffff !important;
}

/* LEARN MORE / dw-link-arrow / Speak with an Expert — defeat Elementor pink */
.dw-main-content #overview button.dw-link-arrow,
.dw-main-content #overview .dw-link-arrow,
.dw-main-content #overview .dw-hc-footer-text a {
    display: inline-flex !important;
    align-items: center !important;
    gap: 8px !important;
    padding: 0 0 3px !important;
    margin: 0 !important;
    background: transparent !important;
    background-image: none !important;
    border: 0 !important;
    border-bottom: 1px solid #7E8460 !important;
    border-radius: 0 !important;
    color: #7E8460 !important;
    font-family: 'Poppins', system-ui, -apple-system, sans-serif !important;
    font-size: 10.5px !important;
    font-weight: 500 !important;
    letter-spacing: 0.3em !important;
    text-transform: uppercase !important;
    line-height: 1 !important;
    text-decoration: none !important;
    cursor: pointer !important;
    box-shadow: none !important;
    text-shadow: none !important;
    transition: color 0.35s ease, border-color 0.35s ease !important;
    -webkit-appearance: none !important;
    appearance: none !important;
}
.dw-main-content #overview .dw-link-arrow:hover,
.dw-main-content #overview .dw-link-arrow:focus,
.dw-main-content #overview .dw-hc-footer-text a:hover,
.dw-main-content #overview .dw-hc-footer-text a:focus {
    color: #413225 !important;
    border-bottom-color: #413225 !important;
    background: transparent !important;
    background-image: none !important;
    outline: 0 !important;
    box-shadow: none !important;
}

.dw-main-content #overview .dw-hc-footer-text {
    margin: 18px 0 0 !important;
    padding: 0 !important;
    text-align: center !important;
    font-family: 'Poppins', system-ui, -apple-system, sans-serif !important;
    font-size: 12px !important;
    line-height: 1.7 !important;
    color: #756050 !important;
    font-weight: 300 !important;
    background: transparent !important;
}

/* ============== OVERVIEW READ MORE — clamp + bottom-sheet modal ============== */
.dw-ov-text.dw-ov-clamped {
    position: relative !important;
    display: -webkit-box !important;
    -webkit-line-clamp: 8 !important;
    line-clamp: 8 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
}
.dw-ov-text.dw-ov-clamped::after {
    content: '' !important;
    position: absolute !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    height: 80px !important;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0) 0%, #ffffff 90%) !important;
    pointer-events: none !important;
}
button.dw-ov-readmore,
.dw-ov-readmore {
    display: inline-flex !important;
    align-items: center !important;
    gap: 10px !important;
    margin: 22px 0 0 !important;
    padding: 0 0 4px !important;
    background: transparent !important;
    background-image: none !important;
    border: 0 !important;
    border-bottom: 1px solid #7E8460 !important;
    border-radius: 0 !important;
    color: #7E8460 !important;
    cursor: pointer !important;
    font-family: 'Poppins', system-ui, -apple-system, sans-serif !important;
    font-size: 10.5px !important;
    font-weight: 500 !important;
    letter-spacing: 0.3em !important;
    text-transform: uppercase !important;
    line-height: 1 !important;
    text-decoration: none !important;
    box-shadow: none !important;
    text-shadow: none !important;
    transition: color 0.35s ease, border-color 0.35s ease !important;
    -webkit-appearance: none !important;
    appearance: none !important;
}
.dw-ov-readmore:hover,
.dw-ov-readmore:focus {
    color: #413225 !important;
    border-bottom-color: #413225 !important;
    outline: 0 !important;
    box-shadow: none !important;
}
.dw-ov-readmore svg {
    width: 13px !important;
    height: 13px !important;
    color: currentColor !important;
    transition: transform 0.35s ease !important;
}
.dw-ov-readmore:hover svg {
    transform: translateX(4px) !important;
}

/* Read more modal — bottom sheet */
.dw-ov-modal-overlay {
    position: fixed !important;
    inset: 0 !important;
    background-color: rgba(26, 26, 26, 0.55) !important;
    backdrop-filter: blur(4px) !important;
    -webkit-backdrop-filter: blur(4px) !important;
    z-index: 10005 !important;
    opacity: 0 !important;
    visibility: hidden !important;
    transition: opacity 0.45s ease, visibility 0.45s ease !important;
    display: flex !important;
    align-items: flex-end !important;
    justify-content: center !important;
}
.dw-ov-modal-overlay.active {
    opacity: 1 !important;
    visibility: visible !important;
}
.dw-ov-modal-sheet {
    width: 100% !important;
    max-width: 760px !important;
    max-height: 86vh !important;
    max-height: 86svh !important;
    background: #ffffff !important;
    transform: translateY(100%) !important;
    transition: transform 0.55s cubic-bezier(0.7, 0, 0.2, 1) !important;
    display: flex !important;
    flex-direction: column !important;
    box-shadow: 0 -30px 80px rgba(0, 0, 0, 0.18) !important;
    border-radius: 0 !important;
}
.dw-ov-modal-overlay.active .dw-ov-modal-sheet {
    transform: translateY(0) !important;
}
.dw-ov-modal-header {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    gap: 18px !important;
    padding: 24px 30px !important;
    border-bottom: 1px solid rgba(186, 170, 140, 0.32) !important;
    background: transparent !important;
}
.dw-ov-modal-eyebrow {
    display: block !important;
    font-family: 'Poppins', system-ui, -apple-system, sans-serif !important;
    font-size: 10px !important;
    font-weight: 500 !important;
    letter-spacing: 0.34em !important;
    text-transform: uppercase !important;
    color: #7E8460 !important;
    margin: 0 0 4px !important;
    background: transparent !important;
}
.dw-ov-modal-header h3 {
    margin: 0 !important;
    padding: 0 !important;
    font-family: 'Libre Baskerville', Georgia, serif !important;
    font-size: 20px !important;
    font-weight: 400 !important;
    color: #1a1a1a !important;
    letter-spacing: 0.005em !important;
    line-height: 1.25 !important;
    text-transform: none !important;
    background: transparent !important;
    text-shadow: none !important;
}
button.dw-ov-modal-close,
.dw-ov-modal-close {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 38px !important;
    height: 38px !important;
    padding: 0 !important;
    margin: 0 !important;
    background: transparent !important;
    background-image: none !important;
    border: 1px solid rgba(186, 170, 140, 0.45) !important;
    border-radius: 0 !important;
    color: #1a1a1a !important;
    cursor: pointer !important;
    flex-shrink: 0 !important;
    transition: background-color 0.35s ease, color 0.35s ease !important;
    -webkit-appearance: none !important;
    appearance: none !important;
}
.dw-ov-modal-close:hover {
    background-color: #1a1a1a !important;
    color: #ffffff !important;
}
.dw-ov-modal-close svg {
    width: 16px !important;
    height: 16px !important;
}
.dw-ov-modal-body {
    flex: 1 !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch !important;
    padding: 28px 30px 36px !important;
    font-family: 'Poppins', system-ui, -apple-system, sans-serif !important;
    font-size: 14.5px !important;
    line-height: 1.85 !important;
    color: #1a1a1a !important;
    font-weight: 300 !important;
    background: #ffffff !important;
}
.dw-ov-modal-body p {
    margin: 0 0 18px !important;
    color: inherit !important;
}
.dw-ov-modal-body,
.dw-ov-modal-body *,
.dw-ov-modal-body p,
.dw-ov-modal-body div,
.dw-ov-modal-body span,
.dw-ov-modal-body strong,
.dw-ov-modal-body em,
.dw-ov-modal-body li,
.dw-ov-modal-body .dw-text-fill {
    opacity: 1 !important;
    visibility: visible !important;
    color: #1a1a1a !important;
    background: transparent !important;
    background-image: none !important;
    -webkit-background-clip: border-box !important;
    background-clip: border-box !important;
    -webkit-text-fill-color: #1a1a1a !important;
    text-shadow: none !important;
    transform: none !important;
}
.dw-ov-modal-body p:last-child { margin-bottom: 0 !important; }

/* ============== QUOTE FORM — new editorial layout ============== */
/* Side-by-side rows for shorter fields */
.dw-quote-sidebar .dw-quote-form .dw-form-row {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 16px !important;
}
@media (max-width: 480px) {
    .dw-quote-sidebar .dw-quote-form .dw-form-row {
        grid-template-columns: 1fr !important;
    }
}
/* Underline-style inputs (more editorial / luxury feel) */
.dw-quote-sidebar .dw-form-group input,
.dw-quote-sidebar .dw-form-group select,
.dw-quote-sidebar .dw-form-group textarea,
.dw-quote-sidebar input[type="text"],
.dw-quote-sidebar input[type="email"],
.dw-quote-sidebar input[type="tel"],
.dw-quote-sidebar select {
    width: 100% !important;
    padding: 11px 0 11px 0 !important;
    margin: 0 !important;
    background: transparent !important;
    background-image: none !important;
    border: 0 !important;
    border-bottom: 1px solid rgba(126, 132, 96, 0.32) !important;
    border-radius: 0 !important;
    color: #1a1a1a !important;
    font-family: 'Libre Baskerville', Georgia, serif !important;
    font-size: 14.5px !important;
    font-weight: 400 !important;
    line-height: 1.4 !important;
    outline: 0 !important;
    box-shadow: none !important;
    text-shadow: none !important;
    transition: border-color 0.3s ease !important;
    -webkit-appearance: none !important;
    appearance: none !important;
}
.dw-quote-sidebar .dw-form-group input:focus,
.dw-quote-sidebar .dw-form-group input:focus-visible,
.dw-quote-sidebar .dw-form-group select:focus,
.dw-quote-sidebar .dw-form-group select:focus-visible,
.dw-quote-sidebar .dw-form-group textarea:focus,
.dw-quote-sidebar input:focus,
.dw-quote-sidebar input:focus-visible,
.dw-quote-sidebar select:focus,
.dw-quote-sidebar select:focus-visible {
    border-bottom-color: #7E8460 !important;
    border-color: transparent transparent #7E8460 transparent !important;
    outline: 0 !important;
    box-shadow: none !important;
    background: transparent !important;
    background-image: none !important;
}
.dw-quote-sidebar .dw-form-group input::placeholder {
    color: #aa9b86 !important;
    opacity: 1 !important;
    font-style: normal !important;
}
.dw-quote-sidebar input[readonly] {
    background-color: transparent !important;
    color: #aa9b86 !important;
    cursor: not-allowed !important;
    border-bottom-color: rgba(126, 132, 96, 0.15) !important;
}
.dw-quote-sidebar select {
    background-image: url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23aa9b86' stroke-width='1.6'%3e%3cpath d='M6 9l6 6 6-6'/%3e%3c/svg%3e") !important;
    background-repeat: no-repeat !important;
    background-position: right 0 center !important;
    background-size: 14px !important;
    padding-right: 24px !important;
}
.dw-quote-sidebar .dw-form-group {
    gap: 6px !important;
}
.dw-quote-sidebar .dw-form-group label {
    font-size: 9.5px !important;
}

/* Mobile — overview stacks, highlights card non-sticky */
@media (max-width: 900px) {
    .dw-main-content #overview .dw-overview-split-layout {
        grid-template-columns: 1fr !important;
        gap: 40px !important;
    }
    .dw-main-content #overview .dw-ov-right {
        position: static !important;
        top: auto !important;
    }
}

@media (max-width: 600px) {
    .dw-hero-section .dw-hero-planner-bar {
        grid-template-columns: 1fr !important;
    }
    .dw-hero-section .dw-hero-planner-col {
        border-right: 0 !important;
        border-bottom: 1px solid rgba(126, 132, 96, 0.18) !important;
    }
    .dw-hero-section .dw-hero-quote-btn {
        width: 100% !important;
        padding: 16px 24px !important;
    }
    .dw-hero-section h1.dw-hero-title,
    .dw-hero-section .dw-hero-title {
        max-width: 92vw !important;
        font-size: 20px !important;
        line-height: 1.18 !important;
        margin-bottom: 26px !important;
    }
    .dw-main-content #overview .dw-highlights-card {
        padding: 28px 18px !important;
    }
    .dw-main-content #overview .dw-hc-offer {
        padding: 26px 18px !important;
    }
}
.dw-faq-left .dw-faq-title {
    text-align: left !important;
    margin-bottom: 20px !important;
    border-bottom: none !important;
}


.dw-am-sidebar-divider {
    display: block !important;
    width: 100% !important;
    height: 1px !important;
    background: rgba(126, 132, 96, 0.18) !important;
    margin: 34px 0 30px !important;
}