image.png/*
 * LOGUETOWN — Design System 2026 "Édition Collector"
 * Fraunces serif · Inter sans · JetBrains Mono
 * Bleu nuit #0E1B26 + Champagne #D4A574  |  Dark / Light
 * Généré depuis le prototype Claude Design — 29 avr. 2026
 */

@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,300;0,9..144,400;0,9..144,500;0,9..144,600;0,9..144,700;0,9..144,800;1,9..144,300;1,9..144,400;1,9..144,500;1,9..144,600;1,9..144,700&family=JetBrains+Mono:wght@300;400;500&display=swap');

/* =====================================================================
   TOKENS 2026
   ===================================================================== */
:root {
  --lt26-champagne:      #D4A574;
  --lt26-champagne-soft: #E8C99A;
  --lt26-champagne-deep: #B8895A;
  --lt26-champagne-glow: rgba(212, 165, 116, 0.32);
  --lt26-coral:          #EE5C6E;
  --lt26-coral-deep:     #D94556;
  --lt26-serif:          "Fraunces", "Times New Roman", serif;
  --lt26-sans:           "Inter", -apple-system, "Helvetica Neue", sans-serif;
  --lt26-mono:           "JetBrains Mono", ui-monospace, monospace;
  --lt26-ease-expo:      cubic-bezier(0.16, 1, 0.3, 1);
  --lt26-ease-soft:      cubic-bezier(0.65, 0, 0.35, 1);
  --lt26-ease-spring:    cubic-bezier(0.34, 1.56, 0.64, 1);
}

/* Dark (défaut) */
:root, [data-theme="dark"] {
  --lt26-bg:          #0E1B26;
  --lt26-bg-soft:     #142531;
  --lt26-bg-elev:     #1A2F3D;
  --lt26-bg-elev2:    #20384A;
  --lt26-line:        rgba(232, 201, 154, 0.14);
  --lt26-line-strong: rgba(232, 201, 154, 0.28);
  --lt26-ink:         #F4EAD9;
  --lt26-ink-soft:    rgba(244, 234, 217, 0.72);
  --lt26-ink-mute:    rgba(244, 234, 217, 0.46);
  --lt26-shadow-soft: 0 30px 80px -20px rgba(0,0,0,0.6);
  --lt26-shadow-glow: 0 0 80px -20px var(--lt26-champagne-glow);

  /* Aliases compatibles maquettes Claude (tokens.css) */
  --bg: var(--lt26-bg);
  --bg-soft: var(--lt26-bg-soft);
  --bg-elev: var(--lt26-bg-elev);
  --bg-elev-2: var(--lt26-bg-elev2);
  --line: var(--lt26-line);
  --line-strong: var(--lt26-line-strong);
  --ink: var(--lt26-ink);
  --ink-soft: var(--lt26-ink-soft);
  --ink-mute: var(--lt26-ink-mute);
  --shadow-soft: var(--lt26-shadow-soft);
  --shadow-glow: var(--lt26-shadow-glow);
  --champagne: var(--lt26-champagne);
  --champagne-soft: var(--lt26-champagne-soft);
  --champagne-deep: var(--lt26-champagne-deep);
  --champagne-glow: var(--lt26-champagne-glow);
  --coral: var(--lt26-coral);
  --coral-deep: var(--lt26-coral-deep);
  --serif: var(--lt26-serif);
  --sans: var(--lt26-sans);
  --mono: var(--lt26-mono);
  --ease-out-expo: var(--lt26-ease-expo);
  --ease-in-out-soft: var(--lt26-ease-soft);
  --ease-spring: var(--lt26-ease-spring);
}

/* Light */
[data-theme="light"] {
  --lt26-bg:          #F6EFE2;
  --lt26-bg-soft:     #EFE5D2;
  --lt26-bg-elev:     #FAF4E8;
  --lt26-bg-elev2:    #FFFFFF;
  --lt26-line:        rgba(46, 36, 24, 0.12);
  --lt26-line-strong: rgba(46, 36, 24, 0.24);
  --lt26-ink:         #1B2630;
  --lt26-ink-soft:    rgba(27, 38, 48, 0.72);
  --lt26-ink-mute:    rgba(27, 38, 48, 0.5);
  --lt26-shadow-soft: 0 30px 60px -25px rgba(31, 22, 14, 0.18);
  --lt26-shadow-glow: 0 0 80px -20px rgba(184, 137, 90, 0.35);

  /* Aliases compatibles maquettes Claude (tokens.css) */
  --bg: var(--lt26-bg);
  --bg-soft: var(--lt26-bg-soft);
  --bg-elev: var(--lt26-bg-elev);
  --bg-elev-2: var(--lt26-bg-elev2);
  --line: var(--lt26-line);
  --line-strong: var(--lt26-line-strong);
  --ink: var(--lt26-ink);
  --ink-soft: var(--lt26-ink-soft);
  --ink-mute: var(--lt26-ink-mute);
  --shadow-soft: var(--lt26-shadow-soft);
  --shadow-glow: var(--lt26-shadow-glow);
  --champagne: var(--lt26-champagne);
  --champagne-soft: var(--lt26-champagne-soft);
  --champagne-deep: var(--lt26-champagne-deep);
  --champagne-glow: var(--lt26-champagne-glow);
  --coral: var(--lt26-coral);
  --coral-deep: var(--lt26-coral-deep);
  --serif: var(--lt26-serif);
  --sans: var(--lt26-sans);
  --mono: var(--lt26-mono);
  --ease-out-expo: var(--lt26-ease-expo);
  --ease-in-out-soft: var(--lt26-ease-soft);
  --ease-spring: var(--lt26-ease-spring);
}

/* Appliquer les nouvelles couleurs de fond/texte */
html, body {
  background: var(--lt26-bg) !important;
  color: var(--lt26-ink);
  font-family: var(--lt26-sans);
  transition: background 600ms var(--lt26-ease-expo), color 600ms var(--lt26-ease-expo);
  overflow-x: hidden;
}
::selection { background: var(--lt26-champagne); color: #0E1B26; }

/* =====================================================================
   GRAIN OVERLAY
   ===================================================================== */
body.lt26-grain::after {
  content: "";
  position: fixed; inset: 0;
  pointer-events: none; z-index: 9999; opacity: 0.04;
  mix-blend-mode: overlay;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}

/* ==========================================================================
   NAV OFFSET — géré par loguetown-gl.css via --gl-nav-h.
   Ces règles sont conservées comme fallback mais désactivées.
   ========================================================================== */
/* body.lt26-grain nav offset → see loguetown-gl.css */

/* =====================================================================
   BANDEAUX GLOBAL (toutes pages) — même navy que la nav
   Cible les "heroes" legacy : .lt-hero (lt-page) + communauté/forum.
   ===================================================================== */
body.lt26-grain .lt-hero,
body.lt26-grain .communaute-hero,
body.lt26-grain .communaute-sub-hero {
  background:
    radial-gradient(80% 60% at 50% -10%, rgba(212,165,116,0.14), transparent 60%),
    radial-gradient(50% 60% at 18% 30%, rgba(212,165,116,0.06), transparent 70%),
    radial-gradient(50% 60% at 82% 30%, rgba(212,165,116,0.06), transparent 70%),
    linear-gradient(180deg, var(--bg) 0%, var(--bg-soft) 100%) !important;
  border-bottom: 1px solid var(--line) !important;
  color: var(--ink) !important;
}
body.lt26-grain .lt-hero .lt-lead,
body.lt26-grain .communaute-hero .lt-lead,
body.lt26-grain .communaute-sub-hero .lt-lead,
body.lt26-grain .communaute-hero .forum-sujet-meta,
body.lt26-grain .communaute-sub-hero .forum-sujet-meta {
  color: var(--ink-soft) !important;
}

[data-theme="light"] body.lt26-grain .lt-hero,
[data-theme="light"] body.lt26-grain .communaute-hero,
[data-theme="light"] body.lt26-grain .communaute-sub-hero {
  background:
    radial-gradient(circle at 18% 10%, rgba(212,165,116,0.18), transparent 55%),
    radial-gradient(circle at 80% 60%, rgba(238,92,110,0.06), transparent 62%),
    linear-gradient(180deg, var(--bg-elev-2) 0%, var(--bg-elev) 100%) !important;
  border-bottom: 1px solid var(--line) !important;
  color: var(--ink) !important;
}

/* =====================================================================
   CURSEUR CUSTOM
   ===================================================================== */
.lt26-cursor-dot, .lt26-cursor-ring {
  position: fixed; top: 0; left: 0;
  pointer-events: none; z-index: 9998;
  transform: translate(-50%, -50%);
  mix-blend-mode: difference;
}
.lt26-cursor-dot {
  width: 6px; height: 6px;
  background: #fff; border-radius: 50%;
  transition: transform 80ms ease, opacity 200ms ease;
}
.lt26-cursor-ring {
  width: 36px; height: 36px;
  border: 1px solid rgba(255,255,255,0.6); border-radius: 50%;
  transition: transform 240ms var(--lt26-ease-expo), width 240ms ease,
              height 240ms ease, border-color 240ms ease;
}
.lt26-cursor-ring.is-hover { width: 60px; height: 60px; border-color: var(--lt26-champagne); }
@media (hover: none) { .lt26-cursor-dot, .lt26-cursor-ring { display: none; } }

/* =====================================================================
   REVEAL ON SCROLL
   ===================================================================== */
.lt26-reveal {
  opacity: 0; transform: translateY(28px);
  transition: opacity 1000ms var(--lt26-ease-expo), transform 1000ms var(--lt26-ease-expo);
}
.lt26-reveal.in { opacity: 1; transform: translateY(0); }

/* Délais stagger */
.lt26-reveal[data-delay="1"] { transition-delay: 100ms; }
.lt26-reveal[data-delay="2"] { transition-delay: 200ms; }
.lt26-reveal[data-delay="3"] { transition-delay: 300ms; }

/* =====================================================================
   TYPOGRAPHIE
   ===================================================================== */
.lt26-serif   { font-family: var(--lt26-serif); font-optical-sizing: auto; }
.lt26-mono    { font-family: var(--lt26-mono); }
.lt26-italic  { font-style: italic; }
.lt26-eyebrow {
  font-family: var(--lt26-mono); font-size: 11px;
  letter-spacing: 0.22em; text-transform: uppercase; color: var(--lt26-champagne);
}
.lt26-display {
  font-family: var(--lt26-serif); font-weight: 400;
  letter-spacing: -0.02em; line-height: 0.96;
}

/* =====================================================================
   BOUTONS
   ===================================================================== */
.lt26-btn {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 13px 22px; border-radius: 999px;
  font-family: var(--lt26-sans); font-size: 14px; font-weight: 500; letter-spacing: 0.02em;
  border: 1px solid transparent;
  background: var(--lt26-ink); color: var(--lt26-bg);
  transition: transform 280ms var(--lt26-ease-expo), background 280ms, box-shadow 280ms;
  white-space: nowrap; cursor: pointer; text-decoration: none;
}
.lt26-btn:hover { transform: translateY(-2px); box-shadow: 0 16px 40px -16px rgba(0,0,0,0.4); }
.lt26-btn--coral  { background: var(--lt26-coral); color: #fff; }
.lt26-btn--coral:hover { background: var(--lt26-coral-deep); }
.lt26-btn--ghost  { background: transparent; color: var(--lt26-ink); border-color: var(--lt26-line-strong); }
.lt26-btn--ghost:hover { border-color: var(--lt26-champagne); color: var(--lt26-champagne); }
.lt26-btn--champ  { background: var(--lt26-champagne); color: #0E1B26; }
.lt26-btn--champ:hover { background: var(--lt26-champagne-deep); }

/* =====================================================================
   TOP NAV
   ===================================================================== */
.lt26-nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 5000;
  padding: 14px 0;
  background: linear-gradient(180deg, var(--lt26-bg) 0%, transparent 100%);
  transition: all 400ms var(--lt26-ease-expo);
}
.lt26-nav.is-scrolled {
  padding: 8px 0;
  backdrop-filter: blur(18px) saturate(140%);
  -webkit-backdrop-filter: blur(18px) saturate(140%);
  background: color-mix(in srgb, var(--lt26-bg) 82%, transparent);
  border-bottom: 1px solid var(--lt26-line);
}
[data-theme="dark"] .lt26-nav.is-scrolled {
  background: rgba(14, 27, 38, 0.82);
}
[data-theme="light"] .lt26-nav.is-scrolled {
  background: rgba(246, 239, 226, 0.88);
}

/* Thème clair : rendre la nav "barre" comme sur la maquette (fond clair + underline actif) */
[data-theme="light"] .lt26-nav {
  background: rgba(246, 239, 226, 0.96);
  border-bottom: 1px solid var(--lt26-line);
}
[data-theme="light"] .lt26-nav__link {
  color: var(--lt26-ink-soft);
}
[data-theme="light"] .lt26-nav__link:hover,
[data-theme="light"] .lt26-nav__link.is-active {
  color: var(--lt26-ink);
}
[data-theme="light"] .lt26-nav__link-line {
  height: 2px;
  bottom: 2px;
  background: var(--lt26-coral);
}
.lt26-nav__inner {
  max-width: 1480px; margin: 0 auto; padding: 0 24px;
  display: flex; align-items: center; gap: 0;
}
.lt26-nav__brand {
  display: inline-flex; align-items: center; text-decoration: none; flex-shrink: 0;
}
.lt26-nav__brand svg text { font-family: var(--lt26-serif, "Fraunces", serif); }

.lt26-nav__links {
  display: flex; align-items: center; justify-content: center;
  gap: 0; list-style: none; margin: 0; padding: 0; flex: 1;
}
.lt26-nav__link {
  position: relative; padding: 10px 12px;
  font-size: 13px; font-weight: 500; color: var(--lt26-ink-soft);
  letter-spacing: 0.01em; transition: color 240ms; text-decoration: none;
  display: block; white-space: nowrap;
}
.lt26-nav__link:hover, .lt26-nav__link.is-active { color: var(--lt26-ink); }
.lt26-nav__link-line {
  position: absolute; left: 12px; right: 12px; bottom: 4px;
  height: 1px; background: var(--lt26-champagne);
  transform: scaleX(0); transform-origin: left;
  transition: transform 360ms var(--lt26-ease-expo);
}
.lt26-nav__link:hover .lt26-nav__link-line,
.lt26-nav__link.is-active .lt26-nav__link-line { transform: scaleX(1); }

/* Barre de recherche nav */
.lt26-nav__search {
  position: relative; display: flex; align-items: center;
  margin: 0 12px;
}
.lt26-nav__search-input {
  height: 38px; width: 220px; border-radius: 12px;
  border: 1px solid var(--lt26-line-strong); background: var(--lt26-bg-elev);
  color: var(--lt26-ink); padding: 0 42px 0 14px; font-size: 13px;
  font-family: var(--lt26-sans); outline: none;
  transition: width 300ms var(--lt26-ease-expo), border-color 240ms, box-shadow 240ms;
}
.lt26-nav__search-input::placeholder { color: var(--lt26-ink-mute); }
.lt26-nav__search-input:focus {
  border-color: var(--lt26-champagne); width: 280px;
  box-shadow: 0 0 0 3px var(--lt26-champagne-glow);
}
.lt26-nav__search-btn {
  position: absolute; right: 5px;
  width: 28px; height: 28px; border-radius: 8px;
  background: var(--lt26-champagne); border: none; cursor: pointer;
  display: grid; place-items: center; color: #0E1B26;
  transition: background 200ms;
}
.lt26-nav__search-btn:hover { background: var(--lt26-champagne-deep); }
#lt26-search-suggestions {
  position: absolute; top: calc(100% + 6px); left: 0; right: 0;
  background: var(--lt26-bg-elev); border: 1px solid var(--lt26-line-strong);
  border-radius: 12px; box-shadow: var(--lt26-shadow-soft);
  display: none; z-index: 100; overflow: hidden;
}
.lt26-sugg-item {
  display: flex; align-items: center; gap: 10px; padding: 10px 14px;
  font-size: 13px; color: var(--lt26-ink-soft); cursor: pointer; transition: background 160ms;
}
.lt26-sugg-item:hover { background: color-mix(in srgb, var(--lt26-champagne) 10%, transparent); color: var(--lt26-ink); }
.lt26-sugg-type {
  margin-left: auto; font-family: var(--lt26-mono); font-size: 9.5px;
  letter-spacing: 0.14em; text-transform: uppercase; color: var(--lt26-champagne);
}

/* Actions */
.lt26-nav__actions {
  display: flex; align-items: center; gap: 4px; flex-shrink: 0;
}
.lt26-nav__icon {
  width: 38px; height: 38px; border-radius: 10px; border: none;
  background: transparent; color: var(--lt26-ink-soft);
  display: grid; place-items: center; cursor: pointer; text-decoration: none;
  transition: background 180ms, color 180ms; position: relative; font-size: 17px;
}
.lt26-nav__icon:hover {
  background: color-mix(in srgb, var(--lt26-champagne) 12%, transparent); color: var(--lt26-ink);
}
.lt26-nav__badge {
  position: absolute; top: 3px; right: 3px;
  min-width: 15px; height: 15px; border-radius: 999px;
  background: var(--lt26-coral); color: #fff;
  font-size: 9px; font-weight: 700; display: grid; place-items: center; padding: 0 3px;
}
.lt26-nav__badge.d-none { display: none !important; }

/* Bouton déposer */
.lt26-nav__cta {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 9px 18px; border-radius: 999px;
  background: var(--lt26-coral); color: #fff;
  font-family: var(--lt26-sans); font-size: 13px; font-weight: 600; letter-spacing: 0.01em;
  text-decoration: none; white-space: nowrap;
  transition: background 240ms, transform 240ms var(--lt26-ease-expo);
  flex-shrink: 0;
}
.lt26-nav__cta:hover { background: var(--lt26-coral-deep); transform: translateY(-1px); }

/* Menu utilisateur */
.lt26-nav__user { position: relative; }
.lt26-nav__user-btn {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 7px 14px; border-radius: 12px;
  border: 1px solid var(--lt26-line-strong); background: var(--lt26-bg-elev);
  color: var(--lt26-ink); font-size: 13px; font-weight: 500; cursor: pointer;
  transition: border-color 240ms, box-shadow 240ms;
  font-family: var(--lt26-sans); white-space: nowrap;
}
.lt26-nav__user-btn:hover {
  border-color: var(--lt26-champagne); box-shadow: 0 0 0 3px var(--lt26-champagne-glow);
}
.lt26-nav__user-avatar {
  width: 24px; height: 24px; border-radius: 50%; object-fit: cover;
}
.lt26-nav__user-name { max-width: 110px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.lt26-nav__dropdown {
  position: absolute; right: 0; top: calc(100% + 8px); min-width: 220px;
  background: var(--lt26-bg-elev); border: 1px solid var(--lt26-line-strong);
  border-radius: 16px; box-shadow: var(--lt26-shadow-soft); padding: 8px;
  opacity: 0; pointer-events: none; transform: translateY(8px);
  transition: opacity 240ms, transform 240ms var(--lt26-ease-expo); z-index: 100;
}
.lt26-nav__dropdown.show { opacity: 1; pointer-events: auto; transform: translateY(0); }
.lt26-nav__dropdown-info {
  padding: 10px 12px 10px; border-bottom: 1px solid var(--lt26-line); margin-bottom: 6px;
}
.lt26-nav__dropdown-info strong { display: block; color: var(--lt26-ink); font-size: 13.5px; }
.lt26-nav__dropdown-info small  { color: var(--lt26-ink-mute); font-size: 11.5px; }
.lt26-nav__dropdown a {
  display: block; padding: 8px 12px; border-radius: 8px; color: var(--lt26-ink-soft);
  font-size: 13px; text-decoration: none; transition: background 160ms, color 160ms;
}
.lt26-nav__dropdown a:hover {
  background: color-mix(in srgb, var(--lt26-champagne) 12%, transparent); color: var(--lt26-ink);
}
.lt26-nav__dropdown hr { border: none; border-top: 1px solid var(--lt26-line); margin: 6px 0; }
.lt26-nav__dropdown .lt26-logout { color: var(--lt26-coral); }
.lt26-nav__dropdown .lt26-logout:hover {
  background: color-mix(in srgb, var(--lt26-coral) 12%, transparent);
}

/* Sélecteur langue */
.lt26-nav__locale {
  display: flex; gap: 2px;
  font-family: var(--lt26-mono); font-size: 10px; letter-spacing: 0.16em; color: var(--lt26-ink-mute);
}
.lt26-nav__locale a {
  padding: 4px 7px; border-radius: 4px; text-decoration: none; color: inherit;
  transition: all 200ms; border: 1px solid transparent;
}
.lt26-nav__locale a.is-on { color: var(--lt26-champagne); border-color: var(--lt26-line-strong); }
.lt26-nav__locale a:hover:not(.is-on) { color: var(--lt26-ink); }

/* Hamburger */
.lt26-nav__hamburger {
  display: none; flex-direction: column; align-items: center; justify-content: center;
  gap: 5px; width: 38px; height: 38px; background: transparent;
  border: none; cursor: pointer; border-radius: 10px; padding: 0;
}
.lt26-nav__hamburger span {
  display: block; width: 20px; height: 1.5px; background: var(--lt26-ink);
  border-radius: 2px; transition: all 300ms;
}

/* Nav mobile drawer */
.lt26-nav__mobile {
  display: none; flex-direction: column; gap: 2px;
  padding: 12px 24px 20px; border-top: 1px solid var(--lt26-line);
  background: var(--lt26-bg);
}
.lt26-nav__mobile.is-open { display: flex; }
.lt26-nav__mobile a {
  display: block; padding: 11px 16px; border-radius: 10px;
  color: var(--lt26-ink-soft); font-size: 15px; text-decoration: none;
  transition: background 160ms, color 160ms;
}
.lt26-nav__mobile a:hover { background: var(--lt26-bg-elev); color: var(--lt26-ink); }

/* Éviter les styles inline (CSP) */
.lt26-nav__logo {
  height: clamp(26px, 7vw, 38px);
  width: auto;
  max-width: min(200px, 54vw);
  display: block;
  object-fit: contain;
  object-position: left center;
}
.lt26-footer__logo-img { height: 40px; width: auto; display: block; }

/* Communauté : remplacer style="display:none" */
.communaute-activity-initial.is-hidden { display: none; }

/* Responsivité nav */
@media (max-width: 1100px) {
  .lt26-nav__links   { display: none; }
  .lt26-nav__search  { display: none; }
  .lt26-nav__locale  { display: none; }
}
@media (max-width: 1100px) {
  .lt26-nav__hamburger { display: flex; }
}
@media (max-width: 768px) {
  .lt26-nav__actions   { gap: 2px; }
  .lt26-nav__cta span  { display: none; }
  .lt26-nav__cta       { padding: 9px 12px; }
}

/* =====================================================================
   FOOTER
   ===================================================================== */
.lt26-footer {
  margin-top: 60px; padding: 80px 40px 40px;
  background: var(--lt26-bg-soft); border-top: 1px solid var(--lt26-line);
}
.lt26-footer__top {
  max-width: 1480px; margin: 0 auto 56px;
  display: flex; justify-content: space-between; align-items: center; gap: 40px;
  padding-bottom: 56px; border-bottom: 1px solid var(--lt26-line); flex-wrap: wrap;
}
.lt26-footer__big {
  font-family: var(--lt26-serif); font-weight: 400;
  font-size: clamp(36px, 5vw, 68px); letter-spacing: -0.02em; line-height: 1;
  color: var(--lt26-ink);
}
.lt26-footer__big em { font-style: italic; color: var(--lt26-champagne); }
.lt26-footer__grid {
  max-width: 1480px; margin: 0 auto;
  display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 56px;
}
.lt26-footer__lede {
  margin-top: 16px; font-size: 13.5px; color: var(--lt26-ink-soft);
  max-width: 300px; line-height: 1.6;
}
.lt26-footer__col h5 {
  font-family: var(--lt26-mono); font-size: 11px; letter-spacing: 0.22em;
  text-transform: uppercase; color: var(--lt26-champagne); margin: 0 0 14px;
}
.lt26-footer__col ul { list-style: none; padding: 0; margin: 0; }
.lt26-footer__col li { padding: 5px 0; }
.lt26-footer__col a {
  font-size: 13.5px; color: var(--lt26-ink-soft); text-decoration: none;
  transition: color 200ms;
}
.lt26-footer__col a:hover { color: var(--lt26-champagne); }
.lt26-footer__base {
  max-width: 1480px; margin: 48px auto 0; padding-top: 24px;
  border-top: 1px solid var(--lt26-line);
  display: flex; justify-content: space-between; flex-wrap: wrap; gap: 8px;
  font-family: var(--lt26-mono); font-size: 11px; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--lt26-ink-mute);
}

/* Colonne marque */
.lt26-footer__brand { display: flex; flex-direction: column; gap: 16px; }
.lt26-footer__logo  {
  display: inline-flex; align-items: center; gap: 10px; text-decoration: none;
  font-family: var(--lt26-mono); font-size: 13px; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--lt26-ink); font-weight: 500;
}
.lt26-footer__desc  { font-size: 13.5px; color: var(--lt26-ink-soft); line-height: 1.65; max-width: 280px; margin: 0; }

/* Réseaux sociaux */
.lt26-footer__socials     { display: flex; gap: 8px; margin-top: 4px; }
.lt26-footer__social-btn  {
  display: grid; place-items: center; width: 34px; height: 34px; border-radius: 8px;
  background: var(--lt26-bg-elev); color: var(--lt26-ink-soft);
  text-decoration: none; transition: background 200ms, color 200ms;
  border: 1px solid var(--lt26-line);
}
.lt26-footer__social-btn:hover { background: var(--lt26-champagne-glow); color: var(--lt26-champagne); }

/* Titre de colonne */
.lt26-footer__col-title {
  font-family: var(--lt26-mono); font-size: 10.5px; letter-spacing: 0.22em;
  text-transform: uppercase; color: var(--lt26-champagne); margin: 0 0 14px;
}

/* Liste de liens */
.lt26-footer__links { list-style: none; padding: 0; margin: 0; }
.lt26-footer__links li { padding: 5px 0; }
.lt26-footer__links a {
  font-size: 13.5px; color: var(--lt26-ink-soft); text-decoration: none;
  transition: color 200ms;
}
.lt26-footer__links a:hover { color: var(--lt26-champagne); }

/* Barre légale */
.lt26-footer__legal {
  max-width: 1480px; margin: 48px auto 0; padding-top: 24px;
  border-top: 1px solid var(--lt26-line);
  display: flex; justify-content: space-between; align-items: center;
  flex-wrap: wrap; gap: 8px;
  font-family: var(--lt26-mono); font-size: 10.5px; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--lt26-ink-mute);
}
.lt26-footer__legal-links { display: flex; align-items: center; gap: 10px; }
.lt26-footer__legal-links a { color: var(--lt26-ink-mute); text-decoration: none; transition: color 200ms; }
.lt26-footer__legal-links a:hover { color: var(--lt26-champagne); }

@media (max-width: 960px) {
  .lt26-footer__grid { grid-template-columns: 1fr 1fr; gap: 40px; }
}
@media (max-width: 600px) {
  .lt26-footer { padding: 60px 20px 40px; }
  .lt26-footer__grid { grid-template-columns: 1fr; gap: 32px; }
  .lt26-footer__top { flex-direction: column; align-items: flex-start; }
  .lt26-footer__legal { flex-direction: column; align-items: flex-start; gap: 12px; }
}

/* =====================================================================
   TOGGLE THÈME (pill fixe en bas à droite)
   ===================================================================== */
.lt26-theme-toggle {
  position: fixed;
  z-index: 10060;
  right: calc(16px + env(safe-area-inset-right, 0px));
  bottom: calc(16px + env(safe-area-inset-bottom, 0px));
  display: inline-flex; align-items: center; gap: 4px; padding: 5px;
  border-radius: 999px; background: var(--lt26-bg-elev); border: 1px solid var(--lt26-line);
  box-shadow: var(--lt26-shadow-soft);
  pointer-events: auto;
  touch-action: manipulation;
}
.lt26-theme-btn {
  min-width: 40px; min-height: 40px; width: 40px; height: 40px; border-radius: 999px; background: transparent;
  border: none; color: var(--lt26-ink-mute); display: grid; place-items: center;
  cursor: pointer; transition: background 200ms, color 200ms, transform 160ms;
  font-size: 1.05rem; line-height: 1;
  -webkit-tap-highlight-color: transparent;
}
.lt26-theme-btn--auto {
  font-size: inherit;
}
.lt26-theme-btn__abbr {
  display: block;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-family: var(--lt26-mono, ui-monospace, monospace);
  line-height: 1.1;
}
.lt26-theme-btn:hover {
  color: var(--lt26-ink);
}
.lt26-theme-btn:focus-visible {
  outline: 2px solid var(--lt26-champagne);
  outline-offset: 2px;
}
.lt26-theme-btn.is-active { background: var(--lt26-champagne); color: #0E1B26; }
@media (min-width: 961px) {
  .lt26-theme-toggle {
    right: calc(24px + env(safe-area-inset-right, 0px));
    bottom: calc(24px + env(safe-area-inset-bottom, 0px));
  }
}

/* =====================================================================
   HERO
   ===================================================================== */
.lt26-hero {
  position: relative; min-height: 100vh; padding: 110px 40px 80px;
  position: relative; min-height: 100dvh; padding: 110px 40px 80px;
  overflow: hidden; background: var(--lt26-bg);
}
.lt26-hero__sky {
  position: absolute; inset: 0; pointer-events: none;
  background:
    radial-gradient(80% 60% at 50% -10%, rgba(212,165,116,0.18), transparent 60%),
    radial-gradient(40% 40% at 20% 30%, rgba(212,165,116,0.08), transparent 70%),
    radial-gradient(40% 40% at 80% 30%, rgba(212,165,116,0.08), transparent 70%);
}
.lt26-hero__rays {
  position: absolute; top: 0; left: 50%; width: 120%; height: 60vh;
  transform: translateX(-50%); pointer-events: none;
  background: conic-gradient(from 180deg at 50% 0%,
    transparent 0deg, rgba(212,165,116,0.04) 12deg, transparent 24deg,
    rgba(212,165,116,0.06) 36deg, transparent 50deg,
    rgba(212,165,116,0.03) 65deg, transparent 80deg,
    transparent 280deg, rgba(212,165,116,0.03) 295deg,
    transparent 310deg, rgba(212,165,116,0.06) 324deg,
    transparent 336deg, rgba(212,165,116,0.04) 348deg, transparent 360deg);
  filter: blur(20px);
  animation: lt26-rays-drift 24s ease-in-out infinite alternate;
}
@keyframes lt26-rays-drift {
  from { transform: translateX(-50%) rotate(-1deg); }
  to   { transform: translateX(-50%) rotate(1deg); }
}
.lt26-hero__floor {
  position: absolute; bottom: 0; left: 0; right: 0; height: 30vh; pointer-events: none;
  background: linear-gradient(180deg, transparent, var(--lt26-bg-soft) 80%);
}

/* Rails latéraux */
.lt26-hero__rail {
  position: absolute; top: 50%; transform: translateY(-50%);
  height: 60vh; width: 32px;
  display: flex; align-items: center; justify-content: center;
  z-index: 5; pointer-events: none;
}
.lt26-hero__rail--l { left: 12px; }
.lt26-hero__rail--r { right: 12px; }
.lt26-hero__rail-meta {
  display: flex; flex-direction: column; align-items: center; gap: 16px;
  writing-mode: vertical-rl; text-orientation: mixed; transform: rotate(180deg);
}
.lt26-hero__rail--r .lt26-hero__rail-meta { transform: rotate(0); }
.lt26-vline { width: 1px; height: 32px; background: var(--lt26-line-strong); writing-mode: horizontal-tb; }
.lt26-small  { font-family: var(--lt26-mono); font-size: 10px; letter-spacing: 0.2em; color: var(--lt26-ink-mute); }

/* Ribbon défilant */
.lt26-hero__ribbon {
  position: absolute; top: 80px; left: 0; right: 0; height: 28px;
  border-top: 1px solid var(--lt26-line); border-bottom: 1px solid var(--lt26-line);
  background: var(--lt26-bg-soft); overflow: hidden; z-index: 4;
}
.lt26-ribbon__track {
  display: flex; gap: 0; white-space: nowrap;
  animation: lt26-ribbon 60s linear infinite;
  height: 100%; align-items: center;
}
@keyframes lt26-ribbon { from { transform: translateX(0); } to { transform: translateX(-50%); } }
.lt26-ribbon__item {
  display: inline-flex; align-items: center; gap: 32px; padding: 0 18px;
  font-family: var(--lt26-mono); font-size: 10px; letter-spacing: 0.22em;
  text-transform: uppercase; color: var(--lt26-ink-mute);
}
.lt26-ribbon__dot { color: var(--lt26-champagne); font-size: 7px; }

/* Vitrine (étagère) */
.lt26-hero__vitrine {
  position: relative; z-index: 3; margin: 48px auto 0;
  max-width: 1200px; height: 460px;
  display: flex; align-items: flex-end; justify-content: center;
  transform-style: preserve-3d;
  transition: transform 800ms var(--lt26-ease-expo);
}
.lt26-hero__shelf {
  position: absolute; left: 5%; right: 5%; height: 1px;
  background: linear-gradient(90deg, transparent, var(--lt26-champagne) 20%, var(--lt26-champagne) 80%, transparent);
  box-shadow: 0 0 24px var(--lt26-champagne-glow);
}
.lt26-hero__shelf--bottom { bottom: 46px; }

.lt26-hero__slot {
  flex: 1; height: 100%; position: relative;
  display: flex; align-items: flex-end; justify-content: center;
  transition: transform 600ms var(--lt26-ease-expo);
}
.lt26-hero__slot--center { z-index: 4; }

/* Pièce de collection (silhouette abstraite) */
.lt26-piece {
  position: relative; width: 80%; max-width: 190px;
  display: flex; flex-direction: column; align-items: center;
  transition: transform 500ms var(--lt26-ease-expo);
}
.lt26-piece--link {
  text-decoration: none;
  color: inherit;
  -webkit-tap-highlight-color: transparent;
}
.lt26-piece--link:focus { outline: none; }
.lt26-piece--link:focus-visible {
  outline: 2px solid rgba(237, 124, 90, 0.85);
  outline-offset: 8px;
  border-radius: 14px;
}
.lt26-hero__slot { cursor: pointer; }
.lt26-hero__slot:hover .lt26-piece,
.lt26-hero__slot:focus-within .lt26-piece { transform: translateY(-10px) scale(1.06); }
.lt26-piece__art   { width: 100%; height: 250px; z-index: 2; position: relative; filter: drop-shadow(0 14px 24px rgba(0,0,0,0.5)); }
.lt26-piece__pedestal {
  position: absolute; bottom: 30px; width: 60%; height: 7px;
  background: linear-gradient(180deg, var(--lt26-bg-elev2), var(--lt26-bg-soft));
  border: 1px solid var(--lt26-line-strong); border-radius: 2px; z-index: 1;
}

/* Accueil — réduire la taille de la "carte" (slot central) */
.lt26-hero__slot--center .lt26-piece { max-width: 170px; }
.lt26-hero__slot--center .lt26-piece__art { height: 220px; }
.lt26-hero__slot--center .lt26-piece__pedestal { bottom: 26px; width: 58%; }

/* Rendu images plus net (évite le flou dû aux transforms GPU) */
img.lt26-piece__art {
  display: block;
  object-fit: contain;
  object-position: center;
  transform: translateZ(0);
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
  will-change: transform;
  image-rendering: -webkit-optimize-contrast;
}
.lt26-piece__plate {
  z-index: 3; margin-top: 10px; text-align: center; position: relative;
  display: flex; flex-direction: column; align-items: center; gap: 3px;
}
.lt26-piece__plate-line { width: 22px; height: 1px; background: var(--lt26-champagne); margin-bottom: 3px; }
.lt26-piece__brand { font-family: var(--lt26-mono); font-size: 8.5px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--lt26-ink-mute); }
.lt26-piece__title { font-family: var(--lt26-serif); font-size: 14px; color: var(--lt26-ink); font-style: italic; }
.lt26-piece__row   { display: flex; gap: 10px; font-size: 10px; color: var(--lt26-ink-soft); }
.lt26-piece__price { color: var(--lt26-champagne); font-family: var(--lt26-serif); font-size: 12px; }

/* Texte hero */
.lt26-hero__copy {
  position: relative; z-index: 5; max-width: 1200px; margin: 40px auto 0; padding: 0 20px;
  display: grid; grid-template-columns: 1.1fr 1fr; gap: 48px; align-items: end;
}
.lt26-hero__eyebrow-row {
  grid-column: 1 / -1; display: flex; align-items: center; gap: 14px; margin-bottom: 6px;
}
.lt26-hero__eyebrow-sep { color: var(--lt26-coral); opacity: .8; }
.lt26-hero__id { font-family: var(--lt26-mono); font-size: 10px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--lt26-ink-mute); }
.lt26-hero__title {
  font-family: var(--lt26-serif); font-weight: 400;
  font-size: clamp(50px, 7.5vw, 118px); letter-spacing: -0.025em; line-height: 0.95; margin: 0;
  color: var(--lt26-ink);
}
.lt26-hero__title-accent { color: var(--lt26-champagne); font-style: italic; }
.lt26-hero__lede { display: flex; gap: 14px; align-items: flex-start; max-width: 440px; }
.lt26-hero__lede p { font-size: 15px; color: var(--lt26-ink-soft); line-height: 1.65; margin: 0; }
.lt26-hero__cta {
  grid-column: 1 / -1; display: flex; align-items: center; gap: 24px;
  margin-top: 28px; flex-wrap: wrap;
}

/* Variante Claude Design (Accueil) */
.lt26-hero__copy--claude { grid-template-columns: 1.25fr 0.75fr; align-items: end; }
.lt26-hero__title--claude { font-size: clamp(68px, 9vw, 150px); line-height: 0.93; letter-spacing: -0.03em; }
.lt26-hero__tline { display: block; }
.lt26-hero__title-em { color: var(--lt26-champagne); font-style: italic; }

.lt26-hero__lede--claude { justify-content: flex-end; max-width: none; }
.lt26-hero__aside {
  max-width: 420px;
  display: grid;
  grid-template-columns: 18px 1fr;
  gap: 14px;
  align-items: start;
  color: var(--lt26-ink-soft);
}
.lt26-hero__aside-arrow {
  color: var(--lt26-champagne);
  font-family: var(--lt26-serif);
  font-size: 20px;
  line-height: 1;
  transform: translateY(2px);
  opacity: .9;
}
.lt26-hero__aside em { color: var(--lt26-ink); font-style: italic; }

.lt26-hero__cta--claude { gap: 16px; }
.lt26-hero__metric {
  display: inline-flex;
  align-items: baseline;
  gap: 12px;
  color: var(--lt26-ink-soft);
  text-decoration: none;
  padding: 10px 0;
}
.lt26-hero__metric-num {
  font-family: var(--lt26-serif);
  font-size: 18px;
  letter-spacing: -0.01em;
  color: var(--lt26-ink);
}
.lt26-hero__metric-text {
  font-family: var(--lt26-mono);
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--lt26-ink-mute);
  white-space: nowrap;
}
.lt26-hero__metric:hover .lt26-hero__metric-text { color: var(--lt26-champagne); }
.lt26-hero__secondary {
  display: inline-flex; align-items: center; gap: 12px;
  padding-left: 24px; border-left: 1px solid var(--lt26-line-strong);
  color: var(--lt26-ink-soft); font-size: 14px; text-decoration: none; transition: color 240ms;
}
.lt26-hero__secondary:hover { color: var(--lt26-champagne); }
.lt26-hero__secondary-num {
  font-family: var(--lt26-serif); font-size: 20px; letter-spacing: 0.03em; color: var(--lt26-ink);
}
.lt26-hero__stats {
  grid-column: 1 / -1; margin-top: 44px; padding-top: 28px;
  border-top: 1px solid var(--lt26-line);
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px;
}
.lt26-hero__stats-num {
  font-family: var(--lt26-serif); font-size: 32px; letter-spacing: -0.02em;
  color: var(--lt26-champagne); display: block; margin-bottom: 4px;
}
.lt26-hero__scroll {
  position: absolute; left: 50%; bottom: 20px; transform: translateX(-50%);
  display: flex; flex-direction: column; align-items: center; gap: 8px; z-index: 10;
}
.lt26-hero__scroll-line {
  width: 1px; height: 36px;
  background: linear-gradient(180deg, var(--lt26-champagne), transparent); overflow: hidden; position: relative;
}
.lt26-hero__scroll-line::after {
  content:""; position: absolute; top: -36px; left: 0; width: 1px; height: 36px;
  background: var(--lt26-champagne); animation: lt26-scroll-cue 2.4s ease-in-out infinite;
}
@keyframes lt26-scroll-cue { 0%{top:-36px} 100%{top:36px} }

/* =====================================================================
   PILLARS
   ===================================================================== */
.lt26-pillars { padding: 110px 40px 80px; }
.lt26-container { max-width: 1480px; margin: 0 auto; padding: 0 40px; }
.lt26-section-head {
  display: flex; align-items: flex-end; justify-content: space-between;
  gap: 40px; margin-bottom: 52px; flex-wrap: wrap;
}
.lt26-section-head h2 {
  font-family: var(--lt26-serif); font-weight: 400;
  font-size: clamp(30px, 3.8vw, 54px); letter-spacing: -0.02em; line-height: 1.05;
  margin: 10px 0 0; color: var(--lt26-ink);
}
.lt26-section-head p { font-size: 14.5px; color: var(--lt26-ink-soft); max-width: 360px; line-height: 1.6; margin: 0; }

.lt26-pillars__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
.lt26-pillar {
  position: relative; padding: 32px; background: var(--lt26-bg-elev);
  border: 1px solid var(--lt26-line); border-radius: 18px;
  display: flex; flex-direction: column; gap: 14px; min-height: 320px;
  transition: all 500ms var(--lt26-ease-expo); overflow: hidden; text-decoration: none;
}
.lt26-pillar::before {
  content:""; position: absolute; top: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent, var(--lt26-champagne), transparent);
  transform: scaleX(0); transition: transform 500ms var(--lt26-ease-expo);
}
.lt26-pillar:hover { transform: translateY(-6px); border-color: var(--lt26-line-strong); box-shadow: var(--lt26-shadow-glow); }
.lt26-pillar:hover::before { transform: scaleX(1); }
.lt26-pillar__head { display: flex; justify-content: space-between; align-items: flex-start; }
.lt26-pillar__num  { font-family: var(--lt26-mono); font-size: 11px; color: var(--lt26-champagne); letter-spacing: 0.2em; }
.lt26-pillar__icon { color: var(--lt26-champagne); opacity: 0.7; }
.lt26-pillar__kick { font-family: var(--lt26-mono); font-size: 10.5px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--lt26-champagne); }
.lt26-pillar__title { font-family: var(--lt26-serif); font-size: 24px; line-height: 1.2; margin: 0; font-weight: 400; color: var(--lt26-ink); }
.lt26-pillar__text  { color: var(--lt26-ink-soft); font-size: 14px; flex-grow: 1; margin: 0; line-height: 1.65; }
.lt26-pillar__more  {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--lt26-mono); font-size: 10.5px; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--lt26-champagne); margin-top: 8px; text-decoration: none;
}
.lt26-pillar__more svg { transition: transform 240ms; }
.lt26-pillar:hover .lt26-pillar__more svg { transform: translateX(4px); }

/* =====================================================================
   FEATURED CARDS
   ===================================================================== */
.lt26-featured { padding: 60px 40px; }
.lt26-featured__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
.lt26-fcard {
  position: relative; border: 1px solid var(--lt26-line); border-radius: 18px;
  background: var(--lt26-bg-elev); overflow: hidden; cursor: pointer;
  transition: border-color 400ms, box-shadow 400ms;
  transform-style: preserve-3d;
  --lt26-mx: 50%; --lt26-my: 50%;
}
.lt26-fcard:hover { border-color: var(--lt26-champagne); box-shadow: var(--lt26-shadow-glow); }
.lt26-fcard__media {
  position: relative; aspect-ratio: 4/5;
  background: radial-gradient(60% 50% at 50% 0%, rgba(212,165,116,0.18), transparent 70%), var(--lt26-bg-soft);
  display: grid; place-items: center; overflow: hidden; border-bottom: 1px solid var(--lt26-line);
}
.lt26-fcard__media-link { text-decoration: none; color: inherit; }
.lt26-fcard__media-link:focus { outline: none; }
.lt26-fcard__media-link:focus-visible {
  outline: 2px solid rgba(212,165,116,0.85);
  outline-offset: -2px;
}
.lt26-fcard__title-link { color: inherit; text-decoration: none; }
.lt26-fcard__title-link:hover { text-decoration: underline; text-decoration-color: rgba(212,165,116,0.65); text-underline-offset: 6px; }
.lt26-fcard__img {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover; object-position: center;
  transform: translateZ(0);
  backface-visibility: hidden;
  filter: saturate(1.02) contrast(1.02);
}
.lt26-fcard__glare {
  position: absolute; inset: 0; pointer-events: none; opacity: 0; transition: opacity 320ms;
  background: radial-gradient(160px at var(--lt26-mx) var(--lt26-my), rgba(212,165,116,0.18), transparent 60%);
}
.lt26-fcard:hover .lt26-fcard__glare { opacity: 1; }
.lt26-fcard__index { position: absolute; top: 12px; left: 12px; font-family: var(--lt26-mono); font-size: 10px; letter-spacing: 0.2em; color: var(--lt26-ink-mute); }
.lt26-fcard__badge {
  position: absolute; top: 12px; right: 12px;
  font-family: var(--lt26-mono); font-size: 9px; letter-spacing: 0.14em; text-transform: uppercase;
  padding: 3px 10px; border: 1px solid var(--lt26-line-strong); border-radius: 999px; color: var(--lt26-champagne);
  background: color-mix(in srgb, var(--lt26-bg) 60%, transparent);
}
.lt26-fcard__meta   { padding: 18px 20px 20px; }
.lt26-fcard__top    { display: flex; justify-content: space-between; align-items: center; }
.lt26-fcard__title  { font-family: var(--lt26-serif); font-size: 21px; font-weight: 400; margin: 7px 0 14px; line-height: 1.15; font-style: italic; color: var(--lt26-ink); }
.lt26-fcard__bottom { display: flex; justify-content: space-between; align-items: flex-end; }
.lt26-fcard__city   { font-family: var(--lt26-mono); font-size: 9px; letter-spacing: 0.14em; color: var(--lt26-ink-mute); margin-bottom: 4px; text-transform: uppercase; }
.lt26-fcard__price  { font-family: var(--lt26-serif); font-size: 19px; color: var(--lt26-champagne); }
.lt26-fcard__cta {
  background: transparent; border: 1px solid var(--lt26-line-strong); color: var(--lt26-ink);
  padding: 8px 14px; border-radius: 999px;
  font-family: var(--lt26-mono); font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase;
  display: inline-flex; align-items: center; gap: 6px; cursor: pointer;
  transition: all 240ms; flex-shrink: 0;
}
.lt26-fcard__cta:hover { background: var(--lt26-champagne); color: #0E1B26; border-color: var(--lt26-champagne); }

/* =====================================================================
   CARTE TEASER
   ===================================================================== */
.lt26-carte { padding: 60px 40px; }
.lt26-carte__inner {
  display: grid; grid-template-columns: 1fr 1.1fr; gap: 56px; align-items: center;
  background: var(--lt26-bg-elev); border: 1px solid var(--lt26-line);
  border-radius: 24px; padding: 56px; overflow: hidden;
}
.lt26-carte__copy h2 {
  font-family: var(--lt26-serif); font-weight: 400;
  font-size: clamp(32px, 4vw, 60px); letter-spacing: -0.02em; line-height: 1.1;
  margin: 10px 0 18px; color: var(--lt26-ink);
}
.lt26-carte__copy h2 em { font-style: italic; color: var(--lt26-champagne); }
.lt26-carte__copy p { color: var(--lt26-ink-soft); font-size: 15px; margin: 0 0 24px; max-width: 380px; line-height: 1.65; }

.lt26-minimap {
  position: relative; aspect-ratio: 16/10; border-radius: 16px; overflow: hidden;
  background: linear-gradient(180deg, var(--lt26-bg-soft), var(--lt26-bg));
  border: 1px solid var(--lt26-line-strong);
}
.lt26-minimap__grid {
  position: absolute; inset: 0;
  background-image: linear-gradient(rgba(212,165,116,0.05) 1px, transparent 1px),
                    linear-gradient(90deg, rgba(212,165,116,0.05) 1px, transparent 1px);
  background-size: 40px 40px;
  -webkit-mask-image: radial-gradient(120% 80% at 50% 50%, #000 30%, transparent 100%);
  mask-image: radial-gradient(120% 80% at 50% 50%, #000 30%, transparent 100%);
}

/* Minimap SVG */
.lt26-minimap__svg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  display: block;
}

.lt26-minimap__pins { isolation: isolate; }
.lt26-minimap__pin-core { fill: var(--lt26-champagne); }
.lt26-minimap__pin-ring {
  fill: none;
  stroke: color-mix(in srgb, var(--lt26-champagne) 70%, transparent);
  stroke-width: 1.6;
  opacity: 0;
  animation: lt26-pin-ring 2.8s ease-out infinite;
}
.lt26-minimap__d30  { animation-delay: 0.3s; }
.lt26-minimap__d60  { animation-delay: 0.6s; }
.lt26-minimap__d75  { animation-delay: 0.75s; }
.lt26-minimap__d90  { animation-delay: 0.9s; }
.lt26-minimap__d100 { animation-delay: 1.0s; }
.lt26-minimap__d110 { animation-delay: 1.1s; }
.lt26-minimap__d120 { animation-delay: 1.2s; }
.lt26-minimap__d135 { animation-delay: 1.35s; }

.lt26-minimap__o50 { opacity: 0.5; }
.lt26-minimap__o55 { opacity: 0.55; }
.lt26-minimap__o60 { opacity: 0.6; }
.lt26-minimap__o70 { opacity: 0.7; }
.lt26-minimap__o75 { opacity: 0.75; }
.lt26-minimap__o80 { opacity: 0.8; }
@keyframes lt26-pin-ring {
  0% { transform: scale(0.55); opacity: 0.9; }
  70% { opacity: 0.25; }
  100% { transform: scale(1.9); opacity: 0; }
}

.lt26-minimap__label {
  fill: color-mix(in srgb, var(--lt26-bg) 72%, transparent);
  stroke: var(--lt26-line-strong);
  stroke-width: 1;
}
.lt26-minimap__label-text {
  font-family: var(--lt26-mono);
  font-size: 13px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  fill: var(--lt26-ink);
}

/* =====================================================================
   CARTE COMMUNAUTAIRE (page)
   Objectif: supprimer tout inline style (CSP friendly)
   ===================================================================== */
.carte-page__accent { color: var(--lt26-champagne); }

.carte-kpi__num {
  font-size: 30px;
  color: var(--lt26-champagne);
}
.carte-kpi__label {
  font-size: 11px;
  color: var(--lt26-ink-mute);
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.carte-mono-caps {
  font-size: 11px;
  color: var(--lt26-ink-mute);
  letter-spacing: 0.12em;
  text-transform: uppercase;
}
.carte-filters__title { margin: 4px 0 12px; font-size: 22px; }
.carte-btn--full { width: 100%; justify-content: center; }
.carte-filters__hint { line-height: 1.5; }

/* 404 / empty states (annonce.php, etc.) */
.lt26-pad-nav { padding-top: 140px; }
.lt26-lead-soft {
  color: var(--lt26-ink-soft);
  max-width: 720px;
}

/* Utilitaire global (préférer classe vs style="display:none") */
.is-hidden { display: none !important; }

/* Fiche annonce (LT26) — anti inline styles */
.fp__crumb-muted { color: var(--lt26-ink-mute); }
.fp__brand.fp__brand--tight { margin: 0; font-size: 11px; }
.fp__brand.fp__brand--champ { margin: 0; color: var(--lt26-champagne); }
.fp__price-euro { font-size: .5em; }
.fp__seller { text-align: right; }
.fp__seller-name { font-size: 22px; color: var(--lt26-ink); }

.fp__kv { margin: 0 0 10px; color: var(--lt26-ink-soft); }
.fp__kv--last { margin: 0; color: var(--lt26-ink-soft); }
.fp__kv strong { color: var(--lt26-ink); }
.fp__kv-plain { margin: 0 0 10px; }
.fp__kv-muted { margin: 0; color: var(--lt26-ink-soft); }
.fp__kv-note { margin: 10px 0 0; color: var(--lt26-ink-soft); }

.annonce-detail-delete-form { display: inline-block; margin: 0; }
.annonce-detail-btn--danger { color: #b91c1c; border-color: #b91c1c; }

.form-hint--muted { margin: 6px 0 0; color: #64748b; font-size: 13px; }
.map-unavailable { padding: 1rem; color: #64748b; }
.lt26-minimap__badge {
  fill: color-mix(in srgb, var(--lt26-champagne) 85%, transparent);
  stroke: color-mix(in srgb, var(--lt26-champagne) 90%, transparent);
  stroke-width: 1;
}
.lt26-minimap__badge-text {
  font-family: var(--lt26-mono);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.12em;
  fill: #0E1B26;
}
.lt26-minimap__city {
  font-family: var(--lt26-mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  fill: color-mix(in srgb, var(--lt26-ink) 82%, transparent);
}
.lt26-minimap__dot {
  position: absolute; border-radius: 50%;
  background: radial-gradient(circle, var(--lt26-champagne) 30%, transparent 70%);
  display: grid; place-items: center; transform: translate(-50%, -50%);
  animation: lt26-dot-pulse 3.6s ease-in-out infinite;
}
.lt26-minimap__dot-ring {
  position: absolute; inset: -8px; border-radius: 50%;
  border: 1px solid var(--lt26-champagne); opacity: 0;
  animation: lt26-dot-ring 3s ease-out infinite;
}
@keyframes lt26-dot-pulse { 0%,100%{filter:drop-shadow(0 0 8px var(--lt26-champagne-glow))} 50%{filter:drop-shadow(0 0 16px var(--lt26-champagne-glow))} }
@keyframes lt26-dot-ring  { 0%{transform:scale(.6);opacity:1} 100%{transform:scale(2);opacity:0} }
.lt26-minimap__count  { font-family: var(--lt26-mono); font-size: 8.5px; color: #0E1B26; font-weight: 700; }
.lt26-minimap__legend {
  position: absolute; bottom: 12px; left: 12px; padding: 4px 12px;
  background: color-mix(in srgb, var(--lt26-bg) 70%, transparent);
  border: 1px solid var(--lt26-line); border-radius: 999px;
  font-family: var(--lt26-mono); font-size: 9px; color: var(--lt26-ink-mute);
}

/* =====================================================================
   MANIFESTO
   ===================================================================== */
.lt26-manifesto {
  padding: 100px 40px;
  background: var(--lt26-bg-soft); border-top: 1px solid var(--lt26-line); border-bottom: 1px solid var(--lt26-line);
}
.lt26-manifesto__inner { max-width: 900px; margin: 0 auto; text-align: center; }
.lt26-manifesto__text {
  font-family: var(--lt26-serif);
  font-size: clamp(22px, 2.8vw, 40px); line-height: 1.42; font-weight: 300;
  letter-spacing: -0.01em; color: var(--lt26-ink); margin: 26px 0 30px;
}
.lt26-manifesto__text em { font-style: italic; color: var(--lt26-champagne); }
.lt26-manifesto__sign { font-family: var(--lt26-mono); color: var(--lt26-ink-mute); letter-spacing: 0.18em; font-size: 11px; }

/* =====================================================================
   FAQ
   ===================================================================== */
.lt26-faq { padding: 80px 40px 48px; }
.lt26-faq__list { display: flex; flex-direction: column; border-top: 1px solid var(--lt26-line-strong); }
.lt26-faq__row {
  border-bottom: 1px solid var(--lt26-line); padding: 22px 4px; cursor: pointer;
  transition: padding 300ms ease;
}
.lt26-faq__row:hover { padding-left: 10px; }
.lt26-faq__q { display: grid; grid-template-columns: 48px 1fr auto; gap: 18px; align-items: baseline; }
.lt26-faq__num { font-family: var(--lt26-mono); font-size: 11px; color: var(--lt26-champagne); letter-spacing: 0.16em; }
.lt26-faq__q-text { font-family: var(--lt26-serif); font-size: clamp(18px, 1.8vw, 26px); font-weight: 400; color: var(--lt26-ink); }
.lt26-faq__plus { font-family: var(--lt26-serif); font-size: 26px; color: var(--lt26-champagne); width: 26px; text-align: center; transition: transform 300ms; }
.lt26-faq__row.is-open .lt26-faq__plus { transform: rotate(45deg); }
.lt26-faq__a {
  max-height: 0; overflow: hidden; padding-left: 66px;
  color: var(--lt26-ink-soft); font-size: 15px; line-height: 1.65;
  transition: max-height 480ms var(--lt26-ease-expo), padding-top 480ms var(--lt26-ease-expo);
}
.lt26-faq__row.is-open .lt26-faq__a { max-height: 200px; padding-top: 12px; }
.lt26-faq__row.is-open .lt26-faq__q-text { color: var(--lt26-champagne); font-style: italic; }

/* =====================================================================
   BRANDS (restyled)
   ===================================================================== */
.lt26-brands { padding: 60px 40px; }
.lt26-brands__grid {
  display: flex; flex-wrap: wrap; gap: 16px; justify-content: center; margin-top: 40px;
}
.lt26-brand-card {
  display: flex; flex-direction: column; align-items: center; gap: 10px;
  padding: 20px 28px; background: var(--lt26-bg-elev); border: 1px solid var(--lt26-line);
  border-radius: 14px; text-decoration: none; color: var(--lt26-ink-soft);
  transition: all 360ms var(--lt26-ease-expo);
}
.lt26-brand-card:hover {
  border-color: var(--lt26-champagne); color: var(--lt26-ink);
  transform: translateY(-3px); box-shadow: var(--lt26-shadow-glow);
}
.lt26-brand-card img { width: 72px; height: 48px; object-fit: contain; filter: saturate(0) brightness(1.4); transition: filter 300ms; }
.lt26-brand-card:hover img { filter: none; }
.lt26-brand-name { font-family: var(--lt26-mono); font-size: 10px; letter-spacing: 0.16em; text-transform: uppercase; }

/* =====================================================================
   NAV — composants complémentaires (user-wrap, icon-btn, dropdown)
   ===================================================================== */

/* Wrapper user + dropdown */
.lt26-nav__user-wrap { position: relative; }

/* Bouton icône générique (messages, etc.) */
.lt26-nav__icon-btn {
  display: inline-flex; align-items: center; justify-content: center;
  width: 38px; height: 38px; border-radius: 10px; border: none;
  background: transparent; color: var(--lt26-ink-soft);
  text-decoration: none; cursor: pointer; transition: background 180ms, color 180ms;
  position: relative;
}
.lt26-nav__icon-btn:hover {
  background: color-mix(in srgb, var(--lt26-champagne) 12%, transparent);
  color: var(--lt26-ink);
}

/* Dropdown utilisateur */
.lt26-user-dropdown {
  position: absolute; right: 0; top: calc(100% + 10px); width: 280px;
  background: var(--lt26-bg-elev); border: 1px solid var(--lt26-line-strong);
  border-radius: 18px; box-shadow: var(--lt26-shadow-soft);
  padding: 10px; z-index: 200;
  opacity: 0; pointer-events: none; transform: translateY(10px);
  transition: opacity 240ms var(--lt26-ease-expo), transform 240ms var(--lt26-ease-expo);
}
.lt26-user-dropdown.show {
  opacity: 1; pointer-events: auto; transform: translateY(0);
}
.lt26-user-dropdown__header {
  display: flex; align-items: center; gap: 12px; padding: 10px 12px 12px;
}
.lt26-user-dropdown__avatar {
  width: 38px; height: 38px; border-radius: 50%; object-fit: cover; flex-shrink: 0;
}
.lt26-user-dropdown__name  { display: block; font-size: 13.5px; font-weight: 600; color: var(--lt26-ink); }
.lt26-user-dropdown__email { display: block; font-size: 11.5px; color: var(--lt26-ink-mute); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.lt26-user-dropdown__sep   { border: none; border-top: 1px solid var(--lt26-line); margin: 6px 0; }
.lt26-user-dropdown__item {
  display: block; padding: 9px 12px; border-radius: 10px;
  color: var(--lt26-ink-soft); font-size: 13px; text-decoration: none;
  transition: background 160ms, color 160ms;
}
.lt26-user-dropdown__item:hover {
  background: color-mix(in srgb, var(--lt26-champagne) 10%, transparent);
  color: var(--lt26-ink);
}
.lt26-user-dropdown__item--danger { color: var(--lt26-coral); }
.lt26-user-dropdown__item--danger:hover {
  background: color-mix(in srgb, var(--lt26-coral) 10%, transparent);
  color: var(--lt26-coral);
}
.lt26-user-dropdown__footer {
  display: flex; align-items: center; justify-content: center; gap: 8px;
  padding: 8px 12px 4px; font-size: 12px; color: var(--lt26-ink-mute);
}
.lt26-user-dropdown__footer a { color: var(--lt26-ink-mute); text-decoration: none; transition: color 160ms; }
.lt26-user-dropdown__footer a:hover { color: var(--lt26-ink); }
.lt26-user-dropdown__register { color: var(--lt26-champagne) !important; font-weight: 600; }
.lt26-user-dropdown__register:hover { color: var(--lt26-champagne-deep) !important; }

/* Formulaire login dans le dropdown */
.lt26-login-form { display: grid; gap: 12px; padding: 4px 4px 8px; }
.lt26-form-group { display: grid; gap: 5px; }
.lt26-form-group label { font-size: 11.5px; font-weight: 600; color: var(--lt26-ink-soft); letter-spacing: 0.04em; }
.lt26-form-group input {
  height: 38px; padding: 0 12px; border-radius: 10px;
  border: 1px solid var(--lt26-line-strong); background: var(--lt26-bg-soft);
  color: var(--lt26-ink); font-size: 13px; font-family: var(--lt26-sans);
  transition: border-color 200ms, box-shadow 200ms; outline: none;
}
.lt26-form-group input:focus {
  border-color: var(--lt26-champagne);
  box-shadow: 0 0 0 3px var(--lt26-champagne-glow);
}
.lt26-form-check {
  display: flex; align-items: center; gap: 8px;
  font-size: 12px; color: var(--lt26-ink-soft); cursor: pointer;
}
.lt26-form-check input { width: 14px; height: 14px; accent-color: var(--lt26-champagne); }

/* Bouton CTA pleine largeur */
.lt26-btn--full { width: 100%; justify-content: center; }

/* =====================================================================
   SCROLLBAR
   ===================================================================== */
::-webkit-scrollbar { width: 8px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--lt26-line-strong); border-radius: 10px; }
::-webkit-scrollbar-thumb:hover { background: var(--lt26-champagne-deep); }

/* =====================================================================
   HERO — éléments supplémentaires (aurora, kicker, slots, spotlight)
   ===================================================================== */

/* Fond aurora animé */
.lt26-hero__aurora {
  position: absolute; inset: 0; pointer-events: none; overflow: hidden; z-index: 0;
}
.lt26-hero__aurora-blob {
  position: absolute; border-radius: 50%; filter: blur(80px);
  animation: lt26-aurora 14s ease-in-out infinite alternate;
}
.lt26-hero__aurora-blob--1 {
  width: 600px; height: 400px; top: -100px; left: -100px;
  background: radial-gradient(ellipse, rgba(212,165,116,0.12), transparent 70%);
  animation-delay: 0s;
}
.lt26-hero__aurora-blob--2 {
  width: 500px; height: 360px; bottom: -60px; right: -80px;
  background: radial-gradient(ellipse, rgba(238,92,110,0.08), transparent 70%);
  animation-delay: -7s;
}
@keyframes lt26-aurora {
  0%   { transform: translate(0,0) scale(1); }
  50%  { transform: translate(40px, 20px) scale(1.08); }
  100% { transform: translate(-20px, -30px) scale(0.95); }
}

/* Kicker (ligne + texte) */
.lt26-hero__kicker {
  display: flex; align-items: center; gap: 12px;
  font-family: var(--lt26-mono); font-size: 10.5px; letter-spacing: 0.24em;
  text-transform: uppercase; color: var(--lt26-champagne);
  grid-column: 1 / -1; margin-bottom: 4px;
}
.lt26-hero__kicker-line {
  display: block; width: 32px; height: 1px; background: var(--lt26-champagne); flex-shrink: 0;
}

/* Slots vitrine (niveaux de profondeur) */
.lt26-hero__slot--back-l,
.lt26-hero__slot--back-r  { opacity: 1; transform: none; z-index: 1; }
.lt26-hero__slot--front-l,
.lt26-hero__slot--front-r { opacity: 1; transform: none; z-index: 2; }
.lt26-hero__slot--center  { z-index: 4; transform: none; transform-origin: bottom center; }

/* Faisceau lumineux centré sur la pièce principale */
.lt26-hero__spotlight {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 160%;
  height: 60vh;
  pointer-events: none;
  z-index: 1;
  background: radial-gradient(ellipse 60% 40% at 50% 0%, rgba(212,165,116,0.26), transparent 70%);
}

/* Étiquette prix + tag sous la pièce centrale */
.lt26-hero__slot-label {
  position: absolute; bottom: -12px; left: 50%; transform: translateX(-50%);
  display: flex; flex-direction: column; align-items: center; gap: 3px; z-index: 10;
}
.lt26-hero__slot-tag {
  font-family: var(--lt26-mono); font-size: 9px; letter-spacing: 0.2em;
  text-transform: uppercase; color: var(--lt26-ink-mute);
}
.lt26-hero__slot-price {
  font-family: var(--lt26-serif); font-size: 15px; color: var(--lt26-champagne);
}

/* =====================================================================
   RIBBON AUTONOME (hors hero)
   ===================================================================== */
.lt26-ribbon {
  overflow: hidden; border-top: 1px solid var(--lt26-line); border-bottom: 1px solid var(--lt26-line);
  background: var(--lt26-bg-soft); height: 34px;
}
.lt26-ribbon .lt26-ribbon__track { animation-duration: 70s; }
.lt26-ribbon__sep { color: var(--lt26-champagne); margin-left: 18px; font-size: 8px; }

/* =====================================================================
   SECTION KICKER / TITLE (utilitaires partagés)
   ===================================================================== */
.lt26-section-kicker {
  font-family: var(--lt26-mono); font-size: 10.5px; letter-spacing: 0.24em;
  text-transform: uppercase; color: var(--lt26-champagne); margin: 0 0 10px;
}
.lt26-section-title {
  font-family: var(--lt26-serif); font-weight: 400;
  font-size: clamp(28px, 3.5vw, 52px); letter-spacing: -0.02em; line-height: 1.08;
  color: var(--lt26-ink); margin: 0 0 36px;
}

/* =====================================================================
   PILLARS — alias + header
   ===================================================================== */
.lt26-pillars__header { margin-bottom: 48px; }

/* alias : __desc → __text, __link → __more */
.lt26-pillar__desc  { color: var(--lt26-ink-soft); font-size: 14px; flex-grow: 1; margin: 0; line-height: 1.65; }
.lt26-pillar__link  {
  margin-top: auto; display: inline-flex; align-items: center; gap: 6px;
  font-family: var(--lt26-mono); font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--lt26-champagne); text-decoration: none; transition: gap 240ms;
}
.lt26-pillar:hover .lt26-pillar__link { gap: 10px; }

/* =====================================================================
   CARTE TEASER — éléments supplémentaires
   ===================================================================== */
.lt26-carte__copy { display: flex; flex-direction: column; gap: 16px; }
.lt26-carte__desc { color: var(--lt26-ink-soft); font-size: 15px; line-height: 1.65; margin: 0; max-width: 380px; }
.lt26-carte__stats {
  display: flex; gap: 32px; flex-wrap: wrap;
  padding: 18px 0; border-top: 1px solid var(--lt26-line); border-bottom: 1px solid var(--lt26-line);
}
.lt26-carte__stat { display: flex; flex-direction: column; gap: 3px; }
.lt26-carte__stat-num {
  font-family: var(--lt26-serif); font-size: 28px; letter-spacing: -0.02em;
  color: var(--lt26-champagne); line-height: 1;
}
.lt26-carte__stat-label { font-family: var(--lt26-mono); font-size: 10px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--lt26-ink-mute); }

/* Minimap SVG container */
.lt26-minimap__svg { width: 100%; height: auto; display: block; }

/* Pin pulse (sur les cercles SVG dans la minimap) */
@keyframes lt26-pin-pulse {
  0%,100% { opacity: 0.15; r: 18; }
  50%      { opacity: 0.35; r: 26; }
}
.lt26-pin-pulse { animation: lt26-pin-pulse 3s ease-in-out infinite; }

/* =====================================================================
   MANIFESTO — version enrichie
   ===================================================================== */
.lt26-manifesto__quote {
  margin: 0 0 60px; text-align: center;
}
.lt26-manifesto__quote p {
  font-family: var(--lt26-serif); font-size: clamp(24px, 3vw, 44px);
  font-weight: 300; line-height: 1.35; letter-spacing: -0.015em; color: var(--lt26-ink); margin: 0;
}
.lt26-manifesto__quote em { font-style: italic; color: var(--lt26-champagne); }
.lt26-manifesto__grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 56px;
  text-align: left; border-top: 1px solid var(--lt26-line); padding-top: 44px;
}
.lt26-manifesto__col h3 {
  font-family: var(--lt26-serif); font-size: 20px; font-weight: 400; color: var(--lt26-ink); margin: 0 0 14px;
}
.lt26-manifesto__col p { color: var(--lt26-ink-soft); font-size: 14.5px; line-height: 1.85; margin: 0; }

/* =====================================================================
   FAQ — version bouton (accessible)
   ===================================================================== */
.lt26-faq__header { margin-bottom: 40px; }

/* Surcharger le style quand .lt26-faq__q est un <button> */
button.lt26-faq__q {
  display: flex; align-items: center; justify-content: space-between;
  width: 100%; background: none; border: none; cursor: pointer; padding: 0;
  text-align: left; gap: 16px;
  font-family: var(--lt26-serif); font-size: clamp(16px, 1.6vw, 22px);
  font-weight: 400; color: var(--lt26-ink);
}
button.lt26-faq__q:focus-visible {
  outline: 2px solid var(--lt26-champagne); outline-offset: 4px; border-radius: 4px;
}
.lt26-faq__chevron {
  flex-shrink: 0; color: var(--lt26-champagne); transition: transform 320ms var(--lt26-ease-expo);
}
.lt26-faq__row.is-open .lt26-faq__chevron { transform: rotate(180deg); }
.lt26-faq__row.is-open button.lt26-faq__q { color: var(--lt26-champagne); font-style: italic; }

/* =====================================================================
   RESPONSIVE
   ===================================================================== */
@media (max-width: 1100px) {
  .lt26-hero__copy { grid-template-columns: 1fr 1fr; }
  .lt26-pillars__grid, .lt26-featured__grid { grid-template-columns: 1fr 1fr; }
  .lt26-carte__inner { grid-template-columns: 1fr; padding: 36px; }
  .lt26-manifesto__grid { grid-template-columns: 1fr; gap: 28px; }
}
@media (max-width: 720px) {
  .lt26-hero { padding: 96px 20px 60px; }
  .lt26-hero__copy { grid-template-columns: 1fr; gap: 24px; }
  .lt26-hero__lede { display: none; }
  .lt26-hero__vitrine { height: 280px; }
  .lt26-hero__rail { display: none; }
  .lt26-pillars, .lt26-featured, .lt26-carte, .lt26-faq, .lt26-brands { padding: 60px 20px; }
  .lt26-pillars { padding-top: 60px; }
  .lt26-pillars__grid, .lt26-featured__grid { grid-template-columns: 1fr; }
  .lt26-manifesto { padding: 60px 20px; }
  .lt26-carte__inner { padding: 28px; }
  .lt26-container { padding: 0 20px; }
  .lt26-hero__kicker { font-size: 9.5px; }
  .lt26-hero__slot--back-l, .lt26-hero__slot--back-r { display: none; }
  .lt26-hero__slot--front-l, .lt26-hero__slot--front-r { opacity: 1; }
  .lt26-faq__list { padding: 0; }
}

/* =====================================================================
   MA VITRINE (LT26) — import adapté depuis Claude Design
   ===================================================================== */
.vit-layout {
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: 40px;
  max-width: 1480px;
  margin: 0 auto;
  padding: 120px 40px 40px;
}
.vitrine-side {
  position: sticky;
  top: 100px;
  align-self: start;
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: 18px;
  padding: 24px 0;
  height: calc(100vh - 130px);
  height: calc(100dvh - 130px);
  display: flex;
  flex-direction: column;
}
.vitrine-side__user {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 0 22px 22px;
  border-bottom: 1px solid var(--line);
  margin-bottom: 14px;
}
.vitrine-side__avatar {
  position: relative;
  width: 44px; height: 44px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--champagne), var(--champagne-deep));
  display: grid; place-items: center;
  color: #0E1B26;
  font-size: 19px;
}
.vitrine-side__avatar-ring {
  position: absolute;
  inset: -3px;
  border-radius: 50%;
  border: 1px dashed var(--champagne);
  opacity: 0.5;
  animation: rot 16s linear infinite;
}
@keyframes rot { to { transform: rotate(360deg); } }
.vitrine-side__name { font-size: 16px; }
.vitrine-side__nav {
  display: flex;
  flex-direction: column;
  gap: 1px;
  padding: 0 12px;
  flex: 1;
  overflow-y: auto;
}
.vitrine-side__item {
  position: relative;
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 14px;
  border-radius: 10px;
  font-size: 13.5px;
  color: var(--ink-soft);
  transition: all 240ms;
}
.vitrine-side__item:hover { background: var(--bg-elev-2); color: var(--ink); }
.vitrine-side__item.is-active {
  background: color-mix(in srgb, var(--champagne) 14%, transparent);
  color: var(--champagne);
}
.vitrine-side__indicator {
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 3px; height: 18px;
  border-radius: 2px;
  background: var(--champagne);
}
.vitrine-side__cta {
  margin: 14px 22px 0;
  padding-top: 18px;
  border-top: 1px solid var(--line);
}
.vitrine-side__bar {
  margin: 8px 0 6px;
  height: 4px;
  border-radius: 4px;
  background: var(--bg-elev-2);
  overflow: hidden;
}
.vitrine-side__bar span {
  display: block;
  height: 100%;
  background: linear-gradient(90deg, var(--champagne), var(--champagne-soft));
  border-radius: 4px;
}

/* Utilitaires CSP-friendly (remplace les style="...") */
.lt26-mono--meta {
  font-size: 11px;
  color: var(--ink-mute);
  letter-spacing: .12em;
  text-transform: uppercase;
}
.lt26-text-champ { color: var(--champagne); }

.vitrine-side__bar-fill { width: 72%; }

.vit-stat__delta--champ { color: var(--champagne); letter-spacing: .12em; text-transform: uppercase; font-size: 11px; }
.vit-stat__delta--coral { color: var(--coral); letter-spacing: .12em; text-transform: uppercase; font-size: 11px; }

/* Ma vitrine — aperçu premium (Claude-like) */
.vit-premium { margin-top: 24px; }
.vit-premium__head { margin-bottom: 14px; }
.vit-premium__kicker { margin-bottom: 8px; }
.vit-premium__toprow { display: flex; align-items: baseline; justify-content: space-between; gap: 16px; flex-wrap: wrap; }
.vit-premium__title { margin: 0; font-size: clamp(22px, 2.6vw, 34px); font-weight: 400; color: var(--ink); letter-spacing: -0.02em; }
.vit-premium__meta { display: inline-flex; align-items: center; gap: 10px; white-space: nowrap; }
.vit-premium__sep { opacity: .5; }
.vit-premium__dot { width: 6px; height: 6px; border-radius: 999px; display: inline-block; }
.vit-premium__dot--sell { background: var(--coral); box-shadow: 0 0 0 4px rgba(238,92,110,0.10); }

.vit-premium__stage {
  position: relative;
  border: 1px solid var(--line);
  background: color-mix(in srgb, var(--bg-elev) 78%, transparent);
  border-radius: 18px;
  overflow: hidden;
  padding: 18px;
}
.vit-premium__glass {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(50% 120% at 15% 50%, rgba(212,165,116,0.18), transparent 60%),
    radial-gradient(50% 120% at 50% 50%, rgba(212,165,116,0.12), transparent 62%),
    radial-gradient(50% 120% at 85% 50%, rgba(212,165,116,0.18), transparent 60%),
    linear-gradient(180deg, rgba(0,0,0,0.30), rgba(0,0,0,0.55));
  pointer-events: none;
}
.vit-premium__stage .vitrine { position: relative; z-index: 1; }

/* Layout vitrine (grille) — nécessaire en LT26 */
.vit-premium__stage .vitrine {
  display: grid;
  gap: 14px;
}
.vit-premium__stage .etagere {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 14px;
}
.vit-premium__stage .slot {
  position: relative;
  min-height: 240px;
  border: 1px dashed rgba(244,234,217,0.18);
  border-radius: 14px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-end;
}
.vit-premium__stage .slot__link {
  width: 100%;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  padding: 14px 10px 10px;
  flex: 1 1 auto;
}
.vit-premium__stage .slot__img {
  width: min(92%, 210px);
  height: auto;
  max-height: 220px;
  object-fit: contain;
  object-position: bottom center;
}

/* Taille des images (S/M/L) — doit impacter les cases + l’image (aperçu premium) */
.vit-premium__stage .vitrine.vitrine-size-s .slot {
  min-height: 190px;
}
.vit-premium__stage .vitrine.vitrine-size-s .slot__img {
  width: min(90%, 170px);
  max-height: 175px;
}

.vit-premium__stage .vitrine.vitrine-size-m .slot {
  min-height: 240px;
}
.vit-premium__stage .vitrine.vitrine-size-m .slot__img {
  width: min(92%, 210px);
  max-height: 220px;
}

.vit-premium__stage .vitrine.vitrine-size-l .slot {
  min-height: 300px;
}
.vit-premium__stage .vitrine.vitrine-size-l .slot__img {
  width: min(94%, 260px);
  max-height: 285px;
}
.vit-premium__stage .slot__empty {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  /* important: on veut que le popover (+) soit cliquable */
  pointer-events: auto;
}
.vit-premium__stage .slot__intent {
  width: 100%;
  display: flex;
  justify-content: center;
  padding: 0 10px 12px;
  pointer-events: none;
}
.vit-premium__stage .slot__intent-pill {
  padding: 6px 10px;
  border-radius: 8px;
  font-family: var(--lt26-mono);
  font-size: 9.5px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  border: 1px solid rgba(244,234,217,0.18);
  background: rgba(0,0,0,0.35);
  color: var(--ink);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}
.vit-premium__stage .slot__intent--sell .slot__intent-pill {
  border-color: color-mix(in srgb, var(--coral) 55%, rgba(244,234,217,0.18));
  background: color-mix(in srgb, rgba(238,92,110,0.18) 60%, rgba(0,0,0,0.35));
}
.vit-premium__stage .slot__intent--expose .slot__intent-pill {
  border-color: color-mix(in srgb, var(--champagne) 55%, rgba(244,234,217,0.18));
  background: color-mix(in srgb, rgba(212,165,116,0.14) 60%, rgba(0,0,0,0.35));
}
.vit-premium__stage .slot__intent--props .slot__intent-pill {
  border-color: color-mix(in srgb, var(--vit-accent-2) 55%, rgba(244,234,217,0.18));
  background: color-mix(in srgb, rgba(155,231,255,0.10) 60%, rgba(0,0,0,0.35));
}
.vit-premium__stage .slot__empty-icon {
  width: 54px;
  height: 54px;
  display: grid;
  place-items: center;
  border-radius: 14px;
  border: 1px dashed rgba(244,234,217,0.22);
  background: rgba(0,0,0,0.25);
  color: var(--ink);
  font-size: 22px;
  transition: transform 240ms var(--lt26-ease-expo), border-color 240ms, background 240ms;
}
.vit-premium__stage .slot__add { pointer-events: auto; }
.vit-premium__stage details.slot__add > summary { list-style: none; }
.vit-premium__stage details.slot__add > summary::-webkit-details-marker { display:none; }

/* Popover "Ajouter" — plus esthétique */
.vit-premium__stage .slot__add {
  position: relative;
}
.vit-premium__stage .slot__add[open] > summary.slot__empty-icon {
  border-color: color-mix(in srgb, var(--vit-accent) 55%, rgba(244,234,217,0.22));
  background: color-mix(in srgb, rgba(212,165,116,0.12) 55%, rgba(0,0,0,0.25));
  transform: translateY(-2px);
}
.vit-premium__stage .slot--empty:hover .slot__empty-icon,
.vit-premium__stage .slot.is-empty:hover .slot__empty-icon {
  border-color: rgba(244,234,217,0.32);
  background: rgba(0,0,0,0.32);
  transform: translateY(-2px);
}

.vit-premium__stage .slot__add-menu {
  position: absolute;
  left: 50%;
  top: calc(100% + 10px);
  transform: translateX(-50%);
  min-width: 210px;
  border-radius: 14px;
  padding: 8px;
  border: 1px solid color-mix(in srgb, var(--vit-accent) 18%, rgba(244,234,217,0.18));
  background:
    radial-gradient(70% 120% at 50% 0%, color-mix(in srgb, var(--vit-accent) 18%, transparent), transparent 70%),
    color-mix(in srgb, var(--lt26-bg-elev) 84%, transparent);
  box-shadow: 0 22px 60px -26px rgba(0,0,0,0.75);
  backdrop-filter: blur(12px) saturate(140%);
  -webkit-backdrop-filter: blur(12px) saturate(140%);
  z-index: 5;
  opacity: 0;
  pointer-events: none;
  transition: opacity 180ms ease, transform 240ms var(--lt26-ease-expo);
}
.vit-premium__stage .slot__add[open] .slot__add-menu {
  opacity: 1;
  pointer-events: auto;
  transform: translateX(-50%) translateY(0);
}

.vit-premium__stage .slot__add-link {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 12px;
  text-decoration: none;
  color: var(--lt26-ink);
  border: 1px solid transparent;
  transition: background 180ms ease, border-color 180ms ease, transform 180ms ease;
  font-family: var(--lt26-sans);
  font-size: 13px;
}
.vit-premium__stage .slot__add-link::before {
  content: "✦";
  width: 18px;
  display: inline-grid;
  place-items: center;
  color: var(--vit-accent);
  font-size: 12px;
  opacity: .95;
}
.vit-premium__stage .slot__add-link:nth-child(2)::before {
  content: "✶";
}
.vit-premium__stage .slot__add-link:hover {
  background: color-mix(in srgb, var(--vit-accent) 10%, transparent);
  border-color: color-mix(in srgb, var(--vit-accent) 22%, transparent);
  transform: translateY(-1px);
}

/* Ajustements pour que la vitrine ressemble plus à la maquette */
.vit-premium__stage .etagere { border-radius: 14px; overflow: visible; }
.vit-premium__stage .slot {
  background: rgba(0,0,0,0.35);
  border-color: rgba(244,234,217,0.16);
}
.vit-premium__stage .slot__img { filter: drop-shadow(0 20px 26px rgba(0,0,0,0.55)); }
.vit-premium__stage .slot--empty .slot__link { opacity: 0.55; }
.vit-premium__stage .slot__empty-icon { color: var(--ink); }

.vit-ins__unit { font-size: 24px; }

/* Etat legacy: zoom (compat) */
.vit-premium[data-zoom="1"] .vit-premium__stage .slot { min-height: 300px; }
.vit-premium[data-zoom="1"] .vit-premium__stage .slot__img { width: min(94%, 260px); max-height: 285px; }

.vit-premium {
  /* Accent local au module (thème par défaut) */
  --vit-accent: var(--champagne);
  --vit-accent-2: var(--champagne-soft);
  --vit-ink: var(--ink);
  --vit-ink-soft: var(--ink-soft);
  --vit-line: var(--line);
  --vit-stage-bg: color-mix(in srgb, var(--bg-elev) 78%, transparent);
  --vit-glass: linear-gradient(180deg, rgba(0,0,0,0.30), rgba(0,0,0,0.55));
}

.vit-premium .vit-premium__title { color: var(--vit-ink); }
.vit-premium .vit-premium__meta,
.vit-premium .vit-premium__kicker { color: var(--ink-mute); }
.vit-premium .vit-premium__ctl:hover { border-color: var(--vit-accent); }
.vit-premium .vit-premium__ctl-ic { color: var(--vit-accent); }
.vit-premium .vit-premium__pill.is-active { background: var(--vit-accent); border-color: var(--vit-accent); }
.vit-premium__ctl--primary { background: var(--vit-accent); border-color: var(--vit-accent); }

.vit-premium .vit-premium__stage {
  background: var(--vit-stage-bg);
  border-color: color-mix(in srgb, var(--vit-accent) 28%, var(--vit-line));
  box-shadow: 0 0 0 1px rgba(0,0,0,0.08), 0 0 80px -36px color-mix(in srgb, var(--vit-accent) 38%, transparent);
}
.vit-premium .vit-premium__glass {
  background:
    radial-gradient(50% 120% at 15% 50%, color-mix(in srgb, var(--vit-accent) 22%, transparent), transparent 60%),
    radial-gradient(50% 120% at 50% 50%, color-mix(in srgb, var(--vit-accent) 14%, transparent), transparent 62%),
    radial-gradient(50% 120% at 85% 50%, color-mix(in srgb, var(--vit-accent) 22%, transparent), transparent 60%),
    var(--vit-glass);
}
.vit-premium .vit-premium__stage .slot.is-drop-target {
  border-color: var(--vit-accent);
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--vit-accent) 22%, transparent);
}

/* THÈMES (identité forte) */
.vit-premium[data-theme="dark"] {
  --vit-accent: var(--champagne);
  --vit-accent-2: var(--champagne-soft);
  --vit-stage-bg: radial-gradient(1200px 600px at 10% 20%, rgba(212,165,116,0.14), transparent 55%),
                  radial-gradient(900px 520px at 90% 60%, rgba(238,92,110,0.06), transparent 60%),
                  color-mix(in srgb, var(--bg-elev) 82%, transparent);
  --vit-glass: linear-gradient(180deg, rgba(0,0,0,0.30), rgba(0,0,0,0.58));
}

.vit-premium[data-theme="wood"] {
  --vit-accent: #E7C69A;
  --vit-accent-2: #CFA26B;
  --vit-stage-bg:
    radial-gradient(1100px 700px at 20% 10%, rgba(231,198,154,0.16), transparent 55%),
    linear-gradient(180deg, rgba(88,58,36,0.55), rgba(0,0,0,0.35)),
    repeating-linear-gradient(90deg, rgba(231,198,154,0.06) 0 2px, transparent 2px 26px);
  --vit-glass: linear-gradient(180deg, rgba(26,18,10,0.30), rgba(0,0,0,0.62));
}
.vit-premium[data-theme="wood"] .vit-premium__stage .slot {
  background: linear-gradient(180deg, rgba(20,12,6,0.35), rgba(0,0,0,0.55));
  border-color: rgba(231,198,154,0.22);
}

.vit-premium[data-theme="neon"] {
  --vit-accent: #7C5CFF;
  --vit-accent-2: #EE5C6E;
  --vit-stage-bg:
    radial-gradient(900px 520px at 30% 30%, rgba(124,92,255,0.18), transparent 60%),
    radial-gradient(900px 520px at 70% 60%, rgba(238,92,110,0.14), transparent 62%),
    linear-gradient(180deg, rgba(6,8,20,0.65), rgba(0,0,0,0.42));
  --vit-glass: linear-gradient(180deg, rgba(6,8,20,0.28), rgba(0,0,0,0.70));
}
.vit-premium[data-theme="neon"] .vit-premium__stage {
  box-shadow:
    0 0 0 1px rgba(124,92,255,0.22),
    0 0 120px -42px rgba(124,92,255,0.55),
    0 0 120px -52px rgba(238,92,110,0.40);
}
.vit-premium[data-theme="neon"] .vit-premium__stage .slot__img {
  filter: drop-shadow(0 20px 30px rgba(0,0,0,0.55)) drop-shadow(0 0 20px rgba(124,92,255,0.24));
}

.vit-premium[data-theme="gallery"] {
  --vit-accent: #9BE7FF;
  --vit-accent-2: #D4A574;
  --vit-stage-bg:
    radial-gradient(1200px 700px at 50% 0%, rgba(155,231,255,0.10), transparent 60%),
    linear-gradient(180deg, rgba(14,27,38,0.40), rgba(0,0,0,0.28));
  --vit-glass: linear-gradient(180deg, rgba(255,255,255,0.06), rgba(0,0,0,0.62));
}
.vit-premium[data-theme="gallery"] .vit-premium__stage .slot {
  background: rgba(255,255,255,0.04);
  border-color: rgba(155,231,255,0.18);
}

/* 3 thèmes supplémentaires */
.vit-premium[data-theme="bloodgold"] {
  --vit-accent: #D33B4A;      /* sang */
  --vit-accent-2: #F2D08A;    /* or pâle */
  --vit-stage-bg:
    radial-gradient(900px 520px at 25% 35%, rgba(211,59,74,0.20), transparent 62%),
    radial-gradient(1100px 700px at 80% 20%, rgba(242,208,138,0.16), transparent 60%),
    linear-gradient(180deg, rgba(10,10,14,0.70), rgba(0,0,0,0.45));
  --vit-glass: linear-gradient(180deg, rgba(10,10,14,0.25), rgba(0,0,0,0.78));
}
.vit-premium[data-theme="bloodgold"] .vit-premium__stage .slot {
  background: linear-gradient(180deg, rgba(12,10,12,0.30), rgba(0,0,0,0.62));
  border-color: rgba(242,208,138,0.18);
}
.vit-premium[data-theme="bloodgold"] .vit-premium__stage .slot__img {
  filter:
    drop-shadow(0 20px 30px rgba(0,0,0,0.60))
    drop-shadow(0 0 22px rgba(211,59,74,0.20));
}

.vit-premium[data-theme="jade"] {
  --vit-accent: #2EE6B5;
  --vit-accent-2: #B8FFD6;
  --vit-stage-bg:
    radial-gradient(900px 520px at 30% 35%, rgba(46,230,181,0.18), transparent 62%),
    radial-gradient(900px 520px at 75% 70%, rgba(184,255,214,0.10), transparent 60%),
    linear-gradient(180deg, rgba(6,18,16,0.72), rgba(0,0,0,0.42));
  --vit-glass: linear-gradient(180deg, rgba(6,18,16,0.26), rgba(0,0,0,0.76));
}
.vit-premium[data-theme="jade"] .vit-premium__stage .slot {
  background: rgba(0,0,0,0.38);
  border-color: rgba(46,230,181,0.18);
}
.vit-premium[data-theme="jade"] .vit-premium__stage .slot__img {
  filter:
    drop-shadow(0 20px 26px rgba(0,0,0,0.55))
    drop-shadow(0 0 18px rgba(46,230,181,0.18));
}

.vit-premium[data-theme="ivory"] {
  --vit-accent: #F2D08A;
  --vit-accent-2: #9BE7FF;
  --vit-stage-bg:
    radial-gradient(1200px 700px at 50% 0%, rgba(242,208,138,0.14), transparent 60%),
    radial-gradient(1200px 700px at 20% 80%, rgba(155,231,255,0.10), transparent 62%),
    linear-gradient(180deg, rgba(255,255,255,0.05), rgba(0,0,0,0.56));
  --vit-glass: linear-gradient(180deg, rgba(255,255,255,0.08), rgba(0,0,0,0.72));
}
.vit-premium[data-theme="ivory"] .vit-premium__stage .slot {
  background: rgba(255,255,255,0.04);
  border-color: rgba(242,208,138,0.18);
}

/* On retire les anciens micro-variants (désormais gérés par variables) */
/* (remplacé) */

.vit-premium[data-light="soft"] .vit-premium__glass {
  background:
    radial-gradient(60% 140% at 20% 50%, rgba(212,165,116,0.12), transparent 62%),
    radial-gradient(60% 140% at 80% 50%, rgba(212,165,116,0.12), transparent 62%),
    linear-gradient(180deg, rgba(0,0,0,0.22), rgba(0,0,0,0.48));
}
.vit-premium[data-light="hard"] .vit-premium__glass {
  background:
    radial-gradient(40% 140% at 18% 50%, rgba(212,165,116,0.24), transparent 60%),
    radial-gradient(40% 140% at 52% 50%, rgba(212,165,116,0.18), transparent 62%),
    radial-gradient(40% 140% at 86% 50%, rgba(212,165,116,0.26), transparent 58%),
    linear-gradient(180deg, rgba(0,0,0,0.30), rgba(0,0,0,0.62));
}

/* Réorganisation (drag & drop) */
.vit-premium__ctl--primary {
  background: var(--champagne);
  border-color: var(--champagne);
  color: #0E1B26;
}
.vit-premium.is-reorg .vit-premium__stage .slot {
  outline: 1px dashed rgba(212,165,116,0.28);
}
.vit-premium__stage .slot__link.is-draggable { cursor: grab; }
.vit-premium__stage .slot.is-dragging { opacity: 0.6; }
.vit-premium__stage .slot.is-drop-target {
  border-color: var(--champagne);
  box-shadow: 0 0 0 2px rgba(212,165,116,0.18);
}

.vit-premium__slotsform { display: none; }

/* Barre d'actions sous la vitrine */
.vit-premium__controls {
  margin-top: 12px;
  padding: 14px 16px;
  /* Doit rester stable : le thème vitrine ne doit pas recolorer ce bandeau */
  border: 1px solid var(--lt26-line);
  background: color-mix(in srgb, var(--lt26-bg-elev) 70%, transparent);
  border-radius: 14px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
}
.vit-premium__controls-left { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.vit-premium__ctl {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  background: transparent;
  border: 1px solid var(--lt26-line);
  border-radius: 999px;
  color: var(--lt26-ink-soft);
  cursor: pointer;
  transition: all 240ms;
}
.vit-premium__ctl:hover { border-color: var(--champagne); color: var(--ink); background: rgba(212,165,116,0.08); }
.vit-premium__ctl-ic { width: 16px; text-align: center; color: var(--champagne); }
.vit-premium__controls-right { margin-left: auto; opacity: .95; }

/* Panneau personnalisation (prototype) */
.vit-premium__panel {
  margin-top: 12px;
  padding: 16px;
  /* Doit rester stable : le thème vitrine ne doit pas recolorer ce bandeau */
  border: 1px solid var(--lt26-line);
  background: var(--lt26-bg-elev);
  border-radius: 14px;
}
.vit-premium__panel-head { display: flex; align-items: baseline; justify-content: space-between; gap: 12px; flex-wrap: wrap; margin-bottom: 12px; }
.vit-premium__panel-sub { opacity: .65; }
.vit-premium__panel-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 14px; }
.vit-premium__panel-grid--wide { grid-template-columns: repeat(2, minmax(0, 1fr)); margin-top: 14px; }
.vit-premium__group { padding: 12px; border: 1px solid var(--lt26-line); border-radius: 12px; background: color-mix(in srgb, var(--lt26-bg) 18%, transparent); }
.vit-premium__label { margin-bottom: 10px; }
.vit-premium__pills { display: flex; gap: 8px; flex-wrap: wrap; }
.vit-premium__pill {
  padding: 8px 12px;
  border-radius: 999px;
  border: 1px solid var(--lt26-line);
  background: transparent;
  color: var(--lt26-ink-soft);
  font-size: 12px;
  cursor: pointer;
  transition: all 240ms;
}
.vit-premium__pill:hover { border-color: var(--champagne); color: var(--ink); }
.vit-premium__pill.is-active { background: var(--champagne); border-color: var(--champagne); color: #0E1B26; }

.vit-premium__fields { display: grid; gap: 10px; }
.vit-premium__field { display: grid; gap: 6px; }
.vit-premium__field-k { font-family: var(--lt26-mono); font-size: 10.5px; letter-spacing: .18em; text-transform: uppercase; color: var(--lt26-ink-mute); }
.vit-premium__input,
.vit-premium__textarea {
  width: 100%;
  border-radius: 12px;
  border: 1px solid var(--lt26-line);
  background: color-mix(in srgb, var(--lt26-bg) 22%, transparent);
  color: var(--lt26-ink);
  padding: 10px 12px;
  font-family: var(--lt26-sans);
  font-size: 13px;
  outline: none;
}
.vit-premium__textarea { resize: vertical; min-height: 86px; }
.vit-premium__input:focus,
.vit-premium__textarea:focus { border-color: color-mix(in srgb, var(--champagne) 55%, var(--lt26-line)); box-shadow: 0 0 0 2px rgba(212,165,116,0.16); }
.vit-premium__range { width: 100%; accent-color: var(--champagne); }
.vit-premium__color { width: 56px; height: 38px; border: 1px solid var(--lt26-line); border-radius: 10px; background: transparent; padding: 0; }
.vit-premium__panel-actions { margin-top: 12px; display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.vit-premium__savehint { opacity: .75; }

@media (max-width: 900px) {
  .vit-premium__panel-grid { grid-template-columns: 1fr; }
  .vit-premium__panel-grid--wide { grid-template-columns: 1fr; }
  .vit-premium__controls-right { margin-left: 0; }
}
.vit-main { display: flex; flex-direction: column; gap: 28px; }
.vit-hero {
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: 24px;
  padding: 44px 48px 36px;
  position: relative;
  overflow: hidden;
}
.vit-hero::before {
  content: "";
  position: absolute;
  top: -120px; right: -80px;
  width: 320px; height: 320px;
  border-radius: 50%;
  background: radial-gradient(circle, var(--champagne-glow), transparent 70%);
  pointer-events: none;
}
.vit-hero__title { position: relative; z-index: 2; }
.vit-hero__h1 {
  font-size: clamp(40px, 4vw, 60px);
  margin: 6px 0 12px;
  line-height: 1;
}
.vit-hero__sub {
  max-width: 540px;
  color: var(--ink-soft);
  font-size: 15px;
  line-height: 1.55;
  margin: 0;
}
.vit-hero__stats {
  position: relative;
  z-index: 2;
  margin: 36px 0 28px;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
  padding-top: 24px;
  border-top: 1px solid var(--line);
}
.vit-stat {
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--line);
  border-radius: 16px;
  padding: 16px 16px 14px;
}
.vit-stat__num {
  font-size: 34px;
  letter-spacing: -0.02em;
  color: var(--ink);
  line-height: 1;
}
.vit-stat__label {
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin-top: 8px;
}
.vit-stat__delta { margin-top: 6px; }
.vit-hero__cta {
  position: relative;
  z-index: 2;
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}
.vit-grid {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: 28px;
}
.vit-act, .vit-ins {
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: 24px;
  padding: 32px 36px;
}
.vit-act__head, .vit-ins__top {
  display: flex; justify-content: space-between; align-items: end;
  margin-bottom: 22px;
}
.vit-act__head h3, .vit-ins__num {
  margin: 6px 0 0;
  font-size: 26px;
  font-weight: 400;
}
.vit-act__all { color: var(--champagne); font-size: 13px; }
.vit-act__timeline { display: flex; flex-direction: column; gap: 0; position: relative; }
.vit-act__timeline::before {
  content: "";
  position: absolute;
  left: 14px; top: 8px; bottom: 8px;
  width: 1px;
  background: var(--line);
}
.vit-act__item {
  position: relative;
  display: grid;
  grid-template-columns: 30px 1fr;
  gap: 14px;
  padding: 12px 0;
  align-items: start;
}
.vit-act__dot {
  position: relative;
  z-index: 2;
  width: 30px; height: 30px;
  border-radius: 50%;
  background: var(--bg-elev-2);
  border: 1px solid var(--line-strong);
  display: grid; place-items: center;
  color: var(--champagne);
}
.vit-act__text { font-size: 14px; color: var(--ink); }
.vit-ins__num { color: var(--ink); font-size: 34px; }
.vit-ins__chart { width: 100%; height: 180px; display: block; }
.vit-ins__base { display: flex; justify-content: space-between; margin-top: 8px; color: var(--ink-mute); }

@media (max-width: 1100px) {
  .vit-layout { grid-template-columns: 1fr; padding: 120px 20px 40px; }
  .vitrine-side { position: relative; height: auto; top: 0; }
  .vit-hero { padding: 34px 22px 26px; }
  .vit-hero__stats { grid-template-columns: repeat(2, 1fr); }
  .vit-grid { grid-template-columns: 1fr; }
  .vit-act, .vit-ins { padding: 22px; }
}

/* =====================================================================
   CARTE COMMUNAUTAIRE (LT26) — import adapté depuis Claude Design
   ===================================================================== */
.carte-page { padding: 130px 40px 40px; max-width: 1480px; margin: 0 auto; }
.carte-page__head {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px;
  margin-bottom: 40px;
  align-items: end;
}
.carte-page__h1 {
  font-size: clamp(48px, 7vw, 110px);
  margin: 12px 0 0;
  letter-spacing: -0.025em;
}
.carte-page__intro p {
  font-size: 16px;
  color: var(--ink-soft);
  line-height: 1.55;
  margin: 0 0 24px;
}
.carte-page__intro em { color: var(--champagne); }
.carte-page__intro-meta {
  display: flex;
  gap: 40px;
  padding-top: 20px;
  border-top: 1px solid var(--line);
  flex-wrap: wrap;
}

.carte-layout {
  display: grid;
  grid-template-columns: 280px 1fr 320px;
  gap: 24px;
  height: 720px;
}

.carte-filters {
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: 18px;
  padding: 28px 24px;
  display: flex;
  flex-direction: column;
  gap: 20px;
  overflow-y: auto;
}
.carte-filters__group { display: flex; flex-direction: column; gap: 8px; }
.carte-filters__group label { color: var(--ink-mute); }
.carte-input {
  appearance: none;
  background: var(--bg);
  border: 1px solid var(--line);
  color: var(--ink);
  border-radius: 10px;
  padding: 10px 12px;
  font-family: inherit;
  font-size: 13px;
  outline: none;
  transition: border-color 200ms;
}
.carte-input:focus { border-color: var(--champagne); }
.carte-radius { display: flex; align-items: center; gap: 12px; }
.carte-radius input { flex: 1; accent-color: var(--champagne); }
.carte-radius__legend { color: var(--ink-mute); margin-top: 4px; }

.carte-canvas {
  position: relative;
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: 18px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}
.carte-canvas__topbar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 14px 20px;
  border-bottom: 1px solid var(--line);
  gap: 16px;
  flex-wrap: wrap;
  z-index: 5;
  background: color-mix(in srgb, var(--bg-elev) 95%, transparent);
}
.carte-canvas__search {
  flex: 1;
  display: flex;
  align-items: center;
  gap: 10px;
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 8px 16px;
  color: var(--ink-mute);
  min-width: 220px;
}
.carte-canvas__search input {
  flex: 1;
  background: transparent;
  border: 0;
  outline: 0;
  color: var(--ink);
  font: inherit;
  font-size: 13px;
}
.carte-canvas__topbar-r { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }

.carte-canvas__map { position: relative; flex: 1; }
.carte-canvas__map .carte-statues-map,
.carte-canvas__map #carte-statues-map {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}

.carte-detail {
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: 18px;
  padding: 28px;
  display: flex;
  flex-direction: column;
  gap: 18px;
  overflow-y: auto;
}
.carte-detail__name { font-size: 34px; margin: 4px 0 4px; line-height: 1; }
.carte-detail__stats {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  padding: 16px 0;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.carte-detail__stats .lt26-serif {
  font-size: 24px;
  color: var(--champagne);
  display: block;
  line-height: 1;
}

@media (max-width: 1300px) {
  .carte-layout { grid-template-columns: 240px 1fr; height: auto; }
  .carte-detail { grid-column: 1 / -1; }
}
@media (max-width: 800px) {
  .carte-layout { grid-template-columns: 1fr; }
  .carte-page__head { grid-template-columns: 1fr; }
  .carte-page { padding: 120px 20px 40px; }
  .carte-layout { height: auto; }
  .carte-canvas { height: 520px; }
}

/* =====================================================================
   FICHE PRODUIT (LT26) — import adapté depuis Claude Design
   (version images réelles au lieu de composant React)
   ===================================================================== */
.fp { padding-top: 110px; }
.fp__crumbs {
  display: flex; align-items: center; gap: 10px;
  max-width: 1480px; margin: 0 auto;
  padding: 16px 24px;
  color: var(--ink-mute);
  flex-wrap: wrap;
}
.fp__crumb-sep { color: var(--ink-mute); }
.fp__crumb-link,
.fp__crumb-cur {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .12em;
  text-transform: uppercase;
  text-decoration: none;
  color: inherit;
}
.fp__crumb-cur { color: var(--champagne); }
.fp__main {
  display: grid;
  grid-template-columns: 1.15fr 1fr;
  gap: 60px;
  max-width: 1480px; margin: 0 auto;
  padding: 20px 24px 60px;
}
.fp__stage-wrap { position: sticky; top: 100px; align-self: start; }
.fp__stage {
  position: relative;
  aspect-ratio: 4/5;
  background:
    radial-gradient(80% 60% at 50% 20%, rgba(212,165,116,0.18), transparent 70%),
    linear-gradient(180deg, var(--bg-elev), var(--bg-soft));
  border: 1px solid var(--line);
  border-radius: 24px;
  overflow: hidden;
  transition: border-color 400ms;
}
.fp__stage-grid {
  position: absolute;
  inset: 14px;
  border-radius: 18px;
  pointer-events: none;
  opacity: .35;
  background-image:
    linear-gradient(to right, rgba(244,234,217,0.10) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(244,234,217,0.10) 1px, transparent 1px);
  background-size: 25% 25%;
  mask-image: radial-gradient(120% 90% at 50% 40%, #000 40%, transparent 70%);
}
.fp__stage-light {
  position: absolute;
  top: -8%; left: 25%; right: 25%;
  height: 60%;
  background:
    radial-gradient(ellipse 80% 60% at 50% 20%, rgba(255,235,200,0.18), transparent 60%),
    radial-gradient(ellipse 60% 80% at 50% 30%, rgba(212,165,116,0.38), transparent 70%);
  filter: blur(8px);
  pointer-events: none;
  z-index: 1;
}
.fp__stage-bg-rays {
  position: absolute;
  top: 0; left: 50%;
  width: 200%;
  height: 100%;
  transform: translateX(-50%);
  background:
    conic-gradient(from 180deg at 50% 0%,
      transparent 0deg,
      rgba(212,165,116,0.04) 16deg,
      transparent 32deg,
      rgba(212,165,116,0.06) 48deg,
      transparent 70deg,
      transparent 290deg,
      rgba(212,165,116,0.06) 310deg,
      transparent 330deg,
      rgba(212,165,116,0.04) 344deg,
      transparent 360deg);
  filter: blur(20px);
  pointer-events: none;
  opacity: 0.7;
}
.fp__stage-floor {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 30%;
  background: linear-gradient(180deg, transparent, color-mix(in srgb, var(--bg) 80%, #000));
  pointer-events: none;
}
.fp__stage-piece {
  position: absolute;
  left: 50%; bottom: 6%;
  transform: translateX(-50%);
  width: 94%;
  display: grid; place-items: center;
  z-index: 3;
  filter: drop-shadow(0 30px 40px rgba(0,0,0,0.6));
}
.fp__stage-piece img {
  width: 100%;
  height: 100%;
  max-height: 640px;
  object-fit: contain;
  object-position: center;
  transform: translateZ(0);
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
  image-rendering: -webkit-optimize-contrast;
}
.fp__stage-empty {
  width: 100%;
  height: 100%;
  display: grid;
  place-items: center;
  color: var(--ink-mute);
  font-family: var(--mono);
  letter-spacing: .12em;
  text-transform: uppercase;
  font-size: 11px;
}
.fp__stage-count { color: var(--champagne); }
.fp__stage-pedestal {
  position: absolute;
  left: 50%; bottom: 8%;
  transform: translateX(-50%);
  width: 45%; height: 4px;
  background: linear-gradient(90deg, transparent, var(--champagne) 15%, var(--champagne) 85%, transparent);
  border-radius: 2px;
  box-shadow: 0 0 32px color-mix(in srgb, var(--champagne) 50%, transparent);
  z-index: 2;
}
.fp__stage-pedestal::after {
  content: ''; position: absolute; top: 4px; left: 10%; right: 10%;
  height: 24px;
  background: linear-gradient(180deg, color-mix(in srgb, var(--champagne) 20%, transparent), transparent);
  filter: blur(4px); pointer-events: none;
}
.fp__stage-meta {
  position: absolute;
  bottom: 16px; left: 16px; right: 16px;
  display: flex; justify-content: space-between; align-items: center;
  font-size: 10px;
  letter-spacing: 0.18em;
  color: var(--ink-mute);
  z-index: 4;
  font-family: var(--mono);
  text-transform: uppercase;
  pointer-events: none;
}
.fp__stage-zoom {
  pointer-events: auto;
  background: transparent; border: 0;
  color: var(--champagne); font-family: var(--mono);
  font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase;
  cursor: pointer; padding: 4px 8px; border-radius: 6px;
  transition: background 200ms;
}
.fp__stage-zoom:hover { background: color-mix(in srgb, var(--champagne) 12%, transparent); }
.fp__stage-zoom-plus { display: inline-block; margin-right: 4px; opacity: 0.7; }
.fp__thumbs {
  display: flex;
  gap: 10px;
  margin-top: 14px;
  overflow-x: auto;
  padding-bottom: 6px;
  -webkit-overflow-scrolling: touch;
  scroll-snap-type: x mandatory;
}
.fp__thumbs::-webkit-scrollbar { height: 8px; }
.fp__thumbs::-webkit-scrollbar-thumb { background: rgba(244,234,217,0.10); border-radius: 999px; }
.fp__thumbs::-webkit-scrollbar-track { background: transparent; }
.fp__thumb {
  flex: 0 0 108px;
  background: transparent;
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 10px 8px;
  cursor: pointer;
  transition: all 240ms;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  scroll-snap-align: start;
}
.fp__thumb:hover { border-color: var(--line-strong); }
.fp__thumb.is-active { border-color: var(--champagne); background: color-mix(in srgb, var(--champagne) 8%, transparent); }
.fp__thumb-inner {
  width: 100%;
  aspect-ratio: 3/4;
  display: grid; place-items: center;
  overflow: hidden;
}
.fp__thumb-inner img { width: 100%; height: 100%; object-fit: cover; border-radius: 10px; }
.fp__thumb-label {
  font-size: 8.5px;
  letter-spacing: 0.14em;
  color: var(--ink-mute);
  text-transform: uppercase;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 100%;
  font-family: var(--mono);
}
.fp__thumb.is-active .fp__thumb-label { color: var(--champagne); }

.fp__info { display: flex; flex-direction: column; gap: 18px; }
.fp__eyebrow { display: flex; justify-content: space-between; align-items: center; gap: 16px; flex-wrap: wrap; }
.fp__brand { font-size: 11px; letter-spacing: 0.22em; color: var(--ink-mute); text-transform: uppercase; font-family: var(--mono); }
.fp__title { font-size: clamp(56px, 7vw, 110px); margin: -4px 0 0; line-height: 0.95; font-family: var(--serif); font-weight: 400; letter-spacing: -0.025em; color: var(--ink); }
.fp__title-accent { color: var(--champagne); font-style: italic; font-weight: 400; }
.fp__sub { font-size: 17px; color: var(--ink-soft); margin-bottom: 8px; font-family: var(--serif); font-style: italic; line-height: 1.4; max-width: 520px; }
.fp__price-row {
  display: flex;
  justify-content: space-between;
  align-items: end;
  padding: 24px 0;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  gap: 18px;
  flex-wrap: wrap;
}
.fp__price { font-size: clamp(48px, 5vw, 64px); letter-spacing: -0.02em; color: var(--champagne); line-height: 1; font-family: var(--serif); margin-top: 6px; }
.fp__price-euro { font-size: 0.5em; opacity: 0.85; margin-left: 4px; }
.fp__specs {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--line);
  border: 1px solid var(--line);
  border-radius: 12px;
  overflow: hidden;
}
.fp__spec { background: var(--bg-elev); padding: 14px 16px; transition: background 240ms; }
.fp__spec:hover { background: color-mix(in srgb, var(--bg-elev) 70%, var(--champagne) 6%); }
.fp__spec .fp__spec-k { font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--ink-mute); }
.fp__spec .fp__spec-v { font-size: 17px; margin-top: 6px; color: var(--ink); font-family: var(--serif); letter-spacing: -0.005em; }
.fp__ctas { display: flex; gap: 10px; align-items: stretch; flex-wrap: wrap; }
.fp__cta-main { flex: 1; min-width: 200px; justify-content: center; padding: 18px 24px; font-size: 14px; letter-spacing: 0.04em; }
.fp__icon-btn {
  width: 52px; height: 52px;
  border-radius: 12px;
  background: transparent;
  border: 1px solid var(--line-strong);
  color: var(--ink);
  display: grid; place-items: center;
  transition: all 240ms;
  cursor: pointer;
  font-size: 18px;
  flex-shrink: 0;
}
.fp__icon-btn:hover { border-color: var(--champagne); color: var(--champagne); transform: translateY(-2px); }
.fp__icon-btn.is-favori { border-color: var(--coral); color: var(--coral); }

.fp__tabs { max-width: 1480px; margin: 0 auto; padding: 40px 24px 20px; border-top: 1px solid var(--line); }
.fp__tabs-rail {
  display: flex;
  gap: 4px;
  border-bottom: 1px solid var(--line);
  margin-bottom: 32px;
  overflow-x: auto;
  position: sticky;
  top: 86px;
  z-index: 20;
  padding-top: 10px;
  padding-bottom: 10px;
  background: color-mix(in srgb, var(--bg) 78%, transparent);
  backdrop-filter: blur(14px) saturate(140%);
  -webkit-backdrop-filter: blur(14px) saturate(140%);
}
.fp__tab {
  position: relative;
  background: transparent;
  border: 0;
  color: var(--ink-soft);
  padding: 14px 20px;
  font-family: var(--sans);
  font-size: 14px;
  letter-spacing: 0.01em;
  cursor: pointer;
  transition: color 240ms;
  white-space: nowrap;
}
.fp__tab:hover, .fp__tab.is-active { color: var(--ink); }
.fp__tab-underline {
  position: absolute;
  left: 14px; right: 14px; bottom: -1px;
  height: 2px;
  background: var(--champagne);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 360ms var(--ease-out-expo);
}
.fp__tab.is-active .fp__tab-underline { transform: scaleX(1); }
.fp__tab-content { padding-bottom: 60px; }
.fp__panel {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: 48px;
  align-items: start;
}
.fp__lede { font-size: clamp(22px, 2.4vw, 32px); line-height: 1.3; font-weight: 400; color: var(--ink); margin: 12px 0 24px; letter-spacing: -0.01em; font-family: var(--serif); }
.fp__lede-em { color: var(--champagne); font-style: italic; }
.fp__body { color: var(--ink-soft); font-size: 15px; line-height: 1.6; max-width: 540px; }
.fp__body p { margin: 0 0 12px; }

/* Liste de features numérotées (B1, B2...) */
.fp__features { list-style: none; padding: 0; margin: 24px 0 0; border-top: 1px solid var(--line); }
.fp__feature { display: grid; grid-template-columns: 36px 1fr; gap: 16px; padding: 14px 0; border-bottom: 1px solid var(--line); align-items: baseline; }
.fp__feature-num { font-family: var(--mono); font-size: 9px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--ink-mute); }
.fp__feature-text { font-size: 14px; color: var(--ink-soft); line-height: 1.5; }

/* Spec table sur la droite avec dimensions */
.fp__dim {
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 18px 20px;
  background: color-mix(in srgb, var(--bg-elev) 60%, transparent);
}
.fp__dim-row { display: flex; justify-content: space-between; align-items: baseline; padding: 10px 0; border-bottom: 1px dashed color-mix(in srgb, var(--line-strong) 60%, transparent); gap: 16px; }
.fp__dim-row:last-child { border-bottom: 0; }
.fp__dim-k { font-family: var(--mono); font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--ink-mute); }
.fp__dim-v { font-family: var(--serif); font-size: 16px; color: var(--ink); }
.fp__dim-v--champ { color: var(--champagne); }

/* Blocs annexes "confiance" + recommandations */
.fp__trust {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  margin-top: 10px;
}
.fp__trust-card {
  position: relative;
  border: 1px solid var(--line);
  background: color-mix(in srgb, var(--bg-elev) 78%, transparent);
  border-radius: 12px;
  padding: 14px 14px 14px 36px;
  transition: border-color 240ms, background 240ms;
}
.fp__trust-card:hover { border-color: color-mix(in srgb, var(--champagne) 50%, var(--line-strong)); background: color-mix(in srgb, var(--bg-elev) 90%, transparent); }
.fp__trust-card::before {
  content: '✓';
  position: absolute;
  left: 12px; top: 14px;
  width: 16px; height: 16px;
  display: grid; place-items: center;
  border-radius: 50%;
  background: color-mix(in srgb, var(--champagne) 18%, transparent);
  color: var(--champagne);
  font-size: 9px; font-weight: 700;
  line-height: 1;
}
.fp__trust-k { font-family: var(--mono); font-size: 10px; letter-spacing: .18em; text-transform: uppercase; color: var(--ink); }
.fp__trust-v { margin-top: 6px; font-size: 12px; color: var(--ink-soft); line-height: 1.45; }

.fp__more { max-width: 1480px; margin: 0 auto; padding: 10px 24px 80px; border-top: 1px solid var(--line); }
.fp__more-head { display:flex; align-items: baseline; justify-content: space-between; gap: 14px; flex-wrap: wrap; margin: 18px 0 22px; }
.fp__more-title { margin: 0; font-family: var(--serif); font-weight: 400; letter-spacing: -0.02em; font-size: clamp(34px, 3.4vw, 54px); }
.fp__more-link { font-family: var(--mono); font-size: 11px; letter-spacing: .18em; text-transform: uppercase; color: var(--ink-soft); text-decoration: none; }
.fp__more-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 14px; }
.fp__more-card { border: 1px solid var(--line); background: color-mix(in srgb, var(--bg-elev) 72%, transparent); border-radius: 16px; overflow: hidden; transition: transform 240ms var(--ease-out-expo), border-color 240ms; text-decoration: none; display: flex; flex-direction: column; }
.fp__more-card:hover { transform: translateY(-3px); border-color: var(--line-strong); }
.fp__more-media { position: relative; aspect-ratio: 1/1; background: linear-gradient(180deg, rgba(212,165,116,0.08), rgba(0,0,0,0.28)); display:grid; place-items:center; overflow:hidden; }
.fp__more-media img { width: 100%; height: 100%; object-fit: cover; }
.fp__more-num { position: absolute; top: 10px; left: 12px; font-family: var(--mono); font-size: 9px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink-mute); }
.fp__more-badge { position: absolute; top: 10px; right: 10px; font-family: var(--mono); font-size: 8px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--ink); background: color-mix(in srgb, var(--bg) 85%, transparent); border: 1px solid var(--line-strong); border-radius: 999px; padding: 3px 8px; }
.fp__more-meta { padding: 14px 14px 16px; flex: 1; display: flex; flex-direction: column; gap: 6px; }
.fp__more-k { font-family: var(--mono); font-size: 10px; letter-spacing: .18em; text-transform: uppercase; color: var(--ink-mute); }
.fp__more-name { font-family: var(--serif); font-size: 17px; font-style: italic; color: var(--ink); letter-spacing: -0.01em; line-height: 1.2; flex: 1; }
.fp__more-row { display:flex; justify-content: space-between; align-items: center; gap: 10px; margin-top: auto; }
.fp__more-scale { font-family: var(--mono); font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--ink-mute); }
.fp__more-price { font-family: var(--serif); color: var(--champagne); font-size: 17px; }
.fp__more-btn { font-family: var(--mono); font-size: 9px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--ink-mute); border: 1px solid var(--line); border-radius: 6px; padding: 5px 9px; transition: border-color 200ms, color 200ms; }
.fp__more-card:hover .fp__more-btn { border-color: var(--champagne); color: var(--champagne); }

/* Watcher count */
.fp__watcher { display: inline-flex; align-items: center; gap: 6px; font-family: var(--mono); font-size: 10px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--champagne); }
.fp__watcher-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--champagne); flex-shrink: 0; animation: fp-dot-pulse 2s ease-in-out infinite; }
@keyframes fp-dot-pulse { 0%, 100% { opacity: 1; transform: scale(1); } 50% { opacity: 0.35; transform: scale(0.65); } }

/* Stars + rating line */
.fp__stars { letter-spacing: 0.06em; color: var(--champagne); }
.fp__price-detail { font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.13em; text-transform: uppercase; color: var(--ink-mute); margin-top: 8px; }
.fp__price-rating { display: flex; align-items: center; gap: 10px; margin-top: 8px; }
.fp__price-rating-text { font-family: var(--mono); font-size: 10px; letter-spacing: 0.13em; text-transform: uppercase; color: var(--ink-mute); }

/* Barre d'actions bas du stage */
.fp__stage-bar { display: flex; align-items: center; justify-content: space-between; gap: 10px; margin-top: 12px; padding: 10px 0; border-top: 1px solid var(--line); flex-wrap: wrap; }
.fp__stage-bar-actions { display: flex; gap: 2px; }
.fp__stage-bar-action { background: transparent; border: 0; padding: 7px 11px; font-family: var(--mono); font-size: 9.5px; letter-spacing: 0.13em; text-transform: uppercase; color: var(--ink-mute); cursor: pointer; border-radius: 7px; transition: color 200ms, background 200ms; }
.fp__stage-bar-action:hover { color: var(--ink); background: var(--bg-elev); }
.fp__stage-bar-sep { color: var(--line-strong); user-select: none; }
.fp__stage-bar-meta { font-family: var(--mono); font-size: 9px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink-mute); text-align: right; }


@media (max-width: 1100px) {
  .fp__main { grid-template-columns: 1fr; }
  .fp__stage-wrap { position: static; }
  .fp__panel { grid-template-columns: 1fr; }
  .fp__specs { grid-template-columns: repeat(2, 1fr); }
  .fp__trust { grid-template-columns: 1fr; }
  .fp__more-grid { grid-template-columns: repeat(2, 1fr); }
  .fp__stage-bar { flex-direction: column; align-items: flex-start; gap: 6px; }
}
@media (max-width: 480px) {
  .fp__more-grid { grid-template-columns: 1fr; }
}
@media (max-width: 700px) {
  .fp__title { font-size: 56px; }
  .fp__price { font-size: 40px; }
  .fp__thumb { flex-basis: 96px; }
  .fp__tabs { padding: 28px 16px 20px; }
  .fp__main { padding: 20px 16px 40px; }
  .fp__crumbs { padding: 16px 16px; }
  .fp__more { padding: 10px 16px 70px; }
}

/* =====================================================================
   PROTOS LT26 — ACHETER / BOUTIQUE / MARKETING (scopés)
   ===================================================================== */

/* Base wrapper */
.lt26-page {
  background: radial-gradient(1200px 600px at 20% -10%, rgba(212,165,116,0.14), transparent 55%),
              radial-gradient(900px 520px at 90% 20%, rgba(238,92,110,0.08), transparent 60%),
              var(--bg);
  color: var(--ink);
}

.lt26-page a { color: inherit; }
.lt26-page .btn, .lt26-page .btn-secondary, .lt26-page .btn-lbc-annonce { text-decoration: none; }

/* ACHETER: rendre l'édition collector cohérente avec LT26 (sans remplacer bundle-acheter.css) */
.lt26-acheter .acheter-page-edition {
  background: transparent;
  color: var(--ink);
}
.lt26-acheter .ae-hero {
  /* IMPORTANT: bundle-acheter.css est chargé après, donc on force */
  background:
    radial-gradient(circle at 18% 20%, rgba(212, 165, 116, 0.22), transparent 55%),
    radial-gradient(circle at 82% 80%, rgba(238, 92, 110, 0.10), transparent 60%),
    linear-gradient(180deg, rgba(14,27,38,0.96) 0%, rgba(14,27,38,0.74) 60%, rgba(14,27,38,0.55) 100%) !important;
  border-bottom: 1px solid var(--line) !important;
}
.lt26-acheter .ae-title,
.lt26-acheter .ae-title em { color: var(--ink); }
.lt26-acheter .ae-title em { color: var(--champagne-soft); }
.lt26-acheter .ae-eyebrow { color: var(--champagne-deep) !important; }
.lt26-acheter .ae-title { color: var(--ink) !important; }
.lt26-acheter .ae-title em { color: var(--champagne) !important; }
.lt26-acheter .ae-lead { color: var(--ink-soft) !important; }
.lt26-acheter .ae-toolbar {
  background: color-mix(in srgb, var(--bg-elev) 88%, transparent) !important;
  border: 1px solid var(--line) !important;
}
.lt26-acheter .ae-sort-pill { border-color: var(--line-strong); color: var(--ink-soft); }
.lt26-acheter .ae-sort-pill:hover { border-color: var(--champagne); background: rgba(212,165,116,0.10); color: var(--ink); }
.lt26-acheter .ae-sort-pill.is-active,
.lt26-acheter .ae-sort-pill[aria-pressed="true"] { background: var(--champagne); border-color: var(--champagne); color: #0E1B26; }

/* petit rappel visuel sous le hero (zone blanche → bleu) */
.lt26-acheter .ae-toolbar,
.lt26-acheter .acheter-layout-flex {
  box-shadow: none;
}

/* Mode soleil : bandeau acheter (hero) doit passer en clair */
[data-theme="light"] .lt26-acheter .ae-hero {
  background:
    radial-gradient(circle at 18% 20%, rgba(212, 165, 116, 0.16), transparent 55%),
    radial-gradient(circle at 82% 80%, rgba(238, 92, 110, 0.06), transparent 60%),
    linear-gradient(180deg, var(--bg-elev-2) 0%, var(--bg-elev) 100%) !important;
  border-bottom: 1px solid var(--line) !important;
}
[data-theme="light"] .lt26-acheter .ae-eyebrow { color: var(--champagne-deep) !important; }
[data-theme="light"] .lt26-acheter .ae-title { color: var(--ink) !important; }
[data-theme="light"] .lt26-acheter .ae-title em { color: var(--champagne-deep) !important; }
[data-theme="light"] .lt26-acheter .ae-lead { color: var(--ink-soft) !important; }
[data-theme="light"] .lt26-acheter .ae-toolbar {
  background: rgba(255,255,255,0.75) !important;
  border: 1px solid var(--line) !important;
}
[data-theme="light"] .lt26-acheter .ae-sort-pill { color: var(--ink-soft); border-color: var(--line-strong); }
[data-theme="light"] .lt26-acheter .ae-sort-pill:hover { background: rgba(212,165,116,0.10); color: var(--ink); border-color: var(--champagne); }

/* BOUTIQUE: léger “skin” global (on garde bundle-vitrine.css) */
.lt26-boutique .shop-page {
  background: transparent;
  color: var(--ink);
}
.lt26-boutique .seller-hero {
  background:
    radial-gradient(circle at 22% 18%, rgba(212,165,116,0.16), transparent 55%),
    radial-gradient(circle at 82% 76%, rgba(238,92,110,0.10), transparent 60%),
    linear-gradient(180deg, rgba(14,27,38,0.96), rgba(14,27,38,0.78));
  border-bottom: 1px solid var(--line);
}
.lt26-boutique .seller-hero__bg {
  background-image:
    linear-gradient(180deg, rgba(14,27,38,0.20), rgba(14,27,38,0.86)),
    var(--seller-banner-url);
  background-size: cover;
  background-position: center;
  opacity: .55;
  filter: saturate(1.05) contrast(1.05);
}
.lt26-boutique .seller-hero__inner { max-width: 1240px; margin: 0 auto; padding: 120px 20px 38px; }
.lt26-boutique .seller-header { gap: 22px; }
.lt26-boutique .seller-info { gap: 18px; }
.lt26-boutique .seller-details h1 {
  font-family: var(--serif);
  font-weight: 400;
  letter-spacing: -0.02em;
  font-size: clamp(34px, 4.4vw, 60px);
  color: var(--ink);
  margin: 0;
  line-height: 1;
}
.lt26-boutique .seller-meta {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--ink-mute);
  gap: 12px;
}
.lt26-boutique .seller-welcome {
  margin-top: 12px;
  border: 1px solid var(--line);
  background: color-mix(in srgb, var(--bg-elev) 72%, transparent);
  color: var(--ink-soft);
  border-radius: 14px;
  padding: 12px 14px;
}
.lt26-boutique .seller-badges { margin-top: 10px; gap: 8px; flex-wrap: wrap; }
.lt26-boutique .seller-badge {
  border: 1px solid color-mix(in srgb, var(--champagne) 35%, var(--line));
  background: color-mix(in srgb, var(--champagne) 10%, transparent);
  color: var(--ink);
  border-radius: 999px;
  padding: 8px 12px;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .16em;
  text-transform: uppercase;
}
.lt26-boutique .seller-bio { margin-top: 14px; }
.lt26-boutique .seller-bio-text { color: var(--ink-soft); }
.lt26-boutique .seller-links { gap: 8px; flex-wrap: wrap; margin-top: 10px; }
.lt26-boutique .seller-link {
  display: inline-flex;
  align-items: center;
  padding: 10px 12px;
  border-radius: 999px;
  border: 1px solid var(--line-strong);
  background: transparent;
  color: var(--ink);
  text-decoration: none;
  transition: all 240ms;
  font-size: 12px;
}
.lt26-boutique .seller-link:hover { border-color: var(--champagne); color: var(--champagne); background: rgba(212,165,116,0.08); transform: translateY(-1px); }

.lt26-boutique .seller-stats {
  background: color-mix(in srgb, var(--bg-elev) 74%, transparent);
  border: 1px solid var(--line);
  border-radius: 16px;
  padding: 14px 16px;
}
.lt26-boutique .seller-stats .stat-number {
  font-family: var(--serif);
  font-size: 28px;
  color: var(--champagne);
  letter-spacing: -0.02em;
}
.lt26-boutique .seller-stats .stat-label {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--ink-mute);
}

.lt26-boutique .shop-content { max-width: 1240px; margin: 0 auto; padding: 26px 20px 90px; }
.lt26-boutique .shop-tab-title { font-family: var(--serif); font-weight: 400; letter-spacing: -0.02em; color: var(--ink); margin-top: 10px; }
.lt26-boutique .listing-card {
  background: color-mix(in srgb, var(--bg-elev) 76%, transparent);
  border: 1px solid var(--line);
  border-radius: 18px;
  overflow: hidden;
  transition: transform 240ms var(--ease-out-expo), border-color 240ms;
}
.lt26-boutique .listing-card:hover { transform: translateY(-3px); border-color: var(--line-strong); }
.lt26-boutique .listing-image { background: linear-gradient(180deg, rgba(212,165,116,0.08), rgba(0,0,0,0.28)); }
.lt26-boutique .listing-info h3 a { color: var(--ink); text-decoration: none; }
.lt26-boutique .listing-price { color: var(--champagne); font-family: var(--serif); }
.lt26-boutique .listing-description { color: var(--ink-soft); }

[data-theme="light"] .lt26-boutique .seller-hero {
  background:
    radial-gradient(circle at 18% 10%, rgba(212,165,116,0.18), transparent 55%),
    radial-gradient(circle at 80% 60%, rgba(238,92,110,0.06), transparent 62%),
    linear-gradient(180deg, var(--bg-elev-2) 0%, var(--bg-elev) 100%);
  border-bottom: 1px solid var(--line);
}
[data-theme="light"] .lt26-boutique .seller-hero__bg { opacity: .40; }
.lt26-boutique .shop-tabs .tab-btn {
  background: transparent;
  border: 1px solid var(--line);
  color: var(--ink-soft);
}
.lt26-boutique .shop-tabs .tab-btn.active,
.lt26-boutique .shop-tabs .tab-btn:hover {
  border-color: var(--champagne);
  color: var(--ink);
}

/* MARKETING: harmoniser les pages "lt-page" existantes quand LT26 est activé */
.lt26-marketing .lt-hero {
  background:
    radial-gradient(circle at 22% 18%, rgba(212,165,116,0.18), transparent 55%),
    radial-gradient(circle at 82% 76%, rgba(238,92,110,0.10), transparent 60%),
    linear-gradient(180deg, rgba(14,27,38,0.92), rgba(14,27,38,0.72));
  border-bottom: 1px solid var(--line);
}

/* =====================================================================
   LIVRAISON (guide legacy) — skin LT26
   ===================================================================== */
.lt26-livraison.guide-page.guide-page--home {
  background: transparent !important;
  color: var(--ink) !important;
}
.lt26-livraison .guide-hero {
  background:
    radial-gradient(circle at 22% 18%, rgba(212,165,116,0.16), transparent 55%),
    radial-gradient(circle at 82% 76%, rgba(238,92,110,0.10), transparent 60%),
    linear-gradient(180deg, rgba(14,27,38,0.96), rgba(14,27,38,0.78));
  border-bottom: 1px solid var(--line);
}
.lt26-livraison .guide-hero h1 {
  color: var(--ink);
  font-family: var(--serif);
  letter-spacing: -0.02em;
}
.lt26-livraison .guide-lead { color: var(--ink-soft); }
.lt26-livraison .guide-content { padding-bottom: 60px; }
.lt26-livraison .guide-card {
  background: var(--bg-elev);
  border: 1px solid var(--line);
  color: var(--ink);
  box-shadow: none;
}
.lt26-livraison .guide-card p,
.lt26-livraison .guide-card li { color: var(--ink-soft); }
.lt26-livraison .guide-card h2,
.lt26-livraison .guide-card h3 { color: var(--ink); font-family: var(--serif); font-weight: 400; }
.lt26-livraison .guide-h3-mt { margin-top: 14px; }
.lt26-livraison .guide-cta a { color: var(--champagne); }
.lt26-livraison .guide-back { color: var(--ink-soft); }

[data-theme="light"] .lt26-livraison .guide-hero {
  background:
    radial-gradient(circle at 18% 10%, rgba(212,165,116,0.18), transparent 55%),
    radial-gradient(circle at 80% 60%, rgba(238,92,110,0.06), transparent 62%),
    linear-gradient(180deg, var(--bg-elev-2) 0%, var(--bg-elev) 100%);
  border-bottom: 1px solid var(--line);
}
.lt26-marketing .lt-hero h1 { color: var(--ink); font-family: var(--serif); letter-spacing: -0.02em; }
.lt26-marketing .lt-lead { color: var(--ink-soft); }
.lt26-marketing .lt-card,
.lt26-marketing .ccm-kpi,
.lt26-marketing details {
  background: var(--bg-elev);
  border: 1px solid var(--line);
  color: var(--ink);
}
.lt26-marketing summary { color: var(--ink); }
.lt26-marketing .lt-subtitle,
.lt26-marketing .ccm-faq-body,
.lt26-marketing .lt-bullet-list { color: var(--ink-soft); }

/* VENDRE (marketing) — lisibilité/contraste */
.lt26-vendre .lt-hero {
  background:
    radial-gradient(circle at 22% 18%, rgba(212,165,116,0.16), transparent 55%),
    radial-gradient(circle at 82% 76%, rgba(238,92,110,0.10), transparent 60%),
    linear-gradient(180deg, rgba(14,27,38,0.96), rgba(14,27,38,0.78));
  border-bottom: 1px solid var(--line);
}
.lt26-vendre .lt-hero h1 {
  color: var(--ink);
  font-family: var(--serif);
  letter-spacing: -0.02em;
}
.lt26-vendre .lt-lead { color: var(--ink-soft); }
.lt26-vendre .lt-hero-tip {
  background: color-mix(in srgb, var(--bg-elev) 82%, transparent);
  border: 1px solid var(--line);
  color: var(--ink);
}
.lt26-vendre .lt-badge {
  background: color-mix(in srgb, var(--champagne) 22%, transparent);
  border: 1px solid color-mix(in srgb, var(--champagne) 55%, var(--line));
  color: var(--ink);
}

.lt26-vendre .lt-section-title { color: var(--ink); }
.lt26-vendre .lt-card,
.lt26-vendre .lt-card.lt-card--hover,
.lt26-vendre .lt-card.lt-card--accent {
  background: var(--bg-elev);
  border: 1px solid var(--line);
  color: var(--ink);
}
.lt26-vendre .lt-card p,
.lt26-vendre .lt-card li { color: var(--ink-soft); }
.lt26-vendre .lt-card h2,
.lt26-vendre .lt-card h3 { color: var(--ink); }
.lt26-vendre .lt-subtitle { color: var(--ink-soft); }
.lt26-vendre .lt-step-num {
  background: color-mix(in srgb, var(--champagne) 22%, transparent);
  border: 1px solid var(--line-strong);
  color: var(--ink);
}

.lt26-vendre .lt-instructions,
.lt26-vendre .lt-instructions li { color: var(--ink-soft); }
.lt26-vendre .lt-instructions strong { color: var(--ink); }

/* Mode soleil : le bandeau (lt-hero) doit changer de couleur */
[data-theme="light"] .lt26-marketing .lt-hero {
  background:
    radial-gradient(circle at 18% 10%, rgba(212,165,116,0.18), transparent 55%),
    radial-gradient(circle at 80% 60%, rgba(238,92,110,0.06), transparent 62%),
    linear-gradient(180deg, var(--bg-elev-2), var(--bg-elev));
  border-bottom: 1px solid var(--line);
}
[data-theme="light"] .lt26-marketing .lt-hero h1 { color: var(--ink); }
[data-theme="light"] .lt26-marketing .lt-lead { color: var(--ink-soft); }
[data-theme="light"] .lt26-marketing .lt-hero-tip {
  background: rgba(255,255,255,0.75);
  border: 1px solid var(--line);
  color: var(--ink);
}
[data-theme="light"] .lt26-marketing .lt-card,
[data-theme="light"] .lt26-marketing .ccm-kpi,
[data-theme="light"] .lt26-marketing details {
  background: rgba(255,255,255,0.85);
  border: 1px solid var(--line);
  color: var(--ink);
}
[data-theme="light"] .lt26-marketing .lt-card p,
[data-theme="light"] .lt26-marketing .lt-bullet-list,
[data-theme="light"] .lt26-marketing .lt-subtitle { color: var(--ink-soft); }

/* ============================================================
   GARDE-FOU GLOBAL — pages "lt-page" (marketing legacy)
   Empêche les incohérences soleil/lune sur les pages non migrées.
   ============================================================ */
body.lt26-grain .lt-page {
  background: transparent;
  color: var(--ink);
}
body.lt26-grain .lt-page .lt-hero {
  background:
    radial-gradient(circle at 22% 18%, rgba(212,165,116,0.18), transparent 55%),
    radial-gradient(circle at 82% 76%, rgba(238,92,110,0.10), transparent 60%),
    linear-gradient(180deg, rgba(14,27,38,0.92), rgba(14,27,38,0.72));
  border-bottom: 1px solid var(--line);
}
body.lt26-grain .lt-page .lt-hero h1 {
  color: var(--ink);
  font-family: var(--serif);
  letter-spacing: -0.02em;
}
body.lt26-grain .lt-page .lt-lead { color: var(--ink-soft); }
body.lt26-grain .lt-page .lt-hero-tip {
  background: color-mix(in srgb, var(--bg-elev) 82%, transparent);
  border: 1px solid var(--line);
  color: var(--ink);
}
body.lt26-grain .lt-page .lt-card,
body.lt26-grain .lt-page .lt-card.lt-card--hover,
body.lt26-grain .lt-page .lt-card.lt-card--accent,
body.lt26-grain .lt-page details,
body.lt26-grain .lt-page .ccm-kpi {
  background: var(--bg-elev);
  border: 1px solid var(--line);
  color: var(--ink);
}
body.lt26-grain .lt-page .lt-card p,
body.lt26-grain .lt-page .lt-card li,
body.lt26-grain .lt-page .lt-bullet-list,
body.lt26-grain .lt-page .lt-subtitle { color: var(--ink-soft); }
body.lt26-grain .lt-page .lt-section-title,
body.lt26-grain .lt-page .lt-card h2,
body.lt26-grain .lt-page .lt-card h3,
body.lt26-grain .lt-page summary { color: var(--ink); }

[data-theme="light"] body.lt26-grain .lt-page .lt-hero {
  background:
    radial-gradient(circle at 18% 10%, rgba(212,165,116,0.18), transparent 55%),
    radial-gradient(circle at 80% 60%, rgba(238,92,110,0.06), transparent 62%),
    linear-gradient(180deg, var(--bg-elev-2), var(--bg-elev));
  border-bottom: 1px solid var(--line);
}
[data-theme="light"] body.lt26-grain .lt-page .lt-hero-tip {
  background: rgba(255,255,255,0.75);
  border: 1px solid var(--line);
  color: var(--ink);
}
[data-theme="light"] body.lt26-grain .lt-page .lt-card,
[data-theme="light"] body.lt26-grain .lt-page details,
[data-theme="light"] body.lt26-grain .lt-page .ccm-kpi {
  background: rgba(255,255,255,0.85);
  border: 1px solid var(--line);
  color: var(--ink);
}

/* ============================================================
   COMPTE (menu colonne) — harmonisation LT26 sur toutes pages
   ============================================================ */
body.lt26-grain .compte-sidebar {
  /* évite de se cacher sous la nav fixed LT26 */
  top: calc(var(--lt26-nav-offset, 84px) + 18px);
}

body.lt26-grain .compte-nav {
  background:
    radial-gradient(120% 80% at 50% 0%, rgba(212,165,116,0.14), transparent 55%),
    linear-gradient(180deg, rgba(26,47,61,0.86), rgba(20,37,49,0.72));
  border: 1px solid var(--line);
  border-radius: 18px;
  padding: 14px;
  box-shadow: var(--shadow-soft);
  backdrop-filter: blur(10px);
}

body.lt26-grain .compte-nav-item {
  border-radius: 14px;
  color: var(--ink-soft);
  font-family: var(--sans);
  transition: background 220ms var(--ease-out-expo), color 220ms var(--ease-out-expo), transform 220ms var(--ease-out-expo);
}

body.lt26-grain .compte-nav-item i {
  color: color-mix(in srgb, var(--ink-soft) 80%, transparent);
}

body.lt26-grain .compte-nav-item:hover {
  background: rgba(255, 255, 255, 0.06);
  color: var(--ink);
  transform: translateY(-1px);
}

body.lt26-grain .compte-nav-item:hover i {
  color: var(--champagne-soft);
}

body.lt26-grain .compte-nav-item.active {
  background:
    linear-gradient(135deg, rgba(212,165,116,0.20), rgba(232,201,154,0.08));
  color: var(--ink);
  border: 1px solid rgba(232,201,154,0.18);
}

body.lt26-grain .compte-nav-item.active i {
  color: var(--champagne-soft);
}

body.lt26-grain .compte-nav-item.active::before {
  content: "";
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: var(--champagne);
  box-shadow: 0 0 0 4px rgba(212,165,116,0.18);
  display: inline-block;
  margin-right: 2px;
}

@media (max-width: 900px) {
  body.lt26-grain .compte-nav {
    border-radius: 16px;
    padding: 10px;
  }
  body.lt26-grain .compte-nav-item {
    border-radius: 12px;
  }
  body.lt26-grain .compte-nav-item.active::before {
    width: 8px;
    height: 8px;
    box-shadow: 0 0 0 3px rgba(212,165,116,0.18);
  }
}

/* Actualités (evenements.php) — lisibilité + styles bundle-misc-pages */
.lt26-actualites .evenements-news-intro,
.lt26-actualites .evenements-news-cache-notice,
.lt26-actualites .evenements-sources-billet,
.lt26-actualites .evenements-sources-billet p {
  color: var(--ink-soft);
}
.lt26-actualites .evenements-sources-billet {
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: 14px;
}
.lt26-actualites .news-card {
  background: var(--bg-elev);
  border: 1px solid var(--line);
  color: var(--ink);
}
.lt26-actualites .news-card p { color: var(--ink-soft); }
.lt26-actualites .news-card a { color: inherit; }

/* Bandeau "Actualités" : même navy que le haut */
.lt26-actualites .lt-hero {
  background:
    radial-gradient(80% 60% at 50% -10%, rgba(212,165,116,0.14), transparent 60%),
    radial-gradient(50% 60% at 18% 30%, rgba(212,165,116,0.06), transparent 70%),
    radial-gradient(50% 60% at 82% 30%, rgba(212,165,116,0.06), transparent 70%),
    linear-gradient(180deg, var(--bg) 0%, var(--bg-soft) 100%) !important;
  border-bottom: 1px solid var(--line) !important;
}

/* Actualité détail : remplacer style inline interdit CSP */
.forum-post-content--full { width: 100%; }

/* =====================================================================
   RESPONSIVE MOBILE — AMÉLIORATIONS GLOBALES (consolidé)
   ===================================================================== */

/* Tablet portrait — 900px */
@media (max-width: 900px) {
  /* Grids 3-cols → 2 cols */
  .lt26-hero__stats { grid-template-columns: repeat(2, 1fr) !important; gap: 24px; }
  .fp__trust { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .lt26-pillars__grid { grid-template-columns: repeat(2, 1fr) !important; }
  .lt26-featured__grid { grid-template-columns: repeat(2, 1fr) !important; gap: 16px; }

  /* Grids 4+ cols → 2 cols */
  .vit-premium { grid-template-columns: repeat(2, minmax(0, 1fr)) !important; gap: 14px; }
  .carte-listing__grid { grid-template-columns: repeat(2, 1fr) !important; gap: 12px; }
}

/* Mobile landscape — 720px */
@media (max-width: 720px) {
  /* Container nav et fp__ alignés */
  .lt26-nav__inner { padding: 0 16px; }

  /* Crumbs : taille réduite + scroll horizontal si trop long */
  .fp__crumbs {
    flex-wrap: nowrap;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    padding: 12px 16px;
  }
  .fp__crumbs::-webkit-scrollbar { display: none; }
  .fp__crumb-link, .fp__crumb-cur { font-size: 10px; white-space: nowrap; }

  /* Stage : aspect-ratio plus carré pour gagner de la hauteur */
  .fp__stage { aspect-ratio: 1 / 1; border-radius: 16px; }
  .fp__stage-grid { inset: 10px; border-radius: 12px; }
  .fp__thumb { flex-basis: 84px; padding: 8px 6px; }

  /* Stage bar : actions en colonne */
  .fp__stage-bar-action { padding: 6px 9px; font-size: 9px; }
  .fp__stage-bar-meta { font-size: 8.5px; }

  /* Info panel typography */
  .fp__title { font-size: clamp(40px, 11vw, 64px) !important; line-height: 0.95; letter-spacing: -0.02em; }
  .fp__sub { font-size: 15px; }
  .fp__price { font-size: 44px !important; }
  .fp__brand { font-size: 10px; }
  .fp__eyebrow { gap: 8px; }
  .fp__watcher { font-size: 9px; }

  /* Specs : 2 cols → 1 col sur small mobile */
  .fp__specs { grid-template-columns: repeat(2, 1fr); }
  .fp__spec { padding: 12px 14px; }
  .fp__spec .fp__spec-v { font-size: 15px; }

  /* CTAs full-width sur mobile */
  .fp__ctas { gap: 8px; }
  .fp__cta-main { width: 100%; flex: 1 1 100%; min-width: 0; padding: 16px; }
  .fp__icon-btn { width: 46px; height: 46px; }

  /* Trust cards en 1 col sur petit mobile */
  .fp__trust { grid-template-columns: 1fr; gap: 8px; }

  /* Tabs : padding réduit + scroll horizontal natif */
  .fp__tabs { padding: 24px 16px 12px; }
  .fp__tabs-rail { gap: 0; padding-top: 6px; padding-bottom: 6px; }
  .fp__tab { padding: 10px 14px; font-size: 13px; }

  /* Panels : 1 col, description en premier, dim table en dessous */
  .fp__panel { gap: 28px; }
  .fp__lede { font-size: 22px !important; line-height: 1.25; margin: 0 0 16px; }
  .fp__body { font-size: 14px; max-width: 100%; }
  .fp__features { margin-top: 18px; }
  .fp__feature { grid-template-columns: 30px 1fr; gap: 10px; padding: 10px 0; }
  .fp__feature-text { font-size: 13px; }
  .fp__dim { padding: 14px 16px; border-radius: 12px; }
  .fp__dim-v { font-size: 14px; }

  /* More grid : 2 cols mobile */
  .fp__more { padding: 6px 16px 60px; }
  .fp__more-grid { grid-template-columns: repeat(2, 1fr); gap: 10px; }
  .fp__more-card { border-radius: 12px; }
  .fp__more-meta { padding: 10px 12px 12px; }
  .fp__more-name { font-size: 15px; }
  .fp__more-price { font-size: 15px; }
  .fp__more-title { font-size: 28px !important; }

  /* Hero typography mobile */
  .lt26-hero { padding: 80px 16px 40px !important; min-height: auto !important; }
  .lt26-hero__title, .lt26-hero__title--claude { font-size: clamp(48px, 13vw, 80px) !important; line-height: 0.92; }
  .lt26-hero__copy { gap: 16px; padding: 0 4px; }
  .lt26-hero__cta { gap: 14px; }
  .lt26-hero__metric-num { font-size: 16px; }
  .lt26-hero__metric-text { font-size: 11px; }
  .lt26-hero__vitrine { height: 240px !important; margin-top: 24px !important; }

  /* Pillars / Featured 1 col sur mobile */
  .lt26-pillars__grid, .lt26-featured__grid { grid-template-columns: 1fr !important; gap: 14px; }
  .lt26-pillars { padding: 60px 16px !important; }
  .lt26-featured { padding: 50px 16px !important; }
  .lt26-section-title { font-size: clamp(28px, 7vw, 40px) !important; margin-bottom: 24px; }

  /* Carte listing 1 col */
  .carte-listing__grid { grid-template-columns: 1fr !important; }

  /* Vitrine premium 1 col */
  .vit-premium { grid-template-columns: 1fr !important; }

  /* Forms / inputs lisibles tactile */
  .form-group input,
  .form-group textarea,
  .form-group select { font-size: 16px; padding: 12px 14px; }
  .modal-content { padding: 1.25rem; max-width: calc(100vw - 24px); }

  /* Boutons généraux : taille tactile */
  .lt26-btn, .annonce-detail-btn { min-height: 44px; padding: 12px 18px; }
}

/* Small mobile — 480px */
@media (max-width: 480px) {
  /* Hero vitrine : seulement la pièce centrale, props plus serrée */
  .lt26-hero__slot--front-l,
  .lt26-hero__slot--front-r,
  .lt26-hero__slot--back-l,
  .lt26-hero__slot--back-r { display: none !important; }
  .lt26-hero__slot--center { transform: scale(1) !important; }
  .lt26-hero__vitrine { height: 200px !important; max-width: 280px; }
  .lt26-hero__shelf { left: 8%; right: 8%; }
  .lt26-piece { max-width: 160px !important; }
  .lt26-piece__art { height: 200px !important; }
  /* Ribbon : police + speed réduits */
  .lt26-hero__ribbon { height: 22px; top: 70px; }
  .lt26-ribbon__item { font-size: 8.5px; padding: 0 12px; gap: 18px; }

  /* Specs en 1 col sur très petit écran */
  .fp__specs { grid-template-columns: 1fr; }

  /* Stage encore plus compact */
  .fp__stage { aspect-ratio: 4 / 5; }
  .fp__stage-meta { bottom: 10px; left: 10px; right: 10px; font-size: 8.5px; }
  .fp__stage-zoom { font-size: 9px; padding: 3px 6px; }

  /* Title encore plus contenu */
  .fp__title { font-size: clamp(34px, 11vw, 48px) !important; }
  .fp__price { font-size: 38px !important; }

  /* More grid : 1 col */
  .fp__more-grid { grid-template-columns: 1fr; }

  /* Tabs scroll horizontal forcé */
  .fp__tabs-rail { overflow-x: auto; flex-wrap: nowrap; }
  .fp__tab { flex-shrink: 0; }

  /* Stats hero 1 col */
  .lt26-hero__stats { grid-template-columns: 1fr !important; }

  /* Réduire espacements globaux */
  .lt26-pillars, .lt26-featured { padding: 48px 14px !important; }
  .fp__main { padding: 16px 12px 32px; }
  .fp__crumbs { padding: 10px 12px; }
}

/* Toggle filtres ma-vitrine : caché par défaut au-dessus de 480px */
.vit-premium__meta-wrap { display: contents; }
.vit-premium__meta-toggle { display: none; }

@media (max-width: 480px) {
  .vit-premium__meta-wrap {
    display: flex; flex-direction: column;
    width: 100%; gap: 0;
  }
  .vit-premium__meta-toggle {
    display: flex; align-items: center; justify-content: space-between;
    width: 100%;
    background: color-mix(in srgb, var(--bg-elev) 60%, transparent);
    border: 1px solid var(--line);
    border-radius: 10px;
    padding: 10px 14px;
    color: var(--ink);
    font-family: var(--mono);
    font-size: 11px;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    cursor: pointer;
    transition: border-color 200ms, background 200ms;
  }
  .vit-premium__meta-toggle:hover,
  .vit-premium__meta-toggle.is-open {
    border-color: var(--champagne);
    background: color-mix(in srgb, var(--bg-elev) 80%, transparent);
  }
  .vit-premium__meta-chevron {
    color: var(--champagne);
    transition: transform 240ms var(--ease-out-expo, ease);
    font-size: 12px;
  }
  .vit-premium__meta-toggle.is-open .vit-premium__meta-chevron { transform: rotate(180deg); }
  .vit-premium__meta {
    max-height: 0; overflow: hidden;
    margin: 0; padding: 0;
    transition: max-height 320ms var(--ease-out-expo, ease), padding 200ms;
    flex-wrap: wrap;
    border-left: 1px solid var(--line);
    border-right: 1px solid var(--line);
    border-bottom: 1px solid var(--line);
    border-radius: 0 0 10px 10px;
    border-top: 0;
    margin-top: -1px;
  }
  .vit-premium__meta.is-open {
    max-height: 200px;
    padding: 12px 14px;
  }

  /* Vitrine grid : 2 cols max, slots plus carrés */
  .vitrine-grid.shop-grid-cols-3,
  .vitrine-grid.shop-grid-cols-4,
  .vitrine-grid.shop-grid-cols-5,
  .vitrine-grid.shop-grid-cols-6 {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 10px !important;
  }
  .vitrine-grid .slot {
    aspect-ratio: 3 / 4 !important;
    min-height: 0 !important;
  }
  .vitrine-grid .slot--empty::after {
    font-size: 28px;
  }

  /* Toolbar contrôles vitrine : compacte, wrap propre */
  .vit-premium__controls {
    flex-direction: column;
    align-items: stretch !important;
    gap: 10px !important;
  }
  .vit-premium__controls-left,
  .vit-premium__controls-right {
    width: 100%;
    flex-wrap: wrap !important;
    justify-content: center !important;
    gap: 6px !important;
  }
  .vit-premium__ctl {
    flex: 1 1 calc(50% - 4px) !important;
    min-width: 0 !important;
    padding: 10px 8px !important;
    font-size: 11px !important;
  }
  .vit-premium__ctl-ic { font-size: 13px !important; }

  /* Cards listing acheter : meta + actions plus serrées */
  .listing-card-acheter-meta { font-size: 11px; }
  .listing-card-acheter-direct { padding: 10px 14px; font-size: 12px; }
}

/* Touch devices : retirer effets hover qui restent collés */
@media (hover: none) and (pointer: coarse) {
  .fp__more-card:hover { transform: none; }
  .lt26-piece:hover { transform: none; }
  .fp__icon-btn:hover { transform: none; }
}

/* Préviens overflow horizontal global */
html, body { overflow-x: hidden; }
img, video { max-width: 100%; height: auto; }
