:root {
  --bg: #EEF1F4;
  --bg-strong: #E6EAEF;
  --surface: #F7F8FA;
  --surface-strong: rgba(255, 255, 255, 0.85);
  --text: #1F2933;
  --muted: #5B6773;
  --line: #D7DEE5;
  --line-strong: #C4CED8;
  --accent: #7E96AA;
  --accent-hover: #657D91;
  --accent-soft: #E3EAF0;
  --error: #D35B5B;
  --error-soft: rgba(211, 91, 91, 0.1);
  --shadow: 0 16px 48px rgba(31, 41, 51, 0.06);
  --radius-xl: 36px;
  --radius-lg: 24px;
  --radius-md: 18px;
  --container: 1180px;
  --ease: cubic-bezier(.16,1,.3,1);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}

body {
  margin: 0;
  font-family: "Manrope", sans-serif;
  color: var(--text);
  background:
    radial-gradient(circle at top left, rgba(126, 150, 170, 0.06), transparent 35%),
    linear-gradient(180deg, var(--bg) 0%, #E8ECEF 100%);
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  background-image:
    linear-gradient(rgba(255, 255, 255, 0.5) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, 0.4) 1px, transparent 1px);
  background-size: 100% 100%, 72px 72px;
  opacity: 0.15;
  mix-blend-mode: soft-light;
}

a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}

.page-shell {
  width: min(calc(100% - 32px), var(--container));
  margin: 0 auto;
  padding: 24px 0 40px;
}

/* ===== HEADER ===== */
.site-header {
  position: sticky;
  top: 16px;
  z-index: 20;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 24px;
  padding: 16px 20px;
  margin-bottom: 28px;
  border: 1px solid rgba(255, 255, 255, 0.7);
  border-radius: 999px;
  background: rgba(245, 241, 234, 0.72);
  backdrop-filter: blur(18px);
  box-shadow: 0 16px 40px rgba(38, 29, 21, 0.08);
}

.brand{display:inline-flex;align-items:center;gap:14px;min-width:0}
.brand img{width:48px;height:48px;object-fit:contain;border-radius:14px;background:rgba(255,255,255,.5);padding:4px}
.brand div{display:grid}

.brand-mark,.eyebrow,.note-label,.role,.visit-label,.service-card-note strong{letter-spacing:.08em;text-transform:uppercase}
.brand-mark{font-size:.95rem;font-weight:800}
.brand-copy{color:var(--muted);font-size:.82rem}

.site-nav{display:inline-flex;justify-content:center;gap:24px;flex-wrap:wrap}
.site-nav a{color:var(--muted);font-size:.95rem}
.site-nav a:hover,.hero-card-bottom a:hover,.button-secondary:hover{color:var(--text)}

/* ===== BUTTONS ===== */
.button{display:inline-flex;align-items:center;justify-content:center;gap:10px;min-height:48px;padding:0 22px;border-radius:999px;border:1px solid transparent;font-weight:700;transition:transform 180ms ease,background-color 180ms ease,border-color 180ms ease}
.button:hover{transform:translateY(-1px)}
.button-primary{background:var(--accent);color:#fff7f2;box-shadow:0 12px 28px rgba(168,85,60,.24)}
.button-primary:hover{background:#944631}
.button-secondary{border-color:var(--line-strong);background:rgba(255,255,255,.45)}
.button-block{width:100%}

.section{margin-bottom:28px}

/* ===== HERO ===== */
.hero{display:grid;grid-template-columns:minmax(0,1.05fr) minmax(320px,.95fr);gap:24px;align-items:stretch}

.hero-copy,.hero-visual,.intro-strip,.feature-band,.booking-card{border:1px solid rgba(255,255,255,.72);background:linear-gradient(180deg,var(--surface-strong),var(--surface));box-shadow:var(--shadow);backdrop-filter:blur(12px)}

.hero-copy,.hero-card,.intro-strip,.section-grid,.feature-band,.booking-card{border-radius:var(--radius-xl)}

.hero-copy{padding:44px}

.eyebrow,.note-label,.role{margin:0 0 14px;color:var(--muted);font-size:.74rem;font-weight:800}

h1,h2,h3{margin:0;font-family:"Fraunces",serif;font-weight:600;line-height:.98}
h1{max-width:10ch;font-size:clamp(3rem,8vw,6.5rem)}
h2{max-width:11ch;font-size:clamp(2.2rem,5vw,4.2rem)}
h3{font-size:1.45rem;line-height:1.05}

.lede,.feature-copy p:last-child,.booking-copy p:last-child{max-width:56ch;margin:22px 0 0;color:var(--muted);font-size:1.06rem;line-height:1.7}

.hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin:28px 0 34px}

.hero-notes{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}
.hero-notes div,.feature-point,.team-card,.service-card,.booking-card{padding:18px;border:1px solid var(--line);border-radius:var(--radius-md);background:rgba(255,255,255,.42)}
.hero-notes strong,.service-card strong{display:block;line-height:1.5}

.hero-visual{position:relative;overflow:hidden;padding:18px}
.hero-visual::before,.map-card::before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(126,150,170,.12),transparent 44%),radial-gradient(circle at bottom right,rgba(31,41,51,.08),transparent 38%)}

.hero-card{position:relative;z-index:1;display:grid;align-content:space-between;min-height:100%;padding:26px;background:linear-gradient(180deg,rgba(31,41,51,.02),rgba(31,41,51,.01)),linear-gradient(145deg,rgba(255,255,255,.85),rgba(255,255,255,.4));border:1px solid rgba(255,255,255,.8)}
.hero-card-top,.hero-card-bottom{display:flex;justify-content:space-between;gap:16px;color:var(--muted);font-size:.92rem}
.hero-card img{width:min(100%,380px);margin:18px auto;filter:drop-shadow(0 24px 36px rgba(31,41,51,.15))}
.hero-card-bottom{align-items:end}
.hero-card-bottom p{max-width:22ch;margin:0;line-height:1.6}
.hero-card-bottom a{font-weight:700}

/* ===== INTRO STRIP ===== */
.intro-strip{padding:24px 28px}
.intro-strip p{max-width:58ch;margin:0;font-family:"Fraunces",serif;font-size:clamp(1.35rem,2vw,1.85rem);line-height:1.25}

/* ===== SECTION GRID ===== */
.section-grid,.feature-band,.visit-section,.booking-section{display:grid;grid-template-columns:minmax(0,.86fr) minmax(0,1.14fr);gap:24px}
.section-heading{padding:18px 8px 0 6px}

.services,.team,.gallery{display:grid;gap:14px}
.services,.team{grid-template-columns:repeat(2,minmax(0,1fr))}

.service-card,.team-card{display:flex;justify-content:space-between;gap:18px;min-height:166px}
.service-card p,.team-card p,.gallery-card p,.feature-point p,.visit-grid p,.booking-note{margin:10px 0 0;color:var(--muted);line-height:1.7}
.service-card strong{font-size:1.2rem;white-space:nowrap}
.service-card-note,.team-card-note{background:linear-gradient(180deg,rgba(126,150,170,.1),rgba(255,255,255,.4))}

/* ===== FEATURE BAND ===== */
.feature-band{padding:28px;align-items:start}
.feature-points{display:grid;gap:14px}
.feature-point{display:grid;grid-template-columns:64px 1fr;align-items:start;gap:12px}
.feature-point span{font-family:"Fraunces",serif;font-size:2rem;color:var(--accent)}

/* ===== GALLERY ===== */
.gallery{grid-template-columns:repeat(3,minmax(0,1fr));grid-auto-rows:180px}
.gallery-card{position:relative;overflow:hidden;padding:22px;border:1px solid rgba(255,255,255,.75);border-radius:var(--radius-lg);background:linear-gradient(155deg,rgba(255,255,255,.8),rgba(255,255,255,.4)),linear-gradient(135deg,rgba(126,150,170,.12),rgba(31,41,51,.04));box-shadow:var(--shadow)}
.gallery-card::after{content:"";position:absolute;inset:auto -12% -26% 36%;height:160px;background:radial-gradient(circle,rgba(255,255,255,.4),transparent 65%);transform:rotate(-12deg)}
.gallery-card span{position:relative;z-index:1;display:inline-block;padding:8px 12px;border-radius:999px;background:rgba(255,255,255,.52);font-size:.8rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase}
.gallery-card p{position:relative;z-index:1;max-width:26ch}
.gallery-card.tall{grid-row:span 2}
.gallery-card.wide{grid-column:span 2}

/* Gallery images */
.gallery-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;opacity:.35;transition:opacity .4s,transform .6s var(--ease)}
.gallery-card:hover img{opacity:.5;transform:scale(1.04)}
.gallery-card span,.gallery-card p{position:relative;z-index:1}

/* ===== BOOKING ===== */
.booking-card{padding:32px}

/* ===== BOOKING SECTION ===== */
.booking-copy{padding:18px 8px 0 6px}
.booking-note{margin-bottom:0}

/* ===== BOOKING UNAVAILABLE OVERLAY ===== */
.booking-unavailable {
  text-align: center;
  padding: 48px 24px;
  border: 1px solid rgba(255,255,255,.72);
  background: linear-gradient(180deg, var(--surface-strong), var(--surface));
  box-shadow: var(--shadow);
  backdrop-filter: blur(12px);
  border-radius: var(--radius-xl);
}
.booking-unavailable h3 {
  font-size: 1.2rem;
  margin-bottom: 10px;
}
.booking-unavailable p {
  color: var(--muted);
  font-size: .92rem;
  max-width: 40ch;
  margin: 0 auto;
  line-height: 1.7;
}

/* ===== BOOKING SYSTEM (Progressive Reveal) ===== */
.booking-system{border:1px solid rgba(255,255,255,.72);background:linear-gradient(180deg,var(--surface-strong),var(--surface));box-shadow:var(--shadow);backdrop-filter:blur(12px);border-radius:var(--radius-xl);overflow:hidden}

.booking-step{padding:28px 32px;border-bottom:1px solid var(--line);transition:opacity .5s ease,max-height .6s var(--ease)}
.booking-step:last-child{border-bottom:none}
.booking-step.locked{opacity:0;max-height:0;padding:0 32px;overflow:hidden;pointer-events:none;border-bottom:none}
.booking-step.unlocked{opacity:1;max-height:2000px;pointer-events:auto}
.booking-step.hidden{display:none}

.step-header{display:flex;align-items:center;gap:14px;margin-bottom:20px}
.step-header h3{font-size:1.1rem}
.step-num{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:50%;background:var(--accent);color:#fff;font-weight:700;font-size:.82rem;flex-shrink:0}
.completed-section .step-num{background:var(--accent-soft);color:var(--accent)}

/* Service options in booking */
.svc-options{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:10px}
.svc-option{padding:18px;border:1px solid var(--line);border-radius:var(--radius-md);cursor:pointer;transition:all .25s var(--ease);display:flex;justify-content:space-between;align-items:center;background:rgba(255,255,255,.42)}
.svc-option:hover{border-color:var(--line-strong);background:rgba(255,255,255,.6);transform:translateX(3px)}
.svc-option.selected{border-color:var(--accent);background:var(--accent-soft);box-shadow:0 0 16px rgba(126,150,170,.15)}
.svc-option .svc-name{font-weight:600;font-size:.9rem}
.svc-option .svc-detail{font-size:.72rem;color:var(--muted);margin-top:3px}
.svc-option .svc-price{font-weight:700;color:var(--accent);font-size:.95rem}

/* Calendar */
.calendar-wrapper{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.calendar{background:rgba(255,255,255,.35);border-radius:var(--radius-md);padding:20px}
.cal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}
.cal-header h3{font-size:1rem}
.cal-nav{display:flex;gap:6px}
.cal-nav button{width:30px;height:30px;border-radius:50%;border:1px solid var(--line);background:none;color:var(--text);cursor:pointer;font-size:.85rem;transition:all .2s;display:flex;align-items:center;justify-content:center}
.cal-nav button:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-soft)}

.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px;text-align:center}
.cal-day-label{font-size:.65rem;color:var(--muted);font-weight:700;letter-spacing:1px;padding:6px 0}
.cal-day{width:100%;aspect-ratio:1;border:none;border-radius:50%;background:none;cursor:pointer;font-size:.82rem;font-weight:500;color:var(--text);transition:all .2s;display:flex;align-items:center;justify-content:center;font-family:inherit}
.cal-day:hover:not(.disabled):not(.empty){background:var(--accent-soft);color:var(--accent)}
.cal-day.today{border:2px solid var(--accent);font-weight:700}
.cal-day.selected{background:var(--accent)!important;color:#fff!important;font-weight:700}
.cal-day.disabled{color:var(--muted);cursor:default;opacity:.4}
.cal-day.empty{cursor:default}

/* Time slots */
#timeSlotsPanel h3{font-size:1rem;margin-bottom:6px}
.date-display{font-size:.82rem;color:var(--muted);margin-bottom:14px}
.slots-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.slots-placeholder{grid-column:1/-1;text-align:center;color:var(--muted);padding:32px 0;font-size:.85rem}

.time-slot{padding:10px;border:1px solid var(--line);border-radius:10px;background:rgba(255,255,255,.42);cursor:pointer;font-size:.82rem;font-weight:500;color:var(--text);transition:all .2s var(--ease);text-align:center;font-family:inherit}
.time-slot:hover:not(.unavailable){border-color:var(--accent);background:var(--accent-soft);color:var(--accent)}
.time-slot.selected{background:var(--accent)!important;color:#fff!important;border-color:var(--accent)!important;font-weight:700}
.time-slot.unavailable{opacity:.3;cursor:not-allowed;text-decoration:line-through}

/* Booking summary */
.booking-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:12px;margin-bottom:20px;padding:16px;background:rgba(255,255,255,.35);border-radius:var(--radius-md)}
.summary-item .label{font-size:.6rem;letter-spacing:2px;color:var(--muted);font-weight:700;text-transform:uppercase;margin-bottom:3px}
.summary-item .value{font-weight:600;font-size:.88rem}
.summary-item .value.accent{color:var(--accent)}

/* ===== FORM ===== */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-group{display:flex;flex-direction:column;gap:6px}
.form-group.full{grid-column:1/-1}
.form-group label{font-size:.78rem;font-weight:600;letter-spacing:.3px}
.form-group .required{color:var(--accent);font-weight:700}
.form-group .optional{color:var(--muted);font-weight:400;font-size:.7rem;letter-spacing:1px}
.form-group input,.form-group textarea{padding:12px 14px;border:1px solid var(--line);border-radius:10px;background:rgba(255,255,255,.5);font-family:inherit;font-size:.88rem;color:var(--text);transition:border-color .2s,box-shadow .2s;outline:none}
.form-group input:focus,.form-group textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.form-group textarea{min-height:80px;resize:vertical}
.form-group input::placeholder,.form-group textarea::placeholder{color:var(--muted)}

/* Inline form errors */
.form-group input.input-error,
.form-group textarea.input-error {
  border-color: var(--error);
  box-shadow: 0 0 0 3px var(--error-soft);
}
.field-error {
  color: var(--error);
  font-size: .75rem;
  font-weight: 500;
  min-height: 0;
  max-height: 0;
  overflow: hidden;
  opacity: 0;
  transition: all .25s ease;
  margin: 0;
}
.field-error.visible {
  min-height: 1em;
  max-height: 3em;
  opacity: 1;
  margin-top: 2px;
}

/* Booking submit error banner */
.booking-error-banner {
  background: var(--error-soft);
  border: 1px solid var(--error);
  border-radius: 10px;
  padding: 12px 16px;
  margin-bottom: 14px;
  color: var(--error);
  font-size: .85rem;
  font-weight: 500;
  text-align: center;
  display: none;
}
.booking-error-banner.visible {
  display: block;
}

.btn-confirm{width:100%;margin-top:18px;padding:16px;border:none;border-radius:999px;background:var(--accent);color:#ffffff;font-family:inherit;font-weight:700;font-size:.95rem;letter-spacing:.5px;cursor:pointer;transition:transform .2s var(--ease),background .3s,box-shadow .3s;box-shadow:0 8px 24px rgba(126,150,170,.25)}
.btn-confirm:hover{transform:translateY(-2px);background:var(--accent-hover);box-shadow:0 6px 20px rgba(126,150,170,.35)}
.btn-confirm:disabled{opacity:.5;cursor:not-allowed;transform:none}

/* ===== CONFIRMATION ===== */
.confirmation{text-align:center;padding:48px 20px}
.check-icon{width:56px;height:56px;margin:0 auto 18px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center}
.check-icon::after{content:'✓';color:#fff;font-size:1.6rem;font-weight:700}
.confirmation h2{max-width:none;font-size:1.6rem;margin-bottom:10px}
.confirmation p{color:var(--muted);font-size:.92rem;max-width:48ch;margin:0 auto;line-height:1.7}

/* Confirmation details card */
.confirm-details {
  text-align: left;
  max-width: 380px;
  margin: 24px auto 0;
  padding: 20px;
  background: rgba(255,255,255,.35);
  border-radius: var(--radius-md);
  border: 1px solid var(--line);
}
.confirm-details .detail-row {
  display: flex;
  justify-content: space-between;
  padding: 8px 0;
  border-bottom: 1px solid var(--line);
  font-size: .85rem;
}
.confirm-details .detail-row:last-child {
  border-bottom: none;
}
.confirm-details .detail-label {
  color: var(--muted);
  font-weight: 600;
  font-size: .7rem;
  letter-spacing: 1px;
  text-transform: uppercase;
}
.confirm-details .detail-value {
  font-weight: 600;
}

.confirm-actions {
  display: flex;
  gap: 10px;
  justify-content: center;
  margin-top: 20px;
  flex-wrap: wrap;
}
.btn-calendar {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 12px 20px;
  border: 1px solid var(--line-strong);
  border-radius: 999px;
  background: rgba(255,255,255,.45);
  font-family: inherit;
  font-weight: 700;
  font-size: .85rem;
  cursor: pointer;
  transition: transform 180ms ease, border-color 180ms ease;
  color: var(--text);
}
.btn-calendar:hover {
  transform: translateY(-1px);
  border-color: var(--accent);
  color: var(--accent);
}

/* ===== NOSCRIPT ===== */
.noscript-msg {
  text-align: center;
  padding: 32px 20px;
  color: var(--muted);
  font-size: .95rem;
}

/* ===== FOOTER ===== */
.site-footer {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 32px;
  padding: 64px 24px 48px;
  color: var(--muted);
  font-size: .95rem;
  line-height: 1.6;
  border-top: 1px solid rgba(0,0,0,0.05);
  margin-top: 64px;
}
.footer-col strong {
  display: block;
  margin-bottom: 12px;
  color: var(--text);
  font-weight: 600;
}
.footer-col a {
  color: inherit;
  text-decoration: none;
  transition: color 200ms ease;
}
.footer-col a:hover {
  color: var(--text);
}

/* ===== SCROLL REVEAL ===== */
/* Content is VISIBLE by default — JS enhances with animation.
   If JS fails to load, all content remains visible. */
.reveal {
  opacity: 1;
  transform: none;
}

/* Only hide for animation when JS confirms it's working */
.js-loaded .reveal {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 650ms ease, transform 650ms ease;
}
.js-loaded .reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* ===== RESPONSIVE ===== */
@media(max-width:1080px){
  .site-header,.hero,.section-grid,.feature-band,.booking-section{grid-template-columns:1fr}
  .site-header{border-radius:28px;padding:18px}
  .site-nav{justify-content:flex-start}
  .section-heading,.booking-copy{padding:0}
  .hero-copy{padding:32px}
}

@media(max-width:780px){
  .page-shell{width:min(calc(100% - 20px),var(--container));padding-top:12px}
  .site-header{position:static;gap:16px;grid-template-columns:1fr}
  .site-nav{gap:16px}
  .hero-copy,.booking-card,.feature-band{padding:24px}
  .hero-notes,.services,.team,.gallery,.site-footer{grid-template-columns:1fr}
  .gallery-card.tall,.gallery-card.wide{grid-column:auto;grid-row:auto}
  .service-card,.team-card{flex-direction:column}
  h1{max-width:12ch;font-size:clamp(2.7rem,15vw,4.2rem)}
  h2{max-width:none}
  .calendar-wrapper{grid-template-columns:1fr}
  .form-grid{grid-template-columns:1fr}
  .booking-step{padding:20px}
  .svc-options{grid-template-columns:1fr}
}

@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  .button,.js-loaded .reveal{transition:none}
  .js-loaded .reveal{opacity:1;transform:none}
}

/* Honeypot — visually hidden; bots often fill hidden “website” fields */
.booking-hp-field{position:absolute!important;width:1px!important;height:1px!important;padding:0!important;margin:-1px!important;overflow:hidden!important;clip:rect(0,0,0,0)!important;white-space:nowrap!important;border:0!important}
