/**
 * Cittago Booking Form — CSS v1.7
 *
 * Changes from v1.6:
 *  - Step circles: numbers now centred using absolute positioning
 *    on the span (immune to inherited line-height from theme)
 *  - Inactive circle: orange border + orange number, white bg
 *  - Form wrapper: background transparent, no box-shadow
 *    (design controlled from Elementor/page-builder)
 *  - .cit-tz-note hidden (removed from display)
 *  - Accent #FF6600 throughout (unchanged from v1.6)
 */

/* ============================================================
   DESIGN TOKENS
   ============================================================ */
.cittago-booking-form {
  --cit-bg-card:        transparent;
  --cit-bg-input:       #181817;
  --cit-bg-input-focus: #1e1e1d;

  --cit-border:         rgba(255, 255, 255, 0.08);
  --cit-border-focus:   #FF6600;
  --cit-border-error:   #e03030;

  --cit-text:           #1a1a1a;
  --cit-text-secondary: #444444;
  --cit-text-muted:     #888888;
  --cit-text-label:     #FF6600;
  --cit-text-on-dark:   #ffffff;
  --cit-text-on-dark-muted: rgba(255, 255, 255, 0.5);

  --cit-accent:         #FF6600;
  --cit-accent-hover:   #e05a00;
  --cit-accent-text:    #ffffff;

  --cit-divider:        rgba(0, 0, 0, 0.08);

  --cit-error:          #e03030;
  --cit-success:        #2e7d32;

  --cit-radius:         8px;
  --cit-radius-pill:    999px;
  --cit-font:           inherit;
  --cit-transition:     0.2s ease;
}

/* ============================================================
   WRAPPER — transparent, no shadow (controlled from page builder)
   ============================================================ */
.cittago-booking-form {
  font-family:   var(--cit-font);
  color:         var(--cit-text);
  max-width:     640px;
  margin:        0 auto;
  box-sizing:    border-box;
  background:    transparent;
  border-radius: 0;
  padding:       0;
  box-shadow:    none;
}

/* ============================================================
   ALGENIX / ThemeREX GLOBAL RESETS
   ============================================================ */
.cittago-booking-form input:not([type="button"]):not([type="submit"]):not([type="checkbox"]):not([type="radio"]),
.cittago-booking-form select,
.cittago-booking-form textarea {
  background:    var(--cit-bg-input) !important;
  color:         var(--cit-text-on-dark) !important;
  border-radius: var(--cit-radius) !important;
  box-shadow:    none !important;
  min-width:     0 !important;
}

.cittago-booking-form input:focus:not([type="button"]):not([type="submit"]):not([type="checkbox"]):not([type="radio"]),
.cittago-booking-form select:focus {
  background:   var(--cit-bg-input-focus) !important;
  color:        var(--cit-text-on-dark) !important;
  border-color: var(--cit-border-focus) !important;
  box-shadow:   0 0 0 3px rgba(255, 102, 0, 0.15) !important;
  outline:      none !important;
}

.cittago-booking-form label {
  color:          inherit !important;
  font-size:      inherit !important;
  font-weight:    inherit !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
  margin-bottom:  0 !important;
}

.cittago-booking-form .wpcf7-form-control-wrap {
  margin-bottom: 0 !important;
}

/* ============================================================
   STEP PROGRESS INDICATOR
   FIX v1.7: circle uses position:relative + span uses
   position:absolute with inset:0 + flex centering.
   This is 100% immune to inherited line-height from the theme.
   ============================================================ */
.cit-steps-indicator {
  display:         flex;
  align-items:     center;
  justify-content: center;
  margin-bottom:   2.5rem;
}

.cit-step-item {
  display:        flex;
  flex-direction: column;
  align-items:    center;
  gap:            8px;
  flex-shrink:    0;
}

.cit-step-divider {
  flex:          1;
  min-width:     32px;
  height:        1px;
  background:    rgba(0, 0, 0, 0.12) !important;
  margin-bottom: 30px;
}

/* Circle — position:relative so the spans can be absolute */
.cit-step-circle {
  position:      relative;
  width:         40px;
  height:        40px;
  border-radius: 50%;
  /* INACTIVE: orange border, white background, orange text */
  border:        2px solid var(--cit-accent) !important;
  background:    #ffffff;
  flex-shrink:   0;
  /* Reset all font inheritance — the spans handle their own */
  font-size:     0 !important;
  line-height:   0 !important;
}

/* Both spans fill the circle and use flex to centre their content */
.cit-step-num,
.cit-step-check {
  position:        absolute;
  inset:           0;
  display:         flex;
  align-items:     center;
  justify-content: center;
  width:           100%;
  height:          100%;
  /* Explicit font — not inherited */
  font-family:     -apple-system, BlinkMacSystemFont, 'Inter', 'Segoe UI', sans-serif !important;
  font-size:       15px !important;
  font-weight:     700 !important;
  line-height:     1 !important;
  color:           var(--cit-accent); /* orange number for inactive */
}

.cit-step-check {
  display: none;
  font-size: 17px !important;
  color: #ffffff;
}

.cit-step-label {
  font-size:      10px;
  font-weight:    600;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  color:          var(--cit-text-muted);
  white-space:    nowrap;
  transition:     color var(--cit-transition);
}

/* ACTIVE step — filled orange */
.cit-step-item.active .cit-step-circle {
  background:   var(--cit-accent) !important;
  border-color: var(--cit-accent) !important;
}
.cit-step-item.active .cit-step-num {
  color: #ffffff !important;
}
.cit-step-item.active .cit-step-label {
  color: var(--cit-text);
}

/* COMPLETED step — filled orange with checkmark */
.cit-step-item.completed .cit-step-circle {
  background:   var(--cit-accent) !important;
  border-color: var(--cit-accent) !important;
}
.cit-step-item.completed .cit-step-num   { display: none; }
.cit-step-item.completed .cit-step-check {
  display: flex;
  color:   #ffffff !important;
}
.cit-step-item.completed + .cit-step-divider {
  background: rgba(255, 102, 0, 0.35) !important;
}

@media (max-width: 420px) {
  .cit-step-circle  { width: 34px; height: 34px; }
  .cit-step-num     { font-size: 13px !important; }
  .cit-step-check   { font-size: 14px !important; }
  .cit-step-label   { font-size: 9px; }
  .cit-step-divider { min-width: 16px; }
}

/* ============================================================
   STEP FADE ANIMATION
   ============================================================ */
.cit-form-step {
  animation: citFadeSlide 0.3s ease forwards;
}

@keyframes citFadeSlide {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ============================================================
   FIELD GROUPS
   ============================================================ */
.cit-field-group { margin-bottom: 1.1rem; }

.cit-row {
  display:               grid;
  grid-template-columns: 1fr 1fr;
  gap:                   1rem;
}

@media (max-width: 520px) {
  .cit-row { grid-template-columns: 1fr; }
}

/* ============================================================
   LABELS
   ============================================================ */
.cit-label {
  display:        block !important;
  font-size:      0.7rem !important;
  font-weight:    700 !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  color:          var(--cit-text-label) !important;
  margin-bottom:  6px !important;
  line-height:    1.3 !important;
}

.cit-req { color: var(--cit-error) !important; margin-left: 2px; }
.cit-opt {
  font-weight:    400 !important;
  font-size:      0.8em !important;
  color:          var(--cit-text-muted) !important;
  margin-left:    5px;
  text-transform: none !important;
  letter-spacing: 0 !important;
}

/* ============================================================
   AUTO-DETECTED TIMEZONE NOTE — hidden
   ============================================================ */
.cit-tz-note {
  display: none !important;
}

/* ============================================================
   TEXT INPUTS — dark bg, white text
   iOS zoom fix: 16px minimum on mobile
   ============================================================ */
.cittago-booking-form input[type="text"],
.cittago-booking-form input[type="email"],
.cittago-booking-form input[type="tel"],
.cittago-booking-form input[type="url"],
.cittago-booking-form input[type="date"] {
  display:       block !important;
  width:         100% !important;
  box-sizing:    border-box !important;
  background:    var(--cit-bg-input) !important;
  color:         var(--cit-text-on-dark) !important;
  border:        2px solid var(--cit-border) !important;
  border-radius: var(--cit-radius) !important;
  padding:       0.75rem 1rem !important;
  font-family:   inherit !important;
  font-size:     16px !important;
  line-height:   1.5 !important;
  outline:       none !important;
  appearance:    none !important;
  -webkit-appearance: none !important;
  transition:    border-color var(--cit-transition), box-shadow var(--cit-transition) !important;
  min-width:     0 !important;
}

@media (min-width: 521px) {
  .cittago-booking-form input[type="text"],
  .cittago-booking-form input[type="email"],
  .cittago-booking-form input[type="tel"],
  .cittago-booking-form input[type="url"],
  .cittago-booking-form input[type="date"] {
    font-size: 0.95rem !important;
  }
}

.cittago-booking-form input[type="text"]:hover,
.cittago-booking-form input[type="email"]:hover,
.cittago-booking-form input[type="tel"]:hover,
.cittago-booking-form input[type="url"]:hover {
  border-color: rgba(255, 102, 0, 0.35) !important;
}

.cittago-booking-form input[type="text"]:focus,
.cittago-booking-form input[type="email"]:focus,
.cittago-booking-form input[type="tel"]:focus,
.cittago-booking-form input[type="url"]:focus,
.cittago-booking-form input[type="date"]:focus {
  border-color: var(--cit-border-focus) !important;
  box-shadow:   0 0 0 3px rgba(255, 102, 0, 0.15) !important;
}

.cittago-booking-form input::placeholder {
  color:   var(--cit-text-on-dark-muted) !important;
  opacity: 1 !important;
}

.cittago-booking-form input.cit-invalid {
  border-color: var(--cit-error) !important;
  box-shadow:   0 0 0 3px rgba(224, 48, 48, 0.15) !important;
}

.cittago-booking-form input.cit-date-input { cursor: pointer !important; }

/* ============================================================
   SELECT DROPDOWNS — dark bg, orange chevron
   iOS zoom fix: 16px minimum
   ============================================================ */
.cittago-booking-form select {
  display:             block !important;
  width:               100% !important;
  box-sizing:          border-box !important;
  background:          var(--cit-bg-input) !important;
  color:               var(--cit-text-on-dark) !important;
  border:              2px solid var(--cit-border) !important;
  border-radius:       var(--cit-radius) !important;
  padding:             0.75rem 2.75rem 0.75rem 1rem !important;
  font-family:         inherit !important;
  font-size:           16px !important;
  line-height:         1.5 !important;
  outline:             none !important;
  appearance:          none !important;
  -webkit-appearance:  none !important;
  cursor:              pointer !important;
  min-width:           0 !important;
  background-image:    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='9' viewBox='0 0 14 9'%3E%3Cpath d='M1 1l6 6 6-6' stroke='%23FF6600' stroke-width='2' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") !important;
  background-repeat:   no-repeat !important;
  background-position: right 14px center !important;
  transition:          border-color var(--cit-transition), box-shadow var(--cit-transition) !important;
}

@media (min-width: 521px) {
  .cittago-booking-form select { font-size: 0.95rem !important; }
}

.cittago-booking-form select:hover {
  border-color: rgba(255, 102, 0, 0.35) !important;
}

.cittago-booking-form select:focus {
  background-color: var(--cit-bg-input-focus) !important;
  border-color:     var(--cit-border-focus) !important;
  box-shadow:       0 0 0 3px rgba(255, 102, 0, 0.15) !important;
}

.cittago-booking-form select.cit-invalid {
  border-color: var(--cit-error) !important;
  box-shadow:   0 0 0 3px rgba(224, 48, 48, 0.15) !important;
}

.cittago-booking-form select option {
  background: #181817;
  color:      #ffffff;
}

/* ============================================================
   NOTES / HELPER TEXT
   ============================================================ */
.cit-note,
.cit-newsletter-note {
  display:     block !important;
  font-size:   0.78rem !important;
  color:       var(--cit-text-muted) !important;
  margin-top:  5px !important;
  line-height: 1.5 !important;
  font-family: inherit !important;
}

.cit-local-time-note {
  color:       var(--cit-accent) !important;
  font-weight: 600 !important;
}

/* ============================================================
   ERROR MESSAGES
   ============================================================ */
.cit-field-error {
  display:     none;
  color:       var(--cit-error) !important;
  font-size:   0.78rem !important;
  margin-top:  4px !important;
  line-height: 1.4 !important;
}

/* ============================================================
   COMMUNICATION CHANNEL PILLS
   ============================================================ */
.cit-channel-grid {
  display:    flex;
  flex-wrap:  wrap;
  gap:        8px;
  margin-top: 6px;
}

.cit-channel-grid .wpcf7-list-item {
  margin: 3px !important;
}

.cit-channel-grid .wpcf7-list-item label {
  display:        flex !important;
  align-items:    center !important;
  gap:            6px !important;
  padding:        0.45rem 1.1rem !important;
  border:         1.5px solid rgba(0, 0, 0, 0.15) !important;
  border-radius:  var(--cit-radius-pill) !important;
  cursor:         pointer !important;
  font-size:      0.85rem !important;
  font-weight:    500 !important;
  color:          var(--cit-text-secondary) !important;
  background:     #ffffff !important;
  transition:     all var(--cit-transition) !important;
  user-select:    none;
  white-space:    nowrap;
  text-transform: none !important;
  letter-spacing: 0 !important;
  margin:         0 !important;
  line-height:    1.4 !important;
  box-shadow:     0 1px 3px rgba(0,0,0,0.08);
}

.cit-channel-grid .wpcf7-list-item label:hover {
  border-color: var(--cit-accent) !important;
  color:        var(--cit-accent) !important;
  background:   rgba(255, 102, 0, 0.06) !important;
  box-shadow:   0 2px 8px rgba(255, 102, 0, 0.15);
}

.cit-channel-grid .wpcf7-list-item:has(input:checked) label,
.cit-channel-grid .wpcf7-list-item.cit-checked label {
  background:   var(--cit-accent) !important;
  border-color: var(--cit-accent) !important;
  color:        #ffffff !important;
  box-shadow:   0 3px 10px rgba(255, 102, 0, 0.3);
}

.cit-channel-grid .wpcf7-list-item input[type="radio"] {
  position: absolute;
  opacity:  0;
  width:    0;
  height:   0;
  margin:   0;
}

@media (max-width: 520px) {
  .cit-channel-grid { flex-direction: column; gap: 6px; }
  .cit-channel-grid .wpcf7-list-item { width: 100%; margin: 2px 0 !important; }
  .cit-channel-grid .wpcf7-list-item label {
    width:           100% !important;
    box-sizing:      border-box !important;
    justify-content: center !important;
  }
}

/* ============================================================
   LEGAL BLOCK — Privacy + Newsletter
   ============================================================ */
.cit-legal-block {
  margin-top:  2rem;
  padding-top: 1.25rem;
  border-top:  1px solid var(--cit-divider);
}

.cit-accept-row { margin-bottom: 1rem; }

.cit-legal-block .wpcf7-acceptance .wpcf7-list-item,
.cit-legal-block .wpcf7-checkbox  .wpcf7-list-item {
  margin:  0 !important;
  display: block !important;
}

.cit-legal-block .wpcf7-list-item label,
.cit-legal-block .wpcf7-acceptance label {
  display:        flex !important;
  align-items:    flex-start !important;
  gap:            10px !important;
  font-size:      0.85rem !important;
  color:          var(--cit-text-secondary) !important;
  cursor:         pointer !important;
  line-height:    1.5 !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
  font-weight:    400 !important;
  background:     transparent !important;
  border:         none !important;
  padding:        0 !important;
  margin:         0 !important;
  box-shadow:     none !important;
}

.cit-legal-block input[type="checkbox"] {
  flex-shrink:  0 !important;
  margin-top:   3px !important;
  width:        15px !important;
  height:       15px !important;
  min-width:    15px !important;
  accent-color: var(--cit-accent) !important;
  cursor:       pointer !important;
  background:   transparent !important;
}

.cit-legal-block a {
  color:                 var(--cit-accent) !important;
  text-decoration:       underline !important;
  text-underline-offset: 2px !important;
}
.cit-legal-block a:hover { opacity: 0.75; }

.cit-newsletter-note {
  margin-left: 25px !important;
  margin-top:  5px !important;
}

/* ============================================================
   STEP ACTION BUTTONS
   ============================================================ */
.cit-step-actions {
  display:         flex;
  justify-content: space-between;
  align-items:     center;
  margin-top:      2rem;
  gap:             1rem;
}

.cit-step-actions--end { justify-content: flex-end; }

/* Back button */
button.cit-btn-back,
.cittago-booking-form button.cit-btn-back,
.cittago-booking-form button.cit-btn-back:not(:disabled),
.cittago-booking-form button.cit-btn-back:hover {
  background:       transparent !important;
  background-color: transparent !important;
  border:           none !important;
  box-shadow:       none !important;
  color:            var(--cit-text-muted) !important;
  font-family:      inherit !important;
  font-size:        0.9rem !important;
  font-weight:      400 !important;
  cursor:           pointer !important;
  padding:          0 !important;
  margin:           0 !important;
  display:          flex !important;
  align-items:      center !important;
  gap:              5px !important;
  line-height:      1 !important;
  text-transform:   none !important;
  letter-spacing:   0 !important;
  transition:       color var(--cit-transition) !important;
  border-radius:    0 !important;
}

button.cit-btn-back:hover,
.cittago-booking-form button.cit-btn-back:hover {
  background:       transparent !important;
  background-color: transparent !important;
  color:            var(--cit-text) !important;
}

/* Continue button */
button.cit-btn-next,
.cittago-booking-form button.cit-btn-next,
.cittago-booking-form button.cit-btn-next:not(:disabled) {
  display:          inline-flex !important;
  align-items:      center !important;
  justify-content:  center !important;
  gap:              8px !important;
  background:       var(--cit-accent) !important;
  background-color: var(--cit-accent) !important;
  color:            #ffffff !important;
  border:           none !important;
  border-radius:    var(--cit-radius-pill) !important;
  padding:          0.7rem 1.8rem !important;
  font-family:      inherit !important;
  font-size:        0.9rem !important;
  font-weight:      600 !important;
  letter-spacing:   0.02em !important;
  text-transform:   none !important;
  cursor:           pointer !important;
  box-shadow:       0 4px 14px rgba(255, 102, 0, 0.3) !important;
  white-space:      nowrap !important;
  line-height:      1.4 !important;
  transition:       background var(--cit-transition), transform 0.15s ease, box-shadow var(--cit-transition) !important;
}

button.cit-btn-next:hover,
.cittago-booking-form button.cit-btn-next:hover {
  background:       var(--cit-accent-hover) !important;
  background-color: var(--cit-accent-hover) !important;
  transform:        translateY(-1px) !important;
  box-shadow:       0 6px 20px rgba(255, 102, 0, 0.4) !important;
  color:            #ffffff !important;
}
button.cit-btn-next:active { transform: translateY(0) !important; }

/* Submit button */
input.cit-btn-submit,
.cittago-booking-form input.cit-btn-submit,
.cittago-booking-form input[type="submit"].cit-btn-submit,
.cittago-booking-form input.cit-btn-submit:not(:disabled) {
  display:          inline-flex !important;
  align-items:      center !important;
  justify-content:  center !important;
  background:       var(--cit-accent) !important;
  background-color: var(--cit-accent) !important;
  color:            #ffffff !important;
  border:           none !important;
  border-radius:    var(--cit-radius-pill) !important;
  padding:          0.75rem 2.2rem !important;
  font-family:      inherit !important;
  font-size:        0.95rem !important;
  font-weight:      700 !important;
  letter-spacing:   0.02em !important;
  text-transform:   none !important;
  cursor:           pointer !important;
  box-shadow:       0 4px 14px rgba(255, 102, 0, 0.3) !important;
  white-space:      nowrap !important;
  min-width:        200px !important;
  line-height:      1.4 !important;
  transition:       background var(--cit-transition), transform 0.15s ease, box-shadow var(--cit-transition) !important;
  appearance:       none !important;
  -webkit-appearance: none !important;
}

input.cit-btn-submit:hover,
.cittago-booking-form input.cit-btn-submit:hover {
  background:       var(--cit-accent-hover) !important;
  background-color: var(--cit-accent-hover) !important;
  transform:        translateY(-1px) !important;
  box-shadow:       0 6px 20px rgba(255, 102, 0, 0.4) !important;
}

input.cit-btn-submit:active   { transform: translateY(0) !important; }
input.cit-btn-submit:disabled {
  opacity:    0.5 !important;
  cursor:     not-allowed !important;
  transform:  none !important;
  box-shadow: none !important;
}

@media (max-width: 520px) {
  .cit-step-actions            { flex-direction: column-reverse; align-items: stretch; }
  .cit-step-actions--end       { flex-direction: column; align-items: stretch; }
  button.cit-btn-next,
  input.cit-btn-submit         { width: 100% !important; }
  button.cit-btn-back          { justify-content: center !important; width: 100% !important; }
}

/* ============================================================
   FLATPICKR — DARK THEME
   ============================================================ */
.flatpickr-calendar {
  background:    #181817 !important;
  border:        1px solid rgba(255,255,255,0.1) !important;
  box-shadow:    0 12px 40px rgba(0,0,0,0.5) !important;
  border-radius: 10px !important;
  color:         #fff !important;
  font-family:   inherit !important;
}

.flatpickr-months,
.flatpickr-month {
  background:    #1e1e1d !important;
  color:         #fff !important;
  fill:          #fff !important;
  border-radius: 10px 10px 0 0 !important;
}

.flatpickr-current-month,
.flatpickr-current-month input.cur-year {
  color:      #fff !important;
  background: transparent !important;
  font-family: inherit !important;
}

.flatpickr-monthDropdown-months {
  background: #1e1e1d !important;
  color:      #fff !important;
}

.flatpickr-prev-month,
.flatpickr-next-month {
  color: rgba(255,255,255,0.5) !important;
  fill:  rgba(255,255,255,0.5) !important;
}

.flatpickr-prev-month:hover,
.flatpickr-next-month:hover {
  background:    rgba(255,255,255,0.08) !important;
  color:         #FF6600 !important;
  fill:          #FF6600 !important;
  border-radius: 4px !important;
}

.numInputWrapper span {
  opacity:      1 !important;
  margin-right: -10px !important;
}

.flatpickr-current-month .numInputWrapper span.arrowUp:after {
  border-bottom-color: #ffffff !important;
}

.flatpickr-current-month .numInputWrapper span.arrowDown:after {
  border-top-color: #ffffff !important;
}

.flatpickr-weekdays { background: #1e1e1d !important; }

span.flatpickr-weekday {
  background:  #1e1e1d !important;
  color:       rgba(255,255,255,0.35) !important;
  font-size:   0.72rem !important;
  font-weight: 600 !important;
}

.flatpickr-day {
  color:         rgba(255,255,255,0.72) !important;
  border-radius: 5px !important;
}

.flatpickr-day:hover {
  background:   rgba(255, 102, 0, 0.15) !important;
  border-color: transparent !important;
  color:        #FF6600 !important;
}

.flatpickr-day.selected,
.flatpickr-day.selected:hover {
  background:   #FF6600 !important;
  border-color: #FF6600 !important;
  color:        #fff !important;
  font-weight:  700 !important;
}

.flatpickr-day.today:not(.selected) {
  border-color: rgba(255, 102, 0, 0.5) !important;
  color:        #FF6600 !important;
}

.flatpickr-day.flatpickr-disabled,
.flatpickr-day.flatpickr-disabled:hover {
  color:           rgba(255,255,255,0.18) !important;
  background:      transparent !important;
  cursor:          not-allowed !important;
  text-decoration: line-through !important;
}

.flatpickr-innerContainer { padding: 4px 8px 10px !important; }

/* ============================================================
   CF7 RESPONSE OUTPUT
   ============================================================ */
.wpcf7 form.wpcf7-form:not(.submitting) .wpcf7-response-output { display: none; }

.wpcf7 .wpcf7-response-output {
  border:        1px solid rgba(0,0,0,0.1) !important;
  border-radius: var(--cit-radius) !important;
  margin:        1rem 0 0 !important;
  padding:       0.75rem 1rem !important;
  font-size:     0.875rem !important;
  color:         var(--cit-text-muted) !important;
  background:    transparent !important;
}

.wpcf7 .wpcf7-mail-sent-ok     { border-color: var(--cit-success) !important; color: var(--cit-success) !important; }
.wpcf7 .wpcf7-validation-errors,
.wpcf7 .wpcf7-mail-sent-ng      { border-color: var(--cit-error) !important; color: var(--cit-error) !important; }

.wpcf7 .ajax-loader   { display: none !important; }
.wpcf7-not-valid-tip  { display: none !important; }
.wpcf7-not-valid      { border-color: var(--cit-error) !important; }