/* =============================================================
   Lacros — Home "Editorial Modern" (static, self-contained)
   Tokens + theme consolidated; classes prefixed `lx-`.
   ============================================================= */

/* ---- Demo placeholder page ---- */
.lx-demo { display: flex; align-items: center; justify-content: center; min-height: 60vh; padding: 96px 32px; text-align: center; }
.lx-demo-inner { max-width: 640px; }
.lx-demo h1 { margin-bottom: 40px; }
.lx-demo-lead { font-size: 18px; color: var(--fg-2); line-height: 1.7; margin: 0 0 64px; }
.lx-demo-lead b { color: var(--ink); font-weight: 700; }
.lx-page a.lx-demo-link { color: var(--lacros-orange); font-weight: 700; border-bottom: 1px solid var(--lacros-orange); }
.lx-page a.lx-demo-link:hover { color: var(--lacros-orange-hover); border-bottom-color: var(--lacros-orange-hover); }
.lx-demo-cta { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; padding-top: 40px; }

@font-face {
  font-family: 'Karla';
  src: url('/fonts/Karla-VariableFont_wght.ttf') format('truetype-variations'),
       url('/fonts/Karla-VariableFont_wght.ttf') format('truetype');
  font-weight: 200 800; font-style: normal; font-display: swap;
}

:root {
  /* Brand */
  --lacros-orange:       #F05010;
  --lacros-orange-hover: #D8430B;
  --lacros-orange-soft:  #FBE5DA;
  /* Foreground */
  --fg-1: #222222; --fg-2: #555555; --fg-3: #888888; --fg-4: #A5A5A5;
  /* Editorial neutrals (warm) */
  --ink:     #161616;
  --paper:   #FBFAF8;
  --paper-2: #F2EFEA;
  --rule:    #E6E2DC;
  --bg-mute: #F5F5F5;
  /* Semantic */
  --rating-star:  #FFD600;
  --sale-red:     #C8102E;
  --success-bg:   #E0EFD1;
  --success-dark: #74A840;
  /* Radii */
  --radius-md: 5px; --radius-pill: 999px;
  /* Fonts */
  --font-sans:    "Karla", "Open Sans", "Helvetica Neue", Arial, sans-serif;
  --font-display: "Bricolage Grotesque", "Karla", "Helvetica Neue", Arial, sans-serif;
}

*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
html { overflow-x: clip; }
.lx-page {
  margin: 0; background: #fff; color: var(--fg-1);
  font-family: var(--font-sans); font-size: 14px; line-height: 1.55;
  -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility;
}
.lx-page img { display: block; max-width: 100%; }
.lx-page p { margin: 0; }
.lx-page a { text-decoration: none; color: inherit; }
.lx-wrap { max-width: 1320px; margin: 0 auto; padding-left: 32px; padding-right: 32px; }

/* ---- Display & eyebrow ---- */
.lx-display { font-family: var(--font-display); font-weight: 500; letter-spacing: -0.02em; line-height: 1; color: var(--ink); margin: 0; }
.lx-display.xl { font-size: 88px;  line-height: .95; letter-spacing: -0.035em; }
.lx-display.l  { font-size: 72px;  line-height: .98; letter-spacing: -0.03em; }
.lx-display.m  { font-size: 56px;  line-height: 1.02; letter-spacing: -0.025em; }
.lx-display.s  { font-size: 40px;  line-height: 1.05; letter-spacing: -0.02em; }
.lx-eyebrow { font-family: var(--font-sans); font-size: 11px; font-weight: 700; letter-spacing: .16em; text-transform: uppercase; color: var(--fg-3); }
.lx-eyebrow.orange { color: var(--lacros-orange); }

/* ---- Buttons ---- */
.lx-btn-cart, .lx-btn-proefrit {
  display: inline-flex; align-items: center; gap: 8px;
  border-radius: var(--radius-md); font-family: var(--font-sans);
  font-weight: 700; font-size: 14px; text-transform: uppercase;
  letter-spacing: .04em; cursor: pointer; transition: background .15s ease, color .15s ease, border-color .15s ease;
}
.lx-btn-cart { padding: 13px 22px; background: var(--lacros-orange); color: #fff; border: 1.5px solid var(--lacros-orange); }
.lx-btn-cart:hover { background: var(--lacros-orange-hover); border-color: var(--lacros-orange-hover); }
.lx-btn-cart.ink { background: var(--ink); border-color: var(--ink); }
.lx-btn-cart.ink:hover { background: #000; border-color: #000; }
.lx-btn-proefrit { padding: 12px 22px; background: #fff; color: var(--ink); border: 1.5px solid var(--ink); }
.lx-btn-proefrit:hover { background: var(--ink); color: #fff; }
.lx-btn-proefrit i { color: var(--lacros-orange); }
.lx-btn-proefrit:hover i { color: #fff; }
.lx-btn-proefrit.on-dark { background: transparent; border-color: #fff; color: #fff; }
.lx-btn-proefrit.on-dark i { color: var(--lacros-orange); }
.lx-btn-proefrit.on-dark:hover { background: #fff; color: var(--ink); }
/* Buttons rendered as links must keep their button text colour (beats `.lx-page a { color: inherit }`) */
.lx-page a.lx-btn-cart { color: #fff; }
.lx-page a.lx-btn-proefrit { color: var(--ink); }
.lx-page a.lx-btn-proefrit.on-dark { color: #fff; }
.lx-page a.lx-btn-proefrit:hover { color: #fff; }
.lx-page a.lx-btn-proefrit.on-dark:hover { color: var(--ink); }

/* ---- Chips ---- */
.lx-tag-chip { display: inline-block; padding: 4px 10px; background: var(--lacros-orange-soft); color: var(--lacros-orange-hover); font-size: 11px; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; border-radius: var(--radius-pill); }
.lx-tag-chip.on-white { background: #fff; color: var(--ink); }
.lx-trust-chip { display: inline-flex; align-items: center; gap: 8px; padding: 6px 10px; background: #fff; border: 1px solid var(--rule); border-radius: var(--radius-pill); font-size: 12px; color: var(--fg-2); }
.lx-trust-chip .lx-rating { font-weight: 700; color: var(--ink); }
.lx-trust-chip .lx-star { color: var(--rating-star); font-size: 11px; }

/* ============================== Top ribbon ============================== */
.lx-ribbon { background: var(--paper); color: var(--fg-2); border-bottom: 1px solid var(--rule); font-size: 12px; }
.lx-ribbon-inner { max-width: 1320px; margin: 0 auto; padding: 10px 32px; display: flex; align-items: center; justify-content: space-between; gap: 16px; }
.lx-ribbon-left { display: flex; gap: 28px; flex-wrap: wrap; }
.lx-ribbon-left i, .lx-ribbon-right i { margin-right: 8px; }
.lx-ribbon-left i { color: var(--lacros-orange); }
.lx-ribbon-right { display: flex; gap: 18px; align-items: center; }
.lx-ribbon-right .lx-star { color: var(--rating-star); }
.lx-ribbon-right b { color: var(--ink); }
.lx-ribbon-langs { opacity: .6; }

/* ============================== Header ============================== */
.lx-header { background: #fff; border-bottom: 1px solid var(--rule); position: sticky; top: 0; z-index: 20; }
.lx-header-inner { max-width: 1320px; margin: 0 auto; padding: 18px 32px; display: grid; grid-template-columns: 160px 1fr auto; align-items: center; gap: 24px; }
.lx-header-inner img { height: 38px; width: auto; }
.lx-nav { display: flex; gap: 28px; justify-content: center; font-size: 14px; font-weight: 600; }
.lx-nav a { color: var(--ink); padding: 4px 0; border-bottom: 2px solid transparent; white-space: nowrap; }
.lx-nav a.is-active { color: var(--lacros-orange); border-bottom-color: var(--lacros-orange); }
.lx-nav a:hover { color: var(--lacros-orange); }
.lx-nav .lx-nav-new { margin-left: 6px; font-size: 9px; padding: 2px 6px; vertical-align: middle; }
.lx-header-tools { display: flex; align-items: center; gap: 18px; color: var(--ink); font-size: 16px; }
.lx-header-tools a { color: var(--ink); }
.lx-cart-wrap { position: relative; }
.lx-cart-count { position: absolute; top: -8px; right: -10px; background: var(--lacros-orange); color: #fff; font-size: 10px; font-weight: 700; width: 18px; height: 18px; border-radius: 999px; display: inline-flex; align-items: center; justify-content: center; }

/* ---- Mobile navigation ---- */
.lx-nav-toggle { display: none; background: none; border: 0; padding: 0; color: var(--ink); font-size: 20px; line-height: 1; cursor: pointer; }
body.lx-noscroll { overflow: hidden; }
.lx-mobile-nav { position: fixed; inset: 0; z-index: 50; background: #fff; display: flex; flex-direction: column; opacity: 0; visibility: hidden; transition: opacity .2s ease, visibility .2s ease; }
.lx-mobile-nav.is-open { opacity: 1; visibility: visible; }
.lx-mobile-nav-top { display: flex; align-items: center; justify-content: space-between; padding: 18px 32px; border-bottom: 1px solid var(--rule); }
.lx-mobile-nav-top img { height: 38px; width: auto; }
.lx-mobile-nav-close { background: none; border: 0; padding: 0; color: var(--ink); font-size: 24px; line-height: 1; cursor: pointer; }
.lx-mobile-nav-links { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 8px; flex: 1; padding: 32px; }
.lx-mobile-nav-links a { font-family: var(--font-display); font-weight: 500; font-size: 30px; color: var(--ink); padding: 10px 0; }
.lx-mobile-nav-links a.is-active { color: var(--lacros-orange); }
.lx-mobile-nav-links a:hover { color: var(--lacros-orange); }
.lx-mobile-nav-links .lx-nav-new { margin-left: 8px; font-size: 11px; padding: 3px 8px; vertical-align: middle; }
@media (min-width: 901px) { .lx-mobile-nav { display: none; } }

/* ============================== Hero ============================== */
.lx-hero-grid { display: grid; grid-template-columns: 1.1fr 1fr; gap: 48px; align-items: center; padding-top: 40px; padding-bottom: 80px; }
.lx-hero-media { background: var(--paper-2) center/cover no-repeat; border-radius: 8px; aspect-ratio: 4/5; position: relative; }
.lx-hero-media-chips { position: absolute; bottom: 20px; left: 20px; right: 20px; display: flex; gap: 8px; }
.lx-hero h1 { margin: 0 0 22px; }
.lx-hero-lead { font-size: 18px; color: var(--fg-2); line-height: 1.5; margin-bottom: 28px; max-width: 500px; }
.lx-hero-stats { display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; padding: 28px 0; border-top: 1px solid var(--rule); border-bottom: 1px solid var(--rule); margin-bottom: 28px; }
.lx-hero-stats > * { min-width: 0; }
.lx-hero-stats .lx-stat-n { font-family: var(--font-display); font-weight: 600; font-size: 40px; color: var(--ink); margin-bottom: 4px; line-height: 1; }
.lx-hero-stats .lx-stat-l { font-size: 12px; color: var(--fg-3); text-transform: uppercase; letter-spacing: .06em; }
.lx-hero-cta { display: flex; gap: 14px; flex-wrap: wrap; }

/* ============================== Keuzehulp (dark) ============================== */
.lx-keuze { background: var(--ink); color: #fff; padding: 80px 0; }
.lx-keuze-head { display: flex; justify-content: space-between; align-items: flex-end; gap: 24px; margin-bottom: 40px; flex-wrap: wrap; }
.lx-keuze-head h2 { color: #fff; max-width: 700px; }
.lx-keuze-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 16px; }
.lx-keuze-card { background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.1); border-radius: 8px; padding: 28px 24px; }
.lx-keuze-card-top { display: flex; justify-content: space-between; align-items: center; margin-bottom: 18px; }
.lx-keuze-card-top .lx-num { font-family: var(--font-display); font-weight: 500; font-size: 36px; color: var(--lacros-orange); line-height: 1; }
.lx-keuze-card-top i { color: rgba(255,255,255,.3); }
.lx-keuze-q { font-family: var(--font-display); font-weight: 500; font-size: 24px; color: #fff; margin-bottom: 18px; }
.lx-keuze-opts { display: flex; flex-direction: column; gap: 8px; }
.lx-keuze-opt { padding: 10px 14px; border-radius: 4px; background: rgba(255,255,255,.06); color: rgba(255,255,255,.85); font-size: 13px; font-weight: 600; }
.lx-keuze-opt.is-sel { background: var(--lacros-orange); color: #fff; }

/* ============================== Section heads ============================== */
.lx-section { padding-top: 88px; padding-bottom: 0; }
.lx-section-head { margin-bottom: 36px; }
.lx-section-head h2 { max-width: 800px; }

/* ============================== Product cards ============================== */
.lx-grid-3 { display: grid; grid-template-columns: repeat(3,1fr); gap: 20px; }
.lx-card { background: #fff; border-radius: 6px; overflow: hidden; border: 1px solid var(--rule); display: flex; flex-direction: column; }
.lx-card-media { position: relative; background: var(--paper); aspect-ratio: 4/3; display: flex; align-items: center; justify-content: center; }
.lx-card-media img { max-width: 82%; max-height: 82%; object-fit: contain; }
.lx-card-media .lx-tag-chip { position: absolute; top: 12px; left: 12px; }
.lx-sale-badge { position: absolute; top: 12px; right: 12px; background: var(--sale-red); color: #fff; font-size: 11px; font-weight: 700; padding: 3px 8px; border-radius: 3px; letter-spacing: .04em; }
.lx-card-body { padding: 18px 20px 20px; display: flex; flex-direction: column; flex: 1; }
.lx-card-cat { color: var(--fg-3); margin-bottom: 6px; }
.lx-card-body h3 { font-size: 22px; margin: 0 0 8px; color: var(--ink); }
.lx-card-blurb { color: var(--fg-2); font-size: 13px; line-height: 1.5; margin-bottom: 12px; min-height: 38px; }
.lx-card-specs { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 14px; }
.lx-card-specs span { font-size: 11px; color: var(--fg-2); background: var(--bg-mute); padding: 4px 8px; border-radius: 3px; }
.lx-card-foot { margin-top: auto; }
.lx-card-price-row { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 12px; }
.lx-card-was { color: var(--fg-4); text-decoration: line-through; font-size: 13px; margin-right: 8px; }
.lx-card-now { font-size: 22px; font-weight: 700; color: var(--ink); }
.lx-card-cta { display: flex; gap: 8px; }
.lx-card-cta .lx-btn-proefrit, .lx-card-cta .lx-btn-cart { flex: 1; padding: 10px 14px; font-size: 11px; justify-content: center; }

/* ============================== In de pers ============================== */
.lx-press { background: var(--paper); padding: 80px 0; }
.lx-press-head { text-align: center; margin-bottom: 48px; }
.lx-press-head h2 { max-width: 700px; margin: 0 auto; }
.lx-press-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 24px; }
.lx-press-card { background: #fff; border-radius: 6px; padding: 28px 24px; border: 1px solid var(--rule); }
.lx-press-card .lx-press-name { font-family: var(--font-display); font-weight: 500; font-size: 20px; color: var(--ink); margin-bottom: 10px; }
.lx-press-card .lx-press-stars { color: var(--rating-star); font-size: 13px; margin-bottom: 14px; }
.lx-press-card p { font-size: 14px; color: var(--fg-2); line-height: 1.5; font-style: italic; }

/* ============================== Locations ============================== */
.lx-loc { padding: 88px 0; }
.lx-loc-grid { display: grid; grid-template-columns: 1fr 1.4fr; gap: 56px; align-items: center; }
.lx-loc-text h2 { margin-bottom: 24px; }
.lx-loc-text p { color: var(--fg-2); font-size: 16px; line-height: 1.6; margin-bottom: 24px; }
.lx-map { position: relative; border-radius: 8px; overflow: hidden; border: 1px solid var(--rule); background: var(--paper); aspect-ratio: 16/10; }
.lx-map svg { width: 100%; height: 100%; display: block; }
.lx-pin { position: absolute; transform: translate(-50%,-100%); display: flex; flex-direction: column; align-items: center; }
.lx-pin .fa-location-dot { color: var(--ink); font-size: 20px; filter: drop-shadow(0 2px 4px rgba(0,0,0,.3)); }
.lx-pin.is-main .fa-location-dot { color: var(--lacros-orange); font-size: 28px; }
.lx-pin-label { background: var(--lacros-orange); color: #fff; padding: 4px 10px; border-radius: 4px; font-size: 11px; font-weight: 700; margin-bottom: 4px; white-space: nowrap; }
.lx-map-card { position: absolute; bottom: 16px; left: 16px; background: #fff; border-radius: 6px; padding: 14px; box-shadow: 0 4px 16px rgba(0,0,0,.12); width: 220px; }
.lx-map-card-t { font-weight: 700; color: var(--ink); margin-bottom: 2px; font-size: 14px; }
.lx-map-card-s { font-size: 12px; color: var(--fg-2); margin-bottom: 8px; }
.lx-map-card-tags { display: flex; gap: 6px; font-size: 11px; }
.lx-map-card-tags span { padding: 3px 7px; border-radius: 3px; }
.lx-map-card-tags .t1 { background: var(--lacros-orange-soft); color: var(--lacros-orange-hover); }
.lx-map-card-tags .t2 { background: var(--success-bg); color: var(--success-dark); }
.lx-map-card-tags .t3 { background: var(--bg-mute); color: var(--fg-2); }

/* ============================== Footer ============================== */
.lx-footer { background: var(--ink); color: rgba(255,255,255,.75); padding: 64px 0 28px; font-size: 13px; }
.lx-footer-top { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr 1.4fr; gap: 40px; padding-bottom: 40px; border-bottom: 1px solid rgba(255,255,255,.12); }
.lx-footer-brand img { height: 40px; margin-bottom: 18px; }
.lx-footer-brand p { color: rgba(255,255,255,.7); max-width: 320px; line-height: 1.6; margin-bottom: 18px; }
.lx-footer-social { display: flex; gap: 14px; font-size: 16px; color: rgba(255,255,255,.7); }
.lx-footer-social a:hover { color: #fff; }
.lx-footer-col-title { color: #fff; font-weight: 700; margin-bottom: 14px; letter-spacing: .04em; text-transform: uppercase; font-size: 12px; }
.lx-footer-col a { display: block; margin-bottom: 8px; color: rgba(255,255,255,.72); }
.lx-footer-col a:hover { color: #fff; }
.lx-footer-news p { color: rgba(255,255,255,.7); margin-bottom: 14px; line-height: 1.6; }
.lx-footer-news-form { display: flex; background: rgba(255,255,255,.08); border-radius: 4px; overflow: hidden; }
.lx-footer-news-form input { flex: 1; padding: 12px 14px; background: transparent; border: 0; color: #fff; font-size: 13px; outline: none; font-family: var(--font-sans); }
.lx-footer-news-form button { background: var(--lacros-orange); color: #fff; border: 0; padding: 0 18px; font-weight: 700; cursor: pointer; font-size: 13px; letter-spacing: .04em; text-transform: uppercase; font-family: var(--font-sans); }
.lx-footer-bottom { display: flex; justify-content: space-between; padding: 24px 0 0; color: rgba(255,255,255,.5); font-size: 12px; flex-wrap: wrap; gap: 12px; }
.lx-footer-legal { display: flex; gap: 24px; flex-wrap: wrap; }

/* ============================== Responsive ============================== */
@media (max-width: 1100px) {
  .lx-display.xl { font-size: 64px; }
  .lx-display.l { font-size: 52px; }
  .lx-display.m { font-size: 42px; }
  .lx-press-grid { grid-template-columns: 1fr 1fr; }
  .lx-footer-top { grid-template-columns: 1fr 1fr 1fr; }
  .lx-footer-brand, .lx-footer-news { grid-column: span 3; }
}
@media (max-width: 900px) {
  .lx-nav { display: none; }
  .lx-nav-toggle { display: inline-flex; }
  .lx-header-inner { grid-template-columns: 1fr auto auto; }
  .lx-ribbon-left span:nth-child(n+2) { display: none; }
  .lx-hero-grid { grid-template-columns: 1fr; gap: 32px; }
  .lx-hero-media { aspect-ratio: 16/10; }
  .lx-keuze-grid { grid-template-columns: 1fr; }
  .lx-grid-3 { grid-template-columns: 1fr 1fr; }
  .lx-loc-grid { grid-template-columns: 1fr; gap: 32px; }
}
@media (max-width: 620px) {
  .lx-wrap, .lx-ribbon-inner, .lx-header-inner { padding-left: 20px; padding-right: 20px; }
  .lx-display.xl { font-size: 48px; }
  .lx-display.l { font-size: 40px; }
  .lx-grid-3, .lx-press-grid, .lx-footer-top { grid-template-columns: 1fr; }
  .lx-footer-brand, .lx-footer-news { grid-column: auto; }
  .lx-ribbon-right .lx-ribbon-langs { display: none; }
  .lx-hero-stats { gap: 12px; padding: 22px 0; }
  .lx-hero-stats .lx-stat-n { font-size: 26px; }
  .lx-hero-grid { padding-bottom: 56px; }
  .lx-section { padding-top: 56px; }
  .lx-keuze, .lx-press, .lx-loc { padding: 56px 0; }
}

/* =============================================================
   Vouwfietsen Overzicht — page-specific styles
   ============================================================= */

/* ---- Editorial link ---- */
.lx-elink { display: inline-flex; align-items: center; gap: 10px; font-size: 15px; font-weight: 700; color: var(--ink); border-bottom: 2px solid var(--lacros-orange); padding-bottom: 4px; transition: gap .15s ease; }
.lx-elink i { font-size: 13px; color: var(--lacros-orange); }
.lx-elink:hover { gap: 14px; }
.lx-elink.on-dark { color: #fff; }

/* ---- Page intro ---- */
.lx-intro { padding-top: 48px; padding-bottom: 24px; }
.lx-breadcrumb { font-size: 12px; color: var(--fg-4); margin-bottom: 22px; }
.lx-breadcrumb .sep { margin: 0 8px; }
.lx-breadcrumb .cur { color: var(--fg-2); }
.lx-intro-grid { display: grid; grid-template-columns: 1.4fr 1fr; gap: 56px; align-items: end; }
.lx-intro h1 { margin: 0 0 18px; }
.lx-intro-lead { font-size: 18px; color: var(--fg-2); line-height: 1.55; max-width: 520px; }
.lx-intro-note { background: var(--paper); border: 1px solid var(--rule); border-radius: 8px; padding: 22px 24px; }
.lx-intro-note .t { font-family: var(--font-display); font-weight: 500; font-size: 22px; color: var(--ink); margin-bottom: 8px; }
.lx-intro-note p { font-size: 14px; color: var(--fg-2); line-height: 1.55; margin-bottom: 16px; }

/* ---- Index strip ---- */
.lx-index { border-top: 1px solid var(--rule); border-bottom: 1px solid var(--rule); margin-top: 36px; }
.lx-index-inner { display: flex; align-items: center; gap: 8px; padding: 14px 0; flex-wrap: wrap; }
.lx-index-label { font-size: 11px; color: var(--fg-3); text-transform: uppercase; letter-spacing: .1em; margin-right: 10px; }
.lx-index-chip { display: inline-flex; align-items: baseline; gap: 7px; padding: 7px 13px; border: 1px solid var(--rule); border-radius: var(--radius-pill); font-size: 13px; font-weight: 600; color: var(--ink); transition: background .15s ease, border-color .15s ease; }
.lx-index-chip .n { font-size: 11px; color: var(--lacros-orange); font-weight: 700; }
.lx-index-chip:hover { background: var(--ink); color: #fff; border-color: var(--ink); }
.lx-index-chip:hover .n { color: #fff; }

/* ---- Model rows ---- */
.lx-band { scroll-margin-top: 80px; }
.lx-band--white  { background: #fff; }
.lx-band--paper  { background: var(--paper); }
.lx-band--paper2 { background: var(--paper-2); }
.lx-band--dark   { background: var(--ink); }
.lx-model {
  display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: center;
  padding: 76px 0; scroll-margin-top: 80px;
}
.lx-model.is-flip .lx-model-media { order: 2; }
.lx-model.is-flip .lx-model-text { order: 1; }
.lx-band--paper .lx-model-media.is-cutout,
.lx-band--paper2 .lx-model-media.is-cutout,
.lx-band--dark .lx-model-media.is-cutout { background: #fff; box-shadow: 0 0 0 1px var(--rule); }
.lx-band--dark .lx-model-media.is-cutout { box-shadow: none; }
.lx-band--dark .lx-display { color: #fff; }
.lx-band--dark .lx-eyebrow { color: rgba(255,255,255,.55); }
.lx-band--dark .lx-model-tagline { color: rgba(255,255,255,.8); }
.lx-band--dark .lx-model-desc { color: rgba(255,255,255,.72); }
.lx-band--dark .lx-model-figs { border-top-color: rgba(255,255,255,.18); border-bottom-color: rgba(255,255,255,.18); }
.lx-band--dark .lx-fig-l { color: rgba(255,255,255,.45); }
.lx-band--dark .lx-fig-v { color: #fff; }
.lx-band--dark .lx-fig-v small { color: rgba(255,255,255,.55); }
.lx-band--dark .lx-elink { color: #fff; }
.lx-band--dark .lx-model-from { color: rgba(255,255,255,.6); }
.lx-band--dark .lx-model-from b { color: #fff; }

.lx-model-media { position: relative; border-radius: 10px; overflow: hidden; aspect-ratio: 5/4; background: var(--paper-2); }
.lx-model-media.is-cutout { background: var(--paper); display: flex; align-items: center; justify-content: center; }
.lx-model-media.is-photo { background-size: cover; background-position: center; }
.lx-model-media.is-cutout img { max-width: 78%; max-height: 80%; object-fit: contain; }
.lx-model-bignum {
  position: absolute; top: 14px; left: 20px; z-index: 2;
  font-family: var(--font-display); font-weight: 600; font-size: 88px; line-height: 1;
  color: transparent; -webkit-text-stroke: 1.5px rgba(255,255,255,.7); letter-spacing: -0.04em;
}
.lx-model-media.is-cutout .lx-model-bignum { -webkit-text-stroke: 1.5px var(--rule); }
.lx-model-badge { position: absolute; top: 18px; right: 18px; z-index: 2; }

.lx-model-eyebrow { display: flex; align-items: center; gap: 12px; margin-bottom: 16px; }
.lx-model-eyebrow .line { width: 24px; height: 2px; background: var(--lacros-orange); }
.lx-model-text h2 { margin: 0 0 12px; }
.lx-model-tagline { font-size: 19px; font-style: italic; color: var(--fg-2); line-height: 1.45; margin-bottom: 18px; max-width: 460px; }
.lx-model-desc { font-size: 15.5px; color: var(--fg-2); line-height: 1.65; max-width: 480px; margin-bottom: 28px; }
.lx-model-figs { display: flex; gap: 40px; padding: 22px 0; border-top: 1px solid var(--rule); border-bottom: 1px solid var(--rule); margin-bottom: 26px; flex-wrap: wrap; }
.lx-fig-l { font-size: 10.5px; font-weight: 800; letter-spacing: .1em; text-transform: uppercase; color: var(--fg-4); margin-bottom: 6px; }
.lx-fig-v { font-family: var(--font-display); font-weight: 500; font-size: 24px; color: var(--ink); line-height: 1; }
.lx-fig-v.is-text { font-size: 18px; }
.lx-fig-v small { font-family: var(--font-sans); font-weight: 600; font-size: 13px; color: var(--fg-3); }
.lx-model-foot { display: flex; align-items: center; gap: 26px; flex-wrap: wrap; }
.lx-model-from { font-size: 13.5px; color: var(--fg-3); }
.lx-model-from b { color: var(--ink); font-size: 15px; }

/* ---- Intro lifestyle strip ---- */
.lx-intro-photo { margin-top: 32px; border-radius: 10px; overflow: hidden; aspect-ratio: 1000 / 400; background: var(--paper-2) center 60%/cover no-repeat; }

/* ---- Brand interlude ---- */
.lx-interlude { background: var(--paper-2); padding: 84px 0; }
.lx-interlude-head { max-width: 720px; margin-bottom: 40px; }
.lx-interlude-head h2 { margin: 14px 0 0; }
.lx-interlude-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.lx-interlude-img { border-radius: 10px; overflow: hidden; aspect-ratio: 4 / 3; background: #fff center/cover no-repeat; margin-bottom: 16px; box-shadow: 0 0 0 1px var(--rule); }
.lx-interlude-card .ic-l { font-size: 11px; font-weight: 800; letter-spacing: .1em; text-transform: uppercase; color: var(--lacros-orange); margin-bottom: 6px; }
.lx-interlude-card .ic-t { font-family: var(--font-display); font-weight: 500; font-size: 21px; color: var(--ink); margin-bottom: 6px; }
.lx-interlude-card p { font-size: 14px; color: var(--fg-2); line-height: 1.55; }

/* ---- Closing band ---- */
.lx-closing { background: var(--ink); color: #fff; padding: 80px 0; margin-top: 8px; }
.lx-closing-grid { display: grid; grid-template-columns: 1.3fr 1fr; gap: 56px; align-items: center; }
.lx-closing h2 { color: #fff; max-width: 560px; margin: 0 0 16px; }
.lx-closing p { color: rgba(255,255,255,.72); font-size: 16px; line-height: 1.6; max-width: 480px; }
.lx-closing-cta { display: flex; gap: 14px; justify-content: flex-end; flex-wrap: wrap; }
.lx-closing--photo { position: relative; background: var(--ink); overflow: hidden; }
.lx-closing--photo::before { content: ''; position: absolute; inset: 0; background-image: linear-gradient(90deg, rgba(20,20,20,.93) 0%, rgba(20,20,20,.66) 50%, rgba(20,20,20,.34) 100%), url(/assets/brand-banner.jpg); background-size: cover; background-position: center; }
.lx-closing--photo > .lx-wrap { position: relative; z-index: 1; }

/* ---- Overzicht responsive ---- */
@media (max-width: 900px) {
  .lx-intro-grid { grid-template-columns: 1fr; gap: 28px; }
  .lx-model, .lx-model.is-flip { grid-template-columns: 1fr; gap: 28px; }
  .lx-model.is-flip .lx-model-media { order: 1; }
  .lx-model.is-flip .lx-model-text { order: 2; }
  .lx-closing-grid { grid-template-columns: 1fr; gap: 28px; }
  .lx-closing-cta { justify-content: flex-start; }
  .lx-interlude-grid { grid-template-columns: 1fr; gap: 28px; }
  .lx-intro-photo { aspect-ratio: 16 / 10; }
}
@media (max-width: 620px) {
  .lx-model-figs { gap: 24px; }
  .lx-intro { padding-top: 32px; padding-bottom: 16px; }
  .lx-model { padding: 52px 0; }
  .lx-model-bignum { font-size: 60px; }
  .lx-interlude { padding: 56px 0; }
  .lx-closing { padding: 56px 0; }
}

/* =============================================================
   Product detail page (PDP) — page-specific styles
   ============================================================= */

/* ===== PDP hero ===== */
.lx-pdp { padding-top: 28px; padding-bottom: 48px; }
.lx-pdp-grid { display: grid; grid-template-columns: 1.05fr 1fr; gap: 56px; align-items: start; }
.lx-gallery { position: sticky; top: 96px; }
.lx-gallery-main { background: var(--paper); border-radius: 12px; aspect-ratio: 5/4; display: flex; align-items: center; justify-content: center; position: relative; }
.lx-gallery-main img { max-width: 84%; max-height: 84%; object-fit: contain; }
.lx-gallery-main .lx-tag-chip { position: absolute; top: 18px; left: 18px; }
.lx-gallery-thumbs { display: grid; grid-template-columns: repeat(4,1fr); gap: 12px; margin-top: 12px; }
.lx-gallery-thumbs > * { min-width: 0; }
.lx-thumb { border-radius: 8px; overflow: hidden; aspect-ratio: 1/1; background: var(--bg-mute) center/cover no-repeat; border: 1px solid var(--rule); cursor: pointer; }
.lx-thumb.is-active { box-shadow: 0 0 0 2px var(--lacros-orange); border-color: transparent; }

.lx-pdp-info .lx-pdp-eyebrow { display: flex; align-items: center; gap: 12px; margin-bottom: 16px; }
.lx-pdp-info .lx-pdp-eyebrow .line { width: 24px; height: 2px; background: var(--lacros-orange); }
.lx-pdp-info h1 { margin: 0 0 14px; }
.lx-pdp-tagline { font-size: 20px; font-style: italic; color: var(--fg-2); line-height: 1.45; margin-bottom: 18px; }
.lx-pdp-intro { font-size: 16px; color: var(--fg-2); line-height: 1.65; margin-bottom: 28px; }
.lx-rating-line { display: inline-flex; align-items: center; gap: 10px; font-size: 13px; color: var(--fg-3); margin-bottom: 28px; }
.lx-rating-line .stars { color: var(--rating-star); font-size: 14px; }
.lx-rating-line b { color: var(--ink); }

.lx-pdp-figs { display: grid; grid-template-columns: repeat(4,1fr); gap: 18px; padding: 24px 0; border-top: 1px solid var(--rule); border-bottom: 1px solid var(--rule); margin-bottom: 26px; }
.lx-pdp-figs .l { font-size: 10.5px; font-weight: 800; letter-spacing: .1em; text-transform: uppercase; color: var(--fg-4); margin-bottom: 6px; }
.lx-pdp-figs .v { font-family: var(--font-display); font-weight: 500; font-size: 22px; color: var(--ink); line-height: 1; }
.lx-pdp-figs .v.is-text { font-size: 17px; }
.lx-pdp-figs .v small { font-family: var(--font-sans); font-weight: 600; font-size: 12px; color: var(--fg-3); }

.lx-bullets { list-style: none; margin: 0 0 30px; padding: 0; }
.lx-bullets li { display: flex; gap: 12px; align-items: flex-start; padding: 7px 0; font-size: 14.5px; color: var(--fg-2); }
.lx-bullets i { color: var(--lacros-orange); font-size: 13px; margin-top: 4px; }

/* Buy card */
.lx-buy { border: 1px solid var(--rule); border-radius: 12px; padding: 24px; background: #fff; }
.lx-buy-top { display: flex; align-items: baseline; justify-content: space-between; gap: 12px; margin-bottom: 18px; flex-wrap: wrap; }
.lx-buy-price { font-family: var(--font-display); font-weight: 600; font-size: 32px; color: var(--ink); }
.lx-buy-price small { font-family: var(--font-sans); font-weight: 600; font-size: 12px; color: var(--fg-3); margin-left: 8px; letter-spacing: .02em; }
.lx-buy-stock { font-size: 12.5px; color: var(--success-dark); font-weight: 700; display: inline-flex; align-items: center; gap: 6px; }
.lx-buy-row { margin-bottom: 18px; }
.lx-buy-label { font-size: 11px; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; color: var(--fg-3); margin-bottom: 10px; }
.lx-swatches { display: flex; gap: 10px; align-items: center; }
.lx-swatch { width: 30px; height: 30px; border-radius: 999px; border: 2px solid #fff; box-shadow: 0 0 0 1px var(--rule); cursor: pointer; }
.lx-swatch.is-active { box-shadow: 0 0 0 2px var(--lacros-orange); }
.lx-swatch-name { font-size: 13px; color: var(--fg-2); margin-left: 6px; }
.lx-battery-opts { display: flex; gap: 10px; flex-wrap: wrap; }
.lx-battery-opt { border: 1px solid var(--rule); border-radius: 8px; padding: 10px 14px; font-size: 13px; color: var(--fg-2); cursor: pointer; }
.lx-battery-opt.is-active { border-color: var(--ink); color: var(--ink); font-weight: 700; }
.lx-battery-opt b { color: var(--ink); }
.lx-buy-cta { display: grid; grid-template-columns: 1.3fr 1fr; gap: 10px; margin: 20px 0 16px; }
.lx-reassure { display: flex; flex-direction: column; gap: 8px; }
.lx-reassure span { display: flex; align-items: center; gap: 10px; font-size: 12.5px; color: var(--fg-2); }
.lx-reassure i { color: var(--lacros-orange); width: 16px; text-align: center; }

/* ===== Editorial feature blocks ===== */
.lx-feature { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: center; padding: 80px 0; }
.lx-feature.is-flip .lx-feature-media { order: 2; }
.lx-feature.is-flip .lx-feature-text { order: 1; }
.lx-feature-media { border-radius: 12px; overflow: hidden; aspect-ratio: 5/4; background: var(--paper-2) center/cover no-repeat; }
.lx-feature-eyebrow { display: flex; align-items: center; gap: 12px; margin-bottom: 16px; }
.lx-feature-eyebrow .line { width: 24px; height: 2px; background: var(--lacros-orange); }
.lx-feature-text h2 { margin: 0 0 16px; }
.lx-feature-text p { font-size: 16px; color: var(--fg-2); line-height: 1.7; max-width: 480px; }
.lx-band--dark .lx-feature-text p { color: rgba(255,255,255,.74); }

/* ===== Specs ===== */
.lx-specs { padding-top: 84px; padding-bottom: 84px; }
.lx-specs-head { margin-bottom: 36px; }
.lx-specs-head h2 { margin-top: 14px; }
.lx-specs-grid { column-count: 2; column-gap: 64px; }
.lx-spec-row { display: flex; justify-content: space-between; gap: 24px; padding: 14px 0; border-bottom: 1px solid var(--rule); font-size: 14.5px; break-inside: avoid; }
.lx-spec-row .k { color: var(--fg-3); }
.lx-spec-row .v { color: var(--ink); font-weight: 600; text-align: right; }

/* ===== Reviews ===== */
.lx-reviews { background: var(--paper); padding: 84px 0; }
.lx-reviews-head { display: flex; align-items: flex-end; justify-content: space-between; gap: 24px; margin-bottom: 40px; flex-wrap: wrap; }
.lx-reviews-head h2 { margin-top: 14px; }
.lx-reviews-score { text-align: right; }
.lx-reviews-score .n { font-family: var(--font-display); font-weight: 600; font-size: 44px; color: var(--ink); line-height: 1; }
.lx-reviews-score .s { color: var(--rating-star); font-size: 15px; }
.lx-reviews-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 20px; }
.lx-review { background: #fff; border: 1px solid var(--rule); border-radius: 10px; padding: 24px; }
.lx-review .s { color: var(--rating-star); font-size: 13px; margin-bottom: 12px; }
.lx-review p { font-size: 14.5px; color: var(--fg-2); line-height: 1.6; margin-bottom: 14px; font-style: italic; }
.lx-review .who { font-size: 13px; color: var(--fg-3); }
.lx-review .who b { color: var(--ink); font-weight: 700; }

/* ===== PDP closing (photo = brand-building) ===== */
.lx-closing--building::before { background-image: linear-gradient(90deg, rgba(20,20,20,.93) 0%, rgba(20,20,20,.66) 52%, rgba(20,20,20,.34) 100%), url(/assets/brand-building.webp); }

/* ===== PDP responsive ===== */
@media (max-width: 1100px) {
  .lx-reviews-grid { grid-template-columns: 1fr; }
}
@media (max-width: 920px) {
  .lx-pdp-grid { grid-template-columns: 1fr; gap: 32px; }
  .lx-gallery { position: static; }
  .lx-feature, .lx-feature.is-flip { grid-template-columns: 1fr; gap: 28px; }
  .lx-feature.is-flip .lx-feature-media { order: 1; }
  .lx-feature.is-flip .lx-feature-text { order: 2; }
  .lx-specs-grid { column-count: 1; }
}
@media (max-width: 620px) {
  .lx-pdp-figs { grid-template-columns: 1fr 1fr; gap: 18px 12px; }
  .lx-buy-cta { grid-template-columns: 1fr; }
  .lx-pdp { padding-top: 16px; padding-bottom: 40px; }
  .lx-feature { padding: 52px 0; }
  .lx-specs { padding-top: 56px; padding-bottom: 56px; }
  .lx-reviews { padding: 56px 0; }
}
