/* ============================================================
   THE ROUNDABOUT — MAASTRICHT
   Clean Dark Editorial CSS — v3 (Updated)
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=Playfair+Display:ital,wght@0,400;0,700;1,400&family=Barlow+Condensed:wght@300;400;500;600;700;800;900&family=Barlow:wght@300;400;500&display=swap');

:root {
  --black:   #0a0a0a;
  --dark:    #111111;
  --card:    #161616;
  --cream:   #f0ebe1;
  --gold:    #c9a84c;
  --gold-d:  #a8882e;
  --white:   #ffffff;
  --muted:   #5a5550;
  --border:  rgba(201,168,76,0.18);
  --border-w: rgba(255,255,255,0.07);

  --font-hero:    'Bebas Neue', sans-serif;
  --font-display: 'Barlow Condensed', sans-serif;
  --font-serif:   'Playfair Display', serif;
  --font-body:    'Barlow', sans-serif;

  --nav-h: 76px;
  --max:   1320px;
  --ease:  0.4s cubic-bezier(0.25,0.46,0.45,0.94);
}

*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { font-size:16px; scroll-behavior:smooth; -webkit-font-smoothing:antialiased; }
body { background:var(--black); color:var(--cream); font-family:var(--font-body); font-weight:400; line-height:1.7; overflow-x:hidden; }
img { width:100%; height:100%; object-fit:cover; display:block; }
a { color:inherit; text-decoration:none; }
ul { list-style:none; }

/* grain */
body::after {
  content:''; position:fixed; inset:0; pointer-events:none; z-index:9999; opacity:0.03;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:200px 200px;
}

/* ============================================================  NAV  */
.nav {
  position:fixed; top:0; left:0; width:100%; z-index:1000;
  height:var(--nav-h); display:flex; align-items:center; padding:0 48px;
  transition:background var(--ease), border-color var(--ease);
  border-bottom:1px solid transparent;
}
.nav.scrolled {
  background:rgba(10,10,10,0.95); border-bottom-color:var(--border);
  backdrop-filter:blur(14px);
}
.nav__inner {
  display:flex; align-items:center; justify-content:space-between;
  width:100%; max-width:var(--max); margin:0 auto;
}
/* Logo wrapper with image + text */
.nav__logo {
  display:flex; align-items:center; gap:14px;
  font-family:var(--font-display); font-weight:900; font-size:1.2rem;
  letter-spacing:0.2em; text-transform:uppercase; line-height:1.1; color:var(--white);
}
.nav__logo img.nav__logo-img {
  height:calc(var(--nav-h) * 0.65); width:auto; object-fit:contain; display:block;
  flex-shrink:0;
  filter: none;
  opacity:1;
}
.nav__logo-text {
  display:flex; flex-direction:column; align-items:flex-start; gap:0;
}
.nav__logo-text > span:first-child {
  font-family:var(--font-display); font-weight:900; font-size:1.35rem;
  letter-spacing:0.15em; text-transform:uppercase; color:var(--white);
}
.nav__logo span { display:block; font-size:0.55rem; letter-spacing:0.35em; color:var(--gold); font-weight:500; margin-top:2px; }
.nav__links { display:flex; gap:36px; align-items:center; }
.nav__links a {
  font-family:var(--font-display); font-size:0.75rem; font-weight:700;
  letter-spacing:0.2em; text-transform:uppercase; color:rgba(240,235,225,0.6);
  transition:color 0.2s; position:relative;
}
.nav__links a::after {
  content:''; position:absolute; bottom:-3px; left:0; width:0; height:1px;
  background:var(--gold); transition:width var(--ease);
}
.nav__links a:hover, .nav__links a.active { color:var(--cream); }
.nav__links a:hover::after, .nav__links a.active::after { width:100%; }
.nav__lang {
  font-family:var(--font-display); font-size:0.72rem; letter-spacing:0.2em; font-weight:700;
  text-transform:uppercase; color:var(--gold); border:2px solid var(--gold);
  padding:6px 16px; transition:all 0.2s;
}
.nav__lang:hover { background:var(--gold); color:var(--black); border-color:var(--gold); }

/* hamburger */
.nav__hamburger {
  display:none; flex-direction:column; gap:5px; cursor:pointer; padding:4px;
  background:none; border:none;
}
.nav__hamburger span { display:block; width:24px; height:1px; background:var(--cream); transition:all 0.3s; }

/* mobile nav */
.nav__mobile {
  position:fixed; top:0; right:-100%; width:min(360px,90vw); height:100vh;
  background:var(--dark); z-index:1001; transition:right var(--ease);
  display:flex; flex-direction:column; padding:40px 40px;
  border-left:1px solid var(--border);
}
.nav__mobile.open { right:0; }
.nav__mobile__close {
  align-self:flex-end; background:none; border:none; color:var(--cream);
  font-size:1.8rem; cursor:pointer; line-height:1; margin-bottom:40px; opacity:0.6;
}
.nav__mobile__close:hover { opacity:1; }
.nav__mobile a {
  font-family:var(--font-display); font-size:1.3rem; font-weight:700;
  letter-spacing:0.15em; text-transform:uppercase; padding:14px 0;
  border-bottom:1px solid var(--border-w); color:rgba(240,235,225,0.75);
  transition:color 0.2s;
}
.nav__mobile a:hover { color:var(--gold); }
.nav__mobile__lang {
  margin-top:32px; font-family:var(--font-display); font-size:0.8rem;
  letter-spacing:0.2em; text-transform:uppercase; color:var(--gold);
  border:2px solid var(--gold); padding:10px 20px; display:inline-block; width:fit-content;
}
.nav__overlay {
  position:fixed; inset:0; background:rgba(0,0,0,0.7); z-index:1000;
  opacity:0; pointer-events:none; transition:opacity var(--ease);
}
.nav__overlay.show { opacity:1; pointer-events:all; }

/* ============================================================  HERO  */
.hero {
  position:relative; height:100vh; min-height:640px;
  display:flex; align-items:flex-start; overflow:hidden;
}
.hero__image {
  position:absolute; inset:0;
}
.hero__image img { transform:scale(1.06); transition:transform 8s ease; }
.hero__overlay {
  display:none;
}
.hero__content {
  position:relative; z-index:2; width:100%; max-width:var(--max);
  margin:0 auto; padding:calc(var(--nav-h) + 40px) 48px 80px;
  display:flex; flex-direction:column; height:100%;
}
.hero__actions {
  margin-top:auto;
}
.hero__label {
  font-family:var(--font-display); font-size:0.82rem; font-weight:700;
  letter-spacing:0.35em; text-transform:uppercase; color:var(--gold);
  margin-bottom:20px; display:inline-block;
  border:1.5px solid rgba(255,255,255,0.4);
  border-radius:999px;
  padding:5px 16px;
  white-space:nowrap;
  width:fit-content;
  background: rgba(0,0,0,0.35);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}
.hero__title {
  font-family:var(--font-hero); font-size:clamp(4.5rem, 12vw, 10rem);
  line-height:0.9; letter-spacing:0.01em; text-transform:uppercase;
  color:var(--cream); margin-bottom:24px; display:block;
  font-weight:900;
  text-shadow: 2px 2px 8px rgba(0,0,0,0.6), 0 0 30px rgba(0,0,0,0.4);
}
.hero__sub {
  font-family:var(--font-body); font-size:1.05rem; font-weight:400;
  color:rgba(240,235,225,0.75); margin-bottom:40px; max-width:420px; line-height:1.6;
}
.hero__actions { display:flex; gap:16px; flex-wrap:wrap; margin-top:auto; }
.hero__scroll {
  position:absolute; bottom:80px; right:48px; z-index:2;
  display:flex; flex-direction:column; align-items:center; gap:8px;
  font-family:var(--font-display); font-size:0.65rem; letter-spacing:0.3em;
  text-transform:uppercase; color:rgba(240,235,225,0.4);
}
.hero__scroll::after {
  content:''; display:block; width:1px; height:56px; background:rgba(201,168,76,0.4);
}

/* ============================================================  BUTTONS  */
.btn {
  display:inline-block; font-family:var(--font-display); font-size:0.78rem;
  font-weight:800; letter-spacing:0.2em; text-transform:uppercase;
  padding:14px 32px; transition:all 0.2s; cursor:pointer; border:none;
}
.btn-gold { background:var(--gold); color:var(--black); }
.btn-gold:hover { background:var(--gold-d); }
.btn-outline { background:transparent; color:var(--cream); border:1px solid rgba(240,235,225,0.35); }
.btn-outline:hover { border-color:var(--cream); background:rgba(240,235,225,0.06); }

/* ============================================================  SECTION  */
.section { padding:100px 48px; }
.section--tight { padding:72px 48px; }
.section__inner { max-width:var(--max); margin:0 auto; }
.section__label {
  font-family:var(--font-display); font-size:0.78rem; font-weight:700;
  letter-spacing:0.35em; text-transform:uppercase; color:var(--gold);
  display:flex; align-items:center; gap:14px; margin-bottom:20px;
}
.section__label::before {
  content:''; display:block; width:32px; height:1px; background:var(--gold);
}
.section__title {
  font-family:var(--font-hero); font-size:clamp(3.5rem, 7vw, 7rem);
  line-height:0.9; text-transform:uppercase; color:var(--cream);
  margin-bottom:24px; font-weight:900;
}
.section__body {
  font-size:1rem; font-weight:400; color:rgba(240,235,225,0.7);
  max-width:520px; line-height:1.75;
}

/* ============================================================  FEATURES GRID (icons)  */
.features { display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--border-w); }
.feature {
  background:var(--dark); padding:48px 40px; display:flex; flex-direction:column;
  align-items:flex-start; gap:16px;
  transition:background 0.2s;
}
.feature:hover { background:var(--card); }
.feature__icon { color:var(--gold); margin-bottom:4px; }
.feature__icon svg { width:32px; height:32px; stroke:currentColor; fill:none; stroke-width:1.5; }
.feature__name {
  font-family:var(--font-display); font-size:0.95rem; font-weight:800;
  letter-spacing:0.1em; text-transform:uppercase; color:var(--cream);
}
.feature__value {
  font-family:var(--font-display); font-size:0.85rem; font-weight:600;
  color:var(--gold); letter-spacing:0.05em;
}

/* ============================================================  TWO-COL  */
.two-col { display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center; }
.two-col--reverse .two-col__image { order:-1; }
.two-col__image { position:relative; }
.two-col__image .img-wrap {
  width:100%; aspect-ratio:4/5; overflow:hidden; position:relative;
}
.two-col__text {}

/* ============================================================  IMAGE PLACEHOLDER  */
.img-placeholder {
  position:relative; width:100%; height:100%; background:var(--card);
  border:1px solid var(--border-w); overflow:hidden;
}
.img-placeholder img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.img-placeholder__label {
  position:absolute; inset:0; display:flex; flex-direction:column;
  align-items:center; justify-content:center; gap:8px; z-index:1;
  text-align:center; padding:20px;
}
.img-placeholder__label .filename {
  font-family:var(--font-display); font-size:0.85rem; font-weight:700;
  letter-spacing:0.08em; color:var(--gold);
}
.img-placeholder__label .dims {
  font-family:var(--font-display); font-size:0.65rem; letter-spacing:0.15em;
  color:var(--muted); text-transform:uppercase;
}
.img-placeholder__label .context {
  font-family:var(--font-display); font-size:0.6rem; letter-spacing:0.2em;
  color:rgba(201,168,76,0.4); text-transform:uppercase; margin-top:4px;
}
.img-placeholder::before {
  content:''; position:absolute; top:50%; left:50%; width:60%; height:1px;
  background:var(--border-w); transform:translate(-50%,-50%) rotate(0deg);
}
.img-placeholder::after {
  content:''; position:absolute; top:50%; left:50%; width:1px; height:60%;
  background:var(--border-w); transform:translate(-50%,-50%);
}

/* ============================================================  ABOUT INTRO  */
.about-intro { display:grid; grid-template-columns:1fr 1fr; gap:0; }
.about-intro__image { aspect-ratio:3/4; }
.about-intro__text {
  padding:80px 64px; display:flex; flex-direction:column; justify-content:center;
  border-left:1px solid var(--border);
}
.about-intro__text blockquote {
  font-family:var(--font-serif); font-size:clamp(1.3rem,2.2vw,1.8rem);
  font-style:italic; color:var(--cream); line-height:1.5;
  margin:24px 0 32px; border-left:2px solid var(--gold); padding-left:24px;
}

/* ============================================================  GALLERY  */
.gallery-grid {
  display:grid; grid-template-columns:repeat(3,1fr); gap:2px;
}
.gallery-grid__item { aspect-ratio:4/5; overflow:hidden; position:relative; }
.gallery-grid__item:first-child,
.gallery-grid__item:nth-child(4) {
  grid-column:span 2; aspect-ratio:16/9;
}
.gallery-grid__item img,
.gallery-grid__item .img-placeholder { height:100%; cursor:zoom-in; }
.gallery-grid__item img { transition:transform 0.6s ease; }
.gallery-grid__item:hover img { transform:scale(1.04); }

/* ============================================================  MENU SLIDESHOW  */
.menu-slideshow-wrapper {
  width:100%; overflow:hidden; background:var(--black); margin-bottom:0;
  position:relative;
}
.menu-slideshow-track {
  display:flex; width:max-content;
  animation:slideshow-scroll 25s linear infinite;
}
.menu-slideshow-track:hover { animation-play-state:running; }
.menu-slide {
  flex-shrink:0; width:420px; aspect-ratio:4/3; overflow:hidden;
  border-right:2px solid var(--black);
}
.menu-slide img { width:100%; height:100%; object-fit:cover; display:block; }
/* SVG placeholder slide */
.menu-slide-placeholder {
  flex-shrink:0; width:420px; aspect-ratio:4/3; overflow:hidden;
  border-right:2px solid var(--black); background:var(--card);
  display:flex; align-items:center; justify-content:center;
  position:relative;
}
.menu-slide-placeholder .slide-label {
  font-family:var(--font-display); font-size:0.75rem; font-weight:600;
  letter-spacing:0.2em; text-transform:uppercase; color:var(--gold);
  text-align:center;
}
@keyframes slideshow-scroll {
  0%   { transform:translateX(0); }
  100% { transform:translateX(-50%); }
}

/* ============================================================  MENU  */
.menu-tabs { display:flex; gap:0; border-bottom:1px solid var(--border-w); margin-bottom:48px; }
.menu-tab {
  font-family:var(--font-display); font-size:0.78rem; font-weight:800;
  letter-spacing:0.2em; text-transform:uppercase; padding:16px 32px;
  border:none; background:none; color:rgba(240,235,225,0.45); cursor:pointer;
  border-bottom:2px solid transparent; margin-bottom:-1px; transition:all 0.2s;
}
.menu-tab.active { color:var(--cream); border-bottom-color:var(--gold); }
.menu-tab:hover { color:var(--cream); }
.menu-panel { display:none; }
.menu-panel.active { display:grid; grid-template-columns:repeat(2,1fr); gap:0; }
.menu-category { padding:40px; border:1px solid var(--border-w); margin:-1px 0 0 -1px; }
.menu-category__title {
  font-family:var(--font-display); font-size:0.78rem; font-weight:800;
  letter-spacing:0.3em; text-transform:uppercase; color:var(--gold); margin-bottom:28px;
}
.menu-item {
  display:flex; justify-content:space-between; align-items:baseline;
  padding:10px 0; border-bottom:1px solid rgba(255,255,255,0.04);
  font-size:0.95rem; font-weight:400; color:rgba(240,235,225,0.85);
}
.menu-item:last-child { border-bottom:none; }
.menu-item__price {
  font-family:var(--font-display); font-size:0.85rem; font-weight:700;
  color:var(--gold); white-space:nowrap; margin-left:16px;
}

/* ============================================================  VISIT  */
.visit-layout { display:grid; grid-template-columns:1fr 1fr; gap:0; }
.visit-info { padding:80px 64px 80px 0; }
.visit-map { position:relative; min-height:500px; background:var(--card); }
.visit-map iframe { position:absolute; inset:0; width:100%; height:100%; border:none; filter:grayscale(100%) contrast(1.1); }
.hours-list { margin:32px 0; }
.hours-row {
  display:flex; justify-content:space-between; padding:14px 0;
  border-bottom:1px solid var(--border-w); font-size:0.97rem;
  color:rgba(240,235,225,0.8); font-weight:400;
}
.hours-row:last-child { border-bottom:none; }
.hours-row strong { color:var(--cream); font-weight:600; }
.contact-block { margin-top:40px; display:flex; flex-direction:column; gap:12px; }
.contact-item {
  display:flex; align-items:center; gap:14px; font-size:0.95rem;
  color:rgba(240,235,225,0.7);
}
.contact-item svg { width:18px; height:18px; stroke:var(--gold); fill:none; stroke-width:1.5; flex-shrink:0; }
.contact-item a { color:inherit; transition:color 0.2s; }
.contact-item a:hover { color:var(--gold); }

/* MAP DIRECTIONS BUTTON */
.map-directions {
  display:block; width:100%; padding:16px 24px; background:var(--gold);
  color:var(--black); font-family:var(--font-display); font-size:0.78rem;
  font-weight:800; letter-spacing:0.2em; text-transform:uppercase;
  text-align:center; transition:background 0.2s; border:none; cursor:pointer;
  text-decoration:none;
}
.map-directions:hover { background:var(--gold-d); }

/* ============================================================  ACCESS INFO  */
.access-section { background:var(--dark); border-top:1px solid var(--border); border-bottom:1px solid var(--border); }
.access-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--border-w); }
.access-card {
  background:var(--dark); padding:40px 36px;
}
.access-card__icon { color:var(--gold); margin-bottom:20px; }
.access-card__icon svg { width:48px; height:48px; stroke:currentColor; fill:none; stroke-width:1.5; }
.access-card__title {
  font-family:var(--font-display); font-size:0.92rem; font-weight:800;
  letter-spacing:0.25em; text-transform:uppercase; color:var(--cream); margin-bottom:12px;
}
.access-card p { font-size:0.97rem; font-weight:400; color:rgba(240,235,225,0.75); line-height:1.7; }
.access-card em { color:var(--gold); font-style:normal; }
.access-warning {
  display:flex; align-items:flex-start; gap:16px; padding:28px 36px;
  background:rgba(201,168,76,0.12); border:2px solid var(--gold);
  margin-top:24px;
  font-size:0.97rem; color:var(--cream); line-height:1.6;
  box-shadow: 0 0 24px rgba(201,168,76,0.15);
}
.access-warning strong { color:var(--gold); font-size:1.05rem; }

/* ============================================================  BRANDS PAGE  */
.brands-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--border-w); }
.brand-card {
  background:var(--dark); padding:48px 40px; display:flex; flex-direction:column;
  align-items:center; gap:20px; text-align:center; transition:background 0.2s;
  cursor:pointer;
}
.brand-card:hover { background:var(--card); }
.brand-card__logo {
  width:180px; height:120px; display:flex; align-items:center; justify-content:center;
  opacity:0.85; transition:opacity 0.2s;
}
.brand-card:hover .brand-card__logo { opacity:1; }
.brand-card__logo img { width:100%; height:100%; object-fit:contain; }
.brand-card__name {
  font-family:var(--font-display); font-size:1rem; font-weight:800;
  letter-spacing:0.1em; text-transform:uppercase; color:var(--cream);
}
.brand-card__desc { font-size:0.9rem; font-weight:400; color:rgba(240,235,225,0.6); line-height:1.6; }
.brands-notice {
  border:1px solid var(--border); padding:28px 36px; margin-top:48px;
  font-size:0.9rem; color:rgba(240,235,225,0.55); line-height:1.7; text-align:center;
}
.brands-notice strong { color:var(--gold); }

/* Premium selection (3 images) */
.selection-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:2px; }
.selection-item { aspect-ratio:4/5; overflow:hidden; }

/* ============================================================  CONTACT FORM  */
.form-field { margin-bottom:24px; }
.form-field label {
  display:block; font-family:var(--font-display); font-size:0.72rem;
  font-weight:700; letter-spacing:0.25em; text-transform:uppercase;
  color:rgba(240,235,225,0.5); margin-bottom:8px;
}
.form-field input, .form-field textarea, .form-field select {
  width:100%; background:var(--card); border:1px solid var(--border-w);
  color:var(--cream); font-family:var(--font-body); font-size:0.95rem; font-weight:400;
  padding:14px 18px; outline:none; transition:border-color 0.2s; appearance:none;
}
.form-field input:focus, .form-field textarea:focus { border-color:var(--gold); }
.form-field textarea { resize:vertical; min-height:140px; }
#form-success {
  display:none; padding:24px; border:1px solid var(--border);
  font-family:var(--font-display); font-size:0.85rem; letter-spacing:0.15em;
  text-transform:uppercase; color:var(--gold); text-align:center;
}

/* ============================================================  PRODUCTS/MERCHANDISE  */
.products-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:2px; align-items:stretch; }
.product-item { display:flex; flex-direction:column; background:var(--card); height:100%; }
.product-item__badge {
  position:absolute; top:12px; left:12px;
  font-family:var(--font-display); font-size:0.6rem; font-weight:800;
  letter-spacing:0.2em; text-transform:uppercase; background:var(--gold);
  color:var(--black); padding:4px 10px; z-index:2;
}
.product-item__image {
  flex:none; height:280px; overflow:hidden; position:relative;
  background:var(--dark); border:1px solid var(--border-w);
}
.product-item__image img { width:100%; height:100%; object-fit:contain; transition:transform 0.5s ease; }
.product-item:hover .product-item__image img { transform:scale(1.04); }
.product-item__image .img-placeholder { height:100%; }
.product-item__info { padding:20px 22px 24px; border:1px solid var(--border-w); border-top:none; }
.product-item__cat {
  font-family:var(--font-display); font-size:0.6rem; font-weight:700;
  letter-spacing:0.3em; text-transform:uppercase; color:var(--gold); margin-bottom:6px;
}
.product-item__name {
  font-family:var(--font-display); font-size:1rem; font-weight:800;
  letter-spacing:0.08em; text-transform:uppercase; color:var(--cream); margin-bottom:8px;
}
.product-item__price {
  font-family:var(--font-display); font-size:0.9rem; font-weight:700; color:var(--gold);
}
.products-section-label {
  font-family:var(--font-display); font-size:0.7rem; font-weight:700;
  letter-spacing:0.35em; text-transform:uppercase; color:var(--gold);
  display:flex; align-items:center; gap:14px; padding:40px 0 20px;
  border-top:1px solid var(--border-w); margin-top:60px;
}
.products-section-label:first-child { border-top:none; margin-top:0; padding-top:0; }
.products-section-label::before { content:''; display:block; width:32px; height:1px; background:var(--gold); }

/* ============================================================  FOOTER  */
.footer { background:var(--dark); border-top:1px solid var(--border); padding:64px 48px 40px; }
.footer__inner { max-width:var(--max); margin:0 auto; }
.footer__top {
  display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:64px; margin-bottom:56px;
}
.footer__brand {
  font-family:var(--font-display); font-size:1.1rem; font-weight:800;
  letter-spacing:0.2em; text-transform:uppercase; display:block; margin-bottom:12px;
}
.footer__tagline {
  font-size:0.88rem; font-weight:400; color:rgba(240,235,225,0.5);
  max-width:280px; line-height:1.7;
}
.footer__social { margin-top:28px; }
.footer__social a {
  font-family:var(--font-display); font-size:0.68rem; font-weight:700;
  letter-spacing:0.25em; text-transform:uppercase; color:var(--gold);
  border:1px solid var(--border); padding:8px 18px; transition:all 0.2s;
}
.footer__social a:hover { background:var(--gold); color:var(--black); }
.footer__col h4 {
  font-family:var(--font-display); font-size:0.68rem; font-weight:800;
  letter-spacing:0.3em; text-transform:uppercase; color:rgba(240,235,225,0.4);
  margin-bottom:20px;
}
.footer__col a, .footer__col p {
  display:block; font-size:0.9rem; font-weight:400;
  color:rgba(240,235,225,0.6); margin-bottom:10px; transition:color 0.2s;
}
.footer__col a:hover { color:var(--gold); }
.footer__bottom {
  display:flex; justify-content:space-between; align-items:center;
  padding-top:24px; border-top:1px solid var(--border-w);
  font-family:var(--font-display); font-size:0.65rem; font-weight:500;
  letter-spacing:0.2em; text-transform:uppercase; color:var(--muted);
}

/* ============================================================  PAGE HERO (inner pages)  */
.page-hero {
  padding:160px 48px 80px; background:var(--dark);
  border-bottom:1px solid var(--border);
  position:relative; overflow:hidden;
}
.page-hero__bg {
  position:absolute; inset:0; z-index:0;
}
.page-hero__bg img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.page-hero__bg::after {
  content:''; position:absolute; inset:0;
  background:linear-gradient(to top, rgba(10,10,10,0.92) 0%, rgba(10,10,10,0.6) 60%, rgba(10,10,10,0.4) 100%);
}
.page-hero__inner {
  max-width:var(--max); margin:0 auto; position:relative; z-index:1;
  display:flex; flex-direction:column; align-items:center; text-align:center;
}
.page-hero__inner .section__label,
.page-hero__inner .section__title,
.page-hero__inner p,
.page-hero__inner .section__body {
  position:relative; z-index:2;
}
.page-hero__logo {
  display:block; width:auto; height:320px; object-fit:contain; margin-bottom:-215px;
  filter: none;
  opacity:0.12; position:relative; z-index:0;
}
/* Keep label left-aligned within centered layout */
.page-hero__inner .section__label {
  justify-content:center;
}
.page-hero__inner .section__title {
  font-size:clamp(4rem, 8vw, 9rem);
  font-weight:900;
}

/* ============================================================  DIVIDERS  */
.divider { width:100%; height:1px; background:var(--border-w); margin:0; }

/* ============================================================  REVEAL  */
.reveal { opacity:0; transform:translateY(24px); transition:opacity 0.7s ease, transform 0.7s ease; }
.reveal.visible { opacity:1; transform:none; }
.reveal-delay-1 { transition-delay:0.1s; }
.reveal-delay-2 { transition-delay:0.2s; }
.reveal-delay-3 { transition-delay:0.3s; }

/* ============================================================  RESPONSIVE  */
@media (max-width:1024px) {
  .nav__links { gap:24px; }
  .two-col { grid-template-columns:1fr; gap:40px; }
  .two-col__text { order:1; }
  .two-col__image { order:2; }
  .two-col--reverse .two-col__image { order:2; }
  .about-intro { grid-template-columns:1fr; }
  .about-intro__image { order:2; }
  .about-intro__text { order:1; padding:48px; border-left:none; border-top:none; border-bottom:1px solid var(--border); }
  .visit-layout { grid-template-columns:1fr; }
  .visit-map { min-height:380px; }
  .footer__top { grid-template-columns:1fr 1fr; gap:40px; }
  .brands-grid { grid-template-columns:repeat(2,1fr); }
  .features { grid-template-columns:repeat(2,1fr); }
  .access-grid { grid-template-columns:repeat(2,1fr); }
  .menu-panel.active { grid-template-columns:1fr; }
  .products-grid { grid-template-columns:repeat(2,1fr); }
}

@media (max-width:768px) {
  .nav { padding:0 24px; }
  .nav__links { display:none; }
  .nav__lang { display:none; }
  .nav__hamburger { display:flex; }
  .section, .section--tight { padding:64px 24px; }
  .hero__scroll { right:24px; }
  .hero__title { font-size:clamp(3.8rem,18vw,7rem); }
  .hero { align-items:flex-start; }
  .hero__overlay { display:none; }
  .hero__content { padding:calc(var(--nav-h) + 8px) 24px 56px; margin-top:0; height:100%; display:flex; flex-direction:column; }
  .page-hero { padding:120px 24px 60px; }
  .page-hero__logo { height:60px; }
  .gallery-grid { grid-template-columns:1fr 1fr; }
  .gallery-grid__item:first-child, .gallery-grid__item:nth-child(4) { grid-column:span 2; }
  .visit-info { padding:48px 24px; }
  .footer { padding:48px 24px 32px; }
  .footer__top { grid-template-columns:1fr; gap:32px; }
  .footer__bottom { flex-direction:column; gap:8px; text-align:center; }
  .features { grid-template-columns:1fr 1fr; }
  .access-grid { grid-template-columns:1fr; }
  .brands-grid { grid-template-columns:1fr 1fr; }
  .products-grid { grid-template-columns:1fr 1fr; }
  .product-item__image { height: 220px; }
  .selection-grid { grid-template-columns:1fr; }
  .section__title { font-size:clamp(2.8rem,10vw,4.5rem); }
  .menu-slide { width:280px; }
  .menu-slide-placeholder { width:280px; }
}

@media (max-width:480px) {
  /* features: 2 cols × 3 rows */
  .features { grid-template-columns:repeat(2,1fr); }
  .feature { padding:28px 20px; gap:10px; }
  .feature__icon svg { width:26px; height:26px; }
  .feature__name { font-size:0.8rem; }
  .feature__value { font-size:0.75rem; }
  .brands-grid { grid-template-columns:1fr; }
  .products-grid { grid-template-columns:repeat(2,1fr); gap:12px; }
  .gallery-grid { grid-template-columns:1fr; }
  .gallery-grid__item, .gallery-grid__item:first-child, .gallery-grid__item:nth-child(4) {
    grid-column:span 1; aspect-ratio:4/3;
  }
  .hero__actions { flex-direction:row; align-items:center; flex-wrap:wrap; }
}

/* ============================================================  PRODUCTS IN-STORE NOTICE */
.products-instore-notice {
  margin-top:56px; padding:28px 36px;
  background:rgba(201,168,76,0.15); border:2px solid var(--gold);
  text-align:center;
  box-shadow: 0 0 28px rgba(201,168,76,0.2);
}
.products-instore-notice p {
  font-family:var(--font-display); font-size:0.78rem; font-weight:700;
  letter-spacing:0.2em; text-transform:uppercase; color:var(--gold);
  margin:0;
}

/* ============================================================  MENU UNIFORM GRID */
.menu-uniform-grid {
  display:grid;
  grid-template-columns:repeat(2, 1fr);
  gap:0;
  border:1px solid var(--border-w);
}
.menu-uniform-cell {
  border:1px solid var(--border-w);
  padding:40px;
  margin:-1px 0 0 -1px;
  min-height:320px;
  display:flex; flex-direction:column;
}
.menu-uniform-cell .section__label {
  margin-bottom:16px;
}

/* ============================================================  MOBILE FIXES v7.4  */

/* Hide ALL placeholder labels and crosshair lines — keep only the actual image */
.img-placeholder__label,
.img-placeholder::before,
.img-placeholder::after { display:none !important; }

/* Also hide slide placeholder labels in menu slideshow */
.menu-slide-placeholder .slide-label { display:none !important; }

/* NAV — left logo, right lang+hamburger on mobile */
@media (max-width:768px) {
  .nav { padding:0 16px; height:60px; }
  :root { --nav-h: 60px; }
  .nav__inner { position:relative; justify-content:space-between; }
  .nav__logo {
    position:static; left:auto; transform:none;
    gap:10px;
  }
  .nav__logo-img { height:44px; opacity:1; filter:none; }
  .nav__logo-text > span:first-child { font-size:1.05rem; letter-spacing:0.1em; }
  .nav__logo span { font-size:0.45rem; letter-spacing:0.2em; }
  .nav__lang { display:flex; margin-right:8px; transform:translateX(8px); }
  .nav__hamburger { height:30px; justify-content:center; }
  .nav__mobile__lang { display:none; }
}

/* MENU PAGE — single column on mobile, no zoom needed */
@media (max-width:768px) {
  .menu-uniform-grid {
    grid-template-columns: 1fr !important;
    width:100%;
  }
  .menu-uniform-cell {
    padding:28px 20px;
    min-height:auto;
  }
  .menu-item {
    font-size:0.9rem;
  }
}

/* HOME GALLERY SLIDESHOW — replace static 2-grid with slideshow */
.home-gallery-slideshow-wrapper {
  width:100%; overflow:hidden; background:var(--black);
  position:relative;
}
.home-gallery-slideshow-track {
  display:flex; width:max-content;
  animation:home-gallery-scroll 35s linear infinite;
}
.home-gallery-slide {
  flex-shrink:0; width:620px; aspect-ratio:4/3; overflow:hidden;
  border-right:4px solid var(--black);
}
.home-gallery-slide img { width:100%; height:100%; object-fit:cover; display:block; }

@keyframes home-gallery-scroll {
  0%   { transform:translateX(0); }
  100% { transform:translateX(-50%); }
}

@media (max-width:768px) {
  .home-gallery-slide { width:88vw; }
}

/* Page hero watermark logo — smaller on mobile so it doesn't clog nav */
@media (max-width:768px) {
  .page-hero__logo { height:140px; margin-bottom:-80px; opacity:0.18; }
  .page-hero { padding:100px 20px 30px; }
  .page-hero__inner .section__title { font-size:clamp(3rem,14vw,5rem); }
}

/* Menu page — center the menu grid on desktop too */
@media (min-width:769px) {
  .menu-uniform-grid { max-width:900px; margin:0 auto; }
}

/* ============================================================  PAGE HERO SOLID (black bg, no image) */
.page-hero--solid {
  background: var(--black);
  padding: 96px 48px 96px;
  border-bottom: 1px solid var(--border);
}
.page-hero--solid .page-hero__bg { display: none; }
/* .page-hero--solid .page-hero__logo now visible — logo watermark shown on all inner pages */
.page-hero--solid .page-hero__inner {
  max-width: var(--max); margin: 0 auto;
  display: flex; flex-direction: column; align-items: center; text-align: center;
}
@media (max-width: 768px) {
  .page-hero--solid { padding: 80px 24px 48px; }
}

/* ============================================================  CONTACT PAGE */
.contact-info-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: var(--border-w);
}
.contact-info-card {
  background: var(--dark);
  padding: 36px 28px;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 12px;
}
.contact-info-card__icon {
  color: var(--gold);
}
.contact-info-card__icon svg {
  width: 28px; height: 28px;
  stroke: currentColor; fill: none; stroke-width: 1.5;
}
.contact-info-card__label {
  font-family: var(--font-display); font-size: 0.65rem; font-weight: 700;
  letter-spacing: 0.3em; text-transform: uppercase;
  color: rgba(240,235,225,0.4);
}
.contact-info-card__value {
  font-size: 0.95rem; color: var(--cream); line-height: 1.6;
}
.contact-info-card__value a { color: var(--gold); transition: opacity 0.2s; }
.contact-info-card__value a:hover { opacity: 0.75; }

.contact-map-full {
  width: 100%; height: 380px; position: relative;
}
.contact-map-full iframe {
  position: absolute; inset: 0; width: 100%; height: 100%;
  border: none; filter: invert(1) grayscale(1) brightness(0.85) contrast(1.1);
}
.contact-map-full .map-directions {
  position: absolute; bottom: 0; left: 0; right: 0;
}

.contact-form-wrap {
  max-width: 720px;
  margin: 0 auto;
}
.contact-form__row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
}
@media (max-width: 600px) {
  .contact-info-grid { grid-template-columns: repeat(2, 1fr); }
  .contact-form__row { grid-template-columns: 1fr; gap: 0; }
  .contact-map-full { height: 280px; }
}

/* ============================================================  MENU IMAGE */
.menu-image-wrap {
  max-width: 680px;
  margin: 0 auto;
}
.menu-image {
  width: 100%;
  height: auto;
  object-fit: contain;
  display: block;
  border-radius: 4px;
}

/* ============================================================  PRODUCTS GRID — more breathing room */
.products-grid { gap: 16px; }
@media (max-width:768px) {
  .products-grid { gap: 12px; }
}
/* coming-soon block: always span 2 columns */
.product-item--coming-soon { grid-column: span 2 !important; min-height:0; }

/* ============================================================  PAGE HERO — consistent min-height on inner pages */
.page-hero--solid { min-height: 280px; display: flex; align-items: center; justify-content: center; }

/* ============================================================  CONTACT MAP */
.contact-map-wrap {
  width: 100%; height: 320px; position: relative; margin-top: 48px;
  border: 1px solid var(--border-w);
}
.contact-map-wrap iframe {
  position: absolute; inset: 0; width: 100%; height: 100%;
  border: none; filter: invert(1) grayscale(1) brightness(0.85) contrast(1.1);
}

/* Brand logo images */
.brand-card__logo {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 120px;
  width: 180px;
  height: 120px;
}
.brand-logo-img {
  max-width: 180px;
  max-height: 120px;
  width: 100%;
  height: 100%;
  object-fit: contain;
}
