/* ── RESET ──────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-tap-highlight-color:transparent}
body{font-family:'Inter',sans-serif;color:var(--black);background:var(--white);overflow-x:hidden;padding-bottom:64px}
img{max-width:100%;display:block;object-fit:cover}
a{text-decoration:none;color:inherit}
button{border:none;cursor:pointer;font-family:'Inter',sans-serif}

/* ── TOKENS ─────────────────────────────── */
:root{
  --red:#D42B1E;
  --black:#1A1A1A;
  --white:#FFFFFF;
  --teal:#2a7a6e;
  --orange:#f26522;
  --gray:#F5F4F2;
  --muted:#7A7A7A;
  --border:#E5E3DF;
  --hero-bg:#111110;
  --r:16px;
}
[data-vibe="lifestyle"]{--red:#f26522;--teal:#2a7a6e;--hero-bg:#0d1f1c}
[data-vibe="notte"] body{background:#0f0f0f;color:#e8e8e8}
[data-vibe="notte"]{--gray:#1a1a1a;--white:#171717;--border:#2a2a2a;--muted:#888;--black:#e8e8e8}

/* ── TYPE ───────────────────────────────── */
.d{font-family:'Oswald',sans-serif;font-weight:700;text-transform:uppercase;line-height:1;letter-spacing:-0.01em}
.tag{font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--red);display:block;margin-bottom:8px}
h2{font-family:'Oswald',sans-serif;font-weight:700;text-transform:uppercase;line-height:1.05;font-size:clamp(28px,7vw,52px)}
h3{font-family:'Oswald',sans-serif;font-weight:600;text-transform:uppercase;font-size:20px;line-height:1.1}

/* ── SECTION BASE ───────────────────────── */
.sec{padding:64px 24px}
.sec-sm{padding:48px 24px}
.sec-hdr{margin-bottom:32px}

/* ── BUTTONS ────────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:8px;padding:14px 24px;border-radius:50px;font-weight:700;font-size:14px;letter-spacing:.04em;text-transform:uppercase;transition:transform .2s,box-shadow .2s;cursor:pointer}
.btn:active{transform:scale(.97)}
.btn-red{background:var(--red);color:#fff}
.btn-red:hover{box-shadow:0 6px 20px rgba(212,43,30,.4)}
.btn-outline{background:transparent;color:#fff;border:2px solid rgba(255,255,255,.5)}
.btn-outline:hover{border-color:#fff;background:rgba(255,255,255,.08)}
.btn-dark{background:var(--black);color:#fff}
.btn-dark:hover{background:#333}
.btn-ghost{background:transparent;color:var(--red);border:2px solid var(--red)}
.btn-ghost:hover{background:var(--red);color:#fff}

/* ── ANIMATE ────────────────────────────── */
[data-ani]{opacity:0;transform:translateY(36px);transition:opacity .65s ease,transform .65s ease}
[data-ani].in{opacity:1;transform:none}
[data-ani-d="1"]{transition-delay:.1s}
[data-ani-d="2"]{transition-delay:.2s}
[data-ani-d="3"]{transition-delay:.3s}
[data-ani-d="4"]{transition-delay:.4s}
[data-ani-d="5"]{transition-delay:.5s}

/* ═══════════════════════════════════════════
   NAV
═══════════════════════════════════════════ */
#nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:0 20px;height:60px;display:flex;align-items:center;justify-content:space-between;transition:background .3s,backdrop-filter .3s}
#nav.scrolled{background:rgba(17,17,16,.92);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px)}
#nav .logo{height:28px;filter:brightness(0) invert(1)}
#nav .logo-icon{height:36px;width:auto;filter:brightness(0) invert(1);flex-shrink:0}
.footer-logo-icon{height:32px;width:32px;filter:brightness(0) invert(1);opacity:.7;margin-right:10px;vertical-align:middle}
footer img{vertical-align:middle}
#nav-right{display:flex;align-items:center;gap:16px}
.lang-btn{font-size:12px;font-weight:700;letter-spacing:.08em;color:rgba(255,255,255,.7);background:none;border:none;cursor:pointer;transition:color .2s;padding:4px}
.lang-btn.active{color:#fff}
.hamburger{width:32px;height:32px;display:flex;flex-direction:column;justify-content:center;gap:6px;cursor:pointer;background:none;border:none}
.hamburger span{display:block;height:2px;background:#fff;border-radius:2px;transition:transform .3s,opacity .3s,width .3s}

/* MENU OVERLAY */
#menu-overlay{position:fixed;inset:0;z-index:99;background:var(--hero-bg);display:flex;flex-direction:column;padding:80px 32px 40px;opacity:0;pointer-events:none;transition:opacity .3s}
#menu-overlay.open{opacity:1;pointer-events:all}
.menu-nav-item{font-family:'Oswald',sans-serif;font-size:clamp(32px,9vw,48px);font-weight:700;text-transform:uppercase;color:#fff;padding:12px 0;border-bottom:1px solid rgba(255,255,255,.1);display:block;transition:color .2s,padding-left .2s}
.menu-nav-item:hover{color:var(--red);padding-left:12px}
.menu-footer{margin-top:auto;display:flex;gap:20px;font-size:13px;color:rgba(255,255,255,.5)}

/* ═══════════════════════════════════════════
   HERO
═══════════════════════════════════════════ */
#hero{min-height:100svh;background:var(--hero-bg);position:relative;display:flex;flex-direction:column;justify-content:flex-end;padding:40px 24px 100px;overflow:hidden}

/* wind lines */
#wind-svg{position:absolute;inset:0;width:100%;height:100%;pointer-events:none}
.wind-line{stroke:var(--red);stroke-width:1.5;fill:none;stroke-linecap:round;stroke-dasharray:120 900;animation:windFlow 4s ease-in-out infinite;opacity:0}
@keyframes windFlow{0%{stroke-dashoffset:1000;opacity:0}15%{opacity:.5}70%{opacity:.25}100%{stroke-dashoffset:-200;opacity:0}}
.wl-1{animation-delay:0s}
.wl-2{animation-delay:.6s;stroke:var(--orange);stroke-width:1}
.wl-3{animation-delay:1.2s;stroke-width:.8;stroke:rgba(255,255,255,.3)}
.wl-4{animation-delay:1.8s;stroke-width:1.2}
.wl-5{animation-delay:2.4s;stroke:var(--orange);stroke-width:.6}
.wl-6{animation-delay:0.3s;stroke-width:.5;stroke:rgba(255,255,255,.2)}

/* bg photo overlay */
#hero-bg-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.22;mix-blend-mode:luminosity}

/* kite silhouette */
#hero-kite{position:absolute;top:10%;right:-10px;width:min(220px,55vw);opacity:.15;filter:invert(1);animation:kiteFloat 7s ease-in-out infinite;transform-origin:center}
@keyframes kiteFloat{0%,100%{transform:translateY(0) rotate(-3deg)}50%{transform:translateY(-18px) rotate(3deg)}}

/* hero content */
.hero-eyebrow{font-size:12px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--red);margin-bottom:16px;display:block}
.hero-h1{font-family:'Oswald',sans-serif;font-weight:700;text-transform:uppercase;line-height:.95;font-size:clamp(56px,16vw,96px);color:#fff;margin-bottom:16px;letter-spacing:-0.02em}
.hero-sub{font-size:16px;color:rgba(255,255,255,.7);margin-bottom:32px;line-height:1.5;max-width:320px}
.hero-ctas{display:flex;gap:12px;flex-wrap:wrap}
.hero-scroll{position:absolute;bottom:80px;right:24px;display:flex;flex-direction:column;align-items:center;gap:8px;color:rgba(255,255,255,.4);font-size:10px;font-weight:600;letter-spacing:.1em;text-transform:uppercase}
.hero-scroll::after{content:'';display:block;width:1px;height:40px;background:rgba(255,255,255,.2);animation:scrollPulse 2s ease-in-out infinite}
@keyframes scrollPulse{0%,100%{transform:scaleY(1);opacity:.4}50%{transform:scaleY(1.3);opacity:.8}}

/* ═══════════════════════════════════════════
   TICKER
═══════════════════════════════════════════ */
#ticker{background:var(--red);padding:14px 0;overflow:hidden;white-space:nowrap}
.ticker-track{display:inline-flex;gap:0;animation:tick 22s linear infinite}
.ticker-item{font-size:12px;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:#fff;padding:0 32px}
.ticker-dot{color:rgba(255,255,255,.5)}

/* ═══════════════════════════════════════════
   CORSI
═══════════════════════════════════════════ */
#corsi{background:var(--white);padding:64px 0}
#corsi .sec-hdr{padding:0 24px}
.scroll-track{display:flex;gap:16px;overflow-x:auto;padding:0 24px 16px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.scroll-track::-webkit-scrollbar{display:none}
.corso-card{flex:0 0 260px;scroll-snap-align:start;border-radius:var(--r);overflow:hidden;background:var(--gray);position:relative}
.corso-img{width:100%;height:200px;object-fit:cover;transition:transform .5s ease}
.corso-card:hover .corso-img{transform:scale(1.04)}
.corso-body{padding:20px}
.corso-type{font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--red);margin-bottom:4px}
.corso-name{font-family:'Oswald',sans-serif;font-weight:700;font-size:22px;text-transform:uppercase;margin-bottom:6px;line-height:1.1}
.corso-desc{font-size:13px;color:var(--muted);line-height:1.5}
.corso-pill{display:inline-flex;align-items:center;gap:4px;background:var(--red);color:#fff;font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:5px 12px;border-radius:50px;margin-top:12px}

/* ═══════════════════════════════════════════
   LIFT
═══════════════════════════════════════════ */
#lift{background:var(--hero-bg);position:relative;overflow:hidden;padding:80px 24px}
#lift-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.3;mix-blend-mode:luminosity}
#lift .content{position:relative;z-index:1}
#lift .tag{color:rgba(255,255,255,.5)}
#lift h2{color:#fff;font-size:clamp(36px,10vw,72px)}
.lift-desc{font-size:16px;color:rgba(255,255,255,.75);line-height:1.65;margin:20px 0 32px;max-width:400px}
.lift-feat{display:flex;flex-direction:column;gap:16px;margin-bottom:40px}
.lift-feat-item{display:flex;align-items:center;gap:14px;color:#fff}
.lift-feat-icon{width:36px;height:36px;border-radius:50%;border:2px solid var(--red);display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}
.lift-feat-text{font-size:14px;font-weight:500;color:rgba(255,255,255,.8)}

/* ═══════════════════════════════════════════
   CHI SIAMO
═══════════════════════════════════════════ */
#chi-siamo{background:var(--gray)}
.chi-text{font-size:16px;line-height:1.75;color:var(--muted);margin:16px 0 28px}
.chi-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;margin-top:32px}
.chi-stat{background:var(--white);padding:20px 12px;text-align:center;border-radius:var(--r)}
.chi-stat-num{font-family:'Oswald',sans-serif;font-size:32px;font-weight:700;color:var(--red);line-height:1;display:block}
.chi-stat-label{font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);margin-top:4px}
.chi-img{width:100%;height:240px;object-fit:cover;border-radius:var(--r);margin-top:32px}

/* ═══════════════════════════════════════════
   ISTRUTTORI
═══════════════════════════════════════════ */
#istruttori{background:var(--white)}
.staff-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-top:32px}
.staff-card{border-radius:var(--r);overflow:hidden;background:var(--gray);position:relative}
.staff-img{width:100%;height:180px;object-fit:cover;object-position:top}
.staff-body{padding:14px}
.staff-name{font-family:'Oswald',sans-serif;font-size:18px;font-weight:700;text-transform:uppercase;margin-bottom:2px}
.staff-role{font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--red)}
.staff-fiv{display:inline-block;margin-top:8px;font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;background:var(--red);color:#fff;padding:3px 8px;border-radius:50px}

/* ═══════════════════════════════════════════
   ATTREZZATURA
═══════════════════════════════════════════ */
#attrezzatura{background:var(--red)}
#attrezzatura .tag{color:rgba(255,255,255,.7)}
#attrezzatura h2{color:#fff}
.gear-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:28px}
.gear-item{background:rgba(255,255,255,.12);border-radius:var(--r);padding:20px 16px;backdrop-filter:blur(8px)}
.gear-item-icon{font-size:24px;margin-bottom:10px}
.gear-item-title{font-family:'Oswald',sans-serif;font-size:17px;font-weight:700;text-transform:uppercase;color:#fff;margin-bottom:4px}
.gear-item-desc{font-size:12px;color:rgba(255,255,255,.7);line-height:1.5}
.gear-item.full{grid-column:1/-1}

/* ═══════════════════════════════════════════
   GALLERY
═══════════════════════════════════════════ */
#gallery{background:var(--hero-bg);padding:64px 0}
#gallery .sec-hdr{padding:0 24px}
#gallery .tag{color:rgba(255,255,255,.5)}
#gallery h2{color:#fff}
.gallery-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:4px;margin-top:28px}
.gallery-img{aspect-ratio:1;object-fit:cover;width:100%;transition:opacity .3s;cursor:pointer}
.gallery-img:hover{opacity:.8}
.gallery-img.tall{aspect-ratio:.7;grid-row:span 2}

/* ═══════════════════════════════════════════
   DOVE SIAMO
═══════════════════════════════════════════ */
#dove-siamo{background:var(--white)}
.map-embed{width:100%;height:280px;border-radius:var(--r);overflow:hidden;border:none;margin-top:28px}
.info-card{background:var(--gray);border-radius:var(--r);padding:24px;margin-top:16px;display:flex;flex-direction:column;gap:14px}
.info-row{display:flex;align-items:flex-start;gap:14px}
.info-icon{width:36px;height:36px;border-radius:50%;background:var(--red);display:flex;align-items:center;justify-content:center;color:#fff;font-size:14px;flex-shrink:0}
.info-text{font-size:14px;color:var(--black);line-height:1.5}
.info-text strong{display:block;font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:2px}

/* ═══════════════════════════════════════════
   BLOG
═══════════════════════════════════════════ */
#blog{background:var(--gray)}
.blog-cards{display:flex;flex-direction:column;gap:16px;margin-top:28px}
.blog-card{background:var(--white);border-radius:var(--r);overflow:hidden;display:flex;gap:0}
.blog-card-img{width:120px;height:120px;object-fit:cover;flex-shrink:0}
.blog-card-body{padding:16px}
.blog-date{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:6px}
.blog-title{font-family:'Oswald',sans-serif;font-size:17px;font-weight:700;text-transform:uppercase;line-height:1.2;margin-bottom:6px}
.blog-excerpt{font-size:12px;color:var(--muted);line-height:1.5}

/* ═══════════════════════════════════════════
   CONTATTI
═══════════════════════════════════════════ */
#contatti{background:var(--hero-bg);padding:80px 24px}
#contatti .tag{color:rgba(255,255,255,.5)}
#contatti h2{color:#fff;margin-bottom:16px}
.contatti-sub{font-size:16px;color:rgba(255,255,255,.6);line-height:1.65;margin-bottom:40px}
.contatti-wa{display:flex;align-items:center;gap:14px;background:#25D366;color:#fff;border-radius:var(--r);padding:20px 24px;font-weight:700;font-size:16px;margin-bottom:16px;transition:transform .2s;text-decoration:none}
.contatti-wa:active{transform:scale(.98)}
.contatti-wa svg{width:28px;height:28px;flex-shrink:0}
.contatti-email{display:flex;align-items:center;gap:14px;background:rgba(255,255,255,.08);color:#fff;border-radius:var(--r);padding:18px 24px;font-size:15px;margin-bottom:32px;font-weight:500;border:1px solid rgba(255,255,255,.1)}
.social-row{display:flex;gap:16px}
.social-btn{width:44px;height:44px;border-radius:50%;background:rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;color:#fff;font-size:14px;font-weight:700;transition:background .2s;border:1px solid rgba(255,255,255,.1);text-align:center;line-height:44px}
.social-btn:hover{background:var(--red);border-color:var(--red)}

/* ═══════════════════════════════════════════
   FOOTER
═══════════════════════════════════════════ */
footer{background:#000;padding:32px 24px;text-align:center}
footer img{height:24px;margin:0 auto 16px;filter:brightness(0) invert(1);opacity:.7}
footer p{font-size:12px;color:rgba(255,255,255,.35);line-height:1.7}

/* ═══════════════════════════════════════════
   BOTTOM NAV
═══════════════════════════════════════════ */
#bottom-nav{position:fixed;bottom:0;left:0;right:0;z-index:98;background:rgba(17,17,16,.92);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:1px solid rgba(255,255,255,.08);display:flex;height:64px;align-items:stretch;padding-bottom:env(safe-area-inset-bottom)}
.bnav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;color:rgba(255,255,255,.4);font-size:10px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;cursor:pointer;transition:color .2s;border:none;background:none}
.bnav-item:active{transform:scale(.9)}
.bnav-item.active{color:var(--red)}
.bnav-icon{font-size:20px;line-height:1}

/* ═══════════════════════════════════════════
   TWEAKS PANEL (design tool only)
═══════════════════════════════════════════ */
#tweaks-panel{display:none;position:fixed;bottom:76px;right:16px;z-index:200;background:#1a1a1a;border:1px solid rgba(255,255,255,.12);border-radius:20px;padding:20px;min-width:220px;box-shadow:0 20px 60px rgba(0,0,0,.5)}
#tweaks-panel .tw-title{font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#fff;margin-bottom:16px}
.tw-group{margin-bottom:16px}
.tw-label{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.4);margin-bottom:8px}
.tw-opts{display:flex;gap:6px;flex-wrap:wrap}
.tw-btn{padding:6px 12px;border-radius:50px;font-size:12px;font-weight:700;background:rgba(255,255,255,.08);color:rgba(255,255,255,.6);border:1px solid rgba(255,255,255,.1);cursor:pointer;transition:all .2s}
.tw-btn.active{background:var(--red);color:#fff;border-color:var(--red)}

/* ── TICKER ANIMATION ── */
@keyframes tick{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ═══════════════════════════════════════════
   UTILITY / LAYOUT
═══════════════════════════════════════════ */
.hero-content{position:relative;z-index:1}

.scroll-label{padding:0 24px;margin-bottom:12px}
.scroll-label+.scroll-track+.scroll-label{margin-top:24px}
.scroll-label-text{font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}

.section-cta{padding:0 24px;margin-top:32px}
.section-cta-center{display:flex;gap:12px;flex-wrap:wrap;margin-top:32px;padding:0 24px}

.staff-cta-card{display:flex;align-items:center;justify-content:center;background:var(--red);min-height:200px;border-radius:var(--r);padding:20px;text-align:center;color:#fff}
.staff-cta-title{font-family:'Oswald',sans-serif;font-size:28px;font-weight:700;text-transform:uppercase;margin-bottom:8px}
.staff-cta-sub{font-size:12px;opacity:.8}

/* ── PREVIEW SECTION — chi-siamo home ── */
.preview-text{font-size:15px;line-height:1.7;color:var(--muted);margin:16px 0 24px}

/* ── GALLERY PREVIEW ── */
.gallery-preview-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:4px;margin-top:28px}
.gallery-preview-img{aspect-ratio:1;object-fit:cover;width:100%;transition:opacity .3s}
.gallery-preview-img:hover{opacity:.8}

/* ── LANG LINK (nav) ── */
a.lang-btn{display:inline-block}

/* ── NAV LOGO LINK ── */
.nav-logo-link{display:flex;align-items:center}

/* ── SECTION HEADER WITH TOP PADDING ── */
.sec-hdr-padded{padding:64px 24px 0}

/* ═══════════════════════════════════════════
   PAGE HERO (inner pages)
═══════════════════════════════════════════ */
.page-hero{background:var(--hero-bg);padding:120px 24px 64px;position:relative;overflow:hidden}
.page-hero .tag{color:rgba(255,255,255,.5)}
.page-hero-h1{font-family:'Oswald',sans-serif;font-weight:700;text-transform:uppercase;line-height:.95;font-size:clamp(44px,12vw,80px);color:#fff;margin-bottom:16px;letter-spacing:-.02em}
.page-hero-sub{font-size:16px;color:rgba(255,255,255,.7);line-height:1.6;max-width:380px;margin-bottom:32px}
.page-hero-kite{position:absolute;top:10%;right:-20px;width:min(180px,44vw);opacity:.1;filter:invert(1);animation:kiteFloat 7s ease-in-out infinite;transform-origin:center}
.page-hero-wind{position:absolute;inset:0;width:100%;height:100%;pointer-events:none}

/* ═══════════════════════════════════════════
   CORSO DETAIL CARD
═══════════════════════════════════════════ */
.corso-detail-card{border-radius:var(--r);overflow:hidden;background:var(--gray);margin-bottom:20px}
.corso-detail-img{width:100%;height:220px;object-fit:cover;transition:transform .5s ease}
.corso-detail-card:hover .corso-detail-img{transform:scale(1.03)}
.corso-detail-body{padding:24px}
.corso-detail-name{font-family:'Oswald',sans-serif;font-size:28px;font-weight:700;text-transform:uppercase;line-height:1.05;margin-bottom:10px}
.corso-detail-pills{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}
.corso-detail-pill{display:inline-flex;align-items:center;gap:4px;background:var(--red);color:#fff;font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:5px 14px;border-radius:50px}
.corso-detail-pill.pill-outline{background:transparent;color:var(--red);border:1.5px solid var(--red)}
.corso-detail-desc{font-size:15px;color:var(--muted);line-height:1.7;margin-bottom:20px}
.corso-detail-list{list-style:none;display:flex;flex-direction:column;gap:8px;margin-bottom:24px}
.corso-detail-list li{font-size:14px;color:var(--black);padding-left:22px;position:relative;line-height:1.5}
.corso-detail-list li::before{content:'✓';position:absolute;left:0;color:var(--red);font-weight:700}

/* ═══════════════════════════════════════════
   PROGRESSIONE STEPS
═══════════════════════════════════════════ */
.prog-steps{display:flex;flex-direction:column;gap:0;margin-top:32px}
.prog-step{display:flex;gap:18px;padding-bottom:36px;position:relative}
.prog-step:not(:last-child)::before{content:'';position:absolute;left:17px;top:40px;bottom:0;width:2px;background:var(--border)}
.prog-step-num{width:36px;height:36px;border-radius:50%;background:var(--red);color:#fff;font-family:'Oswald',sans-serif;font-size:16px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;position:relative;z-index:1}
.prog-step-content{padding-top:5px}
.prog-step-title{font-family:'Oswald',sans-serif;font-size:18px;font-weight:700;text-transform:uppercase;margin-bottom:4px;line-height:1.1}
.prog-step-desc{font-size:14px;color:var(--muted);line-height:1.6}

/* ═══════════════════════════════════════════
   REQUISITI
═══════════════════════════════════════════ */
.req-grid{display:flex;flex-direction:column;gap:12px;margin-top:28px}
.req-item{display:flex;align-items:flex-start;gap:14px;background:var(--white);border-radius:var(--r);padding:18px}
.req-icon{width:40px;height:40px;border-radius:50%;background:var(--gray);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.req-body{}
.req-body strong{display:block;font-size:13px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;margin-bottom:3px}
.req-body span{font-size:14px;color:var(--muted);line-height:1.5}

/* ── BG VARIANTS ── */
.sec-gray{background:var(--gray)}
.sec-dark{background:var(--hero-bg)}

/* ── CONTATTI WA INNER TEXT ── */
.contatti-wa-label{font-size:12px;opacity:.8;font-weight:500}
.contatti-wa-num{font-size:17px}

/* ═══════════════════════════════════════════
   SECTION COLOUR VARIANTS (generic classes)
═══════════════════════════════════════════ */
.sec-dark .tag{color:rgba(255,255,255,.5)}
.sec-dark h2{color:#fff}
.sec-dark p{color:rgba(255,255,255,.7)}
.sec-red{background:var(--red)}
.sec-red .tag{color:rgba(255,255,255,.7)}
.sec-red h2{color:#fff}

/* ═══════════════════════════════════════════
   LIFT PACKAGES
═══════════════════════════════════════════ */
.pack-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:28px}
.pack-card{background:var(--white);border-radius:var(--r);padding:22px 14px 20px;border:1.5px solid var(--border);position:relative;text-align:center;display:flex;flex-direction:column;align-items:center}
.pack-card.featured{border-color:var(--red);background:#fff8f7}
.pack-badge{position:absolute;top:-11px;left:50%;transform:translateX(-50%);background:var(--red);color:#fff;font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:3px 12px;border-radius:50px;white-space:nowrap}
.pack-qty{font-family:'Oswald',sans-serif;font-size:42px;font-weight:700;color:var(--red);line-height:1}
.pack-qty-label{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:6px;display:block}
.pack-name{font-family:'Oswald',sans-serif;font-size:13px;font-weight:700;text-transform:uppercase;color:var(--black);margin:4px 0 2px;line-height:1.1}
.pack-price{font-size:24px;font-weight:800;color:var(--black);line-height:1;margin-bottom:2px}
.pack-price-per{font-size:11px;color:var(--muted);margin-bottom:8px;display:block}
.pack-saving{font-size:11px;color:var(--red);font-weight:700;display:block;margin-bottom:12px}
.pack-seasonal-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:0}
.pack-card-seasonal{background:var(--gray);border-radius:var(--r);padding:20px;display:flex;align-items:center;gap:16px;border:1.5px solid var(--border)}
.pack-seasonal-num{font-family:'Oswald',sans-serif;font-size:32px;font-weight:700;color:var(--red);line-height:1;flex-shrink:0}
.pack-seasonal-info{}
.pack-seasonal-name{font-family:'Oswald',sans-serif;font-size:14px;font-weight:700;text-transform:uppercase;margin-bottom:2px}
.pack-seasonal-desc{font-size:12px;color:var(--muted);line-height:1.4}
.pack-quota-note{font-size:12px;color:var(--muted);text-align:center;margin-top:16px;padding:12px 16px;background:var(--gray);border-radius:var(--r)}
.pack-quota-note strong{color:var(--black)}

/* ═══════════════════════════════════════════
   KATAPULTA SECTION
═══════════════════════════════════════════ */
.kata-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin:28px 0}
.kata-stat{background:rgba(255,255,255,.06);border-radius:var(--r);padding:16px 10px;text-align:center;border:1px solid rgba(255,255,255,.08)}
.kata-stat-num{font-family:'Oswald',sans-serif;font-size:28px;font-weight:700;color:var(--red);line-height:1;display:block}
.kata-stat-label{font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.4);margin-top:4px;display:block}
.kata-feats{display:flex;flex-direction:column;gap:14px;margin-top:4px}
.kata-feat{display:flex;align-items:flex-start;gap:14px;padding:14px;background:rgba(255,255,255,.05);border-radius:12px;border:1px solid rgba(255,255,255,.07)}
.kata-feat-icon{font-size:22px;flex-shrink:0;width:36px;text-align:center;padding-top:1px}
.kata-feat-body strong{display:block;font-size:13px;font-weight:700;color:#fff;margin-bottom:3px;letter-spacing:.02em}
.kata-feat-body span{font-size:13px;color:rgba(255,255,255,.55);line-height:1.5}

/* ═══════════════════════════════════════════
   WIND INFO (vento section)
═══════════════════════════════════════════ */
.wind-info-grid{display:flex;flex-direction:column;gap:10px;margin-top:24px}
.wind-info-item{display:flex;align-items:flex-start;gap:14px;padding:16px;background:rgba(255,255,255,.05);border-radius:var(--r);border:1px solid rgba(255,255,255,.08)}
.wind-info-icon{font-size:22px;flex-shrink:0;width:36px;text-align:center;padding-top:2px}
.wind-info-body strong{display:block;font-family:'Oswald',sans-serif;font-size:16px;font-weight:700;text-transform:uppercase;color:#fff;margin-bottom:3px}
.wind-info-body span{font-size:13px;color:rgba(255,255,255,.6);line-height:1.5;display:block}

/* ═══════════════════════════════════════════
   CHI SIAMO / ABOUT PAGE
═══════════════════════════════════════════ */
/* Team lead card */
.team-lead{background:var(--white);border-radius:var(--r);padding:24px;margin-bottom:16px;border-left:4px solid var(--red)}
.team-lead-name{font-family:'Oswald',sans-serif;font-size:26px;font-weight:700;text-transform:uppercase;margin-bottom:4px}
.team-lead-role{font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--red);display:block;margin-bottom:10px}
.team-lead-desc{font-size:14px;color:var(--muted);line-height:1.7}
.fiv-badge{display:inline-flex;align-items:center;gap:6px;background:var(--red);color:#fff;font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:4px 12px;border-radius:50px;margin-top:10px}
/* Team groups */
.team-groups{display:flex;flex-direction:column;gap:10px}
.team-group{background:var(--white);border-radius:var(--r);padding:14px 18px}
.team-group-label{font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--red);display:block;margin-bottom:5px}
.team-names{font-family:'Oswald',sans-serif;font-size:16px;font-weight:600;text-transform:uppercase;color:var(--black);line-height:1.5}

/* USP items on light background */
.usp-grid{display:flex;flex-direction:column;gap:14px;margin-top:28px}
.usp-item{display:flex;align-items:flex-start;gap:16px;background:var(--gray);border-radius:var(--r);padding:20px 18px}
.usp-icon{font-size:26px;flex-shrink:0;width:40px;text-align:center;padding-top:2px}
.usp-body strong{display:block;font-family:'Oswald',sans-serif;font-size:16px;font-weight:700;text-transform:uppercase;color:var(--black);margin-bottom:4px}
.usp-body span{font-size:14px;color:var(--muted);line-height:1.6;display:block}

/* Prog-steps on dark background */
.sec-dark .prog-step-title{color:#fff}
.sec-dark .prog-step-desc{color:rgba(255,255,255,.6)}
.sec-dark .prog-step:not(:last-child)::before{background:rgba(255,255,255,.15)}

/* ═══════════════════════════════════════════
   GALLERY PAGE
═══════════════════════════════════════════ */
.gal-sec{padding:40px 0 0}
.gal-sec:last-of-type{padding-bottom:48px}
.gal-sec-hdr{padding:0 24px 14px;display:flex;align-items:baseline;gap:10px}
.gal-sec-title{font-family:'Oswald',sans-serif;font-size:18px;font-weight:700;text-transform:uppercase;color:var(--black)}
.gal-sec-count{font-size:11px;font-weight:700;letter-spacing:.06em;color:var(--muted)}
.gallery-ig-cta{background:var(--hero-bg);margin:40px 24px 0;border-radius:var(--r);padding:32px 24px;text-align:center}
.gallery-ig-icon{font-size:32px;margin-bottom:8px}
.gallery-ig-handle{font-family:'Oswald',sans-serif;font-size:22px;font-weight:700;color:#fff;text-transform:uppercase;display:block;margin-bottom:4px}
.gallery-ig-sub{font-size:13px;color:rgba(255,255,255,.5);margin-bottom:20px;display:block}

/* Native dialog lightbox */
#lightbox{border:none;background:rgba(0,0,0,.96);padding:0;max-width:100vw;max-height:100svh;width:100vw;height:100svh;position:fixed;inset:0;display:flex;align-items:center;justify-content:center}
#lightbox::backdrop{background:rgba(0,0,0,.9)}
#lb-img{max-width:94vw;max-height:90svh;object-fit:contain;border-radius:8px;display:block}
#lb-close{position:fixed;top:14px;right:14px;background:rgba(255,255,255,.12);border:none;color:#fff;font-size:20px;width:44px;height:44px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:10;line-height:1}

/* ═══════════════════════════════════════════
   CONTACT PAGE — FAQ
═══════════════════════════════════════════ */
.faq-list{display:flex;flex-direction:column;gap:12px;margin-top:28px}
.faq-item{background:var(--white);border-radius:var(--r);padding:20px 24px}
.faq-q{font-family:'Oswald',sans-serif;font-size:17px;font-weight:700;text-transform:uppercase;color:var(--black);margin-bottom:6px;line-height:1.1}
.faq-a{font-size:14px;color:var(--muted);line-height:1.65}
.faq-a a{color:var(--red);font-weight:600}

/* ═══════════════════════════════════════════
   REGISTRATION PAGE (iscriviti)
═══════════════════════════════════════════ */
.reg-grid{display:flex;flex-direction:column;gap:16px;margin-top:28px}
.reg-card{border-radius:var(--r);border:2px solid var(--border);background:var(--white);padding:32px 24px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:14px;position:relative}
.reg-card.featured{border-color:var(--red);background:#fff8f7}
.reg-card-badge{font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;background:var(--red);color:#fff;padding:4px 16px;border-radius:50px}
.reg-card-badge.badge-teal{background:var(--teal)}
.reg-card-title{font-family:'Oswald',sans-serif;font-size:26px;font-weight:700;text-transform:uppercase;color:var(--black);line-height:1.1}
.reg-card-desc{font-size:14px;color:var(--muted);line-height:1.65;max-width:280px}
.reg-card-note{font-size:12px;font-weight:700;color:var(--red);margin-top:-4px}
.golee-feats{display:flex;flex-direction:column;gap:12px;margin:24px 0}
.golee-feat{display:flex;align-items:center;gap:12px;font-size:14px;color:rgba(255,255,255,.8);line-height:1.4}
.golee-feat-check{font-size:16px;flex-shrink:0}
.golee-apps{display:flex;gap:12px;margin-top:28px;flex-wrap:wrap}
.golee-app-btn{display:flex;align-items:center;gap:10px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);border-radius:12px;padding:12px 18px;color:#fff;flex:1;min-width:140px;transition:background .2s}
.golee-app-btn:hover{background:rgba(255,255,255,.18)}
.golee-app-icon{font-size:26px;flex-shrink:0}
.golee-app-label{font-size:9px;opacity:.65;text-transform:uppercase;letter-spacing:.08em;display:block;line-height:1}
.golee-app-store{font-size:14px;font-weight:700;display:block;line-height:1.3}

/* ═══════════════════════════════════════════
   CAMP PAGE
═══════════════════════════════════════════ */
.camp-dates-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:28px}
.camp-date-card{background:var(--white);border-radius:var(--r);padding:22px 16px;text-align:center;border:2px solid var(--border)}
.camp-date-card.featured{border-color:var(--red)}
.camp-date-label{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--red);display:block;margin-bottom:6px}
.camp-date-nums{font-family:'Oswald',sans-serif;font-size:32px;font-weight:700;color:var(--black);line-height:1}
.camp-date-month{font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);display:block;margin-top:6px}
.camp-price-hero{text-align:center;padding:28px 0 8px}
.camp-price-val{font-family:'Oswald',sans-serif;font-size:72px;font-weight:700;color:#fff;line-height:1;display:block}
.camp-price-label{font-size:13px;color:rgba(255,255,255,.6);margin-top:6px;display:block}
.camp-include-list{display:flex;flex-direction:column;gap:0;margin-top:20px}
.camp-include-item{display:flex;align-items:flex-start;gap:12px;font-size:14px;color:rgba(255,255,255,.85);padding:12px 0;border-bottom:1px solid rgba(255,255,255,.08);line-height:1.5}
.camp-include-item:last-child{border-bottom:none}
.camp-include-icon{font-size:16px;flex-shrink:0;margin-top:1px}
.camp-alert{background:rgba(255,255,255,.1);border-radius:var(--r);padding:18px 20px;margin-top:24px;border:1px solid rgba(255,255,255,.18)}
.camp-alert p{font-size:13px;color:rgba(255,255,255,.8)!important;line-height:1.7;margin-bottom:0}
.camp-alert strong{color:#fff!important}
.camp-spots{display:inline-flex;align-items:center;gap:8px;background:var(--red);color:#fff;font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:6px 16px;border-radius:50px;margin-top:16px}

/* info-card inside dark section */
.camp-info-dark{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);margin-top:32px}
.camp-info-dark .info-icon{background:rgba(255,255,255,.12)}
.camp-info-dark .info-text{color:rgba(255,255,255,.75)}
.camp-info-dark .info-text strong{color:rgba(255,255,255,.5)}

/* sec-red CTA center utility */
.sec-red-cta{text-align:center;margin-top:28px}

/* ─── TEAL BUTTON ─── */
.btn-teal{background:var(--teal);color:#fff}
.btn-teal:hover{box-shadow:0 6px 20px rgba(42,122,110,.4)}

/* ═══════════════════════════════════════════
   ISCRIVITI NUDGE BANNER
═══════════════════════════════════════════ */
.iscriviti-nudge{background:var(--teal);border-radius:var(--r);padding:28px 24px;margin:0 24px;display:flex;flex-direction:column;gap:16px;align-items:flex-start}
.iscriviti-nudge .tag{color:rgba(255,255,255,.65)}
.iscriviti-nudge-title{font-family:'Oswald',sans-serif;font-size:22px;font-weight:700;text-transform:uppercase;color:#fff;line-height:1.1;margin-bottom:4px}
.iscriviti-nudge-sub{font-size:14px;color:rgba(255,255,255,.75);line-height:1.5}

/* ═══════════════════════════════════════════
   INFO & METEO PAGE
═══════════════════════════════════════════ */
.meteo-links-grid{display:flex;flex-direction:column;gap:10px;margin-top:24px}
.meteo-link-item{display:flex;align-items:center;gap:14px;background:var(--white);border-radius:var(--r);padding:16px 20px;border:1.5px solid var(--border);text-decoration:none;color:var(--black);transition:border-color .2s,box-shadow .2s}
.meteo-link-item:hover{border-color:var(--red);box-shadow:0 4px 16px rgba(0,0,0,.08)}
.meteo-link-icon{width:40px;height:40px;border-radius:50%;background:var(--gray);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.meteo-link-body strong{display:block;font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;margin-bottom:2px}
.meteo-link-body span{font-size:12px;color:var(--muted);line-height:1.4}
.meteo-link-arrow{margin-left:auto;color:var(--muted);font-size:18px;flex-shrink:0}
.webcam-grid{display:flex;flex-direction:column;gap:10px;margin-top:24px}
.webcam-item{display:flex;align-items:center;gap:14px;background:rgba(255,255,255,.06);border-radius:var(--r);padding:16px;border:1px solid rgba(255,255,255,.1);text-decoration:none;color:#fff;transition:background .2s}
.webcam-item:hover{background:rgba(255,255,255,.1)}
.webcam-dot{width:8px;height:8px;border-radius:50%;background:#25D366;flex-shrink:0;box-shadow:0 0 6px rgba(37,211,102,.6)}
.webcam-name{font-size:14px;font-weight:600;flex:1}
.webcam-km{font-size:12px;color:rgba(255,255,255,.4)}
.spot-info-grid{display:flex;flex-direction:column;gap:12px;margin-top:24px}
.spot-info-item{display:flex;align-items:flex-start;gap:14px;background:var(--white);border-radius:var(--r);padding:18px}
.spot-info-icon{width:40px;height:40px;border-radius:50%;background:var(--gray);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.spot-info-body strong{display:block;font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;margin-bottom:3px}
.spot-info-body span{font-size:14px;color:var(--muted);line-height:1.5}
.attract-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:24px}
.attract-item{background:var(--white);border-radius:var(--r);padding:16px 14px;text-align:center}
.attract-icon{font-size:26px;margin-bottom:8px}
.attract-name{font-family:'Oswald',sans-serif;font-size:13px;font-weight:700;text-transform:uppercase;color:var(--black);margin-bottom:2px}
.attract-dist{font-size:11px;color:var(--muted)}

/* ═══════════════════════════════════════════
   RESPONSIVE NAV
═══════════════════════════════════════════ */
/* Desktop (≥1024px): solo hamburger overlay, no bottom nav */
@media (min-width:1024px){
  #bottom-nav{display:none}
  body{padding-bottom:0}
}
/* Mobile (<1024px): solo bottom nav, no hamburger */
@media (max-width:1023px){
  .hamburger{display:none}
}
