  :root{--petal:#F3D4CA;--cream:#FCF9F4;--white:#FFFFFF;--ink:#584f4c;--shadow-sm:0 6px 18px rgba(0,0,0,.05);--shadow-md:0 14px 40px rgba(0,0,0,.08)}
*{box-sizing:border-box}
body{margin:0;background:var(--cream);color:var(--ink);font-family:"Afacad",system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,"Helvetica Neue",Arial,sans-serif;font-size:16px;line-height:1.6;-webkit-tap-highlight-color:transparent}
a{color:inherit;text-decoration:none}
.container{width:min(1100px,92vw);margin-inline:auto}
header{position:sticky;top:0;z-index:10;background:#fff;border-bottom:1px solid rgba(0,0,0,.05);backdrop-filter:saturate(140%) blur(6px)}
.nav{display:flex;align-items:center;justify-content:space-between;padding:10px 0;gap:.6rem}
.logo{display:flex;align-items:center;text-decoration:none;gap:.6rem}
.header-logo{height:clamp(28px,6vw,44px);width:auto;display:block}
.header-right{display:flex;align-items:center;gap:.6rem;min-height:calc(28px + .8rem)}
@media (max-width:760px){.nav{padding:8px 0}.header-logo{height:clamp(24px,6vw,32px)}}
.hero{position:relative;padding:28px 0}
.hero-card{border-radius:28px;background:var(--petal);color:var(--white);box-shadow:var(--shadow-md);padding:20px;text-align:center}
.hero-card h1{margin:0;font-size:clamp(20px,5vw,34px);line-height:1.2}
.grid2{display:grid;grid-template-columns:1fr;gap:12px}
.card{background:#fff;border-radius:20px;padding:16px;box-shadow:var(--shadow-sm)}
.section{margin-top:14px}
.section--flush{margin-top:0}
.section-title--flush{margin-top:0}
.date-field-wrap{margin-bottom:1rem}
h2{font-size:20px;margin:0 0 10px;text-transform:uppercase}
.section-heading{display:flex;align-items:center;justify-content:space-between;gap:12px;margin:0 0 10px}
.section-heading h2{margin:0}
.booking-help{position:relative;margin-left:auto}
.booking-help summary{list-style:none;width:32px;height:32px;border:2px solid var(--petal);border-radius:50%;display:flex;align-items:center;justify-content:center;background:#fff;color:var(--ink);font-weight:700;line-height:1;cursor:pointer}
.booking-help summary::-webkit-details-marker{display:none}
.booking-help summary:focus-visible{outline:none;box-shadow:0 0 0 3px rgba(243,212,202,.55)}
.booking-help-panel{position:absolute;right:0;top:calc(100% + 8px);z-index:20;width:min(310px,calc(100vw - 48px));padding:.85rem 1rem;background:#fff;border:1px solid var(--petal);border-radius:14px;box-shadow:0 12px 30px rgba(0,0,0,.12);font-size:15px;line-height:1.4;text-transform:none;font-weight:500}
label{font-weight:600}
input,textarea{width:100%;padding:0.9rem 1rem;border-radius:12px;border:1px solid rgba(0,0,0,.12);background:#fff;font:inherit}
input,textarea,button{font-size:16px}
.services{display:grid;gap:10px}
.service-category{margin-bottom:18px}
.category-title{
  margin:0 0 12px;
  font-size:20px;
  line-height:1.2;
  font-weight:700;
  cursor:pointer;
  user-select:none;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}
.category-title::after{
  content:'▾';
  font-size:18px;
  transition:transform .2s ease;
}
.service-category.collapsed .category-title::after{
  transform:rotate(-90deg);
}
.category-services{
  display:grid;
  gap:10px;
}
.service{
  display:grid;
  grid-template-columns:26px 1fr auto;
  gap:12px;
  align-items:center;
  border:1px solid rgba(0,0,0,.06);
  border-radius:14px;
  padding:14px;
  margin:0;
  background:#fff;
  transition:border-color .15s ease, box-shadow .15s ease, background .15s ease;
}
.service:hover{border-color:rgba(0,0,0,.12);box-shadow:0 4px 14px rgba(0,0,0,.04)}
.service--blocked{opacity:.45;pointer-events:none;cursor:not-allowed}
.service--blocked:hover{border-color:rgba(0,0,0,.06);box-shadow:none}
.service:has(input[type=checkbox]:checked){
  border-color:var(--petal);
  background:#FFF8F4;
}
.service input[type=checkbox],
.consent input[type=checkbox],
.parking-row input[type=checkbox]{
  justify-self:center;
  align-self:center;
  width:13px;height:13px;
  border-radius:3px;
  border:1.25px solid rgba(0,0,0,.28);
  background:#fff;
  appearance:none;
  -webkit-appearance:none;
  cursor:pointer;
  margin:0;
  transition:background .15s ease,border-color .15s ease,transform .08s ease,box-shadow .15s ease;
  padding:0.6rem !important;
}
.service input[type=checkbox]:active,
.consent input[type=checkbox]:active,
.parking-row input[type=checkbox]:active{transform:scale(.94)}
.service input[type=checkbox]:checked,
.consent input[type=checkbox]:checked,
.parking-row input[type=checkbox]:checked{
  background-color:var(--petal);
  border-color:var(--petal);
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24'><path fill='%23111' d='M9.2 16.2 5.7 12.7l1.4-1.4 2.1 2.1 7.7-7.7 1.4 1.4z'/></svg>");
  background-repeat:no-repeat;
  background-position:center;
  background-size:82%;
}
.service input[type=checkbox]:focus-visible,
.consent input[type=checkbox]:focus-visible,
.parking-row input[type=checkbox]:focus-visible{outline:none;box-shadow:0 0 0 3px rgba(243,212,202,.55)}
.service-body{display:flex;flex-direction:column;gap:4px;min-width:0}
.service-name{font-weight:600;line-height:1.3;min-width:0;word-wrap:break-word;overflow-wrap:anywhere}
.service-meta{display:flex;flex-wrap:nowrap;justify-content:flex-end;gap:6px;align-self:center;flex-shrink:0}
.service-description{
  font-size:.95em;
  color:rgba(88,79,76,.78);
  line-height:1.45;
  margin-top:2px;
}
.service-description .desc-text{white-space:pre-wrap}
.service-pack-note{
  grid-column:2 / -1;
  justify-self:start;
  display:inline-flex;
  align-items:center;
  max-width:100%;
  margin-top:8px;
  padding:.2rem .8rem;
  background:#FCEDE5;
  border-radius:999px;
  color:var(--ink);
  font-weight:600;
  font-size:.95em;
  line-height:1.2;
}
.service-pack-note--extra{display:none}
.service:has(input[type=checkbox]:checked) .service-pack-note--extra{display:inline-flex}
.service:has(.service-description[data-collapsed="0"]) .service-pack-note--extra{display:inline-flex}
.desc-toggle{
  background:none;
  border:none;
  color:var(--ink);
  text-decoration:underline;
  text-underline-offset:2px;
  cursor:pointer;
  padding:0;
  margin-left:4px;
  font:inherit;
  font-size:.95em;
  font-weight:600;
}
.desc-toggle:hover{opacity:.75}
.badge{display:inline-block;padding:.2rem .8rem;border-radius:999px;background:#F3D4CA;white-space:nowrap;line-height:1.2;font-size:.95em}
.badge-price{background:#FCEDE5;font-weight:600}
.totals{background:#FCEDE5;border-radius:12px;padding:.8rem 1rem;display:flex;flex-direction:column;gap:6px}
.totals-row{display:flex;justify-content:space-between;align-items:center;gap:12px}
.totals-label{opacity:.75}
.totals-value{font-weight:600;display:inline-flex;align-items:baseline;gap:8px}
.totals-strike{font-weight:400;text-decoration:line-through;opacity:.55}
#services{overflow:visible}
.section-separator{border:0;height:1px;background:rgba(0,0,0,.08);margin:22px auto;width:60%}
.parking-box{display:flex;align-items:center;justify-content:space-between;gap:12px;background:#FCEDE5;border:1px solid #F3D4CA;border-radius:14px;padding:.85rem 1rem;margin-top:14px}
.parking-row{display:flex;align-items:center;gap:12px;cursor:pointer;flex:1;margin:0}
.combo-banners{display:flex;flex-direction:column;gap:8px;margin-top:14px}
.combo-banner{border-radius:12px;padding:.85rem 1rem;line-height:1.35;border:2px solid #E8B7A8;background:#FCEDE5}
.combo-banner--applied{background:#F3D4CA;border-color:#D9A696}
.show-people-tabs{width:100%;min-height:44px;margin:0 0 14px;border:1px solid var(--petal);border-radius:14px;background:#fff;color:var(--ink);font:inherit;font-weight:700;cursor:pointer}
.show-people-tabs:hover{background:#FFF8F4}
.show-people-tabs[hidden]{display:none}
.person-tabs{display:grid;grid-template-columns:repeat(2,1fr);gap:6px;margin:0 0 14px;padding:6px;background:#FCEDE5;border-radius:16px}
.person-tabs[hidden]{display:none}
.person-tab{appearance:none;border:0;background:transparent;border-radius:12px;min-height:44px;padding:.65rem .7rem;font:inherit;font-weight:700;white-space:nowrap;cursor:pointer;color:var(--ink)}
.person-tab[aria-selected="true"]{background:#fff;color:#111;box-shadow:0 4px 14px rgba(0,0,0,.06)}
.person-service-panel[hidden]{display:none}
.person-card{border:1px solid rgba(0,0,0,.08);border-radius:16px;padding:14px;background:#fff;margin-bottom:14px}
.person-card[hidden]{display:none}
.person-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}
.person-title{font-size:18px;font-weight:700;margin:0}
.person-summary{display:flex;flex-direction:column;gap:4px;margin-top:6px;font-size:18px;line-height:1.35;opacity:.84}
.person-summary-empty{opacity:.68}
.person-summary-item{overflow-wrap:anywhere;font-weight:600}
.person-fields{display:grid;gap:12px}
.person-fields .section{margin-top:0}
.person-notes{resize:none}
.slots{display:flex;flex-wrap:wrap;gap:10px;margin-top:8px}
#slots{display:block}
.slot-section{margin-top:12px}
.slot-section-title{font-size:16px;font-weight:700;margin:0 0 8px}
.slot-section-hint{font-size:14px;opacity:.72;margin:-4px 0 8px}
.slot input{display:none}
.slot label{display:inline-block;border:1px solid rgba(0,0,0,.12);border-radius:999px;padding:.7rem 1rem;cursor:pointer}
.slot input:checked + label{background:var(--petal);border-color:var(--petal);color:#111}
.slot--nearby label{border-radius:14px;text-align:left;line-height:1.35}
.row{display:grid;grid-template-columns:1fr;gap:12px}
.row>div{min-width:0}
input,textarea{max-width:100%}
input[type="date"]{
  width:100%;
  max-width:100%;
  min-height:44px;
  appearance:none;
  -webkit-appearance:none;
  background:#fff
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='22' height='22' viewBox='0 0 24 24'><path fill='%23584f4c' d='M7 2h2v2h6V2h2v2h3v18H4V4h3V2zm12 6H5v12h14V8zm-2 3v2H7v-2h10z'/></svg>")
    no-repeat right 12px center;
  padding-right:44px;
  font:inherit;
  color:inherit;
  line-height:1.2;
  letter-spacing:.2px;
  caret-color:#111;
  border:1px solid rgba(0,0,0,.12);
  border-radius:12px;
}
input[type="date"]::-webkit-date-and-time-value{text-align:left;min-height:1.2em;font:inherit;color:inherit}
input[type="date"]::-webkit-datetime-edit{padding:0}
input[type="date"]::-webkit-datetime-edit-fields-wrapper{padding:0}
input[type="date"]::-webkit-datetime-edit-year-field,
input[type="date"]::-webkit-datetime-edit-month-field,
input[type="date"]::-webkit-datetime-edit-day-field{padding:0 .1em}
input[type="date"]::-webkit-calendar-picker-indicator{
  opacity:0;
}
input[type="date"]::-webkit-inner-spin-button,
input[type="date"]::-webkit-clear-button{display:none}
.btn{display:inline-block;width:100%;padding:1rem 1.2rem;border-radius:999px;border:1px solid rgba(0,0,0,.08);background:var(--petal);color:inherit;cursor:pointer;box-shadow:none;font-weight:700}
.btn:active{transform:scale(.99)}
.btn:disabled{opacity:.55;cursor:not-allowed}
.actions{display:flex;justify-content:center;margin-top:1.25rem}
.actions-mobile{display:none}
.consent{display:flex;align-items:center;gap:10px}
.consent span{line-height:1.4;display:inline-block}
.privacy-link{text-decoration:underline}
footer{padding:28px 0 56px;text-align:center;color:#7b6f6b}
.message{margin-top:2rem;font-size:18px;text-align:center;}
.message--error{color:#b3261e}
.message--info{color:#584f4c;font-size:1.02rem;font-weight:500}
[hidden]{display:none !important}
@media (max-width:480px){
  .service{padding:12px;gap:10px;grid-template-columns:26px 1fr}
  .service-meta{grid-column:2 / -1;justify-content:flex-start;align-self:start;margin-top:6px}
  .category-title{font-size:20px}
}
@media (min-width:640px){
  body{font-size:17px}
  .row{grid-template-columns:1fr 1fr}
  .btn{width:auto;min-width:220px}
}
@media (min-width:860px){
  .hero{padding:40px 0}
  .hero-card{padding:32px}
  .grid2{grid-template-columns:1.1fr .9fr;gap:16px}
  .card{padding:20px;border-radius:24px}
  .sticky-parent{position:relative}
  .sticky-child{position:sticky;top:calc(65px + 16px)}
  .sticky-child #services.is-overflowing{overflow-y:auto;overflow-x:hidden;overscroll-behavior:contain}
}
@media (max-width:859px){
  #services{overflow:visible !important;max-height:none !important;height:auto !important}
  .sticky-child,.sticky-parent{position:static !important;max-height:none !important;display:block !important}
  .actions{display:none !important}
  .actions-mobile{display:flex !important;position:fixed !important;left:0;right:0;bottom:0;z-index:9999;padding:12px 16px calc(12px + env(safe-area-inset-bottom));background:rgba(252,249,244,.96);backdrop-filter:saturate(1.2) blur(8px);-webkit-backdrop-filter:saturate(1.2) blur(8px);border-top:1px solid rgba(0,0,0,.06);box-shadow:0 -4px 18px rgba(0,0,0,.05);justify-content:center}
  .actions-mobile .btn{width:100%;max-width:520px}
  body.has-floating-cta{padding-bottom:calc(96px + env(safe-area-inset-bottom))}
}
@media (prefers-reduced-motion:reduce){
  *{scroll-behavior:auto !important}
}
html{scroll-behavior:smooth}
