/* --- 1. TYPOGRAPHY & VARIABLES --- */
/* Fonts loaded via worker <link> tag in headBuilder.js — no @import needed */

:root {
    --primary-color: #1a1a1a;
    --accent-color: #0e2a47;
    --navy: #0e2a47;
    --bg-light: #f9f8f6;
    --font-serif: 'Cormorant Garamond', serif;
    --font-sans: 'Montserrat', sans-serif;
}

/* --- 2. HEADER LOGO --- */

#primary-logo img.logo.primary {
    display: none !important;
}

.luxury-logo-text {
    font-family: var(--font-serif) !important;
    font-size: 34px;
    letter-spacing: 2px;
    font-weight: 400;
    text-transform: uppercase;
    line-height: 1;
    display: inline-block;
    margin-top: -5px;
    margin-bottom: 18px;
    padding-bottom: 10px;
    color: var(--primary-color) !important;
    border-bottom: 1px solid transparent;
    text-shadow: none;
    transition: border-color 0.25s ease !important;
}

/*
.luxury-logo-text:hover {
    border-bottom-color: var(--primary-color) !important;
}
*/

/* Mobile: reduce font size and spacing */
@media (max-width: 768px) {
    .luxury-logo-text {
        font-size: 24px;
        letter-spacing: 1px;
        padding-bottom: 6px;
    }
}

@media (max-width: 480px) {
    .luxury-logo-text {
        font-size: 18px;
        letter-spacing: 0.5px;
        padding-bottom: 4px;
    }
}


/* Homepage: white logo over video */
body.header-transparent .luxury-logo-text {
    color: #ffffff !important;
    border-bottom-color: transparent !important;
    text-shadow: 0 1px 10px rgba(0,0,0,0.3);
}

body.header-transparent .luxury-logo-text:hover {
    border-bottom-color: #ffffff !important;
}

/* Logo underline for KVCore/other page variants */
#primary-logo a,
#primary-logo .logo-text,
.header-logo a {
    display: inline-block;
    border-bottom: 1px solid transparent !important;
    padding-bottom: 10px;
    transition: border-color 0.25s ease !important;
}

#primary-logo a:hover,
#primary-logo .logo-text:hover,
.header-logo a:hover {
    border-bottom-color: var(--primary-color) !important;
}

body.header-transparent #primary-logo a:hover,
body.header-transparent .header-logo a:hover {
    border-bottom-color: #ffffff !important;
}

/* Nested logo text: hover underline via currentColor */
/*
#primary-logo a .luxury-logo-text {
    display: inline-block;
    padding-bottom: 6px;
    border-bottom: 2px solid transparent;
    transition: border-color 0.3s ease;
}


#primary-logo a:hover .luxury-logo-text {
    border-bottom-color: currentColor;
}
*/

.navbar-brand {
    border-bottom: 1px solid transparent !important;
    padding-bottom: 10px;
    transition: border-color 0.25s ease;
}

.navbar-brand:hover {
    border-bottom-color: var(--primary-color) !important;
}

body.header-transparent .navbar-brand:hover {
    border-bottom-color: #ffffff !important;
}

/* --- 3. HERO SECTION & SEARCH REMOVAL --- */

#horizontal-search,
.listing-header-search,
#quick-search {
    display: none !important;
}

.cover {
    position: relative !important;
}

.cover-image.cover-overlay {
    position: absolute !important;
    inset: 0 !important;
    z-index: 1 !important;
}

.hero-overlay-container {
    position: absolute !important;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    text-align: center;
    color: white;
    width: 90%;
    z-index: 50 !important;
    text-shadow: 0 2px 10px rgba(0,0,0,0.5);
}

.hero-overlay-container h1 {
    font-family: var(--font-serif);
    font-size: 4rem;
    font-weight: 400;
    margin-bottom: 10px;
    letter-spacing: 2px;
}

.hero-overlay-container h2 {
    font-family: var(--font-sans);
    font-size: 14px;
    font-weight: 500;
    letter-spacing: 4px;
    text-transform: uppercase;
    margin-bottom: 20px;
}

.hero-overlay-container p {
    font-family: var(--font-sans);
    font-size: 13px;
    font-weight: 400;
    letter-spacing: 2px;
    margin-bottom: 20px;
    opacity: 0.9;
}

/* Hero CTA button */
.hero-overlay-container .hero-cta {
    display: inline-block !important;
    padding: 12px 28px !important;
    border: 1px solid #fff !important;
    color: #fff !important;
    background: transparent !important;
    text-decoration: none !important;
    text-transform: uppercase !important;
    letter-spacing: 2px !important;
    font-size: 11px !important;
    border-radius: 0 !important;
}

/* Press/Authority Section */
.press-section p,
.press-section span,
.press-section h3 {
    color: #ffffff !important;
    text-shadow: 0 1px 3px rgba(0,0,0,0.8);
    opacity: 0.95 !important;
}

/* --- 4. NAVIGATION --- */

.nav-primary-wrapper,
.nav-primary,
.nav-primary .navbar-nav {
    justify-content: center !important;
    text-align: center !important;
}

.nav-primary-wrapper {
    display: flex;
    background: transparent;
}

.nav-primary .nav-item,
.nav-primary .nav-item .nav-link {
    text-align: center !important;
}

/* Homepage (transparent header): white links over video */
body.header-transparent .nav-primary .nav-item .nav-link {
    font-family: var(--font-sans);
    text-transform: uppercase;
    font-size: 13px;
    letter-spacing: 1.5px;
    color: #ffffff !important;
    text-shadow: 0 1px 4px rgba(0,0,0,0.6);
    font-weight: 500;
    transition: all 0.3s ease;
    border-bottom: 2px solid transparent;
}

body.header-transparent .nav-primary .nav-item .nav-link:hover {
    color: #ffffff !important;
    opacity: 1;
    border-bottom: 2px solid #ffffff;
    transform: translateY(-2px);
}

/* Desktop nav */
@media (min-width: 992px) {
    .luxury-logo-text {
        font-size: 28px;
        letter-spacing: 1.2px;
    }
    
    /* Default links (non-transparent pages) */
    .nav-primary .nav-item .nav-link {
        font-family: var(--font-sans);
        text-transform: uppercase;
        font-size: 13px;
        letter-spacing: 1.5px;
        color: var(--primary-color) !important;
        font-weight: 500;
        padding: 15px 20px;
        transition: all 0.3s ease;
    }

    body:not(.header-transparent) .nav-primary .nav-item .nav-link {
        text-shadow: none !important;
        border-bottom: 2px solid transparent !important;
        display: inline-block;
    }

    body:not(.header-transparent) .nav-primary .nav-item .nav-link:hover {
        color: var(--primary-color) !important;
        border-bottom-color: var(--primary-color) !important;
        transform: translateY(-2px);
        opacity: 1 !important;
    }

    body:not(.header-transparent) .nav-primary .nav-item.active .nav-link,
    body:not(.header-transparent) .nav-primary .nav-item .nav-link.active {
        border-bottom-color: var(--primary-color) !important;
    }

    /* Homepage links override to white */
    body.header-transparent .nav-primary .nav-item .nav-link {
        color: #ffffff !important;
        text-shadow: 0 1px 3px rgba(0,0,0,0.6);
    }

    body.header-transparent .nav-primary .nav-item .nav-link:hover {
        opacity: 1;
        transform: translateY(-2px);
        color: #ffffff !important;
        border-bottom: 2px solid #ffffff;
    }

    /* Hero text shadow and CTA hover */
    .hero-overlay-container {
        text-shadow: 0 2px 14px rgba(0,0,0,0.35) !important;
    }

    .hero-overlay-container .hero-cta:hover {
        background: rgba(255,255,255,0.12) !important;
    }
}

/* Mobile nav */
@media (max-width: 991px) {
    .nav-primary-wrapper {
        background-color: #fff !important;
        box-shadow: 0 5px 15px rgba(0,0,0,0.1);
    }

    .nav-primary .nav-item .nav-link,
    body.header-transparent .nav-primary .nav-item .nav-link {
        color: var(--primary-color) !important;
        text-shadow: none !important;
        font-family: var(--font-sans);
        font-weight: 600 !important;
        padding: 15px 20px;
        border-bottom: 1px solid #f0f0f0;
        text-align: left;
    }

    .nav-primary .nav-item .nav-link:hover,
    body.header-transparent .nav-primary .nav-item .nav-link:hover {
        color: var(--accent-color) !important;
        background-color: #f9f9f9 !important;
        border-bottom: 1px solid #f0f0f0;
    }
}

/* --- 5. HAMBURGER BUTTON --- */

.navbar-toggler {
    border: 1px solid rgba(255,255,255, 0.6) !important;
    border-radius: 0px !important;
    padding: 8px 12px !important;
    transition: all 0.3s ease;
    cursor: pointer;
    background-color: transparent !important;
}

.navbar-toggler span {
    background-color: #fff !important;
    height: 1px !important;
    margin: 6px 0 !important;
    transition: all 0.3s ease;
}

.navbar-toggler:hover {
    background-color: transparent !important;
    border-color: var(--accent-color) !important;
    transform: scale(1.05);
}

.navbar-toggler:hover span {
    background-color: var(--accent-color) !important;
}

/* --- 6. GLOBAL BUTTON SYSTEM --- */

a.btn,
button.btn,
input[type="submit"].btn,
input[type="button"].btn,
.btn {
    background: transparent !important;
    border: 1px solid var(--primary-color) !important;
    color: var(--primary-color) !important;
    border-radius: 0 !important;
    text-transform: uppercase !important;
    letter-spacing: 2px !important;
    font-size: 11px !important;
    padding: 12px 22px !important;
    box-shadow: none !important;
    transition: all 0.25s ease !important;
}

a.btn:hover,
button.btn:hover,
input[type="submit"].btn:hover,
input[type="button"].btn:hover,
.btn:hover,
a.btn:focus,
button.btn:focus,
.btn:focus {
    background: var(--primary-color) !important;
    border-color: var(--primary-color) !important;
    color: #ffffff !important;
    opacity: 1 !important;
}

/* btn-primary: filled by default */
.btn-primary,
button.btn-primary,
a.btn-primary {
    background-color: var(--primary-color) !important;
    border-color: var(--primary-color) !important;
    color: #ffffff !important;
    border-radius: 0px !important;
    text-transform: uppercase;
    letter-spacing: 2px;
    font-size: 11px !important;
    padding: 15px 30px !important;
    transition: all 0.3s ease !important;
}

.btn-primary:hover,
button.btn-primary:hover,
a.btn-primary:hover {
    background-color: var(--accent-color) !important;
    border-color: var(--accent-color) !important;
    transform: translateY(-2px);
}

/* Hero CTA buttons (white outline) */
.hero-overlay-container .btn,
.hero-overlay-container .hero-cta {
    border-color: #ffffff !important;
    color: #ffffff !important;
    background: transparent !important;
}

.hero-overlay-container .btn:hover,
.hero-overlay-container .hero-cta:hover {
    background: rgba(255,255,255,0.12) !important;
    border-color: #ffffff !important;
    color: #ffffff !important;
}

/* Search filter bar buttons */
#search-actions .btn,
#search-actions .btn-group .btn {
    background: transparent !important;
    border: 1px solid var(--primary-color) !important;
    color: var(--primary-color) !important;
}

#search-actions .btn:hover,
#search-actions .btn:focus {
    background: var(--primary-color) !important;
    border-color: var(--primary-color) !important;
    color: #ffffff !important;
}

/* Save Search button */
#search-actions .btn-primary,
button[onclick*="saveSearch"] {
    background-color: #1a1a1a !important;
    color: #fff !important;
    border: 1px solid #1a1a1a !important;
}

/* Work with Darci button */
.work-with-darci-btn {
    background: #0b0b0b;
    color: #ffffff;
    border: 1px solid rgba(255,255,255,0.15);
    letter-spacing: 2px;
    transition: background 0.25s ease, border-color 0.25s ease;
}

.work-with-darci-btn:hover {
    background: #0e2a47;
    border-color: rgba(255,255,255,0.35);
}

/* Bio Photo Border */
#froala-editor div[style*="border"] {
    border: 1px solid rgba(14, 42, 71, 0.2) !important;
    padding: 12px !important;
}

/* --- 7. PROPERTY DETAIL PAGE --- */

body.listing-detail h1,
body.listing-detail .listing-address,
body.listing-detail .listing-city-state {
    font-family: 'Cormorant Garamond', serif !important;
    font-weight: 400 !important;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: #1a1a1a !important;
}

body.listing-detail .listing-price {
    font-family: 'Cormorant Garamond', serif !important;
    font-size: 2.5rem !important;
    font-weight: 600 !important;
    color: #0e2a47 !important;
    border-bottom: none !important;
}

.listing-gallery .owl-stage-outer,
.listing-gallery img {
    border-radius: 0px !important;
    box-shadow: none !important;
}

.widget.contact {
    border: 1px solid #e0e0e0 !important;
    border-radius: 0px !important;
    box-shadow: none !important;
    background-color: #fff !important;
}

.widget.contact .form-control {
    border-radius: 0px !important;
    border: 1px solid #ccc !important;
    background-color: #fcfcfc !important;
    font-family: 'Montserrat', sans-serif;
    font-size: 13px;
    padding: 12px;
}

.widget.contact .form-control:focus {
    border-color: #0e2a47 !important;
    background-color: #fff !important;
    outline: none;
}

.listing-detail-attribute {
    border: none !important;
    background: transparent !important;
}

.listing-detail-attribute .value {
    font-family: 'Cormorant Garamond', serif !important;
    font-size: 1.8rem !important;
    color: #1a1a1a !important;
}

.listing-detail-attribute .key {
    font-family: 'Montserrat', sans-serif !important;
    font-size: 0.75rem !important;
    text-transform: uppercase;
    letter-spacing: 2px;
    color: #999 !important;
}

.listing-description {
    font-family: 'Montserrat', sans-serif !important;
    font-size: 1.05rem !important;
    line-height: 1.9 !important;
    color: #444 !important;
    font-weight: 300 !important;
}

.listing-box-image-label,
.label-primary {
    background-color: #0e2a47 !important;
    border-radius: 0px !important;
    font-family: 'Montserrat', sans-serif;
    font-size: 10px;
    letter-spacing: 1px;
    text-transform: uppercase;
    padding: 5px 10px;
}

#map-google, #map-leaflet {
    border: none !important;
    border-top: 1px solid #eee !important;
}

.widgettitle {
    font-family: 'Cormorant Garamond', serif !important;
    font-size: 1.8rem !important;
    border-bottom: 1px solid #0e2a47 !important;
    padding-bottom: 15px !important;
    margin-bottom: 25px !important;
    text-transform: uppercase;
    letter-spacing: 1px;
}

/* --- 8. SEARCH RESULTS PAGE --- */

#search-actions {
    background-color: #fff !important;
    border-bottom: 1px solid #eee !important;
    padding: 15px 20px !important;
}

#map-listings-container .card,
.listing-box {
    border: none !important;
    box-shadow: none !important;
    background-color: #fff !important;
    margin-bottom: 40px !important;
}

#map-listings-container .card-img-top,
.listing-box-image {
    border-radius: 0px !important;
    filter: brightness(1.02);
}

.card-title .card-price,
.listing-box-title h3 {
    font-family: 'Cormorant Garamond', serif !important;
    font-size: 26px !important;
    font-weight: 500 !important;
    color: #0e2a47 !important;
    background: transparent !important;
    padding: 0 !important;
}

.card-title .card-address,
.listing-box-title h2,
.card-footer .card-city {
    font-family: 'Montserrat', sans-serif !important;
    font-size: 11px !important;
    text-transform: uppercase !important;
    letter-spacing: 1px;
    color: #1a1a1a !important;
    margin-top: 5px !important;
}

.card-footer .size-data {
    border-top: 1px solid #f0f0f0 !important;
    padding-top: 10px !important;
    margin-top: 10px !important;
}

.card-footer .size-data .card-value {
    font-family: 'Cormorant Garamond', serif !important;
    font-size: 16px !important;
    font-weight: 600 !important;
    color: #1a1a1a !important;
}

.card-footer .size-data .card-label {
    font-family: 'Montserrat', sans-serif !important;
    font-size: 9px !important;
    text-transform: uppercase;
    color: #999 !important;
}

.card-img-top .card-badge,
.listing-box-image-label {
    background-color: #0e2a47 !important;
    border-radius: 0px !important;
    font-family: 'Montserrat', sans-serif !important;
    font-size: 9px !important;
    letter-spacing: 1px;
    text-transform: uppercase;
    padding: 6px 12px !important;
    top: 15px !important;
    left: 15px !important;
}

.card-actions,
.listing-box-image-links {
    background-color: rgba(14, 42, 71, 0.9) !important;
}

.card-actions a,
.listing-box-image-links a {
    font-family: 'Montserrat', sans-serif !important;
    font-weight: 500 !important;
    letter-spacing: 1px;
    text-transform: uppercase;
    font-size: 11px !important;
}

/* --- 9. MOBILE HERO --- */

@media (max-width: 991px) {
    .cover,
    .cover.agent,
    .cover.agent.video {
        position: relative !important;
        min-height: 78vh !important;
        overflow: hidden !important;
    }

    .cover-image.cover-overlay {
        position: absolute !important;
        inset: 0 !important;
        background-position: center center !important;
        background-size: cover !important;
        background-repeat: no-repeat !important;
        z-index: 1 !important;
        opacity: 0.65 !important;
    }

    .hero-overlay-container {
        position: absolute !important;
        left: 50% !important;
        top: 46% !important;
        transform: translate(-50%, -50%) !important;
        width: min(92vw, 520px) !important;
        z-index: 50 !important;
        text-align: center !important;
        padding: 0 10px !important;
    }

    .hero-overlay-container h2 {
        font-size: 11px !important;
        letter-spacing: 3px !important;
        margin-bottom: 14px !important;
        text-transform: uppercase !important;
    }

    .hero-overlay-container h1 {
        font-size: 2.4rem !important;
        line-height: 1.08 !important;
        letter-spacing: 1px !important;
        margin: 0 0 16px 0 !important;
    }

    .hero-overlay-container a.hero-cta,
    .hero-overlay-container a.btn.btn-outline-white {
        display: inline-block !important;
        padding: 12px 22px !important;
        border: 1px solid #fff !important;
        color: #fff !important;
        background: transparent !important;
        text-decoration: none !important;
        text-transform: uppercase !important;
        letter-spacing: 2px !important;
        font-size: 11px !important;
        border-radius: 0 !important;
        margin-top: 6px !important;
    }

    .press-section {
        position: relative !important;
        z-index: 40 !important;
        margin-top: 52vh !important;
        padding: 18px 0 26px 0 !important;
        border-bottom: 0 !important;
    }

    .press-section p {
        font-size: 10px !important;
        letter-spacing: 2px !important;
        margin-bottom: 12px !important;
    }

    .press-section > .container > div {
        display: grid !important;
        grid-template-columns: 1fr 1fr !important;
        gap: 14px 18px !important;
        justify-items: center !important;
        opacity: 0.75 !important;
        filter: grayscale(100%) !important;
    }

    .press-section span {
        font-size: 16px !important;
        white-space: nowrap !important;
    }
}

@media (max-width: 390px) {
    .hero-overlay-container h1 { font-size: 2.15rem !important; }
}

/* --- 10. VIDEO BACKGROUND --- */

.cover.agent.video {
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}

.hbd-yt-bg iframe {
    opacity: 0;
    transition: opacity 0.8s ease;
}

.hbd-yt-bg.loaded iframe {
    opacity: 1;
}
