/*
Theme Name: Агро Эксперт
Author: Ваше имя
Description: Тема-витрина для запчастей сельхозтехники.
Version: 1.0
License: GPL v2 or later
Text Domain: agrozapchast
*/

:root {
    --p: #F7F3EB;
    --p2: #EDE9DF;
    --p3: #E2DDD3;
    --ink: #1A1914;
    --ink2: #3D3B34;
    --ink3: #6B6860;
    --ink4: #9A978E;
    --rust: #C4521A;
    --rust2: #A24015;
    --rust-lt: #F5EBE4;
    --wheat: #C8911C;
    --wheat-lt: #FAF0DC;
    --border: #D8D4C8;
    --r: 4px;
    --r2: 8px;
    --display: 'Cormorant Garamond', Georgia, serif;
    --body: 'Manrope', system-ui, sans-serif;
    --trans: all .2s cubic-bezier(.4,0,.2,1);
}

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

html {
    overflow-x: hidden;
}

body {
    background: var(--p);
    color: var(--ink);
    font-family: var(--body);
    font-size: 15px;
    line-height: 1.65;
    overflow-x: hidden;
    width: 100%;
}

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

    a:hover {
        color: var(--rust2);
    }

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

button {
    cursor: pointer;
    font-family: var(--body);
    border: none;
    outline: none;
}

input, select, textarea {
    font-family: var(--body);
    outline: none;
    resize: none;
}

ul {
    list-style: none;
}

::-webkit-scrollbar {
    width: 5px;
}

::-webkit-scrollbar-track {
    background: transparent;
}

::-webkit-scrollbar-thumb {
    background: var(--p3);
    border-radius: 3px;
}

:focus-visible {
    outline: 2px solid var(--rust);
    outline-offset: 3px;
}

/* Topbar */
.topbar {
    background: var(--ink);
    padding: 8px 0;
    font-size: 12px;
    letter-spacing: .03em;
    color: rgba(255,255,255,.6);
}

.topbar-inner {
    max-width: 1380px;
    margin: 0 auto;
    padding: 0 32px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    flex-wrap: wrap;
}

.topbar-contacts {
    display: flex;
    gap: 24px;
    flex-wrap: wrap;
}

    .topbar-contacts a {
        color: rgba(255,255,255,.7);
        display: flex;
        align-items: center;
        gap: 7px;
        letter-spacing: .01em;
    }

        .topbar-contacts a:hover {
            color: var(--wheat);
        }

        .topbar-contacts a svg {
            flex-shrink: 0;
            opacity: .6;
        }

.topbar-right {
    display: flex;
    align-items: center;
    gap: 20px;
    font-size: 11.5px;
    color: rgba(255,255,255,.45);
    letter-spacing: .04em;
    text-transform: uppercase;
}

    .topbar-right a {
        color: rgba(255,255,255,.45);
        transition: var(--trans);
    }

        .topbar-right a:hover {
            color: rgba(255,255,255,.8);
        }

/* Header */
.site-header {
    background: var(--p);
    border-bottom: 1px solid var(--border);
    position: sticky;
    top: 0;
    z-index: 1000;
}

    .site-header.scrolled {
        box-shadow: 0 4px 32px rgba(26,25,20,.08);
    }

.header-inner {
    max-width: 1380px;
    margin: 0 auto;
    padding: 0 32px;
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
    gap: 32px;
    height: 72px;
}

.site-logo {
    display: flex;
    align-items: center;
    gap: 12px;
    font-family: var(--display);
    font-size: 22px;
    font-weight: 600;
    color: var(--ink);
    letter-spacing: -.02em;
    line-height: 1;
    white-space: nowrap;
}

    .site-logo:hover {
        color: var(--rust);
    }

.logo-mark {
    width: 36px;
    height: 36px;
    flex-shrink: 0;
    background: var(--ink);
    border-radius: 3px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.site-logo:hover .logo-mark {
    background: var(--rust);
}

.logo-mark svg {
    color: #fff;
}

.header-search {
    position: relative;
    max-width: 460px;
    width: 100%;
}

    .header-search input {
        width: 100%;
        padding: 10px 42px 10px 16px;
        background: var(--p2);
        border: 1px solid var(--border);
        border-radius: var(--r);
        font-size: 13.5px;
        color: var(--ink);
        transition: var(--trans);
        letter-spacing: .01em;
    }

        .header-search input::placeholder {
            color: var(--ink4);
        }

        .header-search input:focus {
            background: #fff;
            border-color: var(--rust);
        }

.search-btn {
    position: absolute;
    right: 12px;
    top: 50%;
    transform: translateY(-50%);
    background: none;
    color: var(--ink3);
    display: flex;
    align-items: center;
    padding: 4px;
}

    .search-btn:hover {
        color: var(--rust);
    }

.header-actions {
    display: flex;
    align-items: center;
    gap: 4px;
}

.hbtn {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 2px;
    padding: 8px 12px;
    border-radius: var(--r);
    color: var(--ink2);
    font-size: 10.5px;
    letter-spacing: .04em;
    text-transform: uppercase;
    background: none;
    position: relative;
    transition: var(--trans);
    white-space: nowrap;
    text-decoration: none;
}

    .hbtn:hover {
        background: var(--p2);
        color: var(--rust);
    }

    .hbtn svg {
        width: 20px;
        height: 20px;
    }

.cart-count {
    position: absolute;
    top: 5px;
    right: 7px;
    background: var(--rust);
    color: #fff;
    border-radius: 99px;
    min-width: 16px;
    height: 16px;
    font-size: 9.5px;
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0 4px;
    line-height: 1;
}

.header-divider {
    width: 1px;
    height: 28px;
    background: var(--border);
    margin: 0 4px;
}

/* Navigation */
.site-nav {
    background: var(--p);
    border-bottom: 1px solid var(--border);
    position: sticky;
    top: 72px;
    z-index: 999;
}

.nav-inner {
    max-width: 1380px;
    margin: 0 auto;
    padding: 0 32px;
    display: flex;
    align-items: stretch;
    gap: 0;
}

    .nav-inner a {
        display: flex;
        align-items: center;
        padding: 11px 18px;
        font-size: 13px;
        font-weight: 500;
        letter-spacing: .02em;
        color: var(--ink2);
        border-bottom: 2px solid transparent;
        white-space: nowrap;
    }

        .nav-inner a:hover, .nav-inner a.active, .nav-inner a.nav-active {
            color: var(--rust);
            border-bottom-color: var(--rust);
        }

        .nav-inner a.active, .nav-inner a.nav-active {
            font-weight: 600;
            background: rgba(196,82,26,0.06);
        }


/* Active nav link class */
.nav-link {
    display: flex;
    align-items: center;
    padding: 11px 18px;
    font-size: 13px;
    font-weight: 500;
    letter-spacing: .02em;
    color: var(--ink2);
    border-bottom: 2px solid transparent;
    white-space: nowrap;
    text-decoration: none;
    transition: color .15s, border-color .15s, background .15s;
}
.nav-link:hover, .nav-link.nav-active {
    color: var(--rust);
    border-bottom-color: var(--rust);
}
.nav-link.nav-active {
    font-weight: 600;
    background: rgba(196,82,26,0.06);
}

/* Breadcrumbs */
.breadcrumbs {
    background: var(--p);
    border-bottom: 1px solid var(--border);
    padding: 10px 0;
    font-size: 12px;
    letter-spacing: .03em;
    color: var(--ink4);
}

.breadcrumbs-inner {
    max-width: 1380px;
    margin: 0 auto;
    padding: 0 32px;
    display: flex;
    gap: 6px;
    align-items: center;
}

.breadcrumbs a {
    color: var(--ink3);
}

    .breadcrumbs a:hover {
        color: var(--rust);
    }

.bc-sep {
    color: var(--border);
    user-select: none;
}

/* Hero */
.hero {
    background: var(--ink);
    padding: 64px 32px 56px;
    position: relative;
    overflow: hidden;
}

    .hero::before {
        content: '';
        position: absolute;
        inset: 0;
        background: repeating-linear-gradient(-45deg, transparent, transparent 40px, rgba(255,255,255,.012) 40px, rgba(255,255,255,.012) 41px);
        pointer-events: none;
    }

.hero-inner {
    max-width: 1380px;
    margin: 0 auto;
    position: relative;
    z-index: 1;
}

.hero-tag {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: 11px;
    font-weight: 600;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: var(--rust);
    margin-bottom: 20px;
}

    .hero-tag::before {
        content: '';
        width: 28px;
        height: 1px;
        background: var(--rust);
    }

.hero h1 {
    font-family: var(--display);
    font-size: clamp(40px,6vw,76px);
    font-weight: 600;
    line-height: 1.04;
    letter-spacing: -.03em;
    color: #fff;
    margin-bottom: 20px;
    max-width: 700px;
}

    .hero h1 em {
        font-style: italic;
        color: var(--wheat);
    }

.hero-sub {
    font-size: 15px;
    color: rgba(255,255,255,.55);
    max-width: 520px;
    line-height: 1.7;
    margin-bottom: 36px;
    font-weight: 300;
    letter-spacing: .01em;
}

.hero-search-wrap {
    display: flex;
    gap: 0;
    max-width: 560px;
    border-radius: var(--r);
    overflow: hidden;
    border: 1px solid rgba(255,255,255,.12);
}

    .hero-search-wrap input {
        flex: 1;
        padding: 14px 20px;
        background: rgba(255,255,255,.06);
        border: none;
        font-size: 14px;
        color: #fff;
        letter-spacing: .01em;
        outline: none;
    }

        .hero-search-wrap input::placeholder {
            color: rgba(255,255,255,.3);
        }

        .hero-search-wrap input:focus {
            background: rgba(255,255,255,.1);
            outline: none;
            box-shadow: none;
        }

.hero-search-btn {
    padding: 0 24px;
    background: var(--rust);
    color: #fff;
    font-size: 13px;
    font-weight: 600;
    letter-spacing: .06em;
    text-transform: uppercase;
    white-space: nowrap;
    flex-shrink: 0;
}

    .hero-search-btn:hover {
        background: var(--rust2);
    }

.hero-stats {
    display: flex;
    gap: 40px;
    margin-top: 44px;
    flex-wrap: wrap;
}

.hero-stat strong {
    display: block;
    font-family: var(--display);
    font-size: 36px;
    font-weight: 600;
    color: #fff;
    letter-spacing: -.03em;
    line-height: 1;
    margin-bottom: 4px;
}

.hero-stat span {
    font-size: 12px;
    color: rgba(255,255,255,.4);
    letter-spacing: .04em;
    text-transform: uppercase;
}

.hero-divider {
    display: inline-block;
    width: 1px;
    height: 44px;
    background: rgba(255,255,255,.1);
    align-self: center;
}

/* Hero slider */
.hero-slider {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 0;
}

.slide-bg {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    opacity: 0;
    transition: opacity 1.2s ease-in-out;
}

    .slide-bg.active {
        opacity: 1;
    }

.hero {
    background: transparent;
    position: relative;
    z-index: 2;
}

    .hero::after {
        content: '';
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        background: rgba(0,0,0,0.45);
        z-index: 1;
    }

.hero-inner {
    position: relative;
    z-index: 2;
}

/* Categories */
.cats-section {
    padding: 52px 0;
    background: var(--p);
    border-bottom: 1px solid var(--border);
}

.cats-inner {
    max-width: 1380px;
    margin: 0 auto;
    padding: 0 32px;
}

.section-eyebrow {
    display: flex;
    align-items: center;
    gap: 12px;
    font-size: 11px;
    font-weight: 600;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: var(--ink3);
    margin-bottom: 28px;
}

    .section-eyebrow::after {
        content: '';
        flex: 1;
        height: 1px;
        background: var(--border);
    }

.cats-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
    gap: 1px;
    background: var(--border);
    border: 1px solid var(--border);
    border-radius: var(--r2);
    overflow: hidden;
}

.cat-tile {
    background: var(--p);
    padding: 24px 20px;
    display: flex;
    flex-direction: column;
    gap: 12px;
    position: relative;
    cursor: pointer;
    text-decoration: none;
}

    .cat-tile:hover {
        background: #fff;
        z-index: 1;
    }

        .cat-tile:hover .cat-num {
            color: var(--rust);
        }

.cat-num {
    font-family: var(--display);
    font-size: 28px;
    font-weight: 400;
    color: var(--p3);
    line-height: 1;
    letter-spacing: -.02em;
}

.cat-icon {
    width: 32px;
    height: 32px;
    color: var(--ink3);
}

.cat-tile:hover .cat-icon {
    color: var(--rust);
}

.cat-name {
    font-size: 13px;
    font-weight: 600;
    color: var(--ink);
    letter-spacing: -.01em;
    line-height: 1.35;
}

.cat-count {
    font-size: 11px;
    color: var(--ink4);
    margin-top: 2px;
}

.cat-arrow {
    position: absolute;
    bottom: 16px;
    right: 16px;
    color: var(--border);
    font-size: 16px;
}

.cat-tile:hover .cat-arrow {
    color: var(--rust);
}

/* Products grid */
.products-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1px;
    background: var(--border);
    border: 1px solid var(--border);
    border-radius: var(--r2);
    overflow: hidden;
}

@media (max-width: 1100px) {
    .products-grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

@media (max-width: 768px) {
    .products-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

.product-card {
    background: var(--p);
    display: flex;
    flex-direction: column;
    position: relative;
    overflow: hidden;
}

    .product-card:hover {
        background: #fff;
        z-index: 1;
    }

.product-badge {
    position: absolute;
    top: 12px;
    left: 12px;
    z-index: 2;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: .06em;
    text-transform: uppercase;
    padding: 3px 8px;
    border-radius: 2px;
}

.badge-in {
    background: var(--ink);
    color: #fff;
}

.badge-out {
    background: #f3f4f6;
    color: #6b7280;
}

.badge-used {
    background: #fff3e0;
    color: #e65100;
}

.badge-sale {
    background: var(--rust);
    color: #fff;
}

.pcard-img {
    aspect-ratio: 4/3;
    background: var(--p2);
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    border-bottom: 1px solid var(--border);
    position: relative;
    padding: 18px;
    box-shadow: inset 0 0 0 1px rgba(0,0,0,0.02), inset 0 6px 14px -8px rgba(26,25,20,0.10);
}

    .pcard-img img {
        width: 100%;
        height: 100%;
        object-fit: contain;
        filter: drop-shadow(0 4px 10px rgba(26,25,20,0.08));
    }

    .pcard-img svg {
        color: var(--p3);
    }

.pcard-body {
    padding: 16px 14px 12px;
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.pcard-meta {
    display: flex;
    gap: 5px;
    flex-wrap: wrap;
}

.pcard-tag {
    font-size: 10.5px;
    color: var(--ink3);
    background: var(--p2);
    padding: 2px 7px;
    border-radius: 2px;
    letter-spacing: .01em;
}

.pcard-sku {
    font-size: 11px;
    color: var(--ink4);
    letter-spacing: .02em;
}

.pcard-name {
    font-size: 13.5px;
    font-weight: 500;
    color: var(--ink);
    line-height: 1.4;
    letter-spacing: -.01em;
    flex: 1;
    word-break: break-word;
    overflow-wrap: break-word;
}

    .pcard-name:hover {
        color: var(--rust);
    }

.pcard-foot {
    padding: 10px 14px 14px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    flex-wrap: wrap;
    border-top: 1px solid var(--border);
    margin-top: auto;
    padding-top: 12px;
}

.btn-add {
    padding: 8px 14px;
    background: var(--rust);
    color: #fff;
    border-radius: var(--r);
    font-size: 12.5px;
    font-weight: 600;
    letter-spacing: .04em;
    white-space: nowrap;
    border: none;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    transition: background .15s;
}

    .btn-add:hover {
        background: var(--rust2);
    }

.btn-order {
    padding: 8px 14px;
    background: transparent;
    color: var(--rust);
    border: 1px solid var(--rust);
    border-radius: var(--r);
    font-size: 12px;
    font-weight: 600;
    letter-spacing: .04em;
    white-space: nowrap;
    cursor: pointer;
}

    .btn-order:hover {
        background: var(--rust-lt);
    }

/* Qty controls on product cards */
.qty-controls {
    display: flex;
    align-items: center;
    gap: 8px;
}

    .qty-controls .qty-b {
        width: 28px;
        height: 28px;
        background: var(--p2);
        border: 1px solid var(--border);
        border-radius: var(--r);
        cursor: pointer;
        font-size: 16px;
    }

    .qty-controls .qty-val-card {
        min-width: 30px;
        text-align: center;
        font-weight: 500;
    }

/* Catalog page */
.catalog-section {
    padding: 40px 0 60px;
}

.catalog-outer {
    max-width: 1380px;
    margin: 0 auto;
    padding: 0 32px;
}

.catalog-grid {
    display: grid;
    grid-template-columns: 260px 1fr;
    gap: 32px;
    align-items: start;
}

@media (max-width: 1100px) {
    .catalog-grid {
        grid-template-columns: 1fr;
    }
}

.sidebar {
    background: var(--p);
    border: 1px solid var(--border);
    border-radius: var(--r2);
    overflow: hidden;
    position: sticky;
    top: 88px;
}

@media (max-width: 1100px) {
    .sidebar {
        position: static;
    }
}

.sidebar-head {
    padding: 16px 20px;
    border-bottom: 1px solid var(--border);
    background: var(--p2);
    display: flex;
    align-items: center;
    justify-content: space-between;
}

    .sidebar-head h3 {
        font-family: var(--display);
        font-size: 17px;
        font-weight: 600;
        letter-spacing: -.02em;
        color: var(--ink);
    }

.filter-group {
    padding: 20px;
    border-bottom: 1px solid var(--border);
}

    .filter-group:last-child {
        border-bottom: none;
    }

.filter-label {
    font-size: 11px;
    font-weight: 600;
    letter-spacing: .1em;
    text-transform: uppercase;
    color: var(--ink3);
    margin-bottom: 14px;
    display: block;
}

.filter-option {
    display: flex;
    align-items: center;
    gap: 9px;
    padding: 5px 0;
    font-size: 13px;
    color: var(--ink2);
    cursor: pointer;
}

    .filter-option:hover {
        color: var(--rust);
    }

    .filter-option input[type=checkbox] {
        accent-color: var(--rust);
        width: 13px;
        height: 13px;
        flex-shrink: 0;
    }

.price-inputs {
    display: flex;
    gap: 8px;
    align-items: center;
}

.price-input {
    flex: 1;
    padding: 8px 10px;
    background: var(--p2);
    border: 1px solid var(--border);
    border-radius: var(--r);
    font-size: 13px;
    color: var(--ink);
}

    .price-input:focus {
        border-color: var(--rust);
        background: #fff;
    }

.price-sep {
    color: var(--ink4);
    font-size: 12px;
}

.sidebar-btn {
    display: block;
    width: calc(100% - 40px);
    margin: 16px 20px 20px;
    padding: 11px;
    background: var(--rust);
    color: #fff;
    border-radius: var(--r);
    font-size: 13px;
    font-weight: 600;
    letter-spacing: .04em;
    text-align: center;
    border: none;
    cursor: pointer;
}

    .sidebar-btn:hover {
        background: var(--rust2);
    }

.sidebar-reset {
    display: block;
    text-align: center;
    margin: -8px 20px 20px;
    font-size: 12px;
    color: var(--ink3);
}

    .sidebar-reset:hover {
        color: var(--rust);
    }

.catalog-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 20px;
    flex-wrap: wrap;
    padding-bottom: 16px;
    border-bottom: 1px solid var(--border);
}

.catalog-count {
    font-size: 13px;
    color: var(--ink3);
}

    .catalog-count strong {
        color: var(--ink);
        font-weight: 600;
    }

.toolbar-right {
    display: flex;
    align-items: center;
    gap: 10px;
}

.sort-select {
    padding: 8px 12px;
    background: var(--p);
    border: 1px solid var(--border);
    border-radius: var(--r);
    font-size: 13px;
    color: var(--ink);
    font-family: var(--body);
    cursor: pointer;
    appearance: none;
    padding-right: 28px;
    background-image: url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%239A978E' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 10px center;
}

    .sort-select:focus {
        border-color: var(--rust);
    }

.view-toggle {
    display: flex;
    gap: 0;
    border: 1px solid var(--border);
    border-radius: var(--r);
    overflow: hidden;
}

.view-btn {
    width: 32px;
    height: 32px;
    background: var(--p);
    color: var(--ink3);
    display: flex;
    align-items: center;
    justify-content: center;
    border: none;
}

    .view-btn:hover {
        background: var(--p2);
    }

    .view-btn.on {
        background: var(--ink);
        color: #fff;
    }

/* Pagination */
.pagination {
    display: flex;
    gap: 4px;
    justify-content: center;
    padding: 40px 0 0;
}

.pag-btn {
    min-width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0 10px;
    border: 1px solid var(--border);
    border-radius: var(--r);
    font-size: 13px;
    color: var(--ink2);
    background: var(--p);
    cursor: pointer;
}

    .pag-btn:hover {
        border-color: var(--rust);
        color: var(--rust);
    }

    .pag-btn.active {
        background: var(--ink);
        border-color: var(--ink);
        color: #fff;
        font-weight: 600;
    }

    .pag-btn.dots {
        border-color: transparent;
        background: transparent;
        cursor: default;
        color: var(--ink4);
    }

/* Single product */
.product-page {
    padding: 40px 0 60px;
}

.product-outer {
    max-width: 1380px;
    margin: 0 auto;
    padding: 0 32px;
}

.product-layout {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 48px;
    align-items: start;
}

@media (max-width: 1100px) {
    .product-layout {
        grid-template-columns: 1fr;
    }
}

.gallery-main {
    background: var(--p);
    border: 1px solid var(--border);
    border-radius: var(--r2);
    overflow: hidden;
}

.gallery-main-img {
    aspect-ratio: 4/3;
    background: var(--p2);
    display: flex;
    align-items: center;
    justify-content: center;
    border-bottom: 1px solid var(--border);
}

    .gallery-main-img img {
        width: 100%;
        height: 100%;
        object-fit: contain;
        padding: 24px;
    }

.gallery-thumbs {
    display: flex;
    gap: 8px;
    padding: 12px;
    background: var(--p2);
    overflow-x: auto;
}

.gallery-thumb {
    width: 68px;
    height: 68px;
    flex-shrink: 0;
    border: 1.5px solid var(--border);
    border-radius: var(--r);
    overflow: hidden;
    cursor: pointer;
}

    .gallery-thumb.active, .gallery-thumb:hover {
        border-color: var(--rust);
    }

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

.product-info-col {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.pinfo-title {
    font-family: var(--display);
    font-size: clamp(24px,3vw,36px);
    font-weight: 600;
    color: var(--ink);
    letter-spacing: -.03em;
    line-height: 1.2;
}

.pinfo-meta {
    display: flex;
    gap: 10px;
    align-items: center;
    flex-wrap: wrap;
}

.pinfo-sku {
    font-size: 12.5px;
    color: var(--ink3);
    letter-spacing: .02em;
}

.pinfo-brand {
    font-size: 11.5px;
    font-weight: 700;
    letter-spacing: .06em;
    text-transform: uppercase;
    background: var(--rust-lt);
    color: var(--rust);
    padding: 3px 10px;
    border-radius: 2px;
}

.attrs-table {
    border: 1px solid var(--border);
    border-radius: var(--r2);
    overflow: hidden;
}

.attr-row {
    display: flex;
    border-bottom: 1px solid var(--border);
}

    .attr-row:last-child {
        border-bottom: none;
    }

.attr-k {
    width: 45%;
    min-width: 120px;
    padding: 9px 14px;
    font-size: 13px;
    color: var(--ink3);
    background: var(--p2);
    flex-shrink: 0;
}

.attr-v {
    flex: 1;
    padding: 9px 14px;
    font-size: 13px;
    word-break: break-word;
    overflow-wrap: break-word;
    background: #fff;
    color: var(--ink2);
}

.price-box {
    background: var(--p2);
    border: 1px solid var(--border);
    border-radius: var(--r2);
    padding: 24px;
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.availability {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 13.5px;
    font-weight: 500;
}

.avail-pip {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    flex-shrink: 0;
    background: var(--ink3);
}

    .avail-pip.in {
        background: #4A9654;
    }

    .avail-pip.out {
        background: var(--wheat);
    }

.qty-add-row {
    display: flex;
    gap: 10px;
    align-items: center;
}

.qty-ctrl {
    display: flex;
    align-items: center;
    border: 1px solid var(--border);
    border-radius: var(--r);
    overflow: hidden;
}

.qty-b {
    width: 36px;
    height: 36px;
    background: var(--p2);
    color: var(--ink);
    font-size: 18px;
    display: flex;
    align-items: center;
    justify-content: center;
    border: none;
    cursor: pointer;
}

    .qty-b:hover {
        background: var(--p3);
    }

.qty-inp {
    width: 48px;
    height: 36px;
    text-align: center;
    border-left: 1px solid var(--border);
    border-right: 1px solid var(--border);
    border-top: none;
    border-bottom: none;
    font-size: 15px;
    font-weight: 600;
    color: var(--ink);
    background: #fff;
}

.btn-add-full {
    flex: 1;
    padding: 0 20px;
    height: 36px;
    background: var(--ink);
    color: #fff;
    border-radius: var(--r);
    font-size: 13px;
    font-weight: 600;
    letter-spacing: .04em;
    border: none;
    cursor: pointer;
}

    .btn-add-full:hover {
        background: var(--rust);
    }

/* Tabs */
.ptabs {
    margin-top: 40px;
    border: 1px solid var(--border);
    border-radius: var(--r2);
    overflow: hidden;
}

.ptabs-nav {
    display: flex;
    border-bottom: 1px solid var(--border);
    background: var(--p2);
}

.ptab-btn {
    padding: 13px 22px;
    font-size: 13px;
    font-weight: 500;
    color: var(--ink3);
    background: none;
    border: none;
    cursor: pointer;
    border-bottom: 2px solid transparent;
    margin-bottom: -1px;
}

    .ptab-btn.active, .ptab-btn:hover {
        color: var(--rust);
        border-bottom-color: var(--rust);
    }

.ptab-panel {
    padding: 24px;
    display: none;
}

    .ptab-panel.active {
        display: block;
    }

/* Cart page */
.cart-section {
    padding: 40px 0 60px;
}

.cart-outer {
    max-width: 1380px;
    margin: 0 auto;
    padding: 0 32px;
}

.cart-layout {
    display: grid;
    grid-template-columns: 1fr 320px;
    gap: 24px;
    align-items: start;
}

@media (max-width: 1100px) {
    .cart-layout {
        grid-template-columns: 1fr;
    }
}

.cart-table-wrap {
    background: var(--p);
    border: 1px solid var(--border);
    border-radius: var(--r2);
    overflow: hidden;
}

.cart-thead {
    display: grid;
    grid-template-columns: 80px 1fr auto auto auto;
    gap: 0;
    background: var(--p2);
    border-bottom: 1px solid var(--border);
    padding: 10px 16px;
}

.cart-th {
    font-size: 11px;
    font-weight: 600;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: var(--ink3);
}

.cart-row {
    display: grid;
    grid-template-columns: 80px 1fr auto auto auto;
    gap: 0;
    align-items: center;
    padding: 14px 16px;
    border-bottom: 1px solid var(--border);
}

    .cart-row:last-child {
        border-bottom: none;
    }

.cart-thumb {
    width: 68px;
    height: 68px;
    background: var(--p2);
    border: 1px solid var(--border);
    border-radius: var(--r);
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}

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

.cart-name {
    font-size: 13.5px;
    font-weight: 500;
    color: var(--ink);
    line-height: 1.35;
    padding: 0 16px;
}

    .cart-name small {
        display: block;
        font-size: 11.5px;
        color: var(--ink3);
        font-weight: 400;
        margin-top: 2px;
    }

.cart-unit {
    font-size: 13px;
    color: var(--ink2);
    text-align: right;
    padding: 0 16px;
}

.cart-qty-ctrl {
    display: flex;
    align-items: center;
    border: 1px solid var(--border);
    border-radius: var(--r);
    overflow: hidden;
}

.cqb {
    width: 28px;
    height: 28px;
    background: var(--p2);
    border: none;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 14px;
}

    .cqb:hover {
        background: var(--p3);
    }

.cq-n {
    width: 36px;
    height: 28px;
    text-align: center;
    border-left: 1px solid var(--border);
    border-right: 1px solid var(--border);
    border-top: none;
    border-bottom: none;
    font-size: 13px;
    font-weight: 600;
    background: #fff;
}

.cart-subtotal {
    font-family: var(--display);
    font-size: 18px;
    font-weight: 600;
    color: var(--ink);
    letter-spacing: -.02em;
    text-align: right;
    padding-left: 16px;
}

.cart-del {
    color: var(--ink4);
    background: none;
    border: none;
    cursor: pointer;
    padding: 4px;
    margin-left: 8px;
}

    .cart-del:hover {
        color: var(--rust);
    }

.cart-summary {
    background: var(--p);
    border: 1px solid var(--border);
    border-radius: var(--r2);
    padding: 24px;
    display: flex;
    flex-direction: column;
    gap: 14px;
}

    .cart-summary h3 {
        font-family: var(--display);
        font-size: 20px;
        font-weight: 600;
        color: var(--ink);
        letter-spacing: -.03em;
        margin-bottom: 4px;
    }

.summary-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 13.5px;
    color: var(--ink2);
    padding: 8px 0;
    border-bottom: 1px solid var(--border);
}

    .summary-row:last-of-type {
        border-bottom: none;
        font-weight: 700;
        font-size: 16px;
        color: var(--ink);
        padding-top: 14px;
    }

    .summary-row span:last-child {
        font-family: var(--display);
        font-size: 20px;
        letter-spacing: -.03em;
    }

.btn-checkout {
    display: block;
    width: 100%;
    padding: 13px;
    background: var(--rust);
    color: #fff;
    text-align: center;
    border-radius: var(--r);
    font-size: 14px;
    font-weight: 600;
    letter-spacing: .04em;
    border: none;
    cursor: pointer;
}

    .btn-checkout:hover {
        background: var(--rust2);
    }

.cart-promo {
    display: flex;
    gap: 0;
    border: 1px solid var(--border);
    border-radius: var(--r);
    overflow: hidden;
}

    .cart-promo input {
        flex: 1;
        padding: 9px 12px;
        background: var(--p2);
        border: none;
        font-size: 13px;
        color: var(--ink);
    }

        .cart-promo input:focus {
            background: #fff;
        }

.promo-btn {
    padding: 0 14px;
    background: var(--ink2);
    color: #fff;
    font-size: 12px;
    font-weight: 600;
    letter-spacing: .04em;
    border: none;
    cursor: pointer;
}

    .promo-btn:hover {
        background: var(--rust);
    }

.secure-note {
    font-size: 11.5px;
    color: var(--ink3);
    text-align: center;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 5px;
}

/* Advantages */
.adv-section {
    padding: 56px 0;
    background: var(--ink);
}

.adv-outer {
    max-width: 1380px;
    margin: 0 auto;
    padding: 0 32px;
}

.adv-head {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    margin-bottom: 40px;
    flex-wrap: wrap;
    gap: 16px;
}

    .adv-head h2 {
        font-family: var(--display);
        font-size: clamp(32px,4vw,52px);
        font-weight: 600;
        color: #fff;
        letter-spacing: -.04em;
        line-height: 1.1;
        max-width: 480px;
    }

        .adv-head h2 em {
            color: var(--wheat);
            font-style: italic;
        }

    .adv-head p {
        font-size: 14px;
        color: rgba(255,255,255,.45);
        max-width: 260px;
        text-align: right;
        line-height: 1.7;
    }

.adv-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 1px;
    background: rgba(255,255,255,.06);
    border: 1px solid rgba(255,255,255,.06);
    border-radius: var(--r2);
    overflow: hidden;
}

.adv-card {
    padding: 28px 24px;
    background: rgba(255,255,255,.025);
}

    .adv-card:hover {
        background: rgba(255,255,255,.055);
    }

.adv-icon {
    width: 36px;
    height: 36px;
    color: var(--wheat);
    margin-bottom: 16px;
}

.adv-num {
    font-family: var(--display);
    font-size: 40px;
    font-weight: 600;
    color: rgba(255,255,255,.15);
    line-height: 1;
    margin-bottom: 4px;
    letter-spacing: -.04em;
}

.adv-title {
    font-size: 14px;
    font-weight: 600;
    color: #fff;
    margin-bottom: 8px;
    letter-spacing: -.01em;
}

.adv-text {
    font-size: 13px;
    color: rgba(255,255,255,.45);
    line-height: 1.65;
}

/* CTA form */
.cta-section {
    padding: 60px 0;
    background: var(--p2);
    border-top: 1px solid var(--border);
    border-bottom: 1px solid var(--border);
}

.cta-outer {
    max-width: 1380px;
    margin: 0 auto;
    padding: 0 32px;
}

.cta-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 56px;
    align-items: center;
}

@media (max-width: 768px) {
    .cta-grid {
        grid-template-columns: 1fr;
    }
}

.cta-text .eyebrow {
    font-size: 11px;
    font-weight: 700;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: var(--rust);
    margin-bottom: 16px;
    display: block;
}

.cta-text h2 {
    font-family: var(--display);
    font-size: clamp(28px,3.5vw,44px);
    font-weight: 600;
    color: var(--ink);
    letter-spacing: -.04em;
    line-height: 1.1;
    margin-bottom: 16px;
}

.cta-text p {
    font-size: 14px;
    color: var(--ink3);
    line-height: 1.75;
    max-width: 420px;
}

.cta-form {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

    .cta-form label {
        font-size: 12px;
        font-weight: 600;
        letter-spacing: .05em;
        text-transform: uppercase;
        color: var(--ink3);
        margin-bottom: -4px;
        display: block;
    }

    .cta-form input, .cta-form textarea, .cta-form select {
        width: 100%;
        padding: 11px 14px;
        background: #fff;
        border: 1px solid var(--border);
        border-radius: var(--r);
        font-size: 14px;
        color: var(--ink);
        resize: none;
    }

        .cta-form input:focus, .cta-form textarea:focus {
            border-color: var(--rust);
            background: #fff;
        }

    .cta-form textarea {
        min-height: 88px;
    }

.cta-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
}

@media (max-width: 768px) {
    .cta-row {
        grid-template-columns: 1fr;
    }
}

.btn-cta {
    padding: 13px;
    background: var(--rust);
    color: #fff;
    border-radius: var(--r);
    font-size: 14px;
    font-weight: 600;
    letter-spacing: .04em;
    border: none;
    cursor: pointer;
}

    .btn-cta:hover {
        background: var(--rust2);
    }

.form-note {
    font-size: 11.5px;
    color: var(--ink4);
    line-height: 1.5;
}

/* Footer */
.site-footer {
    background: var(--ink);
    padding: 56px 0 0;
}

.footer-outer {
    max-width: 1380px;
    margin: 0 auto;
    padding: 0 32px;
}

.footer-grid {
    display: grid;
    grid-template-columns: 2fr 1fr 1fr 1fr;
    gap: 48px;
    padding-bottom: 48px;
    border-bottom: 1px solid rgba(255,255,255,.07);
}

@media (max-width: 1100px) {
    .footer-grid {
        grid-template-columns: 1fr 1fr;
    }
}

@media (max-width: 768px) {
    .footer-grid {
        grid-template-columns: 1fr;
        gap: 28px;
    }
}

.footer-brand .logo {
    font-family: var(--display);
    font-size: 20px;
    font-weight: 600;
    color: #fff;
    letter-spacing: -.02em;
    margin-bottom: 14px;
    display: flex;
    align-items: center;
    gap: 10px;
}

    .footer-brand .logo .lm {
        background: var(--rust);
        width: 28px;
        height: 28px;
        border-radius: 2px;
        display: flex;
        align-items: center;
        justify-content: center;
    }

.footer-brand p {
    font-size: 13px;
    color: rgba(255,255,255,.38);
    line-height: 1.7;
    max-width: 260px;
}

.footer-contacts {
    margin-top: 20px;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

    .footer-contacts a {
        font-size: 13px;
        color: rgba(255,255,255,.5);
        display: flex;
        align-items: center;
        gap: 8px;
    }

        .footer-contacts a:hover {
            color: var(--wheat);
        }

.footer-col h4 {
    font-size: 11px;
    font-weight: 700;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: rgba(255,255,255,.35);
    margin-bottom: 16px;
}

.footer-col ul li {
    margin-bottom: 9px;
}

    .footer-col ul li a {
        font-size: 13px;
        color: rgba(255,255,255,.5);
    }

        .footer-col ul li a:hover {
            color: rgba(255,255,255,.85);
        }

.footer-bottom {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 18px 0;
    flex-wrap: wrap;
    gap: 12px;
}

    .footer-bottom p {
        font-size: 12px;
        color: rgba(255,255,255,.22);
        letter-spacing: .02em;
    }

    .footer-bottom a {
        color: rgba(255,255,255,.22);
    }

        .footer-bottom a:hover {
            color: rgba(255,255,255,.5);
        }

/* Toasts */
.toasts {
    position: fixed;
    bottom: 24px;
    right: 24px;
    z-index: 9999;
    display: flex;
    flex-direction: column;
    gap: 8px;
    pointer-events: none;
}

.toast {
    background: var(--ink);
    color: #fff;
    padding: 12px 18px;
    border-radius: var(--r2);
    font-size: 13.5px;
    font-weight: 500;
    display: flex;
    align-items: center;
    gap: 10px;
    box-shadow: 0 8px 32px rgba(0,0,0,.2);
    pointer-events: auto;
    max-width: 300px;
    border-left: 3px solid var(--wheat);
}

    .toast.success {
        border-left-color: #4A9654;
    }

    .toast.err {
        border-left-color: var(--rust);
    }

@media (max-width: 420px) {
    .toasts {
        left: 12px;
        right: 12px;
        bottom: 16px;
    }
    .toast {
        max-width: none;
        width: 100%;
    }
}

/* Responsive */
@media (max-width: 768px) {
    .nav-inner {
        overflow-x: auto;
        padding: 0 20px;
        -webkit-overflow-scrolling: touch;
    }

    .hero {
        padding: 44px 20px 40px;
    }

    .adv-head {
        flex-direction: column;
    }

        .adv-head p {
            text-align: left;
            max-width: 100%;
        }

    .topbar-inner {
        justify-content: center;
    }

    .topbar-right {
        display: none;
    }

    .cats-section {
        padding: 32px 0;
    }

    .cart-thead, .cart-row {
        grid-template-columns: 60px 1fr auto;
    }

        .cart-th:nth-child(3), .cart-row .cart-unit {
            display: none;
        }
}

/* Cabinet styles */
.ag-cabinet {
    max-width: 1400px;
    margin: 40px auto;
    padding: 0 20px;
}

.ag-cabinet-tabs {
    display: flex;
    gap: 10px;
    border-bottom: 1px solid var(--border);
    margin-bottom: 20px;
}

.ag-tab-btn {
    background: none;
    border: none;
    padding: 10px 20px;
    font-size: 16px;
    cursor: pointer;
    border-bottom: 2px solid transparent;
    color: var(--ink3);
}

    .ag-tab-btn.active {
        color: var(--rust);
        border-bottom-color: var(--rust);
        font-weight: 600;
    }

.ag-tab-pane {
    display: none;
}

.ag-products-table, .ag-admins-table {
    width: 100%;
    border-collapse: collapse;
}

    .ag-products-table th, .ag-products-table td, .ag-admins-table th, .ag-admins-table td {
        padding: 10px;
        text-align: left;
        border-bottom: 1px solid var(--border);
    }

.ag-add-product-btn {
    margin-bottom: 20px;
    background: var(--rust);
    color: white;
    border: none;
    padding: 10px 20px;
    border-radius: var(--r);
    cursor: pointer;
}

#ag-product-form-container {
    background: var(--p2);
    border: 1px solid var(--border);
    border-radius: var(--r2);
    padding: 20px;
    margin-bottom: 20px;
}

#ag-product-form div {
    margin-bottom: 15px;
}

#ag-product-form label {
    display: block;
    margin-bottom: 5px;
    font-weight: 600;
}

#ag-product-form input, #ag-product-form textarea, #ag-product-form select {
    width: 100%;
    padding: 8px;
    border: 1px solid var(--border);
    border-radius: var(--r);
}

.ag-stats-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 20px;
    margin-bottom: 30px;
}

.ag-stat-card {
    background: var(--p2);
    padding: 20px;
    border-radius: var(--r2);
    border: 1px solid var(--border);
}

.ag-stat-title {
    font-size: 13px;
    color: var(--ink3);
    margin-bottom: 8px;
    text-transform: uppercase;
}

.ag-stat-value {
    font-size: 32px;
    font-weight: bold;
    color: var(--ink);
    margin-bottom: 8px;
}

.ag-stat-change.positive {
    color: #2e7d32;
}

.ag-stat-change.negative {
    color: #d32f2f;
}

.ag-popular-content {
    background: var(--p2);
    border: 1px solid var(--border);
    border-radius: var(--r2);
    padding: 20px;
    margin-top: 20px;
}

/* Modal windows */
.cart-modal-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0,0,0,0.5);
    backdrop-filter: blur(4px);
    z-index: 10000;
    display: flex;
    align-items: center;
    justify-content: center;
    visibility: hidden;
    opacity: 0;
    transition: all 0.2s ease;
}

    .cart-modal-overlay.active {
        visibility: visible;
        opacity: 1;
    }

.cart-modal {
    background: var(--p);
    border-radius: 16px;
    width: 90%;
    max-width: 700px;
    max-height: 80vh;
    overflow-y: auto;
    box-shadow: 0 25px 50px -12px rgba(0,0,0,0.25);
    position: relative;
    padding: 24px;
    border: 1px solid var(--border);
}

.cart-modal-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    border-bottom: 1px solid var(--border);
    padding-bottom: 15px;
    margin-bottom: 20px;
}

    .cart-modal-header h2 {
        font-family: var(--display);
        font-size: 24px;
        font-weight: 600;
        color: var(--ink);
    }

.cart-modal-close {
    font-size: 28px;
    cursor: pointer;
    color: var(--ink3);
    transition: color 0.2s;
    line-height: 1;
}

    .cart-modal-close:hover {
        color: var(--rust);
    }

.cart-modal-items {
    margin-bottom: 20px;
    max-height: 50vh;
    overflow-y: auto;
}

.cart-modal-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 12px 0;
    border-bottom: 1px solid var(--border);
    gap: 12px;
    flex-wrap: wrap;
}

.cart-modal-item-photo {
    width: 44px;
    height: 44px;
    border-radius: var(--r);
    overflow: hidden;
    background: var(--p2);
    border: 1px solid var(--border);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

    .cart-modal-item-photo img {
        width: 100%;
        height: 100%;
        object-fit: contain;
    }

    .cart-modal-item-photo i {
        color: var(--p3);
        font-size: 18px;
    }

.cart-modal-item-name {
    flex: 2;
    font-weight: 500;
}

.cart-modal-item-qty {
    display: flex;
    align-items: center;
    gap: 8px;
}

    .cart-modal-item-qty button {
        width: 28px;
        height: 28px;
        background: var(--p2);
        border: none;
        border-radius: var(--r);
        cursor: pointer;
    }

.cart-modal-item-remove {
    background: none;
    border: none;
    color: var(--ink4);
    cursor: pointer;
    font-size: 18px;
}

    .cart-modal-item-remove:hover {
        color: var(--rust);
    }

.cart-modal-footer {
    border-top: 1px solid var(--border);
    padding-top: 20px;
    display: flex;
    justify-content: flex-end;
}

.btn-checkout-modal {
    background: var(--rust);
    color: #fff;
    padding: 10px 20px;
    border: none;
    border-radius: var(--r);
    font-weight: 600;
    cursor: pointer;
}

.empty-cart-message {
    text-align: center;
    color: var(--ink3);
    padding: 30px;
}

.modal-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0,0,0,0.6);
    backdrop-filter: blur(4px);
    z-index: 9999;
    display: flex;
    align-items: center;
    justify-content: center;
    visibility: hidden;
    opacity: 0;
    transition: all 0.2s ease;
}

    .modal-overlay.active {
        visibility: visible;
        opacity: 1;
    }

.modal-container {
    background: var(--p);
    border-radius: 16px;
    width: 90%;
    max-width: 460px;
    max-height: 90vh;
    overflow-y: auto;
    box-shadow: 0 25px 50px -12px rgba(0,0,0,0.25);
    position: relative;
    padding: 28px 24px 32px;
    border: 1px solid var(--border);
}

@media (max-width: 420px) {
    .modal-container {
        padding: 22px 18px 26px;
    }
}

.modal-close {
    position: absolute;
    top: 16px;
    right: 20px;
    font-size: 28px;
    line-height: 1;
    cursor: pointer;
    color: var(--ink3);
    transition: color 0.2s;
}

    .modal-close:hover {
        color: var(--rust);
    }

.modal-tabs {
    display: flex;
    gap: 24px;
    margin-bottom: 24px;
    border-bottom: 2px solid var(--border);
}

.modal-tab {
    font-size: 18px;
    font-weight: 600;
    padding-bottom: 10px;
    cursor: pointer;
    color: var(--ink3);
    border-bottom: 2px solid transparent;
    margin-bottom: -2px;
}

    .modal-tab.active {
        color: var(--rust);
        border-bottom-color: var(--rust);
    }

.modal-form {
    display: none;
}

    .modal-form.active {
        display: block;
    }

    .modal-form input {
        width: 100%;
        padding: 12px 14px;
        margin-bottom: 16px;
        border: 1px solid var(--border);
        border-radius: var(--r);
        background: #fff;
        font-size: 14px;
    }

    .modal-form button {
        width: 100%;
        padding: 12px;
        background: var(--rust);
        color: white;
        border: none;
        border-radius: var(--r);
        font-weight: 600;
        font-size: 14px;
        cursor: pointer;
        margin-top: 8px;
    }

        .modal-form button:hover {
            background: var(--rust2);
        }

.modal-message {
    background: #f8d7da;
    color: #721c24;
    padding: 10px;
    border-radius: 6px;
    margin-bottom: 16px;
    font-size: 13px;
    display: none;
}

    .modal-message.success {
        background: #d4edda;
        color: #155724;
    }

.checkbox-row {
    display: flex;
    align-items: center;
    gap: 8px;
    margin: 12px 0;
}

    .checkbox-row input {
        width: auto;
        margin: 0;
    }

/* Fixes */
input:focus, textarea:focus, select:focus {
    outline: none;
    box-shadow: none;
    border-color: var(--rust);
}

/* Усиление контраста текста в hero-блоке */
.hero-tag {
    font-weight: 800 !important;
    letter-spacing: 0.15em !important;
    text-shadow: 0 2px 4px rgba(0,0,0,0.3);
}

.hero h1 {
    font-weight: 800 !important;
    text-shadow: 0 2px 8px rgba(0,0,0,0.4);
}

    .hero h1 em {
        font-weight: 800 !important;
        text-shadow: 0 2px 8px rgba(0,0,0,0.4);
    }

.hero-sub {
    font-weight: 500 !important;
    text-shadow: 0 1px 3px rgba(0,0,0,0.3);
    color: rgba(255,255,255,0.9) !important;
}

.hero-stats strong {
    font-weight: 800 !important;
    text-shadow: 0 1px 3px rgba(0,0,0,0.3);
}

.hero-search-wrap input::placeholder {
    font-weight: 400;
    color: rgba(255,255,255,0.6);
}

.hero-search-btn {
    font-weight: 700 !important;
    letter-spacing: 0.08em;
}

/* Футер – новая сетка 3 колонки */
.site-footer .footer-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 40px;
    padding-bottom: 40px;
    border-bottom: 1px solid rgba(255,255,255,0.1);
}

@media (max-width: 900px) {
    .site-footer .footer-grid {
        grid-template-columns: 1fr 1fr;
        gap: 28px;
    }
}

@media (max-width: 560px) {
    .site-footer .footer-grid {
        grid-template-columns: 1fr;
        gap: 32px;
    }
    .site-footer { padding: 40px 0 0; }
    .footer-outer { padding: 0 20px; }
    .footer-bottom { text-align: center; justify-content: center; padding: 20px 0 16px; }
}

/* Стили для колонок */
.footer-col h4 {
    font-size: 16px;
    font-weight: 600;
    color: #fff;
    margin-bottom: 20px;
    letter-spacing: 0.5px;
}

.footer-about-text {
    font-size: 13px;
    line-height: 1.6;
    color: rgba(255,255,255,0.5);
    max-width: 300px;
}

.footer-col ul {
    list-style: none;
    padding: 0;
}

    .footer-col ul li {
        margin-bottom: 12px;
    }

        .footer-col ul li a {
            color: rgba(255,255,255,0.5);
            text-decoration: none;
            font-size: 13px;
            transition: color 0.2s;
        }

            .footer-col ul li a:hover {
                color: var(--wheat);
            }

.footer-contacts-list li {
    margin-bottom: 15px;
    font-size: 13px;
    color: rgba(255,255,255,0.5);
    line-height: 1.5;
}

    .footer-contacts-list li strong {
        color: rgba(255,255,255,0.7);
        font-weight: 600;
        display: block;
        margin-bottom: 4px;
    }

    .footer-contacts-list li a {
        color: rgba(255,255,255,0.5);
        text-decoration: none;
    }

        .footer-contacts-list li a:hover {
            color: var(--wheat);
        }

.footer-col ul li a:hover {
    color: var(--rust) !important;
}

.footer-bottom a:hover {
    color: rgba(255,255,255,0.7) !important;
}

/* Отступы между пунктами меню */
.nav-inner {
    gap: 20px;
}

    .nav-inner a {
        padding-left: 18px;
        padding-right: 18px;
    }

/* Иконка трактора в логотипе — белая и видимая */
.logo-mark i {
    color: #ffffff !important;
    font-size: 20px;
}

/* ============================================
   Карточка товара / техники (single-equipment.php, single-product.php)
   Общие стили вынесены сюда чтобы избежать дублирования и ускорить загрузку
   ============================================ */
.eq-single-wrap {
  max-width: 1200px; margin: 0 auto; padding: 40px 20px;
  display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: start;
}
.eq-gallery-col { position: sticky; top: 20px; }
.eq-main-photo-wrap {
  position: relative; background: var(--p2); border: 1px solid var(--border);
  border-radius: 16px; overflow: hidden; aspect-ratio: 4/3;
  display: flex; align-items: center; justify-content: center;
  padding: 24px;
}
.eq-main-photo-wrap img#eq-main-img,
.eq-main-photo-wrap img#prod-main-img {
  width: 100%; height: 100%; object-fit: contain; display: block; cursor: zoom-in;
}
.eq-no-photo { font-size: 64px; color: var(--ink4); }
.eq-arrow {
  position: absolute; top: 50%; transform: translateY(-50%);
  background: rgba(0,0,0,0.55); color: #fff; border: none;
  width: 40px; height: 40px; border-radius: 50%; cursor: pointer;
  font-size: 16px; display: flex; align-items: center; justify-content: center;
  transition: background .15s; z-index: 2;
}
.eq-arrow:hover { background: rgba(0,0,0,0.8); }
.eq-arrow-prev { left: 12px; }
.eq-arrow-next { right: 12px; }
.eq-counter {
  position: absolute; bottom: 12px; left: 50%; transform: translateX(-50%);
  background: rgba(0,0,0,0.5); color: #fff; font-size: 12px;
  padding: 3px 10px; border-radius: 20px; pointer-events: none;
}
.eq-zoom-btn {
  position: absolute; top: 12px; right: 12px;
  background: rgba(0,0,0,0.4); color: #fff; border: none;
  width: 36px; height: 36px; border-radius: 8px; cursor: pointer;
  font-size: 15px; display: flex; align-items: center; justify-content: center;
  transition: background .15s; z-index: 2;
}
.eq-zoom-btn:hover { background: rgba(0,0,0,0.7); }
.eq-thumbs {
  display: flex; gap: 8px; margin-top: 12px; flex-wrap: wrap;
}
.eq-thumb-item {
  width: 72px; height: 72px; border-radius: 8px; overflow: hidden;
  border: 2px solid var(--border); cursor: pointer; transition: border-color .15s;
  flex-shrink: 0;
}
.eq-thumb-item img { width: 100%; height: 100%; object-fit: cover; display: block; }
.eq-thumb-item.active, .eq-thumb-item:hover { border-color: var(--rust); }

/* Info col */
.eq-title { font-family: var(--display); font-size: clamp(22px,3vw,36px); font-weight: 600; color: var(--ink); margin-bottom: 16px; }
.eq-badges { margin-bottom: 16px; }
.eq-cond-badge { display: inline-flex; align-items: center; gap: 6px; font-size: 13px; font-weight: 700; padding: 7px 16px; border-radius: 20px; box-shadow: 0 2px 6px rgba(0,0,0,0.12); letter-spacing: .02em; }
.eq-price { font-size: 38px; font-weight: 700; color: var(--rust); margin-bottom: 20px; }
.eq-price-na { font-size: 22px; color: var(--ink3); margin-bottom: 20px; }
.eq-desc { font-size: 15px; line-height: 1.75; color: var(--ink2); margin-bottom: 28px; }
.eq-actions { display: flex; gap: 12px; flex-wrap: wrap; margin-bottom: 28px; }
.eq-btn { padding: 13px 24px; border-radius: 40px; font-size: 15px; font-weight: 600; text-decoration: none; display: inline-flex; align-items: center; gap: 8px; transition: .15s; }
.eq-btn-call {
  background: var(--rust); color: #fff; box-shadow: 0 4px 14px rgba(196,82,26,0.3);
}
.eq-btn-call:hover { background: #a84118; box-shadow: 0 6px 18px rgba(196,82,26,0.4); transform: translateY(-1px); }
.eq-btn-inquiry {
  background: var(--ink); color: #fff; box-shadow: 0 4px 14px rgba(0,0,0,0.18);
}
.eq-btn-inquiry:hover { background: #000; box-shadow: 0 6px 18px rgba(0,0,0,0.25); transform: translateY(-1px); }
.eq-meta-list { display: flex; flex-direction: column; gap: 10px; }
.eq-meta-row { display: flex; align-items: center; gap: 10px; font-size: 14px; color: var(--ink2); background: var(--p2); padding: 10px 14px; border-radius: 10px; }
.eq-meta-row i { color: var(--rust); width: 16px; }

/* Lightbox */
.eq-lightbox { display: none; position: fixed; inset: 0; z-index: 9999; overflow: hidden; }
.eq-lightbox.open { display: flex; align-items: center; justify-content: center; }
.eq-lightbox-overlay { position: absolute; inset: 0; background: rgba(0,0,0,0.88); cursor: pointer; }
.eq-lightbox-inner { position: relative; z-index: 1; max-width: 90vw; max-height: 90vh; }
.eq-lightbox-inner img { max-width: 90vw; max-height: 85vh; object-fit: contain; border-radius: 4px; display: block; }
.eq-lightbox-close {
  position: absolute; top: -44px; right: 0;
  background: rgba(255,255,255,0.15); color: #fff; border: none;
  width: 36px; height: 36px; border-radius: 50%; font-size: 16px; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
}
.eq-lightbox-arrow {
  position: absolute; top: 50%; transform: translateY(-50%);
  background: rgba(255,255,255,0.15); color: #fff; border: none;
  width: 44px; height: 44px; border-radius: 50%; font-size: 18px; cursor: pointer;
  display: flex; align-items: center; justify-content: center; transition: background .15s;
}
.eq-lightbox-arrow:hover { background: rgba(255,255,255,0.3); }
.eq-lightbox-prev { left: 16px; }
.eq-lightbox-next { right: 16px; }

@media (max-width: 768px) {
  .eq-single-wrap { grid-template-columns: 1fr !important; gap: 24px; }
  .eq-gallery-col { position: static; }
  .eq-lightbox-prev { left: 8px; } .eq-lightbox-next { right: 8px; }
  .eq-lightbox-close { top: 8px; right: 8px; background: rgba(0,0,0,0.45); }
}

/* ============================================
   МОБИЛЬНОЕ МЕНЮ (гамбургер + выезжающая панель)
   ============================================ */

.mobile-menu-toggle {
  display: none;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  background: var(--p2);
  border: 1.5px solid var(--border);
  border-radius: 10px;
  cursor: pointer;
  font-size: 17px;
  color: var(--ink);
  transition: background .15s;
  flex-shrink: 0;
  margin-left: 4px;
}
.mobile-menu-toggle:hover { background: var(--border); }

.mobile-nav-overlay {
  display: none;
  position: fixed; inset: 0;
  background: rgba(0,0,0,0.45);
  z-index: 1998;
  backdrop-filter: blur(2px);
}
.mobile-nav-overlay.open { display: block; }

.mobile-nav-panel {
  position: fixed;
  top: 0; right: 0; bottom: 0;
  width: min(320px, 86vw);
  background: #fff;
  z-index: 1999;
  display: flex;
  flex-direction: column;
  box-shadow: -6px 0 32px rgba(0,0,0,0.18);
  transform: translateX(110%);
  transition: transform .3s cubic-bezier(.4,0,.2,1);
  overflow-y: auto;
}
.mobile-nav-panel.open { transform: translateX(0); }

.mobile-nav-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 18px 20px;
  border-bottom: 1px solid var(--border);
  font-family: var(--display);
  font-size: 16px;
  font-weight: 600;
  color: var(--ink);
  flex-shrink: 0;
}
.mobile-nav-close {
  width: 34px; height: 34px;
  background: var(--p2); border: none; border-radius: 8px;
  cursor: pointer; font-size: 15px; color: var(--ink3);
  display: flex; align-items: center; justify-content: center;
  transition: background .15s;
}
.mobile-nav-close:hover { background: var(--border); }

.mobile-nav-links { flex: 1; padding: 8px 0; }

.mobile-nav-link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 20px;
  font-size: 15px;
  font-weight: 500;
  color: var(--ink2);
  text-decoration: none;
  border-bottom: 1px solid var(--p2);
  transition: background .12s, color .12s;
}
.mobile-nav-link i { font-size: 12px; color: var(--ink4); }
.mobile-nav-link:hover { background: var(--p2); color: var(--rust); }
.mobile-nav-link.mobile-nav-active {
  color: var(--rust);
  font-weight: 700;
  background: rgba(196,82,26,0.05);
}
.mobile-nav-link.mobile-nav-active i { color: var(--rust); }

.mobile-nav-contacts {
  padding: 18px 20px;
  border-top: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  gap: 12px;
  flex-shrink: 0;
}
.mobile-nav-contacts a {
  display: flex; align-items: center; gap: 10px;
  font-size: 14px; color: var(--ink3); text-decoration: none;
  transition: color .15s;
}
.mobile-nav-contacts a i { color: var(--rust); width: 16px; }
.mobile-nav-contacts a:hover { color: var(--rust); }

/* ============================================
   ПОЛНАЯ МОБИЛЬНАЯ АДАПТАЦИЯ
   Точки перелома: 1100px, 768px, 480px, 375px
   ============================================ */

@media (max-width: 1100px) {
  /* Навигация — скрытие длинных подписей */
  .site-logo { font-size: 18px; }
  .nav-link { padding: 10px 13px; font-size: 12.5px; }
  .header-inner { gap: 16px; padding: 0 20px; }
}

@media (max-width: 860px) {
  /* Показываем гамбургер, скрываем десктопную навигацию */
  .mobile-menu-toggle { display: flex; }
  .site-nav { display: none; }

  /* Шапка — две строки: (1) логотип + кнопки, (2) поиск на всю ширину */
  .header-inner {
    grid-template-columns: 1fr auto;
    grid-template-rows: auto auto;
    padding: 10px 16px;
    height: auto;
    row-gap: 10px;
    gap: 12px;
  }
  .site-logo { font-size: 16px; grid-column: 1; grid-row: 1; }
  .site-logo img { height: 34px !important; }
  .header-actions { grid-column: 2; grid-row: 1; }
  .header-search {
    grid-column: 1 / -1;
    grid-row: 2;
    max-width: 100%;
    width: 100%;
  }
  .header-search input { padding: 11px 42px 11px 15px; font-size: 14px; }
  .search-suggestions { left: 0; right: 0; }

  /* Топбар — только телефон */
  .topbar-contacts a:last-child { display: none; }
  .topbar-right { display: none; }
  .topbar-inner { padding: 0 16px; }

  /* Кнопки хэдера — скрываем текст, оставляем иконки */
  .hbtn .hbtn-label { display: none; }
  .hbtn { padding: 8px 10px; min-width: unset; font-size: 13px; }
  .header-divider { display: none; }
}

@media (max-width: 768px) {
  /* Главная страница — hero */
  .hero { padding: 36px 16px 32px; }
  .hero h1 { font-size: clamp(26px, 7vw, 38px); }
  .hero-inner-content { padding: 22px 18px; border-radius: 14px; }
  .hero-stats { flex-wrap: wrap; gap: 10px; }
  .hero-divider { display: none; }
  .hero-stat strong { font-size: 20px; }
  .hero-stat span { font-size: 11px; }

  /* Сетки каталога, техники */
  .arc-results-grid { grid-template-columns: repeat(2, 1fr); gap: 10px; }

  /* О компании — блоки */
  .about-grid { grid-template-columns: 1fr !important; }
  .why-grid { grid-template-columns: 1fr; }
  .stats-strip { grid-template-columns: repeat(2, 1fr); }

  /* Доставка и оплата */
  .req-grid-2col { grid-template-columns: 1fr !important; }

  /* Корзина */
  .cart-layout { grid-template-columns: 1fr !important; }
  .cart-summary { position: static !important; }

  /* Бренды */
  .brands-grid { grid-template-columns: repeat(2, 1fr) !important; }
  .brand-card { min-height: 150px !important; padding: 20px 14px !important; }
  .brand-card-logo { height: 70px !important; }
  .brand-card-logo img { max-height: 70px !important; }
  .brand-card-initial { width: 60px !important; height: 60px !important; font-size: 22px !important; }

  /* Страница товара/техники */
  .eq-single-wrap { grid-template-columns: 1fr !important; gap: 20px; padding: 24px 16px !important; }
  .eq-gallery-col { position: static !important; }
  .eq-actions { flex-wrap: wrap; }
  .eq-btn { flex: 1; justify-content: center; min-width: 140px; }

  /* Доставка — карточки */
  div[style*="minmax(260px,1fr)"] { grid-template-columns: 1fr !important; }
}

@media (max-width: 480px) {
  /* Очень маленькие экраны */
  .arc-results-grid { grid-template-columns: 1fr; }
  .brands-grid { grid-template-columns: 1fr !important; }
  .stats-strip { grid-template-columns: 1fr; }

  /* Корзина — упрощённые строки */
  .cart-row {
    grid-template-columns: 52px 1fr !important;
    grid-template-rows: auto auto;
  }
  .cart-item-photo { width: 52px !important; height: 52px !important; }

  /* Хлебные крошки — укорачиваем */
  .breadcrumbs-inner { font-size: 12px; }

  /* Форма заказа */
  .cart-summary { padding: 18px 14px !important; }

  /* Реквизиты */
  code#req-iban { font-size: 11px !important; letter-spacing: 0 !important; }
}

@media (max-width: 375px) {
  /* iPhone SE, Galaxy A series */
  .header-inner { padding: 10px 12px; gap: 8px; }
  .site-logo img { height: 28px !important; }
  .hero-inner-content { padding: 16px 14px; }
  .arc-product-card .arc-card-body { padding: 10px; }
  .arc-card-name { font-size: 13px; }
}


/* ============================================
   Карточки товаров (каталог + похожие товары на странице товара)
   Вынесено в общий файл, чтобы работало одинаково на archive-product.php и single-product.php
   ============================================ */
.arc-results-grid {
  display:grid; grid-template-columns:repeat(4,1fr); gap:22px;
}
.arc-product-card {
  background:#fff; border:1px solid var(--border); border-radius:14px;
  overflow:hidden; display:flex; flex-direction:column; transition:box-shadow .18s, transform .18s, border-color .18s;
}
.arc-product-card:hover { box-shadow:0 8px 24px rgba(0,0,0,0.09); transform:translateY(-3px); border-color:#e8ddd0; }

.arc-card-img-link { display:block; text-decoration:none; }
.arc-card-img {
  aspect-ratio:1; overflow:hidden; background:var(--p2);
  margin:12px 12px 0; border-radius:10px;
  display:flex; align-items:center; justify-content:center;
  border:1px solid var(--border);
}
.arc-card-img img {
  width:88%; height:88%; object-fit:contain; display:block;
  transition:transform .2s;
}
.arc-product-card:hover .arc-card-img img { transform:scale(1.04); }
.arc-card-img i { color:var(--p3); font-size:32px; }

.arc-card-body { padding:12px 14px 8px; flex:1; display:flex; flex-direction:column; gap:6px; }
.arc-card-brand { font-size:11px; font-weight:700; color:var(--ink4); letter-spacing:.5px; text-transform:uppercase; display:flex; align-items:center; gap:5px; }
.arc-card-sku { font-size:12px; color:var(--ink3); display:flex; align-items:center; gap:5px; font-family:monospace; }
.arc-card-name { font-size:13.5px; font-weight:600; color:var(--ink); text-decoration:none; line-height:1.4; }
.arc-card-name:hover { color:var(--rust); }
.arc-card-badge { display:inline-flex; align-items:center; gap:5px; font-size:11px; font-weight:700; padding:3px 9px; border-radius:20px; margin-top:4px; align-self:flex-start; }
.arc-card-foot { padding:0 14px 14px; }
.arc-card-foot .btn-add,
.cat-card-foot .btn-add { width: 100%; padding: 10px; font-size: 13px; border-radius: 8px; }

@media(max-width:1000px){ .arc-results-grid{ grid-template-columns:repeat(3,1fr); gap:18px; } }
@media(max-width:680px) { .arc-results-grid{ grid-template-columns:repeat(2,1fr); gap:14px; } }
@media(max-width:400px) { .arc-results-grid{ grid-template-columns:1fr; } }

/* ============================================
   Боковые отступы контейнеров на маленьких экранах
   (раньше оставались 32px с каждой стороны даже на узких телефонах)
   ============================================ */
@media (max-width: 600px) {
  .breadcrumbs-inner,
  .cats-inner,
  .cart-outer,
  .nav-inner {
    padding: 0 16px;
  }
}
@media (max-width: 380px) {
  .breadcrumbs-inner,
  .cats-inner,
  .cart-outer {
    padding: 0 12px;
  }
}

