/* TerraLED — polices self-hostées (latin + latin-ext) */
@font-face{font-family:'Fraunces';font-style:italic;font-weight:600;font-display:swap;src:url('../fonts/fraunces-600-italic-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;}
@font-face{font-family:'Fraunces';font-style:italic;font-weight:600;font-display:swap;src:url('../fonts/fraunces-600-italic.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;}
@font-face{font-family:'Fraunces';font-style:normal;font-weight:500;font-display:swap;src:url('../fonts/fraunces-500-normal-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;}
@font-face{font-family:'Fraunces';font-style:normal;font-weight:500;font-display:swap;src:url('../fonts/fraunces-500-normal.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;}
@font-face{font-family:'Fraunces';font-style:normal;font-weight:600;font-display:swap;src:url('../fonts/fraunces-600-normal-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;}
@font-face{font-family:'Fraunces';font-style:normal;font-weight:600;font-display:swap;src:url('../fonts/fraunces-600-normal.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;}
@font-face{font-family:'Fraunces';font-style:normal;font-weight:700;font-display:swap;src:url('../fonts/fraunces-700-normal-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;}
@font-face{font-family:'Fraunces';font-style:normal;font-weight:700;font-display:swap;src:url('../fonts/fraunces-700-normal.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;}
@font-face{font-family:'Lato';font-style:normal;font-weight:400;font-display:swap;src:url('../fonts/lato-400-normal-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;}
@font-face{font-family:'Lato';font-style:normal;font-weight:400;font-display:swap;src:url('../fonts/lato-400-normal.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;}
@font-face{font-family:'Lato';font-style:normal;font-weight:700;font-display:swap;src:url('../fonts/lato-700-normal-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;}
@font-face{font-family:'Lato';font-style:normal;font-weight:700;font-display:swap;src:url('../fonts/lato-700-normal.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;}
@font-face{font-family:'Lato';font-style:normal;font-weight:900;font-display:swap;src:url('../fonts/lato-900-normal-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;}
@font-face{font-family:'Lato';font-style:normal;font-weight:900;font-display:swap;src:url('../fonts/lato-900-normal.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;}
@font-face{font-family:'IBM Plex Mono';font-style:normal;font-weight:400;font-display:swap;src:url('../fonts/ibm-plex-mono-400-normal-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;}
@font-face{font-family:'IBM Plex Mono';font-style:normal;font-weight:400;font-display:swap;src:url('../fonts/ibm-plex-mono-400-normal.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;}
@font-face{font-family:'IBM Plex Mono';font-style:normal;font-weight:500;font-display:swap;src:url('../fonts/ibm-plex-mono-500-normal-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;}
@font-face{font-family:'IBM Plex Mono';font-style:normal;font-weight:500;font-display:swap;src:url('../fonts/ibm-plex-mono-500-normal.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;}
@font-face{font-family:'IBM Plex Mono';font-style:normal;font-weight:600;font-display:swap;src:url('../fonts/ibm-plex-mono-600-normal-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;}
@font-face{font-family:'IBM Plex Mono';font-style:normal;font-weight:600;font-display:swap;src:url('../fonts/ibm-plex-mono-600-normal.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;}

/* ===== TerraLED — Design tokens "Spectre Vivant" ===== */
:root{
  /* primitives marque */
  --tl-green:#176035; --tl-green-600:#1c7a42; --tl-forest:#0a1f13; --tl-forest-2:#10291a;
  --tl-copper:#b56a00; --tl-copper-text:#8f5500; --tl-amber:#e0951f; --tl-gold:#f4bd5e;
  --tl-cream:#f6f1e7; --tl-cream-2:#efe8d8; --tl-grey:#f2f2f2;
  --tl-ink:#15201a; --tl-ink-2:#2c382f; --tl-muted:#5f6d62; --tl-line:#e6dfd0; --tl-white:#fff;
  /* SIGNATURE spectrale (bi-spectre LED) */
  --tl-spectral:linear-gradient(90deg,#2563ff 0%,#7b3ff2 26%,#d61f9b 52%,#ff5a3c 78%,#ffb02e 100%);
  /* sémantique */
  --tl-bg:#fff; --tl-surface:#fff; --tl-text:var(--tl-ink); --tl-text-soft:var(--tl-muted);
  --tl-border:var(--tl-line); --tl-primary:var(--tl-green); --tl-accent:var(--tl-copper);
  --tl-success:#1c7a42; --tl-warning:#b5710a; --tl-danger:#c2412f; --tl-info:#2563ff;
  --tl-instock:#1c7a42; --tl-lowstock:#b5710a; --tl-outstock:#c2412f; --tl-promo:var(--tl-copper);
  /* typographie */
  --tl-font-display:'Fraunces',Georgia,serif; --tl-font-body:'Lato',system-ui,sans-serif; --tl-font-mono:'IBM Plex Mono',ui-monospace,monospace;
  /* espacement base 8px */
  --tl-sp-1:4px; --tl-sp-2:8px; --tl-sp-3:12px; --tl-sp-4:16px; --tl-sp-5:24px; --tl-sp-6:32px; --tl-sp-7:48px; --tl-sp-8:64px; --tl-sp-9:96px;
  /* rayons / ombres / z-index / motion */
  --tl-r-sm:8px; --tl-r:12px; --tl-r-lg:18px; --tl-r-xl:26px; --tl-r-pill:999px;
  --tl-shadow-sm:0 10px 24px -16px rgba(10,31,19,.35); --tl-shadow:0 22px 48px -26px rgba(10,31,19,.5);
  --tl-z-base:1; --tl-z-sticky:50; --tl-z-header:60; --tl-z-overlay:100; --tl-z-modal:110; --tl-z-toast:120;
  --tl-ease:cubic-bezier(.4,0,.2,1); --tl-dur:.25s;
}
[data-tl-theme="dark"]{ --tl-bg:var(--tl-forest); --tl-surface:var(--tl-forest-2); --tl-text:#eaf3ec; --tl-text-soft:#9fb3a4; --tl-border:rgba(255,255,255,.14); }
[data-tl-theme="cream"]{ --tl-bg:var(--tl-cream); --tl-surface:#fff; --tl-text:var(--tl-ink); --tl-border:var(--tl-cream-2); }

/* ===== TerraLED — Base : reset, typographie, signature, helpers ===== */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{margin:0;font-family:var(--tl-font-body);color:var(--tl-text);background:var(--tl-bg);line-height:1.65;-webkit-font-smoothing:antialiased}
img,svg,video{display:block;max-width:100%}
a{color:var(--tl-primary);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3,h4{font-family:var(--tl-font-display);font-optical-sizing:auto;line-height:1.1;letter-spacing:-.015em;font-weight:600;color:var(--tl-text);margin:0 0 .4em}
p{margin:0 0 1em}
:where(button,input,select,textarea){font:inherit;color:inherit}
:focus-visible{outline:3px solid var(--tl-gold);outline-offset:2px;border-radius:4px}
@media (prefers-reduced-motion: reduce){*{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}}

/* lien d'évitement */
.tl-skip{position:absolute;left:-9999px;top:0;z-index:200;background:var(--tl-gold);color:#3a2600;font-family:var(--tl-font-mono);font-size:12px;padding:11px 18px;border-radius:0 0 9px 0;font-weight:600}
.tl-skip:focus{left:0}

/* libellé technique mono + puce spectrale */
.tl-tag{display:inline-flex;align-items:center;gap:10px;font-family:var(--tl-font-mono);font-weight:500;font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--tl-copper-text)}
.tl-tag::before{content:"";width:28px;height:6px;border-radius:3px;background:var(--tl-spectral)}
.tl-dark .tl-tag{color:var(--tl-gold)}

/* SIGNATURE : trait spectral */
.tl-spectral-line{height:6px;width:64px;border-radius:4px;background:var(--tl-spectral);box-shadow:0 0 16px rgba(214,31,155,.35);border:0;margin:0}
.tl-u-spectral{position:relative;white-space:nowrap}
.tl-u-spectral::after{content:"";position:absolute;left:0;right:0;bottom:-.12em;height:6px;border-radius:4px;background:var(--tl-spectral);box-shadow:0 0 16px rgba(214,31,155,.4)}

/* cadre HUD à crochets dorés */
.tl-hud{position:relative}
.tl-hud::before,.tl-hud::after{content:"";position:absolute;width:26px;height:26px;pointer-events:none;z-index:2}
.tl-hud::before{top:-7px;left:-7px;border-top:2px solid var(--tl-gold);border-left:2px solid var(--tl-gold)}
.tl-hud::after{bottom:-7px;right:-7px;border-bottom:2px solid var(--tl-gold);border-right:2px solid var(--tl-gold)}

/* fonds sombres : blueprint + grain */
.tl-dark{background:var(--tl-forest);color:#eaf3ec;position:relative;isolation:isolate}
.tl-blueprint{position:relative}
.tl-blueprint::before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px);background-size:46px 46px;pointer-events:none;z-index:0;mask-image:radial-gradient(120% 100% at 50% 0%,#000 40%,transparent 90%)}

/* layout */
.tl-container{max-width:1240px;margin:0 auto;padding:0 24px}

/* ===== styleguide (page de démonstration uniquement, NON livrée au thème) ===== */
.sg-wrap{max-width:1120px;margin:0 auto;padding:24px 24px 96px}
.sg-toolbar{position:sticky;top:0;z-index:50;display:flex;gap:10px;align-items:center;flex-wrap:wrap;background:var(--tl-surface);border-bottom:1px solid var(--tl-border);padding:12px 0;margin-bottom:24px}
.sg-head h1{font-size:34px;margin:24px 0 6px}
.sg-block{margin:0 0 36px;padding:28px;border:1px solid var(--tl-border);border-radius:var(--tl-r-lg);background:var(--tl-surface)}
.sg-block>h2{font-size:21px;margin:0 0 18px;padding-bottom:10px;border-bottom:1px solid var(--tl-border)}
.sg-row{display:flex;flex-wrap:wrap;gap:16px;align-items:center;margin-bottom:16px}
.sg-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:18px}
.sg-swatch{height:72px;border-radius:10px;border:1px solid var(--tl-border);display:flex;align-items:flex-end;padding:7px;font:600 11px/1.2 var(--tl-font-mono);color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.5)}
.sg-note{font-family:var(--tl-font-mono);font-size:11px;color:var(--tl-text-soft);letter-spacing:.04em}

/* buttons */
/* ==========================================================================
   TerraLED · "Spectre Vivant" — Famille de composants : Boutons & liens
   CSS pur, tokens --tl-* uniquement, BEM préfixé .tl-
   ========================================================================== */

/* --- Base commune ------------------------------------------------------- */
.tl-btn{
  /* le bouton porte ses propres canaux de couleur, surchargés par variante */
  --_bg: transparent;
  --_fg: var(--tl-text);
  --_bd: transparent;
  --_ring: var(--tl-ink);              /* couleur de l'anneau de focus */
  --_shadow: none;
  --_pad-y: var(--tl-sp-3);
  --_pad-x: var(--tl-sp-5);
  --_fs: 14px;
  --_min: 44px;                        /* cible tactile minimale */

  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--tl-sp-2);
  min-height: var(--_min);
  padding: var(--_pad-y) var(--_pad-x);
  font-family: var(--tl-font-mono);
  font-weight: 600;
  font-size: var(--_fs);
  line-height: 1.1;
  letter-spacing: .06em;
  text-transform: uppercase;
  text-decoration: none;
  text-align: center;
  white-space: nowrap;
  color: var(--_fg);
  background: var(--_bg);
  border: 1.5px solid var(--_bd);
  border-radius: var(--tl-r-sm);
  box-shadow: var(--_shadow);
  cursor: pointer;
  -webkit-appearance: none;
  appearance: none;
  user-select: none;
  transition:
    transform var(--tl-dur) var(--tl-ease),
    box-shadow var(--tl-dur) var(--tl-ease),
    background var(--tl-dur) var(--tl-ease),
    border-color var(--tl-dur) var(--tl-ease),
    color var(--tl-dur) var(--tl-ease);
}
.tl-btn__icon{
  display: inline-flex;
  flex: 0 0 auto;
  width: 1.25em;
  height: 1.25em;
}
.tl-btn__icon svg{ width: 100%; height: 100%; display: block; }
.tl-btn__label{ display: inline-block; }

/* --- Focus visible : anneau toujours présent, >=3:1, jamais le seul trait
   spectral. Géré au niveau du composant pour rester homogène. ------------- */
.tl-btn:focus-visible{
  outline: 3px solid var(--_ring);
  outline-offset: 3px;
}
/* Repli navigateurs sans :focus-visible */
.tl-btn:focus:not(:focus-visible){ outline: none; }

/* --- État actif / hover génériques (lift) ------------------------------- */
.tl-btn:hover{ transform: translateY(-2px); }
.tl-btn:active{ transform: translateY(0); }

/* ==========================================================================
   VARIANTES
   ========================================================================== */

/* Primaire — cuivre, texte clair lisible (blanc sur #b56a00 ~ AA pour gros
   texte mono gras). Anneau cuivre-foncé pour contraste sur fonds clairs. --- */
.tl-btn--primary{
  --_bg: var(--tl-copper);
  --_fg: var(--tl-white);
  --_bd: var(--tl-copper);
  --_ring: var(--tl-copper-text);
  --_shadow: var(--tl-shadow-sm);
}
.tl-btn--primary:hover{
  --_bg: var(--tl-copper-text);
  --_bd: var(--tl-copper-text);
  box-shadow: var(--tl-shadow);
}
.tl-btn--primary:active{ --_bg: var(--tl-copper-text); box-shadow: var(--tl-shadow-sm); }

/* CTA ambre/gold — décor brillant : impose texte vert forêt foncé (règle
   stricte ambre/gold). À réserver aux fonds sombres ou gros texte. -------- */
.tl-btn--amber{
  --_bg: var(--tl-amber);
  --_fg: var(--tl-forest);
  --_bd: var(--tl-amber);
  --_ring: var(--tl-forest);
  --_shadow: var(--tl-shadow-sm);
}
.tl-btn--amber:hover{ --_bg: var(--tl-gold); --_bd: var(--tl-gold); }
.tl-btn--amber:active{ --_bg: var(--tl-amber); }

/* Vert — primaire alternatif, texte blanc (AA sur #176035). -------------- */
.tl-btn--green{
  --_bg: var(--tl-green);
  --_fg: var(--tl-white);
  --_bd: var(--tl-green);
  --_ring: var(--tl-forest);
}
.tl-btn--green:hover{ --_bg: var(--tl-green-600); --_bd: var(--tl-green-600); }
.tl-btn--green:active{ --_bg: var(--tl-green); }

/* Sombre — forêt, texte clair. Anneau gold visible sur le sombre. -------- */
.tl-btn--dark{
  --_bg: var(--tl-forest);
  --_fg: var(--tl-cream);
  --_bd: rgba(255,255,255,.16);
  --_ring: var(--tl-gold);
}
.tl-btn--dark:hover{ --_bg: var(--tl-forest-2); --_bd: rgba(255,255,255,.4); }
.tl-btn--dark:active{ --_bg: var(--tl-forest); }

/* Ghost — pensé pour fonds sombres : texte clair, bordure translucide.
   Anneau gold pour rester >=3:1 sur le sombre. --------------------------- */
.tl-btn--ghost{
  --_bg: transparent;
  --_fg: var(--tl-cream);
  --_bd: rgba(255,255,255,.45);
  --_ring: var(--tl-gold);
}
.tl-btn--ghost:hover{ --_bg: rgba(255,255,255,.1); --_bd: var(--tl-white); }
.tl-btn--ghost:active{ --_bg: rgba(255,255,255,.06); }

/* Outline — sur fonds clairs : surface blanche, texte vert foncé lisible. - */
.tl-btn--outline{
  --_bg: var(--tl-surface);
  --_fg: var(--tl-green);
  --_bd: var(--tl-border);
  --_ring: var(--tl-green);
}
.tl-btn--outline:hover{ --_bg: var(--tl-surface); --_bd: var(--tl-green); }
.tl-btn--outline:active{ --_bg: var(--tl-grey); }

/* ==========================================================================
   BOUTON À SOULIGNEMENT SPECTRAL ANIMÉ
   Le trait spectral est DÉCORATIF (porté par ::after, aria-hidden côté HTML
   via un <span> dédié). Il n'est JAMAIS le seul porteur de sens ni le seul
   indicateur de focus : le focus reste l'anneau --_ring.
   ========================================================================== */
.tl-btn--spectral{
  --_bg: var(--tl-forest);
  --_fg: var(--tl-cream);
  --_bd: rgba(255,255,255,.16);
  --_ring: var(--tl-gold);
  overflow: hidden;
}
/* la barre spectrale, posée en bas du bouton */
.tl-btn__spark{
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 3px;
  background: var(--tl-spectral);
  transform: scaleX(.34);
  transform-origin: left center;
  transition: transform var(--tl-dur) var(--tl-ease);
  pointer-events: none;
}
.tl-btn--spectral:hover{ --_bg: var(--tl-forest-2); --_bd: rgba(255,255,255,.4); }
.tl-btn--spectral:hover .tl-btn__spark,
.tl-btn--spectral:focus-visible .tl-btn__spark{ transform: scaleX(1); }

/* Variante claire du spectral, si posé sur surface claire */
.tl-btn--spectral.tl-btn--on-light{
  --_bg: var(--tl-surface);
  --_fg: var(--tl-green);
  --_bd: var(--tl-border);
  --_ring: var(--tl-green);
}

/* ==========================================================================
   LIEN-BOUTON (apparence lien, comportement bouton) + lien spectral
   ========================================================================== */
.tl-link{
  --_ring: var(--tl-green);
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: var(--tl-sp-1);
  min-height: var(--_min, 44px);
  padding: var(--tl-sp-1) 2px;
  font-family: var(--tl-font-mono);
  font-weight: 600;
  font-size: 13px;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--tl-copper-text);          /* lien cuivre lisible (règle) */
  background: none;
  border: 0;
  cursor: pointer;
  text-decoration: none;
}
.tl-link__text{ text-decoration: underline; text-underline-offset: .22em; text-decoration-thickness: 1.5px; }
.tl-link:hover .tl-link__text{ text-decoration-color: var(--tl-copper); }
.tl-link:focus-visible{ outline: 3px solid var(--_ring); outline-offset: 3px; border-radius: var(--tl-r-sm); }
.tl-link:focus:not(:focus-visible){ outline: none; }
.tl-link .tl-btn__icon{ width: 1.1em; height: 1.1em; }

/* lien à soulignement spectral animé (décor) : un vrai souligné est conservé
   en repli sémantique, le trait spectral vient par-dessus. ---------------- */
.tl-link--spectral .tl-link__text{ text-decoration: none; }
.tl-link--spectral .tl-link__spark{
  position: absolute;
  left: 2px;
  right: 2px;
  bottom: 0;
  height: 3px;
  border-radius: 2px;
  background: var(--tl-spectral);
  transform: scaleX(0);
  transform-origin: left center;
  transition: transform var(--tl-dur) var(--tl-ease);
  pointer-events: none;
}
/* repli : un trait neutre toujours visible pour signifier "lien" */
.tl-link--spectral .tl-link__text{
  text-decoration: underline;
  text-decoration-color: currentColor;
  text-underline-offset: .28em;
  text-decoration-thickness: 1.5px;
}
.tl-link--spectral:hover .tl-link__spark,
.tl-link--spectral:focus-visible .tl-link__spark{ transform: scaleX(1); }
/* sur fond sombre */
.tl-link--on-dark{ color: var(--tl-gold); --_ring: var(--tl-gold); }

/* ==========================================================================
   MODIFICATEURS TRANSVERSAUX
   ========================================================================== */

/* Tailles */
.tl-btn--sm{ --_pad-y: var(--tl-sp-2); --_pad-x: var(--tl-sp-4); --_fs: 12px; --_min: 36px; }
.tl-btn--lg{ --_pad-y: var(--tl-sp-4); --_pad-x: var(--tl-sp-6); --_fs: 15px; --_min: 52px; }
/* NB : sm < 44px : à réserver aux actions secondaires non critiques. */

/* Pleine largeur */
.tl-btn--block{ display: flex; width: 100%; }

/* Forme pilule (option esthétique) */
.tl-btn--pill{ border-radius: var(--tl-r-pill); }

/* Icône seule : on garde un carré >=44px et un label accessible via aria. */
.tl-btn--icon{ --_pad-x: var(--tl-sp-3); aspect-ratio: 1 / 1; gap: 0; }

/* ==========================================================================
   ÉTATS
   ========================================================================== */

/* Désactivé — couvre [disabled] (vrai bouton) et [aria-disabled] (lien) */
.tl-btn[disabled],
.tl-btn[aria-disabled="true"],
.tl-link[aria-disabled="true"]{
  cursor: not-allowed;
  opacity: .55;
  box-shadow: none;
  transform: none;
  /* neutralise le hover */
  pointer-events: none;
}
/* Pour un lien <a aria-disabled>, pointer-events:none empêche l'activation ;
   penser aussi à retirer href / ajouter tabindex=-1 côté HTML. */

/* Chargement — déclenché par .tl-btn--loading + aria-busy="true" en HTML.
   Le label reste dans le flux pour les lecteurs d'écran, mais visuellement
   masqué ; le spinner décoratif prend sa place. -------------------------- */
.tl-btn--loading{
  cursor: progress;
  pointer-events: none;
  color: transparent !important;           /* masque le texte visuellement */
}
.tl-btn--loading .tl-btn__icon{ visibility: hidden; }
.tl-btn__spinner{
  position: absolute;
  top: 50%;
  left: 50%;
  width: 1.15em;
  height: 1.15em;
  margin: -0.575em 0 0 -0.575em;
  border-radius: var(--tl-r-pill);
  border: 2px solid currentColor;          /* hérite de --_fg avant masquage */
  border-top-color: transparent;
  opacity: .9;
  color: var(--_fg);
  animation: tl-spin .7s linear infinite;
}
@keyframes tl-spin{ to{ transform: rotate(360deg); } }

/* États de validation (pertinents sur formulaires : ex. "Ajouter au panier") */
.tl-btn--success{
  --_bg: var(--tl-success);
  --_fg: var(--tl-white);
  --_bd: var(--tl-success);
  --_ring: var(--tl-forest);
}
.tl-btn--error{
  --_bg: var(--tl-danger);
  --_fg: var(--tl-white);
  --_bd: var(--tl-danger);
  --_ring: var(--tl-ink);
}

/* ==========================================================================
   RESPONSIVE (mobile-first) — les boutons passent en pleine largeur dans les
   groupes d'actions sur très petit écran.
   ========================================================================== */
.tl-btn-group{
  display: flex;
  flex-wrap: wrap;
  gap: var(--tl-sp-3);
  align-items: center;
}
@media (max-width: 480px){
  .tl-btn-group--stack .tl-btn{ flex: 1 1 100%; }
}

/* ==========================================================================
   PRÉFÉRENCES DE MOUVEMENT — on coupe lift / spinner / trait animé.
   ========================================================================== */
@media (prefers-reduced-motion: reduce){
  .tl-btn,
  .tl-btn__spark,
  .tl-link__spark{ transition: none; }
  .tl-btn:hover{ transform: none; }
  .tl-btn--spectral .tl-btn__spark,
  .tl-link--spectral .tl-link__spark{ transform: scaleX(1); }
  .tl-btn__spinner{ animation-duration: 1.4s; }
}

/* ==========================================================================
   AIDE DÉMO STYLEGUIDE (zones sombres pour tester ghost/spectral)
   Ces classes -demo ne font pas partie du composant ; elles encadrent les
   exemples sur fond sombre dans le styleguide.
   ========================================================================== */
.tl-demo-dark{
  background: var(--tl-forest);
  border-radius: var(--tl-r);
  padding: var(--tl-sp-5);
}
/* forms */
/* =====================================================================
   TerraLED — "Spectre Vivant" / Famille : Formulaires & champs
   CSS pur, tokens --tl-* exclusivement, BEM préfixé .tl-
   Le trait spectral (var(--tl-spectral)) est DÉCORATIF (aria-hidden).
   ===================================================================== */

/* ---- bloc de champ : enveloppe label + contrôle + aide + erreur ---- */
.tl-field{
  display:flex;
  flex-direction:column;
  gap:var(--tl-sp-2);
  font-family:var(--tl-font-body);
  color:var(--tl-text);
  margin-bottom:var(--tl-sp-5);
}
.tl-field:last-child{margin-bottom:0}

/* label : signature mono discrète */
.tl-field__label{
  display:inline-flex;
  align-items:baseline;
  gap:var(--tl-sp-2);
  font-family:var(--tl-font-mono);
  font-weight:600;
  font-size:12.5px;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--tl-text);
  line-height:1.3;
}
/* marqueur "requis" : porteur de sens, pas que la couleur (texte "requis" en sr) */
.tl-field__req{
  color:var(--tl-danger);
  font-size:1.1em;
  line-height:0;
}
/* mention optionnel, ton doux */
.tl-field__optional{
  font-family:var(--tl-font-body);
  font-weight:400;
  font-size:12px;
  letter-spacing:0;
  text-transform:none;
  color:var(--tl-text-soft);
}

/* aide sous le label */
.tl-field__hint{
  font-size:13px;
  line-height:1.45;
  color:var(--tl-text-soft);
}

/* message d'erreur (relié via aria-describedby) */
.tl-field__error{
  display:flex;
  align-items:flex-start;
  gap:var(--tl-sp-2);
  font-size:13px;
  line-height:1.45;
  font-weight:600;
  color:var(--tl-danger);
}
.tl-field__error[hidden]{display:none}
.tl-field__error .tl-field__icon{
  flex:none;
  width:16px;height:16px;
  margin-top:1px;
}

/* message de succès */
.tl-field__success{
  display:flex;
  align-items:flex-start;
  gap:var(--tl-sp-2);
  font-size:13px;
  line-height:1.45;
  font-weight:600;
  color:var(--tl-success);
}
.tl-field__success[hidden]{display:none}
.tl-field__success .tl-field__icon{flex:none;width:16px;height:16px;margin-top:1px}

/* ---- contrôle texte commun : input / textarea / select ---- */
.tl-input,
.tl-textarea,
.tl-select__native{
  width:100%;
  min-height:48px;                 /* cible tactile confortable */
  padding:var(--tl-sp-3) var(--tl-sp-4);
  font-family:var(--tl-font-body);
  font-size:16px;                  /* >=16px : pas de zoom iOS */
  line-height:1.45;
  color:var(--tl-text);
  background:var(--tl-surface);
  border:1.5px solid var(--tl-border);
  border-radius:var(--tl-r-sm);
  box-shadow:var(--tl-shadow-sm);
  transition:border-color var(--tl-dur) var(--tl-ease),
             box-shadow var(--tl-dur) var(--tl-ease),
             background var(--tl-dur) var(--tl-ease);
  appearance:none;
  -webkit-appearance:none;
}
.tl-input::placeholder,
.tl-textarea::placeholder{
  color:var(--tl-text-soft);
  opacity:1;                       /* Firefox */
}
.tl-textarea{
  min-height:120px;
  resize:vertical;
  line-height:1.6;
}

/* survol */
.tl-input:hover:not([disabled]):not([aria-invalid="true"]),
.tl-textarea:hover:not([disabled]):not([aria-invalid="true"]),
.tl-select__native:hover:not([disabled]):not([aria-invalid="true"]){
  border-color:var(--tl-primary);
}

/* focus clavier : anneau visible >=3:1, jamais le seul trait spectral */
.tl-input:focus-visible,
.tl-textarea:focus-visible,
.tl-select__native:focus-visible{
  outline:3px solid var(--tl-gold);
  outline-offset:2px;
  border-color:var(--tl-primary);
  box-shadow:0 0 0 4px rgba(28,122,66,.18);
}
/* focus souris : pas d'anneau gold, mais bordure verte nette */
.tl-input:focus:not(:focus-visible),
.tl-textarea:focus:not(:focus-visible),
.tl-select__native:focus:not(:focus-visible){
  border-color:var(--tl-primary);
  box-shadow:0 0 0 4px rgba(28,122,66,.16);
}

/* état erreur : bordure + fond teinté + anneau danger (focus) */
.tl-input[aria-invalid="true"],
.tl-textarea[aria-invalid="true"],
.tl-select__native[aria-invalid="true"]{
  border-color:var(--tl-danger);
  background:rgba(194,65,47,.04);
}
.tl-input[aria-invalid="true"]:focus-visible,
.tl-textarea[aria-invalid="true"]:focus-visible,
.tl-select__native[aria-invalid="true"]:focus-visible{
  outline-color:var(--tl-gold);
  box-shadow:0 0 0 4px rgba(194,65,47,.2);
}

/* état succès (validé) */
.tl-input.tl-input--ok,
.tl-textarea.tl-input--ok,
.tl-select__native.tl-input--ok{
  border-color:var(--tl-success);
  background:rgba(28,122,66,.04);
}

/* désactivé */
.tl-input[disabled],
.tl-textarea[disabled],
.tl-select__native[disabled]{
  cursor:not-allowed;
  opacity:.6;
  background:var(--tl-grey);
  box-shadow:none;
  border-color:var(--tl-border);
}
.tl-input[readonly]{
  background:var(--tl-grey);
  border-style:dashed;
}

/* ---- input avec icône / affixe ---- */
.tl-input-group{position:relative;display:flex;align-items:stretch}
.tl-input-group .tl-input{padding-left:44px}
.tl-input-group__icon{
  position:absolute;
  left:var(--tl-sp-3);
  top:50%;
  transform:translateY(-50%);
  width:20px;height:20px;
  color:var(--tl-text-soft);
  pointer-events:none;
}
.tl-input-group:focus-within .tl-input-group__icon{color:var(--tl-primary)}

/* ---- select custom (s'appuie sur <select> natif accessible) ---- */
.tl-select{position:relative;display:block}
.tl-select__native{
  padding-right:44px;             /* place pour le chevron */
  cursor:pointer;
}
.tl-select__chevron{
  position:absolute;
  right:var(--tl-sp-4);
  top:50%;
  transform:translateY(-50%);
  width:16px;height:16px;
  color:var(--tl-text-soft);
  pointer-events:none;
  transition:transform var(--tl-dur) var(--tl-ease);
}
.tl-select__native:focus-visible ~ .tl-select__chevron{color:var(--tl-primary)}
.tl-select__native[disabled] ~ .tl-select__chevron{opacity:.5}

/* ---- checkbox & radio stylés (input natif masqué visuellement mais focusable) ---- */
.tl-choice{
  display:flex;
  align-items:flex-start;
  gap:var(--tl-sp-3);
  min-height:44px;                /* cible tactile */
  padding:var(--tl-sp-2) 0;
  cursor:pointer;
  font-family:var(--tl-font-body);
  font-size:15px;
  line-height:1.5;
  color:var(--tl-text);
}
.tl-choice__input{
  /* input réel : invisible mais présent pour le clavier/lecteur d'écran */
  position:absolute;
  width:1px;height:1px;
  opacity:0;
  margin:0;
}
.tl-choice__box{
  flex:none;
  width:24px;height:24px;
  margin-top:1px;
  display:grid;
  place-items:center;
  background:var(--tl-surface);
  border:1.5px solid var(--tl-border);
  box-shadow:var(--tl-shadow-sm);
  transition:border-color var(--tl-dur) var(--tl-ease),
             background var(--tl-dur) var(--tl-ease),
             box-shadow var(--tl-dur) var(--tl-ease);
}
.tl-choice--checkbox .tl-choice__box{border-radius:var(--tl-r-sm)}
.tl-choice--radio .tl-choice__box{border-radius:var(--tl-r-pill)}

/* glyphe coché : caché par défaut */
.tl-choice__box .tl-choice__check{
  width:14px;height:14px;
  color:var(--tl-white);
  opacity:0;
  transform:scale(.6);
  transition:opacity var(--tl-dur) var(--tl-ease),
             transform var(--tl-dur) var(--tl-ease);
}
.tl-choice--radio .tl-choice__box::after{
  content:"";
  width:10px;height:10px;
  border-radius:var(--tl-r-pill);
  background:var(--tl-white);
  opacity:0;
  transform:scale(.4);
  transition:opacity var(--tl-dur) var(--tl-ease),
             transform var(--tl-dur) var(--tl-ease);
}

/* survol */
.tl-choice:hover .tl-choice__input:not([disabled]) ~ .tl-choice__box{
  border-color:var(--tl-primary);
}

/* coché */
.tl-choice__input:checked ~ .tl-choice__box{
  background:var(--tl-primary);
  border-color:var(--tl-primary);
}
.tl-choice__input:checked ~ .tl-choice__box .tl-choice__check{opacity:1;transform:scale(1)}
.tl-choice--radio .tl-choice__input:checked ~ .tl-choice__box::after{opacity:1;transform:scale(1)}

/* indéterminé (checkbox) */
.tl-choice__input:indeterminate ~ .tl-choice__box{
  background:var(--tl-primary);
  border-color:var(--tl-primary);
}
.tl-choice__input:indeterminate ~ .tl-choice__box .tl-choice__check{
  opacity:1;transform:scale(1);
  clip-path:inset(45% 18% 45% 18%);   /* trait horizontal */
}

/* focus clavier : anneau gold sur la boîte */
.tl-choice__input:focus-visible ~ .tl-choice__box{
  outline:3px solid var(--tl-gold);
  outline-offset:2px;
}

/* erreur (groupe invalide) */
.tl-choice--error .tl-choice__box{border-color:var(--tl-danger)}
.tl-choice--error .tl-choice__input:checked ~ .tl-choice__box{
  background:var(--tl-danger);border-color:var(--tl-danger);
}

/* désactivé */
.tl-choice__input[disabled] ~ .tl-choice__box{
  opacity:.5;background:var(--tl-grey);box-shadow:none;
}
.tl-choice:has(.tl-choice__input[disabled]){cursor:not-allowed;color:var(--tl-text-soft)}
.tl-choice__label-text{padding-top:1px}

/* ---- fieldset / legend (groupe) ---- */
.tl-fieldset{
  border:1.5px solid var(--tl-border);
  border-radius:var(--tl-r);
  padding:var(--tl-sp-5);
  margin:0 0 var(--tl-sp-5);
  background:var(--tl-surface);
}
.tl-fieldset__legend{
  padding:0 var(--tl-sp-2);
  font-family:var(--tl-font-mono);
  font-weight:600;
  font-size:12.5px;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--tl-text);
}
.tl-fieldset__hint{
  margin:calc(-1 * var(--tl-sp-2)) 0 var(--tl-sp-4);
  font-size:13px;
  color:var(--tl-text-soft);
}
.tl-fieldset[aria-invalid="true"]{
  border-color:var(--tl-danger);
}
/* rangée de choix horizontale possible */
.tl-choice-list{display:flex;flex-direction:column;gap:var(--tl-sp-1)}
.tl-choice-list--inline{flex-direction:row;flex-wrap:wrap;gap:var(--tl-sp-2) var(--tl-sp-5)}

/* =====================================================================
   Bouton minimal (cible tactile + spectre décoratif) — pour les démos
   ===================================================================== */
.tl-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:var(--tl-sp-2);
  min-height:48px;
  padding:var(--tl-sp-3) var(--tl-sp-5);
  font-family:var(--tl-font-mono);
  font-weight:700;
  font-size:13px;
  letter-spacing:.06em;
  text-transform:uppercase;
  border:1.5px solid transparent;
  border-radius:var(--tl-r-sm);
  cursor:pointer;
  transition:transform var(--tl-dur) var(--tl-ease),
             background var(--tl-dur) var(--tl-ease),
             box-shadow var(--tl-dur) var(--tl-ease),
             color var(--tl-dur) var(--tl-ease);
}
.tl-btn svg{width:18px;height:18px}
/* CTA ambre => texte vert forêt foncé (rappel contraste brief) */
.tl-btn--primary{background:var(--tl-amber);color:var(--tl-forest);box-shadow:var(--tl-shadow-sm)}
.tl-btn--primary:hover:not([disabled]):not([aria-disabled="true"]){background:var(--tl-gold);transform:translateY(-2px)}
.tl-btn--primary:active{transform:translateY(0)}
.tl-btn--green{background:var(--tl-primary);color:var(--tl-white)}
.tl-btn--green:hover:not([disabled]):not([aria-disabled="true"]){background:var(--tl-green-600);transform:translateY(-2px)}
.tl-btn--ghost{background:transparent;color:var(--tl-primary);border-color:var(--tl-border)}
.tl-btn--ghost:hover:not([disabled]):not([aria-disabled="true"]){border-color:var(--tl-primary)}
.tl-btn:focus-visible{outline:3px solid var(--tl-gold);outline-offset:2px}
.tl-btn[disabled],
.tl-btn[aria-disabled="true"]{opacity:.55;cursor:not-allowed;transform:none;box-shadow:none}

/* spinner de chargement (état busy) */
.tl-btn[aria-busy="true"]{pointer-events:none;color:transparent;position:relative}
.tl-btn[aria-busy="true"]::after{
  content:"";
  position:absolute;
  width:18px;height:18px;
  border:2px solid currentColor;
  border-top-color:transparent;
  border-radius:var(--tl-r-pill);
  color:var(--tl-forest);                /* visible sur ambre */
  animation:tl-spin .7s linear infinite;
}
.tl-btn--green[aria-busy="true"]::after{color:var(--tl-white)}
@keyframes tl-spin{to{transform:rotate(360deg)}}

/* =====================================================================
   Champ recherche
   ===================================================================== */
.tl-search{position:relative;display:flex;align-items:stretch;max-width:480px}
.tl-search__field{
  flex:1 1 auto;
  min-height:48px;
  padding:var(--tl-sp-3) var(--tl-sp-4) var(--tl-sp-3) 46px;
  font-family:var(--tl-font-body);
  font-size:16px;
  color:var(--tl-text);
  background:var(--tl-surface);
  border:1.5px solid var(--tl-border);
  border-radius:var(--tl-r-pill);
  box-shadow:var(--tl-shadow-sm);
  transition:border-color var(--tl-dur) var(--tl-ease),box-shadow var(--tl-dur) var(--tl-ease);
}
.tl-search__field::placeholder{color:var(--tl-text-soft)}
.tl-search__field:hover:not([disabled]){border-color:var(--tl-primary)}
.tl-search__field:focus-visible{
  outline:3px solid var(--tl-gold);
  outline-offset:2px;
  border-color:var(--tl-primary);
}
.tl-search__icon{
  position:absolute;
  left:var(--tl-sp-4);
  top:50%;transform:translateY(-50%);
  width:20px;height:20px;
  color:var(--tl-primary);
  pointer-events:none;
}
/* bouton effacer (cible 44px) */
.tl-search__clear{
  position:absolute;
  right:6px;top:50%;transform:translateY(-50%);
  width:44px;height:44px;
  display:grid;place-items:center;
  background:transparent;border:0;border-radius:var(--tl-r-pill);
  color:var(--tl-text-soft);cursor:pointer;
  transition:color var(--tl-dur) var(--tl-ease),background var(--tl-dur) var(--tl-ease);
}
.tl-search__clear:hover{color:var(--tl-text);background:var(--tl-grey)}
.tl-search__clear:focus-visible{outline:3px solid var(--tl-gold);outline-offset:2px}
.tl-search__clear svg{width:18px;height:18px}

/* =====================================================================
   Newsletter inline (sur fond sombre = surface forest)
   ===================================================================== */
.tl-newsletter{
  position:relative;
  background:var(--tl-forest);
  color:var(--tl-cream);
  border-radius:var(--tl-r-lg);
  padding:var(--tl-sp-6);
  overflow:hidden;
  isolation:isolate;
}
/* trait spectral décoratif en tête (aria-hidden côté HTML) */
.tl-newsletter__spectral{
  position:absolute;left:0;right:0;top:0;
  height:3px;
  background:var(--tl-spectral);
  z-index:1;
}
.tl-newsletter__title{
  font-family:var(--tl-font-display);
  font-weight:600;
  font-size:clamp(22px,3vw,30px);
  letter-spacing:-.02em;
  color:var(--tl-white);
  margin:0 0 var(--tl-sp-2);
}
.tl-newsletter__lead{
  color:var(--tl-text-soft);
  font-size:15px;
  margin:0 0 var(--tl-sp-5);
  max-width:48ch;
}
/* sur fond sombre, le ton doux par défaut manque de contraste : on force un vert clair lisible */
.tl-newsletter .tl-newsletter__lead{color:#bdd2c3}

.tl-newsletter__form{
  display:flex;
  flex-wrap:wrap;
  gap:var(--tl-sp-3);
  align-items:flex-start;
}
.tl-newsletter__group{flex:1 1 240px;min-width:0}
/* label visuellement caché mais lu (le placeholder ne suffit pas) */
.tl-sr-only{
  position:absolute !important;
  width:1px;height:1px;
  padding:0;margin:-1px;
  overflow:hidden;clip:rect(0 0 0 0);
  white-space:nowrap;border:0;
}
.tl-newsletter__input{
  width:100%;
  min-height:48px;
  padding:var(--tl-sp-3) var(--tl-sp-4);
  font-family:var(--tl-font-body);
  font-size:16px;
  color:var(--tl-white);
  background:rgba(255,255,255,.06);
  border:1.5px solid rgba(255,255,255,.18);
  border-radius:var(--tl-r-sm);
  transition:border-color var(--tl-dur) var(--tl-ease),background var(--tl-dur) var(--tl-ease);
}
.tl-newsletter__input::placeholder{color:#9fb3a4}
.tl-newsletter__input:hover:not([disabled]){border-color:rgba(255,255,255,.4)}
.tl-newsletter__input:focus-visible{
  outline:3px solid var(--tl-gold);
  outline-offset:2px;
  border-color:rgba(255,255,255,.55);
  background:rgba(255,255,255,.1);
}
.tl-newsletter__input[aria-invalid="true"]{
  border-color:var(--tl-danger);
  background:rgba(194,65,47,.14);
}
/* messages sur fond sombre */
.tl-newsletter__error{
  display:flex;align-items:center;gap:var(--tl-sp-2);
  margin-top:var(--tl-sp-2);
  font-size:13px;font-weight:600;
  color:var(--tl-gold);                 /* lisible sur forest, gros/gras = OK */
}
.tl-newsletter__error[hidden]{display:none}
.tl-newsletter__success{
  display:flex;align-items:center;gap:var(--tl-sp-2);
  margin-top:var(--tl-sp-3);
  font-size:14px;font-weight:600;
  color:#7fe0a0;
}
.tl-newsletter__success[hidden]{display:none}
.tl-newsletter__error svg,
.tl-newsletter__success svg{width:16px;height:16px;flex:none}
.tl-newsletter__submit{flex:0 0 auto}
/* consentement RGPD */
.tl-newsletter .tl-choice{color:#cfe2d6;margin-top:var(--tl-sp-3);flex-basis:100%}
.tl-newsletter .tl-choice__box{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.3)}
.tl-newsletter .tl-choice a{color:var(--tl-gold);text-decoration:underline}

/* =====================================================================
   Helpers de mise en page styleguide (démo)
   ===================================================================== */
.tl-form-grid{display:grid;gap:var(--tl-sp-4)}
@media (min-width:680px){
  .tl-form-grid--2{grid-template-columns:1fr 1fr}
}
.tl-stack{display:flex;flex-direction:column;gap:var(--tl-sp-5)}
.tl-row{display:flex;flex-wrap:wrap;gap:var(--tl-sp-5);align-items:flex-start}
.tl-row>*{flex:1 1 280px}

/* =====================================================================
   Préférences mouvement réduit & contrastes forcés
   ===================================================================== */
@media (prefers-reduced-motion:reduce){
  .tl-input,.tl-textarea,.tl-select__native,.tl-choice__box,
  .tl-choice__check,.tl-btn,.tl-search__field,.tl-search__clear,
  .tl-select__chevron,.tl-newsletter__input,.tl-input-group__icon{
    transition:none !important;
  }
  .tl-btn[aria-busy="true"]::after{animation:none}
}
@media (forced-colors:active){
  .tl-input,.tl-textarea,.tl-select__native,.tl-choice__box,
  .tl-search__field,.tl-newsletter__input{border-color:CanvasText}
  .tl-input:focus-visible,.tl-textarea:focus-visible,
  .tl-select__native:focus-visible,.tl-choice__input:focus-visible ~ .tl-choice__box,
  .tl-search__field:focus-visible,.tl-btn:focus-visible,
  .tl-newsletter__input:focus-visible{outline:3px solid Highlight}
  .tl-choice__input:checked ~ .tl-choice__box{background:Highlight;border-color:Highlight}
  .tl-choice__check{color:Canvas}
}
/* badges-rating */
/* =========================================================================
   TerraLED — Composants : Badges, drapeaux & notation ("Spectre Vivant")
   CSS pur, tokens --tl-* uniquement, BEM préfixé .tl-
   ========================================================================= */

/* utilitaire : texte réservé aux lecteurs d'écran (complément de sens) */
.tl-u-visually-hidden{
  position:absolute;
  width:1px;height:1px;
  padding:0;margin:-1px;
  overflow:hidden;
  clip:rect(0 0 0 0);
  white-space:nowrap;border:0;
}

/* -------------------------------------------------------------------------
   1) DRAPEAUX PRODUIT  (.tl-flag)
   Petites pastilles posées sur les cartes/visuels produit.
   Le sens est porté par le TEXTE (jamais par la seule couleur ou le spectre).
   ------------------------------------------------------------------------- */
.tl-flag{
  display:inline-flex;
  align-items:center;
  gap:var(--tl-sp-1);
  font-family:var(--tl-font-mono);
  font-weight:600;
  font-size:11px;
  line-height:1;
  letter-spacing:.1em;
  text-transform:uppercase;
  padding:6px var(--tl-sp-2);
  border-radius:var(--tl-r-sm);
  border:1px solid transparent;
  white-space:nowrap;
  vertical-align:middle;
}
/* point d'état rond, redondance visuelle (forme + couleur) */
.tl-flag__dot{
  width:6px;height:6px;border-radius:var(--tl-r-pill);
  background:currentColor;flex:none;
}

/* Nouveau — vert forêt sur clair, contraste AA (blanc/vert = 7,6:1) */
.tl-flag--new{
  background:var(--tl-green);
  color:var(--tl-white);
  border-color:var(--tl-green);
}
/* Promo — cuivre en style "teinté" : texte cuivre dédié (var(--tl-copper-text)
   = 6:1 sur sa propre teinte) car blanc OU forêt sur cuivre plein restent
   sous le seuil AA 4.5:1 pour ce petit texte. */
.tl-flag--promo{
  background:rgba(181,106,0,.14);
  color:var(--tl-copper-text);
  border-color:rgba(181,106,0,.40);
  font-weight:700;
}
/* -15% (remise chiffrée) — ambre DÉCOR : texte vert forêt foncé pour l'AA.
   L'ambre est ici un fond clair, donc texte sombre obligatoire (forêt/ambre = 7:1). */
.tl-flag--discount{
  background:var(--tl-amber);
  color:var(--tl-forest);
  border-color:var(--tl-amber);
  font-weight:700;
}
/* Pack / lot — surface neutre + filet, texte cuivre dédié texte (6:1) */
.tl-flag--pack{
  background:var(--tl-surface);
  color:var(--tl-copper-text);
  border-color:var(--tl-border);
}

/* Empilement de drapeaux posé en overlay sur un visuel */
.tl-flags{
  display:inline-flex;
  flex-direction:column;
  align-items:flex-start;
  gap:var(--tl-sp-1);
}

/* -------------------------------------------------------------------------
   2) LABELS D'ÉTAT  (.tl-label)  success / warning / danger / info
   Pour stock, statut de commande, messages contextuels.
   Teinte de fond douce via rgba sur tokens + texte sémantique foncé.
   ------------------------------------------------------------------------- */
.tl-label{
  display:inline-flex;
  align-items:center;
  gap:var(--tl-sp-2);
  font-family:var(--tl-font-body);
  font-weight:700;
  font-size:12.5px;
  line-height:1.2;
  padding:var(--tl-sp-1) var(--tl-sp-3);
  border-radius:var(--tl-r-pill);
  border:1px solid transparent;
}
.tl-label__icon{
  width:9px;height:9px;border-radius:var(--tl-r-pill);
  background:currentColor;flex:none;
}
.tl-label--success{
  color:var(--tl-success);
  background:rgba(28,122,66,.12);
  border-color:rgba(28,122,66,.30);
}
/* warning : le texte utilise --tl-copper-text (5,3:1) car --tl-warning (#b5710a)
   ne passe pas l'AA (3,94:1) en petit texte sur fond clair. */
.tl-label--warning{
  color:var(--tl-copper-text);
  background:rgba(181,113,10,.12);
  border-color:rgba(181,113,10,.34);
}
.tl-label--danger{
  color:var(--tl-danger);
  background:rgba(194,65,47,.12);
  border-color:rgba(194,65,47,.32);
}
.tl-label--info{
  color:var(--tl-info);
  background:rgba(37,99,255,.10);
  border-color:rgba(37,99,255,.30);
}
/* Variante pleine (solide) pour fort accent — texte blanc AA (>=4,8:1) */
.tl-label--solid.tl-label--success{background:var(--tl-success);color:var(--tl-white);border-color:var(--tl-success)}
.tl-label--solid.tl-label--danger{background:var(--tl-danger);color:var(--tl-white);border-color:var(--tl-danger)}
.tl-label--solid.tl-label--info{background:var(--tl-info);color:var(--tl-white);border-color:var(--tl-info)}
/* warning solide : fond ambre clair => texte forêt foncé pour l'AA (7:1) */
.tl-label--solid.tl-label--warning{background:var(--tl-amber);color:var(--tl-forest);border-color:var(--tl-amber)}

/* État de chargement (ex: vérification de stock) */
.tl-label--loading{
  color:var(--tl-text-soft);
  background:rgba(95,109,98,.10);
  border-color:var(--tl-border);
}
.tl-label--loading .tl-label__icon{
  background:transparent;
  border:2px solid currentColor;
  border-top-color:transparent;
  animation:tl-spin .7s linear infinite;
}
@keyframes tl-spin{to{transform:rotate(360deg)}}
@media (prefers-reduced-motion:reduce){
  .tl-label--loading .tl-label__icon{animation:none}
}

/* -------------------------------------------------------------------------
   3) BADGE "MARQUE OFFICIELLE"  (.tl-trust)
   Réassurance revendeur agréé. Filet spectral DÉCORATIF en liseré.
   ------------------------------------------------------------------------- */
.tl-trust{
  display:inline-flex;
  align-items:center;
  gap:var(--tl-sp-2);
  font-family:var(--tl-font-body);
  font-weight:700;
  font-size:13px;
  line-height:1.2;
  color:var(--tl-text);
  background:var(--tl-surface);
  border:1px solid var(--tl-border);
  border-radius:var(--tl-r-pill);
  padding:var(--tl-sp-2) var(--tl-sp-3) var(--tl-sp-2) var(--tl-sp-2);
  position:relative;
  box-shadow:var(--tl-shadow-sm);
}
/* pastille à coche : porteuse de sens via la coche (icône), pas la couleur seule */
.tl-trust__seal{
  width:24px;height:24px;border-radius:var(--tl-r-pill);
  background:var(--tl-green);
  color:var(--tl-white);
  display:inline-flex;align-items:center;justify-content:center;
  flex:none;
}
.tl-trust__seal svg{width:13px;height:13px;display:block}
.tl-trust__text{display:inline-flex;flex-direction:column;gap:1px}
.tl-trust__text small{
  font-family:var(--tl-font-mono);
  font-weight:500;font-size:9.5px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--tl-copper-text);
}
/* liseré spectral décoratif sous le badge (aria-hidden côté markup) */
.tl-trust__spectral{
  position:absolute;left:14px;right:14px;bottom:-1px;height:2px;
  border-radius:var(--tl-r-pill);
  background:var(--tl-spectral);
  pointer-events:none;
}

/* -------------------------------------------------------------------------
   4) ÉTOILES DE NOTATION  (.tl-rating)
   Note réelle + demi-étoiles via masque de largeur. Décoratif : le sens est
   donné par le texte accessible (.tl-rating__value) et un libellé visible.
   ------------------------------------------------------------------------- */
.tl-rating{
  display:inline-flex;
  align-items:center;
  gap:var(--tl-sp-2);
  font-family:var(--tl-font-body);
}
/* la rampe d'étoiles : superposition vide (gris) + remplie (ambre) clippée */
.tl-rating__stars{
  position:relative;
  display:inline-block;
  line-height:1;
  font-size:16px;
  --tl-rating-fill:0%;       /* piloté inline : ex style="--tl-rating-fill:86%" */
}
.tl-rating__stars::before,
.tl-rating__stars::after{
  content:"\2605\2605\2605\2605\2605"; /* cinq étoiles pleines */
  letter-spacing:2px;
}
/* gabarit vide */
.tl-rating__stars::before{
  color:var(--tl-line);
}
/* couche remplie ambre, largeur = note (gère les demi-étoiles) */
.tl-rating__stars::after{
  position:absolute;inset:0;
  width:var(--tl-rating-fill);
  overflow:hidden;
  white-space:nowrap;
  color:var(--tl-amber);
}
/* note chiffrée (porteuse de sens, lisible AA = 16:1) */
.tl-rating__value{
  font-weight:700;font-size:13px;color:var(--tl-text);
}
/* nombre d'avis */
.tl-rating__count{
  font-size:12.5px;color:var(--tl-text-soft);
}
.tl-rating__count a{color:var(--tl-text-soft);text-decoration:underline;border-radius:var(--tl-r-sm)}
.tl-rating__count a:hover{color:var(--tl-text)}
.tl-rating__count a:focus-visible{
  outline:2px solid var(--tl-gold);
  outline-offset:2px;
  box-shadow:0 0 0 2px var(--tl-forest), 0 0 0 5px var(--tl-gold);
  color:var(--tl-text);
}

/* Taille compacte pour listings */
.tl-rating--sm .tl-rating__stars{font-size:13px}
.tl-rating--sm .tl-rating__value{font-size:12px}
.tl-rating--sm .tl-rating__count{font-size:11.5px}

/* Sur fond sombre : étoiles ambre = gros décor OK, libellés clairs */
[data-tl-theme="dark"] .tl-rating__stars::before{color:rgba(255,255,255,.22)}

/* -------------------------------------------------------------------------
   5) CHIPS DE FACETTE / CATÉGORIE REMOVABLES  (.tl-chip)
   Élément interactif : cible tactile >=44px sur le bouton supprimer.
   ------------------------------------------------------------------------- */
.tl-chip{
  display:inline-flex;
  align-items:center;
  gap:var(--tl-sp-2);
  font-family:var(--tl-font-body);
  font-weight:600;
  font-size:13px;
  line-height:1.2;
  color:var(--tl-text);
  background:var(--tl-surface);
  border:1px solid var(--tl-border);
  border-radius:var(--tl-r-pill);
  padding:6px 6px 6px var(--tl-sp-3);
  transition:border-color var(--tl-dur) var(--tl-ease),
             background var(--tl-dur) var(--tl-ease),
             box-shadow var(--tl-dur) var(--tl-ease);
}
.tl-chip__label{display:inline-flex;align-items:center;gap:var(--tl-sp-1)}
/* préfixe facette (ex "Couleur :") en mono cuivre dédié texte (6:1) */
.tl-chip__facet{
  font-family:var(--tl-font-mono);
  font-weight:500;font-size:11px;letter-spacing:.04em;
  color:var(--tl-copper-text);
}
.tl-chip:hover{
  border-color:var(--tl-primary);
  background:rgba(23,96,53,.05);
}

/* bouton supprimer : >=44px de cible tactile, croix dessinée en SVG */
.tl-chip__remove{
  appearance:none;
  -webkit-appearance:none;
  border:0;
  margin:-9px -9px -9px 0;     /* étend la zone cliquable hors du flux visuel */
  padding:9px;
  width:44px;height:44px;
  display:inline-flex;align-items:center;justify-content:center;
  background:transparent;
  color:var(--tl-text-soft);
  border-radius:var(--tl-r-pill);
  cursor:pointer;
  transition:background var(--tl-dur) var(--tl-ease),
             color var(--tl-dur) var(--tl-ease);
}
.tl-chip__remove-icon{
  width:18px;height:18px;display:block;pointer-events:none;
}
.tl-chip__remove:hover{
  background:rgba(194,65,47,.12);
  color:var(--tl-danger);
}
.tl-chip__remove:active{
  background:rgba(194,65,47,.20);
}
/* focus-visible : anneau DOUBLE pour garantir >=3:1 sur tout fond.
   L'or seul ne fait que 1,7:1 sur surface claire ; on ajoute un liseré
   forêt (box-shadow) qui assure le contraste, l'or reste la couleur de marque. */
.tl-chip__remove:focus-visible{
  outline:2px solid var(--tl-gold);
  outline-offset:2px;
  box-shadow:0 0 0 2px var(--tl-forest), 0 0 0 5px var(--tl-gold);
}
.tl-chip__remove[disabled],
.tl-chip__remove[aria-disabled="true"]{
  color:var(--tl-text-soft);
  opacity:.45;
  cursor:not-allowed;
  pointer-events:none;
}

/* chip "tout effacer" : action de réinitialisation, accent cuivre, cible >=44px */
.tl-chip--clear{
  background:transparent;
  border-color:transparent;
  color:var(--tl-copper-text);
  text-decoration:underline;
  padding:11px var(--tl-sp-3);
  cursor:pointer;
  min-height:44px;
}
.tl-chip--clear:hover{
  background:rgba(143,85,0,.08);
  border-color:transparent;
}
.tl-chip--clear:focus-visible{
  outline:2px solid var(--tl-gold);
  outline-offset:2px;
  box-shadow:0 0 0 2px var(--tl-forest), 0 0 0 5px var(--tl-gold);
}

/* Conteneur de chips actifs (barre de filtres) */
.tl-chips{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:var(--tl-sp-2);
}

/* États partagés : le chip réagit au focus de son bouton interne */
.tl-chip:focus-within{
  border-color:var(--tl-primary);
}

/* -------------------------------------------------------------------------
   6) Adaptations thèmes sombre / crème (héritent surtout des tokens)
   ------------------------------------------------------------------------- */
[data-tl-theme="dark"] .tl-flag--pack{
  color:var(--tl-gold);                 /* gold = gros décor / texte sur sombre OK */
}
[data-tl-theme="dark"] .tl-trust__text small{color:var(--tl-gold)}
[data-tl-theme="dark"] .tl-chip__facet{color:var(--tl-gold)}
[data-tl-theme="dark"] .tl-chip--clear{color:var(--tl-gold)}
[data-tl-theme="dark"] .tl-chip--clear:hover{background:rgba(255,255,255,.08)}

/* -------------------------------------------------------------------------
   7) Responsive mobile-first
   ------------------------------------------------------------------------- */
@media (max-width:480px){
  .tl-rating{flex-wrap:wrap;gap:var(--tl-sp-1) var(--tl-sp-2)}
}
/* product-card */
/* =====================================================================
   TerraLED — Famille "Carte produit (miniature)" (Spectre Vivant)
   CSS pur. Tokens --tl-* exclusivement. BEM préfixe .tl-.
   Visuel + drapeaux + coeur wishlist + catégorie + nom + note + prix
   + ajout rapide. Survol (zoom + ombre). États : épuisé, sans image,
   promo, pack. Variantes grille & liste. Lien étiré accessible.
   ===================================================================== */

/* ---------------------------------------------------------------------
   0) Icônes (masques data-URI) portées par la carte
   --------------------------------------------------------------------- */
.tl-card{
  --tl-ico-heart:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="black" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M20.8 4.6a5.5 5.5 0 0 0-7.8 0L12 5.7l-1-1.1a5.5 5.5 0 0 0-7.8 7.8l1 1.1L12 21l7.8-7.5 1-1.1a5.5 5.5 0 0 0 0-7.8Z"/></svg>');
  --tl-ico-heart-fill:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="black" stroke="black" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M20.8 4.6a5.5 5.5 0 0 0-7.8 0L12 5.7l-1-1.1a5.5 5.5 0 0 0-7.8 7.8l1 1.1L12 21l7.8-7.5 1-1.1a5.5 5.5 0 0 0 0-7.8Z"/></svg>');
  --tl-ico-cart:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="black" stroke-width="2.2" stroke-linecap="round" stroke-linejoin="round"><circle cx="9" cy="21" r="1.4"/><circle cx="18" cy="21" r="1.4"/><path d="M2.5 3h2.2l2.2 12.2a2 2 0 0 0 2 1.6h8.2a2 2 0 0 0 2-1.5L21.5 7H6"/></svg>');
  --tl-ico-eye:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="black" stroke-width="2.2" stroke-linecap="round" stroke-linejoin="round"><path d="M2 12s3.6-7 10-7 10 7 10 7-3.6 7-10 7S2 12 2 12Z"/><circle cx="12" cy="12" r="3"/></svg>');
  --tl-ico-frog:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 64 64" fill="none" stroke="black" stroke-width="2.6" stroke-linecap="round" stroke-linejoin="round"><path d="M10 30c0-7 5-12 10-12 4 0 6 3 6 3s2-3 6-3c5 0 10 5 10 12 0 4-2 7-2 7h6c4 0 6 3 6 6s-2 6-6 6H10c-4 0-6-3-6-6s2-6 6-6h6s-2-3-2-7Z"/><circle cx="20" cy="22" r="3.2"/><circle cx="44" cy="22" r="3.2"/><path d="M24 40c4 3 12 3 16 0"/></svg>');
}

/* =====================================================================
   1) CARTE — conteneur, surface, survol (zoom + ombre)
   ===================================================================== */
.tl-card{
  position:relative;            /* ancre le lien étiré */
  display:flex;
  flex-direction:column;
  background:var(--tl-surface);
  border:1px solid var(--tl-border);
  border-radius:var(--tl-r-lg);
  overflow:hidden;
  isolation:isolate;            /* z-index local pour overlay + lien étiré */
  font-family:var(--tl-font-body);
  transition:transform var(--tl-dur) var(--tl-ease),
             box-shadow var(--tl-dur) var(--tl-ease),
             border-color var(--tl-dur) var(--tl-ease);
}
/* Survol carte : légère élévation + ombre marquée */
@media (hover:hover){
  .tl-card:hover{
    transform:translateY(-4px);
    box-shadow:var(--tl-shadow);
    border-color:rgba(23,96,53,.35);
  }
}
/* Focus clavier remontant depuis le lien étiré : la carte est mise en valeur
   par un anneau or visible (>=3:1) doublé d'un liseré forêt. Jamais le spectre. */
.tl-card:focus-within{
  border-color:var(--tl-primary);
  box-shadow:var(--tl-shadow-sm);
}
.tl-card:has(.tl-card__link:focus-visible){
  box-shadow:0 0 0 3px var(--tl-white),0 0 0 6px var(--tl-gold),var(--tl-shadow-sm);
  border-color:var(--tl-primary);
}
[data-tl-theme="dark"] .tl-card:has(.tl-card__link:focus-visible){
  box-shadow:0 0 0 3px var(--tl-forest),0 0 0 6px var(--tl-gold),var(--tl-shadow-sm);
}

/* ---------------------------------------------------------------------
   2) VISUEL  (image, zoom, drapeaux, coeur, ajout rapide)
   --------------------------------------------------------------------- */
.tl-card__media{
  position:relative;
  display:block;
  aspect-ratio:4/3;
  background:var(--tl-grey);
  overflow:hidden;
}
.tl-card__img{
  display:block;
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform .45s var(--tl-ease);
  transform-origin:center;
}
@media (hover:hover){
  .tl-card:hover .tl-card__img{ transform:scale(1.06); }
}
@media (prefers-reduced-motion:reduce){
  .tl-card,.tl-card__img{ transition:none; }
  .tl-card:hover{ transform:none; }
  .tl-card:hover .tl-card__img{ transform:none; }
}

/* Placeholder "rainette" quand aucune image — porteur de sens via texte */
.tl-card__placeholder{
  position:absolute;
  inset:0;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:var(--tl-sp-2);
  background:
    radial-gradient(120% 90% at 50% 15%, rgba(23,96,53,.10), transparent 60%),
    var(--tl-cream-2);
  color:var(--tl-green);
  text-align:center;
  padding:var(--tl-sp-4);
}
.tl-card__placeholder-frog{
  width:56px;height:56px;
  background:var(--tl-green);
  -webkit-mask:var(--tl-ico-frog) center/contain no-repeat;
  mask:var(--tl-ico-frog) center/contain no-repeat;
  opacity:.85;
}
.tl-card__placeholder-text{
  font-family:var(--tl-font-mono);
  font-size:11px;
  font-weight:600;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--tl-copper-text);   /* cuivre dédié texte = AA en petit texte */
}

/* Empilement de drapeaux en overlay (au-dessus du lien étiré) */
.tl-card__flags{
  position:absolute;
  top:var(--tl-sp-3);
  left:var(--tl-sp-3);
  z-index:3;
  display:inline-flex;
  flex-direction:column;
  align-items:flex-start;
  gap:var(--tl-sp-1);
  pointer-events:none;           /* les drapeaux ne bloquent pas le clic carte */
}

/* Bandeau spectral DÉCORATIF en pied de visuel (aria-hidden côté markup) */
.tl-card__spectral{
  position:absolute;
  left:0;right:0;bottom:0;
  height:3px;
  z-index:2;
  background:var(--tl-spectral);
  opacity:0;
  transition:opacity var(--tl-dur) var(--tl-ease);
  pointer-events:none;
}
@media (hover:hover){
  .tl-card:hover .tl-card__spectral{ opacity:.95; }
}
.tl-card:focus-within .tl-card__spectral{ opacity:.95; }

/* ---------------------------------------------------------------------
   3) COEUR WISHLIST  (button aria-pressed) — au-dessus du lien étiré
   Cible tactile >=44px. Sens porté par aria-pressed + libellé, pas la couleur.
   --------------------------------------------------------------------- */
.tl-card__wish{
  position:absolute;
  top:var(--tl-sp-2);
  right:var(--tl-sp-2);
  z-index:4;
  appearance:none;-webkit-appearance:none;
  margin:0;border:0;
  width:44px;height:44px;
  display:inline-flex;align-items:center;justify-content:center;
  border-radius:var(--tl-r-pill);
  background:rgba(255,255,255,.92);
  color:var(--tl-ink-2);
  box-shadow:var(--tl-shadow-sm);
  cursor:pointer;
  transition:background var(--tl-dur) var(--tl-ease),
             color var(--tl-dur) var(--tl-ease),
             transform var(--tl-dur) var(--tl-ease);
}
.tl-card__wish-icon{
  width:20px;height:20px;display:block;pointer-events:none;
  background:currentColor;
  -webkit-mask:var(--tl-ico-heart) center/contain no-repeat;
  mask:var(--tl-ico-heart) center/contain no-repeat;
}
.tl-card__wish:hover{
  background:var(--tl-white);
  color:var(--tl-danger);
}
.tl-card__wish:active{ transform:scale(.92); }
.tl-card__wish:focus-visible{
  outline:3px solid var(--tl-gold);
  outline-offset:2px;
  box-shadow:0 0 0 2px var(--tl-forest),var(--tl-shadow-sm);
}
/* État activé : coeur plein + couleur danger + redondance (icône remplie) */
.tl-card__wish[aria-pressed="true"]{
  color:var(--tl-danger);
  background:var(--tl-white);
}
.tl-card__wish[aria-pressed="true"] .tl-card__wish-icon{
  -webkit-mask:var(--tl-ico-heart-fill) center/contain no-repeat;
  mask:var(--tl-ico-heart-fill) center/contain no-repeat;
}
/* Chargement (ajout en cours) : remplace l'icône par un spinner */
.tl-card__wish.is-loading{ pointer-events:none; color:var(--tl-text-soft); }
.tl-card__wish.is-loading .tl-card__wish-icon{
  -webkit-mask:none;mask:none;
  background:transparent;
  width:18px;height:18px;
  border:2px solid currentColor;
  border-top-color:transparent;
  border-radius:50%;
  animation:tl-spin .7s linear infinite;
}

/* ---------------------------------------------------------------------
   4) AJOUT RAPIDE  (overlay au survol, au-dessus du lien étiré)
   Cible tactile >=44px. Visible au survol/focus, toujours accessible clavier.
   --------------------------------------------------------------------- */
.tl-card__quick{
  position:absolute;
  left:var(--tl-sp-3);
  right:var(--tl-sp-3);
  bottom:var(--tl-sp-3);
  z-index:3;
  display:flex;
  gap:var(--tl-sp-2);
  opacity:0;
  transform:translateY(8px);
  transition:opacity var(--tl-dur) var(--tl-ease),
             transform var(--tl-dur) var(--tl-ease);
}
/* Révélation au survol de la carte ou au focus clavier d'une action interne */
@media (hover:hover){
  .tl-card:hover .tl-card__quick{ opacity:1;transform:none; }
}
.tl-card__quick:focus-within{ opacity:1;transform:none; }
/* Sur tactile (pas de survol fin) : toujours visible pour rester atteignable */
@media (hover:none){
  .tl-card__quick{ opacity:1;transform:none; position:static;
    margin-top:auto; padding:0 var(--tl-sp-4) var(--tl-sp-4); }
}
@media (prefers-reduced-motion:reduce){
  .tl-card__quick{ transition:none; transform:none; }
}

.tl-card__add{
  appearance:none;-webkit-appearance:none;
  border:0;margin:0;cursor:pointer;
  flex:1 1 auto;
  min-height:44px;
  padding:0 var(--tl-sp-4);
  border-radius:var(--tl-r-pill);
  background:var(--tl-amber);
  color:var(--tl-forest);        /* CTA ambre => texte vert forêt foncé (AA) */
  font-family:var(--tl-font-body);
  font-weight:700;
  font-size:14px;
  letter-spacing:.01em;
  display:inline-flex;align-items:center;justify-content:center;gap:var(--tl-sp-2);
  white-space:nowrap;
  transition:background var(--tl-dur) var(--tl-ease),transform var(--tl-dur) var(--tl-ease);
}
.tl-card__add-icon{
  width:18px;height:18px;display:block;pointer-events:none;flex:none;
  background:currentColor;
  -webkit-mask:var(--tl-ico-cart) center/contain no-repeat;
  mask:var(--tl-ico-cart) center/contain no-repeat;
}
.tl-card__add:hover{ background:var(--tl-gold); }
.tl-card__add:active{ transform:translateY(1px); }
.tl-card__add:focus-visible{
  outline:3px solid var(--tl-forest);
  outline-offset:2px;
}
[data-tl-theme="dark"] .tl-card__add:focus-visible{ outline-color:var(--tl-gold); }
/* Chargement : libellé masqué, spinner forêt sur fond ambre */
.tl-card__add.is-loading{ color:transparent;position:relative;pointer-events:none; }
.tl-card__add.is-loading::after{
  content:"";position:absolute;width:18px;height:18px;
  border-radius:50%;border:2px solid rgba(10,31,19,.3);border-top-color:var(--tl-forest);
  animation:tl-spin .7s linear infinite;
}
/* Succès : confirmation textuelle + couleur succès (pas la couleur seule) */
.tl-card__add.is-success{ background:var(--tl-success);color:var(--tl-white); }
.tl-card__add.is-success .tl-card__add-icon{
  -webkit-mask:var(--tl-ico-cart) center/contain no-repeat;
  mask:var(--tl-ico-cart) center/contain no-repeat;
}

/* Bouton "aperçu rapide" secondaire (icône seule, label accessible) */
.tl-card__peek{
  appearance:none;-webkit-appearance:none;
  border:0;margin:0;cursor:pointer;
  flex:none;
  width:44px;height:44px;
  display:inline-flex;align-items:center;justify-content:center;
  border-radius:var(--tl-r-pill);
  background:var(--tl-white);
  color:var(--tl-ink-2);
  box-shadow:var(--tl-shadow-sm);
  transition:background var(--tl-dur) var(--tl-ease),color var(--tl-dur) var(--tl-ease);
}
.tl-card__peek-icon{
  width:20px;height:20px;display:block;pointer-events:none;
  background:currentColor;
  -webkit-mask:var(--tl-ico-eye) center/contain no-repeat;
  mask:var(--tl-ico-eye) center/contain no-repeat;
}
.tl-card__peek:hover{ background:var(--tl-cream); color:var(--tl-green); }
.tl-card__peek:focus-visible{
  outline:3px solid var(--tl-gold);
  outline-offset:2px;
  box-shadow:0 0 0 2px var(--tl-forest),var(--tl-shadow-sm);
}

/* ---------------------------------------------------------------------
   5) CORPS  (catégorie, nom + lien étiré, note, prix)
   --------------------------------------------------------------------- */
.tl-card__body{
  display:flex;
  flex-direction:column;
  gap:var(--tl-sp-2);
  padding:var(--tl-sp-4);
  flex:1 1 auto;
}
.tl-card__cat{
  font-family:var(--tl-font-mono);
  font-size:11px;
  font-weight:600;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--tl-copper-text);   /* cuivre texte = AA petit texte */
  margin:0;
}
.tl-card__title{
  font-family:var(--tl-font-display);
  font-size:17px;
  font-weight:600;
  line-height:1.25;
  letter-spacing:-.01em;
  color:var(--tl-text);
  margin:0;
}
/* LIEN ÉTIRÉ : le <a> du titre couvre toute la carte (::after).
   z-index 1 reste SOUS les actions (coeur z4 / quick z3 / flags z3). */
.tl-card__link{
  color:inherit;
  text-decoration:none;
  border-radius:2px;
}
.tl-card__link::after{
  content:"";
  position:absolute;
  inset:0;
  z-index:1;
  border-radius:inherit;
}
.tl-card__link:hover{ color:var(--tl-green-600); }
/* L'anneau de focus est porté par la CARTE (:has) pour englober tout
   le lien étiré ; on neutralise l'outline par défaut du <a> ici. */
.tl-card__link:focus-visible{ outline:none; }
/* Repli si :has() non supporté : anneau sur le titre lui-même */
@supports not selector(:has(*)){
  .tl-card__link:focus-visible{
    outline:3px solid var(--tl-gold);
    outline-offset:3px;
    box-shadow:0 0 0 2px var(--tl-forest);
  }
}

.tl-card__rating{ margin-top:-2px; }

/* Le bloc prix est poussé en bas pour aligner les cartes d'une grille */
.tl-card__price{ margin-top:auto; padding-top:var(--tl-sp-1); }
.tl-card__price .tl-price__current{ font-size:22px; }
.tl-card__price .tl-price__old{ font-size:14px; }

/* ---------------------------------------------------------------------
   6) ÉTAT ÉPUISÉ  (désactivé)
   Visuel grisé, actions inertes, mention textuelle explicite.
   --------------------------------------------------------------------- */
.tl-card--out .tl-card__img,
.tl-card--out .tl-card__placeholder{
  filter:grayscale(.85) opacity(.65);
}
.tl-card--out .tl-card__media::after{
  content:"";
  position:absolute;inset:0;
  background:rgba(246,241,231,.35);
  pointer-events:none;
}
[data-tl-theme="dark"] .tl-card--out .tl-card__media::after{
  background:rgba(10,31,19,.45);
}
/* L'ajout rapide est désactivé : on neutralise et on grise (token grey) */
.tl-card--out .tl-card__add[disabled],
.tl-card--out .tl-card__add[aria-disabled="true"]{
  background:var(--tl-grey);
  color:var(--tl-muted);
  cursor:not-allowed;
  pointer-events:none;
}
.tl-card--out .tl-card__add[disabled] .tl-card__add-icon,
.tl-card--out .tl-card__add[aria-disabled="true"] .tl-card__add-icon{
  display:none;
}

/* =====================================================================
   7) VARIANTE LISTE  (.tl-card--list) : média à gauche, corps à droite
   ===================================================================== */
.tl-card--list .tl-card__media{ aspect-ratio:1/1; }

@media (min-width:560px){
  .tl-card--list{
    flex-direction:row;
    align-items:stretch;
  }
  .tl-card--list .tl-card__media{
    flex:0 0 38%;
    max-width:240px;
    aspect-ratio:auto;
  }
  .tl-card--list .tl-card__body{
    gap:var(--tl-sp-3);
    padding:var(--tl-sp-5);
  }
  .tl-card--list .tl-card__desc{
    font-size:14px;
    color:var(--tl-text-soft);
    line-height:1.5;
    margin:0;
    display:-webkit-box;
    -webkit-line-clamp:2;
    -webkit-box-orient:vertical;
    overflow:hidden;
  }
  /* En liste, l'ajout rapide vit dans le corps (rangée de prix + CTA) */
  .tl-card--list .tl-card__quick{
    position:static;
    opacity:1;transform:none;
    margin-top:auto;
    padding:0;
    max-width:320px;
  }
  .tl-card--list .tl-card__spectral{ opacity:0; }
  @media (hover:hover){
    .tl-card--list:hover .tl-card__img{ transform:scale(1.04); }
  }
}
/* La description n'apparaît qu'en liste (cachée en grille) */
.tl-card:not(.tl-card--list) .tl-card__desc{ display:none; }

/* =====================================================================
   8) GRILLE D'ACCUEIL  (.tl-cards) — utilitaire de mise en page démo
   ===================================================================== */
.tl-cards{
  display:grid;
  grid-template-columns:1fr;
  gap:var(--tl-sp-4);
}
@media (min-width:560px){
  .tl-cards{ grid-template-columns:repeat(2,1fr); gap:var(--tl-sp-5); }
}
@media (min-width:900px){
  .tl-cards{ grid-template-columns:repeat(3,1fr); }
}
@media (min-width:1180px){
  .tl-cards--4{ grid-template-columns:repeat(4,1fr); }
}
/* La pile liste reste sur une colonne */
.tl-cards--list{ display:flex; flex-direction:column; gap:var(--tl-sp-4); }

/* =====================================================================
   9) THÈMES sombre / crème — héritent surtout des tokens
   ===================================================================== */
/* --tl-text vaut #eaf3ec sous le thème sombre : on réutilise le token. */
[data-tl-theme="dark"] .tl-card__wish{ background:rgba(16,41,26,.92); color:var(--tl-text); }
[data-tl-theme="dark"] .tl-card__peek{ background:var(--tl-forest-2); color:var(--tl-text); }
[data-tl-theme="dark"] .tl-card__peek:hover{ background:var(--tl-forest); color:var(--tl-gold); }
[data-tl-theme="dark"] .tl-card__cat{ color:var(--tl-gold); }
[data-tl-theme="dark"] .tl-card__placeholder{ background:var(--tl-forest-2); color:var(--tl-text); }
[data-tl-theme="dark"] .tl-card__placeholder-text{ color:var(--tl-gold); }

@keyframes tl-spin{ to{ transform:rotate(360deg); } }

/* =====================================================================
   10) Responsive (mobile-first : base = mobile ci-dessus)
   ===================================================================== */
@media (min-width:900px){
  .tl-card__title{ font-size:18px; }
  .tl-card__price .tl-price__current{ font-size:24px; }
}
/* quantity-price */
/* =====================================================================
   TerraLED — Famille "Quantité, prix & stock" (Spectre Vivant)
   CSS pur. Tokens --tl-* exclusivement. BEM préfixe .tl-.
   Sélecteur de quantité, prix, badges stock, chip compte à rebours, "dès XX €".
   ===================================================================== */

/* ---------------------------------------------------------------------
   1) SÉLECTEUR DE QUANTITÉ  (- N +)
   --------------------------------------------------------------------- */
.tl-qty{
  display:inline-flex;
  align-items:stretch;
  border:1px solid var(--tl-border);
  border-radius:var(--tl-r-pill);
  background:var(--tl-surface);
  box-shadow:var(--tl-shadow-sm);
  isolation:isolate;
}
.tl-qty__btn{
  appearance:none;
  -webkit-appearance:none;
  border:0;
  margin:0;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:44px;
  min-height:44px;
  padding:0;
  background:transparent;
  color:var(--tl-text);
  font-family:var(--tl-font-body);
  font-size:20px;
  line-height:1;
  border-radius:var(--tl-r-pill);
  transition:background var(--tl-dur) var(--tl-ease),
             color var(--tl-dur) var(--tl-ease),
             transform var(--tl-dur) var(--tl-ease);
}
.tl-qty__btn svg{width:18px;height:18px;display:block}
.tl-qty__btn:hover{ background:var(--tl-green); color:var(--tl-white); }
.tl-qty__btn:active{ transform:scale(.94); }
.tl-qty__btn:focus-visible{
  outline:3px solid var(--tl-gold);
  outline-offset:2px;
  position:relative;
  z-index:1;
}
.tl-qty__btn[disabled],
.tl-qty__btn[aria-disabled="true"]{
  cursor:not-allowed;
  color:var(--tl-text-soft);
  opacity:.55;
}
.tl-qty__btn[disabled]:hover,
.tl-qty__btn[aria-disabled="true"]:hover{
  background:transparent;
  color:var(--tl-text-soft);
}
.tl-qty__field{
  appearance:textfield;
  -moz-appearance:textfield;
  width:3.25ch;
  min-width:44px;
  border:0;
  background:transparent;
  text-align:center;
  font-family:var(--tl-font-mono);
  font-weight:600;
  font-size:16px;            /* >=16px : évite le zoom auto iOS */
  color:var(--tl-text);
  padding:0 var(--tl-sp-1);
}
.tl-qty__field::-webkit-outer-spin-button,
.tl-qty__field::-webkit-inner-spin-button{ -webkit-appearance:none; margin:0; }
.tl-qty__field:focus-visible{
  outline:3px solid var(--tl-gold);
  outline-offset:-2px;
  border-radius:var(--tl-r-sm);
}
.tl-qty__field[disabled]{ color:var(--tl-text-soft); }

/* États du groupe entier */
.tl-qty.is-loading{ position:relative; pointer-events:none; }
.tl-qty.is-loading .tl-qty__field{ visibility:hidden; }
.tl-qty.is-loading::after{
  content:"";
  position:absolute;
  top:50%; left:50%;
  width:18px; height:18px;
  margin:-9px 0 0 -9px;
  border-radius:50%;
  border:2px solid var(--tl-border);
  border-top-color:var(--tl-primary);
  animation:tl-spin .7s linear infinite;
}
.tl-qty.is-error{ border-color:var(--tl-danger); }
.tl-qty.is-error .tl-qty__field{ color:var(--tl-danger); }
.tl-qty__msg{
  display:block;
  font-family:var(--tl-font-body);
  font-size:13px;
  margin-top:var(--tl-sp-2);
  color:var(--tl-danger);
}
.tl-qty__msg--success{ color:var(--tl-success); }
.tl-qty__msg::before{
  content:"";
  display:inline-block;
  width:1em; height:1em;
  margin-right:.35em;
  vertical-align:-.12em;
  background:currentColor;
  -webkit-mask:var(--tl-ico-alert) center/contain no-repeat;
  mask:var(--tl-ico-alert) center/contain no-repeat;
}
.tl-qty__msg--success::before{
  -webkit-mask:var(--tl-ico-check) center/contain no-repeat;
  mask:var(--tl-ico-check) center/contain no-repeat;
}

@keyframes tl-spin{ to{ transform:rotate(360deg); } }

/* ---------------------------------------------------------------------
   2) PRIX  (actuel, barré, -%, prix unitaire, éco-participation)
   --------------------------------------------------------------------- */
.tl-price{
  display:flex;
  flex-wrap:wrap;
  align-items:baseline;
  gap:var(--tl-sp-2) var(--tl-sp-3);
  font-family:var(--tl-font-body);
}
.tl-price__current{
  font-family:var(--tl-font-display);
  font-weight:600;
  font-size:32px;
  line-height:1;
  letter-spacing:-.015em;
  color:var(--tl-text);
}
.tl-price__current--promo{ color:var(--tl-danger); }
.tl-price__old{
  font-size:16px;
  color:var(--tl-text-soft);
  text-decoration:line-through;
  text-decoration-thickness:1.5px;
}
/* "économisez" : étiquette explicite, pas seulement la couleur */
.tl-price__save{
  display:inline-flex;
  align-items:center;
  gap:6px;
  font-family:var(--tl-font-mono);
  font-weight:600;
  font-size:12px;
  letter-spacing:.04em;
  padding:5px 10px;
  border-radius:var(--tl-r-pill);
  color:var(--tl-white);
  background:var(--tl-danger);
}
.tl-price__unit,
.tl-price__eco{
  flex-basis:100%;
  font-size:13px;
  color:var(--tl-text-soft);
  margin:0;
}
.tl-price__eco{ display:inline-flex; align-items:center; gap:6px; flex-basis:auto; }
.tl-price__eco::before{
  content:"";
  width:1em; height:1em;
  background:var(--tl-primary);
  -webkit-mask:var(--tl-ico-leaf) center/contain no-repeat;
  mask:var(--tl-ico-leaf) center/contain no-repeat;
}
.tl-price__from{
  font-family:var(--tl-font-mono);
  font-size:12px;
  letter-spacing:.04em;
  text-transform:uppercase;
  color:var(--tl-copper-text);   /* cuivre lisible AA en petit texte */
  margin-right:2px;
}
/* "dès XX €" : variante compacte autonome */
.tl-price--from .tl-price__current{ font-size:24px; }

/* ---------------------------------------------------------------------
   3) BADGES DE STOCK
   couleur + icône + texte (jamais la couleur seule)
   --------------------------------------------------------------------- */
.tl-stock{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-family:var(--tl-font-body);
  font-weight:600;
  font-size:13px;
  line-height:1.2;
  padding:6px 12px;
  border-radius:var(--tl-r-pill);
  border:1px solid transparent;
}
.tl-stock__dot{
  flex:0 0 auto;
  width:9px; height:9px;
  border-radius:50%;
  background:currentColor;
}
.tl-stock__ico{
  flex:0 0 auto;
  width:1em; height:1em;
  background:currentColor;
}
/* En stock */
.tl-stock--in{
  color:var(--tl-instock);
  background:color-mix(in srgb, var(--tl-instock) 12%, transparent);
  border-color:color-mix(in srgb, var(--tl-instock) 28%, transparent);
}
/* Stock faible */
.tl-stock--low{
  color:var(--tl-lowstock);
  background:color-mix(in srgb, var(--tl-lowstock) 14%, transparent);
  border-color:color-mix(in srgb, var(--tl-lowstock) 32%, transparent);
}
.tl-stock--low .tl-stock__dot{ animation:tl-pulse 1.6s var(--tl-ease) infinite; }
/* Épuisé */
.tl-stock--out{
  color:var(--tl-outstock);
  background:color-mix(in srgb, var(--tl-outstock) 12%, transparent);
  border-color:color-mix(in srgb, var(--tl-outstock) 30%, transparent);
}
/* Précommande */
.tl-stock--pre{
  color:var(--tl-info);
  background:color-mix(in srgb, var(--tl-info) 12%, transparent);
  border-color:color-mix(in srgb, var(--tl-info) 30%, transparent);
}
.tl-stock__ico--in{ -webkit-mask:var(--tl-ico-check) center/contain no-repeat; mask:var(--tl-ico-check) center/contain no-repeat; }
.tl-stock__ico--low{ -webkit-mask:var(--tl-ico-alert) center/contain no-repeat; mask:var(--tl-ico-alert) center/contain no-repeat; }
.tl-stock__ico--out{ -webkit-mask:var(--tl-ico-cross) center/contain no-repeat; mask:var(--tl-ico-cross) center/contain no-repeat; }
.tl-stock__ico--pre{ -webkit-mask:var(--tl-ico-clock) center/contain no-repeat; mask:var(--tl-ico-clock) center/contain no-repeat; }

/* Sur fond sombre : les fonds color-mix restent lisibles, on éclaircit le texte
   (les tokens sémantiques sont calibrés pour fond clair ; ces 3 teintes sont le
    seul code couleur en dur, justifié par le contraste AA sur var(--tl-forest-2)) */
[data-tl-theme="dark"] .tl-stock--in{ color:#5fd08a; }
[data-tl-theme="dark"] .tl-stock--low{ color:var(--tl-gold); }
[data-tl-theme="dark"] .tl-stock--out{ color:#f0816f; }
[data-tl-theme="dark"] .tl-stock--pre{ color:#7ba7ff; }

@keyframes tl-pulse{ 0%,100%{opacity:1} 50%{opacity:.35} }

/* ---------------------------------------------------------------------
   4) CHIP COMPTE À REBOURS PROMO
   --------------------------------------------------------------------- */
.tl-countdown{
  display:inline-flex;
  align-items:center;
  gap:var(--tl-sp-2);
  padding:7px 14px;
  border-radius:var(--tl-r-pill);
  background:var(--tl-forest);
  color:var(--tl-cream);
  font-family:var(--tl-font-body);
  font-size:13px;
  font-weight:600;
  position:relative;
  overflow:hidden;
}
.tl-countdown__ico{
  width:16px; height:16px;
  background:var(--tl-gold);   /* gold = décor sur fond sombre : OK */
  -webkit-mask:var(--tl-ico-clock) center/contain no-repeat;
  mask:var(--tl-ico-clock) center/contain no-repeat;
}
.tl-countdown__label{ color:var(--tl-gold); letter-spacing:.02em; }
.tl-countdown__time{
  font-family:var(--tl-font-mono);
  font-variant-numeric:tabular-nums;
  font-weight:600;
  letter-spacing:.06em;
}
/* trait spectral DÉCORATIF, jamais seul porteur de sens (aria-hidden) */
.tl-countdown__spectral{
  position:absolute;
  left:0; right:0; bottom:0;
  height:3px;
  background:var(--tl-spectral);
  opacity:.9;
}
.tl-countdown.is-ending .tl-countdown__time{ animation:tl-pulse 1s var(--tl-ease) infinite; }

/* ---------------------------------------------------------------------
   5) BLOC PRIX D'ACHAT (assemblage type fiche produit) — utilitaire démo
   --------------------------------------------------------------------- */
.tl-buy{
  display:flex;
  flex-direction:column;
  gap:var(--tl-sp-4);
  padding:var(--tl-sp-5);
  border:1px solid var(--tl-border);
  border-radius:var(--tl-r-lg);
  background:var(--tl-surface);
  box-shadow:var(--tl-shadow-sm);
  max-width:380px;
}
.tl-buy__row{ display:flex; flex-wrap:wrap; align-items:center; gap:var(--tl-sp-3); }
.tl-buy__cta{
  appearance:none; -webkit-appearance:none;
  border:0; cursor:pointer;
  flex:1 1 auto;
  min-height:48px;
  padding:0 var(--tl-sp-5);
  border-radius:var(--tl-r-pill);
  background:var(--tl-amber);
  color:var(--tl-forest);        /* CTA ambre => texte vert forêt foncé */
  font-family:var(--tl-font-body);
  font-weight:700;
  font-size:15px;
  letter-spacing:.01em;
  display:inline-flex; align-items:center; justify-content:center; gap:var(--tl-sp-2);
  transition:background var(--tl-dur) var(--tl-ease), transform var(--tl-dur) var(--tl-ease);
}
.tl-buy__cta:hover{ background:var(--tl-gold); }
.tl-buy__cta:active{ transform:translateY(1px); }
.tl-buy__cta:focus-visible{ outline:3px solid var(--tl-forest); outline-offset:2px; }
[data-tl-theme="dark"] .tl-buy__cta:focus-visible{ outline-color:var(--tl-gold); }
.tl-buy__cta[disabled],
.tl-buy__cta[aria-disabled="true"]{
  background:var(--tl-grey);
  color:var(--tl-muted);
  cursor:not-allowed;
}
.tl-buy__cta.is-loading{ color:transparent; position:relative; pointer-events:none; }
.tl-buy__cta.is-loading::after{
  content:""; position:absolute; width:18px; height:18px;
  border-radius:50%; border:2px solid rgba(10,31,19,.3); border-top-color:var(--tl-forest);
  animation:tl-spin .7s linear infinite;
}

/* ---------------------------------------------------------------------
   Icônes (masques data-URI) — partagées par la famille.
   Posées sur un conteneur .tl-qps pour rester locales aux composants.
   --------------------------------------------------------------------- */
.tl-qps{
  --tl-ico-check:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="black" stroke-width="2.6" stroke-linecap="round" stroke-linejoin="round"><path d="M20 6 9 17l-5-5"/></svg>');
  --tl-ico-cross:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="black" stroke-width="2.6" stroke-linecap="round" stroke-linejoin="round"><path d="M18 6 6 18M6 6l12 12"/></svg>');
  --tl-ico-alert:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="black" stroke-width="2.6" stroke-linecap="round" stroke-linejoin="round"><path d="M12 9v4M12 17h.01M10.3 3.9 1.8 18a2 2 0 0 0 1.7 3h17a2 2 0 0 0 1.7-3L13.7 3.9a2 2 0 0 0-3.4 0Z"/></svg>');
  --tl-ico-clock:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="black" stroke-width="2.4" stroke-linecap="round" stroke-linejoin="round"><circle cx="12" cy="12" r="9"/><path d="M12 7v5l3 2"/></svg>');
  --tl-ico-leaf:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="black" stroke-width="2.2" stroke-linecap="round" stroke-linejoin="round"><path d="M11 20A7 7 0 0 1 4 13c0-6 7-9 16-9 0 9-3 16-9 16Z"/><path d="M4 20c2-4 5-7 9-9"/></svg>');
}

/* ---------------------------------------------------------------------
   Responsive (mobile-first : la base ci-dessus est mobile ; ici la montée)
   --------------------------------------------------------------------- */
@media (min-width:600px){
  .tl-price__current{ font-size:36px; }
  .tl-price__unit,.tl-price__eco{ flex-basis:auto; }
}
/* nav */
/* =========================================================================
   TerraLED — Famille "Navigation" ("Spectre Vivant")
   Fil d'ariane (BreadcrumbList) · Pagination numérotée · Bouton "voir plus"
   · Onglets desktop (tablist) -> accordéon <details> en mobile.
   CSS PUR. Tokens --tl-* exclusivement. BEM préfixe .tl-.
   États : :hover, :focus-visible (anneau or >=3:1 doublé d'un liseré forêt,
   jamais le spectre seul), :active, [disabled]/[aria-disabled], chargement,
   erreur, succès. Mobile-first. Trait spectral = DÉCOR (aria-hidden).
   ========================================================================= */

/* utilitaire commun (peut déjà exister ailleurs : inoffensif si dupliqué) */
.tl-u-visually-hidden{
  position:absolute;
  width:1px;height:1px;
  padding:0;margin:-1px;
  overflow:hidden;
  clip:rect(0 0 0 0);
  white-space:nowrap;border:0;
}

/* spinner partagé (réutilisé par "voir plus") */
@keyframes tl-spin{ to{ transform:rotate(360deg); } }

/* =========================================================================
   0) Icônes (masques data-URI) portées par la famille navigation
   ========================================================================= */
.tl-breadcrumb,
.tl-pager,
.tl-loadmore,
.tl-tabs{
  --tl-ico-chevron:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="black" stroke-width="2.4" stroke-linecap="round" stroke-linejoin="round"><path d="M9 6l6 6-6 6"/></svg>');
  --tl-ico-home:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="black" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M3 11.5 12 4l9 7.5"/><path d="M5 10v9.5h14V10"/></svg>');
  --tl-ico-plus:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="black" stroke-width="2.4" stroke-linecap="round" stroke-linejoin="round"><path d="M12 5v14M5 12h14"/></svg>');
}

/* =========================================================================
   1) FIL D'ARIANE  (.tl-breadcrumb) — <nav><ol> BreadcrumbList sémantique
   Séparateur chevron DÉCORATIF (::after, aria-hidden côté markup non requis
   car généré en CSS). Dernier item = page courante (aria-current="page").
   ========================================================================= */
.tl-breadcrumb{
  font-family:var(--tl-font-body);
  font-size:13px;
  line-height:1.4;
  color:var(--tl-text-soft);
}
.tl-breadcrumb__list{
  list-style:none;
  margin:0;
  padding:0;
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:var(--tl-sp-1) var(--tl-sp-2);
}
.tl-breadcrumb__item{
  display:inline-flex;
  align-items:center;
  gap:var(--tl-sp-1) var(--tl-sp-2);
  min-width:0;                    /* autorise l'ellipsis sur le lien */
}
/* séparateur chevron décoratif entre items (pas sur le premier) */
.tl-breadcrumb__item + .tl-breadcrumb__item::before{
  content:"";
  width:14px;height:14px;
  flex:none;
  background:var(--tl-line);
  -webkit-mask:var(--tl-ico-chevron) center/contain no-repeat;
  mask:var(--tl-ico-chevron) center/contain no-repeat;
}

/* lien d'un maillon */
.tl-breadcrumb__link{
  display:inline-flex;
  align-items:center;
  gap:var(--tl-sp-1);
  color:var(--tl-text-soft);
  text-decoration:none;
  border-radius:var(--tl-r-sm);
  padding:2px 4px;
  margin:-2px -4px;               /* compense le padding pour aligner le texte */
  max-width:200px;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
  transition:color var(--tl-dur) var(--tl-ease),
             background var(--tl-dur) var(--tl-ease);
}
.tl-breadcrumb__link:hover{
  color:var(--tl-green-600);
  text-decoration:underline;
  text-underline-offset:2px;
}
.tl-breadcrumb__link:active{ color:var(--tl-green); }
.tl-breadcrumb__link:focus-visible{
  outline:2px solid var(--tl-gold);
  outline-offset:2px;
  box-shadow:0 0 0 2px var(--tl-forest), 0 0 0 5px var(--tl-gold);
  color:var(--tl-text);
}

/* maillon "Accueil" : icône maison + libellé visible (ou caché si demandé) */
.tl-breadcrumb__home-icon{
  width:15px;height:15px;
  display:block;flex:none;
  background:currentColor;
  -webkit-mask:var(--tl-ico-home) center/contain no-repeat;
  mask:var(--tl-ico-home) center/contain no-repeat;
}

/* page courante (aria-current="page") : non cliquable, accentuée par le poids
   et la couleur d'encre (sens porté par aria-current + le poids, pas la teinte
   seule). */
.tl-breadcrumb__current{
  color:var(--tl-text);
  font-weight:700;
  max-width:240px;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}

/* thèmes : sur sombre les liens deviennent or au survol (gros décor OK) */
[data-tl-theme="dark"] .tl-breadcrumb__item + .tl-breadcrumb__item::before{
  background:rgba(255,255,255,.28);
}
[data-tl-theme="dark"] .tl-breadcrumb__link:hover{ color:var(--tl-gold); }
[data-tl-theme="dark"] .tl-breadcrumb__link:focus-visible{
  box-shadow:0 0 0 2px var(--tl-forest), 0 0 0 5px var(--tl-gold);
}

/* Sur très petit écran, on peut replier les maillons intermédiaires : la
   classe utilitaire .tl-breadcrumb__item--collapsible se masque sous 480px.
   Le markup doit alors fournir un maillon "…" toujours visible. */
@media (max-width:479px){
  .tl-breadcrumb__item--collapsible{ display:none; }
  .tl-breadcrumb__link{ max-width:140px; }
}

/* =========================================================================
   2) PAGINATION  (.tl-pager) — <nav><ul> + page courante aria-current="page"
   Cibles tactiles >=44px. Précédent/suivant avec libellé accessible.
   ========================================================================= */
.tl-pager{
  font-family:var(--tl-font-body);
}
.tl-pager__list{
  list-style:none;
  margin:0;
  padding:0;
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  justify-content:center;
  gap:var(--tl-sp-2);
}
.tl-pager__item{ display:inline-flex; }

/* maillon générique (numéro, flèche, ellipsis) : socle commun >=44px */
.tl-pager__link,
.tl-pager__current,
.tl-pager__ellipsis{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:var(--tl-sp-2);
  min-width:44px;
  min-height:44px;
  padding:0 var(--tl-sp-2);
  border-radius:var(--tl-r-sm);
  font-size:14px;
  font-weight:600;
  font-variant-numeric:tabular-nums;
  line-height:1;
  border:1px solid transparent;
  box-sizing:border-box;
}

/* numéro cliquable */
.tl-pager__link{
  color:var(--tl-text);
  background:var(--tl-surface);
  border-color:var(--tl-border);
  text-decoration:none;
  cursor:pointer;
  transition:background var(--tl-dur) var(--tl-ease),
             border-color var(--tl-dur) var(--tl-ease),
             color var(--tl-dur) var(--tl-ease),
             transform var(--tl-dur) var(--tl-ease);
}
.tl-pager__link:hover{
  background:rgba(23,96,53,.07);
  border-color:var(--tl-primary);
  color:var(--tl-green-600);
}
.tl-pager__link:active{ transform:translateY(1px); }
.tl-pager__link:focus-visible{
  outline:2px solid var(--tl-gold);
  outline-offset:2px;
  box-shadow:0 0 0 2px var(--tl-forest), 0 0 0 5px var(--tl-gold);
  color:var(--tl-text);
}

/* page courante (aria-current="page") : pleine, vert primaire, non cliquable.
   Sens porté par aria-current + le contraste fort, pas par la couleur seule. */
.tl-pager__current{
  background:var(--tl-primary);
  color:var(--tl-white);
  border-color:var(--tl-primary);
  cursor:default;
  position:relative;
}
/* liseré spectral DÉCORATIF sous la page courante (aria-hidden côté markup,
   jamais seul porteur de sens : l'état est déjà donné par aria-current). */
.tl-pager__current::after{
  content:"";
  position:absolute;
  left:6px;right:6px;bottom:3px;
  height:2px;
  border-radius:var(--tl-r-pill);
  background:var(--tl-spectral);
  opacity:.9;
  pointer-events:none;
}

/* ellipsis (saut de pages) : statique, non focusable */
.tl-pager__ellipsis{
  color:var(--tl-text-soft);
  border-color:transparent;
  letter-spacing:.1em;
  min-width:32px;
}

/* précédent / suivant : libellé + flèche chevron décorative */
.tl-pager__nav{
  gap:var(--tl-sp-1);
  padding:0 var(--tl-sp-3);
  font-weight:700;
}
.tl-pager__nav-icon{
  width:16px;height:16px;
  display:block;flex:none;
  background:currentColor;
  -webkit-mask:var(--tl-ico-chevron) center/contain no-repeat;
  mask:var(--tl-ico-chevron) center/contain no-repeat;
}
.tl-pager__nav--prev .tl-pager__nav-icon{ transform:rotate(180deg); }

/* bornes désactivées (1re/dernière page) : <a aria-disabled> ou <span> */
.tl-pager__nav[aria-disabled="true"],
.tl-pager__nav[disabled]{
  color:var(--tl-text-soft);
  background:var(--tl-grey);
  border-color:var(--tl-border);
  opacity:.6;
  cursor:not-allowed;
  pointer-events:none;
}

/* libellé du nav : caché visuellement sous mobile (flèche seule), lisible AT */
@media (max-width:479px){
  .tl-pager__nav-label{
    position:absolute;width:1px;height:1px;padding:0;margin:-1px;
    overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0;
  }
  .tl-pager__nav{ min-width:44px; padding:0; }
  /* sur mobile on masque les numéros lointains via .tl-pager__item--far */
  .tl-pager__item--far{ display:none; }
}

/* thème sombre : surfaces forêt, survol or */
[data-tl-theme="dark"] .tl-pager__link{ background:var(--tl-surface); }
[data-tl-theme="dark"] .tl-pager__link:hover{
  border-color:var(--tl-gold);
  color:var(--tl-gold);
  background:rgba(255,255,255,.06);
}
[data-tl-theme="dark"] .tl-pager__nav[aria-disabled="true"],
[data-tl-theme="dark"] .tl-pager__nav[disabled]{
  background:rgba(255,255,255,.05);
}

@media (prefers-reduced-motion:reduce){
  .tl-pager__link{ transition:none; }
  .tl-pager__link:active{ transform:none; }
}

/* =========================================================================
   3) BOUTON "VOIR PLUS"  (.tl-loadmore) — charge la suite (infinite-ish)
   Cible >=44px. États chargement / erreur / succès (fin de liste).
   ========================================================================= */
.tl-loadmore{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:var(--tl-sp-3);
  font-family:var(--tl-font-body);
  text-align:center;
}

.tl-loadmore__btn{
  appearance:none;-webkit-appearance:none;
  border:1px solid var(--tl-primary);
  margin:0;
  cursor:pointer;
  min-height:44px;
  padding:0 var(--tl-sp-6);
  border-radius:var(--tl-r-pill);
  background:var(--tl-surface);
  color:var(--tl-green-600);
  font-family:var(--tl-font-body);
  font-weight:700;
  font-size:15px;
  letter-spacing:.01em;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:var(--tl-sp-2);
  position:relative;
  transition:background var(--tl-dur) var(--tl-ease),
             color var(--tl-dur) var(--tl-ease),
             border-color var(--tl-dur) var(--tl-ease),
             transform var(--tl-dur) var(--tl-ease);
}
.tl-loadmore__btn-icon{
  width:18px;height:18px;
  display:block;flex:none;pointer-events:none;
  background:currentColor;
  -webkit-mask:var(--tl-ico-plus) center/contain no-repeat;
  mask:var(--tl-ico-plus) center/contain no-repeat;
}
.tl-loadmore__btn:hover{
  background:var(--tl-primary);
  color:var(--tl-white);
}
.tl-loadmore__btn:active{ transform:translateY(1px); }
.tl-loadmore__btn:focus-visible{
  outline:2px solid var(--tl-gold);
  outline-offset:2px;
  box-shadow:0 0 0 2px var(--tl-forest), 0 0 0 5px var(--tl-gold);
}

/* chargement : libellé "Chargement…" conservé + spinner ; aria-busy côté markup.
   On masque l'icône plus et on insère un spinner avant le texte. */
.tl-loadmore__btn.is-loading{
  pointer-events:none;
  color:var(--tl-text-soft);
  border-color:var(--tl-border);
  background:var(--tl-surface);
}
.tl-loadmore__btn.is-loading .tl-loadmore__btn-icon{
  -webkit-mask:none;mask:none;
  background:transparent;
  width:16px;height:16px;
  border:2px solid currentColor;
  border-top-color:transparent;
  border-radius:50%;
  animation:tl-spin .7s linear infinite;
}

/* désactivé (aucune action) */
.tl-loadmore__btn[disabled],
.tl-loadmore__btn[aria-disabled="true"]{
  color:var(--tl-text-soft);
  background:var(--tl-grey);
  border-color:var(--tl-border);
  cursor:not-allowed;
  pointer-events:none;
}

/* compteur de progression : "24 sur 120 produits" (mono, cuivre texte AA) */
.tl-loadmore__count{
  font-family:var(--tl-font-mono);
  font-size:12px;
  letter-spacing:.04em;
  color:var(--tl-copper-text);
}
/* barre de progression décorative (le sens reste dans le texte du compteur) */
.tl-loadmore__progress{
  width:min(220px,60vw);
  height:4px;
  border-radius:var(--tl-r-pill);
  background:var(--tl-line);
  overflow:hidden;
}
.tl-loadmore__progress-bar{
  display:block;
  height:100%;
  border-radius:inherit;
  background:var(--tl-primary);
  transition:width var(--tl-dur) var(--tl-ease);
}

/* message d'ÉTAT (région live) : erreur / succès (fin de liste) */
.tl-loadmore__status{
  font-size:13px;
  font-weight:600;
  display:inline-flex;
  align-items:center;
  gap:var(--tl-sp-2);
}
.tl-loadmore__status::before{
  content:"";
  width:9px;height:9px;border-radius:var(--tl-r-pill);
  background:currentColor;flex:none;
}
/* erreur : couleur danger + le texte ("Échec du chargement, réessayer") porte
   le sens, pas la pastille seule. */
.tl-loadmore__status--error{ color:var(--tl-danger); }
/* succès / fin de liste : couleur succès + texte explicite */
.tl-loadmore__status--end{ color:var(--tl-success); }

/* sur erreur, le bouton se transforme en "Réessayer" (variante) */
.tl-loadmore__btn--retry{
  border-color:var(--tl-danger);
  color:var(--tl-danger);
}
.tl-loadmore__btn--retry:hover{
  background:var(--tl-danger);
  color:var(--tl-white);
}

/* thème sombre */
[data-tl-theme="dark"] .tl-loadmore__btn{ color:var(--tl-gold); border-color:var(--tl-border); }
[data-tl-theme="dark"] .tl-loadmore__btn:hover{ background:var(--tl-green-600); color:var(--tl-white); border-color:var(--tl-green-600); }
[data-tl-theme="dark"] .tl-loadmore__count{ color:var(--tl-gold); }

@media (prefers-reduced-motion:reduce){
  .tl-loadmore__btn{ transition:none; }
  .tl-loadmore__btn:active{ transform:none; }
  .tl-loadmore__btn.is-loading .tl-loadmore__btn-icon{ animation:none; }
  .tl-loadmore__progress-bar{ transition:none; }
}

/* =========================================================================
   4) ONGLETS  (.tl-tabs)
   Desktop : role="tablist" + role="tab" + role="tabpanel" (aria-selected).
   Mobile  : MARKUP DOUBLE — un bloc <details>/<summary> (accordéon natif)
             visible < 760px, le tablist visible >= 760px. Cette approche
             garde une sémantique native correcte des deux côtés sans JS
             pour l'accordéon. Le panneau "tab" et le panneau "accordéon"
             partagent le même contenu côté intégration (cf. démo).
   ========================================================================= */
.tl-tabs{
  font-family:var(--tl-font-body);
  color:var(--tl-text);
}

/* --- 4a) Mode ACCORDÉON (mobile-first, par défaut affiché) --------------- */
.tl-tabs__accordion{
  display:flex;
  flex-direction:column;
  gap:var(--tl-sp-2);
}
.tl-tabs__acc-item{
  border:1px solid var(--tl-border);
  border-radius:var(--tl-r);
  background:var(--tl-surface);
  overflow:hidden;
}
/* <summary> : en-tête cliquable >=44px, chevron décoratif qui pivote */
.tl-tabs__summary{
  list-style:none;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:var(--tl-sp-3);
  min-height:44px;
  padding:var(--tl-sp-3) var(--tl-sp-4);
  font-family:var(--tl-font-display);
  font-size:16px;
  font-weight:600;
  color:var(--tl-text);
  transition:background var(--tl-dur) var(--tl-ease),
             color var(--tl-dur) var(--tl-ease);
}
.tl-tabs__summary::-webkit-details-marker{ display:none; }
.tl-tabs__summary::marker{ content:""; }
.tl-tabs__summary-icon{
  width:18px;height:18px;
  display:block;flex:none;
  background:currentColor;
  -webkit-mask:var(--tl-ico-chevron) center/contain no-repeat;
  mask:var(--tl-ico-chevron) center/contain no-repeat;
  transform:rotate(90deg);
  transition:transform var(--tl-dur) var(--tl-ease);
}
.tl-tabs__acc-item[open] .tl-tabs__summary-icon{ transform:rotate(-90deg); }
.tl-tabs__summary:hover{
  background:rgba(23,96,53,.06);
  color:var(--tl-green-600);
}
.tl-tabs__acc-item[open] .tl-tabs__summary{ color:var(--tl-green-600); }
/* focus clavier porté par le <summary> */
.tl-tabs__summary:focus-visible{
  outline:2px solid var(--tl-gold);
  outline-offset:-2px;            /* anneau à l'intérieur du bord arrondi */
  box-shadow:inset 0 0 0 2px var(--tl-forest);
}
.tl-tabs__acc-panel{
  padding:0 var(--tl-sp-4) var(--tl-sp-4);
  font-size:14px;
  line-height:1.6;
  color:var(--tl-text-soft);
  border-top:1px solid var(--tl-border);
  padding-top:var(--tl-sp-4);
}

/* --- 4b) Mode TABLIST (desktop, masqué par défaut) ----------------------- */
.tl-tabs__tablist{
  display:none;                   /* activé >= 760px */
}

/* >= 760px : on bascule accordéon -> onglets */
@media (min-width:760px){
  .tl-tabs__accordion{ display:none; }

  .tl-tabs__tablist{
    display:flex;
    flex-wrap:wrap;
    gap:var(--tl-sp-1);
    position:relative;
    border-bottom:1px solid var(--tl-border);
    margin-bottom:var(--tl-sp-5);
  }

  .tl-tabs__tab{
    appearance:none;-webkit-appearance:none;
    border:0;
    margin:0;
    background:transparent;
    cursor:pointer;
    min-height:44px;
    padding:var(--tl-sp-3) var(--tl-sp-4);
    font-family:var(--tl-font-display);
    font-size:16px;
    font-weight:600;
    color:var(--tl-text-soft);
    position:relative;
    display:inline-flex;
    align-items:center;
    gap:var(--tl-sp-2);
    transition:color var(--tl-dur) var(--tl-ease),
               background var(--tl-dur) var(--tl-ease);
  }
  /* compteur optionnel dans l'onglet (ex "Avis (128)") */
  .tl-tabs__tab-count{
    font-family:var(--tl-font-mono);
    font-size:12px;
    font-weight:600;
    color:var(--tl-copper-text);
  }

  .tl-tabs__tab:hover{
    color:var(--tl-green-600);
    background:rgba(23,96,53,.05);
    border-top-left-radius:var(--tl-r-sm);
    border-top-right-radius:var(--tl-r-sm);
  }
  .tl-tabs__tab:focus-visible{
    outline:2px solid var(--tl-gold);
    outline-offset:-3px;
    box-shadow:inset 0 0 0 2px var(--tl-forest);
    border-radius:var(--tl-r-sm);
    color:var(--tl-text);
  }

  /* onglet sélectionné (aria-selected="true") : encre forte + soulignement.
     Le SENS est donné par aria-selected + le poids/couleur d'encre. Le trait
     spectral décoratif vient EN PLUS, jamais seul. */
  .tl-tabs__tab[aria-selected="true"]{
    color:var(--tl-text);
  }
  .tl-tabs__tab[aria-selected="true"] .tl-tabs__tab-count{
    color:var(--tl-green-600);
  }
  /* soulignement porteur de l'état actif (épais, encre) */
  .tl-tabs__tab[aria-selected="true"]::before{
    content:"";
    position:absolute;
    left:var(--tl-sp-3);
    right:var(--tl-sp-3);
    bottom:-1px;
    height:3px;
    border-radius:var(--tl-r-pill);
    background:var(--tl-primary);
  }
  /* trait spectral DÉCORATIF par-dessus (aria-hidden côté markup non requis,
     généré en CSS). Pose une touche de marque sans porter le sens. */
  .tl-tabs__tab[aria-selected="true"]::after{
    content:"";
    position:absolute;
    left:var(--tl-sp-3);
    right:var(--tl-sp-3);
    bottom:-1px;
    height:3px;
    border-radius:var(--tl-r-pill);
    background:var(--tl-spectral);
    opacity:.55;
    mix-blend-mode:normal;
    pointer-events:none;
  }

  /* onglet désactivé */
  .tl-tabs__tab[disabled],
  .tl-tabs__tab[aria-disabled="true"]{
    color:var(--tl-text-soft);
    opacity:.5;
    cursor:not-allowed;
    pointer-events:none;
  }

  /* panneaux : seul le panneau actif est affiché (les autres ont [hidden]) */
  .tl-tabs__panel{
    font-size:15px;
    line-height:1.65;
    color:var(--tl-text);
    outline:none;                 /* panneau focusable (tabindex=0) sans bord disgracieux */
  }
  .tl-tabs__panel:focus-visible{
    outline:2px solid var(--tl-gold);
    outline-offset:4px;
    box-shadow:0 0 0 2px var(--tl-forest), 0 0 0 5px var(--tl-gold);
    border-radius:var(--tl-r-sm);
  }
}

/* thème sombre : onglets et accordéon */
[data-tl-theme="dark"] .tl-tabs__acc-item{ background:var(--tl-surface); }
[data-tl-theme="dark"] .tl-tabs__summary:hover{ color:var(--tl-gold); background:rgba(255,255,255,.05); }
[data-tl-theme="dark"] .tl-tabs__acc-item[open] .tl-tabs__summary{ color:var(--tl-gold); }
[data-tl-theme="dark"] .tl-tabs__summary:focus-visible{ box-shadow:inset 0 0 0 2px var(--tl-forest); }
@media (min-width:760px){
  [data-tl-theme="dark"] .tl-tabs__tab:hover{ color:var(--tl-gold); background:rgba(255,255,255,.05); }
  [data-tl-theme="dark"] .tl-tabs__tab[aria-selected="true"]{ color:var(--tl-text); }
  [data-tl-theme="dark"] .tl-tabs__tab[aria-selected="true"] .tl-tabs__tab-count{ color:var(--tl-gold); }
  [data-tl-theme="dark"] .tl-tabs__tab[aria-selected="true"]::before{ background:var(--tl-gold); }
}

@media (prefers-reduced-motion:reduce){
  .tl-tabs__summary,
  .tl-tabs__summary-icon,
  .tl-tabs__tab{ transition:none; }
}

/* =========================================================================
   5) Conteneur de mise en page démo (styleguide) — non lié aux composants
   ========================================================================= */
.tl-nav-demo-row{
  display:flex;
  flex-direction:column;
  gap:var(--tl-sp-5);
}
.tl-nav-demo-panel{
  padding:var(--tl-sp-5);
  border-radius:var(--tl-r-lg);
  border:1px solid var(--tl-border);
  background:var(--tl-bg);
}
[data-tl-theme="dark"].tl-nav-demo-panel,
[data-tl-theme="cream"].tl-nav-demo-panel{
  background:var(--tl-bg);
  color:var(--tl-text);
}
/* category */
/* ===== TerraLED — Page catégorie : bannière, facettes, tri, pagination ===== */
.tl-cathero{position:relative;color:#fff;overflow:hidden;isolation:isolate;border-radius:0}
.tl-cathero__bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2}
.tl-cathero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,31,19,.45),rgba(10,31,19,.86));z-index:-1}
.tl-cathero__in{max-width:1240px;margin:0 auto;padding:34px 24px 30px}
.tl-cathero h1{font-family:var(--tl-font-display);font-size:clamp(28px,4vw,42px);font-weight:600;color:#fff;margin:10px 0 8px}
.tl-cathero__count{font-family:var(--tl-font-mono);font-size:12px;letter-spacing:.06em;color:#cfe2d6;text-transform:uppercase}
.tl-cathero__desc{max-width:640px;color:#cfe2d6;font-size:15px;margin-top:10px}
.tl-cathero .tl-spectral-line{margin-top:14px}

/* fil d'ariane sur fond sombre */
.tl-cathero .tl-breadcrumb a,.tl-cathero .tl-breadcrumb span{color:#cfe2d6}

/* sous-catégories en chips */
.tl-subcats{display:flex;gap:10px;flex-wrap:wrap;margin:20px 0 0}
.tl-subcat{font-family:var(--tl-font-mono);font-size:12px;letter-spacing:.04em;text-transform:uppercase;color:var(--tl-text);background:var(--tl-surface);border:1px solid var(--tl-border);border-radius:var(--tl-r-pill);padding:8px 14px;text-decoration:none;transition:.18s}
.tl-subcat:hover,.tl-subcat[aria-current="true"]{border-color:var(--tl-green);color:var(--tl-green)}

/* layout listing */
.tl-listing{max-width:1240px;margin:0 auto;padding:28px 24px 64px;display:grid;grid-template-columns:268px 1fr;gap:32px;align-items:start}
.tl-facets{position:sticky;top:96px}
.tl-facets__head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.tl-facets__head h2{font-family:var(--tl-font-mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--tl-copper-text);margin:0}
.tl-facet{border-top:1px solid var(--tl-border)}
.tl-facet>summary{list-style:none;cursor:pointer;display:flex;justify-content:space-between;align-items:center;padding:14px 0;font-family:var(--tl-font-display);font-weight:600;font-size:15px}
.tl-facet>summary::-webkit-details-marker{display:none}
.tl-facet>summary::after{content:"−";color:var(--tl-copper);font-family:var(--tl-font-mono)}
.tl-facet:not([open])>summary::after{content:"+"}
.tl-facet__body{padding:0 0 16px}
.tl-facet .tl-choice-list{display:flex;flex-direction:column;gap:10px}
.tl-facet__count{margin-left:auto;font-family:var(--tl-font-mono);font-size:11px;color:var(--tl-text-soft)}
.tl-range{display:flex;align-items:center;gap:10px;margin-top:6px}
.tl-range input[type=number]{width:80px;padding:8px 10px;border:1px solid var(--tl-border);border-radius:8px;font-family:var(--tl-font-mono);font-size:13px}
.tl-range .bar{height:4px;flex:1;border-radius:2px;background:var(--tl-spectral);opacity:.5}

/* filtres actifs */
.tl-active{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:18px}
.tl-active__chip{display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:700;background:var(--tl-cream);border:1px solid var(--tl-border);border-radius:var(--tl-r-pill);padding:6px 8px 6px 13px}
.tl-active__chip button{width:20px;height:20px;border-radius:50%;border:0;background:var(--tl-line);color:var(--tl-ink);cursor:pointer;line-height:1}
.tl-active__clear{font-family:var(--tl-font-mono);font-size:12px;color:var(--tl-copper-text);background:none;border:0;cursor:pointer;text-decoration:underline}

/* barre de tri */
.tl-sortbar{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:18px;flex-wrap:wrap}
.tl-sortbar__count{font-family:var(--tl-font-mono);font-size:12px;letter-spacing:.04em;color:var(--tl-text-soft);text-transform:uppercase}
.tl-sortbar__right{display:flex;align-items:center;gap:12px}
.tl-sortbar select{padding:10px 14px;border:1px solid var(--tl-border);border-radius:10px;font-family:var(--tl-font-body);font-size:14px;background:var(--tl-surface)}
.tl-filters-toggle{display:none;align-items:center;gap:8px;font-family:var(--tl-font-mono);font-size:12px;text-transform:uppercase;border:1px solid var(--tl-border);border-radius:10px;padding:10px 14px;background:var(--tl-surface);cursor:pointer}

/* pagination */
.tl-pager{display:flex;align-items:center;justify-content:center;gap:6px;margin-top:40px}
.tl-pager a,.tl-pager span{min-width:42px;height:42px;display:grid;place-items:center;border-radius:10px;border:1px solid var(--tl-border);font-family:var(--tl-font-mono);font-size:14px;color:var(--tl-text);text-decoration:none}
.tl-pager a:hover{border-color:var(--tl-green);color:var(--tl-green)}
.tl-pager [aria-current="page"]{background:var(--tl-forest);color:#fff;border-color:var(--tl-forest)}
.tl-loadmore{text-align:center;margin-top:24px}

/* no results */
.tl-noresults{text-align:center;padding:var(--tl-sp-8);border:1px dashed var(--tl-border);border-radius:var(--tl-r-lg);color:var(--tl-text-soft)}

@media(max-width:980px){
  .tl-listing{grid-template-columns:1fr;gap:0}
  .tl-facets{position:fixed;inset:0 0 0 auto;width:min(360px,90vw);background:var(--tl-surface);z-index:var(--tl-z-modal);padding:20px;overflow:auto;transform:translateX(100%);transition:transform var(--tl-dur) var(--tl-ease);box-shadow:var(--tl-shadow)}
  .tl-facets.is-open{transform:translateX(0)}
  .tl-filters-toggle{display:inline-flex}
}

/* product */
/* ===== TerraLED — Fiche produit (PDP) ===== */
.tl-product{max-width:1240px;margin:0 auto;padding:26px 24px 48px;display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:start}
.tl-gallery{position:sticky;top:96px;display:grid;grid-template-columns:74px 1fr;gap:14px}
.tl-gallery__thumbs{display:flex;flex-direction:column;gap:10px}
.tl-gallery__thumb{width:74px;height:74px;border:1px solid var(--tl-border);border-radius:10px;overflow:hidden;background:#fff;cursor:pointer;padding:6px}
.tl-gallery__thumb[aria-current="true"]{border-color:var(--tl-green);box-shadow:0 0 0 1px var(--tl-green)}
.tl-gallery__thumb img{width:100%;height:100%;object-fit:contain}
.tl-gallery__main{position:relative;border:1px solid var(--tl-border);border-radius:var(--tl-r-lg);background:radial-gradient(120% 90% at 50% 0%,#fff,#eef1ec);aspect-ratio:1/1;display:grid;place-items:center;padding:32px;overflow:hidden}
.tl-gallery__main img{max-width:100%;max-height:100%;object-fit:contain}
.tl-gallery__flags{position:absolute;top:16px;left:16px;display:flex;gap:8px;z-index:2}

.tl-pdp__brand{font-family:var(--tl-font-mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--tl-copper-text)}
.tl-pdp__title{font-family:var(--tl-font-display);font-size:clamp(26px,3.4vw,38px);font-weight:600;margin:6px 0 10px;letter-spacing:-.02em}
.tl-pdp__rating{display:flex;align-items:center;gap:10px;margin-bottom:14px;font-size:13px}
.tl-pdp__price{display:flex;align-items:baseline;gap:14px;flex-wrap:wrap;margin:16px 0 4px}
.tl-pdp__price .tl-price__current{font-family:var(--tl-font-display);font-weight:600;font-size:34px;color:var(--tl-green)}
.tl-pdp__price .tl-price__old{color:var(--tl-text-soft);text-decoration:line-through;font-size:18px}
.tl-pdp__eco{font-family:var(--tl-font-mono);font-size:11px;color:var(--tl-text-soft);margin-bottom:14px}
.tl-pdp__lead{color:var(--tl-ink-2);font-size:15px;margin:14px 0}

.tl-variants{margin:20px 0}
.tl-variants__label{font-family:var(--tl-font-mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--tl-text-soft);margin-bottom:10px;display:block}
.tl-variants__opts{display:flex;gap:10px;flex-wrap:wrap}
.tl-variant{font-family:var(--tl-font-mono);font-weight:600;font-size:14px;border:1.5px solid var(--tl-border);border-radius:11px;padding:11px 15px;background:var(--tl-surface);color:var(--tl-text);cursor:pointer;min-width:82px;text-align:center;transition:.15s}
.tl-variant:hover{border-color:var(--tl-text-soft)}
.tl-variant small{display:block;font-size:10px;color:var(--tl-text-soft);margin-top:2px;font-weight:400}
.tl-variant[aria-pressed="true"]{border-color:var(--tl-forest);background:var(--tl-forest);color:#fff}
.tl-variant[aria-pressed="true"] small{color:#9fb3a4}

.tl-pdp__buy{display:flex;gap:14px;align-items:center;flex-wrap:wrap;margin:22px 0 6px}
.tl-pdp__buy .tl-btn{flex:1;min-width:200px}
.tl-pdp__reassure{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:22px;padding-top:20px;border-top:1px solid var(--tl-border)}

/* barre d'achat sticky mobile */
.tl-sticky-atc{position:fixed;left:0;right:0;bottom:0;z-index:var(--tl-z-sticky);background:var(--tl-surface);border-top:1px solid var(--tl-border);box-shadow:0 -10px 26px -18px rgba(0,0,0,.35);padding:10px 16px;display:none;align-items:center;justify-content:space-between;gap:14px}
.tl-sticky-atc .p{font-family:var(--tl-font-display);font-weight:600;font-size:20px;color:var(--tl-green)}
.tl-sticky-atc .tl-btn{flex:1;max-width:220px}

/* souvent achetés ensemble */
.tl-bt{display:flex;align-items:center;gap:16px;flex-wrap:wrap;background:var(--tl-cream);border:1px solid var(--tl-border);border-radius:var(--tl-r-lg);padding:22px}
.tl-bt__item{display:flex;flex-direction:column;align-items:center;gap:6px;width:120px;text-align:center;font-size:12px;color:var(--tl-text)}
.tl-bt__item img{width:96px;height:96px;object-fit:contain;background:#fff;border:1px solid var(--tl-border);border-radius:10px;padding:8px}
.tl-bt__plus{font-size:24px;color:var(--tl-text-soft)}
.tl-bt__total{margin-left:auto;text-align:right}
.tl-bt__total b{font-family:var(--tl-font-display);font-size:24px;color:var(--tl-green);display:block;margin-bottom:8px}

.tl-pdp-section{max-width:1240px;margin:0 auto;padding:8px 24px 28px}
.tl-pdp-section h2{font-family:var(--tl-font-display);font-size:24px;margin:24px 0 16px}

/* modale d'ajout panier : ligne produit + mini cross-sell */
.tl-atc__line{display:flex;gap:14px;align-items:center;padding:12px 0;border-bottom:1px solid var(--tl-border)}
.tl-atc__line img{width:64px;height:64px;object-fit:contain;background:var(--tl-grey);border-radius:10px;padding:6px}
.tl-atc__cross{display:flex;gap:12px;margin-top:14px;overflow:auto}
.tl-atc__cross figure{margin:0;width:90px;text-align:center;font-size:11px}
.tl-atc__cross img{width:70px;height:70px;object-fit:contain;background:var(--tl-grey);border-radius:8px;padding:6px}

@media(max-width:900px){
  .tl-product{grid-template-columns:1fr;gap:24px}
  .tl-gallery{position:static;grid-template-columns:1fr}
  .tl-gallery__thumbs{flex-direction:row;order:2}
  .tl-pdp__reassure{grid-template-columns:1fr}
  .tl-sticky-atc{display:flex}
  body{padding-bottom:74px}
}

/* cart */
/* ===== TerraLED — Panier (page + tiroir) ===== */
.tl-cart{max-width:1240px;margin:0 auto;padding:28px 24px 56px;display:grid;grid-template-columns:1fr 360px;gap:36px;align-items:start}
.tl-cart h1{font-family:var(--tl-font-display);font-size:30px;margin:0 0 6px}
.tl-cart__count{font-family:var(--tl-font-mono);font-size:12px;color:var(--tl-text-soft);text-transform:uppercase;letter-spacing:.04em;margin-bottom:18px}

/* barre franco */
.tl-franco{background:var(--tl-cream);border:1px solid var(--tl-border);border-radius:var(--tl-r);padding:14px 16px;margin-bottom:20px}
.tl-franco__msg{font-size:14px;margin-bottom:8px}.tl-franco__msg b{color:var(--tl-green)}
.tl-franco__bar{height:8px;border-radius:4px;background:var(--tl-line);overflow:hidden}
.tl-franco__fill{height:100%;background:var(--tl-spectral);border-radius:4px}

.tl-cartline{display:grid;grid-template-columns:96px 1fr auto;gap:16px;padding:18px 0;border-bottom:1px solid var(--tl-border);align-items:center}
.tl-cartline__img{width:96px;height:96px;object-fit:contain;background:var(--tl-grey);border-radius:10px;padding:8px}
.tl-cartline__name{font-family:var(--tl-font-display);font-weight:600;font-size:16px;margin:0 0 4px}
.tl-cartline__name a{color:var(--tl-text);text-decoration:none}
.tl-cartline__meta{font-family:var(--tl-font-mono);font-size:11px;color:var(--tl-text-soft);text-transform:uppercase;letter-spacing:.04em}
.tl-cartline__actions{display:flex;align-items:center;gap:16px;margin-top:10px}
.tl-cartline__rm{background:none;border:0;color:var(--tl-text-soft);font-size:13px;cursor:pointer;text-decoration:underline}
.tl-cartline__rm:hover{color:var(--tl-danger)}
.tl-cartline__price{font-family:var(--tl-font-display);font-weight:600;font-size:18px;color:var(--tl-text);text-align:right;white-space:nowrap}

.tl-voucher{display:flex;gap:10px;margin-top:20px}
.tl-voucher input{flex:1;padding:12px 14px;border:1px solid var(--tl-border);border-radius:10px;font-family:var(--tl-font-mono);font-size:13px}

/* récap */
.tl-summary{position:sticky;top:96px;background:var(--tl-surface);border:1px solid var(--tl-border);border-radius:var(--tl-r-lg);padding:24px;box-shadow:var(--tl-shadow-sm);position:relative;overflow:hidden}
.tl-summary::before{content:"";position:absolute;left:0;right:0;top:0;height:3px;background:var(--tl-spectral)}
.tl-summary h2{font-family:var(--tl-font-display);font-size:19px;margin:0 0 16px}
.tl-summary__row{display:flex;justify-content:space-between;padding:8px 0;font-size:14px;color:var(--tl-text-soft)}
.tl-summary__row b{color:var(--tl-text)}
.tl-summary__row--free b{color:var(--tl-green)}
.tl-summary__total{display:flex;justify-content:space-between;align-items:baseline;border-top:1px solid var(--tl-border);margin-top:8px;padding-top:14px}
.tl-summary__total .lab{font-family:var(--tl-font-display);font-weight:600;font-size:17px}
.tl-summary__total .val{font-family:var(--tl-font-display);font-weight:600;font-size:26px;color:var(--tl-green)}
.tl-summary .tl-btn{width:100%;margin-top:16px}
.tl-summary__reassure{display:flex;gap:12px;justify-content:center;margin-top:14px;font-family:var(--tl-font-mono);font-size:10.5px;color:var(--tl-text-soft);text-transform:uppercase;letter-spacing:.04em}
.tl-paylogos{display:flex;gap:6px;justify-content:center;margin-top:12px}
.tl-paylogos span{height:24px;padding:0 8px;border-radius:5px;background:var(--tl-grey);font-family:var(--tl-font-mono);font-size:10px;display:grid;place-items:center}

/* tiroir mini-panier (réutilise .tl-offcanvas de zz-extra) */
.tl-mini__line{display:flex;gap:12px;padding:12px 0;border-bottom:1px solid var(--tl-border)}
.tl-mini__line img{width:56px;height:56px;object-fit:contain;background:var(--tl-grey);border-radius:8px;padding:5px}
.tl-mini__name{font-size:14px;font-weight:700}
.tl-mini__meta{font-family:var(--tl-font-mono);font-size:11px;color:var(--tl-text-soft)}
.tl-mini__total{display:flex;justify-content:space-between;font-family:var(--tl-font-display);font-weight:600;font-size:18px;margin:14px 0}

@media(max-width:900px){ .tl-cart{grid-template-columns:1fr} .tl-summary{position:static} }

/* checkout */
/* ===== TerraLED — Tunnel de commande & confirmation ===== */
.tl-coheader{border-bottom:1px solid var(--tl-border);background:#fff}
.tl-coheader__in{max-width:1240px;margin:0 auto;padding:16px 24px;display:flex;align-items:center;justify-content:space-between}
.tl-coheader .tl-logo b{font-size:20px}
.tl-cosecure{display:inline-flex;align-items:center;gap:8px;font-family:var(--tl-font-mono);font-size:12px;color:var(--tl-text-soft)}
.tl-cosecure svg{width:16px;height:16px;color:var(--tl-success)}

.tl-checkout{max-width:1240px;margin:0 auto;padding:28px 24px 56px;display:grid;grid-template-columns:1fr 380px;gap:36px;align-items:start}
.tl-step{border:1px solid var(--tl-border);border-radius:var(--tl-r-lg);padding:24px;margin-bottom:18px;background:var(--tl-surface)}
.tl-step__head{display:flex;align-items:center;gap:12px;margin-bottom:16px}
.tl-step__num{width:30px;height:30px;border-radius:50%;background:var(--tl-forest);color:#fff;font-family:var(--tl-font-mono);font-weight:600;display:grid;place-items:center;font-size:14px}
.tl-step--done .tl-step__num{background:var(--tl-success)}
.tl-step__title{font-family:var(--tl-font-display);font-weight:600;font-size:19px;margin:0}
.tl-step__edit{margin-left:auto;font-family:var(--tl-font-mono);font-size:12px;color:var(--tl-copper-text);background:none;border:0;cursor:pointer;text-decoration:underline}

.tl-addr{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.tl-addr__card{border:1.5px solid var(--tl-border);border-radius:var(--tl-r);padding:16px;cursor:pointer;position:relative}
.tl-addr__card[aria-pressed="true"]{border-color:var(--tl-forest);box-shadow:0 0 0 1px var(--tl-forest)}
.tl-addr__card b{font-family:var(--tl-font-display)}
.tl-addr__card p{font-size:14px;color:var(--tl-text-soft);margin:6px 0 0}

.tl-carrier,.tl-payment{display:flex;flex-direction:column;gap:12px}
.tl-opt{display:flex;align-items:center;gap:14px;border:1.5px solid var(--tl-border);border-radius:var(--tl-r);padding:16px;cursor:pointer}
.tl-opt[aria-pressed="true"]{border-color:var(--tl-forest);box-shadow:0 0 0 1px var(--tl-forest)}
.tl-opt__radio{width:20px;height:20px;border-radius:50%;border:2px solid var(--tl-border);flex:none;display:grid;place-items:center}
.tl-opt[aria-pressed="true"] .tl-opt__radio{border-color:var(--tl-forest)}
.tl-opt[aria-pressed="true"] .tl-opt__radio::after{content:"";width:10px;height:10px;border-radius:50%;background:var(--tl-forest)}
.tl-opt__body{flex:1}.tl-opt__body b{font-family:var(--tl-font-display);font-size:15px}.tl-opt__body small{display:block;color:var(--tl-text-soft);font-size:13px}
.tl-opt__price{font-family:var(--tl-font-display);font-weight:600}
.tl-opt__logo{height:26px;padding:0 10px;border-radius:6px;background:var(--tl-grey);font-family:var(--tl-font-mono);font-weight:600;font-size:11px;display:grid;place-items:center}
.tl-cgv{display:flex;gap:12px;align-items:flex-start;margin:16px 0;font-size:14px}

/* récap commande (aside) */
.tl-recap{position:sticky;top:24px;border:1px solid var(--tl-border);border-radius:var(--tl-r-lg);padding:22px;background:var(--tl-surface)}
.tl-recap h2{font-family:var(--tl-font-display);font-size:18px;margin:0 0 14px}
.tl-recap__line{display:flex;gap:12px;padding:10px 0;border-bottom:1px solid var(--tl-border);font-size:14px}
.tl-recap__line img{width:48px;height:48px;object-fit:contain;background:var(--tl-grey);border-radius:8px;padding:5px}
.tl-recap__row{display:flex;justify-content:space-between;padding:6px 0;font-size:14px;color:var(--tl-text-soft)}
.tl-recap__total{display:flex;justify-content:space-between;border-top:1px solid var(--tl-border);margin-top:8px;padding-top:12px;font-family:var(--tl-font-display);font-weight:600;font-size:20px}
.tl-recap__total .v{color:var(--tl-green)}

/* confirmation */
.tl-confirm{max-width:760px;margin:0 auto;padding:48px 24px;text-align:center}
.tl-confirm__badge{width:84px;height:84px;border-radius:50%;background:var(--tl-success);color:#fff;display:grid;place-items:center;margin:0 auto 20px}
.tl-confirm__badge svg{width:44px;height:44px}
.tl-confirm h1{font-family:var(--tl-font-display);font-size:32px;margin:0 0 8px}
.tl-confirm__num{font-family:var(--tl-font-mono);font-size:13px;color:var(--tl-text-soft);letter-spacing:.06em}
.tl-confirm__card{text-align:left;border:1px solid var(--tl-border);border-radius:var(--tl-r-lg);padding:24px;margin:28px 0;background:var(--tl-surface)}
.tl-confirm__steps{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:24px}

@media(max-width:900px){ .tl-checkout{grid-template-columns:1fr} .tl-recap{position:static} .tl-addr{grid-template-columns:1fr} .tl-confirm__steps{grid-template-columns:1fr} }

/* account */
/* ===== TerraLED — Compte client, wishlist & B2B ===== */
.tl-page{max-width:1240px;margin:0 auto;padding:28px 24px 56px}
.tl-page__title{font-family:var(--tl-font-display);font-size:30px;margin:0 0 6px}
.tl-page__sub{font-family:var(--tl-font-mono);font-size:12px;color:var(--tl-text-soft);text-transform:uppercase;letter-spacing:.04em;margin-bottom:24px}

/* connexion / inscription */
.tl-auth{display:grid;grid-template-columns:1fr 1fr;gap:24px;max-width:880px;margin:0 auto}
.tl-auth__card{border:1px solid var(--tl-border);border-radius:var(--tl-r-lg);padding:30px;background:var(--tl-surface);position:relative;overflow:hidden}
.tl-auth__card::before{content:"";position:absolute;left:0;right:0;top:0;height:3px;background:var(--tl-spectral)}
.tl-auth__card h2{font-family:var(--tl-font-display);font-size:21px;margin:0 0 18px}
.tl-social{display:flex;gap:10px;margin:14px 0}
.tl-social a{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;border:1px solid var(--tl-border);border-radius:10px;padding:11px;font-family:var(--tl-font-mono);font-size:12px;color:var(--tl-text);text-decoration:none}
.tl-social a:hover{border-color:var(--tl-text-soft)}
.tl-divider{display:flex;align-items:center;gap:12px;color:var(--tl-text-soft);font-family:var(--tl-font-mono);font-size:11px;margin:16px 0}
.tl-divider::before,.tl-divider::after{content:"";flex:1;height:1px;background:var(--tl-border)}

/* layout compte : nav + contenu */
.tl-account{display:grid;grid-template-columns:240px 1fr;gap:32px;align-items:start}
.tl-acct-nav{position:sticky;top:96px;border:1px solid var(--tl-border);border-radius:var(--tl-r-lg);padding:10px;background:var(--tl-surface)}
.tl-acct-nav a{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:10px;color:var(--tl-text);text-decoration:none;font-weight:700;font-size:14px}
.tl-acct-nav a svg{width:18px;height:18px;color:var(--tl-text-soft)}
.tl-acct-nav a:hover{background:var(--tl-grey)}
.tl-acct-nav a[aria-current="page"]{background:var(--tl-forest);color:#fff}
.tl-acct-nav a[aria-current="page"] svg{color:var(--tl-gold)}

/* tableau de bord */
.tl-dash{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-bottom:28px}
.tl-dash-card{border:1px solid var(--tl-border);border-radius:var(--tl-r-lg);padding:22px;background:var(--tl-surface);text-decoration:none;color:var(--tl-text);transition:.2s;display:block}
.tl-dash-card:hover{transform:translateY(-4px);box-shadow:var(--tl-shadow-sm)}
.tl-dash-card__ic{width:46px;height:46px;border-radius:12px;background:var(--tl-cream);color:var(--tl-green);display:grid;place-items:center;margin-bottom:14px}
.tl-dash-card__ic svg{width:23px;height:23px}
.tl-dash-card b{font-family:var(--tl-font-display);font-size:17px;display:block}
.tl-dash-card small{color:var(--tl-text-soft);font-size:13px}

.tl-acct-block{border:1px solid var(--tl-border);border-radius:var(--tl-r-lg);padding:24px;background:var(--tl-surface);margin-bottom:22px}
.tl-acct-block h2{font-family:var(--tl-font-display);font-size:19px;margin:0 0 16px}

/* B2B */
.tl-b2b-hero{background:var(--tl-forest);color:#eaf3ec;border-radius:var(--tl-r-xl);padding:44px;position:relative;overflow:hidden;isolation:isolate;margin-bottom:28px}
.tl-b2b-hero::before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px);background-size:46px 46px;mask-image:radial-gradient(120% 100% at 70% 0%,#000 30%,transparent 80%);z-index:0}
.tl-b2b-hero>*{position:relative;z-index:1}
.tl-b2b-hero h1{font-family:var(--tl-font-display);font-size:clamp(28px,4vw,42px);color:#fff;margin:10px 0 12px}
.tl-b2b-hero p{color:#bdd2c3;max-width:560px}
.tl-b2b-adv{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:28px}
.tl-b2b-form{border:1px solid var(--tl-border);border-radius:var(--tl-r-lg);padding:28px;background:var(--tl-surface);max-width:760px}
.tl-b2b-form .tl-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}

@media(max-width:900px){
  .tl-auth,.tl-b2b-adv,.tl-dash,.tl-b2b-form .tl-row{grid-template-columns:1fr}
  .tl-account{grid-template-columns:1fr}
  .tl-acct-nav{position:static;display:flex;overflow:auto;gap:6px}
  .tl-acct-nav a{white-space:nowrap}
}

/* header */
/* ===== TerraLED — En-tête : bandeau, header, méga menu, drawer mobile ===== */
.tl-announce{background:var(--tl-forest);color:#cfe2d6;font-family:var(--tl-font-mono);font-size:12px;letter-spacing:.04em;text-align:center;padding:10px 16px}
.tl-announce b{color:var(--tl-gold)}.tl-announce .sep{margin:0 14px;color:#3f5a49}
.tl-announce .cd{color:var(--tl-gold);font-weight:600}
.tl-topbar{height:3px;background:var(--tl-spectral)}

.tl-header{position:sticky;top:0;z-index:var(--tl-z-header);background:rgba(255,255,255,.92);backdrop-filter:blur(12px);border-bottom:1px solid var(--tl-border)}
.tl-nav{max-width:1240px;margin:0 auto;padding:0 24px;display:flex;align-items:center;gap:28px;height:80px}
.tl-logo{display:flex;align-items:center;gap:10px}
.tl-logo img{height:40px;width:auto;border-radius:6px}
.tl-logo b{font-family:var(--tl-font-display);font-weight:700;font-size:22px;color:var(--tl-green);letter-spacing:-.02em;line-height:1}
.tl-logo small{display:block;font-family:var(--tl-font-mono);font-size:9.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--tl-copper-text)}
.tl-menu{display:flex;gap:26px;margin-left:6px}
.tl-menu .mi{position:static;display:flex;align-items:center}
.tl-menu>.mi>a{font-weight:700;font-size:15px;color:#27332b;position:relative;padding:8px 0;text-decoration:none}
.tl-menu>.mi>a::after{content:"";position:absolute;left:0;bottom:0;height:3px;width:0;border-radius:2px;background:var(--tl-spectral);transition:width var(--tl-dur) var(--tl-ease)}
.tl-menu>.mi:hover>a,.tl-menu>.mi:focus-within>a{color:var(--tl-green)}
.tl-menu>.mi:hover>a::after,.tl-menu>.mi:focus-within>a::after{width:100%}
.tl-menu>.mi>a.hot{color:var(--tl-copper-text)}.tl-menu>.mi>a.hot::after{width:100%}

.tl-tools{margin-left:auto;display:flex;align-items:center;gap:18px}
.tl-search{display:flex;align-items:center;gap:10px;background:var(--tl-cream);border:1px solid var(--tl-border);border-radius:11px;padding:11px 18px;width:240px;color:var(--tl-text-soft);font-family:var(--tl-font-mono);font-size:12.5px}
.tl-search svg{width:17px;height:17px;color:var(--tl-green)}
.tl-icon{position:relative;color:#27332b;display:inline-flex}.tl-icon svg{width:23px;height:23px}
.tl-icon .badge{position:absolute;top:-7px;right:-9px;background:var(--tl-copper-text);color:#fff;font-family:var(--tl-font-mono);font-weight:600;font-size:11px;width:18px;height:18px;border-radius:50%;display:grid;place-items:center}
.tl-burger{display:none;color:#27332b;background:none;border:0;cursor:pointer}.tl-burger svg{width:26px;height:26px}

/* méga menu pleine largeur */
.tl-mega{position:absolute;left:0;right:0;top:100%;background:#fff;border-top:1px solid var(--tl-border);box-shadow:0 30px 50px -24px rgba(4,18,10,.42);opacity:0;visibility:hidden;transform:translateY(8px);transition:.2s var(--tl-ease);z-index:55}
.tl-mega::before{content:"";position:absolute;left:0;right:0;top:0;height:3px;background:var(--tl-spectral)}
.tl-menu .mi:hover .tl-mega,.tl-menu .mi:focus-within .tl-mega,.tl-mega.is-open{opacity:1;visibility:visible;transform:translateY(0)}
.tl-mega__in{max-width:1240px;margin:0 auto;padding:34px 24px;display:grid;grid-template-columns:1fr 1fr 1fr 1.15fr;gap:34px}
.tl-mega__col h5{font-family:var(--tl-font-mono);font-size:11px;letter-spacing:.13em;text-transform:uppercase;color:var(--tl-copper-text);margin:0 0 16px;padding-bottom:11px;border-bottom:1px solid var(--tl-border);position:relative}
.tl-mega__col h5::after{content:"";position:absolute;left:0;bottom:-1px;width:36px;height:2px;background:var(--tl-spectral)}
.tl-mega__col ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:12px}
.tl-mega__col a{font-weight:700;font-size:14.5px;color:#2b372f;text-decoration:none;display:inline-flex;align-items:center;gap:9px;transition:.18s}
.tl-mega__col a:hover{color:var(--tl-green);transform:translateX(3px)}
.tl-mega__col .bdg{font-family:var(--tl-font-mono);font-size:9px;letter-spacing:.04em;color:#fff;background:var(--tl-green);border-radius:5px;padding:2px 6px;text-transform:uppercase}
.tl-mega__col .bdg.promo{background:var(--tl-copper-text)}
.tl-mega__feat{position:relative;overflow:hidden;background:var(--tl-forest);border-radius:14px;padding:22px;color:#fff;display:flex;flex-direction:column;min-height:230px}
.tl-mega__feat .ft{font-family:var(--tl-font-mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--tl-gold)}
.tl-mega__feat h4{font-family:var(--tl-font-display);font-size:21px;margin:7px 0;color:#fff}
.tl-mega__feat p{font-size:13px;color:#bdd2c3;margin-bottom:14px;max-width:60%}
.tl-mega__feat .lnk{font-family:var(--tl-font-mono);font-size:11px;letter-spacing:.04em;text-transform:uppercase;color:#fff;border-bottom:2px solid var(--tl-copper);padding-bottom:3px;align-self:flex-start;text-decoration:none}
.tl-mega__feat img{position:absolute;right:-12px;bottom:-10px;width:150px;filter:drop-shadow(0 14px 24px rgba(0,0,0,.5))}
.tl-mega__feat::after{content:"";position:absolute;left:0;right:0;bottom:0;height:3px;background:var(--tl-spectral);z-index:2}
.tl-mega__all{grid-column:1/-1;border-top:1px solid var(--tl-border);margin-top:4px;padding-top:16px;display:flex;align-items:center;justify-content:space-between;font-family:var(--tl-font-mono);font-size:11px;letter-spacing:.05em;text-transform:uppercase;color:var(--tl-text-soft)}
.tl-mega__all a{color:var(--tl-green);font-weight:700;text-decoration:none}

@media(max-width:980px){
  .tl-menu,.tl-search{display:none}
  .tl-burger{display:inline-flex}
  .tl-nav{height:64px;gap:16px}
}

/* footer */
/* ===== TerraLED — Pied de page ===== */
.tl-reass{background:#fff;border-top:1px solid var(--tl-border)}
.tl-reass__in{max-width:1240px;margin:0 auto;padding:42px 24px;display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.tl-reass__item{display:flex;gap:14px;align-items:center;padding:4px 22px}
.tl-reass__item+.tl-reass__item{border-left:1px solid var(--tl-border)}
.tl-reass__ic{flex:none;width:46px;height:46px;border-radius:50%;background:var(--tl-cream);color:var(--tl-green);display:grid;place-items:center}
.tl-reass__ic svg{width:23px;height:23px}
.tl-reass__item b{font-family:var(--tl-font-display);font-weight:600;font-size:15px;display:block}
.tl-reass__item small{color:var(--tl-text-soft);font-size:12.5px}

.tl-footer{background:var(--tl-forest);color:#aebfb2}
.tl-footer__top{max-width:1240px;margin:0 auto;padding:64px 24px 44px;display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:40px}
.tl-footer .tl-logo b{color:#fff}
.tl-footer__about{font-size:14px;color:#9fb2a4;max-width:300px;margin:16px 0 20px}
.tl-footer h4{font-family:var(--tl-font-display);color:#fff;font-size:16px;font-weight:600;margin:0 0 16px}
.tl-footer ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:11px}
.tl-footer ul a{font-size:14px;color:#9fb2a4;text-decoration:none;transition:.2s}
.tl-footer ul a:hover{color:var(--tl-gold)}
.tl-socials{display:flex;gap:12px}
.tl-socials a{width:40px;height:40px;border-radius:11px;background:rgba(255,255,255,.07);display:grid;place-items:center;color:#cfe0d4;transition:.2s}
.tl-socials a:hover{background:var(--tl-copper)}.tl-socials svg{width:18px;height:18px}
.tl-footer__sign{font-family:var(--tl-font-mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:#6f8576;margin-top:14px;display:flex;align-items:center;gap:8px}
.tl-footer__sign::before{content:"";width:24px;height:5px;border-radius:3px;background:var(--tl-spectral)}
.tl-newsletter{display:flex;gap:10px;flex-wrap:wrap;margin-top:6px}
.tl-newsletter input{font-family:var(--tl-font-mono);font-size:13px;padding:13px 16px;border:1px solid rgba(255,255,255,.18);border-radius:10px;background:rgba(255,255,255,.06);color:#fff;flex:1;min-width:160px}
.tl-newsletter input::placeholder{color:#7f998a}
.tl-footer__bottom{border-top:1px solid rgba(255,255,255,.1)}
.tl-footer__bottom-in{max-width:1240px;margin:0 auto;padding:22px 24px;display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap}
.tl-footer__bottom small{font-family:var(--tl-font-mono);font-size:11px;color:#8aa093}
.tl-pays{display:flex;gap:9px;align-items:center}
.tl-pay{height:31px;padding:0 12px;border-radius:7px;background:#fff;color:#1a2b20;font-family:var(--tl-font-mono);font-weight:600;font-size:11px;display:grid;place-items:center}
.tl-lang{display:inline-flex;gap:6px;font-family:var(--tl-font-mono);font-size:12px}
.tl-lang a{color:#9fb2a4;text-decoration:none;padding:2px 6px;border-radius:5px}
.tl-lang a[aria-current="true"]{background:rgba(255,255,255,.12);color:#fff}

@media(max-width:980px){
  .tl-reass__in{grid-template-columns:1fr 1fr;gap:18px}
  .tl-reass__item+.tl-reass__item{border-left:none}
  .tl-footer__top{grid-template-columns:1fr 1fr;gap:28px}
}

/* zz-extra */
/* ============================================================
   Familles complémentaires (écrites en direct) :
   overlays · états · contenu · motifs
   CSS pur, tokens --tl-* uniquement, BEM .tl-
   ============================================================ */

/* ---------- OVERLAYS : modale, tiroir, toast, tooltip ---------- */
.tl-overlay[hidden],.tl-offcanvas[hidden]{display:none}
.tl-overlay{position:fixed;inset:0;background:rgba(8,20,12,.55);backdrop-filter:blur(2px);z-index:var(--tl-z-overlay);display:grid;place-items:center;padding:var(--tl-sp-4)}
.tl-modal{background:var(--tl-surface);color:var(--tl-text);border-radius:var(--tl-r-lg);box-shadow:var(--tl-shadow);max-width:520px;width:100%;max-height:90vh;overflow:auto;position:relative;z-index:var(--tl-z-modal)}
.tl-modal::before{content:"";position:absolute;left:0;right:0;top:0;height:3px;background:var(--tl-spectral)}
.tl-modal__head{display:flex;align-items:center;justify-content:space-between;gap:var(--tl-sp-3);padding:var(--tl-sp-5) var(--tl-sp-5) var(--tl-sp-3)}
.tl-modal__title{font-family:var(--tl-font-display);font-size:20px;font-weight:600;margin:0}
.tl-modal__body{padding:0 var(--tl-sp-5) var(--tl-sp-4)}
.tl-modal__foot{padding:var(--tl-sp-4) var(--tl-sp-5) var(--tl-sp-5);display:flex;gap:var(--tl-sp-3);flex-wrap:wrap;justify-content:flex-end}
.tl-modal__close{width:40px;height:40px;border-radius:50%;border:1px solid var(--tl-border);background:var(--tl-bg);color:var(--tl-text-soft);display:grid;place-items:center;cursor:pointer}
.tl-modal__close:hover{color:var(--tl-text);border-color:var(--tl-text-soft)}
/* tiroir off-canvas (panier) depuis la droite */
.tl-offcanvas{position:fixed;top:0;right:0;bottom:0;width:min(420px,92vw);background:var(--tl-surface);color:var(--tl-text);box-shadow:var(--tl-shadow);z-index:var(--tl-z-modal);display:flex;flex-direction:column;transform:translateX(0);transition:transform var(--tl-dur) var(--tl-ease)}
.tl-offcanvas[hidden]{display:none}
.tl-offcanvas__head{display:flex;align-items:center;justify-content:space-between;padding:var(--tl-sp-4) var(--tl-sp-5);border-bottom:1px solid var(--tl-border)}
.tl-offcanvas__body{flex:1;overflow:auto;padding:var(--tl-sp-4) var(--tl-sp-5)}
.tl-offcanvas__foot{border-top:1px solid var(--tl-border);padding:var(--tl-sp-4) var(--tl-sp-5)}
/* toasts */
.tl-toasts{position:fixed;bottom:var(--tl-sp-5);right:var(--tl-sp-5);z-index:var(--tl-z-toast);display:flex;flex-direction:column;gap:var(--tl-sp-2);max-width:360px}
.tl-toast{display:flex;gap:var(--tl-sp-3);align-items:flex-start;background:var(--tl-surface);color:var(--tl-text);border:1px solid var(--tl-border);border-left:4px solid var(--tl-primary);border-radius:var(--tl-r-sm);padding:var(--tl-sp-3) var(--tl-sp-4);box-shadow:var(--tl-shadow-sm)}
.tl-toast--success{border-left-color:var(--tl-success)}
.tl-toast--danger{border-left-color:var(--tl-danger)}
.tl-toast__close{margin-left:auto;background:none;border:0;color:var(--tl-text-soft);cursor:pointer;font-size:18px;line-height:1}
.tl-tooltip{position:relative}
.tl-tooltip__bubble{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translateX(-50%);background:var(--tl-forest);color:#eaf3ec;font-size:12px;padding:6px 10px;border-radius:6px;white-space:nowrap;box-shadow:var(--tl-shadow-sm)}

/* ---------- ÉTATS : skeleton, spinner, vide, erreur, alertes ---------- */
.tl-skeleton{background:linear-gradient(100deg,var(--tl-grey) 30%,#fff 50%,var(--tl-grey) 70%);background-size:200% 100%;animation:tl-shimmer 1.3s var(--tl-ease) infinite;border-radius:var(--tl-r-sm)}
.tl-skeleton--text{height:.8em;margin:.35em 0;border-radius:4px}
.tl-skeleton--card{height:280px}
@keyframes tl-shimmer{from{background-position:200% 0}to{background-position:-200% 0}}
@media (prefers-reduced-motion: reduce){.tl-skeleton{animation:none;background:var(--tl-grey)}}
.tl-spinner{width:28px;height:28px;border-radius:50%;border:3px solid var(--tl-line);border-top-color:var(--tl-primary);animation:tl-spin .8s linear infinite}
@keyframes tl-spin{to{transform:rotate(360deg)}}
@media (prefers-reduced-motion: reduce){.tl-spinner{animation-duration:1.6s}}
.tl-empty{text-align:center;padding:var(--tl-sp-8) var(--tl-sp-5);color:var(--tl-text-soft)}
.tl-empty__icon{width:64px;height:64px;margin:0 auto var(--tl-sp-4);color:var(--tl-primary);opacity:.7}
.tl-empty__title{font-family:var(--tl-font-display);font-size:20px;color:var(--tl-text);margin:0 0 var(--tl-sp-2)}
.tl-alert{display:flex;gap:var(--tl-sp-3);align-items:flex-start;padding:var(--tl-sp-3) var(--tl-sp-4);border-radius:var(--tl-r-sm);border:1px solid;font-size:14px}
.tl-alert--success{background:#eaf5ee;border-color:#bfe0cb;color:#14502f}
.tl-alert--warning{background:#fbf1e0;border-color:#ecd5a8;color:#7a4d06}
.tl-alert--danger{background:#fbeae7;border-color:#f0c4bb;color:#8a2c1d}
.tl-alert--info{background:#e9eefb;border-color:#c4d2f3;color:#1b3a8a}

/* ---------- CONTENU : prose, table, specs, témoignage, FAQ ---------- */
.tl-prose{max-width:72ch;line-height:1.75}
.tl-prose h2{font-size:26px;margin:1.6em 0 .5em}
.tl-prose h3{font-size:20px;margin:1.3em 0 .4em}
.tl-prose a{color:var(--tl-primary);text-decoration:underline;text-underline-offset:2px}
.tl-prose blockquote{margin:1.5em 0;padding:.5em 0 .5em 1.2em;border-left:4px solid;border-image:var(--tl-spectral) 1;font-style:italic;color:var(--tl-ink-2)}
.tl-table-wrap{overflow-x:auto}
.tl-table{width:100%;border-collapse:collapse;font-size:14px}
.tl-table th,.tl-table td{padding:var(--tl-sp-3) var(--tl-sp-4);text-align:left;border-bottom:1px solid var(--tl-border)}
.tl-table thead th{font-family:var(--tl-font-mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--tl-copper-text)}
.tl-table tbody tr:hover{background:var(--tl-grey)}
.tl-specs{display:grid;grid-template-columns:max-content 1fr;gap:var(--tl-sp-2) var(--tl-sp-5);margin:0}
.tl-specs dt{font-family:var(--tl-font-mono);font-size:12px;letter-spacing:.04em;text-transform:uppercase;color:var(--tl-text-soft)}
.tl-specs dd{margin:0;font-weight:700}
.tl-testimonial{background:var(--tl-surface);border:1px solid var(--tl-border);border-radius:var(--tl-r-lg);padding:var(--tl-sp-5);box-shadow:var(--tl-shadow-sm)}
.tl-testimonial__stars{color:var(--tl-amber);letter-spacing:2px}
.tl-testimonial__who{display:flex;align-items:center;gap:var(--tl-sp-3);margin-top:var(--tl-sp-4)}
.tl-testimonial__avatar{width:42px;height:42px;border-radius:50%;background:var(--tl-green);color:#fff;display:grid;place-items:center;font-family:var(--tl-font-display);font-weight:600}
.tl-faq{border-bottom:1px solid var(--tl-border)}
.tl-faq summary{cursor:pointer;padding:var(--tl-sp-4) 0;font-family:var(--tl-font-display);font-weight:600;font-size:17px;list-style:none;display:flex;justify-content:space-between;gap:var(--tl-sp-3)}
.tl-faq summary::-webkit-details-marker{display:none}
.tl-faq summary::after{content:"+";color:var(--tl-copper);font-family:var(--tl-font-mono)}
.tl-faq[open] summary::after{content:"−"}
.tl-faq__body{padding:0 0 var(--tl-sp-4);color:var(--tl-text-soft)}

/* ---------- MOTIFS : icon-box, USP, courbe PAR, panneau sombre ---------- */
.tl-iconbox{display:flex;gap:var(--tl-sp-4);align-items:flex-start}
.tl-iconbox__ic{flex:none;width:50px;height:50px;border-radius:var(--tl-r);background:var(--tl-grey);color:var(--tl-primary);display:grid;place-items:center;position:relative}
.tl-iconbox__ic::after{content:"";position:absolute;left:10px;right:10px;bottom:-1px;height:2px;border-radius:2px;background:var(--tl-spectral);opacity:.85}
.tl-iconbox__ic svg{width:25px;height:25px}
.tl-iconbox b{font-family:var(--tl-font-display);font-weight:600;font-size:16px;display:block}
.tl-iconbox small{color:var(--tl-text-soft);font-size:13px}
.tl-panel-dark{background:var(--tl-forest);color:#eaf3ec;border-radius:var(--tl-r-xl);padding:var(--tl-sp-7);position:relative;overflow:hidden;isolation:isolate}
.tl-panel-dark::before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px);background-size:46px 46px;z-index:0;pointer-events:none;mask-image:radial-gradient(120% 100% at 50% 0%,#000 40%,transparent 90%)}
.tl-panel-dark>*{position:relative;z-index:1}
.tl-par{max-width:340px}
.tl-par text{font-family:var(--tl-font-mono);font-size:9px;fill:#7f998a}

/* zz-a11y-fixes */
/* ============================================================
   Corrections accessibilité AA — audit CP1 (chargé en dernier)
   ============================================================ */
/* B3 : bleu info accessible (texte/bordure) */
:root{ --tl-info:#1b4fd6; }

/* B2 : bouton primaire lisible au repos (blanc sur cuivre foncé = ~5.9:1) */
.tl-btn--primary{ --_bg:var(--tl-copper); }            /* garde l'aspect cuivre vif… */
.tl-btn--primary{ --_bg:var(--tl-copper-text); --_bd:var(--tl-copper-text); } /* …mais fond lisible (#8f5500) */

/* B1 : anneau de focus robuste — or + liseré forêt opaque porteur du >=3:1 sur fond clair */
:focus-visible{ outline:3px solid var(--tl-gold); outline-offset:2px; box-shadow:0 0 0 2px var(--tl-forest); }
[data-tl-theme="dark"] :focus-visible{ box-shadow:0 0 0 2px #04120a; }
.tl-input:focus-visible,.tl-textarea:focus-visible,.tl-select__native:focus-visible,
.tl-choice__input:focus-visible ~ .tl-choice__box,
.tl-search__field:focus-visible,.tl-search__clear:focus-visible{
  outline:3px solid var(--tl-gold); outline-offset:2px; box-shadow:0 0 0 2px var(--tl-forest);
}

/* === home sections (scopé .tl-home) === */
:root{
  --forest:#081a10; --forest-2:#0c2316; --forest-3:#0f2c1b;
  --green:#17813f; --green-d:#176035; --green-600:#1c9a4c; --green-100:#e7f0e8;
  --sage:#eef3ea;
  --copper:#b56a00; --copper-600:#9a5a00; --amber:#e0951f; --gold:#f4bd5e;
  --cream:#f5f0e6; --cream-2:#ece4d4;
  --ink:#13201a; --ink-2:#28342c; --muted:#5f6d62; --line:#e6dfd0;
  /* SIGNATURE : le spectre bi-spectre */
  --spectrum:linear-gradient(90deg,#2563ff 0%,#7b3ff2 26%,#d61f9b 52%,#ff5a3c 78%,#ffb02e 100%);
  --radius:18px; --radius-sm:12px; --radius-lg:26px;
  --shadow:0 28px 64px -32px rgba(4,18,10,.7);
  --shadow-soft:0 16px 38px -24px rgba(4,18,10,.5);
  --maxw:1240px;
  --body:'Lato',system-ui,sans-serif; --disp:'Fraunces',Georgia,serif; --mono:'IBM Plex Mono',ui-monospace,monospace;
  --grain:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}.tl-home *{box-sizing:border-box;margin:0;padding:0}.tl-home{scroll-behavior:smooth}.tl-home{font-family:var(--body);color:var(--ink);background:#fff;line-height:1.65;-webkit-font-smoothing:antialiased}.tl-home img{display:block;max-width:100%}.tl-home a{text-decoration:none;color:inherit}.tl-home h1, .tl-home h2, .tl-home h3, .tl-home h4{font-family:var(--disp);font-optical-sizing:auto;line-height:1.05;letter-spacing:-.015em;font-weight:600}.tl-home .wrap{max-width:var(--maxw);margin:0 auto;padding:0 30px}.tl-home .spectop{height:3px;background:var(--spectrum)}.tl-home /* mono label : signature high-tech */
.mono{font-family:var(--mono);font-weight:500;font-size:12px;letter-spacing:.16em;text-transform:uppercase}.tl-home .tag{display:inline-flex;align-items:center;gap:10px;font-family:var(--mono);font-weight:500;font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--copper)}.tl-home .tag::before{content:"";width:30px;height:6px;border-radius:3px;background:var(--spectrum);box-shadow:0 0 12px rgba(214,31,155,.5)}.tl-home .tag.light{color:#9ad9b0}.tl-home .tag.center{justify-content:center}.tl-home /* spectral underline */
.spec{position:relative;white-space:nowrap}.tl-home .spec::after{content:"";position:absolute;left:0;right:0;bottom:-.12em;height:6px;border-radius:4px;background:var(--spectrum);box-shadow:0 0 16px rgba(214,31,155,.45),0 0 30px rgba(37,99,255,.3)}.tl-home .btn{display:inline-flex;align-items:center;gap:.6em;font-family:var(--mono);font-weight:600;font-size:13px;letter-spacing:.06em;text-transform:uppercase;padding:16px 26px;border-radius:11px;border:1.5px solid transparent;cursor:pointer;transition:transform .25s,box-shadow .25s,background .25s,color .25s}.tl-home .btn svg{width:17px;height:17px}.tl-home .btn-primary{background:var(--copper);color:#fff;box-shadow:0 16px 30px -16px rgba(181,106,0,.9)}.tl-home .btn-primary:hover{transform:translateY(-2px);background:var(--copper-600)}.tl-home .btn-spec{position:relative;background:var(--forest);color:#fff;border:1px solid rgba(255,255,255,.16);overflow:hidden}.tl-home .btn-spec::before{content:"";position:absolute;left:0;right:0;bottom:0;height:2px;background:var(--spectrum)}.tl-home .btn-spec:hover{transform:translateY(-2px);border-color:rgba(255,255,255,.4)}.tl-home .btn-green{background:var(--green);color:#fff}.tl-home .btn-green:hover{transform:translateY(-2px);background:var(--green-600)}.tl-home .btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.4)}.tl-home .btn-ghost:hover{background:rgba(255,255,255,.1);border-color:#fff}.tl-home .btn-outline{background:#fff;color:var(--green-d);border-color:var(--line)}.tl-home .btn-outline:hover{border-color:var(--green);transform:translateY(-2px)}.tl-home .section{padding:108px 0;position:relative}.tl-home .section-head{max-width:680px;margin:0 auto 60px;text-align:center}.tl-home .section-head h2{font-size:clamp(31px,4vw,49px);margin:18px auto 16px;letter-spacing:-.022em;max-width:14ch}.tl-home .section-head h2 em{font-style:italic;color:var(--copper)}.tl-home .section-head p{color:var(--muted);font-size:17.5px}.tl-home .idx{font-family:var(--mono);font-size:12px;letter-spacing:.14em;color:var(--muted);text-transform:uppercase}.tl-home .stars{color:var(--amber);letter-spacing:1.5px}.tl-home /* blueprint helper for dark sections */
.blueprint{position:relative;isolation:isolate}.tl-home .blueprint::before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.045) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.045) 1px,transparent 1px);background-size:46px 46px;z-index:0;pointer-events:none;mask-image:radial-gradient(120% 100% at 50% 0%,#000 40%,transparent 90%)}.tl-home .blueprint::after{content:"";position:absolute;inset:0;background:var(--grain);opacity:.05;mix-blend-mode:overlay;z-index:0;pointer-events:none}.tl-home .blueprint>.wrap{position:relative;z-index:1}.tl-home /* announce */
.announce{background:var(--forest);color:#cfe2d6;font-family:var(--mono);font-size:12px;letter-spacing:.06em;text-align:center;padding:10px 16px}.tl-home .announce b{color:var(--gold)}.tl-home .announce span{margin:0 14px;color:#3f5a49}.tl-home /* header */
header{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.9);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}.tl-home .nav{display:flex;align-items:center;gap:30px;height:84px}.tl-home .logo{display:flex;align-items:center;gap:11px}.tl-home .logo img{height:42px;width:auto;border-radius:7px}.tl-home .logo .lk{line-height:1}.tl-home .logo b{font-family:var(--disp);font-weight:700;font-size:23px;color:var(--green-d);letter-spacing:-.02em;display:block}.tl-home .logo .lk small{font-family:var(--mono);font-size:9.5px;letter-spacing:.22em;color:var(--copper);text-transform:uppercase}.tl-home .menu{display:flex;gap:28px;margin-left:8px}.tl-home .menu a{font-family:var(--body);font-weight:700;font-size:15px;color:#27332b;position:relative;padding:8px 0;transition:color .2s}.tl-home .menu a::after{content:"";position:absolute;left:0;bottom:0;height:3px;width:0;border-radius:2px;background:var(--spectrum);transition:width .28s}.tl-home .menu a:hover{color:var(--green-d)}.tl-home .menu a:hover::after{width:100%}.tl-home .menu a.hot{color:var(--copper)}.tl-home .menu a.hot::after{width:100%}.tl-home .nav-tools{margin-left:auto;display:flex;align-items:center;gap:20px}.tl-home .search{display:flex;align-items:center;gap:10px;background:var(--cream);border:1px solid var(--line);border-radius:11px;padding:11px 18px;width:258px;color:var(--muted);font-family:var(--mono);font-size:12.5px;letter-spacing:.02em}.tl-home .search svg{width:17px;height:17px;flex:none;color:var(--green)}.tl-home .icon-btn{position:relative;color:#27332b;display:inline-flex}.tl-home .icon-btn svg{width:23px;height:23px}.tl-home .icon-btn .badge{position:absolute;top:-7px;right:-9px;background:var(--copper);color:#fff;font-weight:900;font-size:11px;width:18px;height:18px;border-radius:50%;display:grid;place-items:center}.tl-home .burger{display:none}.tl-home /* hud frame device */
.hud{position:relative}.tl-home .hud::before, .tl-home .hud::after{content:"";position:absolute;width:28px;height:28px;z-index:4;pointer-events:none}.tl-home .hud::before{top:-7px;left:-7px;border-top:2px solid var(--gold);border-left:2px solid var(--gold)}.tl-home .hud::after{bottom:-7px;right:-7px;border-bottom:2px solid var(--gold);border-right:2px solid var(--gold)}.tl-home /* spec readouts */
.readouts{display:flex;flex-wrap:wrap;gap:10px}.tl-home .rd{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:12px;letter-spacing:.04em;color:#cfe2d6;border:1px solid rgba(255,255,255,.16);border-radius:9px;padding:8px 12px;background:rgba(255,255,255,.04)}.tl-home .rd::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--spectrum);box-shadow:0 0 8px rgba(214,31,155,.7)}.tl-home .rd b{color:#fff;font-weight:600}.tl-home /* hero */
.hero{position:relative;background:var(--forest);color:#eaf3ec;overflow:hidden;isolation:isolate}.tl-home .hero .bp{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px);background-size:46px 46px;z-index:0;mask-image:radial-gradient(120% 120% at 70% 10%,#000 30%,transparent 80%)}.tl-home .hero .beam{position:absolute;left:-15%;top:34%;width:135%;height:240px;background:var(--spectrum);filter:blur(64px);opacity:.22;transform:rotate(-11deg);z-index:0;animation:beam 14s ease-in-out infinite alternate}
@keyframes beam{from{transform:rotate(-13deg) translateY(-10px);opacity:.16}to{transform:rotate(-9deg) translateY(10px);opacity:.26}}.tl-home .hero .grain{position:absolute;inset:0;background:var(--grain);opacity:.05;mix-blend-mode:overlay;z-index:0}.tl-home .hero .wrap{display:grid;grid-template-columns:1.04fr .96fr;gap:56px;align-items:center;min-height:626px;padding-top:66px;padding-bottom:66px;position:relative;z-index:1}.tl-home .hero-rating{display:inline-flex;align-items:center;gap:10px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.13);border-radius:999px;padding:6px 14px 6px 7px;font-family:var(--mono);font-size:11.5px;letter-spacing:.06em;color:#cfe2d6;margin-bottom:22px}.tl-home .hero-rating .pill{background:var(--gold);color:#3a2600;font-weight:600;border-radius:999px;padding:3px 9px}.tl-home .hero h1{font-size:clamp(42px,5.2vw,72px);font-weight:600;color:#fff;letter-spacing:-.028em;margin:16px 0 24px;font-variation-settings:'opsz' 130}.tl-home .hero h1 em{font-style:italic;font-weight:500}.tl-home .hero .lead{font-size:18.5px;color:#bdd2c3;max-width:505px;margin-bottom:28px}.tl-home .hero .readouts{margin-bottom:32px}.tl-home .hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:40px}.tl-home .hero-stats{display:flex;gap:0;border-top:1px solid rgba(255,255,255,.12)}.tl-home .hero-stats>div{padding:26px 28px 0 0;margin-right:28px;border-right:1px solid rgba(255,255,255,.1)}.tl-home .hero-stats>div:last-child{border-right:none}.tl-home .hero-stats .n{font-family:var(--disp);font-weight:600;font-size:28px;color:#fff;line-height:1}.tl-home .hero-stats small{display:block;font-family:var(--mono);color:#8aa899;font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;margin-top:8px}.tl-home .hero-media{position:relative}.tl-home .hero-frame{position:relative;border-radius:18px;overflow:hidden;box-shadow:0 44px 90px -34px rgba(0,0,0,.8);aspect-ratio:4/4.5}.tl-home .hero-frame img{width:100%;height:100%;object-fit:cover}.tl-home .hero-frame .scan{position:absolute;left:0;right:0;top:0;height:2px;background:var(--spectrum);box-shadow:0 0 18px rgba(214,31,155,.7);animation:scan 5.5s ease-in-out infinite}
@keyframes scan{0%{top:6%}50%{top:94%}100%{top:6%}}.tl-home .hero-frame .corner{position:absolute;left:14px;top:14px;z-index:3;font-family:var(--mono);font-size:11px;letter-spacing:.08em;color:#eafff0;background:rgba(8,26,16,.6);backdrop-filter:blur(5px);border:1px solid rgba(255,255,255,.18);padding:6px 10px;border-radius:8px}.tl-home .float-card{position:absolute;left:-42px;bottom:34px;z-index:5;background:#fff;color:var(--ink);border-radius:16px;padding:14px;display:flex;gap:13px;align-items:center;box-shadow:var(--shadow);width:296px;border-bottom:3px solid transparent;background-clip:padding-box}.tl-home .float-card::after{content:"";position:absolute;left:14px;right:14px;bottom:0;height:3px;border-radius:3px;background:var(--spectrum)}.tl-home .float-card img{width:74px;height:74px;object-fit:contain;background:var(--cream);border-radius:11px;padding:7px}.tl-home .float-card .ft{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--copper)}.tl-home .float-card .nm{font-family:var(--disp);font-weight:600;font-size:16px;line-height:1.15;margin:4px 0 4px}.tl-home .float-card .pr{font-family:var(--disp);font-weight:600;color:var(--green-d);font-size:18px}.tl-home /* marques */
.marques{background:var(--cream);border-bottom:1px solid var(--cream-2)}.tl-home .marques .wrap{display:flex;align-items:center;gap:30px;padding:24px 30px;flex-wrap:wrap;justify-content:center}.tl-home .marques .lbl{font-family:var(--mono);font-size:11.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-2)}.tl-home .marques .lbl b{color:var(--green-d)}.tl-home .marque{height:44px;display:grid;place-items:center;background:#fff;border:1px solid var(--line);border-radius:11px;padding:8px 18px}.tl-home .marque img{height:26px;width:auto;filter:grayscale(1);opacity:.7;transition:.3s}.tl-home .marque:hover img{filter:none;opacity:1}.tl-home /* usp */
.usp{background:#fff}.tl-home .usp .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;padding:48px 30px}.tl-home .usp-item{display:flex;gap:15px;align-items:center;padding:6px 22px}.tl-home .usp-item+.usp-item{border-left:1px solid var(--line)}.tl-home .usp-ic{flex:none;width:50px;height:50px;border-radius:14px;background:var(--sage);display:grid;place-items:center;color:var(--green-d);position:relative}.tl-home .usp-ic::after{content:"";position:absolute;left:10px;right:10px;bottom:-1px;height:2px;border-radius:2px;background:var(--spectrum);opacity:.85}.tl-home .usp-ic svg{width:25px;height:25px}.tl-home .usp-item b{font-family:var(--disp);font-weight:600;font-size:16px;display:block}.tl-home .usp-item small{color:var(--muted);font-size:13px}.tl-home /* univers */
.univers{background:var(--cream)}.tl-home .univers .grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}.tl-home .u-card{position:relative;border-radius:var(--radius);overflow:hidden;background:var(--forest);min-height:448px;display:flex;flex-direction:column;justify-content:flex-end;color:#fff;box-shadow:var(--shadow-soft);transition:transform .35s}.tl-home .u-card:hover{transform:translateY(-7px)}.tl-home .u-card>img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .7s}.tl-home .u-card:hover>img{transform:scale(1.07)}.tl-home .u-card .ov{position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,26,16,.05) 28%,rgba(8,26,16,.92))}.tl-home .u-card .spc{position:absolute;left:0;right:0;bottom:0;height:3px;background:var(--spectrum);opacity:.9;z-index:2}.tl-home .u-card .ct{position:relative;padding:30px}.tl-home .u-num{font-family:var(--mono);font-size:12px;letter-spacing:.16em;color:var(--gold)}.tl-home .u-card h3{font-size:26px;font-weight:600;margin:8px 0 9px}.tl-home .u-card p{font-size:14.5px;color:#cfe0d4;max-width:285px;margin-bottom:18px}.tl-home .u-link{display:inline-flex;align-items:center;gap:9px;font-family:var(--mono);font-weight:600;font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:#fff}.tl-home .u-link svg{width:16px;height:16px;transition:transform .25s}.tl-home .u-card:hover .u-link svg{transform:translateX(5px)}.tl-home /* products */
.p-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}.tl-home .p-card{position:relative;background:#fff;border-radius:var(--radius);border:1px solid var(--line);overflow:hidden;transition:transform .3s,box-shadow .3s,border-color .3s;display:flex;flex-direction:column}.tl-home .p-card:hover{transform:translateY(-7px);box-shadow:var(--shadow);border-color:#d7cfbd}.tl-home .p-thumb{position:relative;background:radial-gradient(120% 90% at 50% 0%,#fff,#eef1ec);aspect-ratio:1/1;display:grid;place-items:center;padding:26px;border-bottom:1px solid var(--line)}.tl-home .p-thumb::before{content:"";position:absolute;left:50%;top:14%;width:62%;height:62%;transform:translateX(-50%);background:radial-gradient(circle,rgba(244,189,94,.35),transparent 65%);opacity:0;transition:opacity .4s}.tl-home .p-card:hover .p-thumb::before{opacity:1}.tl-home .p-thumb img{max-height:100%;width:auto;object-fit:contain;position:relative;transition:transform .4s}.tl-home .p-card:hover .p-thumb img{transform:scale(1.06)}.tl-home .p-flag{position:absolute;top:14px;left:14px;font-family:var(--mono);font-weight:600;font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;padding:6px 10px;border-radius:7px;color:#fff;background:var(--green);z-index:2}.tl-home .p-flag.promo{background:var(--copper)}.tl-home .p-fav{position:absolute;top:13px;right:13px;width:36px;height:36px;border-radius:50%;background:#fff;border:1px solid var(--line);display:grid;place-items:center;color:var(--muted);z-index:2}.tl-home .p-fav svg{width:17px;height:17px}.tl-home .p-body{padding:18px 20px 22px;display:flex;flex-direction:column;flex:1}.tl-home .p-cat{font-family:var(--mono);font-size:10.5px;color:var(--copper);letter-spacing:.08em;text-transform:uppercase}.tl-home .p-name{font-family:var(--disp);font-weight:600;font-size:18px;margin:7px 0 8px;line-height:1.2;min-height:44px}.tl-home .p-spec{font-family:var(--mono);font-size:10.5px;letter-spacing:.04em;color:var(--muted);margin-bottom:10px}.tl-home .p-rate{font-size:12.5px;color:var(--muted);margin-bottom:14px}.tl-home .p-foot{margin-top:auto;display:flex;align-items:center;justify-content:space-between}.tl-home .p-price{font-family:var(--disp);font-weight:600;font-size:22px;color:var(--green-d)}.tl-home .p-price s{font-weight:500;font-size:13px;color:var(--muted);margin-right:6px}.tl-home .p-add{width:46px;height:46px;border-radius:12px;background:var(--green);color:#fff;display:grid;place-items:center;transition:.2s}.tl-home .p-add:hover{background:var(--green-600);transform:scale(1.06)}.tl-home .p-add svg{width:20px;height:20px}.tl-home .center-cta{text-align:center;margin-top:52px}.tl-home /* spotlight with spectrum curve */
.spot{background:var(--forest);color:#eaf3ec}.tl-home .spot .wrap{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}.tl-home .spot-media{position:relative;display:grid;place-items:center}.tl-home .spot-media .halo{position:absolute;width:470px;height:470px;border-radius:50%;background:radial-gradient(circle,rgba(244,189,94,.3),transparent 62%)}.tl-home .spot-media .frame{position:relative}.tl-home .spot-media img.prod{position:relative;max-width:430px;filter:drop-shadow(0 34px 54px rgba(0,0,0,.55))}.tl-home .spectrum-graph{position:absolute;left:50%;bottom:-6px;transform:translateX(-50%);width:90%;max-width:430px;z-index:3;opacity:.96}.tl-home .spot h2{font-size:clamp(32px,3.9vw,49px);font-weight:600;color:#fff;margin:18px 0 18px;letter-spacing:-.022em}.tl-home .spot h2 em{font-style:italic;color:var(--gold)}.tl-home .spot p{color:#bdd2c3;font-size:17px;max-width:490px;margin-bottom:26px}.tl-home .spot .readouts{margin-bottom:32px}.tl-home /* story */
.story{background:#fff;overflow:hidden}.tl-home .story .wrap{display:grid;grid-template-columns:.92fr 1.08fr;gap:60px;align-items:center}.tl-home .story-media{position:relative}.tl-home .story-media .ph{border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow);aspect-ratio:4/4.6}.tl-home .story-media .ph img{width:100%;height:100%;object-fit:cover}.tl-home .story-media .score{position:absolute;right:-26px;bottom:34px;background:var(--forest);color:#fff;border-radius:18px;padding:22px 26px;box-shadow:var(--shadow);text-align:center;border-bottom:3px solid transparent}.tl-home .story-media .score::after{content:"";position:absolute;left:18px;right:18px;bottom:0;height:3px;border-radius:3px;background:var(--spectrum)}.tl-home .story-media .score .big{font-family:var(--disp);font-weight:600;font-size:40px;line-height:1}.tl-home .story-media .score .st{color:var(--gold);font-size:15px;letter-spacing:2px}.tl-home .story-media .score small{font-family:var(--mono);font-size:9.5px;letter-spacing:.1em;text-transform:uppercase;color:#9bb3a4;display:block;margin-top:5px}.tl-home .story h2{font-size:clamp(30px,3.7vw,46px);margin:18px 0 18px;letter-spacing:-.02em}.tl-home .story h2 em{font-style:italic;color:var(--copper)}.tl-home .story .lead{color:var(--ink-2);font-size:17px;margin-bottom:28px;max-width:520px}.tl-home .facts{display:grid;grid-template-columns:1fr 1fr;gap:18px}.tl-home .fact{display:flex;gap:14px;align-items:flex-start}.tl-home .fact-ic{flex:none;width:44px;height:44px;border-radius:12px;background:var(--sage);color:var(--green-d);display:grid;place-items:center}.tl-home .fact-ic svg{width:22px;height:22px}.tl-home .fact b{font-family:var(--disp);font-weight:600;font-size:16px;display:block;line-height:1.2}.tl-home .fact small{color:var(--muted);font-size:13px}.tl-home /* compare */
.compare{background:var(--cream)}.tl-home .compare .grid{display:grid;grid-template-columns:1fr 1fr;gap:26px;max-width:980px;margin:0 auto}.tl-home .cmp{position:relative;border-radius:var(--radius);padding:38px 36px;border:1px solid var(--line);background:#fff}.tl-home .cmp.win{background:var(--forest);color:#fff;border-color:var(--forest);box-shadow:var(--shadow);overflow:hidden}.tl-home .cmp.win::before{content:"";position:absolute;left:0;right:0;top:0;height:3px;background:var(--spectrum)}.tl-home .cmp.win .tagwin{font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);margin-bottom:10px;display:block}.tl-home .cmp h3{font-size:24px;font-weight:600;margin-bottom:6px}.tl-home .cmp .sub{font-family:var(--mono);font-size:11.5px;letter-spacing:.04em;text-transform:uppercase;opacity:.7;margin-bottom:24px}.tl-home .cmp ul{list-style:none;display:flex;flex-direction:column;gap:15px}.tl-home .cmp li{display:flex;gap:13px;align-items:flex-start;font-size:15.5px}.tl-home .cmp li svg{width:22px;height:22px;flex:none;margin-top:1px}.tl-home .cmp.win li svg{color:#7be0a0}.tl-home .cmp.lose .sub{color:var(--muted)}.tl-home .cmp.lose li svg{color:#c2554a}.tl-home .cmp.lose li{color:#55615a}.tl-home /* social */
.social{background:var(--forest-2);color:#eaf3ec}.tl-home .social .section-head h2{color:#fff}.tl-home .social .section-head h2 em{color:var(--gold)}.tl-home .social .section-head p{color:#aec3b4}.tl-home .vid-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-bottom:28px}.tl-home .vid{position:relative;border-radius:var(--radius);overflow:hidden;display:block;box-shadow:var(--shadow);background:#000;aspect-ratio:16/10}.tl-home .vid img{width:100%;height:100%;object-fit:cover;opacity:.92;transition:.5s}.tl-home .vid:hover img{transform:scale(1.05);opacity:1}.tl-home .vid .play{position:absolute;inset:0;display:grid;place-items:center}.tl-home .vid .play span{width:64px;height:64px;border-radius:50%;background:rgba(255,255,255,.94);display:grid;place-items:center;box-shadow:0 10px 30px rgba(0,0,0,.4);transition:.25s}.tl-home .vid:hover .play span{transform:scale(1.08)}.tl-home .vid .play svg{width:23px;height:23px;color:var(--green-d);margin-left:3px}.tl-home .vid .meta{position:absolute;left:0;right:0;bottom:0;padding:15px 16px 16px;background:linear-gradient(0deg,rgba(0,0,0,.85),transparent);display:flex;align-items:center;gap:9px}.tl-home .vid .meta::before{content:"";position:absolute;left:0;right:0;bottom:0;height:3px;background:var(--spectrum);opacity:0;transition:.3s}.tl-home .vid:hover .meta::before{opacity:1}.tl-home .vid .yt{font-family:var(--mono);font-size:10px;font-weight:600;letter-spacing:.06em;color:#fff;background:#c4302b;padding:3px 7px;border-radius:5px}.tl-home .vid .meta b{font-family:var(--disp);font-weight:600;font-size:15px}.tl-home .social .yt-cta{text-align:center;margin:32px 0 62px}.tl-home .proof-split{display:grid;grid-template-columns:.7fr 2.3fr;gap:36px;align-items:center;border-top:1px solid rgba(255,255,255,.12);padding-top:54px}.tl-home .proof-score{text-align:center}.tl-home .proof-score .big{font-family:var(--disp);font-weight:600;font-size:62px;line-height:1;color:#fff}.tl-home .proof-score .big small{font-size:24px;color:#9bb3a4}.tl-home .proof-score .st{color:var(--gold);font-size:22px;letter-spacing:3px;margin:6px 0}.tl-home .proof-score .sub{font-family:var(--mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:#9bb3a4}.tl-home .reviews{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.tl-home .rev{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius);padding:24px 22px}.tl-home .rev .stars{font-size:15px;margin-bottom:12px}.tl-home .rev p{font-size:14.5px;color:#dbe7df;margin-bottom:16px}.tl-home .rev .who{display:flex;align-items:center;gap:11px}.tl-home .rev .av{width:40px;height:40px;border-radius:50%;background:var(--green);color:#fff;display:grid;place-items:center;font-family:var(--disp);font-weight:600}.tl-home .rev .who b{font-family:var(--disp);font-weight:600;font-size:14px;display:block;color:#fff}.tl-home .rev .who small{font-family:var(--mono);font-size:10.5px;letter-spacing:.04em;color:#9bb3a4}.tl-home /* guides */
.guides .grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}.tl-home .guide{border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);background:#fff;transition:.3s;display:flex;flex-direction:column}.tl-home .guide:hover{transform:translateY(-6px);box-shadow:var(--shadow)}.tl-home .guide .gimg{aspect-ratio:16/9;overflow:hidden;position:relative}.tl-home .guide .gimg img{width:100%;height:100%;object-fit:cover;transition:.5s}.tl-home .guide:hover .gimg img{transform:scale(1.06)}.tl-home .guide .gcat{position:absolute;top:14px;left:14px;font-family:var(--mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;background:#fff;color:var(--green-d);padding:5px 10px;border-radius:7px}.tl-home .guide .gbody{padding:22px 24px 26px;display:flex;flex-direction:column;flex:1}.tl-home .guide h3{font-family:var(--disp);font-weight:600;font-size:20px;line-height:1.25;margin-bottom:10px}.tl-home .guide p{color:var(--muted);font-size:14px;margin-bottom:16px}.tl-home .guide .more{margin-top:auto;font-family:var(--mono);font-weight:600;font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--copper);display:inline-flex;align-items:center;gap:7px}.tl-home .guide .more svg{width:15px;height:15px}.tl-home /* pro */
.pro{background:var(--forest);color:#fff}.tl-home .pro .wrap{display:flex;align-items:center;gap:42px;padding:76px 30px;flex-wrap:wrap}.tl-home .pro-ic{width:86px;height:86px;border-radius:20px;background:rgba(255,255,255,.08);display:grid;place-items:center;flex:none;position:relative}.tl-home .pro-ic::after{content:"";position:absolute;left:14px;right:14px;bottom:-1px;height:2px;background:var(--spectrum)}.tl-home .pro-ic svg{width:42px;height:42px;color:var(--gold)}.tl-home .pro h2{font-size:33px;font-weight:600;margin-bottom:9px}.tl-home .pro p{color:#c0d4c6;font-size:16px;max-width:560px}.tl-home .pro .actions{margin-left:auto;display:flex;flex-direction:column;gap:12px;align-items:flex-start}.tl-home .pro .phone{font-family:var(--disp);font-weight:600;font-size:25px;display:flex;align-items:center;gap:11px}.tl-home .pro .phone svg{width:22px;height:22px;color:var(--gold)}.tl-home /* newsletter */
.news{background:var(--cream)}.tl-home .news-box{position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:52px;display:flex;align-items:center;gap:44px;box-shadow:var(--shadow-soft);flex-wrap:wrap;overflow:hidden}.tl-home .news-box::before{content:"";position:absolute;left:0;top:0;bottom:0;width:5px;background:var(--spectrum)}.tl-home .news-box h2{font-size:30px;font-weight:600;margin-bottom:9px}.tl-home .news-box h2 em{font-style:italic;color:var(--copper)}.tl-home .news-box p{color:var(--muted);font-size:15px}.tl-home .news-form{margin-left:auto;display:flex;gap:11px;flex-wrap:wrap}.tl-home .news-form input{font-family:var(--mono);font-size:13px;padding:16px 20px;border:1px solid var(--line);border-radius:11px;width:280px;background:var(--cream)}.tl-home .news-form input:focus{outline:2px solid var(--green);border-color:transparent}.tl-home /* reassurance */
.reass{background:#fff;border-top:1px solid var(--line)}.tl-home .reass .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;padding:42px 30px}.tl-home .reass-item{display:flex;gap:14px;align-items:center;padding:4px 22px}.tl-home .reass-item+.reass-item{border-left:1px solid var(--line)}.tl-home .reass-ic{flex:none;width:46px;height:46px;border-radius:50%;background:var(--sage);color:var(--green-d);display:grid;place-items:center}.tl-home .reass-ic svg{width:23px;height:23px}.tl-home .reass-item b{font-family:var(--disp);font-weight:600;font-size:15px;display:block}.tl-home .reass-item small{color:var(--muted);font-size:12.5px}.tl-home /* footer */
footer{background:var(--forest);color:#aebfb2}.tl-home .foot-top{padding:72px 0 48px;display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:42px}.tl-home .foot .logo b{color:#fff}.tl-home .foot .logo{margin-bottom:18px}.tl-home .foot-about{font-size:14px;color:#9fb2a4;max-width:300px;margin-bottom:22px}.tl-home .foot h4{font-family:var(--disp);color:#fff;font-size:17px;font-weight:600;margin-bottom:18px}.tl-home .foot ul{list-style:none;display:flex;flex-direction:column;gap:11px}.tl-home .foot ul a{font-size:14px;color:#9fb2a4;transition:.2s}.tl-home .foot ul a:hover{color:var(--gold)}.tl-home .socials{display:flex;gap:12px;margin-top:4px}.tl-home .socials a{width:40px;height:40px;border-radius:11px;background:rgba(255,255,255,.07);display:grid;place-items:center;color:#cfe0d4;transition:.2s}.tl-home .socials a:hover{background:var(--copper)}.tl-home .socials svg{width:18px;height:18px}.tl-home .foot-sign{font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:#6f8576;margin-top:14px;display:flex;align-items:center;gap:8px}.tl-home .foot-sign::before{content:"";width:24px;height:5px;border-radius:3px;background:var(--spectrum)}.tl-home .foot-bottom{border-top:1px solid rgba(255,255,255,.1);padding:24px 0;display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap}.tl-home .foot-bottom small{font-family:var(--mono);font-size:11px;letter-spacing:.03em;color:#8aa093}.tl-home .pays{display:flex;gap:9px;align-items:center}.tl-home .pay{height:31px;padding:0 12px;border-radius:7px;background:#fff;color:#1a2b20;font-family:var(--mono);font-weight:600;font-size:11px;display:grid;place-items:center}

@media(max-width:900px){.tl-home .menu, .tl-home .search, .tl-home .hero-stats{display:none}.tl-home .burger{display:inline-flex;color:#27332b}.tl-home .burger svg{width:26px;height:26px}.tl-home .hero .wrap{grid-template-columns:1fr;gap:34px;min-height:0}.tl-home .hero-media{order:-1}.tl-home .hero-frame{aspect-ratio:16/12}.tl-home .float-card{display:none}.tl-home .usp .wrap, .tl-home .reass .wrap{grid-template-columns:1fr 1fr;gap:20px}.tl-home .usp-item+.usp-item, .tl-home .reass-item+.reass-item{border-left:none}.tl-home .univers .grid, .tl-home .p-grid, .tl-home .spot .wrap, .tl-home .story .wrap, .tl-home .compare .grid, .tl-home .vid-grid, .tl-home .reviews, .tl-home .guides .grid{grid-template-columns:1fr}.tl-home .story-media .score{right:18px}.tl-home .proof-split{grid-template-columns:1fr;gap:30px}.tl-home .pro .actions{margin-left:0}.tl-home .news-form{margin-left:0}.tl-home .section{padding:70px 0}.tl-home .spot-media, .tl-home .story-media{order:2}.tl-home .facts{grid-template-columns:1fr}
}.tl-home /* ===== MEGA MENU v4 (ETS-compatible) ===== */
.menu .mi{position:static;display:flex;align-items:center}.tl-home .menu .mega{position:absolute;left:0;right:0;top:100%;background:#fff;border-top:1px solid var(--line);box-shadow:0 30px 50px -24px rgba(4,18,10,.42);opacity:0;visibility:hidden;transform:translateY(8px);transition:.2s;z-index:55}.tl-home .menu .mega::before{content:"";position:absolute;left:0;right:0;top:0;height:3px;background:var(--spectrum)}.tl-home .menu .mi:hover .mega{opacity:1;visibility:visible;transform:translateY(0)}.tl-home .mega-in{max-width:var(--maxw);margin:0 auto;padding:36px 30px;display:grid;grid-template-columns:1fr 1fr 1fr 1.15fr;gap:36px}.tl-home .mega-col h5{font-family:var(--mono);font-size:11px;letter-spacing:.13em;text-transform:uppercase;color:var(--copper);margin-bottom:16px;padding-bottom:11px;border-bottom:1px solid var(--line);position:relative}.tl-home .mega-col h5::after{content:"";position:absolute;left:0;bottom:-1px;width:36px;height:2px;background:var(--spectrum)}.tl-home .mega-col ul{list-style:none;display:flex;flex-direction:column;gap:12px}.tl-home .mega-col ul a{font-family:var(--body);font-weight:700;font-size:14.5px;color:#2b372f;display:inline-flex;align-items:center;gap:9px;transition:.18s}.tl-home .mega-col ul a::after{display:none}.tl-home .mega-col ul a:hover{color:var(--green-d);transform:translateX(3px)}.tl-home .mega-col ul a .bdg{font-family:var(--mono);font-size:9px;letter-spacing:.04em;color:#fff;background:var(--green);border-radius:5px;padding:2px 6px;text-transform:uppercase}.tl-home .mega-col ul a .bdg.promo{background:var(--copper)}.tl-home .mega-feat{position:relative;overflow:hidden;background:var(--forest);border-radius:14px;padding:22px 22px 22px;color:#fff;display:flex;flex-direction:column;min-height:236px}.tl-home .mega-feat .ft{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--gold)}.tl-home .mega-feat h4{font-size:21px;margin:7px 0 7px;color:#fff}.tl-home .mega-feat p{font-size:13px;color:#bdd2c3;margin-bottom:14px;max-width:60%}.tl-home .mega-feat .lnk{font-family:var(--mono);font-size:11px;letter-spacing:.04em;text-transform:uppercase;color:#fff;border-bottom:2px solid var(--copper);padding-bottom:3px;align-self:flex-start}.tl-home .mega-feat img{position:absolute;right:-12px;bottom:-10px;width:150px;filter:drop-shadow(0 14px 24px rgba(0,0,0,.5))}.tl-home .mega-feat::after{content:"";position:absolute;left:0;right:0;bottom:0;height:3px;background:var(--spectrum);z-index:2}.tl-home .mega-brands{display:grid;grid-template-columns:1fr 1fr;gap:12px;align-content:start}.tl-home .mega-brands a{background:#fff;border:1px solid var(--line);border-radius:11px;height:62px;display:grid;place-items:center;padding:12px}.tl-home .mega-brands img{max-height:26px;filter:grayscale(1);opacity:.72;transition:.2s}.tl-home .mega-brands a:hover img{filter:none;opacity:1}.tl-home .mega-allcat{grid-column:1/-1;border-top:1px solid var(--line);margin-top:4px;padding-top:16px;display:flex;align-items:center;justify-content:space-between;font-family:var(--mono);font-size:11px;letter-spacing:.05em;text-transform:uppercase;color:var(--muted)}.tl-home .mega-allcat a{color:var(--green-d);font-weight:700}.tl-home /* ===== CONFIGURATEUR v4 ===== */
.config{background:var(--forest);color:#eaf3ec}.tl-home .config .panel{position:relative;overflow:hidden;background:linear-gradient(160deg,#0c2316,#081a10);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-lg);padding:42px}.tl-home .config .panel::before{content:"";position:absolute;left:0;right:0;top:0;height:3px;background:var(--spectrum)}.tl-home .config .steps{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;margin:4px 0 28px}.tl-home .config .sh{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:#9bb3a4;margin-bottom:15px;display:flex;align-items:center;gap:10px}.tl-home .config .sh b{width:24px;height:24px;border-radius:7px;background:rgba(255,255,255,.08);color:var(--gold);display:grid;place-items:center;font-size:12px;font-weight:600}.tl-home .config .opts{display:flex;flex-wrap:wrap;gap:10px}.tl-home .config .opt{font-family:var(--body);font-weight:700;font-size:14px;color:#dbe7df;border:1px solid rgba(255,255,255,.18);border-radius:11px;padding:11px 15px;cursor:pointer;transition:.18s;background:rgba(255,255,255,.03)}.tl-home .config .opt:hover{border-color:rgba(255,255,255,.45)}.tl-home .config .opt.on{background:#fff;color:var(--forest);border-color:#fff;box-shadow:0 8px 20px -10px rgba(0,0,0,.5)}.tl-home .config .result{display:flex;align-items:center;justify-content:space-between;gap:20px;border-top:1px solid rgba(255,255,255,.12);padding-top:24px;flex-wrap:wrap}.tl-home .config .rtxt{font-family:var(--mono);font-size:12px;letter-spacing:.03em;color:#9bb3a4}.tl-home .config .rtxt b{color:var(--gold);font-size:16px}.tl-home .config .hint{font-family:var(--mono);font-size:10.5px;letter-spacing:.04em;color:#6f8576;margin-top:16px;text-align:center}
@media(max-width:900px){.tl-home .mega-in{grid-template-columns:1fr 1fr;gap:22px}.tl-home .config .steps{grid-template-columns:1fr;gap:20px}.tl-home .config .result{flex-direction:column;align-items:flex-start}}.tl-home /* ===== v6 : accessibilité · onglets · cross-sell · sélecteur · countdown ===== */
.skip{position:absolute;left:-9999px;top:0;z-index:200;background:var(--gold);color:#3a2600;font-family:var(--mono);font-size:12px;padding:11px 18px;border-radius:0 0 9px 0;font-weight:600}.tl-home .skip:focus{left:0}.tl-home a:focus-visible, .tl-home button:focus-visible, .tl-home .opt:focus-visible, .tl-home .tm-opt:focus-visible, .tl-home .tab:focus-visible{outline:3px solid var(--gold);outline-offset:2px;border-radius:6px}.tl-home .menu .mi:focus-within .mega{opacity:1;visibility:visible;transform:translateY(0)}.tl-home .announce .cut{color:#fff}.tl-home .announce .cd{font-family:var(--mono);color:var(--gold);font-weight:600}.tl-home /* onglets produits */
.tabs{display:flex;justify-content:center;gap:10px;flex-wrap:wrap;margin-bottom:42px}.tl-home .tab{font-family:var(--mono);font-size:12px;letter-spacing:.07em;text-transform:uppercase;color:var(--muted);background:#fff;border:1px solid var(--line);border-radius:999px;padding:11px 20px;cursor:pointer;transition:.2s;display:inline-flex;align-items:center;gap:8px}.tl-home .tab:hover{border-color:var(--green)}.tl-home .tab[aria-selected="true"]{background:var(--forest);color:#fff;border-color:var(--forest)}.tl-home .tab .c{font-size:10px;background:var(--copper);color:#fff;border-radius:999px;padding:1px 7px}.tl-home .tab[aria-selected="true"] .c{background:var(--gold);color:#3a2600}.tl-home .tabpanel[hidden]{display:none}.tl-home /* sélecteur TM PRO */
.tm-sel{margin:4px 0 22px}.tl-home .tm-sel .lab{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:#9bb3a4;margin-bottom:12px;display:block}.tl-home .tm-opts{display:flex;gap:10px;flex-wrap:wrap}.tl-home .tm-opt{font-family:var(--mono);font-weight:600;font-size:14px;color:#dbe7df;border:1px solid rgba(255,255,255,.2);border-radius:11px;padding:11px 15px;cursor:pointer;transition:.18s;min-width:78px;text-align:center;background:rgba(255,255,255,.03)}.tl-home .tm-opt:hover{border-color:rgba(255,255,255,.45)}.tl-home .tm-opt.on{background:#fff;color:var(--forest);border-color:#fff}.tl-home .tm-opt small{display:block;font-size:10px;opacity:.65;margin-top:3px;font-weight:400}.tl-home .tm-buy{display:flex;align-items:center;gap:22px;flex-wrap:wrap}.tl-home .tm-price{font-family:var(--disp);font-weight:600;font-size:34px;color:#fff;line-height:1.05}.tl-home .tm-price small{font-family:var(--mono);font-size:11px;color:#9bb3a4;display:block;letter-spacing:.04em;margin-bottom:4px;font-weight:400}.tl-home /* cross-sell */
.xsell{background:var(--cream)}.tl-home .xsell .grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}.tl-home .xs-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:18px;display:flex;flex-direction:column;transition:.28s}.tl-home .xs-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-soft)}.tl-home .xs-thumb{background:radial-gradient(120% 90% at 50% 0%,#fff,#eef1ec);border:1px solid var(--line);border-radius:12px;aspect-ratio:1/1;display:grid;place-items:center;padding:16px;margin-bottom:14px}.tl-home .xs-thumb img{max-height:100%;width:auto;object-fit:contain}.tl-home .xs-card .xc{font-family:var(--mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--copper)}.tl-home .xs-card h4{font-family:var(--disp);font-weight:600;font-size:16px;margin:5px 0 12px;line-height:1.2}.tl-home .xs-foot{margin-top:auto;display:flex;align-items:center;justify-content:space-between}.tl-home .xs-price{font-family:var(--disp);font-weight:600;color:var(--green-d);font-size:18px}.tl-home .xs-add{font-family:var(--mono);font-size:11px;letter-spacing:.04em;text-transform:uppercase;color:#fff;background:var(--green);border:none;border-radius:9px;padding:9px 13px;cursor:pointer;transition:.2s}.tl-home .xs-add:hover{background:var(--green-600)}
@media(max-width:900px){.tl-home .xsell .grid{grid-template-columns:1fr 1fr}.tl-home .tm-price{font-size:28px}}

/* === intégration miniature (listing classic) === */
.tl-card__actions{position:absolute;top:12px;right:12px;z-index:3}
.tl-card__actions a,.tl-card__actions button,.tl-card__actions .wishlist-button-add{width:36px;height:36px;border-radius:50%;background:#fff;border:1px solid var(--tl-line);display:inline-grid;place-items:center;color:var(--tl-muted);cursor:pointer;text-decoration:none}
.tl-card__actions i,.tl-card__actions svg{font-size:18px;width:18px;height:18px}
.tl-card .tl-card__peek-label{display:none}
.tl-flag--on-sale{background:var(--tl-copper-text)}
.tl-flag--out-of-stock{background:var(--tl-muted)}
.tl-card__price .tl-flag--discount{vertical-align:middle;margin-left:6px;font-size:10px}
.products{row-gap:24px}
.tl-card{height:100%}

/* === footer surcharge modules sombre === */
.tl-footer .tl-container{max-width:1240px;margin:0 auto;padding:0 24px}
.tl-footer__before .tl-container,.tl-footer__main .tl-container,.tl-footer__after .tl-container{padding-top:28px;padding-bottom:8px}
.tl-footer__cols{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:32px;padding-bottom:36px}
.tl-footer [class*="row"]{display:contents}
.tl-footer [class*="col-"]{width:auto;max-width:none;flex:initial;padding-left:0;padding-right:0}
.tl-footer ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
.tl-footer a{color:#9fb2a4;text-decoration:none}.tl-footer a:hover{color:var(--tl-gold)}
.tl-footer h1,.tl-footer h2,.tl-footer h3,.tl-footer .h3,.tl-footer .title,.tl-footer .block-title,.tl-footer .links .title{font-family:var(--tl-font-display)!important;color:#fff!important;font-size:16px!important;font-weight:600;margin:0 0 14px;text-transform:none;border:0}
.tl-footer p,.tl-footer li,.tl-footer .block-contact,.tl-footer .navbar-toggler{color:#9fb2a4}
.tl-footer input[type=text],.tl-footer input[type=email]{padding:12px 14px;border-radius:10px;border:1px solid rgba(255,255,255,.18);background:rgba(255,255,255,.06);color:#fff}
.tl-footer input::placeholder{color:#7f998a}
.tl-footer button[type=submit],.tl-footer .btn{background:var(--tl-green);color:#fff;border:0;border-radius:10px;padding:12px 16px}
.tl-footer img{max-height:34px;width:auto}
.tl-footer__bottom-in{padding:22px 24px;display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap;border-top:1px solid rgba(255,255,255,.1)}
.tl-footer__bottom-in small,.tl-footer__bottom-in small a{font-family:var(--tl-font-mono);font-size:11px;color:#8aa093}

/* === header re-skin classic === */
#header{background:#fff}
#header .header-nav{background:var(--tl-cream);border-bottom:1px solid var(--tl-line);font-family:var(--tl-font-mono);font-size:12px;letter-spacing:.02em}
#header .header-nav a{color:var(--tl-ink-2);text-decoration:none}
#header .header-top{padding:16px 0;border-bottom:1px solid var(--tl-line)}
#_desktop_logo img,#header .logo{max-height:48px;width:auto}
#header #top-menu,#header .top-menu{display:flex;flex-wrap:wrap;gap:26px;list-style:none;margin:0;padding:0}
#header #_desktop_top_menu a,#header .top-menu a{font-family:var(--tl-font-body);font-weight:700;font-size:15px;color:#27332b;text-decoration:none;position:relative;padding:6px 0}
#header #_desktop_top_menu a:hover{color:var(--tl-green)}
#header .search-widget input[type=text],#header #search_widget input{border:1px solid var(--tl-line);border-radius:11px;background:var(--tl-cream);padding:11px 16px;font-family:var(--tl-font-mono);font-size:13px}
#header .search-widget button[type=submit]{color:var(--tl-green)}
#header .blockcart{background:transparent}
#header .blockcart .cart-products-count{background:var(--tl-copper-text);color:#fff;border-radius:50%}
#header .header-top-right{display:flex;align-items:center;gap:20px;justify-content:flex-end}

/* blockwishlist : bouton coeur injecte dans la carte */
.tl-card__media{position:relative}
.tl-card__media .wishlist-button{position:absolute;top:.7rem;right:.7rem;z-index:5}
.tl-card__media .wishlist-button-add,.tl-card__media .wishlist-button>button,.tl-card__media .wishlist-button>div{display:grid;place-items:center;width:38px;height:38px;padding:0;border-radius:999px;background:rgba(255,255,255,.92);border:1px solid var(--tl-line,#e6ddcb);box-shadow:0 4px 14px rgba(10,31,19,.12);cursor:pointer;transition:transform .15s ease,background .15s ease,color .15s ease;color:var(--tl-forest,#0a1f13)}
.tl-card__media .wishlist-button-add:hover,.tl-card__media .wishlist-button>button:hover{transform:translateY(-1px);background:#fff;color:var(--tl-magenta,#d61f9b)}
.tl-card__media .wishlist-button svg{width:18px;height:18px}

/* ============================================================
   TerraLED — Catalogue (catégorie + fiche + popup panier)
   Restyle CSS sur markup classic : aucun JS natif touché.
   ============================================================ */

/* ---------- Cadre général pages catalogue ---------- */
#main .page-header h1,
#js-product-list-header{
  font-family:var(--tl-font-display);
  font-weight:600;letter-spacing:-.01em;color:var(--tl-forest);
  font-size:clamp(1.6rem,3.4vw,2.4rem);line-height:1.1;margin:0 0 .2em;
}
.breadcrumb{font-family:var(--tl-font-mono);font-size:.74rem;letter-spacing:.04em;text-transform:uppercase;background:none;padding:1rem 0 .4rem}
.breadcrumb ol{margin:0;padding:0}
.breadcrumb li a{color:var(--tl-muted)}
.breadcrumb li a:hover{color:var(--tl-green)}
.breadcrumb li:last-child span,.breadcrumb li.active span{color:var(--tl-copper-text)}

/* ---------- Colonne gauche : arbre catégories ---------- */
#left-column .block-categories,
#left-column #search_filters_wrapper,
#left-column .block_newsletter,
#left-column .ps-emptyspace{
  background:var(--tl-bg);border:1px solid var(--tl-line);
  border-radius:var(--tl-r-lg);padding:1.1rem 1.15rem;margin-bottom:1.1rem;
  box-shadow:var(--tl-shadow-sm);
}
#left-column .block-categories .category-top-menu{margin:0;padding:0;list-style:none}
.block-categories .h6,.block-categories .category-sub__item--0>a{
  font-family:var(--tl-font-display);font-size:1.05rem;color:var(--tl-forest);font-weight:600;
}
.block-categories a{color:var(--tl-ink-2);font-size:.92rem;padding:.18rem 0;display:inline-block}
.block-categories a:hover{color:var(--tl-green)}
.block-categories .category-sub-menu{margin:.2rem 0 .2rem .55rem;padding-left:.7rem;border-left:1px solid var(--tl-line)}
.block-categories li{position:relative}
.block-categories .navbar-toggler,.block-categories .add,.block-categories .remove{color:var(--tl-copper);opacity:.85}
.block-categories .collapse-icons .remove{display:none}

/* ---------- Facettes ps_facetedsearch ---------- */
#search_filters .h6,
#search_filters .facet-title{
  font-family:var(--tl-font-mono);text-transform:uppercase;letter-spacing:.06em;
  font-size:.76rem;color:var(--tl-copper-text);font-weight:700;margin:.2rem 0 .5rem;
}
#search_filters{border:0;padding:0}
#search_filters .facet{padding:.7rem 0;border-top:1px solid var(--tl-line)}
#search_filters .facet:first-of-type{border-top:0}
#search_filters .facet-label{font-size:.9rem}
#search_filters .facet-label a{color:var(--tl-ink-2);transition:color var(--tl-dur)}
#search_filters .facet-label a:hover,#search_filters .facet-label.active a{color:var(--tl-green)}
#search_filters .facet-label .magnitude{color:var(--tl-muted);font-family:var(--tl-font-mono);font-size:.78rem}
#search_filters .custom-checkbox input[type=checkbox]:checked+span,
#search_filters .custom-checkbox input[type=checkbox]+span{border-radius:5px;border:1.5px solid var(--tl-line)}
#search_filters .custom-checkbox input[type=checkbox]:checked+span{background:var(--tl-green);border-color:var(--tl-green)}
#search_filters .custom-checkbox span .checkbox-checked{color:#fff}
#search_filters .ui-slider{background:var(--tl-cream-2);border:0;height:5px;border-radius:99px}
#search_filters .ui-slider .ui-slider-range{background:linear-gradient(90deg,var(--tl-green),var(--tl-copper))}
#search_filters .ui-slider .ui-slider-handle{background:var(--tl-forest);border:2px solid #fff;border-radius:99px;box-shadow:var(--tl-shadow-sm)}
.js-search-filters-clear-all,#_mobile_search_filters_clear_all{
  font-family:var(--tl-font-mono);font-size:.74rem;letter-spacing:.04em;text-transform:uppercase;
  color:var(--tl-copper-text);background:none;border:0;padding:.3rem 0;cursor:pointer;
}
.js-search-filters-clear-all:hover{color:var(--tl-green)}
.active_filters{background:var(--tl-cream);border:1px solid var(--tl-line);border-radius:var(--tl-r);padding:.7rem .9rem;margin-bottom:1rem}
.active_filters .active-filter-title,.active_filters p{font-family:var(--tl-font-mono);font-size:.74rem;text-transform:uppercase;letter-spacing:.04em;color:var(--tl-muted)}
.active_filters .filter-block{background:#fff;border:1px solid var(--tl-line);border-radius:99px;color:var(--tl-ink-2);padding:.18rem .65rem;font-size:.82rem}
.active_filters .filter-block .close{color:var(--tl-copper)}

/* ---------- Description catégorie ---------- */
#category-description,.category-description,#js-product-list-header+*{line-height:1.65}
#category-description{color:var(--tl-ink-2);max-width:74ch}
#category-description h2,.category-description h2{font-family:var(--tl-font-display);color:var(--tl-forest);font-weight:600}
.category-cover img,.category-header img{border-radius:var(--tl-r-lg)}

/* ---------- Barre tri / nombre de produits ---------- */
.products-selection,.products-sort-order .select-title{font-family:var(--tl-font-body)}
.total-products p,#js-product-count,.total-products{font-family:var(--tl-font-mono);font-size:.8rem;letter-spacing:.03em;color:var(--tl-muted);text-transform:uppercase}
.products-sort-order{position:relative}
.products-sort-order .select-title{
  border:1px solid var(--tl-line);border-radius:99px;background:#fff;color:var(--tl-ink);
  padding:.5rem .95rem;font-size:.85rem;box-shadow:var(--tl-shadow-sm);
}
.products-sort-order .dropdown-menu{border:1px solid var(--tl-line);border-radius:var(--tl-r);box-shadow:var(--tl-shadow);padding:.35rem}
.products-sort-order .dropdown-menu a{border-radius:8px;color:var(--tl-ink-2);font-size:.88rem;padding:.4rem .6rem}
.products-sort-order .dropdown-menu a:hover{background:var(--tl-cream);color:var(--tl-green)}
.sort-by-row{align-items:center}

/* ---------- Sous-catégories ---------- */
.subcategories ul,#subcategories ul{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:1rem;list-style:none;margin:0;padding:0}
.subcategory{border:1px solid var(--tl-line);border-radius:var(--tl-r-lg);overflow:hidden;background:#fff;transition:transform var(--tl-dur) var(--tl-ease),box-shadow var(--tl-dur)}
.subcategory:hover{transform:translateY(-3px);box-shadow:var(--tl-shadow)}
.subcategory-image{display:block;background:linear-gradient(135deg,var(--tl-cream),var(--tl-cream-2));position:relative;min-height:120px}
.subcategory-image::after{content:"";position:absolute;inset:auto 0 0 0;height:4px;background:linear-gradient(90deg,#2563ff,#7b3ff2,#d61f9b,#ff5a3c,#ffb02e);opacity:.85}
.subcategory-image img[src*="-default"],.subcategory-image img[src*="no_picture"]{opacity:0}
.subcategory-name{display:block;font-family:var(--tl-font-display);color:var(--tl-forest);font-weight:600;padding:.7rem .85rem;text-align:left}
.subcategory h5 a{color:var(--tl-forest)}

/* ---------- Pagination ---------- */
.pagination{margin-top:1.6rem}
.pagination .page-list{display:flex;gap:.35rem;flex-wrap:wrap;align-items:center;padding:0}
.pagination .page-item a,.pagination .page-item span,.page-list li a{
  display:grid;place-items:center;min-width:40px;height:40px;padding:0 .6rem;border-radius:10px;
  border:1px solid var(--tl-line);background:#fff;color:var(--tl-ink-2);font-family:var(--tl-font-mono);font-size:.85rem;
  transition:all var(--tl-dur) var(--tl-ease);
}
.pagination .page-item a:hover,.page-list li a:hover{border-color:var(--tl-green);color:var(--tl-green)}
.pagination .page-item.current span,.page-list li.current a,.page-list li.active a{background:var(--tl-forest);color:var(--tl-cream);border-color:var(--tl-forest)}
.pagination .page-item.disabled span,.page-list li.disabled a{opacity:.4}

/* ============================================================
   FICHE PRODUIT
   ============================================================ */
.product-container,#product #content-wrapper{}
#product .product-information,#product .product-info{padding-left:clamp(0px,2vw,2rem)}
/* titre */
#product h1,#product .page-title,.product-information h1{
  font-family:var(--tl-font-display);font-weight:600;letter-spacing:-.01em;color:var(--tl-forest);
  font-size:clamp(1.5rem,3vw,2.1rem);line-height:1.12;
}
/* marque / reference */
.product-manufacturer img{max-height:46px;width:auto}
.product-reference label,.product-reference{font-family:var(--tl-font-mono);font-size:.78rem;letter-spacing:.03em;color:var(--tl-muted)}

/* galerie */
.product-cover{border:1px solid var(--tl-line);border-radius:var(--tl-r-xl);overflow:hidden;background:#fff;box-shadow:var(--tl-shadow-sm)}
.product-cover img{border-radius:var(--tl-r-xl)}
.product-cover .layer{border-radius:var(--tl-r-xl);background:rgba(10,31,19,.28)}
.product-cover .layer .zoom-in{color:#fff}
.js-qv-mask .thumb-container,.product-images li.thumb-container{margin:.35rem}
.product-images img,.js-thumb{border-radius:12px;border:1px solid var(--tl-line);transition:border-color var(--tl-dur)}
.product-images img.selected,.js-thumb.selected,.product-images img:hover{border-color:var(--tl-green)}
#product .images-container .product-images .arrows .arrow-up,
#product .images-container .product-images .arrows .arrow-down{color:var(--tl-forest)}

/* prix */
.product-prices{margin:1rem 0}
.product-price,.current-price .price,#product .current-price span{
  font-family:var(--tl-font-display);font-weight:600;color:var(--tl-forest);font-size:1.9rem;line-height:1;
}
.product-discount .regular-price{color:var(--tl-muted);text-decoration:line-through;font-family:var(--tl-font-body);font-size:1rem}
.has-discount .discount,.product-flag.discount,.discount-percentage{
  background:var(--tl-copper);color:#fff;border-radius:99px;font-family:var(--tl-font-mono);font-weight:700;
  padding:.15rem .55rem;font-size:.8rem;
}
.tax-shipping-delivery-label{color:var(--tl-muted);font-size:.78rem}
.product-unit-price{color:var(--tl-muted);font-size:.8rem}

/* drapeaux produit */
.product-flags li.product-flag{
  font-family:var(--tl-font-mono);text-transform:uppercase;letter-spacing:.04em;font-size:.7rem;font-weight:700;
  border-radius:99px;padding:.22rem .6rem;box-shadow:var(--tl-shadow-sm);
}
.product-flag.new,.product-flag.online-only{background:var(--tl-forest);color:var(--tl-cream)}
.product-flag.on-sale{background:linear-gradient(90deg,var(--tl-copper),var(--tl-amber));color:#fff}

/* variantes */
.product-variants>.product-variants-item{margin:.7rem 0}
.product-variants .control-label,.product-variants label{font-family:var(--tl-font-mono);text-transform:uppercase;letter-spacing:.04em;font-size:.74rem;color:var(--tl-copper-text);font-weight:700}
.product-variants select.form-control,.product-variants .form-control{
  border:1px solid var(--tl-line);border-radius:10px;background:#fff;color:var(--tl-ink);padding:.55rem .8rem;
  box-shadow:none;min-height:auto;
}
.product-variants select.form-control:focus{border-color:var(--tl-green);box-shadow:0 0 0 3px rgba(23,96,53,.12)}
.product-variants ul li .color,.product-variants ul li .texture{border-radius:99px;border:2px solid #fff;box-shadow:0 0 0 1px var(--tl-line);width:34px;height:34px}
.product-variants ul li input:checked+span.color,.product-variants ul li .color.active{box-shadow:0 0 0 2px var(--tl-green)}

/* quantite */
.product-quantity .qty{margin-right:.6rem}
.product-quantity #quantity_wanted,.input-group.bootstrap-touchspin input{
  border:1px solid var(--tl-line);border-radius:10px;text-align:center;font-family:var(--tl-font-mono);
  color:var(--tl-ink);height:48px;box-shadow:none;
}
.bootstrap-touchspin .btn-touchspin,.product-quantity .bootstrap-touchspin-up,.product-quantity .bootstrap-touchspin-down{
  background:var(--tl-cream);border:1px solid var(--tl-line);color:var(--tl-forest);
}
.bootstrap-touchspin .btn-touchspin:hover{background:var(--tl-cream-2)}

/* bouton ajout panier */
.product-add-to-cart .add{margin:0}
#product .btn.add-to-cart,.product-actions .add-to-cart,button[data-button-action="add-to-cart"]{
  background:var(--tl-forest);color:var(--tl-cream);border:0;border-radius:99px;
  font-family:var(--tl-font-mono);text-transform:uppercase;letter-spacing:.06em;font-weight:700;font-size:.92rem;
  padding:.95rem 1.6rem;height:auto;box-shadow:var(--tl-shadow);position:relative;overflow:hidden;
  transition:transform var(--tl-dur) var(--tl-ease),box-shadow var(--tl-dur);
}
#product .btn.add-to-cart::before{content:"";position:absolute;left:0;right:0;top:0;height:3px;background:linear-gradient(90deg,#2563ff,#7b3ff2,#d61f9b,#ff5a3c,#ffb02e);opacity:0;transition:opacity var(--tl-dur)}
#product .btn.add-to-cart:hover{transform:translateY(-2px);background:var(--tl-forest-2)}
#product .btn.add-to-cart:hover::before{opacity:1}
#product .btn.add-to-cart:disabled,#product .btn.add-to-cart[disabled]{opacity:.5;cursor:not-allowed}
#product .btn.add-to-cart .material-icons{margin-right:.4rem}

/* disponibilite */
#product-availability,.product-availability{font-family:var(--tl-font-mono);font-size:.82rem;letter-spacing:.02em}
#product-availability .material-icons.product-available,.product-available{color:var(--tl-instock)}
#product-availability .material-icons.product-last-items,.product-last-items{color:var(--tl-lowstock)}
#product-availability .material-icons.product-unavailable,.product-unavailable{color:var(--tl-outstock)}

/* wishlist coeur sur fiche */
.product-actions .wishlist-button-add,.wishlist-button-product{
  border:1px solid var(--tl-line);border-radius:99px;width:48px;height:48px;background:#fff;color:var(--tl-forest);
  display:grid;place-items:center;transition:all var(--tl-dur)
}
.product-actions .wishlist-button-add:hover{color:var(--tl-magenta);border-color:var(--tl-magenta)}

/* reassurance produit (blockreassurance) */
.product-additional-info .block-social,.product-features,.reassurance-block{margin-top:1.2rem}
#blockreassurance_product .block-title,.blockreassurance .block-title{font-family:var(--tl-font-mono);font-size:.82rem;color:var(--tl-ink);text-transform:none;letter-spacing:0}
#blockreassurance_product ul li,.blockreassurance li{border-top:1px solid var(--tl-line)}
#blockreassurance_product .item-product img,.blockreassurance img{filter:none}

/* onglets details */
.product-tabs .nav-tabs,.tabs .nav-tabs{border-bottom:1px solid var(--tl-line)}
.product-tabs .nav-tabs .nav-link,.tabs .nav-tabs .nav-link{
  font-family:var(--tl-font-mono);text-transform:uppercase;letter-spacing:.05em;font-size:.78rem;font-weight:700;
  color:var(--tl-muted);border:0;border-bottom:2px solid transparent;background:none;padding:.7rem 1rem;
}
.product-tabs .nav-tabs .nav-link.active,.tabs .nav-tabs .nav-link.active{color:var(--tl-forest);border-bottom-color:var(--tl-copper)}
.tab-content{padding:1.2rem 0;color:var(--tl-ink-2);line-height:1.7}
.product-description h1,.product-description h2,.product-description h3{font-family:var(--tl-font-display);color:var(--tl-forest)}

/* features */
.product-features .data-sheet{display:grid;grid-template-columns:1fr;gap:.2rem;margin:0;padding:0}
.product-features .data-sheet dt.name{background:var(--tl-cream);border-radius:8px 8px 0 0;padding:.4rem .7rem;font-family:var(--tl-font-mono);font-size:.78rem;color:var(--tl-copper-text);margin:0}
.product-features .data-sheet dd.value{background:#fff;border:1px solid var(--tl-line);border-top:0;border-radius:0 0 8px 8px;padding:.45rem .7rem;margin:0 0 .5rem}

/* avis productcomments */
.product-comments .comments_note,.product-list-reviews .comments_note,.star_content{color:var(--tl-rating-fill)}
#product-comments-list .comment,.product-comment-list-item{border:1px solid var(--tl-line);border-radius:var(--tl-r);padding:1rem;margin-bottom:.8rem;background:#fff}
.product-comments-additional-info .btn,#new-comment-form-trigger,.btn-comment{
  background:transparent;color:var(--tl-forest);border:1px solid var(--tl-forest);border-radius:99px;
  font-family:var(--tl-font-mono);text-transform:uppercase;letter-spacing:.05em;font-size:.78rem;padding:.55rem 1.1rem;
}
.product-comments-additional-info .btn:hover{background:var(--tl-forest);color:var(--tl-cream)}

/* cross-sell / accessoires */
.product-accessories h2,.featured-products h2,.product-accessories .h2{font-family:var(--tl-font-display);color:var(--tl-forest);font-weight:600}

/* ============================================================
   POPUP AJOUT PANIER (blockcart modal)
   ============================================================ */
#blockcart-modal .modal-content{border:0;border-radius:var(--tl-r-xl);overflow:hidden;box-shadow:var(--tl-shadow);background:var(--tl-bg, #fff)}
#blockcart-modal .modal-header{background:var(--tl-forest);border:0;padding:1rem 1.4rem;position:relative}
#blockcart-modal .modal-header::after{content:"";position:absolute;left:0;right:0;bottom:0;height:3px;background:linear-gradient(90deg,#2563ff,#7b3ff2,#d61f9b,#ff5a3c,#ffb02e)}
#blockcart-modal .modal-title{font-family:var(--tl-font-display);color:var(--tl-cream);font-weight:600;font-size:1.15rem;display:flex;align-items:center;gap:.5rem}
#blockcart-modal .modal-title i,#blockcart-modal .modal-title .material-icons{color:var(--tl-gold)}
#blockcart-modal .close,#blockcart-modal .btn-close{color:var(--tl-cream);opacity:.85;text-shadow:none}
#blockcart-modal .modal-body{padding:1.4rem}
#blockcart-modal .product-image{border:1px solid var(--tl-line);border-radius:var(--tl-r);max-width:100%}
#blockcart-modal .product-name{font-family:var(--tl-font-display);color:var(--tl-forest);font-weight:600}
#blockcart-modal .product-price{font-family:var(--tl-font-display);color:var(--tl-copper-text);font-weight:600}
#blockcart-modal .cart-content{background:var(--tl-cream);border-radius:var(--tl-r);padding:1rem 1.1rem}
#blockcart-modal .cart-products-count{font-family:var(--tl-font-mono);color:var(--tl-ink)}
#blockcart-modal .cart-content-btn{display:flex;gap:.6rem;flex-wrap:wrap;margin-top:.5rem}
#blockcart-modal .cart-content-btn .btn-secondary,#blockcart-modal .cart-content-btn button{
  background:#fff;border:1px solid var(--tl-line);color:var(--tl-forest);border-radius:99px;
  font-family:var(--tl-font-mono);text-transform:uppercase;letter-spacing:.04em;font-size:.78rem;font-weight:700;padding:.65rem 1.1rem;
}
#blockcart-modal .cart-content-btn .btn-primary,#blockcart-modal .cart-content-btn a.btn-primary{
  background:var(--tl-forest);border:0;color:var(--tl-cream);border-radius:99px;
  font-family:var(--tl-font-mono);text-transform:uppercase;letter-spacing:.04em;font-size:.78rem;font-weight:700;padding:.65rem 1.2rem;
}
#blockcart-modal .cart-content-btn .btn-primary:hover{background:var(--tl-forest-2)}
#blockcart-modal .cart-content-btn .btn-secondary:hover{border-color:var(--tl-green);color:var(--tl-green)}

/* ===== TerraLED — Outils en-tête (compte + panier) + toast ===== */
.tl-tools{display:flex;align-items:center;gap:10px;margin-left:14px;flex:none}
.tl-tool{display:inline-flex;align-items:center;gap:8px;color:var(--tl-forest);text-decoration:none;padding:9px 12px;border-radius:12px;border:1px solid transparent;transition:background var(--tl-dur) var(--tl-ease),border-color var(--tl-dur),color var(--tl-dur);position:relative}
.tl-tool:hover{background:var(--tl-cream);border-color:var(--tl-line);color:var(--tl-green)}
.tl-tool svg{width:22px;height:22px;flex:none}
.tl-tool__lbl{font-family:var(--tl-font-mono);font-size:11px;letter-spacing:.04em;text-transform:uppercase;font-weight:600;white-space:nowrap}
.tl-tool--cart{position:relative}
.tl-tool__count{position:absolute;top:1px;right:1px;min-width:18px;height:18px;padding:0 4px;border-radius:999px;background:var(--tl-copper);color:#fff;font-family:var(--tl-font-mono);font-weight:700;font-size:10.5px;line-height:18px;text-align:center;box-shadow:0 0 0 2px #fff;transition:transform .25s var(--tl-ease)}
.tl-tool__count.is-bump{animation:tlbump .5s var(--tl-ease)}
@keyframes tlbump{0%{transform:scale(1)}35%{transform:scale(1.45)}100%{transform:scale(1)}}
@media(max-width:991px){.tl-tool__lbl{display:none}.tl-tools{margin-left:8px}}

/* toast ajout panier */
.tl-toast{position:fixed;right:20px;bottom:20px;z-index:1200;display:flex;align-items:center;gap:14px;background:var(--tl-forest);color:var(--tl-cream);border-radius:16px;padding:16px 18px;box-shadow:0 24px 50px -20px rgba(4,18,10,.6);transform:translateY(140%);opacity:0;transition:transform .4s var(--tl-ease),opacity .4s var(--tl-ease);max-width:min(92vw,400px);overflow:hidden}
.tl-toast::before{content:"";position:absolute;left:0;right:0;top:0;height:3px;background:linear-gradient(90deg,#2563ff,#7b3ff2,#d61f9b,#ff5a3c,#ffb02e)}
.tl-toast.is-on{transform:translateY(0);opacity:1}
.tl-toast__ic{flex:none;width:38px;height:38px;border-radius:50%;background:rgba(123,224,160,.16);display:grid;place-items:center;color:#7be0a0}
.tl-toast__ic svg{width:22px;height:22px}
.tl-toast__txt{flex:1;min-width:0}
.tl-toast__txt b{font-family:var(--tl-font-display);font-weight:600;font-size:15px;display:block;line-height:1.2}
.tl-toast__txt span{font-family:var(--tl-font-mono);font-size:11px;letter-spacing:.03em;color:#aec3b4}
.tl-toast__cta{flex:none;font-family:var(--tl-font-mono);font-weight:700;font-size:11px;letter-spacing:.05em;text-transform:uppercase;color:var(--tl-forest);background:var(--tl-gold);border-radius:999px;padding:9px 14px;text-decoration:none;transition:transform .2s}
.tl-toast__cta:hover{transform:translateY(-1px);color:var(--tl-forest)}
.tl-toast__close{flex:none;background:none;border:0;color:#9bb3a4;cursor:pointer;font-size:18px;line-height:1;padding:4px}

/* ===== TerraLED — Barre méga menu (in-theme) ===== */
#_desktop_top_menu{display:none}
.tl-meganav{position:relative;background:#fff;border-top:1px solid var(--tl-line);border-bottom:1px solid var(--tl-line);z-index:50}
.tl-meganav .container{display:flex;align-items:center}
.tl-meganav .tl-menu{margin:0;padding:0;list-style:none;display:flex;gap:30px;height:54px;align-items:center;flex-wrap:nowrap}
.tl-meganav .tl-menu>.mi>a{display:inline-flex;align-items:center;height:54px;font-family:var(--tl-font-body);font-weight:700;font-size:14.5px;color:#27332b;white-space:nowrap}
.tl-mega__in--auto{grid-template-columns:2.5fr 1fr;gap:30px;align-items:start}
.tl-mega__panel h5{font-family:var(--tl-font-mono);font-size:11px;letter-spacing:.13em;text-transform:uppercase;color:var(--tl-copper-text);margin:0 0 16px;padding-bottom:11px;border-bottom:1px solid var(--tl-line);position:relative}
.tl-mega__panel h5::after{content:"";position:absolute;left:0;bottom:-1px;width:36px;height:2px;background:var(--tl-spectral)}
.tl-mega__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:13px 30px}
.tl-mega__grid a{font-family:var(--tl-font-body);font-weight:700;font-size:14px;color:#2b372f;text-decoration:none;display:inline-flex;align-items:center;gap:9px;transition:color .18s var(--tl-ease),transform .18s var(--tl-ease)}
.tl-mega__grid a::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--tl-line);flex:none;transition:background .18s}
.tl-mega__grid a:hover{color:var(--tl-green);transform:translateX(3px)}
.tl-mega__grid a:hover::before{background:var(--tl-green)}
@media(max-width:991px){.tl-meganav{display:none}}

/* ============================================================
   TerraLED — Tunnel : panier + commande + compte
   Restyle CSS sur markup classic. JS natif (prestashop.checkout) intact.
   ============================================================ */

/* ---------- Titres de page tunnel ---------- */
.cart-grid .h1,.page-content .h1,.page-header h1,#main .page-header .h1,
.page-customer-account #main .page-header h1,.checkout .page-header h1{
  font-family:var(--tl-font-display);font-weight:600;color:var(--tl-forest);letter-spacing:-.01em;
}

/* ============================================================
   PANIER
   ============================================================ */
.cart-grid{margin-top:1rem}
.cart-grid-body .card,.cart-grid-right .card,.cart-container .card{
  border:1px solid var(--tl-line);border-radius:var(--tl-r-lg);box-shadow:var(--tl-shadow-sm);background:#fff;
}
.cart-grid-body .cart-overview{padding:.4rem .9rem}
.cart-item{border-bottom:1px solid var(--tl-line);padding:1.1rem 0}
.cart-item:last-child{border-bottom:0}
.product-line-grid-left img,.cart-item img{border:1px solid var(--tl-line);border-radius:var(--tl-r);background:#fff}
.product-line-info a.label,.cart__product-name,.product-line-grid-body .label{
  font-family:var(--tl-font-display);font-weight:600;color:var(--tl-forest);font-size:1.02rem;text-decoration:none;
}
.product-line-info a.label:hover{color:var(--tl-green)}
.product-line-info.value,.product-line-grid-body .product-line-info{font-family:var(--tl-font-mono);font-size:.8rem;color:var(--tl-muted)}
.product-price,.cart-line-product-actions .remove-from-cart,.product-line-grid .price{color:var(--tl-forest)}
.cart-line-product-actions .remove-from-cart{color:var(--tl-muted);transition:color var(--tl-dur)}
.cart-line-product-actions .remove-from-cart:hover{color:var(--tl-outstock)}
.product-line-grid-right .cart-line-product-actions{display:flex;align-items:center;gap:.6rem}

/* récap panier */
.cart-summary,.cart-detailed-totals,.cart-summary-products{font-family:var(--tl-font-body)}
.cart-summary-line{display:flex;justify-content:space-between;padding:.4rem 0;border-bottom:1px dashed var(--tl-line)}
.cart-summary-line .label{color:var(--tl-ink-2)}
.cart-summary-line .value,.cart-summary-line .price{font-family:var(--tl-font-mono);color:var(--tl-forest)}
.cart-summary-line.cart-total{border-bottom:0;margin-top:.4rem;padding-top:.7rem;border-top:2px solid var(--tl-forest)}
.cart-summary-line.cart-total .label,.cart-total .value{font-family:var(--tl-font-display);font-weight:600;font-size:1.2rem;color:var(--tl-forest)}
.cart-summary-line.cart-summary-subtotals-container .value{color:var(--tl-ink-2)}
.cart-summary-line .sub{color:var(--tl-muted)}

/* code promo */
.cart-voucher,.block-promo .promo-code{background:var(--tl-cream);border-radius:var(--tl-r);padding:1rem;border:1px solid var(--tl-line)}
.promo-code-button,.cart-voucher .promo-code-button{color:var(--tl-copper-text);font-family:var(--tl-font-mono);font-size:.8rem;text-transform:uppercase;letter-spacing:.04em}
.block-promo .promo-input,.cart-voucher input{border:1px solid var(--tl-line);border-radius:10px;background:#fff;padding:.6rem .8rem}
.block-promo .promo-input+button,.cart-voucher .btn{background:var(--tl-forest);color:var(--tl-cream);border:0;border-radius:10px;font-family:var(--tl-font-mono);text-transform:uppercase;letter-spacing:.04em;font-size:.78rem}
.promo-highlighted{font-family:var(--tl-font-mono);font-size:.82rem;color:var(--tl-copper-text)}
.cart-summary-line.cart-summary-tax,.cart-totals .free{color:var(--tl-instock)}

/* boutons panier */
.checkout.cart-detailed-actions .btn,.cart-detailed-actions .btn-primary,a.btn[href*="order"]{
  background:var(--tl-forest);color:var(--tl-cream);border:0;border-radius:99px;width:100%;
  font-family:var(--tl-font-mono);text-transform:uppercase;letter-spacing:.06em;font-weight:700;font-size:.9rem;
  padding:1rem 1.4rem;box-shadow:var(--tl-shadow);transition:transform var(--tl-dur) var(--tl-ease),background var(--tl-dur);
}
.checkout.cart-detailed-actions .btn:hover,.cart-detailed-actions .btn-primary:hover{transform:translateY(-2px);background:var(--tl-forest-2)}
.cart-detailed-actions{margin-top:.8rem}
.label .small,.cart .continue,.cart-grid-body .continue{
  font-family:var(--tl-font-mono);font-size:.78rem;letter-spacing:.03em;text-transform:uppercase;color:var(--tl-copper-text);
}
.cart-grid-body .continue:hover{color:var(--tl-green)}
.blockreassurance .block-title,.cart-grid-right .blockreassurance{font-size:.85rem}

/* ============================================================
   COMMANDE (checkout)
   ============================================================ */
.checkout-step{border:1px solid var(--tl-line);border-radius:var(--tl-r-lg);background:#fff;margin-bottom:1rem;box-shadow:var(--tl-shadow-sm);overflow:hidden}
.checkout-step .step-title,.checkout-step .step-title.h3{
  font-family:var(--tl-font-display);font-weight:600;color:var(--tl-forest);font-size:1.12rem;padding:1.1rem 1.3rem;margin:0;display:flex;align-items:center;gap:.7rem;
}
.checkout-step .step-number{
  display:inline-grid;place-items:center;width:30px;height:30px;border-radius:99px;background:var(--tl-cream-2);color:var(--tl-forest);
  font-family:var(--tl-font-mono);font-weight:700;font-size:.85rem;flex:none;
}
.checkout-step.-current{border-color:var(--tl-green);box-shadow:0 0 0 3px rgba(23,96,53,.1),var(--tl-shadow-sm)}
.checkout-step.-current .step-number{background:var(--tl-forest);color:var(--tl-cream)}
.checkout-step.-complete .step-title{color:var(--tl-instock)}
.checkout-step.-complete .step-number{background:var(--tl-instock);color:#fff}
.checkout-step .step-edit{font-family:var(--tl-font-mono);font-size:.74rem;text-transform:uppercase;letter-spacing:.04em;color:var(--tl-copper-text);margin-left:auto}
.checkout-step .content{padding:0 1.3rem 1.3rem}

/* options livraison / paiement */
.delivery-option,.payment-option{border:1px solid var(--tl-line);border-radius:var(--tl-r);padding:1rem 1.1rem;margin-bottom:.7rem;background:#fff;transition:border-color var(--tl-dur),box-shadow var(--tl-dur)}
.delivery-option:hover,.payment-option:hover{border-color:var(--tl-green)}
.delivery-option .custom-radio input:checked~span,.payment-option .custom-radio input:checked~span{background:var(--tl-green);border-color:var(--tl-green)}
.delivery-option.selected,.payment-option--selected{border-color:var(--tl-green);box-shadow:0 0 0 3px rgba(23,96,53,.1)}
.carrier-name,.carrier-price{font-family:var(--tl-font-body);color:var(--tl-ink)}
.carrier-price,.payment-option .price{font-family:var(--tl-font-mono);color:var(--tl-copper-text);font-weight:700}

/* formulaires checkout / compte */
.checkout .form-control,.page-customer-account .form-control,.js-address-form .form-control,#customer-form .form-control,#delivery-address .form-control,.checkout-step .form-control{
  border:1px solid var(--tl-line);border-radius:10px;background:#fff;color:var(--tl-ink);padding:.6rem .8rem;box-shadow:none;height:auto;
}
.checkout .form-control:focus,.page-customer-account .form-control:focus,.checkout-step .form-control:focus{border-color:var(--tl-green);box-shadow:0 0 0 3px rgba(23,96,53,.12)}
.form-control-label,.checkout label,.page-customer-account label{font-family:var(--tl-font-mono);font-size:.74rem;letter-spacing:.03em;text-transform:uppercase;color:var(--tl-copper-text);font-weight:700}
.checkout .continue,.checkout [type="submit"].continue,#payment-confirmation .btn,.checkout-step .btn-primary,.address-form-footer .btn-primary,#customer-form .btn-primary,#login-form .btn-primary,.register-form .btn-primary{
  background:var(--tl-forest);color:var(--tl-cream);border:0;border-radius:99px;
  font-family:var(--tl-font-mono);text-transform:uppercase;letter-spacing:.06em;font-weight:700;font-size:.86rem;
  padding:.9rem 1.5rem;box-shadow:var(--tl-shadow);transition:transform var(--tl-dur) var(--tl-ease),background var(--tl-dur);
}
.checkout .continue:hover,#payment-confirmation .btn:hover,.checkout-step .btn-primary:hover,#login-form .btn-primary:hover{transform:translateY(-2px);background:var(--tl-forest-2)}
#conditions-to-approve{background:var(--tl-cream);border:1px solid var(--tl-line);border-radius:var(--tl-r);padding:.9rem 1.1rem;margin:1rem 0}

/* récap commande */
#js-checkout-summary,.checkout-process .cart-summary{border:1px solid var(--tl-line);border-radius:var(--tl-r-lg);box-shadow:var(--tl-shadow-sm);background:#fff}
.cart-summary .h3,#cart-summary-product-list .h6{font-family:var(--tl-font-display);color:var(--tl-forest);font-weight:600}
.order-confirmation-table,.order-line{border-color:var(--tl-line)}

/* ============================================================
   COMPTE / CONNEXION
   ============================================================ */
.page-authentication #content,.page-customer-account #content,.login-form,.register-form{
  border:1px solid var(--tl-line);border-radius:var(--tl-r-xl);background:#fff;box-shadow:var(--tl-shadow-sm);padding:1.6rem 1.8rem;
}
.page-authentication .h1,.page-customer-account .page-header h1{font-family:var(--tl-font-display);color:var(--tl-forest);font-weight:600}
.no-account,.forgot-password a,.lost_password a{font-family:var(--tl-font-mono);font-size:.8rem;letter-spacing:.03em;color:var(--tl-copper-text)}
.no-account:hover,.forgot-password a:hover{color:var(--tl-green)}

/* tableau de bord compte : tuiles */
.page-my-account #content .links a,.links .link-item{
  display:flex;flex-direction:column;align-items:center;gap:.6rem;text-align:center;
  border:1px solid var(--tl-line);border-radius:var(--tl-r-lg);background:#fff;padding:1.6rem 1rem;
  color:var(--tl-forest);text-decoration:none;transition:transform var(--tl-dur) var(--tl-ease),box-shadow var(--tl-dur),border-color var(--tl-dur);
  font-family:var(--tl-font-display);font-weight:600;
}
.page-my-account #content .links a:hover,.links .link-item:hover{transform:translateY(-4px);box-shadow:var(--tl-shadow);border-color:var(--tl-green)}
.page-my-account #content .links a i,.links .link-item i{color:var(--tl-copper);font-size:2rem}
.page-my-account #content .links a span.link-item{border:0;padding:0}

/* historique / adresses */
.page-customer-account .address,.addresses-footer a,#addresses article{border:1px solid var(--tl-line);border-radius:var(--tl-r-lg);background:#fff}
#history .orders .order,.table.table-labeled th{font-family:var(--tl-font-body)}
#history .orders .order .label,.order-status .label{border-radius:99px;font-family:var(--tl-font-mono);font-size:.72rem;letter-spacing:.03em}

/* fix bandeau svg inline */
.tl-announce svg,#ship svg{display:inline-block!important;vertical-align:-2px;margin-right:4px}
.tl-announce{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* ===== TerraLED — Tiroir mobile ===== */
.tl-overlay--nav{position:fixed;inset:0;z-index:1100;display:block}
.tl-overlay--nav[hidden]{display:none}
.tl-overlay--nav .tl-overlay__bd{position:absolute;inset:0;background:rgba(4,18,10,.5);backdrop-filter:blur(2px)}
.tl-offcanvas--left{left:0;right:auto;width:min(360px,88vw);background:#fff;color:var(--tl-ink);box-shadow:0 0 60px rgba(4,18,10,.4);animation:tlslidein .28s var(--tl-ease)}
@keyframes tlslidein{from{transform:translateX(-100%)}to{transform:translateX(0)}}
.tl-offcanvas__head{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;border-bottom:1px solid var(--tl-line)}
.tl-offcanvas__title{font-family:var(--tl-font-mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--tl-copper-text);font-weight:700}
.tl-offcanvas__close{background:none;border:0;font-size:26px;line-height:1;color:var(--tl-muted);cursor:pointer;padding:2px 6px}
.tl-offcanvas__close:hover{color:var(--tl-forest)}
.tl-mobnav{padding:6px 0;overflow:auto}
.tl-mobnav__cat{border-bottom:1px solid var(--tl-line)}
.tl-mobnav__cat>summary{list-style:none;display:flex;align-items:center;justify-content:space-between;padding:14px 18px;font-family:var(--tl-font-display);font-weight:600;font-size:16px;color:var(--tl-forest);cursor:pointer}
.tl-mobnav__cat>summary::-webkit-details-marker{display:none}
.tl-mobnav__cat>summary svg{width:18px;height:18px;color:var(--tl-copper);transition:transform .2s var(--tl-ease)}
.tl-mobnav__cat[open]>summary svg{transform:rotate(180deg)}
.tl-mobnav__cat[open]>summary{color:var(--tl-green)}
.tl-mobnav ul{list-style:none;margin:0;padding:0 0 10px;background:var(--tl-cream)}
.tl-mobnav ul li a{display:block;padding:10px 18px 10px 30px;color:var(--tl-ink-2);text-decoration:none;font-size:14.5px}
.tl-mobnav ul li a:hover{color:var(--tl-green)}
.tl-mobnav__all a{font-family:var(--tl-font-mono);font-size:12px;letter-spacing:.03em;text-transform:uppercase;color:var(--tl-copper-text)!important;font-weight:700}
.tl-mobnav__foot{display:flex;gap:10px;padding:16px 18px}
.tl-mobnav__foot a{flex:1;text-align:center;border:1px solid var(--tl-line);border-radius:99px;padding:12px;font-family:var(--tl-font-mono);font-size:12px;letter-spacing:.04em;text-transform:uppercase;font-weight:700;color:var(--tl-forest);text-decoration:none}
.tl-mobnav__foot a:last-child{background:var(--tl-forest);color:var(--tl-cream);border-color:var(--tl-forest)}
.tl-burger{display:none}
@media(max-width:991px){.tl-burger{display:inline-flex!important;align-items:center;justify-content:center}}

/* ===== TerraLED — Correctifs responsive ===== */
/* méga menu : tient dans le conteneur lg (992-1199) au lieu de déborder */
@media(min-width:992px) and (max-width:1199px){
  .tl-meganav .tl-menu{gap:14px}
  .tl-meganav .tl-menu>.mi>a{font-size:12.5px;letter-spacing:-.012em}
}
/* bandeau : ne jamais provoquer de scroll horizontal sur mobile */
@media(max-width:1199px){
  .tl-announce__dist{display:none}
  .tl-announce .sep{display:none}
}
@media(max-width:560px){
  .tl-announce{white-space:normal;line-height:1.45;padding:7px 12px;font-size:11px}
  .tl-announce .cut{display:block}
  .tl-announce__ship{display:block}
}
/* fiche produit : actions (qty + ajout + wishlist) ne débordent pas en tablette */
@media(max-width:991px){
  .product-actions,.product-add-to-cart{flex-wrap:wrap}
  .product-quantity{margin-bottom:.5rem}
  #product .btn.add-to-cart{flex:1 1 auto;min-width:0}
}
/* filet de sécurité anti-débordement horizontal global */
html{overflow-x:clip}

/* ===== TerraLED — Correctifs responsive 2 ===== */
/* hero mobile : empêcher le blowout grid (label nowrap) */
@media(max-width:991px){
  .tl-home .hero .wrap{grid-template-columns:minmax(0,1fr) !important}
  .tl-home .hero .wrap>*{min-width:0;max-width:100%}
  .tl-home .hero .tag,.tl-home .hero .idx,.tl-home .hero .spec{white-space:normal}
  .tl-home .hero-stats{flex-wrap:wrap;gap:12px}
  .tl-home .hero-stats>div{border-right:0;margin-right:0;padding-right:0}
  .tl-home .hero-frame img,.tl-home .hero-media img{max-width:100%}
}
/* fiche produit : le vrai conteneur des actions est .product-quantity */
@media(max-width:991px){
  .product-quantity{flex-wrap:wrap;gap:.5rem}
  .product-quantity .qty,.product-quantity .add{margin-bottom:.4rem}
}
/* en-tête mobile : supprimer le burger classic en double (le notre suffit) */
#menu-icon{display:none}

/* ===== TerraLED — Correctifs responsive 3 : anti-blowout global sections home ===== */
@media(max-width:991px){
  .tl-home .wrap > *{min-width:0}
  .tl-home .wrap *{min-width:0}
  .tl-home .wrap img{max-width:100%;height:auto}
}

/* ===== TerraLED — Correctifs responsive 4 : spot img + halos ===== */
@media(max-width:991px){
  .tl-home .spot-media img.prod{max-width:100%}
  .tl-home .spot-media .halo,.tl-home .hero .halo,.tl-home .hero .beam{max-width:100%;left:0;right:0}
}

/* ===== TerraLED — méga menu enrichi (carte produit + marques) ===== */
.tl-mega__in--3{grid-template-columns:1.5fr 1fr 1.25fr}
.tl-mega__brands{display:grid;grid-template-columns:1fr 1fr;gap:10px;align-content:start}
.tl-mega__brands a{display:grid;place-items:center;background:#fff;border:1px solid var(--tl-line);border-radius:10px;padding:8px;min-height:48px;transition:transform .18s var(--tl-ease),box-shadow .18s}
.tl-mega__brands a:hover{transform:translateY(-2px);box-shadow:var(--tl-shadow-sm)}
.tl-mega__brands img{max-width:100%;max-height:32px;width:auto;object-fit:contain;filter:grayscale(1);opacity:.72;transition:filter .2s,opacity .2s}
.tl-mega__brands a:hover img{filter:none;opacity:1}
.tl-mega__feat{justify-content:flex-start;padding-right:132px}
.tl-mega__feat h4{font-size:17px;line-height:1.2;margin:6px 0 2px;max-width:none}
.tl-mega__feat .price-tag{font-family:var(--tl-font-display);font-weight:600;font-size:21px;color:var(--tl-gold);margin:2px 0 12px;display:block}
.tl-mega__feat .lnk{margin-top:auto}
.tl-mega__feat img{position:absolute;right:16px;bottom:16px;top:auto;width:108px;height:108px;object-fit:cover;border-radius:12px;background:#fff;box-shadow:0 12px 26px rgba(0,0,0,.4);filter:none}
@media(min-width:992px) and (max-width:1199px){.tl-mega__feat{padding-right:118px}.tl-mega__feat img{width:96px;height:96px}}

/* ===== TerraLED — Pied catalogue (sitemap SEO) ===== */
.tl-footer__catalog{border-top:1px solid rgba(255,255,255,.1);padding:36px 0}
.tl-sitemap__head{margin-bottom:22px}
.tl-sitemap__head h2{font-family:var(--tl-font-display);color:#fff;font-size:clamp(1.3rem,2.4vw,1.6rem);font-weight:600;margin:0}
.tl-sitemap__head p{font-family:var(--tl-font-mono);font-size:11px;letter-spacing:.04em;color:#9bb3a4;text-transform:uppercase;margin:.35rem 0 0}
.tl-sitemap__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px 30px}
.tl-sitemap__col h3{margin:0 0 11px}
.tl-sitemap__col h3 a{font-family:var(--tl-font-display);font-weight:600;font-size:15px;color:var(--tl-gold);text-decoration:none}
.tl-sitemap__col h3 a:hover{text-decoration:underline}
.tl-sitemap__col ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:9px}
.tl-sitemap__l1{font-family:var(--tl-font-body);font-weight:700;font-size:13.5px;color:#dbe7df;text-decoration:none}
.tl-sitemap__l1:hover{color:#fff}
.tl-sitemap__sub{display:block;margin:3px 0 1px;line-height:1.7}
.tl-sitemap__sub a{font-size:12px;color:#8fa89a;text-decoration:none;margin-right:12px;display:inline-block}
.tl-sitemap__sub a:hover{color:var(--tl-gold)}
.tl-sitemap__brands{margin-top:26px;padding-top:18px;border-top:1px solid rgba(255,255,255,.1);font-family:var(--tl-font-mono);font-size:12px;letter-spacing:.03em;display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.tl-sitemap__brands span{color:#9bb3a4;text-transform:uppercase}
.tl-sitemap__brands a{color:#dbe7df;text-decoration:none}
.tl-sitemap__brands a:hover{color:var(--tl-gold)}
@media(max-width:991px){.tl-sitemap__grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.tl-sitemap__grid{grid-template-columns:1fr}}

/* ===== TerraLED — Sélecteur de langue ===== */
.tl-lang{position:relative}
.tl-lang__btn{display:inline-flex;align-items:center;gap:5px}
.tl-lang__cur{font-family:var(--tl-font-mono);font-weight:700;font-size:12px;letter-spacing:.04em}
.tl-lang__btn svg{width:18px;height:18px}
.tl-lang__chev{width:13px!important;height:13px!important;transition:transform .2s var(--tl-ease)}
.tl-lang__menu{position:absolute;top:calc(100% + 6px);right:0;min-width:160px;background:#fff;border:1px solid var(--tl-line);border-radius:12px;box-shadow:var(--tl-shadow);padding:6px;list-style:none;margin:0;opacity:0;visibility:hidden;transform:translateY(6px);transition:opacity .18s var(--tl-ease),transform .18s var(--tl-ease),visibility .18s;z-index:120}
.tl-lang:hover .tl-lang__menu,.tl-lang:focus-within .tl-lang__menu{opacity:1;visibility:visible;transform:translateY(0)}
.tl-lang:focus-within .tl-lang__chev,.tl-lang:hover .tl-lang__chev{transform:rotate(180deg)}
.tl-lang__menu li a{display:flex;align-items:center;gap:8px;padding:8px 12px;border-radius:8px;color:var(--tl-ink-2);text-decoration:none;font-size:14px;font-weight:600;white-space:nowrap}
.tl-lang__menu li a:hover{background:var(--tl-cream);color:var(--tl-green)}
.tl-lang__menu li.is-current a{color:var(--tl-green)}
.tl-lang__menu li.is-current a::after{content:"✓";margin-left:auto;color:var(--tl-copper);font-weight:700}

/* ===== TerraLED — langue (sortie module ps_languageselector) ===== */
.tl-lang .language-selector{position:relative}
.tl-lang .language-selector>span{display:inline-flex;align-items:center;gap:7px;cursor:pointer;font-family:var(--tl-font-mono);font-weight:700;font-size:12px;letter-spacing:.03em;text-transform:uppercase;color:var(--tl-forest);padding:9px 12px;border-radius:12px;border:1px solid transparent;transition:background var(--tl-dur),border-color var(--tl-dur),color var(--tl-dur);white-space:nowrap}
.tl-lang .language-selector>span::before{content:"";width:18px;height:18px;flex:none;background:no-repeat center/contain;background-image:url("data:image/svg+xml,%3Csvg xmlns=%27http://www.w3.org/2000/svg%27 viewBox=%270 0 24 24%27 fill=%27none%27 stroke=%27%230a1f13%27 stroke-width=%271.7%27%3E%3Ccircle cx=%2712%27 cy=%2712%27 r=%279%27/%3E%3Cpath d=%27M3 12h18M12 3c2.6 2.7 4 6 4 9s-1.4 6.3-4 9c-2.6-2.7-4-6-4-9s1.4-6.3 4-9Z%27/%3E%3C/svg%3E")}
.tl-lang .language-selector>span::after{content:"";width:9px;height:9px;flex:none;border-right:2px solid currentColor;border-bottom:2px solid currentColor;transform:rotate(45deg) translateY(-2px);transition:transform .2s var(--tl-ease)}
.tl-lang .language-selector:hover>span,.tl-lang.is-open .language-selector>span{background:var(--tl-cream);border-color:var(--tl-line);color:var(--tl-green)}
.tl-lang.is-open .language-selector>span::after,.tl-lang .language-selector:hover>span::after{transform:rotate(225deg) translateY(2px)}
.tl-lang .language-selector ul{position:absolute;top:calc(100% + 6px);right:0;min-width:170px;background:#fff;border:1px solid var(--tl-line);border-radius:12px;box-shadow:var(--tl-shadow);padding:6px;list-style:none;margin:0;opacity:0;visibility:hidden;transform:translateY(6px);transition:opacity .18s var(--tl-ease),transform .18s var(--tl-ease),visibility .18s;z-index:120}
.tl-lang .language-selector:hover ul,.tl-lang .language-selector:focus-within ul,.tl-lang.is-open .language-selector ul{opacity:1;visibility:visible;transform:translateY(0)}
.tl-lang .language-selector li{margin:0}
.tl-lang .language-selector li a{display:flex;align-items:center;padding:8px 12px;border-radius:8px;color:var(--tl-ink-2);text-decoration:none;font-size:14px;font-weight:600;white-space:nowrap}
.tl-lang .language-selector li a:hover{background:var(--tl-cream);color:var(--tl-green)}
.tl-lang .language-selector li.current a{color:var(--tl-green)}
.tl-lang .language-selector li.current a::after{content:"✓";margin-left:auto;padding-left:12px;color:var(--tl-copper);font-weight:700}

/* ===== TerraLED — Home pleine largeur (fonds full width) ===== */
body#index #wrapper > .container{max-width:none;width:100%;padding-left:0;padding-right:0}
body#index #wrapper > .container > .row{margin-left:0;margin-right:0}
body#index #content-wrapper{padding-left:0;padding-right:0;max-width:100%;flex:0 0 100%}
body#index #main,body#index #content.page-home,body#index .tl-home{width:100%;max-width:none;padding-left:0;padding-right:0}
body#index #wrapper{padding-left:0;padding-right:0;overflow-x:clip}

/* ============================================================
   TerraLED — Pied de page (refonte complète)
   ============================================================ */
.tl-footer{background:var(--tl-forest);color:#bcd0c2;font-family:var(--tl-font-body);font-size:14px}
.tl-footer .tl-container{max-width:1240px;margin:0 auto;padding-left:24px;padding-right:24px}
.tl-footer a{color:#dbe7df;text-decoration:none;transition:color .18s var(--tl-ease)}
.tl-footer a:hover{color:var(--tl-gold)}
.tl-footer h3,.tl-footer h4{font-family:var(--tl-font-display);color:#fff;font-weight:600;margin:0}
.tl-footer ul{list-style:none;margin:0;padding:0}
.tl-footer__kicker{font-family:var(--tl-font-mono);font-size:11px;letter-spacing:.13em;text-transform:uppercase;color:var(--tl-gold);display:inline-block;margin-bottom:14px}

/* — Bandeau marque + newsletter — */
.tl-footer__top{border-bottom:1px solid rgba(255,255,255,.1);padding:46px 0}
.tl-footer__top::before{content:"";display:block;height:3px;background:linear-gradient(90deg,#2563ff,#7b3ff2,#d61f9b,#ff5a3c,#ffb02e);position:absolute;left:0;right:0;top:0}
.tl-footer{position:relative}
.tl-footer__top-in{display:grid;grid-template-columns:1.1fr 1fr;gap:48px;align-items:center}
.tl-footer__logo{font-family:var(--tl-font-display);font-weight:600;font-size:26px;color:#fff;display:inline-block;margin-bottom:12px}
.tl-footer__logo b{color:var(--tl-gold)}
.tl-footer__pitch{color:#9fb8a8;line-height:1.6;max-width:46ch;margin:0 0 16px}
.tl-footer__news-title{font-size:21px;margin:0 0 14px;color:#fff}
.tl-footer__social ul,.tl-footer .social-follow ul{display:flex;gap:10px;flex-wrap:wrap}
.tl-footer__social li a,.tl-footer .social-follow li a{display:grid;place-items:center;width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);background-size:18px;background-position:center;background-repeat:no-repeat}
.tl-footer__social li a:hover,.tl-footer .social-follow li a:hover{background-color:rgba(244,189,94,.18);border-color:var(--tl-gold)}

/* newsletter form (ps_emailsubscription) */
.tl-footer__news .block_newsletter form,.tl-footer__news .ps-emailsubscription form,.tl-footer__news form{display:flex;gap:10px;flex-wrap:wrap;max-width:480px}
.tl-footer__news input[type=text],.tl-footer__news input[type=email]{flex:1;min-width:200px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.16);border-radius:10px;padding:13px 16px;color:#fff;font-family:var(--tl-font-mono);font-size:13px}
.tl-footer__news input::placeholder{color:#8aa899}
.tl-footer__news input[type=text]:focus,.tl-footer__news input[type=email]:focus{outline:none;border-color:var(--tl-gold)}
.tl-footer__news button,.tl-footer__news input[type=submit],.tl-footer__news [data-link-action]{background:var(--tl-gold);color:#3a2600;border:0;border-radius:10px;padding:13px 20px;font-family:var(--tl-font-mono);font-weight:700;text-transform:uppercase;letter-spacing:.04em;font-size:12px;cursor:pointer;white-space:nowrap}
.tl-footer__news button:hover{filter:brightness(1.05)}
.tl-footer__news .alert,.tl-footer__news p{font-size:12px;color:#9fb8a8;flex-basis:100%;margin:8px 0 0}

/* — Catalogue condensé — */
.tl-footer__cat{padding:40px 0;border-bottom:1px solid rgba(255,255,255,.1)}
.tl-footer__cat-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:26px 30px}
.tl-fcol h4{font-size:15px;margin:0 0 12px}
.tl-fcol h4 a{color:var(--tl-gold)}
.tl-fcol h4.tl-fcol__h2{margin-top:22px}
.tl-fcol ul{display:flex;flex-direction:column;gap:9px}
.tl-fcol ul li a{font-size:13.5px;color:#bcd0c2}
.tl-fcol ul li a:hover{color:#fff}

/* — Services — */
.tl-footer__services{padding:38px 0;border-bottom:1px solid rgba(255,255,255,.1)}
.tl-footer__services-grid{display:grid;grid-template-columns:1fr 1fr 1.2fr;gap:30px}
.tl-fserv h4{font-size:15px;margin:0 0 14px}
.tl-fserv ul{display:flex;flex-direction:column;gap:9px}
.tl-fserv ul li a{font-size:13.5px}
.tl-fserv .h3,.tl-fserv .title,.tl-fserv .blockcms h3,.tl-fserv h3{display:none}   /* on garde nos propres h4 */
.tl-fserv--contact li,.tl-fserv--contact .block-contact li{display:flex;gap:9px;align-items:flex-start;margin-bottom:11px;color:#bcd0c2;line-height:1.45}
.tl-fserv--contact a{color:var(--tl-gold)}

/* — Réassurance — */
.tl-footer__reassurance{padding:28px 0;border-bottom:1px solid rgba(255,255,255,.1)}
.tl-footer__reassurance ul,.tl-footer__reassurance .block-reassurance,.tl-footer__reassurance .blockreassurance{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin:0}
.tl-footer__reassurance li{display:flex;gap:12px;align-items:center;border:0;padding:0;list-style:none}
.tl-footer__reassurance .block-title,.tl-footer__reassurance .item-product b,.tl-footer__reassurance li p:first-child,.tl-footer__reassurance li .h6{color:#fff;font-family:var(--tl-font-display);font-weight:600;font-size:14px;margin:0}
.tl-footer__reassurance p,.tl-footer__reassurance li span{color:#9fb8a8;font-size:12.5px;margin:0}
.tl-footer__reassurance img,.tl-footer__reassurance svg{width:30px;height:30px;flex:none}

/* — Barre basse — */
.tl-footer__bottom{padding:18px 0;background:rgba(0,0,0,.18)}
.tl-footer__bottom-in{display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap}
.tl-footer__sign{font-family:var(--tl-font-mono);font-size:11px;letter-spacing:.05em;text-transform:uppercase;color:#8aa899}
.tl-footer__copy{font-size:12px;color:#9fb8a8}
.tl-pays{display:flex;gap:7px;flex-wrap:wrap}
.tl-pay{font-family:var(--tl-font-mono);font-size:10px;font-weight:700;letter-spacing:.03em;background:rgba(255,255,255,.92);color:#1a2b20;border-radius:5px;padding:4px 8px}

/* responsive */
@media(max-width:991px){
  .tl-footer__top-in{grid-template-columns:1fr;gap:30px}
  .tl-footer__cat-grid{grid-template-columns:repeat(2,1fr)}
  .tl-footer__services-grid{grid-template-columns:1fr 1fr}
  .tl-footer__reassurance ul,.tl-footer__reassurance .block-reassurance,.tl-footer__reassurance .blockreassurance{grid-template-columns:1fr 1fr}
}
@media(max-width:560px){
  .tl-footer__cat-grid,.tl-footer__services-grid,.tl-footer__reassurance ul,.tl-footer__reassurance .block-reassurance,.tl-footer__reassurance .blockreassurance{grid-template-columns:1fr}
  .tl-footer__bottom-in{flex-direction:column;text-align:center;gap:10px}
}

/* footer contact + material fix */
.tl-footer .material-icons{display:none !important}
.tl-fcontact{display:flex;flex-direction:column;gap:13px;margin:0 0 16px}
.tl-fcontact li{display:flex;gap:11px;align-items:flex-start;color:#bcd0c2;line-height:1.45;font-size:13.5px;list-style:none}
.tl-fcontact li svg{width:19px;height:19px;flex:none;color:var(--tl-gold);margin-top:2px}
.tl-fcontact a{color:#dbe7df}
.tl-fcontact a:hover{color:var(--tl-gold)}
.tl-fcontact__cta{display:inline-flex;font-family:var(--tl-font-mono);font-size:12px;text-transform:uppercase;letter-spacing:.05em;font-weight:700;color:var(--tl-gold)}
.tl-fserv--account ul li{margin-bottom:9px}

/* newsletter footer transparent (corrige boîte blanche + titre double) */
.tl-footer__news > div{background:transparent !important;padding:0 !important;margin:0 !important;box-shadow:none !important;border:0 !important;border-radius:0 !important}
.tl-footer__news > div h1,.tl-footer__news > div h2,.tl-footer__news > div h3,.tl-footer__news > div .h3,.tl-footer__news > div .title,.tl-footer__news > div .block-title{display:none !important}
.tl-footer__news > div p{color:#9fb8a8;background:transparent}
.tl-footer__news .block_newsletter,.tl-footer__news .ps-emailsubscription,.tl-footer__news .newsletter{background:transparent !important}

/* newsletter label fix */
.tl-footer__news #block-newsletter-label{display:none !important}
.tl-footer__news .block_newsletter,.tl-footer__news .block_newsletter [class*="col-"]{flex:0 0 100% !important;max-width:100% !important;padding:0 !important}
.tl-footer__news .block_newsletter .row{margin:0 !important}
.tl-footer__news .input-wrapper{flex:1;min-width:0}

/* newsletter input large */
.tl-footer__news .block_newsletter .col-xs-12{display:flex;gap:10px;align-items:center;flex-wrap:nowrap}
.tl-footer__news .input-wrapper{flex:1 1 auto;min-width:0;display:block}
.tl-footer__news .input-wrapper input{width:100%}
.tl-footer__news .btn[name=submitNewsletter]{flex:none;float:none !important;margin:0}

/* newsletter order : champ puis bouton */
.tl-footer__news .input-wrapper{order:1}
.tl-footer__news .col-xs-12 .btn[name=submitNewsletter]{order:2}

/* réassurance maison (footer) */
.tl-reassure{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin:0;padding:0;list-style:none}
.tl-reassure li{display:flex;gap:13px;align-items:center}
.tl-reassure li svg{width:30px;height:30px;flex:none;color:var(--tl-gold)}
.tl-reassure b{display:block;color:#fff;font-family:var(--tl-font-display);font-weight:600;font-size:14.5px;line-height:1.2}
.tl-reassure span{display:block;color:#9fb8a8;font-size:12.5px;line-height:1.35;margin-top:3px}
@media(max-width:991px){.tl-reassure{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.tl-reassure{grid-template-columns:1fr}}

/* footer top-in pleine largeur + home: pas de marge menu/hero */
.tl-footer__top-in{width:100%}
body#index #wrapper{padding-top:0 !important}

/* neutralise ancienne grille footer__top (règle obsolète l.3266) */
.tl-footer__top{display:block !important;max-width:none !important;grid-template-columns:none !important;margin:0;padding:46px 0}
