/* ===== FONTS (self-hosted via jsDelivr CDN) ===== */
/* vietnamese */
@font-face {
  font-family: 'Bricolage Grotesque';
  font-style: normal;
  font-weight: 500;
  font-stretch: 100%;
  font-display: swap;
  src: url(../assets/fonts/f0.woff2) format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Bricolage Grotesque';
  font-style: normal;
  font-weight: 500;
  font-stretch: 100%;
  font-display: swap;
  src: url(../assets/fonts/f1.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Bricolage Grotesque';
  font-style: normal;
  font-weight: 500;
  font-stretch: 100%;
  font-display: swap;
  src: url(../assets/fonts/f2.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* vietnamese */
@font-face {
  font-family: 'Bricolage Grotesque';
  font-style: normal;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url(../assets/fonts/f0.woff2) format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Bricolage Grotesque';
  font-style: normal;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url(../assets/fonts/f1.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Bricolage Grotesque';
  font-style: normal;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url(../assets/fonts/f2.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* vietnamese */
@font-face {
  font-family: 'Bricolage Grotesque';
  font-style: normal;
  font-weight: 700;
  font-stretch: 100%;
  font-display: swap;
  src: url(../assets/fonts/f0.woff2) format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Bricolage Grotesque';
  font-style: normal;
  font-weight: 700;
  font-stretch: 100%;
  font-display: swap;
  src: url(../assets/fonts/f1.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Bricolage Grotesque';
  font-style: normal;
  font-weight: 700;
  font-stretch: 100%;
  font-display: swap;
  src: url(../assets/fonts/f2.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* vietnamese */
@font-face {
  font-family: 'Bricolage Grotesque';
  font-style: normal;
  font-weight: 800;
  font-stretch: 100%;
  font-display: swap;
  src: url(../assets/fonts/f0.woff2) format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Bricolage Grotesque';
  font-style: normal;
  font-weight: 800;
  font-stretch: 100%;
  font-display: swap;
  src: url(../assets/fonts/f1.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Bricolage Grotesque';
  font-style: normal;
  font-weight: 800;
  font-stretch: 100%;
  font-display: swap;
  src: url(../assets/fonts/f2.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Geist Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(../assets/fonts/f3.woff2) format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Geist Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(../assets/fonts/f4.woff2) format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* symbols2 */
@font-face {
  font-family: 'Geist Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(../assets/fonts/f5.woff2) format('woff2');
  unicode-range: U+2000-2001, U+2004-2008, U+200A, U+23B8-23BD, U+2500-259F;
}
/* vietnamese */
@font-face {
  font-family: 'Geist Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(../assets/fonts/f6.woff2) format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Geist Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(../assets/fonts/f7.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Geist Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(../assets/fonts/f8.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Geist Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(../assets/fonts/f3.woff2) format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Geist Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(../assets/fonts/f4.woff2) format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* symbols2 */
@font-face {
  font-family: 'Geist Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(../assets/fonts/f5.woff2) format('woff2');
  unicode-range: U+2000-2001, U+2004-2008, U+200A, U+23B8-23BD, U+2500-259F;
}
/* vietnamese */
@font-face {
  font-family: 'Geist Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(../assets/fonts/f6.woff2) format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Geist Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(../assets/fonts/f7.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Geist Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(../assets/fonts/f8.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Geist Mono';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(../assets/fonts/f3.woff2) format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Geist Mono';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(../assets/fonts/f4.woff2) format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* symbols2 */
@font-face {
  font-family: 'Geist Mono';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(../assets/fonts/f5.woff2) format('woff2');
  unicode-range: U+2000-2001, U+2004-2008, U+200A, U+23B8-23BD, U+2500-259F;
}
/* vietnamese */
@font-face {
  font-family: 'Geist Mono';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(../assets/fonts/f6.woff2) format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Geist Mono';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(../assets/fonts/f7.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Geist Mono';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(../assets/fonts/f8.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(../assets/fonts/f9.woff2) format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* vietnamese */
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(../assets/fonts/f10.woff2) format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(../assets/fonts/f11.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(../assets/fonts/f12.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(../assets/fonts/f9.woff2) format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* vietnamese */
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(../assets/fonts/f10.woff2) format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(../assets/fonts/f11.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(../assets/fonts/f12.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(../assets/fonts/f9.woff2) format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* vietnamese */
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(../assets/fonts/f10.woff2) format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(../assets/fonts/f11.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(../assets/fonts/f12.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(../assets/fonts/f9.woff2) format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* vietnamese */
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(../assets/fonts/f10.woff2) format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(../assets/fonts/f11.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(../assets/fonts/f12.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url(../assets/fonts/f9.woff2) format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* vietnamese */
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url(../assets/fonts/f10.woff2) format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url(../assets/fonts/f11.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url(../assets/fonts/f12.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* vietnamese */
@font-face {
  font-family: 'Newsreader';
  font-style: italic;
  font-weight: 400;
  font-display: swap;
  src: url(../assets/fonts/f13.woff2) format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Newsreader';
  font-style: italic;
  font-weight: 400;
  font-display: swap;
  src: url(../assets/fonts/f14.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Newsreader';
  font-style: italic;
  font-weight: 400;
  font-display: swap;
  src: url(../assets/fonts/f15.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* vietnamese */
@font-face {
  font-family: 'Newsreader';
  font-style: italic;
  font-weight: 500;
  font-display: swap;
  src: url(../assets/fonts/f13.woff2) format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Newsreader';
  font-style: italic;
  font-weight: 500;
  font-display: swap;
  src: url(../assets/fonts/f14.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Newsreader';
  font-style: italic;
  font-weight: 500;
  font-display: swap;
  src: url(../assets/fonts/f15.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* vietnamese */
@font-face {
  font-family: 'Newsreader';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(../assets/fonts/f16.woff2) format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Newsreader';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(../assets/fonts/f17.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Newsreader';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(../assets/fonts/f18.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* vietnamese */
@font-face {
  font-family: 'Newsreader';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(../assets/fonts/f16.woff2) format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Newsreader';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(../assets/fonts/f17.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Newsreader';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(../assets/fonts/f18.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* vietnamese */
@font-face {
  font-family: 'Newsreader';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(../assets/fonts/f16.woff2) format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Newsreader';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(../assets/fonts/f17.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Newsreader';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(../assets/fonts/f18.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* vietnamese */
@font-face {
  font-family: 'Space Grotesk';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(../assets/fonts/f19.woff2) format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Space Grotesk';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(../assets/fonts/f20.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Space Grotesk';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(../assets/fonts/f21.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* vietnamese */
@font-face {
  font-family: 'Space Grotesk';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(../assets/fonts/f19.woff2) format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Space Grotesk';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(../assets/fonts/f20.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Space Grotesk';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(../assets/fonts/f21.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* vietnamese */
@font-face {
  font-family: 'Space Grotesk';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(../assets/fonts/f19.woff2) format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Space Grotesk';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(../assets/fonts/f20.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Space Grotesk';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(../assets/fonts/f21.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* vietnamese */
@font-face {
  font-family: 'Space Grotesk';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(../assets/fonts/f19.woff2) format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Space Grotesk';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(../assets/fonts/f20.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Space Grotesk';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(../assets/fonts/f21.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

/* ===== /FONTS ===== */

/* Webmarketing Conseil — feuille de styles combinée (Webflow) */

/* ===== base.css ===== */
/* ============================================================
   BASE — shared structure for all 3 directions
   Visual identity lives in themes.css (scoped by [data-dir])
   ============================================================ */

*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--font-body);
  background: #0c0d0e;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
.site {
  background: var(--bg);
  color: var(--ink);
  min-height: 100vh;
  transition: background-color .5s ease, color .5s ease;
}
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; border: none; background: none; color: inherit; }
::selection { background: var(--accent); color: var(--accent-ink, #fff); }

/* ---- layout primitives ---- */
.wrap { width: min(var(--maxw, 1200px), 100% - var(--gutter, 48px) * 2); margin-inline: auto; }
.wrap--narrow { width: min(840px, 100% - var(--gutter, 48px) * 2); margin-inline: auto; }
.section { padding-block: var(--section-pad, 120px); position: relative; }
.section--tight { padding-block: calc(var(--section-pad, 120px) * .62); }
.grid { display: grid; gap: var(--gap, 32px); }

/* ---- type scale (fluid) ---- */
.display {
  font-family: var(--font-display);
  font-weight: var(--display-weight, 600);
  line-height: var(--display-lh, 1.02);
  letter-spacing: var(--display-ls, -0.02em);
  font-size: clamp(2.6rem, 1.2rem + 5.6vw, 5.6rem);
  margin: 0;
  text-wrap: balance;
}
.h2 {
  font-family: var(--font-display);
  font-weight: var(--display-weight, 600);
  line-height: 1.06;
  letter-spacing: var(--display-ls, -0.02em);
  font-size: clamp(2rem, 1.1rem + 3vw, 3.4rem);
  margin: 0;
  text-wrap: balance;
}
.h3 {
  font-family: var(--font-display);
  font-weight: var(--display-weight, 600);
  line-height: 1.12;
  letter-spacing: -0.01em;
  font-size: clamp(1.4rem, 1rem + 1.4vw, 2rem);
  margin: 0;
}
.eyebrow {
  font-family: var(--font-eyebrow, var(--font-body));
  text-transform: uppercase;
  letter-spacing: 0.22em;
  font-size: .76rem;
  font-weight: 600;
  color: var(--accent);
  display: inline-flex;
  align-items: center;
  gap: .6em;
}
.eyebrow::before {
  content: "";
  width: 1.8em; height: 1px;
  background: currentColor;
  opacity: .8;
}
.lead { font-size: clamp(1.1rem, .95rem + .8vw, 1.45rem); line-height: 1.5; color: var(--muted); max-width: 60ch; text-wrap: pretty; }
.muted { color: var(--muted); }
p { text-wrap: pretty; }

/* ---- buttons ---- */
.btn {
  display: inline-flex; align-items: center; gap: .6em;
  padding: 1em 1.6em;
  font-weight: 600;
  font-size: .98rem;
  border-radius: var(--btn-radius, 999px);
  background: var(--accent);
  color: var(--accent-ink, #fff);
  transition: transform .25s cubic-bezier(.2,.8,.2,1), box-shadow .25s, background-color .25s, color .25s;
  white-space: nowrap;
  line-height: 1;
}
.btn:hover { transform: translateY(-2px); box-shadow: var(--btn-shadow, 0 12px 30px -10px var(--accent)); }
.btn:active { transform: translateY(0); }
.btn .arr { transition: transform .25s; }
.btn:hover .arr { transform: translateX(4px); }
.btn--ghost {
  background: transparent;
  color: var(--ink);
  box-shadow: inset 0 0 0 1px var(--line);
}
.btn--ghost:hover { background: var(--surface-2); box-shadow: inset 0 0 0 1px var(--ink); }
.btn--lg { padding: 1.15em 2em; font-size: 1.05rem; }

/* ---- cards ---- */
.card {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--card-radius, 18px);
  padding: var(--card-pad, 32px);
}

/* ---- generic helpers ---- */
.stack > * + * { margin-top: var(--stack, 1.2rem); }
.center { text-align: center; }
.divider { height: 1px; background: var(--line); border: 0; margin: 0; }
.pill {
  display: inline-flex; align-items: center; gap: .5em;
  padding: .5em .9em; border-radius: 0;
  background: transparent; border: 1.5px solid var(--ink);
  font-family: var(--font-mono); text-transform: uppercase; letter-spacing: .04em;
  font-size: .72rem; font-weight: 500; color: var(--ink-soft, var(--ink));
}

/* ---- reveal on load / scroll ---- */
.reveal { opacity: 1; transform: none; }
.js-anim .reveal { opacity: 0; transform: translateY(22px); }
@media (prefers-reduced-motion: no-preference) {
  .js-anim .reveal { transition: opacity .8s ease, transform .8s cubic-bezier(.2,.8,.2,1); }
}
.js-anim .reveal.in { opacity: 1; transform: none; }
.reveal.d1 { transition-delay: .08s; }
.reveal.d2 { transition-delay: .16s; }
.reveal.d3 { transition-delay: .24s; }
.reveal.d4 { transition-delay: .32s; }
.reveal.d5 { transition-delay: .40s; }

/* ============================================================
   SITE CHROME (the review tool, not part of the site)
   ============================================================ */
.chrome {
  position: fixed; top: 0; left: 0; right: 0; z-index: 1000;
  display: flex; align-items: center; gap: 18px;
  padding: 10px 18px;
  background: rgba(12,13,14,.82);
  backdrop-filter: blur(18px) saturate(1.4);
  -webkit-backdrop-filter: blur(18px) saturate(1.4);
  border-bottom: 1px solid rgba(255,255,255,.1);
  color: #fff;
  font-family: var(--chrome-font, ui-sans-serif, system-ui, sans-serif);
}
.chrome__brand { display: flex; align-items: center; gap: 9px; font-size: .82rem; font-weight: 600; letter-spacing: .01em; color: #fff; }
.chrome__brand .dot { width: 8px; height: 8px; border-radius: 50%; background: #5663ff; box-shadow: 0 0 12px #5663ff; }
.chrome__brand .sub { color: rgba(255,255,255,.5); font-weight: 400; }
.chrome__spacer { flex: 1; }
.chrome__group { display: flex; align-items: center; gap: 8px; }
.chrome__label { font-size: .68rem; text-transform: uppercase; letter-spacing: .16em; color: rgba(255,255,255,.4); margin-right: 2px; }

.seg { display: inline-flex; background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.12); border-radius: 999px; padding: 3px; }
.seg button {
  padding: 7px 14px; border-radius: 999px; font-size: .8rem; font-weight: 600;
  color: rgba(255,255,255,.62); transition: color .2s, background-color .2s; position: relative;
  display: inline-flex; align-items: center; gap: 7px;
}
.seg button .k { font-size: .62rem; opacity: .6; font-weight: 700; }
.seg button[aria-selected="true"] { background: #fff; color: #0A0C0B; }
.seg button[aria-selected="true"] .k { opacity: .5; }
.seg--dir button[aria-selected="true"] { background: var(--accent); color: var(--accent-ink, #fff); }

@media (max-width: 880px) {
  .chrome { gap: 10px; flex-wrap: wrap; padding: 8px 12px; }
  .chrome__brand .sub { display: none; }
  .chrome__label { display: none; }
}

/* push site below chrome */
.site { padding-top: 56px; }
@media (max-width: 880px) { .site { padding-top: 92px; } }

/* deferred images: neutral slot until src is swapped in */
img.lazyimg:not([src]) { background: var(--surface-2); min-height: 40px; }
img.lazyimg { transition: opacity .5s ease; }

/* page panels */
.page { display: none; }
.page.is-active { display: block; }

/* show/hide direction-specific blocks */
[data-dironly] { display: none; }


/* ===== themes.css ===== */
/* ============================================================
   THEME — "L'OPÉRATEUR" · édition signal acide
   One committed direction: warm near-black, paper-white ink,
   one electric acid-lime signal. Editorial grotesque + serif
   italic, monospace micro-labels, sharp corners, hairlines.
   ============================================================ */

:root, .site {
  /* type */
  --font-display: "Bricolage Grotesque", system-ui, sans-serif;
  --font-body: "Hanken Grotesk", system-ui, sans-serif;
  --font-eyebrow: "Geist Mono", ui-monospace, monospace;
  --font-mono: "Geist Mono", ui-monospace, monospace;
  --font-serif: "Newsreader", Georgia, serif;
  --display-weight: 800;
  --display-ls: -0.035em;
  --display-lh: 0.92;

  /* palette — signal is overridable via Tweaks (--accent-pick) */
  --signal: var(--accent-pick, #CBF24A);
  --signal-deep: #9FC72C;
  --signal-ink: #15140C;       /* dark text that sits on signal */

  --bg: #14130D;               /* warm near-black */
  --surface: #1D1B12;          /* lifted card on bg */
  --surface-2: #100F0A;        /* deeper alt-section bg */
  --ink: #F2EEE1;              /* warm paper-white */
  --ink-soft: #D8D3C2;
  --muted: #8F897A;
  --line: rgba(242,238,225,0.13);

  --accent: var(--signal);
  --accent-ink: var(--signal-ink);

  --maxw: 1300px;
  --gutter: 40px;
  --section-pad: 122px;
  --card-radius: 4px;
  --btn-radius: 0px;
  --btn-shadow: none;
}

/* ---- type voice ---- */
.display { font-weight: 800; }
.display em, .h2 em { font-family: var(--font-serif); font-style: italic; font-weight: 400; letter-spacing: -0.01em; color: var(--signal); }
.h2 { font-weight: 800; letter-spacing: -0.03em; }
.h3 { font-weight: 700; }
.lead { color: var(--ink-soft); }

.eyebrow {
  font-family: var(--font-mono); text-transform: uppercase; letter-spacing: .16em;
  font-size: .72rem; font-weight: 500; color: var(--signal);
}
.eyebrow::before { background: var(--signal); height: 2px; width: 2.2em; opacity: 1; }

/* ---- buttons: solid sharp blocks ---- */
.btn { background: var(--signal); color: var(--signal-ink); font-family: var(--font-mono); text-transform: uppercase;
  letter-spacing: .04em; font-size: .82rem; font-weight: 600; border-radius: 0; }
.btn:hover { transform: translateY(-2px); box-shadow: 5px 5px 0 var(--signal-deep); }
.btn--ghost { background: transparent; color: var(--ink); box-shadow: inset 0 0 0 1.5px var(--line); }
.btn--ghost:hover { background: transparent; color: var(--signal); box-shadow: inset 0 0 0 1.5px var(--signal); }
.btn--inv { background: var(--ink); color: var(--bg); }
.btn--inv:hover { box-shadow: 5px 5px 0 var(--signal); }
.btn--lg { padding: 1.15em 1.9em; font-size: .9rem; }
.btn .arr { transition: transform .25s; }

/* a plain underline text link */
.btn-link { font-family: var(--font-mono); text-transform: uppercase; letter-spacing: .08em; font-size: .8rem;
  font-weight: 500; color: inherit; padding-bottom: 3px; border-bottom: 2px solid var(--signal);
  transition: color .2s; }
.btn-link:hover { color: var(--signal); }

/* ============================================================
   SITE NAV
   ============================================================ */
.nav { position: sticky; top: 56px; z-index: 60; padding: 14px 0; background: color-mix(in oklch, var(--bg), transparent 12%);
  backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px); border-bottom: 1px solid var(--line); }
.nav__inner { display: flex; align-items: center; gap: 28px; width: 100%; padding: 4px 0; }
.nav__logo { font-family: var(--font-display); font-weight: 800; font-size: 1.12rem; letter-spacing: -.03em;
  display: flex; align-items: center; gap: 10px; text-transform: uppercase; color: var(--ink); }
.nav__logo .mark { width: 30px; height: 30px; border-radius: 0; background: var(--signal); color: var(--signal-ink);
  display: grid; place-items: center; font-size: .95rem; font-weight: 800; }
.nav__links { display: flex; gap: 26px; margin-left: 16px; font-family: var(--font-mono); font-size: .8rem;
  text-transform: uppercase; letter-spacing: .04em; }
.nav__links a { color: var(--muted); transition: color .2s; }
.nav__links a:hover { color: var(--signal); }
.nav__spacer { flex: 1; }
@media (max-width: 860px) { .nav__links { display: none; } .nav { top: 92px; } }

/* ============================================================
   LOGOS BAND
   ============================================================ */
.logos { display: flex; flex-wrap: wrap; align-items: center; justify-content: center; gap: clamp(28px, 5vw, 64px); }
.logos img { height: 30px; width: auto; opacity: .42; filter: grayscale(1) brightness(0) invert(1); transition: opacity .3s; }
.logos__cap { font-family: var(--font-mono); font-size: .74rem; text-transform: uppercase; letter-spacing: .18em; color: var(--muted); }

/* ============================================================
   STAT
   ============================================================ */
.stat__num { font-family: var(--font-display); font-weight: 800; font-size: clamp(2.8rem, 1.4rem + 4.5vw, 5rem);
  line-height: .96; letter-spacing: -.045em; color: var(--signal); }
.stat__lbl { color: var(--ink-soft); margin-top: .6rem; font-family: var(--font-mono); font-size: .8rem;
  text-transform: uppercase; letter-spacing: .08em; }

/* ============================================================
   FEATURE / BULLET
   ============================================================ */
.tick { display: flex; gap: 14px; align-items: flex-start; }
.tick__mk { flex: none; width: 24px; height: 24px; border-radius: 0; display: grid; place-items: center; margin-top: 3px;
  background: var(--signal); color: var(--signal-ink); font-size: .8rem; font-weight: 700; }

/* ============================================================
   CARD
   ============================================================ */
.card__step { font-family: var(--font-mono); font-size: .8rem; letter-spacing: .12em; color: var(--signal); font-weight: 500; }

/* ============================================================
   TESTIMONIAL
   ============================================================ */
.quote { display: flex; flex-direction: column; gap: 18px; height: 100%; }
.quote__body { font-family: var(--font-serif); font-size: 1.22rem; line-height: 1.42; color: var(--ink); }
.quote__who { display: flex; align-items: center; gap: 12px; margin-top: auto; }
.quote__who img { width: 44px; height: 44px; border-radius: 0; object-fit: cover; filter: grayscale(1); }
.quote__name { font-weight: 700; font-size: .95rem; color: var(--ink); }
.quote__role { color: var(--muted); font-size: .82rem; font-family: var(--font-mono); }
.stars { color: var(--signal); letter-spacing: 2px; font-size: .85rem; }

/* ============================================================
   PRICING
   ============================================================ */
.price__amt { font-family: var(--font-display); font-weight: 800; font-size: 2.7rem; line-height: 1; letter-spacing: -.04em; color: var(--ink); }
.price__name { font-family: var(--font-mono); text-transform: uppercase; letter-spacing: .14em; font-size: .78rem; font-weight: 500; color: var(--muted); }
.price__cap { color: var(--muted); font-size: .9rem; }
.price--featured { position: relative; background: var(--signal); color: var(--signal-ink); border-color: var(--signal); }
.price--featured .price__name { color: color-mix(in oklch, var(--signal-ink), transparent 35%); }
.price--featured .price__amt { color: var(--signal-ink); }
.price--featured .price__cap, .price--featured .muted { color: color-mix(in oklch, var(--signal-ink), transparent 30%); }
.price--featured .tick__mk { background: var(--signal-ink); color: var(--signal); }
.price--featured .divider { background: color-mix(in oklch, var(--signal-ink), transparent 78%); }
.badge-reco { position: absolute; top: -13px; left: 50%; transform: translateX(-50%); padding: .4em 1em; border-radius: 0;
  font-family: var(--font-mono); font-size: .68rem; font-weight: 500; letter-spacing: .12em; text-transform: uppercase;
  background: var(--ink); color: var(--bg); white-space: nowrap; }

/* ============================================================
   CTA BAND  — flooded signal
   ============================================================ */
.cta-band { background: var(--signal); color: var(--signal-ink); }
.cta-band .display, .cta-band .h2 { color: var(--signal-ink); }
.cta-band .display em, .cta-band .h2 em { color: var(--signal-ink); }
.cta-band .lead { color: color-mix(in oklch, var(--signal-ink), transparent 25%); }
.cta-band .eyebrow { color: var(--signal-ink); }
.cta-band .eyebrow::before { background: var(--signal-ink); }
.cta-band .muted { color: color-mix(in oklch, var(--signal-ink), transparent 35%); }
.cta-band .btn { background: var(--signal-ink); color: var(--signal); }
.cta-band .btn:hover { box-shadow: 5px 5px 0 var(--ink); }

/* ============================================================
   FOOTER
   ============================================================ */
.foot { padding-block: 70px 50px; border-top: 1px solid var(--line); background: var(--surface-2); }
.foot__cols { display: flex; flex-wrap: wrap; gap: 40px 80px; justify-content: space-between; }
.foot__h { font-family: var(--font-mono); font-size: .72rem; text-transform: uppercase; letter-spacing: .14em; color: var(--ink); font-weight: 500; margin-bottom: 4px; }
.foot a { color: var(--muted); font-size: .9rem; }
.foot a:hover { color: var(--signal); }

/* ============================================================
   grid helpers
   ============================================================ */
.cols-2 { grid-template-columns: repeat(2, 1fr); }
.cols-3 { grid-template-columns: repeat(3, 1fr); }
.cols-4 { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 900px) { .cols-2, .cols-3, .cols-4 { grid-template-columns: 1fr; } }
@media (min-width: 901px) and (max-width: 1100px) { .cols-4 { grid-template-columns: repeat(2,1fr); } }


/* ===== components.css ===== */
/* ============================================================
   COMPONENTS — section-level pieces (themed via variables)
   ============================================================ */

.mono { font-family: var(--font-mono); }
.hero { padding-top: var(--hero-pad-top, clamp(40px, 5vw, 72px)); padding-bottom: var(--hero-pad-bottom, clamp(44px, 5vw, 76px)); overflow: clip; }
.hero__cta { display: flex; flex-wrap: wrap; gap: 14px; align-items: center; }
.sec-head { max-width: 760px; display: flex; flex-direction: column; gap: 18px; }
.sec-head .lead { margin-top: 4px; }

/* ---- section head numbers / cards ---- */
.card__step { display: inline-block; font-family: var(--font-display); font-weight: var(--display-weight);
  font-size: 1rem; color: var(--accent); letter-spacing: .1em; margin-bottom: 14px; }
.card .h3 { margin-bottom: 10px; }

/* ============ reusable portrait — grayscale + acid plinth ============ */
.portrait { position: relative; overflow: hidden; isolation: isolate; background: var(--surface); }
.portrait img { width: 100%; height: 100%; object-fit: cover; display: block; }
.portrait--halftone img { filter: grayscale(1) contrast(1.08) brightness(.96); }
.portrait--halftone::before { content: ""; position: absolute; inset: 0; z-index: 2; pointer-events: none;
  background-image: radial-gradient(rgba(0,0,0,.55) 26%, transparent 27%); background-size: 5px 5px;
  mix-blend-mode: multiply; opacity: .3; }

/* ============ HERO — dark editorial, type-led + diagnostic ============ */
.hero-main { background: var(--bg); color: var(--ink); overflow: clip; position: relative;
  padding-top: clamp(40px, 5vw, 72px); border-bottom: 1px solid var(--line); }
.hero-main .wrap { position: relative; }
.hero-main__title { font-family: var(--font-display); font-weight: 800; letter-spacing: -.04em; line-height: .95;
  font-size: var(--hero-title-size, clamp(2.5rem, 1rem + 4.8vw, 5.2rem)); margin: 18px 0 0; color: var(--ink); text-wrap: balance; }
.hero-main__title .ital { font-family: var(--font-serif); font-style: italic; font-weight: 400; letter-spacing: -.01em; }
.hero-main__title .hl { color: var(--signal); }
.kicker { font-family: var(--font-mono); text-transform: uppercase; letter-spacing: .14em; font-size: .76rem;
  color: var(--muted); display: inline-flex; align-items: center; gap: .8em; }
.kicker::before { content: ""; width: 26px; height: 2px; background: var(--signal); }

.hero-main__grid { display: grid; grid-template-columns: 1fr minmax(340px, .8fr); gap: clamp(32px, 5vw, 72px);
  align-items: end; padding: clamp(36px, 4vw, 56px) 0 clamp(40px, 4vw, 60px); }
.hero-main__lead { display: flex; flex-direction: column; gap: 26px; }
.hero-main__sub { font-size: clamp(1.05rem, .95rem + .5vw, 1.3rem); line-height: 1.5; color: var(--ink-soft); max-width: 44ch; margin: 0; }
.hero-main__cta { display: flex; flex-wrap: wrap; align-items: center; gap: 22px; }
.hero-main__stats { display: flex; gap: clamp(24px, 4vw, 46px); margin: 6px 0 0; padding-top: 26px;
  border-top: 1px solid var(--line); }
.hero-main__stats div { display: flex; flex-direction: column; gap: 4px; }
.hero-main__stats dt { font-family: var(--font-display); font-weight: 800; font-size: clamp(1.6rem,1.2rem+1.2vw,2.2rem);
  letter-spacing: -.03em; line-height: 1; color: var(--signal); }
.hero-main__stats dd { margin: 0; font-family: var(--font-mono); font-size: .72rem; text-transform: uppercase;
  letter-spacing: .08em; color: var(--muted); }

/* ---- diagnostic: the signature mechanic ---- */
.diag { background: var(--surface); border: 1px solid var(--line); position: relative;
  box-shadow: 8px 8px 0 rgba(0,0,0,.35); display: flex; flex-direction: column; min-height: 360px; }
.diag__top { display: flex; align-items: center; justify-content: space-between; padding: 16px 20px; border-bottom: 1px solid var(--line); }
.diag__label { font-family: var(--font-mono); font-size: .7rem; text-transform: uppercase; letter-spacing: .12em; color: var(--signal);
  display: inline-flex; align-items: center; gap: .55em; }
.diag__label i { width: 8px; height: 8px; border-radius: 50%; background: var(--signal); animation: hpulse 1.6s ease-in-out infinite; }
@keyframes hpulse { 0%,100% { opacity: 1; } 50% { opacity: .25; } }
@media (prefers-reduced-motion: reduce) { .diag__label i { animation: none; } }
.diag__dots { display: flex; gap: 6px; }
.diag__dots span { width: 22px; height: 3px; background: var(--line); transition: background-color .3s; }
.diag__dots span.on { background: var(--signal); }
.diag__body { padding: 22px 20px 24px; display: flex; flex-direction: column; gap: 16px; flex: 1; }
.diag__q { font-family: var(--font-display); font-weight: 700; font-size: 1.32rem; letter-spacing: -.02em; line-height: 1.12; color: var(--ink); }
.diag__opts { display: flex; flex-direction: column; gap: 9px; margin-top: 2px; }
.diag__opt { text-align: left; width: 100%; padding: 13px 15px; background: var(--bg); border: 1px solid var(--line);
  color: var(--ink); font-family: var(--font-body); font-size: .95rem; line-height: 1.3; display: flex; align-items: center; gap: 11px;
  transition: border-color .2s, background-color .2s, transform .15s; }
.diag__opt::before { content: ""; flex: none; width: 16px; height: 16px; border: 1.5px solid var(--muted); border-radius: 50%; transition: border-color .2s, background-color .2s; }
.diag__opt:hover { border-color: var(--signal); transform: translateX(3px); }
.diag__opt:hover::before { border-color: var(--signal); box-shadow: inset 0 0 0 3px var(--signal); }
.diag__hint { font-family: var(--font-mono); font-size: .7rem; letter-spacing: .06em; color: var(--muted); text-transform: uppercase; }

/* diagnostic result state */
.diag__result { display: none; flex-direction: column; gap: 14px; padding: 24px 20px 26px; flex: 1; }
.diag.is-done .diag__body { display: none; }
.diag.is-done .diag__result { display: flex; }
.diag__rk { font-family: var(--font-mono); font-size: .7rem; text-transform: uppercase; letter-spacing: .14em; color: var(--muted); }
.diag__rlever { font-family: var(--font-display); font-weight: 800; font-size: 1.9rem; letter-spacing: -.03em; line-height: 1; color: var(--signal); }
.diag__rdesc { color: var(--ink-soft); font-size: .96rem; line-height: 1.5; }
.diag__result .btn { margin-top: auto; width: 100%; justify-content: center; }
.diag__restart { background: none; border: 0; color: var(--muted); font-family: var(--font-mono); font-size: .7rem; text-transform: uppercase;
  letter-spacing: .1em; padding: 0; align-self: flex-start; text-decoration: underline; }
.diag__restart:hover { color: var(--signal); }

/* kinetic ticker along the bottom of the hero */
.ticker { border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); overflow: hidden; background: var(--bg); }
.ticker__track { display: inline-flex; white-space: nowrap; align-items: center; will-change: transform;
  font-family: var(--font-display); font-weight: 800; font-size: 1.1rem; letter-spacing: -.01em; text-transform: uppercase;
  color: var(--ink); animation: ticker 38s linear infinite; padding: 13px 0; }
.ticker__track span { padding: 0 26px; }
.ticker__track .dot { color: var(--signal); }
@keyframes ticker { to { transform: translateX(-50%); } }
@media (prefers-reduced-motion: reduce) { .ticker__track { animation: none; } }

@media (max-width: 880px) {
  .hero-main__grid { grid-template-columns: 1fr; gap: 34px; align-items: stretch; }
  .diag { min-height: 0; }
}

/* ============ MÉTHODE steps ============ */
.steps { display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; margin-top: 54px; }
.step { background: var(--surface); border: 1px solid var(--line); border-radius: var(--card-radius); padding: 30px; display: flex; flex-direction: column; gap: 12px; }
.step__n { font-family: var(--font-eyebrow, var(--font-body)); font-size: .76rem; text-transform: uppercase; letter-spacing: .16em; color: var(--accent); font-weight: 700; }
.step__list { list-style: none; padding: 0; margin: 8px 0 0; display: flex; flex-direction: column; gap: 9px; }
.step__list li { position: relative; padding-left: 22px; color: var(--muted); font-size: .94rem; }
.step__list li::before { content: ""; position: absolute; left: 0; top: .55em; width: 10px; height: 10px; border-radius: 50%; border: 2px solid var(--accent); }
@media (max-width: 900px) { .steps { grid-template-columns: 1fr; } }

/* ============ stats ============ */
.stats { padding-block: 10px; }

/* ============ quotes ============ */
.quotes { align-items: stretch; }

/* ============ RUDY ============ */
.rudy { display: grid; grid-template-columns: .82fr 1.18fr; gap: clamp(32px,5vw,64px); align-items: center; }
.rudy__media { position: relative; }
.rudy__media .portrait { aspect-ratio: 4/5; border-radius: 0; }
.rudy__media .portrait img { object-position: 52% 16%; }
.rudy__media::before { content: ""; position: absolute; inset: 20px -20px -20px 20px; z-index: -1; background: var(--signal); }
.rudy__text { display: flex; flex-direction: column; gap: 18px; }
.rudy__tags { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 10px; }
@media (max-width: 860px) { .rudy { grid-template-columns: 1fr; } .rudy__media { max-width: 340px; } }

/* ============ CTA band ============ */
.cta-band { position: relative; }

/* ============ COLD hero ============ */
.coldHero { display: grid; grid-template-columns: 1.1fr .9fr; gap: clamp(32px,5vw,60px); align-items: center; }
.coldHero .display { font-family: var(--font-display); font-weight: 800; letter-spacing: -.04em; line-height: .95;
  font-size: var(--hero-title-size, clamp(2.5rem, 1rem + 4.8vw, 5.2rem)); }
.coldHero__text { display: flex; flex-direction: column; gap: 22px; }
.coldHero__meta { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 8px; }
.mailcard { background: var(--surface); border: 1px solid var(--line); border-radius: var(--card-radius); padding: 20px; box-shadow: 8px 8px 0 rgba(0,0,0,.35); }
.mailcard__bar { display: flex; align-items: center; gap: 7px; padding-bottom: 14px; border-bottom: 1px solid var(--line); }
.mailcard__row { display: flex; justify-content: space-between; align-items: center; margin-top: 16px; font-size: .86rem; color: var(--muted); }
.mailcard__tag { font-size: .72rem; font-weight: 700; color: var(--signal); border: 1px solid var(--signal); border-radius: 999px; padding: .2em .7em; }
.mailcard__subj { font-weight: 600; margin-top: 10px; }
.mailcard__body { color: var(--muted); margin-top: 6px; font-size: .92rem; }
.mailcard__stats { display: grid; grid-template-columns: repeat(3,1fr); gap: 10px; margin-top: 20px; padding-top: 16px; border-top: 1px solid var(--line); }
.mailcard__stats > div { display: flex; flex-direction: column; }
.mailcard__stats b { font-family: var(--font-display); font-size: 1.5rem; font-weight: 600; letter-spacing: -.02em; color: var(--accent); }
.mailcard__stats span { font-size: .76rem; color: var(--muted); }

/* ============ INCLUS ============ */
.incl { --gap: 48px; align-items: start; }
.incl__list { display: flex; flex-direction: column; gap: 20px; }
.incl__list .tick b { font-size: 1.02rem; }
.incl__list .tick p { margin: 4px 0 0; font-size: .92rem; }
.incl__calls { display: flex; flex-direction: column; gap: 16px; }
.callcard { display: flex; flex-direction: column; gap: 8px; position: relative; }
.callcard__n { font-family: var(--font-display); font-weight: var(--display-weight); color: var(--accent); font-size: 1.1rem; }
.callcard__goal { background: var(--ink); color: var(--bg); border-radius: var(--card-radius); padding: 24px; font-size: .96rem; line-height: 1.5; }
.callcard__goal b { font-family: var(--font-display); }

/* ============ TIMELINE ============ */
.timeline { list-style: none; padding: 0; margin: 0; display: grid; grid-template-columns: repeat(4,1fr); gap: 20px; position: relative; }
.timeline__item { position: relative; padding-top: 30px; display: flex; flex-direction: column; gap: 8px; }
.timeline__item::before { content: ""; position: absolute; top: 6px; left: 0; right: 0; height: 2px; background: var(--line); }
.timeline__item::after { content: ""; position: absolute; top: 1px; left: 0; width: 12px; height: 12px; border-radius: 50%; background: var(--accent); }
.timeline__wk { font-size: .72rem; letter-spacing: .12em; color: var(--accent); font-weight: 600; }
.timeline__item p { margin: 0; font-size: .92rem; }
@media (max-width: 820px) { .timeline { grid-template-columns: 1fr; } .timeline__item::before { display: none; } }

/* ============ PRICING ============ */
.pricing { align-items: stretch; }
.price { display: flex; flex-direction: column; gap: 6px; }
.price__name { font-family: var(--font-eyebrow, var(--font-body)); text-transform: uppercase; letter-spacing: .16em; font-size: .8rem; font-weight: 700; color: var(--muted); }
.price--featured .price__name { color: inherit; opacity: .8; }
.price__amt { margin: 6px 0; }
.price__unit { font-family: var(--font-body); font-size: 1rem; font-weight: 500; color: var(--muted); letter-spacing: 0; }
.price--featured .price__unit { color: inherit; opacity: .7; }
.price .tick { margin-top: 12px; font-size: .94rem; }
.price .divider { margin: 18px 0 4px; }
.price--featured .divider { background: color-mix(in oklch, currentColor, transparent 80%); }

/* ============ SCOPE ============ */
.scope__list { list-style: none; padding: 0; margin: 18px 0; display: flex; flex-direction: column; gap: 10px; }
.scope__list li { position: relative; padding-left: 26px; color: var(--muted); }
.scope__list li::before { content: "✕"; position: absolute; left: 0; top: 0; color: var(--accent); font-weight: 700; }
.scope__note { font-size: .9rem; padding-top: 14px; border-top: 1px solid var(--line); }

/* ============ FOOTER ============ */
.foot__nav { display: flex; flex-direction: column; gap: 10px; }
.foot__h { font-size: .74rem; text-transform: uppercase; letter-spacing: .16em; color: var(--ink); font-weight: 700; margin-bottom: 4px; }
.foot__bottom { margin-top: 48px; padding-top: 24px; border-top: 1px solid var(--line); font-size: .86rem; }
.logos__cap { font-size: .82rem; text-transform: uppercase; letter-spacing: .18em; }

/* ============ responsive heroes ============ */
@media (max-width: 880px) {
  .coldHero { grid-template-columns: 1fr; }
  .coldHero__card { margin-top: 8px; }
}

/* ============ HERO author byline + reassurance ============ */
.hero-main__assure { font-family: var(--font-mono); font-size: .76rem; letter-spacing: .04em; text-transform: uppercase;
  color: var(--muted); margin: -6px 0 0; display: flex; align-items: center; gap: .7em; flex-wrap: wrap; }
.hero-main__assure b { color: var(--signal); font-weight: 500; }
.hero-main__by { display: flex; align-items: center; gap: 14px; margin: 6px 0 0; padding-top: 26px;
  border-top: 1px solid var(--line); }
.hero-main__avatar { flex: none; width: 52px; height: 52px; border-radius: 50%; object-fit: cover;
  filter: grayscale(1); box-shadow: 0 0 0 1px var(--line), 0 0 0 4px var(--bg), 0 0 0 5px var(--signal); }
.hero-main__by p { margin: 0; font-size: .95rem; line-height: 1.45; color: var(--ink-soft); max-width: 46ch; }
.hero-main__by b { color: var(--ink); font-weight: 700; }
.hero-main__by em { font-style: normal; font-family: var(--font-mono); font-size: .82em; color: var(--signal); letter-spacing: .02em; }

/* ============ POUR QUI ============ */
.forwho { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(20px, 3vw, 36px); margin-top: 52px; }
.forwho__col { border: 1px solid var(--line); padding: clamp(24px,3vw,34px); background: var(--surface); }
.forwho__col--no { background: transparent; }
.forwho__h { display: flex; align-items: center; gap: 10px; font-family: var(--font-mono); text-transform: uppercase;
  letter-spacing: .1em; font-size: .78rem; font-weight: 500; margin-bottom: 20px; }
.forwho__h .mk { width: 22px; height: 22px; display: grid; place-items: center; font-weight: 700; font-size: .85rem; }
.forwho--yes .mk { background: var(--signal); color: var(--signal-ink); }
.forwho--no .mk { border: 1.5px solid var(--muted); color: var(--muted); }
.forwho ul { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 14px; }
.forwho li { display: flex; gap: 11px; align-items: flex-start; font-size: 1rem; line-height: 1.4; color: var(--ink-soft); }
.forwho li::before { content: ""; flex: none; width: 7px; height: 7px; margin-top: 8px; border-radius: 50%; }
.forwho--yes li::before { background: var(--signal); }
.forwho--no li::before { background: var(--muted); }
.forwho--no li { color: var(--muted); }
@media (max-width: 760px) { .forwho { grid-template-columns: 1fr; } }

/* ============ FAQ ============ */
.faq { margin-top: 48px; border-top: 1px solid var(--line); }
.faq__item { border-bottom: 1px solid var(--line); }
.faq__item > summary { list-style: none; cursor: pointer; padding: 24px 0; display: flex; align-items: center; gap: 18px;
  font-family: var(--font-display); font-weight: 700; font-size: clamp(1.1rem,1rem+.5vw,1.35rem); letter-spacing: -.01em;
  color: var(--ink); transition: color .2s; }
.faq__item > summary::-webkit-details-marker { display: none; }
.faq__item > summary::after { content: "+"; margin-left: auto; flex: none; font-family: var(--font-mono); font-weight: 400;
  font-size: 1.5rem; color: var(--signal); transition: transform .3s; line-height: 1; }
.faq__item[open] > summary::after { transform: rotate(45deg); }
.faq__item > summary:hover { color: var(--signal); }
.faq__n { font-family: var(--font-mono); font-size: .8rem; color: var(--muted); font-weight: 400; }
.faq__a { padding: 0 0 26px 44px; color: var(--ink-soft); font-size: 1.02rem; line-height: 1.6; max-width: 68ch; margin: 0; }
@media (max-width: 600px) { .faq__a { padding-left: 0; } }


/* ===== variants.css ===== */
/* ============================================================
   VARIANTS — three comparable directions, switchable live.
   Operateur (default) lives in themes.css. Here we add two
   alternative palettes + the component fixes each one needs.
   Switched via [data-theme] on .site (set by the Tweaks panel).
   ============================================================ */

/* keep the warm/editorial DNA, just make the switch explicit */
.site[data-theme="operateur"] {
  --signal: var(--accent-pick, #CBF24A);
  --signal-deep: #9FC72C;
  --signal-ink: #15140C;
}

/* ------------------------------------------------------------
   DIRECTION · ÉDITORIAL CLAIR
   warm paper, near-black ink, deep brick signal. Premium,
   institutional, more print-like. Inverts the whole site.
   ------------------------------------------------------------ */
.site[data-theme="clair"] {
  --signal: var(--accent-pick, #C0392B);   /* deep brick / oxblood */
  --signal-deep: #97291C;
  --signal-ink: #FBF7EC;                    /* paper text on the signal */

  --bg: #EDE7D8;            /* warm paper */
  --surface: #F7F2E7;       /* lifted card */
  --surface-2: #E3DCC9;     /* deeper alt-section */
  --ink: #1B1813;           /* warm near-black */
  --ink-soft: #3B362C;
  --muted: #756E5C;
  --line: rgba(27,24,19,0.16);
}
/* logos read as black ink on paper */
.site[data-theme="clair"] .logos img { filter: grayscale(1) brightness(0); opacity: .42; }
/* trade the hard black plinth-shadows for soft paper shadows */
.site[data-theme="clair"] .diag,
.site[data-theme="clair"] .mailcard { box-shadow: 0 22px 48px -24px rgba(27,24,19,.5); }
.site[data-theme="clair"] .diag__label i,
.site[data-theme="clair"] .hero-main__avatar { filter: none; }
.site[data-theme="clair"] .hero-main__avatar { filter: grayscale(1); }
/* portrait halftone is too heavy on light — lighten the dot screen */
.site[data-theme="clair"] .portrait--halftone::before { opacity: .16; }

/* ------------------------------------------------------------
   DIRECTION · SIGNAL INDIGO
   cooler near-black, electric ultramarine signal, softened
   corners + shadows. A more "studio / product" personality.
   ------------------------------------------------------------ */
.site[data-theme="indigo"] {
  --signal: var(--accent-pick, #5B6CFF);   /* electric ultramarine */
  --signal-deep: #3A48CC;
  --signal-ink: #FFFFFF;                    /* white text on the signal */

  --bg: #0D0F16;           /* cool near-black */
  --surface: #161A26;
  --surface-2: #090B12;
  --ink: #EDEFF7;
  --ink-soft: #C5C9DA;
  --muted: #7C8299;
  --line: rgba(237,239,247,0.12);

  --card-radius: 16px;
  --btn-radius: 12px;
}
/* rounded mark + softer shadows to match the personality */
.site[data-theme="indigo"] .nav__logo .mark { border-radius: 8px; }
.site[data-theme="indigo"] .diag,
.site[data-theme="indigo"] .mailcard {
  border-radius: var(--card-radius);
  box-shadow: 0 34px 80px -36px rgba(0,0,0,.75);
}
.site[data-theme="indigo"] .diag__opt { border-radius: 10px; }
.site[data-theme="indigo"] .pill { border-radius: 999px; }
.site[data-theme="indigo"] .tick__mk,
.site[data-theme="indigo"] .nav__logo .mark { border-radius: 8px; }
/* the offset hard shadow looks wrong on rounded buttons */
.site[data-theme="indigo"] .btn:hover { box-shadow: 0 16px 34px -12px var(--signal); }
.site[data-theme="indigo"] .badge-reco { border-radius: 999px; }

/* ------------------------------------------------------------
   DIRECTION · L'EXPERT
   Same warm near-black + the aggressive yellow he likes — but
   the yellow is rationed to a PRECISE accent instead of flooded
   aplats. Serif sub-leads for authority, calmer ticker, ink
   stats, more air. Reads "consultant", not "growth marketer".
   Pure component re-styling, scoped to the theme — nothing in
   the markup changes, so switching back is lossless.
   ------------------------------------------------------------ */
.site[data-theme="expert"] {
  --signal: var(--accent-pick, #CBF24A);   /* the same acid yellow, kept */
  --signal-deep: #9FC72C;
  --signal-ink: #15140C;

  --bg: #15140F;            /* a touch warmer near-black */
  --surface: #1C1A13;
  --surface-2: #110F0A;
  --ink: #F4F0E6;
  --ink-soft: #D7D2C2;
  --muted: #938C7A;
  --line: rgba(244,240,230,0.11);

  --section-pad: 140px;     /* more breathing room = more premium */
}

/* eyebrows: quiet label + a single yellow tick (not a yellow word) */
.site[data-theme="expert"] .eyebrow { color: var(--muted); letter-spacing: .2em; }
.site[data-theme="expert"] .eyebrow::before { background: var(--signal); }

/* sub-leads in serif — the editorial / authority voice */
.site[data-theme="expert"] .lead { font-family: var(--font-serif); font-weight: 400; letter-spacing: 0; }
.site[data-theme="expert"] .hero-main__sub {
  font-family: var(--font-serif); font-weight: 400; color: var(--ink-soft);
  font-size: clamp(1.16rem, 1rem + .6vw, 1.42rem); line-height: 1.5; max-width: 46ch;
}

/* stats read in ink, not flooded yellow — confidence, not hype */
.site[data-theme="expert"] .stat__num,
.site[data-theme="expert"] .hero-main__stats dt,
.site[data-theme="expert"] .diag__rlever { color: var(--ink); }
.site[data-theme="expert"] .stat__lbl { color: var(--muted); }

/* ticker → a quiet running capability index, not a hype marquee */
.site[data-theme="expert"] .ticker { background: transparent; }
.site[data-theme="expert"] .ticker__track {
  font-family: var(--font-mono); font-weight: 500; font-size: .74rem; letter-spacing: .22em;
  text-transform: uppercase; color: var(--muted); animation-duration: 90s; padding: 15px 0;
}
.site[data-theme="expert"] .ticker__track .dot { color: var(--signal); opacity: .55; }

/* the big move: DEFLATE the flooded yellow CTA band into a
   refined dark band with one yellow rule + one yellow button */
.site[data-theme="expert"] .cta-band {
  background: var(--surface-2); color: var(--ink);
  border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); position: relative;
}
.site[data-theme="expert"] .cta-band::before {
  content: ""; position: absolute; top: 0; left: 0; right: 0; height: 3px; background: var(--signal);
}
.site[data-theme="expert"] .cta-band .display { color: var(--ink); }
.site[data-theme="expert"] .cta-band .display em,
.site[data-theme="expert"] .cta-band .h2 em { color: var(--signal); }
.site[data-theme="expert"] .cta-band .lead { color: var(--ink-soft); }
.site[data-theme="expert"] .cta-band .eyebrow { color: var(--muted); }
.site[data-theme="expert"] .cta-band .eyebrow::before { background: var(--signal); }
.site[data-theme="expert"] .cta-band .muted { color: var(--muted); }
.site[data-theme="expert"] .cta-band .btn { background: var(--signal); color: var(--signal-ink); }
.site[data-theme="expert"] .cta-band .btn:hover { box-shadow: 5px 5px 0 var(--signal-deep); }

/* calmer hero quiz — drop the heavy plinth shadow */
.site[data-theme="expert"] .diag,
.site[data-theme="expert"] .mailcard { box-shadow: 0 26px 56px -32px rgba(0,0,0,.6); }

/* ------------------------------------------------------------
   Corner override (Tweaks · "Coins") — applied inline on #site
   when the user picks a value; "Auto" leaves the direction's own
   radius in place. Nothing needed here; documented for clarity.
   ------------------------------------------------------------ */


/* ===== refine.css ===== */
/* ============================================================
   REFINE — brand lockup, menu redesign, credible logo wall.
   Loaded last so it wins over themes.css / components.css.
   Goal: read as an EXPERT (refined, editorial) while keeping
   the yellow edge as a precise accent, not a shouty default.
   ============================================================ */

/* ------------------------------------------------------------
   BRAND LOCKUP — historical chat-bubble mark, re-cut to theme.
   Pairs the icon with the typographic wordmark.
   ------------------------------------------------------------ */
.brand { display: inline-flex; align-items: center; gap: 11px; color: var(--ink); }
.brand__mark { flex: none; width: 38px; height: 38px; display: block; }
.brand__mark svg { width: 100%; height: 100%; display: block; }
.brand__wm { display: flex; flex-direction: column; line-height: 1; gap: 4px; }
.brand__wm b {
  font-family: var(--font-display); font-weight: 800; font-size: 1.04rem;
  letter-spacing: -.022em; text-transform: none; color: var(--ink);
}
.brand__wm i {
  font-family: var(--font-mono); font-style: normal; font-weight: 500;
  font-size: .6rem; letter-spacing: .26em; text-transform: uppercase; color: var(--muted);
}
.brand:hover .brand__mark svg rect { filter: brightness(1.06); }

/* ------------------------------------------------------------
   MENU — refined, mixed-case, no wrapping, clear hierarchy.
   Drops the all-caps mono (which read "growth-hacker") for a
   quieter editorial nav with an underline-on-hover accent.
   ------------------------------------------------------------ */
.nav__inner { gap: 22px; }
.nav__links {
  display: flex; align-items: center; gap: 30px; margin-left: 14px;
  font-family: var(--font-body); text-transform: none; letter-spacing: 0; font-size: .95rem;
}
.nav__links a {
  position: relative; color: var(--ink-soft); font-weight: 500; white-space: nowrap;
  padding: 6px 0; transition: color .2s;
}
.nav__links a::after {
  content: ""; position: absolute; left: 0; bottom: 0; height: 2px; width: 0;
  background: var(--signal); transition: width .22s cubic-bezier(.2,.8,.2,1);
}
.nav__links a:hover { color: var(--ink); }
.nav__links a:hover::after { width: 100%; }

.nav__login {
  font-family: var(--font-body); font-weight: 500; font-size: .92rem; color: var(--ink);
  white-space: nowrap; display: inline-flex; align-items: center; gap: .5em; transition: color .2s;
}
.nav__login::before {
  content: ""; width: 7px; height: 7px; border-radius: 50%;
  border: 1.5px solid var(--muted); transition: border-color .2s, background-color .2s;
}
.nav__login:hover { color: var(--signal); }
.nav__login:hover::before { border-color: var(--signal); background: var(--signal); }

.nav .btn--sm { padding: .72em 1.2em; font-size: .78rem; }

@media (max-width: 1024px) { .nav__login { display: none; } }
@media (max-width: 880px) { .nav__links { display: none; } }

/* ------------------------------------------------------------
   LOGO WALL — uniform light plaques so the raster logos (SNCF
   grey-fill, Lynx black-circle) read alongside the line marks.
   Bigger, calmer, more "trusted by" than "look at my numbers".
   ------------------------------------------------------------ */
.logos { gap: 18px; }
.logos img {
  height: 34px; width: auto; opacity: .92;
  box-sizing: content-box; padding: 16px 26px;
  background: #F4F1EA; border-radius: 12px;
  box-shadow: inset 0 0 0 1px rgba(20,19,13,.06);
  filter: grayscale(1) contrast(1.02);
  transition: transform .25s cubic-bezier(.2,.8,.2,1), box-shadow .25s, opacity .25s;
}
.logos__cap { color: var(--muted); }

/* keep the SNCF / Lynx plaques the same calm tone on every theme */
.site[data-theme="clair"] .logos img { background: #FFFFFF; box-shadow: inset 0 0 0 1px rgba(27,24,19,.08); }

@media (max-width: 560px) {
  .logos img { height: 26px; padding: 12px 18px; }
}


/* ===== craft.css ===== */
/* ============================================================
   CRAFT — the bespoke layer. Three moves that read as "made by
   a human who cares", not "spun up by AI":
     1. Hero signal canvas — a live acquisition curve that goes
        from jagged (dents de scie) to a smooth compounding climb.
     2. Logo wall — a continuous monochrome marquee, no plaques.
     3. Testimonials — an editorial masonry that breathes.
   Loaded LAST so it wins. Theme-aware via the CSS variables.
   ============================================================ */

/* ------------------------------------------------------------
   1 · HERO SIGNAL CANVAS
   ------------------------------------------------------------ */
.hero-fx {
  position: absolute; inset: 0; z-index: 0; pointer-events: none; display: block;
  -webkit-mask-image:
    linear-gradient(90deg, #000 0%, #000 62%, transparent 90%),
    linear-gradient(180deg, transparent 0%, transparent 12%, #000 28%, #000 90%, transparent 100%);
  -webkit-mask-composite: source-in; mask-composite: intersect;
  mask-image:
    linear-gradient(90deg, #000 0%, #000 62%, transparent 90%),
    linear-gradient(180deg, transparent 0%, transparent 12%, #000 28%, #000 90%, transparent 100%);
  opacity: 1; transition: transform .4s cubic-bezier(.2,.8,.2,1);
}
.hero-main .wrap { z-index: 1; }
.hero-main .ticker { position: relative; z-index: 1; }
@media (max-width: 880px) {
  .hero-fx {
    -webkit-mask-image: linear-gradient(180deg, transparent, #000 18%, #000 70%, transparent);
            mask-image: linear-gradient(180deg, transparent, #000 18%, #000 70%, transparent);
    opacity: .5;
  }
}

/* ------------------------------------------------------------
   2 · LOGO WALL — continuous marquee, valued + monochrome.
   Overrides the earlier plaque treatment in refine.css.
   ------------------------------------------------------------ */
.logos.logowall {
  display: block; position: relative; overflow: hidden; width: 100%;
  -webkit-mask-image: linear-gradient(90deg, transparent, #000 7%, #000 93%, transparent);
          mask-image: linear-gradient(90deg, transparent, #000 7%, #000 93%, transparent);
}
.logowall__track {
  display: flex; align-items: center; width: max-content;
  padding: 6px 0;
  animation: logomarq 42s linear infinite; will-change: transform;
}
/* spacing lives ON each item as PADDING (counted in the track's
   width, unlike a trailing margin or flex gap) so half the track
   width is EXACTLY one set period — no seam jump at the -50% wrap */
/* spacing lives ON each item as PADDING (counted in the track's
   width, unlike a trailing margin or flex gap) so half the track
   width is EXACTLY one set period — no seam jump at the -50% wrap */
.logowall:hover .logowall__track { animation-play-state: paused; }
@keyframes logomarq { to { transform: translateX(-50%); } }
@media (prefers-reduced-motion: reduce) {
  .logowall__track { animation: none; flex-wrap: wrap; justify-content: center; width: auto; }
}
.logowall__track img {
  height: clamp(30px, 3vw, 44px); width: auto; flex: none;
  margin: 0; padding: 0 clamp(48px, 6vw, 92px) 0 0;
  box-sizing: content-box;
  background: none; box-shadow: none; border-radius: 0;
  filter: grayscale(1) brightness(0) invert(1); opacity: .46;
  transition: opacity .3s, filter .3s, transform .3s;
}
/* paper theme: dark ink logos instead of inverted white */
.site[data-theme="clair"] .logowall__track img { filter: grayscale(1) brightness(0); opacity: .5; }

.logos__cap { margin-bottom: 30px; opacity: .9; }

/* ------------------------------------------------------------
   3 · TESTIMONIALS — editorial masonry, room to breathe.
   Kills the equal-height squeeze; each card is its own height.
   ------------------------------------------------------------ */
.quotes.quotewall {
  display: block; columns: 3 300px; column-gap: 24px; margin-top: 52px;
}
@media (max-width: 980px) { .quotes.quotewall { columns: 2 280px; } }
@media (max-width: 640px)  { .quotes.quotewall { columns: 1; } }

.quotewall .quote {
  break-inside: avoid; height: auto; display: flex; flex-direction: column; gap: 18px;
  margin: 0 0 24px; padding: clamp(26px, 2.4vw, 36px);
  position: relative; overflow: hidden;
  transition-property: opacity, transform, border-color, box-shadow, translate;
  transition-duration: .8s, .8s, .3s, .3s, .3s;
  transition-timing-function: ease, cubic-bezier(.2,.8,.2,1), ease, ease, ease;
  transition-delay: var(--rdelay, 0s), var(--rdelay, 0s), 0s, 0s, 0s;
}
/* a quiet oversized quotation mark — editorial signature */
.quotewall .quote::before {
  content: "\201C"; position: absolute; top: -.18em; right: .12em;
  font-family: var(--font-serif); font-style: italic; font-size: 6rem; line-height: 1;
  color: var(--signal); opacity: .12; pointer-events: none;
}
.quotewall .quote:hover {
  border-color: color-mix(in oklch, var(--signal), transparent 55%);
  translate: 0 -3px;
  box-shadow: 0 22px 50px -30px rgba(0,0,0,.6);
}
.quotewall .quote .stars { font-size: .8rem; letter-spacing: 3px; }
.quotewall .quote__body {
  font-family: var(--font-serif); font-size: clamp(1.12rem, 1rem + .35vw, 1.32rem);
  line-height: 1.5; color: var(--ink); position: relative; z-index: 1; margin: 0;
}
.quotewall .quote__who { gap: 14px; padding-top: 4px; }
.quotewall .quote__who img {
  width: 50px; height: 50px; border-radius: 50%;
  box-shadow: 0 0 0 1px var(--line), 0 0 0 4px var(--surface), 0 0 0 5px var(--signal);
}
.quotewall .quote__name { font-size: 1rem; }

/* ------------------------------------------------------------
   4 · FINISH — the details lazy sites never have.
   ------------------------------------------------------------ */
/* text selection in the brand signal */
.site ::selection { background: var(--signal); color: var(--signal-ink); }

/* keyboard focus — visible, branded, never the browser default */
.site a:focus-visible, .site button:focus-visible, .site summary:focus-visible {
  outline: 2px solid var(--signal); outline-offset: 3px; border-radius: 2px;
}

/* anchored sections land with air below the top of the viewport */
.site section[id] { scroll-margin-top: 32px; }
html { scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } }

/* stats — tabular figures so counts don't wobble while animating */
.stat__num { font-variant-numeric: tabular-nums; }

/* unified motion spec for cards: reveal entry (.8s, staggered via
   --rdelay) + INSTANT hover (.3s, no inherited stagger delay).
   Hover lifts via `translate` so it never fights the reveal's
   `transform`. */
.site .card, .site .step {
  transition-property: opacity, transform, border-color, box-shadow, translate;
  transition-duration: .8s, .8s, .3s, .3s, .3s;
  transition-timing-function: ease, cubic-bezier(.2,.8,.2,1), ease, ease, ease;
  transition-delay: var(--rdelay, 0s), var(--rdelay, 0s), 0s, 0s, 0s;
}
.reveal.d1 { --rdelay: .08s; } .reveal.d2 { --rdelay: .16s; } .reveal.d3 { --rdelay: .24s; }
.reveal.d4 { --rdelay: .32s; } .reveal.d5 { --rdelay: .40s; }
@media (prefers-reduced-motion: reduce) {
  .site .card, .site .step { transition-duration: 0s, 0s, .3s, .3s, 0s; }
}
.site .card:hover, .site .step:hover {
  border-color: color-mix(in oklch, var(--signal), transparent 60%);
  translate: 0 -3px;
  box-shadow: 0 20px 44px -30px rgba(0,0,0,.55);
}

/* one in three gets a little more presence — rhythm, not monotony */
.quotewall .quote:nth-child(3n+1) .quote__body { font-size: clamp(1.22rem, 1.05rem + .5vw, 1.5rem); }


/* ===== pages.css ===== */
/* ============================================================
   PAGES — shared pieces for the inner pages (conversion,
   confirmation, capture). Pure composition of the theme vars.
   ============================================================ */

/* ---- simple page hero (no canvas) ---- */
.pageHero { padding: var(--hero-pad-top, clamp(40px, 5vw, 72px)) 0 var(--hero-pad-bottom, clamp(44px, 5vw, 76px)); border-bottom: 1px solid var(--line); position: relative; overflow: clip; }
.pageHero .h1 { font-family: var(--font-display); font-weight: 800; letter-spacing: -.04em; line-height: .95;
  font-size: var(--hero-title-size, clamp(2.5rem, 1rem + 4.8vw, 5.2rem)); margin: 18px 0 0; color: var(--ink); text-wrap: balance; }
.pageHero .h1 em { font-family: var(--font-serif); font-style: italic; font-weight: 400; color: var(--signal); }
.pageHero .lead { margin-top: 22px; }

/* ---- forms ---- */
.field { display: flex; flex-direction: column; gap: 8px; }
.field label { font-family: var(--font-mono); font-size: .72rem; text-transform: uppercase; letter-spacing: .14em; color: var(--muted); }
.input {
  background: var(--bg); border: 1px solid var(--line); color: var(--ink);
  padding: 15px 16px; font: inherit; font-size: 1rem; border-radius: var(--btn-radius, 0);
  transition: border-color .2s;
  width: 100%;
}
.input::placeholder { color: var(--muted); }
.input:focus { outline: 2px solid var(--signal); outline-offset: 2px; border-color: var(--signal); }

/* inline opt-in: email + button */
.optin { display: flex; gap: 12px; align-items: stretch; }
.optin .input { flex: 1; }
.optin .btn { white-space: nowrap; }
@media (max-width: 560px) { .optin { flex-direction: column; } }
.optin-note { font-family: var(--font-mono); font-size: .72rem; letter-spacing: .04em; color: var(--muted); margin-top: 12px; }

/* ---- confirmation pages ---- */
.confirm-mark {
  width: 72px; height: 72px; margin-inline: auto; display: grid; place-items: center;
  background: var(--signal); color: var(--signal-ink); border-radius: 50%;
  font-size: 2rem; font-weight: 800;
}
.nextsteps { list-style: none; counter-reset: ns; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 0; text-align: left; }
.nextsteps li {
  counter-increment: ns; display: flex; gap: 18px; align-items: flex-start;
  padding: 22px 0; border-bottom: 1px solid var(--line);
}
.nextsteps li:last-child { border-bottom: 0; }
.nextsteps li::before {
  content: "0" counter(ns); flex: none;
  font-family: var(--font-mono); font-size: .8rem; color: var(--signal); padding-top: .25em; letter-spacing: .08em;
}
.nextsteps b { color: var(--ink); display: block; margin-bottom: 4px; }
.nextsteps p { margin: 0; color: var(--muted); font-size: .95rem; line-height: 1.5; }

/* ---- squeeze (capture) minimal chrome ---- */
.squeezeNav { display: flex; align-items: center; justify-content: center; padding: 22px 0; }
.squeezeFoot { padding: 36px 0 44px; border-top: 1px solid var(--line); text-align: center; }
.squeezeFoot p { font-size: .8rem; color: var(--muted); max-width: 60ch; margin: 0 auto 10px; }
.squeezeFoot a { color: var(--muted); text-decoration: underline; }

/* ---- embed slot (agenda / video) ---- */
.embed-slot {
  background: var(--surface); border: 1px dashed color-mix(in oklch, var(--muted), transparent 30%);
  border-radius: var(--card-radius, 0); min-height: 480px;
  display: grid; place-items: center; text-align: center; padding: 32px;
}
.embed-slot p { color: var(--muted); font-size: .9rem; max-width: 36ch; margin: 0; line-height: 1.5; }
.embed-slot .mono { display: block; margin-top: 10px; font-size: .74rem; letter-spacing: .06em; color: var(--signal); }

/* the moment a real embed is pasted inside, the slot dissolves */
.embed-slot:has(iframe) { border: 0; padding: 0; background: none; min-height: 0; display: block; }
.embed-slot iframe { width: 100%; min-height: 640px; border: 0; }


/* ===== scroll-anim.css ===== */
/* ============================================================
   scroll-anim.css — the "scroll cinema" layer.
   Everything here is ADDITIVE and gated behind `.js-scroll`
   (added by scroll-anim.js) so the page degrades to the normal
   static layout with no JS / reduced motion. Brand-true: only
   uses existing tokens (--signal, --ink, --bg, --line…).
   ============================================================ */

/* ------------------------------------------------------------
   0 · SCROLL PROGRESS — hairline signal bar under the chrome
   ------------------------------------------------------------ */
.scrollbar {
  position: fixed; left: 0; top: 56px; height: 2px; width: 0%;
  background: var(--signal); z-index: 70;
  box-shadow: 0 0 14px var(--signal);
  transition: width .08s linear;
  pointer-events: none;
}
@media (max-width: 880px) { .scrollbar { top: 92px; } }

/* ------------------------------------------------------------
   1 · CUSTOM CURSOR — a signal dot + trailing ring.
   Hidden on touch / coarse pointers and reduced motion.
   ------------------------------------------------------------ */
.cur, .cur-ring {
  position: fixed; top: 0; left: 0; z-index: 9999; pointer-events: none;
  border-radius: 50%;
  translate: -50% -50%;
}
.cur { width: 6px; height: 6px; background: var(--signal); mix-blend-mode: difference; }
.cur-ring {
  width: 46px; height: 46px; border: none;
  background: radial-gradient(circle at center,
    color-mix(in oklch, var(--signal), transparent 80%) 0%,
    transparent 66%);
  filter: blur(5px);
  opacity: .3; mix-blend-mode: screen;
  transition: width .3s cubic-bezier(.2,.8,.2,1), height .3s cubic-bezier(.2,.8,.2,1), opacity .3s;
}
.cur-ring.is-hot { width: 60px; height: 60px; opacity: .42; }
html.has-cur, html.has-cur * { cursor: none !important; }
@media (hover: none), (pointer: coarse), (prefers-reduced-motion: reduce) {
  .cur, .cur-ring { display: none !important; }
  html.has-cur, html.has-cur * { cursor: auto !important; }
}

/* bigger trust logos on the animated page */
.js-scroll .logowall__track img { height: clamp(70px, 8vw, 116px); padding-right: clamp(70px, 8vw, 130px); opacity: .62; }
.js-scroll .logos__cap { margin-bottom: 48px; }

/* diagnostic result — synthesis + "on peut vous aider" */
.diag__rsynth { color: var(--ink); font-size: 1.02rem; line-height: 1.5; margin: 10px 0 22px; text-wrap: pretty; }
.diag__rk2 { display: block; margin-top: 6px; }

/* "moteur d'acquisition" hero canvas: spans the hero, faded at
   the far edges so headline + diagnostic card stay clean. */
.hero-fx--engine {
  -webkit-mask-image:
    linear-gradient(90deg, transparent 0%, #000 6%, #000 94%, transparent 100%),
    linear-gradient(180deg, transparent 0%, #000 14%, #000 86%, transparent 100%);
  -webkit-mask-composite: source-in; mask-composite: intersect;
  mask-image:
    linear-gradient(90deg, transparent 0%, #000 6%, #000 94%, transparent 100%),
    linear-gradient(180deg, transparent 0%, #000 14%, #000 86%, transparent 100%);
  opacity: .95;
}
@media (max-width: 880px) { .hero-fx--engine { opacity: .6; } }

/* ============================================================
   AURORA — full-spectrum WebGL oil-slick hero (the "WOW")
   ============================================================ */
.hero-fx--aurora, .hero-fx--current, .hero-fx--morph, .hero-fx--silk, .hero-fx--fibers, .hero-fx--fibers3d, .hero-fx--signal {
  position: absolute; inset: 0; z-index: 0;
  width: 100%; height: 100%;
  /* soft bottom fade into the page so the section seam is clean */
  -webkit-mask-image: linear-gradient(180deg, #000 0%, #000 80%, transparent 100%);
          mask-image: linear-gradient(180deg, #000 0%, #000 80%, transparent 100%);
}
.hero-fx--fibers3d canvas, .hero-fx--signal canvas { display:block; width:100% !important; height:100% !important; }

/* "Le Passage" flux hero — same positioning language as the others */
.hero-fx--flux { position:absolute; inset:0; z-index:0; width:100%; height:100%;
  -webkit-mask-image: linear-gradient(180deg,#000 0%,#000 80%,transparent 100%);
          mask-image: linear-gradient(180deg,#000 0%,#000 80%,transparent 100%); }
.hero-fx--flux canvas { display:block; width:100% !important; height:100% !important; }
.js-scroll [data-fx="flux"] { position: relative; isolation: isolate; }
.js-scroll [data-fx="flux"] > *:not(.hero-fx):not(.hero-scrim) { position: relative; z-index: 2; }
.js-scroll [data-fx="flux"] .hero-main__title,
.js-scroll [data-fx="flux"] .hero-main__sub,
.js-scroll [data-fx="flux"] .kicker,
.js-scroll [data-fx="flux"] .h1,
.js-scroll [data-fx="flux"] .lead {
  text-shadow: 0 1px 30px color-mix(in oklch, var(--bg), transparent 20%), 0 1px 3px color-mix(in oklch, var(--bg), transparent 40%);
}
@media (max-width:880px){ .hero-fx--flux { opacity:.9; } }
/* adaptive scrim: keeps the headline legible over any colour.
   Dense enough behind the text (left) to read, clearing toward the
   form so the colour still blooms (WOW kept). */
.hero-scrim {
  position: absolute; inset: 0; z-index: 1; pointer-events: none;
  background:
    linear-gradient(100deg,
      color-mix(in oklch, var(--bg), transparent 16%) 0%,
      color-mix(in oklch, var(--bg), transparent 32%) 30%,
      color-mix(in oklch, var(--bg), transparent 64%) 54%,
      transparent 80%),
    linear-gradient(180deg, transparent 50%, color-mix(in oklch, var(--bg), transparent 40%) 100%);
}
/* safety contrast for hero copy where colour bleeds through */
.js-scroll [data-fx="aurora"] .hero-main__title,
.js-scroll [data-fx="aurora"] .hero-main__sub,
.js-scroll [data-fx="aurora"] .kicker,
.js-scroll [data-fx="current"] .hero-main__title,
.js-scroll [data-fx="current"] .hero-main__sub,
.js-scroll [data-fx="current"] .kicker,
.js-scroll [data-fx="morph"] .hero-main__title,
.js-scroll [data-fx="morph"] .hero-main__sub,
.js-scroll [data-fx="morph"] .kicker,
.js-scroll [data-fx="silk"] .hero-main__title,
.js-scroll [data-fx="silk"] .hero-main__sub,
.js-scroll [data-fx="silk"] .kicker,
.js-scroll [data-fx="fibers"] .hero-main__title,
.js-scroll [data-fx="fibers"] .hero-main__sub,
.js-scroll [data-fx="fibers"] .kicker,
.js-scroll [data-fx="fibers3d"] .hero-main__title,
.js-scroll [data-fx="fibers3d"] .hero-main__sub,
.js-scroll [data-fx="fibers3d"] .kicker,
.js-scroll [data-fx="signal"] .hero-main__title,
.js-scroll [data-fx="signal"] .hero-main__sub,
.js-scroll [data-fx="signal"] .kicker {
  text-shadow: 0 1px 30px color-mix(in oklch, var(--bg), transparent 20%), 0 1px 3px color-mix(in oklch, var(--bg), transparent 40%);
}
/* make sure hero copy sits above canvas + scrim */
.js-scroll [data-fx="aurora"] > *:not(.hero-fx):not(.hero-scrim),
.js-scroll [data-fx="current"] > *:not(.hero-fx):not(.hero-scrim),
.js-scroll [data-fx="morph"] > *:not(.hero-fx):not(.hero-scrim),
.js-scroll [data-fx="silk"] > *:not(.hero-fx):not(.hero-scrim),
.js-scroll [data-fx="fibers3d"] > *:not(.hero-fx):not(.hero-scrim),
.js-scroll [data-fx="signal"] > *:not(.hero-fx):not(.hero-scrim) { position: relative; z-index: 2; }
@media (max-width: 880px) {
  /* on small screens the form lives behind everything, dimmer + denser scrim */
  .hero-fx--aurora, .hero-fx--current, .hero-fx--morph, .hero-fx--silk, .hero-fx--fibers, .hero-fx--fibers3d, .hero-fx--signal { opacity: .9; }
  .hero-scrim {
    background:
      linear-gradient(180deg,
        color-mix(in oklch, var(--bg), transparent 12%) 0%,
        color-mix(in oklch, var(--bg), transparent 30%) 45%,
        color-mix(in oklch, var(--bg), transparent 12%) 100%);
  }
}

/* ============================================================
   MÉTHODE — vertical editorial timeline (steps stacked)
   ============================================================ */
.flow { margin-top: clamp(40px, 5vw, 64px); }
.flow__row {
  display: grid; grid-template-columns: clamp(96px, 13vw, 188px) 1fr;
  gap: clamp(22px, 4vw, 60px); align-items: start;
  padding: clamp(34px, 4vw, 58px) 0; border-top: 1px solid var(--line);
  position: relative;
}
.flow__row:last-child { border-bottom: 1px solid var(--line); }
.flow__idx { position: relative; }
/* connecting rail + node linking the steps in sequence */
.flow__row::before {
  content: ""; position: absolute; left: calc(clamp(96px, 13vw, 188px) / 2);
  top: 0; bottom: 0; width: 1px; background: var(--line); transform: translateX(-50%);
}
.flow__row:first-child::before { top: clamp(34px, 4vw, 58px); }
.flow__row:last-child::before { bottom: auto; height: calc(clamp(34px, 4vw, 58px) + 14px); }
.flow__idx::after {
  content: ""; position: absolute; left: 50%; top: calc(clamp(34px, 4vw, 58px) - 8px);
  width: 11px; height: 11px; background: var(--bg); border: 2px solid var(--signal);
  transform: translateX(-50%); z-index: 1; transition: background-color .25s, box-shadow .25s;
}
.flow__row:hover .flow__idx::after { background: var(--signal); box-shadow: 0 0 14px var(--signal); }
.flow__n {
  display: block; font-family: var(--font-display); font-weight: 800;
  font-size: clamp(3rem, 2rem + 5.5vw, 7rem); line-height: .8; letter-spacing: -.05em;
  color: transparent; -webkit-text-stroke: 1.5px color-mix(in oklch, var(--signal), transparent 32%);
  transition: color .3s, -webkit-text-stroke-color .3s; text-align: center;
}
.flow__row:hover .flow__n { color: var(--signal); -webkit-text-stroke-color: transparent; }
.flow__body .step__n { display: inline-block; margin-bottom: 14px; }
.flow__body .h3 { font-size: clamp(1.7rem, 1.2rem + 1.8vw, 2.7rem); margin-bottom: 14px; }
.flow__body .muted { font-size: 1.08rem; max-width: 54ch; }
.flow__list {
  list-style: none; padding: 0; margin: 24px 0 0;
  display: flex; flex-wrap: wrap; gap: 10px 12px;
}
.flow__list li {
  font-family: var(--font-mono); font-size: .76rem; letter-spacing: .04em; text-transform: uppercase;
  color: var(--ink-soft); padding: .55em .9em; border: 1px solid var(--line);
  display: inline-flex; align-items: center; gap: .6em; transition: border-color .25s, color .25s;
}
.flow__list li::before { content: ""; width: 6px; height: 6px; background: var(--signal); flex: none; }
.flow__row:hover .flow__list li { border-color: color-mix(in oklch, var(--signal), transparent 62%); }
@media (max-width: 640px) {
  .flow__row { grid-template-columns: 1fr; gap: 8px; }
  .flow__row::before, .flow__idx::after { display: none; }
  .flow__n { text-align: left; font-size: 3.4rem; }
}

/* ------------------------------------------------------------ — words rise out of a mask, staggered.
   JS wraps each word: <span class="kw"><i>word</i></span>
   ------------------------------------------------------------ */
.js-scroll .hero-main__title .kw, .js-scroll [data-kin] .kw { display: inline-block; overflow: hidden; vertical-align: top; padding-bottom: .04em; }
.js-scroll .hero-main__title .kw > i, .js-scroll [data-kin] .kw > i {
  display: inline-block; font-style: inherit;
  /* visible end-state by default — a stalled JS/transition leaves text readable */
}
/* hidden start, ONLY while the title is "armed" for the entrance */
.js-scroll .hero-main__title.kin-arm .kw > i, .js-scroll [data-kin].kin-arm .kw > i {
  transform: translateY(110%) rotate(3deg);
  opacity: 0;
}
@media (prefers-reduced-motion: no-preference) {
  .js-scroll .hero-main__title .kw > i, .js-scroll [data-kin] .kw > i {
    transition: transform .9s cubic-bezier(.16,1,.3,1), opacity .9s ease;
    transition-delay: var(--kd, 0s);
  }
}
.js-scroll .hero-main__title.kin-arm .kw > i, .js-scroll [data-kin].kin-arm .kw > i { transition-delay: 0s; }

/* page hero must host the engine canvas behind its content
   (exclude the canvas itself from the child rule, else it falls
   into flow and inflates the hero) */
.js-scroll [data-fx="engine"] { position: relative; isolation: isolate; }
.js-scroll [data-fx="engine"] > .hero-fx { position: absolute; inset: 0; z-index: 0; }
.js-scroll [data-fx="engine"] > *:not(.hero-fx) { position: relative; z-index: 1; }
.js-scroll .pageHero { position: relative; }
.js-scroll .pageHero > *:not(.hero-fx) { position: relative; z-index: 1; }
.js-scroll .pageHero .hero-fx { position: absolute; inset: 0; z-index: 0; }
.js-scroll header.hero { position: relative; }
.js-scroll header.hero > *:not(.hero-fx) { position: relative; z-index: 1; }
/* Fallback sans dépendance JS : le contenu reste au-dessus du canvas .hero-fx */
header.hero, .pageHero, [data-fx] { position: relative; }
[data-fx] > *:not(.hero-fx) { position: relative; z-index: 1; }
.js-scroll header.hero .hero-fx { position: absolute; inset: 0; z-index: 0; }

/* ------------------------------------------------------------
   3 · CLIP-REVEAL HEADINGS — section h2 wipes up on scroll.
   ------------------------------------------------------------ */
.js-scroll [data-reveal-clip] {
  clip-path: inset(0 0 100% 0);
  opacity: 0;
  transform: translateY(18px);
}
@media (prefers-reduced-motion: no-preference) {
  .js-scroll [data-reveal-clip] {
    transition: clip-path 1s cubic-bezier(.16,1,.3,1), opacity .9s ease, transform 1s cubic-bezier(.16,1,.3,1);
  }
}
.js-scroll [data-reveal-clip].in { clip-path: inset(0 0 -10% 0); opacity: 1; transform: none; }

/* ------------------------------------------------------------
   4 · PARALLAX — translate Y bound to scroll, set via --py.
   ------------------------------------------------------------ */
.js-scroll [data-par] { will-change: transform; transform: translate3d(0, var(--py, 0px), 0); }

/* ------------------------------------------------------------
   5 · MÉTHODE — PINNED SCROLL-TELLING
   The section grows tall; an inner stage sticks for the whole
   scroll and the three steps cross-fade while a giant number +
   progress rail scrub. Falls back to a normal stack with no JS.
   ------------------------------------------------------------ */
.js-scroll .pinwrap { height: 340vh; position: relative; }
.js-scroll .pin {
  position: sticky; top: 0; min-height: 100vh;
  display: flex; align-items: center;
  padding-block: clamp(40px, 9vh, 96px); overflow: hidden;
}
.pin__grid {
  display: grid; grid-template-columns: 0.9fr 1.1fr; gap: clamp(32px, 6vw, 90px);
  align-items: center; width: 100%;
}
@media (max-width: 980px) { .pin__grid { grid-template-columns: 1fr; gap: 34px; } }

/* left rail — eyebrow, giant number, progress dots */
.pin__rail { position: relative; }
.pin__num {
  font-family: var(--font-display); font-weight: 800; line-height: .8;
  letter-spacing: -.05em; font-size: clamp(7rem, 4rem + 16vw, 17rem);
  color: transparent;
  -webkit-text-stroke: 2px color-mix(in oklch, var(--signal), transparent 30%);
  position: relative;
}
.pin__num::after {
  content: attr(data-fillnum); position: absolute; inset: 0;
  color: var(--signal); -webkit-text-stroke: 0;
  clip-path: inset(calc(100% - var(--np, 0) * 100%) 0 0 0);
}
.pin__dots { display: flex; gap: 10px; margin-top: 26px; }
.pin__dots i {
  height: 3px; flex: 1; background: var(--line); position: relative; overflow: hidden;
}
.pin__dots i::after {
  content: ""; position: absolute; inset: 0; width: 0%; background: var(--signal);
  box-shadow: 0 0 10px var(--signal); transition: width .2s linear;
}
.pin__dots i.done::after { width: 100%; }
.pin__dots i.active::after { width: var(--seg, 0%); }
.pin__count {
  margin-top: 18px; font-family: var(--font-mono); font-size: .78rem;
  letter-spacing: .14em; text-transform: uppercase; color: var(--muted);
}

/* right panels — stacked, only active one shows */
.pin__panels { position: relative; min-height: 340px; }
.js-scroll .pin__panel {
  position: absolute; inset: 0; display: flex; flex-direction: column; justify-content: center;
  opacity: 0; transform: translateY(40px) scale(.985);
  pointer-events: none;
}
@media (prefers-reduced-motion: no-preference) {
  .js-scroll .pin__panel { transition: opacity .55s ease, transform .7s cubic-bezier(.16,1,.3,1); }
}
.js-scroll .pin__panel.is-on { opacity: 1; transform: none; pointer-events: auto; }
.js-scroll .pin__panel.is-prev { opacity: 0; transform: translateY(-40px) scale(.985); }

.pin__panel .step__n {
  display: inline-block; font-family: var(--font-mono); font-size: .8rem; letter-spacing: .12em;
  text-transform: uppercase; color: var(--signal); margin-bottom: 14px;
}
.pin__panel .h3 { font-size: clamp(1.7rem, 1.2rem + 1.8vw, 2.6rem); margin-bottom: 16px; }
.pin__panel .muted { font-size: 1.08rem; max-width: 46ch; }
.pin__panel .step__list {
  list-style: none; padding: 0; margin: 26px 0 0; display: grid; gap: 0;
}
.pin__panel .step__list li {
  font-family: var(--font-mono); font-size: .82rem; letter-spacing: .03em; text-transform: uppercase;
  color: var(--ink-soft); padding: 14px 0; border-top: 1px solid var(--line);
  display: flex; align-items: center; gap: 14px;
}
.pin__panel .step__list li::before {
  content: ""; width: 7px; height: 7px; background: var(--signal); flex: none;
}
.pin__panel .step__list li:last-child { border-bottom: 1px solid var(--line); }

/* ---- static fallback (reduced-motion desktop / coarse): no pin, plain stack ---- */
.js-scroll .pinwrap.pin-static { height: auto; }
.js-scroll .pinwrap.pin-static .pin { position: static; min-height: 0; display: block; }
.js-scroll .pinwrap.pin-static .pin__panels { min-height: 0; }
.js-scroll .pinwrap.pin-static .pin__panel {
  position: static; opacity: 1; transform: none; pointer-events: auto; margin-bottom: 40px;
}

/* mobile: kill the pin, show steps as a normal stacked list */
@media (max-width: 760px) {
  .js-scroll .pinwrap { height: auto; }
  .js-scroll .pin { position: static; min-height: 0; display: block; }
  .js-scroll .pin__panels { min-height: 0; }
  .js-scroll .pin__panel { position: static; opacity: 1; transform: none; pointer-events: auto; margin-bottom: 40px; }
  .pin__num { font-size: 6rem; }
}

/* ------------------------------------------------------------
   6 · MAGNETIC BUTTONS — JS sets --mx/--my, CSS positions.
   ------------------------------------------------------------ */
.js-scroll .btn[data-mag] { transition: transform .2s cubic-bezier(.2,.8,.2,1), box-shadow .25s; }
.js-scroll .btn[data-mag].pulled { transform: translate(var(--mx,0), var(--my,0)); }
.js-scroll .btn[data-mag].pulled:hover { transform: translate(var(--mx,0), calc(var(--my,0) - 2px)); }

/* ------------------------------------------------------------
   7 · STAGGERED "rise" for grid children on scroll (cards/steps)
   gives a livelier entrance than the base reveal. Optional hook.
   ------------------------------------------------------------ */
.js-scroll [data-rise] > * {
  opacity: 0; transform: translateY(34px);
}
@media (prefers-reduced-motion: no-preference) {
  .js-scroll [data-rise] > * {
    transition: opacity .7s ease, transform .8s cubic-bezier(.16,1,.3,1);
    transition-delay: calc(var(--i, 0) * .09s);
  }
}
.js-scroll [data-rise].in > * { opacity: 1; transform: none; }

@media (prefers-reduced-motion: reduce) {
  .js-scroll .hero-main__title .kw > i,
  .js-scroll [data-kin] .kw > i,
  .js-scroll [data-reveal-clip],
  .js-scroll [data-rise] > *,
  .js-scroll .pin__panel { opacity: 1 !important; transform: none !important; clip-path: none !important; }
}


/* ============ Overrides production Webflow (pas de barre d'aperçu) ============ */
.site{ padding-top:0 !important; }
.nav{ top:0 !important; }
.scrollbar{ top:0 !important; }
.chrome{ display:none !important; }
@media (max-width:880px){ .site{ padding-top:0 !important; } .nav{ top:0 !important; } }


/* ============================================================
   MOBILE FIX — débordement horizontal & marges
   Cause : les CTA à libellé long ("RÉSERVER UN ENTRETIEN
   STRATÉGIQUE") en white-space:nowrap dépassaient la largeur de
   l'écran → toute la page défilait latéralement → gouttières
   écrasées et titres rognés à gauche. On laisse les boutons
   passer à la ligne, on passe les CTA principaux en pleine
   largeur, + filet de sécurité overflow-x sur html.
   ============================================================ */
html { overflow-x: clip; }

/* laisse les blocs flex/grid rétrécir au lieu de déborder (la vraie
   cause du hero coupé à droite : items en min-width:auto) */
@media (max-width: 880px) {
  .hero-main__grid { grid-template-columns: 1fr; }
  .hero-main__grid > * { min-width: 0; }
  .hero-main__lead, .hero-main__by, .hero-main__by p,
  .hero-main__cta, .hero__cta { min-width: 0; }
  .hero-main__sub { max-width: none; }
  .btn { white-space: normal; }
}

@media (max-width: 640px) {
  .btn { max-width: 100%; text-align: center; }
  .hero-main__cta, .hero__cta { width: 100%; }
  .hero-main__cta > .btn--lg, .hero__cta > .btn--lg,
  .cta-band .btn--lg, .cta-band .btn { width: 100%; justify-content: center; }
  /* la nav : on retire le CTA redondant (le hero en a déjà un bien visible)
     pour qu'il ne déborde jamais la barre sur petit écran */
  .nav .btn--sm { display: none; }
  :root, .site, .squeeze { --gutter: 22px; }
}
