/* Brand palette from the card/logo */
:root{
  --ink:#3F3A36;         /* deep warm gray (text) */
  --accent:#D9B67A;      /* gold-beige */
  --paper:#F8F4EE;       /* cream */
  --muted:#FAF8F4;       /* light section background */
  --line:#E7DFD2;
  --max:1120px;
}
*{box-sizing:border-box}
html,body{margin:0;color:var(--ink);background:#fff;font-family:ui-sans-serif,system-ui,Segoe UI,Roboto,Helvetica,Arial}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--max);margin-inline:auto;padding:clamp(16px,4vw,32px)}
.section{padding:clamp(32px,6vw,72px) 0}
.section.muted{background:var(--muted)}

/* Header */
.site-header{position:sticky;top:0;z-index:40;background:rgba(255,255,255,.9);backdrop-filter:saturate(180%) blur(8px);border-bottom:1px solid var(--line)}
.site-header .wrap{display:flex;align-items:center;justify-content:space-between;gap:16px}
.brand{display:flex;align-items:center;gap:12px}
.brand img{width:44px;height:44px;object-fit:contain}
.brand-name{letter-spacing:.18em;font-weight:600}
.nav{display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.nav a{opacity:.9}
.nav a:hover{opacity:1}
.btn{display:inline-block;padding:.7rem 1rem;border:1px solid var(--ink);border-radius:999px}
.btn.book{background:var(--ink);color:#fff;border-color:var(--ink)}
.btn.ghost{background:transparent}
.btn.small{padding:.5rem .8rem;font-size:.95rem}

/* Hero */
.hero{background:linear-gradient(180deg,#fff 0,var(--paper) 100%);border-bottom:1px solid var(--line)}
.hero .hero-text{max-width:720px}
.hero h1{font-size:clamp(28px,5vw,48px);margin:.3em 0}
.hero p{font-size:clamp(16px,2.6vw,18px);opacity:.9}
.cta{display:flex;gap:12px;margin-top:16px;flex-wrap:wrap}

/* About */
.cols{display:grid;grid-template-columns:1.1fr .9fr;gap:32px}
@media (max-width:880px){.cols{grid-template-columns:1fr}}
.lede{opacity:.9;margin-top:.2rem}
.badges{display:flex;gap:8px;flex-wrap:wrap;padding:0;margin:16px 0 0;list-style:none}
.badges li{border:1px solid var(--line);padding:.4rem .6rem;border-radius:999px;background:#fff}
.about-photo .photo-placeholder{height:280px;border:1px dashed var(--line);border-radius:20px;display:grid;place-items:center;color:#9b8f7a;background:var(--muted)}

/* Services */
.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
@media (max-width:1100px){.cards{grid-template-columns:repeat(3,1fr)}}
@media (max-width:800px){.cards{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.cards{grid-template-columns:1fr}}
.card{border:1px solid var(--line);border-radius:16px;padding:16px;background:#fff;display:flex;flex-direction:column;gap:8px}
.card h3{margin:.2rem 0 .1rem}
.card .meta{opacity:.8}
.card .blurb{opacity:.9}
.card .btn{align-self:flex-start;margin-top:auto}

/* FAQ */
.faq details{border:1px solid var(--line);border-radius:12px;background:#fff;padding:14px 16px}
.faq details+details{margin-top:10px}

/* Contact */
.contact-list{padding:0;margin:0 0 14px;list-style:none;display:grid;gap:6px}
.contact-form{border:1px solid var(--line);border-radius:16px;padding:16px;background:#fff;display:grid;gap:12px}
.contact-form label{display:grid;gap:6px}
.contact-form input,.contact-form textarea{padding:.7rem .8rem;border-radius:10px;border:1px solid var(--line);width:100%}
.form-note{font-size:.9rem;opacity:.75;margin:0}

/* Footer */
.site-footer{border-top:1px solid var(--line);background:#fff}
.site-footer .wrap{display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap}
.accent{color:var(--accent)}
