.reservation-section{
  padding-top:clamp(6rem,9vw,8rem);
}

.reservation-info-panel,
.reservation-section .booking-shell{
  width:100%;
  max-width:760px;
}

.reservation-info-panel{
  display:grid;
  grid-template-columns:1fr;
  gap:clamp(1.6rem,4vw,2.7rem);
  margin:1.2rem auto clamp(3.2rem,7vw,5.4rem);
  padding:0;
}

.reservation-info-panel *{
  min-width:0;
}

.reservation-info-intro{
  display:grid;
  align-content:start;
  gap:.55rem;
  justify-items:start;
  max-width:none;
  margin-inline:auto;
  padding:0;
  text-align:left;
}

.reservation-info-intro h2{
  margin:0;
  font-size:clamp(2rem,5vw,3rem);
  line-height:1;
}

.reservation-info-intro p,
.reservation-info-grid p{
  color:var(--text-soft);
}

.reservation-manage-link{
  margin-top:.25rem;
  font-size:.9rem;
}

.reservation-info-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:1.1rem;
  max-width:none;
  margin-inline:auto;
  text-align:left;
}

.reservation-info-grid article{
  padding:0;
  border-bottom:0;
}

.reservation-info-grid h3{
  margin-bottom:.25rem;
  font-family:"Jost",sans-serif;
  font-size:1rem;
  font-weight:500;
  color:var(--color-1);
  letter-spacing:.05em;
  text-transform:uppercase;
}

.reservation-info-grid p + p{
  margin-top:.45rem;
}

.reservation-info-grid a{
  overflow-wrap:anywhere;
}

.reservation-gift-card{
  width:100%;
  max-width:860px;
  display:grid;
  grid-template-columns:minmax(0,1fr) max-content;
  gap:1rem;
  align-items:center;
  margin:0 auto 1.2rem;
  padding:clamp(1rem,3vw,1.35rem);
  border:1px solid rgba(134,78,55,.18);
  border-radius:8px;
  background:
    linear-gradient(135deg,rgba(134,78,55,.08),rgba(243,234,220,.86)),
    var(--white);
  box-shadow:0 12px 26px rgba(47,33,29,.08);
}

.reservation-gift-card h2{
  margin:.2rem 0 .35rem;
  font-size:clamp(1.55rem,3vw,2.1rem);
}

.reservation-gift-card p:not(.step-label){
  max-width:42rem;
}

.reservation-section .booking-shell{
  max-width:860px;
  grid-template-columns:1fr;
  gap:.75rem;
  padding:.9rem;
  margin-inline:auto;
}

.reservation-section .booking-shell *,
.reservation-hero *{
  min-width:0;
}

.reservation-section p,
.reservation-section li,
.reservation-section h2,
.reservation-section h3,
.reservation-section h4,
.reservation-hero p,
.reservation-hero h1{
  overflow-wrap:break-word;
  word-break:normal;
}

.reservation-section .booking-intro{
  display:none;
  position:static;
  grid-template-columns:minmax(0,.9fr) minmax(260px,.7fr);
  gap:1rem;
  align-items:start;
  padding:1rem;
  border:1px solid var(--line);
  border-radius:8px;
  background:linear-gradient(135deg,var(--color-2-light),var(--surface));
}

.reservation-section .booking-intro h2{
  max-width:11ch;
  margin-bottom:.55rem;
}

.reservation-section .booking-facts{
  gap:.45rem;
}

.reservation-section .booking-facts span{
  background:var(--white);
}

.booking-intro-copy{
  display:grid;
  gap:.65rem;
  color:var(--text-soft);
}

.booking-intro-copy p{
  font-size:.95rem;
}

.booking-points{
  display:grid;
  gap:.35rem;
  padding:0;
  margin:0;
  list-style:none;
}

.booking-points li{
  position:relative;
  padding-left:1rem;
  color:var(--dark);
  font-size:.9rem;
}

.booking-points li::before{
  content:"";
  position:absolute;
  left:0;
  top:.72em;
  width:5px;
  height:5px;
  border-radius:50%;
  background:var(--clay);
}

.booking-form{
  gap:.8rem;
}

.booking-panel,
.booking-summary-panel{
  border:1px solid var(--line);
  border-radius:8px;
  background:var(--white);
}

.booking-panel-head{
  display:grid;
  gap:.18rem;
}

.booking-panel-head h3,
.booking-summary-panel h3{
  font-size:clamp(1.45rem,3vw,2rem);
  line-height:1.05;
}

.booking-selector{
  display:grid;
  grid-template-columns:1fr;
  gap:.75rem;
  align-items:start;
}

.booking-panel{
  display:grid;
  gap:.65rem;
  padding:.9rem;
}

.booking-calendar-panel{
  grid-row:auto;
}

.booking-date-field{
  gap:.6rem;
}

.booking-date-field label{
  position:absolute;
  width:1px;
  height:1px;
  overflow:hidden;
  clip:rect(0 0 0 0);
}

.booking-date-field .flatpickr-input{
  border-color:var(--line);
  background:var(--surface);
}

.booking-calendar-panel .flatpickr-calendar{
  width:100%;
  max-width:100%;
  margin-top:.3rem;
  border:1px solid var(--line);
  border-radius:8px;
  box-shadow:none;
  background:var(--surface);
  color:var(--dark);
  font-family:"Jost",sans-serif;
  padding:.8rem;
}

.booking-calendar-panel .flatpickr-innerContainer,
.booking-calendar-panel .flatpickr-rContainer,
.booking-calendar-panel .flatpickr-days,
.booking-calendar-panel .dayContainer{
  width:100%;
  max-width:100%;
}

.booking-calendar-panel .flatpickr-months{
  padding:.2rem .2rem .7rem;
}

.booking-calendar-panel .flatpickr-months .flatpickr-month,
.booking-calendar-panel .flatpickr-weekdays{
  background:transparent;
  color:var(--dark);
}

.booking-calendar-panel .flatpickr-current-month{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:.55rem;
  width:100%;
  left:0;
  padding:0;
  font-size:1.15rem;
}

.booking-calendar-panel .flatpickr-current-month .flatpickr-monthDropdown-months,
.booking-calendar-panel .flatpickr-current-month input.cur-year{
  height:auto;
  padding:.15rem .2rem;
  color:var(--dark);
  font:inherit;
}

.booking-calendar-panel .flatpickr-weekdaycontainer,
.booking-calendar-panel .dayContainer{
  display:grid;
  grid-template-columns:repeat(7,minmax(0,1fr));
}

.booking-calendar-panel .flatpickr-weekdays{
  height:auto;
  margin-bottom:.35rem;
}

.booking-calendar-panel span.flatpickr-weekday{
  display:grid;
  place-items:center;
  height:2rem;
  color:var(--text-soft);
  font-size:.9rem;
  font-weight:500;
  text-transform:lowercase;
}

.booking-calendar-panel .dayContainer{
  min-width:100%;
  gap:.25rem 0;
}

.booking-calendar-panel .flatpickr-day{
  display:grid;
  place-items:center;
  width:100%;
  max-width:none;
  height:3rem;
  line-height:1;
  border-radius:6px;
  color:var(--dark);
  font-size:1rem;
}

.booking-calendar-panel .flatpickr-day.flatpickr-disabled,
.booking-calendar-panel .flatpickr-day.prevMonthDay,
.booking-calendar-panel .flatpickr-day.nextMonthDay{
  color:rgba(96,66,50,.46);
}

.booking-calendar-panel .flatpickr-day:not(.flatpickr-disabled):hover{
  border-color:var(--color-3);
  background:var(--white);
}

.booking-calendar-panel .flatpickr-day.selected,
.booking-calendar-panel .flatpickr-day.startRange,
.booking-calendar-panel .flatpickr-day.endRange{
  border-color:var(--color-1);
  background:var(--color-1);
  color:var(--button-text);
}

.booking-calendar-panel .flatpickr-day.today{
  border-color:var(--color-3);
}

.booking-side-panel{
  min-height:0;
}

.participant-control{
  display:grid;
  grid-template-columns:46px minmax(80px,1fr) 46px;
  gap:.55rem;
  align-items:center;
  position:relative;
  z-index:2;
}

.participant-control button{
  display:grid;
  place-items:center;
  width:46px;
  height:46px;
  border:1px solid var(--line);
  border-radius:999px;
  background:var(--surface);
  color:var(--dark);
  font:inherit;
  font-size:1.35rem;
  cursor:pointer;
  touch-action:manipulation;
}

.participant-control button:hover{
  border-color:var(--color-1);
  background:var(--color-1);
  color:var(--button-text);
}

.participant-control button:disabled{
  cursor:not-allowed;
  opacity:.45;
}

.participant-control button:disabled:hover{
  border-color:var(--line);
  background:var(--surface);
  color:var(--dark);
}

.participant-control input{
  height:46px;
  text-align:center;
  font-size:1.15rem;
  font-weight:500;
}

.booking-slots-panel{
  min-height:0;
}

.booking-slots-panel .slot-choices{
  grid-template-columns:1fr;
}

.booking-slots-panel .slot-choice{
  min-height:54px;
  background:var(--surface);
}

.booking-summary-panel{
  display:grid;
  grid-template-columns:1fr;
  gap:.75rem;
  align-items:start;
  padding:.9rem;
  background:var(--color-1);
  color:var(--button-text);
}

.booking-summary-panel .step-label,
.booking-summary-panel h3{
  color:var(--button-text);
}

.reservation-section .booking-summary{
  padding:0;
  border:0;
  background:transparent;
}

.reservation-section .booking-summary span{
  border:1px solid rgba(255,248,237,.22);
  background:rgba(255,248,237,.12);
  color:var(--button-text);
}

.booking-summary-panel .btn{
  justify-self:start;
  white-space:nowrap;
  background:var(--button-text);
  color:var(--color-1);
}

.booking-summary-panel .btn:hover{
  background:var(--surface);
}

.embedded-payment{
  display:grid;
  gap:1rem;
  margin-top:.9rem;
  padding:1rem;
  border:1px solid var(--line);
  border-radius:8px;
  background:var(--surface);
}

.embedded-payment[hidden]{
  display:none;
}

.embedded-payment-header{
  display:grid;
  gap:.35rem;
}

.embedded-payment-header p:not(.step-label){
  color:var(--text-soft);
  font-size:.95rem;
}

.stripe-checkout{
  min-height:520px;
}

.booking-modal{
  position:fixed;
  inset:0;
  z-index:120;
  display:grid;
  place-items:center;
  padding:1rem;
  visibility:hidden;
  opacity:0;
  pointer-events:none;
  transition:opacity .2s ease,visibility .2s ease;
}

.booking-modal.is-visible{
  visibility:visible;
  opacity:1;
  pointer-events:auto;
}

.booking-modal-backdrop{
  position:absolute;
  inset:0;
  background:rgba(47,33,29,.48);
  backdrop-filter:blur(5px);
}

.booking-modal-card{
  position:relative;
  width:min(100%,640px);
  max-height:min(88vh,820px);
  overflow:auto;
  padding:clamp(1.1rem,3vw,1.6rem);
  border:1px solid var(--line);
  border-radius:8px;
  background:var(--white);
  box-shadow:0 24px 70px rgba(47,33,29,.24);
  text-align:left;
}

.booking-modal-card h2{
  margin:.3rem 2.8rem .7rem 0;
  font-size:clamp(1.7rem,5vw,2.4rem);
  line-height:1.05;
}

.booking-details-modal{
  position:fixed;
  inset:0;
  z-index:120;
  display:block;
  padding:1rem;
  overflow-y:auto;
  visibility:hidden;
  opacity:0;
  pointer-events:none;
  transition:opacity .2s ease,visibility .2s ease;
  -webkit-overflow-scrolling:touch;
}

.booking-details-modal.is-visible{
  visibility:visible;
  opacity:1;
  pointer-events:auto;
}

.booking-details-backdrop{
  position:fixed;
  inset:0;
  background:rgba(47,33,29,.48);
  backdrop-filter:blur(5px);
}

.booking-details-card{
  position:relative;
  z-index:1;
  width:min(100%,640px);
  margin:clamp(.75rem,5vh,2.2rem) auto;
  padding:clamp(1.1rem,3vw,1.6rem);
  border:1px solid var(--line);
  border-radius:8px;
  background:var(--white);
  box-shadow:0 24px 70px rgba(47,33,29,.24);
  text-align:left;
}

.booking-details-card h2{
  margin:.3rem 2.8rem .7rem 0;
  font-size:clamp(1.7rem,5vw,2.4rem);
  line-height:1.05;
}

.booking-modal-card p:not(.eyebrow){
  color:var(--text-soft);
  margin-bottom:1.2rem;
}

.booking-modal-summary{
  display:flex;
  flex-wrap:wrap;
  gap:.45rem;
  margin-bottom:.9rem;
}

.booking-modal-summary span{
  border:1px solid var(--line);
  border-radius:999px;
  background:var(--surface);
  color:var(--text-soft);
  padding:.25rem .65rem;
  font-size:.86rem;
}

.payment-mode-field{
  display:grid;
  gap:.65rem;
  margin:.2rem 0 1rem;
  padding:0;
  border:0;
}

.payment-mode-field[hidden]{
  display:none;
}

.payment-mode-field legend{
  margin-bottom:.45rem;
  color:var(--color-1);
  font-size:.9rem;
  font-weight:500;
}

.payment-mode-option{
  display:grid;
  grid-template-columns:auto minmax(0,1fr);
  gap:.65rem;
  align-items:start;
  padding:.75rem;
  border:1px solid var(--line);
  border-radius:8px;
  background:var(--surface);
  cursor:pointer;
}

.payment-mode-option input{
  width:auto;
  margin-top:.25rem;
}

.payment-mode-option strong,
.payment-mode-option small{
  display:block;
}

.payment-mode-option strong{
  color:var(--dark);
  font-weight:500;
}

.payment-mode-option small{
  color:var(--text-soft);
  font-size:.84rem;
  line-height:1.35;
}

.split-payment-section{
  min-height:72vh;
}

.split-payment-shell{
  width:100%;
  max-width:760px;
  margin:1.2rem auto 0;
  padding:clamp(1rem,3vw,1.3rem);
  border:1px solid var(--line);
  border-radius:8px;
  background:var(--white);
  box-shadow:var(--shadow);
}

.split-payment-head{
  display:grid;
  gap:.45rem;
  margin-bottom:1rem;
}

.split-payment-head h1{
  font-size:clamp(2rem,5vw,3.2rem);
}

.split-payment-summary{
  display:flex;
  flex-wrap:wrap;
  gap:.45rem;
  margin:1rem 0;
}

.split-payment-summary span,
.split-payment-badge{
  display:inline-flex;
  align-items:center;
  width:fit-content;
  border:1px solid var(--line);
  border-radius:999px;
  background:var(--surface);
  color:var(--text-soft);
  padding:.25rem .65rem;
  font-size:.86rem;
}

.split-payment-actions{
  display:flex;
  flex-wrap:wrap;
  gap:.65rem;
  margin-bottom:1rem;
}

.split-payment-list{
  display:grid;
  gap:.65rem;
  margin:1rem 0;
}

.split-payment-item{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:.8rem;
  align-items:center;
  padding:.85rem;
  border:1px solid var(--line);
  border-radius:8px;
  background:var(--surface);
}

.split-payment-item h2{
  margin:0 0 .12rem;
  font-family:"Jost",sans-serif;
  font-size:1rem;
  font-weight:500;
  color:var(--dark);
}

.split-payment-item p{
  margin:0;
  font-size:.9rem;
}

.split-payment-item .btn{
  white-space:nowrap;
}

.split-payment-badge.paid{
  border-color:rgba(134,78,55,.28);
  background:rgba(134,78,55,.12);
  color:var(--color-1);
}

.booking-modal-close{
  position:absolute;
  top:.7rem;
  right:.7rem;
  display:grid;
  place-items:center;
  width:2.2rem;
  height:2.2rem;
  border:1px solid var(--line);
  border-radius:999px;
  background:var(--surface);
  color:var(--dark);
  font-size:1.4rem;
  line-height:1;
  cursor:pointer;
}

.booking-modal-close:hover{
  border-color:var(--color-1);
  background:var(--color-1);
  color:var(--button-text);
}

body.modal-open{
  overflow:hidden;
}

@media (max-width:900px){
  .reservation-info-panel,
  .reservation-info-grid,
  .reservation-section .booking-intro,
  .booking-selector,
  .booking-summary-panel{
    grid-template-columns:1fr;
  }

  .booking-calendar-panel{
    grid-row:auto;
  }

  .booking-summary-panel .btn{
    width:100%;
  }

  .reservation-gift-card{
    grid-template-columns:1fr;
  }
}

@media (max-width:640px){
  .reservation-section{
    padding-top:5.4rem;
  }

  .reservation-hero .section-text,
  .reservation-info-panel,
  .reservation-section .booking-shell{
    max-width:100%;
  }

  .reservation-hero .lead,
  .reservation-info-panel p,
  .booking-intro-copy,
  .booking-intro-copy p,
  .booking-points,
  .booking-points li{
    max-width:100%;
    overflow-wrap:anywhere;
  }

  .reservation-section .container{
    width:calc(100% - 1rem);
    max-width:var(--max);
  }

  .reservation-section .booking-shell{
    max-width:100%;
    padding:.65rem;
  }

  .reservation-section .booking-intro,
  .booking-panel,
  .booking-summary-panel{
    padding:.85rem;
  }

  .reservation-info-panel{
    padding:.65rem;
    margin-bottom:3.2rem;
  }

  .reservation-info-intro{
    padding:0;
  }

  .reservation-section .booking-intro h2{
    max-width:12ch;
  }

  .booking-intro-copy p,
  .booking-points li{
    font-size:.9rem;
  }

  .participant-control{
    grid-template-columns:42px minmax(70px,1fr) 42px;
  }

  .participant-control button{
    width:42px;
    height:42px;
  }

  .booking-details-modal,
  .booking-modal{
    padding:.65rem;
  }

  .booking-details-card,
  .booking-modal-card{
    padding:1rem;
  }

  .split-payment-shell{
    max-width:100%;
  }

  .split-payment-item{
    grid-template-columns:1fr;
    align-items:start;
  }

  .split-payment-item .btn{
    width:100%;
  }

  .stripe-checkout{
    min-height:560px;
  }
}

.gift-code-field{
  grid-column:1 / -1;
}

.gift-code-field input{
  text-transform:uppercase;
}
