/* ============================================================
   SAFFAL JYOTISH — booking.css v1
   3-step booking flow: Service → Details → Payment
   ============================================================ */

/* ─── Page wrapper ───────────────────────────────────────── */
.booking-page {
  background: var(--cream);
  min-height: 100svh;
}

/* ─── Booking header (compact, no full hero) ─────────────── */
.booking-header {
  background: var(--grad-hero);
  padding-block: clamp(2.2rem, 5vw, 3.5rem);
  text-align: center;
  position: relative;
  overflow: hidden;
}
.booking-header::before {
  content: '';
  position: absolute; inset: 0;
  background: radial-gradient(ellipse at 50% 0%, rgba(212,144,10,.12) 0%, transparent 65%);
  pointer-events: none;
}
.booking-header-inner { position: relative; z-index: 1; }
.booking-header h1 {
  font-size: clamp(1.6rem, 3.5vw, 2.4rem);
  color: var(--white);
  margin-bottom: 0.4rem;
}
.booking-header p {
  font-size: 0.9rem;
  color: rgba(255,255,255,.55);
  font-weight: 300;
}

/* ─── Step progress bar ──────────────────────────────────── */
.booking-progress {
  background: var(--white);
  border-bottom: 1px solid var(--border);
  padding-block: 1.1rem;
  position: sticky;
  top: var(--nav-h);
  z-index: 100;
}
.booking-progress-inner {
  max-width: 560px;
  margin-inline: auto;
  padding-inline: var(--pad);
  display: flex;
  align-items: center;
}
.bp-step {
  display: flex;
  align-items: center;
  flex: 1;
  gap: 0.55rem;
}
.bp-step:not(:last-child)::after {
  content: '';
  flex: 1;
  height: 2px;
  background: var(--border);
  margin-inline: 0.4rem;
  border-radius: 2px;
  transition: background var(--dur-m) var(--ease);
}
.bp-step.done:not(:last-child)::after { background: var(--saffron); }

.bp-num {
  width: 30px; height: 30px; flex-shrink: 0;
  border-radius: 50%;
  border: 2px solid var(--border-mid);
  display: flex; align-items: center; justify-content: center;
  font-size: 0.78rem; font-weight: 700;
  color: var(--text-light);
  background: var(--white);
  transition: all var(--dur-m) var(--ease);
  position: relative; z-index: 1;
}
.bp-step.active .bp-num {
  border-color: var(--saffron);
  background: var(--saffron);
  color: var(--white);
  box-shadow: 0 2px 10px rgba(201,64,0,.3);
}
.bp-step.done .bp-num {
  border-color: var(--saffron);
  background: var(--saffron);
  color: var(--white);
}
.bp-step.done .bp-num::after { content: '✓'; }
.bp-step.done .bp-num span   { display: none; }

.bp-label {
  font-size: 0.75rem; font-weight: 600;
  color: var(--text-faint);
  white-space: nowrap;
  transition: color var(--dur-m);
}
.bp-step.active .bp-label { color: var(--saffron); }
.bp-step.done   .bp-label { color: var(--text-light); }

/* ─── Main booking layout ────────────────────────────────── */
.booking-body {
  max-width: 900px;
  margin-inline: auto;
  padding: var(--space-2xl) var(--pad) var(--space-3xl);
}

/* ─── Step panels ────────────────────────────────────────── */
.booking-step { display: none; }
.booking-step.active {
  display: block;
  animation: step-in .32s var(--ease) both;
}
@keyframes step-in {
  from { opacity: 0; transform: translateX(18px); }
  to   { opacity: 1; transform: none; }
}

.step-heading { margin-bottom: var(--space-xl); }
.step-heading .section-label { margin-bottom: var(--space-sm); }
.step-heading h2 {
  font-size: clamp(1.35rem, 2.5vw, 1.9rem);
  color: var(--text-dark); margin-bottom: 0.35rem;
}
.step-heading p { font-size: 0.9rem; color: var(--text-light); line-height: 1.7; }

/* ─── STEP 1 — Service & Date ────────────────────────────── */
.service-pick-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 0.8rem;
  margin-bottom: var(--space-2xl);
}

.service-pick-card {
  background: var(--white);
  border: 2px solid var(--border);
  border-radius: var(--r-lg);
  padding: 1rem 0.85rem 0.9rem;
  cursor: pointer;
  transition: all var(--dur-m) var(--ease);
  position: relative;
  overflow: hidden;
  user-select: none;
  display: flex; flex-direction: column; gap: 0.3rem;
}
.service-pick-card::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: var(--grad-saffron);
  transform: scaleX(0); transform-origin: left;
  transition: transform var(--dur-m) var(--ease);
}
.service-pick-card:hover {
  border-color: var(--border-mid); box-shadow: var(--shadow-md); transform: translateY(-2px);
}
.service-pick-card:hover::before { transform: scaleX(1); }
.service-pick-card.selected {
  border-color: var(--saffron);
  background: rgba(201,64,0,.04);
  box-shadow: 0 0 0 3px rgba(201,64,0,.1), var(--shadow-md);
}
.service-pick-card.selected::before { transform: scaleX(1); }
.spc-check {
  position: absolute; top: 0.5rem; right: 0.5rem;
  width: 18px; height: 18px; border-radius: 50%;
  background: var(--saffron); color: white;
  display: none; align-items: center; justify-content: center;
  font-size: 0.6rem; font-weight: 700;
}
.service-pick-card.selected .spc-check { display: flex; }
.spc-icon { font-size: 1.5rem; line-height: 1; }
.spc-name {
  font-family: var(--font-display);
  font-size: 0.78rem; font-weight: 700;
  color: var(--text-dark); line-height: 1.25;
}
.spc-price { font-size: 0.72rem; color: var(--saffron); font-weight: 600; }

/* Advance notice */
.advance-notice {
  display: flex; align-items: flex-start; gap: 0.6rem;
  padding: 0.75rem var(--space-md);
  background: rgba(212,144,10,.07);
  border: 1px solid rgba(212,144,10,.2);
  border-radius: var(--r-md);
  margin-bottom: var(--space-xl);
  font-size: 0.82rem; color: var(--text-body); line-height: 1.55;
}
.advance-notice-icon { font-size: 0.95rem; flex-shrink: 0; margin-top: 1px; }

/* Date & slot grid */
.date-slot-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-xl);
  margin-bottom: var(--space-2xl);
}

/* Calendar */
.calendar-wrap {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-xl);
  overflow: hidden;
}
.calendar-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: var(--space-md) var(--space-lg);
  background: var(--grad-hero);
  color: rgba(255,255,255,.85);
}
.calendar-month { font-family: var(--font-display); font-weight: 700; font-size: 0.95rem; }
.calendar-nav   { display: flex; gap: 0.4rem; }
.cal-nav-btn {
  width: 28px; height: 28px; border-radius: 50%;
  background: rgba(255,255,255,.1); border: 1px solid rgba(255,255,255,.18);
  color: rgba(255,255,255,.75); display: flex; align-items: center; justify-content: center;
  font-size: 0.85rem; cursor: pointer; transition: all var(--dur-f);
}
.cal-nav-btn:hover { background: rgba(255,255,255,.22); color: white; }
.cal-nav-btn:disabled { opacity: .3; cursor: not-allowed; }

.calendar-grid { padding: var(--space-md); }
.calendar-days-header {
  display: grid; grid-template-columns: repeat(7, 1fr); margin-bottom: 0.4rem;
}
.calendar-days-header span {
  text-align: center; font-size: 0.62rem; font-weight: 700;
  letter-spacing: 0.08em; text-transform: uppercase; color: var(--text-faint); padding: 0.3rem 0;
}
.calendar-days-header span.open-day   { color: var(--saffron); }
.calendar-days-header span.closed-day { color: var(--text-faint); opacity: .45; }

.calendar-dates { display: grid; grid-template-columns: repeat(7, 1fr); gap: 3px; }
.cal-date {
  aspect-ratio: 1; display: flex; align-items: center; justify-content: center;
  font-size: 0.78rem; border-radius: var(--r-sm); cursor: pointer;
  transition: all var(--dur-f); color: var(--text-body);
  position: relative; font-weight: 400;
}
.cal-date.empty       { cursor: default; }
.cal-date.other-month { color: var(--text-faint); opacity: .35; cursor: default; }
.cal-date.closed      { color: var(--text-faint); opacity: .3; cursor: not-allowed; }
.cal-date.too-soon    { color: var(--text-faint); opacity: .3; cursor: not-allowed; }
.cal-date.available   { color: var(--text-dark); font-weight: 600; background: rgba(201,64,0,.07); }
.cal-date.available:hover { background: rgba(201,64,0,.16); color: var(--saffron); }
.cal-date.selected    {
  background: var(--saffron); color: white;
  box-shadow: 0 2px 8px rgba(201,64,0,.35); font-weight: 700;
}
.cal-date.today::after {
  content: ''; position: absolute; bottom: 3px; left: 50%; transform: translateX(-50%);
  width: 3px; height: 3px; border-radius: 50%; background: var(--gold);
}

/* Slot picker */
.slot-panel {
  background: var(--white); border: 1px solid var(--border); border-radius: var(--r-xl); overflow: hidden;
}
.slot-panel-header {
  padding: var(--space-md) var(--space-lg); background: var(--grad-hero);
  color: rgba(255,255,255,.8); font-size: 0.76rem; font-weight: 700;
  letter-spacing: 0.1em; text-transform: uppercase;
}
.slot-panel-body { padding: var(--space-md); }
.slot-empty {
  text-align: center; padding: var(--space-xl) var(--space-md);
  color: var(--text-faint); font-size: 0.85rem; line-height: 1.7;
}
.slot-empty-icon { font-size: 1.8rem; display: block; margin-bottom: 0.55rem; opacity: .35; }
.slots-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0.42rem; }
.slot-btn {
  padding: 0.5rem 0.25rem; border: 1.5px solid var(--border); border-radius: var(--r-md);
  background: var(--white); font-size: 0.76rem; font-weight: 600; color: var(--text-body);
  cursor: pointer; transition: all var(--dur-f); text-align: center; font-family: inherit;
}
.slot-btn:hover { border-color: var(--saffron); color: var(--saffron); background: rgba(201,64,0,.04); }
.slot-btn.selected { background: var(--saffron); border-color: var(--saffron); color: white; box-shadow: 0 2px 8px rgba(201,64,0,.28); }
.slot-btn.taken    { background: var(--cream); color: var(--text-faint); border-color: var(--border); cursor: not-allowed; opacity: .45; text-decoration: line-through; }

.slot-legend {
  display: flex; gap: var(--space-md); flex-wrap: wrap;
  padding: var(--space-sm) var(--space-md) var(--space-md);
  border-top: 1px solid var(--border); margin-top: var(--space-sm);
}
.slot-legend-item { display: flex; align-items: center; gap: 0.35rem; font-size: 0.7rem; color: var(--text-faint); }
.slot-legend-dot { width: 8px; height: 8px; border-radius: 2px; flex-shrink: 0; }
.slot-legend-dot.open   { background: var(--saffron); }
.slot-legend-dot.booked { background: var(--border-mid); }

/* ─── STEP 2 — Details ───────────────────────────────────── */
.details-layout {
  display: grid; grid-template-columns: 1fr 300px;
  gap: var(--space-xl); align-items: start;
}

.form-section {
  background: var(--white); border: 1px solid var(--border);
  border-radius: var(--r-xl); overflow: hidden; margin-bottom: var(--space-lg);
}
.form-section:last-child { margin-bottom: 0; }
.form-section-header {
  padding: var(--space-md) var(--space-xl);
  background: linear-gradient(to right, rgba(201,64,0,.04), transparent);
  border-bottom: 1px solid var(--border);
  display: flex; align-items: center; gap: 0.55rem;
}
.form-section-icon  { font-size: 1rem; }
.form-section-title { font-family: var(--font-display); font-size: 0.88rem; font-weight: 700; color: var(--text-dark); }
.form-section-body  { padding: var(--space-xl); }

.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-md); margin-bottom: var(--space-md); }
.form-row.full     { grid-template-columns: 1fr; }
.form-row.thirds   { grid-template-columns: 1fr 1fr 1fr; }
.form-row:last-child { margin-bottom: 0; }

.form-group { display: flex; flex-direction: column; gap: 0.32rem; }
.form-label {
  font-size: 0.78rem; font-weight: 600; color: var(--text-mid);
  display: flex; align-items: center; gap: 0.3rem;
}
.req-star   { color: var(--saffron); font-size: 0.85rem; line-height: 1; }
.opt-tag    { font-size: 0.65rem; font-weight: 500; color: var(--text-faint); background: var(--cream-dark); padding: 0.08rem 0.42rem; border-radius: var(--r-full); }

.form-input, .form-select, .form-textarea {
  padding: 0.68rem 0.95rem; border: 1.5px solid var(--border); border-radius: var(--r-md);
  font-size: 0.9rem; color: var(--text-dark); background: var(--white);
  transition: border-color var(--dur-f), box-shadow var(--dur-f);
  outline: none; width: 100%; font-family: inherit;
}
.form-input:focus, .form-select:focus, .form-textarea:focus {
  border-color: var(--saffron); box-shadow: 0 0 0 3px rgba(201,64,0,.09);
}
.form-input.error, .form-select.error, .form-textarea.error {
  border-color: var(--error); box-shadow: 0 0 0 3px rgba(185,28,28,.08);
}
.form-textarea { resize: vertical; min-height: 88px; line-height: 1.6; }
.form-hint  { font-size: 0.72rem; color: var(--text-faint); line-height: 1.5; }
.form-error {
  display: none;
  align-items: center;
  gap: 0.35rem;
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--error);
  background: rgba(185,28,28,.07);
  border: 1px solid rgba(185,28,28,.18);
  border-radius: var(--r-sm);
  padding: 0.35rem 0.65rem;
  margin-top: 0.1rem;
  line-height: 1.4;
}
.form-error::before { content: '⚠'; font-size: 0.82rem; flex-shrink: 0; }
.form-error.show { display: flex; animation: err-shake-in .25s var(--ease); }

/* Form group highlight when child is in error */
.form-group:has(.form-input.error) .form-label,
.form-group:has(.form-select.error) .form-label,
.form-group:has(.form-textarea.error) .form-label { color: var(--error); }

/* Shake animation for Next button on failed validation */
@keyframes btn-shake {
  0%,100% { transform: translateX(0); }
  20%      { transform: translateX(-6px); }
  40%      { transform: translateX(6px); }
  60%      { transform: translateX(-4px); }
  80%      { transform: translateX(4px); }
}
.btn-next.shake { animation: btn-shake .4s var(--ease); }

@keyframes err-shake-in {
  from { opacity: 0; transform: translateY(-4px); }
  to   { opacity: 1; transform: none; }
}

/* Topic chips */
.topic-section {
  background: var(--white); border: 1px solid var(--border);
  border-radius: var(--r-xl); overflow: hidden; margin-bottom: var(--space-lg);
}
.topic-section-header {
  padding: var(--space-md) var(--space-xl);
  background: linear-gradient(to right, rgba(201,64,0,.04), transparent);
  border-bottom: 1px solid var(--border);
}
.topic-section-title { font-family: var(--font-display); font-size: 0.88rem; font-weight: 700; color: var(--text-dark); }
.topic-section-sub   { font-size: 0.74rem; color: var(--text-light); margin-top: 0.2rem; }
.topic-section-body  { padding: var(--space-xl); }

.topic-req-note {
  display: flex; align-items: flex-start; gap: 0.5rem;
  font-size: 0.78rem; color: var(--text-light); line-height: 1.55;
  margin-bottom: var(--space-lg); padding: 0.6rem var(--space-md);
  background: rgba(201,64,0,.04); border-radius: var(--r-md);
  border: 1px solid rgba(201,64,0,.1);
}
.topic-chips { display: flex; flex-wrap: wrap; gap: 0.5rem; }
.topic-chip {
  display: inline-flex; align-items: center; gap: 0.3rem;
  padding: 0.4rem 0.9rem; border: 1.5px solid var(--border); border-radius: var(--r-full);
  font-size: 0.81rem; font-weight: 500; color: var(--text-body);
  cursor: pointer; transition: all var(--dur-f); background: var(--white); user-select: none;
}
.topic-chip:hover { border-color: var(--saffron); color: var(--saffron); background: rgba(201,64,0,.04); }
.topic-chip.selected { background: var(--saffron); border-color: var(--saffron); color: white; }
.topic-chip.disabled { opacity: .35; cursor: not-allowed; pointer-events: none; }
.topic-count { font-size: 0.72rem; color: var(--text-faint); margin-top: var(--space-sm); }
.topic-count.ok   { color: var(--success); }
.topic-count.warn { color: var(--warning); }

.prashna-note {
  font-size: 0.8rem; color: var(--text-light); line-height: 1.65; margin-bottom: var(--space-md);
  padding: var(--space-md); background: rgba(212,144,10,.06);
  border-radius: var(--r-md); border: 1px solid rgba(212,144,10,.18);
}

/* Vastu upload */
.vastu-upload-zone {
  border: 2px dashed var(--border-mid); border-radius: var(--r-lg);
  padding: var(--space-xl) var(--space-md); text-align: center;
  cursor: pointer; transition: all var(--dur-m) var(--ease);
  background: var(--cream); position: relative;
}
.vastu-upload-zone:hover { border-color: var(--saffron); background: rgba(201,64,0,.03); }
.vastu-upload-zone.has-file { border-color: var(--success); border-style: solid; background: rgba(21,128,61,.04); }
.vastu-upload-zone input[type="file"] { position: absolute; inset: 0; opacity: 0; cursor: pointer; z-index: 2; }
.vastu-upload-icon  { font-size: 1.8rem; display: block; margin-bottom: 0.5rem; opacity: .4; }
.vastu-upload-label { font-size: 0.85rem; font-weight: 600; color: var(--text-mid); margin-bottom: 0.28rem; }
.vastu-upload-sub   { font-size: 0.74rem; color: var(--text-faint); }
.vastu-file-name    { font-size: 0.8rem; color: var(--success); font-weight: 600; margin-top: 0.45rem; }

/* Sidebar summary */
.details-sidebar { display: flex; flex-direction: column; gap: var(--space-md); }
.booking-summary-card {
  background: var(--grad-hero); border-radius: var(--r-xl); padding: var(--space-xl);
  position: sticky; top: calc(var(--nav-h) + 76px + 1rem);
}
.bsc-label { font-size: 0.65rem; font-weight: 700; letter-spacing: 0.18em; text-transform: uppercase; color: var(--gold-lt); margin-bottom: var(--space-md); }
.bsc-service { display: flex; align-items: center; gap: 0.6rem; margin-bottom: var(--space-md); padding-bottom: var(--space-md); border-bottom: 1px solid rgba(255,255,255,.1); }
.bsc-service-icon { font-size: 1.35rem; }
.bsc-service-name { font-family: var(--font-display); font-size: 0.9rem; font-weight: 700; color: var(--white); }
.bsc-row { display: flex; align-items: center; justify-content: space-between; font-size: 0.8rem; color: rgba(255,255,255,.45); margin-bottom: 0.38rem; }
.bsc-row span:last-child { color: rgba(255,255,255,.78); font-weight: 500; }
.bsc-price-row { display: flex; align-items: center; justify-content: space-between; padding-top: var(--space-md); margin-top: var(--space-sm); border-top: 1px solid rgba(255,255,255,.1); font-size: 0.8rem; color: rgba(255,255,255,.45); }
.bsc-price { font-family: var(--font-display); font-size: 1.5rem; font-weight: 700; color: var(--gold-lt); line-height: 1; }

/* Disclaimer checkbox */
.disclaimer-check-wrap { background: var(--white); border: 1px solid var(--border); border-radius: var(--r-lg); padding: var(--space-lg); }
.disclaimer-check { display: flex; align-items: flex-start; gap: 0.65rem; cursor: pointer; }
.disclaimer-check input[type="checkbox"] { width: 17px; height: 17px; flex-shrink: 0; margin-top: 2px; accent-color: var(--saffron); cursor: pointer; }
.disclaimer-check-text { font-size: 0.79rem; color: var(--text-light); line-height: 1.65; }
.disclaimer-check-text a { color: var(--saffron); text-decoration: underline; }

/* ─── STEP 3 — Payment ───────────────────────────────────── */
.payment-layout { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-xl); align-items: start; }

.upi-panel { background: var(--white); border: 1px solid var(--border); border-radius: var(--r-xl); overflow: hidden; }
.upi-panel-header { padding: var(--space-md) var(--space-xl); background: linear-gradient(to right, rgba(201,64,0,.04), transparent); border-bottom: 1px solid var(--border); display: flex; align-items: center; gap: 0.55rem; }
.upi-panel-title { font-family: var(--font-display); font-size: 0.88rem; font-weight: 700; color: var(--text-dark); }
.upi-panel-body { padding: var(--space-xl); text-align: center; }

.qr-placeholder {
  width: 172px; height: 172px; margin: 0 auto var(--space-lg);
  border-radius: var(--r-lg); border: 2px dashed var(--border-mid);
  background: var(--cream-card); display: flex; flex-direction: column;
  align-items: center; justify-content: center; gap: 0.45rem;
}
.qr-placeholder-icon { font-size: 2rem; opacity: .28; }
.qr-placeholder-text { font-size: 0.7rem; color: var(--text-faint); text-align: center; line-height: 1.5; }

.upi-id-display {
  display: flex; align-items: center; justify-content: center; gap: 0.65rem;
  background: var(--cream-dark); border: 1px solid var(--border);
  border-radius: var(--r-md); padding: 0.65rem var(--space-md); margin-bottom: var(--space-md);
}
.upi-id-text { font-family: monospace; font-size: 0.88rem; font-weight: 700; color: var(--text-dark); letter-spacing: 0.03em; }
.upi-copy-btn {
  font-size: 0.73rem; font-weight: 600; color: var(--saffron); cursor: pointer;
  padding: 0.2rem 0.55rem; border: 1px solid var(--saffron); border-radius: var(--r-full);
  transition: all var(--dur-f); background: none; font-family: inherit;
}
.upi-copy-btn:hover { background: var(--saffron); color: white; }

.upi-apps { display: flex; align-items: center; justify-content: center; gap: var(--space-sm); margin-bottom: var(--space-md); flex-wrap: wrap; }
.upi-app-tag { font-size: 0.7rem; color: var(--text-faint); padding: 0.18rem 0.6rem; border: 1px solid var(--border); border-radius: var(--r-full); font-weight: 500; }
.upi-amount { font-size: 0.82rem; color: var(--text-light); }
.upi-amount strong { font-family: var(--font-display); font-size: 1.15rem; color: var(--saffron); }

/* Screenshot upload */
.screenshot-upload { background: var(--white); border: 1px solid var(--border); border-radius: var(--r-xl); overflow: hidden; }
.screenshot-upload-header { padding: var(--space-md) var(--space-xl); background: linear-gradient(to right, rgba(201,64,0,.04), transparent); border-bottom: 1px solid var(--border); display: flex; align-items: center; gap: 0.55rem; }
.screenshot-upload-title { font-family: var(--font-display); font-size: 0.88rem; font-weight: 700; color: var(--text-dark); }
.screenshot-upload-body { padding: var(--space-xl); }

.screenshot-drop-zone {
  border: 2px dashed var(--border-mid); border-radius: var(--r-lg);
  padding: var(--space-xl) var(--space-md); text-align: center; cursor: pointer;
  transition: all var(--dur-m) var(--ease); background: var(--cream);
  position: relative; margin-bottom: var(--space-md);
}
.screenshot-drop-zone:hover { border-color: var(--saffron); background: rgba(201,64,0,.03); }
.screenshot-drop-zone.has-file { border-color: var(--success); border-style: solid; background: rgba(21,128,61,.04); }
.screenshot-drop-zone input[type="file"] { position: absolute; inset: 0; opacity: 0; cursor: pointer; z-index: 2; }
.sdz-icon  { font-size: 2rem; display: block; margin-bottom: 0.55rem; opacity: .38; }
.sdz-label { font-size: 0.87rem; font-weight: 600; color: var(--text-mid); margin-bottom: 0.3rem; }
.sdz-sub   { font-size: 0.74rem; color: var(--text-faint); }
.sdz-file  { font-size: 0.8rem; color: var(--success); font-weight: 600; margin-top: 0.45rem; display: none; }

.screenshot-preview { display: none; position: relative; border-radius: var(--r-md); overflow: hidden; margin-bottom: var(--space-md); }
.screenshot-preview img { width: 100%; height: 130px; object-fit: cover; display: block; }
.screenshot-preview-clear {
  position: absolute; top: 0.5rem; right: 0.5rem; width: 22px; height: 22px;
  border-radius: 50%; background: rgba(0,0,0,.55); color: white;
  display: flex; align-items: center; justify-content: center;
  font-size: 0.72rem; cursor: pointer; border: none; transition: background var(--dur-f);
}
.screenshot-preview-clear:hover { background: var(--error); }

.screenshot-note {
  font-size: 0.77rem; color: var(--text-faint); line-height: 1.6;
  padding: 0.6rem var(--space-md); background: rgba(212,144,10,.06);
  border-radius: var(--r-sm); border-left: 2px solid var(--gold);
}

/* Payment summary */
.payment-summary-card { background: var(--cream-card); border: 1px solid var(--border); border-radius: var(--r-xl); padding: var(--space-xl); margin-bottom: var(--space-md); }
.psc-title { font-family: var(--font-display); font-size: 0.82rem; font-weight: 700; color: var(--text-dark); margin-bottom: var(--space-md); padding-bottom: var(--space-sm); border-bottom: 1px solid var(--border); }
.psc-row { display: flex; justify-content: space-between; font-size: 0.82rem; margin-bottom: 0.38rem; color: var(--text-light); }
.psc-row span:last-child { color: var(--text-body); font-weight: 500; }
.psc-row.total { margin-top: var(--space-sm); padding-top: var(--space-sm); border-top: 1px solid var(--border); font-weight: 700; color: var(--text-dark); font-size: 0.9rem; }
.psc-row.total span:last-child { color: var(--saffron); font-size: 1.1rem; font-family: var(--font-display); }

.important-note {
  font-size: 0.77rem; color: var(--text-light); line-height: 1.65; padding: 0.65rem var(--space-md);
  background: rgba(212,144,10,.06); border: 1px solid rgba(212,144,10,.2); border-radius: var(--r-md); margin-bottom: var(--space-md);
}
.important-note strong { color: var(--warning); display: block; margin-bottom: 0.2rem; font-size: 0.7rem; letter-spacing: 0.08em; text-transform: uppercase; }

/* ─── Navigation buttons ─────────────────────────────────── */
.booking-nav { display: flex; align-items: center; justify-content: space-between; margin-top: var(--space-2xl); padding-top: var(--space-xl); border-top: 1px solid var(--border); gap: var(--space-md); }
.btn-back {
  display: inline-flex; align-items: center; gap: 0.4rem; padding: 0.7rem 1.4rem;
  border-radius: var(--r-full); font-size: 0.88rem; font-weight: 500; color: var(--text-light);
  border: 1.5px solid var(--border); background: var(--white); cursor: pointer;
  transition: all var(--dur-f); font-family: inherit;
}
.btn-back:hover { border-color: var(--border-mid); color: var(--text-dark); }
.btn-next {
  display: inline-flex; align-items: center; gap: 0.4rem; padding: 0.85rem 2.2rem;
  border-radius: var(--r-full); font-size: 0.95rem; font-weight: 600;
  background: var(--grad-saffron); color: white; border: none; cursor: pointer;
  box-shadow: 0 4px 18px rgba(201,64,0,.35); transition: all var(--dur-m) var(--ease); font-family: inherit;
}
.btn-next:hover { transform: translateY(-2px); box-shadow: 0 7px 26px rgba(201,64,0,.45); }
.btn-next:disabled { opacity: .45; cursor: not-allowed; transform: none; box-shadow: none; }

/* ─── Responsive ─────────────────────────────────────────── */
@media (max-width: 900px) {
  .service-pick-grid { grid-template-columns: repeat(3, 1fr); }
  .date-slot-grid    { grid-template-columns: 1fr; }
  .details-layout    { grid-template-columns: 1fr; }
  .payment-layout    { grid-template-columns: 1fr; }
  .booking-summary-card { position: static; }
}
@media (max-width: 768px) {
  .service-pick-grid { grid-template-columns: repeat(2, 1fr); }
  .form-row, .form-row.thirds { grid-template-columns: 1fr; }
  .slots-grid        { grid-template-columns: repeat(4, 1fr); }
  .bp-label          { display: none; }
}
@media (max-width: 480px) {
  .service-pick-grid { grid-template-columns: 1fr 1fr; }
  .slots-grid        { grid-template-columns: repeat(3, 1fr); }
  .booking-nav       { flex-direction: column-reverse; }
  .booking-nav .btn-next, .booking-nav .btn-back { width: 100%; justify-content: center; }
}


/* ─── Birth time 12-hr input row ─────────────────────────── */
.birth-time-row {
  display: flex;
  align-items: flex-start;
  gap: 0.3rem;
}

/* Each HH / MM / SS field wrapper */
.bt-field-wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.22rem;
  flex: 0 0 64px;   /* fixed width — never shrink */
}

/* Number input — explicitly sized, never truncated */
.bt-num-input {
  width: 64px;
  text-align: center;
  font-size: 1.05rem;
  font-weight: 600;
  padding: 0.7rem 0.4rem;
  letter-spacing: 0.05em;
  -moz-appearance: textfield;
  box-sizing: border-box;
}
.bt-num-input::-webkit-outer-spin-button,
.bt-num-input::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }

.bt-num-input.error {
  border-color: var(--error);
  box-shadow: 0 0 0 3px rgba(185,28,28,.08);
}

/* Sub-label below input */
.bt-field-label {
  font-size: 0.62rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-faint);
  line-height: 1;
}

/* Colon separator — align vertically with middle of input */
.bt-sep {
  color: var(--border-mid);
  font-weight: 700;
  font-size: 1.3rem;
  flex-shrink: 0;
  margin-top: 0.6rem; /* push down to align with input center */
  user-select: none;
  line-height: 1;
}

/* AM / PM pill toggle — stacked vertically, aligned with inputs */
.bt-ampm-toggle {
  display: flex;
  flex-direction: column;
  gap: 4px;
  flex-shrink: 0;
  margin-left: 0.3rem;
  margin-top: 0.15rem;
}
.bt-ampm-btn {
  padding: 0.42rem 0.85rem;
  border-radius: var(--r-sm);
  border: 1.5px solid var(--border);
  background: var(--white);
  font-size: 0.8rem;
  font-weight: 700;
  color: var(--text-faint);
  cursor: pointer;
  transition: all var(--dur-f);
  font-family: inherit;
  letter-spacing: 0.05em;
  line-height: 1;
  text-align: center;
  min-width: 48px;
}
.bt-ampm-btn:hover {
  border-color: var(--saffron);
  color: var(--saffron);
  background: rgba(201,64,0,.05);
}
.bt-ampm-btn.active {
  background: var(--saffron);
  border-color: var(--saffron);
  color: var(--white);
  box-shadow: 0 2px 8px rgba(201,64,0,.28);
}

/* Per-field inline error */
.bt-field-error {
  font-size: 0.65rem;
  color: var(--error);
  line-height: 1.3;
  text-align: center;
  display: none;
  margin-top: 1px;
}
.bt-field-error.show { display: block; }

/* Overall birth time error (shown on step validation) */
.bt-row-error {
  font-size: 0.73rem;
  color: var(--error);
  display: none;
  margin-top: 0.3rem;
}
.bt-row-error.show { display: block; }

@media (max-width: 480px) {
  .bt-field-wrap  { flex: 0 0 54px; }
  .bt-num-input   { width: 54px; font-size: 0.95rem; padding: 0.6rem 0.3rem; }
  .bt-ampm-btn    { padding: 0.38rem 0.65rem; font-size: 0.75rem; min-width: 42px; }
}

/* ─── Birth details layout ───────────────────────────────── */
/* Row 1: Date (fixed) + Time (flexible) */
.birth-row-1 {
  grid-template-columns: 200px 1fr;
  align-items: start;
}
@media (max-width: 600px) {
  .birth-row-1 { grid-template-columns: 1fr; }
}
