/* Nemea Vision — Contact Wizard V23 */
.nv-contact-section {
    position: relative;
    min-height: 100vh;
    padding: clamp(96px, 10vw, 150px) clamp(18px, 5vw, 72px);
    color: #fff;
    background:
        radial-gradient(circle at 18% 80%, rgba(255, 183, 82, .13), transparent 32%),
        radial-gradient(circle at 78% 20%, rgba(95, 33, 180, .22), transparent 34%),
        linear-gradient(180deg, #050505 0%, #090807 100%);
    overflow: hidden;
    isolation: isolate;
}

.nv-contact-section--page {
    min-height: 100vh;
}

.nv-contact-section__bg {
    position: absolute;
    inset: 0;
    z-index: -1;
    pointer-events: none;
    opacity: .82;
}

.nv-contact-section__bg span {
    position: absolute;
    border: 1px solid rgba(255, 183, 82, .16);
    border-radius: 999px;
    filter: blur(.2px);
}

.nv-contact-section__bg span:first-child {
    width: 42vw;
    height: 42vw;
    left: -12vw;
    bottom: -16vw;
    border-color: rgba(95, 33, 180, .25);
}

.nv-contact-section__bg span:last-child {
    width: 54vw;
    height: 54vw;
    right: -16vw;
    top: -18vw;
}

.nv-contact-shell {
    width: min(1280px, 100%);
    margin: 0 auto;
    display: grid;
    grid-template-columns: minmax(320px, .9fr) minmax(360px, 640px);
    gap: clamp(38px, 6vw, 96px);
    align-items: start;
}

.nv-contact-copy {
    position: sticky;
    top: 88px;
    max-width: 680px;
}

.nv-contact-kicker,
.nv-contact-step__kicker {
    margin: 0 0 16px;
    color: #ffb752;
    font-size: 12px;
    font-weight: 950;
    letter-spacing: .18em;
    text-transform: uppercase;
}

.nv-contact-copy h2 {
    margin: 0;
    max-width: 720px;
    font-size: clamp(58px, 7.4vw, 128px);
    line-height: .87;
    letter-spacing: -.075em;
    text-transform: none;
    text-wrap: balance;
}

.nv-contact-lead {
    max-width: 520px;
    margin: 24px 0 0;
    color: rgba(255, 255, 255, .82);
    font-size: clamp(16px, 1.4vw, 20px);
    line-height: 1.5;
}

.nv-contact-card {
    position: relative;
    border: 1px solid rgba(255, 255, 255, .14);
    border-radius: 28px;
    padding: clamp(14px, 2vw, 22px);
    background:
        linear-gradient(180deg, rgba(255, 255, 255, .08), rgba(255, 255, 255, .025)),
        rgba(10, 9, 8, .88);
    box-shadow: 0 22px 90px rgba(0, 0, 0, .48);
    backdrop-filter: blur(18px);
}

.nv-contact-wizard {
    display: grid;
    gap: 18px;
}

.nv-contact-wizard__steps {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.nv-contact-wizard__steps span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 34px;
    padding: 0 14px;
    border-radius: 999px;
    border: 1px solid rgba(255,255,255,.16);
    color: rgba(255,255,255,.68);
    background: rgba(255,255,255,.045);
    font-size: 11px;
    font-weight: 950;
    letter-spacing: .13em;
    text-transform: uppercase;
}

.nv-contact-wizard__steps span.is-active {
    color: #050505;
    border-color: #ffb752;
    background: #ffb752;
}

.nv-contact-wizard__steps span.is-done {
    color: #ffb752;
    border-color: rgba(255,183,82,.36);
}

.nv-contact-step {
    border: 1px solid rgba(255,255,255,.1);
    border-radius: 22px;
    padding: clamp(18px, 2.6vw, 28px);
    background: rgba(0,0,0,.22);
}

.nv-contact-step[hidden] {
    display: none !important;
}

.nv-contact-step h3 {
    margin: 0;
    font-size: clamp(30px, 3.6vw, 56px);
    line-height: .95;
    letter-spacing: -.055em;
}

.nv-contact-step__text {
    margin: 10px 0 18px;
    max-width: 580px;
    color: rgba(255,255,255,.72);
    line-height: 1.45;
}

.nv-contact-field,
.nv-contact-check {
    display: grid;
    gap: 8px;
    margin: 0 0 14px;
}

.nv-contact-field span,
.nv-contact-check span {
    color: rgba(255,255,255,.82);
    font-size: 12px;
    font-weight: 950;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.nv-contact-check {
    grid-template-columns: 20px 1fr;
    align-items: start;
}

.nv-contact-check span {
    text-transform: none;
    letter-spacing: .01em;
    line-height: 1.35;
    font-size: 14px;
}

.nv-contact-field input,
.nv-contact-field select {
    width: 100%;
    min-height: 50px;
    border: 1px solid rgba(255,183,82,.42);
    border-radius: 14px;
    padding: 0 14px;
    color: #fff;
    background: #10100f;
    outline: none;
    font-size: 15px;
    font-weight: 780;
}

.nv-contact-field input:focus,
.nv-contact-field select:focus {
    border-color: #ffb752;
    box-shadow: 0 0 0 4px rgba(255,183,82,.14);
}

.nv-contact-check input {
    width: 17px;
    height: 17px;
    margin-top: 1px;
    accent-color: #ffb752;
}

.nv-contact-privacy {
    margin: 12px 0 16px;
    border: 1px solid rgba(255,255,255,.12);
    border-radius: 14px;
    padding: 12px 14px;
    background: rgba(255,255,255,.035);
}

.nv-contact-privacy summary {
    cursor: pointer;
    color: rgba(255,255,255,.9);
    font-size: 12px;
    font-weight: 950;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.nv-contact-privacy p {
    margin: 10px 0 0;
    color: rgba(255,255,255,.68);
    font-size: 13px;
    line-height: 1.5;
}

.nv-contact-privacy a {
    color: #ffb752;
}

.nv-contact-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 48px;
    border: 0;
    border-radius: 999px;
    padding: 0 24px;
    color: #050505;
    background: #ffb752;
    font-size: 14px;
    font-weight: 950;
    cursor: pointer;
    box-shadow: 0 12px 36px rgba(255,183,82,.18);
    transition: transform .18s ease, opacity .18s ease, background .18s ease;
}

.nv-contact-button:hover {
    transform: translateY(-1px);
}

.nv-contact-button:disabled {
    opacity: .55;
    cursor: wait;
}

.nv-contact-button--ghost {
    color: #fff;
    background: rgba(255,255,255,.08);
    border: 1px solid rgba(255,255,255,.14);
    box-shadow: none;
}

.nv-contact-actions {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}

.nv-contact-error,
.nv-contact-success,
.nv-contact-budget-summary {
    margin: 12px 0;
    padding: 12px 14px;
    border-radius: 14px;
    font-size: 13px;
    font-weight: 800;
    line-height: 1.4;
}

.nv-contact-error {
    color: #ffcf8b;
    background: rgba(255, 183, 82, .08);
    border: 1px solid rgba(255, 183, 82, .28);
}

.nv-contact-success,
.nv-contact-budget-summary {
    color: #dfffe9;
    background: rgba(95, 255, 158, .08);
    border: 1px solid rgba(95, 255, 158, .25);
}

.nv-contact-booking__embed {
    position: relative;
    overflow: hidden;
    min-height: 820px;
    margin: 14px 0 18px;
    border-radius: 22px;
    border: 1px solid rgba(255,255,255,.14);
    background: #fff;
}

.nv-contact-booking__iframe {
    display: block;
    width: 100%;
    min-width: 320px;
    height: 820px;
    border: 0;
    background: #fff;
}

@media (max-width: 980px) {
    .nv-contact-shell {
        grid-template-columns: 1fr;
    }

    .nv-contact-copy {
        position: relative;
        top: auto;
    }

    .nv-contact-copy h2 {
        max-width: 720px;
    }
}

@media (max-width: 640px) {
    .nv-contact-section {
        padding: 86px 14px 72px;
    }

    .nv-contact-card {
        border-radius: 20px;
        padding: 10px;
    }

    .nv-contact-step {
        border-radius: 18px;
        padding: 16px;
    }

    .nv-contact-copy h2 {
        font-size: clamp(48px, 15vw, 76px);
    }

    .nv-contact-booking__embed,
    .nv-contact-booking__iframe {
        min-height: 700px;
        height: 700px !important;
    }

    .nv-contact-wizard__steps span {
        min-height: 30px;
        padding: 0 10px;
        font-size: 9px;
    }
}


/* V23 — CTA visibile anche con embed lungo */
.nv-contact-booking-toolbar {
    display: flex;
    justify-content: flex-end;
    gap: 10px;
    margin: 12px 0;
}

.nv-contact-booking-toolbar--bottom {
    position: sticky;
    bottom: 14px;
    z-index: 4;
    padding: 10px;
    border-radius: 999px;
    background: rgba(5,5,5,.72);
    backdrop-filter: blur(12px);
    border: 1px solid rgba(255,255,255,.10);
}

.nv-contact-newsletter.is-complete .nv-contact-newsletter__body {
    display: none;
}

.nv-contact-final-message {
    margin-top: 14px;
    padding: 18px 18px;
    border-radius: 18px;
    color: #eafff0;
    background: rgba(95,255,158,.09);
    border: 1px solid rgba(95,255,158,.28);
    font-size: 14px;
    line-height: 1.45;
}

.nv-contact-final-message strong {
    display: block;
    margin-bottom: 4px;
    color: #ffffff;
    font-size: 18px;
    letter-spacing: -.02em;
}

/* V23 — Flip card mail */
.nv-contact-mail-card {
    margin-top: 18px;
    min-height: 150px;
    perspective: 1100px;
    cursor: pointer;
    outline: none;
}

.nv-contact-mail-card__inner {
    position: relative;
    min-height: 150px;
    transform-style: preserve-3d;
    transition: transform .58s cubic-bezier(.2,.8,.2,1);
}

.nv-contact-mail-card:hover .nv-contact-mail-card__inner,
.nv-contact-mail-card:focus-visible .nv-contact-mail-card__inner,
.nv-contact-mail-card.is-flipped .nv-contact-mail-card__inner {
    transform: rotateY(180deg);
}

.nv-contact-mail-card__face {
    position: absolute;
    inset: 0;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 8px;
    padding: 20px;
    border: 1px solid rgba(255,255,255,.14);
    border-radius: 22px;
    backface-visibility: hidden;
    background:
        radial-gradient(circle at 18% 16%, rgba(255,183,82,.18), transparent 36%),
        linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.025)),
        rgba(9,9,8,.92);
}

.nv-contact-mail-card__face--back {
    transform: rotateY(180deg);
    border-color: rgba(255,183,82,.35);
}

.nv-contact-mail-card__kicker {
    margin: 0;
    color: #ffb752;
    font-size: 11px;
    font-weight: 950;
    letter-spacing: .16em;
    text-transform: uppercase;
}

.nv-contact-mail-card h3 {
    margin: 0;
    color: #fff;
    font-size: clamp(26px, 3vw, 40px);
    letter-spacing: -.05em;
    line-height: .96;
}

.nv-contact-mail-card p {
    margin: 0;
    color: rgba(255,255,255,.72);
    line-height: 1.4;
}

.nv-contact-mail-card a {
    color: #fff;
    font-size: clamp(18px, 2vw, 26px);
    font-weight: 950;
    letter-spacing: -.03em;
    text-decoration: none;
    word-break: break-word;
}

.nv-contact-mail-card a:hover {
    color: #ffb752;
}

@media (max-width: 640px) {
    .nv-contact-booking-toolbar {
        justify-content: stretch;
    }

    .nv-contact-booking-toolbar .nv-contact-button {
        width: 100%;
    }

    .nv-contact-booking-toolbar--bottom {
        border-radius: 18px;
    }

    .nv-contact-mail-card,
    .nv-contact-mail-card__inner {
        min-height: 172px;
    }
}
