.modal {
  position: fixed; /* вместо absolute */
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: .3s ease;
  z-index: 9999; /* повысить */
}

.modal.is-open {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  z-index: 9999; /* убедиться */
}

.modal__overlay{
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.65);
  backdrop-filter: blur(6px);
}

.modal__box{
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) scale(.96);
  width: min(420px, 92vw);
  padding: 36px 32px 34px;
  border-radius: 28px;
  background: linear-gradient(
    180deg,
    rgba(255,255,255,.14),
    rgba(255,255,255,.04)
  );
  backdrop-filter: blur(18px) saturate(130%);
  box-shadow:
    0 40px 80px rgba(0,0,0,.6),
    inset 0 1px 0 rgba(255,255,255,.25);
  color: #fff;
  animation: modalIn .45s cubic-bezier(.2,.8,.2,1);
}

@keyframes modalIn{
  from{ opacity:0; transform:translate(-50%,-46%) scale(.92);}
  to{ opacity:1; transform:translate(-50%,-50%) scale(1);}
}

.modal__close{
  position: absolute;
  top: 16px;
  right: 18px;
  background: none;
  border: none;
  color: #fff;
  font-size: 28px;
  cursor: pointer;
  opacity: .6;
}
.modal__close:hover{ opacity: 1; }

.modal__title{
  margin: 0;
  font-size: 28px;
  font-weight: 700;
}

.modal__subtitle{
  margin: 10px 0 26px;
  color: rgba(255,255,255,.75);
}

.modal__form input{
  width: 100%;
  margin-bottom: 14px;
  padding: 14px 16px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(255,255,255,.06);
  color: #fff;
  font-size: 15px;
}

.modal__form input::placeholder{
  color: rgba(255,255,255,.5);
}

.modal__submit{
  width: 100%;
  margin-top: 12px;
  padding: 14px;
  border-radius: 999px;
  border: none;
  font-weight: 700;
  text-transform: uppercase;
  background: linear-gradient(135deg,#7c6cff,#4ade80);
  color: #000;
  cursor: pointer;
}

.modal__note{
  margin-top: 12px;
  font-size: 12px;
  opacity: .6;
  text-align: center;
}

.modal__success{
  display: none;
  text-align: center;
}

.modal__success .check{
  font-size: 48px;
  margin-bottom: 10px;
}

/* ===== DIVIDER ===== */
.modal__divider{
  position: relative;
  margin: 26px 0 22px;
  text-align: center;
}

.modal__divider::before{
  content:'';
  position:absolute;
  left:0; right:0;
  top:50%;
  height:1px;
  background: linear-gradient(
    90deg,
    transparent,
    rgba(255,255,255,.25),
    transparent
  );
}

.modal__divider span{
  position: relative;
  z-index: 1;
  padding: 0 14px;
  font-size: 13px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: rgba(255,255,255,.55);
  background: rgba(15,15,20,.85);
  backdrop-filter: blur(6px);
  border-radius: 999px;
}

/* ===== DIRECT CONTACT ===== */
.modal__direct{
  display: flex;
  align-items: center;
  gap: 16px;

  padding: 16px 18px;
  border-radius: 18px;

  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  backdrop-filter: blur(10px) saturate(120%);

  transition: background .3s ease;
}

.modal__direct-icon{
  width: 42px;
  height: 42px;
  border-radius: 14px;

  display: grid;
  place-items: center;

  background: rgba(255,255,255,.08);
  color: rgba(255,255,255,.9);
}

.modal__direct-icon svg{
  width: 18px;
  height: 18px;
}

.modal__direct-text{
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.modal__direct-label{
  font-size: 13px;
  color: rgba(255,255,255,.55);
}

.modal__direct-phone{
  font-size: 18px;
  font-weight: 600;
  letter-spacing: .02em;
  color: #fff;
  text-decoration: none;
}

