/* ============================================================
   RESERVO — TEMA NUTRICIONISTAS
   Paleta: Verde Claro (#6DBF7E, #93C47D) + Morado (#8B5CF6, #A78BFA)
   ============================================================ */

/* ── Variables globales ── */
:root {
  --green-50:  #f0faf2;
  --green-100: #d6f0db;
  --green-300: #93C47D;
  --green-400: #6DBF7E;
  --green-500: #4da863;
  --green-600: #3a8f4e;

  --purple-50:  #f5f2ff;
  --purple-100: #ede9fe;
  --purple-300: #c4b5fd;
  --purple-400: #a78bfa;
  --purple-500: #8b5cf6;
  --purple-600: #7c3aed;

  --gray-50:  #fafafa;
  --gray-100: #f4f4f5;
  --gray-200: #e4e4e7;
  --gray-400: #a1a1aa;
  --gray-600: #52525b;
  --gray-800: #27272a;

  --white: #ffffff;

  --gradient-main: linear-gradient(135deg, var(--green-400) 0%, var(--purple-500) 100%);
  --gradient-light: linear-gradient(135deg, var(--green-50) 0%, var(--purple-50) 100%);

  --shadow-sm: 0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.05);
  --shadow-md: 0 4px 16px rgba(139,92,246,.12), 0 2px 6px rgba(0,0,0,.06);
  --shadow-lg: 0 10px 40px rgba(139,92,246,.16), 0 4px 12px rgba(0,0,0,.08);

  --radius-sm: 8px;
  --radius-md: 14px;
  --radius-lg: 20px;
  --radius-xl: 28px;

  --transition: 0.22s cubic-bezier(.4,0,.2,1);
}

/* ── Reset base ── */
*,
*::before,
*::after {
  box-sizing: border-box;
}

body.bodycel {
  background: var(--gradient-light);
  min-height: 100vh;
  font-family: 'Inter', 'Segoe UI', system-ui, sans-serif;
  color: var(--gray-800);
  -webkit-font-smoothing: antialiased;
  margin-left: 0 !important;  /* sobreescribe el -5px inline del body */
}

/* ── Contenedor principal ── */
#app,
.content {
  background: transparent;
}

/* Aumenta el tamaño base del wizard — sobreescribe el font-size:16px inline */
#app > .font-sans {
  font-size: 18px !important;
  max-width: 100% !important;
}

/* El wizard ocupa todo el ancho disponible */
.vue-form-wizard {
  width: 100%;
}

/* ═══════════════════════════════════════════════
   WIZARD — Estructura general
═══════════════════════════════════════════════ */
.vue-form-wizard {
  background: var(--white);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-lg);
  border: 1px solid var(--green-100);
  /* sin overflow:hidden para no recortar el dropdown del stf-select */
}

.vue-form-wizard.sm {
  padding-bottom: 0;
}

/* ── Header del wizard ── */
.wizard-header {
  background: var(--gradient-main);
  padding: 28px 24px 22px;
  text-align: center;
}

.wizard-title {
  color: var(--white);
  font-size: 1.35rem;
  font-weight: 700;
  letter-spacing: -0.02em;
  margin: 0 0 4px;
  text-shadow: 0 1px 3px rgba(0,0,0,.15);
}

.wizard-header .category {
  color: rgba(255,255,255,.82);
  font-size: .875rem;
  margin: 0;
}

/* ── Barra de progreso ── */
.wizard-progress-with-circle {
  background: var(--gray-100);
  border-radius: 999px;
  height: 5px;
  margin: 18px 20px 0;
  overflow: hidden;
}

.wizard-progress-bar {
  height: 100%;
  border-radius: 999px;
  background: var(--gradient-main) !important;
  transition: width .5s ease !important;
  color: transparent !important;
}

/* ── Nav pills (pasos) ── */
.wizard-nav.wizard-nav-pills {
  display: flex;
  justify-content: space-around;
  align-items: flex-start;
  list-style: none;
  padding: 20px 16px 14px;
  margin: 0;
  background: var(--white);
  gap: 8px;
}

.wizard-nav.wizard-nav-pills li {
  flex: 1;
  text-align: center;
}

.wizard-nav.wizard-nav-pills li a {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  text-decoration: none;
  cursor: pointer;
}

.wizard-nav.wizard-nav-pills li a.disabled {
  cursor: not-allowed;
  opacity: .55;
}

/* ── Círculo del paso ── */
.wizard-icon-circle {
  width: 38px;
  height: 38px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 2.5px solid var(--gray-200);
  background: var(--white);
  font-size: .875rem;
  font-weight: 700;
  color: var(--gray-400);
  transition: all var(--transition);
}

.wizard-icon-circle.checked,
.wizard-icon-circle[style*="border-color"] {
  border-color: var(--green-400) !important;
  box-shadow: 0 0 0 4px var(--green-100);
}

.wizard-icon-container {
  width: 100%;
  height: 100%;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--gradient-main) !important;
}

.wizard-icon-container .wizard-icon {
  color: var(--white);
  font-style: normal;
  font-weight: 700;
  font-size: .875rem;
}

.wizard-icon-circle:not(.checked) .wizard-icon {
  color: var(--gray-400);
}

/* ── Título del paso ── */
.stepTitle {
  font-size: .72rem;
  font-weight: 600;
  color: var(--gray-400);
  line-height: 1.3;
  transition: color var(--transition);
  max-width: 80px;
}

.stepTitle.active {
  color: var(--green-500) !important;
}

/* ── Separador entre pasos ── */
.wizard-nav.wizard-nav-pills li:not(:last-child)::after {
  display: none; /* manejado por la barra superior */
}

/* ═══════════════════════════════════════════════
   WIZARD — Tab container (cuerpo de cada paso)
═══════════════════════════════════════════════ */
.wizard-tab-content {
  background: var(--gray-50);
}

.wizard-tab-container {
  padding: 24px 20px !important;
  background: var(--white) !important;
  border: 1px solid var(--green-100) !important;
  border-radius: var(--radius-lg) !important;
  margin: 16px auto !important;
  box-shadow: var(--shadow-sm);
}

/* ═══════════════════════════════════════════════
   TIPOGRAFÍA & ETIQUETAS
═══════════════════════════════════════════════ */
.text-gray-600 {
  color: var(--gray-600);
}

.text-lg.font-medium {
  font-size: 1rem;
  font-weight: 700;
  color: var(--gray-800);
  display: block;
  margin-bottom: 12px;
  position: relative;
  padding-left: 14px;
}

.text-lg.font-medium::before {
  content: '';
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 4px;
  height: 16px;
  background: var(--gradient-main);
  border-radius: 2px;
}

/* ═══════════════════════════════════════════════
   FORMULARIO — Inputs
═══════════════════════════════════════════════ */
.form-group {
  margin-bottom: 16px;
}

.form-group label {
  display: block;
  font-size: .85rem;
  font-weight: 600;
  color: var(--gray-600);
  margin-bottom: 6px;
}

.form-control {
  width: 100%;
  padding: 10px 14px;
  border: 2px solid var(--gray-200);
  border-radius: var(--radius-sm);
  font-size: .9rem;
  color: var(--gray-800);
  background: var(--white);
  outline: none;
  transition: border-color var(--transition), box-shadow var(--transition);
  font-family: inherit;
}

.form-control:focus {
  border-color: var(--green-400);
  box-shadow: 0 0 0 3px rgba(109,191,126,.18);
}

.form-control::placeholder {
  color: var(--gray-400);
}

.form-group.warning .form-control {
  border-color: #f59e0b;
}

/* ── Alert ── */
.alert {
  display: inline-block;
  padding: 6px 12px;
  border-radius: var(--radius-sm);
  font-size: .8rem;
  font-weight: 500;
  margin-top: 6px;
}

.alert-error {
  background: #fef2f2;
  color: #dc2626;
  border: 1px solid #fecaca;
}

/* ═══════════════════════════════════════════════
   RADIO BUTTONS PERSONALIZADOS
═══════════════════════════════════════════════ */
.grid.grid-cols-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-top: 8px;
}

/* Etiqueta-card del radio */
label.custom-border {
  border: 2px solid var(--gray-200) !important;
  border-radius: var(--radius-sm) !important;
  padding: 12px 14px !important;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: .875rem;
  font-weight: 500;
  color: var(--gray-600);
  background: var(--white);
  transition: all var(--transition);
}

label.custom-border:hover {
  border-color: var(--green-400) !important;
  background: var(--green-50);
  color: var(--green-600);
}

label.custom-selected-border,
label.custom-border.custom-selected-border {
  border-color: var(--purple-500) !important;
  background: var(--purple-50) !important;
  color: var(--purple-600) !important;
  box-shadow: 0 0 0 3px rgba(139,92,246,.12);
}

/* Radio nativo estilizado */
label.custom-border input[type="radio"] {
  appearance: none;
  -webkit-appearance: none;
  width: 18px;
  height: 18px;
  border: 2px solid var(--gray-300);
  border-radius: 50%;
  flex-shrink: 0;
  position: relative;
  transition: all var(--transition);
}

label.custom-border input[type="radio"]:checked {
  border-color: var(--purple-500);
  background: var(--purple-500);
  box-shadow: inset 0 0 0 3px var(--white);
}

/* ── Botón "Otro Rut" ── */
button.otro_rut {
  background: transparent;
  border: 2px solid var(--purple-400);
  color: var(--purple-500);
  border-radius: var(--radius-sm);
  padding: 8px 18px;
  font-size: .85rem;
  font-weight: 600;
  cursor: pointer;
  font-family: inherit;
  transition: all var(--transition);
  margin-top: 8px;
}

button.otro_rut:hover {
  background: var(--purple-50);
  border-color: var(--purple-600);
  color: var(--purple-600);
}

/* ═══════════════════════════════════════════════
   STF SELECT (dropdown de profesional / tratamiento)
═══════════════════════════════════════════════ */
.stf-select {
  position: relative;
  font-family: inherit;
  /* width e inline margin los controla el propio componente via style */
}

.stf-select__container {
  border: 2px solid var(--gray-200);
  border-radius: var(--radius-sm);
  background: var(--white);
  cursor: pointer;
  transition: border-color var(--transition), box-shadow var(--transition);
  /* NO overflow:hidden — evita cortar el texto del valor */
}

.stf-select__container:hover {
  border-color: var(--green-400);
  box-shadow: 0 0 0 3px rgba(109,191,126,.12);
}

.stf-select__value {
  padding: 10px 14px;
  font-size: .9rem;
  color: var(--gray-800);
  font-weight: 500;
}

/* El componente anida dos divs antes del texto; el más interno
   contiene el texto + el span.pull-right con la flecha.
   Usamos flex para centrar verticalmente y empujar la flecha a la derecha,
   neutralizando el float de Bootstrap que desalinea el contenido. */
.stf-select__value > div > div {
  display: flex;
  align-items: center;
  justify-content: space-between;
  line-height: 1.4;
}

.stf-select__value .pull-right {
  float: none; /* cancelamos el float heredado de Bootstrap */
  color: var(--purple-400);
  display: flex;
  align-items: center;
  margin-left: 8px;
  flex-shrink: 0;
}

.stf-select__placeholder {
  padding: 10px 14px;
  color: var(--gray-400);
  font-size: .9rem;
}

.stf-select__search-input {
  padding: 4px 14px 8px;
}

.stf-select__search-input input {
  width: 100%;
  border: none;
  outline: none;
  font-family: inherit;
  font-size: .9rem;
  padding: 4px 0;
  color: var(--gray-800);
  background: transparent;
}

.stf-select__search-input input::placeholder {
  color: var(--gray-400);
}

/* ── Panel de opciones ──
   NO se sobreescribe position porque el JS del componente
   calcula top/left esperando su propio valor (absolute/fixed).
   Solo se estilizan las capas internas. */
.stf-select__options-wraped {
  z-index: 9999;
}

.stf-select__options {
  background: var(--white);
  border: 2px solid var(--green-100);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-lg);
  /* sin overflow:hidden — permite que el scroll del mouse llegue al contenedor hijo */
  min-width: 280px;
}

.stf-select__options-container {
  max-height: 320px;
  overflow-y: scroll;
}

.stf-select__options-container::-webkit-scrollbar {
  width: 5px;
}

.stf-select__options-container::-webkit-scrollbar-track {
  background: var(--gray-50);
}

.stf-select__options-container::-webkit-scrollbar-thumb {
  background: var(--green-300);
  border-radius: 99px;
}

.options.delivery_order__options {
  padding: 8px;
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.stf-select-option {
  padding: 10px 14px;
  border-radius: var(--radius-sm);
  font-size: .875rem;
  color: var(--gray-700);
  cursor: pointer;
  transition: background-color var(--transition), color var(--transition);
  font-weight: 500;
}

.stf-select-option:hover,
.stf-select-option:focus {
  background: var(--green-50);
  color: var(--green-600);
  outline: none;
}

.stf-select-option.selected,
.stf-select-option[aria-selected="true"] {
  background: var(--purple-50);
  color: var(--purple-600);
  font-weight: 600;
}

/* ═══════════════════════════════════════════════
   VUE SELECT (selector de mes)
═══════════════════════════════════════════════ */
.v-select.select-style {
  font-family: inherit;
}

.vs__dropdown-toggle {
  border: 2px solid var(--gray-200);
  border-radius: var(--radius-sm);
  padding: 4px 8px;
  background: var(--white);
  cursor: pointer;
  transition: border-color var(--transition), box-shadow var(--transition);
}

.vs__dropdown-toggle:hover {
  border-color: var(--green-400);
}

.v-select.vs--open .vs__dropdown-toggle {
  border-color: var(--purple-400);
  box-shadow: 0 0 0 3px rgba(139,92,246,.12);
  border-bottom-left-radius: 0;
  border-bottom-right-radius: 0;
}

.vs__selected {
  font-size: .875rem;
  font-weight: 600;
  color: var(--gray-800);
  padding: 2px 4px;
}

.vs__search {
  font-family: inherit;
  font-size: .875rem;
  color: var(--gray-800);
  border: none !important;
  outline: none;
}

.vs__actions {
  display: flex;
  align-items: center;
  gap: 6px;
}

.vs__clear {
  background: none;
  border: none;
  cursor: pointer;
  padding: 2px;
  color: var(--gray-400);
  display: flex;
  align-items: center;
  transition: color var(--transition);
}

.vs__clear:hover {
  color: var(--purple-500);
}

.vs__clear svg path {
  fill: currentColor;
}

.vs__open-indicator {
  fill: var(--green-500);
  transition: transform var(--transition);
}

.v-select.vs--open .vs__open-indicator {
  transform: rotate(180deg);
  fill: var(--purple-500);
}

.vs__spinner {
  color: var(--green-400);
  font-size: .75rem;
}

.vs__dropdown-menu {
  border: 2px solid var(--green-100);
  border-top: none;
  border-radius: 0 0 var(--radius-md) var(--radius-md);
  box-shadow: var(--shadow-md);
  background: var(--white);
  padding: 6px;
}

.vs__dropdown-option {
  padding: 9px 12px;
  border-radius: var(--radius-sm);
  font-size: .875rem;
  cursor: pointer;
  color: var(--gray-700);
  font-weight: 500;
  transition: all var(--transition);
}

.vs__dropdown-option--highlight {
  background: var(--green-50);
  color: var(--green-600);
}

.vs__dropdown-option--selected {
  background: var(--purple-50);
  color: var(--purple-600);
  font-weight: 600;
}

/* ═══════════════════════════════════════════════
   CALENDARIO — Días de la semana
═══════════════════════════════════════════════ */
.grid.grid-cols-7 {
  display: grid !important;
  grid-template-columns: repeat(7, 1fr);
  gap: 3px;
  width: 100% !important;
}

/* ── Slot de día ── */
.custom-calendar-day-slot {
  text-align: center;
  padding: 12px 4px;
  border-radius: var(--radius-sm);
  border: 2px solid transparent;
  background: var(--white);
  transition: all var(--transition);
  position: relative;
}

/* Días disponibles con hover */
.custom-calendar-day-slot.custom-hover {
  cursor: pointer;
  border-color: var(--green-100);
}

.custom-calendar-day-slot.custom-hover:hover {
  background: var(--green-50);
  border-color: var(--green-400);
  transform: translateY(-1px);
  box-shadow: var(--shadow-sm);
}

/* Día seleccionado */
.custom-calendar-day-slot.custom-selected,
.custom-calendar-day-slot[class*="selected"] {
  background: var(--purple-50);
  border-color: var(--purple-500);
  box-shadow: 0 0 0 3px rgba(139,92,246,.15);
}

.custom-calendar-day-slot.custom-selected .space-y-2,
.custom-calendar-day-slot[class*="selected"] .space-y-2 {
  color: var(--purple-600);
}

/* Días deshabilitados */
.custom-calendar-day-slot.opacity-25,
.custom-calendar-day-slot.cursor-not-allowed {
  opacity: .35 !important;
  cursor: not-allowed !important;
  background: var(--gray-50);
  border-color: transparent;
}

.custom-calendar-day-slot.opacity-25:hover,
.custom-calendar-day-slot.cursor-not-allowed:hover {
  transform: none;
  box-shadow: none;
}

/* Nombre del día */
.custom-calendar-day-slot .text-sm,
.custom-calendar-day-slot .text-base {
  font-size: .7rem;
  font-weight: 500;
  color: var(--gray-400);
  text-transform: uppercase;
  letter-spacing: .04em;
}

/* Número del día */
.custom-calendar-day-slot .text-lg,
.custom-calendar-day-slot .text-xl {
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--gray-800);
  line-height: 1.2;
}

/* ── Flechas de navegación del carrusel ── */
.flecha-carrusel-calendar-form {
  cursor: pointer;
  color: var(--green-500);
  transition: all var(--transition);
  padding: 4px;
  border-radius: 50%;
  flex-shrink: 0;
}

.flecha-carrusel-calendar-form:hover:not(.slick-disabled) {
  color: var(--purple-500);
  background: var(--purple-50);
  transform: scale(1.1);
}

.flecha-carrusel-calendar-form.slick-disabled {
  opacity: .3 !important;
  cursor: not-allowed !important;
}

/* ── Contenedor slick ── */
.slick-slider {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 8px 4px;
}

.slick-list {
  overflow: hidden;
  flex: 1;
}

.slick-track {
  display: flex;
}

.slick-slide {
  min-width: 0;
}

/* Borde redondeado de extremos de semana */
.rounded-l-lg { border-top-left-radius: var(--radius-sm) !important; border-bottom-left-radius: var(--radius-sm) !important; }
.rounded-r-lg { border-top-right-radius: var(--radius-sm) !important; border-bottom-right-radius: var(--radius-sm) !important; }

/* ── Selector de mes ── */
.mx-auto.w-52 {
  background: var(--white);
  border: 2px solid var(--green-100);
  border-radius: var(--radius-md);
  padding: 4px;
  margin-bottom: 12px !important;
}

/* ═══════════════════════════════════════════════
   BOTONES
═══════════════════════════════════════════════ */
button.primary-custom-color,
.btn.primary-custom-color {
  background: var(--gradient-main) !important;
  color: var(--white) !important;
  border: none !important;
  border-radius: var(--radius-md) !important;
  padding: 13px 28px !important;
  font-size: .95rem !important;
  font-weight: 700 !important;
  cursor: pointer;
  width: 100%;
  font-family: inherit;
  letter-spacing: .01em;
  transition: opacity var(--transition), transform var(--transition), box-shadow var(--transition);
  box-shadow: 0 4px 18px rgba(139,92,246,.30);
  position: relative;
  overflow: hidden;
}

button.primary-custom-color::after {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(255,255,255,0);
  transition: background var(--transition);
}

button.primary-custom-color:hover::after {
  background: rgba(255,255,255,.08);
}

button.primary-custom-color:hover {
  transform: translateY(-1px);
  box-shadow: 0 6px 24px rgba(139,92,246,.38);
}

button.primary-custom-color:active {
  transform: translateY(0);
  box-shadow: 0 2px 10px rgba(139,92,246,.25);
}

/* ═══════════════════════════════════════════════
   WIZARD FOOTER
═══════════════════════════════════════════════ */
.wizard-card-footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 14px 20px 20px;
  background: var(--white);
  border-top: 1px solid var(--gray-100);
}

.wizard-footer-left,
.wizard-footer-right {
  display: flex;
  align-items: center;
}

.wizard-footer-right {
  flex: 1;
}

/* ═══════════════════════════════════════════════
   LOADING OVERLAY
═══════════════════════════════════════════════ */
.vld-overlay {
  z-index: 9999;
}

.vld-background {
  background: rgba(240, 250, 242, 0.6) !important;
  backdrop-filter: blur(4px) !important;
}

.vld-icon svg {
  stroke: var(--purple-500) !important;
}

/* ═══════════════════════════════════════════════
   SWEETALERT2 — Adaptación temática
═══════════════════════════════════════════════ */
.swal2-popup {
  border-radius: var(--radius-xl) !important;
  font-family: inherit !important;
  box-shadow: var(--shadow-lg) !important;
}

.swal2-popup .swal2-title {
  color: var(--gray-800) !important;
  font-size: 1.4rem !important;
}

.swal2-popup .swal2-content {
  color: var(--gray-600) !important;
}

.swal2-popup .swal2-styled.swal2-confirm {
  background: var(--gradient-main) !important;
  border-radius: var(--radius-sm) !important;
  font-weight: 700 !important;
  padding: 10px 28px !important;
  box-shadow: 0 4px 14px rgba(139,92,246,.28) !important;
}

.swal2-popup .swal2-styled.swal2-cancel {
  background-color: var(--gray-200) !important;
  color: var(--gray-600) !important;
  border-radius: var(--radius-sm) !important;
  font-weight: 600 !important;
}

.swal2-popup .swal2-styled.swal2-confirm:focus {
  box-shadow: 0 0 0 3px rgba(139,92,246,.25) !important;
}

/* ═══════════════════════════════════════════════
   VUE MODAL
═══════════════════════════════════════════════ */
.vm--modal {
  border-radius: var(--radius-xl) !important;
  box-shadow: var(--shadow-lg) !important;
  border: 1px solid var(--green-100) !important;
}

.vm--overlay {
  background: rgba(109,191,126,.12) !important;
  backdrop-filter: blur(3px);
}

/* ── Vue dialog (confirmaciones) ── */
.vue-dialog {
  font-family: inherit;
  border-radius: var(--radius-xl) !important;
}

.vue-dialog-content-title {
  font-size: 1rem;
  font-weight: 700;
  color: var(--gray-800);
}

.vue-dialog-content {
  color: var(--gray-600);
}

.vue-dialog-buttons {
  border-top: 1px solid var(--gray-100) !important;
}

.vue-dialog-button {
  font-weight: 600;
  color: var(--purple-500);
  transition: background var(--transition);
}

.vue-dialog-button:hover {
  background: var(--purple-50) !important;
  color: var(--purple-600);
}

.vue-dialog-button:first-of-type {
  color: var(--gray-500);
}

.vue-dialog-button:first-of-type:hover {
  background: var(--gray-100) !important;
  color: var(--gray-700);
}

/* ═══════════════════════════════════════════════
   UTILIDADES (complementan Tailwind inline)
═══════════════════════════════════════════════ */
.space-y-2 > * + * { margin-top: 8px; }
.space-y-3 > * + * { margin-top: 12px; }
.click-pointer       { cursor: pointer; }

/* Scrollbar personalizado global */
* {
  scrollbar-width: thin;
  scrollbar-color: var(--green-300) var(--gray-100);
}

*::-webkit-scrollbar       { width: 6px; height: 6px; }
*::-webkit-scrollbar-track { background: var(--gray-100); border-radius: 99px; }
*::-webkit-scrollbar-thumb { background: var(--green-300); border-radius: 99px; }
*::-webkit-scrollbar-thumb:hover { background: var(--purple-400); }

/* ═══════════════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════════════ */
@media (max-width: 480px) {
  .wizard-nav.wizard-nav-pills {
    padding: 14px 8px 10px;
  }

  .stepTitle {
    font-size: .62rem;
  }

  .wizard-icon-circle {
    width: 32px;
    height: 32px;
    font-size: .75rem;
  }

  .wizard-tab-container {
    margin: 10px !important;
    padding: 14px 12px !important;
  }

  .custom-calendar-day-slot .text-lg,
  .custom-calendar-day-slot .text-xl {
    font-size: .9rem;
  }
}
