@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";:root{--color-primary: #BF0027;--color-primary-hover: #A50021;--color-primary-light: #FFF0F1;--color-primary-container: #EE0033;--color-white: #FFFFFF;--color-surface: #F5F6FA;--color-surface-2: #FAFBFF;--color-border: #E8EAED;--color-border-light: #F0F2F5;--color-text-primary: #111827;--color-text-secondary: #6B7280;--color-text-muted: #9CA3AF;--color-text-link: #2563EB;--color-success: #16A34A;--color-success-bg: #F0FDF4;--color-success-border: #BBF7D0;--color-warning: #D97706;--color-warning-bg: #FFFBEB;--color-warning-border: #FDE68A;--color-error: #DC2626;--color-error-bg: #FEF2F2;--color-error-border: #FECACA;--color-info: #2563EB;--color-info-bg: #EFF6FF;--color-info-border: #BFDBFE;--sidebar-bg: #FFFFFF;--sidebar-width: 240px;--sidebar-border: #E8EAED;--sidebar-text: #374151;--sidebar-text-muted: #9CA3AF;--sidebar-item-hover: #F9FAFB;--sidebar-item-active-bg: #FFF0F1;--sidebar-item-active-text: #BF0027;--sidebar-item-active-border: #BF0027;--header-height: 60px;--header-bg: #FFFFFF;--header-border: #E8EAED;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--spacing-2xl: 48px;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-full: 9999px;--shadow-sm: 0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 4px 12px rgba(0,0,0,.08), 0 2px 6px rgba(0,0,0,.04);--shadow-lg: 0 10px 30px rgba(0,0,0,.1), 0 4px 12px rgba(0,0,0,.06);--shadow-xl: 0 20px 50px rgba(0,0,0,.12);--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-size-xs: 11px;--font-size-sm: 12px;--font-size-base: 14px;--font-size-md: 15px;--font-size-lg: 16px;--font-size-xl: 18px;--font-size-2xl: 20px;--font-size-3xl: 24px;--font-size-4xl: 28px;--transition-fast: .15s ease;--transition-normal: .2s ease;--transition-slow: .3s ease;--z-sidebar: 100;--z-header: 110;--z-modal: 1000;--z-toast: 1100}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth;-webkit-text-size-adjust:100%}body{font-family:var(--font-family);font-size:var(--font-size-base);color:var(--color-text-primary);background-color:var(--color-surface);line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:var(--color-text-link);text-decoration:none}a:hover{text-decoration:underline}img,svg{display:block;max-width:100%}button{cursor:pointer;font-family:var(--font-family);border:none;background:none}input,textarea,select{font-family:var(--font-family);font-size:var(--font-size-base)}.app-layout{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-width);min-height:100vh;background:var(--sidebar-bg);border-right:1px solid var(--sidebar-border);display:flex;flex-direction:column;position:fixed;top:0;left:0;z-index:var(--z-sidebar);transition:transform var(--transition-normal);overflow-y:auto;overflow-x:hidden}.sidebar-logo{display:flex;align-items:center;justify-content:center;padding:12px var(--spacing-md);border-bottom:1px solid var(--sidebar-border);min-height:var(--header-height);background:#fff}.sidebar-logo-icon{width:34px;height:34px;background:var(--color-primary);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0}.sidebar-logo-icon svg{color:#fff;width:18px;height:18px}.sidebar-logo-text{display:flex;flex-direction:column}.sidebar-logo-title{font-size:14px;font-weight:700;color:var(--color-text-primary);line-height:1.2;letter-spacing:-.01em}.sidebar-logo-subtitle{font-size:10px;color:var(--color-text-muted);font-weight:400;text-transform:uppercase;letter-spacing:.04em;margin-top:1px}.sidebar-nav{flex:1;padding:var(--spacing-sm) 0}.sidebar-nav-section{padding:0 var(--spacing-sm)}.sidebar-nav-label{font-size:10px;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.08em;padding:var(--spacing-md) var(--spacing-sm) var(--spacing-xs)}.sidebar-nav-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:var(--radius-md);font-size:13.5px;font-weight:500;color:var(--sidebar-text);text-decoration:none;transition:all var(--transition-fast);position:relative;margin-bottom:2px;white-space:nowrap;cursor:pointer;border:1.5px solid transparent}.sidebar-nav-item:hover{background:var(--sidebar-item-hover);color:var(--color-text-primary);text-decoration:none}.sidebar-nav-item.active{background:var(--sidebar-item-active-bg);color:var(--sidebar-item-active-text);border-color:transparent;font-weight:600}.sidebar-nav-item.active:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--color-primary);border-radius:0 2px 2px 0}.sidebar-nav-item svg{width:18px;height:18px;flex-shrink:0;opacity:.7}.sidebar-nav-item.active svg{opacity:1}.sidebar-nav-badge{margin-left:auto;background:var(--color-primary);color:#fff;font-size:10px;font-weight:700;border-radius:var(--radius-full);padding:1px 7px;min-width:20px;text-align:center}.sidebar-divider{height:1px;background:var(--sidebar-border);margin:var(--spacing-sm) var(--spacing-md)}.sidebar-footer{padding:var(--spacing-sm);border-top:1px solid var(--sidebar-border)}.main-wrapper{flex:1;margin-left:var(--sidebar-width);display:flex;flex-direction:column;min-height:100vh;min-width:0}.header{position:sticky;top:0;z-index:var(--z-header);background:var(--header-bg);border-bottom:1px solid var(--header-border);height:var(--header-height);display:flex;align-items:center;padding:0 var(--spacing-lg);gap:var(--spacing-md)}.header-search{flex:1;max-width:400px}.header-spacer{flex:1}.header-actions{display:flex;align-items:center;gap:var(--spacing-sm)}.header-icon-btn{width:36px;height:36px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:var(--color-text-secondary);transition:all var(--transition-fast);position:relative;background:transparent;border:none;cursor:pointer}.header-icon-btn:hover{background:var(--color-surface);color:var(--color-text-primary)}.header-icon-btn svg{width:20px;height:20px}.notification-badge{position:absolute;top:4px;right:4px;width:8px;height:8px;background:var(--color-primary);border-radius:var(--radius-full);border:2px solid white}.user-avatar{width:34px;height:34px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;cursor:pointer;flex-shrink:0;color:#fff}.user-info{display:flex;flex-direction:column;text-align:right}.user-name{font-size:13px;font-weight:600;color:var(--color-text-primary);line-height:1.2}.user-role{font-size:11px;color:var(--color-text-muted)}.page-content{flex:1;padding:var(--spacing-lg);overflow-x:hidden}.page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:var(--spacing-lg);gap:var(--spacing-md);flex-wrap:wrap}.page-title{font-size:var(--font-size-2xl);font-weight:700;color:var(--color-text-primary);letter-spacing:-.02em;line-height:1.2}.page-subtitle{font-size:var(--font-size-base);color:var(--color-text-secondary);margin-top:4px}.page-actions{display:flex;align-items:center;gap:var(--spacing-sm);flex-wrap:wrap}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 16px;border-radius:var(--radius-md);font-size:var(--font-size-base);font-weight:600;font-family:var(--font-family);transition:all var(--transition-fast);border:1.5px solid transparent;cursor:pointer;white-space:nowrap;text-decoration:none;line-height:1}.btn:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.btn svg{width:16px;height:16px;flex-shrink:0}.btn-sm{padding:5px 12px;font-size:var(--font-size-sm)}.btn-lg{padding:11px 24px;font-size:var(--font-size-md)}.btn-primary{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.btn-primary:hover{background:var(--color-primary-hover);border-color:var(--color-primary-hover);box-shadow:0 2px 8px #bf00274d;transform:translateY(-1px)}.btn-secondary{background:#fff;color:var(--color-text-primary);border-color:var(--color-border)}.btn-secondary:hover{background:var(--color-surface);border-color:#d1d5db}.btn-ghost{background:transparent;color:var(--color-text-secondary);border-color:transparent}.btn-ghost:hover{background:var(--color-surface);color:var(--color-text-primary)}.btn-danger{background:var(--color-error);color:#fff;border-color:var(--color-error)}.btn-danger:hover{background:#b91c1c;box-shadow:0 2px 8px #dc26264d}.btn-success{background:var(--color-success);color:#fff;border-color:var(--color-success)}.btn-success:hover{background:#15803d;box-shadow:0 2px 8px #16a34a4d}.btn-warning{background:var(--color-warning);color:#fff;border-color:var(--color-warning)}.btn-link{background:transparent;color:var(--color-primary);border:none;padding:0;font-weight:500}.btn-link:hover{color:var(--color-primary-hover)}.form-group{display:flex;flex-direction:column;gap:6px}.form-label{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.04em}.form-label-required:after{content:" *";color:var(--color-primary)}.form-input,.form-select,.form-textarea{width:100%;height:38px;padding:0 12px;border:1.5px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-base);color:var(--color-text-primary);background:#fff;transition:all var(--transition-fast);outline:none;font-family:var(--font-family)}.form-textarea{height:auto;padding:10px 12px;resize:vertical;min-height:80px}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #bf002714}.form-input::placeholder,.form-textarea::placeholder{color:var(--color-text-muted)}.form-input:disabled,.form-select:disabled{background:var(--color-surface);color:var(--color-text-muted);cursor:not-allowed}.form-input-icon{position:relative}.form-input-icon .form-input{padding-left:38px}.form-input-icon .input-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--color-text-muted);width:16px;height:16px}.form-hint{font-size:var(--font-size-xs);color:var(--color-text-muted)}.form-error-msg{font-size:var(--font-size-xs);color:var(--color-error)}.form-input.error,.form-select.error{border-color:var(--color-error)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md)}.form-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:var(--spacing-md)}.form-section{background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg);margin-bottom:var(--spacing-md)}.form-section-title{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--font-size-md);font-weight:700;color:var(--color-text-primary);margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-sm);border-bottom:1px solid var(--color-border-light)}.form-section-title:before{content:"";width:4px;height:16px;border-radius:var(--radius-full);background:var(--color-primary);flex-shrink:0}.search-input-wrapper{position:relative}.search-input-wrapper .search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--color-text-muted);width:16px;height:16px;pointer-events:none}.search-input-wrapper .form-input{padding-left:36px;background:var(--color-surface);border-color:transparent}.search-input-wrapper .form-input:focus{background:#fff;border-color:var(--color-primary)}.card{background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.card-header{padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--color-border-light);display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md)}.card-title{font-size:var(--font-size-md);font-weight:700;color:var(--color-text-primary)}.card-body{padding:var(--spacing-lg)}.card-footer{padding:var(--spacing-md) var(--spacing-lg);border-top:1px solid var(--color-border-light);background:var(--color-surface)}.kpi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.kpi-card{background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg);position:relative;overflow:hidden}.kpi-card-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:var(--spacing-sm)}.kpi-icon{width:44px;height:44px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center}.kpi-icon svg{width:22px;height:22px}.kpi-icon.red{background:#fff0f1;color:var(--color-primary)}.kpi-icon.blue{background:#eff6ff;color:#2563eb}.kpi-icon.green{background:#f0fdf4;color:var(--color-success)}.kpi-icon.orange{background:#fff7ed;color:#ea580c}.kpi-badge{font-size:10px;font-weight:700;padding:3px 8px;border-radius:var(--radius-full)}.kpi-badge.urgent{background:var(--color-error-bg);color:var(--color-error)}.kpi-badge.today{background:var(--color-info-bg);color:var(--color-info)}.kpi-badge.positive{background:var(--color-success-bg);color:var(--color-success)}.kpi-value{font-size:32px;font-weight:800;color:var(--color-text-primary);line-height:1;letter-spacing:-.03em;margin-bottom:4px}.kpi-value.red{color:var(--color-primary)}.kpi-label{font-size:12px;font-weight:500;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.04em}.table-wrapper{background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.table-toolbar{padding:var(--spacing-md) var(--spacing-lg);display:flex;align-items:center;gap:var(--spacing-sm);border-bottom:1px solid var(--color-border-light);flex-wrap:wrap}.table-container{overflow-x:auto;-webkit-overflow-scrolling:touch}.data-table{width:100%;border-collapse:collapse;font-size:var(--font-size-base)}.data-table thead{background:var(--color-surface)}.data-table th{padding:10px 16px;text-align:left;font-size:var(--font-size-xs);font-weight:700;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--color-border);white-space:nowrap}.data-table td{padding:12px 16px;color:var(--color-text-primary);border-bottom:1px solid var(--color-border-light);vertical-align:middle}.data-table tbody tr:last-child td{border-bottom:none}.data-table tbody tr{transition:background var(--transition-fast)}.data-table tbody tr:hover{background:#fafbff}.table-actions{display:flex;align-items:center;gap:var(--spacing-sm);white-space:nowrap}.table-action-link{font-size:var(--font-size-sm);font-weight:600;color:var(--color-primary);cursor:pointer;border:none;background:none;padding:0}.table-action-link:hover{text-decoration:underline}.table-action-link.warning{color:var(--color-warning)}.table-action-link.danger{color:var(--color-error)}.table-action-link.success{color:var(--color-success)}.table-action-link.secondary{color:var(--color-text-secondary)}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:var(--radius-full);font-size:11px;font-weight:600;white-space:nowrap}.badge-dot{width:6px;height:6px;border-radius:var(--radius-full);flex-shrink:0}.badge-success{background:var(--color-success-bg);color:var(--color-success)}.badge-warning{background:var(--color-warning-bg);color:var(--color-warning)}.badge-error{background:var(--color-error-bg);color:var(--color-error)}.badge-info{background:var(--color-info-bg);color:var(--color-info)}.badge-primary{background:var(--color-primary-light);color:var(--color-primary)}.badge-neutral{background:#f3f4f6;color:#6b7280}.badge-purple{background:#f5f3ff;color:#7c3aed}.badge-orange{background:#fff7ed;color:#ea580c}.role-badge{display:inline-flex;align-items:center;padding:2px 10px;border-radius:var(--radius-full);font-size:11px;font-weight:600}.role-staff{background:#f3f4f6;color:#374151}.role-accountant{background:#eff6ff;color:#2563eb}.role-manager{background:#fff7ed;color:#ea580c}.role-director{background:#fef3c7;color:#d97706}.role-qtv{background:#f5f3ff;color:#7c3aed}.role-admin{background:var(--color-error-bg);color:var(--color-error)}.pagination{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md) var(--spacing-lg);border-top:1px solid var(--color-border-light)}.pagination-info{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.pagination-controls{display:flex;align-items:center;gap:4px}.pagination-btn{width:32px;height:32px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:var(--font-size-sm);font-weight:600;cursor:pointer;border:1.5px solid var(--color-border);background:#fff;color:var(--color-text-secondary);transition:all var(--transition-fast)}.pagination-btn:hover:not(:disabled){border-color:var(--color-primary);color:var(--color-primary)}.pagination-btn.active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.pagination-btn:disabled{opacity:.4;cursor:not-allowed}.pagination-btn svg{width:14px;height:14px}.tabs{display:flex;align-items:center;gap:0;border-bottom:2px solid var(--color-border);margin-bottom:var(--spacing-lg)}.tab-item{padding:10px 16px;font-size:var(--font-size-base);font-weight:500;color:var(--color-text-secondary);cursor:pointer;border:none;background:none;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all var(--transition-fast);white-space:nowrap;display:flex;align-items:center;gap:6px}.tab-item:hover{color:var(--color-text-primary)}.tab-item.active{color:var(--color-primary);font-weight:700;border-bottom-color:var(--color-primary)}.tab-count{background:var(--color-primary);color:#fff;font-size:10px;font-weight:700;border-radius:var(--radius-full);padding:1px 6px;min-width:18px;text-align:center}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:var(--z-modal);display:flex;align-items:center;justify-content:center;padding:var(--spacing-lg);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal{background:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);width:100%;max-width:520px;max-height:90vh;overflow-y:auto;animation:modalIn .2s ease}.modal-sm{max-width:400px}.modal-lg{max-width:700px}.modal-xl{max-width:900px}@keyframes modalIn{0%{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-lg) var(--spacing-lg) var(--spacing-md)}.modal-title{font-size:var(--font-size-xl);font-weight:700;color:var(--color-text-primary)}.modal-close{width:32px;height:32px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast);border:none;background:none}.modal-close:hover{background:var(--color-surface);color:var(--color-text-primary)}.modal-close svg{width:18px;height:18px}.modal-body{padding:0 var(--spacing-lg) var(--spacing-lg)}.modal-footer{padding:var(--spacing-md) var(--spacing-lg);border-top:1px solid var(--color-border-light);display:flex;align-items:center;justify-content:flex-end;gap:var(--spacing-sm)}.modal-icon{width:56px;height:56px;border-radius:var(--radius-xl);display:flex;align-items:center;justify-content:center;margin:0 auto var(--spacing-md)}.modal-icon svg{width:28px;height:28px}.modal-icon.success{background:var(--color-success-bg);color:var(--color-success)}.modal-icon.danger{background:var(--color-error-bg);color:var(--color-error)}.modal-icon.warning{background:var(--color-warning-bg);color:var(--color-warning)}.modal-centered{text-align:center}.file-upload-zone{border:2px dashed var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-xl) var(--spacing-lg);text-align:center;cursor:pointer;transition:all var(--transition-fast);background:var(--color-surface)}.file-upload-zone:hover,.file-upload-zone.dragging{border-color:var(--color-primary);background:var(--color-primary-light)}.file-upload-icon{width:48px;height:48px;background:var(--color-border-light);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;margin:0 auto var(--spacing-sm);color:var(--color-text-muted)}.file-upload-icon svg{width:24px;height:24px}.file-upload-text{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.file-upload-link{color:var(--color-primary);font-weight:600;cursor:pointer}.file-upload-hint{font-size:var(--font-size-xs);color:var(--color-text-muted);margin-top:4px}.file-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:10px 12px;background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-md);margin-top:var(--spacing-sm)}.file-item-icon{width:32px;height:32px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0}.file-item-icon.pdf{background:#fee2e2;color:var(--color-error)}.file-item-icon.doc{background:#dbeafe;color:var(--color-info)}.file-item-icon.xls{background:#d1fae5;color:var(--color-success)}.file-item-icon svg{width:16px;height:16px}.file-item-info{flex:1;min-width:0}.file-item-name{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-item-meta{font-size:var(--font-size-xs);color:var(--color-text-muted)}.progress-bar-wrapper{display:flex;flex-direction:column;gap:6px}.progress-bar-header{display:flex;align-items:center;justify-content:space-between}.progress-bar-label{font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-secondary)}.progress-bar-value{font-size:var(--font-size-sm);font-weight:700;color:var(--color-text-primary)}.progress-bar-track{height:6px;background:var(--color-border);border-radius:var(--radius-full);overflow:hidden}.progress-bar-fill{height:100%;border-radius:var(--radius-full);background:var(--color-primary);transition:width .6s ease}.progress-bar-fill.success{background:var(--color-success)}.progress-bar-fill.warning{background:var(--color-warning)}.toast-container{position:fixed;bottom:var(--spacing-lg);right:var(--spacing-lg);z-index:var(--z-toast);display:flex;flex-direction:column;gap:var(--spacing-sm);pointer-events:none}.toast{background:var(--color-text-primary);color:#fff;padding:12px var(--spacing-md);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);font-size:var(--font-size-sm);font-weight:500;display:flex;align-items:center;gap:var(--spacing-sm);pointer-events:all;animation:slideInRight .2s ease;max-width:360px}.toast svg{width:18px;height:18px;flex-shrink:0}.toast.success{background:var(--color-success)}.toast.error{background:var(--color-error)}.toast.warning{background:var(--color-warning)}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.alert{display:flex;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);font-size:var(--font-size-sm);border:1px solid}.alert svg{width:16px;height:16px;flex-shrink:0;margin-top:1px}.alert-info{background:var(--color-info-bg);border-color:var(--color-info-border);color:var(--color-info)}.alert-success{background:var(--color-success-bg);border-color:var(--color-success-border);color:var(--color-success)}.alert-warning{background:var(--color-warning-bg);border-color:var(--color-warning-border);color:var(--color-warning)}.alert-error{background:var(--color-error-bg);border-color:var(--color-error-border);color:var(--color-error)}.filter-bar{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--color-border-light);flex-wrap:wrap}.filter-select{height:34px;padding:0 10px;border:1.5px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-primary);background:#fff;cursor:pointer;font-family:var(--font-family)}.filter-select:focus{border-color:var(--color-primary);outline:none}.filter-date{height:34px;padding:0 10px;border:1.5px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-family:var(--font-family)}.filter-date:focus{border-color:var(--color-primary);outline:none}.doc-group{border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;margin-bottom:var(--spacing-md);background:var(--color-white);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition-fast)}.doc-group:hover{box-shadow:var(--shadow-md)}.doc-group-header{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-sm);padding:12px var(--spacing-md);background:var(--color-surface-2);border-bottom:1px solid var(--color-border);border-left:4px solid var(--color-text-muted);-webkit-user-select:none;user-select:none}.doc-group-title{font-size:var(--font-size-md);font-weight:700;color:var(--color-text-primary);display:flex;align-items:center;gap:var(--spacing-sm)}.doc-group-count{flex-shrink:0;font-size:var(--font-size-xs);font-weight:700;padding:2px 10px;border-radius:var(--radius-full);background:var(--color-white);color:var(--color-text-secondary);border:1px solid var(--color-border)}.doc-group--todo .doc-group-header{border-left-color:var(--color-text-muted);background:var(--color-surface-2)}.doc-group--todo .doc-group-count{color:var(--color-text-secondary);border-color:var(--color-border)}.doc-group--done .doc-group-header{border-left-color:var(--color-success);background:var(--color-success-bg)}.doc-group--done .doc-group-count{background:var(--color-success);color:var(--color-white);border-color:var(--color-success)}.doc-group-meta{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.doc-group-body{padding:4px var(--spacing-md);background:var(--color-white)}.doc-item{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-sm);padding:12px 8px;margin:0 -8px;border-radius:var(--radius-md);border-bottom:1px solid var(--color-border-light);flex-wrap:wrap;row-gap:var(--spacing-sm);transition:background var(--transition-fast)}.doc-item:hover{background:var(--color-surface-2)}.doc-item:last-child{border-bottom:none}.doc-item-notes{flex-basis:100%;width:100%}.steps{display:flex;align-items:center;gap:0;margin-bottom:var(--spacing-lg)}.step-item{display:flex;align-items:center;gap:var(--spacing-sm);flex:1}.step-item:last-child{flex:none}.step-circle{width:28px;height:28px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex-shrink:0;border:2px solid var(--color-border);background:#fff;color:var(--color-text-muted)}.step-circle.active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.step-circle.done{background:var(--color-success);border-color:var(--color-success);color:#fff}.step-label{font-size:13px;font-weight:600;color:var(--color-text-muted);white-space:nowrap}.step-label.active{color:var(--color-primary)}.step-label.done{color:var(--color-success)}.step-connector{flex:1;height:2px;background:var(--color-border);margin:0 var(--spacing-sm)}.step-connector.done{background:var(--color-success)}.avatar{border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-weight:700;flex-shrink:0;color:#fff}.avatar-sm{width:28px;height:28px;font-size:11px}.avatar-md{width:36px;height:36px;font-size:13px}.avatar-lg{width:48px;height:48px;font-size:16px}.avatar-xl{width:72px;height:72px;font-size:22px}.toggle-switch{position:relative;display:inline-block;width:42px;height:24px}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;top:0;right:0;bottom:0;left:0;background:var(--color-border);border-radius:var(--radius-full);transition:all var(--transition-normal)}.toggle-slider:before{content:"";position:absolute;width:18px;height:18px;left:3px;top:3px;background:#fff;border-radius:var(--radius-full);transition:all var(--transition-normal);box-shadow:var(--shadow-sm)}.toggle-switch input:checked+.toggle-slider{background:var(--color-primary)}.toggle-switch input:checked+.toggle-slider:before{transform:translate(18px)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-2xl) var(--spacing-lg);text-align:center}.empty-state-icon{width:64px;height:64px;background:var(--color-surface);border-radius:var(--radius-xl);display:flex;align-items:center;justify-content:center;margin-bottom:var(--spacing-md);color:var(--color-text-muted)}.empty-state-icon svg{width:32px;height:32px}.empty-state-title{font-size:var(--font-size-lg);font-weight:700;color:var(--color-text-primary);margin-bottom:var(--spacing-xs)}.empty-state-desc{font-size:var(--font-size-base);color:var(--color-text-secondary);max-width:360px;margin-bottom:var(--spacing-md)}.split-pane{display:grid;grid-template-columns:360px 1fr;gap:0;height:calc(100vh - var(--header-height) - 120px)}.split-pane-left{border-right:1px solid var(--color-border);overflow-y:auto}.split-pane-right{overflow-y:auto}.approval-item{padding:var(--spacing-md);border-bottom:1px solid var(--color-border-light);cursor:pointer;transition:background var(--transition-fast)}.approval-item:hover{background:var(--color-surface)}.approval-item.active{background:var(--color-primary-light)}.approval-item-header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--spacing-sm);margin-bottom:4px}.approval-item-code{font-size:var(--font-size-sm);font-weight:700;color:var(--color-text-primary)}.approval-item-time{font-size:var(--font-size-xs);color:var(--color-text-muted)}.approval-item-partner{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.signature-preview{border:2px dashed var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-md);display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100px;background:var(--color-surface)}.signature-name{font-style:italic;font-size:20px;font-weight:600;color:var(--color-primary);font-family:Georgia,serif}.signature-info{font-size:var(--font-size-xs);color:var(--color-text-secondary);text-align:center;margin-top:4px}.invoice-preview{background:#fff;padding:var(--spacing-lg);font-size:13px;line-height:1.6;position:relative}.invoice-watermark{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) rotate(-30deg);font-size:80px;font-weight:900;color:#0000000a;white-space:nowrap;pointer-events:none;-webkit-user-select:none;user-select:none;letter-spacing:.05em}.invoice-title{text-align:center;font-size:18px;font-weight:800;color:var(--color-primary);text-transform:uppercase;letter-spacing:.05em}.invoice-subtitle{text-align:center;font-size:11px;color:var(--color-text-muted);margin-bottom:var(--spacing-sm)}.invoice-meta{text-align:right;font-size:11px;color:var(--color-text-secondary);margin-bottom:var(--spacing-md)}.invoice-party{margin-bottom:var(--spacing-md)}.invoice-party-title{font-size:11px;font-weight:800;text-transform:uppercase;color:var(--color-text-primary);border-bottom:1.5px solid var(--color-text-primary);padding-bottom:4px;margin-bottom:var(--spacing-sm)}.invoice-table{width:100%;border-collapse:collapse;margin:var(--spacing-md) 0;font-size:12px}.invoice-table th,.invoice-table td{border:1px solid var(--color-border);padding:6px 10px}.invoice-table th{background:var(--color-surface);font-weight:700;text-align:center;font-size:11px}.invoice-total{display:flex;flex-direction:column;align-items:flex-end;gap:4px;margin-top:var(--spacing-sm)}.invoice-total-row{display:flex;gap:var(--spacing-lg);font-size:12px}.invoice-total-label{color:var(--color-text-secondary)}.invoice-total-value{font-weight:600;min-width:140px;text-align:right}.invoice-total-row.final .invoice-total-value{color:var(--color-primary);font-size:14px;font-weight:800}.login-page{min-height:100vh;background:linear-gradient(135deg,#f5f6fa,#fafaff);display:flex;align-items:center;justify-content:center;padding:var(--spacing-md);position:relative;overflow:hidden}.login-bg-blob-1{position:absolute;top:-10%;left:-5%;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(191,0,39,.06) 0%,transparent 70%);pointer-events:none;animation:float1 20s ease-in-out infinite}.login-bg-blob-2{position:absolute;bottom:-10%;right:-5%;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(37,99,235,.05) 0%,transparent 70%);pointer-events:none;animation:float2 25s ease-in-out infinite}@keyframes float1{0%,to{transform:translateY(0) scale(1)}50%{transform:translateY(-30px) scale(1.05)}}@keyframes float2{0%,to{transform:translateY(0) scale(1)}50%{transform:translateY(30px) scale(.95)}}.login-card{background:#fff;border-radius:20px;box-shadow:0 20px 60px #0000001a;width:100%;max-width:1000px;display:flex;overflow:hidden;position:relative;z-index:1}.login-left{flex:1;background:linear-gradient(145deg,#0d0d1a,#1a0a10 40%,#0d0d1a);padding:48px;display:flex;flex-direction:column;position:relative;overflow:hidden}.login-left-pattern{position:absolute;top:0;right:0;bottom:0;left:0;background-image:repeating-linear-gradient(45deg,rgba(255,255,255,.01) 0px,rgba(255,255,255,.01) 1px,transparent 1px,transparent 40px);pointer-events:none}.login-left-glow{position:absolute;width:300px;height:300px;border-radius:50%;background:#bf002726;filter:blur(80px);top:-50px;right:-50px;pointer-events:none}.login-logo{display:flex;align-items:center;margin-bottom:var(--spacing-xl);background:#fff;border-radius:var(--radius-md);padding:8px 12px;display:inline-flex}.login-logo-icon{width:42px;height:42px;background:var(--color-primary);border-radius:10px;display:flex;align-items:center;justify-content:center}.login-logo-icon svg{color:#fff;width:22px;height:22px}.login-logo-text{font-size:22px;font-weight:800;color:#fff;letter-spacing:-.02em}.login-heading{font-size:26px;font-weight:800;color:#fff;line-height:1.3;letter-spacing:-.02em;margin-bottom:var(--spacing-md)}.login-desc{font-size:14px;color:#ffffff80;line-height:1.7;max-width:360px}.login-features{margin-top:auto;display:flex;gap:var(--spacing-lg)}.login-feature{display:flex;align-items:center;gap:8px;color:#ffffff80;font-size:12px}.login-feature svg{width:16px;height:16px;flex-shrink:0}.login-right{width:440px;padding:48px 40px;display:flex;flex-direction:column;justify-content:center}.login-title{font-size:26px;font-weight:800;color:var(--color-text-primary);margin-bottom:6px;letter-spacing:-.02em}.login-subtitle{font-size:14px;color:var(--color-text-secondary);margin-bottom:var(--spacing-xl)}.login-form{display:flex;flex-direction:column;gap:var(--spacing-md)}.login-footer-link{text-align:center;margin-top:var(--spacing-lg);padding-top:var(--spacing-md);border-top:1px solid var(--color-border-light);font-size:var(--font-size-sm);color:var(--color-text-secondary)}.login-copyright{text-align:center;margin-top:var(--spacing-md);font-size:var(--font-size-xs);color:var(--color-text-muted)}.dashboard-grid{display:grid;grid-template-columns:1fr 320px;gap:var(--spacing-lg)}.activity-list{display:flex;flex-direction:column;gap:0}.activity-item{display:flex;gap:var(--spacing-sm);padding:10px 0;border-bottom:1px solid var(--color-border-light)}.activity-item:last-child{border-bottom:none}.activity-dot{width:8px;height:8px;border-radius:var(--radius-full);background:var(--color-primary);flex-shrink:0;margin-top:6px}.activity-title{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-primary);line-height:1.3}.activity-meta{font-size:var(--font-size-xs);color:var(--color-text-muted);margin-top:2px}.chart-legend{display:flex;flex-direction:column;gap:8px}.legend-item{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-sm)}.legend-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.legend-label{flex:1;font-size:var(--font-size-sm);color:var(--color-text-secondary)}.legend-value{font-size:var(--font-size-sm);font-weight:700;color:var(--color-text-primary)}.approval-detail-card{background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-lg);margin:var(--spacing-md)}.approval-detail-header{padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--color-border-light);display:flex;align-items:center;gap:var(--spacing-sm)}.approval-detail-body{padding:var(--spacing-lg)}.detail-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.detail-info-label{font-size:var(--font-size-xs);font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:2px}.detail-info-value{font-size:var(--font-size-base);font-weight:600;color:var(--color-text-primary)}.detail-info-value.highlight{color:var(--color-primary);font-size:18px;font-weight:800}.req-detail-title{display:flex;align-items:center;flex-wrap:wrap;gap:var(--spacing-sm)}.req-detail-code{font-size:var(--font-size-3xl);font-weight:800;color:var(--color-text-primary);letter-spacing:-.02em;line-height:1.15}.req-status-pill{font-size:var(--font-size-sm);padding:4px 12px}.req-detail-subtitle{margin-top:6px;max-width:720px;font-size:var(--font-size-base);color:var(--color-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.req-meta-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--spacing-md);margin-bottom:var(--spacing-md)}.req-meta-card{background:var(--color-white);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-md)}.req-meta-card-label{font-size:var(--font-size-xs);font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:4px}.req-meta-card-value{font-size:var(--font-size-lg);font-weight:700;color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.req-meta-card-value.accent{color:var(--color-primary)}.req-meta-card-value.amber{color:var(--color-warning)}.req-meta-card-value.muted{color:var(--color-text-muted);font-weight:600}.req-approval-status{display:flex;align-items:center;flex-wrap:wrap;gap:var(--spacing-sm);padding:10px var(--spacing-md);border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-surface-2);font-size:var(--font-size-base);margin-bottom:var(--spacing-md)}.req-approval-status .req-approval-icon{flex-shrink:0;display:inline-flex}.req-approval-status.warning{background:var(--color-warning-bg);border-color:var(--color-warning-border);color:var(--color-warning)}.req-approval-status.success{background:var(--color-success-bg);border-color:var(--color-success-border);color:var(--color-success)}.req-approval-divider{width:1px;align-self:stretch;background:var(--color-border);margin:0 2px}@media(max-width:1100px){.req-meta-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:560px){.req-meta-grid{grid-template-columns:1fr}}.connection-card{background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg);margin-bottom:var(--spacing-md)}.connection-status{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;padding:4px 10px;border-radius:var(--radius-full)}.connection-status.connected{background:var(--color-success-bg);color:var(--color-success)}.connection-status.disconnected{background:var(--color-error-bg);color:var(--color-error)}.connection-info-row{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--color-border-light);font-size:13px}.connection-info-row:last-of-type{border-bottom:none}.connection-info-label{color:var(--color-text-secondary)}.connection-info-value{font-weight:500;color:var(--color-text-primary)}@media(max-width:1280px){.dashboard-grid{grid-template-columns:1fr 280px}}@media(max-width:1100px){.kpi-grid{grid-template-columns:repeat(3,1fr)}.split-pane{grid-template-columns:320px 1fr}}@media(max-width:1024px){:root{--sidebar-width: 220px}.dashboard-grid{grid-template-columns:1fr}.form-row-3{grid-template-columns:1fr 1fr}.login-right{width:400px;padding:40px 32px}}@media(max-width:900px){.split-pane{grid-template-columns:1fr;height:auto}.split-pane-left{border-right:none;border-bottom:1px solid var(--color-border);max-height:300px;overflow-y:auto}}@media(max-width:768px){:root{--sidebar-width: 0px}.sidebar{transform:translate(-240px);width:240px}.sidebar.mobile-open{transform:translate(0);box-shadow:var(--shadow-xl)}.main-wrapper{margin-left:0}.page-content{padding:var(--spacing-md)}.kpi-grid{grid-template-columns:1fr 1fr}.header{padding:0 var(--spacing-md)}.form-row,.form-row-3{grid-template-columns:1fr}.page-header{flex-direction:column;align-items:flex-start}.detail-info-grid{grid-template-columns:1fr}.login-card{flex-direction:column}.login-left{padding:32px;min-height:200px}.login-right{width:100%;padding:32px}.user-info{display:none}.sidebar-mobile-toggle{display:flex}}@media(max-width:480px){.kpi-grid{grid-template-columns:1fr}.filter-bar{flex-direction:column;align-items:stretch}.filter-select,.filter-date{width:100%}.login-left{display:none}.login-card{border-radius:var(--radius-lg)}}.sidebar-mobile-toggle{display:none;width:36px;height:36px;align-items:center;justify-content:center;border-radius:var(--radius-md);cursor:pointer;color:var(--color-text-secondary);border:none;background:none}.sidebar-mobile-toggle svg{width:20px;height:20px}.sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#0000004d;z-index:calc(var(--z-sidebar) - 1)}.sidebar-overlay.visible{display:block}.text-primary{color:var(--color-primary)}.text-success{color:var(--color-success)}.text-warning{color:var(--color-warning)}.text-error{color:var(--color-error)}.text-muted{color:var(--color-text-muted)}.text-secondary{color:var(--color-text-secondary)}.font-bold{font-weight:700}.font-semibold{font-weight:600}.font-medium{font-weight:500}.text-sm{font-size:var(--font-size-sm)}.text-xs{font-size:var(--font-size-xs)}.text-lg{font-size:var(--font-size-lg)}.text-xl{font-size:var(--font-size-xl)}.mt-sm{margin-top:var(--spacing-sm)}.mt-md{margin-top:var(--spacing-md)}.mt-lg{margin-top:var(--spacing-lg)}.mb-sm{margin-bottom:var(--spacing-sm)}.mb-md{margin-bottom:var(--spacing-md)}.mb-lg{margin-bottom:var(--spacing-lg)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-sm{gap:var(--spacing-sm)}.gap-md{gap:var(--spacing-md)}.w-full{width:100%}.min-w-0{min-width:0}.flex-1{flex:1}.flex-shrink-0{flex-shrink:0}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cursor-pointer{cursor:pointer}.hidden{display:none}.divider{height:1px;background:var(--color-border-light);margin:var(--spacing-md) 0}.detail-info-grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:var(--spacing-md) var(--spacing-lg);margin-bottom:var(--spacing-md)}@media(max-width:1024px){.detail-info-grid-3{grid-template-columns:1fr 1fr}}@media(max-width:640px){.detail-info-grid-3{grid-template-columns:1fr}}.section-header-collapsible{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) 0;margin-bottom:var(--spacing-md);color:var(--color-primary);font-weight:700;font-size:var(--font-size-md);border-bottom:2px solid var(--color-primary);cursor:pointer;-webkit-user-select:none;user-select:none;background:none;border-top:none;border-left:none;border-right:none;width:100%;text-align:left}.section-header-collapsible .chevron{display:inline-flex;transition:transform var(--transition-fast)}.section-header-collapsible.collapsed .chevron{transform:rotate(-90deg)}.pill-link{color:var(--color-text-link);text-decoration:none;font-weight:600}.pill-link:hover{text-decoration:underline}.sticky-save-bar{position:sticky;bottom:0;left:0;right:0;z-index:50;display:flex;align-items:center;justify-content:flex-end;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);background:#fff;border-top:1px solid var(--color-border);box-shadow:0 -4px 12px #0000000d;margin-top:var(--spacing-lg)}.sticky-save-bar .dirty-indicator{margin-right:auto;font-size:var(--font-size-sm);color:var(--color-warning);font-weight:600}.radio-group{display:flex;gap:var(--spacing-md);align-items:center;padding:8px 0}.radio-group label{display:inline-flex;align-items:center;gap:6px;cursor:pointer;font-size:var(--font-size-base)}.radio-group input[type=radio]{accent-color:var(--color-primary)}
