*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--color-bg: #f8f9fb;--color-surface: #ffffff;--color-surface-hover: #f1f3f7;--color-surface-active: #e8ebf0;--color-border: #dfe2e8;--color-border-strong: #c4c9d4;--color-text: #1a1d26;--color-text-secondary: #5c6370;--color-text-muted: #8b919e;--color-primary: #1a6b5a;--color-primary-hover: #145a4b;--color-primary-light: #e6f5f0;--color-primary-text: #ffffff;--color-danger: #c0392b;--color-danger-light: #fdf0ee;--color-warning: #d4830a;--color-warning-light: #fef9ee;--color-success: #1a7a4c;--color-success-light: #edf8f2;--color-drop-zone: #e8f4ef;--color-drop-zone-active: #d0eadf;--color-drop-zone-border: #1a6b5a;--font-body: "DM Sans", -apple-system, BlinkMacSystemFont, sans-serif;--font-mono: "JetBrains Mono", "SF Mono", monospace;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .06);--shadow-md: 0 4px 12px rgba(0, 0, 0, .08);--shadow-lg: 0 8px 30px rgba(0, 0, 0, .1);--transition-fast: .15s ease;--transition-normal: .25s ease}html{font-size:15px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-body);color:var(--color-text);background:var(--color-bg);line-height:1.6;min-height:100vh}.app-shell{display:flex;flex-direction:column;height:100vh}.app-header{display:flex;align-items:center;justify-content:space-between;padding:0 2rem;height:60px;background:var(--color-surface);border-bottom:1px solid var(--color-border);position:sticky;top:0;z-index:100}.app-logo{display:flex;align-items:center;gap:.6rem;font-weight:600;font-size:1.05rem;color:var(--color-text);text-decoration:none}.app-logo-icon{width:28px;height:28px;background:var(--color-primary);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;color:#fff;font-size:.75rem;font-weight:700}.app-header-actions{display:flex;align-items:center;gap:1rem}.app-user-info{font-size:.85rem;color:var(--color-text-secondary)}.app-main{flex:1;padding:2rem;max-width:1400px;width:100%;min-width:0;min-height:0;overflow-y:auto;display:flex;flex-direction:column}.app-main:has(.page-viewport),.app-main.app-main-viewport{overflow:hidden}.app-main:has(.invoice-detail-panel),.app-main.app-main-wide{max-width:none}.app-body{display:flex;flex:1;min-height:0}.app-sidebar{width:220px;min-width:220px;background:var(--color-surface);border-right:1px solid var(--color-border);padding:1rem 0;display:flex;flex-direction:column;gap:2px}.sidebar-link{display:flex;align-items:center;gap:.6rem;padding:.55rem 1.25rem;font-size:.875rem;font-weight:500;color:var(--color-text-secondary);text-decoration:none;border-left:3px solid transparent;transition:all var(--transition-fast);cursor:pointer}.sidebar-link:hover:not(.disabled){color:var(--color-text);background:var(--color-surface-hover)}.sidebar-link.active{color:var(--color-primary);background:var(--color-primary-light);border-left-color:var(--color-primary);font-weight:600}.sidebar-link.disabled{color:var(--color-text-muted);cursor:default;opacity:.7}.sidebar-icon{flex-shrink:0}.sidebar-badge{margin-left:auto;font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;padding:.1rem .4rem;border-radius:8px;background:var(--color-surface-active);color:var(--color-text-muted)}.dashboard-summary-row{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.dashboard-summary-label{font-size:.8rem;font-weight:500;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.04em;margin-bottom:.35rem}.dashboard-summary-value{font-size:1.5rem;font-weight:700;font-family:var(--font-mono)}.dashboard-summary-value.revenue{color:var(--color-success)}.dashboard-summary-value.costs{color:var(--color-danger)}.bar-chart-container{width:100%;overflow:hidden}.chart-tooltip{position:absolute;pointer-events:none;transform:translate(-50%,-100%);background:var(--color-text);color:var(--color-surface);padding:.45rem .7rem;border-radius:var(--radius-sm);font-size:.78rem;box-shadow:var(--shadow-md);white-space:nowrap;z-index:50}.chart-tooltip-month{font-weight:600;margin-bottom:.2rem;font-size:.72rem;opacity:.7;text-transform:uppercase;letter-spacing:.03em}.chart-tooltip-row{display:flex;align-items:center;gap:.4rem}.chart-tooltip-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.chart-tooltip-label{opacity:.8}.chart-tooltip-value{font-family:var(--font-mono);font-weight:600}.btn{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem 1.1rem;font-family:var(--font-body);font-size:.875rem;font-weight:500;border:1px solid transparent;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);text-decoration:none;line-height:1.4}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--color-primary);color:var(--color-primary-text);border-color:var(--color-primary)}.btn-primary:hover:not(:disabled){background:var(--color-primary-hover)}.btn-secondary{background:var(--color-surface);color:var(--color-text);border-color:var(--color-border)}.btn-secondary:hover:not(:disabled){background:var(--color-surface-hover);border-color:var(--color-border-strong)}.btn-danger{background:var(--color-surface);color:var(--color-danger);border-color:var(--color-border)}.btn-danger:hover:not(:disabled){background:var(--color-danger-light);border-color:var(--color-danger)}.btn-ghost{background:transparent;color:var(--color-text-secondary);border-color:transparent}.btn-ghost:hover:not(:disabled){background:var(--color-surface-hover);color:var(--color-text)}.btn-sm{padding:.3rem .7rem;font-size:.8rem}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-sm)}.card-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--color-border)}.card-title{font-size:.95rem;font-weight:600}.card-body{padding:1.25rem}.drop-zone{border:2px dashed var(--color-border-strong);border-radius:var(--radius-lg);padding:3rem 2rem;text-align:center;cursor:pointer;transition:all var(--transition-normal);background:var(--color-bg)}.drop-zone:hover{border-color:var(--color-primary);background:var(--color-drop-zone)}.drop-zone.active{border-color:var(--color-drop-zone-border);background:var(--color-drop-zone-active);border-style:solid}.drop-zone.disabled{opacity:.5;cursor:not-allowed}.drop-zone-icon{font-size:2.5rem;margin-bottom:.75rem;opacity:.6}.drop-zone-text{font-size:.95rem;color:var(--color-text-secondary);margin-bottom:.25rem}.drop-zone-hint{font-size:.8rem;color:var(--color-text-muted)}.progress-bar-container{margin-top:1.5rem}.progress-bar-label{display:flex;justify-content:space-between;font-size:.8rem;color:var(--color-text-secondary);margin-bottom:.4rem}.progress-bar-track{width:100%;height:6px;background:var(--color-surface-active);border-radius:3px;overflow:hidden}.progress-bar-fill{height:100%;background:var(--color-primary);border-radius:3px;transition:width var(--transition-normal)}.status-badge{display:inline-flex;align-items:center;gap:.3rem;padding:.2rem .6rem;font-size:.75rem;font-weight:500;border-radius:20px;white-space:nowrap}.status-badge.success{background:var(--color-success-light);color:var(--color-success)}.status-badge.warning{background:var(--color-warning-light);color:var(--color-warning)}.status-badge.danger{background:var(--color-danger-light);color:var(--color-danger)}.status-badge.neutral{background:var(--color-surface-active);color:var(--color-text-secondary)}.status-badge.primary{background:var(--color-primary-light);color:var(--color-primary)}.source-badge{display:inline-flex;align-items:center;padding:.15rem .45rem;font-size:.7rem;font-weight:500;border-radius:4px;white-space:nowrap}.source-portal{background:var(--color-primary-light);color:var(--color-primary)}.source-bc{background:var(--color-surface-active);color:var(--color-text-secondary)}.table-container{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:.875rem}thead th{text-align:left;padding:.65rem 1rem;font-weight:600;font-size:.78rem;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--color-border);white-space:nowrap}tbody td{padding:.65rem 1rem;border-bottom:1px solid var(--color-border);color:var(--color-text)}tbody tr:last-child td{border-bottom:none}tbody tr:hover{background:var(--color-surface-hover)}td.mono{font-family:var(--font-mono);font-size:.8rem}th.sortable{cursor:pointer;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}th.sortable:hover{color:var(--color-text)}.sort-indicator{font-size:.7rem;margin-left:.2rem}.alert{padding:.75rem 1rem;border-radius:var(--radius-sm);font-size:.875rem;display:flex;align-items:flex-start;gap:.5rem}.alert-success{background:var(--color-success-light);color:var(--color-success);border:1px solid #c6e6d4}.alert-error{background:var(--color-danger-light);color:var(--color-danger);border:1px solid #f0d0cc}.alert-warning{background:var(--color-warning-light);color:var(--color-warning);border:1px solid #f0deb8}.empty-state{text-align:center;padding:3rem 1rem;color:var(--color-text-muted)}.empty-state-icon{font-size:2rem;margin-bottom:.5rem;opacity:.4}.empty-state-text{font-size:.9rem}.page-title{font-size:1.35rem;font-weight:600;margin-bottom:.25rem}.page-subtitle{font-size:.9rem;color:var(--color-text-secondary);margin-bottom:0}.section{margin-bottom:2rem}.page-viewport{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden}.page-viewport-header{display:flex;justify-content:space-between;align-items:center;flex-shrink:0;margin-bottom:1rem}.page-viewport .tabs{flex-shrink:0}.card-viewport{flex:1;min-height:0;display:flex;flex-direction:column}.table-scroll{flex:1;min-height:0;overflow-y:auto;overflow-x:auto}.table-scroll thead th{position:sticky;top:0;background:var(--color-surface);z-index:1;box-shadow:inset 0 -1px 0 var(--color-border)}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:2rem}.login-card{max-width:380px;width:100%;text-align:center}.login-card .card-body{padding:2.5rem 2rem}.login-logo{margin-bottom:1.5rem}.login-title{font-size:1.25rem;font-weight:600;margin-bottom:.35rem}.login-subtitle{font-size:.85rem;color:var(--color-text-secondary);margin-bottom:2rem}.login-btn{width:100%;justify-content:center;padding:.7rem 1.5rem;font-size:.95rem}.tabs{display:flex;gap:0;border-bottom:1px solid var(--color-border);margin-bottom:1.5rem}.tab{padding:.6rem 1.2rem;font-size:.875rem;font-weight:500;color:var(--color-text-secondary);cursor:pointer;border:none;background:none;border-bottom:2px solid transparent;margin-bottom:-1px;transition:all var(--transition-fast);font-family:var(--font-body)}.tab:hover{color:var(--color-text)}.tab.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.form-group{margin-bottom:1rem}.form-label{display:block;font-size:.82rem;font-weight:500;color:var(--color-text-secondary);margin-bottom:.35rem}.form-input,.form-select{width:100%;padding:.5rem .75rem;font-family:var(--font-body);font-size:.875rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);color:var(--color-text);transition:border-color var(--transition-fast)}.form-input:focus,.form-select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.spinner{display:inline-block;width:18px;height:18px;border:2px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-page{display:flex;align-items:center;justify-content:center;min-height:100vh;gap:.75rem;color:var(--color-text-secondary);font-size:.9rem}.search-select,.search-select-input-wrapper{position:relative}.search-select-display{display:flex;align-items:center;gap:.4rem;padding:.5rem .75rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);cursor:pointer;min-height:37px;transition:border-color var(--transition-fast)}.search-select-display:hover{border-color:var(--color-border-strong)}.search-select-value{font-size:.875rem;color:var(--color-text);flex:1}.search-select-sublabel{font-size:.75rem;color:var(--color-text-muted)}.search-select-clear{background:none;border:none;font-size:1.1rem;color:var(--color-text-muted);cursor:pointer;padding:0 .2rem;line-height:1}.search-select-clear:hover{color:var(--color-danger)}.search-select-dropdown{margin-top:2px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);box-shadow:var(--shadow-md);max-height:240px;overflow-y:auto;z-index:10000}.search-select-option{display:flex;align-items:center;justify-content:space-between;padding:.45rem .75rem;cursor:pointer;white-space:nowrap;transition:background var(--transition-fast)}.search-select-option:hover,.search-select-option.focused{background:var(--color-surface-hover)}.search-select-option.selected{background:var(--color-primary-light)}.search-select-option-label{font-size:.85rem;color:var(--color-text)}.search-select-option-sublabel{font-size:.75rem;color:var(--color-text-muted);margin-left:.5rem}.search-select-empty{padding:.75rem;text-align:center;font-size:.85rem;color:var(--color-text-muted)}table .form-input,table .form-select{padding:.35rem .5rem;font-size:.82rem}table .search-select-display{padding:.35rem .5rem;min-height:32px}table .search-select-display .search-select-sublabel{display:none}table .search-select-option{padding:.35rem .6rem}tfoot td{border-top:2px solid var(--color-border-strong);padding:.75rem 1rem}.pagination{display:flex;align-items:center;justify-content:center;gap:.3rem;padding:.75rem 1rem;flex-shrink:0;border-top:1px solid var(--color-border)}.pagination-btn{display:inline-flex;align-items:center;justify-content:center;min-width:2rem;padding:.35rem .6rem;font-family:var(--font-body);font-size:.8rem;font-weight:500;color:var(--color-text-secondary);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast)}.pagination-btn:hover:not(:disabled){background:var(--color-surface-hover);border-color:var(--color-border-strong);color:var(--color-text)}.pagination-btn:disabled{opacity:.4;cursor:not-allowed}.pagination-btn.active{background:var(--color-primary);color:var(--color-primary-text);border-color:var(--color-primary)}.pagination-ellipsis{padding:0 .3rem;color:var(--color-text-muted)}.pagination-size-select{padding:.3rem .5rem;font-family:var(--font-body);font-size:.8rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);color:var(--color-text-secondary);cursor:pointer;margin-right:.5rem}.pagination-size-select:focus{outline:none;border-color:var(--color-primary)}.pagination-info{margin-left:.75rem;font-size:.8rem;color:var(--color-text-muted)}.invoice-split-pane{display:flex;flex:1;min-height:0;overflow:hidden}.invoice-split-pane.dragging{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;cursor:col-resize}.invoice-split-pane.dragging iframe{pointer-events:none}.invoice-list-panel{min-width:300px;display:flex;flex-direction:column;overflow:hidden}.invoice-detail-panel{flex:1;min-width:350px;display:flex;flex-direction:column;overflow:hidden;overflow-y:auto;border-left:1px solid var(--color-border)}.invoice-form-panel{padding-left:1.25rem;overflow-y:auto;flex:1}.invoice-drag-handle{width:6px;cursor:col-resize;background:var(--color-border);flex-shrink:0;transition:background .15s}.invoice-drag-handle:hover,.invoice-drag-handle.active{background:var(--color-primary)}.horizontal-drag-handle{height:6px;cursor:row-resize;background:var(--color-border);flex-shrink:0;transition:background .15s}.horizontal-drag-handle:hover,.horizontal-drag-handle.active{background:var(--color-primary)}tbody tr.selected-row{background:var(--color-primary-light)!important}tbody tr{cursor:pointer}.invoice-preview-container{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden}.invoice-preview-container.dragging{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;cursor:row-resize}.invoice-preview-container.dragging iframe{pointer-events:none}.invoice-preview-toolbar{padding:.5rem 1rem;border-bottom:1px solid var(--color-border);flex-shrink:0;display:flex;justify-content:flex-end}.invoice-preview-scroll{flex:1;overflow-y:auto;padding:1.5rem;background:var(--color-bg)}.pdf-viewer-top{flex:1;min-height:100px;overflow:hidden;background:var(--color-bg)}.pdf-viewer-drag-handle{height:6px;cursor:row-resize;background:var(--color-border);flex-shrink:0;transition:background .15s}.pdf-viewer-drag-handle:hover,.pdf-viewer-drag-handle.active{background:var(--color-primary)}.pdf-viewer-bottom{flex:1;min-height:100px;overflow-y:auto;background:var(--color-surface)}.expand-chevron{display:inline-block;font-size:.65rem;transition:transform .15s}.expand-chevron.expanded{transform:rotate(90deg)}.extracted-detail-row>td{background:var(--color-bg)}.extracted-detail{padding:.75rem 1rem;display:flex;flex-direction:column;gap:.75rem}.extracted-detail h5{margin:0 0 .4rem;font-size:.8rem;text-transform:uppercase;letter-spacing:.04em;color:var(--color-text-muted)}.extracted-detail-parties{display:flex;gap:1.5rem}.extracted-detail-parties>.extracted-detail-section{flex:1;min-width:0}.extracted-detail-section{padding:.5rem .75rem;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface)}.extracted-fields{display:flex;flex-wrap:wrap;gap:.5rem 1.5rem}.extracted-field{display:flex;flex-direction:column;gap:.1rem}.extracted-field .field-label{font-size:.7rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.03em}.extracted-field.field-match{background:#22c55e1f;border-radius:var(--radius);padding:.2rem .4rem}.extracted-field.field-mismatch{background:#ef44441f;border-radius:var(--radius);padding:.2rem .4rem}.extracted-field.field-info{background:#3b82f61f;border-radius:var(--radius);padding:.2rem .4rem}.extracted-field-select .search-select,.extracted-field-select .search-select-input-wrapper{line-height:normal}.extracted-field-select .search-select-display{border:none;background:none;padding:0;min-height:auto;gap:.25rem;line-height:normal}.extracted-field-select .search-select-display:hover{border-color:transparent}.extracted-field-select .search-select-value{font-size:.85rem}.extracted-field-select .search-select-sublabel{display:none}.extracted-field-select .search-select-clear{font-size:.9rem;padding:0}.extracted-field-select .search-select-input-wrapper .form-input{border:none;background:none;padding:0;font-size:.85rem;height:auto;min-height:auto;line-height:normal;box-shadow:none;border-bottom:1px dashed var(--color-border-strong);border-radius:0}.extracted-field-select .search-select-input-wrapper .form-input:focus{outline:none;box-shadow:none;border-bottom-color:var(--color-primary)}.btn-revalidate{background:none;border:1px solid var(--color-border, #e2e8f0);border-radius:var(--radius);cursor:pointer;font-size:.85em;padding:0 .3rem;margin-left:.3rem;color:var(--color-text-muted);vertical-align:middle;line-height:1}.btn-revalidate:hover:not(:disabled){background:var(--color-bg-hover, #f1f5f9);color:var(--color-text)}.btn-revalidate:disabled{opacity:.5;cursor:default}.validation-warning{color:var(--color-warning, #d97706);cursor:help;font-size:.9em}.extracted-lines-table{width:100%;font-size:.85rem}.extracted-lines-table th{font-size:.7rem;text-transform:uppercase;letter-spacing:.03em}.a4-page{background:#fff;box-shadow:0 2px 12px #0000001a;padding:3rem 2.5rem;max-width:794px;margin:0 auto;font-size:.85rem;line-height:1.5}.a4-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:2px solid var(--color-text)}.a4-title{font-size:1.6rem;font-weight:700;letter-spacing:.06em;color:var(--color-text)}.a4-invoice-number{font-size:.95rem;font-family:var(--font-mono);color:var(--color-text-secondary);margin-top:.25rem}.a4-meta{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:1.25rem;margin-bottom:2rem}.a4-meta-block{min-width:0}.a4-meta-label{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--color-text-muted);margin-bottom:.2rem}.a4-meta-value{font-size:.88rem;font-weight:500;color:var(--color-text)}.a4-meta-sub{font-size:.78rem;color:var(--color-text-secondary)}.a4-lines-table{width:100%;border-collapse:collapse;font-size:.82rem;margin-bottom:1.5rem}.a4-lines-table thead th{padding:.5rem .6rem;font-weight:600;font-size:.72rem;text-transform:uppercase;letter-spacing:.03em;color:var(--color-text-secondary);border-bottom:1px solid var(--color-border-strong);white-space:nowrap}.a4-lines-table tbody td{padding:.45rem .6rem;border-bottom:1px solid var(--color-border);color:var(--color-text)}.a4-lines-table tbody tr:last-child td{border-bottom:none}.a4-lines-table tbody tr:hover{background:transparent}.a4-lines-table tbody tr{cursor:default}.a4-totals{border-top:2px solid var(--color-text);padding-top:1rem;margin-top:.5rem}.a4-total-row{display:flex;justify-content:space-between;align-items:baseline;font-size:1.05rem;font-weight:700}.a4-total-amount{font-family:var(--font-mono);font-size:1.15rem}.a4-no-lines{padding:2rem 1rem;text-align:center;color:var(--color-text-muted);font-size:.88rem;font-style:italic;border:1px dashed var(--color-border);border-radius:var(--radius-sm);margin-bottom:1.5rem}.a4-attachment{margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--color-border);font-size:.8rem;color:var(--color-text-secondary)}.epc-qr-section{margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--color-border);display:flex;flex-direction:column;align-items:center;gap:.5rem}.epc-qr-label{font-size:.85rem;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em}.epc-qr-image{width:200px;height:200px}.epc-qr-details{font-size:.75rem;color:var(--color-text-secondary);font-family:var(--font-mono, monospace)}.epc-qr-pair{display:flex;gap:1.5rem;justify-content:center;align-items:flex-start}.epc-qr-item{display:flex;flex-direction:column;align-items:center;gap:.3rem}.epc-qr-sublabel{font-size:.7rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em}.epc-qr-note{font-size:.8rem;color:var(--color-text-secondary);font-style:italic;margin:0}.payment-sent-section{margin-top:1rem;display:flex;flex-direction:column;gap:.4rem}.payment-sent-label{font-size:.72rem;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.03em;margin-top:.3rem}.payment-sent-label:first-child{margin-top:0}.payment-sent-row{display:flex;align-items:center;gap:.5rem}.payment-sent-badge{display:inline-flex;align-items:center;gap:.35rem;padding:.35rem .8rem;font-size:.8rem;font-weight:500;border-radius:20px;background:var(--color-success-light);color:var(--color-success)}.btn-mark-paid{padding:.45rem 1rem;font-size:.85rem;font-weight:500;background:var(--color-surface);color:var(--color-primary);border:1px solid var(--color-primary);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast)}.btn-mark-paid:hover:not(:disabled){background:var(--color-primary);color:var(--color-primary-text)}.btn-mark-paid:disabled{opacity:.5;cursor:not-allowed}.payment-sent-inline{font-size:.7rem;color:var(--color-success);font-weight:500;margin-left:.3rem}.payment-sent-date{font-size:.78rem;color:var(--color-text-secondary)}@media(max-width:768px){.app-sidebar{display:none}.dashboard-summary-row{grid-template-columns:1fr}}@media(max-width:640px){.app-header{padding:0 1rem}.app-main{padding:1.25rem}.drop-zone{padding:2rem 1rem}thead th,tbody td{padding:.5rem .6rem;font-size:.8rem}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.form-toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.form-toolbar-title{display:flex;align-items:center;gap:.75rem}.form-toolbar-actions{display:flex;gap:.5rem}.attachment-badge{display:inline-flex;align-items:center;gap:.3rem;background:var(--color-primary-bg, #e8f0fe);color:var(--color-primary, #1a73e8);font-size:.75rem;font-weight:600;padding:.2rem .6rem;border-radius:999px}.form-alert{margin-bottom:1rem}.form-grid-2col{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-group-full{grid-column:1 / -1}.card-body-flush{padding:0}.lines-table-type{width:100px}.lines-table-item{width:220px}.lines-table-qty{width:90px}.lines-table-price{width:110px}.lines-table-disc{width:80px}.lines-table-uom{width:90px}.lines-table-vat{width:140px}.lines-table-amount{width:100px;text-align:right}.lines-table-action{width:40px}.line-amount-cell{text-align:right;font-family:var(--font-mono);font-size:.85rem}.line-total-label{text-align:right;font-weight:600}.line-total-value{text-align:right;font-family:var(--font-mono);font-weight:600;font-size:.95rem}.attachment-hint{font-size:.85rem;color:var(--color-text-muted)}.attachment-row{display:flex;align-items:center;gap:.75rem}.attachment-name{font-size:.9rem}.attachment-size-hint{margin-left:.5rem;font-size:.8rem;color:var(--color-text-muted)}.pdf-upload-tab{display:flex;flex-direction:column;gap:1rem;padding:1rem}.pdf-drop-zone{border:2px dashed var(--color-border-strong);border-radius:var(--radius);padding:2rem;text-align:center;cursor:pointer;transition:border-color .2s,background-color .2s;display:flex;flex-direction:column;align-items:center;gap:.5rem}.pdf-drop-zone:hover,.pdf-drop-zone.drag-over{border-color:var(--color-primary);background-color:var(--color-surface-hover)}.pdf-drop-icon{font-size:1.5rem;font-weight:700;color:var(--color-primary);background:var(--color-surface-hover);border-radius:var(--radius);padding:.5rem 1rem}.pdf-drop-text{font-size:.95rem;color:var(--color-text)}.pdf-drop-hint{font-size:.8rem;color:var(--color-text-muted)}.pdf-extracted-panel{border:1px solid var(--color-border);border-radius:var(--radius);padding:1rem;margin-top:.5rem}.pdf-extracted-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.pdf-extracted-header h3{font-size:.95rem;font-weight:600}.modal-backdrop{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:10001;animation:fadeIn .15s ease}.modal-content{background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:560px;max-height:85vh;overflow-y:auto;animation:slideUp .2s ease}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--color-border)}.modal-title{font-size:1.1rem;font-weight:600}.modal-close{background:none;border:none;font-size:1.4rem;color:var(--color-text-muted);cursor:pointer;padding:0 .2rem;line-height:1}.modal-close:hover{color:var(--color-text)}.modal-body{padding:1.5rem}.modal-footer{display:flex;justify-content:flex-end;gap:.5rem;padding:1rem 1.5rem;border-top:1px solid var(--color-border)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.search-select-create-new{padding:.5rem .75rem;font-size:.85rem;font-weight:500;color:var(--color-primary);cursor:pointer;border-top:1px solid var(--color-border);transition:background var(--transition-fast)}.search-select-create-new:hover{background:var(--color-primary-light)}.search-select-empty .search-select-create-new{border-top:none}
