/* latin-ext */
@font-face {
  font-family: 'Instrument Serif';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../assets/fonts/8b8982bd-758f-444a-acfc-b32dd864e10c.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: 'Instrument Serif';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../assets/fonts/d261c4f9-7260-4e2a-9472-0439f488ade1.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: 'Inter';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../assets/fonts/d03eeda2-e68c-4cf0-87f0-7de58de850c6.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: 'Inter';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../assets/fonts/cc51ad2f-7846-4958-b822-c5730a91d01f.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* greek-ext */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../assets/fonts/94213162-492d-464d-be4b-88ddefe6549f.woff2") format('woff2');
  unicode-range: U+1F00-1FFF;
}
/* greek */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../assets/fonts/01f255b6-2e4b-41f6-8af2-ee4287ba3df4.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: 'Inter';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../assets/fonts/19824b71-3f5e-407e-9304-e887e31c8a08.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: 'Inter';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../assets/fonts/0feda81a-c8df-4617-aa66-1a0909893aca.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: 'Inter';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../assets/fonts/ac58623a-96fb-490c-9caf-ab345e7aba56.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: 'Inter';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../assets/fonts/d03eeda2-e68c-4cf0-87f0-7de58de850c6.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: 'Inter';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../assets/fonts/cc51ad2f-7846-4958-b822-c5730a91d01f.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* greek-ext */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../assets/fonts/94213162-492d-464d-be4b-88ddefe6549f.woff2") format('woff2');
  unicode-range: U+1F00-1FFF;
}
/* greek */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../assets/fonts/01f255b6-2e4b-41f6-8af2-ee4287ba3df4.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: 'Inter';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../assets/fonts/19824b71-3f5e-407e-9304-e887e31c8a08.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: 'Inter';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../assets/fonts/0feda81a-c8df-4617-aa66-1a0909893aca.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: 'Inter';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../assets/fonts/ac58623a-96fb-490c-9caf-ab345e7aba56.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: 'Inter';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../assets/fonts/d03eeda2-e68c-4cf0-87f0-7de58de850c6.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: 'Inter';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../assets/fonts/cc51ad2f-7846-4958-b822-c5730a91d01f.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* greek-ext */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../assets/fonts/94213162-492d-464d-be4b-88ddefe6549f.woff2") format('woff2');
  unicode-range: U+1F00-1FFF;
}
/* greek */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../assets/fonts/01f255b6-2e4b-41f6-8af2-ee4287ba3df4.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: 'Inter';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../assets/fonts/19824b71-3f5e-407e-9304-e887e31c8a08.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: 'Inter';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../assets/fonts/0feda81a-c8df-4617-aa66-1a0909893aca.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: 'Inter';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../assets/fonts/ac58623a-96fb-490c-9caf-ab345e7aba56.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: 'Inter';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("../assets/fonts/d03eeda2-e68c-4cf0-87f0-7de58de850c6.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: 'Inter';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("../assets/fonts/cc51ad2f-7846-4958-b822-c5730a91d01f.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* greek-ext */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("../assets/fonts/94213162-492d-464d-be4b-88ddefe6549f.woff2") format('woff2');
  unicode-range: U+1F00-1FFF;
}
/* greek */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("../assets/fonts/01f255b6-2e4b-41f6-8af2-ee4287ba3df4.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: 'Inter';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("../assets/fonts/19824b71-3f5e-407e-9304-e887e31c8a08.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: 'Inter';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("../assets/fonts/0feda81a-c8df-4617-aa66-1a0909893aca.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: 'Inter';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("../assets/fonts/ac58623a-96fb-490c-9caf-ab345e7aba56.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: 'Inter';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url("../assets/fonts/d03eeda2-e68c-4cf0-87f0-7de58de850c6.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: 'Inter';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url("../assets/fonts/cc51ad2f-7846-4958-b822-c5730a91d01f.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* greek-ext */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url("../assets/fonts/94213162-492d-464d-be4b-88ddefe6549f.woff2") format('woff2');
  unicode-range: U+1F00-1FFF;
}
/* greek */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url("../assets/fonts/01f255b6-2e4b-41f6-8af2-ee4287ba3df4.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: 'Inter';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url("../assets/fonts/19824b71-3f5e-407e-9304-e887e31c8a08.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: 'Inter';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url("../assets/fonts/0feda81a-c8df-4617-aa66-1a0909893aca.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: 'Inter';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url("../assets/fonts/ac58623a-96fb-490c-9caf-ab345e7aba56.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: 'JetBrains Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../assets/fonts/3d8e243e-166e-49e5-8282-35b97736f3a0.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: 'JetBrains Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../assets/fonts/2aca8e16-6ae1-49df-922a-384b0b4d9b8a.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* greek */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../assets/fonts/5b477d9d-aeed-49fd-8cd3-db4fd912f3f0.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: 'JetBrains Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../assets/fonts/32baaf48-9ec1-4c7e-8195-cb9eaa723087.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: 'JetBrains Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../assets/fonts/483428a0-f952-4dbb-80f9-810198f3e559.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: 'JetBrains Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../assets/fonts/d117eda1-737e-49e6-98c4-2ab976cb7ad6.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: 'JetBrains Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../assets/fonts/3d8e243e-166e-49e5-8282-35b97736f3a0.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: 'JetBrains Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../assets/fonts/2aca8e16-6ae1-49df-922a-384b0b4d9b8a.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* greek */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../assets/fonts/5b477d9d-aeed-49fd-8cd3-db4fd912f3f0.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: 'JetBrains Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../assets/fonts/32baaf48-9ec1-4c7e-8195-cb9eaa723087.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: 'JetBrains Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../assets/fonts/483428a0-f952-4dbb-80f9-810198f3e559.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: 'JetBrains Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../assets/fonts/d117eda1-737e-49e6-98c4-2ab976cb7ad6.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{
  --blue-50:#eef5fc; --blue-100:#d2e3f7; --blue-200:#a5c8ef; --blue-300:#79ade7;
  --blue-400:#4d92df; --blue-500:#206bc4; --blue-600:#1c60b0; --blue-700:#19549b;
  --blue-800:#0d2b48; --blue-900:#06151f;
  --gray-50:#f8fafc; --gray-100:#f1f5f9; --gray-200:#e2e8f0; --gray-300:#cbd5e1;
  --gray-400:#94a3b8; --gray-500:#64748b; --gray-600:#475569; --gray-700:#334155;
  --gray-800:#1e293b; --gray-900:#0f172a;
  --bg:#fff; --bg-alt:#f6f8fb; --bg-warm:#f5f1ea;
  --border:#e6e7e9; --border-strong:#d3d7de;
  --fg:#0f172a; --fg-secondary:#334155; --fg-muted:#64748b;
  --success:#2fb344; --success-bg:#e8f6ec; --success-fg:#1f7a2c;
  --warning:#f59f00; --warning-bg:#fdf2da; --warning-fg:#8a5a00;
  --danger:#d63939; --danger-bg:#fbe5e5; --danger-fg:#8c1f1f;
  --info-bg:#e6f1fb; --info-fg:#1f5e91;
  --r-3:6px; --r-4:8px; --r-5:12px; --r-6:16px; --r-full:999px;
  --shadow-xs:0 1px 2px rgba(15,25,40,.06);
  --shadow-sm:0 1px 3px rgba(15,25,40,.08),0 1px 2px rgba(15,25,40,.04);
  --shadow-md:0 4px 12px rgba(15,25,40,.10);
  --shadow-lg:0 24px 60px -20px rgba(15,25,40,.25),0 8px 20px -8px rgba(15,25,40,.12);
  --font-sans:"Inter","Segoe UI",system-ui,sans-serif;
  --font-mono:"JetBrains Mono",ui-monospace,Menlo,monospace;
  --font-serif:"Instrument Serif",Georgia,serif;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);font-family:var(--font-sans);color:var(--fg);font-size:15px;line-height:1.55;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer}
img,svg{display:block}
code{font-family:var(--font-mono);font-size:.85em}

/* ===== Layout ===== */
.wrap{max-width:1240px;margin:0 auto;padding:0 32px}
.eyebrow{font-size:11px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--blue-500)}
.sec-head{text-align:center;max-width:680px;margin:0 auto 56px}
.sec-head h2{font-size:42px;font-weight:600;letter-spacing:-.022em;line-height:1.1;margin:14px 0 14px}
.sec-head p{font-size:17px;color:var(--fg-secondary);margin:0;line-height:1.55}
.section{padding:96px 0}
.section-sm{padding:72px 0}

/* ===== Header ===== */
header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.85);backdrop-filter:blur(14px);border-bottom:1px solid var(--border)}
.nav{display:flex;align-items:center;justify-content:space-between;height:68px}
.brand{display:flex;align-items:center;gap:10px;font-weight:700;font-size:18px;letter-spacing:-.015em}
.brand .name b{color:var(--fg)}
.brand .name span{color:var(--blue-500)}
.nav-links{display:flex;align-items:center;gap:32px;font-size:14px;color:var(--fg-secondary);font-weight:500}
.nav-links a:hover{color:var(--fg)}
.nav-cta{display:flex;align-items:center;gap:10px}

/* ===== Buttons ===== */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 18px;font:600 14px var(--font-sans);color:var(--fg);background:#fff;border:1px solid var(--border-strong);border-radius:var(--r-3);transition:all .15s ease;white-space:nowrap}
.btn:hover{background:var(--bg-alt);border-color:var(--gray-400)}
.btn.pri{background:var(--blue-500);border-color:var(--blue-500);color:#fff;box-shadow:0 1px 2px rgba(32,107,196,.25),inset 0 1px 0 rgba(255,255,255,.18)}
.btn.pri:hover{background:var(--blue-600);border-color:var(--blue-600)}
.btn.lg{padding:13px 22px;font-size:15px}
.btn.gh{background:transparent;border-color:transparent;color:var(--fg-secondary)}
.btn.gh:hover{background:var(--bg-alt);color:var(--fg)}
.btn .ic{width:16px;height:16px}

/* ===== Logo SVG inline ===== */
.tslogo{flex-shrink:0}

/* ===== Hero ===== */
.hero{padding:72px 0 64px;background:linear-gradient(180deg,#fbfcfe 0%,#fff 80%);position:relative;overflow:hidden}
.hero::before{content:"";position:absolute;top:-160px;right:-160px;width:520px;height:520px;border-radius:50%;background:radial-gradient(circle,rgba(32,107,196,.06) 0%,transparent 70%);pointer-events:none}
.hero-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;position:relative}
.hero-pill{display:inline-flex;align-items:center;gap:8px;padding:5px 12px 5px 6px;background:#fff;border:1px solid var(--border);border-radius:var(--r-full);font-size:12px;color:var(--fg-secondary);font-weight:500;box-shadow:var(--shadow-xs);margin-bottom:22px}
.hero-pill .dot{width:18px;height:18px;border-radius:50%;background:var(--success-bg);color:var(--success-fg);display:grid;place-items:center;font-weight:700;font-size:10px}
.hero h1{font-size:60px;font-weight:600;letter-spacing:-.03em;line-height:1.02;margin:0 0 22px;color:var(--fg);text-wrap:balance}
.hero h1 em{font-style:italic;font-family:var(--font-serif);font-weight:400;color:var(--blue-500);letter-spacing:-.01em;font-size:1em}
.hero .sub{font-size:18px;color:var(--fg-secondary);line-height:1.55;max-width:520px;margin:0 0 32px}
.hero-ctas{display:flex;gap:12px;margin-bottom:24px}
.hero-trust{display:flex;align-items:center;gap:10px;font-size:13.5px;color:var(--fg-secondary);font-weight:500;padding:14px 16px;background:#fff;border:1px solid var(--border);border-radius:var(--r-3);max-width:480px;box-shadow:var(--shadow-xs)}
.hero-trust b{color:var(--fg);font-weight:600}
.hero-trust .ic{width:18px;height:18px;color:var(--blue-500);flex-shrink:0}

/* ===== Hero dashboard mockup ===== */
.hero-mockup{position:relative;perspective:1400px}
.mockup{background:#fff;border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow-lg);overflow:hidden;transform:rotateY(-2deg) rotateX(2deg);transform-origin:center}
.mockup-bar{height:32px;background:#f8f9fa;border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 12px;gap:6px}
.mockup-bar i{width:10px;height:10px;border-radius:50%;background:#dde0e4}
.mockup-bar .url{margin-left:14px;padding:3px 10px;background:#fff;border:1px solid var(--border);border-radius:var(--r-full);font-family:var(--font-mono);font-size:10px;color:var(--fg-muted)}
.mockup-body{display:grid;grid-template-columns:160px 1fr;height:440px}
.mock-side{background:#fafbfc;border-right:1px solid var(--border);padding:14px 10px;display:flex;flex-direction:column;gap:3px}
.mock-side .br{display:flex;align-items:center;gap:8px;padding:4px 6px 14px;border-bottom:1px solid var(--border);margin-bottom:8px;font-size:11px;font-weight:700;letter-spacing:-.01em}
.mock-side .item{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:5px;font-size:11px;color:var(--fg-secondary);font-weight:500}
.mock-side .item.on{background:var(--blue-500);color:#fff}
.mock-side .item .dot{width:6px;height:6px;border-radius:50%;background:var(--border-strong)}
.mock-side .item.on .dot{background:#fff}
.mock-main{padding:18px;background:#fff;overflow:hidden}
.mm-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}
.mm-head h4{margin:0;font-size:14px;font-weight:600;letter-spacing:-.01em}
.mm-head .sub{font-size:10px;color:var(--fg-muted);margin-top:1px}
.kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:12px}
.kpi{padding:10px;border:1px solid var(--border);border-radius:5px}
.kpi .lbl{font-size:8.5px;color:var(--fg-muted);text-transform:uppercase;letter-spacing:.08em;font-weight:600}
.kpi .val{font-size:18px;font-weight:600;margin-top:2px;letter-spacing:-.01em}
.kpi .delta{font-size:9px;font-weight:600;margin-top:1px}
.kpi.suc .lbl,.kpi.suc .delta{color:var(--success-fg)}
.kpi.wrn .lbl,.kpi.wrn .delta{color:var(--warning-fg)}
.kpi.dng .lbl,.kpi.dng .delta{color:var(--danger-fg)}
.kpi.inf .lbl,.kpi.inf .delta{color:var(--info-fg)}
.roi{background:linear-gradient(135deg,#eef5fc 0%,#fff 70%);border:1px solid var(--border);border-radius:5px;padding:11px 12px;display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;font-size:10.5px}
.roi b{font-size:11px;color:var(--blue-500);font-weight:600}
.roi .roi-stats{display:flex;gap:14px}
.roi .roi-stats span{display:flex;flex-direction:column}
.roi .roi-stats b{font-size:13px;color:var(--blue-500)}
.roi .roi-stats em{font-style:normal;color:var(--fg-muted);font-size:8.5px;letter-spacing:.04em}

.mock-table{border:1px solid var(--border);border-radius:5px;font-size:10px;overflow:hidden}
.mock-table .thead{display:grid;grid-template-columns:1.5fr .8fr .8fr .8fr;background:#fafbfc;border-bottom:1px solid var(--border);padding:6px 10px;font-size:8.5px;text-transform:uppercase;letter-spacing:.06em;color:var(--fg-muted);font-weight:600}
.mock-table .row{display:grid;grid-template-columns:1.5fr .8fr .8fr .8fr;padding:7px 10px;border-bottom:1px solid var(--border);align-items:center}
.mock-table .row:last-child{border-bottom:0}
.mock-table .row b{font-weight:600;font-size:10.5px}
.mock-table .row .ms{color:var(--fg-muted);font-family:var(--font-mono);font-size:9px}
.bd{display:inline-flex;align-items:center;gap:4px;padding:1px 7px;border-radius:var(--r-full);font-size:9px;font-weight:600}
.bd.dot::before{content:"";width:5px;height:5px;border-radius:50%;background:currentColor}
.bd.suc{background:var(--success-bg);color:var(--success-fg)}
.bd.wrn{background:var(--warning-bg);color:var(--warning-fg)}
.bd.dng{background:var(--danger-bg);color:var(--danger-fg)}
.bd.inf{background:var(--info-bg);color:var(--info-fg)}

/* ===== Logos strip ===== */
.logos{padding:48px 0;background:var(--bg-alt);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.logos .label{text-align:center;font-size:13px;color:var(--fg-muted);margin-bottom:24px;font-weight:500}
.logos-row{display:flex;align-items:center;justify-content:center;gap:64px;flex-wrap:wrap;color:var(--fg-muted);font-weight:600;letter-spacing:-.005em;font-size:18px}
.logos-row span{opacity:.55;font-family:var(--font-serif);font-size:22px;letter-spacing:-.01em;font-weight:400;font-style:italic}

/* ===== Problem ===== */
.problem{background:var(--bg-warm);padding:96px 0}
.problem-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.problem h2{font-size:44px;font-weight:600;letter-spacing:-.022em;line-height:1.08;margin:14px 0 18px}
.problem h2 em{font-style:italic;font-family:var(--font-serif);font-weight:400;color:var(--blue-500);font-size:1em}
.problem p{font-size:17px;color:var(--fg-secondary);margin:0 0 24px;line-height:1.6}
.problem-list{display:flex;flex-direction:column;gap:12px;list-style:none;padding:0;margin:0 0 28px}
.problem-list li{display:flex;align-items:flex-start;gap:12px;font-size:15px;color:var(--fg-secondary)}
.problem-list li::before{content:"";width:18px;height:18px;border-radius:50%;background:#fff;border:1px solid var(--border);flex-shrink:0;margin-top:2px;display:grid;place-items:center;background-image:url("../assets/icons/icon-01.svg");background-size:10px;background-position:center;background-repeat:no-repeat}
.problem-list li b{color:var(--fg);font-weight:600}
.problem-img{background:#fff;border:1px solid var(--border);border-radius:12px;padding:24px;box-shadow:var(--shadow-md);position:relative}
.spreadsheet{font-family:var(--font-mono);font-size:11px;width:100%;border-collapse:collapse;color:var(--fg-secondary)}
.spreadsheet th,.spreadsheet td{padding:7px 10px;border:1px solid var(--border);text-align:left}
.spreadsheet th{background:#fafbfc;font-weight:600;color:var(--fg-muted);font-size:10px}
.spreadsheet td.exp{background:var(--danger-bg);color:var(--danger-fg);font-weight:600}
.spreadsheet td.risk{background:var(--warning-bg);color:var(--warning-fg);font-weight:600}
.scribble{position:absolute;top:-12px;right:30px;background:#fef4a8;color:#5a4a2a;font-family:var(--font-serif);font-style:italic;padding:8px 14px;border-radius:6px;font-size:14px;transform:rotate(-2.5deg);box-shadow:0 4px 12px rgba(0,0,0,.08)}

/* ===== Product preview ===== */
.preview-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.pcard{background:#fff;border:1px solid var(--border);border-radius:var(--r-5);padding:24px;display:flex;flex-direction:column;gap:16px;transition:transform .2s,box-shadow .2s,border-color .2s}
.pcard:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:var(--blue-200)}
.pcard .ttl{font-size:18px;font-weight:600;letter-spacing:-.012em}
.pcard .desc{font-size:14px;color:var(--fg-secondary);line-height:1.55;flex:1}
.pcard .vis{height:140px;border:1px solid var(--border);border-radius:var(--r-4);overflow:hidden;background:#fafbfc;padding:14px;display:flex;flex-direction:column;gap:7px;font-size:10px}
.pcard .more{font-size:13px;color:var(--blue-500);font-weight:600;display:flex;align-items:center;gap:4px}
.vis-row{display:flex;justify-content:space-between;align-items:center;padding:5px 8px;background:#fff;border:1px solid var(--border);border-radius:4px;font-size:10px}
.vis-bar{height:6px;background:var(--bg-alt);border-radius:var(--r-full);overflow:hidden}
.vis-bar i{display:block;height:100%}

/* ===== How it works ===== */
.how{background:var(--bg-alt);padding:96px 0}
.how-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;position:relative}
.how-grid::before{content:"";position:absolute;left:8%;right:8%;top:34px;height:1px;background:repeating-linear-gradient(to right,var(--border-strong) 0 4px,transparent 4px 10px)}
.step{background:#fff;border:1px solid var(--border);border-radius:var(--r-5);padding:24px;display:flex;flex-direction:column;gap:14px;position:relative}
.step .num{width:42px;height:42px;border-radius:var(--r-4);background:var(--blue-500);color:#fff;display:grid;place-items:center;font-weight:700;font-size:16px;letter-spacing:-.01em;font-family:var(--font-serif);font-style:italic}
.step h3{font-size:17px;font-weight:600;letter-spacing:-.01em;margin:0}
.step p{font-size:14px;color:var(--fg-secondary);margin:0;line-height:1.55}

/* ===== Feature grid ===== */
.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.fcard{padding:24px;background:#fff;border:1px solid var(--border);border-radius:var(--r-5);display:flex;flex-direction:column;gap:14px}
.fcard .ico{width:40px;height:40px;border-radius:var(--r-3);background:var(--blue-50);color:var(--blue-500);display:grid;place-items:center}
.fcard h3{font-size:16px;font-weight:600;letter-spacing:-.01em;margin:0}
.fcard p{font-size:14px;color:var(--fg-secondary);margin:0;line-height:1.55}

/* ===== Guarantee ===== */
.guarantee{padding:96px 0}
.guarantee-card{background:linear-gradient(135deg,var(--blue-800) 0%,var(--blue-500) 100%);border-radius:18px;padding:64px 56px;color:#fff;display:grid;grid-template-columns:1.4fr 1fr;gap:48px;align-items:center;position:relative;overflow:hidden}
.guarantee-card::before{content:"";position:absolute;top:-100px;right:-50px;width:380px;height:380px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.10) 0%,transparent 65%)}
.guarantee-card h2{font-size:38px;font-weight:600;letter-spacing:-.022em;line-height:1.1;margin:0 0 18px}
.guarantee-card p{font-size:16px;line-height:1.6;margin:0 0 20px;color:rgba(255,255,255,.85)}
.guarantee-list{margin:0 0 28px;padding:0;list-style:none;display:flex;flex-direction:column;gap:8px;font-size:14px;color:rgba(255,255,255,.85)}
.guarantee-list li{display:flex;gap:10px;align-items:flex-start}
.guarantee-list li::before{content:"";width:16px;height:16px;background:url("../assets/icons/icon-02.svg") center/contain no-repeat;flex-shrink:0;margin-top:2px}
.guarantee-stats{position:relative}
.gstat{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);border-radius:var(--r-4);padding:24px;backdrop-filter:blur(8px);margin-bottom:14px}
.gstat .big{font-size:48px;font-weight:600;letter-spacing:-.025em;line-height:1;font-family:var(--font-serif);font-style:italic}
.gstat .lbl{font-size:13px;color:rgba(255,255,255,.7);margin-top:4px}
.btn.on-dark{background:#fff;color:var(--blue-700);border-color:#fff}
.btn.on-dark:hover{background:rgba(255,255,255,.92)}
.btn.on-dark.gh{background:transparent;color:#fff;border-color:rgba(255,255,255,.3)}
.btn.on-dark.gh:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.6)}

/* ===== Portal ===== */
.portal{padding:96px 0;background:var(--bg-alt)}
.portal-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.portal h2{font-size:42px;font-weight:600;letter-spacing:-.022em;line-height:1.08;margin:14px 0 18px}
.portal h2 em{font-style:italic;font-family:var(--font-serif);font-weight:400;color:var(--blue-500);font-size:1em}
.portal p{font-size:17px;color:var(--fg-secondary);margin:0 0 24px;line-height:1.55}
.portal-list{padding:0;margin:0;list-style:none;display:flex;flex-direction:column;gap:14px}
.portal-list li{display:flex;align-items:flex-start;gap:14px}
.portal-list li .ic{width:32px;height:32px;border-radius:var(--r-3);background:var(--blue-50);color:var(--blue-500);display:grid;place-items:center;flex-shrink:0}
.portal-list li b{display:block;font-size:15px;font-weight:600;color:var(--fg);margin-bottom:2px}
.portal-list li span{font-size:14px;color:var(--fg-secondary);line-height:1.5}
.phone-stage{display:flex;justify-content:center;align-items:center;position:relative;min-height:560px}
.phone{width:300px;height:600px;border-radius:36px;background:#1a1d23;padding:9px;box-shadow:0 30px 80px -20px rgba(15,25,40,.4)}
.phone-inner{width:100%;height:100%;background:#fff;border-radius:28px;overflow:hidden;display:flex;flex-direction:column;position:relative}
.phone-notch{position:absolute;top:6px;left:50%;transform:translateX(-50%);width:84px;height:20px;background:#1a1d23;border-radius:13px;z-index:2}
.phone-stat{height:34px;display:flex;justify-content:space-between;align-items:flex-end;padding:0 22px 5px;font-size:11px;font-weight:600}
.phone-hd{padding:11px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:8px}
.phone-hd .l-mark{display:flex;align-items:center;gap:6px;font-weight:700;font-size:12px}
.phone-hd .secure{margin-left:auto;display:flex;align-items:center;gap:4px;font-size:10px;color:var(--success-fg)}
.phone-body{flex:1;padding:16px 18px;overflow:hidden}
.phone-body h4{font-size:16px;font-weight:600;letter-spacing:-.015em;margin:6px 0 6px;line-height:1.25}
.phone-body p{font-size:11.5px;color:var(--fg-secondary);margin:0 0 14px;line-height:1.5}
.phone-alert{padding:10px 11px;background:var(--warning-bg);border-radius:6px;display:flex;gap:9px;align-items:flex-start;margin-bottom:14px;font-size:10.5px;line-height:1.5}
.phone-alert b{color:var(--warning-fg);display:block;margin-bottom:2px}
.phone-alert .sub{color:var(--fg-secondary)}
.phone-drop{border:2px dashed var(--blue-500);border-radius:10px;padding:20px 14px;background:var(--blue-50);text-align:center}
.phone-drop .ic{width:38px;height:38px;border-radius:50%;background:#fff;display:inline-grid;place-items:center;color:var(--blue-500);margin-bottom:8px}
.phone-drop .ttl{font-size:11.5px;font-weight:600}
.phone-drop .sub{font-size:9.5px;color:var(--fg-muted);margin-top:2px}
.phone-drop .btn{margin-top:10px;width:100%;font-size:11px;padding:7px 12px}
.phone-foot{padding:8px 16px 12px;text-align:center;font-size:9px;color:var(--fg-muted);border-top:1px solid var(--border)}
.email-card{position:absolute;bottom:30px;left:-30px;background:#fff;border:1px solid var(--border);border-radius:var(--r-4);box-shadow:var(--shadow-md);padding:14px 16px;width:240px;transform:rotate(-3deg);font-size:11.5px}
.email-card .meta{font-size:10px;color:var(--fg-muted);font-family:var(--font-mono);margin-bottom:5px}
.email-card b{display:block;margin-bottom:6px;font-size:12px;font-weight:600;letter-spacing:-.01em}
.email-card .bd{margin-top:4px}

/* ===== Audit ===== */
.audit{padding:96px 0}
.audit-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.audit-feed{background:#fff;border:1px solid var(--border);border-radius:var(--r-5);overflow:hidden;box-shadow:var(--shadow-md)}
.audit-feed .head{padding:14px 18px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;background:#fafbfc}
.audit-feed .head b{font-size:14px;font-weight:600}
.audit-feed .head .pill{font-size:11px;color:var(--fg-muted);padding:3px 9px;background:#fff;border:1px solid var(--border);border-radius:var(--r-full)}
.aud-row{display:grid;grid-template-columns:auto 1fr auto;gap:12px;padding:11px 18px;border-bottom:1px solid var(--border);align-items:center;font-size:12.5px}
.aud-row:last-child{border-bottom:0}
.aud-row .av{width:28px;height:28px;border-radius:50%;display:grid;place-items:center;font-weight:600;font-size:10px}
.aud-row .av.s{background:var(--bg-alt);color:var(--fg-muted)}
.aud-row .av.a{background:var(--blue-50);color:var(--blue-700)}
.aud-row .av.b{background:#fdf2da;color:#8a5a00}
.aud-row .av.c{background:#e8f6ec;color:#1f7a2c}
.aud-row .body b{font-weight:600;font-size:13px;display:block}
.aud-row .body .m{font-size:11px;color:var(--fg-muted);margin-top:1px;font-family:var(--font-mono)}
.aud-row .ts{font-size:11px;color:var(--fg-muted);font-family:var(--font-mono);text-align:right}

/* ===== Workspace ===== */
.workspace{padding:96px 0;background:var(--bg-alt)}
.workspace-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.workspace h2{font-size:42px;font-weight:600;letter-spacing:-.022em;line-height:1.08;margin:14px 0 18px}
.workspace h2 em{font-style:italic;font-family:var(--font-serif);font-weight:400;color:var(--blue-500);font-size:1em}
.workspace p{font-size:17px;color:var(--fg-secondary);margin:0 0 24px;line-height:1.55}
.wsfeat{display:grid;grid-template-columns:1fr 1fr;gap:18px 28px;margin-top:8px}
.wsfeat div{display:flex;gap:10px;align-items:flex-start;font-size:14px;color:var(--fg-secondary)}
.wsfeat div b{display:block;color:var(--fg);font-weight:600;font-size:14px;margin-bottom:1px}
.wsfeat .ic{width:18px;height:18px;color:var(--blue-500);flex-shrink:0;margin-top:2px}
.org-card{background:#fff;border:1px solid var(--border);border-radius:var(--r-5);padding:24px;box-shadow:var(--shadow-md)}
.org-row{display:flex;align-items:center;gap:14px;padding:14px 0;border-bottom:1px solid var(--border)}
.org-row:last-child{border-bottom:0}
.org-row .lab{flex:0 0 130px;font-size:12px;color:var(--fg-muted);font-weight:600;letter-spacing:.04em}
.org-row .val{flex:1;font-size:14px;font-weight:500}
.org-row .av-org{width:36px;height:36px;border-radius:var(--r-3);background:var(--blue-500);color:#fff;display:grid;place-items:center;font-weight:700;font-size:14px}
.org-roles{display:flex;gap:6px;flex-wrap:wrap}
.role-pill{display:inline-flex;align-items:center;gap:6px;padding:3px 9px;background:var(--bg-alt);border:1px solid var(--border);border-radius:var(--r-full);font-size:11px;color:var(--fg-secondary)}
.role-pill b{font-size:11px;font-weight:600;color:var(--fg)}

/* ===== Pricing ===== */
.pricing{padding:96px 0}
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;max-width:1080px;margin:0 auto}
.plan{background:#fff;border:1px solid var(--border);border-radius:var(--r-5);padding:32px 28px;display:flex;flex-direction:column;gap:18px;position:relative;transition:transform .2s,box-shadow .2s}
.plan:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
.plan.fea{border-color:var(--blue-500);box-shadow:0 0 0 4px var(--blue-50),var(--shadow-md);transform:translateY(-8px)}
.plan.fea:hover{transform:translateY(-11px)}
.plan-ribbon{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--blue-500);color:#fff;font-size:11px;font-weight:600;padding:5px 14px;border-radius:var(--r-full);letter-spacing:.04em}
.plan h3{font-size:16px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;margin:0;color:var(--fg-secondary)}
.plan .price{display:flex;align-items:baseline;gap:6px}
.plan .price b{font-size:48px;font-weight:600;letter-spacing:-.025em;line-height:1}
.plan .price span{font-size:14px;color:var(--fg-muted);font-weight:500}
.plan .desc{font-size:14px;color:var(--fg-secondary);line-height:1.5;margin:0}
.plan ul{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:10px;font-size:13.5px;color:var(--fg-secondary)}
.plan ul li{display:flex;gap:10px;align-items:flex-start}
.plan ul li::before{content:"";width:14px;height:14px;flex-shrink:0;margin-top:3px;background:url("../assets/icons/icon-03.svg") center/contain no-repeat}
.plan .btn{width:100%}
.pricing-notes{max-width:780px;margin:32px auto 0;display:flex;flex-wrap:wrap;justify-content:center;gap:20px 36px;color:var(--fg-muted);font-size:13px;font-weight:500}
.pricing-notes span{display:flex;align-items:center;gap:6px}

/* ===== FAQ ===== */
.faq{padding:96px 0;background:var(--bg-alt)}
.faq-list{max-width:780px;margin:0 auto;display:flex;flex-direction:column;gap:10px}
.faq-item{background:#fff;border:1px solid var(--border);border-radius:var(--r-4);overflow:hidden;transition:border-color .15s}
.faq-item[open]{border-color:var(--blue-200);box-shadow:var(--shadow-xs)}
.faq-item summary{padding:20px 24px;font-size:16px;font-weight:600;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:24px;letter-spacing:-.005em;list-style:none}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"";width:22px;height:22px;border-radius:50%;background:var(--bg-alt);background-image:url("../assets/icons/icon-04.svg");background-size:12px;background-position:center;background-repeat:no-repeat;flex-shrink:0;transition:transform .2s}
.faq-item[open] summary::after{transform:rotate(180deg)}
.faq-item .ans{padding:0 24px 22px;font-size:14.5px;color:var(--fg-secondary);line-height:1.6}

/* ===== Final CTA ===== */
.final{padding:120px 0;text-align:center;background:linear-gradient(180deg,#fff 0%,#fbfcfe 100%);position:relative;overflow:hidden}
.final::before{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:800px;height:800px;border-radius:50%;background:radial-gradient(circle,rgba(32,107,196,.04) 0%,transparent 65%);pointer-events:none}
.final-inner{position:relative;max-width:680px;margin:0 auto}
.final h2{font-size:54px;font-weight:600;letter-spacing:-.025em;line-height:1.05;margin:0 0 22px;text-wrap:balance}
.final h2 em{font-style:italic;font-family:var(--font-serif);font-weight:400;color:var(--blue-500);font-size:1em}
.final p{font-size:18px;color:var(--fg-secondary);margin:0 0 32px}
.final-ctas{display:flex;justify-content:center;gap:12px;margin-bottom:24px}
.final .trust{font-size:13.5px;color:var(--fg-muted)}
.final .trust b{color:var(--fg);font-weight:600}

/* ===== Footer ===== */
footer{background:var(--blue-900);color:rgba(255,255,255,.7);padding:64px 0 40px;font-size:14px}
.foot-top{display:grid;grid-template-columns:2fr 1fr 1fr 1fr 1fr;gap:48px;margin-bottom:48px;padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,.08)}
.foot-brand{display:flex;flex-direction:column;gap:14px;max-width:280px}
.foot-brand .brand{color:#fff;font-size:17px}
.foot-brand .brand .name b{color:#fff}
.foot-brand .brand .name span{color:var(--blue-300)}
.foot-brand p{margin:0;font-size:13px;color:rgba(255,255,255,.55);line-height:1.55}
.foot-col h5{margin:0 0 14px;font-size:12px;font-weight:600;color:#fff;letter-spacing:.08em;text-transform:uppercase}
.foot-col a{display:block;margin-bottom:8px;font-size:13.5px;color:rgba(255,255,255,.55);transition:color .15s}
.foot-col a:hover{color:#fff}
.foot-bottom{display:flex;justify-content:space-between;align-items:flex-start;gap:48px}
.disclaimer{font-size:12.5px;color:rgba(255,255,255,.45);max-width:680px;line-height:1.55}
.disclaimer b{color:rgba(255,255,255,.6);font-weight:600}
.foot-meta{font-size:12px;color:rgba(255,255,255,.4);text-align:right;line-height:1.6}

/* ===== Responsive ===== */
@media (max-width:1080px){
  .hero-grid,.problem-grid,.portal-grid,.audit-grid,.workspace-grid{grid-template-columns:1fr;gap:48px}
  .preview-grid,.features-grid,.pricing-grid{grid-template-columns:1fr 1fr}
  .how-grid{grid-template-columns:1fr 1fr}
  .how-grid::before{display:none}
  .guarantee-card{grid-template-columns:1fr;padding:48px 36px}
  .foot-top{grid-template-columns:1fr 1fr 1fr;gap:32px}
  .foot-bottom{flex-direction:column;gap:24px}
}
@media (max-width:720px){
  .wrap{padding:0 20px}
  .nav-links{display:none}
  .section{padding:64px 0}
  .hero h1{font-size:42px}
  .sec-head h2,.problem h2,.portal h2,.workspace h2,.guarantee-card h2{font-size:32px}
  .final h2{font-size:38px}
  .preview-grid,.features-grid,.pricing-grid,.how-grid,.wsfeat{grid-template-columns:1fr}
  .plan.fea{transform:none}
  .hero-ctas,.final-ctas{flex-direction:column;align-items:stretch}
  .email-card{display:none}
}
