/* ===== FONTS ===== */
/* latin-ext */
@font-face {
  font-family: 'Bebas Neue';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/font-01.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: 'Bebas Neue';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/font-02.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: 'Open Sans';
  font-style: normal;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("../fonts/font-03.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: 'Open Sans';
  font-style: normal;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("../fonts/font-04.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* greek-ext */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("../fonts/font-05.woff2") format('woff2');
  unicode-range: U+1F00-1FFF;
}
/* greek */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("../fonts/font-06.woff2") format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
/* hebrew */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("../fonts/font-07.woff2") format('woff2');
  unicode-range: U+0307-0308, U+0590-05FF, U+200C-2010, U+20AA, U+25CC, U+FB1D-FB4F;
}
/* math */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("../fonts/font-08.woff2") format('woff2');
  unicode-range: U+0302-0303, U+0305, U+0307-0308, U+0310, U+0312, U+0315, U+031A, U+0326-0327, U+032C, U+032F-0330, U+0332-0333, U+0338, U+033A, U+0346, U+034D, U+0391-03A1, U+03A3-03A9, U+03B1-03C9, U+03D1, U+03D5-03D6, U+03F0-03F1, U+03F4-03F5, U+2016-2017, U+2034-2038, U+203C, U+2040, U+2043, U+2047, U+2050, U+2057, U+205F, U+2070-2071, U+2074-208E, U+2090-209C, U+20D0-20DC, U+20E1, U+20E5-20EF, U+2100-2112, U+2114-2115, U+2117-2121, U+2123-214F, U+2190, U+2192, U+2194-21AE, U+21B0-21E5, U+21F1-21F2, U+21F4-2211, U+2213-2214, U+2216-22FF, U+2308-230B, U+2310, U+2319, U+231C-2321, U+2336-237A, U+237C, U+2395, U+239B-23B7, U+23D0, U+23DC-23E1, U+2474-2475, U+25AF, U+25B3, U+25B7, U+25BD, U+25C1, U+25CA, U+25CC, U+25FB, U+266D-266F, U+27C0-27FF, U+2900-2AFF, U+2B0E-2B11, U+2B30-2B4C, U+2BFE, U+3030, U+FF5B, U+FF5D, U+1D400-1D7FF, U+1EE00-1EEFF;
}
/* symbols */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("../fonts/font-09.woff2") format('woff2');
  unicode-range: U+0001-000C, U+000E-001F, U+007F-009F, U+20DD-20E0, U+20E2-20E4, U+2150-218F, U+2190, U+2192, U+2194-2199, U+21AF, U+21E6-21F0, U+21F3, U+2218-2219, U+2299, U+22C4-22C6, U+2300-243F, U+2440-244A, U+2460-24FF, U+25A0-27BF, U+2800-28FF, U+2921-2922, U+2981, U+29BF, U+29EB, U+2B00-2BFF, U+4DC0-4DFF, U+FFF9-FFFB, U+10140-1018E, U+10190-1019C, U+101A0, U+101D0-101FD, U+102E0-102FB, U+10E60-10E7E, U+1D2C0-1D2D3, U+1D2E0-1D37F, U+1F000-1F0FF, U+1F100-1F1AD, U+1F1E6-1F1FF, U+1F30D-1F30F, U+1F315, U+1F31C, U+1F31E, U+1F320-1F32C, U+1F336, U+1F378, U+1F37D, U+1F382, U+1F393-1F39F, U+1F3A7-1F3A8, U+1F3AC-1F3AF, U+1F3C2, U+1F3C4-1F3C6, U+1F3CA-1F3CE, U+1F3D4-1F3E0, U+1F3ED, U+1F3F1-1F3F3, U+1F3F5-1F3F7, U+1F408, U+1F415, U+1F41F, U+1F426, U+1F43F, U+1F441-1F442, U+1F444, U+1F446-1F449, U+1F44C-1F44E, U+1F453, U+1F46A, U+1F47D, U+1F4A3, U+1F4B0, U+1F4B3, U+1F4B9, U+1F4BB, U+1F4BF, U+1F4C8-1F4CB, U+1F4D6, U+1F4DA, U+1F4DF, U+1F4E3-1F4E6, U+1F4EA-1F4ED, U+1F4F7, U+1F4F9-1F4FB, U+1F4FD-1F4FE, U+1F503, U+1F507-1F50B, U+1F50D, U+1F512-1F513, U+1F53E-1F54A, U+1F54F-1F5FA, U+1F610, U+1F650-1F67F, U+1F687, U+1F68D, U+1F691, U+1F694, U+1F698, U+1F6AD, U+1F6B2, U+1F6B9-1F6BA, U+1F6BC, U+1F6C6-1F6CF, U+1F6D3-1F6D7, U+1F6E0-1F6EA, U+1F6F0-1F6F3, U+1F6F7-1F6FC, U+1F700-1F7FF, U+1F800-1F80B, U+1F810-1F847, U+1F850-1F859, U+1F860-1F887, U+1F890-1F8AD, U+1F8B0-1F8BB, U+1F8C0-1F8C1, U+1F900-1F90B, U+1F93B, U+1F946, U+1F984, U+1F996, U+1F9E9, U+1FA00-1FA6F, U+1FA70-1FA7C, U+1FA80-1FA89, U+1FA8F-1FAC6, U+1FACE-1FADC, U+1FADF-1FAE9, U+1FAF0-1FAF8, U+1FB00-1FBFF;
}
/* vietnamese */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("../fonts/font-10.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: 'Open Sans';
  font-style: normal;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("../fonts/font-11.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: 'Open Sans';
  font-style: normal;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("../fonts/font-12.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: 'Open Sans';
  font-style: normal;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url("../fonts/font-03.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: 'Open Sans';
  font-style: normal;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url("../fonts/font-04.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* greek-ext */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url("../fonts/font-05.woff2") format('woff2');
  unicode-range: U+1F00-1FFF;
}
/* greek */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url("../fonts/font-06.woff2") format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
/* hebrew */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url("../fonts/font-07.woff2") format('woff2');
  unicode-range: U+0307-0308, U+0590-05FF, U+200C-2010, U+20AA, U+25CC, U+FB1D-FB4F;
}
/* math */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url("../fonts/font-08.woff2") format('woff2');
  unicode-range: U+0302-0303, U+0305, U+0307-0308, U+0310, U+0312, U+0315, U+031A, U+0326-0327, U+032C, U+032F-0330, U+0332-0333, U+0338, U+033A, U+0346, U+034D, U+0391-03A1, U+03A3-03A9, U+03B1-03C9, U+03D1, U+03D5-03D6, U+03F0-03F1, U+03F4-03F5, U+2016-2017, U+2034-2038, U+203C, U+2040, U+2043, U+2047, U+2050, U+2057, U+205F, U+2070-2071, U+2074-208E, U+2090-209C, U+20D0-20DC, U+20E1, U+20E5-20EF, U+2100-2112, U+2114-2115, U+2117-2121, U+2123-214F, U+2190, U+2192, U+2194-21AE, U+21B0-21E5, U+21F1-21F2, U+21F4-2211, U+2213-2214, U+2216-22FF, U+2308-230B, U+2310, U+2319, U+231C-2321, U+2336-237A, U+237C, U+2395, U+239B-23B7, U+23D0, U+23DC-23E1, U+2474-2475, U+25AF, U+25B3, U+25B7, U+25BD, U+25C1, U+25CA, U+25CC, U+25FB, U+266D-266F, U+27C0-27FF, U+2900-2AFF, U+2B0E-2B11, U+2B30-2B4C, U+2BFE, U+3030, U+FF5B, U+FF5D, U+1D400-1D7FF, U+1EE00-1EEFF;
}
/* symbols */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url("../fonts/font-09.woff2") format('woff2');
  unicode-range: U+0001-000C, U+000E-001F, U+007F-009F, U+20DD-20E0, U+20E2-20E4, U+2150-218F, U+2190, U+2192, U+2194-2199, U+21AF, U+21E6-21F0, U+21F3, U+2218-2219, U+2299, U+22C4-22C6, U+2300-243F, U+2440-244A, U+2460-24FF, U+25A0-27BF, U+2800-28FF, U+2921-2922, U+2981, U+29BF, U+29EB, U+2B00-2BFF, U+4DC0-4DFF, U+FFF9-FFFB, U+10140-1018E, U+10190-1019C, U+101A0, U+101D0-101FD, U+102E0-102FB, U+10E60-10E7E, U+1D2C0-1D2D3, U+1D2E0-1D37F, U+1F000-1F0FF, U+1F100-1F1AD, U+1F1E6-1F1FF, U+1F30D-1F30F, U+1F315, U+1F31C, U+1F31E, U+1F320-1F32C, U+1F336, U+1F378, U+1F37D, U+1F382, U+1F393-1F39F, U+1F3A7-1F3A8, U+1F3AC-1F3AF, U+1F3C2, U+1F3C4-1F3C6, U+1F3CA-1F3CE, U+1F3D4-1F3E0, U+1F3ED, U+1F3F1-1F3F3, U+1F3F5-1F3F7, U+1F408, U+1F415, U+1F41F, U+1F426, U+1F43F, U+1F441-1F442, U+1F444, U+1F446-1F449, U+1F44C-1F44E, U+1F453, U+1F46A, U+1F47D, U+1F4A3, U+1F4B0, U+1F4B3, U+1F4B9, U+1F4BB, U+1F4BF, U+1F4C8-1F4CB, U+1F4D6, U+1F4DA, U+1F4DF, U+1F4E3-1F4E6, U+1F4EA-1F4ED, U+1F4F7, U+1F4F9-1F4FB, U+1F4FD-1F4FE, U+1F503, U+1F507-1F50B, U+1F50D, U+1F512-1F513, U+1F53E-1F54A, U+1F54F-1F5FA, U+1F610, U+1F650-1F67F, U+1F687, U+1F68D, U+1F691, U+1F694, U+1F698, U+1F6AD, U+1F6B2, U+1F6B9-1F6BA, U+1F6BC, U+1F6C6-1F6CF, U+1F6D3-1F6D7, U+1F6E0-1F6EA, U+1F6F0-1F6F3, U+1F6F7-1F6FC, U+1F700-1F7FF, U+1F800-1F80B, U+1F810-1F847, U+1F850-1F859, U+1F860-1F887, U+1F890-1F8AD, U+1F8B0-1F8BB, U+1F8C0-1F8C1, U+1F900-1F90B, U+1F93B, U+1F946, U+1F984, U+1F996, U+1F9E9, U+1FA00-1FA6F, U+1FA70-1FA7C, U+1FA80-1FA89, U+1FA8F-1FAC6, U+1FACE-1FADC, U+1FADF-1FAE9, U+1FAF0-1FAF8, U+1FB00-1FBFF;
}
/* vietnamese */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url("../fonts/font-10.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: 'Open Sans';
  font-style: normal;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url("../fonts/font-11.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: 'Open Sans';
  font-style: normal;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url("../fonts/font-12.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: 'Open Sans';
  font-style: normal;
  font-weight: 700;
  font-stretch: 100%;
  font-display: swap;
  src: url("../fonts/font-03.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: 'Open Sans';
  font-style: normal;
  font-weight: 700;
  font-stretch: 100%;
  font-display: swap;
  src: url("../fonts/font-04.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* greek-ext */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 700;
  font-stretch: 100%;
  font-display: swap;
  src: url("../fonts/font-05.woff2") format('woff2');
  unicode-range: U+1F00-1FFF;
}
/* greek */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 700;
  font-stretch: 100%;
  font-display: swap;
  src: url("../fonts/font-06.woff2") format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
/* hebrew */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 700;
  font-stretch: 100%;
  font-display: swap;
  src: url("../fonts/font-07.woff2") format('woff2');
  unicode-range: U+0307-0308, U+0590-05FF, U+200C-2010, U+20AA, U+25CC, U+FB1D-FB4F;
}
/* math */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 700;
  font-stretch: 100%;
  font-display: swap;
  src: url("../fonts/font-08.woff2") format('woff2');
  unicode-range: U+0302-0303, U+0305, U+0307-0308, U+0310, U+0312, U+0315, U+031A, U+0326-0327, U+032C, U+032F-0330, U+0332-0333, U+0338, U+033A, U+0346, U+034D, U+0391-03A1, U+03A3-03A9, U+03B1-03C9, U+03D1, U+03D5-03D6, U+03F0-03F1, U+03F4-03F5, U+2016-2017, U+2034-2038, U+203C, U+2040, U+2043, U+2047, U+2050, U+2057, U+205F, U+2070-2071, U+2074-208E, U+2090-209C, U+20D0-20DC, U+20E1, U+20E5-20EF, U+2100-2112, U+2114-2115, U+2117-2121, U+2123-214F, U+2190, U+2192, U+2194-21AE, U+21B0-21E5, U+21F1-21F2, U+21F4-2211, U+2213-2214, U+2216-22FF, U+2308-230B, U+2310, U+2319, U+231C-2321, U+2336-237A, U+237C, U+2395, U+239B-23B7, U+23D0, U+23DC-23E1, U+2474-2475, U+25AF, U+25B3, U+25B7, U+25BD, U+25C1, U+25CA, U+25CC, U+25FB, U+266D-266F, U+27C0-27FF, U+2900-2AFF, U+2B0E-2B11, U+2B30-2B4C, U+2BFE, U+3030, U+FF5B, U+FF5D, U+1D400-1D7FF, U+1EE00-1EEFF;
}
/* symbols */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 700;
  font-stretch: 100%;
  font-display: swap;
  src: url("../fonts/font-09.woff2") format('woff2');
  unicode-range: U+0001-000C, U+000E-001F, U+007F-009F, U+20DD-20E0, U+20E2-20E4, U+2150-218F, U+2190, U+2192, U+2194-2199, U+21AF, U+21E6-21F0, U+21F3, U+2218-2219, U+2299, U+22C4-22C6, U+2300-243F, U+2440-244A, U+2460-24FF, U+25A0-27BF, U+2800-28FF, U+2921-2922, U+2981, U+29BF, U+29EB, U+2B00-2BFF, U+4DC0-4DFF, U+FFF9-FFFB, U+10140-1018E, U+10190-1019C, U+101A0, U+101D0-101FD, U+102E0-102FB, U+10E60-10E7E, U+1D2C0-1D2D3, U+1D2E0-1D37F, U+1F000-1F0FF, U+1F100-1F1AD, U+1F1E6-1F1FF, U+1F30D-1F30F, U+1F315, U+1F31C, U+1F31E, U+1F320-1F32C, U+1F336, U+1F378, U+1F37D, U+1F382, U+1F393-1F39F, U+1F3A7-1F3A8, U+1F3AC-1F3AF, U+1F3C2, U+1F3C4-1F3C6, U+1F3CA-1F3CE, U+1F3D4-1F3E0, U+1F3ED, U+1F3F1-1F3F3, U+1F3F5-1F3F7, U+1F408, U+1F415, U+1F41F, U+1F426, U+1F43F, U+1F441-1F442, U+1F444, U+1F446-1F449, U+1F44C-1F44E, U+1F453, U+1F46A, U+1F47D, U+1F4A3, U+1F4B0, U+1F4B3, U+1F4B9, U+1F4BB, U+1F4BF, U+1F4C8-1F4CB, U+1F4D6, U+1F4DA, U+1F4DF, U+1F4E3-1F4E6, U+1F4EA-1F4ED, U+1F4F7, U+1F4F9-1F4FB, U+1F4FD-1F4FE, U+1F503, U+1F507-1F50B, U+1F50D, U+1F512-1F513, U+1F53E-1F54A, U+1F54F-1F5FA, U+1F610, U+1F650-1F67F, U+1F687, U+1F68D, U+1F691, U+1F694, U+1F698, U+1F6AD, U+1F6B2, U+1F6B9-1F6BA, U+1F6BC, U+1F6C6-1F6CF, U+1F6D3-1F6D7, U+1F6E0-1F6EA, U+1F6F0-1F6F3, U+1F6F7-1F6FC, U+1F700-1F7FF, U+1F800-1F80B, U+1F810-1F847, U+1F850-1F859, U+1F860-1F887, U+1F890-1F8AD, U+1F8B0-1F8BB, U+1F8C0-1F8C1, U+1F900-1F90B, U+1F93B, U+1F946, U+1F984, U+1F996, U+1F9E9, U+1FA00-1FA6F, U+1FA70-1FA7C, U+1FA80-1FA89, U+1FA8F-1FAC6, U+1FACE-1FADC, U+1FADF-1FAE9, U+1FAF0-1FAF8, U+1FB00-1FBFF;
}
/* vietnamese */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 700;
  font-stretch: 100%;
  font-display: swap;
  src: url("../fonts/font-10.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: 'Open Sans';
  font-style: normal;
  font-weight: 700;
  font-stretch: 100%;
  font-display: swap;
  src: url("../fonts/font-11.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: 'Open Sans';
  font-style: normal;
  font-weight: 700;
  font-stretch: 100%;
  font-display: swap;
  src: url("../fonts/font-12.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;
}

/* ===== APP STYLES ===== */

  *, *::before, *::after { box-sizing: border-box; }
  html, body { margin: 0; padding: 0; background: #fff; }
  body {
    font-family: 'Open Sans', sans-serif;
    color: #000;
    font-size: 18px;
    line-height: 1.4;
  }
  a { color: inherit; text-decoration: none; }
  button { font-family: inherit; cursor: pointer; border: none; background: none; padding: 0; }
  img { display: block; max-width: 100%; }
  h1,h2,h3,h4 { margin: 0; font-weight: normal; }
  .bebas { font-family: 'Bebas Neue', sans-serif; letter-spacing: 0.03em; }

  /* 1920px design canvas — scales down responsively */
  .canvas {
    width: 1920px;
    margin: 0 auto;
    position: relative;
    transform-origin: top center;
  }

  /* ============= HEADER (128px) ============= */
  .header {
    width: 1920px;
    height: 128px;
    background: #fff;
    position: relative;
  }
  .header .logo {
    position: absolute;
    left: 250px;
    top: 20px;
    width: 222px;
    height: 88px;
  }
  .header .nav {
    position: absolute;
    left: 560px;
    top: 52px;
    width: 880px;
    height: 25px;
    display: flex;
    flex-direction: row;
    gap: 28px;
    align-items: center;
  }
  .header .nav a {
    font-family: 'Open Sans', sans-serif;
    font-size: 18px;
    line-height: 1;
    color: #000;
    white-space: nowrap;
  }
  .header .phone-btn {
    position: absolute;
    left: 1482px;
    top: 42px;
    width: 188px;
    height: 45px;
    border-radius: 10px;
    border: 1px solid #000;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: 'Open Sans', sans-serif;
    font-weight: 700;
    font-size: 18px;
    color: #000;
    transition: background .15s;
  }
  .header .phone-btn:hover { background: #ffdd2d; }

  /* ============= HERO (820px) ============= */
  .hero {
    position: relative;
    width: 1920px;
    height: 820px;
    background-image:
      linear-gradient(rgba(255,255,255,.6) 0%, rgba(255,255,255,0) 100%),
      url("../images/hero-bg.jpg");
    background-size: cover;
    background-position: center;
  }
  .hero h1 {
    position: absolute;
    left: 160px;
    top: 60px;
    width: 1600px;
    font-family: 'Bebas Neue', sans-serif;
    font-size: 90px;
    line-height: 1;
    letter-spacing: 0.03em;
    text-align: center;
    color: #000;
    text-transform: uppercase;
  }
  .hero-cta {
    position: absolute;
    left: 725px;
    top: 220px;
    width: 470px;
    height: 65px;
    display: flex;
    flex-direction: row;
    gap: 20px;
    align-items: center;
  }

  /* ============= BUTTONS ============= */
  .btn {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 65px;
    padding: 20px 34px;
    border-radius: 16px;
    font-family: 'Open Sans', sans-serif;
    font-size: 18px;
    line-height: 1;
    color: #000;
    cursor: pointer;
    transition: transform .15s, box-shadow .15s;
    white-space: nowrap;
  }
  .btn:hover { transform: translateY(-1px); box-shadow: 0 6px 18px rgba(0,0,0,.12); }
  .btn-yellow { background: #ffdd2d; }
  .btn-ghost { background: rgba(255,255,255,.3); backdrop-filter: blur(4px); }
  .btn-outline {
    height: 57px;
    padding: 16px 24px;
    border-radius: 16px;
    border: 1px solid #aaa;
    background: #fff;
    font-family: 'Open Sans', sans-serif;
    font-size: 18px;
    color: #000;
    transition: border-color .15s;
  }
  .btn-outline:hover { border-color: #000; }

  /* ============= SECTION TITLES ============= */
  .section-title {
    font-family: 'Bebas Neue', sans-serif;
    font-size: 50px;
    line-height: 1;
    letter-spacing: 0.02em;
    color: #000;
    text-transform: uppercase;
    white-space: nowrap;
  }
  .section-title.wrap { white-space: normal; line-height: 1.05; }

  /* ============= ABOUT (top: 1098, w 1420 h 672) ============= */
  .about {
    position: relative;
    left: 250px;
    width: 1420px;
    margin-top: 80px; /* 1098 - 128 - 820 = 150 */
    height: 672px;
  }
  .about h2 {
    position: absolute;
    left: 0; top: 0;
    width: auto; height: 50px;
  }
  .about .desc {
    position: absolute;
    left: 0; top: 90px;
    width: 700px; height: 206px;
    font-family: 'Open Sans', sans-serif;
    font-size: 20px;
    line-height: 1.4;
    color: #000;
  }
  .about .desc p { margin: 0 0 1em 0; }
  .about .photo {
    position: absolute;
    left: 837px; top: 90px;
    width: 583px; height: 582px;
    background: url("../images/about-photo.jpg") center/cover no-repeat;
    border-radius: 20px;
  }
  .pros {
    position: absolute;
    left: 0; top: 434px;
    width: 700px; height: 238px;
  }
  .pro {
    position: absolute;
    width: 340px; height: 50px;
    display: flex;
    flex-direction: row;
    gap: 20px;
    align-items: center;
  }
  .pro-icon {
    width: 50px; height: 50px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 50px;
  }
  .pro-icon img { width: 50px; height: 50px; object-fit: contain; }
  .pro-text {
    width: 270px; height: 50px;
    font-family: 'Open Sans', sans-serif;
    font-weight: 700;
    font-size: 18px;
    line-height: 1.2;
    color: #000;
    display: flex;
    align-items: center;
  }

  /* ============= CALC / QUIZ (top: 1920) ============= */
  .calc {
    position: relative;
    width: 1420px;
    margin: 80px auto 0;
  }
  .calc h2 {
    text-align: center;
    margin-bottom: 40px;
  }
  .quiz {
    position: relative;
    width: 100%;
    border-radius: 30px;
    background: #fff;
    box-shadow: 0 4px 40px rgba(0,0,0,.08);
    color: #000;
    padding: 50px 60px 40px;
  }
  .quiz-question {
    font-family: 'Open Sans', sans-serif;
    font-weight: 600;
    font-size: 28px;
    line-height: 1.2;
    margin-bottom: 32px;
  }
  .quiz-options {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px 20px;
    margin-bottom: 40px;
  }
  .quiz-opt {
    display: flex;
    align-items: center;
    gap: 16px;
    height: 64px;
    padding: 0 22px;
    border-radius: 12px;
    background: #fff;
    border: 1px solid #e6e6e6;
    cursor: pointer;
    font-family: 'Open Sans', sans-serif;
    font-size: 18px;
    line-height: 1.2;
    color: #000;
    text-align: left;
    transition: border-color .15s, background .15s;
  }
  .quiz-opt:hover { border-color: #f1b910; }
  .quiz-opt .dot {
    width: 22px; height: 22px;
    flex: 0 0 22px;
    border-radius: 50%;
    border: 2px solid #d0d0d0;
    background: #f4f4f4;
    position: relative;
    transition: border-color .15s, background .15s;
  }
  .quiz-opt.selected { border-color: #f1b910; background: #fffbe6; }
  .quiz-opt.selected .dot { border-color: #f1b910; background: #f1b910; }
  .quiz-opt.selected .dot::after {
    content: '';
    position: absolute;
    inset: 4px;
    border-radius: 50%;
    background: #fff;
  }
  .quiz-input {
    width: 100%;
    height: 64px;
    padding: 0 22px;
    border-radius: 12px;
    border: 1px solid #e6e6e6;
    background: #fff;
    font-family: 'Open Sans', sans-serif;
    font-size: 18px;
    color: #000;
    margin-bottom: 16px;
  }
  .quiz-input:focus { outline: none; border-color: #f1b910; }
  .quiz-bottom {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
  }
  .quiz-progress-wrap {
    flex: 1 1 auto;
    max-width: 60%;
  }
  .quiz-progress-label {
    font-family: 'Open Sans', sans-serif;
    font-size: 16px;
    color: #6b6b6b;
    margin-bottom: 10px;
  }
  .quiz-progress-label b { color: #f1b910; font-weight: 700; }
  .quiz-progress-bar {
    width: 100%;
    height: 6px;
    border-radius: 4px;
    background: #e6e6e6;
    overflow: hidden;
  }
  .quiz-progress-fill {
    height: 100%;
    background: #f1b910;
    width: 0;
    transition: width .3s ease;
  }
  .quiz-nav {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 6px;
  }
  .quiz-nav-row {
    display: flex;
    gap: 12px;
    align-items: center;
  }
  .quiz-back {
    width: 56px; height: 56px;
    border-radius: 12px;
    background: #fff;
    border: 1px solid #e6e6e6;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    color: #333;
    transition: border-color .15s, color .15s;
  }
  .quiz-back:hover { border-color: #aaa; color: #000; }
  .quiz-back[disabled] { opacity: .35; cursor: not-allowed; }
  .quiz-next {
    height: 56px;
    padding: 0 28px;
    border-radius: 12px;
    background: #ffdd2d;
    font-family: 'Open Sans', sans-serif;
    font-size: 18px;
    color: #000;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 10px;
    transition: background .15s;
  }
  .quiz-next:hover { background: #f1b910; }
  .quiz-next[disabled] { opacity: .45; cursor: not-allowed; }
  .quiz-hint {
    font-family: 'Open Sans', sans-serif;
    font-size: 13px;
    color: #999;
  }
  .quiz-hint kbd {
    font-family: inherit;
    background: #ececec;
    padding: 1px 6px;
    border-radius: 4px;
  }

  /* ============= SERVICES (top: 2720, h 1189) ============= */
  .services {
    position: relative;
    left: 250px;
    width: 1420px;
    margin-top: 80px;
    height: 1230px;
  }
  .services h2 {
    position: absolute;
    left: 0; top: 0;
    width: auto; height: 50px;
  }
  .service-card {
    position: absolute;
    width: 460px;
    display: flex;
    flex-direction: column;
    align-items: center;
    transition: transform .2s;
    cursor: pointer;
  }
  .service-card:hover { transform: translateY(-6px); }
  .service-card .img {
    width: 460px;
    height: 263px;
    border-radius: 20px;
    background-size: cover;
    background-position: center;
    background-color: #f4f4f4;
    position: relative;
    overflow: hidden;
  }
  .service-card .img::after {
    content: '';
    position: absolute;
    inset: 0;
    background: rgba(241,185,16,.0);
    border-radius: 20px;
    transition: background .2s;
  }
  .service-card:hover .img::after {
    background: rgba(241,185,16,.18);
  }
  .service-card h4 {
    margin-top: 20px;
    width: 460px;
    font-family: 'Open Sans', sans-serif;
    font-weight: 700;
    font-size: 24px;
    line-height: 1.3;
    text-align: center;
    color: #000;
    white-space: normal;
    overflow: visible;
  }

  /* ============= ADVANTAGES (top: 4059, h 1030) ============= */
  .advantages {
    position: relative;
    left: 250px;
    width: 1420px;
    margin-top: 80px;
    height: 1090px;
  }
  .advantages h2 {
    position: absolute;
    left: 0; top: 0;
    width: auto;
  }
  .advantages .grid {
    position: absolute;
    left: 0; top: 120px;
    width: 1420px; height: 940px;
  }
  .adv-card {
    position: absolute;
    width: 460px; height: 300px;
    border-radius: 20px;
    background: #fff8d6;
    padding: 36px 36px;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    gap: 16px;
  }
  .adv-card h4 {
    font-family: 'Open Sans', sans-serif;
    font-weight: 700; font-size: 22px;
    line-height: 1.25; color: #000;
  }
  .adv-card p {
    font-family: 'Open Sans', sans-serif;
    font-size: 15px; line-height: 1.55;
    color: #000;
  }
  .adv-img {
    position: absolute;
    border-radius: 20px;
    background-size: cover;
    background-position: center;
  }

  /* ============= PRICES (top: 5239, h 585) ============= */
  .prices {
    position: relative;
    left: 250px;
    width: 1420px;
    margin-top: 80px;
    height: 585px;
  }
  .prices h2 {
    position: absolute;
    left: 0; top: 0;
    width: auto; height: 50px;
  }
  .price-grid {
    position: absolute;
    left: 0; top: 90px;
    width: 1420px; height: 495px;
    display: flex;
    flex-direction: row;
    gap: 20px;
    align-items: flex-start;
  }
  .price-card {
    width: 268px;
    height: 495px;
    display: flex;
    flex-direction: column;
    gap: 20px;
  }
  .price-card .img {
    width: 268px;
    height: 175px;
    border-radius: 20px;
    background-size: cover;
    background-position: center;
    background-color: #eee;
  }
  .price-card .body {
    width: 268px;
    height: 300px;
    padding: 0 10px;
    display: flex;
    flex-direction: column;
    gap: 16px;
  }
  .price-card h4 {
    font-family: 'Open Sans', sans-serif;
    font-weight: 700; font-size: 20px;
    line-height: 1.2;
  }
  .price-card .specs { display: flex; flex-direction: column; gap: 8px; }
  .spec-row { display: flex; justify-content: space-between; font-size: 15px; line-height: 1; }
  .spec-row .label { opacity: .5; }
  .price-actions {
    display: flex;
    justify-content: space-between;
    align-items: center;
    height: 57px;
    margin-top: auto;
  }
  .price-actions .btn-outline {
    width: 130px;
    padding: 14px 10px;
    font-size: 15px;
    white-space: nowrap;
  }
  .price-num {
    display: flex; gap: 6px; align-items: baseline;
    font-family: 'Open Sans', sans-serif;
    font-weight: 700; font-size: 20px;
  }
  .price-old { font-weight: 400; font-size: 16px; opacity: .5; text-decoration: line-through; }

  .promo-card {
    width: 268px;
    height: 495px;
    border-radius: 20px;
    overflow: hidden;
    background:
      linear-gradient(rgba(0,0,0,.5), rgba(0,0,0,.5)),
      url("../images/promo-bg.jpg") center/cover no-repeat;
    color: #fff;
    position: relative;
  }
  .promo-stat {
    position: absolute;
    left: 14px; top: 49px;
    width: 240px; height: 82px;
    display: flex;
    flex-direction: row;
    gap: 16px;
    align-items: center;
  }
  .promo-stat .num {
    font-family: 'Open Sans', sans-serif;
    font-size: 60px; line-height: 1;
    color: #f1b910;
  }
  .promo-stat .lbl {
    font-family: 'Open Sans', sans-serif;
    font-weight: 700; font-size: 18px;
    line-height: 1.2;
  }
  .promo-list {
    position: absolute;
    left: 14px; top: 160px;
    display: flex;
    flex-direction: column;
    gap: 12px;
    width: 240px;
    list-style: none;
    padding: 0; margin: 0;
  }
  .promo-list li {
    display: flex;
    gap: 8px;
    font-weight: 700;
    font-size: 15px;
    line-height: 1.3;
    align-items: flex-start;
  }
  .promo-list li svg { flex: 0 0 24px; margin-top: 2px; }
  .promo-call {
    position: absolute;
    left: 14px;
    top: 360px;
    width: 240px;
    text-align: center;
  }
  .promo-call .small {
    font-family: 'Open Sans', sans-serif;
    font-weight: 700; font-size: 15px;
    line-height: 1.4;
  }
  .promo-call .num {
    font-family: 'Open Sans', sans-serif;
    font-weight: 700; font-size: 24px;
    color: #f1b910;
    margin-top: 12px;
  }

  /* ============= PRODUCER (top: 5974, h 558) ============= */
  .producer {
    position: relative;
    left: 250px;
    width: 1420px;
    margin-top: 80px;
    height: 600px;
  }
  .producer h2 {
    position: absolute;
    left: 0; top: 0;
    width: auto;
    white-space: normal;
    max-width: 700px;
  }
  .producer .desc {
    position: absolute;
    left: 0; top: 100px;
    width: 700px; height: 380px;
    font-family: 'Open Sans', sans-serif;
    font-size: 20px;
    line-height: 1.4;
  }
  .producer .desc p { margin: 0 0 1em 0; }
  .producer .photo {
    position: absolute;
    left: 720px; top: 100px;
    width: 700px; height: 467px;
    background: url("../images/production.jpg") center/cover no-repeat;
    border-radius: 20px;
  }
  .producer .cta {
    position: absolute;
    left: 0; top: 500px;
    width: 367px; height: 65px;
    background: #ffdd2d;
    border-radius: 16px;
  }

  /* ============= CERT (top: 6682, h 702) ============= */
  .cert {
    position: relative;
    left: 250px;
    width: 1420px;
    margin-top: 80px;
    height: 750px;
  }
  .cert h2 {
    position: absolute;
    left: 0; top: 0;
    width: auto;
  }
  .cert .desc {
    position: absolute;
    left: 0; top: 100px;
    width: 460px;
    font-family: 'Open Sans', sans-serif;
    font-size: 18px;
    line-height: 1.5;
  }
  .cert .desc p { margin: 0 0 28px 0; }
  .cert .img1 {
    position: absolute;
    left: 480px; top: 100px;
    width: 460px; height: 612px;
    border-radius: 20px;
    background: url("../images/cert-1.jpg") center/cover no-repeat;
    border: 1px solid rgba(0,0,0,.25);
  }
  .cert .img2 {
    position: absolute;
    left: 960px; top: 100px;
    width: 460px; height: 612px;
    border-radius: 20px;
    background: url("../images/cert-2.jpg") center/cover no-repeat;
    border: 1px solid rgba(0,0,0,.25);
  }

  /* ============= TAKELAZH (top: 7534, h 472) ============= */
  .takelazh {
    position: relative;
    left: 250px;
    width: 1420px;
    margin-top: 80px;
    height: 500px;
  }
  .takelazh h2 {
    position: absolute;
    left: 0; top: 0;
    width: auto;
  }
  .takelazh .desc {
    position: absolute;
    left: 0; top: 100px;
    width: 700px;
    font-family: 'Open Sans', sans-serif;
    font-size: 18px;
    line-height: 1.5;
  }
  .takelazh .desc p { margin: 0 0 14px 0; }
  .takelazh .photo {
    position: absolute;
    left: 720px; top: 100px;
    width: 700px; height: 382px;
    background: url("../images/takelazh-photo.jpg") center/cover no-repeat;
    border-radius: 20px;
  }
  .takelazh .cta {
    position: absolute;
    left: 0; top: 380px;
    width: 262px; height: 65px;
    background: #ffdd2d;
    border-radius: 16px;
  }

  /* ============= FAQ (top: 8156, h auto) ============= */
  .faq {
    position: relative;
    left: 250px;
    width: 1420px;
    margin-top: 80px;
    padding-bottom: 40px;
    display: grid;
    grid-template-columns: 820px 580px;
    column-gap: 20px;
    row-gap: 40px;
  }
  .faq h2 {
    grid-column: 1 / -1;
    width: auto;
  }
  .faq-list {
    grid-column: 1;
    width: 820px;
    display: flex;
    flex-direction: column;
    gap: 20px;
  }
  .faq-item {
    width: 820px;
    border-radius: 10px;
    background: #fff;
    box-shadow: 0 3px 15px rgba(0,0,0,.1);
    overflow: hidden;
  }
  .faq-q {
    width: 100%;
    text-align: left;
    padding: 18px 24px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-family: 'Open Sans', sans-serif;
    font-weight: 700;
    font-size: 18px;
    line-height: 1.3;
    background: #fff;
    cursor: pointer;
    color: #000;
  }
  .faq-q .chev {
    flex: 0 0 20px;
    width: 20px; height: 20px;
    transition: transform .2s;
  }
  .faq-item.open .faq-q .chev { transform: rotate(180deg); }
  .faq-a { max-height: 0; overflow: hidden; transition: max-height .25s; }
  .faq-item.open .faq-a { max-height: 400px; }
  .faq-a-inner { padding: 0 24px 22px; font-size: 18px; line-height: 1.5; color: #333; }

  .faq-cta {
    grid-column: 2;
    align-self: start;
    position: relative;
    width: 580px; height: 570px;
    border-radius: 20px;
    overflow: hidden;
    background:
      linear-gradient(rgba(0,0,0,.45), rgba(0,0,0,.35)),
      url("../images/takelazh-photo.jpg") center/cover no-repeat;
    box-shadow: 0 3px 15px rgba(0,0,0,.1);
  }
  .faq-cta h4 {
    position: absolute;
    left: 42px; top: 40px;
    width: 497px;
    font-family: 'Open Sans', sans-serif;
    font-weight: 700; font-size: 30px;
    line-height: 1.4;
    color: #fff;
  }
  .faq-cta p {
    position: absolute;
    left: 62px; top: 102px;
    width: 456px;
    font-family: 'Open Sans', sans-serif;
    font-size: 24px;
    line-height: 1.4;
    color: #fff;
  }
  .faq-cta .form {
    position: absolute;
    left: 40px; top: 176px;
    width: 500px;
    display: flex;
    flex-direction: column;
    gap: 20px;
  }
  .faq-cta input {
    width: 500px;
    height: 65px;
    border-radius: 10px;
    border: none;
    padding: 20px;
    font-family: 'Open Sans', sans-serif;
    font-size: 18px;
    background: #fff;
    color: #000;
  }
  .faq-cta .btn {
    position: absolute;
    left: 40px; top: 410px;
    width: 212px; height: 65px;
    border-radius: 10px;
    background: #ffdd2d;
  }

  /* ============= PARTNERS (top: 8906) ============= */
  .partners {
    position: relative;
    width: 1920px;
    margin-top: 80px;
    height: 220px;
    text-align: center;
    padding-top: 80px;
  }
  .partners h2 {
    width: 1920px; height: 60px;
    text-align: center;
    margin-bottom: 0;
  }
  .partners .row {
    margin-top: 20px;
    width: 1920px;
    height: 98px;
    display: flex;
    flex-direction: row;
    gap: 60px;
    justify-content: center;
    align-items: center;
  }
  .partner {
    width: 200px; height: 80px;
    border-radius: 0;
    background: transparent;
    border: none;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #222;
    font-weight: 700;
    font-size: 14px;
  }

  /* ============= FOOTER (top: 9244, h 443) ============= */
  .footer {
    position: relative;
    width: 1920px;
    margin-top: 80px;
    /*height: 443px;*/
    height: 580px;
    border-top: 1px solid #aaa;
  }
  .footer .logo-img {
    position: absolute;
    left: 250px; 
	top: 50px;
    width: 222px; 
	height: 88px;
  }
  .footer .addr {
    position: absolute;
    left: 250px; top: 173px;
    width: 347px; height: 40px;
    display: flex;
    align-items: center;
    gap: 10px;
    font-family: 'Open Sans', sans-serif;
    font-size: 18px;
  }
  .footer .privacy {
    position: absolute;
    left: 250px; top: 273px;
    width: 220px; height: 19px;
    opacity: .5;
    font-size: 14px;
  }
  .footer .agreement {
    position: absolute;
    left: 250px; top: 312px;
    width: 317px; height: 19px;
    opacity: .5;
    font-size: 14px;
  }
  .footer .services-col {
    position: absolute;
    left: 730px; top: 50px;
    width: 420px; height: 317px;
  }
  .footer .services-col h5 {
    font-family: 'Open Sans', sans-serif;
    font-weight: 700; font-size: 20px;
    line-height: 1; color: #000;
    margin-bottom: 20px;
  }
  .footer .services-col ul {
    list-style: none; padding: 0; margin: 0;
    display: flex; flex-direction: column; gap: 10px;
  }
  .footer .services-col a {
    font-family: 'Open Sans', sans-serif;
    font-size: 18px; line-height: 1; color: #000;
  }
  .footer .services-col a:hover { color: #f1b910; }
  .footer .right-col {
    position: absolute;
    left: 1250px; top: 50px;
    width: 420px; height: 317px;
    text-align: right;
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 16px;
  }
  .footer .right-col .phone {
    font-family: 'Open Sans', sans-serif;
    font-weight: 700; font-size: 30px;
    line-height: 1;
  }
  .footer .right-col .email,
  .footer .right-col .hours {
    font-size: 18px;
    line-height: 1;
  }

  /* ============= CATALOG PAGE ============= */
  .hero2 {
    position: relative;
    width: 1920px;
    height: 592px;
    background:
      linear-gradient(#fff 0%, rgba(255,255,255,0) 58%),
      url("../images/catalog-hero-bg.jpg") center/cover no-repeat;
  }
  .hero2 h1 {
    position: absolute;
    left: 160px; top: 60px;
    width: 1600px;
    font-family: 'Bebas Neue', sans-serif;
    font-size: 90px;
    line-height: 1;
    letter-spacing: 0.03em;
    text-align: center;
    text-transform: uppercase;
  }
  .catalog-section {
    position: relative;
    width: 1920px;
    margin-top: 80px;
  }
  .catalog-title {
    position: relative;
    left: 0; top: 0;
    transform: none;
    width: 100%;
    text-align: center;
    margin-bottom: 40px;
  }
  .catalog-tabs {
    position: relative;
    margin: 0 auto;
    width: auto;
    max-width: 1420px;
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: center;
    gap: 12px;
  }
  .catalog-tab {
    height: 59px;
    padding: 17px 24px;
    border-radius: 100px;
    background: #fff;
    border: 1px solid #eee;
    font-family: 'Open Sans', sans-serif;
    font-size: 18px;
    line-height: 1.4;
    color: #000;
    cursor: pointer;
    transition: background .15s;
  }
  .catalog-tab:hover { background: #fafafa; }
  .catalog-tab.active { background: #ffdd2d; border-color: transparent; }

  .catalog-grid {
    position: relative;
    margin: 80px auto 0;
    width: 1420px;
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    gap: 20px;
  }
  .catalog-card {
    width: 460px;
    border-radius: 20px;
    overflow: hidden;
    border: 1px solid rgba(0,0,0,.2);
    background: #fff;
    display: flex;
    flex-direction: column;
    padding-bottom: 20px;
    transition: transform .2s, box-shadow .2s;
  }
  .catalog-card:hover { transform: translateY(-4px); box-shadow: 0 12px 30px rgba(0,0,0,.08); }
  .catalog-card .img {
    width: 460px;
    height: 350px;
    border-radius: 20px;
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
    background-color: #eee;
  }
  .catalog-card .body {
    margin-top: 20px;
    padding: 0 20px;
    display: flex;
    flex-direction: column;
    gap: 20px;
    flex: 1;
  }
  .catalog-card h3 {
    font-family: 'Open Sans', sans-serif;
    font-weight: 700; font-size: 24px;
    line-height: 1.2;
  }
  .catalog-card .desc {
    font-family: 'Open Sans', sans-serif;
    font-size: 18px; line-height: 1.2;
  }
  .catalog-card .specs { display: flex; flex-direction: column; gap: 10px; }
  .catalog-foot {
    margin-top: auto;
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
  .catalog-price {
    font-family: 'Open Sans', sans-serif;
    font-weight: 700; font-size: 24px;
    white-space: nowrap;
  }

  .adv2 {
    position: relative;
    left: 250px;
    width: 1420px;
    margin-top: 80px;
  }
  .adv2 h2 {
    width: 1420px;
    margin-bottom: 40px;
  }
  .adv2 .grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 20px;
  }
  .adv2-card {
    border-radius: 20px;
    border: 1px solid #f1b910;
    background: rgba(241,185,16,.1);
    padding: 20px;
    min-height: 168px;
    display: flex;
    flex-direction: column;
    gap: 20px;
  }
  .adv2-card h4 {
    font-family: 'Open Sans', sans-serif;
    font-weight: 700; font-size: 22px;
    line-height: 1.2;
  }
  .adv2-card p {
    font-family: 'Open Sans', sans-serif;
    font-size: 18px;
    line-height: 1.2;
  }

  .projects {
    position: relative;
    left: 250px;
    width: 1420px;
    margin-top: 80px;
  }
  .projects h2 {
    width: 1420px; height: 50px;
    text-align: center;
    margin-bottom: 40px;
  }
  .projects-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
  }
  .project-card {
    border-radius: 20px;
    overflow: hidden;
    border: 1px solid #eee;
    background: #fafafa;
    display: flex;
    flex-direction: column;
    transition: transform .2s, box-shadow .2s;
  }
  .project-card:hover { transform: translateY(-4px); box-shadow: 0 12px 30px rgba(0,0,0,.08); }
  .project-card .img {
    width: 100%;
    aspect-ratio: 460/300;
    background-color: #ddd;
    background-size: cover;
    background-position: center;
  }
  .project-card .body {
    padding: 24px;
    display: flex;
    flex-direction: column;
    gap: 12px;
  }
  .project-card h4 {
    font-family: 'Open Sans', sans-serif;
    font-weight: 700; font-size: 24px;
  }
  .project-card p {
    font-family: 'Open Sans', sans-serif;
    font-size: 16px; line-height: 1.4;
    opacity: .8;
  }

  /* placeholder */
  .ph {
    background: repeating-linear-gradient(45deg, #ececec 0 12px, #f6f6f6 12px 24px);
    color: #888;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: 'Courier New', monospace;
    font-size: 13px;
  }

  /* page toggle */
  .page { display: none; }
  .page.active { display: block; }

  /* ===== BLOG ===== */
  .blog-hero {
    position: relative;
    width: 1920px;
    height: 260px;
    background-color: #f1b910;
    background-image: linear-gradient(135deg, #ffdd2d 0%, #f1b910 100%);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: 0 40px;
  }
  .blog-hero h1 {
    font-family: 'Bebas Neue', sans-serif;
    font-size: 64px;
    color: #000;
    letter-spacing: .04em;
    line-height: 1;
    margin-bottom: 14px;
  }
  .blog-hero p {
    font-size: 20px;
    color: rgba(0,0,0,.6);
    max-width: 720px;
  }
  .blog-section {
    position: relative;
    left: 250px;
    width: 1420px;
    margin-top: 70px;
    padding-bottom: 100px;
  }
  .blog-grid {
    display: grid;
    grid-template-columns: repeat(3, 460px);
    gap: 20px;
    margin-top: 50px;
  }
  .blog-card {
    background: #fff;
    border-radius: 20px;
    border: 1.5px solid #e8e8e8;
    overflow: hidden;
    cursor: pointer;
    transition: transform .2s, box-shadow .2s;
    text-decoration: none;
    color: inherit;
    display: flex;
    flex-direction: column;
  }
  .blog-card:hover { transform: translateY(-6px); box-shadow: 0 12px 40px rgba(0,0,0,.1); }
  .blog-card__body { padding: 28px 28px 20px; flex: 1; }
  .blog-card__cat {
    font-size: 12px;
    font-weight: 700;
    letter-spacing: .15em;
    text-transform: uppercase;
    color: #f1b910;
    margin-bottom: 10px;
  }
  .blog-card__title {
    font-family: 'Open Sans', sans-serif;
    font-size: 20px;
    font-weight: 700;
    line-height: 1.3;
    color: #1a2940;
    margin-bottom: 12px;
  }
  .blog-card__excerpt { font-size: 15px; color: #555; line-height: 1.6; }
  .blog-card__foot {
    padding: 16px 28px;
    border-top: 1.5px solid #f0f0f0;
    display: flex;
    align-items: center;
    justify-content: space-between;
  }
  .blog-card__read { font-size: 13px; font-weight: 700; color: #c9960a; }
  .blog-card__date { font-size: 12px; color: #aaa; }

  /* Article full */
  .blog-article {
    position: relative;
    left: 250px;
    /*width: 900px;*/
    width: 1200px;
    margin-top: 50px;
    padding-bottom: 100px;
  }
  .blog-article__back {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 15px;
    color: #888;
    margin-bottom: 28px;
    text-decoration: none;
    font-family: 'Open Sans', sans-serif;
  }
  .blog-article__back:hover { color: #1a2940; }
  .blog-article__cat {
    font-size: 12px;
    font-weight: 700;
    letter-spacing: .15em;
    text-transform: uppercase;
    color: #f1b910;
    margin-bottom: 14px;
  }
  .blog-article h1 {
    font-family: 'Bebas Neue', sans-serif;
    font-size: 56px;
    line-height: 1.08;
    letter-spacing: .02em;
    color: #1a2940;
    margin-bottom: 18px;
  }
  .blog-article__meta {
    font-size: 14px;
    color: #999;
    margin-bottom: 40px;
    display: flex;
    gap: 20px;
    font-family: 'Open Sans', sans-serif;
    border-bottom: 1px solid #eee;
    padding-bottom: 20px;
  }
  .blog-article h2 {
    font-family: 'Open Sans', sans-serif;
    font-size: 24px;
    font-weight: 700;
    margin: 36px 0 12px;
    color: #1a2940;
  }
  .blog-article p {
    font-family: 'Open Sans', sans-serif;
    font-size: 18px;
    line-height: 1.75;
    color: #333;
    margin-bottom: 16px;
  }
  .blog-article ul { margin: 0 0 16px 24px; }
  .blog-article ul li {
    font-family: 'Open Sans', sans-serif;
    font-size: 18px;
    line-height: 1.75;
    color: #333;
    margin-bottom: 8px;
  }
  .blog-article .highlight {
    background: #fff8e1;
    border-left: 4px solid #f1b910;
    padding: 18px 24px;
    border-radius: 0 12px 12px 0;
    margin: 28px 0;
    font-size: 17px;
    line-height: 1.65;
    color: #444;
    font-family: 'Open Sans', sans-serif;
  }
  .blog-article .art-cta {
    background: #1a2940;
    color: #fff;
    border-radius: 20px;
    padding: 44px 48px;
    margin: 44px 0;
    text-align: center;
  }
  .blog-article .art-cta h3 {
    font-family: 'Bebas Neue', sans-serif;
    font-size: 40px;
    margin-bottom: 12px;
    letter-spacing: .03em;
    color: #fff;
  }
  .blog-article .art-cta p {
    color: rgba(255,255,255,.7);
    margin-bottom: 24px;
    font-size: 17px;
  }
  .blog-article .art-cta a {
    display: inline-block;
    background: #f1b910;
    color: #1a2940;
    font-weight: 700;
    padding: 18px 40px;
    border-radius: 12px;
    font-size: 19px;
    text-decoration: none;
    font-family: 'Open Sans', sans-serif;
  }
  .blog-article .art-cta a:hover { background: #ffdd2d; }
  .blog-article__footer { margin-top: 48px; padding-top: 28px; border-top: 1px solid #eee; }

  /* responsive scaling: scale 1920 canvas down on smaller screens */
  @media (max-width: 1920px) {
    .canvas { transform: scale(calc(100vw / 1920)); width: 1920px; }
    body { overflow-x: hidden; }
    .canvas-wrap { width: 100vw; overflow: hidden; }
  }

/* ===== MOBILE ADAPTIVE (≤ 767px) ===== */
@media (max-width: 767px) {

  /* ══ Canvas: отключаем transform-масштабирование ══ */
  .canvas-wrap { width: 100% !important; overflow-x: hidden !important; overflow-y: visible !important; }
  .canvas      { width: 100% !important; transform: none !important; min-width: 0 !important; overflow: visible !important; }

  /* ══ HEADER ══ */
  .header {
    width: 100% !important; height: 60px !important;
    padding: 0 16px !important;
    display: flex !important; align-items: center !important;
    justify-content: space-between !important;
    box-shadow: 0 2px 6px rgba(0,0,0,.07);
    position: relative !important;
  }
  .header .logo {
    position: static !important; left: auto !important; top: auto !important;
    width: 108px !important; height: 42px !important; object-fit: contain;
  }
  .header .nav       { display: none !important; }
  .header .phone-btn { display: none !important; }  /* телефон — внутри мобильного меню */

  /* ══ HERO — тёмный overlay поверх фото ══ */
  .hero {
    position: relative !important;
    width: 100% !important; height: auto !important; min-height: 0 !important;
    display: flex !important; flex-direction: column !important;
    align-items: center !important; justify-content: center !important;
    padding: 44px 20px 40px !important;
    background-image:
      linear-gradient(rgba(10,25,50,.78) 0%, rgba(15,35,65,.72) 100%),
      url('../images/hero-bg.jpg') !important;
    background-size: cover !important;
    background-position: center !important;
  }
  .hero h1 {
    position: static !important; left: auto !important; top: auto !important;
    width: 100% !important; font-size: 28px !important; line-height: 1.25 !important;
    text-align: center !important; color: #fff !important; margin-bottom: 28px !important;
  }
  .hero-cta {
    position: static !important; left: auto !important; top: auto !important;
    width: 100% !important; height: auto !important;
    display: flex !important; flex-direction: column !important;
    align-items: stretch !important; gap: 12px !important;
  }
  .hero-cta .btn {
    width: 100% !important; height: 50px !important;
    display: flex !important; justify-content: center !important; align-items: center !important;
    font-size: 15px !important;
  }
  .hero-cta .btn-ghost {
    background: rgba(255,255,255,.15) !important;
    color: #fff !important;
    border: 1.5px solid rgba(255,255,255,.45) !important;
  }

  /* ══ Заголовки секций ══ */
  .section-title {
    font-size: 26px !important; line-height: 1.2 !important;
    white-space: normal !important; max-width: 100% !important;
  }

  /* ══ ABOUT ══ */
  .about {
    position: static !important; left: auto !important;
    width: 100% !important; height: auto !important;
    padding: 0 16px !important; margin-top: 36px !important;
  }
  .about h2    { position: static !important; height: auto !important; margin-bottom: 14px !important; }
  .about .desc {
    position: static !important; left: auto !important; top: auto !important;
    width: 100% !important; height: auto !important;
    font-size: 15px !important; line-height: 1.65 !important;
  }
  .about .desc p { margin-bottom: 10px; }
  .about .photo  {
    position: static !important; left: auto !important; top: auto !important;
    width: 100% !important; height: 200px !important; margin-top: 20px !important;
  }
  .pros {
    position: static !important; left: auto !important; top: auto !important;
    width: 100% !important; height: auto !important; margin-top: 20px !important;
    display: grid !important; grid-template-columns: 1fr 1fr !important; gap: 12px !important;
  }
  .pro        { position: static !important; width: 100% !important; height: auto !important; gap: 10px !important; }
  .pro-text   { width: auto !important; height: auto !important; font-size: 13px !important; }
  .pro-icon   { width: 36px !important; height: 36px !important; flex: 0 0 36px !important; }
  .pro-icon img { width: 36px !important; height: 36px !important; }

  /* ══ QUIZ / CALC ══ */
  .calc { width: 100% !important; padding: 0 16px !important; margin-top: 36px !important; }
  .quiz { padding: 20px 16px !important; border-radius: 14px !important; }
  .quiz-question       { font-size: 17px !important; }
  .quiz-options        { grid-template-columns: 1fr !important; }
  .quiz-opt            { height: auto !important; min-height: 50px; padding: 12px 14px; font-size: 15px !important; }
  .quiz-input          { height: 52px !important; font-size: 15px !important; }
  .quiz-bottom         { flex-direction: column !important; align-items: stretch; gap: 14px; }
  .quiz-progress-wrap  { max-width: 100% !important; }
  .quiz-nav            { align-items: stretch; }
  .quiz-nav-row        { justify-content: space-between; }
  .quiz-next           { justify-content: center; font-size: 15px !important; }

  /* ══ SERVICES ══ */
  .services {
    position: static !important; left: auto !important;
    width: 100% !important; height: auto !important;
    padding: 0 16px !important; margin-top: 36px !important;
  }
  .services h2 { position: static !important; height: auto !important; margin-bottom: 18px !important; }
  .service-card {
    position: static !important; left: auto !important; top: auto !important;
    width: 100% !important; margin-bottom: 16px !important;
  }
  .service-card .img { width: 100% !important; height: 175px !important; border-radius: 16px !important; }
  .service-card h4   { width: 100% !important; font-size: 16px !important; margin-top: 10px !important; }

  /* ══ ADVANTAGES (блоки) ══ */
  .advantages {
    position: static !important; left: auto !important;
    width: 100% !important; height: auto !important;
    padding: 0 16px !important; margin-top: 36px !important;
  }
  .advantages h2      { position: static !important; max-width: 100% !important; margin-bottom: 18px !important; }
  .advantages .grid   {
    position: static !important; left: auto !important; top: auto !important;
    width: 100% !important; height: auto !important;
    display: flex !important; flex-direction: column !important; gap: 14px !important;
  }
  .adv-card {
    position: static !important; left: auto !important; top: auto !important;
    width: 100% !important; height: auto !important;
    padding: 20px 16px !important;
  }
  .adv-card h4 { font-size: 17px !important; }
  .adv-card p  { font-size: 14px !important; }
  .adv-img     {
    position: static !important; left: auto !important; top: auto !important;
    width: 100% !important; height: 160px !important;
    border-radius: 14px !important; background-size: cover !important;
  }

  /* ══ PRICES ══ */
  .prices {
    position: static !important; left: auto !important;
    width: 100% !important; height: auto !important;
    padding: 0 16px !important; margin-top: 36px !important;
  }
  .prices h2  { position: static !important; height: auto !important; margin-bottom: 18px !important; }
  .price-grid {
    position: static !important; left: auto !important; top: auto !important;
    width: 100% !important; height: auto !important;
    flex-direction: column !important; gap: 18px !important;
  }
  .price-card        { width: 100% !important; height: auto !important; }
  .price-card .img   { width: 100% !important; height: 150px !important; border-radius: 12px !important; }
  .price-card .body  { width: 100% !important; height: auto !important; padding: 0 !important; }
  .price-card h4     { font-size: 17px !important; }
  .spec-row          { font-size: 13px !important; }
  .price-num         { font-size: 17px !important; }
  .btn-outline       { font-size: 13px !important; height: auto !important; padding: 10px 12px !important; width: auto !important; }
  .promo-card {
    width: 100% !important; height: auto !important;
    padding: 20px 16px !important;
    display: flex !important; flex-direction: column !important; gap: 14px !important;
  }
  .promo-stat        { position: static !important; width: 100% !important; height: auto !important; }
  .promo-stat .num   { font-size: 44px !important; }
  .promo-stat .lbl   { font-size: 15px !important; }
  .promo-list        { position: static !important; width: 100% !important; }
  .promo-list li     { font-size: 13px !important; }
  .promo-call        { position: static !important; width: 100% !important; text-align: left !important; }
  .promo-call .small { font-size: 13px !important; }
  .promo-call .num   { font-size: 20px !important; margin-top: 6px !important; }

  /* ══ PRODUCER ══ */
  .producer {
    position: static !important; left: auto !important;
    width: 100% !important; height: auto !important;
    padding: 0 16px !important; margin-top: 36px !important;
  }
  .producer h2       { position: static !important; white-space: normal !important; max-width: 100% !important; margin-bottom: 14px !important; }
  .producer .desc    {
    position: static !important; left: auto !important; top: auto !important;
    width: 100% !important; height: auto !important; font-size: 15px !important;
  }
  .producer .desc p  { margin-bottom: 10px; }
  .producer .photo   {
    position: static !important; left: auto !important; top: auto !important;
    width: 100% !important; height: 190px !important; margin-top: 16px !important;
  }
  .producer .cta     {
    position: static !important; left: auto !important; top: auto !important;
    width: 100% !important; height: auto !important;
    padding: 14px 20px !important; margin-top: 16px !important;
    display: flex !important; align-items: center !important; justify-content: center !important;
    font-size: 14px !important;
  }

  /* ══ CERT ══ */
  .cert {
    position: static !important; left: auto !important;
    width: 100% !important; height: auto !important;
    padding: 0 16px !important; margin-top: 36px !important;
  }
  .cert h2         { position: static !important; margin-bottom: 14px !important; }
  .cert .desc      {
    position: static !important; left: auto !important; top: auto !important;
    width: 100% !important; font-size: 15px !important;
  }
  .cert .desc p    { margin-bottom: 12px; }
  .cert .img1, .cert .img2 {
    position: static !important; left: auto !important; top: auto !important;
    width: 100% !important; height: 420px !important; margin-top: 14px !important;
    background-size: contain !important;
    background-color: #f5f5f5 !important;
  }

  /* ══ TAKELAZH ══ */
  .takelazh {
    position: static !important; left: auto !important;
    width: 100% !important; height: auto !important;
    padding: 0 16px !important; margin-top: 36px !important;
  }
  .takelazh h2       { position: static !important; white-space: normal !important; font-size: 26px !important; margin-bottom: 14px !important; }
  .takelazh .desc    {
    position: static !important; left: auto !important; top: auto !important;
    width: 100% !important; font-size: 15px !important;
  }
  .takelazh .desc p  { margin-bottom: 10px; }
  .takelazh .photo   {
    position: static !important; left: auto !important; top: auto !important;
    width: 100% !important; height: 190px !important; margin-top: 14px !important;
  }
  .takelazh .cta     {
    position: static !important; left: auto !important; top: auto !important;
    width: 100% !important; height: auto !important;
    padding: 14px 20px !important; margin-top: 16px !important;
    display: flex !important; align-items: center !important; justify-content: center !important;
    font-size: 14px !important;
  }

  /* ══ FAQ ══ */
  .faq {
    position: static !important; left: auto !important;
    width: 100% !important; height: auto !important;
    padding: 0 16px 36px !important; margin-top: 36px !important;
    display: block !important; /* убираем grid */
  }
  .faq h2            { margin-bottom: 16px !important; }
  .faq-list          { width: 100% !important; display: block; }
  .faq-item          { width: 100% !important; margin-bottom: 8px; }
  .faq-item.open .faq-a { max-height: 700px !important; }
  .faq-q             { font-size: 14px !important; padding: 12px 14px !important; }
  .faq-a-inner       { font-size: 14px !important; padding: 0 14px 16px !important; }
  .faq-cta           {
    width: 100% !important; height: auto !important;
    overflow: visible !important;
    padding: 22px 18px !important; margin-top: 24px;
    border-radius: 16px !important;
  }
  .faq-cta h4        {
    position: static !important; left: auto !important; top: auto !important;
    width: 100% !important; font-size: 18px !important; margin-bottom: 8px !important;
  }
  .faq-cta p         {
    position: static !important; left: auto !important; top: auto !important;
    width: 100% !important; font-size: 15px !important; margin-bottom: 14px !important;
  }
  .faq-cta .form     {
    position: static !important; left: auto !important; top: auto !important;
    width: 100% !important; gap: 12px !important;
  }
  .faq-cta input[type="text"],
  .faq-cta input[type="tel"]  { width: 100% !important; height: 50px !important; font-size: 15px !important; }
  .faq-cta input[type="checkbox"] {
    width: 16px !important; height: 16px !important;
    flex-shrink: 0 !important; margin-top: 2px !important;
    accent-color: #ffdd2d;
  }
  .faq-cta .btn      {
    position: static !important; left: auto !important; top: auto !important;
    width: 100% !important; height: 50px !important; margin-top: 0 !important;
    font-size: 14px !important;
  }

  /* ══ PARTNERS ══ */
  .partners          { width: 100% !important; height: auto !important; padding: 28px 16px !important; margin-top: 0 !important; }
  .partners h2       { width: 100% !important; height: auto !important; font-size: 26px !important; margin-bottom: 14px !important; }
  .partners .row     {
    width: 100% !important; height: auto !important; margin-top: 14px !important;
    flex-wrap: wrap !important; gap: 14px 36px !important; justify-content: center;
  }
  .partner           { width: 120px !important; height: 50px !important; font-size: 12px !important; }

  /* ══ FOOTER ══ */
  .footer {
    width: 100% !important; height: auto !important;
    padding: 24px 16px !important; margin-top: 36px !important;
    display: flex !important; flex-direction: column !important; gap: 14px !important;
  }
  .footer .logo-img  {
    position: static !important; left: auto !important; top: auto !important;
    width: 130px !important; height: 52px !important; object-fit: contain;
  }
  .footer .addr      {
    position: static !important; left: auto !important; top: auto !important;
    width: 100% !important; height: auto !important; font-size: 14px !important;
  }
  .footer .addr svg  { width: 28px !important; height: 28px !important; flex-shrink: 0; }
  .footer .privacy   {
    position: static !important; left: auto !important; top: auto !important;
    width: auto !important; height: auto !important; font-size: 12px !important;
  }
  .footer .agreement {
    position: static !important; left: auto !important; top: auto !important;
    width: auto !important; height: auto !important; font-size: 12px !important;
  }
  .footer .services-col {
    position: static !important; left: auto !important; top: auto !important;
    width: 100% !important; height: auto !important;
  }
  .footer .services-col h5 { font-size: 16px !important; margin-bottom: 10px !important; }
  .footer .services-col a  { font-size: 14px !important; }
  .footer .right-col {
    position: static !important; left: auto !important; top: auto !important;
    width: 100% !important; height: auto !important;
    text-align: left !important; align-items: flex-start !important; gap: 8px !important;
  }
  .footer .right-col .phone { font-size: 20px !important; }
  .footer .right-col .email,
  .footer .right-col .hours { font-size: 14px !important; }

  /* ══ CATALOG HERO ══ */
  .hero2 {
    width: 100% !important; height: auto !important; min-height: 200px;
    display: flex !important; align-items: center !important; justify-content: center !important;
    padding: 32px 16px !important;
  }
  .hero2 h1 {
    position: static !important; left: auto !important; top: auto !important;
    width: 100% !important; font-size: 30px !important; text-align: center !important;
  }
  .catalog-section   { width: 100% !important; margin-top: 32px !important; }
  .catalog-title     { font-size: 24px !important; padding: 0 16px; }
  .catalog-tabs      { padding: 0 16px !important; gap: 8px !important; flex-wrap: wrap; }
  .catalog-tab       { font-size: 13px !important; padding: 9px 12px !important; height: auto !important; }
  .catalog-grid      { width: 100% !important; padding: 0 16px !important; margin-top: 24px !important; gap: 14px !important; }
  .catalog-card      { width: 100% !important; }
  .catalog-card .img { width: 100% !important; height: 200px !important; }
  .catalog-card h3   { font-size: 18px !important; }
  .catalog-card .desc{ font-size: 14px !important; }
  .catalog-price     { font-size: 18px !important; }
  .adv2              { position: static !important; left: auto !important; width: 100% !important; padding: 0 16px !important; margin-top: 32px !important; }
  .adv2 h2           { width: 100% !important; font-size: 24px !important; margin-bottom: 18px !important; }
  .adv2 .grid        { grid-template-columns: 1fr !important; }
  .adv2-card h4      { font-size: 16px !important; }
  .adv2-card p       { font-size: 14px !important; }
  .projects          { position: static !important; left: auto !important; width: 100% !important; padding: 0 16px !important; margin-top: 32px !important; }
  .projects h2       { width: 100% !important; height: auto !important; font-size: 24px !important; }
  .projects-grid     { grid-template-columns: 1fr !important; }
  .project-card h4   { font-size: 18px !important; }
  .project-card p    { font-size: 14px !important; }

  /* ══ BLOG / ARTICLE ══ */
  .blog-hero         { width: 100% !important; height: auto !important; padding: 28px 16px !important; }
  .blog-hero h1      { font-size: 28px !important; }
  .blog-section      { position: static !important; left: auto !important; width: 100% !important; padding: 0 16px 50px !important; margin-top: 32px !important; }
  .blog-grid         { grid-template-columns: 1fr !important; }
  .blog-card__title  { font-size: 17px !important; }
  .blog-article      { position: static !important; left: auto !important; width: 100% !important; padding: 0 16px 50px !important; margin-top: 24px !important; }
  .blog-article h1   { font-size: 26px !important; }
  .blog-article h2   { font-size: 20px !important; }
  .blog-article p, .blog-article ul li { font-size: 15px !important; }
  .blog-article .art-cta           { padding: 22px 18px !important; }
  .blog-article .art-cta h3        { font-size: 24px !important; }
  .blog-article .art-cta a         { padding: 12px 18px !important; font-size: 14px !important; }

  /* ══ Кнопки общие ══ */
  .btn { font-size: 14px !important; }

}

/* ===== BURGER & MOBILE NAV ===== */
.burger {
  display: none;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 5px;
  width: 40px; height: 40px;
  background: none;
  border: none;
  cursor: pointer;
  padding: 4px;
  border-radius: 8px;
  flex-shrink: 0;
}
.burger span {
  display: block;
  width: 22px; height: 2px;
  background: #1a2940;
  border-radius: 2px;
  transition: transform .22s, opacity .22s;
}
.burger.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.burger.open span:nth-child(2) { opacity: 0; }
.burger.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

.mobile-nav {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 9999;
  background: rgba(15, 28, 50, .97);
  flex-direction: column;
  align-items: stretch;
  justify-content: flex-start;
  overflow-y: auto;
  opacity: 0;
  pointer-events: none;
  transition: opacity .22s;
}
.mobile-nav.open {
  opacity: 1;
  pointer-events: auto;
}
.mobile-nav__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 28px 24px 40px;
  min-height: 100%;
}
.mobile-nav__logo {
  width: 130px;
  margin-bottom: 36px;
  filter: brightness(0) invert(1);
}
.mobile-nav__logo img { width: 100%; height: auto; }
.mobile-nav__links {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0;
  width: 100%;
}
.mobile-nav__link {
  display: block;
  width: 100%;
  text-align: center;
  padding: 17px 0;
  font-size: 20px;
  font-weight: 600;
  color: #fff;
  text-decoration: none;
  border-bottom: 1px solid rgba(255,255,255,.1);
  transition: color .15s;
  font-family: 'Open Sans', sans-serif;
}
.mobile-nav__link:first-child { border-top: 1px solid rgba(255,255,255,.1); }
.mobile-nav__link:active { color: #f1b910; }
.mobile-nav__phone {
  display: inline-block;
  margin-top: 36px;
  font-size: 22px;
  font-weight: 700;
  color: #f1b910;
  text-decoration: none;
  letter-spacing: .02em;
  font-family: 'Open Sans', sans-serif;
}

@media (max-width: 767px) {
  .burger       { display: flex !important; }
  .mobile-nav   { display: flex !important; }
}

/* ===== ORDER MODAL ===== */
#modal-specs-table td { padding: 6px 8px; border-bottom: 1px solid #f0f0f0; font-size:14px; }
#modal-specs-table td:first-child { color:#666; width:55%; }
#modal-specs-table td:last-child { font-weight:600; }
#modal-name:focus, #modal-phone:focus, #modal-comment:focus { border-color:#f1b910; outline:none; }
#modal-comment { display:block; width:100%; margin-bottom:20px; padding:14px 16px; border:1.5px solid #ddd; border-radius:10px; font-size:15px; font-family:inherit; resize:vertical; min-height:90px; box-sizing:border-box; }
