*,*: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}.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}@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}.metricCardValue{font-size:clamp(1rem,3.5vw,1.375rem);font-weight:700;word-break:break-word}.dataScroll{overflow-x:auto;-webkit-overflow-scrolling:touch;margin-left:-4px;margin-right:-4px;padding-bottom:4px;min-width:0}.txGridMin{min-width:1180px}.addTxForm{display:grid;grid-template-columns:1fr;gap:12px;align-items:end}@media(min-width:1100px){.addTxForm{grid-template-columns:140px 160px 160px 140px 160px 160px 44px}}.addTxSubmitBtn{height:44px;justify-self:stretch}@media(min-width:1100px){.addTxSubmitBtn{height:36px;justify-self:end;width:44px;padding:0}}.addPortfolioForm{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-top:12px}.addPortfolioForm .addPortfolioNameInput{flex:1 1 180px;min-width:0}.addPortfolioForm select{flex:0 0 auto}.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}.publicPageHeader h1{margin:0;font-size:clamp(1.1rem,4vw,1.5rem);flex:1 1 200px;min-width:0;word-break:break-word}.publicPageHeaderMeta{color:var(--muted);font-size:12px;flex:1 1 100%}@media(min-width:640px){.publicPageHeaderMeta{flex:0 0 auto}}.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}}.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}
