/* ============================================================
   GREAT BEAR VINEYARDS — shared design system
   "Dark cinematic editorial luxury"
   Site concept crafted by Spatial Port · spatial-port.com
   ============================================================ */

/* ---------- Tokens ---------- */
:root{
  --espresso:        #14100D;
  --espresso-2:      #1B1611;
  --espresso-3:      #241C16;
  --parchment:       #EFE7D8;
  --parchment-2:     #C9BCA6;
  --parchment-light: #F2EBDD;
  --gold:            #B0894F;
  --gold-hi:         #D8B981;
  --gold-soft:       #c7a572;
  --sage:            #6B7257;
  --wine:            #5E2331;
  --line:            rgba(216,185,129,.20);
  --line-strong:     rgba(216,185,129,.40);

  --serif: "Cormorant Garamond", Georgia, "Times New Roman", serif;
  --sans: "Inter", system-ui, -apple-system, "Segoe UI", sans-serif;

  --ease: cubic-bezier(.22,.61,.36,1);
  --ease-out: cubic-bezier(.16,1,.3,1);

  --gutter: clamp(20px, 5vw, 80px);
  --maxw: 1320px;

  --header-h: 80px;
}

/* ---------- Reset ---------- */
*,*::before,*::after{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; overflow-x:clip; }
html,body{ margin:0; padding:0; width:100%; max-width:100%; }
body{
  font-family:var(--sans);
  background:var(--espresso);
  color:var(--parchment);
  font-weight:300;
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:clip;
}
img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; }
h1,h2,h3,h4{ margin:0; font-weight:400; }
p{ margin:0; }
ul{ margin:0; padding:0; list-style:none; }

/* Lenis */
html.lenis,html.lenis body{ height:auto; }
.lenis.lenis-smooth{ scroll-behavior:auto !important; }
.lenis.lenis-stopped{ overflow:hidden; }

/* ---------- Typography helpers ---------- */
.eyebrow{
  font-family:var(--sans);
  font-weight:500;
  font-size:.72rem;
  letter-spacing:.42em;
  text-transform:uppercase;
  color:var(--gold-hi);
  display:inline-block;
}
.eyebrow--dark{ color:var(--gold); }

.display{
  font-family:var(--serif);
  font-weight:400;
  line-height:.98;
  letter-spacing:-.01em;
  font-size:clamp(2.8rem, 8vw, 7.5rem);
}
.h2{
  font-family:var(--serif);
  font-weight:400;
  line-height:1.03;
  letter-spacing:-.01em;
  font-size:clamp(2.2rem, 5.2vw, 4.6rem);
}
.h3{
  font-family:var(--serif);
  font-weight:400;
  line-height:1.1;
  font-size:clamp(1.5rem, 2.6vw, 2.3rem);
}
.lead{
  font-size:clamp(1.05rem,1.5vw,1.32rem);
  line-height:1.75;
  color:var(--parchment);
  font-weight:300;
}
.muted{ color:var(--parchment-2); }
.serif-italic{ font-family:var(--serif); font-style:italic; }

/* ---------- Layout ---------- */
.wrap{ max-width:var(--maxw); margin:0 auto; padding-left:var(--gutter); padding-right:var(--gutter); }
.section{ padding:clamp(72px, 11vh, 160px) 0; position:relative; }
.section--tight{ padding:clamp(48px,7vh,96px) 0; }
.grid{ display:grid; gap:clamp(24px,4vw,72px); }
.cols-2{ grid-template-columns:1fr 1fr; }
.cols-3{ grid-template-columns:repeat(3,1fr); }
.cols-4{ grid-template-columns:repeat(4,1fr); }
.align-center{ align-items:center; }

/* Light parchment sections */
.section--light{ background:var(--parchment-light); color:var(--espresso-2); }
.section--light .eyebrow{ color:var(--gold); }
.section--light .lead{ color:#3a2f25; }
.section--light .muted{ color:#6a5c4a; }
.section--light .hairline{ background:rgba(20,16,13,.18); }

/* hairline */
.hairline{ height:1px; background:var(--line); border:0; margin:0; }
.rule-label{ display:flex; align-items:center; gap:18px; }
.rule-label .hairline{ flex:1; }

/* ---------- Film grain + scroll bar ---------- */
.grain{
  position:fixed; inset:0; z-index:9000; pointer-events:none; opacity:.05;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  mix-blend-mode:overlay;
}
.scroll-progress{
  position:fixed; top:0; left:0; height:2px; width:0%; z-index:9500;
  background:linear-gradient(90deg,var(--gold),var(--gold-hi));
  box-shadow:0 0 12px rgba(216,185,129,.55);
}

/* ---------- Custom cursor ---------- */
.cursor-dot,.cursor-ring{
  position:fixed; top:0; left:0; z-index:9600; pointer-events:none;
  border-radius:50%; transform:translate(-50%,-50%);
  mix-blend-mode:difference;
}
.cursor-dot{ width:6px; height:6px; background:var(--gold-hi); }
.cursor-ring{
  width:34px; height:34px; border:1px solid rgba(216,185,129,.7);
  transition:width .3s var(--ease), height .3s var(--ease), background .3s var(--ease), opacity .3s;
}
.cursor-ring.is-hover{ width:62px; height:62px; background:rgba(216,185,129,.10); }
body.no-cursor .cursor-dot,body.no-cursor .cursor-ring{ display:none; }
@media (hover:none),(pointer:coarse){ .cursor-dot,.cursor-ring{ display:none !important; } }

/* ---------- Header ---------- */
.site-header{
  position:fixed; top:0; left:0; right:0; z-index:8000;
  display:flex; align-items:center; justify-content:space-between;
  height:var(--header-h);
  padding:0 var(--gutter);
  transition:background .5s var(--ease), backdrop-filter .5s, height .5s var(--ease), border-color .5s;
  border-bottom:1px solid transparent;
}
.site-header.is-condensed{
  height:64px;
  background:rgba(20,16,13,.72);
  backdrop-filter:blur(14px) saturate(1.2);
  -webkit-backdrop-filter:blur(14px) saturate(1.2);
  border-bottom:1px solid var(--line);
}
.brand{ display:flex; align-items:center; gap:12px; z-index:2; }
.brand img{ height:42px; width:auto; transition:height .5s var(--ease); }
.is-condensed .brand img{ height:34px; }
.brand .brand-fallback{
  font-family:var(--serif); font-size:1.4rem; letter-spacing:.04em; color:var(--parchment);
  display:none;
}
.nav{ display:flex; align-items:center; gap:clamp(18px,2vw,34px); }
.nav-links{ display:flex; align-items:center; gap:clamp(16px,1.8vw,30px); }
.nav-links a{
  font-size:.78rem; letter-spacing:.16em; text-transform:uppercase; font-weight:400;
  color:var(--parchment-2); position:relative; padding:6px 0;
  transition:color .35s var(--ease);
}
.nav-links a::after{
  content:""; position:absolute; left:0; bottom:0; height:1px; width:100%;
  background:var(--gold-hi); transform:scaleX(0); transform-origin:right; transition:transform .4s var(--ease);
}
.nav-links a:hover{ color:var(--parchment); }
.nav-links a:hover::after{ transform:scaleX(1); transform-origin:left; }
.nav-links a.is-active{ color:var(--gold-hi); }
.nav-links a.is-active::after{ transform:scaleX(1); }

.btn-reserve{
  font-size:.74rem; letter-spacing:.18em; text-transform:uppercase;
  border:1px solid var(--gold); color:var(--gold-hi);
  padding:12px 22px; border-radius:2px; position:relative; overflow:hidden;
  transition:color .4s var(--ease), border-color .4s;
  background:transparent;
}
.btn-reserve span{ position:relative; z-index:2; }
.btn-reserve::before{
  content:""; position:absolute; inset:0; background:linear-gradient(120deg,var(--gold),var(--gold-hi));
  transform:translateY(101%); transition:transform .45s var(--ease); z-index:1;
}
.btn-reserve:hover{ color:var(--espresso); border-color:var(--gold-hi); }
.btn-reserve:hover::before{ transform:translateY(0); }

.menu-toggle{
  display:none; background:none; border:0; cursor:pointer; z-index:2;
  width:42px; height:42px; flex-direction:column; gap:6px; align-items:center; justify-content:center;
}
.menu-toggle span{ width:26px; height:1.5px; background:var(--parchment); transition:transform .4s var(--ease), opacity .3s; }

/* mobile overlay */
.mobile-menu{
  position:fixed; inset:0; z-index:7900; background:var(--espresso);
  display:flex; flex-direction:column; justify-content:center; align-items:center;
  gap:6px; transform:translateY(-100%); transition:transform .7s var(--ease-out), visibility .7s;
  padding:var(--gutter);
  visibility:hidden; overflow:hidden;
}
.mobile-menu.is-open{ transform:translateY(0); visibility:visible; }
/* The mobile overlay only exists below the nav breakpoint; never on desktop. */
@media (min-width:861px){ .mobile-menu{ display:none; } }
.mobile-menu a{
  font-family:var(--serif); font-size:clamp(1.8rem,7vw,3rem); color:var(--parchment);
  padding:8px 0; transition:color .3s, letter-spacing .4s var(--ease);
}
.mobile-menu a:hover{ color:var(--gold-hi); letter-spacing:.03em; }
.mobile-menu .mm-reserve{ margin-top:24px; }
.mobile-menu .mm-meta{ position:absolute; bottom:36px; left:0; right:0; text-align:center; color:var(--parchment-2); font-size:.8rem; letter-spacing:.1em; }

/* ---------- Buttons / links ---------- */
.btn{
  display:inline-flex; align-items:center; gap:12px;
  font-size:.78rem; letter-spacing:.18em; text-transform:uppercase; font-weight:400;
  padding:15px 30px; border-radius:2px; position:relative; overflow:hidden;
  border:1px solid var(--gold); color:var(--gold-hi); background:transparent;
  transition:color .4s var(--ease), border-color .4s;
  cursor:pointer;
}
.btn span{ position:relative; z-index:2; }
.btn::before{
  content:""; position:absolute; inset:0; z-index:1;
  background:linear-gradient(120deg,var(--gold),var(--gold-hi));
  transform:translateY(101%); transition:transform .45s var(--ease);
}
.btn:hover{ color:var(--espresso); border-color:var(--gold-hi); }
.btn:hover::before{ transform:translateY(0); }
.btn--solid{ background:linear-gradient(120deg,var(--gold),var(--gold-hi)); color:var(--espresso); border-color:transparent; }
.btn--solid::before{ background:var(--espresso); }
.btn--solid:hover{ color:var(--gold-hi); }

.link-underline{
  display:inline-block; position:relative; color:var(--gold-hi);
  font-size:.82rem; letter-spacing:.16em; text-transform:uppercase; padding-bottom:4px;
}
.link-underline::after{
  content:""; position:absolute; left:0; bottom:0; height:1px; width:100%;
  background:var(--gold-hi); transform:scaleX(1); transform-origin:left; transition:transform .4s var(--ease);
}
.link-underline:hover::after{ transform:scaleX(0); transform-origin:right; }

/* ---------- Hero ---------- */
.hero{
  position:relative; min-height:100svh; display:flex; align-items:flex-end;
  overflow:hidden; background:var(--espresso);
}
.hero--mid{ min-height:78vh; }
.hero__media{ position:absolute; inset:0; z-index:0; background:var(--espresso-2); overflow:hidden; }
.hero__media img{
  position:absolute; top:-8%; left:-8%; width:116%; height:116%; max-width:none;
  object-fit:cover; will-change:transform;
}
.hero__scrim{
  position:absolute; inset:0; z-index:1;
  background:
    linear-gradient(180deg, rgba(20,16,13,.55) 0%, rgba(20,16,13,.12) 32%, rgba(20,16,13,.20) 58%, rgba(20,16,13,.92) 100%),
    radial-gradient(120% 80% at 20% 100%, rgba(20,16,13,.55), transparent 70%);
}
.hero__inner{
  position:relative; z-index:2; width:100%;
  padding-bottom:clamp(56px,9vh,120px); padding-top:calc(var(--header-h) + 40px);
}
.hero__eyebrow{ margin-bottom:26px; opacity:0; }
.hero__title{ margin-bottom:30px; max-width:16ch; }
.hero__sub{ max-width:54ch; opacity:0; }
.hero__meta{
  display:flex; flex-wrap:wrap; gap:30px; margin-top:40px; opacity:0;
  font-size:.74rem; letter-spacing:.2em; text-transform:uppercase; color:var(--parchment-2);
}
.hero__meta span{ display:flex; align-items:center; gap:10px; }
.hero__meta span::before{ content:""; width:6px; height:6px; border-radius:50%; background:var(--gold); }

.scroll-cue{
  position:absolute; right:var(--gutter); bottom:clamp(40px,7vh,90px); z-index:2;
  display:flex; flex-direction:column; align-items:center; gap:14px;
  font-size:.62rem; letter-spacing:.34em; text-transform:uppercase; color:var(--parchment-2);
  writing-mode:vertical-rl;
}
.scroll-cue .line{ width:1px; height:54px; background:linear-gradient(var(--gold-hi),transparent); writing-mode:horizontal-tb; animation:cueDrop 2.2s var(--ease) infinite; }
@keyframes cueDrop{ 0%{ transform:scaleY(0); transform-origin:top; } 45%{ transform:scaleY(1); transform-origin:top; } 55%{ transform:scaleY(1); transform-origin:bottom; } 100%{ transform:scaleY(0); transform-origin:bottom; } }

/* Splitting masked reveal */
.reveal-mask .word{ overflow:hidden; padding-bottom:.04em; }
.reveal-mask .char{ display:inline-block; transform:translateY(110%); }
.is-ready .reveal-mask.done .char{ transform:none; }

/* ---------- Scroll reveal (default visible; JS adds .anim) ---------- */
.is-ready .anim .fx{ opacity:0; transform:translateY(34px); }
.fx{ transition:none; }

/* ---------- Figures / images ---------- */
.figure{ position:relative; overflow:hidden; background:var(--espresso-2); border-radius:2px; }
.figure img{ width:100%; height:100%; object-fit:cover; transition:transform 1.1s var(--ease); }
.figure--tall{ aspect-ratio:3/4; }
.figure--wide{ aspect-ratio:16/10; }
.figure--square{ aspect-ratio:1/1; }
.figure.zoom:hover img{ transform:scale(1.06); }
.figure__caption{
  position:absolute; left:0; bottom:0; right:0; padding:20px 22px;
  background:linear-gradient(transparent, rgba(20,16,13,.85));
  font-size:.72rem; letter-spacing:.16em; text-transform:uppercase; color:var(--parchment-2);
}
.parallax-frame{ overflow:hidden; }
.parallax-frame img{ will-change:transform; }

/* ---------- Stat / count ---------- */
.stats{ display:grid; grid-template-columns:repeat(4,1fr); gap:clamp(18px,3vw,40px); }
.stat__num{ font-family:var(--serif); font-size:clamp(2.6rem,5vw,4.2rem); line-height:1; color:var(--gold-hi); }
.stat__label{ margin-top:10px; font-size:.7rem; letter-spacing:.2em; text-transform:uppercase; color:var(--parchment-2); }

/* ---------- Award row ---------- */
.awards{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--line); border:1px solid var(--line); }
.award{
  background:var(--espresso-2); padding:clamp(28px,3.4vw,46px);
  display:flex; flex-direction:column; gap:12px;
}
.award__score{ font-family:var(--serif); font-size:clamp(2.4rem,4vw,3.4rem); color:var(--gold-hi); line-height:1; }
.award__name{ font-size:.92rem; color:var(--parchment); }
.award__cat{ font-size:.68rem; letter-spacing:.2em; text-transform:uppercase; color:var(--parchment-2); }

/* ---------- Cards ---------- */
.card{
  background:var(--espresso-2); border:1px solid var(--line); border-radius:3px;
  padding:clamp(26px,3vw,40px); position:relative; overflow:hidden;
  transition:border-color .5s var(--ease), transform .5s var(--ease), background .5s;
}
.card::after{
  content:""; position:absolute; inset:0; pointer-events:none;
  background:radial-gradient(120% 90% at 50% 0%, rgba(216,185,129,.07), transparent 60%);
  opacity:0; transition:opacity .5s;
}
.card:hover{ border-color:var(--line-strong); transform:translateY(-4px); }
.card:hover::after{ opacity:1; }
.card__kicker{ font-size:.68rem; letter-spacing:.22em; text-transform:uppercase; color:var(--gold); margin-bottom:18px; }
.card .h3{ margin-bottom:14px; }
.card__price{ font-family:var(--serif); font-size:1.7rem; color:var(--gold-hi); }
.card__meta{ font-size:.75rem; letter-spacing:.1em; color:var(--parchment-2); text-transform:uppercase; }
.card--feature{ border-color:var(--line-strong); background:linear-gradient(160deg,var(--espresso-3),var(--espresso-2)); }
.card--feature .card__kicker{ color:var(--gold-hi); }

.section--light .card{ background:#fff; border-color:rgba(20,16,13,.12); color:var(--espresso-2); }
.section--light .card .h3{ color:var(--espresso); }
.section--light .card__price{ color:var(--gold); }
.section--light .card__meta{ color:#7a6c58; }
.section--light .card:hover{ border-color:rgba(176,137,79,.5); }

/* feature line list */
.feat-list{ display:flex; flex-direction:column; gap:14px; }
.feat-list li{ display:flex; gap:14px; align-items:flex-start; color:var(--parchment); font-size:.98rem; }
.feat-list li::before{ content:""; margin-top:.6em; width:18px; height:1px; background:var(--gold); flex:none; }
.section--light .feat-list li{ color:#3a2f25; }

/* ---------- Pull quote ---------- */
.pullquote{ font-family:var(--serif); font-style:italic; font-weight:400; line-height:1.25;
  font-size:clamp(1.8rem,4vw,3.4rem); color:var(--parchment); max-width:24ch; }
.pullquote .by{ display:block; font-family:var(--sans); font-style:normal; font-size:.74rem; letter-spacing:.22em; text-transform:uppercase; color:var(--gold); margin-top:28px; }

/* ---------- Split feature ---------- */
.split{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(30px,5vw,80px); align-items:center; }
.split--reverse .split__media{ order:2; }
.split__body .h2{ margin-bottom:24px; }
.split__body .lead{ margin-bottom:24px; }

/* ---------- Horizontal scroll gallery ---------- */
.hscroll-outer{ position:relative; }
.hscroll{ display:flex; gap:clamp(18px,2vw,32px); padding:0 var(--gutter); }
.hscroll__panel{ flex:0 0 min(78vw,520px); }
.hscroll__panel .figure{ aspect-ratio:4/5; margin-bottom:20px; }
.hscroll__panel h3{ font-family:var(--serif); font-size:clamp(1.4rem,2.4vw,2rem); margin-bottom:8px; }
.hscroll__panel p{ color:var(--parchment-2); font-size:.95rem; max-width:42ch; }
.hscroll__num{ font-size:.7rem; letter-spacing:.24em; color:var(--gold); margin-bottom:14px; }
/* fallback when JS off: horizontal swipe */
.no-js .hscroll, .no-pin .hscroll{ overflow-x:auto; scroll-snap-type:x mandatory; -webkit-overflow-scrolling:touch; padding-bottom:18px; }
.no-js .hscroll__panel,.no-pin .hscroll__panel{ scroll-snap-align:start; }

/* ---------- Gallery grid ---------- */
.gallery-grid{ display:grid; grid-template-columns:repeat(12,1fr); gap:clamp(10px,1.4vw,18px); }
.gallery-grid .figure{ grid-column:span 4; aspect-ratio:1/1; }
.gallery-grid .figure.span6{ grid-column:span 6; aspect-ratio:4/3; }
.gallery-grid .figure.span8{ grid-column:span 8; aspect-ratio:16/9; }
.gallery-grid .figure.tall{ grid-row:span 2; aspect-ratio:3/5; }

/* ---------- Cart icon (header) ---------- */
.cart-link{
  position:relative; display:inline-flex; align-items:center; justify-content:center;
  width:38px; height:38px; color:var(--parchment-2);
  transition:color .35s var(--ease);
}
.cart-link svg{ width:21px; height:21px; }
.cart-link:hover{ color:var(--gold-hi); }
.cart-badge{
  position:absolute; top:-2px; right:-3px; min-width:16px; height:16px; padding:0 4px;
  display:flex; align-items:center; justify-content:center;
  font-size:.58rem; font-weight:500; letter-spacing:.02em; line-height:1;
  color:var(--espresso); background:linear-gradient(120deg,var(--gold),var(--gold-hi));
  border-radius:100px;
}
@media (max-width:860px){ .cart-link{ margin-left:auto; margin-right:8px; } }

/* ---------- Experience mosaic (home) ---------- */
.mosaic{
  display:grid; grid-template-columns:repeat(12,1fr);
  grid-auto-rows:clamp(96px,12vw,168px);
  gap:clamp(8px,1.1vw,16px);
}
.mosaic__tile{
  position:relative; overflow:hidden; border-radius:2px;
  background:var(--espresso-2); display:block;
  grid-column:span 3; grid-row:span 2;
}
.mosaic__tile.t-wide{ grid-column:span 6; }
.mosaic__tile.t-tall{ grid-row:span 3; }
.mosaic__tile.t-big{ grid-column:span 6; grid-row:span 3; }
.mosaic__tile.t-sq{ grid-column:span 4; grid-row:span 2; }
.mosaic__tile img{
  position:absolute; inset:0; width:100%; height:100%; object-fit:cover;
  transition:transform 1.2s var(--ease); will-change:transform;
}
.mosaic__tile::after{
  content:""; position:absolute; inset:0; pointer-events:none;
  box-shadow:inset 0 0 0 1px transparent;
  background:linear-gradient(transparent 55%, rgba(20,16,13,.78));
  opacity:.85; transition:opacity .5s var(--ease), box-shadow .5s var(--ease);
}
.mosaic__cap{
  position:absolute; left:0; right:0; bottom:0; z-index:2;
  padding:16px 18px; transform:translateY(8px); opacity:0;
  transition:transform .5s var(--ease), opacity .5s var(--ease);
  font-size:.7rem; letter-spacing:.16em; text-transform:uppercase; color:var(--parchment);
}
.mosaic__cap::before{
  content:""; display:block; width:20px; height:1px; background:var(--gold-hi);
  margin-bottom:9px; transform:scaleX(0); transform-origin:left; transition:transform .5s var(--ease) .05s;
}
.is-ready .anim .mosaic__tile{ opacity:0; transform:translateY(40px) scale(.97); }
@media (hover:hover){
  .mosaic__tile:hover img{ transform:scale(1.08); }
  .mosaic__tile:hover::after{ opacity:1; box-shadow:inset 0 0 0 1px var(--line-strong); }
  .mosaic__tile:hover .mosaic__cap{ transform:translateY(0); opacity:1; }
  .mosaic__tile:hover .mosaic__cap::before{ transform:scaleX(1); }
}
/* touch / no-hover: captions always visible */
@media (hover:none){
  .mosaic__cap{ transform:none; opacity:1; }
  .mosaic__cap::before{ transform:scaleX(1); }
}
@media (max-width:860px){
  .mosaic{ grid-template-columns:repeat(6,1fr); grid-auto-rows:clamp(88px,22vw,150px); }
  .mosaic__tile,.mosaic__tile.t-sq{ grid-column:span 3; grid-row:span 2; }
  .mosaic__tile.t-wide,.mosaic__tile.t-big{ grid-column:span 6; grid-row:span 2; }
  .mosaic__tile.t-tall{ grid-row:span 2; }
}
@media (max-width:480px){
  .mosaic{ grid-template-columns:repeat(2,1fr); }
  .mosaic__tile,.mosaic__tile.t-sq,.mosaic__tile.t-wide,.mosaic__tile.t-big,.mosaic__tile.t-tall{
    grid-column:span 1; grid-row:span 2;
  }
  .mosaic__cap{ transform:none; opacity:1; }
  .mosaic__cap::before{ transform:scaleX(1); }
}

/* ---------- Shop ---------- */
.shop-filters{ display:flex; flex-wrap:wrap; gap:12px; }
.chip{
  font-family:var(--sans); font-size:.7rem; letter-spacing:.16em; text-transform:uppercase;
  color:var(--parchment-2); background:transparent; cursor:pointer;
  border:1px solid var(--line); border-radius:100px; padding:10px 20px;
  transition:color .35s var(--ease), border-color .35s, background .35s;
}
.chip:hover{ color:var(--parchment); border-color:var(--line-strong); }
.chip.is-active{ color:var(--espresso); border-color:transparent;
  background:linear-gradient(120deg,var(--gold),var(--gold-hi)); }

.shop-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(20px,2.4vw,34px); }
.product{
  display:flex; flex-direction:column;
  background:var(--espresso-2); border:1px solid var(--line); border-radius:3px;
  overflow:hidden; transition:border-color .5s var(--ease), transform .5s var(--ease);
}
.product:hover{ border-color:var(--line-strong); transform:translateY(-4px); }
.product__media{ position:relative; aspect-ratio:4/5; overflow:hidden; background:var(--espresso-3); }
.product__media img{ width:100%; height:100%; object-fit:cover; transition:transform 1.1s var(--ease); }
.product:hover .product__media img{ transform:scale(1.07); }
.product__cat{
  position:absolute; top:14px; left:14px; z-index:2;
  font-size:.6rem; letter-spacing:.18em; text-transform:uppercase; color:var(--gold-hi);
  background:rgba(20,16,13,.6); backdrop-filter:blur(6px);
  border:1px solid var(--line); border-radius:100px; padding:6px 12px;
}
.product__body{ padding:22px 22px 26px; display:flex; flex-direction:column; flex:1; gap:10px; }
.product__name{ font-family:var(--serif); font-size:1.32rem; line-height:1.12; color:var(--parchment); }
.product__name .accolade{ display:block; font-family:var(--sans); font-size:.6rem; letter-spacing:.18em;
  text-transform:uppercase; color:var(--gold); margin-top:7px; }
.product__desc{ font-size:.88rem; color:var(--parchment-2); line-height:1.55; flex:1; }
.product__foot{ display:flex; align-items:center; justify-content:space-between; gap:14px; margin-top:8px; }
.product__price{ font-family:var(--serif); font-size:1.4rem; color:var(--gold-hi); }
.product__memtag{ font-size:.62rem; letter-spacing:.1em; text-transform:uppercase; color:var(--parchment-2); }
.product__btn{
  font-size:.66rem; letter-spacing:.16em; text-transform:uppercase; font-weight:400;
  color:var(--gold-hi); background:transparent; cursor:pointer;
  border:1px solid var(--gold); border-radius:2px; padding:11px 18px; position:relative; overflow:hidden;
  transition:color .4s var(--ease), border-color .4s; white-space:nowrap;
}
.product__btn span{ position:relative; z-index:2; }
.product__btn::before{ content:""; position:absolute; inset:0; z-index:1;
  background:linear-gradient(120deg,var(--gold),var(--gold-hi)); transform:translateY(101%);
  transition:transform .45s var(--ease); }
.product__btn:hover{ color:var(--espresso); border-color:var(--gold-hi); }
.product__btn:hover::before{ transform:translateY(0); }
.product.is-hidden{ display:none; }
.shop-note{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--line);
  border:1px solid var(--line); border-radius:3px; overflow:hidden; }
.shop-note > div{ background:var(--espresso-2); padding:clamp(24px,3vw,40px); }
.shop-note h3{ font-family:var(--serif); font-size:1.4rem; color:var(--gold-hi); margin-bottom:12px; }
.shop-note p{ color:var(--parchment-2); font-size:.92rem; }
.section--light .shop-note{ background:rgba(20,16,13,.12); border-color:rgba(20,16,13,.12); }
.section--light .shop-note > div{ background:#fff; }
.section--light .shop-note p{ color:#6a5c4a; }

@media (max-width:960px){ .shop-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:860px){ .shop-note{ grid-template-columns:1fr; } }
@media (max-width:560px){ .shop-grid{ grid-template-columns:1fr; } }

/* ---------- Forms ---------- */
.form{ display:grid; gap:18px; }
.field{ display:flex; flex-direction:column; gap:8px; }
.field label{ font-size:.68rem; letter-spacing:.2em; text-transform:uppercase; color:var(--parchment-2); }
.field input,.field select,.field textarea{
  background:var(--espresso-3); border:1px solid var(--line); color:var(--parchment);
  padding:14px 16px; border-radius:2px; font-family:var(--sans); font-size:.95rem; font-weight:300;
  transition:border-color .35s;
}
.field input:focus,.field select:focus,.field textarea:focus{ outline:none; border-color:var(--gold); }
.field--full{ grid-column:1/-1; }
.section--light .field input,.section--light .field select,.section--light .field textarea{ background:#fff; border-color:rgba(20,16,13,.14); color:var(--espresso); }
.section--light .field label{ color:#6a5c4a; }

/* ---------- Map ---------- */
.map-frame{ position:relative; border:1px solid var(--line); border-radius:3px; overflow:hidden; background:var(--espresso-2); }
.map-frame iframe{ display:block; width:100%; height:100%; border:0; filter:grayscale(.4) sepia(.22) brightness(.78) contrast(1.05); }

/* ---------- Info rows ---------- */
.info-row{ display:flex; justify-content:space-between; gap:24px; padding:18px 0; border-bottom:1px solid var(--line); }
.info-row dt{ font-size:.72rem; letter-spacing:.2em; text-transform:uppercase; color:var(--parchment-2); }
.info-row dd{ margin:0; text-align:right; color:var(--parchment); }

/* ---------- Marquee CTA band ---------- */
.cta-band{ position:relative; text-align:center; padding:clamp(70px,12vh,150px) 0; overflow:hidden; }
.cta-band .h2{ margin-bottom:30px; }
.cta-band__bg{ position:absolute; inset:0; z-index:0; }
.cta-band__bg img{ width:100%; height:100%; object-fit:cover; }
.cta-band__bg::after{ content:""; position:absolute; inset:0; background:linear-gradient(rgba(20,16,13,.82),rgba(20,16,13,.92)); }
.cta-band .wrap{ position:relative; z-index:1; }

/* ---------- Footer ---------- */
.site-footer{ background:var(--espresso-2); border-top:1px solid var(--line); padding:clamp(60px,8vh,100px) 0 40px; }
.footer-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1.2fr; gap:clamp(30px,4vw,60px); }
.footer-brand img{ height:48px; margin-bottom:22px; }
.footer-brand p{ color:var(--parchment-2); font-size:.9rem; max-width:34ch; }
.footer-col h4{ font-size:.68rem; letter-spacing:.22em; text-transform:uppercase; color:var(--gold); margin-bottom:20px; }
.footer-col a,.footer-col p{ display:block; color:var(--parchment-2); font-size:.92rem; margin-bottom:11px; transition:color .3s; }
.footer-col a:hover{ color:var(--gold-hi); }
.footer-socials{ display:flex; gap:18px; margin-top:8px; }
.footer-socials a{ font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; }
.footer-bottom{ display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:14px;
  margin-top:clamp(46px,6vh,80px); padding-top:28px; border-top:1px solid var(--line);
  font-size:.78rem; letter-spacing:.06em; color:var(--parchment-2); }
.footer-bottom .signature{ color:var(--gold-soft); letter-spacing:.1em; }
.footer-bottom .signature a{ color:var(--gold-hi); }

/* ---------- Barba transition curtain ---------- */
.curtain{
  position:fixed; inset:0; z-index:9700; pointer-events:none;
  background:linear-gradient(160deg,var(--espresso) 0%, #2a1d14 55%, var(--espresso) 100%);
  transform:scaleY(0); transform-origin:bottom;
  display:flex; align-items:center; justify-content:center;
}
.curtain img{ height:60px; opacity:0; }
.curtain__rule{ position:absolute; left:50%; bottom:34%; width:0; height:1px; background:var(--gold-hi); transform:translateX(-50%); }

/* fade-in for barba container */
.is-ready [data-barba="container"]{ }

/* ---------- Utility ---------- */
.center{ text-align:center; }
.mt-s{ margin-top:18px; } .mt-m{ margin-top:32px; } .mt-l{ margin-top:56px; }
.mb-m{ margin-bottom:32px; }
.maxw-60{ max-width:60ch; } .maxw-46{ max-width:46ch; }
.text-gold{ color:var(--gold-hi); }
.divider-num{ font-family:var(--serif); color:var(--gold); font-size:1.1rem; }
.tag{ display:inline-block; font-size:.64rem; letter-spacing:.2em; text-transform:uppercase; color:var(--gold-hi);
  border:1px solid var(--line); border-radius:100px; padding:6px 14px; }

/* ---------- Responsive ---------- */
@media (max-width:1024px){
  .footer-grid{ grid-template-columns:1fr 1fr; }
  .cols-4{ grid-template-columns:repeat(2,1fr); }
  .awards{ grid-template-columns:repeat(3,1fr); }
}
@media (max-width:860px){
  .nav-links,.btn-reserve.desktop{ display:none; }
  .menu-toggle{ display:flex; }
  .split,.split--reverse .split__media{ grid-template-columns:1fr; order:0; }
  .split{ gap:36px; }
  .cols-2,.cols-3,.cols-4{ grid-template-columns:1fr; }
  .stats{ grid-template-columns:repeat(2,1fr); gap:30px; }
  .awards{ grid-template-columns:1fr; }
  .gallery-grid .figure,.gallery-grid .figure.span6,.gallery-grid .figure.span8{ grid-column:span 6; aspect-ratio:1/1; }
  .gallery-grid .figure.tall{ grid-row:auto; }
  .info-row{ flex-direction:column; gap:4px; }
  .info-row dd{ text-align:left; }
}
@media (max-width:560px){
  .footer-grid{ grid-template-columns:1fr; }
  .stats{ grid-template-columns:1fr 1fr; }
  .gallery-grid{ grid-template-columns:repeat(2,1fr); }
  .gallery-grid .figure,.gallery-grid .figure.span6,.gallery-grid .figure.span8{ grid-column:span 2; }
  .hero__meta{ gap:16px; }
}

/* ---------- Reduced motion ---------- */
@media (prefers-reduced-motion:reduce){
  *{ animation-duration:.001ms !important; animation-iteration-count:1 !important; transition-duration:.001ms !important; }
  .hero__media img{ position:static; inset:auto; width:100%; height:100%; }
  .is-ready .anim .fx{ opacity:1 !important; transform:none !important; }
  .is-ready .anim .mosaic__tile{ opacity:1 !important; transform:none !important; }
  .mosaic__cap{ transform:none !important; opacity:1 !important; }
  .mosaic__cap::before{ transform:scaleX(1) !important; }
  .reveal-mask .char{ transform:none !important; }
}

/* fonts loading flash guard — content always visible */
.no-js .hero__eyebrow,.no-js .hero__sub,.no-js .hero__meta{ opacity:1 !important; }
