
/* self-hosted fonts */
@font-face{font-family:'Playfair Display';font-weight:600;font-display:optional;src:url('/fonts/playfairdisplay-600.woff2') format('woff2')}
@font-face{font-family:'Playfair Display';font-weight:700;font-display:optional;src:url('/fonts/playfairdisplay-700.woff2') format('woff2')}
@font-face{font-family:'Playfair Display';font-weight:800;font-display:optional;src:url('/fonts/playfairdisplay-800.woff2') format('woff2')}
@font-face{font-family:'DM Sans';font-weight:400;font-display:swap;src:url('/fonts/dmsans-400.woff2') format('woff2')}
@font-face{font-family:'DM Sans';font-weight:500;font-display:swap;src:url('/fonts/dmsans-500.woff2') format('woff2')}
@font-face{font-family:'DM Sans';font-weight:700;font-display:swap;src:url('/fonts/dmsans-700.woff2') format('woff2')}
img{max-width:100%;height:auto}
picture{display:contents}
.skip-link{position:absolute;left:-9999px;top:0;z-index:200;background:var(--terracotta,#C2704A);color:#fff;padding:.6rem 1rem;border-radius:0 0 6px 0}
.skip-link:focus{left:0}
.st-credit{font-family:'DM Sans',monospace;font-size:.75rem;letter-spacing:.02em;color:#fff;opacity:.6;text-decoration:none;transition:color .2s,opacity .2s}
.st-credit:hover{opacity:1;color:#BFFF00}
.st-wm{font-weight:700}.st-wm u{color:#BFFF00;text-decoration:none}

        *,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
        :root{
            --linen:#F5EDE4;--cream:#FBF7F2;--charcoal:#1E1B18;--espresso:#2D2926;--warm-brown:#4A3F37;
            --terracotta:#C2704A;--terracotta-deep:#A85C38;--burnt-sienna:#D4845A;
            --amber:#D4A24E;--amber-light:#E8C07A;
            --sage:#7A9472;--sage-muted:#94A88D;--sage-deep:#5C7B54;
            --dusty-rose:#C49B93;--mauve:#A8828A;
            --slate-warm:#8A7E76;--stone:#B8AEA3;--pebble:#D6CEC5;--taupe:#9E9288;
        }
        html{scroll-behavior:smooth;overflow-x:hidden;width:100%}
        body{font-family:'DM Sans',sans-serif;background:var(--cream);color:var(--charcoal);overflow-x:hidden;font-weight:400;line-height:1.7;-webkit-font-smoothing:antialiased}

        /* === NAV === */
        nav{position:fixed;top:0;left:0;right:0;z-index:1000;padding:1.5rem 3.5rem;display:flex;justify-content:space-between;align-items:center;transition:all .6s cubic-bezier(.16,1,.3,1)}
        nav.scrolled{background:rgba(251,247,242,.88);backdrop-filter:blur(24px) saturate(1.5);-webkit-backdrop-filter:blur(24px) saturate(1.5);padding:.9rem 3.5rem;box-shadow:0 1px 0 rgba(30,27,24,.05)}
        .nav-logo{font-family:'Playfair Display',serif;font-size:1.35rem;font-weight:600;color:var(--charcoal);text-decoration:none;display:flex;align-items:center}
        nav:not(.scrolled) .nav-logo img{filter:brightness(0) invert(1) drop-shadow(0 1px 3px rgba(0,0,0,.4))}
        .nav-links{display:flex;gap:2.2rem;align-items:center}
        .nav-links a{text-decoration:none;color:var(--charcoal);font-size:.82rem;font-weight:500;letter-spacing:.04em;text-transform:uppercase;transition:color .3s}
        nav:not(.scrolled) .nav-links a{color:rgba(255,255,255,.85)}
        nav:not(.scrolled) .nav-links a:hover{color:#fff}
        .nav-links a:hover{color:var(--terracotta)}
        .nav-book-btn{background:var(--terracotta-deep)!important;color:#fff!important;padding:.7rem 1.8rem;border-radius:8px;font-weight:500!important;transition:all .3s ease!important;box-shadow:0 2px 12px rgba(194,112,74,.25)}
        .nav-book-btn:hover{background:#8E4E2F!important;transform:translateY(-1px);box-shadow:0 6px 20px rgba(194,112,74,.35)}
        .mobile-toggle{display:none;flex-direction:column;gap:5px;cursor:pointer;z-index:1100;background:none;border:none;padding:4px}
        .mobile-toggle span{width:22px;height:2px;background:var(--charcoal);transition:all .3s;display:block}
        nav:not(.scrolled) .mobile-toggle span{background:#fff}

        /* === HERO === */
        .hero{position:relative;height:100vh;min-height:700px;display:flex;align-items:center;justify-content:center;overflow:hidden}
        .hero-img{position:absolute;inset:0}
        .hero-img img{width:100%;height:100%;object-fit:cover;object-position:center 40%}
        .hero-overlay{position:absolute;inset:0;background:radial-gradient(ellipse at center 50%,rgba(30,27,24,.65) 0%,rgba(30,27,24,.45) 50%,rgba(30,27,24,.3) 100%);z-index:1}
        .hero-content{position:relative;z-index:3;padding:2rem 4rem;max-width:850px;color:#fff;text-align:center}
        .hero-pill{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.12);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.15);padding:8px 18px;border-radius:100px;font-size:.72rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;margin-bottom:1.8rem;color:rgba(255,255,255,.95);animation:heroFade 1s ease .2s both}
        .hero-pill .dot{width:6px;height:6px;border-radius:50%;background:var(--amber);box-shadow:0 0 8px var(--amber)}
        .hero h1{font-family:'Playfair Display',serif;font-size:clamp(2.8rem,5.5vw,4.2rem);font-weight:500;line-height:1.12;margin-bottom:1.2rem;letter-spacing:-.02em;animation:heroFade 1s ease .4s both}
        .hero h1 .accent{color:var(--amber-light);font-style:italic}
        .hero-desc{font-size:1.05rem;color:rgba(255,255,255,.65);font-weight:300;max-width:520px;margin:0 auto;line-height:1.8;margin-bottom:2.5rem;animation:heroFade 1s ease .6s both}
        .hero-actions{display:flex;gap:1rem;align-items:center;justify-content:center;animation:heroFade 1s ease .8s both}
        .btn-primary{display:inline-flex;align-items:center;gap:10px;background:var(--terracotta-deep);color:#fff;padding:1rem 2.2rem;border-radius:10px;text-decoration:none;font-size:.88rem;font-weight:500;transition:all .4s ease;box-shadow:0 4px 20px rgba(194,112,74,.35)}
        .btn-primary:hover{background:#8E4E2F;transform:translateY(-2px);box-shadow:0 8px 30px rgba(194,112,74,.45)}
        .btn-ghost{display:inline-flex;align-items:center;gap:8px;color:rgba(255,255,255,.75);text-decoration:none;font-size:.85rem;padding:1rem 1.2rem;transition:color .3s}
        .btn-ghost:hover{color:#fff}
        @keyframes heroFade{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}

        /* === TRUST BAR === */
        .trust-bar{background:var(--espresso);padding:2rem 3.5rem;display:flex;justify-content:center;gap:4rem;flex-wrap:wrap}
        .trust-item{display:flex;align-items:center;gap:12px;color:rgba(255,255,255,.7);font-size:.85rem}
        .trust-icon{width:40px;height:40px;border-radius:10px;background:rgba(255,255,255,.06);display:flex;align-items:center;justify-content:center;font-size:1.1rem}
        .trust-value{font-family:'Playfair Display',serif;font-size:1.3rem;font-weight:600;color:#fff;display:block;line-height:1.2}
        .trust-label{font-size:.75rem;color:rgba(255,255,255,.72)}

        /* === SECTION LABEL === */
        .section-label{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--terracotta);font-weight:600;margin-bottom:1rem;display:flex;align-items:center;gap:12px}
        .section-label .line{width:32px;height:2px;background:var(--terracotta);border-radius:2px}

        /* === ABOUT === */
        .about{padding:8rem 3.5rem;max-width:1300px;margin:0 auto}
        .about-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:6rem;align-items:center}
        .about-images{position:relative;min-height:600px}
        .about-img-main{width:85%;aspect-ratio:3/4;border-radius:20px;overflow:hidden;box-shadow:0 30px 80px rgba(30,27,24,.15);position:relative;z-index:2}
        .about-img-main img{width:100%;height:100%;object-fit:cover}
        .about-img-accent{position:absolute;bottom:-1rem;right:0;width:55%;aspect-ratio:1;border-radius:20px;overflow:hidden;z-index:3;box-shadow:0 20px 60px rgba(30,27,24,.2);border:5px solid var(--cream)}
        .about-img-accent img{width:100%;height:100%;object-fit:cover}
        .about-decor{position:absolute;top:-2rem;right:3rem;width:140px;height:140px;border-radius:50%;background:var(--sage);opacity:.12;z-index:1}
        .about-text h2{font-family:'Playfair Display',serif;font-size:clamp(2.2rem,3.5vw,3rem);font-weight:500;line-height:1.18;margin-bottom:1.8rem}
        .about-text h2 .italic{font-style:italic;color:var(--sage-deep)}
        .about-text p{font-size:1rem;color:var(--slate-warm);line-height:1.9;margin-bottom:1.5rem}
        .about-highlights{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem;margin-top:2.5rem}
        .highlight-item{display:flex;align-items:center;gap:10px;padding:.9rem 1.2rem;background:var(--linen);border-radius:12px;font-size:.88rem;font-weight:500;color:var(--warm-brown);transition:all .3s}
        .highlight-item:hover{background:#fff;box-shadow:0 4px 20px rgba(30,27,24,.06);transform:translateY(-2px)}
        .highlight-item .hi-icon{width:32px;height:32px;border-radius:8px;background:#fff;display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0}
        .highlight-item:hover .hi-icon{background:var(--linen)}

        /* === GALLERY === */
        .gallery{padding:0 3.5rem 8rem;max-width:1300px;margin:0 auto}
        .gallery-header{text-align:center;margin-bottom:3.5rem}
        .gallery-header h2{font-family:'Playfair Display',serif;font-size:clamp(2rem,3.5vw,2.8rem);font-weight:500}
        .gallery-mosaic{display:grid;grid-template-columns:repeat(12,1fr);grid-template-rows:280px 280px;gap:1rem}
        .gal-item{border-radius:16px;overflow:hidden;position:relative;cursor:pointer}
        .gal-item img{width:100%;height:100%;object-fit:cover;transition:transform .7s cubic-bezier(.16,1,.3,1)}
        .gal-item:hover img{transform:scale(1.06)}
        .gal-item::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(30,27,24,.4) 0%,transparent 50%);opacity:0;transition:opacity .4s}
        .gal-item:hover::after{opacity:1}
        .gal-label{position:absolute;bottom:1.2rem;left:1.2rem;color:#fff;font-size:.82rem;font-weight:500;letter-spacing:.04em;z-index:2;opacity:0;transform:translateY(8px);transition:all .4s}
        .gal-item:hover .gal-label{opacity:1;transform:translateY(0)}
        .gal-item:nth-child(1){grid-column:1/8;grid-row:1/2}
        .gal-item:nth-child(2){grid-column:8/13;grid-row:1/2}
        .gal-item:nth-child(3){grid-column:1/5;grid-row:2/3}
        .gal-item:nth-child(4){grid-column:5/9;grid-row:2/3}
        .gal-item:nth-child(5){grid-column:9/13;grid-row:2/3}

        /* === AMENITIES === */
        .amenities{padding:7rem 3.5rem;background:var(--charcoal);position:relative;overflow:hidden}
        .amenities::before{content:'';position:absolute;top:-200px;right:-200px;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(194,112,74,.08),transparent 70%)}
        .amenities::after{content:'';position:absolute;bottom:-150px;left:-150px;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(122,148,114,.06),transparent 70%)}
        .amenities-inner{max-width:1300px;margin:0 auto;position:relative;z-index:2}
        .amenities-header{text-align:center;margin-bottom:4rem}
        .amenities-header .section-label{color:var(--amber);justify-content:center}
        .amenities-header .section-label .line{background:var(--amber)}
        .amenities-header h2{font-family:'Playfair Display',serif;font-size:clamp(2.2rem,3.5vw,3rem);font-weight:500;color:#fff;margin-bottom:1rem}
        .amenities-header p{color:rgba(255,255,255,.4);font-size:1rem;max-width:500px;margin:0 auto}
        .amenity-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}
        .amenity-card{padding:2rem;border-radius:18px;background:rgba(255,255,255,.035);border:1px solid rgba(255,255,255,.06);transition:all .4s cubic-bezier(.16,1,.3,1);position:relative;overflow:hidden}
        .amenity-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;border-radius:3px 3px 0 0;opacity:0;transition:opacity .4s}
        .amenity-card:hover::before{opacity:1}
        .amenity-card:hover{background:rgba(255,255,255,.07);transform:translateY(-6px);box-shadow:0 20px 50px rgba(0,0,0,.2);border-color:rgba(255,255,255,.1)}
        .amenity-card.accent-terra::before{background:linear-gradient(90deg,var(--terracotta),var(--burnt-sienna))}
        .amenity-card.accent-sage::before{background:linear-gradient(90deg,var(--sage),var(--sage-muted))}
        .amenity-card.accent-amber::before{background:linear-gradient(90deg,var(--amber),var(--amber-light))}
        .amenity-card.accent-rose::before{background:linear-gradient(90deg,var(--dusty-rose),var(--mauve))}
        .amenity-emoji{font-size:2rem;margin-bottom:1rem;display:block}
        .amenity-card h3{font-family:'Playfair Display',serif;font-size:1.2rem;font-weight:500;color:#fff;margin-bottom:.4rem}
        .amenity-card p{font-size:.88rem;color:rgba(255,255,255,.35);line-height:1.6}

        /* === EXPERIENCE BANNER === */
        .experience-banner{position:relative;padding:8rem 3.5rem;overflow:hidden}
        .experience-banner .bg-img{position:absolute;inset:0}
        .experience-banner .bg-img img{width:100%;height:100%;object-fit:cover}
        .experience-banner .overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(92,123,84,.88),rgba(30,27,24,.82))}
        .experience-inner{position:relative;z-index:2;max-width:1300px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}
        .experience-text{color:#fff}
        .experience-text .section-label{color:var(--amber-light)}
        .experience-text .section-label .line{background:var(--amber-light)}
        .experience-text h2{font-family:'Playfair Display',serif;font-size:clamp(2rem,3.5vw,2.8rem);font-weight:500;margin-bottom:1.5rem;line-height:1.2}
        .experience-text p{color:rgba(255,255,255,.65);font-size:1rem;line-height:1.9;margin-bottom:1.2rem}
        .exp-features{display:flex;flex-direction:column;gap:1.2rem}
        .exp-feature{display:flex;align-items:center;gap:1rem;background:rgba(255,255,255,.08);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.1);padding:1.2rem 1.5rem;border-radius:14px;transition:all .3s}
        .exp-feature:hover{background:rgba(255,255,255,.12);transform:translateX(6px)}
        .exp-feature-icon{width:48px;height:48px;border-radius:12px;background:rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;font-size:1.4rem;flex-shrink:0}
        .exp-feature h3{font-size:.95rem;font-weight:500;color:#fff;margin-bottom:2px}
        .exp-feature p{font-size:.82rem!important;margin:0!important;color:rgba(255,255,255,.45)!important;line-height:1.4!important}

        /* === REVIEWS === */
        .reviews{padding:8rem 3.5rem;max-width:1300px;margin:0 auto}
        .reviews-top{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:4rem}
        .reviews-top .section-desc{color:var(--taupe);max-width:400px}
        .reviews-score{text-align:right}
        .reviews-score .big-num{font-family:'Playfair Display',serif;font-size:5rem;font-weight:500;line-height:1;color:var(--charcoal);position:relative}
        .reviews-score .big-num::after{content:'★';font-size:1.5rem;color:var(--amber);position:absolute;top:.5rem;right:-1.5rem}
        .reviews-score .score-sub{font-size:.82rem;color:var(--taupe);margin-top:.3rem}
        .reviews-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
        .review-card{background:#fff;border-radius:20px;padding:2.2rem;position:relative;transition:all .4s cubic-bezier(.16,1,.3,1);border:1px solid rgba(30,27,24,.04)}
        .review-card:hover{transform:translateY(-6px);box-shadow:0 20px 50px rgba(30,27,24,.08)}
        .review-card::before{content:'\201C';font-family:'Playfair Display',serif;font-size:5rem;line-height:1;color:var(--pebble);position:absolute;top:1rem;right:1.5rem}
        .review-stars{display:flex;gap:3px;margin-bottom:1rem}
        .review-stars span{color:var(--amber);font-size:.85rem}
        .review-card blockquote{font-size:.95rem;color:var(--slate-warm);line-height:1.8;margin-bottom:1.5rem;font-style:italic;position:relative;z-index:1}
        .review-author{display:flex;align-items:center;gap:10px}
        .review-avatar{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'Playfair Display',serif;font-weight:600;font-size:.9rem;color:#fff}
        .review-avatar.av-terra{background:var(--terracotta)}
        .review-avatar.av-sage{background:var(--sage)}
        .review-avatar.av-amber{background:var(--amber)}
        .review-name{font-weight:500;font-size:.88rem}
        .review-date{font-size:.75rem;color:var(--stone)}
        .review-categories{display:flex;justify-content:center;gap:3rem;margin-top:3rem;padding-top:3rem;border-top:1px solid var(--pebble)}
        .rev-cat{text-align:center}
        .rev-cat-score{font-family:'Playfair Display',serif;font-size:1.4rem;font-weight:600;color:var(--charcoal)}
        .rev-cat-label{font-size:.72rem;color:var(--taupe);letter-spacing:.04em;margin-top:.2rem}
        .rev-cat-bar{width:60px;height:4px;background:var(--pebble);border-radius:4px;margin:6px auto 0;position:relative;overflow:hidden}
        .rev-cat-bar .fill{position:absolute;left:0;top:0;bottom:0;border-radius:4px}
        .fill-terra{background:var(--terracotta)}
        .fill-sage{background:var(--sage)}
        .fill-amber{background:var(--amber)}

        /* === LOCATION === */
        .location{padding:7rem 3.5rem;background:var(--linen)}
        .location-inner{max-width:1300px;margin:0 auto}
        .location-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:4rem;align-items:center}
        .location-text .section-label{color:var(--sage-deep)}
        .location-text .section-label .line{background:var(--sage-deep)}
        .location-text h2{font-family:'Playfair Display',serif;font-size:clamp(2rem,3.5vw,2.6rem);font-weight:500;margin-bottom:1.5rem;line-height:1.2}
        .location-text > p{color:var(--slate-warm);font-size:1rem;line-height:1.8;margin-bottom:2rem}
        .loc-items{display:flex;flex-direction:column;gap:1rem}
        .loc-item{display:flex;align-items:center;gap:14px;padding:1rem 1.2rem;background:#fff;border-radius:14px;transition:all .3s}
        .loc-item:hover{transform:translateX(6px);box-shadow:0 4px 20px rgba(30,27,24,.05)}
        .loc-item-icon{width:42px;height:42px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.15rem;flex-shrink:0}
        .loc-item-icon.bg-terra{background:rgba(194,112,74,.1)}
        .loc-item-icon.bg-sage{background:rgba(122,148,114,.12)}
        .loc-item-icon.bg-amber{background:rgba(212,162,78,.1)}
        .loc-item h3{font-size:.9rem;font-weight:500}
        .loc-item p{font-size:.8rem;color:var(--taupe);margin:0}
        .location-map{border-radius:20px;overflow:hidden;aspect-ratio:4/3;box-shadow:0 20px 60px rgba(30,27,24,.1)}
        .location-map iframe{width:100%;height:100%;border:none}

        /* === HOST === */
        .host{padding:7rem 3.5rem;max-width:900px;margin:0 auto;text-align:center}
        .host-avatar-ring{width:320px;height:420px;border-radius:20px;background:linear-gradient(135deg,var(--terracotta),var(--amber));padding:4px;margin:0 auto 1.5rem;display:flex;align-items:center;justify-content:center}
        .host-avatar-inner{width:100%;height:100%;border-radius:17px;overflow:hidden;background:var(--cream);display:flex;align-items:center;justify-content:center;font-family:'Playfair Display',serif;font-size:2.5rem;font-weight:500;color:var(--terracotta)}
        .host-avatar-inner img{width:100%;height:100%;object-fit:cover;object-position:center top}
        @media(max-width:768px){.host-avatar-ring{width:72vw;max-width:320px;height:calc(72vw * 1.3125);max-height:420px}}
        @media(max-width:480px){.host-avatar-ring{width:80vw;max-width:280px;height:calc(80vw * 1.3125);max-height:370px}}
        .host .section-label{justify-content:center}
        .host h2{font-family:'Playfair Display',serif;font-size:2.2rem;font-weight:500;margin-bottom:.6rem}
        .host-badge{display:inline-flex;align-items:center;gap:6px;background:var(--linen);border:1px solid var(--pebble);padding:6px 16px;border-radius:100px;font-size:.75rem;font-weight:500;letter-spacing:.06em;text-transform:uppercase;color:var(--amber);margin-bottom:1.5rem}
        .host p{color:var(--slate-warm);font-size:1rem;line-height:1.9;max-width:600px;margin:0 auto 2rem}
        .host-stats{display:flex;justify-content:center;gap:3rem}
        .host-stat-num{font-family:'Playfair Display',serif;font-size:1.8rem;font-weight:600;color:var(--charcoal)}
        .host-stat-label{font-size:.72rem;color:var(--taupe);margin-top:.1rem}

        /* === CTA === */
        .final-cta{padding:8rem 3.5rem;text-align:center;position:relative;overflow:hidden;background:linear-gradient(180deg,var(--cream) 0%,var(--linen) 100%)}
        .final-cta .decor-circle{position:absolute;border-radius:50%;opacity:.06}
        .final-cta .decor-circle:nth-child(1){width:500px;height:500px;background:var(--terracotta);top:-200px;right:-100px}
        .final-cta .decor-circle:nth-child(2){width:350px;height:350px;background:var(--sage);bottom:-150px;left:-50px}
        .final-cta .content{position:relative;z-index:2}
        .final-cta h2{font-family:'Playfair Display',serif;font-size:clamp(2.5rem,5vw,3.5rem);font-weight:500;margin-bottom:1rem;line-height:1.15}
        .final-cta h2 .accent{color:var(--terracotta);font-style:italic}
        .final-cta .content > p{color:var(--taupe);font-size:1.05rem;max-width:480px;margin:0 auto 2.5rem;line-height:1.8}
        .cta-btn-large{display:inline-flex;align-items:center;gap:12px;background:var(--charcoal);color:#fff;padding:1.15rem 3rem;border-radius:12px;text-decoration:none;font-size:.9rem;font-weight:500;transition:all .4s ease;box-shadow:0 4px 20px rgba(30,27,24,.15)}
        .cta-btn-large:hover{background:var(--terracotta);transform:translateY(-3px);box-shadow:0 12px 40px rgba(194,112,74,.3)}

        /* === FOOTER === */
        footer{background:var(--charcoal);padding:3.5rem}
        .footer-inner{max-width:1300px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1.5rem}
        .footer-brand{font-family:'Playfair Display',serif;font-size:1.2rem;font-weight:600;color:#fff}
        .footer-links{display:flex;gap:2rem}
        .footer-links a{color:rgba(255,255,255,.4);text-decoration:none;font-size:.82rem;transition:color .3s}
        .footer-links a:hover{color:var(--amber-light)}
        .footer-copy{color:rgba(255,255,255,.25);font-size:.78rem}

        /* === ANIMATIONS === */
        .reveal{opacity:0;transform:translateY(28px);transition:all .9s cubic-bezier(.16,1,.3,1)}
        .reveal.visible{opacity:1;transform:translateY(0)}
        .reveal-left{opacity:0;transform:translateX(-30px);transition:all .9s cubic-bezier(.16,1,.3,1)}
        .reveal-left.visible{opacity:1;transform:translateX(0)}
        .reveal-right{opacity:0;transform:translateX(30px);transition:all .9s cubic-bezier(.16,1,.3,1)}
        .reveal-right.visible{opacity:1;transform:translateX(0)}

        /* === RESPONSIVE === */
        @media(max-width:1024px){
            .about-grid{grid-template-columns:1fr;gap:3rem}
            .about-images{min-height:450px}
            .amenity-grid{grid-template-columns:repeat(2,1fr)}
            .experience-inner{grid-template-columns:1fr;gap:3rem}
            .reviews-cards{grid-template-columns:repeat(2,1fr)}
            .location-grid{grid-template-columns:1fr}
            .gallery-mosaic{grid-template-columns:repeat(2,1fr);grid-template-rows:auto}
            .gal-item:nth-child(1){grid-column:1/3}
            .gal-item:nth-child(n){grid-column:auto}
            .gal-item:nth-child(1){grid-column:1/3}
            .gal-item{height:240px}
        }
        @media(max-width:768px){
            nav{padding:1rem 1.5rem}
            nav.scrolled{padding:.7rem 1.5rem}
            .nav-links{display:none;position:fixed;inset:0;background:var(--cream);flex-direction:column;align-items:center;justify-content:center;gap:1.8rem;z-index:1050}
            .nav-links.active{display:flex}
            .nav-links.active a{color:var(--charcoal)!important;font-size:1rem}
            .mobile-toggle{display:flex}
            .hero-content{padding:3rem 2rem}
            .hero-actions{flex-direction:column;align-items:center}
            .trust-bar{gap:2rem;padding:2rem 1.5rem}
            section,.about,.gallery,.reviews,.host,.final-cta,.amenities,.location,.experience-banner{padding-left:1.5rem;padding-right:1.5rem}
            .about-grid{gap:2.5rem}
            .about-img-accent{width:50%;bottom:-.5rem;right:-.5rem}
            .about-highlights{grid-template-columns:1fr}
            .gallery-mosaic{grid-template-columns:1fr;grid-template-rows:auto}
            .gal-item,.gal-item:nth-child(1){grid-column:1!important;height:220px}
            .amenity-grid{grid-template-columns:1fr}
            .reviews-top{flex-direction:column;align-items:flex-start;gap:2rem}
            .reviews-score{text-align:left}
            .reviews-cards{grid-template-columns:1fr}
            .review-categories{gap:1.5rem;flex-wrap:wrap}
            .host-stats{gap:2rem;flex-wrap:wrap;justify-content:center}
            .footer-inner{flex-direction:column;text-align:center}
            .footer-links{flex-wrap:wrap;justify-content:center}
        }
    
.amenity-emoji{color:var(--terracotta);line-height:0}.amenity-emoji svg{width:34px;height:34px}
.exp-feature-icon{color:#fff}.exp-feature-icon svg{width:26px;height:26px}
.loc-item-icon svg{width:22px;height:22px}
.loc-item-icon.bg-terra{color:var(--terracotta)}.loc-item-icon.bg-sage{color:var(--sage-deep)}.loc-item-icon.bg-amber{color:var(--amber)}
.hi-icon{color:var(--terracotta)}.hi-icon svg{width:18px;height:18px}
.trust-icon{color:var(--amber-light)}.trust-icon svg{width:22px;height:22px}

/* ---- guide pages ---- */
.guide-hero{background:var(--linen);padding:130px 0 60px;border-bottom:1px solid rgba(0,0,0,.06)}
.guide-hero .inner{max-width:760px;margin:0 auto;padding:0 5vw;text-align:center}
.crumb{font-family:'DM Sans',sans-serif;font-size:.82rem;color:var(--slate-warm);margin-bottom:1rem}
.crumb a{color:var(--terracotta);text-decoration:none}.crumb a:hover{text-decoration:underline}
.guide-hero h1{font-family:'Playfair Display',serif;font-weight:700;font-size:clamp(2.2rem,5vw,3.4rem);color:var(--charcoal);line-height:1.08;margin-bottom:1.1rem}
.guide-hero p{font-size:1.12rem;color:var(--warm-brown);line-height:1.7}
.guide-sec{padding:64px 0}
.guide-sec .inner{max-width:1080px;margin:0 auto;padding:0 5vw}
.guide-sec h2{font-family:'Playfair Display',serif;font-weight:600;font-size:clamp(1.7rem,3vw,2.3rem);color:var(--charcoal);margin-bottom:.6rem}
.guide-sec .lead{color:var(--warm-brown);max-width:46rem;margin-bottom:2rem;font-size:1.05rem}
.place-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.1rem}
.place-card{background:#fff;border:1px solid rgba(0,0,0,.07);border-radius:14px;padding:1.4rem 1.5rem;transition:transform .18s,box-shadow .18s}
.place-card:hover{transform:translateY(-3px);box-shadow:0 14px 34px rgba(45,41,38,.1)}
.place-card .top{display:flex;justify-content:space-between;align-items:baseline;gap:1rem;margin-bottom:.35rem}
.place-card h3{font-family:'Playfair Display',serif;font-size:1.2rem;color:var(--charcoal);margin:0}
.place-card .stars{font-family:'DM Sans',sans-serif;font-size:.82rem;color:var(--amber-light);white-space:nowrap;font-weight:600}
.place-card .stars b{color:var(--warm-brown)}
.place-card .tag{display:inline-block;font-family:'DM Sans',sans-serif;font-size:.7rem;letter-spacing:.04em;text-transform:uppercase;color:var(--terracotta);background:rgba(194,112,74,.09);padding:.2rem .6rem;border-radius:6px;margin-bottom:.6rem}
.place-card p{color:var(--warm-brown);font-size:.94rem;line-height:1.55;margin-bottom:.6rem}
.place-card .addr{font-family:'DM Sans',sans-serif;font-size:.82rem;color:var(--slate-warm)}
.woosh-band{background:var(--espresso);color:var(--cream);border-radius:18px;padding:2.4rem 2.2rem;display:flex;gap:1.8rem;align-items:center;flex-wrap:wrap;justify-content:space-between}
.woosh-band .wt{flex:1;min-width:260px}
.woosh-band h3{font-family:'Playfair Display',serif;font-size:1.5rem;color:#fff;margin-bottom:.5rem}
.woosh-band p{color:rgba(255,255,255,.8);font-size:.98rem;line-height:1.6}
.woosh-band .wbtn{background:var(--terracotta-deep);color:#fff;text-decoration:none;padding:.85rem 1.7rem;border-radius:10px;font-family:'DM Sans',sans-serif;font-weight:600;white-space:nowrap}
.woosh-band .wbtn:hover{background:var(--burnt-sienna)}
.trip-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem}
.trip-card{background:var(--cream);border:1px solid rgba(0,0,0,.06);border-radius:14px;padding:1.5rem}
.trip-card .dist{font-family:'DM Sans',sans-serif;font-size:.72rem;letter-spacing:.05em;text-transform:uppercase;color:var(--sage-deep);margin-bottom:.5rem;font-weight:600}
.trip-card h3{font-family:'Playfair Display',serif;font-size:1.22rem;color:var(--charcoal);margin-bottom:.5rem}
.trip-card p{color:var(--warm-brown);font-size:.93rem;line-height:1.55}
.guide-cta{background:var(--linen);text-align:center;padding:70px 5vw}
.guide-cta h2{font-family:'Playfair Display',serif;font-weight:700;font-size:clamp(1.8rem,3.4vw,2.6rem);color:var(--charcoal);margin-bottom:.8rem}
.guide-cta p{color:var(--warm-brown);max-width:34rem;margin:0 auto 1.6rem}
.guide-cta .cbtn{background:var(--terracotta-deep);color:#fff;text-decoration:none;padding:1rem 2.2rem;border-radius:12px;font-family:'DM Sans',sans-serif;font-weight:600;display:inline-block}
.guide-cta .cbtn:hover{background:var(--burnt-sienna)}
.checklist{list-style:none;padding:0;margin:0;display:grid;gap:.8rem}
.checklist li{display:flex;gap:.8rem;align-items:flex-start;color:var(--warm-brown);font-size:1rem;line-height:1.55}
.checklist svg{flex:none;width:22px;height:22px;color:var(--sage-deep);margin-top:2px}
.superhost-badge{display:inline-flex;align-items:center;gap:.5rem;font-family:'DM Sans',sans-serif;font-size:.82rem;font-weight:600;color:var(--terracotta-deep);background:rgba(194,112,74,.1);padding:.4rem .9rem;border-radius:50px;margin-top:1rem}
.superhost-badge svg{width:16px;height:16px}
@media(max-width:760px){.place-grid,.trip-grid{grid-template-columns:1fr}}

.st-credit-line{width:100%;text-align:center;margin-top:2rem;padding-top:1.4rem;border-top:1px solid rgba(255,255,255,.1)}

/* guide pages have a LIGHT hero, so the nav uses the solid/dark treatment from the top */
body.guide nav:not(.scrolled){background:rgba(251,247,242,.9);backdrop-filter:blur(24px) saturate(1.5);-webkit-backdrop-filter:blur(24px) saturate(1.5);box-shadow:0 1px 0 rgba(30,27,24,.05)}
body.guide nav:not(.scrolled) .nav-logo img{filter:none}
body.guide nav:not(.scrolled) .nav-links a{color:var(--charcoal)}
body.guide nav:not(.scrolled) .nav-links a:hover{color:var(--terracotta)}
body.guide nav:not(.scrolled) .mobile-toggle span{background:var(--charcoal)}
/* business cards link out to Google Maps */
a.place-card{text-decoration:none;color:inherit}
.maps-cue{display:block;margin-top:.55rem;color:var(--terracotta-deep);font-weight:600;font-size:.78rem;letter-spacing:.01em}
.place-card:hover .maps-cue{text-decoration:underline}

/* NAV+OVERFLOW MOBILE FIXES */
@media(max-width:640px){
  .nav-logo img{height:38px!important}
  .gallery-mosaic{grid-template-columns:1fr 1fr;grid-auto-rows:180px;grid-template-rows:none}
  .gallery-mosaic > *{grid-column:auto!important;grid-row:auto!important}
}
