/* ═══════════════════════════════════════════════
   NBC Invoice — страница «Спасибо» + счёт А4
   ═══════════════════════════════════════════════ */

:root {
    --inv-navy:    #1B2356;
    --inv-navy-2:  #0E1433;
    --inv-gold:    #C49953;
    --inv-cream:   #FAF6F0;
    --inv-cream-d: #F0E8DA;
    --inv-text:    #2A2A2A;
    --inv-muted:   #6B6B6B;
    --inv-border:  rgba(27,35,86,.12);
}

/* ── Страница «Спасибо» ─────────────────────── */

.nbc-inv-thanks {
    background: var(--inv-cream);
    min-height: 100vh;
    padding: 120px 24px 80px;
    font-family: 'Montserrat', sans-serif;
    color: var(--inv-text);
}
.nbc-inv-thanks__wrap {
    max-width: 1240px;
    margin: 0 auto;
}
/* Шапка: слева (под колонкой «Детали заказа», 360px) — заголовок + подзаголовок,
   справа (под превью счёта, 1fr) — телефон заведения. */
.nbc-inv-thanks__head {
    display: grid;
    grid-template-columns: 360px 1fr;
    gap: 32px;
    align-items: end;
    margin-bottom: 40px;
}
.nbc-inv-thanks__head-left  { text-align: left; }
.nbc-inv-thanks__head-right { text-align: right; }
.nbc-inv-thanks__title {
    font-family: 'Spectral', serif;
    font-weight: 400;
    font-size: 36px;
    color: var(--inv-navy);
    margin: 0 0 10px;
    line-height: 1.2;
}
.nbc-inv-thanks__sub {
    font-size: 14px;
    color: var(--inv-muted);
    margin: 0;
    line-height: 1.6;
}
.nbc-inv-thanks__phone {
    font-family: 'Spectral', serif;
    font-size: 26px;
    color: var(--inv-navy);
    font-weight: 400;
    text-decoration: none;
    display: inline-block;
    margin-bottom: 6px;
}
.nbc-inv-thanks__phone:hover { color: var(--inv-gold, #C49953); }
.nbc-inv-thanks__phone-note {
    font-size: 13px;
    color: var(--inv-muted);
    margin: 0;
    line-height: 1.5;
}

@media (max-width: 768px) {
    .nbc-inv-thanks__head {
        grid-template-columns: 1fr;
        gap: 20px;
        align-items: start;
    }
    .nbc-inv-thanks__head-right { text-align: left; }
}

.nbc-inv-thanks__grid {
    display: grid;
    grid-template-columns: 360px 1fr;
    gap: 32px;
    align-items: start;
}

/* ── Инфо-блок слева ───────────────────────── */

.nbc-inv-info {
    background: #fff;
    border-radius: 16px;
    padding: 28px 24px;
    box-shadow: 0 2px 18px rgba(27,35,86,.06);
}
.nbc-inv-info__title {
    font-family: 'Spectral', serif;
    font-weight: 500;
    font-size: 22px;
    color: var(--inv-navy);
    margin: 0 0 18px;
}
.nbc-inv-info__row {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    padding: 8px 0;
    border-bottom: 1px dashed var(--inv-border);
    font-size: 13px;
}
.nbc-inv-info__row span { color: var(--inv-muted); flex-shrink: 0; }
.nbc-inv-info__row strong { color: var(--inv-text); text-align: right; font-weight: 500; }

.nbc-inv-info__subtitle {
    font-family: 'Spectral', serif;
    font-weight: 500;
    font-size: 16px;
    color: var(--inv-navy);
    margin: 22px 0 10px;
}
.nbc-inv-info__items { list-style: none; margin: 0; padding: 0; }
.nbc-inv-info__items li {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    padding: 8px 0;
    border-bottom: 1px dashed var(--inv-border);
    font-size: 13px;
}
.nbc-inv-info__iname { color: var(--inv-text); }
.nbc-inv-info__iprice { color: var(--inv-text); font-weight: 500; white-space: nowrap; }

.nbc-inv-info__total {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    margin-top: 18px;
    padding-top: 14px;
    border-top: 1px solid var(--inv-border);
}
.nbc-inv-info__total span { color: var(--inv-muted); font-size: 13px; }
.nbc-inv-info__total strong {
    font-family: 'Spectral', serif;
    font-weight: 500;
    font-size: 22px;
    color: var(--inv-navy);
}

.nbc-inv-info__status { margin-top: 14px; }
.nbc-inv-status {
    display: inline-block;
    padding: 6px 14px;
    border-radius: 100px;
    font-size: 11px;
    font-weight: 500;
    letter-spacing: .04em;
    text-transform: uppercase;
}
.nbc-inv-status--wait { background: #FEF3C7; color: #92400E; }
.nbc-inv-status--paid { background: #D1FAE5; color: #065F46; }

/* ── Превью счёта справа ───────────────────── */

.nbc-inv-preview {
    background: #fff;
    border-radius: 16px;
    padding: 20px;
    box-shadow: 0 2px 18px rgba(27,35,86,.06);
    overflow: hidden;
}
.nbc-inv-preview__hint {
    font-size: 12px;
    color: var(--inv-muted);
    text-align: center;
    margin-bottom: 14px;
    font-style: italic;
}

/* Контейнер-рамка, в который счёт встаёт по ширине; высота подстраивается JS */
.nbc-inv-scaler {
    width: 100%;
    overflow: hidden;
    cursor: zoom-in;
    position: relative;
}
.nbc-inv-scaler .nbc-inv-paper {
    transform-origin: top left;
    width: 210mm;
    min-height: 297mm;
    box-shadow: 0 1px 6px rgba(0,0,0,.05);
}

/* ── Кнопки под «Деталями заказа» ── */
.nbc-inv-info__buttons {
    display: flex;
    flex-direction: column;
    gap: 10px;
    margin-top: 20px;
    padding-top: 16px;
    border-top: 1px solid var(--inv-border);
}
.nbc-inv-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 12px 22px;
    border-radius: 100px;
    border: 1px solid var(--inv-border);
    background: #fff;
    color: var(--inv-navy);
    font-family: 'Montserrat', sans-serif;
    font-size: 13px;
    font-weight: 500;
    cursor: pointer;
    text-decoration: none;
    transition: all .3s;
}
.nbc-inv-btn svg { width: 16px; height: 16px; }
.nbc-inv-btn:hover { border-color: var(--inv-gold); color: var(--inv-gold); }
a.nbc-inv-btn--account,
a.nbc-inv-btn--account:link,
a.nbc-inv-btn--account:visited,
a.nbc-inv-btn--account:hover,
a.nbc-inv-btn--account:active,
a.nbc-inv-btn--account:focus {
    background: var(--inv-navy) !important;
    color: #FFFFFF !important;
    border-color: var(--inv-navy) !important;
    text-decoration: none !important;
}
a.nbc-inv-btn--account:hover {
    background: var(--inv-navy-2) !important;
    border-color: var(--inv-navy-2) !important;
}

.nbc-inv-empty {
    text-align: center;
    padding: 80px 20px;
    color: var(--inv-muted);
    font-family: 'Montserrat', sans-serif;
}
.nbc-inv-empty a { color: var(--inv-gold); }

/* ══════════════════════════════════════════════
   Счёт А4
   ══════════════════════════════════════════════ */

.nbc-inv-paper {
    width: 210mm;
    min-height: 297mm;
    background: #fff;
    padding: 18mm 15mm;
    box-sizing: border-box;
    font-family: 'Times New Roman', Times, serif;
    color: #000;
    font-size: 10pt;
    line-height: 1.35;
}

.nbc-inv-doc__topnote {
    text-align: center;
    font-size: 9pt;
    margin-bottom: 12px;
    line-height: 1.4;
}

/* Блок банковских реквизитов */
.nbc-inv-doc__bank {
    width: 100%;
    border-collapse: collapse;
    margin-bottom: 10px;
}
.nbc-inv-doc__bank td {
    border: 1px solid #000;
    padding: 4px 6px;
    font-size: 9pt;
    vertical-align: middle;
}
.nbc-inv-doc__bank-name { width: 55%; font-weight: 400; line-height: 1.3; }
.nbc-inv-doc__bank-label { font-size: 7pt; color: #555; display: block; margin-top: 3px; font-style: italic; }
.nbc-inv-doc__bank-k { width: 8%; text-align: center; font-size: 8pt; color: #333; }
.nbc-inv-doc__bank-v { width: 37%; font-size: 10pt; letter-spacing: .2px; }
.nbc-inv-doc__bank-k2 { font-size: 9pt; }
.nbc-inv-doc__bank-pay { font-weight: 500; line-height: 1.3; }

/* Заголовок документа */
.nbc-inv-doc__title {
    font-size: 14pt;
    font-weight: 700;
    margin: 12px 0 10px;
    padding-bottom: 5px;
    border-bottom: 2px solid #000;
}

/* Стороны */
.nbc-inv-doc__parties { margin-bottom: 12px; }
.nbc-inv-doc__party { display: flex; gap: 8px; font-size: 9.5pt; margin-bottom: 4px; }
.nbc-inv-doc__party-label { flex: 0 0 110px; color: #555; }
.nbc-inv-doc__party-val { flex: 1; }

/* Таблица позиций */
.nbc-inv-doc__items {
    width: 100%;
    border-collapse: collapse;
    margin-bottom: 0;
    font-size: 9.5pt;
}
.nbc-inv-doc__items th,
.nbc-inv-doc__items td {
    border: 1px solid #000;
    padding: 4px 6px;
    vertical-align: top;
}
.nbc-inv-doc__items th { background: #f0f0f0; font-weight: 700; text-align: center; }
.nbc-inv-doc__items .c-num   { width: 5%;  text-align: center; }
.nbc-inv-doc__items .c-name  { width: 55%; }
.nbc-inv-doc__items .c-qty   { width: 8%;  text-align: center; }
.nbc-inv-doc__items .c-unit  { width: 7%;  text-align: center; }
.nbc-inv-doc__items .c-price { width: 12%; text-align: right; }
.nbc-inv-doc__items .c-sum   { width: 13%; text-align: right; }

/* Итоги */
.nbc-inv-doc__totals {
    width: 45%;
    margin-left: auto;
    border-collapse: collapse;
    margin-top: 0;
    font-size: 10pt;
}
.nbc-inv-doc__totals td {
    padding: 3px 8px;
    border: none;
}
.nbc-inv-doc__totals td:first-child { text-align: right; font-weight: 500; }
.nbc-inv-doc__totals td:last-child  { text-align: right; font-variant-numeric: tabular-nums; }
.nbc-inv-doc__totals-all td { font-weight: 700; border-top: 1px solid #000; padding-top: 5px; }

.nbc-inv-doc__count { margin: 10px 0 4px; font-size: 9.5pt; }
.nbc-inv-doc__words { margin: 0 0 14px; font-size: 9.5pt; }
.nbc-inv-doc__words strong { font-weight: 700; }

.nbc-inv-doc__terms {
    font-size: 7.5pt;
    line-height: 1.3;
    text-align: justify;
    margin-top: 10px;
    color: #222;
}

/* Подпись + печать (слева) + место под QR (справа) */
.nbc-inv-doc__sign {
    display: grid;
    grid-template-columns: 1fr 150px;
    gap: 18px;
    margin-top: 18px;
    padding-top: 6px;
    align-items: start;
}
.nbc-inv-doc__sign-wrap {
    position: relative;
    min-height: 120px;
    padding-top: 8px;
}
.nbc-inv-doc__sign-line {
    display: flex;
    align-items: baseline;
    gap: 14px;
    font-size: 10pt;
    border-bottom: 1px solid #000;
    padding-bottom: 2px;
    max-width: 420px;
    margin-left: 150px;                 /* сдвиг вправо, чтобы печать села у «Руководитель» */
}
.nbc-inv-doc__sign-line span:first-child { flex: 0 0 auto; }
.nbc-inv-doc__sign-name { flex: 1; text-align: left; font-weight: 500; }
.nbc-inv-doc__seal {
    position: absolute;
    top: -18px;
    left: 0;                            /* печать слева, у слова «Руководитель» */
    width: 195px;
    height: auto;
    opacity: .92;
    pointer-events: none;
}

/* Слот под QR-код */
.nbc-inv-doc__qr {
    width: 150px;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
}
.nbc-inv-doc__qr img {
    width: 150px;
    height: 150px;
    display: block;
    border: 1px solid #e5e5e5;
    background: #fff;
    padding: 3px;
    box-sizing: border-box;
}
.nbc-inv-doc__qr-cap {
    font-size: 8pt;
    color: #555;
    text-align: center;
    line-height: 1.3;
}

/* ══════════════════════════════════════════════
   Модалка zoom
   ══════════════════════════════════════════════ */

.nbc-inv-modal {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(14,20,51,.85);
    z-index: 9999;
    overflow-y: auto;
    padding: 40px 20px;
}
.nbc-inv-modal.show { display: block; }
.nbc-inv-modal__body {
    max-width: 210mm;
    margin: 0 auto;
    background: #fff;
    box-shadow: 0 10px 60px rgba(0,0,0,.4);
}
.nbc-inv-modal__body .nbc-inv-paper--large {
    transform: none;
    width: 100%;
    min-height: auto;
}
.nbc-inv-modal__close {
    position: fixed;
    top: 20px; right: 24px;
    width: 44px; height: 44px;
    border-radius: 50%;
    background: #fff;
    border: none;
    color: var(--inv-navy);
    font-size: 28px;
    line-height: 1;
    cursor: pointer;
    z-index: 10000;
    box-shadow: 0 4px 16px rgba(0,0,0,.2);
}
.nbc-inv-modal__close:hover { background: var(--inv-gold); color: #fff; }

/* ══════════════════════════════════════════════
   Адаптив
   ══════════════════════════════════════════════ */

@media (max-width: 900px) {
    .nbc-inv-thanks__grid { grid-template-columns: 1fr; }
    .nbc-inv-thanks__title { font-size: 26px; }
    .nbc-inv-scaler .nbc-inv-paper { transform: scale(.42); margin-bottom: -58%; }
    .nbc-inv-paper { padding: 12mm 10mm; }
}

/* ══════════════════════════════════════════════
   PRINT
   ══════════════════════════════════════════════ */

@media print {
    @page { size: A4; margin: 0; }

    /* Полностью убираем всё лишнее из DOM (display:none), чтобы не занимало
       высоту макета. visibility: hidden не годится — остаётся в layout. */
    html, body {
        background: #fff !important;
        margin: 0 !important;
        padding: 0 !important;
        width: 210mm !important;
    }
    body > *:not(.nbc-inv-thanks) { display: none !important; }

    /* Внутри .nbc-inv-thanks оставляем только preview со счётом */
    .nbc-inv-thanks,
    .nbc-inv-thanks__wrap { display: block !important; padding: 0 !important; margin: 0 !important; background: #fff !important; }
    .nbc-inv-thanks__head,
    .nbc-inv-info,
    .nbc-inv-preview__hint,
    .nbc-inv-modal,
    .nbc-mobile-cart-btn,
    #wpadminbar { display: none !important; }

    .nbc-inv-preview { box-shadow: none !important; background: transparent !important; padding: 0 !important; margin: 0 !important; border: 0 !important; }
    .nbc-inv-scaler  { overflow: visible !important; border: 0 !important; padding: 0 !important; margin: 0 !important; height: auto !important; background: transparent !important; }

    .nbc-inv-paper {
        position: static !important;
        width: 210mm !important;
        max-width: 210mm !important;
        min-height: 0 !important;        /* критично — иначе 297mm + padding = 2 страницы */
        height: auto !important;
        margin: 0 !important;
        padding: 8mm 12mm !important;
        transform: none !important;
        box-shadow: none !important;
        border: 0 !important;
        background: #fff !important;
        font-size: 9pt;
        line-height: 1.22;
    }

    /* Условия — самый длинный блок, сжимаем ещё немного */
    .nbc-inv-paper .nbc-inv-doc__terms,
    .nbc-inv-paper .nbc-inv-doc__topnote { font-size: 8pt; line-height: 1.22; }

    /* Отступы между секциями уменьшаем */
    .nbc-inv-paper h1, .nbc-inv-paper h2, .nbc-inv-paper h3 { margin: 4px 0 !important; }
    .nbc-inv-paper table { margin-bottom: 4px !important; }
    .nbc-inv-paper p { margin: 2px 0 !important; }

    /* Запрет разрыва ключевых блоков между страницами */
    .nbc-inv-doc__bank,
    .nbc-inv-doc__parties,
    .nbc-inv-doc__items,
    .nbc-inv-doc__signature,
    .nbc-inv-doc__topnote { page-break-inside: avoid; break-inside: avoid; }
    /* Подпись/печать обязательно на той же странице, что и предыдущий блок */
    .nbc-inv-doc__signature { page-break-before: avoid; break-before: avoid; }
}
