/* =============================================================
   KOPTICAL — Design System
   Charte 2025 : Manrope · vert PANTONE 556/559/5545 · mauve 5205/5235
   Combine : frontend-design (direction) + gpt-taste (rythme éditorial)
             + impeccable (rigueur, contrastes, motion responsable)
   ============================================================= */

/* ---------- 1. TOKENS ---------- */
:root {
  /* Brand — valeurs charte (HEX verrouillés, identity-preservation) */
  --green:        #6fa287;   /* PANTONE 556  — principal */
  --green-light:  #adcab8;   /* PANTONE 559  — clair */
  --green-dark:   #43695b;   /* PANTONE 5545 — foncé, surfaces sombres */
  --mauve:        #86647a;   /* PANTONE 5205 — complémentaire */
  --mauve-light:  #c6b0bc;   /* PANTONE 5235 — fonds doux */

  /* Dérivés */
  --green-900:    #2f4a40;   /* forêt profond, contraste hero */
  --green-cta:    #4a7d63;   /* vert assombri pour surfaces à texte blanc (AA : 4.77:1) */
  --green-50:     #eef3ef;   /* voile vert très clair */
  --mauve-900:    #5d4453;   /* mauve profond, texte sur clair */
  --mauve-50:     #f3eef1;

  /* Texte & surfaces sur fonds sombres (tokenisé) */
  --on-dark:         #eaf1ec;  /* texte courant sur fond sombre */
  --on-dark-soft:    #d8e4dc;  /* corps muté sur sombre (AA 4.7:1) */
  --on-dark-faint:   #a9c2b4;  /* tertiaire sur la surface la plus sombre */
  --on-dark-surface: rgba(255,255,255,.06);
  --on-dark-border:  rgba(255,255,255,.12);

  --ink:          #1b211e;   /* near-black tinté vert */
  --ink-soft:     #45504b;   /* texte secondaire (contraste AA sur paper) */
  --paper:        #f5f7f5;   /* off-white tinté brand (pas cream/beige) */
  --surface:      #ffffff;
  --line:         #e2e8e3;   /* séparateurs */

  /* Typo */
  --font: "Manrope", ui-sans-serif, system-ui, sans-serif;
  --fs-900: clamp(2.9rem, 6vw, 5.4rem);   /* hero (≤6rem) */
  --fs-800: clamp(2.2rem, 4.2vw, 3.6rem); /* section title */
  --fs-700: clamp(1.6rem, 2.6vw, 2.3rem);
  --fs-600: clamp(1.3rem, 1.8vw, 1.6rem);
  --fs-500: 1.18rem;
  --fs-400: 1rem;
  --fs-300: 0.875rem;
  --fs-200: 0.78rem;

  /* Espacements — rythme cinématique */
  --space-section: clamp(3.5rem, 6.5vw, 5.5rem);
  --gutter: clamp(1.25rem, 4vw, 3rem);
  --maxw: 1240px;
  --maxw-wide: 1440px;

  /* Rayons */
  --r-sm: 8px;
  --r-md: 14px;
  --r-lg: 26px;
  --r-xl: 38px;
  --r-pill: 999px;

  /* Ombres douces */
  --sh-1: 0 1px 2px rgba(27,33,30,.04), 0 4px 14px rgba(27,33,30,.06);
  --sh-2: 0 8px 30px rgba(27,33,30,.10);
  --sh-3: 0 20px 60px rgba(47,74,64,.18);

  /* Z-index sémantique */
  --z-base: 1;
  --z-dropdown: 100;
  --z-sticky: 200;
  --z-backdrop: 300;
  --z-modal: 400;

  /* Motion */
  --ease: cubic-bezier(.22,1,.36,1);          /* ease-out-quint */
  --ease-soft: cubic-bezier(.33,.8,.3,1);
  --dur: .7s;
}

/* ---------- 2. RESET / BASE ---------- */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } }

body {
  font-family: var(--font);
  font-size: var(--fs-400);
  line-height: 1.6;
  color: var(--ink);
  background: var(--paper);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}

img, svg, video { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; border: none; background: none; color: inherit; }
ul { list-style: none; padding: 0; }
:focus-visible { outline: 3px solid var(--green); outline-offset: 3px; border-radius: 4px; }
::selection { background: var(--green); color: #fff; }

h1, h2, h3, h4 { line-height: 1.04; font-weight: 800; letter-spacing: -0.03em; text-wrap: balance; }
p { text-wrap: pretty; }

/* ---------- 3. LAYOUT ---------- */
.wrap { width: min(100% - var(--gutter) * 2, var(--maxw)); margin-inline: auto; }
.wrap--wide { width: min(100% - var(--gutter) * 2, var(--maxw-wide)); margin-inline: auto; }
.section { padding-block: var(--space-section); }
.section--tight { padding-block: clamp(2.5rem, 4.5vw, 3.75rem); }
main { overflow-x: hidden; width: 100%; }

/* Eyebrow nommé (système de marque délibéré, PAS sur chaque section) */
.kicker {
  display: inline-flex; align-items: center; gap: .55em;
  font-size: var(--fs-300); font-weight: 700; letter-spacing: .02em;
  color: var(--mauve-900);
}
.kicker::before {
  content: "»"; color: var(--green); font-weight: 800; font-size: 1.2em; line-height: 0;
}

.section-head { max-width: 46rem; margin-bottom: clamp(2.2rem, 4vw, 3.4rem); }
.section-head h2 { font-size: var(--fs-800); margin-top: .5rem; }
.section-head p { color: var(--ink-soft); font-size: var(--fs-500); margin-top: 1rem; max-width: 60ch; }

/* ---------- 4. HALFTONE (signature catalogue) ---------- */
.halftone { position: relative; isolation: isolate; }
.halftone::after {
  content: ""; position: absolute; inset: 0; z-index: -1; pointer-events: none;
  background-image: radial-gradient(currentColor 1.4px, transparent 1.5px);
  background-size: 15px 15px;
  opacity: .14;
  -webkit-mask-image: linear-gradient(115deg, #000 0 35%, transparent 78%);
          mask-image: linear-gradient(115deg, #000 0 35%, transparent 78%);
}

/* ---------- 5. CHEVRON »  ---------- */
.chev { color: var(--green); font-weight: 800; }

/* ---------- 6. BOUTONS ---------- */
.btn {
  display: inline-flex; align-items: center; gap: .6em;
  padding: .92em 1.5em; border-radius: var(--r-pill);
  font-weight: 700; font-size: var(--fs-400); letter-spacing: -.01em;
  transition: transform .35s var(--ease), background-color .35s var(--ease), color .35s var(--ease), box-shadow .35s var(--ease);
  will-change: transform;
}
.btn:hover { transform: translateY(-3px); }
.btn:active { transform: translateY(-1px); }
.btn .ic { transition: transform .4s var(--ease); }
.btn:hover .ic { transform: translateX(4px); }

.btn--primary { background: var(--mauve); color: #fff; box-shadow: 0 8px 22px rgba(134,100,122,.32); }
.btn--primary:hover { background: var(--mauve-900); box-shadow: 0 14px 30px rgba(134,100,122,.4); }

.btn--green { background: var(--green-cta); color: #fff; box-shadow: 0 8px 22px rgba(74,125,99,.32); }
.btn--green:hover { background: var(--green-dark); }

.btn--ghost { background: transparent; color: currentColor; box-shadow: inset 0 0 0 1.5px currentColor; }
.btn--ghost:hover { background: currentColor; }
.btn--ghost:hover span { color: var(--green-dark); }
.on-dark .btn--ghost:hover span { color: var(--green-dark); }

.btn--light { background: #fff; color: var(--green-dark); }
.btn--light:hover { background: var(--green-light); }

.link-arrow { display: inline-flex; align-items: center; gap: .5em; font-weight: 700; color: var(--mauve-900); }
.link-arrow .ic { transition: transform .4s var(--ease); }
.link-arrow:hover .ic { transform: translateX(5px); }

/* ---------- 7. PILL-TAB à chevron (onglets fiche produit) ---------- */
.pill {
  display: inline-flex; align-items: center; justify-content: center; gap: .65em;
  padding: .7em 1.3em; min-height: 44px; border-radius: var(--r-pill);
  background: var(--mauve-light); color: var(--mauve-900);
  font-weight: 700; font-size: var(--fs-300);
  transition: background .3s var(--ease), color .3s var(--ease), transform .3s var(--ease);
}
.pill .dchev { color: var(--green-dark); font-weight: 800; }
.pill:hover, .pill.is-active { background: var(--mauve); color: #fff; transform: translateY(-2px); }
.pill:hover .dchev, .pill.is-active .dchev { color: #fff; }

.badge-new {
  display: inline-block; padding: .25em .7em; border-radius: var(--r-pill);
  background: var(--mauve); color: #fff; font-size: var(--fs-200); font-weight: 800;
  letter-spacing: .04em; vertical-align: middle;
}

/* ---------- 8. SURFACES SOMBRES ---------- */
.on-dark { color: var(--on-dark); }
.on-dark h1, .on-dark h2, .on-dark h3 { color: #fff; }
.on-dark .kicker { color: var(--green-light); }
.bg-forest { background: var(--green-dark); color: var(--on-dark); }
.bg-forest-deep { background: var(--green-900); color: var(--on-dark); }
.bg-mauve-deep { background: linear-gradient(135deg, var(--mauve-900) 0%, var(--mauve) 100%); color: var(--on-dark); }

/* ---------- 9. MEDIA (photos N&B / duotone) ---------- */
.media { position: relative; overflow: hidden; background: var(--green-900); }
.media img {
  width: 100%; height: 100%; object-fit: cover;
  filter: grayscale(1) contrast(1.06);
  transition: transform 1.1s var(--ease), filter .6s var(--ease);
}
.media--zoom:hover img { transform: scale(1.06); }
/* Images conservées en couleur (verres teintés, miroirs) — exemptées du N&B */
.media--color img { filter: none !important; }
.media--color { background: #fff; }
/* voile duotone vert subtil (au survol des cartes) */
.media--duo::after {
  content: ""; position: absolute; inset: 0;
  background: var(--duo, var(--green-dark)); mix-blend-mode: color; opacity: var(--duo-rest, 0); transition: opacity .5s var(--ease);
}
.media--duo:hover::after { opacity: var(--duo-hover, .55); }

/* Cadre en arche (signature catalogue) */
.frame-arch { border-radius: 48% 48% var(--r-lg) var(--r-lg) / 26% 26% 4% 4%; }

/* ---------- 10. HEADER / NAV ---------- */
.site-header {
  position: sticky; top: 0; z-index: var(--z-sticky);
  transition: background .4s var(--ease), box-shadow .4s var(--ease), padding .4s var(--ease);
  padding-block: 1.1rem;
}
/* Pages à fond clair sous le header : fine bordure de séparation au repos (subtile) */
.home .site-header,
.light-top .site-header { border-bottom: 1px solid var(--line); }
.home .site-header.is-scrolled,
.light-top .site-header.is-scrolled { border-bottom-color: transparent; }
.site-header.is-scrolled {
  background: rgba(245,247,245,.82);
  backdrop-filter: saturate(1.4) blur(14px);
  box-shadow: 0 1px 0 var(--line);
  padding-block: .6rem;
}
.nav { display: flex; align-items: center; justify-content: space-between; gap: 1.5rem; }
.brand { display: inline-flex; align-items: center; gap: .7rem; flex: none; }
.brand-mark, .brand-word {
  display: block; background: currentColor;
  -webkit-mask-repeat: no-repeat; mask-repeat: no-repeat;
  -webkit-mask-size: contain; mask-size: contain;
}
.brand-mark {
  width: 34px; height: 34px; color: var(--green);
  -webkit-mask-position: center; mask-position: center;
  -webkit-mask-image: url("data:image/svg+xml;base64,PHN2ZyB2ZXJzaW9uPSIxLjAiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIKIHZpZXdCb3g9IjAgMCA2ODQuMDAwMDAwIDY4NC4wMDAwMDAiCiBwcmVzZXJ2ZUFzcGVjdFJhdGlvPSJ4TWlkWU1pZCBtZWV0Ij4KPGcgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoMC4wMDAwMDAsNjg0LjAwMDAwMCkgc2NhbGUoMC4xMDAwMDAsLTAuMTAwMDAwKSIKZmlsbD0iIzAwMDAwMCIgc3Ryb2tlPSJub25lIj4KPHBhdGggZD0iTTI4IDY4MTIgbC0yOCAtMTcgMCAtMTQyNyBjMCAtMTQyNiAwIC0xNDI4IDIwIC0xNDI4IDExIDAgNjkgMjMgMTI4CjUxIDE0MyA2OCAyMzMgMTA4IDI5NyAxMzIgMjIgOCA2NCAyNSA5MyAzNyA1NyAyMiAyNjMgOTEgMzQ3IDExNSAxNzUgNDkgMjU2CjY5IDM2NSA5MCA0NyA5IDEwNCAyMCAxMjggMjYgMjQgNSA4NiAxNCAxMzkgMTkgNTIgNiA5OSAxMyAxMDQgMTYgNSAzIDczIDkKMTUyIDE0IDc4IDUgMTgxIDEyIDIzMCAxNiBsODcgNyAtMiAtMTAzOSAtMyAtMTAzOSAtMTEwIC03IGMtNjAgLTQgLTE0MSAtMTUKLTE3OSAtMjMgLTM4IC04IC04MyAtMTUgLTEwMCAtMTUgLTMwIDAgLTkxIC0xNiAtMjQxIC02MCAtMzggLTEyIC04NyAtMjUKLTEwOCAtMzEgLTIxIC01IC00NSAtMTMgLTU1IC0xOCAtOSAtNSAtNjkgLTMxIC0xMzIgLTU3IC02MyAtMjcgLTEzNSAtNjAKLTE2MCAtNzQgLTI1IC0xNCAtNTIgLTI5IC02MCAtMzMgLTggLTQgLTI4IC0xNiAtNDUgLTI3IC0xNiAtMTAgLTQ5IC0yOSAtNzEKLTQxIC0zOCAtMTkgLTIyMiAtMTUzIC0yOTkgLTIxNyAtNjkgLTU2IC0yNDUgLTIzMyAtMzAwIC0zMDEgLTEwMyAtMTI2IC0xNzcKLTIyNSAtMTkzIC0yNTggLTkgLTE4IC0xOSAtMzMgLTI0IC0zMyAtNCAwIC04IC0yNTggLTggLTU3MyBsMCAtNTc0IDI1IC0xMQpjMzggLTE3IDIwNDYgLTE3IDIwNjMgMCA5IDkgMTIgMjg0IDEyIDExNzYgbDAgMTE2NCAyMTggLTQgYzExOSAtMyAyNDIgLTEwCjI3MiAtMTcgMzAgLTYgODkgLTE5IDEzMCAtMjcgNDEgLTggOTUgLTIxIDEyMCAtMjggMjUgLTggNzIgLTIyIDEwNSAtMzEgNTUKLTE2IDExOSAtNDAgMjUyIC05NCA3OSAtMzIgMjUxIC0xMjMgMzM0IC0xNzYgNDEgLTI2IDg1IC01NCA5OSAtNjMgNTEgLTMxCjI1NyAtMjAyIDMzMSAtMjc0IDE1NyAtMTUyIDM0MSAtMzg3IDQxOSAtNTMzIDYgLTExIDE5IC0zMyAzMCAtNTAgMTEgLTE2IDI0Ci0zOSAyOSAtNTEgNSAtMTIgMzMgLTY5IDYxIC0xMjggMjkgLTU5IDU2IC0xMjAgNjAgLTEzNCA1IC0xNSAxOCAtNTIgMzAgLTgyCjEyIC0zMCAyNCAtNjQgMjYgLTc1IDMgLTExIDExIC00MiAxOSAtNzAgNDkgLTE3OCA1OCAtMjE5IDgwIC0zODQgOCAtNTYgMjAKLTEwOSAyNiAtMTE3IDEwIC0xMiAxNjggLTE0IDEwMzggLTEyIGwxMDI2IDMgMyA1NCBjMyA1NyAtMzIgMzg3IC00OCA0NTYgLTUKMjIgLTEwIDU1IC0xMCA3NCAwIDMzIC0xOCAxMjEgLTQyIDIwNiAtNiAyMiAtMTUgNTggLTE5IDgwIC0zMCAxNTAgLTYzIDI2NAotMTM0IDQ2MCAtMjAgNTUgLTQwIDExNCAtNDUgMTMwIC05IDMzIC0yNyA3NiAtNzIgMTc1IC0xNyAzNiAtNDEgOTAgLTU1IDEyMAotNjMgMTQwIC0xMzcgMjgxIC0xODMgMzUwIC02IDggLTEzIDIyIC0xNyAzMCAtNTkgMTMwIC0zNjEgNTQ5IC01MTEgNzEwIC0xMwoxNCAtNDMgNTAgLTY3IDgwIC00NCA1NSAtMzE1IDMxOSAtMzk3IDM4NiAtODMgNjggLTg5IDc1IC04NiA4OCAyIDcgNDEgNDYgODgKODYgMjM4IDIwOCA1NjAgNTU1IDY5NyA3NTEgMjggNDEgODIgMTE3IDExOSAxNjkgMzcgNTIgNzYgMTEyIDg4IDEzMyAxMiAyMQoyNiA0NiAzMSA1NSA2IDkgMzUgNjAgNjUgMTEyIDMwIDUyIDYwIDEwNCA2NyAxMTUgMTYgMjggNTggMTE0IDg5IDE4MyA0OSAxMDgKODYgMTg3IDk2IDIwNiAxMiAyMiA2NiAxNjkgNzggMjExIDUgMTcgMjUgNzUgNDUgMTMwIDM4IDEwNSA2MSAxODMgNzQgMjUwIDQKMjIgMTMgNjAgMjAgODUgNDAgMTQ0IDcxIDI4NSA3MSAzMTcgMCAxNSA2IDY0IDE0IDEwOCAyMCAxMDkgNDYgMzQ3IDQ2IDQxNSAwCjMxIC01IDYxIC0xMiA2OCAtMTggMTggLTIwMjcgMTcgLTIwNTEgMCAtMTMgLTEwIC0yMSAtNDIgLTMxIC0xMTggLTIzIC0xNzIKLTM4IC0yNDUgLTgxIC0zOTAgLTggLTI1IC0xNyAtNjAgLTIwIC03NyAtNCAtMTggLTExIC0zNSAtMTYgLTM4IC01IC00IC05Ci0xMyAtOSAtMjIgMCAtOCAtNiAtMjkgLTE0IC00NiAtNyAtMTggLTIxIC01MiAtMzEgLTc3IC0zMyAtODcgLTEyMCAtMjU2Ci0xODcgLTM2NyAtMTYyIC0yNzAgLTM4NCAtNTEzIC02NTAgLTcxMyAtNTkgLTQ0IC0xMTAgLTgwIC0xMTIgLTgwIC0zIDAgLTMzCi0xOSAtNjggLTQzIC02OCAtNDYgLTI0OCAtMTQwIC0zMzggLTE3NyAtMzAgLTEyIC02OCAtMjggLTg1IC0zNSAtNjUgLTI4Ci0xMDMgLTQxIC0yNzAgLTg4IC0yNyAtOCAtODggLTIyIC0xMzUgLTMxIC00NyAtMTAgLTEwNyAtMjIgLTEzNSAtMjggLTI3IC02Ci0xNDMgLTEzIC0yNTcgLTE2IGwtMjA4IC00IDAgMTE3MSAwIDExNzEgLTI2IDEwIGMtMTYgNiAtMzk4IDEwIC0xMDIyIDEwCi05MjIgLTEgLTk5OSAtMiAtMTAyNCAtMTh6Ii8+CjwvZz4KPC9zdmc+Cg=="); mask-image: url("data:image/svg+xml;base64,PHN2ZyB2ZXJzaW9uPSIxLjAiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIKIHZpZXdCb3g9IjAgMCA2ODQuMDAwMDAwIDY4NC4wMDAwMDAiCiBwcmVzZXJ2ZUFzcGVjdFJhdGlvPSJ4TWlkWU1pZCBtZWV0Ij4KPGcgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoMC4wMDAwMDAsNjg0LjAwMDAwMCkgc2NhbGUoMC4xMDAwMDAsLTAuMTAwMDAwKSIKZmlsbD0iIzAwMDAwMCIgc3Ryb2tlPSJub25lIj4KPHBhdGggZD0iTTI4IDY4MTIgbC0yOCAtMTcgMCAtMTQyNyBjMCAtMTQyNiAwIC0xNDI4IDIwIC0xNDI4IDExIDAgNjkgMjMgMTI4CjUxIDE0MyA2OCAyMzMgMTA4IDI5NyAxMzIgMjIgOCA2NCAyNSA5MyAzNyA1NyAyMiAyNjMgOTEgMzQ3IDExNSAxNzUgNDkgMjU2CjY5IDM2NSA5MCA0NyA5IDEwNCAyMCAxMjggMjYgMjQgNSA4NiAxNCAxMzkgMTkgNTIgNiA5OSAxMyAxMDQgMTYgNSAzIDczIDkKMTUyIDE0IDc4IDUgMTgxIDEyIDIzMCAxNiBsODcgNyAtMiAtMTAzOSAtMyAtMTAzOSAtMTEwIC03IGMtNjAgLTQgLTE0MSAtMTUKLTE3OSAtMjMgLTM4IC04IC04MyAtMTUgLTEwMCAtMTUgLTMwIDAgLTkxIC0xNiAtMjQxIC02MCAtMzggLTEyIC04NyAtMjUKLTEwOCAtMzEgLTIxIC01IC00NSAtMTMgLTU1IC0xOCAtOSAtNSAtNjkgLTMxIC0xMzIgLTU3IC02MyAtMjcgLTEzNSAtNjAKLTE2MCAtNzQgLTI1IC0xNCAtNTIgLTI5IC02MCAtMzMgLTggLTQgLTI4IC0xNiAtNDUgLTI3IC0xNiAtMTAgLTQ5IC0yOSAtNzEKLTQxIC0zOCAtMTkgLTIyMiAtMTUzIC0yOTkgLTIxNyAtNjkgLTU2IC0yNDUgLTIzMyAtMzAwIC0zMDEgLTEwMyAtMTI2IC0xNzcKLTIyNSAtMTkzIC0yNTggLTkgLTE4IC0xOSAtMzMgLTI0IC0zMyAtNCAwIC04IC0yNTggLTggLTU3MyBsMCAtNTc0IDI1IC0xMQpjMzggLTE3IDIwNDYgLTE3IDIwNjMgMCA5IDkgMTIgMjg0IDEyIDExNzYgbDAgMTE2NCAyMTggLTQgYzExOSAtMyAyNDIgLTEwCjI3MiAtMTcgMzAgLTYgODkgLTE5IDEzMCAtMjcgNDEgLTggOTUgLTIxIDEyMCAtMjggMjUgLTggNzIgLTIyIDEwNSAtMzEgNTUKLTE2IDExOSAtNDAgMjUyIC05NCA3OSAtMzIgMjUxIC0xMjMgMzM0IC0xNzYgNDEgLTI2IDg1IC01NCA5OSAtNjMgNTEgLTMxCjI1NyAtMjAyIDMzMSAtMjc0IDE1NyAtMTUyIDM0MSAtMzg3IDQxOSAtNTMzIDYgLTExIDE5IC0zMyAzMCAtNTAgMTEgLTE2IDI0Ci0zOSAyOSAtNTEgNSAtMTIgMzMgLTY5IDYxIC0xMjggMjkgLTU5IDU2IC0xMjAgNjAgLTEzNCA1IC0xNSAxOCAtNTIgMzAgLTgyCjEyIC0zMCAyNCAtNjQgMjYgLTc1IDMgLTExIDExIC00MiAxOSAtNzAgNDkgLTE3OCA1OCAtMjE5IDgwIC0zODQgOCAtNTYgMjAKLTEwOSAyNiAtMTE3IDEwIC0xMiAxNjggLTE0IDEwMzggLTEyIGwxMDI2IDMgMyA1NCBjMyA1NyAtMzIgMzg3IC00OCA0NTYgLTUKMjIgLTEwIDU1IC0xMCA3NCAwIDMzIC0xOCAxMjEgLTQyIDIwNiAtNiAyMiAtMTUgNTggLTE5IDgwIC0zMCAxNTAgLTYzIDI2NAotMTM0IDQ2MCAtMjAgNTUgLTQwIDExNCAtNDUgMTMwIC05IDMzIC0yNyA3NiAtNzIgMTc1IC0xNyAzNiAtNDEgOTAgLTU1IDEyMAotNjMgMTQwIC0xMzcgMjgxIC0xODMgMzUwIC02IDggLTEzIDIyIC0xNyAzMCAtNTkgMTMwIC0zNjEgNTQ5IC01MTEgNzEwIC0xMwoxNCAtNDMgNTAgLTY3IDgwIC00NCA1NSAtMzE1IDMxOSAtMzk3IDM4NiAtODMgNjggLTg5IDc1IC04NiA4OCAyIDcgNDEgNDYgODgKODYgMjM4IDIwOCA1NjAgNTU1IDY5NyA3NTEgMjggNDEgODIgMTE3IDExOSAxNjkgMzcgNTIgNzYgMTEyIDg4IDEzMyAxMiAyMQoyNiA0NiAzMSA1NSA2IDkgMzUgNjAgNjUgMTEyIDMwIDUyIDYwIDEwNCA2NyAxMTUgMTYgMjggNTggMTE0IDg5IDE4MyA0OSAxMDgKODYgMTg3IDk2IDIwNiAxMiAyMiA2NiAxNjkgNzggMjExIDUgMTcgMjUgNzUgNDUgMTMwIDM4IDEwNSA2MSAxODMgNzQgMjUwIDQKMjIgMTMgNjAgMjAgODUgNDAgMTQ0IDcxIDI4NSA3MSAzMTcgMCAxNSA2IDY0IDE0IDEwOCAyMCAxMDkgNDYgMzQ3IDQ2IDQxNSAwCjMxIC01IDYxIC0xMiA2OCAtMTggMTggLTIwMjcgMTcgLTIwNTEgMCAtMTMgLTEwIC0yMSAtNDIgLTMxIC0xMTggLTIzIC0xNzIKLTM4IC0yNDUgLTgxIC0zOTAgLTggLTI1IC0xNyAtNjAgLTIwIC03NyAtNCAtMTggLTExIC0zNSAtMTYgLTM4IC01IC00IC05Ci0xMyAtOSAtMjIgMCAtOCAtNiAtMjkgLTE0IC00NiAtNyAtMTggLTIxIC01MiAtMzEgLTc3IC0zMyAtODcgLTEyMCAtMjU2Ci0xODcgLTM2NyAtMTYyIC0yNzAgLTM4NCAtNTEzIC02NTAgLTcxMyAtNTkgLTQ0IC0xMTAgLTgwIC0xMTIgLTgwIC0zIDAgLTMzCi0xOSAtNjggLTQzIC02OCAtNDYgLTI0OCAtMTQwIC0zMzggLTE3NyAtMzAgLTEyIC02OCAtMjggLTg1IC0zNSAtNjUgLTI4Ci0xMDMgLTQxIC0yNzAgLTg4IC0yNyAtOCAtODggLTIyIC0xMzUgLTMxIC00NyAtMTAgLTEwNyAtMjIgLTEzNSAtMjggLTI3IC02Ci0xNDMgLTEzIC0yNTcgLTE2IGwtMjA4IC00IDAgMTE3MSAwIDExNzEgLTI2IDEwIGMtMTYgNiAtMzk4IDEwIC0xMDIyIDEwCi05MjIgLTEgLTk5OSAtMiAtMTAyNCAtMTh6Ii8+CjwvZz4KPC9zdmc+Cg==");
}
.brand-word {
  width: 132px; height: 18px; color: var(--green-dark);
  -webkit-mask-position: left center; mask-position: left center;
  -webkit-mask-image: url("data:image/svg+xml;base64,PHN2ZyB2ZXJzaW9uPSIxLjAiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIKIHZpZXdCb3g9IjAgMCAxNTgxLjAwMDAwMCAyMTYuMDAwMDAwIgogcHJlc2VydmVBc3BlY3RSYXRpbz0ieE1pZFlNaWQgbWVldCI+CjxnIHRyYW5zZm9ybT0idHJhbnNsYXRlKDAuMDAwMDAwLDIxNi4wMDAwMDApIHNjYWxlKDAuMTAwMDAwLC0wLjEwMDAwMCkiCmZpbGw9IiMwMDAwMDAiIHN0cm9rZT0ibm9uZSI+CjxwYXRoIGQ9Ik0yOCAyMTM1IGMtMTcgLTIyIC0xOCAtODkgLTE4IC0xMDU5IGwwIC0xMDM1IDIyIC0xNSBjMzEgLTIyIDM4OQotMjQgNDA3IC0zIDcgMTAgMTIgMTQyIDEzIDQyOCBsMyA0MTQgNDcgLTIgYzEwMCAtMyAyNzQgLTYwIDM2MyAtMTE5IDg5IC01OQoxNjggLTEyOCAyMjIgLTE5NCAyOSAtMzYgNTMgLTY4IDUzIC03MiAwIC00IDE0IC0yNyAzMCAtNTEgMTcgLTI1IDMwIC01MiAzMAotNjAgMCAtOSA0IC0xOCA5IC0yMSAyMCAtMTMgNDUgLTExNCA2OCAtMjcxIDMgLTIyIDEyIC00NiAyMSAtNTIgMjIgLTE4IDM4MwotMTggNDAwIC0xIDE3IDE3IDE0IDk4IC04IDIxOCAtNjEgMzI5IC0yMTMgNTg0IC00NzIgNzk0IC0yNyAyMSAtNDggNDQgLTQ4CjUxIDAgNyAyOCAzNiA2MyA2MyA4NCA2OCAxNjIgMTUxIDIzMyAyNDcgNzkgMTA4IDk5IDE0MyAxNTYgMjc0IDU2IDEyOSAxMDIKMzkzIDgyIDQ2OSAtNiAyMiAtNyAyMiAtMjAzIDIyIC0yMjkgMCAtMjEwIDEwIC0yMzEgLTEyMCAtMzkgLTI0NSAtMTQ4IC00MjcKLTM0MCAtNTY5IC02MSAtNDYgLTIwNiAtMTIxIC0yMzMgLTEyMSAtNiAwIC0zMSAtNyAtNTUgLTE1IC0yMyAtOCAtNzUgLTE2Ci0xMTUgLTE3IGwtNzIgLTMgLTUgNDEwIGMtMyAyMjYgLTkgNDE2IC0xMyA0MjMgLTYgOSAtNTcgMTIgLTIwMCAxMiAtMTkxIC0xCi0xOTIgLTEgLTIwOSAtMjV6Ii8+CjxwYXRoIGQ9Ik0zMDA1IDIxNDQgYy0xNzkgLTM1IC0yMjUgLTQ3IC0yOTUgLTc3IC0zMDUgLTEyOCAtNTQxIC0zOTEgLTYyNAotNjk3IC01OCAtMjEzIC01OCAtMzQwIDIgLTU4MCAzNSAtMTQ2IDE0MiAtMzMxIDI2MSAtNDUzIDY0IC02NiAyNzUgLTIxNyAzMDMKLTIxNyA4IDAgMTggLTQgMjMgLTkgMTQgLTEzIDg1IC0zOCAxODAgLTYzIDE1OCAtNDIgNDg2IC0yNyA2MTIgMjggMTcgOCAzNAoxNCAzOCAxNCAxNiAwIDE0NyA3MiAyMTcgMTE5IDE5NSAxMzMgMzgyIDQwMyA0MTggNjA1IDUgMjYgMTQgNjMgMjAgODIgMTggNTUKMTUgMzA5IC01IDM5NSAtMzggMTYzIC03OCAyNTcgLTE2MyAzODMgLTE0OSAyMjEgLTM5MyAzOTEgLTYzMiA0NDAgLTI0NCA1MQotMjQ3IDUxIC0zNTUgMzB6IG0yNzUgLTQ1MyBjMTc5IC01MSAzNDQgLTE5NiA0MTkgLTM2NiAyNCAtNTQgNTEgLTE4NSA1MQotMjQ2IDAgLTg1IC0zMyAtMjE2IC03MSAtMjc5IC01IC04IC0xMiAtMjIgLTE2IC0zMCAtMTIgLTI3IC05MCAtMTI0IC0xMjQKLTE1NSAtMzIwIC0yODYgLTgxOCAtMTg0IC05OTYgMjA1IC03MiAxNTYgLTcyIDM2OCAtMSA1MjUgNjkgMTU1IDIzMiAyOTQgNDAzCjM0NSA4NCAyNiAyNDkgMjYgMzM1IDF6Ii8+CjxwYXRoIGQ9Ik00NTI0IDIxMzUgYy0xMiAtMTYgLTE0IC0xOTAgLTE0IC0xMDU3IGwwIC0xMDM3IDIyIC0xNSBjMTggLTEzIDU0Ci0xNiAxOTMgLTE1IDkzIDEgMTgxIDQgMTk1IDggbDI1IDcgNSAzODkgNSAzOTAgNDE1IDUgYzQwMSA1IDQxNyA2IDQ3OSAyOQoxMDkgMzggMTYzIDcyIDIzNyAxNDUgMTEyIDExMiAxNzEgMjM2IDE5NSA0MDYgMzQgMjUxIC03NiA1MTAgLTI3MiA2NDAgLTE2NQoxMDkgLTI3OCAxMjQgLTk3MyAxMjUgLTQ4NSAwIC00OTkgLTEgLTUxMiAtMjB6IG0xMTk5IC00NDIgYzkyIC01MSAxMjcgLTExMAoxMjcgLTIxNyAwIC0xMjEgLTUyIC0xOTUgLTE2MSAtMjI5IC00NyAtMTUgLTk2IC0xNyAtMzk0IC0xNSBsLTM0MCAzIC0zIDIyNQpjLTEgMTIzIDAgMjMwIDIgMjM3IDQgMTAgODQgMTMgMzcyIDEzIDMyOCAwIDM2OSAtMiAzOTcgLTE3eiIvPgo8cGF0aCBkPSJNNjY0MCAyMTQwIGMtNyAtMTIgLTkgLTk0IC04IC0yMjIgbDMgLTIwMyAzMzQgLTMgYzI1MyAtMiAzMzcgLTUKMzQzIC0xNSA0IC02IDggLTM4MyA4IC04MzggMCAtNjI4IDMgLTgyOCAxMiAtODM3IDE1IC0xNSAzNzUgLTE3IDM5OCAtMiAxMyA4CjE2IDExNyAyMCA4NDcgbDUgODM4IDMzNSA1IDMzNSA1IDMgMjAzIGMxIDEyOCAtMSAyMTAgLTggMjIyIC0xMSAyMCAtMjUgMjAKLTg5MCAyMCAtODY1IDAgLTg3OSAwIC04OTAgLTIweiIvPgo8cGF0aCBkPSJNOTAwMiAxMDk4IGwzIC0xMDYzIDIyMCAwIDIyMCAwIDMgMTA2MyAyIDEwNjIgLTIyNSAwIC0yMjUgMCAyCi0xMDYyeiIvPgo8cGF0aCBkPSJNMTA5NjAgMjE0NCBjLTEyNiAtMjQgLTIxMyAtNDUgLTI1NSAtNjEgLTMwNiAtMTE5IC01MTggLTMyOCAtNjM4Ci02MjggLTU3IC0xNDMgLTg0IC0zOTEgLTU2IC01MjcgNDMgLTIxMSA3MiAtMjg3IDE2OCAtNDMzIDE1MSAtMjMxIDM3NyAtMzg5CjY0NiAtNDUxIDExOSAtMjggNDAwIC0yNiA1MDUgNCAyNDIgNjggNDM4IDE5OCA1NzggMzgyIDYzIDgzIDY5IDkyIDExOSAxOTIKMTkgMzggMzMgNzkgMzEgOTEgLTMgMjEgLTQ4IDQzIC0xMzMgNjcgLTE2IDUgLTU1IDE4IC04NSAzMCAtMzAgMTIgLTY5IDI1Ci04NSAyOSAtMTcgNCAtNDAgMTMgLTUxIDE5IC0yNiAxNCAtNDYgLTYgLTg0IC04MyAtMTQgLTI4IC02MyAtODggLTExMCAtMTM2Ci02NyAtNjcgLTEwMSAtOTMgLTE2MCAtMTIxIC0xMTMgLTU0IC0xMzYgLTYwIC0yNTAgLTY1IC04NSAtNCAtMTIwIC0xIC0xODAKMTUgLTExMyAzMCAtMjE2IDg5IC0yOTggMTcxIC00MyA0MiAtMTIyIDE1NiAtMTIyIDE3NCAwIDcgLTUgMTggLTEwIDIzIC02IDYKLTIwIDQ4IC0zMCA5MyAtNjEgMjUyIDI4IDUwMiAyMzMgNjU2IDEyMCA4OSAyMjkgMTI1IDM4MyAxMjUgMTE0IDAgMTY5IC0xMwoyODQgLTY4IDkzIC00NCAyMTkgLTE2NiAyNjYgLTI1NyAyNSAtNTAgMzUgLTYwIDU1IC01OSAyMSAyIDEwNyAzMSAyNTkgODggMjUKMTAgNjAgMjIgNzggMjcgNDEgMTMgNDEgMzMgMiAxMTAgLTg0IDE2NyAtMTcxIDI2OSAtMzM1IDM5NiAtOTkgNzcgLTM1MSAxODMKLTQzNCAxODMgLTIwIDAgLTYzIDcgLTk2IDE1IC03MyAxNyAtOTkgMTcgLTE5NSAtMXoiLz4KPHBhdGggZD0iTTEzMTU1IDIxNDQgYy0zMyAtOCAtOTEgLTIxIC0xMzAgLTMwIC0yMDcgLTQ4IC00MjYgLTIyNiAtNTI3IC00MjkKLTg2IC0xNzMgLTgxIC0xMjAgLTg1IC05MzAgLTQgLTY3NSAtMyAtNzIwIDEzIC03MzIgMjYgLTE5IDM4NyAtMTggNDAzIDAgNyA5CjEyIDg2IDEzIDIxMyBsMyAxOTkgNDA1IDAgNDA1IDAgMyAtMTk1IGMyIC0xODUgMyAtMTk2IDIzIC0yMTIgMTggLTE2IDQ0IC0xOAoxOTQgLTE4IDk2IDAgMTg1IDQgMTk5IDEwIGwyNiAxMCAtMiA2OTIgYy0zIDU0MSAtNiA3MDYgLTE3IDc1MyAtNTkgMjU5IC0yMzMKNDc5IC00NjcgNTkwIC03MSAzMyAtMTY5IDY1IC0yMDMgNjUgLTE0IDAgLTUxIDcgLTgxIDE1IC02NiAxOCAtOTYgMTggLTE3NQotMXogbTI2NSAtNDcxIGM5NCAtNDMgMTYzIC0xMTQgMjE0IC0yMTggMTggLTM2IDIwIC02OCAyNCAtMjk5IDIgLTE1MyAwIC0yNjIKLTUgLTI2NyAtMTEgLTExIC03ODcgLTE0IC04MDMgLTQgLTYgNCAtMTAgOTggLTEwIDIzMyAwIDE5NCAzIDIzNyAxOSAyOTQgMzgKMTMyIDEzMCAyMjkgMjY1IDI3OSA4MCAyOSAyMTEgMjIgMjk2IC0xOHoiLz4KPHBhdGggZD0iTTE0NDQyIDIxNDAgYy05IC0xNSAtMTIgLTI1MCAtMTIgLTEwNjUgbDAgLTEwNDUgMjYgLTEwIGMyOCAtMTEKMTMxMSAtMTQgMTMzOCAtNCAxNCA1IDE2IDM0IDE2IDIyMCBsMCAyMTQgLTQ2NyAyIC00NjggMyAtMyA4MzQgYy0yIDc1OSAtNAo4MzYgLTE5IDg1MyAtMTQgMTYgLTM1IDE4IC0yMDcgMTggLTE4MCAwIC0xOTIgLTEgLTIwNCAtMjB6Ii8+CjwvZz4KPC9zdmc+Cg=="); mask-image: url("data:image/svg+xml;base64,PHN2ZyB2ZXJzaW9uPSIxLjAiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIKIHZpZXdCb3g9IjAgMCAxNTgxLjAwMDAwMCAyMTYuMDAwMDAwIgogcHJlc2VydmVBc3BlY3RSYXRpbz0ieE1pZFlNaWQgbWVldCI+CjxnIHRyYW5zZm9ybT0idHJhbnNsYXRlKDAuMDAwMDAwLDIxNi4wMDAwMDApIHNjYWxlKDAuMTAwMDAwLC0wLjEwMDAwMCkiCmZpbGw9IiMwMDAwMDAiIHN0cm9rZT0ibm9uZSI+CjxwYXRoIGQ9Ik0yOCAyMTM1IGMtMTcgLTIyIC0xOCAtODkgLTE4IC0xMDU5IGwwIC0xMDM1IDIyIC0xNSBjMzEgLTIyIDM4OQotMjQgNDA3IC0zIDcgMTAgMTIgMTQyIDEzIDQyOCBsMyA0MTQgNDcgLTIgYzEwMCAtMyAyNzQgLTYwIDM2MyAtMTE5IDg5IC01OQoxNjggLTEyOCAyMjIgLTE5NCAyOSAtMzYgNTMgLTY4IDUzIC03MiAwIC00IDE0IC0yNyAzMCAtNTEgMTcgLTI1IDMwIC01MiAzMAotNjAgMCAtOSA0IC0xOCA5IC0yMSAyMCAtMTMgNDUgLTExNCA2OCAtMjcxIDMgLTIyIDEyIC00NiAyMSAtNTIgMjIgLTE4IDM4MwotMTggNDAwIC0xIDE3IDE3IDE0IDk4IC04IDIxOCAtNjEgMzI5IC0yMTMgNTg0IC00NzIgNzk0IC0yNyAyMSAtNDggNDQgLTQ4CjUxIDAgNyAyOCAzNiA2MyA2MyA4NCA2OCAxNjIgMTUxIDIzMyAyNDcgNzkgMTA4IDk5IDE0MyAxNTYgMjc0IDU2IDEyOSAxMDIKMzkzIDgyIDQ2OSAtNiAyMiAtNyAyMiAtMjAzIDIyIC0yMjkgMCAtMjEwIDEwIC0yMzEgLTEyMCAtMzkgLTI0NSAtMTQ4IC00MjcKLTM0MCAtNTY5IC02MSAtNDYgLTIwNiAtMTIxIC0yMzMgLTEyMSAtNiAwIC0zMSAtNyAtNTUgLTE1IC0yMyAtOCAtNzUgLTE2Ci0xMTUgLTE3IGwtNzIgLTMgLTUgNDEwIGMtMyAyMjYgLTkgNDE2IC0xMyA0MjMgLTYgOSAtNTcgMTIgLTIwMCAxMiAtMTkxIC0xCi0xOTIgLTEgLTIwOSAtMjV6Ii8+CjxwYXRoIGQ9Ik0zMDA1IDIxNDQgYy0xNzkgLTM1IC0yMjUgLTQ3IC0yOTUgLTc3IC0zMDUgLTEyOCAtNTQxIC0zOTEgLTYyNAotNjk3IC01OCAtMjEzIC01OCAtMzQwIDIgLTU4MCAzNSAtMTQ2IDE0MiAtMzMxIDI2MSAtNDUzIDY0IC02NiAyNzUgLTIxNyAzMDMKLTIxNyA4IDAgMTggLTQgMjMgLTkgMTQgLTEzIDg1IC0zOCAxODAgLTYzIDE1OCAtNDIgNDg2IC0yNyA2MTIgMjggMTcgOCAzNAoxNCAzOCAxNCAxNiAwIDE0NyA3MiAyMTcgMTE5IDE5NSAxMzMgMzgyIDQwMyA0MTggNjA1IDUgMjYgMTQgNjMgMjAgODIgMTggNTUKMTUgMzA5IC01IDM5NSAtMzggMTYzIC03OCAyNTcgLTE2MyAzODMgLTE0OSAyMjEgLTM5MyAzOTEgLTYzMiA0NDAgLTI0NCA1MQotMjQ3IDUxIC0zNTUgMzB6IG0yNzUgLTQ1MyBjMTc5IC01MSAzNDQgLTE5NiA0MTkgLTM2NiAyNCAtNTQgNTEgLTE4NSA1MQotMjQ2IDAgLTg1IC0zMyAtMjE2IC03MSAtMjc5IC01IC04IC0xMiAtMjIgLTE2IC0zMCAtMTIgLTI3IC05MCAtMTI0IC0xMjQKLTE1NSAtMzIwIC0yODYgLTgxOCAtMTg0IC05OTYgMjA1IC03MiAxNTYgLTcyIDM2OCAtMSA1MjUgNjkgMTU1IDIzMiAyOTQgNDAzCjM0NSA4NCAyNiAyNDkgMjYgMzM1IDF6Ii8+CjxwYXRoIGQ9Ik00NTI0IDIxMzUgYy0xMiAtMTYgLTE0IC0xOTAgLTE0IC0xMDU3IGwwIC0xMDM3IDIyIC0xNSBjMTggLTEzIDU0Ci0xNiAxOTMgLTE1IDkzIDEgMTgxIDQgMTk1IDggbDI1IDcgNSAzODkgNSAzOTAgNDE1IDUgYzQwMSA1IDQxNyA2IDQ3OSAyOQoxMDkgMzggMTYzIDcyIDIzNyAxNDUgMTEyIDExMiAxNzEgMjM2IDE5NSA0MDYgMzQgMjUxIC03NiA1MTAgLTI3MiA2NDAgLTE2NQoxMDkgLTI3OCAxMjQgLTk3MyAxMjUgLTQ4NSAwIC00OTkgLTEgLTUxMiAtMjB6IG0xMTk5IC00NDIgYzkyIC01MSAxMjcgLTExMAoxMjcgLTIxNyAwIC0xMjEgLTUyIC0xOTUgLTE2MSAtMjI5IC00NyAtMTUgLTk2IC0xNyAtMzk0IC0xNSBsLTM0MCAzIC0zIDIyNQpjLTEgMTIzIDAgMjMwIDIgMjM3IDQgMTAgODQgMTMgMzcyIDEzIDMyOCAwIDM2OSAtMiAzOTcgLTE3eiIvPgo8cGF0aCBkPSJNNjY0MCAyMTQwIGMtNyAtMTIgLTkgLTk0IC04IC0yMjIgbDMgLTIwMyAzMzQgLTMgYzI1MyAtMiAzMzcgLTUKMzQzIC0xNSA0IC02IDggLTM4MyA4IC04MzggMCAtNjI4IDMgLTgyOCAxMiAtODM3IDE1IC0xNSAzNzUgLTE3IDM5OCAtMiAxMyA4CjE2IDExNyAyMCA4NDcgbDUgODM4IDMzNSA1IDMzNSA1IDMgMjAzIGMxIDEyOCAtMSAyMTAgLTggMjIyIC0xMSAyMCAtMjUgMjAKLTg5MCAyMCAtODY1IDAgLTg3OSAwIC04OTAgLTIweiIvPgo8cGF0aCBkPSJNOTAwMiAxMDk4IGwzIC0xMDYzIDIyMCAwIDIyMCAwIDMgMTA2MyAyIDEwNjIgLTIyNSAwIC0yMjUgMCAyCi0xMDYyeiIvPgo8cGF0aCBkPSJNMTA5NjAgMjE0NCBjLTEyNiAtMjQgLTIxMyAtNDUgLTI1NSAtNjEgLTMwNiAtMTE5IC01MTggLTMyOCAtNjM4Ci02MjggLTU3IC0xNDMgLTg0IC0zOTEgLTU2IC01MjcgNDMgLTIxMSA3MiAtMjg3IDE2OCAtNDMzIDE1MSAtMjMxIDM3NyAtMzg5CjY0NiAtNDUxIDExOSAtMjggNDAwIC0yNiA1MDUgNCAyNDIgNjggNDM4IDE5OCA1NzggMzgyIDYzIDgzIDY5IDkyIDExOSAxOTIKMTkgMzggMzMgNzkgMzEgOTEgLTMgMjEgLTQ4IDQzIC0xMzMgNjcgLTE2IDUgLTU1IDE4IC04NSAzMCAtMzAgMTIgLTY5IDI1Ci04NSAyOSAtMTcgNCAtNDAgMTMgLTUxIDE5IC0yNiAxNCAtNDYgLTYgLTg0IC04MyAtMTQgLTI4IC02MyAtODggLTExMCAtMTM2Ci02NyAtNjcgLTEwMSAtOTMgLTE2MCAtMTIxIC0xMTMgLTU0IC0xMzYgLTYwIC0yNTAgLTY1IC04NSAtNCAtMTIwIC0xIC0xODAKMTUgLTExMyAzMCAtMjE2IDg5IC0yOTggMTcxIC00MyA0MiAtMTIyIDE1NiAtMTIyIDE3NCAwIDcgLTUgMTggLTEwIDIzIC02IDYKLTIwIDQ4IC0zMCA5MyAtNjEgMjUyIDI4IDUwMiAyMzMgNjU2IDEyMCA4OSAyMjkgMTI1IDM4MyAxMjUgMTE0IDAgMTY5IC0xMwoyODQgLTY4IDkzIC00NCAyMTkgLTE2NiAyNjYgLTI1NyAyNSAtNTAgMzUgLTYwIDU1IC01OSAyMSAyIDEwNyAzMSAyNTkgODggMjUKMTAgNjAgMjIgNzggMjcgNDEgMTMgNDEgMzMgMiAxMTAgLTg0IDE2NyAtMTcxIDI2OSAtMzM1IDM5NiAtOTkgNzcgLTM1MSAxODMKLTQzNCAxODMgLTIwIDAgLTYzIDcgLTk2IDE1IC03MyAxNyAtOTkgMTcgLTE5NSAtMXoiLz4KPHBhdGggZD0iTTEzMTU1IDIxNDQgYy0zMyAtOCAtOTEgLTIxIC0xMzAgLTMwIC0yMDcgLTQ4IC00MjYgLTIyNiAtNTI3IC00MjkKLTg2IC0xNzMgLTgxIC0xMjAgLTg1IC05MzAgLTQgLTY3NSAtMyAtNzIwIDEzIC03MzIgMjYgLTE5IDM4NyAtMTggNDAzIDAgNyA5CjEyIDg2IDEzIDIxMyBsMyAxOTkgNDA1IDAgNDA1IDAgMyAtMTk1IGMyIC0xODUgMyAtMTk2IDIzIC0yMTIgMTggLTE2IDQ0IC0xOAoxOTQgLTE4IDk2IDAgMTg1IDQgMTk5IDEwIGwyNiAxMCAtMiA2OTIgYy0zIDU0MSAtNiA3MDYgLTE3IDc1MyAtNTkgMjU5IC0yMzMKNDc5IC00NjcgNTkwIC03MSAzMyAtMTY5IDY1IC0yMDMgNjUgLTE0IDAgLTUxIDcgLTgxIDE1IC02NiAxOCAtOTYgMTggLTE3NQotMXogbTI2NSAtNDcxIGM5NCAtNDMgMTYzIC0xMTQgMjE0IC0yMTggMTggLTM2IDIwIC02OCAyNCAtMjk5IDIgLTE1MyAwIC0yNjIKLTUgLTI2NyAtMTEgLTExIC03ODcgLTE0IC04MDMgLTQgLTYgNCAtMTAgOTggLTEwIDIzMyAwIDE5NCAzIDIzNyAxOSAyOTQgMzgKMTMyIDEzMCAyMjkgMjY1IDI3OSA4MCAyOSAyMTEgMjIgMjk2IC0xOHoiLz4KPHBhdGggZD0iTTE0NDQyIDIxNDAgYy05IC0xNSAtMTIgLTI1MCAtMTIgLTEwNjUgbDAgLTEwNDUgMjYgLTEwIGMyOCAtMTEKMTMxMSAtMTQgMTMzOCAtNCAxNCA1IDE2IDM0IDE2IDIyMCBsMCAyMTQgLTQ2NyAyIC00NjggMyAtMyA4MzQgYy0yIDc1OSAtNAo4MzYgLTE5IDg1MyAtMTQgMTYgLTM1IDE4IC0yMDcgMTggLTE4MCAwIC0xOTIgLTEgLTIwNCAtMjB6Ii8+CjwvZz4KPC9zdmc+Cg==");
}

.nav-menu { display: flex; align-items: center; gap: .35rem; }
.nav-menu > li > a, .nav-trigger {
  display: inline-flex; align-items: center; gap: .35em;
  padding: .55em .9em; border-radius: var(--r-pill); font-weight: 600; font-size: .98rem;
  color: var(--ink); transition: background .25s var(--ease), color .25s var(--ease);
}
.nav-menu > li > a:hover, .nav-trigger:hover, .nav-item.open .nav-trigger { background: var(--green-50); color: var(--green-dark); }
.nav-trigger .caret { transition: transform .3s var(--ease); font-size: .7em; }
.nav-item.open .nav-trigger .caret { transform: rotate(180deg); }

/* Dropdown produits */
.nav-item { position: relative; }
.dropdown {
  position: absolute; top: calc(100% + .6rem); left: 50%; transform: translateX(-50%) translateY(8px);
  width: min(92vw, 640px); padding: 1.1rem; border-radius: var(--r-lg);
  background: var(--surface); box-shadow: var(--sh-3); border: 1px solid var(--line);
  display: grid; grid-template-columns: 1fr 1fr; gap: .3rem;
  opacity: 0; visibility: hidden; transition: opacity .3s var(--ease), transform .3s var(--ease); z-index: var(--z-dropdown);
}
.nav-item.open .dropdown { opacity: 1; visibility: visible; transform: translateX(-50%) translateY(0); }
.dropdown--col { grid-template-columns: 1fr; width: min(92vw, 330px); }
.dropdown a { display: flex; flex-direction: column; gap: .1rem; padding: .7rem .85rem; border-radius: var(--r-md); transition: background .2s var(--ease); }
.dropdown a:hover { background: var(--mauve-50); }
.dropdown a strong { font-weight: 700; color: var(--green-dark); }
.dropdown a span { font-size: var(--fs-300); color: var(--ink-soft); }

.nav-cta { display: flex; align-items: center; gap: .6rem; }
.nav-cta-mobile { display: none; } /* CTA "Accès opticiens" : seulement dans le menu mobile */
/* Le CTA mobile reste violet à texte blanc, même au survol (sur-spécifie .nav-menu>li>a) */
.nav-cta-mobile .btn--primary { color: #fff; }
.nav-cta-mobile .btn--primary:hover { color: #fff; background: var(--mauve-900); }
.nav-burger { display: none; width: 46px; height: 46px; border-radius: var(--r-md); align-items: center; justify-content: center; }
.nav-burger span, .nav-burger span::before, .nav-burger span::after {
  content: ""; display: block; width: 22px; height: 2px; background: var(--ink); border-radius: 2px; transition: transform .3s var(--ease), opacity .3s var(--ease); position: relative;
}
.nav-burger span::before { position: absolute; top: -7px; }
.nav-burger span::after { position: absolute; top: 7px; }
body.nav-open .nav-burger span { background: transparent; }
body.nav-open .nav-burger span::before { transform: translateY(7px) rotate(45deg); }
body.nav-open .nav-burger span::after { transform: translateY(-7px) rotate(-45deg); }

/* ---------- 11. HERO (Editorial Split) ---------- */
.hero { position: relative; }
.hero-grid {
  display: grid; grid-template-columns: 1.05fr .95fr; align-items: stretch;
  border-radius: var(--r-xl); overflow: clip; box-shadow: var(--sh-3);
  min-height: clamp(460px, 72vh, 760px);
}
.hero-panel {
  position: relative; padding: clamp(2rem, 4.5vw, 4rem);
  display: flex; flex-direction: column; justify-content: center; gap: 1.5rem;
}
.hero-panel .v-label {
  position: absolute; top: clamp(2rem,4.5vw,4rem); right: clamp(1rem,2vw,1.6rem);
  writing-mode: vertical-rl; font-size: var(--fs-300); font-weight: 700; letter-spacing: .35em;
  color: var(--green-light); text-transform: uppercase;
}
.hero h1 { font-size: var(--fs-900); max-width: 14ch; }
.hero h1 em { font-style: normal; color: var(--green-light); }
.hero-panel p { font-size: var(--fs-500); color: var(--on-dark-soft); max-width: 46ch; }
.hero-actions { display: flex; flex-wrap: wrap; gap: .9rem; margin-top: .4rem; }
.hero-media { position: relative; }
.hero-media img { width: 100%; height: 100%; object-fit: cover; filter: grayscale(1) contrast(1.05); }
.hero-meta {
  display: flex; gap: clamp(1.5rem,4vw,3.5rem); margin-top: 2.4rem; flex-wrap: wrap;
}
.hero-meta .stat { display: flex; flex-direction: column; }
.hero-meta .stat b { font-size: clamp(1.6rem,2.6vw,2.3rem); font-weight: 800; color: #fff; letter-spacing: -.03em; }
.hero-meta .stat span { font-size: var(--fs-300); color: var(--green-light); }

/* ---------- 12. MARQUEE ---------- */
.marquee { overflow: hidden; border-block: 1px solid var(--line); padding-block: 1.3rem; -webkit-mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent); mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent); }
.marquee-track { display: flex; gap: 3.5rem; width: max-content; animation: marquee 38s linear infinite; }
.marquee:hover .marquee-track { animation-play-state: paused; }
.marquee-track span { display: inline-flex; align-items: center; gap: .6rem; font-weight: 700; font-size: 1.05rem; color: var(--ink-soft); white-space: nowrap; }
.marquee-track span::before { content: "»"; color: var(--green); }
@keyframes marquee { to { transform: translateX(-50%); } }
@media (prefers-reduced-motion: reduce) { .marquee-track { animation: none; } }

/* ---------- 13. BENTO ---------- */
.bento { display: grid; grid-template-columns: repeat(12, 1fr); grid-auto-rows: minmax(196px, auto); gap: 16px; grid-auto-flow: dense; }
.tile { position: relative; border-radius: var(--r-lg); overflow: hidden; display: flex; flex-direction: column; justify-content: flex-end; padding: 1.6rem; min-height: 196px; transition: transform .5s var(--ease); isolation: isolate; }
.tile:hover { transform: translateY(-4px); }
.tile h3 { font-size: var(--fs-600); }
.tile p { font-size: var(--fs-300); margin-top: .3rem; }
.tile .tile-count { font-size: var(--fs-200); font-weight: 800; letter-spacing: .04em; opacity: .85; }
.tile .ic-go { position: absolute; top: 1.2rem; right: 1.2rem; width: 38px; height: 38px; border-radius: var(--r-pill); display: grid; place-items: center; background: rgba(255,255,255,.16); transition: background .3s var(--ease), transform .3s var(--ease); }
.tile:hover .ic-go { background: rgba(255,255,255,.3); transform: translate(3px,-3px); }

.tile--photo { color: #fff; }
.tile--photo::before { content: ""; position: absolute; inset: 0; z-index: -2; }
.tile--photo img { position: absolute; inset: 0; z-index: -3; width: 100%; height: 100%; object-fit: cover; object-position: center 26%; filter: grayscale(1) contrast(1.05); transition: transform 1.1s var(--ease); }
.tile--photo:hover img { transform: scale(1.07); }
.tile--photo::after { content: ""; position: absolute; inset: 0; z-index: -1; background: linear-gradient(180deg, rgba(47,74,64,.05) 30%, rgba(27,33,30,.82)); }

.tile--green { background: var(--green-cta); color: #fff; }
.tile--green-dark { background: var(--green-dark); color: #fff; }
.tile--mauve { background: var(--mauve); color: #fff; }
.tile--mauve-light { background: var(--mauve-light); color: #4c3543; }
.tile--green-soft { background: var(--green-50); color: var(--green-dark); }
.tile--green-soft h3 { color: var(--green-dark); }
.tile--paper { background: var(--surface); color: var(--ink); border: 1px solid var(--line); }
.tile--paper h3 { color: var(--green-dark); }

.b-half { grid-column: span 6; }   /* moitié — tuiles vedettes (haut du bento) */
.b-third { grid-column: span 4; }  /* tiers — 3 colonnes égales sur les 2 dernières lignes */
.row-2 { grid-row: span 2; }

/* ---------- 14. FEATURE (techno) ---------- */
.feature { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(1.5rem, 4vw, 4rem); align-items: center; }
.feature .media { border-radius: var(--r-xl); aspect-ratio: 4/5; box-shadow: var(--sh-3); }
.tech-list { display: grid; grid-template-columns: 1fr 1fr; gap: .7rem 1.4rem; margin-top: 1.8rem; }
.tech-list li { display: flex; align-items: flex-start; gap: .6rem; font-weight: 600; font-size: var(--fs-300); }
.tech-list li::before { content: "»"; color: var(--green); font-weight: 800; }

/* ---------- 15. CARDS Espace porteur ---------- */
.cards-3 { display: grid; grid-template-columns: repeat(auto-fit, minmax(270px, 1fr)); gap: clamp(1rem, 2.5vw, 1.8rem); }
.pcard { background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-xl); overflow: hidden; display: flex; flex-direction: column; transition: transform .5s var(--ease), box-shadow .5s var(--ease); }
.pcard:hover { transform: translateY(-6px); box-shadow: var(--sh-2); }
.pcard .media { aspect-ratio: 16/11; }
.pcard-body { padding: 1.5rem 1.6rem 1.8rem; display: flex; flex-direction: column; gap: .6rem; flex: 1; }
.pcard-body h3 { font-size: var(--fs-600); color: var(--green-dark); }
.pcard-body p { color: var(--ink-soft); font-size: var(--fs-300); flex: 1; }
/* Accents Espace porteur — déclinaison verte (3 nuances) + lien d'action en violet */
.pcard { --accent: var(--green-cta); --duo: var(--accent); --duo-rest: .24; --duo-hover: .5; }
.pcard--green  { --accent: var(--green-cta); }
.pcard--forest { --accent: var(--green-dark); }
.pcard--deep   { --accent: var(--green-900); }
.pcard-eyebrow { align-self: flex-start; font-size: var(--fs-200); font-weight: 800; letter-spacing: .08em; text-transform: uppercase; color: #fff; background: var(--accent); padding: .32em .8em; border-radius: var(--r-pill); }
.pcard .link-arrow { color: var(--mauve-900); margin-top: auto; }

/* Section Espace porteur : kicker en vert (tout vert sauf le lien d'action) */
.section--porteur .kicker { color: var(--green-dark); }

/* ---------- 15b. PRODUITS (grille catégorie) ---------- */
.prod-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: clamp(1rem, 2vw, 1.5rem); }
.prod {
  display: flex; flex-direction: column; gap: .7rem;
  background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-lg);
  padding: 1.6rem 1.7rem 1.7rem; transition: transform .5s var(--ease), box-shadow .5s var(--ease), border-color .5s var(--ease);
}
.prod:hover { transform: translateY(-6px); box-shadow: var(--sh-2); border-color: transparent; }
.prod h3 { font-size: var(--fs-700); color: var(--green-dark); }
.prod > p { color: var(--ink-soft); font-size: var(--fs-300); flex: 1; }
.prod .link-arrow { margin-top: .4rem; }
.prod--feature { padding: 0; overflow: hidden; }
.prod--feature .media { aspect-ratio: 16/10; }
.prod--feature .prod-body { padding: 1.5rem 1.7rem 1.7rem; display: flex; flex-direction: column; gap: .7rem; flex: 1; }
.prod-tags { display: flex; flex-wrap: wrap; gap: .4rem; }
.tag { display: inline-block; padding: .3em .8em; border-radius: var(--r-pill); background: var(--green-50); color: var(--green-dark); font-size: var(--fs-200); font-weight: 700; }
.tag--mauve { background: var(--mauve-50); color: var(--mauve-900); }

/* ---------- 16. CTA BAND ---------- */
.cta-band { position: relative; overflow: hidden; border-radius: var(--r-xl); padding: clamp(2.4rem, 6vw, 4.5rem); color: #fff; }
.cta-band h2 { font-size: var(--fs-800); max-width: 18ch; }
.cta-band p { color: var(--on-dark-soft); max-width: 52ch; margin-top: 1rem; font-size: var(--fs-500); }
/* Bande CTA texte + actions : 2 colonnes desktop, empilées en mobile */
.cta-grid { display: grid; grid-template-columns: 1.3fr auto; gap: 2rem; align-items: center; }
@media (max-width: 760px) { .cta-grid { grid-template-columns: 1fr; gap: 1.5rem; } }

/* ---------- 17. FOOTER ---------- */
.site-footer { background: var(--green-900); color: var(--on-dark-soft); padding-block: clamp(3.5rem, 7vw, 5.5rem) 2rem; }
.footer-grid { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: 2.5rem 1.5rem; }
/* Footer : logo complet empilé (koptical-logo.svg) — K centré au-dessus du mot,
   proportions et espacements du fichier d'origine. On masque le mot et on affiche
   le logo entier à la place du « K ». */
.site-footer .brand-word { display: none; }
.site-footer .brand-mark {
  width: 150px; height: auto; aspect-ratio: 1581 / 1110;
  -webkit-mask-image: none; mask-image: none;
  background: url("../img/koptical-logo-footer.svg") center / contain no-repeat;
}
.footer-col h4 { font-size: var(--fs-300); letter-spacing: .04em; text-transform: uppercase; color: var(--green-light); margin-bottom: 1rem; }
.footer-col a { display: block; padding: .28rem 0; color: var(--on-dark-soft); transition: color .2s var(--ease); }
.footer-col a:hover { color: #fff; }
.footer-bottom { display: flex; justify-content: space-between; gap: 1rem; flex-wrap: wrap; margin-top: 3rem; padding-top: 1.6rem; border-top: 1px solid var(--on-dark-border); font-size: var(--fs-300); color: var(--on-dark-faint); }

/* ---------- 18. BREADCRUMB / PAGE HEAD ---------- */
.page-head { position: relative; padding-block: clamp(2.5rem, 6vw, 4.5rem); }
.crumb { display: flex; gap: .5rem; font-size: var(--fs-300); color: var(--ink-soft); margin-bottom: 1rem; flex-wrap: wrap; }
.crumb a:hover { color: var(--green-dark); }
.crumb .sep { color: var(--green); }
.page-head h1 { font-size: var(--fs-800); max-width: 20ch; }
.page-head p { color: var(--ink-soft); font-size: var(--fs-500); margin-top: 1rem; max-width: 62ch; }
/* Contraste sur fond sombre : le texte clair l'emporte sur --ink-soft (AA : 4.71:1) */
.page-head.on-dark p, .on-dark .page-head p { color: var(--on-dark-soft); }
.on-dark .section-head p { color: var(--on-dark-soft); }
.page-head.on-dark .crumb a:hover { color: #fff; }

/* ---------- 18c. CAT HERO — entête catégorie allégée + photo en dégradé ---------- */
.cat-hero { position: relative; overflow: hidden; min-height: clamp(320px, 42vw, 440px); display: flex; align-items: center; }
.cat-hero > img { position: absolute; inset: 0; z-index: -2; width: 100%; height: 100%; object-fit: cover; object-position: center 26%; filter: grayscale(1) contrast(1.05); }
.cat-hero::after { content: ""; position: absolute; inset: 0; z-index: -1; background: linear-gradient(105deg, var(--green-900) 6%, rgba(47,74,64,.88) 46%, rgba(47,74,64,.32) 100%); }
.cat-hero__inner { padding-block: clamp(2.4rem, 5vw, 3.8rem); color: var(--on-dark); }
.cat-hero h1 { font-size: var(--fs-800); max-width: 16ch; margin-top: .5rem; }
.cat-hero p { color: var(--on-dark-soft); font-size: var(--fs-500); margin-top: 1rem; max-width: 52ch; }
.cat-hero .crumb { color: var(--on-dark-faint); margin-bottom: .4rem; }
.cat-hero .crumb a:hover { color: #fff; }
.cat-hero .crumb .sep { color: var(--green-light); }
.cat-hero .kicker { color: var(--green-light); }

/* ---------- 18b. FICHE PRODUIT ---------- */
.fiche-tabs { display: flex; flex-wrap: wrap; gap: .6rem; margin-top: .6rem; }
.fiche-sub { color: var(--green-light); font-weight: 700; letter-spacing: .12em; text-transform: uppercase; font-size: var(--fs-300); }
/* fil d'ariane sur le panneau sombre du hero fiche */
.fiche-crumb { display: flex; gap: .5rem; flex-wrap: wrap; font-size: var(--fs-300); color: var(--on-dark-faint); margin-bottom: .3rem; }
.fiche-crumb a:hover { color: #fff; }
.fiche-crumb .sep { color: var(--green-light); }
/* « En bref » + « Points forts » : 2 panneaux alignés (même hauteur, même retrait) */
.fiche-essentiel { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(1.1rem, 2.5vw, 1.7rem); align-items: stretch; }
.info-panel, .plus-panel { padding: clamp(1.5rem, 3vw, 2.1rem); border-radius: var(--r-xl); border: 1px solid var(--line); }
.info-panel { background: var(--surface); }
.plus-panel { background: var(--green-50); }
.info-panel h3, .plus-panel h3 { font-size: var(--fs-600); color: var(--green-dark); margin-bottom: 1rem; }
.info-panel .lead { font-size: var(--fs-500); color: var(--ink); }
.info-panel .lead + p { margin-top: .75rem; color: var(--ink-soft); font-size: var(--fs-400); }
.plus-panel ul { display: grid; gap: .85rem; }
.plus-panel li { display: flex; gap: .75rem; align-items: flex-start; font-weight: 600; color: var(--ink); }
.plus-panel li::before { content: "✓"; flex: none; width: 23px; height: 23px; border-radius: 50%; background: var(--green); color: #fff; font-size: .78rem; font-weight: 800; display: grid; place-items: center; margin-top: 1px; }
@media (max-width: 760px) { .fiche-essentiel { grid-template-columns: 1fr; } }

/* bandeau « inclus / garanties » — éléments communs à toutes les fiches (fond sombre) */
.facts-3 { display: grid; grid-template-columns: repeat(auto-fit, minmax(210px, 1fr)); gap: 1.1rem; margin-top: 1.9rem; }
.fact { background: var(--on-dark-surface); border: 1px solid var(--on-dark-border); border-radius: var(--r-lg); padding: 1.5rem 1.6rem; }
.fact b { display: block; font-size: var(--fs-700); color: #fff; letter-spacing: -.02em; }
.fact span { display: block; margin-top: .4rem; color: var(--on-dark-soft); font-size: var(--fs-300); line-height: 1.5; }
.fiche-defer { margin-top: 1.9rem; padding-top: 1.5rem; border-top: 1px solid var(--on-dark-border); color: var(--on-dark-soft); font-size: var(--fs-300); }
.fiche-defer a { color: var(--green-light); font-weight: 700; }
.fiche-defer a:hover { color: #fff; }

.tagline {
  position: relative; border-radius: var(--r-xl); padding: clamp(1.8rem, 4vw, 3rem) clamp(1.8rem, 4vw, 3.4rem);
  background: var(--mauve-light); color: var(--mauve-900);
}
.tagline q { font-size: var(--fs-700); font-weight: 800; letter-spacing: -.02em; quotes: "«" "»"; line-height: 1.12; display: block; max-width: 24ch; }
.tagline q::before { content: "» "; color: var(--green-dark); }

.duo-col { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(1.5rem, 4vw, 3rem); }
.info-block h3 { font-size: var(--fs-600); color: var(--green-dark); margin-bottom: .9rem; }
.info-block p { color: var(--ink-soft); }
.info-block ul { display: grid; gap: .6rem; margin-top: 1rem; }
.info-block li { display: flex; gap: .6rem; align-items: flex-start; }
.info-block li::before { content: "»"; color: var(--green); font-weight: 800; flex: none; }

.spec-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1.2rem; margin-top: 2.5rem; }
.spec { background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-lg); overflow: hidden; }
.spec h4 { background: var(--green-dark); color: #fff; padding: .75rem 1.2rem; font-size: var(--fs-300); letter-spacing: .02em; }
.spec dl { margin: 0; padding: .5rem 1.2rem 1rem; }
.spec div { display: flex; justify-content: space-between; gap: 1rem; padding: .6rem 0; border-bottom: 1px solid var(--line); font-size: var(--fs-300); }
.spec div:last-child { border-bottom: none; }
.spec dt { color: var(--ink-soft); }
.spec dd { margin: 0; font-weight: 700; text-align: right; }

.tech-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(210px, 1fr)); gap: .8rem; margin-top: 1.5rem; }
.tech-chip { display: flex; align-items: center; gap: .7rem; padding: 1rem 1.1rem; border-radius: var(--r-md); background: var(--on-dark-surface); border: 1px solid var(--on-dark-border); font-weight: 600; font-size: var(--fs-300); }
.tech-chip .dot { width: 10px; height: 10px; border-radius: 50%; background: var(--green-light); flex: none; }

.garantie-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1.2rem; }
.garantie { background: var(--green-50); border-radius: var(--r-lg); padding: 1.6rem 1.7rem; }
.garantie b { display: block; font-size: var(--fs-700); color: var(--green-dark); letter-spacing: -.02em; }
.garantie span { color: var(--ink-soft); font-size: var(--fs-300); }

@media (max-width: 760px) { .duo-col, .spec-grid, .garantie-grid { grid-template-columns: 1fr; } }

/* ---------- 19. TABLE compatibilités ---------- */
.compat { width: 100%; border-collapse: separate; border-spacing: 0; font-size: var(--fs-300); }
.compat th, .compat td { padding: .7rem .8rem; text-align: center; }
.compat thead th { background: var(--green-dark); color: #fff; font-weight: 700; }
.compat thead th:first-child { background: transparent; }
.compat tbody th { text-align: left; font-weight: 600; color: var(--ink); background: var(--surface); }
.compat tbody tr:nth-child(even) th, .compat tbody tr:nth-child(even) td { background: var(--green-50); }
.compat .yes { color: var(--green-dark); font-weight: 800; }
.compat .no { color: #c8d3cb; }
.compat-group { display: flex; align-items: center; gap: .7rem; margin: 2rem 0 .8rem; }
.compat-group .pill { pointer-events: none; }

/* ---------- 20. LIMITES (barres Ø/Cyl) ---------- */
.limit-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); gap: 1.1rem; }
.limit-card { background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-md); padding: 1rem 1.1rem 1.2rem; }
.limit-card h4 { background: var(--green-dark); color: #fff; font-size: var(--fs-300); text-align: center; padding: .45rem; border-radius: var(--r-sm); margin-bottom: .8rem; font-weight: 700; }
.limit-head, .limit-row { display: grid; grid-template-columns: 46px 30px 1fr 30px 22px; align-items: center; gap: .45rem; font-size: var(--fs-200); }
.limit-head { color: var(--ink-soft); font-weight: 700; padding-bottom: .35rem; border-bottom: 1px solid var(--line); margin-bottom: .35rem; }
.limit-head span:nth-child(3) { text-align: center; }
.limit-row { padding: .28rem 0; }
.limit-row .o { font-weight: 700; }
.limit-row .neg, .limit-row .pos { color: var(--ink-soft); font-variant-numeric: tabular-nums; }
.limit-row .pos { text-align: right; }
.limit-row .cyl { text-align: right; font-weight: 700; color: var(--green-dark); }
.limit-row .bar { height: 7px; border-radius: var(--r-pill); background: var(--green-light); position: relative; }
.limit-row .bar i { position: absolute; top: 0; height: 100%; border-radius: var(--r-pill); background: var(--green-dark); }

/* ---------- 21. FORM ---------- */
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1.1rem; }
.field { display: flex; flex-direction: column; gap: .4rem; }
.field.full { grid-column: 1 / -1; }
.field label { font-weight: 700; font-size: var(--fs-300); }
.field input, .field select, .field textarea {
  font: inherit; padding: .85em 1em; border-radius: var(--r-md); border: 1.5px solid var(--line); background: var(--surface); color: var(--ink);
  transition: border-color .25s var(--ease), box-shadow .25s var(--ease);
}
.field input::placeholder, .field textarea::placeholder { color: #677470; }
.field input:focus, .field select:focus, .field textarea:focus { outline: none; border-color: var(--green); box-shadow: 0 0 0 4px rgba(111,162,135,.18); }
.field textarea { resize: vertical; min-height: 130px; }

/* ---------- 22. TIMELINE / STEPS ---------- */
.steps { display: grid; gap: 1.1rem; }
.step { display: grid; grid-template-columns: 64px 1fr; gap: 1.2rem; align-items: start; background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-lg); padding: 1.4rem 1.5rem; }
.step .n { width: 56px; height: 56px; border-radius: var(--r-pill); display: grid; place-items: center; background: var(--green-dark); color: #fff; font-weight: 800; font-size: 1.3rem; }
.step h3 { font-size: var(--fs-600); color: var(--green-dark); }
.step p { color: var(--ink-soft); font-size: var(--fs-300); margin-top: .3rem; }

/* do / don't */
.dd { display: grid; grid-template-columns: 1fr 1fr; gap: 1.4rem; }
.dd ul { display: grid; gap: .7rem; }
.dd li { display: flex; gap: .7rem; align-items: flex-start; font-size: var(--fs-400); }
.dd .yes::before { content: "✓"; color: #fff; background: var(--green); width: 24px; height: 24px; border-radius: 50%; display: grid; place-items: center; font-size: .8rem; font-weight: 800; flex: none; }
.dd .no::before  { content: "✕"; color: #fff; background: var(--mauve); width: 24px; height: 24px; border-radius: 50%; display: grid; place-items: center; font-size: .8rem; font-weight: 800; flex: none; }

/* ---------- 22b. FAQ (accordéon natif) ---------- */
.faq { display: grid; gap: .8rem; max-width: 56rem; }
.faq details { background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-md); overflow: hidden; transition: box-shadow .3s var(--ease); }
.faq details[open] { box-shadow: var(--sh-1); }
.faq summary { list-style: none; cursor: pointer; padding: 1.1rem 1.3rem; font-weight: 700; display: flex; justify-content: space-between; gap: 1rem; align-items: center; color: var(--green-dark); }
.faq summary::-webkit-details-marker { display: none; }
.faq summary::after { content: "+"; font-size: 1.4rem; color: var(--green); transition: transform .3s var(--ease); line-height: 1; }
.faq details[open] summary::after { transform: rotate(45deg); }
.faq details p { padding: 0 1.3rem 1.2rem; color: var(--ink-soft); }

/* ---------- 22c. ORDONNANCE ---------- */
.ordo { background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-lg); overflow: hidden; box-shadow: var(--sh-2); }
.ordo table { width: 100%; border-collapse: collapse; }
.ordo th, .ordo td { padding: .95rem 1rem; text-align: center; border-bottom: 1px solid var(--line); }
.ordo thead th { background: var(--green-dark); color: #fff; font-weight: 700; font-size: var(--fs-300); }
.ordo tbody th { text-align: left; background: var(--green-50); color: var(--green-dark); font-weight: 800; }
.ordo td b { color: var(--ink); font-variant-numeric: tabular-nums; }
.ordo caption { caption-side: top; text-align: left; padding: 1.1rem 1.2rem; font-weight: 800; color: var(--green-dark); background: var(--mauve-50); }
.legend { display: grid; gap: .8rem; }
.legend-item { display: grid; grid-template-columns: auto 1fr; gap: 1rem; align-items: start; }
.legend-item .key { background: var(--mauve); color: #fff; font-weight: 800; font-size: var(--fs-300); padding: .45rem .8rem; border-radius: var(--r-pill); white-space: nowrap; }
.legend-item p { color: var(--ink-soft); font-size: var(--fs-300); }
.legend-item strong { color: var(--green-dark); }

/* ---------- 22d. CARTES TÉLÉCHARGEMENT (Espace pro) ---------- */
.dl-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 1.1rem; }
.dl-card { display: flex; flex-direction: column; gap: .5rem; background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-lg); padding: 1.5rem 1.6rem; transition: transform .4s var(--ease), box-shadow .4s var(--ease); }
.dl-card:hover { transform: translateY(-5px); box-shadow: var(--sh-2); }
.dl-card .ext { align-self: flex-start; background: var(--mauve-light); color: var(--mauve-900); font-weight: 800; font-size: var(--fs-200); padding: .3em .7em; border-radius: var(--r-sm); letter-spacing: .04em; }
.dl-card h3 { font-size: var(--fs-600); color: var(--green-dark); }
.dl-card p { color: var(--ink-soft); font-size: var(--fs-300); flex: 1; }

/* ---------- 22e. LOGIN (Espace pro) ---------- */
.login-card { background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-xl); padding: clamp(1.8rem, 4vw, 2.6rem); box-shadow: var(--sh-2); }
.login-card h2 { font-size: var(--fs-700); color: var(--green-dark); }

/* ---------- 22f. CONTACT INFO ---------- */
.contact-grid { display: grid; grid-template-columns: 1.2fr .9fr; gap: clamp(1.5rem, 4vw, 3rem); align-items: start; }
.info-line { display: grid; grid-template-columns: 40px 1fr; gap: .9rem; align-items: start; padding: 1rem 0; border-bottom: 1px solid var(--line); }
.info-line .ico { width: 40px; height: 40px; border-radius: var(--r-pill); background: var(--green-50); color: var(--green-dark); display: grid; place-items: center; font-weight: 800; }
.info-line h4 { font-size: var(--fs-400); color: var(--green-dark); }
.info-line p { color: var(--ink-soft); font-size: var(--fs-300); }
.map-embed { border-radius: var(--r-lg); overflow: hidden; border: 1px solid var(--line); aspect-ratio: 16/10; background:
  repeating-linear-gradient(45deg, var(--green-50) 0 14px, #fff 14px 28px); display: grid; place-items: center; color: var(--green-dark); font-weight: 700; position: relative; }
.map-embed::after { content: "»"; }
@media (max-width: 820px) { .contact-grid { grid-template-columns: 1fr; } }

/* ---------- 23. REVEAL (motion subtil) ----------
   Le contenu est VISIBLE par défaut. On ne masque que si JS est actif
   (classe .js sur <html>) → aucune section ne reste blanche sans JS,
   en lecteur headless, ou si le script échoue. */
html.js .reveal { opacity: 0; transform: translateY(26px); transition: opacity .8s var(--ease), transform .8s var(--ease); }
html.js .reveal.in { opacity: 1; transform: none; }
.reveal[data-d="1"] { transition-delay: .08s; }
.reveal[data-d="2"] { transition-delay: .16s; }
.reveal[data-d="3"] { transition-delay: .24s; }
.reveal[data-d="4"] { transition-delay: .32s; }
@media (prefers-reduced-motion: reduce) {
  .reveal { opacity: 1; transform: none; transition: none; }
  .btn, .tile, .pcard, .media img { transition: none !important; }
}

/* ---------- 24. RESPONSIVE ---------- */
@media (max-width: 1080px) {
  .footer-grid { grid-template-columns: 1.4fr 1fr 1fr; }
}
@media (max-width: 900px) {
  .hero-grid { grid-template-columns: 1fr; min-height: 0; }
  .hero-media { aspect-ratio: 4/3; order: -1; }
  .hero-panel .v-label { display: none; }
  .feature { grid-template-columns: 1fr; }
  .feature .media { aspect-ratio: 16/10; max-height: 420px; }
  .bento { grid-template-columns: repeat(6, 1fr); }
  .b-half { grid-column: span 6; }
  .b-third { grid-column: span 2; }
  .row-2 { grid-row: span 1; }
  .dd, .form-grid { grid-template-columns: 1fr; }
  .footer-grid { grid-template-columns: 1fr 1fr; }

  .nav-menu, .nav-cta .btn { display: none; }
  .nav-burger { display: flex; }
  .nav-menu.mobile-open {
    display: flex; flex-direction: column; align-items: stretch; gap: .2rem;
    position: fixed; inset: 64px 0 auto 0; z-index: var(--z-backdrop);
    background: var(--surface); padding: 1rem var(--gutter) 1.6rem; box-shadow: var(--sh-3);
  }
  .nav-menu.mobile-open > li > a, .nav-menu.mobile-open .nav-trigger { width: 100%; justify-content: space-between; font-size: 1.1rem; padding: .9em 1em; }
  .nav-menu.mobile-open .dropdown { position: static; transform: none; opacity: 1; visibility: visible; width: 100%; box-shadow: none; border: none; background: var(--green-50); grid-template-columns: 1fr; margin-top: .3rem; display: none; }
  .nav-menu.mobile-open .nav-item.open .dropdown { display: grid; }
  .nav-menu.mobile-open .nav-cta-mobile { display: block; margin-top: .6rem; padding-top: .9rem; border-top: 1px solid var(--line); }
  .nav-menu.mobile-open .nav-cta-mobile .btn { display: flex; width: 100%; justify-content: center; gap: .4em; }
}
@media (max-width: 560px) {
  .bento { grid-template-columns: 1fr; }
  .b-half, .b-third, .row-2 { grid-column: span 1; }
  .tech-list, .footer-grid { grid-template-columns: 1fr; }
  .compat-wrap { overflow-x: auto; }
  .compat { min-width: 560px; }
}
