:root{
      --bg:#0e1726; --text:#e6eaf2; --muted:#aab3c5; --accent:#38bdf8; --card:#131c2e; --shadow: 0 10px 30px rgba(0,0,0,.25);
    }
    *{box-sizing:border-box}
    html{scroll-behavior:smooth}
    body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto;line-height:1.6;color:var(--text);background:var(--bg)}
    a{color:inherit;text-decoration:none}
    img{max-width:100%;display:block}

/* NAV */
.nav{position:fixed;inset:0 0 auto 0;backdrop-filter:saturate(160%) blur(8px);background:linear-gradient(180deg,rgba(13,18,31,.85),rgba(13,18,31,.4) 70%,rgba(13,18,31,0));z-index:50}
.nav-inner{max-width:1100px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;padding:10px 20px}
.brand{display:flex;align-items:center;gap:.6rem;font-weight:800;letter-spacing:.3px}
.brand .logo{  width:60px;  height:60px;  object-fit:contain;  border-radius:8px;}
.menu{display:flex;gap:1.2rem;align-items:center}
.menu a{font-weight:600;color:var(--muted)}
.menu a:hover:not(.cta), .menu a.active{color:#fff}
.cta{padding:.55rem 1rem;border-radius:999px;background:var(--accent);color:#05121c;font-weight:800;box-shadow:var(--shadow)}
.cta:hover{color:#05121c; background:#67d3fb;}
/* New NAV with hamburger */
.menu-toggle{  display:none;  background:none;  border:0;  cursor:pointer;  padding:8px;  flex-direction:column;  gap:5px;}
.menu-toggle span{  display:block;  width:24px;  height:2px;  background:#fff;  border-radius:2px;}
.menu .cta {color: #05121c;}
.menu .cta:hover {  color: #05121c;  background: #67d3fb;}

/* Mobile */
@media (max-width: 768px){
  .nav-inner{ position:relative; padding:10px 16px;  }
  .brand{ max-width:calc(100% - 56px);  }
  .brand span{ font-size:.95rem; white-space:nowrap; overflow:hidden; text-overflow:ellipsis;  }
  .menu-toggle{ display:flex;  }
  .menu{ display:none; position:absolute; top:100%; left:12px; right:12px; background:var(--card); border:1px solid rgba(255,255,255,.08); border-radius:16px; box-shadow:var(--shadow); padding:12px; flex-direction:column; align-items:stretch; gap:.4rem;  }
  .menu.open{ display:flex;  }
  .menu a{ color:#fff; padding:10px 12px; border-radius:10px; font-size:0.95rem; }
  .menu a:hover:not(.cta){ background:rgba(255,255,255,.06);  }
  .menu .dropdown{ width:100%;  }
  .menu .cta{ display:block; width:100%; text-align:center;  }
  .menu .dropdown-content{ position:static; display:none; margin-top:8px; border-radius:12px; min-width:unset; box-shadow:none; background:rgba(255,255,255,.04);  }
  .dropdown:hover .dropdown-content{display:none;}
  .menu .dropdown.open .dropdown-content{ display:block;  }
  .menu .dropdown-content a{ padding:10px 12px;  }
}

    /* DROPDOWN */
.dropdown {  position: relative;}
.dropdown-content {  display: none;  position: absolute;  right: 0;  top: 120%;  background: var(--card);  border-radius: 12px;  box-shadow: var(--shadow);  overflow: hidden;  min-width: 200px;}
.dropdown-content a {  display: block;  padding: 10px 14px;  color: var(--text);  font-weight: 600;}
.dropdown-content a:hover {  background: rgba(255,255,255,0.05);}
/* Show on hover */
@media (min-width: 769px){
  .dropdown:hover .dropdown-content {
    display: block;
  }
}
/* HERO */
.hero{position:relative;min-height:92vh;display:grid;place-items:center;text-align:center}
.hero::before{content:"";position:absolute;inset:0;background:url('../images/porto_ceresio.webp') center/cover no-repeat ;filter:grayscale(.1) saturate(105%)}
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(6,16,28,.65),rgba(6,16,28,.55) 30%,rgba(6,16,28,.85));}
.hero .content{position:relative;z-index:1;max-width:900px;padding:0 20px}
.title{font-size:clamp(38px,6vw,64px);line-height:1.08;margin:0 0 .6rem}
.subtitle{font-size:clamp(16px,2.4vw,20px);color:var(--muted);max-width:700px;margin:0 auto 1.2rem}
.scroll-hint{margin-top:1.2rem;font-size:14px;color:var(--muted)}
.hero-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-top:18px}
.btn-secondary{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.35)}
.btn-secondary:hover{background:rgba(255,255,255,.08)}


/* SECTIONS */
section{padding:72px 20px}
.container{max-width:1100px;margin:0 auto}
.card{background:var(--card);border:1px solid rgba(255,255,255,.06);border-radius:16px;box-shadow:var(--shadow)}

/* ABOUT */
.about{display:grid;grid-template-columns:1.2fr .8fr;gap:24px}
@media (max-width:900px){.about{grid-template-columns:1fr;}}

/* AMENITIES */
.amenities{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media (max-width:800px){.amenities{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.amenities{grid-template-columns:1fr}}
.amenity{padding:16px 18px;border-radius:14px;border:1px dashed rgba(255,255,255,.12)}
.amenity h4{margin:.2rem 0;font-size:1rem}
.amenity p{margin:0;color:var(--muted);font-size:.95rem}

/* GALLERY */
.carousel{position:relative;overflow:hidden;border-radius:16px}
.track{display:flex;transition:transform .45s cubic-bezier(.22,.61,.36,1);}
.slide{min-width:100%;height:58vh;background:#0b1322;display:flex;place-items:center; justify-content: center;}
.slide img{max-width: 100%; max-height: 100%; width: auto; height: auto;}
.ctrl{position:absolute;top:50%;transform:translateY(-50%);background:rgba(0,0,0,.4);border:1px solid rgba(255,255,255,.2);backdrop-filter:blur(6px);padding:.6rem;border-radius:50%;cursor:pointer}
.prev{left:12px} .next{right:12px}
.dots{position:absolute;left:0;right:0;bottom:10px;display:flex;justify-content:center;gap:8px}
.dot{width:9px;height:9px;border-radius:50%;background:rgba(255,255,255,.4);border:1px solid rgba(255,255,255,.65);cursor:pointer}
.dot.active{background:#fff}

/* LOCATION */
.location-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media (max-width:900px){.location-grid{grid-template-columns:1fr}}
.map{aspect-ratio:16/10;border:0;border-radius:16px;overflow:hidden}
iframe{width:100%;height:100%;border:0}

/* CONTACT */
form{display:grid;gap:12px}
.row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media (max-width:720px){.row{grid-template-columns:1fr}}
label{font-weight:600;font-size:.95rem}
input, textarea{width:100%;padding:12px 14px;border-radius:12px;border:1px solid rgba(255,255,255,.12);background:#0b1322;color:#fff}
textarea{min-height:120px;resize:vertical}
.gdpr{font-size:.9rem;color:var(--muted)}
.btn{display:inline-block;padding:12px 18px;border-radius:12px;background:var(--accent);color:#05121c;font-weight:800;border:0;cursor:pointer}

/*  Country phone */
.iti__country-list {  background: #fff;   color: #0e1726;   }
.iti__country {  color: #0e1726;}
.iti__country:hover {  background-color: #f0f4f8;}
.iti__dial-code {  color: #555;}

/* FOOTER */
footer{padding:30px 20px;color:var(--muted);text-align:center}
