/* ============================================================
   VITRINES-RÉFRIGÉRÉES.FR — FEUILLE DE STYLE PRODUCTION
   Direction « Instrument » (01) · froid lu comme une mesure.
   ------------------------------------------------------------
   • Remplace intégralement src/styles.css (CSS vanilla, zéro dépendance).
   • Couvre TOUS les types de pages : accueil, page métier, catalogue
     (hub / catégorie / fiche produit), zones (hub / ville), formulaire.
   • Inclut le méga-menu (desktop survol/focus + mobile accordéon),
     fil d'Ariane, grilles catalogue, fiche technique « instrument »,
     pagination, blocs zones. Requiert nav.js pour le menu tactile.
   • Mobile-first, accessible AA (focus visibles, cibles ≥ 44px).
   • Polices : IBM Plex Sans + IBM Plex Mono (voir INTEGRATION.md ;
     auto-hébergement recommandé). Repli system-ui si non chargées.
   ============================================================ */
:root{
  --ink:      oklch(24% 0.012 250);
  --ink-soft: oklch(38% 0.012 250);
  --muted:    oklch(52% 0.012 250);
  --paper:    oklch(97.5% 0.004 240);
  --panel:    oklch(99% 0.003 240);
  --steel:    oklch(94% 0.006 240);
  --steel-2:  oklch(90% 0.008 240);
  --line:     oklch(86% 0.01 240);
  --line-2:   oklch(79% 0.012 240);
  --accent:   oklch(58% 0.13 225);
  --accent-d: oklch(46% 0.12 230);
  --accent-ghost: oklch(95% 0.03 225);
  --ok:   oklch(58% 0.1 168);
  --ok-bg:oklch(93% 0.05 168);
  --mid:  oklch(60% 0.1 225);
  --mid-bg:oklch(92% 0.05 225);
  --hot:  oklch(40% 0.12 250);
  --hot-fg:oklch(97% 0.01 240);
  --mono: "IBM Plex Mono", ui-monospace, monospace;
  --sans: "IBM Plex Sans", ui-sans-serif, system-ui, sans-serif;
  --maxw: 1200px;
  --r: 4px;
}
*{ box-sizing:border-box; }
html{ color:var(--ink); background:var(--paper); font-family:var(--sans); -webkit-text-size-adjust:100%; }
body{ margin:0; line-height:1.62; font-size:17px; overflow-x:hidden; }
@media (max-width:560px){ body{ font-size:16px; } }
a{ color:inherit; }
p{ max-width:68ch; }
img,svg{ max-width:100%; }
::selection{ background:var(--accent); color:#fff; }
:focus-visible{ outline:2px solid var(--accent); outline-offset:2px; border-radius:2px; }

/* layout rails */
.hero,.trust,.metiers,.section,.final-cta,.steps-wrap{ max-width:var(--maxw); margin-inline:auto; }
.section{ padding:clamp(34px,5vw,60px) clamp(18px,4vw,40px); }
.section.narrow{ max-width:760px; }

/* ---------- header ---------- */
.site-header{ position:sticky; top:0; z-index:30; display:grid; grid-template-columns:auto 1fr auto; gap:24px; align-items:center;
  padding:0 clamp(16px,4vw,40px); min-height:64px; background:oklch(98% 0.004 240 / .82); backdrop-filter:blur(14px) saturate(1.1);
  border-bottom:1px solid var(--line); }
.brand{ display:inline-flex; align-items:center; gap:10px; font-weight:700; font-size:1.02rem; letter-spacing:-0.01em; text-decoration:none; white-space:nowrap; }
.brand-mark{ width:18px; height:18px; border:2px solid var(--accent); border-radius:50%; position:relative; background:
   linear-gradient(var(--accent),var(--accent)) center/2px 10px no-repeat,
   linear-gradient(var(--accent),var(--accent)) center/10px 2px no-repeat; box-shadow:inset 0 0 0 4px var(--paper); }
.brand-tld{ color:var(--accent-d); }
.nav{ display:flex; justify-content:center; align-items:center; gap:4px; font-size:.92rem; color:var(--muted); }
.nav > a, .nav .nav-top{ display:inline-flex; align-items:center; gap:5px; text-decoration:none; padding:8px 12px; border-radius:var(--r); white-space:nowrap; color:var(--muted); transition:color .15s,background .15s; }
.nav > a:hover,.nav > a:focus-visible,.nav .nav-top:hover,.nav .nav-top:focus-visible{ color:var(--ink); background:var(--steel); }
.nav a[aria-current="page"]{ color:var(--accent-d); }
.nav-top::after{ content:"▾"; font-size:.66em; color:var(--muted); }
.submenu-toggle,.nav-toggle{ display:none; }
.nav .nav-cta-mobile{ display:none; }
.header-cta{ display:flex; align-items:center; gap:14px; }
.link-call{ font-family:var(--mono); font-size:.86rem; color:var(--ink-soft); text-decoration:none; white-space:nowrap; }
.link-call:hover{ color:var(--accent-d); }

/* ---------- buttons ---------- */
.button{ display:inline-flex; align-items:center; justify-content:center; gap:8px; min-height:48px; padding:0 22px;
  border:1px solid var(--accent-d); border-radius:var(--r); background:var(--accent); color:#fff; font-weight:600; font-size:.96rem;
  letter-spacing:.01em; text-decoration:none; cursor:pointer; transition:transform .12s ease, box-shadow .15s ease, background .15s;
  box-shadow:0 1px 0 oklch(40% 0.1 230 / .4); }
.button::after{ content:"→"; font-family:var(--mono); transform:translateX(0); transition:transform .15s ease; }
.button:hover,.button:focus-visible{ background:var(--accent-d); box-shadow:0 6px 18px oklch(50% 0.12 230 / .28); }
.button:hover::after{ transform:translateX(3px); }
.button.secondary{ background:transparent; color:var(--ink); border-color:var(--line-2); box-shadow:none; }
.button.secondary::after{ content:""; }
.button.secondary:hover{ background:var(--steel); border-color:var(--ink-soft); }
.button.wide{ width:100%; }

/* ---------- hero ---------- */
main{ overflow:clip; }
.hero{ width:100%; display:grid; grid-template-columns:minmax(0,1.02fr) minmax(384px,.96fr); gap:clamp(28px,4.5vw,56px); align-items:start;
  padding:clamp(32px,4.5vw,60px) clamp(18px,4vw,40px) clamp(26px,4vw,44px); position:relative; }
.hero > *{ min-width:0; }
.hero-text{ align-self:center; }
.eyebrow{ display:inline-flex; align-items:center; gap:8px; width:fit-content; margin:0 0 20px; padding:6px 12px;
  font-family:var(--mono); font-size:.72rem; font-weight:500; letter-spacing:.12em; text-transform:uppercase; color:var(--accent-d);
  background:var(--accent-ghost); border:1px solid oklch(82% 0.05 225); border-radius:2px; }
.eyebrow::before{ content:"●"; font-size:.6em; color:var(--accent); }
h1{ margin:0; max-width:16ch; font-size:clamp(2.1rem,4.6vw,3.5rem); line-height:1.05; letter-spacing:-0.025em; font-weight:600; }
.hero-copy{ margin:22px 0 0; max-width:54ch; color:var(--ink-soft); font-size:clamp(1.04rem,1.3vw,1.16rem); }
.hero-bullets{ list-style:none; margin:24px 0 0; padding:0; display:grid; gap:10px; }
.hero-bullets li{ position:relative; padding-left:26px; color:var(--ink-soft); font-size:.97rem; }
.hero-bullets li::before{ content:"✓"; position:absolute; left:0; top:0; color:var(--accent); font-weight:700; }
.hero-actions{ display:flex; flex-wrap:wrap; align-items:center; gap:16px; margin-top:28px; }

/* compact temperature legend in hero (signature cue above the fold) */
.temp-legend{ list-style:none; margin:26px 0 0; padding:0; display:flex; flex-wrap:wrap; gap:9px; }
.temp-legend li{ display:inline-flex; align-items:center; gap:8px; padding:7px 12px; border:1px solid var(--line); border-radius:999px; background:var(--panel); font-size:.85rem; color:var(--ink-soft); white-space:nowrap; }
.temp-legend li b{ font-family:var(--mono); font-weight:600; font-size:.8rem; color:var(--ink); }
.temp-legend .lg{ width:9px; height:9px; border-radius:2px; }
.temp-legend .lg.ok{ background:var(--ok); }
.temp-legend .lg.mid{ background:var(--mid); }
.temp-legend .lg.hot{ background:var(--hot); }
.hero-jump{ display:inline-flex; align-items:center; min-height:48px; font-family:var(--mono); font-size:.82rem; color:var(--accent-d); text-decoration:none; }
.hero-jump:hover{ text-decoration:underline; }

/* hero quote form (above the fold) */
.hero-form{ align-self:start; background:linear-gradient(180deg, var(--panel), var(--steel)); border:1px solid var(--line-2); border-radius:8px; overflow:hidden;
  box-shadow:0 1px 0 #fff inset, 0 24px 52px oklch(40% 0.04 240 / .16); scroll-margin-top:80px; min-width:0; width:100%; max-width:100%; }
.hf-head{ padding:15px 20px 14px; border-bottom:1px solid var(--line); background:oklch(96.5% 0.005 240); }
.hf-head .eyebrow{ margin:0 0 9px; }
.hf-head strong{ display:block; font-size:1.1rem; letter-spacing:-0.015em; }
.hf-head span{ display:block; margin-top:3px; font-family:var(--mono); font-size:.74rem; color:var(--muted); }
.hero-form .form{ padding:17px 20px 20px; gap:11px; }
.hero-form .form label{ font-size:.78rem; }
.hero-form .form input, .hero-form .form select, .hero-form .form textarea{ min-height:44px; padding:9px 12px; }
.hero-form .form select{ background-position:calc(100% - 18px) 19px,calc(100% - 13px) 19px; }
.hero-form .form textarea{ min-height:64px; }
.hero-form .form .button.wide{ min-height:50px; margin-top:2px; }
.hero-form .form .consent{ font-size:.8rem; }

/* temperature signature band (full instrument panel, just under hero) */
.section.temp-band{ padding-top:clamp(6px,1.5vw,16px); padding-bottom:clamp(22px,3.5vw,40px); }
.temp-band-inner{ display:grid; grid-template-columns:minmax(0,1fr) minmax(320px,.82fr); gap:clamp(28px,5vw,60px); align-items:center; }
.temp-band-text h2{ margin:0 0 14px; }
.temp-band-text p{ color:var(--ink-soft); max-width:48ch; }
.temp-band .temp-visual{ margin:0; }

/* ---------- temp visual (signature instrument) ---------- */
.temp-visual{ position:relative; padding:0; background:
   linear-gradient(180deg, var(--panel), var(--steel));
   border:1px solid var(--line-2); border-radius:8px; overflow:hidden;
   box-shadow:0 1px 0 #fff inset, 0 24px 50px oklch(40% 0.04 240 / .14); }
.visual-top{ display:flex; align-items:center; justify-content:space-between; gap:12px; padding:14px 18px;
  border-bottom:1px solid var(--line); background:oklch(96% 0.005 240); }
.vt-label{ font-family:var(--mono); font-size:.7rem; letter-spacing:.14em; text-transform:uppercase; color:var(--muted); }
.visual-top strong{ font-size:.84rem; font-weight:600; color:var(--ink); }
.temp-grid{ display:grid; gap:0; }
.temp-row{ display:grid; grid-template-columns:1fr auto; align-items:center; gap:12px; padding:15px 18px; border-bottom:1px solid var(--line); }
.temp-row:last-child{ border-bottom:0; }
.temp-label{ font-size:.95rem; color:var(--ink-soft); }
.temp-cell{ font-family:var(--mono); font-size:.92rem; font-weight:500; padding:6px 12px; border-radius:3px; font-variant-numeric:tabular-nums; white-space:nowrap; }
.temp-cell.ok{ background:var(--ok-bg); color:oklch(34% 0.08 168); border:1px solid oklch(82% 0.07 168); }
.temp-cell.mid{ background:var(--mid-bg); color:oklch(34% 0.09 230); border:1px solid oklch(80% 0.07 225); }
.temp-cell.hot{ background:var(--hot); color:var(--hot-fg); border:1px solid var(--hot); }
.temp-foot{ margin:0; padding:13px 18px; font-size:.8rem; color:var(--muted); background:oklch(96% 0.005 240); border-top:1px solid var(--line); }

/* ---------- trust ---------- */
.trust{ padding:0 clamp(18px,4vw,40px) clamp(20px,3vw,28px); }
.trust-inner{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--line); border:1px solid var(--line); border-radius:8px; overflow:hidden; }
.trust-item{ display:flex; gap:12px; padding:20px 18px; background:var(--panel); }
.trust-num{ font-family:var(--mono); font-size:.78rem; color:var(--accent); padding-top:2px; }
.trust-item strong{ display:block; font-size:.96rem; margin-bottom:3px; }
.trust-item p{ margin:0; font-size:.85rem; color:var(--muted); }

/* ---------- metiers ---------- */
.metiers{ padding:clamp(20px,3vw,30px) clamp(18px,4vw,40px); }
.metiers-kicker{ font-family:var(--mono); font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; color:var(--muted); margin:0 0 14px; }
.metier-chips{ list-style:none; margin:0; padding:0; display:flex; flex-wrap:wrap; gap:8px; }
.metier-chips li{ display:inline-flex; align-items:center; gap:8px; padding:8px 14px; border:1px solid var(--line); border-radius:999px; font-size:.88rem; color:var(--ink-soft); background:var(--panel); }
.chip-dot{ width:6px; height:6px; border-radius:50%; background:var(--accent); }

/* ---------- sections / intro ---------- */
.kicker{ font-family:var(--mono); font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; color:var(--accent-d); margin:0 0 14px; }
.section h2{ margin:0 0 16px; font-size:clamp(1.5rem,2.8vw,2.1rem); line-height:1.12; letter-spacing:-0.02em; font-weight:600; max-width:22ch; }
.section p{ color:var(--ink-soft); }
.intro{ padding-top:clamp(34px,4.5vw,56px); padding-bottom:6px; }
.lead{ font-size:1.18rem; color:var(--ink); max-width:64ch; }
.lead-sub{ font-size:1.04rem; color:var(--ink-soft); margin-top:14px; }
.content-section{ position:relative; padding-top:clamp(26px,3.5vw,40px); padding-bottom:clamp(26px,3.5vw,40px); border-top:1px solid var(--line); }
.sec-index{ font-family:var(--mono); font-size:.8rem; color:var(--accent); display:block; margin-bottom:10px; }
.content-section p+p{ margin-top:14px; }

/* ---------- guide chapters ---------- */
.guide-section{ max-width:var(--maxw); display:grid; grid-template-columns:minmax(0,.86fr) minmax(320px,.74fr); gap:clamp(30px,5vw,70px);
  align-items:center; padding-top:clamp(42px,6vw,78px); padding-bottom:clamp(42px,6vw,78px); border-top:1px solid var(--line); }
.guide-section.is-reversed{ grid-template-columns:minmax(320px,.74fr) minmax(0,.86fr); }
.guide-section.is-reversed .guide-copy{ grid-column:2; grid-row:1; }
.guide-section.is-reversed .guide-visual{ grid-column:1; grid-row:1; }
.guide-copy{ max-width:680px; }
.guide-copy h2{ max-width:17ch; margin-bottom:18px; }
.guide-copy p{ max-width:64ch; margin:0; color:var(--ink-soft); }
.guide-copy p+p{ margin-top:16px; }
.guide-visual{ margin:0; border:1px solid var(--line-2); border-radius:10px; overflow:hidden; background:linear-gradient(180deg,var(--panel),var(--steel));
  box-shadow:0 1px 0 #fff inset, 0 20px 46px oklch(40% 0.04 240 / .12); }
.guide-media{ position:relative; aspect-ratio:4/3; background:var(--steel); border-bottom:1px solid var(--line); overflow:hidden; }
.guide-media img{ display:block; width:100%; height:100%; object-fit:cover; }
.guide-media::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,transparent 56%,oklch(20% 0.02 240 / .28)); pointer-events:none; }
.guide-media-tag{ position:absolute; left:12px; bottom:12px; z-index:1; font-family:var(--mono); font-size:.68rem; letter-spacing:.1em; text-transform:uppercase;
  color:var(--accent-d); background:oklch(98% 0.006 240 / .94); border:1px solid var(--line); padding:5px 8px; border-radius:2px; }
.guide-visual figcaption{ display:grid; gap:4px; padding:15px 17px 13px; border-bottom:1px solid var(--line); }
.guide-visual figcaption strong{ font-size:1rem; line-height:1.25; }
.guide-visual figcaption span{ color:var(--muted); font-size:.86rem; line-height:1.45; }
.guide-facts{ list-style:none; margin:0; padding:0; display:grid; grid-template-columns:repeat(3,1fr); }
.guide-facts li{ display:grid; gap:3px; padding:13px 12px; border-right:1px solid var(--line); min-width:0; }
.guide-facts li:last-child{ border-right:0; }
.guide-facts span{ font-family:var(--mono); font-size:.66rem; letter-spacing:.08em; text-transform:uppercase; color:var(--muted); white-space:nowrap; }
.guide-facts b{ font-size:.84rem; line-height:1.2; color:var(--ink); }

/* ---------- showcase ---------- */
.showcase{ padding:clamp(20px,3vw,30px) clamp(18px,4vw,40px); }
.showcase-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:14px; }
.shot{ margin:0; }
.shot-img{ position:relative; aspect-ratio:4/3; border:1px solid var(--line-2); border-radius:6px; display:flex; align-items:flex-end; padding:12px;
  background:
    repeating-linear-gradient(135deg, oklch(93% 0.006 240) 0 9px, oklch(96% 0.004 240) 9px 18px); }
.shot-tag{ font-family:var(--mono); font-size:.66rem; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); background:var(--panel); border:1px solid var(--line); padding:3px 7px; border-radius:2px; }
.shot figcaption{ display:flex; flex-direction:column; gap:2px; margin-top:10px; }
.shot figcaption strong{ font-size:.94rem; }
.shot figcaption span{ font-size:.82rem; color:var(--muted); }

/* ---------- FAQ ---------- */
.faq{ border-top:1px solid var(--line); }
.faq details{ border:1px solid var(--line); border-radius:6px; background:var(--panel); margin-bottom:10px; transition:border-color .15s; }
.faq details[open]{ border-color:var(--line-2); }
.faq summary{ cursor:pointer; list-style:none; padding:16px 18px; font-weight:600; font-size:1rem; display:flex; justify-content:space-between; gap:16px; align-items:center; }
.faq summary::-webkit-details-marker{ display:none; }
.faq summary::after{ content:"+"; font-family:var(--mono); color:var(--accent); font-size:1.3rem; line-height:1; transition:transform .2s; }
.faq details[open] summary::after{ content:"−"; }
.faq details p{ margin:0; padding:0 18px 18px; color:var(--muted); }

/* ---------- grid maillage ---------- */
.grid-wrap{ border-top:1px solid var(--line); }
.grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:14px; margin-top:8px; }
.panel{ display:flex; flex-direction:column; padding:22px; border:1px solid var(--line); border-radius:8px; background:var(--panel); transition:border-color .15s, transform .15s, box-shadow .15s; }
.panel:hover{ border-color:var(--accent); transform:translateY(-2px); box-shadow:0 12px 28px oklch(50% 0.05 240 / .1); }
.panel strong{ display:block; margin-bottom:8px; font-size:1.05rem; line-height:1.25; }
.panel strong a{ text-decoration:none; }
.panel p{ margin:0 0 14px; color:var(--muted); font-size:.92rem; }
.panel-go{ margin-top:auto; font-family:var(--mono); font-size:.78rem; color:var(--accent-d); }

/* ---------- steps ---------- */
.steps-wrap{ padding:clamp(34px,5vw,60px) clamp(18px,4vw,40px); }
.steps-title{ font-size:clamp(1.5rem,2.8vw,2.1rem); letter-spacing:-0.02em; margin:0 0 24px; font-weight:600; }
.steps{ list-style:none; margin:0; padding:0; display:grid; grid-template-columns:repeat(3,1fr); gap:14px; counter-reset:none; }
.step{ padding:22px; border:1px solid var(--line); border-radius:8px; background:var(--panel); position:relative; }
.step-num{ display:inline-flex; align-items:center; justify-content:center; width:34px; height:34px; border-radius:50%; background:var(--accent-ghost); color:var(--accent-d); font-family:var(--mono); font-weight:600; margin-bottom:14px; border:1px solid oklch(82% 0.05 225); }
.step h3{ margin:0 0 6px; font-size:1.05rem; font-weight:600; }
.step p{ margin:0; color:var(--muted); font-size:.92rem; }

/* ---------- form ---------- */
.form-section{ scroll-margin-top:80px; }
.form-wrap{ display:grid; grid-template-columns:minmax(0,.82fr) minmax(0,1.1fr); gap:clamp(26px,4vw,52px); align-items:start;
  padding:clamp(26px,4vw,42px); border:1px solid var(--line-2); border-radius:12px;
  background:linear-gradient(180deg, var(--panel), var(--steel)); box-shadow:0 1px 0 #fff inset, 0 26px 56px oklch(40% 0.04 240 / .12); }
.form-intro .eyebrow{ margin-bottom:16px; }
.form-intro h2{ margin:0 0 12px; font-size:clamp(1.4rem,2.4vw,1.9rem); letter-spacing:-0.02em; }
.form-intro .lead{ font-size:1.02rem; color:var(--ink-soft); }
.reassure{ list-style:none; margin:20px 0 0; padding:0; display:grid; gap:11px; }
.reassure li{ position:relative; padding-left:28px; color:var(--ink-soft); font-size:.95rem; }
.reassure li::before{ content:"✓"; position:absolute; left:0; top:0; width:18px; height:18px; display:grid; place-items:center; font-size:.7rem; color:#fff; background:var(--ok); border-radius:3px; }
.form-aside{ margin:20px 0 0; font-size:.82rem; color:var(--muted); font-family:var(--mono); }
.form{ display:grid; grid-template-columns:repeat(2,1fr); gap:14px; min-width:0; }
label{ display:grid; gap:6px; font-size:.82rem; font-weight:500; color:var(--ink-soft); }
input,select,textarea{ width:100%; min-height:48px; padding:11px 13px; border:1px solid var(--line-2); border-radius:var(--r);
  background:var(--panel); color:var(--ink); font:inherit; font-size:.96rem; transition:border-color .15s, box-shadow .15s; min-width:0; }
input::placeholder,textarea::placeholder{ color:oklch(68% 0.01 240); }
input:focus,select:focus,textarea:focus{ outline:none; border-color:var(--accent); box-shadow:0 0 0 3px var(--accent-ghost); }
select{ appearance:none; background-image:linear-gradient(45deg,transparent 50%,var(--muted) 50%),linear-gradient(135deg,var(--muted) 50%,transparent 50%); background-position:calc(100% - 18px) 21px,calc(100% - 13px) 21px; background-size:5px 5px,5px 5px; background-repeat:no-repeat; }
textarea{ min-height:104px; resize:vertical; }
.wide{ grid-column:1 / -1; }
.consent{ grid-template-columns:auto 1fr; align-items:start; gap:11px; font-weight:400; font-size:.85rem; color:var(--muted); }
.consent input{ width:20px; height:20px; min-height:auto; margin-top:2px; accent-color:var(--accent); }
.consent a{ color:var(--accent-d); }
.hp{ position:absolute; left:-9999px; width:1px; height:1px; overflow:hidden; }
.form-note{ grid-column:1/-1; margin:2px 0 0; text-align:center; font-size:.82rem; color:var(--muted); font-family:var(--mono); }

/* ---------- final cta ---------- */
.final-cta{ padding:clamp(36px,5vw,64px) clamp(18px,4vw,40px); }
.final-inner{ background:var(--ink); color:oklch(96% 0.01 240); border-radius:12px; padding:clamp(30px,4vw,52px); text-align:center;
  background-image:radial-gradient(120% 140% at 80% -10%, oklch(40% 0.08 230 / .6), transparent 60%); }
.final-inner h2{ margin:0 0 12px; font-size:clamp(1.6rem,3vw,2.4rem); letter-spacing:-0.02em; color:#fff; }
.final-inner p{ margin:0 auto 26px; max-width:56ch; color:oklch(82% 0.02 240); }
.final-inner .hero-actions{ justify-content:center; }
.final-inner .button.secondary{ color:#fff; border-color:oklch(50% 0.02 240); }
.final-inner .button.secondary:hover{ background:oklch(32% 0.02 240); }

/* ---------- footer ---------- */
.site-footer{ border-top:1px solid var(--line); background:oklch(96% 0.006 240); }
.footer-cols{ max-width:var(--maxw); margin-inline:auto; display:flex; flex-wrap:wrap; gap:32px 28px; padding:48px clamp(18px,4vw,40px) 28px; }
.footer-about{ flex:1 1 260px; min-width:240px; }
.footer-cols>div:not(.footer-about){ flex:1 1 150px; min-width:140px; }
.footer-about strong{ display:inline-flex; align-items:center; gap:9px; margin-bottom:12px; font-size:1rem; }
.footer-blog{ margin-top:24px; }
.footer-blog strong{ display:block; margin-bottom:12px; font-size:1rem; }
.footer-cols p{ margin:0; color:var(--muted); font-size:.9rem; }
.footer-cols>div>strong{ display:block; margin-bottom:12px; }
.footer-cols a{ display:block; color:var(--muted); text-decoration:none; margin-bottom:8px; font-size:.92rem; }
.footer-cols a:hover{ color:var(--accent-d); }
.footer-legal{ max-width:var(--maxw); margin-inline:auto; display:flex; flex-wrap:wrap; justify-content:space-between; gap:12px;
  padding:18px clamp(18px,4vw,40px); border-top:1px solid var(--line); color:var(--muted); font-size:.85rem; }
.footer-legal a{ text-decoration:none; color:var(--muted); }
.footer-legal a:hover{ color:var(--accent-d); }

/* ============================================================
   CATALOGUE & ZONES — composants additionnels (Direction 01)
   ============================================================ */

/* breadcrumb */
.crumbs{ max-width:var(--maxw); margin:0 auto; padding:14px clamp(18px,4vw,40px) 0; display:flex; flex-wrap:wrap; gap:7px; align-items:center;
  font-family:var(--mono); font-size:.74rem; color:var(--muted); }
.crumbs a{ text-decoration:none; color:var(--muted); white-space:nowrap; }
.crumbs [aria-current]{ color:var(--ink); white-space:nowrap; }
.crumbs a:hover{ color:var(--accent-d); }
.crumbs .sep{ color:var(--line-2); }
.crumbs [aria-current]{ color:var(--ink); }

/* header mega-menu (Équipements) — desktop : survol/focus ; mobile : accordéon */
.nav-item{ position:relative; }
.nav-item-row{ display:flex; align-items:center; }
.menu-panel{ position:absolute; top:calc(100% + 10px); left:50%; transform:translateX(-50%) translateY(6px);
  width:min(620px,86vw); padding:14px; background:var(--panel); border:1px solid var(--line-2); border-radius:12px;
  box-shadow:0 26px 60px oklch(40% 0.04 240 / .18); display:grid; grid-template-columns:1fr 1fr; gap:6px;
  opacity:0; visibility:hidden; transition:opacity .16s ease, transform .16s ease; z-index:40; }
.nav-item:hover .menu-panel, .nav-item:focus-within .menu-panel{ opacity:1; visibility:visible; transform:translateX(-50%) translateY(0); }
.menu-link{ display:grid; grid-template-columns:1fr auto; align-items:center; gap:4px 10px; padding:11px 13px; border-radius:8px; text-decoration:none; transition:background .14s; }
.menu-link:hover{ background:var(--steel); }
.menu-link strong{ font-size:.95rem; font-weight:600; }
.menu-link .ml-count{ font-family:var(--mono); font-size:.7rem; color:var(--accent-d); white-space:nowrap; }
.menu-link span{ grid-column:1 / -1; font-size:.82rem; color:var(--muted); }

/* catalogue hub — cartes familles */
.cat-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:14px; margin-top:10px; }
.cat-card{ display:flex; flex-direction:column; padding:0; border:1px solid var(--line); border-radius:10px; background:var(--panel); overflow:hidden; transition:border-color .15s, transform .15s, box-shadow .15s; }
.cat-card:hover{ border-color:var(--accent); transform:translateY(-2px); box-shadow:0 14px 30px oklch(50% 0.05 240 / .1); }
.cat-card .cc-img{ aspect-ratio:16/10; border-bottom:1px solid var(--line); display:flex; align-items:flex-end; padding:11px;
  background:repeating-linear-gradient(135deg, oklch(93% 0.006 240) 0 9px, oklch(96% 0.004 240) 9px 18px); }
.cat-card .cc-tag{ font-family:var(--mono); font-size:.64rem; letter-spacing:.08em; text-transform:uppercase; color:var(--muted); background:var(--panel); border:1px solid var(--line); padding:3px 7px; border-radius:2px; }
.cat-card .cc-body{ display:flex; flex-direction:column; padding:18px; flex:1; }
.cat-card h3{ margin:0 0 6px; font-size:1.08rem; line-height:1.2; }
.cat-card h3 a{ text-decoration:none; }
.cat-card .cc-desc{ margin:0 0 14px; font-size:.9rem; color:var(--muted); }
.cat-card .cc-foot{ margin-top:auto; display:flex; align-items:center; justify-content:space-between; gap:10px; padding-top:14px; border-top:1px solid var(--line); }
.cat-card .cc-count{ font-family:var(--mono); font-size:.78rem; color:var(--accent-d); }
.cat-card .cc-go{ font-family:var(--mono); font-size:.78rem; color:var(--ink-soft); }

/* product list (page catégorie) */
.product-list{ display:grid; grid-template-columns:repeat(2,1fr); gap:14px; margin-top:10px; }
.product-card{ display:grid; grid-template-columns:128px 1fr; gap:0; border:1px solid var(--line); border-radius:10px; background:var(--panel); overflow:hidden; transition:border-color .15s, box-shadow .15s; }
.product-card:hover{ border-color:var(--accent); box-shadow:0 12px 28px oklch(50% 0.05 240 / .1); }
.pc-thumb{ position:relative; border-right:1px solid var(--line); display:flex; align-items:flex-start; padding:10px;
  background:repeating-linear-gradient(135deg, oklch(93% 0.006 240) 0 8px, oklch(96% 0.004 240) 8px 16px); }
.pc-gamme{ font-family:var(--mono); font-size:.6rem; letter-spacing:.06em; text-transform:uppercase; color:var(--accent-d); background:var(--accent-ghost); border:1px solid oklch(84% 0.04 225); padding:3px 7px; border-radius:2px; }
.pc-body{ display:flex; flex-direction:column; padding:16px 18px; }
.pc-body h3{ margin:0 0 6px; font-size:1.04rem; line-height:1.22; }
.pc-body h3 a{ text-decoration:none; }
.pc-desc{ margin:0 0 12px; font-size:.88rem; color:var(--muted); }
.pc-foot{ margin-top:auto; display:flex; align-items:baseline; justify-content:space-between; gap:10px; flex-wrap:wrap; }
.pc-price{ font-size:.82rem; color:var(--muted); }
.pc-price b{ font-family:var(--mono); font-size:.95rem; color:var(--ink); }
.pc-cta{ font-family:var(--mono); font-size:.76rem; color:var(--accent-d); text-decoration:none; white-space:nowrap; }
.pc-cta:hover{ text-decoration:underline; }

/* pagination */
.pager{ display:flex; gap:8px; align-items:center; justify-content:center; margin-top:26px; }
.pager a,.pager span{ min-width:44px; height:44px; padding:0 12px; display:inline-grid; place-items:center; border:1px solid var(--line-2); border-radius:6px; font-family:var(--mono); font-size:.84rem; text-decoration:none; color:var(--ink-soft); }
.pager a:hover{ border-color:var(--accent); color:var(--accent-d); }
.pager .current{ background:var(--accent); color:#fff; border-color:var(--accent-d); }

/* product hero */
.product-hero{ display:grid; grid-template-columns:minmax(0,1fr) minmax(320px,.88fr); gap:clamp(28px,4.5vw,56px); align-items:start;
  max-width:var(--maxw); margin-inline:auto; padding:clamp(22px,3.5vw,40px) clamp(18px,4vw,40px) clamp(20px,3vw,32px); }
.ph-info .eyebrow{ margin-bottom:16px; }
.ph-info h1{ max-width:18ch; }
.ph-info .hero-copy{ margin-top:16px; }
.ph-media{ border:1px solid var(--line-2); border-radius:10px; overflow:hidden; background:var(--panel); box-shadow:0 18px 42px oklch(40% 0.04 240 / .12); }
.ph-media .media-ph{ aspect-ratio:4/3; display:flex; align-items:flex-end; padding:12px; background:repeating-linear-gradient(135deg, oklch(93% 0.006 240) 0 10px, oklch(96% 0.004 240) 10px 20px); }
.ph-media .media-ph span{ font-family:var(--mono); font-size:.66rem; letter-spacing:.08em; text-transform:uppercase; color:var(--muted); background:var(--panel); border:1px solid var(--line); padding:3px 8px; border-radius:2px; }
.ph-media figcaption{ padding:11px 14px; font-size:.8rem; color:var(--muted); border-top:1px solid var(--line); font-style:italic; }
.price-block{ display:flex; flex-wrap:wrap; align-items:center; gap:14px; margin:22px 0 0; padding:16px 18px; border:1px solid var(--line-2); border-left:3px solid var(--accent); border-radius:7px; background:oklch(97.5% 0.006 240); }
.price-block .pr-amount{ font-family:var(--mono); font-size:1.12rem; font-weight:600; color:var(--ink); }
.price-block .pr-note{ font-size:.8rem; color:var(--muted); max-width:34ch; }
.price-block .button{ margin-left:auto; }

/* spec sheet (instrument) */
.spec-band{ max-width:var(--maxw); margin-inline:auto; padding:clamp(20px,3.5vw,40px) clamp(18px,4vw,40px); }
.spec-band-inner{ display:grid; grid-template-columns:minmax(0,1.25fr) minmax(280px,.8fr); gap:clamp(26px,4vw,48px); align-items:start; }
.specs-sheet{ border:1px solid var(--line-2); border-radius:8px; overflow:hidden; background:linear-gradient(180deg,var(--panel),var(--steel)); box-shadow:0 1px 0 #fff inset, 0 20px 44px oklch(40% 0.04 240 / .12); }
.specs-sheet .sheet-top{ display:flex; align-items:center; justify-content:space-between; gap:12px; padding:14px 18px; border-bottom:1px solid var(--line); background:oklch(96% 0.005 240); }
.specs-sheet .sheet-top .vt-label{ font-family:var(--mono); font-size:.7rem; letter-spacing:.14em; text-transform:uppercase; color:var(--muted); }
.specs-sheet .sheet-top strong{ font-size:.84rem; }
.specs-sheet dl{ margin:0; }
.spec-row{ display:grid; grid-template-columns:minmax(0,.85fr) minmax(0,1.15fr); gap:14px; padding:13px 18px; border-bottom:1px solid var(--line); }
.spec-row:last-child{ border-bottom:0; }
.spec-row dt{ margin:0; color:var(--ink-soft); font-size:.92rem; }
.spec-row dd{ margin:0; font-family:var(--mono); font-size:.88rem; font-weight:500; color:var(--ink); }
.spec-aside h2{ font-size:clamp(1.4rem,2.4vw,1.9rem); margin:0 0 14px; }
.spec-aside p{ color:var(--ink-soft); }

/* checklist (service zone) */
.checklist{ list-style:none; margin:18px 0 0; padding:0; display:grid; gap:13px; }
.checklist li{ position:relative; padding-left:32px; color:var(--ink-soft); }
.checklist li::before{ content:"✓"; position:absolute; left:0; top:1px; width:20px; height:20px; display:grid; place-items:center; font-size:.72rem; color:#fff; background:var(--ok); border-radius:4px; }

/* ============================================================ */

/* ---------- responsive ---------- */
@media (max-width:980px){
  .hero{ grid-template-columns:1fr; gap:32px; }
  .hero-text{ align-self:auto; }
  .temp-band-inner{ grid-template-columns:1fr; gap:28px; }
  .trust-inner{ grid-template-columns:repeat(2,1fr); }
  .showcase-grid{ grid-template-columns:repeat(2,1fr); }
  .grid,.steps{ grid-template-columns:1fr 1fr; }
  .cat-grid{ grid-template-columns:repeat(2,1fr); }
  .product-hero,.spec-band-inner{ grid-template-columns:1fr; }
  .guide-section,.guide-section.is-reversed{ grid-template-columns:1fr; gap:24px; }
  .guide-section.is-reversed .guide-copy,.guide-section.is-reversed .guide-visual{ grid-column:auto; grid-row:auto; }
  .ph-media .media-ph{ aspect-ratio:16/9; }
  .form-wrap{ grid-template-columns:1fr; }
  .link-call{ display:none; }
}
/* ----- mega-menu responsive : drawer + accordéon (≤900px) ----- */
@media (max-width:900px){
  .site-header{ grid-template-columns:auto 1fr auto; position:sticky; }
  .hero{ justify-items:center; }
  .hero-text,.hero-form{ width:min(350px,calc(100vw - 40px)); max-width:min(350px,calc(100vw - 40px)); justify-self:center; }
  h1{ max-width:10.8ch; }
  .hero-copy{ max-width:31ch; }
  .header-cta > .link-call, .header-cta > .button{ display:none; }
  .nav-toggle{ display:inline-flex; align-items:center; gap:9px; min-height:44px; padding:0 14px; border:1px solid var(--line-2);
    border-radius:var(--r); background:var(--panel); font:inherit; font-size:.9rem; font-weight:600; color:var(--ink); cursor:pointer; }
  .nav-toggle .bars, .nav-toggle .bars::before, .nav-toggle .bars::after{ content:""; display:block; width:18px; height:2px; background:var(--ink); border-radius:2px; transition:transform .2s ease; }
  .nav-toggle .bars{ position:relative; }
  .nav-toggle .bars::before{ position:absolute; left:0; top:-6px; }
  .nav-toggle .bars::after{ position:absolute; left:0; top:6px; }
  .site-header[data-open="true"] .nav-toggle .bars{ background:transparent; }
  .site-header[data-open="true"] .nav-toggle .bars::before{ top:0; transform:rotate(45deg); }
  .site-header[data-open="true"] .nav-toggle .bars::after{ top:0; transform:rotate(-45deg); }
  .nav{ position:absolute; top:100%; left:0; right:0; flex-direction:column; align-items:stretch; gap:0; justify-content:flex-start;
    background:var(--panel); border-bottom:1px solid var(--line); box-shadow:0 26px 44px oklch(40% 0.04 240/.16);
    max-height:0; overflow:hidden; visibility:hidden; padding:0 clamp(16px,4vw,40px); transition:max-height .26s ease, visibility .26s; }
  .site-header[data-open="true"] .nav{ max-height:min(80vh,580px); overflow-y:auto; visibility:visible; padding-top:6px; padding-bottom:16px; }
  .nav > a:not(.nav-cta-mobile), .nav .nav-top{ padding:15px 2px; border-bottom:1px solid var(--line); border-radius:0; justify-content:space-between; width:100%; color:var(--ink); font-size:1rem; }
  .nav-top::after{ display:none; }
  .nav-item{ position:static; }
  .nav-item-row{ border-bottom:1px solid var(--line); }
  .nav-item-row .nav-top{ border-bottom:0; flex:1; }
  .submenu-toggle{ display:inline-flex; align-items:center; justify-content:center; width:52px; align-self:stretch; background:transparent;
    border:0; border-left:1px solid var(--line); color:var(--accent-d); font:inherit; font-size:1.5rem; line-height:1; cursor:pointer; }
  .submenu-toggle::before{ content:"+"; }
  .nav-item[data-open="true"] .submenu-toggle::before{ content:"−"; }
  .menu-panel{ position:static; transform:none; width:auto; opacity:1; visibility:visible; display:none; grid-template-columns:1fr;
    box-shadow:none; border:0; border-radius:0; padding:8px 0; background:transparent; }
  .nav-item[data-open="true"] .menu-panel{ display:grid; }
  .menu-link{ background:var(--steel); margin-bottom:6px; }
  .nav .nav-cta-mobile{ display:inline-flex; margin-top:14px; }
}
@media (max-width:680px){
  .trust-inner,.showcase-grid,.grid,.steps{ grid-template-columns:1fr; }
  .cat-grid,.product-list{ grid-template-columns:1fr; }
  .price-block .button{ margin-left:0; width:100%; }
  .temp-legend{ display:none; }
  .hero{ max-width:100vw; padding-left:20px; padding-right:20px; justify-items:stretch; }
  .hero-text,.hero-form{ width:min(350px,calc(100vw - 40px)); max-width:min(350px,calc(100vw - 40px)); }
  .hero-copy{ width:100%; max-width:31ch; }
  .hero-form{ justify-self:stretch; }
  .hf-head span,.form-note,.consent span{ overflow-wrap:anywhere; }
  h1{ overflow-wrap:break-word; }
  .guide-section{ padding-top:36px; padding-bottom:40px; }
  .guide-media{ aspect-ratio:16/11; }
  .guide-facts{ grid-template-columns:1fr; }
  .guide-facts li{ border-right:0; border-bottom:1px solid var(--line); }
  .guide-facts li:last-child{ border-bottom:0; }
  .form{ grid-template-columns:1fr; }
  h1{ max-width:10.8ch; font-size:clamp(1.85rem,8vw,2.25rem); }
  .hero-actions .button{ flex:1 1 auto; }
}
@media (max-width:480px){
  .hero{ justify-items:center; }
}

/* ============================================================
   ADDITIONS PROJET (images réelles, schémas, intro pages internes)
   ============================================================ */
/* image d'en-tête des pages internes (hub catalogue, catégorie, zones) */
.page-hero{ max-width:var(--maxw); margin:14px auto 0; padding:0 clamp(18px,4vw,40px); }
.page-hero img{ display:block; width:100%; height:auto; aspect-ratio:21/9; object-fit:cover; border:1px solid var(--line-2); border-radius:10px; }
@media (max-width:560px){ .page-hero img{ aspect-ratio:16/9; } }
/* légende illustrative (italique, discrète) */
.img-illus{ font-style:italic; color:var(--muted); font-size:.8rem; margin-top:8px; }
/* intro centrée des pages catalogue/zones */
.catalogue-intro .eyebrow{ margin-bottom:10px; }
.catalogue-intro h1{ max-width:20ch; }
/* galerie produit (2 illustrations) */
.product-gallery{ display:grid; grid-template-columns:1fr 1fr; gap:12px; margin:0; }
.product-gallery figure{ margin:0; border:1px solid var(--line-2); border-radius:10px; overflow:hidden; background:var(--panel); }
.product-gallery img{ display:block; width:100%; height:auto; aspect-ratio:1/1; object-fit:cover; }
.product-gallery figcaption{ padding:9px 12px; border-top:1px solid var(--line); font-style:italic; color:var(--muted); font-size:.78rem; }
@media (max-width:560px){ .product-gallery{ grid-template-columns:1fr; } }
/* schéma de principe SVG (fiche produit) */
.vitrine-schema{ margin:18px 0 0; border:1px solid var(--line); border-radius:8px; padding:14px 16px; background:var(--panel); }
.vitrine-schema svg{ display:block; width:100%; max-width:320px; height:auto; margin:0 auto; }
/* pages légales / contenu simple */
.legal h2{ font-size:1.2rem; margin:26px 0 10px; }
.legal p,.legal li{ color:var(--ink-soft); }

/* ============================================================
   RYTHME DE BLOCS « chapitres » (inspiré chroma-static : sono)
   Alternance fond clair / bande teintée + stats + split + critères.
   ============================================================ */
/* bande pleine largeur teintée (alternance avec les sections claires) */
.band{ background:var(--steel); border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.band .section{ padding-top:clamp(30px,4.5vw,56px); padding-bottom:clamp(30px,4.5vw,56px); }
/* bandeau de stats (4 repères factuels) */
.cat-stats{ max-width:var(--maxw); margin:18px auto 0; display:grid; grid-template-columns:repeat(4,1fr);
  border:1px solid var(--line); border-radius:10px; overflow:hidden; background:var(--panel); }
.cat-stat{ padding:18px 20px; border-right:1px solid var(--line); }
.cat-stat:last-child{ border-right:0; }
.cat-stat b{ display:block; font-family:var(--mono); font-size:1.06rem; color:var(--ink); letter-spacing:-0.01em; }
.cat-stat span{ font-size:.82rem; color:var(--muted); }
/* bloc deux colonnes (texte + liste / visuel) */
.split{ display:grid; grid-template-columns:1.1fr .9fr; gap:clamp(26px,4vw,52px); align-items:center; }
.split-media{ margin:0; border:1px solid var(--line-2); border-radius:10px; overflow:hidden; background:var(--panel); }
.split-media img{ display:block; width:100%; height:auto; aspect-ratio:4/3; object-fit:cover; }
.split-media figcaption{ padding:9px 12px; border-top:1px solid var(--line); font-style:italic; color:var(--muted); font-size:.78rem; }
/* liste de critères (dimensions specs réelles) */
.crit-list{ list-style:none; margin:16px 0 0; padding:0; display:grid; gap:10px; }
.crit-list li{ position:relative; padding-left:26px; color:var(--ink-soft); font-size:.95rem; }
.crit-list li::before{ content:"→"; position:absolute; left:0; top:0; color:var(--accent-d); font-family:var(--mono); }
.crit-list b{ color:var(--ink); font-weight:600; }
.band-links{ margin:22px 0 0; display:flex; flex-wrap:wrap; gap:8px 28px; }
.band-links a{ font-family:var(--mono); font-size:.85rem; color:var(--accent-d); text-decoration:none; }
.band-links a:hover{ text-decoration:underline; }
/* air au-dessus du bandeau confiance quand il suit une bande (transition) */
.band + .trust{ padding-top:clamp(28px,3.5vw,40px); }

/* ============================================================
   CARTES PRODUIT cliquables en entier (stretched-link) + CTA sans prix
   ============================================================ */
.product-card{ position:relative; }
.pc-link{ text-decoration:none; color:inherit; }
.pc-link::after{ content:""; position:absolute; inset:0; z-index:1; }
.product-card:hover .pc-link{ color:var(--accent-d); }
.product-card .pc-cta{ color:var(--accent-d); }   /* span visuel (le lien couvre la carte) */
/* fiche produit : CTA devis sans tarif */
.product-cta{ display:flex; flex-wrap:wrap; align-items:center; gap:12px 18px; margin:22px 0 0; }
.product-cta-note{ font-family:var(--mono); font-size:.8rem; color:var(--muted); }

/* ============================================================
   MAILLAGE — 3 traitements distincts (anti-doublon) : back-link / CTA / cartes
   ============================================================ */
.linkhub{ border-top:1px solid var(--line); }
.linkhub-title{ margin:0 0 14px; }
/* PARENT : barre "remonter" fine */
.nav-back{ display:flex; align-items:baseline; gap:12px; flex-wrap:wrap; padding:12px 16px; margin-bottom:20px;
  border:1px solid var(--line); border-left:3px solid var(--line-2); border-radius:8px; background:var(--panel); text-decoration:none; transition:border-color .15s; }
.nav-back:hover{ border-left-color:var(--accent); }
.nav-back .nb-label{ font-family:var(--mono); font-size:.76rem; color:var(--accent-d); white-space:nowrap; }
.nav-back .nb-title{ font-weight:600; color:var(--ink); }
/* BRIDGE catalogue : CTA accentué */
.bridge-cta{ display:flex; align-items:center; justify-content:space-between; gap:18px; padding:20px 24px; margin-bottom:24px;
  border:1px solid var(--accent-d); border-radius:10px; background:var(--accent-ghost); text-decoration:none; transition:box-shadow .15s, transform .12s; }
.bridge-cta:hover{ box-shadow:0 12px 28px oklch(50% 0.12 230 / .2); transform:translateY(-1px); }
.bridge-cta .bc-eyebrow{ display:block; font-family:var(--mono); font-size:.7rem; letter-spacing:.1em; text-transform:uppercase; color:var(--accent-d); margin-bottom:4px; }
.bridge-cta strong{ display:block; font-size:1.08rem; color:var(--ink); letter-spacing:-0.01em; }
.bridge-cta .bc-desc{ display:block; font-size:.88rem; color:var(--ink-soft); margin-top:3px; }
.bridge-cta .bc-go{ font-family:var(--mono); font-size:1.6rem; color:var(--accent-d); flex:0 0 auto; }
/* PROCHES : grille de cartes compactes taguées */
.link-grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(260px,1fr)); gap:12px; }
.link-card{ display:flex; flex-direction:column; gap:4px; padding:16px 18px; border:1px solid var(--line); border-radius:8px;
  background:var(--panel); text-decoration:none; transition:border-color .15s, transform .12s, box-shadow .15s; }
.link-card:hover{ border-color:var(--accent); transform:translateY(-2px); box-shadow:0 10px 24px oklch(50% 0.05 240 / .1); }
.link-card .lc-eyebrow{ font-family:var(--mono); font-size:.65rem; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); }
.link-card strong{ font-size:.98rem; color:var(--ink); line-height:1.25; letter-spacing:-0.01em; }
.link-card .lc-desc{ font-size:.86rem; color:var(--muted); }
.link-card .lc-go{ margin-top:auto; padding-top:6px; font-family:var(--mono); font-size:.78rem; color:var(--accent-d); }
@media (max-width:780px){
  .cat-stats{ grid-template-columns:1fr 1fr; }
  .cat-stat:nth-child(2){ border-right:0; }
  .cat-stat:nth-child(1),.cat-stat:nth-child(2){ border-bottom:1px solid var(--line); }
  .split{ grid-template-columns:1fr; }
}

/* dropdowns simples (Guides d'achat, Occasion, Zones) — liste verticale de liens */
.menu-list-panel a{ display:block; padding:9px 12px; border-radius:8px; text-decoration:none; color:var(--ink-soft); font-size:.9rem; }
.menu-list-panel a:hover{ background:var(--steel); color:var(--accent-d); }
@media (min-width:901px){
  .menu-list-panel{ grid-template-columns:1fr; width:min(290px,86vw); }
  /* pont hover : comble le vide de 10px entre l'entrée et le panneau,
     sinon le survol se perd en descendant la souris et le panneau se ferme. */
  .menu-panel::before{ content:""; position:absolute; top:-14px; left:0; right:0; height:14px; }
}

/* vraies images dans les emplacements du kit (placeholders rayés -> photos/illustrations) */
.cat-card .cc-img{ position:relative; padding:0; overflow:hidden; background:var(--steel); }
.cat-card .cc-img img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.cat-card .cc-img .cc-tag{ position:absolute; left:11px; bottom:11px; z-index:1; }
.pc-thumb{ position:relative; padding:0; overflow:hidden; background:var(--steel); }
.pc-thumb img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.pc-thumb .pc-gamme{ position:absolute; left:8px; top:8px; z-index:1; }
.ph-media .media-ph{ position:relative; padding:0; }
.ph-media .media-ph img{ display:block; width:100%; height:100%; object-fit:cover; }
.ph-media .media-ph span{ position:absolute; left:12px; bottom:12px; z-index:1; }
/* image "en situation" dans l'aside de la fiche produit */
.aside-fig{ margin:16px 0 0; border:1px solid var(--line-2); border-radius:8px; overflow:hidden; background:var(--panel); }
.aside-fig img{ display:block; width:100%; height:auto; aspect-ratio:4/3; object-fit:cover; }
.aside-fig figcaption{ padding:8px 12px; border-top:1px solid var(--line); margin-top:0; }
