:root {
    --cms-bg: #f6f7f9;
    --cms-surface: #ffffff;
    --cms-surface-soft: #fbfcfd;
    --cms-line: #d8dde4;
    --cms-line-strong: #bcc6d2;
    --cms-text: #0f1722;
    --cms-muted: #667384;
    --cms-dark: #11192a;
    --cms-dark-2: #1a2740;
    --cms-dark-3: #0f1522;
    --cms-accent: #d9b36b;
    --cms-shadow: 0 24px 52px rgba(17, 25, 42, 0.08);
}

html, body {
    min-height: 100%;
}

body {
    margin: 0;
    background: var(--cms-bg);
    color: var(--cms-text);
    letter-spacing: 0.01em;
}

a {
    color: inherit;
    text-decoration: none;
}

.site-header {
    background: linear-gradient(90deg, var(--cms-dark-3) 0%, var(--cms-dark-2) 100%);
    border-bottom: 1px solid rgba(255,255,255,0.08);
    position: sticky;
    top: 0;
    z-index: 1030;
}

.site-header-row {
    min-height: 82px;
    display: flex;
    align-items: center;
    gap: 1.5rem;
}

.site-brand {
    display: inline-flex;
    align-items: center;
    gap: 0.95rem;
    color: #fff;
    flex: 0 0 auto;
}

.site-brand-mark {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 56px;
    height: 56px;
    border-radius: 14px;
    background: linear-gradient(180deg, rgba(255,255,255,0.10), rgba(255,255,255,0.03));
    border: 1px solid rgba(255,255,255,0.14);
    font-weight: 700;
    letter-spacing: 0.04em;
}

.site-brand-copy {
    display: flex;
    flex-direction: column;
    gap: 0.15rem;
}

.site-brand-copy strong {
    font-size: 1.08rem;
    font-weight: 700;
    letter-spacing: 0.03em;
}

.site-brand-copy small {
    color: rgba(255,255,255,0.62);
    font-size: 0.76rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
}

.site-menu-shell {
    display: flex;
    align-items: center;
    gap: 1rem;
    flex: 1 1 auto;
}

.site-nav {
    display: flex;
    align-items: center;
    gap: 1.3rem;
    flex: 1 1 auto;
}

.site-nav a {
    color: rgba(255,255,255,0.78);
    font-size: 0.96rem;
    line-height: 1;
    padding: 0.4rem 0;
    border-bottom: 2px solid transparent;
}

.site-nav a:hover,
.site-nav a.is-active {
    color: #fff;
    border-bottom-color: var(--cms-accent);
}

.site-tools {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 0.65rem;
    flex-wrap: wrap;
}

.lang-switch {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
}

.lang-pill,
.site-tool-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 38px;
    padding: 0 0.9rem;
    border-radius: 10px;
    border: 1px solid rgba(255,255,255,0.18);
    background: rgba(255,255,255,0.02);
    color: rgba(255,255,255,0.88);
    font-size: 0.92rem;
}

.lang-pill:hover,
.lang-pill.is-active,
.site-tool-link:hover {
    color: #fff;
    border-color: rgba(255,255,255,0.34);
}

.site-tool-link.is-solid {
    background: #fff;
    color: var(--cms-dark);
    border-color: #fff;
}

.site-toggle {
    display: none;
    margin-left: auto;
    min-width: 44px;
    min-height: 44px;
    border-radius: 10px;
    border: 1px solid rgba(255,255,255,0.18);
    background: transparent;
    color: #fff;
}

.site-main {
    padding: 2.2rem 0 3.5rem;
}

.site-footer {
    border-top: 1px solid var(--cms-line);
    background: #fff;
}

.site-footer-row {
    min-height: 74px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    color: var(--cms-muted);
    font-size: 0.92rem;
}

.manufacturer-hero {
    position: relative;
    overflow: hidden;
    border-radius: 28px;
    margin-bottom: 2rem;
    background:
        radial-gradient(circle at top right, rgba(217, 179, 107, 0.20), transparent 26%),
        radial-gradient(circle at bottom left, rgba(255,255,255,0.08), transparent 20%),
        linear-gradient(135deg, var(--cms-dark-3) 0%, var(--cms-dark-2) 100%);
    border: 1px solid rgba(255,255,255,0.06);
    box-shadow: 0 28px 70px rgba(16, 25, 39, 0.24);
}

.manufacturer-hero-grid {
    display: grid;
    grid-template-columns: minmax(0, 0.95fr) minmax(0, 1.15fr);
}

.hero-copy {
    padding: 3.2rem;
}

.hero-kicker {
    color: rgba(255,255,255,0.58);
    text-transform: uppercase;
    letter-spacing: 0.18em;
    font-size: 0.78rem;
    margin-bottom: 1rem;
}

.hero-title {
    color: #fff;
    font-size: clamp(2.25rem, 4.3vw, 4.2rem);
    line-height: 1.04;
    max-width: 10ch;
    margin-bottom: 1.2rem;
    font-weight: 700;
}

.hero-text {
    color: rgba(255,255,255,0.76);
    max-width: 56ch;
    font-size: 1.04rem;
    line-height: 1.7;
}

.hero-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    margin-top: 1.8rem;
}

.hero-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 48px;
    padding: 0 1.25rem;
    border-radius: 12px;
    border: 1px solid rgba(255,255,255,0.20);
    color: #fff;
}

.hero-button.is-solid {
    background: #fff;
    border-color: #fff;
    color: var(--cms-dark);
}

.hero-lineup {
    padding: 1.6rem;
    border-left: 1px solid rgba(255,255,255,0.07);
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
    align-content: center;
}

.lineup-card,
.spec-card,
.controller-card,
.card-industrial,
.admin-card,
.table-wrap,
.support-panel,
.product-detail-card,
.commercial-card,
.product-story {
    background: var(--cms-surface);
    border: 1px solid var(--cms-line);
    box-shadow: var(--cms-shadow);
}

.lineup-card {
    border-radius: 20px;
    padding: 1.2rem;
    display: flex;
    flex-direction: column;
    gap: 0.65rem;
    min-height: 196px;
}

.lineup-code {
    color: var(--cms-muted);
    text-transform: uppercase;
    letter-spacing: 0.14em;
    font-size: 0.72rem;
}

.lineup-card h3 {
    margin: 0;
    font-size: 1.45rem;
}

.lineup-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-top: auto;
}

.lineup-pill,
.badge-stock,
.catalog-kicker,
.spec-chip {
    display: inline-flex;
    align-items: center;
    min-height: 30px;
    padding: 0 0.72rem;
    border-radius: 999px;
    font-size: 0.76rem;
    border: 1px solid var(--cms-line-strong);
    background: var(--cms-surface-soft);
    color: #223245;
}

.catalog-header,
.page-intro {
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1.35rem;
}

.catalog-kicker,
.section-kicker {
    color: var(--cms-muted);
    text-transform: uppercase;
    letter-spacing: 0.15em;
    font-size: 0.76rem;
    font-weight: 700;
}

.catalog-grid,
.controller-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1.2rem;
}

.controller-card,
.controller-tile,
.support-panel {
    border-radius: 22px;
    padding: 1.35rem;
    display: flex;
    flex-direction: column;
    gap: 0.9rem;
}

.controller-card-top,
.controller-topline {
    display: flex;
    justify-content: space-between;
    align-items: start;
    gap: 0.75rem;
}

.controller-card h2,
.controller-card h3,
.controller-tile h2,
.controller-tile h3 {
    margin: 0;
    font-size: 1.55rem;
    min-height: 3.6rem;
}

.controller-card p,
.controller-tile p,
.support-panel p,
.product-story p {
    color: var(--cms-muted);
    margin: 0;
}

.controller-card-footer,
.controller-footer {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
    gap: 0.75rem;
    margin-top: auto;
}

.price-tag {
    font-weight: 700;
    font-size: 1.06rem;
}

.action-dark,
.action-outline {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 42px;
    padding: 0 1rem;
    border-radius: 10px;
    font-weight: 500;
}

.action-dark {
    background: var(--cms-dark);
    color: #fff;
    border: 1px solid var(--cms-dark);
}

.action-outline {
    background: transparent;
    color: var(--cms-dark);
    border: 1px solid var(--cms-line-strong);
}

.feature-band {
    margin-bottom: 2rem;
}

.feature-band-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1rem;
}

.spec-card {
    border-radius: 20px;
    padding: 1.2rem;
}

.spec-card h3 {
    font-size: 1.02rem;
    margin: 0 0 0.55rem;
}

.content-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1.2rem;
}

.support-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1.2rem;
}

.page-shell {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 360px;
    gap: 1.35rem;
}

.product-story,
.product-detail-card,
.commercial-card {
    border-radius: 24px;
}

.product-story,
.product-detail-card {
    padding: 2rem;
}

.product-eyebrow {
    color: var(--cms-muted);
    text-transform: uppercase;
    letter-spacing: 0.18em;
    font-size: 0.76rem;
    margin-bottom: 0.9rem;
}

.product-head {
    margin-bottom: 1.4rem;
}

.product-head h1 {
    margin: 0;
    font-size: clamp(2rem, 3vw, 3rem);
}

.product-lead {
    color: var(--cms-muted);
    font-size: 1.08rem;
}

.product-story {
    background: linear-gradient(180deg, #ffffff 0%, #fbfcfd 100%);
}

.spec-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.85rem;
    margin-top: 1.4rem;
}

.spec-item {
    border: 1px solid var(--cms-line);
    border-radius: 16px;
    padding: 0.95rem 1rem;
    background: #fff;
}

.spec-item strong {
    display: block;
    color: var(--cms-muted);
    font-size: 0.82rem;
    margin-bottom: 0.3rem;
}

.commercial-card {
    padding: 1.5rem;
    position: sticky;
    top: 100px;
}

.commercial-price {
    font-size: clamp(2.2rem, 4vw, 3rem);
    font-weight: 700;
    line-height: 1;
    margin-bottom: 1.2rem;
}

.form-label {
    font-weight: 500;
}

.table thead th {
    background: #eef2f6;
    color: #2a394a;
    text-transform: uppercase;
    font-size: 0.78rem;
    letter-spacing: 0.06em;
}

.admin-sidebar {
    background: linear-gradient(180deg, #1f2937 0%, #111827 100%);
}

.admin-sidebar a {
    color: rgba(255,255,255,.85);
    text-decoration: none;
    display: block;
    padding: .7rem .85rem;
    border-radius: .75rem;
}

.admin-sidebar a.active,
.admin-sidebar a:hover {
    background: rgba(255,255,255,.12);
    color: #fff;
}

.admin-statistics-page,
.admin-statistics-page .row,
.admin-statistics-page [class*="col-"] {
    min-width: 0;
}

.admin-statistics-page .admin-card {
    min-width: 0;
    overflow: hidden;
}

.admin-statistics-page .statistics-chart-shell {
    position: relative;
    width: 100%;
    max-width: 100%;
    min-height: 280px;
}

.admin-statistics-page .statistics-chart-shell--compact {
    min-height: 320px;
}

.admin-statistics-page canvas {
    display: block;
    width: 100% !important;
    max-width: 100%;
}

.admin-statistics-page .table-responsive {
    width: 100%;
    max-width: 100%;
    overflow-x: auto;
}

.admin-statistics-page .statistics-table {
    width: 100%;
    table-layout: fixed;
}

.admin-statistics-page .statistics-table th,
.admin-statistics-page .statistics-table td {
    overflow-wrap: anywhere;
    word-break: break-word;
}

@media (max-width: 1199.98px) {
    .catalog-grid,
    .controller-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .content-grid,
    .feature-band-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .page-shell {
        grid-template-columns: 1fr 320px;
    }
}

@media (max-width: 991.98px) {
    .site-toggle {
        display: inline-flex;
    }

    .site-menu-shell {
        display: none;
        position: absolute;
        left: 12px;
        right: 12px;
        top: calc(100% + 8px);
        background: linear-gradient(180deg, rgba(17,25,42,0.98), rgba(17,25,42,0.98));
        border: 1px solid rgba(255,255,255,0.10);
        border-radius: 18px;
        padding: 1rem;
        box-shadow: 0 22px 50px rgba(10, 16, 26, 0.28);
        flex-direction: column;
        align-items: stretch;
    }

    .site-menu-shell.is-open {
        display: flex;
    }

    .site-header-row {
        position: relative;
    }

    .site-nav,
    .site-tools {
        flex-direction: column;
        align-items: stretch;
        justify-content: flex-start;
    }

    .site-nav a {
        border-bottom: 0;
        padding: 0.55rem 0;
    }

    .manufacturer-hero-grid,
    .page-shell,
    .support-grid {
        grid-template-columns: 1fr;
    }

    .hero-lineup {
        border-left: 0;
        border-top: 1px solid rgba(255,255,255,0.07);
    }

    .feature-band-grid,
    .content-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 767.98px) {
    .site-header-row {
        min-height: 74px;
    }

    .site-brand-mark {
        width: 48px;
        height: 48px;
    }

    .hero-copy,
    .product-story,
    .product-detail-card,
    .commercial-card {
        padding: 1.25rem;
    }

    .hero-lineup,
    .catalog-grid,
    .controller-grid,
    .spec-grid {
        grid-template-columns: 1fr;
    }

    .site-footer-row,
    .catalog-header,
    .page-intro,
    .controller-card-footer,
    .controller-footer {
        flex-direction: column;
        align-items: flex-start;
    }
}

/* ===== Frontend refresh v4: white + green public theme only ===== */
.frontend-site {
    background: #f8fbf6;
    color: #213126;
}

.frontend-site .site-header {
    background: rgba(255, 255, 255, 0.96);
    border-bottom: 1px solid #d9e6d1;
    box-shadow: 0 8px 30px rgba(48, 79, 49, 0.08);
    backdrop-filter: blur(8px);
}

.frontend-site .site-header-stripe {
    height: 4px;
    background: linear-gradient(90deg, #57a728 0%, #86c935 50%, #57a728 100%);
}

.frontend-site .site-header-row {
    min-height: 88px;
    gap: 1.25rem;
}

.frontend-site .site-brand {
    color: #1f2e21;
}

.frontend-site .site-brand-mark {
    width: 54px;
    height: 54px;
    border-radius: 14px;
    background: linear-gradient(180deg, #8fd04b 0%, #63aa28 100%);
    border: 1px solid #5fa424;
    box-shadow: 0 12px 24px rgba(92, 156, 35, 0.22);
    color: #fff;
}

.frontend-site .site-brand-copy small {
    color: #688069;
}

.frontend-site .site-nav {
    gap: 1.1rem;
}

.frontend-site .site-nav > a,
.frontend-site .nav-link-main {
    color: #334a34;
    font-weight: 600;
    font-size: 0.95rem;
    border-bottom: 0;
    position: relative;
    padding: 0.55rem 0;
}

.frontend-site .site-nav > a::after,
.frontend-site .nav-link-main::after {
    content: '';
    position: absolute;
    left: 0;
    right: 0;
    bottom: -0.1rem;
    height: 2px;
    border-radius: 999px;
    background: #6bbb2f;
    transform: scaleX(0);
    transform-origin: center;
    transition: transform 0.2s ease;
}

.frontend-site .site-nav > a:hover,
.frontend-site .site-nav > a.is-active,
.frontend-site .nav-item.is-active > .nav-link-main,
.frontend-site .nav-link-main:hover {
    color: #1d2b1f;
}

.frontend-site .site-nav > a:hover::after,
.frontend-site .site-nav > a.is-active::after,
.frontend-site .nav-item.is-active > .nav-link-main::after,
.frontend-site .nav-link-main:hover::after {
    transform: scaleX(1);
}

.frontend-site .nav-item {
    position: relative;
}

.frontend-site .nav-dropdown {
    position: absolute;
    top: calc(100% + 16px);
    left: 0;
    min-width: 290px;
    background: #fff;
    border: 1px solid #dce8d3;
    border-radius: 0;
    box-shadow: 0 22px 44px rgba(41, 77, 41, 0.12);
    padding: 1rem;
    opacity: 0;
    visibility: hidden;
    transform: translateY(8px);
    transition: opacity 0.2s ease, transform 0.2s ease, visibility 0.2s ease;
    z-index: 20;
}

.frontend-site .has-dropdown:hover .nav-dropdown,
.frontend-site .has-dropdown:focus-within .nav-dropdown {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

.frontend-site .nav-dropdown-grid {
    display: grid;
    gap: 0.55rem;
}

.frontend-site .nav-dropdown-grid a {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 0.75rem 0.85rem;
    border-radius: 0;
    background: #f8fbf5;
    border: 1px solid #e4eedf;
    color: #233424;
}

.frontend-site .nav-dropdown-grid a:hover {
    background: #eef8e5;
    border-color: #cde5b6;
}

.frontend-site .nav-dropdown-grid strong {
    font-size: 0.96rem;
}

.frontend-site .nav-dropdown-grid small,
.frontend-site .nav-dropdown-all,
.frontend-site .mini-link,
.frontend-site .section-subtitle,
.frontend-site .content-page-body,
.frontend-site .hero-text,
.frontend-site .controller-card p,
.frontend-site .hero-controller-card p,
.frontend-site .info-band-card p,
.frontend-site .content-card p,
.frontend-site .product-main-copy,
.frontend-site .product-main-lead,
.frontend-site .site-footer-row {
    color: #647565;
}

.frontend-site .nav-dropdown-all,
.frontend-site .mini-link {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    color: #4b8f1d;
    font-weight: 700;
    text-decoration: none;
}

.frontend-site .nav-dropdown-all {
    margin-top: 0.85rem;
}

.frontend-site .site-tools {
    gap: 0.55rem;
}

.frontend-site .lang-pill,
.frontend-site .site-tool-link {
    min-height: 40px;
    border-radius: 11px;
    border: 1px solid #d8e4cf;
    background: #fff;
    color: #2a3d2a;
    font-weight: 600;
}

.frontend-site .lang-pill.is-active,
.frontend-site .lang-pill:hover {
    border-color: #95ca67;
    background: #eef8e5;
    color: #1d321f;
}

.frontend-site .site-tool-link:hover,
.frontend-site .site-tool-link.is-outline {
    border-color: #a4cf7f;
    background: #f4faee;
    color: #223624;
}

.frontend-site .site-tool-link.is-solid {
    border-color: #6eb534;
    background: linear-gradient(180deg, #81c943 0%, #65ae2a 100%);
    color: #fff;
}

.frontend-site .tool-count {
    display: inline-flex;
    min-width: 22px;
    min-height: 22px;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    background: #eaf5dd;
    color: #447a19;
    font-size: 0.76rem;
    margin-left: 0.45rem;
}

.frontend-site .site-main {
    padding: 2rem 0 3.25rem;
}

.frontend-site .front-hero {
    display: grid;
    grid-template-columns: minmax(0, 1.08fr) minmax(0, 0.92fr);
    gap: 1.3rem;
    margin-bottom: 1.6rem;
}

.frontend-site .front-hero-copy,
.frontend-site .front-hero-side,
.frontend-site .controller-card,
.frontend-site .info-band-card,
.frontend-site .content-card,
.frontend-site .content-page-card,
.frontend-site .product-main-card,
.frontend-site .product-buy-card {
    background: #fff;
    border: 1px solid #dce8d2;
    border-radius: 24px;
    box-shadow: 0 18px 36px rgba(66, 101, 55, 0.08);
}

.frontend-site .front-hero-copy {
    padding: 2.5rem;
    background: linear-gradient(180deg, #ffffff 0%, #f6fbf1 100%);
}

.frontend-site .front-hero-side {
    padding: 1.4rem;
}

.frontend-site .hero-kicker,
.frontend-site .catalog-kicker,
.frontend-site .section-kicker {
    color: #6da53c;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    font-size: 0.76rem;
    font-weight: 800;
}

.frontend-site .hero-title,
.frontend-site .section-title,
.frontend-site .product-main-title {
    color: #203121;
    font-weight: 700;
    line-height: 1.08;
}

.frontend-site .hero-title {
    font-size: clamp(2.15rem, 4vw, 4rem);
    max-width: 12ch;
    margin-bottom: 1rem;
}

.frontend-site .hero-text {
    max-width: 56ch;
    font-size: 1.02rem;
    line-height: 1.75;
}

.frontend-site .hero-actions,
.frontend-site .controller-card-footer {
    display: flex;
    gap: 0.75rem;
    flex-wrap: wrap;
}

.frontend-site .action-green,
.frontend-site .action-outline {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 44px;
    padding: 0 1rem;
    border-radius: 12px;
    border: 1px solid transparent;
    font-weight: 700;
    text-decoration: none;
}

.frontend-site .action-green {
    background: linear-gradient(180deg, #80c840 0%, #67ae2c 100%);
    border-color: #63a728;
    color: #fff;
}

.frontend-site .action-green:hover {
    color: #fff;
    filter: brightness(0.98);
}

.frontend-site .action-outline {
    background: #fff;
    border-color: #cfe0c3;
    color: #244025;
}

.frontend-site .action-outline:hover {
    background: #f2f9ec;
    color: #1f341f;
}

.frontend-site .hero-meta-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.8rem;
    margin-top: 2rem;
}

.frontend-site .hero-meta-item {
    padding: 0.95rem 1rem;
    border-radius: 16px;
    background: #f7fbf4;
    border: 1px solid #dce8d1;
}

.frontend-site .hero-meta-item span {
    display: block;
    color: #728272;
    font-size: 0.8rem;
    margin-bottom: 0.3rem;
}

.frontend-site .hero-meta-item strong {
    color: #213322;
    font-size: 1rem;
}

.frontend-site .hero-side-head,
.frontend-site .section-heading-row {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1rem;
}

.frontend-site .hero-controller-list,
.frontend-site .catalog-grid,
.frontend-site .content-grid,
.frontend-site .info-band-grid {
    display: grid;
    gap: 1rem;
}

.frontend-site .hero-controller-list {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.frontend-site .catalog-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.frontend-site .content-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.frontend-site .info-band-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    margin-bottom: 1.6rem;
}

.frontend-site .hero-controller-card,
.frontend-site .controller-card,
.frontend-site .info-band-card,
.frontend-site .content-card {
    display: flex;
    flex-direction: column;
    gap: 0.85rem;
    padding: 1.2rem;
    border-radius: 20px;
    background: #fff;
    border: 1px solid #dde9d4;
}

.frontend-site .hero-controller-card,
.frontend-site .controller-card,
.frontend-site .content-page-card,
.frontend-site .product-main-card,
.frontend-site .product-buy-card {
    position: relative;
    overflow: hidden;
}

.frontend-site .hero-controller-card::before,
.frontend-site .controller-card::before,
.frontend-site .content-page-card::before,
.frontend-site .product-main-card::before,
.frontend-site .product-buy-card::before {
    content: '';
    position: absolute;
    inset: 0 auto auto 0;
    width: 100%;
    height: 4px;
    background: linear-gradient(90deg, #7ec83f 0%, #5ca625 100%);
}

.frontend-site .hero-controller-top,
.frontend-site .controller-card-top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
}

.frontend-site .hero-controller-card h3,
.frontend-site .controller-card h2,
.frontend-site .controller-card h3,
.frontend-site .content-card h3,
.frontend-site .info-band-card h3 {
    color: #213322;
    margin: 0;
    font-weight: 700;
}

.frontend-site .badge-stock,
.frontend-site .spec-chip {
    display: inline-flex;
    align-items: center;
    min-height: 30px;
    padding: 0 0.72rem;
    border-radius: 999px;
    border: 1px solid #d6e6c7;
    background: #eef7e6;
    color: #44771c;
    font-size: 0.76rem;
    font-weight: 700;
}

.frontend-site .price-tag,
.frontend-site .product-buy-price {
    color: #223523;
    font-weight: 800;
}

.frontend-site .price-tag {
    font-size: 1rem;
}

.frontend-site .product-page-shell {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 340px;
    gap: 1.25rem;
}

.frontend-site .product-main-card {
    padding: 2rem;
}

.frontend-site .product-buy-card {
    padding: 1.5rem;
    align-self: start;
    position: sticky;
    top: 108px;
}

.frontend-site .product-main-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: 1rem;
    margin-bottom: 1rem;
}

.frontend-site .product-main-header .catalog-kicker {
    margin-left: auto;
}

.frontend-site .product-main-title {
    font-size: clamp(2rem, 3.5vw, 3.15rem);
    margin-bottom: 0.8rem;
}

.frontend-site .product-main-lead,
.frontend-site .product-main-copy,
.frontend-site .content-page-body {
    line-height: 1.8;
}

.frontend-site .product-spec-wrap {
    margin-top: 1.8rem;
}

.frontend-site .product-share-shell {
    margin-top: 1.4rem;
    padding-top: 1.1rem;
    border-top: 1px solid #dce8d2;
}

.frontend-site .product-share-kicker {
    margin-bottom: 0.7rem;
}

.frontend-site .product-share-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.55rem;
}

.frontend-site .product-share-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.7rem;
    height: 2.7rem;
    border: 1px solid #dce8d2;
    background: #fff;
    color: #264126;
    transition: background 0.18s ease, border-color 0.18s ease, color 0.18s ease;
}

.frontend-site .product-share-link:hover,
.frontend-site .product-share-link:focus-visible {
    background: #eef8e5;
    border-color: #b8d79a;
    color: #447c18;
}

.frontend-site .product-share-link.is-success {
    background: #eef8e5;
    border-color: #b8d79a;
    color: #447c18;
}

.frontend-site .product-share-link svg {
    width: 1.08rem;
    height: 1.08rem;
    fill: currentColor;
}

.frontend-site .product-share-feedback {
    min-height: 1.2rem;
    margin-top: 0.55rem;
    font-size: 0.82rem;
    color: #4b8f1d;
    opacity: 0;
    transition: opacity 0.18s ease;
}

.frontend-site .product-share-feedback.is-visible {
    opacity: 1;
}

.frontend-site .product-share-feedback.is-error {
    color: #a1542a;
}

.frontend-site .product-spec-wrap .catalog-kicker {
    border-radius: 0;
}

.frontend-site .spec-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.9rem;
}

.frontend-site .spec-item {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
    padding: 1rem;
    border-radius: 0;
    background: #f7fbf4;
    border: 1px solid #dfeada;
}

.frontend-site .spec-item strong {
    color: #203321;
}

.frontend-site .spec-item span {
    color: #647565;
}

.frontend-site .content-page-card {
    max-width: 980px;
    margin: 0 auto;
    padding: 2rem 2.1rem;
}

.frontend-site .section-block,
.frontend-site .page-top-block {
    margin-bottom: 1.6rem;
}

.frontend-site .accent-card {
    background: linear-gradient(180deg, #eff8e7 0%, #ffffff 100%);
}

.frontend-site .content-card,
.frontend-site .info-band-card {
    min-height: 100%;
}

.frontend-site .footer-dot {
    margin: 0 0.45rem;
    color: #90a58d;
}

.frontend-site .site-footer {
    background: #fff;
    border-top: 1px solid #dce8d2;
}

.frontend-site .site-footer-row {
    min-height: 72px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    font-size: 0.94rem;
}

.frontend-site .form-control,
.frontend-site .form-select {
    border-color: #d7e4ce;
}

.frontend-site .form-control:focus,
.frontend-site .form-select:focus {
    border-color: #89c95b;
    box-shadow: 0 0 0 0.2rem rgba(115, 185, 49, 0.12);
}

.frontend-site .btn-dark,
.frontend-site .btn.btn-dark {
    background: linear-gradient(180deg, #80c840 0%, #67ae2c 100%);
    border-color: #63a728;
}

.frontend-site .btn-outline-dark,
.frontend-site .btn.btn-outline-dark {
    color: #244025;
    border-color: #cfe0c3;
    background: #fff;
}

.frontend-site .btn-outline-dark:hover,
.frontend-site .btn.btn-outline-dark:hover {
    background: #f2f9ec;
    color: #1f341f;
    border-color: #cfe0c3;
}

.frontend-site .checkout-button-flat {
    border-radius: 0;
}

.frontend-site .checkout-card-logos {
    display: block;
    height: auto;
    max-width: min(100%, 340px);
    width: 100%;
}

.frontend-site .cart-page-flat .card-industrial,
.frontend-site .cart-page-flat .table-wrap,
.frontend-site .cart-page-flat .alert,
.frontend-site .cart-page-flat .form-control,
.frontend-site .cart-page-flat .btn,
.frontend-site .cart-page-flat .btn-sm {
    border-radius: 0 !important;
}

.frontend-site .cart-quantity-control {
    display: flex;
    align-items: stretch;
    min-width: 136px;
}

.frontend-site .cart-quantity-button {
    width: 42px;
    min-width: 42px;
    padding: 0;
    border: 1px solid #d7e4ce;
    background: #f7fbf3;
    color: #264025;
    font-size: 1.15rem;
    line-height: 1;
}

.frontend-site .cart-quantity-button:hover {
    background: #edf6e7;
}

.frontend-site .cart-quantity-input {
    min-width: 0;
    text-align: center;
    border-left: 0;
    border-right: 0;
}

.frontend-site .list-group-item {
    border-color: #e2eddc;
}

.frontend-site .site-toggle {
    display: none;
    margin-left: auto;
    width: 46px;
    height: 46px;
    border-radius: 12px;
    border: 1px solid #dbe7d2;
    background: #fff;
    color: #203121;
    padding: 0;
}

.frontend-site .site-toggle span {
    display: block;
    width: 18px;
    height: 2px;
    margin: 4px auto;
    background: #284128;
    border-radius: 999px;
}

.frontend-site .site-menu-shell {
    display: flex;
    align-items: center;
    gap: 1rem;
    flex: 1 1 auto;
}

@media (max-width: 1199.98px) {
    .frontend-site .catalog-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 991.98px) {
    .frontend-site .site-toggle {
        display: inline-flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
    }

    .frontend-site .site-menu-shell {
        display: none;
        position: absolute;
        top: calc(100% + 10px);
        left: 0;
        right: 0;
        background: #fff;
        border: 1px solid #dce8d2;
        border-radius: 18px;
        padding: 1rem;
        box-shadow: 0 22px 44px rgba(41, 77, 41, 0.12);
        z-index: 40;
        flex-direction: column;
        align-items: stretch;
    }

    .frontend-site .site-menu-shell.is-open {
        display: flex;
    }

    .frontend-site .site-header-row {
        position: relative;
    }

    .frontend-site .site-nav,
    .frontend-site .site-tools {
        width: 100%;
        flex-direction: column;
        align-items: stretch;
    }

    .frontend-site .nav-dropdown {
        position: static;
        opacity: 1;
        visibility: visible;
        transform: none;
        min-width: 100%;
        box-shadow: none;
        margin-top: 0.65rem;
    }

    .frontend-site .front-hero,
    .frontend-site .product-page-shell,
    .frontend-site .info-band-grid,
    .frontend-site .content-grid {
        grid-template-columns: 1fr;
    }

    .frontend-site .hero-controller-list,
    .frontend-site .spec-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 575.98px) {
    .frontend-site .cart-quantity-control {
        min-width: 124px;
    }

    .frontend-site .cart-quantity-button {
        width: 38px;
        min-width: 38px;
    }
}

@media (max-width: 767.98px) {
    .frontend-site .site-header-row {
        min-height: 74px;
    }

    .frontend-site .site-brand-mark {
        width: 48px;
        height: 48px;
    }

    .frontend-site .front-hero-copy,
    .frontend-site .front-hero-side,
    .frontend-site .product-main-card,
    .frontend-site .product-buy-card,
    .frontend-site .content-page-card {
        padding: 1.25rem;
    }

    .frontend-site .hero-meta-grid,
    .frontend-site .hero-controller-list,
    .frontend-site .catalog-grid,
    .frontend-site .content-grid,
    .frontend-site .info-band-grid,
    .frontend-site .spec-grid {
        grid-template-columns: 1fr;
    }

    .frontend-site .product-share-actions {
        gap: 0.45rem;
    }

    .frontend-site .hero-side-head,
    .frontend-site .section-heading-row,
    .frontend-site .site-footer-row,
    .frontend-site .product-main-header {
        flex-direction: column;
        align-items: flex-start;
    }
}

/* ===== Frontend refresh v5: manufacturer-style landing + language combo ===== */
.frontend-site {
    background: #f6faf3;
    color: #213126;
}

.frontend-site .site-header {
    background: rgba(255,255,255,0.98);
    border-bottom: 1px solid #d7e5cf;
    box-shadow: 0 10px 28px rgba(63, 93, 43, 0.08);
}

.frontend-site .site-header-row {
    min-height: 92px;
    gap: 1.5rem;
}

.frontend-site .site-menu-shell {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1.5rem;
    flex: 1 1 auto;
}

.frontend-site .site-nav {
    gap: 1.35rem;
    flex-wrap: nowrap;
}

.frontend-site .site-tools {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 0.55rem;
    flex-wrap: nowrap;
    white-space: nowrap;
}

.frontend-site .logout-inline {
    margin: 0;
}

.frontend-site .language-flag-switcher {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    flex: 0 0 auto;
}

.frontend-site .language-flag-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 42px;
    min-width: 42px;
    min-height: 40px;
    padding: 0;
    border-radius: 0;
    border: 1px solid #d8e4cf;
    background: #fff;
    transition: border-color 0.2s ease, background-color 0.2s ease, transform 0.2s ease;
}

.frontend-site .language-flag-link:hover {
    border-color: #a4cf7f;
    background: #f4faee;
    transform: translateY(-1px);
}

.frontend-site .language-flag-link.is-active {
    border-color: #6fb32f;
    background: #eef7e5;
    box-shadow: inset 0 0 0 1px rgba(111, 179, 47, 0.16);
}

.frontend-site .language-flag {
    display: block;
    width: 24px;
    height: 16px;
    border-radius: 0;
    border: 1px solid rgba(34, 54, 36, 0.12);
    overflow: hidden;
}

.frontend-site .language-flag--am {
    background: linear-gradient(180deg, #d90012 0 33.33%, #0033a0 33.33% 66.66%, #f2a800 66.66% 100%);
}

.frontend-site .language-flag--ru {
    background: linear-gradient(180deg, #ffffff 0 33.33%, #224c9a 33.33% 66.66%, #d52b1e 66.66% 100%);
}

.frontend-site .language-flag--en {
    background:
        linear-gradient(90deg, transparent 0 38%, #c8102e 38% 62%, transparent 62% 100%),
        linear-gradient(180deg, transparent 0 38%, #c8102e 38% 62%, transparent 62% 100%),
        #ffffff;
}

.frontend-site .site-tool-link {
    white-space: nowrap;
}

.frontend-site .manufacturer-landing-hero {
    position: relative;
    overflow: hidden;
    display: grid;
    grid-template-columns: minmax(0, 0.84fr) minmax(0, 1.16fr);
    align-items: start;
    gap: 1.05rem;
    padding: 1.05rem;
    margin-bottom: 1.45rem;
    border-radius: 28px;
    background:
        radial-gradient(circle at top right, rgba(136, 201, 53, 0.18), transparent 28%),
        linear-gradient(135deg, #1d2d1e 0%, #274228 45%, #345b24 100%);
    border: 1px solid rgba(95, 166, 36, 0.22);
    box-shadow: 0 20px 48px rgba(21, 38, 17, 0.20);
}

.frontend-site .manufacturer-landing-copy,
.frontend-site .manufacturer-landing-lineup {
    position: relative;
    z-index: 1;
}

.frontend-site .manufacturer-landing-copy {
    padding: 1.35rem 1.3rem 1.2rem;
}

.frontend-site .manufacturer-landing-hero .hero-kicker {
    color: rgba(255,255,255,0.62);
}

.frontend-site .manufacturer-landing-hero .hero-title,
.frontend-site .manufacturer-landing-hero .hero-text {
    color: #fff;
}

.frontend-site .manufacturer-landing-hero .hero-title {
    max-width: 10ch;
    font-size: clamp(1.9rem, 3vw, 3.15rem);
    line-height: 1.02;
    margin-bottom: 0.75rem;
}

.frontend-site .manufacturer-landing-hero .hero-text {
    max-width: 46ch;
    font-size: 0.98rem;
    line-height: 1.55;
    color: rgba(255,255,255,0.78);
}

.frontend-site .manufacturer-landing-hero .hero-meta-item {
    background: rgba(255,255,255,0.08);
    border-color: rgba(255,255,255,0.10);
}

.frontend-site .manufacturer-landing-hero .hero-meta-item span {
    color: rgba(255,255,255,0.60);
}

.frontend-site .manufacturer-landing-hero .hero-meta-item strong {
    color: #fff;
}

.frontend-site .manufacturer-landing-hero .action-outline {
    background: rgba(255,255,255,0.08);
    border-color: rgba(255,255,255,0.18);
    color: #fff;
}

.frontend-site .manufacturer-landing-hero .action-outline:hover {
    background: rgba(255,255,255,0.14);
    color: #fff;
}

.frontend-site .manufacturer-landing-lineup {
    border-radius: 22px;
    background: rgba(255,255,255,0.94);
    border: 1px solid rgba(215, 229, 207, 0.85);
    padding: 0.95rem;
}

.frontend-site .manufacturer-lineup-head {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1rem;
}

.frontend-site .manufacturer-lineup-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.8rem;
}

.frontend-site .manufacturer-lineup-card,
.frontend-site .manufacturer-strip-card,
.frontend-site .manufacturer-post-card,
.frontend-site .manufacturer-catalog-card {
    position: relative;
    overflow: hidden;
}

.frontend-site .manufacturer-lineup-card {
    display: flex;
    flex-direction: column;
    gap: 0.65rem;
    min-height: 0;
    padding: 0.95rem;
    border-radius: 18px;
    background: linear-gradient(180deg, #ffffff 0%, #f7fbf4 100%);
    border: 1px solid #dbe7d1;
}

.frontend-site .manufacturer-lineup-card::before,
.frontend-site .manufacturer-strip-card::before,
.frontend-site .manufacturer-post-card::before,
.frontend-site .manufacturer-catalog-card::before {
    content: '';
    position: absolute;
    inset: 0 auto auto 0;
    width: 100%;
    height: 4px;
    background: linear-gradient(90deg, #8bd145 0%, #5aa626 100%);
}

.frontend-site .manufacturer-lineup-top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
}

.frontend-site .manufacturer-lineup-card h3,
.frontend-site .manufacturer-strip-card h3,
.frontend-site .manufacturer-post-card h3 {
    margin: 0;
    color: #1f3320;
    font-weight: 700;
}

.frontend-site .manufacturer-lineup-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
}

.frontend-site .manufacturer-section-block {
    margin-bottom: 1.65rem;
}

.frontend-site .catalog-grid-wide {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.frontend-site .manufacturer-strip-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1rem;
    margin-bottom: 1.65rem;
}

.frontend-site .manufacturer-strip-card,
.frontend-site .manufacturer-post-card {
    display: flex;
    flex-direction: column;
    gap: 0.85rem;
    min-height: 100%;
    padding: 1.2rem;
    border-radius: 22px;
    background: #fff;
    border: 1px solid #dce8d2;
    box-shadow: 0 18px 36px rgba(66, 101, 55, 0.08);
}

.frontend-site .manufacturer-post-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.frontend-site .footer-links-row {
    display: flex;
    align-items: center;
    gap: 1rem;
    flex-wrap: wrap;
}

.frontend-site .footer-links-row a {
    color: #5a6f5a;
    text-decoration: none;
}

.frontend-site .footer-links-row a:hover {
    color: #3f7b18;
}

@media (max-width: 1199.98px) {
    .frontend-site .manufacturer-strip-grid,
    .frontend-site .catalog-grid-wide {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 991.98px) {
    .frontend-site .site-menu-shell {
        display: none;
        position: absolute;
        top: calc(100% + 10px);
        left: 0;
        right: 0;
        background: #fff;
        border: 1px solid #dce8d2;
        border-radius: 18px;
        padding: 1rem;
        box-shadow: 0 22px 44px rgba(41, 77, 41, 0.12);
        z-index: 40;
        flex-direction: column;
        align-items: stretch;
    }

    .frontend-site .site-menu-shell.is-open {
        display: flex;
    }

    .frontend-site .site-header-row {
        position: relative;
    }

    .frontend-site .site-nav,
    .frontend-site .site-tools {
        width: 100%;
        flex-direction: column;
        align-items: stretch;
        white-space: normal;
    }

    .frontend-site .manufacturer-landing-hero,
    .frontend-site .manufacturer-strip-grid,
    .frontend-site .manufacturer-post-grid {
        grid-template-columns: 1fr;
    }

    .frontend-site .manufacturer-lineup-grid,
    .frontend-site .catalog-grid-wide {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 767.98px) {
    .frontend-site .manufacturer-landing-hero {
        gap: 0.85rem;
        padding: 0.85rem;
    }

    .frontend-site .manufacturer-landing-copy,
    .frontend-site .manufacturer-landing-lineup {
        padding: 0.9rem;
    }

    .frontend-site .manufacturer-landing-hero .hero-title {
        max-width: none;
        font-size: clamp(1.75rem, 8vw, 2.45rem);
    }

    .frontend-site .manufacturer-lineup-head,
    .frontend-site .footer-links-row {
        flex-direction: column;
        align-items: flex-start;
    }

    .frontend-site .manufacturer-lineup-grid,
    .frontend-site .catalog-grid-wide {
        grid-template-columns: 1fr;
    }

    .frontend-site .language-flag-switcher {
        width: 100%;
        justify-content: flex-start;
    }
}

/* ===== v7 media management + slider ===== */
.frontend-site .site-logo-image {
    display: block;
    width: auto;
    height: 58px;
    max-width: 320px;
    object-fit: contain;
}

.homepage-hero-card {
    margin-bottom: 1.8rem;
}

.homepage-hero-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.02fr) minmax(0, 0.98fr);
    gap: 1.25rem;
    align-items: stretch;
    background: linear-gradient(180deg, #ffffff 0%, #f6faf2 100%);
    border: 1px solid #dbe7d2;
    border-radius: 26px;
    box-shadow: 0 18px 36px rgba(66, 101, 55, 0.08);
    overflow: hidden;
}

.homepage-hero-copy {
    padding: 2.6rem 2.5rem;
}

.homepage-hero-title {
    color: #203121;
    font-weight: 800;
    line-height: 1.08;
    font-size: clamp(2.25rem, 4.2vw, 4rem);
    max-width: 12ch;
    margin-bottom: 1rem;
}

.homepage-hero-text {
    color: #667566;
    max-width: 54ch;
    font-size: 1.02rem;
    line-height: 1.72;
    margin-bottom: 1.4rem;
}

.homepage-hero-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    margin-bottom: 1.2rem;
}

.homepage-hero-features {
    display: flex;
    flex-wrap: wrap;
    gap: 0.85rem;
    color: #5e755e;
    font-weight: 600;
}

.homepage-hero-features span {
    display: inline-flex;
    align-items: center;
    min-height: 36px;
    padding: 0 0.9rem;
    border-radius: 999px;
    background: #f3f8ee;
    border: 1px solid #dce8d2;
}

.homepage-hero-media {
    position: relative;
    padding: 1.2rem 1.2rem 0.9rem;
    background: radial-gradient(circle at top right, rgba(111, 176, 48, 0.15), transparent 28%), linear-gradient(180deg, #fcfffa 0%, #eff7e7 100%);
}

.hero-slider {
    position: relative;
    min-height: 100%;
}

.hero-slide {
    display: none;
    min-height: 100%;
    align-items: center;
    justify-content: center;
}

.hero-slide.is-active {
    display: flex;
}

.hero-slide img {
    width: 100%;
    max-height: 440px;
    object-fit: contain;
    display: block;
}

.hero-slider-dots {
    display: flex;
    justify-content: center;
    gap: 0.55rem;
    padding: 0.85rem 0 0.1rem;
}

.hero-slider-dot {
    width: 11px;
    height: 11px;
    border-radius: 999px;
    border: 0;
    background: #c7d7ba;
}

.hero-slider-dot.is-active {
    background: #69ae2f;
}

.catalog-grid-home,
.catalog-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
}

.product-photo-card {
    display: flex;
    flex-direction: column;
    gap: 0.85rem;
    min-height: 100%;
    padding: 0;
    overflow: hidden;
}

.product-card-photo-wrap {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 220px;
    padding: 1.1rem;
    background: #ffffff;
    border-bottom: 1px solid #e3eddc;
}

.product-card-photo {
    width: 100%;
    max-height: 180px;
    object-fit: contain;
}

.product-photo-card .controller-card-top,
.product-photo-card h2,
.product-photo-card h3,
.product-photo-card p,
.product-photo-card .d-flex,
.product-photo-card .controller-card-footer {
    padding-left: 1.2rem;
    padding-right: 1.2rem;
}

.product-photo-card .controller-card-top {
    padding-top: 0.3rem;
}

.product-photo-card .controller-card-footer {
    padding-bottom: 1.2rem;
}

.homepage-benefits-row {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.85rem;
    margin-bottom: 1.6rem;
}

.benefit-item,
.homepage-about-card {
    background: #fff;
    border: 1px solid #dce8d2;
    border-radius: 22px;
    box-shadow: 0 18px 36px rgba(66, 101, 55, 0.08);
}

.benefit-item {
    min-height: 74px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1rem;
    color: #334834;
    font-weight: 700;
    text-align: center;
}

.homepage-about-card {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 280px;
    gap: 1rem;
    padding: 1.5rem;
}

.homepage-about-media {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 0.85rem;
    padding: 1rem;
    border-radius: 18px;
    background: linear-gradient(180deg, #fbfef9 0%, #f1f8ec 100%);
}

.homepage-about-media-rect {
    padding: 0;
    background: transparent;
    border: 0;
    overflow: hidden;
    line-height: 0;
}

.homepage-about-photo {
    display: block;
    width: 100%;
    height: auto;
    max-width: 100%;
}

.about-logo-preview {
    max-width: 100%;
    max-height: 70px;
    object-fit: contain;
}

.about-media-note {
    color: #688069;
    font-weight: 700;
}

.product-main-image-wrap {
    min-height: 260px;
    background: #ffffff;
    border: 1px solid #e0ead8;
    padding: 1rem;
}

.product-gallery-shell {
    width: 100%;
    display: grid;
    gap: 0.9rem;
}

.product-gallery-stage {
    position: relative;
    overflow: hidden;
    background: #ffffff;
}

.product-gallery-slide {
    --zoom-x: 50%;
    --zoom-y: 50%;
    width: 100%;
    min-height: 420px;
    border: 0;
    background: transparent;
    padding: 1rem;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: zoom-in;
    overflow: hidden;
}

.product-gallery-slide[hidden],
.product-gallery-lightbox-slide[hidden],
.product-gallery-lightbox[hidden] {
    display: none !important;
}

.product-main-image {
    width: 100%;
    max-height: 390px;
    object-fit: contain;
    transform-origin: var(--zoom-x) var(--zoom-y);
    transition: transform 0.18s ease;
}

@media (hover: hover) and (pointer: fine) {
    .product-gallery-slide:hover .product-main-image {
        transform: scale(1.65);
    }
}

.product-gallery-zoom {
    position: absolute;
    right: 14px;
    bottom: 14px;
    z-index: 3;
    border: 1px solid #bdd6ab;
    background: rgba(255, 255, 255, 0.96);
    color: #4d7f23;
    min-height: 40px;
    padding: 0 0.9rem;
    font-size: 0.86rem;
    font-weight: 700;
}

.product-gallery-arrow {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 3;
    width: 46px;
    height: 46px;
    border: 1px solid #bdd6ab;
    background: rgba(255, 255, 255, 0.96);
    color: #4d7f23;
    font-size: 24px;
    line-height: 1;
    font-weight: 700;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    box-shadow: none;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition:
        background 0.2s ease,
        color 0.2s ease,
        border-color 0.2s ease,
        opacity 0.2s ease,
        visibility 0.2s ease;
}

.product-gallery-shell:hover .product-gallery-arrow {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
}

.product-gallery-arrow:hover,
.product-gallery-zoom:hover {
    background: #6fb32f;
    border-color: #6fb32f;
    color: #ffffff;
}

.product-gallery-arrow-prev {
    left: 14px;
}

.product-gallery-arrow-next {
    right: 14px;
}

.product-gallery-thumbs {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(84px, 1fr));
    gap: 0.75rem;
}

.product-gallery-thumb {
    border: 1px solid #dce8d2;
    background: #ffffff;
    padding: 0.45rem;
    min-height: 84px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.product-gallery-thumb.is-active {
    border-color: #6fb32f;
    background: #ffffff;
    box-shadow: inset 0 0 0 1px #6fb32f;
}

.product-gallery-thumb img {
    width: 100%;
    height: 68px;
    object-fit: contain;
}

.product-gallery-lightbox {
    position: fixed;
    inset: 0;
    z-index: 1200;
}

.product-gallery-lightbox-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(18, 24, 18, 0.86);
}

.product-gallery-lightbox-dialog {
    position: relative;
    z-index: 1;
    width: min(92vw, 1280px);
    height: min(88vh, 900px);
    margin: 6vh auto;
    background: rgba(255, 255, 255, 0.04);
    display: flex;
    align-items: center;
    justify-content: center;
}

.product-gallery-lightbox-track {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
}

.product-gallery-lightbox-slide {
    width: 100%;
    height: 100%;
    margin: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 3rem;
}

.product-gallery-lightbox-slide img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
}

.product-gallery-lightbox-close {
    position: absolute;
    top: 12px;
    right: 12px;
    z-index: 2;
    width: 44px;
    height: 44px;
    border: 1px solid rgba(255, 255, 255, 0.4);
    background: rgba(24, 32, 24, 0.7);
    color: #ffffff;
    font-size: 30px;
    line-height: 1;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.product-gallery-arrow.is-lightbox {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    background: rgba(24, 32, 24, 0.8);
    color: #ffffff;
    border-color: rgba(255, 255, 255, 0.32);
}

body.product-gallery-lightbox-open {
    overflow: hidden;
}

@media (max-width: 1199.98px) {
    .catalog-grid-home,
    .catalog-grid,
    .homepage-benefits-row {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 991.98px) {
    .frontend-site .site-logo-image {
        height: 52px;
        max-width: 250px;
    }

    .homepage-hero-grid,
    .homepage-about-card {
        grid-template-columns: 1fr;
    }

    .product-gallery-slide {
        min-height: 340px;
    }

    .product-main-image {
        max-height: 310px;
    }
}

@media (max-width: 767.98px) {
    .catalog-grid-home,
    .catalog-grid,
    .homepage-benefits-row {
        grid-template-columns: 1fr;
    }

    .homepage-hero-copy {
        padding: 1.5rem;
    }

    .homepage-hero-title {
        max-width: none;
        font-size: clamp(1.95rem, 8vw, 2.8rem);
    }

    .frontend-site .site-logo-image {
        height: 46px;
        max-width: 210px;
    }

    .product-gallery-arrow {
        width: 40px;
        height: 40px;
        font-size: 20px;
        opacity: 1;
        visibility: visible;
        pointer-events: auto;
    }

    .product-gallery-arrow-prev {
        left: 8px;
    }

    .product-gallery-arrow-next {
        right: 8px;
    }

    .product-gallery-slide {
        min-height: 260px;
        padding: 0.75rem;
    }

    .product-main-image {
        max-height: 230px;
    }

    .product-gallery-thumbs {
        grid-template-columns: repeat(auto-fit, minmax(68px, 1fr));
        gap: 0.5rem;
    }

    .product-gallery-thumb {
        min-height: 68px;
    }

    .product-gallery-thumb img {
        height: 54px;
    }

    .product-gallery-lightbox-dialog {
        width: 100vw;
        height: 100vh;
        margin: 0;
    }

    .product-gallery-lightbox-slide {
        padding: 1.5rem;
    }
}

/* ===== v8 flat public styling + multilingual content management support ===== */
.frontend-site .site-logo-image {
    height: 60px;
    max-width: 260px;
}

.frontend-site .site-tools,
.frontend-site .site-nav {
    white-space: nowrap;
}

.frontend-site .language-combo,
.frontend-site .site-tool-link,
.frontend-site .action-green,
.frontend-site .action-outline,
.frontend-site button,
.frontend-site .form-control,
.frontend-site .form-select,
.frontend-site .benefit-item,
.frontend-site .badge-stock,
.frontend-site .spec-chip,
.frontend-site .homepage-about-card,
.frontend-site .controller-card,
.frontend-site .content-page-card,
.frontend-site .product-main-card,
.frontend-site .product-buy-card,
.frontend-site .product-main-image-wrap,
.frontend-site .homepage-hero-media,
.frontend-site .hero-slide img,
.frontend-site .footer-social-link,
.frontend-site .footer-icon-circle {
    border-radius: 0 !important;
}

.frontend-site .language-combo,
.frontend-site .site-tool-link,
.frontend-site .action-green,
.frontend-site .action-outline {
    min-height: 40px;
    box-shadow: none !important;
}

.frontend-site .site-tool-link.is-solid,
.frontend-site .action-green {
    background: #6fb32f;
    border-color: #6fb32f;
}

.frontend-site .site-tool-link.is-outline,
.frontend-site .action-outline,
.frontend-site .site-tool-link,
.frontend-site .language-combo {
    background: #fff;
    border-color: #bdd6ab;
}

.frontend-site .homepage-hero-card,
.frontend-site .homepage-hero-grid {
    background: transparent;
    border: 0;
    box-shadow: none;
    border-radius: 0;
}

.frontend-site .homepage-hero-grid-plain {
    display: grid;
    grid-template-columns: minmax(0, 0.92fr) minmax(0, 1.08fr);
    gap: 1.4rem;
    align-items: center;
    margin-bottom: 2rem;
}

.frontend-site .homepage-hero-copy-plain {
    padding: 0.4rem 0;
}

.frontend-site .homepage-hero-title {
    max-width: 11ch;
}

.frontend-site .homepage-hero-slider-only {
    padding: 0;
    background: transparent;
    border: 0;
    box-shadow: none;
}

.frontend-site .hero-slider {
    min-height: 460px;
    background: linear-gradient(180deg, #fbfef9 0%, #f4f9ef 100%);
}

.frontend-site .hero-slide {
    min-height: 460px;
}

.frontend-site .hero-slide img {
    width: 100%;
    max-height: 460px;
    object-fit: contain;
    background: linear-gradient(180deg, #fbfef9 0%, #f1f7eb 100%);
}

.frontend-site .hero-slider-dots {
    padding-top: 0.6rem;
}

.frontend-site .hero-slider-dot {
    width: 10px;
    height: 10px;
    border-radius: 999px !important;
}

.frontend-site .controller-card,
.frontend-site .content-page-card,
.frontend-site .product-main-card,
.frontend-site .product-buy-card,
.frontend-site .homepage-about-card,
.frontend-site .benefit-item {
    border: 1px solid #dce8d2;
    box-shadow: none;
}

.frontend-site .controller-card::before,
.frontend-site .content-page-card::before,
.frontend-site .product-main-card::before,
.frontend-site .product-buy-card::before,
.frontend-site .homepage-about-card::before,
.frontend-site .benefit-item::before {
    display: none;
}

.frontend-site .flat-card {
    border-radius: 0 !important;
}

.frontend-site .product-card-linkarea {
    display: block;
    color: inherit;
    text-decoration: none;
}

.frontend-site .product-card-linkarea:hover h2,
.frontend-site .product-card-linkarea:hover h3 {
    color: #4b8f1d;
}

.frontend-site .product-card-discount-note {
    margin-top: 0.45rem;
    color: #4b8f1d;
    font-size: 0.9rem;
    font-weight: 700;
    line-height: 1.45;
}

.frontend-site .px-card {
    padding-left: 1.2rem;
    padding-right: 1.2rem;
}

.frontend-site .product-photo-card .controller-card-footer {
    padding: 0 1.2rem 1.2rem;
}

.frontend-site .product-card-photo-wrap {
    position: relative;
    overflow: hidden;
    min-height: 230px;
    background: #ffffff;
}

.frontend-site .product-sticker-badge {
    position: absolute;
    top: 12px;
    left: 12px;
    z-index: 2;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 32px;
    padding: 0 0.8rem;
    border: 1px solid transparent;
    font-size: 0.74rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.frontend-site .product-sticker-badge.is-new {
    background: #eef8e5;
    border-color: #b8d79a;
    color: #447c18;
}

.frontend-site .product-sticker-badge.is-bestseller {
    background: #fff4db;
    border-color: #e2c67a;
    color: #8a5c00;
}

.frontend-site .product-sticker-inline {
    position: static;
}

.frontend-site .homepage-benefits-row {
    gap: 0;
    margin-bottom: 1.4rem;
    border-top: 1px solid #dce8d2;
    border-bottom: 1px solid #dce8d2;
}

.frontend-site .benefit-item {
    border: 0;
    border-right: 1px solid #dce8d2;
    min-height: 76px;
    background: transparent;
}

.frontend-site .benefit-item:last-child {
    border-right: 0;
}

.frontend-site .homepage-about-card {
    grid-template-columns: minmax(0, 1fr) 420px;
    padding: 1.25rem;
}

.frontend-site .homepage-about-copy,
.frontend-site .homepage-about-media,
.frontend-site .homepage-about-media-rect {
    min-width: 0;
}

.frontend-site .homepage-about-media {
    background: transparent;
    border: 0;
    border-radius: 0;
    padding: 0;
    align-self: stretch;
    overflow: hidden;
}

.frontend-site .homepage-about-media-rect {
    background: transparent;
    border: 0;
    padding: 0;
}

.frontend-site .homepage-about-photo {
    display: block;
    width: 100%;
    height: auto;
    max-width: 100%;
}

.frontend-site .content-page-card,
.frontend-site .product-main-card,
.frontend-site .product-buy-card {
    padding: 1.4rem;
}

.frontend-site .site-footer-rich {
    background: #fff;
    border-top: 1px solid #dce8d2;
}

.frontend-site .footer-contact-row {
    min-height: 72px;
    display: grid;
    grid-template-columns: repeat(4, max-content) 1fr;
    gap: 1rem;
    align-items: center;
}

.frontend-site .footer-contact-item {
    display: inline-flex;
    align-items: center;
    gap: 0.7rem;
    color: #455b45;
    font-weight: 500;
}

.frontend-site .footer-icon-circle,
.frontend-site .footer-social-link {
    width: 34px;
    height: 34px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid #bdd6ab;
    background: #fff;
}

.frontend-site .footer-icon-circle svg,
.frontend-site .footer-social-link svg {
    width: 18px;
    height: 18px;
    fill: currentColor;
}

.frontend-site .footer-socials {
    margin-left: auto;
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
}

.frontend-site .footer-legal-links {
    display: flex;
    align-items: center;
    gap: 1.25rem;
    padding: 0 0 1rem;
}

.frontend-site .footer-legal-links a {
    color: #455b45;
    font-size: 0.95rem;
    font-weight: 700;
    text-decoration: none;
}

.frontend-site .footer-legal-links a:hover {
    color: #2e512f;
}

.frontend-site .footer-copyright {
    color: #7a8878;
    font-size: 0.85rem;
    letter-spacing: 0.03em;
    padding: 0 0 1.15rem;
}

.frontend-site .footer-yandex-iks {
    display: inline-flex;
    align-items: center;
}

.frontend-site .footer-yandex-iks img {
    display: block;
}

.frontend-site .footer-social-link {
    color: #fff;
    border-color: transparent;
}

.frontend-site .footer-social-link.facebook { background: #3b5998; }
.frontend-site .footer-social-link.instagram { background: #d9467a; }
.frontend-site .footer-social-link.whatsapp { background: #25d366; }
.frontend-site .footer-social-link.telegram { background: #2aabee; }

@media (max-width: 991.98px) {
    .frontend-site .homepage-hero-grid-plain,
    .frontend-site .homepage-about-card {
        grid-template-columns: 1fr;
    }

    .frontend-site .homepage-about-card {
        gap: 1rem;
    }

    .frontend-site .homepage-about-media,
    .frontend-site .homepage-about-media-rect,
    .frontend-site .homepage-about-photo {
        width: 100%;
        max-width: 100%;
    }

    .frontend-site .footer-contact-row {
        grid-template-columns: 1fr;
        padding: 1rem 0;
    }

    .frontend-site .footer-socials {
        margin-left: 0;
    }

    .frontend-site .footer-legal-links {
        flex-direction: column;
        align-items: flex-start;
        gap: 0.5rem;
        padding-top: 0.25rem;
    }
}

@media (max-width: 767.98px) {
    .frontend-site .homepage-benefits-row,
    .frontend-site .catalog-grid,
    .frontend-site .catalog-grid-home {
        grid-template-columns: 1fr;
    }

    .frontend-site .benefit-item {
        border-right: 0;
        border-bottom: 1px solid #dce8d2;
    }

    .frontend-site .benefit-item:last-child {
        border-bottom: 0;
    }

    .frontend-site .hero-slider,
    .frontend-site .hero-slide {
        min-height: 300px;
    }

    .frontend-site .hero-slide img {
        max-height: 300px;
    }
}

/* v9 home hero: slider only, no left text block */
.frontend-site .slider-only-block {
    margin-bottom: 2rem;
}

.frontend-site .homepage-slider-only-wrap {
    width: 100%;
}

.frontend-site .slider-only-block .homepage-hero-slider-only {
    width: 100%;
}

.frontend-site .slider-only-block .hero-slider {
    min-height: 500px;
}

.frontend-site .slider-only-block .hero-slide {
    min-height: 500px;
}

.frontend-site .slider-only-block .hero-slide img {
    width: 100%;
    max-height: 500px;
    object-fit: contain;
}

@media (max-width: 991.98px) {
    .frontend-site .slider-only-block .hero-slider,
    .frontend-site .slider-only-block .hero-slide {
        min-height: 320px;
    }

    .frontend-site .slider-only-block .hero-slide img {
        max-height: 320px;
    }
}

/* v10 slider arrows + synced dots */
.frontend-site .hero-slider-shell {
    position: relative;
}

.frontend-site .hero-slider-arrow {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 3;
    width: 46px;
    height: 46px;
    border: 1px solid #bdd6ab;
    background: rgba(255, 255, 255, 0.96);
    color: #4d7f23;
    font-size: 24px;
    line-height: 1;
    font-weight: 700;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    box-shadow: none;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition:
        background 0.2s ease,
        color 0.2s ease,
        border-color 0.2s ease,
        opacity 0.2s ease,
        visibility 0.2s ease;
}

.frontend-site .hero-slider-shell:hover .hero-slider-arrow {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
}

.frontend-site .hero-slider-arrow:hover {
    background: #6fb32f;
    border-color: #6fb32f;
    color: #ffffff;
}

.frontend-site .hero-slider-arrow-prev {
    left: 14px;
}

.frontend-site .hero-slider-arrow-next {
    right: 14px;
}
@media (max-width: 767.98px) {
    .frontend-site .hero-slider-arrow {
        width: 40px;
        height: 40px;
        font-size: 20px;
        opacity: 1;
        visibility: visible;
        pointer-events: auto;
    }

    .frontend-site .hero-slider-arrow-prev {
        left: 8px;
    }

    .frontend-site .hero-slider-arrow-next {
        right: 8px;
    }
}


/* v11 breadcrumbs */
.frontend-site .page-breadcrumb-wrap {
    margin-bottom: 1rem;
}

.frontend-site .site-breadcrumbs {
    border: 1px solid #dce8d2;
    background: #ffffff;
    padding: 0.8rem 1rem;
}

.frontend-site .site-breadcrumb-list {
    list-style: none;
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem 0;
    margin: 0;
    padding: 0;
}

.frontend-site .site-breadcrumb-item {
    display: inline-flex;
    align-items: center;
    color: #607660;
    font-size: 0.92rem;
    line-height: 1.4;
}

.frontend-site .site-breadcrumb-item + .site-breadcrumb-item::before {
    content: '/';
    color: #94aa85;
    margin: 0 0.55rem;
}

.frontend-site .site-breadcrumb-item a {
    color: #4b8f1d;
    text-decoration: none;
}

.frontend-site .site-breadcrumb-item a:hover {
    text-decoration: underline;
}

.frontend-site .site-breadcrumb-current {
    color: #2d3e2d;
    font-weight: 700;
}

@media (max-width: 767.98px) {
    .frontend-site .page-breadcrumb-wrap {
        margin-bottom: 0.85rem;
    }

    .frontend-site .site-breadcrumbs {
        padding: 0.7rem 0.85rem;
    }

    .frontend-site .site-breadcrumb-item {
        font-size: 0.88rem;
    }
}


.frontend-site .homepage-benefits-row-target .benefit-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 30px;
    min-width: 30px;
    height: 30px;
    line-height: 1;
    margin-right: 10px;
    flex: 0 0 30px;
}

.frontend-site .homepage-benefits-row-target .benefit-icon img {
    display: block;
    width: 26px;
    height: 26px;
    object-fit: contain;
}

.frontend-site .homepage-benefits-row-target .benefit-item {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0;
}


/* ===== Safari mobile menu bottom-safe fix ===== */
@media (max-width: 991.98px) {
    .frontend-site .site-header,
    .frontend-site .site-header-row {
        overflow: visible;
    }

    .frontend-site .site-menu-shell {
        max-height: calc(100dvh - 96px);
        overflow-y: auto;
        -webkit-overflow-scrolling: touch;
        overscroll-behavior: contain;
        padding-bottom: calc(20px + env(safe-area-inset-bottom));
    }

    .frontend-site .site-nav,
    .frontend-site .site-tools {
        min-width: 0;
    }

    .frontend-site .site-tools {
        padding-bottom: calc(12px + env(safe-area-inset-bottom));
    }

    .frontend-site .site-tools > *:last-child,
    .frontend-site .site-nav > *:last-child {
        margin-bottom: calc(8px + env(safe-area-inset-bottom));
    }
}

.frontend-site .catalog-carousel-shell {
    position: relative;
}

.frontend-site .catalog-carousel-track {
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: minmax(280px, calc((100% - 2rem) / 3));
    gap: 1rem;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    padding-bottom: 0.5rem;
    scrollbar-width: thin;
}

.frontend-site .catalog-carousel-card {
    scroll-snap-align: start;
}

.frontend-site .catalog-carousel-arrow {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 2;
    width: 42px;
    height: 42px;
    border: 1px solid #bdd6ab;
    background: rgba(255, 255, 255, 0.96);
    color: #4d7f23;
    font-size: 24px;
    font-weight: 700;
    line-height: 1;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
}

.frontend-site .catalog-carousel-arrow:hover {
    background: #6fb32f;
    border-color: #6fb32f;
    color: #ffffff;
}

.frontend-site .catalog-carousel-arrow-prev {
    left: -18px;
}

.frontend-site .catalog-carousel-arrow-next {
    right: -18px;
}

.frontend-site .catalog-page-layout {
    display: grid;
    grid-template-columns: minmax(240px, 280px) minmax(0, 1fr);
    gap: 1.25rem;
    align-items: start;
}

.frontend-site .catalog-sidebar-card {
    position: sticky;
    top: 1.25rem;
}

.frontend-site .catalog-tree-wrap {
    display: grid;
    gap: 0.75rem;
}

.frontend-site .catalog-tree-root,
.frontend-site .catalog-tree-list a {
    display: inline-flex;
    width: 100%;
    text-decoration: none;
    color: #334a34;
    border: 1px solid #dce8d2;
    background: #ffffff;
    padding: 0.7rem 0.9rem;
    transition: border-color 0.2s ease, background 0.2s ease, color 0.2s ease;
}

.frontend-site .catalog-tree-root:hover,
.frontend-site .catalog-tree-root.is-active,
.frontend-site .catalog-tree-list a:hover,
.frontend-site .catalog-tree-list a.is-active {
    background: #eef8e5;
    border-color: #cde5b6;
    color: #1d2b1f;
}

.frontend-site .catalog-tree-list {
    list-style: none;
    margin: 0;
    padding: 0 0 0 0.9rem;
    display: grid;
    gap: 0.55rem;
}

.frontend-site .catalog-tree-list li {
    display: grid;
    gap: 0.55rem;
}

.frontend-site .product-main-copy > *:first-child,
.frontend-site .content-page-body > *:first-child {
    margin-top: 0;
}

.frontend-site .product-main-copy > *:last-child,
.frontend-site .content-page-body > *:last-child {
    margin-bottom: 0;
}

.frontend-site .product-main-copy img,
.frontend-site .content-page-body img,
.frontend-site .product-main-copy iframe,
.frontend-site .content-page-body iframe {
    max-width: 100%;
}

@media (max-width: 1199.98px) {
    .frontend-site .catalog-carousel-track {
        grid-auto-columns: minmax(280px, calc((100% - 1rem) / 2));
    }
}

@media (max-width: 991.98px) {
    .frontend-site .catalog-page-layout {
        grid-template-columns: 1fr;
    }

    .frontend-site .catalog-sidebar-card {
        position: static;
    }

    .frontend-site .catalog-carousel-arrow-prev {
        left: 8px;
    }

    .frontend-site .catalog-carousel-arrow-next {
        right: 8px;
    }
}

@media (max-width: 767.98px) {
    .frontend-site .catalog-carousel-track {
        grid-auto-columns: 88%;
        padding-left: 0.15rem;
        padding-right: 0.15rem;
    }

    .frontend-site .catalog-carousel-arrow {
        width: 38px;
        height: 38px;
        font-size: 20px;
    }
}

.frontend-site .account-menu {
    position: relative;
}

.frontend-site .account-menu::after {
    content: '';
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    height: 0.85rem;
}

.frontend-site .account-menu-trigger::after {
    content: '▾';
    margin-left: 0.45rem;
    font-size: 0.72rem;
}

.frontend-site .account-menu-dropdown {
    position: absolute;
    top: calc(100% + 0.25rem);
    right: 0;
    min-width: 220px;
    padding: 0.45rem;
    border: 1px solid #d7e6cc;
    border-radius: 18px;
    background: #fff;
    box-shadow: 0 18px 32px rgba(44, 76, 33, 0.12);
    display: none;
    z-index: 30;
}

.frontend-site .account-menu:hover .account-menu-dropdown,
.frontend-site .account-menu:focus-within .account-menu-dropdown {
    display: grid;
    gap: 0.2rem;
}

.frontend-site .account-menu-dropdown a {
    display: block;
    padding: 0.7rem 0.85rem;
    border-radius: 12px;
    color: #223624;
    text-decoration: none;
    font-weight: 600;
}

.frontend-site .account-menu-dropdown a:hover {
    background: #f4faee;
    color: #1f341f;
}

.frontend-site .account-shell {
    display: grid;
    grid-template-columns: minmax(240px, 280px) minmax(0, 1fr);
    gap: 1.25rem;
}

.frontend-site .account-sidebar,
.frontend-site .account-content {
    min-width: 0;
}

.frontend-site .account-sidebar {
    padding: 1.35rem;
    align-self: start;
}

.frontend-site .account-side-nav {
    display: grid;
    gap: 0.35rem;
}

.frontend-site .account-side-nav a {
    display: block;
    padding: 0.82rem 0.95rem;
    border-radius: 14px;
    color: #274128;
    text-decoration: none;
    font-weight: 700;
    background: #f8fcf4;
    border: 1px solid transparent;
}

.frontend-site .account-side-nav a:hover,
.frontend-site .account-side-nav a.is-active {
    background: #eef8e5;
    border-color: #cfe0c3;
    color: #1d321f;
}

.frontend-site .account-payment-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 32px;
    padding: 0 0.8rem;
    border-radius: 999px;
    font-weight: 700;
    font-size: 0.82rem;
}

.frontend-site .account-payment-badge.is-paid {
    background: #e7f5db;
    color: #2e6d10;
}

.frontend-site .account-payment-badge.is-unpaid {
    background: #fff4d8;
    color: #8b5a00;
}

.frontend-site .account-payment-card {
    overflow: hidden;
}

.frontend-site .account-payment-hero {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(190px, auto);
    gap: 1rem;
    align-items: start;
    padding-bottom: 1.25rem;
    margin-bottom: 1.25rem;
    border-bottom: 1px solid #dce8d2;
}

.frontend-site .account-payment-total {
    padding: 1rem 1.15rem;
    min-width: 190px;
    background: linear-gradient(180deg, #f8fcf4 0%, #eef8e6 100%);
    border: 1px solid #cfe0c3;
    text-align: right;
}

.frontend-site .account-payment-total-value {
    color: #1f341f;
    font-size: clamp(1.25rem, 2vw, 1.65rem);
    font-weight: 800;
    line-height: 1.15;
}

.frontend-site .account-payment-summary .flat-card,
.frontend-site .account-payment-action {
    border: 1px solid #dce8d2;
    background: #fff;
}

.frontend-site .account-payment-status-card {
    display: flex;
    flex-direction: column;
}

.frontend-site .account-payment-status-card .account-payment-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 34px;
    padding: 0 0.85rem;
    border: 1px solid transparent;
    font-size: 0.82rem;
    font-weight: 800;
}

.frontend-site .account-payment-status-card .account-payment-badge.is-pending {
    background: #fff4d8;
    border-color: #ead292;
    color: #8b5a00;
}

.frontend-site .account-payment-status-card .account-payment-badge.is-failed {
    background: #fde2e2;
    border-color: #f2b6b6;
    color: #9b1c1c;
}

.frontend-site .account-payment-status-card .account-payment-badge.is-refunded {
    background: #e7f0ff;
    border-color: #b9d0f5;
    color: #1d4e89;
}

.frontend-site .account-payment-reference {
    display: inline-block;
    max-width: 100%;
    word-break: break-word;
}

.frontend-site .account-payment-action {
    background: linear-gradient(180deg, #ffffff 0%, #f8fcf4 100%);
    border-color: #cfe0c3;
}

.frontend-site .account-payment-submit {
    min-width: min(100%, 240px);
}

.frontend-site .account-payment-actions {
    padding-top: 0.25rem;
}

@media (max-width: 991.98px) {
    .frontend-site .account-shell {
        grid-template-columns: 1fr;
    }

    .frontend-site .account-menu-dropdown {
        right: auto;
        left: 0;
        min-width: min(260px, calc(100vw - 40px));
    }

    .frontend-site .account-payment-hero {
        grid-template-columns: 1fr;
    }

    .frontend-site .account-payment-total {
        text-align: left;
    }
}

@media (max-width: 575.98px) {
    .frontend-site .account-payment-actions,
    .frontend-site .account-payment-actions .action-outline,
    .frontend-site .account-payment-actions form,
    .frontend-site .account-payment-actions button,
    .frontend-site .account-payment-submit {
        width: 100%;
    }
}

/* v12 header stability + catalog card fixes */
.frontend-site .site-menu-shell,
.frontend-site .site-nav,
.frontend-site .site-tools,
.frontend-site .site-nav > *,
.frontend-site .site-tools > * {
    min-width: 0;
}

.frontend-site .site-menu-shell {
    gap: 0.75rem;
}

.frontend-site .site-nav {
    gap: clamp(0.7rem, 0.9vw, 1.15rem);
}

.frontend-site .site-nav > a,
.frontend-site .nav-link-main {
    font-size: 0.9rem;
}

.frontend-site .site-tool-link,
.frontend-site .language-combo {
    padding-left: 0.75rem;
    padding-right: 0.75rem;
    font-size: 0.88rem;
}

.frontend-site .account-menu,
.frontend-site .logout-inline {
    min-width: 0;
}

.frontend-site .account-menu-trigger {
    max-width: clamp(8.5rem, 14vw, 12rem);
    overflow: hidden;
    text-overflow: ellipsis;
}

.frontend-site .catalog-page-content .catalog-grid {
    grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
}

.frontend-site .product-photo-card .controller-card-top {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.55rem 0.75rem;
    padding-top: 0.3rem;
}

.frontend-site .product-photo-card .badge-stock {
    max-width: 100%;
}

.frontend-site .product-photo-card .price-tag {
    margin-left: auto;
    white-space: nowrap;
    line-height: 1;
}

.frontend-site .product-photo-card h2,
.frontend-site .product-photo-card h3 {
    font-size: 1.18rem;
    line-height: 1.18;
    min-height: 0;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.frontend-site .product-photo-card p {
    font-size: 0.94rem;
    line-height: 1.55;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.frontend-site .product-photo-card .spec-chip {
    max-width: 100%;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.frontend-site .catalog-carousel-arrow {
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition:
        background 0.2s ease,
        color 0.2s ease,
        border-color 0.2s ease,
        opacity 0.2s ease,
        visibility 0.2s ease;
}

.frontend-site .catalog-carousel-shell:hover .catalog-carousel-arrow {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
}

@media (min-width: 992px) and (max-width: 1439.98px) {
    .frontend-site .site-header-row {
        flex-wrap: wrap;
        align-items: flex-start;
        padding: 0.75rem 0;
    }

    .frontend-site .site-menu-shell {
        flex: 1 1 720px;
        flex-wrap: wrap;
        justify-content: flex-end;
        row-gap: 0.75rem;
    }

    .frontend-site .site-tools {
        order: 1;
        flex: 0 1 auto;
        flex-wrap: wrap;
        justify-content: flex-end;
    }

    .frontend-site .site-nav {
        order: 2;
        flex: 1 1 100%;
        justify-content: flex-start;
        flex-wrap: wrap;
        white-space: normal;
        gap: 0.9rem 1.1rem;
    }
}

@media (max-width: 1199.98px) {
    .frontend-site .catalog-page-content .section-heading-row {
        flex-direction: column;
        align-items: flex-start;
    }
}

@media (max-width: 767.98px) {
    .frontend-site .catalog-carousel-arrow {
        opacity: 1;
        visibility: visible;
        pointer-events: auto;
    }

    .frontend-site .product-photo-card .controller-card-top {
        align-items: flex-start;
    }

    .frontend-site .product-photo-card .price-tag {
        margin-left: 0;
    }
}

/* v13 public live search + catalog facet filters */
.frontend-site .blog-live-header {
    align-items: center;
}

.frontend-site .blog-live-search {
    flex: 0 1 320px;
    width: min(100%, 320px);
}

.frontend-site .catalog-live-search .form-control,
.frontend-site .blog-live-search .form-control {
    border: 1px solid #cfe0c3;
    background: #ffffff;
    min-height: 44px;
}

.frontend-site .blog-subscribe-shell .form-control {
    min-height: 46px;
    border: 1px solid #cfe0c3;
    background: #ffffff;
}

.frontend-site .blog-subscribe-form-shell {
    display: flex;
    justify-content: flex-start;
}

.frontend-site .blog-subscribe-form-shell form {
    width: min(100%, 470px);
}

.frontend-site .catalog-filter-stack {
    display: grid;
    gap: 1rem;
}

.frontend-site .catalog-filter-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
}

.frontend-site .catalog-filter-title {
    font-size: 1rem;
    font-weight: 700;
    color: #223624;
}

.frontend-site .catalog-filter-reset {
    border: 0;
    background: transparent;
    color: #5d972c;
    font-weight: 700;
    padding: 0;
}

.frontend-site .catalog-filter-group {
    border: 1px solid #dce8d2;
    background: #ffffff;
    padding: 0.9rem;
    border-radius: 0;
}

.frontend-site .catalog-filter-group-toggle {
    width: 100%;
    border: 0;
    background: transparent;
    padding: 0;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    text-align: left;
}

.frontend-site .catalog-filter-group-title {
    margin: 0;
    font-size: 0.95rem;
    font-weight: 700;
    color: #223624;
}

.frontend-site .catalog-filter-group-symbol {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 24px;
    height: 24px;
    border-radius: 0;
    border: 1px solid #dce8d2;
    color: #5d972c;
    font-size: 1rem;
    line-height: 1;
}

.frontend-site .catalog-filter-options {
    display: grid;
    gap: 0.45rem;
    margin-top: 0.85rem;
}

.frontend-site .catalog-filter-option {
    display: grid;
    grid-template-columns: 18px minmax(0, 1fr) auto;
    align-items: start;
    gap: 0.55rem;
    font-size: 0.92rem;
    color: #314632;
    cursor: pointer;
}

.frontend-site .catalog-filter-option input {
    margin-top: 0.2rem;
}

.frontend-site .catalog-filter-option small {
    color: #789076;
    font-size: 0.8rem;
}

.frontend-site .catalog-filter-show-all {
    border: 1px solid #bfd8ad;
    background: #f7fbf2;
    color: #3e6820;
    min-height: 42px;
    border-radius: 0;
    font-weight: 700;
}

.frontend-site .catalog-filter-show-all:hover {
    background: #eef8e5;
    border-color: #9fc67d;
}

.frontend-site .contact-page-shell {
    display: grid;
    gap: 1.25rem;
}

.frontend-site .contact-page-form-card {
    width: 100%;
    max-width: 980px;
    margin: 0 auto;
}

.frontend-site .contact-page-shell > * {
    width: 100%;
}

.frontend-site .contact-page-form-card form {
    width: 100%;
}

.frontend-site .partner-application-shell {
    display: grid;
    gap: 1.25rem;
}

.frontend-site .partner-application-summary {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem 1.5rem;
    flex-wrap: wrap;
}

.frontend-site .partner-application-toggle {
    white-space: nowrap;
}

.frontend-site .partner-application-panel {
    display: block;
}

.frontend-site .partner-directory-filters-shell {
    margin-bottom: 1rem;
    padding: 1rem 1.15rem;
    border: 1px solid #dce8d2;
    background: #fbfdf8;
}

.frontend-site .partner-directory-filters-form {
    display: grid;
    grid-template-columns: minmax(220px, 1fr) minmax(170px, 210px) auto auto;
    gap: 0.85rem 0.9rem;
    align-items: end;
}

.frontend-site .partner-directory-filters-summary,
.frontend-site .partner-directory-filters-panel {
    display: contents;
}

.frontend-site .partner-directory-filters-toggle {
    display: none;
}

.frontend-site .partner-directory-filter-field {
    min-width: 0;
    margin: 0;
    padding: 0;
    border: 0;
}

.frontend-site .partner-directory-filter-label {
    display: block;
    margin-bottom: 0.45rem;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: #7ca53a;
}

.frontend-site .partner-directory-filter-field--services .partner-directory-filter-label {
    margin-bottom: 0.55rem;
}

.frontend-site .partner-directory-filter-field--services {
    justify-self: start;
    min-width: 9rem;
}

.frontend-site .partner-directory-filter-chip-list {
    display: flex;
    flex-wrap: nowrap;
    gap: 0.45rem;
}

.frontend-site .partner-directory-filter-chip {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.5rem;
    height: 2.5rem;
    border: 1px solid #dce8d2;
    background: #fff;
    color: #2a3f2d;
    cursor: pointer;
    transition: border-color 0.2s ease, background-color 0.2s ease, color 0.2s ease;
}

.frontend-site .partner-directory-filter-chip input {
    position: absolute;
    inset: 0;
    opacity: 0;
    cursor: pointer;
}

.frontend-site .partner-directory-filter-chip-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.frontend-site .partner-directory-filter-chip-icon svg {
    width: 1.1rem;
    height: 1.1rem;
    fill: currentColor;
}

.frontend-site .partner-directory-filter-chip.is-selected {
    border-color: #78be20;
    background: #eef8e5;
    color: #335718;
}

.frontend-site .partner-directory-filter-actions {
    display: flex;
    justify-content: flex-end;
    align-items: end;
    gap: 0.55rem;
    justify-self: end;
    white-space: nowrap;
}

.frontend-site .partner-directory-filter-actions .action-green,
.frontend-site .partner-directory-filter-actions .action-outline {
    min-height: 42px;
    padding: 0 0.9rem;
}

.frontend-site .partner-directory-list {
    display: grid;
    gap: 1rem;
}

.frontend-site [data-partners-directory] {
    position: relative;
}

.frontend-site [data-partners-directory].is-loading::before {
    content: '';
    position: absolute;
    inset: 0;
    background: rgba(251, 253, 248, 0.7);
    z-index: 5;
}

.frontend-site [data-partners-directory].is-loading::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    width: 2.25rem;
    height: 2.25rem;
    margin: -1.125rem 0 0 -1.125rem;
    border: 3px solid #dce8d2;
    border-top-color: #6fb32f;
    border-radius: 50%;
    animation: partner-directory-spin 0.75s linear infinite;
    z-index: 6;
}

.frontend-site [data-partners-directory].is-loading > * {
    pointer-events: none;
}

@keyframes partner-directory-spin {
    to {
        transform: rotate(360deg);
    }
}

.frontend-site .partner-directory-item {
    display: grid;
    grid-template-columns: minmax(230px, 250px) minmax(140px, 160px) minmax(210px, 240px) minmax(175px, 205px);
    grid-template-rows: auto auto;
    justify-content: start;
    gap: 0.8rem;
    align-items: start;
    padding: 1rem 1.15rem;
    border: 1px solid #dce8d2;
    background: #fbfdf8;
}

.frontend-site .partner-directory-cell {
    min-width: 0;
}

.frontend-site .partner-directory-cell--service-top {
    grid-column: 1;
    grid-row: 1;
}

.frontend-site .partner-directory-cell--city-top {
    grid-column: 2;
    grid-row: 1;
}

.frontend-site .partner-directory-cell--address-top {
    grid-column: 3;
    grid-row: 1;
}

.frontend-site .partner-directory-cell--services-top {
    grid-column: 4;
    grid-row: 1;
    min-width: 0;
    max-width: 12.75rem;
}

.frontend-site .partner-directory-cell--experience-bottom {
    grid-column: 1;
    grid-row: 2;
}

.frontend-site .partner-directory-cell--phone-bottom {
    grid-column: 2;
    grid-row: 2;
}

.frontend-site .partner-directory-cell--hours-bottom {
    grid-column: 3;
    grid-row: 2;
    padding-left: 0.95rem;
}

.frontend-site .partner-directory-cell--payments-bottom {
    grid-column: 4;
    grid-row: 2;
    min-width: 0;
    max-width: 12.75rem;
}

.frontend-site .partner-directory-label {
    margin-bottom: 0.35rem;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: #7ca53a;
}

.frontend-site .partner-directory-value {
    color: #233728;
    word-break: break-word;
}

.frontend-site .partner-directory-cell--services-top .partner-directory-label {
    margin-bottom: 0.6rem;
}

.frontend-site .partner-directory-cell--services-top .partner-directory-icon-set,
.frontend-site .partner-directory-cell--payments-bottom .partner-directory-icon-set {
    align-items: flex-start;
}

.frontend-site .partner-directory-cell--phone .partner-directory-value {
    display: flex;
    align-items: center;
    min-height: 38px;
}

.frontend-site .partner-directory-meta-list {
    display: grid;
    gap: 0.55rem;
}

.frontend-site .partner-directory-meta-row {
    display: grid;
    grid-template-columns: 2rem minmax(0, 1fr);
    gap: 0.45rem;
    align-items: center;
}

.frontend-site .partner-directory-meta-heading {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2rem;
    min-width: 2rem;
}

.frontend-site .partner-directory-meta-heading-icon,
.frontend-site .partner-directory-icon-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2rem;
    height: 2rem;
    border: 1px solid #dce8d2;
    background: #fff;
    color: #2a3f2d;
    flex: 0 0 auto;
}

.frontend-site .partner-directory-meta-heading-icon svg,
.frontend-site .partner-directory-icon-badge svg {
    width: 1.1rem;
    height: 1.1rem;
    fill: currentColor;
}

.frontend-site .partner-directory-icon-set {
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem;
}

.frontend-site .partner-directory-icon-set--payments {
    flex-wrap: nowrap;
}

.frontend-site .partner-directory-meta-text {
    color: #233728;
    word-break: break-word;
}

.frontend-site .partner-directory-meta-text .btn {
    white-space: nowrap;
    padding: 0.45rem 0.8rem;
    line-height: 1.15;
}

html[lang="am"] .frontend-site .partner-directory-item {
    grid-template-columns: minmax(230px, 250px) minmax(175px, 205px) minmax(225px, 255px) minmax(175px, 205px);
}

html[lang="am"] .frontend-site .partner-directory-cell--hours-bottom {
    padding-left: 1.3rem;
}

.frontend-site .partner-directory-meta-text--schedule {
    line-height: 1.45;
}

.frontend-site .partner-directory-pagination {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 0.5rem;
    margin-top: 1.25rem;
}

.frontend-site .partner-directory-page-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 2.5rem;
    padding: 0.55rem 0.85rem;
    border: 1px solid #dce8d2;
    color: #2b3f2f;
    text-decoration: none;
    background: #fff;
}

.frontend-site .partner-directory-page-link.is-active {
    background: #78be20;
    border-color: #78be20;
    color: #fff;
}

.frontend-site .partner-directory-page-link.is-disabled {
    pointer-events: none;
    opacity: 0.45;
}

@media (max-width: 991.98px) {
    .frontend-site .partner-directory-filters-form {
        grid-template-columns: minmax(220px, 1fr) minmax(180px, 220px);
    }

    .frontend-site .partner-directory-filter-field--services {
        grid-column: 1 / -1;
    }

    .frontend-site .partner-directory-filter-actions {
        justify-content: flex-start;
    }

    .frontend-site .partner-directory-item {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        grid-template-rows: auto;
        justify-content: stretch;
        gap: 1rem;
    }

    .frontend-site .partner-directory-item > .partner-directory-cell {
        grid-column: auto;
        grid-row: auto;
        max-width: none;
        padding-left: 0;
    }

    .frontend-site .partner-directory-meta-row {
        grid-template-columns: 2rem minmax(0, 1fr);
    }

    .frontend-site .partner-directory-icon-set--payments {
        flex-wrap: wrap;
    }
}

@media (max-width: 767.98px) {
    .frontend-site .partner-application-summary {
        align-items: flex-start;
    }

    .frontend-site .partner-directory-filters-form {
        grid-template-columns: 1fr;
        gap: 0.85rem;
        align-items: stretch;
    }

    .frontend-site .partner-directory-filters-summary,
    .frontend-site .partner-directory-filters-panel {
        display: block;
    }

    .frontend-site .partner-directory-filters-summary {
        display: grid;
        grid-template-columns: minmax(0, 1fr) auto;
        gap: 0.75rem;
        align-items: end;
    }

    .frontend-site .partner-directory-filters-toggle {
        display: inline-flex;
        white-space: nowrap;
        align-self: end;
    }

    .frontend-site .partner-directory-filters-shell:not(.is-open) .partner-directory-filters-panel {
        display: none;
    }

    .frontend-site .partner-directory-filters-panel {
        margin-top: 0.15rem;
    }

    .frontend-site .partner-directory-filter-field--city,
    .frontend-site .partner-directory-filter-field--services,
    .frontend-site .partner-directory-filter-actions {
        margin-top: 0.85rem;
    }

    .frontend-site .partner-directory-filter-chip-list {
        gap: 0.55rem;
    }

    .frontend-site .partner-directory-filter-chip {
        width: auto;
        min-width: 4.8rem;
        max-width: 6.4rem;
        height: auto;
        min-height: 3.8rem;
        padding: 0.3rem 0.35rem;
        flex-direction: column;
        gap: 0.2rem;
    }

    .frontend-site .partner-directory-filter-chip::after {
        content: attr(data-label);
        display: block;
        font-size: 0.56rem;
        line-height: 1.15;
        text-align: center;
        letter-spacing: 0;
        text-transform: none;
        color: #233728;
    }

    .frontend-site .partner-directory-filter-actions {
        flex-direction: column;
        align-items: stretch;
    }

    .frontend-site .partner-directory-filter-actions > * {
        width: 100%;
        justify-content: center;
    }

    .frontend-site .partner-directory-item {
        display: flex;
        flex-direction: column;
        gap: 0.9rem;
    }

    .frontend-site .partner-directory-pagination {
        justify-content: flex-start;
    }

    .frontend-site .partner-directory-cell--service-top {
        order: 1;
    }

    .frontend-site .partner-directory-cell--experience-bottom {
        order: 2;
    }

    .frontend-site .partner-directory-cell--city-top {
        order: 3;
    }

    .frontend-site .partner-directory-cell--phone-bottom {
        order: 4;
    }

    .frontend-site .partner-directory-cell--address-top {
        order: 5;
    }

    .frontend-site .partner-directory-cell--hours-bottom {
        order: 6;
        padding-left: 0;
        align-self: stretch;
        width: 100%;
    }

    html[lang="am"] .frontend-site .partner-directory-cell--hours-bottom {
        padding-left: 0;
    }

    .frontend-site .partner-directory-cell--hours-bottom .partner-directory-meta-row {
        justify-content: flex-start;
        width: 100%;
    }

    .frontend-site .partner-directory-cell--hours-bottom .partner-directory-meta-text--schedule {
        text-align: left;
    }

    .frontend-site .partner-directory-cell--services-top {
        order: 7;
    }

    .frontend-site .partner-directory-cell--payments-bottom {
        order: 8;
    }
}

@media (hover: none), (pointer: coarse) {
    .frontend-site .partner-directory-icon-set {
        gap: 0.55rem;
    }

    .frontend-site .partner-directory-icon-badge {
        width: auto;
        min-width: 4.8rem;
        max-width: 6.4rem;
        height: auto;
        min-height: 3.8rem;
        padding: 0.3rem 0.35rem;
        flex-direction: column;
        gap: 0.2rem;
    }

    .frontend-site .partner-directory-icon-badge::after {
        content: attr(aria-label);
        display: block;
        font-size: 0.56rem;
        line-height: 1.15;
        text-align: center;
        letter-spacing: 0;
        text-transform: none;
        color: #233728;
        word-break: break-word;
    }
}

.frontend-site .product-buy-price {
    display: flex;
    flex-wrap: wrap;
    align-items: baseline;
    gap: 0.5rem 0.75rem;
}

.frontend-site .product-buy-card .form-text.text-success {
    color: #4b8f1d !important;
    font-weight: 700;
}

.frontend-site .contact-page-form-card .input-group-text {
    border-color: #cfe0c3;
    background: #f5faef;
    color: #244025;
    font-weight: 700;
}

.frontend-site .account-order-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.55rem;
}

.frontend-site .account-order-actions .action-outline,
.frontend-site .account-order-actions button.action-outline {
    min-height: 34px;
    padding: 0.35rem 0.8rem;
    font-size: 0.82rem;
}

.frontend-site .invoice-card {
    display: grid;
    gap: 1.25rem;
    padding: 1.4rem;
}

.frontend-site .invoice-toolbar {
    display: flex;
    justify-content: flex-end;
    gap: 0.75rem;
    flex-wrap: wrap;
}

.frontend-site .invoice-header,
.frontend-site .invoice-parties {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.frontend-site .invoice-total-box,
.frontend-site .invoice-party,
.frontend-site .invoice-bank-details {
    border: 1px solid #dce8d2;
    padding: 1rem;
    background: #fff;
}

.frontend-site .invoice-total-box {
    justify-self: end;
    min-width: min(100%, 260px);
}

.frontend-site .invoice-total-amount {
    font-size: 1.7rem;
    font-weight: 700;
    color: #1f3320;
}

.frontend-site .invoice-party-title {
    font-size: 0.85rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: #6a8564;
    margin-bottom: 0.55rem;
}

.frontend-site .invoice-table th,
.frontend-site .invoice-table td {
    padding-top: 0.85rem;
    padding-bottom: 0.85rem;
}

.frontend-site .delivery-method-option {
    align-items: flex-start;
    background: #fff;
    border: 1px solid #dce8d2;
    cursor: pointer;
    display: flex;
    gap: 0.75rem;
    height: 100%;
    padding: 1rem;
    transition: border-color 0.18s ease, box-shadow 0.18s ease;
}

.frontend-site .delivery-method-option:hover {
    border-color: #69a92f;
    box-shadow: 0 12px 28px rgba(48, 106, 37, 0.08);
}

.frontend-site .delivery-method-option .form-check-input {
    flex: 0 0 auto;
    margin-top: 0.25rem;
}

.frontend-site .delivery-method-option strong,
.frontend-site .delivery-method-option small {
    display: block;
}

.frontend-site .delivery-method-option small {
    color: #6f7a6b;
    line-height: 1.45;
    margin-top: 0.35rem;
}

.frontend-site .delivery-method-option .delivery-free-note {
    color: #4f8f1f;
    font-weight: 700;
}

.frontend-site [data-blog-item][hidden],
.frontend-site [data-catalog-item][hidden] {
    display: none !important;
}

@media (max-width: 991.98px) {
    .frontend-site .blog-live-search {
        flex-basis: 100%;
        width: 100%;
    }

    .frontend-site .invoice-header,
    .frontend-site .invoice-parties {
        grid-template-columns: 1fr;
    }

    .frontend-site .invoice-total-box {
        justify-self: stretch;
    }
}

@media print {
    .site-header,
    .site-footer,
    .page-breadcrumb-wrap,
    .account-sidebar,
    .no-print,
    .alert {
        display: none !important;
    }

    .site-main,
    .site-main .container,
    .account-shell,
    .account-content {
        display: block !important;
        width: 100% !important;
        max-width: 100% !important;
        padding: 0 !important;
        margin: 0 !important;
    }

    .invoice-card {
        border: 0 !important;
        box-shadow: none !important;
        padding: 0 !important;
    }
}
