/*
Theme Name: GeMEB
Theme URI: www.niering.it
Author: NIER INGEGNERIA S.P.A. Bologna
Author URI: https://www.niering.it/
Description: GeMEB valorizza il know-how tecnico con recupero del contesto, risposte verificate, citazioni e supporto NIS2 / IEC 62443 / Cyber Resilience Act.
Tags: 
Version: 2024
Requires at least: 5.2
Tested up to: 6.1
Requires PHP: 7.0
License: 
License URI: 
Text Domain: gemeb
*/

/** STILI TEMP **/

:root{
    --p4ul-primary:#6C63F0;
    --p4ul-primary-hover:#827BF6;
    --p4ul-primary-deep:#4337A8;
    --p4ul-primary-ink:#A49BFF;
    --p4ul-text:#1E2C3A;
    --p4ul-text-soft:#666F8A;
    --p4ul-bg:#F7F8FD;
    --p4ul-surface-soft:#FBFBFF;
    --p4ul-surface:#ffffff;
    --p4ul-border:rgba(108,99,240,.16);
    --p4ul-border-strong:rgba(108,99,240,.24);
    --p4ul-contrast:#171A2E;
    --p4ul-secondary:#3D388E;
    --p4ul-tertiary:#E3DFFF;
    --p4ul-neutral:#6D7390;
    --p4ul-navy:#12233D;
    --p4ul-navy-deep:#0B1324;
    --p4ul-accent:#DC3545;
    --p4ul-accent-hover:#b02a37;
}

.brand-wordmark{
    letter-spacing:inherit;
    white-space:nowrap;
}

.brand-o{
    color:var(--p4ul-accent);
}

/* Consolidated final source of truth for Vantaggi + Compliance */
#vantaggi.icons{
    background:
      radial-gradient(circle at 18% 10%, rgba(108,99,240,.10) 0%, rgba(108,99,240,0) 30%),
      radial-gradient(circle at 82% 8%, rgba(220,53,69,.06) 0%, rgba(220,53,69,0) 24%),
      linear-gradient(180deg, #eef4fa 0%, #dde6f1 100%) !important;
    color:#132131 !important;
}

#vantaggi .icons__container > h2{
    color:#4337A8 !important;
}

#vantaggi .icons__section-copy{
    color:#5f6f7a !important;
}

#vantaggi .icons__comparison{
    display:flex !important;
    justify-content:center !important;
}

#vantaggi .icons__comparison-tablewrap,
#vantaggi .icons__comparison-visual{
    background:#ffffff !important;
    border:1px solid rgba(108,99,240,.16) !important;
    border-radius:28px !important;
    box-shadow:0 22px 52px rgba(11,19,36,.12) !important;
}

#vantaggi .icons__comparison-table thead th,
#vantaggi .icons__comparison-table tbody td{
    color:#243140 !important;
    border-color:rgba(108,99,240,.08) !important;
}

#vantaggi .icons__comparison-table thead th:last-child{
    color:#6C63F0 !important;
    background:linear-gradient(180deg, rgba(108,99,240,.14) 0%, rgba(108,99,240,.08) 100%) !important;
}

#vantaggi .icons__comparison-table tbody td:first-child,
#vantaggi .icons__comparison-visual h3{
    color:#132131 !important;
}

#vantaggi .icons__comparison-table tbody td:last-child{
    background:linear-gradient(180deg, rgba(108,99,240,.06) 0%, rgba(108,99,240,.03) 100%) !important;
    color:#0f1730 !important;
}

#vantaggi .icons__comparison-table strong{
    color:#132131 !important;
}

#vantaggi .icons__comparison-visual p{
    color:#5f6f7a !important;
}

#vantaggi .icons__comparison-visual img{
    border-color:rgba(108,99,240,.10) !important;
    box-shadow:0 16px 36px rgba(11,19,36,.08) !important;
}

#vantaggi .icons__result{
    display:grid;
    gap:6px;
    justify-items:center;
    text-align:center;
    width:min(100%, 720px);
    margin:0 auto 6px;
}

#vantaggi .icons__result-eyebrow{
    margin:0;
    font-size:.74rem;
    font-weight:800;
    letter-spacing:.24em;
    text-transform:uppercase;
    color:var(--p4ul-accent);
}

#vantaggi .icons__result-copy{
    margin:0;
    max-width:60ch;
    color:rgba(255,255,255,.84);
    font-size:clamp(1.05rem, 1.3vw, 1.16rem);
    line-height:1.68;
}

#vantaggi .icons__container{
    max-width:1440px;
    display:grid;
    gap:28px;
}

#vantaggi .icons__container > h2{
    margin:0;
    text-align:center;
    max-width:none;
    white-space:normal;
    font-size:clamp(1.9rem, 3vw, 3rem);
    line-height:1.02;
    color:#f8fafc;
}

#vantaggi .icons__layout{
    display:grid;
    grid-template-columns:1fr;
    gap:24px;
    align-items:start;
    margin-top:0;
}

#vantaggi .icons__points{
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:18px;
    position:relative;
}

#vantaggi .icons__points::before{
    content:none;
}

#vantaggi .icons__point{
    display:grid;
    gap:14px;
    align-items:start;
    min-height:180px;
    padding:24px 22px 22px;
    border:1px solid rgba(255,255,255,.10);
    border-radius:24px;
    background:linear-gradient(180deg, rgba(12,18,28,.94) 0%, rgba(9,15,23,.98) 100%) !important;
    border-color:rgba(255,255,255,.11) !important;
    box-shadow:0 20px 44px rgba(0,0,0,.24) !important;
    position:relative;
    overflow:hidden;
}

#vantaggi .icons__point::before{
    content:"";
    position:absolute;
    inset:0 auto auto 0;
    width:100%;
    height:3px;
    background:linear-gradient(90deg, var(--p4ul-accent) 0%, rgba(255,255,255,.16) 100%);
    opacity:.9;
}

#vantaggi .icons__point-body{
    gap:12px;
    padding-top:16px;
}

#vantaggi .icons__point-body h3{
    margin:0;
    font-size:1.2rem;
    line-height:1.2;
    color:#ffffff !important;
}

#vantaggi .icons__point-body p{
    margin:0;
    font-size:1.02rem;
    line-height:1.66;
    color:rgba(255,255,255,.72) !important;
    max-width:none;
}

#vantaggi .icons__lead{
    position:relative;
    top:auto;
    display:block;
    min-height:100%;
}

#vantaggi .icons__lead-frame{
    position:relative;
    overflow:hidden;
    min-height:100%;
    padding:34px 32px 30px;
    border-radius:28px;
    border:1px solid rgba(255,255,255,.08);
    border-left:4px solid rgba(220,53,69,.85);
    background:
      radial-gradient(circle at 88% 18%, rgba(220,53,69,.13) 0%, rgba(220,53,69,0) 18%),
      radial-gradient(circle at 14% 88%, rgba(108,99,240,.14) 0%, rgba(108,99,240,0) 20%),
      linear-gradient(180deg, rgba(12,18,28,.78) 0%, rgba(9,15,23,.96) 100%);
    box-shadow:0 24px 50px rgba(0,0,0,.24);
}

#vantaggi .icons__lead-frame::before{
    content:"";
    position:absolute;
    top:20px;
    right:20px;
    width:118px;
    height:118px;
    border-radius:50%;
    border:1px solid rgba(255,255,255,.08);
    background:
      radial-gradient(circle at center, rgba(255,255,255,.08) 0 22%, transparent 23%),
      radial-gradient(circle at center, transparent 0 62%, rgba(255,255,255,.05) 63% 64%, transparent 65%);
    opacity:.95;
    pointer-events:none;
}

#vantaggi .icons__lead-frame::after{
    content:"";
    position:absolute;
    left:24px;
    right:24px;
    bottom:18px;
    height:1px;
    background:linear-gradient(90deg, rgba(255,255,255,.16) 0%, rgba(255,255,255,0) 100%);
    pointer-events:none;
}

#vantaggi .icons__lead-copyblock{
    position:relative;
    z-index:1;
    display:grid;
    gap:15px;
    max-width:62ch;
    padding-left:20px;
    border-left:1px solid rgba(255,255,255,.10);
}

#vantaggi .icons__lead-badge{
    margin:0;
    display:inline-flex;
    align-items:center;
    width:max-content;
    padding:7px 12px;
    border-radius:999px;
    background:rgba(255,255,255,.06);
    border:1px solid rgba(255,255,255,.10);
    color:rgba(255,255,255,.88);
    font-size:.8rem;
    font-weight:800;
    letter-spacing:.22em;
    text-transform:uppercase;
}

#vantaggi .icons__lead-title{
    margin:0;
    color:#ffffff !important;
    max-width:18ch;
    font-size:clamp(2rem, 3vw, 3rem);
    line-height:1.02;
    letter-spacing:-.05em;
    text-wrap:balance;
}

#vantaggi .icons__lead-copy{
    margin:0;
    max-width:42ch;
    font-size:1.03rem;
    line-height:1.7;
    color:rgba(255,255,255,.78) !important;
}

@media (max-width: 1100px){
    #vantaggi .icons__layout{
        grid-template-columns:1fr;
        gap:24px;
    }

    #vantaggi .icons__lead-frame{
        min-height:auto;
        padding:30px 24px;
    }

    #vantaggi .icons__lead-frame::before{
        top:16px;
        right:16px;
        width:92px;
        height:92px;
    }

    #vantaggi .icons__points{
        grid-template-columns:1fr;
    }

    #vantaggi .icons__point{
        min-height:auto;
        padding:19px 18px 17px;
    }

    #vantaggi .icons__point:last-child{
        grid-column:auto;
    }

    #vantaggi .icons__point-body h3{
        font-size:1.06rem;
    }

    #vantaggi .icons__point-body p{
        font-size:.97rem;
        max-width:none;
    }

    #vantaggi .icons__lead-title{
        max-width:18ch;
        font-size:clamp(1.95rem, 5vw, 2.8rem);
        line-height:1.04;
    }
}

@media (max-width: 720px){
    #vantaggi.icons{
        padding:56px 0 48px;
    }

    #vantaggi .icons__container > h2{
        font-size:clamp(1.6rem, 8vw, 2.2rem);
    }

    #vantaggi .icons__lead-frame{
        padding:24px 20px 22px;
        border-radius:24px;
    }

    #vantaggi .icons__lead-frame::before{
        width:72px;
        height:72px;
    }

    #vantaggi .icons__lead-copyblock{
        max-width:none;
        padding-left:16px;
    }

    #vantaggi .icons__lead-title{
        max-width:none;
        font-size:clamp(1.65rem, 8vw, 2.25rem);
        line-height:1.05;
    }
}

@media (max-width: 720px){
    #vantaggi .icons__comparison{
        grid-template-columns:1fr !important;
    }

    #vantaggi .icons__comparison-table thead th,
    #vantaggi .icons__comparison-table tbody td{
        padding:14px 12px !important;
        font-size:.88rem !important;
        line-height:1.45 !important;
    }

    #vantaggi .icons__comparison-table thead th:last-child{
        font-size:.8rem !important;
    }

    #vantaggi .icons__comparison-table tbody td:first-child{
        width:auto !important;
    }

    #vantaggi .icons__comparison-visual{
        padding:16px !important;
    }
}

#compliance.compliance{
    background:
      radial-gradient(circle at 18% 12%, rgba(108,99,240,.18) 0%, rgba(108,99,240,0) 30%),
      radial-gradient(circle at 82% 8%, rgba(220,53,69,.12) 0%, rgba(220,53,69,0) 24%),
      linear-gradient(180deg, #f7fafc 0%, #eef3f8 100%) !important;
    color:#132131 !important;
    min-height:auto !important;
    display:block !important;
    padding:76px 0 !important;
}

#compliance .compliance__intro{
    max-width:760px !important;
    margin:0 auto !important;
    text-align:center !important;
}

#compliance .compliance__intro .service__eyebrow{
    color:var(--p4ul-primary) !important;
}

#compliance .compliance__intro .service__title{
    color:#132131 !important;
    font-size:clamp(2rem, 3.2vw, 3.2rem) !important;
    letter-spacing:-.04em !important;
}

#compliance .compliance__intro .service__subtitle{
    color:var(--p4ul-text-soft) !important;
    max-width:700px;
    margin:6px auto 0;
    text-align:center;
    font-size:1rem;
    line-height:1.38;
}

#compliance .compliance__grid{
    display:grid !important;
    grid-template-columns:repeat(12,minmax(0,1fr)) !important;
    gap:14px !important;
}

#compliance .compliance-card{
    position:relative !important;
    overflow:hidden !important;
    border-radius:22px !important;
    background:#ffffff !important;
    border:1px solid rgba(108,99,240,.12) !important;
    box-shadow:0 20px 44px rgba(11,19,36,.12) !important;
}

#compliance .compliance-card__media{
    aspect-ratio:1 / 1 !important;
}

#compliance .compliance-card--rail .compliance-card__media{
    aspect-ratio:16 / 4.4 !important;
}

#compliance .compliance-card__overlay{
    padding:28px 22px 20px !important;
    background:linear-gradient(180deg, rgba(11,19,36,0) 0%, rgba(11,19,36,.84) 100%) !important;
}

#compliance .compliance-card__overlay h3{
    font-size:1.12rem !important;
}

#compliance .compliance-card__overlay p{
    font-size:1rem !important;
    line-height:1.52 !important;
}

#compliance .compliance-card--rail{
    grid-column:span 12;
}

#compliance .compliance-card--medical,
#compliance .compliance-card--automotive,
#compliance .compliance-card--cyber{
    grid-column:span 4;
}

#compliance .compliance-card--rail .compliance-card__overlay p{
    max-width:34ch;
}

@media (max-width: 980px){
    #compliance .compliance__grid{
        grid-template-columns:1fr !important;
    }

    #compliance .compliance-card--rail,
    #compliance .compliance-card--medical,
    #compliance .compliance-card--automotive,
    #compliance .compliance-card--cyber{
        grid-column:auto;
    }

    #compliance .compliance-card__media,
    #compliance .compliance-card--rail .compliance-card__media{
        aspect-ratio:1 / 1 !important;
    }
}

@media (max-width: 720px){
    #compliance .compliance__grid{
        gap:12px !important;
    }
}

/* Intro global final override */
#content .intro#intro .homepage-hero-heading{
    display:flex !important;
    justify-content:center !important;
    width:100% !important;
    margin-bottom:10px !important;
    text-align:center !important;
}

#content .intro#intro .homepage-hero-heading .homepage-section-title{
    max-width:24ch !important;
    font-size:clamp(36px, 4.2vw, 64px) !important;
    line-height:1.02 !important;
    letter-spacing:-.045em !important;
    margin-left:auto !important;
    margin-right:auto !important;
    text-align:center !important;
}

#content .intro#intro .homepage-copy--lead{
    width:100% !important;
    max-width:100% !important;
    font-size:21px !important;
    line-height:1.64 !important;
}

#content .intro#intro .intro__left > p{
    width:100% !important;
    max-width:100% !important;
}

#content .intro#intro .homepage-hero-body{
    display:grid !important;
    grid-template-columns:minmax(0,1fr) minmax(0,1fr) !important;
    gap:30px !important;
    align-items:center !important;
}

#content .intro#intro .intro__left{
    gap:14px !important;
    max-width:none !important;
    justify-self:start !important;
    width:100% !important;
}

#content .intro#intro .intro__visual{
    width:100% !important;
    justify-self:center !important;
    position:relative !important;
    margin-left:auto !important;
    margin-right:auto !important;
    display:flex !important;
    flex-direction:column !important;
    justify-content:center !important;
    align-items:center !important;
}

#content .intro#intro .intro__visual-frame{
    position:relative !important;
    width:min(88%, 540px) !important;
    overflow:hidden !important;
    border-radius:28px !important;
    isolation:isolate !important;
    background:transparent !important;
}

#content .intro#intro .intro__visual::before{
    content:none !important;
    display:none !important;
    background:none !important;
    border:none !important;
    box-shadow:none !important;
    backdrop-filter:none !important;
}

#content .intro#intro .homepage-image--hero{
    display:block !important;
    width:100% !important;
    max-height:360px !important;
    object-fit:cover !important;
    border-radius:28px !important;
    box-shadow:0 28px 68px rgba(0,0,0,.18) !important;
}

#content .intro#intro .intro__visual-card{
    position:absolute !important;
    width:min(100%, 280px) !important;
    left:18px !important;
    right:auto !important;
    bottom:18px !important;
    padding:10px 12px !important;
    z-index:2 !important;
    background:rgba(16,24,40,.72) !important;
    border:1px solid rgba(255,255,255,.16) !important;
    color:#ffffff !important;
    box-shadow:0 16px 34px rgba(0,0,0,.24) !important;
    backdrop-filter:blur(10px) !important;
}

#content .intro#intro .intro__collaboration{
    margin-top:0 !important;
    width:min(92%, 620px) !important;
    justify-self:center !important;
    padding-top:10px !important;
    border-top:1px solid rgba(108,99,240,.10) !important;
}

#content .intro#intro .intro__collaboration-title{
    margin:0 0 14px !important;
    font-size:.7rem !important;
    line-height:1.15 !important;
    letter-spacing:.2em !important;
    text-transform:uppercase !important;
    color:#7d879d !important;
    opacity:.92 !important;
}

#content .intro#intro .intro__collaboration-grid{
    display:grid !important;
    grid-template-columns:repeat(3, minmax(0, 1fr)) !important;
    gap:14px !important;
    align-items:stretch !important;
}

#content .intro#intro .intro__collaboration-item{
    display:grid !important;
    gap:5px !important;
    padding:8px 6px !important;
    border:0 !important;
    border-radius:0 !important;
    background:transparent !important;
    box-shadow:none !important;
    min-height:0 !important;
    justify-items:center !important;
    text-align:center !important;
}

#content .intro#intro .intro__collaboration-item:nth-child(2){
    background:transparent !important;
    border:0 !important;
}

#content .intro#intro .intro__collaboration-item:nth-child(3){
    background:transparent !important;
    border:0 !important;
}

#content .intro#intro .intro__collaboration-name{
    font-size:.98rem !important;
    font-weight:800 !important;
    line-height:1.15 !important;
    color:#1f2b3d !important;
}

#content .intro#intro .intro__collaboration-role{
    font-size:.76rem !important;
    line-height:1.4 !important;
    color:#6b7789 !important;
    text-align:center !important;
}

#content .intro#intro .intro__collaboration-item:nth-child(2){
    position:relative !important;
}

#content .intro#intro .intro__collaboration-item:nth-child(2)::before,
#content .intro#intro .intro__collaboration-item:nth-child(2)::after{
    content:"" !important;
    position:absolute !important;
    top:8px !important;
    bottom:8px !important;
    width:1px !important;
    background:rgba(108,99,240,.10) !important;
}

#content .intro#intro .intro__collaboration-item:nth-child(2)::before{
    left:-7px !important;
}

#content .intro#intro .intro__collaboration-item:nth-child(2)::after{
    right:-7px !important;
}

#content .intro#intro .intro__section-divider{
    width:min(88%, 540px) !important;
    height:1px !important;
    margin:24px auto 18px !important;
    background:linear-gradient(90deg, rgba(108,99,240,0) 0%, rgba(108,99,240,.18) 50%, rgba(108,99,240,0) 100%) !important;
    opacity:.9 !important;
}

#content .intro#intro .intro__articles-link{
    margin:18px 0 4px !important;
    width:min(100%, 640px) !important;
    justify-self:center !important;
    text-align:center !important;
}

#content .intro#intro .intro__articles-link a{
    display:flex !important;
    align-items:center !important;
    gap:10px !important;
    justify-content:center !important;
    padding:0 !important;
    border:0 !important;
    border-radius:0 !important;
    background:transparent !important;
    color:#1f2940 !important;
    font-size:1.12rem !important;
    font-weight:700 !important;
    line-height:1.2 !important;
    text-decoration:underline !important;
    text-decoration-color:rgba(108,99,240,.30) !important;
    text-underline-offset:3px !important;
    text-decoration-thickness:1px !important;
    box-shadow:none !important;
}

#content .intro#intro .intro__articles-link a::after{
    content:"→" !important;
    color:var(--p4ul-violet, #6c63f0) !important;
    font-weight:700 !important;
    font-size:1.05rem !important;
    transition:transform .18s ease;
}

#content .intro#intro .intro__articles-link a:hover{
    text-decoration-color:rgba(108,99,240,.55) !important;
}

#content .intro#intro .intro__articles-link a:hover::after{
    transform:translateX(2px);
}

@media (max-width: 767px){
    #content .intro#intro .homepage-hero-body{
        grid-template-columns:1fr !important;
        gap:18px !important;
    }

    #content .intro#intro .intro__visual{
        width:100% !important;
        max-width:560px !important;
        justify-self:center !important;
    }

    #content .intro#intro .intro__visual-frame{
        width:min(92%, 520px) !important;
        border-radius:24px !important;
    }

    #content .intro#intro .homepage-image--hero{
        max-height:none !important;
    }

    #content .intro#intro .intro__visual-card{
        position:absolute !important;
        left:12px !important;
        bottom:12px !important;
        width:calc(100% - 24px) !important;
        max-width:280px !important;
    }

    #content .intro#intro .intro__collaboration{
        width:min(92%, 520px) !important;
        justify-self:center !important;
    }

    #content .intro#intro .intro__collaboration-grid{
        grid-template-columns:1fr !important;
    }

    #content .intro#intro .intro__collaboration-item{
        min-height:0 !important;
    }

    #content .intro#intro .intro__section-divider{
        width:min(92%, 520px) !important;
        margin:16px 0 12px !important;
    }
}

/* Intro cards: single source of truth */
#content .intro#intro .intro__overview-grid{
    display:grid !important;
    grid-template-columns:repeat(3, minmax(0, 1fr)) !important;
    grid-template-areas:
        "featured support wide" !important;
    column-gap:12px !important;
    row-gap:12px !important;
    align-content:start !important;
    align-items:start !important;
    grid-auto-rows:min-content !important;
    margin:0 0 4px !important;
    width:100% !important;
    max-width:100% !important;
}

#content .intro#intro .intro__overview-card{
    display:grid !important;
    grid-template-columns:40px minmax(0,1fr) !important;
    gap:8px !important;
    align-items:start !important;
    padding:14px 16px !important;
    border-radius:16px !important;
    min-height:0 !important;
    height:auto !important;
    box-sizing:border-box !important;
    width:100% !important;
    background:
        linear-gradient(180deg, rgba(255,255,255,.96) 0%, rgba(246,242,255,.92) 100%) !important;
    border:1px solid rgba(108,99,240,.14) !important;
    box-shadow:
        0 12px 30px rgba(36,42,84,.08),
        inset 0 1px 0 rgba(255,255,255,.9) !important;
}

#content .intro#intro .intro__overview-card--featured{
    background:linear-gradient(180deg, rgba(255,255,255,.98) 0%, rgba(245,242,255,.94) 100%) !important;
    border-color:rgba(108,99,240,.18) !important;
    box-shadow:
        0 14px 34px rgba(108,99,240,.08),
        inset 0 1px 0 rgba(255,255,255,.92) !important;
}

#content .intro#intro .intro__overview-card--compact{
    background:linear-gradient(180deg, rgba(255,255,255,.98) 0%, rgba(243,247,255,.94) 100%) !important;
    border-color:rgba(78,126,232,.16) !important;
    box-shadow:
        0 12px 30px rgba(78,126,232,.06),
        inset 0 1px 0 rgba(255,255,255,.92) !important;
}

#content .intro#intro .intro__overview-card--wide{
    background:linear-gradient(180deg, rgba(255,255,255,.98) 0%, rgba(248,245,255,.94) 100%) !important;
    border-color:rgba(136,99,240,.16) !important;
    box-shadow:
        0 16px 38px rgba(136,99,240,.07),
        inset 0 1px 0 rgba(255,255,255,.92) !important;
}

#content .intro#intro .intro__overview-card--featured{
    grid-area:featured !important;
}

#content .intro#intro .intro__overview-card--compact{
    grid-area:support !important;
}

#content .intro#intro .intro__overview-card--wide{
    grid-area:wide !important;
    justify-self:stretch !important;
    width:100% !important;
}

#content .intro#intro .intro__overview-icon-wrap{
    width:40px !important;
    height:40px !important;
    flex:0 0 40px !important;
    align-self:start !important;
    justify-self:center !important;
    display:grid !important;
    place-items:center !important;
    margin-top:0 !important;
    background:linear-gradient(180deg, rgba(108,99,240,.16) 0%, rgba(108,99,240,.08) 100%) !important;
    border:1px solid rgba(108,99,240,.20) !important;
    box-shadow:0 8px 18px rgba(108,99,240,.10) !important;
    color:var(--p4ul-violet, #6c63f0) !important;
}

#content .intro#intro .intro__overview-card--compact .intro__overview-icon-wrap{
    background:linear-gradient(180deg, rgba(78,126,232,.16) 0%, rgba(78,126,232,.08) 100%) !important;
    border-color:rgba(78,126,232,.20) !important;
    box-shadow:0 8px 18px rgba(78,126,232,.10) !important;
    color:#4e7ee8 !important;
}

#content .intro#intro .intro__overview-card--wide .intro__overview-icon-wrap{
    background:linear-gradient(180deg, rgba(136,99,240,.16) 0%, rgba(136,99,240,.08) 100%) !important;
    border-color:rgba(136,99,240,.20) !important;
    box-shadow:0 8px 18px rgba(136,99,240,.10) !important;
    color:#8863f0 !important;
}

#content .intro#intro .intro__overview-icon-wrap .material-symbols-outlined{
    font-size:1.18rem !important;
    color:inherit !important;
    line-height:1 !important;
    display:block !important;
}

#content .intro#intro .intro__overview-label{
    font-size:.88rem !important;
    line-height:1.05 !important;
    letter-spacing:.09em !important;
    font-weight:800 !important;
    color:var(--p4ul-violet, #6c63f0) !important;
    text-transform:uppercase !important;
}

#content .intro#intro .intro__overview-card--compact .intro__overview-label{
    color:#4e7ee8 !important;
}

#content .intro#intro .intro__overview-card--wide .intro__overview-label{
    color:#8863f0 !important;
}

#content .intro#intro .intro__overview-copy p:last-child{
    font-size:.88rem !important;
    line-height:1.34 !important;
    margin-top:1px !important;
    color:#344356 !important;
}

#content .intro#intro .intro__overview-copy{
    align-self:start !important;
    padding-top:1px !important;
}

@media (max-width: 767px){
    #content .intro#intro .intro__overview-grid{
        grid-template-columns:1fr !important;
        grid-template-areas:
            "featured"
            "support"
            "wide" !important;
        max-width:none !important;
        justify-self:stretch !important;
    }

    #content .intro#intro .intro__overview-card{
        width:100% !important;
    }

    #content .intro#intro .intro__overview-card--wide{
        width:100% !important;
    }
}

.grecaptcha-badge { 
    visibility: hidden;
}

.wpcf7-form.submitting .wpcf7-submit {
    pointer-events: none;
}

#servizio,
#moduli,
#vantaggi,
#faq,
#contacts{
    scroll-margin-top: 88px;
}

#contacts{
    scroll-margin-top: 104px;
}

.previewImg{
    position: relative;
}
.previewImg img{
    opacity: .5;
    transition: all .45s;
}
.previewImg:before{
    content: url('build/assets/img/lens.svg');
    opacity: .7;
    position: absolute;
    display: block;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 2;
    transition: all .45s;
}

.previewImg:hover:before{
    transform: translate(-50%, -50%) scale(1.2);
}

.previewImg:hover img{
    opacity: 1;
}

.slick-dots li button:before{
    background-color:var(--p4ul-primary) !important;
}

.slick-dots li.slick-active button:before{
    background-color:var(--p4ul-primary) !important;
}

.homepage-accent{
    color:#DC3545;
}

.service__title-accent{
    color:#DC3545;
}

html{
    scroll-padding-top:56px;
}

#intro,
#servizio,
#moduli,
#vantaggi,
#faq,
#contacts{
    scroll-margin-top:88px;
}

#contacts{
    scroll-margin-top:104px;
}

.header{
    position:fixed;
    top:0;
    left:0;
    right:0;
    z-index:1000;
    background:rgba(244,248,252,.62);
    border-bottom:1px solid var(--p4ul-border);
    box-shadow:0 14px 30px rgba(15,30,48,.12);
    height:auto !important;
    min-height:60px;
    backdrop-filter:saturate(130%) blur(16px);
    transition:background .28s ease, box-shadow .28s ease, border-color .28s ease, min-height .28s ease;
}

.header--scrolled{
    background:rgba(244,248,252,.94);
    border-bottom:1px solid var(--p4ul-border-strong);
    box-shadow:0 16px 34px rgba(15,30,48,.18);
    min-height:48px;
}

.header__container{
    display:flex;
    margin:auto;
    align-items:center;
    justify-content:space-between;
    gap:24px;
    margin-top:0 !important;
    margin-bottom:0 !important;
    min-height:56px;
    padding-top:5px !important;
    padding-bottom:5px !important;
    padding-left:1.5rem;
    padding-right:1.5rem;
    max-width:1440px;
}

.header__brand{
    flex:0 0 auto;
    display:flex;
    align-items:center;
    margin-left:-16px;
    line-height:0;
}

.header__menu{
    flex:1 1 auto;
    min-width:0;
    display:flex;
    justify-content:flex-end;
}

.header img.homepage-header-logo{
    display:block;
    transition:transform .28s ease, height .28s ease, opacity .5s ease, visibility .5s ease, filter .28s ease;
    width:auto;
    height:80px;
    max-width:none;
    opacity:0;
    visibility:hidden;
    transform:translateY(-1px);
    filter:drop-shadow(0 1px 3px rgba(0,0,0,.22));
}

.header--cover .homepage-header-logo{
    opacity:0;
    visibility:hidden;
    transform:translateY(-6px) scale(.96);
    pointer-events:none;
}

.header--logo-visible img.homepage-header-logo{
    opacity:1;
    visibility:visible;
    pointer-events:auto;
}

.header--scrolled img.homepage-header-logo{
    width:auto;
    height:60px;
    transform:translateY(0);
    filter:drop-shadow(0 1px 2px rgba(0,0,0,.18));
}

.header nav{
    display:flex;
    align-items:center;
    flex-wrap:wrap;
    justify-content:flex-end;
    max-width:100%;
}

.header nav a{
    color:var(--p4ul-text);
    text-decoration:none;
    font-size:16px;
    font-weight:700;
    letter-spacing:1px;
    text-transform:uppercase;
    margin:0 8px;
    line-height:1;
    font-family:"NeutraText-Bold", "Montserrat", sans-serif;
}

.header nav a.evidence{
    color:#ffffff !important;
    padding:10px 12px;
    background:#DC3545;
    border:1px solid #DC3545;
    border-radius:5px;
    text-decoration:none;
    transition:all 0.3s ease;
    box-shadow:0 10px 18px rgba(21,42,68,.20);
   
    letter-spacing:1px;
    font-size:16px;
}

.header nav a.evidence,
.header nav a.evidence:hover,
.header nav a.evidence:focus,
.header nav a.evidence:active{
    color:#ffffff !important;
    text-decoration:none !important;
}

.header nav a:hover{
    color:#DC3545;
    text-decoration:underline;
    text-underline-offset:3px;
}

.header nav a.evidence:hover{
    background:#b02a37;
    border-color:#b02a37;
}

@media (max-width: 768px){
    .header{
        min-height:56px;
    }

    .header__container{
        min-height:56px;
        padding-left:1rem;
        padding-right:1rem;
    }

    .header__menu{
        justify-content:flex-end;
    }

    .header__brand{
        margin-left:-8px;
    }

    .header img.homepage-header-logo{
        width:100px;
        height:auto;
        transform:translateY(-1px);
        filter:drop-shadow(0 1px 2px rgba(0,0,0,.18));
    }

    .header nav{
        justify-content:flex-end;
    }

    .header nav a{
        margin:0 6px;
    }

    .header nav a.evidence{
        padding:8px 10px;
    }
}

@media (max-width: 992px){
    .header{
        min-height:56px;
    }

    .header__container{
        align-items:flex-start;
        padding-top:8px;
        padding-bottom:8px;
        gap:12px;
    }

    .header__menu{
        justify-content:flex-end;
    }

    .header nav{
        gap:6px 8px;
        row-gap:6px;
    }

    .header nav a{
        display:inline-flex;
        margin:0;
        font-size:13px;
        letter-spacing:.08em;
        white-space:nowrap;
    }

    .header nav a.evidence{
        display:inline-flex;
        padding:8px 10px;
        font-size:12px;
    }

    .header img.homepage-header-logo{
        width:100px !important;
        height:auto;
        transform:translateY(-1px);
        filter:drop-shadow(0 1px 2px rgba(0,0,0,.18));
    }

    #servizio,
    #moduli,
    #faq,
    #vantaggi,
    #contacts{
        scroll-margin-top:52px;
    }

    #contacts{
        scroll-margin-top:64px;
    }
}

.cover__video{
    position:absolute !important;
    top:0 !important;
    left:0 !important;
    right:0 !important;
    width:100% !important;
    height:100% !important;
    margin:auto !important;
    object-fit:contain !important;
    object-position:center center !important;
    transform:none !important;
    opacity:0;
    filter:contrast(1.02) brightness(.96) saturate(.92);
    transition:opacity 1.2s cubic-bezier(.22,1,.36,1), filter 1.2s cubic-bezier(.22,1,.36,1) !important;
    background:linear-gradient(180deg, #0b111e 0%, #0d1424 100%);
    z-index:1;
}

.cover--video-ready .cover__video{
    opacity:1;
}

.cover__video--ended{
    opacity:0 !important;
    filter:none !important;
    transform:none !important;
}

.cover__scroll{
    position:absolute;
    left:50%;
    bottom:20px;
    z-index:100;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    width:40px;
    max-width:40px;
    margin:0;
    opacity:0;
    visibility:hidden;
    pointer-events:none;
    transform:translateX(-50%);
    transition:opacity .65s ease, visibility .65s ease, transform .65s ease;
    animation:MoveUpDown 2.4s linear infinite;
}

.cover__scroll img{
    display:block;
    width:100%;
    height:auto;
    filter:brightness(0) saturate(100%) invert(12%) sepia(93%) saturate(6412%) hue-rotate(346deg) brightness(93%) contrast(114%) drop-shadow(0 8px 18px rgba(0, 0, 0, 0.18));
}

.cover{
    margin-top:56px !important;
    display:flex;
    align-items:center;
    justify-content:center;
    overflow:hidden;
    position:relative;
    isolation:isolate;
    height:calc(100vh - 56px);
    min-height:calc(100vh - 56px);
    padding:0;
    background:
      radial-gradient(circle at center, rgba(108,99,240,.20) 0%, rgba(17,26,45,.96) 72%, rgba(8,13,24,1) 100%),
      linear-gradient(180deg, #0b111e 0%, #07101d 100%);
}

.cover__backdrop{
    position:absolute;
    inset:0;
    z-index:0;
    background:
      radial-gradient(circle at center, rgba(108,99,240,.10) 0%, rgba(17,26,45,.90) 58%, rgba(8,13,24,1) 100%),
      linear-gradient(180deg, rgba(7,16,29,.72) 0%, rgba(7,16,29,.96) 100%);
    opacity:1;
    transform:scale(1.03);
    filter:saturate(.9) brightness(.82);
    transition:opacity 1.05s ease, transform 1.35s ease, filter 1.35s ease;
}

.cover--video-ready .cover__backdrop{
    opacity:0;
    transform:scale(1.06);
    filter:saturate(.95) brightness(.72);
}

.cover--ended{
    background:
      radial-gradient(circle at center, rgba(164,155,255,.18) 0%, rgba(108,99,240,.72) 58%, rgba(67,55,168,.96) 100%),
      linear-gradient(180deg, rgba(67,55,168,.72) 0%, rgba(13,19,29,.96) 100%);
}

.cover::after{
    content:"";
    position:absolute;
    inset:0;
    background:
      radial-gradient(circle at center, rgba(164,155,255,.16) 0%, rgba(108,99,240,.64) 66%, rgba(16,32,51,.94) 100%),
      linear-gradient(180deg, rgba(90,122,105,.14) 0%, rgba(67,55,168,.68) 100%);
    opacity:0;
    transition:opacity 1.1s ease;
    pointer-events:none;
    z-index:1;
}

.cover__backdrop::after{
    content:"";
    position:absolute;
    inset:0;
    background:
      radial-gradient(circle at center, rgba(0,0,0,0) 34%, rgba(0,0,0,.22) 76%, rgba(0,0,0,.42) 100%),
      linear-gradient(180deg, rgba(8,12,22,.08) 0%, rgba(8,12,22,.34) 100%);
    pointer-events:none;
}

.cover--static{
    background:
      radial-gradient(circle at center, rgba(164,155,255,.16) 0%, rgba(108,99,240,.76) 68%, rgba(16,32,51,.96) 100%),
      linear-gradient(180deg, var(--p4ul-primary) 0%, var(--p4ul-primary-deep) 100%);
}

.cover--static .cover__video{
    display:none !important;
}

.cover--static .cover__backdrop{
    opacity:0;
}

.cover--static::after{
    opacity:1;
}

.cover__endcard{
    position:absolute;
    inset:0;
    display:flex;
    align-items:center;
    justify-content:center;
    padding:0;
    opacity:0;
    visibility:hidden;
    pointer-events:none;
    transition:opacity 1.05s ease, visibility 1.05s ease;
    z-index:2;
}

.cover--static .cover__endcard{
    position:relative;
    inset:auto;
    width:100%;
    opacity:1;
    visibility:visible;
}

.cover__endcard-inner{
    display:block;
    width:min(86vw, 760px);
    min-height:auto;
    padding:20px 0 58px;
    position:relative;
    display:flex;
    flex-direction:column;
    align-items:center;
    gap:12px;
    transform:translateY(0) scale(1);
    opacity:0;
    transition:transform 1.15s cubic-bezier(.22,1,.36,1), opacity 1.05s ease;
    background:transparent;
    border:0;
    border-radius:0;
    box-shadow:none;
    backdrop-filter:none;
    -webkit-backdrop-filter:none;
}

.cover--static .cover__endcard-inner{
    transform:none;
    opacity:1;
}

.cover__endcard-inner::before,
.cover__endcard-inner::after{
    content:"";
    position:absolute;
    left:50%;
    transform:translateX(-50%);
    width:min(72vw, 420px);
    pointer-events:none;
}

.cover__endcard-inner::before{
    top:4px;
    height:1px;
    background:linear-gradient(90deg, rgba(255,255,255,0) 0%, rgba(255,255,255,.92) 50%, rgba(255,255,255,0) 100%);
}

.cover__endcard-inner::after{
    bottom:0;
    width:min(74vw, 540px);
    height:min(74vw, 240px);
    transform:translateX(-50%) translateY(12px);
    background:radial-gradient(circle, rgba(164,155,255,.10) 0%, rgba(164,155,255,0) 70%);
    filter:blur(14px);
    z-index:-1;
}

.cover__endcard-p4ul{
    display:block;
    margin:0 auto;
    margin-bottom:16px;
    width:min(56vw, 200px);
    height:auto;
    transform:translateY(0);
    filter:drop-shadow(0 12px 28px rgba(0,0,0,.28));
}

.cover__endcard-eyebrow{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    margin:0 auto 4px;
    padding:0 12px;
    font-family:"Montserrat", sans-serif;
    font-size:.64rem;
    font-weight:800;
    letter-spacing:.26em;
    line-height:1.2;
    text-transform:uppercase;
    color:var(--p4ul-accent);
    text-align:center;
}

.cover__endcard-title{
    max-width:min(74vw, 640px);
    margin:8px auto 8px;
    text-align:center;
    font-family:"Montserrat", sans-serif;
    font-size:clamp(1.2rem, 3vw, 2.8rem);
    line-height:1.06;
    font-weight:800;
    letter-spacing:-.048em;
    color:#ffffff;
    text-wrap:balance;
    text-shadow:0 6px 18px rgba(0,0,0,.30);
}

.cover__endcard-subtitle{
    max-width:min(68vw, 600px);
    margin:0 auto;
    text-align:center;
    font-family:"Montserrat", sans-serif;
    font-size:clamp(.92rem, 1.08vw, .98rem);
    line-height:1.58;
    color:rgba(255,255,255,.82);
    text-wrap:balance;
    text-shadow:0 4px 16px rgba(0,0,0,.22);
}

.cover__endcard{
    padding:0 0 52px 0;
}

.cover__signature{
    position:absolute;
    right:20px;
    bottom:16px;
    z-index:3;
    display:flex;
    flex-direction:column;
    align-items:flex-end;
    gap:6px;
    width:auto;
    padding:0;
    background:transparent;
    border:0;
    border-radius:0;
    box-shadow:none;
    opacity:0;
    visibility:hidden;
    pointer-events:none;
    transition:opacity .4s ease, visibility .4s ease, transform .4s ease;
}

.cover__endcard-credit{
    margin:0;
    font-family:"Montserrat", sans-serif;
    font-size:.72rem;
    font-weight:600;
    letter-spacing:.16em;
    text-transform:uppercase;
    color:rgba(255,255,255,.72);
    text-shadow:0 1px 4px rgba(0,0,0,.16);
    text-align:right;
}

.cover__endcard-link{
    display:flex;
    align-items:center;
    justify-content:flex-end;
    pointer-events:auto;
    cursor:pointer;
    width:auto;
    max-width:none;
    min-height:auto;
    padding:0;
    background:none;
    border:0;
    box-shadow:none;
    transition:transform .35s ease, opacity .35s ease;
}

.cover__endcard-link:hover,
.cover__endcard-link:focus-visible{
    transform:translateY(-2px);
    opacity:1;
}

.cover__endcard-nier{
    display:block;
    width:118px;
    height:auto;
    opacity:1;
    margin:0 auto;
    filter:drop-shadow(0 1px 3px rgba(0,0,0,.10));
}

.cover--ended::after,
.cover--ended .cover__endcard{
    opacity:1;
    visibility:visible;
}

.cover--ended .cover__video{
    opacity:0;
    filter:none;
    transition:opacity 1.2s ease, filter 1.2s ease !important;
}

.cover--ended .cover__scroll{
    opacity:1;
    visibility:visible;
    pointer-events:auto;
    transform:translateX(-50%);
}

.cover--ended .cover__signature{
    opacity:1;
    visibility:visible;
    pointer-events:auto;
}

.cover--ended .cover__endcard-inner{
    transform:translateY(0) scale(1);
    opacity:1;
}

@keyframes MoveUpDown{
    0%,100%{transform:translateY(0)}
    50%{transform:translateY(-24px)}
}

.homepage-hero-title,
.homepage-section-title{
    font-family:"Montserrat", sans-serif;
}

.homepage-section-title{
    color:var(--p4ul-primary-deep);
}

.homepage-hero-title,
.homepage-section-title{
    max-width:none !important;
    color:var(--p4ul-primary-deep);
}

.homepage-hero-title{
    font-size:clamp(2.4rem,4.3vw,4rem) !important;
    line-height:1.08;
    margin-bottom:24px !important;
    letter-spacing:-0.03em;
    text-align:center;
    margin-left:auto;
    margin-right:auto;
}

.homepage-section-title{
    font-size:clamp(2rem,3.4vw,3rem);
    line-height:1.12;
    margin-bottom:24px !important;
    letter-spacing:-0.02em;
}

.homepage-copy{
    font-size:clamp(1.05rem,1.5vw,1.32rem) !important;
    line-height:1.68;
    color:var(--p4ul-text);
    margin-bottom:10px;
}

.homepage-copy--lead{
    max-width:700px;
    margin-left:0;
    margin-right:0;
}

.homepage-copy--intro{
     max-width:980px;
    margin-bottom:32px;
}

#perchi .homepage-section-title,
#perchi .homepage-copy--intro{
    text-align:center;
    margin-left:auto;
    margin-right:auto;
}

.intro#intro .intro__container{
    display:flex;
    flex-wrap:wrap;
    align-items:center;
    align-content:flex-start;
    justify-content:flex-start;
    gap:40px;
    width:100%;
    min-height:100%;
    padding-top:56px;
    padding-bottom:56px;
    position:relative;
    z-index:0;
}

.intro#intro{
    display:flex;
    align-items:center;
    position:relative;
    overflow:hidden;
    scroll-margin-top:112px;
    min-height:calc(100svh - 56px);
    min-height:calc(100vh - 56px);
    min-height:calc(100dvh - 56px);
    background:#ffffff;
}

.homepage-hero-heading{
    width:100%;
    position:relative;
    z-index:1;
    margin-bottom:0;
    margin-top:0;
}

.homepage-hero-body{
    width:100%;
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:36px;
    position:relative;
    z-index:1;
}

.intro#intro .homepage-hero-body .intro__left{
    width:57%;
}

.intro#intro .homepage-hero-body .intro__right{
    width:43%;
    position:relative;
    display:flex;
    align-items:center;
    justify-content:center;
}

.homepage-image{
    display:block;
    max-width:100%;
    height:auto;
}

.homepage-image--hero{
    margin-left:0 !important;
    margin-top:0 !important;
    max-width:80%;
    position:relative;
    z-index:1;
}

.intro#intro .homepage-hero-body .intro__right img{
    display:block;
    width:100%;
    max-width:100%;
    margin-left:0;
    margin-top:0;
    max-height:410px;
    height:auto;
    position:relative;
    z-index:1;
    filter:none;
}

.intro#intro .homepage-hero-body .intro__right::before{
    content:"";
    position:absolute;
    inset:8% 8%;
    border-radius:28px;
    background:linear-gradient(180deg, rgba(255,255,255,.82) 0%, rgba(255,255,255,.42) 100%);
    border:1px solid var(--p4ul-border);
    box-shadow:0 24px 60px rgba(23,56,74,.08);
    backdrop-filter:blur(8px);
    z-index:0;
}

.intro#intro h1{
    color:#111111 !important;
    font-size:clamp(40px, 4.6vw, 68px);
    line-height:.96;
    letter-spacing:-.04em;
    margin-bottom:20px;
    max-width:none;
}

.intro#intro .homepage-hero-title{
    color:#111111 !important;
    text-align:center;
    max-width:none;
    margin-left:auto;
    margin-right:auto;
}

.intro#intro p,
.intro#intro .homepage-copy{
    color:#5f5f5f !important;
    font-size:clamp(1.05rem, 1.5vw, 1.32rem) !important;
    line-height:1.68;
    max-width:760px;
}

.intro#intro strong,
.intro#intro b{
    font-weight:700;
    color:#111111;
}

.intro#intro .homepage-copy{
    margin-bottom:18px;
}

.homepage-copy--lead{
    max-width:100%;
    margin-left:0;
    margin-right:0;
 
}


.homepage-image--offset{
    margin-left:0 !important;
}

.homepage-image--normativa{
    margin-left:60px !important;
    margin-top:200px !important;
    max-width:100%;
}

.homepage-cta-panel{
    max-width:1060px;
    margin:32px auto 18px;
}

.homepage-cta-title{
    margin:0 auto 6px;
    max-width:820px;
    font-size:clamp(1.55rem,2.35vw,2.05rem);
    line-height:1.2;
    color:var(--p4ul-contrast);
}

.homepage-cta-text{
    margin:0;
    font-size:clamp(1.08rem,1.7vw,1.42rem);
    color:var(--p4ul-text-soft);
}

.homepage-list{
    margin:0 0 18px 20px;
    padding:0;
    list-style:disc;
}

.homepage-list li{
    margin-bottom:8px;
    font-size:clamp(1.05rem,1.5vw,1.32rem);
    line-height:1.6;
    color:var(--p4ul-text);
}

.homepage-text-offset{
    margin-left:20px;
}

.icons{
    background:
      radial-gradient(circle at 1px 1px, rgba(255,255,255,.06) 1px, transparent 0) 0 0/18px 18px,
      linear-gradient(180deg, var(--p4ul-navy) 0%, var(--p4ul-navy-deep) 100%);
    color:rgba(255,255,255,.86);
    min-height:calc(100svh - 56px);
    display:flex;
    align-items:center;
    padding-block:clamp(48px,5.5vh,76px);
    border-top:0;
    border-bottom:0;
}

.icons__container{
    width:100%;
    display:flex;
    flex-direction:column;
    align-items:center;
    min-height:100%;
}

.icons__container > h2{
    color:#f8fafc;
    text-align:center;
    margin:0 auto 28px;
    max-width:none;
    white-space:nowrap;
    font-size:clamp(2.05rem, 3.8vw, 3.45rem);
    line-height:.95;
    letter-spacing:-.04em;
    text-transform:none;
    text-shadow:0 8px 26px rgba(0,0,0,.24);
}

.icons__layout{
    display:grid;
    grid-template-columns:minmax(0,.95fr) minmax(300px,.9fr);
    gap:clamp(24px,3.2vw,36px);
    align-items:start;
    width:100%;
}

.icons__features{
    width:100%;
    margin:18px 0 30px;
}

.icons__points{
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:18px;
    position:relative;
    padding:0;
    align-self:start;
}

.icons__points::before{
    content:none;
}

.icons__point{
    display:grid;
    gap:16px;
    grid-template-columns:1fr;
    align-items:start;
    padding:22px 20px 20px;
    border-radius:3px;
    background:rgba(36,43,55,.9);
    border:1px solid rgba(255,255,255,.06);
    box-shadow:0 10px 26px rgba(0,0,0,.16);
    min-height:190px;
}

.icons__point:nth-child(odd),
.icons__point:nth-child(even){
    grid-column:auto;
    padding-left:20px;
    padding-right:20px;
}

.icons__point-icon{
    width:26px;
    height:26px;
    border-radius:0;
    display:grid;
    place-items:center;
    background:none;
    border:0;
    color:var(--p4ul-accent);
    box-shadow:none;
}

.icons__point-badge{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    width:100%;
    height:100%;
    font-size:1.1rem;
    font-weight:700;
    letter-spacing:0;
}

.icons__point-body{
    display:grid;
    gap:10px;
    padding-top:4px;
}

.icons__point-body h3{
    margin:0;
    font-size:1.02rem;
    color:#f8fafc;
    font-weight:800;
}

.icons__point-body p{
    margin:0;
    max-width:none;
    line-height:1.5;
    color:rgba(255,255,255,.72);
}

.icons__lead{
    display:grid;
    gap:16px;
    position:sticky;
    top:clamp(24px,4vh,48px);
    align-self:start;
    justify-items:start;
    text-align:left;
}

.icons__lead-frame{
    display:grid;
    gap:18px;
    justify-items:start;
    width:100%;
    max-width:540px;
    padding:0;
    border:0;
    background:none;
    box-shadow:none;
}

.icons__lead-badge{
    margin:0;
    color:#f8fafc;
    font-size:.78rem;
    font-weight:800;
    letter-spacing:.16em;
    text-transform:none;
    padding:0;
    background:none;
    border:0;
}

.icons__lead-title{
    margin:0;
    color:#ffffff;
    font-size:clamp(2rem, 4vw, 3.45rem);
    line-height:.98;
    letter-spacing:-.05em;
    font-weight:900;
    text-transform:none;
}

.icons__lead-copy{
    margin:0;
    max-width:52ch;
    color:rgba(255,255,255,.76);
    font-size:1rem;
    line-height:1.7;
}

.icons__lead-list{
    list-style:none !important;
    margin:6px 0 0;
    padding:0;
    display:grid;
    gap:14px;
}

.icons__lead-list li::marker{
    content:"";
}

.icons__lead-list li{
    position:relative;
    padding-left:32px;
    color:rgba(255,255,255,.9);
    line-height:1.55;
}

.icons__lead-list li::before{
    content:"?";
    position:absolute;
    left:0;
    top:0;
    width:22px;
    height:22px;
    border-radius:50%;
    display:grid;
    place-items:center;
    color:var(--p4ul-accent);
    border:1px solid var(--p4ul-accent);
    font-size:.82rem;
    line-height:1;
}

.icons#vantaggi .icons__point{
    background:rgba(14,20,29,.94);
    border-color:rgba(255,255,255,.06);
    box-shadow:none;
    border-radius:2px;
    min-height:unset;
    padding:17px 17px 16px;
    gap:10px;
}

.icons#vantaggi{
    background:
      radial-gradient(circle at 1px 1px, rgba(255,255,255,.06) 1px, transparent 0) 0 0/18px 18px,
      linear-gradient(180deg, #12233D 0%, #0B1324 100%) !important;
    color:rgba(255,255,255,.86);
    border-top:0;
    border-bottom:0;
}

.icons#vantaggi .icons__points{
    gap:16px;
}

.icons#vantaggi .icons__lead{
    padding-top:4px;
}

.icons#vantaggi .icons__point-body h3{
    color:#ffffff;
    font-size:1rem;
}

.icons#vantaggi .icons__point-body p,
.icons#vantaggi .icons__lead-copy,
.icons#vantaggi .icons__lead-list li{
    color:rgba(255,255,255,.76);
}

.icons#vantaggi .icons__lead-badge{
    color:rgba(255,255,255,.96);
    letter-spacing:.18em;
}

.icons#vantaggi .icons__lead-list li::before{
    color:var(--p4ul-accent);
    border-color:var(--p4ul-accent);
}

@media (max-width: 1100px){
    .icons{
        min-height:auto;
    }

    .icons__layout{
        grid-template-columns:1fr;
    }

    .icons__points{
        grid-template-columns:1fr 1fr;
    }

    .icons__lead{
        position:relative;
        top:auto;
    }
}

@media (max-width: 720px){
    .icons{
        padding-block:44px 36px;
    }

    .icons__container > h2{
        white-space:normal;
        margin-bottom:20px;
        max-width:15ch;
    }

    .icons__points{
        grid-template-columns:1fr;
    }

    .icons__point{
        min-height:auto;
    }

    .icons__lead-title{
        font-size:clamp(1.55rem, 9vw, 2.2rem);
        line-height:1.02;
    }

.icons__lead-copy{
        font-size:.96rem;
    }
}



/* Icon legibility override */
.service-feature__icon{
    width:60px !important;
    height:60px !important;
}

.service-feature__icon img{
    width:30px !important;
    height:30px !important;
}

.module-card__icon{
    width:60px !important;
    height:60px !important;
}

.module-card__icon img{
    width:28px !important;
    height:28px !important;
}

/* Final cohesion layer */
.service-standard,
.module-card{
    border-radius:18px;
    box-shadow:0 16px 34px rgba(67,55,168,.08);
}

.service-standard{
    background:linear-gradient(180deg, rgba(255,255,255,.98) 0%, #F7FAFD 100%);
    border-color:rgba(67,55,168,.09);
}

.module-card{
    background:linear-gradient(180deg, rgba(255,255,255,.98) 0%, rgba(248,251,254,.94) 100%);
    border-color:rgba(108,99,240,.12);
}

.service-feature__icon,
.module-card__icon{
    border-radius:10px;
}

.service__standards,
.service__features,
.features__modules{
    gap:18px;
}

.service__intro,
.features__intro{
    gap:10px;
}

.service__features{
    padding-top:14px;
}

.icons__point{
    border-radius:18px;
    box-shadow:0 14px 34px rgba(0,0,0,.18);
}

.icons__point-body{
    gap:6px;
}

.icons__point-body h3{
    font-size:1rem;
}

.icons#vantaggi .icons__point{
    background:rgba(14,20,29,.96);
    border-color:rgba(255,255,255,.06);
}

.icons#vantaggi .icons__lead-title{
    font-size:clamp(1.62rem, 2.8vw, 2.45rem);
}

@media (max-width: 720px){
    .icons__container > h2{
        max-width:15ch;
        margin-bottom:20px;
    }

.icons__lead-title{
    font-size:clamp(1.55rem, 9vw, 2.2rem);
    line-height:1.02;
}
}

/* Final visual unifier: keep the page feeling like one system. */
.service__standards,
.service__features,
.features__modules,
.icons__points{
    gap:18px;
}

.service-standard,
.module-card{
    border-radius:18px;
    box-shadow:0 16px 34px rgba(67,55,168,.08);
}

.service-standard{
    background:linear-gradient(180deg, rgba(255,255,255,.98) 0%, #F7FAFD 100%);
    border-color:rgba(67,55,168,.09);
}

.module-card{
    background:linear-gradient(180deg, rgba(255,255,255,.98) 0%, rgba(248,251,254,.94) 100%);
    border-color:rgba(108,99,240,.12);
}

.service-feature__icon,
.module-card__icon{
    border-radius:10px;
}

.service__title,
.features__intro .homepage-section-title,
.icons__container > h2{
    letter-spacing:-.04em;
}

.service__intro,
.features__intro{
    gap:10px;
}

.service__features{
    padding-top:14px;
}

.service{
    background:
        radial-gradient(circle at top left, rgba(108,99,240,.08), transparent 30%),
        radial-gradient(circle at bottom right, rgba(220,53,69,.05), transparent 24%),
        linear-gradient(180deg, var(--p4ul-surface) 0%, #F5F8FC 100%);
    padding:88px 0 84px;
    color:var(--p4ul-text);
}

.service__container{
    display:grid;
    gap:34px;
}

.service__intro{
    display:grid;
    justify-items:center;
    gap:14px;
    text-align:center;
}

.service__title{
    margin:0;
    font-family:"Montserrat", sans-serif;
    font-size:clamp(1.72rem, 3vw, 2.62rem);
    line-height:1.08;
    letter-spacing:-.03em;
    font-weight:850;
    color:var(--p4ul-primary-deep);
}

.service__subtitle{
    margin:0;
    max-width:64ch;
    font-size:1.04rem;
    line-height:1.6;
    color:var(--p4ul-text-soft);
}

.service__standards{
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:10px;
    margin-top:2px;
}

.service-standard{
    min-height:104px;
    padding:13px 12px 11px;
    display:grid;
    align-content:center;
    justify-items:center;
    text-align:center;
    background:#ffffff;
    border:1px solid rgba(67,55,168,.08);
    box-shadow:0 10px 20px rgba(67,55,168,.05);
    gap:6px;
    position:relative;
    overflow:hidden;
    transform:translateY(0);
    transition:transform .22s ease, box-shadow .22s ease, border-color .22s ease, background .22s ease;
}

.service-standard::before{
    content:"";
    position:absolute;
    inset:0 0 auto 0;
    height:3px;
    background:linear-gradient(90deg, var(--p4ul-primary) 0%, var(--p4ul-primary-deep) 55%, var(--p4ul-accent) 100%);
    opacity:.9;
}

.service-standard::after{
    content:"";
    position:absolute;
    inset:auto -18% -24% auto;
    width:82px;
    height:82px;
    border-radius:999px;
    background:radial-gradient(circle, rgba(108,99,240,.08) 0%, rgba(108,99,240,0) 68%);
    pointer-events:none;
}

.service-standard:hover{
    transform:translateY(-3px);
    border-color:rgba(67,55,168,.14);
    box-shadow:0 16px 28px rgba(67,55,168,.08);
    background:linear-gradient(180deg, rgba(255,255,255,.99) 0%, #f6f9fd 100%);
}

.service-standard:hover .service-standard__code{
    color:var(--p4ul-primary-ink);
}

.service-standard__icon{
    width:30px;
    height:30px;
    display:grid;
    place-items:center;
    color:var(--p4ul-accent);
    flex:0 0 auto;
    position:relative;
    z-index:1;
}

.service-standard__icon svg{
    width:100%;
    height:100%;
    display:block;
}

.service-standard__icon--environment{
    color:#7B74F7;
}

.service-standard__icon--safety{
    color:#ff6a63;
}

.service-standard__icon--energy{
    color:#ff9f3a;
}

.service-standard__icon--fire{
    color:#ff7b2f;
}

.service-standard__icon--seveso{
    width:32px;
    height:32px;
    border-radius:999px;
    border:2px solid rgba(67,55,168,.22);
    color:var(--p4ul-primary-deep);
    font-size:.64rem;
    font-weight:900;
    letter-spacing:.04em;
    line-height:1;
}

.service-standard__icon-text{
    display:block;
    transform:translateY(1px);
}

.service-standard__code{
    margin:0;
    color:var(--p4ul-primary-deep);
    font-size:.86rem;
    font-weight:850;
    line-height:1.08;
    position:relative;
    z-index:1;
}

.service-standard__label{
    margin:0;
    color:var(--p4ul-text-soft);
    font-size:.6rem;
    font-weight:800;
    letter-spacing:.10em;
    position:relative;
    z-index:1;
}

.service__process{
    display:grid;
    grid-template-columns:minmax(0,.76fr) minmax(480px,1.42fr);
    gap:0;
    margin-top:10px;
    align-items:start;
    padding:24px 24px;
    border:1px solid rgba(67,55,168,.08);
    border-radius:32px;
    background:
        radial-gradient(circle at top right, rgba(108,99,240,.05) 0%, rgba(108,99,240,0) 28%),
        linear-gradient(180deg, rgba(255,255,255,.97) 0%, rgba(248,251,254,.95) 100%);
    box-shadow:0 18px 34px rgba(67,55,168,.06);
}

.service__process-head{
    display:grid;
    gap:8px;
    max-width:680px;
}

.service__process-label{
    margin:0;
    color:var(--p4ul-accent);
    font-size:.78rem;
    font-weight:800;
    letter-spacing:.18em;
    text-transform:uppercase;
}

.service__process-title{
    
    color:var(--p4ul-primary-deep);
    font-size:clamp(1.34rem, 2.1vw, 2.05rem);
    line-height:1.08;
    letter-spacing:-.04em;
    font-weight:900;
   
}

.service__process-subtitle{
    margin:0;
    max-width:64ch;
    color:var(--p4ul-text-soft);
    font-size:1.03rem;
    line-height:1.7;
}

.service__steps{
    list-style:none;
    margin:0;
    padding:0;
    display:grid;
    gap:14px;
    position:relative;
    max-width:none;
}

.service__steps::before{
    content:"";
    position:absolute;
    left:23px;
    top:16px;
    bottom:16px;
    width:2px;
    border-radius:999px;
    background:linear-gradient(180deg, rgba(108,99,240,.14) 0%, rgba(67,55,168,.08) 45%, rgba(220,53,69,.16) 100%);
}

.service__dashboard{
    margin-top:0;
    padding:0;
    width:100%;
    border:0;
    border-radius:0;
    background:transparent;
    box-shadow:none;
    align-self:start;
    position:relative;
    overflow:visible;
}

.service__dashboard::before{
    display:none;
}

.service__dashboard img{
    display:block;
    width:100%;
    height:auto;
    border-radius:20px;
    transform:translateZ(0);
}

.service__dashboard:hover{
    transform:none;
    box-shadow:none;
}

.service__aside{
    display:grid;
    gap:10px;
    align-content:start;
    padding-left:14px;
    border-left:1px solid rgba(67,55,168,.05);
}

.service__highlights{
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:10px;
    margin-top:2px;
}

.service__highlight{
    display:grid;
    gap:6px;
    padding:14px 14px 13px;
    border-radius:18px;
    border:1px solid rgba(67,55,168,.10);
    background:linear-gradient(180deg, rgba(255,255,255,.98) 0%, rgba(246,249,252,.96) 100%);
    box-shadow:0 12px 22px rgba(67,55,168,.06);
}

.service__highlight span{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    width:30px;
    height:30px;
    border-radius:999px;
    background:rgba(108,99,240,.10);
    color:var(--p4ul-primary-deep);
    font-size:.75rem;
    font-weight:900;
    letter-spacing:.06em;
}

.service__highlight p{
    margin:0;
    color:var(--p4ul-text);
    font-size:.92rem;
    line-height:1.35;
    font-weight:700;
}

.service__standards{
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:3px;
    margin-top:0;
}

.service-standard{
    min-height:42px;
    padding:0;
    gap:5px;
    background:transparent;
    border:0;
    box-shadow:none;
    display:flex;
    align-items:center;
    justify-items:start;
    text-align:left;
}

.service-standard__icon{
    width:26px;
    height:26px;
    align-self:center;
    flex:0 0 auto;
}

.service-standard__icon--seveso{
    width:26px;
    height:26px;
    font-size:.56rem;
}

.service-standard__code{
    display:block;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
    font-size:.73rem;
    font-weight:800;
    letter-spacing:-.02em;
    color:var(--p4ul-primary-deep);
    line-height:1.05;
}

.service-standard__label{
    display:block;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
    font-size:.48rem;
    font-weight:700;
    letter-spacing:.075em;
    color:var(--p4ul-text-soft);
    line-height:1.05;
}

.service-standard::before,
.service-standard::after,
.service-standard:hover::before,
.service-standard:hover::after{
    display:none;
}

.service-standard:hover{
    transform:none;
    background:transparent;
    box-shadow:none;
}

.service-step{
    display:grid;
    grid-template-columns:48px minmax(0,1fr);
    gap:16px;
    align-items:start;
    padding:8px 0;
    position:relative;
}

.service-step + .service-step{
    margin-top:2px;
}

.service-step__index{
    width:48px;
    height:48px;
    display:grid;
    place-items:center;
    border-radius:50%;
    border:1px solid rgba(67,55,168,.14);
    background:linear-gradient(180deg, #ffffff 0%, #f6f9fd 100%);
    color:var(--p4ul-primary-deep);
    font-size:.72rem;
    font-weight:900;
    letter-spacing:.08em;
    box-shadow:0 8px 16px rgba(67,55,168,.08);
    z-index:1;
    position:relative;
}

.service-step__index::before{
    content:"";
    position:absolute;
    inset:-3px;
    border-radius:inherit;
    border:1px solid rgba(220,53,69,.12);
    pointer-events:none;
}

.service-step__body{
    display:grid;
    gap:6px;
    padding-top:2px;
}

.service-step__body h4{
    margin:0;
    color:var(--p4ul-primary-deep);
    font-size:1.18rem;
    line-height:1.18;
    font-weight:850;
}

.service-step__body p{
    margin:0;
    color:var(--p4ul-text-soft);
    font-size:1.04rem;
    line-height:1.66;
}

.service-step:hover .service-step__index{
    border-color:rgba(220,53,69,.28);
    box-shadow:0 10px 18px rgba(220,53,69,.10);
}

.service-step:hover .service-step__body h4{
    color:var(--p4ul-primary-ink);
}

.service__features{
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:32px;
    padding-top:18px;
}

.service-feature{
    display:grid;
    gap:20px;
    justify-items:start;
    text-align:left;
}

.service-feature__icon{
    width:58px;
    height:58px;
    display:grid;
    place-items:center;
    background:#111827;
    color:#ffffff;
    border-radius:2px;
    box-shadow:0 10px 22px rgba(15,23,42,.12);
}

.service-feature__icon img{
    width:30px;
    height:30px;
    object-fit:contain;
    filter:brightness(100%) contrast(100%);
}

.service-feature__body{
    display:grid;
    gap:8px;
}

.service-feature__body h3{
    margin:0;
    font-size:1.48rem;
    line-height:1.15;
    letter-spacing:-.03em;
    color:var(--p4ul-primary-deep);
}

.service-feature__body p{
    margin:0;
    max-width:34ch;
    font-size:1.03rem;
    line-height:1.7;
    color:var(--p4ul-text-soft);
}

@media (max-width: 1100px){
    .service__process{
        grid-template-columns:1fr;
        gap:14px;
        padding:18px;
    }

    .service__standards{
        grid-template-columns:repeat(2,minmax(0,1fr));
    }

    .service__aside{
        padding-left:0;
        border-left:0;
    }

    .service__highlights{
        grid-template-columns:repeat(3,minmax(0,1fr));
    }

    .service__steps{
        gap:14px;
    }

    .service__dashboard{
        padding:12px;
        border-radius:20px;
    }

    .service__features{
        grid-template-columns:1fr;
        gap:24px;
    }

    .service-feature__body p{
        max-width:none;
    }
}

@media (max-width: 620px){
    .service__standards{
        grid-template-columns:1fr;
    }

    .service__highlights{
        grid-template-columns:1fr;
    }
}

@media (max-width: 720px){
    .service{
        padding:64px 0 60px;
    }

    .service__standards{
        grid-template-columns:1fr;
    }

    .service-standard{
        min-height:auto;
        padding:12px 10px 10px;
    }

    .service-standard__icon{
        width:28px;
        height:28px;
    }

    .service-standard__icon--seveso{
        width:30px;
        height:30px;
    }

    .service-step{
        grid-template-columns:42px minmax(0,1fr);
        gap:14px;
    }

    .service__steps::before{
        left:19px;
    }

    .service-step__index{
        width:42px;
        height:42px;
        font-size:.68rem;
    }

    .service-step__body h4{
        font-size:1.08rem;
    }

    .service-step__body p{
        font-size:1rem;
    }

    .service__dashboard img{
        border-radius:14px;
    }

    .service__highlights{
        grid-template-columns:1fr;
    }
}

.icons{
    background:
      radial-gradient(circle at 1px 1px, rgba(255,255,255,.06) 1px, transparent 0) 0 0/18px 18px,
      linear-gradient(180deg, var(--p4ul-navy) 0%, var(--p4ul-navy-deep) 100%);
    color:rgba(255,255,255,.86);
    border-top:0;
    border-bottom:0;
}

.icons__container > h2{
    color:#f8fafc;
    text-align:center;
    margin:0 auto 24px;
    max-width:none;
    white-space:nowrap;
    font-size:clamp(2.2rem, 4.2vw, 4rem);
    line-height:.95;
    letter-spacing:-.04em;
    text-transform:none;
    text-shadow:0 8px 26px rgba(0,0,0,.24);
}

.icons__layout{
    grid-template-columns:minmax(0,.95fr) minmax(300px,.9fr);
    gap:clamp(24px,3.5vw,40px);
}

.icons__points{
    gap:18px;
    padding:0;
}

.icons__points::before{
    content:none;
}

.icons__point{
    gap:16px;
    grid-template-columns:1fr;
    padding:22px 20px 20px;
    border-radius:3px;
    background:rgba(20,28,38,.96);
    border:1px solid rgba(255,255,255,.08);
    box-shadow:0 12px 30px rgba(0,0,0,.24);
    min-height:190px;
}

.icons__point:nth-child(odd),
.icons__point:nth-child(even){
    grid-column:auto;
    padding-left:20px;
    padding-right:20px;
}

.icons__point-icon{
    width:26px;
    height:26px;
    border-radius:0;
    background:none;
    border:0;
    color:var(--p4ul-accent);
    box-shadow:none;
}

.icons__point-badge{
    font-size:1.1rem;
    letter-spacing:0;
}

.icons__point-body{
    gap:10px;
    padding-top:4px;
}

.icons__point-body h3{
    color:#ffffff;
    font-size:1.08rem;
    font-weight:800;
}

.icons__point-body p{
    color:rgba(255,255,255,.86);
    line-height:1.58;
}

.icons__lead{
    justify-items:start;
    text-align:left;
    position:sticky;
    top:clamp(24px,4vh,48px);
}

.icons__lead-frame{
    justify-items:start;
    max-width:540px;
    padding:0;
    background:none;
    border:0;
    box-shadow:none;
}

.icons__lead-badge{
    color:rgba(255,255,255,.94);
    font-size:.78rem;
    font-weight:800;
    letter-spacing:.16em;
    text-transform:none;
    padding:0;
    background:none;
    border:0;
}

.icons__lead-title{
    margin:0;
    color:#ffffff;
    font-size:clamp(2rem, 4vw, 3.45rem);
    line-height:.98;
    letter-spacing:-.05em;
    font-weight:900;
}

.icons__lead-copy{
    margin:0;
    max-width:52ch;
    color:rgba(255,255,255,.88);
    font-size:1rem;
    line-height:1.7;
}

.icons__lead-list{
    list-style:none !important;
    margin:6px 0 0;
    padding:0;
    display:grid;
    gap:14px;
}

.icons__lead-list li::marker{
    content:"";
}

.icons__lead-list li{
    position:relative;
    padding-left:32px;
    color:rgba(255,255,255,.94);
    line-height:1.55;
}

.icons__lead-list li::before{
    content:"?";
    position:absolute;
    left:0;
    top:0;
    width:22px;
    height:22px;
    border-radius:50%;
    display:grid;
    place-items:center;
    color:var(--p4ul-accent);
    border:1px solid var(--p4ul-accent);
    font-size:.82rem;
    line-height:1;
}

@media (max-width: 1100px){
    .icons{
        min-height:auto;
    }

    .icons__layout{
        grid-template-columns:1fr;
    }

    .icons__points{
        grid-template-columns:1fr 1fr;
    }

    .icons__lead{
        position:relative;
        top:auto;
    }
}

@media (max-width: 720px){
    .icons{
        padding-block:44px 36px;
    }

    .icons__container > h2{
        white-space:normal;
        margin-bottom:20px;
        max-width:15ch;
    }

    .icons__points{
        grid-template-columns:1fr;
    }

    .icons__point{
        min-height:auto;
    }

    .icons__lead-title{
        font-size:clamp(1.55rem, 9vw, 2.2rem);
        line-height:1.02;
    }

    .icons__lead-copy{
        font-size:.96rem;
    }
}



/* Final override to keep all core sections visually aligned. */
.service-standard,
.module-card{
    border-radius:18px;
    box-shadow:0 16px 34px rgba(67,55,168,.08);
}

.service-standard{
    background:linear-gradient(180deg, rgba(255,255,255,.98) 0%, #F7FAFD 100%);
    border-color:rgba(67,55,168,.09);
}

.module-card{
    background:linear-gradient(180deg, rgba(255,255,255,.98) 0%, rgba(248,251,254,.94) 100%);
    border-color:rgba(108,99,240,.12);
}

.service-feature__icon,
.module-card__icon{
    border-radius:10px;
}

.service__standards,
.service__features,
.features__modules{
    gap:18px;
}

.service__intro,
.features__intro{
    gap:10px;
}

.service__features{
    padding-top:14px;
}

.icons__point{
    border-radius:18px;
    box-shadow:0 14px 34px rgba(0,0,0,.18);
}

.icons__point-body{
    gap:6px;
}

.icons__point-body h3{
    font-size:1rem;
}

.icons#vantaggi .icons__point{
    background:rgba(14,20,29,.96);
    border-color:rgba(255,255,255,.06);
}

.icons#vantaggi .icons__lead-title{
    font-size:clamp(1.62rem, 2.8vw, 2.45rem);
}

@media (max-width: 720px){
    .icons__container > h2{
        max-width:15ch;
        margin-bottom:20px;
    }

    .icons__lead-title{
        font-size:clamp(1.55rem, 9vw, 2.2rem);
        line-height:1.02;
    }
}

.icons__layout{
    display:grid;
    grid-template-columns:minmax(0,1.15fr) minmax(300px,.85fr);
    gap:clamp(24px,3.5vw,40px);
    align-items:start;
    width:100%;
}

.icons__lead{
    display:grid;
    gap:16px;
    position:sticky;
    top:clamp(24px,4vh,48px);
    justify-items:center;
    text-align:center;
    align-self:start;
}

.icons__lead-frame{
    display:grid;
    gap:14px;
    justify-items:center;
    width:min(100%, 520px);
    padding:0;
    border-radius:0;
    background:none;
    border:0;
    box-shadow:none;
    backdrop-filter:none;
}

.icons__lead-badge{
    margin:0;
    padding:8px 14px;
    border-radius:999px;
    background:rgba(108,99,240,.10);
    border:1px solid var(--p4ul-border);
    color:var(--p4ul-primary-deep);
    font-size:.72rem;
    font-weight:800;
    letter-spacing:.12em;
    text-transform:uppercase;
    white-space:nowrap;
}

.icons__lead-visual{
    display:grid;
    gap:10px;
    width:100%;
    padding:0;
    border:0;
    background:none;
    box-shadow:none;
}

.icons__lead-visual img{
    width:100%;
    height:auto;
    display:block;
    border-radius:0;
    box-shadow:none;
}

.icons__lead-caption{
    max-width:420px;
    margin:0;
    color:var(--p4ul-text-soft);
    line-height:1.55;
}

.icons__list{
    display:grid;
    gap:14px;
}

.icons__list .icons__item{
    display:grid;
    grid-template-columns:64px minmax(0,1fr);
    gap:16px;
    align-items:start;
    padding:18px 20px;
    background:rgba(255,255,255,.74);
    border:1px solid var(--p4ul-border);
    border-radius:22px;
}

.icons__list .icons__item img{
    width:52px;
    height:52px;
    margin-top:2px;
}

.icons__list .icons__item div{
    display:grid;
    gap:6px;
}

.icons__list .icons__item h3{
    font-size:1.05rem;
}

.icons__list .icons__item p{
    font-size:.95rem;
    opacity:.88;
    max-width:none;
}

.icons__list .icons__item:hover,
.icons__list .icons__item:focus-within{
    transform:translateY(-3px);
}

.icons__points{
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:0 34px;
    position:relative;
    padding:8px 18px 0;
    align-self:center;
}

.icons__points::before{
    content:"";
    position:absolute;
    top:0;
    bottom:0;
    left:50%;
    width:1px;
    background:linear-gradient(180deg, rgba(108,99,240,.05) 0%, rgba(108,99,240,.26) 20%, rgba(108,99,240,.26) 80%, rgba(108,99,240,.05) 100%);
    transform:translateX(-50%);
}

.icons__point{
    display:grid;
    grid-template-columns:52px minmax(0,1fr);
    gap:18px;
    align-items:start;
    padding:18px 0 18px 0;
    background:none;
    border-radius:0;
    box-shadow:none;
    position:relative;
}

.icons__point:nth-child(odd){
    grid-column:1;
    padding-right:28px;
}

.icons__point:nth-child(even){
    grid-column:2;
    padding-left:28px;
}

.icons__point-icon{
    width:48px;
    height:48px;
    border-radius:50%;
    display:grid;
    place-items:center;
    background:linear-gradient(135deg, rgba(108,99,240,.12) 0%, rgba(108,99,240,.05) 100%);
    border:1px solid rgba(108,99,240,.12);
    color:var(--p4ul-primary-deep);
}

.icons__point-badge{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    width:100%;
    height:100%;
    font-size:.82rem;
    font-weight:700;
    letter-spacing:.12em;
}

.icons__point-body{
    display:grid;
    gap:4px;
    padding-top:0;
}

.icons__point-body h3{
    margin:0;
    font-size:1.08rem;
    color:var(--p4ul-primary-deep);
}

.icons__point-body p{
    margin:0;
    max-width:none;
    line-height:1.55;
    color:var(--p4ul-text-soft);
}

@media (max-width: 1100px){
    .icons__layout{
        grid-template-columns:1fr;
    }

    .icons__lead{
        position:relative;
        top:auto;
    }

    .icons__lead-frame{
        width:min(100%, 560px);
    }

    .icons{
        min-height:calc(100svh - 52px);
        align-items:flex-start;
    }

    .icons__container{
        min-height:auto;
    }

    .icons__points{
        grid-template-columns:1fr;
    }

    .icons__points::before{
        left:26px;
        transform:none;
    }

    .icons__point{
        padding:20px 0;
        grid-column:auto !important;
        padding-left:44px;
        padding-right:0;
    }
}

@media (max-width: 992px){
    .icons__lead{
        top:48px;
    }
}

@media (max-width: 720px){
    .icons{
        min-height:auto;
        padding-block:40px 32px;
    }

    .icons__container > h2{
        white-space:normal;
        max-width:20ch;
    }

    .icons__layout{
        gap:20px;
        justify-items:center;
    }

    .icons__lead,
    .icons__points,
    .icons__point{
        justify-items:center;
        text-align:center;
    }

    .icons__lead-frame{
        padding:14px;
        border-radius:26px;
        width:min(100%, 560px);
    }

    .icons__point{
        grid-template-columns:1fr;
        gap:10px;
        padding:12px 0;
    }

    .icons__point-icon{
        margin-top:0;
    }

    .icons__point-body{
        justify-items:center;
    }

    .icons__lead-badge{
        font-size:.66rem;
        letter-spacing:.1em;
    }

    .icons__lead-caption{
        font-size:.96rem;
    }
}

@media (max-width: 992px){
    .header__brand{
        margin-left:-8px;
    }

    .header__container{
        gap:12px;
        min-height:52px;
        padding-top:4px !important;
        padding-bottom:4px !important;
    }

    .header{
        min-height:52px;
    }

    .header img.homepage-header-logo{
        width:52px !important;
        transform:translateY(-2px);
    }

    .homepage-hero-title{
        font-size:clamp(1.5rem,6.2vw,2.1rem) !important;
    }

    .contacts h2{
        font-size:clamp(1.2rem, 4.8vw, 1.65rem);
        line-height:1.12;
        margin-bottom:28px;
        max-width:none;
    }

    .contacts__title{
        gap:4px;
    }

    .contacts{
        min-height:auto;
        padding-top:56px;
        padding-bottom:48px;
        display:block;
    }

    .cover__video--ended{
        opacity:0 !important;
    }

    .cover__endcard{
        padding:0;
    }

    .cover__endcard-inner{
        display:flex;
        flex-direction:column;
        align-items:center;
        justify-content:center;
        gap:16px;
        width:min(92vw, 340px);
        min-height:0;
        padding:34px 0 24px;
        transform:translateY(0) scale(1);
    }

    .cover--ended .cover__endcard-inner{
        transform:translateY(0) scale(1);
    }

    .cover__endcard-inner::before,
    .cover__endcard-inner::after{
        width:min(78vw, 240px);
    }

    .cover__endcard-p4ul{
        width:min(58vw, 176px);
        transform:translateY(0);
    }

    .cover__endcard-title{
        max-width:min(92vw, 340px);
        margin:8px auto 2px;
        font-size:clamp(1rem, 4.4vw, 1.22rem);
    }

    .cover__endcard-subtitle{
        max-width:min(92vw, 320px);
        font-size:1rem;
        line-height:1.56;
        margin-bottom:-2px;
    }

    .cover__endcard-credit{
        font-size:.5rem;
        letter-spacing:.12em;
        width:auto;
        text-align:center;
    }

    .cover__endcard-link{
        width:min(34vw, 108px);
        max-width:min(34vw, 108px);
        padding:0;
    }

    .cover__endcard-nier{
        width:min(48vw, 140px);
    }

    .cover__signature{
        right:34px;
        bottom:16px;
        gap:4px;
    }

    .cover__scroll{
        width:44px !important;
        height:44px !important;
        margin:0 !important;
        left:50% !important;
        bottom:12px !important;
        transform:translateX(-50%) !important;
        padding:8px !important;
    }

    .cover__scroll img{
        width:100% !important;
        display:block;
        margin:0 auto;
    }

    .cover{
        margin-top:52px !important;
        height:calc(100vh - 52px);
        min-height:calc(100vh - 52px);
        padding:0;
    }

    .homepage-section-title{
        font-size:clamp(1.75rem,6.5vw,2.5rem);
    }

    .intro#intro .intro__container{
        gap:20px;
        padding-top:24px;
        padding-bottom:24px;
    }

    .homepage-hero-body{
        flex-direction:column;
        gap:24px;
    }

    .intro#intro .homepage-hero-body .intro__left,
    .intro#intro .homepage-hero-body .intro__right{
        width:100%;
    }

    .intro#intro{
        background:
          linear-gradient(180deg, rgba(16,36,52,.16) 0%, rgba(222,238,245,.72) 16%, rgba(247,251,253,.98) 38%, #ffffff 100%);
        scroll-margin-top:52px;
        background:#ffffff;
        min-height:calc(100vh - 52px);
        min-height:calc(100dvh - 52px);
    }

    .intro#intro .homepage-hero-body .intro__right img{
        width:auto;
        max-width:84%;
        margin-left:auto;
        margin-right:auto;
    }

    .homepage-copy--lead{
        text-align:center;
    }

    .intro#intro .homepage-hero-body .intro__right{
        width:100%;
        padding:20px 0;
        justify-content:center;
    }

    .intro#intro .homepage-hero-body .intro__left{
        width:100%;
        transform:none;
    }

    .homepage-image--hero{
        max-width:84%;
        max-height:250px;
        transform:none;
    }

    .homepage-image--normativa{
        display:block;
        margin-top:22px !important;
        margin-left:auto !important;
        margin-right:auto !important;
    }

    .homepage-copy,
    .homepage-list li{
        font-size:1rem !important;
    }

    .icons__item{
        transform:none !important;
        padding:0 2px;
        margin-bottom:14px;
    }

    .icons__item p{
        opacity:1 !important;
        max-height:none !important;
        transform:none !important;
        overflow:visible;
    }

    .contacts{
        padding-top:48px;
        padding-bottom:40px;
    }

    .contacts form{
        padding:22px 18px 4px;
        border-radius:18px;
    }
}

@media (prefers-reduced-motion: reduce){
    .cover__video{
        animation:none !important;
    }

    .header img{
        transition:none !important;
    }
}

/** RESET **/
html,body,div,span,applet,object,iframe,h1,h2,h3,h4,h5,h6,p,blockquote,pre,a,abbr,acronym,address,big,cite,code,del,dfn,em,img,ins,kbd,q,s,samp,small,strike,strong,sub,sup,tt,var,b,u,i,center,dl,dt,dd,ol,ul,li,fieldset,form,label,legend,table,caption,tbody,tfoot,thead,tr,th,td,article,aside,canvas,details,embed,figure,figcaption,footer,header,hgroup,menu,nav,output,ruby,section,summary,time,mark,audio,video{margin:0;padding:0;border:0;font-size:100%;font:inherit;vertical-align:baseline}html{scroll-behavior:smooth}body{line-height:1}a{text-decoration-skip-ink:auto}a[href^="tel"]{color:inherit;text-decoration:none}button{outline:0}ol,ul{list-style:none}blockquote,q{quotes:none}blockquote:before,blockquote:after,q:before,q:after{content:'';content:none}q{display:inline;font-style:italic}q:before{content:'"';font-style:normal}q:after{content:'"';font-style:normal}textarea,input[type="text"],input[type="button"],input[type="submit"],input[type="reset"],input[type="search"],input[type="password"]{-webkit-appearance:none;appearance:none;border-radius:0}input[type="search"]{-webkit-appearance:textfield}table{border-collapse:collapse;border-spacing:0}th,td{padding:2px}big{font-size:120%}small,sup,sub{font-size:80%}sup{vertical-align:super}sub{vertical-align:sub}dd{margin-left:20px}kbd,tt{font-family:courier;font-size:12px}ins{text-decoration:underline}del,strike,s{text-decoration:line-through}dt{font-weight:bold}address,cite,var{font-style:italic}article,aside,details,figcaption,figure,footer,header,hgroup,menu,nav,section{display:block}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
.sticky{}.bypostauthor{}.wp-caption{}.wp-caption-text{}.gallery-caption{}.alignright{}.alignleft{}.aligncenter{}
.screen-reader-text{border:0;clip:rect(1px,1px,1px,1px);-webkit-clip-path:inset(50%);clip-path:inset(50%);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute!important;width:1px;word-wrap:normal!important;word-break:normal}
.screen-reader-text:focus{background-color:var(--p4ul-surface);border-radius:3px;box-shadow:0 0 2px 2px rgba(0,0,0,.6);clip:auto!important;-webkit-clip-path:none;clip-path:none;color:var(--p4ul-primary);display:block;font-size:14px;font-size:.875rem;font-weight:700;height:auto;right:5px;line-height:normal;padding:15px 23px 14px;text-decoration:none;top:5px;width:auto;z-index:100000}
.skip-link{left:-9999rem;top:2.5rem;z-index:999999999;text-decoration:underline}
.skip-link:focus{display:block;left:6px;top:7px;font-size:14px;font-weight:600;text-decoration:none;line-height:normal;padding:15px 23px 14px;z-index:100000;right:auto}
.visually-hidden:not(:focus):not(:active), .form-allowed-tags:not(:focus):not(:active){position:absolute !important;height:1px;width:1px;overflow:hidden;clip:rect(1px 1px 1px 1px);clip:rect(1px, 1px, 1px, 1px);white-space:nowrap}

.features{
    padding:88px 0 54px;
}

.features__container{
    display:grid;
    gap:28px;
}

.features__intro{
    display:grid;
    gap:10px;
    max-width:1100px;
    justify-items:center;
}

.features__intro .features__eyebrow{
    margin:0;
    justify-self:center;
    font-size:.74rem;
    font-weight:800;
    letter-spacing:.24em;
    text-transform:uppercase;
    color:var(--p4ul-accent);
}

.features__intro .homepage-section-title{
    margin:0 auto;
    width:100%;
    max-width:24ch;
    text-align:center;
    color:var(--p4ul-primary-deep);
    text-wrap:balance;
}

.features__intro .homepage-copy--intro{
    width:100%;
    margin-left:auto;
    margin-right:auto;
}

.features__cards{
    display:grid;
    grid-template-columns:repeat(5,minmax(0,1fr));
    gap:14px;
    margin-top:14px;
}

.features__cards > .feature-card{
    grid-column:auto;
}

.feature-card--product{
    gap:10px;
    padding:14px;
    border-radius:20px;
}

.feature-card__badge{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-width:40px;
    padding:5px 10px;
    border-radius:999px;
    background:rgba(108,99,240,.12);
    color:var(--p4ul-primary-deep);
    font-size:.74rem;
    font-weight:800;
    letter-spacing:.14em;
    text-transform:uppercase;
}

.feature-card--product .feature-card__body{
    gap:6px;
    padding:0;
}

.feature-card--product .feature-card__body h3{
    font-size:1.05rem;
}

.feature-card--product .feature-card__body p{
    font-size:.92rem;
    line-height:1.56;
}

.features__grid{
    display:grid;
    grid-template-columns:repeat(12,minmax(0,1fr));
    gap:22px;
}

.feature-card{
    display:grid;
    gap:16px;
    padding:18px;
    border-radius:28px;
    border:1px solid var(--p4ul-border);
    background:linear-gradient(180deg,var(--p4ul-surface) 0%,#F4F8FC 100%);
    box-shadow:0 18px 40px rgba(67,55,168,.08);
    transition:transform .22s ease, box-shadow .22s ease, border-color .22s ease;
    grid-column:span 6;
}

.feature-card:hover{
    transform:translateY(-4px);
    border-color:var(--p4ul-border-strong);
    box-shadow:0 24px 48px rgba(67,55,168,.12);
}

.feature-card--wide{
    grid-template-columns:1.25fr .95fr;
    align-items:center;
    gap:24px;
}

.features__grid > .feature-card:nth-child(1),
.features__grid > .feature-card:nth-child(4){
    grid-column:1 / -1;
    grid-template-columns:1.1fr .9fr;
    align-items:center;
}

.features__grid > .feature-card:nth-child(4){
    grid-template-columns:.95fr 1.05fr;
}

.features__grid > .feature-card:nth-child(1) .feature-card__art,
.features__grid > .feature-card:nth-child(4) .feature-card__art{
    min-height:300px;
}

.features__grid > .feature-card:nth-child(2),
.features__grid > .feature-card:nth-child(3),
.features__grid > .feature-card:nth-child(5),
.features__grid > .feature-card:nth-child(6){
    grid-column:span 6;
}

.feature-card__art{
    display:flex;
    align-items:center;
    justify-content:center;
    overflow:hidden;
    min-height:260px;
    padding:12px;
    border-radius:22px;
    background:
      radial-gradient(circle at top right, rgba(164,155,255,.16), transparent 44%),
      linear-gradient(180deg, rgba(108,99,240,.06) 0%, rgba(108,99,240,.02) 100%);
}

.feature-card__art img{
    width:100%;
    height:auto;
    display:block;
}

.feature-card__body{
    display:grid;
    gap:8px;
    padding:2px 6px 10px;
}

.feature-card__label{
    font-size:.74rem;
    font-weight:800;
    letter-spacing:.18em;
    text-transform:uppercase;
    color:var(--p4ul-primary-hover);
}

.feature-card__body h3{
    margin:0;
    font-size:1.28rem;
    line-height:1.2;
    color:var(--p4ul-primary-deep);
}

.feature-card__body p{
    margin:0;
    line-height:1.68;
    color:var(--p4ul-text-soft);
}

.feature-card__list{
    margin:0;
    padding-left:18px;
    display:grid;
    gap:8px;
    color:var(--p4ul-text-soft);
    line-height:1.55;
}

.features__layout{
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:18px;
    align-items:start;
}

.features__layout > .feature-card{
    grid-column:auto;
}

.features__layout > .feature-card--hero{
    grid-template-columns:1fr;
    min-height:auto;
}

.features__layout > .feature-card--hero .feature-card__art{
    min-height:150px;
}

.features__layout > .feature-card--split{
    grid-template-columns:1fr;
}

.features__layout > .feature-card--split .feature-card__art{
    min-height:150px;
}

.features__layout > .features__stack{
    display:grid;
    gap:18px;
}

.features__layout > .features__stack > .feature-card{
    grid-column:auto;
}

.feature-card--compact{
    gap:12px;
    padding:16px;
}

.feature-card--compact .feature-card__art{
    min-height:150px;
    padding:10px;
}

.feature-card--compact .feature-card__body{
    gap:6px;
    padding:0 4px 2px;
}

.feature-card--compact .feature-card__body h3{
    font-size:1.08rem;
}

.feature-card--compact .feature-card__body p{
    line-height:1.55;
}

.feature-card__note{
    margin:0;
    color:var(--p4ul-primary-ink);
    font-size:.88rem;
    line-height:1.45;
}

.features__layout{
    grid-template-columns:repeat(5,minmax(0,1fr));
    gap:14px;
}

.features__layout > .feature-card,
.features__layout > .feature-card--hero,
.features__layout > .feature-card--split,
.features__layout > .features__stack > .feature-card{
    grid-column:auto;
    grid-template-columns:1fr;
}

.features__layout > .feature-card--hero,
.features__layout > .feature-card--split{
    min-height:auto;
}

.features__layout > .feature-card--hero .feature-card__art,
.features__layout > .feature-card--split .feature-card__art,
.features__layout > .features__stack > .feature-card .feature-card__art{
    display:none;
}

.features__layout > .features__stack{
    display:contents;
}

.feature-card{
    gap:12px;
    padding:16px;
    border-radius:22px;
}

.feature-card__body{
    gap:7px;
    padding:0;
}

.feature-card__label{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    width:max-content;
    padding:6px 10px;
    border-radius:999px;
    background:rgba(108,99,240,.10);
    color:var(--p4ul-primary-deep);
    letter-spacing:.14em;
}

.feature-card__body h3{
    font-size:1.06rem;
}

.feature-card__body p{
    font-size:.92rem;
    line-height:1.55;
}

.feature-card__list{
    padding-left:16px;
    gap:6px;
    font-size:.88rem;
}

@media (max-width: 980px){
    .homepage-hero-title{
        max-width:18ch !important;
    }

    .features{
        padding:64px 0 44px;
    }

    .features__cards{
        grid-template-columns:repeat(2,minmax(0,1fr));
    }

    .feature-card--product{
        padding:14px;
        border-radius:20px;
    }

    .feature-card--product .feature-card__body h3{
        font-size:1rem;
    }

    .feature-card--product .feature-card__body p{
        font-size:.88rem;
    }
}

@media (max-width: 360px){
    .features__cards{
        grid-template-columns:1fr;
    }
}

.features__intro{
    display:grid;
    gap:12px;
    max-width:1100px;
    margin:0 auto;
    justify-items:center;
}

.features__intro .homepage-copy{
    max-width:66ch;
    margin:0 auto;
}

#funzionamento .features__intro{
    justify-items:start;
    text-align:left;
}

#funzionamento .homepage-section-title{
    margin:0;
}

.features__steps{
    list-style:none;
    margin:26px auto 0;
    padding:0;
    max-width:760px;
    display:grid;
    gap:16px;
    position:relative;
}

.features__steps::before{
    content:"";
    position:absolute;
    left:23px;
    top:18px;
    bottom:18px;
    width:1px;
    background:linear-gradient(180deg, rgba(220,53,69,.18) 0%, rgba(220,53,69,.06) 100%);
}

.features-step{
    display:grid;
    grid-template-columns:48px minmax(0,1fr);
    gap:16px;
    align-items:start;
    padding:2px 0;
}

.features-step__index{
    width:48px;
    height:48px;
    display:grid;
    place-items:center;
    border-radius:50%;
    border:1.5px solid var(--p4ul-accent);
    background:#ffffff;
    color:var(--p4ul-accent);
    font-size:.74rem;
    font-weight:900;
    letter-spacing:.08em;
    box-shadow:0 10px 24px rgba(220,53,69,.08);
    z-index:1;
}

.features-step__body{
    display:grid;
    gap:5px;
    padding-top:3px;
}

.features-step__body h3{
    margin:0;
    color:var(--p4ul-contrast);
    font-size:1.06rem;
    line-height:1.2;
    font-weight:800;
}

.features-step__body p{
    margin:0;
    color:var(--p4ul-text-soft);
    font-size:.95rem;
    line-height:1.55;
}

.features__modules{
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:32px;
    align-items:stretch;
    margin-top:30px;
}

.module-card{
    display:grid;
    gap:24px;
    padding:36px 36px 34px;
    border-radius:26px;
    background:linear-gradient(180deg, rgba(255,255,255,.96) 0%, rgba(244,248,252,.92) 100%);
    border:1px solid rgba(108,99,240,.12);
    box-shadow:0 20px 44px rgba(67,55,168,.07);
    min-height:100%;
}

.module-card--highlight{
    border-color:rgba(108,99,240,.18);
    box-shadow:0 22px 48px rgba(67,55,168,.09);
}

.module-card__header{
    display:grid;
    grid-template-columns:62px minmax(0,1fr);
    gap:18px;
    align-items:center;
}

.module-card__icon{
    width:62px;
    height:62px;
    display:grid;
    place-items:center;
    background:rgba(108,99,240,.08);
    border-radius:12px;
}

.module-card__icon img{
    width:32px;
    height:32px;
    object-fit:contain;
}

.module-card__eyebrow{
    margin:0 0 4px;
    font-size:.78rem;
    font-weight:800;
    letter-spacing:.2em;
    text-transform:uppercase;
    color:var(--p4ul-primary-hover);
}

.module-card__titleblock h3{
    margin:0;
    font-size:clamp(1.55rem, 2vw, 2rem);
    line-height:1.05;
    letter-spacing:-.025em;
    text-transform:uppercase;
    color:var(--p4ul-contrast);
}

.module-card__lead{
    margin:0;
    max-width:60ch;
    font-size:1.08rem;
    line-height:1.72;
    color:var(--p4ul-text-soft);
}

.module-card__list{
    list-style:none;
    margin:0;
    padding:0;
    display:grid;
    gap:16px;
}

.module-card__list li{
    display:grid;
    grid-template-columns:28px minmax(0,1fr);
    align-items:center;
    gap:18px;
    padding:16px 18px;
    border-radius:2px;
    background:var(--p4ul-surface-soft);
    color:var(--p4ul-contrast);
    font-weight:700;
    letter-spacing:.01em;
    font-size:1.03rem;
    line-height:1.5;
}

.module-card__mini-icon{
    display:inline-grid;
    place-items:center;
    width:28px;
    height:28px;
    color:var(--p4ul-accent);
    font-size:1rem;
    line-height:1;
}

.module-card__mini-icon img{
    display:block;
    width:100%;
    height:100%;
    object-fit:contain;
}

.features__benefits{
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:18px;
    margin-top:22px;
}

.features__benefit{
    display:grid;
    gap:10px;
    padding:22px 22px 20px;
    border-radius:20px;
    background:linear-gradient(180deg, rgba(255,255,255,.94) 0%, rgba(244,248,252,.86) 100%);
    border:1px solid rgba(108,99,240,.10);
    box-shadow:0 14px 32px rgba(67,55,168,.06);
}

.features__benefit h3{
    margin:0;
    font-size:1.08rem;
    line-height:1.22;
    letter-spacing:-.02em;
    color:var(--p4ul-contrast);
}

.features__benefit p{
    margin:0;
    font-size:.98rem;
    line-height:1.6;
    color:var(--p4ul-text-soft);
}

.features__group{
    display:grid;
    gap:18px;
}

.features__group--support{
    margin-top:12px;
}

.features__eyebrow{
    margin:0;
    justify-self:center;
    font-size:.78rem;
    font-weight:800;
    letter-spacing:.24em;
    text-transform:uppercase;
    color:var(--p4ul-accent);
}

.features__flow{
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:22px;
    align-items:stretch;
    margin-top:0;
}

.feature-flow-card{
    display:grid;
    grid-template-columns:76px minmax(0,1fr);
    align-items:center;
    gap:18px;
    text-align:left;
    padding:22px 20px;
    border-radius:24px;
    background:linear-gradient(180deg, rgba(255,255,255,.95), rgba(244,248,252,.86));
    border:1px solid rgba(108,99,240,.10);
    box-shadow:0 16px 34px rgba(67,55,168,.05);
}

.feature-flow-card__icon{
    width:76px;
    height:76px;
    border-radius:50%;
    display:grid;
    place-items:center;
    margin:0;
    background:rgba(108,99,240,.14);
    box-shadow:0 10px 24px rgba(108,99,240,.12);
}

.feature-flow-card__icon img{
    width:34px;
    height:34px;
    object-fit:contain;
}

.feature-flow-card__body{
    display:grid;
    gap:8px;
    justify-items:start;
}

.feature-flow-card__body h3{
    margin:0;
    font-size:1.22rem;
    line-height:1.2;
    color:var(--p4ul-primary-deep);
}

.feature-flow-card__body p{
    margin:0;
    max-width:none;
    line-height:1.6;
    color:var(--p4ul-text-soft);
}

.feature-flow-card--primary .feature-flow-card__icon{
    width:88px;
    height:88px;
}

.feature-card__icon{
    width:72px;
    height:72px;
    border-radius:50%;
    display:grid;
    place-items:center;
    margin:0 auto;
    background:rgba(108,99,240,.12);
    box-shadow:0 10px 24px rgba(108,99,240,.12);
}

.feature-card__icon img{
    width:32px;
    height:32px;
    object-fit:contain;
}

.feature-flow-card--primary .feature-flow-card__body h3{
    font-size:1.3rem;
}

.features__support{
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:18px;
    margin-top:0;
    padding-top:32px;
    border-top:1px solid var(--p4ul-border);
}

.feature-card--support{
    grid-column:auto;
    display:grid;
    grid-template-columns:68px minmax(0,1fr);
    align-items:center;
    gap:16px;
    text-align:left;
    padding:18px 18px 18px 16px;
    border-radius:18px;
    background:linear-gradient(180deg, rgba(255,255,255,.88), rgba(244,248,252,.72));
    border:1px solid rgba(108,99,240,.08);
    border-left:4px solid rgba(108,99,240,.28);
    box-shadow:0 10px 22px rgba(67,55,168,.04);
}

.feature-card--support .feature-card__body{
    gap:8px;
    padding:0;
    justify-items:start;
}

.feature-card--support .feature-card__body h3{
    font-size:1.02rem;
    line-height:1.25;
}

.feature-card--support .feature-card__body p{
    font-size:.92rem;
    line-height:1.55;
}

@media (max-width: 1100px){
    .features__modules{
        grid-template-columns:1fr;
    }

    .features__benefits{
        grid-template-columns:1fr;
    }

    .module-card{
        padding:28px 24px 24px;
        gap:22px;
    }

    .features__flow{
        gap:18px;
        grid-template-columns:repeat(2,minmax(0,1fr));
    }

    .feature-flow-card--primary{
        grid-column:1 / -1;
    }

    .features__support{
        grid-template-columns:repeat(2,minmax(0,1fr));
    }
}

@media (max-width: 720px){
    .module-card__header{
        grid-template-columns:52px minmax(0,1fr);
    }

    .module-card__icon{
        width:52px;
        height:52px;
    }

    .module-card__titleblock h3{
        font-size:1.62rem;
    }

    .module-card__lead{
        font-size:1rem;
    }

    .features__flow{
        grid-template-columns:1fr;
    }

    .feature-flow-card{
        grid-template-columns:1fr;
        justify-items:center;
        text-align:center;
        padding:18px 14px 16px;
    }

    .feature-flow-card__body{
        justify-items:center;
        text-align:center;
    }

    .feature-flow-card__body p{
        max-width:30ch;
    }

    .features__support{
        grid-template-columns:1fr;
        margin-top:34px;
        padding-top:24px;
    }

    .feature-card--support{
        grid-template-columns:1fr;
        justify-items:center;
        text-align:center;
        padding:18px 14px 16px;
    }

    .feature-card--support .feature-card__body{
        justify-items:center;
        text-align:center;
    }

    .features__benefits{
        margin-top:16px;
    }

    .features__benefit{
        padding:18px 18px 17px;
    }
}

.icons{
    background:
      radial-gradient(circle at 1px 1px, rgba(255,255,255,.06) 1px, transparent 0) 0 0/18px 18px,
      linear-gradient(180deg, var(--p4ul-navy) 0%, var(--p4ul-navy-deep) 100%);
    color:rgba(255,255,255,.86);
    border-top:0;
    border-bottom:0;
}

.icons__container > h2{
    color:#f8fafc;
    text-align:center;
    margin:0 auto 24px;
    max-width:none;
    white-space:nowrap;
    font-size:clamp(2rem, 3.4vw, 3.2rem);
    line-height:.98;
    letter-spacing:-.035em;
    text-transform:none;
    text-shadow:0 8px 26px rgba(0,0,0,.24);
}

.icons__layout{
    grid-template-columns:minmax(0,.95fr) minmax(300px,.9fr);
    gap:clamp(22px,3vw,32px);
}

.icons__points{
    gap:18px;
    padding:0;
}

.icons__points::before{
    content:none;
}

.icons__point{
    gap:16px;
    grid-template-columns:1fr;
    padding:17px 17px 16px;
    border-radius:18px;
    background:rgba(14,20,29,.96);
    border:1px solid rgba(255,255,255,.06);
    box-shadow:0 14px 34px rgba(0,0,0,.18);
    min-height:190px;
}

.icons__point:nth-child(odd),
.icons__point:nth-child(even){
    grid-column:auto;
    padding-left:20px;
    padding-right:20px;
}

.icons__point-icon{
    width:26px;
    height:26px;
    border-radius:0;
    background:none;
    border:0;
    color:var(--p4ul-accent);
    box-shadow:none;
}

.icons__point-badge{
    font-size:1.1rem;
    letter-spacing:0;
}

.icons__point-body{
    gap:6px;
    padding-top:4px;
}

.icons__point-body h3{
    color:#f8fafc;
    font-size:1rem;
    font-weight:800;
}

.icons__point-body p{
    color:rgba(255,255,255,.76);
    line-height:1.5;
}

.icons__lead{
    justify-items:start;
    text-align:left;
    position:sticky;
    top:clamp(24px,4vh,48px);
}

.icons__lead-frame{
    justify-items:start;
    max-width:540px;
    padding:0;
    background:none;
    border:0;
    box-shadow:none;
}

.icons__lead-badge{
    color:rgba(255,255,255,.96);
    font-size:.78rem;
    font-weight:800;
    letter-spacing:.18em;
    text-transform:none;
    padding:0;
    background:none;
    border:0;
}

.icons__lead-title{
    margin:0;
    color:#ffffff;
    font-size:clamp(1.65rem, 2.8vw, 2.45rem);
    line-height:1;
    letter-spacing:-.04em;
    font-weight:900;
}

.icons__lead-copy{
    margin:0;
    max-width:52ch;
    color:rgba(255,255,255,.76);
    font-size:1rem;
    line-height:1.7;
}

.icons__lead-list{
    list-style:none;
    margin:6px 0 0;
    padding:0;
    display:grid;
    gap:14px;
}

.icons__lead-list li{
    position:relative;
    padding-left:32px;
    color:rgba(255,255,255,.76);
    line-height:1.55;
}

.icons__lead-list li::before{
    content:"?";
    position:absolute;
    left:0;
    top:0;
    width:22px;
    height:22px;
    border-radius:50%;
    display:grid;
    place-items:center;
    color:var(--p4ul-accent);
    border:1px solid var(--p4ul-accent);
    font-size:.82rem;
    line-height:1;
}

@media (max-width: 1100px){
    .icons{
        min-height:auto;
    }

    .icons__layout{
        grid-template-columns:1fr;
    }

    .icons__points{
        grid-template-columns:1fr 1fr;
    }

    .icons__lead{
        position:relative;
        top:auto;
    }
}

@media (max-width: 720px){
    .icons{
        padding-block:44px 36px;
    }

    .icons__container > h2{
        white-space:normal;
        margin-bottom:20px;
        max-width:15ch;
    }

    .icons__points{
        grid-template-columns:1fr;
    }

    .icons__point{
        min-height:auto;
    }

    .icons__lead-title{
        font-size:clamp(1.55rem, 9vw, 2.2rem);
        line-height:1.02;
    }

    .icons__lead-copy{
        font-size:.96rem;
    }
}


/* Absolute final lock: these values must win over historical rules above. */
.service-standard,
.module-card{
    border-radius:18px !important;
    box-shadow:0 16px 34px rgba(67,55,168,.08) !important;
}

.service-standard{
    background:linear-gradient(180deg, rgba(255,255,255,.98) 0%, #F7FAFD 100%) !important;
    border-color:rgba(67,55,168,.09) !important;
    position:relative !important;
    overflow:hidden !important;
    transform:translateY(0) !important;
    transition:transform .22s ease !important, box-shadow .22s ease !important, border-color .22s ease !important, background .22s ease !important;
}

.service-standard::before{
    content:"" !important;
    position:absolute !important;
    inset:0 0 auto 0 !important;
    height:3px !important;
    background:linear-gradient(90deg, var(--p4ul-primary) 0%, var(--p4ul-primary-deep) 55%, var(--p4ul-accent) 100%) !important;
    opacity:.9 !important;
}

.service-standard::after{
    content:"" !important;
    position:absolute !important;
    inset:auto -18% -24% auto !important;
    width:82px !important;
    height:82px !important;
    border-radius:999px !important;
    background:radial-gradient(circle, rgba(108,99,240,.08) 0%, rgba(108,99,240,0) 68%) !important;
    pointer-events:none !important;
}

.service-standard:hover{
    transform:translateY(-3px) !important;
    border-color:rgba(67,55,168,.14) !important;
    box-shadow:0 16px 28px rgba(67,55,168,.08) !important;
    background:linear-gradient(180deg, rgba(255,255,255,.99) 0%, #f6f9fd 100%) !important;
}

.module-card{
    background:linear-gradient(180deg, rgba(255,255,255,.98) 0%, rgba(248,251,254,.94) 100%) !important;
    border-color:rgba(108,99,240,.12) !important;
}

.service-feature__icon,
.module-card__icon{
    border-radius:10px !important;
}

.service-standard__icon{
    border-radius:0 !important;
    position:relative !important;
    z-index:1 !important;
}

.service-standard__icon--seveso{
    border-radius:999px !important;
}

.service-standard__code,
.service-standard__label{
    position:relative !important;
    z-index:1 !important;
}

.service__steps::before{
    width:2px !important;
    border-radius:999px !important;
    top:14px !important;
    bottom:14px !important;
    background:linear-gradient(180deg, rgba(108,99,240,.14) 0%, rgba(67,55,168,.08) 45%, rgba(220,53,69,.16) 100%) !important;
}

.service-step__index{
    border:1px solid rgba(67,55,168,.14) !important;
    background:linear-gradient(180deg, #ffffff 0%, #f6f9fd 100%) !important;
    color:var(--p4ul-primary-deep) !important;
    box-shadow:0 8px 16px rgba(67,55,168,.08) !important;
    position:relative !important;
}

.service-step__index::before{
    content:"" !important;
    position:absolute !important;
    inset:-3px !important;
    border-radius:inherit !important;
    border:1px solid rgba(220,53,69,.12) !important;
    pointer-events:none !important;
}

.service-step:hover .service-step__index{
    border-color:rgba(220,53,69,.28) !important;
    box-shadow:0 10px 18px rgba(220,53,69,.10) !important;
}

.service-step:hover .service-step__body h4{
    color:var(--p4ul-primary-ink) !important;
}

.service__standards,
.service__features,
.features__modules{
    gap:18px !important;
}

.service__aside{
    display:grid !important;
    gap:10px !important;
    align-content:start !important;
    padding-left:14px !important;
    border-left:1px solid rgba(67,55,168,.05) !important;
}

.service__standards{
    grid-template-columns:repeat(3,minmax(0,1fr)) !important;
    gap:3px !important;
    margin-top:0 !important;
}

.service-standard{
    min-height:42px !important;
    padding:0 2px !important;
    gap:5px !important;
    background:transparent !important;
    border:0 !important;
    box-shadow:none !important;
    display:flex !important;
    align-items:center !important;
    justify-items:start !important;
    text-align:left !important;
}

.service-standard__icon{
    width:26px !important;
    height:26px !important;
    align-self:center !important;
    flex:0 0 auto !important;
}

.service-standard__icon--seveso{
    width:26px !important;
    height:26px !important;
    font-size:.56rem !important;
}

.service-standard__code{
    display:block !important;
    white-space:nowrap !important;
    overflow:hidden !important;
    text-overflow:ellipsis !important;
    font-size:.73rem !important;
    font-weight:800 !important;
    letter-spacing:-.02em !important;
    color:var(--p4ul-primary-deep) !important;
    line-height:1.05 !important;
}

.service-standard__label{
    display:block !important;
    white-space:nowrap !important;
    overflow:hidden !important;
    text-overflow:ellipsis !important;
    font-size:.48rem !important;
    font-weight:700 !important;
    letter-spacing:.075em !important;
    color:var(--p4ul-text-soft) !important;
    line-height:1.05 !important;
}

.service-standard::before,
.service-standard::after{
    display:none !important;
}

.service-standard:hover{
    transform:none !important;
    background:transparent !important;
    box-shadow:none !important;
}

@media (max-width: 620px){
    .service__standards{
        grid-template-columns:1fr !important;
    }

    .service__aside{
        padding-left:0 !important;
        border-left:0 !important;
    }
}

.service__intro,
.features__intro{
    gap:10px !important;
}

.service__features{
    padding-top:14px !important;
}

.icons__point{
    border-radius:18px !important;
    box-shadow:0 14px 34px rgba(0,0,0,.18) !important;
}

.icons__point-body{
    gap:6px !important;
}

.icons__point-body h3{
    font-size:1rem !important;
}

.icons__point-body p{
    color:rgba(255,255,255,.76) !important;
}

.icons#vantaggi .icons__point{
    background:rgba(14,20,29,.96) !important;
    border-color:rgba(255,255,255,.06) !important;
}

.icons#vantaggi .icons__lead-title{
    font-size:clamp(1.62rem, 2.8vw, 2.45rem) !important;
}

.faq__eyebrow{
    margin:0;
    font-size:.74rem;
    font-weight:800;
    letter-spacing:.24em;
    text-transform:uppercase;
    color:var(--p4ul-accent);
}

.faq__copy{
    margin:0;
    max-width:64ch;
    color:var(--p4ul-text-soft);
    font-size:1.04rem;
    line-height:1.6;
}

.faq{
    padding:72px 0 84px;
    background:linear-gradient(180deg, #ffffff 0%, #f8fbfe 100%);
}

.faq__container{
    display:grid;
    gap:32px;
}

.faq__intro{
    display:grid;
    gap:8px;
    justify-items:center;
    text-align:center;
}

.faq__list{
    display:grid;
    gap:14px;
    max-width:1020px;
    margin:0 auto;
}

.faq__item{
    border:1px solid var(--p4ul-border);
    border-radius:20px;
    background:
      linear-gradient(180deg, rgba(255,255,255,.99) 0%, #f7fafc 100%);
    box-shadow:0 16px 36px rgba(67,55,168,.07);
    overflow:hidden;
    position:relative;
}

.faq__item::before{
    content:"";
    position:absolute;
    inset:0 auto auto 0;
    width:100%;
    height:3px;
    background:linear-gradient(90deg, var(--p4ul-primary) 0%, var(--p4ul-primary-deep) 55%, var(--p4ul-accent) 100%);
    opacity:.88;
}

.faq__item summary{
    list-style:none;
    cursor:pointer;
    padding:20px 22px;
    font-weight:800;
    color:var(--p4ul-contrast);
    font-size:1.08rem;
    line-height:1.36;
}

.faq__item summary::-webkit-details-marker{
    display:none;
}

.faq__item summary::after{
    content:"+";
    float:right;
    color:var(--p4ul-accent);
    font-weight:900;
}

.faq__item p{
    margin:0;
    padding:0 22px 20px;
    color:var(--p4ul-text-soft);
    font-size:1.04rem;
    line-height:1.7;
}

@media (max-width: 720px){
    .faq{
        padding:56px 0 64px;
    }

    .faq__item summary,
    .faq__item p{
        padding-left:18px;
        padding-right:18px;
    }

    .faq__intro .homepage-section-title{
        max-width:17ch;
    }

    .faq__copy{
        font-size:1rem;
        line-height:1.65;
    }

    .faq__item summary{
        font-size:1.02rem;
    }

    .faq__item p{
        font-size:.98rem;
        line-height:1.62;
    }
}

.faq__item{
    transition:border-color .2s ease, box-shadow .2s ease, transform .2s ease;
}

.faq__item summary{
    transition:color .2s ease, background-color .2s ease;
}

.faq__item[open]{
    border-color:rgba(108,99,240,.22);
    box-shadow:0 18px 36px rgba(67,55,168,.08);
}

.faq__item[open] summary::after{
    content:"-";
}

.faq__item summary:hover,
.faq__item summary:focus-visible{
    color:var(--p4ul-primary-deep);
    background:rgba(108,99,240,.04);
}

/* Body copy tuning: slightly larger non-title text for better readability */
.homepage-copy{
    font-size:clamp(1.08rem,1.55vw,1.38rem) !important;
    line-height:1.72;
}

.service__subtitle{
    font-size:1.03rem;
    line-height:1.75;
}

.module-card__lead{
    font-size:1.06rem;
    line-height:1.72;
}

.module-card__list li{
    font-size:1.01rem;
    line-height:1.55;
}

.features__benefit p{
    font-size:.96rem;
    line-height:1.58;
}

#vantaggi .icons__result-copy,
#vantaggi .icons__point-body p,
#vantaggi .icons__lead-copy{
    font-size:1.02rem;
}

.faq__copy,
.faq__item p{
    font-size:1.02rem;
}

/* Full-viewport sections */
section.cover,
section.intro#intro,
section.service#servizio,
section.features#moduli,
section.icons#vantaggi,
section.faq#faq,
section.contacts#contacts{
    min-height:calc(100svh - 56px);
    display:flex;
    flex-direction:column;
    justify-content:center;
}

section.cover{
    height:calc(100svh - 56px);
}

@media (max-width: 992px){
    section.cover,
    section.intro#intro,
    section.service#servizio,
    section.features#moduli,
    section.icons#vantaggi,
    section.faq#faq,
    section.contacts#contacts{
        min-height:calc(100svh - 52px);
    }

    section.cover{
        height:calc(100svh - 52px);
    }
}

.compliance{
    background:#f7fafc !important;
    padding:84px 0 !important;
}

.compliance__container{
    gap:24px !important;
}

.compliance__intro{
    max-width:none !important;
}

.compliance__intro .service__eyebrow{
    color:var(--p4ul-primary);
}

.compliance__intro .service__title{
    font-size:clamp(2rem, 3.2vw, 3.2rem);
    letter-spacing:-.04em;
}

/* Vantaggi balance pass: make the cards and dashboard occupy the same space. */
#vantaggi{
    padding-bottom:120px !important;
}

#vantaggi .icons__hero{
    grid-template-columns:minmax(0,1fr) minmax(0,1fr) !important;
    gap:22px !important;
    align-items:stretch !important;
}

#vantaggi .icons__hero-copy{
    align-self:stretch !important;
    display:grid !important;
}

#vantaggi .icons__benefits{
    height:100% !important;
    align-content:stretch !important;
    grid-auto-rows:minmax(0,1fr) !important;
    margin-bottom:40px !important;
}

#vantaggi .icons__benefit{
    min-height:0 !important;
}

#vantaggi .icons__benefit:first-child{
    grid-column:span 2 !important;
}

#vantaggi .icons__benefit--accent{
    grid-column:auto !important;
    grid-row:auto !important;
    align-self:start !important;
}

#vantaggi .icons__hero-visual{
    align-self:center !important;
    height:auto !important;
    justify-self:center !important;
    width:min(100%, 480px) !important;
    margin:0 auto !important;
    padding:8px !important;
    border-radius:22px !important;
    display:flex;
    align-items:center;
    justify-content:center;
}

#vantaggi .icons__hero-visual img{
    width:100% !important;
    height:auto !important;
    border-radius:14px !important;
    box-shadow:0 16px 34px rgba(0,0,0,.20) !important;
}

@media (max-width: 767px){
    #vantaggi .icons__benefit:first-child{
        grid-column:1 / -1 !important;
    }

    #vantaggi .icons__benefit--accent{
        grid-column:1 / -1 !important;
        grid-row:auto !important;
    }

    #vantaggi .icons__comparison-table thead th{
        padding:14px 12px !important;
        font-size:.78rem !important;
        line-height:1.15 !important;
        letter-spacing:.02em !important;
        white-space:normal !important;
    }

    #vantaggi .icons__comparison-table thead th:last-child{
        font-size:.8rem !important;
    }

    #vantaggi .icons__comparison-table tbody td{
        padding:14px 12px !important;
        font-size:.92rem !important;
        line-height:1.45 !important;
    }
}

/* GeMEB editorial sections: Come funziona + Funzionalità principali */
.process-section{
    padding:72px 0;
    background:
      radial-gradient(circle at top left, rgba(108,99,240,.06) 0%, rgba(108,99,240,0) 28%),
      linear-gradient(180deg, #ffffff 0%, #f4f7fb 100%);
    color:#132131;
}

.process-section__container{
    display:grid;
    gap:28px;
}

.process-section__intro{
    width:100%;
    max-width:none;
    margin:18px 0 0;
    text-align:center;
    justify-items:center;
    gap:14px;
}

.process-section .service__title,
.features-section .service__title{
    color:#132131;
}

.process-section__intro .service__title,
.features-section__intro .service__title{
    margin:10px 0 0;
    max-width:none;
    font-size:clamp(1.72rem, 3vw, 2.62rem);
    line-height:1.08;
    letter-spacing:-.03em;
    font-weight:850;
    width:100%;
    text-align:center;
    text-shadow:none;
}

.process-section__intro .service__title-accent{
    color:#DC3545;
}

.process-section .service__subtitle,
.features-section .service__subtitle{
    color:#5F6F7A;
    width:100%;
    max-width:90ch;
    line-height:1.75;
    text-align:center;
    font-size:1.03rem;
    margin-top:22px;
    margin-bottom: 22px
}

.process-section .features-section{
    padding:0;
    background:transparent;
    color:#102131;
    grid-column:1 / -1;
}

.process-section .features-section__container{
    display:grid;
    gap:14px;
    padding-top:0;
    border-top:0;
}

.process-section .features-section__bridge{
    justify-content:center;
    margin:0;
    text-align:center;
    font-size:.92rem;
    font-weight:700;
    letter-spacing:.14em;
    text-transform:uppercase;
    color:#827BF6;
    display:flex;
    align-items:center;
    gap:10px;
    flex-wrap:wrap;
    padding:12px 0 14px;
}

.process-section .features-section__bridge-label{
    color:#DC3545;
}

.process-section .features-section__bridge-separator{
    color:rgba(19,33,49,.28);
    font-size:.85rem;
    line-height:1;
}

.process-section .features-section__bridge-text{
    color:#827BF6;
}

.process-section .features-section__cards{
    max-width:none;
    margin-top:0;
}

.process-section__layout{
    display:grid;
    grid-template-columns:minmax(340px,1.05fr) minmax(0,.95fr);
    gap:24px;
    align-items:stretch;
}

.process-section__problem{
    display:grid;
    gap:16px;
    padding:28px;
    border-radius:30px;
    background:linear-gradient(180deg, #12233D 0%, #171A2E 100%);
    border:1px solid rgba(108,99,240,.24);
    box-shadow:0 24px 56px rgba(0,0,0,.20);
    position:relative;
    overflow:hidden;
    align-self:stretch;
}

.process-section__problem::before{
    content:"";
    position:absolute;
    inset:0;
    background:
      radial-gradient(circle at top right, rgba(108,99,240,.18) 0%, rgba(108,99,240,0) 34%),
      linear-gradient(180deg, rgba(255,255,255,.02) 0%, rgba(255,255,255,0) 100%);
    pointer-events:none;
}

.process-section__problem-head,
.process-section__problem-threats,
.process-section__problem-diagram{
    position:relative;
    z-index:1;
}

.process-section__problem-head{
    display:grid;
    gap:10px;
}

.process-section__problem-kicker{
    margin:0;
    color:#DC3545;
    font-size:.74rem;
    font-weight:800;
    letter-spacing:.22em;
    text-transform:uppercase;
}

.process-section__problem-title{
    margin:0;
    color:#ffffff;
    font-size:clamp(1.32rem, 1.95vw, 1.8rem);
    line-height:1.04;
    letter-spacing:-.04em;
}

.process-section__problem-copy{
    margin:0;
    color:rgba(255,255,255,.78);
    line-height:1.62;
    font-size:.95rem;
}

.process-section__problem-threats{
    display:grid;
    grid-template-columns:repeat(3, minmax(0, 1fr));
    gap:10px 14px;
}

.process-section__problem-threat{
    display:flex;
    align-items:center;
    gap:10px;
    padding:0;
    background:none;
    border:0;
    text-align:left;
}

.process-section__problem-threat .material-symbols-outlined{
    font-size:1.05rem;
    line-height:1;
    color:#A49BFF;
    font-variation-settings:'FILL' 0, 'wght' 300, 'GRAD' 0, 'opsz' 24;
    width:20px;
    text-align:center;
}

.process-section__problem-threat-label{
    color:#ffffff;
    font-size:.84rem;
    line-height:1.35;
    font-weight:700;
    letter-spacing:0;
}

.process-section__problem-diagram{
    position:relative;
    display:grid;
    grid-template-columns:auto minmax(0, 1fr) auto;
    gap:12px;
    align-items:center;
    padding:12px;
    border-radius:20px;
    background:rgba(255,255,255,.04);
    border:1px solid rgba(108,99,240,.18);
}

.process-section__problem-diagram::before{
    content:"";
    position:absolute;
    left:10%;
    right:10%;
    top:50%;
    border-top:1px dashed rgba(108,99,240,.28);
    transform:translateY(-50%);
    pointer-events:none;
    z-index:0;
}

.process-section__problem-node,
.process-section__problem-core{
    position:relative;
    z-index:1;
}

.process-section__problem-node{
    display:grid;
    justify-items:center;
    gap:6px;
    color:#ffffff;
    text-align:center;
}

.process-section__problem-node-label{
    font-size:.7rem;
    font-weight:800;
    letter-spacing:.16em;
    text-transform:uppercase;
    color:rgba(255,255,255,.70);
}

.process-section__problem-node .material-symbols-outlined{
    font-size:2rem;
    color:rgba(164,155,255,.98);
}

.process-section__problem-core{
    display:grid;
    justify-items:center;
    gap:8px;
}

.process-section__problem-core-label{
    color:#A49BFF;
    font-size:.82rem;
    font-weight:800;
    letter-spacing:.18em;
}

.process-section__problem-core-box{
    display:flex;
    align-items:center;
    justify-content:center;
    gap:8px;
    width:96px;
    height:50px;
    border-radius:16px;
    background:linear-gradient(135deg, rgba(164,155,255,.22) 0%, rgba(164,155,255,.08) 100%);
    border:1px solid rgba(164,155,255,.28);
    box-shadow:0 10px 24px rgba(19,33,49,.08);
    position:relative;
    z-index:2;
}

.process-section__problem-core-box span{
    display:block;
    width:12px;
    height:12px;
    border-radius:50%;
    background:rgba(164,155,255,.32);
}

.process-section__problem-core-box span:first-child{
    background:#A49BFF;
}

.process-section__problem-core-note{
    margin:0;
    padding:5px 9px;
    border-radius:999px;
    background:rgba(164,155,255,.24);
    border:1px solid rgba(164,155,255,.30);
    color:#ffffff;
    font-size:.7rem;
    font-weight:700;
    letter-spacing:.01em;
    text-align:center;
}

.process-section__steps{
    list-style:none;
    margin:0;
    padding:0;
    display:grid;
    grid-template-columns:1fr;
    gap:12px;
    align-self:center;
}

.process-step{
    display:grid;
    grid-template-columns:64px minmax(0,1fr);
    gap:16px;
    align-content:start;
    padding:18px 18px 18px 20px;
    border-radius:0;
    background:transparent;
    border-top:1px solid rgba(108,99,240,.10);
    border-right:0;
    border-bottom:0;
    border-left:0;
    box-shadow:none;
}

.process-step:first-child{
    border-top:0;
    padding-top:0;
}

.process-step__index{
    width:58px;
    height:58px;
    border-radius:16px;
    display:grid;
    place-items:center;
    background:rgba(106,151,127,.14);
    border:1px solid rgba(106,151,127,.22);
    color:#827BF6;
}

.process-step__index-number{
    font-size:1.25rem;
    line-height:1;
    font-weight:800;
    letter-spacing:-.03em;
}

.process-step__body h3{
    margin:0;
    color:#132131;
    font-size:1.02rem;
    line-height:1.2;
}

.process-step__body p{
    margin:10px 0 0;
    color:#6D7390;
    line-height:1.6;
    font-size:.88rem;
}

.process-step__body{
    display:grid;
    align-content:start;
}

#come-funziona .process-step:nth-child(1) .process-step__index{
    background:linear-gradient(180deg, rgba(108,99,240,.18) 0%, rgba(108,99,240,.08) 100%);
    color:#6C63F0;
    box-shadow:inset 0 0 0 1px rgba(108,99,240,.16);
}

#come-funziona .process-step:nth-child(1) .process-step__index-number,
#come-funziona .process-step:nth-child(1) .process-step__body h3{
    color:#4337A8;
}

#come-funziona .process-step:nth-child(2) .process-step__index{
    background:linear-gradient(180deg, rgba(67,55,168,.18) 0%, rgba(67,55,168,.08) 100%);
    color:#4337A8;
    box-shadow:inset 0 0 0 1px rgba(67,55,168,.16);
}

#come-funziona .process-step:nth-child(2) .process-step__index-number,
#come-funziona .process-step:nth-child(2) .process-step__body h3{
    color:#2F4C87;
}

#come-funziona .process-step:nth-child(3) .process-step__index{
    background:linear-gradient(180deg, rgba(220,53,69,.16) 0%, rgba(220,53,69,.08) 100%);
    color:#DC3545;
    box-shadow:inset 0 0 0 1px rgba(220,53,69,.16);
}

#come-funziona .process-step:nth-child(3) .process-step__index-number,
#come-funziona .process-step:nth-child(3) .process-step__body h3{
    color:#B61F35;
}

#come-funziona .process-step:nth-child(4) .process-step__index{
    background:linear-gradient(180deg, rgba(47,76,135,.18) 0%, rgba(47,76,135,.08) 100%);
    color:#2F4C87;
    box-shadow:inset 0 0 0 1px rgba(47,76,135,.16);
}

#come-funziona .process-step:nth-child(4) .process-step__index-number,
#come-funziona .process-step:nth-child(4) .process-step__body h3{
    color:#22406E;
}

.features-section{
    padding:78px 0;
    background:#f6f8fb;
    color:#102131;
}

.features-section__list{
    margin-top:18px;
    margin-bottom:18px;
    display:grid;
    grid-template-columns:repeat(2, minmax(0, 1fr));
    gap:12px;
    max-width:1080px;
    margin-left:auto;
    margin-right:auto;
}

.feature-row{
    position:relative;
    display:grid;
    grid-template-columns:auto minmax(0,1fr);
    gap:18px;
    align-items:start;
    padding:24px 24px 22px;
    border-radius:20px;
    background:rgba(255,255,255,.9);
    border:1px solid rgba(108,99,240,.14);
    box-shadow:0 12px 28px rgba(19,33,49,.06);
    transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}

.feature-row::before{
    content:"";
    position:absolute;
    left:0;
    top:14px;
    bottom:14px;
    width:3px;
    border-radius:999px;
    background:linear-gradient(180deg, #827BF6 0%, #6C63F0 100%);
    opacity:.85;
}

.feature-row:nth-child(2n){
    background:linear-gradient(180deg, rgba(255,255,255,.94) 0%, rgba(244,248,250,.94) 100%);
}

.feature-row:hover{
    transform:translateY(-3px);
    border-color:rgba(108,99,240,.28);
    box-shadow:0 18px 34px rgba(19,33,49,.10);
}

.feature-row__icon{
    display:grid;
    place-items:center;
    width:56px;
    height:56px;
    border-radius:18px;
    background:linear-gradient(180deg, rgba(108,99,240,.16) 0%, rgba(108,99,240,.08) 100%);
    border:1px solid rgba(108,99,240,.18);
    color:#6C63F0;
    font-size:1.8rem;
    font-variation-settings:'FILL' 0, 'wght' 300, 'GRAD' 0, 'opsz' 24;
}

.feature-row__body{
    display:grid;
    gap:8px;
}

.feature-row__body h3{
    margin:0;
    color:#132131;
    font-size:1.12rem;
    line-height:1.2;
}

.feature-row__body p{
    margin:0;
    color:#5F6F7A;
    line-height:1.56;
    font-size:.98rem;
}

@media (max-width: 991px){
    .process-section__container{
        gap:28px;
    }

    .process-section__layout{
        grid-template-columns:1fr;
    }

    .process-section .features-section{
        padding-top:0;
    }

    .process-section__steps,
    .features-section__cards{
        grid-template-columns:repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 720px){
    .process-section,
    .features-section{
        padding:58px 0;
    }

    .process-section__container{
        gap:22px;
    }

    .process-section .features-section__container{
        gap:12px;
        padding-top:12px;
    }

    .process-section__problem{
        padding:20px;
    }

    .process-section__problem-threats{
        grid-template-columns:1fr;
        gap:8px 10px;
    }

    .process-section__problem-diagram{
        grid-template-columns:1fr;
        gap:12px;
    }

    .process-section__problem-diagram::before{
        left:50%;
        right:auto;
        top:12px;
        bottom:12px;
        border-top:0;
        border-left:1px dashed rgba(108,99,240,.22);
        transform:none;
    }

    .process-section__problem-node{
        grid-template-columns:auto 1fr;
        justify-items:start;
        text-align:left;
    }

    .process-step{
        grid-template-columns:56px minmax(0,1fr);
        padding:18px 0;
    }

    .process-section__steps,
    .features-section__list{
        grid-template-columns:1fr;
        gap:14px;
    }

    .process-section .features-section{
        padding-top:0;
    }

    .process-step,
    .feature-row{
        padding:22px;
    }
}

.compliance{
    background:
      radial-gradient(circle at 82% 14%, rgba(108,99,240,.20) 0%, rgba(108,99,240,0) 24%),
      linear-gradient(180deg, #f3f6f8 0%, #e4eaee 100%) !important;
    color:#132131 !important;
    min-height:100vh;
    display:flex;
    align-items:center;
    padding:72px 0;
}

.compliance__panel{
    display:grid !important;
    background:transparent !important;
    border:0 !important;
    box-shadow:none !important;
    padding:0 !important;
    min-height:calc(100vh - 144px);
    grid-template-columns:minmax(0,1fr) minmax(360px,1.04fr) !important;
    gap:clamp(28px, 4vw, 56px) !important;
    align-items:center !important;
    align-content:center;
    position:relative;
}

.compliance__copy .service__title,
.compliance__copy .service__subtitle,
.compliance__standard h4,
.compliance__standard p,
.compliance__meta span{
    color:#132131 !important;
}

.compliance__copy{
    padding-right:42px;
    border-right:1px solid rgba(108,99,240,.12);
    display:flex;
    flex-direction:column;
    justify-content:center;
    align-self:center;
}

.compliance__copy .service__title{
    width:min(100%, 30ch) !important;
    margin-top:6px !important;
}

.compliance__copy .service__subtitle{
    width:min(100%, 58ch) !important;
    margin-top:12px !important;
}

.compliance__standards{
    display:grid !important;
    grid-template-columns:repeat(3,minmax(0,1fr)) !important;
    gap:0 !important;
    margin-top:34px !important;
    padding-top:26px !important;
    padding-left:0 !important;
    border-top:1px solid rgba(108,99,240,.10) !important;
}

.compliance__standard{
    display:flex !important;
    gap:14px !important;
    align-items:flex-start !important;
    padding:10px 18px 0 0 !important;
    background:transparent !important;
    border:0 !important;
    border-radius:0 !important;
    position:relative;
    min-height:118px;
}

.compliance__standard + .compliance__standard{
    border-left:1px solid rgba(108,99,240,.10) !important;
    padding-left:18px !important;
}

.compliance__icon{
    display:none !important;
}

.compliance__meta span{
    background:rgba(108,99,240,.08) !important;
    border-color:rgba(108,99,240,.18) !important;
}

.compliance__standard h4{
    margin-bottom:8px !important;
    font-size:1.06rem !important;
    letter-spacing:-.01em;
}

.compliance__standard p{
    color:#5f6f7a !important;
    line-height:1.6 !important;
    font-size:.96rem !important;
}

.compliance__visual{
    position:relative;
    background:transparent !important;
    border:0 !important;
    border-radius:24px !important;
    overflow:visible !important;
    min-height:clamp(600px, 72vh, 820px) !important;
    display:flex;
    align-items:center;
    justify-content:center;
    justify-self:center;
    align-self:center;
    margin-left:0;
    isolation:isolate;
}

.compliance__visual-ring{
    position:absolute;
    left:50%;
    top:50%;
    width:min(70vw, 300px);
    height:min(70vw, 300px);
    transform:translate(-50%, -50%);
    z-index:2;
    pointer-events:none;
}

.compliance__visual-ring--outer{
    width:min(82vw, 380px);
    height:min(82vw, 380px);
    z-index:0;
    opacity:.88;
}

.compliance__visual-ring::before{
    border-color:rgba(108,99,240,.18) !important;
    border-width:2px;
    border-style:dashed;
    border-radius:50%;
    animation:compliance-spin 18s linear infinite;
}

.compliance__visual-ring--outer::before{
    content:"";
    position:absolute;
    inset:0;
    border:1.5px dashed rgba(108,99,240,.18);
    border-radius:50%;
    box-shadow:0 0 0 1px rgba(108,99,240,.05) inset;
    animation:compliance-spin 28s linear infinite reverse;
}

.compliance__visual-shield{
    position:relative;
    width:210px;
    height:210px;
    border-radius:50%;
    display:flex;
    align-items:center;
    justify-content:center;
    z-index:1;
    background:radial-gradient(circle at top, rgba(108,99,240,.20) 0%, rgba(108,99,240,.08) 42%, rgba(255,255,255,.08) 100%) !important;
    border-color:rgba(108,99,240,.22) !important;
    box-shadow:0 24px 64px rgba(19,33,49,.10), 0 0 42px rgba(108,99,240,.14) !important;
}

.compliance__visual-icon{
    font-size:168px;
    line-height:1;
    font-variation-settings:'FILL' 0, 'wght' 300, 'GRAD' 0, 'opsz' 48;
    color:#6C63F0 !important;
    filter:drop-shadow(0 0 10px rgba(108,99,240,.18)) !important;
    transform:translateY(1px);
}

/* Results section override for Google3 charts */
.case-study{
    
    background:
      radial-gradient(circle at top right, rgba(108,99,240,.08) 0%, rgba(108,99,240,0) 28%),
      radial-gradient(circle at left center, rgba(220,53,69,.05) 0%, rgba(220,53,69,0) 32%),
      linear-gradient(180deg, #ffffff 0%, #f4f7fb 100%);
    color:var(--p4ul-text);
    min-height:100vh;
    display:flex;
    align-items:center;
    padding:64px 0;
}

.case-study__container{
    display:grid;
    width:min(1240px, calc(100% - 48px)) !important;
    max-width:1240px !important;
    margin:0 auto !important;
    gap:14px;
    min-height:calc(100vh - 128px);

}

.case-study__intro{
    max-width:920px !important;
    margin:0 auto 26px !important;
    text-align:center;
    justify-self:center;
}

.case-study__intro .service__subtitle{
    display:block;
    max-width:860px;
    margin:12px auto 0;
    text-align:center !important;
    font-size:1rem;
    line-height:1.62;
    color:#5F6F7A;
}

.case-study__results{
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:22px;
    align-items:stretch;
    align-self:center;
}

.case-study__chart{
    display:grid;
    justify-items:center;
    gap:12px;
    padding:26px 22px 20px;
    border-radius:24px;
    background:rgba(255,255,255,.94);
    border:1px solid rgba(108,99,240,.12);
    box-shadow:0 18px 38px rgba(11,19,36,.08);
    text-align:center;
}

.case-study__chart-ring{
    width:128px;
    height:128px;
    border-radius:50%;
    display:grid;
    place-items:center;
    position:relative;
    margin-bottom:0;
    background:rgba(255,255,255,.98);
    box-shadow:inset 0 0 0 1px rgba(108,99,240,.10);
    overflow:hidden;
}

.case-study__chart-ring svg{
    position:absolute;
    inset:0;
    width:100%;
    height:100%;
    transform:rotate(-90deg);
}

.case-study__chart-track,
.case-study__chart-value{
    fill:none;
    stroke-width:8;
    cx:64;
    cy:64;
    r:58;
}

.case-study__chart-track{
    stroke:rgba(108,99,240,.12);
}

.case-study__chart-value{
    stroke:var(--p4ul-primary);
    stroke-linecap:round;
    stroke-dasharray:364;
}

.case-study__chart-ring span{
    position:relative;
    z-index:1;
    font-size:1.9rem;
    font-weight:800;
    color:var(--p4ul-primary-deep);
    letter-spacing:-.04em;
}

.case-study__chart-ring--mid{
    box-shadow:inset 0 0 0 1px rgba(61,56,142,.14);
}

.case-study__chart-ring--mid .case-study__chart-value{
    stroke:#3D388E;
}

.case-study__chart-ring--final{
    box-shadow:0 0 0 1px rgba(108,99,240,.12), inset 0 0 0 1px rgba(108,99,240,.08);
}

.case-study__chart h4{
    margin:0;
    color:var(--p4ul-primary-deep);
    font-size:.98rem;
    font-weight:800;
}

.case-study__chart p{
    margin:0;
    color:var(--p4ul-text-soft);
    font-size:.9rem;
    line-height:1.45;
}

.case-study__metrics{
    display:flex;
    gap:12px;
    align-items:stretch;
}

.case-study__metrics > *{
    flex:1 1 0;
}

.case-study__err,
.case-study__avg{
    display:grid;
    gap:4px;
    margin-top:0;
    padding-top:6px;
    justify-items:center;
    text-align:center;
    border-top:1px solid rgba(108,99,240,.10);
}

.case-study__err{
    border-top-color:rgba(220,53,69,.12);
}

.case-study__err-value,
.case-study__avg-value{
    display:inline-flex;
    align-items:baseline;
    justify-content:center;
    gap:4px;
    font-size:1.16rem;
    font-weight:800;
    letter-spacing:-.03em;
    line-height:1;
}

.case-study__err-value{
    color:var(--p4ul-accent);
}

.case-study__avg-value{
    color:var(--p4ul-primary-deep);
}

.case-study__chart--primary .case-study__avg-value{
    color:var(--p4ul-primary);
}

.case-study__avg-scale{
    font-size:.62em;
    font-weight:700;
    letter-spacing:0;
    color:var(--p4ul-text-soft);
}

.case-study__err-label,
.case-study__avg-label{
    font-size:.64rem;
    line-height:1.2;
    text-transform:uppercase;
    letter-spacing:.08em;
    color:var(--p4ul-text-soft);
}

.case-study__chart--accent{
    transform:none;
}

.case-study__chart--primary{
    border-color:rgba(108,99,240,.24);
    box-shadow:0 20px 42px rgba(108,99,240,.10);
}

.case-study__note{
    max-width:760px;
    margin:24px auto 0;
    padding:14px 16px;
    border-radius:16px;
    background:rgba(108,99,240,.05);
    border:1px solid rgba(108,99,240,.10);
    text-align:center;
}

.case-study__note p{
    margin:0;
    color:var(--p4ul-text-soft);
    font-size:.92rem;
    line-height:1.5;
}

@media (max-width: 980px){
    .case-study{
        min-height:auto;
        padding:52px 0;
        display:block;
    }

    .case-study__container{
        min-height:auto;
    }

    .case-study__results{
        grid-template-columns:1fr;
    }

    .case-study__chart--accent{
        transform:none;
    }
}

@media (max-width: 720px){
    .case-study{
        padding:44px 0;
    }

    .case-study__chart{
        padding:20px 18px 18px;
    }

    .case-study__chart-ring{
        width:110px;
        height:110px;
    }

    .case-study__chart-ring span{
        font-size:1.68rem;
    }

    .case-study__metrics{
        gap:10px;
    }

    .case-study__err-value,
    .case-study__avg-value{
        font-size:1.08rem;
    }

}

.compliance__star{
    color:#6C63F0 !important;
}

.contacts{
    background:
      radial-gradient(circle at top left, rgba(108,99,240,.12) 0%, rgba(108,99,240,0) 34%),
      radial-gradient(circle at top right, rgba(220,53,69,.06) 0%, rgba(220,53,69,0) 28%),
      linear-gradient(180deg, #101a2d 0%, #0b1324 54%, #08111d 100%) !important;
    color:var(--p4ul-surface) !important;
}

section.contacts#contacts .contacts__container,
section#contacts.contacts .contacts__container{
    max-width:1120px !important;
}

section.contacts#contacts .contacts__title{
    display:grid;
    justify-items:center;
    gap:6px;
    max-width:56rem;
    margin:0 auto 28px;
    text-align:center;
}

.contacts h2,
section.contacts h2,
section#contacts.contacts h2{
    color:var(--p4ul-surface) !important;
}

.contacts__title-line{
    display:block;
    color:var(--p4ul-surface);
    line-height:1.04;
}

.contacts form,
section.contacts .wpcf7-form,
section#contacts.contacts .wpcf7-form{
    background:rgba(255,255,255,.07) !important;
    border:1px solid rgba(255,255,255,.10) !important;
    border-radius:24px !important;
    padding:28px 28px 10px !important;
    box-shadow:0 18px 44px rgba(0,0,0,.18) !important;
    color:var(--p4ul-surface) !important;
}

.contacts input[type="text"],
.contacts input[type="email"],
.contacts textarea,
section.contacts .wpcf7-form input:not([type="submit"]),
section.contacts .wpcf7-form textarea,
section.contacts .wpcf7-form select{
    background:rgba(255,255,255,.94) !important;
    color:var(--p4ul-text) !important;
    border-color:rgba(164,155,255,.22) !important;
}

.contacts form p,
section.contacts .wpcf7-form p{
    margin:0 0 14px;
}

.contacts .cta,
.contacts .wpcf7-submit,
.contacts .btn-submit,
.contacts form input[type="submit"],
.contacts form .wpcf7-submit,
.contacts form .btn-submit{
    background:#DC3545 !important;
    border-color:#DC3545 !important;
    color:#ffffff !important;
    min-height:52px;
    padding:0 28px;
    border-radius:999px !important;
    font-weight:700;
    letter-spacing:.01em;
    text-transform:uppercase;
    box-shadow:0 14px 28px rgba(220,53,69,.24) !important;
}

.contacts .cta:hover,
.contacts .wpcf7-submit:hover,
.contacts .btn-submit:hover,
.contacts form input[type="submit"]:hover,
.contacts form .wpcf7-submit:hover,
.contacts form .btn-submit:hover{
    background:#b02a37 !important;
    border-color:#b02a37 !important;
    color:#ffffff !important;
    transform:translateY(-1px);
    box-shadow:0 16px 30px rgba(220,53,69,.28) !important;
}

/* Vantaggi problem panel: replace the old dashboard with the right-side problem content from google.txt. */
#vantaggi .icons__hero-visual.icons__problem{
    align-self:stretch !important;
    width:min(100%, 620px) !important;
    justify-self:end !important;
    display:grid !important;
    gap:16px !important;
    padding:20px !important;
    border-radius:28px !important;
    background:linear-gradient(180deg, rgba(11,19,36,.94) 0%, rgba(5,12,20,.98) 100%) !important;
    border:1px solid rgba(220,53,69,.12) !important;
    box-shadow:0 24px 48px rgba(0,0,0,.22), 0 0 0 1px rgba(255,255,255,.02) inset !important;
}

#vantaggi .icons__problem-head{
    display:grid;
    gap:10px;
}

#vantaggi .icons__problem-kicker{
    margin:0;
    color:var(--p4ul-accent);
    font-size:.74rem;
    font-weight:800;
    letter-spacing:.22em;
    text-transform:uppercase;
}

#vantaggi .icons__problem-title{
    margin:0;
    color:#fff;
    font-size:clamp(1.55rem, 2.6vw, 2.15rem);
    line-height:1.02;
    letter-spacing:-.04em;
}

#vantaggi .icons__problem-copy{
    margin:0;
    color:rgba(255,255,255,.78);
    font-size:.98rem;
    line-height:1.62;
}

#vantaggi .icons__problem-threats{
    display:grid;
    grid-template-columns:repeat(5, minmax(0, 1fr));
    gap:10px;
}

#vantaggi .icons__problem-threat{
    display:grid;
    justify-items:center;
    gap:8px;
    padding:12px 10px;
    border-radius:18px;
    background:rgba(255,255,255,.04);
    border:1px solid rgba(255,255,255,.08);
    text-align:center;
}

#vantaggi .icons__problem-threat .material-symbols-outlined{
    font-size:1.15rem;
    line-height:1;
    color:#e05662;
    font-variation-settings:'FILL' 0, 'wght' 300, 'GRAD' 0, 'opsz' 24;
}

#vantaggi .icons__problem-threat span:last-child{
    color:#d8e3fb;
    font-size:.7rem;
    line-height:1.18;
    font-weight:700;
    letter-spacing:.01em;
}

#vantaggi .icons__problem-diagram{
    position:relative;
    display:grid;
    grid-template-columns:auto minmax(0,1fr) auto;
    gap:16px;
    align-items:center;
    padding:18px 16px;
    border-radius:22px;
    background:rgba(255,255,255,.03);
    border:1px solid rgba(255,255,255,.08);
}

#vantaggi .icons__problem-diagram::before{
    content:"";
    position:absolute;
    left:10%;
    right:10%;
    top:50%;
    border-top:1px dashed rgba(255,255,255,.18);
    transform:translateY(-50%);
    pointer-events:none;
}

#vantaggi .icons__problem-node,
#vantaggi .icons__problem-core{
    position:relative;
    z-index:1;
}

#vantaggi .icons__problem-node{
    display:grid;
    justify-items:center;
    gap:8px;
    color:#fff;
    text-align:center;
}

#vantaggi .icons__problem-node-label{
    font-size:.7rem;
    font-weight:800;
    letter-spacing:.16em;
    text-transform:uppercase;
}

#vantaggi .icons__problem-node .material-symbols-outlined{
    font-size:2rem;
    color:rgba(255,255,255,.55);
}

#vantaggi .icons__problem-core{
    display:grid;
    justify-items:center;
    gap:10px;
}

#vantaggi .icons__problem-core-label{
    color:#e05662;
    font-size:.82rem;
    font-weight:800;
    letter-spacing:.18em;
}

#vantaggi .icons__problem-core-box{
    display:flex;
    align-items:center;
    justify-content:center;
    gap:8px;
    width:140px;
    height:66px;
    padding:14px;
    border-radius:16px;
    background:#081425;
    border:1px solid rgba(220,53,69,.18);
    box-shadow:0 10px 24px rgba(0,0,0,.22);
}

#vantaggi .icons__problem-core-box span{
    display:block;
    width:12px;
    height:12px;
    border-radius:50%;
    background:rgba(255,255,255,.16);
}

#vantaggi .icons__problem-core-box span:first-child{
    background:#e05662;
}

#vantaggi .icons__problem-core-note{
    margin:0;
    padding:6px 10px;
    border-radius:999px;
    background:rgba(255,255,255,.04);
    color:#d8e3fb;
    font-size:.72rem;
    line-height:1.2;
    text-align:center;
}

@media (max-width: 1100px){
    #vantaggi .icons__hero{
        grid-template-columns:1fr !important;
    }

    #vantaggi .icons__hero-visual.icons__problem{
        width:100% !important;
        justify-self:stretch !important;
    }

    #vantaggi .icons__problem-threats{
        grid-template-columns:repeat(2, minmax(0,1fr));
    }
}

@media (max-width: 720px){
    #vantaggi .icons__problem-diagram{
        grid-template-columns:1fr;
        gap:12px;
    }

    #vantaggi .icons__problem-diagram::before{
        left:50%;
        right:auto;
        top:12px;
        bottom:12px;
        border-top:0;
        border-left:1px dashed rgba(255,255,255,.18);
        transform:none;
    }

    #vantaggi .icons__problem-node{
        grid-template-columns:auto 1fr;
        justify-items:start;
        text-align:left;
    }
}

/* Final clear override for Vantaggi */
section.icons#vantaggi,
#vantaggi.icons{
    background:
      radial-gradient(circle at 18% 10%, rgba(108,99,240,.10) 0%, rgba(108,99,240,0) 30%),
      radial-gradient(circle at 82% 8%, rgba(220,53,69,.06) 0%, rgba(220,53,69,0) 24%),
      linear-gradient(180deg, #eef4fa 0%, #dde6f1 100%) !important;
    color:#132131 !important;
}

#vantaggi .icons__container > h2{
    color:#4337A8 !important;
}

#vantaggi .icons__section-copy{
    color:#5f6f7a !important;
}

#vantaggi .icons__comparison{
    display:block !important;
}

#vantaggi .icons__comparison-tablewrap,
#vantaggi .icons__comparison-visual{
    width:min(100%, 1040px) !important;
    margin:0 auto !important;
    background:transparent !important;
    border:0 !important;
    box-shadow:none !important;
    border-radius:0 !important;
}

#vantaggi .icons__comparison-table{
    width:100% !important;
    table-layout:fixed !important;
    border-collapse:collapse !important;
    background:#ffffff !important;
    border:1px solid rgba(108,99,240,.16) !important;
    border-radius:28px !important;
    overflow:hidden !important;
    box-shadow:0 22px 52px rgba(11,19,36,.12) !important;
}

#vantaggi .icons__comparison-table thead th,
#vantaggi .icons__comparison-table tbody td{
    background:transparent !important;
    color:#243140 !important;
    border-color:rgba(108,99,240,.08) !important;
}

#vantaggi .icons__comparison-table thead th:last-child{
    color:#6C63F0 !important;
    background:linear-gradient(180deg, rgba(108,99,240,.14) 0%, rgba(108,99,240,.08) 100%) !important;
}

#vantaggi .icons__comparison-table tbody td:first-child,
#vantaggi .icons__comparison-visual h3{
    color:#132131 !important;
}

#vantaggi .icons__comparison-table tbody td:last-child{
    background:linear-gradient(180deg, rgba(108,99,240,.06) 0%, rgba(108,99,240,.03) 100%) !important;
    color:#0f1730 !important;
}

#vantaggi .icons__comparison-table strong{
    color:#132131 !important;
}

#vantaggi .icons__comparison-visual p{
    color:#5f6f7a !important;
}

#vantaggi .icons__comparison-visual img{
    border-color:rgba(108,99,240,.10) !important;
    box-shadow:0 16px 36px rgba(11,19,36,.08) !important;
}

@media (max-width: 720px){
    #vantaggi .icons__comparison-table thead th,
    #vantaggi .icons__comparison-table tbody td{
        padding:14px 12px !important;
        font-size:.88rem !important;
        line-height:1.45 !important;
    }

    #vantaggi .icons__comparison-table thead th:last-child{
        font-size:.8rem !important;
    }

    #vantaggi .icons__comparison-table tbody td:first-child{
        width:auto !important;
    }
}

/* Premium comparison table refresh */
section.icons#vantaggi .icons__comparison{
    display:flex !important;
    justify-content:center !important;
}

section.icons#vantaggi .icons__comparison-tablewrap{
    width:min(100%, 1080px) !important;
    margin:0 auto !important;
    padding:0 !important;
    background:linear-gradient(180deg, rgba(255,255,255,.96) 0%, #ffffff 100%) !important;
    border:1px solid rgba(108,99,240,.14) !important;
    border-radius:32px !important;
    box-shadow:0 24px 58px rgba(11,19,36,.12) !important;
    overflow:hidden !important;
}

section.icons#vantaggi .icons__comparison-table{
    width:100% !important;
    border-collapse:separate !important;
    border-spacing:0 !important;
    table-layout:fixed !important;
    color:#1f2b3d !important;
}

section.icons#vantaggi .icons__comparison-table thead th{
    padding:22px 24px !important;
    font-size:.78rem !important;
    line-height:1.15 !important;
    letter-spacing:.18em !important;
    text-transform:uppercase !important;
    font-weight:800 !important;
    color:#4337A8 !important;
    background:
      linear-gradient(180deg, rgba(108,99,240,.10) 0%, rgba(108,99,240,.04) 100%) !important;
    border-bottom:1px solid rgba(108,99,240,.10) !important;
    vertical-align:bottom !important;
}

section.icons#vantaggi .icons__comparison-table thead th:first-child{
    width:28% !important;
}

section.icons#vantaggi .icons__comparison-table thead th:nth-child(2),
section.icons#vantaggi .icons__comparison-table thead th:nth-child(3){
    text-align:center !important;
}

section.icons#vantaggi .icons__comparison-table thead th:last-child{
    color:#6C63F0 !important;
    background:linear-gradient(180deg, rgba(108,99,240,.16) 0%, rgba(108,99,240,.10) 100%) !important;
    box-shadow:inset 2px 0 0 rgba(108,99,240,.12) !important;
}

section.icons#vantaggi .icons__comparison-table tbody td{
    padding:22px 24px !important;
    vertical-align:top !important;
    font-size:1rem !important;
    line-height:1.6 !important;
    color:#39485c !important;
    background:#ffffff !important;
    border-bottom:1px solid rgba(108,99,240,.07) !important;
}

section.icons#vantaggi .icons__comparison-table tbody tr:last-child td{
    border-bottom:0 !important;
}

section.icons#vantaggi .icons__comparison-table tbody tr:nth-child(even) td{
    background:rgba(247,249,253,.96) !important;
}

section.icons#vantaggi .icons__comparison-table tbody tr:hover td{
    background:rgba(108,99,240,.04) !important;
}

section.icons#vantaggi .icons__comparison-table tbody td:first-child{
    color:#132131 !important;
    font-weight:800 !important;
}

section.icons#vantaggi .icons__comparison-table tbody td:nth-child(2),
section.icons#vantaggi .icons__comparison-table tbody td:nth-child(3){
    text-align:center !important;
}

section.icons#vantaggi .icons__comparison-table tbody td:last-child{
    color:#0f1730 !important;
    background:linear-gradient(180deg, rgba(108,99,240,.05) 0%, rgba(108,99,240,.02) 100%) !important;
    box-shadow:inset 2px 0 0 rgba(108,99,240,.08) !important;
}

section.icons#vantaggi .comparison-headline,
section.icons#vantaggi .comparison-feature{
    display:inline-block !important;
}

section.icons#vantaggi .comparison-pill{
    display:inline-flex !important;
    align-items:center !important;
    gap:8px !important;
    justify-content:center !important;
    padding:8px 12px !important;
    border-radius:999px !important;
    font-size:.78rem !important;
    line-height:1 !important;
    font-weight:800 !important;
    letter-spacing:.03em !important;
    white-space:nowrap !important;
}

section.icons#vantaggi .comparison-pill .material-symbols-outlined{
    font-size:1rem !important;
    line-height:1 !important;
}

section.icons#vantaggi .comparison-pill--generic{
    color:#4a5568 !important;
    background:rgba(74,85,104,.08) !important;
}

section.icons#vantaggi .comparison-pill--gemeb{
    color:#4337A8 !important;
    background:rgba(108,99,240,.10) !important;
}

section.icons#vantaggi .comparison-note{
    display:inline-block !important;
    padding:8px 10px !important;
    border-radius:14px !important;
    font-weight:700 !important;
    line-height:1.45 !important;
}

section.icons#vantaggi .comparison-note--generic{
    background:rgba(74,85,104,.06) !important;
    color:#4a5568 !important;
}

section.icons#vantaggi .comparison-note--gemeb{
    background:rgba(108,99,240,.08) !important;
    color:#132131 !important;
}

@media (max-width: 720px){
    section.icons#vantaggi .icons__comparison-table thead th,
    section.icons#vantaggi .icons__comparison-table tbody td{
        padding:14px 12px !important;
        font-size:.86rem !important;
        line-height:1.45 !important;
        letter-spacing:.02em !important;
    }

    section.icons#vantaggi .icons__comparison-table thead th{
        font-size:.72rem !important;
    }

    section.icons#vantaggi .comparison-pill{
        padding:7px 10px !important;
        font-size:.72rem !important;
    }

    section.icons#vantaggi .comparison-note{
        padding:7px 8px !important;
        border-radius:12px !important;
    }
}

section.icons#vantaggi .icons__comparison-table thead th:last-child{
    box-shadow:inset 0 0 0 1px rgba(108,99,240,.08), inset 3px 0 0 rgba(108,99,240,.14) !important;
}

section.icons#vantaggi .icons__comparison-table tbody td:last-child{
    background:linear-gradient(180deg, rgba(108,99,240,.10) 0%, rgba(108,99,240,.05) 100%) !important;
    border-left:3px solid rgba(108,99,240,.14) !important;
    box-shadow:inset 0 1px 0 rgba(255,255,255,.72) !important;
}

section.icons#vantaggi .comparison-pill--gemeb{
    color:#2f2a78 !important;
    background:linear-gradient(180deg, rgba(108,99,240,.16) 0%, rgba(108,99,240,.10) 100%) !important;
    box-shadow:inset 0 0 0 1px rgba(108,99,240,.10) !important;
}

section.icons#vantaggi .comparison-note--gemeb{
    background:linear-gradient(180deg, rgba(108,99,240,.12) 0%, rgba(108,99,240,.06) 100%) !important;
    color:#0f1730 !important;
    box-shadow:inset 0 0 0 1px rgba(108,99,240,.08) !important;
}

/* Final compliance image treatment */
section#compliance.compliance .compliance-card{
    overflow:hidden !important;
}

section#compliance.compliance .compliance-card__media{
    position:relative !important;
}

section#compliance.compliance .compliance-card__media::before{
    content:"" !important;
    position:absolute !important;
    inset:0 !important;
    z-index:1 !important;
    pointer-events:none !important;
    background:linear-gradient(180deg, rgba(255,255,255,.08) 0%, rgba(11,19,36,.06) 100%) !important;
}

section#compliance.compliance .compliance-card__media img{
    display:block !important;
    width:100% !important;
    height:100% !important;
    object-fit:cover !important;
    filter:saturate(.98) contrast(1.06) brightness(.96) !important;
    transform:scale(1) !important;
    transition:transform .6s ease, filter .6s ease !important;
    will-change:transform, filter !important;
}

section#compliance.compliance .compliance-card:hover .compliance-card__media img{
    transform:scale(1.06) !important;
    filter:saturate(1.03) contrast(1.08) brightness(.98) !important;
}

section#compliance.compliance .compliance-card:hover{
    box-shadow:0 34px 72px rgba(11,19,36,.24) !important;
}

/* Cinematic compliance refresh */
section#compliance.compliance .compliance-card__media{
    background:linear-gradient(180deg, #16162b 0%, #0b1120 100%) !important;
}

section#compliance.compliance .compliance-card__media::before{
    background:
      linear-gradient(180deg, rgba(108,99,240,.36) 0%, rgba(108,99,240,0) 38%),
      linear-gradient(180deg, rgba(35,10,79,.14) 0%, rgba(11,19,36,.78) 100%) !important;
    box-shadow:inset 0 0 0 1px rgba(255,255,255,.10), inset 0 0 0 16px rgba(255,255,255,.04) !important;
}

section#compliance.compliance .compliance-card__media::after{
    content:"" !important;
    position:absolute !important;
    inset:12px !important;
    z-index:2 !important;
    pointer-events:none !important;
    border:1px solid rgba(183,171,255,.36) !important;
    border-radius:22px !important;
    box-shadow:inset 0 0 0 1px rgba(255,255,255,.07), 0 0 0 1px rgba(11,19,36,.18) !important;
}

section#compliance.compliance .compliance-card__media img{
    filter:saturate(.66) contrast(1.28) brightness(.74) hue-rotate(-16deg) !important;
}

section#compliance.compliance .compliance-card:hover .compliance-card__media img{
    transform:scale(1.12) !important;
    filter:saturate(.90) contrast(1.30) brightness(.84) hue-rotate(-10deg) !important;
}

section#compliance.compliance .compliance-card__badge{
    position:absolute !important;
    top:18px !important;
    left:18px !important;
    z-index:4 !important;
    display:inline-flex !important;
    align-items:center !important;
    gap:8px !important;
    padding:8px 12px !important;
    border-radius:999px !important;
    background:rgba(10,18,32,.68) !important;
    border:1px solid rgba(96,140,190,.34) !important;
    color:#eef6ff !important;
    font-size:.66rem !important;
    line-height:1 !important;
    letter-spacing:.08em !important;
    text-transform:uppercase !important;
    backdrop-filter:blur(10px) saturate(1.1) !important;
    box-shadow:0 12px 28px rgba(7,10,20,.28) !important;
}

section#compliance.compliance .compliance-card__badge .material-symbols-outlined{
    font-size:1rem !important;
    line-height:1 !important;
    color:#efe1ff !important;
}

section#compliance.compliance .compliance-card__overlay{
    position:absolute !important;
    inset:auto 0 0 0 !important;
    z-index:5 !important;
    display:flex !important;
    flex-direction:column !important;
    justify-content:flex-end !important;
    background:
      linear-gradient(180deg, rgba(11,18,32,.02) 0%, rgba(58,28,92,.56) 54%, rgba(11,18,32,.94) 100%) !important;
    padding:32px 24px 24px !important;
}

section#compliance.compliance .compliance-card__overlay h3{
    position:relative !important;
    z-index:1 !important;
    color:#ffffff !important;
    font-size:1.46rem !important;
    line-height:1.12 !important;
    letter-spacing:-.045em !important;
    text-shadow:0 4px 16px rgba(7,10,20,.52) !important;
    font-weight:800 !important;
    max-width:13ch !important;
}

section#compliance.compliance .compliance-card__overlay p{
    position:relative !important;
    z-index:1 !important;
    color:rgba(255,255,255,.94) !important;
    font-size:1.12rem !important;
    line-height:1.44 !important;
    text-shadow:0 2px 12px rgba(7,10,20,.40) !important;
    font-weight:600 !important;
    max-width:30ch !important;
}
