/* ═══════════════════════════════════════════════════════
   GP GOMME TRIESTE — PRO2 DESIGN SYSTEM
   Dark Automotive + Gold Accents
   ═══════════════════════════════════════════════════════ */

/* ─── RESET & VARIABLES ─── */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --gold:#E8B930;
  --gold-50:rgba(232,185,48,.05);--gold-10:rgba(232,185,48,.10);
  --gold-20:rgba(232,185,48,.20);--gold-glow:rgba(232,185,48,.35);
  --dark-1:#060809;--dark-2:#0C0F11;--dark-3:#121618;
  --dark-4:#1A1F22;--dark-5:#222930;
  --white:#F4F4F2;--gray-1:#C8CDD0;--gray-2:#8B949A;--gray-3:#5C666D;
  --ff:'Outfit',sans-serif;--fs:'Poppins',sans-serif;
  --ease:cubic-bezier(.4,0,.2,1);--ease-spring:cubic-bezier(.34,1.56,.64,1);
  --ease-out:cubic-bezier(0,.55,.45,1);
}
html{scroll-behavior:smooth;font-size:16px;overflow-x:hidden}
body{font-family:var(--ff);background:var(--dark-1)!important;color:var(--white)!important;overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;position:relative}
body.no-scroll{overflow:hidden}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
ul{list-style:none}
.wrap{max-width:1180px;margin:0 auto;padding:0 28px}

/* GHL override */
.hl_page-creator--content,.hl_page-creator--content *,[class*="row--"],[class*="col--"],[class*="inner-"]{background-color:transparent!important}

/* ─── PRELOADER ─── */
.preloader{position:fixed;inset:0;z-index:9999;background:var(--dark-1);display:flex;flex-direction:column;align-items:center;justify-content:center;transition:opacity .6s var(--ease),visibility .6s}
.preloader.done{opacity:0;visibility:hidden;pointer-events:none}
.preloader-logo{width:120px;animation:preloader-pulse 1.2s ease-in-out infinite alternate}
.preloader-bar{width:140px;height:3px;background:var(--dark-4);border-radius:3px;margin-top:28px;overflow:hidden}
.preloader-fill{height:100%;background:var(--gold);border-radius:3px;width:0;animation:preloader-load 1.6s var(--ease) forwards}
@keyframes preloader-pulse{0%{opacity:.5;transform:scale(.95)}100%{opacity:1;transform:scale(1)}}
@keyframes preloader-load{0%{width:0}100%{width:100%}}

/* ─── KEYFRAMES ─── */
@keyframes ticker{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
@keyframes glow-pulse{0%,100%{box-shadow:0 0 0 0 var(--gold-glow)}50%{box-shadow:0 0 0 14px transparent}}
@keyframes fade-slide{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}
@keyframes hero-ken{0%{transform:scale(1.04)}100%{transform:scale(1)}}
@keyframes float{0%,100%{transform:translateY(0) rotate(0deg)}33%{transform:translateY(-8px) rotate(1deg)}66%{transform:translateY(4px) rotate(-1deg)}}
@keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}
@keyframes reveal-up{from{clip-path:inset(100% 0 0 0)}to{clip-path:inset(0 0 0 0)}}
@keyframes reveal-left{from{clip-path:inset(0 100% 0 0)}to{clip-path:inset(0 0 0 0)}}
@keyframes spin-slow{from{transform:rotate(0)}to{transform:rotate(360deg)}}
@keyframes dash{0%{stroke-dashoffset:300}100%{stroke-dashoffset:0}}
@keyframes sparkle{0%,100%{opacity:.3}50%{opacity:1}}
@keyframes confetti-fall{0%{transform:translateY(-10px) rotate(0);opacity:1}100%{transform:translateY(60px) rotate(360deg);opacity:0}}
@keyframes slide-in-left{from{opacity:0;transform:translateX(-80px)}to{opacity:1;transform:translateX(0)}}
@keyframes slide-in-right{from{opacity:0;transform:translateX(80px)}to{opacity:1;transform:translateX(0)}}
@keyframes scale-in{from{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}
@keyframes border-glow{0%,100%{border-color:var(--gold-20)}50%{border-color:var(--gold)}}
@keyframes text-glow{0%,100%{text-shadow:0 0 20px var(--gold-glow)}50%{text-shadow:0 0 50px var(--gold-glow)}}

/* ─── SCROLL ANIMATIONS ─── */
[data-anim]{opacity:0;transform:translateY(50px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
[data-anim="left"]{transform:translateX(-80px)}
[data-anim="right"]{transform:translateX(80px)}
[data-anim="scale"]{transform:scale(.85)}
[data-anim="up"]{transform:translateY(50px)}
[data-anim="fade"]{transform:none}
[data-anim="rotate"]{transform:rotate(-5deg) scale(.9)}
[data-anim].in-view{opacity:1;transform:translate(0) scale(1) rotate(0)}
[data-anim-delay="1"]{transition-delay:.12s}
[data-anim-delay="2"]{transition-delay:.24s}
[data-anim-delay="3"]{transition-delay:.36s}
[data-anim-delay="4"]{transition-delay:.48s}
[data-anim-delay="5"]{transition-delay:.60s}
[data-anim-delay="6"]{transition-delay:.72s}

/* Text reveal word-by-word */
.split-word{display:inline-block;overflow:hidden;vertical-align:top}
.split-word .word{display:inline-block;transform:translateY(110%);transition:transform .7s var(--ease-spring);transition-delay:var(--d,0s)}
.split-word.in-view .word{transform:translateY(0)}

/* ─── BUTTONS ─── */
.btn{display:inline-flex;align-items:center;gap:10px;padding:15px 34px;border-radius:8px;font-family:var(--ff);font-size:14px;font-weight:600;letter-spacing:.02em;cursor:pointer;border:none;transition:all .35s var(--ease);position:relative;overflow:hidden}
.btn::before{content:'';position:absolute;inset:0;background:linear-gradient(120deg,transparent,rgba(255,255,255,.12),transparent);transform:translateX(-100%);transition:transform .5s}
.btn:hover::before{transform:translateX(100%)}
.btn-gold{background:var(--gold);color:#000!important;font-weight:700}
.btn-gold:hover{background:#f0c94a;box-shadow:0 10px 36px var(--gold-glow);transform:translateY(-2px)}
.btn-ghost{background:rgba(255,255,255,.08);color:var(--white);border:1.5px solid rgba(255,255,255,.25);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold)}
.btn-white{background:var(--white);color:var(--dark-1)}
.btn-white:hover{background:#e8e8e6;transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.3)}
.btn svg{transition:transform .3s}
.btn:hover svg{transform:translateX(4px)}

/* Magnetic button wrapper */
.magnetic{display:inline-block;transition:transform .3s var(--ease-out)}

/* ─── SECTION UTILITIES ─── */
.sec-eyebrow{display:inline-flex;align-items:center;gap:12px;font-size:11px;font-weight:700;color:var(--gold);letter-spacing:.16em;text-transform:uppercase;margin-bottom:18px}
.sec-eyebrow::before,.sec-eyebrow::after{content:'';width:24px;height:1px;background:var(--gold);opacity:.4}
.sec-heading{font-family:var(--fs);font-size:clamp(32px,4.5vw,52px);line-height:1.12;margin-bottom:22px}
.sec-heading em{color:var(--gold);font-style:italic}
.sec-sub{font-size:17px;line-height:1.8;color:var(--gray-2);max-width:600px;margin-bottom:8px}
.text-center{text-align:center}
.text-center .sec-eyebrow,.sec-eyebrow.text-center{display:flex;justify-content:center;width:100%}
.text-center .sec-heading,.sec-heading.text-center{text-align:center;width:100%}
.text-center .sec-sub,.sec-sub.text-center{margin-left:auto;margin-right:auto;text-align:center}
.mx-auto{margin-left:auto;margin-right:auto}

/* Gold line divider */
.gold-line{height:1px;background:linear-gradient(90deg,transparent,var(--gold-20),transparent);margin:0}

/* ═══════════════════════════════════════════════════════
   NAVBAR
   ═══════════════════════════════════════════════════════ */
.topbar{position:fixed;top:0;left:0;right:0;z-index:100;transition:all .45s var(--ease)}
.topbar::before{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(6,8,9,.9) 0%,transparent 100%);pointer-events:none;transition:opacity .45s}
.topbar.pinned::before{opacity:0}
.topbar.pinned{background:rgba(6,8,9,.95);border-bottom:1px solid rgba(232,185,48,.06)}
.topbar-inner{display:flex;align-items:center;justify-content:space-between;max-width:1180px;margin:0 auto;padding:18px 28px;position:relative;z-index:2;transition:padding .4s}
.topbar.pinned .topbar-inner{padding-top:12px;padding-bottom:12px}
.brand img{height:64px;width:auto;transition:height .3s}
.topbar.pinned .brand img{height:50px;width:auto}
.nav-menu{display:flex;align-items:center;gap:6px}
.nav-menu a{position:relative;padding:8px 16px;font-size:13.5px;font-weight:500;color:var(--gray-2);letter-spacing:.02em;transition:color .3s}
.nav-menu a::after{content:'';position:absolute;bottom:2px;left:16px;right:16px;height:1.5px;background:var(--gold);transform:scaleX(0);transform-origin:right;transition:transform .35s var(--ease)}
.nav-menu a:hover{color:var(--white)}
.nav-menu a:hover::after{transform:scaleX(1);transform-origin:left}
.nav-menu a.active{color:var(--gold)}
.nav-menu a.active::after{transform:scaleX(1)}
.nav-cta-btn{display:inline-flex;align-items:center;gap:8px;margin-left:12px;padding:10px 26px;background:var(--gold)!important;color:#000!important;font-size:13px;font-weight:800;border-radius:8px;letter-spacing:.04em;text-transform:uppercase;transition:all .3s var(--ease);border:none;cursor:pointer}
.nav-cta-btn:hover{background:#f0c94a;transform:translateY(-1px);box-shadow:0 8px 28px var(--gold-glow)}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;padding:6px;cursor:pointer;z-index:201}
.burger span{display:block;width:22px;height:2px;background:var(--white);border-radius:2px;transition:all .3s}
.burger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* ═══════════════════════════════════════════════════════
   HERO
   ═══════════════════════════════════════════════════════ */
.hero{position:relative;min-height:100vh;min-height:100dvh;display:flex;align-items:flex-end;padding-top:120px;padding-bottom:180px;overflow:hidden}
.hero-bg-wrap{position:absolute;inset:0}
.hero-img{position:absolute;inset:0;opacity:0;transition:opacity 1.4s var(--ease);background-size:cover;background-position:center center;animation:hero-ken 10s var(--ease) forwards}
.hero-img.live{opacity:1}
.hero-img img{width:100%;height:100%;object-fit:cover;object-position:center center;animation:hero-ken 10s var(--ease) forwards}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(6,8,9,.55) 0%,rgba(6,8,9,.25) 35%,rgba(6,8,9,.7) 70%,var(--dark-1) 100%),linear-gradient(90deg,rgba(6,8,9,.8) 0%,transparent 55%);pointer-events:none}
.hero-grain{position:absolute;inset:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.04'/%3E%3C/svg%3E");pointer-events:none;opacity:.5}
.hero-body{position:relative;z-index:3;width:100%}
.hero-tag{display:inline-flex;align-items:center;gap:10px;padding:7px 18px;border-radius:6px;background:var(--gold-10);border:1px solid var(--gold-20);font-size:11.5px;font-weight:700;color:var(--gold);letter-spacing:.12em;text-transform:uppercase;margin-bottom:24px;animation:fade-slide .8s var(--ease) .2s both}
.hero-tag .dot{width:5px;height:5px;border-radius:50%;background:var(--gold);animation:glow-pulse 2s infinite}
.hero-h1{font-family:var(--fs);font-size:clamp(36px,5vw,64px);font-weight:700;line-height:1.1;margin-bottom:18px;max-width:620px;animation:fade-slide .8s var(--ease) .35s both}
.hero-h1 em{color:var(--gold);text-shadow:0 0 60px var(--gold-glow)}
.hero-p{font-size:16.5px;line-height:1.7;color:var(--gray-1);max-width:480px;margin-bottom:36px;animation:fade-slide .8s var(--ease) .5s both}
.hero-btns{display:flex;gap:14px;flex-wrap:wrap;animation:fade-slide .8s var(--ease) .65s both}

/* Hero strip KPIs */
.hero-strip{position:absolute;bottom:0;left:0;right:0;z-index:5;background:var(--dark-2);border-top:1px solid rgba(255,255,255,.04)}
.hero-strip-inner{display:grid;grid-template-columns:repeat(4,1fr);max-width:1180px;margin:0 auto}
.hero-kpi{padding:28px;text-align:center;border-right:1px solid rgba(255,255,255,.04);transition:background .3s}
.hero-kpi:last-child{border-right:none}
.hero-kpi:hover{background:rgba(232,185,48,.03)}
.hero-kpi-val{font-family:var(--fs);font-size:34px;color:var(--gold);line-height:1}
.hero-kpi-lab{font-size:11.5px;color:var(--gray-3);text-transform:uppercase;letter-spacing:.1em;margin-top:6px;font-weight:600}

/* Hero progress dots */
.hero-progress{position:absolute;bottom:200px;right:40px;z-index:5;display:flex;flex-direction:column;gap:8px}
.hero-progress-dot{width:3px;height:24px;border-radius:3px;background:rgba(255,255,255,.15);border:none;cursor:pointer;transition:all .4s}
.hero-progress-dot.on{background:var(--gold);height:40px;box-shadow:0 0 12px var(--gold-glow)}

/* ═══════════════════════════════════════════════════════
   MARQUEE
   ═══════════════════════════════════════════════════════ */
.marquee{background:var(--gold);padding:12px 0;overflow:hidden;position:relative;z-index:6}
.marquee-track{display:flex;gap:0;white-space:nowrap;animation:ticker 30s linear infinite;width:max-content}
.marquee-item{display:inline-flex;align-items:center;gap:16px;padding:0 32px;font-size:13px;font-weight:700;color:var(--dark-1);text-transform:uppercase;letter-spacing:.08em}
.marquee-item .sep{width:5px;height:5px;border-radius:50%;background:var(--dark-1);opacity:.3}

/* ═══════════════════════════════════════════════════════
   CELEBRATION BANNER
   ═══════════════════════════════════════════════════════ */
.celebration{padding:80px 0;background:var(--dark-1)!important;position:relative;overflow:hidden}
.celebration::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at center,var(--gold-50) 0%,transparent 65%);pointer-events:none}
.celeb-card{position:relative;z-index:2;background:linear-gradient(135deg,var(--dark-3) 0%,var(--dark-4) 100%);border:1px solid var(--gold-20);border-radius:20px;padding:56px 48px;text-align:center;overflow:hidden}
.celeb-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent,var(--gold),transparent)}
.celeb-sparkles{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.celeb-sparkle{position:absolute;width:4px;height:4px;background:var(--gold);border-radius:50%;animation:sparkle 2s ease-in-out infinite}
.celeb-sparkle:nth-child(1){top:15%;left:8%;animation-delay:0s}
.celeb-sparkle:nth-child(2){top:25%;right:12%;animation-delay:.4s}
.celeb-sparkle:nth-child(3){bottom:20%;left:15%;animation-delay:.8s}
.celeb-sparkle:nth-child(4){top:10%;right:30%;animation-delay:1.2s}
.celeb-sparkle:nth-child(5){bottom:30%;right:8%;animation-delay:.6s}
.celeb-sparkle:nth-child(6){top:40%;left:5%;animation-delay:1s}
.celeb-emoji{font-size:48px;margin-bottom:16px}
.celeb-eyebrow{display:inline-flex;align-items:center;gap:10px;font-size:12px;font-weight:800;color:var(--gold);letter-spacing:.18em;text-transform:uppercase;margin-bottom:16px}
.celeb-h2{font-family:var(--fs);font-size:clamp(32px,5vw,52px);line-height:1.1;margin-bottom:14px}
.celeb-h2 em{color:var(--gold);font-style:italic}
.celeb-sub{font-size:18px;color:var(--gray-1);margin-bottom:8px;font-weight:500}
.celeb-date{display:inline-flex;align-items:center;gap:10px;margin-top:20px;padding:14px 32px;background:var(--gold-10);border:1px solid var(--gold-20);border-radius:12px;font-size:16px;font-weight:700;color:var(--gold)}
.celeb-date svg{flex-shrink:0}
.celeb-p{font-size:15px;color:var(--gray-2);margin-top:20px;line-height:1.7;max-width:520px;margin-left:auto;margin-right:auto}

/* ═══════════════════════════════════════════════════════
   DPF BANNER
   ═══════════════════════════════════════════════════════ */
.dpf{padding:100px 0;position:relative;background:var(--dark-2);overflow:hidden}
.dpf::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--gold-20),transparent)}
.dpf-wrap{display:grid;grid-template-columns:1fr 1.1fr;gap:0;border-radius:16px;overflow:hidden;border:1px solid rgba(255,255,255,.05);background:var(--dark-3)}
.dpf-visual{position:relative;min-height:420px;overflow:hidden}
.dpf-visual img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.dpf-wrap:hover .dpf-visual img{transform:scale(1.05)}
.dpf-ribbon{position:absolute;top:0;left:0;background:var(--gold);color:var(--dark-1);padding:10px 28px 10px 20px;font-size:11px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;clip-path:polygon(0 0,100% 0,90% 100%,0 100%)}
.dpf-body{padding:56px 48px;display:flex;flex-direction:column;justify-content:center}
.dpf-eyebrow{font-size:11px;font-weight:700;color:var(--gold);letter-spacing:.14em;text-transform:uppercase;margin-bottom:14px}
.dpf-h2{font-family:var(--fs);font-size:34px;line-height:1.15;margin-bottom:18px}
.dpf-p{font-size:15.5px;line-height:1.75;color:var(--gray-2);margin-bottom:32px}

/* ═══════════════════════════════════════════════════════
   INTRO / BENVENUTI
   ═══════════════════════════════════════════════════════ */
.intro{padding:120px 0 100px;position:relative;text-align:center;background:var(--dark-1);overflow:hidden}
.intro::after{content:'';position:absolute;top:50%;left:50%;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,var(--gold-50) 0%,transparent 70%);transform:translate(-50%,-50%);pointer-events:none;filter:blur(80px)}
.intro-content{position:relative;z-index:2}

/* ═══════════════════════════════════════════════════════
   SERVICE CARDS
   ═══════════════════════════════════════════════════════ */
.services{padding:40px 0 120px;background:var(--dark-1)}
.srv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.srv-card{background:var(--dark-3);border:1px solid rgba(255,255,255,.04);border-radius:14px;padding:36px 30px;transition:all .4s var(--ease);position:relative;overflow:hidden}
.srv-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--gold),transparent);opacity:0;transition:opacity .4s}
.srv-card:hover{border-color:var(--gold-20);transform:translateY(-6px)}
.srv-card:hover::before{opacity:1}
.srv-icon{width:52px;height:52px;border-radius:12px;background:var(--gold-10);border:1px solid var(--gold-20);display:flex;align-items:center;justify-content:center;margin-bottom:20px;color:var(--gold);transition:all .4s}
.srv-card:hover .srv-icon{background:var(--gold);color:var(--dark-1)}
.srv-card h3{font-size:17px;font-weight:700;margin-bottom:10px}
.srv-card p{font-size:14px;line-height:1.65;color:var(--gray-2)}

/* ═══════════════════════════════════════════════════════
   APPROACH
   ═══════════════════════════════════════════════════════ */
.approach{padding:100px 0;background:var(--dark-2);border-top:1px solid rgba(255,255,255,.03);border-bottom:1px solid rgba(255,255,255,.03);overflow:hidden}
.approach-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:72px;align-items:center}
.approach-img-box{position:relative}
.approach-img-box img{width:100%;height:480px;object-fit:cover;border-radius:14px}
.approach-img-box::before{content:'';position:absolute;top:-14px;left:-14px;z-index:2;width:70px;height:70px;border-top:2.5px solid var(--gold);border-left:2.5px solid var(--gold);border-radius:6px 0 0 0;opacity:.5}
.approach-img-box::after{content:'';position:absolute;bottom:-14px;right:-14px;z-index:2;width:70px;height:70px;border-bottom:2.5px solid var(--gold);border-right:2.5px solid var(--gold);border-radius:0 0 6px 0;opacity:.5}
.approach-badge{position:absolute;bottom:24px;left:24px;z-index:3;background:rgba(6,8,9,.85);backdrop-filter:blur(12px);border:1px solid var(--gold-20);border-radius:10px;padding:16px 22px;display:flex;align-items:center;gap:14px}
.approach-badge-icon{width:42px;height:42px;border-radius:50%;background:var(--gold);color:var(--dark-1);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:14px}
.approach-badge-text{font-size:13px;font-weight:600}
.approach-badge-sub{font-size:11px;color:var(--gray-3)}
.approach-right .sec-eyebrow{justify-content:flex-start}
.approach-right .sec-eyebrow::before{display:none}
.approach-h2{font-family:var(--fs);font-size:40px;line-height:1.15;margin-bottom:20px}
.approach-p{font-size:16px;line-height:1.8;color:var(--gray-2);margin-bottom:32px}
.check-list{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:36px}
.check-item{display:flex;align-items:center;gap:10px;font-size:13.5px;font-weight:500;color:var(--gray-1)}
.check-dot{width:22px;height:22px;border-radius:6px;background:var(--gold-10);border:1px solid var(--gold-20);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.check-dot svg{width:12px;height:12px;color:var(--gold)}

/* ═══════════════════════════════════════════════════════
   GALLERY STRIP
   ═══════════════════════════════════════════════════════ */
.gallery-strip{padding:80px 0 0;overflow:hidden;background:var(--dark-1)}
.gallery-track{display:flex;gap:12px;animation:ticker 45s linear infinite;width:max-content}
.gallery-track:hover{animation-play-state:paused}
.gallery-thumb{flex-shrink:0;width:300px;height:200px;border-radius:10px;overflow:hidden;border:1px solid rgba(255,255,255,.04)}
.gallery-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.gallery-thumb:hover img{transform:scale(1.08)}

/* ═══════════════════════════════════════════════════════
   TESTIMONIALS
   ═══════════════════════════════════════════════════════ */
.reviews{padding:120px 0;position:relative;background:var(--dark-1)!important;overflow:hidden}
.reviews-head{text-align:center;margin-bottom:60px}
.reviews-h2{font-family:var(--fs);font-size:clamp(28px,4vw,42px);line-height:1.15}
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.rev-card{background:var(--dark-3);border:1px solid rgba(255,255,255,.04);border-radius:14px;padding:34px 30px;position:relative;transition:all .4s var(--ease)}
.rev-card:hover{border-color:var(--gold-20);transform:translateY(-4px)}
.rev-card .quote-mark{position:absolute;top:18px;right:24px;font-family:var(--fs);font-size:64px;line-height:1;color:var(--gold);opacity:.12}
.rev-stars{display:flex;gap:3px;margin-bottom:18px}
.rev-stars svg{width:16px;height:16px;fill:var(--gold);color:var(--gold)}
.rev-text{font-size:14.5px;line-height:1.7;color:var(--gray-1);margin-bottom:24px;font-style:italic}
.rev-author{display:flex;align-items:center;gap:12px}
.rev-avatar{width:40px;height:40px;border-radius:10px;background:linear-gradient(135deg,var(--gold),#c9962a);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:15px;color:var(--dark-1)}
.rev-name{font-size:14px;font-weight:600}
.rev-label{font-size:11px;color:var(--gray-3);margin-top:1px}
.google-badge{display:inline-flex;align-items:center;gap:10px;margin-top:48px;padding:12px 24px;background:var(--dark-3);border:1px solid rgba(255,255,255,.06);border-radius:10px;font-size:14px;font-weight:600}
.google-badge .g-score{color:var(--gold);font-size:18px;font-weight:700}

/* ═══════════════════════════════════════════════════════
   CONTACT + MAP
   ═══════════════════════════════════════════════════════ */
.contact{padding:100px 0;background:var(--dark-2);border-top:1px solid rgba(255,255,255,.03);overflow:hidden}
.contact-grid{display:grid;grid-template-columns:1fr 1.3fr;gap:40px}
.contact-card{background:var(--dark-3);border:1px solid rgba(255,255,255,.05);border-radius:16px;padding:44px 38px}
.contact-h2{font-family:var(--fs);font-size:32px;margin-bottom:30px}
.c-row{display:flex;align-items:flex-start;gap:16px;padding:16px 0;border-bottom:1px solid rgba(255,255,255,.04)}
.c-row:last-of-type{border-bottom:none}
.c-icon{width:42px;height:42px;border-radius:10px;background:var(--gold-10);border:1px solid var(--gold-20);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--gold)}
.c-label{font-size:10.5px;font-weight:700;color:var(--gray-3);text-transform:uppercase;letter-spacing:.1em;margin-bottom:3px}
.c-val{font-size:15px;font-weight:500}
.c-val a{transition:color .3s}
.c-val a:hover{color:var(--gold)}
.wa-btn{display:flex;align-items:center;justify-content:center;gap:10px;margin-top:28px;padding:14px 0;width:100%;background:#25D366;color:#fff;border-radius:10px;font-size:14px;font-weight:700;border:none;cursor:pointer;transition:all .3s}
.wa-btn:hover{background:#1fba59;transform:translateY(-1px);box-shadow:0 6px 20px rgba(37,211,102,.35)}
.map-box{border-radius:16px;overflow:hidden;height:100%;min-height:420px;border:1px solid rgba(255,255,255,.05)}
.map-box iframe{width:100%;height:100%;min-height:420px;border:0;filter:grayscale(.55) brightness(.75) contrast(1.15);transition:filter .5s}
.map-box:hover iframe{filter:grayscale(.2) brightness(.85) contrast(1.05)}

/* ═══════════════════════════════════════════════════════
   FOOTER
   ═══════════════════════════════════════════════════════ */
.footer{padding:56px 0 28px;background:var(--dark-1);border-top:1px solid rgba(255,255,255,.03);overflow:hidden}
.footer-top,.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px;margin-bottom:44px}
.footer-brand img,.footer-grid>div:first-child img{height:44px;width:auto;margin-bottom:16px}
.footer-desc{font-size:13.5px;line-height:1.7;color:var(--gray-3);max-width:280px}
.footer-grid>div>ul{list-style:none;padding:0;margin:0}
.footer-grid>div>h4{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;margin-bottom:16px;color:var(--white)}
.footer-grid>div>ul>li{padding:3px 0}
.footer-grid>div>ul>li>a{display:block;font-size:13.5px;color:var(--gray-3);padding:2px 0;transition:color .3s}
.footer-grid>div>ul>li>a:hover{color:var(--gold)}
.footer-grid>div>ul>li{font-size:13.5px;color:var(--gray-3)}
.footer-socials{display:flex;gap:10px;margin-top:20px}
.footer-socials a{width:36px;height:36px;border-radius:8px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.05);display:flex;align-items:center;justify-content:center;color:var(--gray-3);transition:all .3s}
.footer-socials a:hover{border-color:var(--gold);color:var(--gold);background:var(--gold-10)}
.footer-col h5{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;margin-bottom:16px;color:var(--white)}
.footer-col a{display:block;font-size:13.5px;color:var(--gray-3);padding:5px 0;transition:color .3s}
.footer-col a:hover{color:var(--gold)}
.footer-line{border-top:1px solid rgba(255,255,255,.04);padding-top:24px;display:flex;justify-content:space-between;align-items:center;font-size:12px;color:var(--gray-3)}

/* ═══════════════════════════════════════════════════════
   WHATSAPP FLOAT
   ═══════════════════════════════════════════════════════ */
.wa-float{position:fixed;bottom:24px;right:24px;z-index:90;width:58px;height:58px;border-radius:16px;background:#25D366;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 24px rgba(37,211,102,.4);animation:bob 3s ease-in-out infinite;transition:all .3s}
.wa-float:hover{transform:scale(1.08);animation-play-state:paused;box-shadow:0 8px 32px rgba(37,211,102,.5)}
.wa-float svg{width:28px;height:28px;fill:#fff}
.wa-float-pulse{position:absolute;inset:-4px;border-radius:20px;border:2px solid #25D366;animation:glow-pulse 2s infinite;pointer-events:none}

/* ═══════════════════════════════════════════════════════
   COOKIE BANNER
   ═══════════════════════════════════════════════════════ */
/* Cookie gestito da Iubenda - vecchio banner rimosso */

/* ═══════════════════════════════════════════════════════
   PAGE HEADERS (inner pages)
   ═══════════════════════════════════════════════════════ */
.page-hero{position:relative;padding:180px 0 100px;overflow:hidden;background:var(--dark-1);text-align:center;max-width:100vw}
.page-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at top center,var(--gold-50) 0%,transparent 50%);pointer-events:none}
.page-hero::after{content:'';position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--gold-20),transparent)}
.page-hero .wrap{position:relative;z-index:2}
.page-hero-eyebrow{display:inline-flex;align-items:center;gap:10px;padding:7px 18px;border-radius:6px;background:var(--gold-10);border:1px solid var(--gold-20);font-size:11px;font-weight:700;color:var(--gold);letter-spacing:.12em;text-transform:uppercase;margin-bottom:20px}
.page-hero-h1{font-family:var(--fs);font-size:clamp(40px,6vw,72px);line-height:1.08;margin-bottom:18px}
.page-hero-h1 em{color:var(--gold);text-shadow:0 0 60px var(--gold-glow)}
.page-hero-p{font-size:17px;line-height:1.7;color:var(--gray-1);max-width:560px;margin:0 auto}
/* Decorative floating shapes */
.page-hero-shape{position:absolute;border:1px solid var(--gold-20);border-radius:50%;opacity:.15;pointer-events:none}
.page-hero-shape.s1{width:300px;height:300px;top:-80px;right:-60px;animation:spin-slow 40s linear infinite}
.page-hero-shape.s2{width:180px;height:180px;bottom:20px;left:-40px;animation:spin-slow 30s linear infinite reverse}

/* ═══════════════════════════════════════════════════════
   CHI SIAMO PAGE
   ═══════════════════════════════════════════════════════ */
.story{padding:100px 0;background:var(--dark-1);overflow:hidden}
.story-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.story-img{position:relative;border-radius:14px;overflow:hidden;height:420px}
.story-img img{width:100%;height:100%;object-fit:cover}
.story-img::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,transparent 60%,var(--gold-10));pointer-events:none}
.story-text h2{font-family:var(--fs);font-size:36px;line-height:1.15;margin-bottom:20px}
.story-text h2 em{color:var(--gold);font-style:italic}
.story-text p{font-size:15.5px;line-height:1.8;color:var(--gray-2);margin-bottom:16px}

/* Timeline */
.timeline{padding:100px 0;background:var(--dark-2)}
.timeline-list{position:relative;max-width:700px;margin:48px auto 0}
.timeline-list::before{content:'';position:absolute;left:24px;top:0;bottom:0;width:2px;background:linear-gradient(180deg,var(--gold),var(--gold-20),transparent)}
.timeline-item{position:relative;padding-left:68px;margin-bottom:48px}
.timeline-dot{position:absolute;left:16px;top:4px;width:18px;height:18px;border-radius:50%;border:3px solid var(--gold);background:var(--dark-2)}
.timeline-year{font-family:var(--fs);font-size:24px;color:var(--gold);margin-bottom:4px}
.timeline-desc{font-size:15px;line-height:1.7;color:var(--gray-1)}

/* Values */
.values{padding:100px 0;background:var(--dark-1)}
.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:48px}
.value-card{background:var(--dark-3);border:1px solid rgba(255,255,255,.04);border-radius:14px;padding:40px 32px;text-align:center;transition:all .4s var(--ease)}
.value-card:hover{border-color:var(--gold-20);transform:translateY(-4px)}
.value-icon{width:64px;height:64px;border-radius:16px;background:var(--gold-10);border:1px solid var(--gold-20);display:flex;align-items:center;justify-content:center;margin:0 auto 20px;color:var(--gold);font-size:28px}
.value-card h3{font-size:17px;font-weight:700;margin-bottom:10px}
.value-card p{font-size:14px;line-height:1.65;color:var(--gray-2)}

/* Numbers */
.numbers{padding:80px 0;background:var(--dark-2)}
.numbers-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.num-card{text-align:center;padding:32px 20px}
.num-val{font-family:var(--fs);font-size:48px;color:var(--gold);line-height:1;margin-bottom:8px}
.num-label{font-size:13px;color:var(--gray-2);font-weight:500}

/* ═══════════════════════════════════════════════════════
   SERVIZI PAGE
   ═══════════════════════════════════════════════════════ */
.service-detail{padding:100px 0}
.service-detail:nth-child(even){background:var(--dark-2)}
.service-detail:nth-child(odd){background:var(--dark-1)}
.service-row{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.service-detail:nth-child(even) .service-row{direction:rtl}
.service-detail:nth-child(even) .service-row>*{direction:ltr}
.service-img{position:relative;border-radius:14px;overflow:hidden;height:380px}
.service-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.service-img:hover img{transform:scale(1.05)}
/* ── Novita Section ── */
.novita-section{padding:60px 0 40px;background:var(--dark-1);overflow:hidden}
.novita-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:36px}
.novita-card{background:var(--dark-3);border:1px solid rgba(255,255,255,.05);border-radius:14px;padding:24px;transition:all .4s var(--ease);overflow:hidden}
.novita-card:hover{border-color:var(--gold-20);transform:translateY(-4px)}
.novita-badge{display:inline-block;background:var(--gold);color:#000;padding:5px 14px;border-radius:6px;font-size:10px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;margin-bottom:14px}
.novita-img{border-radius:10px;overflow:hidden;height:160px;margin-bottom:16px}
.novita-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s var(--ease)}
.novita-card:hover .novita-img img{transform:scale(1.05)}
.novita-card h3{font-size:16px;font-weight:700;margin-bottom:8px}
.novita-card p{font-size:13.5px;line-height:1.6;color:var(--gray-2)}

.service-img .service-badge{position:absolute;top:16px;left:16px;background:var(--gold);color:var(--dark-1);padding:6px 16px;border-radius:6px;font-size:10px;font-weight:800;letter-spacing:.1em;text-transform:uppercase}
.service-body h2{font-family:var(--fs);font-size:34px;line-height:1.15;margin-bottom:16px}
.service-body h2 em{color:var(--gold);font-style:italic}
.service-body p{font-size:15.5px;line-height:1.8;color:var(--gray-2);margin-bottom:24px}
.service-features{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:28px}
.service-feat{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:500;color:var(--gray-1)}
.service-feat svg{width:16px;height:16px;color:var(--gold);flex-shrink:0}

/* CTA section */
.cta-section{padding:100px 0;background:var(--dark-2);text-align:center;position:relative;overflow:hidden;max-width:100vw}
.cta-section::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at center,var(--gold-50) 0%,transparent 60%);pointer-events:none}
.cta-content{position:relative;z-index:2}

/* ═══════════════════════════════════════════════════════
   NOLEGGIO PAGE
   ═══════════════════════════════════════════════════════ */
.rental-intro{padding:80px 0 60px;text-align:center;background:var(--dark-1)}
.rental-grid{padding:0 0 100px;background:var(--dark-1)}
.rental-card{background:var(--dark-3);border:1px solid rgba(255,255,255,.05);border-radius:16px;overflow:hidden;transition:all .4s var(--ease);position:relative}
.rental-card:hover{border-color:var(--gold-20);transform:translateY(-8px);box-shadow:0 20px 60px rgba(0,0,0,.3)}
.rental-card.popular{border-color:var(--gold);box-shadow:0 0 0 1px var(--gold)}
.rental-popular-tag{position:absolute;top:16px;right:16px;z-index:3;background:var(--gold);color:var(--dark-1);padding:6px 14px;border-radius:6px;font-size:10px;font-weight:800;letter-spacing:.1em;text-transform:uppercase}
.rental-img{height:220px;overflow:hidden;position:relative}
.rental-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.rental-card:hover .rental-img img{transform:scale(1.06)}
.rental-body{padding:28px 24px}
.rental-name{font-family:var(--fs);font-size:26px;margin-bottom:6px}
.rental-desc{font-size:13.5px;line-height:1.6;color:var(--gray-2);margin-bottom:20px}
.rental-specs{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:24px;padding:20px 0;border-top:1px solid rgba(255,255,255,.04);border-bottom:1px solid rgba(255,255,255,.04)}
.rental-spec{display:flex;align-items:center;gap:8px;font-size:12.5px;color:var(--gray-1)}
.rental-spec svg{width:14px;height:14px;color:var(--gold);flex-shrink:0}
.rental-price{font-family:var(--fs);font-size:28px;color:var(--gold);margin-bottom:4px}
.rental-price-note{font-size:11px;color:var(--gray-3);margin-bottom:16px}
.rental-card .btn{width:100%;justify-content:center}

/* Rental info */
.rental-info{padding:80px 0;background:var(--dark-2)}
.rental-info-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:48px}
.rental-info-card{background:var(--dark-3);border:1px solid rgba(255,255,255,.04);border-radius:14px;padding:32px 24px;text-align:center;transition:all .3s var(--ease)}
.rental-info-card:hover{border-color:var(--gold-20)}
.rental-info-icon{font-size:32px;margin-bottom:14px}
.rental-info-card h3{font-size:15px;font-weight:700;margin-bottom:8px}
.rental-info-card p{font-size:13px;line-height:1.6;color:var(--gray-2)}

/* ═══════════════════════════════════════════════════════
   CONTATTI PAGE
   ═══════════════════════════════════════════════════════ */
.contact-full{padding:80px 0;background:var(--dark-1)}
.contact-full-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:40px}
.contact-info-cards{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:24px}
.contact-info-card{background:var(--dark-3);border:1px solid rgba(255,255,255,.04);border-radius:12px;padding:24px 20px;transition:all .3s var(--ease)}
.contact-info-card:hover{border-color:var(--gold-20)}
.contact-info-card .c-icon{margin-bottom:12px}
.contact-info-card .c-label{margin-bottom:4px}
.contact-info-card .c-val{font-size:14px}

/* Contact form */
.contact-form-card{background:var(--dark-3);border:1px solid rgba(255,255,255,.05);border-radius:16px;padding:44px 38px}
.contact-form-card h2{font-family:var(--fs);font-size:28px;margin-bottom:24px}
.form-group{margin-bottom:18px}
.form-group label{display:block;font-size:12px;font-weight:600;color:var(--gray-2);text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px}
.form-input,.form-textarea{width:100%;padding:14px 18px;background:var(--dark-4);border:1px solid rgba(255,255,255,.06);border-radius:10px;color:var(--white);font-family:var(--ff);font-size:14px;transition:all .3s;outline:none}
.form-input:focus,.form-textarea:focus{border-color:var(--gold);box-shadow:0 0 0 3px var(--gold-10)}
.form-textarea{min-height:120px;resize:vertical}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}

/* ═══════════════════════════════════════════════════════
   RESPONSIVE — TABLET (max 900px)
   ═══════════════════════════════════════════════════════ */
@media(max-width:900px){
  .wrap{padding:0 20px}

  /* ── Mobile Nav ── */
  .nav-menu{display:none;position:fixed;inset:0;z-index:200;background:rgba(6,8,9,.98);backdrop-filter:blur(30px);-webkit-backdrop-filter:blur(30px);flex-direction:column;justify-content:center;align-items:center;gap:10px;padding:80px 28px 40px}
  .nav-menu.open{display:flex}
  .nav-menu a{font-size:20px;padding:14px 24px;font-weight:500;color:var(--gray-1);text-align:center;width:100%;max-width:300px;border-radius:10px;transition:background .3s,color .3s}
  .nav-menu a:hover,.nav-menu a.active{background:var(--gold-10);color:var(--gold)}
  .nav-menu a::after{display:none}
  .nav-menu .nav-cta-btn{margin:16px 0 0;padding:16px 40px!important;font-size:15px!important;width:auto;max-width:300px;justify-content:center;border-radius:10px!important}
  .burger{display:flex;z-index:201}
  .burger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
  .burger.open span:nth-child(2){opacity:0}
  .burger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}
  .mob-close{display:none!important}

  /* ── Hero ── */
  .hero{padding-bottom:180px;min-height:85vh}
  .hero-h1{font-size:clamp(36px,8vw,56px);max-width:100%}
  .hero-p{font-size:15px;max-width:100%}
  .hero-btns{flex-direction:column;gap:10px}
  .hero-btns .btn{width:100%;justify-content:center}
  .hero-strip-inner{grid-template-columns:repeat(2,1fr)}
  .hero-kpi:nth-child(2){border-right:none}
  .hero-kpi{padding:20px 16px}
  .hero-progress{display:none}

  /* ── Marquee ── */
  .marquee{padding:10px 0}
  .marquee-item{font-size:11px;padding:0 20px}

  /* ── Celebration ── */
  .celeb-card{padding:40px 24px}
  .celeb-h2{font-size:clamp(28px,6vw,42px)}
  .celeb-date{padding:12px 20px;font-size:14px}

  /* ── DPF ── */
  .dpf{padding:60px 0}
  .dpf-wrap{grid-template-columns:1fr}
  .dpf-visual{min-height:240px}
  .dpf-body{padding:32px 24px}
  .dpf-h2{font-size:28px}

  /* ── Intro ── */
  .intro{padding:80px 0 60px}

  /* ── Novita + Service Cards ── */
  .novita-section{padding:40px 0 20px}
  .novita-grid{grid-template-columns:1fr;gap:14px;margin-top:24px}
  .novita-card{padding:20px}
  .novita-img{height:200px}
  .services{padding:20px 0 80px}
  .srv-grid{grid-template-columns:1fr;gap:14px}
  .srv-card{padding:28px 24px}

  /* ── Approach ── */
  .approach{padding:60px 0}
  .approach-grid{grid-template-columns:1fr;gap:32px}
  .approach-img-box{order:-1}
  .approach-img-box img{height:260px}
  .approach-img-box::before,.approach-img-box::after{display:none}
  .approach-h2{font-size:32px}
  .check-list{grid-template-columns:1fr}

  /* ── Gallery ── */
  .gallery-strip{padding:40px 0 0}
  .gallery-thumb{width:220px;height:150px}

  /* ── Reviews ── */
  .reviews{padding:80px 0}
  .reviews-grid{grid-template-columns:1fr;max-width:480px;margin:0 auto}

  /* ── Contact ── */
  .contact{padding:60px 0}
  .contact-grid{grid-template-columns:1fr}
  .contact-card{padding:32px 24px}

  /* ── Footer ── */
  .footer-top,.footer-grid{grid-template-columns:1fr 1fr;gap:28px}
  .footer-line,.footer-bottom{flex-direction:column;gap:8px;text-align:center}

  /* ── Page Hero (inner pages) ── */
  .page-hero{padding:140px 0 60px}
  .page-hero-h1{font-size:clamp(36px,8vw,56px)}
  .page-hero-shape{display:none}

  /* ── Chi Siamo ── */
  .story{padding:60px 0}
  .story-grid{grid-template-columns:1fr;gap:32px}
  .story-img{height:260px}
  .timeline{padding:60px 0}
  .values{padding:60px 0}
  .values-grid{grid-template-columns:1fr;gap:16px}
  .numbers{padding:60px 0}
  .numbers-grid{grid-template-columns:repeat(2,1fr);gap:16px}

  /* ── Servizi ── */
  .service-detail{padding:60px 0}
  .service-row{grid-template-columns:1fr;gap:28px}
  .service-detail:nth-child(even) .service-row{direction:ltr}
  .service-img{height:240px}
  .service-body h2{font-size:28px}
  .service-features{grid-template-columns:1fr}

  /* ── Noleggio ── */
  .rental-intro{padding:40px 0 20px}
  .rental-grid-inner{grid-template-columns:1fr;max-width:420px;margin:0 auto}
  .rental-info{padding:60px 0}
  .rental-info-grid{grid-template-columns:1fr;gap:16px}

  /* ── Contatti ── */
  .contact-full{padding:40px 0}
  .contact-full-grid{grid-template-columns:1fr}
  .contact-info-cards{grid-template-columns:1fr 1fr;gap:12px}
  .contact-form-card{padding:32px 24px;margin-top:20px}

  /* ── CTA ── */
  .cta-section{padding:60px 0}
  .cta-buttons,.cta-btns{flex-direction:column;align-items:center}
  .cta-buttons .btn,.cta-btns .btn{width:100%;max-width:320px;justify-content:center}

  /* ── Cookie & WA ── */
  .wa-float{width:52px;height:52px}
}

/* ═══════════════════════════════════════════════════════
   RESPONSIVE — MOBILE (max 600px)
   ═══════════════════════════════════════════════════════ */
@media(max-width:600px){
  .wrap{padding:0 16px}

  /* ── Hero ── */
  .hero{min-height:80vh;padding-bottom:160px}
  .hero-h1{font-size:clamp(30px,9vw,44px)}
  .hero-p{font-size:14px}
  .hero-tag{font-size:10px;padding:5px 12px}
  .hero-strip-inner{grid-template-columns:1fr 1fr}
  .hero-kpi{padding:14px 10px}
  .hero-kpi-val{font-size:22px}
  .hero-kpi-lab{font-size:9.5px;letter-spacing:.06em}

  /* ── Sections ── */
  .sec-heading{font-size:clamp(26px,6vw,36px)}
  .sec-sub{font-size:15px}
  .intro{padding:60px 0 40px}
  .celebration{padding:24px 0}
  .celeb-card{padding:20px 14px;border-radius:12px}
  .celeb-emoji{font-size:28px;margin-bottom:8px}
  .celeb-eyebrow{font-size:10px;margin-bottom:8px}
  .celeb-h2{font-size:22px;margin-bottom:8px}
  .celeb-sub{font-size:14px;margin-bottom:4px}
  .celeb-date{padding:8px 14px;font-size:11px;margin-top:10px}
  .celeb-p{font-size:12px;margin-top:10px;line-height:1.5}
  .celeb-sparkles{display:none}
  .dpf{padding:40px 0}
  .dpf-h2{font-size:24px}
  .dpf-p{font-size:14px}

  /* ── Novita ── */
  .novita-section{padding:28px 0 16px}
  .novita-grid{gap:12px;margin-top:18px}
  .novita-card{padding:16px}
  .novita-card h3{font-size:15px}
  .novita-card p{font-size:12.5px}
  .novita-img{height:180px}
  .novita-badge{font-size:9px;padding:4px 10px}

  /* ── Cards ── */
  .srv-card{padding:24px 20px}
  .value-card{padding:28px 20px}
  .rev-card{padding:24px 20px}

  /* ── Page Hero ── */
  .page-hero{padding:120px 0 40px}
  .page-hero-h1{font-size:clamp(30px,9vw,44px)}
  .page-hero-p{font-size:14.5px}

  /* ── Story ── */
  .story-text h2{font-size:28px}
  .story-img{height:220px}
  .timeline-list{padding-left:0}
  .timeline-list::before{left:16px}
  .timeline-item{padding-left:50px;margin-bottom:32px}
  .timeline-dot{left:8px}

  /* ── Numbers ── */
  .num-val{font-size:36px}
  .num-label{font-size:11px}

  /* ── Rental ── */
  .rental-card{border-radius:12px}
  .rental-img{height:180px}
  .rental-name{font-size:22px}
  .rental-price{font-size:24px}
  .rental-specs{grid-template-columns:1fr}
  .rental-body{padding:20px 18px}

  /* ── Contact ── */
  .contact-info-cards{grid-template-columns:1fr}
  .contact-form-card{padding:24px 18px}
  .contact-form-card h2{font-size:24px}
  .form-row{grid-template-columns:1fr}

  /* ── Footer minimal mobile ── */
  .footer{padding:32px 0 16px}
  .footer .wrap{display:flex;flex-direction:column;align-items:center}
  .footer-top,.footer-grid{display:flex!important;flex-direction:column;align-items:center;text-align:center;gap:0;margin-bottom:20px;width:100%}
  .footer-top>div:first-child,.footer-grid>div:first-child{order:0;margin-bottom:20px;text-align:center;width:100%;display:flex;flex-direction:column;align-items:center}
  .footer-top>div:first-child img,.footer-grid>div:first-child img{margin:0 auto 12px;height:54px;width:auto}
  .footer-desc{max-width:280px;margin:0 auto;font-size:12.5px;line-height:1.5;text-align:center}
  .footer-socials{justify-content:center;margin-top:14px}
  .footer-col:nth-child(2),.footer-col:nth-child(3),.footer-grid>div:nth-child(2),.footer-grid>div:nth-child(3){display:none!important}
  .footer-col:last-child,.footer-grid>div:last-child{display:block!important;text-align:center;margin-top:16px;padding-top:16px;border-top:1px solid rgba(255,255,255,.04);width:100%}
  .footer-col:last-child h4,.footer-col:last-child h5,.footer-grid>div:last-child h4{font-size:11px;margin-bottom:10px;text-align:center}
  .footer-col:last-child ul,.footer-grid>div:last-child ul{display:flex;flex-wrap:wrap;justify-content:center;gap:4px 16px;padding:0;margin:0}
  .footer-col:last-child li,.footer-grid>div:last-child li{font-size:12px;text-align:center}
  .footer-col:last-child a,.footer-grid>div:last-child a{font-size:12px;padding:2px 0;display:inline}
  .footer-bottom{padding-top:14px;margin-top:4px;text-align:center;width:100%}
  .footer-bottom p{font-size:10.5px;line-height:1.5;text-align:center}
  .footer-line{text-align:center;font-size:10.5px;width:100%}

  /* ── Buttons ── */
  .btn{padding:14px 28px;font-size:13px;width:100%;justify-content:center}
  .hero-btns .btn,.cta-buttons .btn{border-radius:10px}

  /* ── Cookie & WA ── */
  .wa-float{bottom:14px;right:14px;width:48px;height:48px;border-radius:12px}
  .wa-float svg{width:24px;height:24px}

  /* ── Approach ── */
  .approach-badge{bottom:12px;left:12px;padding:12px 16px;gap:10px}
  .approach-badge-icon{width:34px;height:34px;font-size:12px}
  .approach-badge-text{font-size:12px}

  /* ── Map ── */
  .map-box{min-height:300px;border-radius:12px}
  .map-box iframe{min-height:300px}
}

/* ─── EXTRA UTILITIES ─── */
.dark-1{background:var(--dark-1)}
.dark-2{background:var(--dark-2)}
.cta-buttons,.cta-btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:32px}
.footer-logo{display:inline-block;margin-bottom:16px}
.footer-logo img{height:44px;width:auto}

/* Rental grid inner wrapper */
.rental-grid-inner{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
/* Footer aliases for inner pages */
.footer-top,.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px;margin-bottom:44px}
.footer-grid .footer-col ul{list-style:none;padding:0}
.footer-grid .footer-col h4{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;margin-bottom:16px;color:var(--white)}
.footer-grid .footer-col a{display:block;font-size:13.5px;color:var(--gray-3);padding:5px 0;transition:color .3s}
.footer-grid .footer-col a:hover{color:var(--gold)}
.footer-grid .footer-col li{font-size:13.5px;color:var(--gray-3);padding:3px 0}
.footer-bottom{border-top:1px solid rgba(255,255,255,.04);padding-top:24px;font-size:12px;color:var(--gray-3);text-align:center}
.footer-bottom a{color:var(--gold)}

@media(max-width:900px){
  .rental-grid-inner{grid-template-columns:1fr;max-width:420px;margin:0 auto}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:600px){
  .rental-grid-inner{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
}
