@font-face {
  font-family: 'Gilroy';
  src: local('Gilroy Light'), local('Gilroy-Light'), local('Gilroy-Thin'),
       url('../fonts/Gilroy-Medium.woff2') format('woff2'),
       url('../fonts/Gilroy-Medium.ttf') format('truetype');
  font-weight: 300;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Gilroy';
  src: local('Gilroy Regular'), local('Gilroy-Regular'), local('Gilroy'),
       url('../fonts/Gilroy-Medium.woff2') format('woff2'),
       url('../fonts/Gilroy-Medium.ttf') format('truetype');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Gilroy';
  src: local('Gilroy Medium'), local('Gilroy-Medium'), local('Gilroy'),
       url('../fonts/Gilroy-Medium.woff2') format('woff2'),
       url('../fonts/Gilroy-Medium.ttf') format('truetype');
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}
/* We do not define remote webfont files for weights 600 (SemiBold), 700 (Bold), and 800 (ExtraBold)
   to allow:
   1. The browser to load the REAL local Gilroy SemiBold/Bold files if the client has them installed on their machine.
   2. The browser to automatically apply high-quality synthetic bolding to Gilroy-Medium if the font is not installed locally.
*/
@font-face {
  font-family: 'Gilroy';
  src: local('Gilroy SemiBold'), local('Gilroy-SemiBold'), local('Gilroy Medium'), local('Gilroy');
  font-weight: 600;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Gilroy';
  src: local('Gilroy Bold'), local('Gilroy-Bold'), local('Gilroy Medium'), local('Gilroy');
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Gilroy';
  src: local('Gilroy ExtraBold'), local('Gilroy-ExtraBold'), local('Gilroy-Bold'), local('Gilroy');
  font-weight: 800;
  font-style: normal;
  font-display: swap;
}

/* ══════════════════════════════════════════════════════════
   PM Global — Shared styles across ALL pages
   Banner, Nav, Footer, Cart Drawer, Cookie Popup,
   Typography, Grain Texture, Utilities
   ══════════════════════════════════════════════════════════ */

/* ── VARIABLES ──────────────────────────────── *
 * Aligned pixel-perfect with the client mockups (exigence-client/*.html).
 * Reference: index.html :root block (lines 23-39).
 *
 * Variables marked [custom] are theme-specific (not in mockup) and kept
 * for components that exist only in PrestaShop integration (cart drawer,
 * sticky footer bar, panel surfaces, etc.).
 */
:root {
  --bg:      #FAFAF8;
  --bg2:     #EDEAE2;
  --dk:      #0B0B09;
  --dk2:     #13161F;
  --text:    #1A1916;
  --muted:   #8A8580;
  --border:  #E0DDD5;
  --gold:    #A8812A;
  --tr:      0.28s cubic-bezier(.25,.1,.25,1);
  --g:       clamp(24px, 3.8vw, 60px);
  --mw:      1480px;
  --nav-h:   56px;
  --fd:      'Bebas Neue', sans-serif;
  --fb:      'Gilroy', sans-serif;
  --fi:      'Cormorant Garamond', serif;

  /* [custom] Theme-only variables (not in mockup) */
  --panel:    #F2EFE8;                              /* panel surfaces */
  --clay:     #B84A2E;                              /* accent red */
  --success:  #2D7A4F;                              /* success green */
  --white:    #FFFFFF;
  --hover-bg: #EDEAE2;
  --banner-h: 32px;                                 /* announcement banner height */
  --fbar-h:   48px;                                 /* sticky footer bar height */

  /* [custom] Overrides for legacy main.css globals that clash with mockup */
  --default-color:     #1A1916;
  --heading-color:     #1A1916;
  --background-color:  #FAFAF8;
}

/* ── HOMEPAGE SPECIFIC OVERRIDES ──────────────── */
/* Aligned pixel-perfect with index.html mockup (pure white background, wider grid) */
body#index {
  --bg:     #FFFFFF;
  --bg2:    #F3F1EC;
  --dk:     #0B0E15;
  --dk2:    #13161F;
  --text:   #0C0C0C;
  --muted:  #787878;
  --border: #E2DFDA;
  --gold:   #B08A26;
  --tr:     0.38s cubic-bezier(.25,.1,.25,1);
  --g:      clamp(16px, 3.5vw, 56px);
  --mw:     1540px;
  --nav-h:  55px;

  /* Surcharge for legacy override variables */
  --default-color:     #0C0C0C;
  --heading-color:     #0C0C0C;
  --background-color:  #FFFFFF;
}
body#index .footer__brand-name {
  font-size: 20px !important;
  line-height: 20px !important;
  color: rgba(255, 255, 255, 0.9) !important;
  letter-spacing: 0.22em !important;
}
body#index .footer__desc {
  color: rgba(255, 255, 255, 0.26) !important;
}

body#index .hero__h1 em,
body#index .hero h1 em {
  font-family: var(--fi) !important;
  font-style: italic !important;
  font-size: 0.76em !important;
  font-weight: 300 !important;
  text-transform: none !important;
  color: rgba(255, 255, 255, 0.76) !important;
  opacity: 1 !important;
  letter-spacing: 0.02em !important;
  display: inline-block;
}


/* ── RESET (supplement to theme reset) ───────── */
*, *::before, *::after { box-sizing: border-box; }
a    { text-decoration: none; color: inherit; }
ul   { list-style: none; }
button { cursor: pointer; font-family: inherit; border: none; background: none; }

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    transition-duration: 0.01ms !important;
  }
}

/* ── GRAIN TEXTURE ──────────────────────────── */
body::before {
  content: '';
  position: fixed;
  inset: 0;
  z-index: 9998;
  pointer-events: none;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size: 160px 160px;
  opacity: 0.024;
}

/* ── FOCUS VISIBLE ────────────────────────────── */
:focus-visible {
  outline: 2px solid var(--gold);
  outline-offset: 3px;
}

/* ── ANNOUNCEMENT BANNER ───────────────────────── */
.banner {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 910;
  height: var(--banner-h);
  background: var(--dk);
  overflow: hidden;
  transition: height .3s, opacity .3s;
  /* Override main.css .banner { display:inline-block; padding-left:100%; animation:scroll... } */
  display: block;
  padding-left: 0;
  animation: none;
}
.banner.hidden, .banner.gone { height: 0 !important; opacity: 0; pointer-events: none; }
.banner__ticker, .banner__track {
  position: absolute;
  top: 0; bottom: 0;
  left: 0; right: 44px;
  overflow: hidden;
}
.banner span { padding-right: 0; }
.banner__msg {
  position: absolute;
  top: 50%;
  left: 0;
  white-space: nowrap;
  font: 300 9px/1 var(--fb);
  letter-spacing: .26em;
  text-transform: uppercase;
  color: rgba(255,255,255,.72);
  transform: translateY(-50%) translateX(100vw);
}
.banner__msg.run, .banner__msg.go {
  animation: banScroll 12s linear forwards;
}
@keyframes banScroll {
  from { transform: translateY(-50%) translateX(100vw); }
  to   { transform: translateY(-50%) translateX(calc(-100% - 40px)); }
}
@keyframes bannerTick {
  from { transform: translateY(-50%) translateX(100vw); }
  to   { transform: translateY(-50%) translateX(calc(-100% - 40px)); }
}
.banner__close {
  position: absolute;
  right: 0; top: 0; bottom: 0;
  width: 44px;
  display: flex; align-items: center; justify-content: center;
  color: rgba(255,255,255,.28);
  cursor: pointer;
  background: none; border: none;
  transition: color .2s;
  z-index: 2;
}
.banner__close:hover { color: rgba(255,255,255,.8); }
.banner__close svg { width: 10px; height: 10px; stroke: currentColor; stroke-width: 2; fill: none; }

/* ── NAV — COMMON ──────────────────────────────── */
.nav {
  position: fixed;
  top: var(--banner-h);
  left: 0; right: 0;
  z-index: 900;
  height: var(--nav-h);
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  padding: 0 var(--g);
  transition: background var(--tr), border-color var(--tr), top .3s ease, transform .38s cubic-bezier(.25,.1,.25,1), box-shadow .3s;
}
.nav.scrolled {
  box-shadow: 0 1px 16px rgba(11,11,9,.08);
}
.nav--hidden { transform: translateY(-100%); }

/* ── NAV — INNER PAGES (always solid) ──────────── */
.nav--solid {
  background: rgba(250,250,248,.96);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-bottom: 1px solid var(--border);
}

/* ── NAV — HOMEPAGE (transparent → solid on scroll) ── */
.nav--hero .nav__logo img {
  filter: invert(1) brightness(10);
  transition: filter var(--tr);
}
.nav--hero.lit .nav__logo img {
  filter: invert(0) brightness(1);
}
.nav--hero.lit {
  background: rgba(250,250,248,.95);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-bottom: 1px solid var(--border);
}

.nav__logo {
  display: flex;
  align-items: center;
}
.nav__logo img {
  height: clamp(13px, 1.1vw, 16px);
  width: auto;
  display: block;
  transition: filter var(--tr);
}

/* Nav Links */
.nav__links {
  display: flex;
  gap: clamp(18px, 2.4vw, 40px);
  padding: 0;
  margin: 0;
}
.nav__links a {
  font-family: var(--fb);
  font-size: 11px;
  font-weight: 300;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  transition: color var(--tr);
  position: relative;
}
.nav__links a::after {
  content: '';
  position: absolute;
  bottom: -2px; left: 0; right: 0;
  height: 1px;
  background: currentColor;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.26s ease;
}
.nav__links a:hover::after { transform: scaleX(1); }
.nav__links a.active::after { transform: scaleX(1); }

/* Disable focus outline on nav elements to match mockup design */
.nav a:focus,
.nav a:active,
.nav a:focus-visible,
.nav button:focus,
.nav button:active,
.nav button:focus-visible,
.nav__lang:focus,
.nav__lang:active,
.nav__lang:focus-visible,
.mob-menu a:focus,
.mob-menu a:active,
.mob-menu a:focus-visible,
.mob-menu button:focus,
.mob-menu button:active,
.mob-menu button:focus-visible {
  outline: none !important;
  box-shadow: none !important;
  border: none !important;
}


/* Inner pages link colors */
.nav--solid .nav__links a { color: var(--muted); }
.nav--solid .nav__links a:hover { color: var(--text); }
.nav--solid .nav__links a.active { color: var(--dk); }

/* Homepage link colors */
.nav--hero .nav__links a { color: rgba(255,255,255,.65); }
.nav--hero .nav__links a:hover { color: #fff !important; }
.nav--hero.lit .nav__links a { color: var(--muted); }
.nav--hero.lit .nav__links a:hover { color: var(--text) !important; }

/* Nav Icons */
.nav__icons {
  display: flex;
  gap: 16px;
  justify-content: flex-end;
  align-items: center;
}
.nav__icon {
  transition: color var(--tr);
  display: flex;
  cursor: pointer;
}
.nav__icon svg {
  width: 18px; height: 18px;
  fill: none; stroke: currentColor;
  stroke-width: 1.5; stroke-linecap: round; stroke-linejoin: round;
}

/* Inner pages icon colors */
.nav--solid .nav__icon { color: var(--muted); }
.nav--solid .nav__icon:hover { color: var(--text) !important; }

/* Homepage icon colors */
.nav--hero .nav__icon { color: rgba(255,255,255,.65); }
.nav--hero .nav__icon:hover { color: #fff !important; }
.nav--hero.lit .nav__icon { color: var(--muted); }
.nav--hero.lit .nav__icon:hover { color: var(--text) !important; }

/* Cart badge */
.nav__cart { position: relative; }
.nav__cart-badge {
  position: absolute;
  top: -7px; right: -8px;
  min-width: 16px; height: 16px;
  padding: 0 4px;
  background: #C0392B;
  color: #fff;
  font-family: var(--fb);
  font-size: 9px;
  font-weight: 400;
  line-height: 16px;
  text-align: center;
  border-radius: 999px;
  pointer-events: none;
  display: block;
}

/* Language switcher */
.nav__lang {
  position: relative;
  display: flex;
  align-items: center;
  gap: 5px;
  cursor: pointer;
  font: 300 10px/1 var(--fb);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  text-decoration: none;
  transition: color var(--tr);
}
.nav__lang svg {
  width: 16px; height: 16px;
  fill: none; stroke: currentColor;
  stroke-width: 1.5; stroke-linecap: round; stroke-linejoin: round;
}
.nav__lang-drop {
  position: absolute;
  top: calc(100% + 12px); right: 0;
  background: rgba(250,250,248,.98);
  backdrop-filter: blur(12px);
  border: 1px solid var(--border);
  min-width: 80px;
  padding: 6px 0;
  z-index: 200;
  opacity: 0;
  pointer-events: none;
  transform: scale(0.82) translateY(-8px);
  transform-origin: top right;
  transition: opacity .14s ease, transform .14s ease-in;
}
.nav__lang.open .nav__lang-drop {
  opacity: 1;
  pointer-events: auto;
  transform: scale(1) translateY(0);
  transition: opacity .18s ease, transform .3s cubic-bezier(0.22, 1, 0.36, 1);
}
.nav__lang-drop a {
  display: block;
  padding: 8px 16px;
  font: 300 10px/1 var(--fb);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--muted);
  text-decoration: none;
  transition: color var(--tr);
}
.nav__lang-drop a:hover, .nav__lang-drop a.active { color: var(--dk); }

/* Inner pages lang colors */
.nav--solid .nav__lang { color: var(--muted); }
.nav--solid .nav__lang:hover { color: var(--text) !important; }

/* Homepage lang colors */
.nav--hero .nav__lang { color: rgba(255,255,255,.65); }
.nav--hero .nav__lang:hover { color: #fff !important; }
.nav--hero.lit .nav__lang { color: var(--muted); }
.nav--hero.lit .nav__lang:hover { color: var(--text) !important; }

/* ── HAMBURGER ────────────────────────────────── */
.nav__burger {
  display: none;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 5px;
  width: 44px; height: 44px;
  cursor: pointer;
  background: none;
  border: none;
  /* Remove from grid flow on desktop so 3-col grid works with logo|links|icons */
  position: absolute;
}
.nav__burger span {
  display: block;
  width: 22px; height: 1px;
  transition: background var(--tr), transform var(--tr), opacity var(--tr);
  transform-origin: center;
}
.nav--solid .nav__burger span { background: var(--text); }
.nav--hero .nav__burger span { background: rgba(255,255,255,.75); }
.nav--hero.lit .nav__burger span { background: var(--text); }

.nav__burger.open span:nth-child(1) { transform: translateY(6px) rotate(45deg); }
.nav__burger.open span:nth-child(2) { opacity: 0; transform: scaleX(0); }
.nav__burger.open span:nth-child(3) { transform: translateY(-6px) rotate(-45deg); }

@media (max-width: 1058px) {
  .nav__links { display: none; }
  /* Show burger as grid column 1 (left), restore to grid flow */
  .nav__burger { display: flex; position: static; }
  /* Center the logo */
  .nav__logo { justify-content: center; }
  /* Hide desktop-only icons on mobile */
  .nav__desk-only { display: none !important; }
  /* Cart stays on the right */
  .nav__icons {
    justify-content: flex-end;
  }
}

/* ── MOBILE MENU DRAWER (matches product-mobile.html mockup) ── */
.mob-overlay {
  position: fixed; inset: 0;
  z-index: 940;
  background: rgba(11,14,21,.45);
  opacity: 0;
  pointer-events: none;
  transition: opacity .28s;
}
.mob-overlay.open {
  opacity: 1;
  pointer-events: auto;
}
.mob-menu {
  position: fixed;
  top: 0; left: 0; bottom: 0;
  z-index: 950;
  width: 280px;
  max-width: 82vw;
  background: var(--bg);
  transform: translateX(-100%);
  transition: transform .3s cubic-bezier(.32,.72,0,1);
  display: flex;
  flex-direction: column;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}
.mob-menu.open {
  transform: translateX(0);
}
.mob-menu__head {
  padding: calc(18px + env(safe-area-inset-top, 0px)) 20px 18px;
  border-bottom: 1px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-shrink: 0;
}
.mob-menu__brand {
  font-family: var(--fd);
  font-size: 16px;
  letter-spacing: .22em;
  color: var(--dk);
}
.mob-menu__close {
  width: 36px; height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--muted);
  cursor: pointer;
  background: none;
  border: none;
}
.mob-menu__close svg {
  width: 14px; height: 14px;
  stroke: currentColor;
  stroke-width: 2;
  fill: none;
}
.mob-menu__links {
  flex: 1;
  padding: 8px 0;
}
.mob-menu__link {
  display: flex;
  align-items: center;
  padding: 14px 20px;
  width: 100%;
  font: 300 12px/1 var(--fb);
  letter-spacing: .12em;
  text-transform: uppercase;
  color: #555;
  cursor: pointer;
  text-align: left;
  min-height: 44px;
  transition: color var(--tr), background var(--tr);
}
.mob-menu__link:hover {
  color: var(--dk);
  background: var(--bg2);
}
.mob-menu__sep {
  height: 1px;
  background: var(--border);
  margin: 6px 20px;
}
.mob-menu__bot {
  padding: 16px 20px;
  padding-bottom: calc(16px + env(safe-area-inset-bottom, 0px));
  border-top: 1px solid var(--border);
  flex-shrink: 0;
}
.mob-menu__lang {
  display: flex;
  gap: 8px;
}
.mob-menu__lang-btn {
  font: 300 10px/1 var(--fb);
  letter-spacing: .12em;
  text-transform: uppercase;
  color: #aaa;
  border: 1px solid var(--border);
  padding: 6px 12px;
  cursor: pointer;
  background: none;
  text-decoration: none;
  transition: color var(--tr), border-color var(--tr);
}
.mob-menu__lang-btn:hover {
  color: var(--text);
  border-color: var(--text);
}
.mob-menu__lang-btn.active {
  color: var(--dk);
  border-color: var(--dk);
}

/* ── PUSH (spacer for fixed banner+nav) ────────── */
.pm-push {
  height: calc(var(--banner-h) + var(--nav-h));
}

/* ── HERO ─────────────────────────────────────── */
.hero {
  position: relative;
  height: 100vh;
  min-height: 580px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  align-items: stretch;
  padding: 0 var(--g) clamp(56px, 8vh, 96px);
  background: transparent;
  color: var(--text);
}
.hero__vid {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
}
.hero__mask {
  position: absolute; inset: 0;
  background: linear-gradient(
    165deg,
    rgba(11,14,21,.02) 0%,
    rgba(11,14,21,.18) 40%,
    rgba(11,14,21,.90) 100%
  );
}
.hero__inner {
  position: relative;
  z-index: 1;
  max-width: var(--mw);
  margin: 0 auto;
  width: 100%;
}
.hero__h1 {
  font-family: var(--fd);
  font-weight: 400;
  font-size: clamp(64px, 10.5vw, 160px);
  line-height: .86;
  letter-spacing: -.01em;
  text-transform: uppercase;
  color: #fff;
  margin-bottom: 36px;
  opacity: 0;
  animation: heroUp .9s .35s ease forwards;
}
.hero__h1 span { display: block; }
.hero__h1 em {
  font-style: normal;
  font-size: .76em;
  opacity: .58;
  letter-spacing: .02em;
}
/* Override main.css .hero h1 (specificity 0,1,1 > .hero__h1 0,1,0) */
.hero h1 {
  font-family: var(--fd);
  font-weight: 400;
  font-size: clamp(64px, 10.5vw, 160px);
  line-height: .86;
  letter-spacing: -.01em;
  text-transform: uppercase;
  color: #fff;
  margin: 0 0 36px;
  max-width: none;
}
.hero__sub {
  font-family: var(--fi);
  font-size: clamp(12px, 1.1vw, 14px);
  font-weight: 300;
  font-style: italic;
  letter-spacing: 0.04em;
  color: rgba(255,255,255,.45);
  margin-top: 18px;
  margin-bottom: 28px;
  opacity: 0;
  animation: heroUp .7s .52s ease forwards;
}
/* Override main.css .hero p (specificity 0,1,1 > .hero__sub 0,1,0) */
.hero p {
  font-family: var(--fi);
  font-size: clamp(12px, 1.1vw, 14px);
  font-weight: 300;
  font-style: italic;
  letter-spacing: 0.04em;
  color: rgba(255,255,255,.45);
  margin: 18px 0 28px;
}
.hero__ctas {
  display: flex;
  gap: 10px;
  align-items: center;
  opacity: 0;
  animation: heroUp .7s .72s ease forwards;
}
.hero__cta {
  font-family: var(--fb);
  font-size: 12px;
  font-weight: 300;
  letter-spacing: .08em;
  color: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0;
  min-width: 130px;
  border: 1px solid rgba(255,255,255,.55);
  border-radius: 999px;
  padding: 12px 24px;
  background: transparent;
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  white-space: nowrap;
  cursor: pointer;
  transition: background .26s ease, border-color .26s ease, color .26s ease;
  overflow: hidden;
}
/* Override main.css .hero a / .hero small (specificity 0,1,1) */
.hero a {
  font-size: 12px;
  font-weight: 300;
}
.hero small {
  font-size: 12px;
  font-weight: 300;
}
.hero__cta:hover { background: #000; border-color: #000; color: #fff; }
.hero__cta svg {
  width: 13px; height: 13px;
  fill: none; stroke: currentColor; stroke-width: 2; flex-shrink: 0;
  opacity: 0;
  max-width: 0;
  margin-left: 0;
  transform: translateX(-4px);
  transition: opacity .22s ease .06s, transform .22s ease .06s, max-width .22s ease, margin-left .22s ease;
  overflow: hidden;
}
.hero__cta:hover svg {
  opacity: 1;
  max-width: 16px;
  margin-left: 9px;
  transform: translateX(0);
}
.hero__tagline {
  margin-top: clamp(24px, 3vw, 36px);
  font-family: var(--fi);
  font-size: clamp(11px, 1vw, 13px);
  font-style: italic;
  font-weight: 300;
  color: rgba(255,255,255,.42);
  line-height: 1.8;
  letter-spacing: .02em;
}
.hero__tagline span { display: block; }

/* Scroll indicator */
.hero__scroll {
  position: absolute;
  bottom: clamp(28px, 5vh, 44px);
  right: var(--g);
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  opacity: 0;
  animation: heroUp .6s .85s ease forwards;
}
.hero__scroll span {
  font-family: var(--fb);
  font-size: 9px;
  font-weight: 300;
  letter-spacing: .26em;
  text-transform: uppercase;
  color: rgba(255,255,255,.26);
  writing-mode: vertical-rl;
}
.hero__scroll-line {
  width: 1px;
  height: 44px;
  background: rgba(255,255,255,.14);
  position: relative;
  overflow: hidden;
}
.hero__scroll-line::after {
  content: '';
  position: absolute;
  top: -100%; left: 0;
  width: 100%; height: 100%;
  background: rgba(255,255,255,.55);
  animation: scrollLine 2s ease infinite;
}
@keyframes scrollLine { to { top: 100%; } }
@keyframes heroUp {
  from { opacity: 0; transform: translateY(22px); }
  to   { opacity: 1; transform: none; }
}

/* ── MARQUEE ──────────────────────────────────── */
.marquee {
  overflow: hidden;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  padding: 15px 0;
  background: var(--bg);
  cursor: default;
  user-select: none;
}
.marquee__track {
  display: inline-flex;
  white-space: nowrap;
  animation: marqueeScroll 52s linear infinite;
}
.marquee:hover .marquee__track { animation-play-state: paused; }
.marquee__item {
  font-family: var(--fd);
  font-size: clamp(11px, 1.05vw, 13px);
  letter-spacing: .24em;
  text-transform: uppercase;
  color: var(--text);
  padding: 0 clamp(22px, 3vw, 44px);
}
.marquee__sep {
  color: var(--gold);
  font-size: 7px;
  line-height: 13.3px;
  display: block;
}
@keyframes marqueeScroll {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

/* ── Scroll cue (mobile only — centered bottom line) ─ */
.hero__scroll-cue {
  display: none;
}

/* ── HERO + MARQUEE — RESPONSIVE ──────────────── */
@media (max-width: 768px) {
  .hero { padding-bottom: clamp(88px, 14vh, 120px); }
  .hero__h1 { font-size: clamp(72px, 22vw, 98px); }
  .hero__h1 em { font-size: .78em; opacity: .52; letter-spacing: .02em; }
  .hero__sub {
    font-size: 13px; margin-top: 14px; margin-bottom: 26px; line-height: 1.68;
  }
  .hero__scroll { display: none; }
  .hero__scroll-cue {
    display: block;
    position: absolute; bottom: 32px; left: 50%;
    transform: translateX(-50%); z-index: 1;
    opacity: 0; animation: heroUp .5s .9s ease forwards;
  }
  .hero__scroll-cue .hero__scroll-line {
    width: 1px; height: 34px;
    background: rgba(255,255,255,.12);
    position: relative; overflow: hidden;
  }
  .hero__scroll-cue .hero__scroll-line::after {
    content: ''; position: absolute; top: -100%; left: 0;
    width: 100%; height: 100%;
    background: rgba(255,255,255,.5);
    animation: scrollLine 2s ease infinite;
  }
}

/* ── FOOTER ───────────────────────────────────── */
.pm-footer {
  background: var(--dk);
  padding: clamp(52px,6vw,84px) var(--g) 28px;
  border: none;
}
.footer__inner {
  max-width: var(--mw); margin: 0 auto;
  display: grid;
  grid-template-columns: 1.1fr 2fr;
  gap: clamp(40px,6vw,110px);
  padding-bottom: 48px;
  border-bottom: 1px solid rgba(255,255,255,.06);
  margin-bottom: 24px;
}
.footer__brand-name {
  font-family: var(--fd);
  font-size: clamp(14px,1.2vw,18px);
  letter-spacing: .24em;
  color: rgba(255,255,255,.8);
  margin-bottom: 22px;
}
.footer__nl-form {
  display: flex;
  align-items: center;
  border-bottom: 1px solid rgba(255,255,255,.1);
  padding-bottom: 10px;
  gap: 8px;
  margin-bottom: 18px;
}
.footer__nl-input {
  flex: 1;
  background: none; border: none; outline: none;
  font: 300 9.5px/1 var(--fb);
  letter-spacing: .22em; text-transform: uppercase;
  color: rgba(255,255,255,.48);
}
.footer__nl-input::placeholder { color: rgba(255,255,255,.16); }
.footer__nl-btn {
  background: none; border: none; cursor: pointer;
  color: rgba(255,255,255,.28);
  display: flex;
  transition: color .18s;
}
.footer__nl-btn:hover { color: #fff; }
.footer__nl-btn svg { width: 13px; height: 13px; stroke: currentColor; stroke-width: 1.5; fill: none; }
.footer__desc {
  font: 300 11px/1.95 var(--fb);
  color: rgba(255,255,255,.18);
}
.footer__cols {
  display: grid;
  grid-template-columns: repeat(3,1fr);
  gap: clamp(16px,2.5vw,48px);
}
.fch {
  font: 400 9px/1 var(--fb);
  letter-spacing: .24em;
  text-transform: uppercase;
  color: rgba(255,255,255,.28);
  margin-bottom: 14px;
}
.fcol ul { padding: 0; margin: 0; list-style: none; }
.fcol ul li { margin-bottom: 9px; }
.fcol ul a {
  font: 300 11px/1 var(--fb);
  color: rgba(255,255,255,.36);
  transition: color .18s;
}
.fcol ul a:hover { color: rgba(255,255,255,.8); }
.footer__bot {
  max-width: var(--mw); margin: 0 auto;
  display: flex; align-items: center; justify-content: space-between;
}
.footer__tagline {
  font: 300 italic 11px/1 var(--fi);
  color: rgba(255,255,255,.16);
}
.fcopy {
  font: 300 9px/1 var(--fb);
  letter-spacing: .16em;
  text-transform: uppercase;
  color: rgba(255,255,255,.1);
}

/* ── CART DRAWER ─────────────────────────────── */
.cart-overlay {
  position: fixed; inset: 0; z-index: 999998;
  background: rgba(11,11,9,.42);
  opacity: 0; pointer-events: none;
  transition: opacity .35s;
  cursor: pointer;
}
.cart-overlay.open {
  opacity: 1;
  pointer-events: auto;
}

.cart-drawer {
  position: fixed; top: var(--banner-h); right: 0; bottom: 0; z-index: 999999;
  width: clamp(340px,38vw,520px);
  background: var(--bg);
  display: flex; flex-direction: column;
  transform: translateX(102%);
  transition: transform .42s cubic-bezier(.4,0,.2,1), top .3s ease;
}
.cart-drawer.open { transform: translateX(0); }
.cart-drawer__head {
  flex-shrink: 0; padding: 24px 28px;
  display: flex; align-items: center;
  border-bottom: 1px solid var(--border);
  position: relative;
}
.cart-drawer__title {
  font: 400 10px/1 var(--fb); letter-spacing: .22em; text-transform: uppercase; color: var(--dk);
}
.cart-drawer__count {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 18px; height: 18px; border-radius: 999px;
  background: var(--dk); color: var(--bg);
  font: 400 9px/1 var(--fb); padding: 0 5px; margin-left: 8px;
}
.cart-drawer__close {
  position: absolute; right: 18px; top: 50%; transform: translateY(-50%);
  width: 44px; height: 44px;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; border: none; background: none;
  color: var(--dk); font-size: 26px; line-height: 1;
  transition: opacity .16s;
}
.cart-drawer__close:hover { opacity: .4; }
.cart-drawer__body {
  flex: 1; overflow-y: auto; scrollbar-width: none; padding: 0;
  position: relative;
}
/* Premium Cart Drawer Loading Overlay */
.cart-drawer.loading .cart-drawer__body {
  pointer-events: none;
}
.cart-drawer.loading .cart-drawer__body > * {
  opacity: 0.44;
  filter: blur(1.5px);
  transition: opacity .25s ease, filter .25s ease;
}
.cart-drawer.loading .cart-drawer__body::after {
  content: '';
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  width: 28px; height: 28px;
  border: 1.5px solid rgba(26,25,22,.15);
  border-top-color: var(--dk);
  border-radius: 50%;
  animation: pmSpinner .6s linear infinite;
  z-index: 10;
}
@keyframes pmSpinner {
  to { transform: translate(-50%, -50%) rotate(360deg); }
}
.cart-empty {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  height: 100%; gap: 14px; padding: 40px;
}
@keyframes bagSway { 0%,100%{transform:rotate(0deg)} 28%{transform:rotate(-4deg)} 72%{transform:rotate(3.5deg)} }
.cart-empty__icon {
  width: 56px; height: 64px; stroke: var(--border); stroke-width: 1; fill: none;
  transform-origin: 50% 5px; animation: bagSway 4.2s ease-in-out .4s infinite;
}
.cart-empty p {
  font: 300 10px/1.7 var(--fb); letter-spacing: .16em; text-transform: uppercase;
  color: var(--muted); text-align: center;
}
.cart-item {
  display: flex; gap: 16px; padding: 20px 28px; border-bottom: 1px solid var(--border);
}
.cart-item__img {
  width: 72px; height: 96px; flex-shrink: 0; background: var(--bg2); overflow: hidden;
}
.cart-item__img img { width: 100%; height: 100%; object-fit: cover; object-position: center top; }
.cart-item__info {
  flex: 1; display: flex; flex-direction: column; justify-content: space-between; min-height: 96px;
}
.cart-item__name { font: 600 12px/1.2 var(--fb); color: var(--dk); }
.cart-item__meta {
  font: 300 9px/1 var(--fb); letter-spacing: .14em; text-transform: uppercase;
  color: var(--muted); margin-top: 4px;
}
.cart-item__row {
  display: flex; align-items: center; justify-content: space-between; margin-top: auto;
}
.cart-item__price { font: 400 16px/1 var(--fd); color: var(--dk); }
.cart-item__qty { display: flex; align-items: center; }
.cart-qty__btn {
  width: 26px; height: 26px; display: flex; align-items: center; justify-content: center;
  border: 1px solid var(--border); background: none; cursor: pointer;
  font-size: 14px; color: var(--dk); transition: background .14s; flex-shrink: 0; line-height: 1;
}
.cart-qty__btn:hover { background: var(--bg2); }
.cart-qty__val {
  min-width: 32px; text-align: center; font: 400 11px/1 var(--fb); color: var(--dk);
  border-top: 1px solid var(--border); border-bottom: 1px solid var(--border);
  height: 26px; display: flex; align-items: center; justify-content: center;
}
.cart-item__remove {
  font: 300 9px/1 var(--fb); letter-spacing: .12em; text-transform: uppercase;
  color: var(--muted); background: none; border: none; cursor: pointer;
  text-decoration: underline; text-underline-offset: 3px; transition: color .16s;
}
.cart-item__remove:hover { color: #B84A2E; }
.cart-drawer__footer {
  padding: 20px 28px 28px; border-top: 1px solid var(--border); flex-shrink: 0;
}
.cart-subtotal {
  display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 6px;
}
.cart-subtotal__label {
  font: 300 9.5px/1 var(--fb); letter-spacing: .16em; text-transform: uppercase; color: var(--muted);
}
.cart-subtotal__amount { font: 400 22px/1 var(--fd); color: var(--dk); }
.cart-shipping {
  font: 300 9px/1 var(--fb); letter-spacing: .12em; text-transform: uppercase; color: var(--gold); margin-bottom: 8px;
}
.cart-returns {
  display: flex; align-items: center; gap: 7px;
  font: 300 9px/1 var(--fb); letter-spacing: .12em; text-transform: uppercase; color: var(--muted); margin-bottom: 18px;
}
.cart-returns svg { width: 12px; height: 12px; stroke: currentColor; stroke-width: 1.3; fill: none; flex-shrink: 0; }
.cart-checkout, .cart-applepay {
  width: 100%; height: 50px;
  display: flex; align-items: center; justify-content: center;
  border: none; cursor: pointer; position: relative; overflow: hidden;
}
.cart-checkout {
  background: #000; color: #fff;
  font: 400 10px/1 var(--fb); letter-spacing: .2em; text-transform: uppercase;
  margin-bottom: 9px; transition: color .34s; border: 1px solid #000;
}
.cart-checkout::before {
  content: ''; position: absolute; inset: 0;
  background: var(--bg); transform: translateX(-102%);
  transition: transform .42s cubic-bezier(.77,0,.175,1); z-index: 0;
}
.cart-checkout:hover::before { transform: translateX(0); }
.cart-checkout:hover { color: #000; }
.cart-checkout span { position: relative; z-index: 1; }

.cart-applepay {
  background: #000; color: #fff;
  gap: 7px;
  font-family: -apple-system, BlinkMacSystemFont, 'SF Pro Display', sans-serif;
  font-size: 15px; font-weight: 500; letter-spacing: .01em;
  transition: color .34s, box-shadow .34s; border: 1px solid #000;
}
.cart-applepay::before {
  content: ''; position: absolute; inset: 0;
  background: var(--bg); transform: translateX(-102%);
  transition: transform .42s cubic-bezier(.77,0,.175,1); z-index: 0;
}
.cart-applepay:hover::before { transform: translateX(0); }
.cart-applepay:hover { color: #000; }
.cart-applepay:active { transform: scale(.99); }
.cart-applepay__inner { position: relative; z-index: 1; display: flex; align-items: center; gap: 7px; }
.cart-applepay__logo { width: 17px; height: 20px; fill: currentColor; flex-shrink: 0; margin-top: -1px; }
@keyframes badgePop { 0%{transform:scale(1)} 30%{transform:scale(1.7)} 60%{transform:scale(.9)} 100%{transform:scale(1)} }
.nav__cart-badge.pop { animation: badgePop .45s cubic-bezier(.36,.07,.19,.97); }

/* ── COOKIE POPUP — EDITION TENNIS ── */
.ck-overlay {
  position: fixed; inset: 0; z-index: 99999;
  display: flex; align-items: center; justify-content: center; padding: 12px;
  background: rgba(0,0,0,0); pointer-events: none;
  transition: background .4s ease;
}
.ck-overlay.show { background: rgba(0,0,0,.5); pointer-events: auto; }
.ck-popup {
  background: #F5EDE0; border: 1px solid rgba(194,80,42,.18);
  width: 100%; max-width: 880px; overflow: hidden;
  transform: translateY(20px); opacity: 0;
  transition: transform .52s cubic-bezier(.22,1,.36,1), opacity .38s ease;
  position: relative; display: flex; flex-direction: column;
}
.ck-overlay.show .ck-popup { transform: translateY(0); opacity: 1; }
.ck-score {
  background: #C2502A; padding: 10px 18px;
  display: flex; align-items: center; justify-content: space-between; gap: 8px;
}
.ck-score__label {
  font: 300 8px/1 var(--fb); letter-spacing: .28em; text-transform: uppercase; color: rgba(255,255,255,.85);
}
.ck-score__board { display: flex; border: 1px solid rgba(255,255,255,.35); overflow: hidden; flex-shrink: 0; }
.ck-score__cell {
  font: 400 12px/1 var(--fd); letter-spacing: .04em;
  padding: 4px 10px; border-right: 1px solid rgba(255,255,255,.25); color: rgba(255,255,255,.72);
}
.ck-score__cell:last-child { border-right: none; }
.ck-score__cell.hi { color: #fff; }
.ck-close {
  position: absolute; top: 52px; right: 14px;
  width: 30px; height: 30px; border-radius: 50%;
  border: 1.5px solid rgba(194,80,42,.45); background: none; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  color: #C2502A; transition: border-color .2s, color .2s; z-index: 2;
}
.ck-close:hover { border-color: #C2502A; color: #8A2E10; }
.ck-close svg { width: 12px; height: 12px; stroke: currentColor; stroke-width: 2; fill: none; }
.ck-body { padding: 22px 26px 0; }
.ck-ref {
  font: 300 8px/1.4 var(--fb); letter-spacing: .24em; text-transform: uppercase; color: rgba(28,9,5,.3); margin-bottom: 14px;
}
.ck-ref em { font-style: italic; font-family: var(--fi); font-size: 10px; letter-spacing: .04em; color: #C2502A; text-transform: none; }
.ck-title { font: 400 clamp(34px,9vw,52px)/.9 var(--fd); letter-spacing: .06em; text-transform: uppercase; color: #1C0905; margin: 0 0 6px; }
.ck-tagline { font: 300 italic clamp(19px,5vw,30px)/1.2 var(--fi); color: #C2502A; margin: 0 0 20px; }
.ck-divider { display: flex; align-items: center; gap: 10px; margin: 0 0 20px; }
.ck-divider__ball { width: 16px; height: 16px; flex-shrink: 0; }
.ck-divider__line { flex: 1; height: 0; border-top: 1.5px dashed rgba(194,80,42,.4); }
.ck-desc { font: 300 12px/1.8 var(--fb); color: rgba(28,9,5,.55); margin: 0 0 20px; }
.ck-desc p { margin: 0 0 8px; }
.ck-desc p:last-child { margin: 0; }
.ck-btns { display: flex; flex-direction: column; gap: 10px; }
.ck-btn {
  display: block; width: 100%; padding: 14px 16px;
  font: 400 10px/1 var(--fb); letter-spacing: .22em; text-transform: uppercase;
  cursor: pointer; text-align: center;
  transition: background .2s, color .2s, border-color .2s;
}
.ck-btn--ace { background: #C2502A; color: #fff; border: none; }
.ck-btn--ace:hover { background: #8A2E10; }
.ck-btn--filet { background: transparent; color: #C2502A; border: 1.5px solid rgba(194,80,42,.5); }
.ck-btn--filet:hover { color: #8A2E10; border-color: #C2502A; }
.ck-fine {
  padding: 16px 26px; border-top: 1px solid rgba(194,80,42,.15);
  display: flex; align-items: center; gap: 10px; margin-top: auto;
}
.ck-fine svg { width: 16px; height: 16px; flex-shrink: 0; stroke: #C2502A; fill: none; stroke-width: 1.5; opacity: .6; }
.ck-fine__text { font: 300 italic 10px/1.5 var(--fi); color: rgba(28,9,5,.38); }
.ck-main { display: flex; flex: 1; }
.ck-left { display: flex; flex-direction: column; flex: 1; min-width: 0; }
.ck-right { width: 42%; flex-shrink: 0; overflow: hidden; }
.ck-right img { width: 100%; height: 100%; object-fit: cover; display: block; }

/* ── REVEAL AU SCROLL ─────────────────────────── */
.rv { opacity: 0; transform: translateY(24px); transition: opacity .82s ease, transform .82s ease; }
.rv.on { opacity: 1; transform: none; }
.d1 { transition-delay: .06s; }
.d2 { transition-delay: .12s; }
.d3 { transition-delay: .18s; }
.d4 { transition-delay: .24s; }
.d5 { transition-delay: .30s; }
.d6 { transition-delay: .36s; }

/* ── RESPONSIVE ──────────────────────────────── */
@media (max-width: 768px) {
  .footer__inner { grid-template-columns: 1fr; gap: 28px; padding-bottom: 32px; }
  .footer__cols  { grid-template-columns: 1fr 1fr; gap: 20px; }
  .footer__bot   { flex-direction: column; align-items: center; gap: 10px; text-align: center; }
}

@media (max-width: 600px) {
  .ck-overlay { padding: 10px; }
  .ck-popup { max-width: 100%; }
  .ck-right { display: none; }
  .ck-score { padding: 8px 14px; }
  .ck-body { padding: 16px 18px 0; }
  .ck-title { font-size: clamp(26px,11vw,36px); }
  .ck-tagline { font-size: clamp(16px,5.5vw,22px); margin-bottom: 14px; }
  .ck-divider { margin-bottom: 14px; }
  .ck-desc { font-size: 11px; margin-bottom: 14px; }
  .ck-btn { padding: 12px 14px; }
  .ck-fine { padding: 12px 18px; margin-top: 14px; }
  .ck-close { top: 46px; right: 10px; }
}

/* ── TOUCH: CTAs always visible ─────────────── */
@media (hover: none) {
  .split__link    { opacity: 1; transform: none; }
  .pitem__actions { opacity: 1; transform: none; }
}

/* ══════════════════════════════════════════════════════════
   INNER PAGE OVERRIDES
   Hide/restyle PrestaShop default elements that conflict
   with the new unified header, footer, nav
   ══════════════════════════════════════════════════════════ */

/* Body typography for ALL pages — aligned pixel-perfect with mockup index.html (lines 42-50) */
body {
  font-family: var(--fb);
  font-size: 16px;
  line-height: 1.6;
  color: var(--text);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* Fix legacy theme.css `body, html { height: 100% }` which combined with
   `overflow-x: hidden` makes body the scroll container instead of html.
   This breaks IntersectionObserver, window.scrollY, sticky headers etc.
   Replace with `min-height: 100%` to preserve visual intent (body fills
   viewport when content is short) while keeping natural document scroll. */
html, body {
  height: auto !important;
  min-height: 100%;
}
body {
  overflow-x: clip;
  overflow-y: visible;
}

/* Hide old PrestaShop headers */
#header-base, #checkout-header, #header-placeholder { display: none !important; }

/* Hide legacy old footers */
#spe-footer, #checkout-footer, #ft, footer.page-footer { display: none !important; }

/* Override wrapper top padding (was pushed by old fixed header) */
#wrapper {
  padding-top: 0 !important;
  margin-top: 0 !important;
}

/* Ensure full-container has no overflow clip */
.full-container { overflow: visible; }

/* Content wrapper — let pages breathe */
#content-wrapper {
  max-width: var(--mw);
  margin: 0 auto;
  padding: 24px var(--g) 48px;
}

/* Homepage overrides — already handled by pm_homepage module CSS */
body#index #wrapper,
body#index #content-wrapper {
  padding: 0 !important;
  max-width: 100%;
}

/* Hide PS default breadcrumb on homepage */
body#index .breadcrumb { display: none; }

/* Inner page breadcrumb styling */
.breadcrumb {
  font-family: var(--fb);
  font-size: 11px;
  letter-spacing: .06em;
  color: var(--muted);
  padding: 12px 0;
}
.breadcrumb a { color: var(--muted); transition: color var(--tr); }
.breadcrumb a:hover { color: var(--text); }

/* Inner page headings */
h1, h2, h3 {
  font-family: var(--fd);
  font-weight: 400;
  letter-spacing: .06em;
  text-transform: uppercase;
}

/* Footer is rendered outside #wrapper — ensure full-width */
footer.pm-footer { margin: 0; width: 100%; }

/* Links in content */
a:hover { text-decoration: none; }

/* Point 8: Express Checkout buttons hidden on checkout page only */
body#checkout .express-strip,
body#checkout .or-divider,
body#checkout .pay-applepay,
body#checkout .express-btn,
body#checkout #mollie-express-checkout-wrapper,
body#checkout #mollie_applepay_button,
body#checkout #mollie-applepay-direct-button {
  display: none !important;
}

/* ── MA TAILLE SIZE WIZARD MODAL HIGH-FIDELITY OVERRIDES ── */
#wrap_smartsizes.modal.fade .modal-dialog,
#wrap_smartsizes.modal.show .modal-dialog,
#wrap_smartsizes.show .modal-dialog {
  transform: translateY(0%) !important;
  -webkit-transform: translateY(0%) !important;
}
#wrap_smartsizes a:hover {
  color: rgb(0, 0, 0);
}
#wrap_smartsizes .wizard > .actions > ul > li:first-child a {
  background: rgb(238, 238, 238) !important;
  color: rgb(170, 170, 170) !important;
}
#wrap_smartsizes .wizard > .actions > ul > li:first-child:hover a {
  color: rgb(0, 0, 0) !important;
}
#wrap_smartsizes .wizard > .actions > ul > li a:hover {
  color: rgb(255, 255, 255) !important;
}
.wizard > .steps .current a, 
.wizard > .steps .current a:hover, 
.wizard > .steps .current a:active {
  color: rgb(255, 255, 255) !important;
  background: rgb(35, 35, 35) !important;
}
.actions ul > li:first-child a {
  background: rgb(192, 192, 197) !important;
}
#autosizes .reponse.little {
  min-height: 38px;
  min-width: 81px;
}
.row_q {
  display: flex;
  flex-wrap: wrap;
}
.avec_input {
  width: 100%;
  display: flex;
  margin-top: 10px;
}
#wrap_smartsizes #autosizes .steps ul[role="tablist"] li {
  width: 15% !important;
}
.wizard > .steps > ul > li:last-child, 
.wizard > .actions > ul > li:last-child {
  display: none !important;
}

/* ══════════════════════════════════════════════════════════════════
   CHECKOUT PAGE — Layout, Header & Footer overrides
   Match the client mockup: dark minimal header, centered 2-col layout
   ══════════════════════════════════════════════════════════════════ */

/* 1. Hide main site nav, banner, push spacer, and footer on checkout */
body#checkout .banner,
body#checkout #banner,
body#checkout .nav,
body#checkout #nav,
body#checkout .pm-push {
  display: none !important;
}

/* 2. Checkout minimal header — injected by JS (pm-global.js) */
.pm-checkout-header {
  position: sticky;
  top: 0;
  z-index: 1000;
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  background: var(--ink, #1a1916);
  color: #fff;
  padding: 14px 32px;
  font-family: var(--ff-sans, 'Montserrat', sans-serif);
}
.pm-checkout-header a {
  color: rgba(255,255,255,.8);
  text-decoration: none;
  font-size: .78rem;
  letter-spacing: .08em;
  text-transform: uppercase;
  transition: color .2s;
}
.pm-checkout-header a:hover { color: #fff; }
.pm-checkout-header__left { justify-self: start; }
.pm-checkout-header__left svg {
  width: 16px; height: 16px;
  stroke: currentColor; fill: none;
  stroke-width: 1.6; stroke-linecap: round; stroke-linejoin: round;
  vertical-align: -2px; margin-right: 4px;
}
.pm-checkout-header__brand {
  justify-self: center;
  font-family: var(--ff-display, 'Bebas Neue', sans-serif);
  font-size: 1.35rem;
  letter-spacing: .22em;
  color: #fff;
  text-decoration: none;
}
.pm-checkout-header__right {
  justify-self: end;
  font-size: .75rem;
  letter-spacing: .06em;
  color: rgba(255,255,255,.7);
  display: flex;
  align-items: center;
  gap: 5px;
}
.pm-checkout-header__right svg {
  width: 14px; height: 14px;
  stroke: currentColor; fill: none;
  stroke-width: 1.6; stroke-linecap: round; stroke-linejoin: round;
}

/* 3. Center the checkout layout via parent flex */
body#checkout .full-container {
  display: flex !important;
  justify-content: center !important;
  padding-left: 20px;
  padding-right: 20px;
}
body#checkout .checkout-wrap {
  margin-left: auto !important;
  margin-right: auto !important;
}

/* 5. On smaller screens, stack to single column */
@media (max-width: 991px) {
  body#checkout .checkout-wrap {
    grid-template-columns: 1fr !important;
    padding: 20px 16px 60px !important;
  }
}

/* ══════════════════════════════════════════════════════════
   ORDER CONFIRMATION — Featured/Cross-sell product grid
   Modules like ps_featuredproducts inject products inside
   a `.products` div that lacks grid styling in this theme.
   ══════════════════════════════════════════════════════════ */
#content-hook-order-confirmation-footer .products,
#content-hook_order_confirmation .products,
.page-order-confirmation .products {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: clamp(10px, 1.6vw, 24px) clamp(14px, 2vw, 32px);
  padding: 0;
  margin: 0;
}

#content-hook-order-confirmation-footer section,
.page-order-confirmation section {
  max-width: var(--mw, 1480px);
  margin: 40px auto;
  padding: 0 var(--g, 40px);
}

#content-hook-order-confirmation-footer section > h1,
#content-hook-order-confirmation-footer section > h2 {
  font-family: var(--fd, 'Bebas Neue', sans-serif);
  font-size: clamp(22px, 2.5vw, 32px);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  margin-bottom: 24px;
  color: var(--dk, #0B0B09);
}

#content-hook-order-confirmation-footer section > a {
  display: inline-block;
  margin-top: 20px;
  font: 300 11px/1 var(--fb, 'Gilroy', sans-serif);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--muted, #8A8580);
  border-bottom: 1px solid currentColor;
  padding-bottom: 2px;
  transition: color 0.28s;
}
#content-hook-order-confirmation-footer section > a:hover {
  color: var(--dk, #0B0B09);
}

@media (max-width: 991px) {
  #content-hook-order-confirmation-footer .products,
  #content-hook_order_confirmation .products,
  .page-order-confirmation .products {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}
@media (max-width: 640px) {
  #content-hook-order-confirmation-footer .products,
  #content-hook_order_confirmation .products,
  .page-order-confirmation .products {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 6px 8px;
  }
}
