@import "https://fonts.googleapis.com/css2?family=Outfit:wght@400;500;600;700;800&family=Noto+Sans+TC:wght@400;500;700&display=swap";:root{--font-ui:"Outfit", "Noto Sans TC", sans-serif;--bg:#f0f4f8;--bg-alt:#e6ecf4;--surface:#ffffffe0;--surface-solid:#fff;--surface-glass:#fff9;--line:#1e3a5c1a;--line-strong:#1e3a5c33;--text:#1a2f4a;--text-sub:#4b6180;--text-muted:#7a93ad;--primary:#006d80;--primary-light:#e0f4f7;--primary-soft:#006d801f;--primary-hover:#005768;--income:#0f7a52;--income-bg:#e8f7f1;--expense:#c0330d;--expense-bg:#fdeee9;--warning:#a06000;--warning-bg:#fef3e0;--investment:#4a47a3;--investment-bg:#eeedf8;--fx:#1565a0;--fx-bg:#e8f0fb;--transfer-bg:#f0f0f0;--transfer:#555;--shadow-sm:0 1px 4px #1122380f;--shadow:0 4px 16px #11223817;--shadow-lg:0 12px 40px #11223821;--radius-xs:6px;--radius-sm:10px;--radius-md:16px;--radius-lg:22px;--radius-xl:30px;--radius-pill:999px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{min-height:100%}body{font-family:var(--font-ui);color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-image:radial-gradient(at 10% 0,#0096b41f 0%,#0000 50%),radial-gradient(at 90% 100%,#ffb43c14 0%,#0000 50%);background-attachment:fixed;min-width:320px;font-size:15px;font-weight:400;line-height:1.55}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit}button{cursor:pointer}table{border-collapse:collapse}#root{padding:20px 18px}.app-shell{gap:18px;max-width:1400px;margin:0 auto;display:grid}.top-nav-shell{z-index:20;border:1px solid var(--line);border-radius:var(--radius-pill);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);box-shadow:var(--shadow);background:#fffc;align-items:center;gap:12px;padding:7px 10px 7px 18px;display:flex;position:sticky;top:14px}.site-name{letter-spacing:-.02em;color:var(--primary);white-space:nowrap;border-right:1.5px solid var(--line-strong);flex-shrink:0;margin-right:2px;padding-right:14px;font-size:1.1rem;font-weight:800}.top-nav-toggle{flex-wrap:nowrap;flex:1;gap:4px;display:flex}.top-nav-link{border-radius:var(--radius-pill);text-align:center;color:var(--text-sub);white-space:nowrap;flex:1;padding:10px 14px;font-size:.93rem;font-weight:600;transition:background .15s,color .15s}.top-nav-link:hover{color:var(--primary);background:var(--primary-soft)}.top-nav-link.active{color:var(--primary);background:var(--primary-soft);font-weight:700}.content{min-width:0}.page-grid{gap:18px;display:grid}.card{border:1px solid var(--line);border-radius:var(--radius-xl);background:var(--surface);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:var(--shadow);padding:22px}.card-header{justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;display:flex}.card-header h2{color:var(--text);margin:0;font-size:1rem;font-weight:700;line-height:1.2}.stat-card{border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--surface);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:var(--shadow-sm);gap:6px;padding:18px 20px;display:grid}.stat-card>span,.stat-card>.label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-size:.82rem;font-weight:600}.stat-card>strong{color:var(--text);font-size:clamp(1.15rem,2.5vw,1.65rem);font-weight:700;line-height:1.15}.stat-income>strong{color:var(--income)}.stat-expense>strong{color:var(--expense)}.stat-warning>strong{color:var(--warning)}.overview-stats-grid{grid-template-columns:repeat(2,1fr);gap:12px;display:grid}@media (width>=680px){.overview-stats-grid{grid-template-columns:repeat(4,1fr)}}.fx-stat-card{gap:8px;display:grid}.fx-breakdown{flex-direction:column;gap:2px;display:flex}.fx-line strong{color:var(--warning);font-size:1rem;font-weight:600}.overview-account-section+.overview-account-section{margin-top:18px}.overview-account-section-title{color:var(--text-soft);letter-spacing:.04em;margin:0 0 10px;font-size:.9rem;font-weight:700}.overview-account-list{gap:8px;display:grid}.overview-card-actions{align-items:center;gap:8px;display:flex}.overview-account-row{border-radius:var(--radius-sm);background:var(--bg-alt);border:1px solid var(--line);justify-content:space-between;align-items:center;gap:12px;padding:10px 14px;display:flex}.overview-account-row-dragging{box-shadow:var(--shadow);border-color:var(--primary)}.overview-account-actions{flex-shrink:0;align-items:center;gap:10px;display:flex}.account-name{color:var(--text);font-weight:500}.account-balance{color:var(--primary);white-space:nowrap;font-size:.95rem;font-weight:700}.account-reorder-handle{border:1px dashed var(--line-strong);border-radius:var(--radius-sm);background:var(--surface-solid);min-width:40px;min-height:36px;color:var(--text-sub);letter-spacing:.08em;touch-action:none;padding:6px 8px;font-size:1.05rem;font-weight:700;line-height:1}.account-reorder-handle:hover{background:var(--primary-soft);color:var(--primary);border-color:var(--primary)}.investment-list{gap:10px;display:grid}.investment-row{border-radius:var(--radius-md);background:var(--bg-alt);border:1px solid var(--line);gap:10px;padding:14px 16px;display:grid}.investment-summary-row{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;display:flex}.investment-summary-meta,.investment-card-actions{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.stock-name{color:var(--text);font-size:.97rem;font-weight:700}.stock-code{color:var(--text-muted);background:var(--line);border-radius:4px;width:fit-content;padding:1px 5px;font-family:Courier New,monospace;font-size:.8rem}.investment-metric-labels,.investment-metric-values{grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;display:grid}.metric-label{color:var(--text-muted);text-align:left;font-size:.75rem;font-weight:500}.investment-metric-values strong{text-align:left;font-size:.92rem;font-weight:700}.investment-cost-price{white-space:nowrap;font-size:.88rem}.pnl-positive{color:var(--expense)}.pnl-negative{color:var(--income)}.reports-toolbar{flex-wrap:nowrap;align-items:center;gap:12px;display:flex}.toolbar-period-field{white-space:nowrap;align-items:center;gap:8px;display:flex}.toolbar-period-field>span{color:var(--text-muted);font-size:.85rem;font-weight:600}.toolbar-period-field>select{border:1px solid var(--line-strong);border-radius:var(--radius-pill);background:var(--surface);min-height:44px;color:var(--text);min-width:110px;padding:9px 14px;font-size:.9rem}.reports-summary-grid{grid-template-columns:1fr;gap:14px;display:grid}.reports-top-stats{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.reports-top-stats .stat-card{min-width:0}.reports-chart-card{border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--surface);box-shadow:var(--shadow-sm);gap:10px;padding:18px 20px;display:grid}.reports-chart-header{justify-content:space-between;align-items:baseline;gap:12px;display:flex}.reports-chart-header h3{color:var(--text);font-size:.95rem;font-weight:700}.reports-chart-header span{color:var(--text-muted);font-size:.8rem}.reports-center-col{justify-content:center;align-items:center;min-width:0;display:flex}.investment-stat-card{border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--surface);box-shadow:var(--shadow-sm);gap:8px;padding:18px 20px;display:grid}.investment-stat-card>span{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-size:.82rem;font-weight:600}.investment-amounts{gap:6px;display:grid}.inv-line{justify-content:space-between;align-items:center;gap:8px;display:flex}.inv-line>span{color:var(--text-muted);font-size:.82rem}.inv-buy{color:var(--income);font-size:.95rem;font-weight:700}.inv-sell{color:var(--expense);font-size:.95rem;font-weight:700}.tx-section{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-xl);box-shadow:var(--shadow);padding:22px}.tx-section-header{align-items:baseline;gap:10px;margin-bottom:14px;display:flex}.tx-section-title{color:var(--text);font-size:1rem;font-weight:700}.tx-count{color:var(--text-muted);font-size:.82rem}.tx-filter-bar{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:10px;display:flex}.tx-filter-chip{border:1px solid var(--line-strong);border-radius:var(--radius-pill);background:var(--surface-solid);min-height:34px;color:var(--text-sub);justify-content:center;align-items:center;padding:5px 12px;font-size:.82rem;font-weight:600;transition:background .14s,color .14s,border-color .14s;display:inline-flex;position:relative;overflow:hidden}.tx-filter-chip:hover{background:var(--primary-soft);color:var(--primary)}.tx-filter-chip-active{background:var(--primary-soft);color:var(--primary);border-color:var(--primary)}.tx-filter-chip>select{opacity:0;cursor:pointer;width:100%;height:100%;position:absolute;inset:0}.tx-filter-chip>select:focus{outline:none}.tx-sort-bar{flex-wrap:wrap;align-items:center;gap:6px;margin-bottom:14px;display:flex}.sort-label{color:var(--text-muted);font-size:.8rem;font-weight:500}.sort-btn{border:1px solid var(--line-strong);border-radius:var(--radius-pill);background:var(--surface-solid);color:var(--text-sub);padding:5px 12px;font-size:.82rem;font-weight:600;transition:background .14s,color .14s}.sort-btn:hover{background:var(--primary-soft);color:var(--primary)}.sort-active{background:var(--primary-soft)!important;color:var(--primary)!important;border-color:var(--primary)!important}.tx-list{gap:8px;display:grid}.tx-empty{text-align:center;color:var(--text-muted);padding:20px 0}.tx-card{border:1px solid var(--line);border-radius:var(--radius-md);background:var(--surface-solid);gap:8px;padding:12px 16px;transition:box-shadow .15s;display:grid}.tx-card:hover{box-shadow:var(--shadow)}.tx-card-top{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.tx-meta{flex-wrap:wrap;align-items:center;gap:7px;display:flex}.tx-date{color:var(--text-muted);font-size:.82rem;font-weight:500}.tx-badge{border-radius:var(--radius-pill);letter-spacing:.02em;padding:2px 8px;font-size:.72rem;font-weight:700}.badge-expense{background:var(--expense-bg);color:var(--expense)}.badge-income{background:var(--income-bg);color:var(--income)}.badge-transfer{background:var(--transfer-bg);color:var(--transfer)}.badge-fx{background:var(--fx-bg);color:var(--fx)}.badge-investment{background:var(--investment-bg);color:var(--investment)}.tx-category{color:var(--text-sub);font-size:.85rem;font-weight:500}.tx-amount{white-space:nowrap;color:var(--text);font-size:.97rem;font-weight:700}.amount-income{color:var(--income)}.amount-expense{color:var(--expense)}.tx-card-bottom{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.tx-account{color:var(--text-sub);flex:1.35;min-width:180px;font-size:.82rem}.tx-note{color:var(--text-muted);flex:.8;min-width:120px;font-size:.8rem}.tx-actions{gap:6px;margin-left:auto;display:flex}.tx-action-btn{border:1px solid var(--line-strong);border-radius:var(--radius-pill);color:var(--text-sub);background:0 0;padding:4px 12px;font-size:.78rem;font-weight:600;transition:all .14s}.tx-action-btn:hover{background:var(--bg-alt)}.tx-action-btn:disabled{opacity:.45;cursor:not-allowed}.tx-action-danger{color:var(--expense);border-color:#c0330d38}.tx-action-danger:hover{background:var(--expense-bg)}.segmented-control{border:1px solid var(--line-strong);border-radius:var(--radius-pill);background:#ffffffb3;align-items:center;gap:4px;min-height:44px;padding:4px;display:inline-flex}.full-row .segmented-control{grid-template-columns:repeat(5,minmax(0,1fr));width:100%;display:grid}.segment{border-radius:var(--radius-pill);min-height:36px;color:var(--text-sub);white-space:nowrap;background:0 0;border:1px solid #0000;padding:9px 16px;font-size:.88rem;font-weight:600;transition:all .14s}.segment:hover{background:var(--primary-soft);color:var(--primary)}.segment.active{background:var(--primary);color:#fff;border-color:#0000}.category-grid{grid-template-columns:repeat(3,1fr);gap:8px;display:grid}.chip{border-radius:var(--radius-sm);border:1px solid var(--line-strong);background:var(--surface-solid);color:var(--text);text-align:center;padding:9px 10px;font-size:.88rem;font-weight:500;transition:all .14s}.chip:hover{border-color:var(--primary);color:var(--primary)}.chip.active{background:var(--primary);color:#fff;border-color:var(--primary)}.form-grid{grid-template-columns:1fr;gap:14px;display:grid}.form-grid.compact{gap:12px}.field{gap:6px;display:grid}.field>span{color:var(--text-sub);font-size:.83rem;font-weight:600}.field input,.field select,.field textarea{border:1px solid var(--line-strong);border-radius:var(--radius-sm);background:var(--surface-solid);width:100%;color:var(--text);padding:11px 13px;font-size:.92rem;transition:border-color .14s,box-shadow .14s}.field input:not([type=checkbox]):not([type=radio]),.field select{height:44px;min-height:44px}.field select{appearance:none;line-height:1.2}.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-soft);outline:none}.field textarea{resize:vertical;min-height:60px}.journal-form-grid{--jfg:8px;--jcg:14px;--jdate-min:9em;--jnum-min:6em;--jtxt-min:7em;--jacc-min:6em;--jsym-min:5em;--jfx-min:5em;gap:12px;display:grid}.full-row{width:100%}.journal-form-grid .inline-label-field{align-items:center;gap:var(--jfg);flex-direction:row;width:100%;min-width:0;display:flex}.journal-form-grid .inline-label-field>span{white-space:nowrap;color:var(--text-sub);flex-shrink:0;font-size:.85rem;font-weight:600}.journal-form-grid .inline-label-field>input,.journal-form-grid .inline-label-field>select,.journal-form-grid .inline-label-field>textarea{border:1px solid var(--line-strong);border-radius:var(--radius-sm);background:var(--surface-solid);width:0;min-width:0;color:var(--text);flex:1 1 0;padding:10px 12px;font-size:.9rem}.journal-form-grid .inline-label-field>input:focus,.journal-form-grid .inline-label-field>select:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-soft);outline:none}.form-row{gap:var(--jcg);flex-flow:row;align-items:center;min-width:0;display:flex}.form-row>*{flex:1 1 0;min-width:0}.compact-label{gap:var(--jfg);align-items:center}.compact-label>span{font-size:.85rem}.full-width{width:100%}.note-submit-row{align-items:center}.note-submit-row>.full-width{flex:1 1 0}.note-submit-row>button{flex:none}.journal-date-amount-row>.date-input-field,.journal-date-rate-row>.date-input-field{flex:1.1 1 0}.journal-date-amount-row>.amount-input-field,.journal-date-rate-row>.amount-input-field{flex:.9 1 0}.investment-total-row>.investment-fee-field{flex:.82 1 0}.investment-total-row>.investment-total-field{flex:1.18 1 0}.date-input-field{gap:var(--jfg);align-items:center}.journal-form-grid .date-input-field>input[type=date]{min-width:var(--jdate-min)}.account-select-field{gap:var(--jfg);align-items:center}.account-select-field>select,.wide-account-field>select{min-width:var(--jacc-min)}.amount-input-field,.narrow-amount-field{gap:var(--jfg);align-items:center}.journal-form-grid .narrow-amount-field>input{min-width:var(--jfx-min)}.fx-row>.amount-input-field,.fx-row>.narrow-amount-field{flex:.8 1 0}.fx-row>.account-select-field{flex:1.2 1 0}.investment-top-row{align-items:center}.investment-top-row>.date-input-field{flex:1 1 0}.investment-top-row>.no-label-segment{flex:none}.investment-target-row{align-items:center}.investment-target-row>.name-input-field{flex:1 1 0}.investment-code-row>.symbol-input-field{flex:.8 1 0}.investment-code-row>.account-select-field{flex:1.2 1 0}.investment-code-row>.symbol-input-field>input{min-width:0}.journal-form-grid input[type=text],.journal-form-grid input:not([type]),.journal-form-grid textarea,.journal-form-grid select{min-width:var(--jtxt-min)}.journal-form-grid input[type=number]{min-width:var(--jnum-min)}.no-label-segment .segmented-control{grid-template-columns:repeat(2,minmax(0,1fr));width:fit-content;margin-left:auto}.no-label-segment .segment{white-space:nowrap;min-width:56px;padding:8px 10px}.category-field{gap:8px}.primary-button{border-radius:var(--radius-pill);background:var(--primary);color:#fff;border:none;padding:11px 18px;font-size:.88rem;font-weight:700;transition:background .14s,box-shadow .14s}.primary-button:hover{background:var(--primary-hover);box-shadow:var(--shadow)}.primary-button:disabled{opacity:.65;cursor:wait}.compact-button{padding:8px 14px;font-size:.85rem}.secondary-button,.table-action-button,.icon-button{border:1px solid var(--line-strong);border-radius:var(--radius-pill);background:var(--surface-solid);color:var(--text);padding:11px 18px;font-size:.88rem;font-weight:600;transition:all .14s}.secondary-button:hover,.table-action-button:hover{background:var(--bg-alt)}.danger-button,.table-action-button.danger{border-radius:var(--radius-pill);background:var(--expense-bg);color:var(--expense);border:1px solid #c0330d38;padding:11px 18px;font-size:.88rem;font-weight:700}.danger-button:hover{background:#c0330d2e}.icon-button{min-width:44px;padding:9px 13px;font-size:1.1rem}.form-footer{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.status-copy,.empty-copy{color:var(--text-muted);font-size:.88rem}.modal-backdrop{z-index:40;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0a142670;place-items:center;padding:20px;display:grid;position:fixed;inset:0}.modal-panel{border:1px solid var(--line);border-radius:var(--radius-xl);width:min(100%,720px);max-height:min(92vh,960px);box-shadow:var(--shadow-lg);background:#fffffffa;padding:24px;overflow:auto}.modal-header{justify-content:space-between;align-items:center;gap:12px;margin-bottom:20px;display:flex}.modal-header h2{font-size:1.05rem;font-weight:700}.confirm-body p{color:var(--text);margin-bottom:18px}.chart-wrap{width:100%;min-height:260px}.stacked-cell{gap:3px;display:grid}.stacked-cell strong{font-size:.93rem;line-height:1.2}.stacked-cell span{color:var(--text-muted);font-size:.8rem}.page-intro{margin-bottom:8px}.eyebrow{text-transform:uppercase;letter-spacing:.06em;color:var(--primary);font-size:.78rem;font-weight:700}.mode-badge{border-radius:var(--radius-pill);background:var(--primary-soft);color:var(--primary);padding:4px 10px;font-size:.78rem;font-weight:700}@media (width<=600px){#root{padding:12px 10px}.top-nav-shell{padding:6px 8px 6px 14px;top:10px}.site-name{padding-right:10px;font-size:1rem}.top-nav-link{padding:9px 8px;font-size:.85rem}.card,.modal-panel,.tx-section{border-radius:var(--radius-lg);padding:16px}.overview-stats-grid{grid-template-columns:repeat(2,1fr)}.journal-form-grid{--jcg:8px;--jfg:5px;--jdate-min:8em;--jnum-min:4em;--jtxt-min:4em;--jacc-min:4em;--jsym-min:3em;--jfx-min:3em}.journal-form-grid .field input,.journal-form-grid .field select,.journal-form-grid .field textarea,.journal-form-grid .inline-label-field>input,.journal-form-grid .inline-label-field>select,.journal-form-grid .inline-label-field>textarea{font-size:16px!important}.journal-form-grid .field input:not([type=checkbox]):not([type=radio]),.journal-form-grid .field select,.journal-form-grid .inline-label-field>input:not([type=checkbox]):not([type=radio]),.journal-form-grid .inline-label-field>select{height:44px;min-height:44px}.journal-form-grid .field textarea,.journal-form-grid .inline-label-field>textarea{height:auto;min-height:60px}.reports-toolbar{flex-wrap:nowrap;align-items:stretch}.toolbar-period-field{flex:1;justify-content:flex-end;align-items:center;gap:6px;min-height:44px;display:flex}.toolbar-period-field>span{font-size:.8rem;line-height:44px}.toolbar-period-field>select{height:44px;min-height:44px;font-size:16px}.investment-metrics{grid-template-columns:repeat(2,minmax(0,1fr))}.investment-row{gap:8px;padding:12px}.investment-metric-labels,.investment-metric-values{grid-template-columns:1fr 1.5fr 1.5fr 1.5fr;gap:6px}.metric-label{text-align:left;font-size:.68rem}.investment-metric-values strong{text-align:left;font-size:.8rem}.investment-cost-price{font-size:.76rem}.tx-account,.tx-note{min-width:0}}
