:root{--teal: #0f766e;--teal-light: #ccfbf1;--teal-hover: #0d9488;--bg: #f8f9fa;--surface: #ffffff;--border: #e5e7eb;--border-soft: #f3f4f6;--text: #111827;--text-muted: #6b7280;--text-subtle: #9ca3af;--warn: #d97706;--warn-light: #fef3c7;--err: #dc2626;--err-light: #fee2e2;--ok-light: #dcfce7;--ok: #16a34a;--radius: 8px;--radius-sm: 5px;--shadow: 0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 4px 16px rgba(0,0,0,.1)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:IBM Plex Sans,system-ui,sans-serif;background:var(--bg);color:var(--text);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}.mono{font-family:IBM Plex Mono,Courier New,monospace}.header{background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100}.header-inner{max-width:1280px;margin:0 auto;padding:0 24px;height:56px;display:flex;align-items:center;justify-content:space-between}.header-brand{display:flex;align-items:center;gap:10px}.header-title{font-size:16px;font-weight:600;color:var(--text);letter-spacing:-.3px}.header-nav{display:flex;gap:4px}.nav-btn{padding:6px 14px;border-radius:var(--radius-sm);border:none;background:transparent;font:inherit;font-size:13px;font-weight:500;color:var(--text-muted);cursor:pointer;transition:all .15s}.nav-btn:hover{background:var(--border-soft);color:var(--text)}.nav-btn.active{background:var(--teal-light);color:var(--teal)}.main{max-width:1280px;margin:0 auto;padding:24px}.selectors-row{display:flex;align-items:flex-start;gap:10px;margin-bottom:12px}.anio-selector{position:relative;flex-shrink:0;width:160px}.anio-btn{width:100%;display:flex;align-items:center;justify-content:space-between;gap:10px;padding:8px 14px;min-height:44px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;font:inherit;text-align:left;transition:border-color .15s}.anio-btn:hover,.anio-btn.open{border-color:var(--teal)}.anio-btn-content{display:flex;flex-direction:column;gap:2px}.anio-btn-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted)}.anio-btn-value{font-size:14px;font-weight:700;color:var(--teal)}.anio-chevron{flex-shrink:0;color:var(--text-muted);transition:transform .15s}.anio-btn.open .anio-chevron{transform:rotate(180deg)}.anio-dropdown{position:absolute;top:calc(100% + 6px);left:0;right:0;z-index:150;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-md);overflow:hidden}.anio-option{width:100%;display:block;padding:10px 14px;background:transparent;border:none;border-bottom:1px solid var(--border-soft);cursor:pointer;font:inherit;font-size:14px;font-weight:600;text-align:left;color:var(--text);transition:background .1s}.anio-option:last-child{border-bottom:none}.anio-option:hover{background:var(--border-soft)}.anio-option.selected{background:var(--teal-light);color:var(--teal)}.cliente-selector{position:relative;flex:1;min-width:0}.cliente-btn{width:100%;display:flex;align-items:center;justify-content:space-between;gap:10px;padding:8px 14px;min-height:44px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;font:inherit;text-align:left;transition:border-color .15s}.cliente-btn:hover,.cliente-btn.open{border-color:var(--teal)}.cliente-btn.has-value{border-color:var(--teal);background:var(--teal-light)}.cliente-btn-content{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1}.cliente-btn-nombre{font-size:13px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cliente-btn-placeholder{font-weight:400;color:var(--text-muted)}.cliente-btn-meta{font-size:11px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cliente-chevron{flex-shrink:0;color:var(--text-muted);transition:transform .15s}.cliente-btn.open .cliente-chevron{transform:rotate(180deg)}.cliente-dropdown{position:absolute;top:calc(100% + 6px);left:0;right:0;z-index:150;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-md);max-height:320px;overflow-y:auto}.cliente-option{width:100%;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 14px;background:transparent;border:none;border-bottom:1px solid var(--border-soft);cursor:pointer;font:inherit;text-align:left;transition:background .1s}.cliente-option:last-child{border-bottom:none}.cliente-option:hover{background:var(--border-soft)}.cliente-option.selected{background:var(--teal-light)}.cliente-option-main{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1}.cliente-option-nombre{font-size:13px;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cliente-option-rfc{font-size:11px;color:var(--text-muted)}.cliente-option-meta{font-size:11px;color:var(--text-muted);white-space:nowrap;flex-shrink:0}.cliente-option.selected .cliente-option-nombre{color:var(--teal);font-weight:600}.summary-strip{display:flex;gap:0;flex-wrap:wrap;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:16px;overflow:hidden}.summary-item{flex:1;min-width:140px;padding:14px 20px;display:flex;flex-direction:column;gap:2px;border-right:1px solid var(--border)}.summary-item:last-child{border-right:none}.summary-label{font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);font-weight:500}.summary-value{font-size:18px;font-weight:600;color:var(--text)}.summary-value.teal{color:var(--teal)}.summary-value.warn{color:var(--warn)}.filter-bar{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}.filter-input,.filter-select{height:36px;padding:0 12px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text);font:inherit;font-size:13px;outline:none;transition:border-color .15s}.filter-input:focus,.filter-select:focus{border-color:var(--teal)}.filter-search{flex:1;min-width:200px}.table-wrapper{overflow-x:auto;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius)}.factura-table{width:100%;border-collapse:collapse}.factura-table th{padding:10px 14px;text-align:left;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);background:var(--border-soft);border-bottom:1px solid var(--border);white-space:nowrap}.factura-table td{padding:11px 14px;border-bottom:1px solid var(--border-soft);font-size:13px;vertical-align:middle}.factura-table tbody tr:last-child td{border-bottom:none}.factura-row{cursor:pointer;transition:background .1s}.factura-row:hover td{background:#f0fdf9}.cell-name{font-weight:500}.cell-rfc{font-size:11px;color:var(--text-muted);margin-top:1px}.right{text-align:right}.badge{display:inline-block;padding:2px 8px;border-radius:20px;font-size:11px;font-weight:600;white-space:nowrap}.badge-ok{background:var(--ok-light);color:var(--ok)}.badge-warn{background:var(--warn-light);color:var(--warn)}.badge-err{background:var(--err-light);color:var(--err)}.fuente-tag{display:inline-block;padding:2px 7px;border-radius:4px;font-size:11px;font-weight:500;font-family:IBM Plex Mono,monospace;background:var(--border-soft);color:var(--text-muted);border:1px solid var(--border)}.pagination{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--surface);border:1px solid var(--border);border-top:none;border-radius:0 0 var(--radius) var(--radius)}.page-btn{padding:6px 14px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text);font:inherit;font-size:13px;cursor:pointer;transition:all .15s}.page-btn:hover:not(:disabled){border-color:var(--teal);color:var(--teal)}.page-btn:disabled{opacity:.4;cursor:not-allowed}.page-info{font-size:13px;color:var(--text-muted)}.loading-state,.empty-state,.error-state{padding:48px 24px;text-align:center;color:var(--text-muted);font-size:14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius)}.error-state{color:var(--err)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;display:flex;align-items:flex-start;justify-content:center;padding:24px;z-index:200;overflow-y:auto}.modal{background:var(--surface);border-radius:12px;box-shadow:var(--shadow-md);width:100%;max-width:780px;min-height:200px;flex-shrink:0}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 16px;border-bottom:1px solid var(--border);gap:12px}.modal-title{font-size:17px;font-weight:600;margin-bottom:6px}.modal-close{width:32px;height:32px;border-radius:6px;border:1px solid var(--border);background:transparent;color:var(--text-muted);font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s}.modal-close:hover{background:var(--border-soft);color:var(--text)}.modal-body{padding:20px 24px 28px;display:flex;flex-direction:column;gap:24px}.section-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--teal);margin-bottom:12px;padding-bottom:6px;border-bottom:1px solid var(--teal-light)}.fields-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}.primary-row{display:flex;gap:16px;flex-wrap:wrap;padding:16px 18px;background:var(--border-soft);border-radius:var(--radius);border:1px solid var(--border)}.primary-row-field{min-width:0}.primary-row-field.grow{flex:1;min-width:200px}.parties-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}@media (max-width: 560px){.parties-grid{grid-template-columns:1fr}}.party-card{border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;display:flex;flex-direction:column;gap:10px;background:var(--surface)}.party-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--teal)}.totals-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.totals-grid-5{grid-template-columns:repeat(6,1fr)}.totals-grid-5 .total-item:nth-child(1),.totals-grid-5 .total-item:nth-child(2),.totals-grid-5 .total-item:nth-child(3){grid-column:span 2}.totals-grid-5 .total-item:nth-child(3){border-right:none}.totals-grid-5 .total-item:nth-child(4),.totals-grid-5 .total-item:nth-child(5){grid-column:span 3;border-top:1px solid var(--border)}.total-item .copy-field-value{white-space:nowrap}@media (max-width: 640px){.totals-grid,.totals-grid-5{grid-template-columns:repeat(2,1fr)}.totals-grid-5 .total-item{grid-column:span 1!important;border-top:none!important}.totals-grid-5 .total-item:nth-child(3){border-right:1px solid var(--border)}.totals-grid-5 .total-item:nth-child(2n){border-right:none}}.total-item{padding:14px 16px;border-right:1px solid var(--border);background:var(--surface)}.total-item:last-child{border-right:none}.total-item-main{background:var(--teal-light)}.total-item-main .copy-field-value{font-size:15px;font-weight:700;color:var(--teal)}.total-item-discount{background:#fffbeb}.total-item-discount .copy-field-value{color:var(--warn)}.pago-row{display:flex;gap:16px;flex-wrap:wrap}.pago-row>*{flex:1;min-width:140px}.status-cta{width:100%;padding:12px 20px;border-radius:var(--radius);border:none;font:inherit;font-size:14px;font-weight:600;cursor:pointer;transition:all .15s;letter-spacing:.01em}.status-cta:disabled{opacity:.5;cursor:not-allowed}.status-cta-ok{background:var(--ok);color:#fff}.status-cta-ok:hover:not(:disabled){background:#15803d}.status-cta-warn{background:var(--warn);color:#fff}.status-cta-warn:hover:not(:disabled){background:#b45309}.detail-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;padding:10px 14px;border:1px dashed var(--border);border-radius:var(--radius);background:transparent;cursor:pointer;font:inherit;font-size:12px;font-weight:500;color:var(--text-muted);transition:all .15s;gap:8px}.detail-toggle:hover{border-color:var(--teal);color:var(--teal);background:var(--teal-light)}.detail-toggle-hint{font-size:11px;color:var(--text-subtle);font-weight:400}.collapsible-section{display:flex;flex-direction:column;gap:24px;border-top:1px solid var(--border);padding-top:20px}.copy-field{display:flex;flex-direction:column;gap:3px}.copy-field-label{font-size:11px;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.copy-field-row{display:flex;align-items:center;gap:6px}.copy-field-value{font-size:13px;color:var(--text);word-break:break-all;flex:1}.copy-field-value.mono{font-family:IBM Plex Mono,monospace;font-size:12px}.copy-field-empty{color:var(--text-subtle)}.copy-btn{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface);color:var(--text-muted);font:inherit;font-size:11px;cursor:pointer;white-space:nowrap;flex-shrink:0;transition:all .15s}.copy-btn:hover{border-color:var(--teal);color:var(--teal);background:var(--teal-light)}.copy-btn.copied{border-color:var(--ok);color:var(--ok);background:var(--ok-light)}.conceptos-table-wrapper{overflow-x:auto;border:1px solid var(--border);border-radius:var(--radius)}.conceptos-table{width:100%;border-collapse:collapse}.conceptos-table th{padding:8px 12px;text-align:left;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);background:var(--border-soft);border-bottom:1px solid var(--border)}.conceptos-table td{padding:9px 12px;border-bottom:1px solid var(--border-soft);font-size:12px}.conceptos-table tbody tr:last-child td{border-bottom:none}.resumen-container{display:flex;flex-direction:column;gap:20px}.resumen-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}.resumen-title{font-size:20px;font-weight:600}.resumen-selectors{display:flex;gap:8px}.resumen-dropdown{position:relative;flex-shrink:0}.resumen-dd-btn{width:100%;display:flex;align-items:center;justify-content:space-between;gap:10px;padding:8px 14px;min-height:44px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;font:inherit;text-align:left;transition:border-color .15s}.resumen-dd-btn:hover,.resumen-dd-btn.open{border-color:var(--teal)}.resumen-dd-content{display:flex;flex-direction:column;gap:2px}.resumen-dd-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted)}.resumen-dd-value{font-size:14px;font-weight:700;color:var(--teal)}.resumen-dd-chevron{flex-shrink:0;color:var(--text-muted);transition:transform .15s}.resumen-dd-btn.open .resumen-dd-chevron{transform:rotate(180deg)}.resumen-dd-panel{position:absolute;top:calc(100% + 6px);left:0;right:0;z-index:150;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-md);max-height:260px;overflow-y:auto}.resumen-dd-option{width:100%;display:block;padding:9px 14px;background:transparent;border:none;border-bottom:1px solid var(--border-soft);cursor:pointer;font:inherit;font-size:13px;font-weight:500;text-align:left;color:var(--text);transition:background .1s}.resumen-dd-option:last-child{border-bottom:none}.resumen-dd-option:hover{background:var(--border-soft)}.resumen-dd-option.selected{background:var(--teal-light);color:var(--teal);font-weight:600}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px}.kpi-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px 20px;display:flex;flex-direction:column;gap:4px;box-shadow:var(--shadow)}.kpi-label{font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);font-weight:500}.kpi-value{font-size:22px;font-weight:700;color:var(--text)}.kpi-value.teal{color:var(--teal)}.resumen-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px 20px;box-shadow:var(--shadow)}.card-title{font-size:13px;font-weight:600;color:var(--text);margin-bottom:14px}.top-emisores{grid-column:1 / -1}.stat-list{display:flex;flex-direction:column;gap:10px}.stat-row{display:flex;align-items:center;justify-content:space-between}.stat-count{font-weight:600;font-size:15px}.modal-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.action-btn{height:32px;padding:0 12px;border-radius:var(--radius-sm);border:1px solid transparent;font:inherit;font-size:12px;font-weight:500;cursor:pointer;white-space:nowrap;transition:all .15s}.action-btn:disabled{opacity:.5;cursor:not-allowed}.action-btn-ok{background:var(--ok-light);color:var(--ok);border-color:#bbf7d0}.action-btn-ok:hover:not(:disabled){background:#dcfce7;border-color:var(--ok)}.action-btn-warn{background:var(--warn-light);color:var(--warn);border-color:#fde68a}.action-btn-warn:hover:not(:disabled){background:#fef3c7;border-color:var(--warn)}.action-btn-delete{background:var(--err-light);color:var(--err);border-color:#fecaca}.action-btn-delete:hover:not(:disabled){background:#fee2e2;border-color:var(--err)}.action-btn-delete.confirming{background:var(--err);color:#fff;border-color:var(--err)}@keyframes rowFadeIn{0%{opacity:0;background:#f0fdf9}to{opacity:1;background:transparent}}.row-new td{animation:rowFadeIn 1.5s ease-out forwards}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-subtle)}
