@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swap";
:root{--color-primary:#1ad079;--color-primary-hover:#15b86a;--color-primary-light:#1ad07914;--color-primary-muted:#1ad0792e;--color-accent:#38a57e;--color-accent-light:#38a57e1a;--color-bg-primary:#0c222c;--color-bg-secondary:#0f2b37;--color-bg-tertiary:#f8f9fa;--color-bg-elevated:#fff;--color-bg-card:#fff;--color-bg-card-hover:#f5f7fa;--color-bg-input:#f5f7fa;--color-bg-input-focus:#fff;--color-border:#00000014;--color-border-light:#0000000d;--color-border-active:#1ad07980;--color-border-input:#00000026;--color-text-primary:#0c222c;--color-text-secondary:#475569;--color-text-muted:#94a3b8;--color-text-disabled:#cbd5e1;--color-text-inverse:#fff;--color-text-on-dark:#fff;--color-success:#16a34a;--color-success-bg:#16a34a14;--color-warning:#ea580c;--color-warning-bg:#ea580c14;--color-danger:#dc2626;--color-danger-bg:#dc262614;--color-info:#2563eb;--color-info-bg:#2563eb14;--color-income:#16a34a;--color-income-bg:#16a34a14;--color-expense:#dc2626;--color-expense-bg:#dc262614;--gradient-green:linear-gradient(135deg, #0f2b37 0%, #122f3d 50%, #1ad07914 100%);--gradient-gray:linear-gradient(135deg, #f1f5f9 0%, #e2e8f0 100%);--gradient-card:linear-gradient(145deg, #fff 0%, #f8fafc 100%);--gradient-primary-btn:linear-gradient(135deg, #1ad079 0%, #15b86a 100%);--font-family:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-size-xs:.75rem;--font-size-sm:.8125rem;--font-size-base:.875rem;--font-size-md:1rem;--font-size-lg:1.125rem;--font-size-xl:1.25rem;--font-size-2xl:1.5rem;--font-size-3xl:1.875rem;--font-size-4xl:2.25rem;--font-size-5xl:3rem;--font-weight-light:300;--font-weight-regular:400;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--font-weight-extrabold:800;--line-height-tight:1.2;--line-height-normal:1.5;--line-height-relaxed:1.65;--space-1:.25rem;--space-2:.5rem;--space-3:.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--space-16:4rem;--space-20:5rem;--space-24:6rem;--radius-sm:6px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--radius-2xl:20px;--radius-full:9999px;--shadow-sm:0 1px 3px #0000000f;--shadow-md:0 4px 12px #00000014;--shadow-lg:0 8px 24px #0000001f;--shadow-xl:0 12px 48px #00000029;--shadow-glow:0 0 20px #1ad0791f;--shadow-card:0 1px 3px #0000000f, 0 1px 2px #0000000a;--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);--transition-spring:.4s cubic-bezier(.34, 1.56, .64, 1);--z-dropdown:1000;--z-sticky:1020;--z-fixed:1030;--z-modal:1050;--z-popover:1060;--z-tooltip:1070;--z-toast:1080;--sidebar-width:260px;--sidebar-width-collapsed:72px;--header-height:64px;--content-max-width:1440px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;scroll-behavior:smooth;font-size:16px}body{font-family:var(--font-family);font-size:var(--font-size-base);font-weight:var(--font-weight-regular);line-height:var(--line-height-normal);color:var(--color-text-primary);background-color:#f1f5f9;min-height:100vh;overflow-x:hidden}a{color:var(--color-primary);transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--color-primary-hover)}img,video{max-width:100%;height:auto;display:block}button{cursor:pointer;color:inherit;background:0 0;border:none;font-family:inherit}input,textarea,select{font-family:inherit;font-size:inherit;color:inherit;outline:none}.label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary)}.input{width:100%;padding:var(--space-3) var(--space-4);border:1px solid var(--color-border-input);border-radius:var(--radius-md);color:var(--color-text-primary);font-size:var(--font-size-sm);transition:all var(--transition-fast);appearance:none;line-height:var(--line-height-normal);background:#fff;height:42px}select.input{background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23475569' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");background-position:right 12px center;background-repeat:no-repeat;background-size:16px;padding-right:36px}textarea.input{resize:vertical;height:auto;min-height:80px}.input::placeholder,.input.placeholder{color:var(--color-text-muted)}.input:hover{border-color:#94a3b8}.input:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 0 3px #1ad07926}.input:disabled{color:var(--color-text-muted);cursor:not-allowed;opacity:.7;background:#f8fafc}input[type=checkbox],input[type=radio]{accent-color:var(--color-primary);cursor:pointer;width:18px;height:18px}.custom-select-container{width:100%;position:relative}.custom-select-container.disabled{opacity:.7}.select-trigger{cursor:pointer;text-align:left;background:#fff;justify-content:space-between;align-items:center;display:flex!important}.select-trigger.open{border-color:var(--color-primary);box-shadow:0 0 0 3px #1ad07926}.select-icon{color:var(--color-text-muted);transition:transform var(--transition-fast)}.select-icon.open{transform:rotate(180deg)}.select-dropdown{border:1px solid var(--color-border-input);border-radius:var(--radius-md);width:100%;box-shadow:var(--shadow-lg);z-index:var(--z-dropdown);background:#fff;max-height:250px;animation:.15s ease-out fade-in-down;position:absolute;top:calc(100% + 4px);left:0;overflow-y:auto}.select-options{padding:var(--space-2);margin:0;list-style:none}.select-option{padding:var(--space-2) var(--space-3);font-size:var(--font-size-sm);color:var(--color-text-primary);border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition-fast);justify-content:space-between;align-items:center;display:flex}.select-option:hover{background:var(--color-bg-card-hover)}.select-option.selected{background:var(--color-primary-light);color:var(--color-text-primary);font-weight:var(--font-weight-medium)}.text-primary{color:var(--color-primary)}ul,ol{list-style:none}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{border-radius:var(--radius-full);background:#0000001f}::-webkit-scrollbar-thumb:hover{background:#0003}.h1,h1{font-size:var(--font-size-4xl);font-weight:var(--font-weight-bold);line-height:var(--line-height-tight);letter-spacing:-.025em}.h2,h2{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);line-height:var(--line-height-tight);letter-spacing:-.02em}.h3,h3{font-size:var(--font-size-2xl);font-weight:var(--font-weight-semibold);line-height:var(--line-height-tight);letter-spacing:-.015em}.h4,h4{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);line-height:var(--line-height-tight)}.h5,h5{font-size:var(--font-size-lg);font-weight:var(--font-weight-medium);line-height:var(--line-height-normal)}.text-sm{font-size:var(--font-size-sm)}.text-xs{font-size:var(--font-size-xs)}.text-md{font-size:var(--font-size-md)}.text-lg{font-size:var(--font-size-lg)}.text-muted{color:var(--color-text-muted)}.text-secondary{color:var(--color-text-secondary)}.text-success{color:var(--color-success)}.text-danger{color:var(--color-danger)}.text-warning{color:var(--color-warning)}.font-medium{font-weight:var(--font-weight-medium)}.font-semibold{font-weight:var(--font-weight-semibold)}.font-bold{font-weight:var(--font-weight-bold)}.btn{justify-content:center;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);border-radius:var(--radius-md);transition:all var(--transition-base);white-space:nowrap;-webkit-user-select:none;user-select:none;line-height:1;display:inline-flex;position:relative;overflow:hidden}.btn:after{content:"";border-radius:inherit;opacity:0;transition:opacity var(--transition-fast);position:absolute;inset:0}.btn:hover:after{opacity:1}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.5;pointer-events:none;filter:grayscale(.4)}.btn-primary{background:var(--gradient-primary-btn);color:var(--color-text-inverse);box-shadow:0 2px 8px #1ad0794d}.btn-primary:after{background:#0000001a}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 16px #1ad07959}.btn-secondary{color:var(--color-text-primary);border:1px solid var(--color-border-input);background:#fff}.btn-secondary:after{background:#00000008}.btn-secondary:hover{border-color:var(--color-border-active)}.btn-ghost{color:var(--color-text-secondary);background:0 0}.btn-ghost:hover{color:var(--color-text-primary);background:#0000000a}.btn-danger{background:var(--color-danger);color:#fff}.btn-danger:after{background:#00000026}.btn-sm{padding:var(--space-2) var(--space-4);font-size:var(--font-size-sm)}.btn-lg{padding:var(--space-4) var(--space-8);font-size:var(--font-size-md)}.btn-icon{border-radius:var(--radius-md);width:40px;height:40px;padding:0}.btn-icon.btn-sm{width:32px;height:32px}.form-group{gap:var(--space-2);flex-direction:column;display:flex}.form-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary)}.form-input{width:100%;height:44px;padding:0 var(--space-4);background:var(--color-bg-input);border:1px solid var(--color-border-input);border-radius:var(--radius-md);color:var(--color-text-primary);font-size:var(--font-size-base);transition:all var(--transition-base)}.form-input::placeholder{color:var(--color-text-muted)}.form-input:focus{border-color:var(--color-primary);background:var(--color-bg-input-focus);box-shadow:0 0 0 3px var(--color-primary-light)}.form-input:hover:not(:focus){border-color:#00000040}.form-input.error{border-color:var(--color-danger);box-shadow:0 0 0 3px var(--color-danger-bg)}.form-error{font-size:var(--font-size-xs);color:var(--color-danger);align-items:center;gap:var(--space-1);display:flex}textarea.form-input{height:auto;min-height:100px;padding:var(--space-3) var(--space-4);resize:vertical}select.form-input{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='rgba(255,255,255,0.45)' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--space-3) center;padding-right:var(--space-10)}.card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-6);transition:all var(--transition-base)}.card:hover{border-color:var(--color-border-active);box-shadow:var(--shadow-md)}.table-responsive{-webkit-overflow-scrolling:touch;border-radius:var(--radius-lg);overflow-x:auto}.table-responsive>table{min-width:600px}.card-flat{border:1px solid var(--color-border-light);border-radius:var(--radius-lg);padding:var(--space-6);background:#f8fafc}.card-glass{-webkit-backdrop-filter:blur(12px);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-6);background:#ffffffd9}.badge{align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);border-radius:var(--radius-full);line-height:1.4;display:inline-flex}.badge-success{background:var(--color-success-bg);color:var(--color-success)}.badge-danger{background:var(--color-danger-bg);color:var(--color-danger)}.badge-warning{background:var(--color-warning-bg);color:var(--color-warning)}.badge-info{background:var(--color-info-bg);color:var(--color-info)}.badge-neutral{color:var(--color-text-secondary);background:#f1f5f9}.toast-container{top:var(--space-6);right:var(--space-6);z-index:var(--z-toast);gap:var(--space-3);pointer-events:none;flex-direction:column;display:flex;position:fixed}.toast{align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-5);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);pointer-events:all;animation:toast-slide-in .3s var(--transition-spring);background:#fff;min-width:min(320px,100vw - 32px);max-width:min(440px,100vw - 32px);display:flex}.toast-success{border-left:3px solid var(--color-success)}.toast-error{border-left:3px solid var(--color-danger)}.toast-warning{border-left:3px solid var(--color-warning)}@keyframes toast-slide-in{0%{opacity:0;transform:translate(100%)scale(.95)}to{opacity:1;transform:translate(0)scale(1)}}@keyframes toast-slide-out{0%{opacity:1;transform:translate(0)scale(1)}to{opacity:0;transform:translate(100%)scale(.95)}}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:var(--z-modal);padding:var(--space-4);background:#0009;justify-content:center;align-items:center;animation:.2s ease-out modal-fade-in;display:flex;position:fixed;inset:0}.modal{border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);width:100%;max-width:min(520px,100vw - 32px);max-height:85vh;animation:modal-scale-in .25s var(--transition-spring);background:#fff;overflow-y:auto}.modal-header{padding:var(--space-6);border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;display:flex}.modal-body{padding:var(--space-6)}.modal-footer{justify-content:flex-end;align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-6);border-top:1px solid var(--color-border);display:flex}@keyframes modal-fade-in{0%{opacity:0}to{opacity:1}}@keyframes modal-scale-in{0%{opacity:0;transform:scale(.95)translateY(10px)}to{opacity:1;transform:scale(1)translateY(0)}}.spinner{border:2px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;width:20px;height:20px;animation:.6s linear infinite spin}.spinner-sm{width:16px;height:16px}.spinner-lg{border-width:3px;width:32px;height:32px}@keyframes spin{to{transform:rotate(360deg)}}@keyframes shimmer{0%{background-position:-600px 0}to{background-position:600px 0}}.skeleton{background:linear-gradient(90deg,#f1f5f9 25%,#e2e8f0 50%,#f1f5f9 75%) 0 0/600px 100%;border-radius:4px;animation:1.5s ease-in-out infinite shimmer}.flex{display:flex}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.justify-end{justify-content:flex-end}.gap-1{gap:var(--space-1)}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-6{gap:var(--space-6)}.gap-8{gap:var(--space-8)}.grid{display:grid}.w-full{width:100%}.h-full{height:100%}.relative{position:relative}.absolute{position:absolute}.overflow-hidden{overflow:hidden}.overflow-auto{overflow:auto}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes fade-in-up{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes fade-in-down{0%{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}@keyframes scale-in{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes pulse-glow{0%,to{box-shadow:0 0 #1ad07933}50%{box-shadow:0 0 20px 4px #1ad0791a}}.animate-fade-in{animation:.4s ease-out both fade-in}.animate-fade-in-up{animation:.5s ease-out both fade-in-up}.animate-fade-in-down{animation:.5s ease-out both fade-in-down}.animate-scale-in{animation:.3s ease-out both scale-in}.delay-100{animation-delay:.1s}.delay-200{animation-delay:.2s}.delay-300{animation-delay:.3s}.delay-400{animation-delay:.4s}.delay-500{animation-delay:.5s}@media (max-width:768px){:root{--font-size-4xl:1.875rem;--font-size-3xl:1.5rem;--font-size-2xl:1.25rem;--sidebar-width:100%}.modal-header,.modal-body,.modal-footer{padding-inline:var(--space-4)}.drawer-header,.drawer-body,.card{padding:var(--space-4)}}@media (max-width:480px){:root{--font-size-4xl:1.5rem;--font-size-3xl:1.25rem;--font-size-2xl:1.125rem;--font-size-xl:1rem}.btn{padding:var(--space-2) var(--space-4);font-size:var(--font-size-sm)}.modal-footer{gap:var(--space-2);flex-direction:column}.modal-footer .btn{justify-content:center;width:100%}}@media (hover:none) and (pointer:coarse){.btn:hover{transform:none}.card:hover{box-shadow:var(--shadow-md);transform:none}.sidebar-nav-item:hover{background:0 0}}.dark-context,.sidebar{--color-text-primary:#fff;--color-text-secondary:#ffffffb8;--color-text-muted:#ffffff73;--color-border:#ffffff14;--color-border-light:#ffffff0d;--color-bg-input:#ffffff0f;--color-border-input:#ffffff1f;color:#fff}.drawer-overlay{-webkit-backdrop-filter:blur(4px);z-index:var(--z-modal);opacity:0;pointer-events:none;background:#0c222c99;transition:opacity .3s;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.drawer-overlay.open{pointer-events:auto;animation:.3s forwards fadeIn}.drawer-panel{width:100%;max-width:min(540px,100vw);z-index:calc(var(--z-modal) + 1);background:#fff;flex-direction:column;transition:transform .3s cubic-bezier(.16,1,.3,1);display:flex;position:fixed;top:0;bottom:0;right:0;transform:translate(100%);box-shadow:-10px 0 30px #0000001a}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}.drawer-panel.open{animation:.35s cubic-bezier(.16,1,.3,1) forwards slideInRight}.drawer-header{padding:var(--space-6);border-bottom:1px solid var(--color-border);background:#f8fafc;justify-content:space-between;align-items:center;display:flex}.drawer-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary)}.drawer-close{color:var(--color-text-muted);transition:color var(--transition-fast);cursor:pointer;padding:var(--space-2);border-radius:var(--radius-sm);background:0 0;border:none;justify-content:center;align-items:center;display:flex}.drawer-close:hover{color:var(--color-text-secondary);background:#0000000a}.drawer-body{padding:var(--space-6);flex:1;overflow-y:auto}.drawer-footer{padding:var(--space-6);border-top:1px solid var(--color-border);justify-content:flex-end;align-items:center;gap:var(--space-4);background:#f1f5f9;display:flex}@media print{.sidebar,.main-header,.no-print,.page-header{display:none!important}.main-content{margin-left:0!important}.print-area{margin:0!important;padding:0!important}.card{break-inside:avoid;box-shadow:none!important;border:1px solid #e2e8f0!important}.crud-table{font-size:11px}.crud-table th,.crud-table td{padding:6px 10px!important}body{background:#fff!important}}
