:root{--primary:#13b6ec;--bg-light:#f6f8f8;--bg-dark:#101d22;--text:#1f2937;--muted:#6b7280}
*{box-sizing:border-box}
html,body{height:100%;overflow-x:hidden}
body{margin:0;background:var(--bg-light);color:var(--text);font-family:"Plus Jakarta Sans",system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,"Helvetica Neue",Arial,sans-serif}
html{-webkit-text-size-adjust:100%}
header{padding-top:env(safe-area-inset-top)}
footer{padding-bottom:env(safe-area-inset-bottom)}
/* Header & Navigation */
.scroll-hint{display:flex;align-items:center;justify-content:center;gap:8px;color:var(--muted);font-size:.9rem;margin:6px 0 10px}
.scroll-hint .chev{font-size:1rem;animation:nudge 900ms ease-in-out infinite}
@keyframes nudge{0%{transform:translateX(0)}50%{transform:translateX(6px)}100%{transform:translateX(0)}}
@media(min-width:768px){.scroll-hint{display:none}}
/* Feature cards */
.feature-grid{display:grid;gap:16px;grid-template-columns:1fr}
@media(min-width:768px){.feature-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.feature-grid{grid-template-columns:repeat(4,1fr)}}
.card{border:1px solid rgba(19,182,236,.2);border-radius:12px;background:#fff;padding:24px;transition:transform 200ms ease,box-shadow 200ms ease}
.card:hover{transform:translateY(-2px);box-shadow:0 8px 20px rgba(0,0,0,.08)}
.card h3{margin:8px 0 4px}
.card p{margin:0;color:var(--muted)}
/* Packages carousel */
.carousel{overflow-x:auto;scroll-snap-type:x proximity;display:flex;gap:16px;padding:16px}
.carousel::-webkit-scrollbar{display:none}
.carousel-item{min-width:16rem;scroll-snap-align:start}
.packages-mobile-center #packagesScroll .flex[data-card]{scroll-snap-align:center}
@media(max-width:767px){
  #packagesScroll .flex[data-card]{min-width:100%;flex:0 0 100%;scroll-snap-align:center}
  #packagesScroll{scroll-padding-left:0;scroll-padding-right:0}
}
#packagesScroll [data-card]{scroll-snap-stop:always}
/* Ensure horizontal scrolling behavior consistently */
#packagesScroll{overflow-x:auto;overflow-y:hidden;touch-action:pan-x;-webkit-overflow-scrolling:touch;overscroll-behavior-x:none;overscroll-behavior-y:none;scroll-padding-left:16px;scroll-padding-right:16px;display:flex;gap:16px;scroll-snap-type:x mandatory}
@media(max-width:767px){
  .packages-mobile-center #packagesScroll{padding-left:0!important;padding-right:0!important;scroll-padding-left:0;scroll-padding-right:0}
}
/* Slider cards responsive sizing and snapping */
@media(max-width:767px){
  #packagesScroll .flex[data-card]{flex:0 0 100%;width:100%;min-width:100%;scroll-snap-align:center}
}
@media(min-width:768px){
  #packagesScroll{--cards-gap:1rem}
  #packagesScroll .flex[data-card]{flex:0 0 calc((100% - (var(--cards-gap)*2))/3);width:calc((100% - (var(--cards-gap)*2))/3);min-width:calc((100% - (var(--cards-gap)*2))/3);scroll-snap-align:start}
}
/* Ensure package images follow rounded container curves */
#packagesScroll .flex[data-card] .package-img{border-radius:inherit}
@media(max-width:767px){
  .packages-mobile-center h2{text-align:center;margin-left:auto;margin-right:auto;display:block;width:100%}
  .packages-mobile-center .scroll-hint{justify-content:center}
}
/* Package images fit to viewframe */
.package-img{width:100%;height:160px;object-fit:cover;border-radius:1rem;display:block;background-color:rgba(19,182,236,.08)}
@media(min-width:640px){.package-img{height:180px}}
@media(max-width:767px){
  .package-img{width:100%;height:180px;object-fit:contain;object-position:center;margin:0 auto;display:block;background-color:transparent}
}
.package-title{font-weight:700;letter-spacing:-.015em;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.package-desc{color:var(--muted);font-size:.875rem;line-height:1.4;margin:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:2.8em}
.reveal{opacity:0;transform:translateY(16px);transition:opacity 600ms ease,transform 600ms ease}
.reveal-in{opacity:1;transform:translateY(0)}
/* Gallery */
.gallery-grid{display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}
.gallery-card{position:relative;border-radius:12px;overflow:hidden;background:#fff;border:1px solid rgba(19,182,236,.2)}
.gallery-card img{display:block;width:100%;height:200px;object-fit:cover;transition:transform 250ms ease}
.gallery-card:hover img{transform:scale(1.03)}
.gallery-caption{position:absolute;left:0;right:0;bottom:0;display:flex;flex-direction:column;gap:2px;background:rgba(0,0,0,.45);backdrop-filter:blur(6px);color:#fff;padding:10px 14px}
.gallery-caption .caption-title{font-size:1rem;font-weight:800;letter-spacing:-.015em}
.gallery-caption .caption-subtitle{font-size:.8125rem;font-weight:500;color:rgba(255,255,255,.85)}
.package-title{font-weight:700;letter-spacing:-.015em;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.package-desc{color:var(--muted);font-size:.875rem;line-height:1.4;margin:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:2.8em}

/* Vertical page snapping removed to restore previous behavior */

/* Scroll edges hint for horizontal lists */
.scroll-edges{display:none}
/* Base on white section to avoid cast of bg-light */
.scroll-edge-left,.scroll-edge-right{display:none}
@media(min-width:768px){.scroll-edges{display:none}}

@media (prefers-reduced-motion: reduce){
  .reveal{transition:none}
  .revealed .text{animation:none}
}

/* Package thumbnails fallback bg (when remote images blocked) */
.package-thumb{background-color:rgba(19,182,236,.08)}

.snap-container{height:calc(100vh - var(--header-h,0px));width:100%;overflow-x:auto;overflow-y:hidden;scroll-snap-type:x mandatory;display:flex;-webkit-overflow-scrolling:touch;background:#000;color:#fff;-ms-overflow-style:none;scrollbar-width:none;touch-action:pan-x;overscroll-behavior-x:contain;overscroll-behavior-y:none}
.snap-container::-webkit-scrollbar{display:none}
.slide{position:relative;flex:0 0 100%;height:calc(100vh - var(--header-h,0px));scroll-snap-align:start;background-repeat:no-repeat;background-position:center;background-size:cover;background-color:transparent}
@supports (height: 100svh){
  .snap-container{height:calc(100svh - var(--header-h,0px))}
  .slide{height:calc(100svh - var(--header-h,0px))}
}
/* Mobile Gallery Fix Reverted */
@media (max-width: 1023px) {
  /* Restore snap behavior but allow vertical scroll if needed */
  .snap-container { 
    height: calc(100vh - var(--header-h,0px)); 
    display: flex !important; 
    flex-direction: row !important; /* Forza la direzione orizzontale */
    overflow-x: auto !important; 
    overflow-y: hidden; 
    scroll-snap-type: x mandatory; 
    background: #000; 
    width: 100%;
  }
  
  .slide { 
    height: 100% !important; 
    width: 100vw !important; /* Forza larghezza schermo intero */
    flex: 0 0 100% !important; /* Impedisce il ridimensionamento */
    display: block; 
    margin-bottom: 0; 
  }
  
  .bottom-caption { 
    bottom: calc(24px + env(safe-area-inset-bottom)); 
    left: 24px; 
    right: 24px; 
    text-align: center; 
    justify-content: center; 
    padding-bottom: env(safe-area-inset-bottom);
  }
  
  .text { 
    opacity: 0; 
    transform: translateY(18px); 
    text-align: center; 
  }
  
  .revealed .text { 
    animation: fadeInUp 700ms ease forwards; 
  }
  
  .text h1 { font-size: 2rem; }
  .text p { font-size: 1rem; }
}
.slide::before{content:"";position:absolute;inset:0;background:rgba(0,0,0,.45);pointer-events:none}
.content{position:relative;z-index:1;display:flex;align-items:center;justify-content:center;height:100%;width:100%;text-align:center;padding:0 5vw}
.bottom-caption{position:absolute;left:24px;right:24px;bottom:calc(24px + env(safe-area-inset-bottom));z-index:1;display:flex;justify-content:center;text-align:center;padding:0 2vw;padding-bottom:env(safe-area-inset-bottom)}
.text{max-width:72ch;opacity:0;transform:translateY(18px)}
.revealed .text{animation:fadeInUp 700ms ease forwards}
@keyframes fadeInUp{0%{opacity:0;transform:translateY(18px)}100%{opacity:1;transform:translateY(0)}}

.lightbox{position:fixed;inset:0;background:rgba(0,0,0,.75);display:none;align-items:center;justify-content:center;z-index:1000}
.lightbox.open{display:flex}
.lightbox img{max-width:90vw;max-height:85vh;border-radius:8px}
.lightbox .close{position:absolute;top:16px;right:16px;background:#fff;color:#000;border-radius:999px;padding:8px 12px;font-weight:700;cursor:pointer}

#mobileMenu{opacity:0;transform:translateY(-8px);transition:opacity 200ms ease,transform 200ms ease}
#mobileMenu.mm-open{opacity:1;transform:translateY(0)}
#mobileOverlay{opacity:0;transition:opacity 200ms ease}
#mobileOverlay.mo-open{opacity:1}
