/* ================== MODAL BASE ================== */

.modal-container {
  display: none;
  opacity: 0;
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -48%);
  width: 90%;
  max-width: 420px;
  background: #fff;
  padding: 28px;
  border-radius: 10px;
  border: 1px solid #ccc;
  z-index: 1001;
  text-align: left;
  transition: opacity .25s ease, transform .25s ease;
}

.modal-visible {
  display: block !important;
}

.modal-active {
  opacity: 1 !important;
  transform: translate(-50%, -50%) !important;
}

/* ================== OVERLAY ================== */

#overlay {
  display: none;
  opacity: 0;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.55);
  z-index: 1000;
  transition: opacity .25s ease;
}

.overlay-active {
  display: block !important;
  opacity: 1 !important;
}

/* ================== CLOSE BUTTON ================== */

.modal-close {
  position: absolute;
  top: 12px;
  right: 15px;
  font-size: 28px;
  background: none;
  border: none;
  cursor: pointer;
  color: #444;
}

/* ================== TITLES ================== */

.modal-container h2 {
  text-align: center;
  margin-bottom: 10px;
  font-size: 22px;
  font-weight: 700;
}

.modal-container p {
  text-align: center;
  color: #555;
  margin-bottom: 20px;
  font-size: 14px;
}

/* ================== INPUT CONTAINER ================== */

.input-container {
  position: relative;
  margin-top: 28px;
}

.input-container input {
  width: 100%;
  padding: 14px 12px 10px;
  border: 1.8px solid #ccc;
  border-radius: 8px;
  font-size: 15px;
  outline: none;
  background: white;
  transition: border-color .25s ease;
}

.input-container input:focus {
  border-color: #0fd46c;
}

/* ================== FLOAT LABEL ================== */

.input-container label {
  position: absolute;
  left: 12px;
  top: 50%;
  transform: translateY(-50%);
  color: #777;
  background: white;
  padding: 0 6px;
  font-size: 15px;
  pointer-events: none;
  transition: .25s ease;
}

.input-container input:focus + label, .input-container input:not(:placeholder-shown) + label {
  top: -7px;
  font-size: 12px;
  color: #0fd46c;
}

/* ================== SUCCESS CHECK ================== */

.success-check {
  position: absolute;
  right: 10px;
  top: 12px;
  font-size: 16px;
  color: #0fd46c;
  display: none;
}

.success-check.show {
  display: block;
}

/* ================== ERROR STYLING ================== */

.input-error {
  border-color: #e63946 !important;
}

.input-success {
  border-color: #0fd46c !important;
}

.error-msg {
  color: #e63946;
  font-size: 12px;
  margin-top: 4px;
  display: none;
  opacity: 0;
  transition: opacity .25s ease;
}

.error-msg.show {
  display: block;
  opacity: 1;
}

/* Shake animation */

@keyframes shake {
  0% {
    transform: translateX(0);
  }
  25% {
    transform: translateX(-4px);
  }
  50% {
    transform: translateX(4px);
  }
  75% {
    transform: translateX(-4px);
  }
  100% {
    transform: translateX(0);
  }
}

.shake {
  animation: shake .3s ease;
}

/* ================== SUBMIT BUTTON ================== */

.submit-btn {
  margin-top: 25px;
  width: 100%;
  background: #0fd46c;
  border: none;
  padding: 14px;
  color: white;
  font-size: 16px;
  border-radius: 8px;
  cursor: pointer;
  font-weight: 600;
  transition: .25s ease;
}

.submit-btn:hover {
  opacity: .9;
}

/* ================== FOOTNOTE ================== */

.modal-footnote {
  margin-top: 15px;
  font-size: 12px;
  color: #777;
}

.modal-footnote a {
  color: #0fd46c;
  text-decoration: none;
}

/* Overlay fade */

#overlay {
  display: none;
  opacity: 0;
  transition: opacity 0.25s ease;
}

/* Modal fade */

#consultationModal {
  display: none;
  opacity: 0;
  transform: translate(-50%, -48%);
  transition: opacity 0.25s ease, transform 0.25s ease;
}

.modal-visible {
  display: block !important;
}

.modal-active {
  opacity: 1 !important;
  transform: translate(-50%, -50%) !important;
}

.overlay-active {
  display: block !important;
  opacity: 1 !important;
}

/* Modal content alignment */

#consultationModal {
  text-align: left;
  padding: 32px 28px;
  border-radius: 10px;
  max-width: 440px;
}

/* Fix close button */

#consultationModal button[onclick="hideModal()"] {
  top: 12px;
  right: 14px;
  font-size: 26px;
  color: #333;
}

/* Title */

#consultationModal h2 {
  text-align: center;
  margin-bottom: 10px;
  font-size: 24px;
  font-weight: 700;
}

/* Description */

#consultationModal p {
  text-align: center;
  line-height: 1.45;
}

/* INPUT CONTAINER */

.input-container {
  position: relative;
  margin-top: 25px;
}

.input-container input {
  width: 100%;
  padding: 12px 10px;
  font-size: 15px;
  border: 1.6px solid #ccc;
  border-radius: 6px;
  outline: none;
  transition: 0.25s ease;
}

.input-container input:focus {
  border-color: #28a745;
}

/* FLOATING LABEL */

.input-container label {
  position: absolute;
  left: 12px;
  top: 50%;
  transform: translateY(-50%);
  color: #777;
  font-size: 14px;
  pointer-events: none;
  transition: 0.25s ease;
  background: white;
  padding: 0 5px;
}

/* Float label when input has value or focus */

.input-container input:focus + label, .input-container input:not(:placeholder-shown) + label {
  top: -8px;
  font-size: 12px;
  color: #28a745;
}

/* Fix schedule button */

#consultationModal button[type="submit"] {
  background: #28a745 !important;
  font-weight: 600;
  border-radius: 6px !important;
  margin-top: 25px;
}

/* Disclaimer spacing */

#consultationModal form p {
  margin-top: 15px;
  font-size: 11.5px;
  color: #666 !important;
}

/* Mobile spacing fix */

@media (max-width: 480px) {
  #consultationModal {
    padding: 25px 20px;
  }
}

/* INPUT CONTAINER */

.input-container {
  position: relative;
  margin-top: 28px;
}

/* Input styling */

.input-container input {
  width: 100%;
  padding: 14px 12px 10px;
  font-size: 15px;
  border: 1.8px solid #cfcfcf;
  border-radius: 8px;
  outline: none;
  transition: all 0.25s ease;
  background: white;
}

/* Focus border color */

.input-container input:focus {
  border-color: #28a745;
}

/* LABEL — cut-border style */

.input-container label {
  position: absolute;
  left: 12px;
  top: 0;
  transform: translateY(-50%);
  font-size: 13px;
  color: #28a745;
  background: white;
  padding: 0 6px;
  pointer-events: none;
  transition: 0.25s ease;
}

/* When input is empty (no focus), label should sit ON the border */

.input-container input:placeholder-shown + label {
  top: 50%;
  transform: translateY(-50%);
  font-size: 15px;
  color: #777;
  background: transparent;
  padding: 0;
}

/* When focused OR typed → float with white background cutting border */

.input-container input:focus + label, .input-container input:not(:placeholder-shown) + label {
  top: 0;
  transform: translateY(-50%);
  font-size: 13px;
  color: #28a745;
  background: white;
  padding: 0 6px;
}

