/*
 * Calculadora de Presupuesto Pro — Estilos v2.1.0
 * Diseño: Minimalista profesional. Paleta: Slate + Emerald accent.
 * Inspiración: Linear, Stripe, Notion.
 */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap');

/* ═══════════════════════════════════
   DESIGN TOKENS
═══════════════════════════════════ */
.calc-pres-wrap {
    /* Colores base */
    --cp-black:        #0f172a;
    --cp-gray-900:     #1e293b;
    --cp-gray-700:     #334155;
    --cp-gray-500:     #64748b;
    --cp-gray-300:     #cbd5e1;
    --cp-gray-200:     #e2e8f0;
    --cp-gray-100:     #f1f5f9;
    --cp-gray-50:      #f8fafc;
    --cp-white:        #ffffff;

    /* Acento único — verde esmeralda sobrio */
    --cp-accent:       #059669;
    --cp-accent-d:     #047857;
    --cp-accent-l:     #d1fae5;
    --cp-accent-xl:    #ecfdf5;

    /* Semánticos */
    --cp-danger:       #dc2626;
    --cp-danger-l:     #fef2f2;
    --cp-warning:      #d97706;
    --cp-warning-l:    #fffbeb;
    --cp-success:      #059669;
    --cp-success-l:    #d1fae5;

    /* Tipografía y espaciado */
    --cp-font:         'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
    --cp-radius-sm:    6px;
    --cp-radius:       10px;
    --cp-radius-lg:    16px;
    --cp-shadow-xs:    0 1px 2px rgba(0,0,0,.06);
    --cp-shadow-sm:    0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.04);
    --cp-shadow:       0 4px 6px -1px rgba(0,0,0,.06), 0 2px 4px -2px rgba(0,0,0,.04);
    --cp-shadow-md:    0 10px 15px -3px rgba(0,0,0,.06), 0 4px 6px -4px rgba(0,0,0,.04);

    font-family: var(--cp-font);
    max-width: 1000px;
    margin: 2rem auto;
    -webkit-font-smoothing: antialiased;
    color: var(--cp-gray-900);
}

/* ═══════════════════════════════════
   HEADER — Limpio, sin gradientes
═══════════════════════════════════ */
.cp-header {
    background: var(--cp-white);
    border: 1px solid var(--cp-gray-200);
    border-radius: var(--cp-radius-lg) var(--cp-radius-lg) 0 0;
    padding: 1.5rem 2rem;
    border-bottom: 3px solid var(--cp-accent);  /* línea acento sutil */
}
.cp-header-inner {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    flex-wrap: wrap;
}
.cp-title-group {
    display: flex;
    align-items: center;
    gap: .875rem;
}
.cp-logo-icon {
    font-size: 1.75rem;
    line-height: 1;
}
.cp-title {
    font-size: 1.35rem;
    font-weight: 800;
    margin: 0;
    color: var(--cp-black);
    letter-spacing: -.025em;
}
.cp-subtitle {
    margin: .15rem 0 0;
    color: var(--cp-gray-500);
    font-size: .85rem;
    font-weight: 400;
}
.cp-currency-box {
    display: flex;
    align-items: center;
    gap: .5rem;
    background: var(--cp-gray-50);
    border: 1px solid var(--cp-gray-200);
    border-radius: var(--cp-radius);
    padding: .5rem .875rem;
}
.cp-currency-label {
    font-weight: 600;
    font-size: .78rem;
    color: var(--cp-gray-500);
    text-transform: uppercase;
    letter-spacing: .05em;
    white-space: nowrap;
}
.cp-currency-select {
    background: transparent;
    border: none;
    color: var(--cp-gray-900);
    font-weight: 600;
    font-size: .9rem;
    cursor: pointer;
    outline: none;
    font-family: var(--cp-font);
}
.cp-currency-select option { background: var(--cp-white); color: var(--cp-gray-900); }

/* ═══════════════════════════════════
   STEPPER — Línea simple y clara
═══════════════════════════════════ */
.cp-stepper {
    display: flex;
    align-items: center;
    background: var(--cp-gray-50);
    padding: 1rem 2rem;
    border-left: 1px solid var(--cp-gray-200);
    border-right: 1px solid var(--cp-gray-200);
    border-bottom: 1px solid var(--cp-gray-200);
}
.cp-step {
    display: flex;
    align-items: center;
    gap: .5rem;
    font-weight: 500;
    font-size: .82rem;
    color: var(--cp-gray-400, #94a3b8);
    transition: color .2s;
    white-space: nowrap;
}
.cp-step-num {
    width: 26px;
    height: 26px;
    border-radius: 50%;
    background: var(--cp-gray-200);
    color: var(--cp-gray-500);
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: .78rem;
    transition: all .2s;
    flex-shrink: 0;
}
.cp-step--active { color: var(--cp-gray-900); }
.cp-step--active .cp-step-num {
    background: var(--cp-black);
    color: var(--cp-white);
    box-shadow: 0 0 0 3px rgba(15,23,42,.1);
}
.cp-step--done { color: var(--cp-accent); }
.cp-step--done .cp-step-num { background: var(--cp-accent); color: var(--cp-white); }
.cp-step-line {
    flex: 1;
    height: 1px;
    background: var(--cp-gray-200);
    margin: 0 .5rem;
}
.cp-step-line--done { background: var(--cp-accent); }

/* ═══════════════════════════════════
   BODY / PANELS
═══════════════════════════════════ */
.cp-body {
    background: var(--cp-white);
    border: 1px solid var(--cp-gray-200);
    border-top: none;
    border-radius: 0 0 var(--cp-radius-lg) var(--cp-radius-lg);
    box-shadow: var(--cp-shadow-md);
    overflow: hidden;
}
.cp-panel {
    display: none;
    padding: 2.25rem 2rem;
    animation: cpFadeUp .3s ease-out;
}
.cp-panel--active { display: block; }
@keyframes cpFadeUp {
    from { opacity: 0; transform: translateY(8px); }
    to   { opacity: 1; transform: translateY(0); }
}

.cp-panel-header {
    display: flex;
    align-items: center;
    gap: .75rem;
    margin-bottom: 2rem;
    padding-bottom: 1.25rem;
    border-bottom: 1px solid var(--cp-gray-100);
}
.cp-panel-icon { font-size: 1.5rem; line-height: 1; }
.cp-panel-header h2 {
    font-size: 1.15rem;
    font-weight: 700;
    margin: 0;
    color: var(--cp-black);
    letter-spacing: -.02em;
}

/* ═══════════════════════════════════
   FORMS
═══════════════════════════════════ */
.cp-grid-2 {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 1.25rem;
    margin-bottom: 1.25rem;
}
/* Grid de 3 columnas para fila de configuración */
.cp-grid-3 {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.25rem;
    margin-bottom: 1.25rem;
}
@media (max-width: 640px) {
    .cp-grid-3 { grid-template-columns: 1fr; }
}

/* Fila Adicional: Configuración Tributaria y Laboral Colombiana */
.cp-colombia-config {
    background: #f0fdf4; /* Soft warm emerald tint */
    border: 1px solid #bbf7d0;
    border-left: 4px solid var(--cp-accent);
    border-radius: var(--cp-radius-lg);
    padding: 1.5rem 1.25rem 1.25rem 1.25rem;
    margin-top: 0.5rem;
    margin-bottom: 1.75rem;
    position: relative;
    box-shadow: 0 4px 6px -1px rgba(16,185,129,0.03), 0 2px 4px -2px rgba(16,185,129,0.02);
    display: flex;
    flex-wrap: wrap;
    gap: 1.25rem;
}
.cp-colombia-config::before {
    content: "🇨🇴 CONFIGURACIÓN COLOMBIANA (TRIBUTARIA Y LABORAL)";
    display: block;
    width: 100%;
    font-size: 0.72rem;
    font-weight: 800;
    color: var(--cp-accent-d);
    letter-spacing: 0.06em;
    margin-bottom: 0.5rem;
}
.cp-colombia-config .cp-field-group {
    flex: 1 1 240px;
    margin-bottom: 0;
}
/* Textarea que crece para igualar alturas en grid */
.cp-grid-2 .cp-field-group { display: flex; flex-direction: column; }
.cp-textarea--grow { flex: 1; resize: vertical; }
.cp-field-group { margin-bottom: 1.25rem; }
.cp-label {
    display: block;
    font-weight: 700;
    margin-bottom: .45rem;
    font-size: .75rem;
    color: var(--cp-gray-700);
    text-transform: uppercase;
    letter-spacing: .05em;
}
.cp-required { color: var(--cp-danger); margin-left: 2px; }

.cp-input, .cp-select {
    width: 100%;
    height: 44px;
    padding: 0 1rem;
    border: 1px solid var(--cp-gray-200);
    border-radius: var(--cp-radius);
    font-size: .92rem;
    font-family: var(--cp-font);
    color: var(--cp-gray-900);
    background: var(--cp-white);
    box-sizing: border-box;
    transition: all .2s cubic-bezier(0.4, 0, 0.2, 1);
    outline: none;
    text-align: left !important;
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
}
.cp-textarea {
    width: 100%;
    padding: .75rem 1rem;
    border: 1px solid var(--cp-gray-200);
    border-radius: var(--cp-radius);
    font-size: .92rem;
    font-family: var(--cp-font);
    color: var(--cp-gray-900);
    background: var(--cp-white);
    box-sizing: border-box;
    transition: all .2s cubic-bezier(0.4, 0, 0.2, 1);
    outline: none;
    text-align: left !important;
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
    min-height: 120px;
    resize: vertical;
}
.cp-select {
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3E%3Cpath stroke='%2364748b' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3E%3C/svg%3E");
    background-position: right 0.75rem center;
    background-repeat: no-repeat;
    background-size: 1.25rem;
    padding-right: 2.5rem !important; /* Make room for the arrow */
}
.cp-input:hover, .cp-select:hover, .cp-textarea:hover {
    border-color: var(--cp-gray-300);
}
.cp-input::placeholder, .cp-textarea::placeholder { color: var(--cp-gray-400); }
.cp-input:focus, .cp-select:focus, .cp-textarea:focus {
    border-color: var(--cp-accent);
    box-shadow: 0 0 0 2px #fff, 0 0 0 4px rgba(5,150,105,.15), 0 1px 2px rgba(15, 23, 42, 0.05);
}

/* Hide number inputs spinner arrows for a cleaner look */
.cp-input::-webkit-outer-spin-button,
.cp-input::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}
.cp-input[type=number] {
    -moz-appearance: textfield;
}

/* Nota pedagógica sobre el IVA & Punto de Equilibrio Highlights */
.cp-info-note {
    margin-top: 1.5rem;
    background: #f0fdf4;
    border: 1px solid #bbf7d0;
    border-radius: var(--cp-radius);
    padding: 1rem;
    font-size: .85rem;
    color: #166534;
    display: flex;
    align-items: flex-start;
    gap: .5rem;
    box-shadow: 0 1px 2px rgba(16, 185, 129, 0.05);
}
.calc-pres-wrap.cp-dark .cp-info-note {
    background: rgba(4, 120, 87, 0.1);
    border-color: rgba(52, 211, 153, 0.2);
    color: #34d399;
}
.cp-kpi-card--be {
    background: var(--cp-accent-xl);
    border-color: var(--cp-accent-l);
}
.cp-kpi-card--be .cp-kpi-label {
    color: var(--cp-accent-d);
}
.cp-kpi-card--be .cp-kpi-value {
    color: var(--cp-accent-d);
}
.calc-pres-wrap.cp-dark .cp-kpi-card--be {
    background: rgba(4, 120, 87, 0.15);
    border-color: rgba(52, 211, 153, 0.3);
}
.calc-pres-wrap.cp-dark .cp-kpi-card--be .cp-kpi-label,
.calc-pres-wrap.cp-dark .cp-kpi-card--be .cp-kpi-value {
    color: #34d399;
}

.cp-help-text {
    font-size: 0.72rem;
    color: var(--cp-gray-500);
    margin-top: 0.35rem;
    line-height: 1.3;
    margin-bottom: 0;
    font-weight: 500;
}

.cp-field-error {
    color: var(--cp-danger);
    font-size: .8rem;
    font-weight: 600;
    margin-top: .3rem;
    padding: .3rem .5rem;
    background: var(--cp-danger-l);
    border-radius: var(--cp-radius-sm);
}

/* ═══════════════════════════════════
   BOTONES — Minimalistas
═══════════════════════════════════ */
.cp-btn {
    padding: .6rem 1.25rem;
    border-radius: var(--cp-radius);
    font-weight: 600;
    font-size: .88rem;
    font-family: var(--cp-font);
    cursor: pointer;
    border: 1px solid transparent;
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
    letter-spacing: .01em;
    white-space: nowrap;
    box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
}
.cp-btn:hover {
    transform: translateY(-1px);
    box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.08), 0 2px 4px -2px rgba(0, 0, 0, 0.08);
}
.cp-btn:active {
    transform: translateY(0) scale(.98);
    box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
}

.cp-btn--primary {
    background: var(--cp-black);
    color: var(--cp-white);
    border-color: var(--cp-black);
}
.cp-btn--primary:hover { background: var(--cp-gray-700); border-color: var(--cp-gray-700); }

.cp-btn--calc {
    background: var(--cp-accent);
    color: var(--cp-white);
    border-color: var(--cp-accent);
    font-size: .92rem;
    padding: .7rem 1.5rem;
}
.cp-btn--calc:hover { background: var(--cp-accent-d); border-color: var(--cp-accent-d); }

.cp-btn--ghost {
    background: var(--cp-white);
    color: var(--cp-gray-700);
    border-color: var(--cp-gray-200);
}
.cp-btn--ghost:hover { background: var(--cp-gray-50); border-color: var(--cp-gray-300); }

.cp-btn--add {
    width: 100%;
    background: var(--cp-white);
    color: var(--cp-gray-500);
    border: 1.5px dashed var(--cp-gray-200);
    justify-content: center;
    margin: .75rem 0 1.25rem;
    padding: .65rem;
}
.cp-btn--add:hover { background: var(--cp-gray-50); border-color: var(--cp-gray-300); color: var(--cp-gray-700); }

.cp-btn--excel   { background: var(--cp-accent);  color: #fff; border-color: var(--cp-accent); }
.cp-btn--excel:hover { background: var(--cp-accent-d); }
.cp-btn--print   { background: var(--cp-white); color: var(--cp-gray-700); border-color: var(--cp-gray-200); }
.cp-btn--print:hover { background: var(--cp-gray-50); }
.cp-btn--simulate { background: var(--cp-white); color: var(--cp-warning); border-color: var(--cp-gray-200); }
.cp-btn--simulate:hover { background: var(--cp-warning-l); }

.cp-actions { display: flex; gap: .75rem; margin-top: 2rem; flex-wrap: wrap; }
.cp-actions--right { justify-content: flex-end; }
.cp-actions--spread { justify-content: space-between; }

/* ═══════════════════════════════════
   TABLA DE ÍTEMS
═══════════════════════════════════ */
.cp-table-wrap { overflow-x: auto; border-radius: var(--cp-radius); border: 1px solid var(--cp-gray-200); }
.cp-table {
    width: 100%;
    border-collapse: collapse;
    font-size: .88rem;
}
.cp-table th {
    background: var(--cp-gray-50);
    padding: .75rem 1rem;
    text-align: left;
    font-weight: 700;
    font-size: .72rem;
    text-transform: uppercase;
    color: var(--cp-gray-500);
    letter-spacing: .06em;
    border-bottom: 1px solid var(--cp-gray-200);
}
.cp-table td {
    padding: .65rem 1rem;
    border-bottom: 1px solid var(--cp-gray-100);
    vertical-align: middle;
    color: var(--cp-gray-700);
}
.cp-table tr:last-child td { border-bottom: none; }
.cp-table tbody tr:hover { background: var(--cp-gray-50); }
.cp-table .cp-input, .cp-table .cp-select {
    height: 34px;
    padding: 0 .65rem;
    font-size: .85rem;
    border-radius: var(--cp-radius-sm);
    box-sizing: border-box;
}
.cp-table .cp-select {
    background-position: right 0.4rem center;
    background-size: 1rem;
    padding-right: 1.5rem !important;
}

/* ═══════════════════════════════════
   RESUMEN POR CATEGORÍA
═══════════════════════════════════ */
.cp-cat-summary {
    background: var(--cp-gray-50);
    border: 1px solid var(--cp-gray-200);
    border-radius: var(--cp-radius-lg);
    padding: 1.25rem;
    margin-top: 1.25rem;
}
.cp-cat-summary-title {
    font-weight: 700;
    font-size: .78rem;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: var(--cp-gray-500);
    margin: 0 0 .875rem;
}
.cp-cat-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(130px, 1fr));
    gap: .625rem;
}
.cp-cat-item {
    background: var(--cp-white);
    border-radius: var(--cp-radius);
    padding: .75rem;
    text-align: center;
    border: 1px solid var(--cp-gray-200);
}
.cp-cat-item-label {
    display: block;
    font-size: .68rem;
    font-weight: 700;
    text-transform: uppercase;
    color: var(--cp-gray-500);
    letter-spacing: .05em;
    margin-bottom: .3rem;
}
.cp-cat-item-value {
    color: var(--cp-gray-900);
    font-weight: 700;
    font-size: .9rem;
}

/* ═══════════════════════════════════
   KPI CARDS — Limpias y planas
═══════════════════════════════════ */
.cp-kpi-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
    gap: .875rem;
    margin-bottom: 1.5rem;
}
.cp-kpi-card {
    background: var(--cp-white);
    border: 1px solid var(--cp-gray-200);
    border-radius: var(--cp-radius-lg);
    padding: 1.25rem;
    transition: box-shadow .15s;
}
.cp-kpi-card:hover { box-shadow: var(--cp-shadow); }
.cp-kpi-card--highlight {
    background: var(--cp-black);
    border-color: var(--cp-black);
}
.cp-kpi-icon { font-size: 1.25rem; margin-bottom: .5rem; display: block; }
.cp-kpi-label {
    font-size: .72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: var(--cp-gray-500);
    margin-bottom: .375rem;
    display: block;
}
.cp-kpi-card--highlight .cp-kpi-label { color: rgba(255,255,255,.55); }
.cp-kpi-value {
    font-size: 1.5rem;
    font-weight: 800;
    color: var(--cp-gray-900);
    letter-spacing: -.03em;
    line-height: 1.1;
}
.cp-kpi-card--highlight .cp-kpi-value { color: var(--cp-white); }

/* ═══════════════════════════════════
   MÉTRICAS SECUNDARIAS
═══════════════════════════════════ */
.cp-metrics-row {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
    gap: .875rem;
    margin-bottom: 1.75rem;
}
.cp-metric-box {
    display: flex;
    align-items: center;
    gap: .75rem;
    background: var(--cp-gray-50);
    border: 1px solid var(--cp-gray-200);
    border-radius: var(--cp-radius);
    padding: .875rem 1rem;
}
.cp-metric-box--highlight {
    background: var(--cp-accent-xl);
    border-color: var(--cp-accent);
}
.cp-metric-box--highlight .cp-metric-label {
    color: var(--cp-accent-d);
}
.cp-metric-box--highlight .cp-metric-value {
    color: var(--cp-accent-d);
    font-size: 1.15rem;
}

/* Dark mode compatibility for highlights */
.calc-pres-wrap.cp-dark .cp-metric-box--highlight {
    background: rgba(4, 120, 87, 0.15);
    border-color: rgba(52, 211, 153, 0.3);
}
.calc-pres-wrap.cp-dark .cp-metric-box--highlight .cp-metric-label,
.calc-pres-wrap.cp-dark .cp-metric-box--highlight .cp-metric-value {
    color: #34d399;
}
.cp-metric-icon { font-size: 1.35rem; flex-shrink: 0; }
.cp-metric-label {
    font-size: .72rem;
    font-weight: 700;
    color: var(--cp-gray-500);
    text-transform: uppercase;
    letter-spacing: .04em;
    margin-bottom: .15rem;
    display: block;
}
.cp-metric-value {
    font-weight: 800;
    font-size: 1rem;
    color: var(--cp-gray-900);
}

/* ═══════════════════════════════════
   GRÁFICO
═══════════════════════════════════ */
.cp-chart-card {
    background: var(--cp-gray-50);
    border: 1px solid var(--cp-gray-200);
    border-radius: var(--cp-radius-lg);
    padding: 1.5rem;
    margin-bottom: 1.5rem;
}
.cp-chart-title {
    font-size: .9rem;
    font-weight: 700;
    margin: 0 0 1.25rem;
    color: var(--cp-gray-700);
}
.cp-chart {
    height: 240px;
    display: flex;
    align-items: flex-end;
    gap: 5px;
    border-bottom: 1px solid var(--cp-gray-300);
    padding-top: 1.5rem;
    position: relative;
    overflow: visible;
}
.cp-chart-caption {
    font-size: .76rem;
    color: var(--cp-gray-400, #94a3b8);
    margin: .625rem 0 0;
}

.cp-bar-group {
    flex: 1;
    height: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    position: relative;
    min-width: 0;
}
.cp-bar-inner {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: flex-end;
    justify-content: center;
}
.cp-bar {
    width: 65%;
    border-radius: 4px 4px 0 0;
    background: var(--cp-gray-700);
    transition: height .6s cubic-bezier(.215, .61, .355, 1);
    min-height: 3px;
}
.cp-bar--negative {
    background: var(--cp-gray-300);
    border-radius: 0 0 4px 4px;
    align-self: flex-start;
}
.cp-bar-label {
    font-size: 9px;
    font-weight: 600;
    color: var(--cp-gray-400, #94a3b8);
    margin-top: 5px;
    text-transform: uppercase;
    letter-spacing: .03em;
}
.cp-bar-tooltip {
    position: absolute;
    background: var(--cp-black);
    color: var(--cp-white);
    padding: 8px 10px;
    border-radius: var(--cp-radius);
    font-size: 11px;
    line-height: 1.5;
    pointer-events: none;
    opacity: 0;
    transition: opacity .15s;
    z-index: 999;
    width: 160px;
    bottom: calc(100% + 10px);
    box-shadow: var(--cp-shadow-md);
}
.cp-bar-group:hover .cp-bar-tooltip { opacity: 1; }

/* ═══════════════════════════════════
   TABLA DE RESULTADOS
═══════════════════════════════════ */
.cp-table-card {
    border: 1px solid var(--cp-gray-200);
    border-radius: var(--cp-radius-lg);
    overflow: hidden;
    margin-bottom: 2rem;
}
.cp-table-title {
    font-size: .88rem;
    font-weight: 700;
    margin: 0;
    padding: 1rem 1.25rem;
    background: var(--cp-gray-50);
    border-bottom: 1px solid var(--cp-gray-200);
    color: var(--cp-gray-700);
}
.cp-results-table .cp-recovery-row { background: var(--cp-accent-xl); }
.cp-results-table .cp-recovery-row td:first-child { color: var(--cp-accent); font-weight: 700; }
.cp-no-recovery {
    background: var(--cp-danger-l);
    color: var(--cp-danger);
    padding: .875rem 1.25rem;
    font-weight: 600;
    margin: 0;
    font-size: .85rem;
    border-top: 1px solid #fee2e2;
}

/* Badges */
.cp-badge {
    padding: 2px 9px;
    border-radius: 20px;
    font-size: .72rem;
    font-weight: 700;
    display: inline-block;
    letter-spacing: .02em;
}
.cp-badge--green  { background: var(--cp-success-l); color: var(--cp-accent-d); }
.cp-badge--red    { background: var(--cp-danger-l);  color: var(--cp-danger); }
.cp-badge--yellow { background: var(--cp-warning-l); color: var(--cp-warning); }

/* ═══════════════════════════════════
   RESUMEN TIEMPO REAL — PASO 3 (v2.2.0)
═══════════════════════════════════ */
.cp-prod-summary {
    background: var(--cp-gray-50);
    border: 1px solid var(--cp-gray-200);
    border-radius: var(--cp-radius-lg);
    padding: 1.25rem;
    margin-top: .5rem;
}
.cp-prod-summary-title {
    font-size: .78rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: var(--cp-gray-500);
    margin: 0 0 .875rem;
}
.cp-prod-summary-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    gap: .75rem;
}
.cp-prod-stat {
    background: var(--cp-white);
    border: 1px solid var(--cp-gray-200);
    border-radius: var(--cp-radius);
    padding: .875rem 1rem;
    display: flex;
    flex-direction: column;
    gap: .25rem;
}
.cp-prod-stat-label {
    font-size: .72rem;
    font-weight: 600;
    color: var(--cp-gray-500);
    text-transform: uppercase;
    letter-spacing: .04em;
}
.cp-prod-stat-value {
    font-size: 1rem;
    font-weight: 800;
    color: var(--cp-accent);
}

/* ═══════════════════════════════════
   ACCIONES FINALES
═══════════════════════════════════ */
.cp-final-actions {
    display: flex;
    flex-wrap: wrap;
    gap: .75rem;
    padding-top: 1.5rem;
    border-top: 1px solid var(--cp-gray-100);
}

/* ═══════════════════════════════════
   RESPONSIVE
═══════════════════════════════════ */
@media (max-width: 640px) {
    .calc-pres-wrap { margin: 0; }
    .cp-header { border-radius: 0; padding: 1.25rem; }
    .cp-header-inner { flex-direction: column; align-items: flex-start; }
    .cp-stepper { padding: .875rem 1rem; overflow-x: auto; gap: .25rem; }
    .cp-step span { display: none; }
    .cp-panel { padding: 1.5rem 1rem; }
    .cp-kpi-grid { grid-template-columns: 1fr 1fr; }
    .cp-metrics-row { grid-template-columns: 1fr 1fr; }
    .cp-final-actions { flex-direction: column; }
    .cp-body { border-radius: 0; }
    .cp-kpi-value { font-size: 1.2rem; }
}
@media (max-width: 400px) {
    .cp-kpi-grid { grid-template-columns: 1fr; }
    .cp-metrics-row { grid-template-columns: 1fr; }
}

/* ═══ SESIÓN BANNER ═══ */
.cp-session-banner {
    display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: .75rem;
    background: #eff6ff; border: 1px solid #bfdbfe; border-radius: var(--cp-radius);
    padding: .875rem 1.25rem; margin-bottom: 1rem; font-size: .88rem; color: var(--cp-gray-700);
}
.cp-session-actions { display: flex; gap: .5rem; }

/* ═══ DARK MODE ═══ */
.calc-pres-wrap.cp-dark {
    --cp-black: #f1f5f9; --cp-gray-900: #e2e8f0; --cp-gray-700: #cbd5e1;
    --cp-gray-500: #94a3b8; --cp-gray-300: #475569; --cp-gray-200: #334155;
    --cp-gray-100: #1e293b; --cp-gray-50: #0f172a; --cp-white: #1e293b;
    --cp-accent-xl: #022c22;
    --cp-accent-l: #047857;
    --cp-accent-d: #34d399;
}
.calc-pres-wrap.cp-dark .cp-colombia-config {
    background: #0f172a;
    border-color: #334155;
}
.calc-pres-wrap.cp-dark .cp-colombia-config::before {
    color: #34d399;
}
.calc-pres-wrap.cp-dark .cp-header { background: #1e293b; border-color: #334155; }
.calc-pres-wrap.cp-dark .cp-body { background: #1e293b; border-color: #334155; }
.calc-pres-wrap.cp-dark .cp-stepper { background: #0f172a; border-color: #334155; }
.calc-pres-wrap.cp-dark .cp-input,
.calc-pres-wrap.cp-dark .cp-select,
.calc-pres-wrap.cp-dark .cp-textarea {
    background: #0f172a; color: #e2e8f0; border-color: #334155;
}
.calc-pres-wrap.cp-dark .cp-kpi-card { background: #0f172a; border-color: #334155; }
.calc-pres-wrap.cp-dark .cp-kpi-value { color: #e2e8f0; }
.calc-pres-wrap.cp-dark .cp-metric-box { background: #0f172a; border-color: #334155; }
.calc-pres-wrap.cp-dark .cp-table th { background: #0f172a; color: #94a3b8; }
.calc-pres-wrap.cp-dark .cp-table td { color: #cbd5e1; border-color: #1e293b; }
.calc-pres-wrap.cp-dark .cp-table tbody tr:hover { background: #0f172a; }
.calc-pres-wrap.cp-dark .cp-cat-summary,
.calc-pres-wrap.cp-dark .cp-prod-summary,
.calc-pres-wrap.cp-dark .cp-chart-card { background: #0f172a; border-color: #334155; }
.calc-pres-wrap.cp-dark .cp-cat-item,
.calc-pres-wrap.cp-dark .cp-prod-stat { background: #1e293b; border-color: #334155; }
.calc-pres-wrap.cp-dark .cp-bar-tooltip { background: #e2e8f0; color: #0f172a; }
.calc-pres-wrap.cp-dark .cp-session-banner { background: #1e3a5f; border-color: #2563eb; color: #bfdbfe; }

/* ═══ DIAGNÓSTICO FINANCIERO ═══ */
.cp-diagnostic {
    border: 1px solid var(--cp-gray-200); border-radius: var(--cp-radius-lg);
    overflow: hidden; margin-bottom: 1.75rem;
}
.cp-diagnostic-header {
    display: flex; align-items: center; gap: .75rem;
    padding: 1rem 1.25rem; background: var(--cp-gray-50);
    border-bottom: 1px solid var(--cp-gray-200);
}
.cp-diagnostic-header h3 {
    font-size: .9rem; font-weight: 700; margin: 0; color: var(--cp-gray-700);
}
.cp-diagnostic-grid {
    display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 0;
}
.cp-diag-card {
    display: flex; align-items: flex-start; gap: .75rem;
    padding: 1.1rem 1.25rem; border-right: 1px solid rgba(0,0,0,.06);
    border-bottom: 1px solid rgba(0,0,0,.06); border-radius: 0;
}
.cp-diag-card:last-child { border-right: none; }
.cp-diag-dot {
    width: 10px; height: 10px; border-radius: 50%; flex-shrink: 0; margin-top: .35rem;
}
.cp-diag-label {
    font-size: .72rem; font-weight: 700; text-transform: uppercase;
    letter-spacing: .05em; color: var(--cp-gray-500); margin-bottom: .25rem;
}
.cp-diag-value { font-size: 1.1rem; font-weight: 800; margin-bottom: .2rem; }
.cp-diag-desc { font-size: .78rem; color: var(--cp-gray-500); }

/* Ocultar elementos exclusivos de impresión en pantalla */
.cp-print-only {
    display: none !important;
}

/* ═══ PRINT MEJORADO (DOSSIER PROFESIONAL) ═══ */
@media print {
    /* Ocultar elementos de navegación, control y formularios web */
    .cp-session-banner, .cp-stepper, .cp-actions, .cp-final-actions,
    .cp-btn, .cp-btn--add, .cp-cat-summary, .cp-prod-summary,
    .cp-chart-card, #cp-step-1, #cp-step-2, #cp-step-3, .cp-header { 
        display: none !important; 
    }
    
    /* Mostrar elementos exclusivos de impresión */
    .cp-print-only { 
        display: block !important; 
    }
    .cp-print-only.cp-print-signatures {
        display: grid !important;
        grid-template-columns: 1fr 1fr !important;
        gap: 3rem !important;
    }
    
    /* Ajustes generales de página y tipografía */
    .calc-pres-wrap {
        max-width: 100% !important;
        margin: 0 !important;
        padding: 0 !important;
        color: #000 !important;
        background: #fff !important;
    }
    
    .cp-body {
        border: none !important;
        box-shadow: none !important;
        padding: 0 !important;
        background: transparent !important;
    }
    
    .cp-panel {
        display: block !important;
        padding: 0 !important;
    }
    
    /* Grid de KPIs impreso en 4 columnas limpias */
    .cp-kpi-grid {
        display: grid !important;
        grid-template-columns: repeat(4, 1fr) !important;
        gap: 0.75rem !important;
        margin-bottom: 1.5rem !important;
        page-break-inside: avoid;
    }
    
    .cp-kpi-card {
        border: 1px solid #ddd !important;
        background: #fff !important;
        padding: 0.875rem !important;
        border-radius: 6px !important;
    }
    
    .cp-kpi-card--highlight {
        background: #f8fafc !important;
        border-color: #cbd5e1 !important;
    }
    
    .cp-kpi-card--highlight .cp-kpi-label {
        color: #64748b !important;
    }
    
    .cp-kpi-card--highlight .cp-kpi-value {
        color: #000 !important;
    }
    
    /* Métricas secundarias en 4 o 3 columnas */
    .cp-metrics-row {
        display: grid !important;
        grid-template-columns: repeat(4, 1fr) !important;
        gap: 0.75rem !important;
        margin-bottom: 1.5rem !important;
        page-break-inside: avoid;
    }
    
    #cp-tax-metrics {
        grid-template-columns: repeat(3, 1fr) !important;
    }
    
    .cp-metric-box {
        border: 1px solid #ddd !important;
        background: #fff !important;
        padding: 0.75rem !important;
        border-radius: 6px !important;
    }
    
    .cp-metric-box--highlight {
        background: #f0fdf4 !important;
        border-color: #bbf7d0 !important;
    }
    
    .cp-metric-box--highlight .cp-metric-label {
        color: #166534 !important;
    }
    
    .cp-metric-box--highlight .cp-metric-value {
        color: #166534 !important;
    }
    
    /* Diagnóstico de salud */
    .cp-diagnostic {
        border: 1px solid #ddd !important;
        margin-bottom: 1.5rem !important;
        page-break-inside: avoid;
    }
    
    .cp-diagnostic-grid {
        display: grid !important;
        grid-template-columns: repeat(4, 1fr) !important;
    }
    
    .cp-diag-card {
        border: 1px solid rgba(0,0,0,0.1) !important;
        padding: 0.75rem !important;
    }
    
    /* Tablas impresas */
    .cp-table-card {
        border: 1px solid #ccc !important;
        margin-bottom: 1.5rem !important;
        page-break-inside: avoid;
    }
    
    .cp-table {
        border-collapse: collapse !important;
        width: 100% !important;
    }
    
    .cp-table th, .cp-table td {
        border: 1px solid #ddd !important;
        padding: 6px 10px !important;
        font-size: 0.78rem !important;
    }
    
    .cp-table th {
        background: #f1f5f9 !important;
        color: #1e293b !important;
    }
    
    .cp-results-table .cp-recovery-row {
        background: #ecfdf5 !important;
    }
    
    .cp-results-table .cp-recovery-row td {
        font-weight: 700 !important;
    }
    
    .cp-badge {
        border: 1px solid #ccc !important;
        background: transparent !important;
        color: #000 !important;
        padding: 1px 6px !important;
    }
    
    /* Firmas en impresión */
    .cp-print-signatures {
        page-break-inside: avoid;
    }
    
    @page {
        size: portrait;
        margin: 1.2cm;
    }
}

