*,*:before,*:after{box-sizing:border-box}html,body{margin:0;padding:0}html{overflow-x:hidden}body{font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;overflow-x:hidden;min-width:0}#root{min-width:0;width:100%}button{transition:background-color .15s ease,transform .05s ease}button:hover{filter:brightness(.85)}button:active{transform:scale(.98)}:root{--bg: #f8fafc;--surface: #ffffff;--text: #0f172a;--muted: #64748b;--border: #e2e8f0;--shadow: 0 18px 55px rgba(0, 0, 0, .1);--primary: #2563eb;--primary-hover: #1d4ed8;--danger: #e11d48;--danger-hover: #be123c;--success-bg: #ecfdf5;--success-border: #bbf7d0;--success-text: #166534;--error-bg: #fef2f2;--error-border: #fecaca;--error-text: #b91c1c;--radius: 12px}html,body{height:100%}body{background:var(--bg);color:var(--text)}.appContainer{min-height:100vh}.pageCentered{min-height:100vh;display:grid;place-items:center;padding:16px}.authBgLogin{background:linear-gradient(135deg,#eef2ff,#fff)}.authBgRegister{background:linear-gradient(135deg,#ecfeff,#fff)}.card{width:100%;max-width:420px;background:var(--surface);border-radius:calc(var(--radius) + 4px);border:1px solid var(--border);box-shadow:var(--shadow);overflow:hidden}.cardHeader{padding:24px;border-bottom:1px solid #eef2f7}.cardTitle{font-size:28px;font-weight:800;letter-spacing:-.5px}.cardSubtitle{margin-top:6px;color:var(--muted)}.cardBody{padding:24px}.loginLangSwitch{display:flex;justify-content:flex-end;align-items:center;gap:8px;margin-bottom:16px}.loginLangSwitchLabel{font-size:12px;color:var(--muted);margin-right:4px}.loginLangSwitchGroup{display:inline-flex;border-radius:8px;border:1px solid var(--border);overflow:hidden;background:#f8fafc}.loginLangSwitchBtn{margin:0;padding:6px 12px;font-size:12px;font-weight:700;border:none;background:transparent;color:var(--muted);cursor:pointer;line-height:1.2}.loginLangSwitchBtn:hover{color:var(--text);background:#ffffffb3}.loginLangSwitchBtn--active{background:#fff;color:var(--primary);box-shadow:0 0 0 1px var(--border)}.fieldLabel{display:block;font-size:13px;color:#475569;margin-bottom:6px}.textInput{width:100%;padding:12px 14px;border-radius:10px;border:1px solid #cbd5e1;outline:none;font-size:14px}.textInput:focus{border-color:#93c5fd;box-shadow:0 0 0 3px #3b82f633}.btn{border:none;border-radius:10px;padding:12px 14px;font-weight:700;font-size:15px;cursor:pointer}.btn:disabled{cursor:default;opacity:.65}.btnPrimary{background:var(--primary);color:#fff;box-shadow:0 10px 22px #2563eb40}.btnPrimary:hover:not(:disabled){background:var(--primary-hover)}.btnDanger{background:var(--danger);color:#fff}.btnDanger:hover:not(:disabled){background:var(--danger-hover)}.btnLink{background:none;border:none;padding:0;color:var(--primary);font-weight:700;cursor:pointer}.inlineAlert{margin-top:12px;padding:10px 12px;border-radius:10px;font-size:13px;white-space:pre-wrap;border:1px solid transparent}.inlineAlertError{background:var(--error-bg);border-color:var(--error-border);color:var(--error-text)}.inlineAlertSuccess{background:var(--success-bg);border-color:var(--success-border);color:var(--success-text)}.footerText{margin-top:16px;text-align:center;color:var(--muted);font-size:13px}.publicPortfoliosSection{margin-top:16px;padding-top:14px;border-top:1px solid var(--border)}.publicPortfoliosSectionTitle{font-weight:700;font-size:13px;color:#475569;margin-bottom:8px}.publicPortfolioItemLink{display:block;text-decoration:none;cursor:pointer;outline:none}.publicPortfolioItem{display:flex;align-items:center;gap:10px;padding:10px 12px;border:1px solid #cbd5e1;border-radius:10px;background:var(--surface);transition:background-color .15s ease,border-color .15s ease,transform .15s ease}.publicPortfolioName{font-weight:400;font-size:14px;color:var(--text)}.publicPortfolioCurrency{color:var(--muted);font-weight:400;font-size:14px}.publicPortfolioPnl{margin-left:auto;text-align:right;font-weight:400;font-size:14px;font-variant-numeric:tabular-nums}.publicPortfolioPnl--neutral{color:var(--muted)}.publicPortfolioPnl--success{color:var(--success-text)}.publicPortfolioPnl--error{color:var(--error-text)}.publicPortfoliosEmptyState{color:var(--muted);font-size:13px}.publicPortfoliosList{display:flex;flex-direction:column;gap:10px}.publicPortfolioItemLink:hover .publicPortfolioItem{background:#f1f5f9}.publicPortfolioItemLink:focus-visible{outline:3px solid rgba(37,99,235,.35);outline-offset:2px;border-radius:10px}.btnLogout{background:#e11d48;color:#fff;border:none;padding:8px 14px;border-radius:6px;cursor:pointer;font-weight:700;font-size:14px;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;transition:filter .15s ease}.btnLogout:hover{filter:brightness(.9)}.btnLogout:focus-visible{outline:3px solid rgba(225,29,72,.35);outline-offset:2px}.pageCentered{padding:max(12px,env(safe-area-inset-top)) max(12px,env(safe-area-inset-right)) max(12px,env(safe-area-inset-bottom)) max(12px,env(safe-area-inset-left))}.card{max-width:min(420px,100%)}.cardTitle{font-size:clamp(1.25rem,4vw,1.75rem);flex-wrap:wrap;justify-content:center}.publicPortfolioItem{flex-wrap:wrap;row-gap:6px}.publicPortfolioName{min-width:0;flex:1 1 auto;word-break:break-word}.publicPortfolioPnl{margin-left:0;width:100%;text-align:right}@media(min-width:380px){.publicPortfolioPnl{margin-left:auto;width:auto}}.dashboardPage{padding:max(12px,env(safe-area-inset-top)) max(12px,env(safe-area-inset-right)) max(20px,env(safe-area-inset-bottom)) max(12px,env(safe-area-inset-left));font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;background:var(--bg);min-height:100vh;min-width:0;color:var(--text);box-sizing:border-box}.dashboardHeader{display:flex;flex-wrap:wrap;align-items:flex-start;justify-content:space-between;gap:12px 16px;margin-bottom:20px;padding-bottom:12px;border-bottom:1px solid var(--border)}.dashboardBrand{margin:0;display:flex;align-items:center;gap:10px;font-size:clamp(1.15rem,4.5vw,1.75rem);line-height:1.2;min-width:0}.dashboardHeaderActions{display:flex;flex-wrap:wrap;gap:8px;width:100%}@media(min-width:520px){.dashboardHeaderActions{width:auto;justify-content:flex-end}}.dashboardBtn{border:none;padding:8px 12px;border-radius:8px;cursor:pointer;font-weight:700;font-size:13px;white-space:nowrap}.dashboardBtn--primary{background:var(--primary);color:#fff}.dashboardBtn--danger{background:var(--danger);color:#fff}.dashboardMainGrid{display:grid;grid-template-columns:1fr;gap:24px;min-width:0;padding-top:16px}.dashboardMainGrid>*{min-width:0}.dashboardSidebar{width:100%;max-width:100%}.dashboardDetail{width:100%;min-width:0}.dashboardPieSection{margin-top:32px;border-top:2px solid var(--border);padding-top:20px;min-width:0}.walletRow{margin-bottom:10px;min-width:0}.walletCard{width:100%;min-width:0;padding:12px;border-radius:8px;cursor:pointer;box-sizing:border-box}.walletCard--selected{background:#e0f2fe;border:1px solid #38bdf8}.walletCard--idle{background:#fff;border:1px solid #cbd5e1}.walletTitleRow{display:flex;justify-content:space-between;align-items:flex-start;gap:8px;min-width:0}.walletTitleText{min-width:0;flex:1;word-break:break-word;line-height:1.35}.walletEditHit{flex-shrink:0;cursor:pointer;padding:0 2px;-webkit-user-select:none;user-select:none}.walletMetaRow{display:flex;flex-wrap:wrap;gap:8px 12px;align-items:center;justify-content:space-between;font-size:12px;margin-top:8px;min-width:0}.walletMetaRowLeft{display:flex;flex-wrap:wrap;gap:8px 12px;align-items:center;min-width:0;flex:1}.walletDeleteBtn{width:36px;height:36px;min-width:36px;flex-shrink:0;align-self:center;border-radius:8px;border:1px solid #fecaca;color:#dc2626;cursor:pointer;background:#fff;display:grid;place-items:center;font-size:16px;padding:0;box-sizing:border-box}.transactionListRoot,.portfolioChartRoot,.addTxCardShell,.pieChartSectionRoot{min-width:0;width:100%;max-width:100%;box-sizing:border-box}.txListPanel{max-width:100%;min-width:0;box-sizing:border-box}@media(min-width:960px){.dashboardMainGrid{grid-template-columns:minmax(240px,300px) minmax(0,1fr);gap:30px}}.metricCards{display:grid;grid-template-columns:1fr;gap:12px;margin-top:16px;min-width:0}@media(min-width:560px){.metricCards{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(min-width:960px){.metricCards{grid-template-columns:repeat(4,minmax(0,1fr))}}.metricCard{padding:14px;border:1px solid #e5e7eb;border-radius:10px;background:#fff;min-width:0;text-align:center}.metricCardValue{font-size:clamp(1rem,3.5vw,1.375rem);font-weight:700;word-break:break-word}.dataScroll{overflow-x:auto;overflow-y:visible;-webkit-overflow-scrolling:touch;margin-left:-4px;margin-right:-4px;padding-bottom:4px;min-width:0;max-width:100%}.txGridMin{--tx-grid-min: 1540px;width:100%;min-width:max(100%,var(--tx-grid-min));box-sizing:border-box}.txGridMin .txGridRow{width:100%;min-width:100%;max-width:none;box-sizing:border-box}.addTxForm{display:grid;grid-template-columns:1fr;gap:12px;align-items:end}@media(min-width:1100px){.addTxForm{grid-template-columns:140px 160px 44px 160px 140px 160px 160px 44px}}.addTxOrBetweenSpacer{visibility:hidden;-webkit-user-select:none;user-select:none;pointer-events:none}.addTxOrBetweenWord{display:flex;align-items:center;justify-content:center;height:36px;font-size:12px;font-weight:600;color:#64748b;text-transform:lowercase}@media(max-width:1099px){.addTxOrBetweenSpacer{display:none}.addTxOrBetweenWord{height:auto;padding:6px 0}}.addTxSubmitBtn{height:44px;justify-self:stretch}@media(min-width:1100px){.addTxSubmitBtn{height:36px;justify-self:end;width:44px;padding:0}}.dashboardFormPanel{display:flex;flex-direction:column;padding:14px;border:1px solid #e5e7eb;border-radius:10px;background:#fff;box-sizing:border-box;min-width:0;width:100%}.dashboardFormPanelTitle{font-weight:700;margin-bottom:10px;flex-shrink:0}.addPortfolioPanel.dashboardFormPanel{margin-top:0}.dashboardFormPanel>form{flex:1 1 auto;min-height:0}@media(min-width:1100px){.dashboardFormPanel{min-height:172px}}.addPortfolioForm{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-top:0}.addPortfolioForm .addPortfolioNameInput{flex:1 1 180px;min-width:0}.addPortfolioForm select{flex:0 0 auto}.addPortfolioFormActions{flex:1 1 100%;display:flex;align-items:center;justify-content:space-between;gap:8px}.chartToolbar{display:flex;flex-wrap:wrap;align-items:center;gap:10px;min-width:0}.chartToolbarGroup{display:flex;flex-wrap:wrap;gap:8px;align-items:center;min-width:0}.chartToolbarGrow{flex:1 1 220px;min-width:0;display:flex;flex-wrap:wrap;gap:8px;align-items:center;justify-content:flex-end}.chartToolbarGrow .textInput{width:100%;max-width:260px;min-width:0}.publicPage{padding:max(12px,env(safe-area-inset-top)) max(12px,env(safe-area-inset-right)) max(20px,env(safe-area-inset-bottom)) max(12px,env(safe-area-inset-left));font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;background:var(--bg);min-height:100vh;min-width:0;color:var(--text)}.publicPageHeader{display:flex;flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:16px}.publicPageHeaderTitleRow{display:flex;flex-wrap:wrap;align-items:baseline;gap:6px 10px;min-width:0;flex:1 1 140px}.publicPageHeaderTitleRow h1{margin:0;font-size:clamp(1.1rem,4vw,1.5rem);min-width:0;word-break:break-word;line-height:1.25}.publicPageHeaderMeta{color:var(--muted);font-size:12px;font-weight:500;flex-shrink:0;line-height:1.25}.publicPageHeaderActions{flex:1 1 100%;display:flex;justify-content:flex-start}@media(min-width:640px){.publicPageHeaderActions{flex:0 0 auto;margin-left:auto;justify-content:flex-end}}.publicPageLoading{display:flex;align-items:flex-start;justify-content:center;padding-top:max(24px,env(safe-area-inset-top))}.publicPageLoadingInner{width:100%;max-width:400px;padding:20px 16px;background:var(--surface);border:1px solid var(--border);border-radius:calc(var(--radius) + 4px);box-shadow:var(--shadow);box-sizing:border-box}.publicPageLoadingTitle{margin:0 0 6px;font-size:1.25rem;font-weight:800;color:var(--text);text-align:center}.publicPageLoadingSub{margin:0 0 18px;font-size:14px;color:var(--muted);text-align:center}.loadProgressPanel{width:100%;max-width:400px;margin:0 auto}.loadProgressPanel--compact{max-width:none;margin:0}.publicPageLoadingInner--compact{padding:14px 12px;box-shadow:none;border-radius:var(--radius)}.loadProgressPanel--compact .publicPageLoadingTitle{font-size:1.05rem;text-align:left}.loadProgressPanel--compact .publicPageLoadingSub{text-align:left}.loadProgressTrack{height:8px;border-radius:999px;background:#e2e8f0;overflow:hidden}.loadProgressTrack--indeterminate{background:linear-gradient(90deg,#e2e8f0,#cbd5e1,#e2e8f0 90%);background-size:200% 100%;animation:loadProgressShimmer 1.15s ease-in-out infinite}@keyframes loadProgressShimmer{0%{background-position:100% 0}to{background-position:-100% 0}}.loadProgressFill{height:100%;border-radius:999px;background:linear-gradient(90deg,var(--primary),#60a5fa);transition:width .35s ease}.loadProgressFraction{margin:10px 0 0;font-size:13px;font-weight:700;color:#475569;text-align:center;font-variant-numeric:tabular-nums}.loadProgressSteps{list-style:none;margin:16px 0 0;padding:0;font-size:13px;color:#64748b}.loadProgressSteps li{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid #f1f5f9}.loadProgressSteps li:last-child{border-bottom:none}.loadProgressSteps__mark{display:inline-flex;width:1.5rem;justify-content:center;font-weight:800;color:var(--muted)}.loadProgressSteps__item--done{color:#166534}.loadProgressSteps__item--done .loadProgressSteps__mark{color:#16a34a}.dashboardBootOverlay{position:fixed;inset:0;z-index:100;display:flex;align-items:flex-start;justify-content:center;padding:max(32px,env(safe-area-inset-top)) 16px 16px;background:#f8fafcf0;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);box-sizing:border-box}.dashboardBootOverlay .loadProgressPanel{margin-top:min(12vh,80px)}.pieChartCard{flex:1 1 100%;min-width:0;max-width:520px;width:100%;padding:16px;background:#fff;border-radius:12px;border:1px solid #e5e7eb;box-shadow:0 1px 3px #0000000d}.pieChartGrid{display:flex;flex-wrap:wrap;gap:20px;justify-content:center}.pieChartInner{width:100%;height:min(320px,55vw);min-height:220px}
