.vv-modal-open { overflow: hidden; }
.vv-renovacao-modal[hidden] { display: none !important; }
.vv-renovacao-modal { position: fixed; inset: 0; z-index: 999999; display: grid; place-items: center; padding: 18px; font-family: Arial, Helvetica, sans-serif; }
.vv-renovacao-modal__backdrop { position: absolute; inset: 0; background: rgba(8, 28, 33, .76); backdrop-filter: blur(4px); }
.vv-renovacao-modal__dialog { position: relative; width: min(100%, 520px); max-height: calc(100vh - 36px); overflow: auto; padding: 34px; border-radius: 22px; background: #fff; color: #1e2933; box-shadow: 0 24px 80px rgba(0,0,0,.28); }
.vv-renovacao-modal__close { position: absolute; top: 12px; right: 15px; width: 40px; height: 40px; border: 0; border-radius: 50%; background: #eef5f5; color: #174f5b; font-size: 27px; line-height: 1; cursor: pointer; }
.vv-renovacao-modal__eyebrow { display: block; margin-bottom: 8px; color: #174f5b; font-size: 12px; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; }
.vv-renovacao-modal h2 { margin: 0 34px 10px 0; color: #103a43; font-size: 28px; line-height: 1.15; }
.vv-renovacao-modal p { margin: 0 0 22px; color: #61707b; line-height: 1.55; }
.vv-renovacao-modal__form { display: grid; gap: 15px; }
.vv-renovacao-modal__form label { display: grid; gap: 7px; color: #25343d; font-size: 14px; font-weight: 750; }
.vv-renovacao-modal__form input { width: 100%; min-height: 50px; padding: 11px 13px; border: 1px solid #cfdcdf; border-radius: 10px; background: #fff; color: #1e2933; font: inherit; }
.vv-renovacao-modal__form input:focus { outline: 3px solid rgba(23,79,91,.14); border-color: #174f5b; }
.vv-renovacao-modal__honeypot { position: absolute !important; left: -9999px !important; opacity: 0 !important; }
.vv-renovacao-modal__error { padding: 11px 13px; border-radius: 9px; background: #fff0f0; color: #9d2020; font-size: 14px; }
.vv-renovacao-modal__submit { min-height: 55px; border: 0; border-radius: 11px; background: #174f5b; color: #fff; font-size: 16px; font-weight: 800; cursor: pointer; box-shadow: 0 12px 24px rgba(23,79,91,.22); }
.vv-renovacao-modal__submit:hover { background: #103a43; }
.vv-renovacao-modal__submit:disabled { opacity: .65; cursor: wait; }
.vv-renovacao-modal__form small { color: #71808a; text-align: center; }
.vv-confirmation { width: min(100%, 720px); margin: 40px auto; padding: 45px 32px; border: 1px solid #dce5e7; border-radius: 22px; background: #fff; color: #1e2933; text-align: center; box-shadow: 0 18px 50px rgba(20,48,55,.10); font-family: Arial, Helvetica, sans-serif; }
.vv-confirmation__spinner { width: 48px; height: 48px; margin: 0 auto 22px; border: 4px solid #dce8e9; border-top-color: #174f5b; border-radius: 50%; animation: vv-spin .8s linear infinite; }
.vv-confirmation__spinner[hidden] { display: none; }
.vv-confirmation h2 { margin: 0 0 12px; color: #103a43; font-size: clamp(28px, 5vw, 40px); }
.vv-confirmation p { margin: 0 auto 24px; max-width: 590px; color: #61707b; font-size: 17px; line-height: 1.6; }
.vv-confirmation__actions { display: grid; justify-items: center; gap: 13px; }
.vv-confirmation__button { display: inline-flex; min-height: 56px; align-items: center; justify-content: center; padding: 14px 24px; border-radius: 11px; background: #174f5b; color: #fff !important; font-weight: 800; text-decoration: none !important; }
.vv-confirmation__receipt { color: #174f5b !important; font-weight: 700; }
.vv-confirmation.is-success { border-top: 5px solid #187e59; }
@keyframes vv-spin { to { transform: rotate(360deg); } }
@media (max-width: 600px) {
  .vv-renovacao-modal { padding: 10px; }
  .vv-renovacao-modal__dialog { padding: 28px 20px 22px; border-radius: 17px; }
  .vv-renovacao-modal h2 { font-size: 24px; }
  .vv-confirmation { margin: 20px auto; padding: 34px 20px; border-radius: 17px; }
  .vv-confirmation__button { width: 100%; }
}
