@charset "UTF-8";:root{font-family:Pretendard,Noto Sans KR,Apple SD Gothic Neo,Malgun Gothic,Segoe UI,sans-serif;color:#11223d;background:linear-gradient(145deg,#edf4ff,#f8fbff);line-height:1.45;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*,*:before,*:after{box-sizing:border-box;min-width:0}html,body,#root{width:100%;max-width:100vw;max-width:100%;overflow-x:hidden;overscroll-behavior-x:none;touch-action:pan-y}body{margin:0;min-width:0;min-height:100vh;padding:0}#root{min-height:100vh}.auth-shell{min-height:100vh;display:grid;place-items:center;padding:1.25rem}.auth-card{background:#fff;border:1px solid #dce5f2;border-radius:20px;padding:1.25rem;display:grid;gap:.75rem;width:min(440px,100%)}.tabs button.active,.inline button.active{background:#0b4ab4;color:#fff;box-shadow:0 4px 6px -1px #0b4ab433}.tabs button.active:hover:not(:disabled),.inline button.active:hover:not(:disabled){background:#08398b}.auth-switch{display:flex;align-items:center;gap:.35rem;flex-wrap:wrap;color:#355177;font-size:.85rem}.auth-pending-invite{border:1px solid #c8d9f9;background:#eef4ff;color:#1f4c99;border-radius:12px;padding:.7rem .8rem;display:grid;gap:.25rem;font-size:.88rem}.auth-pending-invite strong{font-size:.9rem}.text-button{background:transparent;color:#0b4ab4;border:0;border-radius:0;padding:0;font-size:.85rem;font-weight:600;text-decoration:underline}.text-button:hover{color:#08398b}.auth-options{display:grid;gap:.25rem}.check-row{display:flex;align-items:center;gap:.4rem;font-size:.85rem;color:#355177}.check-row input[type=checkbox]{width:auto}.upload-row{align-items:center}.upload-file-name{font-size:.85rem;color:#355177}.file-drop-area{border:2px dashed #b6cff6;border-radius:10px;padding:3rem 1rem;text-align:center;background-color:#f7fbff;cursor:pointer;transition:all .2s ease;margin-top:1rem}.file-drop-area:hover,.file-drop-area.drag-over{border-color:#0b4ab4;background-color:#eaf2ff}.upload-placeholder{color:#3f5f8f;font-size:.95rem}.import-progress{border:1px solid #c8d9f9;background:#eef4ff;color:#1f4c99;border-radius:10px;padding:.45rem .6rem;font-size:.86rem}.app-shell{padding:1rem;display:grid;gap:1rem;max-width:1480px;margin:0 auto}.app-copyright{position:fixed;right:14px;bottom:12px;color:#0f172a8f;font-size:.72rem;font-weight:600;letter-spacing:.01em;pointer-events:none;-webkit-user-select:none;user-select:none;z-index:15}.topbar{background:linear-gradient(120deg,#0b4ab4,#1d9ce5);color:#fff;border-radius:16px;padding:1rem;display:flex;justify-content:space-between;gap:1rem;align-items:start}.topbar h1{margin:0;font-size:1.35rem}.meta{margin-top:.35rem;display:flex;gap:.7rem;flex-wrap:wrap;font-size:.85rem}.tabs{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.tabs-left,.tabs-right{display:flex;gap:.5rem;flex-wrap:wrap}.tabs-right{margin-left:auto;justify-content:flex-end}.tabs button{border-radius:999px;background:#f1f5f9;color:#64748b;font-weight:600;box-shadow:none;display:inline-flex;align-items:center;gap:.35rem}.tabs button:hover:not(:disabled){background:#e2e8f0;color:#0f172a;transform:translateY(-1px)}.tab-badge{min-width:1.1rem;height:1.1rem;border-radius:999px;background:#f43f5e;color:#fff;font-size:.7rem;display:inline-flex;align-items:center;justify-content:center;padding:0 .3rem}.sub-tab-badge{min-width:1.2rem;height:1.2rem;border-radius:999px;background:#dbeafe;color:#1d4ed8;font-size:.72rem;display:inline-flex;align-items:center;justify-content:center;padding:0 .35rem}.tab-invite-pulse{animation:tab-invite-pulse 1s ease-in-out infinite}@keyframes tab-invite-pulse{0%,to{box-shadow:0 0 #f43f5e73}50%{box-shadow:0 0 0 10px #f43f5e00}}.sub-tabs{margin-bottom:.1rem}.grid-2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.9rem}.dashboard-loading-banner,.dashboard-refresh-note{grid-column:1 / -1;border-radius:10px;padding:.5rem .7rem;font-size:.88rem}.dashboard-loading-banner{border:1px solid #c8d9f9;background:#eef4ff;color:#1f4c99}.dashboard-refresh-note{border:1px solid #d4e3fb;background:#f5f9ff;color:#29538f}.grid-1{display:grid;grid-template-columns:minmax(0,1fr);gap:.9rem}.card{background:#fff;border:1px solid #dbe3ef;border-radius:16px;padding:.95rem;display:grid;gap:.8rem}.card h2{margin:0;font-size:1.08rem}.surface-list-heading{display:flex;justify-content:space-between;align-items:baseline;gap:.75rem;flex-wrap:wrap}.surface-count-summary{margin:0}.chart-card{min-height:320px;grid-template-rows:auto 1fr}.chart-card-header{justify-content:space-between;align-items:center}.chart-wrap{position:relative;height:320px;min-height:320px;max-height:320px;overflow:hidden}.chart-wrap canvas{width:100%!important;height:100%!important}.chart-loading{height:100%;display:grid;place-content:center;gap:.6rem;text-align:center;color:#355177}.chart-loading p{margin:0;font-size:.9rem}.loading-spinner{width:30px;height:30px;border:3px solid #c8d9f9;border-top-color:#0b4ab4;border-radius:50%;justify-self:center;animation:spinner-rotate .9s linear infinite}@keyframes spinner-rotate{to{transform:rotate(360deg)}}.summary{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.5rem}.summary>div{background:#f7f9fc;border:1px solid #e6ecf5;border-radius:10px;padding:.45rem .6rem;font-size:.9rem;display:grid;gap:.15rem}.summary>div strong{font-size:.78rem;color:#355177;font-weight:700}.summary>div span{font-size:.93rem;font-weight:600;color:#16233a}.summary-placeholder{color:#3f5f8f}.inline{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}.actions{display:flex;gap:.5rem;flex-wrap:wrap}.form-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.55rem}.transactions-form-grid label select:disabled{background:#f3f6fb;color:#6b7f9d}.holdings-form-container{background-color:#f8fafc;border-radius:12px;padding:1.5rem;margin-bottom:1.5rem;border:1px solid #e2e8f0}.holdings-form-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem;align-items:end}.holdings-form-grid label{display:flex;flex-direction:column;gap:.4rem;font-size:.85rem;font-weight:600;color:#475569;margin-bottom:0}.holdings-form-grid input,.holdings-form-grid select{padding:.6rem .75rem;border:1px solid #cbd5e1;border-radius:8px;font-size:.95rem;transition:all .2s;background-color:#fff}.holdings-form-grid input:focus,.holdings-form-grid select:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.holdings-form-actions{display:flex;gap:.75rem;margin-top:1.5rem;justify-content:flex-end;grid-column:1 / -1;border-top:1px solid #e2e8f0;padding-top:1rem}.holdings-form-actions button{padding:.6rem 1.5rem;border-radius:8px;font-weight:600}.holdings-inline-editor{grid-template-columns:repeat(4,minmax(0,1fr));gap:.45rem}.transactions-inline-editor{background:transparent}.transaction-inline-editor-row{background:#f7fbff}.tx-inline-category-section{padding:0;display:flex;align-items:flex-start;flex-wrap:wrap;gap:.35rem;width:100%;margin-top:.05rem;max-width:100%}.tx-inline-editor-actions{width:auto;margin-left:0;justify-content:flex-end;gap:.45rem;align-self:stretch}.tx-inline-date-field,.tx-inline-type-field,.tx-inline-amount-field,.tx-inline-memo-field,.tx-inline-owner-field{min-width:0;width:100%;max-width:100%}.tx-inline-major-field,.tx-inline-minor-field{min-width:0;flex:1 1 0;width:auto;max-width:calc(50% - .18rem)}.tx-inline-memo-field,.tx-inline-owner-field{display:block}.transaction-inline-editor-row td{padding:.28rem .45rem .35rem;border-bottom:1px solid #d8e4f5}.holdings-inline-editor input,.holdings-inline-editor select,.transactions-inline-editor input,.transactions-inline-editor select{width:100%;min-width:0;font-size:.86rem;padding:.28rem .45rem;border-radius:7px}.tx-inline-category-section select{background-position:right .45rem center}.transaction-inline-editor-row td,.transaction-inline-editor-row .transactions-inline-editor{background:transparent}.transactions-inline-editor input[type=date],.transactions-inline-editor input[type=number],.transactions-inline-editor input:not([type]),.transactions-inline-editor select{line-height:1.2}.transactions-inline-editor label{margin-bottom:0;gap:.35rem;font-size:.8rem;display:inline-flex;align-items:center}.transactions-inline-editor .tx-inline-category-section label{margin-bottom:0}.transactions-inline-editor .date-field .today-btn{justify-self:start}.holding-row-editing,.transaction-row-editing{background:#f7fbff}.holding-inline-editor-row td{background:#f7fbff;padding:.6rem}.date-input-wrap{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:.45rem;align-items:center}.today-btn{white-space:nowrap}.month-nav-btn{min-width:3rem;white-space:nowrap}.month-nav{display:flex;gap:.5rem;align-items:flex-end;flex-wrap:wrap}.month-nav label{min-width:4.6rem;display:flex;flex-direction:column;justify-content:flex-end;margin-bottom:0}.month-toolbar{margin-bottom:.2rem}.form-actions{grid-column:1 / -1;justify-content:flex-end}.collaboration-toolbar{display:flex;align-items:flex-end;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.collaboration-toolbar label{flex:1;max-width:400px;margin-bottom:0}.collaboration-toolbar .table-summary{margin:0;padding-bottom:.6rem}.household-select{width:100%;padding:.6rem .75rem;border:1px solid #cbd5e1;border-radius:8px;background-color:#fff;font-size:.95rem;color:#0f172a;cursor:pointer;transition:all .2s}.household-select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.collaboration-form-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.collaboration-accept-grid{grid-template-columns:minmax(0,1fr)}.invite-acceptance-banner{border:1px solid #cfe6c7;background:#f5fbec;color:#355a21;border-radius:12px;padding:.75rem .85rem;display:flex;align-items:center;justify-content:space-between;gap:.75rem}.invite-arrival-banner{border:1px solid #f8d4da;background:#fff4f6;color:#8b1e3f;border-radius:12px;padding:.75rem .85rem;display:flex;align-items:center;justify-content:space-between;gap:.75rem;box-shadow:0 0 0 3px #f43f5e14}.invite-acceptance-copy,.invite-arrival-copy{display:grid;gap:.2rem}.invite-acceptance-copy strong{font-size:.95rem}.invite-arrival-copy strong{font-size:.95rem;color:#8b1e3f}.invite-acceptance-copy span{font-size:.85rem;color:#47682d}.invite-arrival-copy span{font-size:.85rem;color:#a3395c}.invite-banner-actions,.invite-table-actions{justify-content:flex-end;flex-wrap:wrap;gap:.45rem}label{display:grid;gap:.28rem;font-size:.86rem}input,select,button,textarea{border:1px solid #c8d2e3;border-radius:10px;padding:.45rem .55rem;font-size:.9rem;max-width:100%;min-width:0;box-sizing:border-box}button{border-color:transparent;background:#0b4ab4;color:#fff;cursor:pointer;transition:all .2s ease}button:hover:not(:disabled){background:#08398b;transform:translateY(-1px);box-shadow:0 4px 6px -1px #0b4ab433}button:active:not(:disabled){background:#062b69;transform:translateY(0);box-shadow:none}button:focus-visible{outline:2px solid #0b4ab4;outline-offset:2px}button:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}button.secondary{background:#fff;color:#0b4ab4;border-color:#0b4ab4}button.secondary:hover:not(:disabled){background:#f4f8ff;color:#08398b;border-color:#08398b}button.secondary:active:not(:disabled){background:#eaf2ff}button.danger{background:#fff;color:#c22d35;border-color:#c22d35}button.danger:hover:not(:disabled){background:#fef2f2;color:#9f1239;border-color:#9f1239;box-shadow:0 4px 6px -1px #c22d3533}button.danger:active:not(:disabled){background:#fee2e2}.message{border-radius:10px;border:1px solid #b6cff6;background:#eaf2ff;color:#164087;padding:.5rem .7rem;font-size:.9rem;display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem}.message span{white-space:pre-line}.message-close{flex-shrink:0;padding:.2rem .55rem;font-size:.8rem;line-height:1.2}.confirm-backdrop{position:fixed;inset:0;background:#0f172a6b;display:grid;place-items:center;z-index:50;padding:1rem}.confirm-dialog{width:min(420px,100%);background:#fff;border:1px solid #dbe3ef;border-radius:14px;padding:1rem;display:grid;gap:.7rem;box-shadow:0 20px 40px #0f172a33}.confirm-dialog h2{margin:0;font-size:1rem}.confirm-dialog p{margin:0;font-size:.9rem;color:#355177}.confirm-actions{display:flex;justify-content:flex-end;gap:.5rem}.table-header-group{display:flex;justify-content:flex-start;margin-bottom:.5rem;flex-wrap:wrap}.month-stepper-inline{display:flex;align-items:center;gap:.25rem;flex-wrap:wrap}.table-card{overflow:auto}.table-toolbar{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.55rem;align-items:end}.table-summary{margin:0;font-size:.84rem;color:#355177}.compact-support-card,.compact-inline-details{padding:.9rem 1rem}.settings-advanced-card{align-self:start}.compact-support-card>summary,.compact-inline-details>summary{cursor:pointer;list-style:none;display:flex;align-items:center;justify-content:space-between;gap:.75rem;font-weight:700;color:#173a67}.compact-support-card>summary::-webkit-details-marker,.compact-inline-details>summary::-webkit-details-marker,.holding-column-width-editor>summary::-webkit-details-marker{display:none}.compact-support-summary{margin-top:.55rem}.compact-support-grid{display:grid;gap:.9rem;margin-top:.9rem}.compact-support-section{display:grid;gap:.65rem;padding:.85rem;border:1px solid #e2e8f0;border-radius:12px;background:#fbfdff}.compact-support-header{justify-content:space-between;align-items:center;gap:.75rem}.compact-support-header h3{margin:0;font-size:1rem}.compact-inline-select{margin:0;min-width:160px}.portfolio-view-summary{display:flex;flex-wrap:wrap;gap:.25rem}.compact-chart-wrap{min-height:220px}.empty-state{text-align:center;color:#5d7597}.status-pill{display:inline-flex;align-items:center;justify-content:center;min-width:4.6rem;padding:.2rem .55rem;border-radius:999px;font-size:.78rem;font-weight:700;border:1px solid transparent}.status-pill-pending{background:#eef4ff;color:#1f4c99;border-color:#c8d9f9}.status-pill-accepted{background:#edf9f0;color:#25663b;border-color:#cfe6c7}.status-pill-revoked{background:#fff1f0;color:#b42318;border-color:#f7c6c2}.status-pill-expired{background:#f7f9fc;color:#516985;border-color:#dbe3ef}.status-pill-highlight{box-shadow:0 0 0 3px #25663b1f}.invite-row-highlight td{background:#f8fdf6}.invite-section-attention{border-color:#f8d4da;box-shadow:0 0 0 3px #f43f5e14}.section-header-cell{background:#f4f8ff;color:#1f4c99;font-weight:700}table{width:100%;border-collapse:collapse}th,td{border-bottom:1px solid #e6edf7;padding:.45rem;text-align:left;font-size:.84rem;vertical-align:middle}thead{background:#f4f8ff}.sort-header{border:0;padding:0;margin:0;display:inline-flex;align-items:center;gap:.25rem;font:inherit;font-weight:700;color:inherit;background:transparent;cursor:pointer}.sort-header:hover{opacity:.9}.sort-header.active{color:#0b4ab4}.sort-indicator{width:.8rem;text-align:center;display:inline-block;font-size:.7rem}.report{background:#101827;color:#e6edf7;border-radius:10px;padding:.7rem;font-size:.78rem;max-height:460px;overflow:auto}.import-report{display:grid;gap:.7rem}.import-summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.55rem}.import-summary-item{display:grid;gap:.2rem;background:#f4f8ff;border:1px solid #d8e4f5;border-radius:8px;padding:.45rem .55rem;font-size:.83rem}.import-list-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:.7rem}.import-list-grid h3{margin:0 0 .4rem;font-size:.9rem}.compact-list{margin:0;padding-left:1rem;display:grid;gap:.25rem;max-height:220px;overflow:auto}.compact-list li{font-size:.81rem;color:#203147}.category-entry-toolbar{gap:.5rem}.category-manager-guide{display:grid;gap:.2rem;padding:.65rem .75rem;border:1px solid #d8e4f5;border-radius:10px;background:#f8fbff}.category-manager-guide strong{color:#163866}.category-usage-month summary{cursor:pointer;font-weight:600;color:#244772}.report-raw summary{cursor:pointer;font-size:.83rem;color:#355177}.filter-card{padding:0;grid-column:1 / -1;background:transparent;box-shadow:none;border:none}.summary-card{grid-column:1 / -1}.filter-card h2{display:none}.filter-container{display:flex;align-items:center;flex-wrap:wrap;gap:1rem}.filter-modes-segmented{display:flex;background-color:#f1f5f9;border-radius:8px;padding:.25rem;height:42px}.filter-modes-segmented button{background:transparent;border:none;color:#64748b;padding:0 1rem;font-size:.9rem;font-weight:600;border-radius:6px;cursor:pointer;transition:all .2s ease;height:100%;display:flex;align-items:center;justify-content:center}.filter-modes-segmented button:hover{color:#0f172a}.filter-modes-segmented button.active{background-color:#fff;color:#0f172a;box-shadow:0 1px 3px #0000001a}.filter-inputs-wrapper{display:flex;align-items:center;flex-wrap:wrap;gap:.5rem}.month-stepper{display:inline-flex;align-items:center;gap:.25rem;background-color:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:.25rem;height:42px}.month-stepper .icon-btn{display:flex;align-items:center;justify-content:center;background:transparent;border:none;color:#64748b;width:32px;height:32px;border-radius:6px;cursor:pointer;padding:0}.month-stepper .icon-btn:hover:not(:disabled){background-color:#f1f5f9;color:#0f172a}.month-stepper .icon-btn:disabled{opacity:.5;cursor:not-allowed}.month-stepper .date-inputs{display:flex;align-items:baseline;gap:.25rem;font-weight:600;color:#0f172a}.month-stepper .date-inputs input{border:none;background:transparent;font-weight:600;color:#0f172a;padding:0;text-align:right;width:3.5rem;font-size:1rem}.month-stepper .date-inputs input[type=number]::-webkit-inner-spin-button,.month-stepper .date-inputs input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.month-stepper .date-inputs input:focus{outline:none;background-color:#f1f5f9;border-radius:4px}.month-stepper .text-btn{display:flex;align-items:center;justify-content:center;background:transparent;border:none;color:#3b82f6;font-weight:600;font-size:.85rem;padding:0 .75rem;border-radius:6px;cursor:pointer;height:32px}.month-stepper .text-btn:hover{background-color:#eff6ff}.month-stepper .text-btn.apply-btn{color:#fff;background-color:#3b82f6;margin-left:.5rem}.month-stepper .text-btn.apply-btn:hover{background-color:#2563eb}.range-picker{display:flex;align-items:center;gap:.5rem;background-color:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:.25rem .5rem;height:42px}.range-picker input[type=date]{border:none;background:transparent;font-weight:500;color:#0f172a;padding:0 .4rem;height:100%}.range-picker input[type=date]:focus{outline:none;background-color:#f1f5f9;border-radius:4px}.range-separator{color:#64748b;font-weight:600}.filter-apply-btn{padding:0 1.5rem;font-weight:600;border-radius:8px;height:42px;display:flex;align-items:center;justify-content:center}.onboarding-guide{border-color:#c8d9f9;background:linear-gradient(135deg,#eef4ff,#f8fbff)}.onboarding-guide p{margin:.35rem 0 0;color:#355177}.tx-entry-banner{display:flex;align-items:center;justify-content:space-between;gap:.75rem;border:1px solid #d6e7c3;border-radius:12px;background:#f5fbec;color:#355a21;padding:.7rem .8rem}.transaction-row td{background:transparent}.transaction-row td:first-child{box-shadow:inset .55rem 0 0 var(--transaction-row-accent, transparent);padding-left:.8rem}.transaction-col-type,.transaction-col-owner,.transaction-col-updated{color:#5f7596}.transaction-flow-badge{display:inline-flex;align-items:center;justify-content:center;min-width:4rem;border-radius:999px;padding:.22rem .58rem;font-size:.78rem;font-weight:700;background:#dbeafebf;color:#173a67}.transaction-flow-income{background:#d4f2dce6;color:#1f5b2f}.transaction-flow-expense{background:#ffe1dff2;color:#9b2c2c}.transaction-flow-investment{background:#dfeafff2;color:#214e96}.transaction-flow-transfer{background:#fff0d6f2;color:#935f14}.transaction-owner-chip,.holding-owner-chip{display:inline-flex;align-items:center;justify-content:center;width:1.12rem;min-width:1.12rem;height:1.12rem;border-radius:999px;font-size:.64rem;font-weight:800;background:var(--transaction-owner-chip-bg, var(--holding-owner-chip-bg, rgba(200, 217, 249, .18)));color:var(--transaction-owner-color, var(--holding-owner-color, #173a67));box-shadow:inset 0 0 0 1px var(--transaction-owner-chip-ring, var(--holding-owner-chip-ring, rgba(15, 23, 42, .12)))}.transaction-memo-text{font-weight:600;color:#16233a}.transaction-amount-text{font-weight:700;color:#132b4c}.transaction-owner-cue{display:inline-flex;align-items:center;gap:.35rem;font-size:.82rem;color:#566c8b}.transaction-owner-cue:before{content:"";width:.48rem;height:.48rem;border-radius:999px;background:var(--transaction-owner-color, #c8d9f9);box-shadow:0 0 0 2px var(--transaction-owner-chip-bg, rgba(219, 234, 254, .75))}.transaction-row-editing td,.transaction-inline-editor-row td{background:#f7fbff}.holding-name-cell{white-space:normal;word-break:break-word;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.holding-name-cell:before{content:"";display:inline-block;width:.55rem;height:.55rem;margin-right:.5rem;border-radius:999px;background:var(--holding-row-cue, #c8d9f9);box-shadow:0 0 0 2px #dbeafebf;vertical-align:.05rem}.holding-type-label{font-weight:700;color:#173a67}.holding-type-category-hint{display:none;font-size:.78rem;color:#6a7f99}.holding-column-width-editor summary{cursor:pointer;font-weight:600;color:#355177}.holding-display-options{margin-top:.8rem;border:1px solid #e2e8f0;border-radius:12px;background:#fbfdff}.holding-display-options>.table-toolbar,.holding-display-options>.holding-column-width-editor{margin-top:.85rem}.holding-col-name{width:var(--holding-col-name, 220px)}.holding-col-type{width:var(--holding-col-type, 120px)}.holding-col-owner{width:var(--holding-col-owner, 120px)}.holding-col-category{width:var(--holding-col-category, 130px)}.holding-col-quantity{width:var(--holding-col-quantity, 100px)}.holding-col-average{width:var(--holding-col-average, 120px)}.holding-col-market{width:var(--holding-col-market, 130px)}.holding-col-gain{width:var(--holding-col-gain, 130px)}.settings-category-usage-detail{margin-top:.15rem;border:1px dashed #d6e3f7;border-radius:8px;padding:.5rem .7rem;background:#f8fbff}.invite-row-new{animation:invite-row-new .8s ease}@keyframes invite-row-new{0%{transform:translateY(4px);opacity:.35}to{transform:translateY(0);opacity:1}}.mobile-toggle-btn,.transaction-mobile-expanded-actions-row,.holding-mobile-expanded-actions-row{display:none}.category-cell{display:grid;gap:.1rem;justify-items:start;text-align:left}.category-cell-compact{display:none;font-size:.82rem;font-weight:600;color:#355177}.category-cell-major{font-weight:700;color:#163866}.category-cell-minor{font-size:.83rem;color:#5f7596}.category-cell-empty{color:#7b8faa}.settings-grid{align-items:start}.settings-span-full{grid-column:1 / -1}.settings-form-grid{align-items:end}.settings-preview{grid-column:1 / -1;font-size:.9rem;color:#355177}.settings-actions{grid-column:1 / -1;justify-content:flex-end}.settings-household-switch{display:grid;gap:.65rem}.settings-household-switch label{margin-bottom:0}.settings-household-switch .table-summary{margin:0}.settings-color-form{display:grid;gap:.65rem}.settings-color-row{display:grid;grid-template-columns:minmax(0,1fr) minmax(110px,180px) auto auto;align-items:center;gap:.75rem;font-size:.9rem;color:#243b5f}.settings-color-preview-bar{width:100%;height:.95rem;border-radius:999px;background:var(--settings-color-preview, #e2e8f0);border:1px solid #dbe3ef;box-shadow:inset 0 0 0 1px #ffffff61}.settings-color-row code{color:#516985;background:#f7f9fc;border:1px solid #dbe3ef;border-radius:999px;padding:.2rem .55rem}.settings-category-flows{display:grid;gap:1rem}.settings-category-flow{display:grid;gap:.75rem;border:1px solid #e2e8f0;border-radius:14px;padding:.85rem;background:#fbfdff}.settings-category-flow-header,.settings-category-group-header,.settings-category-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:.75rem;align-items:center}.settings-category-group{display:grid;gap:.55rem;border-top:1px solid #e6edf7;padding-top:.75rem}.settings-category-list{display:grid;gap:.45rem}.settings-category-row{grid-template-columns:160px minmax(0,1fr) 110px auto;border:1px solid #e6edf7;border-radius:10px;padding:.6rem .7rem;background:#fff}.category-row-editing{background:#f7fbff}.settings-category-major{font-weight:700;color:#173a67}.settings-category-minor{color:#385272}.settings-category-usage{font-size:.82rem;color:#6a7f99}@media(max-width:1100px){.grid-2{grid-template-columns:minmax(0,1fr)}.form-grid,.summary{grid-template-columns:repeat(2,minmax(0,1fr))}.surface-list-card{order:1}.surface-entry-card{order:2}.surface-support-card{order:3}}@media(max-width:760px){.app-shell{padding:.75rem .55rem;width:100%;max-width:100%;margin-inline:0}.topbar{padding:.54rem .64rem;width:100%;max-width:100%;margin-inline:0;display:grid;grid-template-columns:minmax(0,1fr);gap:.32rem;align-items:start}.card{padding:.64rem .7rem;gap:.52rem;border-radius:14px}.surface-list-card{gap:.5rem}.surface-entry-card,.surface-support-card{gap:.55rem}.table-toolbar{grid-template-columns:1fr}.form-grid{grid-template-columns:minmax(0,1fr)}.topbar-identity{min-width:0}.topbar h1{font-size:1rem}.topbar-meta{margin-top:.12rem;font-size:.68rem;gap:.28rem;flex-wrap:nowrap;overflow-x:auto;scrollbar-width:none}.topbar-meta::-webkit-scrollbar{display:none}.topbar-meta span{flex:0 0 auto;white-space:nowrap}.topbar-actions{flex-wrap:nowrap;overflow-x:auto;scrollbar-width:none;width:100%}.topbar-actions::-webkit-scrollbar{display:none}.topbar-actions button{flex:0 0 auto;white-space:nowrap;padding:.38rem .62rem;font-size:.78rem}.topbar-tabs{position:sticky;top:0;z-index:18;padding:.08rem 0 .22rem;margin-top:-.12rem;background:linear-gradient(180deg,#eff5fffa,#eff5fff0);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.app-shell{--mobile-tabs-sticky-offset: 2.62rem}.tabs{gap:.35rem;flex-wrap:nowrap;overflow-x:auto;scrollbar-width:none}.tabs::-webkit-scrollbar{display:none}.tabs-left,.tabs-right{display:contents}.tabs-right{margin-left:0}.tabs button{flex:0 0 auto;white-space:nowrap;padding:.36rem .64rem;font-size:.82rem}.summary{grid-template-columns:repeat(2,minmax(0,1fr))}.transaction-list-card>.surface-list-heading{order:1}.transaction-list-card>.transactions-surface-table{order:2}.transaction-list-card>.message{order:3}.transaction-list-card>.table-header-group{order:4;padding-top:.24rem;border-top:1px solid #eef3f9}.transaction-list-card>.table-toolbar{order:5}.holding-list-card>.surface-list-heading{order:1}.holding-list-card>.holdings-surface-table{order:2}.holding-list-card>.sub-tabs{order:3}.holding-list-card>.message{order:4}.holding-list-card>.holding-display-options{order:5;margin-top:.1rem;padding-top:.5rem;border-top:1px solid #eef3f9}.surface-list-heading{gap:.18rem .42rem;align-items:center}.surface-list-heading>h2{font-size:.98rem}.surface-list-heading>.surface-count-summary{font-size:.74rem}.message{padding:.4rem .55rem;font-size:.82rem;gap:.45rem;border-radius:9px}.message-close{padding:.14rem .44rem;font-size:.74rem}.holdings-form-container{padding:.85rem;margin-bottom:0}.compact-support-grid{gap:.6rem;margin-top:.65rem}.compact-support-section{padding:.68rem .72rem;border-radius:10px;background:#fff}.transaction-entry-card .category-entry-toolbar{width:100%;justify-content:flex-start}.table-summary{font-size:.8rem}.table-card{overflow-x:hidden}.table-card>*{min-width:0;max-width:100%}table{min-width:0}table,thead,tbody,th,td,tr{display:block;width:100%;box-sizing:border-box}thead tr{display:none}tr{border:1px solid #e6edf7;border-radius:8px;margin-bottom:.8rem;padding:.5rem;background:#fff}tr.transaction-row{border-left:.55rem solid var(--transaction-row-accent, transparent);padding-left:.25rem}.mobile-toggle-btn{display:inline-flex}td[data-label=동작]:before{display:none}tr.transaction-row td[data-label=동작] .inline,tr.holding-row td[data-label=동작] .inline{justify-content:flex-end;width:100%}tr.transaction-row:not(.mobile-row-expanded) td[data-label=동작] .inline>button:not(.mobile-toggle-btn),tr.holding-row:not(.mobile-row-expanded) td[data-label=동작] .inline>button:not(.mobile-toggle-btn){display:none}tr.transaction-row:not(.mobile-row-expanded) td[data-label]:not([data-label=일자]):not([data-label=유형]):not([data-label=금액]):not([data-label=동작]){display:none}tr.holding-row:not(.mobile-row-expanded) td[data-label]:not([data-label=이름]):not([data-label=유형]):not([data-label="평가(KRW)"]):not([data-label=동작]){display:none}td{border:none;border-bottom:1px solid #f4f8ff;padding:.4rem .2rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;text-align:right;white-space:normal;word-break:break-all;gap:.5rem}.transaction-row td:first-child{box-shadow:none;padding-left:.2rem}.settings-color-row{grid-template-columns:minmax(0,1fr) auto auto}.settings-color-preview-bar{grid-column:1 / -1}.invite-acceptance-banner,.invite-arrival-banner{align-items:flex-start;flex-direction:column}.invite-acceptance-banner .inline,.invite-arrival-banner .inline{width:100%}.invite-banner-actions,.invite-table-actions{width:100%;justify-content:flex-start}.collaboration-toolbar label,.collaboration-toolbar .table-summary{width:100%;max-width:none}td:last-child{border-bottom:0}td:before{content:attr(data-label);font-weight:600;color:#355177;text-align:left;flex-shrink:0;word-break:keep-all}td[colspan]{display:block;text-align:center;padding:1rem}td[colspan]:before{display:none}.holdings-inline-editor{grid-template-columns:repeat(2,minmax(0,1fr))}.tx-inline-date-field,.tx-inline-type-field,.tx-inline-amount-field,.tx-inline-major-field,.tx-inline-minor-field,.tx-inline-memo-field,.tx-inline-owner-field{width:100%;max-width:100%}.tx-inline-editor-actions{gap:.45rem;justify-content:flex-end}.tx-inline-category-section{max-width:100%}.surface-ledger-mobile-head,.mobile-date-text,.transaction-mobile-category-cue,.transaction-owner-chip,.transaction-flow-short,.holding-mobile-meta,.holding-owner-chip{display:none}.transaction-col-memo,.transaction-memo-text,.holding-name-cell,.holding-mobile-meta{min-width:0}.tx-entry-banner,.compact-support-header,.settings-color-row,.settings-category-flow-header,.settings-category-group-header,.settings-category-row{grid-template-columns:minmax(0,1fr)}.compact-inline-select{width:100%;min-width:0}.settings-actions{justify-content:stretch}.settings-actions button{width:100%}.filter-container,.actions,.filter-modes-segmented,.filter-modes-segmented button,.month-stepper,.range-picker,.filter-apply-btn{max-width:100%;min-width:0;width:100%}.month-stepper .date-inputs input{width:3rem}.month-stepper .text-btn.apply-btn{margin-left:.25rem}}@media(max-width:760px){.transaction-list-card,.holding-list-card{--surface-section-sticky-top: calc(var(--mobile-tabs-sticky-offset, 2.62rem) + .18rem);--surface-heading-sticky-height: 2.18rem;--surface-ledger-sticky-top: calc(var(--surface-section-sticky-top) + var(--surface-heading-sticky-height))}.transaction-list-card>.surface-list-heading,.holding-list-card>.surface-list-heading{position:sticky;top:var(--surface-section-sticky-top);z-index:24;padding:.12rem 0 .24rem;margin-bottom:0;background:linear-gradient(180deg,#fffffffb,#fffffff0);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid rgba(219,227,239,.78);box-shadow:0 10px 18px -24px #0f172a61}.surface-ledger-mobile-head{display:grid;align-items:center;gap:.35rem;padding:.32rem .62rem .28rem .68rem;margin:0;border:1px solid #dbe3ef;border-bottom:1px solid #dbe3ef;border-radius:12px 12px 0 0;background:#f7f9fc;color:#5f7596;font-size:.64rem;font-weight:700;letter-spacing:.01em;position:sticky;top:var(--surface-ledger-sticky-top, calc(var(--mobile-tabs-sticky-offset, 2.62rem) + .18rem));z-index:23;box-shadow:0 1px #ffffffeb,0 10px 20px -22px #0f172a8c}.transactions-mobile-ledger-head{grid-template-columns:2.85rem minmax(0,1fr) auto auto auto;grid-template-areas:"date main amount cues actions"}.holdings-mobile-ledger-head{grid-template-columns:minmax(0,1fr) minmax(0,4.8rem) auto auto;grid-template-areas:"main cues amount actions"}.surface-ledger-mobile-head .ledger-head-select{display:none}.surface-ledger-mobile-head .ledger-head-date{grid-area:date}.surface-ledger-mobile-head .ledger-head-main{grid-area:main;min-width:0}.surface-ledger-mobile-head .ledger-head-amount{grid-area:amount;text-align:right}.surface-ledger-mobile-head .ledger-head-cues{grid-area:cues;text-align:right}.surface-ledger-mobile-head .ledger-head-actions{grid-area:actions;text-align:center}.transactions-surface-table,.holdings-surface-table{display:block;width:100%;min-width:0;border-collapse:separate;border:1px solid #dbe3ef;border-radius:0 0 12px 12px;overflow:hidden;background:#fff}.transactions-surface-table thead,.holdings-surface-table thead{display:none}.transactions-surface-table tbody,.holdings-surface-table tbody{display:block;padding-top:1.46rem}.transactions-surface-table td,.holdings-surface-table td{display:block;border:0;padding:0;min-width:0;text-align:left;word-break:break-word}.transactions-surface-table td:before,.holdings-surface-table td:before{display:none;content:none}.transactions-surface-table tbody tr.transaction-row,.holdings-surface-table tbody tr.holding-row{margin-bottom:0;padding:.42rem .54rem .4rem .7rem;border-radius:0;border:0;border-bottom:1px solid #e8eef6;background:linear-gradient(90deg,var(--transaction-row-wash-strong, var(--holding-row-wash-strong, rgba(255, 255, 255, .99))) 0%,var(--transaction-row-wash, var(--holding-row-wash, rgba(255, 255, 255, .97))) 36%,var(--transaction-row-wash-soft, var(--holding-row-wash-soft, rgba(255, 255, 255, .95))) 100%);box-shadow:inset 0 0 0 1px var(--transaction-row-border, var(--holding-row-border, rgba(15, 23, 42, .06)));gap:.2rem .45rem;align-items:center;position:relative}.transactions-surface-table tbody tr.transaction-row:first-child,.holdings-surface-table tbody tr.holding-row:first-child{margin-top:0}.transactions-surface-table tbody tr.transaction-row td,.holdings-surface-table tbody tr.holding-row td{background:transparent}.transactions-surface-table tbody tr.transaction-row{display:grid;grid-template-columns:2.85rem minmax(0,1fr) auto auto auto;grid-template-areas:"date memo amount type actions"}.transactions-surface-table tbody tr.transaction-row.mobile-row-expanded{grid-template-areas:"date memo amount type actions" "category category category category category" "owner owner owner owner owner" "updated updated updated updated updated";border-bottom:0;padding-bottom:.22rem}.transactions-surface-table tbody tr.transaction-row:before,.holdings-surface-table tbody tr.holding-row:before{content:"";position:absolute;left:.22rem;top:.44rem;bottom:.44rem;width:.2rem;border-radius:999px;background:var(--transaction-row-accent, var(--holding-row-cue, transparent))}.transactions-surface-table .transaction-col-select{display:none!important}.transactions-surface-table .transaction-col-date{grid-area:date;font-size:.7rem;color:#6a7f99;white-space:nowrap}.transactions-surface-table .transaction-col-date .desktop-date-text{display:none}.transactions-surface-table .transaction-col-date .mobile-date-text{display:inline}.transactions-surface-table .transaction-col-amount{grid-area:amount;justify-self:end;text-align:right;white-space:nowrap;font-size:.82rem}.transactions-surface-table .transaction-col-category{display:none!important}.transactions-surface-table .transaction-col-type{grid-area:type;justify-self:end;text-align:right;display:inline-flex;align-items:center;gap:.12rem;white-space:nowrap}.transactions-surface-table .transaction-col-memo{grid-area:memo;display:block!important;min-width:0;white-space:nowrap}.transactions-surface-table .transaction-col-owner,.transactions-surface-table .transaction-col-updated{display:none!important}.transactions-surface-table .transaction-mobile-category-cue{display:none}.transactions-surface-table .transaction-memo-text{display:block;width:100%;font-size:.85rem;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.transactions-surface-table .transaction-owner-chip{display:inline-flex}.transactions-surface-table .transaction-flow-full,.transactions-surface-table .transaction-flow-short{display:none}.transactions-surface-table tbody tr.transaction-row.mobile-row-expanded .transaction-col-updated{display:block!important;grid-column:2 / -1;padding-top:.18rem;font-size:.76rem;color:#6a7f99}.transactions-surface-table tbody tr.transaction-row.mobile-row-expanded .transaction-col-category,.transactions-surface-table tbody tr.transaction-row.mobile-row-expanded .transaction-col-owner{display:block!important;grid-column:2 / -1;padding-top:.18rem;font-size:.76rem;color:#5f7596}.transactions-surface-table tbody tr.transaction-row.mobile-row-expanded .transaction-col-category{padding-top:.28rem;border-top:1px solid var(--transaction-row-border, rgba(220, 230, 244, .9))}.transactions-surface-table .transaction-col-actions{grid-area:actions;justify-self:end;position:relative;z-index:2;width:1.72rem}.transactions-surface-table tbody tr.transaction-row .transaction-col-actions .inline,.holdings-surface-table tbody tr.holding-row .holding-col-actions .inline{justify-content:flex-end;width:auto}.transactions-surface-table tbody tr.transaction-row:not(.mobile-row-expanded) .transaction-col-category,.transactions-surface-table tbody tr.transaction-row:not(.mobile-row-expanded) .transaction-col-owner,.holdings-surface-table tbody tr.holding-row:not(.mobile-row-expanded) .holding-col-owner{display:none!important}.transactions-surface-table tbody tr.transaction-row .transaction-col-actions .inline>button:not(.mobile-toggle-btn),.holdings-surface-table tbody tr.holding-row .holding-col-actions .inline>button:not(.mobile-toggle-btn){display:none}.transactions-surface-table .transaction-col-select,.transactions-surface-table .transaction-col-actions{border:0}.transactions-surface-table .category-cell{gap:0}.transactions-surface-table .category-cell-compact{display:inline}.transactions-surface-table .category-cell-major,.transactions-surface-table .category-cell-minor{display:none}.transactions-surface-table .transaction-flow-badge{min-width:auto;padding-inline:.34rem;font-size:.66rem}.holdings-surface-table tbody tr.holding-row{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,4.8rem) auto auto;grid-template-areas:"name type market actions"}.holdings-surface-table tbody tr.holding-row.mobile-row-expanded{grid-template-areas:"name type market actions" "owner owner owner owner" "quantity quantity quantity quantity" "average average average average" "gain gain gain gain" "updated updated updated updated";border-bottom:0;padding-bottom:.22rem}.holdings-surface-table .holding-col-select{display:none!important}.holdings-surface-table .holding-col-name{grid-area:name;width:auto;min-width:0;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;-webkit-line-clamp:unset;-webkit-box-orient:initial}.holdings-surface-table .holding-col-market{grid-area:market;width:auto;justify-self:end;text-align:right;font-weight:700;font-size:.84rem;color:#132b4c}.holdings-surface-table .holding-col-type{grid-area:type;width:auto;min-width:0;max-width:5.3rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:.72rem;color:#5f7596}.holdings-surface-table .holding-type-label,.holdings-surface-table .holding-type-category-hint{display:none}.holdings-surface-table .holding-mobile-meta{display:inline}.holdings-surface-table .holding-owner-chip{display:inline-flex;margin-left:.2rem;vertical-align:middle}.holdings-surface-table .holding-name-cell:before{width:.42rem;height:.42rem;margin-right:.34rem}.holdings-surface-table .section-header-cell{padding:.26rem .48rem;font-size:.78rem}.holdings-surface-table .section-header-cell .inline{gap:.35rem;align-items:center;min-width:0;flex-wrap:nowrap}.holdings-surface-table .section-header-cell .inline>span:first-child{flex:1 1 auto;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.holdings-surface-table .section-header-cell .inline>span.inline{flex:0 0 auto;gap:.18rem}.holdings-surface-table .section-header-cell .inline>span.inline button{padding:.04rem .22rem;min-width:0;font-size:.72rem;line-height:1.05}.holdings-surface-table .holding-col-owner,.holdings-surface-table .holding-col-category,.holdings-surface-table .holding-col-quantity,.holdings-surface-table .holding-col-average,.holdings-surface-table .holding-col-gain,.holdings-surface-table .holding-col-updated{display:none!important}.holdings-surface-table tbody tr.holding-row.mobile-row-expanded .holding-col-quantity,.holdings-surface-table tbody tr.holding-row.mobile-row-expanded .holding-col-average,.holdings-surface-table tbody tr.holding-row.mobile-row-expanded .holding-col-gain,.holdings-surface-table tbody tr.holding-row.mobile-row-expanded .holding-col-updated{display:block!important;grid-column:2 / -1;padding-top:.18rem;font-size:.78rem;color:#5f7596}.holdings-surface-table tbody tr.holding-row.mobile-row-expanded .holding-col-owner{display:block!important;grid-column:2 / -1;padding-top:.28rem;border-top:1px solid var(--holding-row-border, rgba(220, 230, 244, .9));font-size:.76rem;color:#5f7596}.holdings-surface-table .holding-col-actions{grid-area:actions;justify-self:end;position:relative;z-index:2}.transactions-surface-table .mobile-toggle-btn,.holdings-surface-table .mobile-toggle-btn{width:1.72rem;min-width:1.72rem;height:1.72rem;padding:0;border-radius:14px;border-color:var(--transaction-row-border, var(--holding-row-border, rgba(151, 172, 201, .55)));background:linear-gradient(180deg,#fffffffc,#f2f7fff0);color:#284a7b;box-shadow:inset 0 1px #fffffff0,0 10px 18px -20px #0f172a8c}.transactions-surface-table .mobile-toggle-btn:hover,.holdings-surface-table .mobile-toggle-btn:hover{transform:translateY(-1px);border-color:#2563eb47;box-shadow:inset 0 1px #fffffff5,0 12px 20px -20px #2563eb61}.transactions-surface-table .mobile-toggle-icon,.holdings-surface-table .mobile-toggle-icon{display:inline-flex;align-items:center;justify-content:center;width:100%;height:100%}.transactions-surface-table .mobile-toggle-icon svg,.holdings-surface-table .mobile-toggle-icon svg{width:.98rem;height:.98rem;transition:transform .18s ease}.transactions-surface-table .mobile-toggle-btn[aria-expanded=true] .mobile-toggle-icon svg,.holdings-surface-table .mobile-toggle-btn[aria-expanded=true] .mobile-toggle-icon svg{transform:rotate(90deg)}.transactions-surface-table .mobile-toggle-btn[aria-expanded=true],.holdings-surface-table .mobile-toggle-btn[aria-expanded=true]{background:linear-gradient(180deg,#fffffffe,#e9f2fff5);color:#173f7a}.transaction-mobile-expanded-actions-row,.holding-mobile-expanded-actions-row{display:table-row}.transaction-mobile-expanded-actions-row>td,.holding-mobile-expanded-actions-row>td{padding:0 .54rem .42rem .7rem;border:0;border-bottom:1px solid #e8eef6;background:linear-gradient(90deg,var(--transaction-row-wash-strong, var(--holding-row-wash-strong, rgba(255, 255, 255, .98))) 0%,var(--transaction-row-wash, var(--holding-row-wash, rgba(255, 255, 255, .96))) 34%,var(--transaction-row-wash-soft, var(--holding-row-wash-soft, rgba(255, 255, 255, .94))) 100%)}.transaction-mobile-expanded-actions,.holding-mobile-expanded-actions{display:flex;width:100%;justify-content:flex-end;gap:.34rem;flex-wrap:wrap;padding-top:.28rem;border-top:1px dashed var(--transaction-row-border, var(--holding-row-border, #dce6f4))}.transaction-mobile-expanded-actions button,.holding-mobile-expanded-actions button{min-width:auto;padding:.26rem .6rem;font-size:.74rem;border-radius:999px}}@media(prefers-reduced-motion:reduce){.tab-invite-pulse,.invite-row-new{animation:none}}
