:root{
  --ink:#1f2f38;
  --muted:#5c6870;
  --line:#e5e1d8;
  --lake:#0f6f8f;
  --lake-dark:#0b536b;
  --lake-soft:#e8f5f7;
  --sand:#f5f0e7;
  --cream:#fffdf8;
  --white:#fff;
  --shadow:0 18px 45px rgba(32,48,56,.13);
  --radius:14px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Arial,Helvetica,sans-serif;
  color:var(--ink);
  line-height:1.55;
  background:var(--cream);
}
a{color:inherit}
.container{
  width:min(1120px,calc(100% - 40px));
  margin:0 auto;
}
.skip-link{position:absolute;left:-999px}
.skip-link:focus{left:16px;top:16px;background:#fff;padding:10px;z-index:99}

.site-header{
  position:sticky;
  top:0;
  z-index:20;
  background:rgba(255,253,248,.96);
  border-bottom:1px solid var(--line);
  backdrop-filter:blur(10px);
}
.nav{
  display:flex;
  justify-content:space-between;
  align-items:center;
  min-height:70px;
  gap:24px;
}
.brand{
  display:flex;
  align-items:center;
  gap:10px;
  font-weight:700;
}
.brand-mark{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:36px;
  height:36px;
  border-radius:50%;
  background:var(--lake);
  color:#fff;
  font-size:.82rem;
}
nav{display:flex;align-items:center;gap:20px;font-size:.93rem}
nav a{text-decoration:none}
.nav-cta{
  background:var(--lake);
  color:#fff;
  padding:10px 15px;
  border-radius:999px;
}

.hero{
  position:relative;
  min-height:78vh;
  display:flex;
  align-items:center;
  background:
    linear-gradient(90deg,rgba(255,253,248,.82),rgba(255,253,248,.34)),
    linear-gradient(135deg,#dceff4,#f5f0e7);
  overflow:hidden;
}
.hero-video{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
}
.video-slot::after{
  content:"Drone video placeholder: replace with silent looping Mara Lake footage";
  position:absolute;
  right:28px;
  bottom:22px;
  color:rgba(31,47,56,.55);
  font-weight:700;
  font-size:.86rem;
}
.hero-overlay{
  position:absolute;
  inset:0;
  background:linear-gradient(90deg,rgba(255,253,248,.72),rgba(255,253,248,.15));
}
.hero-grid{
  position:relative;
  z-index:2;
  display:grid;
  grid-template-columns:1fr;
  align-items:center;
  padding:92px 0;
}
.hero-copy{
  max-width:760px;
  background:rgba(255,253,248,.9);
  border-radius:var(--radius);
  padding:44px;
  box-shadow:var(--shadow);
}
.eyebrow,.section-label{
  text-transform:uppercase;
  letter-spacing:.13em;
  font-weight:700;
  color:var(--lake-dark);
  font-size:.76rem;
}
h1{
  font-size:clamp(2.6rem,6vw,5.1rem);
  line-height:1.02;
  margin:12px 0 18px;
}
.hero-subtitle{
  font-size:clamp(1.05rem,2vw,1.34rem);
  max-width:680px;
  color:#344a54;
}
.button-row{display:flex;flex-wrap:wrap;gap:12px;margin-top:28px}
.button{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  text-decoration:none;
  border-radius:999px;
  padding:13px 21px;
  font-weight:700;
  transition:.2s ease;
}
.button.primary{background:var(--lake);color:#fff}
.button.primary:hover{background:var(--lake-dark)}
.button.secondary{background:#fff;color:var(--lake-dark);border:2px solid var(--lake)}
.button.large{font-size:1.05rem;padding:15px 26px}

.quick-panel{
  background:transparent;
  transform:translateY(-34px);
  position:relative;
  z-index:5;
}
.quick-grid{
  display:grid;
  grid-template-columns:repeat(6,1fr);
  gap:1px;
  background:var(--line);
  border-radius:var(--radius);
  overflow:hidden;
  box-shadow:var(--shadow);
}
.quick-grid div{background:#fff;padding:22px 16px}
.quick-grid strong{display:block;margin-bottom:6px}
.quick-grid span{display:block;color:var(--muted);font-size:.92rem}

.section{padding:86px 0;border-bottom:1px solid var(--line);background:var(--cream)}
.section.muted{background:var(--lake-soft)}
.split-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:54px;
  align-items:center;
}
h2{
  font-size:clamp(2rem,4vw,3.15rem);
  line-height:1.12;
  margin:10px 0 20px;
}
h3{font-size:1.25rem;margin:0 0 10px}
p{color:var(--muted)}
.wide-copy{max-width:860px;font-size:1.08rem}
.text-link{display:inline-block;margin-top:10px;font-weight:700;color:var(--lake-dark)}

.image-slot{
  background:
    linear-gradient(135deg,rgba(15,111,143,.12),rgba(245,240,231,.72)),
    repeating-linear-gradient(45deg,rgba(255,255,255,.35),rgba(255,255,255,.35) 12px,rgba(255,255,255,.12) 12px,rgba(255,255,255,.12) 24px);
}
.media-card{
  min-height:390px;
  border-radius:var(--radius);
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  color:var(--lake-dark);
  font-weight:700;
  border:1px solid rgba(15,111,143,.22);
}

.cards{display:grid;gap:24px;margin-top:34px}
.cards.three{grid-template-columns:repeat(3,1fr)}
.cards.two{grid-template-columns:repeat(2,1fr)}
.cards article{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:26px;
  box-shadow:0 10px 28px rgba(32,48,56,.06);
}
.check-list{padding-left:0;list-style:none}
.check-list li{margin:10px 0;padding-left:28px;position:relative}
.check-list li::before{content:"✓";position:absolute;left:0;color:var(--lake);font-weight:700}

.experience{background:var(--sand)}
.carousel-placeholder{
  min-height:360px;
  border-radius:var(--radius);
  margin:34px 0 24px;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  border:1px solid rgba(15,111,143,.22);
}
.carousel-placeholder div{max-width:520px}
.carousel-placeholder strong{display:block;color:var(--lake-dark);font-size:1.25rem;margin-bottom:8px}
.carousel-placeholder span{color:var(--muted)}

.timeline{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
}
.timeline article{
  background:#fff;
  border-radius:var(--radius);
  padding:22px;
  border:1px solid rgba(0,0,0,.08);
}
.timeline strong{display:block;color:var(--lake-dark);margin-bottom:6px}
.timeline span{color:var(--muted)}
.card-image{
  height:190px;
  border-radius:12px;
  margin:-8px -8px 22px;
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--lake-dark);
  font-weight:700;
}
.stay-cards a{font-weight:700;color:var(--lake-dark)}
.direct-card{
  margin-top:28px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:26px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:24px;
  box-shadow:0 10px 28px rgba(32,48,56,.06);
}
.direct-card h3{margin-bottom:4px}
.direct-card p{margin:0}
.quote-card p{font-size:1.25rem;color:var(--ink)}
.faq details{
  background:#fff;
  border:1px solid var(--line);
  border-radius:12px;
  padding:18px 20px;
  margin:14px 0;
}
.faq summary{cursor:pointer;font-weight:700;font-size:1.05rem}
.final-cta{
  background:linear-gradient(135deg,var(--lake-dark),var(--lake));
  color:#fff;
  text-align:center;
}
.final-cta p{color:rgba(255,255,255,.88)}
.final-cta h2{color:#fff}

.sticky-cta{
  position:fixed;
  right:18px;
  bottom:18px;
  z-index:25;
  background:var(--lake);
  color:#fff;
  padding:13px 18px;
  border-radius:999px;
  text-decoration:none;
  font-weight:700;
  box-shadow:var(--shadow);
}
.site-footer{
  background:#102f3b;
  color:#fff;
  padding:36px 0;
}
.site-footer p{color:rgba(255,255,255,.75)}
.footer-grid{display:flex;justify-content:space-between;gap:20px}
.footer-grid a{display:inline-block;margin-left:18px;color:#fff;text-decoration:none}

@media (max-width: 920px){
  nav{display:none}
  .split-grid,.cards.three,.cards.two,.timeline{grid-template-columns:1fr}
  .quick-grid{grid-template-columns:repeat(2,1fr)}
  .hero-copy{padding:30px}
  .section{padding:64px 0}
  .direct-card{display:block}
  .direct-card .button{margin-top:18px}
  .footer-grid{display:block}
  .footer-grid a{margin:12px 14px 0 0}
}

@media (max-width: 560px){
  .container{width:min(100% - 28px,1120px)}
  .quick-grid{grid-template-columns:1fr}
  .hero{min-height:82vh}
  h1{font-size:2.55rem}
  .button{width:100%}
  .sticky-cta{left:14px;right:14px;text-align:center}
}
