/* ============================================================
   RAK Your Life - Scheduling UI (shared by all booking pages)
   Pairs with assets/css/site.css design tokens + scheduling/scheduler.js
   ============================================================ */

.sched-wrap { max-width: 1040px; margin: 0 auto; padding: 4rem 1.5rem 6rem; }
.sched-head { text-align: center; margin-bottom: 3rem; }
.sched-head .eyebrow { justify-content: center; }
.eyebrow { font-size: 11px; font-weight: 600; letter-spacing: 3px; text-transform: uppercase;
  color: var(--blue); margin-bottom: 1rem; display: flex; align-items: center; gap: 10px; }
.sched-head .eyebrow::before { content:''; display:block; width:15px; height:15px; flex:none; background:url(/assets/img/fist-blue.svg) center/contain no-repeat; }
.sched-head h1 { font-family: var(--font-display); font-size: 56px; font-weight: 900;
  text-transform: uppercase; line-height: 1; color: var(--navy); margin-bottom: .75rem; }
.sched-head p { color: var(--text-muted); font-size: 17px; max-width: 560px; margin: 0 auto; line-height: 1.7; }

/* Event-type cards */
.type-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 1.25rem; }
.type-card { display: flex; flex-direction: column; text-align: left; border: 1px solid var(--border);
  background: var(--white); padding: 1.75rem; text-decoration: none; color: var(--navy);
  transition: transform .15s, box-shadow .2s, border-color .2s; border-top: 4px solid var(--blue); }
.type-card:hover { transform: translateY(-3px); box-shadow: 0 18px 40px rgba(4,30,66,.1); border-color: var(--blue); }
.type-card h3 { font-family: var(--font-display); font-size: 26px; font-weight: 800; text-transform: uppercase;
  line-height: 1.05; margin-bottom: .5rem; }
.type-card .meta { font-size: 13px; font-weight: 600; color: var(--blue-mid); text-transform: uppercase;
  letter-spacing: 1px; margin-bottom: .75rem; display: flex; gap: .5rem; flex-wrap: wrap; }
.type-card .meta span { background: var(--stone); padding: 4px 10px; border-radius: 2px; }
.type-card p { color: var(--text-muted); font-size: 15px; line-height: 1.6; flex: 1; }
.type-card .go { margin-top: 1.25rem; font-family: var(--font-display); font-weight: 800; letter-spacing: 2px;
  text-transform: uppercase; font-size: 14px; color: var(--blue); }
.group-card { border-top-color: var(--navy); }

.sched-subhead { font-family: var(--font-display); font-size: 20px; font-weight: 800; letter-spacing: 2px;
  text-transform: uppercase; color: var(--navy); margin: 3rem 0 1.25rem; padding-bottom: .5rem;
  border-bottom: 2px solid var(--border); }

/* Booking flow two-panel */
.booking { display: grid; grid-template-columns: 340px 1fr; background: var(--white);
  border: 1px solid var(--border); border-radius: 14px; overflow: hidden;
  box-shadow: 0 30px 70px -42px rgba(4,30,66,.4); }
.booking-side { position: relative; padding: 2.5rem 2rem; background: var(--navy); color: #fff; overflow: hidden; }
.booking-side::after { content: ''; position: absolute; right: -42px; bottom: -42px; width: 210px; height: 210px;
  background: url(/assets/img/fist-white.svg) center/contain no-repeat; opacity: .06; pointer-events: none; }
.booking-side > * { position: relative; }
.booking-side .back { font-size: 12px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase;
  color: rgba(255,255,255,.7); text-decoration: none; display: inline-block; margin-bottom: 1.5rem; }
.booking-side .back:hover { color: #fff; }
.booking-side h2 { font-family: var(--font-display); font-size: 32px; font-weight: 800; text-transform: uppercase;
  line-height: 1.03; color: #fff; margin-bottom: 1.25rem; }
.booking-side .detail { display: flex; align-items: center; gap: 10px; color: rgba(255,255,255,.75);
  font-size: 14px; font-weight: 500; margin-bottom: .6rem; }
.booking-side .detail b { color: #fff; }
.booking-side .blurb { color: rgba(255,255,255,.72); font-size: 14px; line-height: 1.6; margin-top: 1rem; }
.sidebar-note { margin-top: 1.5rem; padding-top: 1.25rem; border-top: 1px solid rgba(255,255,255,.15);
  font-size: 13px; line-height: 1.6; color: rgba(255,255,255,.72); }
.sidebar-note a { color: #fff; text-decoration: underline; text-underline-offset: 2px; }
.booking-main { padding: 2.5rem; }
.booking-main h3 { font-family: var(--font-display); font-size: 22px; font-weight: 800; text-transform: uppercase;
  color: var(--navy); margin-bottom: 1.25rem; }

/* Calendar */
.cal-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 1rem; }
.cal-head .mon { font-family: var(--font-display); font-size: 20px; font-weight: 800; text-transform: uppercase; }
.cal-nav { display: flex; gap: .5rem; }
.cal-nav button { width: 40px; height: 40px; border: 1px solid var(--border); background: var(--white);
  cursor: pointer; font-size: 18px; color: var(--navy); transition: .15s; }
.cal-nav button:hover:not(:disabled) { border-color: var(--blue); color: var(--blue); }
.cal-nav button:disabled { opacity: .3; cursor: default; }
.cal-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 4px; }
.cal-dow { text-align: center; font-size: 11px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase;
  color: var(--text-muted); padding: .4rem 0; }
.cal-day { aspect-ratio: 1; border: 1px solid transparent; border-radius: 6px; background: var(--stone); cursor: pointer;
  font-family: var(--font-body); font-weight: 600; font-size: 15px; color: var(--navy); transition: transform .12s, background .12s, border-color .12s;
  display: flex; align-items: center; justify-content: center; position: relative; }
.cal-day:hover:not(:disabled) { background: var(--blue-pale); border-color: var(--blue); transform: translateY(-1px); }
.cal-day.has-slots { background: #fff; border-color: var(--blue); color: var(--blue-dark); font-weight: 700; }
.cal-day.has-slots::after { content: ''; position: absolute; bottom: 6px; left: 50%; transform: translateX(-50%);
  width: 5px; height: 5px; border-radius: 50%; background: var(--blue); }
.cal-day.selected, .cal-day.selected.has-slots { background: var(--navy); border-color: var(--navy); color: #fff; }
.cal-day.selected::after { background: #fff; }
.cal-day:disabled { background: transparent; color: var(--text-muted); opacity: .7; cursor: default; }
.cal-day.empty { background: transparent; border: none; cursor: default; }

/* Slots */
.slots-col { max-height: 420px; overflow-y: auto; }
.slots-date { font-weight: 600; color: var(--navy); margin-bottom: 1rem; font-size: 15px; }
.slot-list { display: grid; grid-template-columns: repeat(auto-fill, minmax(120px,1fr)); gap: .6rem; }
.slot { padding: 13px 10px; border: 1.5px solid var(--blue); border-radius: 7px; background: var(--white); color: var(--blue-dark);
  font-weight: 700; font-size: 15px; cursor: pointer; text-align: center; transition: transform .12s, background .12s, color .12s; min-height: 46px; }
.slot:hover { background: var(--navy); border-color: var(--navy); color: #fff; transform: translateY(-1px); }

.tz-row { margin-top: 1.5rem; font-size: 14px; color: var(--text-muted); display: flex; align-items: center; gap: .5rem; flex-wrap: wrap; }
.tz-row select { font-family: var(--font-body); font-size: 14px; font-weight: 600; padding: 9px 12px; border: 1px solid var(--border);
  border-radius: 6px; color: var(--navy); background: var(--white); max-width: 280px; min-height: 40px; }

/* Form */
.field { margin-bottom: 1.25rem; }
.field label { display: block; font-size: 13px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase;
  color: var(--navy); margin-bottom: .4rem; }
.field input, .field textarea { width: 100%; padding: 12px 14px; border: 1px solid var(--border);
  font-family: var(--font-body); font-size: 16px; color: var(--navy); background: var(--white); }
.field input:focus, .field textarea:focus { outline: none; border-color: var(--blue); }
.field textarea { min-height: 96px; resize: vertical; }
/* Consent checkbox */
.field.consent { background: var(--cream); border: 1px solid var(--border); padding: 1rem 1.25rem; }
.field.consent .cb { display: flex; gap: .65rem; align-items: flex-start; text-transform: none;
  letter-spacing: 0; font-weight: 500; font-size: 13.5px; line-height: 1.55; color: var(--navy); margin: 0; cursor: pointer; }
.field.consent .cb input { width: auto; margin-top: 3px; flex: none; }
.field.consent .cb a { color: var(--blue-mid); }
.btn-primary { background: var(--navy); color: #fff; font-family: var(--font-display); font-size: 16px;
  font-weight: 800; text-transform: uppercase; letter-spacing: 2px; padding: 15px 32px; border: none;
  cursor: pointer; transition: .18s; }
.btn-primary:hover:not(:disabled) { background: var(--blue); }
.btn-primary:disabled { opacity: .5; cursor: default; }
.chosen-slot { background: var(--cream); border: 1px solid var(--border); padding: 1rem 1.25rem; margin-bottom: 1.5rem; }
.chosen-slot b { color: var(--navy); }
.chosen-slot a { font-size: 13px; color: var(--blue-mid); margin-left: 1rem; }

/* States */
.muted { color: var(--text-muted); font-size: 15px; padding: 2rem 0; }
.err { color: #b00020; font-size: 14px; margin-top: 1rem; }
.confirm { text-align: center; padding: 2rem; }
.confirm .check { width: 76px; height: 76px; border-radius: 50%; background: var(--navy); color: #fff;
  display: flex; align-items: center; justify-content: center; font-size: 38px; margin: 0 auto 1.5rem;
  box-shadow: 0 16px 36px -10px rgba(4,30,66,.45); }
.confirm h2 { font-family: var(--font-display); font-size: 38px; font-weight: 900; text-transform: uppercase;
  color: var(--navy); margin-bottom: 1rem; }
.confirm p { color: var(--text-muted); font-size: 16px; line-height: 1.7; max-width: 460px; margin: 0 auto 1rem; }
.confirm .when { font-size: 18px; color: var(--navy); font-weight: 600; margin-bottom: 1.5rem; }

/* Intake (embedded form on the confirmation step) */
.intake { padding: 0 2rem 2rem; }
.intake h3 { font-family: var(--font-display); font-size: 24px; font-weight: 800; text-transform: uppercase;
  color: var(--navy); margin-bottom: .75rem; text-align: center; }

.confirm .manage-note { font-size: 14px; margin-top: 1.25rem; }
.confirm .manage-note a { color: var(--blue); font-weight: 600; }

/* Post-booking "finish up" steps (sign release, intake) */
.finish-steps { max-width: 760px; margin: 0 auto; padding: 1rem 2rem 2.5rem; }
.finish-head { font-family: var(--font-display); font-size: 16px; font-weight: 800; letter-spacing: 1px;
  text-transform: uppercase; color: var(--blue-mid); text-align: center; margin: 1rem 0 1.75rem; }
.finish-step { border: 1px solid var(--border); background: #fff; padding: 1.75rem; margin-bottom: 1.5rem; }
.finish-step h3 { font-family: var(--font-display); font-size: 22px; font-weight: 800; text-transform: uppercase;
  color: var(--navy); margin-bottom: .5rem; display: flex; align-items: center; gap: .65rem; }
.finish-step .step-num { display: inline-flex; align-items: center; justify-content: center; width: 30px; height: 30px;
  border-radius: 50%; background: var(--navy); color: #fff; font-size: 16px; flex: none; }
.finish-step iframe { display: block; margin-top: .5rem; }

.spinner { display: inline-block; width: 18px; height: 18px; border: 2px solid rgba(255,255,255,.4);
  border-top-color: #fff; border-radius: 50%; animation: spin .7s linear infinite; vertical-align: middle; }
@keyframes spin { to { transform: rotate(360deg); } }

@media (max-width: 760px) {
  .sched-head h1 { font-size: 40px; }
  .booking { grid-template-columns: 1fr; }
  .booking-side { border-right: none; border-bottom: 1px solid var(--border); }
}

/* Branded wrapper for the embedded guest-intake (Jotform) form. The form's own
   font/colors are set inside Jotform's Form Designer; this frames it on-brand. */
.intake-frame { border: 1px solid var(--border); border-radius: 10px; overflow: hidden;
  background: #fff; box-shadow: 0 1px 4px rgba(4,30,66,.05); }
.intake-frame iframe { width: 100%; min-height: 900px; border: 0; display: block; }

/* Visible keyboard focus across the booking UI (a11y) */
.type-card:focus-visible, .cal-day:focus-visible:not(:disabled), .cal-nav button:focus-visible,
.slot:focus-visible, .tz-row select:focus-visible, .field input:focus-visible, .field textarea:focus-visible,
.field.consent .cb input:focus-visible, .btn-primary:focus-visible, .booking-side .back:focus-visible,
.chosen-slot a:focus-visible, .confirm .manage-note a:focus-visible {
  outline: 2px solid var(--blue); outline-offset: 2px; border-radius: 3px;
}

/* Respect reduced-motion for the booking UI */
@media (prefers-reduced-motion: reduce) {
  .type-card, .cal-day, .cal-nav button, .slot, .btn-primary { transition: none; }
  .spinner { animation-duration: 1.2s; }
}
