*,:before,:after{box-sizing:border-box}:root{-webkit-font-smoothing:antialiased;--color-bg:#fff;--color-text:#333;--color-text-secondary:#555;--color-text-muted:#888;--color-primary:#4a90d9;--color-primary-hover:#3a7bc8;--color-primary-ring:#4a90d933;--color-surface:#f7f7f8;--color-surface-hover:#f0f0f0;--color-border:#ddd;--color-border-light:#eee;--color-input-border:#ccc;--color-card-bg:#fff;--color-row-hover:#f5f8fc;--color-row-selected:#e3f2fd;--color-filter-bg:#fafafa;--alert-error-bg:#fdecea;--alert-error-text:#b71c1c;--alert-error-border:#f5c6cb;--alert-success-bg:#e8f5e9;--alert-success-text:#2e7d32;--alert-success-border:#c8e6c9;--alert-info-bg:#e3f2fd;--alert-info-text:#1565c0;--alert-info-border:#bbdefb;--alert-warning-bg:#fff8e1;--alert-warning-text:#e65100;--alert-warning-border:#ffecb3;color:var(--color-text);background:var(--color-bg);font-family:system-ui,Segoe UI,Roboto,sans-serif;font-size:15px;line-height:1.5}[data-theme=dark]{--color-bg:#1a1a2e;--color-text:#e0e0e0;--color-text-secondary:#b0b0b0;--color-text-muted:#888;--color-primary:#5a9fe6;--color-primary-hover:#7ab3ed;--color-primary-ring:#5a9fe64d;--color-surface:#16213e;--color-surface-hover:#1f3056;--color-border:#2a2a4a;--color-border-light:#252545;--color-input-border:#3a3a5a;--color-card-bg:#1e1e38;--color-row-hover:#1f2b45;--color-row-selected:#1a3a5c;--color-filter-bg:#1e1e38;--alert-error-bg:#3b1c1c;--alert-error-text:#f5a0a0;--alert-error-border:#5a2020;--alert-success-bg:#1c3b1c;--alert-success-text:#a0d8a0;--alert-success-border:#2a5a2a;--alert-info-bg:#1c2a3b;--alert-info-text:#90c0f0;--alert-info-border:#2a3a5a;--alert-warning-bg:#3b2e1c;--alert-warning-text:#f0c060;--alert-warning-border:#5a4020}body{margin:0}#root{min-height:100vh}h1{margin:0 0 .5rem;font-size:1.6rem}h3{margin:0 0 .75rem;font-size:1rem}hr{border:none;border-top:1px solid var(--color-border);margin:1rem 0}a{color:var(--color-primary)}.dashboard-layout{min-height:100vh;display:flex}.sidebar{background:var(--color-surface);border-right:1px solid var(--color-border);flex-direction:column;width:220px;min-width:220px;padding:1rem;display:flex}.sidebar-content{flex:1}.sidebar-footer{text-align:center;margin-top:auto}.sidebar-logo{max-width:100%;margin-bottom:.5rem}.sidebar-brand{color:var(--color-text-muted);font-size:.8rem}.sidebar-group{margin-bottom:.75rem}.sidebar-group label{margin-bottom:.25rem;font-size:.85rem;font-weight:500;display:block}.sidebar-group select,.sidebar-group input[type=number]{width:100%}.sidebar hr{border:none;border-top:1px solid var(--color-border);margin:.75rem 0}.main-content{flex:1;padding:1rem 1.5rem;overflow-x:auto}.theme-toggle{justify-content:space-between;align-items:center;gap:.5rem;display:flex}.theme-toggle label{font-size:.85rem;font-weight:500}.toggle-switch{flex-shrink:0;width:40px;height:22px;position:relative}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{cursor:pointer;background:var(--color-input-border);border-radius:22px;transition:background .2s;position:absolute;inset:0}.toggle-slider:before{content:"";background:var(--color-card-bg);border-radius:50%;width:16px;height:16px;transition:transform .2s;position:absolute;bottom:3px;left:3px}.toggle-switch input:checked+.toggle-slider{background:var(--color-primary)}.toggle-switch input:checked+.toggle-slider:before{transform:translate(18px)}.login-container{max-width:440px;margin:3rem auto;padding:0 1rem}.login-language-selector{text-align:right;margin-bottom:1.5rem}.login-language-selector label{margin-right:.5rem;font-size:.85rem}.login-card{background:var(--color-card-bg);border:1px solid var(--color-border);border-radius:8px;padding:2rem}.login-card h1{margin:0 0 .25rem}.login-card h3{color:var(--color-text-secondary);margin:0 0 1.5rem;font-weight:400}.form-group{margin-bottom:1rem}.form-group label{margin-bottom:.25rem;font-size:.9rem;font-weight:500;display:block}input[type=text],input[type=email],input[type=password],input[type=number],select{border:1px solid var(--color-input-border);box-sizing:border-box;background:var(--color-card-bg);width:100%;color:var(--color-text);border-radius:4px;padding:.5rem .6rem;font-size:.9rem}input:focus,select:focus{border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary-ring);outline:none}.btn{border:1px solid var(--color-input-border);cursor:pointer;background:var(--color-card-bg);color:var(--color-text);border-radius:4px;justify-content:center;align-items:center;padding:.45rem 1rem;font-size:.85rem;transition:background .15s;display:inline-flex}.btn:hover:not(:disabled){background:var(--color-surface-hover)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.btn-primary:hover:not(:disabled){background:var(--color-primary-hover)}.btn-secondary{background:var(--color-surface)}.btn-danger{color:#fff;background:#dc3545;border-color:#dc3545}.btn-danger:hover:not(:disabled){background:#bb2d3b}.btn-small{padding:.2rem .5rem;font-size:.8rem}.btn-full{width:100%}.alert{border-radius:4px;margin-bottom:.75rem;padding:.6rem 1rem;font-size:.9rem}.alert-error{background:var(--alert-error-bg);color:var(--alert-error-text);border:1px solid var(--alert-error-border)}.alert-success{background:var(--alert-success-bg);color:var(--alert-success-text);border:1px solid var(--alert-success-border)}.alert-info{background:var(--alert-info-bg);color:var(--alert-info-text);border:1px solid var(--alert-info-border)}.alert-warning{background:var(--alert-warning-bg);color:var(--alert-warning-text);border:1px solid var(--alert-warning-border)}.filters-section{margin-bottom:.75rem}.filters-toolbar{flex-wrap:wrap;gap:.5rem;display:flex}.search-input-wrapper{position:relative}.search-input-wrapper input{width:100%;padding-right:1.75rem}.search-clear-btn{width:1.25rem;height:1.25rem;color:var(--color-text);cursor:pointer;opacity:.6;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:0;font-size:1.1rem;line-height:1;display:flex;position:absolute;top:50%;right:.4rem;transform:translateY(-50%)}.search-clear-btn:hover{opacity:1;background:var(--color-border-light)}.filters-grid{background:var(--color-filter-bg);border:1px solid var(--color-border-light);border-radius:4px;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.75rem;margin-top:.75rem;padding:1rem;display:grid}.filter-group label{margin-bottom:.3rem;font-size:.8rem;font-weight:600;display:block}.chip-group{flex-wrap:wrap;gap:.3rem;display:flex}.chip{border:1px solid var(--color-input-border);background:var(--color-card-bg);color:var(--color-text);cursor:pointer;border-radius:12px;padding:.2rem .6rem;font-size:.75rem}.chip-active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.table-wrapper{border:1px solid var(--color-border);border-radius:4px;max-height:1000px;margin:.75rem 0;overflow:auto}table{border-collapse:collapse;width:100%;font-size:.85rem}thead{background:var(--color-surface);z-index:1;position:sticky;top:0}th,td{text-align:left;border-bottom:1px solid var(--color-border-light);white-space:nowrap;padding:.45rem .6rem}th{border-bottom:2px solid var(--color-border);font-weight:600}tr:hover{background:var(--color-row-hover)}.row-selected{background:var(--color-row-selected)!important}.actions-bar{align-items:center;gap:1rem;margin:.75rem 0;display:flex}.pagination{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;display:flex}.pagination-buttons{flex-wrap:wrap;align-items:center;gap:.25rem;display:flex}.btn-page{border:1px solid var(--color-input-border);background:var(--color-card-bg);min-width:2rem;padding:.45rem .5rem}.btn-page-active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.btn-page-active:hover:not(:disabled){background:var(--color-primary-hover)}.report-id-link{color:var(--color-primary);cursor:pointer;text-decoration:none}.report-id-link:hover{text-decoration:underline}.report-table-container{margin-top:.5rem}.table-loading-overlay{background:var(--color-overlay,#fff9);z-index:2;border-radius:4px;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}[data-theme=dark] .table-loading-overlay{background:#00000073}.spinner{border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;width:36px;height:36px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.modal-backdrop{z-index:100;background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-content{background:var(--color-card-bg);border:1px solid var(--color-border);border-radius:8px;width:480px;max-width:90vw;max-height:85vh;padding:2rem;overflow-y:auto}.modal-content h2{margin:0 0 1.25rem}.modal-section-heading{color:var(--color-text-secondary);margin:1rem 0 .5rem;font-size:.95rem;font-weight:600}.form-row{gap:.75rem;display:flex}.toast{z-index:200;border-radius:6px;align-items:center;gap:.75rem;max-width:500px;padding:.75rem 1rem;font-size:.9rem;display:flex;position:fixed;top:1rem;left:50%;transform:translate(-50%);box-shadow:0 4px 12px #00000026}.toast-success{background:var(--alert-success-bg);color:var(--alert-success-text);border:1px solid var(--alert-success-border)}.toast-error{background:var(--alert-error-bg);color:var(--alert-error-text);border:1px solid var(--alert-error-border)}.report-detail-page{background:var(--color-surface);min-height:100vh}.report-detail-loading{justify-content:center;align-items:center;padding:3rem;display:flex}.report-detail-topbar{background:var(--color-card-bg);border-bottom:1px solid var(--color-border);flex-wrap:wrap;align-items:center;gap:2rem;padding:1rem 1.5rem;display:flex}.topbar-item{flex-direction:column;gap:.15rem;display:flex}.topbar-label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.03em;font-size:.75rem;font-weight:600}.topbar-value{font-size:1rem;font-weight:500}.topbar-back{padding:.25rem .7rem;font-size:1.4rem;line-height:1}.invoice-status{border-radius:8px;padding:.15rem .5rem;font-size:.8rem;font-weight:600}.invoice-status-7{background:var(--color-input-border);color:var(--color-text)}.invoice-status-8{color:#856404;background:#fff3cd}.invoice-status-9{color:#155724;background:#d4edda}.invoice-status-16{color:#856404;background:#d4edda}.invoice-status-19{color:#721c24;background:#f8d7da}.topbar-logo{height:36px;margin-left:auto}.qr-modal{text-align:center;max-width:360px}.qr-code-container{justify-content:center;margin:1.5rem 0;display:flex}.qr-code-url{color:var(--color-text-secondary);word-break:break-all;margin-bottom:1rem;font-size:.8rem}.topbar-actions{margin-left:auto}.report-detail-body{flex:1;display:flex}.report-detail-main{flex:1;min-width:0}.report-detail-actions{background:var(--color-card-bg);border-left:1px solid var(--color-border);flex-direction:column;gap:.75rem;width:220px;min-width:220px;padding:1.5rem 1rem;display:flex}.report-detail-actions h3{margin:0 0 .5rem;font-size:1rem}.report-detail-columns{grid-template-columns:1fr 1fr;gap:1.5rem;padding:1.5rem;display:grid}.report-detail-left,.report-detail-right{background:var(--color-card-bg);border:1px solid var(--color-border);border-radius:8px;padding:1.5rem}.report-detail-left h2,.report-detail-right h2,.report-detail-invoice h2{margin:0 0 1rem;font-size:1.1rem}.placeholder-box{text-align:center;color:var(--color-text-muted);background:var(--color-filter-bg);border:1px dashed var(--color-border-light);border-radius:6px;padding:2rem;font-size:.9rem}.detail-list{grid-template-columns:auto 1fr;gap:.4rem 1rem;margin:0;font-size:.9rem;display:grid}.detail-list dt{color:var(--color-text-secondary);white-space:nowrap;font-weight:600}.detail-list dd{margin:0}.detail-section-heading{color:var(--color-text-secondary);margin:1.25rem 0 .5rem;font-size:.95rem;font-weight:600}.photo-viewer-main{background:#000;border-radius:6px;justify-content:center;align-items:center;width:100%;min-height:300px;max-height:500px;display:flex;overflow:hidden}.photo-viewer-main img{object-fit:contain;max-width:100%;max-height:500px}.photo-viewer-controls{justify-content:center;align-items:center;gap:1rem;margin-top:.75rem;display:flex}.photo-viewer-count{color:var(--color-text-secondary);font-size:.85rem}.photo-upload-controls{margin-top:.75rem}.report-detail-invoice{background:var(--color-card-bg);border:1px solid var(--color-border);border-radius:8px;margin:0 1.5rem 1.5rem;padding:1.5rem}.invoice-document{border-top:2px solid var(--color-border);margin-top:1.25rem;padding-top:1.25rem;font-size:.9rem;line-height:1.6}.invoice-header{color:var(--color-text-secondary);margin-bottom:1rem;font-style:italic}.invoice-position{background:var(--color-filter-bg);border:1px solid var(--color-border-light);border-radius:6px;margin-bottom:1rem;padding:1rem}.invoice-totals{border-top:2px solid var(--color-border);justify-items:end;margin-top:1rem;padding-top:1rem}.invoice-positions-table{width:100%;margin:1rem 0}.invoice-positions-table th,.invoice-positions-table td{vertical-align:top;white-space:normal}.invoice-positions-table td:nth-child(2),.invoice-positions-table td:nth-child(3),.invoice-positions-table th:nth-child(2),.invoice-positions-table th:nth-child(3){white-space:nowrap;text-align:right;width:100px}.invoice-payments{border-top:2px solid var(--color-border);margin-top:1rem;padding-top:1rem}.invoice-payments h3{margin:0 0 .5rem;font-size:.95rem}.invoice-footer{color:var(--color-text-secondary);margin-top:1rem;font-style:italic}@media (width<=768px){.report-detail-body{flex-direction:column}.report-detail-actions{border-left:none;border-top:1px solid var(--color-border);flex-flow:wrap;width:auto;min-width:0}.report-detail-columns{grid-template-columns:1fr}.report-detail-topbar{gap:1rem}}.toast-close{cursor:pointer;color:inherit;background:0 0;border:none;flex-shrink:0;padding:0;font-size:1.25rem;line-height:1}
