/*! tailwindcss v4.1.14 | MIT License | https://tailwindcss.com */
@import url('https://fonts.googleapis.com/css2?family=Jost:wght@300;400;500&family=Urbanist:wght@300;400;700&display=swap');
@layer properties;
@layer theme, base, components, utilities;

@layer theme {

    :root,
    :host {
        --font-sans: ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji",
            "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
        --font-mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono",
            "Courier New", monospace;
        --color-red-600: oklch(57.7% 0.245 27.325);
        --color-blue-500: oklch(62.3% 0.214 259.815);
        --color-gray-200: oklch(92.8% 0.006 264.531);
        --color-white: #fff;
        --spacing: 0.25rem;
        --container-3xl: 48rem;
        --container-4xl: 56rem;
        --text-sm: 0.875rem;
        --text-sm--line-height: calc(1.25 / 0.875);
        --text-base: 1rem;
        --text-base--line-height: calc(1.5 / 1);
        --text-lg: 1.125rem;
        --text-lg--line-height: calc(1.75 / 1.125);
        --text-xl: 1.25rem;
        --text-xl--line-height: calc(1.75 / 1.25);
        --text-2xl: 1.5rem;
        --text-2xl--line-height: calc(2 / 1.5);
        --text-3xl: 1.875rem;
        --text-3xl--line-height: calc(2.25 / 1.875);
        --text-4xl: 2.25rem;
        --text-4xl--line-height: calc(2.5 / 2.25);
        --text-5xl: 3rem;
        --text-5xl--line-height: 1;
        --font-weight-light: 300;
        --font-weight-normal: 400;
        --font-weight-bold: 700;
        --leading-snug: 1.375;
        --ease-in-out: cubic-bezier(0.4, 0, 0.2, 1);
        --default-transition-duration: 150ms;
        --default-transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
        --default-font-family: var(--font-sans);
        --default-mono-font-family: var(--font-mono);
        --font-jost: "Jost", sans-serif;
        --font-urbanist: 'Urbanist', sans-serif;
        --color-nero: #0a0a0a;
        --color-rosso: #ff0000;
    }
}

@layer base {

    *,
    ::after,
    ::before,
    ::backdrop,
    ::file-selector-button {
        box-sizing: border-box;
        margin: 0;
        padding: 0;
        border: 0 solid;
    }

    html,
    :host {
        line-height: 1.5;
        -webkit-text-size-adjust: 100%;
        tab-size: 4;
        font-family: var(--default-font-family, ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji",
                "Segoe UI Symbol", "Noto Color Emoji");
        font-feature-settings: var(--default-font-feature-settings, normal);
        font-variation-settings: var(--default-font-variation-settings, normal);
        -webkit-tap-highlight-color: transparent;
    }

    hr {
        height: 0;
        color: inherit;
        border-top-width: 1px;
    }

    abbr:where([title]) {
        -webkit-text-decoration: underline dotted;
        text-decoration: underline dotted;
    }

    h1,
    h2,
    h3,
    h4,
    h5,
    h6 {
        font-size: inherit;
        font-weight: inherit;
    }

    a {
        color: inherit;
        -webkit-text-decoration: inherit;
        text-decoration: inherit;
    }

    b,
    strong {
        font-weight: bolder;
    }

    code,
    kbd,
    samp,
    pre {
        font-family: var(--default-mono-font-family, ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono",
                "Courier New", monospace);
        font-feature-settings: var(--default-mono-font-feature-settings, normal);
        font-variation-settings: var(--default-mono-font-variation-settings, normal);
        font-size: 1em;
    }

    small {
        font-size: 80%;
    }

    sub,
    sup {
        font-size: 75%;
        line-height: 0;
        position: relative;
        vertical-align: baseline;
    }

    sub {
        bottom: -0.25em;
    }

    sup {
        top: -0.5em;
    }

    table {
        text-indent: 0;
        border-color: inherit;
        border-collapse: collapse;
    }

    :-moz-focusring {
        outline: auto;
    }

    progress {
        vertical-align: baseline;
    }

    summary {
        display: list-item;
    }

    ol,
    ul,
    menu {
        list-style: none;
    }

    img,
    svg,
    video,
    canvas,
    audio,
    iframe,
    embed,
    object {
        display: block;
        vertical-align: middle;
    }

    img,
    video {
        max-width: 100%;
        height: auto;
    }

    button,
    input,
    select,
    optgroup,
    textarea,
    ::file-selector-button {
        font: inherit;
        font-feature-settings: inherit;
        font-variation-settings: inherit;
        letter-spacing: inherit;
        color: inherit;
        border-radius: 0;
        background-color: transparent;
        opacity: 1;
    }

    :where(select:is([multiple], [size])) optgroup {
        font-weight: bolder;
    }

    :where(select:is([multiple], [size])) optgroup option {
        padding-inline-start: 20px;
    }

    ::file-selector-button {
        margin-inline-end: 4px;
    }

    ::placeholder {
        opacity: 1;
    }

    @supports (not (-webkit-appearance: -apple-pay-button)) or (contain-intrinsic-size: 1px) {
        ::placeholder {
            color: currentcolor;

            @supports (color: color-mix(in lab, red, red)) {
                color: color-mix(in oklab, currentcolor 50%, transparent);
            }
        }
    }

    textarea {
        resize: vertical;
    }

    ::-webkit-search-decoration {
        -webkit-appearance: none;
    }

    ::-webkit-date-and-time-value {
        min-height: 1lh;
        text-align: inherit;
    }

    ::-webkit-datetime-edit {
        display: inline-flex;
    }

    ::-webkit-datetime-edit-fields-wrapper {
        padding: 0;
    }

    ::-webkit-datetime-edit,
    ::-webkit-datetime-edit-year-field,
    ::-webkit-datetime-edit-month-field,
    ::-webkit-datetime-edit-day-field,
    ::-webkit-datetime-edit-hour-field,
    ::-webkit-datetime-edit-minute-field,
    ::-webkit-datetime-edit-second-field,
    ::-webkit-datetime-edit-millisecond-field,
    ::-webkit-datetime-edit-meridiem-field {
        padding-block: 0;
    }

    ::-webkit-calendar-picker-indicator {
        line-height: 1;
    }

    :-moz-ui-invalid {
        box-shadow: none;
    }

    button,
    input:where([type="button"], [type="reset"], [type="submit"]),
    ::file-selector-button {
        appearance: button;
    }

    ::-webkit-inner-spin-button,
    ::-webkit-outer-spin-button {
        height: auto;
    }

    [hidden]:where(:not([hidden="until-found"])) {
        display: none !important;
    }
}

@layer utilities {
    .container {
        width: 100%;

        @media (width >=40rem) {
            max-width: 40rem;
        }

        @media (width >=48rem) {
            max-width: 48rem;
        }

        @media (width >=64rem) {
            max-width: 64rem;
        }

        @media (width >=80rem) {
            max-width: 80rem;
        }

        @media (width >=96rem) {
            max-width: 96rem;
        }
    }

    .m-0 {
        margin: calc(var(--spacing) * 0);
    }

    .mx-4 {
        margin-inline: calc(var(--spacing) * 4);
    }

    .mx-auto {
        margin-inline: auto;
    }

    .my-4 {
        margin-block: calc(var(--spacing) * 4);
    }

    .-mt-\[29rem\] {
        margin-top: calc(29rem * -1);
    }

    .mt-1\.5 {
        margin-top: calc(var(--spacing) * 1.5);
    }

    .mt-2 {
        margin-top: calc(var(--spacing) * 2);
    }

    .mt-6 {
        margin-top: calc(var(--spacing) * 6);
    }

    .mt-7 {
        margin-top: calc(var(--spacing) * 7);
    }

    .mt-12 {
        margin-top: calc(var(--spacing) * 12);
    }

    .mb-1 {
        margin-bottom: calc(var(--spacing) * 1);
    }

    .mb-2 {
        margin-bottom: calc(var(--spacing) * 2);
    }

    .mb-8 {
        margin-bottom: calc(var(--spacing) * 8);
    }

    .mb-12 {
        margin-bottom: calc(var(--spacing) * 12);
    }

    .mb-20 {
        margin-bottom: calc(var(--spacing) * 20);
    }

    .flex {
        display: flex;
    }

    .grid {
        display: grid;
    }

    .hidden {
        display: none;
    }

    .inline {
        display: inline;
    }

    .inline-block {
        display: inline-block;
    }

    .h-9 {
        height: calc(var(--spacing) * 9);
    }

    .h-10 {
        height: calc(var(--spacing) * 10);
    }

    .h-full {
        height: 100%;
    }

    .min-h-full {
        min-height: 100%;
    }

    .max-w-3xl {
        max-width: var(--container-3xl);
    }

    .max-w-4xl {
        max-width: var(--container-4xl);
    }

    .grid-cols-1 {
        grid-template-columns: repeat(1, minmax(0, 1fr));
    }

    .justify-between {
        justify-content: space-between;
    }

    .justify-start {
        justify-content: flex-start;
    }

    .gap-6 {
        gap: calc(var(--spacing) * 6);
    }

    .border-nero {
        border-color: var(--color-nero);
    }

    .bg-nero {
        background-color: var(--color-nero);
    }

    .bg-rosso {
        background-color: var(--color-rosso);
    }

    .bg-white {
        background-color: var(--color-white);
    }

    .p-4 {
        padding: calc(var(--spacing) * 4);
    }

    .px-2 {
        padding-inline: calc(var(--spacing) * 2);
    }

    .pb-10 {
        padding-bottom: calc(var(--spacing) * 10);
    }

    .text-center {
        text-align: center;
    }

    .text-base {
        font-size: var(--text-base);
        line-height: var(--tw-leading, var(--text-base--line-height));
    }

    .text-xl {
        font-size: var(--text-xl);
        line-height: var(--tw-leading, var(--text-xl--line-height));
    }

    .leading-\[1\.1\] {
        --tw-leading: 1.1;
        line-height: 1.1;
    }

    .font-bold {
        --tw-font-weight: var(--font-weight-bold);
        font-weight: var(--font-weight-bold);
    }

    .font-light {
        --tw-font-weight: var(--font-weight-light);
        font-weight: var(--font-weight-light);
    }

    .text-nero {
        color: var(--color-nero);
    }

    .text-red-600 {
        color: var(--color-red-600);
    }

    .text-rosso {
        color: var(--color-rosso);
    }

    .text-white {
        color: var(--color-white);
    }

    .underline {
        text-decoration-line: underline;
    }

    .shadow-2xl {
        --tw-shadow: 0 25px 50px -12px var(--tw-shadow-color, rgb(0 0 0 / 0.25));
        box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow),
            var(--tw-shadow);
    }

    .sm\:-mt-\[31rem\] {
        @media (width >=40rem) {
            margin-top: calc(31rem * -1);
        }
    }

    .md\:-mt-\[27rem\] {
        @media (width >=48rem) {
            margin-top: calc(27rem * -1);
        }
    }

    .md\:mb-16 {
        @media (width >=48rem) {
            margin-bottom: calc(var(--spacing) * 16);
        }
    }

    .md\:mb-28 {
        @media (width >=48rem) {
            margin-bottom: calc(var(--spacing) * 28);
        }
    }

    .md\:h-14 {
        @media (width >=48rem) {
            height: calc(var(--spacing) * 14);
        }
    }

    .md\:grid-cols-2 {
        @media (width >=48rem) {
            grid-template-columns: repeat(2, minmax(0, 1fr));
        }
    }

    .md\:text-2xl {
        @media (width >=48rem) {
            font-size: var(--text-2xl);
            line-height: var(--tw-leading, var(--text-2xl--line-height));
        }
    }

    .md\:text-lg {
        @media (width >=48rem) {
            font-size: var(--text-lg);
            line-height: var(--tw-leading, var(--text-lg--line-height));
        }
    }

    .lg\:mx-auto {
        @media (width >=64rem) {
            margin-inline: auto;
        }
    }

    .lg\:my-8 {
        @media (width >=64rem) {
            margin-block: calc(var(--spacing) * 8);
        }
    }

    .lg\:-mt-96 {
        @media (width >=64rem) {
            margin-top: calc(var(--spacing) * -96);
        }
    }

    .lg\:block {
        @media (width >=64rem) {
            display: block;
        }
    }

    .lg\:max-w-3xl {
        @media (width >=64rem) {
            max-width: var(--container-3xl);
        }
    }

    .lg\:grid-cols-4 {
        @media (width >=64rem) {
            grid-template-columns: repeat(4, minmax(0, 1fr));
        }
    }

    .lg\:gap-8 {
        @media (width >=64rem) {
            gap: calc(var(--spacing) * 8);
        }
    }

    .lg\:py-10 {
        @media (width >=64rem) {
            padding-block: calc(var(--spacing) * 10);
        }
    }

    .lg\:text-xl {
        @media (width >=64rem) {
            font-size: var(--text-xl);
            line-height: var(--tw-leading, var(--text-xl--line-height));
        }
    }

    .xl\:-mt-\[27rem\] {
        @media (width >=80rem) {
            margin-top: calc(27rem * -1);
        }
    }
}

@layer base {
    html {
        scroll-behavior: smooth;
    }

    body {
        background-color: var(--color-white);
        font-family: var(--font-jost);
        --tw-leading: var(--leading-snug);
        line-height: var(--leading-snug);
        --tw-font-weight: var(--font-weight-light);
        font-weight: var(--font-weight-light);
        color: var(--color-nero);
    }

    h1,
    h2,
    h3,
    h4,
    h5,
    h6 {
        font-family: var(--font-urbanist);
        --tw-font-weight: var(--font-weight-bold);
        font-weight: var(--font-weight-bold);
    }

    h1 {
        font-size: var(--text-2xl);
        line-height: var(--tw-leading, var(--text-2xl--line-height));

        @media (width >=48rem) {
            font-size: var(--text-4xl);
            line-height: var(--tw-leading, var(--text-4xl--line-height));
        }

        @media (width >=64rem) {
            font-size: var(--text-5xl);
            line-height: var(--tw-leading, var(--text-5xl--line-height));
        }
    }

    h2 {
        font-size: var(--text-lg);
        line-height: var(--tw-leading, var(--text-lg--line-height));

        @media (width >=48rem) {
            font-size: var(--text-3xl);
            line-height: var(--tw-leading, var(--text-3xl--line-height));
        }

        @media (width >=64rem) {
            font-size: var(--text-4xl);
            line-height: var(--tw-leading, var(--text-4xl--line-height));
        }
    }

    h3 {
        font-size: var(--text-lg);
        line-height: var(--tw-leading, var(--text-lg--line-height));

        @media (width >=48rem) {
            font-size: var(--text-2xl);
            line-height: var(--tw-leading, var(--text-2xl--line-height));
        }

        @media (width >=64rem) {
            font-size: var(--text-3xl);
            line-height: var(--tw-leading, var(--text-3xl--line-height));
        }
    }

    h4 {
        font-size: var(--text-base);
        line-height: var(--tw-leading, var(--text-base--line-height));

        @media (width >=48rem) {
            font-size: var(--text-xl);
            line-height: var(--tw-leading, var(--text-xl--line-height));
        }

        @media (width >=64rem) {
            font-size: var(--text-2xl);
            line-height: var(--tw-leading, var(--text-2xl--line-height));
        }
    }

    h5 {
        font-size: var(--text-base);
        line-height: var(--tw-leading, var(--text-base--line-height));

        @media (width >=64rem) {
            font-size: var(--text-lg);
            line-height: var(--tw-leading, var(--text-lg--line-height));
        }
    }

    nav {
        padding: calc(var(--spacing) * 3);
    }

    header {
        height: 700px;
        background-image: url('../img/header.jpg');
        background-size: cover;
        background-position: center;
    }

    [type='radio'] {
        position: absolute;
        width: 1px;
        height: 1px;
        padding: 0;
        margin: -1px;
        overflow: hidden;
        clip-path: inset(50%);
        white-space: nowrap;
        border-width: 0;
        cursor: pointer;
        --tw-outline-style: none;
        outline-style: none;
    }

    select,
    input[type='text'],
    input[type='email'] {
        display: block;
        width: 100%;
        border-style: var(--tw-border-style);
        border-width: 1px;
        border-color: var(--color-nero);
        background-color: var(--color-white);
        padding: calc(var(--spacing) * 2.5);
        font-size: var(--text-sm);
        line-height: var(--tw-leading, var(--text-sm--line-height));
        color: var(--color-nero);

        &:focus {
            border-radius: 0;
        }

        &:focus {
            border-color: var(--color-blue-500);
        }

        &:focus {
            --tw-ring-color: var(--color-blue-500);
        }

        &:focus-visible {
            border-radius: 0;
        }

        &:focus-visible {
            border-color: var(--color-blue-500);
        }

        &:focus-visible {
            --tw-ring-color: var(--color-blue-500);
        }

        @media (width >=48rem) {
            padding: calc(var(--spacing) * 3.5);
        }

        @media (width >=48rem) {
            font-size: var(--text-base);
            line-height: var(--tw-leading, var(--text-base--line-height));
        }
    }

    input[type='text'],
    input[type='email'] {
        margin-bottom: calc(var(--spacing) * 4);
        cursor: text;

        &::placeholder {
            color: var(--color-nero);
        }

        &::placeholder {
            font-style: italic;
        }
    }

    form h4 {
        margin-bottom: calc(var(--spacing) * 8);
        text-align: center;
        font-family: var(--font-jost);
        --tw-font-weight: var(--font-weight-light);
        font-weight: var(--font-weight-light);

        @media (width >=48rem) {
            margin-bottom: calc(var(--spacing) * 10);
        }

        @media (width >=64rem) {
            margin-bottom: calc(var(--spacing) * 16);
        }
    }
}

@layer components {
    .container {
        margin-inline: auto;
    }

    .wrapper {
        margin-inline: auto;

        @media (width >=64rem) {
            width: calc(10/12 * 100%);
        }
    }

    .padding {
        padding: calc(var(--spacing) * 4);

        @media (width >=48rem) {
            padding: calc(var(--spacing) * 12);
        }
    }

    .layer {
        height: 100%;
        background-color: color-mix(in srgb, #0a0a0a 70%, transparent);

        @supports (color: color-mix(in lab, red, red)) {
            background-color: color-mix(in oklab, var(--color-nero) 70%, transparent);
        }

        color: var(--color-white);
    }

    .link {
        position: relative;
        margin-top: calc(var(--spacing) * 5);
        display: inline-block;
        color: var(--color-rosso);
    }

    .titoletto {
        margin-bottom: calc(var(--spacing) * 3);
        font-size: var(--text-lg);
        line-height: var(--tw-leading, var(--text-lg--line-height));

        @media (width >=48rem) {
            font-size: var(--text-2xl);
            line-height: var(--tw-leading, var(--text-2xl--line-height));
        }
    }

    .vantaggi {
        border-bottom-style: var(--tw-border-style);
        border-bottom-width: 1px;
        border-bottom-color: var(--color-white);
        padding-bottom: calc(var(--spacing) * 3);
    }

    .vantaggi h4 {
        color: var(--color-white);
    }

    .incluso .vantaggi {
        margin-bottom: calc(var(--spacing) * 6);
        border-bottom-style: var(--tw-border-style);
        border-bottom-width: 1px;
        border-bottom-color: var(--color-nero);
        padding-bottom: calc(var(--spacing) * 2);
    }

    .incluso .vantaggi h4 {
        color: var(--color-nero);
    }

    .card {
        border-style: var(--tw-border-style);
        border-width: 1px;
        border-color: var(--color-gray-200);

        @media (width >=48rem) {
            grid-column: span 2 / span 2;
        }
    }

    .card-img {
        position: relative;
    }

    .fascia {
        position: absolute;
        top: calc(var(--spacing) * 0);
        width: 100%;
        background-color: var(--color-nero);
        padding: calc(var(--spacing) * 1);
        text-align: center;
        --tw-font-weight: var(--font-weight-normal);
        font-weight: var(--font-weight-normal);
        color: var(--color-white);
    }

    .card-body {
        padding: calc(var(--spacing) * 4);

        @media (width >=48rem) {
            height: calc(var(--spacing) * 72);
        }

        @media (width >=48rem) {
            padding: calc(var(--spacing) * 6);
        }
    }

    .card-body h3 {
        margin-bottom: calc(var(--spacing) * 4);
    }

    .card-body ul {
        list-style-type: disc;
        padding-left: calc(var(--spacing) * 5);
    }

    .card-body li {
        margin-bottom: calc(var(--spacing) * 3);
    }

    .card-footer {
        padding-inline: calc(var(--spacing) * 4);
        padding-bottom: calc(var(--spacing) * 4);

        @media (width >=48rem) {
            padding-inline: calc(var(--spacing) * 6);
        }

        @media (width >=48rem) {
            padding-bottom: calc(var(--spacing) * 6);
        }
    }

    .btn {
        display: inline-block;
        border-style: var(--tw-border-style);
        border-width: 1px;
        border-color: var(--color-rosso);
        background-color: transparent;
        padding-inline: calc(var(--spacing) * 8);
        padding-block: calc(var(--spacing) * 4);
        text-align: center;
        color: var(--color-rosso);
        transition-property: color, background-color, border-color, outline-color, text-decoration-color, fill, stroke,
            --tw-gradient-from, --tw-gradient-via, --tw-gradient-to;
        transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
        transition-duration: var(--tw-duration, var(--default-transition-duration));
        --tw-duration: 100ms;
        transition-duration: 100ms;
        --tw-ease: var(--ease-in-out);
        transition-timing-function: var(--ease-in-out);

        &:hover {
            @media (hover: hover) {
                background-color: var(--color-rosso);
            }
        }

        &:hover {
            @media (hover: hover) {
                color: var(--color-white);
            }
        }
    }

    .btn-2 {
        border-color: var(--color-white);
        color: var(--color-white);

        &:hover {
            @media (hover: hover) {
                border-color: var(--color-rosso);
            }
        }
    }

    .btn-submit {
        width: 100%;
        background-color: var(--color-rosso);
        color: var(--color-white);

        &:hover {
            @media (hover: hover) {
                background-color: var(--color-white);
            }
        }

        &:hover {
            @media (hover: hover) {
                color: var(--color-rosso);
            }
        }
    }

    .btn-small {
        margin-top: calc(var(--spacing) * 4);
        display: inline-block;
        width: auto;
        padding-inline: calc(var(--spacing) * 1);
        padding-block: calc(var(--spacing) * 1);
    }

    .bg {
        min-height: 300px;
        overflow-y: scroll;
        background-image: url('../img/bgk.jpg');
        background-size: cover;
        background-attachment: fixed;
        background-position: center;
        background-repeat: no-repeat;
    }

    .lead {
        font-size: var(--text-lg);
        line-height: var(--tw-leading, var(--text-lg--line-height));

        @media (width >=48rem) {
            font-size: var(--text-xl);
            line-height: var(--tw-leading, var(--text-xl--line-height));
        }
    }

    .bollino {
        margin-top: calc(var(--spacing) * 3);
        display: inline-block;
        background-color: var(--color-rosso);
        padding-inline: calc(var(--spacing) * 2);
        padding-block: calc(var(--spacing) * 1);
        text-align: center;
        --tw-font-weight: var(--font-weight-bold);
        font-weight: var(--font-weight-bold);
        color: var(--color-white);
        --tw-shadow: 0 20px 25px -5px var(--tw-shadow-color, rgb(0 0 0 / 0.1)), 0 8px 10px -6px var(--tw-shadow-color, rgb(0 0 0 / 0.1));
        box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow),
            var(--tw-shadow);

        @media (width >=64rem) {
            position: absolute;
        }

        @media (width >=64rem) {
            top: calc(var(--spacing) * -16);
        }

        @media (width >=64rem) {
            right: calc(var(--spacing) * -36);
        }

        @media (width >=64rem) {
            margin-top: calc(var(--spacing) * 0);
        }

        @media (width >=64rem) {
            height: calc(var(--spacing) * 32);
        }

        @media (width >=64rem) {
            width: calc(var(--spacing) * 32);
        }

        @media (width >=64rem) {
            border-radius: calc(infinity * 1px);
        }

        @media (width >=64rem) {
            padding-block: calc(var(--spacing) * 10);
        }

        @media (width >=64rem) {
            font-size: var(--text-lg);
            line-height: var(--tw-leading, var(--text-lg--line-height));
        }

        @media (width >=80rem) {
            right: calc(var(--spacing) * -16);
        }
    }

    form .btn {
        width: auto;
        padding-inline: calc(var(--spacing) * 4);
    }

    .form-group label {
        margin-bottom: calc(var(--spacing) * 1);
        display: block;
        font-size: var(--text-sm);
        line-height: var(--tw-leading, var(--text-sm--line-height));

        @media (width >=48rem) {
            margin-bottom: calc(var(--spacing) * 1.5);
        }

        @media (width >=48rem) {
            font-size: var(--text-base);
            line-height: var(--tw-leading, var(--text-base--line-height));
        }
    }

    .wrapper-button {
        margin-top: calc(var(--spacing) * 12);
        display: flex;
        flex-direction: row;
        justify-content: space-between;
        column-gap: calc(var(--spacing) * 2);

        @media (width >=48rem) {
            margin-top: calc(var(--spacing) * 20);
        }
    }

    .privacy {
        margin-top: calc(var(--spacing) * 8);
        text-align: left;
        font-size: var(--text-sm);
        line-height: var(--tw-leading, var(--text-sm--line-height));

        @media (width >=48rem) {
            font-size: var(--text-base);
            line-height: var(--tw-leading, var(--text-base--line-height));
        }
    }

    .privacy a {
        text-decoration-line: underline;
    }

    form .errore {
        margin-top: calc(var(--spacing) * 2);
        display: none;
        font-size: var(--text-sm);
        line-height: var(--tw-leading, var(--text-sm--line-height));

        @media (width >=48rem) {
            font-size: var(--text-base);
            line-height: var(--tw-leading, var(--text-base--line-height));
        }
    }

    .choice label {
        display: block;
        height: 100%;
        cursor: pointer;
        align-content: center;
        border-style: var(--tw-border-style);
        border-width: 2px;
        border-color: var(--color-nero);
        transition-property: all;
        transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
        transition-duration: var(--tw-duration, var(--default-transition-duration));
        --tw-duration: 300ms;
        transition-duration: 300ms;
        --tw-ease: var(--ease-in-out);
        transition-timing-function: var(--ease-in-out);

        &:hover {
            @media (hover: hover) {
                --tw-scale-x: 105%;
                --tw-scale-y: 105%;
                --tw-scale-z: 105%;
                scale: var(--tw-scale-x) var(--tw-scale-y);
            }
        }

        &:hover {
            @media (hover: hover) {
                background-color: var(--color-nero);
            }
        }

        &:hover {
            @media (hover: hover) {
                color: var(--color-white);
            }
        }

        &:hover {
            @media (hover: hover) {
                --tw-shadow: 0 25px 50px -12px var(--tw-shadow-color, rgb(0 0 0 / 0.25));
                box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow),
                    var(--tw-shadow);
            }
        }
    }

    .choice label span {
        display: block;
        padding: calc(var(--spacing) * 4);
        text-align: center;
        font-size: var(--text-lg);
        line-height: var(--tw-leading, var(--text-lg--line-height));

        @media (width >=48rem) {
            padding: calc(var(--spacing) * 6);
        }

        @media (width >=48rem) {
            font-size: var(--text-xl);
            line-height: var(--tw-leading, var(--text-xl--line-height));
        }
    }

    .griglia {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: calc(var(--spacing) * 4);

        @media (width >=48rem) {
            gap: calc(var(--spacing) * 10);
        }

        @media (width >=64rem) {
            grid-template-columns: repeat(4, minmax(0, 1fr));
        }
    }

    .steps .step {
        display: none;
    }

    .steps #step-0 {
        display: block;
    }
}

@layer utilities {
    #pageloader {
        display: flex;
        gap: 1rem;
        justify-content: center;
        align-items: center;
        display: none;
    }

    .babyPage {
        width: 48px;
        height: 48px;
        border: 5px solid #FFF;
        border-bottom-color: #FF3D00;
        border-radius: 50%;
        display: inline-block;
        box-sizing: border-box;
        animation: rotation 1s linear infinite;
    }

    @keyframes rotation {
        0% {
            transform: rotate(0deg);
        }

        100% {
            transform: rotate(360deg);
        }
    }

    .fade-in {
        -webkit-animation: fade-in 0.4s cubic-bezier(0.39, 0.575, 0.565, 1) both;
        animation: fade-in 0.4s cubic-bezier(0.39, 0.575, 0.565, 1) both;
    }
}

@property --tw-leading {
    syntax: "*";
    inherits: false;
}

@property --tw-font-weight {
    syntax: "*";
    inherits: false;
}

@property --tw-shadow {
    syntax: "*";
    inherits: false;
    initial-value: 0 0 #0000;
}

@property --tw-shadow-color {
    syntax: "*";
    inherits: false;
}

@property --tw-shadow-alpha {
    syntax: "<percentage>";
    inherits: false;
    initial-value: 100%;
}

@property --tw-inset-shadow {
    syntax: "*";
    inherits: false;
    initial-value: 0 0 #0000;
}

@property --tw-inset-shadow-color {
    syntax: "*";
    inherits: false;
}

@property --tw-inset-shadow-alpha {
    syntax: "<percentage>";
    inherits: false;
    initial-value: 100%;
}

@property --tw-ring-color {
    syntax: "*";
    inherits: false;
}

@property --tw-ring-shadow {
    syntax: "*";
    inherits: false;
    initial-value: 0 0 #0000;
}

@property --tw-inset-ring-color {
    syntax: "*";
    inherits: false;
}

@property --tw-inset-ring-shadow {
    syntax: "*";
    inherits: false;
    initial-value: 0 0 #0000;
}

@property --tw-ring-inset {
    syntax: "*";
    inherits: false;
}

@property --tw-ring-offset-width {
    syntax: "<length>";
    inherits: false;
    initial-value: 0px;
}

@property --tw-ring-offset-color {
    syntax: "*";
    inherits: false;
    initial-value: #fff;
}

@property --tw-ring-offset-shadow {
    syntax: "*";
    inherits: false;
    initial-value: 0 0 #0000;
}

@property --tw-border-style {
    syntax: "*";
    inherits: false;
    initial-value: solid;
}

@property --tw-duration {
    syntax: "*";
    inherits: false;
}

@property --tw-ease {
    syntax: "*";
    inherits: false;
}

@property --tw-scale-x {
    syntax: "*";
    inherits: false;
    initial-value: 1;
}

@property --tw-scale-y {
    syntax: "*";
    inherits: false;
    initial-value: 1;
}

@property --tw-scale-z {
    syntax: "*";
    inherits: false;
    initial-value: 1;
}

@layer properties {
    @supports ((-webkit-hyphens: none) and (not (margin-trim: inline))) or ((-moz-orient: inline) and (not (color:rgb(from red r g b)))) {

        *,
        ::before,
        ::after,
        ::backdrop {
            --tw-leading: initial;
            --tw-font-weight: initial;
            --tw-shadow: 0 0 #0000;
            --tw-shadow-color: initial;
            --tw-shadow-alpha: 100%;
            --tw-inset-shadow: 0 0 #0000;
            --tw-inset-shadow-color: initial;
            --tw-inset-shadow-alpha: 100%;
            --tw-ring-color: initial;
            --tw-ring-shadow: 0 0 #0000;
            --tw-inset-ring-color: initial;
            --tw-inset-ring-shadow: 0 0 #0000;
            --tw-ring-inset: initial;
            --tw-ring-offset-width: 0px;
            --tw-ring-offset-color: #fff;
            --tw-ring-offset-shadow: 0 0 #0000;
            --tw-border-style: solid;
            --tw-duration: initial;
            --tw-ease: initial;
            --tw-scale-x: 1;
            --tw-scale-y: 1;
            --tw-scale-z: 1;
        }
    }
}