*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{color:#111827;background:#f3f4f6;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:14px}.layout{min-height:100vh;display:flex}.sidebar{z-index:100;background:#1e293b;flex-direction:column;flex-shrink:0;width:240px;min-height:100vh;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar-logo{border-bottom:1px solid #334155;padding:20px 16px 14px}.sidebar-logo .app-name{color:#f1f5f9;font-size:13px;font-weight:700;line-height:1.3}.sidebar-logo .app-sub{color:#94a3b8;margin-top:2px;font-size:11px}.sidebar-nav{flex:1;padding:8px 0;overflow-y:auto}.nav-section-title{letter-spacing:.08em;color:#475569;text-transform:uppercase;padding:14px 16px 4px;font-size:10px;font-weight:600}.nav-item{color:#94a3b8;cursor:pointer;text-align:left;background:0 0;border:none;border-radius:0;align-items:center;gap:10px;width:100%;padding:8px 16px;font-size:13.5px;text-decoration:none;transition:background .15s,color .15s;display:flex}.nav-item:hover{color:#f1f5f9;background:#334155}.nav-item.active{color:#fff;background:#3b82f6}.nav-item .nav-icon{text-align:center;width:20px;font-size:15px}.sidebar-user{border-top:1px solid #334155;padding:12px 16px}.sidebar-user .user-name{color:#f1f5f9;font-size:13px;font-weight:600}.sidebar-user .user-role{color:#94a3b8;font-size:11px}.sidebar-user .logout-btn{color:#94a3b8;cursor:pointer;background:0 0;border:none;margin-top:8px;padding:0;font-size:12px}.sidebar-user .logout-btn:hover{color:#ef4444}.main-content{flex:1;min-height:100vh;margin-left:240px;padding:24px}.page-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.page-title{color:#111827;font-size:22px;font-weight:700}.card{background:#fff;border-radius:10px;margin-bottom:20px;padding:20px;box-shadow:0 1px 3px #00000012,0 1px 2px #0000000a}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:20px;display:grid}.stat-card{background:#fff;border-radius:10px;padding:18px 20px;box-shadow:0 1px 3px #00000012}.stat-label{color:#6b7280;margin-bottom:6px;font-size:12px;font-weight:500}.stat-value{color:#111827;font-size:24px;font-weight:700}.stat-value.green{color:#10b981}.stat-value.red{color:#ef4444}.stat-value.blue{color:#3b82f6}.stat-value.orange{color:#f59e0b}.stat-sub{color:#9ca3af;margin-top:4px;font-size:11px}.btn{cursor:pointer;border:none;border-radius:7px;align-items:center;gap:6px;padding:8px 16px;font-size:13.5px;font-weight:500;text-decoration:none;transition:background .15s,opacity .15s;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{color:#fff;background:#3b82f6}.btn-primary:hover:not(:disabled){background:#2563eb}.btn-secondary{color:#374151;background:#f3f4f6}.btn-secondary:hover:not(:disabled){background:#e5e7eb}.btn-danger{color:#dc2626;background:#fee2e2}.btn-danger:hover:not(:disabled){background:#fecaca}.btn-success{color:#059669;background:#d1fae5}.btn-success:hover:not(:disabled){background:#a7f3d0}.btn-sm{padding:5px 10px;font-size:12px}.btn-icon{padding:6px 8px}.form-group{margin-bottom:14px}.form-label{color:#374151;margin-bottom:5px;font-size:12.5px;font-weight:500;display:block}.form-input,.form-select,.form-textarea{color:#111827;background:#fff;border:1px solid #d1d5db;border-radius:7px;outline:none;width:100%;padding:8px 10px;font-size:13.5px;transition:border-color .15s,box-shadow .15s}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61f}.form-textarea{resize:vertical;min-height:60px}.form-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}.form-row-3{grid-template-columns:1fr 1fr 1fr;gap:12px;display:grid}.filter-bar{flex-wrap:wrap;align-items:flex-end;gap:10px;margin-bottom:16px;display:flex}.filter-bar .form-group{margin-bottom:0}.filter-bar .form-input,.filter-bar .form-select{min-width:140px}.table-wrap{overflow-x:auto}table{border-collapse:collapse;width:100%}thead th{text-align:left;color:#6b7280;white-space:nowrap;background:#f9fafb;border-bottom:1px solid #e5e7eb;padding:10px 12px;font-size:12px;font-weight:600}tbody td{color:#374151;vertical-align:middle;border-bottom:1px solid #f3f4f6;padding:10px 12px;font-size:13.5px}tbody tr:hover{background:#f9fafb}tbody tr:last-child td{border-bottom:none}.actions{gap:6px;display:flex}.badge{border-radius:999px;padding:2px 8px;font-size:11.5px;font-weight:600;display:inline-block}.badge-green{color:#059669;background:#d1fae5}.badge-red{color:#dc2626;background:#fee2e2}.badge-blue{color:#2563eb;background:#dbeafe}.badge-gray{color:#6b7280;background:#f3f4f6}.badge-orange{color:#d97706;background:#ffedd5}.badge-purple{color:#7c3aed;background:#ede9fe}.alert{border-radius:7px;margin-bottom:14px;padding:10px 14px;font-size:13.5px}.alert-error{color:#dc2626;background:#fee2e2}.alert-success{color:#059669;background:#d1fae5}.alert-info{color:#2563eb;background:#dbeafe}.modal-overlay{z-index:1000;background:#00000073;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal{background:#fff;border-radius:12px;flex-direction:column;width:100%;max-width:560px;max-height:90vh;display:flex;box-shadow:0 20px 60px #0003}.modal-lg{max-width:780px}.modal-header{border-bottom:1px solid #e5e7eb;justify-content:space-between;align-items:center;padding:18px 22px 14px;display:flex}.modal-title{color:#111827;font-size:16px;font-weight:700}.modal-close{cursor:pointer;color:#6b7280;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;width:28px;height:28px;font-size:20px;line-height:1;display:flex}.modal-close:hover{color:#111827;background:#f3f4f6}.modal-body{flex:1;padding:20px 22px;overflow-y:auto}.modal-footer{border-top:1px solid #e5e7eb;justify-content:flex-end;gap:10px;padding:14px 22px;display:flex}.empty{text-align:center;color:#9ca3af;padding:40px 20px}.empty-icon{margin-bottom:12px;font-size:40px}.tabs{border-bottom:2px solid #e5e7eb;gap:0;margin-bottom:20px;display:flex}.tab{cursor:pointer;color:#6b7280;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-2px;padding:10px 20px;font-size:14px;font-weight:500;transition:color .15s,border-color .15s}.tab.active{color:#3b82f6;border-bottom-color:#3b82f6}.tab:hover:not(.active){color:#374151}.cur-rub{color:#10b981}.cur-usd{color:#3b82f6}.cur-eur{color:#a855f7}.login-page{background:linear-gradient(135deg,#1e293b 0%,#0f172a 100%);justify-content:center;align-items:center;min-height:100vh;display:flex}.login-card{background:#fff;border-radius:14px;width:360px;padding:40px 36px;box-shadow:0 20px 60px #0000004d}.login-logo{text-align:center;margin-bottom:28px}.login-logo h1{color:#1e293b;font-size:20px;font-weight:800}.login-logo p{color:#6b7280;margin-top:4px;font-size:13px}.color-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px;display:inline-block}.progress-bar-bg{background:#f3f4f6;border-radius:999px;height:8px;overflow:hidden}.progress-bar-fill{background:#3b82f6;border-radius:999px;height:100%;transition:width .4s}.month-nav{align-items:center;gap:10px;display:flex}.month-nav .month-label{color:#111827;text-align:center;min-width:140px;font-size:15px;font-weight:600}.dept-header td{color:#374151;background:#f1f5f9;padding:8px 12px;font-size:12.5px;font-weight:700}.totals-row td{background:#fef9c3;font-weight:700}.checkbox-label{cursor:pointer;color:#374151;align-items:center;gap:8px;font-size:13.5px;display:flex}.checkbox-label input[type=checkbox]{cursor:pointer;width:15px;height:15px}input[type=color]{cursor:pointer;border:1px solid #d1d5db;border-radius:7px;width:40px;height:34px;padding:2px 4px}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:999px}.ie-cell{cursor:pointer;border-radius:4px;min-height:20px;padding:1px 4px;transition:background .15s;display:block}.ie-cell:hover{background:#f0f4ff;outline:1px solid #c7d2fe}
