@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";:root{--bg-primary: #f8fafc;--bg-secondary: #ffffff;--bg-card: rgba(255, 255, 255, .9);--bg-glass: rgba(0, 0, 0, .04);--border-color: rgba(0, 0, 0, .08);--text-primary: #0f172a;--text-secondary: #475569;--text-muted: #64748b;--accent-teal: #0d9488;--accent-teal-dark: #0f766e;--accent-blue: #0284c7;--accent-purple: #7c3aed;--accent-red: #ef4444;--accent-green: #16a34a;--accent-orange: #ea580c;--gradient-1: linear-gradient(135deg, #f0fdfa 0%, #e0f2fe 100%);--gradient-card: linear-gradient(135deg, rgba(13, 148, 136, .05), rgba(2, 132, 199, .05));--shadow-lg: 0 10px 40px rgba(0, 0, 0, .08);--shadow-md: 0 4px 20px rgba(0, 0, 0, .05);--btn-primary-text: #ffffff;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--transition: all .3s cubic-bezier(.4, 0, .2, 1)}[data-theme=dark]{--bg-primary: #0f172a;--bg-secondary: #0b1120;--bg-card: rgba(15, 23, 42, .8);--bg-glass: rgba(255, 255, 255, .05);--border-color: rgba(255, 255, 255, .1);--text-primary: #f8fafc;--text-secondary: #94a3b8;--text-muted: #64748b;--accent-teal: #2dd4bf;--accent-teal-dark: #14b8a6;--accent-blue: #38bdf8;--accent-purple: #a78bfa;--accent-red: #f87171;--accent-green: #4ade80;--accent-orange: #fb923c;--gradient-1: linear-gradient(135deg, #020617 0%, #0f172a 100%);--gradient-card: linear-gradient(135deg, rgba(45, 212, 191, .1), rgba(56, 189, 248, .05));--shadow-lg: 0 10px 40px rgba(0, 0, 0, .5);--shadow-md: 0 4px 20px rgba(0, 0, 0, .4);--btn-primary-text: #020617}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--gradient-1);color:var(--text-primary);min-height:100vh;-webkit-font-smoothing:antialiased}.navbar{background:var(--bg-secondary);border-bottom:1px solid var(--border-color);padding:0 1.5rem;position:sticky;top:0;z-index:1000;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.navbar-inner{display:flex;align-items:center;justify-content:space-between;height:64px;max-width:1400px;margin:0 auto}.navbar-brand{display:flex;align-items:center;gap:.75rem;text-decoration:none;color:var(--text-primary)}.navbar-brand .logo-icon{width:36px;height:36px;background:linear-gradient(135deg,var(--accent-teal),var(--accent-blue));border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:1.2rem}.navbar-brand span{font-weight:700;font-size:1.1rem;letter-spacing:-.02em}.navbar-menu{display:flex;align-items:center;gap:.25rem;list-style:none}.navbar-menu a{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;color:var(--text-secondary);text-decoration:none;border-radius:var(--radius-sm);font-size:.875rem;font-weight:500;transition:var(--transition);white-space:nowrap}.navbar-menu a:hover{color:var(--text-primary);background:var(--bg-glass)}.navbar-menu a.active{color:var(--accent-teal);background:#2dd4bf1a}.navbar-user{display:flex;align-items:center;gap:1rem}.theme-toggle{background:none;border:none;font-size:1.25rem;cursor:pointer;padding:.25rem;display:flex;align-items:center;justify-content:center;color:var(--text-primary);opacity:.8;transition:var(--transition)}.theme-toggle:hover{opacity:1;transform:scale(1.1)}.navbar-user .user-info{display:flex;align-items:center;gap:.5rem;color:var(--text-secondary);font-size:.85rem}.navbar-user .user-avatar{width:32px;height:32px;background:linear-gradient(135deg,var(--accent-purple),var(--accent-blue));border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:600;color:#fff}.btn-logout{background:#f8717126;color:var(--accent-red);border:none;padding:.4rem .8rem;border-radius:var(--radius-sm);font-size:.8rem;font-weight:500;cursor:pointer;transition:var(--transition)}.btn-logout:hover{background:#f8717140}.hamburger{display:none;background:none;border:none;color:var(--text-primary);font-size:1.5rem;cursor:pointer;padding:.25rem}.main-content{max-width:1400px;margin:0 auto;padding:1.5rem}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--gradient-1);padding:1rem}.login-card{background:var(--bg-card);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:2.5rem;width:100%;max-width:420px;box-shadow:var(--shadow-lg)}.login-card h1{text-align:center;font-size:1.5rem;font-weight:700;margin-bottom:.25rem;background:linear-gradient(135deg,var(--accent-teal),var(--accent-blue));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.login-card .subtitle{text-align:center;color:var(--text-secondary);font-size:.875rem;margin-bottom:2rem}.login-card .logo-wrapper{text-align:center;margin-bottom:1.5rem}.login-card .logo-wrapper .logo-circle{width:64px;height:64px;background:linear-gradient(135deg,var(--accent-teal),var(--accent-blue));border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:1.8rem}.form-group{margin-bottom:1.25rem}.form-group label{display:block;font-size:.85rem;font-weight:500;color:var(--text-secondary);margin-bottom:.4rem}.form-control{width:100%;padding:.75rem 1rem;background:var(--bg-glass);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-primary);font-size:1rem;font-family:inherit;transition:var(--transition);outline:none}.form-control:focus{border-color:var(--accent-teal);box-shadow:0 0 0 3px #2dd4bf26}.form-control::placeholder{color:var(--text-muted)}select.form-control{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%2394a3b8' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10l-5 5z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;padding-right:2rem}textarea.form-control{resize:vertical;min-height:80px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.65rem 1.25rem;border:none;border-radius:var(--radius-sm);font-size:.875rem;font-weight:600;font-family:inherit;cursor:pointer;transition:var(--transition);text-decoration:none;white-space:nowrap;min-height:44px}.btn-primary{background:linear-gradient(135deg,var(--accent-teal),var(--accent-teal-dark));color:var(--btn-primary-text)}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 20px #2dd4bf4d}.btn-secondary{background:var(--bg-glass);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover{background:#ffffff1a}.btn-danger{background:#f8717126;color:var(--accent-red)}.btn-danger:hover{background:#f8717140}.btn-sm{padding:.4rem .75rem;font-size:.8rem;min-height:36px}.btn-block{width:100%}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.25rem;margin-bottom:1.5rem}.stat-card{background:var(--bg-card);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:1.5rem;transition:var(--transition);position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px}.stat-card.income:before{background:linear-gradient(90deg,var(--accent-green),var(--accent-teal))}.stat-card.expense:before{background:linear-gradient(90deg,var(--accent-red),var(--accent-orange))}.stat-card.balance:before{background:linear-gradient(90deg,var(--accent-blue),var(--accent-purple))}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.stat-card .stat-icon{width:44px;height:44px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:1.3rem;margin-bottom:1rem}.stat-card.income .stat-icon{background:#4ade8026}.stat-card.expense .stat-icon{background:#f8717126}.stat-card.balance .stat-icon{background:#38bdf826}.stat-card .stat-label{font-size:.8rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.35rem}.stat-card .stat-value{font-size:1.5rem;font-weight:700;letter-spacing:-.02em}.dashboard-tabs{display:flex;gap:.5rem;margin-bottom:1.5rem;background:var(--bg-glass);padding:.5rem;border-radius:var(--radius-lg);width:max-content;max-width:100%;overflow-x:auto}.tab-btn{padding:.6rem 1.2rem;border:none;background:transparent;color:var(--text-secondary);font-weight:600;font-size:.9rem;border-radius:var(--radius-md);cursor:pointer;transition:var(--transition);white-space:nowrap}.tab-btn:hover{color:var(--text-primary);background:#0000000d}[data-theme=dark] .tab-btn:hover{background:#ffffff0d}.tab-btn.active{background:var(--bg-card);color:var(--accent-teal);box-shadow:0 2px 10px #0000000d}.stats-grid.modern{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}.stat-card.modern{display:flex;align-items:center;gap:1.25rem;padding:1.75rem;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);box-shadow:0 4px 20px #00000005}.stat-card.modern:before{display:none}.stat-card.modern .stat-icon{width:56px;height:56px;border-radius:var(--radius-md);font-size:1.5rem;margin-bottom:0;flex-shrink:0}.stat-card.modern .stat-info{display:flex;flex-direction:column}.stat-card.modern .stat-label{font-size:.85rem;font-weight:500;color:var(--text-muted);text-transform:none;letter-spacing:normal;margin-bottom:.2rem}.stat-card.modern .stat-value{font-size:1.8rem;font-weight:700;color:var(--text-primary)}.stat-card.modern.income .stat-icon{background:#16a34a1a;color:var(--accent-green)}.stat-card.modern.expense .stat-icon{background:#ef44441a;color:var(--accent-red)}.stat-card.modern.balance .stat-icon{background:#0284c71a;color:var(--accent-blue)}.stat-card.modern.warning .stat-icon{background:#ea580c1a;color:var(--accent-orange)}.stat-card.modern.success .stat-icon{background:#0d94881a;color:var(--accent-teal)}.dashboard-row-normal{display:grid;grid-template-columns:35fr 65fr;gap:1.5rem;margin-bottom:1.5rem}.dashboard-row-reverse{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-bottom:1.5rem}.dashboard-row-four{display:grid;grid-template-columns:2fr 3fr 3fr 2fr;gap:1.5rem;margin-bottom:1.5rem}.dashboard-col-stats{display:flex;flex-direction:column;gap:1.25rem}.dashboard-grid-2x2{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}@media(max-width:992px){.dashboard-row-normal,.dashboard-row-reverse,.dashboard-row-four{grid-template-columns:1fr}}.chart-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:1.5rem}.chart-container.modern{padding:1.75rem;border-radius:var(--radius-xl);box-shadow:0 4px 20px #00000005;margin-bottom:0}.chart-header{margin-bottom:1.5rem}.chart-header h3{font-size:1.1rem;font-weight:700;color:var(--text-primary);margin-bottom:.25rem}.chart-header .subtitle{font-size:.85rem;color:var(--text-muted)}.chart-container{background:var(--bg-card);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:1.5rem;margin-bottom:1.5rem}.chart-container h3{font-size:1rem;font-weight:600;margin-bottom:1rem;color:var(--text-secondary)}.table-container{background:var(--bg-card);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden}.table-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;flex-wrap:wrap;gap:1rem}.table-header h2{font-size:1.1rem;font-weight:600}.table-filters{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.table-filters .form-control{width:auto;min-width:120px;padding:.5rem .75rem;font-size:.85rem}.table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}table{width:100%;border-collapse:collapse;min-width:600px}th{padding:.75rem 1rem;text-align:left;font-size:.75rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;background:#0003;border-bottom:1px solid var(--border-color)}td{padding:.85rem 1rem;font-size:.875rem;border-bottom:1px solid var(--border-color);color:var(--text-secondary)}tr:hover td{background:var(--bg-glass)}tr:last-child td{border-bottom:none}td.nominal{font-weight:600;font-variant-numeric:tabular-nums}.actions{display:flex;gap:.5rem}.modal-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:2000;padding:1rem;animation:fadeIn .2s ease}.modal-content{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);width:100%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:slideUp .3s ease}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-color)}.modal-header h3{font-size:1.1rem;font-weight:600}.modal-close{background:none;border:none;color:var(--text-muted);font-size:1.5rem;cursor:pointer;padding:.25rem;transition:var(--transition)}.modal-close:hover{color:var(--text-primary)}.modal-body{padding:1.5rem}.modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1.25rem 1.5rem;border-top:1px solid var(--border-color)}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.page-header h1{font-size:1.5rem;font-weight:700;letter-spacing:-.02em}.report-selector{display:flex;gap:.5rem;margin-bottom:1.5rem}.report-tab{padding:.6rem 1.25rem;background:var(--bg-glass);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-secondary);font-weight:500;font-size:.875rem;cursor:pointer;transition:var(--transition);font-family:inherit}.report-tab.active{background:#2dd4bf26;color:var(--accent-teal);border-color:var(--accent-teal)}.report-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1.5rem}.summary-item{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:1.25rem}.summary-item .label{font-size:.8rem;color:var(--text-muted);margin-bottom:.3rem}.summary-item .value{font-size:1.25rem;font-weight:700}.summary-item .value.positive{color:var(--accent-green)}.summary-item .value.negative{color:var(--accent-red)}.summary-item .value.neutral{color:var(--accent-blue)}.file-upload{border:2px dashed var(--border-color);border-radius:var(--radius-sm);padding:1.25rem;text-align:center;cursor:pointer;transition:var(--transition)}.file-upload:hover{border-color:var(--accent-teal);background:#2dd4bf0d}.file-upload input{display:none}.file-upload .upload-text{color:var(--text-muted);font-size:.85rem}.file-upload .upload-icon{font-size:1.5rem;margin-bottom:.5rem}.struk-link{color:var(--accent-blue);text-decoration:none;font-size:.85rem}.struk-link:hover{text-decoration:underline}.badge{display:inline-block;padding:.2rem .6rem;border-radius:20px;font-size:.7rem;font-weight:600;text-transform:uppercase}.badge-admin{background:#a78bfa33;color:var(--accent-purple)}.badge-user{background:#38bdf833;color:var(--accent-blue)}.badge-permintaan{background:#fbbf2433;color:#fbbf24}.badge-pending{background:#fbbf2426;color:#fbbf24}.badge-terealisasi{background:#4ade8026;color:var(--accent-green)}.btn-success{background:#4ade8026;color:var(--accent-green);border:1px solid rgba(74,222,128,.3)}.btn-success:hover{background:#4ade8040}.form-readonly{opacity:.7;cursor:not-allowed;background:#0000001a!important}.alert{padding:.75rem 1rem;border-radius:var(--radius-sm);font-size:.875rem;margin-bottom:1rem}.alert-error{background:#f8717126;color:var(--accent-red);border:1px solid rgba(248,113,113,.3)}.alert-success{background:#4ade8026;color:var(--accent-green);border:1px solid rgba(74,222,128,.3)}.empty-state{text-align:center;padding:3rem 1rem;color:var(--text-muted)}.empty-state .empty-icon{font-size:2.5rem;margin-bottom:.75rem}.empty-state p{font-size:.9rem}.confirm-text{text-align:center;color:var(--text-secondary);font-size:.95rem;padding:1rem 0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media print{body{background:#fff!important;color:#000!important}.navbar,.btn,.table-filters,.report-selector,.page-header .btn,.no-print{display:none!important}.main-content{padding:0;max-width:100%}.table-container,.stat-card,.summary-item,.chart-container{background:#fff!important;border:1px solid #ddd!important;box-shadow:none!important;-webkit-backdrop-filter:none!important;backdrop-filter:none!important}.stat-card:before{display:none}td,th,.stat-value,.stat-label,.value,.label,h1,h2,h3{color:#000!important}.print-header{display:block!important;text-align:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid #000}.print-header h2{font-size:1.2rem;margin-bottom:.25rem}.print-header p{font-size:.85rem;color:#555}}.print-header{display:none}@media(max-width:768px){.hamburger{display:block}.navbar-menu{display:none;position:absolute;top:64px;left:0;right:0;background:var(--bg-secondary);border-bottom:1px solid var(--border-color);flex-direction:column;padding:.5rem;box-shadow:var(--shadow-md)}.navbar-menu.open{display:flex}.navbar-menu a{padding:.75rem 1rem;width:100%}.navbar-user .user-info span{display:none}.stats-grid{grid-template-columns:1fr;gap:.75rem}.stat-card{padding:1.25rem}.stat-card .stat-value{font-size:1.25rem}.page-header{flex-direction:column;align-items:flex-start}.page-header .btn{width:100%}.table-header{flex-direction:column;align-items:flex-start;padding:1rem}.table-filters{width:100%}.table-filters .form-control{flex:1;min-width:0}.main-content{padding:1rem}.modal-content{margin:.5rem}.report-selector{flex-wrap:wrap}.report-summary{grid-template-columns:1fr}.modal-footer{flex-direction:column}.modal-footer .btn{width:100%}.chart-container{padding:1rem}}@media(max-width:480px){.navbar-brand span{font-size:.95rem}.login-card{padding:1.5rem}.page-header h1{font-size:1.25rem}}.loading{display:flex;align-items:center;justify-content:center;padding:2rem;color:var(--text-muted)}.spinner{width:24px;height:24px;border:3px solid var(--border-color);border-top-color:var(--accent-teal);border-radius:50%;animation:spin .8s linear infinite;margin-right:.5rem}@keyframes spin{to{transform:rotate(360deg)}}
