.urgent-booking-wrap { max-width: 520px; padding-top: 96px; padding-bottom: 48px; margin-top: 0; }
.urgent-booking-wrap .urgent-booking-form .form-group { margin-bottom: 18px; }
.urgent-booking-wrap .urgent-booking-form .control-label { font-size: 13.5px; font-weight: 600; color: #4a4360; margin-bottom: 6px; }
.urgent-booking-wrap .urgent-booking-form .form-control { height: auto; min-height: 44px; padding: 10px 14px; font-size: 15px; color: #2a2042; border: 1px solid #ddd2ef; border-radius: 10px; box-shadow: none; transition: border-color .15s, box-shadow .15s; }
.urgent-booking-wrap .urgent-booking-form select.form-control { height: auto; min-height: 44px; cursor: pointer; -webkit-appearance: none; -moz-appearance: none; appearance: none; padding: 10px 40px 10px 14px; background-image: url("data:image/svg+xml;charset=UTF-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%237b5ea7' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 14px center; background-size: 16px 16px; text-overflow: ellipsis; }
.urgent-booking-wrap .urgent-booking-form select.form-control::-ms-expand { display: none; }
.urgent-booking-wrap .urgent-booking-form textarea.form-control { min-height: 88px; font-size: 15px; padding: 10px 14px; resize: vertical; border-radius: 10px; }
.urgent-booking-wrap .urgent-booking-form .form-control:focus { border-color: var(--site-primary, #7b5ea7); box-shadow: 0 0 0 3px rgba(123, 94, 167, .14); }
.urgent-booking-wrap .urgent-booking-form .btn { padding: 11px 24px; font-size: 15px; font-weight: 600; border-radius: 10px; min-height: 44px; }
.urgent-booking-wrap h1 { font-size: 28px; font-weight: 700; letter-spacing: -.01em; color: #1f1733; margin-bottom: 24px; }
.urgent-booking-wrap .help-block { font-size: 13px; }
.urgent-steps-indicator { display: flex; justify-content: space-between; margin-bottom: 30px; padding: 0 8px; }
.urgent-steps-indicator .step-dot { width: 38px; height: 38px; border-radius: 50%; border: 2px solid #e2d8f3; background: #fff; display: flex; align-items: center; justify-content: center; font-size: 14px; font-weight: 700; color: #b0a7c4; transition: background .2s, border-color .2s, color .2s, box-shadow .2s; }
.urgent-steps-indicator .step-dot.active { border-color: var(--site-primary, #7b5ea7); background: var(--site-primary, #7b5ea7); color: #fff; box-shadow: 0 4px 12px rgba(123, 94, 167, .3); }
.urgent-steps-indicator .step-dot.done { border-color: var(--site-primary-light, #9b7ec8); background: var(--site-primary-light, #9b7ec8); color: #fff; }
.urgent-steps-indicator > div { display: flex; flex-direction: column; align-items: center; }
.urgent-steps-indicator .step-label { font-size: 12px; color: #b0a7c4; margin-top: 7px; text-align: center; max-width: 72px; }
.urgent-steps-indicator .step-dot.active + .step-label { color: #5d3f8f; font-weight: 600; }
.urgent-steps-indicator .step-dot.done + .step-label { color: #6f6788; }
.urgent-step { display: none; }
.urgent-step.active { display: block; }
/* Force first step (and any active step) visible — override theme .js .to-animate { opacity:0 } and similar */
.site-signup .urgent-step.active,
.urgent-booking-wrap .urgent-step.active {
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
}
.site-signup .urgent-step.active p,
.site-signup .urgent-step.active .form-group,
.site-signup .urgent-step.active label,
.site-signup .urgent-step.active .radio,
.urgent-booking-wrap .urgent-step.active p,
.urgent-booking-wrap .urgent-step.active .form-group,
.urgent-booking-wrap .urgent-step.active label,
.urgent-booking-wrap .urgent-step.active .radio {
  color: #333 !important;
  opacity: 1 !important;
  visibility: visible !important;
}

/* Cancel theme .js .to-animate { opacity: 0 } so first step is visible without JS animation.
   Use .js .page-signup so we beat theme selector .js .to-animate (higher specificity). */
.js .page-urgent-booking .to-animate,
.js .page-urgent-booking .to-animate-2,
.js .page-urgent-booking .single-animate,
.js .page-signup .to-animate,
.js .page-signup .to-animate-2,
.js .page-signup .single-animate,
.js .page-register .to-animate,
.js .page-register .to-animate-2,
.js .page-register .single-animate,
.js .page-urgent-booking .urgent-booking-wrap .to-animate,
.js .page-urgent-booking .urgent-booking-wrap .to-animate-2,
.js .page-urgent-booking .urgent-booking-wrap .single-animate,
.js .page-signup .urgent-booking-wrap .to-animate,
.js .page-signup .urgent-booking-wrap .to-animate-2,
.js .page-signup .urgent-booking-wrap .single-animate,
.js .page-signup .site-signup .to-animate,
.js .page-signup .site-signup .to-animate-2,
.js .page-signup .site-signup .single-animate,
.page-urgent-booking .to-animate,
.page-urgent-booking .to-animate-2,
.page-urgent-booking .single-animate,
.page-signup .to-animate,
.page-signup .to-animate-2,
.page-signup .single-animate,
.page-register .to-animate,
.page-register .to-animate-2,
.page-register .single-animate,
.urgent-booking-wrap .to-animate,
.urgent-booking-wrap .to-animate-2,
.urgent-booking-wrap .single-animate,
.site-signup .to-animate,
.site-signup .to-animate-2,
.site-signup .single-animate {
  opacity: 1 !important;
}
/* Ensure main content area on signup/urgent/register is never hidden by theme animation classes */
.js .page-signup .main-content-wrap,
.js .page-signup .main-content-wrap .to-animate,
.js .page-signup .main-content-wrap .to-animate-2,
.js .page-signup .main-content-wrap .single-animate,
.js .page-urgent-booking .main-content-wrap,
.js .page-urgent-booking .main-content-wrap .to-animate,
.js .page-urgent-booking .main-content-wrap .to-animate-2,
.js .page-urgent-booking .main-content-wrap .single-animate,
.js .page-register .main-content-wrap,
.js .page-register .main-content-wrap .to-animate,
.js .page-register .main-content-wrap .to-animate-2,
.js .page-register .main-content-wrap .single-animate {
  opacity: 1 !important;
}
.urgent-booking-wrap .urgent-step.active .row,
.urgent-booking-wrap .urgent-step.active .row *,
.site-signup .urgent-step.active .row,
.site-signup .urgent-step.active .row * {
  opacity: 1 !important;
}
.urgent-step-buttons { margin-top: 24px; display: flex; flex-wrap: wrap; gap: 12px; align-items: center; }
.urgent-step-buttons .btn-back { margin-right: auto; }
.urgent-step-buttons .btn-step-next { margin-left: auto; }
.urgent-step-error { display: none; margin-bottom: 12px; padding: 12px 14px; background: #fbe3df; border: 1px solid #f3c6bf; color: #c0392b; border-radius: 10px; font-size: 14px; }
.urgent-step-error.visible { display: block; }
.urgent-service-search-wrap { position: relative; }
.urgent-service-search-list { position: absolute; top: calc(100% + 4px); left: 0; right: 0; z-index: 100; max-height: 240px; overflow-y: auto; background: #fff; border: 1px solid #e6ddf5; border-radius: 12px; box-shadow: 0 8px 24px rgba(123,94,167,0.16); list-style: none; margin: 0; padding: 6px; }
.urgent-service-search-list li { padding: 10px 12px; cursor: pointer; font-size: 14px; border-radius: 8px; }
.urgent-service-search-list li:hover { background: var(--site-primary-xlight, #eae0f8); color: #5d3f8f; }
.urgent-date-search-wrap { position: relative; }
.urgent-date-search-list { position: absolute; top: calc(100% + 4px); left: 0; right: 0; z-index: 100; max-height: 240px; overflow-y: auto; background: #fff; border: 1px solid #e6ddf5; border-radius: 12px; box-shadow: 0 8px 24px rgba(123,94,167,0.16); list-style: none; margin: 0; padding: 6px; }
.urgent-date-search-list li { padding: 10px 12px; cursor: pointer; font-size: 14px; border-radius: 8px; }
.urgent-date-search-list li:hover { background: var(--site-primary-xlight, #eae0f8); color: #5d3f8f; }
.urgent-step[data-step="3"] .urgent-date-time-row { display: flex; align-items: flex-start; gap: 12px; }
.urgent-step[data-step="3"] .urgent-date-wrap { flex: 1; position: relative; }
.urgent-step[data-step="3"] .urgent-date-wrap .form-group { margin-bottom: 0; }
.urgent-step[data-step="3"] .urgent-date-wrap .form-group .control-label { margin-bottom: 6px !important; line-height: 1.2; display: block; }
.urgent-step[data-step="3"] .urgent-date-wrap .form-group input[type="hidden"] { position: absolute; width: 0; height: 0; margin: 0; padding: 0; border: none; overflow: hidden; clip: rect(0,0,0,0); }
.urgent-step[data-step="3"] .urgent-date-wrap .form-group .help-block { margin: 0; padding: 0; min-height: 0; line-height: 0; font-size: 0; overflow: hidden; display: block; }
.urgent-step[data-step="3"] .urgent-date-wrap .urgent-date-display-inner { margin-top: 0; padding-top: 0; }
.urgent-step[data-step="3"] .urgent-time-wrap .form-group { margin-bottom: 0; }
.urgent-step[data-step="3"] .urgent-time-wrap .form-group .control-label { margin-bottom: 6px !important; line-height: 1.2; display: block; }
.urgent-step[data-step="3"] .urgent-time-wrap .form-group .help-block { margin: 0; padding: 0; min-height: 0; line-height: 0; font-size: 0; overflow: hidden; display: block; }
.urgent-booking-wrap .urgent-budget-input-wrap { max-width: 150px; }
.urgent-booking-wrap .urgent-budget-input-wrap .input-group .form-control { border-radius: 10px 0 0 10px; }
.urgent-booking-wrap .urgent-budget-currency { padding: 8px 10px; font-size: 14px; color: #6f6788; min-width: 44px; text-align: center; border: 1px solid #ddd2ef; border-left: none; border-radius: 0 10px 10px 0; background: #faf8fd; }
.urgent-booking-wrap .urgent-phone-code-select { min-width: 90px; }
.urgent-step[data-step="3"] .urgent-date-display { height: 44px; padding: 10px 14px; font-size: 15px; border: 1px solid #ddd2ef; border-radius: 10px; background: #fff; display: flex; align-items: center; text-align: left; color: #2a2042; }
.urgent-step[data-step="3"] .urgent-date-picker-overlay { position: absolute; top: 0; left: 0; width: 100%; height: 100%; min-height: 44px; opacity: 0; cursor: pointer; font-size: 16px; }
.urgent-step[data-step="3"] .urgent-time-wrap { flex: 1; }
.urgent-step[data-step="3"] .urgent-time-wrap .form-control { height: 44px; min-height: 44px; text-align: left; }

/* Signup step 3: align checkbox "Ознайомтесь з Умовами використання" */
.signup-step4-agree {
  margin-bottom: 8px;
}
.site-signup .urgent-step[data-step="3"] .signup-step4-agree .form-group,
.urgent-booking-wrap .urgent-step[data-step="3"] .signup-step4-agree .form-group {
  margin-bottom: 0;
}
.site-signup .urgent-step[data-step="3"] .signup-step4-agree .checkbox,
.urgent-booking-wrap .urgent-step[data-step="3"] .signup-step4-agree .checkbox {
  display: flex;
  align-items: center;
  min-height: 28px;
  margin-top: 0;
}
.site-signup .urgent-step[data-step="3"] .signup-step4-agree .checkbox label,
.urgent-booking-wrap .urgent-step[data-step="3"] .signup-step4-agree .checkbox label {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin: 0;
  padding-left: 0;
  padding-top: 0;
  cursor: pointer;
  font-weight: normal;
  font-size: 15px;
  line-height: 1.45;
}
.site-signup .urgent-step[data-step="3"] .signup-step4-agree .checkbox input[type="checkbox"],
.urgent-booking-wrap .urgent-step[data-step="3"] .signup-step4-agree .checkbox input[type="checkbox"] {
  flex-shrink: 0;
  margin: 0;
  width: 22px;
  height: 22px;
  accent-color: var(--site-primary, #7b5ea7);
  cursor: pointer;
  vertical-align: middle;
}
.site-signup .urgent-step[data-step="3"] .signup-step4-terms,
.urgent-booking-wrap .urgent-step[data-step="3"] .signup-step4-terms {
  margin-top: 8px;
  margin-bottom: 0;
  padding-left: 34px;
}
