/* CTA modal (modern, mobile-first) */

.cta-modal{
  position:fixed;
  inset:0;
  display:none;
  align-items:flex-end;
  justify-content:center;
  padding:12px 12px calc(env(safe-area-inset-bottom) + 12px);
  background:rgba(0,0,0,.68);
  backdrop-filter: blur(10px);
  z-index:99999;
}

.cta-modal.show{display:flex}

.cta-modal-content{
  width:min(520px, 100%);
  border-radius:28px;
  background:linear-gradient(135deg, rgba(255,255,255,.08), rgba(255,255,255,.04));
  box-shadow:0 30px 90px rgba(0,0,0,.85), 0 0 0 1px rgba(255,255,255,.14);
  padding:18px 16px 16px;
  max-height:min(86vh, 720px);
  overflow:auto;
}

/* Desktop-like center alignment for wider screens */
@media (min-width:520px){
  .cta-modal{align-items:center}
  .cta-modal-content{padding:22px 20px}
}

.cta-close{
  float:right;
  width:42px;
  height:42px;
  border-radius:16px;
  display:grid;
  place-items:center;
  cursor:pointer;
  color:rgba(255,255,255,.78);
  background:rgba(255,255,255,.06);
  box-shadow:0 0 0 1px rgba(255,255,255,.10);
  user-select:none;
}

.cta-close:active{transform:translateY(1px)}

.cta-modal-content h3{
  margin:2px 0 6px;
  font-size:1.2rem;
  letter-spacing:-.01em;
}

.cta-modal-content p{
  color:rgba(255,255,255,.72);
  line-height:1.45;
  margin-bottom:14px;
}

.cta-modal-content label{
  display:block;
  font-size:.86rem;
  color:rgba(255,255,255,.76);
  margin:10px 0 6px;
}

.cta-modal-content input,
.cta-modal-content textarea{
  width:100%;
  padding:12px 12px;
  background:rgba(0,0,0,.35);
  border:1px solid rgba(255,255,255,.14);
  color:rgba(255,255,255,.95);
  border-radius:16px;
  outline:none;
}

.cta-modal-content textarea{resize:vertical;min-height:112px}

.cta-modal-content input:focus,
.cta-modal-content textarea:focus{
  box-shadow:0 0 0 4px rgba(5,234,118,.22);
  border-color:rgba(5,234,118,.55);
}

.cta-submit{
  width:100%;
  margin-top:14px;
  padding:13px 14px;
  border-radius:18px;
  border:0;
  background:linear-gradient(135deg, rgba(5,234,118,1), rgba(105,56,239,1));
  color:#fff;
  font-weight:800;
  letter-spacing:-.01em;
  cursor:pointer;
}

.cta-submit:active{transform:translateY(1px)}

.cta-status{
  margin-top:10px;
  font-size:.88rem;
  min-height:1.1em;
  color:rgba(255,255,255,.78);
}

.cta-fallback{
  text-align:center;
  margin-top:14px;
  font-size:.88rem;
  color:rgba(255,255,255,.60);
}

.cta-fallback a{
  text-decoration:none;
  color:rgba(5,234,118,.95);
}

.cta-fallback a:active{text-decoration:underline}
