/* =====================================================
   Azzurro Charter — Editorial cream/sand system v2
   Polished build: bilingual safe, hero rebuilt, mobile clean.
   ===================================================== */
:root{
  /* Color */
  --paper:#f4ede0;
  --paper-2:#ede4d2;
  --paper-3:#e3d9c4;
  --ivory:#faf6ec;

  --ink:#1a1d1f;
  --ink-2:#33363a;
  --ink-soft:#5e5b53;
  --ink-faint:#8a857a;

  --sea:#1d3a4a;
  --sea-2:#2a546b;
  --sea-l:#a8c4cf;
  --brass:#a98349;
  --brass-l:#c8a974;

  --line:rgba(26,29,31,.12);
  --line-strong:rgba(26,29,31,.22);
  --line-sea:rgba(29,58,74,.22);

  --serif:'Fraunces','Cormorant Garamond',Georgia,serif;
  --sans:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;

  --gutter:max(28px,4.5vw);
  --ease:cubic-bezier(.22,.61,.36,1);
  --ease-out:cubic-bezier(.16,1,.3,1);
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;background:var(--paper);scroll-padding-top:140px}
body{
  margin:0;background:var(--paper);color:var(--ink);
  font-family:var(--sans);font-weight:400;font-size:16.5px;line-height:1.65;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;
  font-feature-settings:"ss01","cv11";
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
::selection{background:var(--sea);color:var(--paper)}
button{font:inherit;cursor:pointer}

/* ================================================================
   BILINGUAL — scope hide rules to the OTHER language only.
   Visible-language elements keep their natural display
   (so .btn stays inline-flex, h1 stays block, etc.)
   ================================================================ */
html:not([lang="en"]) [data-lang-en]{display:none !important}
html[lang="en"] [data-lang-it]{display:none !important}

/* ----- Type ----- */
h1,h2,h3,h4,.display{
  font-family:var(--serif);
  font-weight:300;
  letter-spacing:-.012em;
  margin:0;color:var(--ink);
  font-variation-settings:"opsz" 144,"SOFT" 50;
}
em,.italic{font-style:italic}
h1 em,h2 em,h3 em{font-weight:300;color:var(--sea)}

p{margin:0 0 1em;color:var(--ink-2)}

.eyebrow{
  display:inline-flex;align-items:center;gap:12px;
  font-family:var(--sans);font-size:.66rem;font-weight:500;
  letter-spacing:.34em;text-transform:uppercase;
  color:var(--ink-faint);
}
.eyebrow::before{content:"";width:30px;height:1px;background:currentColor;opacity:.7;flex:0 0 30px}
.eyebrow.center{justify-content:center}
.eyebrow.center::after{content:"";width:30px;height:1px;background:currentColor;opacity:.7;flex:0 0 30px}

/* ----- Layout ----- */
.wrap{width:min(1320px,calc(100vw - 2*var(--gutter)));margin:0 auto}
.narrow{width:min(880px,calc(100vw - 2*var(--gutter)));margin:0 auto}
section{position:relative}

/* ----- Buttons ----- */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 26px;border-radius:0;
  font-family:var(--sans);font-size:.7rem;font-weight:500;
  letter-spacing:.24em;text-transform:uppercase;
  transition:transform .25s var(--ease), background .35s var(--ease), color .35s var(--ease), border-color .35s var(--ease);
  border:1px solid transparent;position:relative;
  text-align:center;line-height:1.3;
}
.btn.solid{background:var(--ink);color:var(--paper)}
.btn.solid:hover{background:var(--sea);color:var(--paper)}
.btn.outline{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn.outline:hover{background:var(--ink);color:var(--paper)}
.btn.outline.light{color:var(--paper);border-color:rgba(244,237,224,.7)}
.btn.outline.light:hover{background:var(--paper);color:var(--ink);border-color:var(--paper)}
.btn.solid.sea{background:var(--sea)}
.btn.solid.sea:hover{background:var(--ink)}
.btn .arrow{display:inline-block;transition:transform .35s var(--ease)}
.btn:hover .arrow{transform:translateX(6px)}

/* ----- Inline link ----- */
.ilink{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--sans);font-size:.7rem;font-weight:500;
  letter-spacing:.26em;text-transform:uppercase;
  color:var(--ink);padding-bottom:6px;
  border-bottom:1px solid var(--ink);
  transition:gap .3s var(--ease),color .3s var(--ease),border-color .3s var(--ease);
}
.ilink:hover{gap:18px;color:var(--sea);border-color:var(--sea)}
.ilink.light{color:var(--paper);border-color:var(--paper)}
.ilink.light:hover{color:var(--sea-l);border-color:var(--sea-l)}

/* =================
   UTILITY BAR
   ================= */
.utility{
  background:var(--ink);color:var(--paper);
  font-size:.64rem;letter-spacing:.3em;text-transform:uppercase;
  padding:9px 0;border-bottom:1px solid rgba(244,237,224,.12);
  position:relative;z-index:65;
}
.utility-inner{
  display:flex;align-items:center;justify-content:space-between;gap:14px;
  flex-wrap:wrap;
}
.utility-left{display:flex;align-items:center;gap:18px;color:rgba(244,237,224,.82);flex-wrap:wrap}
.utility-left a{color:inherit;transition:color .25s}
.utility-left a:hover{color:var(--paper)}
.utility-left .dot{width:3px;height:3px;border-radius:50%;background:var(--brass-l);opacity:.7;flex:0 0 auto}
.utility-right{display:flex;align-items:center;gap:14px}
.lang-toggle{display:inline-flex;background:rgba(244,237,224,.06);border:1px solid rgba(244,237,224,.18);border-radius:999px;padding:2px;gap:0}
.lang-toggle button{
  background:none;border:0;color:rgba(244,237,224,.62);
  padding:4px 10px;font-size:.6rem;letter-spacing:.3em;
  border-radius:999px;cursor:pointer;transition:all .25s;font-weight:600;
}
.lang-toggle button.active{background:var(--paper);color:var(--ink)}
@media (max-width:720px){
  .utility-left{gap:12px;font-size:.58rem;letter-spacing:.2em}
  .utility-left .hide-sm,.utility-left .dot.hide-sm{display:none}
}
/* On phones the dark utility bar reads like a fake browser chrome — hide it. */
@media (max-width:760px){
  .utility{display:none}
}

/* =================
   NAV
   ================= */
.nav{
  position:sticky;top:0;z-index:60;
  background:rgba(244,237,224,.94);
  backdrop-filter:saturate(150%) blur(14px);
  -webkit-backdrop-filter:saturate(150%) blur(14px);
  border-bottom:1px solid var(--line);
  transition:padding .35s var(--ease);
}
.nav-inner{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:14px 0;min-height:64px}
.brand{display:flex;align-items:center;gap:12px;color:var(--ink);flex:0 0 auto}
.brand img{height:36px;width:auto;display:block}
.nav-links{display:flex;align-items:center;gap:30px}
.nav-links a{
  color:var(--ink);font-size:.7rem;font-weight:500;
  letter-spacing:.22em;text-transform:uppercase;
  transition:color .25s;position:relative;padding:6px 0;
  white-space:nowrap;
}
.nav-links a::after{
  content:"";position:absolute;left:0;right:0;bottom:0;
  height:1px;background:var(--ink);
  transform:scaleX(0);transform-origin:right;
  transition:transform .35s var(--ease);
}
.nav-links a:hover,.nav-links a.current{color:var(--sea)}
.nav-links a:hover::after,.nav-links a.current::after{transform:scaleX(1);transform-origin:left;background:var(--sea)}
.nav-cta{display:flex;align-items:center;gap:12px;flex:0 0 auto}
.nav-cta .btn{padding:11px 20px;font-size:.66rem}

/* In-nav language toggle (desktop hidden, shown on mobile when utility is hidden) */
.nav-lang{
  display:none;
  background:transparent;border:1px solid var(--line);
  border-radius:999px;padding:2px;
}
.nav-lang button{
  background:none;border:0;color:var(--ink-faint);
  padding:5px 10px;font-size:.6rem;letter-spacing:.3em;font-weight:600;
  border-radius:999px;cursor:pointer;transition:all .25s;
}
.nav-lang button.active{background:var(--ink);color:var(--paper)}
@media (max-width:760px){
  .nav-lang{display:inline-flex}
}

/* Inline phone CTA — surfaced inside hamburger menu only on mobile, never duplicated in main nav */
.nav-phone{display:none}

/* In-nav contact block — only visible inside the open mobile menu */
.menu-contact{display:none}

.menu-toggle{display:none;background:none;border:none;color:var(--ink);cursor:pointer;padding:6px;width:38px;height:38px;position:relative;flex:0 0 auto}
.menu-toggle span{display:block;width:22px;height:1.5px;background:currentColor;margin:5px auto;transition:transform .3s,opacity .3s}
.nav.open .menu-toggle span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.nav.open .menu-toggle span:nth-child(2){opacity:0}
.nav.open .menu-toggle span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

@media (max-width:1080px){
  .nav-links{gap:22px}
  .nav-links a{font-size:.66rem;letter-spacing:.2em}
}
@media (max-width:960px){
  .nav-links{display:none}
  .menu-toggle{display:block}
  .nav.open .nav-links{
    display:flex;flex-direction:column;gap:0;align-items:flex-start;
    position:absolute;top:100%;left:0;right:0;
    background:var(--paper);padding:24px var(--gutter) 32px;
    border-bottom:1px solid var(--line);
    box-shadow:0 24px 50px -24px rgba(26,29,31,.18);
  }
  .nav.open .nav-links a{
    font-size:1.6rem;font-family:var(--serif);font-style:italic;
    letter-spacing:0;text-transform:none;font-weight:300;color:var(--ink);
    padding:14px 0;border-bottom:1px solid var(--line);width:100%;
  }
  .nav.open .nav-links a:last-child{border-bottom:0}
  .nav.open .nav-links a::after{display:none}
  .nav.open .nav-links .menu-contact{
    display:flex;flex-direction:column;gap:4px;width:100%;
    margin-top:14px;padding-top:18px;border-top:1px solid var(--line);
    font-family:var(--sans);font-size:.7rem;letter-spacing:.22em;
    text-transform:uppercase;color:var(--ink-faint);font-weight:500;
  }
  .nav.open .nav-links .menu-contact a{
    font-size:1rem;font-family:var(--sans);font-style:normal;
    letter-spacing:0;text-transform:none;color:var(--ink);
    padding:6px 0;border-bottom:0;
  }
}
@media (max-width:560px){
  .nav-cta .btn{padding:10px 14px;font-size:.62rem;letter-spacing:.18em}
  .brand img{height:32px}
}

/* =================
   HERO — clean rebuild
   ================= */
.hero{
  position:relative;
  min-height:min(720px,86vh);min-height:min(720px,86dvh);
  background:var(--ink);
  color:var(--paper);overflow:hidden;isolation:isolate;
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:clamp(80px,12vw,140px) 0 clamp(60px,8vw,90px);
}
.hero.short{min-height:min(560px,68vh);min-height:min(560px,68dvh);padding:clamp(80px,10vw,120px) 0 clamp(56px,6vw,80px)}
.hero-bg{
  position:absolute;inset:0;z-index:-2;
  background-position:50% 35%;background-size:cover;background-repeat:no-repeat;
  background-color:var(--ink);
  transform:scale(1.04);
  animation:slowZoom 22s ease-out forwards;will-change:transform;
}
@keyframes slowZoom{to{transform:scale(1)}}
.hero::after{
  content:"";position:absolute;inset:0;z-index:-1;
  background:
    linear-gradient(90deg,rgba(26,29,31,.78) 0%,rgba(26,29,31,.45) 35%,rgba(26,29,31,.10) 65%,rgba(26,29,31,.05) 100%),
    linear-gradient(180deg,rgba(26,29,31,.30) 0%,rgba(26,29,31,.10) 40%,rgba(26,29,31,.55) 75%,rgba(26,29,31,.92) 100%);
}
@media (max-width:780px){
  .hero::after{
    background:
      linear-gradient(180deg,rgba(26,29,31,.55) 0%,rgba(26,29,31,.35) 22%,rgba(26,29,31,.62) 48%,rgba(26,29,31,.86) 78%,rgba(26,29,31,.96) 100%);
  }
  .hero h1{text-shadow:0 2px 28px rgba(0,0,0,.45)}
  .hero p.lead{text-shadow:0 1px 14px rgba(0,0,0,.6)}
}
.hero .eyebrow{color:rgba(244,237,224,.86)}
.hero h1{
  color:var(--paper);
  font-size:clamp(2.4rem,7vw,6.4rem);
  line-height:.98;letter-spacing:-.018em;
  font-weight:300;max-width:18ch;margin:18px 0 24px;
  font-variation-settings:"opsz" 144,"SOFT" 80;
  text-wrap:balance;
}
.hero h1 em{color:var(--paper);font-style:italic}
.hero p.lead{
  color:rgba(244,237,224,.88);max-width:54ch;
  font-size:clamp(1rem,1.3vw,1.18rem);line-height:1.6;font-weight:300;
}
.hero .ctas{display:flex;flex-wrap:wrap;gap:12px;margin-top:32px}
.hero .ctas .btn{padding:14px 24px}
.hero-meta{
  display:flex;flex-wrap:wrap;gap:14px 28px;
  margin-top:42px;padding-top:26px;
  border-top:1px solid rgba(244,237,224,.18);
  font-size:.6rem;letter-spacing:.32em;
  text-transform:uppercase;color:rgba(244,237,224,.72);
}
.hero-meta span{display:flex;align-items:center;gap:9px}
.hero-meta span::before{content:"";width:5px;height:5px;border-radius:50%;background:var(--brass-l);flex:0 0 auto}

.hero-rail{
  position:absolute;right:24px;top:50%;
  transform:translateY(-50%) rotate(90deg);transform-origin:right top;
  font-size:.58rem;letter-spacing:.42em;text-transform:uppercase;
  color:rgba(244,237,224,.7);white-space:nowrap;display:flex;align-items:center;gap:14px;
  pointer-events:none;
}
.hero-rail::before{content:"";width:60px;height:1px;background:var(--brass-l)}
@media (max-width:1400px){.hero-rail{display:none}}

/* short hero variants — smaller text */
.hero.short h1{font-size:clamp(2.2rem,5.6vw,5rem);margin-bottom:20px}
.hero.short p.lead{max-width:60ch}

@media (max-width:600px){
  .hero{padding-top:80px;padding-bottom:54px}
  .hero h1{font-size:clamp(2rem,9vw,3.2rem);margin:14px 0 18px}
  .hero p.lead{font-size:.98rem}
  .hero .ctas{gap:10px;margin-top:26px;width:100%}
  .hero .ctas .btn{flex:1 1 auto;justify-content:center;padding:13px 18px;font-size:.66rem;letter-spacing:.18em}
  .hero-meta{margin-top:32px;padding-top:22px;gap:10px 18px;font-size:.55rem;letter-spacing:.24em}
}

/* =================
   SECTION
   ================= */
.sec{padding:clamp(72px,10vw,140px) 0;position:relative}
.sec.tight{padding:clamp(56px,7vw,100px) 0}
.sec.paper-2{background:var(--paper-2)}
.sec.ink{background:var(--ink);color:var(--paper)}
.sec.ink h1,.sec.ink h2,.sec.ink h3,.sec.ink h4{color:var(--paper)}
.sec.ink h1 em,.sec.ink h2 em,.sec.ink h3 em{color:var(--brass-l)}
.sec.ink p{color:rgba(244,237,224,.78)}
.sec.ink .eyebrow{color:var(--brass-l)}
.sec.sea{background:var(--sea);color:var(--paper)}
.sec.sea h1,.sec.sea h2,.sec.sea h3{color:var(--paper)}
.sec.sea h1 em,.sec.sea h2 em,.sec.sea h3 em{color:var(--brass-l)}
.sec.sea p{color:rgba(244,237,224,.86)}
.sec.sea .eyebrow{color:var(--brass-l)}

.sec-head{display:grid;grid-template-columns:1fr 1.3fr;gap:60px;align-items:flex-end;margin-bottom:64px}
@media (max-width:920px){.sec-head{grid-template-columns:1fr;gap:18px;margin-bottom:44px}}
.sec-head h2{
  font-size:clamp(2.1rem,5vw,4.4rem);line-height:1.02;
  letter-spacing:-.018em;
  font-variation-settings:"opsz" 144,"SOFT" 60;
  text-wrap:balance;
}
.sec-head .head-r{padding-bottom:6px}
.sec-head .head-r p{max-width:54ch;font-size:1rem;color:var(--ink-2)}
.sec.ink .sec-head .head-r p,.sec.sea .sec-head .head-r p{color:rgba(244,237,224,.8)}

.divider{height:1px;background:var(--line);margin:0 auto;width:min(1320px,calc(100vw - 2*var(--gutter)))}

/* =================
   FLEET CARDS (home)
   ================= */
.fleet-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:48px 40px}
@media (max-width:880px){.fleet-grid{grid-template-columns:1fr;gap:42px}}
.fleet-card{display:flex;flex-direction:column;gap:14px;cursor:pointer;color:var(--ink)}
.fleet-card .img{
  position:relative;aspect-ratio:5/4;overflow:hidden;
  background:var(--paper-2);
}
.fleet-card .img img{
  width:100%;height:100%;object-fit:cover;object-position:center 45%;
  transition:transform 1.6s var(--ease-out);
}
.fleet-card:hover .img img{transform:scale(1.05)}
.fleet-card .img::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(180deg,transparent 55%,rgba(26,29,31,.32) 100%);
}
.fleet-card .corner{
  position:absolute;top:16px;left:16px;z-index:2;
  background:rgba(244,237,224,.94);color:var(--ink);
  padding:6px 11px;font-size:.58rem;letter-spacing:.3em;text-transform:uppercase;font-weight:500;
  backdrop-filter:blur(6px);
}
.fleet-card .price{
  position:absolute;bottom:16px;right:16px;z-index:2;
  background:rgba(26,29,31,.78);color:var(--paper);
  padding:8px 13px;font-size:.6rem;letter-spacing:.24em;text-transform:uppercase;
  backdrop-filter:blur(6px);font-weight:500;
  max-width:calc(100% - 32px);
}
.fleet-card .price b{color:var(--brass-l);font-weight:600;letter-spacing:.04em}
/* When fleet cards become single column, the absolute price tag risks bleeding
   off the right edge — drop it below the image and centre the boat with a 4:3 crop
   matching the source ratio. */
@media (max-width:880px){
  .fleet-card .img{aspect-ratio:4/3}
  .fleet-card .img img{object-position:center 50%}
  .fleet-card .price{
    position:static;display:inline-flex;align-self:flex-start;
    background:var(--ink);
    margin-top:-4px;
    max-width:none;
  }
  .fleet-card .corner{top:12px;left:12px;font-size:.55rem;padding:5px 9px}
}
.fleet-card h3{font-size:clamp(1.5rem,2.4vw,2.2rem);line-height:1.06;font-weight:300;margin:4px 0 0}
.fleet-card .meta{
  display:flex;gap:16px;flex-wrap:wrap;
  font-size:.62rem;letter-spacing:.26em;text-transform:uppercase;
  color:var(--ink-faint);font-weight:500;
}
.fleet-card .meta span{display:inline-flex;align-items:center;gap:8px}
.fleet-card .meta span::before{content:"";width:4px;height:4px;border-radius:50%;background:var(--sea);flex:0 0 auto}
.fleet-card .desc{color:var(--ink-2);font-size:.95rem;line-height:1.55;max-width:48ch;margin:0}

/* Boat block — wraps each .vessel + .v-gallery on the fleet page */
.boat-block{
  padding:clamp(40px,6vw,84px) 0;
  position:relative;
  scroll-margin-top:120px;
}
.boat-block + .boat-block{
  border-top:1px solid var(--line);
}
.boat-block::before{
  content:"";
  position:absolute;
  top:-1px;left:50%;transform:translateX(-50%);
  width:46px;height:1px;
  background:var(--brass-l);
}
.boat-block:first-of-type{padding-top:clamp(28px,4vw,56px)}
.boat-block:first-of-type::before{display:none}

.boat-block .vessel{border-top:0;margin:0}
.boat-block .v-gallery{border-bottom:0;margin-top:1px;background:var(--paper-2)}
.boat-block .v-gallery .g-item{background:var(--paper-3)}

/* Detail row (full fleet / destinations page) */
.vessel{
  display:grid;grid-template-columns:1fr 1fr;gap:0;align-items:stretch;
  border-top:1px solid var(--line);background:var(--paper);
  min-height:clamp(440px,46vw,620px);
}
.vessel.reverse .v-img{order:2}
@media (max-width:920px){
  .vessel{grid-template-columns:1fr;min-height:0}
  .vessel.reverse .v-img{order:0}
}
.v-img{
  position:relative;overflow:hidden;
  background:var(--paper-2);
  min-height:340px;
}
.v-img img{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;object-position:center 45%;
  transition:transform 1.6s var(--ease-out);
}
@media (max-width:920px){
  .v-img{aspect-ratio:5/4;min-height:0}
  .v-img img{position:relative;inset:auto}
}
.v-img:hover img{transform:scale(1.04)}
.v-img .badge{
  position:absolute;top:22px;left:22px;z-index:2;
  background:rgba(244,237,224,.94);color:var(--ink);
  padding:8px 13px;font-size:.6rem;letter-spacing:.3em;text-transform:uppercase;font-weight:500;
  backdrop-filter:blur(6px);
}
.v-body{
  padding:clamp(36px,5.5vw,72px) clamp(28px,4vw,60px);
  display:flex;flex-direction:column;justify-content:center;gap:14px;
}
.v-num{
  font-family:var(--serif);font-style:italic;font-weight:300;
  font-size:.95rem;color:var(--sea);
  display:flex;align-items:center;gap:14px;
}
.v-num::before{content:"";flex:0 0 44px;height:1px;background:var(--sea)}
.v-body h3{font-size:clamp(1.7rem,3vw,2.8rem);line-height:1.04;font-weight:300}
.v-body .lead{
  font-family:var(--serif);font-style:italic;font-size:1.15rem;
  line-height:1.45;color:var(--sea);font-weight:300;max-width:38ch;margin:4px 0 8px;
}
.v-body p{color:var(--ink-2);font-size:.96rem;line-height:1.6;max-width:54ch;margin:0 0 1em}
.v-spec{
  list-style:none;padding:0;margin:14px 0 6px;
  display:grid;grid-template-columns:repeat(2,1fr);gap:14px 28px;
  border-top:1px solid var(--line);padding-top:22px;
}
.v-spec li{display:flex;flex-direction:column;gap:3px}
.v-spec li b{
  font-size:.58rem;letter-spacing:.28em;text-transform:uppercase;
  color:var(--ink-faint);font-weight:500;
}
.v-spec li span{font-family:var(--serif);font-size:1rem;font-weight:300;color:var(--ink);font-style:italic}
/* Tabs inside each boat body (Info · Specifiche · Equipaggiamento · Prezzi) */
.v-tabs{
  display:flex;flex-wrap:wrap;gap:0;
  margin:8px 0 22px;
  border-bottom:1px solid var(--line);
}
.v-tabs button{
  background:none;border:0;
  padding:12px 0;margin-right:24px;
  font-family:var(--sans);font-size:.66rem;font-weight:500;
  letter-spacing:.26em;text-transform:uppercase;
  color:var(--ink-faint);
  cursor:pointer;position:relative;
  transition:color .25s var(--ease);
}
.v-tabs button:last-child{margin-right:0}
.v-tabs button::after{
  content:"";position:absolute;left:0;right:0;bottom:-1px;height:2px;
  background:var(--sea);transform:scaleX(0);transform-origin:left;
  transition:transform .35s var(--ease);
}
.v-tabs button:hover{color:var(--ink)}
.v-tabs button.active{color:var(--sea)}
.v-tabs button.active::after{transform:scaleX(1)}

.v-pane{display:none;animation:paneFade .35s var(--ease-out)}
.v-pane.active{display:block}
@keyframes paneFade{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}

.v-pane p{color:var(--ink-2);font-size:.96rem;line-height:1.6;max-width:54ch;margin:0 0 1em}
.v-pane p:last-child{margin-bottom:0}

/* Equipment list (two columns when wide) */
.v-equip{
  display:grid;grid-template-columns:1fr 1fr;gap:36px 30px;
  margin:0;
}
@media (max-width:560px){.v-equip{grid-template-columns:1fr;gap:24px}}
.v-equip h4{
  font-size:.6rem;letter-spacing:.32em;text-transform:uppercase;
  color:var(--ink-faint);font-weight:500;font-family:var(--sans);
  margin-bottom:14px;padding-bottom:10px;border-bottom:1px solid var(--line);
}
.v-equip ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}
.v-equip li{
  font-family:var(--serif);font-style:italic;font-weight:300;
  font-size:.96rem;color:var(--ink-2);line-height:1.5;
  padding-left:18px;position:relative;
}
.v-equip li::before{
  content:"";position:absolute;left:0;top:.65em;
  width:10px;height:1px;background:var(--sea);
}

/* Price table */
.v-prices{margin:0}
.v-prices table{
  width:100%;border-collapse:collapse;
  font-family:var(--sans);font-size:.92rem;
}
.v-prices thead th{
  text-align:left;padding:10px 0;
  font-size:.58rem;letter-spacing:.3em;text-transform:uppercase;
  color:var(--ink-faint);font-weight:500;
  border-bottom:1px solid var(--line);
}
.v-prices thead th:last-child{text-align:right}
.v-prices tbody td{
  padding:11px 0;border-bottom:1px solid var(--line);
  color:var(--ink-2);font-size:.94rem;
}
.v-prices tbody td.amt{
  text-align:right;
  font-family:var(--serif);font-style:italic;
  color:var(--sea);font-size:1.04rem;font-weight:300;
}
.v-prices tbody tr.peak td{color:var(--ink)}
.v-prices tbody tr.peak td.amt{color:var(--brass);font-weight:500}
.v-prices tbody tr:last-child td{border-bottom:0}

.v-prices .opts{
  margin-top:24px;padding-top:18px;
  border-top:1px solid var(--line);
}
.v-prices .opts h4{
  font-size:.6rem;letter-spacing:.32em;text-transform:uppercase;
  color:var(--ink-faint);font-weight:500;font-family:var(--sans);margin-bottom:12px;
}
.v-prices .opts ul{
  list-style:none;padding:0;margin:0;
  display:grid;grid-template-columns:1fr 1fr;gap:8px 24px;
}
@media (max-width:560px){.v-prices .opts ul{grid-template-columns:1fr}}
.v-prices .opts li{
  display:flex;justify-content:space-between;gap:14px;
  font-size:.88rem;color:var(--ink-2);
  padding:6px 0;border-bottom:1px dotted var(--line);
}
.v-prices .opts li b{
  font-family:var(--serif);font-style:italic;font-weight:300;
  color:var(--sea);
}
.v-prices .note{
  margin-top:18px;
  font-family:var(--serif);font-style:italic;font-size:.82rem;
  color:var(--ink-faint);line-height:1.5;
}

.v-cta-row{
  display:flex;gap:18px 24px;flex-wrap:wrap;align-items:center;
  margin-top:18px;padding-top:20px;border-top:1px solid var(--line);
  justify-content:space-between;
}
.v-cta-row .price-band{
  font-family:var(--serif);font-style:italic;font-size:1.05rem;
  color:var(--sea);line-height:1.45;
  flex:1 1 220px;min-width:0;
  display:flex;flex-direction:column;gap:2px;
}
.v-cta-row .price-band .row-1{display:inline-flex;align-items:baseline;gap:6px;flex-wrap:wrap}
.v-cta-row .price-band .from{font-style:italic;color:var(--ink-faint);font-size:.66rem;letter-spacing:.28em;text-transform:uppercase;font-weight:500;font-family:var(--sans)}
.v-cta-row .price-band strong{font-style:normal;font-weight:500;color:var(--ink);font-size:1.4rem;font-family:var(--serif)}
.v-cta-row .price-band .per{font-style:italic;color:var(--ink-faint);font-size:.85rem}
.v-cta-row .price-band .peak{font-size:.82rem;color:var(--ink-faint);font-style:italic;letter-spacing:.01em}
.v-cta-row .price-band .peak b{color:var(--brass);font-weight:500;font-style:normal}
.v-cta-row .btn{flex:0 0 auto}
.v-cta-row .price-band{
  font-family:var(--serif);font-style:italic;font-size:1.05rem;color:var(--sea);
  flex:1 1 auto;min-width:240px;line-height:1.4;
}
.v-cta-row .price-band strong{font-style:normal;font-weight:500}

@media (max-width:540px){
  .v-spec{grid-template-columns:1fr 1fr;gap:14px 16px}
  .v-body{padding:34px 22px 40px}
}

/* =================
   PER-BOAT GALLERY (under each .vessel row)
   ================= */
.v-gallery{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:0;
  background:var(--paper-2);
  border-bottom:1px solid var(--line);
}
.v-gallery .g-item{
  display:block;
  overflow:hidden;
  aspect-ratio:4/3;
  background:var(--paper-3);
  position:relative;
  cursor:zoom-in;
  border-right:1px solid var(--line);
}
.v-gallery .g-item:last-child{border-right:0}
.v-gallery .g-item img{
  width:100%;height:100%;
  object-fit:cover;object-position:center 50%;
  transition:transform 1.6s var(--ease-out), filter .4s var(--ease);
  display:block;
}
.v-gallery .g-item:hover img{transform:scale(1.05);filter:brightness(.94)}
.v-gallery .g-item::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(180deg,transparent 70%,rgba(26,29,31,.18) 100%);
}
.v-gallery .g-item .zoom{
  position:absolute;top:14px;right:14px;
  width:34px;height:34px;border-radius:50%;
  background:rgba(244,237,224,.92);color:var(--ink);
  display:grid;place-items:center;
  opacity:0;transform:translateY(-4px);
  transition:opacity .3s var(--ease),transform .3s var(--ease);
  pointer-events:none;
}
.v-gallery .g-item:hover .zoom{opacity:1;transform:translateY(0)}
.v-gallery .g-item .zoom svg{width:14px;height:14px;stroke:currentColor;stroke-width:1.6;fill:none}

@media (max-width:780px){
  .v-gallery{
    display:flex;
    overflow-x:auto;
    scroll-snap-type:x mandatory;
    -webkit-overflow-scrolling:touch;
  }
  .v-gallery::-webkit-scrollbar{height:0}
  .v-gallery .g-item{
    flex:0 0 78%;
    scroll-snap-align:start;
    border-right:1px solid var(--line);
    aspect-ratio:4/3;
  }
}

/* Lightbox */
.lightbox{
  position:fixed;inset:0;z-index:200;
  background:rgba(8,9,11,.94);
  display:none;align-items:center;justify-content:center;
  padding:max(48px,5vw);
  opacity:0;transition:opacity .35s var(--ease);
}
.lightbox.open{display:flex;opacity:1}
.lightbox img{
  max-width:100%;max-height:100%;
  object-fit:contain;
  box-shadow:0 30px 80px rgba(0,0,0,.6);
}
.lightbox .lb-close{
  position:absolute;top:24px;right:24px;
  width:46px;height:46px;border-radius:50%;
  background:rgba(244,237,224,.12);border:1px solid rgba(244,237,224,.2);
  color:var(--paper);display:grid;place-items:center;cursor:pointer;
  transition:background .25s,transform .25s;
}
.lightbox .lb-close:hover{background:rgba(244,237,224,.2);transform:scale(1.05)}
.lightbox .lb-close svg{width:18px;height:18px;stroke:currentColor;stroke-width:1.6;fill:none}
.lightbox .lb-nav{
  position:absolute;top:50%;transform:translateY(-50%);
  width:54px;height:54px;border-radius:50%;
  background:rgba(244,237,224,.1);border:1px solid rgba(244,237,224,.18);
  color:var(--paper);display:grid;place-items:center;cursor:pointer;
  transition:background .25s,transform .25s;
}
.lightbox .lb-nav:hover{background:rgba(244,237,224,.2)}
.lightbox .lb-prev{left:24px}
.lightbox .lb-next{right:24px}
.lightbox .lb-nav svg{width:20px;height:20px;stroke:currentColor;stroke-width:1.6;fill:none}
.lightbox .lb-counter{
  position:absolute;bottom:28px;left:50%;transform:translateX(-50%);
  font-family:var(--serif);font-style:italic;font-weight:300;
  color:rgba(244,237,224,.7);font-size:.95rem;
}
@media (max-width:640px){
  .lightbox{padding:24px}
  .lightbox .lb-nav{width:42px;height:42px}
  .lightbox .lb-prev{left:12px}
  .lightbox .lb-next{right:12px}
  .lightbox .lb-close{top:14px;right:14px;width:40px;height:40px}
}

/* =================
   DESTINATION CARDS
   ================= */
.dest-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
@media (max-width:980px){.dest-grid{grid-template-columns:repeat(2,1fr);gap:22px}}
@media (max-width:600px){.dest-grid{grid-template-columns:1fr;gap:22px}}
.dest-card{position:relative;overflow:hidden;aspect-ratio:1/1;color:var(--paper);background:var(--ink);display:block}
.dest-card img{width:100%;height:100%;object-fit:cover;object-position:center 45%;transition:transform 1.6s var(--ease-out)}
.dest-card:hover img{transform:scale(1.06)}
.dest-card::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(180deg,rgba(26,29,31,.10) 0%,rgba(26,29,31,.10) 35%,rgba(26,29,31,.85) 100%);
}
.dest-card .body{
  position:absolute;left:0;right:0;bottom:0;padding:24px 22px;z-index:2;
}
.dest-card .num{
  font-family:var(--serif);font-style:italic;font-size:.9rem;color:var(--brass-l);margin-bottom:6px;
}
.dest-card h3{
  color:var(--paper);font-size:clamp(1.5rem,2.2vw,2rem);
  line-height:1.05;font-weight:300;margin-bottom:6px;
}
.dest-card p{
  color:rgba(244,237,224,.86);font-size:.84rem;line-height:1.5;max-width:34ch;margin:0;
}

/* =================
   SERVICES GRID
   ================= */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid var(--line);border-left:1px solid var(--line)}
@media (max-width:880px){.svc-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.svc-grid{grid-template-columns:1fr}}
.svc{
  padding:32px 28px;border-right:1px solid var(--line);border-bottom:1px solid var(--line);
  display:flex;flex-direction:column;gap:12px;background:var(--paper);
  transition:background .35s var(--ease);
}
.svc:hover{background:var(--ivory)}
.svc h3{font-size:1.2rem;line-height:1.18;font-weight:300}
.svc p{color:var(--ink-2);font-size:.92rem;line-height:1.55;margin:0}
.svc .num{font-family:var(--serif);font-style:italic;font-size:.88rem;color:var(--sea-2);margin-bottom:-2px}

/* =================
   QUOTE / MANIFESTO
   ================= */
.quote-block{
  text-align:center;max-width:880px;margin:0 auto;
}
.quote-block .mark{font-family:var(--serif);font-size:3.6rem;color:var(--brass-l);line-height:.4;margin-bottom:18px;font-style:italic}
.quote-block blockquote{
  font-family:var(--serif);font-style:italic;font-weight:300;
  font-size:clamp(1.5rem,3vw,2.4rem);line-height:1.32;letter-spacing:-.005em;
  color:var(--paper);margin:0 0 28px;text-wrap:balance;
}
.quote-block blockquote em{color:var(--brass-l)}
.quote-block .by{
  font-size:.62rem;letter-spacing:.36em;text-transform:uppercase;
  color:rgba(244,237,224,.6);font-weight:500;
}

.man{display:grid;grid-template-columns:5fr 7fr;gap:70px;align-items:center}
@media (max-width:920px){.man{grid-template-columns:1fr;gap:38px}}
.man-img{
  position:relative;overflow:hidden;background:var(--paper-2);
  aspect-ratio:4/5;
}
.man-img img{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;object-position:center 45%;
  transition:transform 1.6s var(--ease-out);
}
.man-img:hover img{transform:scale(1.04)}
.man-copy h2{font-size:clamp(2rem,4.2vw,3.4rem);line-height:1.04;margin:14px 0 22px;text-wrap:balance}
.man-copy .lead{
  font-family:var(--serif);font-style:italic;font-size:1.4rem;line-height:1.4;
  color:var(--sea);margin-bottom:24px;max-width:32ch;
  padding-left:22px;border-left:1px solid var(--sea);
}
.man-copy p{color:var(--ink-2);font-size:.98rem;max-width:54ch;margin:0 0 1em}
.man-copy p:first-of-type::first-letter{
  font-family:var(--serif);font-style:italic;font-weight:300;
  font-size:3rem;float:left;line-height:.85;margin:6px 10px 0 0;color:var(--sea);
}

/* =================
   STATS
   ================= */
.stats{
  display:grid;grid-template-columns:repeat(4,1fr);gap:0;
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
}
@media (max-width:880px){.stats{grid-template-columns:repeat(2,1fr)}}
.stat{
  padding:42px 24px;border-right:1px solid var(--line);
  display:flex;flex-direction:column;gap:6px;align-items:flex-start;
}
.stat:last-child{border-right:0}
@media (max-width:880px){
  .stat:nth-child(2n){border-right:0}
  .stat:nth-child(-n+2){border-bottom:1px solid var(--line)}
}
.stat .n{font-family:var(--serif);font-size:clamp(2.2rem,4.2vw,3.6rem);font-weight:300;line-height:.95;color:var(--ink)}
.stat .n em{font-style:italic;color:var(--sea)}
.stat .l{font-size:.62rem;letter-spacing:.3em;text-transform:uppercase;color:var(--ink-faint);font-weight:500;line-height:1.3}

/* =================
   MARINAS
   ================= */
.marinas{display:grid;grid-template-columns:repeat(5,1fr);gap:0;border-top:1px solid var(--line)}
@media (max-width:1100px){.marinas{grid-template-columns:repeat(3,1fr)}}
@media (max-width:680px){.marinas{grid-template-columns:repeat(2,1fr)}}
@media (max-width:420px){.marinas{grid-template-columns:1fr}}
.marina{
  padding:30px 22px;border-right:1px solid var(--line);border-bottom:1px solid var(--line);
  display:flex;flex-direction:column;gap:6px;background:var(--paper);
}
.marina:last-child{border-right:0}
.marina .region{font-size:.58rem;letter-spacing:.3em;text-transform:uppercase;color:var(--ink-faint);font-weight:500}
.marina h4{font-family:var(--serif);font-size:1.3rem;font-weight:300;color:var(--ink)}
.marina p{font-size:.82rem;color:var(--ink-2);margin:0;line-height:1.45}

/* =================
   CONTACT FORM
   ================= */
.contact-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:48px;align-items:flex-start}
@media (max-width:920px){.contact-grid{grid-template-columns:1fr;gap:40px}}

.form-panel{
  background:var(--ivory);
  border:1px solid var(--line);
  padding:clamp(28px,3.6vw,52px);
  display:flex;flex-direction:column;gap:6px;
}
.form-panel .form-head{margin-bottom:18px}
.form-panel .form-head h2{
  font-size:clamp(1.6rem,2.4vw,2.2rem);font-weight:300;line-height:1.1;margin-top:8px;
}
.form{display:flex;flex-direction:column;gap:20px}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media (max-width:560px){.form .row{grid-template-columns:1fr;gap:18px}}
.field{display:flex;flex-direction:column;gap:7px;position:relative}
.field label{
  font-size:.58rem;letter-spacing:.3em;text-transform:uppercase;color:var(--ink-faint);font-weight:500;
}
.field input,.field select,.field textarea{
  border:0;border-bottom:1.5px solid var(--line-strong);
  background:transparent;color:var(--ink);
  padding:10px 0;font:inherit;font-family:var(--sans);font-size:.98rem;
  transition:border-color .25s;border-radius:0;
  -webkit-appearance:none;-moz-appearance:textfield;appearance:none;
}
/* Native select arrow */
.field select{
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6' fill='none'><path d='M1 1l4 4 4-4' stroke='%231a1d1f' stroke-width='1.2' stroke-linecap='round'/></svg>");
  background-repeat:no-repeat;background-position:right 4px center;background-size:10px 6px;
  padding-right:22px;cursor:pointer;
}
.field input[type=number]{-moz-appearance:textfield}
.field input[type=number]::-webkit-outer-spin-button,
.field input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
.field input[type=date]::-webkit-calendar-picker-indicator{cursor:pointer;opacity:.6}
.field textarea{min-height:120px;resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--sea)}
.form-foot{
  display:flex;flex-wrap:wrap;align-items:center;gap:18px;
  margin-top:6px;padding-top:6px;
}
.form-foot .or{
  font-size:.78rem;color:var(--ink-faint);font-style:italic;font-family:var(--serif);
}
.form-foot .or a{color:var(--sea);border-bottom:1px solid var(--line-sea)}

.contact-info{
  display:flex;flex-direction:column;gap:0;
  background:var(--ink);color:var(--paper);
  padding:clamp(28px,3.4vw,42px);
}
.contact-info .info-head{margin-bottom:22px}
.contact-info h3{font-size:1.5rem;font-weight:300;color:var(--paper);margin-top:8px}
.contact-info .eyebrow{color:var(--brass-l)}
.contact-row{
  display:flex;flex-direction:column;gap:6px;
  padding:18px 0;border-bottom:1px solid rgba(244,237,224,.14);
}
.contact-row:last-child{border-bottom:0}
.contact-row .l{font-size:.58rem;letter-spacing:.3em;text-transform:uppercase;color:rgba(200,169,116,.85);font-weight:500}
.contact-row .v{font-family:var(--serif);font-style:italic;font-weight:300;font-size:1.1rem;color:var(--paper);line-height:1.45}
.contact-row .v a{color:inherit;border-bottom:1px solid rgba(244,237,224,.2);transition:border-color .2s}
.contact-row .v a:hover{border-color:var(--brass-l)}

/* =================
   FOOTER
   ================= */
.footer{background:var(--ink);color:var(--paper);padding:80px 0 32px}
.footer .grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:48px;margin-bottom:48px}
@media (max-width:920px){.footer .grid{grid-template-columns:1fr 1fr;gap:36px}}
@media (max-width:520px){.footer .grid{grid-template-columns:1fr}}
.footer h4{font-size:.66rem;letter-spacing:.32em;text-transform:uppercase;color:var(--brass-l);font-weight:500;margin-bottom:16px;font-family:var(--sans)}
.footer p,.footer a,.footer li{color:rgba(244,237,224,.72);font-size:.9rem;line-height:1.7}
.footer a:hover{color:var(--paper)}
.footer ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:6px}
.footer .lead{
  font-family:var(--serif);font-style:italic;font-size:1.35rem;color:var(--paper);
  font-weight:300;line-height:1.3;max-width:30ch;margin-bottom:18px;
}
.footer-bottom{
  border-top:1px solid rgba(244,237,224,.12);
  padding-top:26px;display:flex;flex-wrap:wrap;justify-content:space-between;gap:12px;
  font-size:.62rem;letter-spacing:.22em;text-transform:uppercase;color:rgba(244,237,224,.5);
}
.footer-bottom .credit{font-style:italic;letter-spacing:.04em;text-transform:none;color:rgba(244,237,224,.55);font-family:var(--serif);font-size:.86rem}
.footer-bottom .credit a{color:var(--brass-l);border-bottom:1px solid rgba(200,169,116,.4)}
.footer-bottom .credit a:hover{color:var(--paper);border-color:var(--paper)}

/* =================
   IMAGE STRIP
   ================= */
.strip{display:grid;grid-template-columns:repeat(4,1fr);gap:0}
@media (max-width:780px){.strip{grid-template-columns:repeat(2,1fr)}}
.strip a{display:block;overflow:hidden;aspect-ratio:1/1;background:var(--paper-2)}
.strip img{width:100%;height:100%;object-fit:cover;object-position:center 45%;transition:transform 1.6s var(--ease-out)}
.strip a:hover img{transform:scale(1.05)}

/* =================
   ANCHOR NAV ROW
   ================= */
.anchor-nav{
  padding:28px 0;border-bottom:1px solid var(--line);
  background:var(--paper);
}
.anchor-nav-inner{
  display:flex;flex-wrap:wrap;gap:14px 28px;
  align-items:center;justify-content:center;
  font-size:.62rem;letter-spacing:.26em;text-transform:uppercase;color:var(--ink-faint);
}
.anchor-nav-inner a{color:var(--ink);font-weight:500;transition:color .2s}
.anchor-nav-inner a:hover{color:var(--sea)}
.anchor-nav-inner .sep{color:var(--ink-faint);opacity:.5}

/* =================
   CHARTER TYPE CARDS (servizi: Bareboat / Crewed)
   ================= */
.charter-types{display:grid;grid-template-columns:1fr 1fr;gap:32px}
@media (max-width:760px){.charter-types{grid-template-columns:1fr;gap:22px}}
.charter-card{
  background:var(--paper);padding:clamp(28px,3.6vw,46px);
  border:1px solid var(--line);
  display:flex;flex-direction:column;
}
.charter-card .ct-num{
  font-family:var(--serif);font-style:italic;color:var(--sea);font-size:1rem;
  margin-bottom:8px;
}
.charter-card h3{
  font-size:clamp(1.5rem,3vw,2.1rem);font-weight:300;line-height:1.1;
  margin-bottom:18px;
}
.charter-card p{color:var(--ink-2);font-size:.96rem;line-height:1.6;margin:0 0 1em}
.charter-card .ct-tag{
  margin-top:12px;font-style:italic;color:var(--sea);
  font-family:var(--serif);font-size:1.05rem;line-height:1.4;
}

/* =================
   PROCESS STEPS
   ================= */
.process{
  display:grid;grid-template-columns:repeat(4,1fr);gap:1px;
  background:rgba(244,237,224,.12);border:1px solid rgba(244,237,224,.12);
}
@media (max-width:880px){.process{grid-template-columns:repeat(2,1fr)}}
@media (max-width:480px){.process{grid-template-columns:1fr}}
.process .step{background:var(--ink);padding:34px 26px;display:flex;flex-direction:column;gap:12px}
.process .step .stepnum{font-family:var(--serif);font-style:italic;font-size:2.2rem;color:var(--brass-l);font-weight:300;line-height:1}
.process .step h4{font-size:.66rem;letter-spacing:.3em;text-transform:uppercase;color:var(--paper);font-weight:500;font-family:var(--sans)}
.process .step p{font-size:.9rem;color:rgba(244,237,224,.78);margin:0;line-height:1.55}

/* =================
   INCLUDED VS OPTIONAL — comparison panel
   ================= */
.incl-compare{
  display:grid;grid-template-columns:1fr 1fr;gap:0;
  border:1px solid var(--line);
  background:var(--paper);
  margin-top:8px;
}
.incl-panel{
  padding:clamp(28px,3.6vw,46px);
  display:flex;flex-direction:column;gap:22px;
  position:relative;
}
.incl-panel.incl-yes{
  background:var(--ink);color:var(--paper);
}
.incl-panel.incl-no{
  background:var(--paper);
  border-left:1px solid var(--line);
}
.incl-head{
  padding-bottom:18px;
  border-bottom:1px solid var(--line);
}
.incl-yes .incl-head{border-bottom-color:rgba(244,237,224,.16)}
.incl-tag{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--sans);font-size:.6rem;letter-spacing:.32em;
  text-transform:uppercase;font-weight:500;
  margin-bottom:12px;
}
.incl-tag::before{content:"";width:6px;height:6px;border-radius:50%}
.incl-yes .incl-tag{color:var(--brass-l)}
.incl-yes .incl-tag::before{background:var(--brass-l);box-shadow:0 0 0 3px rgba(200,169,116,.18)}
.incl-no .incl-tag{color:var(--ink-faint)}
.incl-no .incl-tag::before{background:var(--sea);box-shadow:0 0 0 3px rgba(29,58,74,.18)}
.incl-head h3{
  font-size:clamp(1.4rem,2.2vw,1.9rem);font-weight:300;line-height:1.1;
  font-variation-settings:"opsz" 144,"SOFT" 50;
}
.incl-yes .incl-head h3{color:var(--paper)}
.incl-yes .incl-head h3 em{color:var(--brass-l)}
.incl-no .incl-head h3{color:var(--ink)}
.incl-no .incl-head h3 em{color:var(--sea)}
.incl-head .desc{
  margin:8px 0 0;font-size:.88rem;line-height:1.5;
}
.incl-yes .incl-head .desc{color:rgba(244,237,224,.7)}
.incl-no .incl-head .desc{color:var(--ink-faint)}
.incl-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:13px}
.incl-list li{
  display:flex;align-items:flex-start;gap:14px;
  font-size:.96rem;line-height:1.5;
}
.incl-list li svg{
  width:18px;height:18px;flex:0 0 18px;margin-top:3px;
  fill:none;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round;
}
.incl-yes .incl-list li{color:rgba(244,237,224,.84)}
.incl-yes .incl-list li svg{stroke:var(--brass-l)}
.incl-no .incl-list li{color:var(--ink-2)}
.incl-no .incl-list li svg{stroke:var(--sea)}
.incl-no .incl-list li b{color:var(--sea);font-weight:500;font-style:italic;font-family:var(--serif)}

.incl-note{
  margin-top:24px;
  font-family:var(--serif);font-style:italic;font-size:.86rem;
  color:var(--ink-faint);line-height:1.5;text-align:center;
  max-width:780px;margin-left:auto;margin-right:auto;
}

@media (max-width:880px){
  .incl-compare{grid-template-columns:1fr}
  .incl-panel.incl-no{border-left:0;border-top:1px solid var(--line)}
}

/* =================
   FORM CONFIRMATION ON SEA / INK + page-end CTA blocks
   ================= */
.cta-block{text-align:center;max-width:820px;margin:0 auto}
.cta-block .eyebrow,.cta-block .eyebrow.center{justify-content:center}
.cta-block h1,.cta-block h2{
  font-size:clamp(2.2rem,5vw,4rem);max-width:22ch;
  margin:18px auto 22px;line-height:1.04;text-wrap:balance;
  font-weight:300;
}
.cta-block h1{font-size:clamp(2.4rem,6vw,4.6rem)}
.cta-block p{max-width:56ch;margin:0 auto 30px;font-size:1rem;line-height:1.55}
.cta-block .actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-top:8px}

/* Mobile sizing for cta-block */
@media (max-width:600px){
  .cta-block h1{font-size:clamp(2rem,8vw,2.7rem);margin:14px auto 18px}
  .cta-block h2{font-size:clamp(1.85rem,8vw,2.6rem);margin:14px auto 18px}
  .cta-block p{font-size:.96rem;margin-bottom:24px}
  .cta-block .actions{flex-direction:column;align-items:stretch;gap:10px;width:100%}
  .cta-block .actions .btn{justify-content:center;width:100%}
}

/* contatti hero variant — light section, centered headline */
.contatti-hero{padding-top:clamp(64px,9vw,120px);padding-bottom:clamp(48px,6vw,80px)}

/* =================
   REVEAL ON SCROLL
   ================= */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .8s var(--ease-out),transform .8s var(--ease-out)}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  .reveal,.reveal.in{opacity:1;transform:none;transition:none}
  .hero-bg{animation:none;transform:none}
  *{animation-duration:.01ms !important;transition-duration:.1ms !important}
}

/* =================
   FOCUS / A11Y
   ================= */
:focus-visible{outline:2px solid var(--sea);outline-offset:3px}
.btn:focus-visible{outline-offset:3px}

/* =====================================================
   HARMONY POLISH PASS — section rhythm + mobile tighten
   Last in the file so it overrides earlier per-component
   media queries where needed.
   ===================================================== */

/* === Manifesto image: 4:3 source crops too aggressively at 4:5 portrait.
       Use a softer 1:1 on tablet, 4:3 on phone so the shot reads cleanly. === */
@media (max-width:920px){
  .man-img{aspect-ratio:1/1;max-height:60vh}
}
@media (max-width:600px){
  .man-img{aspect-ratio:4/3}
}

/* === Section rhythm normalization: a single visual rhythm across all pages === */
@media (max-width:760px){
  .sec{padding:64px 0}
  .sec.tight{padding:46px 0}
  .sec-head{margin-bottom:36px;gap:14px}
  .sec-head h2{font-size:clamp(1.85rem,8vw,2.6rem);line-height:1.06}
  .sec-head .head-r p{font-size:.96rem;line-height:1.55;max-width:none}
}
@media (max-width:480px){
  .sec{padding:54px 0}
  .sec.tight{padding:40px 0}
  .sec-head{margin-bottom:28px}
  .sec-head h2{font-size:clamp(1.7rem,8.5vw,2.3rem)}
}

/* === Hero typography on phones — keep text out of the photo's busy zones === */
@media (max-width:600px){
  .hero{padding:90px 0 64px;min-height:min(640px,84dvh)}
  .hero h1{font-size:clamp(2rem,9vw,3rem);max-width:14ch;margin:14px 0 18px;letter-spacing:-.012em}
  .hero p.lead{font-size:.96rem;max-width:38ch}
  .hero.short{min-height:min(480px,62dvh);padding:80px 0 60px}
  .hero.short h1{font-size:clamp(1.85rem,8vw,2.4rem);max-width:14ch}
  .hero.short p.lead{max-width:38ch}
}

/* === CTA blocks (.sec.sea / .sec.ink at end of pages) — guarantee centering === */
.sec.sea > .wrap, .sec.ink > .wrap{position:relative}
@media (max-width:600px){
  /* Inline-styled CTA h2 sizes are too large on phones — clamp them down. */
  .sec.sea h2[style], .sec.ink h2[style]{
    font-size:clamp(1.9rem,8vw,2.6rem) !important;
    margin:18px auto 22px !important;
    max-width:18ch !important;
    line-height:1.06 !important;
  }
  .sec.sea p[style], .sec.ink p[style]{
    font-size:.96rem !important;
    margin-bottom:28px !important;
    max-width:42ch !important;
  }
  .sec.sea .ctas, .sec.ink .ctas,
  .sec.sea .actions, .sec.ink .actions,
  .sec.sea > .wrap > div[style*="flex"]{
    flex-direction:column !important;
    align-items:stretch !important;
    gap:10px !important;
  }
  .sec.sea .btn, .sec.ink .btn{
    justify-content:center;
    width:100%;
  }
}

/* === Stats grid: make sure 4-up reads cleanly on small mobile === */
@media (max-width:560px){
  .stats{grid-template-columns:1fr 1fr}
  .stat{padding:30px 18px}
  .stat .n{font-size:clamp(2rem,9vw,2.6rem)}
  .stat .l{font-size:.55rem;letter-spacing:.24em}
}

/* === Marinas grid: avoid orphan single cell on narrow widths === */
@media (max-width:380px){
  .marinas{grid-template-columns:1fr}
  .marina{padding:22px 18px}
  .marina:last-child{border-bottom:0}
}

/* === Strip on mobile: don't crop too aggressively === */
@media (max-width:600px){
  .strip a{aspect-ratio:1.1/1}
}

/* === Boat block on mobile: tighter padding + softer separator === */
@media (max-width:600px){
  .boat-block{padding:32px 0}
  .boat-block::before{width:32px}
  .v-body{padding:30px 22px 36px}
  .v-body h3{font-size:clamp(1.6rem,7vw,2.1rem)}
  .v-body .lead{font-size:1.05rem}
  .v-tabs{margin:6px 0 18px}
  .v-tabs button{font-size:.6rem;letter-spacing:.22em;margin-right:18px}
  .v-equip{gap:22px}
  .v-prices table{font-size:.86rem}
  .v-prices tbody td.amt{font-size:.95rem}
}

/* === Contact form panel: aggressive mobile cleanup === */
@media (max-width:760px){
  /* Form rows always single column on mobile — no 2-col squeeze */
  .form .row{grid-template-columns:1fr !important;gap:16px}
  /* Drop the panel border on mobile, keep just the bg */
  .form-panel{
    padding:24px 22px;
    border:0;
    background:var(--ivory);
  }
  .form-panel .form-head{margin-bottom:14px;padding-bottom:14px;border-bottom:1px solid var(--line)}
  .form-panel .form-head h2{font-size:1.4rem;margin-bottom:6px;line-height:1.18}
  .form{gap:18px}
  .field{gap:5px}
  .field input,.field select,.field textarea{
    font-size:16px; /* prevents iOS auto-zoom */
    padding:11px 0;
  }
  .field textarea{min-height:90px}
  .field label{font-size:.55rem;letter-spacing:.24em}
  .form-foot{gap:14px;flex-direction:column;align-items:stretch}
  .form-foot .btn{width:100%;justify-content:center}
  .form-foot .or{font-size:.85rem;text-align:center;order:2}
  /* Contact info panel mobile */
  .contact-info{padding:26px 22px}
  .contact-info h3{font-size:1.35rem}
  .contact-row{padding:14px 0;gap:5px}
  .contact-row .v{font-size:1rem;line-height:1.4}
  .contact-row .l{font-size:.55rem;letter-spacing:.26em}
}

/* === Stamp out native select chevron everywhere — iOS Safari leaks it === */
.field select{
  -webkit-appearance:none !important;
  -moz-appearance:none !important;
  appearance:none !important;
}
.field select::-ms-expand{display:none}

/* === Inline-styled "split" panels in servizi (Bareboat / Crewed) — single col on mobile === */
@media (max-width:760px){
  .sec.paper-2 > .wrap > div[style*="grid-template-columns:1fr 1fr"][style*="50px"]{
    grid-template-columns:1fr !important;
    gap:24px !important;
  }
}

/* === Quote / dark blockquote: scale down on mobile === */
@media (max-width:600px){
  .quote-block blockquote{font-size:clamp(1.3rem,6vw,1.9rem)}
  .quote-block .mark{font-size:2.6rem}
}

/* === Process steps inline-grid: smaller numbers on mobile === */
@media (max-width:600px){
  .process .step{padding:26px 22px}
  .process .step .stepnum{font-size:1.8rem}
  .process .step h4{font-size:.6rem}
  .process .step p{font-size:.86rem}
}

/* === Footer: tighter rhythm on mobile === */
@media (max-width:520px){
  .footer{padding:60px 0 28px}
  .footer .grid{gap:32px;margin-bottom:36px}
  .footer .lead{font-size:1.2rem}
  .footer-bottom{flex-direction:column;align-items:flex-start;gap:8px}
}

/* === Anchor nav row (flotta/destinazioni) — wrap nicely on mobile === */
@media (max-width:600px){
  nav.sec.tight[style] > .wrap[style]{
    gap:10px 18px !important;
    font-size:.58rem !important;
    letter-spacing:.2em !important;
  }
  nav.sec.tight[style] > .wrap[style] span{display:none}
}

/* === V-cta-row on narrow widths: stack price-band above button cleanly === */
@media (max-width:560px){
  .v-cta-row{gap:14px}
  .v-cta-row .price-band{flex:1 1 100%}
  .v-cta-row .btn{flex:1 1 100%;justify-content:center}
}

/* === Destinations vessel itinerary inline list: fix mobile === */
@media (max-width:600px){
  .v-body div[style*="margin-top:18px"][style*="border-top"] ul[style]{
    font-size:.92rem !important;
  }
}

/* === Make sure inline-styled form button row centers properly on mobile === */
@media (max-width:600px){
  .form-panel .form-foot{flex-wrap:wrap}
  .form-panel .form-foot .btn{flex:1 1 100%;justify-content:center;padding:13px 18px}
}

/* === Hero meta on mobile becomes a centered, smaller row === */
@media (max-width:600px){
  .hero-meta{margin-top:24px;padding-top:18px;font-size:.5rem;letter-spacing:.22em;gap:8px 14px}
  .hero-meta span::before{width:4px;height:4px}
}

/* === Image aspect harmony: dest-card 1:1 already; manifesto 4:3 mobile already.
       Vessel image: ensure mobile keeps clean 5:4 already set elsewhere. === */
