/* ═══════════════════════════════════════════════════════
   DCA Hammam Booking — Active/Modern Design System
   Matches dcaactive.org color scheme
   ═══════════════════════════════════════════════════════ */

:root {
  --dhb-primary:    #B1FC54; /* Bright Lime Green from DCA Active */
  --dhb-primary-hover: #9ce042;
  --dhb-slate:      #1E3F52; /* Dark Slate Blue */
  --dhb-slate-dark: #132B3A;
  --dhb-burgundy:   #632641; /* From Logo */
  --dhb-bg:         #FFFFFF;
  --dhb-bg-alt:     #F8F9FA;
  --dhb-text:       #333333;
  --dhb-text-muted: #666666;
  --dhb-border:     #E5E7EB;
  --dhb-radius:     16px;
  --dhb-radius-sm:  8px;
  --dhb-shadow:     0 12px 40px rgba(0,0,0,0.08);
  --dhb-transition: 0.25s ease-in-out;
}

/* ── Widget Shell ── */
.dca-hammam-app.dhb-widget {
  position: relative !important;
  max-width: 1000px !important;
  margin: 0 auto !important;
  background: var(--dhb-bg) !important;
  border-radius: var(--dhb-radius) !important;
  border: 1px solid var(--dhb-border) !important;
  box-shadow: var(--dhb-shadow) !important;
  color: var(--dhb-text) !important;
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif !important;
  overflow: hidden !important;
  padding: 0 0 40px !important;
  line-height: 1.5 !important;
  -webkit-font-smoothing: antialiased !important;
  -moz-osx-font-smoothing: grayscale !important;
}

.dca-hammam-app * {
  box-sizing: border-box !important;
}

/* ── Header ── */
.dca-hammam-app .dhb-header {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  padding: 32px 40px 24px !important;
  background: var(--dhb-slate) !important;
  color: #FFFFFF !important;
  text-align: center !important;
}

.dca-hammam-app .dhb-logos {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  margin-bottom: 20px !important;
  background: #FFFFFF !important;
  padding: 8px 16px !important;
  border-radius: 12px !important;
  box-shadow: 0 4px 12px rgba(0,0,0,0.15) !important;
}

.dca-hammam-app .dhb-logos img,
.dca-hammam-app .dhb-logo-combined,
.dca-hammam-app img.dhb-logo-combined {
  width: auto !important;
  max-width: 100% !important;
  object-fit: contain !important;
  margin: 0 !important;
  padding: 0 !important;
  border: none !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  display: block !important;
}

.dca-hammam-app .dhb-eyebrow {
  font-size: 12px !important;
  letter-spacing: 0.15em !important;
  text-transform: uppercase !important;
  color: var(--dhb-primary) !important;
  margin: 0 0 8px !important;
  font-weight: 600 !important;
}

.dca-hammam-app .dhb-title {
  font-family: 'Bebas Neue', 'Inter', sans-serif !important;
  font-size: clamp(24px, 4vw, 36px) !important;
  font-weight: 800 !important;
  margin: 0 !important;
  line-height: 1.2 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.02em !important;
  color: #FFFFFF !important;
}

/* ── Progress ── */
.dca-hammam-app .dhb-progress-wrap {
  padding: 24px 40px 0 !important;
  background: var(--dhb-bg) !important;
}

.dca-hammam-app .dhb-progress-bar {
  height: 6px !important;
  background: var(--dhb-bg-alt) !important;
  border-radius: 99px !important;
  overflow: hidden !important;
  margin-bottom: 16px !important;
  box-shadow: inset 0 1px 3px rgba(0,0,0,0.05) !important;
}

.dca-hammam-app .dhb-progress-fill {
  height: 100% !important;
  background: var(--dhb-primary) !important;
  border-radius: 99px !important;
  transition: width 0.5s ease !important;
}

.dca-hammam-app .dhb-step-labels {
  display: flex !important;
  justify-content: space-between !important;
}

.dca-hammam-app .dhb-step-lbl {
  font-size: 11px !important;
  text-transform: uppercase !important;
  letter-spacing: 0.05em !important;
  color: #A0AEC0 !important;
  font-weight: 600 !important;
  transition: color var(--dhb-transition) !important;
}

.dca-hammam-app .dhb-step-lbl.active {
  color: var(--dhb-slate) !important;
}

/* ── Steps ── */
.dca-hammam-app .dhb-step {
  display: none;
  padding: 32px 40px 0 !important;
  opacity: 0;
}

.dca-hammam-app .dhb-step.dhb-step-active {
  display: block !important;
  opacity: 1 !important;
  animation: dhbFadeIn 0.3s ease forwards !important;
}

@keyframes dhbFadeIn {
  from { opacity: 0; transform: translateY(10px); }
  to { opacity: 1; transform: none; }
}

.dca-hammam-app .dhb-step-title {
  font-family: 'Bebas Neue', 'Inter', sans-serif !important;
  font-size: clamp(22px, 3vw, 28px) !important;
  font-weight: 800 !important;
  margin: 0 0 8px !important;
  color: var(--dhb-slate) !important;
  text-transform: uppercase !important;
}

.dca-hammam-app .dhb-step-sub {
  font-size: 15px !important;
  color: var(--dhb-text-muted) !important;
  margin: 0 0 24px !important;
}

/* ── Service Cards ── */
.dca-hammam-app .dhb-cards {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 20px !important;
  margin-top: 24px !important;
}

@media (max-width: 950px) {
  .dca-hammam-app .dhb-cards { 
    grid-template-columns: 1fr !important; 
    max-width: 480px !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }
}

.dca-hammam-app .dhb-card {
  position: relative !important;
  background: var(--dhb-bg) !important;
  border: 2px solid var(--dhb-border) !important;
  border-radius: var(--dhb-radius) !important;
  padding: 32px 24px !important;
  text-align: left !important;
  cursor: pointer !important;
  transition: var(--dhb-transition) !important;
  color: var(--dhb-text) !important;
  display: flex !important;
  flex-direction: column !important;
  overflow: hidden !important;
}

.dca-hammam-app .dhb-card:hover {
  border-color: var(--dhb-primary) !important;
  transform: translateY(-4px) !important;
  box-shadow: 0 12px 30px rgba(177, 252, 84, 0.2) !important;
}

.dca-hammam-app .dhb-card-featured {
  border-color: var(--dhb-slate) !important;
  background: var(--dhb-bg-alt) !important;
}

.dca-hammam-app .dhb-card-ribbon {
  position: absolute !important;
  top: 16px !important;
  right: -30px !important;
  background: var(--dhb-slate) !important;
  color: #FFFFFF !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.1em !important;
  padding: 4px 40px !important;
  transform: rotate(35deg) !important;
  box-shadow: 0 2px 4px rgba(0,0,0,0.1) !important;
}

.dca-hammam-app .dhb-card-top {
  display: flex !important;
  justify-content: space-between !important;
  align-items: flex-start !important;
  margin-bottom: 20px !important;
}

.dca-hammam-app .dhb-card-icon {
  color: var(--dhb-slate) !important;
  background: var(--dhb-bg-alt) !important;
  width: 48px !important;
  height: 48px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  border-radius: 12px !important;
}

.dca-hammam-app .dhb-card-badge {
  font-size: 28px !important;
  font-weight: 800 !important;
  color: var(--dhb-slate) !important;
  font-family: 'Bebas Neue', 'Inter', sans-serif !important;
}

.dca-hammam-app .dhb-card-badge span {
  font-size: 16px !important;
}

.dca-hammam-app .dhb-badge-custom {
  font-family: 'Inter', sans-serif !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  background: var(--dhb-bg-alt) !important;
  border: 1px solid var(--dhb-border) !important;
  padding: 4px 10px !important;
  border-radius: 20px !important;
  color: var(--dhb-slate) !important;
}

.dca-hammam-app .dhb-card-name {
  font-size: 20px !important;
  font-weight: 800 !important;
  margin: 0 0 6px !important;
  color: var(--dhb-slate) !important;
  text-transform: uppercase !important;
}

.dca-hammam-app .dhb-card-tag {
  font-size: 12px !important;
  color: var(--dhb-burgundy) !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  margin: 0 0 20px !important;
}

.dca-hammam-app .dhb-card-features {
  margin: 0 0 24px !important;
  padding-left: 0 !important;
  list-style: none !important;
  flex: 1 !important;
}

.dca-hammam-app .dhb-card-features li {
  font-size: 14px !important;
  color: var(--dhb-text-muted) !important;
  margin-bottom: 10px !important;
  position: relative !important;
  padding-left: 24px !important;
  line-height: 1.4 !important;
}

.dca-hammam-app .dhb-card-features li::before {
  content: '✓' !important;
  position: absolute !important;
  left: 0 !important;
  color: var(--dhb-primary) !important;
  font-size: 14px !important;
  font-weight: 800 !important;
}

.dca-hammam-app .dhb-card-cta {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  background: var(--dhb-primary) !important;
  color: var(--dhb-slate-dark) !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  padding: 12px 20px !important;
  border-radius: var(--dhb-radius-sm) !important;
  margin-top: auto !important;
  text-transform: uppercase !important;
  transition: var(--dhb-transition) !important;
}

.dca-hammam-app .dhb-card:hover .dhb-card-cta {
  background: var(--dhb-slate) !important;
  color: #FFFFFF !important;
}

.dca-hammam-app .dhb-cta-inquiry {
  background: var(--dhb-bg-alt) !important;
  color: var(--dhb-slate) !important;
  border: 1px solid var(--dhb-border) !important;
}

.dca-hammam-app .dhb-card:hover .dhb-cta-inquiry {
  background: var(--dhb-slate) !important;
  color: #FFFFFF !important;
  border-color: var(--dhb-slate) !important;
}

/* ── Gender ── */
.dca-hammam-app .dhb-gender-grid {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 24px !important;
  margin: 24px 0 !important;
}

.dca-hammam-app .dhb-gender-btn {
  background: var(--dhb-bg) !important;
  border: 2px solid var(--dhb-border) !important;
  border-radius: var(--dhb-radius) !important;
  padding: 40px 24px !important;
  cursor: pointer !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  gap: 12px !important;
  transition: var(--dhb-transition) !important;
  color: var(--dhb-slate) !important;
}

.dca-hammam-app .dhb-gender-btn:hover, 
.dca-hammam-app .dhb-gender-btn.selected {
  border-color: var(--dhb-primary) !important;
  background: var(--dhb-bg-alt) !important;
  transform: translateY(-4px) !important;
  box-shadow: 0 12px 24px rgba(0,0,0,0.05) !important;
}

.dca-hammam-app .dhb-gender-icon {
  color: var(--dhb-slate) !important;
  margin-bottom: 8px !important;
}

.dca-hammam-app .dhb-gender-label {
  font-size: 22px !important;
  font-weight: 800 !important;
  text-transform: uppercase !important;
}

.dca-hammam-app .dhb-gender-note {
  font-size: 14px !important;
  color: var(--dhb-text-muted) !important;
}

/* ── Calendar & Layout ── */
.dca-hammam-app .dhb-date-time-layout {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 32px !important;
  margin: 24px 0 !important;
}

@media (max-width: 768px) {
  .dca-hammam-app .dhb-date-time-layout { grid-template-columns: 1fr !important; gap: 24px !important; }
}

.dca-hammam-app .dhb-cal-wrap {
  background: var(--dhb-bg) !important;
  border: 1px solid var(--dhb-border) !important;
  border-radius: var(--dhb-radius) !important;
  padding: 24px !important;
  box-shadow: 0 4px 12px rgba(0,0,0,0.03) !important;
}

.dca-hammam-app .dhb-cal-head {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  margin-bottom: 20px !important;
}

.dca-hammam-app .dhb-cal-nav {
  background: var(--dhb-bg-alt) !important;
  border: 1px solid var(--dhb-border) !important;
  color: var(--dhb-slate) !important;
  width: 40px !important;
  height: 40px !important;
  border-radius: var(--dhb-radius-sm) !important;
  cursor: pointer !important;
  font-size: 18px !important;
  font-weight: bold !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  transition: var(--dhb-transition) !important;
}

.dca-hammam-app .dhb-cal-nav:hover {
  background: var(--dhb-slate) !important;
  color: #FFF !important;
  border-color: var(--dhb-slate) !important;
}

.dca-hammam-app .dhb-cal-month {
  font-size: 18px !important;
  font-weight: 700 !important;
  color: var(--dhb-slate) !important;
}

.dca-hammam-app .dhb-cal-days {
  display: grid !important;
  grid-template-columns: repeat(7, 1fr) !important;
  gap: 4px !important;
  margin-bottom: 8px !important;
}

.dca-hammam-app .dhb-cal-days span {
  text-align: center !important;
  font-size: 12px !important;
  color: var(--dhb-text-muted) !important;
  padding: 8px 0 !important;
  font-weight: 700 !important;
}

.dca-hammam-app .dhb-cal-grid {
  display: grid !important;
  grid-template-columns: repeat(7, 1fr) !important;
  gap: 6px !important;
}

.dca-hammam-app .dhb-cal-day {
  aspect-ratio: 1 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  border-radius: var(--dhb-radius-sm) !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  cursor: pointer !important;
  transition: var(--dhb-transition) !important;
  background: var(--dhb-bg-alt) !important;
  color: var(--dhb-text) !important;
  border: 2px solid transparent !important;
}

.dca-hammam-app .dhb-cal-day:hover:not(.dhb-day-disabled):not(.dhb-day-empty) {
  border-color: var(--dhb-slate) !important;
}

.dca-hammam-app .dhb-cal-day.dhb-day-today {
  border-color: var(--dhb-primary) !important;
  font-weight: 700 !important;
}

.dca-hammam-app .dhb-cal-day.dhb-day-selected {
  background: var(--dhb-slate) !important;
  color: #FFFFFF !important;
  border-color: var(--dhb-slate) !important;
  font-weight: 700 !important;
}

.dca-hammam-app .dhb-cal-day.dhb-day-disabled {
  background: transparent !important;
  color: #CBD5E0 !important;
  cursor: not-allowed !important;
}

.dca-hammam-app .dhb-cal-day.dhb-day-empty {
  background: transparent !important;
  pointer-events: none !important;
}

/* ── Time Selection Panel ── */
.dca-hammam-app .dhb-time-selection-panel {
  display: flex !important;
  flex-direction: column !important;
  gap: 24px !important;
}

.dca-hammam-app .dhb-slots-title {
  font-size: 18px !important;
  font-weight: 700 !important;
  color: var(--dhb-slate) !important;
  margin: 0 0 16px !important;
}

.dca-hammam-app .dhb-slots {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 12px !important;
}

.dca-hammam-app .dhb-slot {
  background: var(--dhb-bg) !important;
  border: 2px solid var(--dhb-border) !important;
  border-radius: var(--dhb-radius-sm) !important;
  padding: 12px 20px !important;
  cursor: pointer !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  color: var(--dhb-slate) !important;
  transition: var(--dhb-transition) !important;
  flex: 1 1 calc(50% - 12px) !important;
  text-align: center !important;
  min-height: 48px !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
}

.dca-hammam-app .dhb-slot:hover:not(.dhb-slot-full) {
  border-color: var(--dhb-primary) !important;
  background: var(--dhb-bg-alt) !important;
}

.dca-hammam-app .dhb-slot.selected {
  background: var(--dhb-primary) !important;
  color: var(--dhb-slate-dark) !important;
  border-color: var(--dhb-primary) !important;
}

.dca-hammam-app .dhb-slot.dhb-slot-full {
  opacity: 0.5 !important;
  cursor: not-allowed !important;
  background: var(--dhb-bg-alt) !important;
  color: var(--dhb-text-muted) !important;
}

.dca-hammam-app .dhb-slot-remaining {
  font-size: 11px !important;
  color: var(--dhb-burgundy) !important;
  display: block !important;
  margin-top: 4px !important;
}

/* ── Ottoman Preferred Time ── */
.dca-hammam-app .dhb-ottoman-time {
  display: none !important; /* toggled via JS */
}

.dca-hammam-app .dhb-ottoman-note {
  font-size: 14px !important;
  color: var(--dhb-text-muted) !important;
  margin: 0 0 20px !important;
  line-height: 1.5 !important;
}

.dca-hammam-app .dhb-pref-grid {
  display: flex !important;
  flex-direction: column !important;
  gap: 12px !important;
}

.dca-hammam-app .dhb-pref-btn {
  background: var(--dhb-bg) !important;
  border: 2px solid var(--dhb-border) !important;
  border-radius: var(--dhb-radius-sm) !important;
  padding: 16px 20px !important;
  cursor: pointer !important;
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  transition: var(--dhb-transition) !important;
  color: var(--dhb-slate) !important;
}

.dca-hammam-app .dhb-pref-btn:hover, 
.dca-hammam-app .dhb-pref-btn.selected {
  border-color: var(--dhb-primary) !important;
  background: var(--dhb-bg-alt) !important;
}

.dca-hammam-app .dhb-pref-btn.selected {
  background: var(--dhb-primary) !important;
  color: var(--dhb-slate-dark) !important;
}

.dca-hammam-app .dhb-pref-label {
  font-weight: 700 !important;
  font-size: 15px !important;
}

.dca-hammam-app .dhb-pref-range {
  font-size: 13px !important;
  opacity: 0.8 !important;
  font-weight: 500 !important;
}

/* ── Service Pill ── */
.dca-hammam-app .dhb-service-pill {
  display: inline-flex !important;
  align-items: center !important;
  background: var(--dhb-slate) !important;
  color: #FFFFFF !important;
  padding: 8px 16px !important;
  border-radius: 99px !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  margin-bottom: 24px !important;
}

/* ── Hours Details ── */
.dca-hammam-app .dhb-hours-card {
  background: var(--dhb-bg-alt) !important;
  border-radius: var(--dhb-radius-sm) !important;
  padding: 20px !important;
  border: 1px solid var(--dhb-border) !important;
}

.dca-hammam-app .dhb-hours-card h4 {
  margin: 0 0 16px !important;
  font-size: 15px !important;
  color: var(--dhb-slate) !important;
}

.dca-hammam-app .dhb-hours-grid {
  display: flex !important;
  flex-direction: column !important;
  gap: 8px !important;
}

.dca-hammam-app .dhb-hour-row {
  display: flex !important;
  justify-content: space-between !important;
  font-size: 13px !important;
  padding-bottom: 8px !important;
  border-bottom: 1px dashed var(--dhb-border) !important;
}

.dca-hammam-app .dhb-hour-row:last-child {
  border-bottom: none !important;
  padding-bottom: 0 !important;
}

.dca-hammam-app .dhb-hour-row span:first-child {
  color: var(--dhb-text-muted) !important;
}

.dca-hammam-app .dhb-hour-row span:last-child {
  color: var(--dhb-text) !important;
  font-weight: 600 !important;
}

.dca-hammam-app .dhb-hr-closed span {
  color: #A0AEC0 !important;
}

/* ── Forms ── */
.dca-hammam-app .dhb-form-grid {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 20px !important;
  margin-bottom: 24px !important;
}

@media (max-width: 640px) {
  .dca-hammam-app .dhb-form-grid { grid-template-columns: 1fr !important; }
}

.dca-hammam-app .dhb-field {
  display: flex !important;
  flex-direction: column !important;
  gap: 8px !important;
}

.dca-hammam-app .dhb-field-full {
  grid-column: 1 / -1 !important;
}

.dca-hammam-app .dhb-field label {
  font-size: 14px !important;
  color: var(--dhb-slate) !important;
  font-weight: 600 !important;
}

.dca-hammam-app .dhb-field abbr {
  color: #E53E3E !important;
  text-decoration: none !important;
}

.dca-hammam-app .dhb-input, 
.dca-hammam-app .dhb-select, 
.dca-hammam-app .dhb-textarea {
  background: #FFFFFF !important;
  border: 1px solid var(--dhb-border) !important;
  border-radius: var(--dhb-radius-sm) !important;
  color: var(--dhb-text) !important;
  font-family: 'Inter', sans-serif !important;
  font-size: 15px !important;
  padding: 14px 16px !important;
  outline: none !important;
  transition: all var(--dhb-transition) !important;
  width: 100% !important;
  box-shadow: 0 1px 2px rgba(0,0,0,0.02) !important;
  min-height: 48px !important;
}

.dca-hammam-app .dhb-input::placeholder, 
.dca-hammam-app .dhb-textarea::placeholder {
  color: #A0AEC0 !important;
}

.dca-hammam-app .dhb-input:focus, 
.dca-hammam-app .dhb-select:focus, 
.dca-hammam-app .dhb-textarea:focus {
  border-color: var(--dhb-slate) !important;
  box-shadow: 0 0 0 3px rgba(30, 63, 82, 0.1) !important;
}

.dca-hammam-app .dhb-textarea {
  resize: vertical !important;
  min-height: 100px !important;
}

/* ── Mini Summary ── */
.dca-hammam-app .dhb-mini-summary {
  background: var(--dhb-bg-alt) !important;
  border: 1px solid var(--dhb-border) !important;
  border-radius: var(--dhb-radius-sm) !important;
  padding: 16px 20px !important;
  font-size: 14px !important;
  color: var(--dhb-slate) !important;
  margin-bottom: 24px !important;
  display: flex !important;
  gap: 16px !important;
  flex-wrap: wrap !important;
  font-weight: 500 !important;
}

.dca-hammam-app .dhb-mini-summary strong {
  color: var(--dhb-slate) !important;
  font-weight: 800 !important;
}

/* ── What to Bring ── */
.dca-hammam-app .dhb-wtb-box {
  background: var(--dhb-bg-alt) !important;
  border: 1px solid var(--dhb-border) !important;
  border-radius: var(--dhb-radius-sm) !important;
  padding: 24px !important;
  margin: 32px 0 20px !important;
}

.dca-hammam-app .dhb-wtb-title {
  margin: 0 0 20px !important;
  font-size: 18px !important;
  color: var(--dhb-slate) !important;
  font-weight: 700 !important;
}

.dca-hammam-app .dhb-wtb-grid {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 24px !important;
}

.dca-hammam-app .dhb-wtb-full {
  grid-column: 1 / -1 !important;
}

.dca-hammam-app .dhb-wtb-col h5 {
  font-size: 13px !important;
  text-transform: uppercase !important;
  letter-spacing: 0.05em !important;
  color: var(--dhb-text-muted) !important;
  margin: 0 0 12px !important;
}

.dca-hammam-app .dhb-wtb-col ul {
  margin: 0 !important;
  padding: 0 0 0 20px !important;
}

.dca-hammam-app .dhb-wtb-col li {
  font-size: 14px !important;
  color: var(--dhb-text) !important;
  margin-bottom: 8px !important;
}

/* ── Payment Step ── */
.dca-hammam-app .dhb-order-summary {
  background: var(--dhb-bg-alt) !important;
  border: 1px solid var(--dhb-border) !important;
  border-radius: var(--dhb-radius-sm) !important;
  padding: 24px !important;
  margin-bottom: 32px !important;
}

.dca-hammam-app .dhb-order-row {
  display: flex !important;
  justify-content: space-between !important;
  font-size: 15px !important;
  margin-bottom: 12px !important;
  color: var(--dhb-text) !important;
}

.dca-hammam-app .dhb-order-row span:first-child {
  color: var(--dhb-text-muted) !important;
}

.dca-hammam-app .dhb-order-row.dhb-order-total {
  border-top: 2px solid var(--dhb-border) !important;
  margin-top: 16px !important;
  padding-top: 16px !important;
  font-size: 20px !important;
  font-weight: 800 !important;
  color: var(--dhb-slate) !important;
}

.dca-hammam-app .dhb-order-row.dhb-order-total span:first-child {
  color: var(--dhb-slate) !important;
}

.dca-hammam-app .dhb-secure-badge {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  font-size: 13px !important;
  color: #38A169 !important;
  font-weight: 600 !important;
  margin-bottom: 20px !important;
}

.dca-hammam-app .dhb-card-input-wrap {
  position: relative !important;
}

.dca-hammam-app .dhb-card-brand {
  position: absolute !important;
  right: 16px !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  font-size: 24px !important;
  pointer-events: none !important;
}

.dca-hammam-app .dhb-pay-note {
  font-size: 13px !important;
  color: var(--dhb-text-muted) !important;
  margin-top: 20px !important;
  text-align: center !important;
}

/* ── Buttons ── */
.dca-hammam-app .dhb-nav {
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  margin-top: 32px !important;
  padding-top: 24px !important;
  border-top: 1px solid var(--dhb-border) !important;
  gap: 16px !important;
}

.dca-hammam-app .dhb-btn {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  border: none !important;
  border-radius: var(--dhb-radius-sm) !important;
  padding: 16px 32px !important;
  font-size: 15px !important;
  font-weight: 700 !important;
  cursor: pointer !important;
  transition: var(--dhb-transition) !important;
  font-family: 'Inter', sans-serif !important;
  text-transform: uppercase !important;
  letter-spacing: 0.05em !important;
  min-height: 48px !important;
}

.dca-hammam-app .dhb-btn-ghost {
  background: transparent !important;
  border: 2px solid var(--dhb-border) !important;
  color: var(--dhb-text-muted) !important;
}

.dca-hammam-app .dhb-btn-ghost:hover {
  border-color: var(--dhb-slate) !important;
  color: var(--dhb-slate) !important;
}

.dca-hammam-app .dhb-btn-primary {
  background: var(--dhb-primary) !important;
  color: var(--dhb-slate-dark) !important;
}

.dca-hammam-app .dhb-btn-primary:hover {
  background: var(--dhb-primary-hover) !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 8px 20px rgba(177, 252, 84, 0.4) !important;
}

.dca-hammam-app .dhb-btn-pay {
  background: var(--dhb-slate) !important;
  color: #FFFFFF !important;
  flex: 1 !important;
}

.dca-hammam-app .dhb-btn-pay:hover {
  background: var(--dhb-slate-dark) !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 8px 20px rgba(30, 63, 82, 0.3) !important;
}

.dca-hammam-app .dhb-btn-outline {
  background: transparent !important;
  border: 2px solid var(--dhb-slate) !important;
  color: var(--dhb-slate) !important;
}

.dca-hammam-app .dhb-btn-outline:hover {
  background: var(--dhb-slate) !important;
  color: #FFFFFF !important;
}

.dca-hammam-app .dhb-btn:disabled {
  opacity: 0.6 !important;
  cursor: not-allowed !important;
  transform: none !important;
  box-shadow: none !important;
}

.dca-hammam-app .dhb-spinner {
  width: 18px !important;
  height: 18px !important;
  border: 3px solid rgba(255,255,255,0.3) !important;
  border-top-color: currentColor !important;
  border-radius: 50% !important;
  animation: dhbSpin 0.8s linear infinite !important;
  display: none !important;
}

@keyframes dhbSpin {
  to { transform: rotate(360deg); }
}

.dca-hammam-app .dhb-loading .dhb-spinner {
  display: block !important;
}

.dca-hammam-app .dhb-loading .dhb-btn-label,
.dca-hammam-app .dhb-loading .dhb-lock-icon {
  display: none !important;
}

/* ── Error Messages ── */
.dca-hammam-app .dhb-error {
  background: #FFF5F5 !important;
  border: 1px solid #FEB2B2 !important;
  border-radius: var(--dhb-radius-sm) !important;
  padding: 16px !important;
  font-size: 14px !important;
  color: #C53030 !important;
  margin-top: 20px !important;
  display: none !important;
  font-weight: 600 !important;
}

.dca-hammam-app .dhb-error.visible {
  display: block !important;
  animation: dhbFadeIn 0.3s ease forwards !important;
}

/* ── Confirmation ── */
.dca-hammam-app .dhb-confirm-icon {
  width: 80px !important;
  height: 80px !important;
  background: var(--dhb-primary) !important;
  border-radius: 50% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 40px !important;
  color: var(--dhb-slate-dark) !important;
  margin: 0 auto 24px !important;
  box-shadow: 0 12px 30px rgba(177, 252, 84, 0.4) !important;
}

.dca-hammam-app .dhb-confirm-title {
  font-family: 'Bebas Neue', 'Inter', sans-serif !important;
  font-size: clamp(28px, 4vw, 36px) !important;
  color: var(--dhb-slate) !important;
  margin: 0 0 12px !important;
  text-align: center !important;
  text-transform: uppercase !important;
}

.dca-hammam-app .dhb-confirm-sub {
  font-size: 16px !important;
  color: var(--dhb-text-muted) !important;
  text-align: center !important;
  margin: 0 0 32px !important;
}

.dca-hammam-app .dhb-confirm-card {
  background: var(--dhb-bg-alt) !important;
  border: 1px solid var(--dhb-border) !important;
  border-radius: var(--dhb-radius) !important;
  padding: 32px !important;
  margin-bottom: 32px !important;
}

.dca-hammam-app .dhb-confirm-row {
  display: flex !important;
  justify-content: space-between !important;
  padding: 12px 0 !important;
  border-bottom: 1px dashed var(--dhb-border) !important;
  font-size: 15px !important;
}

.dca-hammam-app .dhb-confirm-row:last-child {
  border-bottom: none !important;
}

.dca-hammam-app .dhb-confirm-row span:first-child {
  color: var(--dhb-text-muted) !important;
}

.dca-hammam-app .dhb-confirm-row span:last-child {
  color: var(--dhb-slate) !important;
  font-weight: 700 !important;
}

.dca-hammam-app .dhb-confirm-ref {
  display: block !important;
  background: var(--dhb-bg) !important;
  border: 2px dashed var(--dhb-border) !important;
  color: var(--dhb-slate) !important;
  font-family: monospace !important;
  font-size: 20px !important;
  font-weight: 700 !important;
  padding: 16px !important;
  border-radius: var(--dhb-radius-sm) !important;
  letter-spacing: 0.1em !important;
  margin: 0 auto 24px !important;
  text-align: center !important;
}

.dca-hammam-app .dhb-confirm-contact {
  background: var(--dhb-slate) !important;
  color: #FFFFFF !important;
  border-radius: var(--dhb-radius-sm) !important;
  padding: 24px !important;
  font-size: 15px !important;
  line-height: 1.8 !important;
  text-align: center !important;
}

.dca-hammam-app .dhb-confirm-contact p {
  margin: 0 !important;
}

.dca-hammam-app .dhb-arrive-note {
  font-size: 13px !important;
  margin-top: 16px !important;
  color: var(--dhb-primary) !important;
  font-weight: 600 !important;
}

/* ── Responsive ── */
@media (max-width: 600px) {
  .dca-hammam-app .dhb-header { padding: 24px 20px !important; }
  .dca-hammam-app .dhb-logos { flex-direction: column !important; gap: 16px !important; }
  .dca-hammam-app .dhb-progress-wrap { padding: 20px 20px 0 !important; }
  .dca-hammam-app .dhb-step { padding: 24px 20px 0 !important; }
  .dca-hammam-app .dhb-gender-grid { grid-template-columns: 1fr !important; }
  .dca-hammam-app .dhb-nav { flex-direction: column-reverse !important; gap: 12px !important; }
  .dca-hammam-app .dhb-btn { width: 100% !important; justify-content: center !important; }
  .dca-hammam-app .dhb-wtb-grid { grid-template-columns: 1fr !important; }
  .dca-hammam-app .dhb-step-labels { display: none !important; }
  .dca-hammam-app .dhb-cal-day { min-height: 44px !important; min-width: 44px !important; }
  .dca-hammam-app .dhb-slot { flex: 1 1 100% !important; }
}
