/* ============================================================
   HotelPools — Aqua Dark Luxury | dark-only
   W.B. Berkshire Italia Srl
   Palette: teal #1a6e8a / azure #2a9fd6 / acqua #0dcac8
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,600;0,700;1,300;1,400&family=Barlow:wght@300;400;500;600&family=Barlow+Condensed:wght@400;500;600;700&display=swap');

:root {
  --bg:        #060b0f;
  --bg-mid:    #0b1520;
  --bg-light:  #112030;
  --fg:        #eef4f8;
  --fg-dim:    rgba(238,244,248,.65);
  --fg-ghost:  rgba(238,244,248,.08);

  --a1:        #2a9fd6;
  --a1-lt:     #55bae8;
  --a1-dk:     #1a6e8a;
  --a2:        #0dcac8;
  --a3:        #0a3a52;

  --b-sub:     rgba(42,159,214,.18);
  --b-card:    rgba(42,159,214,.10);

  /* aliases brevettopilota-compat */
  --noir:      var(--bg);
  --noir-mid:  var(--bg-mid);
  --noir-light:var(--bg-light);
  --gold:      var(--a1);
  --gold-light:var(--a1-lt);
  --gold-dark: var(--a1-dk);
  --white:     var(--fg);
  --white-dim: var(--fg-dim);
  --accent:    var(--a2);

  --fd: 'Cormorant Garamond', Georgia, serif;
  --fb: 'Barlow', sans-serif;
  --fc: 'Barlow Condensed', sans-serif;
  --tr: .4s cubic-bezier(.25,.46,.45,.94);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{background:var(--bg);color:var(--fg);font-family:var(--fb);font-weight:300;line-height:1.7;overflow-x:hidden}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
ul{list-style:none}

/* ── Utility ─────────────────────────────────────────────── */
.container{width:90%;max-width:1240px;margin:0 auto}
.text-center{text-align:center}
.accent{color:var(--a1)}

/* ── img-cover ───────────────────────────────────────────── */
.img-cover{position:relative;overflow:hidden;width:100%}
.img-cover img{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:100%;height:100%;object-fit:cover;transition:transform .8s ease}
.ratio-16-9{padding-bottom:56.25%}
.ratio-4-3{padding-bottom:75%}
.ratio-3-2{padding-bottom:66.66%}

/* ── Eyebrow ──────────────────────────────────────────────── */
.eyebrow{font-family:var(--fc);font-size:.75rem;font-weight:600;letter-spacing:.25em;text-transform:uppercase;color:var(--a1);display:flex;align-items:center;gap:10px;margin-bottom:1rem}
.eyebrow::before{content:'';display:inline-block;width:32px;height:1px;background:var(--a1);flex-shrink:0}

/* ── Animations ───────────────────────────────────────────── */
@keyframes fadeUp{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes heroZoom{from{transform:scale(1.05)}to{transform:scale(1)}}
@keyframes scrollPulse{0%,100%{opacity:.4}50%{opacity:1}}
@keyframes pulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.3);opacity:.7}}
.reveal{opacity:0;transform:translateY(32px);transition:opacity .7s ease,transform .7s ease}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-d1{transition-delay:.1s}
.reveal-d2{transition-delay:.2s}
.reveal-d3{transition-delay:.3s}
.reveal-d4{transition-delay:.4s}

/* ── Buttons ──────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:10px;font-family:var(--fc);font-size:.85rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;padding:14px 32px;border:1px solid transparent;cursor:pointer;transition:var(--tr);position:relative;overflow:hidden}
.btn::after{content:'';position:absolute;inset:0;background:rgba(255,255,255,.06);opacity:0;transition:opacity .3s}
.btn:hover::after{opacity:1}
.btn svg{width:16px;height:16px;flex-shrink:0}
.btn-az{background:var(--a1);color:var(--bg);border-color:var(--a1)}
.btn-az:hover{background:var(--a1-lt);border-color:var(--a1-lt)}
.btn-out{background:transparent;color:var(--fg);border-color:rgba(238,244,248,.35)}
.btn-out:hover{border-color:var(--a1);color:var(--a1)}
.btn-out-az{background:transparent;color:var(--a1);border-color:var(--a1)}
.btn-out-az:hover{background:var(--a1);color:var(--bg)}
.btn-lg{padding:18px 48px;font-size:.95rem}

/* ── Section titles ───────────────────────────────────────── */
.sec-title{font-family:var(--fd);font-size:clamp(2.2rem,4vw,3.6rem);font-weight:600;line-height:1.1;margin-bottom:20px}
.sec-title em{font-style:italic;color:var(--a1)}
.sec-lead{color:var(--fg-dim);font-size:1rem;line-height:1.8;margin-bottom:16px}

/* ── Anchor nav (sottosezioni) ────────────────────────────── */
.anchor-nav{background:var(--bg-mid);border-bottom:1px solid var(--b-sub);position:sticky;top:80px;z-index:900}
.anchor-nav-inner{display:flex;gap:0;overflow-x:auto;scrollbar-width:none;width:92%;max-width:1320px;margin:0 auto}
.anchor-nav-inner::-webkit-scrollbar{display:none}
.anchor-link{font-family:var(--fc);font-size:.75rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--fg-dim);padding:16px 20px;white-space:nowrap;border-bottom:2px solid transparent;transition:color .3s,border-color .3s;flex-shrink:0}
.anchor-link:hover,.anchor-link.active{color:var(--a1);border-bottom-color:var(--a1)}

/* ── Page hero (internal pages) ───────────────────────────── */
.page-hero{padding:140px 0 80px;background:var(--bg-mid);position:relative;overflow:hidden}
.page-hero::before{content:'';position:absolute;inset:0;background:url('/assets/img/cta-pool-night.webp') center/cover no-repeat;opacity:.08}
.page-hero-content{position:relative;z-index:1;max-width:780px}
.page-hero h1{font-family:var(--fd);font-size:clamp(2.8rem,5vw,5rem);font-weight:600;line-height:1.05;margin-bottom:20px}
.page-hero h1 em{font-style:italic;color:var(--a1)}
.page-hero .subtitle{font-size:1.1rem;color:var(--fg-dim);line-height:1.75;max-width:620px}

/* ── Content sections (pagine interne) ────────────────────── */
.content-section{padding:100px 0}
.content-section:nth-child(even){background:var(--bg-mid)}
.content-section:nth-child(odd){background:var(--bg)}
.content-layout{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}
.content-layout.reverse{direction:rtl}
.content-layout.reverse>*{direction:ltr}
.content-layout.single{grid-template-columns:1fr;max-width:860px}
.content-body h2{font-family:var(--fd);font-size:clamp(1.8rem,3vw,2.8rem);font-weight:600;line-height:1.1;margin-bottom:20px}
.content-body h2 em{font-style:italic;color:var(--a1)}
.content-body p{color:var(--fg-dim);font-size:.95rem;line-height:1.85;margin-bottom:16px}
.content-body p:last-child{margin-bottom:0}

/* Bullet list stile scuola */
.content-list{margin:28px 0;display:flex;flex-direction:column;gap:12px}
.content-list li{display:flex;align-items:flex-start;gap:14px;font-size:.9rem;color:var(--fg-dim);line-height:1.65}
.content-list li::before{content:'';width:20px;height:1px;background:var(--a1);margin-top:13px;flex-shrink:0}

/* Card grid 3col */
.card-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--b-card)}
.card-grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--b-card)}
.feature-card{background:var(--bg-mid);padding:44px 36px;position:relative;overflow:hidden;transition:background .4s}
.feature-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--a1),var(--a2));transform:scaleX(0);transform-origin:left;transition:transform .4s}
.feature-card:hover{background:var(--bg-light)}
.feature-card:hover::after{transform:scaleX(1)}
.feature-card .fc-icon{width:40px;height:40px;color:var(--a1);margin-bottom:20px}
.feature-card h3{font-family:var(--fd);font-size:1.5rem;font-weight:600;margin-bottom:12px}
.feature-card p{color:var(--fg-dim);font-size:.88rem;line-height:1.75}
.feature-card .fc-tag{font-family:var(--fc);font-size:.68rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--a2);margin-bottom:10px}

/* Highlight box */
.highlight-box{background:var(--bg-light);border-left:3px solid var(--a1);padding:32px 36px;margin:32px 0}
.highlight-box p{color:var(--fg-dim);font-size:.95rem;line-height:1.8;margin:0}
.highlight-box strong{color:var(--fg);font-weight:500}

/* ══════════════════════════════════════════════════════════
   HEADER
══════════════════════════════════════════════════════════ */
#site-header{position:fixed;top:0;left:0;right:0;z-index:1000;transition:background .5s,box-shadow .5s}
#site-header.scrolled{background:rgba(6,11,15,.96);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);box-shadow:0 1px 0 rgba(42,159,214,.22)}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:80px;width:92%;max-width:1320px;margin:0 auto}

.site-logo{display:flex;align-items:center;gap:12px}
.site-logo img{height:40px;width:auto}
.logo-text .logo-main{font-family:var(--fc);font-size:1.4rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--fg);line-height:1}
.logo-text .logo-main span{color:var(--a1)}
.logo-text .logo-sub{font-family:var(--fb);font-size:.6rem;letter-spacing:.22em;text-transform:uppercase;color:var(--a1);opacity:.75;margin-top:2px;display:block}

.main-nav{display:flex;align-items:center;gap:0}
.nav-item{position:relative}
.nav-link{font-family:var(--fc);font-size:.78rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--fg-dim);padding:10px 14px;display:block;transition:color .3s;white-space:nowrap}
.nav-link:hover,.nav-link.active{color:var(--a1)}

/* Dropdown */
.has-drop:hover .dropdown{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.dropdown{position:absolute;top:calc(100% + 8px);left:50%;transform:translateX(-50%) translateY(-8px);background:var(--bg-mid);border:1px solid rgba(42,159,214,.2);border-top:2px solid var(--a1);min-width:240px;opacity:0;visibility:hidden;transition:opacity .3s,transform .3s,visibility .3s;z-index:100}
.dropdown a{display:block;font-family:var(--fc);font-size:.75rem;letter-spacing:.1em;text-transform:uppercase;color:var(--fg-dim);padding:11px 18px;border-bottom:1px solid rgba(255,255,255,.04);transition:color .3s,background .3s,padding-left .3s}
.dropdown a:last-child{border-bottom:none}
.dropdown a:hover{color:var(--a1);background:rgba(42,159,214,.06);padding-left:26px}

.header-cta{display:flex;align-items:center;gap:14px}
.header-tel{font-family:var(--fc);font-size:.78rem;letter-spacing:.1em;color:var(--fg-dim);transition:color .3s}
.header-tel:hover{color:var(--a1)}

.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px}
.hamburger span{display:block;width:24px;height:1.5px;background:var(--fg);transition:var(--tr)}

.mobile-nav{display:none;position:fixed;inset:0;background:rgba(6,11,15,.98);z-index:999;flex-direction:column;align-items:center;justify-content:center;gap:24px}
.mobile-nav.open{display:flex}
.mobile-nav .mob-link{font-family:var(--fd);font-size:1.8rem;font-weight:400;color:var(--fg);transition:color .3s}
.mobile-nav .mob-link:hover{color:var(--a1)}
.mobile-close{position:absolute;top:24px;right:28px;background:none;border:none;color:var(--fg);font-size:2.4rem;cursor:pointer}
.mob-div{width:40px;height:1px;background:rgba(42,159,214,.3)}

/* ══════════════════════════════════════════════════════════
   HERO
══════════════════════════════════════════════════════════ */
#hero{position:relative;height:100vh;min-height:640px;display:flex;align-items:center;overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;object-position:center top;transform:scale(1.05);animation:heroZoom 14s ease-out forwards}
.hero-ov{position:absolute;inset:0;z-index:1;background:linear-gradient(110deg,rgba(6,11,15,.88) 0%,rgba(6,11,15,.55) 50%,rgba(13,30,50,.18) 100%)}
.hero-ov-btm{position:absolute;bottom:0;left:0;right:0;height:260px;z-index:2;background:linear-gradient(to top,rgba(6,11,15,1) 0%,rgba(10,25,45,.3) 60%,transparent 100%)}
.hero-content{position:relative;z-index:3;width:92%;max-width:1320px;margin:0 auto;padding-top:80px}
.hero-eyebrow{font-family:var(--fc);font-size:.72rem;font-weight:600;letter-spacing:.3em;text-transform:uppercase;color:var(--a2);display:flex;align-items:center;gap:12px;margin-bottom:28px;opacity:0;animation:fadeUp .8s .3s forwards}
.hero-eyebrow::before{content:'';width:40px;height:1px;background:var(--a2)}
.hero-title{font-family:var(--fd);font-size:clamp(3.2rem,7vw,7rem);font-weight:600;line-height:1.05;color:var(--fg);max-width:780px;margin-bottom:28px;opacity:0;animation:fadeUp .9s .5s forwards}
.hero-title em{font-style:italic;color:var(--a1)}
.hero-sub{font-size:1.05rem;font-weight:300;color:var(--fg-dim);max-width:500px;line-height:1.8;margin-bottom:48px;opacity:0;animation:fadeUp .9s .7s forwards}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap;opacity:0;animation:fadeUp .9s .9s forwards}
.hero-scroll{position:absolute;bottom:48px;left:50%;transform:translateX(-50%);z-index:3;display:flex;flex-direction:column;align-items:center;gap:8px;opacity:0;animation:fadeIn 1s 1.4s forwards}
.hero-scroll span{font-family:var(--fc);font-size:.62rem;letter-spacing:.25em;text-transform:uppercase;color:var(--fg-dim)}
.scroll-line{width:1px;height:48px;background:linear-gradient(to bottom,var(--a1),transparent);animation:scrollPulse 2s ease-in-out infinite}

/* ══════════════════════════════════════════════════════════
   STATS
══════════════════════════════════════════════════════════ */
#stats{background:var(--bg-mid);border-top:1px solid var(--b-sub);border-bottom:1px solid var(--b-sub)}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr)}
.stat-item{padding:52px 40px;text-align:center;border-right:1px solid rgba(238,244,248,.06);transition:background .3s}
.stat-item:last-child{border-right:none}
.stat-item:hover{background:rgba(42,159,214,.05)}
.stat-num{font-family:var(--fd);font-size:clamp(2.8rem,4vw,4.4rem);font-weight:600;color:var(--a1);line-height:1;margin-bottom:10px}
.stat-lbl{font-family:var(--fc);font-size:.75rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--fg-dim)}

/* ══════════════════════════════════════════════════════════
   PERCHE (home block) / Intro
══════════════════════════════════════════════════════════ */
#perche-home{padding:120px 0;background:var(--bg)}
.perche-header{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:end;margin-bottom:80px}
.cards-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--b-card)}

/* ══════════════════════════════════════════════════════════
   PROGETTI / brevetti-style cards
══════════════════════════════════════════════════════════ */
#progetti{padding:120px 0;background:var(--bg-mid)}
.proj-grid{display:grid;grid-template-columns:1fr 1fr;gap:2px;background:rgba(42,159,214,.1)}
.proj-card{position:relative;overflow:hidden;cursor:pointer}
.proj-card .card-img{height:520px}
.proj-card .card-img img{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:100%;height:100%;object-fit:cover;transition:transform .8s}
.proj-card:hover .card-img img{transform:translate(-50%,-50%) scale(1.06)}
.proj-overlay{position:absolute;inset:0;z-index:2;background:linear-gradient(to top,rgba(6,11,15,.92) 0%,rgba(6,11,15,.45) 50%,rgba(6,11,15,.12) 100%);transition:background .4s}
.proj-card:hover .proj-overlay{background:linear-gradient(to top,rgba(6,11,15,.95) 0%,rgba(6,11,15,.65) 55%,rgba(6,11,15,.28) 100%)}
.proj-content{position:absolute;bottom:0;left:0;right:0;z-index:3;padding:44px 48px}
.proj-tag{font-family:var(--fc);font-size:.68rem;font-weight:600;letter-spacing:.28em;text-transform:uppercase;color:var(--a1);margin-bottom:10px}
.proj-content h3{font-family:var(--fd);font-size:2.4rem;font-weight:600;margin-bottom:12px;line-height:1.1;color:#f0f8ff}
.proj-content p{color:var(--fg-dim);font-size:.88rem;line-height:1.7;margin-bottom:24px;max-width:400px}
.proj-pills{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:28px}
.proj-pill{font-family:var(--fc);font-size:.68rem;font-weight:600;letter-spacing:.15em;text-transform:uppercase;padding:5px 12px;border:1px solid rgba(42,159,214,.4);color:var(--a1-lt);transition:var(--tr)}
.proj-card:hover .proj-pill{border-color:var(--a1);background:rgba(42,159,214,.12)}

/* ══════════════════════════════════════════════════════════
   CHI SIAMO (home)
══════════════════════════════════════════════════════════ */
#chi-siamo{padding:120px 0;background:var(--bg)}
.chi-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.chi-img{position:relative}
.chi-img .img-cover{height:560px;padding-bottom:0}
.chi-img::before{content:'';position:absolute;top:-18px;left:-18px;width:80px;height:80px;border-top:2px solid var(--a1);border-left:2px solid var(--a1);z-index:2;pointer-events:none}
.chi-img::after{content:'';position:absolute;bottom:-18px;right:-18px;width:80px;height:80px;border-bottom:2px solid var(--a1);border-right:2px solid var(--a1);z-index:2;pointer-events:none}
.chi-badge{position:absolute;bottom:36px;left:-28px;background:var(--a1);color:var(--bg);padding:20px 28px;z-index:3;text-align:center}
.chi-badge .bn{font-family:var(--fd);font-size:2.6rem;font-weight:700;line-height:1;display:block}
.chi-badge .bl{font-family:var(--fc);font-size:.62rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;display:block;margin-top:4px}

/* ══════════════════════════════════════════════════════════
   STEPS
══════════════════════════════════════════════════════════ */
#percorso{padding:120px 0;background:var(--bg-mid)}
.steps-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:rgba(42,159,214,.1)}
.step-card{background:var(--bg-mid);padding:48px 32px;transition:background .3s}
.step-card:hover{background:var(--bg-light)}
.step-num{font-family:var(--fd);font-size:5.5rem;font-weight:700;line-height:1;color:rgba(42,159,214,.1);margin-bottom:24px;transition:color .3s}
.step-card:hover .step-num{color:rgba(42,159,214,.22)}
.step-card h4{font-family:var(--fc);font-size:1rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;margin-bottom:12px}
.step-card p{font-size:.88rem;color:var(--fg-dim);line-height:1.7}

/* ══════════════════════════════════════════════════════════
   TESTIMONIANZE
══════════════════════════════════════════════════════════ */
#testimonianze{padding:120px 0;background:var(--bg);position:relative;overflow:hidden}
#testimonianze::before{content:'\201C';position:absolute;top:-80px;left:-20px;font-family:var(--fd);font-size:36rem;line-height:1;color:rgba(42,159,214,.025);pointer-events:none}
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;background:rgba(42,159,214,.08)}
.testi-card{background:var(--bg-mid);padding:44px 36px;display:flex;flex-direction:column;gap:20px;transition:background .3s}
.testi-card:hover{background:var(--bg-light)}
.testi-stars{color:var(--a1);font-size:1rem;letter-spacing:2px}
.testi-quote{font-family:var(--fd);font-size:1.15rem;font-style:italic;line-height:1.65;color:var(--fg);flex-grow:1}
.testi-author{padding-top:16px;border-top:1px solid rgba(42,159,214,.18)}
.testi-name{font-family:var(--fc);font-size:.82rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase}
.testi-role{font-size:.78rem;color:var(--a1);margin-top:3px}

/* ══════════════════════════════════════════════════════════
   CTA FINALE
══════════════════════════════════════════════════════════ */
#cta-finale{position:relative;padding:140px 0;overflow:hidden;text-align:center}
.cta-bg{position:absolute;inset:0}
.cta-bg img{width:100%;height:100%;object-fit:cover}
.cta-ov{position:absolute;inset:0;background:rgba(6,11,15,.82)}
.cta-content{position:relative;z-index:2}
.cta-content h2{font-family:var(--fd);font-size:clamp(2.8rem,5vw,5.2rem);font-weight:600;line-height:1.1;margin-bottom:20px;max-width:780px;margin-left:auto;margin-right:auto}
.cta-content h2 em{font-style:italic;color:var(--a1)}
.cta-content p{color:var(--fg-dim);font-size:1.05rem;max-width:480px;margin:0 auto 48px;line-height:1.75}
.cta-actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}

/* ══════════════════════════════════════════════════════════
   FAQ
══════════════════════════════════════════════════════════ */
#faq-section{padding:120px 0;background:var(--bg)}
.faq-list{max-width:860px;margin:0 auto;display:flex;flex-direction:column;gap:2px}
.faq-item{background:var(--bg-mid);border-left:2px solid transparent;transition:border-color .3s}
.faq-item.open{border-left-color:var(--a1)}
.faq-q{display:flex;justify-content:space-between;align-items:center;padding:24px 28px;cursor:pointer;gap:20px}
.faq-q h3{font-family:var(--fc);font-size:1rem;font-weight:600;letter-spacing:.06em;color:var(--fg);transition:color .3s}
.faq-item.open .faq-q h3{color:var(--a1)}
.faq-icon{width:20px;height:20px;flex-shrink:0;color:var(--a1);transition:transform .3s}
.faq-item.open .faq-icon{transform:rotate(45deg)}
.faq-a{display:none;padding:0 28px 24px;color:var(--fg-dim);font-size:.92rem;line-height:1.8}
.faq-item.open .faq-a{display:block}

/* ══════════════════════════════════════════════════════════
   FORM / CONTACT
══════════════════════════════════════════════════════════ */
.form-wrap{background:var(--bg-light);border:1px solid var(--b-card);padding:48px 44px;position:relative}
.form-wrap::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--a1),var(--a2))}
.form-row{margin-bottom:20px}
.form-row label{display:block;font-family:var(--fc);font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--fg-dim);margin-bottom:8px}
.form-row input,.form-row select,.form-row textarea{width:100%;background:var(--bg-mid);border:1px solid rgba(42,159,214,.2);color:var(--fg);font-family:var(--fb);font-size:.92rem;font-weight:300;padding:12px 16px;outline:none;transition:border-color .3s;-webkit-appearance:none}
.form-row input:focus,.form-row select:focus,.form-row textarea:focus{border-color:var(--a1)}
.form-row textarea{resize:vertical;min-height:120px}
.form-row select{cursor:pointer}
.form-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-consent{margin:16px 0 4px}
.form-consent label{display:flex;align-items:flex-start;gap:10px;font-size:.82rem;font-weight:300;color:var(--fg-dim);cursor:pointer;text-transform:none;letter-spacing:0}
.form-consent input[type=checkbox]{width:16px;height:16px;flex-shrink:0;accent-color:var(--a1);margin-top:2px}
.modal-link{color:var(--a1);cursor:pointer;text-decoration:underline;text-decoration-color:rgba(42,159,214,.4)}
.modal-link:hover{text-decoration-color:var(--a1)}
.form-note{font-size:.73rem;color:rgba(238,244,248,.3);margin-top:12px;line-height:1.6}
.hp-field{display:none!important}
.form-notice{font-family:var(--fc);font-size:.8rem;letter-spacing:.08em;padding:10px 14px;margin-top:12px;display:none}
.form-notice.ok{background:rgba(13,202,200,.1);border-left:2px solid var(--a2);color:var(--a2);display:block}
.form-notice.err{background:rgba(200,60,60,.1);border-left:2px solid #c83c3c;color:#e07070;display:block}

/* Upload field */
.form-upload{border:1px dashed rgba(42,159,214,.3);padding:20px;text-align:center;cursor:pointer;transition:border-color .3s;color:var(--fg-dim);font-size:.85rem}
.form-upload:hover{border-color:var(--a1)}

/* ══════════════════════════════════════════════════════════
   MODAL GDPR
══════════════════════════════════════════════════════════ */
.modal-ov{display:none;position:fixed;inset:0;z-index:9000;background:rgba(6,11,15,.9);backdrop-filter:blur(8px);align-items:center;justify-content:center}
.modal-ov.open{display:flex}
.modal-box{background:var(--bg-mid);border:1px solid var(--b-card);max-width:560px;width:90%;padding:48px 40px;position:relative;animation:fadeUp .3s ease}
.modal-box::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--a1),var(--a2))}
.modal-box h3{font-family:var(--fd);font-size:1.6rem;font-weight:600;margin-bottom:16px}
.modal-box p{color:var(--fg-dim);font-size:.88rem;line-height:1.75}
.modal-close{position:absolute;top:16px;right:20px;background:none;border:none;color:var(--fg-dim);font-size:1.6rem;cursor:pointer;transition:color .3s}
.modal-close:hover{color:var(--a1)}

/* ══════════════════════════════════════════════════════════
   LANDING
══════════════════════════════════════════════════════════ */
.landing-hero{min-height:100vh;display:flex;align-items:center;background:var(--bg);position:relative;overflow:hidden;padding:100px 0 60px}
.landing-hero::before{content:'';position:absolute;inset:0;background:url('/assets/img/hero-pool-resort.webp') center/cover no-repeat;opacity:.12}
.landing-hero-content{position:relative;z-index:1;max-width:640px}
.landing-kicker{font-family:var(--fc);font-size:.72rem;font-weight:600;letter-spacing:.35em;text-transform:uppercase;color:var(--a2);display:flex;align-items:center;gap:12px;margin-bottom:24px}
.landing-kicker::before{content:'';width:40px;height:1px;background:var(--a2)}
.landing-h1{font-family:var(--fd);font-size:clamp(2.8rem,6vw,6rem);font-weight:700;line-height:1.02;margin-bottom:24px}
.landing-h1 em{font-style:italic;color:var(--a1)}
.landing-sub{font-size:1.1rem;color:var(--fg-dim);line-height:1.8;margin-bottom:40px;max-width:520px}
.landing-proof{display:flex;gap:32px;flex-wrap:wrap;margin-top:48px;padding-top:32px;border-top:1px solid rgba(42,159,214,.2)}
.proof-item{display:flex;flex-direction:column;gap:4px}
.proof-num{font-family:var(--fd);font-size:2.4rem;font-weight:600;color:var(--a1);line-height:1}
.proof-lbl{font-family:var(--fc);font-size:.7rem;letter-spacing:.15em;text-transform:uppercase;color:var(--fg-dim)}

.landing-form-col{background:var(--bg-mid);padding:48px 44px;border:1px solid var(--b-card);position:relative}
.landing-form-col::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--a1),var(--a2))}
.landing-form-col h2{font-family:var(--fd);font-size:2rem;font-weight:600;margin-bottom:8px;line-height:1.15}
.landing-form-col h2 em{font-style:italic;color:var(--a1)}
.landing-form-col .sub{color:var(--fg-dim);font-size:.88rem;margin-bottom:28px}

.urgency-bar{background:var(--a1-dk);padding:12px 0;text-align:center}
.urgency-bar p{font-family:var(--fc);font-size:.8rem;font-weight:600;letter-spacing:.15em;text-transform:uppercase;color:var(--fg)}
.urgency-bar span{color:var(--a2)}

.benefits-strip{padding:80px 0;background:var(--bg-mid)}
.benefits-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--b-card)}
.benefit-item{background:var(--bg-mid);padding:40px 32px;text-align:center}
.benefit-icon{width:40px;height:40px;color:var(--a1);margin:0 auto 16px}
.benefit-item h3{font-family:var(--fc);font-size:.9rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;margin-bottom:8px}
.benefit-item p{color:var(--fg-dim);font-size:.82rem;line-height:1.65}

.social-proof-strip{padding:80px 0;background:var(--bg)}
.logo-strip{display:flex;align-items:center;justify-content:center;gap:48px;flex-wrap:wrap;opacity:.45;filter:brightness(0) invert(1)}

/* ══════════════════════════════════════════════════════════
   FOOTER
══════════════════════════════════════════════════════════ */
#site-footer{background:var(--bg-mid);border-top:1px solid var(--b-sub);padding:80px 0 0}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:56px;padding-bottom:60px;border-bottom:1px solid rgba(238,244,248,.06)}
.fb-logo{display:flex;align-items:center;gap:10px;margin-bottom:16px}
.fb-logo img{height:36px}
.fb-logo-main{font-family:var(--fc);font-size:1.3rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase}
.fb-logo-main span{color:var(--a1)}
.fb-sub{font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;color:var(--fg-dim);display:block;margin-top:3px}
.footer-brand p{font-size:.85rem;color:var(--fg-dim);line-height:1.75;margin-bottom:24px}
.footer-social{display:flex;gap:10px}
.social-link{width:36px;height:36px;border:1px solid rgba(42,159,214,.25);display:flex;align-items:center;justify-content:center;color:var(--fg-dim);transition:var(--tr)}
.social-link:hover{border-color:var(--a1);color:var(--a1);background:rgba(42,159,214,.08)}
.social-link svg{width:16px;height:16px}
.footer-col h4{font-family:var(--fc);font-size:.7rem;font-weight:600;letter-spacing:.24em;text-transform:uppercase;color:var(--a1);margin-bottom:18px;padding-bottom:12px;border-bottom:1px solid rgba(42,159,214,.2)}
.footer-col ul{display:flex;flex-direction:column;gap:10px}
.footer-col ul a{font-size:.85rem;color:var(--fg-dim);transition:color .3s,padding-left .3s;display:block}
.footer-col ul a:hover{color:var(--a1);padding-left:6px}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding:24px 0;flex-wrap:wrap;gap:12px}
.footer-legal{font-size:.72rem;color:rgba(238,244,248,.28);line-height:1.6}
.footer-links-bottom{display:flex;gap:24px;flex-wrap:wrap}
.footer-links-bottom a{font-family:var(--fc);font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;color:rgba(238,244,248,.32);transition:color .3s}
.footer-links-bottom a:hover{color:var(--a1)}

.spec-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:32px}
.tri-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;background:var(--b-card);margin-top:32px}
@media(max-width:768px){
  .spec-grid{grid-template-columns:1fr}
  .tri-grid{grid-template-columns:1fr}
  .contatti-sedi{grid-template-columns:1fr!important}
  .contatti-bottom{grid-template-columns:1fr!important}
}

/* WhatsApp Float */
#wa-float{position:fixed;bottom:32px;right:32px;z-index:900;width:60px;height:60px;background:#25D366;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 32px rgba(37,211,102,.4);transition:transform .3s,box-shadow .3s;color:#fff}
#wa-float:hover{transform:translateY(-4px) scale(1.05);box-shadow:0 16px 48px rgba(37,211,102,.55)}
#wa-float svg{width:30px;height:30px}
.wa-tip{position:absolute;right:72px;top:50%;transform:translateY(-50%);background:var(--bg-mid);border:1px solid rgba(37,211,102,.3);color:var(--fg);font-family:var(--fc);font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;padding:8px 14px;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .3s;border-radius:2px}
#wa-float:hover .wa-tip{opacity:1}

/* ══════════════════════════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════════════════════════ */
@media(max-width:1100px){
  .footer-grid{grid-template-columns:1fr 1fr;gap:40px}
  .content-layout{grid-template-columns:1fr;gap:48px}
  .perche-header{grid-template-columns:1fr;gap:28px}
}
@media(max-width:900px){
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .steps-grid{grid-template-columns:repeat(2,1fr)}
  .card-grid-3{grid-template-columns:1fr 1fr}
  .testi-grid{grid-template-columns:1fr 1fr}
  .proj-grid{grid-template-columns:1fr}
  .chi-grid{grid-template-columns:1fr}
  .benefits-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:768px){
  .main-nav,.header-cta .btn{display:none}
  .hamburger{display:flex}
  .footer-grid{grid-template-columns:1fr;gap:32px}
  .footer-bottom{flex-direction:column;align-items:flex-start}
  .hero-actions{flex-direction:column}
  .card-grid-3,.card-grid-2,.testi-grid,.cards-3{grid-template-columns:1fr}
  .steps-grid{grid-template-columns:1fr}
  .form-grid-2{grid-template-columns:1fr}
  .chi-badge{left:0}
  .landing-proof{gap:20px}
  #wa-float{bottom:20px;right:20px}
  .proj-card .card-img{height:400px}
}
@media(max-width:480px){
  .stats-grid{grid-template-columns:1fr 1fr}
  .stat-item{padding:36px 20px}
  .steps-grid{grid-template-columns:1fr}
  .benefits-grid{grid-template-columns:1fr}
  .cta-actions{flex-direction:column;align-items:center}
}
@media(hover:none),(pointer:coarse){
  *{cursor:auto!important}
  .cb-tip{display:none}
}