:root{
  --lake:#0B2A3A;
  --sun:#E09F3E;
  --off:#F3EFEB;
  --off2:#FFF7EE;
  --textOnDark: rgba(243,239,235,.80); --family2: 'IvyMode-Light', serif;
}
.fixed-top {

    z-index: 9;
}
.tlg-body{ background: var(--off); font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; overflow: hidden; }
#smooth-wrapper{ height: 100vh; }
#smooth-content{ will-change: transform; }

.tlg-nav{
  position: fixed; inset: 0 0 auto 0;
  z-index: 50;
  transform: translateY(0);
  transition: transform .5s ease, background-color .5s ease, padding .5s ease, backdrop-filter .5s ease;
  padding: .1rem 0;
  background: transparent;
}
.tlg-nav.is-hidden{ transform: translateY(-110%); }
.tlg-nav.is-scrolled{
  padding: 1rem 0;
  background: rgba(11,42,58,.90);
  backdrop-filter: blur(12px);
}
.tlg-brand{
  font-family: "Cormorant Garamond", serif;
  font-weight: 700;
  letter-spacing: .22em;
  font-size: 1.35rem;
  margin-left: 2rem;
  color: #fff;
}
.tlg-brand__accent{ color: var(--sun); }

.tlg-nav__link{
  color: #fff;
  font-size: .72rem;
  letter-spacing: .18em;
  text-decoration: none;
  transition: color .25s ease;
}
.tlg-nav__link:hover{ color: var(--sun); }

.tlg-cta{
  display:inline-block;
  background: var(--sun);
  color:#fff;
  padding: .85rem 1.6rem;
  border-radius: 999px;
  font-size: .72rem;
  letter-spacing: .10em;
  font-weight: 700;
  text-decoration:none;
  box-shadow: 0 20px 50px rgba(0,0,0,.18);
  transition: background-color .25s ease, color .25s ease;
}
.tlg-cta:hover{ background:#fff; color: var(--lake); }
.logo{height: 135px;width:auto}
/* HERO */
.tlg-hero{
  position: relative;
  min-height: 100vh;
  display:flex;
  align-items:center;
  background: var(--lake);
  overflow:hidden;
}
.tlg-hero__grid{
  position: relative;
  z-index: 2;
  padding-top: 8.5rem;
  padding-bottom: 3rem;
  display:grid;
  grid-template-columns: 1fr;
  gap: 3rem;
}
.nav-link {font-size: 1.7rem;font-weight: 500;color: black;line-height: .8;}
@media (min-width: 768px){
  .tlg-hero__grid{
    padding-top: 0;
    grid-template-columns: 7fr 5fr;
    align-items:center;
    gap: 2.5rem;
    min-height: 100vh;
  }
	
}
button.offcanvas{border-radius:10px!important}
.tlg-blob{
  position:absolute;
  pointer-events:none;
  opacity:.10;
}
.tlg-blob__svg{ width:100%; height:100%; }
.tlg-blob--hero{ top:0; right:0; width:50vw; height:100vh; }
.tlg-hero__copy{margin-left:6vw}

.tlg-kicker{
  color: var(--sun);
  font-weight: 500;
  letter-spacing: .34em;
  font-size: .82rem;
  margin: 0 0 .75rem 0;
}
.tlg-kicker--gold{ color: var(--sun); }

.tlg-hero__title{
font-family: var(--family2);
  font-weight: 600;
  color:#fff;
  line-height: .9;
  font-size: clamp(3.2rem, 7vw, 6rem);
  margin: 0 0 1.25rem 0;
}
@media (min-width: 768px){
  .tlg-hero__title{ font-size: clamp(4.2rem, 6.8vw, 5.2rem); }
}

.tlg-lede{
  color: rgba(243,239,235,.80);
  font-size: 1.05rem;
  max-width: 38rem;
  line-height: 1.9;
  margin: 0;
}
.tlg-btn-outline{
  border: 1px solid rgba(255,255,255,.9);
  background: transparent;
  color:#fff;
  padding: 1rem 2.2rem;
  border-radius: 999px;
  font-size: .82rem;
  letter-spacing: .12em;
  transition: background-color .25s ease, color .25s ease;
}
.tlg-btn-outline:hover{ background:#fff; color: var(--lake); }

.tlg-hero__media{ position: relative; height: 520px; }
@media (min-width: 768px){ .tlg-hero__media{position:absolute;height: 72vh;width: 62vw;right: 2vw;z-index:-1;margin-top: 4rem;} }

.tlg-hero__imageWrap{
  position:absolute;
  inset: 0;
  border-radius: 1.75rem;
  overflow:hidden;
  box-shadow: 0 30px 90px rgba(0,0,0,.40);
  transform: rotate(2deg);
  will-change: transform;
  width: 100%;
  object-fit: cover;left:0
}
.tlg-hero__image{
  width:100%; height:100%;
  object-fit: cover;
  transform: scale(1.25);
  will-change: transform;
}
.page-template-piazzole .tlg-hero__media{ position: relative; height: 520px; }

.marginTriple{margin-top: 10rem!important;}

.page-template-home .tlg-hero__media{position:absolute;height: 100vh;width: 100vw;right: 0;z-index:-1;margin-top: 0;}

.page-template-home .tlg-hero__imageWrap{
  position:absolute;
  inset: 0;
  border-radius:0;
  overflow:hidden;
  box-shadow: 0 30px 90px rgba(0,0,0,.40);
  transform: none!important;
  will-change: transform;
  width: 100%;
  object-fit: cover;left:0
}

nav-link {
    
    transition: color .15s ease-in-out, background-color .15s ease-in-out, border-color .15s ease-in-out;
    color: black;
    font-size: 1.2rem;
}


/* ===== Fullscreen Offcanvas ===== */
.rose-offcanvas-full{
  width: 100vw !important;
  height: 100vh !important;
  max-width: 100vw !important;
  border-left: 0;
  background: rgba(248,250,249,.96);
  backdrop-filter: blur(18px);
  box-shadow: -30px 0 90px rgba(0,0,0,.18);
  overflow: hidden; /* internal columns will scroll */
}

.rose-offcanvas-full__header{
  height: 76px;
  display:flex;
  align-items:center;
  justify-content: space-between;
  padding: 1rem 1.25rem;
  border-bottom: 1px solid rgba(15,61,62,.10);
}

.rose-offcanvas-full__title{
  font-size: 1.35rem;
  letter-spacing: .06em;
}

.rose-offcanvas-full__subtitle{
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: .35em;
  opacity: .7;
  margin-top: .2rem;
}

[type=button].rose-offcanvas-full__close{
  width: 46px;
  height: 46px;
  border-radius: 999px;
  border: 1px solid rgba(15,61,62,.12);
  background: var(--deep-teal);
  color:var(--lake);
  font-weight: 900;
  color: var(--deep-teal);
  transition: all .7s;
}
[type=button].rose-offcanvas-full__close:hover{
  background: var(--deep-teal);
  color:var(--lake);
  box-shadow: 0 18px 45px rgba(0,0,0,.16);
}

/* Grid: header fixed + two columns fill remaining height */
.rose-offcanvas-full__grid{
  height: calc(100vh - 76px);
  display: grid;
  grid-template-columns: 1fr 1fr; /* 50/50 */
}
.rose-offcanvas-full__grid .nav{margin-top:10%;padding-left: 6rem;width: 100%;}

/* Each column scrolls if overflow */
.rose-panel-col{
  padding: 1.25rem;
  overflow: auto;
  -webkit-overflow-scrolling: touch;
}

.rose-panel-col__head{
  display:flex;
  align-items:center;
  justify-content: space-between;
  margin-bottom: .9rem;
}

.rose-panel-col--menu{
  border-right: 1px solid rgba(15,61,62,.10);
  background: rgba(255,255,255,.40);
}

.rose-panel-col--news{
  background: rgba(248,250,249,.25);
}

/* Mobile: stack columns (menu first, then news) */
@media (max-width: 991.98px){
  .rose-offcanvas-full__grid{
    grid-template-columns: 1fr;
  }
  .rose-panel-col--menu{
    border-right: 0;
    border-bottom: 1px solid rgba(15,61,62,.10);
  }
}

/* ===== Shared UI bits (if not already defined) ===== */
.rose-panel-kicker{
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: .6em;
  font-weight: 800;
  color: var(--coral);
}
.rose-panel-link{
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: .28em;
  font-weight: 800;
  color: var(--deep-teal);
  opacity: .75;
  text-decoration: none;
}
.rose-panel-link:hover{ opacity: 1; }

.rose-panel-divider{
  height: 1px;
  background: rgba(15,61,62,.12);
  margin: 1.2rem 0;
}

/* News list */
.rose-newslist{
  display:grid;
  gap:.75rem;
}
.rose-newsitem{
  display:block;
  padding: 1rem;
  border-radius: 24px;
  text-decoration:none;
  color: var(--lake);
  background: rgba(255,255,255,.75);
  border: 1px solid rgba(15,61,62,.10);
  transition: all .7s;
  background-color: #367984;
}
.rose-newsitem:hover{
  transform: translateY(-2px);
  box-shadow: 0 18px 45px rgba(0,0,0,.10);
  border-color: rgba(226,125,96,.30);
}




.rose-newsitem__meta{
  display:flex;
  align-items:center;
  gap:.5rem;
  margin-bottom:.4rem;
}
.rose-dot{
  width: 8px; height: 8px;
  border-radius: 99px;
  background: var(--coral);
}
.rose-newsitem__date{
  font-size: 14px;
  text-transform: uppercase;
  letter-spacing: .38em;
  font-weight: 800;
  opacity: .65;
}
.rose-newsitem__title{
  font-family: var(--family2);
  font-weight: bold;
  letter-spacing: 0.01em;
  margin-bottom: .25rem;
  font-size: 1.3rem;
}
.rose-newsitem__text{
  opacity: .75;
  line-height: 1.8;
  font-weight: 300;
  margin: 0;
}

/* Accordion styling */
.rose-accordion .accordion-item{ border:0; background: transparent; }
.rose-acc-item{
  border: 1px solid rgba(15,61,62,.10);
  border-radius: 2px;
  overflow: hidden;
  background: rgba(255,255,255,.70);
  margin-bottom: .65rem;
}
.rose-acc-btn{
  background: transparent !important;
  color: var(--deep-teal) !important;
  font-weight: 500;
  letter-spacing: .12em;
  text-transform: uppercase;
  font-size: 12px;
  padding: 1rem;
}
.rose-acc-btn:focus{ box-shadow: none; }
.rose-acc-body{ padding: .35rem 1rem 1rem; }

.rose-panel-navlink{
  display:block;
  padding: .55rem .75rem;
  border-radius: 999px;
  text-decoration:none;
  color: var(--deep-teal);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: .22em;
  font-weight: 800;
  opacity: .82;
  transition: all .7s;
}
.rose-panel-navlink:hover{
  background: var(--deep-teal);
  color:#fff;
  opacity: 1;
}

/* Availability block */
.rose-avail{
  padding: 1.25rem;
  border-radius: 2px;
  background: rgba(255,255,255,.75);
  border: 1px solid rgba(15,61,62,.10);
  box-shadow: 0 18px 45px rgba(0,0,0,.08);
}
.rose-avail__kicker{
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: .6em;
  font-weight: 800;
  color: var(--coral);
  margin-bottom: .6rem;
}
.rose-avail__title{
  font-size: 1.65rem;
  margin-bottom: .5rem;
}
.rose-avail__text{
  opacity: .75;
  line-height: 1.8;
  font-weight: 300;
  margin-bottom: 1rem;
}
.rose-avail__mini{
  margin-top: .75rem;
  font-size: 12px;
  opacity: .75;
}
.rose-avail__mini a{ color: var(--deep-teal); font-weight: 700; text-decoration: none; }
.rose-avail__mini a:hover{ text-decoration: underline; }


.page-template-glamping-type 
.tlg-floatCard2{
  position:absolute;
  right: 30%;
  top: 5rem;

  padding: 0;
  border-radius: 1.25rem;
  box-shadow: 0 25px 70px rgba(0,0,0,.25);
  width: 320px;
  height:250px;background-size:cover;background-position:center center;background-repeat:no-repeat
}
.page-template-glamping-type 
.tlg-floatCard2b{
  position:absolute;
  right: 30%;
  bottom: 15rem;
z-index:9999;
  padding: 0;
  border-radius: 1.25rem;
  box-shadow: 0 25px 70px rgba(0,0,0,.25);
  width: 320px;
  height:250px;background-size:cover;background-position:center center;background-repeat:no-repeat
}

.tlg-floatCard2{
  position:absolute;
  right: 31%;
  top: 5rem;
  padding: 0;
  border-radius: 1.25rem;
  box-shadow: 0 25px 70px rgba(0,0,0,.25);
  width: 380px;
  height:250px;
  background-size:cover;
  background-position:center center;
  background-repeat:no-repeat
}


.tlg-floatCard3{
  position:absolute;
  right: -20px;
  top: 1rem;
  padding: 0;
  border-radius: 1.25rem;
  box-shadow: 0 25px 70px rgba(0,0,0,.25);
  width: 380px;
  height:500px;
  background-size:cover;
  background-position:center center;
  background-repeat:no-repeat
}


.page-template-glamping-type 
.tlg-floatCard3{
  position:absolute;
  right: -3vw;
  top: 1rem;

  padding: 0;
  border-radius: 1.25rem;
  box-shadow: 0 25px 70px rgba(0,0,0,.25);
  width: 380px;
  height:500px;background-size:cover;background-position:center center;background-repeat:no-repeat
}

.page-template-glamping-type 
.tlg-floatCard3b{
  position:absolute;
  right: -9vw;
  bottom: 11rem;
  padding: 0;
  z-index: 9;
  border-radius: 1.25rem;
  box-shadow: 0 25px 70px rgba(0,0,0,.25);
  width: 330px;
  height: 400px;
  background-size:cover;
  background-position:center center;
  background-repeat:no-repeat
}



.rose-narrative__innerVideo{position:absolute;width:100%; height:100%;
  object-fit: cover;}
.tlg-floatCard{
  position:absolute;
  left: -42px;
  bottom: -40px;
  background: var(--off2);
  padding: 1.8rem;
  border-radius: 1.25rem;
  box-shadow: 0 25px 70px rgba(0,0,0,.25);
  max-width: 212px;
}
.tlg-floatCard__title{
  font-family: "Cormorant Garamond", serif;
  font-style: italic;
  font-size: 1.35rem;
  margin: 0 0 .35rem 0;
  color: var(--lake);
}
.tlg-floatCard__text{
  margin:0;
  font-size: .75rem;
  line-height: 1.6;
  color: rgba(11,42,58,.60);
}
.page-template-home  .tlg-floatCard{
  position:absolute;
  left: 80vw;
  bottom: 10vh;
  background: var(--off2);
  padding: 1.8rem;
  border-radius: 1.25rem;
  box-shadow: 0 25px 70px rgba(0,0,0,.25);
  max-width: 212px;
}
/* NATURE */
.tlg-nature{
  background: var(--lake);
  color: var(--off);
  min-height: 200vh;
}
.tlg-nature__left{
  height: 100vh;
  display:flex;
  flex-direction: column;
  justify-content: center;
  padding-right: 3rem;
}
.tlg-h2{
font-family: var(--family2);
  font-weight: 600;
  font-size: clamp(2.6rem, 5.5vw, 4.4rem);
  line-height: 1.05;
  margin: 1rem 0 1.5rem 0;
}
.tlg-bodyText{
  color: rgba(243,239,235,.70);
  font-size: 1.1rem;
  line-height: 1.9;
  max-width: 34rem;
}
.tlg-arrowBtn{
  background: transparent;
  border:0;
  color: var(--off);
  display:flex;
  align-items:center;
  gap: 1rem;
  padding: 0;
}
.tlg-arrowBtn__circle{
  width: 48px; height:48px;
  border-radius: 999px;
  border: 1px solid var(--sun);
  display:flex;
  align-items:center;
  justify-content:center;
  transition: background-color .25s ease, color .25s ease;
}
.tlg-arrowBtn__label{
  font-size: .78rem;
  letter-spacing: .22em;
  text-transform: uppercase;
  transition: color .25s ease;
}




.tlg-arrowBtn.blue{
  background: transparent;
  border:0;
  color: #0b2a3a;
  display:flex;
  align-items:center;
  gap: 1rem;
  padding: 0;
}
.tlg-arrowBtn__circle.blue{
  width: 48px; height:48px;
  border-radius: 999px;
  border: 1px solid var(--sun);
  display:flex;
  align-items:center;
  justify-content:center;
  transition: background-color .25s ease, color .25s ease;
}



.tlg-arrowBtn:hover .tlg-arrowBtn__circle{ background: var(--sun); color: #fff; }
.tlg-arrowBtn:hover .tlg-arrowBtn__label{ color: var(--sun); }

.tlg-nature__right{
  padding: 8rem 0;
  display:flex;
  flex-direction: column;
  gap: 8rem;
}
.tlg-imgCard{
  width: 100%;
  aspect-ratio: 3 / 4;
  border-radius: 1.75rem;
  overflow:hidden;
  box-shadow: 0 30px 90px rgba(0,0,0,.35);
  position: relative;
}
.tlg-imgCard img{ width:100%; height:100%; object-fit: cover; transform: translateZ(0); }
.tlg-imgCard--narrow{ width: 82%; aspect-ratio: 4/5; }
.tlg-imgCard--wide{ aspect-ratio: 16/9; }
.tlg-imgCard--round{
  width: 75%;
  aspect-ratio: 1/1;
  border-radius: 100px;
  transform: rotate(3deg);
}

.tlg-glassBadge{
  position:absolute;
  top: 2rem;
  left: 2rem;
  background: rgba(243,239,235,.10);
  border: 1px solid rgba(255,255,255,.20);
  backdrop-filter: blur(10px);
  padding: 1.1rem 1.25rem;
  border-radius: 1.25rem;
}
.tlg-glassBadge p{
  margin:0;
  font-family: "Cormorant Garamond", serif;
  font-size: 1.6rem;
  color:#fff;
}

/* ACTIVITIES */
.tlg-activities{ background: var(--off); overflow:hidden; }
.tlg-activities__trigger{ overflow:hidden; }
.tlg-activities__stage{
  height: 100vh;
  display:flex;
  align-items:center;
  gap: 3rem;
}
.tlg-activities__intro{
  flex: 0 0 auto;
  padding-left: 10vw;
  padding-right: 2.5rem;
  max-width: 520px;
}
.text-lake{ color: var(--lake); }
.text-lake-60{ color: rgba(11,42,58,.60); }

.tlg-activities__rail{
  display:flex;
  gap: 3rem;
  padding-right: 10vw;
  padding-left: 2.5rem;
  will-change: transform;
}
.tlg-actCard{ width: 450px; flex: 0 0 auto; }
@media (max-width: 991px){
  .tlg-actCard{ width: 320px; }
  .tlg-activities__intro{ padding-left: 6vw; }
}
.tlg-actCard__media{
  position: relative;
  aspect-ratio: 3 / 4;
  overflow:hidden;
  border-radius: 1.75rem;
  box-shadow: 0 20px 55px rgba(0,0,0,.18);
}
.tlg-actCard__media img{
  width:100%; height:100%;
  object-fit: cover;
  transition: transform .7s ease;
}
.tlg-actCard__overlay{
  position:absolute; inset:0;
  background: linear-gradient(to top, rgba(11,42,58,.80), rgba(11,42,58,0));
  opacity: 0;
  transition: opacity .5s ease;
  display:flex;
  align-items:flex-end;
  padding: 2.2rem;
}
.tlg-actCard__overlay h3{
  font-family: "Cormorant Garamond", serif;
  color:#fff;
  font-size: 2.2rem;
  margin:0;
}
.tlg-actCard:hover .tlg-actCard__overlay{ opacity:1; }
.tlg-actCard:hover .tlg-actCard__media img{ transform: scale(1.10); }

.tlg-actCard__title{
  font-family: "Cormorant Garamond", serif;
  color: var(--lake);
  font-size: 1.65rem;
  margin: 1.25rem 0 .25rem 0;
  transition: color .25s ease;
}
.tlg-actCard__desc{
  color: rgba(11,42,58,.50);
  font-size: .9rem;
  margin:0;
}
.tlg-actCard:hover .tlg-actCard__title{ color: var(--sun); }

/* INFO */
.tlg-info{ padding: 8rem 0; background: var(--off); overflow:hidden; }
.tlg-info__mainImg{
  width:100%;
  aspect-ratio: 4/5;
  border-radius: 60px;
  overflow:hidden;
  box-shadow: 0 30px 90px rgba(0,0,0,.20);
  transform: rotate(-2deg);
}
.tlg-info__mainImg img{ width:100%; height:100%; object-fit: cover; }
.tlg-info__bubble{
  position:absolute;
  right: -1rem;
  bottom: -3rem;
  width: 50%;
  aspect-ratio: 1/1;
  border-radius: 999px;
  border: 8px solid var(--off);
  overflow:hidden;
  box-shadow: 0 30px 90px rgba(0,0,0,.20);
}
.tlg-info__bubble img{ width:100%; height:100%; object-fit: cover; }

.tlg-h3{
  font-family: "Cormorant Garamond", serif;
  font-weight: 600;
  font-size: clamp(2.2rem, 4vw, 3.4rem);
  line-height: 1.12;
  margin: .75rem 0 1rem 0;
  color: var(--lake);
}
.tlg-italic{ font-style: italic; font-weight: 400; }

.tlg-info__copy .tlg-bodyText{ color: rgba(11,42,58,.70); }

.tlg-quote{
  margin-top: 1.5rem;
  display:flex;
  align-items:center;
  gap: 1rem;
}
.tlg-quote__line{ width: 64px; height:1px; background: rgba(11,42,58,.30); }
.tlg-quote__text{
  margin:0;
  font-family: "Cormorant Garamond", serif;
  font-style: italic;
  font-size: 1.55rem;
  color: var(--lake);
}

/* ACCOMMODATIONS */
.tlg-acc{ padding: 8rem 0; background: var(--off); position: relative; overflow:hidden; }
.tlg-acc__bgText{
  position:absolute;
  top: 80px; left: 0;
  white-space: nowrap;
  pointer-events:none;
  user-select:none;
  opacity: .03;
}
.tlg-acc__bgText .acc-bg-text{
  font-family: "Cormorant Garamond", serif;
  font-weight: 700;
  font-size: 250px;
  line-height: 1;
  text-transform: uppercase;
  color: var(--lake);
}
@media (max-width: 991px){ .tlg-acc__bgText .acc-bg-text{ font-size: 160px; } }

.tlg-acc__head{ max-width: 42rem; margin-bottom: 5rem; position: relative; z-index: 2; }
.tlg-acc__list{ display:flex; flex-direction: column; gap: 10rem; position: relative; z-index: 2; }

.tlg-accItem{
  display:flex;
  flex-direction: column;
  gap: 3rem;
  align-items:center;
}
@media (min-width: 768px){
  .tlg-accItem{flex-direction: row;gap: 4.5rem;margin-bottom: 7rem;}
  .tlg-accItem.is-reverse{ flex-direction: row-reverse; }
}
.tlg-accItem__media{ width: 100%; }
@media (min-width: 768px){ .tlg-accItem__media{ width: 60%; } }

.tlg-accItem__img{
  position: relative;
  overflow:hidden;
  border-radius: 40px;
  box-shadow: 0 30px 90px rgba(0,0,0,.18);
  aspect-ratio: 16/10;
}
.tlg-accItem__img img{ width:100%; height:100%; object-fit: cover; transition: transform 1s ease; }
.tlg-accItem__img:hover img{ transform: scale(1.05); }
.tlg-accItem__veil{ position:absolute; inset:0; background: rgba(11,42,58,.10); transition: opacity .5s ease; }
.tlg-accItem__img:hover .tlg-accItem__veil{ opacity: 0; }

.tlg-accItem__copy{ width:100%; }
   .tlg-accItem__copy h3{
  font-family: var(--family2);
    font-weight: 600;
    font-size: clamp(2.6rem, 5.5vw, 3.4rem);
    line-height: 1.05;
    margin: 1rem 0 1.5rem 0;
    color: var(--lake);
    }
@media (min-width: 768px){ .tlg-accItem__copy{ width: 40%; } }
.tlg-accItem {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 4.5rem;
  margin-bottom: 7rem;
  transition: all .4s ease;
}

.tlg-accItem {
  margin-bottom: 7rem;
}

.tlg-accItem .rose-choice__card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 4.5rem;
  transition: all .4s ease;
  color: var(--lake);
  text-decoration: none;
}

.tlg-accItem.is-reverse .rose-choice__card {
  flex-direction: row-reverse;
}
.tlg-tag{
  color: var(--sun);
  letter-spacing: .18em;
  text-transform: uppercase;
  font-size: .72rem;
  font-weight: 500;
}
.tlg-accItem__title{
  font-family: "Cormorant Garamond", serif;
  font-size: clamp(2rem, 3vw, 3.1rem);
  margin: .6rem 0 0 0;
  color: var(--lake);
}
.tlg-accItem__desc{ color: rgba(11,42,58,.70); font-size: 1.05rem; line-height: 1.9; margin: 0; max-width: 34rem; }

.tlg-feats{
  display:grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: .9rem 1.2rem;
  padding-top: .6rem;
}
.tlg-feat{
  display:flex;
  align-items:center;
  gap: .75rem;
  color: rgba(11,42,58,.60);
  font-size: .85rem;
  letter-spacing: .02em;
}
.tlg-dot{
  width:6px; height:6px;
  border-radius:999px;
  background: var(--sun);
  flex: 0 0 auto;
}
.tlg-accBtn{
  display:inline-block;
  margin-top: 1.25rem;
  padding: .85rem 1.6rem;
  border-radius: 999px;
  border: 1px solid rgba(11,42,58,.20);
  color: var(--lake);
  background: transparent;
  font-size: .72rem;
  letter-spacing: .22em;
  text-transform: uppercase;
  transition: background-color .25s ease, color .25s ease;
}
.tlg-accBtn:hover{ background: var(--lake); color:#fff; }

/* FOOTER */
.tlg-footer{
  background: var(--lake);
  color: var(--off);
  padding: 6.5rem 0 3.5rem 0;
  position: relative;
  overflow:hidden;
}
.tlg-blob--footer{ bottom:-140px; left:-140px; width: 600px; height: 600px; opacity:.10; }

.tlg-footer__brand{
  font-family: "Cormorant Garamond", serif;
  font-weight: 700;
  letter-spacing: .22em;
  font-size: 3rem;
  margin: 0 0 1.25rem 0;
}
.tlg-footer__lede{
  color: rgba(243,239,235,.60);
  max-width: 22rem;
  line-height: 1.9;
  margin: 0 0 2rem 0;
}
.tlg-footer__link{
  color: rgba(243,239,235,.85);
  font-size: .75rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  text-decoration:none;
  transition: color .25s ease;
}
.tlg-footer__link:hover{ color: var(--sun); }

.tlg-footer__kicker{
  color: var(--sun);
  font-weight: 700;
  letter-spacing: .18em;
  text-transform: uppercase;
  font-size: .72rem;
  margin: 0 0 1.25rem 0;
}
.tlg-footer__list{ list-style:none; padding:0; margin:0; display:flex; flex-direction: column; gap: .75rem; }
.tlg-footer__item{ color: rgba(243,239,235,.80); text-decoration:none; transition: color .25s ease; }
.tlg-footer__item:hover{ color:#fff; }
.tlg-footer__text{ color: rgba(243,239,235,.80); margin: 0 0 .75rem 0; }
.tlg-footer__underline{
  text-decoration: underline;
  text-decoration-color: var(--sun);
  text-underline-offset: 6px;
}
.tlg-footer__bottom{
  border-top: 1px solid rgba(255,255,255,.10);
  padding-top: 2.5rem;
  display:flex;
  flex-direction: column;
  gap: 1rem;
}
@media (min-width: 768px){
  .tlg-footer__bottom{ flex-direction: row; justify-content: space-between; align-items:center; }
}
.tlg-footer__small{ margin:0; color: rgba(243,239,235,.40); font-size: .72rem; letter-spacing: .12em; }
.tlg-footer__smallLink{ color: rgba(243,239,235,.40); font-size: .72rem; text-decoration:none; transition: color .25s ease; }
.tlg-footer__smallLink:hover{ color:#fff; }





/* CHECK-IN block */
.tlg-infoBlock{
  padding: clamp(18px, 3.2vw, 5rem);

    background: var(--lake);
  border: 1px solid rgba(255,255,255,.10);
  backdrop-filter: blur(10px);color:white
}

.tlg-infoTitle{
  margin: 0 0 14px;
  font-size: 18px;
  letter-spacing: .14em;
  text-transform: uppercase;
  opacity: .95;
}

.tlg-infoSection{ margin-top: 10px; }

.tlg-infoKicker{
  margin: 0 0 12px;
  font-size: 14px;
  letter-spacing: .06em;
  text-transform: uppercase;
  opacity: .9;
}

.tlg-infoKicker__note{
  font-size: 13px;
  letter-spacing: .02em;
  text-transform: none;
  opacity: .8;
}

/* ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã¢â‚¬Â ÃƒÂ¢Ã¢â€šÂ¬Ã¢â€žÂ¢ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã‚Â ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬ÃƒÂ¢Ã¢â‚¬Å¾Ã‚Â¢ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬Ãƒâ€¦Ã‚Â¡ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã¢â‚¬Â ÃƒÂ¢Ã¢â€šÂ¬Ã¢â€žÂ¢ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã†â€™Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬Ãƒâ€¦Ã‚Â¡ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¬ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã‚Â¦ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¡ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬Ãƒâ€¦Ã‚Â¡ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¬ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã¢â‚¬Â ÃƒÂ¢Ã¢â€šÂ¬Ã¢â€žÂ¢ÃƒÆ’Ã†â€™Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡Ãƒâ€šÃ‚Â¬ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¦ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã†â€™Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬Ãƒâ€¦Ã‚Â¡ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¬ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã‚Â¦ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬Ãƒâ€¦Ã¢â‚¬Å“tableÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã¢â‚¬Â ÃƒÂ¢Ã¢â€šÂ¬Ã¢â€žÂ¢ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã‚Â ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬ÃƒÂ¢Ã¢â‚¬Å¾Ã‚Â¢ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬Ãƒâ€¦Ã‚Â¡ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã¢â‚¬Â ÃƒÂ¢Ã¢â€šÂ¬Ã¢â€žÂ¢ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã†â€™Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬Ãƒâ€¦Ã‚Â¡ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¬ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã‚Â¦ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¡ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬Ãƒâ€¦Ã‚Â¡ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¬ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã¢â‚¬Â ÃƒÂ¢Ã¢â€šÂ¬Ã¢â€žÂ¢ÃƒÆ’Ã†â€™Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡Ãƒâ€šÃ‚Â¬ÃƒÆ’Ã¢â‚¬Â¦Ãƒâ€šÃ‚Â¡ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬Ãƒâ€¦Ã‚Â¡ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â layout */
.tlg-infoTable{
  display: grid;
  gap: 10px;
}

.tlg-infoRow{
  display: grid;
  grid-template-columns: minmax(130px, 190px) 1fr;
  gap: 14px;
  padding: 12px 14px;
  border-radius: 14px;
  background: rgba(0,0,0,.18);
  border: 1px solid rgba(255,255,255,.08);
  transition: transform .25s ease, border-color .25s ease, background .25s ease;
}

.tlg-infoRow:hover{
  transform: translateY(-1px);
  border-color: rgba(255,255,255,.16);
  background: rgba(0,0,0,.22);
}

.tlg-infoCell{
  font-size: 15px;
  line-height: 1.35;
  opacity: .92;
}

.tlg-infoCell--label{
  font-weight: 600;
  opacity: .98;
}

/* Responsive */
@media (max-width: 640px){
  .tlg-infoRow{
    grid-template-columns: 1fr;
    gap: 6px;
  }
  .tlg-infoCell--label{
    font-size: 13px;
    letter-spacing: .04em;
    text-transform: uppercase;
    opacity: .85;
  }
}




/* ===== Gallery wrapper ===== */
/* ================================
   HERO IMAGE WRAP
================================ */

.page-template-glamping-type .tlg-hero__imageWrap{
  position:absolute;
  inset:0;
  border-radius:1.75rem;
  overflow:hidden;
  box-shadow:0 30px 90px rgba(0,0,0,.40);
}

/* Rotazione separata per non rompere Swiper */
.page-template-glamping-type .tlg-hero__inner{
  width:100%;
  height:100%;
  will-change:transform;
}

/* ================================
   SWIPER BASE
================================ */

.page-template-glamping-type .tlg-hero__imageWrap .swiper{
  width:100%;
  height:100%;
}

.page-template-glamping-type .tlg-hero__imageWrap .swiper-wrapper{
  width:100%;
  height:100%;
}

.page-template-glamping-type .tlg-hero__imageWrap .swiper-slide{
  position:relative;
  width:100%;
  height:100%;
  overflow:hidden;
}

/* ================================
   BACKGROUND IMAGE
================================ */

.page-template-glamping-type .swiper-slide-bg{
  position:absolute;
  inset:0;
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
  width:100%;
  height:100%;
  transform:scale(1.05);
  transition:transform 6s ease;
}

/* Slow cinematic zoom */
.page-template-glamping-type .swiper-slide-active .swiper-slide-bg{
  transform:scale(1);
}

/* ================================
   DARK OVERLAY (optional)
================================ */

.page-template-glamping-type .swiper-slide.dark::after{
  content:"";
  position:absolute;
  inset:0;
  background:rgba(0,0,0,.35);
  z-index:1;
}

/* ================================
   FADE FIX
================================ */

.page-template-glamping-type .swiper-fade .swiper-slide{
  pointer-events:none;
}

.page-template-glamping-type .swiper-fade .swiper-slide-active{
  pointer-events:auto;
}

/* ================================
   PERFORMANCE FIX
================================ */

.page-template-glamping-type .swiper,
.page-template-glamping-type .swiper-wrapper,
.page-template-glamping-type .swiper-slide{
  transform:translateZ(0);
  backface-visibility:hidden;
}

/* ========================================
   HERO WRAP
======================================== */

.page-template-villaggi .tlg-hero__imageWrap{
  position:absolute;
  inset:0;
  border-radius:1.75rem;
  overflow:hidden;
  box-shadow:0 30px 90px rgba(0,0,0,.40);
}

/* Rotazione separata */
.page-template-villaggi .tlg-hero__inner{
  width:100%;
  height:100%;
  will-change:transform;
}

/* ========================================
   SWIPER BASE
======================================== */

.page-template-villaggi .tlg-hero__imageWrap .swiper{
  width:100%;
  height:100%;
}

.page-template-villaggi .tlg-hero__imageWrap .swiper-wrapper{
  width:100%;
  height:100%;
}

.page-template-villaggi .tlg-hero__imageWrap .swiper-slide{
  position:relative;
  width:100%;
  height:100%;
  overflow:hidden;
}

/* ========================================
   BACKGROUND IMAGE
======================================== */

.page-template-villaggi .swiper-slide-bg{
  position:absolute;
  inset:0;
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
  width:100%;
  height:100%;
  transform:scale(1.06);
  transition:transform 6s ease;
}

/* Cinematic zoom effect */
.page-template-villaggi .swiper-slide-active .swiper-slide-bg{
  transform:scale(1);
}

/* ========================================
   DARK OVERLAY (se slide ha .dark)
======================================== */

.page-template-villaggi .swiper-slide.dark::after{
  content:"";
  position:absolute;
  inset:0;
  background:rgba(0,0,0,.35);
  z-index:1;
}

/* ========================================
   FADE FIX
======================================== */

.page-template-villaggi .swiper-fade .swiper-slide{
  pointer-events:none;
}

.page-template-villaggi .swiper-fade .swiper-slide-active{
  pointer-events:auto;
}

/* ========================================
   PERFORMANCE FIX
======================================== */

.page-template-villaggi .swiper,
.page-template-villaggi .swiper-wrapper,
.page-template-villaggi .swiper-slide{
  transform:translateZ(0);
  backface-visibility:hidden;
}



















/* ===== Gallery wrapper ===== */
/* ================================
   HERO IMAGE WRAP
================================ */

.page-template-villaggio-type .tlg-hero__imageWrap{
  position:absolute;
  inset:0;
  border-radius:1.75rem;
  overflow:hidden;
  box-shadow:0 30px 90px rgba(0,0,0,.40);
}

/* Rotazione separata per non rompere Swiper */
.page-template-villaggio-type .tlg-hero__inner{
  width:100%;
  height:100%;
 
  will-change:transform;
}

/* ================================
   SWIPER BASE
================================ */

.page-template-villaggio-type .tlg-hero__imageWrap .swiper{
  width:100%;
  height:100%;
}

.page-template-villaggio-type .tlg-hero__imageWrap .swiper-wrapper{
  width:100%;
  height:100%;
}

.page-template-villaggio-type .tlg-hero__imageWrap .swiper-slide{
  position:relative;
  width:100%;
  height:100%;
  overflow:hidden;
}

/* ================================
   BACKGROUND IMAGE
================================ */

.page-template-villaggio-type .swiper-slide-bg{
  position:absolute;
  inset:0;
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
  width:100%;
  height:100%;
  transform:scale(1.05);
  transition:transform 6s ease;
}

/* Slow cinematic zoom */
.page-template-villaggio-type .swiper-slide-active .swiper-slide-bg{
  transform:scale(1);
}

/* ================================
   DARK OVERLAY (optional)
================================ */

.page-template-villaggio-type .swiper-slide.dark::after{
  content:"";
  position:absolute;
  inset:0;
  background:rgba(0,0,0,.35);
  z-index:1;
}

/* ================================
   FADE FIX
================================ */

.page-template-villaggio-type .swiper-fade .swiper-slide{
  pointer-events:none;
}

.page-template-villaggio-type .swiper-fade .swiper-slide-active{
  pointer-events:auto;
}

/* ================================
   PERFORMANCE FIX
================================ */

.page-template-villaggio-type .swiper,
.page-template-villaggio-type .swiper-wrapper,
.page-template-villaggio-type .swiper-slide{
  transform:translateZ(0);
  backface-visibility:hidden;
}

/* ========================================
   HERO WRAP
======================================== */

.page-template-villaggi .tlg-hero__imageWrap{
  position:absolute;
  inset:0;
  border-radius:1.75rem;
  overflow:hidden;
  box-shadow:0 30px 90px rgba(0,0,0,.40);
}

/* Rotazione separata */
.page-template-villaggi .tlg-hero__inner{
  width:100%;
  height:100%;

  will-change:transform;
}

/* ========================================
   SWIPER BASE
======================================== */

.page-template-villaggi .tlg-hero__imageWrap .swiper{
  width:100%;
  height:100%;
}

.page-template-villaggi .tlg-hero__imageWrap .swiper-wrapper{
  width:100%;
  height:100%;
}

.page-template-villaggi .tlg-hero__imageWrap .swiper-slide{
  position:relative;
  width:100%;
  height:100%;
  overflow:hidden;
}

/* ========================================
   BACKGROUND IMAGE
======================================== */

.page-template-villaggi .swiper-slide-bg{
  position:absolute;
  inset:0;
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
  width:100%;
  height:100%;
  transform:scale(1.06);
  transition:transform 6s ease;
}

/* Cinematic zoom effect */
.page-template-villaggi .swiper-slide-active .swiper-slide-bg{
  transform:scale(1);
}

/* ========================================
   DARK OVERLAY (se slide ha .dark)
======================================== */

.page-template-villaggi .swiper-slide.dark::after{
  content:"";
  position:absolute;
  inset:0;
  background:rgba(0,0,0,.35);
  z-index:1;
}

/* ========================================
   FADE FIX
======================================== */

.page-template-villaggi .swiper-fade .swiper-slide{
  pointer-events:none;
}

.page-template-villaggi .swiper-fade .swiper-slide-active{
  pointer-events:auto;
}

/* ========================================
   PERFORMANCE FIX
======================================== */

.page-template-villaggi .swiper,
.page-template-villaggi .swiper-wrapper,
.page-template-villaggi .swiper-slide{
  transform:translateZ(0);
  backface-visibility:hidden;
}




/* SECTION BACKGROUND */
.tlg-checkin {
  background: transparent; /* blu elegante */
  padding: 3rem 0;
  color: rgba(255,255,255,0.85);
}

/* TITOLO */
.tlg-checkin__title {
  font-family: "Playfair Display", serif;
  font-size: 3.2rem;
  font-weight: 400;
  color: #ffffff;
  margin-bottom: 1rem;
  letter-spacing: 0.5px;
}

/* SOTTOTITOLO */
.tlg-checkin__subtitle {
  color: rgba(255,255,255,0.55);
  margin-bottom: 4rem;
  font-size: 1rem;
  font-weight: 300;
}

/* LISTA */
.tlg-checkin__list {
  border-top: 1px solid rgba(255,255,255,0.12);
}

/* RIGA */
.tlg-checkin__item {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  padding: 1.8rem 0;
  border-bottom: 1px solid rgba(255,255,255,0.08);
}

/* GIORNO */
.tlg-checkin__day {
  font-weight: 500;
  color: #ffffff;
  min-width: 220px;
  letter-spacing: 0.4px;
}

/* DESTINAZIONI */
.tlg-checkin__locations {
  color: rgba(255,255,255,0.65);
  max-width: 600px;
  line-height: 1.6;
  font-weight: 300;
}

/* STAGIONE */
.tlg-checkin__season {
  margin-top: 5rem;
}

.tlg-checkin__season h3 {
  font-family: "Playfair Display", serif;
  font-size: 1.6rem;
  font-weight: 400;
  color: #ffffff;
  margin-bottom: 0.5rem;
}

.tlg-checkin__season p {
  color: rgba(255,255,255,0.6);
}

/* Stile di base del bottone (rimuove i bordi default se necessario) */
.rose-burger {
  background: transparent;
  border: none;
  padding: 18px;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background-color: #0b2a3a;
  border-radius:30px
}

/* Stile dell'SVG */
.rose-burger__svg {
  width: 32px; /* Dimensione dell'icona, modificala a tuo piacimento */
  height: 32px;
  color: #fff; /* Colore dell'icona (adattalo al design di digitalgarda) */
}

/* Stile delle tre linee dell'hamburger */
.rose-burger__svg .line {
  stroke: currentColor;
  stroke-width: 2.5;
  stroke-linecap: round;
  /* Imposta il centro di rotazione al centro esatto dell'SVG (12px, 12px) */
  transform-origin: 12px 12px; 
  transition: transform 0.3s ease-in-out, opacity 0.3s ease-in-out;
}

/* =========================================
   STATO "OPEN" (Menu Aperto -> X)
   Bootstrap imposta aria-expanded="true" 
   ========================================= */

/* Linea superiore: scende e ruota di 45 gradi */
.rose-burger[aria-expanded="true"] .line-top {
  transform: translate(0, 6px) rotate(45deg);
}

/* Linea centrale: scompare scalando a 0 */
.rose-burger[aria-expanded="true"] .line-middle {
  opacity: 0;
  transform: scaleX(0);
}

/* Linea inferiore: sale e ruota di -45 gradi */
.rose-burger[aria-expanded="true"] .line-bottom {
  transform: translate(0, -6px) rotate(-45deg);
}


@media (max-width: 991px) {.rose-offcanvas-full{
  width: 100vw !important;
  height: auto !important;
  max-width: 100vw !important;
  border-left: 0;
  background: rgba(248,250,249,.96);
  backdrop-filter: blur(18px);
  box-shadow: -30px 0 90px rgba(0,0,0,.18);
  overflow: hidden; /* internal columns will scroll */
}
  /* 1. Applica lo scorrimento all'intero offcanvas */
  .rose-offcanvas-full {
    overflow-y: auto !important; 
    overflow-x: hidden;
    /* Opzionale: se Bootstrap forza un flex-column che ti sballa il layout, 
       display: block aiuta a far fluire i contenuti naturalmente */
    display: block !important; 
  }

  /* 2. Rimuovi qualsiasi scroll o altezza bloccata dai div interni */
  .rose-offcanvas-full__grid,
  .rose-panel-col,
  .rose-newslist,
  .rose-avail {
    height: auto !important;
    max-height: none !important;
    overflow-y: visible !important;
  }

  /* 3. Assicurati che l'header non rimanga bloccato (se vuoi che scorra via con il resto) */
  .rose-offcanvas-full__header {
    position: relative !important; 
    top: 0;
  }
	.rose-offcanvas-full__grid .nav{
margin-top:10%;padding-left:0
}
.nav-link {
    font-family: "Cormorant Garamond", serif;
    font-size: 1.3rem;
    font-weight: 400;
    color: black;
    line-height: 1;
    text-align: center;
}
}

.newsletter-band{
  padding: 4rem 1.2rem;
  background: linear-gradient(135deg, rgba(243,239,235,1) 0%, rgba(255,247,238,1) 100%);
}

.newsletter-box{
  position: relative;
  overflow: hidden;
  padding: 2.2rem 2rem;
  border-radius: 28px;
  background: linear-gradient(135deg, rgba(11,42,58,.96) 0%, rgba(20,55,72,.92) 100%);
  box-shadow: 0 25px 70px rgba(11,42,58,.16);
}

.newsletter-box::before{
  content: "";
  position: absolute;
  top: -80px;
  right: -80px;
  width: 220px;
  height: 220px;
  border-radius: 50%;
  background: rgba(224,159,62,.16);
  filter: blur(10px);
}

.newsletter-box::after{
  content: "";
  position: absolute;
  bottom: -60px;
  left: -60px;
  width: 180px;
  height: 180px;
  border-radius: 50%;
  background: rgba(255,255,255,.05);
}

.newsletter-kicker{
  display: inline-block;
  margin-bottom: .65rem;
  color: #E09F3E;
  font-size: .75rem;
  font-weight: 600;
  letter-spacing: .22em;
  text-transform: uppercase;
}

.newsletter-title{
  margin: 0 0 .6rem 0;
  font-family: "Cormorant Garamond", serif;
  font-size: clamp(2rem, 3.5vw, 3rem);
  line-height: 1;
  color: #F3EFEB;
}

.newsletter-text{
  color: rgba(243,239,235,.78);
  font-size: 1rem;
  line-height: 1.7;
  max-width: 36rem;
}

.newsletter-form{
  position: relative;
  z-index: 2;
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 10px;
  border-radius: 999px;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.12);
  backdrop-filter: blur(8px);
}

.newsletter-form input{
  flex: 1 1 auto;
  min-width: 0;
  height: 58px;
  border: 0;
  outline: 0;
  background: transparent;
  color: #fff;
  padding: 0 1.1rem;
  font-size: 1rem;
}

.newsletter-form input::placeholder{
  color: rgba(243,239,235,.62);
}

.newsletter-form button{
  flex: 0 0 auto;
  height: 58px;
  padding: 0 1.7rem;
  border: 0;
  border-radius: 999px;
  background: #E09F3E;
  color: #fff;
  font-size: .82rem;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
  transition: transform .25s ease, box-shadow .25s ease, background .25s ease;
  box-shadow: 0 12px 28px rgba(224,159,62,.28);
}

.newsletter-form button:hover{
  transform: translateY(-2px);
  background: #f0ab45;
  box-shadow: 0 18px 34px rgba(224,159,62,.34);
}

.newsletter-form button:active{
  transform: translateY(0);
}

@media (max-width: 991.98px){
  .newsletter-box{
    padding: 2rem 1.2rem;
    text-align: center;
  }

  .newsletter-form{
    flex-direction: column;
    border-radius: 24px;
    padding: 14px;
  }

  .newsletter-form input,
  .newsletter-form button{
    width: 100%;
  }

  .newsletter-form input{
    height: 54px;
    background: rgba(255,255,255,.06);
    border-radius: 14px;
  }

  .newsletter-form button{
    height: 54px;
  }
}
.menu-bg-water{
  position: relative;
  overflow: hidden;
  isolation: isolate;
  min-height: 260px;
  background:
  linear-gradient(135deg, rgba(11, 42, 58, .96) 0%, rgba(20, 55, 72, .92) 100%);
}

/* massa liquida calda */
.menu-bg-water::before{
  content: "";
  position: absolute;
  inset: -12%;
  z-index: 0;
  pointer-events: none;


  animation: menuWaterBlob1 14s ease-in-out infinite alternate;
}

/* massa liquida fresca */
.menu-bg-water::after{
  content: "";
  position: absolute;
  left: -8%;
  top: -6%;
  width: 116%;
  height: 112%;
  z-index: 1;
  pointer-events: none;
  background:
linear-gradient(135deg, rgba(11, 42, 58, .96) 0%, rgba(20, 55, 72, .92) 100%);
  filter: blur(34px);
  opacity: .95;
  animation: menuWaterBlob2 18s ease-in-out infinite alternate;
}

/* velo acquatico molto soft */
.menu-bg-water .menu-bg-water__surface{
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
  opacity: .42;
  mix-blend-mode: soft-light;
  background:
    radial-gradient(ellipse at 20% 30%, rgba(255,255,255,.22) 0%, rgba(255,255,255,0) 22%),
    radial-gradient(ellipse at 68% 44%, rgba(255,255,255,.16) 0%, rgba(255,255,255,0) 18%),
    radial-gradient(ellipse at 44% 76%, rgba(255,255,255,.18) 0%, rgba(255,255,255,0) 20%);
  filter: blur(10px);
  animation: menuWaterLight 9s ease-in-out infinite alternate;
}

/* seconda pelle organica */
.menu-bg-water .menu-bg-water__surface2{
  position: absolute;
  inset: -4%;
  z-index: 2;
  pointer-events: none;
  opacity: .28;
  background:
    radial-gradient(ellipse at 30% 22%, rgba(255,255,255,.20) 0%, rgba(255,255,255,0) 16%),
    radial-gradient(ellipse at 82% 54%, rgba(255,255,255,.14) 0%, rgba(255,255,255,0) 16%),
    radial-gradient(ellipse at 54% 86%, rgba(255,255,255,.12) 0%, rgba(255,255,255,0) 14%);
  filter: blur(18px);
  animation: menuWaterLight2 16s ease-in-out infinite alternate;
}

.menu-bg-water > *{
  position: relative;
  z-index: 3;
}

@keyframes menuWaterBlob1{
  0%{
    transform: translate3d(0,0,0) scale(1);
  }
  50%{
    transform: translate3d(2%,-2%,0) scale(1.06);
  }
  100%{
    transform: translate3d(-2%,1.5%,0) scale(1.03);
  }
}

@keyframes menuWaterBlob2{
  0%{
    transform: translate3d(0,0,0) scale(1) rotate(0deg);
  }
  50%{
    transform: translate3d(-1.5%,2%,0) scale(1.05) rotate(.8deg);
  }
  100%{
    transform: translate3d(2%,-1%,0) scale(1.04) rotate(-.6deg);
  }
}

@keyframes menuWaterLight{
  0%{
    transform: translate3d(0,0,0) scale(1);
    opacity: .34;
  }
  100%{
    transform: translate3d(1.5%,-1%,0) scale(1.04);
    opacity: .48;
  }
}

@keyframes menuWaterLight2{
  0%{
    transform: translate3d(0,0,0) scale(1);
  }
  100%{
    transform: translate3d(-1.5%,1.2%,0) scale(1.03);
  }
}

@media (prefers-reduced-motion: reduce){
  .menu-bg-water::before,
  .menu-bg-water::after,
  .menu-bg-water .menu-bg-water__surface,
  .menu-bg-water .menu-bg-water__surface2{
    animation: none !important;
  }
}

/* ===== MENU OFFCANVAS CLEAN: linea + pallino + wave ===== */

.rose-offcanvas-full .nav.flex-column > .nav-item > .nav-link, .rose-offcanvas-full__grid .nav li {
  position: relative;
  display: inline-block !important;
  font-family: var(--family2);
  width: 90% !important;
  padding: .38rem 0 .82rem 1.25rem !important;
  line-height: .8 !important;
  color: #fff !important;
  text-decoration: none !important;
  background-repeat: no-repeat !important;
  transition:
    color .35s ease,
    transform .35s ease,
    background-size .35s ease,
    background-position .35s ease;

  /* pallino + linea + riflesso */
  background-image:
    radial-gradient(circle, var(--sun) 0 58%, transparent 62%),
    linear-gradient(90deg, rgba(63,160,184,.95), rgba(224,159,62,1)),
    linear-gradient(90deg, transparent 0%, rgba(255,255,255,.95) 50%, transparent 100%);
  background-size:
    0 0,
    0 3px,
    0 3px;
  background-position:
    left .05rem center,
    left 1.25rem bottom 0,
    left 1.25rem bottom 0;
}
.rose-offcanvas-full__grid .nav li a{ color: #fff !important;font-family: var(--family2);font-size:1.3rem;padding: .38rem 0 .82rem 1.25rem !important;
  line-height: .8 !important;  text-decoration: none !important;}
/* hover */
.rose-offcanvas-full .nav.flex-column > .nav-item > .nav-link:hover,.rose-offcanvas-full__grid .nav li:hover{
  color: var(--sun) !important;
  transform: translateX(8px);
  background-size:
    9px 9px,
    calc(100% - 1.25rem) 3px,
    42px 3px;
  animation: dgWaveLine 1.6s linear infinite;
}

/* attivo */
.rose-offcanvas-full .nav.flex-column > .nav-item > .nav-link.active,
.rose-offcanvas-full .nav.flex-column > .nav-item > .nav-link.nav-path-selected, , .rose-offcanvas-full__grid ul.nav li{
  color: var(--sun) !important;
  background-size:
    9px 9px,
    calc(100% - 1.25rem) 3px,
    54px 3px;
  animation: dgWaveLine 2.2s linear infinite;
}

@keyframes dgWaveLine{
  0%{
    background-position:
      left .05rem center,
      left 1.25rem bottom 0,
      left 1.25rem bottom 0;
  }
  100%{
    background-position:
      left .05rem center,
      left 1.25rem bottom 0,
      calc(100% - .35rem) bottom 0;
  }
}
/* ===== RIGHT PANEL BACKGROUND: acqua soft premium ===== */

.rose-panel-col--news,
.lido-panel-col--news{
  position: relative;
  overflow: hidden;
  isolation: isolate;
  background:
    linear-gradient(180deg,
      rgba(255,247,238,.96) 0%,
      rgba(243,239,235,.88) 28%,
      rgba(210,234,238,.82) 68%,
      rgba(166,214,223,.78) 100%);
}

/* tutti i contenuti sopra il background */
.rose-panel-col--news > *,
.lido-panel-col--news > *{
  position: relative;
  z-index: 3;
}

/* luce morbida che si muove */
.rose-panel-col--news::before,
.lido-panel-col--news::before{
  content: "";
  position: absolute;
  inset: -12%;
  z-index: 0;
  pointer-events: none;
  background:
    radial-gradient(circle at 18% 22%, rgba(255,255,255,.46) 0%, transparent 18%),
    radial-gradient(circle at 78% 16%, rgba(224,159,62,.14) 0%, transparent 18%),
    radial-gradient(circle at 52% 72%, rgba(63,160,184,.14) 0%, transparent 26%);
  filter: blur(10px);
  animation: lidoNewsGlow 10s ease-in-out infinite alternate;
}

/* onde grandi / riflessi */
.rose-panel-col--news::after,
.lido-panel-col--news::after{
  content: "";
  position: absolute;
  left: -10%;
  top: 10%;
  width: 120%;
  height: 85%;
  z-index: 1;
  pointer-events: none;
  opacity: .95;
  filter: blur(16px);
  background:
    radial-gradient(ellipse at 18% 38%, rgba(255,255,255,.34) 0%, rgba(255,255,255,0) 34%),
    radial-gradient(ellipse at 48% 58%, rgba(63,160,184,.10) 0%, rgba(63,160,184,0) 34%),
    radial-gradient(ellipse at 84% 34%, rgba(255,255,255,.26) 0%, rgba(255,255,255,0) 28%);
  animation: lidoNewsWave 7s ease-in-out infinite;
}

/* texture acqua leggera */
.rose-panel-col--news{
  background-image:
    linear-gradient(180deg,
      rgba(255,247,238,.96) 0%,
      rgba(243,239,235,.88) 28%,
      rgba(210,234,238,.82) 68%,
      rgba(166,214,223,.78) 100%),
    repeating-linear-gradient(
      108deg,
      rgba(255,255,255,.00) 0px,
      rgba(255,255,255,.00) 12px,
      rgba(255,255,255,.12) 17px,
      rgba(255,255,255,.00) 26px,
      rgba(255,255,255,.00) 38px
    );
  background-size: 100% 100%, 140px 140px;
  animation: lidoSurfaceMove 14s linear infinite;
}

.lido-panel-col--news{
  background-image:
    linear-gradient(180deg,
      rgba(255,247,238,.96) 0%,
      rgba(243,239,235,.88) 28%,
      rgba(210,234,238,.82) 68%,
      rgba(166,214,223,.78) 100%),
    repeating-linear-gradient(
      108deg,
      rgba(255,255,255,.00) 0px,
      rgba(255,255,255,.00) 12px,
      rgba(255,255,255,.12) 17px,
      rgba(255,255,255,.00) 26px,
      rgba(255,255,255,.00) 38px
    );
  background-size: 100% 100%, 140px 140px;
  animation: lidoSurfaceMove 14s linear infinite;
}

/* un po' di glass sulle card interne */
.rose-panel-col--news .rose-newsitem,
.lido-panel-col--news .rose-newsitem{
  background: rgba(255,255,255,.62);
  backdrop-filter: blur(10px);
  border: 1px solid rgba(11,42,58,.08);
  box-shadow: 0 10px 30px rgba(11,42,58,.06);
}

/* divisori piÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¹ morbidi */
.rose-panel-col--news .rose-panel-divider,
.lido-panel-col--news .rose-panel-divider{
  background: linear-gradient(
    90deg,
    rgba(11,42,58,0) 0%,
    rgba(11,42,58,.14) 50%,
    rgba(11,42,58,0) 100%
  );
}

/* animazioni */
@keyframes lidoNewsGlow{
  0%{
    transform: translate3d(0,0,0) scale(1);
    opacity: .92;
  }
  50%{
    transform: translate3d(2%,-2%,0) scale(1.04);
    opacity: 1;
  }
  100%{
    transform: translate3d(-2%,1.5%,0) scale(1.02);
    opacity: .9;
  }
}

@keyframes lidoNewsWave{
  0%{
    transform: translate3d(0,0,0) scale(1) rotate(0deg);
  }
  25%{
    transform: translate3d(-2%,1%,0) scale(1.03) rotate(-.8deg);
  }
  50%{
    transform: translate3d(2%,-1%,0) scale(1.05) rotate(.8deg);
  }
  75%{
    transform: translate3d(-1%,1%,0) scale(1.02) rotate(-.4deg);
  }
  100%{
    transform: translate3d(0,0,0) scale(1) rotate(0deg);
  }
}

@keyframes lidoSurfaceMove{
  0%{
    background-position: 0 0, 0 0;
  }
  100%{
    background-position: 0 0, 140px 40px;
  }
}

@media (prefers-reduced-motion: reduce){
  .rose-panel-col--news,
  .lido-panel-col--news,
  .rose-panel-col--news::before,
  .lido-panel-col--news::before,
  .rose-panel-col--news::after,
  .lido-panel-col--news::after{
    animation: none !important;
  }
}
/* opzionale: centrare meglio la lista su mobile */
@media (max-width: 991px){
  .rose-offcanvas-full .nav.flex-column > .nav-item{
    display: flex;
    justify-content: center;
  }

  .rose-offcanvas-full .nav.flex-column > .nav-item > .nav-link{
    padding-left: 1.15rem !important;
    text-align: center;
  }

  .rose-offcanvas-full .nav.flex-column > .nav-item > .nav-link:hover{
    transform: none;
  }
}
.rose-offers-page{
  position: relative;
  padding: 7rem 0;
  background:
    radial-gradient(circle at 12% 14%, rgba(224,159,62,.12) 0%, rgba(224,159,62,0) 24%),
    radial-gradient(circle at 80% 18%, rgba(255,247,238,.80) 0%, rgba(255,247,238,0) 22%),
    radial-gradient(circle at 68% 76%, rgba(63,160,184,.10) 0%, rgba(63,160,184,0) 26%),
    linear-gradient(180deg, #f6efe8 0%, #f3efeb 36%, #edf5f6 100%);
  overflow: hidden;
}

.rose-offers-page::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  opacity:.35;
  background:
    radial-gradient(ellipse at 20% 32%, rgba(255,255,255,.35) 0%, rgba(255,255,255,0) 22%),
    radial-gradient(ellipse at 75% 44%, rgba(255,255,255,.20) 0%, rgba(255,255,255,0) 18%);
  filter: blur(18px);
}

.rose-offers-page .container{
  position: relative;
  z-index: 2;
}

.rose-offers-hero{
  max-width: 860px;
  margin: 0 auto 3rem;
}

.rose-offers-kicker{
  margin: 0 0 .8rem;
  color: var(--sun);
  font-size: .78rem;
  letter-spacing: .30em;
  text-transform: uppercase;
  font-weight: 700;
}

.rose-offers-title{
  margin: 0 0 1rem;
  font-family: "Cormorant Garamond", serif;
  font-size: clamp(3rem, 6vw, 5.3rem);
  line-height: .95;
  color: var(--lake);
}

.rose-offers-lead{
  max-width: 760px;
  margin: 0 auto;
  color: rgba(11,42,58,.72);
  font-size: 1.05rem;
  line-height: 1.9;
}

.rose-offers-anchor{
  margin-bottom: 4rem;
}

.rose-offers-chip{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: .9rem 1.3rem;
  border-radius: 999px;
  text-decoration: none;
  color: var(--lake);
  background: rgba(255,255,255,.65);
  border: 1px solid rgba(11,42,58,.10);
  box-shadow: 0 8px 24px rgba(11,42,58,.06);
  transition: all .35s ease;
}

.rose-offers-chip:hover{
  color: #fff;
  background: var(--lake);
  border-color: var(--lake);
  transform: translateY(-2px);
}

.rose-offers-section{
  margin-bottom: 5rem;
}

.rose-offers-section--alt{
  margin-top: 1rem;
}

.rose-offers-head{
  max-width: 880px;
  margin-bottom: 2rem;
}

.rose-offers-section-kicker{
  margin: 0 0 .6rem;
  color: var(--sun);
  font-size: .74rem;
  letter-spacing: .28em;
  text-transform: uppercase;
  font-weight: 700;
}

.rose-offers-section-title{
  margin: 0 0 .8rem;
  font-family: "Cormorant Garamond", serif;
  font-size: clamp(2.2rem, 4vw, 3.5rem);
  line-height: 1;
  color: var(--lake);
}

.rose-offers-section-text{
  margin: 0;
  color: rgba(11,42,58,.72);
  line-height: 1.85;
  font-size: 1rem;
}

.rose-offer-card{
  position: relative;
  height: 100%;
  padding: 2rem 1.5rem;
  border-radius: 26px;
  background: rgba(255,255,255,.72);
  border: 1px solid rgba(11,42,58,.08);
  backdrop-filter: blur(12px);
  box-shadow: 0 18px 48px rgba(11,42,58,.08);
  overflow: hidden;
  transition: transform .35s ease, box-shadow .35s ease, border-color .35s ease;
}

.rose-offer-card::before{
  content: "";
  position: absolute;
  top: -40px;
  right: -30px;
  width: 120px;
  height: 120px;
  border-radius: 50%;
  background: rgba(224,159,62,.10);
  filter: blur(10px);
}

.rose-offer-card:hover{
  transform: translateY(-4px);
  box-shadow: 0 24px 56px rgba(11,42,58,.12);
  border-color: rgba(224,159,62,.22);
}

.rose-offer-period{
  display: inline-block;
  margin-bottom: 1rem;
  color: var(--lake);
  font-size: .82rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  font-weight: 700;
}

.rose-offer-price{
  font-family: "Cormorant Garamond", serif;
  font-size: clamp(2.3rem, 4vw, 3.2rem);
  line-height: 1;
  color: var(--lake);
  margin-bottom: .65rem;
}

.rose-offer-note{
  margin: 0;
  color: rgba(11,42,58,.62);
  line-height: 1.6;
}

.rose-rate-block{
  margin-bottom: 2rem;
  border-radius: 30px;
  overflow: hidden;
  background: rgba(255,255,255,.68);
  border: 1px solid rgba(11,42,58,.08);
  box-shadow: 0 18px 48px rgba(11,42,58,.08);
  backdrop-filter: blur(12px);
}

.rose-rate-block__head{
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 1rem;
  padding: 1.8rem 2rem;
  background: linear-gradient(135deg, rgba(11,42,58,.95) 0%, rgba(20,56,75,.92) 100%);
  color: #fff;
}

.rose-rate-block__head h3{
  margin: 0;
  font-family: "Cormorant Garamond", serif;
  font-size: clamp(2rem, 3vw, 2.8rem);
  line-height: 1;
  color: #fff;
}

.rose-rate-block__kicker{
  display: inline-block;
  margin-bottom: .45rem;
  color: rgba(255,255,255,.72);
  font-size: .72rem;
  letter-spacing: .24em;
  text-transform: uppercase;
}

.rose-rate-block__stay{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: .75rem 1rem;
  border-radius: 999px;
  background: rgba(255,255,255,.10);
  border: 1px solid rgba(255,255,255,.14);
  color: #fff;
  font-size: .78rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  font-weight: 700;
  white-space: nowrap;
}

.rose-rate-list{
  padding: 1rem 2rem 1.4rem;
}

.rose-rate-row{
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1.2rem;
  padding: 1rem 0;
  border-bottom: 1px solid rgba(11,42,58,.08);
}

.rose-rate-row:last-child{
  border-bottom: 0;
}

.rose-rate-row span{
  color: var(--lake);
  font-size: 1rem;
  line-height: 1.5;
}

.rose-rate-row strong{
  color: var(--lake);
  font-size: 1.08rem;
  font-weight: 700;
  white-space: nowrap;
}

.rose-offers-cta{
  margin-top: 5rem;
}

.rose-offers-cta__inner{
  padding: 3rem 2rem;
  border-radius: 34px;
  background: linear-gradient(135deg, rgba(11,42,58,.96) 0%, rgba(20,55,72,.92) 100%);
  box-shadow: 0 30px 70px rgba(11,42,58,.16);
}

.rose-offers-cta__title{
  margin: 0 0 .8rem;
  font-family: "Cormorant Garamond", serif;
  font-size: clamp(2.2rem, 4vw, 3.4rem);
  line-height: 1;
  color: #fff;
}

.rose-offers-cta__text{
  max-width: 720px;
  margin: 0 auto 1.5rem;
  color: rgba(243,239,235,.78);
  line-height: 1.85;
}

@media (max-width: 991.98px){
  .rose-offers-page{
    padding: 5.5rem 0;
  }

  .rose-rate-block__head{
    flex-direction: column;
    align-items: flex-start;
  }

  .rose-rate-block__stay{
    white-space: normal;
  }

  .rose-rate-list{
    padding: 1rem 1.25rem 1.2rem;
  }
}

@media (max-width: 767.98px){
  .rose-offer-card{
    padding: 1.6rem 1.25rem;
  }

  .rose-rate-row{
    align-items: flex-start;
    flex-direction: column;
    gap: .35rem;
  }

  .rose-offers-cta__inner{
    padding: 2.2rem 1.2rem;
  }
}.rose-cta__btn{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 58px;
  padding: .95rem 1.8rem;
  border: 0;
  border-radius: 999px;
  background: var(--sun);
  color: #fff;
  font-size: .82rem;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
  text-decoration: none;
  box-shadow: 0 12px 28px rgba(224,159,62,.28);
  transition:
    transform .25s ease,
    box-shadow .25s ease,
    background-color .25s ease,
    color .25s ease;
}

.rose-cta__btn:hover{
  transform: translateY(-2px);
  background: var(--lake);
  color: #fff;
  box-shadow: 0 18px 34px rgba(11,42,58,.22);
}

.rose-cta__btn:active{
  transform: translateY(0);
}

.rose-cta__btn:focus-visible{
  outline: 2px solid rgba(11,42,58,.22);
  outline-offset: 3px;
}

.rose-booking-card{
  position: relative;
  max-width: 920px;
  margin: 0 auto;
  padding: 2.2rem 2rem;
  border-radius: 30px;
  overflow: hidden;
  background:
    linear-gradient(180deg, rgba(255,255,255,.78) 0%, rgba(255,247,238,.72) 100%);
  border: 1px solid rgba(11,42,58,.08);
  box-shadow: 0 20px 55px rgba(11,42,58,.08);
  backdrop-filter: blur(12px);
}

.rose-booking-card__glow{
  position: absolute;
  top: -60px;
  right: -40px;
  width: 180px;
  height: 180px;
  border-radius: 50%;
  background: rgba(224,159,62,.12);
  filter: blur(18px);
  pointer-events: none;
}

.rose-booking-card__kicker{
  position: relative;
  z-index: 2;
  margin: 0 0 .7rem;
  color: var(--sun);
  font-size: .76rem;
  font-weight: 700;
  letter-spacing: .28em;
  text-transform: uppercase;
}

.rose-booking-card__title{
  position: relative;
  z-index: 2;
  margin: 0 0 1.4rem;
  font-family: "Cormorant Garamond", serif;
  font-size: clamp(2rem, 4vw, 3rem);
  line-height: 1;
  color: var(--lake);
}

.rose-booking-list{
  position: relative;
  z-index: 2;
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 1rem;
}

.rose-booking-list li{
  position: relative;
  padding: 1rem 1rem 1rem 1.2rem;
  border-radius: 18px;
  background: rgba(255,255,255,.58);
  border: 1px solid rgba(11,42,58,.06);
  color: rgba(11,42,58,.82);
  line-height: 1.8;
  box-shadow: 0 10px 30px rgba(11,42,58,.04);
}

.rose-booking-list li::before{
  content: "";
  position: absolute;
  top: 1.35rem;
  left: .55rem;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--sun);
}

.rose-booking-list strong{
  color: var(--lake);
}

.rose-booking-list__refund{
  padding-bottom: 1.2rem !important;
}

.rose-booking-table-wrap{
  margin-top: .9rem;
  overflow-x: auto;
}

.rose-booking-table{
  width: 100%;
  border-collapse: collapse;
  overflow: hidden;
  border-radius: 18px;
  background: rgba(255,255,255,.72);
}

.rose-booking-table thead th{
  padding: .9rem 1rem;
  text-align: left;
  font-size: .82rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: #fff;
  background: linear-gradient(135deg, rgba(11,42,58,.96) 0%, rgba(20,56,75,.92) 100%);
}

.rose-booking-table tbody td{
  padding: .95rem 1rem;
  border-bottom: 1px solid rgba(11,42,58,.08);
  color: rgba(11,42,58,.82);
  font-size: .98rem;
}

.rose-booking-table tbody tr:last-child td{
  border-bottom: 0;
}

.rose-booking-table tbody tr:nth-child(even){
  background: rgba(243,239,235,.55);
}

.rose-booking-muted{
  color: rgba(11,42,58,.62);
}

.rose-booking-note{
  position: relative;
  z-index: 2;
  margin-top: 1.25rem;
  padding: 1.15rem 1.2rem;
  border-radius: 20px;
  background: rgba(11,42,58,.94);
  box-shadow: 0 18px 40px rgba(11,42,58,.12);
}

.rose-booking-note__title{
  margin: 0 0 .35rem;
  color: var(--sun);
  font-size: .78rem;
  font-weight: 700;
  letter-spacing: .24em;
  text-transform: uppercase;
}

.rose-booking-note__text{
  margin: 0;
  color: rgba(243,239,235,.82);
  line-height: 1.8;
  font-size: .96rem;
}

@media (max-width: 767.98px){
  .rose-booking-card{
    padding: 1.5rem 1rem;
    border-radius: 24px;
  }

  .rose-booking-list li{
    padding: .95rem .9rem .95rem 1.1rem;
  }

  .rose-booking-table thead th,
  .rose-booking-table tbody td{
    padding: .8rem .75rem;
  }
}


/* =========================================================
   FAQ PAGE LAYOUT ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬ÃƒÂ¢Ã¢â€šÂ¬Ã…â€œ stile coerente con theme caricato
========================================================= */

.tlg-faq-section{
  position: relative;
  padding: 7rem 0;
  background: var(--off);
  overflow: hidden;
}

.tlg-faq-section::before{
  content: "";
  position: absolute;
  top: -120px;
  right: -120px;
  width: 340px;
  height: 340px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(224,159,62,.10) 0%, rgba(224,159,62,0) 70%);
  pointer-events: none;
}

.tlg-faq-head{
  max-width: 860px;
  margin: 0 auto 3.5rem auto;
  text-align: center;
}

.tlg-faq-head .tlg-kicker{
  justify-content: center;
  margin-bottom: .9rem;
}

.tlg-faq-head .tlg-h3{
  margin-bottom: 1rem;
}

.tlg-faq-intro{
  max-width: 720px;
  margin: 0 auto;
  color: rgba(11,42,58,.72);
  font-size: 1.02rem;
  line-height: 1.9;
}

.tlg-faq-shell{
  max-width: 980px;
  margin: 0 auto;
}

/* =========================
   CATEGORY TITLES
========================= */
.tlg-faq-shell .underHight{
  position: relative;
  margin: 4rem 0 1.5rem 0;
  padding: 0 0 .9rem 0;
  font-family: var(--family2);
  font-size: clamp(2rem, 3.5vw, 3rem);
  line-height: 1.05;
  font-weight: 600;
  color: var(--lake);
  text-transform: none;
  letter-spacing: 0;
  border-bottom: 1px solid rgba(11,42,58,.10);
}

.tlg-faq-shell .underHight::after{
  content: "";
  position: absolute;
  left: 0;
  bottom: -1px;
  width: 88px;
  height: 2px;
  background: var(--sun);
  border-radius: 999px;
}

/* =========================
   FAQ ITEM
========================= */
.tlg-faq-shell .toggle.faq{
  margin: 0 0 1rem 0 !important;
  padding: 0 !important;
  border: 1px solid rgba(11,42,58,.10);
  border-radius: 1.35rem;
  overflow: hidden;
  background: rgba(255,255,255,.72);
  box-shadow: 0 18px 40px rgba(11,42,58,.06);
  transition: transform .28s ease, box-shadow .28s ease, border-color .28s ease;
  backdrop-filter: blur(8px);
}

.tlg-faq-shell .toggle.faq:hover{
  transform: translateY(-2px);
  box-shadow: 0 26px 55px rgba(11,42,58,.10);
  border-color: rgba(224,159,62,.28);
}

/* HEADER */
.tlg-faq-shell .toggle-header{
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1.15rem 1.35rem;
  cursor: pointer;
  transition: background-color .25s ease;
}

.tlg-faq-shell .toggle-header:hover{
  background: rgba(243,239,235,.66);
}

.tlg-faq-shell .toggle-title{
  margin: 0;
  padding-left: 0 !important;
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-size: 1rem;
  line-height: 1.55;
  font-weight: 600;
  color: var(--lake);
}

.tlg-faq-shell .toggle-title strong{
  font-weight: 600;
}

/* ICON */
.tlg-faq-shell .toggle-icon{
  position: relative;
  flex: 0 0 42px;
  width: 42px;
  height: 42px;
  border-radius: 999px;
  border: 1px solid rgba(11,42,58,.14);
  background: rgba(11,42,58,.03);
  transition: background-color .25s ease, border-color .25s ease, transform .25s ease;
}

.tlg-faq-shell .toggle-icon::before,
.tlg-faq-shell .toggle-icon::after{
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 14px;
  height: 1.6px;
  background: var(--lake);
  border-radius: 999px;
  transform: translate(-50%, -50%);
  transition: transform .25s ease, opacity .25s ease, background-color .25s ease;
}

.tlg-faq-shell .toggle-icon::after{
  transform: translate(-50%, -50%) rotate(90deg);
}

.tlg-faq-shell .toggle.faq.is-open .toggle-icon{
  background: var(--sun);
  border-color: var(--sun);
  transform: rotate(180deg);
}

.tlg-faq-shell .toggle.faq.is-open .toggle-icon::before,
.tlg-faq-shell .toggle.faq.is-open .toggle-icon::after{
  background: #fff;
}

.tlg-faq-shell .toggle.faq.is-open .toggle-icon::after{
  opacity: 0;
}

/* CONTENT */
.tlg-faq-shell .toggle-content{
  display: none;
  padding: 0 1.35rem 1.35rem 1.35rem !important;
  color: rgba(11,42,58,.76);
  font-size: .98rem;
  line-height: 1.85;
}

.tlg-faq-shell .toggle.faq.is-open .toggle-content{
  display: block;
}

.tlg-faq-shell .toggle-content p:last-child{
  margin-bottom: 0;
}

.tlg-faq-shell .toggle-content a{
  color: var(--lake);
  text-decoration: none;
  border-bottom: 1px solid rgba(224,159,62,.45);
  transition: color .25s ease, border-color .25s ease;
}

.tlg-faq-shell .toggle-content a:hover{
  color: var(--sun);
  border-color: var(--sun);
}

/* CTA BUTTON INSIDE FAQ */
.tlg-faq-shell .button.button-rounded.button-amber{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: .95rem 1.4rem;
  border-radius: 999px;
  background: var(--sun);
  color: #fff !important;
  font-size: .78rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  border: 0;
  box-shadow: 0 18px 36px rgba(224,159,62,.22);
  transition: transform .25s ease, box-shadow .25s ease, background-color .25s ease;
}

.tlg-faq-shell .button.button-rounded.button-amber:hover{
  background: var(--lake);
  color: #fff !important;
  transform: translateY(-2px);
  box-shadow: 0 24px 42px rgba(11,42,58,.20);
}

/* SMALL REFINEMENTS */
.tlg-faq-shell u{
  text-decoration: none;
}

.tlg-faq-shell .pl-1,
.tlg-faq-shell .pl-4{
  padding-left: 1rem !important;
}

/* =========================
   MOBILE
========================= */
@media (max-width: 767.98px){
  .tlg-faq-section{
    padding: 5rem 0;
  }

  .tlg-faq-head{
    text-align: left;
    margin-bottom: 2.5rem;
  }

  .tlg-faq-intro{
    margin: 0;
    max-width: 100%;
    font-size: .96rem;
  }

  .tlg-faq-shell .underHight{
    margin-top: 3rem;
    font-size: 1.85rem;
  }

  .tlg-faq-shell .toggle-header{
    align-items: flex-start;
    padding: 1rem 1rem;
  }

  .tlg-faq-shell .toggle-title{
    font-size: .96rem;
    padding-right: .25rem;
  }

  .tlg-faq-shell .toggle-content{
    padding: 0 1rem 1rem 1rem !important;
    font-size: .94rem;
  }

  .tlg-faq-shell .toggle-icon{
    width: 38px;
    height: 38px;
    flex-basis: 38px;
  }
}


.tlg-footer__socials{
  margin-top: 1.5rem;
}

.tlg-footer__socialIcon{
  width: 48px;
  height: 48px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.14);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  text-decoration: none;
  transition: all .28s ease;
  background: rgba(255,255,255,.04);
}

.tlg-footer__socialIcon svg{
  width: 18px;
  height: 18px;
  display: block;
}

.tlg-footer__socialIcon:hover{
  background: var(--sun);
  border-color: var(--sun);
  color: var(--lake);
  transform: translateY(-2px);
}

.tlg-footer__badges{
  display: grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 1rem;
  align-items: stretch;
}

.tlg-footer__badge{
  min-height: 110px;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 1rem;
  padding: 1rem;
  display:flex;
  align-items:center;
  justify-content:center;
  text-decoration:none;
  transition: all .3s ease;
}

.tlg-footer__badge img{
  max-width: 100%;
  max-height: 70px;
  width: auto;
  height: auto;
  display:block;
}

.tlg-footer__badge:hover{
  transform: translateY(-3px);
  border-color: rgba(224,159,62,.45);
  box-shadow: 0 18px 35px rgba(0,0,0,.18);
}

.tlg-footer__badge--widget{
  padding: .75rem;
  text-align: center;
}

.tlg-footer__banners{
  display: table;
  gap: 1rem;
  max-width: 15vw;
  height: auto;
}

.tlg-footer__banner{
  display:block;
  border-radius: 1.1rem;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
  transition: all .3s ease;
}

.tlg-footer__banner img{
  width: 100%;
  height: auto;
  display: block;
}

.tlg-footer__banner:hover{
  transform: translateY(-3px);
  box-shadow: 0 20px 40px rgba(0,0,0,.18);
  border-color: rgba(224,159,62,.45);
}

.tlg-footer__reviewBox{
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 1.1rem;
  padding: 1rem;
  height: 100%;
  display:flex;
  align-items:center;
  justify-content:center;
}

.tlg-footer__reviewBox img{
  max-width: 100%;
  height: auto;
  display:block;
}

.tlg-footer .tlg-footer__item{
  color: rgba(243,239,235,.82);
}

.tlg-footer .tlg-footer__item:hover{
  color: var(--sun);
}

@media (max-width: 991.98px){
  .tlg-footer__badges{
    grid-template-columns: 1fr;
  }
  .lido-nav{background-color:#0B2A3A;}
  .tlg-brand{
  font-family: "Cormorant Garamond", serif;
  font-weight: 700;
  letter-spacing: .22em;
  font-size: 1.35rem;
  margin-left: 1rem;
  color: #fff;
}
  .logo{height: 75px;width:auto}
}
/* =========================
   Language dropdown
========================= */

.ha-lang{
  position: relative;
  z-index: 10020;
  display: inline-block;
  left: 15px;
}

.ha-lang__toggle{
  min-width: 86px;
  height: 44px;
  padding: 0 16px;
  border: 1px solid rgba(44,54,57,.14);
  border-radius: 999px;
  background: rgba(255,255,255,.58);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
  display: inline-flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-right: 1.1rem;
  color: #343a40;
  cursor: pointer;
  box-shadow: 0 10px 24px rgba(0,0,0,.06);
  transition: background .25s ease, border-color .25s ease, transform .25s ease, box-shadow .25s ease;
}

.ha-lang__toggle:hover{
  transform: translateY(-1px);
  background: rgba(255,255,255,.78);
  border-color: rgba(232,72,21,.22);
  box-shadow: 0 14px 28px rgba(0,0,0,.08);
}

.ha-lang__label{
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .28em;
  text-transform: uppercase;
  line-height: 1;
}

.ha-lang__chevron{
  width: 8px;
  height: 8px;
  border-right: 2px solid #E09F3E;
  border-bottom: 2px solid #E09F3E;
  transform: rotate(45deg) translateY(-1px);
  transition: transform .25s ease;
  flex: 0 0 auto;
}

.ha-lang.is-open .ha-lang__chevron{
  transform: rotate(-135deg) translateY(-1px);
}

.ha-lang__menu{
  position: absolute;
  top: calc(100% + 12px);
  right: 0;
  width: 220px;
  padding: 10px;
  border-radius: 22px;
  border: 1px solid rgba(44,54,57,.08);
  background: rgba(255,255,255,.88);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  box-shadow: 0 24px 60px rgba(0,0,0,.10);
  opacity: 0;
  visibility: hidden;
  transform: translateY(10px);
  pointer-events: none;
  transition: opacity .25s ease, transform .25s ease, visibility .25s ease;
}

.ha-lang.is-open .ha-lang__menu{
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
  pointer-events: auto;
}

.ha-lang__item{
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 16px;
  border-radius: 16px;
  color: #343a40;
  transition: background .22s ease, color .22s ease, transform .22s ease;
}

.ha-lang__item:hover{
  background: rgba(232,72,21,.07);
  color: var(--gold);
  transform: translateX(2px);
}

.ha-lang__item.is-active{
  background: rgba(232,72,21,.10);
}

.ha-lang__code{
  min-width: 34px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--gold);
}

.ha-lang__name{
  font-size: 15px;
  line-height: 1.2;
  color: inherit;
}

/* versione scura sopra hero */
.ha-headerV2 .ha-lang__toggle,
.ha-header .ha-lang__toggle{
  color: #343a40;
}

.ha-compass.is-scrolled ~ * .ha-lang__toggle{
  background: rgba(255,255,255,.78);
}

/* se vuoi forzarlo  elegante dentro header fixed */
.ha-headerV2 .ha-lang{
  pointer-events: auto;
}

/* Mobile */
@media (max-width: 991.98px){
  .ha-lang{

  left: 5px;
}
  .ha-lang__toggle{
    min-width: 58px;
    height: 40px;
    padding: 0 14px;
  }

  .ha-lang__label{
    font-size: 10px;
    letter-spacing: .22em;
  }

  .ha-lang__menu{
    width: 160px;
    border-radius: 18px;
  }

  .ha-lang__item{
    padding: 12px 14px;
  }

  .ha-lang__name{
    font-size: 14px;
  }
  .tlg-cta {
    display: inline-block;
    background: var(--sun);
    color: #fff;
    padding: .85rem 1.1rem;
    border-radius: 999px;
    font-size: .70rem;
    letter-spacing: .05em;
    font-weight: 700;
    text-decoration: none;
    box-shadow: 0 20px 50px rgba(0, 0, 0, .18);
    transition: background-color .25s ease, color .25s ease;
}
	.tlg-acc__list {
    gap: 7rem;  
}
	.tlg-accItem {
    margin-bottom: 1rem;
}
	.tlg-info{ padding: 2rem 0;  }
	

	#barMobBott {
    display: block!important;
    position: fixed!important;;
    bottom: 0px;
    left: 0px;
    width: 100%;
    z-index: 9950;background:var(--lake);
}

#barMobBott div.col {
    display: flex;
    width: 25.000000%;
    height: 60px;
    overflow: hidden;
    box-sizing: border-box;border-left: 1px solid rgba(255,255,255,0.2);
}
#barMobBott div.col figure {
    width: 100%;
    height: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
}
    #barMobBott div.col figure a {
  
    color: white!important;
}
#barMobBott div.col figure svg {
    width: 22px;
    height: 18px;
    position: relative;stroke:white!important;
}

.tlg-footer__banners{
  display: table;
  gap: 1rem;
  max-width: 60%;
  height: auto;margin-left:20%
}
	.tlg-footer__bottom{
 padding-bottom:4rem
}



}