/* ============================================================
   popup.css
   Reusable popup/modal system + form styles inside popup
   Desktop 1440px  |  Mobile 370px (max-width: 767px)
   ============================================================ */

/* ═══════════════════════════════════════════════════════════════
   POPUP OVERLAY
   ═══════════════════════════════════════════════════════════════ */
.miauto-popup {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 9999;
  align-items: center;
  justify-content: center;
}

.miauto-popup.-visible {
  display: flex;
}

.miauto-popup__overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.6);
  backdrop-filter: blur(5px);
  -webkit-backdrop-filter: blur(5px);
}

.miauto-popup__content {
  position: relative;
  width: calc(480 / var(--vw-base) * 100vw);
  max-width: 90vw;
  max-height: 90vh;
  background-color: var(--color-white);
  border-radius: calc(15 / var(--vw-base) * 100vw);
  overflow: hidden;
  overflow-y: auto;
  z-index: 1;
}

[id^="popup-karta-"] .miauto-popup__content {
	width: calc(1242 / var(--vw-base) * 100vw);
}

.miauto-popup__close {
  position: absolute;
  top: calc(4 / var(--vw-base) * 100vw);
  right: calc(4 / var(--vw-base) * 100vw);
  width:  calc(36 / var(--vw-base) * 100vw);
  height: calc(36 / var(--vw-base) * 100vw);
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: var(--color-white);
  border: none;
  border-radius: 50%;
  font-size: calc(24 / var(--vw-base) * 100vw);
  color: var(--color-text);
  cursor: pointer;
  z-index: 2;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
  transition: background-color 0.2s;
}

.miauto-popup__close:hover {
  background-color: #f0f0f0;
}

.miauto-popup__body {
  padding: calc(36 / var(--vw-base) * 100vw) calc(30 / var(--vw-base) * 100vw) calc(30 / var(--vw-base) * 100vw);
}

/* Legacy content support (tables, iframes) */
.miauto-popup__body iframe {
  max-width: 100%;
  border: none;
}

.miauto-popup__body table {
  width: 100%;
  border-collapse: collapse;
}

.miauto-popup__body table td,
.miauto-popup__body table th {
  padding: calc(8 / var(--vw-base) * 100vw) calc(10 / var(--vw-base) * 100vw);
  border: 1px solid #e0e0e0;
  font-size: calc(13 / var(--vw-base) * 100vw);
  line-height: 1.4;
}

/* ═══════════════════════════════════════════════════════════════
   POPUP FORM
   ═══════════════════════════════════════════════════════════════ */
.popup-form {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: calc(10 / var(--vw-base) * 100vw);
  width: 100%;
}

.popup-form__title {
  font-size:   calc(22 / var(--vw-base) * 100vw);
  font-weight: 600;
  line-height: 1.2;
  color: var(--color-dark);
  text-align: center;
  margin: 0;
}

.popup-form__subtitle {
  font-size:   calc(14 / var(--vw-base) * 100vw);
  font-weight: 400;
  line-height: 1.43;
  color: var(--color-text);
  text-align: center;
  margin: 0 0 calc(10 / var(--vw-base) * 100vw);
}

/* ── CF7 form inside popup ─────────────────────────────────── */
.popup-form .wpcf7 {
  width: 100%;
}

.popup-form .wpcf7-form {
  display: flex;
  flex-direction: column;
  gap: calc(15 / var(--vw-base) * 100vw);
}

/* Fields wrapper */
.popup-form__fields {
  display: flex;
  flex-direction: column;
  gap: calc(10 / var(--vw-base) * 100vw);
}

.popup-form__fields .wpcf7-form-control-wrap {
  display: flex;
}

/* Inputs */
.popup-form .wpcf7-form-control:not([type="submit"]):not([type="hidden"]):not(span) {
	display: block;
  width: 100%;
  height: calc(50 / var(--vw-base) * 100vw);
  padding: 0 calc(20 / var(--vw-base) * 100vw);
  border: calc(1 / var(--vw-base) * 100vw) solid #e0e0e0;
  border-radius: calc(10 / var(--vw-base) * 100vw);
  font-family: 'Inter', sans-serif;
  font-size:   calc(14 / var(--vw-base) * 100vw);
  font-weight: 400;
  line-height: 1.43;
  color: var(--color-text);
  background-color: var(--color-white);
  box-sizing: border-box;
  transition: border-color 0.2s;
}

.popup-form .wpcf7-form-control:not([type="submit"]):not([type="hidden"]):not(span):focus {
  outline: none;
  border-color: var(--color-red);
}

.popup-form .wpcf7-form-control::placeholder {
  color: rgb(154, 154, 154);
}

/* Submit button */
.popup-form .wpcf7-submit {
  width: 100%;
  height: calc(50 / var(--vw-base) * 100vw);
  border: none;
  border-radius: calc(10 / var(--vw-base) * 100vw);
  font-family: 'Inter', sans-serif;
  font-size:   calc(14 / var(--vw-base) * 100vw);
  font-weight: 500;
  line-height: 1.43;
  color: var(--color-white);
  background-color: var(--color-red);
  cursor: pointer;
  transition: opacity 0.2s;
}

.popup-form .wpcf7-submit:hover {
  opacity: 0.9;
}

/* Privacy checkbox */
.popup-form__privacy {
  display: flex;
  align-items: flex-start;
  gap: calc(10 / var(--vw-base) * 100vw);
  cursor: pointer;
}

.popup-form__privacy input[type="checkbox"] {
  flex-shrink: 0;
  width:  calc(16 / var(--vw-base) * 100vw);
  height: calc(16 / var(--vw-base) * 100vw);
  margin-top: calc(2 / var(--vw-base) * 100vw);
  border: none;
  border-radius: calc(4 / var(--vw-base) * 100vw);
  accent-color: var(--color-red);
  cursor: pointer;
}

.popup-form__privacy span {
  font-size:   calc(12 / var(--vw-base) * 100vw);
  font-weight: 400;
  line-height: 1.33;
  color: var(--color-text);
}

.popup-form__privacy a {
  color: var(--color-red);
  text-decoration: underline;
}

/* CF7 response / validation */
.popup-form .wpcf7-response-output {
  margin: 0;
  padding: 0;
  border: none;
  font-size: calc(12 / var(--vw-base) * 100vw);
  text-align: center;
}

.popup-form .wpcf7-not-valid-tip {
  color: var(--color-red);
  font-size: calc(11 / var(--vw-base) * 100vw);
}

/* ── Fallback HTML form inside popup ───────────────────────── */
.popup-form__fallback {
  display: flex;
  flex-direction: column;
  gap: calc(10 / var(--vw-base) * 100vw);
  width: 100%;
}

.popup-form__fallback input[type="text"],
.popup-form__fallback input[type="tel"],
.popup-form__fallback input[type="email"],
.popup-form__fallback textarea {
  width: 100%;
  height: calc(50 / var(--vw-base) * 100vw);
  padding: 0 calc(20 / var(--vw-base) * 100vw);
  border: calc(1 / var(--vw-base) * 100vw) solid #e0e0e0;
  border-radius: calc(10 / var(--vw-base) * 100vw);
  font-family: 'Inter', sans-serif;
  font-size:   calc(14 / var(--vw-base) * 100vw);
  font-weight: 400;
  line-height: 1.43;
  color: var(--color-text);
  background-color: var(--color-white);
  box-sizing: border-box;
  transition: border-color 0.2s;
}

.popup-form__fallback input::placeholder,
.popup-form__fallback textarea::placeholder {
  color: rgb(154, 154, 154);
}

.popup-form__fallback input:focus,
.popup-form__fallback textarea:focus {
  outline: none;
  border-color: var(--color-red);
}

.popup-form__fallback textarea {
  height: calc(100 / var(--vw-base) * 100vw);
  padding: calc(15 / var(--vw-base) * 100vw) calc(20 / var(--vw-base) * 100vw);
  resize: vertical;
}

.popup-form__fallback button[type="submit"] {
  width: 100%;
  height: calc(50 / var(--vw-base) * 100vw);
  border: none;
  border-radius: calc(10 / var(--vw-base) * 100vw);
  font-family: 'Inter', sans-serif;
  font-size:   calc(14 / var(--vw-base) * 100vw);
  font-weight: 500;
  line-height: 1.43;
  color: var(--color-white);
  background-color: var(--color-red);
  cursor: pointer;
  transition: opacity 0.2s;
}

.popup-form__fallback button[type="submit"]:hover {
  opacity: 0.9;
}

/* ═══════════════════════════════════════════════════════════════
   MOBILE  (max-width: 767px)
   ═══════════════════════════════════════════════════════════════ */
@media (max-width: 767px) {

  .miauto-popup__content {
    width: auto;
    max-width: 95vw;
    max-height: 95vh;
    border-radius: calc(10 / var(--vw-base) * 100vw);
  }

  .miauto-popup__body {
    padding: calc(30 / var(--vw-base) * 100vw) calc(15 / var(--vw-base) * 100vw) calc(20 / var(--vw-base) * 100vw);
  }

  .miauto-popup__close {
    width:  calc(32 / var(--vw-base) * 100vw);
    height: calc(32 / var(--vw-base) * 100vw);
    font-size: calc(20 / var(--vw-base) * 100vw);
  }

  .popup-form {
    gap: calc(8 / var(--vw-base) * 100vw);
  }

  .popup-form__title {
    font-size: calc(18 / var(--vw-base) * 100vw);
  }

  .popup-form__subtitle {
    font-size: calc(13 / var(--vw-base) * 100vw);
  }

  .popup-form .wpcf7-form-control:not([type="submit"]):not([type="hidden"]):not(span) {
    height: calc(45 / var(--vw-base) * 100vw);
  }

  .popup-form .wpcf7-submit {
    height: calc(45 / var(--vw-base) * 100vw);
  }

  .popup-form__fallback input[type="text"],
  .popup-form__fallback input[type="tel"],
  .popup-form__fallback input[type="email"],
  .popup-form__fallback textarea {
    height: calc(45 / var(--vw-base) * 100vw);
  }

  .popup-form__fallback textarea {
    height: calc(80 / var(--vw-base) * 100vw);
  }

  .popup-form__fallback button[type="submit"] {
    height: calc(45 / var(--vw-base) * 100vw);
  }
}
