
:root{
  --bg:#ffffff;
  --text:#0e2240;
  --muted:#4b5a73;
  --brand:#0057b8;
  --brand-2:#003e82;
  --surface:#f6f9ff;
  --border:#e1e8f5;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial;line-height:1.7;color:var(--text);
background:var(--bg)}
.skip-to{position:absolute;left:-9999px}
.skip-to:focus{position:static;padding:.5rem 1rem;background:#fff;
border:2px solid var(--brand)}
.site-nav{position:sticky;top:0;
  z-index:20;background:#fff;border-bottom:1px solid var(--border);
  display:flex;align-items:center;
  justify-content:space-between;
  padding:.9rem 1rem;gap:1rem}
.site-nav .logo{font-weight:900;letter-spacing:.3px;color:var(--brand);text-decoration:none;font-size:1.35rem}
.site-nav .logo span{color:var(--text)}
.site-nav ul{list-style:none;
  display:flex;gap:.4rem;
  flex-wrap:wrap;margin:0;
  padding:0}
.site-nav a{display:inline-block;
  padding:.5rem .7rem;
  text-decoration:none;
  color:var(--text);
  border-radius:.5rem}
.site-nav a:hover,.site-nav a:focus{background:var(--surface);
  color:var(--brand)}

.hero{position:relative;
  min-height:70vh;display:grid;
  place-items:center;
  overflow:hidden}
.hero img{position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  filter:brightness(.7)}
.hero-text{position:relative;
  z-index:1;
  text-align:center;
  color:#fff;max-width:900px;
  padding:0 1rem}
.hero-text h1{font-size:clamp(2rem,6vw,4rem);
  margin:.2rem 0 .5rem 0}
.hero-text p{opacity:.95;
  font-size:clamp(1rem,2.2vw,1.25rem)}
.cta-row{margin-top:1rem;
  display:flex;gap:.75rem;
  justify-content:center;
  flex-wrap:wrap}
.btn{padding:.7rem 1.1rem;
  border-radius:999px;
  background:#fff;color:var(--brand);
  border:2px solid #fff;
  font-weight:700;cursor:pointer;
  text-decoration:none}
.btn:hover,.btn:focus{background:transparent;color:#fff}

.section{padding:2.2rem 1rem}
.section h2{font-size:clamp(1.4rem,3vw,2rem);
  margin:.25rem 0 1rem 0}
.section .lead{color:var(--muted);
  max-width:820px}

.tiles{display:grid;
  grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
  gap:1rem}
.tile{position:relative;
  border-radius:1rem;overflow:hidden;
  min-height:220px;border:1px solid var(--border);
  background:#000}
.tile img{width:100%;height:100%;
  object-fit:cover;
  display:block;opacity:.92;
  transition:scale .3s ease}
.tile .label{position:absolute;
  inset:auto 0 0 0;padding:1rem;
  background:linear-gradient(transparent,rgba(0,0,0,.65));
  color:#fff;font-weight:800;
  letter-spacing:.3px}
.tile:hover img{scale:1.03}

.cards{padding:2rem 1rem}
.grid-3{display:grid;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:1rem}
.card{background:#fff;
  border:1px solid var(--border);
  border-radius:1rem;padding:1rem}
.card img{width:100%;height:200px;
  object-fit:cover;
  border-radius:.75rem}
.card h3{margin:.6rem 0 .3rem 0}

.page-header{padding:2rem 1rem;
  background:var(--surface);
  border-bottom:1px solid var(--border)}
.page-header h1{margin:.3rem 0 0 0;
  font-size:clamp(1.8rem,3.5vw,2.4rem)}
.page-header .lead{color:var(--muted)}

.split{display:grid;
  grid-template-columns:1fr;
  gap:1rem;
  align-items:start}
.split img{width:100%;
  height:260px;
  object-fit:cover;
  border-radius:.75rem;
  border:1px solid var(--border)}
@media (min-width: 900px){ .split{grid-template-columns:1.2fr 1fr} }

.strip{padding:1.5rem 1rem;
  background:var(--surface);
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border)}
.bullets{padding-left:1.1rem}

.itinerary{padding:2rem 1rem}
.itinerary ol{padding-left:1.25rem}
.note{color:var(--muted);
  font-style:italic}

.grid-2{display:grid;grid-template-columns:1fr;gap:1rem;padding:2rem 1rem}
.grid-2>div{background:#fff;border:1px solid var(--border);
  border-radius:1rem;padding:1rem}
@media (min-width: 900px){ .grid-2{grid-template-columns:1fr 1fr} }

.contact-form{display:grid;
  gap:.8rem;padding:2rem 1rem}
.contact-form fieldset{border:1px solid var(--border);
  border-radius:.75rem;
  padding:1rem;margin:0}
.contact-form label{display:block;
  margin:.25rem 0 .25rem;
  font-weight:650}
.contact-form input[type="text"], 
.contact-form input[type="email"], 
.contact-form textarea{width:100%;
  padding:.7rem .8rem;border:1px solid var(--border)
  ;border-radius:.6rem;
  font:inherit}
.contact-form input:focus,
 .contact-form textarea:focus{outline:3px solid #cfe3ff;border-color:var(--brand)}
.contact-form .consent{display:flex;gap:.5rem;align-items:flex-start;
  font-weight:400}

.site-footer{padding:2.2rem 1rem;
  background:#071a3d;
  color:#eaf0ff;
  margin-top:2rem}
.site-footer a{color:#eaf0ff;
  text-decoration:none}
.site-footer a:hover{text-decoration:underline}
.footer-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
  gap:1rem}
.updated{opacity:.8;font-size:.9rem}
/* ========== Responsive 3-dot menu ========== */
.menu-toggle {
  display: none;
  background: none;
  border: none;
  font-size: 28px;
  color: var(--brand);
  cursor: pointer;
}

/* Hide the list by default on mobile */
@media (max-width: 768px) {
  .menu-toggle {
    display: block;
  }

  .site-nav ul {
    display: none;
    flex-direction: column;
    position: absolute;
    top: 100%;
    right: 1rem;
    background: var(--bg);
    border: 1px solid var(--border);
    border-radius: 0.75rem;
    box-shadow: 0 4px 10px rgba(0,0,0,0.15);
    padding: 0.5rem 0;
    width: 180px;
  }

  .site-nav ul.open {
    display: flex;
  }

  .site-nav ul li {
    width: 100%;
  }

  .site-nav ul a {
    display: block;
    width: 100%;
    padding: 0.7rem 1rem;
  }

  .site-nav ul a:hover {
    background: var(--surface);
  }
}

