/*
 * modal-v2.css — Modal de propostas v2 (Opção C + 10 ajustes)
 *
 * Spec: docs/specs/historico-proposta-modal-v2.md
 * Ref visual: docs/previews/modal-proposta-opcao-C.html
 *
 * ATENÇÃO:
 * - Arquivo isolado. Não editar pacto-ds.css. Todas as regras vivem aqui.
 * - Escopo: seletores começam com .pmv2- para evitar colisão com .pm-* (v1).
 * - Carregado APÓS proposal-modal.css para prevalecer por cascade.
 * - Z-index 1200: acima de .modal-overlay (1100), abaixo de .tkt-modal-overlay
 *   (9999) e .consulta-overview-overlay (10010).
 */

/* ============================================================ */
/* Overlay + dialog                                             */
/* ============================================================ */

.pmv2-overlay {
    position: fixed;
    inset: 0;
    z-index: 1200;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 24px;
    background: var(--pacto-overlay-backdrop, rgba(10, 37, 64, .46));
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    animation: pmv2-fade-in 180ms cubic-bezier(.16, 1, .3, 1);
}

.pmv2-overlay.hidden,
.pmv2-overlay[hidden] {
    display: none !important;
}

.pmv2-overlay-secondary {
    z-index: 1210;
}

.pmv2-dialog {
    width: 100%;
    max-width: 1200px;
    max-height: calc(100vh - 48px);
    display: flex;
    flex-direction: column;
    background: var(--color-surface, #FFFFFF);
    border: 1px solid var(--color-border, #DDE3EC);
    border-radius: 12px;
    box-shadow: var(--shadow-xl, 0 20px 60px rgba(10, 37, 64, .22));
    overflow: hidden;
    animation: pmv2-scale-in 220ms cubic-bezier(.16, 1, .3, 1);
}

.pmv2-dialog-secondary {
    max-width: 860px;
}

@keyframes pmv2-fade-in {
    from { opacity: 0; }
    to   { opacity: 1; }
}

@keyframes pmv2-scale-in {
    from { opacity: 0; transform: translateY(8px) scale(.98); }
    to   { opacity: 1; transform: translateY(0) scale(1); }
}

/* ============================================================ */
/* Header                                                       */
/* ============================================================ */

.pmv2-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
    padding: 20px 24px 16px;
    border-bottom: 1px solid var(--color-border, #DDE3EC);
    background: var(--color-surface, #FFFFFF);
}

.pmv2-header-text {
    flex: 1;
    min-width: 0;
}

.pmv2-header h2 {
    margin: 0 0 6px;
    font-size: 18px;
    font-weight: 600;
    color: var(--color-text, #0A2540);
    letter-spacing: -.2px;
}

.pmv2-subtitle {
    margin: 0 0 8px;
    font-size: 13px;
    line-height: 1.5;
    color: var(--color-text-subtle, #5A6776);
    max-width: 72ch;
}

.pmv2-link-btn {
    background: none;
    border: none;
    padding: 0;
    font-size: 12px;
    font-weight: 500;
    color: var(--color-accent, #0570DE);
    cursor: pointer;
    text-decoration: underline;
    text-underline-offset: 2px;
}

.pmv2-link-btn:hover {
    color: var(--color-accent-hover, #0258B8);
}

.pmv2-link-btn:focus-visible {
    outline: none;
    box-shadow: 0 0 0 3px var(--tint-accent-hover, rgba(5, 112, 222, .18));
    border-radius: 2px;
}

.pmv2-close-btn {
    flex-shrink: 0;
    width: 32px;
    height: 32px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: transparent;
    border: 1px solid var(--color-border, #DDE3EC);
    border-radius: 6px;
    color: var(--color-text-muted, #3D4B5C);
    cursor: pointer;
    transition: all 180ms cubic-bezier(.16, 1, .3, 1);
}

.pmv2-close-btn:hover {
    background: var(--color-surface-alt, #F6F9FC);
    color: var(--color-text, #0A2540);
    border-color: var(--color-border-strong, #B8C2CE);
}

.pmv2-close-btn:focus-visible {
    outline: none;
    box-shadow: 0 0 0 3px var(--tint-accent-hover, rgba(5, 112, 222, .18));
}

/* ============================================================ */
/* Body — 2 colunas                                             */
/* ============================================================ */

.pmv2-body {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: 0;
    flex: 1;
    min-height: 0;
    overflow: hidden;
}

.pmv2-body-single {
    grid-template-columns: minmax(0, 1fr);
}

.pmv2-panel {
    display: flex;
    flex-direction: column;
    min-height: 0;
    min-width: 0;
    background: var(--color-surface, #FFFFFF);
    overflow: hidden;
}

.pmv2-panel-left {
    border-right: 1px solid var(--color-border, #DDE3EC);
    background: var(--color-surface-alt, #F6F9FC);
}

.pmv2-panel-head {
    padding: 14px 20px;
    border-bottom: 1px solid var(--color-border, #DDE3EC);
    background: var(--color-surface, #FFFFFF);
}

.pmv2-panel-title {
    margin: 0 0 2px;
    font-size: 13px;
    font-weight: 600;
    color: var(--color-text, #0A2540);
    text-transform: uppercase;
    letter-spacing: .4px;
}

.pmv2-panel-sub {
    margin: 0;
    font-size: 12px;
    color: var(--color-text-subtle, #5A6776);
}

/* ============================================================ */
/* Painel esquerdo — propostas recentes                         */
/* ============================================================ */

.pmv2-left-list {
    flex: 1;
    overflow-y: auto;
    padding: 16px 20px;
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.pmv2-proposal-card {
    background: var(--color-surface, #FFFFFF);
    border: 1px solid var(--color-border, #DDE3EC);
    border-radius: 8px;
    box-shadow: var(--shadow-sm, 0 1px 2px rgba(10, 37, 64, .05));
    overflow: hidden;
}

.pmv2-proposal-head {
    padding: 10px 14px;
    display: flex;
    flex-wrap: wrap;
    gap: 8px 12px;
    align-items: center;
    justify-content: space-between;
    background: var(--color-surface-alt, #F6F9FC);
    border-bottom: 1px solid var(--color-border, #DDE3EC);
    font-size: 12px;
    color: var(--color-text-muted, #3D4B5C);
}

.pmv2-proposal-id {
    font-weight: 600;
    color: var(--color-text, #0A2540);
}

.pmv2-proposal-operator {
    font-size: 12px;
}

.pmv2-proposal-date {
    font-size: 11px;
    color: var(--color-text-subtle, #5A6776);
}

.pmv2-ops-list {
    display: flex;
    flex-direction: column;
}

.pmv2-op-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto auto;
    gap: 10px 14px;
    align-items: center;
    padding: 10px 14px;
    border-top: 1px solid var(--color-border, #DDE3EC);
}

.pmv2-op-row:first-child { border-top: none; }

.pmv2-op-title {
    font-size: 13px;
    font-weight: 500;
    color: var(--color-text, #0A2540);
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.pmv2-op-meta {
    font-size: 11px;
    color: var(--color-text-subtle, #5A6776);
    margin-top: 2px;
}

.pmv2-op-value {
    font-size: 13px;
    font-weight: 600;
    color: var(--color-text, #0A2540);
    text-align: right;
    white-space: nowrap;
}

.pmv2-op-action {
    justify-self: end;
}

.pmv2-tag {
    display: inline-flex;
    align-items: center;
    height: 18px;
    padding: 0 6px;
    margin-left: 6px;
    font-size: 10px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .4px;
    border-radius: 4px;
    background: var(--tint-accent-hover, rgba(5, 112, 222, .12));
    color: var(--color-accent, #0570DE);
    border: 1px solid var(--tint-accent-active, rgba(5, 112, 222, .22));
}

/* ============================================================ */
/* Painel direito — oferta atual                                */
/* ============================================================ */

.pmv2-offer-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 16px 20px;
}

.pmv2-offer-counter {
    font-size: 12px;
    color: var(--color-text-muted, #3D4B5C);
    font-weight: 500;
}

.pmv2-offer-total {
    font-size: 20px;
    font-weight: 700;
    color: var(--color-primary, #13314D);
    letter-spacing: -.3px;
    white-space: nowrap;
}

:root[data-theme="dark"] .pmv2-offer-total {
    color: var(--color-accent, #4A9EFF);
}

.pmv2-right-body {
    flex: 1;
    overflow-y: auto;
    padding: 12px 20px 8px;
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.pmv2-group-title {
    margin: 4px 0 8px;
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .5px;
    color: var(--color-text-subtle, #5A6776);
}

.pmv2-group-list {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.pmv2-offer-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 12px;
    align-items: center;
    padding: 12px 14px;
    background: var(--color-surface, #FFFFFF);
    border: 1px solid var(--color-border, #DDE3EC);
    border-radius: 8px;
    box-shadow: var(--shadow-sm, 0 1px 2px rgba(10, 37, 64, .05));
    position: relative;
}

.pmv2-offer-row.pmv2-is-adopted {
    border-left: 3px solid var(--color-accent, #0570DE);
}

/*
 * Ficha inativa — Variante 1 aprovada:
 * wrapper informativo com opacity 40% + strikethrough no valor.
 * Botão "Reativar" FICA FORA do wrapper e mantém opacity: 1.
 *
 * Implementação: .pmv2-offer-row mantém display:grid; o container
 * .pmv2-offer-info engloba cabeçalho/metadados/valor e recebe opacity.
 * O botão .pmv2-row-action está fora desse container, irmão direto do row.
 */
.pmv2-offer-info {
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.pmv2-offer-row.pmv2-is-inactive .pmv2-offer-info {
    opacity: .4;
}

.pmv2-offer-row.pmv2-is-inactive .pmv2-offer-value {
    text-decoration: line-through;
    text-decoration-thickness: 1.5px;
}

.pmv2-offer-title {
    font-size: 13px;
    font-weight: 500;
    color: var(--color-text, #0A2540);
    line-height: 1.35;
}

.pmv2-offer-meta {
    font-size: 11px;
    color: var(--color-text-subtle, #5A6776);
    line-height: 1.4;
}

.pmv2-offer-value-wrap {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 2px;
}

.pmv2-offer-value {
    font-size: 14px;
    font-weight: 600;
    color: var(--color-text, #0A2540);
    white-space: nowrap;
}

.pmv2-row-action {
    grid-column: 2;
    align-self: center;
    opacity: 1 !important;
}

/* ============================================================ */
/* Helper text (oferta zerada)                                  */
/* ============================================================ */

.pmv2-helper-text {
    padding: 10px 20px;
    margin: 0 20px;
    background: var(--tint-warning, rgba(245, 158, 11, .12));
    border: 1px solid var(--tint-warning, rgba(245, 158, 11, .22));
    border-radius: 6px;
    font-size: 12px;
    color: var(--color-text-muted, #3D4B5C);
    text-align: center;
}

.pmv2-helper-text[hidden] {
    display: none;
}

/* ============================================================ */
/* Footer                                                       */
/* ============================================================ */

.pmv2-footer {
    display: flex;
    gap: 10px;
    justify-content: flex-end;
    padding: 14px 20px;
    border-top: 1px solid var(--color-border, #DDE3EC);
    background: var(--color-surface, #FFFFFF);
}

.pmv2-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 36px;
    padding: 0 16px;
    font-size: 13px;
    font-weight: 500;
    border: 1px solid transparent;
    border-radius: 6px;
    cursor: pointer;
    transition: all 180ms cubic-bezier(.16, 1, .3, 1);
    white-space: nowrap;
}

.pmv2-btn:focus-visible {
    outline: none;
    box-shadow: 0 0 0 3px var(--tint-accent-hover, rgba(5, 112, 222, .18));
}

.pmv2-btn-ghost {
    background: transparent;
    border-color: var(--color-border, #DDE3EC);
    color: var(--color-text-muted, #3D4B5C);
}

.pmv2-btn-ghost:hover {
    background: var(--color-surface-alt, #F6F9FC);
    color: var(--color-text, #0A2540);
    border-color: var(--color-border-strong, #B8C2CE);
}

.pmv2-btn-primary {
    background: var(--color-primary, #13314D);
    color: var(--color-surface, #FFFFFF);
}

.pmv2-btn-primary:hover:not(:disabled) {
    background: var(--color-primary-hover, #1F4061);
    box-shadow: var(--shadow-md, 0 2px 6px rgba(10, 37, 64, .08));
    transform: translateY(-1px);
}

:root[data-theme="dark"] .pmv2-btn-primary {
    background: var(--color-accent, #4A9EFF);
    color: #0E1620;
}

:root[data-theme="dark"] .pmv2-btn-primary:hover:not(:disabled) {
    background: var(--color-accent-hover, #7AB8FF);
}

.pmv2-btn:disabled {
    opacity: .5;
    cursor: not-allowed;
    box-shadow: none;
    transform: none;
}

.pmv2-btn-action {
    min-height: 30px;
    padding: 0 12px;
    font-size: 12px;
    background: var(--color-surface, #FFFFFF);
    border-color: var(--color-border, #DDE3EC);
    color: var(--color-accent, #0570DE);
    font-weight: 500;
}

.pmv2-btn-action:hover:not(:disabled) {
    background: var(--tint-accent-hover, rgba(5, 112, 222, .08));
    border-color: var(--color-accent, #0570DE);
}

.pmv2-btn-action:disabled {
    opacity: .6;
    background: var(--color-surface-alt, #F6F9FC);
    color: var(--color-text-subtle, #5A6776);
    cursor: not-allowed;
}

.pmv2-btn-danger-ghost {
    min-height: 30px;
    padding: 0 12px;
    font-size: 12px;
    background: transparent;
    border-color: var(--color-border, #DDE3EC);
    color: var(--color-text-muted, #3D4B5C);
    font-weight: 500;
}

.pmv2-btn-danger-ghost:hover:not(:disabled) {
    background: rgba(220, 38, 38, .08);
    border-color: rgba(220, 38, 38, .4);
    color: rgb(185, 28, 28);
}

/* ============================================================ */
/* Estados vazios / loading                                     */
/* ============================================================ */

.pmv2-empty {
    padding: 24px 16px;
    text-align: center;
    color: var(--color-text-subtle, #5A6776);
    font-size: 13px;
}

/* ============================================================ */
/* Scrollbar                                                    */
/* ============================================================ */

.pmv2-left-list::-webkit-scrollbar,
.pmv2-right-body::-webkit-scrollbar,
.pmv2-full-list::-webkit-scrollbar {
    width: 8px;
}

.pmv2-left-list::-webkit-scrollbar-thumb,
.pmv2-right-body::-webkit-scrollbar-thumb,
.pmv2-full-list::-webkit-scrollbar-thumb {
    background: var(--color-border-strong, #B8C2CE);
    border-radius: 4px;
}

/* ============================================================ */
/* Histórico completo (modal secundário)                        */
/* ============================================================ */

.pmv2-full-list {
    flex: 1;
    overflow-y: auto;
    padding: 16px 20px;
    display: flex;
    flex-direction: column;
    gap: 12px;
    max-height: calc(100vh - 220px);
}

.pmv2-full-card {
    padding: 12px 14px;
    background: var(--color-surface, #FFFFFF);
    border: 1px solid var(--color-border, #DDE3EC);
    border-radius: 8px;
}

.pmv2-full-card-head {
    display: flex;
    flex-wrap: wrap;
    gap: 6px 12px;
    align-items: baseline;
    margin-bottom: 6px;
    font-size: 12px;
    color: var(--color-text-muted, #3D4B5C);
}

.pmv2-full-badge {
    display: inline-flex;
    align-items: center;
    height: 18px;
    padding: 0 6px;
    font-size: 10px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .4px;
    border-radius: 4px;
    background: var(--color-surface-alt, #F6F9FC);
    border: 1px solid var(--color-border, #DDE3EC);
    color: var(--color-text-subtle, #5A6776);
}

/* ============================================================ */
/* Responsivo                                                   */
/* ============================================================ */

@media (max-width: 1024px) {
    .pmv2-dialog {
        max-width: 100%;
    }

    .pmv2-body {
        grid-template-columns: minmax(0, 1fr);
    }

    .pmv2-panel-left {
        border-right: none;
        border-bottom: 1px solid var(--color-border, #DDE3EC);
        max-height: 45vh;
    }

    .pmv2-panel-right {
        min-height: 45vh;
    }
}

@media (max-width: 767px) {
    .pmv2-overlay {
        padding: 0;
        align-items: stretch;
    }

    .pmv2-dialog {
        max-width: 100%;
        max-height: 100vh;
        height: 100vh;
        border-radius: 0;
        border: none;
    }

    .pmv2-header {
        padding: 14px 16px 12px;
    }

    .pmv2-header h2 {
        font-size: 16px;
    }

    .pmv2-subtitle {
        font-size: 12px;
    }

    .pmv2-panel-head,
    .pmv2-offer-head {
        padding: 12px 16px;
    }

    .pmv2-left-list,
    .pmv2-right-body {
        padding: 12px 16px;
    }

    .pmv2-offer-total {
        font-size: 18px;
    }

    .pmv2-op-row,
    .pmv2-offer-row {
        grid-template-columns: minmax(0, 1fr);
        gap: 8px;
    }

    .pmv2-op-value,
    .pmv2-offer-value-wrap {
        justify-self: flex-start;
        align-items: flex-start;
        text-align: left;
    }

    .pmv2-op-action,
    .pmv2-row-action {
        grid-column: auto;
        justify-self: flex-start;
    }

    .pmv2-footer {
        padding: 12px 16px;
        gap: 8px;
    }

    .pmv2-btn {
        flex: 1;
    }
}
