/* cyrillic-ext */
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url("../assets/fonts/dbf8e1d8-760d-4033-8fc8-d3c4645a4168.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url("../assets/fonts/b028f818-0b20-4131-bfcd-89876b72b0f1.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url("../assets/fonts/8ce313ca-a6c0-4b5a-b456-eeecd8aea24a.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url("../assets/fonts/9268368e-0938-45ce-ba2d-98f5cbc6dde2.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url("../assets/fonts/910338f2-859e-4fcc-9462-3b6445864e48.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../assets/fonts/dbf8e1d8-760d-4033-8fc8-d3c4645a4168.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../assets/fonts/b028f818-0b20-4131-bfcd-89876b72b0f1.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../assets/fonts/8ce313ca-a6c0-4b5a-b456-eeecd8aea24a.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../assets/fonts/9268368e-0938-45ce-ba2d-98f5cbc6dde2.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../assets/fonts/910338f2-859e-4fcc-9462-3b6445864e48.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../assets/fonts/dbf8e1d8-760d-4033-8fc8-d3c4645a4168.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../assets/fonts/b028f818-0b20-4131-bfcd-89876b72b0f1.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../assets/fonts/8ce313ca-a6c0-4b5a-b456-eeecd8aea24a.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../assets/fonts/9268368e-0938-45ce-ba2d-98f5cbc6dde2.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../assets/fonts/910338f2-859e-4fcc-9462-3b6445864e48.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../assets/fonts/dbf8e1d8-760d-4033-8fc8-d3c4645a4168.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../assets/fonts/b028f818-0b20-4131-bfcd-89876b72b0f1.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../assets/fonts/8ce313ca-a6c0-4b5a-b456-eeecd8aea24a.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../assets/fonts/9268368e-0938-45ce-ba2d-98f5cbc6dde2.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../assets/fonts/910338f2-859e-4fcc-9462-3b6445864e48.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("../assets/fonts/dbf8e1d8-760d-4033-8fc8-d3c4645a4168.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("../assets/fonts/b028f818-0b20-4131-bfcd-89876b72b0f1.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("../assets/fonts/8ce313ca-a6c0-4b5a-b456-eeecd8aea24a.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("../assets/fonts/9268368e-0938-45ce-ba2d-98f5cbc6dde2.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("../assets/fonts/910338f2-859e-4fcc-9462-3b6445864e48.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url("../assets/fonts/dbf8e1d8-760d-4033-8fc8-d3c4645a4168.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url("../assets/fonts/b028f818-0b20-4131-bfcd-89876b72b0f1.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url("../assets/fonts/8ce313ca-a6c0-4b5a-b456-eeecd8aea24a.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url("../assets/fonts/9268368e-0938-45ce-ba2d-98f5cbc6dde2.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url("../assets/fonts/910338f2-859e-4fcc-9462-3b6445864e48.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Geist Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../assets/fonts/fbc6db0d-766f-49bf-8b0f-cabd6d055d1b.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Geist Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../assets/fonts/5fcb8b8c-619f-41e1-b015-aa416167d13f.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* symbols2 */
@font-face {
  font-family: 'Geist Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../assets/fonts/5d9526e7-0f3f-4d22-9521-365fd04ad25d.woff2") format('woff2');
  unicode-range: U+2000-2001, U+2004-2008, U+200A, U+23B8-23BD, U+2500-259F;
}
/* vietnamese */
@font-face {
  font-family: 'Geist Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../assets/fonts/d47bb62f-5ed8-41de-8799-eb50d6531731.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Geist Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../assets/fonts/d84bffe8-f3e2-4b9e-bdbe-209cbe1a7efd.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Geist Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../assets/fonts/b63617bb-a0db-49a6-8524-78cefc5652d9.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Geist Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../assets/fonts/fbc6db0d-766f-49bf-8b0f-cabd6d055d1b.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Geist Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../assets/fonts/5fcb8b8c-619f-41e1-b015-aa416167d13f.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* symbols2 */
@font-face {
  font-family: 'Geist Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../assets/fonts/5d9526e7-0f3f-4d22-9521-365fd04ad25d.woff2") format('woff2');
  unicode-range: U+2000-2001, U+2004-2008, U+200A, U+23B8-23BD, U+2500-259F;
}
/* vietnamese */
@font-face {
  font-family: 'Geist Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../assets/fonts/d47bb62f-5ed8-41de-8799-eb50d6531731.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Geist Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../assets/fonts/d84bffe8-f3e2-4b9e-bdbe-209cbe1a7efd.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Geist Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../assets/fonts/b63617bb-a0db-49a6-8524-78cefc5652d9.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Geist Mono';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../assets/fonts/fbc6db0d-766f-49bf-8b0f-cabd6d055d1b.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Geist Mono';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../assets/fonts/5fcb8b8c-619f-41e1-b015-aa416167d13f.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* symbols2 */
@font-face {
  font-family: 'Geist Mono';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../assets/fonts/5d9526e7-0f3f-4d22-9521-365fd04ad25d.woff2") format('woff2');
  unicode-range: U+2000-2001, U+2004-2008, U+200A, U+23B8-23BD, U+2500-259F;
}
/* vietnamese */
@font-face {
  font-family: 'Geist Mono';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../assets/fonts/d47bb62f-5ed8-41de-8799-eb50d6531731.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Geist Mono';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../assets/fonts/d84bffe8-f3e2-4b9e-bdbe-209cbe1a7efd.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Geist Mono';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../assets/fonts/b63617bb-a0db-49a6-8524-78cefc5652d9.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: 'Instrument Serif';
  font-style: italic;
  font-weight: 400;
  font-display: swap;
  src: url("../assets/fonts/9e87a6d8-8993-47ee-9042-93854b214adc.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: italic;
  font-weight: 400;
  font-display: swap;
  src: url("../assets/fonts/c0ab134b-c1fb-4ec4-a417-d8acb616779b.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: 'Instrument Serif';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../assets/fonts/dd021ad1-d788-475f-b3ec-91f2e713ab2a.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/6f2c948e-bed9-4447-bc51-dbb12c5aa36f.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{
      /* Dark theme tokens — default */
      --bg:               #0a0d12;
      --bg-grad:          radial-gradient(1200px 700px at 85% -10%, rgba(245,184,0,.08), transparent 60%),
                          radial-gradient(900px 600px at -10% 110%, rgba(52,211,153,.06), transparent 60%),
                          #0a0d12;
      --surface-1:        #11151c;
      --surface-2:        #161b25;
      --surface-3:        #1c2230;
      --surface-hi:       #232a39;
      --border:           rgba(255,255,255,.06);
      --border-strong:    rgba(255,255,255,.12);
      --text:             #f1f3f7;
      --text-dim:         #9ca3af;
      --text-mute:        #6b7280;
      --text-faint:       #4b5263;

      --accent:           #f5b800;       /* warm gold */
      --accent-soft:      rgba(245,184,0,.12);
      --accent-strong:    #fbcb2a;
      --accent-ink:       #1a1208;

      --success:          #34d399;
      --success-soft:     rgba(52,211,153,.14);
      --info:             #60a5fa;
      --info-soft:        rgba(96,165,250,.14);
      --warning:          #fbbf24;
      --warning-soft:     rgba(251,191,36,.14);
      --danger:           #f87171;
      --danger-soft:      rgba(248,113,113,.14);
      --purple:           #a78bfa;
      --purple-soft:      rgba(167,139,250,.14);
      --teal:             #2dd4bf;
      --teal-soft:        rgba(45,212,191,.14);

      --r-xs: 6px;
      --r-sm: 10px;
      --r-md: 14px;
      --r-lg: 18px;
      --r-xl: 24px;

      --sidebar-w: 240px;
      --topbar-h:  64px;

      /* Mono/sans aliases */
      --font-sans: 'Geist', ui-sans-serif, system-ui, -apple-system, 'Helvetica Neue', Arial, sans-serif;
      --font-mono: 'Geist Mono', ui-monospace, SFMono-Regular, Menlo, monospace;
      --font-serif:'Instrument Serif', ui-serif, Georgia, serif;
    }

    [data-theme="light"]{
      --bg:               #f6f5f0;
      --bg-grad:          radial-gradient(1200px 700px at 85% -10%, rgba(245,184,0,.16), transparent 60%),
                          radial-gradient(900px 600px at -10% 110%, rgba(26,77,46,.05), transparent 60%),
                          #f6f5f0;
      --surface-1:        #ffffff;
      --surface-2:        #fbfaf6;
      --surface-3:        #f1ede2;
      --surface-hi:       #e8e2d2;
      --border:           rgba(20,15,8,.07);
      --border-strong:    rgba(20,15,8,.14);
      --text:             #1b1810;
      --text-dim:         #5a5446;
      --text-mute:        #8a8474;
      --text-faint:       #b0aa9a;
      --accent-ink:       #1a1208;
      --success:          #0c9a6a;
      --success-soft:     rgba(12,154,106,.14);
      --info:             #1d6fd1;
      --info-soft:        rgba(29,111,209,.12);
      --warning:          #b87d05;
      --warning-soft:     rgba(184,125,5,.14);
      --danger:           #c8324a;
      --danger-soft:      rgba(200,50,74,.12);
      --purple:           #6d4ed1;
      --purple-soft:      rgba(109,78,209,.12);
      --teal:             #0a8e8a;
      --teal-soft:        rgba(10,142,138,.12);
    }

    *{box-sizing:border-box}
    html,body{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:var(--font-sans);
      -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;}
    body{background:var(--bg-grad);min-height:100vh;}
    button{font-family:inherit}
    a{color:inherit;text-decoration:none}

    /* ── Layout ─────────────────────────────────────────────────────── */
    .app{display:grid;grid-template-columns:var(--sidebar-w) 1fr;min-height:100vh;}

    /* Sidebar */
    .sidebar{position:sticky;top:0;height:100vh;border-right:1px solid var(--border);
      background:linear-gradient(180deg, var(--surface-1), var(--bg) 70%);
      display:flex;flex-direction:column;padding:18px 14px;}
    .brand{display:flex;align-items:center;gap:10px;padding:6px 8px 18px;}
    .brand-mark{
      width:36px;height:36px;border-radius:10px;
      background:
        conic-gradient(from 45deg at 50% 50%,
          var(--accent) 0deg 90deg,
          color-mix(in srgb, var(--accent) 60%, transparent) 90deg 180deg,
          var(--accent) 180deg 270deg,
          color-mix(in srgb, var(--accent) 60%, transparent) 270deg 360deg);
      position:relative;box-shadow:0 0 0 1px rgba(245,184,0,.25), 0 8px 24px -8px rgba(245,184,0,.4);
    }
    .brand-mark::after{content:"";position:absolute;inset:6px;border-radius:6px;background:var(--surface-1)}
    .brand-mark::before{content:"";position:absolute;inset:13px;border-radius:2px;background:var(--accent);
      box-shadow:0 0 12px rgba(245,184,0,.5)}
    .brand-name{font-weight:700;letter-spacing:-.01em;font-size:15px;line-height:1.1}
    .brand-sub{font-size:10.5px;color:var(--text-mute);letter-spacing:.08em;text-transform:uppercase;margin-top:2px}

    .nav-group{display:flex;flex-direction:column;gap:2px;margin-top:8px}
    .nav-label{font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--text-faint);
      padding:14px 10px 6px;font-weight:600}
    .nav-item{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:8px;cursor:pointer;
      color:var(--text-dim);font-size:13.5px;font-weight:500;transition:background .15s, color .15s;
      border:1px solid transparent;}
    .nav-item:hover{background:var(--surface-2);color:var(--text)}
    .nav-item.active{background:linear-gradient(180deg, var(--surface-2), var(--surface-1));
      color:var(--text);border-color:var(--border)}
    .nav-item.active .nav-icon{color:var(--accent)}
    .nav-icon{width:16px;height:16px;flex-shrink:0;color:var(--text-mute)}
    .nav-badge{margin-left:auto;font-size:10.5px;font-family:var(--font-mono);background:var(--surface-3);
      color:var(--text-dim);padding:1px 6px;border-radius:6px;font-weight:500}
    .nav-item.active .nav-badge{background:var(--accent-soft);color:var(--accent)}

    .sidebar-foot{margin-top:auto;padding:12px 10px;border-top:1px solid var(--border);font-size:11px;
      color:var(--text-mute);display:flex;align-items:center;gap:8px}
    .pulse{width:8px;height:8px;border-radius:50%;background:var(--success);
      box-shadow:0 0 0 0 var(--success);animation:pulse 2s infinite}
    @keyframes pulse{
      0%{box-shadow:0 0 0 0 color-mix(in srgb, var(--success) 60%, transparent)}
      100%{box-shadow:0 0 0 8px transparent}
    }

    /* Topbar */
    .topbar{height:var(--topbar-h);border-bottom:1px solid var(--border);display:flex;align-items:center;
      justify-content:space-between;padding:0 28px;gap:24px;position:sticky;top:0;z-index:20;
      background:color-mix(in srgb, var(--bg) 78%, transparent);backdrop-filter:blur(16px) saturate(140%);
      -webkit-backdrop-filter:blur(16px) saturate(140%);}
    .crumbs{display:flex;align-items:center;gap:8px;color:var(--text-dim);font-size:13px}
    .crumbs .sep{color:var(--text-faint)}
    .crumbs .cur{color:var(--text);font-weight:500}
    .search{flex:1;max-width:480px;display:flex;align-items:center;gap:10px;height:38px;padding:0 14px;
      background:var(--surface-2);border:1px solid var(--border);border-radius:10px;
      color:var(--text-dim);font-size:13px;transition:border-color .15s, background .15s}
    .search:focus-within{border-color:var(--border-strong);background:var(--surface-1)}
    .search input{flex:1;border:0;background:transparent;color:var(--text);font-family:inherit;font-size:13px;outline:none}
    .search input::placeholder{color:var(--text-mute)}
    .kbd{font-family:var(--font-mono);font-size:10.5px;color:var(--text-mute);
      border:1px solid var(--border);padding:1px 5px;border-radius:5px;background:var(--bg)}
    .topbar-actions{display:flex;align-items:center;gap:12px}
    .icon-btn{width:36px;height:36px;border-radius:10px;background:var(--surface-2);border:1px solid var(--border);
      display:grid;place-items:center;cursor:pointer;color:var(--text-dim);transition:all .15s;position:relative}
    .icon-btn:hover{background:var(--surface-3);color:var(--text)}
    .notif-dot{position:absolute;top:7px;right:8px;width:7px;height:7px;border-radius:50%;background:var(--danger);
      box-shadow:0 0 0 2px var(--surface-2)}
    .user-chip{display:flex;align-items:center;gap:10px;padding:4px 12px 4px 4px;border-radius:24px;
      background:var(--surface-2);border:1px solid var(--border);cursor:pointer}
    .avatar{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg, var(--accent), #b87d05);
      display:grid;place-items:center;font-weight:700;color:var(--accent-ink);font-size:11px;letter-spacing:.04em}
    .user-name{font-size:12.5px;font-weight:500}
    .user-org{font-size:10.5px;color:var(--text-mute);letter-spacing:.02em}

    /* Main */
    .main{display:flex;flex-direction:column;min-width:0}
    .content{padding:28px 32px 80px;display:flex;flex-direction:column;gap:24px;min-width:0;max-width:1600px}

    /* Reusable primitives */
    .card{background:var(--surface-1);border:1px solid var(--border);border-radius:var(--r-md);padding:20px;
      transition:border-color .15s, transform .15s, background .15s}
    .card.hover:hover{border-color:var(--border-strong)}
    .row{display:flex;align-items:center;gap:12px}
    .between{justify-content:space-between}
    .stack{display:flex;flex-direction:column}
    .gap-4{gap:4px}.gap-6{gap:6px}.gap-8{gap:8px}.gap-10{gap:10px}.gap-12{gap:12px}.gap-16{gap:16px}.gap-20{gap:20px}.gap-24{gap:24px}
    .grow{flex:1}
    .mono{font-family:var(--font-mono);font-variant-numeric:tabular-nums}
    .serif{font-family:var(--font-serif)}
    .dim{color:var(--text-dim)}
    .mute{color:var(--text-mute)}

    .h-eyebrow{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--text-mute);font-weight:600}
    .h-title{font-size:28px;font-weight:600;letter-spacing:-.02em;line-height:1.1;margin:0}
    .h-section{font-size:18px;font-weight:600;letter-spacing:-.01em;margin:0}
    .h-kicker{font-size:13px;color:var(--text-dim);letter-spacing:.02em}

    .pill{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;font-weight:500;padding:3px 9px;
      border-radius:999px;border:1px solid var(--border);background:var(--surface-2);color:var(--text-dim);
      font-family:var(--font-sans);letter-spacing:.01em}
    .pill .dot{width:6px;height:6px;border-radius:50%;background:currentColor}
    .pill-accent{background:var(--accent-soft);color:var(--accent);border-color:transparent}
    .pill-success{background:var(--success-soft);color:var(--success);border-color:transparent}
    .pill-info   {background:var(--info-soft);color:var(--info);border-color:transparent}
    .pill-warning{background:var(--warning-soft);color:var(--warning);border-color:transparent}
    .pill-danger {background:var(--danger-soft);color:var(--danger);border-color:transparent}
    .pill-purple {background:var(--purple-soft);color:var(--purple);border-color:transparent}
    .pill-teal   {background:var(--teal-soft);color:var(--teal);border-color:transparent}

    .btn{display:inline-flex;align-items:center;gap:8px;padding:9px 14px;border-radius:10px;font-size:13px;
      font-weight:500;border:1px solid var(--border);background:var(--surface-2);color:var(--text);cursor:pointer;
      transition:all .15s;font-family:inherit}
    .btn:hover{background:var(--surface-3)}
    .btn-primary{background:var(--accent);color:var(--accent-ink);border-color:transparent;font-weight:600}
    .btn-primary:hover{background:var(--accent-strong)}
    .btn-ghost{background:transparent;border:1px solid var(--border)}
    .btn-ghost:hover{background:var(--surface-2)}
    .btn-sm{padding:6px 10px;font-size:12px;border-radius:8px}

    /* Progress ring + bar */
    .prog-bar{height:6px;background:var(--surface-3);border-radius:999px;overflow:hidden;position:relative}
    .prog-bar > span{display:block;height:100%;background:linear-gradient(90deg, var(--accent), var(--accent-strong));border-radius:999px;}

    .grid{display:grid;gap:20px}
    .grid-4{grid-template-columns:repeat(4, minmax(0, 1fr))}
    .grid-3{grid-template-columns:repeat(3, minmax(0, 1fr))}
    .grid-2{grid-template-columns:repeat(2, minmax(0, 1fr))}

    /* Scrollbars */
    *::-webkit-scrollbar{width:10px;height:10px}
    *::-webkit-scrollbar-track{background:transparent}
    *::-webkit-scrollbar-thumb{background:var(--surface-hi);border-radius:8px;border:2px solid var(--bg);background-clip:padding-box}
    *::-webkit-scrollbar-thumb:hover{background:var(--text-faint);background-clip:padding-box;border:2px solid var(--bg)}

    /* Subtle entrance */
    .fade-in{animation:fadeIn .4s ease-out both}
    @keyframes fadeIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

    /* Drawer */
    .drawer-scrim{position:fixed;inset:0;background:rgba(0,0,0,.55);backdrop-filter:blur(4px);
      z-index:40;animation:fadeBg .2s ease-out both}
    @keyframes fadeBg{from{opacity:0}to{opacity:1}}
    .drawer{position:fixed;top:0;right:0;height:100vh;width:min(640px, 100vw);background:var(--surface-1);
      border-left:1px solid var(--border-strong);z-index:50;display:flex;flex-direction:column;
      animation:slideIn .25s cubic-bezier(.2,.8,.2,1) both;overflow:hidden}
    @keyframes slideIn{from{transform:translateX(100%)}to{transform:none}}
    .drawer-head{padding:24px 28px 20px;border-bottom:1px solid var(--border);display:flex;flex-direction:column;gap:10px}
    .drawer-body{flex:1;overflow-y:auto;padding:24px 28px}
    .drawer-foot{padding:18px 28px;border-top:1px solid var(--border);display:flex;gap:10px;justify-content:flex-end}

    /* World map */
    .map-wrap{position:relative;background:var(--surface-1);border:1px solid var(--border);border-radius:var(--r-md);
      overflow:hidden}
    .map-wrap svg{display:block;width:100%;height:auto}
    .continent{fill:var(--surface-3);stroke:var(--border-strong);stroke-width:.5}
    .continent.africa{fill:color-mix(in srgb, var(--accent) 18%, var(--surface-3));
      stroke:color-mix(in srgb, var(--accent) 35%, var(--border-strong))}
    .grid-line{stroke:var(--border);stroke-width:.5;stroke-dasharray:2 4;opacity:.6}
    .marker{cursor:pointer}
    .marker-pulse{transform-origin:center;animation:markerPulse 3s ease-out infinite}
    @keyframes markerPulse{0%{transform:scale(1);opacity:.6}100%{transform:scale(2.6);opacity:0}}
    .arc{fill:none;stroke:var(--accent);stroke-width:1;opacity:.35;stroke-dasharray:3 3;
      animation:arcMove 30s linear infinite}
    @keyframes arcMove{to{stroke-dashoffset:-200}}

    /* Kanban */
    .kanban{display:grid;grid-template-columns:repeat(5, minmax(240px, 1fr));gap:14px;overflow-x:auto;padding-bottom:8px}
    .kcol{background:var(--surface-1);border:1px solid var(--border);border-radius:var(--r-md);padding:14px;
      display:flex;flex-direction:column;gap:10px;min-height:520px}
    .kcol-head{display:flex;align-items:center;justify-content:space-between;padding-bottom:6px;
      border-bottom:1px solid var(--border)}
    .kcard{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-sm);padding:12px;
      display:flex;flex-direction:column;gap:8px;cursor:pointer;transition:all .15s}
    .kcard:hover{border-color:var(--border-strong);transform:translateY(-1px)}

    /* Opportunity card */
    .opp-card{display:grid;grid-template-columns:auto 1fr auto;gap:18px;align-items:center;padding:18px 20px;
      border:1px solid var(--border);background:var(--surface-1);border-radius:var(--r-md);cursor:pointer;
      transition:all .15s}
    .opp-card:hover{border-color:var(--border-strong);background:var(--surface-2)}
    .opp-flag{font-size:32px;line-height:1;width:48px;height:48px;display:grid;place-items:center;
      background:var(--surface-2);border-radius:12px;border:1px solid var(--border)}
    .opp-amount{font-family:var(--font-mono);font-size:14px;color:var(--text);font-weight:500;letter-spacing:-.02em}

    /* Match score */
    .match{display:flex;align-items:center;gap:10px;min-width:120px}
    .match-ring{position:relative;width:40px;height:40px;flex-shrink:0}
    .match-ring svg{transform:rotate(-90deg)}
    .match-ring text{font-family:var(--font-mono);font-size:11px;font-weight:600;fill:var(--text);
      transform:rotate(90deg);transform-origin:center}

    /* Filter chips */
    .chip{font-size:12px;padding:6px 12px;border-radius:8px;background:var(--surface-2);border:1px solid var(--border);
      color:var(--text-dim);cursor:pointer;display:inline-flex;align-items:center;gap:6px;
      transition:all .15s;font-family:inherit}
    .chip:hover{background:var(--surface-3);color:var(--text)}
    .chip.on{background:var(--accent-soft);color:var(--accent);border-color:transparent}

    /* Partner card */
    .partner-card{background:var(--surface-1);border:1px solid var(--border);border-radius:var(--r-md);
      padding:18px;display:flex;flex-direction:column;gap:12px;transition:all .15s;cursor:pointer;position:relative;
      overflow:hidden}
    .partner-card:hover{border-color:var(--border-strong);transform:translateY(-2px)}

    /* Profile flourishes */
    .pillar{display:flex;flex-direction:column;gap:8px;padding:18px;border:1px solid var(--border);
      border-radius:var(--r-md);background:var(--surface-1);position:relative;overflow:hidden;min-height:140px}
    .pillar-letter{position:absolute;right:-4px;top:-22px;font-family:var(--font-serif);font-size:120px;
      font-style:italic;color:color-mix(in srgb, var(--accent) 16%, transparent);line-height:1;pointer-events:none}

    /* KPI */
    .kpi{display:flex;flex-direction:column;gap:8px;padding:20px;border:1px solid var(--border);
      background:var(--surface-1);border-radius:var(--r-md);position:relative;overflow:hidden}
    .kpi-spark{position:absolute;right:14px;top:18px;width:80px;height:32px;opacity:.85}
    .kpi-val{font-size:30px;font-weight:600;letter-spacing:-.025em;line-height:1;font-family:var(--font-sans);
      font-variant-numeric:tabular-nums}
    .kpi-delta{font-size:11.5px;font-family:var(--font-mono);font-weight:500}
    .kpi-label{font-size:11.5px;color:var(--text-mute);letter-spacing:.06em;text-transform:uppercase;font-weight:600}

    /* Hero banner */
    .hero{padding:28px 28px 26px;border-radius:var(--r-lg);border:1px solid var(--border);
      background:
        radial-gradient(800px 300px at 100% 0%, color-mix(in srgb, var(--accent) 18%, transparent), transparent 60%),
        radial-gradient(600px 240px at 0% 100%, color-mix(in srgb, var(--success) 12%, transparent), transparent 60%),
        var(--surface-1);
      position:relative;overflow:hidden}
    .hero-mesh{position:absolute;inset:0;background-image:
      linear-gradient(var(--border) 1px, transparent 1px),
      linear-gradient(90deg, var(--border) 1px, transparent 1px);
      background-size:48px 48px;mask-image:radial-gradient(800px 400px at 70% 30%, black, transparent 70%);
      opacity:.5;pointer-events:none}

/* App behavior additions */
.gap-22{gap:22px}
.nav-item{appearance:none;width:100%;background:transparent;text-align:left}
.user-chip{appearance:none;color:inherit;font:inherit;text-align:left}
.btn:disabled{opacity:.58;cursor:not-allowed}
.btn.is-on,.btn-ghost.is-on{background:var(--accent-soft);color:var(--accent);border-color:transparent}
.count-dot{position:absolute;top:4px;right:4px;min-width:15px;height:15px;border-radius:999px;background:var(--accent);color:var(--accent-ink);font:700 9px/15px var(--font-mono);text-align:center;box-shadow:0 0 0 2px var(--surface-2)}
.search-results{position:absolute;top:calc(var(--topbar-h) + 8px);left:calc(var(--sidebar-w) + 260px);width:min(520px, calc(100vw - var(--sidebar-w) - 300px));z-index:30;background:var(--surface-1);border:1px solid var(--border-strong);border-radius:12px;padding:8px;box-shadow:0 24px 60px rgba(0,0,0,.4)}
.search-result{appearance:none;width:100%;border:0;background:transparent;color:inherit;display:flex;align-items:center;gap:10px;padding:10px;border-radius:8px;cursor:pointer;text-align:left;font:inherit}
.search-result:hover{background:var(--surface-2)}
.app-popover{position:absolute;top:calc(var(--topbar-h) + 8px);right:24px;width:min(360px, calc(100vw - var(--sidebar-w) - 48px));z-index:35;background:var(--surface-1);border:1px solid var(--border-strong);border-radius:12px;padding:12px;box-shadow:0 24px 60px rgba(0,0,0,.42)}
.popover-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:4px 2px 12px;font-size:13px;font-weight:600}
.popover-row{display:grid;grid-template-columns:34px 1fr;gap:10px;padding:8px;border-radius:8px;font-size:12.5px;color:var(--text-dim)}
.popover-row:hover{background:var(--surface-2);color:var(--text)}
.popover-link{appearance:none;width:100%;border:1px solid var(--border);background:var(--surface-2);color:inherit;border-radius:8px;padding:10px;display:flex;align-items:center;justify-content:space-between;gap:10px;text-align:left;font:inherit;cursor:pointer}
.popover-link:hover{background:var(--surface-3);border-color:var(--border-strong)}
.empty-note{padding:22px 8px;text-align:center;color:var(--text-mute);font-size:12.5px;border:1px dashed var(--border);border-radius:8px}
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);z-index:80;background:var(--surface-1);border:1px solid var(--border-strong);border-radius:12px;padding:12px 18px;display:flex;align-items:center;gap:10px;box-shadow:0 20px 60px rgba(0,0,0,.5);animation:fadeIn .2s both;max-width:min(560px, calc(100vw - 32px))}
.toast-icon{width:24px;height:24px;border-radius:50%;background:var(--success-soft);color:var(--success);display:grid;place-items:center;flex-shrink:0}
.toast[data-tone="info"] .toast-icon{background:var(--info-soft);color:var(--info)}
.kcol.drop-on{border-color:var(--accent);background:color-mix(in srgb, var(--accent) 7%, var(--surface-1))}
.kcard[draggable="true"]{cursor:grab}
.kcard[draggable="true"]:active{cursor:grabbing}
.stage-select{max-width:116px;border:1px solid var(--border);border-radius:7px;background:var(--surface-3);color:var(--text-dim);font:11px var(--font-sans);padding:3px 6px;outline:none}
.stage-select:focus{border-color:var(--accent);color:var(--text)}
.partner-card.is-saved{border-color:color-mix(in srgb, var(--accent) 36%, var(--border));box-shadow:0 0 0 1px color-mix(in srgb, var(--accent) 12%, transparent)}

@media (max-width: 1200px){
  .grid-4{grid-template-columns:repeat(2,minmax(0,1fr))}
  .grid-3{grid-template-columns:repeat(2,minmax(0,1fr))}
  .content{padding:24px 24px 72px}
  .content > .grid[style*="grid-template-columns"]{grid-template-columns:1fr !important}
}

@media (max-width: 900px){
  :root{--sidebar-w:100vw}
  .app{display:block}
  .sidebar{position:relative;height:auto;border-right:0;border-bottom:1px solid var(--border);padding:14px}
  .brand{padding:4px 6px 10px}
  .nav-group{margin-top:6px}
  .sidebar-foot{display:none}
  .topbar{height:auto;min-height:var(--topbar-h);padding:12px 16px;flex-wrap:wrap;gap:12px}
  .crumbs{min-width:0}
  .search{order:3;flex:1 0 100%;max-width:none}
  .topbar-actions{margin-left:auto}
  .content{padding:18px 16px 56px;gap:18px}
  .grid-4,.grid-3,.grid-2{grid-template-columns:1fr}
  .opp-card{grid-template-columns:auto 1fr;gap:12px;padding:14px}
  .opp-card .match{grid-column:1 / -1}
  .search-results,.app-popover{position:fixed;top:130px;left:16px;right:16px;width:auto}
  .kanban{grid-template-columns:repeat(5, minmax(230px, 78vw))}
}

@media (max-width: 560px){
  .h-title{font-size:24px}
  .hero{padding:22px 18px}
  .topbar-actions{width:100%;justify-content:space-between}
  .user-chip{padding-right:8px}
  .user-name,.user-org{display:none}
  .drawer-head,.drawer-body,.drawer-foot{padding-left:18px;padding-right:18px}
  .drawer-foot{flex-wrap:wrap}
  .drawer-foot .btn{flex:1;justify-content:center}
}
