/* =============================================================================
   MediCore — Public Booking Form
   Full reset within scope to prevent WordPress theme overrides.
   ============================================================================= */

/* ── CSS variables — override at theme level if needed ─────────────────────
   Example: add to your theme's CSS:
   .mc-booking-wrap { --mc-accent: #your-color; }
   ──────────────────────────────────────────────────────────────────────────── */
.mc-booking-wrap {
  --mc-accent:      var(--wp--preset--color--primary, #3b82f6);
  --mc-accent-dark: #2563eb;
  --mc-accent-bg:   #eff6ff;
  --mc-accent-ring: rgba(59,130,246,.25);
  --mc-green:       #10b981;
  --mc-green-bg:    #d1fae5;
  --mc-green-border:#a7f3d0;
  --mc-red:         #ef4444;
  --mc-gray-50:     #f8fafc;
  --mc-gray-100:    #f1f5f9;
  --mc-gray-200:    #e2e8f0;
  --mc-gray-300:    #cbd5e1;
  --mc-gray-400:    #94a3b8;
  --mc-gray-500:    #64748b;
  --mc-gray-600:    #475569;
  --mc-gray-700:    #334155;
  --mc-gray-800:    #1e293b;
  --mc-gray-900:    #0f172a;
  --mc-white:       #ffffff;
  --mc-font:        -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
  --mc-r:           10px;
  --mc-r-sm:        7px;
  --mc-shadow:      0 1px 3px rgba(0,0,0,.08);
  --mc-shadow-md:   0 4px 16px rgba(0,0,0,.1);
}

/* ── Scoped reset — prevent theme from breaking our styles ──────────────── */
.mc-booking-wrap,
.mc-booking-wrap *,
.mc-booking-wrap *::before,
.mc-booking-wrap *::after {
  box-sizing: border-box !important;
  line-height: normal;
}

/* Reset headings, paragraphs — themes set huge margins/sizes */
.mc-booking-wrap p,
.mc-booking-wrap ul,
.mc-booking-wrap li { margin: 0; padding: 0; list-style: none; }

/* Reset ALL buttons inside our wrapper — most critical fix */
.mc-booking-wrap button {
  all: unset !important;
  box-sizing: border-box !important;
  cursor: pointer !important;
  font-family: var(--mc-font) !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  border: none !important;
  background: none !important;
  padding: 0 !important;
  margin: 0 !important;
  width: auto !important;
  min-width: 0 !important;
  text-decoration: none !important;
  line-height: 1 !important;
  -webkit-appearance: none !important;
  -moz-appearance: none !important;
  appearance: none !important;
}

/* Reset ALL inputs, selects, textareas */
.mc-booking-wrap input,
.mc-booking-wrap select,
.mc-booking-wrap textarea {
  font-family: var(--mc-font) !important;
  font-size: 14px !important;
  box-sizing: border-box !important;
  -webkit-appearance: none !important;
  -moz-appearance: none !important;
  appearance: none !important;
}

/* ── Wrapper ─────────────────────────────────────────────────────────────── */
.mc-booking-wrap {
  font-family: var(--mc-font);
  max-width: 820px;
  margin: 0 auto;
  background: var(--mc-white);
  border-radius: 14px;
  box-shadow: 0 2px 20px rgba(0,0,0,.09);
  padding: 32px 36px;
  color: var(--mc-gray-700);
  position: relative;
}
@media (max-width: 600px) {
  .mc-booking-wrap { padding: 20px 16px; border-radius: 0; box-shadow: none; }
}

/* ── Step progress ───────────────────────────────────────────────────────── */
.mc-steps-progress {
  display: flex;
  align-items: center;
  margin-bottom: 28px;
}
.mc-step-indicator {
  display: flex; align-items: center; gap: 7px;
  font-size: 13px; font-weight: 500; color: var(--mc-gray-400);
  font-family: var(--mc-font);
}
.mc-step-indicator__number {
  width: 26px; height: 26px; border-radius: 50%;
  background: var(--mc-gray-100); color: var(--mc-gray-400);
  display: flex; align-items: center; justify-content: center;
  font-weight: 700; font-size: 12px; transition: all .25s; flex-shrink: 0;
}
.mc-step-indicator__label { white-space: nowrap; }
.mc-step-indicator.active .mc-step-indicator__number { background: var(--mc-accent); color: #fff; }
.mc-step-indicator.active                             { color: var(--mc-gray-800); font-weight: 600; }
.mc-step-indicator.done   .mc-step-indicator__number  { background: var(--mc-green); color: #fff; }
.mc-step-indicator__connector { flex: 1; min-width: 20px; height: 1px; background: var(--mc-gray-200); margin: 0 6px; }
@media (max-width: 420px) { .mc-step-indicator__label { display: none; } }

/* ── Step 1 header ───────────────────────────────────────────────────────── */
.mc-booking-step__header { margin-bottom: 24px; }
.mc-booking-title {
  font-size: 22px !important;
  font-weight: 700 !important;
  color: var(--mc-gray-900) !important;
  margin: 0 0 4px !important;
  line-height: 1.2 !important;
  font-family: var(--mc-font) !important;
}
.mc-clinic-name {
  display: flex; align-items: center; gap: 5px;
  font-size: 13px !important; color: var(--mc-gray-400) !important;
  margin: 0 !important; font-family: var(--mc-font) !important;
}
.mc-clinic-name svg { flex-shrink: 0; }

/* ── Date + time grid ────────────────────────────────────────────────────── */
.mc-date-time-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-bottom: 20px;
}
@media (max-width: 560px) { .mc-date-time-grid { grid-template-columns: 1fr; } }

/* ── Calendar picker ─────────────────────────────────────────────────────── */
.mc-calendar-picker {
  border: 1px solid var(--mc-gray-200); border-radius: var(--mc-r); overflow: hidden;
  background: var(--mc-white); box-shadow: var(--mc-shadow);
}
.mc-calendar-picker__header {
  display: flex !important; align-items: center !important; justify-content: space-between !important;
  padding: 12px 14px !important; background: var(--mc-gray-900) !important;
}
.mc-calendar-picker__month {
  font-size: 13px !important; font-weight: 600 !important; color: #fff !important;
  text-transform: capitalize !important; font-family: var(--mc-font) !important;
  flex: 1 !important; text-align: center !important;
}

/* ── Calendar nav buttons — full reset ──────────────────────────────────── */
.mc-booking-wrap .mc-calendar-nav {
  /* Full override — prevents ANY theme button style from leaking in */
  all: unset !important;
  box-sizing: border-box !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 28px !important;
  height: 28px !important;
  min-width: 28px !important;
  max-width: 28px !important;
  min-height: 28px !important;
  flex-shrink: 0 !important;
  background: rgba(255,255,255,.15) !important;
  border: none !important;
  border-radius: 6px !important;
  color: #fff !important;
  cursor: pointer !important;
  font-size: 17px !important;
  line-height: 1 !important;
  padding: 0 !important;
  margin: 0 !important;
  transition: background .15s !important;
  -webkit-appearance: none !important;
  appearance: none !important;
  text-decoration: none !important;
}
.mc-booking-wrap .mc-calendar-nav:hover {
  background: rgba(255,255,255,.3) !important;
}

/* Calendar weekdays + days */
.mc-calendar-picker__weekdays {
  display: grid; grid-template-columns: repeat(7, 1fr);
  padding: 8px 10px 4px; background: var(--mc-gray-50);
  border-bottom: 1px solid var(--mc-gray-100); gap: 2px;
}
.mc-calendar-picker__weekdays span {
  text-align: center; font-size: 10px; font-weight: 600;
  color: var(--mc-gray-400); text-transform: uppercase; letter-spacing: .3px;
  font-family: var(--mc-font);
}
.mc-calendar-picker__days {
  display: grid; grid-template-columns: repeat(7, 1fr); padding: 8px 10px 12px; gap: 3px;
}
.mc-calendar-day {
  aspect-ratio: 1; display: flex; align-items: center; justify-content: center;
  border-radius: 6px; font-size: 13px; font-weight: 500; cursor: default;
  transition: all .12s; border: 1.5px solid transparent; position: relative;
  font-family: var(--mc-font);
}
.mc-calendar-day.empty { visibility: hidden; }
.mc-calendar-day.past,
.mc-calendar-day.unavailable { color: var(--mc-gray-200); pointer-events: none; }
.mc-calendar-day.available {
  color: var(--mc-gray-800); cursor: pointer; font-weight: 600;
  background: var(--mc-gray-50);
}
.mc-calendar-day.available:hover {
  background: var(--mc-accent-bg); color: var(--mc-accent);
  border-color: var(--mc-accent-bg);
}
.mc-calendar-day.selected {
  background: var(--mc-accent); color: #fff; border-color: var(--mc-accent);
}
.mc-calendar-day.today::after {
  content: ''; position: absolute; bottom: 3px; left: 50%; transform: translateX(-50%);
  width: 3px; height: 3px; border-radius: 50%; background: currentColor; opacity: .5;
}
.mc-calendar-loading {
  grid-column: 1/-1; text-align: center; padding: 18px 0;
  color: var(--mc-gray-400); font-size: 13px; font-family: var(--mc-font);
}

/* ── Time slots panel ────────────────────────────────────────────────────── */
.mc-time-slots-panel {
  border: 1px solid var(--mc-gray-200); border-radius: var(--mc-r);
  overflow: hidden; display: flex; flex-direction: column;
  background: var(--mc-white); box-shadow: var(--mc-shadow);
}
.mc-time-slots-title {
  /* p tag — override any inherited styles */
  font-size: 12px !important; font-weight: 600 !important;
  color: var(--mc-gray-600) !important; text-transform: uppercase !important;
  letter-spacing: .4px !important; margin: 0 !important;
  padding: 12px 14px !important; border-bottom: 1px solid var(--mc-gray-100) !important;
  background: var(--mc-gray-50) !important; font-family: var(--mc-font) !important;
  line-height: 1.4 !important;
}
.mc-time-slots-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 7px;
  padding: 12px; overflow-y: auto; max-height: 300px; flex: 1;
}

/* ── Time slot buttons — full reset ──────────────────────────────────────── */
.mc-booking-wrap .mc-time-slot {
  all: unset !important;
  box-sizing: border-box !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 9px 8px !important;
  border: 1.5px solid var(--mc-gray-200) !important;
  border-radius: var(--mc-r-sm) !important;
  cursor: pointer !important;
  font-size: 13px !important;
  font-weight: 500 !important;
  color: var(--mc-gray-700) !important;
  text-align: center !important;
  transition: all .12s !important;
  background: var(--mc-white) !important;
  font-family: var(--mc-font) !important;
  line-height: 1 !important;
  width: 100% !important;
}
.mc-booking-wrap .mc-time-slot:hover {
  border-color: var(--mc-accent) !important;
  color: var(--mc-accent) !important;
  background: var(--mc-accent-bg) !important;
}
.mc-booking-wrap .mc-time-slot.selected {
  border-color: var(--mc-accent) !important;
  background: var(--mc-accent) !important;
  color: #fff !important;
}
.mc-slots-placeholder { grid-column: 1/-1; text-align: center; padding: 28px 12px; color: var(--mc-gray-400); }
.mc-slots-placeholder svg { display: block; margin: 0 auto 8px; opacity: .35; }
.mc-slots-placeholder p { font-size: 12px !important; font-family: var(--mc-font) !important; margin: 0 !important; }
.mc-slots-loading { grid-column: 1/-1; text-align: center; padding: 18px; color: var(--mc-gray-400); font-size: 13px; font-family: var(--mc-font); }
.mc-no-slots { grid-column: 1/-1; text-align: center; padding: 18px; }
.mc-no-slots p { color: var(--mc-gray-400); font-size: 13px !important; margin: 0 !important; }

/* ── Step footer ─────────────────────────────────────────────────────────── */
.mc-step-footer {
  display: flex; align-items: center; justify-content: space-between;
  padding-top: 18px; border-top: 1px solid var(--mc-gray-100); gap: 12px; flex-wrap: wrap;
}
.mc-selected-summary {
  display: flex; align-items: center; gap: 7px; font-size: 13px;
  color: var(--mc-gray-700); background: var(--mc-green-bg);
  padding: 7px 13px; border-radius: var(--mc-r-sm); border: 1px solid var(--mc-green-border);
  font-weight: 500; font-family: var(--mc-font);
}

/* ── Our action buttons — fully scoped overrides ─────────────────────────── */
.mc-booking-wrap .mc-btn {
  all: unset !important;
  box-sizing: border-box !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 6px !important;
  padding: 10px 20px !important;
  border-radius: var(--mc-r-sm) !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  cursor: pointer !important;
  border: 1.5px solid transparent !important;
  transition: all .15s !important;
  font-family: var(--mc-font) !important;
  white-space: nowrap !important;
  line-height: 1.4 !important;
  text-decoration: none !important;
  -webkit-appearance: none !important;
  appearance: none !important;
  width: auto !important;
}
.mc-booking-wrap .mc-btn:focus-visible {
  outline: 2px solid var(--mc-accent) !important; outline-offset: 2px !important;
}
.mc-booking-wrap .mc-btn:disabled { opacity: .45 !important; cursor: not-allowed !important; }
.mc-booking-wrap .mc-btn--primary {
  background: var(--mc-accent) !important; color: #fff !important; border-color: var(--mc-accent) !important;
}
.mc-booking-wrap .mc-btn--primary:hover:not(:disabled) {
  background: var(--mc-accent-dark) !important;
}
.mc-booking-wrap .mc-btn--outline {
  background: var(--mc-white) !important; color: var(--mc-gray-600) !important;
  border-color: var(--mc-gray-300) !important;
}
.mc-booking-wrap .mc-btn--outline:hover:not(:disabled) {
  border-color: var(--mc-gray-500) !important; color: var(--mc-gray-800) !important;
}
.mc-booking-wrap .mc-btn--lg { padding: 12px 26px !important; font-size: 15px !important; }

.mc-btn--loading::before {
  content: '' !important; width: 14px !important; height: 14px !important;
  border: 2px solid rgba(255,255,255,.3) !important; border-top-color: #fff !important;
  border-radius: 50% !important; animation: mc-spin .7s linear infinite !important;
  flex-shrink: 0 !important;
}
@keyframes mc-spin { to { transform: rotate(360deg); } }

/* ── Step 2 — Patient form ───────────────────────────────────────────────── */
.mc-booking-step__header .mc-selected-appointment-summary {
  display: inline-flex; align-items: center; gap: 6px;
  background: var(--mc-accent-bg); border: 1px solid #bfdbfe;
  padding: 6px 12px; border-radius: var(--mc-r-sm);
  font-size: 13px; color: var(--mc-accent); font-weight: 500;
  margin-top: 10px; font-family: var(--mc-font);
}
.mc-form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 13px; margin-bottom: 4px; }
.mc-form-field--full { grid-column: 1 / -1; }
@media (max-width: 500px) { .mc-form-grid { grid-template-columns: 1fr; } }

.mc-field-label {
  display: block; font-size: 11px !important; font-weight: 600;
  color: var(--mc-gray-500) !important; margin-bottom: 5px;
  text-transform: uppercase; letter-spacing: .4px; font-family: var(--mc-font) !important;
}
.mc-required { color: var(--mc-red); }
.mc-optional { color: var(--mc-gray-400); font-weight: 400; text-transform: none; letter-spacing: 0; }

.mc-booking-wrap .mc-field-input,
.mc-booking-wrap .mc-field-textarea {
  width: 100% !important; padding: 10px 13px !important;
  border: 1.5px solid var(--mc-gray-200) !important; border-radius: var(--mc-r-sm) !important;
  font-size: 14px !important; font-family: var(--mc-font) !important;
  color: var(--mc-gray-800) !important; background: var(--mc-white) !important;
  transition: border-color .15s, box-shadow .15s !important;
  box-sizing: border-box !important; display: block !important;
}
.mc-booking-wrap .mc-field-input::placeholder,
.mc-booking-wrap .mc-field-textarea::placeholder { color: var(--mc-gray-300) !important; }
.mc-booking-wrap .mc-field-input:focus,
.mc-booking-wrap .mc-field-textarea:focus {
  outline: none !important; border-color: var(--mc-accent) !important;
  box-shadow: 0 0 0 3px var(--mc-accent-ring) !important;
}
.mc-booking-wrap .mc-field-input.mc-error,
.mc-booking-wrap .mc-field-textarea.mc-error { border-color: var(--mc-red) !important; }
.mc-field-error {
  display: block; font-size: 11px; color: var(--mc-red);
  margin-top: 3px; min-height: 14px; font-family: var(--mc-font);
}
.mc-booking-wrap .mc-field-textarea { resize: vertical !important; min-height: 80px !important; }

/* ── Step 3 — Success ────────────────────────────────────────────────────── */
.mc-success-screen { text-align: center; padding: 32px 20px; }
.mc-success-icon-wrap {
  width: 60px; height: 60px; border-radius: 50%; background: var(--mc-green-bg);
  display: flex; align-items: center; justify-content: center;
  margin: 0 auto 18px; animation: mc-pop .4s ease; color: var(--mc-green);
}
@keyframes mc-pop { 0% { transform: scale(.5); opacity: 0; } 70% { transform: scale(1.1); } 100% { transform: scale(1); opacity: 1; } }
.mc-success-screen__title {
  font-size: 20px !important; font-weight: 700 !important;
  color: var(--mc-gray-900) !important; margin: 0 0 8px !important; font-family: var(--mc-font) !important;
}
.mc-success-screen__subtitle {
  font-size: 14px !important; color: var(--mc-gray-500) !important;
  margin: 0 0 24px !important; font-family: var(--mc-font) !important;
}
.mc-success-details {
  display: inline-flex; flex-direction: column; gap: 10px; text-align: left;
  background: var(--mc-gray-50); border: 1px solid var(--mc-gray-200);
  border-radius: var(--mc-r); padding: 18px 24px; margin-bottom: 24px; min-width: 240px;
}
.mc-success-detail { display: flex; justify-content: space-between; gap: 20px; }
.mc-success-detail__label {
  font-size: 13px !important; color: var(--mc-gray-400) !important; font-family: var(--mc-font) !important;
}
.mc-success-detail__value {
  font-size: 13px !important; font-weight: 600 !important; color: var(--mc-gray-800) !important; font-family: var(--mc-font) !important;
}
.mc-success-actions { display: flex; justify-content: center; }

/* Flip arrow for "back" button */
.mc-icon-flip { transform: scaleX(-1); display: inline-block; }

/* ── Error banner ────────────────────────────────────────────────────────── */
.mc-error-banner {
  position: fixed; bottom: 24px; left: 50%; transform: translateX(-50%);
  background: var(--mc-gray-900); color: #fff; padding: 12px 16px;
  border-radius: var(--mc-r-sm); display: flex; align-items: center; gap: 10px;
  box-shadow: 0 8px 24px rgba(0,0,0,.2); z-index: 99999;
  max-width: 460px; width: calc(100% - 32px);
  animation: mc-slide-up .3s ease; font-family: var(--mc-font); font-size: 13px;
}
@keyframes mc-slide-up { from { transform: translateX(-50%) translateY(60px); opacity: 0; } to { transform: translateX(-50%) translateY(0); opacity: 1; } }
.mc-booking-wrap .mc-error-banner__close {
  all: unset !important; color: rgba(255,255,255,.6) !important; cursor: pointer !important;
  font-size: 16px !important; margin-left: auto !important; padding: 0 !important;
  line-height: 1 !important;
}
.mc-booking-wrap .mc-error-banner__close:hover { color: #fff !important; }
