:root{
  /* Cycladic palette: whitewash + Aegean/Santorini blues */
  --white:#ffffff; --foam:#eef4f9; --ink:#16323f; --muted:#5d7787;
  --aegean:#1c72ab; --deep:#0c4a73; --line:#d4e5f0; --night:#0c2e44;
  --serif:"Marcellus",Georgia,serif; --sans:"Inter",system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--sans);color:var(--ink);background:var(--white);line-height:1.65;font-weight:300}
h1,h2,h3{font-family:var(--serif);font-weight:400;line-height:1.12;letter-spacing:.01em}
img{max-width:100%}

/* NAV — transparent over the hero, solid white once into the content */
.nav{position:fixed;top:0;left:0;right:0;z-index:30;display:flex;flex-wrap:nowrap;
  justify-content:space-between;align-items:center;gap:1rem;padding:1rem 1.5rem;
  color:#fff;background:linear-gradient(to bottom,rgba(8,30,46,.34),rgba(8,30,46,0));
  transition:background .4s,color .4s,box-shadow .4s}
.nav__brand{font-family:var(--serif);font-size:1.4rem;letter-spacing:.06em;color:inherit;
  text-decoration:none;white-space:nowrap;text-shadow:0 1px 10px rgba(0,0,0,.35)}
.nav__links{display:flex;flex-wrap:nowrap;gap:1.3rem}
.nav__links a{color:inherit;text-decoration:none;font-size:.8rem;letter-spacing:.14em;
  text-transform:uppercase;white-space:nowrap;text-shadow:0 1px 10px rgba(0,0,0,.3)}
.nav__links a:hover{opacity:.7}
.nav.nav--solid{background:rgba(255,255,255,.92);color:var(--deep);
  box-shadow:0 1px 0 var(--line);backdrop-filter:saturate(1.2) blur(6px)}
.nav.nav--solid .nav__brand,.nav.nav--solid .nav__links a{text-shadow:none}
@media(max-width:560px){
  .nav{padding:.7rem 1rem;gap:.6rem}
  .nav__brand{font-size:1.05rem;letter-spacing:.04em}
  .nav__links{gap:.7rem}
  .nav__links a{font-size:.6rem;letter-spacing:.08em}
}

/* HERO */
.hero{position:relative;height:600vh}
.hero__sticky{position:sticky;top:0;height:100vh;overflow:hidden;background:var(--night)}
.hero__canvas{position:absolute;inset:0;width:100%;height:100%;display:block}
.hero__fallback{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero__overlay{position:absolute;top:36%;left:0;right:0;text-align:center;color:#fff;
  text-shadow:0 2px 26px rgba(0,0,0,.5);transition:opacity .5s}
.hero__title{font-size:clamp(2.6rem,8.5vw,6.2rem);letter-spacing:.06em}
.hero__subtitle{font-size:clamp(.85rem,2.4vw,1.15rem);letter-spacing:.3em;text-transform:uppercase;
  margin-top:.7rem;font-family:var(--sans);font-weight:300}
.hero__caption{position:absolute;bottom:12%;left:0;right:0;text-align:center;color:#fff;
  font-family:var(--serif);font-size:clamp(1.5rem,4vw,2.6rem);letter-spacing:.04em;opacity:0;
  transition:opacity .4s;text-shadow:0 2px 20px rgba(0,0,0,.55)}
.hero__caption.is-visible{opacity:1}
.hero__scrollcue{position:absolute;bottom:4%;left:0;right:0;text-align:center;color:#fff;
  font-size:.72rem;letter-spacing:.24em;text-transform:uppercase;opacity:.85;animation:bob 2s infinite}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(6px)}}
.hero__preloader{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:center;
  align-items:center;background:var(--night);color:#fff;z-index:5;transition:opacity .6s}
.hero__preloader.is-done{opacity:0;pointer-events:none}
.hero__preloader-bar{width:min(60vw,260px);height:2px;background:rgba(255,255,255,.25);overflow:hidden}
.hero__preloader-bar span{display:block;height:100%;width:0;background:#fff;transition:width .2s}
.hero__preloader-text{margin-top:1rem;font-size:.78rem;letter-spacing:.18em;text-transform:uppercase}

/* SECTIONS */
.section{max-width:1040px;margin:0 auto;padding:6.5rem 1.5rem}
.section h2{font-size:clamp(1.9rem,5vw,3rem);color:var(--deep);margin-bottom:1.25rem}
.section p{max-width:60ch;color:var(--muted);font-size:1.05rem;margin-bottom:1rem}
#about{background:var(--foam)}
#location{background:var(--foam)}
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.5rem;margin-top:2rem}
.card{background:var(--white);border:1px solid var(--line);border-radius:12px;overflow:hidden;
  box-shadow:0 6px 22px rgba(12,74,115,.06)}
.card img{width:100%;height:175px;object-fit:cover;display:block}
.card h3{color:var(--deep);font-size:1.35rem;padding:1rem 1rem .25rem}
.card p{padding:0 1rem 1.25rem;font-size:.95rem;margin:0}
.amenities{list-style:none;margin:2.25rem 0 0;display:flex;flex-wrap:wrap;gap:.6rem 1.6rem}
.amenities li{color:var(--ink);font-size:.98rem;display:flex;align-items:center}
.amenities li::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--aegean);
  margin-right:.6rem;flex:none}
.btn{display:inline-block;background:var(--aegean);color:#fff;text-decoration:none;padding:.75rem 1.5rem;
  border-radius:999px;letter-spacing:.06em;font-size:.9rem;border:none;cursor:pointer;transition:background .25s}
.btn:hover{background:var(--deep)}
.contact{list-style:none;margin:1rem 0 2rem;font-size:1.1rem;line-height:1.9}
.contact a{color:var(--aegean);text-decoration:none}
.contact a:hover{text-decoration:underline}
.enquiry{display:grid;gap:.8rem;max-width:480px}
.enquiry input,.enquiry textarea{padding:.75rem .9rem;border:1px solid var(--line);border-radius:8px;
  font:inherit;color:var(--ink);background:var(--white)}
.enquiry input:focus,.enquiry textarea:focus{outline:none;border-color:var(--aegean)}
.footer{background:var(--deep);color:#cfe3f0;text-align:center;padding:2.5rem 1.5rem;font-size:.9rem}

.reveal{opacity:0;transform:translateY(24px);transition:opacity .8s,transform .8s}
.reveal.is-in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}html{scroll-behavior:auto}}
