/* =========================================================
   MidasFX — Call Request Form
   ========================================================= */

/* --- Brand palette -------------------------------------- */
:root {
  --bg-white:         #fff;
  --bg-logo:          #f67e07;
  --bg-primary:       #0341c7;
  --bg-secondary:     #f67e07;

  --text-white:       #fff;
  --text-primary:     #0341c7;
  --text-secondary:   #f67e07;
  --text-link:        #4989d6;
  --text-link-hover:  #81bafe;
  --text-descr:       #3879c8;
  --text-descr-footer:#aeb8c4;
  --text-descr-form:  #3dfff5;

  --btn-primary:      #f67e07;
  --btn-primary-hover:#fe9227;
}

/* --- Component tokens (mapped to brand palette) --------- */
:root {
  --mfx-gold:       var(--bg-secondary);      /* #f67e07 orange */
  --mfx-gold-light: var(--btn-primary-hover); /* #fe9227 */
  --mfx-gold-dark:  #d46300;                  /* darker orange */
  --mfx-bg:         var(--bg-white);          /* #fff */
  --mfx-surface:    #f0f5ff;                  /* light blue tint */
  --mfx-surface2:   #e6edf9;
  --mfx-border:     #c5d3ee;
  --mfx-text:       var(--text-primary);      /* #0341c7 */
  --mfx-muted:      var(--text-descr);        /* #3879c8 */
  --mfx-error:      #d63b3b;
  --mfx-success:    #1a9e5c;
  --mfx-radius:     10px;
  --mfx-transition: 0.22s ease;
}




/* --- Overlay / Modal ------------------------------------ */
.mfx-overlay {
  position: fixed;
  inset: 0;
  z-index: 9999;
  background: rgba(3, 65, 199, 0.55);
  backdrop-filter: blur(4px);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 12px;
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--mfx-transition);
}
.mfx-overlay.is-open {
  opacity: 1;
  pointer-events: all;
}

/* --- Modal box ------------------------------------------ */
.mfx-modal {
  background: var(--mfx-surface);
  border: 1px solid var(--mfx-border);
  border-radius: var(--mfx-radius);
  width: 100%;
  max-width: 440px;
  max-height: calc(100vh - 24px);
  overflow-y: auto;
  padding: 28px 24px 24px;
  position: relative;
  box-shadow: 0 24px 64px rgba(3, 65, 199, 0.12),
              0 0 0 1px rgba(246, 126, 7, 0.18);
  transform: translateY(18px) scale(0.97);
  transition: transform var(--mfx-transition), opacity var(--mfx-transition);
}
.mfx-overlay.is-open .mfx-modal {
  transform: translateY(0) scale(1);
}

/* gold top accent line */
.mfx-modal::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  border-radius: var(--mfx-radius) var(--mfx-radius) 0 0;
  background: linear-gradient(90deg, var(--mfx-gold-dark), var(--mfx-gold-light), var(--mfx-gold-dark));
}

/* --- Close button --------------------------------------- */
.mfx-close {
  position: absolute;
  top: 12px; right: 12px;
  width: 28px; height: 28px;
  border: none;
  background: transparent;
  color: var(--mfx-muted);
  font-size: 18px;
  line-height: 1;
  cursor: pointer;
  border-radius: 6px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: color var(--mfx-transition), background var(--mfx-transition);
}
.mfx-close:hover {
  color: var(--mfx-text);
  background: var(--mfx-border);
}

/* --- Header --------------------------------------------- */
.mfx-header {
  margin-bottom: 18px;
}
.mfx-header__icon {
  width: 34px; height: 34px;
  margin-bottom: 10px;
  color: var(--mfx-gold);
}
.mfx-header__title {
  font-family: inherit;
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--mfx-text);
  margin: 0 0 4px;
  letter-spacing: -0.01em;
}
.mfx-header__sub {
  font-size: 0.75rem;
  color: var(--mfx-muted);
  margin: 0;
  line-height: 1.5;
}

/* --- Form layout ---------------------------------------- */
.mfx-form {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

/* --- Field ---------------------------------------------- */
.mfx-field {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.mfx-field__label {
  font-size: 0.6875rem;
  font-weight: 600;
  color: var(--mfx-muted);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.mfx-field__label span {
  color: var(--mfx-gold);
  margin-left: 2px;
}

/* --- Inputs --------------------------------------------- */
.mfx-input,
.mfx-select {
  width: 100%;
  background: var(--mfx-surface2);
  border: 1px solid var(--mfx-border);
  border-radius: 7px;
  color: var(--mfx-text);
  font-size: 0.8125rem;
  padding: 8px 11px;
  outline: none;
  transition: border-color var(--mfx-transition), box-shadow var(--mfx-transition);
  appearance: none;
  -webkit-appearance: none;
}
.mfx-input::placeholder {
  color: #a8bedd;
  opacity: 1;
}
.mfx-input:focus,
.mfx-select:focus {
  border-color: var(--mfx-gold);
  box-shadow: 0 0 0 3px rgba(246, 126, 7, 0.18);
}
.mfx-input.has-error,
.mfx-select.has-error {
  border-color: var(--mfx-error);
  box-shadow: 0 0 0 3px rgba(224, 85, 85, 0.12);
}

/* Select arrow */
.mfx-select-wrap {
  position: relative;
}
.mfx-select-wrap::after {
  content: '';
  position: absolute;
  right: 11px;
  top: 50%;
  transform: translateY(-50%);
  width: 0; height: 0;
  border-left: 4px solid transparent;
  border-right: 4px solid transparent;
  border-top: 5px solid var(--mfx-muted);
  pointer-events: none;
}
.mfx-select {
  padding-right: 30px;
  cursor: pointer;
}
.mfx-select option {
  background: var(--mfx-surface2);
  color: var(--mfx-text);
}

/* Phone row (flag + input) */
.mfx-phone-row {
  display: flex;
  gap: 6px;
}
.mfx-phone-row .mfx-select-wrap {
  flex: 0 0 auto;
  width: 80px;
}
.mfx-phone-row .mfx-input {
  flex: 1;
}
/* Custom country code field (shown when "Other" selected) */
.mfx-custom-code {
  flex: 0 0 auto !important;
  width: 58px !important;
  padding-left: 8px;
  padding-right: 8px;
  text-align: center;
  letter-spacing: 0.04em;
  font-variant-numeric: tabular-nums;
}

/* --- Textarea ------------------------------------------- */
.mfx-textarea {
  resize: vertical;
  min-height: 64px;
  line-height: 1.5;
}

/* --- Account type tiles --------------------------------- */
.mfx-account-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 6px;
}
.mfx-account-tile {
  position: relative;
}
.mfx-account-tile input[type="checkbox"] {
  position: absolute;
  opacity: 0;
  width: 0; height: 0;
}
.mfx-account-tile__label {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 3px;
  padding: 9px 6px;
  background: var(--mfx-surface2);
  border: 1px solid var(--mfx-border);
  border-radius: 7px;
  cursor: pointer;
  transition: border-color var(--mfx-transition), background var(--mfx-transition), box-shadow var(--mfx-transition);
  text-align: center;
  user-select: none;
}
.mfx-account-tile__label:hover {
  border-color: rgba(246, 126, 7, 0.45);
  background: rgba(246, 126, 7, 0.07);
}
.mfx-account-tile input:checked + .mfx-account-tile__label {
  border-color: var(--mfx-gold);
  background: rgba(246, 126, 7, 0.1);
  box-shadow: 0 0 0 1px var(--mfx-gold);
}
.mfx-account-tile__type {
  font-size: 0.625rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--mfx-gold);
}
.mfx-account-tile__name {
  font-size: 0.8125rem;
  font-weight: 700;
  color: var(--mfx-text);
}
.mfx-account-tile__spread {
  font-size: 0.6875rem;
  color: var(--mfx-muted);
}

/* --- Time slots ----------------------------------------- */
.mfx-time-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 4px;
}
.mfx-time-tile {
  position: relative;
}
.mfx-time-tile input[type="radio"] {
  position: absolute;
  opacity: 0;
  width: 0; height: 0;
}
.mfx-time-tile__label {
  display: block;
  padding: 6px 3px;
  text-align: center;
  font-size: 0.6875rem;
  font-weight: 600;
  color: var(--mfx-muted);
  background: var(--mfx-surface2);
  border: 1px solid var(--mfx-border);
  border-radius: 7px;
  cursor: pointer;
  transition: all var(--mfx-transition);
}
.mfx-time-tile__label:hover {
  color: var(--mfx-text);
  border-color: rgba(246, 126, 7, 0.45);
}
.mfx-time-tile input:checked + .mfx-time-tile__label {
  color: var(--mfx-gold);
  border-color: var(--mfx-gold);
  background: rgba(246, 126, 7, 0.1);
  box-shadow: 0 0 0 1px var(--mfx-gold);
}

/* --- Error message -------------------------------------- */
.mfx-error-msg {
  font-size: 0.6875rem;
  color: var(--mfx-error);
  margin-top: 1px;
  display: none;
}
.mfx-error-msg.is-visible {
  display: block;
}

/* --- Submit button -------------------------------------- */
.mfx-submit {
  width: 100%;
  padding: 11px;
  background: linear-gradient(135deg, var(--mfx-gold-dark), var(--mfx-gold), var(--mfx-gold-dark));
  background-size: 200% 100%;
  background-position: 100% 0;
  border: none;
  border-radius: 7px;
  color: var(--text-white);
  font-size: 0.8125rem;
  font-weight: 700;
  letter-spacing: 0.03em;
  cursor: pointer;
  margin-top: 2px;
  transition: background-position 0.4s ease, transform var(--mfx-transition), box-shadow var(--mfx-transition);
}
.mfx-submit:hover:not(:disabled) {
  background-position: 0 0;
  box-shadow: 0 4px 20px rgba(246, 126, 7, 0.4);
  transform: translateY(-1px);
}
.mfx-submit:active:not(:disabled) {
  transform: translateY(0);
}
.mfx-submit:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}

/* Spinner inside button */
.mfx-submit__spinner {
  display: none;
  width: 16px; height: 16px;
  border: 2px solid rgba(0,0,0,0.3);
  border-top-color: var(--text-white);
  border-radius: 50%;
  animation: mfx-spin 0.7s linear infinite;
  margin: 0 auto;
}
.mfx-submit.is-loading .mfx-submit__text { display: none; }
.mfx-submit.is-loading .mfx-submit__spinner { display: block; }

@keyframes mfx-spin {
  to { transform: rotate(360deg); }
}

/* --- Success state -------------------------------------- */
.mfx-success {
  display: none;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: 8px 0 2px;
  gap: 10px;
}
.mfx-success.is-visible { display: flex; }
.mfx-success__icon {
  width: 44px; height: 44px;
  border-radius: 50%;
  background: rgba(76, 175, 129, 0.15);
  border: 2px solid var(--mfx-success);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--mfx-success);
  font-size: 20px;
}
.mfx-success__title {
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--mfx-text);
  margin: 0;
}
.mfx-success__text {
  font-size: 0.75rem;
  color: var(--mfx-muted);
  margin: 0;
  line-height: 1.6;
}

/* --- Trigger button (floating) -------------------------- */
.mfx-trigger {
  position: fixed;
  bottom: 28px;
  left: 28px;
  z-index: 9998;
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 11px 16px;
  background: linear-gradient(135deg, var(--mfx-gold-dark), var(--mfx-gold));
  border: none;
  border-radius: 40px;
  color: var(--text-white);
  font-size: 0.8125rem;
  font-weight: 700;
  cursor: pointer;
  box-shadow: 0 6px 24px rgba(246, 126, 7, 0.45);
  transition: transform var(--mfx-transition), box-shadow var(--mfx-transition);
  letter-spacing: 0.02em;
}
.mfx-trigger:hover {
  transform: translateY(-2px);
  box-shadow: 0 10px 32px rgba(246, 126, 7, 0.55);
}
.mfx-trigger svg {
  flex-shrink: 0;
}

/* Pulse ring */
.mfx-trigger::after {
  content: '';
  position: absolute;
  inset: -4px;
  border-radius: 44px;
  border: 2px solid var(--mfx-gold);
  opacity: 0;
  animation: mfx-pulse 2.4s ease-out infinite;
}
@keyframes mfx-pulse {
  0%   { opacity: 0.6; transform: scale(1); }
  100% { opacity: 0;   transform: scale(1.22); }
}

/* --- Inline embed variant ------------------------------- */
.mfx-form-inline {
  background: var(--mfx-surface);
  border: 1px solid var(--mfx-border);
  border-radius: var(--mfx-radius);
  padding: 24px 20px;
  max-width: 440px;
  position: relative;
  overflow: hidden;
}
.mfx-form-inline::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--mfx-gold-dark), var(--mfx-gold-light), var(--mfx-gold-dark));
}

/* --- Responsive ----------------------------------------- */
@media (max-width: 480px) {
  .mfx-modal {
    padding: 22px 16px 18px;
  }
  .mfx-account-grid {
    grid-template-columns: 1fr 1fr;
  }
  .mfx-time-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .mfx-trigger {
    bottom: 16px;
    left: 16px;
    padding: 10px 14px;
  }
}
