/* ============================================================
   Volektra Controller Store — ecommerce styles
   ============================================================ */
/* ============================================================
   VOLEKTRA — Colors & Type Foundations
   Brand: Volektra ("Simply Elektrik") + sub-brand Vimag Labs
   B2B EV motor technology. Warm-white, industrial, deep-tech.
   ============================================================ */

/* ----- Fonts (Google Fonts CDN — see README font note) -----
   Display/Headlines : Montserrat      (geometric sans — matches the VOLEKTRA wordmark)
   Body/UI           : Hanken Grotesk  (warm, legible, professional)
   Data/Specs/Mono   : IBM Plex Mono   (technical figures, torque/efficiency)
*/
/* cyrillic-ext */
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../assets/bundled/f7247588-1d3d-466c-bed8-3875d7c7850c.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* vietnamese */
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../assets/bundled/d5799202-4b6a-419d-b3a3-6b1e629dd080.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../assets/bundled/fb5e3560-7abb-48df-9d3d-4518beefb388.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../assets/bundled/f1477afa-174f-4637-91b0-7165aeff569f.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../assets/bundled/f7247588-1d3d-466c-bed8-3875d7c7850c.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* vietnamese */
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../assets/bundled/d5799202-4b6a-419d-b3a3-6b1e629dd080.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../assets/bundled/fb5e3560-7abb-48df-9d3d-4518beefb388.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../assets/bundled/f1477afa-174f-4637-91b0-7165aeff569f.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../assets/bundled/f7247588-1d3d-466c-bed8-3875d7c7850c.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* vietnamese */
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../assets/bundled/d5799202-4b6a-419d-b3a3-6b1e629dd080.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../assets/bundled/fb5e3560-7abb-48df-9d3d-4518beefb388.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../assets/bundled/f1477afa-174f-4637-91b0-7165aeff569f.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("../assets/bundled/f7247588-1d3d-466c-bed8-3875d7c7850c.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* vietnamese */
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("../assets/bundled/d5799202-4b6a-419d-b3a3-6b1e629dd080.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("../assets/bundled/fb5e3560-7abb-48df-9d3d-4518beefb388.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("../assets/bundled/f1477afa-174f-4637-91b0-7165aeff569f.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: 'IBM Plex Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../assets/bundled/0a2d16ac-446c-4990-b43b-077d4c49256d.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: 'IBM Plex Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../assets/bundled/437c2479-12c9-4db9-bdab-cf360d173243.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'IBM Plex Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../assets/bundled/0d68b695-de38-4073-b492-6860f6137295.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: 'IBM Plex Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../assets/bundled/43ca1722-a4e1-4751-bc4e-1cf14d634eb0.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: 'IBM Plex Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../assets/bundled/da470694-d74d-459c-80d5-ef9e33a5ba0b.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: 'IBM Plex Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../assets/bundled/c0d4cd44-6fd8-494b-a1ed-561f892348b1.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: 'IBM Plex Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../assets/bundled/e870f3e9-d54a-4792-b3ed-26be168f9796.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'IBM Plex Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../assets/bundled/1a3ff909-8bf4-4831-80c7-d08476b0e20f.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: 'IBM Plex Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../assets/bundled/875e567c-cd1a-4ffe-95ff-d0e4d0d2fc95.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: 'IBM Plex Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../assets/bundled/5aa9633c-935b-49d8-9c63-eac71d496470.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: 'IBM Plex Mono';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../assets/bundled/edef3014-9aed-4cea-86ef-da099a5ed6f5.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: 'IBM Plex Mono';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../assets/bundled/a3af97d7-6a49-4720-b6ee-aec935af21d9.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'IBM Plex Mono';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../assets/bundled/03ec2747-9fea-4ba6-a1dc-502ef1975b35.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: 'IBM Plex Mono';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../assets/bundled/86c1c11e-251c-402f-9f76-563c51300f6e.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: 'IBM Plex Mono';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../assets/bundled/31b66195-2bcf-40dd-bb59-58f873480871.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: 'Montserrat';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../assets/bundled/a127ca7a-df2a-4954-b2e2-7f08227770e0.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: 'Montserrat';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../assets/bundled/570ebe05-8540-4604-8eb3-67b6df4e2c39.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../assets/bundled/52b17c9a-a07a-40f3-b084-cff11d68867c.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: 'Montserrat';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../assets/bundled/ae90d59f-e6a0-4cdc-a72e-6b15ba765dc1.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: 'Montserrat';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../assets/bundled/89ed256f-afa4-4608-acfd-4e13c8e55479.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: 'Montserrat';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../assets/bundled/a127ca7a-df2a-4954-b2e2-7f08227770e0.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: 'Montserrat';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../assets/bundled/570ebe05-8540-4604-8eb3-67b6df4e2c39.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../assets/bundled/52b17c9a-a07a-40f3-b084-cff11d68867c.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: 'Montserrat';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../assets/bundled/ae90d59f-e6a0-4cdc-a72e-6b15ba765dc1.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: 'Montserrat';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../assets/bundled/89ed256f-afa4-4608-acfd-4e13c8e55479.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: 'Montserrat';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("../assets/bundled/a127ca7a-df2a-4954-b2e2-7f08227770e0.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: 'Montserrat';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("../assets/bundled/570ebe05-8540-4604-8eb3-67b6df4e2c39.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("../assets/bundled/52b17c9a-a07a-40f3-b084-cff11d68867c.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: 'Montserrat';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("../assets/bundled/ae90d59f-e6a0-4cdc-a72e-6b15ba765dc1.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: 'Montserrat';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("../assets/bundled/89ed256f-afa4-4608-acfd-4e13c8e55479.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: 'Montserrat';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url("../assets/bundled/a127ca7a-df2a-4954-b2e2-7f08227770e0.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: 'Montserrat';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url("../assets/bundled/570ebe05-8540-4604-8eb3-67b6df4e2c39.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url("../assets/bundled/52b17c9a-a07a-40f3-b084-cff11d68867c.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: 'Montserrat';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url("../assets/bundled/ae90d59f-e6a0-4cdc-a72e-6b15ba765dc1.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: 'Montserrat';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url("../assets/bundled/89ed256f-afa4-4608-acfd-4e13c8e55479.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: 'Montserrat';
  font-style: normal;
  font-weight: 900;
  font-display: swap;
  src: url("../assets/bundled/a127ca7a-df2a-4954-b2e2-7f08227770e0.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: 'Montserrat';
  font-style: normal;
  font-weight: 900;
  font-display: swap;
  src: url("../assets/bundled/570ebe05-8540-4604-8eb3-67b6df4e2c39.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 900;
  font-display: swap;
  src: url("../assets/bundled/52b17c9a-a07a-40f3-b084-cff11d68867c.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: 'Montserrat';
  font-style: normal;
  font-weight: 900;
  font-display: swap;
  src: url("../assets/bundled/ae90d59f-e6a0-4cdc-a72e-6b15ba765dc1.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: 'Montserrat';
  font-style: normal;
  font-weight: 900;
  font-display: swap;
  src: url("../assets/bundled/89ed256f-afa4-4608-acfd-4e13c8e55479.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 CORE ============== */
  --voltage-blue:   #1B8DBF;  /* Volektra primary — the blue "V" triangle  */
  --electric-lime:  #ADCF37;  /* Volektra energy accent — the lightning bolt */
  --ink:            #0E0F12;  /* near-black wordmark ink */

  /* Vimag Labs sub-brand (deep-tech / R&D) */
  --vimag-indigo:   #5C6CF2;  /* periwinkle/violet circuit */
  --vimag-lime:     #A8E36B;  /* "labs" green */
  --vimag-charcoal: #21232C;  /* "VImag" wordmark charcoal */

  /* ============== BACKGROUNDS (warm white) ============== */
  --bg:        #FAF7F1;  /* primary canvas — warm white */
  --bg-raised: #FFFFFF;  /* cards / raised surfaces */
  --bg-sunken: #F2ECE0;  /* sunken wells, alt sections */
  --bg-sand:   #EDE5D6;  /* warm sand band */

  /* ============== INK / TEXT (warm-tinted neutrals) ============== */
  --fg1: #0E0F12;  /* primary text / headlines */
  --fg2: #3A3D44;  /* secondary text */
  --fg3: #6A6E78;  /* muted / captions / labels */
  --fg4: #9DA0AA;  /* disabled / faint */
  --on-dark:   #FAF7F1;  /* text on dark/ink surfaces */
  --on-dark-2: #B9BCC4;  /* secondary text on dark */

  /* Hairlines & borders (warm) */
  --line:        #E6DFD0;  /* default hairline on warm white */
  --line-strong: #D6CDB8;  /* stronger divider */
  --line-ink:    rgba(14,15,18,0.10);

  /* ============== BLUE SCALE (tints/shades of voltage blue) ============== */
  --blue-050: #EAF4F9;
  --blue-100: #CFE7F1;
  --blue-200: #9FCFE4;
  --blue-300: #63B2D2;
  --blue-400: #2E9BC8;
  --blue-500: #1B8DBF;  /* = voltage-blue */
  --blue-600: #1576A0;
  --blue-700: #105E80;
  --blue-800: #0C465F;
  --blue-900: #082F40;

  /* ============== LIME SCALE ============== */
  --lime-050: #F4F8E4;
  --lime-100: #E7F1C2;
  --lime-200: #D3E58C;
  --lime-300: #BFD95A;
  --lime-400: #ADCF37;  /* = electric-lime */
  --lime-500: #94B62A;
  --lime-600: #769220;
  --lime-700: #586E18;

  /* ============== SEMANTIC ============== */
  --success: #5A9E2E;
  --success-bg: #EDF4E1;
  --warning: #E0A52B;
  --warning-bg: #FBF1DA;
  --danger:  #D1452B;
  --danger-bg:  #FBE6E1;
  --info:    var(--voltage-blue);
  --info-bg: var(--blue-050);

  /* ============== GRADIENTS ============== */
  /* Volektra energy — blue → lime (use sparingly: hero accents, bars) */
  --grad-energy: linear-gradient(100deg, var(--voltage-blue) 0%, var(--electric-lime) 100%);
  /* Vimag circuit — green → indigo (sub-brand only) */
  --grad-vimag:  linear-gradient(110deg, var(--vimag-lime) 0%, var(--vimag-indigo) 100%);
  /* Ink wash for dark hero panels */
  --grad-ink:    linear-gradient(160deg, #15171C 0%, #0B0C0F 100%); /* @kind color */

  /* ============== ELEVATION / SHADOW ============== */
  --shadow-sm: 0 1px 2px rgba(14,15,18,0.06), 0 1px 3px rgba(14,15,18,0.04);
  --shadow-md: 0 4px 12px rgba(14,15,18,0.08), 0 2px 4px rgba(14,15,18,0.05);
  --shadow-lg: 0 16px 40px rgba(14,15,18,0.12), 0 4px 10px rgba(14,15,18,0.06);
  --shadow-blue: 0 12px 30px rgba(27,141,191,0.22);

  /* ============== RADII ============== */
  --r-xs: 4px;
  --r-sm: 8px;
  --r-md: 12px;
  --r-lg: 18px;
  --r-xl: 28px;
  --r-pill: 999px;

  /* ============== SPACING (4px base) ============== */
  --sp-1: 4px;
  --sp-2: 8px;
  --sp-3: 12px;
  --sp-4: 16px;
  --sp-5: 24px;
  --sp-6: 32px;
  --sp-7: 48px;
  --sp-8: 64px;
  --sp-9: 96px;

  /* ============== TYPE FAMILIES ============== */
  --font-display: 'Montserrat', system-ui, sans-serif;
  --font-body: 'Hanken Grotesk', system-ui, sans-serif;
  --font-mono: 'IBM Plex Mono', ui-monospace, monospace;
}

/* ============================================================
   SEMANTIC TYPE STYLES
   Display = Montserrat (geometric, heavy, slight negative tracking)
   Body = Hanken Grotesk
   Eyebrows / data = IBM Plex Mono, uppercase, wide tracking
   ============================================================ */

.t-display {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: clamp(48px, 7vw, 92px);
  line-height: 0.98;
  letter-spacing: -0.02em;
  color: var(--fg1);
  text-wrap: balance;
}

.t-h1 {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: clamp(36px, 4.5vw, 60px);
  line-height: 1.03;
  letter-spacing: -0.015em;
  color: var(--fg1);
  text-wrap: balance;
}

.t-h2 {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: clamp(28px, 3vw, 40px);
  line-height: 1.08;
  letter-spacing: -0.01em;
  color: var(--fg1);
}

.t-h3 {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 24px;
  line-height: 1.2;
  letter-spacing: -0.005em;
  color: var(--fg1);
}

.t-lead {
  font-family: var(--font-body);
  font-weight: 400;
  font-size: clamp(18px, 1.6vw, 22px);
  line-height: 1.5;
  color: var(--fg2);
  text-wrap: pretty;
}

.t-body {
  font-family: var(--font-body);
  font-weight: 400;
  font-size: 16px;
  line-height: 1.6;
  color: var(--fg2);
  text-wrap: pretty;
}

.t-small {
  font-family: var(--font-body);
  font-weight: 400;
  font-size: 14px;
  line-height: 1.5;
  color: var(--fg3);
}

/* Eyebrow / kicker — the signature technical label */
.t-eyebrow {
  font-family: var(--font-mono);
  font-weight: 500;
  font-size: 13px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--voltage-blue);
}

/* Data figure — for specs, metrics, torque/efficiency */
.t-data {
  font-family: var(--font-mono);
  font-weight: 500;
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.01em;
  color: var(--fg1);
}

.t-metric {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: clamp(40px, 5vw, 64px);
  line-height: 1;
  letter-spacing: -0.02em;
  color: var(--fg1);
  font-variant-numeric: tabular-nums;
}


*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body { background: var(--bg); font-family: var(--font-body); color: var(--fg1); -webkit-font-smoothing: antialiased; }

/* ---- scrollbar ---- */
::-webkit-scrollbar { width: 6px; } ::-webkit-scrollbar-track { background: var(--bg-sunken); } ::-webkit-scrollbar-thumb { background: var(--line-strong); border-radius: 3px; }

/* ---- HEADER ---- */
.st-header { position: sticky; top: 0; z-index: 100; background: var(--ink); border-bottom: 2px solid rgba(173,207,55,.18); }
.st-header-top { max-width: 1440px; margin: 0 auto; padding: 12px 32px; display: flex; align-items: center; gap: 20px; }
.st-logo { flex: none; display: flex; align-items: center; gap: 10px; }
.st-logo img { height: 36px; }
.st-search { flex: 1; display: flex; background: var(--bg); border-radius: var(--r-pill); overflow: hidden; border: 2px solid var(--electric-lime); box-shadow: 0 0 0 0 transparent; transition: box-shadow .15s; }
.st-search:focus-within { box-shadow: 0 0 0 3px rgba(173,207,55,.3); }
.st-search-cat { font-family: var(--font-mono); font-size: 12px; letter-spacing: .04em; background: var(--bg-sunken); border: none; border-right: 1px solid var(--line); padding: 0 14px; color: var(--fg2); cursor: pointer; white-space: nowrap; }
.st-search input { flex: 1; border: none; background: transparent; padding: 11px 16px; font-family: var(--font-body); font-size: 15px; color: var(--fg1); outline: none; }
.st-search-btn { background: var(--electric-lime); border: none; padding: 0 20px; cursor: pointer; display: flex; align-items: center; }
.st-search-btn svg { width: 20px; height: 20px; stroke: var(--ink); }
.st-hdr-actions { flex: none; display: flex; align-items: center; gap: 8px; }
.st-hdr-btn { display: flex; flex-direction: column; align-items: center; gap: 4px; background: none; border: none; cursor: pointer; padding: 6px 10px; border-radius: var(--r-sm); color: rgba(255,255,255,.78); font-family: var(--font-mono); font-size: 11px; letter-spacing: .04em; transition: color .15s, background .15s; }
.st-hdr-btn:hover { background: rgba(255,255,255,.08); color: #fff; }
.st-hdr-btn svg { width: 22px; height: 22px; stroke: currentColor; }
.st-cart-badge { position: relative; }
.st-cart-count { position: absolute; top: -2px; right: -2px; width: 18px; height: 18px; border-radius: 50%; background: var(--electric-lime); color: var(--ink); font-family: var(--font-mono); font-size: 10px; font-weight: 700; display: flex; align-items: center; justify-content: center; }

/* category nav */
.st-cat-nav { background: #141820; border-top: 1px solid rgba(255,255,255,.07); }
.st-cat-nav-inner { max-width: 1440px; margin: 0 auto; padding: 0 32px; display: flex; align-items: center; gap: 0; overflow-x: auto; }
.st-cat-nav a { font-family: var(--font-mono); font-size: 12px; letter-spacing: .1em; text-transform: uppercase; color: rgba(255,255,255,.62); padding: 12px 16px; white-space: nowrap; cursor: pointer; border-bottom: 3px solid transparent; transition: color .15s, border-color .15s; text-decoration: none; }
.st-cat-nav a:hover { color: #fff; }
.st-cat-nav a.active { color: var(--electric-lime); border-bottom-color: var(--electric-lime); }

/* ---- HERO ---- */
.st-hero { background: linear-gradient(120deg, #091627 0%, #0E2A4E 35%, #1B6A8A 70%, #6B8A1A 100%); color: #fff; overflow: hidden; position: relative; }
.st-hero::after { content: ""; position: absolute; left: 0; right: 0; bottom: 0; height: 5px; background: var(--grad-energy); }
.st-hero-glow { position: absolute; width: 700px; height: 700px; right: -100px; top: -200px; background: radial-gradient(circle, rgba(27,141,191,.28), transparent 62%); pointer-events: none; }
.st-hero-inner { max-width: 1440px; margin: 0 auto; padding: 72px 32px 80px; display: grid; grid-template-columns: 1fr 460px; gap: 60px; align-items: center; position: relative; }
.st-hero-kicker { font-family: var(--font-mono); font-size: 12px; letter-spacing: .22em; text-transform: uppercase; color: var(--electric-lime); margin-bottom: 16px; }
.st-hero-title { font-family: var(--font-display); font-weight: 900; font-size: 70px; line-height: .96; letter-spacing: -.03em; margin-bottom: 20px; }
.st-hero-sub { font-size: 18px; color: rgba(255,255,255,.76); max-width: 520px; line-height: 1.55; margin-bottom: 32px; }
.st-hero-ctas { display: flex; gap: 14px; flex-wrap: wrap; }
.st-hero-stat-row { display: flex; gap: 32px; margin-top: 36px; }
.st-hero-stat .n { font-family: var(--font-display); font-weight: 800; font-size: 36px; letter-spacing: -.02em; color: var(--electric-lime); }
.st-hero-stat .l { font-family: var(--font-mono); font-size: 11px; letter-spacing: .08em; text-transform: uppercase; color: rgba(255,255,255,.52); margin-top: 4px; }
.st-hero-img { display: flex; align-items: center; justify-content: center; }
.st-hero-img img { width: 100%; max-width: 420px; filter: drop-shadow(0 20px 40px rgba(0,0,0,.5)); }

/* ---- BUTTONS ---- */
.btn { font-family: var(--font-display); font-weight: 600; font-size: 15px; border: none; border-radius: var(--r-sm); padding: 13px 24px; cursor: pointer; display: inline-flex; align-items: center; gap: 8px; transition: all .18s cubic-bezier(.2,.7,.2,1); }
.btn-lime { background: var(--electric-lime); color: var(--ink); }
.btn-lime:hover { background: var(--lime-500); }
.btn-ghost-dark { background: transparent; color: #fff; border: 1px solid rgba(255,255,255,.35); }
.btn-ghost-dark:hover { background: rgba(255,255,255,.1); }
.btn-primary { background: var(--voltage-blue); color: #fff; box-shadow: var(--shadow-sm); }
.btn-primary:hover { background: var(--blue-600); box-shadow: var(--shadow-md); }
.btn-ghost { background: transparent; color: var(--fg1); border: 1px solid var(--line-strong); }
.btn-ghost:hover { background: var(--bg-sunken); }
.btn-sm { padding: 9px 16px; font-size: 13px; }
.btn-full { width: 100%; justify-content: center; }

/* ---- CATEGORY TILES ---- */
.st-cats { max-width: 1440px; margin: 36px auto; padding: 0 32px; }
.st-cats-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 12px; }
.st-cat-tile { background: var(--bg-raised); border: 1px solid var(--line); border-radius: var(--r-lg); padding: 20px 14px 16px; display: flex; flex-direction: column; align-items: center; gap: 10px; cursor: pointer; transition: all .18s cubic-bezier(.2,.7,.2,1); }
.st-cat-tile:hover, .st-cat-tile.active { border-color: var(--voltage-blue); box-shadow: var(--shadow-blue); background: var(--blue-050); }
.st-cat-tile .ico { width: 52px; height: 52px; border-radius: var(--r-md); background: var(--blue-050); display: flex; align-items: center; justify-content: center; }
.st-cat-tile:hover .ico, .st-cat-tile.active .ico { background: var(--voltage-blue); }
.st-cat-tile:hover .ico svg, .st-cat-tile.active .ico svg { stroke: #fff; }
.st-cat-tile .ico svg { width: 26px; height: 26px; stroke: var(--voltage-blue); transition: stroke .15s; }
.st-cat-tile .lbl { font-family: var(--font-mono); font-size: 11px; letter-spacing: .06em; text-transform: uppercase; color: var(--fg2); text-align: center; }

/* ---- SECTION HEADER ---- */
.st-section { max-width: 1440px; margin: 0 auto; padding: 0 32px 48px; }
.st-sec-head { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 24px; }
.st-sec-head h2 { font-family: var(--font-display); font-weight: 800; font-size: 28px; letter-spacing: -.015em; }
.st-sec-head a { font-family: var(--font-mono); font-size: 13px; letter-spacing: .06em; color: var(--voltage-blue); cursor: pointer; text-decoration: none; }

/* ---- PRODUCT GRID ---- */
.st-product-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 16px; }
.st-product-grid.cols-4 { grid-template-columns: repeat(4, 1fr); }

/* ---- PRODUCT CARD ---- */
.st-card { background: var(--bg-raised); border: 1px solid var(--line); border-radius: var(--r-lg); overflow: hidden; cursor: pointer; transition: all .2s cubic-bezier(.2,.7,.2,1); position: relative; display: flex; flex-direction: column; }
.st-card:hover { border-color: var(--blue-200); box-shadow: var(--shadow-md); transform: translateY(-3px); }
.st-card-img { position: relative; overflow: hidden; background: var(--bg-sunken); aspect-ratio: 4/3; display: flex; align-items: center; justify-content: center; }
.st-card-img img { width: 100%; height: 100%; object-fit: contain; padding: 12px; transition: transform .25s; }
.st-card:hover .st-card-img img { transform: scale(1.06); }
.st-card-badge { position: absolute; top: 10px; left: 10px; font-family: var(--font-mono); font-size: 10px; letter-spacing: .06em; padding: 4px 8px; border-radius: var(--r-pill); }
.badge-new { background: var(--voltage-blue); color: #fff; }
.badge-hot { background: var(--electric-lime); color: var(--ink); }
.badge-b2b { background: var(--ink); color: var(--bg); }
.badge-sale { background: var(--danger); color: #fff; }
.st-card-hover-actions { position: absolute; bottom: 0; left: 0; right: 0; display: flex; gap: 0; opacity: 0; transform: translateY(8px); transition: all .18s; }
.st-card:hover .st-card-hover-actions { opacity: 1; transform: none; }
.st-card-hover-actions button { flex: 1; font-family: var(--font-mono); font-size: 11px; letter-spacing: .04em; padding: 10px 6px; border: none; cursor: pointer; transition: background .15s; }
.st-card-hover-actions .hbtn-cart { background: var(--voltage-blue); color: #fff; }
.st-card-hover-actions .hbtn-cart:hover { background: var(--blue-600); }
.st-card-hover-actions .hbtn-quote { background: var(--electric-lime); color: var(--ink); }
.st-card-hover-actions .hbtn-quote:hover { background: var(--lime-500); }
.st-card-body { padding: 14px 14px 16px; display: flex; flex-direction: column; flex: 1; }
.st-card-cat { font-family: var(--font-mono); font-size: 10px; letter-spacing: .08em; text-transform: uppercase; color: var(--voltage-blue); margin-bottom: 5px; }
.st-card-name { font-family: var(--font-display); font-weight: 700; font-size: 16px; color: var(--fg1); margin-bottom: 6px; line-height: 1.2; }
.st-card-tagline { font-size: 12px; color: var(--fg3); margin-bottom: 10px; line-height: 1.4; }
.st-card-specs { display: flex; flex-wrap: wrap; gap: 4px; margin-bottom: 10px; }
.st-spec-pill { font-family: var(--font-mono); font-size: 10px; padding: 3px 7px; background: var(--bg-sunken); border-radius: var(--r-pill); color: var(--fg2); border: 1px solid var(--line); }
.st-card-footer { margin-top: auto; }
.st-card-price { font-family: var(--font-display); font-weight: 800; font-size: 20px; color: var(--fg1); letter-spacing: -.01em; }
.st-card-price .from { font-size: 11px; color: var(--fg4); font-family: var(--font-mono); font-weight: 400; }
.st-card-moq { font-family: var(--font-mono); font-size: 10px; color: var(--fg3); margin-top: 3px; }
.st-card-rating { display: flex; align-items: center; gap: 5px; margin-top: 8px; font-size: 12px; color: var(--fg3); }
.stars { color: #F5A623; letter-spacing: -.5px; font-size: 13px; }

/* ---- PRODUCT IMAGE PLACEHOLDER ---- */
.st-prod-placeholder { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; position: relative; overflow: hidden; padding: 20px; background: linear-gradient(135deg, #0A1D35 0%, #0E3A6E 60%, #1B5A8A 100%); }
.st-prod-placeholder .pl-spec { font-family: var(--font-display); font-weight: 900; font-size: 42px; color: rgba(255,255,255,.9); letter-spacing: -.02em; line-height: 1; text-align: center; }
.st-prod-placeholder .pl-sub { font-family: var(--font-mono); font-size: 11px; letter-spacing: .1em; color: rgba(255,255,255,.6); text-transform: uppercase; margin-top: 4px; text-align: center; }
.st-prod-placeholder .pl-mark { position: absolute; bottom: 10px; right: 12px; opacity: .2; width: 36px; }

/* ---- TRUST BAR ---- */
.st-trust { background: var(--ink); padding: 28px 32px; }
.st-trust-inner { max-width: 1440px; margin: 0 auto; display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
.st-trust-item { display: flex; align-items: center; gap: 14px; }
.st-trust-item .ti { width: 44px; height: 44px; border-radius: var(--r-md); background: rgba(27,141,191,.2); display: flex; align-items: center; justify-content: center; flex: none; }
.st-trust-item .ti svg { width: 22px; height: 22px; stroke: var(--electric-lime); }
.st-trust-item .tt { font-family: var(--font-display); font-weight: 700; font-size: 15px; color: #fff; }
.st-trust-item .td { font-size: 13px; color: rgba(255,255,255,.54); margin-top: 2px; }

/* ---- LISTING PAGE ---- */
.st-listing { max-width: 1440px; margin: 0 auto; padding: 28px 32px 60px; display: grid; grid-template-columns: 240px 1fr; gap: 28px; align-items: start; }
.st-sidebar { background: var(--bg-raised); border: 1px solid var(--line); border-radius: var(--r-lg); padding: 24px; position: sticky; top: 120px; }
.st-sidebar h3 { font-family: var(--font-display); font-weight: 700; font-size: 18px; margin-bottom: 20px; }
.st-filter-group { margin-bottom: 22px; }
.st-filter-group h4 { font-family: var(--font-mono); font-size: 11px; letter-spacing: .1em; text-transform: uppercase; color: var(--fg3); margin-bottom: 12px; padding-bottom: 8px; border-bottom: 1px solid var(--line); }
.st-filter-option { display: flex; align-items: center; gap: 10px; padding: 5px 0; cursor: pointer; font-size: 14px; color: var(--fg2); }
.st-filter-option input[type=checkbox] { accent-color: var(--voltage-blue); width: 15px; height: 15px; }
.st-filter-option .fcount { margin-left: auto; font-family: var(--font-mono); font-size: 11px; color: var(--fg4); }
.st-filter-range { width: 100%; accent-color: var(--voltage-blue); }
.st-filter-range-labels { display: flex; justify-content: space-between; font-family: var(--font-mono); font-size: 11px; color: var(--fg3); margin-top: 4px; }
.st-clear-btn { width: 100%; font-family: var(--font-mono); font-size: 12px; letter-spacing: .06em; padding: 9px; border: 1px solid var(--line); background: transparent; border-radius: var(--r-sm); cursor: pointer; color: var(--fg3); margin-top: 8px; transition: .15s; }
.st-clear-btn:hover { background: var(--bg-sunken); color: var(--fg1); }

.st-listing-main {}
.st-sort-bar { display: flex; align-items: center; justify-content: space-between; margin-bottom: 18px; padding-bottom: 14px; border-bottom: 1px solid var(--line); }
.st-result-count { font-family: var(--font-mono); font-size: 13px; color: var(--fg3); }
.st-result-count strong { color: var(--fg1); }
.st-sort-controls { display: flex; align-items: center; gap: 12px; }
.st-sort-select { font-family: var(--font-mono); font-size: 12px; padding: 8px 14px; border: 1px solid var(--line); border-radius: var(--r-sm); background: var(--bg-raised); color: var(--fg1); cursor: pointer; }
.st-view-btns { display: flex; gap: 4px; }
.st-view-btn { width: 34px; height: 34px; border: 1px solid var(--line); border-radius: var(--r-sm); background: transparent; cursor: pointer; display: flex; align-items: center; justify-content: center; }
.st-view-btn.active { background: var(--voltage-blue); border-color: var(--voltage-blue); }
.st-view-btn svg { width: 16px; height: 16px; stroke: var(--fg3); }
.st-view-btn.active svg { stroke: #fff; }

/* ---- BREADCRUMB ---- */
.st-breadcrumb { font-family: var(--font-mono); font-size: 12px; letter-spacing: .04em; color: var(--fg3); padding: 16px 32px; max-width: 1440px; margin: 0 auto; display: flex; align-items: center; gap: 8px; }
.st-breadcrumb a { color: var(--fg3); cursor: pointer; text-decoration: none; }
.st-breadcrumb a:hover { color: var(--voltage-blue); }
.st-breadcrumb .sep { color: var(--fg4); }
.st-breadcrumb .current { color: var(--fg1); }

/* ---- DETAIL PAGE ---- */
.st-detail { max-width: 1440px; margin: 0 auto; padding: 0 32px 60px; }
.st-detail-grid { display: grid; grid-template-columns: 520px 1fr; gap: 48px; align-items: start; }
.st-detail-gallery { position: sticky; top: 120px; }
.st-detail-main-img { background: var(--bg-raised); border: 1px solid var(--line); border-radius: var(--r-lg); aspect-ratio: 4/3; display: flex; align-items: center; justify-content: center; overflow: hidden; margin-bottom: 12px; }
.st-detail-main-img img { max-width: 100%; max-height: 100%; object-fit: contain; padding: 24px; }
.st-detail-thumbs { display: flex; gap: 10px; }
.st-detail-thumb { width: 80px; height: 60px; border-radius: var(--r-sm); border: 2px solid var(--line); background: var(--bg-raised); overflow: hidden; cursor: pointer; display: flex; align-items: center; justify-content: center; padding: 4px; transition: border-color .15s; }
.st-detail-thumb.active, .st-detail-thumb:hover { border-color: var(--voltage-blue); }
.st-detail-thumb img { max-width: 100%; max-height: 100%; object-fit: contain; }
.st-detail-info {}
.st-detail-cat { font-family: var(--font-mono); font-size: 11px; letter-spacing: .12em; text-transform: uppercase; color: var(--voltage-blue); }
.st-detail-name { font-family: var(--font-display); font-weight: 800; font-size: 38px; letter-spacing: -.02em; line-height: 1.05; margin: 10px 0 4px; }
.st-detail-tagline { font-size: 18px; color: var(--fg3); margin-bottom: 18px; }
.st-detail-rating-row { display: flex; align-items: center; gap: 14px; margin-bottom: 22px; padding-bottom: 22px; border-bottom: 1px solid var(--line); }
.st-detail-price-block { background: var(--bg-sunken); border-radius: var(--r-lg); padding: 20px 22px; margin-bottom: 22px; }
.st-detail-price { font-family: var(--font-display); font-weight: 800; font-size: 44px; letter-spacing: -.02em; color: var(--fg1); }
.st-detail-bulk { margin-top: 10px; display: flex; gap: 10px; flex-wrap: wrap; }
.st-detail-bulk-row { font-family: var(--font-mono); font-size: 12px; background: var(--bg-raised); border: 1px solid var(--line); padding: 6px 12px; border-radius: var(--r-sm); color: var(--fg2); }
.st-detail-bulk-row strong { color: var(--voltage-blue); }
.st-detail-specs-table { width: 100%; border-collapse: collapse; margin-bottom: 22px; }
.st-detail-specs-table tr:nth-child(odd) td:first-child { background: var(--bg-sunken); }
.st-detail-specs-table td { padding: 10px 14px; font-size: 14px; border-bottom: 1px solid var(--line); }
.st-detail-specs-table td:first-child { font-family: var(--font-mono); font-size: 12px; letter-spacing: .04em; color: var(--fg3); width: 44%; }
.st-detail-specs-table td:last-child { font-weight: 600; color: var(--fg1); }
.st-detail-qty { display: flex; align-items: center; gap: 12px; margin-bottom: 18px; }
.st-qty-ctrl { display: flex; align-items: center; border: 1px solid var(--line-strong); border-radius: var(--r-sm); overflow: hidden; }
.st-qty-ctrl button { width: 38px; height: 38px; border: none; background: var(--bg-sunken); cursor: pointer; font-size: 18px; color: var(--fg2); display: flex; align-items: center; justify-content: center; transition: background .15s; }
.st-qty-ctrl button:hover { background: var(--bg-sand); }
.st-qty-ctrl input { width: 52px; height: 38px; border: none; text-align: center; font-family: var(--font-mono); font-size: 15px; background: var(--bg-raised); color: var(--fg1); outline: none; }
.st-detail-moq { font-family: var(--font-mono); font-size: 12px; color: var(--fg3); }
.st-detail-actions { display: flex; flex-direction: column; gap: 12px; margin-bottom: 22px; }
.st-detail-actions .btn { font-size: 16px; padding: 15px 24px; }
.st-detail-tags { display: flex; flex-wrap: wrap; gap: 8px; }
.st-detail-tag { font-family: var(--font-mono); font-size: 11px; padding: 5px 11px; border-radius: var(--r-pill); background: var(--blue-050); color: var(--blue-700); border: 1px solid var(--blue-100); }

/* ---- CART DRAWER ---- */
.st-overlay { position: fixed; inset: 0; background: rgba(14,15,18,.5); z-index: 200; opacity: 0; transition: opacity .25s; pointer-events: none; }
.st-overlay.open { opacity: 1; pointer-events: auto; }
.st-cart-drawer { position: fixed; top: 0; right: -480px; width: 440px; height: 100vh; background: var(--bg); z-index: 201; box-shadow: var(--shadow-lg); display: flex; flex-direction: column; transition: right .3s cubic-bezier(.2,.7,.2,1); overflow: hidden; }
.st-cart-drawer.open { right: 0; }
.st-cart-hdr { padding: 24px; border-bottom: 1px solid var(--line); display: flex; justify-content: space-between; align-items: center; }
.st-cart-hdr h3 { font-family: var(--font-display); font-weight: 800; font-size: 22px; }
.st-cart-hdr button { background: none; border: none; cursor: pointer; width: 32px; height: 32px; display: flex; align-items: center; justify-content: center; border-radius: var(--r-sm); }
.st-cart-hdr button:hover { background: var(--bg-sunken); }
.st-cart-items { flex: 1; overflow-y: auto; padding: 16px 24px; display: flex; flex-direction: column; gap: 14px; }
.st-cart-item { display: flex; gap: 14px; padding: 14px; background: var(--bg-raised); border: 1px solid var(--line); border-radius: var(--r-md); }
.st-cart-item-img { width: 72px; height: 54px; border-radius: var(--r-sm); background: var(--bg-sunken); overflow: hidden; flex: none; display: flex; align-items: center; justify-content: center; }
.st-cart-item-img img { width: 100%; height: 100%; object-fit: contain; padding: 4px; }
.st-cart-item-info { flex: 1; min-width: 0; }
.st-cart-item-name { font-family: var(--font-display); font-weight: 700; font-size: 15px; color: var(--fg1); }
.st-cart-item-sub { font-size: 12px; color: var(--fg3); margin-top: 2px; }
.st-cart-item-price { font-family: var(--font-mono); font-weight: 600; font-size: 15px; color: var(--fg1); margin-top: 8px; }
.st-cart-item-actions { display: flex; align-items: center; gap: 8px; margin-top: 8px; }
.st-cart-item-qty { display: flex; align-items: center; gap: 0; border: 1px solid var(--line); border-radius: var(--r-sm); overflow: hidden; }
.st-cart-item-qty button { width: 28px; height: 28px; background: var(--bg-sunken); border: none; cursor: pointer; font-size: 16px; color: var(--fg2); }
.st-cart-item-qty span { width: 34px; text-align: center; font-family: var(--font-mono); font-size: 13px; color: var(--fg1); }
.st-cart-rm { background: none; border: none; cursor: pointer; width: 26px; height: 26px; display: flex; align-items: center; justify-content: center; color: var(--fg4); border-radius: var(--r-sm); }
.st-cart-rm:hover { background: var(--bg-sunken); color: var(--danger); }
.st-cart-foot { padding: 20px 24px; border-top: 1px solid var(--line); }
.st-cart-subtotal { display: flex; justify-content: space-between; align-items: center; margin-bottom: 8px; }
.st-cart-subtotal .lbl { font-size: 15px; color: var(--fg2); }
.st-cart-subtotal .val { font-family: var(--font-display); font-weight: 800; font-size: 26px; color: var(--fg1); }
.st-cart-note { font-family: var(--font-mono); font-size: 11px; color: var(--fg3); margin-bottom: 16px; }

/* ---- CHECKOUT ---- */
.st-checkout { max-width: 1200px; margin: 0 auto; padding: 32px; display: grid; grid-template-columns: 1fr 380px; gap: 40px; align-items: start; }
.st-checkout-form h2 { font-family: var(--font-display); font-weight: 800; font-size: 30px; letter-spacing: -.015em; margin-bottom: 28px; }
.st-checkout-section { background: var(--bg-raised); border: 1px solid var(--line); border-radius: var(--r-lg); padding: 28px; margin-bottom: 20px; }
.st-checkout-section h3 { font-family: var(--font-display); font-weight: 700; font-size: 18px; margin-bottom: 18px; display: flex; align-items: center; gap: 10px; }
.st-checkout-section h3 .badge { font-family: var(--font-mono); font-size: 11px; width: 22px; height: 22px; border-radius: 50%; background: var(--voltage-blue); color: #fff; display: inline-flex; align-items: center; justify-content: center; }
.st-field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-bottom: 14px; }
.st-field { display: flex; flex-direction: column; gap: 6px; }
.st-field.full { grid-column: 1 / -1; }
.st-field label { font-family: var(--font-mono); font-size: 11px; letter-spacing: .08em; text-transform: uppercase; color: var(--fg3); }
.st-field input, .st-field select, .st-field textarea { font-family: var(--font-body); font-size: 15px; padding: 11px 14px; border: 1px solid var(--line-strong); border-radius: var(--r-sm); background: var(--bg); color: var(--fg1); outline: none; transition: .15s; }
.st-field input:focus, .st-field select:focus, .st-field textarea:focus { border-color: var(--voltage-blue); box-shadow: 0 0 0 3px var(--blue-100); }
.st-field textarea { resize: vertical; min-height: 80px; }
.st-order-type-pills { display: flex; gap: 10px; margin-bottom: 14px; }
.st-order-pill { flex: 1; padding: 12px; border: 2px solid var(--line); border-radius: var(--r-md); cursor: pointer; text-align: center; transition: .15s; }
.st-order-pill.active { border-color: var(--voltage-blue); background: var(--blue-050); }
.st-order-pill .pt { font-family: var(--font-display); font-weight: 700; font-size: 15px; }
.st-order-pill .ps { font-size: 12px; color: var(--fg3); margin-top: 2px; }
.st-checkout-summary { background: var(--bg-raised); border: 1px solid var(--line); border-radius: var(--r-lg); padding: 24px; position: sticky; top: 120px; }
.st-checkout-summary h3 { font-family: var(--font-display); font-weight: 700; font-size: 18px; margin-bottom: 18px; padding-bottom: 14px; border-bottom: 1px solid var(--line); }
.st-summary-item { display: flex; align-items: flex-start; gap: 12px; margin-bottom: 12px; }
.st-summary-item-img { width: 52px; height: 40px; background: var(--bg-sunken); border-radius: var(--r-sm); flex: none; overflow: hidden; display: flex; align-items: center; justify-content: center; }
.st-summary-item-img img { max-width: 100%; max-height: 100%; object-fit: contain; }
.st-summary-item-info { flex: 1; }
.st-summary-item-name { font-size: 13px; font-weight: 600; color: var(--fg1); }
.st-summary-item-qty { font-family: var(--font-mono); font-size: 11px; color: var(--fg3); }
.st-summary-item-price { font-family: var(--font-mono); font-size: 13px; font-weight: 600; color: var(--fg1); margin-left: auto; }
.st-summary-totals { margin-top: 16px; padding-top: 16px; border-top: 1px solid var(--line); display: flex; flex-direction: column; gap: 8px; }
.st-summary-row { display: flex; justify-content: space-between; font-size: 14px; color: var(--fg2); }
.st-summary-row.total { font-family: var(--font-display); font-weight: 800; font-size: 20px; color: var(--fg1); margin-top: 4px; }
.st-pay-methods { display: flex; gap: 8px; flex-wrap: wrap; margin: 16px 0; }
.st-pay-badge { font-family: var(--font-mono); font-size: 10px; padding: 4px 9px; border: 1px solid var(--line); border-radius: 4px; color: var(--fg3); }

/* ---- SUCCESS ---- */
.st-success { text-align: center; max-width: 560px; margin: 80px auto; padding: 0 32px; }
.st-success .icon { width: 80px; height: 80px; border-radius: 50%; background: var(--success-bg); display: flex; align-items: center; justify-content: center; margin: 0 auto 24px; }
.st-success .icon svg { width: 40px; height: 40px; stroke: var(--success); }
.st-success h2 { font-family: var(--font-display); font-weight: 800; font-size: 34px; letter-spacing: -.02em; margin-bottom: 12px; }
.st-success p { font-size: 17px; color: var(--fg3); margin-bottom: 32px; line-height: 1.55; }

/* ---- EMPTY CART ---- */
.st-empty-cart { text-align: center; padding: 60px 24px; color: var(--fg3); }
.st-empty-cart svg { width: 56px; height: 56px; stroke: var(--fg4); margin-bottom: 16px; }
.st-empty-cart p { font-size: 15px; }

/* ---- FOOTER ---- */
.st-footer { background: var(--ink); padding: 56px 32px 36px; }
.st-footer-inner { max-width: 1440px; margin: 0 auto; display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: 40px; margin-bottom: 40px; }
.st-footer-brand img { height: 44px; margin-bottom: 16px; }
.st-footer-brand p { font-size: 14px; color: rgba(255,255,255,.54); line-height: 1.6; max-width: 280px; }
.st-footer-col h4 { font-family: var(--font-mono); font-size: 11px; letter-spacing: .12em; text-transform: uppercase; color: var(--electric-lime); margin-bottom: 16px; }
.st-footer-col a { display: block; font-size: 14px; color: rgba(255,255,255,.58); margin-bottom: 10px; cursor: pointer; text-decoration: none; transition: color .15s; }
.st-footer-col a:hover { color: #fff; }
.st-footer-bottom { max-width: 1440px; margin: 0 auto; display: flex; justify-content: space-between; align-items: center; padding-top: 24px; border-top: 1px solid rgba(255,255,255,.1); font-family: var(--font-mono); font-size: 12px; color: rgba(255,255,255,.38); }

/* ---- UTILITIES ---- */
.eyebrow { font-family: var(--font-mono); font-weight: 500; font-size: 12px; letter-spacing: .2em; text-transform: uppercase; color: var(--voltage-blue); display: inline-flex; align-items: center; gap: 12px; }
.eyebrow::before { content: ""; width: 28px; height: 3px; background: var(--electric-lime); }

/* ---- JS RENDERED UTILITIES ---- */
.st-logo-click { cursor: pointer; }
.st-cart-icon-wrap { position: relative; }
.st-empty-state { text-align: center; padding: 60px 0; color: var(--fg3); }
.st-empty-state-lg { padding: 80px 0; }
.st-detail-unit { font-size: 16px; color: var(--fg3); font-family: var(--font-body); font-weight: 400; }
.st-detail-qty-label { font-family: var(--font-mono); font-size: 12px; color: var(--fg3); }
.st-detail-total { margin-left: auto; font-family: var(--font-mono); }
.st-detail-description { margin-top: 22px; padding-top: 20px; border-top: 1px solid var(--line); font-size: 15px; color: var(--fg2); line-height: 1.65; }
.st-cart-continue { margin-top: 10px; }
.st-auth-modal { position: fixed; z-index: 230; top: 96px; left: 50%; transform: translateX(-50%); width: min(440px, calc(100vw - 32px)); box-shadow: var(--shadow-lg); }
.st-auth-text { margin-bottom: 16px; color: var(--fg2); }
.st-auth-stack { margin-top: 12px; }
.st-auth-otp { margin-top: 14px; }
.st-auth-message { margin-top: 12px; color: var(--fg3); font-size: 14px; }
.st-auth-close { margin-top: 8px; }
.st-checkout-company, .st-checkout-city-row { margin-top: 14px; }
.st-place-order { font-size: 18px; padding: 18px; }
.st-loading { padding: 80px 32px; text-align: center; color: var(--fg3); }
.st-error { padding: 80px 32px; text-align: center; color: var(--danger); }

/* ---- BOOTSTRAP RESPONSIVE LAYER ---- */
@media (max-width: 1399.98px) {
  .st-product-grid { grid-template-columns: repeat(4, minmax(0, 1fr)); }
  .st-cats-grid { grid-template-columns: repeat(5, minmax(0, 1fr)); }
  .st-detail-grid { grid-template-columns: minmax(360px, 460px) 1fr; gap: 32px; }
}

@media (max-width: 1199.98px) {
  .st-header-top,
  .st-cat-nav-inner,
  .st-hero-inner,
  .st-cats,
  .st-section,
  .st-listing,
  .st-detail,
  .st-trust,
  .st-footer { padding-left: 24px; padding-right: 24px; }
  .st-hero-inner { grid-template-columns: 1fr 360px; gap: 36px; padding-top: 56px; padding-bottom: 64px; }
  .st-hero-title { font-size: 56px; }
  .st-product-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .st-listing { grid-template-columns: 220px 1fr; gap: 20px; }
  .st-detail-grid { grid-template-columns: 420px 1fr; }
  .st-checkout { grid-template-columns: 1fr 340px; gap: 28px; }
  .st-footer-inner { grid-template-columns: 1.2fr 1fr 1fr; }
}

@media (max-width: 991.98px) {
  .st-header { position: relative; }
  .st-header-top { flex-wrap: wrap; gap: 12px; }
  .st-logo { order: 1; }
  .st-hdr-actions { order: 2; margin-left: auto; }
  .st-search { order: 3; flex-basis: 100%; }
  .st-cat-nav-inner { padding-top: 2px; padding-bottom: 2px; }
  .st-hero-inner { grid-template-columns: 1fr; text-align: center; }
  .st-hero-sub { margin-left: auto; margin-right: auto; }
  .st-hero-ctas,
  .st-hero-stat-row { justify-content: center; }
  .st-hero-img img { max-width: 340px; }
  .st-cats-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .st-listing { display: block; }
  .st-sidebar { position: static; margin-bottom: 22px; }
  .st-filter-group { margin-bottom: 16px; }
  .st-detail-grid { grid-template-columns: 1fr; }
  .st-detail-gallery { position: static; }
  .st-detail-main-img { max-width: 560px; margin-left: auto; margin-right: auto; }
  .st-checkout { grid-template-columns: 1fr; }
  .st-checkout-summary { position: static; }
  .st-trust-inner { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .st-footer-inner { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 767.98px) {
  .st-header-top,
  .st-cat-nav-inner,
  .st-hero-inner,
  .st-cats,
  .st-section,
  .st-listing,
  .st-detail,
  .st-checkout,
  .st-trust,
  .st-footer,
  .st-breadcrumb { padding-left: 16px; padding-right: 16px; }
  .st-header-top { align-items: flex-start; }
  .st-logo img { height: 30px; }
  .st-hdr-actions { gap: 4px; }
  .st-hdr-btn { padding: 5px 7px; font-size: 10px; }
  .st-hdr-btn svg { width: 20px; height: 20px; }
  .st-search { border-radius: var(--r-md); flex-wrap: wrap; }
  .st-search-cat { width: 100%; border-right: none; border-bottom: 1px solid var(--line); padding: 10px 14px; }
  .st-search input { min-width: 0; padding: 12px 14px; }
  .st-search-btn { min-height: 44px; padding: 0 16px; }
  .st-cat-nav a { padding: 10px 12px; font-size: 11px; }
  .st-hero-inner { padding-top: 44px; padding-bottom: 52px; }
  .st-hero-title { font-size: 44px; }
  .st-hero-sub { font-size: 16px; }
  .st-hero-stat-row { gap: 18px; flex-wrap: wrap; }
  .st-hero-stat .n { font-size: 30px; }
  .st-hero-img img { max-width: 280px; }
  .st-cats { margin: 24px auto; }
  .st-cats-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .st-cat-tile { padding: 16px 12px 14px; }
  .st-product-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; }
  .st-card-hover-actions { position: static; opacity: 1; transform: none; }
  .st-card:hover { transform: none; }
  .st-sec-head { align-items: flex-start; gap: 10px; flex-direction: column; }
  .st-sort-bar { align-items: stretch; gap: 12px; flex-direction: column; }
  .st-sort-select { width: 100%; }
  .st-detail-name { font-size: 32px; }
  .st-detail-price { font-size: 34px; }
  .st-detail-qty { align-items: flex-start; flex-wrap: wrap; }
  .st-detail-total { width: 100%; margin-left: 0; }
  .st-field-row { grid-template-columns: 1fr; }
  .st-order-type-pills { flex-direction: column; }
  .st-cart-drawer { width: min(100vw, 420px); right: -100vw; }
  .st-cart-hdr,
  .st-cart-foot { padding: 18px; }
  .st-cart-items { padding: 14px 18px; }
  .st-auth-modal { top: 56px; max-height: calc(100vh - 72px); overflow-y: auto; }
  .st-trust-inner,
  .st-footer-inner { grid-template-columns: 1fr; }
  .st-footer-bottom { align-items: flex-start; gap: 8px; flex-direction: column; }
}

@media (max-width: 575.98px) {
  .st-hero-title { font-size: 38px; }
  .st-hero-kicker { font-size: 10px; letter-spacing: .16em; }
  .st-hero-ctas .btn { width: 100%; justify-content: center; }
  .st-cats-grid,
  .st-product-grid { grid-template-columns: 1fr; }
  .st-card-img { aspect-ratio: 16 / 10; }
  .st-detail-main-img { aspect-ratio: 1 / 1; }
  .st-detail-thumbs { overflow-x: auto; padding-bottom: 4px; }
  .st-detail-specs-table,
  .st-detail-specs-table tbody,
  .st-detail-specs-table tr,
  .st-detail-specs-table td { display: block; width: 100%; }
  .st-detail-specs-table tr { border-bottom: 1px solid var(--line); padding: 8px 0; }
  .st-detail-specs-table td { border-bottom: none; padding: 4px 0; }
  .st-cart-item { gap: 10px; padding: 12px; }
  .st-cart-item-img { width: 58px; height: 46px; }
  .st-summary-item { align-items: center; }
}
