/*!**************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[13].oneOf[7].use[2]!./node_modules/next/dist/build/webpack/loaders/postcss-loader/src/index.js??ruleSet[1].rules[13].oneOf[7].use[3]!./components/layout/footer/footer.module.css ***!
  \**************************************************************************************************************************************************************************************************************************************************************************************/
.footer_footer__bIxLQ {
    background-color: var(--primary-color);
    color: rgba(253, 251, 247, 0.8);
    padding: calc(var(--spacing-unit) * 4) 0 calc(var(--spacing-unit) * 2);
    font-size: 0.9rem;
    font-family: var(--main-font);
}

.footer_footerContainer__vn7es {
    text-align: left;
}

.footer_footerGrid__JIRoT {
    display: grid;
    grid-template-columns: 1fr;
    grid-gap: calc(var(--spacing-unit) * 2.5);
    gap: calc(var(--spacing-unit) * 2.5);
    margin-bottom: calc(var(--spacing-unit) * 3);
}

.footer_footerColumn__ZJXp8 h4 {
    color: var(--secondary-color);
    font-size: 1.1rem;
    margin-bottom: var(--spacing-unit);
    font-family: var(--heading-font);
    font-weight: bold;
}

.footer_footerColumn__ZJXp8 p,
.footer_footerColumn__ZJXp8 address {
    margin-bottom: calc(var(--spacing-unit) * 0.5);
    line-height: 1.6;
    font-style: normal;
}

.footer_footerColumn__ZJXp8 a {
    color: rgba(253, 251, 247, 0.8);
    text-decoration: underline;
    -webkit-text-decoration-color: rgba(253, 251, 247, 0.4);
            text-decoration-color: rgba(253, 251, 247, 0.4);
    font-weight: normal;
    transition: color 0.2s ease, -webkit-text-decoration-color 0.2s ease;
    transition: color 0.2s ease, text-decoration-color 0.2s ease;
    transition: color 0.2s ease, text-decoration-color 0.2s ease, -webkit-text-decoration-color 0.2s ease;
}

.footer_footerColumn__ZJXp8 a:hover {
    color: var(--secondary-color);
    -webkit-text-decoration-color: var(--secondary-color);
            text-decoration-color: var(--secondary-color);
}

.footer_inn__UNaCl {
    opacity: 0.7;
    font-size: 0.8rem;
    margin-top: var(--spacing-unit);
}

.footer_copyright__5B8y2 {
    text-align: center;
    padding-top: calc(var(--spacing-unit) * 2);
    border-top: 1px solid rgba(255,255,255,0.2);
    opacity: 0.7;
    font-size: 0.8rem;
}

@media (min-width: 768px) {
    .footer_footerGrid__JIRoT {
        grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
        gap: calc(var(--spacing-unit) * 4);
    }
}

/*!**************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[13].oneOf[7].use[2]!./node_modules/next/dist/build/webpack/loaders/postcss-loader/src/index.js??ruleSet[1].rules[13].oneOf[7].use[3]!./components/layout/header/header.module.css ***!
  \**************************************************************************************************************************************************************************************************************************************************************************************/
.header_header__BPOYe {
    background-color: rgba(244, 241, 236, 0.8);
    -webkit-backdrop-filter: url(#liquid-glass-filter);
    backdrop-filter: url(#liquid-glass-filter);
    padding: calc(var(--spacing-unit) * 0.85) 0;
    border-bottom: 1px solid var(--border-color);
    position: -webkit-sticky;
    position: sticky;
    top: 0;
    z-index: 100;
    box-shadow: 0 2px 15px rgba(0,0,0,0.05);
    transition: background-color 0.35s ease, border-color 0.35s ease, box-shadow 0.35s ease;
}

.header_header__BPOYe.header_menuOpen__KHTop {
    background-color: transparent;
    box-shadow: none;
    border-color: transparent;
    -webkit-backdrop-filter: none;
    backdrop-filter: none;
}

.header_headerContent__QDFtL {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.header_logo__octdO {
    font-family: var(--heading-font);
    color: var(--text-color);
    flex-shrink: 0;
    z-index: 101;
    white-space: nowrap;
    display: flex;
    flex-direction: column;
    line-height: 1.2;
}

.header_logoName__dQDHE {
    font-size: 1.6rem;
    font-weight: bold;
}

.header_logoSubtitle__Ls9f8 {
    font-size: 0.8rem;
    font-weight: normal;
    font-family: var(--main-font);
    color: var(--text-color);
    opacity: 0.8;
}

.header_header__BPOYe.header_menuOpen__KHTop .header_logo__octdO {
    position: fixed;
    top: calc(var(--spacing-unit) * 1.25);
    left: 50%;
    transform: translateX(-50%);
    align-items: center;
}

.header_logo__octdO:hover {
    text-decoration: none;
    color: var(--primary-color);
}

/* Burger Button - Mobile Only */
.header_burgerButton__kXt1b {
    display: none;
    background: none;
    border: none;
    cursor: pointer;
    padding: 10px;
    z-index: 101;
    position: relative;
    width: 40px;
    height: 40px;
}

.header_burgerButton__kXt1b span {
    display: block;
    width: 24px;
    height: 2px;
    background-color: var(--text-color);
    margin: 5px auto;
    transition: all 0.3s ease-in-out;
    border-radius: 2px;
}

.header_burgerButton__kXt1b.header_open__Nb9di span {
    background-color: var(--text-color);
}

.header_burgerButton__kXt1b.header_open__Nb9di span:nth-child(1) {
    transform: translateY(7px) rotate(45deg);
}
.header_burgerButton__kXt1b.header_open__Nb9di span:nth-child(2) {
    opacity: 0;
}
.header_burgerButton__kXt1b.header_open__Nb9di span:nth-child(3) {
    transform: translateY(-7px) rotate(-45deg);
}

/* Desktop Navigation */
.header_desktopNav__He9ZT {
    display: flex;
    align-items: center;
    gap: calc(var(--spacing-unit) * 2);
}

.header_navigation__uzzkR {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 5px var(--spacing-unit);
}

.header_navigation__uzzkR a {
    color: var(--text-color);
    font-weight: 500;
    font-family: var(--main-font);
    position: relative;
    padding-bottom: 4px;
    letter-spacing: 0.5px;
    font-size: 0.95rem;
    white-space: nowrap;
}

.header_navigation__uzzkR a::after {
    content: '';
    position: absolute;
    width: 0;
    height: 2px;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    background-color: var(--accent-color);
    transition: width 0.3s ease;
}

.header_navigation__uzzkR a:hover::after {
    width: 100%;
}

/* Mobile Navigation Overlay */
.header_mobileNav__2uRM5 {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(244, 241, 236, 0.95);
    -webkit-backdrop-filter: url(#liquid-glass-filter) blur(8px);
    backdrop-filter: url(#liquid-glass-filter) blur(8px);
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: calc(var(--spacing-unit) * 2);
    transform: translateX(100%);
    transition: transform 0.35s cubic-bezier(0.4, 0, 0.2, 1), visibility 0.35s;
    padding: calc(var(--spacing-unit) * 8) calc(var(--spacing-unit) * 2) calc(var(--spacing-unit) * 2);
    z-index: 99;
    visibility: hidden;
    overflow-y: auto;
}

.header_mobileNav__2uRM5.header_open__Nb9di {
    transform: translateX(0);
    visibility: visible;
}

.header_headerActionPlaceholder__w4UuX {
    display: none;
}

/* Mobile Styles */
@media (max-width: 992px) {
    .header_desktopNav__He9ZT {
        display: none;
    }

    .header_burgerButton__kXt1b {
        display: block;
    }

    .header_burgerButton__kXt1b.header_open__Nb9di {
        position: fixed;
        top: calc(var(--spacing-unit) * 0.85);
        right: calc(var(--spacing-unit) * 1.5);
    }

    .header_headerActionPlaceholder__w4UuX {
        display: block;
        width: 40px; /* Same as burger button */
    }

    .header_mobileNav__2uRM5 .header_navigation__uzzkR {
        flex-direction: column;
        align-items: center;
        gap: var(--spacing-unit);
    }

    .header_mobileNav__2uRM5 .header_navigation__uzzkR a {
        font-size: 1.5rem;
    }
}

/* Desktop Styles */
@media (min-width: 993px) {
    .header_mobileNav__2uRM5 {
        display: none;
    }
}

/*!****************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[13].oneOf[7].use[2]!./node_modules/next/dist/build/webpack/loaders/postcss-loader/src/index.js??ruleSet[1].rules[13].oneOf[7].use[3]!./components/shared/cookie-banner/cookie-banner.module.css ***!
  \****************************************************************************************************************************************************************************************************************************************************************************************************/
.cookie-banner_banner__NYgel {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 1001;
    background-color: rgba(28, 28, 28, 0.95); /* Dark background */
    color: var(--light-text-color);
    padding: var(--spacing-unit);
    box-shadow: 0 -2px 10px rgba(0,0,0,0.2);
    -webkit-backdrop-filter: blur(5px);
    backdrop-filter: blur(5px);
    transform: translateY(100%);
    animation: cookie-banner_slideIn__A1Gos 0.5s forwards cubic-bezier(0.16, 1, 0.3, 1);
}

@keyframes cookie-banner_slideIn__A1Gos {
    to {
        transform: translateY(0);
    }
}

.cookie-banner_content__b8Up2 {
    max-width: var(--container-width);
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: var(--spacing-unit);
    padding: 0 calc(var(--spacing-unit) * 1.5);
}

.cookie-banner_content__b8Up2 p {
    margin: 0;
    font-size: 0.9rem;
    max-width: none;
}

.cookie-banner_content__b8Up2 a {
    color: #fff;
    text-decoration: underline;
    font-weight: normal;
}

.cookie-banner_button__5vDhS {
    background-color: var(--primary-color);
    color: var(--light-text-color);
    border: none;
    padding: calc(var(--spacing-unit) * 0.5) calc(var(--spacing-unit) * 1.5);
    border-radius: var(--border-radius);
    cursor: pointer;
    font-weight: bold;
    font-family: var(--main-font);
    transition: background-color 0.2s ease;
    flex-shrink: 0;
}

.cookie-banner_button__5vDhS:hover {
    background-color: var(--accent-color);
}

@media (max-width: 768px) {
    .cookie-banner_content__b8Up2 {
        flex-direction: column;
        text-align: center;
        gap: calc(var(--spacing-unit) * 1.5);
    }
}

/*!************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[13].oneOf[7].use[2]!./node_modules/next/dist/build/webpack/loaders/postcss-loader/src/index.js??ruleSet[1].rules[13].oneOf[7].use[3]!./components/shared/floating-contact-button/floating-contact-button.module.css ***!
  \************************************************************************************************************************************************************************************************************************************************************************************************************************/
.floating-contact-button_button__KpVzA {
    position: fixed;
    bottom: calc(var(--spacing-unit) * 1.5);
    right: calc(var(--spacing-unit) * 1.5);
    z-index: 999;
    width: 60px;
    height: 60px;
    background-color: var(--primary-color);
    color: var(--light-text-color);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 4px 15px rgba(0,0,0,0.2);
    transition: all 0.3s ease;
    border: 2px solid rgba(255, 255, 255, 0.5);
}

.floating-contact-button_button__KpVzA:hover {
    transform: scale(1.1) rotate(10deg);
    background-color: var(--accent-color);
    border-color: var(--light-text-color);
    box-shadow: 0 6px 20px rgba(0,0,0,0.25);
    text-decoration: none;
}

.floating-contact-button_icon__EVB3r {
    width: 28px;
    height: 28px;
}

@media (max-width: 768px) {
    .floating-contact-button_button__KpVzA {
        width: 50px;
        height: 50px;
        bottom: var(--spacing-unit);
        right: var(--spacing-unit);
    }

    .floating-contact-button_icon__EVB3r {
        width: 24px;
        height: 24px;
    }
}

/*!*******************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[13].oneOf[2].use[1]!./node_modules/next/dist/build/webpack/loaders/next-font-loader/index.js??ruleSet[1].rules[13].oneOf[2].use[2]!./node_modules/next/font/google/target.css?{"path":"app/fonts.ts","import":"Inter","arguments":[{"subsets":["latin","cyrillic"],"display":"swap","variable":"--main-font"}],"variableName":"inter"} ***!
  \*******************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/
/* cyrillic-ext */
@font-face {
  font-family: '__Inter_fcbcbf';
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url(/_next/static/media/ba9851c3c22cd980-s.woff2) format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: '__Inter_fcbcbf';
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url(/_next/static/media/21350d82a1f187e9-s.p.woff2) format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* greek-ext */
@font-face {
  font-family: '__Inter_fcbcbf';
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url(/_next/static/media/c5fe6dc8356a8c31-s.woff2) format('woff2');
  unicode-range: U+1F00-1FFF;
}
/* greek */
@font-face {
  font-family: '__Inter_fcbcbf';
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url(/_next/static/media/19cfc7226ec3afaa-s.woff2) format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
/* vietnamese */
@font-face {
  font-family: '__Inter_fcbcbf';
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url(/_next/static/media/df0a9ae256c0569c-s.woff2) format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: '__Inter_fcbcbf';
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url(/_next/static/media/8e9860b6e62d6359-s.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: '__Inter_fcbcbf';
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url(/_next/static/media/e4af272ccee01ff0-s.p.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;
}@font-face {font-family: '__Inter_Fallback_fcbcbf';src: local("Arial");ascent-override: 90.49%;descent-override: 22.56%;line-gap-override: 0.00%;size-adjust: 107.06%
}.__className_fcbcbf {font-family: '__Inter_fcbcbf', '__Inter_Fallback_fcbcbf';font-style: normal
}.__variable_fcbcbf {--main-font: '__Inter_fcbcbf', '__Inter_Fallback_fcbcbf'
}

/*!***********************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[13].oneOf[2].use[1]!./node_modules/next/dist/build/webpack/loaders/next-font-loader/index.js??ruleSet[1].rules[13].oneOf[2].use[2]!./node_modules/next/font/google/target.css?{"path":"app/fonts.ts","import":"Merriweather","arguments":[{"subsets":["latin","cyrillic"],"weight":["400","700"],"display":"swap","variable":"--heading-font"}],"variableName":"merriweather"} ***!
  \***********************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/
/* cyrillic-ext */
@font-face {
  font-family: '__Merriweather_d22de1';
  font-style: normal;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url(/_next/static/media/fe4c52824bfaed3e-s.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: '__Merriweather_d22de1';
  font-style: normal;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url(/_next/static/media/3e8ab5100a4aa694-s.p.woff2) format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: '__Merriweather_d22de1';
  font-style: normal;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url(/_next/static/media/b78b37b810acce9f-s.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: '__Merriweather_d22de1';
  font-style: normal;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url(/_next/static/media/027647acf05c7ff8-s.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: '__Merriweather_d22de1';
  font-style: normal;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url(/_next/static/media/1f3fe8c6df3d47c1-s.p.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: '__Merriweather_d22de1';
  font-style: normal;
  font-weight: 700;
  font-stretch: 100%;
  font-display: swap;
  src: url(/_next/static/media/fe4c52824bfaed3e-s.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: '__Merriweather_d22de1';
  font-style: normal;
  font-weight: 700;
  font-stretch: 100%;
  font-display: swap;
  src: url(/_next/static/media/3e8ab5100a4aa694-s.p.woff2) format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: '__Merriweather_d22de1';
  font-style: normal;
  font-weight: 700;
  font-stretch: 100%;
  font-display: swap;
  src: url(/_next/static/media/b78b37b810acce9f-s.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: '__Merriweather_d22de1';
  font-style: normal;
  font-weight: 700;
  font-stretch: 100%;
  font-display: swap;
  src: url(/_next/static/media/027647acf05c7ff8-s.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: '__Merriweather_d22de1';
  font-style: normal;
  font-weight: 700;
  font-stretch: 100%;
  font-display: swap;
  src: url(/_next/static/media/1f3fe8c6df3d47c1-s.p.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;
}@font-face {font-family: '__Merriweather_Fallback_d22de1';src: local("Times New Roman");ascent-override: 80.59%;descent-override: 22.36%;line-gap-override: 0.00%;size-adjust: 122.09%
}.__className_d22de1 {font-family: '__Merriweather_d22de1', '__Merriweather_Fallback_d22de1';font-style: normal
}.__variable_d22de1 {--heading-font: '__Merriweather_d22de1', '__Merriweather_Fallback_d22de1'
}

/*!*************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[13].oneOf[12].use[2]!./node_modules/next/dist/build/webpack/loaders/postcss-loader/src/index.js??ruleSet[1].rules[13].oneOf[12].use[3]!./app/globals.css ***!
  \*************************************************************************************************************************************************************************************************************************************************************/
/* === RESET === */
*, 
*::before, 
*::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

/* === HTML & BODY DEFAULTS === */
/* Hide scrollbar for Chrome, Safari and Opera */
html::-webkit-scrollbar {
    display: none;
}

html {
    /* Hide scrollbar for IE, Edge and Firefox */
    -ms-overflow-style: none;  /* IE and Edge */
    scrollbar-width: none;  /* Firefox */
    scroll-behavior: smooth;
    font-size: 16px; /* Set a base font size */
    scrollbar-gutter: stable; /* Prevent layout shift when scrollbar appears/disappears */
}

body {
    line-height: 1.7;
    background-color: var(--bg-color);
    color: var(--text-color);
    font-family: var(--main-font);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    -webkit-user-select: none;
       -moz-user-select: none;
            user-select: none;
}

/* === SCROLL LOCK UTILITY === */
html.scroll-lock {
    overflow: hidden;
}

/* === VARIABLES === */
:root {
    --primary-color: #9A2A2A; /* A deep, classic red */
    --secondary-color: #FFFFFF; /* Clean white for cards */
    --accent-color: #7E2323; /* A darker red for hover effects */
    --heading-color: #4E342E; /* Dark Brown for headings */
    --text-color: #1C1C1C; /* A very dark grey, almost black */
    --light-text-color: #FDFBF7; /* A very light, warm off-white */
    --bg-color: #F7F2E9; /* Main background color, light desk */
    --border-color: #EAE2D6; /* Border color for cards */
    --container-width: 1280px;
    --spacing-unit: 1rem;
    --border-radius: 28px; /* Pronounced 'squircle' radius */
}


/* === TYPOGRAPHY === */
h1, h2, h3, h4, h5, h6 {
    font-family: var(--heading-font);
    line-height: 1.3;
    margin-bottom: var(--spacing-unit);
    color: var(--heading-color);
    font-weight: 600;
}

h1 {
    font-size: 3rem;
}

h2 {
    font-size: 2.25rem;
    text-align: center;
    margin-bottom: calc(var(--spacing-unit) * 2.5);
}

p {
    margin-bottom: var(--spacing-unit);
    max-width: 75ch; /* Improve readability */
}

a {
    color: var(--primary-color);
    text-decoration: none;
    font-weight: bold;
    transition: color 0.2s ease-in-out;
}

a:hover {
    color: var(--accent-color);
    text-decoration: none;
}

/* === UTILITIES & COMPONENTS === */
.container {
    max-width: var(--container-width);
    margin: 0 auto;
    padding: 0 calc(var(--spacing-unit) * 1.5);
}

section {
    padding: calc(var(--spacing-unit) * 5) 0;
}

main > section:nth-of-type(even) {
    background-color: #fff;
}

.btn {
    display: inline-block;
    padding: calc(var(--spacing-unit) * 0.8) calc(var(--spacing-unit) * 2);
    background-color: var(--primary-color);
    color: var(--light-text-color);
    border-radius: var(--border-radius);
    text-decoration: none;
    font-weight: bold;
    font-family: var(--main-font);
    border: 2px solid var(--primary-color);
    transition: all 0.3s ease;
    cursor: pointer;
    letter-spacing: 0.5px;
    text-transform: uppercase;
    font-size: 0.9rem;
}

.btn:hover {
    background-color: var(--accent-color);
    border-color: var(--accent-color);
    color: #fff;
    text-decoration: none;
    transform: translateY(-2px);
    box-shadow: 0 4px 10px rgba(0,0,0,0.1);
}

/* === RESPONSIVE STYLES === */
@media (max-width: 768px) {
    h1 {
        font-size: 2.5rem;
    }
    h2 {
        font-size: 2rem;
    }
    section {
        padding: calc(var(--spacing-unit) * 3) 0;
    }
}

