@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(fonts/font-1.woff2) format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(fonts/font-2.woff2) format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(fonts/font-3.woff2) format('woff2');
  unicode-range: U+1F00-1FFF;
}
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(fonts/font-4.woff2) format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(fonts/font-5.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;
}
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(fonts/font-6.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;
}
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(fonts/font-7.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';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(fonts/font-1.woff2) format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(fonts/font-2.woff2) format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(fonts/font-3.woff2) format('woff2');
  unicode-range: U+1F00-1FFF;
}
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(fonts/font-4.woff2) format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(fonts/font-5.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;
}
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(fonts/font-6.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;
}
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(fonts/font-7.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';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(fonts/font-1.woff2) format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(fonts/font-2.woff2) format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(fonts/font-3.woff2) format('woff2');
  unicode-range: U+1F00-1FFF;
}
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(fonts/font-4.woff2) format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(fonts/font-5.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;
}
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(fonts/font-6.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;
}
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(fonts/font-7.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: 'Playfair Display';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(fonts/font-8.woff2) format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
@font-face {
  font-family: 'Playfair Display';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(fonts/font-9.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;
}
@font-face {
  font-family: 'Playfair Display';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(fonts/font-10.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;
}
@font-face {
  font-family: 'Playfair Display';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(fonts/font-11.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: 'Playfair Display';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(fonts/font-8.woff2) format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
@font-face {
  font-family: 'Playfair Display';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(fonts/font-9.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;
}
@font-face {
  font-family: 'Playfair Display';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(fonts/font-10.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;
}
@font-face {
  font-family: 'Playfair Display';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(fonts/font-11.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: 'Playfair Display';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(fonts/font-8.woff2) format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
@font-face {
  font-family: 'Playfair Display';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(fonts/font-9.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;
}
@font-face {
  font-family: 'Playfair Display';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(fonts/font-10.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;
}
@font-face {
  font-family: 'Playfair Display';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(fonts/font-11.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

:root {
            --bg-body: #FAF9F6;
            --bg-surface: #FFFFFF;
            --bg-muted: #F4F2ED;
            --accent-primary: #5A7A6A;
            --accent-secondary: #8F643D;
            --accent-hover: #73502F;

            --text-main: #1E2923;
            --text-secondary: #5C6B5F;
            --border: #E8E5DE;
            --shadow: 0 4px 24px rgba(30, 41, 35, 0.06);
            --shadow-hover: 0 8px 32px rgba(30, 41, 35, 0.1);
            --radius: 14px;
            --radius-lg: 20px;
            --transition: all 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);
            --font-heading: 'Playfair Display', Georgia, 'Times New Roman', serif;
            --font-body: 'Inter', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', Arial, sans-serif;
            --container: 1160px;
            --section-py: clamp(4rem, 8vw, 6.5rem);
        }

        *,
        *::before,
        *::after {
            box-sizing: border-box;
            margin: 0;
            padding: 0;
        }

        html {
            scroll-behavior: smooth;
        }

        body {
            font-family: var(--font-body);
            font-size: 1.05rem;
            line-height: 1.65;
            color: var(--text-main);
            background: var(--bg-body);
            overflow-x: hidden;
            -webkit-font-smoothing: antialiased;
        }

        img,
        svg {
            display: block;
            max-width: 100%;
            height: auto;
        }

        a {
            text-decoration: none;
            color: inherit;
            transition: var(--transition);
        }

        ul {
            list-style: none;
        }

        button {
            font-family: inherit;
            cursor: pointer;
            border: none;
            background: none;
        }

        :focus-visible {
            outline: 3px solid rgba(90, 122, 106, 0.45);
            outline-offset: 4px;
            border-radius: 8px;
        }

        .skip-link {
            position: fixed;
            top: 1rem;
            left: 1rem;
            z-index: 1000;
            padding: 0.75rem 1rem;
            background: var(--text-main);
            color: #fff;
            border-radius: 999px;
            transform: translateY(-150%);
        }

        .skip-link:focus {
            transform: translateY(0);
        }

        .container {
            width: 100%;
            max-width: var(--container);
            margin: 0 auto;
            padding: 0 1.5rem;
        }

        .section {
            padding: var(--section-py) 0;
        }

        section[id] {
            scroll-margin-top: 92px;
        }

        .section-header {
            max-width: 700px;
            margin-bottom: clamp(2.5rem, 5vw, 3.5rem);
        }

        .section-title {
            font-family: var(--font-heading);
            font-size: clamp(2rem, 4vw, 2.8rem);
            font-weight: 600;
            line-height: 1.2;
            margin-bottom: 0.75rem;
            color: var(--text-main);
        }

        .section-subtitle {
            color: var(--text-secondary);
            font-size: 1.1rem;
        }

        .btn {
            display: inline-flex;
            align-items: center;
            justify-content: center;
            padding: 0.95rem 2rem;
            border-radius: 50px;
            font-weight: 600;
            font-size: 1rem;
            transition: var(--transition);
            white-space: nowrap;
            cursor: pointer;
            letter-spacing: 0.01em;
        }

        .btn--primary {
            background: var(--accent-secondary);
            color: #fff;
            box-shadow: 0 4px 16px rgba(143, 100, 61, 0.26);
        }

        .btn--primary:hover {
            background: var(--accent-hover);
            transform: translateY(-2px);
        }

        .btn--outline {
            background: transparent;
            border: 1.5px solid var(--accent-primary);
            color: var(--accent-primary);
        }

        .btn--outline:hover {
            background: var(--accent-primary);
            color: #fff;
            transform: translateY(-2px);
        }

        .btn--full {
            width: 100%;
        }

        .btn--large {
            padding: 1rem 2.5rem;
            font-size: 1.05rem;
        }

        .fade-up {
            opacity: 1;
            transform: none;
        }

        .js .fade-up {
            opacity: 0;
            transform: translateY(28px);
            transition: opacity 0.8s ease, transform 0.8s ease;
        }

        .js .fade-up.visible {
            opacity: 1;
            transform: translateY(0);
        }

        .fade-up--delay {
            transition-delay: 0.1s;
        }

        .header {
            position: sticky;
            top: 0;
            z-index: 100;
            background: rgba(250, 249, 246, 0.92);
            backdrop-filter: blur(12px);
            border-bottom: 1px solid var(--border);
            padding: 1.1rem 0;
        }

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

        .header__logo {
            display: inline-flex;
            align-items: center;
            gap: 0.65rem;
            font-family: var(--font-heading);
            font-weight: 600;
            font-size: 1.35rem;
            color: var(--accent-primary);
        }

        .header__logo-mark {
            width: 36px;
            height: 36px;
            flex: 0 0 36px;
        }

        .header__logo-text {
            white-space: nowrap;
        }

        .header__nav {
            display: flex;
            gap: 1.8rem;
        }

        .header__link {
            font-weight: 500;
            color: var(--text-secondary);
            font-size: 0.95rem;
        }

        .header__link:hover {
            color: var(--accent-primary);
        }

        .header__burger {
            display: none;
            font-size: 1.6rem;
            color: var(--text-main);
        }

        .hero {
            min-height: 88vh;
            display: flex;
            align-items: center;
            padding: 2rem 0;
            position: relative;
            overflow: hidden;
        }

        .hero::before {
            content: '';
            position: absolute;
            top: -20%;
            right: -10%;
            width: 60vw;
            height: 60vw;
            background: radial-gradient(circle, rgba(90, 122, 106, 0.08) 0%, transparent 70%);
            pointer-events: none;
        }

        .hero__grid {
            display: grid;
            grid-template-columns: 1.1fr 1fr;
            gap: 4rem;
            align-items: center;
            position: relative;
            z-index: 1;
        }

        .hero__brand {
            display: inline-flex;
            align-items: center;
            gap: 1.1rem;
            margin-bottom: 1.5rem;
            padding: 0.75rem 1.2rem 0.75rem 0.75rem;
            border: 1px solid var(--border);
            border-radius: 999px;
            background: rgba(255, 255, 255, 0.72);
            box-shadow: var(--shadow);
        }

        .hero__brand-logo {
            width: 64px;
            height: 64px;
            flex: 0 0 64px;
        }

        .hero__tagline {
            font-family: var(--font-heading);
            font-size: clamp(1.1rem, 2vw, 1.35rem);
            line-height: 1.25;
            color: var(--accent-primary);
            white-space: nowrap;
        }

        .hero__title {
            font-family: var(--font-heading);
            font-size: clamp(2.6rem, 5vw, 3.8rem);
            font-weight: 700;
            line-height: 1.1;
            margin-bottom: 1.2rem;
            color: var(--text-main);
        }

        .hero__subtitle {
            font-size: 1.15rem;
            color: var(--text-secondary);
            margin-bottom: 2.2rem;
            max-width: 540px;
        }

        .hero__actions {
            display: flex;
            gap: 1rem;
            flex-wrap: wrap;
        }

        .hero__visual {
            position: relative;
            border-radius: var(--radius-lg);
            overflow: hidden;
            box-shadow: var(--shadow);
            aspect-ratio: 4/5;
            background: var(--bg-muted);
        }

        .hero__visual img {
            width: 100%;
            height: 100%;
            object-fit: cover;
        }

        .about__grid {
            display: grid;
            grid-template-columns: 1fr 1.4fr;
            gap: 4rem;
            align-items: center;
        }

        .about__quote {
            font-family: var(--font-heading);
            font-size: 1.5rem;
            font-weight: 500;
            color: var(--accent-primary);
            line-height: 1.4;
            margin-bottom: 1.5rem;
            position: relative;
            padding-left: 1.5rem;
            border-left: 3px solid var(--accent-secondary);
        }

        .about__text {
            color: var(--text-secondary);
            margin-bottom: 1rem;
        }

        .about-channel {
            margin-top: 1.5rem;
            padding: 1.25rem;
            background: var(--bg-muted);
            border: 1px solid var(--border);
            border-radius: var(--radius);
        }

        .about-channel__text {
            color: var(--text-secondary);
            margin-bottom: 1rem;
        }

        .about__stats {
            display: flex;
            gap: 2.5rem;
            margin-top: 2rem;
            padding-top: 1.5rem;
            border-top: 1px solid var(--border);
            flex-wrap: wrap;
        }

        .stat-item {
            text-align: center;
        }

        .stat-num {
            font-family: var(--font-heading);
            font-size: 1.8rem;
            font-weight: 700;
            color: var(--accent-primary);
            display: block;
        }

        .stat-label {
            font-size: 0.85rem;
            color: var(--text-secondary);
            margin-top: 0.2rem;
        }

        .problems__grid {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
            gap: 1.5rem;
        }

        .problem-card {
            background: var(--bg-surface);
            padding: 1.8rem;
            border-radius: var(--radius);
            border: 1px solid var(--border);
            transition: var(--transition);
            display: flex;
            gap: 1rem;
            align-items: flex-start;
        }

        .problem-card:hover {
            transform: translateY(-4px);
            box-shadow: var(--shadow-hover);
            border-color: var(--accent-primary);
        }

        .problem-icon {
            min-width: 42px;
            height: 42px;
            background: var(--bg-muted);
            color: var(--accent-primary);
            border-radius: 10px;
            display: flex;
            align-items: center;
            justify-content: center;
        }

        .problem-icon svg {
            width: 20px;
            height: 20px;
        }

        .problem-title {
            font-weight: 600;
            margin-bottom: 0.3rem;
        }

        .problem-desc {
            font-size: 0.92rem;
            color: var(--text-secondary);
            line-height: 1.5;
        }

        .process__grid {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
            gap: 2rem;
            counter-reset: step;
        }

        .process-step {
            background: var(--bg-surface);
            padding: 2rem;
            border-radius: var(--radius);
            border: 1px solid var(--border);
            position: relative;
        }

        .process-step::before {
            counter-increment: step;
            content: counter(step);
            width: 40px;
            height: 40px;
            background: var(--accent-primary);
            color: #fff;
            border-radius: 50%;
            display: flex;
            align-items: center;
            justify-content: center;
            font-family: var(--font-heading);
            font-weight: 700;
            margin-bottom: 1.2rem;
        }

        .process-title {
            font-weight: 600;
            font-size: 1.15rem;
            margin-bottom: 0.4rem;
        }

        .process-desc {
            font-size: 0.95rem;
            color: var(--text-secondary);
        }

        .benefits {
            background: var(--bg-surface);
        }

        .benefits__grid {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
            gap: 1.5rem;
        }

        .benefit-item {
            display: flex;
            gap: 1rem;
            align-items: flex-start;
            padding: 1.5rem;
            background: var(--bg-surface);
            border-radius: var(--radius);
            border: 1px solid var(--border);
        }

        .benefit-icon {
            min-width: 40px;
            height: 40px;
            background: var(--bg-muted);
            color: var(--accent-primary);
            border-radius: 10px;
            display: flex;
            align-items: center;
            justify-content: center;
        }

        .benefit-icon svg {
            width: 20px;
            height: 20px;
        }

        .benefit-text {
            font-weight: 500;
        }

        .testimonials__showcase {
            display: grid;
            grid-template-columns: minmax(260px, 0.85fr) minmax(0, 1.45fr);
            gap: 2rem;
            align-items: stretch;
        }

        .testimonials__list {
            display: flex;
            flex-direction: column;
            gap: 0.85rem;
        }

        .testimonial-tab {
            width: 100%;
            text-align: left;
            display: flex;
            align-items: center;
            gap: 0.9rem;
            padding: 1rem;
            border: 1px solid var(--border);
            border-radius: var(--radius);
            background: var(--bg-surface);
            color: var(--text-main);
            transition: var(--transition);
        }

        .testimonial-tab:hover,
        .testimonial-tab.is-active {
            border-color: rgba(90, 122, 106, 0.35);
            box-shadow: var(--shadow);
            transform: translateY(-2px);
        }

        .testimonial-tab.is-active {
            background: linear-gradient(135deg, #ffffff 0%, #f6f8f5 100%);
        }

        .testimonial-avatar {
            width: 48px;
            height: 48px;
            background: var(--bg-muted);
            color: var(--accent-primary);
            border-radius: 50%;
            display: flex;
            align-items: center;
            justify-content: center;
            font-family: var(--font-heading);
            font-weight: 700;
            font-size: 1.2rem;
            flex: 0 0 48px;
        }

        .testimonial-tab.is-active .testimonial-avatar {
            background: var(--accent-primary);
            color: #fff;
        }

        .testimonial-tab__meta {
            min-width: 0;
        }

        .testimonial-name {
            display: block;
            font-weight: 600;
            font-size: 1rem;
        }

        .testimonial-role {
            display: block;
            font-size: 0.85rem;
            line-height: 1.35;
            color: var(--text-secondary);
        }

        .testimonial-panel {
            background: var(--bg-surface);
            padding: clamp(2rem, 4vw, 3rem);
            border-radius: var(--radius-lg);
            border: 1px solid var(--border);
            box-shadow: var(--shadow);
            position: relative;
            overflow: hidden;
            min-height: 520px;
            display: flex;
            flex-direction: column;
        }

        .testimonial-panel::before {
            content: '"';
            position: absolute;
            top: 1.2rem;
            right: 2rem;
            font-family: var(--font-heading);
            font-size: 7rem;
            line-height: 1;
            color: var(--accent-secondary);
            opacity: 0.12;
        }

        .testimonial-panel__eyebrow {
            color: var(--accent-secondary);
            font-size: 0.78rem;
            font-weight: 700;
            letter-spacing: 0.12em;
            text-transform: uppercase;
            margin-bottom: 1.1rem;
        }

        .testimonial-panel__header {
            display: flex;
            align-items: center;
            gap: 1rem;
            position: relative;
            z-index: 1;
        }

        .testimonial-panel__name {
            font-family: var(--font-heading);
            font-size: clamp(1.45rem, 3vw, 2rem);
            font-weight: 600;
            line-height: 1.2;
        }

        .testimonial-panel__role {
            color: var(--text-secondary);
            font-size: 0.95rem;
        }

        .testimonial-panel__body {
            margin-top: 1.8rem;
            padding-right: 0.7rem;
            max-height: 360px;
            overflow-y: auto;
            scrollbar-gutter: stable;
            position: relative;
            z-index: 1;
        }

        .testimonial-panel__body p {
            color: var(--text-main);
            font-size: clamp(1rem, 1.2vw, 1.08rem);
            line-height: 1.75;
            margin-bottom: 1rem;
        }

        .testimonial-panel__body p:last-child {
            margin-bottom: 0;
        }

        .testimonial-panel__body::-webkit-scrollbar {
            width: 6px;
        }

        .testimonial-panel__body::-webkit-scrollbar-track {
            background: var(--bg-muted);
            border-radius: 999px;
        }

        .testimonial-panel__body::-webkit-scrollbar-thumb {
            background: rgba(90, 122, 106, 0.45);
            border-radius: 999px;
        }

        .cta {
            background: linear-gradient(135deg, #f4f2ed 0%, #eef1ea 100%);
            text-align: center;
            position: relative;
            overflow: hidden;
        }

        .cta::before {
            content: '';
            position: absolute;
            top: 0;
            left: 0;
            right: 0;
            bottom: 0;
            background: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%235A7A6A' fill-opacity='0.03'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
            opacity: 0.6;
        }

        .cta__content {
            position: relative;
            z-index: 1;
            max-width: 700px;
            margin: 0 auto;
        }

        .cta__title {
            margin-bottom: 1rem;
        }

        .cta__text {
            margin-bottom: 2rem;
        }

        .contacts {
            background: var(--bg-surface);
        }

        .section-header--center {
            text-align: center;
            margin-left: auto;
            margin-right: auto;
        }

        .section-header--center .section-subtitle {
            max-width: 620px;
            margin-left: auto;
            margin-right: auto;
        }

        .contacts__grid {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
            gap: 2rem;
            margin-bottom: 2.5rem;
            align-items: stretch;
        }

        .contact-card {
            background: var(--bg-body);
            padding: 2.2rem 1.8rem;
            border-radius: var(--radius-lg);
            border: 1px solid var(--border);
            text-align: center;
            display: flex;
            flex-direction: column;
            height: 100%;
        }

        .contact-title {
            font-family: var(--font-heading);
            font-size: 1.3rem;
            font-weight: 600;
            margin-bottom: 0.5rem;
        }

        .contact-desc {
            color: var(--text-secondary);
            margin-bottom: 1.5rem;
            font-size: 0.95rem;
        }

        .qr-placeholder {
            width: 150px;
            height: 150px;
            background: var(--bg-surface);
            margin: 0 auto 1.5rem;
            border-radius: 12px;
            padding: 12px;
            box-shadow: var(--shadow);
            display: flex;
            align-items: center;
            justify-content: center;
            color: var(--text-secondary);
            font-size: 0.85rem;
            border: 1px dashed var(--border);
        }

        .contact-card .btn {
            margin-top: auto;
        }

        .contact-card__actions {
            display: grid;
            gap: 0.75rem;
            margin-top: auto;
        }

        .contact-card__actions .btn {
            margin-top: 0;
        }

        .contacts__info {
            text-align: center;
            padding-top: 2rem;
            border-top: 1px solid var(--border);
        }

        .contacts__phone {
            font-family: var(--font-heading);
            font-size: 1rem;
            font-weight: 600;
            letter-spacing: 0.01em;
            white-space: nowrap;
        }

        .contact-card--phone {
            justify-content: flex-start;
        }

        .phone-visual {
            width: 150px;
            height: 150px;
            background: var(--bg-surface);
            margin: 0 auto 1.5rem;
            border-radius: 50%;
            box-shadow: var(--shadow);
            border: 1px solid var(--border);
            display: flex;
            align-items: center;
            justify-content: center;
            color: var(--accent-primary);
        }

        .phone-visual svg {
            width: 58px;
            height: 58px;
        }

        .footer {
            background: var(--text-main);
            color: rgba(255, 255, 255, 0.85);
            padding: 3rem 0 2rem;
            text-align: center;
        }

        .footer__name {
            font-family: var(--font-heading);
            font-size: 1.25rem;
            font-weight: 600;
            color: #fff;
            margin-bottom: 0.3rem;
        }

        .footer__role {
            color: rgba(255, 255, 255, 0.6);
            font-size: 0.9rem;
            margin-bottom: 0;
        }

        .footer__links {
            display: flex;
            justify-content: center;
            gap: 1rem;
            flex-wrap: wrap;
            margin-top: 1.2rem;
            font-size: 0.85rem;
        }

        .footer__link {
            color: rgba(255, 255, 255, 0.65);
        }

        .footer__link:hover {
            color: #fff;
        }

        .footer__copy {
            font-size: 0.8rem;
            color: rgba(255, 255, 255, 0.4);
            margin-top: 1.5rem;
            padding-top: 1.2rem;
            border-top: 1px solid rgba(255, 255, 255, 0.1);
        }

        @media (max-width: 900px) {

            .hero__grid,
            .about__grid {
                grid-template-columns: 1fr;
                text-align: center;
            }

            .hero__content {
                margin: 0 auto;
            }

            .hero__actions {
                justify-content: center;
            }

            .hero__brand {
                justify-content: center;
            }

            .about__quote {
                border-left: none;
                border-top: 3px solid var(--accent-secondary);
                padding-left: 0;
                padding-top: 1.2rem;
            }

            .about__stats {
                justify-content: center;
            }

            .testimonials__showcase {
                grid-template-columns: 1fr;
            }

            .testimonials__list {
                display: grid;
                grid-template-columns: repeat(5, minmax(220px, 1fr));
                overflow-x: auto;
                padding-bottom: 0.4rem;
                scroll-snap-type: x proximity;
            }

            .testimonial-tab {
                scroll-snap-align: start;
            }

            .header__nav {
                display: none;
                position: absolute;
                top: 100%;
                left: 0;
                right: 0;
                background: var(--bg-body);
                padding: 1.5rem;
                flex-direction: column;
                gap: 1.2rem;
                align-items: center;
                border-bottom: 1px solid var(--border);
                box-shadow: var(--shadow);
            }

            .header__nav.active {
                display: flex;
            }

            .header__burger {
                display: block;
            }

        }

        @media (max-width: 600px) {
            .section {
                padding: 3rem 0;
            }

            .hero {
                min-height: auto;
                padding: 2.5rem 0 2rem;
            }

            .hero__actions {
                flex-direction: column;
            }

            .hero__brand {
                width: 100%;
                flex-direction: column;
                gap: 0.7rem;
                padding: 1rem;
                border-radius: var(--radius-lg);
            }

            .hero__tagline {
                text-align: center;
                white-space: normal;
            }

            .btn {
                width: 100%;
            }

            .process__grid {
                grid-template-columns: 1fr;
            }

            .testimonials__list {
                grid-template-columns: repeat(5, minmax(210px, 78vw));
            }

            .testimonial-panel {
                min-height: auto;
                padding: 1.5rem;
            }

            .testimonial-panel__header {
                align-items: flex-start;
            }

            .testimonial-panel__body {
                max-height: 420px;
                padding-right: 0.35rem;
            }

            .qr-placeholder {
                width: 130px;
                height: 130px;
            }
        }

        @media (prefers-reduced-motion: reduce) {

            *,
            *::before,
            *::after {
                animation-duration: 0.01ms !important;
                transition-duration: 0.01ms !important;
                scroll-behavior: auto !important;
            }

            .fade-up {
                opacity: 1;
                transform: none;
            }

            .js .fade-up {
                opacity: 1;
                transform: none;
            }
        }

.legal-page {
    font-family: var(--font-body);
    line-height: 1.7;
    color: var(--text-main);
    background: var(--bg-body);
    padding: 2rem 1rem;
    overflow-x: hidden;
}

.legal-page main {
    width: 100%;
    max-width: 840px;
    margin: 0 auto;
    background: var(--bg-surface);
    border: 1px solid var(--border);
    border-radius: 20px;
    padding: clamp(1.5rem, 4vw, 3rem);
}

.legal-page h1,
.legal-page h2 {
    font-family: var(--font-heading);
    line-height: 1.25;
}

.legal-page h1 {
    font-size: clamp(2rem, 5vw, 3rem);
    margin-bottom: 1rem;
    overflow-wrap: anywhere;
    hyphens: auto;
}

.legal-page h2 {
    font-size: 1.35rem;
    margin: 2rem 0 0.75rem;
}

.legal-page p,
.legal-page li {
    color: var(--text-secondary);
    margin-bottom: 0.75rem;
}

.legal-page ul {
    list-style: disc;
    padding-left: 1.25rem;
}

.legal-page a {
    color: var(--accent-secondary);
    font-weight: 600;
}

.legal-page .back {
    display: inline-flex;
    margin-bottom: 2rem;
    color: var(--accent-primary);
    text-decoration: none;
}

.cookie-notice[hidden] {
    display: none;
}

.cookie-notice {
    position: fixed;
    right: 1rem;
    bottom: 1rem;
    z-index: 200;
    display: grid;
    grid-template-columns: 1fr auto auto;
    gap: 0.9rem;
    align-items: center;
    max-width: min(760px, calc(100vw - 2rem));
    padding: 1rem;
    color: var(--text-main);
    background: rgba(255, 255, 255, 0.96);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    box-shadow: var(--shadow-hover);
}

.cookie-notice__text {
    font-size: 0.9rem;
    line-height: 1.45;
}

.cookie-notice__link {
    color: var(--accent-secondary);
    font-weight: 600;
    white-space: nowrap;
}

.cookie-notice__button {
    padding: 0.65rem 1rem;
    color: #fff;
    font-weight: 700;
    background: var(--accent-primary);
    border-radius: 999px;
}

@media (max-width: 420px) {
    .legal-page {
        padding: 1rem 0.75rem;
    }

    .legal-page main {
        border-radius: 16px;
        padding: 1.25rem;
    }

    .legal-page h1 {
        font-size: 1.65rem;
        line-height: 1.15;
    }

    .cookie-notice {
        left: 0.75rem;
        right: 0.75rem;
        bottom: 0.75rem;
        grid-template-columns: 1fr;
    }
}
