/* ═══════════════════════════════════════════════════
   SALTY BEACH BAR — Aligned with booking.saltybeachbar.com
   Palette: creamy sand bg · warm gold · dark brown text
   Fonts: Cormorant Garamond (display) · Inter (body)
═══════════════════════════════════════════════════ */

*, *::before, *::after { margin:0; padding:0; box-sizing:border-box }

:root {
  --gold:     #C4973A;
  --gold-l:   #D9B060;
  --gold-d:   #9E7822;
  --bg:       #FAF7F2;
  --bg-sand:  #F5EDD8;
  --bg-sand2: #EDE0C4;
  --bg-white: #FFFFFF;
  --dark:     #2C1F0E;
  --dark2:    #3D2E1A;
  --text:     #2C1F0E;
  --text-m:   #7A6245;
  --text-l:   rgba(44,31,14,.45);
  --border:   rgba(196,151,58,.22);
  --border-l: rgba(196,151,58,.12);
  --shadow:   0 2px 24px rgba(44,31,14,.08);
  --shadow-l: 0 1px 8px rgba(44,31,14,.05);
  --ease:     cubic-bezier(.16,1,.3,1);
  --serif:    'Cormorant Garamond', Georgia, serif;
  --sans:     'Inter', system-ui, sans-serif;
}

html { font-size:17px; scroll-behavior:smooth }
body {
  background: var(--bg);
  color: var(--text);
  font-family: var(--sans);
  font-weight: 300;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}
img { display:block; max-width:100% }
a { color:inherit; text-decoration:none }
button { font-family:var(--sans); cursor:pointer }
.page { display:none; min-height:100vh }
.page.active { display:block }

/* ─── NAV ─── */
#nav {
  position: fixed; top:0; left:0; right:0; z-index:900;
  padding: 20px 5vw;
  display: flex; align-items:center; justify-content:space-between;
  transition: all .4s;
}
#nav.solid, #nav.scrolled {
  background: rgba(250,247,242,.97);
  border-bottom: 1px solid var(--border-l);
  padding: 13px 5vw;
  backdrop-filter: blur(16px);
  box-shadow: var(--shadow-l);
}
.nav-logo-w { cursor:pointer }
#nav-logo { height:50px; width:auto; transition:height .35s }
#nav.solid #nav-logo, #nav.scrolled #nav-logo { height:36px }

.nav-right { display:flex; align-items:center; gap:12px }
.lang-btn {
  display:flex; align-items:center; gap:6px;
  background:none; border:1px solid var(--border);
  color:var(--text-m); padding:6px 12px;
  font-size:.72rem; letter-spacing:.12em; text-transform:uppercase;
  transition:all .3s;
}
.lang-btn:hover { border-color:var(--gold); color:var(--gold) }
#nav:not(.solid):not(.scrolled) .lang-btn { border-color:rgba(255,255,255,.4); color:rgba(255,255,255,.8) }
#nav:not(.solid):not(.scrolled) .lang-btn:hover { border-color:#fff; color:#fff }

/* Burger */
#burger { display:flex; flex-direction:column; gap:5px; padding:5px; background:none; border:none }
.bl { width:24px; height:1.5px; transition:all .4s var(--ease); display:block; transform-origin:center }
#nav.solid .bl, #nav.scrolled .bl { background:var(--dark) }
#nav:not(.solid):not(.scrolled) .bl { background:#fff }
#burger.open .bl:nth-child(1) { transform:translateY(6.5px) rotate(45deg) }
#burger.open .bl:nth-child(2) { opacity:0; transform:scaleX(0) }
#burger.open .bl:nth-child(3) { transform:translateY(-6.5px) rotate(-45deg) }
#burger.open .bl { background:var(--bg) !important }

/* ─── OVERLAY MENU ─── */
#overlay {
  position:fixed; inset:0; z-index:800;
  background: var(--dark);
  display:flex; flex-direction:column;
  padding: 108px 8vw 52px;
  clip-path: inset(0 0 100% 0);
  transition: clip-path .72s var(--ease);
  pointer-events:none; overflow:hidden;
}
#overlay.open { clip-path:inset(0 0 0% 0); pointer-events:all }

.ov-wm { position:absolute; right:-2%; bottom:-6%; width:52%; opacity:.06; pointer-events:none; transform:rotate(-5deg) }
#ov-logo { position:absolute; top:24px; left:5vw; height:42px; opacity:.6 }
.ov-x { position:absolute; top:20px; right:5vw; background:none; border:none; color:rgba(250,247,242,.45); font-size:2rem; line-height:1; transition:color .3s }
.ov-x:hover { color:var(--gold-l) }

.ov-nav { flex:1; display:flex; flex-direction:column; justify-content:center }
.ov-link {
  display:flex; align-items:baseline; gap:16px;
  font-family:var(--serif); font-size:clamp(2.8rem,6vw,5.5rem); font-weight:300;
  color:rgba(250,247,242,.7); line-height:1.18;
  transform:translateX(-36px); opacity:0;
  transition:color .3s, transform .3s;
  border-bottom: 1px solid rgba(250,247,242,.06);
  padding-bottom:2px;
}
.ov-link:last-child { border-bottom:none }
.ov-link em { font-style:italic; color:var(--gold-l) }
.ov-link:hover { color:var(--gold-l); transform:translateX(10px)!important }
#overlay.open .ov-link { transform:translateX(0); opacity:1 }
#overlay.open .ov-link:nth-child(1){transition:opacity .5s .07s,transform .5s .07s,color .3s}
#overlay.open .ov-link:nth-child(2){transition:opacity .5s .14s,transform .5s .14s,color .3s}
#overlay.open .ov-link:nth-child(3){transition:opacity .5s .21s,transform .5s .21s,color .3s}
#overlay.open .ov-link:nth-child(4){transition:opacity .5s .28s,transform .5s .28s,color .3s}
#overlay.open .ov-link:nth-child(5){transition:opacity .5s .35s,transform .5s .35s,color .3s}
.ov-num { font-family:var(--sans); font-size:.62rem; letter-spacing:.25em; color:var(--gold); font-weight:400; flex-shrink:0 }

.ov-foot {
  display:flex; flex-wrap:wrap; gap:20px 44px; align-items:flex-end;
  border-top:1px solid rgba(250,247,242,.1); padding-top:24px;
  opacity:0; transform:translateY(14px);
  transition:opacity .4s .42s, transform .4s .42s;
}
#overlay.open .ov-foot { opacity:1; transform:translateY(0) }
.ov-ci .lbl { font-size:.6rem; letter-spacing:.25em; text-transform:uppercase; color:var(--gold); margin-bottom:4px }
.ov-ci .val { font-size:.95rem; color:rgba(250,247,242,.75) }
.ov-soc { display:flex; gap:10px; margin-left:auto }
.ov-soc a { width:40px; height:40px; border:1px solid rgba(250,247,242,.15); display:flex; align-items:center; justify-content:center; color:rgba(250,247,242,.45); transition:all .3s }
.ov-soc a:hover { background:var(--gold); border-color:var(--gold); color:#fff }

/* ─── HERO ─── */
#hero-sec {
  position:relative; height:100svh; min-height:640px;
  display:flex; align-items:center; justify-content:center; overflow:hidden;
}
.h-slide { position:absolute; inset:0; opacity:0; transition:opacity 1.6s ease; background-size:cover; background-position:center }
.h-slide.active { opacity:1 }
.h-ov {
  position:absolute; inset:0;
  background:linear-gradient(to bottom, rgba(44,31,14,.22) 0%, rgba(44,31,14,.44) 50%, rgba(44,31,14,.88) 100%)
}
.h-content { position:relative; z-index:2; text-align:center; padding:0 6vw; display:flex; flex-direction:column; align-items:center }

/* THE HERO LOGO — big, clear, central */
.h-logo {
  width: min(500px, 80vw);
  margin-bottom:32px;
  opacity:0; animation:fu 1.4s .3s both;
  filter: drop-shadow(0 4px 32px rgba(196,151,58,.35));
}

.h-loc {
  font-size:.8rem; letter-spacing:.42em; text-transform:uppercase;
  color:rgba(250,247,242,.8); margin-bottom:10px;
  opacity:0; animation:fu 1s 1s both;
}
.h-tagline {
  font-family:var(--serif); font-style:italic;
  font-size:clamp(1.3rem,2.5vw,2rem); font-weight:300;
  color:var(--gold-l); margin-bottom:44px;
  opacity:0; animation:fu 1s 1.2s both;
  letter-spacing:.05em;
}
.h-btns { display:flex; gap:14px; flex-wrap:wrap; justify-content:center; opacity:0; animation:fu 1s 1.5s both }

.h-dots { position:absolute; bottom:80px; left:50%; transform:translateX(-50%); z-index:3; display:flex; gap:8px }
.dot { width:20px; height:1.5px; background:rgba(255,255,255,.28); cursor:pointer; transition:all .35s }
.dot.active { width:42px; background:var(--gold-l) }
.h-scroll { position:absolute; bottom:26px; left:50%; transform:translateX(-50%); z-index:3; display:flex; flex-direction:column; align-items:center; gap:6px; opacity:0; animation:fu 1s 2.2s both }
.h-scroll span { font-size:.58rem; letter-spacing:.28em; text-transform:uppercase; color:rgba(255,255,255,.38) }
.sline { width:1px; height:36px; background:linear-gradient(to bottom, var(--gold-l), transparent); animation:sp 2s infinite }

/* ─── BUTTONS ─── */
.btn {
  display:inline-block; padding:14px 34px;
  font-family:var(--sans); font-size:.76rem; font-weight:500;
  letter-spacing:.18em; text-transform:uppercase; transition:all .3s;
  border:none; cursor:pointer; text-align:center;
}
.btn-gold { background:var(--gold); color:#fff }
.btn-gold:hover { background:var(--gold-l) }
.btn-dark { background:var(--dark); color:var(--bg) }
.btn-dark:hover { background:var(--dark2) }
.btn-outline { background:transparent; border:1.5px solid var(--dark); color:var(--dark) }
.btn-outline:hover { background:var(--dark); color:var(--bg) }
.btn-outline-w { background:transparent; border:1.5px solid rgba(255,255,255,.55); color:#fff }
.btn-outline-w:hover { border-color:#fff; background:rgba(255,255,255,.12) }

/* ─── LAYOUT ─── */
.sec { padding:100px 5vw }
.sec-sand { background:var(--bg-sand) }
.sec-sand2 { background:var(--bg-sand2) }
.sec-white { background:var(--bg-white) }
.sec-dark { background:var(--dark); color:var(--bg) }

/* ─── SECTION HEADERS ─── */
.tag {
  display:inline-flex; align-items:center; gap:10px;
  font-size:.68rem; letter-spacing:.32em; text-transform:uppercase;
  color:var(--gold); font-weight:500; margin-bottom:14px;
}
.tag::before { content:''; width:28px; height:1px; background:var(--gold) }
.h2 {
  font-family:var(--serif); font-size:clamp(2.6rem,4.5vw,4.4rem);
  font-weight:300; line-height:1.08; color:var(--text);
}
.h2 em { font-style:italic; color:var(--gold) }
.h2-w { color:var(--bg) }
.h2-w em { color:var(--gold-l) }
.bodyt { font-size:1.05rem; line-height:1.92; color:var(--text-m) }

.sep {
  margin:0 5vw;
  height:1px;
  background:linear-gradient(to right, transparent, var(--border), transparent);
}

/* ─── SPLIT LAYOUT ─── */
.split { display:grid; grid-template-columns:1fr 1fr; gap:8vw; align-items:center }
.split-imgs { position:relative }
.main-img { width:100%; aspect-ratio:3/4; object-fit:cover }
.float-img { position:absolute; bottom:-28px; right:-28px; width:50%; aspect-ratio:4/3; object-fit:cover; box-shadow:var(--shadow); border:4px solid var(--bg) }
.badge {
  position:absolute; top:28px; left:-28px; width:90px; height:90px;
  border-radius:50%; background:var(--gold); color:#fff;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  font-family:var(--serif); box-shadow:var(--shadow);
}
.badge strong { font-size:1.5rem; font-weight:500; line-height:1 }
.badge small { font-size:.44rem; letter-spacing:2px; text-transform:uppercase; margin-top:2px }

.stats { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:44px; padding-top:36px; border-top:1px solid var(--border-l) }
.stat-n { font-family:var(--serif); font-size:3rem; font-weight:300; color:var(--gold); line-height:1 }
.stat-l { font-size:.65rem; letter-spacing:.18em; text-transform:uppercase; color:var(--text-l); margin-top:6px }

/* ─── SERVICE CARDS ─── */
.cards { display:grid; grid-template-columns:repeat(2, minmax(0,1fr)); gap:24px; margin-top:56px; max-width:920px; margin-left:auto; margin-right:auto }
.card {
  background:var(--bg-white); padding:44px 34px;
  box-shadow:var(--shadow-l); border:1px solid var(--border-l);
  position:relative; overflow:hidden; transition:all .4s; cursor:pointer;
}
.card::before {
  content:''; position:absolute; bottom:0; left:0; right:0; height:2px;
  background:var(--gold); transform:scaleX(0); transform-origin:left;
  transition:transform .5s var(--ease);
}
.card:hover { transform:translateY(-4px); box-shadow:var(--shadow) }
.card:hover::before { transform:scaleX(1) }
.card-n { font-family:var(--serif); font-size:4.5rem; font-weight:300; color:rgba(196,151,58,.15); line-height:1; margin-bottom:20px }
.card-t { font-family:var(--serif); font-size:2rem; font-weight:400; color:var(--text); margin-bottom:14px }
.card-b { font-size:1rem; line-height:1.85; color:var(--text-m) }

/* ─── GALLERY ─── */
.gal { display:grid; grid-template-columns:repeat(3,1fr); gap:4px; margin-top:52px }
.gi { overflow:hidden; cursor:zoom-in; aspect-ratio:4/3 }
.gi img { width:100%; height:100%; object-fit:cover; transition:transform .8s var(--ease) }
.gi:hover img { transform:scale(1.06) }
.gi-wide { grid-column:span 2; aspect-ratio:unset }
.gi-wide img { aspect-ratio:16/7 }

/* ─── PAGE HERO ─── */
.page-hero {
  position:relative; height:58vh; min-height:400px;
  display:flex; align-items:flex-end; overflow:hidden;
  padding:0 5vw 60px;
}
.ph-bg { position:absolute; inset:0; background-size:cover; background-position:center }
.ph-ov { position:absolute; inset:0; background:linear-gradient(160deg, rgba(44,31,14,.04) 0%, rgba(44,31,14,.72) 100%) }
.ph-content { position:relative; z-index:2 }
.ph-tag { font-size:.7rem; letter-spacing:.32em; text-transform:uppercase; color:var(--gold-l); margin-bottom:14px; display:flex; align-items:center; gap:10px }
.ph-tag::before { content:''; width:24px; height:1px; background:var(--gold-l) }
.ph-title { font-family:var(--serif); font-size:clamp(3.4rem,8vw,8rem); font-weight:300; line-height:.95; color:#fff }
.ph-title em { font-style:italic; color:var(--gold-l) }

/* ─── BEACH FEATURES ─── */
.feats { display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--border-l) }
.feat { background:var(--bg-white); padding:48px 34px; text-align:center; transition:background .3s }
.feat:hover { background:var(--bg-sand) }
.feat-icon { font-size:2.2rem; margin-bottom:18px; display:block }
.feat-t { font-family:var(--serif); font-size:1.8rem; font-weight:400; color:var(--text); margin-bottom:12px }
.feat-b { font-size:1rem; line-height:1.85; color:var(--text-m) }

/* ─── MENU GRID ─── */
.menu-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:1px; background:var(--border-l); margin-top:56px }
.mc { background:var(--bg-white); padding:44px 38px; transition:background .3s }
.mc:hover { background:var(--bg-sand) }
.mc-cat { font-size:.65rem; letter-spacing:.28em; text-transform:uppercase; color:var(--gold); margin-bottom:12px; display:flex; align-items:center; gap:8px }
.mc-cat::before { content:''; width:18px; height:1px; background:var(--gold) }
.mc-t { font-family:var(--serif); font-size:2rem; font-weight:400; color:var(--text); margin-bottom:18px }
.mc-items { list-style:none; display:flex; flex-direction:column; gap:11px }
.mc-items li { font-size:1rem; color:var(--text-m); padding-bottom:11px; border-bottom:1px solid var(--border-l); display:flex; align-items:center; gap:10px }
.mc-items li:last-child { border-bottom:none; padding-bottom:0 }
.mc-items li::before { content:'—'; color:var(--gold); font-size:.85rem; flex-shrink:0 }


/* ─── BOOKING LINK BANNER ─── */
.booking-banner {
  background:var(--dark); color:var(--bg);
  padding:60px 5vw;
  display:flex; align-items:center; justify-content:space-between; gap:32px; flex-wrap:wrap;
}
.booking-banner-text .tag { color:var(--gold-l) }
.booking-banner-text .tag::before { background:var(--gold-l) }
.booking-banner-text h2 { font-family:var(--serif); font-size:clamp(2rem,4vw,3.5rem); font-weight:300; color:var(--bg); margin-top:10px }
.booking-banner-text h2 em { font-style:italic; color:var(--gold-l) }

/* ─── CONTACT ─── */
.contact-layout { display:grid; grid-template-columns:1fr 1fr; gap:9vw; align-items:start }
.form-row { margin-bottom:26px }
.form-lbl { display:block; font-size:.67rem; letter-spacing:.22em; text-transform:uppercase; color:var(--text-l); margin-bottom:10px }
.form-field {
  width:100%; background:var(--bg-white); border:none; border-bottom:1.5px solid var(--border-l);
  color:var(--text); padding:12px 0; font-size:1.05rem; font-family:var(--sans); font-weight:300;
  outline:none; transition:border-color .3s; border-radius:0;
}
.form-field:focus { border-color:var(--gold) }
.form-field::placeholder { color:var(--text-l) }
textarea.form-field { resize:none; height:110px; background:transparent }
select.form-field { cursor:pointer; -webkit-appearance:none; background:transparent; background-image:url("assets/images/salty-01.svg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23C4973A' stroke-width='1.5' fill='none'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 4px center }
.form-msg { min-height:22px; font-size:1rem; margin-top:14px }
.form-msg-ok { color:var(--gold-d) }
.form-msg-err { color:#c0392b }

.ci-item { margin-bottom:34px }
.ci-lbl { font-size:.65rem; letter-spacing:.28em; text-transform:uppercase; color:var(--gold); margin-bottom:9px; display:flex; align-items:center; gap:10px }
.ci-lbl::before { content:''; width:18px; height:1px; background:var(--gold) }
.ci-val { font-size:1.1rem; color:var(--text); line-height:1.7 }
.ci-val a { color:var(--text); transition:color .3s }
.ci-val a:hover { color:var(--gold) }
.soc-row { display:flex; gap:12px; margin-top:38px }
.soc-btn { width:46px; height:46px; border:1px solid var(--border); display:flex; align-items:center; justify-content:center; color:var(--gold); transition:all .3s }
.soc-btn:hover { background:var(--gold); color:#fff; border-color:var(--gold) }

/* ─── INFO STRIP (like booking page) ─── */
.info-strip {
  background:var(--gold); padding:28px 5vw;
  display:grid; grid-template-columns:repeat(3,1fr); gap:20px; text-align:center;
}
.is-lbl { font-size:.62rem; letter-spacing:.28em; text-transform:uppercase; color:rgba(255,255,255,.65); margin-bottom:7px }
.is-val { font-family:var(--serif); font-size:1.45rem; font-weight:400; color:#fff }

/* ─── FOOTER ─── */
footer {
  background:var(--dark); color:var(--bg);
  padding:60px 5vw 36px;
}
.footer-top { display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:5vw; margin-bottom:52px }
.ft-logo { height:48px; opacity:.75; margin-bottom:18px }
.footer-brand p { font-size:.95rem; line-height:1.8; color:rgba(250,247,242,.45); max-width:260px }
.footer-col h4 { font-size:.62rem; letter-spacing:.3em; text-transform:uppercase; color:var(--gold); margin-bottom:18px; font-weight:500 }
.footer-col ul { list-style:none; display:flex; flex-direction:column; gap:12px }
.footer-col li a { font-size:.95rem; color:rgba(250,247,242,.45); transition:color .3s; cursor:pointer }
.footer-col li a:hover { color:var(--gold-l) }
.footer-bottom {
  display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:16px;
  padding-top:28px; border-top:1px solid rgba(250,247,242,.08);
}
.ft-copy { font-size:.75rem; color:rgba(250,247,242,.3); letter-spacing:.05em }
.ft-soc { display:flex; gap:10px }
.ft-soc a { width:38px; height:38px; border:1px solid rgba(250,247,242,.12); display:flex; align-items:center; justify-content:center; color:rgba(250,247,242,.35); transition:all .3s }
.ft-soc a:hover { background:var(--gold); border-color:var(--gold); color:#fff }
.ft-lang a { font-size:.7rem; letter-spacing:.18em; text-transform:uppercase; color:rgba(250,247,242,.3); cursor:pointer; transition:color .3s; margin-left:14px }
.ft-lang a.act, .ft-lang a:hover { color:var(--gold-l) }

/* ─── LIGHTBOX ─── */
#lb { display:none; position:fixed; inset:0; z-index:1000; background:rgba(44,31,14,.97); align-items:center; justify-content:center }
#lb.open { display:flex }
#lb-img { max-width:90vw; max-height:86vh; object-fit:contain }
.lbx,.lbn { background:none; border:none; cursor:pointer; transition:color .3s }
.lbx { position:absolute; top:22px; right:26px; color:rgba(250,247,242,.45); font-size:2rem }
.lbx:hover,.lbn:hover { color:var(--gold-l) }
.lbn { position:absolute; top:50%; transform:translateY(-50%); color:rgba(250,247,242,.3); font-size:2.8rem; padding:16px }
.lbprev{left:6px}.lbnext{right:6px}

/* ─── REVEAL ─── */
.rv { opacity:0; transform:translateY(26px); transition:opacity .85s var(--ease), transform .85s var(--ease) }
.rv.vis { opacity:1; transform:translateY(0) }
.d1{transition-delay:.12s}.d2{transition-delay:.24s}

@keyframes fu { from{opacity:0;transform:translateY(22px)} to{opacity:1;transform:translateY(0)} }
@keyframes sp  { 0%,100%{opacity:1} 50%{opacity:.22} }

/* ─── RESPONSIVE ─── */
@media(max-width:900px){
  .split,.contact-layout { grid-template-columns:1fr; gap:44px }
  .float-img,.badge { display:none }
  .cards,.feats { grid-template-columns:1fr; gap:1px; background:var(--border-l) }
  .card { box-shadow:none }
  .menu-grid,.ev-grid { grid-template-columns:1fr; gap:1px; background:var(--border-l) }
  .ev { box-shadow:none }
  .gal { grid-template-columns:1fr 1fr; gap:3px }
  .gi-wide { grid-column:span 2 } .gi-wide img { aspect-ratio:16/9 }
  .info-strip { grid-template-columns:1fr; padding:24px 6vw }
  .footer-top { grid-template-columns:1fr 1fr; gap:36px }
  .footer-bottom { flex-direction:column; align-items:center; text-align:center }
  .booking-banner { flex-direction:column; text-align:center }
  .sec { padding:68px 5vw }
  .page-hero { height:46vh; padding:0 5vw 40px }
}
@media(max-width:520px){
  #nav-logo { height:40px }
  .h-btns { flex-direction:column; align-items:center }
  .footer-top { grid-template-columns:1fr }
  html { font-size:16px }
}

/* Modern refactor layer — booking page inspired */
:root {
  --radius-sm: 14px;
  --radius-md: 22px;
  --radius-lg: 34px;
  --glass: rgba(255,255,255,.72);
  --ring: 0 0 0 4px rgba(196,151,58,.13);
}
body::before {
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:-1;
  background:
    radial-gradient(circle at 18% 10%, rgba(217,176,96,.16), transparent 34%),
    radial-gradient(circle at 82% 3%, rgba(196,151,58,.10), transparent 28%),
    linear-gradient(180deg, var(--bg), #f8f1e5 46%, var(--bg));
}
#nav.solid, #nav.scrolled {
  margin: 12px clamp(14px, 3vw, 34px);
  left: 0; right: 0;
  border: 1px solid var(--border-l);
  border-radius: 999px;
  box-shadow: 0 18px 48px rgba(44,31,14,.08);
}
.h-content {
  max-width: 940px;
  border: 1px solid rgba(255,255,255,.14);
  border-radius: var(--radius-lg);
  padding: clamp(34px, 5vw, 70px);
  background: linear-gradient(180deg, rgba(44,31,14,.18), rgba(44,31,14,.06));
  backdrop-filter: blur(3px);
}
.btn { border-radius: 999px; }
.btn-gold { box-shadow: 0 14px 28px rgba(196,151,58,.24); }
.btn:focus-visible, .lang-btn:focus-visible, #burger:focus-visible, .form-field:focus-visible {
  outline: none;
  box-shadow: var(--ring);
}
.card, .ev, .mc, .feat {
  border-radius: var(--radius-md);
}
.cards, .ev-grid, .menu-grid, .feats { gap: 18px; background: transparent; }
.card, .ev, .mc, .feat {
  background: linear-gradient(180deg, rgba(255,255,255,.92), rgba(255,255,255,.76));
  backdrop-filter: blur(12px);
  box-shadow: 0 20px 60px rgba(44,31,14,.07);
}
.form-field {
  border: 1px solid var(--border-l);
  border-radius: var(--radius-sm);
  padding: 14px 16px;
  background: rgba(255,255,255,.76);
}
textarea.form-field { background: rgba(255,255,255,.76); }
.info-strip {
  background: linear-gradient(135deg, var(--gold-d), var(--gold), var(--gold-l));
}
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration:.01ms!important; animation-iteration-count:1!important; scroll-behavior:auto!important; transition-duration:.01ms!important; }
}
@media(max-width:900px){
  #nav.solid, #nav.scrolled { margin: 8px 10px; }
  .cards, .ev-grid, .menu-grid, .feats { gap: 14px; }
}

/* ─── NAV UPDATE: larger logo + sticky gold logo + language dropdown ─── */
.nav-logo-w {
  position: relative;
  display: inline-flex;
  align-items: center;
  min-width: 138px;
  min-height: 92px;
}
.nav-logo {
  width: auto;
  object-fit: contain;
  transition: opacity .28s ease, height .35s ease, transform .35s ease;
}
.nav-logo-default {
  height: 92px;
}
.nav-logo-sticky {
  position: absolute;
  left: 0;
  top: 50%;
  height: 62px;
  opacity: 0;
  transform: translateY(-50%);
  pointer-events: none;
}
#nav.solid .nav-logo-default,
#nav.scrolled .nav-logo-default {
  opacity: 0;
  pointer-events: none;
}
#nav.solid .nav-logo-sticky,
#nav.scrolled .nav-logo-sticky {
  opacity: 1;
}
#nav.solid .nav-logo-w,
#nav.scrolled .nav-logo-w {
  min-height: 62px;
  min-width: 102px;
}

.lang-dropdown {
  position: relative;
  z-index: 940;
}
.lang-btn {
  min-height: 44px;
  padding: 9px 14px;
  gap: 9px;
  border-radius: 6px;
  background: rgba(250,247,242,.18);
  backdrop-filter: blur(8px);
}
.lang-globe,
.lang-caret { flex-shrink: 0; }
.lang-caret { transition: transform .25s ease; }
.lang-dropdown.open .lang-caret { transform: rotate(180deg); }
.lang-menu {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  min-width: 112px;
  padding: 8px;
  background: rgba(44,31,14,.96);
  border: 1px solid rgba(217,176,96,.25);
  box-shadow: 0 18px 42px rgba(44,31,14,.20);
  opacity: 0;
  visibility: hidden;
  transform: translateY(-8px);
  transition: opacity .22s ease, transform .22s ease, visibility .22s ease;
}
.lang-dropdown.open .lang-menu {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}
.lang-option {
  width: 100%;
  display: block;
  background: transparent;
  border: 0;
  color: rgba(250,247,242,.82);
  text-align: left;
  padding: 12px 14px;
  font-size: .78rem;
  letter-spacing: .16em;
  text-transform: uppercase;
  transition: color .2s ease, background .2s ease;
}
.lang-option:hover,
.lang-option.active {
  color: var(--gold-l);
  background: rgba(255,255,255,.06);
}
#nav.solid .lang-btn,
#nav.scrolled .lang-btn {
  background: rgba(255,255,255,.78);
  color: var(--dark);
  border-color: var(--border);
}
#nav:not(.solid):not(.scrolled) .lang-btn {
  border-color: rgba(255,255,255,.38);
  color: #fff;
}
#nav:not(.solid):not(.scrolled) .lang-btn:hover,
#nav.solid .lang-btn:hover,
#nav.scrolled .lang-btn:hover {
  border-color: var(--gold-l);
  color: var(--gold-l);
}

@media(max-width:700px){
  .nav-logo-w { min-width: 104px; min-height: 68px; }
  .nav-logo-default { height: 68px; }
  .nav-logo-sticky { height: 48px; }
  #nav.solid .nav-logo-w,
  #nav.scrolled .nav-logo-w { min-height: 48px; min-width: 82px; }
  .lang-btn { min-height: 40px; padding: 8px 11px; }
  .lang-menu { min-width: 96px; }
}


/* Turnstile widget */
.turnstile-widget { min-height: 65px; display:flex; align-items:center; }
.turnstile-widget:empty { display:none; }


/* ─── LEGAL PAGES ─── */
.legal-page { background: var(--bg); }
.legal-hero {
  position: relative; min-height: 46vh; padding: 160px 5vw 72px;
  display:flex; align-items:flex-end; overflow:hidden;
  background: linear-gradient(135deg, rgba(44,31,14,.78), rgba(44,31,14,.58)), url('../images/salty-05.jpg') center/cover no-repeat;
}
.legal-hero::after { content:''; position:absolute; inset:auto 0 0; height:42%; background:linear-gradient(to bottom, transparent, var(--bg)); pointer-events:none; }
.legal-hero-inner { position:relative; z-index:1; max-width:980px; }
.legal-kicker { font-size:.68rem; letter-spacing:.32em; text-transform:uppercase; color:var(--gold-l); margin-bottom:16px; display:flex; align-items:center; gap:12px; }
.legal-kicker::before { content:''; width:28px; height:1px; background:var(--gold-l); }
.legal-title { font-family:var(--serif); font-size:clamp(3rem,7vw,6.8rem); font-weight:300; line-height:.96; color:#fff; }
.legal-title em { color:var(--gold-l); font-style:italic; }
.legal-wrap { padding:80px 5vw 100px; }
.legal-card { max-width:980px; margin:0 auto; background:var(--bg-white); border:1px solid var(--border-l); box-shadow:var(--shadow-l); padding:clamp(28px,5vw,64px); }
.legal-card h2 { font-family:var(--serif); font-size:2.1rem; font-weight:400; margin:36px 0 12px; color:var(--text); }
.legal-card h2:first-child { margin-top:0; }
.legal-card p, .legal-card li { font-size:1rem; line-height:1.9; color:var(--text-m); }
.legal-card ul { margin:10px 0 22px 22px; }
.legal-updated { color:var(--gold); font-size:.72rem; letter-spacing:.18em; text-transform:uppercase; margin-bottom:30px; }
.legal-placeholder { border-left:2px solid var(--gold); padding:16px 18px; background:var(--bg-sand); margin:24px 0; color:var(--text-m); }
@media(max-width:700px){ .legal-hero{padding:130px 6vw 58px; min-height:40vh}.legal-wrap{padding:56px 5vw 76px}.legal-card{padding:28px 22px} }


/* Final owner-requested image treatment */
.main-img,
.float-img,
.gi img,
.ev img,
.mc img,
.feat img,
.split-imgs img {
  border-radius: var(--radius-lg);
}

/* Use the provided original logo files without altering the tagline alignment */
.nav-logo,
.h-logo,
.ft-logo,
#ov-logo {
  object-fit: contain;
}


/* Booking-style beach reservation tabs */
.booking-tab-grid {
  padding: 0 5vw 76px;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 24px;
}
.booking-tab {
  position: relative;
  min-height: 240px;
  border-radius: var(--radius-lg);
  overflow: hidden;
  background-size: cover;
  background-position: center;
  box-shadow: 0 22px 58px rgba(44,31,14,.12);
  border: 1px solid rgba(255,255,255,.28);
  display: flex;
  align-items: flex-end;
  transform: translateY(0);
  transition: transform .45s var(--ease), box-shadow .45s var(--ease);
}
.booking-tab:hover {
  transform: translateY(-6px);
  box-shadow: 0 28px 70px rgba(44,31,14,.18);
}
.booking-tab-ov {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(44,31,14,.06) 0%, rgba(44,31,14,.32) 42%, rgba(44,31,14,.76) 100%);
  transition: background .45s var(--ease);
}
.booking-tab:hover .booking-tab-ov {
  background: linear-gradient(180deg, rgba(44,31,14,.02) 0%, rgba(44,31,14,.22) 40%, rgba(44,31,14,.82) 100%);
}
.booking-tab-content {
  position: relative;
  z-index: 2;
  padding: 34px 32px 30px;
  color: #fff;
  width: 100%;
}
.booking-tab-content strong {
  display: block;
  font-family: var(--serif);
  font-size: clamp(1.55rem, 2.5vw, 2.25rem);
  line-height: 1.18;
  font-weight: 600;
  text-shadow: 0 2px 18px rgba(0,0,0,.35);
}
.booking-tab-content small {
  display: block;
  margin-top: 12px;
  font-family: var(--sans);
  font-size: .96rem;
  font-weight: 600;
  color: rgba(255,255,255,.92);
  text-shadow: 0 2px 12px rgba(0,0,0,.35);
}
@media(max-width:900px){
  .booking-tab-grid { grid-template-columns: 1fr; padding: 0 5vw 56px; gap: 18px; }
  .booking-tab { min-height: 230px; }
}
@media(max-width:520px){
  .booking-tab-grid { padding-left: 4vw; padding-right: 4vw; }
  .booking-tab-content { padding: 28px 24px 26px; }
}

/* ─── GOOGLE MAP SECTION ─── */
.map-section {
  padding: 86px 5vw;
  background: var(--bg-sand);
}
.map-section .map-head {
  max-width: 760px;
  margin: 0 auto 34px;
  text-align: center;
}
.map-frame {
  width: min(1180px, 100%);
  margin: 0 auto;
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow);
  border: 1px solid var(--border-l);
  background: var(--bg-white);
}
.map-frame iframe {
  display: block;
  width: 100%;
  height: 450px;
  border: 0;
}
@media(max-width:700px){
  .map-section { padding: 64px 5vw; }
  .map-frame iframe { height: 360px; }
}
