/* ══════════════════════════════════════════════════════════════════
   ALLOD | SWG — Marketing site
   Luxury forest aesthetic · dark hero → light sections → dark footer
   ══════════════════════════════════════════════════════════════════ */

/* latin-ext */
@font-face {
  font-family: 'Gabarito';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("/static/fonts/gabarito-400-latin-ext.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Gabarito';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("/static/fonts/gabarito-400-latin.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;
}
/* latin-ext */
@font-face {
  font-family: 'Gabarito';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("/static/fonts/gabarito-400-latin-ext.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Gabarito';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("/static/fonts/gabarito-400-latin.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;
}
/* latin-ext */
@font-face {
  font-family: 'Gabarito';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("/static/fonts/gabarito-400-latin-ext.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Gabarito';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("/static/fonts/gabarito-400-latin.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;
}
/* latin-ext */
@font-face {
  font-family: 'Gabarito';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("/static/fonts/gabarito-400-latin-ext.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Gabarito';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("/static/fonts/gabarito-400-latin.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;
}
/* latin-ext */
@font-face {
  font-family: 'Gabarito';
  font-style: normal;
  font-weight: 900;
  font-display: swap;
  src: url("/static/fonts/gabarito-400-latin-ext.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Gabarito';
  font-style: normal;
  font-weight: 900;
  font-display: swap;
  src: url("/static/fonts/gabarito-400-latin.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: 'Noto Sans';
  font-style: italic;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("/static/fonts/noto-sans-400-italic-cyrillic-ext.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: 'Noto Sans';
  font-style: italic;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("/static/fonts/noto-sans-400-italic-cyrillic.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* devanagari */
@font-face {
  font-family: 'Noto Sans';
  font-style: italic;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("/static/fonts/noto-sans-400-italic-devanagari.woff2") format('woff2');
  unicode-range: U+0900-097F, U+1CD0-1CF9, U+200C-200D, U+20A8, U+20B9, U+20F0, U+25CC, U+A830-A839, U+A8E0-A8FF, U+11B00-11B09;
}
/* greek-ext */
@font-face {
  font-family: 'Noto Sans';
  font-style: italic;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("/static/fonts/noto-sans-400-italic-greek-ext.woff2") format('woff2');
  unicode-range: U+1F00-1FFF;
}
/* greek */
@font-face {
  font-family: 'Noto Sans';
  font-style: italic;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("/static/fonts/noto-sans-400-italic-greek.woff2") format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
/* vietnamese */
@font-face {
  font-family: 'Noto Sans';
  font-style: italic;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("/static/fonts/noto-sans-400-italic-latin-ext.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: 'Noto Sans';
  font-style: italic;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("/static/fonts/noto-sans-400-italic-latin-ext-2.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: 'Noto Sans';
  font-style: italic;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("/static/fonts/noto-sans-400-italic-latin.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: 'Noto Sans';
  font-style: normal;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("/static/fonts/noto-sans-400-cyrillic-ext.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: 'Noto Sans';
  font-style: normal;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("/static/fonts/noto-sans-400-cyrillic.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* devanagari */
@font-face {
  font-family: 'Noto Sans';
  font-style: normal;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("/static/fonts/noto-sans-400-devanagari.woff2") format('woff2');
  unicode-range: U+0900-097F, U+1CD0-1CF9, U+200C-200D, U+20A8, U+20B9, U+20F0, U+25CC, U+A830-A839, U+A8E0-A8FF, U+11B00-11B09;
}
/* greek-ext */
@font-face {
  font-family: 'Noto Sans';
  font-style: normal;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("/static/fonts/noto-sans-400-greek-ext.woff2") format('woff2');
  unicode-range: U+1F00-1FFF;
}
/* greek */
@font-face {
  font-family: 'Noto Sans';
  font-style: normal;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("/static/fonts/noto-sans-400-greek.woff2") format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
/* vietnamese */
@font-face {
  font-family: 'Noto Sans';
  font-style: normal;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("/static/fonts/noto-sans-400-latin-ext-2.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: 'Noto Sans';
  font-style: normal;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("/static/fonts/noto-sans-400-latin-ext.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Noto Sans';
  font-style: normal;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("/static/fonts/noto-sans-400-latin.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: 'Noto Sans';
  font-style: normal;
  font-weight: 500;
  font-stretch: 100%;
  font-display: swap;
  src: url("/static/fonts/noto-sans-400-cyrillic-ext.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: 'Noto Sans';
  font-style: normal;
  font-weight: 500;
  font-stretch: 100%;
  font-display: swap;
  src: url("/static/fonts/noto-sans-400-cyrillic.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* devanagari */
@font-face {
  font-family: 'Noto Sans';
  font-style: normal;
  font-weight: 500;
  font-stretch: 100%;
  font-display: swap;
  src: url("/static/fonts/noto-sans-400-devanagari.woff2") format('woff2');
  unicode-range: U+0900-097F, U+1CD0-1CF9, U+200C-200D, U+20A8, U+20B9, U+20F0, U+25CC, U+A830-A839, U+A8E0-A8FF, U+11B00-11B09;
}
/* greek-ext */
@font-face {
  font-family: 'Noto Sans';
  font-style: normal;
  font-weight: 500;
  font-stretch: 100%;
  font-display: swap;
  src: url("/static/fonts/noto-sans-400-greek-ext.woff2") format('woff2');
  unicode-range: U+1F00-1FFF;
}
/* greek */
@font-face {
  font-family: 'Noto Sans';
  font-style: normal;
  font-weight: 500;
  font-stretch: 100%;
  font-display: swap;
  src: url("/static/fonts/noto-sans-400-greek.woff2") format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
/* vietnamese */
@font-face {
  font-family: 'Noto Sans';
  font-style: normal;
  font-weight: 500;
  font-stretch: 100%;
  font-display: swap;
  src: url("/static/fonts/noto-sans-400-latin-ext-2.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: 'Noto Sans';
  font-style: normal;
  font-weight: 500;
  font-stretch: 100%;
  font-display: swap;
  src: url("/static/fonts/noto-sans-400-latin-ext.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Noto Sans';
  font-style: normal;
  font-weight: 500;
  font-stretch: 100%;
  font-display: swap;
  src: url("/static/fonts/noto-sans-400-latin.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: 'Noto Sans';
  font-style: normal;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url("/static/fonts/noto-sans-400-cyrillic-ext.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: 'Noto Sans';
  font-style: normal;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url("/static/fonts/noto-sans-400-cyrillic.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* devanagari */
@font-face {
  font-family: 'Noto Sans';
  font-style: normal;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url("/static/fonts/noto-sans-400-devanagari.woff2") format('woff2');
  unicode-range: U+0900-097F, U+1CD0-1CF9, U+200C-200D, U+20A8, U+20B9, U+20F0, U+25CC, U+A830-A839, U+A8E0-A8FF, U+11B00-11B09;
}
/* greek-ext */
@font-face {
  font-family: 'Noto Sans';
  font-style: normal;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url("/static/fonts/noto-sans-400-greek-ext.woff2") format('woff2');
  unicode-range: U+1F00-1FFF;
}
/* greek */
@font-face {
  font-family: 'Noto Sans';
  font-style: normal;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url("/static/fonts/noto-sans-400-greek.woff2") format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
/* vietnamese */
@font-face {
  font-family: 'Noto Sans';
  font-style: normal;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url("/static/fonts/noto-sans-400-latin-ext-2.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: 'Noto Sans';
  font-style: normal;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url("/static/fonts/noto-sans-400-latin-ext.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Noto Sans';
  font-style: normal;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url("/static/fonts/noto-sans-400-latin.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: 'Noto Sans';
  font-style: normal;
  font-weight: 700;
  font-stretch: 100%;
  font-display: swap;
  src: url("/static/fonts/noto-sans-400-cyrillic-ext.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: 'Noto Sans';
  font-style: normal;
  font-weight: 700;
  font-stretch: 100%;
  font-display: swap;
  src: url("/static/fonts/noto-sans-400-cyrillic.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* devanagari */
@font-face {
  font-family: 'Noto Sans';
  font-style: normal;
  font-weight: 700;
  font-stretch: 100%;
  font-display: swap;
  src: url("/static/fonts/noto-sans-400-devanagari.woff2") format('woff2');
  unicode-range: U+0900-097F, U+1CD0-1CF9, U+200C-200D, U+20A8, U+20B9, U+20F0, U+25CC, U+A830-A839, U+A8E0-A8FF, U+11B00-11B09;
}
/* greek-ext */
@font-face {
  font-family: 'Noto Sans';
  font-style: normal;
  font-weight: 700;
  font-stretch: 100%;
  font-display: swap;
  src: url("/static/fonts/noto-sans-400-greek-ext.woff2") format('woff2');
  unicode-range: U+1F00-1FFF;
}
/* greek */
@font-face {
  font-family: 'Noto Sans';
  font-style: normal;
  font-weight: 700;
  font-stretch: 100%;
  font-display: swap;
  src: url("/static/fonts/noto-sans-400-greek.woff2") format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
/* vietnamese */
@font-face {
  font-family: 'Noto Sans';
  font-style: normal;
  font-weight: 700;
  font-stretch: 100%;
  font-display: swap;
  src: url("/static/fonts/noto-sans-400-latin-ext-2.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: 'Noto Sans';
  font-style: normal;
  font-weight: 700;
  font-stretch: 100%;
  font-display: swap;
  src: url("/static/fonts/noto-sans-400-latin-ext.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Noto Sans';
  font-style: normal;
  font-weight: 700;
  font-stretch: 100%;
  font-display: swap;
  src: url("/static/fonts/noto-sans-400-latin.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: 'Noto Sans Mono';
  font-style: normal;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("/static/fonts/noto-sans-mono-400-cyrillic-ext.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: 'Noto Sans Mono';
  font-style: normal;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("/static/fonts/noto-sans-mono-400-cyrillic.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* greek-ext */
@font-face {
  font-family: 'Noto Sans Mono';
  font-style: normal;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("/static/fonts/noto-sans-mono-400-greek-ext.woff2") format('woff2');
  unicode-range: U+1F00-1FFF;
}
/* greek */
@font-face {
  font-family: 'Noto Sans Mono';
  font-style: normal;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("/static/fonts/noto-sans-mono-400-greek.woff2") format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
/* vietnamese */
@font-face {
  font-family: 'Noto Sans Mono';
  font-style: normal;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("/static/fonts/noto-sans-mono-400-latin-ext-2.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: 'Noto Sans Mono';
  font-style: normal;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("/static/fonts/noto-sans-mono-400-latin-ext.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Noto Sans Mono';
  font-style: normal;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("/static/fonts/noto-sans-mono-400-latin.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: 'Noto Sans Mono';
  font-style: normal;
  font-weight: 500;
  font-stretch: 100%;
  font-display: swap;
  src: url("/static/fonts/noto-sans-mono-400-cyrillic-ext.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: 'Noto Sans Mono';
  font-style: normal;
  font-weight: 500;
  font-stretch: 100%;
  font-display: swap;
  src: url("/static/fonts/noto-sans-mono-400-cyrillic.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* greek-ext */
@font-face {
  font-family: 'Noto Sans Mono';
  font-style: normal;
  font-weight: 500;
  font-stretch: 100%;
  font-display: swap;
  src: url("/static/fonts/noto-sans-mono-400-greek-ext.woff2") format('woff2');
  unicode-range: U+1F00-1FFF;
}
/* greek */
@font-face {
  font-family: 'Noto Sans Mono';
  font-style: normal;
  font-weight: 500;
  font-stretch: 100%;
  font-display: swap;
  src: url("/static/fonts/noto-sans-mono-400-greek.woff2") format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
/* vietnamese */
@font-face {
  font-family: 'Noto Sans Mono';
  font-style: normal;
  font-weight: 500;
  font-stretch: 100%;
  font-display: swap;
  src: url("/static/fonts/noto-sans-mono-400-latin-ext-2.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: 'Noto Sans Mono';
  font-style: normal;
  font-weight: 500;
  font-stretch: 100%;
  font-display: swap;
  src: url("/static/fonts/noto-sans-mono-400-latin-ext.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Noto Sans Mono';
  font-style: normal;
  font-weight: 500;
  font-stretch: 100%;
  font-display: swap;
  src: url("/static/fonts/noto-sans-mono-400-latin.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: 'Noto Sans Mono';
  font-style: normal;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url("/static/fonts/noto-sans-mono-400-cyrillic-ext.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: 'Noto Sans Mono';
  font-style: normal;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url("/static/fonts/noto-sans-mono-400-cyrillic.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* greek-ext */
@font-face {
  font-family: 'Noto Sans Mono';
  font-style: normal;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url("/static/fonts/noto-sans-mono-400-greek-ext.woff2") format('woff2');
  unicode-range: U+1F00-1FFF;
}
/* greek */
@font-face {
  font-family: 'Noto Sans Mono';
  font-style: normal;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url("/static/fonts/noto-sans-mono-400-greek.woff2") format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
/* vietnamese */
@font-face {
  font-family: 'Noto Sans Mono';
  font-style: normal;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url("/static/fonts/noto-sans-mono-400-latin-ext-2.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: 'Noto Sans Mono';
  font-style: normal;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url("/static/fonts/noto-sans-mono-400-latin-ext.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Noto Sans Mono';
  font-style: normal;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url("/static/fonts/noto-sans-mono-400-latin.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;
}


:root {
    /* Brand palette */
    --green:    #92A673;
    --forest:   #3A4A3F;
    --espresso: #2C2825;
    --light:    #F7F3F2;
    --cream:    #EBE4D4;
    --gold:     #AF9061;
    --stone:    #8D806C;

    --green-rgb:  146, 166, 115;
    --gold-rgb:   175, 144, 97;
    --forest-rgb: 58, 74, 63;

    /* Dark forest surfaces */
    --d-base:     #0f140d;
    --d-raised:   #161d14;
    --d-elevated: #1e271b;
    --d-border:   rgba(146, 166, 115, 0.16);
    --d-border-2: rgba(146, 166, 115, 0.28);

    /* Light surfaces */
    --l-cream:    #EBE4D4;
    --l-paper:    #F7F3F2;
    --l-card:     #FFFFFF;
    --l-border:   rgba(58, 74, 63, 0.14);

    /* Text */
    --d-text:     #ece6d6;
    --d-text-2:   #b6ad99;
    --d-text-3:   #837a68;
    --l-text:     #20251d;
    --l-text-2:   #59614f;
    --l-text-3:   #8d806c;

    /* Accent (tweakable) */
    --accent:     var(--green);
    --accent-rgb: var(--green-rgb);

    --font-display: 'Gabarito', -apple-system, BlinkMacSystemFont, sans-serif;
    --font-sans:    'Noto Sans', -apple-system, BlinkMacSystemFont, sans-serif;
    --font-mono:    'Noto Sans Mono', ui-monospace, monospace;

    --maxw: 1200px;
    --pad-section: 7rem;
}

[data-density="compact"] { --pad-section: 4.5rem; }
[data-density="comfy"]   { --pad-section: 9rem; }

* { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; }

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

.wrap { max-width: var(--maxw); margin: 0 auto; padding: 0 2rem; }

.eyebrow {
    font-family: var(--font-mono);
    font-size: 0.72rem;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.18em;
    color: var(--accent);
    display: inline-flex;
    align-items: center;
    gap: 0.6rem;
}
.eyebrow::before {
    content: '';
    width: 18px; height: 1px;
    background: var(--accent);
    opacity: 0.7;
}
.eyebrow.center::before { display: none; }

h1, h2, h3 { font-family: var(--font-display); font-weight: 600; letter-spacing: -0.01em; line-height: 1.08; }

a { color: inherit; text-decoration: none; }

/* ── Buttons ───────────────────────────────────────────────── */
.btn {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    font-family: var(--font-sans);
    font-weight: 600;
    font-size: 0.95rem;
    padding: 0.85rem 1.5rem;
    border-radius: 6px;
    border: 1px solid transparent;
    cursor: pointer;
    transition: transform 0.18s ease, background 0.18s, border-color 0.18s, color 0.18s;
    white-space: nowrap;
}
.btn:hover { transform: translateY(-2px); }
.btn svg { width: 18px; height: 18px; }

.btn-accent {
    background: var(--accent);
    color: #11160f;
    box-shadow: 0 8px 24px rgba(var(--accent-rgb), 0.22);
}
.btn-accent:hover { background: color-mix(in oklab, var(--accent) 85%, white); }

.btn-ghost-gold {
    background: transparent;
    border-color: rgba(var(--gold-rgb), 0.5);
    color: var(--gold);
}
.btn-ghost-gold:hover { background: rgba(var(--gold-rgb), 0.1); border-color: var(--gold); }

.btn-dark {
    background: var(--espresso);
    color: var(--cream);
}
.btn-dark:hover { background: #1f1c1a; }

.btn-outline-dark {
    background: transparent;
    border-color: var(--l-border);
    color: var(--l-text);
}
.btn-outline-dark:hover { border-color: var(--forest); background: rgba(var(--forest-rgb), 0.05); }

.btn-lg { padding: 1rem 1.9rem; font-size: 1.02rem; }
.btn-sm { padding: 0.6rem 1.1rem; font-size: 0.88rem; }

/* ══════════════════════════════════════════════════════════════
   NAV
   ══════════════════════════════════════════════════════════════ */
.nav {
    position: fixed;
    top: 0; left: 0; right: 0;
    z-index: 50;
    height: 72px;
    display: flex;
    align-items: center;
    transition: background 0.3s, border-color 0.3s, backdrop-filter 0.3s;
    border-bottom: 1px solid transparent;
}
.nav.scrolled {
    background: rgba(15, 20, 13, 0.82);
    backdrop-filter: blur(16px) saturate(1.2);
    -webkit-backdrop-filter: blur(16px) saturate(1.2);
    border-bottom-color: var(--d-border);
}
.nav .wrap { display: flex; align-items: center; width: 100%; gap: 2.5rem; }

.brand {
    font-family: var(--font-display);
    font-weight: 600;
    font-size: 1.18rem;
    letter-spacing: 0.03em;
    color: var(--gold);
    display: flex;
    align-items: center;
    gap: 0.6rem;
    white-space: nowrap;
}
.brand svg { height: 30px; width: auto; }

.nav-links { display: flex; gap: 0.4rem; flex: 1; }
.nav-links a {
    color: var(--d-text-2);
    font-size: 0.92rem;
    font-weight: 500;
    padding: 0.5rem 0.85rem;
    border-radius: 5px;
    transition: color 0.16s, background 0.16s;
}
.nav-links a:hover { color: var(--d-text); background: rgba(var(--green-rgb), 0.08); }
.nav-actions { display: flex; align-items: center; gap: 0.9rem; }
.nav-signin { color: var(--d-text-2); font-size: 0.92rem; font-weight: 500; transition: color 0.16s; }
.nav-signin:hover { color: var(--d-text); }

.nav-toggle { display: none; }

/* ══════════════════════════════════════════════════════════════
   HERO  (shared dark forest shell)
   ══════════════════════════════════════════════════════════════ */
.hero {
    position: relative;
    background: var(--d-base);
    color: var(--d-text);
    overflow: hidden;
    isolation: isolate;
}
.hero-bg {
    position: absolute;
    inset: 0;
    z-index: -2;
    background:
        radial-gradient(900px 600px at 70% -10%, rgba(var(--green-rgb), 0.18), transparent 60%),
        radial-gradient(700px 500px at 15% 110%, rgba(var(--forest-rgb), 0.55), transparent 65%),
        linear-gradient(170deg, #10160e 0%, #0d120c 55%, #0b0f0a 100%);
}
[data-herobg="espresso"] .hero-bg {
    background:
        radial-gradient(900px 600px at 70% -10%, rgba(var(--gold-rgb), 0.14), transparent 60%),
        radial-gradient(700px 500px at 15% 110%, rgba(44, 40, 37, 0.8), transparent 65%),
        linear-gradient(170deg, #221f1c 0%, #1a1715 55%, #141210 100%);
}
[data-herobg="midnight"] .hero-bg {
    background:
        radial-gradient(900px 600px at 70% -10%, rgba(var(--green-rgb), 0.12), transparent 60%),
        linear-gradient(170deg, #0a0d09 0%, #070907 100%);
}
/* grain */
.hero-bg::after {
    content: '';
    position: absolute; inset: 0;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='4'/%3E%3C/filter%3E%3Crect width='160' height='160' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
}

/* hidden / shown variants */
.hero-variant { display: none; }
[data-hero="a"] .hero-variant.hero-a,
[data-hero="b"] .hero-variant.hero-b,
[data-hero="c"] .hero-variant.hero-c { display: block; }

/* ── Forest / mountain silhouette scape ── */
.hero-scape {
    position: absolute;
    left: 0; right: 0; bottom: 0;
    z-index: -1;
    line-height: 0;
    pointer-events: none;
    -webkit-mask-image: linear-gradient(to top, #000 68%, transparent);
    mask-image: linear-gradient(to top, #000 68%, transparent);
}
.hero-scape svg { width: 100%; height: auto; display: block; }

/* ── Hero A — editorial centered ── */
.hero-a { padding: 12rem 0 9rem; text-align: center; }
.hero-a .eyebrow { margin-bottom: 1.8rem; }
.hero-a h1 {
    font-size: clamp(2.6rem, 6.5vw, 5.2rem);
    max-width: 16ch;
    margin: 0 auto 1.6rem;
}
.hero-a h1 .dot { color: var(--gold); }
.hero-a .lead {
    font-size: clamp(1.05rem, 1.8vw, 1.3rem);
    color: var(--d-text-2);
    max-width: 56ch;
    margin: 0 auto 2.6rem;
}
.hero-cta { display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap; }
.hero-a .hero-cta { justify-content: center; }

.hero-trust {
    margin-top: 4.5rem;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 2.5rem;
    flex-wrap: wrap;
    color: var(--d-text-3);
    font-size: 0.8rem;
    font-family: var(--font-mono);
    letter-spacing: 0.04em;
}
.hero-trust .dotsep { width: 4px; height: 4px; border-radius: 50%; background: var(--d-text-3); }

/* ── Hero B — split ── */
.hero-b { padding: 11rem 0 7rem; }
.hero-b .grid {
    display: grid;
    grid-template-columns: 1.05fr 1fr;
    gap: 4rem;
    align-items: center;
}
.hero-b .eyebrow { margin-bottom: 1.6rem; }
.hero-b h1 { font-size: clamp(2.4rem, 4.6vw, 4rem); margin-bottom: 1.4rem; }
.hero-b h1 .dot { color: var(--gold); }
.hero-b .lead { font-size: 1.18rem; color: var(--d-text-2); max-width: 44ch; margin-bottom: 2.3rem; }
.hero-b .mini-stats { display: flex; gap: 2.5rem; margin-top: 3rem; }
.hero-b .mini-stat .n { font-family: var(--font-display); font-weight: 700; font-size: 1.9rem; color: var(--d-text); }
.hero-b .mini-stat .l { font-size: 0.8rem; color: var(--d-text-3); font-family: var(--font-mono); letter-spacing: 0.03em; margin-top: 0.2rem; }

/* ── Hero C — full statement ── */
.hero-c { padding: 13rem 0 8rem; }
.hero-c .eyebrow { margin-bottom: 2.2rem; }
.hero-c h1 {
    font-size: clamp(3rem, 10vw, 8.5rem);
    font-weight: 700;
    line-height: 0.98;
    letter-spacing: -0.03em;
    max-width: 14ch;
}
.hero-c h1 .dot { color: var(--gold); }
.hero-c .statement-foot {
    margin-top: 3.5rem;
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    gap: 2rem;
    flex-wrap: wrap;
    border-top: 1px solid var(--d-border);
    padding-top: 2rem;
}
.hero-c .statement-foot .lead { font-size: 1.15rem; color: var(--d-text-2); max-width: 46ch; }

/* ══════════════════════════════════════════════════════════════
   PRODUCT MOCKUP  (used in hero B + feature section)
   ══════════════════════════════════════════════════════════════ */
.mock {
    background: var(--d-raised);
    border: 1px solid var(--d-border-2);
    border-radius: 12px;
    box-shadow: 0 32px 80px rgba(0, 0, 0, 0.55), 0 0 0 1px rgba(0,0,0,0.3);
    overflow: hidden;
    font-size: 0.8rem;
}
.mock-bar {
    background: var(--d-elevated);
    border-bottom: 1px solid var(--d-border);
    padding: 0.7rem 1rem;
    display: flex;
    align-items: center;
    gap: 0.6rem;
}
.mock-bar .brand-sm { font-family: var(--font-display); font-weight: 600; color: var(--gold); font-size: 0.85rem; letter-spacing: 0.03em; margin-right: auto; white-space: nowrap; }
.mock-dot { width: 8px; height: 8px; border-radius: 50%; }
.mock-body { padding: 1.1rem; }
.mock-row { display: grid; grid-template-columns: 1fr 1fr; gap: 0.7rem; margin-bottom: 0.7rem; }
.mock-card {
    background: var(--d-base);
    border: 1px solid var(--d-border);
    border-top: 2px solid var(--accent);
    border-radius: 7px;
    padding: 0.75rem 0.85rem;
}
.mock-card.gold { border-top-color: var(--gold); }
.mock-sub { font-family: var(--font-mono); font-size: 0.62rem; text-transform: uppercase; letter-spacing: 0.08em; color: var(--d-text-3); margin-bottom: 0.35rem; }
.mock-metric { font-family: var(--font-display); font-weight: 700; font-size: 1.5rem; color: var(--d-text); }
.mock-metric.accent { color: var(--accent); }
.mock-metric.gold { color: var(--gold); }
.mock-log {
    background: var(--d-base);
    border: 1px solid var(--d-border);
    border-radius: 7px;
    padding: 0.7rem 0.85rem;
    font-family: var(--font-mono);
    font-size: 0.68rem;
    line-height: 1.7;
    color: var(--d-text-2);
}
.mock-log .muted { color: var(--d-text-3); }
.mock-log .ok { color: var(--green); }
.mock-log .blk { color: #d98a8a; }

/* ══════════════════════════════════════════════════════════════
   LIGHT SECTIONS
   ══════════════════════════════════════════════════════════════ */
section { position: relative; }
.sec { padding: var(--pad-section) 0; }
.sec.cream { background: var(--l-cream); }
.sec.paper { background: var(--l-paper); }

.sec-head { max-width: 60ch; margin-bottom: 3.5rem; }
.sec-head.center { margin-left: auto; margin-right: auto; text-align: center; }
.sec-head .eyebrow { margin-bottom: 1.2rem; }
.sec-head h2 { font-size: clamp(2rem, 4vw, 3.1rem); color: var(--l-text); margin-bottom: 1.1rem; }
.sec-head p { font-size: 1.12rem; color: var(--l-text-2); }
.sec-head.center .eyebrow { justify-content: center; }
.sec-head.center .eyebrow::before { display: none; }

/* ── Trust bar ── */
.trustbar {
    background: var(--d-base);
    border-top: 1px solid var(--d-border);
    padding: 2.2rem 0;
}
.trustbar .wrap { display: flex; align-items: center; justify-content: center; gap: 3rem; flex-wrap: wrap; }
.trustbar .label { font-family: var(--font-mono); font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.14em; color: var(--d-text-3); }
.trustbar .logos { display: flex; gap: 2.5rem; align-items: center; flex-wrap: wrap; }
.trustbar .logo {
    font-family: var(--font-display);
    font-weight: 600;
    font-size: 1.15rem;
    color: var(--d-text-2);
    opacity: 0.75;
    letter-spacing: 0.02em;
}

/* ── Thesis / problem ── */
.thesis-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 5rem; align-items: center; }
.thesis-grid .big-quote {
    font-family: var(--font-display);
    font-weight: 500;
    font-size: clamp(1.7rem, 3vw, 2.5rem);
    line-height: 1.25;
    color: var(--l-text);
    letter-spacing: -0.01em;
}
.thesis-grid .big-quote em { font-style: normal; color: var(--forest); position: relative; }
.thesis-grid .big-quote em::after {
    content: ''; position: absolute; left: 0; right: 0; bottom: 0.08em; height: 0.32em;
    background: rgba(var(--green-rgb), 0.35); z-index: -1;
}
.thesis-points { display: flex; flex-direction: column; gap: 1.6rem; }
.thesis-point { display: flex; gap: 1rem; }
.thesis-point .ico {
    flex-shrink: 0; width: 42px; height: 42px; border-radius: 9px;
    background: rgba(var(--green-rgb), 0.12);
    display: grid; place-items: center; color: var(--forest);
}
.thesis-point .ico svg { width: 22px; height: 22px; }
.thesis-point h4 { font-family: var(--font-display); font-weight: 600; font-size: 1.12rem; color: var(--l-text); margin-bottom: 0.25rem; }
.thesis-point p { font-size: 0.96rem; color: var(--l-text-2); }

/* ── Features grid ── */
.feature-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; }
.feature-card {
    background: var(--l-card);
    border: 1px solid var(--l-border);
    border-radius: 12px;
    padding: 2rem 1.8rem;
    transition: transform 0.2s, box-shadow 0.2s, border-color 0.2s;
}
.feature-card:hover { transform: translateY(-4px); box-shadow: 0 18px 48px rgba(58, 74, 63, 0.12); border-color: rgba(var(--green-rgb), 0.4); }
.feature-card .ico {
    width: 48px; height: 48px; border-radius: 11px;
    background: linear-gradient(140deg, var(--forest), #2b372d);
    display: grid; place-items: center; color: var(--cream);
    margin-bottom: 1.4rem;
}
.feature-card .ico svg { width: 24px; height: 24px; }
.feature-card h3 { font-size: 1.28rem; color: var(--l-text); margin-bottom: 0.6rem; }
.feature-card p { font-size: 0.97rem; color: var(--l-text-2); }
.feature-card .tag {
    display: inline-block; margin-top: 1.1rem;
    font-family: var(--font-mono); font-size: 0.7rem; text-transform: uppercase; letter-spacing: 0.08em;
    color: var(--gold);
}

/* ── How it works ── */
.steps { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.5rem; position: relative; }
.steps::before {
    content: ''; position: absolute; top: 26px; left: 8%; right: 8%; height: 1px;
    background: repeating-linear-gradient(to right, rgba(var(--forest-rgb), 0.3) 0 8px, transparent 8px 16px);
    z-index: 0;
}
.step { position: relative; z-index: 1; text-align: center; }
.step .num {
    width: 54px; height: 54px; margin: 0 auto 1.3rem;
    border-radius: 50%;
    background: var(--l-paper);
    border: 1px solid var(--forest);
    display: grid; place-items: center;
    font-family: var(--font-display); font-weight: 700; font-size: 1.3rem; color: var(--forest);
}
.sec.cream .step .num { background: var(--l-cream); }
.step h4 { font-family: var(--font-display); font-weight: 600; font-size: 1.15rem; color: var(--l-text); margin-bottom: 0.5rem; }
.step p { font-size: 0.92rem; color: var(--l-text-2); padding: 0 0.5rem; }

/* ── Privacy / dark break ── */
.darkbreak {
    background: var(--d-base);
    color: var(--d-text);
    position: relative;
    overflow: hidden;
}
.darkbreak .hero-bg { z-index: 0; }
.darkbreak .wrap { position: relative; z-index: 1; }
.darkbreak .inner { display: grid; grid-template-columns: 1fr 1fr; gap: 5rem; align-items: center; }
.darkbreak .eyebrow { margin-bottom: 1.3rem; }
.darkbreak h2 { font-size: clamp(2rem, 4vw, 3.1rem); color: var(--d-text); margin-bottom: 1.3rem; }
.darkbreak p { color: var(--d-text-2); font-size: 1.08rem; margin-bottom: 1rem; }
.guarantee-list { list-style: none; margin-top: 2rem; display: flex; flex-direction: column; gap: 1rem; }
.guarantee-list li { display: flex; gap: 0.8rem; align-items: flex-start; color: var(--d-text); font-size: 1rem; }
.guarantee-list .check {
    flex-shrink: 0; width: 24px; height: 24px; border-radius: 50%;
    background: rgba(var(--green-rgb), 0.16); color: var(--green);
    display: grid; place-items: center; margin-top: 1px;
}
.guarantee-list .check svg { width: 14px; height: 14px; }

.zerobadge {
    background: var(--d-raised);
    border: 1px solid var(--d-border-2);
    border-radius: 16px;
    padding: 3rem;
    text-align: center;
    box-shadow: 0 30px 70px rgba(0,0,0,0.5);
}
.zerobadge .huge {
    font-family: var(--font-display); font-weight: 900;
    font-size: clamp(5rem, 12vw, 8rem); line-height: 1;
    background: linear-gradient(160deg, var(--green), var(--gold));
    -webkit-background-clip: text; background-clip: text; color: transparent;
}
.zerobadge .cap { font-family: var(--font-mono); font-size: 0.8rem; text-transform: uppercase; letter-spacing: 0.16em; color: var(--d-text-2); margin-top: 0.8rem; }
.zerobadge .sub { color: var(--d-text-3); font-size: 0.92rem; margin-top: 1.4rem; }

/* ── Stats strip ── */
.stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 2rem; }
.stat { text-align: center; }
.stat .n {
    font-family: var(--font-display); font-weight: 700;
    font-size: clamp(2.4rem, 4.5vw, 3.6rem); color: var(--forest); line-height: 1;
}
.stat .n .unit { color: var(--green); }
.stat .l { font-size: 0.9rem; color: var(--l-text-2); margin-top: 0.6rem; font-family: var(--font-mono); letter-spacing: 0.03em; }

/* ── Testimonial ── */
.testimonial { max-width: 60ch; margin: 0 auto; text-align: center; }
.testimonial .quote {
    font-family: var(--font-display); font-weight: 500;
    font-size: clamp(1.5rem, 3vw, 2.3rem); line-height: 1.3; color: var(--l-text);
    letter-spacing: -0.01em;
}
.testimonial .mark { color: var(--gold); font-size: 3rem; line-height: 0; font-family: Georgia, serif; }
.testimonial .who { margin-top: 2rem; display: flex; align-items: center; justify-content: center; gap: 0.9rem; }
.testimonial .who .av { width: 46px; height: 46px; border-radius: 50%; background: linear-gradient(140deg, var(--forest), var(--green)); }
.testimonial .who .meta { text-align: left; }
.testimonial .who .nm { font-weight: 600; color: var(--l-text); font-size: 0.95rem; }
.testimonial .who .rl { font-size: 0.85rem; color: var(--l-text-3); }

/* ── Final CTA ── */
.cta-final {
    background: linear-gradient(150deg, var(--forest) 0%, var(--espresso) 100%);
    color: var(--cream);
    position: relative;
    overflow: hidden;
}
.cta-final::before {
    content: ''; position: absolute; inset: 0;
    background: radial-gradient(700px 400px at 80% 0%, rgba(var(--green-rgb), 0.25), transparent 60%);
}
.cta-final .wrap { position: relative; text-align: center; }
.cta-final h2 { font-size: clamp(2.2rem, 5vw, 3.8rem); margin-bottom: 1.2rem; }
.cta-final h2 .dot { color: var(--gold); }
.cta-final p { font-size: 1.15rem; color: rgba(235, 228, 212, 0.8); max-width: 50ch; margin: 0 auto 2.6rem; }
.cta-final .hero-cta { justify-content: center; }

/* ── Footer ── */
.footer {
    background: var(--d-base);
    border-top: 1px solid var(--d-border);
    color: var(--d-text-2);
    padding: 4.5rem 0 2.5rem;
}
.footer-grid { display: grid; grid-template-columns: 1.6fr 1fr 1fr 1fr; gap: 3rem; margin-bottom: 3.5rem; }
.footer .brand { margin-bottom: 1.2rem; }
.footer .blurb { font-size: 0.92rem; color: var(--d-text-3); max-width: 32ch; }
.footer h5 { font-family: var(--font-mono); font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.12em; color: var(--d-text-3); margin-bottom: 1.1rem; }
.footer ul { list-style: none; display: flex; flex-direction: column; gap: 0.7rem; }
.footer ul a { font-size: 0.92rem; color: var(--d-text-2); transition: color 0.16s; }
.footer ul a:hover { color: var(--green); }
.footer-base {
    border-top: 1px solid var(--d-border);
    padding-top: 1.8rem;
    display: flex; justify-content: space-between; align-items: center; gap: 1rem; flex-wrap: wrap;
    font-size: 0.84rem; color: var(--d-text-3);
}
.footer-base .lockup { font-family: var(--font-mono); letter-spacing: 0.04em; }

/* ── Reveal on scroll ── */
.reveal { opacity: 0; transform: translateY(24px); transition: opacity 0.7s ease, transform 0.7s ease; }
.reveal.in { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) {
    .reveal { opacity: 1; transform: none; transition: none; }
    html { scroll-behavior: auto; }
}

/* ══════════════════════════════════════════════════════════════
   RESPONSIVE
   ══════════════════════════════════════════════════════════════ */
@media (max-width: 900px) {
    .nav-links { display: none; }
    .hero-b .grid, .thesis-grid, .darkbreak .inner { grid-template-columns: 1fr; gap: 3rem; }
    .feature-grid { grid-template-columns: 1fr 1fr; }
    .steps { grid-template-columns: 1fr 1fr; gap: 2.5rem; }
    .steps::before { display: none; }
    .stats { grid-template-columns: 1fr 1fr; gap: 2.5rem; }
    .footer-grid { grid-template-columns: 1fr 1fr; gap: 2rem; }
    .hero-b .mock-wrap { order: -1; }
}
@media (max-width: 560px) {
    .wrap { padding: 0 1.3rem; }
    .feature-grid, .stats { grid-template-columns: 1fr; }
    .hero-trust { gap: 1rem; }
    .hero-c .statement-foot { flex-direction: column; align-items: flex-start; }
    .nav-actions .nav-signin { display: none; }
}

/* ══════════════════════════════════════════════════════════════
   CONTACT FORM
   ══════════════════════════════════════════════════════════════ */
.contact-form { display: flex; flex-direction: column; gap: 1.5rem; }
.contact-form .field { display: flex; flex-direction: column; gap: 0.5rem; }
.contact-form label { font-size: 0.85rem; font-weight: 600; letter-spacing: 0.06em; text-transform: uppercase; color: var(--text-muted); }
.contact-form input,
.contact-form textarea {
    background: rgba(255,255,255,0.04);
    border: 1px solid rgba(255,255,255,0.12);
    border-radius: 8px;
    color: var(--text);
    font-family: var(--font-sans);
    font-size: 1rem;
    padding: 0.75rem 1rem;
    transition: border-color 0.2s;
    width: 100%;
    box-sizing: border-box;
}
.contact-form input:focus,
.contact-form textarea:focus {
    border-color: var(--accent);
    outline: none;
}
.contact-form textarea { resize: vertical; min-height: 7rem; }
.form-error {
    background: rgba(220,60,60,0.12);
    border: 1px solid rgba(220,60,60,0.3);
    border-radius: 8px;
    color: #e88;
    font-size: 0.9rem;
    padding: 0.75rem 1rem;
    margin-bottom: 0.5rem;
}
.contact-success { text-align: center; padding: 3rem 0; }
.contact-success h1 { margin-bottom: 1rem; }
.contact-success .btn { margin-top: 2rem; }
.contact-section { min-height: 100vh; display: flex; align-items: center; background: var(--d-base); color: var(--d-text); }
.contact-wrap { max-width: 640px; margin: 0 auto; padding-top: 6rem; padding-bottom: 4rem; }
.contact-lead { margin-bottom: 2.5rem; }
.nav-links a.active { color: var(--accent); }
