/* ============================================================
   IBAR Toulouse — landing v4
   Mobile-first. Sable chaud + warm dark. Hero plein-cadre.
   ============================================================ */

:root{
  /* Warm sand / champagne palette (LIGHT but not white) */
  --sand: #e7d6b3;       /* warm tan — main light bg */
  --sand-2: #ddc89c;     /* deeper sand for alternating sections */
  --sand-3: #c9ad7e;     /* edges, dividers */
  --sand-line: rgba(26, 14, 16, 0.14);

  --ink: #1a0e10;
  --ink-soft: #4d3e3a;
  --ink-mute: #5a4738; /* WCAG AA: ~6.4:1 on --sand */

  /* Warm dark palette */
  --dark: #1d1217;       /* warm dark, not pure black */
  --dark-2: #2a181e;
  --dark-3: #382028;
  --dark-line: rgba(232, 201, 140, 0.12);

  --dark-ink: #ecdfc6;
  --dark-ink-soft: #c6b08a;

  /* Accents */
  --gold: #9a6e2f;        /* rich gold for sand bg */
  --gold-light: #d4af6a;  /* gold for dark bg */
  --gold-bright: #e8c98c;
  --red: #b8392b;

  --serif: "Cormorant Garamond", "Times New Roman", serif;
  --sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --display: "Bebas Neue", "Anton", "Impact", sans-serif;
  --mono: "Space Mono", "SF Mono", Menlo, monospace;

  --max: 1320px;
  --pad-x: clamp(20px, 5vw, 64px);

  --ease: cubic-bezier(.2,.7,.2,1);
  --ease-out: cubic-bezier(.16,1,.3,1);
}

*,*::before,*::after{ box-sizing: border-box; }
html{ scroll-behavior: smooth; }
body{
  margin: 0;
  background: var(--sand);
  color: var(--ink);
  font: 400 16px/1.55 var(--sans);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
::selection{ background: var(--ink); color: var(--sand); }
img,video{ display: block; max-width: 100%; height: auto; }
a{ color: inherit; text-decoration: none; }
button{ background: none; border: 0; color: inherit; font: inherit; cursor: pointer; }

.container{
  max-width: var(--max);
  margin: 0 auto;
  padding: 0 var(--pad-x);
}

/* ===== Scroll progress ===== */
.progress{
  position: fixed; top: 0; left: 0; right: 0;
  height: 2px;
  z-index: 300;
  pointer-events: none;
}
.progress > span{
  display: block; height: 100%; width: 0;
  background: var(--gold-bright);
  transition: width .08s linear;
}


/* ===== Typography ===== */
.overline{
  font: 500 11px/1 var(--mono);
  letter-spacing: 0.26em;
  text-transform: uppercase;
  color: var(--gold);
  margin: 0 0 14px;
}
.overline--gold{ color: var(--gold-bright); }
.overline--light{ color: var(--gold-light); }

.display{
  font: 400 clamp(38px, 12vw, 132px)/0.88 var(--display);
  letter-spacing: -0.005em;
  margin: 0 0 22px;
  color: var(--ink);
}
.display em{
  font-family: var(--serif);
  font-weight: 400;
  font-style: italic;
  letter-spacing: -0.015em;
  color: var(--gold);
}
.display--light{ color: var(--dark-ink); }
.display--light em{ color: var(--gold-bright); }

.section-head{ max-width: 720px; margin: 0 auto 36px; }
.section-head--center{ text-align: center; }

.section-lede{
  font: 400 17px/1.55 var(--serif);
  font-style: italic;
  color: var(--ink-soft);
  max-width: 52ch;
}
.section-lede--light{ color: var(--dark-ink-soft); }
.section-head--center .section-lede{ margin-left: auto; margin-right: auto; }

.linkish{ background: none; border: 0; padding: 0; color: inherit; font: inherit; cursor: pointer; }

/* ===== Header (transparent over hero, opaque after) ===== */
.site-head{
  position: fixed; top: 0; left: 0; right: 0;
  z-index: 100;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  padding: 14px var(--pad-x);
  gap: 16px;
  background: rgba(29, 18, 23, 0);
  backdrop-filter: blur(0);
  -webkit-backdrop-filter: blur(0);
  transition: padding .25s var(--ease), background .25s var(--ease), backdrop-filter .25s var(--ease), border-color .25s;
  border-bottom: 1px solid transparent;
}
.site-head.is-scrolled{
  padding: 10px var(--pad-x);
  background: rgba(231, 214, 179, 0.95);
  backdrop-filter: blur(14px) saturate(1.4);
  -webkit-backdrop-filter: blur(14px) saturate(1.4);
  border-bottom-color: var(--sand-line);
}

/* On the dark hero, header text is cream */
.brand{ display: inline-flex; align-items: center; gap: 10px; color: var(--sand); transition: color .25s; }
.site-head.is-scrolled .brand{ color: var(--ink); }
.brand__mark{
  font-family: var(--display);
  font-size: 24px;
  line-height: 1;
  letter-spacing: -0.02em;
  display: inline-block;
  padding: 4px 9px 3px;
  border: 1.5px solid currentColor;
  border-radius: 3px;
}
.brand__sub{
  font: 500 10px/1 var(--mono);
  letter-spacing: 0.22em;
  text-transform: uppercase;
  opacity: 0.85;
}

.nav--desktop{ display: none; gap: 26px; justify-self: center; }
.nav--desktop a{
  font: 500 12px/1 var(--mono);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--sand);
  padding: 6px 0;
  position: relative;
  transition: color .2s, opacity .2s;
  opacity: 0.85;
}
.nav--desktop a::after{
  content: ""; position: absolute; left: 0; right: 100%; bottom: 0; height: 1px; background: currentColor;
  transition: right .35s var(--ease);
}
.nav--desktop a:hover{ opacity: 1; }
.nav--desktop a:hover::after{ right: 0; }
.site-head.is-scrolled .nav--desktop a{ color: var(--ink); opacity: 0.85; }

.head-actions{ display: flex; align-items: center; gap: 10px; justify-self: end; }
.lang{ display: inline-flex; align-items: center; gap: 6px; font: 500 11px/1 var(--mono); letter-spacing: .1em; color: var(--sand); opacity: 0.85; }
.site-head.is-scrolled .lang{ color: var(--ink-soft); }
.lang__btn{ padding: 4px 5px; color: inherit; transition: opacity .2s; opacity: 0.7; }
.lang__btn:hover{ opacity: 1; }
.lang__btn.is-active{ opacity: 1; font-weight: 700; }
.lang--desktop{ display: none; }

/* CTA */
.cta{
  display: inline-flex;
  align-items: center; justify-content: center;
  gap: 8px;
  padding: 12px 22px;
  font: 600 11px/1 var(--mono);
  letter-spacing: 0.2em;
  text-transform: uppercase;
  border-radius: 999px;
  white-space: nowrap;
  transition: transform .25s var(--ease), background .25s, color .25s, border-color .25s, opacity .25s;
}

/* Hero CTAs — larger, icon + label, more readable on photo */
.hero-cta{
  display: inline-flex;
  align-items: center; justify-content: center;
  gap: 12px;
  padding: 16px 24px;
  font: 600 13px/1 var(--mono);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  border-radius: 999px;
  white-space: nowrap;
  transition: transform .25s var(--ease), background .25s, color .25s, border-color .25s;
}
.hero-cta__icon{ flex-shrink: 0; }
.hero-cta__label{
  display: inline-flex; flex-direction: column;
  align-items: flex-start;
  gap: 3px;
  font-weight: 600;
  line-height: 1;
}
.hero-cta__hint{
  font: 400 12px/1.1 var(--sans);
  letter-spacing: 0.02em;
  text-transform: none;
  opacity: 0.85;
}
.hero-cta--gold{
  background: var(--gold-bright);
  color: var(--ink);
  border: 1.5px solid var(--gold-bright);
}
.hero-cta--gold:hover{ background: var(--sand); border-color: var(--sand); transform: translateY(-2px); }
.hero-cta--outline{
  background: rgba(244, 236, 220, 0.06);
  color: var(--sand);
  border: 1.5px solid var(--sand);
  -webkit-backdrop-filter: blur(4px);
  backdrop-filter: blur(4px);
}
.hero-cta--outline:hover{ background: var(--sand); color: var(--ink); transform: translateY(-2px); }
.cta--solid{ background: var(--ink); color: var(--sand); border: 1.5px solid var(--ink); }
.cta--solid:hover{ background: var(--gold); border-color: var(--gold); color: var(--ink); transform: translateY(-2px); }
.cta--gold{ background: var(--gold-bright); color: var(--ink); border: 1.5px solid var(--gold-bright); }
.cta--gold:hover{ background: var(--sand); border-color: var(--sand); transform: translateY(-2px); }
.cta--ghost-light{ background: transparent; color: var(--ink); border: 1.5px solid var(--ink); }
.cta--ghost-light:hover{ background: var(--ink); color: var(--sand); transform: translateY(-2px); }
.cta--ghost-on-photo{ background: rgba(232,201,140,0.08); color: var(--gold-bright); border: 1.5px solid var(--gold-bright); }
.cta--ghost-on-photo:hover{ background: var(--gold-bright); color: var(--ink); transform: translateY(-2px); }
.cta--big{ padding: 16px 30px; font-size: 12px; }
.cta--reserve{ padding: 9px 18px; font-size: 10px; }
/* Header reserve button when over hero — gold on dark */
.cta--reserve{ background: var(--gold-bright); color: var(--ink); border-color: var(--gold-bright); }
.cta--reserve:hover{ background: var(--sand); border-color: var(--sand); transform: translateY(-1px); }

.burger{
  width: 40px; height: 40px;
  display: inline-grid; place-items: center;
  border: 1.5px solid var(--sand);
  border-radius: 50%;
  position: relative;
  color: var(--sand);
  transition: border-color .25s, color .25s;
}
.site-head.is-scrolled .burger{ border-color: var(--ink); color: var(--ink); }
.burger span{
  display: block; width: 16px; height: 1.5px; background: currentColor;
  position: absolute; left: 11px;
  transition: transform .3s var(--ease), opacity .3s, top .3s var(--ease);
}
.burger span:nth-child(1){ top: 14px; }
.burger span:nth-child(2){ top: 19px; }
.burger span:nth-child(3){ top: 24px; }
.burger[aria-expanded="true"] span:nth-child(1){ top: 19px; transform: rotate(45deg); }
.burger[aria-expanded="true"] span:nth-child(2){ opacity: 0; }
.burger[aria-expanded="true"] span:nth-child(3){ top: 19px; transform: rotate(-45deg); }

/* ===== Drawer ===== */
.drawer{
  position: fixed; top: 0; right: 0; bottom: 0;
  width: min(92vw, 380px);
  background: var(--sand);
  z-index: 200;
  transform: translateX(100%);
  transition: transform .45s var(--ease);
  display: flex; flex-direction: column;
  padding: 28px var(--pad-x) 32px;
  border-left: 1px solid var(--sand-line);
}
.drawer.is-open{ transform: translateX(0); }
.drawer__inner{ margin-top: 80px; display: flex; flex-direction: column; gap: 24px; height: 100%; }
.drawer__lang{ display: inline-flex; gap: 12px; padding-bottom: 18px; border-bottom: 1px solid var(--sand-line); }
.drawer__lang .lang__btn{ font: 600 13px/1 var(--mono); padding: 8px 14px; border: 1.5px solid var(--ink); border-radius: 999px; color: var(--ink); opacity: 1; }
.drawer__lang .lang__btn.is-active{ background: var(--ink); color: var(--sand); }
.drawer__nav{ display: flex; flex-direction: column; gap: 4px; }
.drawer__nav a{
  font: 400 30px/1.1 var(--display);
  padding: 12px 0; border-bottom: 1px solid var(--sand-line);
  color: var(--ink); transition: color .2s, padding-left .25s var(--ease);
}
.drawer__nav a:hover{ color: var(--gold); padding-left: 8px; }
.drawer__ctas{ display: flex; flex-direction: column; gap: 10px; margin-top: auto; padding-bottom: 30px; }
.drawer__ctas .cta{ width: 100%; }
.drawer-scrim{
  position: fixed; inset: 0; background: rgba(29, 18, 23, 0.6);
  z-index: 150; opacity: 0; pointer-events: none;
  transition: opacity .35s var(--ease);
  backdrop-filter: blur(2px);
}
.drawer-scrim.is-on{ opacity: 1; pointer-events: auto; }

/* ===== HERO — full-bleed photo with overlay text ===== */
.hero{
  position: relative;
  min-height: 100svh;
  display: grid;
  align-items: end;
  padding: 100px var(--pad-x) 80px;
  overflow: hidden;
  isolation: isolate;
}
.hero__bg{ position: absolute; inset: 0; z-index: -2; }
.hero__bg img{
  width: 100%; height: 100%; object-fit: cover;
  object-position: 50% 12%;  /* keeps IBAR sign and dome in view */
  filter: saturate(1.1) contrast(1.05);
  animation: heroBreath 18s ease-in-out infinite;
}
@keyframes heroBreath{
  0%,100%{ transform: scale(1); }
  50%{ transform: scale(1.05); }
}
.hero__veil{
  position: absolute; inset: 0; z-index: -1;
  background:
    radial-gradient(ellipse at 50% 20%, transparent 0%, rgba(29,18,23,0.15) 60%),
    linear-gradient(to bottom, rgba(29,18,23,0.08) 0%, rgba(29,18,23,0.55) 60%, rgba(29,18,23,0.92) 100%);
}

.hero__inner{
  position: relative; z-index: 1;
  max-width: 760px; margin: 0 auto;
  text-align: center;
  color: var(--sand);
}
.hero__overline{
  font: 500 11px/1 var(--mono);
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--gold-bright);
  margin: 0 0 22px;
}
.hero__title{
  font-family: var(--display);
  font-size: clamp(110px, 28vw, 280px);
  line-height: 0.82;
  letter-spacing: -0.025em;
  margin: 0 0 6px;
  color: var(--sand);
  text-shadow: 0 6px 80px rgba(0,0,0,0.5);
}
.hero__city{
  font: 400 clamp(24px, 4.4vw, 40px)/1 var(--serif);
  font-style: italic;
  color: var(--gold-bright);
  margin: 0 0 28px;
}
.hero__city em{ font-style: italic; }
.hero__tagline{
  max-width: 28ch;
  margin: 0 auto 28px;
  font: 500 clamp(15px, 2.4vw, 22px)/1.35 var(--serif);
  font-style: italic;
  color: var(--sand);
}
.hero__meta{
  display: flex; flex-wrap: wrap; align-items: center; justify-content: center; gap: 12px;
  font: 500 11px/1 var(--mono); letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--dark-ink-soft);
  margin: 0 0 30px;
}
.hero__meta strong{ color: var(--gold-bright); font-weight: 700; }
.hero__meta .dot{ display: inline-block; width: 3px; height: 3px; border-radius: 50%; background: var(--dark-ink-soft); }
.hero__ctas{ display: flex; flex-wrap: wrap; gap: 10px; justify-content: center; }

.hero__scroll{
  position: absolute; bottom: 20px; left: 50%; transform: translateX(-50%);
  width: 22px; height: 36px;
  border: 1.5px solid var(--dark-ink-soft); border-radius: 12px;
  display: grid; place-items: center;
  z-index: 2;
  opacity: 0.7;
}
.hero__scroll span{ width: 2px; height: 6px; background: var(--gold-bright); border-radius: 2px; animation: scrollDot 1.8s ease-in-out infinite; }
@keyframes scrollDot{
  0%{ transform: translateY(-6px); opacity: 0; }
  40%{ opacity: 1; }
  80%{ transform: translateY(6px); opacity: 0; }
  100%{ opacity: 0; }
}

/* ===== Marquee ===== */
.marquee{
  overflow: hidden;
  white-space: nowrap;
  background: var(--dark);
  padding: 14px 0;
}
.marquee__track{
  display: inline-flex; gap: 50px;
  animation: marquee 40s linear infinite;
  font: 400 20px/1 var(--display);
  letter-spacing: 0.04em;
  color: var(--gold-light);
  text-transform: uppercase;
  padding-left: 50px;
}
.marquee__track span{ flex-shrink: 0; }
@keyframes marquee{ to{ transform: translateX(-50%); } }

/* ===== Dancefloor — moment d'émotion ===== */
.dancefloor{
  position: relative;
  min-height: 80vh;
  display: grid;
  align-items: end;
  padding: 100px var(--pad-x) 90px;
  overflow: hidden;
  isolation: isolate;
  color: var(--dark-ink);
  background: var(--dark);
}
.dancefloor__bg{ position: absolute; inset: 0; z-index: -2; }
.dancefloor__bg img{
  width: 100%; height: 100%; object-fit: cover;
  object-position: center 35%;
  filter: saturate(1.15) contrast(1.05);
  animation: danceBreath 20s ease-in-out infinite;
}
@keyframes danceBreath{
  0%,100%{ transform: scale(1); }
  50%{ transform: scale(1.05); }
}
.dancefloor__veil{
  position: absolute; inset: 0; z-index: -1;
  background:
    radial-gradient(ellipse at 50% 70%, transparent 0%, rgba(29,18,23,0.25) 60%),
    linear-gradient(to bottom, rgba(29,18,23,0.55) 0%, rgba(29,18,23,0.35) 30%, rgba(29,18,23,0.55) 70%, rgba(29,18,23,1) 100%);
}
.dancefloor__inner{
  position: relative; z-index: 1;
  max-width: 720px;
  margin: 0 auto;
  text-align: center;
}
.dancefloor__lede{
  font: 400 18px/1.5 var(--serif);
  font-style: italic;
  color: var(--dark-ink);
  margin: 18px auto 0;
  max-width: 38ch;
  text-shadow: 0 2px 20px rgba(0,0,0,0.5);
}
.dancefloor__lede strong{ color: var(--gold-bright); font-style: normal; font-weight: 600; }
.dancefloor .display{ text-shadow: 0 4px 30px rgba(0,0,0,0.6); }
@media (prefers-reduced-motion: reduce){
  .dancefloor__bg img{ animation: none; }
}

/* ===== Arrival — full-bleed unified (queue-red photo + overlay text) ===== */
.arrival{
  position: relative;
  min-height: 80vh;
  display: grid;
  align-items: end;
  padding: 100px var(--pad-x) 90px;
  overflow: hidden;
  isolation: isolate;
  color: var(--dark-ink);
  background: var(--dark);
}
.arrival__bg{ position: absolute; inset: 0; z-index: -2; }
.arrival__bg img{
  width: 100%; height: 100%; object-fit: cover;
  object-position: center 35%;
  filter: saturate(1.18) contrast(1.05);
}
.arrival__veil{
  position: absolute; inset: 0; z-index: -1;
  background:
    linear-gradient(to bottom, rgba(29,18,23,0.35) 0%, rgba(29,18,23,0.55) 50%, rgba(29,18,23,0.95) 100%);
}
.arrival__inner{
  position: relative; z-index: 1;
  max-width: 820px;
  margin: 0 auto;
  width: 100%;
}
.arrival .display{ margin-bottom: 24px; text-shadow: 0 4px 30px rgba(0,0,0,0.6); }
.arrival__lines{ display: flex; flex-direction: column; gap: 12px; }
.arrival__lines p{
  margin: 0;
  font: 400 18px/1.45 var(--serif);
  font-style: italic;
  color: var(--dark-ink);
  text-shadow: 0 2px 20px rgba(0,0,0,0.5);
}
.arrival__lines p strong{ color: var(--gold-bright); font-style: normal; font-weight: 600; }

/* ===== VIP — text-only rate cards ===== */
.vip{ padding: 80px 0 80px; background: var(--dark); color: var(--dark-ink); }
.rates{
  list-style: none; padding: 0; margin: 0 0 32px;
  display: grid; grid-template-columns: 1fr;
  gap: 14px;
}
.rate{
  position: relative;
  display: grid;
  grid-template-columns: 1fr auto;
  grid-template-rows: auto auto;
  gap: 4px 18px;
  align-items: end;
  padding: 22px 22px 22px;
  background: var(--dark-2);
  border: 1px solid var(--dark-line);
  border-radius: 6px;
  transition: border-color .3s, background .3s, transform .3s var(--ease);
}
.rate:hover{ border-color: var(--gold-light); background: var(--dark-3); transform: translateY(-2px); }
.rate__head{ grid-column: 1; grid-row: 1; }
.rate__name{
  font: 400 22px/1 var(--display);
  letter-spacing: 0.04em;
  color: var(--dark-ink-soft);
  margin: 0 0 4px;
  text-transform: uppercase;
}
.rate__name strong{ color: var(--dark-ink); font-weight: 400; }
.rate__sub{
  font: 400 13px/1.3 var(--serif);
  font-style: italic;
  color: var(--gold-light);
  margin: 0;
}
.rate__price{
  grid-column: 2; grid-row: 1;
  font: 400 48px/1 var(--display);
  color: var(--gold-bright);
  display: inline-flex; align-items: flex-start; gap: 2px;
}
.rate__price sup{ font-size: 18px; line-height: 1; padding-top: 6px; color: var(--gold-light); }
.rate__feats{
  grid-column: 1 / -1; grid-row: 2;
  list-style: none; padding: 14px 0 0; margin: 8px 0 0;
  display: flex; flex-wrap: wrap; gap: 8px 16px;
  border-top: 1px solid var(--dark-line);
}
.rate__feats li{
  font: 500 10px/1.4 var(--mono);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--dark-ink-soft);
  display: flex; align-items: center; gap: 8px;
}
.rate__feats li::before{ content: ""; width: 12px; height: 1px; background: var(--gold-light); }

.rate--flag{ border-color: var(--gold-light); box-shadow: 0 0 0 1px var(--gold-light) inset; }
.rate__flag{
  position: absolute; top: -10px; right: 18px; z-index: 2;
  background: var(--gold-light); color: var(--dark);
  font: 700 10px/1 var(--mono);
  letter-spacing: 0.2em; text-transform: uppercase;
  padding: 6px 10px; border-radius: 2px;
}

.vip__note{
  text-align: center;
  font: 400 13px/1.5 var(--serif);
  font-style: italic;
  color: var(--dark-ink-soft);
  max-width: 52ch;
  margin: 0 auto 28px;
}
.vip__cta{ display: flex; flex-wrap: wrap; gap: 12px; justify-content: center; }
.vip__cta .cta--ghost-light{ color: var(--dark-ink); border-color: var(--dark-ink); }
.vip__cta .cta--ghost-light:hover{ background: var(--dark-ink); color: var(--dark); }

/* ===== Ladies (visual scroll moment) ===== */
.ladies{
  position: relative;
  padding: 90px var(--pad-x) 90px;
  overflow: hidden;
  text-align: center;
}
.ladies__bg{ position: absolute; inset: 0; z-index: -2; }
.ladies__bg img{
  width: 100%; height: 100%; object-fit: cover;
  filter: brightness(0.65) saturate(1.1);
  transform: scale(1.05);
}
.ladies__veil{
  position: absolute; inset: 0; z-index: -1;
  background:
    radial-gradient(ellipse at center, rgba(176,134,67,0.12), transparent 60%),
    linear-gradient(to bottom, rgba(29,18,23,0.55), rgba(29,18,23,0.75));
}
.ladies__inner{ position: relative; max-width: 600px; margin: 0 auto; }
.ladies__sub{
  font: 400 17px/1.55 var(--serif); font-style: italic;
  color: var(--dark-ink); max-width: 40ch; margin: 14px auto 0;
}
.ladies__sub strong{ color: var(--gold-bright); font-style: normal; font-weight: 600; }

/* ===== Venir (sand-2) ===== */
.venir{ padding: 80px 0; background: var(--sand-2); }
.venir__grid{ display: grid; grid-template-columns: 1fr; gap: 32px; margin-bottom: 24px; }
.venir__lede{
  font: 400 17px/1.55 var(--serif); font-style: italic;
  color: var(--ink-soft); max-width: 44ch;
}
.venir__lede strong{ color: var(--ink); font-style: normal; font-weight: 600; }
.meta{
  display: grid; grid-template-columns: 1fr 1fr; gap: 22px 18px;
  margin: 0; padding: 24px 0 0;
  border-top: 1px solid var(--sand-line);
}
.meta div{ display: flex; flex-direction: column; gap: 6px; }
.meta dt{
  font: 500 10px/1 var(--mono);
  letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--gold);
}
.meta dd{ margin: 0; font: 400 15px/1.4 var(--sans); color: var(--ink); }
.map-link{
  display: inline-flex; align-items: center; gap: 8px;
  font: 500 11px/1 var(--mono); letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--ink);
  padding: 10px 0;
  border-bottom: 1.5px solid var(--ink);
  transition: gap .25s;
}
.map-link:hover{ gap: 14px; }

/* ===== Contact — Direction + Recrutement ===== */
.contact{ padding: 80px 0 80px; background: var(--sand); }
.contact .section-head{ margin-bottom: 44px; }

.contact__blocks{
  display: grid; grid-template-columns: 1fr;
  gap: 18px;
  max-width: 960px; margin: 0 auto;
}
.info-block{
  padding: 32px 28px 32px;
  background: var(--sand-2);
  border: 1px solid var(--sand-line);
  border-radius: 8px;
  transition: border-color .3s, transform .3s var(--ease);
  position: relative;
  display: flex; flex-direction: column;
  gap: 14px;
}
.info-block:hover{ border-color: var(--ink); transform: translateY(-3px); }
.info-block__lbl{
  font: 500 10px/1 var(--mono);
  letter-spacing: 0.26em; text-transform: uppercase;
  color: var(--gold);
  margin: 0;
}
.info-block__title{
  font: 400 28px/1.05 var(--display);
  letter-spacing: 0.01em;
  color: var(--ink);
  margin: 0;
  text-transform: uppercase;
}
.info-block__lede{
  font: 400 15px/1.55 var(--serif);
  font-style: italic;
  color: var(--ink-soft);
  margin: 0;
  max-width: 38ch;
}
.info-block__link{
  display: inline-flex; align-items: center; gap: 10px;
  margin-top: auto; padding-top: 8px;
  font: 600 12px/1 var(--mono);
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--ink);
  align-self: flex-start;
  border-bottom: 1.5px solid var(--ink);
  padding-bottom: 6px;
  transition: gap .25s, color .25s;
}
.info-block__link:hover{ gap: 16px; color: var(--gold); border-color: var(--gold); }
.info-block__arrow{ font-size: 16px; }

/* ===== Footer ===== */
.foot{ padding: 50px 0 26px; background: var(--dark); color: var(--dark-ink); }
.foot__top{ display: grid; grid-template-columns: 1fr; gap: 26px; padding-bottom: 28px; border-bottom: 1px solid var(--dark-line); }
.foot__brand{ display: flex; flex-direction: column; gap: 14px; }
.foot__brand .brand__mark{ align-self: flex-start; color: var(--gold-light); border-color: var(--gold-light); }
.foot__brand p{ font: 400 14px/1.5 var(--sans); color: var(--dark-ink-soft); max-width: 36ch; margin: 0; }
.foot__nav{ display: flex; flex-wrap: wrap; gap: 14px 20px; }
.foot__nav a, .foot__nav button{
  font: 500 11px/1 var(--mono);
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--dark-ink-soft);
  transition: color .2s;
}
.foot__nav a:hover, .foot__nav button:hover{ color: var(--dark-ink); }
.foot__bot{
  display: flex; justify-content: space-between; align-items: center;
  padding-top: 20px;
  font: 400 11px/1 var(--mono); letter-spacing: 0.12em;
  color: var(--dark-ink-soft);
  flex-wrap: wrap; gap: 12px;
}

/* ===== Legal modal ===== */
.legal{
  border: 0;
  background: var(--sand);
  color: var(--ink);
  width: min(620px, 92vw);
  max-height: 86vh;
  border-radius: 6px;
  padding: 0;
  border: 1px solid var(--sand-line);
}
.legal::backdrop{ background: rgba(29,18,23,0.7); backdrop-filter: blur(6px); }
.legal__inner{ padding: 36px 32px 40px; max-height: 86vh; overflow-y: auto; }
.legal__close{
  position: absolute; top: 12px; right: 12px;
  width: 36px; height: 36px;
  border-radius: 50%;
  display: grid; place-items: center;
  font-size: 24px; line-height: 1;
  color: var(--ink-soft);
  background: var(--sand-2);
}
.legal__close:hover{ color: var(--ink); }
.legal h2{ font: 400 32px/1 var(--display); margin: 0 0 24px; color: var(--ink); }
.legal h3{
  font: 500 11px/1 var(--mono); letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--gold); margin: 24px 0 10px;
}
.legal p{ font: 400 14px/1.55 var(--sans); color: var(--ink-soft); margin: 0 0 10px; }
.legal a{ color: var(--ink); border-bottom: 1px solid var(--ink); }

/* ===== Reveal ===== */
.reveal{
  opacity: 0; transform: translateY(20px);
  transition: opacity .9s var(--ease-out), transform .9s var(--ease-out);
}
.reveal.is-in{ opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce){
  .reveal{ opacity: 1; transform: none; transition: none; }
  .hero__bg img{ animation: none; }
  .marquee__track{ animation: none; }
}

/* ============================================================
   Breakpoints — MOBILE-FIRST
   ============================================================ */

@media (min-width: 720px){
  .rates{ grid-template-columns: 1fr 1fr; gap: 18px; }
  .contact__blocks{ grid-template-columns: 1fr 1fr; }
  .foot__top{ grid-template-columns: 1fr auto; align-items: end; }
  .foot__nav{ justify-content: flex-end; }
  .meta{ grid-template-columns: 1fr 1fr; }
}

@media (min-width: 1000px){
  .nav--desktop{ display: inline-flex; }
  .lang--desktop{ display: inline-flex; }
  .burger{ display: none; }

  .venir__grid{ grid-template-columns: 1fr 1fr; gap: 80px; align-items: start; }
  .meta{ border-top: 0; padding-top: 0; }

  .rates{ grid-template-columns: repeat(4, 1fr); }

  .hero{ padding: 140px var(--pad-x) 100px; }
  .hero__bg img{ object-position: 50% 18%; }

  /* Cinema flow on desktop — sections feel like one continuous film */
  .dancefloor,
  .arrival,
  .ladies{ min-height: 100vh; padding-top: 140px; padding-bottom: 120px; }

  .dancefloor__inner,
  .arrival__inner,
  .ladies__inner{ max-width: 960px; }
}

@media (max-width: 600px){
  .brand__sub{ display: none; }
  .head-actions .cta--reserve{ display: none; }
  .hero__title{ font-size: clamp(90px, 26vw, 160px); }
}
