/* ═══════════════════════════════════════════════════════════════
   MOONFORM — Swiss German Stylesheet (Heimfinder theme)
   Scoped under .moonform to avoid conflicts with host page styles.
   ═══════════════════════════════════════════════════════════════ */

.moonform *, .moonform *::before, .moonform *::after { box-sizing: border-box; margin: 0; padding: 0; line-height: 1; }

.moonform button, .moonform input, .moonform .autocomplete-item { touch-action: manipulation; }

/* ═══ THEME — Heimfinder palette ═══ */
.moonform {
  --purple-deep: #2E2868;
  --purple-mid: #4A4290;
  --purple-soft: #9294C9;
  --purple-pale: #EEEDF6;
  --pink: #E72168;
  --pink-light: #F8CAE0;
  --pink-pale: #FDF0F6;
  --blue: #4AB8EA;
  --blue-light: #EAF6FD;
  --white: #FFFFFF;
  --bg: #F7F6FB;
  --text: #3E3C49;
  --text-muted: #7B7886;
  --border: #E2E0EC;
  --border-focus: #9294C9;
  --error: #C0392B;
  --gold: #C4973A;
  --gold-light: #FDF6E8;
  --radius: 16px;
  --radius-sm: 10px;
  --shadow: 0 4px 24px rgba(46,40,104,0.08);
  --shadow-lg: 0 2px 4px rgba(46,40,104,0.04), 0 12px 56px rgba(46,40,104,0.12);
  --transition: 0.22s cubic-bezier(0.4,0,0.2,1);
  font-family: 'Nunito', 'DM Sans', sans-serif;
}
/* ═══ COMPONENT STYLES BELOW — rarely need editing ═══ */

/* ── Container ── */
.moonform .form-wrapper {
  width: 100%;
  position: relative;
  padding: 0;
}

.moonform .form-card {
  background: var(--white);
  border-radius: 20px;
  box-shadow: var(--shadow-lg);
  overflow: hidden;
}

/* ── Header ── */
.moonform .form-header {
  background: transparent;
  padding: 10px 28px 14px;
  border-bottom: 1px solid var(--border);
}

.moonform .header-label { display: none; }

.moonform .header-title {
  font-family: 'Quicksand', sans-serif;
  font-size: 19px;
  font-weight: 700;
  color: var(--purple-deep);
  line-height: 1.35;
  text-align: center;
}

/* ── Progress bar ── */
.moonform .progress-bar-wrap {
  background: var(--border);
  border-radius: 99px;
  height: 4px;
  margin-top: 12px;
}

.moonform .progress-bar-fill {
  height: 100%;
  border-radius: 99px;
  background: var(--purple-deep);
  transition: width 0.5s cubic-bezier(0.4,0,0.2,1);
  width: 0%;
}

.moonform .progress-label { display: none; }

/* ── Body ── */
.moonform .form-body { padding: 20px 28px 20px; }

/* ── Mobile (<=599px) ── */
@media (max-width: 599px) {
  .moonform .form-wrapper { padding: 0; }
  .moonform .form-card { border-radius: 0; box-shadow: none; }
  .moonform .form-header { padding: 8px 20px 10px; }
  .moonform .header-title { font-size: 16px; }
  .moonform .progress-bar-wrap { margin-top: 8px; }
  .moonform .form-body { padding: 12px 20px 16px; }
  .moonform .step-hint { font-size: 12px; margin-bottom: 10px; line-height: 1.35; }
  .moonform .choices { gap: 7px; }
  .moonform .choice-card { padding: 10px 12px; }
  .moonform .choice-card:hover { transform: none; }
  .moonform .choice-icon { width: 26px; height: 26px; }
  .moonform .choice-label { font-size: 13px; }
  .moonform .choice-desc { font-size: 11px; }
  .moonform .input-group { margin-bottom: 14px; }
  .moonform .input-label { line-height: 1.2; margin-bottom: 3px; margin-top: 16px; }
  .moonform .input-field { padding: 10px 12px; font-size: 16px; }
  .moonform .autocomplete-item { font-size: 16px; }
  .moonform .civil-btn { padding: 5px 6px; white-space: nowrap; font-size: 12px; }
  .moonform .civil-row { margin-bottom: 8px; }
  /* Prevent segment labels from wrapping and inflating row height */
  .moonform .segment-label { font-size: 11px; white-space: nowrap; }
  /* Prevent choice labels from line-breaking mid-word on narrow screens */
  .moonform .choice-label { overflow-wrap: break-word; hyphens: auto; }
  /* Prevent nav buttons from wrapping */
  .moonform .btn-next, .moonform .btn-submit, .moonform .btn-back { white-space: nowrap; }
  .moonform .budget-display-row { margin-bottom: 6px; }
  .moonform .budget-value-display { padding: 5px 16px; }
  .moonform .budget-amount-input { font-size: 19px; }
  .moonform .budget-slider-section { padding: 2px 0 4px; }
  .moonform .segment-btn { padding: 8px 6px; }
  .moonform .confidentiality-note { margin-bottom: 10px; font-size: 11px; padding: 8px 10px; }
  .moonform .form-nav { margin-top: 12px; padding: 10px 0 8px; }
  /* Thank-you mobile */
  .moonform #step-thankyou { padding: 10px 0 4px; }
  .moonform .ty-icon { width: 42px; height: 42px; margin-bottom: 10px; }
  .moonform .ty-title { font-size: 16px; margin-bottom: 6px; }
  .moonform .ty-text { font-size: 12px; line-height: 1.4; margin-bottom: 10px; }
  .moonform .ty-badge {
    display: flex; flex-direction: row; align-items: center; flex-wrap: wrap;
    justify-content: center; text-align: center; border-radius: 10px; width: 100%;
    padding: 8px 12px; gap: 3px;
  }
  .moonform .ty-badge strong { margin-left: 0; font-size: 13px; }
}

/* ── Steps ── */
.moonform .step { display: none; animation: moonformFadeSlide 0.35s ease forwards; }
.moonform .step.active { display: block; }

@keyframes moonformFadeSlide {
  from { opacity: 0; transform: translateX(18px); }
  to   { opacity: 1; transform: translateX(0); }
}

.moonform .step-question { display: none; } /* shown in header — no duplication */

.moonform .step-hint { font-size: 14px; color: var(--text-muted); margin-bottom: 14px; line-height: 1.5; }
.moonform .step-hint strong { color: var(--text); font-weight: 600; }

/* ── Choice Cards ── */
.moonform .choices { display: flex; flex-direction: column; gap: 8px; }

.moonform .choice-card {
  display: flex; align-items: center; gap: 14px; padding: 11px 14px;
  border: 1.5px solid var(--border); border-radius: var(--radius);
  cursor: pointer; transition: all var(--transition);
  background: var(--white); text-align: left; width: 100%; font-family: 'Nunito', sans-serif;
}

.moonform .choice-card:hover { border-color: var(--purple-soft); background: var(--purple-pale); transform: translateX(3px); }
.moonform .choice-card.selected { border-color: var(--purple-mid); background: var(--purple-pale); box-shadow: 0 0 0 3px rgba(46,40,104,0.10); }

.moonform .choice-icon {
  flex-shrink: 0; width: 32px; height: 32px;
  display: flex; align-items: center; justify-content: center;
  color: var(--text-muted); transition: color var(--transition);
}

.moonform .choice-card:hover .choice-icon,
.moonform .choice-card.selected .choice-icon { color: var(--purple-deep); }

.moonform .status-dot {
  display: inline-block; width: 10px; height: 10px;
  border-radius: 50%; flex-shrink: 0; transition: transform var(--transition);
}

.moonform .choice-card:hover .status-dot,
.moonform .choice-card.selected .status-dot { transform: scale(1.2); }

.moonform .dot-red   { background-color: #C0392B; }
.moonform .dot-amber { background-color: #C4973A; }
.moonform .dot-green { background-color: #27AE60; }

.moonform .choice-text { flex: 1; }
.moonform .choice-label { font-size: 15px; font-weight: 600; color: var(--text); display: block; line-height: 1.2; }
.moonform .choice-desc { font-size: 13px; color: var(--text-muted); margin-top: 1px; display: block; line-height: 1.25; }

.moonform .choice-check {
  width: 20px; height: 20px; border-radius: 50%; border: 2px solid var(--border);
  flex-shrink: 0; display: flex; align-items: center; justify-content: center;
  transition: all var(--transition); color: transparent;
}

.moonform .choice-card.selected .choice-check { background: var(--purple-deep); border-color: var(--purple-deep); color: white; }

/* ── Urgency special colors ── */
.moonform .choice-card[data-value="urgent"].selected { border-color: #C0392B; background: #FDF2F2; box-shadow: 0 0 0 3px rgba(192,57,43,0.10); }
.moonform .choice-card[data-value="urgent"].selected .choice-check { background: #C0392B; border-color: #C0392B; }
.moonform .choice-card[data-value="urgent"]:hover { border-color: #C0392B; background: #FDF2F2; transform: translateX(3px); }
.moonform .choice-card[data-value="moyen"].selected { border-color: var(--gold); background: var(--gold-light); box-shadow: 0 0 0 3px rgba(196,151,58,0.12); }
.moonform .choice-card[data-value="moyen"].selected .choice-check { background: var(--gold); border-color: var(--gold); }
.moonform .choice-card[data-value="moyen"]:hover { border-color: var(--gold); background: var(--gold-light); transform: translateX(3px); }

/* ── Autonomy special colors ── */
.moonform .choice-card[data-value="autonome"].selected { border-color: #27AE60; background: #F0FBF4; box-shadow: 0 0 0 3px rgba(39,174,96,0.10); }
.moonform .choice-card[data-value="autonome"].selected .choice-check { background: #27AE60; border-color: #27AE60; }
.moonform .choice-card[data-value="autonome"]:hover { border-color: #27AE60; background: #F0FBF4; transform: translateX(3px); }
.moonform .choice-card[data-value="semi_autonome"].selected { border-color: var(--gold); background: var(--gold-light); box-shadow: 0 0 0 3px rgba(196,151,58,0.12); }
.moonform .choice-card[data-value="semi_autonome"].selected .choice-check { background: var(--gold); border-color: var(--gold); }
.moonform .choice-card[data-value="semi_autonome"]:hover { border-color: var(--gold); background: var(--gold-light); transform: translateX(3px); }
.moonform .choice-card[data-value="dependante"].selected { border-color: #C0392B; background: #FDF2F2; box-shadow: 0 0 0 3px rgba(192,57,43,0.10); }
.moonform .choice-card[data-value="dependante"].selected .choice-check { background: #C0392B; border-color: #C0392B; }
.moonform .choice-card[data-value="dependante"]:hover { border-color: #C0392B; background: #FDF2F2; transform: translateX(3px); }

/* ── Text Inputs ── */
.moonform .input-group { margin-bottom: 9px; }

.moonform .input-label {
  font-size: 13px; font-weight: 600; color: var(--text-muted);
  letter-spacing: 0.4px; text-transform: uppercase; display: block; margin-bottom: 4px;
}

.moonform .input-field {
  width: 100%; padding: 11px 14px; border: 1.5px solid var(--border);
  border-radius: var(--radius-sm); font-family: 'Nunito', sans-serif;
  font-size: 15px; color: var(--text); background: var(--white);
  transition: border-color var(--transition), box-shadow var(--transition);
  outline: none; -webkit-appearance: none;
}

.moonform .input-field:focus { border-color: var(--purple-soft); box-shadow: 0 0 0 3px rgba(146,148,201,0.18); }
.moonform .input-field::placeholder { color: #B5B1C2; }
.moonform .input-field.error { border-color: var(--error); box-shadow: 0 0 0 3px rgba(192,57,43,0.10); }
.moonform .input-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }

@media (max-width: 440px) { .moonform .input-row { grid-template-columns: 1fr; } }

.moonform .error-msg { font-size: 11px; color: var(--error); margin-top: 4px; display: none; }
.moonform .error-msg.visible { display: block; }

/* ── Date input (flatpickr-backed) ── */
.moonform .input-date { cursor: pointer; }

/* ── Resident badge ── */
.moonform .resident-badge {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 5px 10px; margin-bottom: 16px;
  background: var(--purple-pale); color: var(--purple-deep);
  border-radius: 20px; font-size: 12px; font-weight: 600;
  letter-spacing: 0.01em;
}

/* ── Civilite inline ── */
.moonform .civil-row { display: flex; gap: 8px; margin-bottom: 10px; }

.moonform .civil-btn {
  flex: 1; padding: 6px 8px; border: 1.5px solid var(--border);
  border-radius: var(--radius-sm); background: var(--white);
  font-family: 'Nunito', sans-serif; font-size: 13px; font-weight: 600;
  color: var(--text-muted); cursor: pointer; transition: all var(--transition); text-align: center;
}

.moonform .civil-btn:hover { border-color: var(--purple-soft); color: var(--text); }
.moonform .civil-btn.selected { border-color: var(--purple-mid); background: var(--purple-pale); color: var(--purple-deep); }

/* ── Budget Slider ── */
.moonform .budget-slider-section { padding: 4px 0 8px; }

.moonform .budget-display-row { display: flex; justify-content: center; margin-bottom: 8px; }

.moonform .budget-value-display {
  background: var(--purple-pale); border: 1px solid var(--purple-soft); border-radius: 10px;
  padding: 6px 18px; text-align: center; display: inline-flex;
  align-items: baseline; gap: 7px; transition: all var(--transition);
}

.moonform .budget-amount-input {
  font-family: 'Quicksand', sans-serif; font-size: 21px;
  font-weight: 700; color: var(--purple-deep); line-height: 1;
  background: transparent; border: none; outline: none;
  width: 90px; text-align: center; padding: 0;
  -webkit-appearance: none; appearance: none;
}

.moonform .budget-amount-input:focus { color: var(--purple-mid); }

.moonform .budget-period-text { font-size: 13px; color: var(--text-muted); }
.moonform .slider-container { padding: 0 4px; margin-bottom: 8px; }

.moonform .budget-range {
  -webkit-appearance: none; appearance: none; width: 100%; height: 6px;
  border-radius: 99px; background: var(--border); outline: none; cursor: pointer; transition: background 0.1s;
}

.moonform .budget-range::-webkit-slider-thumb {
  -webkit-appearance: none; appearance: none; width: 24px; height: 24px;
  border-radius: 50%; background: var(--purple-deep); border: 3px solid white;
  box-shadow: 0 2px 8px rgba(46,40,104,0.35); cursor: pointer;
  transition: box-shadow var(--transition), transform var(--transition);
}

.moonform .budget-range::-webkit-slider-thumb:hover { box-shadow: 0 2px 14px rgba(46,40,104,0.50); transform: scale(1.1); }

.moonform .budget-range::-moz-range-thumb {
  width: 24px; height: 24px; border-radius: 50%; background: var(--purple-deep);
  border: 3px solid white; box-shadow: 0 2px 8px rgba(46,40,104,0.35); cursor: pointer;
}

.moonform .budget-range::-moz-range-track { height: 6px; border-radius: 99px; background: var(--border); }
.moonform .budget-range::-moz-range-progress { height: 6px; border-radius: 99px; background: var(--purple-deep); }

.moonform .budget-scale { display: flex; justify-content: space-between; font-size: 11px; color: var(--text-muted); padding: 0 4px; }

/* ── Budget preset slider ── */
.moonform .budget-preset-label {
  font-family: 'Quicksand', sans-serif; font-size: 16px;
  font-weight: 700; color: var(--purple-deep); text-align: center;
}
.moonform .budget-tick-marks {
  display: flex; justify-content: space-between;
  padding: 5px 12px 0; /* 12px = half thumb width, aligns ticks to thumb stops */
}
.moonform .budget-tick-marks span {
  width: 2px; height: 8px; background: var(--border); border-radius: 1px;
  transition: background var(--transition);
}
.moonform .budget-tick-marks span.active { background: var(--purple-deep); }
.moonform .budget-preset-scale {
  display: flex; justify-content: space-between; padding: 4px 4px 0;
}
.moonform .budget-preset-scale span {
  flex: 1; font-size: 10.5px; color: var(--text-muted);
  text-align: center; line-height: 1.35;
}

/* ── Navigation ── */
.moonform .form-nav {
  display: flex; align-items: center; justify-content: center;
  margin-top: 18px; padding-top: 14px; border-top: 1px solid var(--border); gap: 12px;
}

.moonform .btn-back {
  font-family: 'Nunito', sans-serif; font-size: 13px; color: var(--text-muted);
  background: none; border: none; cursor: pointer; padding: 8px 4px;
  display: flex; align-items: center; gap: 6px; transition: color var(--transition); flex-shrink: 0;
}

.moonform .btn-back:hover { color: var(--text); }
.moonform .btn-back svg { transition: transform var(--transition); }
.moonform .btn-back:hover svg { transform: translateX(-3px); }

.moonform .btn-next {
  font-family: 'Nunito', sans-serif; font-size: 14px; font-weight: 700;
  color: var(--white); background: var(--purple-deep); border: none; border-radius: var(--radius-sm);
  padding: 9px 24px; cursor: pointer; transition: all var(--transition);
  display: flex; align-items: center; gap: 8px;
}

.moonform .btn-next:hover { background: var(--purple-mid); transform: translateX(2px); }
.moonform .btn-next:disabled { opacity: 0.45; cursor: not-allowed; transform: none; }
.moonform .btn-next svg { transition: transform var(--transition); }
.moonform .btn-next:hover:not(:disabled) svg { transform: translateX(3px); }

.moonform .btn-submit {
  font-family: 'Nunito', sans-serif; font-size: 14px; font-weight: 700;
  color: var(--white); background: linear-gradient(135deg, var(--pink), #C91A58);
  border: none; border-radius: var(--radius-sm); padding: 9px 28px; cursor: pointer;
  transition: all var(--transition); display: flex; align-items: center; gap: 8px;
  box-shadow: 0 4px 16px rgba(231,33,104,0.30);
}

.moonform .btn-submit:hover { transform: translateY(-1px); box-shadow: 0 6px 20px rgba(231,33,104,0.40); }
.moonform .btn-submit:disabled { opacity: 0.5; cursor: not-allowed; transform: none; }

/* ── Confidentialite ── */
.moonform .confidentiality-note {
  display: flex; align-items: flex-start; gap: 8px; background: var(--purple-pale);
  border-radius: var(--radius-sm); padding: 12px 14px; margin-bottom: 20px;
  font-size: 12px; color: var(--purple-deep); line-height: 1.5;
}

.moonform .confidentiality-note svg { flex-shrink: 0; margin-top: 1px; }

/* ── Thank you page ── */
.moonform #step-thankyou { text-align: center; padding: 20px 0 8px; }

.moonform .ty-icon {
  width: 68px; height: 68px; background: var(--purple-pale); border-radius: 50%;
  display: flex; align-items: center; justify-content: center; margin: 0 auto 20px;
}

.moonform .ty-title { font-family: 'Quicksand', sans-serif; font-size: 22px; font-weight: 700; color: var(--purple-deep); margin-bottom: 10px; }
.moonform .ty-text { font-size: 14px; color: var(--text-muted); line-height: 1.7; max-width: 380px; margin: 0 auto 20px; }

.moonform .ty-badge {
  display: none; align-items: center; gap: 8px; background: var(--pink-pale);
  border: 1px solid rgba(231,33,104,0.2); border-radius: 99px; padding: 8px 16px;
  font-size: 13px; color: #8B2F4D; font-weight: 500;
}

.moonform .ty-badge-body { display: inline-flex; align-items: flex-start; gap: 6px; }
.moonform .ty-badge-stat { font-size: 13px; font-weight: 700; white-space: nowrap; }

/* ── Autocomplete dropdown ── */
.moonform .autocomplete-wrap { position: relative; }

.moonform .autocomplete-list {
  position: absolute; top: 100%; left: 0; right: 0; background: var(--white);
  border: 1.5px solid var(--border); border-top: none;
  border-radius: 0 0 var(--radius-sm) var(--radius-sm);
  box-shadow: var(--shadow); z-index: 100; max-height: 200px; overflow-y: auto; display: none;
}

.moonform .autocomplete-list.open { display: block; }

.moonform .autocomplete-item { padding: 11px 16px; font-size: 13px; color: var(--text); cursor: pointer; transition: background var(--transition); }
.moonform .autocomplete-item:hover,
.moonform .autocomplete-item.highlighted { background: var(--purple-pale); }

/* ── Loading spinner ── */
.moonform .spinner {
  display: inline-block; width: 16px; height: 16px;
  border: 2px solid rgba(255,255,255,0.4); border-top-color: white;
  border-radius: 50%; animation: moonformSpin 0.7s linear infinite; display: none;
}

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

/* ── 2x2 Grid for choice cards (lien de parente) ── */
.moonform .choices-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.moonform .choices-grid .choice-card {
  flex-direction: column; align-items: center; justify-content: flex-start;
  padding: 14px 10px 12px; gap: 7px; min-height: 80px; position: relative;
}
.moonform .choices-grid .choice-card:hover { transform: translateY(-2px); }
.moonform .choices-grid .choice-card.selected { transform: none; }
.moonform .choices-grid .choice-icon { width: 26px; height: 26px; }
.moonform .choices-grid .choice-text { flex: unset; text-align: center; }
.moonform .choices-grid .choice-label { font-size: 12.5px; text-align: center; line-height: 1.35; }
.moonform .choices-grid .choice-check { position: absolute; top: 7px; right: 7px; width: 16px; height: 16px; }
@media (max-width: 360px) { .moonform .choices-grid { grid-template-columns: 1fr; } }

/* ── Segmented Control (autonomie) ── */
.moonform .segment-control {
  display: flex; border: 1.5px solid var(--border); border-radius: var(--radius);
  overflow: hidden; transition: border-color var(--transition);
}

.moonform .segment-btn {
  flex: 1; display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 4px; padding: 10px 8px; background: var(--white); border: none;
  border-right: 1.5px solid var(--border); cursor: pointer;
  transition: background var(--transition); font-family: 'Nunito', sans-serif;
}

.moonform .segment-btn:last-child { border-right: none; }
.moonform .segment-btn[data-value="autonome"]:hover,
.moonform .segment-btn[data-value="autonome"].selected { background: #F0FBF4; }
.moonform .segment-btn[data-value="semi_autonome"]:hover,
.moonform .segment-btn[data-value="semi_autonome"].selected { background: var(--gold-light); }
.moonform .segment-btn[data-value="dependante"]:hover,
.moonform .segment-btn[data-value="dependante"].selected { background: #FDF2F2; }
.moonform .segment-label { font-size: 13px; font-weight: 600; color: var(--text); display: block; line-height: 1.2; transition: color var(--transition); }
.moonform .segment-btn.selected .segment-label { color: var(--purple-deep); font-weight: 700; }

/* ── Test button (TEST_MODE only) ── */
.moonform .btn-test {
  display: none; margin-top: 12px; padding: 5px 12px; font-size: 11px; font-family: monospace;
  background: #f5f5f5; border: 1px dashed #aaa; border-radius: 6px; color: #888; cursor: pointer; width: 100%;
}
.moonform .btn-test:hover { background: #ebebeb; color: #555; }

/* ── Flatpickr calendar — Heimfinder theme ── */
.flatpickr-calendar {
  font-family: 'Nunito', sans-serif;
  border-radius: 14px;
  box-shadow: 0 4px 24px rgba(46,40,104,0.15);
  border: 1.5px solid #E2E0EC;
}
.flatpickr-months { background: #2E2868; border-radius: 12px 12px 0 0; }
.flatpickr-month { background: transparent; color: white; fill: white; }
.flatpickr-current-month { color: white; }
.flatpickr-current-month .flatpickr-monthDropdown-months { background: #2E2868; color: white; }
.flatpickr-current-month input.cur-year { color: white; }
.flatpickr-prev-month, .flatpickr-next-month { color: white; fill: white; }
.flatpickr-prev-month:hover svg, .flatpickr-next-month:hover svg { fill: #F8CAE0; }
.flatpickr-weekdays { background: #2E2868; }
span.flatpickr-weekday { background: #2E2868; color: rgba(255,255,255,0.55); font-size: 11px; font-weight: 600; }
.flatpickr-day { border-radius: 8px; color: #3E3C49; font-size: 13px; }
.flatpickr-day:hover:not(.disabled):not(.selected):not(.today) { background: #EEEDF6; border-color: #EEEDF6; }
.flatpickr-day.today { border-color: #E72168; color: #E72168; font-weight: 600; }
.flatpickr-day.today:hover { background: #FDF0F6; border-color: #E72168; }
.flatpickr-day.selected, .flatpickr-day.selected:hover { background: #2E2868; border-color: #2E2868; color: white; }
.flatpickr-day.flatpickr-disabled, .flatpickr-day.flatpickr-disabled:hover { color: #C5CDD6; }
