:root{
  --cream:#f4f0e8; --paper:#fbf9f4; --ink:#2e2c27; --muted:#6f6a60;
  --sage:#7c8a72; --sage-dk:#5f6c57; --line:#e2dccf;
}
*{ margin:0; padding:0; box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{ font-family:"Helvetica Neue",Arial,sans-serif; color:var(--ink); background:var(--cream); line-height:1.6; font-size:17px; overflow-x:hidden; }
.serif{ font-family:"Didot","Hoefler Text",Georgia,"Times New Roman",serif; }
a{ color:inherit; }
img{ max-width:100%; display:block; }
.wrap{ width:100%; max-width:1040px; margin:0 auto; padding:0 22px; }
.eyebrow{ font-size:12px; letter-spacing:3px; text-transform:uppercase; color:var(--sage); font-weight:700; }

/* Header */
header{ position:sticky; top:0; z-index:50; background:rgba(244,240,232,.92); backdrop-filter:blur(6px); border-bottom:1px solid var(--line); }
.nav{ display:flex; align-items:center; justify-content:space-between; height:64px; }
.brand{ font-size:20px; font-weight:700; letter-spacing:.3px; text-decoration:none; }
.brand b{ color:var(--sage-dk); }
.nav-cta{ display:flex; align-items:center; gap:14px; }
.nav-phone{ font-weight:600; text-decoration:none; font-size:15px; }
.btn{ display:inline-block; background:var(--sage-dk); color:#fff; text-decoration:none; font-weight:600; font-size:15px; padding:11px 20px; border-radius:6px; transition:background .15s; }
.btn:hover{ background:#4e5a47; }
.btn.light{ background:transparent; color:var(--sage-dk); border:1.5px solid var(--sage); }
.btn.light:hover{ background:#eae4d6; }

/* Hero */
.hero{ padding:78px 0 64px; text-align:center; }
.hero h1{ font-size:46px; font-weight:700; line-height:1.12; letter-spacing:.3px; margin:18px 0 0; overflow-wrap:break-word; }
.hero h1 span{ color:var(--sage-dk); font-style:italic; }
.hero p.sub{ font-size:19px; color:var(--muted); max-width:560px; margin:20px auto 0; }
.hero .ctas{ margin-top:30px; display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }
.hero .area{ margin-top:26px; font-size:13px; letter-spacing:1.5px; text-transform:uppercase; color:var(--muted); }

section{ padding:60px 0; }
.section-head{ text-align:center; margin-bottom:42px; }
.section-head h2{ font-size:32px; font-weight:700; margin-top:10px; }
.section-head p{ color:var(--muted); margin-top:10px; max-width:540px; margin-left:auto; margin-right:auto; }

/* Services */
.services{ background:var(--paper); border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.card{ background:var(--cream); border:1px solid var(--line); border-radius:10px; padding:26px 24px; }
.card h3{ font-size:20px; font-weight:700; }
.card .price{ color:var(--sage-dk); font-weight:700; font-size:15px; margin-top:4px; }
.card p{ color:var(--muted); margin-top:10px; font-size:15.5px; }

/* Service groups (for homes / for hosts) */
.svc-group-label{ font-size:13px; letter-spacing:2.5px; text-transform:uppercase; color:var(--sage-dk); font-weight:700; text-align:center; margin-bottom:22px; }
.svc-note{ text-align:center; color:var(--muted); margin:34px auto 0; max-width:660px; font-size:15.5px; }
.host-teaser{ display:flex; align-items:center; justify-content:space-between; gap:26px; background:var(--cream); border:1px solid var(--line); border-radius:12px; padding:28px 32px; max-width:820px; margin:0 auto; }
.host-teaser h3{ font-size:21px; font-weight:700; }
.host-teaser p{ color:var(--muted); margin-top:8px; font-size:15.5px; }
.host-teaser .btn{ white-space:nowrap; }

/* About */
.about-flex{ display:flex; gap:46px; align-items:center; max-width:940px; margin:0 auto; }
.about-photo{ flex:0 0 42%; }
.about-photo img{ width:100%; border-radius:12px; box-shadow:0 10px 34px rgba(46,44,39,.12); }
.about-text{ flex:1; text-align:left; }
.about-text h2{ font-size:32px; font-weight:700; }
.about-text p{ font-size:18px; margin-top:16px; color:#3a372f; }
.sig{ margin-top:22px; font-size:26px; color:var(--sage-dk); }

/* Why / trust */
.why{ background:var(--sage-dk); color:#f3efe6; border:none; }
.why .section-head h2{ color:#fff; }
.why .grid4{ display:grid; grid-template-columns:repeat(4,1fr); gap:24px; }
.why .item h3{ font-size:18px; font-weight:700; margin-bottom:8px; }
.why .item p{ font-size:14.5px; color:#d8d2c4; line-height:1.55; }

/* Included list (airbnb page) */
.included{ max-width:740px; margin:0 auto; display:grid; grid-template-columns:1fr 1fr; gap:16px 36px; }
.included li{ list-style:none; padding-left:28px; position:relative; font-size:16.5px; }
.included li::before{ content:"\2713"; position:absolute; left:0; top:1px; color:var(--sage); font-weight:800; }

/* Gallery */
.gallery{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.gallery figure{ border-radius:10px; overflow:hidden; border:1px solid var(--line); }
.gallery img{ width:100%; height:100%; object-fit:cover; }
.gallery.uniform img{ height:auto; aspect-ratio:4 / 3; object-fit:cover; }

/* Hero collage */
.hero-collage{ display:grid; grid-template-columns:repeat(3,1fr); gap:10px; max-width:780px; margin:42px auto 0; }
.hero-collage img{ width:100%; height:210px; object-fit:cover; border-radius:10px; display:block; box-shadow:0 8px 28px rgba(46,44,39,.10); }

/* Testimonials */
.quotes{ display:grid; grid-template-columns:repeat(2,1fr); gap:22px; max-width:860px; margin:0 auto; }
.quote{ background:var(--paper); border:1px solid var(--line); border-radius:10px; padding:26px; }
.quote p{ font-size:17px; font-style:italic; }
.quote .who{ margin-top:14px; font-style:normal; font-weight:600; color:var(--sage-dk); font-size:14px; }

/* Area */
.area-list{ text-align:center; max-width:640px; margin:0 auto; }
.area-list .tags{ display:flex; flex-wrap:wrap; gap:10px; justify-content:center; margin-top:22px; }
.area-list .tag{ background:var(--paper); border:1px solid var(--line); border-radius:30px; padding:8px 18px; font-size:14.5px; font-weight:600; }

/* Contact */
.contact{ background:var(--paper); border-top:1px solid var(--line); text-align:center; }
.contact .num{ font-size:38px; font-weight:700; letter-spacing:1px; margin:8px 0 6px; }
.contact .num a{ text-decoration:none; }
.contact .ctas{ margin-top:24px; display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }
.contact .small{ color:var(--muted); font-size:15px; margin-top:22px; }

footer{ background:var(--cream); border-top:1px solid var(--line); text-align:center; padding:34px 0; color:var(--muted); font-size:14px; }
footer .fbrand{ font-weight:700; color:var(--ink); font-size:16px; }
footer a{ text-decoration:none; }

@media (max-width:720px){
  body{ font-size:16px; }
  .about-flex{ flex-direction:column; gap:24px; }
  .about-photo{ flex:none; width:100%; max-width:340px; margin:0 auto; }
  .about-text{ text-align:center; }
  .hero-collage{ gap:7px; margin-top:30px; }
  .hero-collage img{ height:120px; }
  .hero{ padding:54px 0 46px; }
  .hero h1{ font-size:29px; }
  .brk{ display:none; }
  .nav-cta .btn{ padding:10px 16px; font-size:14px; }
  .hero p.sub{ font-size:17px; }
  .nav-phone{ display:none; }
  .section-head h2{ font-size:26px; }
  .grid{ grid-template-columns:1fr; }
  .host-teaser{ flex-direction:column; align-items:flex-start; gap:18px; }
  .included{ grid-template-columns:1fr; }
  .why .grid4{ grid-template-columns:1fr 1fr; gap:22px; }
  .gallery{ grid-template-columns:1fr; }
  .quotes{ grid-template-columns:1fr; }
  .contact .num{ font-size:30px; }
}
