/* ================================================================
   VALUNA — Sea View Apartment
   Two fonts: Cormorant Garamond · Inter
   ================================================================ */

:root {
  --ink:     #091824;
  --navy:    #0e1e32;
  --deep:    #162a44;
  --teal:    #1aabb8;
  --teal-hi: #30d0df;
  --teal-lo: #128893;
  --gold:    #c9a96e;
  --cream:   #faf8f3;
  --sand:    #ede8dd;
  --warm:    #f5f1ea;
  --white:   #ffffff;
  --text:    #253142;
  --muted:   #7b8a9a;
  --border:  #d8d1c4;

  --serif: 'Cormorant Garamond', Georgia, serif;
  --sans:  'Inter', system-ui, sans-serif;

  --nav-h: 90px;
  --ease:  cubic-bezier(.22,.1,.36,1);
  --ease-o: cubic-bezier(0,.55,.45,1);
}

/* ── Reset ─────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font:400 1rem/1.7 var(--sans);color:var(--text);
  background:var(--cream);
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{cursor:pointer;font:inherit;border:none;background:none}
ul{list-style:none}
::selection{background:var(--teal);color:#fff}

/* ── Utilities ─────────────────────────────────────────── */
.container{max-width:1100px;margin:0 auto;padding:0 40px}
.tc{text-align:center}

/* ── Decorative section rule ───────────────────────────── */
.sec-rule{
  width:40px;height:1px;
  background:var(--teal);
  margin:0 auto 18px;
  opacity:.6;
}
.sec-rule--light{
  width:40px;height:1px;
  background:rgba(255,255,255,.25);
  margin:0 0 18px;
  opacity:1;
}
.sec-head .sec-rule{margin-bottom:18px}

/* ── Typography ────────────────────────────────────────── */
.eyebrow{
  font:600 .58rem/1 var(--sans);
  letter-spacing:.28em;text-transform:uppercase;
  color:var(--teal);margin-bottom:12px;
}
.eyebrow-light{
  font:600 .58rem/1 var(--sans);
  letter-spacing:.28em;text-transform:uppercase;
  color:rgba(255,255,255,.35);margin-bottom:12px;
}
h2{
  font:500 italic clamp(1.7rem,3vw,2.5rem)/1.2 var(--serif);
  color:var(--ink);margin-bottom:18px;
}
h3{font-family:var(--serif)}
.body-text{font:300 .9rem/1.85 var(--sans);color:var(--muted)}
.sec-head{
  text-align:center;max-width:520px;
  margin:0 auto 56px;padding:0 40px;
}

/* ── Buttons ───────────────────────────────────────────── */
.fill-btn{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--teal);color:#fff;
  font:600 .72rem/1 var(--sans);
  letter-spacing:.1em;text-transform:uppercase;
  padding:14px 34px;border-radius:48px;
  transition:all .35s var(--ease);
}
.fill-btn:hover{
  background:var(--teal-hi);transform:translateY(-2px);
  box-shadow:0 10px 30px rgba(26,171,184,.28);
}
.ghost-btn{
  display:inline-flex;align-items:center;
  font:500 .78rem/1 var(--sans);letter-spacing:.06em;
  color:rgba(255,255,255,.55);
  border-bottom:1px solid rgba(255,255,255,.2);
  padding-bottom:3px;transition:color .3s,border-color .3s;
}
.ghost-btn:hover{color:#fff;border-color:#fff}

/* ── Reveal ────────────────────────────────────────────── */
.reveal,.reveal-r{
  opacity:0;transition:opacity 1s var(--ease),transform 1s var(--ease);
}
.reveal{transform:translateY(28px)}
.reveal-r{transform:translateX(28px)}
.reveal.on,.reveal-r.on{opacity:1;transform:none}

.reveal-s>*{
  opacity:0;transform:translateY(18px);
  transition:opacity .75s var(--ease),transform .75s var(--ease);
}
.reveal-s.on>*{opacity:1;transform:none}
.reveal-s.on>*:nth-child(1){transition-delay:.04s}
.reveal-s.on>*:nth-child(2){transition-delay:.1s}
.reveal-s.on>*:nth-child(3){transition-delay:.16s}
.reveal-s.on>*:nth-child(4){transition-delay:.22s}
.reveal-s.on>*:nth-child(5){transition-delay:.28s}
.reveal-s.on>*:nth-child(6){transition-delay:.34s}
.reveal-s.on>*:nth-child(7){transition-delay:.4s}
.reveal-s.on>*:nth-child(8){transition-delay:.46s}
.reveal-s.on>*:nth-child(9){transition-delay:.52s}


/* ================================================================
   NAV
   ================================================================ */
#nav{
  position:fixed;inset:0 0 auto;z-index:900;
  height:var(--nav-h);
  transition:background .45s var(--ease),box-shadow .45s var(--ease);
}
#nav.scrolled{
  background:rgba(9,24,36,.98);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  box-shadow:0 1px 0 rgba(255,255,255,.04);
}
.nav-shell{
  position:relative;display:flex;align-items:center;
  justify-content:space-between;
  height:100%;max-width:1320px;margin:0 auto;padding:0 36px;
}
.nav-logo img{
  height:84px;width:auto;object-fit:contain;
  filter:drop-shadow(0 2px 10px rgba(0,0,0,.3));
}
.nav-links{
  position:absolute;left:50%;transform:translateX(-50%);
  display:flex;align-items:center;gap:44px;
}
.nl{
  font:600 .68rem/1 var(--sans);
  letter-spacing:.2em;text-transform:uppercase;
  color:rgba(255,255,255,.5);position:relative;
  padding:6px 0;transition:color .3s;
}
.nl::after{
  content:'';position:absolute;
  bottom:-3px;left:0;right:0;height:1px;
  background:var(--teal-hi);
  transform:scaleX(0);transform-origin:left;
  transition:transform .35s var(--ease);
}
.nl:hover{color:rgba(255,255,255,.85)}
.nl:hover::after{transform:scaleX(1)}
.nl.active{color:#fff}
.nl.active::after{transform:scaleX(1)}
.nl-book-mb{display:none}

.nav-end{display:flex;align-items:center;gap:16px}
.lang-btn{
  display:flex;align-items:center;gap:5px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);
  border-radius:20px;padding:7px 16px;
  font:600 .62rem/1 var(--sans);
  letter-spacing:.1em;color:rgba(255,255,255,.42);
  transition:background .3s;
}
.lang-btn:hover{background:rgba(255,255,255,.12)}
.lo{transition:color .3s}.lo.active{color:#fff}
.ls{color:rgba(255,255,255,.15);font-weight:400}

.nav-book{
  font:600 .64rem/1 var(--sans);
  letter-spacing:.12em;text-transform:uppercase;
  background:var(--teal);color:#fff;
  padding:11px 24px;border-radius:48px;
  transition:background .3s,transform .25s;
}
.nav-book:hover{background:var(--teal-hi);transform:translateY(-1px)}

.hamburger{display:none;flex-direction:column;gap:5px;padding:5px;z-index:2}
.hamburger span{
  display:block;width:20px;height:1.5px;
  background:rgba(255,255,255,.75);border-radius:2px;
  transition:all .3s var(--ease);
}
.hamburger.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}


/* ================================================================
   HERO
   ================================================================ */
#hero{
  position:relative;
  height:100svh;min-height:640px;
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  overflow:hidden;color:#fff;
}
.hero-bg{
  position:absolute;inset:-6%;
  background-size:cover;background-position:center 35%;
  will-change:transform;
  animation:kenBurns 20s ease alternate infinite;
}
@keyframes kenBurns{
  0%{transform:scale(1) translate(0,0)}
  100%{transform:scale(1.05) translate(-1%,-1%)}
}
.hero-veil{
  position:absolute;inset:0;
  background:
    radial-gradient(ellipse 80% 70% at 50% 48%, rgba(9,24,36,.45) 0%, rgba(9,24,36,.8) 100%),
    linear-gradient(to top, rgba(9,24,36,.85) 0%, transparent 35%),
    linear-gradient(to bottom, rgba(9,24,36,.6) 0%, transparent 25%);
}
.hero-grain{
  position:absolute;inset:0;z-index:1;
  opacity:.03;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:180px;
}

@keyframes heroIn{
  from{opacity:0;transform:translateY(18px)}
  to{opacity:1;transform:none}
}
@keyframes heroFade{from{opacity:0}to{opacity:1}}

.hero-body{
  position:relative;z-index:2;
  display:flex;flex-direction:column;
  align-items:center;text-align:center;
  padding:0 40px;
  margin-top:-20px;
}

.hero-loc{
  font:500 .54rem/1 var(--sans);
  letter-spacing:.4em;text-transform:uppercase;
  color:rgba(255,255,255,.35);
  margin-bottom:20px;
  animation:heroFade 1s .1s var(--ease-o) both;
}

.hero-brand{
  font:700 clamp(3.5rem,8vw,7rem)/1 var(--serif);
  letter-spacing:.15em;
  color:#fff;
  text-shadow:0 4px 60px rgba(0,0,0,.25);
  margin-bottom:16px;
  animation:heroIn 1s .2s var(--ease-o) both;
}

.hero-rule{
  width:48px;height:1px;
  background:var(--teal-hi);
  margin:0 auto 18px;
  opacity:.5;
  animation:heroFade 1s .35s var(--ease-o) both;
}

.hero-tagline{
  font-family:var(--serif);
  line-height:1.05;
  margin-bottom:20px;
  display:flex;flex-direction:column;align-items:center;gap:2px;
  animation:heroIn 1s .4s var(--ease-o) both;
}
.h1-light{
  font-size:clamp(1.6rem,2.8vw,2.4rem);
  font-weight:300;font-style:italic;
  color:rgba(255,255,255,.6);
}
.h1-strong{
  font-size:clamp(2rem,3.5vw,3rem);
  font-weight:600;
  color:rgba(255,255,255,.85);
}

.hero-sub{
  font:300 .82rem/1.6 var(--sans);
  letter-spacing:.04em;
  color:rgba(255,255,255,.55);
  max-width:min(720px,92vw);
  margin-bottom:32px;
  animation:heroFade 1s .55s var(--ease-o) both;
}
.hero-sub .nobrk{white-space:nowrap}
.hero-sub .sub-brk{display:none}
/* Force break on narrow viewports (too narrow for both halves inline) */
@media(max-width:680px){
  .hero-sub .sub-brk{display:inline}
}

.hero-btns{
  display:flex;gap:12px;flex-wrap:wrap;justify-content:center;
  animation:heroIn 1s .65s var(--ease-o) both;
}
.hbtn{
  font:600 .62rem/1 var(--sans);
  letter-spacing:.14em;text-transform:uppercase;
  padding:14px 30px;border-radius:48px;
  transition:all .35s var(--ease);white-space:nowrap;
}
.hbtn--fill{
  background:var(--teal);color:#fff;
  box-shadow:0 4px 24px rgba(26,171,184,.3);
}
.hbtn--fill:hover{
  background:var(--teal-hi);transform:translateY(-2px);
  box-shadow:0 10px 36px rgba(26,171,184,.4);
}
.hbtn--ghost{
  color:rgba(255,255,255,.5);
  border:1px solid rgba(255,255,255,.16);
}
.hbtn--ghost:hover{
  color:#fff;border-color:rgba(255,255,255,.5);
  background:rgba(255,255,255,.04);
}

/* Bottom area */
.hero-bottom{
  position:absolute;z-index:2;
  bottom:0;left:0;right:0;
  display:flex;align-items:center;justify-content:center;
  flex-direction:column;gap:16px;
  padding-bottom:24px;
  animation:heroFade 1s .8s var(--ease-o) both;
}
.hero-stats{
  display:flex;align-items:center;gap:24px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.07);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  border-radius:48px;padding:10px 32px;
}
.hst{display:flex;flex-direction:column;align-items:center;gap:3px}
.hst-v{font:700 italic 1.15rem/1 var(--serif);color:#fff}
.hst-l{
  font:500 .46rem/1 var(--sans);
  letter-spacing:.16em;text-transform:uppercase;
  color:rgba(255,255,255,.28);
}
.hst-sep{width:1px;height:20px;background:rgba(255,255,255,.08)}

.hero-scroll{
  color:rgba(255,255,255,.2);
  transition:color .3s;
  animation:bounce 3s ease infinite;
}
.hero-scroll:hover{color:rgba(255,255,255,.5)}
@keyframes bounce{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(4px)}
}


/* ================================================================
   GALLERY
   ================================================================ */
#gallery{
  background:var(--warm);padding:0;
}

.mosaic{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  grid-auto-rows:280px;
  gap:3px;
}
.mosaic--int{grid-template-rows:repeat(5,280px)}
.mosaic--ext{grid-template-rows:repeat(3,280px)}
.mi--feat{grid-column:1/3;grid-row:1/3}

.mi{
  position:relative;overflow:hidden;
  cursor:pointer;background:var(--sand);
}
.mi img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .7s var(--ease);
}
.mi-veil{
  position:absolute;inset:0;
  background:rgba(9,24,36,.35);
  display:flex;align-items:center;justify-content:center;
  opacity:0;transition:opacity .4s;
}
.mi-veil span{
  font:200 2rem/1 var(--serif);color:#fff;
  transform:scale(.65);transition:transform .4s var(--ease);
}
.mi:hover img{transform:scale(1.05)}
.mi:hover .mi-veil{opacity:1}
.mi:hover .mi-veil span{transform:scale(1)}


/* ================================================================
   THE SPACE
   ================================================================ */
#space{background:var(--ink);overflow:hidden}
.space-grid{
  display:grid;grid-template-columns:1fr 1fr;
  min-height:auto;
}
.space-text{
  padding:100px 68px;
  display:flex;flex-direction:column;justify-content:center;
  color:#fff;
}
.space-text h2{
  color:#fff;font-size:clamp(1.6rem,2.6vw,2.2rem);margin-bottom:18px;
}
.space-text .body-text{color:rgba(255,255,255,.48);margin-bottom:32px}

/* Feature list */
.space-features{
  display:flex;flex-direction:column;gap:18px;
  margin-bottom:36px;
  padding-bottom:32px;
  border-bottom:1px solid rgba(255,255,255,.07);
}
.sf{
  display:flex;align-items:flex-start;gap:14px;
}
.sf svg{
  flex-shrink:0;margin-top:2px;
  color:var(--teal);opacity:.7;
}
.sf div{display:flex;flex-direction:column;gap:3px}
.sf strong{
  font:600 .82rem/1.2 var(--sans);color:rgba(255,255,255,.85);
}
.sf span{
  font:300 .76rem/1.5 var(--sans);color:rgba(255,255,255,.38);
}

.space-nums{
  display:grid;grid-template-columns:repeat(4,1fr);
  border-bottom:1px solid rgba(255,255,255,.07);
  padding:16px 0;margin-bottom:28px;
}
.sn{
  display:flex;flex-direction:column;align-items:center;gap:5px;
  border-right:1px solid rgba(255,255,255,.07);padding:6px 0;
}
.sn:last-child{border-right:none}
.sn strong{font:700 italic 1.8rem/1 var(--serif);color:var(--teal-hi)}
.sn span{
  font:500 .52rem/1 var(--sans);
  letter-spacing:.14em;text-transform:uppercase;
  color:rgba(255,255,255,.28);
}

/* CTA button */
.space-cta{
  display:inline-flex;align-items:center;
  font:600 .68rem/1 var(--sans);
  letter-spacing:.12em;text-transform:uppercase;
  color:var(--teal-hi);
  padding:12px 0;
  border-bottom:1px solid rgba(48,208,223,.3);
  transition:color .3s,border-color .3s;
  align-self:flex-start;
}
.space-cta:hover{color:#fff;border-color:#fff}

/* Photo grid: 1 big + 2 small */
.space-photos{
  display:grid;
  grid-template-rows:1fr auto;
  gap:3px;
}
.sp-main{overflow:hidden}
.sp-main img{
  width:100%;height:100%;object-fit:cover;
  min-height:380px;
  transition:transform .9s var(--ease);
}
.sp-main:hover img{transform:scale(1.03)}
.sp-duo{
  display:grid;grid-template-columns:1fr 1fr;gap:3px;
}
.sp-small{overflow:hidden;height:200px}
.sp-small img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .7s var(--ease);
}
.sp-small:hover img{transform:scale(1.05)}


/* ================================================================
   HIGHLIGHTS
   ================================================================ */
#highlights{
  background:var(--warm);padding:60px 0 0;overflow:hidden;
}
#highlights .sec-head{margin-bottom:48px}

.hl-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:3px;
}
.hl{position:relative;aspect-ratio:3/4;overflow:hidden}
.hl img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .9s var(--ease);filter:brightness(.78);
}
.hl:hover img{transform:scale(1.05);filter:brightness(.6)}

.hl-over{
  position:absolute;inset:0;
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:40px 32px;
  background:linear-gradient(to top,
    rgba(9,24,36,.85) 0%,rgba(9,24,36,.06) 55%,transparent 100%);
  color:#fff;
}
/* Decorative number */
.hl-num{
  font:300 italic 4.5rem/1 var(--serif);
  color:rgba(255,255,255,.06);
  position:absolute;top:28px;left:28px;
}
.hl-over h3{
  font:700 italic 1.6rem/1.12 var(--serif);margin-bottom:7px;
}
.hl-desc{
  font:300 .78rem/1.55 var(--sans);color:rgba(255,255,255,.55);
}


/* ================================================================
   AMENITIES
   ================================================================ */
#amenities{background:var(--cream);padding:140px 0}
#amenities .sec-head{margin-bottom:52px}

.am-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:1px;background:var(--border);
  border:1px solid var(--border);border-radius:14px;overflow:hidden;
}
.am{
  background:var(--white);
  display:flex;align-items:flex-start;gap:16px;
  padding:26px 22px;transition:background .35s;
}
.am:hover{background:var(--warm)}

.am-ico{
  flex-shrink:0;width:40px;height:40px;
  background:var(--sand);border-radius:10px;
  display:flex;align-items:center;justify-content:center;
  color:var(--teal-lo);transition:background .35s,color .35s;
}
.am:hover .am-ico{background:var(--teal);color:#fff}
.am>div{display:flex;flex-direction:column;gap:3px}
.am strong{font:600 .82rem/1.2 var(--sans);color:var(--ink)}
.am span{font:400 .72rem/1.4 var(--sans);color:var(--muted)}


/* ================================================================
   LOCATION
   ================================================================ */
#location{background:var(--sand);padding:140px 0 0}
.loc-grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:60px;align-items:center;padding-bottom:80px;
}
.loc-text h2{font-size:clamp(1.6rem,2.6vw,2.2rem)}
.loc-text .body-text{margin-bottom:26px}

.loc-list{display:flex;flex-direction:column;gap:10px}
.loc-list li{
  display:flex;align-items:center;gap:10px;
  font:500 .82rem/1 var(--sans);color:var(--text);
}
.loc-dot{
  width:5px;height:5px;border-radius:50%;
  background:var(--teal);flex-shrink:0;
}
.loc-map{
  border-radius:16px;overflow:hidden;
  box-shadow:0 16px 56px rgba(9,24,36,.1);
}

.loc-quote{position:relative;height:320px;overflow:hidden}
.loc-quote img{
  width:100%;height:100%;object-fit:cover;
  object-position:center 55%;filter:brightness(.45);
}
.loc-quote-veil{
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
  padding:32px;
}
.loc-quote-veil p{
  font:400 italic clamp(1.3rem,2.6vw,2rem)/1.42 var(--serif);
  color:rgba(255,255,255,.82);text-align:center;
  max-width:600px;text-shadow:0 2px 20px rgba(0,0,0,.3);
}


/* ================================================================
   RATES
   ================================================================ */
#rates{background:var(--ink);padding:120px 0;color:#fff}
#rates h2{color:#fff;font-size:clamp(1.8rem,3vw,2.6rem)}

.rates-inner{
  display:grid;grid-template-columns:1fr 1.3fr;
  gap:72px;align-items:start;
  max-width:1100px;margin:0 auto;padding:0 40px;
}

/* Left text */
.rates-text{}
.rates-desc{
  font:300 .88rem/1.8 var(--sans);
  color:rgba(255,255,255,.45);margin-bottom:28px;
}
.rates-includes{
  display:flex;flex-direction:column;gap:10px;
  margin-bottom:28px;
  padding-bottom:24px;
  border-bottom:1px solid rgba(255,255,255,.06);
}
.rates-includes li{
  display:flex;align-items:center;gap:9px;
  font:400 .8rem/1 var(--sans);
  color:rgba(255,255,255,.55);
}
.rates-includes li svg{color:var(--teal-hi);flex-shrink:0}
.rates-note{
  font:400 .7rem/1.6 var(--sans);
  color:rgba(255,255,255,.2);
}

/* Right cards */
.rates-cards{
  display:flex;flex-direction:column;gap:14px;
}
.rc{
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.06);
  border-radius:14px;
  padding:28px 32px;
  display:grid;grid-template-columns:1fr auto auto;
  align-items:center;gap:24px;
  position:relative;
  transition:background .35s,border-color .35s,transform .4s var(--ease);
}
.rc:hover{
  background:rgba(255,255,255,.05);
  border-color:rgba(255,255,255,.1);
  transform:translateX(4px);
}
.rc--feat{
  background:rgba(26,171,184,.06);
  border-color:rgba(26,171,184,.35);
  padding-top:36px;
}
.rc--feat:hover{
  background:rgba(26,171,184,.1);
  border-color:rgba(26,171,184,.5);
}

.rc-badge{
  position:absolute;top:0;left:32px;
  background:var(--teal);color:#fff;
  font:700 .48rem/1 var(--sans);
  letter-spacing:.14em;text-transform:uppercase;
  padding:4px 14px;
  border-radius:0 0 8px 8px;
  white-space:nowrap;
}

.rc-head{}
.rc-name{
  font:600 .56rem/1 var(--sans);
  letter-spacing:.18em;text-transform:uppercase;
  color:var(--teal-hi);margin-bottom:4px;
}
.rc-period{
  font:400 .76rem/1 var(--sans);
  color:rgba(255,255,255,.3);
}

.rc-body{text-align:right}
.rc-price{
  font:400 .82rem/1 var(--sans);
  color:rgba(255,255,255,.4);margin-bottom:2px;
}
.rc-price strong{
  font:700 italic 2rem/1 var(--serif);color:#fff;
}
.rc-unit{
  font:400 .52rem/1 var(--sans);
  letter-spacing:.1em;text-transform:uppercase;
  color:rgba(255,255,255,.2);
}

.rc-btn{
  font:600 .56rem/1 var(--sans);
  letter-spacing:.12em;text-transform:uppercase;
  color:rgba(255,255,255,.45);
  border:1px solid rgba(255,255,255,.12);
  padding:10px 20px;border-radius:48px;
  transition:all .3s var(--ease);
  white-space:nowrap;
}
.rc-btn:hover{
  color:#fff;border-color:rgba(255,255,255,.4);
  background:rgba(255,255,255,.04);
}
.rc-btn--fill{
  background:var(--teal);color:#fff;border-color:var(--teal);
}
.rc-btn--fill:hover{
  background:var(--teal-hi);border-color:var(--teal-hi);
  transform:translateY(-1px);
  box-shadow:0 6px 20px rgba(26,171,184,.25);
}


/* ================================================================
   DISCOVER JADRANOVO
   ================================================================ */
#discover{
  background:var(--white);
  padding:0 0 140px;
}

/* Unified Discover banner — one image, everything on top */
.disc-banner{
  position:relative;
  width:100%;
  overflow:hidden;
  margin-bottom:96px;
}
.disc-banner-bg{
  position:absolute;inset:0;
  background-size:cover;background-position:center 55%;
}
.disc-banner-veil{
  position:absolute;inset:0;
  background:
    linear-gradient(to bottom,
      rgba(9,24,36,.6) 0%,
      rgba(9,24,36,.72) 40%,
      rgba(9,24,36,.85) 100%);
}
.disc-banner-content{
  position:relative;z-index:1;
  max-width:1120px;margin:0 auto;
  padding:120px 40px 100px;
}

/* Top: eyebrow + heading + lead + quote */
.disc-banner-head{
  text-align:center;
  max-width:720px;margin:0 auto 80px;
  color:#fff;
}
.disc-banner-head .sec-rule--light{margin:0 auto 18px}
.disc-banner-head h2{
  color:#fff;
  font:500 italic clamp(2rem,4vw,3.2rem)/1.15 var(--serif);
  margin-bottom:26px;
}
.disc-banner-lead{
  font:300 .92rem/1.85 var(--sans);
  color:rgba(255,255,255,.68);
  margin-bottom:24px;
  max-width:620px;margin-left:auto;margin-right:auto;
}
.disc-banner-quote{
  font:400 italic clamp(.95rem,1.5vw,1.15rem)/1.5 var(--serif);
  color:var(--teal-hi);
  opacity:.75;
  margin-top:22px;
}

/* Beaches subheader */
.disc-beaches-subhead{
  text-align:center;
  margin-bottom:32px;
  padding-top:28px;
  border-top:1px solid rgba(255,255,255,.08);
}
.disc-beaches-wrap{
  max-width:100%;
}

/* Block container */
.disc-block{
  margin-bottom:56px;
}
.disc-block-head{
  display:flex;align-items:center;gap:14px;
  margin-bottom:24px;
  padding-bottom:16px;
  border-bottom:1px solid var(--border);
}
.disc-icon{
  width:40px;height:40px;
  display:flex;align-items:center;justify-content:center;
  background:var(--sand);border-radius:10px;
  color:var(--teal-lo);flex-shrink:0;
}
.disc-block-head h3{
  font:600 italic 1.4rem/1 var(--serif);
  color:var(--ink);
}

/* Beaches grid on dark banner */
.disc-beaches{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:14px;
}
.disc-beach{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  border-radius:14px;
  padding:26px 24px;
  transition:background .35s,border-color .35s,transform .35s var(--ease);
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
}
.disc-beach:hover{
  background:rgba(255,255,255,.07);
  border-color:rgba(26,171,184,.4);
  transform:translateY(-3px);
}
.disc-beach strong{
  font:700 italic 1.25rem/1 var(--serif);
  color:var(--teal-hi);
  display:block;margin-bottom:10px;
}
.disc-beach p{
  font:300 .82rem/1.65 var(--sans);
  color:rgba(255,255,255,.62);
}

/* Two-column: Trails + Events */
.disc-duo{
  display:grid;grid-template-columns:1fr 1fr;
  gap:40px;
}

/* Trails */
.disc-trail{
  margin-bottom:20px;
  padding-bottom:20px;
  border-bottom:1px solid var(--border);
}
.disc-trail:last-child{border-bottom:none;padding-bottom:0;margin-bottom:0}
.disc-trail strong{
  font:600 .88rem/1.2 var(--sans);color:var(--ink);
  display:block;margin-bottom:5px;
}
.disc-trail p{
  font:300 .8rem/1.65 var(--sans);color:var(--muted);
}

/* Events */
.disc-event{
  margin-bottom:20px;
  padding-bottom:20px;
  border-bottom:1px solid var(--border);
}
.disc-event:last-child{border-bottom:none;padding-bottom:0;margin-bottom:0}
.disc-event strong{
  font:600 .84rem/1.2 var(--sans);color:var(--ink);
  display:block;margin-bottom:5px;
}
.disc-event p{
  font:300 .78rem/1.6 var(--sans);color:var(--muted);
}

/* Day trips */
.disc-trips{
  display:grid;grid-template-columns:repeat(2,1fr);
  gap:16px;
}
.disc-trip{
  display:flex;align-items:flex-start;gap:16px;
  background:var(--warm);border-radius:14px;
  padding:24px;
  transition:background .3s,transform .35s var(--ease);
}
.disc-trip:hover{background:var(--sand);transform:translateY(-3px)}
.disc-trip-time{
  flex-shrink:0;
  font:700 .56rem/1 var(--sans);
  letter-spacing:.08em;text-transform:uppercase;
  color:var(--teal);
  background:rgba(26,171,184,.08);
  padding:6px 10px;border-radius:6px;
  white-space:nowrap;margin-top:2px;
}
.disc-trip strong{
  font:600 .88rem/1.2 var(--sans);color:var(--ink);
  display:block;margin-bottom:4px;
}
.disc-trip p{
  font:300 .78rem/1.55 var(--sans);color:var(--muted);
}

/* Bottom highlights */
.disc-highlights{
  text-align:center;
  padding-top:56px;
  border-top:1px solid var(--border);
}
.disc-highlights h3{
  font:600 italic 1.6rem/1.2 var(--serif);
  color:var(--ink);margin-bottom:24px;
}
.disc-tags{
  display:flex;flex-wrap:wrap;justify-content:center;
  gap:8px;margin-bottom:28px;
}
.disc-tags span{
  font:500 .68rem/1 var(--sans);
  letter-spacing:.04em;
  color:var(--teal-lo);
  background:rgba(26,171,184,.06);
  border:1px solid rgba(26,171,184,.12);
  padding:8px 16px;border-radius:48px;
  transition:background .3s,color .3s;
}
.disc-tags span:hover{
  background:var(--teal);color:#fff;
}
.disc-closing{
  font:300 .88rem/1.75 var(--sans);
  color:var(--muted);max-width:560px;margin:0 auto;
}

/* Responsive */
@media(max-width:1024px){
  .disc-beaches{grid-template-columns:repeat(2,1fr)}
  .disc-trips{grid-template-columns:1fr}
  .disc-duo{grid-template-columns:1fr;gap:48px}
}
@media(max-width:768px){
  #discover{padding:0 0 88px}
  .disc-banner{margin-bottom:72px}
  .disc-banner-content{padding:80px 24px 72px}
  .disc-banner-head{margin-bottom:56px}
  .disc-beaches{grid-template-columns:1fr;gap:12px}
  .disc-trips{grid-template-columns:1fr}
}


/* ================================================================
   BOOKING
   ================================================================ */
/* Book: hero banner */
#book{background:var(--cream)}
.book-hero{
  position:relative;height:340px;overflow:hidden;
}
.book-hero img{
  width:100%;height:100%;object-fit:cover;
  object-position:center 60%;
}
.book-hero-veil{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(9,24,36,.85),rgba(9,24,36,.35));
}
.book-hero-text{
  position:absolute;inset:0;z-index:1;
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  text-align:center;color:#fff;padding:0 24px;
}
.book-hero-text h2{
  color:#fff;
  font:700 italic clamp(1.8rem,3.2vw,2.8rem)/1.15 var(--serif);
  margin-bottom:10px;
}
.book-hero-text p{
  font:300 .9rem/1.6 var(--sans);
  color:rgba(255,255,255,.55);max-width:440px;
}

/* Book: main area with floating card */
.book-main{
  max-width:820px;margin:0 auto;
  padding:0 40px;
  margin-top:-60px;
  position:relative;z-index:2;
  padding-bottom:100px;
}
.book-form-card{
  background:var(--white);
  border-radius:18px;
  box-shadow:0 20px 60px rgba(9,24,36,.1),0 2px 8px rgba(9,24,36,.04);
  overflow:hidden;
}

/* Benefits strip at top of card */
.bfc-top{
  background:var(--ink);padding:28px 40px;
}
.bfc-benefits{
  display:grid;grid-template-columns:repeat(3,1fr);gap:20px;
}
.bfb{
  display:flex;align-items:flex-start;gap:12px;
}
.bfb svg{
  flex-shrink:0;color:var(--teal-hi);margin-top:1px;
}
.bfb div{display:flex;flex-direction:column;gap:2px}
.bfb strong{
  font:600 .72rem/1.2 var(--sans);color:rgba(255,255,255,.85);
}
.bfb span{
  font:300 .66rem/1.4 var(--sans);color:rgba(255,255,255,.35);
}

/* Form area */
.book-form-card form{
  padding:36px 40px 28px;
  display:flex;flex-direction:column;gap:14px;
}
.form-title{
  font:600 italic 1.3rem/1 var(--serif);
  color:var(--ink);margin-bottom:4px;
}

#bform{display:flex;flex-direction:column;gap:14px}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.fg{display:flex;flex-direction:column;gap:5px}
.fg.full{grid-column:1/-1}

.fg label{
  font:600 .54rem/1 var(--sans);
  letter-spacing:.16em;text-transform:uppercase;
  color:var(--muted);
}
.fg input,.fg select,.fg textarea{
  background:var(--warm);
  border:1.5px solid var(--border);border-radius:8px;
  padding:11px 14px;
  font:400 .86rem/1 var(--sans);color:var(--text);
  transition:border-color .3s,box-shadow .3s,background .3s;
  -webkit-appearance:none;appearance:none;width:100%;
}
.fg input::placeholder,.fg textarea::placeholder{color:#bec7d2}
.fg input:focus,.fg select:focus,.fg textarea:focus{
  outline:none;border-color:var(--teal);background:#fff;
  box-shadow:0 0 0 3px rgba(26,171,184,.08);
}
.fg select{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%237b8a9a' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 12px center;
  padding-right:34px;cursor:pointer;
}
.fg textarea{resize:vertical;min-height:80px;line-height:1.6}
input[type="date"]::-webkit-calendar-picker-indicator{opacity:.35;cursor:pointer}

.fsub{
  background:var(--teal);color:#fff;border:none;
  border-radius:10px;padding:14px;
  font:600 .8rem/1 var(--sans);letter-spacing:.04em;
  cursor:pointer;margin-top:4px;
  transition:background .3s,transform .3s,box-shadow .3s;
}
.fsub:hover{
  background:var(--teal-hi);transform:translateY(-2px);
  box-shadow:0 8px 24px rgba(26,171,184,.22);
}
.fsub:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}

/* Card footer */
.bfc-foot{
  padding:20px 40px 28px;
  border-top:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;gap:12px;
}
.bfc-foot p{
  font:400 .66rem/1 var(--sans);
  color:var(--muted);letter-spacing:.06em;
}
.bfc-platforms{
  display:flex;align-items:center;gap:6px;
  font:500 .72rem/1 var(--sans);
}
.bfc-platforms a{
  color:var(--teal-lo);
  text-decoration:underline;text-decoration-color:rgba(18,136,147,.25);
  text-underline-offset:3px;transition:color .3s;
}
.bfc-platforms a:hover{color:var(--teal)}
.bfc-platforms span{color:var(--border)}


/* ================================================================
   FOOTER
   ================================================================ */
#footer{
  background:var(--ink);position:relative;overflow:hidden;
  border-top:1px solid var(--teal-lo);
}
.ft-watermark{
  position:absolute;top:-14px;left:50%;transform:translateX(-50%);
  font:900 13vw/1 var(--serif);
  color:rgba(255,255,255,.02);letter-spacing:.12em;
  pointer-events:none;user-select:none;white-space:nowrap;
}
.ft-top{
  position:relative;z-index:1;
  display:grid;grid-template-columns:1.5fr 1fr 1fr;
  gap:52px;max-width:1060px;margin:0 auto;padding:68px 40px 52px;
}
.ft-logo{
  height:100px;width:auto;object-fit:contain;
  opacity:.88;margin-bottom:16px;
  filter:drop-shadow(0 2px 10px rgba(0,0,0,.25));
}
.ft-tagline{
  font:500 .6rem/1 var(--sans);
  letter-spacing:.2em;text-transform:uppercase;
  color:var(--teal-hi);margin-bottom:12px;
}
.ft-desc{
  font:300 .82rem/1.7 var(--sans);
  color:rgba(255,255,255,.28);max-width:260px;
}
.ft-h{
  font:600 .52rem/1 var(--sans);
  letter-spacing:.22em;text-transform:uppercase;
  color:rgba(255,255,255,.2);margin-bottom:18px;
}
.ft-col ul{display:flex;flex-direction:column;gap:9px}
.ft-col ul li a{
  font:400 .82rem/1 var(--sans);
  color:rgba(255,255,255,.38);transition:color .3s;
}
.ft-col ul li a:hover{color:#fff}
.ft-book{color:var(--teal-hi)!important;font-weight:500!important}
.ft-book:hover{opacity:.8}

.ft-also{
  font:400 .66rem/1 var(--sans);
  color:rgba(255,255,255,.18);margin-top:22px;margin-bottom:7px;
}
.ft-platforms{
  display:flex;align-items:center;gap:6px;
  font:400 .76rem/1 var(--sans);color:rgba(255,255,255,.22);
}
.ft-platforms a{
  color:rgba(255,255,255,.36);
  text-decoration:underline;text-decoration-color:rgba(255,255,255,.1);
  text-underline-offset:3px;transition:color .3s;
}
.ft-platforms a:hover{color:var(--teal-hi)}

.ft-bottom{
  position:relative;z-index:1;
  border-top:1px solid rgba(255,255,255,.05);
  padding:18px 40px;text-align:center;
}
.ft-bottom p{
  font:400 .62rem/1 var(--sans);
  letter-spacing:.04em;color:rgba(255,255,255,.14);
}
.ft-legal{
  display:flex;align-items:center;justify-content:center;
  gap:8px;margin-top:10px;
}
.ft-legal a{
  font:400 .58rem/1 var(--sans);
  color:rgba(255,255,255,.2);transition:color .3s;
  letter-spacing:.02em;
}
.ft-legal a:hover{color:rgba(255,255,255,.5)}
.ft-legal span{color:rgba(255,255,255,.1);font-size:.5rem}


/* ================================================================
   COOKIE BAR
   ================================================================ */
.cookie-bar{
  position:fixed;bottom:0;left:0;right:0;z-index:1500;
  background:rgba(9,24,36,.95);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border-top:1px solid rgba(255,255,255,.06);
  padding:18px 0;
  transform:translateY(100%);
  transition:transform .5s var(--ease);
}
.cookie-bar.on{transform:translateY(0)}

.cookie-inner{
  max-width:1100px;margin:0 auto;padding:0 40px;
  display:flex;align-items:center;justify-content:space-between;
  gap:24px;
}
.cookie-text{
  font:300 .78rem/1.55 var(--sans);
  color:rgba(255,255,255,.55);flex:1;
}
.cookie-actions{
  display:flex;align-items:center;gap:10px;flex-shrink:0;
}
.cookie-link{
  font:400 .66rem/1 var(--sans);
  color:rgba(255,255,255,.3);
  text-decoration:underline;text-decoration-color:rgba(255,255,255,.1);
  text-underline-offset:3px;
  transition:color .3s;margin-right:6px;
}
.cookie-link:hover{color:rgba(255,255,255,.6)}

.cookie-btn{
  font:600 .58rem/1 var(--sans);
  letter-spacing:.1em;text-transform:uppercase;
  padding:9px 18px;border-radius:48px;
  transition:all .3s var(--ease);white-space:nowrap;cursor:pointer;
}
.cookie-btn--ghost{
  color:rgba(255,255,255,.45);
  border:1px solid rgba(255,255,255,.12);
  background:none;
}
.cookie-btn--ghost:hover{
  color:#fff;border-color:rgba(255,255,255,.35);
}
.cookie-btn--fill{
  background:var(--teal);color:#fff;border:none;
}
.cookie-btn--fill:hover{
  background:var(--teal-hi);transform:translateY(-1px);
}

@media(max-width:768px){
  .cookie-inner{flex-direction:column;gap:14px;text-align:center}
  .cookie-actions{justify-content:center}
}


/* ================================================================
   TEMPORARY: hide rates section + its nav/footer links
   ================================================================ */
#rates,
.nav-links li:has(a[href="#rates"]),
.ft-col li:has(a[href="#rates"]){
  display:none !important;
}


/* ================================================================
   LIGHTBOX
   ================================================================ */
#lb{
  position:fixed;inset:0;z-index:2000;
  background:rgba(5,10,18,.97);
  display:flex;align-items:center;justify-content:center;
  opacity:0;pointer-events:none;
  transition:opacity .4s var(--ease);
}
#lb.on{opacity:1;pointer-events:all}
.lb-wrap{max-width:92vw;max-height:90vh}
#lb-img{
  max-width:92vw;max-height:90vh;object-fit:contain;
  border-radius:4px;box-shadow:0 24px 64px rgba(0,0,0,.55);
  transition:opacity .2s;
}
.lb-x,.lb-p,.lb-n{
  position:absolute;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.08);
  border-radius:50%;width:44px;height:44px;
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-weight:200;
  backdrop-filter:blur(6px);transition:background .3s;
}
.lb-x:hover,.lb-p:hover,.lb-n:hover{background:rgba(255,255,255,.12)}
.lb-x{top:20px;right:20px;font-size:1.2rem}
.lb-p{left:20px;top:50%;transform:translateY(-50%);font-size:1.5rem}
.lb-n{right:20px;top:50%;transform:translateY(-50%);font-size:1.5rem}
.lb-ct{
  position:absolute;bottom:20px;left:50%;transform:translateX(-50%);
  font:400 .66rem/1 var(--sans);letter-spacing:.1em;
  color:rgba(255,255,255,.28);
}


/* ================================================================
   FLOATING CTA
   ================================================================ */
#fcta{
  position:fixed;bottom:28px;right:28px;z-index:800;
  background:var(--teal);color:#fff;
  font:600 .62rem/1 var(--sans);
  letter-spacing:.12em;text-transform:uppercase;
  padding:12px 22px;border-radius:48px;
  box-shadow:0 6px 24px rgba(26,171,184,.35);
  opacity:0;transform:translateY(12px);pointer-events:none;
  transition:opacity .4s var(--ease),transform .4s var(--ease),background .3s;
}
#fcta.on{opacity:1;transform:none;pointer-events:all}
#fcta:hover{background:var(--teal-hi)}


/* ================================================================
   TABLET  <=1024
   ================================================================ */
@media(max-width:1024px){
  .space-grid{grid-template-columns:1fr}
  .space-text{padding:60px 40px}
  .sp-main img{min-height:340px}
  .sp-small{height:180px}
  .book-hero{height:280px}
  .bfc-top{padding:24px 28px}
  .bfc-benefits{grid-template-columns:1fr;gap:14px}
  .book-form-card form{padding:28px 28px 24px}
  .bfc-foot{padding:16px 28px 24px}
  .book-main{padding:0 20px;padding-bottom:80px}
  .hl-grid{grid-template-columns:1fr}
  .hl{aspect-ratio:16/7}
  .mosaic{grid-auto-rows:220px}
  .mosaic--int{grid-template-rows:repeat(5,220px)}
  .mosaic--ext{grid-template-rows:repeat(3,220px)}
  .ft-top{grid-template-columns:1fr 1fr;gap:32px}
  .ft-brand{grid-column:1/-1}
  .loc-grid{gap:40px}
}

/* ================================================================
   MOBILE  <=768
   ================================================================ */
@media(max-width:768px){
  :root{--nav-h:74px}
  .hamburger{display:flex}
  .nav-links{
    position:fixed;top:var(--nav-h);left:0;right:0;
    background:rgba(9,24,36,.97);
    backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
    flex-direction:column;align-items:center;gap:0;
    padding:22px 20px;
    border-bottom:1px solid rgba(255,255,255,.05);
    transform:translateY(-110%);opacity:0;
    transition:transform .4s var(--ease),opacity .4s var(--ease);
    pointer-events:none;
  }
  .nav-links.open{transform:translateY(0);opacity:1;pointer-events:all}
  .nav-logo img{height:64px}
  .nl{font-size:.68rem;padding:14px 18px}
  .nl::after{display:none}
  .nl-book-mb{display:block;margin-top:8px}
  .nl-book-mb .nav-book{
    display:inline-flex;width:100%;justify-content:center;
    padding:12px;border-radius:10px;
  }
  .nav-book-desk{display:none}

  .hero-body{padding:0 24px}
  .hero-stats{gap:16px;padding:8px 22px}
  .hst-v{font-size:1rem}.hst-l{font-size:.42rem}
  .hst-v{font-size:1rem}.hst-l{font-size:.44rem}

  .mosaic{
    grid-template-columns:1fr 1fr;
    grid-auto-rows:190px;
  }
  .mosaic--int,.mosaic--ext{grid-template-rows:none}
  .mi--feat{grid-column:1/3;grid-row:1/3}

  .hl{aspect-ratio:4/3}
  .loc-grid{grid-template-columns:1fr;gap:28px;padding-bottom:0}
  .loc-map{padding-bottom:40px}
  .am-grid{grid-template-columns:1fr 1fr}
  .rates-inner{grid-template-columns:1fr;gap:40px}
  .rc{grid-template-columns:1fr;gap:14px;text-align:center}
  .rc-body{text-align:center}
  .rc-btn{justify-self:center}
  .rc-badge{left:50%;transform:translateX(-50%)}
  .space-nums{grid-template-columns:repeat(2,1fr)}
  .sp-small{height:150px}
  .frow{grid-template-columns:1fr}
  .ft-top{grid-template-columns:1fr;gap:32px;padding:52px 24px 40px}
  .ft-brand{grid-column:auto}
  .ft-watermark{display:none}
  #fcta{bottom:16px;right:14px}
  .lb-p{left:8px}.lb-n{right:8px}
  #gallery,#highlights,#amenities,#location,#rates{padding-top:88px}
  #amenities,#rates{padding-bottom:88px}
  .sec-head{margin-bottom:44px}
}

/* ================================================================
   SMALL  <=480
   ================================================================ */
@media(max-width:480px){
  .container,.sec-head{padding-left:20px;padding-right:20px}
  .hero-body{padding:0 20px}
  .hero-brand{font-size:3rem;letter-spacing:.1em}
  .h1-light{font-size:1.4rem}
  .h1-strong{font-size:1.8rem}
  .hero-stats{display:none}
  .am-grid{grid-template-columns:1fr}
  .mosaic{grid-template-columns:1fr;grid-template-rows:unset}
  .mi{height:240px}
  .mi--feat{grid-column:1;grid-row:auto}
  .hl{aspect-ratio:4/3}
  .book-form-card form{padding:24px 20px 20px}
  .bfc-top{padding:20px}
  .book-hero{height:220px}
  .book-main{margin-top:-40px}
  .space-text{padding:44px 20px}
  .loc-quote{height:240px}
}
