@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,500;1,400;1,500&family=DM+Sans:wght@300;400;500&display=swap');

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

:root{
  --cream:#fdf8f4;
  --blush:#f5ede8;
  --rose:#e8c8be;
  --dusty:#c9a49a;
  --ink:#2c2420;
  --muted:#8a7570;
  --accent:#b07060;
  --gold:#c4975a;
  --border:rgba(44,36,32,0.1);
  --serif:'Playfair Display',Georgia,serif;
  --sans:'DM Sans',system-ui,sans-serif;
}

html{scroll-behavior:smooth;background:#ebe8e2}
body{font-family:var(--sans);background:var(--cream);color:var(--ink);font-size:16px;line-height:1.75;font-weight:300;max-width:1280px;margin:0 auto;box-shadow:0 0 60px rgba(44,36,32,0.08)}

/* ── NAV ── */
nav{
  position:fixed;top:0;left:50%;transform:translateX(-50%);
  width:100%;max-width:1280px;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:0.9rem 5rem;
  background:rgba(253,248,244,0.97);
  backdrop-filter:blur(12px);
  border-bottom:1px solid var(--border);
}
.nav-logo{
  font-family:var(--serif);font-size:2.4rem;font-weight:400;
  font-style:italic;letter-spacing:0.02em;
  color:var(--ink);text-decoration:none;
}
.nav-links{display:flex;gap:2.25rem;list-style:none}
.nav-links a{
  font-size:0.75rem;letter-spacing:0.14em;text-transform:uppercase;
  color:var(--muted);text-decoration:none;transition:color 0.2s;font-weight:400;
}
.nav-links a:hover,.nav-links a.active{color:var(--ink)}
.nav-cta{
  font-family:var(--sans);font-size:0.72rem;letter-spacing:0.12em;
  text-transform:uppercase;padding:0.6rem 1.5rem;
  background:var(--accent);color:#fff;
  text-decoration:none;border:none;cursor:pointer;
  transition:opacity 0.25s;font-weight:400;
}
.nav-cta:hover{opacity:0.82}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:none;padding:4px}
.hamburger span{display:block;width:22px;height:1px;background:var(--ink);transition:all 0.3s}
.mobile-menu{display:none;position:fixed;inset:0;z-index:99;background:var(--cream);padding:6rem 2.5rem 2rem;flex-direction:column}
.mobile-menu.open{display:flex}
.mobile-menu a{font-family:var(--serif);font-size:1.9rem;font-style:italic;font-weight:400;color:var(--ink);text-decoration:none;border-bottom:1px solid var(--border);padding:0.9rem 0}
.mobile-menu .mobile-cta{margin-top:2rem;font-size:0.78rem;letter-spacing:0.12em;text-transform:uppercase;font-family:var(--sans);font-style:normal}

/* ── HERO ── */
.hero{
  min-height:100vh;
  display:grid;
  grid-template-columns:1fr 1fr;
  position:relative;
  overflow:hidden;
}
.hero-left{
  display:flex;flex-direction:column;justify-content:center;
  padding:8rem 4rem 5rem 4.5rem;
  background:var(--cream);
  position:relative;z-index:1;
}
.hero-right{
  position:relative;overflow:hidden;
}
.hero-right img{
  width:100%;height:100%;object-fit:cover;object-position:center;
  display:block;
}
.hero-right::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(to right,var(--cream) 0%,transparent 18%);
}
.eyebrow{
  font-size:0.68rem;letter-spacing:0.3em;text-transform:uppercase;
  color:var(--dusty);margin-bottom:1.5rem;display:block;font-weight:400;
}
.hero h1{
  font-family:var(--serif);
  font-size:clamp(2.4rem,4.5vw,3.8rem);
  font-weight:400;font-style:italic;
  line-height:1.15;letter-spacing:-0.01em;
  margin-bottom:1.75rem;color:var(--ink);
}
.hero h1 em{font-style:normal;color:var(--accent)}
.hero-sub{
  font-size:0.95rem;color:var(--muted);
  max-width:440px;margin-bottom:2.75rem;line-height:1.9;
}
.hero-actions{display:flex;gap:1rem;flex-wrap:wrap;align-items:center}
.hero-scroll{
  position:absolute;bottom:2.5rem;left:4.5rem;
  font-size:0.65rem;letter-spacing:0.25em;text-transform:uppercase;
  color:var(--dusty);display:flex;align-items:center;gap:0.75rem;
}
.hero-scroll::before{content:'';display:block;width:32px;height:1px;background:var(--rose)}

/* ── BUTTONS ── */
.btn{display:inline-block;text-decoration:none;font-family:var(--sans);font-weight:400;cursor:pointer;border:none;transition:all 0.25s}
.btn-primary{
  font-size:0.72rem;letter-spacing:0.12em;text-transform:uppercase;
  padding:0.9rem 2rem;background:var(--accent);color:#fff;
}
.btn-primary:hover{opacity:0.82}
.btn-soft{
  font-size:0.72rem;letter-spacing:0.12em;text-transform:uppercase;
  padding:0.9rem 2rem;background:var(--blush);color:var(--accent);
  border:1px solid var(--rose);
}
.btn-soft:hover{background:var(--rose)}
.btn-outline{
  font-size:0.72rem;letter-spacing:0.12em;text-transform:uppercase;
  padding:0.9rem 2rem;background:transparent;color:var(--muted);
  border:1px solid var(--border);
}
.btn-outline:hover{border-color:var(--accent);color:var(--accent)}

/* ── ORNAMENT ── */
.ornament{
  display:block;text-align:center;color:var(--rose);
  font-size:1.2rem;letter-spacing:0.5em;margin-bottom:1.25rem;
  opacity:0.7;
}

/* ── SECTIONS ── */
section{padding:4rem 6rem}
.section-inner{max-width:1000px;margin:0 auto}
.section-label{
  font-size:0.65rem;letter-spacing:0.32em;text-transform:uppercase;
  color:var(--dusty);margin-bottom:1.25rem;display:block;font-weight:400;
}
.section-title{
  font-family:var(--serif);font-size:clamp(1.9rem,3.2vw,2.8rem);
  font-weight:400;font-style:italic;line-height:1.25;margin-bottom:1.75rem;color:var(--ink);
}
hr.thin{border:none;border-top:1px solid var(--border);margin:0}
.divider-ornament{text-align:center;padding:2rem 0;color:var(--rose);font-size:1rem;letter-spacing:0.4em;opacity:0.6}

/* ── BRAND STATEMENT ── */
.brand-statement{
  background:var(--blush);
  text-align:center;
  padding:3.5rem 6rem;
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
}
.brand-statement-text{
  font-family:var(--serif);
  font-size:clamp(1.7rem,3vw,2.6rem);
  font-weight:400;font-style:italic;
  line-height:1.3;max-width:700px;margin:0 auto 2rem;color:var(--ink);
}
.brand-statement p{
  font-size:0.9rem;color:var(--muted);max-width:500px;
  margin:0 auto 2.5rem;line-height:1.9;
}

/* ── MEET YOUR GUIDE (about preview) ── */
.guide-section{padding:4rem 6rem}
.guide-inner{max-width:1000px;margin:0 auto;display:grid;grid-template-columns:320px 1fr;gap:4rem;align-items:center}
.guide-img-wrap{position:relative}
.guide-img-wrap img{
  width:100%;aspect-ratio:3/4;object-fit:cover;
  object-position:center top;
  clip-path:ellipse(50% 50% at 50% 50%);
  display:block;
}
.guide-img-frame{
  position:absolute;inset:-12px;
  border:1px solid var(--rose);
  clip-path:ellipse(50% 50% at 50% 50%);
  pointer-events:none;
}
.guide-body{}
.guide-body .section-label{margin-bottom:0.75rem}
.guide-body h2{font-family:var(--serif);font-size:clamp(2rem,3vw,2.8rem);font-weight:400;font-style:italic;margin-bottom:1.5rem;color:var(--ink)}
.guide-body p{font-size:0.95rem;color:var(--muted);margin-bottom:1.1rem;line-height:1.9}
.guide-body p.lead{font-family:var(--serif);font-size:1.2rem;font-weight:400;color:var(--ink);line-height:1.5;margin-bottom:1.5rem;font-style:italic}

/* ── SERVICE CARDS ── */
.services-band{
  background:var(--ink);
  padding:3.5rem 6rem;
  position:relative;overflow:hidden;
}
.services-band::before{
  content:'';position:absolute;inset:0;
  background:url('/images/hero-bg.jpg') center/cover no-repeat;
  opacity:0.08;
}
.services-band .section-label{color:var(--rose);position:relative;z-index:1;text-align:center}
.services-band .section-title{color:#fff;text-align:center;position:relative;z-index:1;margin-bottom:3rem}
.services-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:1.25rem;position:relative;z-index:1;max-width:1000px;margin:0 auto;
}
.service-card{
  background:rgba(253,248,244,0.07);
  border:1px solid rgba(255,255,255,0.12);
  padding:2.5rem 2rem;
  transition:background 0.3s;
}
.service-card:hover{background:rgba(253,248,244,0.13)}
.service-card h3{
  font-family:var(--serif);font-size:1.4rem;font-weight:400;
  font-style:italic;color:#fff;margin-bottom:1rem;line-height:1.3;
}
.service-card p{font-size:0.85rem;color:rgba(255,255,255,0.6);line-height:1.85;margin-bottom:1.5rem}
.service-card a{
  font-size:0.68rem;letter-spacing:0.18em;text-transform:uppercase;
  color:var(--rose);text-decoration:none;
  display:inline-flex;align-items:center;gap:0.5rem;transition:gap 0.2s;
}
.service-card a:hover{gap:0.8rem}
.service-card a::after{content:'→'}

/* ── INTRO TEXT ── */
.intro-block{max-width:640px}
.intro-block p{color:var(--muted);margin-bottom:1.25rem;font-size:0.97rem;line-height:1.9}
.intro-block p.standout{font-family:var(--serif);font-size:1.3rem;font-style:italic;color:var(--ink);margin-bottom:1.5rem;line-height:1.5}

/* ── TWO COL ── */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:5.5rem;align-items:start}
.two-col-left p{font-size:0.95rem;color:var(--muted);margin-bottom:1.1rem;line-height:1.9}
.feature-list{list-style:none;display:flex;flex-direction:column;gap:0.6rem;margin-top:0.5rem}
.feature-list li{
  padding:1rem 1.25rem 1rem 2.5rem;
  background:var(--blush);
  border-left:2px solid var(--rose);
  font-size:0.88rem;color:var(--muted);position:relative;
}
.feature-list li::before{content:'✦';position:absolute;left:0.85rem;color:var(--dusty);font-size:0.55rem;top:50%;transform:translateY(-50%)}

/* ── HOW IT WORKS ── */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:2rem}
.step{text-align:center;padding:2rem 1.5rem;border:1px solid var(--border);background:#fff;position:relative}
.step-num{
  font-family:var(--serif);font-size:2.5rem;font-weight:400;font-style:italic;
  color:var(--rose);line-height:1;margin-bottom:1rem;
}
.step h3{font-family:var(--serif);font-size:1.15rem;font-weight:400;font-style:italic;margin-bottom:0.75rem;color:var(--ink)}
.step p{font-size:0.85rem;color:var(--muted);line-height:1.8}

/* ── TESTIMONIALS ── */
.client-love{background:var(--blush);padding:3.5rem 6rem;border-top:1px solid var(--border)}
.testimonials-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:1.75rem}
.testi{
  background:#fff;
  padding:2rem 1.75rem;
  border:1px solid var(--border);
  position:relative;
}
.testi::before{
  content:'\201C';
  font-family:var(--serif);font-size:4rem;color:var(--rose);
  position:absolute;top:0.5rem;left:1.25rem;line-height:1;opacity:0.5;
}
.testi-text{
  font-family:var(--serif);font-size:1rem;font-weight:400;
  font-style:italic;line-height:1.7;color:var(--ink);
  margin-bottom:1.25rem;padding-top:1.25rem;
}
.testi-attr{font-size:0.68rem;letter-spacing:0.1em;text-transform:uppercase;color:var(--dusty)}

/* ── OFFER ── */
.offer-section{padding:4rem 6rem;text-align:center}
.offer-block{
  max-width:620px;margin:0 auto;
  border:1px solid var(--border);
  background:#fff;
  padding:4rem 3.5rem;
  position:relative;
}
.offer-block::before{
  content:'';position:absolute;inset:8px;
  border:1px solid var(--rose);opacity:0.4;pointer-events:none;
}
.offer-price{
  font-family:var(--serif);font-size:4.5rem;font-weight:400;
  line-height:1;margin:1.25rem 0 0.25rem;color:var(--ink);
}
.offer-price sup{font-size:1.8rem;vertical-align:super}
.offer-label{
  font-size:0.65rem;letter-spacing:0.25em;text-transform:uppercase;
  color:var(--dusty);margin-bottom:1.75rem;display:block;
}
.offer-title{font-family:var(--serif);font-size:1.5rem;font-weight:400;font-style:italic;margin-bottom:1rem;color:var(--ink)}
.offer-desc{font-size:0.9rem;color:var(--muted);max-width:420px;margin:0 auto 2.5rem;line-height:1.9}
.offer-note{font-size:0.78rem;color:var(--dusty);margin-top:1.5rem;font-style:italic}

/* ── LIMITED ── */
.limited-band{
  background:var(--ink);padding:3.5rem 6rem;text-align:center;
  position:relative;overflow:hidden;
}
.limited-band::before{content:'';position:absolute;inset:0;background:url('/images/hero-bg.jpg') center/cover;opacity:0.06}
.limited-band .section-label{color:var(--rose);position:relative;z-index:1}
.limited-band .section-title{color:#fff;position:relative;z-index:1;margin-bottom:0.75rem}
.limited-band p{color:rgba(255,255,255,0.55);max-width:450px;margin:0 auto 2.5rem;font-size:0.9rem;line-height:1.85;position:relative;z-index:1}.limited-band .btn{position:relative;z-index:2}

/* ── FILTER ── */
.filter-section{
  text-align:center;padding:3rem 6rem;
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  background:var(--blush);
}
.filter-section p{
  font-family:var(--serif);font-size:1.3rem;font-style:italic;
  color:var(--muted);max-width:480px;margin:0 auto;line-height:1.55;
}

/* ── CLOSING ── */
.closing{text-align:center;padding:4rem 6rem}
.closing-text{
  font-family:var(--serif);
  font-size:clamp(1.6rem,2.8vw,2.4rem);
  font-weight:400;font-style:italic;
  max-width:560px;margin:0 auto 1.5rem;line-height:1.35;color:var(--ink);
}
.closing-sub{color:var(--muted);font-size:0.9rem;margin-bottom:2.5rem}

/* ── FOOTER ── */
footer{
  background:var(--ink);
  padding:3rem 4rem;
  display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1.5rem;
}
.footer-logo{font-family:var(--serif);font-size:1.1rem;font-style:italic;color:rgba(255,255,255,0.7);text-decoration:none}
.footer-links{display:flex;gap:2rem;list-style:none}
.footer-links a{font-size:0.68rem;letter-spacing:0.12em;text-transform:uppercase;color:rgba(255,255,255,0.45);text-decoration:none;transition:color 0.2s}
.footer-links a:hover{color:#fff}
.footer-copy{font-size:0.7rem;color:rgba(255,255,255,0.3)}

/* ── PAGE HERO ── */
.page-hero{padding:7rem 6rem 3rem;border-bottom:1px solid var(--border)}
.page-hero-inner{max-width:1000px;margin:0 auto}
.page-hero h1{font-family:var(--serif);font-size:clamp(2.4rem,4vw,3.4rem);font-weight:400;font-style:italic;max-width:620px;line-height:1.15;color:var(--ink)}
.page-hero p{color:var(--muted);max-width:500px;margin-top:1.25rem;font-size:0.97rem;line-height:1.9}

/* ── ABOUT PAGE ── */
.about-wrap{max-width:1000px;margin:0 auto;padding:3.5rem 0}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:6rem;align-items:start}
.about-body p{font-size:0.97rem;color:var(--muted);margin-bottom:1.5rem;line-height:1.9}
.about-body p.lead{font-family:var(--serif);font-size:1.45rem;font-weight:400;font-style:italic;color:var(--ink);line-height:1.4;margin-bottom:2rem}
.about-body p.statement{font-family:var(--serif);font-size:1.1rem;font-weight:400;font-style:italic;color:var(--ink);margin-bottom:1.75rem}
.about-img-wrap{position:sticky;top:8rem}
.about-img-frame{
  position:relative;display:inline-block;width:100%;
}
.about-img-frame img{
  width:100%;display:block;
  clip-path:ellipse(50% 50% at 50% 50%);
  aspect-ratio:3/4;object-fit:cover;object-position:center top;
}
.about-img-frame::after{
  content:'';
  position:absolute;inset:-14px;
  border:1px solid var(--rose);
  clip-path:ellipse(50% 50% at 50% 50%);
  pointer-events:none;
}

/* ── FAQ ── */
.faq-wrap{max-width:1140px;margin:0 auto}
.faq-list{max-width:680px;padding:2.5rem 0}
.faq-item{border-bottom:1px solid var(--border);padding:1.75rem 0}
.faq-q{
  font-family:var(--serif);font-size:1.15rem;font-weight:400;font-style:italic;
  cursor:pointer;display:flex;justify-content:space-between;align-items:flex-start;
  gap:1rem;color:var(--ink);background:none;border:none;width:100%;text-align:left;
}
.faq-q .icon{font-size:1.3rem;color:var(--dusty);flex-shrink:0;transition:transform 0.3s;font-family:var(--serif);font-style:normal}
.faq-a{display:none;font-size:0.93rem;color:var(--muted);padding-top:1rem;line-height:1.9}
.faq-item.open .faq-a{display:block}
.faq-item.open .icon{transform:rotate(45deg)}

/* ── BOOKING ── */
.booking-wrap{max-width:1140px;margin:0 auto;padding:4.5rem 0;display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:start}
.booking-info h2{font-family:var(--serif);font-size:2.4rem;font-weight:400;font-style:italic;margin-bottom:1.25rem;color:var(--ink)}
.booking-info p{font-size:0.88rem;color:var(--muted);line-height:1.9;margin-bottom:0.85rem}
.booking-info ul{list-style:none;margin-top:1.5rem}
.booking-info li{font-size:0.85rem;color:var(--muted);padding:0.65rem 0;border-bottom:1px solid var(--border);display:flex;gap:0.75rem}
.booking-info li::before{content:'✦';color:var(--dusty);flex-shrink:0;font-size:0.6rem;margin-top:0.35rem}

/* ── FORM ── */
.form-group{margin-bottom:1.65rem}
.form-group label{display:block;font-size:0.65rem;letter-spacing:0.18em;text-transform:uppercase;color:var(--muted);margin-bottom:0.6rem;font-weight:400}
.form-group input,.form-group select,.form-group textarea{
  width:100%;padding:0.85rem 1rem;
  background:#fff;border:1px solid var(--border);
  font-family:var(--sans);font-size:0.92rem;font-weight:300;
  color:var(--ink);outline:none;transition:border-color 0.2s;
  -webkit-appearance:none;
}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--dusty)}
.form-group textarea{resize:vertical;min-height:110px}
.form-group select{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='7' viewBox='0 0 10 7'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%238a7570' stroke-width='1.2' fill='none'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 1rem center;background-color:#fff;
}
.form-note{font-size:0.75rem;color:var(--dusty);margin-top:0.4rem;font-style:italic}
.form-terms{font-size:0.78rem;color:var(--muted);margin:1.5rem 0;line-height:1.8}
.form-terms a{color:var(--accent);text-decoration:underline}
.secure-note{display:flex;align-items:center;gap:0.5rem;font-size:0.7rem;color:var(--dusty);margin-top:0.85rem}

/* ── CALENDAR ── */
.cal-container{border:1px solid var(--border);overflow:hidden;margin-bottom:1.75rem;background:#fff}
.cal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--border);background:var(--blush)}
.cal-nav{background:none;border:1px solid var(--border);width:30px;height:30px;cursor:pointer;font-size:1rem;color:var(--muted);display:flex;align-items:center;justify-content:center;transition:all 0.2s}
.cal-nav:hover{border-color:var(--accent);color:var(--accent)}
.cal-month{font-family:var(--serif);font-size:1rem;font-weight:400;font-style:italic;color:var(--ink)}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr)}
.cal-day-name{font-size:0.6rem;letter-spacing:0.08em;text-transform:uppercase;color:var(--dusty);padding:0.65rem 0;border-bottom:1px solid var(--border);text-align:center;font-weight:400}
.cal-day{aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:0.82rem;cursor:default;border-right:1px solid var(--border);border-bottom:1px solid var(--border);transition:all 0.15s;color:var(--muted)}
.cal-day:nth-child(7n){border-right:none}
.cal-day.empty{pointer-events:none}
.cal-day.available{color:var(--ink);cursor:pointer}
.cal-day.available:hover{background:var(--blush);color:var(--accent)}
.cal-day.selected{background:var(--accent);color:#fff}
.cal-day.past{opacity:0.28;pointer-events:none}
.time-slots{padding:1.25rem;border-top:1px solid var(--border);background:var(--blush)}
.time-slots-label{font-size:0.62rem;letter-spacing:0.15em;text-transform:uppercase;color:var(--dusty);margin-bottom:0.75rem;display:block}
.slots-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0.5rem}
.slot{padding:0.55rem;border:1px solid var(--border);font-size:0.78rem;text-align:center;cursor:pointer;color:var(--muted);transition:all 0.15s;background:#fff;font-family:var(--sans)}
.slot:hover,.slot.selected{background:var(--accent);color:#fff;border-color:var(--accent)}

/* ── TERMS ── */
.terms-wrap{max-width:1000px;margin:0 auto;padding:3rem 0}
.terms-body{max-width:700px}
.terms-body h2{font-family:var(--serif);font-size:1.35rem;font-weight:400;font-style:italic;margin:2.5rem 0 0.85rem;color:var(--ink)}
.terms-body p,.terms-body li{font-size:0.92rem;color:var(--muted);line-height:1.9;margin-bottom:0.85rem}
.terms-body ul{padding-left:1.25rem;margin-bottom:1rem}
.terms-body li{margin-bottom:0.4rem}
.terms-body strong{color:var(--ink);font-weight:500}

/* ── APPLY ── */
.apply-wrap{max-width:1000px;margin:0 auto;padding:3rem 0;display:grid;grid-template-columns:1fr 1fr;gap:3.5rem}
.apply-info h2{font-family:var(--serif);font-size:2.4rem;font-weight:400;font-style:italic;margin-bottom:1.25rem;color:var(--ink)}
.apply-info p{font-size:0.9rem;color:var(--muted);line-height:1.9;margin-bottom:1rem}

/* ── SUCCESS ── */
.success-wrap{min-height:70vh;display:flex;align-items:center;justify-content:center;text-align:center;padding:8rem 2rem 4rem;max-width:560px;margin:0 auto}
.success-wrap h1{font-family:var(--serif);font-size:2.5rem;font-weight:400;font-style:italic;margin-bottom:1rem;color:var(--ink)}
.success-wrap p{color:var(--muted);margin-bottom:2rem;font-size:0.95rem;line-height:1.9}

/* ── RESPONSIVE ── */
@media(max-width:960px){
  nav{padding:1.25rem 1.75rem}
  .nav-links,.nav-cta{display:none}
  .hamburger{display:flex}
  .hero{grid-template-columns:1fr;min-height:auto}
  .hero-left{padding:7rem 2rem 3rem}
  .hero-right{height:55vw;max-height:420px}
  .hero-right::after{background:linear-gradient(to bottom,var(--cream) 0%,transparent 25%)}
  .hero-scroll{display:none}
  section{padding:3rem 2rem}
  .page-hero{padding:7rem 2rem 2.5rem}
  .brand-statement{padding:3rem 2rem}
  .guide-section{padding:3rem 2rem}
  .guide-inner{grid-template-columns:1fr;gap:3rem}
  .guide-img-wrap{max-width:280px;margin:0 auto}
  .guide-img-wrap img{clip-path:ellipse(50% 50% at 50% 50%)}
  .guide-img-frame{clip-path:ellipse(50% 50% at 50% 50%)}
  .services-band{padding:3rem 2rem}
  .services-grid{grid-template-columns:1fr;gap:1rem}
  .two-col{grid-template-columns:1fr;gap:3rem}
  .steps{grid-template-columns:1fr;gap:1.5rem}
  .client-love{padding:3rem 2rem}
  .testimonials-grid{grid-template-columns:1fr;gap:1.25rem}
  .offer-section{padding:3rem 2rem}
  .offer-block{padding:2.5rem 1.5rem}
  .limited-band{padding:3rem 2rem}
  .filter-section{padding:2.5rem 2rem}
  .closing{padding:3rem 2rem}
  footer{padding:2rem 1.75rem;flex-direction:column;align-items:flex-start}
  .about-wrap{padding:3rem 0}
  .about-grid{grid-template-columns:1fr;gap:3rem}
  .about-img-wrap{position:static;max-width:300px;margin:0 auto}
  .booking-wrap,.apply-wrap{grid-template-columns:1fr;gap:3rem;padding:2.5rem 0}
  .slots-grid{grid-template-columns:repeat(4,1fr)}
  .terms-wrap{padding:2.5rem 0}
  .faq-list{padding:2.5rem 0}
}
@media(max-width:500px){
  .hero h1{font-size:2rem}
  .offer-price{font-size:3.2rem}
  .slots-grid{grid-template-columns:repeat(3,1fr)}
}

/* ── BOOK FULL HEIGHT LAYOUT ── */
.book-full{
  display:grid;
  grid-template-columns:380px 1fr;
  min-height:calc(100vh - 80px);
  border-top:1px solid var(--border);
}
.book-left{
  padding:2.5rem 3rem;
  border-right:1px solid var(--border);
  display:flex;flex-direction:column;gap:0;
}
.book-left h2{
  font-family:var(--serif);font-size:2.4rem;font-weight:400;
  font-style:italic;margin-bottom:1.5rem;color:var(--ink);line-height:1.25;
}
.book-left p{font-size:0.88rem;color:var(--muted);line-height:1.9;margin-bottom:1rem}
.book-list{list-style:none;margin:0.5rem 0 2rem}
.book-list li{
  font-size:0.85rem;color:var(--muted);padding:0.65rem 0 0.65rem 1.75rem;
  border-bottom:1px solid var(--border);display:flex;gap:0.6rem;position:relative;
}
.book-list li::before{content:'✦';position:absolute;left:0;color:var(--dusty);font-size:0.55rem;top:50%;transform:translateY(-50%)}
.book-contact{font-size:0.8rem!important;color:var(--muted);margin-top:auto!important}
.book-contact a{color:var(--accent);text-decoration:none}
.book-right{
  display:flex;flex-direction:column;
  background:#fff;
  overflow:hidden;
}
.book-right iframe{flex:1}
@media(max-width:960px){
  .book-full{grid-template-columns:1fr;min-height:auto}
  .book-left{padding:2.5rem 2rem;border-right:none;border-bottom:1px solid var(--border)}
  .book-right iframe{min-height:600px}
}

/* ── 4-CARD SERVICE GRID ── */
.services-grid-4{grid-template-columns:repeat(4,1fr)}
@media(max-width:960px){.services-grid-4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:500px){.services-grid-4{grid-template-columns:1fr}}
