@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600&family=JetBrains+Mono&display=swap";
:root{--color-canvas:#faf9f5;--color-surface-soft:#f5f0e8;--color-surface-card:#efe9de;--color-primary:#cc785c;--color-primary-active:#a9583e;--color-surface-dark:#181715;--color-ink:#141413;--color-body:#3d3d3a;--color-muted:#6c6a64;--color-hairline:#e6dfd8;--color-on-primary:#fff;--color-bg:var(--color-canvas);--color-border:var(--color-hairline);--color-text-primary:var(--color-ink);--color-text-secondary:var(--color-body);--color-text-tertiary:var(--color-muted);--color-accent:var(--color-primary);--space-section:96px;--space-xl:32px;--space-lg:24px;--space-md:16px;--space-sm:12px;--space-xs:8px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--radius-pill:9999px;--font-main:"Google Sans Flex", "Inter", sans-serif;--font-mono:"JetBrains Mono", monospace;--color-surface:var(--color-surface-card);--color-border-light:var(--color-hairline);--color-text-inverse:var(--color-on-primary);--font-family:var(--font-main);--header-height:64px;--max-width:960px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;font-size:16px}body{font-family:var(--font-main);font-optical-sizing:auto;font-variation-settings:"slnt" 0, "wdth" 100, "GRAD" 0, "ROND" 0;background-color:var(--color-bg);color:var(--color-text-secondary);min-height:100vh;line-height:1.55}h1,h2,h3,h4{font-family:var(--font-main);color:var(--color-text-primary);letter-spacing:-.02em;font-weight:700;line-height:1.1}h1{font-size:3rem}h2{font-size:2.25rem}h3{font-size:1.75rem}a{color:var(--color-accent);text-decoration:none;transition:opacity .2s}a:hover{opacity:.8}.container{max-width:var(--max-width);padding:0 var(--space-lg);margin:0 auto}.app-header{height:var(--header-height);background:var(--color-canvas);border-bottom:1px solid var(--color-hairline);z-index:100;align-items:center;display:flex;position:sticky;top:0}.app-header .container{justify-content:space-between;align-items:center;width:100%;display:flex}.app-header__logo{align-items:center;transition:opacity .2s;display:flex}.app-header__nav{gap:.5rem;display:flex}.app-header__link{border-radius:var(--radius-md);color:var(--color-muted);align-items:center;gap:8px;padding:.5rem 1rem;font-size:.875rem;font-weight:500;text-decoration:none;transition:all .2s;display:flex}.app-header__link--active{background:var(--color-surface-card);color:var(--color-ink)}.app-header__link svg{opacity:.7;transition:transform .2s}.app-header__link:hover{color:var(--color-text-primary);background:#0000000a}.app-header__link:hover svg{opacity:1;transform:translateY(-1px)}.app-header__link--active{background:var(--color-bg-primary);color:var(--color-text-primary);box-shadow:var(--shadow-sm);border:1px solid var(--color-border)}.app-header__link--active svg{opacity:1;color:var(--color-accent)}.app-header__link--active:hover{background:var(--color-accent-hover);color:var(--color-text-inverse)}.app-footer{background:var(--color-surface-dark);color:var(--color-on-dark-soft,#a09d96);margin-top:auto;padding:64px 0}.app-footer__content{align-items:center;gap:var(--space-xs);text-align:center;flex-direction:column;font-size:.8125rem;display:flex}.app-footer__credit a{color:var(--color-canvas);font-weight:500;transition:opacity .2s}.app-footer__credit a:hover{opacity:.8;text-decoration:underline}@media (min-width:768px){.app-footer__content{text-align:left;flex-direction:row;justify-content:space-between}}.card{background:var(--color-surface-card);border:1px solid var(--color-hairline);border-radius:var(--radius-lg);padding:var(--space-xl)}.card__header{margin-bottom:var(--space-md);padding-bottom:var(--space-md);border-bottom:1px solid var(--color-border-light);justify-content:space-between;align-items:center;display:flex}.card__title{font-size:var(--font-size-md);letter-spacing:-.01em;font-weight:700}.card__subtitle{font-size:var(--font-size-sm);color:var(--color-text-tertiary);margin-top:2px}.card__badge{font-size:var(--font-size-xs);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);background:var(--color-bg);color:var(--color-text-secondary);font-weight:600}.stat-grid{gap:var(--space-md);grid-template-columns:repeat(auto-fit,minmax(200px,1fr));display:grid}.stat-widget{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-lg);transition:all var(--transition-base)}.stat-widget:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.stat-widget__label{font-size:var(--font-size-xs);color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-sm);font-weight:600}.stat-widget__value{font-size:var(--font-size-2xl);letter-spacing:-.03em;font-weight:800;line-height:1}.stat-widget__detail{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-top:var(--space-sm);line-height:1.4}.table-wrap{-webkit-overflow-scrolling:touch;overflow-x:auto}.table{border-collapse:collapse;width:100%;font-size:var(--font-size-sm)}.table th{text-align:left;font-weight:600;font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-tertiary);padding:var(--space-sm) var(--space-md);border-bottom:2px solid var(--color-border);white-space:nowrap}.table td{padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--color-border-light);vertical-align:top}.table tbody tr{transition:background var(--transition-fast)}.table tbody tr:hover{background:var(--color-surface-hover)}.table td:first-child{color:var(--color-text-tertiary);width:40px;font-weight:500}.table__categories{flex-wrap:wrap;gap:6px;max-width:200px;display:flex}.table__kategori{border:1px solid var(--color-border);color:var(--color-text-secondary);white-space:nowrap;background:#f1f1f1;border-radius:6px;align-items:center;padding:4px 10px;font-size:11px;font-weight:600;display:inline-flex}.btn{justify-content:center;align-items:center;gap:var(--space-sm);border-radius:var(--radius-sm);font-family:var(--font-family);font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;border:none;padding:10px 20px;font-weight:600;display:inline-flex}.btn:active{transform:scale(.97)}.btn--primary{background:var(--color-primary);color:var(--color-on-primary);border-radius:var(--radius-md)}.btn--primary:hover{background:var(--color-primary-active);box-shadow:0 4px 12px #cc785c33}.btn--outline{color:var(--color-text-primary);border:1px solid var(--color-border);background:0 0}.btn--outline:hover{background:var(--color-surface-hover);border-color:var(--color-text-tertiary)}.btn--danger{color:var(--color-danger);border:1px solid var(--color-danger);background:0 0}.btn--danger:hover{background:var(--color-danger);color:var(--color-text-inverse)}.btn--sm{font-size:var(--font-size-xs);padding:6px 12px}.btn--icon{border-radius:var(--radius-sm);padding:8px}.form-group{margin-bottom:var(--space-lg)}.form-label{font-size:var(--font-size-sm);color:var(--color-text-primary);margin-bottom:var(--space-sm);font-weight:600;display:block}.form-input,.form-textarea,.form-select{border:1px solid var(--color-border);border-radius:var(--radius-sm);width:100%;font-family:var(--font-family);font-size:var(--font-size-base);color:var(--color-text-primary);background:var(--color-surface);transition:all var(--transition-fast);outline:none;padding:10px 14px}.form-input:focus,.form-textarea:focus,.form-select:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px #21212114}.form-input::placeholder,.form-textarea::placeholder{color:var(--color-text-tertiary)}.form-textarea{resize:vertical;min-height:100px}.section-label{font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-tertiary);margin-bottom:var(--space-md);font-weight:700}.info-block{padding:var(--space-md) var(--space-lg);background:var(--color-bg);border-radius:var(--radius-md);border-left:3px solid var(--color-border);font-size:var(--font-size-base);color:var(--color-text-secondary);white-space:pre-wrap;line-height:1.7}.info-block--empty{color:var(--color-text-tertiary);font-style:italic}.month-picker{align-items:center;gap:var(--space-sm);display:flex}.month-picker__input{border:1px solid var(--color-border);border-radius:var(--radius-sm);font-family:var(--font-family);font-size:var(--font-size-sm);color:var(--color-text-primary);background:var(--color-surface);transition:all var(--transition-fast);outline:none;padding:8px 14px;font-weight:500}.month-picker__input:focus{border-color:var(--color-accent)}.page{padding:var(--space-xl) 0 var(--space-3xl)}.page__header{margin-bottom:var(--space-xl)}.page__title{font-size:var(--font-size-2xl);letter-spacing:-.03em;font-weight:800;line-height:1.2}.page__description{font-size:var(--font-size-base);color:var(--color-text-secondary);margin-top:var(--space-sm)}.page__actions{gap:var(--space-sm);margin-top:var(--space-md);flex-wrap:wrap;display:flex}.section-gap{margin-top:var(--space-xl)}.empty-state{text-align:center;padding:var(--space-3xl) var(--space-lg)}.empty-state__icon{margin-bottom:var(--space-md);opacity:.3;font-size:3rem}.empty-state__title{font-size:var(--font-size-lg);color:var(--color-text-secondary);margin-bottom:var(--space-sm);font-weight:700}.empty-state__text{font-size:var(--font-size-sm);color:var(--color-text-tertiary)}.login-page{background-color:var(--color-canvas);min-height:100vh;padding:var(--space-lg);justify-content:center;align-items:center;display:flex}.login-card{background:var(--color-surface-card);border-radius:var(--radius-xl);border:1px solid var(--color-hairline);width:100%;max-width:400px;box-shadow:var(--shadow-lg);text-align:center;padding:48px}.login-card__header{margin-bottom:var(--space-xl)}.login-card__title{margin-bottom:var(--space-xs);font-size:1.75rem}.login-card__subtitle{color:var(--color-muted);font-size:.875rem}.login-form{text-align:left}.login-error{color:#b91c1c;border-radius:var(--radius-md);margin-bottom:var(--space-lg);background:#fee2e2;border:1px solid #fecaca;padding:12px;font-size:.8125rem;font-weight:500}.btn--full{width:100%;margin-top:var(--space-md);padding:12px}.login-card__footer{margin-top:var(--space-xl);padding-top:var(--space-lg);border-top:1px solid var(--color-hairline)}.login-back-link{color:var(--color-muted);font-size:.8125rem}.toast{bottom:var(--space-lg);right:var(--space-lg);padding:var(--space-md) var(--space-lg);background:var(--color-accent);color:var(--color-text-inverse);border-radius:var(--radius-md);font-size:var(--font-size-sm);box-shadow:var(--shadow-xl);z-index:1000;font-weight:500;animation:.3s cubic-bezier(.4,0,.2,1) toast-in;position:fixed}.toast--success{background:var(--color-success)}.toast--error{background:var(--color-danger)}@keyframes toast-in{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.modal-overlay{background:var(--color-overlay);z-index:200;padding:var(--space-md);justify-content:center;align-items:center;animation:.2s fade-in;display:flex;position:fixed;inset:0}.modal{background:var(--color-surface);border-radius:var(--radius-lg);padding:var(--space-xl);width:100%;max-width:520px;max-height:90vh;box-shadow:var(--shadow-xl);animation:.25s cubic-bezier(.4,0,.2,1) modal-in;overflow-y:auto}.modal__header{margin-bottom:var(--space-lg);justify-content:space-between;align-items:center;display:flex}.modal__title{font-size:var(--font-size-lg);font-weight:700}.modal__close{border-radius:var(--radius-sm);cursor:pointer;width:32px;height:32px;font-size:var(--font-size-lg);color:var(--color-text-tertiary);transition:all var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;display:flex}.modal__close:hover{background:var(--color-surface-hover);color:var(--color-text-primary)}.modal__actions{gap:var(--space-sm);margin-top:var(--space-lg);padding-top:var(--space-md);border-top:1px solid var(--color-border-light);justify-content:flex-end;display:flex}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes modal-in{0%{opacity:0;transform:scale(.95)translateY(8px)}to{opacity:1;transform:scale(1)translateY(0)}}.tabs{background:var(--color-bg);border-radius:var(--radius-md);border:1px solid var(--color-border);gap:2px;width:fit-content;padding:3px;display:flex}.tab{border-radius:var(--radius-sm);font-family:var(--font-family);font-size:var(--font-size-sm);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;padding:8px 18px;font-weight:500}.tab:hover{color:var(--color-text-primary)}.tab--active{background:var(--color-surface);color:var(--color-text-primary);box-shadow:var(--shadow-sm);font-weight:600}.skeleton{background:linear-gradient(90deg, var(--color-bg) 25%, var(--color-border-light) 50%, var(--color-bg) 75%);border-radius:var(--radius-sm);background-size:200% 100%;animation:1.5s ease-in-out infinite skeleton-wave}.skeleton--text{height:16px;margin-bottom:var(--space-sm)}.skeleton--title{width:200px;height:28px;margin-bottom:var(--space-md)}.skeleton--block{height:120px}@keyframes skeleton-wave{0%{background-position:200% 0}to{background-position:-200% 0}}.confirm-text{font-size:var(--font-size-base);color:var(--color-text-secondary);line-height:1.6}@media (max-width:768px){:root{--space-lg:16px;--space-xl:24px;--space-2xl:32px;--space-3xl:48px}.page__title{font-size:var(--font-size-xl)}.stat-grid{grid-template-columns:1fr 1fr}.app-header__nav{gap:var(--space-xs)}.app-header__link{padding:var(--space-sm) var(--space-sm);font-size:var(--font-size-xs)}.tabs{width:100%}.tab{text-align:center;flex:1;padding:8px 12px}}@media (max-width:480px){.stat-grid{grid-template-columns:1fr}.page__actions{flex-direction:column}.page__actions .btn{width:100%}.modal{padding:var(--space-md)}}
