:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:#ffffffde;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#242424;font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;font-weight:400;line-height:1.5}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}a{color:#646cff;-webkit-text-decoration:inherit;text-decoration:inherit;font-weight:500}a:hover{color:#535bf2}html,body,#root{height:100%}body{min-width:320px;min-height:100vh;margin:0;display:block}h1{font-size:3.2em;line-height:1.1}button{cursor:pointer;background-color:#1a1a1a;border:1px solid #0000;border-radius:8px;padding:.6em 1.2em;font-family:inherit;font-size:1em;font-weight:500;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.server-startup-overlay{z-index:9999;background:radial-gradient(1200px 600px at 80% -10%,#3b82f61f,#0000 60%),radial-gradient(900px 500px at -10% 110%,#6366f11a,#0000 60%),#0d0f14;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.server-startup-content{text-align:center;max-width:400px;padding:48px}.server-startup-icon{justify-content:center;align-items:center;margin-bottom:24px;font-size:48px;display:flex}.spinner{border:3px solid #3b82f633;border-top-color:#3b82f6;border-radius:50%;width:48px;height:48px;animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.server-startup-title{color:#e7eaf3;margin:0 0 12px;font-size:22px;font-weight:700}.server-startup-message{color:#a7b1c2;margin:0 0 24px;font-size:14px;line-height:1.5}.server-startup-progress{flex-direction:column;align-items:center;gap:8px;display:flex}.progress-bar{background:#3b82f633;border-radius:2px;width:200px;height:4px;overflow:hidden}.progress-fill{background:#3b82f6;border-radius:2px;height:100%;transition:width .3s}.progress-text{color:#6b7280;font-size:12px}.server-startup-retry-btn{color:#fff;cursor:pointer;background:linear-gradient(#3b82f6,#2563eb);border:none;border-radius:12px;margin-top:8px;padding:12px 24px;font-size:14px;font-weight:600;transition:filter .2s}.server-startup-retry-btn:hover{filter:brightness(1.05)}:root{--bg:#0d0f14;--bg-elev:#141822;--bg-elev-2:#1a1f2b;--text:#e7eaf3;--muted:#a7b1c2;--primary:#3b82f6;--primary-600:#2563eb;--secondary:#6b7280;--outline:#2b3140;--ring:#3b82f673;--shadow:0 20px 50px #00000073;--radius:14px}.start-root{background:radial-gradient(1200px 600px at 80% -10%, #3b82f61f, transparent 60%), radial-gradient(900px 500px at -10% 110%, #6366f11a, transparent 60%), var(--bg);width:100%;min-height:100dvh;color:var(--text);grid-template-rows:1fr auto;align-self:stretch;display:grid}.login-wrap{place-self:center;width:100%;max-width:500px;margin:0 auto;padding:48px 24px 24px}.login-header{text-align:center;margin-bottom:24px}.app-title{letter-spacing:.2px;margin:0 0 8px;font-size:28px;font-weight:800}.app-subtitle{color:var(--muted);margin:0;font-size:14px}.login-module{background:linear-gradient(180deg, var(--bg-elev), var(--bg-elev-2));border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid #ffffff0a;margin-top:24px;padding:24px}.nip-form{margin-bottom:16px}.nip-label{color:var(--muted);justify-content:center;align-items:center;gap:8px;margin:0 0 8px 2px;font-size:13px;display:flex}.nip-label .hint{color:#9aa7bd;cursor:help}.nip-input{border:1px solid var(--outline);width:100%;height:44px;color:var(--text);background:#0f131b;border-radius:12px;outline:none;padding:0 12px;font-size:14px;transition:border-color .2s,box-shadow .2s}.nip-input::placeholder{color:#8a93a8}.nip-input:focus{border-color:#41506b;box-shadow:0 0 0 4px #41506b59}.nip-help{color:#94a3b8;text-align:center;margin:6px 2px 0;font-size:12px}.primary-actions{grid-template-columns:1fr;gap:12px;display:grid}.btn{letter-spacing:.2px;cursor:pointer;border:1px solid #0000;border-radius:12px;justify-content:flex-start;align-items:center;gap:10px;width:100%;height:48px;padding:0 16px;font-size:15px;font-weight:700;transition:transform 60ms,background-color .2s,border-color .2s,box-shadow .2s;display:inline-flex}.btn:active{transform:translateY(1px)}.btn-primary{background:linear-gradient(180deg, var(--primary), var(--primary-600));color:#fff;box-shadow:0 8px 24px #3b82f659,inset 0 1px #ffffff1a}.btn-primary:hover{filter:brightness(1.03)}.btn-primary:focus{box-shadow:0 0 0 4px var(--ring);outline:none}.btn-secondary{color:#eef2ff;background:linear-gradient(#3a4253,#2f3646);border-color:#ffffff0f}.btn-secondary:hover{filter:brightness(1.03);border-color:#ffffff1f}.btn-secondary:focus{outline:none;box-shadow:0 0 0 4px #94a3b859}.btn-outline{color:var(--text);border-color:var(--outline);background:0 0}.btn-outline:hover{background:#ffffff05;border-color:#3b4354}.btn-outline:focus{outline:none;box-shadow:0 0 0 4px #94a3b840}.btn-icon{background:#ffffff1f;border-radius:8px;justify-content:center;align-items:center;width:28px;height:28px;display:inline-flex}.btn-primary .btn-icon{background:#ffffff2e}.btn-secondary .btn-icon{background:#00000026}.token-form{margin-top:20px}.token-label{color:var(--muted);justify-content:center;align-items:center;gap:8px;margin:0 0 8px 2px;font-size:13px;display:flex}.token-input-row{grid-template-columns:1fr auto;align-items:center;gap:10px;display:grid}.token-icon{border:1px solid var(--outline);color:#f5c76f;background:#0f131b;border-radius:12px;justify-content:center;align-items:center;width:44px;height:44px;display:inline-flex}.token-input{border:1px solid var(--outline);height:44px;color:var(--text);background:#0f131b;border-radius:12px;outline:none;padding:0 12px;font-size:14px;transition:border-color .2s,box-shadow .2s}.token-input::placeholder{color:#8a93a8}.token-input:focus{border-color:#41506b;box-shadow:0 0 0 4px #41506b59}.token-help{color:#94a3b8;text-align:center;margin:8px 2px 0;font-size:12px}.demo-link-wrap{text-align:center;margin:16px 0 0}.demo-link{color:#8ea7ff;font-size:14px}.demo-link:hover{color:#b7c5ff}.site-footer{color:var(--muted);border-top:1px solid #ffffff0f;padding:16px 24px 28px}.footer-inner{justify-content:center;align-items:center;gap:12px;max-width:960px;margin:0 auto;display:flex}.footer-link{color:var(--muted)}.footer-link:hover{color:var(--text)}.footer-inner .dot{color:#4b5566;margin:0 10px}.sr-only{clip:rect(0,0,0,0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.auth-root{background:var(--bg,#0e1116);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.auth-wrap{flex-direction:column;gap:24px;width:100%;max-width:440px;display:flex}.auth-header{text-align:center;flex-direction:column;align-items:center;gap:8px;display:flex}.auth-logo-dot{background:linear-gradient(135deg, var(--accent,#22d3ee), #06b6d4);border-radius:50%;width:48px;height:48px;margin-bottom:8px;box-shadow:0 0 24px #22d3ee4d}.auth-title{color:var(--text,#e6e9ef);margin:0;font-size:28px;font-weight:700}.auth-subtitle{color:var(--muted,#a4a9b6);margin:0;font-size:15px}.auth-card{background:var(--panel,#151a22);border:1px solid var(--border,#1f2733);border-radius:12px;padding:32px}.auth-error{color:#fca5a5;background:#ef44441a;border:1px solid #ef44444d;border-radius:8px;margin-bottom:16px;padding:12px;font-size:14px}.auth-form{flex-direction:column;gap:6px;display:flex}.auth-label{color:var(--muted,#a4a9b6);margin-top:8px;font-size:13px;font-weight:600}.auth-input{border:1px solid var(--border,#1f2733);width:100%;color:var(--text,#e6e9ef);box-sizing:border-box;background:#0f141b;border-radius:8px;outline:none;padding:12px 14px;font-size:14px;transition:border-color .2s}.auth-input:focus{border-color:var(--accent,#22d3ee)}.auth-input:disabled{opacity:.5;cursor:not-allowed}.auth-input::placeholder{color:#4a5568}.auth-btn-primary{background:var(--accent,#22d3ee);color:#001018;cursor:pointer;border:none;border-radius:8px;width:100%;margin-top:16px;padding:14px;font-size:15px;font-weight:700;transition:all .2s}.auth-btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 16px #22d3ee4d}.auth-btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none}.auth-divider{align-items:center;gap:12px;margin:24px 0 16px;display:flex}.auth-divider:before,.auth-divider:after{content:"";background:var(--border,#1f2733);flex:1;height:1px}.auth-divider span{color:var(--muted,#a4a9b6);text-transform:uppercase;letter-spacing:1px;font-size:12px}.auth-alt{text-align:center}.auth-alt p{color:var(--muted,#a4a9b6);margin:0 0 8px;font-size:14px}.auth-link{color:var(--accent,#22d3ee);font-size:14px;font-weight:600;text-decoration:none;transition:opacity .2s}.auth-link:hover{opacity:.8}.auth-footer{text-align:center;color:#4a5568;font-size:12px}@media (width<=480px){.auth-card{padding:24px 20px}.auth-title{font-size:24px}}.auth-logo-img{object-fit:contain;filter:drop-shadow(0 0 16px #22d3ee40);width:64px;height:64px;margin-bottom:8px}:root{--bg:#0e1116;--panel:#151a22;--muted:#a4a9b6;--text:#e6e9ef;--accent:#22d3ee;--success:#22c55e;--danger:#ef4444;--warning:#f59e0b;--border:#1f2733;--sidenav-w:260px;--sidenav-collapsed-w:72px}.dash-root{background:var(--bg);color:var(--text);grid-template-rows:100vh;grid-template-columns:auto 1fr;display:grid}.dash-main{flex-direction:column;display:flex;overflow:hidden}.dash-content{flex:1;padding:24px;overflow:auto}.dash-header h1{margin:0;font-size:22px}.subtitle{color:var(--muted);margin-top:6px}.alert-box{background:#fbbf241a;border:1px solid #fbbf244d;border-radius:12px;align-items:center;gap:14px;margin:18px 0;padding:16px 20px;display:flex}.alert-box.warning{background:#fbbf2414;border-color:#fbbf2440}.alert-icon{flex-shrink:0;font-size:28px}.alert-content{flex:1}.alert-content strong{color:#fcd34d;margin-bottom:4px;font-size:15px;display:block}.alert-content p{color:#fde68a;margin:0;font-size:14px;line-height:1.5}.link-button{color:#60a5fa;cursor:pointer;font:inherit;background:0 0;border:none;padding:0;text-decoration:underline}.link-button:hover{color:#93c5fd}.kpi-grid{grid-template-columns:1fr 1fr 2fr;gap:16px;margin-top:18px;display:grid}.kpi-card{background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:18px}.kpi-card.wide{grid-column:span 1}.kpi-title{color:var(--muted);letter-spacing:.3px;margin-bottom:10px;font-size:12px;font-weight:500}.kpi-value{font-size:32px;font-weight:800;line-height:1.1}.kpi-value.accent{color:var(--accent)}.kpi-pills{flex-wrap:wrap;gap:8px;display:flex}.pill{border:1px solid var(--border);color:var(--muted);background:#0f141b;border-radius:999px;padding:6px 10px;font-size:12px}.pill.success{color:#a7f3d0;background:#22c55e14;border-color:#22c55e4d}.pill.danger{color:#fecaca;background:#ef444414;border-color:#ef44444d}.mini-chart{align-items:end;gap:6px;height:100px;margin-top:12px;display:flex}.bar-pair{flex:1;align-items:end;gap:3px;height:100%;display:flex}.bar{opacity:.9;border-radius:3px 3px 0 0;width:100%;max-width:10px}.bar.issued{background:linear-gradient(#22d3ee 0%,#22d3ee4d 100%)}.bar.received{background:linear-gradient(#93c5fd 0%,#93c5fd4d 100%)}.chart-legend{color:var(--muted);gap:16px;margin-top:12px;font-size:12px;display:flex}.legend-item{align-items:center;display:flex}.dot{border-radius:50%;width:8px;height:8px;margin-right:6px;display:inline-block}.dot.issued{background:var(--accent)}.dot.received{background:#93c5fd}.ops-section{margin-top:28px}.section-header-centered{text-align:center;flex-direction:column;align-items:center;gap:16px;margin-bottom:20px;display:flex}.section-header-centered h2{margin:0;font-size:18px;font-weight:600}.btn-fetch{background:var(--accent);color:#001018;cursor:pointer;border:none;border-radius:12px;align-items:center;gap:10px;padding:14px 28px;font-size:15px;font-weight:700;transition:all .2s;display:flex;box-shadow:0 2px 8px #22d3ee33}.btn-fetch:hover:not(:disabled){filter:brightness(1.1);transform:translateY(-1px);box-shadow:0 4px 12px #22d3ee4d}.btn-fetch:disabled{opacity:.5;cursor:not-allowed}.btn-fetch .btn-icon{font-size:18px;line-height:1}.ops-header{justify-content:space-between;align-items:center;gap:16px;margin-bottom:16px;display:flex}.ops-header h2{margin:0;font-size:16px}.ops-actions{align-items:center;gap:10px;display:flex}.search{border:1px solid var(--border);color:var(--text);background:#0f141b;border-radius:8px;min-width:260px;padding:10px 12px}.filters{flex-wrap:wrap;gap:12px;margin:12px 0;display:flex}.filters label{color:var(--muted);flex-direction:column;gap:6px;font-size:12px;display:flex}.filters input,.filters select{border:1px solid var(--border);color:var(--text);background:#0f141b;border-radius:8px;padding:8px 10px}.table-wrap{background:var(--panel);border:1px solid var(--border);border-radius:12px;position:relative;overflow:auto}.loading-overlay{color:var(--accent);font-size:16px;font-weight:600;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.error-message{text-align:center;color:var(--danger);padding:20px}.data-table{border-collapse:separate;border-spacing:0;width:100%}.data-table thead th{color:var(--muted);text-align:left;border-bottom:1px solid var(--border);background:#121722;padding:12px;font-size:12px;font-weight:600;position:sticky;top:0}.data-table tbody td{border-bottom:1px solid var(--border);padding:12px;font-size:14px}.data-table tbody tr:hover{background:#ffffff08}.status-dot{border-radius:50%;width:10px;height:10px;margin-right:8px;display:inline-block}.status-dot.accepted{background:var(--success)}.status-dot.pending{background:var(--warning)}.status-dot.rejected{background:var(--danger)}.status-text{vertical-align:middle}.future-section{margin-top:28px}.future-section h2{margin-bottom:16px;font-size:18px;font-weight:600}.future-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;display:grid}.future-card{background:var(--panel);border:1px solid var(--border);border-radius:12px;flex-direction:column;align-items:flex-start;gap:10px;padding:18px;transition:all .2s;display:flex}.future-card:hover{border-color:#22d3ee4d;transform:translateY(-2px)}.future-icon{font-size:26px}.future-title{font-size:15px;font-weight:600}.future-badge{color:var(--muted);border:1px dashed var(--border);background:#ffffff05;border-radius:999px;padding:4px 10px;font-size:11px}.btn-accent{background:var(--accent);color:#001018;cursor:pointer;border:none;border-radius:10px;padding:10px 16px;font-weight:700;transition:all .2s}.btn-accent:hover{filter:brightness(1.1);transform:translateY(-1px)}.btn-light{border:1px solid var(--border);color:var(--text);cursor:pointer;background:#0f141b;border-radius:10px;padding:10px 12px}.btn-light.small{padding:6px 10px;font-size:12px}@media (width<=1200px){.kpi-grid{grid-template-columns:1fr 1fr}.kpi-card.wide{grid-column:span 2}}@media (width<=900px){.kpi-grid{grid-template-columns:1fr}.kpi-card.wide{grid-column:span 1}.future-grid{grid-template-columns:1fr}.section-header-centered{gap:12px}.btn-fetch{padding:12px 20px;font-size:14px}}:root{--sidenav-w:260px;--sidenav-collapsed-w:72px}.side-nav{width:var(--sidenav-w);z-index:100;background-color:#171721;border-right:1px solid #2d2d3d;flex-direction:column;flex-shrink:0;height:100dvh;transition:width .3s;display:flex;position:sticky;top:0}.side-nav.collapsed{width:var(--sidenav-collapsed-w)}.collapse-btn{color:#a0a0b0;cursor:pointer;z-index:101;background:#171721;border:1px solid #2d2d3d;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-size:12px;font-weight:700;transition:all .2s;display:flex;position:absolute;top:12px;right:-12px}.collapse-btn:hover{color:#fff;background:#252535;border-color:#3d3d4d}.collapse-icon{line-height:1}.side-nav-content{flex:1;padding:24px;transition:padding .3s;overflow-y:auto}.side-nav.collapsed .side-nav-content{padding:24px 12px}.side-nav .brand{align-items:center;gap:12px;min-height:24px;margin-bottom:24px;display:flex}.side-nav.collapsed .brand{justify-content:center}.side-nav .logo-dot{background-color:#00e096;border-radius:50%;flex-shrink:0;width:12px;height:12px}.side-nav .brand-name{color:#fff;white-space:nowrap;align-items:center;gap:8px;font-size:1.1rem;font-weight:600;display:flex}.brand-icon{width:28px;height:28px}.side-nav-user-info{background:#ffffff08;border:1px solid #ffffff12;border-radius:8px;flex-direction:column;gap:6px;margin-bottom:12px;padding:10px 14px;display:flex}.user-name-badge{color:#e6e9ef;white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.company-name-badge{color:#a4a9b6;white-space:nowrap;text-overflow:ellipsis;font-size:12px;overflow:hidden}.ksef-status-badge{border-radius:6px;align-self:flex-start;padding:3px 8px;font-size:11px;font-weight:600;display:inline-block}.ksef-status-badge.connected{color:#22c55e;background:#22c55e26}.ksef-status-badge.disconnected{color:#ef4444;background:#ef444426}.ksef-status-badge.expired{color:#f59e0b;background:#f59e0b26}.ksef-auth-method-badge{color:#67e8f9;text-align:center;background:#22d3ee1a;border:1px solid #22d3ee4d;border-radius:6px;padding:5px 10px;font-family:JetBrains Mono,Fira Code,Consolas,monospace;font-size:12px;font-weight:600}.ksef-setup-link{color:#22d3ee;text-align:center;background:#22d3ee1a;border:1px solid #22d3ee4d;border-radius:6px;margin-top:2px;padding:5px 10px;font-size:12px;font-weight:600;text-decoration:none;transition:all .2s;animation:2s ease-in-out infinite pulse-glow;display:block}.ksef-setup-link:hover{background:#22d3ee2e}.side-nav .new-invoice{text-align:center;box-sizing:border-box;white-space:nowrap;border-radius:8px;width:100%;margin-bottom:4px;padding:11px 12px;font-size:14px;font-weight:600;text-decoration:none;display:block;overflow:hidden}.side-nav.collapsed .new-invoice{padding:11px 8px;font-size:18px}.side-nav .nav-list{flex-direction:column;gap:2px;margin-top:8px;display:flex}.side-nav .nav-item{color:#a0a0b0;box-sizing:border-box;border-radius:6px;align-items:center;gap:12px;width:100%;padding:10px 14px;font-size:14px;text-decoration:none;transition:background-color .2s,color .2s;display:flex;overflow:hidden}.side-nav.collapsed .nav-item{justify-content:center;gap:0;padding:10px}.side-nav .nav-label{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.side-nav .nav-item:hover{color:#fff;background-color:#252535}.side-nav .nav-item.active{color:#fff;background-color:#2a2a3c;font-weight:500}.side-nav .nav-item .icon{flex-shrink:0;font-size:1.15rem}.logout-btn{cursor:pointer;font:inherit;color:inherit;background:0 0;border:none}.logout-btn:hover{color:#fff;background-color:#252535}.side-nav-footer{background:#0003;border-top:1px solid #ffffff14;flex-shrink:0;justify-content:center;align-items:center;padding:12px 16px;display:flex}.footer-copyright{color:#ffffff73;letter-spacing:.2px;white-space:nowrap;align-items:center;gap:6px;font-size:11px;font-weight:400;display:flex}.footer-icon{width:18px;height:18px}.side-nav-content::-webkit-scrollbar{width:4px}.side-nav-content::-webkit-scrollbar-track{background:0 0}.side-nav-content::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:2px}.side-nav-content::-webkit-scrollbar-thumb:hover{background:#fff3}@keyframes pulse-glow{0%,to{box-shadow:0 0 #22d3ee33}50%{box-shadow:0 0 12px 4px #22d3ee26}}@media (width<=768px){.side-nav-content{padding:16px}.side-nav-footer{padding:10px 16px}.footer-copyright{font-size:10px}}.top-bar{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#171721cc;border-bottom:1px solid #2d2d3d;flex-shrink:0;justify-content:space-between;align-items:center;padding:12px 24px;display:flex}.top-bar-spacer{flex:1}.top-bar-status{align-items:center;gap:10px;display:flex}.status-indicator{border-radius:50%;flex-shrink:0;width:8px;height:8px}.status-indicator.online{background:#22c55e;box-shadow:0 0 8px #22c55e80}.status-indicator.offline{background:#6b7280}.status-text{color:#a7b1c2;font-size:13px}.status-text strong{color:#e7eaf3;font-weight:600}.top-bar-btn{cursor:pointer;border:none;border-radius:6px;padding:6px 14px;font-size:12px;font-weight:500;transition:all .2s}.top-bar-btn.logout{color:#fca5a5;background:#ef44441a;border:1px solid #ef444433}.top-bar-btn.logout:hover{background:#ef444433;border-color:#ef444466}.top-bar-btn.login{color:#93c5fd;background:#3b82f61a;border:1px solid #3b82f633}.top-bar-btn.login:hover{background:#3b82f633;border-color:#3b82f666}.alert-summary{background:#ef444414;border:1px solid #ef444440;border-radius:12px;align-items:center;gap:12px;margin-bottom:20px;padding:14px 20px;animation:.3s fadeIn;display:flex}.alert-summary-icon{flex-shrink:0;font-size:22px}.alert-summary-text{color:#fca5a5;font-size:14px;line-height:1.4}.alert-count{font-weight:600}.alert-count.high{color:#ef4444}.alert-count.medium{color:#f59e0b}.selection-count{color:var(--accent);white-space:nowrap;background:#22d3ee1a;border:1px solid #22d3ee33;border-radius:8px;padding:6px 14px;font-size:13px;font-weight:600}.table-controls{justify-content:space-between;align-items:center;gap:16px;padding:12px 0;display:flex}.page-size-label{color:var(--muted);align-items:center;gap:8px;font-size:13px;display:flex}.page-size-select{border:1px solid var(--border);color:var(--text);cursor:pointer;background:#0f141b;border-radius:8px;padding:6px 10px;font-size:13px;transition:border-color .2s}.page-size-select:focus{border-color:var(--accent);outline:none}.page-size-select:hover{border-color:#2e3a4a}.results-count{color:var(--muted);font-variant-numeric:tabular-nums;font-size:13px}.checkbox-col{text-align:center;width:44px}.checkbox-col input[type=checkbox]{cursor:pointer;width:16px;height:16px;accent-color:var(--accent)}.alert-col{text-align:center;width:80px}.ksef-number{color:var(--accent);word-break:break-all;letter-spacing:.2px;background:#22d3ee12;border-radius:4px;max-width:220px;padding:3px 7px;font-family:JetBrains Mono,Fira Code,Consolas,monospace;font-size:11px;line-height:1.4;display:inline-block}.contractor-name{text-overflow:ellipsis;white-space:nowrap;max-width:200px;overflow:hidden}.amount-cell{white-space:nowrap;text-align:right;font-variant-numeric:tabular-nums;letter-spacing:.3px;font-weight:600}.row-selected{background:#22d3ee0d!important}.row-selected td:first-child{box-shadow:inset 3px 0 0 var(--accent)}.row-alert-high{background:#ef44440d!important}.row-alert-high td:first-child{box-shadow:inset 3px 0 0 var(--danger)}.row-alert-medium{background:#f59e0b0d!important}.row-alert-medium td:first-child{box-shadow:inset 3px 0 0 var(--warning)}.pagination{flex-wrap:wrap;justify-content:center;align-items:center;gap:4px;padding:20px 0 8px;display:flex}.pagination-nav{border:1px solid var(--border);color:var(--muted);cursor:pointer;-webkit-user-select:none;user-select:none;background:#0f141b;border-radius:8px;padding:7px 14px;font-size:13px;font-weight:500;transition:all .2s}.pagination-nav:hover:not(:disabled){border-color:var(--accent);color:var(--text);background:#22d3ee0d}.pagination-nav:disabled{opacity:.3;cursor:not-allowed}.pagination-page{min-width:36px;height:36px;color:var(--muted);cursor:pointer;-webkit-user-select:none;user-select:none;background:0 0;border:1px solid #0000;border-radius:8px;justify-content:center;align-items:center;font-size:13px;font-weight:500;transition:all .2s;display:flex}.pagination-page:hover{color:var(--text);background:#22d3ee14}.pagination-page.active{background:var(--accent);color:#001018;cursor:default;font-weight:700}.pagination-dots{color:var(--muted);-webkit-user-select:none;user-select:none;pointer-events:none;padding:0 2px;font-size:14px}.pagination-info{color:var(--muted);white-space:nowrap;font-variant-numeric:tabular-nums;margin-left:16px;font-size:13px}.loading-spinner{flex-direction:column;justify-content:center;align-items:center;gap:16px;padding:60px 20px;display:flex}.loading-spinner:before{content:"";border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:28px;height:28px;animation:.7s linear infinite spin}.loading-spinner-text{color:var(--accent);font-size:14px;font-weight:600}@keyframes fadeIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.empty-state{color:var(--muted);flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:48px 20px;display:flex}.empty-state-icon{opacity:.5;font-size:36px}.empty-state-text{font-size:14px}@media (width<=900px){.table-controls{flex-direction:column;align-items:flex-start;gap:8px}.ksef-number{max-width:130px;font-size:10px}.contractor-name{max-width:120px}.pagination{gap:2px}.pagination-nav{padding:6px 10px;font-size:12px}.pagination-page{min-width:32px;height:32px;font-size:12px}.pagination-info{text-align:center;width:100%;margin-top:8px;margin-left:0}}@media (width<=600px){.alert-summary{text-align:center;flex-direction:column;gap:8px}.pagination-nav span{display:none}}.invoice-filters{margin-bottom:16px}.filters-header{justify-content:space-between;align-items:center;gap:12px;display:flex}.filters-left{align-items:center;gap:8px;display:flex}.filters-toggle{color:var(--muted);cursor:pointer;background:0 0;border:none;border-radius:8px;align-items:center;gap:8px;padding:8px 12px;font-size:13px;font-weight:500;transition:all .2s;display:flex}.filters-toggle:hover{color:var(--text);background:#ffffff0a}.filters-toggle-icon{text-align:center;width:12px;font-size:10px}.filters-badge{color:var(--accent);background:#22d3ee1f;border-radius:999px;padding:2px 8px;font-size:11px;font-weight:600}.suspicious-pill{color:var(--muted);cursor:pointer;white-space:nowrap;background:0 0;border:1px solid #f59e0b4d;border-radius:999px;padding:5px 12px;font-size:12px;transition:all .2s}.suspicious-pill:hover{color:var(--warning);background:#f59e0b0f;border-color:#f59e0b80}.suspicious-pill.active{border-color:var(--warning);color:#fcd34d;background:#f59e0b1f}.filters-reset{color:#fca5a5;cursor:pointer;white-space:nowrap;background:0 0;border:1px solid #ef444440;border-radius:8px;padding:5px 12px;font-size:12px;transition:all .2s}.filters-reset:hover{color:#ef4444;background:#ef44441a;border-color:#ef444466}.filters-content{opacity:0;max-height:0;transition:max-height .3s,padding .3s,opacity .2s;overflow:hidden}.filters-content.expanded{opacity:1;max-height:400px;padding-top:16px}.filters-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px;display:grid}.filter-group{flex-direction:column;gap:5px;display:flex}.filter-label{color:var(--muted);letter-spacing:.2px;font-size:12px;font-weight:500}.filter-input{border:1px solid var(--border);color:var(--text);background:#0f141b;border-radius:8px;width:100%;padding:9px 12px;font-size:13px;transition:border-color .2s,box-shadow .2s}.filter-input:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 2px #22d3ee1a}.filter-input:hover{border-color:#2e3a4a}.filter-input::placeholder{color:#4a5568}@media (width<=700px){.filters-grid{grid-template-columns:1fr 1fr}}@media (width<=480px){.filters-grid{grid-template-columns:1fr}.filters-header{flex-direction:column;align-items:flex-start;gap:8px}.filters-left{flex-wrap:wrap}}.fraud-badge-container{display:inline-flex;position:relative}.fraud-badge{cursor:help;border-radius:6px;justify-content:center;align-items:center;width:28px;height:28px;font-size:14px;transition:transform .15s;display:inline-flex}.fraud-badge:hover{transform:scale(1.1)}.fraud-badge-ok{color:#22c55e;background:#22c55e1a}.fraud-badge-low{background:#3b82f626}.fraud-badge-medium{background:#f59e0b26}.fraud-badge-high{background:#ef444426;animation:2s infinite pulse-alert}@keyframes pulse-alert{0%,to{box-shadow:0 0 #ef444466}50%{box-shadow:0 0 0 6px #ef444400}}.fraud-tooltip{z-index:1000;background:#1a1f2b;border:1px solid #2b3140;border-radius:12px;width:320px;margin-top:8px;padding:16px;position:absolute;top:100%;left:0;box-shadow:0 10px 40px #00000080}.fraud-tooltip:before{content:"";background:#1a1f2b;border-top:1px solid #2b3140;border-left:1px solid #2b3140;width:12px;height:12px;position:absolute;top:-6px;left:12px;transform:rotate(45deg)}.fraud-tooltip-header{border-bottom:1px solid #2b3140;align-items:center;gap:8px;margin-bottom:12px;padding-bottom:12px;display:flex}.fraud-tooltip-icon{font-size:20px}.fraud-tooltip-title{color:#e7eaf3;font-size:14px;font-weight:600}.fraud-tooltip-list{flex-direction:column;gap:8px;margin:0;padding:0;list-style:none;display:flex}.fraud-alert-item{border-radius:8px;justify-content:space-between;align-items:flex-start;gap:8px;padding:10px;font-size:13px;line-height:1.4;display:flex}.fraud-alert-low{color:#93c5fd;background:#3b82f61a}.fraud-alert-medium{color:#fcd34d;background:#f59e0b1a}.fraud-alert-high{color:#fca5a5;background:#ef44441a}.fraud-alert-message{flex:1}.fraud-alert-dismiss{color:#a7b1c2;cursor:pointer;background:#ffffff1a;border:none;border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;font-size:10px;transition:all .15s;display:flex}.fraud-alert-dismiss:hover{color:#e7eaf3;background:#fff3}.fraud-tooltip-action{color:#86efac;cursor:pointer;background:#22c55e1a;border:1px solid #22c55e4d;border-radius:8px;width:100%;margin-top:12px;padding:10px;font-size:13px;font-weight:500;transition:all .15s}.fraud-tooltip-action:hover{background:#22c55e33}.alert-indicator{border-radius:12px;align-items:center;gap:4px;padding:4px 10px;font-size:12px;font-weight:500;display:inline-flex}.alert-indicator-high{color:#fca5a5;background:#ef444426}.alert-indicator-medium{color:#fcd34d;background:#f59e0b26}.alert-indicator-low{color:#93c5fd;background:#3b82f626}.two-col .card{margin-bottom:0}.field-row{grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:12px;display:grid}label{color:var(--muted,#a4a9b6);flex-direction:column;gap:6px;font-size:13px;font-weight:500;display:flex}label input,label select,label textarea{color:var(--text,#e6e9ef);border:1px solid var(--border,#1f2733);background:#0f141b;border-radius:8px;padding:10px 12px;font-size:14px}label input:focus,label select:focus,label textarea:focus{border-color:var(--accent,#22d3ee);background:#121722;outline:none}label input[readonly]{color:var(--muted,#a4a9b6);cursor:default;background:#0a0d11}.input-group{align-items:center;display:flex}.input-group .input{color:var(--text,#e6e9ef);border:1px solid var(--border,#1f2733);background:#0f141b;border-right:none;border-radius:8px 0 0 8px;flex:1;padding:10px 12px;font-size:14px}.input-group .input:focus{border-color:var(--accent,#22d3ee);background:#121722;outline:none}.input-group .suffix{color:var(--muted,#a4a9b6);border:1px solid var(--border,#1f2733);white-space:nowrap;background:#0a0d11;border-radius:0 8px 8px 0;padding:10px 12px;font-size:13px;font-weight:500}.seller-nip-box{background:#00e09614;border:1px solid #00e09640;border-radius:10px;flex-direction:column;gap:6px;margin-bottom:16px;padding:14px 18px;display:flex}.seller-nip-label{color:var(--muted,#a4a9b6);font-size:12px;font-weight:500}.seller-nip-value{color:#00e096;letter-spacing:1px;font-family:Monaco,Consolas,monospace;font-size:18px;font-weight:700}.table-wrap{overflow-x:auto}.invoice-lines-table{border-collapse:collapse;table-layout:fixed;width:100%}.invoice-lines-table th{text-align:left;color:var(--muted,#a4a9b6);border-bottom:1px solid var(--border,#1f2733);white-space:nowrap;vertical-align:middle;background:#0f141b;padding:12px 8px;font-size:12px;font-weight:600}.invoice-lines-table th.text-right{text-align:right;padding-right:16px}.invoice-lines-table td{vertical-align:top;border-bottom:1px solid #ffffff0d;padding:8px}.invoice-lines-table td input,.invoice-lines-table td select{border:1px solid var(--border,#1f2733);width:100%;color:var(--text,#e6e9ef);box-sizing:border-box;background:#0a0d11;border-radius:6px;padding:8px 10px;font-size:13px}.invoice-lines-table td input:focus,.invoice-lines-table td select:focus{border-color:var(--accent,#22d3ee);background:#0f141b;outline:none}.invoice-lines-table td.text-right{text-align:right;white-space:nowrap;color:var(--text,#e6e9ef);vertical-align:middle;padding:16px 16px 8px 8px;font-family:Monaco,Consolas,monospace;font-size:14px;font-weight:600}.invoice-lines-table tfoot td{border-bottom:none;padding-top:16px}.invoice-lines-table tbody tr:hover{background:#ffffff05}.invoice-lines-table .btn-light.small.danger{color:var(--danger,#ef4444);cursor:pointer;background:#ef44441a;border:1px solid #ef44444d;border-radius:6px;padding:6px 10px;font-size:14px;transition:all .2s}.invoice-lines-table .btn-light.small.danger:hover{border-color:var(--danger,#ef4444);background:#ef444433}.summary-bar{border:1px solid var(--border,#1f2733);background:#0f141b;border-radius:10px;justify-content:flex-end;gap:32px;margin-top:16px;padding:16px 20px;display:flex}.summary-bar span{color:var(--muted,#a4a9b6);font-size:14px}.summary-bar strong{color:var(--text,#e6e9ef);margin-left:8px;font-family:Monaco,Consolas,monospace;font-size:16px;font-weight:700}.bank-account-section{margin-top:16px}.warning-banner{color:#fcd34d;background:#fbbf241a;border:1px solid #fbbf244d;border-radius:8px;margin-bottom:16px;padding:12px 16px;font-size:14px}.info-banner.success{color:#86efac;background:#22c55e1a;border-color:#22c55e4d}.error-message strong{margin-bottom:8px;font-size:15px;display:block}.error-message ul{margin:8px 0 0 20px;padding:0}.error-message li{margin-bottom:4px}.print-only{display:none!important}@media (width<=1200px){.field-row{grid-template-columns:repeat(2,1fr)}}@media (width<=1024px){.two-col{grid-template-columns:1fr}.invoice-lines-table{font-size:12px}.invoice-lines-table th,.invoice-lines-table td{padding:8px 4px}.summary-bar{flex-wrap:wrap;gap:16px}}@media (width<=768px){.field-row{grid-template-columns:1fr}.summary-bar{flex-direction:column;align-items:flex-end;gap:8px}.card{padding:16px}.ops-header{flex-direction:column;align-items:stretch;gap:12px}.ops-actions{flex-wrap:wrap}}@media print{@page{margin:12mm;size:A4}*{box-sizing:border-box}.side-nav,.top-bar,.ops-section,.dash-header,.no-print,.dash-content{display:none!important}.print-only{display:block!important}.dash-root,.dash-main{background:#fff!important;width:100%!important;margin:0!important;padding:0!important;display:block!important}html,body{-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important;background:#fff!important;margin:0!important;padding:0!important}.print-invoice{color:#000;background:#fff;width:170mm;margin:0 auto;padding:0;font-family:Arial,Helvetica,sans-serif;font-size:9pt;line-height:1.4}.print-content{padding:0}.print-header{border-bottom:2px solid #000;justify-content:space-between;align-items:flex-start;margin-bottom:8px;padding-bottom:8px;display:flex}.print-header-left h2{margin:0 0 2px;font-size:10pt}.print-header-left .ksef-label{color:#c00;font-size:14pt;font-weight:700}.print-header-right{text-align:right}.print-header-right .invoice-number-label{color:#666;font-size:7pt}.print-header-right .invoice-number{font-size:12pt;font-weight:700}.print-header-right .invoice-type{font-size:8pt}.print-hr{border:none;border-top:1px solid #999;margin:8px 0}.print-parties{gap:20px;margin:8px 0;display:flex}.print-party{flex:1}.print-party h3{border-bottom:1px solid #ccc;margin:0 0 4px;padding-bottom:2px;font-size:10pt}.print-party p{margin:2px 0;font-size:8pt}.print-party .label{color:#666;margin-top:4px;font-size:7pt}.print-details{margin:8px 0}.print-details h3{margin:0 0 4px;font-size:10pt}.print-details-row{margin-bottom:2px;font-size:8pt}.print-details-row .label{color:#666}.print-items{margin:10px 0 20px}.print-items h3{margin:0 0 2px;font-size:10pt}.print-items .subtitle{color:#666;margin-bottom:6px;font-size:7pt}.print-table{border-collapse:collapse;width:100%;font-size:8pt}.print-table th,.print-table td{text-align:left;border:2px solid #444;padding:6px}.print-table th{background-color:#eee;font-size:7pt;font-weight:700}.print-table .text-right{text-align:right}.print-total{text-align:right;margin:15px 0;font-size:12pt;font-weight:700}.print-vat-summary{margin:15px 0}.print-vat-summary h3{margin:0 0 8px;font-size:10pt}.print-vat-table{border-collapse:collapse;font-size:8pt}.print-vat-table th,.print-vat-table td{border:2px solid #444;padding:6px}.print-vat-table th{background-color:#eee;font-size:7pt;font-weight:700}.print-vat-table .text-right{text-align:right}.print-payment{margin:10px 0}.print-payment h3{margin:0 0 4px;font-size:10pt}.print-payment-row{font-size:8pt}.print-payment .label{color:#666}.print-payment p{margin:4px 0;font-size:8pt}.print-footer{text-align:center;background:#fff;border-top:1px solid #ccc;padding:6px 12mm;position:fixed;bottom:0;left:0;right:0}.print-footer p{color:#666;margin:2px 0;font-size:7pt}.print-footer .note{color:#999;font-size:6pt;font-style:italic}.print-footer a{color:#06c;text-decoration:none}}.btn-close-session{color:#fca5a5;cursor:pointer;white-space:nowrap;background:0 0;border:1px solid #ef444466;border-radius:8px;padding:8px 16px;font-size:14px;font-weight:600;transition:all .2s}.btn-close-session:hover:not(:disabled){background:#ef44441a;border-color:#ef4444b3}.btn-close-session:disabled{opacity:.5;cursor:not-allowed}.bank-input-wrapper{flex-direction:column;gap:6px;display:flex}.bank-input-label{color:var(--muted,#a4a9b6);font-size:13px;font-weight:500}.bank-input-container{align-items:center;display:flex;position:relative}.bank-input{border:1px solid var(--border,#1f2733);width:100%;color:var(--text,#e6e9ef);letter-spacing:1px;background:#0f141b;border-radius:8px;padding:10px 55px 10px 12px;font-family:Monaco,Consolas,Courier New,monospace;font-size:14px;transition:all .2s}.bank-input:focus{border-color:var(--accent,#22d3ee);background:#121722;outline:none;box-shadow:0 0 0 3px #22d3ee1a}.bank-input::placeholder{color:var(--muted,#a4a9b6);opacity:.6;letter-spacing:.5px}.bank-input-container.has-error .bank-input{border-color:var(--danger,#ef4444)}.bank-input-container.is-valid .bank-input{border-color:#22c55e}.bank-counter{color:var(--muted,#a4a9b6);pointer-events:none;font-family:Monaco,Consolas,monospace;font-size:11px;position:absolute;right:12px}.bank-counter.complete{color:#22c55e}.bank-error{color:var(--danger,#ef4444);font-size:12px}.bank-valid{color:#22c55e;font-size:12px}.contractor-select{flex-direction:column;gap:12px;display:flex}.contractor-label{color:var(--text,#e6e9ef);margin-bottom:4px;font-size:14px;font-weight:600}.client-selector{position:relative}.btn-select-client{width:100%;color:var(--text,#e6e9ef);cursor:pointer;background:linear-gradient(135deg,#22d3ee1a 0%,#22d3ee0d 100%);border:1px solid #22d3ee4d;border-radius:10px;align-items:center;gap:10px;padding:12px 16px;font-size:14px;font-weight:500;transition:all .2s;display:flex}.btn-select-client:hover{border-color:var(--accent,#22d3ee);background:linear-gradient(135deg,#22d3ee26 0%,#22d3ee14 100%)}.btn-select-client .btn-icon{font-size:18px}.btn-select-client .dropdown-arrow{color:var(--muted,#a4a9b6);margin-left:auto;font-size:10px}.client-dropdown{border:1px solid var(--border,#1f2733);z-index:1000;background:#0f141b;border-radius:10px;flex-direction:column;max-height:400px;display:flex;position:absolute;top:calc(100% + 4px);left:0;right:0;overflow:hidden;box-shadow:0 8px 32px #0006}.dropdown-search{border-bottom:1px solid var(--border,#1f2733);padding:12px}.dropdown-search input{border:1px solid var(--border,#1f2733);width:100%;color:var(--text,#e6e9ef);background:#0a0d11;border-radius:8px;padding:10px 14px;font-size:14px}.dropdown-search input:focus{border-color:var(--accent,#22d3ee);outline:none}.dropdown-search input::placeholder{color:var(--muted,#a4a9b6)}.dropdown-list{max-height:280px;overflow-y:auto}.dropdown-empty{text-align:center;color:var(--muted,#a4a9b6);padding:24px;font-size:14px}.dropdown-item{text-align:left;cursor:pointer;background:0 0;border:none;border-bottom:1px solid #ffffff0d;width:100%;padding:12px 16px;transition:background .15s;display:block}.dropdown-item:hover{background:#22d3ee1a}.dropdown-item:last-child{border-bottom:none}.dropdown-item .item-name{color:var(--text,#e6e9ef);margin-bottom:4px;font-size:14px;font-weight:600}.dropdown-item .item-details{color:var(--muted,#a4a9b6);gap:12px;font-size:12px;display:flex}.dropdown-item .item-nip{font-family:Monaco,Consolas,monospace}.dropdown-footer{border-top:1px solid var(--border,#1f2733);background:#0a0d11;padding:10px 16px}.add-client-link{color:var(--accent,#22d3ee);font-size:13px;text-decoration:none}.add-client-link:hover{text-decoration:underline}.no-clients-hint{color:#fcd34d;background:#fbbf241a;border:1px solid #fbbf244d;border-radius:8px;padding:12px 16px;font-size:13px}.no-clients-hint a{color:var(--accent,#22d3ee);font-weight:500;text-decoration:none}.no-clients-hint a:hover{text-decoration:underline}.divider{align-items:center;gap:12px;margin:4px 0;display:flex}.divider:before,.divider:after{content:"";background:var(--border,#1f2733);flex:1;height:1px}.divider span{color:var(--muted,#a4a9b6);text-transform:uppercase;letter-spacing:.5px;font-size:12px}.contractor-fields{flex-direction:column;gap:12px;display:flex}.contractor-fields .field{flex-direction:column;gap:6px;display:flex}.contractor-fields .label{color:var(--muted,#a4a9b6);font-size:12px;font-weight:500}.contractor-fields .input{border:1px solid var(--border,#1f2733);color:var(--text,#e6e9ef);background:#0f141b;border-radius:8px;padding:10px 12px;font-size:14px;transition:all .2s}.contractor-fields .input:focus{border-color:var(--accent,#22d3ee);background:#121722;outline:none}.contractor-fields .input::placeholder{color:var(--muted,#a4a9b6)}.contractor-fields .input--error{border-color:var(--danger,#ef4444)}.contractor-fields .field-error{color:var(--danger,#ef4444);font-size:12px}@media (width<=480px){.dropdown-item .item-details{flex-direction:column;gap:2px}}.filters-row{flex-wrap:wrap;gap:16px;margin-bottom:16px;display:flex}.filter-label{color:var(--muted);align-items:center;gap:8px;font-size:14px;display:flex}.filter-select{background:var(--bg);border:1px solid var(--border);color:var(--text);cursor:pointer;border-radius:6px;padding:6px 12px;font-size:14px}.filter-select:focus{border-color:var(--accent);outline:none}.buyer-cell{flex-direction:column;gap:2px;display:flex}.buyer-name{color:var(--text);font-weight:500}.buyer-nip{color:var(--muted);font-family:JetBrains Mono,Fira Code,Consolas,monospace;font-size:12px}.status-badge{text-transform:uppercase;letter-spacing:.5px;border-radius:12px;padding:4px 10px;font-size:12px;font-weight:600;display:inline-block}.status-pending{color:#f59e0b;background:#f59e0b26;border:1px solid #f59e0b4d}.status-approved{color:#22c55e;background:#22c55e26;border:1px solid #22c55e4d}.status-rejected{color:#ef4444;background:#ef444426;border:1px solid #ef44444d}.actions-cell{align-items:center;gap:8px;display:flex}.btn-icon{cursor:pointer;background:0 0;border:none;border-radius:4px;padding:4px 8px;font-size:16px;transition:background .2s}.btn-icon:hover{background:#ffffff0d}.btn-accent.small,.btn-danger.small{border-radius:6px;padding:4px 10px;font-size:12px}.btn-accent.small{background:var(--accent);color:#001018;cursor:pointer;border:none;font-weight:600;transition:all .2s}.btn-accent.small:hover:not(:disabled){filter:brightness(1.1);transform:translateY(-1px)}.btn-accent.small:disabled{opacity:.5;cursor:not-allowed}.btn-danger{background:var(--danger);color:#fff;cursor:pointer;border:none;font-weight:600;transition:all .2s}.btn-danger:hover:not(:disabled){filter:brightness(1.1)}.btn-danger:disabled{opacity:.5;cursor:not-allowed}.btn-danger.small{padding:4px 8px}.empty-state-hint{color:var(--muted);margin-top:8px;font-size:13px;display:block}.modal-backdrop{z-index:1000;background:#000000b3;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.preview-modal{max-width:900px}.reject-modal{max-width:500px}.modal-header h3{color:var(--text);margin:0;font-size:18px}.modal-body{padding:20px}.preview-grid{grid-template-columns:1fr 1fr;gap:24px;margin-bottom:20px;display:grid}.preview-section h4{text-transform:uppercase;letter-spacing:1px;color:var(--muted);margin:0 0 8px;font-size:12px}.preview-section p{color:var(--text);margin:0 0 4px;font-size:14px}.preview-dates{background:var(--bg);color:var(--muted);border-radius:8px;gap:32px;margin-bottom:20px;padding:12px 16px;font-size:14px;display:flex}.preview-dates strong{color:var(--text)}.preview-items-table{border-collapse:collapse;width:100%;margin-bottom:16px;font-size:14px}.preview-items-table th,.preview-items-table td{text-align:left;border-bottom:1px solid var(--border);padding:10px 12px}.preview-items-table th{background:var(--bg);color:var(--muted);text-transform:uppercase;letter-spacing:.5px;font-size:12px}.preview-items-table td{color:var(--text)}.preview-totals{border-top:1px solid var(--border);flex-direction:column;align-items:flex-end;gap:8px;padding-top:16px;display:flex}.total-row{color:var(--muted);gap:16px;font-size:14px;display:flex}.total-row strong{color:var(--text);text-align:right;min-width:120px}.total-row.total-gross{border-top:1px solid var(--border);padding-top:8px;font-size:16px}.total-row.total-gross strong{color:var(--accent)}.rejection-info{background:#ef44441a;border:1px solid #ef44444d;border-radius:8px;margin-top:20px;padding:16px}.rejection-info h4{color:#ef4444;margin:0 0 8px;font-size:14px}.rejection-info p{color:var(--text);margin:0;font-size:14px}.reject-label{color:var(--text);flex-direction:column;gap:8px;font-size:14px;display:flex}.reject-textarea{background:var(--bg);border:1px solid var(--border);color:var(--text);resize:vertical;border-radius:8px;padding:12px;font-family:inherit;font-size:14px}.reject-textarea:focus{border-color:var(--accent);outline:none}.reject-textarea::placeholder{color:var(--muted)}.btn-light{border:1px solid var(--border);color:var(--text);cursor:pointer;background:0 0;border-radius:6px;padding:8px 16px;font-size:14px;transition:all .2s}.btn-light:hover{border-color:var(--muted);background:#ffffff0d}@media (width<=768px){.preview-grid{grid-template-columns:1fr;gap:16px}.preview-dates{flex-direction:column;gap:8px}.preview-items-table{font-size:12px}.preview-items-table th,.preview-items-table td{padding:8px}.actions-cell{flex-wrap:wrap}}.search-input{border:1px solid var(--border,#1f2733);color:var(--text,#e6e9ef);background:#0f141b;border-radius:8px;min-width:250px;padding:10px 14px;font-size:14px}.search-input:focus{border-color:var(--accent,#22d3ee);outline:none}.search-input::placeholder{color:var(--muted,#a4a9b6)}.empty-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:60px 20px;display:flex}.empty-icon{opacity:.5;margin-bottom:20px;font-size:64px}.empty-state h3{color:var(--text,#e6e9ef);margin-bottom:8px;font-size:20px}.empty-state p{color:var(--muted,#a4a9b6);max-width:400px;margin-bottom:20px}.clients-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px;margin-top:16px;display:grid}.client-card{background:var(--panel,#151a22);border:1px solid var(--border,#1f2733);border-radius:12px;flex-direction:column;gap:16px;padding:20px;transition:border-color .2s;display:flex}.client-card:hover{border-color:#22d3ee4d}.client-info{flex:1}.client-name{color:var(--text,#e6e9ef);margin:0 0 8px;font-size:16px;font-weight:600}.client-nip{color:var(--accent,#22d3ee);margin-bottom:8px;font-family:Monaco,Consolas,monospace;font-size:14px}.client-address,.client-bank,.client-email,.client-phone{color:var(--muted,#a4a9b6);margin-bottom:4px;font-size:13px}.client-bank{font-family:Monaco,Consolas,monospace;font-size:12px}.client-actions{border-top:1px solid var(--border,#1f2733);gap:8px;padding-top:12px;display:flex}.client-actions .btn-light.small{flex:1;padding:8px 12px;font-size:13px}.modal-overlay{z-index:1000;background:#000000b3;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal-content{background:var(--panel,#151a22);border:1px solid var(--border,#1f2733);border-radius:16px;width:100%;max-width:500px;max-height:90vh;overflow-y:auto}.modal-header h2{color:var(--text,#e6e9ef);margin:0;font-size:18px}.modal-close{color:var(--muted,#a4a9b6);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:4px 8px;font-size:20px;transition:all .15s}.modal-close:hover{color:var(--text,#e6e9ef);background:#ffffff1a}.modal-body .field{flex-direction:column;gap:6px;display:flex}.modal-body .label{color:var(--muted,#a4a9b6);font-size:13px;font-weight:500}.modal-body .input{border:1px solid var(--border,#1f2733);color:var(--text,#e6e9ef);background:#0f141b;border-radius:8px;padding:10px 12px;font-size:14px;transition:all .2s}.modal-body .input:focus{border-color:var(--accent,#22d3ee);background:#121722;outline:none}.modal-body .input::placeholder{color:var(--muted,#a4a9b6)}.error-message{color:#fca5a5;background:#ef44441a;border:1px solid #ef44444d;border-radius:8px;margin:0 24px;padding:12px 16px}.info-banner{color:#86efac;background:#22c55e1a;border:1px solid #22c55e4d;border-radius:8px;margin-bottom:16px;padding:12px 16px}@media (width<=768px){.ops-header{flex-direction:column;gap:12px}.ops-actions{flex-direction:column;width:100%}.search-input{min-width:unset;width:100%}.clients-grid{grid-template-columns:1fr}}.reports-filters{flex-wrap:wrap;align-items:flex-end;gap:16px;display:flex}.reports-filters label{min-width:120px}.kpi-grid{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px;display:grid}.kpi-card{text-align:center;padding:24px 16px!important}.kpi-title{color:var(--muted,#a4a9b6);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;font-size:13px}.kpi-value{color:var(--text,#e6e9ef);font-family:Monaco,Consolas,monospace;font-size:28px;font-weight:700}.reports-grid{grid-template-columns:1fr 1fr;gap:20px;display:grid}.reports-grid .card h3{color:var(--text,#e6e9ef);border-bottom:1px solid var(--border,#1f2733);margin:0 0 16px;padding-bottom:12px;font-size:15px;font-weight:600}.type-badge{border-radius:4px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-block}.type-badge.issued{color:#00e096;background:#00e09626}.type-badge.received{color:#60a5fa;background:#3b82f626}.text-right{text-align:right}@media (width<=1200px){.kpi-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=768px){.kpi-grid,.reports-grid{grid-template-columns:1fr}.reports-filters{flex-direction:column}.reports-filters label{width:100%}.kpi-value{font-size:24px}}@media print{.ops-actions{display:none!important}.kpi-grid{grid-template-columns:repeat(4,1fr)}.kpi-card{background:#f9f9f9!important;border:1px solid #ccc!important}.reports-grid{grid-template-columns:1fr 1fr}}.card{background:var(--panel,#151a22);border:1px solid var(--border,#1f2733);border-radius:12px;margin-bottom:20px;padding:20px}.card h3{color:var(--text,#e6e9ef);border-bottom:1px solid var(--border,#1f2733);margin:0 0 16px;padding-bottom:12px;font-size:16px;font-weight:600}.card label{color:var(--muted,#a4a9b6);flex-direction:column;gap:6px;margin-bottom:12px;font-size:13px;font-weight:500;display:flex}.card label input,.card label select,.card label textarea{color:var(--text,#e6e9ef);border:1px solid var(--border,#1f2733);background:#0f141b;border-radius:8px;padding:10px 12px;font-size:14px}.card label input:focus,.card label select:focus{border-color:var(--accent,#22d3ee);background:#121722;outline:none}.card label input:disabled{opacity:.5;cursor:not-allowed}.settings-tabs-nav{background:var(--panel,#151a22);border:1px solid var(--border,#1f2733);border-radius:12px;flex-wrap:wrap;gap:4px;margin-bottom:24px;padding:6px;display:flex}.settings-tab-btn{color:var(--muted,#a4a9b6);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-radius:8px;align-items:center;gap:6px;padding:10px 16px;font-size:13px;font-weight:500;transition:all .2s;display:flex}.settings-tab-btn:hover{color:var(--text,#e6e9ef);background:#ffffff0d}.settings-tab-btn.active{color:var(--accent,#22d3ee);background:#22d3ee1a;font-weight:600}.settings-tab-icon{font-size:15px;line-height:1}.settings-tab-label{line-height:1}.settings-tab-content{min-height:300px}.two-col{grid-template-columns:1fr 1fr;gap:16px;margin-bottom:12px;display:grid}.two-col label{margin-bottom:0}.checkbox{cursor:pointer;align-items:center;gap:10px;flex-direction:row!important;margin-bottom:0!important;display:inline-flex!important}.checkbox input[type=checkbox]{cursor:pointer;width:18px;height:18px;accent-color:var(--accent,#22d3ee)}.hint{color:var(--muted,#a4a9b6);opacity:.8;font-size:12px}.file-btn{cursor:pointer;position:relative;overflow:hidden}.file-btn input[type=file]{opacity:0;cursor:pointer;position:absolute;inset:0}.settings-divider{background:#2b3140;height:1px;margin:16px 0}.input-hint{color:#6b7280;margin-top:4px;font-size:11px;font-weight:400;display:block}.inline-label{color:#a7b1c2;align-items:center;gap:12px;margin-top:8px;margin-left:28px;font-size:13px;display:flex}.small-input{color:#e7eaf3;background:#0f131b;border:1px solid #2b3140;border-radius:6px;width:80px;padding:6px 10px;font-size:13px}.inline-settings{margin-top:12px;margin-left:28px}.info-banner{color:#86efac;background:#22c55e1a;border:1px solid #22c55e4d;border-radius:8px;margin-bottom:16px;padding:12px 16px;font-size:14px}.error-message{color:#fca5a5;background:#ef44441a;border:1px solid #ef44444d;border-radius:10px;margin-bottom:16px;padding:14px 18px}.error-message strong{margin-bottom:8px;display:block}.error-message ul{margin:0;padding-left:20px}.danger-zone{border-color:#ef44444d}.danger-zone h3{color:#fca5a5}.danger-actions{flex-wrap:wrap;gap:12px;margin-top:12px;display:flex}.btn-danger{color:#fecaca;cursor:pointer;background:#7f1d1d;border:1px solid #991b1b;border-radius:8px;padding:10px 16px;font-weight:500;transition:all .2s}.btn-danger:hover{background:#991b1b}.auth-method-selector{flex-direction:column;gap:12px;margin-bottom:16px;display:flex}.auth-method-option{border:2px solid var(--border,#1f2733);cursor:pointer;background:#0f141b;border-radius:10px;padding:16px;transition:all .2s;flex-direction:row!important;align-items:flex-start!important;gap:12px!important;display:flex!important}.auth-method-option:hover{background:#121722;border-color:#22d3ee66}.auth-method-option input[type=radio]{cursor:pointer;width:20px;height:20px;accent-color:var(--accent,#22d3ee);margin-top:4px}.auth-method-option input[type=radio]:disabled{opacity:.4;cursor:not-allowed}.auth-method-option:has(input[type=radio]:checked){border-color:var(--accent,#22d3ee);background:#22d3ee0d}.auth-method-option:has(input[type=radio]:disabled){opacity:.6;cursor:not-allowed}.auth-method-content{opacity:.7;flex:1;gap:12px;transition:opacity .2s;display:flex}.auth-method-icon{font-size:32px;line-height:1}.auth-method-text{flex-direction:column;gap:6px;display:flex}.auth-method-title{color:var(--text,#e6e9ef);align-items:center;gap:8px;font-size:15px;font-weight:600;display:flex}.auth-method-badge{color:#fbbf24;text-transform:uppercase;background:#f59e0b26;border-radius:4px;padding:3px 8px;font-size:11px;font-weight:600}.auth-method-description{color:var(--muted,#a4a9b6);font-size:13px;line-height:1.5}.certificate-upload-container{flex-direction:column;gap:16px;display:flex}.certificate-status{background:#22c55e0d;border:1px solid #22c55e33;border-radius:10px;flex-direction:column;gap:16px;padding:16px;display:flex}.certificate-status-header{align-items:flex-start;gap:16px;display:flex}.certificate-status-icon{font-size:40px;line-height:1}.certificate-status-text{flex-direction:column;gap:6px;display:flex}.certificate-status-title{color:#86efac;font-size:16px;font-weight:600}.certificate-status-subtitle{color:#a7f3d0;font-size:13px}.certificate-info-box{background:#0003;border-radius:8px;flex-direction:column;gap:8px;padding:12px 16px;display:flex}.certificate-info-row{justify-content:space-between;align-items:center;gap:16px;font-size:13px;display:flex}.certificate-info-label{color:#a7f3d0;font-weight:500}.certificate-info-value{color:#d1fae5;font-family:JetBrains Mono,Fira Code,Consolas,monospace}.certificate-actions{flex-wrap:wrap;gap:10px;display:flex}.certificate-upload-form,.certificate-file-inputs{flex-direction:column;gap:12px;display:flex}.certificate-file-label{border:2px dashed var(--border,#1f2733);cursor:pointer;background:#0f141b;border-radius:8px;flex-direction:column;gap:8px;padding:14px;transition:all .2s;display:flex}.certificate-file-label:hover{background:#121722;border-color:#22d3ee66}.certificate-file-label-text{color:var(--text,#e6e9ef);font-size:14px;font-weight:600}.certificate-file-input{display:none}.certificate-file-name{color:var(--accent,#22d3ee);font-family:JetBrains Mono,Fira Code,Consolas,monospace;font-size:13px}@media (width<=1100px){.settings-tabs-nav{gap:2px}.settings-tab-btn{padding:9px 12px;font-size:12px}}@media (width<=860px){.two-col{grid-template-columns:1fr}.auth-method-selector{gap:10px}.auth-method-option{padding:14px}.auth-method-icon{font-size:28px}}@media (width<=768px){.card{padding:16px}.settings-tabs-nav{gap:2px;padding:4px}.settings-tab-btn{gap:4px;padding:8px 10px;font-size:12px}.settings-tab-label{display:none}.settings-tab-icon{font-size:18px}.danger-actions{flex-direction:column}.danger-actions button,.danger-actions .file-btn{text-align:center;width:100%}.certificate-actions{flex-direction:column}.certificate-actions button{width:100%}}@media (width<=480px){.settings-tab-btn{padding:8px}}@media print{.settings-tabs-nav,.file-btn,.btn-danger,.danger-zone,.auth-method-selector,.certificate-upload-container{display:none!important}}.ksef-card-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding-bottom:12px;display:flex}.ksef-card-header--editing{margin-bottom:20px}.ksef-card-title{border:none;margin:0;padding:0}.ksef-meta-row{flex-wrap:wrap;gap:32px;margin-top:16px;display:flex}.ksef-meta-label{color:var(--muted);text-transform:uppercase;letter-spacing:.5px;font-size:11px}.ksef-meta-value{color:var(--text);margin-top:4px;font-size:14px;font-weight:600}.ksef-meta-value--mono{font-family:JetBrains Mono,Fira Code,Consolas,monospace}.ksef-action-row{gap:12px;margin-top:16px;display:flex}.btn-save{background:var(--accent);color:#001018;border:none;font-weight:700}.btn-disconnect{color:#fca5a5;background:#ef444426;border:1px solid #ef44444d}.env-badge{text-transform:uppercase;letter-spacing:.5px;border-radius:4px;margin-left:8px;padding:2px 8px;font-size:11px;font-weight:700}.env-badge--production{color:#fca5a5;background:#ef444426}.env-badge--test{color:#fbbf24;background:#f59e0b26}.ksef-status-value{margin-top:4px;font-size:14px;font-weight:600}.ksef-status-value--connected{color:var(--success)}.ksef-status-value--disconnected{color:var(--danger)}.ksef-method-value{color:var(--accent);margin-top:4px;font-family:JetBrains Mono,Fira Code,Consolas,monospace;font-size:14px;font-weight:600}.ksef-connect-error{color:#fca5a5;background:#ef44441a;border:1px solid #ef44444d;border-radius:8px;margin-top:8px;margin-bottom:16px;padding:12px;font-size:14px}.ksef-connect-actions{flex-wrap:wrap;gap:12px;display:flex}.ksef-method-extra{border-top:1px solid var(--border);margin-top:20px;padding-top:20px}.ksef-token-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.ksef-section-title{color:var(--text);margin:0 0 12px;font-size:14px;font-weight:600}.ksef-token-header .ksef-section-title{margin:0}.ksef-setup-hint{margin-bottom:20px}.ksef-cert-hint{margin-bottom:16px;font-size:13px}.ksef-env-selector{margin-top:16px}.ksef-env-description{margin:0}.ksef-setup-submit{margin-top:4px}.ksef-edit-label{margin-top:16px}.input-mono{font-family:JetBrains Mono,Fira Code,Consolas,monospace}.auth-method-description--danger{color:#fca5a5}.modal-backdrop{z-index:1000;background-color:#0009;justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:fixed;top:0;left:0}.modal-content{background-color:#1e1e2d;border-radius:8px;width:100%;max-width:500px;animation:.3s ease-out fadeIn}.modal-header{border-bottom:1px solid #333;justify-content:space-between;align-items:center;padding:16px 24px;display:flex}.modal-header h2{margin:0;font-size:1.2rem}.close-button{color:#888;cursor:pointer;background:0 0;border:none;font-size:1.8rem;line-height:1}.modal-body{flex-direction:column;gap:16px;padding:24px;display:flex}.modal-footer{border-top:1px solid #333;justify-content:flex-end;gap:12px;padding:16px 24px;display:flex}
