@import"https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;500;600;700&display=swap";:root{--green-50: #e8f5ee;--green-100: #c5e6d1;--green-200: #9ed5b3;--green-300: #6ec292;--green-400: #3cab6c;--green-500: #11954a;--green-600: #0e7a3d;--green-700: #0b6232;--green-800: #084a25;--green-900: #053219;--success: var(--green-500);--warning: #f59e0b;--danger: #ef4444;--info: #3b82f6;--neutral: #6b7280;--gray-50: #f9fafb;--gray-100: #f3f4f6;--gray-200: #e5e7eb;--gray-300: #d1d5db;--gray-400: #9ca3af;--gray-500: #6b7280;--gray-600: #4b5563;--gray-700: #374151;--gray-800: #1f2937;--gray-900: #111827;--bg-primary: #ffffff;--bg-secondary: #f9fafb;--bg-card: #ffffff;--bg-sidebar: #ffffff;--text-primary: #1f2937;--text-secondary: #6b7280;--text-muted: #9ca3af;--border: #e5e7eb;--border-focus: var(--green-500);--font-sans: "Poppins", "Inter", system-ui, -apple-system, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--space-3xl: 4rem;--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -2px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -4px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 8px 10px -6px rgba(0, 0, 0, .1);--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .2s cubic-bezier(.4, 0, .2, 1);--transition-slow: .3s cubic-bezier(.4, 0, .2, 1);--sidebar-width: 260px;--sidebar-collapsed: 64px;--topbar-height: 56px;--bottomnav-height: 64px;--content-max-width: 1280px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-sans);font-size:.875rem;line-height:1.5;color:var(--text-primary);background-color:var(--bg-secondary);min-height:100vh;overflow-x:hidden}a{color:var(--green-500);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--green-600)}img{max-width:100%;height:auto}h1,h2,h3,h4,h5,h6{color:var(--text-primary);line-height:1.3;font-weight:600}h1{font-size:1.5rem;font-weight:700}h2{font-size:1.25rem}h3{font-size:1rem}@media (min-width: 1024px){h1{font-size:2rem}h2{font-size:1.5rem}h3{font-size:1.125rem}}.text-sm{font-size:.75rem}.text-muted{color:var(--text-secondary)}.text-success{color:var(--green-500)}.text-danger{color:var(--danger)}.text-warning{color:var(--warning)}.text-info{color:var(--info)}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1.25rem;font-family:var(--font-sans);font-size:.875rem;font-weight:500;line-height:1;border:1px solid transparent;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);min-height:44px;white-space:nowrap;text-decoration:none}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--green-500);color:#fff;border-color:var(--green-500)}.btn-primary:hover:not(:disabled){background:var(--green-600);border-color:var(--green-600)}.btn-primary:active:not(:disabled){background:var(--green-700)}.btn-secondary{background:transparent;color:var(--green-500);border-color:var(--green-500)}.btn-secondary:hover:not(:disabled){background:var(--green-50);color:var(--green-600)}.btn-danger{background:var(--danger);color:#fff;border-color:var(--danger)}.btn-danger:hover:not(:disabled){background:#dc2626}.btn-ghost{background:transparent;color:var(--text-secondary);border-color:transparent}.btn-ghost:hover:not(:disabled){background:var(--gray-100);color:var(--text-primary)}.btn-sm{padding:.375rem .75rem;font-size:.75rem;min-height:32px}.btn-icon{padding:.5rem;min-height:40px;min-width:40px}.fab{position:fixed;bottom:calc(var(--bottomnav-height) + 1rem);right:1rem;width:56px;height:56px;border-radius:var(--radius-full);background:var(--green-500);color:#fff;border:none;box-shadow:var(--shadow-lg);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-fast);z-index:40}.fab:hover{background:var(--green-600);transform:scale(1.05)}.fab:active{transform:scale(.95)}@media (min-width: 1024px){.fab{display:none}}.badge{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .625rem;font-size:.75rem;font-weight:500;line-height:1;border-radius:var(--radius-full);white-space:nowrap}.badge-success{background:var(--green-50);color:var(--green-700)}.badge-warning{background:#fef3c7;color:#92400e}.badge-danger{background:#fef2f2;color:#991b1b}.badge-info{background:#eff6ff;color:#1e40af}.badge-neutral{background:var(--gray-100);color:var(--gray-600)}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-lg);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition-fast)}.card:hover{box-shadow:var(--shadow-md)}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-md)}.card-body{display:flex;flex-direction:column;gap:var(--space-sm)}.card-footer{display:flex;align-items:center;justify-content:space-between;margin-top:var(--space-md);padding-top:var(--space-md);border-top:1px solid var(--border)}.card-list{display:flex;flex-direction:column;gap:var(--space-sm)}.card-list .card{cursor:pointer;padding:var(--space-md)}.card-list .card:active{background:var(--gray-50)}.card-row{display:flex;align-items:center;justify-content:space-between;gap:var(--space-sm)}.card-title,.card-amount{font-weight:600;font-size:.875rem;color:var(--text-primary)}.card-label{font-size:.75rem;color:var(--text-secondary)}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-lg);display:flex;flex-direction:column;gap:var(--space-xs)}.stat-card .stat-value{font-size:1.75rem;font-weight:700;color:var(--text-primary);line-height:1}.stat-card .stat-label{font-size:.75rem;color:var(--text-secondary);font-weight:500}.stat-card .stat-change{font-size:.75rem;font-weight:500}.stat-card .stat-change.positive{color:var(--green-500)}.stat-card .stat-change.negative{color:var(--danger)}.stat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-md)}@media (min-width: 768px){.stat-grid{grid-template-columns:repeat(4,1fr)}}.data-table{width:100%;border-collapse:collapse;font-size:.8125rem}.data-table th{text-align:left;padding:.75rem 1rem;font-weight:600;font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;background:var(--gray-50);border-bottom:2px solid var(--border);white-space:nowrap}.data-table td{padding:.75rem 1rem;border-bottom:1px solid var(--border);color:var(--text-primary);vertical-align:middle}.data-table tbody tr{transition:background var(--transition-fast);cursor:pointer}.data-table tbody tr:hover{background:var(--green-50)}.data-table tbody tr:active{background:var(--green-100)}.form-group{display:flex;flex-direction:column;gap:var(--space-xs)}.form-label{font-size:.75rem;font-weight:500;color:var(--text-secondary)}.form-input,.form-select,.form-textarea{width:100%;padding:.625rem .75rem;font-family:var(--font-sans);font-size:.875rem;color:var(--text-primary);background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-md);transition:border-color var(--transition-fast),box-shadow var(--transition-fast);min-height:44px}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--green-500);box-shadow:0 0 0 3px #11954a1a}.form-input::placeholder{color:var(--text-muted)}.form-error{font-size:.75rem;color:var(--danger)}.form-grid{display:grid;gap:var(--space-md);grid-template-columns:1fr}@media (min-width: 768px){.form-grid-2{grid-template-columns:repeat(2,1fr)}.form-grid-3{grid-template-columns:repeat(3,1fr)}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:flex-end;justify-content:center;z-index:100;animation:fadeIn var(--transition-base) ease-out}@media (min-width: 768px){.modal-overlay{align-items:center}}.modal{background:var(--bg-card);width:100%;max-height:90vh;overflow-y:auto;border-radius:var(--radius-xl) var(--radius-xl) 0 0;animation:slideUp var(--transition-base) ease-out}@media (min-width: 768px){.modal{max-width:560px;border-radius:var(--radius-xl);animation:scaleIn var(--transition-base) ease-out}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-lg);border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--bg-card);z-index:1}.modal-body{padding:var(--space-lg)}.modal-footer{display:flex;gap:var(--space-sm);justify-content:flex-end;padding:var(--space-lg);border-top:1px solid var(--border);position:sticky;bottom:0;background:var(--bg-card)}.toast-container{position:fixed;top:var(--space-lg);right:var(--space-lg);z-index:200;display:flex;flex-direction:column;gap:var(--space-sm);pointer-events:none}@media (max-width: 767px){.toast-container{top:auto;bottom:calc(var(--bottomnav-height) + var(--space-lg));left:var(--space-md);right:var(--space-md)}}.toast{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-md) var(--space-lg);box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:var(--space-sm);pointer-events:all;animation:slideIn var(--transition-slow) ease-out;font-size:.875rem}.toast-success{border-left:4px solid var(--green-500)}.toast-error{border-left:4px solid var(--danger)}.toast-warning{border-left:4px solid var(--warning)}.toast-info{border-left:4px solid var(--info)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-3xl) var(--space-xl);text-align:center;color:var(--text-secondary);gap:var(--space-md)}.empty-state svg{width:64px;height:64px;color:var(--gray-300)}.spinner{width:24px;height:24px;border:3px solid var(--border);border-top-color:var(--green-500);border-radius:50%;animation:spin .6s linear infinite}.loading-page{display:flex;align-items:center;justify-content:center;min-height:50vh}.page{padding:var(--space-md);max-width:var(--content-max-width);margin:0 auto}@media (min-width: 1024px){.page{padding:var(--space-xl) var(--space-2xl)}}.page-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);margin-bottom:var(--space-lg);flex-wrap:wrap}.page-title{display:flex;flex-direction:column;gap:var(--space-xs)}.page-title h1{font-size:1.25rem;font-weight:700}@media (min-width: 1024px){.page-title h1{font-size:1.5rem}}.page-subtitle{font-size:.75rem;color:var(--text-secondary)}.page-actions{display:flex;gap:var(--space-sm);align-items:center}@media (max-width: 767px){.page-actions .btn-primary:not(.btn-sm){display:none}}.toolbar{display:flex;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-md);flex-wrap:wrap}.search-box{flex:1;min-width:200px;position:relative}.search-box input{width:100%;padding:.5rem 2rem .5rem 2.5rem;font-size:.875rem;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-primary);min-height:40px}.search-box input:focus{outline:none;border-color:var(--green-500);box-shadow:0 0 0 3px #11954a1a}.search-box .search-icon{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);color:var(--text-muted);width:16px;height:16px}.search-box .search-clear{position:absolute;right:.5rem;top:50%;transform:translateY(-50%);background:var(--gray-200);border:none;border-radius:var(--radius-full);width:22px;height:22px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:.7rem;color:var(--text-secondary);transition:all var(--transition-fast);line-height:1;padding:0}.search-box .search-clear:hover{background:var(--gray-300);color:var(--text-primary)}.pagination{display:flex;align-items:center;justify-content:center;gap:var(--space-xs);padding:var(--space-md) 0}.pagination button{min-width:36px;min-height:36px;display:flex;align-items:center;justify-content:center;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-primary);color:var(--text-secondary);font-size:.875rem;cursor:pointer;transition:all var(--transition-fast)}.pagination button:hover{border-color:var(--green-500);color:var(--green-500)}.pagination button.active{background:var(--green-500);color:#fff;border-color:var(--green-500)}.avatar{width:36px;height:36px;border-radius:var(--radius-full);background:var(--green-100);color:var(--green-700);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.875rem;flex-shrink:0}.avatar-sm{width:28px;height:28px;font-size:.75rem}.avatar-lg{width:48px;height:48px;font-size:1.125rem}.divider{height:1px;background:var(--border);margin:var(--space-md) 0}.progress-bar{width:100%;height:8px;background:var(--gray-200);border-radius:var(--radius-full);overflow:hidden}.progress-bar-fill{height:100%;border-radius:var(--radius-full);transition:width var(--transition-slow);background:var(--green-500)}.progress-bar-fill.warning{background:var(--warning)}.progress-bar-fill.danger{background:var(--danger)}.dropdown{position:relative;display:inline-flex}.dropdown-menu{position:absolute;top:100%;right:0;min-width:180px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:50;padding:var(--space-xs);animation:scaleIn var(--transition-fast) ease-out}.dropdown-item{display:flex;align-items:center;gap:var(--space-sm);padding:.5rem .75rem;font-size:.875rem;color:var(--text-primary);border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition-fast);width:100%;border:none;background:none;text-align:left;font-family:var(--font-sans)}.dropdown-item:hover{background:var(--gray-100)}.dropdown-item.danger{color:var(--danger)}.dropdown-item.danger:hover{background:#fef2f2}.tabs{display:flex;gap:0;border-bottom:2px solid var(--border);overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.tabs::-webkit-scrollbar{display:none}.tab{padding:.75rem 1rem;font-size:.875rem;font-weight:500;color:var(--text-secondary);border:none;background:none;cursor:pointer;white-space:nowrap;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all var(--transition-fast);font-family:var(--font-sans)}.tab:hover{color:var(--text-primary)}.tab.active{color:var(--green-500);border-bottom-color:var(--green-500)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-xs{gap:var(--space-xs)}.gap-sm{gap:var(--space-sm)}.gap-md{gap:var(--space-md)}.gap-lg{gap:var(--space-lg)}.hidden{display:none!important}@media (max-width: 767px){.desktop-only{display:none!important}}@media (min-width: 768px){.mobile-only{display:none!important}}.permission-denied{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;text-align:center;gap:var(--space-md);color:var(--text-secondary)}.permission-denied svg{width:80px;height:80px;color:var(--gray-300)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes scaleIn{0%{transform:scale(.95);opacity:0}to{transform:scale(1);opacity:1}}@keyframes spin{to{transform:rotate(360deg)}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}.grid-wrapper{overflow:scroll!important;scrollbar-width:auto!important;scrollbar-color:#94a3b8 #e2e8f0!important}.grid-wrapper::-webkit-scrollbar{width:14px!important;height:14px!important}.grid-wrapper::-webkit-scrollbar-track{background:#e2e8f0!important}.grid-wrapper::-webkit-scrollbar-thumb{background:#94a3b8!important;border-radius:7px;border:2px solid #e2e8f0!important}.grid-wrapper::-webkit-scrollbar-thumb:hover{background:#64748b!important}.grid-wrapper::-webkit-scrollbar-corner{background:#e2e8f0!important}.action-group{display:flex;gap:4px;align-items:center;flex-wrap:nowrap}.action-icon{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:50%;font-size:13px;border:none;cursor:pointer;transition:all .15s ease;background:transparent;position:relative}.action-icon:hover{transform:scale(1.15)}.action-icon.detail{background:#e8f5e9}.action-icon.detail:hover{background:#c8e6c9}.action-icon.edit{background:#fff3e0}.action-icon.edit:hover{background:#ffe0b2}.action-icon.delete{background:#ffebee}.action-icon.delete:hover{background:#ffcdd2}.sp-group-header{display:flex;align-items:center;gap:10px;padding:10px 16px;background:linear-gradient(135deg,#f0fdf4,#e8f5e9);border-left:4px solid var(--green-500);border-radius:8px;margin:18px 0 8px;font-size:14px;font-weight:600;color:#2d5016}.sp-group-header .sp-count{background:var(--green-500);color:#fff;font-size:11px;padding:1px 8px;border-radius:12px;font-weight:500}@media print{.no-print,.toolbar,.fab,.page-actions,.modal-overlay,.toast-container,.action-group,.data-table th:first-child,.data-table td:first-child{display:none!important}.page{padding:0!important;max-width:100%!important}.page-header{margin-bottom:.5rem!important}.card{border:none!important;box-shadow:none!important;padding:0!important}.data-table{font-size:11px!important}.data-table th{background:#f3f4f6!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}.badge{-webkit-print-color-adjust:exact;print-color-adjust:exact}body{background:#fff!important}}
