.app{height:100dvh;max-height:100dvh;display:flex;flex-direction:column;max-width:480px;margin:0 auto;background:var(--bg);overflow:hidden}.main{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;padding:16px 20px 24px;-webkit-overflow-scrolling:touch}.page-title{font-size:1.75rem;font-weight:700;color:var(--text);margin:0 0 4px}.page-subtitle{font-size:.9375rem;color:var(--muted);margin:0 0 20px}.home-header{text-align:center;margin-bottom:20px}.home-title{margin-bottom:4px}.home-title-en{margin:0;font-size:.9375rem;font-weight:600;color:var(--muted);letter-spacing:.06em}.card{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:18px;margin-bottom:14px}.card-label{font-size:.8125rem;color:var(--muted);margin-bottom:6px}.card-value{font-size:1.5rem;font-weight:700;color:var(--text)}.row{display:flex;gap:12px}.row .card{flex:1}.income{color:var(--income)}.expense{color:var(--expense)}.error-text{color:var(--expense);margin-bottom:12px}.status-text{text-align:center;color:var(--primary);margin-bottom:8px}.empty-text{text-align:center;color:var(--muted);margin-top:40px}.btn-primary{width:100%;margin-top:12px;padding:14px;border:none;border-radius:12px;background:var(--primary);color:#fff;font-size:1rem;font-weight:600;cursor:pointer}.btn-primary:disabled,.btn-secondary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{width:100%;padding:12px;border:none;border-radius:12px;background:#eef2ff;color:var(--primary-dark);font-size:.9375rem;font-weight:600;cursor:pointer}.input{width:100%;min-height:72px;padding:12px;border:1px solid var(--border);border-radius:12px;font-size:.9375rem;font-family:inherit;resize:vertical;margin-bottom:12px;box-sizing:border-box}.mic-area{display:flex;justify-content:center;margin-bottom:16px}.mic-button{width:160px;height:160px;border:none;border-radius:50%;background:var(--primary);color:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;box-shadow:0 6px 20px #2563eb40;cursor:pointer;touch-action:none;user-select:none;-webkit-user-select:none}.mic-button.active{background:var(--mic-active);transform:scale(1.05)}.mic-icon{font-size:2.625rem;margin-bottom:8px}.mic-label{font-size:1rem;font-weight:600}.tabs{flex-shrink:0;display:flex;overflow-x:auto;border-top:1px solid var(--border);background:var(--card);padding:4px 0 calc(4px + env(safe-area-inset-bottom));box-shadow:0 -2px 12px #0f172a0f;z-index:100;-webkit-overflow-scrolling:touch;scrollbar-width:none}.tabs::-webkit-scrollbar{display:none}.tab{flex:1;min-width:3.5rem;display:flex;flex-direction:column;align-items:center;gap:2px;padding:4px 2px;border:none;background:none;color:var(--muted);font-size:.5625rem;font-weight:600;cursor:pointer}.tab.active{color:var(--primary)}.tab-icon{font-size:1.0625rem;line-height:1}.tx-group{margin-bottom:20px}.tx-group-header{display:flex;align-items:center;justify-content:space-between;gap:12px;width:100%;margin:8px 0 12px;padding:10px 4px;border:none;border-radius:10px;background:transparent;color:inherit;font:inherit;text-align:left;cursor:pointer;-webkit-tap-highlight-color:transparent}.tx-group-header:active{background:#0000000a}.tx-group-header-main{display:flex;align-items:center;gap:8px;min-width:0}.tx-group-chevron{flex-shrink:0;width:1rem;font-size:.6875rem;color:var(--muted)}.tx-group-summary{display:flex;flex-direction:column;align-items:flex-end;gap:2px;flex-shrink:0}.tx-group-summary-income{font-size:.8125rem;font-weight:600;color:var(--income)}.tx-group-summary-expense{font-size:.8125rem;font-weight:600;color:var(--expense)}.tx-group-title{margin:0;font-size:1rem;font-weight:700;color:var(--text)}.tx-group-count{font-size:.75rem;color:var(--muted)}.tx-category-group{margin:0 0 10px 10px;padding-left:10px;border-left:2px solid var(--border)}.tx-category-header{display:flex;align-items:center;justify-content:space-between;gap:12px;width:100%;margin:0 0 8px;padding:8px 4px;border:none;border-radius:10px;background:transparent;color:inherit;font:inherit;text-align:left;cursor:pointer;-webkit-tap-highlight-color:transparent}.tx-category-header:active{background:#0000000a}.tx-category-header-main{display:flex;align-items:center;gap:8px;min-width:0}.tx-category-name{font-size:.9375rem;font-weight:700;color:var(--text)}.tx-category-header-meta{display:flex;flex-direction:column;align-items:flex-end;gap:2px;flex-shrink:0}.tx-category-total{font-size:.875rem;font-weight:700;white-space:nowrap}.tx-card-detail{margin-left:4px;margin-bottom:10px;padding:14px 16px}.tx-card-detail .tx-category{font-size:.9375rem}.tx-row{display:flex;gap:12px;align-items:flex-start}.tx-category{font-size:1rem;font-weight:600}.tx-desc{font-size:.875rem;color:var(--muted);margin-top:2px}.tx-date{font-size:.75rem;color:var(--muted);margin-top:6px}.tx-amount{font-size:1.125rem;font-weight:700;white-space:nowrap}.tx-raw{margin-top:10px;font-size:.8125rem;color:var(--muted);font-style:italic}.tx-hint{margin-top:8px;font-size:.6875rem;color:var(--muted)}.tx-card{cursor:pointer}.loading{text-align:center;padding:40px;color:var(--primary)}.tip-title{font-size:.9375rem;font-weight:600;margin-bottom:8px}.tip-text{font-size:.875rem;line-height:1.6;color:var(--muted)}.browser-tip{background:#fffbeb;border:1px solid #fcd34d;border-radius:12px;padding:12px;font-size:.8125rem;color:#92400e;margin-bottom:14px;line-height:1.5}.section-title{display:flex;align-items:center;justify-content:space-between;font-size:.875rem;font-weight:700;color:var(--text);margin:4px 0 10px}.summary-section-btn{display:block;width:100%;margin:0 0 4px;padding:0;border:none;background:transparent;color:inherit;font:inherit;text-align:left;cursor:pointer;-webkit-tap-highlight-color:transparent}.summary-section-btn:active .card{opacity:.88}.section-link-hint{font-size:.75rem;font-weight:500;color:var(--primary)}.period-toggle{display:flex;gap:8px;margin-bottom:16px}.history-toggle{margin-top:-4px}.history-year-picker{margin-bottom:12px}.period-toggle button{flex:1;padding:10px;border-radius:12px;border:1px solid var(--border);background:var(--card);color:var(--muted);font-weight:600;cursor:pointer}.period-toggle button.active{background:var(--primary);border-color:var(--primary);color:#fff}.balance-note{margin:10px 0 0;font-size:.75rem;color:var(--muted);line-height:1.5}.balance-hero{display:flex;gap:12px;margin-bottom:14px}.balance-hero-card{flex:1;min-width:0;margin-bottom:0;padding:16px 14px}.balance-hero-value{font-size:1.375rem;line-height:1.2;word-break:break-word}.balance-hero-card .balance-note{margin-top:8px;font-size:.6875rem}.balance-hero-footnote{margin:-6px 0 14px;padding:0 4px}.tx-badge{display:inline-block;margin-left:8px;padding:2px 8px;border-radius:999px;background:#eef2ff;color:var(--primary-dark);font-size:.6875rem;font-weight:600;vertical-align:middle}.chart-card{padding-bottom:12px}.chart-wrap{margin-top:4px}.chart-empty{text-align:center;color:var(--muted);font-size:.875rem;padding:32px 8px;margin:0}.chart-legend{display:flex;justify-content:center;gap:20px;margin-top:8px;font-size:.75rem;color:var(--muted)}.legend-item{display:inline-flex;align-items:center;gap:6px}.legend-line{display:inline-block;width:18px;height:0;border-top-width:2px;border-top-style:solid}.legend-line.balance{border-top-color:var(--primary)}.legend-line.expense{border-top-color:var(--expense);border-top-style:dashed}.legend-swatch{display:inline-block;width:10px;height:10px;border-radius:2px}.legend-swatch.income{background:var(--income)}.legend-swatch.expense{background:#fca5a5}.analysis-table-card{padding:0;overflow:hidden}.analysis-table{width:100%;border-collapse:collapse;font-size:.8125rem}.analysis-table th,.analysis-table td{padding:12px 10px;text-align:right;border-bottom:1px solid var(--border)}.analysis-table th:first-child,.analysis-table td:first-child{text-align:left;padding-left:16px}.analysis-table th:last-child,.analysis-table td:last-child{padding-right:16px}.analysis-table th{color:var(--muted);font-weight:600;background:#f8fafc}.analysis-table tbody tr{cursor:pointer}.analysis-table tbody tr.selected{background:#eff6ff}.analysis-table tbody tr:active{background:#f1f5f9}.year-picker{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}.year-picker button{padding:8px 14px;border-radius:999px;border:1px solid var(--border);background:var(--card);color:var(--muted);font-size:.8125rem;font-weight:600;cursor:pointer}.year-picker button.active{background:var(--primary);border-color:var(--primary);color:#fff}.modal-backdrop{position:fixed;inset:0;z-index:200;display:flex;align-items:flex-start;justify-content:center;padding:10dvh 16px 16px;overflow:hidden;overscroll-behavior:contain;touch-action:none;background:#0f172a73}.modal-card{display:flex;flex-direction:column;width:100%;max-width:480px;max-height:min(72dvh,520px);overflow:hidden;border-radius:16px;background:var(--card);box-shadow:0 12px 40px #0f172a2e}.modal-header{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-shrink:0;padding:16px 20px 12px;border-bottom:1px solid var(--border)}.modal-title{margin:0;font-size:1.0625rem;font-weight:700}.modal-close{flex-shrink:0;width:32px;height:32px;padding:0;border:none;border-radius:999px;background:var(--bg);color:var(--muted);font-size:.875rem;line-height:1;cursor:pointer}.modal-close:disabled{opacity:.6;cursor:not-allowed}.modal-body{flex:1;min-height:0;overflow-y:auto;padding:14px 20px;-webkit-overflow-scrolling:touch;touch-action:pan-y}.modal-footer{flex-shrink:0;display:flex;flex-direction:column;gap:8px;padding:12px 20px 16px;border-top:1px solid var(--border);background:var(--card)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}.form-field{margin-bottom:12px}.form-row .form-field{margin-bottom:0}.form-row+.form-field,.form-field+.form-row{margin-top:12px}.form-label{display:block;margin-bottom:6px;font-size:.8125rem;font-weight:600;color:var(--muted)}.form-input,.form-select{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:12px;background:#fff;color:var(--text);font-size:1rem}.form-select{appearance:none}.modal-note{margin:0 0 12px;font-size:.8125rem;color:var(--muted);line-height:1.5}.modal-actions-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}.modal-actions-row .btn-primary,.modal-actions-row .btn-secondary,.modal-footer .btn-danger{margin-top:0}.btn-danger{width:100%;padding:12px;border:none;border-radius:12px;background:#fef2f2;color:var(--expense);font-size:.9375rem;font-weight:600;cursor:pointer}.btn-danger:disabled{opacity:.6;cursor:not-allowed}.loading-screen{min-height:100dvh;display:grid;place-items:center;font-size:1rem;color:var(--muted)}.member-bar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 16px 0}.demo-banner{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 16px;background:linear-gradient(135deg,#eff6ff,#fef9c3);border-bottom:1px solid #bfdbfe}.demo-banner__text{display:flex;flex-direction:column;gap:2px;font-size:.8125rem;color:var(--text)}.demo-banner__text strong{font-size:.875rem}.demo-banner__text span{color:var(--muted)}.demo-banner__login{flex-shrink:0;border:none;border-radius:999px;padding:8px 14px;background:var(--primary);color:#fff;font-size:.8125rem;font-weight:700;cursor:pointer}.login-overlay{position:fixed;inset:0;z-index:10000;background:#0f172a73;overflow-y:auto}.login-cancel{display:block;margin:0 0 12px auto;border:none;background:transparent;color:var(--primary);font-size:.875rem;font-weight:600;cursor:pointer}.member-bar__name{font-size:.875rem;font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.member-bar__logout{flex-shrink:0;border:1px solid var(--border);background:var(--card);color:var(--primary);border-radius:999px;padding:6px 12px;font-size:.8125rem;font-weight:600;cursor:pointer}.login-page{min-height:100dvh;display:grid;place-items:center;padding:24px 20px;background:radial-gradient(circle at top,rgba(37,99,235,.12),transparent 55%),var(--bg)}.login-card{width:min(100%,360px);background:var(--card);border:2px solid var(--border);border-radius:24px;padding:28px 22px;box-shadow:0 12px 30px #0f172a14}.login-title{margin:0 0 6px;text-align:center;font-size:2rem}.login-subtitle,.login-message{margin:0 0 16px;text-align:center;color:var(--muted);font-size:.9375rem}.login-message{min-height:2.8em}.login-actions{display:grid;gap:10px}.btn-login{width:100%;padding:14px 16px;border:2px solid var(--border);border-radius:16px;background:#fff;font-size:1rem;font-weight:700;cursor:pointer}.btn-login:disabled{opacity:.65;cursor:not-allowed}.btn-login--google{color:#1d4ed8}.btn-login--line{color:#15803d}.login-retry-btn{margin-top:12px}.login-dev{margin-top:18px;padding-top:18px;border-top:1px dashed var(--border)}.login-dev-row{display:grid;grid-template-columns:1fr auto;gap:8px;margin-top:8px}.ptr{position:relative;min-height:100%;min-height:100dvh;width:100%;--ptr-fg: #1e3a8a;--ptr-line: #94a3b8}.ptr__rail{position:fixed;left:50%;transform:translate(-50%);width:min(100%,480px);top:0;z-index:9000;pointer-events:none;background:linear-gradient(to bottom,rgba(37,99,235,.12),rgba(37,99,235,.02) 60%,transparent);transition:opacity .15s ease}.ptr__hint{position:fixed;z-index:9001;top:10px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:8px;font-size:13px;line-height:1.2;color:var(--ptr-fg);user-select:none;-webkit-user-select:none;pointer-events:none;text-shadow:0 0 1px #fff,0 0 2px #fff,0 0 3px #fff}.ptr__text{white-space:nowrap;letter-spacing:.02em}.ptr__icon{display:block;width:0;height:0;border-left:6px solid transparent;border-right:6px solid transparent;border-top:9px solid var(--ptr-line);border-bottom:0;flex-shrink:0;transition:transform .15s ease;transform:rotate(0)}.ptr__icon--flip{transform:rotate(180deg);border-top-color:var(--primary)}.ptr__spinner{display:block;width:16px;height:16px;flex-shrink:0;border:2px solid #cbd5e1;border-top-color:var(--primary);border-radius:50%;animation:ptrspin .6s linear infinite}.ptr--loading .ptr__spinner{border-top-color:var(--primary-dark)}@keyframes ptrspin{to{transform:rotate(360deg)}}.ptr__content{min-height:100dvh;will-change:transform}:root{--bg: #f4f7fb;--card: #ffffff;--primary: #2563eb;--primary-dark: #1d4ed8;--income: #059669;--expense: #dc2626;--text: #0f172a;--muted: #64748b;--border: #e2e8f0;--mic-active: #ef4444}*{box-sizing:border-box}html,body,#root{margin:0;height:100%;overflow:hidden}html,body{overscroll-behavior-y:none}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Noto Sans TC,sans-serif;background:var(--bg);color:var(--text);-webkit-tap-highlight-color:transparent}button,input,textarea{font:inherit}
