    :root {
        --savanna: #F5A623;
        --dusk: #E8602A;
        --mara: #2E7D32;
        --mara2: #1B5E20;
        --sky: #FFF8EE;
        --sky2: #FFF0D6;
        --earth: #8B5E3C;
        --earth2: #5C3A1E;
        --stone: #F0E6D3;
        --stone2: #E2D0B8;
        --ivory: #FFFCF5;
        --night: #1A0F00;
        --txt: #3D2200;
        --txt2: #7A5C3A;
        --txt3: #B08060;
        --white: #FFFFFF;
        --r: 14px;
        --r2: 22px;
        --r3: 36px;
        --sh1: 0 4px 20px rgba(61, 34, 0, .09);
        --sh2: 0 10px 40px rgba(61, 34, 0, .14);
        --sh3: 0 20px 70px rgba(61, 34, 0, .18);
    }

    *,
    *::before,
    *::after {
        box-sizing: border-box;
        margin: 0;
        padding: 0
    }

    html {
        scroll-behavior: smooth;
        max-width: 100%;
        overflow-x: hidden
    }

    body {
        font-family: 'Nunito', sans-serif;
        background: var(--ivory);
        color: var(--txt);
        overflow-x: hidden;
        max-width: 100%
    }

    ::-webkit-scrollbar {
        width: 5px
    }

    ::-webkit-scrollbar-track {
        background: var(--stone)
    }

    ::-webkit-scrollbar-thumb {
        background: var(--dusk);
        border-radius: 3px
    }

    img {
        display: block;
        max-width: 100%
    }

    a {
        color: inherit;
        text-decoration: none
    }

    .rv {
        opacity: 0;
        transform: translateY(32px);
        transition: opacity .7s ease, transform .7s ease
    }

    .rv.on {
        opacity: 1;
        transform: none
    }

    .rl {
        opacity: 0;
        transform: translateX(-32px);
        transition: opacity .7s ease, transform .7s ease
    }

    .rl.on {
        opacity: 1;
        transform: none
    }

    .rr {
        opacity: 0;
        transform: translateX(32px);
        transition: opacity .7s ease, transform .7s ease
    }

    .rr.on {
        opacity: 1;
        transform: none
    }

    /* ALERT BAR */
    .alert-bar {
        background: linear-gradient(90deg, var(--mara), var(--mara2));
        color: #fff;
        text-align: center;
        padding: 9px 44px 9px 12px;
        font-size: .75rem;
        font-weight: 600;
        position: relative;
        display: flex;
        align-items: center;
        justify-content: center;
        gap: 7px;
        flex-wrap: wrap;
        line-height: 1.5;
        min-height: 38px;
        width: 100%;
        box-sizing: border-box
    }

    .ab-pulse {
        width: 8px;
        height: 8px;
        border-radius: 50%;
        background: #A5D6A7;
        animation: abp 2s infinite;
        flex-shrink: 0
    }

    @keyframes abp {

        0%,
        100% {
            box-shadow: 0 0 0 0 rgba(165, 214, 167, .5)
        }

        60% {
            box-shadow: 0 0 0 8px rgba(165, 214, 167, 0)
        }
    }

    .ab-close {
        position: absolute;
        right: 8px;
        top: 50%;
        transform: translateY(-50%);
        background: none;
        border: none;
        color: rgba(255, 255, 255, .75);
        font-size: .95rem;
        cursor: pointer;
        padding: 6px 8px;
        line-height: 1;
        z-index: 2
    }

    .ab-close:hover {
        color: #fff
    }

    /* NAV */
    #nav {
        position: sticky;
        top: 0;
        z-index: 900;
        background: rgba(255, 252, 245, .96);
        backdrop-filter: blur(18px);
        border-bottom: 2px solid var(--stone2);
        display: flex;
        align-items: center;
        justify-content: space-between;
        padding: 0 48px;
        height: 72px;
        transition: box-shadow .3s;
        gap: 12px
    }

    #nav.scrolled {
        box-shadow: var(--sh1)
    }

    .nav-brand {
        display: flex;
        align-items: center;
        gap: 10px;
        min-width: 0;
        flex-shrink: 1
    }

    .nav-paw {
        font-size: 1.6rem;
        animation: pawWiggle 3s ease-in-out infinite;
        flex-shrink: 0
    }

    @keyframes pawWiggle {

        0%,
        100% {
            transform: rotate(0)
        }

        30% {
            transform: rotate(-12deg)
        }

        60% {
            transform: rotate(8deg)
        }
    }

    .nav-brand-text {
        min-width: 0;
        overflow: hidden
    }

    .nb-main {
        font-family: 'Alike Angular', serif;
        font-size: 1.2rem;
        color: var(--dusk);
        letter-spacing: .02em;
        line-height: 1.1;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
        display: block
    }

    .nb-sub {
        font-size: .58rem;
        font-weight: 700;
        letter-spacing: .22em;
        text-transform: uppercase;
        color: var(--txt3);
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
        display: block
    }

    .nav-links {
        display: flex;
        gap: 1.8rem;
        list-style: none
    }

    .nav-links a {
        font-size: .76rem;
        font-weight: 700;
        color: var(--txt2);
        transition: color .2s;
        padding: .2rem 0;
        position: relative
    }

    .nav-links a::after {
        content: '';
        position: absolute;
        bottom: 0;
        left: 0;
        width: 0;
        height: 2px;
        border-radius: 1px;
        background: var(--dusk);
        transition: width .25s
    }

    .nav-links a:hover {
        color: var(--dusk)
    }

    .nav-links a:hover::after {
        width: 100%
    }

    .nav-r {
        display: flex;
        align-items: center;
        gap: 10px;
        flex-shrink: 0
    }

    .nav-weather {
        display: flex;
        align-items: center;
        gap: 6px;
        background: var(--stone);
        border-radius: 99px;
        padding: 6px 14px;
        font-size: .72rem;
        font-weight: 600;
        color: var(--txt2);
        white-space: nowrap
    }

    .nw-icon {
        font-size: 1rem
    }

    .th-toggle {
        width: 50px;
        height: 26px;
        border-radius: 13px;
        background: var(--sky2);
        border: 2px solid var(--stone2);
        cursor: pointer;
        position: relative;
        flex-shrink: 0
    }

    .th-thumb {
        position: absolute;
        top: 2px;
        left: 2px;
        width: 18px;
        height: 18px;
        border-radius: 50%;
        background: var(--savanna);
        transition: transform .3s;
        display: flex;
        align-items: center;
        justify-content: center;
        font-size: .7rem
    }

    .dark .th-thumb {
        transform: translateX(24px)
    }

    .book-pill {
        padding: 9px 24px;
        font-size: .75rem;
        font-weight: 800;
        background: linear-gradient(135deg, var(--dusk), var(--savanna));
        color: #fff;
        border: none;
        border-radius: 99px;
        cursor: pointer;
        box-shadow: 0 4px 16px rgba(232, 96, 42, .4);
        transition: all .26s;
        white-space: nowrap
    }

    .book-pill:hover {
        transform: translateY(-2px);
        box-shadow: 0 8px 24px rgba(232, 96, 42, .5)
    }

    .ham {
        display: none;
        flex-direction: column;
        gap: 5px;
        cursor: pointer;
        padding: 6px;
        flex-shrink: 0
    }

    .ham span {
        width: 22px;
        height: 2px;
        background: var(--txt);
        border-radius: 1px;
        transition: all .3s
    }

    /* HERO */
    #hero {
        position: relative;
        min-height: 100vh;
        display: flex;
        flex-direction: column;
        overflow: hidden
    }

    .hero-bg {
        position: absolute;
        inset: 0;
        background: url('./assets/cam3.jpg') center/cover no-repeat;
        animation: hzoom 10s ease-in-out infinite alternate
    }

    @keyframes hzoom {
        from {
            transform: scale(1.0)
        }

        to {
            transform: scale(1.08)
        }
    }

    .hero-gradient {
        position: absolute;
        inset: 0;
        background: linear-gradient(to bottom, rgba(26, 15, 0, .25) 0%, rgba(26, 15, 0, .1) 40%, rgba(26, 15, 0, .7) 80%, rgba(26, 15, 0, .92) 100%)
    }

    .grass {
        position: absolute;
        bottom: 0;
        left: 0;
        right: 0;
        height: 140px;
        overflow: hidden;
        pointer-events: none;
        z-index: 3
    }

    .grass svg {
        width: 100%;
        height: 100%;
        display: block
    }

    .g-blade {
        transform-origin: bottom center;
        animation: sway 3.5s ease-in-out infinite alternate
    }

    .g-blade:nth-child(2n) {
        animation-delay: .4s;
        animation-duration: 4.2s
    }

    .g-blade:nth-child(3n) {
        animation-delay: .8s;
        animation-duration: 3.8s
    }

    .g-blade:nth-child(4n) {
        animation-delay: 1.2s;
        animation-duration: 4.5s
    }

    @keyframes sway {
        from {
            transform: rotate(-4deg)
        }

        to {
            transform: rotate(4deg)
        }
    }

    .bird {
        position: absolute;
        top: 18%;
        font-size: 1.4rem;
        animation: birdFly 18s linear infinite;
        opacity: .75;
        z-index: 2;
        pointer-events: none
    }

    .bird2 {
        top: 25%;
        animation-delay: 7s;
        animation-duration: 22s;
        font-size: 1rem
    }

    .bird3 {
        top: 12%;
        animation-delay: 13s;
        animation-duration: 16s;
        font-size: 1.6rem
    }

    @keyframes birdFly {
        from {
            left: -5%
        }

        to {
            left: 105%
        }
    }

    .hero-content {
        position: relative;
        z-index: 4;
        flex: 1;
        display: flex;
        flex-direction: column;
        justify-content: flex-end;
        padding: 0 64px 160px;
        max-width: 820px
    }

    .hero-eyebrow {
        display: inline-flex;
        align-items: center;
        gap: 10px;
        background: rgba(255, 255, 255, .15);
        backdrop-filter: blur(8px);
        border: 1px solid rgba(255, 255, 255, .3);
        border-radius: 99px;
        padding: 7px 18px;
        font-size: .72rem;
        font-weight: 700;
        letter-spacing: .16em;
        text-transform: uppercase;
        color: rgba(255, 255, 255, .9);
        margin-bottom: 24px;
        width: fit-content
    }

    .he-dot {
        width: 7px;
        height: 7px;
        border-radius: 50%;
        background: var(--savanna);
        animation: abp 2s infinite
    }

    .hero-h1 {
        font-family: 'Alike Angular', serif;
        font-size: clamp(3rem, 7vw, 6.5rem);
        line-height: 1.0;
        color: #fff;
        margin-bottom: 20px;
        text-shadow: 0 2px 32px rgba(0, 0, 0, .3)
    }

    .hero-h1 span {
        color: var(--savanna)
    }

    .hero-sub {
        font-size: 1.1rem;
        font-weight: 300;
        line-height: 1.8;
        color: rgba(255, 255, 255, .85);
        max-width: 560px;
        margin-bottom: 36px
    }

    .hero-actions {
        display: flex;
        gap: 14px;
        flex-wrap: wrap;
        margin-bottom: 40px
    }

    .ha-wh {
        padding: 14px 36px;
        font-size: .82rem;
        font-weight: 800;
        background: linear-gradient(135deg, var(--dusk), var(--savanna));
        color: #fff;
        border: none;
        border-radius: 99px;
        cursor: pointer;
        box-shadow: 0 8px 28px rgba(232, 96, 42, .5);
        transition: all .28s
    }

    .ha-wh:hover {
        transform: translateY(-3px);
        box-shadow: 0 12px 36px rgba(232, 96, 42, .6)
    }

    .ha-ghost {
        padding: 14px 36px;
        font-size: .82rem;
        font-weight: 700;
        background: rgba(255, 255, 255, .15);
        backdrop-filter: blur(8px);
        color: #fff;
        border: 2px solid rgba(255, 255, 255, .5);
        border-radius: 99px;
        cursor: pointer;
        transition: all .25s
    }

    .ha-ghost:hover {
        background: rgba(255, 255, 255, .25);
        border-color: #fff
    }

    /* QUICK BOOK */
    .hero-quickbook {
        position: relative;
        z-index: 4;
        margin: 0 48px;
        background: rgba(255, 252, 245, .97);
        backdrop-filter: blur(16px);
        border-radius: var(--r2);
        padding: 20px 28px;
        display: flex;
        align-items: center;
        gap: 16px;
        box-shadow: var(--sh3);
        border: 1px solid var(--stone2);
        transform: translateY(-50%);
        flex-wrap: wrap
    }

    .qb-field {
        flex: 1;
        min-width: 140px
    }

    .qb-label {
        font-size: .6rem;
        font-weight: 800;
        letter-spacing: .18em;
        text-transform: uppercase;
        color: var(--txt3);
        margin-bottom: 5px
    }

    .qb-input,
    .qb-select {
        width: 100%;
        font-family: 'Nunito', sans-serif;
        font-size: .87rem;
        font-weight: 600;
        background: transparent;
        color: var(--txt);
        border: none;
        outline: none;
        border-bottom: 2px solid var(--stone2);
        padding: 6px 0;
        transition: border-color .25s
    }

    .qb-input:focus,
    .qb-select:focus {
        border-color: var(--dusk)
    }

    .qb-select {
        appearance: none;
        cursor: pointer
    }

    .qb-divider {
        width: 1px;
        height: 50px;
        background: var(--stone2);
        flex-shrink: 0
    }

    .qb-btn {
        padding: 14px 32px;
        font-size: .8rem;
        font-weight: 800;
        background: linear-gradient(135deg, var(--dusk), var(--savanna));
        color: #fff;
        border: none;
        border-radius: 99px;
        cursor: pointer;
        box-shadow: 0 4px 16px rgba(232, 96, 42, .4);
        transition: all .25s;
        white-space: nowrap;
        flex-shrink: 0
    }

    .qb-btn:hover {
        transform: translateY(-2px);
        box-shadow: 0 8px 22px rgba(232, 96, 42, .5)
    }

    /* BIG 5 */
    .big5-strip {
        margin: 0 48px 0;
        background: linear-gradient(135deg, var(--earth2), var(--earth));
        border-radius: var(--r2);
        padding: 24px 36px;
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 20px;
        flex-wrap: wrap;
        color: #fff
    }

    .b5-title {
        font-family: 'Alike Angular', serif;
        font-size: 1.1rem;
        white-space: nowrap
    }

    .b5-animals {
        display: flex;
        gap: 24px;
        flex-wrap: wrap
    }

    .b5-animal {
        display: flex;
        flex-direction: column;
        align-items: center;
        gap: 4px;
        cursor: pointer;
        transition: transform .25s
    }

    .b5-animal:hover {
        transform: scale(1.15)
    }

    .b5-emoji {
        font-size: 2rem
    }

    .b5-name {
        font-size: .6rem;
        font-weight: 700;
        letter-spacing: .12em;
        text-transform: uppercase;
        opacity: .8
    }

    .b5-badge {
        background: var(--savanna);
        color: var(--earth2);
        border-radius: 99px;
        padding: 2px 8px;
        font-size: .58rem;
        font-weight: 800
    }

    /* SECTION ATOMS */
    .sec {
        padding: 88px 64px
    }

    .sec-tag {
        display: inline-flex;
        align-items: center;
        gap: 8px;
        background: var(--stone);
        border-radius: 99px;
        padding: 6px 16px;
        font-size: .65rem;
        font-weight: 800;
        color: var(--dusk);
        text-transform: uppercase;
        letter-spacing: .14em;
        margin-bottom: 16px
    }

    .sec-tag-dot {
        width: 6px;
        height: 6px;
        border-radius: 50%;
        background: var(--dusk)
    }

    .sec-h {
        font-family: 'Alike Angular', serif;
        font-size: clamp(1.9rem, 3.5vw, 3rem);
        line-height: 1.1;
        color: var(--txt);
        margin-bottom: 14px
    }

    .sec-h em {
        font-style: italic;
        color: var(--dusk)
    }

    .sec-p {
        font-size: .93rem;
        line-height: 1.9;
        color: var(--txt2);
        font-weight: 400;
        max-width: 560px
    }

    /* WILDLIFE */
    #wildlife {
        background: var(--stone)
    }

    .wl-grid {
        display: grid;
        grid-template-columns: repeat(3, 1fr);
        gap: 20px;
        margin-top: 52px
    }

    .wl-card {
        border-radius: var(--r2);
        overflow: hidden;
        position: relative;
        cursor: pointer;
        box-shadow: var(--sh1);
        transition: transform .35s, box-shadow .35s
    }

    .wl-card:hover {
        transform: translateY(-8px);
        box-shadow: var(--sh3)
    }

    .wl-img {
        width: 100%;
        aspect-ratio: 3/4;
        object-fit: cover;
        transition: transform .6s
    }

    .wl-card:hover .wl-img {
        transform: scale(1.07)
    }

    .wl-overlay {
        position: absolute;
        inset: 0;
        background: linear-gradient(to top, rgba(26, 15, 0, .85) 0%, rgba(26, 15, 0, .1) 55%, transparent 100%);
        display: flex;
        flex-direction: column;
        justify-content: flex-end;
        padding: 24px 22px
    }

    .wl-animal {
        font-size: 2.2rem;
        margin-bottom: 8px
    }

    .wl-name {
        font-family: 'Alike Angular', serif;
        font-size: 1.3rem;
        color: #fff;
        margin-bottom: 5px
    }

    .wl-desc {
        font-size: .76rem;
        color: rgba(255, 255, 255, .8);
        line-height: 1.6;
        margin-bottom: 12px
    }

    .wl-badge {
        display: inline-flex;
        align-items: center;
        gap: 6px;
        background: var(--savanna);
        color: var(--earth2);
        border-radius: 99px;
        padding: 5px 14px;
        font-size: .62rem;
        font-weight: 800
    }

    /* ROOMS */
    #rooms {
        background: var(--ivory)
    }

    .rooms-top {
        display: flex;
        justify-content: space-between;
        align-items: flex-end;
        margin-bottom: 48px;
        flex-wrap: wrap;
        gap: 16px
    }

    .rooms-grid {
        display: grid;
        grid-template-columns: repeat(3, 1fr);
        gap: 22px
    }

    .rc {
        background: var(--white);
        border-radius: var(--r2);
        overflow: hidden;
        border: 1.5px solid var(--stone2);
        box-shadow: var(--sh1);
        transition: transform .3s, box-shadow .3s;
        display: flex;
        flex-direction: column
    }

    .rc:hover {
        transform: translateY(-8px);
        box-shadow: var(--sh3)
    }

    .rc-img-w {
        overflow: hidden;
        position: relative
    }

    .rc-img {
        width: 100%;
        aspect-ratio: 16/10;
        object-fit: cover;
        transition: transform .55s
    }

    .rc:hover .rc-img {
        transform: scale(1.06)
    }

    .rc-label {
        position: absolute;
        top: 14px;
        left: 14px;
        border-radius: 99px;
        padding: 5px 14px;
        font-size: .62rem;
        font-weight: 800;
        letter-spacing: .08em;
        text-transform: uppercase
    }

    .rc-body {
        padding: 22px 22px 24px;
        flex: 1;
        display: flex;
        flex-direction: column
    }

    .rc-name {
        font-family: 'Alike Angular', serif;
        font-size: 1.2rem;
        color: var(--txt);
        margin-bottom: 8px
    }

    .rc-chips {
        display: flex;
        flex-wrap: wrap;
        gap: 6px;
        margin-bottom: 12px
    }

    .rc-chip {
        background: var(--stone);
        border-radius: 99px;
        padding: 4px 11px;
        font-size: .64rem;
        font-weight: 700;
        color: var(--txt2)
    }

    .rc-desc {
        font-size: .8rem;
        line-height: 1.75;
        color: var(--txt2);
        flex: 1;
        margin-bottom: 16px
    }

    .rc-foot {
        display: flex;
        justify-content: space-between;
        align-items: center;
        border-top: 1.5px solid var(--stone2);
        padding-top: 16px
    }

    .rc-price {
        font-family: 'Alike Angular', serif;
        font-size: 1.3rem;
        color: var(--dusk)
    }

    .rc-price small {
        font-family: 'Nunito', sans-serif;
        font-size: .66rem;
        font-weight: 600;
        color: var(--txt3)
    }

    .rc-btn {
        padding: 9px 22px;
        font-size: .7rem;
        font-weight: 800;
        background: var(--dusk);
        color: #fff;
        border: none;
        border-radius: 99px;
        cursor: pointer;
        transition: all .25s
    }

    .rc-btn:hover {
        background: var(--savanna);
        color: var(--txt);
        transform: translateY(-2px)
    }

    /* ABOUT */
    #about {
        background: linear-gradient(160deg, #FFF3E0 0%, var(--ivory) 60%)
    }

    .about-grid {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 72px;
        align-items: center
    }

    .about-imgs {
        position: relative
    }

    .ai-main {
        width: 88%;
        aspect-ratio: 4/5;
        object-fit: cover;
        border-radius: var(--r2);
        box-shadow: var(--sh3)
    }

    .ai-accent {
        position: absolute;
        bottom: -28px;
        right: 0;
        width: 48%;
        aspect-ratio: 1;
        object-fit: cover;
        border-radius: var(--r);
        border: 5px solid var(--ivory);
        box-shadow: var(--sh2)
    }

    .ai-years {
        position: absolute;
        top: 32px;
        right: 12%;
        background: var(--dusk);
        color: #fff;
        border-radius: var(--r);
        padding: 18px 20px;
        text-align: center;
        box-shadow: var(--sh2)
    }

    .aiy-num {
        font-family: 'Alike Angular', serif;
        font-size: 2.2rem;
        display: block;
        line-height: 1
    }

    .aiy-lab {
        font-size: .58rem;
        font-weight: 700;
        letter-spacing: .18em;
        text-transform: uppercase;
        opacity: .85
    }

    .check-list {
        list-style: none;
        margin: 20px 0 28px;
        display: flex;
        flex-direction: column;
        gap: 10px
    }

    .cl-i {
        display: flex;
        align-items: center;
        gap: 12px;
        font-size: .86rem;
        color: var(--txt2);
        font-weight: 600
    }

    .cl-c {
        width: 22px;
        height: 22px;
        border-radius: 50%;
        flex-shrink: 0;
        background: var(--mara);
        color: #fff;
        display: flex;
        align-items: center;
        justify-content: center;
        font-size: .7rem;
        font-weight: 800
    }

    /* AMENITIES */
    #amenities {
        background: var(--stone)
    }

    .am-bento {
        display: grid;
        grid-template-columns: repeat(4, 1fr);
        gap: 14px;
        margin-top: 52px
    }

    .am-cell {
        background: var(--white);
        border-radius: var(--r2);
        padding: 28px 22px;
        border: 1.5px solid var(--stone2);
        transition: all .3s;
        cursor: default
    }

    .am-cell:hover {
        background: var(--dusk);
        border-color: var(--dusk);
        transform: translateY(-5px);
        box-shadow: var(--sh2)
    }

    .am-cell:hover .am-icon,
    .am-cell:hover .am-name,
    .am-cell:hover .am-desc {
        color: #fff !important
    }

    .am-wide {
        grid-column: span 2
    }

    .am-icon {
        font-size: 1.8rem;
        margin-bottom: 12px;
        color: var(--dusk);
        transition: color .3s
    }

    .am-name {
        font-family: 'Alike Angular', serif;
        font-size: 1rem;
        color: var(--txt);
        margin-bottom: 6px;
        transition: color .3s
    }

    .am-desc {
        font-size: .75rem;
        line-height: 1.7;
        color: var(--txt2);
        transition: color .3s
    }

    /* TRIP PLANNER */
    #planner {
        background: linear-gradient(135deg, var(--mara) 0%, var(--mara2) 100%);
        padding: 80px 64px;
        position: relative;
        overflow: hidden
    }

    #planner::before {
        content: '🦓🦒🐘🦁🐆';
        position: absolute;
        right: -20px;
        top: 50%;
        transform: translateY(-50%);
        font-size: 6rem;
        opacity: .08;
        letter-spacing: 10px;
        white-space: nowrap;
        pointer-events: none
    }

    .planner-wrap {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 64px;
        align-items: center
    }

    .planner-left {
        color: #fff
    }

    .pl-tag {
        display: inline-flex;
        align-items: center;
        gap: 8px;
        background: rgba(255, 255, 255, .15);
        border-radius: 99px;
        padding: 6px 16px;
        font-size: .65rem;
        font-weight: 800;
        letter-spacing: .14em;
        text-transform: uppercase;
        color: rgba(255, 255, 255, .9);
        margin-bottom: 16px
    }

    .pl-h {
        font-family: 'Alike Angular', serif;
        font-size: clamp(1.8rem, 3vw, 2.6rem);
        line-height: 1.15;
        margin-bottom: 14px
    }

    .pl-h span {
        color: var(--savanna)
    }

    .pl-p {
        font-size: .9rem;
        line-height: 1.85;
        opacity: .85;
        margin-bottom: 28px;
        font-weight: 400
    }

    .pl-steps {
        display: flex;
        flex-direction: column;
        gap: 16px
    }

    .pl-step {
        display: flex;
        gap: 14px;
        align-items: flex-start
    }

    .ps-num {
        width: 28px;
        height: 28px;
        border-radius: 50%;
        flex-shrink: 0;
        background: var(--savanna);
        color: var(--earth2);
        display: flex;
        align-items: center;
        justify-content: center;
        font-size: .75rem;
        font-weight: 800
    }

    .ps-txt {
        font-size: .85rem;
        color: rgba(255, 255, 255, .85);
        line-height: 1.6;
        font-weight: 600
    }

    .ps-txt strong {
        color: #fff
    }

    .planner-form {
        background: rgba(255, 255, 255, .97);
        border-radius: var(--r2);
        padding: 36px 32px;
        box-shadow: var(--sh3)
    }

    .pf-title {
        font-family: 'Alike Angular', serif;
        font-size: 1.35rem;
        color: var(--txt);
        margin-bottom: 6px
    }

    .pf-sub {
        font-size: .78rem;
        color: var(--txt3);
        margin-bottom: 28px;
        font-weight: 600
    }

    .pf-field {
        margin-bottom: 16px
    }

    .pfl {
        display: block;
        font-size: .62rem;
        font-weight: 800;
        letter-spacing: .16em;
        text-transform: uppercase;
        color: var(--txt3);
        margin-bottom: 7px
    }

    .pfi,
    .pfsel {
        width: 100%;
        padding: 11px 14px;
        font-family: 'Nunito', sans-serif;
        font-size: .86rem;
        font-weight: 600;
        background: var(--stone);
        color: var(--txt);
        border: 1.5px solid var(--stone2);
        border-radius: 10px;
        outline: none;
        transition: border-color .25s, background .25s
    }

    .pfi:focus,
    .pfsel:focus {
        border-color: var(--dusk);
        background: #fff
    }

    .pfsel {
        appearance: none;
        cursor: pointer
    }

    .pf-row {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 12px
    }

    .pf-interests {
        display: flex;
        flex-wrap: wrap;
        gap: 8px;
        margin-bottom: 20px
    }

    .pi-tag {
        padding: 6px 14px;
        border-radius: 99px;
        font-size: .7rem;
        font-weight: 700;
        border: 1.5px solid var(--stone2);
        color: var(--txt2);
        cursor: pointer;
        transition: all .2s;
        background: var(--stone)
    }

    .pi-tag.sel,
    .pi-tag:hover {
        background: var(--dusk);
        border-color: var(--dusk);
        color: #fff
    }

    .pf-submit {
        width: 100%;
        padding: 14px;
        font-size: .78rem;
        font-weight: 800;
        background: linear-gradient(135deg, var(--dusk), var(--savanna));
        color: #fff;
        border: none;
        border-radius: 99px;
        cursor: pointer;
        box-shadow: 0 6px 20px rgba(232, 96, 42, .4);
        transition: all .28s
    }

    .pf-submit:hover {
        transform: translateY(-2px);
        box-shadow: 0 10px 28px rgba(232, 96, 42, .5)
    }

    .pf-submit.sent {
        background: linear-gradient(135deg, var(--mara), var(--mara2))
    }

    /* GALLERY */
    #gallery {
        background: var(--ivory);
        overflow: hidden
    }

    .gal-head {
        display: flex;
        justify-content: space-between;
        align-items: flex-end;
        margin-bottom: 32px;
        flex-wrap: wrap;
        gap: 14px
    }

    .gal-mosaic {
        display: grid;
        grid-template-columns: repeat(12, 1fr);
        grid-auto-rows: 55px;
        gap: 10px
    }

    .gm {
        overflow: hidden;
        border-radius: var(--r);
        position: relative;
        cursor: pointer
    }

    .gm img {
        width: 100%;
        height: 100%;
        object-fit: cover;
        transition: transform .5s, filter .3s;
        filter: brightness(.9)
    }

    .gm:hover img {
        transform: scale(1.08);
        filter: brightness(1.05)
    }

    .gm::after {
        content: '🔍';
        position: absolute;
        inset: 0;
        display: flex;
        align-items: center;
        justify-content: center;
        font-size: 1.4rem;
        background: rgba(26, 15, 0, .3);
        opacity: 0;
        transition: opacity .3s;
        border-radius: var(--r)
    }

    .gm:hover::after {
        opacity: 1
    }

    .gm1 {
        grid-column: span 5;
        grid-row: span 6
    }

    .gm2 {
        grid-column: span 4;
        grid-row: span 3
    }

    .gm3 {
        grid-column: span 3;
        grid-row: span 3
    }

    .gm4 {
        grid-column: span 3;
        grid-row: span 3
    }

    .gm5 {
        grid-column: span 4;
        grid-row: span 3
    }

    .gm6 {
        grid-column: span 5;
        grid-row: span 5
    }

    /* EXPERIENCES */
    #exp {
        background: var(--stone)
    }

    .exp-tabs-wrap {
        display: grid;
        grid-template-columns: 280px 1fr;
        gap: 32px;
        margin-top: 48px
    }

    .exp-tab-list {
        display: flex;
        flex-direction: column;
        gap: 4px
    }

    .exp-tab {
        padding: 18px 20px;
        border-radius: var(--r);
        border-left: 3px solid var(--stone2);
        cursor: pointer;
        transition: all .25s;
        background: transparent;
        text-align: left;
        font-family: 'Nunito', sans-serif;
        width: 100%
    }

    .exp-tab.active {
        border-left-color: var(--dusk);
        background: var(--white);
        box-shadow: var(--sh1)
    }

    .exp-tab:hover:not(.active) {
        border-left-color: var(--txt3);
        background: rgba(255, 255, 255, .5)
    }

    .et-num {
        font-size: .6rem;
        font-weight: 800;
        letter-spacing: .16em;
        text-transform: uppercase;
        color: var(--txt3);
        margin-bottom: 4px
    }

    .et-icon {
        font-size: 1.3rem;
        margin-bottom: 4px
    }

    .et-title {
        font-family: 'Alike Angular', serif;
        font-size: 1rem;
        color: var(--txt);
        margin-bottom: 2px
    }

    .et-sub {
        font-size: .72rem;
        color: var(--txt3);
        font-weight: 600
    }

    .exp-panel {
        display: none
    }

    .exp-panel.active {
        display: block
    }

    .ep-img {
        width: 100%;
        aspect-ratio: 16/9;
        object-fit: cover;
        border-radius: var(--r2);
        margin-bottom: 24px;
        box-shadow: var(--sh2)
    }

    .ep-h {
        font-family: 'Alike Angular', serif;
        font-size: 1.7rem;
        color: var(--txt);
        margin-bottom: 12px
    }

    .ep-p {
        font-size: .9rem;
        line-height: 1.85;
        color: var(--txt2);
        margin-bottom: 20px;
        font-weight: 400
    }

    .ep-details {
        display: flex;
        gap: 16px;
        flex-wrap: wrap;
        margin-bottom: 20px
    }

    .epd {
        background: var(--white);
        border-radius: 10px;
        padding: 10px 16px;
        display: flex;
        gap: 8px;
        align-items: center;
        font-size: .78rem;
        font-weight: 700;
        color: var(--txt2);
        box-shadow: var(--sh1)
    }

    .epd-icon {
        font-size: 1rem
    }

    .ep-cta {
        padding: 12px 32px;
        font-size: .75rem;
        font-weight: 800;
        background: var(--dusk);
        color: #fff;
        border: none;
        border-radius: 99px;
        cursor: pointer;
        transition: all .25s
    }

    .ep-cta:hover {
        background: var(--savanna);
        color: var(--txt);
        transform: translateY(-2px)
    }

    /* TESTIMONIALS */
    #testimonials {
        background: linear-gradient(160deg, #FFF3E0, var(--sky2))
    }

    .test-grid {
        display: grid;
        grid-template-columns: repeat(3, 1fr);
        gap: 20px;
        margin-top: 52px
    }

    .tc {
        background: var(--white);
        border-radius: var(--r2);
        padding: 28px 24px;
        border: 1.5px solid var(--stone2);
        box-shadow: var(--sh1);
        transition: transform .3s, box-shadow .3s
    }

    .tc:hover {
        transform: translateY(-6px);
        box-shadow: var(--sh2)
    }

    .tc-hot {
        background: linear-gradient(135deg, var(--dusk), var(--savanna));
        border-color: transparent
    }

    .tc-hot .tc-text,
    .tc-hot .tc-name {
        color: #fff
    }

    .tc-hot .tc-divider {
        background: rgba(255, 255, 255, .25)
    }

    .tc-hot .tc-src {
        color: rgba(255, 255, 255, .7)
    }

    .tc-stars {
        font-size: .85rem;
        color: var(--savanna);
        margin-bottom: 12px
    }

    .tc-text {
        font-family: 'Alike Angular', serif;
        font-size: .98rem;
        font-style: italic;
        line-height: 1.7;
        color: var(--txt);
        margin-bottom: 16px
    }

    .tc-divider {
        height: 1px;
        background: var(--stone2);
        margin-bottom: 12px
    }

    .tc-name {
        font-size: .74rem;
        font-weight: 800;
        color: var(--dusk)
    }

    .tc-src {
        font-size: .64rem;
        color: var(--txt3);
        font-weight: 600;
        margin-top: 2px
    }

    /* LOYALTY */
    #loyalty {
        background: linear-gradient(135deg, var(--earth2), #3D1A00);
        padding: 80px 64px;
        color: #fff;
        position: relative;
        overflow: hidden
    }

    #loyalty::after {
        content: '';
        position: absolute;
        inset: 0;
        pointer-events: none;
        background: radial-gradient(ellipse 60% 80% at 80% 50%, rgba(245, 166, 35, .15), transparent)
    }

    .loyalty-wrap {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 64px;
        align-items: center;
        position: relative;
        z-index: 1
    }

    .loy-left .sec-tag {
        background: rgba(255, 255, 255, .12);
        color: var(--savanna)
    }

    .loy-h {
        font-family: 'Alike Angular', serif;
        font-size: clamp(1.8rem, 3vw, 2.6rem);
        line-height: 1.15;
        margin-bottom: 14px
    }

    .loy-h span {
        color: var(--savanna)
    }

    .loy-p {
        font-size: .9rem;
        line-height: 1.85;
        opacity: .8;
        margin-bottom: 32px;
        max-width: 460px
    }

    .loy-tiers {
        display: flex;
        flex-direction: column;
        gap: 14px
    }

    .loy-tier {
        display: flex;
        align-items: center;
        gap: 16px;
        background: rgba(255, 255, 255, .08);
        border-radius: var(--r);
        padding: 16px 20px;
        border: 1px solid rgba(255, 255, 255, .1);
        transition: all .25s
    }

    .loy-tier:hover {
        background: rgba(245, 166, 35, .2);
        border-color: rgba(245, 166, 35, .4);
        transform: translateX(6px)
    }

    .lt-badge {
        width: 40px;
        height: 40px;
        border-radius: 50%;
        display: flex;
        align-items: center;
        justify-content: center;
        font-size: 1.2rem;
        flex-shrink: 0
    }

    .lt-b1 {
        background: rgba(176, 128, 96, .3)
    }

    .lt-b2 {
        background: rgba(192, 192, 192, .2)
    }

    .lt-b3 {
        background: rgba(245, 166, 35, .25)
    }

    .lt-name {
        font-size: .85rem;
        font-weight: 800;
        margin-bottom: 2px
    }

    .lt-desc {
        font-size: .72rem;
        opacity: .7;
        font-weight: 400
    }

    .loy-form {
        background: rgba(255, 255, 255, .08);
        border-radius: var(--r2);
        padding: 32px 28px;
        border: 1px solid rgba(255, 255, 255, .12)
    }

    .lf-h {
        font-family: 'Alike Angular', serif;
        font-size: 1.3rem;
        margin-bottom: 6px
    }

    .lf-sub {
        font-size: .78rem;
        opacity: .7;
        margin-bottom: 24px;
        font-weight: 400
    }

    .lf-input {
        width: 100%;
        margin-bottom: 12px;
        padding: 12px 16px;
        font-family: 'Nunito', sans-serif;
        font-size: .86rem;
        background: rgba(255, 255, 255, .1);
        color: #fff;
        border: 1.5px solid rgba(255, 255, 255, .2);
        border-radius: 10px;
        outline: none;
        transition: border-color .25s
    }

    .lf-input::placeholder {
        color: rgba(255, 255, 255, .4)
    }

    .lf-input:focus {
        border-color: var(--savanna)
    }

    .lf-submit {
        width: 100%;
        padding: 13px;
        font-size: .76rem;
        font-weight: 800;
        background: linear-gradient(135deg, var(--savanna), var(--dusk));
        color: #fff;
        border: none;
        border-radius: 99px;
        cursor: pointer;
        box-shadow: 0 4px 16px rgba(245, 166, 35, .4);
        transition: all .25s
    }

    .lf-submit:hover {
        transform: translateY(-2px);
        box-shadow: 0 8px 22px rgba(245, 166, 35, .5)
    }

    /* BOOKING */
    #booking {
        background: var(--ivory)
    }

    .booking-wrap {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 64px;
        align-items: start
    }

    .contact-list {
        display: flex;
        flex-direction: column;
        gap: 12px;
        margin-top: 28px
    }

    .cl-card {
        display: flex;
        align-items: center;
        gap: 14px;
        background: var(--white);
        border-radius: var(--r);
        padding: 14px 18px;
        border: 1.5px solid var(--stone2);
        box-shadow: var(--sh1);
        transition: transform .2s
    }

    .cl-card:hover {
        transform: translateX(6px)
    }

    .cl-icon {
        width: 40px;
        height: 40px;
        border-radius: 12px;
        display: flex;
        align-items: center;
        justify-content: center;
        font-size: 1.1rem;
        flex-shrink: 0
    }

    .cli1 {
        background: #FFF3E0
    }

    .cli2 {
        background: #E8F5E9
    }

    .cli3 {
        background: #E3F2FD
    }

    .cli4 {
        background: #FCE4EC
    }

    .cli5 {
        background: #F3E5F5
    }

    .cl-lbl {
        font-size: .6rem;
        font-weight: 800;
        letter-spacing: .14em;
        text-transform: uppercase;
        color: var(--txt3);
        margin-bottom: 2px
    }

    .cl-val {
        font-size: .87rem;
        font-weight: 700;
        color: var(--txt)
    }

    .bk-form {
        background: var(--white);
        border-radius: var(--r2);
        padding: 36px 32px;
        border: 1.5px solid var(--stone2);
        box-shadow: var(--sh2)
    }

    .bkf-h {
        font-family: 'Alike Angular', serif;
        font-size: 1.45rem;
        color: var(--txt);
        margin-bottom: 5px
    }

    .bkf-sub {
        font-size: .78rem;
        color: var(--txt3);
        font-weight: 600;
        margin-bottom: 28px
    }

    .ff {
        margin-bottom: 16px
    }

    .fl2 {
        display: block;
        font-size: .6rem;
        font-weight: 800;
        letter-spacing: .16em;
        text-transform: uppercase;
        color: var(--txt3);
        margin-bottom: 6px
    }

    .fi2,
    .fsel2 {
        width: 100%;
        padding: 11px 14px;
        font-family: 'Nunito', sans-serif;
        font-size: .86rem;
        font-weight: 600;
        background: var(--stone);
        color: var(--txt);
        border: 1.5px solid var(--stone2);
        border-radius: 10px;
        outline: none;
        transition: border-color .25s, background .25s
    }

    .fi2:focus,
    .fsel2:focus {
        border-color: var(--dusk);
        background: #fff
    }

    .fsel2 {
        appearance: none;
        cursor: pointer
    }

    .ff-row {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 12px
    }

    .bk-submit {
        width: 100%;
        margin-top: 6px;
        padding: 14px;
        font-size: .8rem;
        font-weight: 800;
        background: linear-gradient(135deg, var(--dusk), var(--savanna));
        color: #fff;
        border: none;
        border-radius: 99px;
        cursor: pointer;
        box-shadow: 0 6px 20px rgba(232, 96, 42, .4);
        transition: all .28s
    }

    .bk-submit:hover {
        transform: translateY(-2px);
        box-shadow: 0 10px 28px rgba(232, 96, 42, .5)
    }

    .bk-submit.sent {
        background: linear-gradient(135deg, var(--mara), var(--mara2))
    }

    /* NEWSLETTER */
    #newsletter {
        background: linear-gradient(135deg, var(--savanna), var(--dusk));
        padding: 72px 64px;
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 40px;
        flex-wrap: wrap
    }

    .nl-left {
        color: #fff;
        flex: 1;
        min-width: 260px
    }

    .nl-title {
        font-family: 'Alike Angular', serif;
        font-size: clamp(1.5rem, 3vw, 2.2rem);
        margin-bottom: 10px
    }

    .nl-sub {
        font-size: .9rem;
        opacity: .85;
        max-width: 420px;
        line-height: 1.7;
        font-weight: 400
    }

    .nl-form {
        display: flex;
        gap: 10px;
        flex: 1;
        min-width: 280px;
        max-width: 480px
    }

    .nl-input {
        flex: 1;
        padding: 14px 18px;
        font-family: 'Nunito', sans-serif;
        font-size: .88rem;
        background: rgba(255, 255, 255, .95);
        color: var(--txt);
        border: none;
        border-radius: 99px;
        outline: none
    }

    .nl-btn {
        padding: 14px 28px;
        font-size: .76rem;
        font-weight: 800;
        background: var(--earth2);
        color: #fff;
        border: none;
        border-radius: 99px;
        cursor: pointer;
        white-space: nowrap;
        transition: all .25s
    }

    .nl-btn:hover {
        background: #2a0d00;
        transform: translateY(-2px)
    }

    /* MAP */
    #mapwrap {
        margin: 0 64px 72px;
        border-radius: var(--r2);
        overflow: hidden;
        box-shadow: var(--sh3)
    }

    #mapwrap iframe {
        width: 100%;
        height: 420px;
        border: none;
        display: block
    }

    /* FOOTER */
    footer {
        background: var(--earth2);
        color: rgba(255, 255, 255, .8);
        padding: 72px 64px 32px
    }

    .ft-grid {
        display: grid;
        grid-template-columns: 2fr 1fr 1fr 1fr;
        gap: 48px;
        margin-bottom: 52px
    }

    .ft-brand {
        font-family: 'Alike Angular', serif;
        font-size: 1.5rem;
        color: var(--savanna);
        margin-bottom: 4px
    }

    .ft-sub {
        font-size: .6rem;
        font-weight: 700;
        letter-spacing: .2em;
        text-transform: uppercase;
        color: var(--txt3);
        margin-bottom: 14px
    }

    .ft-desc {
        font-size: .8rem;
        line-height: 1.8;
        color: rgba(255, 255, 255, .55);
        max-width: 260px
    }

    .ft-col-h {
        font-size: .62rem;
        font-weight: 800;
        letter-spacing: .2em;
        text-transform: uppercase;
        color: rgba(255, 255, 255, .35);
        margin-bottom: 16px
    }

    .ft-links {
        list-style: none;
        display: flex;
        flex-direction: column;
        gap: 10px
    }

    .ft-links a {
        font-size: .8rem;
        color: rgba(255, 255, 255, .6);
        transition: color .2s;
        font-weight: 600
    }

    .ft-links a:hover {
        color: var(--savanna)
    }

    .ft-bottom {
        display: flex;
        justify-content: space-between;
        align-items: center;
        padding-top: 28px;
        border-top: 1px solid rgba(255, 255, 255, .08);
        font-size: .72rem;
        color: rgba(255, 255, 255, .3);
        flex-wrap: wrap;
        gap: 12px
    }

    .ft-social {
        display: flex;
        gap: 10px
    }

    .ft-social a {
        width: 34px;
        height: 34px;
        border-radius: 50%;
        border: 1px solid rgba(255, 255, 255, .12);
        display: flex;
        align-items: center;
        justify-content: center;
        font-size: .8rem;
        color: rgba(255, 255, 255, .45);
        transition: all .25s
    }

    .ft-social a:hover {
        border-color: var(--savanna);
        color: var(--savanna)
    }

    /* DARK MODE */
    body.dark {
        background: var(--night);
        color: rgba(255, 240, 214, .9)
    }

    body.dark #nav {
        background: rgba(20, 10, 0, .96);
        border-color: rgba(255, 255, 255, .07)
    }

    body.dark .sec {
        background: #160b00
    }

    body.dark #wildlife {
        background: #1c1000
    }

    body.dark #amenities,
    body.dark #about {
        background: #1c1000
    }

    body.dark #testimonials {
        background: linear-gradient(160deg, #2a1400, #1a1000)
    }

    body.dark .rc,
    body.dark .wl-card,
    body.dark .am-cell,
    body.dark .tc,
    body.dark .cl-card,
    body.dark .bk-form {
        background: #241400;
        border-color: rgba(255, 255, 255, .07)
    }

    body.dark .sec-h,
    body.dark .rc-name,
    body.dark .wl-name,
    body.dark .am-name,
    body.dark .tc-text {
        color: #ffe4b8
    }

    body.dark .sec-p,
    body.dark .rc-desc,
    body.dark .wl-desc,
    body.dark .am-desc {
        color: rgba(255, 220, 160, .6)
    }

    body.dark .rc-chip {
        background: #3a2000;
        color: rgba(255, 220, 160, .7)
    }

    body.dark .sec-tag {
        background: #3a2000;
        color: var(--savanna)
    }

    body.dark .fi2,
    body.dark .fsel2,
    body.dark .pfi,
    body.dark .pfsel {
        background: #3a2000;
        border-color: rgba(255, 255, 255, .1);
        color: #ffe4b8
    }

    body.dark footer {
        background: #0d0600
    }

    body.dark #mapwrap iframe {
        filter: invert(90%) hue-rotate(180deg) brightness(.8) saturate(.9)
    }

    body.dark .hero-quickbook {
        background: rgba(30, 15, 0, .97);
        border-color: rgba(255, 200, 80, .15)
    }

    body.dark .qb-label,
    body.dark .qb-input,
    body.dark .qb-select {
        color: rgba(255, 220, 160, .7)
    }

    body.dark .nb-main {
        color: var(--savanna)
    }

    body.dark .nav-links a {
        color: rgba(255, 220, 160, .6)
    }

    body.dark .mob-menu {
        background: #1c1000
    }

    body.dark .mob-menu a {
        color: #ffe4b8;
        border-color: rgba(255, 255, 255, .08)
    }

    body.dark .mob-menu a:hover {
        background: #241400;
        color: var(--savanna)
    }

    body.dark .mob-x {
        color: var(--savanna)
    }

    /* MOBILE MENU */
    .mob-menu {
        position: fixed;
        inset: 0;
        z-index: 800;
        background: var(--ivory);
        display: none;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        gap: 0;
        padding: 0;
        overflow: hidden;
    }

    .mob-menu.open {
        display: flex
    }

    .mob-menu a {
        font-family: 'Alike Angular', serif;
        font-size: 1.75rem;
        color: var(--txt);
        transition: color .2s;
        text-align: center;
        width: 100%;
        padding: 14px 24px;
        display: block;
        border-bottom: 1px solid var(--stone2);
        line-height: 1.3;
    }

    .mob-menu a:first-of-type {
        border-top: 1px solid var(--stone2);
        margin-top: 72px
    }

    .mob-menu a:hover {
        color: var(--dusk);
        background: var(--stone)
    }

    .mob-x {
        position: absolute;
        top: 0;
        right: 0;
        width: 64px;
        height: 64px;
        background: none;
        border: none;
        font-size: 1.4rem;
        cursor: pointer;
        color: var(--txt);
        display: flex;
        align-items: center;
        justify-content: center;
        z-index: 10;
    }

    /* ── SMALL SCREEN NAV (≤480px): hide weather, shrink pill ── */
    @media(max-width:480px) {
        .nav-weather {
            display: none;
        }

        .book-pill {
            padding: 7px 14px;
            font-size: .68rem;
        }

        .nb-sub {
            display: none;
        }

        .nb-main {
            font-size: .95rem;
        }

        #nav {
            padding: 0 14px;
            gap: 8px;
            height: 60px;
        }

        .nav-paw {
            font-size: 1.3rem;
        }
    }

    /* ═══════════════════════════════════════════
       COMPREHENSIVE MOBILE RESPONSIVE FIXES
    ═══════════════════════════════════════════ */

    /* ── TABLET BREAKPOINT 1100px ── */
    @media(max-width:1100px) {
        #nav {
            padding: 0 20px;
            height: 68px;
            gap: 10px;
        }

        .nav-links {
            display: none;
        }

        .ham {
            display: flex;
        }

        .nav-weather {
            padding: 5px 12px;
            font-size: .68rem;
        }

        .book-pill {
            padding: 8px 18px;
            font-size: .7rem;
        }

        .nb-main {
            font-size: 1.05rem;
        }

        .nb-sub {
            font-size: .54rem;
            letter-spacing: .16em;
        }

        .sec {
            padding: 68px 28px;
        }

        .sec-p {
            max-width: 100%;
        }

        .hero-quickbook {
            margin: 0 20px;
            transform: none;
        }

        .big5-strip {
            margin: 16px 20px 0;
        }

        .wl-grid {
            grid-template-columns: 1fr 1fr 1fr;
        }

        .rooms-grid {
            grid-template-columns: 1fr 1fr;
            gap: 16px;
        }

        .rooms-top {
            flex-direction: column;
            align-items: flex-start;
            gap: 14px;
        }

        .about-grid {
            grid-template-columns: 1fr;
            gap: 36px;
        }

        .ai-accent,
        .ai-years {
            display: none;
        }

        .ai-main {
            width: 100%;
            aspect-ratio: 16/10;
        }

        .am-bento {
            grid-template-columns: 1fr 1fr;
            gap: 12px;
            margin-top: 36px;
        }

        .am-wide {
            grid-column: span 2;
        }

        #planner {
            padding: 60px 28px;
        }

        .planner-wrap {
            grid-template-columns: 1fr;
            gap: 36px;
        }

        .booking-wrap {
            grid-template-columns: 1fr;
            gap: 36px;
        }

        .loyalty-wrap {
            grid-template-columns: 1fr;
            gap: 36px;
        }

        #loyalty {
            padding: 60px 28px;
        }

        .test-grid {
            grid-template-columns: 1fr 1fr;
            gap: 16px;
        }

        .exp-tabs-wrap {
            grid-template-columns: 1fr;
            gap: 20px;
        }

        .ft-grid {
            grid-template-columns: 1fr 1fr;
            gap: 32px;
            margin-bottom: 36px;
        }

        footer {
            padding: 52px 28px 24px;
        }

        #mapwrap {
            margin: 0 28px 52px;
        }

        #newsletter {
            padding: 52px 28px;
        }
    }

    /* ── MOBILE BREAKPOINT 768px ── */
    @media(max-width:768px) {

        /* Alert bar */
        .alert-bar {
            font-size: .68rem;
            padding: 8px 40px 8px 10px;
            gap: 5px;
            justify-content: center;
            text-align: center;
            flex-wrap: wrap;
            line-height: 1.5;
        }

        .ab-pulse {
            width: 6px;
            height: 6px;
            flex-shrink: 0;
        }

        .ab-close {
            right: 6px;
            font-size: .9rem;
        }

        #hero {
            min-height: 88vh;
        }

        .hero-content {
            padding: 0 20px 80px;
            max-width: 100%;
        }

        .hero-h1 {
            font-size: clamp(2.2rem, 9vw, 3.4rem);
            margin-bottom: 14px;
        }

        .hero-sub {
            font-size: .9rem;
            margin-bottom: 22px;
            max-width: 100%;
        }

        .hero-eyebrow {
            font-size: .62rem;
            padding: 6px 14px;
            margin-bottom: 18px;
        }

        .hero-actions {
            flex-direction: column;
            gap: 10px;
            margin-bottom: 24px;
        }

        .ha-wh,
        .ha-ghost {
            width: 100%;
            text-align: center;
            padding: 13px 20px;
            font-size: .78rem;
            border-radius: 99px;
        }

        .hero-gradient {
            background: linear-gradient(to bottom, rgba(26, 15, 0, .2) 0%, rgba(26, 15, 0, .05) 30%, rgba(26, 15, 0, .65) 72%, rgba(26, 15, 0, .95) 100%);
        }

        .grass {
            height: 80px;
        }

        /* Quick book bar */
        .hero-quickbook {
            margin: 0 14px;
            padding: 16px 18px;
            flex-direction: column;
            gap: 0;
            transform: none;
            border-radius: 14px;
        }

        .qb-field {
            min-width: 100%;
            padding: 12px 0;
            border-bottom: 1px solid var(--stone2);
            border-right: none;
        }

        .qb-divider {
            display: none;
        }

        .qb-btn {
            width: 100%;
            margin-top: 14px;
            padding: 13px;
            font-size: .78rem;
            border-radius: 99px;
        }

        .qb-input,
        .qb-select {
            font-size: .85rem;
        }

        /* Big 5 */
        .big5-strip {
            margin: 12px 14px 0;
            padding: 18px 18px;
            flex-direction: column;
            gap: 14px;
            border-radius: 14px;
        }

        .b5-title {
            font-size: .9rem;
            text-align: center;
            white-space: normal;
        }

        .b5-animals {
            justify-content: center;
            gap: 14px;
        }

        .b5-emoji {
            font-size: 1.6rem;
        }

        .b5-name {
            font-size: .54rem;
        }

        .b5-badge {
            font-size: .5rem;
            padding: 2px 7px;
        }

        /* Sections */
        .sec {
            padding: 52px 16px;
        }

        .sec-h {
            font-size: clamp(1.55rem, 6vw, 2.2rem);
        }

        .sec-p {
            font-size: .87rem;
        }

        /* Wildlife */
        .wl-grid {
            grid-template-columns: 1fr;
            gap: 14px;
            margin-top: 32px;
        }

        .wl-img {
            aspect-ratio: 4/3;
        }

        .wl-name {
            font-size: 1.1rem;
        }

        .wl-desc {
            font-size: .73rem;
        }

        /* Rooms */
        .rooms-grid {
            grid-template-columns: 1fr;
            gap: 14px;
        }

        .rc-name {
            font-size: 1.1rem;
        }

        .rc-price {
            font-size: 1.15rem;
        }

        .rc-foot {
            flex-direction: row;
        }

        /* About */
        .about-grid {
            grid-template-columns: 1fr;
            gap: 28px;
        }

        /* Amenities */
        .am-bento {
            grid-template-columns: 1fr 1fr;
            gap: 10px;
            margin-top: 28px;
        }

        .am-wide {
            grid-column: span 2;
        }

        .am-cell {
            padding: 20px 16px;
        }

        .am-icon {
            font-size: 1.5rem;
            margin-bottom: 10px;
        }

        .am-name {
            font-size: .88rem;
        }

        .am-desc {
            font-size: .71rem;
        }

        /* Trip planner */
        #planner {
            padding: 52px 16px;
        }

        .planner-wrap {
            grid-template-columns: 1fr;
            gap: 30px;
        }

        .pl-h {
            font-size: clamp(1.5rem, 5vw, 2rem);
        }

        .pf-row {
            grid-template-columns: 1fr;
            gap: 0;
        }

        .pf-interests {
            gap: 7px;
        }

        .pi-tag {
            font-size: .67rem;
            padding: 5px 11px;
        }

        .planner-form {
            padding: 26px 20px;
        }

        /* Gallery */
        .gal-mosaic {
            grid-template-columns: 1fr 1fr;
            grid-auto-rows: 88px;
            gap: 7px;
        }

        .gm1,
        .gm2,
        .gm3,
        .gm4,
        .gm5,
        .gm6 {
            grid-column: span 1;
            grid-row: span 2;
        }

        .gal-head {
            flex-direction: column;
            gap: 8px;
            margin-bottom: 18px;
        }

        /* Experiences — horizontal scroll tabs */
        .exp-tabs-wrap {
            grid-template-columns: 1fr;
            gap: 16px;
        }

        .exp-tab-list {
            flex-direction: row;
            overflow-x: auto;
            gap: 8px;
            padding-bottom: 8px;
            scrollbar-width: none;
            -ms-overflow-style: none;
        }

        .exp-tab-list::-webkit-scrollbar {
            display: none;
        }

        .exp-tab {
            flex-shrink: 0;
            min-width: 110px;
            border-left: none;
            border-bottom: 3px solid var(--stone2);
            border-radius: 10px 10px 0 0;
            padding: 10px 14px;
            background: rgba(255, 255, 255, .5);
        }

        .exp-tab.active {
            border-left: none;
            border-bottom-color: var(--dusk);
            background: var(--white);
        }

        .et-num {
            font-size: .54rem;
        }

        .et-icon {
            font-size: 1.05rem;
        }

        .et-title {
            font-size: .8rem;
        }

        .et-sub {
            font-size: .62rem;
        }

        .ep-h {
            font-size: 1.3rem;
        }

        .ep-p {
            font-size: .85rem;
        }

        .ep-details {
            gap: 8px;
        }

        .epd {
            padding: 8px 12px;
            font-size: .71rem;
        }

        /* Testimonials */
        .test-grid {
            grid-template-columns: 1fr;
            gap: 14px;
            margin-top: 30px;
        }

        /* Loyalty */
        #loyalty {
            padding: 52px 16px;
        }

        .loyalty-wrap {
            grid-template-columns: 1fr;
            gap: 30px;
        }

        .loy-h {
            font-size: clamp(1.5rem, 5vw, 2rem);
        }

        .loy-p {
            font-size: .85rem;
            margin-bottom: 22px;
        }

        .loy-tier {
            padding: 12px 14px;
        }

        .lt-name {
            font-size: .82rem;
        }

        .lt-desc {
            font-size: .67rem;
        }

        .loy-form {
            padding: 24px 20px;
        }

        /* Booking */
        .booking-wrap {
            grid-template-columns: 1fr;
            gap: 28px;
        }

        .contact-list {
            gap: 9px;
        }

        .cl-card {
            padding: 11px 13px;
        }

        .cl-val {
            font-size: .82rem;
        }

        .bk-form {
            padding: 24px 18px;
        }

        .ff-row {
            grid-template-columns: 1fr;
            gap: 0;
        }

        .bkf-h {
            font-size: 1.2rem;
        }

        /* Newsletter */
        #newsletter {
            padding: 44px 16px;
            flex-direction: column;
            gap: 24px;
        }

        .nl-title {
            font-size: clamp(1.25rem, 5vw, 1.7rem);
        }

        .nl-sub {
            font-size: .83rem;
        }

        .nl-form {
            flex-direction: column;
            gap: 10px;
            max-width: 100%;
        }

        .nl-input,
        .nl-btn {
            border-radius: 99px;
            width: 100%;
        }

        /* Map */
        #mapwrap {
            margin: 0 14px 44px;
            border-radius: 14px;
        }

        #mapwrap iframe {
            height: 260px;
        }

        /* Footer */
        footer {
            padding: 48px 16px 22px;
        }

        .ft-grid {
            grid-template-columns: 1fr 1fr;
            gap: 26px;
            margin-bottom: 30px;
        }

        .ft-brand {
            font-size: 1.15rem;
        }

        .ft-desc {
            font-size: .76rem;
            max-width: 100%;
        }

        .ft-bottom {
            padding-top: 20px;
        }

        /* Trust bar in hero */
        .hero-trust-row {
            gap: 10px !important;
        }

        .hero-trust-row>div {
            font-size: .7rem !important;
            gap: 5px !important;
        }
    }

    /* ── SMALL PHONE 480px ── */
    @media(max-width:480px) {
        .am-bento {
            grid-template-columns: 1fr;
        }

        .am-wide {
            grid-column: span 1;
        }

        .ft-grid {
            grid-template-columns: 1fr;
            gap: 22px;
        }

        .ft-bottom {
            flex-direction: column;
            align-items: center;
            text-align: center;
            gap: 12px;
        }

        .ft-social {
            justify-content: center;
        }

        .mob-menu a {
            font-size: 1.65rem;
        }

        .rc-chips {
            gap: 5px;
        }

        .rc-chip {
            font-size: .6rem;
            padding: 3px 9px;
        }

        .gal-mosaic {
            grid-template-columns: 1fr;
            grid-auto-rows: 160px;
        }

        .gm1,
        .gm2,
        .gm3,
        .gm4,
        .gm5,
        .gm6 {
            grid-column: span 1;
            grid-row: span 1;
        }
    }

    /* ── TOUCH TARGETS ── */
    @media(max-width:768px) {

        .ha-wh,
        .ha-ghost,
        .qb-btn,
        .book-pill,
        .bk-submit,
        .lf-submit,
        .pf-submit,
        .rc-btn,
        .ep-cta,
        .nl-btn {
            min-height: 44px;
        }

        .exp-tab {
            min-height: 44px;
        }

        .b5-animal {
            min-width: 48px;
            padding: 4px;
        }

        nav a,
        .mob-menu a {
            min-height: 44px;
            display: flex;
            align-items: center;
        }
    }