/* ============================================================
   ООО "Комрат" — клиентский сайт
   Палитра: graphite + cobalt blue
   Шрифты: Saira (UI), Saira Condensed (заголовки), JetBrains Mono (цифры)
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Saira+Condensed:wght@500;600;700&family=Saira:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500;700&display=swap');

:root {
    --navy-900: #141619;
    --navy-800: #1e2125;
    --navy-700: #2a2e33;
    --navy-600: #394049;
    --accent:     #2f6fd0;
    --accent-600: #2459ac;
    --accent-100: #dde9f9;
    --ink:        #16202c;
    --steel-700:  #3d4a5a;
    --steel-600:  #5a6776;
    --steel-500:  #7a8794;
    --steel-400:  #9aa6b2;
    --steel-300:  #c3cbd4;
    --steel-200:  #dde2e8;
    --steel-100:  #eef1f4;
    --steel-50:   #f5f7f9;
    --line:       #dde2e8;
    --line-strong:#c3cbd4;
    --ok:  #1f9d57;  --ok-bg:  #e4f4ea;
    --low: #e0961a;  --low-bg: #fbefda;
    --no:  #9aa6b2;
    --err: #c62828;  --err-bg: #fce4ec;
    --f-display: 'Saira Condensed', sans-serif;
    --f-head:    'Saira', sans-serif;
    --f-body:    'Segoe UI', 'Saira', sans-serif;
    --f-mono:    'JetBrains Mono', monospace;
    --maxw: 1320px;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html, body { height: 100%; }
body {
    font-family: var(--f-body);
    color: var(--ink);
    background: #fff;
    font-size: 15px;
    line-height: 1.5;
    -webkit-font-smoothing: antialiased;
    display: flex;
    flex-direction: column;
}
a { color: inherit; text-decoration: none; }
button { font-family: inherit; cursor: pointer; }
img { max-width: 100%; display: block; }

.container { max-width: var(--maxw); margin: 0 auto; padding: 0 28px; }
main { flex: 1; }

/* ============================================================
   HEADER
   ============================================================ */
.header {
    background: var(--navy-800);
    color: #fff;
    position: sticky;
    top: 0;
    z-index: 50;
    border-bottom: 1px solid var(--navy-700);
}
.header__inner {
    display: flex;
    align-items: center;
    gap: 24px;
    height: 70px;
}
.logo {
    display: flex;
    align-items: center;
    gap: 11px;
    flex-shrink: 0;
}
.logo__icon {
    width: 38px; height: 38px;
    background: var(--accent);
    border-radius: 4px;
    display: grid; place-items: center;
    font-size: 18px;
    color: #fff;
    box-shadow: inset 0 0 0 2px rgba(255,255,255,.18);
}
.logo__text {
    font-family: var(--f-display);
    font-weight: 700;
    font-size: 22px;
    letter-spacing: .5px;
    text-transform: uppercase;
    color: #fff;
}

.nav {
    display: flex;
    align-items: center;
    gap: 4px;
}
.nav__link {
    font-family: var(--f-head);
    font-weight: 500;
    font-size: 14px;
    color: #aebccb;
    padding: 8px 14px;
    border-radius: 4px;
    transition: color .12s, background .12s;
}
.nav__link:hover { color: #fff; }
.nav__link--active { color: #fff; background: rgba(255,255,255,.06); }

.header__actions {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-left: auto;
}

.search {
    display: flex;
    height: 38px;
}
.search__input {
    border: none;
    outline: none;
    padding: 0 14px;
    width: 220px;
    font-family: var(--f-body);
    font-size: 13.5px;
    background: rgba(255,255,255,.08);
    color: #fff;
    border-radius: 4px 0 0 4px;
}
.search__input::placeholder { color: rgba(255,255,255,.5); }
.search__btn {
    border: none;
    background: var(--accent);
    color: #fff;
    width: 42px;
    border-radius: 0 4px 4px 0;
    display: grid; place-items: center;
    font-size: 14px;
}
.search__btn:hover { background: var(--accent-600); }

.cart-btn {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    background: rgba(255,255,255,.16);
    border: 1px solid rgba(255,255,255,.24);
    color: #fff;
    padding: 8px 14px;
    border-radius: 4px;
    font-family: var(--f-head);
    font-weight: 500;
    font-size: 13.5px;
    position: relative;
}
.cart-btn:hover { background: rgba(255,255,255,.26); }
.cart-btn__count {
    background: var(--accent);
    color: #fff;
    font-family: var(--f-mono);
    font-weight: 700;
    font-size: 11px;
    min-width: 18px;
    height: 18px;
    border-radius: 9px;
    padding: 0 5px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.auth-login-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: var(--accent);
    color: #fff;
    padding: 8px 16px;
    border-radius: 4px;
    font-family: var(--f-head);
    font-weight: 600;
    font-size: 13.5px;
}
.auth-login-btn:hover { background: var(--accent-600); }

/* User dropdown menu */
.user-menu { position: relative; }
.user-menu__btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: rgba(255,255,255,.16);
    border: 1px solid rgba(255,255,255,.24);
    color: #fff;
    padding: 6px 12px;
    border-radius: 4px;
    font-family: var(--f-head);
    font-weight: 500;
    font-size: 13.5px;
}
.user-menu__btn:hover { background: rgba(255,255,255,.26); }
.user-menu__avatar {
    width: 26px; height: 26px;
    border-radius: 50%;
    background: var(--accent);
    color: #fff;
    display: grid; place-items: center;
    font-family: var(--f-head);
    font-weight: 700;
    font-size: 12px;
}
.user-menu__arrow { font-size: 9px; color: #aebccb; }
.user-menu__dropdown {
    position: absolute; top: calc(100% + 6px); right: 0;
    background: #fff;
    border: 1px solid var(--line);
    border-radius: 6px;
    box-shadow: 0 8px 24px rgba(0,0,0,.16);
    min-width: 240px;
    display: none;
    overflow: hidden;
    z-index: 100;
}
.user-menu__dropdown.is-open { display: block; }
.user-menu__header {
    padding: 14px 16px;
    background: var(--steel-50);
    border-bottom: 1px solid var(--line);
}
.user-menu__full-name {
    font-family: var(--f-head);
    font-weight: 600;
    font-size: 14px;
    color: var(--ink);
}
.user-menu__email {
    font-family: var(--f-mono);
    font-size: 12px;
    color: var(--steel-500);
    margin-top: 2px;
}
.user-menu__item {
    display: block;
    padding: 11px 16px;
    color: var(--steel-700);
    font-size: 13.5px;
    font-family: var(--f-head);
    font-weight: 500;
    background: none;
    border: none;
    width: 100%;
    text-align: left;
}
.user-menu__item:hover { background: var(--steel-50); color: var(--accent); }
.user-menu__item--logout { color: var(--err); }
.user-menu__item--logout:hover { background: var(--err-bg); color: var(--err); }
.user-menu__divider { height: 1px; background: var(--line); }

/* ============================================================
   FLASH MESSAGES
   ============================================================ */
.flash {
    max-width: var(--maxw);
    margin: 16px auto 0;
    padding: 12px 18px;
    border-radius: 4px;
    font-size: 14px;
    font-weight: 600;
    border: 1px solid transparent;
}
.flash--success { background: var(--ok);  color: #fff; border-color: var(--ok); }
.flash--error   { background: var(--err); color: #fff; border-color: var(--err); }

/* ============================================================
   PAGE HERO (универсальная шапка страниц)
   ============================================================ */
.page-hero {
    background: var(--steel-50);
    padding: 32px 0 28px;
    border-bottom: 1px solid var(--line);
}
.page-hero__crumbs {
    display: flex; align-items: center; gap: 9px;
    font-size: 13px; color: var(--steel-500); margin-bottom: 14px;
}
.page-hero__crumbs a { color: var(--steel-500); }
.page-hero__crumbs a:hover { color: var(--accent); }
.page-hero__crumbs .s { color: var(--steel-300); }
.page-hero__title {
    font-family: var(--f-display);
    font-weight: 700;
    font-size: 38px;
    line-height: 1.05;
    text-transform: uppercase;
    letter-spacing: .3px;
    color: var(--ink);
    margin: 0 0 6px;
}
.page-hero__sub { color: var(--steel-500); font-size: 14px; }

/* ============================================================
   SECTIONS / PANELS / CARDS
   ============================================================ */
.section { padding: 40px 0; }
.section--gray { background: var(--steel-50); }

.panel {
    background: #fff;
    border: 1px solid var(--line);
    border-radius: 6px;
}
.panel-pad { padding: 22px; }
.panel-head {
    padding: 14px 22px;
    border-bottom: 1px solid var(--line);
    font-family: var(--f-head);
    font-weight: 600;
    font-size: 13.5px;
    color: var(--ink);
    text-transform: uppercase;
    letter-spacing: .4px;
}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    font-family: var(--f-head);
    font-weight: 600;
    font-size: 14px;
    padding: 11px 22px;
    border-radius: 4px;
    border: 1.5px solid transparent;
    cursor: pointer;
    text-decoration: none;
    line-height: 1;
    white-space: nowrap;
    transition: background .12s, border-color .12s, color .12s;
}
.btn--primary { background: var(--accent); color: #fff; }
.btn--primary:hover { background: var(--accent-600); }
.btn--dark    { background: var(--navy-800); color: #fff; }
.btn--dark:hover { background: var(--navy-700); }
.btn--outline { background: #fff; color: var(--ink); border-color: var(--line-strong); }
.btn--outline:hover { border-color: var(--accent); color: var(--accent); }
.btn--soft    { background: var(--steel-100); color: var(--steel-700); }
.btn--soft:hover { background: var(--steel-200); }
.btn--sm { padding: 7px 14px; font-size: 12.5px; }
.btn--block { display: flex; width: 100%; }

/* ============================================================
   FORMS
   ============================================================ */
.field { display: block; }
.field > span,
.field > label {
    display: block;
    font-family: var(--f-head);
    font-weight: 600;
    font-size: 11.5px;
    text-transform: uppercase;
    letter-spacing: .4px;
    color: var(--steel-600);
    margin-bottom: 6px;
}
.input, .select, .textarea {
    width: 100%;
    border: 1px solid var(--line-strong);
    border-radius: 4px;
    padding: 10px 13px;
    font-family: var(--f-body);
    font-size: 14px;
    background: #fff;
    color: var(--ink);
    outline: none;
}
.input:focus, .select:focus, .textarea:focus {
    border-color: var(--accent);
    box-shadow: 0 0 0 3px var(--accent-100);
}
.textarea { resize: vertical; min-height: 84px; }

/* ============================================================
   TABLES
   ============================================================ */
.tbl {
    width: 100%;
    background: #fff;
    border: 1px solid var(--line);
    border-radius: 6px;
    border-collapse: separate;
    border-spacing: 0;
    overflow: hidden;
}
.tbl thead th {
    background: var(--steel-50);
    font-family: var(--f-head);
    font-weight: 600;
    font-size: 11.5px;
    text-transform: uppercase;
    letter-spacing: .5px;
    color: var(--steel-600);
    text-align: left;
    padding: 12px 14px;
    border-bottom: 2px solid var(--line-strong);
    white-space: nowrap;
}
.tbl thead th.num { text-align: right; }
.tbl thead th.ctr { text-align: center; }
.tbl tbody td {
    padding: 12px 14px;
    border-bottom: 1px solid var(--line);
    font-size: 14px;
    vertical-align: middle;
    color: var(--steel-700);
}
.tbl tbody tr:last-child td { border-bottom: none; }
.tbl tbody tr:hover { background: var(--steel-50); }
.tbl .mono { font-family: var(--f-mono); }
.tbl .num  { text-align: right; font-family: var(--f-mono); }
.tbl .name { font-family: var(--f-head); font-weight: 600; color: var(--ink); }
.tbl .art  { font-family: var(--f-mono); font-size: 12px; color: var(--steel-500); }

/* ============================================================
   BADGES / DOTS
   ============================================================ */
.badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-family: var(--f-head);
    font-weight: 600;
    font-size: 11px;
    letter-spacing: .4px;
    text-transform: uppercase;
    padding: 3px 9px;
    border-radius: 3px;
}
.badge--ok        { background: var(--ok-bg);  color: var(--ok); }
.badge--low       { background: var(--low-bg); color: var(--low); }
.badge--no        { background: var(--steel-100); color: var(--steel-500); }
.badge--new       { background: var(--accent-100); color: var(--accent); }
.badge--paid      { background: var(--accent-100); color: var(--accent-600); }
.badge--processing{ background: var(--low-bg); color: var(--low); }
.badge--shipped   { background: var(--ok-bg);  color: var(--ok); }
.badge--delivered { background: var(--ok-bg);  color: #1b5e20; }
.badge--cancelled { background: var(--err-bg); color: var(--err); }

.dot {
    width: 8px; height: 8px; border-radius: 50%;
    display: inline-block; flex-shrink: 0;
}
.dot--ok  { background: var(--ok); }
.dot--low { background: var(--low); }
.dot--no  { background: var(--no); }

/* ============================================================
   PRODUCT CARD (используется на главной)
   ============================================================ */
.product-card {
    background: #fff;
    border: 1px solid var(--line);
    border-radius: 6px;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    transition: border-color .15s, box-shadow .15s;
}
.product-card:hover {
    border-color: var(--accent);
    box-shadow: 0 4px 16px rgba(15,27,46,.08);
}
.product-card__img {
    aspect-ratio: 4/3;
    background:
        repeating-linear-gradient(135deg, var(--steel-100) 0 10px, var(--steel-50) 10px 20px);
    display: grid; place-items: center;
    color: var(--steel-400);
    border-bottom: 1px solid var(--line);
}
.product-card__img svg { width: 60%; opacity: .85; }
.product-card__body { padding: 14px 16px 18px; flex: 1; display: flex; flex-direction: column; }
.product-card__name {
    font-family: var(--f-head);
    font-weight: 600;
    font-size: 14.5px;
    color: var(--ink);
    line-height: 1.35;
    margin-bottom: 4px;
}
.product-card__art {
    font-family: var(--f-mono);
    font-size: 11.5px;
    color: var(--steel-500);
    margin-bottom: 12px;
}
.product-card__bottom {
    margin-top: auto;
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 8px;
}
.product-card__price {
    font-family: var(--f-mono);
    font-weight: 700;
    font-size: 17px;
    color: var(--ink);
}
.product-card__price small {
    display: block;
    font-weight: 400;
    font-size: 11px;
    color: var(--steel-400);
}

/* ============================================================
   FOOTER
   ============================================================ */
.footer {
    background: var(--navy-900);
    color: #aebccb;
    margin-top: 48px;
    font-size: 14px;
}
.footer__inner {
    padding: 44px 0 32px;
    display: grid;
    grid-template-columns: 1.6fr 1fr 1fr 1.2fr;
    gap: 36px;
}
.footer a:hover { color: #fff; }
.footer__col .logo__text { color: #fff; }
.footer__desc { color: var(--steel-500); font-size: 13.5px; margin-top: 14px; line-height: 1.5; }
.footer__heading {
    color: #fff;
    font-family: var(--f-head);
    font-weight: 600;
    font-size: 13px;
    text-transform: uppercase;
    letter-spacing: .6px;
    margin-bottom: 14px;
}
.footer__list { list-style: none; display: flex; flex-direction: column; gap: 9px; }
.footer__list a { color: #aebccb; font-size: 13.5px; }
.footer__list--contacts li { font-family: var(--f-mono); font-size: 13px; color: #aebccb; }
.footer__bottom {
    border-top: 1px solid var(--navy-700);
    padding: 18px 0;
    font-size: 12.5px;
    color: var(--steel-500);
}

/* ============================================================
   PAGINATION (.pager — кастомный шаблон vendor/pagination/jbi)
   ============================================================ */
.pager {
    display: flex;
    align-items: center;
    gap: 6px;
    flex-wrap: wrap;
    justify-content: center;
    font-family: var(--f-mono, 'JetBrains Mono', monospace);
}
.pager__btn,
.pager__num {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 38px;
    height: 38px;
    padding: 0 10px;
    border: 1px solid var(--steel-200);
    border-radius: 6px;
    background: #fff;
    color: var(--ink);
    font-size: 14px;
    line-height: 1;
    text-decoration: none;
    transition: border-color .15s, background .15s, color .15s;
}
.pager__btn { font-size: 18px; }
.pager__btn:hover,
.pager__num:hover {
    border-color: var(--accent);
    color: var(--accent);
}
.pager__num.is-active {
    background: var(--accent);
    border-color: var(--accent);
    color: #fff;
}
.pager__btn.is-disabled {
    color: var(--steel-300);
    border-color: var(--steel-100);
    background: var(--steel-50);
    pointer-events: none;
}
.pager__dots { padding: 0 4px; color: var(--steel-400); }

/* ============================================================
   RESPONSIVE
   ============================================================ */

/* Кнопка-бургер: скрыта на десктопе, появляется на мобильных */
.burger {
    display: none;
    background: none;
    border: none;
    color: #fff;
    font-size: 26px;
    line-height: 1;
    cursor: pointer;
    padding: 4px 8px;
    margin-left: 6px;
}

@media (max-width: 1100px) {
    .burger { display: block; }

    /* Навигация превращается в выпадающую панель под шапкой */
    .nav {
        display: none;
        position: absolute;
        top: 100%;
        left: 0;
        right: 0;
        flex-direction: column;
        align-items: stretch;
        gap: 0;
        background: var(--navy-800);
        border-top: 1px solid var(--navy-700);
        border-bottom: 1px solid var(--navy-700);
        padding: 6px 0;
        box-shadow: 0 12px 24px rgba(0,0,0,.25);
        z-index: 60;
    }
    .nav.is-open { display: flex; }
    .nav__link { padding: 13px 22px; border-radius: 0; font-size: 15px; }

    .search__input { width: 160px; }
    .footer__inner { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 760px) {
    .header__inner { gap: 12px; }
    .search { display: none; }
    .user-menu__name { display: none; }
    .footer__inner { grid-template-columns: 1fr; }
}
