body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0}code{font-family:JetBrains Mono,Fira Code,Cascadia Code,Consolas,monospace}:root{--primary:#2563eb;--secondary:#64748b;--success:#16a34a;--warning:#d97706;--danger:#dc2626;--info:#0ea5e9;--bg-primary:#fff;--bg-secondary:#f8fafc;--bg-tertiary:#f1f5f9;--bg-gradient:linear-gradient(135deg,#f8fafc,#e2e8f0);--table-header-bg:#e0ebf7;--table-header-text:#1e3a8a;--table-header-border:#cbd5e1;--modal-header-bg:#f0f7ff;--modal-footer-bg:#f8fafc;--text-primary:#1e293b;--text-secondary:#64748b;--text-muted:#94a3b8;--text-disabled:#cbd5e1;--border-color:#e2e8f0cc;--border-light:#e2e8f080;--glass-bg:#fffffff2;--shadow-sm:0 1px 2px 0 #0000000d;--shadow:0 2px 8px #00000014;--shadow-md:0 4px 12px #0000001f;--shadow-lg:0 8px 24px #00000029;--shadow-xl:0 25px 50px -12px #0006;--accent-gradient:linear-gradient(135deg,#2563eb,#0ea5e9);--accent-gradient-hover:linear-gradient(135deg,#1d4ed8,#0284c7);--spacing-xs:0.25rem;--spacing-sm:0.5rem;--spacing-md:0.625rem;--spacing-lg:0.875rem;--spacing-xl:1.25rem;--radius-sm:0.375rem;--radius:0.5rem;--radius-md:0.75rem;--radius-lg:1rem;--transition-fast:0.15s ease;--transition:0.2s ease;--transition-slow:0.3s ease;--z-table-content:1;--z-action-column-body:2;--z-table-header:10;--z-action-column-header:20;--z-dropdown:1000;--z-module-header:100;--z-main-layout-dropdown:1030;--z-fixed:1040;--z-active-row:10005;--z-modal-backdrop:10040;--z-modal:10050;--z-action-menu:10100;--font-family-base:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;--font-family-mono:"JetBrains Mono","Fira Code","Cascadia Code",Consolas,monospace;--font-size-xs:0.75rem;--font-size-sm:0.8125rem;--font-size-base:0.875rem;--font-size-md:0.9375rem;--font-size-lg:1.0625rem;--font-size-xl:1.25rem;--line-height-tight:1.3;--line-height-base:1.5;--line-height-relaxed:1.6;--layout-header-height:3rem;--layout-footer-height:2rem;--layout-tabbar-height:2.5rem;--layout-sidebar-width:16rem;--layout-sidebar-collapsed-width:4rem}[data-theme=dark]{--bg-primary:#0f172a;--bg-secondary:#1e293b;--bg-tertiary:#334155;--bg-gradient:linear-gradient(135deg,#0f172a,#1e293b);--table-header-bg:#1e3a5f;--table-header-text:#e8eef7;--table-header-border:#475569;--modal-header-bg:#1e3a5f;--modal-footer-bg:#1e293b;--text-primary:#f1f5f9;--text-secondary:#cbd5e1;--text-muted:#64748b;--border-color:#47556980;--glass-bg:#0f172af2}*{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{color:#1e293b;color:var(--text-primary);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font-family-base);font-size:.875rem;font-size:var(--font-size-base);line-height:1.5;line-height:var(--line-height-base);overflow-x:hidden}.module-master-container,body{background:linear-gradient(135deg,#f8fafc,#e2e8f0);background:var(--bg-gradient)}.module-master-container{display:flex;flex-direction:column;height:100%;min-height:0;overflow:hidden}.module-header{align-items:center;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#fffffff2;background:var(--glass-bg);border:1px solid #e2e8f080;border:1px solid var(--border-light);border-radius:.75rem;border-radius:var(--radius-md);box-shadow:0 2px 8px #00000014;box-shadow:var(--shadow);display:flex;flex-shrink:0;flex-wrap:wrap;gap:.875rem;gap:var(--spacing-lg);justify-content:space-between;margin:.625rem 1.25rem 1.25rem;margin:var(--spacing-md) 1.25rem 1.25rem 1.25rem;min-height:2.75rem;padding:.875rem 1.5rem;position:-webkit-sticky;position:sticky;top:0;z-index:100;z-index:var(--z-module-header)}.module-header-content{display:flex;flex-direction:column;gap:.125rem}.module-title{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#2563eb,#0ea5e9);background:var(--accent-gradient);-webkit-background-clip:text;background-clip:text;font-size:1.0625rem;font-size:var(--font-size-lg);font-weight:700;line-height:1.2;margin:0}.module-description{color:#64748b;color:var(--text-secondary);font-size:.75rem;font-size:var(--font-size-xs);margin:0}.module-toolbar{align-items:center;display:flex;flex-wrap:wrap;gap:.5rem;gap:var(--spacing-sm)}.toolbar-separator{background:#e2e8f0cc;background:var(--border-color);height:1.5rem;margin:0 .25rem;width:1px}.view-mode-group{background:#fff;background:var(--bg-primary);border:1px solid #e2e8f0cc;border:1px solid var(--border-color);border-radius:.375rem;border-radius:var(--radius-sm);gap:.125rem;padding:.125rem}.view-mode-btn,.view-mode-group{align-items:center;display:inline-flex}.view-mode-btn{background:#0000;border:none;border-radius:.375rem;border-radius:var(--radius-sm);color:#64748b;color:var(--text-secondary);cursor:pointer;height:2rem;justify-content:center;padding:0;position:relative;transition:all .2s ease;transition:all var(--transition);width:2rem}.view-mode-btn:hover{background:#f8fafc;background:var(--bg-secondary);color:#1e293b;color:var(--text-primary)}.view-mode-btn.active{background:#2563eb;background:var(--primary);box-shadow:0 1px 3px #2563eb4d;color:#fff}.view-mode-btn svg{height:16px;width:16px}.view-mode-btn:after{background:#1e293b;background:var(--text-primary);border-radius:.375rem;border-radius:var(--radius-sm);bottom:calc(100% + .5rem);color:#fff;content:attr(data-tooltip);font-size:.7rem;font-weight:500;left:50%;opacity:0;padding:.375rem .625rem;pointer-events:none;position:absolute;transform:translateX(-50%);transition:opacity .2s ease;transition:opacity var(--transition);white-space:nowrap;z-index:1000}.view-mode-btn:hover:after{opacity:1}.module-content{display:flex;flex:1 1;gap:0;min-height:0;overflow:hidden;padding-top:.5rem;position:relative;transition:all .3s ease;transition:all var(--transition-slow)}.search-input-wrapper{align-items:center;display:flex;min-width:250px;position:relative}.search-input-wrapper svg{color:#94a3b8;color:var(--text-muted);left:.625rem;pointer-events:none;position:absolute;z-index:1}.search-input{background:#fff;background:var(--bg-primary);border:1px solid #e2e8f0cc;border:1px solid var(--border-color);border-radius:.375rem;border-radius:var(--radius-sm);color:#1e293b;color:var(--text-primary);font-family:inherit;font-size:.8125rem;font-size:var(--font-size-sm);padding:.5rem .75rem .5rem 2.25rem;transition:all .2s ease;transition:all var(--transition);width:100%}.search-input:focus{border-color:#2563eb;border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a;outline:none}.search-input::placeholder{color:#94a3b8;color:var(--text-muted)}.data-grid-container{display:flex;flex:1 1;flex-direction:column;min-height:0;min-width:0;padding:0 0 1rem;position:relative;transition:all .3s ease;transition:all var(--transition-slow)}.layout-body.footer-hidden .data-grid-container{padding-bottom:0}.action-menu-container{display:inline-block;position:relative}.action-menu-trigger{align-items:center;background:#fff;background:var(--bg-primary);border:1px solid #e2e8f0cc;border:1px solid var(--border-color);border-radius:.375rem;border-radius:var(--radius-sm);color:#64748b;color:var(--text-secondary);cursor:pointer;display:inline-flex;height:1.875rem;justify-content:center;padding:0;position:relative;transition:all .2s ease;transition:all var(--transition);width:1.875rem;z-index:1}.action-menu-trigger:hover{background:#f8fafc;background:var(--bg-secondary);border-color:#2563eb;border-color:var(--primary);color:#2563eb;color:var(--primary)}.action-menu-trigger.active{background:#2563eb;background:var(--primary);border-color:#2563eb;border-color:var(--primary);color:#fff;z-index:10102;z-index:calc(var(--z-action-menu) + 2)}.action-menu-trigger svg{height:16px;width:16px}.action-menu-dropdown{animation:slideDown .2s ease;animation:slideDown var(--transition);background:#fff;background:var(--bg-primary);border:2px solid #2563eb;border:2px solid var(--primary);border-radius:.75rem;border-radius:var(--radius-md);box-shadow:0 12px 32px #2563eb33;max-height:280px;min-width:180px;overflow-y:auto;padding:.5rem;position:absolute;right:0;top:calc(100% + .5rem);z-index:10100;z-index:var(--z-action-menu)}@media (max-width:768px){.action-menu-dropdown{animation:slideUp .2s ease;border-radius:1rem;border-radius:var(--radius-lg);bottom:1rem;box-shadow:0 -4px 32px #0003;left:1rem;max-height:60vh;min-width:auto;position:fixed;right:1rem;top:auto}.action-menu-item{font-size:.95rem;padding:.875rem 1rem}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.action-menu-item{align-items:center;background:#0000;border:none;border-radius:.5rem;border-radius:var(--radius);color:#1e293b;color:var(--text-primary);cursor:pointer;display:flex;font-family:inherit;font-size:.8125rem;font-size:var(--font-size-sm);font-weight:500;gap:.75rem;padding:.625rem .875rem;text-align:left;transition:all .2s cubic-bezier(.4,0,.2,1);white-space:nowrap;width:100%}.action-menu-item:hover{background:#f8fafc;background:var(--bg-secondary);color:#2563eb;color:var(--primary);padding-left:1rem;transform:translateX(4px)}.action-menu-item svg{flex-shrink:0;height:18px;transition:transform .2s ease;transition:transform var(--transition);width:18px}.action-menu-item:hover svg{transform:scale(1.15)}.action-menu-item-danger,.action-menu-item-danger:hover{color:#dc2626;color:var(--danger)}.action-menu-item-danger:hover{background:#dc26261a}.action-menu-divider{background:#e2e8f0cc;background:var(--border-color);height:1px;margin:.5rem 0}.btn{align-items:center;border:none;border-radius:.375rem;border-radius:var(--radius-sm);cursor:pointer;display:inline-flex;font-family:inherit;font-size:.8125rem;font-size:var(--font-size-sm);font-weight:600;gap:.5rem;gap:var(--spacing-sm);justify-content:center;padding:.5rem .875rem;padding:var(--spacing-sm) var(--spacing-lg);text-decoration:none;transition:all .2s ease;transition:all var(--transition);-webkit-user-select:none;user-select:none;white-space:nowrap}.btn:disabled{cursor:not-allowed;opacity:.5}.btn-primary{background:#2563eb;background:var(--primary);box-shadow:0 2px 8px #00000014;box-shadow:var(--shadow);color:#fff}.btn-primary:hover:not(:disabled){background:#1d4ed8;box-shadow:0 4px 12px #0000001f;box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-secondary{background:#fff;background:var(--bg-primary);border:1.5px solid #e2e8f0cc;border:1.5px solid var(--border-color);color:#1e293b;color:var(--text-primary)}.btn-secondary:hover:not(:disabled){background:#f8fafc;background:var(--bg-secondary);border-color:#2563eb;border-color:var(--primary);color:#2563eb;color:var(--primary)}.btn-danger{background:#dc2626;background:var(--danger);box-shadow:0 2px 8px #00000014;box-shadow:var(--shadow);color:#fff}.btn-danger:hover:not(:disabled){background:#b91c1c;box-shadow:0 4px 12px #0000001f;box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-success{background:#16a34a;background:var(--success);box-shadow:0 2px 8px #00000014;box-shadow:var(--shadow);color:#fff}.btn-success:hover:not(:disabled){background:#15803d;box-shadow:0 4px 12px #0000001f;box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-icon{align-items:center;background:#fff;background:var(--bg-primary);border:1px solid #e2e8f0cc;border:1px solid var(--border-color);border-radius:.375rem;border-radius:var(--radius-sm);color:#64748b;color:var(--text-secondary);cursor:pointer;display:inline-flex;height:2rem;justify-content:center;padding:0;transition:all .2s ease;transition:all var(--transition);width:2rem}.btn-icon:hover{background:#f8fafc;background:var(--bg-secondary);border-color:#2563eb;border-color:var(--primary);color:#2563eb;color:var(--primary);transform:translateY(-1px)}.btn-icon svg{stroke-width:2;height:18px;width:18px}.search-panel{background:#fff;background:var(--bg-primary);border-left:1px solid #e2e8f0cc;border-left:1px solid var(--border-color);box-shadow:-4px 0 12px #00000014;display:flex;flex-direction:column;flex-shrink:0;height:100%;overflow:hidden;transition:all .3s ease;transition:all var(--transition-slow);width:320px}.search-panel.collapsed{border-left:none;box-shadow:none;width:0}.search-panel-header{align-items:center;background:#e0ebf7;background:var(--table-header-bg);border-bottom:1px solid #e2e8f0cc;border-bottom:1px solid var(--border-color);display:flex;flex-shrink:0;justify-content:space-between;padding:.875rem 1.25rem;padding:var(--spacing-lg) 1.25rem}.search-panel-title{color:#1e3a8a;color:var(--table-header-text);font-size:.9375rem;font-size:var(--font-size-md);font-weight:600;margin:0}.search-panel-close{align-items:center;background:#fff;background:var(--bg-primary);border:1px solid #e2e8f0cc;border:1px solid var(--border-color);border-radius:.375rem;border-radius:var(--radius-sm);color:#94a3b8;color:var(--text-muted);cursor:pointer;display:flex;flex-shrink:0;height:1.75rem;justify-content:center;transition:all .2s ease;transition:all var(--transition);width:1.75rem}.search-panel-close:hover{background:#dc2626;background:var(--danger,#ef4444);border-color:#dc2626;border-color:var(--danger,#ef4444);color:#fff}.search-panel-content{flex:1 1;min-height:0;overflow-y:auto;padding:1.25rem}.filter-section{margin-bottom:1.25rem}.filter-section:last-child{margin-bottom:0}.filter-section-title{color:#64748b;color:var(--text-secondary);font-size:.75rem;font-size:var(--font-size-xs);font-weight:600;letter-spacing:.05em;margin-bottom:.625rem;text-transform:uppercase}.filter-actions{background:#f8fafc;background:var(--bg-secondary);border-top:1px solid #e2e8f0cc;border-top:1px solid var(--border-color);display:flex;flex-shrink:0;gap:.625rem;padding:.875rem 1.25rem;padding:var(--spacing-lg) 1.25rem}.filter-actions .btn{flex:1 1}.pagination-footer{align-items:center;background:#fff;background:var(--bg-primary);border-radius:0 0 .75rem .75rem;border-radius:0 0 var(--radius-md) var(--radius-md);border-top:1px solid #e2e8f0cc;border-top:1px solid var(--border-color);display:flex;flex-shrink:0;flex-wrap:wrap;gap:.625rem;gap:var(--spacing-md);justify-content:space-between;margin:0;padding:.625rem .875rem;padding:.625rem var(--spacing-lg)}.pagination-info{color:#64748b;color:var(--text-secondary);font-size:.75rem;font-size:var(--font-size-xs)}.pagination-controls{align-items:center;display:flex;gap:.25rem}.page-btn{align-items:center;background:#fff;background:var(--bg-primary);border:1px solid #e2e8f0cc;border:1px solid var(--border-color);border-radius:.375rem;border-radius:var(--radius-sm);cursor:pointer;display:inline-flex;font-family:inherit;font-size:.75rem;font-size:var(--font-size-xs);height:2rem;justify-content:center;min-width:2rem;padding:0 .5rem;transition:all .15s ease;transition:all var(--transition-fast)}.page-btn:hover:not(:disabled){background:#f8fafc;background:var(--bg-secondary);color:#2563eb;color:var(--primary)}.page-btn.active,.page-btn:hover:not(:disabled){border-color:#2563eb;border-color:var(--primary)}.page-btn.active{background:#2563eb;background:var(--primary);color:#fff}.page-btn:disabled{cursor:not-allowed;opacity:.5}.page-size-selector select{background:#fff;background:var(--bg-primary);border:1px solid #e2e8f0cc;border:1px solid var(--border-color);border-radius:.375rem;border-radius:var(--radius-sm);cursor:pointer;font-family:inherit;font-size:.75rem;font-size:var(--font-size-xs);padding:.375rem .625rem}.form-group{margin-bottom:.875rem;margin-bottom:var(--spacing-lg)}.form-label{color:#1e293b;color:var(--text-primary);display:block;font-size:.75rem;font-size:var(--font-size-xs);font-weight:600;margin-bottom:.375rem}.form-input,.form-select,.form-textarea{background:#fff;background:var(--bg-primary);border:1px solid #e2e8f0cc;border:1px solid var(--border-color);border-radius:.375rem;border-radius:var(--radius-sm);color:#1e293b;color:var(--text-primary);font-family:inherit;font-size:.8125rem;font-size:var(--font-size-sm);padding:.5rem .75rem;transition:all .2s ease;transition:all var(--transition);width:100%}input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}input[type=number]{-moz-appearance:textfield}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:#2563eb;border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a;outline:none}.form-textarea{min-height:80px;resize:vertical}.checkbox-label{align-items:center;color:#1e293b;color:var(--text-primary);cursor:pointer;display:flex;font-size:.8rem;gap:.5rem;margin-bottom:.5rem}.checkbox-label input[type=checkbox],.checkbox-label input[type=radio]{accent-color:#2563eb;accent-color:var(--primary);cursor:pointer;height:16px;width:16px}.syut-select-container{display:flex;flex-direction:column;gap:.375rem}.syut-select-label{color:#1e293b;color:var(--text-primary);display:block;font-size:.75rem;font-size:var(--font-size-xs);font-weight:600}.syut-select-required{margin-left:.25rem}.syut-select-error,.syut-select-required{color:#dc2626;color:var(--danger,#ef4444)}.syut-select-error,.syut-select-helper{font-size:.75rem;font-size:var(--font-size-xs)}.syut-select-helper{color:#94a3b8;color:var(--text-muted)}.syut-select__control,.syut-select__menu{border-radius:.375rem!important;border-radius:var(--radius-sm)!important;font-family:inherit!important}.syut-select__option--is-focused{background:#f8fafc!important;background:var(--bg-secondary)!important}.syut-select__option--is-selected{background:#2563eb!important;background:var(--primary)!important}.badge{align-items:center;border-radius:.375rem;border-radius:var(--radius-sm);display:inline-flex;font-size:.75rem;font-size:var(--font-size-xs);font-weight:600;gap:.25rem;letter-spacing:.025em;padding:.1875rem .4375rem;text-transform:uppercase;white-space:nowrap}.badge-active{background:#16a34a1a;color:#16a34a;color:var(--success)}.badge-inactive{background:#64748b1a;color:#64748b;color:var(--secondary)}.badge-pending{background:#d977061a;color:#d97706;color:var(--warning)}.badge-error{background:#dc26261a;color:#dc2626;color:var(--danger)}.modal-backdrop{animation:fadeIn .2s ease;animation:fadeIn var(--transition);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;inset:0;position:fixed;z-index:10040;z-index:var(--z-modal-backdrop)}.modal-container{animation:modalSlideUp .3s ease;animation:modalSlideUp var(--transition-slow);background:#fff;background:var(--bg-primary);border-radius:1rem;border-radius:var(--radius-lg);box-shadow:0 25px 50px -12px #0006;box-shadow:var(--shadow-xl);display:flex;flex-direction:column;left:50%;max-height:85vh;overflow:hidden;position:fixed;top:50%;transform:translate(-50%,-50%);width:90%;z-index:10050;z-index:var(--z-modal)}.modal-sm{max-width:400px;min-height:280px}.modal-md{max-width:600px;min-height:400px}.modal-lg{max-width:900px;min-height:500px}.modal-header{align-items:center;background:#f0f7ff;background:var(--modal-header-bg);border-bottom:2px solid #e0ebf7;display:flex;flex-shrink:0;justify-content:space-between;min-height:4rem;padding:1.25rem 1.5rem}.modal-title{color:#1e293b;color:var(--text-primary);font-size:1.25rem;font-size:var(--font-size-xl);font-weight:700;margin:0}.modal-close{align-items:center;background:#0000;border:none;border-radius:.375rem;border-radius:var(--radius-sm);color:#64748b;color:var(--text-secondary);cursor:pointer;display:flex;height:2rem;justify-content:center;padding:0;transition:all .2s ease;transition:all var(--transition);width:2rem}.modal-close:hover{background:#f8fafc;background:var(--bg-secondary);color:#dc2626;color:var(--danger)}.modal-tabs{background:#fff;background:var(--bg-primary);border-bottom:1px solid #e2e8f0cc;border-bottom:1px solid var(--border-color);display:flex;gap:.25rem;padding:.75rem 1.5rem 0}.modal-tab{background:#0000;border:none;border-bottom:2px solid #0000;color:#64748b;color:var(--text-secondary);cursor:pointer;font-size:.8125rem;font-size:var(--font-size-sm);font-weight:500;padding:.5rem 1rem;transition:all .2s ease;transition:all var(--transition)}.modal-tab.active,.modal-tab:hover{color:#2563eb;color:var(--primary)}.modal-tab.active{border-bottom-color:#2563eb;border-bottom-color:var(--primary)}.modal-content{background:#fff;background:var(--bg-primary);flex:1 1;min-height:0;overflow-y:auto;padding:1.5rem}.modal-content .syut-select__control{border-color:#334155!important}.modal-footer{align-items:center;background:#f8fafc;background:var(--modal-footer-bg);border-top:2px solid #e2e8f0cc;border-top:2px solid var(--border-color);display:flex;flex-shrink:0;gap:.875rem;justify-content:flex-end;min-height:4.5rem;padding:1.25rem 1.5rem}.modal-footer .btn{font-weight:600;height:2.5rem;min-width:110px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@keyframes modalSlideUp{0%{opacity:0;transform:translate(-50%,-45%)}to{opacity:1;transform:translate(-50%,-50%)}}@media (max-width:768px){.module-header{align-items:stretch;flex-direction:column;gap:.625rem;gap:var(--spacing-md);padding:.625rem .875rem;padding:var(--spacing-md) var(--spacing-lg)}.module-toolbar{flex-wrap:wrap;width:100%}.search-input-wrapper{flex:1 1;min-width:auto}.data-grid-container{display:flex;flex:1 1;height:calc(100% - 20px);min-height:0;overflow:hidden;padding:0 .75rem .75rem;position:relative}.search-panel{bottom:60px;box-shadow:-8px 0 24px #0003;display:flex!important;flex-direction:column!important;height:auto;max-width:320px;overflow:hidden!important;position:absolute;right:0;top:0;width:100%;z-index:1040;z-index:var(--z-fixed)}.search-panel.collapsed{transform:translateX(100%);width:320px}.search-panel-header{flex-shrink:0!important}.search-panel-content{flex:1 1 auto!important;min-height:0!important;overflow-x:hidden!important;overflow-y:auto!important;padding:1.25rem}.filter-actions{background:#f8fafc;background:var(--bg-secondary);box-shadow:0 -4px 12px #00000014;flex-shrink:0!important;z-index:10}.data-table{font-size:.75rem}.data-table tbody td,.data-table thead th{padding:.5rem .375rem}.action-column{width:60px}.pagination-footer{flex-direction:column;gap:.625rem;gap:var(--spacing-md)}.modal-container{max-height:95vh;width:95%}.view-mode-group{justify-content:center;order:-1;width:100%}}::-webkit-scrollbar{height:8px;width:8px}::-webkit-scrollbar-track{background:#f8fafc;background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:#e2e8f0cc;background:var(--border-color);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#94a3b8;background:var(--text-muted)}.text-center{text-align:center}.text-right{text-align:right}.font-bold{font-weight:700}.font-semibold{font-weight:600}.text-sm{font-size:.875rem}.text-xs{font-size:.75rem}.mt-1{margin-top:.25rem;margin-top:var(--spacing-xs)}.mt-2{margin-top:.5rem;margin-top:var(--spacing-sm)}.mt-3{margin-top:.625rem;margin-top:var(--spacing-md)}.mt-4{margin-top:.875rem;margin-top:var(--spacing-lg)}.mb-1{margin-bottom:.25rem;margin-bottom:var(--spacing-xs)}.mb-2{margin-bottom:.5rem;margin-bottom:var(--spacing-sm)}.mb-3{margin-bottom:.625rem;margin-bottom:var(--spacing-md)}.mb-4{margin-bottom:.875rem;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-2{gap:.5rem;gap:var(--spacing-sm)}.gap-3{gap:.625rem;gap:var(--spacing-md)}.gap-4{gap:.875rem;gap:var(--spacing-lg)}.App{text-align:center}.App-logo{height:40vmin;pointer-events:none}@media (prefers-reduced-motion:no-preference){.App-logo{animation:App-logo-spin 20s linear infinite}}.App-header{align-items:center;background-color:#282c34;color:#fff;display:flex;flex-direction:column;font-size:calc(10px + 2vmin);justify-content:center;min-height:100vh}.App-link{color:#61dafb}@keyframes App-logo-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.kfs-page-wrapper{display:flex;flex:1 1;flex-direction:column;gap:.625rem;min-height:0;overflow:hidden;padding:.75rem}.kfs-page-header{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#fffffff2;background:var(--glass-bg,#fffffff2);border:1px solid #e2e8f080;border:1px solid var(--border-light,#e2e8f080);border-radius:12px;border-radius:var(--radius-md,12px);box-shadow:0 2px 8px #00000014;box-shadow:var(--shadow,0 2px 8px #00000014);gap:.75rem;padding:.625rem 1rem}.kfs-header-icon,.kfs-page-header{align-items:center;display:flex;flex-shrink:0}.kfs-header-icon{border-radius:10px;color:#fff;height:36px;justify-content:center;width:36px}.kfs-header-icon,.kfs-header-text h2{background:linear-gradient(135deg,#2563eb,#0ea5e9)}.kfs-header-text h2{-webkit-text-fill-color:#0000;-webkit-background-clip:text;background-clip:text;font-size:.9375rem;font-weight:700;margin:0}.kfs-header-text p{color:#64748b;color:var(--text-secondary,#64748b);font-size:.7rem;margin:1px 0 0}.kfs-card{background:#fff;background:var(--bg-primary,#fff);border:1px solid #e2e8f0cc;border:1px solid var(--border-color,#e2e8f0cc);border-radius:8px;border-radius:var(--radius,8px);box-shadow:0 1px 2px #0000000d;box-shadow:var(--shadow-sm,0 1px 2px #0000000d);display:flex;flex-direction:column;min-height:0;overflow:hidden}.kfs-card-header{background:#f8fafc;background:var(--bg-secondary,#f8fafc);border-bottom:1px solid #e2e8f0cc;border-bottom:1px solid var(--border-color,#e2e8f0cc);gap:.5rem;padding:.5rem .875rem}.kfs-card-header,.kfs-card-header-icon{align-items:center;display:flex;flex-shrink:0}.kfs-card-header-icon{border-radius:6px;font-size:.8125rem;height:26px;justify-content:center;width:26px}.kfs-card-header-icon.blue{background:#2563eb1a;color:#2563eb;color:var(--primary,#2563eb)}.kfs-card-header-icon.green{background:#16a34a1a;color:#16a34a;color:var(--success,#16a34a)}.kfs-card-header-icon.purple{background:#7c3aed1a;color:#7c3aed}.kfs-card-header-icon.amber{background:#d977061a;color:#d97706;color:var(--warning,#d97706)}.kfs-card-header h3{color:#1e293b;color:var(--text-primary,#1e293b);font-size:.8125rem;font-weight:600;margin:0}.kfs-card-header span{color:#94a3b8;color:var(--text-muted,#94a3b8);font-size:.65rem;margin-left:auto}.kfs-card-body{flex:1 1;min-height:0;overflow-y:auto;padding:.75rem}.kfs-content-grid{grid-gap:.625rem;display:grid;flex:1 1;grid-template-columns:1fr 1fr}.kfs-content-grid,.kfs-left-column{gap:.625rem;min-height:0;overflow:hidden}.kfs-left-column{display:flex;flex-direction:column}@media (max-width:1024px){.kfs-page-wrapper{overflow-x:hidden;overflow-y:auto}.kfs-content-grid{flex:none;grid-template-columns:1fr;overflow:visible}.kfs-card,.kfs-left-column{min-height:auto;overflow:visible}.kfs-card-body{overflow:visible}}.kfs-input-grid{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:1fr 1fr}@media (max-width:600px){.kfs-input-grid{grid-template-columns:1fr}}.kfs-field-error{color:#dc2626;color:var(--danger,#dc2626);display:block;font-size:.7rem;font-weight:500;margin-top:4px}.form-input-error{border-color:#dc2626!important;border-color:var(--danger,#dc2626)!important;box-shadow:0 0 0 3px #dc262614!important}.kfs-summary-table{border-collapse:initial;border-spacing:0;font-size:.8125rem;width:100%}.kfs-summary-table th{background:#f8fafc;background:var(--bg-secondary,#f8fafc);border-bottom:2px solid #e2e8f0;border-bottom:2px solid var(--border-color,#e2e8f0);color:#64748b;color:var(--text-secondary,#64748b);font-size:.65rem;font-weight:600;letter-spacing:.05em;padding:.4rem .625rem;text-align:left;text-transform:uppercase}.kfs-summary-table td{border-bottom:1px solid #f1f5f9;border-bottom:1px solid var(--bg-secondary,#f1f5f9);color:#1e293b;color:var(--text-primary,#1e293b);font-size:.8rem;padding:.375rem .625rem}.kfs-summary-table tbody tr{transition:background .15s ease}.kfs-summary-table tbody tr:hover{background:#2563eb08}.kfs-summary-table tbody tr:last-child td{border-bottom:none}.kfs-field-no{color:#94a3b8;color:var(--text-muted,#94a3b8);font-size:.75rem;font-weight:600;width:32px}.kfs-value{font-feature-settings:"tnum";color:#1e293b;color:var(--text-primary,#1e293b);font-variant-numeric:tabular-nums;font-weight:700;text-align:right;white-space:nowrap}.kfs-value.highlight{color:#2563eb;color:var(--primary,#2563eb);font-size:.875rem}.kfs-highlight-row{background:linear-gradient(135deg,#2563eb0a,#0ea5e90a)}.kfs-highlight-row td{border-top:2px solid #2563eb!important;border-top:2px solid var(--primary,#2563eb)!important;font-weight:600}.kfs-value.placeholder{color:#94a3b8;color:var(--text-muted,#94a3b8);font-weight:400}.kfs-tooltip-wrapper{cursor:help;display:inline-flex;position:relative}.kfs-info-icon{align-items:center;background:#2563eb14;border-radius:50%;color:#2563eb;color:var(--primary,#2563eb);display:inline-flex;font-size:.625rem;font-style:italic;font-weight:700;height:18px;justify-content:center;transition:all .15s ease;width:18px}.kfs-tooltip-wrapper:hover .kfs-info-icon{background:#2563eb26}.kfs-tooltip-text{background:#1e293b;background:var(--text-primary,#1e293b);border-radius:8px;bottom:calc(100% + 8px);box-shadow:0 4px 12px #0003;color:#fff;font-size:.7rem;font-weight:500;line-height:1.4;padding:8px 12px;pointer-events:none;white-space:nowrap;z-index:100}.kfs-tooltip-text,.kfs-tooltip-text:after{left:50%;position:absolute;transform:translateX(-50%)}.kfs-tooltip-text:after{border:5px solid #0000;border-top:5px solid var(--text-primary,#1e293b);content:"";top:100%}.kfs-tooltip-cell{text-align:center;width:32px}.kfs-instalment-grid{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:repeat(4,1fr)}@media (max-width:768px){.kfs-instalment-grid{grid-template-columns:repeat(2,1fr)}}.kfs-instalment-card{align-items:center;background:#f8fafc;background:var(--bg-secondary,#f8fafc);border:1px solid #e2e8f0cc;border:1px solid var(--border-color,#e2e8f0cc);border-radius:6px;border-radius:var(--radius-sm,6px);display:flex;flex-direction:column;padding:.625rem .5rem;transition:all .15s ease}.kfs-instalment-card.blue{background:#2563eb0d;border-color:#2563eb33}.kfs-instalment-card.blue:hover{border-color:#2563eb;box-shadow:0 2px 8px #2563eb1f}.kfs-instalment-card.blue .kfs-instalment-label{color:#2563eb}.kfs-instalment-card.green{background:#16a34a0d;border-color:#16a34a33}.kfs-instalment-card.green:hover{border-color:#16a34a;box-shadow:0 2px 8px #16a34a1f}.kfs-instalment-card.green .kfs-instalment-label{color:#16a34a}.kfs-instalment-card.amber{background:#d977060d;border-color:#d9770633}.kfs-instalment-card.amber:hover{border-color:#d97706;box-shadow:0 2px 8px #d977061f}.kfs-instalment-card.amber .kfs-instalment-label{color:#d97706}.kfs-instalment-card.purple{background:#7c3aed0d;border-color:#7c3aed33}.kfs-instalment-card.purple:hover{border-color:#7c3aed;box-shadow:0 2px 8px #7c3aed1f}.kfs-instalment-card.purple .kfs-instalment-label{color:#7c3aed}.kfs-instalment-label{color:#2563eb;color:var(--primary,#2563eb);font-size:.6875rem;font-weight:700;letter-spacing:.05em;margin-bottom:.25rem;text-transform:uppercase}.kfs-instalment-date{font-feature-settings:"tnum";color:#1e293b;color:var(--text-primary,#1e293b);font-size:.8125rem;font-variant-numeric:tabular-nums;font-weight:700}.kfs-instalment-formula{color:#94a3b8;color:var(--text-muted,#94a3b8);font-size:.6rem;margin-top:2px}.kfs-actions{background:#f8fafc;background:var(--bg-secondary,#f8fafc);border:1px solid #e2e8f0cc;border:1px solid var(--border-color,#e2e8f0cc);border-radius:8px;border-radius:var(--radius,8px);gap:.625rem;justify-content:flex-end}.kfs-actions,.kfs-total-row{display:flex;flex-shrink:0;padding:.5rem .875rem}.kfs-total-row{align-items:center;background:linear-gradient(135deg,#2563eb0a,#0ea5e90a);border-top:2px solid #2563eb;border-top:2px solid var(--primary,#2563eb);justify-content:space-between}.kfs-total-label{color:#1e293b;color:var(--text-primary,#1e293b);font-size:.8125rem;font-weight:600}.kfs-total-value{font-feature-settings:"tnum";color:#2563eb;color:var(--primary,#2563eb);font-size:1.125rem;font-variant-numeric:tabular-nums;font-weight:800}.kfs-apr-row{background:#f8fafc;background:var(--bg-secondary,#f8fafc);border-top:1px solid #e2e8f0cc;border-top:1px solid var(--border-color,#e2e8f0cc);flex-shrink:0;justify-content:space-between;padding:.375rem .875rem}.kfs-apr-label,.kfs-apr-row{align-items:center;display:flex}.kfs-apr-label{font-size:.8rem;font-weight:500;gap:.375rem}.kfs-apr-label,.kfs-apr-value{color:#1e293b;color:var(--text-primary,#1e293b)}.kfs-apr-value{font-feature-settings:"tnum";font-size:.8125rem;font-variant-numeric:tabular-nums;font-weight:700}.kfs-print-layout{display:none}@media print{body *{visibility:hidden!important}.kfs-print-layout,.kfs-print-layout *{visibility:visible!important}.kfs-print-layout{background:#fff!important;color:#000!important;display:block!important;font-family:Segoe UI,Arial,sans-serif;height:auto;left:0;padding:40px;position:fixed!important;top:0;width:100%;z-index:99999}.kfs-print-inner{margin:0 auto;max-width:600px}.kfs-print-header{border-bottom:2px solid #000;margin-bottom:24px;padding-bottom:16px;text-align:center}.kfs-print-header h1{color:#000;font-size:1.5rem;letter-spacing:.08em;margin:0 0 4px;text-transform:uppercase}.kfs-print-header h2{color:#444;font-size:1rem;font-weight:400;margin:0}.kfs-print-divider{border-top:1px solid #ccc;margin:16px 0}.kfs-print-section{margin-bottom:12px}.kfs-print-subtitle{color:#000;font-size:.9rem;font-weight:700;letter-spacing:.03em;margin:0 0 8px;text-transform:uppercase}.kfs-print-table{border-collapse:collapse;width:100%}.kfs-print-table td{color:#000;font-size:.875rem;padding:5px 0}.kfs-print-label{color:#333}.kfs-print-value{font-feature-settings:"tnum";color:#000;font-variant-numeric:tabular-nums;font-weight:700;text-align:right}.kfs-print-footer{border-top:1px solid #ccc;color:#888;font-size:.75rem;margin-top:32px;padding-top:16px;text-align:center}}
/*# sourceMappingURL=main.c8fd8971.css.map*/