@import url('https://fonts.googleapis.com/css2?family=Anton&family=Barlow+Condensed:wght@400;500;600;700&family=Great+Vibes&family=Montserrat:wght@300;400;500;600;700;800&display=swap');

*{box-sizing:border-box;margin:0;padding:0}
body{font-family:Arial,Helvetica,sans-serif;background:#eef6fb;color:#062b69}
a{text-decoration:none;color:inherit}

.site-header{
  position:absolute;
  top:0;
  left:0;
  width:100%;
  z-index:100;
  display:flex;
  align-items:center;
  gap:26px;
  justify-content:space-between;
  padding:16px 38px;
  background:transparent;
}
.site-header.inner{position:relative;background:linear-gradient(90deg,#00349b,#0066e6)}

.brand{display:flex;align-items:center;gap:14px;color:white;text-shadow:0 2px 9px rgba(0,0,0,.45)}
.brand img{width:92px;height:92px;object-fit:contain}
.brand-title{font-family:'Barlow Condensed',Arial,sans-serif;font-size:32px;line-height:.92;font-weight:500;letter-spacing:.3px}
.brand-sub{font-size:14px;font-style:normal;margin-top:5px;font-family:'Montserrat',Arial,sans-serif;font-weight:300;letter-spacing:.8px}

.menu{display:flex;align-items:center;gap:38px;margin-left:auto}
.menu a{font-family:'Barlow Condensed',Arial,sans-serif;font-weight:500;font-size:23px;color:white;text-shadow:0 2px 9px rgba(0,0,0,.35);padding-bottom:8px;border-bottom:2px solid transparent;white-space:nowrap;letter-spacing:.4px}
.menu a.active{border-color:white}

.languages{display:flex;gap:11px;align-items:center}
.languages button{border:0;background:transparent;color:white;display:flex;flex-direction:column;align-items:center;gap:4px;font-weight:700;cursor:pointer;text-shadow:0 2px 8px rgba(0,0,0,.45)}
.languages button.active{transform:translateY(-2px)}
.languages small{font-size:11px}

.flag{width:36px;height:36px;border-radius:50%;border:2px solid white;display:inline-block;box-shadow:0 4px 12px rgba(0,0,0,.25);overflow:hidden}
.it{background:linear-gradient(90deg,#009246 0 33.33%,#fff 33.33% 66.66%,#ce2b37 66.66%)}
.fr{background:linear-gradient(90deg,#0055a4 0 33.33%,#fff 33.33% 66.66%,#ef4135 66.66%)}
.de{background:linear-gradient(180deg,#000 0 33.33%,#dd0000 33.33% 66.66%,#ffce00 66.66%)}
.es{background:linear-gradient(180deg,#aa151b 0 25%,#f1bf00 25% 75%,#aa151b 75%)}
.en{background:url("assets/en-flag.jpeg") center/cover no-repeat;border:0}

.book{color:white;border:1px solid rgba(255,255,255,.9);border-radius:12px;padding:13px 20px;background:rgba(0,30,90,.20);font-family:'Barlow Condensed',Arial,sans-serif;font-weight:600;font-size:21px;letter-spacing:.4px;text-shadow:0 2px 8px rgba(0,0,0,.35);white-space:nowrap}

/* Copertina intera: non viene più tagliata */
.hero{width:100%;position:relative;background:#005ed4;overflow:hidden}
.hero img{display:block;width:100%;height:auto}

.destinations{max-width:1420px;margin:auto;padding:28px 30px 60px}
.section-title{text-align:center;margin-bottom:28px}
.section-title h1{font-size:36px;color:#062b69;font-weight:900}
.decor{margin-top:8px;color:#0a85e8;font-size:23px;display:flex;justify-content:center;align-items:center;gap:12px}
.decor span{display:inline-block;width:45px;height:2px;background:#0a85e8}

.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:25px 28px}
.card{position:relative;height:320px;border-radius:16px;overflow:hidden;box-shadow:0 12px 26px rgba(0,45,95,.20);background:#d9e7ef}
.card img{width:100%;height:100%;object-fit:cover;display:block}
.card:after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.78),rgba(0,0,0,.22) 46%,rgba(0,0,0,.03))}
.info{position:absolute;bottom:20px;left:12px;right:12px;text-align:center;color:white;z-index:2;text-shadow:0 2px 8px rgba(0,0,0,.85)}
.info h2{font-size:29px;line-height:1.05;font-weight:900}
.info p{font-size:18px;margin:5px 0 11px}
.card-flags{display:flex;gap:8px;justify-content:center}
.card-flags .flag{width:31px;height:31px}

footer{text-align:center;color:white;background:#062b69;padding:28px}
.page{min-height:calc(100vh - 180px);padding:55px 24px}
.content-card{max-width:920px;margin:auto;background:white;border-radius:18px;box-shadow:0 12px 28px rgba(0,45,95,.18);padding:38px;line-height:1.7}
.content-card h1{font-size:36px;margin-bottom:15px}.content-card h2{margin-top:24px}

@media(max-width:1150px){
  .site-header{position:relative;background:linear-gradient(90deg,#00349b,#0066e6);flex-wrap:wrap;justify-content:center}
  .menu{margin-left:0}
  .grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:700px){
  .brand-title{font-family:'Barlow Condensed',Arial,sans-serif;font-size:32px;line-height:.92;font-weight:500;letter-spacing:.3px}
  .brand img{width:62px;height:62px}
  .menu{gap:18px}
  .menu a{font-family:'Barlow Condensed',Arial,sans-serif;font-weight:500;font-size:23px;color:white;text-shadow:0 2px 9px rgba(0,0,0,.35);padding-bottom:8px;border-bottom:2px solid transparent;white-space:nowrap;letter-spacing:.4px}
  .languages{flex-wrap:wrap;justify-content:center}
  .grid{grid-template-columns:1fr}
  .card{height:285px}
  .destinations{padding:26px 16px}
  .section-title h1{font-size:29px}
}


.about-grid{max-width:1400px;margin:auto;display:grid;grid-template-columns:2fr 1fr;gap:32px}
.info-box{background:white;border-radius:22px;padding:40px;box-shadow:0 14px 32px rgba(0,45,95,.16)}
.info-box h1,.info-box h2{font-size:36px;margin-bottom:18px;color:#062b69}
.info-box p{font-size:18px;line-height:1.9;margin-bottom:18px;color:#143f7a}
.contact-box{align-self:start}
.contact-item{margin-bottom:22px}
.contact-item strong{font-size:20px;display:block;margin-bottom:6px}
.contact-button{display:block;width:100%;text-align:center;margin-top:16px;background:#0a85e8;color:white;padding:16px;border-radius:14px;font-weight:900;font-size:18px}
.facebook-btn{background:#003fa5}

.whatsapp-float{
position:fixed;
right:18px;
bottom:18px;
background:#25D366;
color:white;
padding:14px 20px;
border-radius:999px;
font-weight:900;
z-index:99999;
box-shadow:0 8px 22px rgba(0,0,0,.30)
}

@media(max-width:900px){
.about-grid{grid-template-columns:1fr}
}


/* Layout moderno Chi siamo e contatti */
.page.about-page{
  min-height:calc(100vh - 180px);
  padding:58px 28px 72px;
  background:
    radial-gradient(circle at top left,rgba(14,133,232,.15),transparent 35%),
    linear-gradient(180deg,#eef8ff 0%,#f7fbff 100%);
}

.about-hero-panel{
  max-width:1380px;
  margin:0 auto 30px;
  background:linear-gradient(135deg,#00349b 0%,#0066e6 52%,#07a7e8 100%);
  color:white;
  border-radius:30px;
  padding:46px 48px;
  box-shadow:0 18px 42px rgba(0,55,120,.22);
  position:relative;
  overflow:hidden;
}

.about-hero-panel:after{
  content:"";
  position:absolute;
  width:260px;
  height:260px;
  right:-70px;
  top:-80px;
  border-radius:50%;
  background:rgba(255,255,255,.16);
}

.about-kicker{
  font-family:'Montserrat',Arial,sans-serif;
  font-size:14px;
  text-transform:uppercase;
  letter-spacing:2.4px;
  font-weight:600;
  opacity:.9;
  margin-bottom:12px;
}

.about-hero-panel h1{
  font-family:'Barlow Condensed',Arial,sans-serif;
  font-size:52px;
  line-height:1;
  font-weight:500;
  margin-bottom:16px;
}

.about-hero-panel p{
  max-width:900px;
  font-size:20px;
  line-height:1.65;
  opacity:.96;
}

.about-modern-grid{
  max-width:1380px;
  margin:auto;
  display:grid;
  grid-template-columns:1.45fr .85fr;
  gap:30px;
  align-items:start;
}

.modern-card{
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(8px);
  border:1px solid rgba(0,80,170,.08);
  border-radius:28px;
  padding:38px;
  box-shadow:0 16px 36px rgba(0,45,95,.13);
}

.modern-card h2{
  font-family:'Barlow Condensed',Arial,sans-serif;
  font-size:40px;
  line-height:1;
  font-weight:500;
  color:#063478;
  margin-bottom:22px;
}

.about-points{
  display:grid;
  gap:18px;
}

.about-point{
  display:grid;
  grid-template-columns:48px 1fr;
  gap:16px;
  align-items:start;
  padding:18px;
  border-radius:20px;
  background:linear-gradient(180deg,#f7fbff,#edf7ff);
  border:1px solid rgba(0,92,190,.08);
}

.about-icon{
  width:48px;
  height:48px;
  border-radius:16px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:#e4f3ff;
  color:#0066e6;
  font-size:24px;
  box-shadow:inset 0 0 0 1px rgba(0,92,190,.08);
}

.about-point h3{
  font-family:'Barlow Condensed',Arial,sans-serif;
  font-size:25px;
  font-weight:500;
  color:#062b69;
  margin-bottom:5px;
}

.about-point p{
  font-size:17px;
  line-height:1.65;
  color:#244a78;
}

.contact-card{
  position:sticky;
  top:24px;
}

.contact-list{
  display:grid;
  gap:16px;
  margin-top:18px;
}

.contact-row{
  padding:18px;
  border-radius:18px;
  background:#f4faff;
  border:1px solid rgba(0,92,190,.08);
}

.contact-row strong{
  display:block;
  font-family:'Barlow Condensed',Arial,sans-serif;
  font-size:23px;
  font-weight:500;
  color:#063478;
  margin-bottom:4px;
}

.contact-row p{
  font-size:16px;
  color:#244a78;
  overflow-wrap:anywhere;
}

.contact-actions{
  display:grid;
  gap:13px;
  margin-top:24px;
}

.contact-button{
  display:block;
  width:100%;
  text-align:center;
  margin-top:0;
  background:#0a85e8;
  color:white;
  padding:16px;
  border-radius:16px;
  font-family:'Barlow Condensed',Arial,sans-serif;
  font-weight:600;
  font-size:23px;
  letter-spacing:.4px;
  box-shadow:0 10px 20px rgba(0,89,190,.18);
}

.contact-button.whatsapp-contact{
  background:#25D366;
}

.facebook-btn{
  background:#003fa5;
}

@media(max-width:900px){
  .page.about-page{
    padding:34px 16px 54px;
  }
  .about-hero-panel{
    padding:34px 26px;
    border-radius:24px;
  }
  .about-hero-panel h1{
    font-size:42px;
  }
  .about-hero-panel p{
    font-size:18px;
  }
  .about-modern-grid{
    grid-template-columns:1fr;
  }
  .modern-card{
    padding:26px;
    border-radius:24px;
  }
  .about-point{
    grid-template-columns:42px 1fr;
    padding:15px;
  }
  .about-icon{
    width:42px;
    height:42px;
  }
  .contact-card{
    position:relative;
    top:auto;
  }
}


/* Fix proporzioni hero e larghezza responsive */
html,body{
  width:100%;
  max-width:100%;
  overflow-x:hidden;
}

.site-header,
.hero,
.hero img,
.destinations,
.page,
footer{
  max-width:100%;
}

.hero{
  width:100%;
  max-width:100vw;
  overflow:hidden;
}

.hero img{
  display:block;
  width:100%;
  max-width:100%;
  height:auto;
  object-fit:contain;
}

@media(max-width:1150px){
  .site-header{
    width:100%;
    max-width:100vw;
  }
}

@media(max-width:700px){
  .hero img{
    width:100%;
    height:auto;
    max-width:100%;
  }

  .site-header{
    padding-left:14px;
    padding-right:14px;
  }

  .languages{
    max-width:100%;
  }

  .book{
    max-width:100%;
  }
}


/* Header alignment fix */
.site-header{
  width:100%;
  max-width:100%;
  left:0;
  right:0;
  padding:16px 26px;
}

.menu{
  gap:24px;
}

.book{
  flex-shrink:0;
}

@media(max-width:1150px){
  .site-header{
    justify-content:space-between;
    gap:18px;
    padding:14px 18px;
  }

  .menu{
    gap:16px;
  }

  .book{
    font-size:18px;
    padding:12px 16px;
  }
}

@media(max-width:700px){

  .site-header{
    padding:12px 12px;
    gap:10px;
  }

  .menu{
    gap:10px;
  }

  .menu a{
    font-size:18px;
  }

  .book{
    font-size:17px;
    padding:10px 13px;
  }

  .languages{
    gap:6px;
  }

  .languages button small{
    font-size:9px;
  }

  .flag{
    width:30px;
    height:30px;
  }
}









/* HEADER CORRETTO: menu e lingue sul lato destro */
html,body{
  max-width:100%;
  overflow-x:hidden;
}

.site-header{
  left:0 !important;
  right:0 !important;
  width:100% !important;
  max-width:100vw !important;
  box-sizing:border-box !important;
  padding:13px 34px 13px 20px !important;
  display:flex !important;
  align-items:center !important;
  justify-content:flex-start !important;
  gap:16px !important;
}

.brand{
  flex:0 0 auto !important;
}

.brand img{
  width:74px !important;
  height:74px !important;
}

.brand-title{
  font-family:'Barlow Condensed',Arial,sans-serif !important;
  font-size:30px !important;
  line-height:.92 !important;
  font-weight:500 !important;
  letter-spacing:.2px !important;
}

.brand-sub{
  font-size:13px !important;
}

/* Menu sul lato destro */
.menu{
  margin-left:auto !important;
  display:flex !important;
  align-items:center !important;
  gap:22px !important;
}

.menu a{
  font-family:'Barlow Condensed',Arial,sans-serif !important;
  font-size:22px !important;
  font-weight:500 !important;
  padding-bottom:7px !important;
}

/* Lingue DOPO il menu */
.languages{
  margin-left:14px !important;
  display:flex !important;
  align-items:center !important;
  gap:8px !important;
}

.languages button{
  flex:0 0 auto !important;
}

.languages small{
  font-size:9px !important;
}

.flag{
  width:32px !important;
  height:32px !important;
}

/* Facebook ultimo elemento a destra */
.book{
  margin-left:14px !important;
  margin-right:0 !important;
  white-space:nowrap !important;
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  padding:10px 14px !important;
  font-family:'Barlow Condensed',Arial,sans-serif !important;
  font-size:19px !important;
  font-weight:600 !important;
  letter-spacing:.3px !important;
  flex-shrink:0 !important;
}

@media(max-width:1280px){

  .site-header{
    padding:12px 24px 12px 16px !important;
    gap:10px !important;
  }

  .brand img{
    width:62px !important;
    height:62px !important;
  }

  .brand-title{
    font-size:26px !important;
  }

  .brand-sub{
    font-size:11px !important;
  }

  .menu{
    gap:14px !important;
  }

  .menu a{
    font-size:18px !important;
  }

  .languages{
    gap:5px !important;
    margin-left:8px !important;
  }

  .flag{
    width:27px !important;
    height:27px !important;
  }

  .languages small{
    font-size:8px !important;
  }

  .book{
    font-size:16px !important;
    padding:8px 10px !important;
    margin-left:8px !important;
  }
}

@media(max-width:980px){

  .site-header{
    position:relative !important;
    background:linear-gradient(90deg,#00349b,#0066e6) !important;
    flex-wrap:wrap !important;
    justify-content:center !important;
    padding:12px 14px !important;
  }

  .menu{
    margin-left:0 !important;
  }

  .languages{
    margin-left:0 !important;
  }

  .book{
    margin-left:0 !important;
  }
}

@media(max-width:700px){

  .site-header{
    gap:10px !important;
    padding:12px 10px !important;
  }

  .brand-title{
    font-size:23px !important;
  }

  .brand img{
    width:56px !important;
    height:56px !important;
  }

  .menu{
    gap:14px !important;
  }

  .menu a{
    font-size:18px !important;
  }

  .languages{
    justify-content:center !important;
    flex-wrap:wrap !important;
  }

  .book{
    font-size:17px !important;
    padding:10px 14px !important;
  }
}


@media(max-width:700px){
  .whatsapp-float{
    width:62px;
    height:62px;
    right:16px;
    bottom:16px;
  }

  .whatsapp-float svg{
    width:33px;
    height:33px;
  }
}


@media(max-width:700px){
  .whatsapp-float{
    width:38px;
    height:38px;
    right:14px;
    bottom:14px;
  }

  .whatsapp-float svg{
    width:20px;
    height:20px;
  }
}


/* WhatsApp compact refined button */
.whatsapp-float{
  position:fixed;
  right:16px;
  bottom:16px;
  width:34px;
  height:34px;
  border-radius:50%;
  background:#25D366;
  display:flex;
  align-items:center;
  justify-content:center;
  z-index:99999;
  box-shadow:0 4px 12px rgba(0,0,0,.18);
  text-decoration:none;
  transition:transform .18s ease;
}

.whatsapp-float:hover{
  transform:scale(1.08);
}

.whatsapp-float svg{
  width:22px;
  height:22px;
  fill:white;
}

@media(max-width:700px){
  .whatsapp-float{
    width:32px;
    height:32px;
    right:12px;
    bottom:12px;
  }

  .whatsapp-float svg{
    width:21px;
    height:21px;
  }
}


/* HERO rettangolare pulita */
.hero,
.hero-banner,
.hero-section{
  width:100% !important;
  max-width:100vw !important;
  overflow:hidden !important;
}

.hero img,
.hero-banner img,
.hero-section img{
  width:100% !important;
  height:auto !important;
  display:block !important;
  object-fit:cover !important;
  object-position:center center !important;
}


/* Fix palma dietro Home */
.hero-title-overlay{
  top:42% !important;
  left:43% !important;
  transform:translate(-50%,-50%) rotate(-2deg) scale(0.92) !important;
  max-width:52% !important;
}

@media(max-width:900px){
  .hero-title-overlay{
    top:45% !important;
    left:42% !important;
    transform:translate(-50%,-50%) rotate(-2deg) scale(0.88) !important;
  }
}


/* piccolo abbassamento titolo hero */
.hero-title-overlay{
    top:46% !important;
}

@media(max-width:900px){
  .hero-title-overlay{
      top:49% !important;
  }
}


/* HERO CINEMATICA PREMIUM - solo overlay HTML traducibile */
.hero.hero-cinematic{
  position:relative !important;
  width:100% !important;
  height:clamp(340px,39vw,650px) !important;
  overflow:hidden !important;
  background:#00a9ef !important;
}
.hero.hero-cinematic img{
  position:absolute !important;
  inset:0 !important;
  width:100% !important;
  height:100% !important;
  display:block !important;
  object-fit:cover !important;
  object-position:center center !important;
  filter:saturate(1.08) contrast(1.03) brightness(1.03) !important;
  z-index:1 !important;
}
.hero.hero-cinematic:before{
  content:"" !important;
  position:absolute !important;
  inset:0 !important;
  z-index:2 !important;
  background:radial-gradient(ellipse at 50% 52%,rgba(255,255,255,.50) 0%,rgba(255,255,255,.25) 24%,rgba(255,255,255,.06) 48%,rgba(255,255,255,0) 70%) !important;
  pointer-events:none !important;
}
.hero.hero-cinematic:after{
  content:"" !important;
  position:absolute !important;
  left:50% !important;
  top:54% !important;
  width:min(760px,54vw) !important;
  height:min(360px,25vw) !important;
  transform:translate(-50%,-50%) rotate(-5deg) !important;
  z-index:2 !important;
  background:linear-gradient(90deg,rgba(255,255,255,0),rgba(255,255,255,.22),rgba(255,255,255,0)) !important;
  filter:blur(14px) !important;
  border-radius:50% !important;
  pointer-events:none !important;
}
.hero-cinematic-overlay{
  position:absolute !important;
  inset:0 !important;
  z-index:4 !important;
  display:flex !important;
  flex-direction:column !important;
  align-items:center !important;
  justify-content:center !important;
  text-align:center !important;
  padding-top:clamp(22px,4.5vw,76px) !important;
  pointer-events:none !important;
  transform:rotate(-.8deg) !important;
}
.hero-top-script{
  position:relative !important;
  display:inline-block !important;
  font-family:'Great Vibes','Brush Script MT','Segoe Script',cursive !important;
  font-size:clamp(58px,5.7vw,118px) !important;
  line-height:.68 !important;
  color:#fff !important;
  font-weight:400 !important;
  letter-spacing:.2px !important;
  text-shadow:0 2px 0 #0b75de,0 5px 10px rgba(0,50,150,.55),0 0 16px rgba(255,255,255,.95) !important;
}
.hero-top-script:after{
  content:"" !important;
  position:absolute !important;
  left:-7% !important;
  right:-8% !important;
  bottom:-13px !important;
  height:clamp(14px,1.4vw,24px) !important;
  border-radius:999px !important;
  background:linear-gradient(90deg,transparent 0%,#ffe200 10%,#ff9d00 48%,#ffd600 87%,transparent 100%) !important;
  transform:skewX(-20deg) rotate(-.8deg) !important;
  box-shadow:0 2px 0 #00caff,0 0 14px rgba(255,210,0,.72) !important;
  z-index:-1 !important;
}
.hero-title-stack{
  margin-top:clamp(18px,2.1vw,31px) !important;
  filter:drop-shadow(0 14px 16px rgba(0,32,105,.35)) !important;
}
.hero-main-line{
  font-family:'Anton','Barlow Condensed','Impact','Arial Narrow',sans-serif !important;
  font-size:clamp(54px,7.4vw,148px) !important;
  line-height:.78 !important;
  text-transform:uppercase !important;
  color:#fff !important;
  font-weight:400 !important;
  letter-spacing:2px !important;
  -webkit-text-stroke:2px rgba(0,64,170,.92) !important;
  text-shadow:0 2px 0 #1b8cff,0 6px 0 #003ca4,0 12px 18px rgba(0,20,90,.44),0 0 12px rgba(255,255,255,.75) !important;
}
.hero-sub-line{
  margin-top:clamp(2px,.4vw,7px) !important;
  font-family:'Great Vibes','Brush Script MT','Segoe Script',cursive !important;
  font-size:clamp(50px,5.6vw,112px) !important;
  line-height:.78 !important;
  color:#fff !important;
  font-weight:400 !important;
  letter-spacing:.2px !important;
  text-shadow:0 2px 0 #0b75de,0 6px 12px rgba(0,40,130,.50),0 0 16px rgba(255,255,255,.94) !important;
}
.hero-sub-line:after{
  content:"" !important;
  display:block !important;
  width:58% !important;
  height:clamp(6px,.7vw,10px) !important;
  margin:3px auto 0 !important;
  border-radius:999px !important;
  background:linear-gradient(90deg,transparent,#1685ff 17%,#001d96 62%,transparent) !important;
  transform:skewX(-24deg) rotate(-.6deg) !important;
  box-shadow:0 1px 0 rgba(255,255,255,.45),0 0 8px rgba(0,90,255,.38) !important;
}
.hero-tags{
  margin-top:clamp(12px,1.3vw,20px) !important;
  display:flex !important;
  justify-content:center !important;
  align-items:center !important;
  gap:clamp(12px,2vw,30px) !important;
  flex-wrap:wrap !important;
  font-family:'Montserrat',Arial,sans-serif !important;
  font-size:clamp(10px,1.05vw,17px) !important;
  text-transform:uppercase !important;
  font-weight:800 !important;
  color:#00429d !important;
  letter-spacing:.7px !important;
  text-shadow:0 1px 0 rgba(255,255,255,.95),0 2px 7px rgba(0,75,160,.22) !important;
}
.hero-tags span{display:inline-flex !important;align-items:center !important;gap:8px !important;}
.hero-tags span:before{
  content:"✦" !important;
  color:#ffd400 !important;
  font-size:1.2em !important;
  text-shadow:0 2px 4px rgba(0,55,130,.35) !important;
}
@media(max-width:980px){
  .hero.hero-cinematic{height:clamp(310px,47vw,450px) !important;}
  .hero-cinematic-overlay{transform:rotate(-.8deg) scale(.88) !important;padding-top:34px !important;}
  .hero-main-line{-webkit-text-stroke:1.4px rgba(0,64,170,.92) !important;}
}
@media(max-width:700px){
  .hero.hero-cinematic{height:340px !important;}
  .hero-cinematic-overlay{transform:rotate(-.8deg) scale(.70) !important;padding-top:20px !important;}
  .hero-main-line{-webkit-text-stroke:1px rgba(0,64,170,.92) !important;letter-spacing:1px !important;}
  .hero-tags{gap:8px !important;}
}


/* HERO MULTILINGUA CON TESTO STAMPATO - mantiene proporzioni identiche per tutte le lingue */
.hero.hero-language{
  width:100% !important;
  max-width:100vw !important;
  position:relative !important;
  overflow:hidden !important;
  background:#02a8ec !important;
}
.hero.hero-language img{
  display:block !important;
  width:100% !important;
  height:auto !important;
  max-width:100% !important;
  object-fit:contain !important;
  object-position:center center !important;
}
@media(max-width:700px){
  .hero.hero-language img{
    width:100% !important;
    height:auto !important;
  }
}

/* Aggiornamento griglia: foto luminose, opacità solo in basso */
.card img{
  filter:brightness(1.06) saturate(1.08) contrast(1.02) !important;
}
.card:after{
  content:"" !important;
  position:absolute !important;
  inset:0 !important;
  background:linear-gradient(to top,
    rgba(0,0,0,.72) 0%,
    rgba(0,0,0,.50) 18%,
    rgba(0,0,0,.24) 32%,
    rgba(0,0,0,.06) 45%,
    rgba(0,0,0,0) 58%,
    rgba(0,0,0,0) 100%) !important;
}


/* FINAL FIX: hero images must keep exact file proportions, no zoom, no crop, no deformation */
.hero.hero-language{
  width:100% !important;
  max-width:100vw !important;
  height:auto !important;
  line-height:0 !important;
  overflow:hidden !important;
  background:#02a8ec !important;
}
.hero.hero-language img,
#heroImage{
  display:block !important;
  width:100% !important;
  height:auto !important;
  max-width:100% !important;
  object-fit:contain !important;
  object-position:center center !important;
  aspect-ratio:auto !important;
  transform:none !important;
  zoom:1 !important;
  image-rendering:auto !important;
}

/* FINAL FIX: language labels as clean two-letter codes */
.languages small{
  font-size:10px !important;
  font-weight:800 !important;
  letter-spacing:.8px !important;
  text-transform:uppercase !important;
  line-height:1 !important;
  margin-top:2px !important;
}

/* FINAL FIX: grid images bright; opacity only in the lower title area */
.card img{
  filter:brightness(1.08) saturate(1.08) contrast(1.02) !important;
}
.card:after{
  content:"" !important;
  position:absolute !important;
  inset:0 !important;
  background:linear-gradient(to top,
    rgba(0,0,0,.74) 0%,
    rgba(0,0,0,.55) 18%,
    rgba(0,0,0,.24) 32%,
    rgba(0,0,0,.08) 42%,
    rgba(0,0,0,0) 52%,
    rgba(0,0,0,0) 100%) !important;
  pointer-events:none !important;
}

/* FINAL UPDATE: card 3 uses Panama asset; destination cards slightly smaller, same proportions */
.destinations{
  max-width:1260px !important;
  padding:26px 24px 56px !important;
}
.grid{
  grid-template-columns:repeat(3,minmax(0,1fr)) !important;
  gap:22px 24px !important;
}
.card{
  height:286px !important;
  border-radius:15px !important;
}
.card img{
  filter:brightness(1.08) saturate(1.08) contrast(1.02) !important;
}
.card:after{
  content:"" !important;
  position:absolute !important;
  inset:0 !important;
  background:linear-gradient(to top,
    rgba(0,0,0,.76) 0%,
    rgba(0,0,0,.54) 18%,
    rgba(0,0,0,.24) 31%,
    rgba(0,0,0,.07) 41%,
    rgba(0,0,0,0) 52%,
    rgba(0,0,0,0) 100%) !important;
  pointer-events:none !important;
}
@media(max-width:1150px){
  .destinations{max-width:900px !important;padding:26px 20px 54px !important;}
  .grid{grid-template-columns:repeat(2,minmax(0,1fr)) !important;gap:20px !important;}
  .card{height:280px !important;}
}
@media(max-width:700px){
  .destinations{padding:24px 15px 50px !important;}
  .grid{grid-template-columns:1fr !important;gap:18px !important;}
  .card{height:265px !important;}
}


/* FINAL FIX: WhatsApp official white icon visible */
.whatsapp-float{
  width:42px !important;
  height:42px !important;
  border-radius:50% !important;
  background:#25D366 !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  padding:0 !important;
  color:white !important;
  font-size:0 !important;
}
.whatsapp-float svg{
  width:25px !important;
  height:25px !important;
  display:block !important;
  fill:#fff !important;
}
.whatsapp-float span{display:none !important;}
@media(max-width:700px){
  .whatsapp-float{width:40px !important;height:40px !important;}
  .whatsapp-float svg{width:24px !important;height:24px !important;}
}


/* ABOUT PAGE - stile agenzia viaggi / tour operator crocieristi */
.about-travel-page{
  background:linear-gradient(180deg,#ffffff 0%,#f6fbff 42%,#ffffff 100%) !important;
  color:#062b69 !important;
  overflow:hidden !important;
}
.about-travel-hero{
  min-height:360px !important;
  position:relative !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  text-align:center !important;
  background:
    linear-gradient(90deg,rgba(255,255,255,.84) 0%,rgba(255,255,255,.60) 38%,rgba(255,255,255,.18) 68%,rgba(255,255,255,.08) 100%),
    linear-gradient(180deg,rgba(0,50,145,.05),rgba(0,50,145,.12)),
    url('assets/about-cruise-bg.png') center center/cover no-repeat !important;
  box-shadow:inset 0 -70px 80px rgba(255,255,255,.86) !important;
}
.about-travel-hero:after{
  content:"" !important;
  position:absolute !important;
  left:50% !important;
  bottom:42px !important;
  width:150px !important;
  height:4px !important;
  transform:translateX(-50%) skewX(-20deg) !important;
  border-radius:999px !important;
  background:#f6c500 !important;
  box-shadow:0 2px 0 rgba(0,107,230,.22) !important;
}
.about-hero-content{
  position:relative !important;
  z-index:2 !important;
  width:min(760px,92vw) !important;
  padding:44px 28px 52px !important;
  transform:translateX(8%) !important;
}
.about-kicker-travel{
  display:inline-flex !important;
  align-items:center !important;
  gap:8px !important;
  padding:8px 18px !important;
  border-radius:999px !important;
  background:rgba(255,255,255,.72) !important;
  color:#003b99 !important;
  font-family:'Montserrat',Arial,sans-serif !important;
  font-size:13px !important;
  font-weight:800 !important;
  text-transform:uppercase !important;
  letter-spacing:1.8px !important;
  box-shadow:0 10px 28px rgba(0,52,155,.10) !important;
}
.about-hero-content h1{
  margin:14px 0 12px !important;
  color:#00349b !important;
  text-shadow:0 2px 0 rgba(255,255,255,.76),0 10px 24px rgba(0,60,160,.20) !important;
}
.about-hero-content h1 span{
  display:block !important;
  font-family:'Brush Script MT','Segoe Script',cursive !important;
  font-size:clamp(46px,5vw,80px) !important;
  font-weight:500 !important;
  line-height:.82 !important;
  color:#003fa5 !important;
  text-transform:none !important;
}
.about-hero-content h1 em{
  display:block !important;
  font-family:'Barlow Condensed',Arial,sans-serif !important;
  font-size:clamp(56px,6vw,96px) !important;
  line-height:.82 !important;
  font-style:normal !important;
  font-weight:600 !important;
  letter-spacing:2px !important;
  text-transform:uppercase !important;
}
.about-hero-content p{
  max-width:650px !important;
  margin:0 auto !important;
  font-family:'Montserrat',Arial,sans-serif !important;
  font-size:18px !important;
  line-height:1.65 !important;
  color:#062b69 !important;
  font-weight:600 !important;
}
.about-experience-section{
  max-width:1320px !important;
  margin:42px auto 30px !important;
  padding:0 28px !important;
  display:grid !important;
  grid-template-columns:.82fr 1.18fr !important;
  gap:34px !important;
  align-items:start !important;
}
.experience-copy{
  padding:10px 0 0 !important;
}
.section-eyebrow{
  width:54px !important;
  height:54px !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  font-size:32px !important;
  margin-bottom:10px !important;
}
.experience-copy h2,
.contact-details-travel h2,
.contact-actions-travel h2{
  font-family:'Barlow Condensed',Arial,sans-serif !important;
  font-size:clamp(34px,3vw,48px) !important;
  line-height:.92 !important;
  color:#00349b !important;
  font-weight:600 !important;
  text-transform:uppercase !important;
  letter-spacing:.8px !important;
  margin:0 0 18px !important;
  position:relative !important;
}
.experience-copy h2:after,
.contact-details-travel h2:after,
.contact-actions-travel h2:after{
  content:"" !important;
  display:block !important;
  width:120px !important;
  height:4px !important;
  background:#f6c500 !important;
  border-radius:999px !important;
  margin-top:10px !important;
  transform:skewX(-20deg) !important;
}
.experience-copy p{
  font-family:'Montserrat',Arial,sans-serif !important;
  font-size:17px !important;
  line-height:1.85 !important;
  color:#173f78 !important;
  font-weight:500 !important;
}
.travel-seal-row{
  display:flex !important;
  flex-wrap:wrap !important;
  gap:10px !important;
  margin-top:22px !important;
}
.travel-seal-row span{
  background:#eef8ff !important;
  border:1px solid rgba(0,102,230,.12) !important;
  color:#003fa5 !important;
  border-radius:999px !important;
  padding:10px 14px !important;
  font-family:'Montserrat',Arial,sans-serif !important;
  font-weight:800 !important;
  font-size:13px !important;
  box-shadow:0 8px 20px rgba(0,60,160,.07) !important;
}
.experience-feature-grid{
  display:grid !important;
  grid-template-columns:repeat(2,minmax(0,1fr)) !important;
  gap:18px !important;
}
.experience-tile{
  background:rgba(255,255,255,.96) !important;
  border:1px solid rgba(0,85,185,.10) !important;
  border-radius:22px !important;
  padding:24px 22px !important;
  min-height:210px !important;
  box-shadow:0 16px 35px rgba(0,45,95,.10) !important;
  text-align:center !important;
  position:relative !important;
  overflow:hidden !important;
}
.experience-tile:before{
  content:"" !important;
  position:absolute !important;
  inset:0 0 auto 0 !important;
  height:5px !important;
  background:linear-gradient(90deg,#003fa5,#00a8ef,#f6c500) !important;
}
.experience-tile.wide-tile{
  grid-column:1/-1 !important;
  min-height:auto !important;
  display:grid !important;
  grid-template-columns:auto 1fr !important;
  text-align:left !important;
  gap:18px !important;
  align-items:center !important;
}
.tile-icon{
  width:58px !important;
  height:58px !important;
  margin:0 auto 16px !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  border-radius:20px !important;
  background:linear-gradient(180deg,#eef9ff,#dff2ff) !important;
  color:#003fa5 !important;
  font-size:30px !important;
  box-shadow:inset 0 0 0 1px rgba(0,102,230,.10),0 10px 20px rgba(0,75,180,.10) !important;
}
.wide-tile .tile-icon{margin:0 !important;}
.experience-tile h3{
  font-family:'Barlow Condensed',Arial,sans-serif !important;
  font-size:28px !important;
  line-height:1 !important;
  font-weight:600 !important;
  color:#00349b !important;
  margin:0 0 10px !important;
}
.experience-tile p{
  font-family:'Montserrat',Arial,sans-serif !important;
  font-size:15px !important;
  line-height:1.65 !important;
  color:#244a78 !important;
  margin:0 !important;
}
.contact-travel-panel{
  max-width:1320px !important;
  margin:34px auto 64px !important;
  padding:0 !important;
  display:grid !important;
  grid-template-columns:.9fr 1fr .9fr !important;
  gap:0 !important;
  border-radius:28px !important;
  overflow:hidden !important;
  background:linear-gradient(90deg,#f7fbff,#ffffff) !important;
  box-shadow:0 18px 45px rgba(0,45,95,.14) !important;
  border:1px solid rgba(0,85,185,.10) !important;
}
.contact-board{
  min-height:280px !important;
  padding:34px !important;
  display:flex !important;
  flex-direction:column !important;
  justify-content:center !important;
  background:
    radial-gradient(circle at 18% 18%,rgba(255,255,255,.82),rgba(255,255,255,0) 45%),
    linear-gradient(135deg,rgba(0,136,230,.14),rgba(246,197,0,.14)),
    url('assets/dest02.png') center/cover no-repeat !important;
}
.board-title{
  display:inline-block !important;
  width:max-content !important;
  max-width:100% !important;
  padding:20px 26px !important;
  border-radius:18px !important;
  background:rgba(121,74,31,.72) !important;
  color:white !important;
  font-family:'Brush Script MT','Segoe Script',cursive !important;
  font-size:56px !important;
  line-height:.9 !important;
  text-shadow:0 3px 8px rgba(0,0,0,.30) !important;
  box-shadow:0 16px 35px rgba(0,45,95,.22) !important;
}
.contact-board p{
  margin-top:14px !important;
  font-family:'Montserrat',Arial,sans-serif !important;
  color:white !important;
  font-weight:800 !important;
  text-shadow:0 2px 8px rgba(0,35,95,.55) !important;
  font-size:18px !important;
}
.contact-details-travel,
.contact-actions-travel{
  padding:34px !important;
  background:rgba(255,255,255,.84) !important;
}
.contact-details-travel{
  border-left:1px dashed rgba(0,52,155,.22) !important;
  border-right:1px dashed rgba(0,52,155,.22) !important;
}
.contact-list-travel{
  display:grid !important;
  gap:18px !important;
}
.contact-line{
  display:grid !important;
  grid-template-columns:42px 1fr !important;
  gap:12px !important;
  align-items:start !important;
}
.contact-line span{
  width:42px !important;
  height:42px !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  border-radius:14px !important;
  color:white !important;
  background:#003fa5 !important;
  font-weight:900 !important;
  font-family:'Montserrat',Arial,sans-serif !important;
}
.contact-line strong{
  display:block !important;
  font-family:'Montserrat',Arial,sans-serif !important;
  color:#062b69 !important;
  font-size:15px !important;
  margin-bottom:3px !important;
}
.contact-line p{
  color:#244a78 !important;
  font-size:15px !important;
  line-height:1.45 !important;
  margin:0 !important;
  overflow-wrap:anywhere !important;
}
.contact-actions-travel{
  display:flex !important;
  flex-direction:column !important;
  justify-content:center !important;
}
.contact-actions-travel .contact-button{
  margin-top:12px !important;
}
@media(max-width:980px){
  .about-hero-content{transform:none !important;}
  .about-experience-section{grid-template-columns:1fr !important;}
  .contact-travel-panel{grid-template-columns:1fr !important;margin-left:18px !important;margin-right:18px !important;}
  .contact-details-travel{border-left:0 !important;border-right:0 !important;border-top:1px dashed rgba(0,52,155,.22) !important;border-bottom:1px dashed rgba(0,52,155,.22) !important;}
}
@media(max-width:700px){
  .about-travel-hero{min-height:320px !important;}
  .about-hero-content{padding:32px 18px 42px !important;}
  .about-hero-content h1 em{letter-spacing:1px !important;}
  .about-experience-section{padding:0 16px !important;margin-top:30px !important;}
  .experience-feature-grid{grid-template-columns:1fr !important;}
  .experience-tile.wide-tile{grid-template-columns:1fr !important;text-align:center !important;}
  .wide-tile .tile-icon{margin:0 auto 16px !important;}
  .contact-board,.contact-details-travel,.contact-actions-travel{padding:28px 22px !important;}
  .board-title{font-size:44px !important;}
}

.card-link{display:block;color:inherit}
