/* ═══════════════════════════════════════════════════════════════
   TOUR-ED MINE — Reservation / Book a Tour Styles
   ═══════════════════════════════════════════════════════════════ */

/* ─── BOOKING HERO (plain dark, no image) ─── */
.booking-hero {
  background:#0d0b07;
  padding:48px 24px 36px;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  text-align:center;
  gap:8px;
}
.booking-hero h1 {
  font-family:'Raleway', sans-serif;
  font-size:2rem;
  font-weight:900;
  color:#fff;
  margin:0;
  letter-spacing:0.02em;
}
.booking-hero-intro {
  font-family:'Raleway', sans-serif;
  font-size:0.92rem;
  font-weight:500;
  font-style:italic;
  color:var(--warm);
  max-width:620px;
  line-height:1.65;
  margin:8px 0 0;
  opacity:0.85;
}

/* ─── STEP INDICATOR ─── */
.step-indicator {
  display:flex;
  align-items:flex-start;
  justify-content:center;
  margin-bottom:36px;
  padding:20px 0 28px;
}
.step-item {
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:8px;
  min-width:72px;
}
.step-circle {
  width:36px;
  height:36px;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  font-family:'Raleway', sans-serif;
  font-size:0.85rem;
  font-weight:900;
  background:var(--coal);
  border:2px solid rgba(168,152,128,0.25);
  color:rgba(168,152,128,0.4);
  transition:all 0.25s;
}
.step-label {
  font-family:'Raleway', sans-serif;
  font-size:0.62rem;
  font-weight:600;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:rgba(168,152,128,0.35);
  text-align:center;
  transition:color 0.25s, font-weight 0.25s;
  max-width:80px;
}
/* Active step */
.step-item.active .step-circle {
  background:var(--gold);
  border-color:var(--gold);
  color:var(--coal);
}
.step-item.active .step-label {
  color:var(--gold);
  font-weight:800;
}
/* Completed step */
.step-item.completed .step-circle {
  background:var(--gold);
  border-color:var(--gold);
  color:var(--coal);
}
.step-item.completed .step-label {
  color:var(--warm);
}
/* Connecting line */
.step-line {
  flex:1;
  height:2px;
  background:rgba(168,152,128,0.15);
  margin-top:18px; /* center with circle */
  max-width:60px;
  min-width:16px;
  transition:background 0.25s;
}
.step-line.completed {
  background:var(--gold);
}

/* ─── FORM WRAPPER ─── */
.booking-form-wrap {
  max-width:780px;
  margin:0 auto;
  background:var(--mid);
  border:1px solid rgba(255,199,44,0.1);
  padding:48px;
}

/* ─── SECTIONS ─── */
.booking-section {
  padding-top:36px;
  padding-bottom:36px;
  border-bottom:1px solid rgba(255,199,44,0.15);
  border-left:3px solid transparent;
  padding-left:24px;
  transition:border-color 0.25s;
}
.booking-section:first-child {
  padding-top:0;
}
.booking-section:last-child {
  border-bottom:none;
  padding-bottom:0;
}
/* Active section gold left border */
.booking-section.is-active {
  border-left-color:var(--gold);
}
.booking-section-title {
  font-family:'Raleway', sans-serif;
  font-size:1.15rem;
  font-weight:800;
  color:var(--warm);
  margin-bottom:8px;
}
.booking-section-note {
  font-family:'Raleway', sans-serif;
  font-size:0.85rem;
  font-weight:500;
  font-style:italic;
  color:var(--stone);
  margin-bottom:20px;
}

/* ─── RADIO CARDS ─── */
.radio-cards {
  display:grid;
  gap:16px;
}
.radio-cards--two {
  grid-template-columns:1fr 1fr;
}
.radio-cards--three {
  grid-template-columns:1fr 1fr 1fr;
}
.radio-card {
  cursor:pointer;
}
.radio-card input { display:none; }
.radio-card-inner {
  display:flex;
  flex-direction:column;
  align-items:center;
  text-align:center;
  gap:8px;
  padding:24px 16px;
  background:var(--coal);
  border:2px solid rgba(255,199,44,0.1);
  transition:border-color 0.2s, background 0.2s;
}
.radio-card input:checked + .radio-card-inner {
  border-color:var(--gold);
  background:rgba(255,199,44,0.06);
}
.radio-card:hover .radio-card-inner {
  border-color:rgba(255,199,44,0.35);
}
.radio-card-icon {
  color:var(--stone);
  transition:color 0.2s;
}
.radio-card input:checked + .radio-card-inner .radio-card-icon {
  color:var(--gold);
}
.radio-card-label {
  font-family:'Raleway', sans-serif;
  font-size:0.92rem;
  font-weight:800;
  color:var(--warm);
}
.radio-card-desc {
  font-family:'Raleway', sans-serif;
  font-size:0.78rem;
  font-weight:500;
  color:var(--stone);
  line-height:1.4;
}

/* Slot-specific radio cards */
.radio-card--slot.is-sold-out {
  pointer-events:none;
  opacity:0.45;
}
.radio-card--slot.is-sold-out .radio-card-inner {
  border-color:rgba(255,199,44,0.05);
}
.radio-card--slot.is-locked {
  pointer-events:none;
  opacity:0.35;
}
.slot-availability {
  font-family:'Raleway', sans-serif;
  font-size:0.75rem;
  font-weight:600;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:var(--stone);
}
.slot-availability.is-available { color:#5a9a5a; }
.slot-availability.is-filling { color:#d4a020; }
.slot-availability.is-sold-out { color:var(--red); }

.slot-note {
  font-family:'Raleway', sans-serif;
  font-size:0.7rem;
  font-weight:500;
  color:var(--stone);
  font-style:italic;
}

/* ─── BOOKING CALENDAR ─── */
.booking-calendar {
  background:var(--coal);
  padding:20px;
  border:1px solid rgba(255,199,44,0.1);
}
.bcal-nav {
  display:flex;
  align-items:center;
  justify-content:space-between;
  margin-bottom:12px;
}
.bcal-title {
  font-family:'Raleway', sans-serif;
  font-size:0.95rem;
  font-weight:900;
  letter-spacing:0.1em;
  text-transform:uppercase;
  color:var(--warm);
}
.bcal-btn {
  background:none;
  border:none;
  cursor:pointer;
  color:var(--gold);
  font-size:1.3rem;
  font-weight:700;
  padding:4px 12px;
  font-family:'Raleway', sans-serif;
  line-height:1;
  transition:color 0.15s;
}
.bcal-btn:hover {
  color:#FFD55A;
}
.bcal-grid {
  display:grid;
  grid-template-columns:repeat(7, 1fr);
  gap:2px;
}
.bcal-hdr {
  font-family:'Raleway', sans-serif;
  font-size:0.65rem;
  font-weight:800;
  letter-spacing:0.12em;
  text-transform:uppercase;
  color:var(--stone);
  text-align:center;
  padding:6px 0;
}
.bcal-hdr.oh {
  color:var(--gold);
}
.bcal-day {
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:3px;
  padding:6px 2px;
  min-height:52px;
  cursor:default;
  position:relative;
  transition:background 0.15s, border-color 0.15s;
  border:2px solid transparent;
}
.bcal-day.empty {
  min-height:52px;
}
.bcal-num {
  font-family:'Raleway', sans-serif;
  font-size:0.8rem;
  font-weight:700;
  line-height:1;
}
.bcal-day.open {
  color:var(--warm);
  background:rgba(255,199,44,0.04);
  cursor:pointer;
}
.bcal-day.open:hover {
  background:rgba(255,199,44,0.12);
}
.bcal-day.open:focus {
  outline:none;
  border-color:rgba(255,199,44,0.4);
}
.bcal-day.closed {
  color:rgba(168,152,128,0.25);
  background:rgba(0,0,0,0.3);
}
.bcal-day.past {
  color:rgba(168,152,128,0.2);
  opacity:0.5;
}
.bcal-day.today.open .bcal-num {
  color:var(--gold);
  font-weight:900;
}
.bcal-day.selected {
  border-color:var(--gold);
  background:rgba(255,199,44,0.1);
}
.bcal-day.selected .bcal-num {
  color:var(--gold);
  font-weight:900;
}

/* Availability dots */
.bcal-dot {
  width:10px;
  height:10px;
  border-radius:50%;
  transition:background 0.2s;
}
.bcal-dot.g { background:#50d080; }
.bcal-dot.y { background:var(--gold); }
.bcal-dot.r { background:var(--red); }

/* Calendar legend */
.bcal-legend {
  display:flex;
  align-items:center;
  justify-content:center;
  gap:20px;
  padding:14px 0 4px;
}
.bcal-legend-item {
  font-family:'Raleway', sans-serif;
  font-size:0.72rem;
  font-weight:600;
  color:var(--stone);
  display:flex;
  align-items:center;
  gap:6px;
}
.bcal-legend .bcal-dot {
  flex-shrink:0;
}
.bcal-legend-closed {
  width:10px;
  height:10px;
  border:1px solid rgba(168,152,128,0.3);
  background:rgba(0,0,0,0.3);
  flex-shrink:0;
}

/* ─── GUEST ROWS (stacked layout) ─── */
.guest-rows {
  display:flex;
  flex-direction:column;
}
.guest-row {
  display:flex;
  align-items:center;
  gap:16px;
  padding:14px 0;
  border-bottom:1px solid rgba(255,199,44,0.06);
}
.guest-row:last-child {
  border-bottom:none;
}
.guest-row-label {
  font-family:'Raleway', sans-serif;
  font-size:0.88rem;
  font-weight:700;
  color:var(--warm);
  flex:1;
  min-width:0;
}
.guest-row-label small {
  font-size:0.75rem;
  font-weight:500;
  color:var(--stone);
}
.guest-row-price {
  font-family:'Raleway', sans-serif;
  font-size:0.8rem;
  font-weight:600;
  color:var(--stone);
  min-width:80px;
  text-align:right;
}
.number-input {
  display:flex;
  align-items:stretch;
  border:1px solid rgba(255,199,44,0.15);
  background:var(--coal);
  flex-shrink:0;
}
.number-input input {
  width:56px;
  text-align:center;
  font-family:'Raleway', sans-serif;
  font-size:1.1rem;
  font-weight:700;
  color:var(--warm);
  background:transparent;
  border:none;
  outline:none;
  padding:10px 0;
  -moz-appearance:textfield;
}
.number-input input::-webkit-outer-spin-button,
.number-input input::-webkit-inner-spin-button {
  -webkit-appearance:none;
  margin:0;
}
.num-btn {
  width:40px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:rgba(255,199,44,0.08);
  border:none;
  color:var(--gold);
  font-size:1.2rem;
  font-weight:700;
  cursor:pointer;
  transition:background 0.15s;
  user-select:none;
}
.num-btn:hover {
  background:rgba(255,199,44,0.18);
}

/* Guest summary bar */
.guest-summary {
  display:flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  margin-top:20px;
  padding:16px 20px;
  background:rgba(255,199,44,0.06);
  border:1px solid rgba(255,199,44,0.12);
  font-family:'Raleway', sans-serif;
}
.guest-summary-count {
  font-size:0.95rem;
  font-weight:700;
  color:var(--warm);
}
.guest-summary-sep {
  font-size:0.95rem;
  color:var(--stone);
}
.guest-summary-price {
  font-size:0.95rem;
  font-weight:500;
  color:var(--stone);
}
.guest-summary-price strong {
  font-weight:900;
  color:var(--gold);
  font-size:1.1rem;
}

/* ─── CHECKBOX CARDS (Special Requests) ─── */
.checkbox-cards {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px;
  align-items:stretch;
}
.checkbox-card {
  cursor:pointer;
  display:flex;
}
.checkbox-card input { display:none; }
.checkbox-card-inner {
  display:flex;
  align-items:flex-start;
  gap:14px;
  padding:20px;
  background:var(--coal);
  border:2px solid rgba(255,199,44,0.1);
  transition:border-color 0.2s, background 0.2s;
  flex:1;
}
.checkbox-card input:checked + .checkbox-card-inner {
  border-color:var(--gold);
  background:rgba(255,199,44,0.06);
}
.checkbox-card:hover .checkbox-card-inner {
  border-color:rgba(255,199,44,0.35);
}
.checkbox-card-check {
  flex-shrink:0;
  width:28px;
  height:28px;
  display:flex;
  align-items:center;
  justify-content:center;
  border:2px solid rgba(255,199,44,0.2);
  color:transparent;
  transition:border-color 0.2s, color 0.2s, background 0.2s;
}
.checkbox-card input:checked + .checkbox-card-inner .checkbox-card-check {
  background:var(--gold);
  border-color:var(--gold);
  color:var(--coal);
}
.checkbox-card-label {
  display:block;
  font-family:'Raleway', sans-serif;
  font-size:0.92rem;
  font-weight:800;
  color:var(--warm);
  margin-bottom:2px;
}
.checkbox-card-desc {
  display:block;
  font-family:'Raleway', sans-serif;
  font-size:0.78rem;
  font-weight:500;
  color:var(--stone);
  line-height:1.4;
}

/* ─── FORM FIELDS ─── */
.booking-form .form-row {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px;
  margin-bottom:16px;
}
.booking-form .form-group {
  display:flex;
  flex-direction:column;
  margin-bottom:16px;
}
.booking-form .form-group label {
  font-family:'Raleway', sans-serif;
  font-size:0.78rem;
  font-weight:700;
  letter-spacing:0.15em;
  text-transform:uppercase;
  color:var(--gold);
  margin-bottom:6px;
}
.booking-form .form-group input,
.booking-form .form-group select,
.booking-form .form-group textarea {
  font-family:'Raleway', sans-serif;
  font-size:0.92rem;
  font-weight:500;
  background:var(--coal);
  color:var(--warm);
  border:1px solid rgba(255,199,44,0.15);
  padding:12px 14px;
  transition:border-color 0.2s;
}
.booking-form .form-group input:focus,
.booking-form .form-group select:focus,
.booking-form .form-group textarea:focus {
  outline:none;
  border-color:var(--gold);
}
.booking-form .form-group textarea {
  resize:vertical;
  min-height:80px;
}
.booking-form .form-group input::placeholder,
.booking-form .form-group textarea::placeholder {
  color:var(--stone);
  opacity:0.5;
}

/* Field feedback */
.field-feedback {
  font-family:'Raleway', sans-serif;
  font-size:0.78rem;
  font-weight:600;
  margin-top:6px;
  min-height:1.2em;
  display:block;
}
.field-feedback.is-error { color:var(--red); }
.field-feedback.is-warning { color:#d4a020; }
.field-feedback.is-success { color:#5a9a5a; }

/* ─── REVIEW SUMMARY ─── */
.booking-summary {
  background:var(--coal);
  border:1px solid rgba(255,199,44,0.1);
  border-left:3px solid var(--gold);
  padding:24px;
  margin-bottom:20px;
}
.summary-row {
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:12px 0;
  border-bottom:1px solid rgba(255,199,44,0.06);
}
.summary-row:last-child { border-bottom:none; }
.summary-row--total {
  border-top:2px solid rgba(255,199,44,0.15);
  margin-top:4px;
  padding-top:16px;
}
.summary-label {
  font-family:'Raleway', sans-serif;
  font-size:0.85rem;
  font-weight:600;
  color:var(--stone);
  text-transform:uppercase;
  letter-spacing:0.1em;
}
.summary-value {
  font-family:'Raleway', sans-serif;
  font-size:1.1rem;
  font-weight:700;
  color:var(--warm);
}
.summary-value--price {
  font-size:1.3rem;
  font-weight:900;
  color:var(--gold);
}

/* Reassurance box */
.booking-reassurance {
  background:rgba(255,199,44,0.08);
  border:1px solid rgba(255,199,44,0.2);
  border-radius:6px;
  padding:16px 20px;
  margin-bottom:24px;
}
.reassurance-main {
  font-family:'Raleway', sans-serif;
  font-size:0.95rem;
  font-weight:700;
  color:var(--gold);
  margin-bottom:6px;
}
.reassurance-detail {
  font-family:'Raleway', sans-serif;
  font-size:0.85rem;
  font-weight:500;
  color:var(--warm);
  line-height:1.55;
}

/* Submit button */
.booking-submit {
  width:100%;
  justify-content:center;
  font-size:1rem;
  padding:18px 34px;
  border:none;
  cursor:pointer;
}
.booking-submit:disabled {
  opacity:0.5;
  cursor:not-allowed;
  transform:none !important;
}

/* ─── SUCCESS / ERROR MESSAGES ─── */
.booking-message {
  text-align:center;
  padding:60px 40px;
}
.booking-message-icon {
  margin-bottom:20px;
}
.booking-message-title {
  font-family:'Raleway', sans-serif;
  font-size:1.6rem;
  font-weight:900;
  color:var(--warm);
  margin-bottom:12px;
}
.booking-message-text {
  font-family:'Raleway', sans-serif;
  font-size:1rem;
  font-weight:500;
  color:var(--stone);
  line-height:1.65;
  max-width:520px;
  margin:0 auto 16px;
}
.booking-message-sub {
  font-family:'Raleway', sans-serif;
  font-size:0.88rem;
  font-weight:600;
  color:var(--stone);
}
.booking-message-sub a {
  color:var(--gold);
  transition:color 0.2s;
}
.booking-message-sub a:hover { color:#FFD55A; }
.booking-message--error {
  padding:16px 20px;
  background:rgba(200,32,64,0.08);
  border:1px solid rgba(200,32,64,0.25);
  margin-bottom:24px;
}
.booking-message--error p {
  font-family:'Raleway', sans-serif;
  font-size:0.88rem;
  font-weight:600;
  color:var(--red);
  margin:0;
}

/* ─── GROUP RANGE BUTTONS (student count selector) ─── */
.group-range-section {
  margin-top:24px;
}
.group-range-label {
  font-family:'Raleway', sans-serif;
  font-weight:700;
  font-size:0.92rem;
  color:var(--warm);
  margin-bottom:12px;
}
.range-buttons {
  display:flex;
  gap:12px;
  flex-wrap:wrap;
}
.range-btn {
  flex:1 1 auto;
  min-width:100px;
  padding:16px 20px;
  background:rgba(255,199,44,0.03);
  border:2px solid rgba(255,199,44,0.18);
  border-radius:0;
  color:var(--gold);
  font-family:'Raleway', sans-serif;
  font-weight:800;
  font-size:1.05rem;
  cursor:pointer;
  transition:border-color 0.2s, background 0.2s, box-shadow 0.2s;
  text-align:center;
}
.range-btn:hover {
  border-color:rgba(255,199,44,0.5);
  background:rgba(255,199,44,0.08);
}
.range-btn.selected {
  border-color:var(--gold);
  background:rgba(255,199,44,0.12);
  box-shadow:0 0 0 1px var(--gold);
  color:#fff;
}

/* ─── FULL-DAY CALLOUT NOTE ─── */
.booking-section-note--callout {
  margin-top:16px;
  padding:14px 18px;
  background:rgba(255,199,44,0.05);
  border-left:3px solid var(--gold);
  font-style:italic;
}

/* ─── RESPONSIVE ─── */

@media (max-width:1050px) {
  .booking-form-wrap { padding:36px; }
}

@media (max-width:768px) {
  .booking-hero { padding:36px 20px 28px; }
  .booking-hero h1 { font-size:1.6rem; }
  .booking-hero-intro { font-size:0.85rem; }

  .booking-form-wrap {
    padding:28px 20px;
    border:none;
  }

  /* Step indicator */
  .step-indicator {
    flex-wrap:wrap;
    gap:4px 0;
    padding:16px 0 20px;
  }
  .step-item { min-width:56px; }
  .step-circle { width:28px; height:28px; font-size:0.72rem; }
  .step-label { font-size:0.55rem; max-width:60px; }
  .step-line { margin-top:14px; max-width:28px; min-width:8px; }

  /* Calendar */
  .booking-calendar { padding:14px; }
  .bcal-day { min-height:44px; }
  .bcal-num { font-size:0.72rem; }
  .bcal-legend { gap:12px; flex-wrap:wrap; }

  /* Active section border */
  .booking-section.is-active { padding-left:16px; }

  .radio-cards--two,
  .radio-cards--three {
    grid-template-columns:1fr;
  }

  /* Guest rows */
  .guest-row { gap:10px; }
  .guest-row-label { font-size:0.8rem; }
  .guest-row-price { min-width:60px; font-size:0.72rem; }

  .checkbox-cards {
    grid-template-columns:1fr;
  }

  /* Range buttons stack on mobile */
  .range-buttons {
    flex-direction:column;
  }
  .range-btn {
    min-width:unset;
  }

  .booking-form .form-row {
    grid-template-columns:1fr;
    gap:0;
  }

  .booking-message { padding:40px 20px; }
}

@media (max-width:480px) {
  .booking-form-wrap { padding:20px 16px; }
  .booking-section { padding-top:24px; padding-bottom:24px; }
  .booking-section-title { font-size:1.05rem; }
  .radio-card-inner { padding:18px 14px; }
  .number-input input { width:48px; }
  .num-btn { width:36px; }

  /* Step indicator: hide lines on very small screens */
  .step-line { display:none; }
  .step-indicator { gap:6px; flex-wrap:wrap; }

  /* Guest rows stack tighter */
  .guest-row { flex-wrap:wrap; gap:8px; }
  .guest-row-price { min-width:auto; text-align:left; }
}
