/* ─────────────────────────────────────────────────────────────
   STYLED BY KARI · booking — services fold, availability calendar,
   proposal form + on-screen proposal summary. Inherits site tokens.
   ───────────────────────────────────────────────────────────── */

/* ─── Services fold (compact, three offerings) ─────────────── */
.svc__head { display: grid; gap: 16px; max-width: 760px; margin-bottom: clamp(34px, 4vw, 60px); }
.svc__grid {
  display: grid; gap: clamp(20px, 2.4vw, 34px);
  grid-template-columns: repeat(3, 1fr);
}
.svc__card {
  display: grid; grid-template-rows: auto auto auto 1fr auto; gap: 16px;
  padding-top: 22px; border-top: 1px solid var(--hair);
}
.svc__num {
  font-family: var(--body); font-weight: 500; font-size: 10px;
  letter-spacing: 0.28em; text-transform: uppercase; color: var(--bronze);
}
.svc__title { font-family: var(--display); font-weight: 300; font-size: clamp(24px, 2.6vw, 32px); line-height: 1.05; color: var(--warm-ink); margin: 0; }
.svc__copy { color: var(--muted); font-size: 15.5px; line-height: 1.62; margin: 0; }
.svc__copy .accent { color: var(--ink); }
.svc__meta { display: grid; gap: 6px; margin: 2px 0 0; padding: 0; list-style: none; }
.svc__meta li { display: flex; gap: 12px; font-size: 12.5px; color: var(--muted); }
.svc__meta dt { flex: 0 0 64px; font-weight: 500; letter-spacing: 0.12em; text-transform: uppercase; font-size: 10px; color: var(--taupe); padding-top: 2px; }
.svc__meta dd { margin: 0; font-family: var(--display); font-style: italic; font-size: 15px; color: var(--ink); }
.svc__pick {
  justify-self: start; margin-top: 4px;
  font-family: var(--body); font-weight: 500; font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--cognac); display: inline-flex; align-items: center; gap: 9px;
  border-bottom: 1px solid var(--hair); padding-bottom: 4px;
  transition: gap 320ms var(--ease), border-color 320ms var(--ease);
  cursor: pointer;
}
.svc__pick:hover { gap: 14px; border-color: var(--cognac); }
@media (max-width: 860px) { .svc__grid { grid-template-columns: 1fr; gap: 4px; } .svc__card { padding-top: 26px; } }

/* ─── Inquire section shell ────────────────────────────────── */
.booking__head { display: grid; gap: 16px; max-width: 820px; margin-bottom: clamp(36px, 4.5vw, 64px); }
.booking__grid {
  display: grid; gap: clamp(28px, 3.6vw, 56px);
  grid-template-columns: minmax(320px, 0.92fr) 1.1fr;
  align-items: start;
}
.booking__aside { display: grid; gap: clamp(14px, 1.8vw, 20px); align-content: start; position: sticky; top: 96px; }
@media (max-width: 820px) { .booking__aside { position: static; } }
@media (max-width: 820px) { .booking__grid { grid-template-columns: 1fr; gap: clamp(34px, 7vw, 52px); } }

/* ─── Calendar ─────────────────────────────────────────────── */
.cal {
  background: var(--white); border: 1px solid var(--hair);
  padding: clamp(20px, 2.4vw, 30px);
  box-shadow: 0 30px 70px -52px rgba(26,24,24,0.5);
}
@media (max-width: 820px) { .cal { position: static; } }
@media (max-width: 520px) { .cal__day { min-height: 44px; font-size: 17px; } .cal { padding: 20px 16px; } }
.cal__head { display: flex; align-items: center; justify-content: space-between; gap: 14px; margin-bottom: 20px; }
.cal__month { font-family: var(--display); font-weight: 300; font-size: clamp(22px, 2.4vw, 30px); color: var(--warm-ink); line-height: 1; }
.cal__month span { display: block; font-family: var(--body); font-weight: 500; font-size: 10px; letter-spacing: 0.26em; text-transform: uppercase; color: var(--bronze); margin-bottom: 7px; }
.cal__nav { display: flex; gap: 8px; }
.cal__btn {
  width: 40px; height: 40px; border: 1px solid var(--hair); border-radius: 50%;
  display: grid; place-items: center; color: var(--ink); font-size: 15px;
  transition: background 240ms var(--ease), border-color 240ms var(--ease), color 240ms var(--ease), opacity 240ms;
}
.cal__btn:hover:not(:disabled) { background: var(--ink); color: var(--ivory); border-color: var(--ink); }
.cal__btn:disabled { opacity: 0.28; cursor: default; }
.cal__dow { display: grid; grid-template-columns: repeat(7, 1fr); margin-bottom: 6px; }
.cal__dow span { text-align: center; font-family: var(--body); font-weight: 500; font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--taupe); padding-bottom: 8px; }
.cal__grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 4px; }
.cal__day {
  position: relative; aspect-ratio: 1 / 1; width: 100%;
  display: grid; place-items: center;
  font-family: var(--display); font-size: clamp(15px, 1.6vw, 18px); color: var(--ink);
  border: 1px solid transparent; border-radius: 3px;
  transition: background 200ms var(--ease), color 200ms var(--ease), border-color 200ms var(--ease);
}
.cal__day.is-empty { pointer-events: none; }
.cal__day.is-open { cursor: pointer; }
.cal__day.is-open:hover { background: var(--bone); border-color: var(--hair); }
.cal__day.is-out { color: var(--taupe); cursor: default; }
.cal__day.is-blocked { color: var(--taupe); cursor: default; }
.cal__day.is-blocked::after {
  content: ""; position: absolute; left: 22%; right: 22%; top: 50%; height: 1px;
  background: var(--taupe); transform: rotate(-18deg); opacity: 0.7;
}
.cal__day.is-today { border-color: var(--bronze); }
.cal__day.is-selected, .cal__day.is-selected:hover { background: var(--cognac); color: var(--ivory); border-color: var(--cognac); }
.cal__legend { display: flex; flex-wrap: wrap; gap: 16px; margin-top: 20px; padding-top: 16px; border-top: 1px solid var(--hair); }
.cal__legend span { display: inline-flex; align-items: center; gap: 8px; font-size: 11px; letter-spacing: 0.04em; color: var(--muted); }
.cal__swatch { width: 13px; height: 13px; border-radius: 3px; border: 1px solid var(--hair); display: inline-block; }
.cal__swatch--open { background: var(--white); }
.cal__swatch--sel { background: var(--cognac); border-color: var(--cognac); }
.cal__swatch--off { background: var(--bone); position: relative; }
.cal__swatch--off::after { content: ""; position: absolute; left: 2px; right: 2px; top: 50%; height: 1px; background: var(--taupe); transform: rotate(-18deg); }

/* ─── Form ─────────────────────────────────────────────────── */
.booking__form { display: grid; gap: clamp(18px, 2.4vw, 24px); }
.book-date {
  display: grid; gap: 7px;
  padding: clamp(16px, 1.8vw, 20px) clamp(18px, 2vw, 22px);
  background: var(--white); border: 1px solid var(--hair);
}
.book-date__label { font-family: var(--body); font-weight: 500; font-size: 10px; letter-spacing: 0.24em; text-transform: uppercase; color: var(--muted); }
.book-date__value { font-family: var(--display); font-style: italic; font-size: clamp(20px, 2.2vw, 26px); color: var(--cognac); text-align: left; line-height: 1.1; }
.book-date__value.is-empty { color: var(--taupe); }
.book-row { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(16px, 2.3vw, 22px); }
@media (max-width: 560px) { .book-row { grid-template-columns: 1fr; } }
.book-actions { display: flex; align-items: center; justify-content: space-between; gap: 16px; flex-wrap: wrap; margin-top: 4px; }
.book-note { font-family: var(--display); font-style: italic; font-size: 15px; color: var(--muted); }
.book-error { color: var(--cognac); font-size: 13px; font-weight: 500; min-height: 1em; }
/* honeypot */
.book-hp { position: absolute; left: -9999px; width: 1px; height: 1px; overflow: hidden; }

/* ─── Proposal summary (instant, on submit) ────────────────── */
#services, #inquire { scroll-margin-top: 84px; }
.proposal { display: none; max-width: 860px; margin-inline: auto; }
.booking.is-sent .booking__grid { display: none; }
.booking.is-sent .proposal { display: block; }
.proposal__card {
  background: var(--white); border: 1px solid var(--hair);
  box-shadow: 0 30px 70px -52px rgba(26,24,24,0.5);
  padding: clamp(26px, 3.4vw, 46px);
}
.proposal__sign { font-family: "Allura", var(--script); font-size: 48px; line-height: 0.9; color: var(--cognac); }
.proposal__eyebrow { font-family: var(--body); font-weight: 500; font-size: 10px; letter-spacing: 0.26em; text-transform: uppercase; color: var(--bronze); }
.proposal__title { font-family: var(--display); font-weight: 300; font-size: clamp(28px, 3.4vw, 44px); line-height: 1.04; color: var(--warm-ink); margin: 10px 0 6px; }
.proposal__sub { color: var(--muted); font-size: 15.5px; line-height: 1.6; max-width: 52ch; margin: 0 0 clamp(22px, 3vw, 30px); }
.proposal__list { display: grid; gap: 0; margin: 0 0 clamp(24px, 3vw, 32px); padding: 0; border-top: 1px solid var(--hair); }
.proposal__list div { display: grid; grid-template-columns: 150px 1fr; gap: 16px; padding: 13px 0; border-bottom: 1px solid var(--hair); }
.proposal__list dt { font-family: var(--body); font-weight: 500; font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--muted); padding-top: 3px; }
.proposal__list dd { margin: 0; font-family: var(--display); font-size: clamp(17px, 1.8vw, 20px); color: var(--ink); }
@media (max-width: 520px) { .proposal__list div { grid-template-columns: 1fr; gap: 3px; } }
.proposal__foot { display: flex; align-items: center; gap: 20px; flex-wrap: wrap; }
.proposal__edit { font-family: var(--body); font-weight: 500; font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--muted); border-bottom: 1px solid var(--hair); padding-bottom: 3px; cursor: pointer; transition: color 240ms, border-color 240ms; }
.proposal__edit:hover { color: var(--ink); border-color: var(--ink); }

/* ─── Mobile adaptation ────────────────────────────────────── */
@media (max-width: 640px) {
  .booking__grid { gap: clamp(28px, 8vw, 42px); }
  .book-date { flex-direction: column; align-items: flex-start; gap: 5px; padding: 15px 16px; }
  .book-date__value { text-align: left; font-size: 21px; }
  .book-actions { flex-direction: column; align-items: stretch; gap: 15px; }
  .book-actions .cta { width: 100%; justify-content: center; }
  .book-note { text-align: center; order: 2; }
  .cal__legend { gap: 12px 18px; }
  .proposal__foot { gap: 14px; }
}
