/*
Theme Name: P4UL
Theme URI: www.p4ul.it
Author: NIER INGEGNERIA S.P.A. Bologna
Author URI: https://www.niering.it/
Description: Servizio smart di aggiornamento normativo e monitoraggio degli adempimenti.
Tags: 
Version: 2024
Requires at least: 5.2
Tested up to: 6.1
Requires PHP: 7.0
License: 
License URI: 
Text Domain: p4ul
*/

/** STILI TEMP **/

:root{
    --p4ul-primary:#4F7D67;
    --p4ul-primary-hover:#6A977F;
    --p4ul-primary-deep:#355648;
    --p4ul-primary-ink:#6A977F;
    --p4ul-text:#1E2C3A;
    --p4ul-text-soft:#66786F;
    --p4ul-bg:#F7F9FB;
    --p4ul-surface-soft:#FBFCFD;
    --p4ul-surface:#ffffff;
    --p4ul-border:rgba(79,125,103,.16);
    --p4ul-border-strong:rgba(79,125,103,.24);
    --p4ul-contrast:#13241D;
    --p4ul-secondary:#2F4B3F;
    --p4ul-tertiary:#D8E2DC;
    --p4ul-neutral:#66786F;
    --p4ul-navy:#102018;
    --p4ul-navy-deep:#0A1410;
    --p4ul-accent:#DC3545;
    --p4ul-accent-hover:#b02a37;
}

.brand-wordmark{
    letter-spacing:inherit;
    white-space:nowrap;
}

.brand-o{
    color:var(--p4ul-accent);
}

.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:var(--p4ul-accent);
}

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;
    background:
      radial-gradient(circle at center, rgba(202,214,205,.10) 0%, rgba(79,125,103,.34) 52%, rgba(16,32,51,.78) 100%),
      linear-gradient(180deg, rgba(13,19,29,.96) 0%, rgba(53,86,72,.88) 100%);
    opacity:.98;
    filter:contrast(1.04) brightness(.98) saturate(.94);
    transition:opacity 1.05s cubic-bezier(.22,1,.36,1), filter 1.05s cubic-bezier(.22,1,.36,1) !important;
}

.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(202,214,205,.16) 0%, rgba(79,125,103,.76) 68%, rgba(16,32,51,.96) 100%),
      linear-gradient(180deg, var(--p4ul-primary) 0%, var(--p4ul-primary-deep) 100%);
}

.cover--ended{
    background:
      radial-gradient(circle at center, rgba(202,214,205,.18) 0%, rgba(79,125,103,.72) 58%, rgba(53,86,72,.96) 100%),
      linear-gradient(180deg, rgba(53,86,72,.72) 0%, rgba(13,19,29,.96) 100%);
}

.cover::after{
    content:"";
    position:absolute;
    inset:0;
    background:
      radial-gradient(circle at center, rgba(202,214,205,.16) 0%, rgba(79,125,103,.64) 66%, rgba(16,32,51,.94) 100%),
      linear-gradient(180deg, rgba(90,122,105,.14) 0%, rgba(53,86,72,.68) 100%);
    opacity:0;
    transition:opacity 1.1s ease;
    pointer-events:none;
    z-index:1;
}

.cover--static{
    background:
      radial-gradient(circle at center, rgba(202,214,205,.16) 0%, rgba(79,125,103,.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::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(202,214,205,.10) 0%, rgba(202,214,205,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;
}

#funzionalita .homepage-section-title{
    color:var(--p4ul-primary-deep) !important;
    text-align:center;
    width:100%;
    margin-left:auto;
    margin-right:auto;
}

#funzionalita .features__intro .homepage-copy,
#funzionalita .features__intro p{
    color:var(--p4ul-text) !important;
}

#funzionalita .feature-card__body p{
    color:var(--p4ul-text-soft) !important;
}

.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;
}

.article-arrow-link{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    margin-left:.15em;
    color:var(--p4ul-primary);
    text-decoration:none;
    transition:transform .2s ease, color .2s ease, opacity .2s ease;
    vertical-align:middle;
}

.article-arrow-link:hover,
.article-arrow-link:focus-visible{
    transform:translateX(3px);
    opacity:.82;
}

.homepage-copy--hero-support{
    max-width:720px;
    font-size:clamp(.98rem,1.3vw,1.14rem) !important;
    line-height:1.72;
    color:var(--p4ul-text-soft);
    margin-bottom: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:760px;
    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, #102018 0%, #0A1410 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;
    }
}



/* Final contact palette adjustment */
.contacts{
    background:
      radial-gradient(circle at top left, rgba(79,125,103,.16) 0%, rgba(79,125,103,0) 34%),
      radial-gradient(circle at top right, rgba(49,86,155,.18) 0%, rgba(49,86,155,0) 32%),
      linear-gradient(180deg, #18324f 0%, #0b1521 56%, #09110d 100%);
}

.contacts__container{
    width:100%;
}

.contacts h2{
    color:var(--p4ul-surface);
}

.contacts form{
    background:rgba(9,15,24,.72);
    border:1px solid rgba(255,255,255,.14);
    border-radius:24px;
    box-shadow:0 18px 44px rgba(0,0,0,.30);
}

.contacts input[type="text"],
.contacts input[type="email"],
.contacts textarea{
    background:rgba(248,251,254,.98);
    border:1px solid rgba(202,214,205,.30);
    color:var(--p4ul-text);
}

.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;
    box-shadow:0 14px 28px rgba(220,53,69,.24);
}

.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;
}

/* 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;
}

section.contacts,
section#contacts.contacts{
    background:
      radial-gradient(circle at top left, rgba(220,53,69,.12) 0%, rgba(220,53,69,0) 34%),
      radial-gradient(circle at bottom right, rgba(79,125,103,.06) 0%, rgba(79,125,103,0) 38%),
      linear-gradient(180deg, var(--p4ul-navy) 0%, var(--p4ul-navy-deep) 100%) !important;
    color:var(--p4ul-surface) !important;
}

section.contacts h2,
section#contacts.contacts h2,
section.contacts .wpcf7-form p,
section.contacts .wpcf7-form label{
    color:var(--p4ul-surface) !important;
}

section.contacts .wpcf7-form,
section#contacts.contacts .wpcf7-form{
    background:rgba(13,19,29,.72) !important;
    border:1px solid rgba(255,255,255,.08) !important;
    border-radius:24px !important;
    box-shadow:0 18px 44px rgba(0,0,0,.18) !important;
    color:var(--p4ul-surface) !important;
}

section.contacts .wpcf7-form input:not([type="submit"]),
section.contacts .wpcf7-form textarea,
section.contacts .wpcf7-form select{
    background:rgba(248,251,254,.96) !important;
    color:var(--p4ul-text) !important;
    border-color:rgba(202,214,205,.22) !important;
}

/* Final cohesion layer */
.service-standard,
.module-card{
    border-radius:18px;
    box-shadow:0 16px 34px rgba(53,86,72,.08);
}

.service-standard{
    background:linear-gradient(180deg, rgba(255,255,255,.98) 0%, #F7FAFD 100%);
    border-color:rgba(53,86,72,.09);
}

.module-card{
    background:linear-gradient(180deg, rgba(255,255,255,.98) 0%, rgba(248,251,254,.94) 100%);
    border-color:rgba(79,125,103,.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(53,86,72,.08);
}

.service-standard{
    background:linear-gradient(180deg, rgba(255,255,255,.98) 0%, #F7FAFD 100%);
    border-color:rgba(53,86,72,.09);
}

.module-card{
    background:linear-gradient(180deg, rgba(255,255,255,.98) 0%, rgba(248,251,254,.94) 100%);
    border-color:rgba(79,125,103,.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(79,125,103,.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:68ch;
    font-size:1.06rem;
    line-height:1.74;
    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(53,86,72,.08);
    box-shadow:0 10px 20px rgba(53,86,72,.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(79,125,103,.08) 0%, rgba(79,125,103,0) 68%);
    pointer-events:none;
}

.service-standard:hover{
    transform:translateY(-3px);
    border-color:rgba(53,86,72,.14);
    box-shadow:0 16px 28px rgba(53,86,72,.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:#4e9b59;
}

.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(53,86,72,.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(53,86,72,.08);
    border-radius:32px;
    background:
        radial-gradient(circle at top right, rgba(79,125,103,.05) 0%, rgba(79,125,103,0) 28%),
        linear-gradient(180deg, rgba(255,255,255,.97) 0%, rgba(248,251,254,.95) 100%);
    box-shadow:0 18px 34px rgba(53,86,72,.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{
    margin:0;
    color:var(--p4ul-primary-deep);
    font-size:clamp(1.34rem, 2.1vw, 2.05rem);
    line-height:1.08;
    letter-spacing:-.04em;
    font-weight:900;
    max-width:26ch;
}

.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(79,125,103,.14) 0%, rgba(53,86,72,.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(53,86,72,.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(53,86,72,.10);
    background:linear-gradient(180deg, rgba(255,255,255,.98) 0%, rgba(246,249,252,.96) 100%);
    box-shadow:0 12px 22px rgba(53,86,72,.06);
}

.service__highlight span{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    width:30px;
    height:30px;
    border-radius:999px;
    background:rgba(79,125,103,.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(53,86,72,.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(53,86,72,.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(53,86,72,.08);
}

.service-standard{
    background:linear-gradient(180deg, rgba(255,255,255,.98) 0%, #F7FAFD 100%);
    border-color:rgba(53,86,72,.09);
}

.module-card{
    background:linear-gradient(180deg, rgba(255,255,255,.98) 0%, rgba(248,251,254,.94) 100%);
    border-color:rgba(79,125,103,.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;
    }
}

.contacts{
min-height:calc(100vh - 88px);
    background:
      radial-gradient(circle at top left, rgba(79,125,103,.10) 0%, rgba(79,125,103,0) 36%),
      radial-gradient(circle at bottom right, rgba(17,26,39,.18) 0%, rgba(17,26,39,0) 38%),
      linear-gradient(180deg, #1B3028 0%, #0A1410 100%);
    color:var(--p4ul-surface);
    padding-top:56px;
    padding-bottom:48px;
    display:flex;
    align-items:center;
}

.contacts__container{
    padding-bottom:0;
    max-width:900px;
}

.contacts h1{
    margin-bottom:36px;
}

.contacts h2{
    margin-bottom:36px;
    text-align:center;
    color:var(--p4ul-surface);
    font-family:"Montserrat", sans-serif;
    font-size:clamp(1.45rem, 2.6vw, 2rem);
    line-height:1.08;
    font-weight:800;
    letter-spacing:-.02em;
    max-width:28ch;
    margin-left:auto;
    margin-right:auto;
}

.contacts__title{
    display:grid;
    gap:6px;
}

.contacts__title-line{
    display:block;
}

.contacts form,
.contacts form p,
.contacts form label{
    color:var(--p4ul-surface);
}

.contacts input[type="text"],
.contacts input[type="email"],
.contacts textarea{
    color:var(--p4ul-text);
}

.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(79,125,103,.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(79,125,103,.05) 0%, rgba(79,125,103,.26) 20%, rgba(79,125,103,.26) 80%, rgba(79,125,103,.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(79,125,103,.12) 0%, rgba(79,125,103,.05) 100%);
    border:1px solid rgba(79,125,103,.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;
    }
}

.contacts form{
    background:rgba(255,255,255,.08);
    border:1px solid rgba(255,255,255,.14);
    border-radius:24px;
    padding:28px 28px 10px;
}

.contacts input[type="text"],
.contacts input[type="email"],
.contacts textarea{
    border-radius:14px;
    padding:14px 16px;
}

.contacts .cta{
    min-width:220px;
    min-height:52px;
    font-weight:700;
    letter-spacing:.01em;
    border-radius:50px;
    background:#DC3545;
    color:#ffffff;
    border:1px solid #DC3545;
    box-shadow:0 14px 30px rgba(220,53,69,.24);
}

.contacts .cta:hover,
.contacts .cta:focus-visible{
    background:#b02a37;
    color:#ffffff;
    border-color:#b02a37;
    box-shadow:0 14px 30px rgba(220,53,69,.24);
}

.contacts .wpcf7-submit,
.contacts .wpcf7 button[type="submit"]{
    min-width:220px;
    min-height:52px;
    padding:0 28px;
    border-radius:50px;
    background:#DC3545;
    color:#ffffff;
    border:1px solid #DC3545;
    font-weight:700;
    line-height:1;
    letter-spacing:.01em;
    text-transform:uppercase;
    box-shadow:0 14px 30px rgba(220,53,69,.24);
    margin:4px auto 0;
}

.contacts .wpcf7-submit:hover,
.contacts .wpcf7-submit:focus-visible,
.contacts .wpcf7 button[type="submit"]:hover,
.contacts .wpcf7 button[type="submit"]:focus-visible{
    background:#b02a37;
    color:#ffffff;
    border-color:#b02a37;
    box-shadow:0 14px 30px rgba(220,53,69,.24);
}

@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(28vw, 92px);
        max-width:min(28vw, 92px);
        padding:0;
    }

    .cover__endcard-nier{
        width:min(36vw, 112px);
    }

    .cover__signature{
        right:18px;
        bottom:14px;
        gap:4px;
    }

    .cover__scroll{
        width:42px !important;
        height:42px !important;
        margin:0 !important;
        left:50% !important;
        bottom:16px !important;
        transform:translateX(-50%) !important;
        padding:6px !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:36px;
        padding-bottom:36px;
    }

    .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:0;
        justify-content:center;
        background:transparent;
    }

    .intro#intro .homepage-hero-body .intro__left{
        width:100%;
        transform:none;
    }

    .intro#intro .homepage-hero-body .intro__right::before{
        content:none;
    }

    .homepage-image--hero{
        display:block;
        max-width:84%;
        max-height:250px;
        margin-left:auto;
        margin-right:auto;
        transform:none;
        border-radius:0;
        box-shadow: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-copy{
    max-width:58ch;
    margin:0 auto;
    text-align:center;
    color:var(--p4ul-text);
    font-size:clamp(1rem, 1.35vw, 1.16rem);
    line-height:1.62;
}

.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(79,125,103,.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(53,86,72,.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(53,86,72,.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(202,214,205,.16), transparent 44%),
      linear-gradient(180deg, rgba(79,125,103,.06) 0%, rgba(79,125,103,.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(79,125,103,.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: 560px){
    .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(79,125,103,.12);
    box-shadow:0 20px 44px rgba(53,86,72,.07);
    min-height:100%;
}

.module-card--highlight{
    border-color:rgba(79,125,103,.18);
    box-shadow:0 22px 48px rgba(53,86,72,.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(79,125,103,.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(79,125,103,.10);
    box-shadow:0 14px 32px rgba(53,86,72,.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(79,125,103,.10);
    box-shadow:0 16px 34px rgba(53,86,72,.05);
}

.feature-flow-card__icon{
    width:76px;
    height:76px;
    border-radius:50%;
    display:grid;
    place-items:center;
    margin:0;
    background:rgba(79,125,103,.14);
    box-shadow:0 10px 24px rgba(79,125,103,.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(79,125,103,.12);
    box-shadow:0 10px 24px rgba(79,125,103,.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(79,125,103,.08);
    border-left:4px solid rgba(79,125,103,.28);
    box-shadow:0 10px 22px rgba(53,86,72,.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(53,86,72,.08) !important;
}

.service-standard{
    background:linear-gradient(180deg, rgba(255,255,255,.98) 0%, #F7FAFD 100%) !important;
    border-color:rgba(53,86,72,.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(79,125,103,.08) 0%, rgba(79,125,103,0) 68%) !important;
    pointer-events:none !important;
}

.service-standard:hover{
    transform:translateY(-3px) !important;
    border-color:rgba(53,86,72,.14) !important;
    box-shadow:0 16px 28px rgba(53,86,72,.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(79,125,103,.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(79,125,103,.14) 0%, rgba(53,86,72,.08) 45%, rgba(220,53,69,.16) 100%) !important;
}

.service-step__index{
    border:1px solid rgba(53,86,72,.14) !important;
    background:linear-gradient(180deg, #ffffff 0%, #f6f9fd 100%) !important;
    color:var(--p4ul-primary-deep) !important;
    box-shadow:0 8px 16px rgba(53,86,72,.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(53,86,72,.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;
}

.contacts{
    background:
      radial-gradient(circle at top left, rgba(79,125,103,.10) 0%, rgba(79,125,103,0) 36%),
      radial-gradient(circle at bottom right, rgba(17,26,39,.18) 0%, rgba(17,26,39,0) 38%),
      linear-gradient(180deg, #1B3028 0%, #0A1410 100%) !important;
}

.contacts form{
    background:rgba(255,255,255,.06) !important;
    border:1px solid rgba(255,255,255,.12) !important;
    border-radius:24px !important;
    box-shadow:0 18px 44px rgba(0,0,0,.18) !important;
}

.contacts input[type="text"],
.contacts input[type="email"],
.contacts textarea{
    background:rgba(255,255,255,.94) !important;
    border:1px solid rgba(255,255,255,.26) !important;
    color:var(--p4ul-text) !important;
}

.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;
    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;
}

/* Vantaggi refresh */
#vantaggi.icons{
  background:
    radial-gradient(circle at top left, rgba(66,97,130,.12) 0%, rgba(66,97,130,0) 28%),
    radial-gradient(circle at bottom right, rgba(255,255,255,.06) 0%, rgba(255,255,255,0) 34%),
    linear-gradient(180deg, #0d1521 0%, #090f17 100%) !important;
  padding:88px 0 84px;
}

#vantaggi .icons__container{
  max-width:1440px;
  display:grid;
  gap:28px;
}

#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 > 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(79,125,103,.14) 0%, rgba(79,125,103,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;
    }
}

/* Vantaggi alternate layout: three feature cards on top, synthesis block below. */
#vantaggi .icons__result{
  margin-bottom:0;
}

#vantaggi .icons__layout{
  grid-template-columns:1fr;
}

#vantaggi .icons__points{
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:18px;
}

#vantaggi .icons__lead{
  position:relative;
  top:auto;
  justify-items:stretch;
  text-align:left;
}

#vantaggi .icons__lead-frame{
  width:100%;
}

@media (max-width: 1100px){
  #vantaggi .icons__points{
    grid-template-columns:1fr;
  }
}

.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:66ch;
    color:var(--p4ul-text-soft);
    font-size:clamp(1.05rem, 1.34vw, 1.18rem);
    line-height:1.68;
}

.faq{
    padding:72px 0 84px;
    background:linear-gradient(180deg, #ffffff 0%, #f8fbfe 100%);
}

.faq__container{
    display:grid;
    gap:32px;
}

.faq__intro{
    display:grid;
    gap:14px;
    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(53,86,72,.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(79,125,103,.22);
    box-shadow:0 18px 36px rgba(53,86,72,.08);
}

.faq__item[open] summary::after{
    content:"-";
}

.faq__item summary:hover,
.faq__item summary:focus-visible{
    color:var(--p4ul-primary-deep);
    background:rgba(79,125,103,.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;
}

.homepage-copy--hero-support{
    font-size:clamp(1rem,1.32vw,1.18rem) !important;
    line-height:1.74;
}

.service__subtitle{
    font-size:1.03rem;
    line-height:1.75;
}

.features__intro-copy{
    font-size:clamp(1.02rem, 1.38vw, 1.18rem);
    line-height:1.68;
}

.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);
    }
}

/* Landing refresh: closer to the provided reference, without changing the page structure. */
.intro#intro{
    background:
      radial-gradient(circle at top left, rgba(79,125,103,.08) 0%, rgba(79,125,103,0) 28%),
      radial-gradient(circle at top right, rgba(202,214,205,.18) 0%, rgba(202,214,205,0) 24%),
      linear-gradient(180deg, #ffffff 0%, #f6f9fd 100%);
    color:#1E2C3A;
}

.intro#intro .intro__container{
    min-height:calc(100svh - 56px);
    padding-top:56px;
    padding-bottom:56px;
}

.intro#intro .homepage-hero-heading{
    text-align:center;
}

.intro#intro .homepage-section-title,
.intro#intro h1{
    color:#13241D !important;
    max-width:22ch;
    margin-left:auto;
    margin-right:auto;
    text-align:center;
}

.intro#intro p,
.intro#intro .homepage-copy{
    color:#66786F !important;
}

.intro#intro strong,
.intro#intro b{
    color:#13241D;
}

.intro#intro .homepage-hero-body .intro__right::before{
    inset:4%;
    border-color:rgba(79,125,103,.14);
    background:linear-gradient(180deg, rgba(255,255,255,.9) 0%, rgba(244,248,252,.82) 100%);
}

.intro#intro .homepage-hero-body .intro__right img{
    border-radius:26px;
    box-shadow:0 34px 72px rgba(0,0,0,.34);
}

.service__steps{
    grid-template-columns:repeat(6,minmax(0,1fr));
    gap:18px;
}

.service__steps::before{
    display:none;
}

.service-step{
    display:flex;
    flex-direction:column;
    align-items:center;
    text-align:center;
    gap:14px;
    padding:24px 18px;
    min-height:100%;
    border-radius:24px;
    border:1px solid rgba(79,125,103,.14);
    background:linear-gradient(180deg, rgba(255,255,255,.98) 0%, rgba(247,250,253,.96) 100%);
    box-shadow:0 18px 38px rgba(16,32,51,.08);
}

.service-step__index{
    width:56px;
    height:56px;
    border-radius:50%;
    border:none;
    background:linear-gradient(180deg, #4F7D67 0%, #355648 100%);
    color:#fff;
    box-shadow:0 14px 24px rgba(46,143,120,.22);
}

.service-step__index::before{
    display:none;
}

.service-step__body{
    padding-top:0;
}

.service-step__body h4{
    font-size:1rem;
}

.service-step__body p{
    font-size:.94rem;
}

@media (max-width: 1200px){
    .service__steps{
        grid-template-columns:repeat(3,minmax(0,1fr));
    }
}

@media (max-width: 767px){
    .intro#intro .intro__container{
        padding-top:32px;
        padding-bottom:32px;
    }

    .intro#intro .homepage-hero-heading{
        text-align:center;
    }

    .intro#intro .homepage-section-title,
    .intro#intro h1{
        max-width:none;
        margin-left:auto;
        margin-right:auto;
    }

    .service__steps{
        grid-template-columns:1fr;
    }
}
/* Service refactor: reference-like split layout */
.service__process{
    display:grid;
    gap:24px;
    padding:0;
    border:0;
    border-radius:0;
    background:transparent;
    box-shadow:none;
}

.service__steps--horizontal{
    grid-template-columns:repeat(6,minmax(0,1fr));
    gap:18px;
}

.service__steps--horizontal::before{
    display:none;
}

.service__steps--horizontal .service-step{
    display:grid;
    grid-template-columns:1fr;
    justify-items:center;
    gap:12px;
    text-align:center;
    padding:0;
    position:relative;
}

.service__steps--horizontal .service-step:not(:last-child)::after{
    content:">";
    position:absolute;
    right:-14px;
    top:24px;
    color:var(--p4ul-primary-hover);
    font-size:1.75rem;
    line-height:1;
    font-weight:500;
    opacity:.9;
}

.service__steps--horizontal .service-step__index{
    width:54px;
    height:54px;
    font-size:.78rem;
}

.service__steps--horizontal .service-step__body{
    gap:4px;
    padding-top:0;
}

.service__steps--horizontal .service-step__body h4{
    font-size:.98rem;
    line-height:1.1;
}

.service__steps--horizontal .service-step__body p{
    font-size:.86rem;
    line-height:1.38;
    max-width:15ch;
}

.service__split{
    display:grid;
    grid-template-columns:minmax(0,.92fr) minmax(0,1.08fr);
    gap:28px;
    align-items:start;
    padding:24px;
    border:1px solid rgba(53,86,72,.08);
    border-radius:28px;
    background:linear-gradient(180deg, rgba(255,255,255,.98) 0%, rgba(248,251,254,.95) 100%);
    box-shadow:0 18px 34px rgba(53,86,72,.06);
}

.service__content{
    display:grid;
    gap:14px;
}

.service__eyebrow{
    margin:0;
    color:var(--p4ul-accent);
    font-size:.78rem;
    font-weight:800;
    letter-spacing:.18em;
    text-transform:uppercase;
}

.service__split-title{
    margin:0;
    color:var(--p4ul-primary-deep);
    font-family:"Montserrat", sans-serif;
    font-size:clamp(1.6rem, 2.8vw, 2.45rem);
    line-height:1.05;
    letter-spacing:-.04em;
    font-weight:900;
    max-width:14ch;
}

.service__subtitle--aside{
    max-width:48ch;
}

.service__featurelist{
    display:grid;
    gap:16px;
    margin-top:8px;
}

.service__featureitem{
    display:grid;
    grid-template-columns:44px minmax(0,1fr);
    gap:14px;
    align-items:start;
}

.service__featureicon{
    width:44px;
    height:44px;
    display:grid;
    place-items:center;
    border-radius:14px;
    background:rgba(79,125,103,.10);
    color:var(--p4ul-primary-deep);
    font-size:.84rem;
    font-weight:900;
    letter-spacing:.04em;
}

.service__featureicon svg{
    width:22px;
    height:22px;
    display:block;
}

.service__featureitem h4{
    margin:0;
    color:var(--p4ul-primary-deep);
    font-size:1rem;
    line-height:1.18;
    font-weight:850;
}

.service__featureitem p{
    margin:4px 0 0;
    color:var(--p4ul-text-soft);
    font-size:.95rem;
    line-height:1.55;
}

.service__steps--horizontal .service-step__index{
    width:68px;
    height:68px;
    display:grid;
    grid-template-rows:auto 1fr;
    place-items:center;
    gap:4px;
    border-radius:50%;
    border:1px solid rgba(53,86,72,.10);
    background:linear-gradient(180deg, #ffffff 0%, #f6f9fd 100%);
    box-shadow:0 10px 18px rgba(53,86,72,.08);
    color:var(--p4ul-primary-deep);
}

.service-step__index-badge{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    width:20px;
    height:20px;
    margin-top:2px;
    border-radius:999px;
    background:var(--p4ul-primary);
    color:#ffffff;
    font-size:.58rem;
    font-weight:900;
    letter-spacing:.05em;
    line-height:1;
}

.service-step__index-icon{
    display:grid;
    place-items:center;
    width:30px;
    height:30px;
}

.service-step__index-icon svg{
    width:100%;
    height:100%;
    display:block;
}

.service__steps--horizontal .service-step:not(:last-child)::after{
    content:"\2192";
    position:absolute;
    right:-14px;
    top:26px;
    color:var(--p4ul-primary-hover);
    font-size:1.4rem;
    line-height:1;
    font-weight:700;
    opacity:.9;
}

.service__steps--horizontal .service-step__body h4{
    font-size:.98rem;
    line-height:1.16;
}

.service__steps--horizontal .service-step__body p{
    font-size:.9rem;
    line-height:1.45;
    max-width:19ch;
}

.service__split{
    display:grid;
    grid-template-columns:minmax(0,.88fr) minmax(0,1.12fr);
    gap:28px;
    align-items:start;
    padding:24px;
    border:1px solid rgba(53,86,72,.08);
    border-radius:28px;
    background:linear-gradient(180deg, rgba(255,255,255,.98) 0%, rgba(248,251,254,.95) 100%);
    box-shadow:0 18px 34px rgba(53,86,72,.06);
}

.service__content{
    display:grid;
    gap:14px;
}

.service__eyebrow{
    margin:0;
    color:var(--p4ul-accent);
    font-size:.78rem;
    font-weight:800;
    letter-spacing:.18em;
    text-transform:uppercase;
}

.service__split-title{
    margin:0;
    color:var(--p4ul-primary-deep);
    font-family:"Montserrat", sans-serif;
    font-size:clamp(1.6rem, 2.8vw, 2.45rem);
    line-height:1.05;
    letter-spacing:-.04em;
    font-weight:900;
    max-width:14ch;
}

.service__subtitle--aside{
    max-width:48ch;
}

.service__featurelist{
    display:grid;
    gap:16px;
    margin-top:8px;
}

.service__featureitem{
    display:grid;
    grid-template-columns:44px minmax(0,1fr);
    gap:14px;
    align-items:start;
}

.service__featureicon{
    width:44px;
    height:44px;
    display:grid;
    place-items:center;
    border-radius:14px;
    background:rgba(79,125,103,.10);
    color:var(--p4ul-primary-deep);
    font-size:.84rem;
    font-weight:900;
    letter-spacing:.04em;
}

.service__featureitem h4{
    margin:0;
    color:var(--p4ul-primary-deep);
    font-size:1rem;
    line-height:1.18;
    font-weight:850;
}

.service__featureitem p{
    margin:4px 0 0;
    color:var(--p4ul-text-soft);
    font-size:.95rem;
    line-height:1.55;
}

.service__visual{
    display:grid;
    align-items:start;
}

.service__visual .service__dashboard{
    padding:0;
    border:0;
    border-radius:0;
    box-shadow:none;
}

.service__visual .service__dashboard img{
    border-radius:24px;
    box-shadow:0 24px 54px rgba(16,32,51,.14);
}

@media (max-width: 1100px){
    .service__steps--horizontal{
        grid-template-columns:repeat(3,minmax(0,1fr));
    }

    .service__steps--horizontal .service-step:not(:last-child)::after{
        display:none;
    }

    .service__split{
        grid-template-columns:1fr;
        gap:20px;
        padding:18px;
    }

    .service__split-title{
        max-width:none;
    }
}

@media (max-width: 720px){
    .service__steps--horizontal{
        grid-template-columns:1fr;
        gap:14px;
    }

    .service__steps--horizontal .service-step{
        grid-template-columns:48px minmax(0,1fr);
        justify-items:start;
        text-align:left;
    }

    .service__steps--horizontal .service-step:not(:last-child)::after{
        display:none;
    }

    .service__steps--horizontal .service-step__body p{
        max-width:none;
    }

    .service__featureitem{
        grid-template-columns:40px minmax(0,1fr);
        gap:12px;
    }
}

.service__visual{
    display:grid;
    align-items:start;
}

.service__visual .service__dashboard{
    padding:0;
    border:0;
    border-radius:0;
    box-shadow:none;
}

.service__visual .service__dashboard img{
    border-radius:24px;
    box-shadow:0 24px 54px rgba(16,32,51,.14);
}

@media (max-width: 1100px){
    .service__steps--horizontal{
        grid-template-columns:repeat(3,minmax(0,1fr));
    }

    .service__steps--horizontal .service-step:not(:last-child)::after{
        display:none;
    }

    .service__split{
        grid-template-columns:1fr;
        gap:20px;
        padding:18px;
    }

    .service__split-title{
        max-width:none;
    }
}

@media (max-width: 720px){
    .service__steps--horizontal{
        grid-template-columns:1fr;
        gap:14px;
    }

    .service__steps--horizontal .service-step{
        grid-template-columns:48px minmax(0,1fr);
        justify-items:start;
        text-align:left;
    }

    .service__steps--horizontal .service-step:not(:last-child)::after{
        display:none;
    }

    .service__steps--horizontal .service-step__body p{
        max-width:none;
    }

    .service__featureitem{
        grid-template-columns:40px minmax(0,1fr);
        gap:12px;
    }
}
/* Service editorial final pass */
.service__process{
    gap:30px;
}

.service__steps--horizontal{
    grid-template-columns:repeat(6,minmax(0,1fr));
    gap:12px;
}

.service__steps--horizontal .service-step{
    padding:18px 14px 16px;
    border:1px solid rgba(53,86,72,.10);
    border-radius:22px;
    background:linear-gradient(180deg, rgba(255,255,255,.99) 0%, rgba(247,250,253,.97) 100%);
    box-shadow:0 16px 30px rgba(53,86,72,.06);
}

.service__steps--horizontal .service-step:not(:last-child)::after{
    display:none;
}

.service__steps--horizontal .service-step__index{
    width:62px;
    height:62px;
    box-shadow:0 10px 18px rgba(53,86,72,.08);
}

.service__steps--horizontal .service-step__body h4{
    font-size:.96rem;
}

.service__steps--horizontal .service-step__body p{
    font-size:.9rem;
    line-height:1.45;
    max-width:none;
}

.service__split{
    gap:32px;
    padding:28px;
    border-radius:30px;
}

.service__split-title{
    max-width:12ch;
}

.service__featureitem{
    padding:16px 16px 15px;
    border:1px solid rgba(53,86,72,.08);
    border-radius:18px;
    background:linear-gradient(180deg, rgba(255,255,255,.98) 0%, rgba(247,250,253,.96) 100%);
    box-shadow:0 10px 20px rgba(53,86,72,.05);
}

.service__featureicon{
    background:rgba(79,125,103,.08);
}

.service__visual .service__dashboard img{
    border-radius:22px;
    box-shadow:0 20px 44px rgba(16,32,51,.12);
}

@media (max-width: 1100px){
    .service__steps--horizontal{
        grid-template-columns:repeat(3,minmax(0,1fr));
    }

    .service__steps--horizontal .service-step{
        padding:16px 14px 14px;
    }

    .service__split{
        padding:20px;
        gap:22px;
    }
}

@media (max-width: 720px){
    .service__steps--horizontal{
        grid-template-columns:1fr;
    }

    .service__steps--horizontal .service-step{
        grid-template-columns:56px minmax(0,1fr);
        justify-items:start;
        text-align:left;
        gap:14px;
    }

    .service__steps--horizontal .service-step__index{
        width:56px;
        height:56px;
    }

    .service__steps--horizontal .service-step__body p,
    .service__steps--horizontal .service-step__body h4{
        max-width:none;
    }

    .service__featureitem{
        padding:14px 14px 13px;
    }
}

/* Service stepper arrows visible */
.service__steps--horizontal{
    gap:18px;
}

.service__steps--horizontal .service-step:not(:last-child)::after{
    content:">";
    display:block;
    position:absolute;
    right:-16px;
    top:18px;
    color:var(--p4ul-primary-hover);
    font-size:2rem;
    line-height:1;
    font-weight:700;
    opacity:.95;
}

@media (max-width: 1100px){
    .service__steps--horizontal .service-step:not(:last-child)::after{
        display:none;
    }
}

/* Service stepper arrows fix */
.service__steps--horizontal .service-step:not(:last-child)::after{
    content:"\2192";
}

/* Service process stack */
.service__process{
    display:flex;
    flex-direction:column;
}

.service__process > *{
    width:100%;
}

/* Service icon centering */
.service__steps--horizontal .service-step__index{
    width:80px;
    height:80px;
    display:flex;
    align-items:center;
    justify-content:center;
    background:linear-gradient(180deg, rgba(255,255,255,.12) 0%, rgba(255,255,255,.05) 100%);
    box-shadow:0 12px 24px rgba(16,32,51,.12), inset 0 0 0 1px rgba(255,255,255,.12);
}

.service__steps--horizontal .service-step__index-icon{
    width:44px;
    height:44px;
    display:grid;
    place-items:center;
    margin:0 auto;
    color:#ffffff;
    filter:drop-shadow(0 2px 3px rgba(0,0,0,.18));
}

.service__steps--horizontal .service-step__index-icon svg{
    width:100%;
    height:100%;
    display:block;
    shape-rendering:geometricPrecision;
}

.service__steps--horizontal .service-step__index-icon--asset-network{
    color:#ffffff;
    background:currentColor;
    -webkit-mask-repeat:no-repeat;
    -webkit-mask-position:center;
    -webkit-mask-size:contain;
    mask-repeat:no-repeat;
    mask-position:center;
    mask-size:contain;
}

.service__steps--horizontal .service-step__index-icon--asset-network{
    -webkit-mask-image:url("build/assets/img/icone/asset-network.svg");
    mask-image:url("build/assets/img/icone/asset-network.svg");
}

.service__steps--horizontal .service-step__index-icon--asset-network svg{
    display:none;
}

.service__steps--horizontal .service-step__index-icon--threats{
    color:#ffffff;
    background:currentColor;
    -webkit-mask-repeat:no-repeat;
    -webkit-mask-position:center;
    -webkit-mask-size:contain;
    mask-repeat:no-repeat;
    mask-position:center;
    mask-size:contain;
    -webkit-mask-image:url("build/assets/img/icone/threats.svg");
    mask-image:url("build/assets/img/icone/threats.svg");
}

.service__steps--horizontal .service-step__index-icon--threats svg{
    display:none;
}

.service__steps--horizontal .service-step__index-icon--chart-evaluation{
    color:#ffffff;
    background:currentColor;
    -webkit-mask-repeat:no-repeat;
    -webkit-mask-position:center;
    -webkit-mask-size:contain;
    mask-repeat:no-repeat;
    mask-position:center;
    mask-size:contain;
    -webkit-mask-image:url("build/assets/img/icone/chart-evaluation.svg");
    mask-image:url("build/assets/img/icone/chart-evaluation.svg");
}

.service__steps--horizontal .service-step__index-icon--chart-evaluation svg{
    display:none;
}

.service__steps--horizontal .service-step__index-icon--risk-analysis-outline{
    color:#ffffff;
    background:currentColor;
    -webkit-mask-repeat:no-repeat;
    -webkit-mask-position:center;
    -webkit-mask-size:contain;
    mask-repeat:no-repeat;
    mask-position:center;
    mask-size:contain;
    -webkit-mask-image:url("build/assets/img/icone/risk-analysis-outline.svg");
    mask-image:url("build/assets/img/icone/risk-analysis-outline.svg");
}

.service__steps--horizontal .service-step__index-icon--risk-analysis-outline svg{
    display:none;
}

/* Service visual positioning */
.service__visual{
    align-self:start;
    display:flex;
    justify-content:center;
    padding-top:6px;
}

.service__visual .service__dashboard{
    width:min(100%, 720px);
    margin:0 auto;
}

.service__visual .service__dashboard img{
    display:block;
    width:100%;
    height:auto;
    object-fit:contain;
}

/* Standards integrated in service */
.service__standards--block{
    display:grid;
    gap:18px;
    margin-top:26px;
}

.service__standards-intro{
    display:grid;
    gap:10px;
    max-width:860px;
}

.service__standards-title{
    margin:0;
    color:var(--p4ul-primary-deep);
    font-family:"Montserrat", sans-serif;
    font-size:clamp(1.45rem, 2.6vw, 2.1rem);
    line-height:1.08;
    letter-spacing:-.04em;
    font-weight:900;
}

.service__standards-copy{
    margin:0;
    max-width:62ch;
    color:var(--p4ul-text-soft);
    font-size:1rem;
    line-height:1.65;
}

.service__standards-modules{
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:18px;
}

@media (max-width: 900px){
    .service__standards-modules{
        grid-template-columns:1fr;
    }
}

/* Service section final cleanup */
.service__featurewrap{
    display:grid;
    grid-template-columns:minmax(0,.95fr) minmax(360px,1.05fr);
    gap:34px;
    align-items:center;
    margin-top:24px;
}

.service__featurecontent{
    display:grid;
    gap:14px;
}

.service__featurecontent .service__split-title{
    max-width:18ch;
}

.service__visual{
    display:flex;
    flex-direction:column;
    align-items:stretch;
}

.service__featurevisual{
    display:flex;
    flex-direction:column;
    align-items:stretch;
    gap:18px;
    padding-top:28px;
    align-items:flex-end;
}

.service__featurevisual .service__dashboard{
    position:relative;
    width:min(100%, 620px);
    max-width:620px;
    padding:0;
    margin:0;
    overflow:hidden;
    align-self:flex-end;
}

.service__featurevisual .service__dashboard::before{
    content:"";
    position:absolute;
    inset:4%;
    border-radius:28px;
    background:linear-gradient(180deg, rgba(255,255,255,.9) 0%, rgba(244,248,252,.82) 100%);
    border:1px solid rgba(79,125,103,.14);
    box-shadow:0 24px 60px rgba(23,56,74,.08);
    z-index:0;
}

.service__featurevisual .service__dashboard img{
    position:relative;
    z-index:1;
    width:100%;
    display:block;
    border-radius:26px;
    max-height:410px;
    object-fit:contain;
    box-shadow:0 34px 72px rgba(0,0,0,.34);
}

.service__featurevisual .service__cards{
    display:flex;
    flex-wrap:wrap;
    gap:10px;
    justify-content:center;
    width:min(100%, 620px);
    align-self:flex-end;
    margin-top:0;
}

.service-standard--compact{
    position:relative;
    display:inline-flex;
    align-items:center;
    gap:12px;
    min-height:0;
    padding:10px 16px 10px 10px;
    border-radius:999px;
    border:1px solid rgba(19,34,48,.10);
    background:linear-gradient(180deg, #203445 0%, #132230 100%);
    box-shadow:0 12px 24px rgba(16,32,51,.18);
    overflow:hidden;
}

.service-standard--compact::before{
    content:"";
    position:absolute;
    left:42px;
    top:50%;
    width:1px;
    height:20px;
    background:rgba(255,255,255,.12);
    transform:translateY(-50%);
}

.service-standard--compact .service-standard__check{
    position:relative;
    z-index:1;
    width:24px;
    height:24px;
    display:grid;
    place-items:center;
    border-radius:999px;
    background:#ffffff;
    color:var(--p4ul-primary-deep);
    box-shadow:0 6px 14px rgba(16,32,51,.16);
    margin-left:3px;
}

.service-standard--compact .service-standard__check svg{
    width:15px;
    height:15px;
    display:block;
}

.service-standard--compact::after{
    content:"";
    position:absolute;
    inset:0 auto auto 0;
    width:100%;
    height:4px;
    background:linear-gradient(90deg, var(--p4ul-primary) 0%, var(--p4ul-primary-hover) 100%);
    opacity:.95;
}

.service-standard--compact .service-standard__body{
    position:relative;
    z-index:1;
    padding-left:0;
}

.service-standard--compact .service-standard__eyebrow{
    margin:0;
    color:#ffffff;
    font-size:.92rem;
    line-height:1.05;
    font-weight:900;
    letter-spacing:.02em;
    text-transform:uppercase;
}

@media (max-width: 900px){
    .service__featurewrap{
        grid-template-columns:1fr;
        gap:20px;
    }

    .service__featurevisual{
        padding-top:0;
    }

    .service__cards{
        grid-template-columns:1fr;
    }

    .service__featurevisual .service__cards{
        justify-content:flex-start;
    }

    .service-standard--compact{
        gap:12px;
        padding:10px 16px 10px 10px;
    }

    .service-standard--compact .service-standard__check{
        width:22px;
        height:22px;
    }
}

/* Service stepper final override */
.service__process .service__steps--horizontal .service-step__index{
    width:80px !important;
    height:80px !important;
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
    background:linear-gradient(180deg, #203445 0%, #132230 100%) !important;
    box-shadow:0 12px 24px rgba(16,32,51,.20), inset 0 0 0 1px rgba(255,255,255,.06) !important;
    color:#ffffff !important;
}

.service__process .service__steps--horizontal .service-step__index-icon{
    width:44px !important;
    height:44px !important;
    color:#ffffff !important;
}

.service__process .service__steps--horizontal .service-step__body h4{
    color:var(--p4ul-primary-deep) !important;
}

.service__process .service__steps--horizontal .service-step__body p{
    color:var(--p4ul-text-soft) !important;
}

.service__process .service__steps--horizontal .service-step__body{
    display:flex;
    flex-direction:column;
    align-items:center;
    text-align:center;
    gap:6px;
}

/* Service ISO final override */
.service__featurevisual .service-standard--compact{
    background:transparent !important;
    border:0 !important;
    box-shadow:none !important;
    padding:0 !important;
    gap:10px !important;
    color:var(--p4ul-primary-deep) !important;
}

.service__featurevisual .service-standard--compact .service-standard__check{
    width:36px !important;
    height:36px !important;
    background:linear-gradient(180deg, var(--p4ul-primary-deep) 0%, #132230 100%) !important;
    color:#ffffff !important;
    box-shadow:0 8px 18px rgba(16,32,51,.18) !important;
}

.service__featurevisual .service-standard--compact .service-standard__eyebrow{
    color:var(--p4ul-primary-deep) !important;
}

/* Vantaggi layout refresh: dashboard-led, green background. */
#vantaggi.icons{
    background:
      radial-gradient(circle at top left, rgba(79,125,103,.12) 0%, rgba(79,125,103,0) 28%),
      radial-gradient(circle at bottom right, rgba(255,255,255,.06) 0%, rgba(255,255,255,0) 34%),
      linear-gradient(180deg, #355648 0%, #0A1410 100%) !important;
    padding:88px 0 76px;
}

#vantaggi .icons__container{
    display:grid;
    gap:28px;
}

#vantaggi .icons__container > h2{
    color:#f8fafc;
    text-align:center;
    margin:0 auto;
    max-width:none;
    white-space:normal;
    font-size:clamp(1.95rem, 3vw, 3rem);
    line-height:1.02;
    letter-spacing:-.04em;
    text-shadow:0 8px 26px rgba(0,0,0,.24);
}

#vantaggi .icons__hero{
    display:grid;
    grid-template-columns:minmax(0,1.04fr) minmax(320px,.96fr);
    gap:28px;
    align-items:stretch;
}

#vantaggi .icons__hero-copy{
    display:grid;
    gap:16px;
    align-content:start;
    padding:8px 0;
}

#vantaggi .icons__eyebrow{
    margin:0;
    color:var(--p4ul-accent);
    font-size:.76rem;
    font-weight:800;
    letter-spacing:.22em;
    text-transform:uppercase;
}

#vantaggi .icons__hero-title{
    margin:0;
    color:#ffffff;
    font-size:clamp(2rem, 3.25vw, 3.4rem);
    line-height:1.02;
    letter-spacing:-.05em;
    text-wrap:balance;
    max-width:16ch;
}

#vantaggi .icons__hero-copytext{
    margin:0;
    max-width:58ch;
    color:rgba(255,255,255,.82);
    font-size:1.03rem;
    line-height:1.7;
}

#vantaggi .icons__benefits{
    display:grid;
    gap:14px;
}

#vantaggi .icons__benefit{
    display:grid;
    grid-template-columns:54px minmax(0,1fr);
    gap:16px;
    align-items:start;
    padding:18px 18px 17px;
    border-radius:24px;
    background:rgba(12,18,28,.64);
    border:1px solid rgba(255,255,255,.08);
    box-shadow:0 18px 42px rgba(0,0,0,.18);
    backdrop-filter:blur(6px);
}

#vantaggi .icons__benefit-icon{
    width:48px;
    height:48px;
    border-radius:50%;
    display:grid;
    place-items:center;
    background:linear-gradient(135deg, rgba(79,125,103,.16) 0%, rgba(79,125,103,.06) 100%);
    border:1px solid rgba(79,125,103,.18);
    color:#ffffff;
}

#vantaggi .icons__benefit-icon svg{
    width:24px;
    height:24px;
    display:block;
}

#vantaggi .icons__benefit h4{
    margin:0;
    color:#ffffff;
    font-size:1.02rem;
    line-height:1.15;
}

#vantaggi .icons__benefit p{
    margin:6px 0 0;
    color:rgba(255,255,255,.75);
    font-size:.96rem;
    line-height:1.55;
    max-width:none;
}

#vantaggi .icons__hero-visual{
    display:grid;
    align-self:start;
    padding:18px;
    border-radius:28px;
    background:rgba(255,255,255,.06);
    border:1px solid rgba(255,255,255,.10);
    box-shadow:0 24px 48px rgba(0,0,0,.22);
}

#vantaggi .icons__hero-visual img{
    width:100%;
    height:auto;
    display:block;
    border-radius:18px;
    box-shadow:0 18px 38px rgba(0,0,0,.22);
}

#vantaggi .icons__audience{
    display:grid;
    grid-template-columns:minmax(0,.82fr) minmax(0,1.18fr);
    gap:22px;
    align-items:center;
    padding:14px 0 0;
    background:transparent;
    border-top:1px solid rgba(255,255,255,.12);
    box-shadow:none;
    position:relative;
}

#vantaggi .icons__audience::before{
    content:"";
    position:absolute;
    inset:-1px 0 auto 0;
    height:3px;
    background:linear-gradient(90deg, rgba(220,53,69,.92) 0%, rgba(220,53,69,.16) 100%);
    pointer-events:none;
}

#vantaggi .icons__audience-label{
    margin:0;
    color:#ffffff;
    font-size:.78rem;
    font-weight:800;
    letter-spacing:.22em;
    text-transform:uppercase;
}

#vantaggi .icons__audience-copy{
    margin:10px 0 0;
    max-width:42ch;
    color:rgba(255,255,255,.76);
    font-size:1rem;
    line-height:1.62;
}

#vantaggi .icons__audience-chips{
    display:flex;
    flex-wrap:wrap;
    justify-content:flex-start;
    gap:8px;
    align-self:center;
    padding-left:18px;
    border-left:1px solid rgba(255,255,255,.12);
}

#vantaggi .icons__audience-chips span{
    display:inline-flex;
    align-items:center;
    min-height:34px;
    padding:8px 12px;
    border-radius:999px;
    background:rgba(255,255,255,.06);
    border:1px solid rgba(255,255,255,.10);
    color:#ffffff;
    font-size:.78rem;
    font-weight:700;
    line-height:1.15;
    letter-spacing:.01em;
    box-shadow:none;
}

#vantaggi .icons__standards{
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:14px;
}

#vantaggi .icons__standard{
    padding:16px 18px;
    border-radius:20px;
    background:linear-gradient(180deg, rgba(12,18,28,.90) 0%, rgba(9,15,23,.98) 100%);
    border:1px solid rgba(255,255,255,.08);
    box-shadow:0 16px 34px rgba(0,0,0,.18);
}

#vantaggi .icons__standard--accent{
    border-left:4px solid rgba(220,53,69,.9);
}

#vantaggi .icons__standard-kicker{
    margin:0 0 8px;
    color:rgba(255,255,255,.66);
    font-size:.68rem;
    font-weight:800;
    letter-spacing:.20em;
    text-transform:uppercase;
}

#vantaggi .icons__standard h3{
    margin:0;
    color:#ffffff;
    font-size:1rem;
    line-height:1.2;
}

#vantaggi .icons__standard p{
    margin:8px 0 0;
    color:rgba(255,255,255,.74);
    font-size:.92rem;
    line-height:1.48;
    max-width:none;
}

@media (max-width: 1100px){
    #vantaggi .icons__hero{
        grid-template-columns:1fr;
    }

    #vantaggi .icons__audience{
        grid-template-columns:1fr;
    }

    #vantaggi .icons__hero-title{
        max-width:18ch;
    }
}

@media (max-width: 720px){
    #vantaggi.icons{
        padding:56px 0 48px !important;
    }

    #vantaggi .icons__container{
        gap:20px;
    }

    #vantaggi .icons__hero-visual,
    #vantaggi .icons__audience,
    #vantaggi .icons__standard{
        padding:16px 14px;
        border-radius:20px;
    }

    #vantaggi .icons__hero-title{
        max-width:none;
        font-size:clamp(1.7rem, 8vw, 2.3rem);
    }

    #vantaggi .icons__benefit{
        grid-template-columns:46px minmax(0,1fr);
        gap:12px;
        padding:15px 15px 14px;
    }

    #vantaggi .icons__benefit-icon{
        width:42px;
        height:42px;
    }

    #vantaggi .icons__audience-chips span{
        white-space:normal;
    }
}

/* Vantaggi compact premium pass */
#vantaggi .icons__hero{
    gap:24px;
}

#vantaggi .icons__hero-copy{
    gap:14px;
}

#vantaggi .icons__hero-title{
    max-width:15ch;
}

#vantaggi .icons__hero-copytext{
    max-width:54ch;
}

#vantaggi .icons__benefits{
    gap:12px;
}

#vantaggi .icons__benefit{
    padding:16px 16px 15px;
    border-radius:22px;
    box-shadow:0 14px 32px rgba(0,0,0,.16);
}

#vantaggi .icons__hero-visual{
    padding:16px;
    border-radius:24px;
}

    #vantaggi .icons__audience{
        padding:16px 18px;
        gap:12px;
    }

#vantaggi .icons__standards{
    gap:12px;
}

#vantaggi .icons__standard{
    padding:14px 16px;
    border-radius:18px;
}

#vantaggi .icons__standard-kicker{
    margin-bottom:6px;
}

@media (max-width: 1100px){
    #vantaggi .icons__hero-title{
        max-width:17ch;
    }
}

@media (max-width: 720px){
    #vantaggi .icons__hero{
        gap:18px;
    }

    #vantaggi .icons__hero-copy{
        gap:12px;
    }

    #vantaggi .icons__benefits{
        gap:10px;
    }

    #vantaggi .icons__hero-visual{
        padding:14px;
    }

    #vantaggi .icons__audience{
        grid-template-columns:1fr;
        padding:12px 0 0;
        gap:14px;
    }

    #vantaggi .icons__audience-chips{
        padding-left:0;
        border-left:0;
    }
}

/* Vantaggi final polish: clearer hierarchy and stronger rhythm. */
#vantaggi .icons__hero{
    grid-template-columns:minmax(0,.86fr) minmax(420px,1.14fr) !important;
    gap:24px !important;
    align-items:center !important;
}

#vantaggi .icons__hero-copy{
    gap:12px !important;
    padding-top:6px !important;
}

#vantaggi .icons__hero-title{
    max-width:14ch !important;
}

#vantaggi .icons__benefits{
    display:grid !important;
    grid-template-columns:repeat(3,minmax(0,1fr)) !important;
    gap:12px !important;
}

#vantaggi .icons__benefit{
    grid-template-columns:1fr !important;
    gap:10px !important;
    padding:16px !important;
    border-radius:20px !important;
    min-height:100% !important;
}

#vantaggi .icons__benefit-icon{
    width:44px !important;
    height:44px !important;
}

#vantaggi .icons__benefit h4{
    font-size:.98rem !important;
}

#vantaggi .icons__benefit p{
    font-size:.92rem !important;
    line-height:1.5 !important;
}

#vantaggi .icons__hero-visual{
    padding:12px !important;
    border-radius:28px !important;
    align-self:center !important;
}

#vantaggi .icons__hero-caption{
    font-size:.88rem !important;
    max-width:34ch !important;
}

#vantaggi .icons__audience{
    padding:18px 20px !important;
    gap:12px !important;
}

#vantaggi .icons__audience-label{
    font-size:.96rem !important;
}

    #vantaggi .icons__audience-chips{
        gap:8px 8px !important;
    }

    #vantaggi .icons__audience-chips span{
        min-height:32px !important;
        padding:7px 11px !important;
        font-size:.8rem !important;
    }

#vantaggi .icons__standards{
    gap:12px !important;
}

#vantaggi .icons__standard{
    padding:14px 16px !important;
    border-radius:18px !important;
}

#vantaggi .icons__standard h3{
    font-size:.98rem !important;
}

#vantaggi .icons__standard p{
    margin-top:6px !important;
    font-size:.9rem !important;
    line-height:1.46 !important;
}

@media (max-width: 1100px){
    #vantaggi .icons__benefits{
        grid-template-columns:1fr !important;
    }

    #vantaggi .icons__hero-title{
        max-width:18ch !important;
    }
}

@media (max-width: 720px){
    #vantaggi .icons__hero{
        gap:18px !important;
    }

    #vantaggi .icons__benefits{
        gap:10px !important;
    }

    #vantaggi .icons__hero-visual{
        padding:12px !important;
    }

    #vantaggi .icons__audience{
        padding:14px 14px 12px !important;
    }

    #vantaggi .icons__audience-chips span{
        white-space:normal !important;
    }
}

/* Vantaggi dashboard emphasis: make the visual read as the main anchor. */
#vantaggi .icons__hero{
    grid-template-columns:minmax(0,.68fr) minmax(520px,1.32fr) !important;
    gap:18px !important;
    align-items:center !important;
}

#vantaggi .icons__hero-copy{
    gap:14px !important;
    padding-top:0 !important;
}

#vantaggi .icons__hero-copytext{
    max-width:52ch !important;
    font-size:1.06rem !important;
    line-height:1.72 !important;
    color:rgba(255,255,255,.84) !important;
}

#vantaggi .icons__benefits{
    gap:10px !important;
}

#vantaggi .icons__benefit{
    padding:15px !important;
    border-radius:18px !important;
}

#vantaggi .icons__hero-visual{
    padding:8px !important;
    border-radius:30px !important;
    background:rgba(255,255,255,.04) !important;
    box-shadow:0 30px 64px rgba(0,0,0,.28) !important;
}

#vantaggi .icons__hero-visual img{
    border-radius:16px !important;
    box-shadow:0 24px 52px rgba(0,0,0,.30) !important;
}

#vantaggi .icons__hero-caption{
    max-width:none !important;
    font-size:.84rem !important;
    letter-spacing:.01em !important;
}

@media (max-width: 1100px){
    #vantaggi .icons__hero{
        grid-template-columns:1fr !important;
    }

    #vantaggi .icons__hero-title{
        max-width:18ch !important;
    }
}

@media (max-width: 720px){
    #vantaggi .icons__hero-visual{
        padding:10px !important;
    }

    #vantaggi .icons__hero-caption{
        font-size:.9rem !important;
    }
}

#vantaggi .icons__standard-list{
    list-style:none;
    margin:10px 0 0;
    padding:0;
    display:grid;
    gap:8px;
}

#vantaggi .icons__standard-list li{
    position:relative;
    padding-left:18px;
    color:rgba(255,255,255,.80);
    font-size:.92rem;
    line-height:1.44;
}

#vantaggi .icons__standard-list li::before{
    content:"";
    position:absolute;
    left:0;
    top:.56em;
    width:7px;
    height:7px;
    border-radius:50%;
    background:var(--p4ul-accent);
    box-shadow:0 0 0 4px rgba(66,184,155,.10);
}

@media (max-width: 720px){
    #vantaggi .icons__standard-list{
        gap:6px;
    }

    #vantaggi .icons__standard-list li{
        font-size:.88rem;
    }
}

/* Restore the earlier green dotted background for Vantaggi. */
#vantaggi.icons{
    background:
      radial-gradient(circle at 1px 1px, rgba(255,255,255,.06) 1px, transparent 0) 0 0/18px 18px,
      radial-gradient(circle at top left, rgba(79,125,103,.10) 0%, rgba(79,125,103,0) 36%),
      radial-gradient(circle at bottom right, rgba(53,86,72,.18) 0%, rgba(53,86,72,0) 38%),
      linear-gradient(180deg, #355648 0%, #0A1410 100%) !important;
}

/* Vantaggi ISO strip: one intro plus a checklist panel. */
#vantaggi .icons__standards-strip{
    display:grid;
    grid-template-columns:minmax(0,.72fr) minmax(0,1.28fr);
    gap:18px;
    align-items:stretch;
    padding:22px 24px;
    border-radius:28px;
    background:linear-gradient(180deg, rgba(255,255,255,.94) 0%, rgba(246,249,252,.92) 100%);
    border:1px solid rgba(79,125,103,.12);
    box-shadow:0 20px 46px rgba(0,0,0,.12);
}

#vantaggi .icons__standards-copy{
    display:grid;
    gap:10px;
    padding-right:18px;
    border-right:1px solid rgba(79,125,103,.14);
}

#vantaggi .icons__standards-kicker{
    margin:0;
    color:var(--p4ul-primary-deep);
    font-size:.74rem;
    font-weight:800;
    letter-spacing:.22em;
    text-transform:uppercase;
}

#vantaggi .icons__standards-copy h3{
    margin:0;
    color:var(--p4ul-primary-deep);
    font-size:clamp(1.35rem, 1.9vw, 1.9rem);
    line-height:1.08;
    letter-spacing:-.04em;
}

#vantaggi .icons__standards-copy p{
    margin:0;
    color:var(--p4ul-text-soft);
    font-size:1rem;
    line-height:1.6;
    max-width:30ch;
}

#vantaggi .icons__standards-list{
    display:grid;
    gap:12px;
    padding:10px 14px 10px 18px;
    border-radius:22px;
    background:rgba(255,255,255,.96);
    border:1px solid rgba(79,125,103,.10);
    box-shadow:0 16px 36px rgba(0,0,0,.08);
}

#vantaggi .icons__standards-note{
    margin:0;
    color:var(--p4ul-primary-deep);
    font-size:1rem;
    font-weight:800;
    line-height:1.25;
}

#vantaggi .icons__standard-checklist{
    list-style:none;
    margin:0;
    padding:0;
    display:grid;
    gap:8px;
}

#vantaggi .icons__standard-checklist li{
    position:relative;
    padding-left:24px;
    color:var(--p4ul-primary-deep);
    font-size:.95rem;
    line-height:1.45;
}

#vantaggi .icons__standard-checklist li::before{
    content:"✓";
    position:absolute;
    left:0;
    top:.02em;
    color:#2a67d0;
    font-weight:900;
}

@media (max-width: 1100px){
    #vantaggi .icons__standards-strip{
        grid-template-columns:1fr;
    }

    #vantaggi .icons__standards-copy{
        padding-right:0;
        padding-bottom:16px;
        border-right:0;
        border-bottom:1px solid rgba(79,125,103,.14);
    }
}

@media (max-width: 720px){
    #vantaggi .icons__standards-strip{
        padding:18px 16px;
        border-radius:22px;
    }

    #vantaggi .icons__standards-list{
        padding:12px 12px 10px;
    }
}

/* Red accents for NIER identity. */
#vantaggi .icons__standards-strip{
    position:relative;
    overflow:hidden;
}

#vantaggi .icons__standards-strip::before{
    content:"";
    position:absolute;
    inset:0 auto auto 0;
    width:100%;
    height:3px;
    background:linear-gradient(90deg, rgba(220,53,69,.92) 0%, rgba(220,53,69,.20) 100%);
    pointer-events:none;
}

#vantaggi .icons__benefit:nth-child(3) .icons__benefit-icon{
    background:linear-gradient(135deg, rgba(220,53,69,.18) 0%, rgba(220,53,69,.08) 100%) !important;
    border-color:rgba(220,53,69,.24) !important;
    box-shadow:0 0 0 1px rgba(220,53,69,.10), 0 10px 24px rgba(220,53,69,.10) !important;
}

#vantaggi .icons__benefit:nth-child(3) .icons__benefit-icon svg{
    color:#e05662;
}

/* Benefit grid final lock: four cards, 2x2, with standard card accent. */
#vantaggi .icons__benefits{
    grid-template-columns:repeat(2,minmax(0,1fr)) !important;
    gap:12px !important;
}

#vantaggi .icons__benefit:nth-child(3) .icons__benefit-icon{
    background:linear-gradient(135deg, rgba(79,125,103,.16) 0%, rgba(79,125,103,.06) 100%) !important;
    border-color:rgba(79,125,103,.18) !important;
    box-shadow:none !important;
}

#vantaggi .icons__benefit:nth-child(3) .icons__benefit-icon svg{
    color:#ffffff !important;
}

#vantaggi .icons__benefit:nth-child(4){
    border-color:rgba(220,53,69,.16) !important;
    box-shadow:0 18px 42px rgba(0,0,0,.18), 0 0 0 1px rgba(220,53,69,.10) inset !important;
}

#vantaggi .icons__benefit:nth-child(4) .icons__benefit-icon{
    background:linear-gradient(135deg, rgba(220,53,69,.18) 0%, rgba(220,53,69,.08) 100%) !important;
    border-color:rgba(220,53,69,.22) !important;
    box-shadow:0 0 0 1px rgba(220,53,69,.10), 0 10px 24px rgba(220,53,69,.10) !important;
}

#vantaggi .icons__benefit:nth-child(4) .icons__benefit-icon svg{
    color:#e05662 !important;
}

@media (max-width: 1100px){
    #vantaggi .icons__benefits{
        grid-template-columns:1fr !important;
    }
}

#vantaggi .icons__section-copy{
    margin:0 auto;
    max-width:74ch;
    color:rgba(255,255,255,.82);
    font-size:1.04rem;
    line-height:1.68;
    text-align:center;
}

#vantaggi .icons__hero-copytext{
    display:none !important;
}

@media (max-width: 720px){
    #vantaggi .icons__section-copy{
        font-size:.98rem;
        line-height:1.62;
    }
}

/* Vantaggi balance pass: make the cards and dashboard occupy the same space. */
#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;
}

#vantaggi .icons__benefit{
    min-height:0 !important;
}

#vantaggi .icons__hero-visual{
    align-self:stretch !important;
    height:100% !important;
    justify-self:end !important;
    width:min(100%, 620px) !important;
    margin-top:4px !important;
    padding:12px !important;
    border-radius:28px !important;
}

#vantaggi .icons__hero-visual img{
    width:100% !important;
    height:auto !important;
    border-radius:16px !important;
    box-shadow:0 18px 38px rgba(0,0,0,.22) !important;
}

/* Audience strip final pass: editorial line instead of a card. */
#vantaggi .icons__audience{
    grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr) !important;
    gap:16px !important;
    align-items:start !important;
    padding:10px 0 0 !important;
    background:transparent !important;
    border-top:1px solid rgba(255,255,255,.12) !important;
    box-shadow:none !important;
    position:relative !important;
    overflow:visible !important;
}

#vantaggi .icons__audience::before{
    content:"" !important;
    position:absolute !important;
    inset:-1px 0 auto 0 !important;
    height:3px !important;
    background:linear-gradient(90deg, rgba(220,53,69,.92) 0%, rgba(220,53,69,.16) 100%) !important;
    border-radius:999px !important;
    pointer-events:none !important;
}

#vantaggi .icons__audience-label{
    color:#ffffff !important;
    font-size:.82rem !important;
    letter-spacing:.19em !important;
}

#vantaggi .icons__audience-copy{
    margin:6px 0 0 !important;
    max-width:40ch !important;
    color:rgba(255,255,255,.74) !important;
    font-size:.97rem !important;
    line-height:1.56 !important;
}

#vantaggi .icons__audience-chips{
    display:flex !important;
    flex-wrap:wrap !important;
    justify-content:flex-start !important;
    gap:7px !important;
    align-self:start !important;
    padding-left:0 !important;
    border-left:0 !important;
}

#vantaggi .icons__audience-chips span{
    min-height:30px !important;
    padding:7px 10px !important;
    border-radius:999px !important;
    background:#1c2633 !important;
    border:1px solid rgba(255,255,255,.10) !important;
    color:#ffffff !important;
    font-size:.75rem !important;
    line-height:1.12 !important;
    box-shadow:none !important;
}

@media (max-width: 720px){
#vantaggi .icons__audience{
        grid-template-columns:1fr !important;
        padding:16px !important;
        gap:12px !important;
    }

    #vantaggi .icons__audience-chips{
        padding-left:0 !important;
        border-left:0 !important;
    }
}

/* Audience band: regular 3x2 image grid. */
.icons__audience{
    display:grid !important;
    grid-template-columns:minmax(240px, .72fr) minmax(0, 1.28fr) !important;
    grid-template-areas:"title roles" !important;
    gap:18px 24px !important;
    margin-top:20px !important;
    padding:18px 0 0 !important;
    background:transparent !important;
    border:0 !important;
    border-radius:0 !important;
    box-shadow:none !important;
    position:relative !important;
}

.icons__audience-roles{
    grid-area:roles !important;
    display:grid !important;
    grid-template-columns:repeat(3, minmax(0, 1fr)) !important;
    grid-template-rows:repeat(2, minmax(168px, auto)) !important;
    grid-auto-flow:row !important;
    gap:12px !important;
    align-items:stretch !important;
    justify-content:center !important;
    justify-items:stretch !important;
    padding:0 !important;
    border:0 !important;
    width:100% !important;
}

.icons__audience-title{
    grid-area:title !important;
    margin:0 !important;
    display:flex !important;
    align-items:center !important;
    color:#ffffff !important;
    font-family:"Montserrat", sans-serif !important;
    font-size:clamp(1.35rem, 1.9vw, 2.1rem) !important;
    line-height:1.08 !important;
    letter-spacing:-.035em !important;
    font-weight:700 !important;
    text-align:left !important;
    justify-self:start !important;
    width:100% !important;
    max-width:12ch !important;
    align-self:center !important;
    min-height:100% !important;
}

.icons__audience-roles span{
    position:relative !important;
    display:flex !important;
    flex-direction:column !important;
    align-items:center !important;
    justify-content:flex-start !important;
    gap:10px !important;
    min-height:142px !important;
    padding:12px 12px 10px !important;
    text-align:center !important;
    overflow:hidden !important;
    border-radius:20px !important;
    background:
        linear-gradient(180deg, rgba(13,20,31,.06) 0%, rgba(13,20,31,.18) 52%, rgba(13,20,31,.64) 100%) !important,
        rgba(13, 20, 31, .76) !important;
    border:1px solid rgba(255,255,255,.06) !important;
    color:#ffffff !important;
    box-shadow:0 12px 22px rgba(0,0,0,.16) !important;
    isolation:isolate !important;
    width:100% !important;
    max-width:none !important;
    justify-self:stretch !important;
}

.icons__audience-roles span::before{
    content:"" !important;
    position:absolute !important;
    inset:0 !important;
    background:
        radial-gradient(circle at 18% 12%, rgba(255,255,255,.08) 0%, rgba(255,255,255,0) 42%),
        linear-gradient(180deg, rgba(255,255,255,.02) 0%, rgba(255,255,255,0) 40%) !important;
    z-index:0 !important;
    pointer-events:none !important;
}

.icons__audience-roles span::after{
    content:"" !important;
    position:absolute !important;
    inset:auto 12px 12px auto !important;
    width:24px !important;
    height:24px !important;
    border-radius:999px !important;
    border:1px solid rgba(255,255,255,.14) !important;
    box-shadow:0 0 0 1px rgba(255,255,255,.06) inset !important;
    opacity:.38 !important;
    z-index:0 !important;
}

.icons__audience-roles span img{
    position:relative !important;
    z-index:1 !important;
    display:block !important;
    width:68px !important;
    height:68px !important;
    object-fit:contain !important;
    flex:0 0 auto !important;
    opacity:1 !important;
    filter:drop-shadow(0 10px 18px rgba(0,0,0,.20)) !important;
}

.icons__audience-roles span{
    font-size:.82rem !important;
    line-height:1.22 !important;
}

@media (max-width: 1100px){
    .icons__audience{
        grid-template-columns:minmax(0, 1fr) !important;
        grid-template-areas:
            "title"
            "roles" !important;
        gap:14px !important;
    }

    .icons__audience-title{
        max-width:18ch !important;
        align-self:start !important;
    }

    .icons__audience-roles{
        grid-template-columns:repeat(3, minmax(0, 1fr)) !important;
        grid-template-rows:repeat(2, minmax(136px, auto)) !important;
    }
}

@media (max-width: 720px){
    .icons__audience-title{
        max-width:none !important;
    }

    .icons__audience-roles{
        grid-template-columns:1fr !important;
        grid-template-rows:auto !important;
        grid-auto-rows:auto !important;
        gap:10px !important;
    }

    .icons__audience-title{
        max-width:none !important;
        text-align:left !important;
    }

    .icons__audience-roles span,
    .icons__audience-roles span:nth-child(1),
    .icons__audience-roles span:nth-child(2),
    .icons__audience-roles span:nth-child(3),
    .icons__audience-roles span:nth-child(4),
    .icons__audience-roles span:nth-child(5),
    .icons__audience-roles span:nth-child(6){
        grid-column:auto !important;
        grid-row:auto !important;
        min-height:0 !important;
        padding:12px !important;
    }

    .icons__audience-roles span{
        flex-direction:column !important;
        align-items:center !important;
        gap:12px !important;
    }

    .icons__audience-roles span img,
    .icons__audience-roles span:nth-child(1) img,
    .icons__audience-roles span:nth-child(2) img,
    .icons__audience-roles span:nth-child(3) img,
    .icons__audience-roles span:nth-child(4) img,
    .icons__audience-roles span:nth-child(5) img,
    .icons__audience-roles span:nth-child(6) img{
        width:68px !important;
        height:68px !important;
    }
}

@media (max-width: 720px){
    #vantaggi .icons__hero-visual{
        padding:0 !important;
        background:transparent !important;
        border:0 !important;
        border-radius:0 !important;
        box-shadow:none !important;
    }

    #vantaggi .icons__hero-visual img{
        border-radius:16px !important;
        box-shadow:none !important;
    }

    .service__process .service__steps--horizontal .service-step__index{
        width:56px !important;
        height:56px !important;
    }

    .service__process .service__steps--horizontal .service-step__index-icon{
        width:30px !important;
        height:30px !important;
    }
}
