:root{
  --bg:#0d0d0f;
  --bg-2:#141417;
  --panel:#1a1a1e;
  --gold:#c9a24b;
  --gold-bright:#e3c374;
  --cream:#f4efe6;
  --muted:#9a948a;
  --line:rgba(201,162,75,.25);
  --shadow:0 20px 60px rgba(0,0,0,.5);
}
*{margin:0;padding:0;box-sizing:border-box}

/* Themed text selection */
::selection{background:var(--gold);color:#0d0d0f}
::-moz-selection{background:var(--gold);color:#0d0d0f}

/* Visible keyboard focus (accessibility) */
:focus-visible{outline:2px solid var(--gold-bright);outline-offset:3px;border-radius:2px}
a:focus-visible,button:focus-visible,.nav__cta:focus-visible{outline:2px solid var(--gold-bright);outline-offset:3px}

/* Themed scrollbar (vertical only — no horizontal bar) */
html{scrollbar-width:thin;scrollbar-color:var(--gold) var(--bg-2)}
::-webkit-scrollbar{width:12px}
::-webkit-scrollbar:horizontal{height:0}
::-webkit-scrollbar-track{background:var(--bg-2)}
::-webkit-scrollbar-thumb{background:linear-gradient(var(--gold-bright),var(--gold));border-radius:8px;border:3px solid var(--bg-2)}
::-webkit-scrollbar-thumb:hover{background:var(--gold-bright)}
::-webkit-scrollbar-corner{background:var(--bg-2)}

html{scroll-behavior:smooth;overflow-x:hidden;max-width:100%}
body{
  background:var(--bg);
  color:var(--cream);
  font-family:'Oswald',sans-serif;
  font-weight:300;
  line-height:1.6;
  overflow-x:hidden;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
em{font-family:'Cormorant Garamond',serif;font-style:italic;color:var(--gold-bright);font-weight:500}

/* ---------- NAV ---------- */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:50;
  transition:background .4s,box-shadow .4s;
}
.nav.scrolled{background:rgba(13,13,15,.96);box-shadow:0 2px 20px rgba(0,0,0,.6)}
.nav.menu-open{box-shadow:none}
.nav__inner{
  max-width:1280px;margin:0 auto;padding:18px 28px;
  display:flex;align-items:center;justify-content:space-between;
}
.nav__brand{display:flex;align-items:center;gap:12px;position:relative;z-index:60}
.nav__brand-mark{
  width:46px;height:46px;flex:none;border:2px solid var(--gold);
  display:grid;place-items:center;border-radius:50%;overflow:hidden;
  background:var(--cream);
}
.nav__brand-mark img{width:100%;height:100%;object-fit:cover;display:block}
.nav__brand-text{font-family:'Bebas Neue',sans-serif;font-size:24px;line-height:.85;letter-spacing:1.5px;display:flex;flex-direction:column}
.nav__brand-text small{font-size:11px;letter-spacing:4px;color:var(--gold);font-family:'Oswald';font-weight:400}
.nav__links{display:flex;align-items:center;gap:34px}
.nav__links a{font-size:14px;letter-spacing:2px;text-transform:uppercase;font-weight:400;transition:color .25s;position:relative}
.nav__links a:not(.nav__cta)::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:1px;background:var(--gold);transition:width .3s}
.nav__links a:not(.nav__cta):hover{color:var(--gold-bright)}
.nav__links a:not(.nav__cta):hover::after{width:100%}
.nav__cta{
  border:1px solid var(--gold);color:var(--gold);padding:9px 22px;border-radius:2px;
  transition:all .3s;
}
.nav__cta:hover{background:var(--gold);color:#0d0d0f}
.nav__toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px}
.nav__toggle span{width:26px;height:2px;background:var(--cream);transition:.3s}

/* ---------- BUTTONS ---------- */
.btn{
  display:inline-block;font-family:'Oswald';font-weight:500;font-size:14px;
  letter-spacing:2.5px;text-transform:uppercase;padding:15px 34px;border-radius:2px;
  transition:all .3s;cursor:pointer;
}
.btn--lg{padding:18px 46px;font-size:15px}
.btn--gold{background:var(--gold);color:#0d0d0f;border:1px solid var(--gold)}
.btn--gold:hover{background:var(--gold-bright);border-color:var(--gold-bright);transform:translateY(-2px);box-shadow:0 10px 30px rgba(201,162,75,.35)}
.btn--ghost{border:1px solid rgba(244,239,230,.4);color:var(--cream)}
.btn--ghost:hover{border-color:var(--cream);background:rgba(244,239,230,.08)}

/* ---------- HERO ---------- */
.hero{position:relative;height:100vh;height:100svh;min-height:600px;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden}
.hero__video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:25% center;z-index:0;transition:opacity 1s linear;transform:translateZ(0);backface-visibility:hidden}
.hero__video--a{opacity:1}
.hero__video--b{opacity:0}
.hero__overlay{position:absolute;inset:0;z-index:1;background:
  linear-gradient(to bottom,rgba(13,13,15,.55),rgba(13,13,15,.35) 40%,rgba(13,13,15,.85)),
  radial-gradient(circle at center,transparent 30%,rgba(13,13,15,.6))}
.hero__content{position:relative;z-index:2;padding:0 20px;animation:rise 1s ease both}
.hero__eyebrow{letter-spacing:6px;text-transform:uppercase;font-size:13px;color:var(--gold);margin-bottom:18px}
.hero__title{font-family:'Bebas Neue',sans-serif;font-size:clamp(64px,13vw,160px);line-height:.86;letter-spacing:3px;text-shadow:0 6px 40px rgba(0,0,0,.6)}
.hero__title span{color:var(--gold);-webkit-text-stroke:1px var(--gold-bright)}
.hero__tagline{font-family:'Cormorant Garamond',serif;font-size:clamp(18px,2.4vw,26px);font-style:italic;margin:22px 0 36px;color:var(--cream)}
.hero__actions{display:flex;gap:18px;justify-content:center;flex-wrap:wrap}
.hero__scroll{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);z-index:2;font-size:11px;letter-spacing:3px;text-transform:uppercase;color:var(--muted);display:flex;flex-direction:column;align-items:center;gap:10px}
.hero__scroll span{width:1px;height:40px;background:linear-gradient(var(--gold),transparent);animation:scrollpulse 1.8s infinite}
@keyframes scrollpulse{0%,100%{opacity:.3;transform:scaleY(.6)}50%{opacity:1;transform:scaleY(1)}}
@keyframes rise{from{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}

/* ---------- SECTION SHELL ---------- */
.section{padding:110px 28px;max-width:1280px;margin:0 auto}
.section__head{text-align:center;margin-bottom:64px}
.section__eyebrow{letter-spacing:5px;text-transform:uppercase;font-size:13px;color:var(--gold)}
.section__title{font-family:'Bebas Neue',sans-serif;font-size:clamp(42px,6vw,80px);line-height:.95;letter-spacing:2px;margin-top:10px}
.section__sub{color:var(--muted);margin-top:14px;font-size:17px}

/* ---------- PORTFOLIO CAROUSEL ---------- */
.portfolio{max-width:none;padding-left:0;padding-right:0}
.portfolio__title{font-family:'Parisienne',cursive;font-size:clamp(46px,7vw,86px);color:var(--cream);line-height:1;margin-top:8px;font-weight:400}
.portfolio__stage{position:relative;display:flex;align-items:center;justify-content:center}
.portfolio__viewport{overflow:hidden;width:100%}
.portfolio__track{display:flex;gap:16px;transition:transform .6s cubic-bezier(.22,.61,.36,1);position:relative;will-change:transform;padding:20px 0}
.portfolio__slide{flex:0 0 auto;width:min(560px,62vw);aspect-ratio:4/5;border-radius:4px;overflow:hidden;cursor:pointer;background:var(--panel);
  filter:grayscale(1) brightness(.42);transform:scale(.92);transition:filter .6s,transform .6s,box-shadow .6s}
.portfolio__slide img{width:100%;height:100%;object-fit:cover;display:block}
.portfolio__slide.is-active{filter:none;transform:scale(1);box-shadow:0 30px 70px rgba(0,0,0,.6),0 0 0 1px var(--line)}
.portfolio__arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:5;width:54px;height:54px;border-radius:50%;
  background:rgba(13,13,15,.65);backdrop-filter:blur(4px);border:1px solid var(--gold);color:var(--gold-bright);
  font-size:28px;line-height:1;cursor:pointer;transition:.25s;display:grid;place-items:center}
.portfolio__arrow:hover{background:var(--gold);color:#0d0d0f}
.portfolio__arrow--prev{left:18px}
.portfolio__arrow--next{right:18px}
.portfolio__thumbs{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;max-width:1100px;margin:40px auto 0;padding:0 28px}
.portfolio__thumb{flex:0 0 auto;width:72px;height:72px;border-radius:3px;overflow:hidden;cursor:pointer;border:2px solid transparent;
  padding:0;background:none;opacity:.55;filter:grayscale(1);transition:.3s}
.portfolio__thumb img{width:100%;height:100%;object-fit:cover;display:block}
.portfolio__thumb:hover{opacity:.85}
.portfolio__thumb.is-active{opacity:1;filter:none;border-color:var(--gold)}
.portfolio__toggle{display:none;margin:18px auto 0;background:none;border:1px solid var(--gold);color:var(--gold-bright);
  font-family:'Oswald';font-weight:500;font-size:13px;letter-spacing:2px;text-transform:uppercase;padding:11px 26px;border-radius:2px;cursor:pointer;transition:.25s}
.portfolio__toggle:hover{background:var(--gold);color:#0d0d0f}

/* ---------- CRAFT ---------- */
.craft{display:grid;grid-template-columns:.9fr 1.2fr .9fr;gap:40px;align-items:center;max-width:1280px;margin:0 auto;padding:60px 28px 110px}
.craft__art{position:relative}
.craft__art img{width:100%;border-radius:4px;box-shadow:var(--shadow)}
.craft__art-frame{position:absolute;inset:14px;border:1px solid var(--gold);pointer-events:none;border-radius:2px}
.craft__text{text-align:center}
.craft__text .section__title{font-size:clamp(34px,4vw,54px);margin-bottom:18px}
.craft__text p{color:var(--muted);font-size:16px;margin-bottom:26px}
.craft__towel{position:relative;border-radius:4px;overflow:hidden;box-shadow:var(--shadow)}
.craft__towel img{width:100%;height:100%;object-fit:cover;filter:contrast(1.05)}
.craft__towel-label{position:absolute;bottom:0;left:0;right:0;padding:14px;text-align:center;background:linear-gradient(transparent,rgba(13,13,15,.9));font-family:'Cormorant Garamond',serif;font-style:italic;font-size:18px;color:var(--gold-bright)}

/* ---------- SERVICES ---------- */
.services{background:var(--bg-2);max-width:none;margin:0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.services__grid{max-width:820px;margin:0 auto;display:flex;flex-direction:column;gap:8px}
.service{padding:24px 26px;border:1px solid transparent;border-radius:4px;transition:all .3s;position:relative}
.service:hover{background:var(--panel);border-color:var(--line)}
.service__row{display:flex;align-items:baseline;gap:14px}
.service__row h3{font-family:'Bebas Neue',sans-serif;font-size:28px;letter-spacing:1.5px;font-weight:400}
.service__dots{flex:1;border-bottom:1px dotted rgba(201,162,75,.4);transform:translateY(-4px)}
.service__price{font-family:'Bebas Neue',sans-serif;font-size:30px;color:var(--gold-bright)}
.service p{color:var(--muted);font-size:15px;margin-top:4px;max-width:560px}
.service--feature{background:linear-gradient(135deg,rgba(201,162,75,.12),transparent);border-color:var(--line)}
.service__badge{position:absolute;top:-10px;right:20px;background:var(--gold);color:#0d0d0f;font-size:11px;letter-spacing:2px;text-transform:uppercase;padding:4px 12px;border-radius:2px;font-weight:600}
.services__cta{text-align:center;margin-top:48px}

/* ---------- ACTION BAND ---------- */
.band{position:relative;background-size:cover;background-position:center 28%;background-attachment:fixed;min-height:60vh;display:flex;align-items:center;justify-content:center;text-align:center}
.band__overlay{position:absolute;inset:0;background:linear-gradient(rgba(13,13,15,.7),rgba(13,13,15,.55))}
.band__content{position:relative;z-index:2;max-width:820px;padding:0 28px}
.band__quote{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:clamp(26px,4vw,46px);color:var(--cream);line-height:1.3}
.band__by{display:block;margin-top:20px;letter-spacing:3px;text-transform:uppercase;font-size:13px;color:var(--gold-bright)}

/* ---------- REVIEWS ---------- */
.reviews{background:var(--bg-2);max-width:none;margin:0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.reviews__agg{display:inline-flex;align-items:center;gap:12px;margin-top:18px;font-size:18px}
.reviews__stars{color:var(--gold-bright);letter-spacing:2px}
.reviews__agg strong{font-family:'Bebas Neue',sans-serif;font-size:30px;color:var(--cream);line-height:1}
.reviews__count{color:var(--muted);font-size:15px}
.reviews__grid{max-width:1180px;margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.review{background:var(--panel);border:1px solid var(--line);border-radius:8px;padding:32px;display:flex;flex-direction:column;gap:16px}
.review__stars{color:var(--gold-bright);letter-spacing:3px;font-size:17px}
.review blockquote{font-family:'Cormorant Garamond',serif;font-size:21px;line-height:1.5;color:var(--cream);flex:1}
.review figcaption{display:flex;align-items:center;gap:14px;border-top:1px solid var(--line);padding-top:18px}
.review__avatar{width:44px;height:44px;flex:none;border-radius:50%;display:grid;place-items:center;background:var(--gold);color:#0d0d0f;font-family:'Bebas Neue',sans-serif;font-size:22px}
.review__who{display:flex;flex-direction:column;line-height:1.3}
.review__who strong{letter-spacing:1px}
.review__who small{color:var(--muted);font-size:13px}
.reviews__cta{text-align:center;margin-top:44px}

/* ---------- ABOUT ---------- */
.about__inner{display:grid;grid-template-columns:1fr 1.3fr;gap:64px;align-items:center}
.about__tools{position:relative;border-radius:6px;overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow)}
.about__tools img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .8s}
.about__tools:hover img{transform:scale(1.04)}
.about__tools-label{position:absolute;left:0;right:0;bottom:0;padding:32px 22px 18px;font-family:'Cormorant Garamond',serif;font-style:italic;font-size:20px;color:var(--gold-bright);background:linear-gradient(transparent,rgba(13,13,15,.85))}
.about__lead{font-family:'Cormorant Garamond',serif;font-size:24px;font-style:italic;line-height:1.5;color:var(--cream);margin:24px 0 36px;border-left:2px solid var(--gold);padding-left:24px}
.about__stats{display:flex;gap:40px;flex-wrap:wrap}
.about__stats div{display:flex;flex-direction:column}
.about__stats strong{font-family:'Bebas Neue',sans-serif;font-size:46px;color:var(--gold-bright);line-height:1}
.about__stats span{font-size:13px;letter-spacing:2px;text-transform:uppercase;color:var(--muted)}

/* ---------- VISIT ---------- */
.visit__panel{background:var(--panel);border:1px solid var(--line);border-radius:8px;padding:54px}
.visit__cols{display:grid;grid-template-columns:repeat(3,1fr);gap:48px}
.visit__col h3{font-family:'Bebas Neue',sans-serif;font-size:26px;letter-spacing:1.5px;color:var(--gold);margin-bottom:16px}
.visit__col p{margin-bottom:10px;font-size:16px}
.visit__col a{color:var(--gold-bright);transition:color .25s}
.visit__col a:hover{color:var(--cream)}
.visit__muted{color:var(--muted);font-size:14px}
.visit__link{display:inline-block;margin-top:8px;letter-spacing:1px}
.visit__hours{display:flex;justify-content:space-between;font-size:17px;border-bottom:1px solid var(--line);padding-bottom:10px}
.visit__cta{display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;
  margin-top:44px;padding-top:36px;border-top:1px solid var(--line)}
.visit__cta p{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:21px;color:var(--cream)}

/* ---------- FOOTER ---------- */
.footer{text-align:center;padding:60px 28px 40px;background:var(--bg-2);border-top:1px solid var(--line)}
.footer__brand{display:inline-flex;align-items:center;gap:12px;margin-bottom:14px}
.footer__tag{font-family:'Cormorant Garamond',serif;font-style:italic;color:var(--muted);font-size:18px}
.footer__links{display:flex;gap:26px;justify-content:center;margin:22px 0;flex-wrap:wrap}
.footer__links a{letter-spacing:2px;text-transform:uppercase;font-size:13px;color:var(--gold);transition:color .25s}
.footer__links a:hover{color:var(--gold-bright)}
.footer__copy{color:var(--muted);font-size:13px;letter-spacing:1px}

/* ---------- LIGHTBOX ---------- */
.lightbox{position:fixed;inset:0;z-index:100;background:rgba(8,8,10,.95);display:none;align-items:center;justify-content:center;padding:40px}
.lightbox.open{display:flex;animation:fade .3s}
.lightbox img{max-width:90vw;max-height:85vh;border-radius:4px;box-shadow:0 30px 80px rgba(0,0,0,.7)}
.lightbox__close{position:absolute;top:24px;right:30px;background:none;border:none;color:var(--cream);font-size:46px;cursor:pointer;line-height:1}
.lightbox__nav{position:absolute;top:50%;transform:translateY(-50%);background:rgba(201,162,75,.15);border:1px solid var(--gold);color:var(--gold-bright);width:56px;height:56px;border-radius:50%;font-size:30px;cursor:pointer;transition:.25s}
.lightbox__nav:hover{background:var(--gold);color:#0d0d0f}
.lightbox__prev{left:30px}.lightbox__next{right:30px}
@keyframes fade{from{opacity:0}to{opacity:1}}

/* ---------- REVEAL ---------- */
.reveal{opacity:0;transform:translateY(40px);transition:opacity .8s,transform .8s}
.reveal.in{opacity:1;transform:none}

/* ---------- RESPONSIVE ---------- */
@media(max-width:900px){
  .craft{grid-template-columns:1fr;gap:30px}
  .about__inner{grid-template-columns:1fr;gap:36px}
  .about__tools{max-width:420px;margin:0 auto}
}
@media(max-width:760px){
  .nav__links{position:fixed;inset:0;width:100%;height:100%;max-width:none;background:#000;flex-direction:column;justify-content:center;align-items:center;gap:38px;transform:translateX(100%);transition:transform .4s;z-index:55}
  .nav__links.open{transform:translateX(0)}
  .nav__links a{font-size:20px;letter-spacing:3px}
  .nav__links .nav__cta{margin-top:8px;padding:14px 34px}
  .nav__toggle{display:flex;z-index:60}
  body.no-scroll{overflow:hidden}
  .nav.menu-open .nav__toggle span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .nav.menu-open .nav__toggle span:nth-child(2){opacity:0}
  .nav.menu-open .nav__toggle span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
  .section{padding:80px 20px}
  .portfolio__toggle{display:block}
  .portfolio__thumbs{position:relative;overflow:hidden}
  .portfolio__thumbs.is-collapsed{max-height:72px}
  .portfolio__thumbs.is-collapsed::after{content:"";position:absolute;left:0;right:0;bottom:0;height:36px;
    background:linear-gradient(transparent,var(--bg));pointer-events:none}
  .reviews__grid{grid-template-columns:1fr}
  .band{background-attachment:scroll;min-height:48vh}
  .visit__cols{grid-template-columns:1fr;gap:32px}
  .visit__panel{padding:32px}
  .visit__cta{flex-direction:column;text-align:center}
  .gallery{grid-template-columns:repeat(auto-fill,minmax(130px,1fr))}
  .lightbox__nav{width:44px;height:44px;font-size:24px}
  .lightbox__prev{left:12px}.lightbox__next{right:12px}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;scroll-behavior:auto}
  .reveal{opacity:1;transform:none}
}
