:root{--color-primary:#2c5f4a;--color-primary-light:#3a7d62;--color-primary-dark:#1e4435;--color-accent:#c8956c;--color-accent-light:#e8c9a8;--color-bg:#faf9f7;--color-bg-alt:#f0eeeb;--color-text:#2d2d2d;--color-text-light:#6b6b6b;--color-white:#fff;--color-border:#e2dfda;--font-heading:'Playfair Display',Georgia,serif;--font-body:'Inter',-apple-system,sans-serif;--radius:12px;--radius-sm:8px;--shadow:0 2px 16px rgba(0,0,0,.06);--shadow-lg:0 8px 32px rgba(0,0,0,.1);--transition:.3s ease;--container-width:1140px}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font-body);color:var(--color-text);background:var(--color-bg);line-height:1.7;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}
.container{max-width:var(--container-width);margin:0 auto;padding:0 24px}
.btn{display:inline-flex;align-items:center;justify-content:center;padding:14px 32px;border-radius:var(--radius-sm);font-family:var(--font-body);font-size:.95rem;font-weight:500;letter-spacing:.02em;transition:all var(--transition);cursor:pointer;border:2px solid transparent}
.btn-primary{background:var(--color-primary);color:var(--color-white);border-color:var(--color-primary)}
.btn-primary:hover{background:var(--color-primary-light);border-color:var(--color-primary-light);transform:translateY(-1px);box-shadow:var(--shadow)}
.btn-outline{background:transparent;color:var(--color-white);border-color:var(--color-white)}
.btn-outline:hover{background:var(--color-white);color:var(--color-primary)}
.btn-outline-dark{background:transparent;color:var(--color-primary);border-color:var(--color-primary)}
.btn-outline-dark:hover{background:var(--color-primary);color:var(--color-white)}
.navbar{position:fixed;top:0;left:0;right:0;z-index:1000;background:transparent;transition:all var(--transition);padding:20px 0}
.navbar.scrolled{background:rgba(255,255,255,.97);backdrop-filter:blur(12px);box-shadow:0 1px 8px rgba(0,0,0,.06);padding:12px 0}
.navbar.scrolled .nav-logo,.navbar.scrolled .nav-menu a{color:var(--color-text)}
.nav-container{max-width:var(--container-width);margin:0 auto;padding:0 24px;display:flex;align-items:center;justify-content:space-between}
.nav-logo{font-family:var(--font-heading);font-size:1.3rem;font-weight:700;color:var(--color-white);transition:color var(--transition)}
.nav-logo span{font-weight:400;margin-left:4px;opacity:.8}
.nav-menu{display:flex;gap:8px}
.nav-menu a{padding:8px 16px;color:var(--color-white);font-size:.9rem;font-weight:450;border-radius:var(--radius-sm);transition:all var(--transition)}
.nav-menu a:hover,.nav-menu a.active{background:rgba(255,255,255,.15)}
.navbar.scrolled .nav-menu a:hover,.navbar.scrolled .nav-menu a.active{background:var(--color-bg-alt);color:var(--color-primary)}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:4px}
.nav-toggle span{width:24px;height:2px;background:var(--color-white);transition:all var(--transition)}
.navbar.scrolled .nav-toggle span{background:var(--color-text)}
.hero{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#2c5f4a 0%,#1a3d30 40%,#1e4435 70%,#3a7d62 100%);color:var(--color-white);overflow:hidden}
.hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 20% 80%,rgba(200,149,108,.15) 0%,transparent 50%),radial-gradient(ellipse at 80% 20%,rgba(58,125,98,.3) 0%,transparent 50%),radial-gradient(ellipse at 50% 50%,rgba(255,255,255,.03) 0%,transparent 70%)}
.hero-overlay{display:none}
.hero-content{position:relative;text-align:center;max-width:720px;padding:0 24px}
.hero h1{font-family:var(--font-heading);font-size:clamp(2.2rem,5vw,3.5rem);font-weight:700;line-height:1.2;margin-bottom:20px}
.hero-h1-sub{font-size:clamp(1rem,2.5vw,1.6rem);font-weight:400;display:block;margin-top:8px;opacity:.9}
.hero-subtitle{font-size:clamp(1rem,2vw,1.2rem);opacity:.9;margin-bottom:36px;font-weight:300;line-height:1.6}
.hero-actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.highlights{padding:80px 0;background:var(--color-white)}
.highlights-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:32px}
.highlight-card{text-align:center;padding:32px 20px}
.highlight-icon{width:48px;height:48px;margin:0 auto 16px;color:var(--color-primary)}
.highlight-icon svg{width:100%;height:100%}
.highlight-card h3{font-family:var(--font-heading);font-size:1.15rem;margin-bottom:8px}
.highlight-card p{font-size:.9rem;color:var(--color-text-light)}
.about-section{padding:100px 0}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.about-image img{border-radius:var(--radius);object-fit:cover;width:100%;height:460px;box-shadow:var(--shadow-lg)}
.about-content h2{font-family:var(--font-heading);font-size:2rem;margin-bottom:20px;line-height:1.3}
.about-content p{color:var(--color-text-light);margin-bottom:16px}
.about-features{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:32px;padding-top:32px;border-top:1px solid var(--color-border)}
.feature{text-align:center}
.feature strong{display:block;font-family:var(--font-heading);font-size:1.8rem;color:var(--color-primary)}
.feature span{font-size:.85rem;color:var(--color-text-light)}
.amenities-section{padding:100px 0;background:var(--color-white)}
.amenities-section h2{font-family:var(--font-heading);font-size:2rem;text-align:center;margin-bottom:48px}
.amenities-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:40px}
.amenity-group h3{font-family:var(--font-heading);font-size:1.15rem;margin-bottom:16px;padding-bottom:12px;border-bottom:2px solid var(--color-primary);display:inline-block}
.amenity-group ul li{padding:8px 0 8px 24px;position:relative;font-size:.95rem;color:var(--color-text-light)}
.amenity-group ul li::before{content:'';position:absolute;left:0;top:16px;width:8px;height:8px;border-radius:50%;background:var(--color-accent)}
.preview-gallery{padding:80px 0;background:var(--color-white)}
.preview-gallery h2{font-family:var(--font-heading);font-size:2rem;text-align:center;margin-bottom:32px}
.preview-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.preview-grid .gallery-item{border-radius:var(--radius);overflow:hidden;aspect-ratio:4/3;cursor:pointer;position:relative}
.preview-grid .gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.preview-grid .gallery-item:hover img{transform:scale(1.05)}
.location-section{padding:100px 0}
.location-section h2{font-family:var(--font-heading);font-size:2rem;text-align:center;margin-bottom:8px}
.section-subtitle{text-align:center;color:var(--color-text-light);margin-bottom:48px}
.location-grid{display:grid;grid-template-columns:1.5fr 1fr;gap:40px;align-items:start}
.location-info h3{font-family:var(--font-heading);font-size:1.3rem;margin-bottom:24px}
.proximity-list li{display:flex;align-items:center;gap:16px;padding:16px 0;border-bottom:1px solid var(--color-border);font-size:.95rem}
.proximity-distance{background:var(--color-primary);color:var(--color-white);padding:4px 12px;border-radius:20px;font-size:.8rem;font-weight:600;white-space:nowrap;min-width:60px;text-align:center}
.cta-section{padding:100px 0;background:var(--color-primary);color:var(--color-white);text-align:center}
.cta-section h2{font-family:var(--font-heading);font-size:2rem;margin-bottom:12px}
.cta-section p{opacity:.85;margin-bottom:32px;font-size:1.05rem}
.cta-actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.footer{background:var(--color-text);color:rgba(255,255,255,.7);padding:60px 0 0}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:40px;padding-bottom:40px}
.footer h4{color:var(--color-white);font-family:var(--font-heading);margin-bottom:16px;font-size:1.1rem}
.footer a:hover{color:var(--color-white)}
.footer-nav li{margin-bottom:8px}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding:20px 0;text-align:center;font-size:.85rem}
.footer-airbnb{margin-top:16px;padding-top:12px;border-top:1px solid rgba(255,255,255,.15)}
.footer-airbnb a{color:var(--color-accent-light);font-weight:500;transition:color var(--transition)}
.footer-airbnb a:hover{color:var(--color-white)}
.page-header{padding:160px 0 80px;background:var(--color-primary);color:var(--color-white);text-align:center}
.page-header h1{font-family:var(--font-heading);font-size:2.5rem;margin-bottom:12px}
.page-header p{opacity:.85;font-size:1.05rem}
.gallery-section{padding:80px 0}
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.gallery-item{border-radius:var(--radius);overflow:hidden;cursor:pointer;position:relative;aspect-ratio:4/3}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.gallery-item:hover img{transform:scale(1.05)}
.gallery-item.featured{grid-column:span 2;grid-row:span 2;aspect-ratio:auto}
.lightbox{display:none;position:fixed;inset:0;z-index:2000;background:rgba(0,0,0,.92);align-items:center;justify-content:center;padding:40px}
.lightbox.active{display:flex}
.lightbox img{max-width:90%;max-height:85vh;border-radius:var(--radius-sm);object-fit:contain}
.lightbox-close{position:absolute;top:24px;right:24px;background:none;border:none;color:#fff;font-size:2rem;cursor:pointer;width:48px;height:48px;display:flex;align-items:center;justify-content:center}
.lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.15);border:none;color:#fff;font-size:1.5rem;cursor:pointer;width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:background var(--transition)}
.lightbox-nav:hover{background:rgba(255,255,255,.3)}
.lightbox-prev{left:24px}
.lightbox-next{right:24px}
.activities-section{padding:80px 0}
.activities-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:32px}
.activity-card{background:var(--color-white);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);transition:transform var(--transition),box-shadow var(--transition)}
.activity-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.activity-card-image{height:220px;overflow:hidden}
.activity-card-image img{width:100%;height:100%;object-fit:cover}
.activity-card-content{padding:28px}
.activity-card-content h3{font-family:var(--font-heading);font-size:1.25rem;margin-bottom:8px}
.activity-card-content .activity-distance{display:inline-block;background:var(--color-accent-light);color:var(--color-accent);padding:3px 10px;border-radius:20px;font-size:.8rem;font-weight:600;margin-bottom:12px}
.activity-card-content p{color:var(--color-text-light);font-size:.93rem}
.reservation-section{padding:80px 0}
.reservation-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px}
.form-group{margin-bottom:20px}
.form-group label{display:block;margin-bottom:6px;font-weight:500;font-size:.9rem}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:12px 16px;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-family:var(--font-body);font-size:.95rem;background:var(--color-white);transition:border-color var(--transition)}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--color-primary)}
.form-group textarea{resize:vertical;min-height:120px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-submit{margin-top:8px}
.form-submit .btn{width:100%}
.reservation-info{background:var(--color-white);border-radius:var(--radius);padding:36px;box-shadow:var(--shadow);height:fit-content;position:sticky;top:100px}
.reservation-info h3{font-family:var(--font-heading);font-size:1.3rem;margin-bottom:24px}
.info-item{display:flex;align-items:start;gap:12px;padding:14px 0;border-bottom:1px solid var(--color-border)}
.info-item:last-child{border-bottom:none}
.info-item-icon{width:20px;height:20px;color:var(--color-primary);flex-shrink:0;margin-top:2px}
.info-item-icon svg{width:100%;height:100%}
.info-item-text strong{display:block;font-size:.9rem}
.info-item-text span{font-size:.85rem;color:var(--color-text-light)}
.contact-section{padding:80px 0}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px}
.contact-details{display:flex;flex-direction:column;gap:24px}
.contact-item{display:flex;gap:16px;align-items:start}
.contact-icon{width:44px;height:44px;background:var(--color-bg-alt);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--color-primary)}
.contact-icon svg{width:20px;height:20px}
.contact-item h4{font-size:.95rem;margin-bottom:4px}
.contact-item p,.contact-item a{color:var(--color-text-light);font-size:.93rem}
.contact-item a:hover{color:var(--color-primary)}
.form-message{padding:14px 20px;border-radius:var(--radius-sm);margin-bottom:20px;font-size:.9rem;display:none}
.form-message.success{background:#e8f5e9;color:#2e7d32;display:block}
.form-message.error{background:#fce4ec;color:#c62828;display:block}
.airbnb-banner{background:var(--color-bg-alt);padding:16px 0;text-align:center;font-size:.9rem}
.airbnb-banner a{color:var(--color-primary);font-weight:600;text-decoration:underline;text-underline-offset:3px}
.airbnb-banner a:hover{color:var(--color-primary-light)}
@media(max-width:968px){
.highlights-grid{grid-template-columns:repeat(2,1fr)}
.about-grid{grid-template-columns:1fr;gap:40px}
.about-image img{height:320px}
.amenities-grid{grid-template-columns:1fr 1fr}
.location-grid{grid-template-columns:1fr}
.gallery-grid{grid-template-columns:repeat(2,1fr)}
.gallery-item.featured{grid-column:span 2}
.preview-grid{grid-template-columns:repeat(2,1fr)}
.preview-grid .gallery-item:nth-child(3){display:none}
.activities-grid{grid-template-columns:1fr}
.reservation-grid{grid-template-columns:1fr}
.contact-grid{grid-template-columns:1fr}
.footer-grid{grid-template-columns:1fr 1fr;gap:32px}
}
@media(max-width:640px){
.nav-menu{display:none;position:absolute;top:100%;left:0;right:0;background:var(--color-white);flex-direction:column;padding:16px;box-shadow:var(--shadow);gap:4px;border-radius:0 0 var(--radius) var(--radius)}
.nav-menu.open{display:flex}
.nav-menu a{color:var(--color-text)!important;padding:12px 16px;border-radius:var(--radius-sm)}
.nav-menu a:hover,.nav-menu a.active{background:var(--color-bg-alt)}
.nav-toggle{display:flex}
.hero{min-height:85vh}
.hero h1{font-size:1.8rem}
.hero-h1-sub{font-size:1rem}
.hero-subtitle{font-size:.95rem}
.hero-actions{flex-direction:column;align-items:center}
.hero-actions .btn{width:100%;max-width:280px}
.highlights{padding:48px 0}
.highlights-grid{grid-template-columns:1fr;gap:16px}
.highlight-card{padding:20px 16px;display:flex;align-items:center;gap:16px;text-align:left}
.highlight-icon{margin:0;flex-shrink:0;width:36px;height:36px}
.highlight-card h3{font-size:1rem;margin-bottom:2px}
.highlight-card p{font-size:.85rem}
.about-section{padding:60px 0}
.about-image img{height:240px}
.about-content h2{font-size:1.5rem}
.about-features{grid-template-columns:repeat(2,1fr)}
.amenities-section{padding:60px 0}
.amenities-section h2{font-size:1.5rem}
.amenities-grid{grid-template-columns:1fr}
.preview-gallery{padding:60px 0}
.preview-gallery h2{font-size:1.5rem}
.preview-grid{grid-template-columns:1fr;gap:12px}
.preview-grid .gallery-item:nth-child(3){display:block}
.location-section{padding:60px 0}
.location-section h2{font-size:1.5rem}
.gallery-grid{grid-template-columns:1fr 1fr;gap:8px}
.gallery-item.featured{grid-column:span 2}
.gallery-section{padding:40px 0}
.activities-section{padding:40px 0}
.activity-card-image{height:180px}
.reservation-section{padding:40px 0}
.reservation-grid{gap:32px}
.form-row{grid-template-columns:1fr}
.reservation-info{padding:24px}
.contact-section{padding:40px 0}
.cta-section{padding:60px 0}
.cta-section h2{font-size:1.5rem}
.cta-actions{flex-direction:column;align-items:center}
.cta-actions .btn{width:100%;max-width:280px}
.page-header{padding:110px 0 50px}
.page-header h1{font-size:1.6rem}
.page-header p{font-size:.93rem}
.footer{padding:40px 0 0}
.footer-grid{grid-template-columns:1fr;gap:24px}
.lightbox{padding:16px}
.lightbox img{max-width:100%;max-height:80vh}
.lightbox-nav{width:40px;height:40px;font-size:1.2rem}
.lightbox-prev{left:8px}
.lightbox-next{right:8px}
.lightbox-close{top:12px;right:12px}
}
