/* ============================================================
   Watermark Inn — Provincetown
   Premium coastal build · cinematic motion, interactive systems
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,300..600;1,9..144,300..500&family=Inter:wght@300;400;500;600&display=swap');

:root{
  --sand:        #f5f0e8;
  --sand-2:      #ece3d4;
  --paper:       #fbf8f3;
  --ink:         #1b2a31;
  --ink-soft:    #3c4f57;
  --bay:         #2f6076;
  --bay-deep:    #16323f;
  --bay-light:   #6f9fb2;
  --blush:       #d39079;
  --gold:        #c79a4f;
  --line:        rgba(27,42,49,.14);
  --shadow:      0 24px 60px -28px rgba(22,50,63,.45);
  --shadow-sm:   0 12px 30px -18px rgba(22,50,63,.4);
  --shadow-lg:   0 50px 110px -40px rgba(13,32,42,.7);

  --serif: "Fraunces", Georgia, 'Times New Roman', serif;
  --sans:  "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;

  --maxw: 1240px;
  --gutter: clamp(20px, 5vw, 64px);
  --ease: cubic-bezier(.2,.7,.2,1);
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  margin:0;
  font-family:var(--sans);
  color:var(--ink);
  background:var(--paper);
  font-weight:400;
  line-height:1.65;
  font-size:17px;
  letter-spacing:.005em;
  overflow-x:hidden;
}
body.is-loading{ overflow:hidden; height:100vh; }
img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
h1,h2,h3,h4{ font-family:var(--serif); font-weight:400; line-height:1.08; margin:0; letter-spacing:-.01em; }
::selection{ background:var(--gold); color:#fff; }

.wrap{ max-width:var(--maxw); margin:0 auto; padding-inline:var(--gutter); }
.eyebrow{
  font-family:var(--sans);
  font-size:.72rem; font-weight:600; letter-spacing:.28em; text-transform:uppercase;
  color:var(--bay); margin:0 0 1.1rem; display:flex; align-items:center; gap:12px;
}
.eyebrow::before{ content:""; width:26px; height:1px; background:currentColor; opacity:.6; }
.eyebrow.light{ color:rgba(255,255,255,.85); }
.lead{ font-size:clamp(1.12rem,1.5vw,1.35rem); color:var(--ink-soft); line-height:1.7; }

/* film grain + reveal -------------------------------------------------- */
.grain::after{
  content:""; position:fixed; inset:0; z-index:9000; pointer-events:none; opacity:.04;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
[data-reveal]{ opacity:0; transform:translateY(28px); transition:opacity 1s var(--ease), transform 1s var(--ease); }
[data-reveal].in{ opacity:1; transform:none; }
[data-reveal][data-delay="1"]{ transition-delay:.12s; }
[data-reveal][data-delay="2"]{ transition-delay:.24s; }
[data-reveal][data-delay="3"]{ transition-delay:.36s; }

/* split-text headline animation */
.split-line{ display:block; overflow:hidden; }
.split-word{ display:inline-block; transform:translateY(108%); transition:transform .9s var(--ease); }
.split-word .sp{ display:inline-block; }
[data-split].in .split-word{ transform:translateY(0); }
[data-split] .split-word{ transition-delay:calc(var(--wi) * .045s); }

/* clip image reveal */
.reveal-img{ overflow:hidden; }
.reveal-img img{ transform:scale(1.18); transition:transform 1.4s var(--ease); clip-path:inset(0 0 100% 0); }
[data-reveal].in .reveal-img img,
.reveal-img.in img{ transform:scale(1); clip-path:inset(0 0 0% 0); }

/* ===================== PRELOADER ===================== */
.preloader{
  position:fixed; inset:0; z-index:10000; background:var(--bay-deep); color:#fff;
  display:flex; align-items:center; justify-content:center;
  transition:opacity .7s ease, visibility .7s;
}
.preloader.done{ opacity:0; visibility:hidden; }
.pre-inner{ text-align:center; width:min(80vw,420px); }
.pre-mark{ font-family:var(--serif); font-size:clamp(2.4rem,6vw,3.6rem); font-style:italic; letter-spacing:.01em; line-height:1; }
.pre-mark span{ display:block; font-style:normal; font-size:.42em; letter-spacing:.5em; text-transform:uppercase; color:var(--bay-light); margin-top:.5em; padding-left:.5em; }
.pre-sub{ font-size:.66rem; letter-spacing:.34em; text-transform:uppercase; color:rgba(255,255,255,.5); margin-top:18px; }
.pre-line{ height:1px; background:rgba(255,255,255,.15); margin:30px 0 16px; position:relative; overflow:hidden; }
.pre-line span{ position:absolute; inset:0 100% 0 0; background:linear-gradient(90deg,var(--blush),var(--gold)); transition:right .2s linear; }
.pre-count{ font-family:var(--serif); font-size:1.1rem; color:rgba(255,255,255,.7); }
.pre-count i{ font-style:normal; font-size:.7em; opacity:.6; }

/* ===================== SCROLL PROGRESS ===================== */
.scroll-progress{ position:fixed; top:0; left:0; height:3px; width:0; z-index:9500; background:linear-gradient(90deg,var(--blush),var(--gold)); transition:width .1s linear; }

/* ===================== CUSTOM CURSOR ===================== */
.cursor, .cursor-ring{ position:fixed; top:0; left:0; z-index:9600; pointer-events:none; border-radius:50%; mix-blend-mode:difference; }
.cursor{ width:7px; height:7px; background:#fff; transform:translate(-50%,-50%); transition:opacity .3s, width .3s, height .3s; }
.cursor-ring{
  width:42px; height:42px; border:1px solid rgba(255,255,255,.7); transform:translate(-50%,-50%);
  transition:width .35s var(--ease), height .35s var(--ease), opacity .3s, background .35s;
  display:flex; align-items:center; justify-content:center;
}
.cursor-label{ font-family:var(--sans); font-size:.5rem; letter-spacing:.16em; text-transform:uppercase; color:#fff; opacity:0; transition:opacity .25s; mix-blend-mode:normal; }
body.cursor-hover .cursor-ring{ width:64px; height:64px; background:rgba(255,255,255,.08); }
body.cursor-hover .cursor{ width:4px; height:4px; }
body.cursor-view .cursor-ring{ width:84px; height:84px; border-color:#fff; }
body.cursor-view .cursor-label{ opacity:1; }
@media (hover:none), (pointer:coarse){ .cursor,.cursor-ring{ display:none; } }

/* ===================== SIDE DOTS ===================== */
.dots{ position:fixed; right:26px; top:50%; transform:translateY(-50%); z-index:90; display:flex; flex-direction:column; gap:16px; }
.dots a{ width:9px; height:9px; border-radius:50%; border:1px solid rgba(27,42,49,.4); position:relative; transition:.35s; }
.dots a.active{ background:var(--bay); border-color:var(--bay); transform:scale(1.25); }
.dots a::after{
  content:attr(data-label); position:absolute; right:20px; top:50%; transform:translateY(-50%) translateX(6px);
  white-space:nowrap; font-size:.62rem; letter-spacing:.14em; text-transform:uppercase; color:var(--ink);
  background:var(--paper); padding:5px 11px; border-radius:30px; box-shadow:var(--shadow-sm);
  opacity:0; pointer-events:none; transition:.3s;
}
.dots a:hover::after{ opacity:1; transform:translateY(-50%) translateX(0); }
.dots.on-dark a{ border-color:rgba(255,255,255,.5); }
.dots.on-dark a.active{ background:#fff; border-color:#fff; }
@media (max-width:1100px){ .dots{ display:none; } }

/* ===================== NAV ===================== */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:100;
  display:flex; align-items:center; justify-content:space-between;
  padding:22px var(--gutter);
  transition:background .45s ease, padding .45s ease, box-shadow .45s ease;
}
.nav.scrolled{
  background:rgba(251,248,243,.9);
  backdrop-filter:blur(14px) saturate(140%);
  padding:13px var(--gutter);
  box-shadow:0 1px 0 var(--line);
}
.brand{ display:flex; flex-direction:column; line-height:1; color:#fff; transition:color .45s; }
.nav.scrolled .brand{ color:var(--ink); }
.brand .name{ font-family:var(--serif); font-size:1.5rem; font-style:italic; letter-spacing:.01em; }
.brand .sub{ font-family:var(--sans); font-size:.6rem; font-weight:500; letter-spacing:.32em; text-transform:uppercase; opacity:.75; margin-top:5px; white-space:nowrap; }
.nav-links{ display:flex; align-items:center; gap:34px; }
.nav-links a{
  font-size:.78rem; font-weight:500; letter-spacing:.16em; text-transform:uppercase;
  color:rgba(255,255,255,.9); position:relative; padding:4px 0;
}
.nav.scrolled .nav-links a{ color:var(--ink-soft); }
.nav-links a:not(.btn)::after{
  content:""; position:absolute; left:0; bottom:-2px; width:0; height:1px;
  background:currentColor; transition:width .35s ease;
}
.nav-links a:not(.btn):hover::after{ width:100%; }
.btn{
  display:inline-block; font-family:var(--sans);
  font-size:.78rem; font-weight:600; letter-spacing:.14em; text-transform:uppercase;
  padding:13px 26px; border-radius:2px; transition:all .35s ease; cursor:pointer; border:1px solid transparent;
  position:relative; overflow:hidden;
}
.btn-sm{ padding:11px 22px; font-size:.72rem; }
.btn-solid{ background:var(--bay); color:#fff; }
.btn-solid:hover{ background:var(--bay-deep); transform:translateY(-2px); box-shadow:var(--shadow-sm); }
.btn-ghost{ border-color:rgba(255,255,255,.55); color:#fff; }
.nav.scrolled .btn-ghost{ border-color:var(--bay); color:var(--bay); }
.btn-ghost:hover{ background:#fff; color:var(--ink); border-color:#fff; }
.nav.scrolled .btn-ghost:hover{ background:var(--bay); color:#fff; border-color:var(--bay); }
.nav-toggle{ display:none; background:none; border:0; cursor:pointer; width:30px; height:22px; position:relative; z-index:101; }
.nav-toggle span{ position:absolute; left:0; width:100%; height:2px; background:#fff; transition:.3s; }
.nav.scrolled .nav-toggle span{ background:var(--ink); }
.nav-toggle span:nth-child(1){ top:0; } .nav-toggle span:nth-child(2){ top:10px; } .nav-toggle span:nth-child(3){ top:20px; }
.nav-toggle.open span{ background:var(--ink); }
.nav-toggle.open span:nth-child(1){ top:10px; transform:rotate(45deg); }
.nav-toggle.open span:nth-child(2){ opacity:0; }
.nav-toggle.open span:nth-child(3){ top:10px; transform:rotate(-45deg); }

/* ===================== HERO ===================== */
.hero{ position:relative; height:100vh; min-height:660px; display:flex; align-items:flex-end; overflow:hidden; }
.hero-bg{ position:absolute; inset:0; z-index:0; }
.hero-bg img{
  width:100%; height:100%; object-fit:cover; object-position:center 58%;
  transform:scale(1.12); animation:kenburns 24s ease-out forwards;
}
@keyframes kenburns{ to{ transform:scale(1); } }
.hero-grade{
  position:absolute; inset:0; z-index:1;
  background:linear-gradient(180deg, rgba(13,32,42,.46) 0%, rgba(13,32,42,.1) 30%, rgba(13,32,42,.14) 55%, rgba(13,32,42,.82) 100%);
}
.hero-inner{ position:relative; z-index:2; color:#fff; padding-bottom:clamp(48px,9vh,120px); max-width:920px; }
.hero h1{ font-size:clamp(2.9rem,7.4vw,6.4rem); line-height:.96; letter-spacing:-.025em; text-shadow:0 2px 40px rgba(0,0,0,.25); }
.hero-lede{ font-size:clamp(1.05rem,1.7vw,1.4rem); max-width:560px; margin:1.6rem 0 2.2rem; color:rgba(255,255,255,.92); font-weight:300; }
.hero-cta{ display:flex; gap:18px; flex-wrap:wrap; align-items:center; }
.hero-phone{ font-size:.82rem; letter-spacing:.14em; text-transform:uppercase; color:rgba(255,255,255,.88); display:flex; align-items:center; gap:9px; }
.hero-phone:hover{ color:var(--gold); }
.scroll-cue{
  position:absolute; bottom:30px; left:50%; transform:translateX(-50%); z-index:3;
  color:rgba(255,255,255,.7); font-size:.64rem; letter-spacing:.3em; text-transform:uppercase;
  display:flex; flex-direction:column; align-items:center; gap:10px;
}
.scroll-cue .bar{ width:1px; height:46px; background:linear-gradient(rgba(255,255,255,.7),transparent); animation:cue 2.4s ease-in-out infinite; transform-origin:top; }
@keyframes cue{ 0%,100%{ transform:scaleY(.4); opacity:.4; } 50%{ transform:scaleY(1); opacity:1; } }

/* sun-arc widget */
.sunwidget{
  position:absolute; right:var(--gutter); bottom:clamp(48px,9vh,120px); z-index:3;
  width:280px; padding:20px 22px; border-radius:8px; color:#fff;
  background:rgba(13,32,42,.42); backdrop-filter:blur(16px) saturate(140%);
  border:1px solid rgba(255,255,255,.16); box-shadow:var(--shadow-lg);
  opacity:0; transform:translateY(20px); transition:opacity 1s var(--ease) .8s, transform 1s var(--ease) .8s;
}
body:not(.is-loading) .sunwidget{ opacity:1; transform:none; }
.sw-head{ font-size:.64rem; letter-spacing:.16em; text-transform:uppercase; color:rgba(255,255,255,.82); display:flex; align-items:center; gap:7px; }
.sw-tz{ opacity:.6; }
.sw-dot{ width:6px; height:6px; border-radius:50%; background:var(--gold); box-shadow:0 0 0 0 rgba(199,154,79,.6); animation:pulse 2.4s infinite; }
@keyframes pulse{ 0%{ box-shadow:0 0 0 0 rgba(199,154,79,.5);} 70%{ box-shadow:0 0 0 8px rgba(199,154,79,0);} 100%{ box-shadow:0 0 0 0 rgba(199,154,79,0);} }
.sw-arc{ width:100%; height:74px; margin:8px 0 4px; overflow:visible; }
.sw-horizon{ stroke:rgba(255,255,255,.25); stroke-width:1; stroke-dasharray:2 3; }
.sw-track{ fill:none; stroke:rgba(255,255,255,.18); stroke-width:1.5; }
.sw-fill{ fill:none; stroke:url(#arcGrad); stroke-width:2; stroke-linecap:round; }
.sw-sun{ fill:#fff; filter:drop-shadow(0 0 6px rgba(255,236,200,.9)); }
.sw-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:6px; margin-top:6px; text-align:center; }
.sw-k{ display:block; font-size:.56rem; letter-spacing:.12em; text-transform:uppercase; color:rgba(255,255,255,.55); }
.sw-v{ display:block; font-family:var(--serif); font-size:1.02rem; margin-top:3px; }
@media (max-width:980px){ .sunwidget{ display:none; } }

/* ===================== MARQUEE ===================== */
.marquee{ background:var(--bay-deep); color:#fff; overflow:hidden; padding:16px 0; white-space:nowrap; }
.marquee-track{ display:inline-flex; align-items:center; gap:34px; animation:marq 32s linear infinite; }
.marquee-track span{ font-family:var(--serif); font-size:1.15rem; font-style:italic; }
.marquee-track i{ color:var(--gold); font-style:normal; font-size:.7rem; }
@keyframes marq{ to{ transform:translateX(-50%); } }
.marquee:hover .marquee-track{ animation-play-state:paused; }

/* ===================== SECTION SCAFFOLD ===================== */
section{ position:relative; }
.section{ padding:clamp(72px,11vh,150px) 0; }
.section-head{ max-width:680px; margin-bottom:clamp(40px,6vh,72px); }
.section-head h2{ font-size:clamp(2rem,4.4vw,3.5rem); }
.section-head.center{ margin-inline:auto; text-align:center; }
.section-head.center .eyebrow{ justify-content:center; }

/* Intro */
.intro{ background:var(--paper); }
.intro-grid{ display:grid; grid-template-columns:1.15fr .85fr; gap:clamp(36px,6vw,90px); align-items:center; }
.intro-grid h2{ font-size:clamp(2.1rem,4.2vw,3.4rem); margin-bottom:1.4rem; }
.intro-figure{ position:relative; margin:0; }
.intro-figure .reveal-img{ border-radius:3px; box-shadow:var(--shadow); }
.intro-figure img{ width:100%; aspect-ratio:3/4; object-fit:cover; }
.intro-figure .tag{
  position:absolute; bottom:-26px; left:-26px; background:var(--ink); color:#fff; padding:22px 26px; border-radius:3px;
  box-shadow:var(--shadow-sm); max-width:230px;
}
.intro-figure .tag .n{ font-family:var(--serif); font-size:2.4rem; line-height:1; display:block; }
.intro-figure .tag .t{ font-size:.74rem; letter-spacing:.04em; line-height:1.5; opacity:.85; margin-top:6px; display:block; }

.stat-row{ display:flex; gap:clamp(28px,5vw,72px); flex-wrap:wrap; margin-top:2.4rem; }
.stat .n{ font-family:var(--serif); font-size:2.8rem; color:var(--bay); line-height:1; }
.stat .n small{ font-size:1.2rem; }
.stat .t{ font-size:.8rem; letter-spacing:.05em; color:var(--ink-soft); margin-top:6px; max-width:130px; }

/* ===================== A DAY ON THE WATER (pinned) ===================== */
.day{ height:400vh; background:var(--bay-deep); position:relative; }
.day-sticky{ position:sticky; top:0; height:100vh; overflow:hidden; }
.day-track{ display:flex; height:100%; width:400vw; will-change:transform; }
.day-panel{ position:relative; width:100vw; height:100%; display:flex; align-items:flex-end; overflow:hidden; }
.dp-bg{ position:absolute; inset:0; z-index:0; }
.dp-bg img{ width:100%; height:100%; object-fit:cover; transform:scale(1.1); }
.day-panel::after{ content:""; position:absolute; inset:0; z-index:1; }
/* time-of-day mood lives in the overlay gradients — no costly image filters */
.day-panel[data-grade="dawn"]::after{ background:linear-gradient(180deg,rgba(150,110,130,.42),rgba(20,40,60,.9)); }
.day-panel[data-grade="noon"]::after{ background:linear-gradient(180deg,rgba(120,170,200,.2),rgba(13,32,42,.82)); }
.day-panel[data-grade="gold"]::after{ background:linear-gradient(180deg,rgba(210,150,70,.4),rgba(60,32,14,.9)); }
.day-panel[data-grade="night"]::after{ background:linear-gradient(180deg,rgba(30,55,95,.55),rgba(6,14,24,.94)); }
.dp-text{ position:relative; z-index:2; color:#fff; padding:0 var(--gutter) clamp(70px,12vh,130px); max-width:640px; }
.dp-time{ font-size:.72rem; letter-spacing:.24em; text-transform:uppercase; color:var(--gold); }
.dp-text h3{ font-size:clamp(2rem,4.6vw,3.6rem); margin:14px 0 16px; line-height:1.04; }
.dp-text p{ font-size:1.1rem; font-weight:300; color:rgba(255,255,255,.9); max-width:520px; }
.day-progress{ position:absolute; top:0; left:0; right:0; height:3px; background:rgba(255,255,255,.12); z-index:5; }
.day-progress span{ display:block; height:100%; width:0; background:linear-gradient(90deg,var(--blush),var(--gold)); }
.day-hint{ position:absolute; right:var(--gutter); top:50%; transform:translateY(-50%); z-index:5; color:rgba(255,255,255,.7); font-size:.66rem; letter-spacing:.24em; text-transform:uppercase; display:flex; align-items:center; gap:8px; }
.day-hint i{ animation:nudge 1.6s ease-in-out infinite; font-style:normal; }
@keyframes nudge{ 0%,100%{ transform:translateX(0);} 50%{ transform:translateX(6px);} }

/* ===================== SUITES EXPLORER ===================== */
.suites{ background:linear-gradient(180deg,var(--sand) 0%, var(--paper) 100%); }
.explorer{ display:grid; grid-template-columns:1.5fr 1fr; gap:clamp(24px,3vw,44px); }
.ex-stage{ background:#fff; border:1px solid var(--line); border-radius:6px; overflow:hidden; box-shadow:var(--shadow); display:flex; flex-direction:column; }
.ex-imgwrap{ position:relative; aspect-ratio:16/11; overflow:hidden; background:var(--sand-2); }
.ex-imgwrap img{ width:100%; height:100%; object-fit:cover; transition:opacity .5s ease, transform 7s ease; }
.ex-imgwrap img.swapping{ opacity:0; }
.ex-imgwrap:hover img{ transform:scale(1.05); }
.ex-badge{ position:absolute; top:18px; left:18px; background:var(--gold); color:#fff; font-size:.64rem; letter-spacing:.16em; text-transform:uppercase; padding:7px 14px; border-radius:30px; }
.ex-zoom{ position:absolute; bottom:18px; right:18px; background:rgba(13,32,42,.6); backdrop-filter:blur(6px); color:#fff; border:1px solid rgba(255,255,255,.3); border-radius:30px; padding:9px 16px; font-size:.66rem; letter-spacing:.12em; text-transform:uppercase; cursor:pointer; transition:.3s; }
.ex-zoom:hover{ background:var(--bay); }
.ex-detail{ padding:28px 32px 32px; }
.ex-tier{ font-size:.7rem; letter-spacing:.2em; text-transform:uppercase; color:var(--gold); }
.ex-detail h3{ font-size:1.9rem; margin:8px 0 10px; }
.ex-detail p{ color:var(--ink-soft); font-size:.98rem; margin:0 0 16px; }
.ex-feats{ list-style:none; padding:0; margin:0 0 20px; display:flex; flex-wrap:wrap; gap:8px 18px; }
.ex-feats li{ font-size:.84rem; color:var(--ink-soft); display:flex; align-items:center; gap:8px; }
.ex-feats li::before{ content:""; width:5px; height:5px; border-radius:50%; background:var(--blush); }
.ex-foot{ display:flex; align-items:baseline; justify-content:space-between; padding:16px 0; border-top:1px solid var(--line); border-bottom:1px solid var(--line); margin-bottom:20px; }
.ex-price b{ font-family:var(--serif); font-size:1.7rem; color:var(--ink); }
.ex-price i{ font-style:normal; font-size:.84rem; color:var(--ink-soft); }
.ex-nums{ font-size:.76rem; letter-spacing:.08em; text-transform:uppercase; color:var(--bay); }
.ex-list{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:10px; }
.ex-list li{ display:grid; grid-template-columns:auto 1fr auto; grid-template-rows:auto auto; column-gap:16px; align-items:center; padding:18px 20px; border:1px solid var(--line); border-radius:5px; cursor:pointer; transition:.35s var(--ease); background:#fff; }
.ex-list li:hover{ border-color:var(--bay-light); transform:translateX(4px); }
.ex-list li.active{ background:var(--bay-deep); border-color:var(--bay-deep); color:#fff; }
.el-no{ grid-row:1/3; font-family:var(--serif); font-size:1.4rem; color:var(--bay-light); }
.ex-list li.active .el-no{ color:var(--gold); }
.el-name{ font-family:var(--serif); font-size:1.18rem; }
.el-tag{ grid-column:2; font-size:.76rem; color:var(--ink-soft); }
.ex-list li.active .el-tag{ color:rgba(255,255,255,.6); }
.el-price{ grid-row:1/3; font-family:var(--serif); font-size:1.2rem; color:var(--bay); }
.ex-list li.active .el-price{ color:#fff; }
.el-price::before{ content:"from "; font-family:var(--sans); font-size:.58rem; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-soft); display:block; }
.ex-list li.active .el-price::before{ color:rgba(255,255,255,.5); }

.amenities{ display:flex; flex-wrap:wrap; gap:12px 26px; margin-top:54px; padding-top:40px; border-top:1px solid var(--line); }
.amenities span{ font-size:.86rem; color:var(--ink-soft); display:flex; align-items:center; gap:9px; }
.amenities span::before{ content:""; width:6px; height:6px; border-radius:50%; background:var(--blush); }

/* ===================== PLAN YOUR STAY ===================== */
.book{ background:var(--sand); }
.planner{ display:grid; grid-template-columns:1.1fr .9fr; gap:clamp(20px,2.6vw,40px); align-items:start; }
.cal, .est{ background:#fff; border:1px solid var(--line); border-radius:6px; box-shadow:var(--shadow-sm); }
.cal{ padding:24px 26px 20px; }
.cal-head{ display:flex; align-items:center; justify-content:space-between; margin-bottom:18px; }
.cal-head span{ font-family:var(--serif); font-size:1.3rem; }
.cal-nav{ width:38px; height:38px; border:1px solid var(--line); background:#fff; border-radius:50%; cursor:pointer; font-size:1.2rem; color:var(--bay); transition:.3s; }
.cal-nav:hover{ background:var(--bay); color:#fff; border-color:var(--bay); }
.cal-dow{ display:grid; grid-template-columns:repeat(7,1fr); gap:4px; margin-bottom:6px; }
.cal-dow span{ text-align:center; font-size:.64rem; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-soft); }
.cal-grid{ display:grid; grid-template-columns:repeat(7,1fr); gap:4px; }
.cal-cell{ aspect-ratio:1; display:flex; align-items:center; justify-content:center; font-size:.92rem; border-radius:5px; cursor:pointer; position:relative; transition:background .2s, color .2s; }
.cal-cell.empty{ pointer-events:none; }
.cal-cell.past{ color:var(--line); pointer-events:none; }
.cal-cell.avail:hover{ background:var(--sand-2); }
.cal-cell.start, .cal-cell.end{ background:var(--bay); color:#fff; font-weight:600; z-index:1; }
.cal-cell.range{ background:rgba(47,96,118,.12); border-radius:0; }
.cal-cell.start{ border-radius:5px 0 0 5px; }
.cal-cell.end{ border-radius:0 5px 5px 0; }
.cal-cell .sd{ position:absolute; bottom:5px; width:4px; height:4px; border-radius:50%; }
.cal-hint{ font-size:.78rem; color:var(--ink-soft); margin:16px 0 0; text-align:center; }

.est{ padding:26px 28px 28px; }
.est-field label{ font-size:.7rem; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-soft); display:block; margin-bottom:8px; }
.est-field select{ width:100%; padding:13px 14px; border:1px solid var(--line); border-radius:4px; font-family:var(--sans); font-size:.95rem; color:var(--ink); background:var(--paper); cursor:pointer; }
.est-field select:focus{ outline:none; border-color:var(--bay); }
.est-rows{ margin:22px 0 0; }
.est-row{ display:flex; justify-content:space-between; align-items:center; padding:12px 0; border-bottom:1px solid var(--line); font-size:.92rem; }
.est-row span{ color:var(--ink-soft); }
.est-row b{ font-weight:500; color:var(--ink); }
.est-total{ display:flex; justify-content:space-between; align-items:baseline; margin:20px 0 4px; padding:18px 20px; background:var(--bay-deep); color:#fff; border-radius:5px; }
.est-total span{ font-size:.78rem; letter-spacing:.1em; text-transform:uppercase; color:var(--bay-light); }
.est-total b{ font-family:var(--serif); font-size:2rem; }
.est-note{ font-size:.76rem; color:var(--ink-soft); line-height:1.6; margin:14px 0 20px; }
.est .btn-solid{ width:100%; text-align:center; }

.rate-toggle{ margin-top:46px; border-top:1px solid var(--line); }
.rate-toggle summary{ list-style:none; cursor:pointer; padding:22px 0; font-size:.8rem; letter-spacing:.14em; text-transform:uppercase; color:var(--bay); display:flex; align-items:center; justify-content:space-between; font-weight:600; }
.rate-toggle summary::-webkit-details-marker{ display:none; }
.rate-toggle summary i{ font-style:normal; font-size:1.3rem; transition:transform .3s; }
.rate-toggle[open] summary i{ transform:rotate(45deg); }
.rate-wrap{ overflow-x:auto; padding-bottom:10px; }
.rate-table{ width:100%; border-collapse:collapse; font-size:.96rem; min-width:520px; }
.rate-table th, .rate-table td{ padding:16px 14px; text-align:right; border-bottom:1px solid var(--line); }
.rate-table th{ font-family:var(--sans); font-weight:500; font-size:.7rem; letter-spacing:.12em; text-transform:uppercase; color:var(--bay); }
.rate-table th small{ display:block; color:var(--ink-soft); font-weight:400; font-size:.62rem; margin-top:3px; }
.rate-table td:first-child, .rate-table th:first-child{ text-align:left; }
.rate-table tbody td:first-child{ font-family:var(--serif); font-size:1.05rem; }
.rate-table tbody td:first-child small{ display:block; font-family:var(--sans); font-size:.72rem; color:var(--ink-soft); margin-top:3px; }
.rate-table tbody tr{ transition:background .3s; }
.rate-table tbody tr:hover{ background:var(--sand); }
.rate-note{ margin-top:20px; font-size:.82rem; color:var(--ink-soft); line-height:1.7; max-width:760px; }

/* ===================== GALLERY ===================== */
.gallery{ background:var(--paper); }
.gallery .section-head{ display:flex; flex-direction:column; }
.gal-filter{ display:flex; flex-wrap:wrap; gap:10px; margin-top:24px; }
.gal-filter button{ font-family:var(--sans); font-size:.72rem; letter-spacing:.12em; text-transform:uppercase; padding:9px 18px; border:1px solid var(--line); background:#fff; border-radius:30px; cursor:pointer; color:var(--ink-soft); transition:.3s; }
.gal-filter button:hover{ border-color:var(--bay); color:var(--bay); }
.gal-filter button.active{ background:var(--bay); border-color:var(--bay); color:#fff; }
.gal-grid{ display:grid; grid-template-columns:repeat(12,1fr); gap:14px; grid-auto-flow:dense; }
.gal-item{ position:relative; overflow:hidden; border-radius:4px; cursor:pointer; background:var(--sand-2); }
.gal-item img{ width:100%; height:100%; object-fit:cover; transition:transform 1.1s var(--ease), filter .5s; }
.gal-item:hover img{ transform:scale(1.06); }
.gal-item figcaption{ position:absolute; inset:auto 0 0 0; padding:34px 16px 14px; color:#fff; font-size:.74rem; letter-spacing:.03em; background:linear-gradient(transparent,rgba(13,32,42,.85)); opacity:0; transition:opacity .4s; transform:translateY(8px); }
.gal-item:hover figcaption{ opacity:1; transform:none; }
.gal-item.hide{ display:none; }
.gal-item.g-wide{ grid-column:span 8; aspect-ratio:16/9; }
.gal-item.g-tall{ grid-column:span 4; grid-row:span 2; aspect-ratio:auto; }
.gal-item.g-std{ grid-column:span 4; aspect-ratio:4/3; }
.gal-item.g-half{ grid-column:span 6; aspect-ratio:3/2; }

/* ===================== BAND ===================== */
.band{ position:relative; height:88vh; min-height:540px; overflow:hidden; display:flex; align-items:center; }
.band-bg{ position:absolute; inset:-12% 0; z-index:0; }
.band-bg img{ width:100%; height:100%; object-fit:cover; will-change:transform; }
.band-bg::after{ content:""; position:absolute; inset:0; background:linear-gradient(90deg, rgba(13,32,42,.78), rgba(13,32,42,.3) 60%, transparent); }
.band-inner{ position:relative; z-index:2; color:#fff; max-width:620px; }
.band-inner h2{ font-size:clamp(2.1rem,4.6vw,3.6rem); margin-bottom:1.2rem; }
.band-inner p{ color:rgba(255,255,255,.9); font-weight:300; font-size:1.12rem; }
.band-link{ display:inline-block; margin-top:1.8rem; font-size:.8rem; letter-spacing:.16em; text-transform:uppercase; color:var(--gold); border-bottom:1px solid currentColor; padding-bottom:5px; transition:.3s; }
.band-link:hover{ color:#fff; }

/* ===================== GETTING HERE + MAP ===================== */
.getting{ background:var(--paper); }
.getting-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(36px,5vw,80px); align-items:center; }
.getting-copy .lead{ margin-bottom:32px; }
.getting-list{ display:flex; flex-direction:column; gap:6px; }
.g-item{ display:flex; gap:18px; padding:18px 0; border-bottom:1px solid var(--line); align-items:flex-start; }
.g-ic{ width:34px; height:34px; flex:none; border:1px solid var(--line); border-radius:50%; display:flex; align-items:center; justify-content:center; color:var(--bay); font-size:1rem; }
.g-item b{ font-family:var(--serif); font-size:1.15rem; font-weight:500; }
.g-item p{ font-size:.9rem; color:var(--ink-soft); margin:4px 0 0; }
.getting-map{ position:relative; border-radius:6px; overflow:hidden; box-shadow:var(--shadow); }
.getting-map iframe{ width:100%; height:clamp(380px,52vh,520px); border:0; display:block; filter:grayscale(.2) contrast(1.02); }
.map-card{ position:absolute; left:20px; bottom:20px; background:#fff; padding:18px 22px; border-radius:5px; box-shadow:var(--shadow-sm); max-width:240px; }
.mc-k{ font-family:var(--serif); font-size:1.15rem; display:block; }
.mc-v{ font-size:.84rem; color:var(--ink-soft); display:block; margin:6px 0 10px; line-height:1.5; }
.map-card a{ font-size:.72rem; letter-spacing:.1em; text-transform:uppercase; color:var(--bay); }

/* ===================== TESTIMONIALS ===================== */
.quotes{ background:linear-gradient(180deg,var(--paper),var(--sand)); }
.quote-stage{ max-width:840px; margin:0 auto; overflow:hidden; }
.quote-track{ display:flex; transition:transform .7s var(--ease); }
.q-slide{ flex:0 0 100%; margin:0; text-align:center; padding:0 clamp(10px,4vw,50px); }
.q-slide p{ font-family:var(--serif); font-size:clamp(1.3rem,2.6vw,2rem); line-height:1.5; color:var(--bay-deep); font-weight:300; }
.q-slide cite{ display:block; font-style:normal; font-family:var(--sans); font-size:.78rem; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-soft); margin-top:24px; }
.q-stars{ display:block; color:var(--gold); letter-spacing:.2em; margin-top:12px; font-size:.9rem; }
.quote-nav{ display:flex; align-items:center; justify-content:center; gap:22px; margin-top:40px; }
.quote-nav button{ width:46px; height:46px; border-radius:50%; border:1px solid var(--line); background:#fff; cursor:pointer; font-size:1.3rem; color:var(--bay); transition:.3s; }
.quote-nav button:hover{ background:var(--bay); color:#fff; border-color:var(--bay); }
.quote-dots{ display:flex; gap:9px; }
.quote-dots span{ width:8px; height:8px; border-radius:50%; background:var(--line); cursor:pointer; transition:.3s; }
.quote-dots span.active{ background:var(--bay); transform:scale(1.3); }

/* ===================== ARTISTS ===================== */
.artists{ background:var(--paper); }
.art-masonry{ columns:3; column-gap:18px; margin-top:10px; }
.art-masonry figure{ break-inside:avoid; margin:0 0 18px; position:relative; overflow:hidden; border-radius:3px; background:var(--sand-2); cursor:pointer; }
.art-masonry img{ width:100%; transition:transform 1.1s ease, filter .6s; }
.art-masonry figure:hover img{ transform:scale(1.05); }
.art-masonry figcaption{ position:absolute; inset:auto 0 0 0; padding:34px 18px 14px; color:#fff; font-size:.78rem; letter-spacing:.04em; background:linear-gradient(transparent, rgba(13,32,42,.85)); opacity:0; transition:opacity .4s; }
.art-masonry figure:hover figcaption{ opacity:1; }
.art-roster{ display:flex; flex-wrap:wrap; gap:10px 14px; margin-top:40px; }
.art-roster span{ font-size:.82rem; color:var(--ink-soft); padding:7px 16px; border:1px solid var(--line); border-radius:40px; transition:.3s; }
.art-roster span:hover{ border-color:var(--bay); color:var(--bay); }
.poem{ font-family:var(--serif); font-style:italic; font-size:clamp(1.2rem,2vw,1.6rem); line-height:1.7; color:var(--bay-deep); max-width:620px; margin:54px auto 0; text-align:center; }
.poem cite{ display:block; font-style:normal; font-family:var(--sans); font-size:.8rem; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-soft); margin-top:20px; }

/* ===================== RESERVE ===================== */
.reserve{ background:var(--sand); }
.reserve-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(40px,6vw,84px); }
.reserve-info h2{ font-size:clamp(2rem,4vw,3.2rem); margin-bottom:1.2rem; }
.contact-list{ margin:32px 0 0; padding:0; list-style:none; }
.contact-list li{ display:flex; gap:16px; padding:16px 0; border-bottom:1px solid var(--line); align-items:flex-start; }
.contact-list .ic{ width:20px; flex:none; color:var(--bay); margin-top:3px; }
.contact-list .k{ font-size:.72rem; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-soft); display:block; margin-bottom:3px; }
.contact-list .v{ font-size:1.02rem; color:var(--ink); }
.contact-list a.v:hover{ color:var(--bay); }

.form{ background:#fff; padding:clamp(28px,3vw,44px); border-radius:6px; box-shadow:var(--shadow); }
.form h3{ font-size:1.5rem; margin-bottom:.4rem; }
.form .fnote{ font-size:.86rem; color:var(--ink-soft); margin:0 0 1.6rem; }
.field{ margin-bottom:18px; }
.field label{ font-size:.72rem; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-soft); display:block; margin-bottom:7px; }
.field input, .field textarea, .field select{
  width:100%; padding:13px 15px; border:1px solid var(--line); border-radius:3px; font-family:var(--sans);
  font-size:.96rem; color:var(--ink); background:var(--paper); transition:border .3s, box-shadow .3s;
}
.field input:focus, .field textarea:focus, .field select:focus{ outline:none; border-color:var(--bay); box-shadow:0 0 0 3px rgba(47,96,118,.12); }
.field-row{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.form .btn-solid{ width:100%; text-align:center; margin-top:6px; border:0; font-size:.82rem; }
.form-success{ display:none; padding:16px; background:rgba(47,96,118,.08); border-left:3px solid var(--bay); font-size:.92rem; color:var(--bay-deep); margin-top:14px; border-radius:2px; }

/* ===================== FOOTER ===================== */
.footer{ background:var(--bay-deep); color:rgba(255,255,255,.7); padding:70px 0 34px; }
.footer-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:40px; padding-bottom:48px; border-bottom:1px solid rgba(255,255,255,.12); }
.footer .name{ font-family:var(--serif); font-style:italic; font-size:1.9rem; color:#fff; }
.footer p{ font-size:.92rem; line-height:1.7; margin:.8rem 0 0; }
.footer h4{ font-family:var(--sans); font-size:.74rem; letter-spacing:.16em; text-transform:uppercase; color:var(--bay-light); margin:0 0 16px; }
.footer ul{ list-style:none; margin:0; padding:0; }
.footer ul li{ margin-bottom:10px; font-size:.92rem; }
.footer ul li a:hover{ color:#fff; }
.footer-bottom{ display:flex; justify-content:space-between; flex-wrap:wrap; gap:12px; padding-top:26px; font-size:.8rem; color:rgba(255,255,255,.5); }
.footer-bottom a{ color:rgba(255,255,255,.7); }
.footer-bottom a:hover{ color:#fff; }

/* ===================== LIGHTBOX ===================== */
.lightbox{ position:fixed; inset:0; z-index:9700; background:rgba(8,18,26,.94); backdrop-filter:blur(8px); display:flex; align-items:center; justify-content:center; opacity:0; visibility:hidden; transition:opacity .4s, visibility .4s; }
.lightbox.open{ opacity:1; visibility:visible; }
.lb-figure{ margin:0; max-width:88vw; max-height:84vh; text-align:center; }
.lb-figure img{ max-width:88vw; max-height:78vh; object-fit:contain; border-radius:3px; box-shadow:var(--shadow-lg); }
.lb-figure figcaption{ color:rgba(255,255,255,.8); font-size:.82rem; letter-spacing:.04em; margin-top:18px; }
.lb-close{ position:absolute; top:24px; right:30px; background:none; border:0; color:#fff; font-size:1.6rem; cursor:pointer; opacity:.8; transition:.3s; }
.lb-close:hover{ opacity:1; transform:rotate(90deg); }
.lb-arrow{ position:absolute; top:50%; transform:translateY(-50%); width:56px; height:56px; border-radius:50%; border:1px solid rgba(255,255,255,.3); background:rgba(255,255,255,.06); color:#fff; font-size:1.6rem; cursor:pointer; transition:.3s; }
.lb-arrow:hover{ background:rgba(255,255,255,.16); }
.lb-prev{ left:30px; } .lb-next{ right:30px; }
.lb-count{ position:absolute; bottom:26px; left:50%; transform:translateX(-50%); color:rgba(255,255,255,.6); font-size:.78rem; letter-spacing:.16em; }

/* ===================== RESPONSIVE ===================== */
@media (max-width:980px){
  .explorer{ grid-template-columns:1fr; }
  .planner{ grid-template-columns:1fr; }
  .getting-grid{ grid-template-columns:1fr; }
}
@media (max-width:1024px){
  .nav-links{
    position:fixed; inset:0 0 0 auto; width:min(82vw,340px); flex-direction:column; align-items:flex-start; justify-content:center;
    gap:26px; background:var(--paper); padding:60px var(--gutter); transform:translateX(100%); transition:transform .45s cubic-bezier(.4,0,.2,1);
    box-shadow:-20px 0 60px -30px rgba(0,0,0,.5);
  }
  .nav-links.open{ transform:translateX(0); }
  .nav-links a{ color:var(--ink-soft) !important; font-size:.95rem; }
  .nav-links .btn{ width:100%; text-align:center; }
  .nav-toggle{ display:block; }
}
@media (max-width:900px){
  .intro-grid{ grid-template-columns:1fr; }
  .intro-figure{ max-width:420px; }
  .reserve-grid{ grid-template-columns:1fr; }
  .art-masonry{ columns:2; }
  .band-bg::after{ background:linear-gradient(rgba(13,32,42,.5), rgba(13,32,42,.66)); }
  .gal-item.g-wide{ grid-column:span 12; }
  .gal-item.g-tall{ grid-column:span 6; grid-row:span 1; }
  .gal-item.g-std{ grid-column:span 6; }
  .gal-item.g-half{ grid-column:span 6; }
  /* disable pinned horizontal scroll on smaller screens — stack instead */
  .day{ height:auto; }
  .day-sticky{ position:relative; height:auto; }
  .day-track{ flex-direction:column; width:100%; transform:none !important; }
  .day-panel{ width:100%; height:86vh; min-height:520px; }
  .day-hint, .day-progress{ display:none; }
}
@media (max-width:560px){
  body{ font-size:16px; }
  .field-row{ grid-template-columns:1fr; }
  .art-masonry{ columns:1; }
  .footer-grid{ grid-template-columns:1fr; gap:30px; }
  .rate-table{ font-size:.84rem; }
  .gal-item.g-wide,.gal-item.g-tall,.gal-item.g-std,.gal-item.g-half{ grid-column:span 12; grid-row:span 1; aspect-ratio:4/3; }
  .intro-figure .tag{ left:0; }
  .ex-list li{ padding:14px 16px; }
  .quote-nav button{ width:42px; height:42px; }
}
@media (prefers-reduced-motion:reduce){
  *{ animation:none !important; transition-duration:.01ms !important; }
  [data-reveal]{ opacity:1 !important; transform:none !important; }
  .split-word{ transform:none !important; }
  .reveal-img img{ transform:none !important; clip-path:none !important; }
  html{ scroll-behavior:auto; }
  .day{ height:auto; }
  .day-sticky{ position:relative; height:auto; }
  .day-track{ flex-direction:column; width:100%; transform:none !important; }
  .day-panel{ width:100%; height:86vh; min-height:480px; }
}
