@import"https://fonts.googleapis.com/css2?family=IBM+Plex+Sans+Thai:wght@400;500;600;700&display=swap";:root{--bg: #f3f5f2;--text: #15211c;--muted: #6c7a72;--line: #e6eae5;--card: #ffffff;--primary: #137a52;--primary-dark: #0e5e3f;--primary-soft: #e4f1ea;--primary-glow: rgba(19, 122, 82, .28);--income: #1f8a5b;--expense: #c1453a;--sb-bg: #0f1c17;--sb-text: #dfe8e2;--sb-muted: #8aa097;--sb-border: rgba(255, 255, 255, .07);--sb-card: rgba(255, 255, 255, .05);--sb-active: rgba(255, 255, 255, .09);color:var(--text);background:var(--bg);font-family:IBM Plex Sans Thai,system-ui,-apple-system,Segoe UI,sans-serif;-webkit-font-smoothing:antialiased}*{box-sizing:border-box}body{margin:0}button,input,select,textarea{font:inherit}@keyframes ml-fadeUp{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}@keyframes ml-modalIn{0%{opacity:0;transform:translateY(24px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes ml-backdrop{0%{opacity:0}to{opacity:1}}.workspace-gate{min-height:100vh;display:grid;place-items:center;padding:24px}.workspace-card{width:min(420px,100%);background:var(--card);border:1px solid var(--line);border-radius:18px;padding:28px;box-shadow:0 20px 60px #101d1a14}.workspace-card h1{margin:4px 0 12px}.workspace-card label{display:block;margin:18px 0 8px;font-weight:600}.workspace-card input{width:100%;border:1.5px solid var(--line);border-radius:12px;padding:12px 13px;background:#fafbfa}.workspace-card button{width:100%;margin-top:16px;padding:13px;border:0;border-radius:12px;cursor:pointer;font-weight:700;color:#fff;background:var(--primary);box-shadow:0 6px 18px var(--primary-glow)}.form-error{color:var(--expense);font-weight:600}.eyebrow{color:var(--muted);font-size:11px;font-weight:700;letter-spacing:.6px;text-transform:uppercase}.muted{color:var(--muted)}.app-shell{display:flex;min-height:100vh}.sidebar{width:240px;flex:none;position:sticky;top:0;height:100vh;display:flex;flex-direction:column;gap:6px;padding:22px 16px;background:var(--sb-bg);color:var(--sb-text);border-right:1px solid var(--sb-border)}.sb-brand{display:flex;align-items:center;gap:11px;padding:6px 8px 20px}.sb-mark{width:34px;height:34px;flex:none;border-radius:10px;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:17px;box-shadow:0 4px 14px var(--primary-glow)}.sb-brand-title{font-weight:700;font-size:15px}.sb-brand-sub{font-size:11px;opacity:.55;font-weight:500}.sb-label{font-size:10.5px;font-weight:700;letter-spacing:1px;opacity:.4;padding:6px 10px}.sidebar nav{display:flex;flex-direction:column;gap:4px}.sidebar nav button{display:flex;align-items:center;gap:12px;width:100%;border:0;cursor:pointer;text-align:left;padding:10px 11px;border-radius:11px;font-size:14px;font-weight:500;color:var(--sb-text);background:transparent;transition:background .18s ease,color .18s ease}.sidebar nav button svg{width:18px;height:18px;flex:none;opacity:.6}.sidebar nav button:hover{background:var(--sb-card)}.sidebar nav button.active{background:var(--sb-active);color:#fff;font-weight:600}.sidebar nav button.active svg{opacity:1}.sb-foot{margin-top:auto;display:flex;flex-direction:column;gap:10px}.sb-workspace{padding:13px;border-radius:13px;background:var(--sb-card);border:1px solid var(--sb-border)}.sb-workspace span{font-size:10.5px;font-weight:700;letter-spacing:.6px;opacity:.5}.sb-workspace strong{display:flex;align-items:center;gap:8px;margin-top:7px;font-weight:600;font-size:13.5px}.sb-dot{width:8px;height:8px;border-radius:50%;background:var(--primary);box-shadow:0 0 0 3px var(--primary-glow)}.sb-user{display:flex;align-items:center;gap:10px;padding:4px 8px}.sb-avatar{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:13px}.sb-user-name{font-size:13px;font-weight:600}.sb-user-role{font-size:11px;opacity:.5}.content-shell{flex:1;min-width:0;display:flex;flex-direction:column}.app-header{position:sticky;top:0;z-index:5;display:flex;align-items:center;gap:18px;padding:18px 30px;background:#f3f5f2d1;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}.app-header h1{margin:0;font-size:21px;font-weight:700;letter-spacing:-.2px}.app-header p{margin:3px 0 0;font-size:13px;color:var(--muted)}.header-search{display:flex;align-items:center;gap:9px;padding:9px 13px;border-radius:11px;background:#fff;border:1px solid #e3e8e2;width:230px}.header-search svg{width:15px;height:15px;opacity:.4;flex:none}.header-search input{border:0;outline:0;background:transparent;width:100%;font-size:13.5px;color:var(--text)}.page-body{flex:1;padding:26px 30px 48px}.panel{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:22px;box-shadow:0 1px 2px #14281e0a}.panel h2{margin:0;font-size:16px;font-weight:700}.panel-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}.filters{display:flex;align-items:center;gap:10px}.inline-filter{display:inline-flex;align-items:center;gap:6px;color:var(--muted);font-size:13px}.primary-action{display:flex;align-items:center;gap:8px;border:0;cursor:pointer;padding:11px 17px;border-radius:11px;font-size:14px;font-weight:600;color:#fff;background:var(--primary);box-shadow:0 6px 18px var(--primary-glow);transition:transform .15s ease}.primary-action:hover{transform:translateY(-1px)}.primary-action svg{width:16px;height:16px}.income{color:var(--income);font-weight:700}.expense{color:var(--expense);font-weight:700}.dashboard-grid,.stack{display:flex;flex-direction:column;gap:18px}.hero-row,.controls-row{display:flex;align-items:center;justify-content:space-between;gap:12px}.kpi-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px}.kpi{padding:18px;border-radius:16px;background:var(--card);border:1px solid var(--line);box-shadow:0 1px 2px #14281e0a;animation:ml-fadeUp .5s ease both}.kpi-top{display:flex;align-items:center;justify-content:space-between}.kpi span{font-size:12.5px;font-weight:600;color:var(--muted)}.kpi-icon{width:30px;height:30px;border-radius:9px;display:flex;align-items:center;justify-content:center;background:var(--primary-soft);color:var(--primary)}.kpi-icon svg{width:16px;height:16px}.kpi strong{display:block;margin-top:13px;font-size:27px;font-weight:700;letter-spacing:-.5px;font-variant-numeric:tabular-nums}.chart-row{display:grid;grid-template-columns:1.55fr 1fr;gap:18px}.chart-legend{display:flex;gap:14px;font-size:12px;color:var(--muted)}.chart-legend span{display:flex;align-items:center;gap:6px}.chart-legend i{width:9px;height:9px;border-radius:3px;display:inline-block}.bar-chart{display:flex;align-items:flex-end;justify-content:space-between;gap:8px;height:180px;padding-top:18px}.bar-pair{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px;height:100%;justify-content:flex-end}.bar-pair>div{display:flex;align-items:flex-end;gap:3px;height:100%;width:100%;justify-content:center}.bar{width:9px;min-height:2px;border-radius:5px 5px 0 0}.bar-pair small{font-size:11px;color:#9aa49c;font-weight:500}.income-bar{background:var(--income)}.expense-bar{background:var(--expense)}.cat-list{display:flex;flex-direction:column;gap:15px}.cat-line .cat-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px;font-size:13px}.cat-line .cat-name{display:flex;align-items:center;gap:8px;font-weight:500}.cat-line .cat-name i{width:9px;height:9px;border-radius:3px}.cat-line .cat-amount{font-weight:600;font-variant-numeric:tabular-nums}.cat-track{height:7px;border-radius:5px;background:#eef1ed;overflow:hidden}.cat-fill{height:100%;border-radius:5px;transition:width .9s cubic-bezier(.2,.7,.2,1)}.category-line{display:flex;justify-content:space-between;border-bottom:1px solid #f1f3ef;padding:11px 0}.recent-list{display:flex;flex-direction:column}.txn-row{display:flex;align-items:center;gap:14px;padding:12px 0;border-top:1px solid #f1f3ef;transition:background .15s ease}.recent-list .txn-row:first-child{border-top:0}.txn-avatar{width:38px;height:38px;flex:none;border-radius:11px;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px}.txn-main{flex:1;min-width:0}.txn-desc{font-size:14px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.txn-meta{font-size:12px;color:#8a968e;margin-top:2px}.txn-amount{font-size:15px;font-weight:700;font-variant-numeric:tabular-nums;min-width:96px;text-align:right}.receipt-chip{font-size:11px;font-weight:600;color:var(--primary);background:var(--primary-soft);padding:3px 8px;border-radius:7px}.link-button{border:0;background:transparent;cursor:pointer;font-size:13px;font-weight:600;color:var(--primary)}.transaction-table{width:100%;border-collapse:collapse;font-size:13.5px}.transaction-table th,.transaction-table td{border-bottom:1px solid #f1f3ef;padding:13px 12px;text-align:left}.transaction-table th{background:#f8faf7;color:#8a968e;font-size:11.5px;font-weight:700;letter-spacing:.4px}.transaction-table tbody tr:hover{background:#f8faf7}.cell-item{display:flex;align-items:center;gap:12px}.cell-item .txn-avatar{width:34px;height:34px;border-radius:10px;font-size:13px}.table-action{border:1px solid var(--line);border-radius:9px;padding:6px 10px;margin-right:6px;font-size:12px;font-weight:600;cursor:pointer;background:#fff;color:#46524b}.table-action.danger{color:var(--expense);border-color:#f0d7d4;background:#fbeae8}.modal-backdrop{position:fixed;inset:0;z-index:50;background:#0f1c176b;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:24px;animation:ml-backdrop .2s ease}.modal{width:520px;max-width:100%;max-height:90vh;overflow:auto;background:#fff;border-radius:20px;padding:26px;box-shadow:0 30px 80px #0f1c174d;animation:ml-modalIn .28s cubic-bezier(.2,.8,.2,1)}.modal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.modal-head h2{margin:0;font-size:19px;font-weight:700}.modal-close{width:32px;height:32px;border:0;cursor:pointer;border-radius:9px;background:#f1f3ef;color:var(--muted);font-size:18px}.transaction-form{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.transaction-form label{display:grid;gap:7px;font-size:13px;font-weight:600;color:#46524b}.transaction-form input,.transaction-form select,.transaction-form textarea,.filters select{border:1.5px solid #e3e8e2;border-radius:12px;padding:12px 13px;background:#fafbfa;color:var(--text);outline:0}.transaction-form button{grid-column:1 / -1;border:0;border-radius:12px;padding:14px;color:#fff;background:var(--primary);font-weight:700;font-size:15px;cursor:pointer;box-shadow:0 6px 18px var(--primary-glow)}.transaction-form h2{grid-column:1 / -1;margin:0}textarea{width:100%;min-height:110px;font-family:inherit}.wallet-grid,.wallet-tools{display:grid;gap:16px;grid-template-columns:repeat(2,minmax(0,1fr))}.wallet-card{display:grid;gap:6px;padding:22px;border-radius:18px;border:1px solid var(--line);background:#fff;box-shadow:0 1px 2px #14281e0a}.wallet-card-head{display:flex;justify-content:space-between;align-items:flex-start;gap:8px}.wallet-card h2{margin:2px 0 0;font-size:15px}.wallet-card>strong{font-size:28px;font-weight:700;letter-spacing:-.6px;font-variant-numeric:tabular-nums}.wallet-card span{color:var(--muted);font-size:12px;font-weight:600}.wallet-card dl{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin:10px 0 0}.wallet-card dt,.wallet-card dd{margin:0}.wallet-card dt{color:var(--muted);font-size:11px}.wallet-card dd{font-weight:600;font-variant-numeric:tabular-nums}.transfer-list{display:grid;gap:4px}.transfer-row{display:flex;align-items:center;justify-content:space-between;gap:12px;border-top:1px solid #f1f3ef;padding:12px 0}.transfer-row p{margin:3px 0 0;color:var(--muted);font-size:12px}.year-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px}.month-cell{border:1px solid var(--line);border-radius:14px;padding:16px;display:flex;justify-content:space-between}.report-controls{display:flex;gap:16px;flex-wrap:wrap}.report-controls label{display:grid;gap:7px;font-size:13px;font-weight:600;color:#46524b}.report-controls input,.report-controls select{width:140px;border:1.5px solid #e3e8e2;border-radius:12px;padding:12px 13px;background:#fafbfa;color:var(--text);outline:0}.export-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.export-grid label{display:grid;gap:7px;font-size:12px;font-weight:700;letter-spacing:.4px;color:var(--muted)}.export-grid textarea{margin-top:0;min-height:150px;border-radius:12px;border:1.5px solid #e3e8e2;background:#fafbfa;font-family:Cascadia Code,SFMono-Regular,Consolas,monospace;font-size:12px;resize:vertical}@media(max-width:860px){.export-grid{grid-template-columns:1fr}}.receipt-list{display:grid;gap:12px}.receipt-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:12px;align-items:center;padding:16px;border:1px solid var(--line);border-radius:14px;background:#fff}.receipt-row p{margin:4px 0 0;color:var(--muted)}.receipt-actions,.receipt-links{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end}.receipt-links a{color:var(--primary);font-weight:600;text-decoration:none}.receipt-status-success{grid-column:1 / -1;margin:0;color:var(--income);font-weight:600}.receipt-status-error{margin:0;color:var(--expense);font-weight:600}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.api-docs h2{margin-top:0}.api-docs pre{max-width:100%;overflow-x:auto;border:1px solid var(--line);border-radius:12px;padding:12px;background:var(--sb-bg);color:var(--sb-text)}.api-docs code{font-family:Cascadia Code,SFMono-Regular,Consolas,monospace;font-size:13px}.api-docs-hero{align-items:flex-start}.api-docs-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.api-definition-list{display:grid;gap:8px;margin:0}.api-definition-list dt{font-weight:700}.api-definition-list dd{margin:0 0 8px;color:var(--muted)}.api-endpoint-list{display:grid;gap:10px}.api-endpoint{display:grid;gap:6px;border:1px solid var(--line);border-radius:12px;padding:12px;background:#f8faf7}.api-endpoint div{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.api-endpoint p{margin:0}.api-method,.api-pill{display:inline-flex;align-items:center;border-radius:999px;padding:3px 8px;color:#fff;font-size:12px;font-weight:700}.api-method-get{background:var(--income)}.api-method-post{background:#1f5f7a}.api-method-patch{background:#8a6b21}.api-method-delete{background:var(--expense)}.api-pill{color:var(--primary);background:var(--primary-soft)}.api-checklist{display:grid;gap:10px;padding-left:20px}.api-error-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.api-error-grid div{display:grid;gap:4px;border:1px solid var(--line);border-radius:12px;padding:10px;background:#f8faf7}.api-error-grid span{color:var(--muted)}@media(max-width:860px){.app-shell{flex-direction:column}.sidebar{width:100%;height:auto;position:static;flex-direction:row;flex-wrap:wrap}.sidebar nav{flex-direction:row;flex-wrap:wrap}.sb-foot{display:none}.kpi-grid,.chart-row,.wallet-grid,.wallet-tools,.year-grid,.api-docs-grid,.api-error-grid{grid-template-columns:1fr}.app-header{flex-wrap:wrap}.header-search{width:100%;order:3}.receipt-row{grid-template-columns:1fr}}
