/**
 * Cotización y proformas — lista de precios para enviar (sin venta).
 */
@layer feature-modules {
.cotizacion-container {
    padding: var(--space-lg);
    padding-bottom: calc(var(--space-2xl) + 4rem);
    max-width: 1120px;
    display: flex;
    flex-direction: column;
    gap: var(--space-lg);
}

.cotizacion-panel {
    padding: var(--space-md);
    border-radius: var(--radius-lg);
    border: 1px solid var(--color-border);
    background: var(--color-surface, var(--color-bg));
}

.cotizacion-panel h2 {
    margin: 0 0 var(--space-md);
    font-size: var(--text-base);
    font-weight: 700;
    color: var(--color-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.03em;
}

.cotizacion-hint {
    margin: 0 0 var(--space-md);
    font-size: var(--text-sm);
    color: var(--color-text-muted);
    line-height: 1.45;
}

.cotizacion-hint:last-child {
    margin-bottom: 0;
}

.cotizacion-precio-hint {
    margin: calc(var(--space-sm) * -1) 0 var(--space-md);
}

/* —— Paso 1: tipo de documento —— */
.cotizacion-setup {
    margin-bottom: 0;
}

.cotizacion-modo-group {
    display: grid;
    gap: var(--space-sm);
    grid-template-columns: 1fr;
}

@media (min-width: 640px) {
    .cotizacion-modo-group {
        grid-template-columns: repeat(3, 1fr);
    }
}

.cotizacion-modo-btn {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 0.2rem;
    width: 100%;
    padding: 0.65rem 0.75rem;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    background: var(--color-surface, var(--color-bg));
    text-align: left;
    font: inherit;
    cursor: pointer;
    color: inherit;
    transition: border-color 0.15s, background 0.15s;
    min-height: 100%;
}

.cotizacion-modo-btn:hover {
    border-color: color-mix(in srgb, var(--color-primary) 40%, var(--color-border));
}

.cotizacion-modo-btn:focus-visible {
    outline: 2px solid var(--color-primary);
    outline-offset: 2px;
}

.cotizacion-modo-btn--active {
    border-color: var(--color-primary);
    background: color-mix(in srgb, var(--color-primary) 10%, transparent);
}

.cotizacion-modo-btn__title {
    font-weight: 600;
    font-size: var(--text-sm);
    line-height: 1.3;
}

.cotizacion-modo-btn__desc {
    font-size: var(--text-xs);
    color: var(--color-text-muted);
    line-height: 1.35;
}

.cotizacion-modo-recommended {
    display: inline-block;
    margin-left: 0.25rem;
    padding: 0.05rem 0.35rem;
    border-radius: var(--radius-sm);
    font-size: 0.6rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.02em;
    background: color-mix(in srgb, var(--color-success, #16a34a) 18%, transparent);
    color: var(--color-success, #16a34a);
    vertical-align: middle;
}

.cotizacion-extra {
    margin-top: var(--space-md);
    padding-top: var(--space-md);
    border-top: 1px solid var(--color-border);
}

.cotizacion-extra[hidden] {
    display: none !important;
}

.cotizacion-cliente-grid {
    display: grid;
    gap: var(--space-md);
    grid-template-columns: 1fr;
}

@media (min-width: 640px) {
    .cotizacion-cliente-grid {
        grid-template-columns: 1fr 1fr;
    }

    .cotizacion-cliente-grid__buscar,
    .cotizacion-cliente-grid__picked {
        grid-column: 1 / -1;
    }
}

.cotizacion-cliente-panel[hidden],
.cotizacion-etiqueta-panel[hidden] {
    display: none !important;
}

.cotizacion-cliente-picked {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-sm);
    padding: var(--space-2) var(--space-3);
    border-radius: var(--radius-md);
    background: color-mix(in srgb, var(--color-primary) 10%, transparent);
    border: 1px solid color-mix(in srgb, var(--color-primary) 22%, var(--color-border));
}

.cotizacion-cliente-picked[hidden] {
    display: none !important;
}

.cotizacion-cliente-nivel {
    display: inline-block;
    margin-left: 0.35rem;
    padding: 0.1rem 0.45rem;
    border-radius: var(--radius-sm);
    font-size: 0.72rem;
    font-weight: 600;
    background: var(--color-border);
}

/* —— Paso 2: productos + lista —— */
.cotizacion-work-layout {
    display: grid;
    gap: var(--space-lg);
    align-items: start;
}

@media (min-width: 960px) {
    .cotizacion-work-layout {
        grid-template-columns: minmax(0, 1fr) 272px;
    }
}

.cotizacion-work .cotizacion-lista-header h2 {
    color: var(--color-text-muted);
}

.cotizacion-prod-toolbar {
    display: flex;
    flex-direction: column;
    gap: var(--space-md);
    margin-bottom: var(--space-sm);
}

.cotizacion-prod-search {
    position: relative;
    flex: 1 1 auto;
    min-width: 0;
}

.cotizacion-prod-search:focus-within,
.cotizacion-cliente-grid__buscar:focus-within {
    z-index: 40;
}

.cotizacion-cliente-grid__buscar {
    position: relative;
}

@media (min-width: 720px) {
    .cotizacion-prod-toolbar {
        flex-direction: row;
        align-items: flex-end;
    }

    .cotizacion-prod-nivel {
        flex: 0 0 auto;
        min-width: 11rem;
    }
}

.cotizacion-prod-search .cotizacion-autocomplete {
    position: absolute;
    left: 0;
    right: 0;
    top: calc(100% - 0.15rem);
    margin-top: 0;
    z-index: 35;
}

#cot-lineas-wrap {
    min-height: 0;
    transition: min-height 0.15s ease;
}

#cot-lineas-wrap.cotizacion-lineas-wrap--ac-open:not(.cotizacion-lineas-wrap--has-items) {
    min-height: 0;
}

#cot-lineas-wrap.cotizacion-lineas-wrap--ac-open:not(.cotizacion-lineas-wrap--has-items) .cotizacion-lineas-empty {
    display: none;
}

.cotizacion-prod-nivel__label {
    display: block;
    margin-bottom: 0.35rem;
    font-size: var(--text-sm);
    font-weight: 500;
}

.cotizacion-prod-nivel[hidden] {
    display: none !important;
}

.cotizacion-nivel-toggle {
    display: flex;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    overflow: hidden;
}

.cotizacion-nivel-btn {
    flex: 1;
    padding: 0.45rem 0.65rem;
    border: none;
    background: transparent;
    font: inherit;
    font-size: var(--text-sm);
    font-weight: 500;
    cursor: pointer;
    color: var(--color-text-muted);
}

.cotizacion-nivel-btn:not(:last-child) {
    border-right: 1px solid var(--color-border);
}

.cotizacion-nivel-btn--active {
    background: color-mix(in srgb, var(--color-primary) 14%, transparent);
    color: var(--color-text);
    font-weight: 600;
}

.cotizacion-autocomplete {
    position: relative;
    margin-top: 0.25rem;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    background: var(--color-surface, var(--color-bg));
    box-shadow: var(--shadow-md);
    max-height: 260px;
    overflow-y: auto;
    z-index: 35;
}

.cotizacion-autocomplete[hidden] {
    display: none !important;
}

.cotizacion-ac-item {
    display: block;
    width: 100%;
    padding: 0.55rem 0.75rem;
    border: none;
    border-bottom: 1px solid var(--color-border);
    background: transparent;
    text-align: left;
    font: inherit;
    cursor: pointer;
    color: inherit;
}

.cotizacion-ac-item:hover,
.cotizacion-ac-item:focus-visible {
    background: color-mix(in srgb, var(--color-primary) 12%, transparent);
}

.cotizacion-ac-item.autocomplete-sug-active,
.cotizacion-ac-item.autocomplete-sug-active:hover {
    background: color-mix(in srgb, var(--color-primary) 18%, transparent);
    outline: 2px solid var(--color-primary, #3b82f6);
    outline-offset: -2px;
}

.cotizacion-ac-item.cotizacion-ac-loading {
    cursor: default;
    color: var(--color-text-muted);
    font-style: italic;
}

.cotizacion-ac-code {
    font-size: 0.8em;
    color: var(--color-text-muted);
}

.cotizacion-ac-price {
    float: right;
    font-weight: 600;
}

.cotizacion-lineas-empty {
    margin: var(--space-sm) 0 var(--space-md);
    padding: var(--space-md);
    text-align: center;
    color: var(--color-text-muted);
    font-size: var(--text-sm);
    border: 1px dashed var(--color-border);
    border-radius: var(--radius-md);
    background: color-mix(in srgb, var(--color-border) 22%, transparent);
}

.cotizacion-lineas-table-wrap {
    overflow-x: auto;
    margin-bottom: var(--space-md);
}

.cotizacion-lineas-table {
    width: 100%;
    border-collapse: collapse;
    font-size: var(--text-sm);
}

.cotizacion-lineas-table th,
.cotizacion-lineas-table td {
    padding: 0.5rem 0.4rem;
    border-bottom: 1px solid var(--color-border);
    vertical-align: middle;
}

.cotizacion-lineas-table th {
    font-size: var(--text-xs);
    font-weight: 600;
    color: var(--color-text-muted);
    text-align: left;
}

.cotizacion-num {
    text-align: right;
    white-space: nowrap;
}

.cotizacion-linea-cant {
    width: 4.5rem;
    min-width: 4rem;
}

.cotizacion-lista-header {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-sm);
    margin-bottom: var(--space-md);
}

.cotizacion-lista-header h2 {
    margin: 0;
}

.cotizacion-badge {
    display: inline-flex;
    align-items: center;
    padding: 0.2rem 0.55rem;
    border-radius: 999px;
    font-size: var(--text-xs);
    font-weight: 600;
    background: var(--color-border);
    color: var(--color-text-muted);
}

.cotizacion-badge--items {
    background: color-mix(in srgb, var(--color-primary) 14%, var(--color-border));
    color: var(--color-text);
}

.cotizacion-lista-footer {
    display: flex;
    flex-direction: column;
    gap: var(--space-sm);
    padding-top: var(--space-md);
    border-top: 1px solid var(--color-border);
}

.cotizacion-notas {
    margin: 0;
}

.cotizacion-btn-vaciar {
    align-self: flex-start;
}

/* —— Paso 3: enviar (sidebar) —— */
.cotizacion-aside {
    display: flex;
    flex-direction: column;
}

@media (min-width: 960px) {
    .cotizacion-aside {
        position: sticky;
        top: var(--space-md);
    }
}

.cotizacion-resumen-card {
    padding: var(--space-md);
    border-radius: var(--radius-lg);
    border: 1px solid color-mix(in srgb, var(--color-primary) 28%, var(--color-border));
    background: color-mix(in srgb, var(--color-primary) 6%, var(--color-surface, var(--color-bg)));
}

.cotizacion-resumen-heading {
    margin: 0 0 var(--space-sm);
    font-size: var(--text-base);
    font-weight: 700;
    color: var(--color-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.03em;
}

.cotizacion-resumen-tipo {
    font-size: var(--text-lg);
    font-weight: 700;
    margin: 0 0 var(--space-xs);
    line-height: 1.25;
}

.cotizacion-resumen-meta {
    margin: 0 0 var(--space-md);
    font-size: var(--text-sm);
    color: var(--color-text-muted);
    line-height: 1.4;
}

.cotizacion-resumen-total {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: var(--space-sm);
    padding: var(--space-md) 0;
    margin-bottom: var(--space-md);
    border-top: 2px solid var(--color-border);
    border-bottom: 2px solid var(--color-border);
    font-weight: 700;
}

.cotizacion-resumen-total strong {
    font-size: var(--text-xl);
    color: var(--color-primary, inherit);
}

.cotizacion-actions {
    display: flex;
    flex-direction: column;
    gap: var(--space-sm);
}

.cotizacion-actions .btn--primary-stack {
    width: 100%;
}

.cotizacion-actions .btn--wa:not(:disabled) {
    background: #25d366;
    border-color: #25d366;
    color: #fff;
}

.cotizacion-actions .btn--wa:not(:disabled):hover {
    filter: brightness(0.95);
}

.cotizacion-actions .btn--wa[hidden] {
    display: none !important;
}

.cotizacion-wa-hint {
    margin: 0;
    font-size: var(--text-xs);
    color: var(--color-text-muted);
    line-height: 1.35;
}

.cotizacion-wa-hint[hidden] {
    display: none !important;
}

/* Barra fija en móvil */
.cotizacion-mobile-bar {
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 30;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-sm);
    padding: var(--space-sm) var(--space-md);
    padding-bottom: max(var(--space-sm), env(safe-area-inset-bottom));
    background: var(--color-surface, var(--color-bg));
    border-top: 1px solid var(--color-border);
    box-shadow: 0 -4px 16px rgba(0, 0, 0, 0.08);
}

.cotizacion-mobile-bar[hidden] {
    display: none !important;
}

@media (min-width: 960px) {
    .cotizacion-mobile-bar {
        display: none !important;
    }

    .cotizacion-container {
        padding-bottom: var(--space-2xl);
    }
}

.cotizacion-mobile-bar__total {
    font-size: var(--text-sm);
    font-weight: 600;
    min-width: 0;
}

.cotizacion-mobile-bar__total strong {
    display: block;
    font-size: var(--text-lg);
}

.cotizacion-mobile-bar__btns {
    display: flex;
    gap: var(--space-xs);
    flex-shrink: 0;
}

}