/* ============================================================
   ЛУНА · Лунная дорожка — restaurant complex, Nakhodka
   Vanilla cinematic build. Mobile-first, progressive enhancement.
   ============================================================ */

:root{
  /* palette */
  --bg:#06070d;
  --bg-deep:#03040a;
  --panel:#0b0e18;
  --ink:#0c0f1a;
  --ink-soft:#141826;
  --moon:#eef0f4;
  --moon-warm:#f7f1e4;
  --silver:#9fb2c4;
  --silver-dim:#8493a8;
  --gold:#c9a24b;
  --gold-soft:#8a6f3a;
  --line:#1c2334;
  --line-soft:rgba(159,178,196,.14);

  /* type */
  --display:"Prata",Georgia,serif;
  --ital:"Playfair Display",Georgia,serif;
  --accent:"Forum","Prata",serif;
  --body:"Manrope",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;

  /* spacing rhythm */
  --section-pad:clamp(6rem,12vw,13rem);
  --gutter:max(clamp(1.4rem,5vw,7rem), env(safe-area-inset-left), env(safe-area-inset-right));
  --maxw:1320px;

  /* easings */
  --ease-moon:cubic-bezier(.16,1,.3,1);
  --ease-tide:cubic-bezier(.7,0,.2,1);
  --ease-micro:cubic-bezier(.22,.61,.36,1);
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
html.js.lenis{scroll-behavior:auto}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}

body{
  margin:0;
  background:var(--bg);
  color:var(--silver);
  font-family:var(--body);
  font-weight:300;
  font-size:clamp(1rem,.55rem + .55vw,1.16rem);
  line-height:1.72;
  letter-spacing:.005em;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
main{overflow:clip}
img,svg,canvas{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
::selection{background:rgba(201,162,75,.28);color:var(--moon)}

/* page base gradient so no-JS still feels like deep sea + sky */
body::before{
  content:"";position:fixed;inset:0;z-index:-3;pointer-events:none;
  background:
    radial-gradient(120% 80% at 72% 8%, rgba(64,78,104,.34), transparent 46%),
    radial-gradient(140% 120% at 50% 120%, rgba(5,8,16,.9), transparent 55%),
    linear-gradient(180deg,#070912 0%, var(--bg) 38%, var(--bg-deep) 100%);
}

.display{font-family:var(--display);font-weight:400;letter-spacing:.005em;line-height:1.04;color:var(--moon)}
.ital{font-family:var(--ital);font-style:italic;font-weight:400}

/* ---------- shared bits ---------- */
.eyebrow{
  font-family:var(--accent);
  font-size:.72rem;letter-spacing:.34em;text-transform:uppercase;
  color:var(--silver-dim);margin:0 0 1.4rem;
  display:flex;align-items:center;gap:.9em;
}
.eyebrow::before{content:"";width:clamp(18px,3vw,40px);height:1px;background:linear-gradient(90deg,var(--gold-soft),transparent)}

.layer{position:fixed;inset:0;pointer-events:none}
.layer--stars{z-index:-2}
.layer--vignette{
  z-index:1;
  background:radial-gradient(120% 100% at 50% 42%, transparent 52%, rgba(3,4,10,.55) 86%, var(--bg-deep) 100%);
}
.layer--grain{z-index:2;width:100%;height:100%;opacity:.05;mix-blend-mode:overlay}
.svg-defs{position:absolute}

/* ---------- buttons ---------- */
/* CTAs are emphasized text links — no fill, no border, no pill */
.btn{
  position:relative;display:inline-flex;align-items:center;gap:.55em;
  font-family:var(--body);font-weight:500;font-size:.98rem;letter-spacing:.005em;
  color:var(--moon);background:transparent;border:0;padding:.3em 0;cursor:pointer;
  -webkit-tap-highlight-color:transparent;transition:color .4s var(--ease-moon),opacity .3s}
.btn::after{content:"";position:absolute;left:0;right:0;bottom:.04em;height:1px;
  background:linear-gradient(90deg,var(--gold) 45%,rgba(201,162,75,.18));
  opacity:.4;transition:opacity .45s var(--ease-moon)}
.btn:hover{color:var(--moon-warm)}
.btn:hover::after{opacity:1}
.btn:active{opacity:.7}
.btn:disabled{opacity:.4;cursor:default}
.btn__chip{display:inline-flex;align-items:center;justify-content:center;
  width:1.05em;height:1.05em;color:var(--gold);background:none;border:0;
  transition:transform .45s var(--ease-micro)}
.btn__chip svg{width:1em;height:1em}
.btn:hover .btn__chip{transform:translateX(4px)}
.btn--lg{font-size:1.12rem;gap:.6em}
.btn--block{align-self:flex-start;justify-self:start}

.link-gold{color:var(--gold);font-weight:500;letter-spacing:.02em;
  border-bottom:1px solid rgba(201,162,75,.3);padding-bottom:.15em;transition:border-color .4s,color .4s}
.link-gold:hover{color:var(--moon-warm);border-color:var(--gold)}

/* keyboard focus visibility on the dark canvas */
a:focus-visible,.btn:focus-visible,.star:focus-visible,.phases__item:focus-visible,
.nav__links a:focus-visible,.menu__links a:focus-visible,.link-gold:focus-visible,
.contacts__v a:focus-visible,.footer__col a:focus-visible,.nav__burger:focus-visible{
  outline:2px solid var(--gold);outline-offset:3px;border-radius:3px}
:focus:not(:focus-visible){outline:none}

/* skip link */
.skip{position:fixed;left:50%;top:0;translate:-50% -120%;z-index:80;
  background:var(--panel);color:var(--moon);border:1px solid var(--gold);
  padding:.7em 1.2em;border-radius:0 0 12px 12px;font-size:.85rem;
  transition:translate .3s var(--ease-moon)}
.skip:focus{translate:-50% 0}

/* required-field marker */
.req{color:var(--gold);margin-left:.25em;font-size:.85em;vertical-align:.05em}

/* ============================================================
   NAV
   ============================================================ */
.nav{position:fixed;top:0;left:0;right:0;z-index:40;
  padding:max(clamp(.7rem,2vw,1.4rem),env(safe-area-inset-top)) var(--gutter) clamp(.7rem,2vw,1.4rem);
  transition:transform .6s var(--ease-moon), background .6s, backdrop-filter .6s}
.nav--hidden{transform:translateY(-130%)}
.nav__inner{
  max-width:var(--maxw);margin:0 auto;display:flex;align-items:center;gap:1.4rem;
  padding:.55rem .65rem .55rem 1.3rem;border-radius:999px;
  border:1px solid transparent;transition:border-color .6s, background .6s, box-shadow .6s;
}
.nav--solid .nav__inner{
  border-color:var(--line-soft);
  background:rgba(8,10,18,.55);
  backdrop-filter:blur(16px) saturate(120%);
  -webkit-backdrop-filter:blur(16px) saturate(120%);
  box-shadow:0 18px 50px -30px rgba(0,0,0,.9), inset 0 1px 0 rgba(255,255,255,.04);
}
.nav__brand{display:flex;align-items:center;gap:.6em;margin-right:auto;font-family:var(--accent);
  font-size:1.05rem;letter-spacing:.42em;text-indent:.42em;color:var(--moon)}
.nav__moon{width:.92em;height:.92em;border-radius:50%;
  background:radial-gradient(circle at 35% 32%, #fff, var(--moon) 42%, #aeb8cb 78%, #7d8aa0);
  box-shadow:0 0 16px rgba(238,240,244,.34), inset -2px -2px 4px rgba(0,0,0,.3)}
.nav__links{display:flex;gap:clamp(1rem,2vw,2.1rem)}
.nav__links a{font-size:.83rem;letter-spacing:.05em;color:var(--silver);position:relative;padding:.2em 0;transition:color .4s}
.nav__links a::after{content:"";position:absolute;left:0;right:100%;bottom:-2px;height:1px;
  background:var(--gold);transition:right .45s var(--ease-moon)}
.nav__links a:hover{color:var(--moon)}
.nav__links a:hover::after{right:0}
.nav__cta{flex:0 0 auto}
.nav__burger{display:none;width:44px;height:44px;border:1px solid var(--line-soft);border-radius:50%;
  background:rgba(10,12,20,.4);position:relative;cursor:pointer}
.nav__burger span{position:absolute;left:50%;top:50%;width:16px;height:1.4px;background:var(--moon);
  transition:transform .5s var(--ease-moon),opacity .3s;translate:-50% -50%}
.nav__burger span:first-child{translate:-50% calc(-50% - 4px)}
.nav__burger span:last-child{translate:-50% calc(-50% + 4px)}
.menu-open .nav__burger span:first-child{translate:-50% -50%;transform:rotate(45deg)}
.menu-open .nav__burger span:last-child{translate:-50% -50%;transform:rotate(-45deg)}

/* full-screen menu */
.menu{position:fixed;inset:0;z-index:38;display:flex;flex-direction:column;justify-content:center;
  padding:max(var(--gutter),env(safe-area-inset-top)) var(--gutter) max(var(--gutter),env(safe-area-inset-bottom));
  gap:2rem;overflow-y:auto;-webkit-overflow-scrolling:touch;
  background:rgba(4,5,12,.78);backdrop-filter:blur(26px);-webkit-backdrop-filter:blur(26px);
  opacity:0;visibility:hidden;transition:opacity .6s var(--ease-moon),visibility .6s}
.menu-open .menu{opacity:1;visibility:visible}
.menu__links{display:flex;flex-direction:column;gap:.2rem}
.menu__links a{font-family:var(--display);font-size:clamp(2.1rem,9vw,3.6rem);color:var(--moon);
  display:flex;align-items:baseline;gap:.6rem;padding:.2em 0;
  opacity:0;transform:translateY(28px);transition:transform .7s var(--ease-moon),opacity .7s,color .4s}
.menu-open .menu__links a{opacity:1;transform:none}
.menu-open .menu__links a:nth-child(1){transition-delay:.08s}
.menu-open .menu__links a:nth-child(2){transition-delay:.14s}
.menu-open .menu__links a:nth-child(3){transition-delay:.2s}
.menu-open .menu__links a:nth-child(4){transition-delay:.26s}
.menu-open .menu__links a:nth-child(5){transition-delay:.32s}
.menu__links a:hover{color:var(--gold)}
.menu__idx{font-family:var(--accent);font-size:.7rem;letter-spacing:.3em;color:var(--gold)}
.menu__foot{display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;
  font-family:var(--accent);letter-spacing:.18em;text-transform:uppercase;font-size:.75rem;color:var(--silver-dim);
  border-top:1px solid var(--line-soft);padding-top:1.4rem}

/* ---------- right phase nav ---------- */
.phases{position:fixed;right:clamp(1rem,2vw,1.9rem);top:50%;transform:translateY(-50%);z-index:30;
  display:flex;flex-direction:column;gap:1.05rem;align-items:center}
.phases__item{position:relative;width:15px;height:15px;cursor:pointer;border:0;background:transparent;padding:0;
  display:grid;place-items:center}
.phases__disc{width:11px;height:11px;border-radius:50%;border:1px solid var(--silver-dim);
  background:radial-gradient(circle at 32% 30%, var(--moon), #aeb8cb 60%, #59657a);
  transition:transform .5s var(--ease-moon),box-shadow .5s;position:relative;overflow:hidden}
.phases__disc::after{content:"";position:absolute;inset:0;background:var(--bg-deep);
  transform:translateX(var(--shadow,40%));transition:transform .6s var(--ease-tide)}
.phases__item:hover .phases__disc{transform:scale(1.25)}
.phases__item.is-active .phases__disc{box-shadow:0 0 0 1px var(--gold),0 0 14px rgba(201,162,75,.5);transform:scale(1.25)}
.phases__tip{position:absolute;right:24px;top:50%;translate:0 -50%;white-space:nowrap;
  font-family:var(--accent);text-transform:uppercase;letter-spacing:.2em;font-size:.66rem;color:var(--silver);
  opacity:0;transform:translateX(8px);transition:.4s var(--ease-moon);pointer-events:none}
.phases__item:hover .phases__tip,.phases__item.is-active .phases__tip{opacity:1;transform:none}

/* scroll progress hairline */
.scroll-progress{position:fixed;left:0;top:0;height:2px;width:100%;z-index:45;transform:scaleX(0);transform-origin:0 50%;
  background:linear-gradient(90deg,var(--gold-soft),var(--gold));opacity:.85;pointer-events:none}

/* custom luminous cursor (desktop fine-pointer only, enhancement) */
.cursor{position:fixed;top:0;left:0;width:30px;height:30px;border-radius:50%;z-index:60;
  margin:-15px 0 0 -15px;pointer-events:none;opacity:0;mix-blend-mode:screen;
  background:radial-gradient(circle, rgba(238,240,244,.5), rgba(159,178,196,.12) 45%, transparent 70%);
  transition:opacity .4s, width .35s var(--ease-micro), height .35s var(--ease-micro)}
html.fine-pointer.cursor-on .cursor{opacity:1}
html.fine-pointer.cursor-on.cursor-mag .cursor{width:64px;height:64px;margin:-32px 0 0 -32px;
  background:radial-gradient(circle, rgba(201,162,75,.3), rgba(201,162,75,.08) 50%, transparent 72%)}

/* ============================================================
   reveal system (gated so no-JS / reduced-motion always show content)
   ============================================================ */
html.js:not(.reduce-motion) [data-reveal]{opacity:0;transform:translateY(30px);filter:blur(7px);
  transition:opacity .9s var(--ease-moon),transform 1s var(--ease-moon),filter .9s var(--ease-moon)}
html.js:not(.reduce-motion) [data-reveal].is-in{opacity:1;transform:none;filter:none}
html.js:not(.reduce-motion) [data-lines] .line{display:block;overflow:hidden}
html.js:not(.reduce-motion) [data-lines] .line > span,
html.js:not(.reduce-motion) [data-lines] .line{}
html.js:not(.reduce-motion) [data-lines] .line{opacity:0;transform:translateY(110%);
  transition:opacity .9s var(--ease-moon),transform 1.1s var(--ease-moon)}
html.js:not(.reduce-motion) [data-lines].is-in .line{opacity:1;transform:none}
html.js:not(.reduce-motion) [data-lines].is-in .line:nth-child(2){transition-delay:.12s}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;min-height:100svh;min-height:100dvh;display:flex;flex-direction:column;
  justify-content:center;padding:clamp(7rem,16vh,10rem) var(--gutter) clamp(5rem,11vh,7.5rem);isolation:isolate;overflow:hidden}
.hero__water{position:absolute;inset:0;width:100%;height:100%;z-index:-1}
/* CSS fallback moonlight path (visible without JS canvas) */
.hero::after{content:"";position:absolute;inset:0;z-index:-1;pointer-events:none;
  background:
    radial-gradient(60% 40% at 72% 22%, rgba(238,240,244,.12), transparent 60%),
    linear-gradient(180deg, transparent 52%, rgba(8,11,20,.4) 64%, rgba(3,4,10,.92) 100%);
  -webkit-mask:linear-gradient(#000,#000);mask:linear-gradient(#000,#000)}
html.js .hero::after{opacity:.55}
/* when the WebGL shader runs it draws sky + moon + water itself: drop CSS/SVG fallbacks */
html.has-webgl .hero::after{display:none}
html.has-webgl .scene{display:none}

.scene{position:absolute;inset:0;z-index:-1;pointer-events:none;overflow:hidden}
.moon{position:absolute;top:clamp(4%,7vh,11%);right:clamp(6%,12vw,16%);
  width:clamp(150px,26vw,360px);aspect-ratio:1;
  filter:drop-shadow(0 0 34px rgba(243,238,224,.24)) drop-shadow(0 0 80px rgba(205,214,230,.12))}
.moon__svg{width:100%;height:100%;overflow:visible}
/* moon stays present at rest (entrance carried by stars + water) so it can never freeze hidden */

.coast{position:absolute;left:0;right:0;bottom:0;width:100%;height:clamp(120px,26vh,260px)}
.coast__hill{fill:#080b14}
.coast__hill--far{fill:#0a0e1a;opacity:.85}
.coast__hill--near{fill:#05070e}
.win{fill:var(--gold);opacity:.85;filter:drop-shadow(0 0 3px rgba(201,162,75,.8))}
html.js:not(.reduce-motion) .win{opacity:0}
html.js:not(.reduce-motion) .hero.is-ready .win{opacity:.85;transition:opacity 1.2s var(--ease-moon)}
html.js:not(.reduce-motion) .hero.is-ready .win:nth-child(2){transition-delay:.5s}
html.js:not(.reduce-motion) .hero.is-ready .win:nth-child(3){transition-delay:.9s}
html.js:not(.reduce-motion) .hero.is-ready .win:nth-child(5){transition-delay:.7s}
html.js:not(.reduce-motion) .hero.is-ready .win:nth-child(7){transition-delay:1.1s}
.lightbeam{fill:var(--gold);filter:drop-shadow(0 0 6px var(--gold))}
html:not(.reduce-motion) .lightbeam{animation:beacon 4.2s var(--ease-tide) infinite}
@keyframes beacon{0%,72%,100%{opacity:.25;r:2.6px}82%{opacity:1;r:4px}}

.hero__content{position:relative;max-width:var(--maxw);width:100%;margin:0 auto}
.hero__eyebrow{margin:0 0 clamp(1.8rem,3.6vh,2.7rem)}
.hero__eyebrow span{display:inline-block}
.hero__title{font-family:var(--display);color:var(--moon);margin:0;position:relative;
  font-size:clamp(4.6rem,23vw,20rem);line-height:.95;letter-spacing:.01em;
  text-shadow:0 0 70px rgba(238,240,244,.16)}
.hero__title-reflect{position:absolute;left:0;top:100%;transform:translateY(100%) scaleY(-1);transform-origin:top;
  -webkit-mask:linear-gradient(180deg,rgba(0,0,0,.32),transparent 44%);
  mask:linear-gradient(180deg,rgba(0,0,0,.32),transparent 44%);
  opacity:.15;pointer-events:none;filter:blur(1.6px)}
.hero__sub{font-size:clamp(1.05rem,1.9vw,1.6rem);color:var(--moon);font-weight:300;max-width:30ch;
  margin:1.6rem 0 0;line-height:1.42}
.hero__sub .ital{color:var(--silver)}
.hero__actions{display:flex;flex-wrap:wrap;gap:1rem;margin-top:2.4rem}
.hero__cuesub{font-family:var(--accent);letter-spacing:.16em;text-transform:uppercase;font-size:.72rem;
  color:var(--silver-dim);margin-top:1.8rem}
.hero__coords{position:absolute;left:var(--gutter);bottom:clamp(1rem,3vh,2rem);z-index:1;
  font-family:var(--accent);letter-spacing:.32em;text-transform:uppercase;font-size:.64rem;color:var(--silver-dim);
  writing-mode:horizontal-tb}
.hero__scroll{position:absolute;right:var(--gutter);bottom:clamp(1rem,3vh,2rem);z-index:1;
  display:flex;flex-direction:column;align-items:center;gap:.7rem;color:var(--silver-dim);
  font-family:var(--accent);letter-spacing:.28em;text-transform:uppercase;font-size:.6rem}
.hero__scroll-line{width:1px;height:46px;background:linear-gradient(var(--silver-dim),transparent);overflow:hidden;position:relative}
.hero__scroll-line::after{content:"";position:absolute;top:0;left:0;width:100%;height:40%;background:var(--gold)}
html:not(.reduce-motion) .hero__scroll-line::after{animation:scrolldrop 2.4s var(--ease-tide) infinite}
@keyframes scrolldrop{0%{transform:translateY(-100%)}60%,100%{transform:translateY(260%)}}
.hero__coords,.hero__scroll{opacity:0}
html.js:not(.reduce-motion) .hero.is-ready .hero__coords,
html.js:not(.reduce-motion) .hero.is-ready .hero__scroll{opacity:1;transition:opacity 1.4s 1s var(--ease-moon)}
html:not(.js) .hero__coords,html:not(.js) .hero__scroll,html.reduce-motion .hero__coords,html.reduce-motion .hero__scroll{opacity:1}

/* ============================================================
   MANIFESTO
   ============================================================ */
.manifesto{position:relative;padding:var(--section-pad) var(--gutter);overflow:hidden}
.manifesto__inner{max-width:var(--maxw);margin:0 auto;max-width:1100px}
.manifesto__title{font-size:clamp(2.4rem,6vw,5.4rem);margin:.4rem 0 0;max-width:16ch}
.manifesto__lead{font-size:clamp(1.2rem,2.4vw,1.9rem);color:var(--silver);margin:1.8rem 0 0;max-width:30ch;line-height:1.4}
.manifesto__body{margin-top:clamp(2.6rem,6vw,4.5rem);max-width:60ch;display:flex;flex-direction:column;gap:1.5rem}
.manifesto__body p{margin:0;color:var(--silver)}
.pullquote{font-family:var(--ital);font-style:italic;font-size:clamp(1.5rem,3.4vw,2.7rem);
  color:var(--moon);line-height:1.34;margin:clamp(3rem,7vw,5rem) 0 0;max-width:24ch;border:0;padding:0;position:relative}
.pullquote::before{content:"";display:block;width:54px;height:1px;background:linear-gradient(90deg,var(--gold),transparent);margin-bottom:1.6rem}
/* "diamond ring" flash at hero->manifesto seam */
.ring{position:absolute;left:50%;top:-2px;width:min(86vw,920px);height:240px;translate:-50% -50%;z-index:0;pointer-events:none;
  opacity:0;background:
    radial-gradient(closest-side, rgba(255,250,235,.85), rgba(201,162,75,.32) 36%, rgba(201,162,75,0) 70%);
  filter:blur(6px);mix-blend-mode:screen}
.ring::before{content:"";position:absolute;left:50%;top:50%;translate:-50% -50%;width:170px;height:170px;border-radius:50%;
  border:1px solid rgba(238,240,244,.55);box-shadow:0 0 22px rgba(201,162,75,.5);opacity:.9}
.ring::after{content:"";position:absolute;left:50%;top:50%;translate:-50% -50%;width:14px;height:14px;border-radius:50%;
  background:radial-gradient(circle,#fff,rgba(255,244,214,.8) 45%,transparent 72%);box-shadow:0 0 26px 6px rgba(255,248,228,.7)}

/* ============================================================
   CUISINE — horizontal track
   ============================================================ */
.cuisine{position:relative;padding:var(--section-pad) 0;overflow:hidden}
.cuisine__smoke{position:absolute;inset:0;width:100%;height:100%;z-index:0;opacity:.5;pointer-events:none}
.cuisine__head{max-width:var(--maxw);margin:0 auto;padding:0 var(--gutter);position:relative;z-index:1}
.cuisine__title{font-size:clamp(2.4rem,6.4vw,5.6rem);margin:.4rem 0 0}
.cuisine__sub{max-width:42ch;margin:1.6rem 0 0;color:var(--silver)}
.cuisine__hint{font-family:var(--accent);letter-spacing:.28em;text-transform:uppercase;font-size:.68rem;
  color:var(--gold);margin-top:2rem}
.track{position:relative;z-index:1;margin-top:clamp(2.5rem,6vw,5rem);overflow-x:auto;overflow-y:hidden;
  scrollbar-width:none;-webkit-overflow-scrolling:touch;scroll-snap-type:x proximity}
.track::-webkit-scrollbar{display:none}
.track__rail{display:flex;align-items:flex-start;gap:clamp(1.5rem,4vw,4rem);
  padding:6vh var(--gutter);width:max-content}
.dish{position:relative;flex:0 0 auto;width:min(80vw,360px);scroll-snap-align:center;
  transform:translateY(var(--y,0))}
.dish__meta{font-family:var(--accent);letter-spacing:.2em;text-transform:uppercase;font-size:.66rem;color:var(--silver)}
.dish__name{font-size:clamp(1.8rem,3.4vw,2.7rem);margin:.7rem 0 0;line-height:1.06}
.dish__rule{display:block;height:1px;width:0;background:linear-gradient(90deg,var(--gold),transparent);margin:1.1rem 0;
  transition:width 1s var(--ease-moon)}
.dish.is-in .dish__rule,.dish:hover .dish__rule{width:100%}
html:not(.js) .dish__rule,html.reduce-motion .dish__rule{width:72%}
.dish__desc{color:var(--silver);font-size:.96rem;line-height:1.62;max-width:34ch}
.dish::before{content:"";position:absolute;inset:-14% -10%;z-index:-1;border-radius:50%;
  background:radial-gradient(closest-side, rgba(201,162,75,.12), transparent 72%);
  opacity:0;transition:opacity .6s var(--ease-moon)}
.dish:hover::before{opacity:1}
.dish--note{display:flex;flex-direction:column;gap:1.4rem;justify-content:center;width:min(78vw,330px)}
.dish--note p{font-size:1.2rem;color:var(--moon);line-height:1.45;margin:0}
html.js:not(.reduce-motion) .cuisine.is-pinned .track{overflow:visible}
html.js:not(.reduce-motion) .cuisine.is-cuisine-active .track__rail{will-change:transform}
html.js:not(.reduce-motion) .cuisine.is-pinned .dish{opacity:.001;filter:blur(12px);transition:opacity .8s var(--ease-moon),filter .8s var(--ease-moon)}
html.js:not(.reduce-motion) .cuisine.is-pinned .dish.is-in{opacity:1;filter:none}

/* ============================================================
   HALLS — constellation
   ============================================================ */
.halls{position:relative;padding:var(--section-pad) var(--gutter)}
.halls__head{max-width:var(--maxw);margin:0 auto}
.halls__title{font-size:clamp(2.2rem,5.6vw,4.8rem);margin:.4rem 0 0}
.halls__sub{max-width:40ch;margin:1.6rem 0 0;color:var(--silver)}
.halls__map{position:relative;max-width:var(--maxw);margin:clamp(2.5rem,5vw,4.5rem) auto 0;
  aspect-ratio:1000/560;min-height:340px}
.constellation{position:absolute;inset:0;width:100%;height:100%;overflow:visible}
.cn-line{fill:none;stroke:var(--silver);stroke-width:1;stroke-opacity:.4;
  stroke-dasharray:1;stroke-dashoffset:1}
html.js:not(.reduce-motion) .cn-line{stroke-dasharray:var(--len);stroke-dashoffset:var(--len);
  transition:stroke-dashoffset 1.6s var(--ease-tide)}
html.js:not(.reduce-motion) .halls__map.is-in .cn-line{stroke-dashoffset:0}
.star{position:absolute;left:var(--sx);top:var(--sy);translate:-50% -50%;
  background:transparent;border:0;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:.6rem;z-index:2}
.star__dot{width:13px;height:13px;border-radius:50%;
  background:radial-gradient(circle at 34% 32%, #fff, var(--moon) 50%, #8893a8);
  box-shadow:0 0 0 5px rgba(159,178,196,.08),0 0 16px rgba(238,240,244,.4);
  transition:box-shadow .5s var(--ease-moon),transform .5s var(--ease-moon)}
.star__label{font-family:var(--accent);letter-spacing:.2em;text-transform:uppercase;font-size:.66rem;color:var(--silver);
  transition:color .4s;white-space:nowrap}
.star:hover .star__dot,.star.is-active .star__dot{transform:scale(1.35);
  box-shadow:0 0 0 6px rgba(201,162,75,.12),0 0 22px rgba(201,162,75,.7);
  background:radial-gradient(circle at 34% 32%, #fff, var(--gold-soft) 70%, var(--gold))}
.star:hover .star__label,.star.is-active .star__label{color:var(--gold)}
html:not(.reduce-motion) .star.is-active .star__dot{animation:starpulse 2.6s var(--ease-tide) infinite}
@keyframes starpulse{0%,100%{box-shadow:0 0 0 6px rgba(201,162,75,.1),0 0 18px rgba(201,162,75,.55)}
  50%{box-shadow:0 0 0 9px rgba(201,162,75,.04),0 0 30px rgba(201,162,75,.85)}}
.halls__readout{position:absolute;left:0;bottom:0;max-width:32ch;padding:1.6rem 1.8rem;
  border-left:1px solid var(--line-soft);background:linear-gradient(180deg,transparent,rgba(11,14,24,.4));
  transition:opacity .5s}
.halls__readout h3{font-size:clamp(1.6rem,3vw,2.4rem);margin:0}
.halls__readout-meta{font-family:var(--accent);letter-spacing:.18em;text-transform:uppercase;font-size:.66rem;
  color:var(--silver);margin:.7rem 0 .9rem}
.halls__readout-desc{color:var(--silver);font-size:.95rem;line-height:1.62;margin:0}
/* fallback list (hidden when JS map active) */
.halls__list{list-style:none;margin:clamp(2rem,5vw,4rem) 0 0;padding:0;display:grid;gap:2rem;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}
.halls__list h3{font-size:1.5rem;margin:0}
.halls__list span{display:block;font-family:var(--accent);letter-spacing:.16em;text-transform:uppercase;
  font-size:.64rem;color:var(--silver);margin:.6rem 0 .8rem}
.halls__list p{margin:0;color:var(--silver);font-size:.94rem}
html.js .halls__map{display:block}
html.js .halls__list{display:none}
html:not(.js) .halls__map{display:none}
/* mid screens: lift the readout out of the absolute corner so it can't collide with a star */
@media (max-width:1000px){
  .halls__map{aspect-ratio:auto;min-height:0}
  .constellation{position:relative;height:clamp(300px,52vw,440px)}
  .halls__readout{position:static;left:auto;bottom:auto;max-width:none;margin-top:clamp(1.4rem,4vw,2.4rem);
    background:none;border-left:1px solid var(--line-soft)}
}
/* small screens: the constellation can't stay legible — show the accessible list instead */
@media (max-width:768px){
  html.js .halls__map{display:none}
  html.js .halls__list{display:block}
}

/* ============================================================
   ATMOSPHERE
   ============================================================ */
.atmos{position:relative;padding:var(--section-pad) var(--gutter);overflow:hidden;min-height:90vh;display:flex;align-items:center}
.atmos__scene{position:absolute;inset:0;z-index:0;pointer-events:none}
.atmos__building{position:absolute;right:clamp(3%,6vw,9%);bottom:17%;width:min(30vw,360px);height:60%;
  background:linear-gradient(180deg,#0a0e1a 0%,#070a12 70%,#05070e);border-radius:5px 5px 0 0;
  box-shadow:0 0 1px rgba(159,178,196,.18);
  -webkit-mask:linear-gradient(180deg,#000 78%,transparent);mask:linear-gradient(180deg,#000 78%,transparent);opacity:.92}
.atmos__windows{position:absolute;inset:10% 13% 16%;display:grid;
  grid-template-columns:repeat(5,1fr);grid-auto-rows:1fr;gap:clamp(7px,1vw,13px)}
.atmos__windows i{display:block;border-radius:.5px;background:rgba(206,170,96,.95);
  box-shadow:0 0 7px rgba(201,162,75,.55);opacity:.1}
html.js:not(.reduce-motion) .atmos__windows i{opacity:.04}
html.js:not(.reduce-motion) .atmos.is-in .atmos__windows i{opacity:var(--on,.8);transition:opacity 1.2s var(--ease-moon)}
html.reduce-motion .atmos__windows i,html:not(.js) .atmos__windows i{opacity:var(--on,.55)}
.atmos__reflection{position:absolute;right:clamp(3%,6vw,9%);bottom:0;width:min(30vw,360px);height:17%;
  background:radial-gradient(70% 130% at 50% 0%, rgba(201,162,75,.22), transparent 72%);
  filter:url(#seaShimmer);opacity:.75;
  -webkit-mask:linear-gradient(180deg,#000,transparent);mask:linear-gradient(180deg,#000,transparent)}
html.reduce-motion .atmos__reflection{filter:none}
.atmos__inner{position:relative;z-index:1;max-width:var(--maxw);margin:0 auto;width:100%}
.atmos__title{font-size:clamp(2.2rem,5.6vw,4.8rem);margin:.4rem 0 0;max-width:18ch}
.atmos__sub{font-size:clamp(1.1rem,2vw,1.5rem);color:var(--silver);margin:1.4rem 0 0}
.atmos__body{margin-top:clamp(2.4rem,5vw,4rem);max-width:56ch;display:flex;flex-direction:column;gap:1.4rem}
.atmos__body p{margin:0;color:var(--silver)}
.soundwave{display:flex;align-items:flex-end;gap:5px;height:46px;margin:2.6rem 0 0}
.soundwave i{width:3px;border-radius:3px;background:linear-gradient(180deg,var(--silver),transparent);opacity:.5;
  height:30%}
html:not(.reduce-motion) .soundwave i{animation:sw 1.6s var(--ease-tide) infinite alternate}
@keyframes sw{from{height:14%}to{height:100%}}
.atmos__quote{font-size:clamp(1.4rem,3vw,2.3rem);color:var(--moon);margin:2.6rem 0 0;max-width:24ch;line-height:1.36}
.atmos__stat{display:flex;align-items:baseline;gap:1.4rem;margin-top:3rem;flex-wrap:wrap}
.atmos__stat-num{font-size:clamp(3rem,8vw,6rem);color:var(--gold);line-height:1}
.atmos__stat-label{max-width:24ch;color:var(--silver);font-size:.95rem}

/* ============================================================
   EVENTS
   ============================================================ */
.events{position:relative;padding:var(--section-pad) var(--gutter)}
.events__head{max-width:var(--maxw);margin:0 auto}
.events__title{font-size:clamp(2.2rem,5.6vw,4.8rem);margin:.4rem 0 0}
.events__sub{max-width:48ch;margin:1.6rem 0 0;color:var(--silver)}
.events__grid{max-width:var(--maxw);margin:clamp(2.6rem,6vw,4.6rem) auto 0;
  display:grid;gap:clamp(1.6rem,3vw,3rem);grid-template-columns:repeat(auto-fit,minmax(280px,1fr));align-items:start}
.format{position:relative;padding:2.2rem 0 0;border-top:1px solid var(--line-soft)}
.format--offset{transform:translateY(0)}
.format__phase{display:block;width:46px;height:46px;border-radius:50%;margin-bottom:1.6rem;position:relative;overflow:hidden;
  border:1px solid var(--line);background:radial-gradient(circle at 34% 32%, #2a3040, #0b0e18)}
.format__phase::after{content:"";position:absolute;inset:0;border-radius:50%;
  background:radial-gradient(circle at 38% 34%, var(--moon), #8893a8 70%);
  -webkit-mask:linear-gradient(90deg,#000 var(--lit,18%),transparent var(--lit,18%));
  mask:linear-gradient(90deg,#000 var(--lit,18%),transparent var(--lit,18%));transition:--lit 1.2s var(--ease-tide)}
@property --lit{syntax:"<percentage>";inherits:false;initial-value:18%}
html.js:not(.reduce-motion) .format.is-lit .format__phase::after{--lit:100%}
html:not(.js) .format__phase::after,html.reduce-motion .format__phase::after{--lit:86%}
.format__name{font-size:clamp(1.7rem,3vw,2.4rem);margin:0}
.format__meta{display:block;font-family:var(--accent);letter-spacing:.16em;text-transform:uppercase;
  font-size:.64rem;color:var(--silver);margin:.9rem 0 1.2rem}
.format__desc{margin:0;color:var(--silver);font-size:.95rem;line-height:1.64}
@media (min-width:780px){
  .events__grid > .format:nth-child(2){transform:translateY(clamp(1.6rem,4vw,3.4rem))}
  .events__grid > .format:nth-child(3){transform:translateY(clamp(3.2rem,8vw,6.8rem))}
}

.tide{max-width:var(--maxw);margin:clamp(3rem,7vw,5.5rem) auto 0}
.tide__head{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:1rem}
.tide__head .eyebrow{margin:0}
.tide__caption{font-family:var(--accent);letter-spacing:.16em;text-transform:uppercase;font-size:.66rem;color:var(--silver)}
.tide__svg{width:100%;height:90px;margin-top:1.4rem;overflow:visible}
.tide__wave{stroke:var(--silver);stroke-width:1.3;stroke-opacity:.55;
  stroke-dasharray:var(--len,2600);stroke-dashoffset:var(--len,2600)}
html.js:not(.reduce-motion) .tide.is-in .tide__wave{transition:stroke-dashoffset 2.2s var(--ease-tide);stroke-dashoffset:0}
html:not(.js) .tide__wave,html.reduce-motion .tide__wave{stroke-dashoffset:0}
.tide__now{fill:var(--gold);filter:drop-shadow(0 0 8px rgba(201,162,75,.9))}
.tide__scale{display:flex;justify-content:space-between;margin-top:.6rem;
  font-family:var(--accent);letter-spacing:.14em;font-size:.62rem;color:var(--silver-dim)}
.events__cta{display:flex;align-items:center;gap:1.6rem;flex-wrap:wrap;margin-top:clamp(2.6rem,5vw,4rem);
  max-width:var(--maxw);margin-left:auto;margin-right:auto}
.events__cta-sub{font-family:var(--accent);letter-spacing:.14em;text-transform:uppercase;font-size:.66rem;color:var(--silver-dim)}

/* ============================================================
   RESERVE
   ============================================================ */
.reserve{position:relative;padding:var(--section-pad) var(--gutter);overflow:hidden;
  background:linear-gradient(180deg,var(--bg) 0%, var(--bg-deep) 100%)}
.reserve__candle{position:absolute;inset:0;width:100%;height:100%;z-index:0;pointer-events:none;opacity:.9}
.reserve__inner{position:relative;z-index:1;max-width:var(--maxw);margin:0 auto;
  display:grid;gap:clamp(2.5rem,6vw,6rem);grid-template-columns:1fr;align-items:start}
@media (min-width:920px){.reserve__inner{grid-template-columns:1.05fr .95fr}}
.reserve__title{font-size:clamp(2.4rem,6vw,5rem);margin:.4rem 0 0}
.reserve__lead{max-width:40ch;margin:1.8rem 0 0;color:var(--silver)}
.contacts{list-style:none;margin:clamp(2.4rem,5vw,3.4rem) 0 0;padding:0;display:flex;flex-direction:column}
.contacts li{display:grid;grid-template-columns:7rem 1fr;gap:1rem;padding:1.1rem 0;border-top:1px solid var(--line-soft)}
.contacts li:last-child{border-bottom:1px solid var(--line-soft)}
.contacts__k{font-family:var(--accent);letter-spacing:.2em;text-transform:uppercase;font-size:.64rem;color:var(--silver-dim);padding-top:.2em}
.contacts__v{color:var(--moon);font-size:.98rem}
.contacts__v a{border-bottom:1px solid rgba(159,178,196,.25);transition:color .3s,border-color .3s}
.contacts__v a:hover{color:var(--gold);border-color:var(--gold)}
.reserve__coords{font-family:var(--accent);letter-spacing:.3em;text-transform:uppercase;font-size:.62rem;
  color:var(--silver-dim);margin-top:1.8rem}

.reserve__form{position:relative;display:grid;grid-template-columns:1fr 1fr;gap:1.1rem 1.2rem;
  padding:clamp(1.6rem,3vw,2.4rem);border:1px solid var(--line-soft);border-radius:22px;
  background:linear-gradient(180deg, rgba(11,14,24,.6), rgba(6,7,13,.6));
  box-shadow:0 40px 90px -50px rgba(0,0,0,.9), inset 0 1px 0 rgba(255,255,255,.03);
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}
.field{display:flex;flex-direction:column;gap:.5rem}
.field--full{grid-column:1/-1}
.field label{font-family:var(--accent);letter-spacing:.18em;text-transform:uppercase;font-size:.62rem;color:var(--silver-dim)}
.field input,.field select,.field textarea{
  font-family:var(--body);font-size:.95rem;color:var(--moon);background:rgba(3,4,10,.5);
  border:1px solid var(--silver-dim);border-radius:11px;padding:.85em .95em;width:100%;
  transition:border-color .4s,box-shadow .4s;-webkit-appearance:none;appearance:none}
.field textarea{resize:vertical;min-height:3.2em}
.field input::placeholder,.field textarea::placeholder{color:var(--silver);opacity:1}
.field input:focus-visible,.field select:focus-visible,.field textarea:focus-visible{outline:none;border-color:var(--gold);
  box-shadow:0 0 0 2px var(--bg),0 0 0 4px var(--gold)}
.field select{background-image:linear-gradient(45deg,transparent 50%,var(--silver) 50%),linear-gradient(135deg,var(--silver) 50%,transparent 50%);
  background-position:calc(100% - 18px) center,calc(100% - 13px) center;background-size:5px 5px,5px 5px;background-repeat:no-repeat}
.reserve__note{grid-column:1/-1;font-size:.74rem;color:var(--silver-dim);margin:.2rem 0 0;text-align:center}
.reserve__success{grid-column:1/-1;display:flex;align-items:center;gap:1rem;padding:1.2rem;
  border:1px solid rgba(201,162,75,.3);border-radius:14px;background:rgba(201,162,75,.06);color:var(--moon)}
.reserve__success[hidden]{display:none}
.reserve__success p{margin:0;font-size:.95rem}
.reserve__success-moon{width:30px;height:30px;flex:0 0 auto;border-radius:50%;
  background:radial-gradient(circle at 34% 32%, #fff, var(--gold) 75%);box-shadow:0 0 18px rgba(201,162,75,.7)}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{position:relative;padding:clamp(5rem,10vw,9rem) var(--gutter) clamp(2rem,4vw,3rem);overflow:hidden;
  background:linear-gradient(180deg,var(--bg-deep),#020308)}
.footer__reflect{position:absolute;left:50%;bottom:-40px;width:8px;height:8px;border-radius:50%;translate:-50% 0;
  background:radial-gradient(circle,#fff,rgba(201,162,75,.5) 50%,transparent 75%);filter:blur(.4px)}
html:not(.reduce-motion) .footer__reflect{animation:reflectflicker 5s var(--ease-tide) infinite}
@keyframes reflectflicker{0%,100%{opacity:.4;transform:translate(-50%,0) scale(.9)}50%{opacity:.9;transform:translate(-50%,0) scale(1.15)}}
.footer__inner{max-width:var(--maxw);margin:0 auto}
.footer__line{font-size:clamp(1.8rem,4.4vw,3.4rem);max-width:20ch;margin:0;line-height:1.18}
.footer__sub{max-width:40ch;margin:1.6rem 0 0;color:var(--silver)}
.footer__cols{display:grid;gap:2.4rem;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));
  margin:clamp(3rem,7vw,5rem) 0 0;padding:clamp(2.4rem,5vw,3.5rem) 0 0;border-top:1px solid var(--line-soft)}
.footer__brand{display:flex;flex-direction:column;gap:.5rem}
.footer__brand .nav__moon{width:1.6em;height:1.6em}
.footer__name{font-family:var(--accent);letter-spacing:.4em;text-indent:.4em;font-size:1.3rem;color:var(--moon);margin-top:.4rem}
.footer__tag{font-family:var(--accent);letter-spacing:.14em;text-transform:uppercase;font-size:.6rem;color:var(--silver-dim)}
.footer__col{display:flex;flex-direction:column;gap:.65rem}
.footer__h{font-family:var(--accent);letter-spacing:.2em;text-transform:uppercase;font-size:.64rem;color:var(--gold);margin:0 0 .4rem}
.footer__col a{font-size:.9rem;color:var(--silver);transition:color .35s}
.footer__col a:hover{color:var(--moon)}
.footer__bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;
  margin-top:clamp(3rem,6vw,4.5rem);padding-top:1.6rem;border-top:1px solid var(--line-soft);
  font-family:var(--accent);letter-spacing:.14em;text-transform:uppercase;font-size:.62rem;color:var(--silver-dim)}
.footer__credit{margin:1rem 0 0;font-size:.62rem;letter-spacing:.04em;color:var(--silver-dim);opacity:.6}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:899px){
  /* native horizontal swipe is active here — drop the diagonal vertical offsets so cards don't clip */
  .dish{--y:0 !important}
}
@media (max-width:880px){
  .nav__links,.nav__cta{display:none}
  .nav__burger{display:block}
  .phases{display:none}
  .reserve__form{grid-template-columns:1fr}
}
@media (max-width:560px){
  .hero{justify-content:center;padding-bottom:6rem}
  .hero__title{font-size:clamp(3.6rem,27vw,7rem)}
  .hero__coords{font-size:.54rem;letter-spacing:.2em;right:var(--gutter);left:auto;text-align:right}
  .contacts li{grid-template-columns:1fr;gap:.3rem}
  .footer__bottom{flex-direction:column}
}

/* reduce-motion: freeze all loops, show final states */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms !important;animation-iteration-count:1 !important;
    transition-duration:.001ms !important;scroll-behavior:auto !important}
  .layer--grain{opacity:.04}
}
html.reduce-motion .dish__rule{width:72%}
html.reduce-motion [data-reveal],html.reduce-motion [data-lines] .line{opacity:1 !important;transform:none !important;filter:none !important}
