/* ============ TOKENS ============ */
:root{
  --noir:#0b0b0c;        /* deep black base */
  --ink:#141417;         /* raised black */
  --paper:#efece5;       /* warm off-white */
  --bone:#dcd8ce;        /* light warm grey */
  --ash:#908d85;         /* muted secondary text */
  --ash-dim:#6f6c66;
  --hair-light:rgba(239,236,229,.14);  /* hairline on dark */
  --hair-dark:rgba(20,20,23,.16);      /* hairline on light */

  --container:1320px;
  --pad-x:clamp(1.5rem,5vw,5rem);
  --pad-y:clamp(5rem,13vh,10rem);

  --display:"Bebas Neue",sans-serif;
  --display-alt:"Oswald",sans-serif;
  --body:"Inter",system-ui,sans-serif;

  --ease:cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  background:var(--noir);
  color:var(--paper);
  font-family:var(--body);
  font-weight:300;
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}

/* ============ HELPERS ============ */
.container{max-width:var(--container);margin-inline:auto;padding-inline:var(--pad-x)}
.section{padding-block:var(--pad-y)}

.eyebrow{
  font-family:var(--body);
  font-size:.72rem;
  font-weight:500;
  letter-spacing:.4em;
  text-transform:uppercase;
  color:var(--ash);
  display:inline-block;
}
.h2{
  font-family:var(--display);
  font-weight:400;
  font-size:clamp(2.75rem,7.5vw,6.75rem);
  line-height:.92;
  letter-spacing:.01em;
}
.lead{
  font-size:clamp(1.05rem,1.5vw,1.3rem);
  line-height:1.7;
  font-weight:300;
  max-width:46ch;
}
.muted{color:var(--ash)}
.on-paper .muted{color:var(--ash-dim)}

/* ============ BUTTONS ============ */
.btn{
  display:inline-flex;align-items:center;gap:.7em;
  font-family:var(--body);
  font-size:.74rem;font-weight:600;
  letter-spacing:.22em;text-transform:uppercase;
  padding:1.15rem 2.4rem;
  border:1px solid transparent;
  cursor:pointer;
  transition:background .4s var(--ease),color .4s var(--ease),border-color .4s var(--ease),transform .4s var(--ease);
}
.btn .arrow{transition:transform .4s var(--ease)}
.btn:hover .arrow{transform:translateX(5px)}
.btn--solid{background:var(--paper);color:var(--noir)}
.btn--solid:hover{background:transparent;color:var(--paper);border-color:var(--paper)}
.btn--solid-dark{background:var(--noir);color:var(--paper)}
.btn--solid-dark:hover{background:transparent;color:var(--noir);border-color:var(--noir)}
.btn--ghost{background:transparent;color:var(--paper);border-color:var(--hair-light)}
.btn--ghost:hover{background:var(--paper);color:var(--noir);border-color:var(--paper)}
.btn--ghost-dark{background:transparent;color:var(--noir);border-color:var(--hair-dark)}
.btn--ghost-dark:hover{background:var(--noir);color:var(--paper);border-color:var(--noir)}

/* ============ NAV ============ */
.nav{
  position:fixed;inset:0 0 auto 0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:1.4rem var(--pad-x);
  transition:background .5s var(--ease),padding .5s var(--ease),border-color .5s var(--ease);
  border-bottom:1px solid transparent;
}
.nav--solid{
  background:rgba(11,11,12,.82);
  -webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);
  border-bottom-color:var(--hair-light);
  padding-block:1rem;
}
.nav__logo{
  font-family:var(--display);font-size:1.35rem;letter-spacing:.12em;
  line-height:1;white-space:nowrap;
}
.nav__logo img{height:40px;width:auto;display:block}
@media (max-width:520px){.nav__logo img{height:34px}}
.nav__links{display:flex;gap:2.4rem;list-style:none}
.nav__links a{
  font-size:.74rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;
  color:var(--bone);position:relative;padding-block:.3rem;transition:color .3s;
}
.nav__links a::after{
  content:"";position:absolute;left:0;bottom:0;width:0;height:1px;background:var(--paper);
  transition:width .4s var(--ease);
}
.nav__links a:hover{color:var(--paper)}
.nav__links a:hover::after{width:100%}
.nav__cta{
  font-size:.72rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;
  border:1px solid var(--hair-light);padding:.85rem 1.6rem;
  transition:background .4s var(--ease),color .4s var(--ease),border-color .4s;
}
.nav__cta:hover{background:var(--paper);color:var(--noir);border-color:var(--paper)}
.nav__right{display:flex;align-items:center;gap:1.8rem}

.nav__burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px}
.nav__burger span{width:26px;height:1.5px;background:var(--paper);transition:transform .4s var(--ease),opacity .3s}
.nav.is-open .nav__burger span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.nav.is-open .nav__burger span:nth-child(2){opacity:0}
.nav.is-open .nav__burger span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

/* mobile menu */
.menu{
  position:fixed;inset:0;z-index:90;background:var(--noir);
  display:flex;flex-direction:column;justify-content:center;align-items:center;gap:1.1rem;
  opacity:0;visibility:hidden;transform:translateY(-8px);
  transition:opacity .5s var(--ease),transform .5s var(--ease),visibility .5s;
}
.menu.is-open{opacity:1;visibility:visible;transform:translateY(0)}
.menu a{font-family:var(--display);font-size:clamp(2.4rem,11vw,3.6rem);letter-spacing:.04em;color:var(--bone);transition:color .3s}
.menu a:hover{color:var(--paper)}
.menu .btn{margin-top:1.6rem}

/* ============ HERO (image only) ============ */
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;justify-content:center;overflow:hidden;padding-bottom:clamp(3.5rem,8vh,6rem)}
.hero__cta{position:relative;z-index:2}
.hero__book{font-size:.74rem;padding:1.05rem 2.6rem;box-shadow:0 14px 44px rgba(0,0,0,.42)}
.hero__bg{
  position:absolute;inset:0;
  background-image:linear-gradient(180deg,rgba(11,11,12,.32) 0%,rgba(11,11,12,.04) 28%,rgba(11,11,12,.04) 58%,rgba(11,11,12,.44) 100%),
                   url("../images/hero.jpg");
  background-size:cover;background-position:center 30%;
  filter:grayscale(18%) contrast(1.04) brightness(.98);
  transform:scale(1.05);
  animation:heroZoom 16s var(--ease) forwards;
}
@keyframes heroZoom{to{transform:scale(1)}}

/* ============ INTRO / MASTERING (editorial) ============ */
.intro{background:var(--paper);color:var(--noir)}
.intro__grid{max-width:1000px;margin-inline:auto;text-align:center}
.intro__text{max-width:740px;margin-inline:auto}
.intro h2{margin:1.4rem auto 0;max-width:20ch}
.intro__text p{margin:1.8rem auto 0;font-size:clamp(1.02rem,1.35vw,1.2rem);line-height:1.85;color:#3b3a37;max-width:58ch}
.intro__media{position:relative;width:min(660px,94%);margin:clamp(3rem,6vw,5rem) auto 0;aspect-ratio:4/5;overflow:hidden}
.intro__media .ph{position:absolute;inset:0;background-size:cover;background-position:center;filter:grayscale(40%) contrast(1.04);transition:transform 1.4s var(--ease)}
.intro__media:hover .ph{transform:scale(1.04)}
.intro__media .frame{position:absolute;inset:14px;border:1px solid rgba(239,236,229,.55);pointer-events:none}

/* ============ MARQUEE (brand strip) ============ */
.strip{border-block:1px solid var(--hair-light);background:var(--noir);overflow:hidden;padding-block:1.5rem}
.strip__track{display:flex;gap:0;white-space:nowrap;width:max-content;animation:marquee 38s linear infinite}
.strip__track span{
  font-family:var(--display);font-size:clamp(1.6rem,3.4vw,2.6rem);letter-spacing:.08em;
  color:var(--ash);padding-inline:2.2rem;text-transform:uppercase;
}
.strip__track span::after{content:"—";margin-left:4.4rem;color:var(--hair-light)}
@keyframes marquee{to{transform:translateX(-50%)}}

/* ============ ABOUT (full-bleed, primary) ============ */
.band{position:relative;min-height:80vh;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden;padding-block:clamp(4rem,9vh,7rem)}
.band__bg{position:absolute;inset:0;background-size:cover;background-position:center 38%;filter:grayscale(55%) contrast(1.05) brightness(.7);transform:scale(1.06);transition:transform 1.6s var(--ease)}
.band.is-visible .band__bg{transform:scale(1)}
.band__inner{position:relative;z-index:2;color:var(--paper);max-width:780px;margin-inline:auto}
.band__inner .eyebrow{color:var(--bone)}
.band__inner h2{margin-top:1rem;font-size:clamp(2.6rem,7vw,6rem)}
.band__inner p{margin:1.8rem auto 0;color:var(--bone);font-size:clamp(1.02rem,1.4vw,1.2rem);line-height:1.85;max-width:56ch}

/* ============ REVIEWS ============ */
.reviews{background:var(--paper);color:var(--noir);overflow:hidden}
.reviews__head{text-align:center;margin-bottom:clamp(2.5rem,5vw,4rem)}
.reviews__head .sub{color:var(--ash-dim);font-size:.8rem;letter-spacing:.3em;text-transform:uppercase;margin-top:1.2rem;display:block}
.rev-marquee{position:relative;overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.rev-track{display:flex;gap:1.6rem;width:max-content;animation:marquee 46s linear infinite}
.reviews:hover .rev-track{animation-play-state:paused}
.rev-card{width:clamp(300px,34vw,420px);background:#fff;border:1px solid var(--hair-dark);padding:2.4rem 2.2rem;display:flex;flex-direction:column;gap:1.1rem}
.rev-card .rstars{color:var(--noir);letter-spacing:.16em;font-size:.85rem}
.rev-card p{font-size:1.08rem;line-height:1.65;color:#2a2a28;font-weight:400}
.rev-card .who{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ash-dim);margin-top:auto}
.reviews__cta{text-align:center;margin-top:clamp(2.5rem,5vw,3.5rem)}

/* ============ BEFORE YOU VISIT (compact) ============ */
.before{background:var(--paper);color:var(--noir);padding-block:clamp(3.25rem,7vh,5rem)}
.before__top{display:flex;flex-wrap:wrap;align-items:baseline;gap:.6rem 1.4rem;margin-bottom:clamp(1.8rem,3.5vw,2.6rem)}
.before__top h2{font-size:clamp(2rem,4.5vw,3.4rem)}
.before__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.6rem,4vw,3rem);border-top:1px solid var(--hair-dark);padding-top:clamp(1.8rem,3.5vw,2.6rem)}
.before__cell .k{font-size:.7rem;letter-spacing:.28em;text-transform:uppercase;color:var(--ash-dim);margin-bottom:.7rem}
.before__cell .v{font-size:.96rem;line-height:1.6;color:#3b3a37;font-weight:300;max-width:36ch}

/* ============ FINAL CTA (minimal) ============ */
.final{position:relative;text-align:center;overflow:hidden;padding-block:clamp(4.5rem,11vh,7.5rem)}
.final__bg{position:absolute;inset:0;background-size:cover;background-position:center;filter:grayscale(72%) contrast(1.05)}
.final__inner{position:relative;max-width:760px;margin-inline:auto;padding-block:clamp(2.5rem,5vw,3.5rem);border-block:1px solid var(--hair-light)}
.final__logo{width:58px;height:auto;display:block;margin:0 auto 1.4rem;opacity:.92}
.final h2{font-size:clamp(2.6rem,7vw,5.5rem);max-width:16ch;margin-inline:auto;margin-bottom:1.2rem}
.final p{color:var(--bone);max-width:40ch;margin-inline:auto;margin-bottom:2.2rem;font-size:1.02rem}

/* ============ FOOTER (minimal) ============ */
.footer{background:var(--noir);border-top:1px solid var(--hair-light);padding-block:clamp(3rem,6vh,4.5rem) 2rem}
.footer__logo-img{height:62px;width:auto;display:block;margin-bottom:clamp(2rem,4vw,3rem);opacity:.96}
.footer__grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:start}
.footer__col h4{font-size:.7rem;letter-spacing:.28em;text-transform:uppercase;color:var(--ash);margin-bottom:1.2rem;font-weight:500}
.footer__col p,.footer__col a{display:block;color:var(--bone);font-size:.92rem;line-height:1.95;transition:color .3s}
.footer__col a:hover{color:var(--paper)}
.footer__hours span{display:flex;justify-content:space-between;max-width:240px;color:var(--bone);font-size:.88rem;padding-block:.15rem}
.footer__hours span i{color:var(--ash);font-style:normal}
.footer__act{display:flex;flex-direction:column;align-items:flex-start;gap:1.1rem}
.footer__bottom{margin-top:clamp(2.5rem,5vw,3.5rem);padding-top:1.6rem;border-top:1px solid var(--hair-light);display:flex;flex-wrap:wrap;justify-content:space-between;gap:1rem;color:var(--ash-dim);font-size:.74rem;letter-spacing:.12em}

/* ============ REVEAL ============ */
.reveal{opacity:0;transform:translateY(30px);transition:opacity 1s var(--ease),transform 1s var(--ease)}
.reveal.is-visible{opacity:1;transform:none}
.reveal-img{clip-path:inset(0 0 100% 0);transition:clip-path 1.3s var(--ease)}
.reveal-img.is-visible{clip-path:inset(0 0 0 0)}

/* skip link */
.skip{position:absolute;left:-9999px;top:0;background:var(--paper);color:var(--noir);padding:.8rem 1.2rem;z-index:200;font-size:.8rem;letter-spacing:.1em}
.skip:focus{left:1rem;top:1rem}

:focus-visible{outline:2px solid var(--paper);outline-offset:3px}
.on-paper :focus-visible{outline-color:var(--noir)}

/* ============ RESPONSIVE ============ */
@media (max-width:860px){
  .nav__links,.nav__cta{display:none}
  .nav__burger{display:flex}
  .before__grid{grid-template-columns:1fr;gap:1.6rem}
  .footer__grid{grid-template-columns:1fr;gap:2.25rem}
}
@media (max-width:520px){
  .hero__book{width:auto}
  .btn{width:100%;justify-content:center}
  .rev-card{width:80vw}
}

@media (min-width:861px){
  .hero__bg{background-position:center 60%;background-size:130%}
}

@media (prefers-reduced-motion:reduce){
  *{animation:none !important;scroll-behavior:auto}
  .reveal,.reveal-img{opacity:1;transform:none;clip-path:none;transition:none}
  .strip__track,.rev-track{animation:none;white-space:normal;flex-wrap:wrap;width:auto;justify-content:center}
}