/* =====================================================================
   PRINTINGLIFE — HEADER
   Минималистичная двухрядная sticky-шапка с B2B-ориентацией.
   Токены — локально, позже вынесу в printinglife-tokens.css.
   ===================================================================== */

:root {
    --pl-brand:        #fe2e46;
    --pl-brand-dark:   #e61e36;
    --pl-ink:          #41496D;
    --pl-ink-soft:     #5a6180;
    --pl-text:         #1e293b;
    --pl-muted:        #64748b;
    --pl-line:         #e8eaf0;
    --pl-line-soft:    #f1f3f7;
    --pl-bg:           #ffffff;
    --pl-bg-soft:      #f8fafc;
    --pl-bg-tint:      #fff5f6;

    --pl-radius-sm:    6px;
    --pl-radius-md:    10px;
    --pl-radius-lg:    14px;
    --pl-radius-pill:  999px;

    --pl-transition:   180ms cubic-bezier(0.4, 0, 0.2, 1);
    --pl-shadow:       0 1px 3px rgba(15, 23, 42, 0.04), 0 4px 16px rgba(15, 23, 42, 0.06);
    --pl-shadow-pop:   0 8px 28px rgba(15, 23, 42, 0.12);

    --pl-header-top-h:  40px;
    --pl-header-main-h: 80px;

    /* === Единая ширина контейнера для всех printinglife-* страниц === */
    --pl-page-px: 4rem;
}

@media (max-width: 960px) {
    :root { --pl-page-px: 2rem; }
}

@media (max-width: 640px) {
    :root { --pl-page-px: 1rem; }
}

/* ===== Хост ===== */
.pl-header {
    position: sticky;
    top: 0;
    z-index: 100;
    background: var(--pl-bg);
    border-bottom: 1px solid var(--pl-line);
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
    font-feature-settings: "ss01", "cv11";
    -webkit-font-smoothing: antialiased;
}

/* === Базовый reset кнопок в printinglife-scope ===
   Legacy modern-update.css стилизует все <button> глобально
   (красный фон, padding, радиус). Нам нужен чистый лист,
   чтобы .pl-*/.plc-* классы сами задавали стиль. */
.pl-header button,
.pl-catalog button,
.pl-modal button,
.pl-mobile-nav button,
.plc-page button,
.pl-discount button,
.pl-dealer button,
.pl-kontakty button,
.pl-bloknoty button,
.pl-footer button {
    background: transparent;
    color: inherit;
    border: 0;
    padding: 0;
    border-radius: 0;
    font: inherit;
    line-height: inherit;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0;
    cursor: pointer;
}

.pl-header__container {
    width: 100%;
    max-width: 100%;
    margin: 0;
    padding: 0 var(--pl-page-px);
    display: flex;
    align-items: center;
    gap: 1rem;
    height: 100%;
}

/* ===== Верхняя тонкая полоса (top utility) ===== */
.pl-header__top {
    height: var(--pl-header-top-h);
    background: var(--pl-bg-soft);
    border-bottom: 1px solid var(--pl-line-soft);
    font-size: 0.8125rem;
    color: var(--pl-muted);
    overflow: hidden;
    transition: height var(--pl-transition), border-color var(--pl-transition);
}

.pl-header[data-scrolled="true"] .pl-header__top {
    height: 0;
    border-bottom-color: transparent;
}

.pl-header__top .pl-header__container {
    justify-content: space-between;
}

.pl-header__top-left,
.pl-header__top-center,
.pl-header__top-right {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

/* Текстовое nav в top-bar (Главная, Контакты) */
.pl-top-nav {
    display: inline-flex;
    align-items: center;
    gap: 1rem;
}

.pl-top-nav__link {
    font-size: 0.8125rem;
    font-weight: 500;
    color: var(--pl-ink);
    text-decoration: none;
    white-space: nowrap;
    transition: color var(--pl-transition);
}

.pl-top-nav__link:hover {
    color: var(--pl-brand);
}

.pl-utility {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    white-space: nowrap;
    color: var(--pl-muted);
    text-decoration: none;
    transition: color var(--pl-transition);
}

.pl-utility--accent {
    color: var(--pl-brand);
    font-weight: 600;
}

.pl-utility--accent:hover {
    color: var(--pl-brand-dark);
}

.pl-utility svg,
.pl-icon-link svg {
    width: 16px;
    height: 16px;
    flex-shrink: 0;
}

/* Контакты-текстом (телефон, email) в верхней полосе */
.pl-header__contact {
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--pl-ink);
    text-decoration: none;
    letter-spacing: 0.01em;
    white-space: nowrap;
    transition: color var(--pl-transition);
}

.pl-header__contact--phone {
    font-size: 0.9375rem;
}

.pl-header__contact:hover {
    color: var(--pl-brand);
}

/* Тонкий разделитель между группами */
.pl-header__divider {
    width: 1px;
    height: 18px;
    background: var(--pl-line);
    margin: 0 0.25rem;
}

.pl-icon-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    border-radius: var(--pl-radius-sm);
    color: var(--pl-muted);
    text-decoration: none;
    transition: all var(--pl-transition);
}

.pl-icon-link:hover {
    color: var(--pl-brand);
    background: var(--pl-bg-tint);
}

/* Дилер-чип */
.pl-dealer-chip {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    padding: 0.28rem 0.7rem 0.28rem 0.85rem;
    border: 1px solid var(--pl-line);
    border-radius: var(--pl-radius-pill);
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--pl-ink);
    text-decoration: none;
    background: var(--pl-bg);
    transition: all var(--pl-transition);
}

.pl-dealer-chip svg { width: 12px; height: 12px; }

.pl-dealer-chip:hover {
    border-color: var(--pl-brand);
    color: var(--pl-brand);
}

.pl-dealer-chip--active {
    background: var(--pl-brand);
    border-color: var(--pl-brand);
    color: #fff;
}
.pl-dealer-chip--active:hover {
    background: var(--pl-brand-dark);
    border-color: var(--pl-brand-dark);
    color: #fff;
}

/* ===== Основная полоса ===== */
.pl-header__main {
    height: var(--pl-header-main-h);
}

/* Равномерное распределение разделов во второй строке */
.pl-header__main > .pl-header__container {
    justify-content: space-between;
}

/* Логотип */
.pl-logo {
    display: inline-flex;
    align-items: center;
    text-decoration: none;
    color: var(--pl-ink);
    flex-shrink: 0;
    transition: opacity var(--pl-transition);
}

.pl-logo:hover { opacity: 0.85; }

.pl-logo__text {
    display: inline-flex;
    flex-direction: column;
    line-height: 1.15;
}

.pl-logo__name {
    font-weight: 800;
    font-size: 1.375rem;
    letter-spacing: -0.02em;
    color: var(--pl-ink);
}

.pl-logo__dot {
    color: var(--pl-brand);
}

.pl-logo__tag {
    font-size: 0.72rem;
    font-weight: 500;
    color: var(--pl-muted);
    letter-spacing: 0.01em;
    margin-top: 2px;
}

/* Каталог-кнопка */
.pl-catalog-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    height: 44px;
    padding: 0 1.1rem;
    background: var(--pl-ink);
    color: #fff;
    border: 0;
    border-radius: var(--pl-radius-md);
    font-weight: 600;
    font-size: 0.875rem;
    cursor: pointer;
    transition: background var(--pl-transition), transform var(--pl-transition);
    white-space: nowrap;
    flex-shrink: 0;
}

.pl-catalog-btn svg {
    width: 18px;
    height: 18px;
}

.pl-catalog-btn:hover {
    background: #2f3656;
}

.pl-catalog-btn[aria-expanded="true"] {
    background: var(--pl-brand);
}

/* Поиск — белый фон, фикс. размер (no flex-grow), чтобы space-between
   распределял запас места равномерно между всеми разделами */
.pl-search {
    position: relative;
    flex: 0 1 460px;
    min-width: 220px;
    max-width: 460px;
    display: flex;
    align-items: center;
    height: 46px;
    background: var(--pl-bg);
    border: 1.5px solid var(--pl-line);
    border-radius: var(--pl-radius-md);
    transition: all var(--pl-transition);
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.03);
}

.pl-search:hover {
    border-color: #cfd3df;
}

.pl-search:focus-within {
    border-color: var(--pl-ink);
    box-shadow: 0 0 0 3px rgba(65, 73, 109, 0.08);
}

.pl-search__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    color: var(--pl-muted);
    pointer-events: none;
}

.pl-search__icon svg {
    width: 18px;
    height: 18px;
}

.pl-search__input {
    flex: 1;
    border: 0;
    background: transparent;
    outline: none;
    font-size: 0.9rem;
    color: var(--pl-text);
    padding-right: 1rem;
}

.pl-search__input::placeholder {
    color: var(--pl-muted);
}

/* Убираем дефолтный «крестик» браузера у input[type=search] —
   используем свой .pl-search__clear */
.pl-search__input::-webkit-search-cancel-button,
.pl-search__input::-webkit-search-decoration {
    -webkit-appearance: none;
    appearance: none;
}
.pl-search__input::-ms-clear {
    display: none;
    width: 0;
    height: 0;
}

/* === Поиск — крестик очистки === */
.pl-search__clear {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    margin-right: 4px;
    border: 0;
    background: transparent;
    border-radius: 6px;
    color: var(--pl-muted);
    cursor: pointer;
    transition: all 160ms ease;
}

.pl-search__clear[hidden] { display: none; }

.pl-search__clear svg {
    width: 18px;
    height: 18px;
}

.pl-search__clear:hover {
    color: var(--pl-brand);
    background: var(--pl-bg-tint);
}

/* === Поиск — выпадающий список результатов === */
.pl-search__results {
    position: absolute;
    top: calc(100% + 8px);
    left: 0;
    right: 0;
    background: var(--pl-bg);
    border: 1px solid var(--pl-line);
    border-radius: var(--pl-radius-md);
    box-shadow: var(--pl-shadow-pop);
    max-height: 520px;
    overflow-y: auto;
    z-index: 110;
    padding: 0.5rem 0;
    scrollbar-width: thin;
    scrollbar-color: var(--pl-line) transparent;
}

.pl-search__results::-webkit-scrollbar { width: 6px; }
.pl-search__results::-webkit-scrollbar-thumb { background: var(--pl-line); border-radius: 3px; }

.pl-search__section + .pl-search__section {
    border-top: 1px solid var(--pl-line-soft);
    margin-top: 0.35rem;
    padding-top: 0.35rem;
}

.pl-search__section-title {
    padding: 0.4rem 1rem 0.25rem;
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--pl-muted);
}

.pl-search__result {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.55rem 1rem;
    text-decoration: none;
    color: var(--pl-text);
    transition: background 140ms ease;
    border: 0;
}

.pl-search__result:hover,
.pl-search__result--hl {
    background: var(--pl-bg-soft);
}

.pl-search__result mark {
    background: transparent;
    color: var(--pl-brand);
    font-weight: 600;
}

.pl-search__result-main {
    flex: 1;
    min-width: 0;
}

.pl-search__result-title {
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--pl-ink);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.pl-search__result-sub {
    margin-top: 2px;
    font-size: 0.75rem;
    color: var(--pl-muted);
}

.pl-search__result-price {
    flex-shrink: 0;
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--pl-brand);
    white-space: nowrap;
}

/* Превью товара */
.pl-search__thumb {
    width: 40px;
    height: 40px;
    border-radius: 6px;
    background: var(--pl-bg-soft);
    flex-shrink: 0;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
}

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

.pl-search__thumb--empty::after {
    content: '';
    display: block;
    width: 16px;
    height: 16px;
    border-radius: 3px;
    border: 1.5px dashed var(--pl-line);
}

/* Иконка раздела для категорий */
.pl-search__cat-icon {
    width: 18px;
    height: 18px;
    flex-shrink: 0;
    background-color: var(--pl-muted);
    -webkit-mask: url(/public/images/icons/cat-folder.svg) no-repeat center / contain;
            mask: url(/public/images/icons/cat-folder.svg) no-repeat center / contain;
}

.pl-search__result--cat:hover .pl-search__cat-icon {
    background-color: var(--pl-brand);
}

/* Сервисные строки */
.pl-search__loading {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.6rem;
    padding: 1rem;
    color: var(--pl-muted);
    font-size: 0.875rem;
}

.pl-search__spinner {
    width: 14px;
    height: 14px;
    border: 2px solid var(--pl-line);
    border-top-color: var(--pl-brand);
    border-radius: 50%;
    animation: pl-spin 700ms linear infinite;
}

.pl-search__empty {
    padding: 1.5rem 1rem;
    text-align: center;
    color: var(--pl-muted);
    font-size: 0.875rem;
}

.pl-search__empty p { margin: 0; }
.pl-search__empty strong { color: var(--pl-ink); }

.pl-search__all {
    display: block;
    padding: 0.7rem 1rem;
    margin-top: 0.25rem;
    border-top: 1px solid var(--pl-line-soft);
    text-align: center;
    color: var(--pl-brand);
    text-decoration: none;
    font-size: 0.8125rem;
    font-weight: 600;
    transition: background 140ms ease;
}

.pl-search__all:hover,
.pl-search__all.pl-search__result--hl {
    background: var(--pl-bg-tint);
}

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

/* CTA — «Рассчитать заказ» */
.pl-cta {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    height: 44px;
    padding: 0 1.2rem;
    background: var(--pl-brand);
    color: #fff;
    text-decoration: none;
    border-radius: var(--pl-radius-md);
    font-weight: 600;
    font-size: 0.875rem;
    white-space: nowrap;
    flex-shrink: 0;
    transition: all var(--pl-transition);
    box-shadow: 0 1px 2px rgba(254, 46, 70, 0.25);
}

.pl-cta svg {
    width: 18px;
    height: 18px;
}

.pl-cta:hover {
    background: var(--pl-brand-dark);
    box-shadow: 0 4px 12px rgba(254, 46, 70, 0.3);
    transform: translateY(-1px);
}

/* Группа правого угла — корзина + пользователь. Благодаря
 * justify-content: space-between на контейнере сами собой окажутся у края.
 */
.pl-header__actions {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    padding-left: 1rem;
    border-left: 1px solid var(--pl-line);
    flex-shrink: 0;
}

/* Акшны (корзина/пользователь) */
.pl-action {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    border-radius: var(--pl-radius-md);
    color: var(--pl-ink);
    text-decoration: none;
    transition: all var(--pl-transition);
    flex-shrink: 0;
    background: transparent;
    border: 0;
    cursor: pointer;
}

.pl-action svg {
    width: 22px;
    height: 22px;
}

.pl-action:hover {
    background: var(--pl-bg-soft);
    color: var(--pl-brand);
}

.pl-badge {
    position: absolute;
    top: 4px;
    right: 4px;
    min-width: 18px;
    height: 18px;
    padding: 0 4px;
    background: var(--pl-brand);
    color: #fff;
    border-radius: var(--pl-radius-pill);
    font-size: 0.65rem;
    font-weight: 700;
    line-height: 18px;
    text-align: center;
    border: 2px solid var(--pl-bg);
    pointer-events: none;
}

/* Пользовательское меню */
.pl-user {
    position: relative;
}

.pl-user__btn {
    width: 44px;
    height: 44px;
    border: 0;
    background: transparent;
    border-radius: var(--pl-radius-md);
    color: var(--pl-ink);
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: all var(--pl-transition);
}

.pl-user__btn svg { width: 22px; height: 22px; }

.pl-user__btn:hover {
    background: var(--pl-bg-soft);
    color: var(--pl-brand);
}

.pl-user__menu {
    position: absolute;
    top: calc(100% + 8px);
    right: 0;
    min-width: 220px;
    background: var(--pl-bg);
    border: 1px solid var(--pl-line);
    border-radius: var(--pl-radius-md);
    box-shadow: var(--pl-shadow-pop);
    padding: 0.5rem;
    z-index: 110;
}

.pl-user__head {
    padding: 0.6rem 0.75rem;
    border-bottom: 1px solid var(--pl-line-soft);
    margin-bottom: 0.4rem;
}

.pl-user__head strong {
    display: block;
    font-size: 0.875rem;
    color: var(--pl-text);
}

.pl-user__head small {
    display: block;
    font-size: 0.75rem;
    color: var(--pl-muted);
    margin-top: 2px;
}

.pl-user__item {
    display: block;
    padding: 0.55rem 0.75rem;
    font-size: 0.875rem;
    color: var(--pl-text);
    text-decoration: none;
    border-radius: var(--pl-radius-sm);
    transition: background var(--pl-transition), color var(--pl-transition);
}

.pl-user__item:hover {
    background: var(--pl-bg-soft);
    color: var(--pl-ink);
}

.pl-user__item--logout {
    color: var(--pl-brand);
}

.pl-user__item--logout:hover {
    background: var(--pl-bg-tint);
    color: var(--pl-brand);
}

/* Бургер — только на мобилках */
.pl-burger {
    display: none;
    width: 44px;
    height: 44px;
    border: 0;
    background: transparent;
    cursor: pointer;
    border-radius: var(--pl-radius-md);
    padding: 0;
    position: relative;
    flex-shrink: 0;
}

.pl-burger span {
    display: block;
    width: 20px;
    height: 2px;
    background: var(--pl-ink);
    border-radius: 2px;
    margin: 4px auto;
    transition: all var(--pl-transition);
}

.pl-burger[aria-expanded="true"] span:nth-child(1) {
    transform: translateY(6px) rotate(45deg);
}
.pl-burger[aria-expanded="true"] span:nth-child(2) {
    opacity: 0;
}
.pl-burger[aria-expanded="true"] span:nth-child(3) {
    transform: translateY(-6px) rotate(-45deg);
}

/* Мобильное меню */
.pl-mobile-nav {
    display: none;
    background: var(--pl-bg);
    border-top: 1px solid var(--pl-line);
    padding: 1rem 1.5rem 1.5rem;
    flex-direction: column;
    gap: 0.5rem;
}

.pl-mobile-nav[aria-hidden="false"] {
    display: flex;
}

.pl-mobile-nav__search {
    position: relative;
    display: flex;
    align-items: center;
    height: 44px;
    background: var(--pl-bg-soft);
    border-radius: var(--pl-radius-md);
    margin-bottom: 0.5rem;
}

.pl-mobile-nav__link {
    display: block;
    padding: 0.75rem 0.5rem;
    color: var(--pl-text);
    text-decoration: none;
    font-weight: 500;
    font-size: 1rem;
    border-bottom: 1px solid var(--pl-line-soft);
}

.pl-mobile-nav__link:last-of-type {
    border-bottom: 0;
}

.pl-mobile-nav__contacts {
    margin-top: 1rem;
    padding-top: 1rem;
    border-top: 1px solid var(--pl-line);
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.pl-mobile-nav__phone {
    font-size: 1.125rem;
    font-weight: 700;
    color: var(--pl-ink);
    text-decoration: none;
}

.pl-mobile-nav__messengers {
    display: flex;
    gap: 0.75rem;
}

.pl-mobile-nav__messengers a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border: 1px solid var(--pl-line);
    border-radius: var(--pl-radius-md);
    color: var(--pl-ink);
    transition: all var(--pl-transition);
}

.pl-mobile-nav__messengers a svg {
    width: 20px;
    height: 20px;
}

.pl-mobile-nav__messengers a:hover {
    border-color: var(--pl-brand);
    color: var(--pl-brand);
}

/* ===== Адаптивность ===== */

/* До 1200px — прячем text-часть логотипа, оставляем mark */
@media (max-width: 1200px) {
    .pl-logo__text {
        display: none;
    }
    .pl-search {
        max-width: none;
    }
}

/* До 1024px — CTA сжимается */
@media (max-width: 1024px) {
    .pl-cta span {
        display: none;
    }
    .pl-cta {
        width: 44px;
        padding: 0;
        justify-content: center;
    }
}

/* До 1100px — в top-bar прячем email-текст, оставляем телефон */
@media (max-width: 1100px) {
    .pl-header__contact:not(.pl-header__contact--phone) {
        display: none;
    }
    .pl-header__divider {
        display: none;
    }
}

/* До 900px — top-bar упрощается до телефона + мессенджеров + дилер */
@media (max-width: 900px) {
    .pl-utility:first-child,
    .pl-top-nav,
    .pl-header__top-left .pl-header__divider {
        display: none;
    }
}

/* До 768px — мобильный режим: скрываем всё кроме лого/поиска/корзины/бургера */
@media (max-width: 768px) {
    :root {
        --pl-header-main-h: 64px;
        --pl-header-top-h: 36px;
    }

    .pl-header__container {
        padding: 0 1rem;
        gap: 0.5rem;
    }

    .pl-catalog-btn,
    .pl-cta,
    .pl-user,
    .pl-header__top {
        display: none;
    }
    .pl-header__actions {
        margin-left: auto;
        padding-left: 0;
        border-left: 0;
    }

    /* Pop-up: top-bar вшит в мобильное меню — вернём top-bar при открытом меню, нет, не надо */

    .pl-logo__text { display: none; }

    .pl-search {
        order: 10;
        width: 100%;
        display: none; /* показываем через бургер-меню, в main-ряду пока скрыт */
    }

    .pl-burger {
        display: inline-flex;
        align-items: center;
        justify-content: center;
    }

    .pl-action + .pl-action {
        margin-left: 0;
    }
}

@media (max-width: 480px) {
    .pl-logo__mark {
        width: 36px;
        height: 36px;
        font-size: 1.2rem;
    }
}
