/* ==========================================================================
   Nester & Finn – Brand-Aligned Custom CSS (2025)
   ========================================================================== */

/* ———————— Core Brand Colors ———————— */
:root {
    --nester-primary:       #0B1D35;   /* Dark Navy – Primary Color */
    --nester-dark-neutral:  #264653;   /* Dark Cyan – headers, footers */
    --nester-accent:        #d9a67a;   /* Warm Clay – CTAs, highlights */
    --nester-complementary: #bec8af;   /* Light Green – subtle accents */
    --nester-supplemental:  #4C5C36;   /* Dark Green – secondary buttons, icons */
    --nester-light-neutral: #ede1db;   /* Close-to-white – main background */
    --nester-dark-navy:     #0B1D35;
}

/* ———————— Typography ———————— */
body {
    background-color: var(--nester-light-neutral);   /* #fcfbf6 */
    font-family: 'Quattrocento Sans', Georgia, serif;
    color: #333;
    line-height: 1.7;
    padding-top: 0 !important;
}

/* Headings – elegant serif */
h1, h2, h3, h4, h5, h6,
.display-1, .display-2, .display-3, .display-4 {
    font-family: 'Playfair Display', Georgia, serif;
    font-weight: 100;
    letter-spacing: 1px;
}

/* Subtle text adjustments */
.text-muted { color: #777 !important; }
small, .small { color: #888; }

/* ———————— Bootstrap Overrides – Make Primary = Warm Clay ———————— */
.btn-primary,
.btn-outline-primary:hover {
    background-color: var(--nester-accent) !important;      /* #d9a67a */
    border-color: var(--nester-accent) !important;
    color: #fff !important;
}

.btn-primary:hover {
    background-color: #d09462 !important;   /* slightly darker on hover */
    border-color: #d09462 !important;
}

/* Success / Secondary actions – Dark Green */
.btn-success,
.btn-outline-success:hover {
    background-color: var(--nester-supplemental) !important;  /* #4C5C36 */
    border-color: var(--nester-supplemental) !important;
}

/* Outline versions */
.btn-outline-primary {
    color: var(--nester-accent);
    border-color: var(--nester-accent);
}
.btn-outline-success {
    color: var(--nester-supplemental);
    border-color: var(--nester-supplemental);
}

/* Pill-shaped buttons (your signature style) */
.btn {
    border-radius: 50px;
    padding: 0.65rem 2rem;
    font-weight: 500;
    transition: all 0.3s ease;
}

/* ———————— Navbar – Transparent → Solid on Scroll ———————— */
.navbar {
    transition: all 0.4s ease;
    background: transparent;
    padding: 1.5rem 1rem;
}

.navbar .navbar-brand,
.navbar .nav-link {
    color: #fff;
    text-shadow: 1px 1px 1px rgba(0,0,0,0.5);
    font-weight: 200;
}

.navbar .btn {
    background: var(--nester-accent);
    border-color: var(--nester-accent);
}

/* Scrolled state */
.navbar.scrolled {
    background: rgba(252, 251, 246, 0.97) !important;   /* light neutral with slight transparency */
    backdrop-filter: saturate(180%) blur(12px);
    box-shadow: 0 4px 30px rgba(0,0,0,0.08);
    padding: 0.8rem 1rem;
}

.navbar.scrolled .navbar-brand,
.navbar.scrolled .nav-link {
    color: var(--nester-primary) !important;
    text-shadow: none;
}

.navbar.scrolled .btn {
    background: var(--nester-accent);
}

/* ———————— Hero Section ———————— */
.hero-bg {
    height: 100vh;
    min-height: 650px;
    background-attachment: fixed;
    background-position: center;
    background-size: cover;
}

/* ———————— Forms ———————— */
.form-control,
.form-select {
    background-color: #fff;
    border: 0px solid #ddd;
    border-bottom: 1px solid #ddd;
    padding: 0.75rem 1.5rem;
    transition: border-color 0.3s ease;
}

.form-control:focus,
.form-select:focus {
    border-color: var(--nester-accent);
    box-shadow: 0 0 0 0.2rem rgba(217, 166, 122, 0.25);
}

/* ———————— Footer ———————— */
footer {
    background-color: var(--nester-primary) !important;   /* Dark Navy #0B1D35 */
    color: #ddd;
    padding: 4rem 0 2rem;
}

footer a {
    color: var(--nester-accent);
}

footer a:hover {
    color: #fff;
}

/* ———————— Custom Shapes & Polish ———————— */
.radius-pointed-tr-bl {
    border-top-left-radius: 65px;
    border-bottom-right-radius: 65px;
}
.radius-pointed-tl-br {
    border-top-right-radius: 65px;
    border-bottom-left-radius: 65px;
}

.booking-pill {
    box-shadow: 0 8px 25px rgba(0,0,0,0.1);
    transition: all 0.3s ease;
}
.booking-pill:hover {
    transform: translateY(-4px);
    box-shadow: 0 14px 35px rgba(0,0,0,0.15);
}

/* Subtle background sections */
.bg-light-neutral { background-color: var(--nester-light-neutral); }
.bg-warm-clay     { background-color: var(--nester-accent); color: #fff; }
.bg-dark-green    { background-color: var(--nester-supplemental); color: #fff; }
.bg-dark          { background-color: var(--nester-primary); color: #fff; }


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