:root{--ice:#f2f5f9;--ice2:#e8eef6;--ice3:#d8e4f0;--ice4:#c4d6eb;--blue:#0b1f3a;--blue2:#152f58;--blue3:#1e4282;--acc:#3a7be0;--acc2:#5b9ef5;--white:#fff;--text:#0b1f3a;--muted:#4e6280;--R:9999px;--s1:0 4px 20px rgba(11,31,58,.07);--s2:0 12px 44px rgba(11,31,58,.13);--s3:0 24px 72px rgba(11,31,58,.18)}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{overflow-x:hidden;scroll-behavior:smooth}
body{background:var(--ice);color:var(--text);font-family:'DM Sans',sans-serif;font-weight:300;overflow-x:hidden;cursor:none}
/** CURSOR */ .cur{position:fixed;width:10px;height:10px;background:var(--acc);border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);mix-blend-mode:multiply;transition:width .3s,height .3s}
.cur-r{position:fixed;width:36px;height:36px;border:1.5px solid rgba(58,123,224,.3);border-radius:50%;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);transition:width .4s,height .4s,border-color .3s}
.cur.h{width:5px;height:5px}
.cur-r.h{width:50px;height:50px;border-color:var(--acc)}
/** NAV */ nav{position:fixed;top:0;left:0;right:0;z-index:300;padding:22px 60px;display:flex;justify-content:space-between;align-items:center;transition:all .5s}
nav.s{background:rgba(242,245,249,.98);padding:12px 36px;box-shadow:0 2px 24px rgba(11,31,58,.06)}
.nav-logo{display:flex;align-items:center;gap:12px;text-decoration:none;position:static}
.nav-logo-img{width:50px;height:50px;object-fit:contain;border-radius:50%;background:#fff;padding:1px;transition:background .4s;flex-shrink:0}
nav.s .nav-logo-img{background:#fff}
.nav-brand{font-family:'Copperplate Gothic Light','Copperplate',fantasy;font-size:.82rem;letter-spacing:.06em;text-transform:uppercase;color:#fff;line-height:1.1;transition:color .4s;white-space:nowrap}
.nav-brand .BIG{font-size:1.15em}
nav.s .nav-brand{color:var(--blue)}
.nav-sub-t{font-family:'DM Serif Display',serif;font-size:.48rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.4);display:none;transition:color .4s}
nav.s .nav-sub-t{color:var(--muted)}
.nav-right{display:flex;align-items:center;gap:16px}
.nav-links{display:none;gap:26px;list-style:none}
.nav-links a{font-size:.66rem;letter-spacing:.13em;text-transform:uppercase;color:rgba(255,255,255,.7);text-decoration:none;transition:color .3s;position:relative}
nav.s .nav-links a{color:var(--muted)}
.nav-links a::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:1.5px;background:var(--acc);transition:width .3s}
.nav-links a:hover{color:var(--acc)!important}
.nav-links a:hover::after{width:100%}
/** MENU BUTTON — mobile only */ .nav-menu-btn{display:none;background:rgba(255,255,255,.12);border:1.5px solid rgba(255,255,255,.25);border-radius:12px;width:44px;height:44px;flex-direction:column;align-items:center;justify-content:center;gap:5px;cursor:pointer;transition:background .3s,border-color .3s;flex-shrink:0}
.nav-menu-btn span{width:18px;height:1.5px;background:#fff;border-radius:2px;transition:all .3s;display:block}
nav.s .nav-menu-btn{background:var(--ice2);border-color:var(--ice3)}
nav.s .nav-menu-btn span{background:var(--blue)}
.nav-menu-btn.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.nav-menu-btn.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.nav-menu-btn.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}
/** MOBILE FULL-SCREEN NAV OVERLAY */ .mob-nav{position:fixed;inset:0;background:var(--blue);z-index:200;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:80px 24px 48px;opacity:0;pointer-events:none;transform:translateY(-16px);transition:opacity .35s ease,transform .35s ease}
.mob-nav.open{opacity:1;pointer-events:all;transform:translateY(0)}
.mob-nav-item{font-family:'Cormorant Garamond',serif;font-size:2.1rem;font-weight:300;color:rgba(255,255,255,.7);text-decoration:none;letter-spacing:.03em;padding:18px 0;text-align:center;display:block;width:100%;border-bottom:1px solid rgba(255,255,255,.07);transition:color .2s}
.mob-nav-item:first-of-type{border-top:1px solid rgba(255,255,255,.07)}
.mob-nav-item:active{color:#fff;background:rgba(255,255,255,.05)}
.mob-nav-cta{margin-top:32px;width:100%;max-width:280px}
/** BUBBLE BUTTONS */ .btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;border:none;cursor:none;font-family:'DM Sans',sans-serif;font-weight:400;letter-spacing:.09em;text-transform:uppercase;text-decoration:none;transition:all .38s cubic-bezier(.34,1.56,.64,1)}
.btn-g{background:linear-gradient(135deg,var(--acc) 0%,var(--acc2) 55%,#7ab8ff 100%);color:#fff;padding:14px 34px;border-radius:var(--R);font-size:.72rem;box-shadow:0 4px 22px rgba(58,123,224,.34),inset 0 1px 0 rgba(255,255,255,.22)}
.btn-g:hover{transform:translateY(-3px) scale(1.04);box-shadow:0 12px 38px rgba(58,123,224,.46)}
.btn-d{background:linear-gradient(135deg,var(--blue) 0%,var(--blue2) 60%,var(--blue3) 100%);color:#fff;padding:14px 34px;border-radius:var(--R);font-size:.72rem;box-shadow:0 4px 22px rgba(11,31,58,.28),inset 0 1px 0 rgba(255,255,255,.1)}
.btn-d:hover{transform:translateY(-3px) scale(1.04);box-shadow:0 12px 38px rgba(11,31,58,.4)}
.btn-gl{background:rgba(255,255,255,.11);color:#fff;padding:14px 34px;border-radius:var(--R);font-size:.72rem;border:1.5px solid rgba(255,255,255,.24)}
.btn-gl:hover{background:rgba(255,255,255,.2);transform:translateY(-2px)}
.btn-w{background:#fff;color:var(--blue);padding:15px 38px;border-radius:var(--R);font-size:.72rem;font-weight:500;box-shadow:0 4px 22px rgba(255,255,255,.22)}
.btn-w:hover{transform:translateY(-3px) scale(1.04);box-shadow:0 14px 40px rgba(255,255,255,.34)}
/** SERVICE CARD BOOK BUTTON — animated, rectangular right-anchored */ .sc-book-btn{display:block;width:100%;background:linear-gradient(135deg,var(--blue) 0%,var(--blue2) 60%,var(--blue3) 100%);color:#fff;padding:13px 20px;border-radius:0 0 24px 24px;font-family:'DM Sans',sans-serif;font-size:.76rem;font-weight:400;letter-spacing:.12em;text-transform:uppercase;border:none;cursor:none;text-align:center;transition:all .35s ease;position:relative;overflow:hidden;box-shadow:inset 0 1px 0 rgba(255,255,255,.1)}
.sc-book-btn::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,var(--acc) 0%,var(--acc2) 60%,#7ab8ff 100%);opacity:0;transition:opacity .4s}
.sc-book-btn::after{content:'';position:absolute;top:50%;left:-60%;width:40%;height:200%;background:rgba(255,255,255,.15);transform:translateY(-50%) skewX(-20deg);transition:left .5s ease}
.sc-book-btn span{position:relative;z-index:1}
.sc:hover .sc-book-btn{transform:none;box-shadow:0 4px 20px rgba(11,31,58,.25);animation:bookPulse 1.5s ease-in-out 3}
.sc:hover .sc-book-btn::before{opacity:1}
.sc:hover .sc-book-btn::after{left:120%}
@keyframes bookPulse{0%,100%{box-shadow:0 4px 22px rgba(58,123,224,.3),inset 0 1px 0 rgba(255,255,255,.1);}50%{box-shadow:0 8px 32px rgba(58,123,224,.55),inset 0 1px 0 rgba(255,255,255,.18);}}
.sc-book-btn{animation:none;width:auto!important;border-radius:100px!important;padding:11px 28px!important;font-size:.7rem!important;margin:6px 0 16px!important;display:inline-block!important;box-shadow:0 4px 18px rgba(11,31,58,.22)!important}
/** HERO */ .hero{min-height:100vh;background:linear-gradient(148deg,var(--blue) 0%,var(--blue2) 48%,var(--blue3) 100%);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;position:relative;overflow:hidden;padding:140px 40px 100px}
.orb{position:absolute;border-radius:50%;filter:blur(60px);pointer-events:none}
.ob1{width:560px;height:560px;background:rgba(91,158,245,.15);top:-130px;right:-130px}
.ob2{width:380px;height:380px;background:rgba(58,123,224,.12);bottom:-80px;left:-80px}
.ob3{width:220px;height:220px;background:rgba(184,149,90,.07);top:42%;left:42%}
.hgrid{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);background-size:62px 62px;display:none}
.hring{position:absolute;border-radius:50%;border:1px solid rgba(255,255,255,.06);top:50%;left:50%;transform:translate(-50%,-50%);pointer-events:none}
.r1{width:680px;height:680px}
.r2{width:880px;height:880px}
.r3{width:480px;height:480px;border-color:rgba(255,255,255,.04)}
.hlogo-wrap{display:none}
.htitle{font-family:'Cormorant Garamond',serif;font-size:clamp(2.4rem,9vw,3.2rem);font-weight:300;line-height:1.06;color:#fff;margin-bottom:12px;opacity:0;animation:fadeIn .2s ease forwards;max-width:860px}
.htitle em{font-style:italic;color:var(--acc2)}
.hsub{font-size:.86rem;line-height:1.75;color:rgba(255,255,255,.56);max-width:580px;margin:0 auto 48px;opacity:0;animation:fadeIn .2s ease .1s forwards;margin-bottom:28px}
.hactions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;opacity:0;animation:fadeIn .2s ease .15s forwards}
.hstats{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;margin-top:24px;opacity:0;animation:fadeIn .2s ease .2s forwards}
.hstat{background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.13);border-radius:16px;padding:12px 14px;text-align:center;min-width:0;width:100%}
.hstat-n{font-family:'Cormorant Garamond',serif;font-size:1.9rem;font-weight:300;color:#fff;line-height:1}
.hstat-n sup{font-size:1rem;vertical-align:super;color:var(--acc2)}
.hstat-l{font-size:.58rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.42);margin-top:4px}
.scrl{position:static;bottom:34px;left:auto;transform:none;display:flex;flex-direction:column;align-items:center;gap:8px;font-size:.58rem;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.26);opacity:0;animation:fadeIn .2s ease .25s forwards;margin-top:28px;padding-bottom:8px}
.scrl-l{width:1px;height:42px;background:linear-gradient(to bottom,rgba(255,255,255,.34),transparent)}
/** STATS STRIP — mobile only, after marquee */ .stats-strip{display:none;background:var(--blue);padding:20px 20px 24px;gap:12px}
.stats-strip .hstat{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.14);border-radius:14px;padding:14px 8px;text-align:center;flex:1;min-width:0}
@media(max-width:640px){.stats-strip{display:flex}}
@media(min-width:641px){.stats-strip{display:none!important}}
/** MARQUEE */ .mq-wrap{background:var(--blue);padding:16px 0}
.mq-track{display:flex;gap:32px;flex-wrap:wrap;justify-content:center;white-space:normal}
.mq-item{display:flex;align-items:center;gap:14px;font-size:.63rem;letter-spacing:.24em;text-transform:uppercase;color:rgba(255,255,255,.3);flex-shrink:0}
.mq-dot{width:4px;height:4px;background:var(--acc2);border-radius:50%;flex-shrink:0}
/** SECTIONS */ section{padding:100px 60px}
.sec-in{max-width:1080px;margin:0 auto}
.stag{display:inline-flex;align-items:center;gap:10px;font-size:.6rem;letter-spacing:.28em;text-transform:uppercase;color:var(--acc);margin-bottom:14px}
.stag::before,.stag::after{content:'';width:16px;height:1.5px;background:var(--acc);border-radius:2px}
.stag.w{color:var(--acc2)}
.stag.w::before,.stag.w::after{background:var(--acc2)}
.stag-left{display:inline-flex;align-items:center;gap:10px;font-size:.6rem;letter-spacing:.28em;text-transform:uppercase;color:var(--acc);margin-bottom:14px}
.stag-left::before{content:'';width:22px;height:1.5px;background:var(--acc);border-radius:2px}
.stag-left.w{color:var(--acc2)}
.stag-left.w::before{background:var(--acc2)}
.stitle{font-family:'Cormorant Garamond',serif;font-size:clamp(2.2rem,3.6vw,4rem);font-weight:300;line-height:1.1;color:var(--blue);margin-bottom:14px}
.stitle em{font-style:italic;color:var(--acc)}
.stitle.w{color:#fff}
.stitle.w em{color:var(--acc2)}
.slead{font-size:.93rem;line-height:1.9;color:var(--muted);max-width:640px;margin:0 auto 52px}
.slead.left{margin:0 0 52px}
.slead.w{color:rgba(255,255,255,.56)}
/** TRATTAMENTI */ .svc-sec{background:var(--ice)}
.svc-intro{font-family:'Cormorant Garamond',serif;font-size:1.6rem;font-weight:300;color:var(--muted);margin-bottom:0;font-style:italic}
.svc-g{display:grid;grid-template-columns:1fr;gap:20px;text-align:left;margin-top:36px}
.sc{background:var(--white);border-radius:26px;overflow:hidden;border:2px solid var(--acc);transition:transform .42s cubic-bezier(.34,1.56,.64,1),box-shadow .42s cubic-bezier(.34,1.56,.64,1),border-color .42s cubic-bezier(.34,1.56,.64,1);cursor:none;display:flex;flex-direction:column;align-items:center;box-shadow:0 0 0 1px rgba(58,123,224,.12)}
.sc:hover{transform:translateY(-8px);box-shadow:var(--s3);border-color:var(--ice3)}
.sc-top{padding:20px 18px 12px;position:relative;border-bottom:1px solid var(--ice2);width:100%;text-align:center}
.sc-top::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--acc),var(--acc2));transform:scaleX(0);transform-origin:left;transition:transform .4s}
.sc:hover .sc-top::before{transform:scaleX(1)}
.sc-num{font-size:.56rem;letter-spacing:.22em;color:var(--acc);margin-bottom:0;opacity:.6;text-align:center}
.sc-name{font-family:'Cormorant Garamond',serif;font-size:1.22rem;font-weight:400;color:var(--blue);margin:10px 0 11px;line-height:1.2;text-align:center}
.sc-desc{font-size:.81rem;line-height:1.78;color:var(--muted);text-align:center}
.sc-mid{padding:12px 18px;flex:1;width:100%}
.sc-pros{list-style:none;display:flex;flex-direction:column;gap:6px;width:100%}
.sc-pros li{font-size:.74rem;color:var(--muted);display:flex;align-items:flex-start;gap:7px;line-height:1.4;text-align:left}
.sc-pros li::before{content:'—';color:var(--acc);flex-shrink:0;font-size:.8rem}
.altri-wrap{margin-top:40px;background:var(--white);border-radius:24px;padding:32px;text-align:center;border:2px solid var(--acc)}
.altri-title{font-family:'Cormorant Garamond',serif;font-size:1.46rem;color:var(--blue);margin-bottom:20px}
.altri-g{display:flex;flex-wrap:wrap;gap:10px;justify-content:center}
.atag{background:var(--ice);border:1.5px solid var(--ice3);border-radius:var(--R);padding:8px 20px;font-size:.74rem;color:var(--muted);transition:all .3s;cursor:none}
.atag:hover{background:var(--acc);color:#fff;border-color:var(--acc);transform:translateY(-2px)}
/** TEAM (blue) */ .team-sec{background:var(--blue);padding:100px 60px}
.team-sec .stag{color:var(--acc2)}
.team-sec .stag::before,.team-sec .stag::after{background:var(--acc2)}
.car-outer{overflow:hidden;margin-top:46px}
.car-track{display:flex;gap:18px;transition:transform .62s cubic-bezier(.25,.46,.45,.94)}
.tcard{flex:0 0 265px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.13);border-radius:24px;overflow:hidden;cursor:none;transition:all .4s}
.tcard:hover{background:rgba(255,255,255,.14);transform:translateY(-6px);border-color:rgba(255,255,255,.26)}
.tcard-ph{aspect-ratio:4/5;background:linear-gradient(135deg,rgba(255,255,255,.05),rgba(255,255,255,.02));position:relative;display:flex;align-items:flex-end;justify-content:center;overflow:hidden}
.tcard-img{width:100%;height:100%;object-fit:cover;object-position:center top;display:block;position:absolute;top:0;left:0}
.sil-w{position:absolute;bottom:0;display:flex;flex-direction:column;align-items:center}
.sil-h{width:60px;height:60px;background:rgba(255,255,255,.1);border-radius:50%;margin-bottom:3px}
.sil-b{width:106px;height:72px;background:rgba(255,255,255,.07);border-radius:53px 53px 0 0}
.tcard-gr{position:absolute;bottom:0;left:0;right:0;height:50%;background:linear-gradient(to top,rgba(11,31,58,.8),transparent)}
.tcard-i{padding:16px 20px 20px;text-align:left}
.tcard-r{font-size:.56rem;letter-spacing:.17em;text-transform:uppercase;color:var(--acc2);margin-bottom:4px}
.tcard-n{font-family:'Cormorant Garamond',serif;font-size:1.22rem;font-weight:400;color:#fff;margin-bottom:5px;line-height:1.2}
.tcard-s{font-size:.71rem;color:rgba(255,255,255,.42);line-height:1.55}
.car-ctrl{display:flex;align-items:center;gap:12px;justify-content:center;margin-top:28px}
.car-btn{width:44px;height:44px;border-radius:50%;background:rgba(255,255,255,.09);border:1.5px solid rgba(255,255,255,.16);color:#fff;font-size:.95rem;display:flex;align-items:center;justify-content:center;cursor:none;transition:all .3s}
.car-btn:hover{background:rgba(255,255,255,.2);border-color:rgba(255,255,255,.36);transform:scale(1.06)}
.car-dots{display:flex;gap:7px}
.car-dot{width:7px;height:7px;border-radius:4px;background:rgba(255,255,255,.2);cursor:none;transition:all .3s}
.car-dot.active{width:22px;background:rgba(255,255,255,.72)}
/** STORIA (white, left aligned) */ .storia-sec{background:var(--white)}
.storia-txt p{font-size:.92rem;line-height:1.95;color:var(--muted);margin-bottom:16px;max-width:680px}
.storia-txt p strong{color:var(--blue);font-weight:500}
/** EVOLUZIONE (blue2, left aligned) */ .tl-sec{background:var(--blue2);padding:96px 60px 104px}
.tl-inner{max-width:1080px;margin:0 auto;text-align:left}
.tl-wrap{position:relative;max-width:720px;margin:46px 0 0}
.tl-line{position:absolute;left:17px;top:0;bottom:0;width:2px;background:linear-gradient(to bottom,var(--acc),rgba(58,123,224,.08));border-radius:2px}
.tl-item{padding:14px 0 14px 52px;position:relative;cursor:none;transition:padding-left .3s}
.tl-item:hover{padding-left:60px}
.tl-item::before{content:'';position:absolute;left:9px;top:20px;width:16px;height:16px;border-radius:50%;border:2px solid var(--acc2);background:var(--blue2);transition:background .3s}
.tl-item:hover::before{background:var(--acc2)}
.tl-yr{font-size:.56rem;letter-spacing:.24em;color:var(--acc2);margin-bottom:3px}
.tl-txt{font-family:'Cormorant Garamond',serif;font-size:1.15rem;color:#fff;line-height:1.3}
.tl-sub{font-size:.74rem;color:rgba(255,255,255,.34);margin-top:2px;line-height:1.5}
.tl-sep{height:1px;background:rgba(255,255,255,.05);margin:0 0 0 52px}
/** FAQ */ .faq-sec{background:var(--ice2)}
.faq-wrap{max-width:700px;margin:44px auto 0;text-align:left}
.fi{background:var(--white);border-radius:16px;margin-bottom:10px;border:1.5px solid var(--acc2);overflow:hidden;cursor:none;transition:all .3s}
.fi.open{border-color:var(--ice3);box-shadow:var(--s1)}
.fi-q{padding:18px 22px;display:flex;justify-content:space-between;align-items:center;gap:12px;font-size:.86rem;font-weight:400;color:var(--blue);cursor:none}
.fi-ic{width:26px;height:26px;border-radius:50%;background:var(--ice);color:var(--acc);display:flex;align-items:center;justify-content:center;font-size:.93rem;flex-shrink:0;transition:transform .3s,background .3s}
.fi.open .fi-ic{transform:rotate(45deg);background:var(--blue);color:#fff}
.fi-a{max-height:0;overflow:hidden;transition:max-height .42s ease,padding .3s;padding:0 22px;font-size:.83rem;line-height:1.82;color:var(--muted)}
.fi.open .fi-a{max-height:600px;padding:0 22px 18px}
/** MAP */ .map-wrap{position:relative;width:100%;height:260px;border-radius:20px;overflow:hidden;margin-top:28px;border:1.5px solid rgba(255,255,255,.12)}
.map-wrap iframe{position:absolute;inset:0;width:100%;height:100%;border:none;display:block}
.map-tap-overlay{position:absolute;inset:0;z-index:2;display:block}
/** CTA FINAL */ .cta-sec{background:linear-gradient(148deg,var(--blue) 0%,var(--blue2) 50%,var(--blue3) 100%);position:relative;overflow:hidden}
.cta-o1{position:absolute;width:480px;height:480px;background:rgba(91,158,245,.1);border-radius:50%;right:-90px;top:-90px;filter:blur(68px)}
.cta-o2{position:absolute;width:280px;height:280px;background:rgba(58,123,224,.08);border-radius:50%;left:-70px;bottom:-70px;filter:blur(58px)}
.cta-inner{max-width:1080px;margin:0 auto;position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;text-align:center;gap:36px}
.ci-item{display:flex;align-items:flex-start;gap:16px;padding:16px 0;border-bottom:1px solid rgba(255,255,255,.07);font-size:.8rem;color:rgba(255,255,255,.52)}
.ci-item:last-child{border:none}
.ci-ico{width:38px;height:38px;background:rgba(255,255,255,.08);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:.95rem;flex-shrink:0;margin-top:2px}
.cta-contacts-row{display:flex;gap:0;flex-wrap:wrap;justify-content:center;margin-top:8px;flex-direction:column;max-width:520px;text-align:left;margin:16px auto 0}
/** FOOTER */ footer{background:var(--blue);padding:64px 60px 32px}
.ft-layout{display:flex;grid-template-columns:1fr;gap:32px;max-width:1080px;margin:0 auto 40px;align-items:center;flex-direction:column}
.ft-logo-col{display:none;flex-direction:column;align-items:center;gap:0}
.ft-logo-img{width:72px;height:72px;object-fit:contain;border-radius:50%;background:rgba(255,255,255,.1);padding:3px;display:none}
.ft-center-col{display:flex;flex-direction:column;align-items:center;text-align:center;width:100%}
.ft-brand{font-family:'Copperplate Gothic Light','Copperplate',fantasy;font-size:clamp(1.2rem,5vw,1.8rem);letter-spacing:.07em;text-transform:uppercase;color:#fff;line-height:1.05;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ft-brand .BIG{font-size:1.18em}
.ft-brand-sub{font-family:'DM Serif Display',serif;font-size:.72rem;letter-spacing:.28em;text-transform:uppercase;color:rgba(255,255,255,.38);margin-top:6px;margin-bottom:32px}
.ft-links-row{display:grid;grid-template-columns:1fr 1fr;gap:40px;width:100%;text-align:left}
.ft-col h4{font-family:'Copperplate Gothic Light','Copperplate',fantasy;font-size:.56rem;letter-spacing:.24em;text-transform:uppercase;color:var(--acc2);margin-bottom:16px}
.ft-links{list-style:none;display:flex;flex-direction:column;gap:9px}
.ft-links a{font-size:.78rem;color:rgba(255,255,255,.36);text-decoration:none;transition:color .3s;cursor:none}
.ft-links a:hover{color:#fff}
.ft-ci{font-size:.78rem;color:rgba(255,255,255,.36);margin-bottom:9px;line-height:1.65}
.ft-ci strong{font-family:'Copperplate Gothic Light','Copperplate',fantasy;color:rgba(255,255,255,.6);font-size:.54rem;letter-spacing:.13em;text-transform:uppercase;display:block;margin-bottom:2px}
.ft-div{height:1px;background:rgba(255,255,255,.08);max-width:1080px;margin:0 auto 24px}
/** FOOTER BOTTOM */ .ft-btm{text-align:center;max-width:1080px;margin:0 auto}
.ft-btm-brand{font-family:'Copperplate Gothic Light','Copperplate',fantasy;font-size:1.1rem;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.65);white-space:nowrap;margin-bottom:6px}
.ft-btm-sub{font-size:.62rem;letter-spacing:.24em;text-transform:uppercase;color:rgba(255,255,255,.28);margin-bottom:14px}
.ft-btm-legal{font-size:.5rem;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.16)}
/** AI CHAT */ .ai-bub{position:fixed;bottom:28px;right:28px;z-index:400}
.ai-tog{width:60px;height:60px;border-radius:50%;background:linear-gradient(135deg,var(--blue),var(--acc));border:none;cursor:none;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 28px rgba(11,31,58,.28);transition:all .38s cubic-bezier(.34,1.56,.64,1);font-size:1.4rem}
.ai-tog:hover{transform:scale(1.1)}
.ai-tog.open{border-radius:18px}
.ai-pan{position:absolute;bottom:76px;right:0;width:292px;height:464px;background:#fff;border-radius:24px;box-shadow:0 24px 64px rgba(11,31,58,.18);display:none;flex-direction:column;overflow:hidden;border:1px solid var(--ice3)}
.ai-pan.open{display:flex}
.ai-hd{padding:16px 20px;background:linear-gradient(135deg,var(--blue),var(--blue2));display:flex;align-items:center;gap:12px}
.ai-av{width:36px;height:36px;border-radius:12px;background:rgba(255,255,255,.12);display:flex;align-items:center;justify-content:center;font-size:1.1rem}
.ai-hn{font-size:.84rem;font-weight:500;color:#fff}
.ai-hs{font-size:.6rem;color:rgba(255,255,255,.43);display:flex;align-items:center;gap:5px}
.ai-dot{width:5px;height:5px;background:#4ade80;border-radius:50%;animation:p2 2s infinite}
@keyframes p2{0%,100%{opacity:1;}50%{opacity:.4;}}
.ai-msgs{flex:1;overflow-y:auto;padding:14px;display:flex;flex-direction:column;gap:11px}
.ai-msgs::-webkit-scrollbar{width:3px}
.ai-msgs::-webkit-scrollbar-thumb{background:var(--ice3);border-radius:3px}
.msg{display:flex;gap:8px;align-items:flex-end}
.msg.u{flex-direction:row-reverse}
.mb{max-width:224px;padding:10px 13px;border-radius:15px;font-size:.78rem;line-height:1.54}
.msg.b .mb{background:var(--ice);color:var(--text);border-bottom-left-radius:3px}
.msg.u .mb{background:var(--blue);color:#fff;border-bottom-right-radius:3px}
.mav{width:24px;height:24px;border-radius:50%;background:var(--ice2);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:.76rem}
.ai-typ{display:flex;gap:4px;align-items:center;padding:10px 13px;background:var(--ice);border-radius:15px;border-bottom-left-radius:3px;width:fit-content}
.ai-typ span{width:6px;height:6px;background:var(--acc);border-radius:50%;animation:tp 1.2s ease-in-out infinite}
.ai-typ span:nth-child(2){animation-delay:.2s}
.ai-typ span:nth-child(3){animation-delay:.4s}
@keyframes tp{0%,60%,100%{transform:translateY(0)}30%{transform:translateY(-5px)}}
.ai-qb{padding:0 14px 9px;display:flex;gap:6px;flex-wrap:wrap}
.ai-qbtn{font-size:.66rem;padding:6px 12px;border-radius:var(--R);border:1.5px solid var(--ice3);background:#fff;color:var(--muted);cursor:none;transition:all .25s;white-space:nowrap}
.ai-qbtn:hover{border-color:var(--acc);color:var(--acc);background:rgba(58,123,224,.05)}
.ai-ir{padding:11px 14px;border-top:1px solid var(--ice2);display:flex;gap:8px;align-items:center}
.ai-in{flex:1;background:var(--ice);border:1.5px solid transparent;border-radius:var(--R);padding:9px 13px;font-family:'DM Sans',sans-serif;font-size:.78rem;outline:none;color:var(--text);transition:border-color .3s;cursor:none}
.ai-in:focus{border-color:var(--acc)}
.ai-snd{width:34px;height:34px;border-radius:50%;background:var(--blue);color:#fff;border:none;cursor:none;display:flex;align-items:center;justify-content:center;font-size:.84rem;transition:all .3s}
.ai-snd:hover{background:var(--acc);transform:scale(1.08)}
/** MODAL */ .mo-ov{position:fixed;inset:0;background:rgba(11,31,58,.55);z-index:500;display:none;align-items:center;justify-content:center;padding:20px}
.mo-ov.open{display:flex}
.mo{background:#fff;border-radius:28px;width:100%;max-width:660px;max-height:94vh;overflow-y:auto;box-shadow:0 32px 80px rgba(11,31,58,.2)}
.mo-hd{padding:30px 34px 18px;border-bottom:1px solid var(--ice2);display:flex;justify-content:space-between;align-items:flex-start}
.mo-t{font-family:'Cormorant Garamond',serif;font-size:1.85rem;color:var(--blue)}
.mo-sub{font-size:.76rem;color:var(--muted);margin-top:3px}
.mo-cl{width:36px;height:36px;min-width:44px;min-height:44px;padding:4px;border-radius:50%;background:var(--ice);border:none;cursor:none;font-size:1rem;color:var(--muted);display:flex;align-items:center;justify-content:center;transition:all .3s;flex-shrink:0}
.mo-cl:hover{background:var(--blue);color:#fff}
.mo-bd{padding:22px 34px 34px}
.ms{display:none}
.ms.active{display:block}
.stp-l{font-size:.56rem;letter-spacing:.22em;text-transform:uppercase;color:var(--acc);margin-bottom:16px}
.progress-bar{display:flex;gap:8px;margin-bottom:22px}
.pb-step{flex:1;height:3px;border-radius:3px;background:var(--ice3);transition:background .4s}
.pb-step.done{background:var(--acc)}
.pb-step.active{background:var(--acc2)}
.cal{border:1.5px solid var(--ice3);border-radius:16px;overflow:hidden;margin-bottom:18px}
.cal-hd{background:var(--blue);padding:13px 20px;display:flex;justify-content:space-between;align-items:center}
.cal-m{font-family:'Cormorant Garamond',serif;font-size:1.1rem;color:#fff}
.cal-n{background:transparent;border:1px solid rgba(255,255,255,.2);border-radius:50%;width:30px;height:30px;min-width:44px;min-height:44px;padding:7px;color:#fff;cursor:none;font-size:.86rem;display:flex;align-items:center;justify-content:center;transition:background .3s}
.cal-n:hover{background:rgba(255,255,255,.14)}
.cal-dlhd{display:grid;grid-template-columns:repeat(7,1fr);background:var(--ice);padding:8px 0}
.cal-dl{text-align:center;font-size:.54rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.cal-g{display:grid;grid-template-columns:repeat(7,1fr);gap:3px;padding:9px}
.cal-d{aspect-ratio:1;display:flex;align-items:center;justify-content:center;border-radius:50%;font-size:.78rem;color:var(--muted);cursor:none;transition:all .2s}
.cal-d:not(.emp):not(.past):not(.closed):hover{background:var(--ice2);color:var(--blue)}
.cal-d.sel{background:var(--blue);color:#fff}
.cal-d.today{border:1.5px solid var(--acc);color:var(--acc)}
.cal-d.past,.cal-d.closed{opacity:.22;pointer-events:none}
.cal-d.emp{pointer-events:none}
.cal-d.closed{font-style:italic}
.tsl-g{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:18px}
.tsl{padding:11px 0;text-align:center;border:1.5px solid var(--ice3);border-radius:var(--R);font-size:.76rem;color:var(--muted);cursor:none;transition:all .25s}
.tsl:hover{border-color:var(--acc);color:var(--acc);background:rgba(58,123,224,.05)}
.tsl.sel{background:var(--blue);color:#fff;border-color:var(--blue)}
.tsl.taken{opacity:.26;pointer-events:none;text-decoration:line-through}
.mfg{margin-bottom:12px}
.mfl{display:block;font-size:.56rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:5px}
.mfi{width:100%;background:var(--ice);border:1.5px solid var(--ice3);border-radius:12px;padding:12px 16px;color:var(--text);font-family:'DM Sans',sans-serif;font-size:1rem;outline:none;transition:border-color .3s,background .3s;cursor:none}
.mfi:focus{border-color:var(--acc);background:#fff}
.mfi::placeholder{color:rgba(78,98,128,.38)}
.mfrow{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.cfm-box{background:var(--ice);border-radius:16px;padding:22px;margin-bottom:18px;border:1.5px solid var(--ice3)}
.cfm-i{display:flex;justify-content:space-between;padding:9px 0;border-bottom:1px solid var(--ice3);font-size:.81rem}
.cfm-i:last-child{border:none}
.cfm-i span:first-child{color:var(--muted)}
.cfm-i span:last-child{color:var(--blue);font-weight:500}
.mo-ft{padding:0 34px 34px;display:flex;justify-content:space-between;align-items:center}
.mo-bk{background:none;border:none;color:var(--muted);font-size:.74rem;cursor:none;display:flex;align-items:center;gap:5px;transition:color .3s}
.mo-bk:hover{color:var(--blue)}
.closed-note{font-size:.7rem;color:var(--muted);text-align:center;padding:8px;background:var(--ice2);border-radius:8px;margin-bottom:14px}
/** ANIMATIONS */ @keyframes fadeIn{from{opacity:0}
to{opacity:1}
} .rev{opacity:1}
.d1{transition-delay:.1s}
.d2{transition-delay:.2s}
.d3{transition-delay:.3s}
.d4{transition-delay:.4s}
/** RESPONSIVE */ @media(min-width:641px){.nav-links{display:flex}.nav-menu-btn{display:none!important}}
@media(max-width:1024px){nav{padding:18px 36px}
section{padding:80px 36px}
.team-sec,.tl-sec{padding:56px 20px}
footer{padding:48px 20px 24px}
} @media(max-width:640px){/* ── NAV ── */
  nav{padding:14px 20px}
.nav-menu-btn{display:flex!important}
/** ── SECTIONS ── */ section{padding:56px 20px}
/** ── HERO ── */ .hero{padding:96px 20px 40px}
.ob1,.ob2,.ob3{display:none}
/** ── TRATTAMENTI ── */ .svc-sec .stitle{display:none}.svc-sec{padding-top:32px!important}
/** ── CTA FINALE ── */ .cta-contacts-row{flex-direction:column;gap:0}
.map-wrap{height:220px}
/** ── FOOTER ── */ .ft-links-row{grid-template-columns:1fr}
* ── MODAL / AI ── */ .mfrow{grid-template-columns:1fr}
/** ── HERO BUTTONS ── */ .hactions{flex-direction:column;align-items:stretch;gap:10px}
.hactions .btn{width:100%;min-height:48px;padding:14px 20px;justify-content:center;text-align:center}
/** ── STATS ── */ .hstats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;justify-items:center}
} /* touch devices: hide cursor overlay, restore pointer */ @media(hover:none),(pointer:coarse){body{cursor:auto}
.cur,.cur-r{display:none!important}
*[style*="cursor:none"],*{cursor:auto}
a,button,.btn,.sc,.fi,.fi-q,.atag,.tsl,.cal-d,.car-btn,.car-dot,.ai-tog,.ai-qbtn,.sc-book-btn,.mob-nav-item,.nav-menu-btn,.mo-cl,.mo-bk,.tcard,.tl-item{cursor:pointer!important}
} /* respect reduced-motion preference */ @media(prefers-reduced-motion:reduce){*,*::before,*::after{animation:none!important;transition:none!important}
} .subhero{background:linear-gradient(148deg,var(--blue) 0%,var(--blue2) 48%,var(--blue3) 100%);padding:140px 60px 90px;text-align:center;position:relative;overflow:hidden}
.subhero-inner{position:relative;z-index:1;max-width:700px;margin:0 auto}
.subhero h1{font-family:'Cormorant Garamond',serif;font-size:clamp(2.8rem,5vw,5.4rem);font-weight:300;color:#fff;line-height:1.06;margin-bottom:16px}
.subhero h1 em{font-style:italic;color:var(--acc2)}
.subhero p{font-size:.95rem;color:rgba(255,255,255,.56);max-width:540px;margin:0 auto 36px;line-height:1.9}
.dtv-sec{background:var(--white)}
.dtv-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start;max-width:1080px;margin:0 auto}
.dtv-info{display:flex;flex-direction:column;gap:0}
.dtv-block{padding:24px 0;border-bottom:1px solid var(--ice3)}
.dtv-block:last-child{border:none}
.dtv-label{font-size:.56rem;letter-spacing:.24em;text-transform:uppercase;color:var(--acc);margin-bottom:8px}
.dtv-value{font-size:.95rem;color:var(--blue);line-height:1.7}
.dtv-value a{color:var(--blue);text-decoration:none}
.dtv-value a:hover{color:var(--acc)}
.dtv-map{position:relative;border-radius:24px;overflow:hidden;height:520px;width:100%;border:1.5px solid var(--ice3);box-shadow:var(--s2)}
.dtv-map iframe{position:absolute;inset:0;width:100%;height:100%;border:none;display:block}
.dtv-metro{display:inline-flex;align-items:center;gap:8px;background:var(--ice2);border-radius:var(--R);padding:6px 14px;font-size:.76rem;color:var(--muted);margin-top:8px}
.dtv-metro-dot{width:10px;height:10px;background:#009fe3;border-radius:50%;flex-shrink:0}
@media(max-width:900px){
  .dtv-grid{grid-template-columns:1fr;gap:40px;}
  .dtv-map{height:340px;}
}
@media(max-width:640px){
  .subhero{padding:100px 20px 60px;}
  .dtv-sec{padding:56px 20px!important;}
  .dtv-map{height:300px;border-radius:16px;}
}
.nav-brand-wrap{position:absolute;left:50%;transform:translateX(-50%);pointer-events:none;text-align:center;display:flex;flex-direction:column;align-items:center;gap:2px}
.nav-brand-sub-t{font-family:'DM Serif Display',serif;font-size:.56rem;letter-spacing:.28em;text-transform:uppercase;color:rgba(255,255,255,.38);white-space:nowrap;display:block;line-height:1.2;transition:color .4s}
nav.s .nav-brand-sub-t{color:var(--muted)}
.ci-label{font-size:.58rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.3);margin-bottom:3px}
.ci-val{font-size:1.08rem;color:rgba(255,255,255,.68);line-height:1.65;overflow-wrap:break-word;word-break:break-word}
.ci-val a{color:inherit;text-decoration:none}
@media(max-width:640px){.subhero{padding:72px 20px 36px;}.subhero h1{font-size:clamp(2.4rem,10vw,3.2rem);margin-bottom:10px}.subhero p{margin-bottom:20px;font-size:.86rem}.subhero .btn-w{margin-bottom:0}}
/** ── ACCESSIBILITY: Focus outlines ── */ :focus-visible{outline:2px solid var(--acc);outline-offset:3px;border-radius:3px}
button:focus-visible,a:focus-visible{outline:2px solid var(--acc);outline-offset:3px}
input:focus-visible,select:focus-visible,textarea:focus-visible{outline:2px solid var(--acc);outline-offset:0}
/** Ensure cursor:none does not hide focus ring */ *:focus{outline-color:var(--acc)}
textarea.mfi,select.mfi{font-size:1rem}
/** ── Skip-to-content link (keyboard only) ── */ .skip-link{position:absolute;top:-100px;left:16px;z-index:9999;background:var(--blue);color:#fff;padding:10px 18px;border-radius:8px;font-size:.82rem;letter-spacing:.04em;text-decoration:none;transition:top .2s}
.skip-link:focus{top:16px}
/* ── Utility classes for recurring inline styles ── */
.link-blue{color:var(--blue);font-weight:500;text-decoration:none;}
.link-inherit{color:inherit;text-decoration:none;}
.text-center-full{text-align:center;width:100%;}
.mo-done-icon{font-size:3.4rem;margin-bottom:16px;font-family:'Cormorant Garamond',serif;color:var(--acc);}
.mo-done-title{font-family:'Cormorant Garamond',serif;font-size:1.85rem;color:var(--blue);margin-bottom:10px;}
/** ── MOBILE UX POLISH ── */
@media(max-width:640px){
  /* Hero: no forced fullscreen — content-height only, top-anchored */
  .hero{min-height:0;justify-content:flex-start;padding-top:82px;padding-bottom:36px}
  /* Hide scroll indicator (no value on touch, saves ~80px) */
  .scrl{display:none}
  /* Compact stats so they don't crowd the CTA area */
  .hstats{margin-top:18px;gap:6px}
  .hstat{padding:9px 7px}
  .hstat-n{font-size:1.48rem}
  .hstat-l{font-size:.5rem;margin-top:2px}
  /* More generous breathing room between sections */
  section{padding-top:68px;padding-bottom:68px}
  .faq-sec{padding-top:68px;padding-bottom:68px}
}
.mo-done-text{font-size:.84rem;color:var(--muted);line-height:1.78;max-width:340px;margin:0 auto 24px;}
/** ── HERO SYMMETRY & SPACING FIX ── */

/* ── DESKTOP: 4-column stats row, extra headroom above title, SCORRI pinned to bottom ── */
@media(min-width:641px){
  .hero{padding-top:200px;padding-bottom:110px}
  .htitle{margin-bottom:20px}
  .hsub{margin-bottom:36px;font-size:.9rem;line-height:1.8}
  .hactions{gap:20px}
  /* 4-column horizontal row instead of 4 stacked full-width cards */
  .hstats{flex-wrap:nowrap;gap:20px;margin-top:56px;width:100%;max-width:860px}
  .hstat{width:auto;flex:1;min-width:0;padding:14px 10px}
  /* SCORRI anchored at the true bottom of the hero */
  .scrl{display:flex;position:absolute;bottom:40px;left:50%;transform:translateX(-50%);margin-top:0}
}

/* ── SPLIT CTA: prenota + chiamaci side by side ── */
.hero-split-cta{display:flex;flex-direction:row;flex-wrap:nowrap;gap:12px;justify-content:center;width:100%}
.hero-split-cta .btn{flex:1!important;width:auto!important;max-width:none!important;min-width:0;gap:7px}
/* SVG in split buttons */
.hbtn-svg{flex-shrink:0;display:block}
/* ── LIST BUTTONS (address + scopri) ── */
.hero-icon-btn{justify-content:flex-start!important;text-align:left;gap:14px;padding:14px 18px}
.hbtn-ic{width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.hbtn-txt{flex:1;text-align:left;line-height:1.4;white-space:normal}
.hbtn-arr{flex-shrink:0;opacity:.5;display:flex;align-items:center}

/* ── MOBILE hero layout ── */
@media(max-width:640px){
  /* justify-content:flex-end → title+text+buttons group anchors to bottom,
     leaving the upper portion free for the logo space */
  .hero{min-height:100svh;justify-content:flex-end;padding-top:100px;padding-bottom:48px}
  .hlogo-wrap{display:none}
  /* Title: even bigger */
  .htitle{font-size:clamp(3rem,11vw,3.8rem);margin-bottom:12px}
  .hsub{font-size:.85rem;line-height:1.8;margin-bottom:16px}
  /* Push block closer to bottom edge */
  .hero{padding-bottom:32px}
  /* Buttons: compact gap */
  .hactions{margin-top:20px;align-items:center;gap:14px}
  /* Split CTA (prenota/chiamaci) */
  .hactions > .btn{width:100%;max-width:340px;padding:15px 18px;font-size:.72rem;min-height:52px}
  .hero-split-cta{max-width:340px;width:100%}
  .hero-split-cta .btn{padding:15px 8px!important;font-size:.7rem!important;min-height:52px!important}
  /* List buttons — same height as split CTA: single-line text, compact icon */
  .hero-icon-btn{padding:11px 16px!important;min-height:52px!important;max-height:52px;overflow:hidden}
  .hbtn-ic{width:30px!important;height:30px!important}
  .hbtn-txt{font-size:.66rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  /* Stats hidden in hero */
  .hstats{display:none!important}
  .scrl{display:none}
}
