.layout{min-height:100vh;display:flex;flex-direction:column;background:linear-gradient(to bottom,#fafbfc,#f3f4f6,#fafbfc)}.navbar{background:#ffffffd9;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);color:#1f2937;padding:0;box-shadow:0 1px 3px #0000000d,0 1px 2px #00000008;border-bottom:1px solid rgba(226,232,240,.8);position:sticky;top:0;z-index:100;transition:all .3s ease;-webkit-transition:all .3s ease;padding-top:env(safe-area-inset-top)}.navbar-container{max-width:1400px;margin:0 auto;padding:0 2.5rem;display:flex;justify-content:space-between;align-items:center;height:80px}.navbar-brand{text-decoration:none;display:flex;align-items:center;gap:.875rem;transition:all .3s cubic-bezier(.4,0,.2,1);padding:.5rem .75rem;border-radius:12px}.brand-icon{width:42px;height:42px;border-radius:12px;background:linear-gradient(135deg,#6366f1,#8b5cf6);display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.25rem;box-shadow:0 4px 12px #6366f14d;transition:all .3s ease}.brand-text{display:flex;flex-direction:column;gap:.125rem}.brand-title{font-size:1.25rem;font-weight:700;color:#1f2937;letter-spacing:-.5px;line-height:1.2}.brand-subtitle{font-size:.6875rem;font-weight:500;color:#6b7280;text-transform:uppercase;letter-spacing:.5px}.navbar-brand:hover{transform:translate(2px);-webkit-transform:translateX(2px)}.navbar-brand:hover .brand-icon{transform:rotate(-5deg) scale(1.05);-webkit-transform:rotate(-5deg) scale(1.05);box-shadow:0 6px 16px #6366f166}@media (max-width: 768px){.navbar-brand:hover{transform:none;-webkit-transform:none}.navbar-brand:hover .brand-icon{transform:scale(1.02);-webkit-transform:scale(1.02)}}.navbar-actions{display:flex;align-items:center;gap:.75rem;margin-left:1.5rem}.navbar-search{position:relative;display:flex;align-items:center}.search-icon-button{display:flex;align-items:center;justify-content:center;width:44px;height:44px;border:1px solid rgba(226,232,240,.8);border-radius:12px;background:#ffffffe6;color:#6b7280;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);outline:none}.search-icon-button:hover{background:#fff;border-color:#6366f1;color:#6366f1;box-shadow:0 0 0 3px #6366f11a;transform:scale(1.05);-webkit-transform:scale(1.05)}@media (max-width: 768px){.search-icon-button:hover{transform:none;-webkit-transform:none}}.search-icon-only{font-size:1.25rem}.search-input-wrapper{position:relative;display:flex;align-items:center;width:44px;transition:width .3s cubic-bezier(.4,0,.2,1);overflow:hidden}.search-input-wrapper.expanded{width:400px;max-width:400px}.search-input{width:100%;padding:.75rem 2.75rem .75rem 1rem;border:1px solid rgba(226,232,240,.8);border-radius:12px;background:#ffffffe6;color:#1f2937;font-size:.875rem;font-weight:500;transition:all .2s ease;-webkit-transition:all .2s ease;outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none}.search-input:focus{background:#fff;border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.search-input.highlighted{animation:searchHighlight .6s ease-out}.search-input-wrapper.highlighted{animation:searchWrapperPulse .6s ease-out}@keyframes searchHighlight{0%{box-shadow:0 0 0 3px #6366f11a}50%{box-shadow:0 0 0 6px #6366f14d,0 0 20px #6366f133;transform:scale(1.02)}to{box-shadow:0 0 0 3px #6366f11a}}@keyframes searchWrapperPulse{0%{transform:scale(1)}50%{transform:scale(1.02)}to{transform:scale(1)}}.search-input::placeholder{color:#9ca3af}.search-icon-right{position:absolute;right:1rem;color:#9ca3af;font-size:1.125rem;pointer-events:none;z-index:1}.search-results{position:absolute;top:calc(100% + .5rem);right:0;min-width:100%;background:#fff;border:1px solid rgba(226,232,240,.8);border-radius:12px;box-shadow:0 10px 40px #00000026,0 4px 16px #0000001a;overflow:hidden;z-index:1000;max-height:300px;overflow-y:auto}.search-result-item{display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;cursor:pointer;transition:background-color .2s ease;border-bottom:1px solid rgba(226,232,240,.5)}.search-result-item:last-child{border-bottom:none}.search-result-item:hover{background-color:#f9fafb}.search-result-item.selected{background-color:#eff6ff;border-left:3px solid #6366f1}.search-result-symbol{font-weight:700;font-size:.9375rem;color:#1f2937;min-width:80px}.search-result-name{flex:1;font-size:.875rem;color:#6b7280;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.search-result-exchange{padding:.25rem .5rem;border-radius:6px;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.3px;cursor:default;-webkit-user-select:none;user-select:none}.search-result-exchange.exchange-nasdaq{background:#3b82f614;color:#3b82f6;border:1px solid rgba(59,130,246,.2)}.search-result-exchange.exchange-tase{background:#8b5cf614;color:#8b5cf6;border:1px solid rgba(139,92,246,.2)}.search-result-exchange.exchange-nyse{background:#10b98114;color:#059669;border:1px solid rgba(16,185,129,.2)}.search-result-exchange.exchange-other{background:#64748b14;color:#64748b;border:1px solid rgba(100,116,139,.2)}.navbar-links{display:flex;gap:.5rem;align-items:center;background:#f9fafb99;padding:.375rem;border-radius:12px;border:1px solid rgba(226,232,240,.8)}.nav-link{color:#6b7280;text-decoration:none;padding:.625rem 1.25rem;border-radius:10px;transition:all .2s cubic-bezier(.4,0,.2,1);font-weight:600;font-size:.9375rem;letter-spacing:-.01em;position:relative;display:flex;align-items:center;gap:.5rem;background:transparent}.nav-icon{font-size:1.125rem;transition:all .2s ease}.nav-link:hover{color:#1f2937;background-color:#fffc;transform:translateY(-1px);-webkit-transform:translateY(-1px)}.nav-link:hover .nav-icon{transform:scale(1.1);-webkit-transform:scale(1.1)}@media (max-width: 768px){.nav-link:hover,.nav-link:hover .nav-icon{transform:none;-webkit-transform:none}}.nav-link.active{color:#6366f1;background:#fff;box-shadow:0 1px 3px #00000014,0 4px 12px #6366f126}.nav-link.active .nav-icon{color:#8b5cf6}.upload-icon-button{display:flex;align-items:center;justify-content:center;width:44px;height:44px;border:1px solid rgba(226,232,240,.8);border-radius:12px;background:#ffffffe6;color:#6b7280;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);outline:none}.upload-icon-button:hover:not(:disabled){background:#fff;border-color:#6366f1;color:#6366f1;box-shadow:0 0 0 3px #6366f11a;transform:scale(1.05);-webkit-transform:scale(1.05)}.upload-icon-button:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 768px){.upload-icon-button:hover:not(:disabled){transform:none;-webkit-transform:none}}.upload-icon{font-size:1.25rem}.upload-spinner{width:18px;height:18px;border:2px solid rgba(99,102,241,.2);border-top-color:#6366f1;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.menu-dropdown-container{position:relative;display:flex;align-items:center}.menu-icon-button{display:flex;align-items:center;justify-content:center;width:44px;height:44px;border:1px solid rgba(226,232,240,.8);border-radius:12px;background:#ffffffe6;color:#6b7280;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);outline:none}.menu-icon-button:hover{background:#fff;border-color:#6366f1;color:#6366f1;box-shadow:0 0 0 3px #6366f11a;transform:scale(1.05);-webkit-transform:scale(1.05)}.menu-icon-button[aria-expanded=true]{background:#fff;border-color:#6366f1;color:#6366f1;box-shadow:0 0 0 3px #6366f11a}@media (max-width: 768px){.menu-icon-button:hover{transform:none;-webkit-transform:none}}.menu-icon{font-size:1.25rem}.menu-dropdown{position:absolute;top:calc(100% + .5rem);right:0;min-width:180px;background:#fff;border:1px solid rgba(226,232,240,.8);border-radius:12px;box-shadow:0 10px 40px #00000026,0 4px 16px #0000001a;overflow:hidden;z-index:1000;animation:dropdownSlideIn .2s ease-out}@keyframes dropdownSlideIn{0%{transform:translateY(-10px);opacity:0}to{transform:translateY(0);opacity:1}}.menu-dropdown-item{display:flex;align-items:center;gap:.75rem;width:100%;padding:.875rem 1rem;background:transparent;border:none;color:#1f2937;font-size:.9375rem;font-weight:500;cursor:pointer;transition:background-color .2s ease;text-align:left;outline:none}.menu-dropdown-item:hover{background-color:#f9fafb}.menu-dropdown-item:active{background-color:#f3f4f6}.menu-dropdown-icon{font-size:1.125rem;color:#6b7280}.menu-dropdown-item:hover .menu-dropdown-icon{color:#6366f1}.menu-dropdown-item-broker-view{white-space:nowrap}.menu-dropdown-item-logout{border-top:1px solid rgba(226,232,240,.8);color:#dc2626}.menu-dropdown-item-logout:hover{background-color:#fef2f2;color:#dc2626}.menu-dropdown-item-logout .menu-dropdown-icon{color:#dc2626}.menu-dropdown-item-toggle{justify-content:space-between;gap:1rem}.menu-dropdown-item-interval{justify-content:space-between;gap:.75rem;cursor:default;border-top:1px solid rgba(226,232,240,.8)}.menu-dropdown-item-interval label{color:#4b5563;font-size:.875rem}.menu-interval-input{width:72px;padding:.35rem .5rem;border:1px solid rgba(209,213,219,1);border-radius:8px;font-size:.875rem;color:#1f2937;background:#fff}.menu-interval-input:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.menu-toggle{width:40px;height:22px;border-radius:999px;background:#d1d5db;display:inline-flex;align-items:center;padding:2px;transition:background-color .2s ease;flex-shrink:0}.menu-toggle.enabled{background:#6366f1}.menu-toggle-thumb{width:18px;height:18px;border-radius:50%;background:#fff;transition:transform .2s ease;box-shadow:0 1px 3px #0003}.menu-toggle.enabled .menu-toggle-thumb{transform:translate(18px)}@media (max-width: 768px){.menu-dropdown{min-width:160px}}.upload-message{position:fixed;top:80px;right:2rem;padding:1rem 1.5rem;border-radius:12px;font-size:.875rem;font-weight:500;box-shadow:0 4px 12px #00000026,0 2px 4px #0000001a;z-index:1000;animation:slideIn .3s ease-out;max-width:500px;line-height:1.6}.upload-message.upload-success{background:#d1fae5;color:#059669;border:1px solid #a7f3d0}.upload-message.upload-error{background:#fee2e2;color:#dc2626;border:1px solid #fecaca}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@media (max-width: 768px){.upload-message{top:120px;right:1rem;left:1rem;max-width:none}}.main-content{flex:1;max-width:1200px;width:100%;margin:0 auto;padding:2rem}@media (max-width: 768px){.navbar-container{flex-wrap:wrap;gap:1rem;height:auto;padding:1rem 1.5rem}.navbar-brand{padding:.375rem .5rem}.brand-icon{width:36px;height:36px;font-size:1.125rem}.brand-title{font-size:1.125rem}.brand-subtitle{font-size:.625rem}.navbar-links{width:100%;justify-content:space-between;padding:.375rem;order:2}.nav-link{padding:.625rem .5rem;font-size:.875rem;flex:1;justify-content:center;min-height:48px;min-width:48px}.nav-link span{display:none}.nav-icon{font-size:1.375rem}.navbar-actions{width:100%;margin:0;order:3;gap:.5rem}.navbar-search{width:100%;max-width:100%}.search-icon-button{width:48px;height:48px}.search-input-wrapper.expanded{width:100%;max-width:100%}.search-results{max-height:250px}.search-result-item{min-height:48px;padding:1rem}.upload-icon-button{width:48px;height:48px;order:4}.upload-icon{font-size:1.25rem}.menu-icon-button{margin-left:0;order:5;width:48px;height:48px}.menu-icon{font-size:1.25rem}.main-content{padding:1rem}}.shortcut-hint{position:fixed;top:100px;right:2rem;display:flex;align-items:center;gap:.75rem;padding:.75rem 1.25rem;background:#6366f1f2;color:#fff;border-radius:12px;font-size:.875rem;font-weight:600;box-shadow:0 4px 12px #6366f14d,0 2px 4px #0000001a;z-index:1001;animation:shortcutHintSlideIn .3s ease-out;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.shortcut-key{display:inline-flex;align-items:center;justify-content:center;min-width:2rem;padding:.25rem .5rem;background:#fff3;border:1px solid rgba(255,255,255,.3);border-radius:6px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-size:.8125rem;font-weight:700;letter-spacing:.5px}.shortcut-text{font-weight:500;letter-spacing:.3px}@keyframes shortcutHintSlideIn{0%{transform:translateY(-20px) scale(.95);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}@media (max-width: 768px){.shortcut-hint{top:140px;right:1rem;left:1rem;max-width:none;justify-content:center}}@media (max-width: 480px){.navbar-container{padding:.875rem 1rem}.nav-link{padding:.5rem .25rem}.nav-icon{font-size:1.25rem}.brand-subtitle{display:none}.main-content{padding:.75rem}.shortcut-hint{top:120px;padding:.625rem 1rem;font-size:.8125rem}.shortcut-key{min-width:1.75rem;padding:.2rem .4rem;font-size:.75rem}}.dashboard{padding:2rem;max-width:1200px;margin:0 auto;background:linear-gradient(to bottom,#f9fafb,#fff);min-height:100vh;overflow-x:hidden}.dashboard h1{margin-bottom:2rem;color:#8b5cf6;font-size:2rem;font-weight:700;letter-spacing:-.5px}.dashboard-content{display:flex;flex-direction:column;gap:2rem}.portfolio-cards-container{background:linear-gradient(135deg,#fffffff2,#f8fafcf2);padding:1rem 1.25rem;border-radius:16px;box-shadow:0 8px 30px #00000014,0 1px 3px #0000000d;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.8);transition:all .3s ease;-webkit-transition:all .3s ease}.portfolio-cards-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;flex-wrap:wrap;gap:.75rem}.portfolio-cards-title{margin:0;color:#1f2937;font-weight:700;font-size:1.5rem;letter-spacing:-.5px}.currency-toggle{display:inline-flex;background:#f9fafbcc;border-radius:10px;padding:.25rem;gap:.25rem;border:1px solid #e5e7eb;box-shadow:0 1px 2px #0000000d}.currency-toggle-btn{border:none;background:transparent;padding:.5rem 1rem;border-radius:8px;cursor:pointer;color:#6b7280;font-weight:600;font-size:.875rem;transition:all .2s ease;display:flex;align-items:center;gap:.5rem;white-space:nowrap}.currency-toggle-btn:hover{background:#fffc;color:#1f2937}.currency-toggle-btn.active{background:#fff;color:#6366f1;box-shadow:0 1px 3px #00000014,0 4px 12px #6366f126}.currency-toggle-btn span:first-child{font-size:1.125rem;font-weight:700}.portfolio-cards-container:hover{box-shadow:0 12px 40px #0000001f,0 2px 6px #0000000f;transform:translateY(-2px);-webkit-transform:translateY(-2px)}@media (max-width: 768px){.portfolio-cards-container{padding:1.5rem;border-radius:16px;width:100%}.portfolio-cards-container:hover{transform:none;-webkit-transform:none}.portfolio-cards-header{flex-direction:column;align-items:flex-start;margin-bottom:1rem}.portfolio-cards-title{font-size:1.25rem}.currency-toggle{width:100%;justify-content:stretch}.currency-toggle-btn{flex:1;justify-content:center}.portfolio-summary-modern{grid-template-columns:1fr;justify-content:stretch}}.portfolio-summary-modern{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.25rem}.value-card{background:#ffffffb3;padding:.75rem 1rem;border-radius:12px;box-shadow:0 1px 3px #00000008,0 2px 6px #0000000a;border:1px solid rgba(226,232,240,.6);transition:all .3s ease;-webkit-transition:all .3s ease;position:relative;overflow:hidden;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.value-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#3b82f6,#60a5fa)}.value-card-usd:before{background:linear-gradient(90deg,#3b82f6,#60a5fa)}.value-card-ils:before{background:linear-gradient(90deg,#8b5cf6,#a78bfa)}.value-card-portfolio:before{background:linear-gradient(90deg,#3b82f6,#8b5cf6)}.value-card-equity:before{background:linear-gradient(90deg,#8b5cf6,#a78bfa)}.value-card-performance.profit-card{background:#f0fdfacc;border-color:#10b9814d}.value-card-performance.profit-card:before{background:linear-gradient(90deg,#10b981,#34d399)}.value-card-performance.loss-card{background:#fef2f2cc;border-color:#ef44444d}.value-card-performance.loss-card:before{background:linear-gradient(90deg,#ef4444,#f87171)}.value-card:hover{transform:translateY(-2px);-webkit-transform:translateY(-2px);box-shadow:0 4px 8px #0000000f,0 8px 16px #00000014;background:#ffffffe6;border-color:#6366f133}@media (max-width: 768px){.value-card:hover{transform:none;-webkit-transform:none}}.card-title{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;padding-bottom:.5rem;border-bottom:1px solid #f3f4f6}.card-title-content{display:inline-flex;align-items:center;gap:.625rem}.card-title-content .card-currency-icon{font-size:1.25rem;font-weight:600;color:#8b5cf6;flex-shrink:0;line-height:1}.card-title-content .card-title-icon{font-size:1.25rem;color:#8b5cf6;flex-shrink:0}.card-title-content span{color:#1f2937;font-weight:600;font-size:.9375rem;letter-spacing:-.01em;line-height:1.4}.card-value{font-size:1.5rem;font-weight:700;color:#1f2937;line-height:1.2;margin-bottom:.375rem;letter-spacing:-.5px}.card-value-container{display:flex;flex-direction:column;gap:.5rem;margin-bottom:.375rem}.card-value-item{display:flex;flex-direction:column;gap:.25rem}.card-value-label{font-size:.8125rem;color:#6b7280;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.card-value-amount{font-size:1.25rem;font-weight:700;color:#1f2937;line-height:1.2;letter-spacing:-.5px}.performance-value{color:inherit}.value-card-performance.profit-card .card-value{color:#10b981}.value-card-performance.loss-card .card-value{color:#ef4444}.card-footer{padding-top:.375rem;border-top:1px solid #f3f4f6}.date-label{font-size:.8125rem;color:#6b7280;font-weight:500}.value-card-performance .date-label{font-size:1.125rem;font-weight:600;color:#4b5563}.percent-chip-large{padding:.375rem .75rem;border-radius:6px;font-size:.875rem;font-weight:700;line-height:1;white-space:nowrap}.percent-chip-large.profit-chip{color:#059669;background:#d1fae5;border:1px solid #a7f3d0}.percent-chip-large.loss-chip{color:#dc2626;background:#fee2e2;border:1px solid #fecaca}@media (max-width: 768px){.dashboard{padding:1rem}.dashboard-content{gap:1.5rem}.portfolio-summary-modern{grid-template-columns:1fr;gap:1rem}.value-card{padding:1rem}.card-value{font-size:1.5rem}.chart-header{flex-direction:column;align-items:flex-start;gap:1rem}.positions-list{grid-template-columns:1fr}}.positions-section{background:linear-gradient(135deg,#fffffff2,#f8fafcf2);padding:2rem;border-radius:20px;box-shadow:0 8px 30px #00000014,0 1px 3px #0000000d;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.8);transition:all .3s ease;-webkit-transition:all .3s ease}.positions-section:hover{box-shadow:0 12px 40px #0000001f,0 2px 6px #0000000f;transform:translateY(-2px);-webkit-transform:translateY(-2px)}@media (max-width: 768px){.positions-section{padding:1.5rem;border-radius:16px}.positions-section:hover{transform:none;-webkit-transform:none}}.section-title-nav-style{display:inline-flex;align-items:center;gap:.625rem;margin:0;padding:0}.section-title-nav-style .section-title-icon{font-size:1.375rem;color:#8b5cf6;flex-shrink:0}.section-title-nav-style span{color:#1f2937;font-weight:600;font-size:1.25rem;letter-spacing:-.01em;line-height:1.4}.positions-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.positions-section-header h2{margin-bottom:0}.positions-header-controls{display:flex;align-items:center;gap:1rem}.loss-filter-button{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:8px;border:1px solid #e5e7eb;background:#fff;color:#6b7280;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap}.loss-filter-button:hover{border-color:#ef4444;color:#dc2626;box-shadow:0 0 0 3px #ef44441a}.loss-filter-button-active{background:#fee2e2;border-color:#fca5a5;color:#dc2626;font-weight:600;box-shadow:0 0 0 3px #ef44441a}.loss-filter-button-active:hover{background:#fecaca;border-color:#f87171}.loss-filter-count{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;border-radius:10px;background:#dc2626;color:#fff;font-size:.75rem;font-weight:700}.daily-change-button{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:8px;border:1px solid #e5e7eb;background:#fff;color:#6b7280;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap}.daily-change-button:hover{border-color:#2563eb;color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.daily-change-button-active{background:#dbeafe;border-color:#93c5fd;color:#2563eb;font-weight:600;box-shadow:0 0 0 3px #2563eb1a}.daily-change-button-active:hover{background:#bfdbfe;border-color:#60a5fa}.position-since-purchase{display:block;font-size:.7rem;color:#6b7280;margin-top:.15rem;white-space:nowrap}.position-since-purchase-row{margin-top:.2rem}.section-title-icon-loss{color:#ef4444!important}.exchange-filter{position:relative;display:flex;align-items:center}.exchange-filter-button{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:8px;border:1px solid #e5e7eb;background:#fff;color:#1f2937;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;min-width:150px}.exchange-filter-button:hover{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.exchange-filter-button:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.exchange-filter-badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;border-radius:10px;background:#6366f1;color:#fff;font-size:.75rem;font-weight:600}.exchange-filter-dropdown{position:absolute;top:calc(100% + .5rem);left:0;z-index:1000;min-width:200px;background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 4px 12px #00000026,0 2px 4px #0000001a;overflow:hidden}.exchange-filter-header{display:flex;justify-content:space-between;padding:.75rem;border-bottom:1px solid #e5e7eb;background:#f9fafb}.exchange-filter-clear,.exchange-filter-select-all{padding:.25rem .5rem;border:none;background:transparent;color:#6366f1;font-size:.75rem;font-weight:600;cursor:pointer;transition:color .2s ease}.exchange-filter-clear:hover,.exchange-filter-select-all:hover{color:#4f46e5;text-decoration:underline}.exchange-filter-options{max-height:200px;overflow-y:auto;padding:.5rem 0}.exchange-filter-option{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;cursor:pointer;transition:background-color .2s ease}.exchange-filter-option:hover{background-color:#f9fafb}.exchange-filter-option input[type=checkbox]{width:16px;height:16px;cursor:pointer;accent-color:#6366f1}.exchange-filter-option span{font-size:.875rem;color:#1f2937;font-weight:500}.view-toggle{display:inline-flex;background:#f9fafb99;border-radius:10px;padding:.25rem;gap:.25rem;border:1px solid #e5e7eb}.view-toggle-btn{border:none;background:transparent;padding:.5rem;border-radius:8px;cursor:pointer;color:#6b7280;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.view-toggle-btn:hover{background:#fffc;color:#1f2937;transform:translateY(-1px)}.view-toggle-btn.active{background:#fff;color:#6366f1;box-shadow:0 1px 3px #00000014,0 4px 12px #6366f126}.view-toggle-btn.active:hover{background:#fff}.chart-section{background:linear-gradient(135deg,#fffffff2,#f8fafcf2);padding:2rem;border-radius:20px;box-shadow:0 8px 30px #00000014,0 1px 3px #0000000d;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.8);transition:all .3s ease;-webkit-transition:all .3s ease}.chart-section:hover{box-shadow:0 12px 40px #0000001f,0 2px 6px #0000000f;transform:translateY(-2px);-webkit-transform:translateY(-2px)}@media (max-width: 768px){.chart-section{padding:1.5rem;border-radius:16px}.chart-section:hover{transform:none;-webkit-transform:none}}.chart-container{background:#fff;border-radius:20px;padding:2rem 1.5rem;border:1px solid rgba(226,232,240,.6);box-shadow:0 10px 40px #0000001f,0 4px 16px #00000014;overflow:hidden;display:flex;flex-direction:column;min-height:500px}.chart-container-heatmap{padding:1rem;height:100%}.recharts-pie-label-text{font-size:13px;font-weight:700;fill:#1e293b;text-shadow:0 2px 4px rgba(255,255,255,.9)}.recharts-legend-item-text{font-weight:600!important;font-size:13px!important;color:#475569!important}.recharts-sector:hover{opacity:1;filter:brightness(1.05) saturate(1.1);cursor:pointer}.recharts-bar-rectangle:hover{filter:brightness(1.1) saturate(1.2);cursor:pointer}.chart-header{display:flex;justify-content:space-between;align-items:center;gap:1.5rem;flex-wrap:wrap;margin-bottom:2rem;width:100%;overflow:hidden}.chart-title-nav-style{display:inline-flex;align-items:center;gap:.625rem;margin:0;padding:0;max-width:100%;overflow:hidden}.chart-title-nav-style .chart-title-icon{font-size:1.375rem;color:#8b5cf6;flex-shrink:0}.chart-title-nav-style span{color:#1f2937;font-weight:600;font-size:1.25rem;letter-spacing:-.01em;line-height:1.4;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chart-toggle{display:inline-flex;background:linear-gradient(135deg,#f8fafcf2,#f1f5f9f2);border-radius:12px;padding:.3rem;gap:.3rem;box-shadow:0 2px 8px #0000000f,inset 0 1px 2px #0000000d;border:1px solid rgba(226,232,240,.6);flex-wrap:wrap}.toggle-button{border:none;background:transparent;padding:.6rem 1.1rem;border-radius:10px;font-weight:700;font-size:.85rem;cursor:pointer;color:#64748b;transition:all .3s ease;-webkit-transition:all .3s ease;display:inline-flex;align-items:center;gap:.5rem;letter-spacing:-.01em;white-space:nowrap}.toggle-button.active{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;box-shadow:0 4px 12px #6366f166,0 2px 4px #6366f133;transform:translateY(-1px)}.toggle-button:hover:not(.active){background:#fffc;color:#475569;transform:translateY(-1px);box-shadow:0 2px 8px #00000014}.positions-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem}.positions-list-compact{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.75rem}.expand-card{background:#f9fafb99;padding:1.5rem;border-radius:12px;border:2px dashed #d1d5db;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;min-height:200px;text-decoration:none;color:inherit;position:relative}.expand-card:hover{border-color:#6366f1;background:#ffffffe6;transform:translateY(-2px);box-shadow:0 4px 12px #6366f126}.expand-card:active{transform:translateY(0)}.expand-card-content{display:flex;flex-direction:row;align-items:center;justify-content:center;gap:.75rem}.expand-button-large{background:linear-gradient(135deg,#60a5fa,#3b82f6);color:#fff;border:none;border-radius:50%;width:48px;height:48px;font-size:2rem;font-weight:700;display:flex;align-items:center;justify-content:center;transition:all .2s ease;box-shadow:0 2px 4px #3b82f633}.expand-card:hover .expand-button-large{background:linear-gradient(135deg,#3b82f6,#2563eb);transform:scale(1.1);box-shadow:0 4px 8px #3b82f64d}.expand-text{color:#6b7280;font-size:1rem;font-weight:600;text-align:center}.expand-card:hover .expand-text{color:#6366f1}.expand-card .expand-button-icon{font-size:1.5rem;font-weight:700;line-height:1;color:#6b7280;display:inline-flex;align-items:center}.expand-card:hover .expand-button-icon{color:#6366f1}.position-card{background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 1px 3px #0000000d,0 2px 6px #00000014;text-decoration:none;color:inherit;display:block;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);border:1px solid #e5e7eb;position:relative;overflow:hidden}.position-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#6366f1,#8b5cf6);transform:scaleX(0);transition:transform .3s ease}.position-card:hover{box-shadow:0 4px 12px #00000014,0 8px 24px #6366f11f;transform:translateY(-4px);border-color:#c7d2fe}.position-card:hover:before{transform:scaleX(1)}.position-card:active{transform:translateY(-2px)}.position-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.25rem;padding-bottom:1rem;border-bottom:1px solid #e5e7eb;gap:1rem}.position-header-left{display:flex;flex-direction:column;gap:.5rem;flex:1}.position-header h3{font-size:1.5rem;font-weight:700;color:#111827;margin:0;line-height:1.2}.position-header-badges{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.position-header-right{display:flex;align-items:center;flex-shrink:0}.position-header-right .position-header-badges{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.currency{background:#f3f4f6;padding:.35rem .75rem;border-radius:6px;font-size:.8rem;font-weight:500;color:#6b7280;border:1px solid #e5e7eb}.currency-badge{display:inline-block;background:#f0f0f0;padding:.25rem .75rem;border-radius:4px;font-size:.85rem;font-weight:500;color:#666;white-space:nowrap}.exchange-badge{padding:.35rem .75rem;border-radius:6px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;line-height:1}.percent-chip{padding:.4rem .75rem;border-radius:6px;font-size:.875rem;font-weight:700;line-height:1;white-space:nowrap}.profit-chip{color:#059669;background:#d1fae5;border:1px solid #a7f3d0}.loss-chip{color:#dc2626;background:#fee2e2;border:1px solid #fecaca}.position-details{display:flex;flex-direction:column;gap:.75rem}.detail{display:flex;justify-content:space-between;align-items:center}.detail .label{color:#666;font-size:.9rem}.detail .value{font-weight:600;color:#333}.detail .value.profit-value{color:#10b981!important}.detail .value.loss-value{color:#ef4444!important}.profit-stack{display:flex;flex-direction:column;align-items:flex-end;gap:.15rem;text-align:right}.detail .value.secondary{font-weight:600;font-size:.9em}.detail .value.secondary.profit-value{color:#10b981!important}.detail .value.secondary.loss-value{color:#ef4444!important}.profit-stack .value.profit-value,.profit-stack .value.secondary.profit-value{color:#10b981!important}.profit-stack .value.loss-value,.profit-stack .value.secondary.loss-value{color:#ef4444!important}.fx-error{color:#ef4444;font-size:.85rem}.profit-value{color:#10b981}.loss-value{color:#ef4444}.profit-percent{color:#10b981;font-size:.9em}.loss-percent{color:#ef4444;font-size:.9em}.quick-actions{display:flex;gap:1rem;margin-top:1rem}.action-button{padding:.75rem 1.5rem;background:linear-gradient(135deg,#60a5fa,#3b82f6);color:#fff;text-decoration:none;border-radius:6px;font-weight:500;transition:all .2s;border:none}.action-button:hover{background:linear-gradient(135deg,#3b82f6,#2563eb);transform:translateY(-1px);box-shadow:0 2px 4px #3b82f64d}.empty-state{text-align:center;padding:2rem;color:#666;background:#fff;border-radius:8px}.positions-table-view{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000000d,0 2px 6px #00000014;overflow-x:auto;overflow-y:visible;-webkit-overflow-scrolling:touch;position:relative;isolation:isolate;width:100%;max-width:100%;margin:0 auto;border:1px solid #e5e7eb}@media (max-width: 768px){.positions-table-view{border-radius:8px}}.positions-table-view::-webkit-scrollbar{height:8px}.positions-table-view::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.positions-table-view::-webkit-scrollbar-thumb{background:#888;border-radius:4px}.positions-table-view::-webkit-scrollbar-thumb:hover{background:#555}.dashboard-positions-table{width:100%;border-collapse:collapse;border-spacing:0;table-layout:fixed}.dashboard-positions-thead,.dashboard-positions-header-row{background:#f8f9fa}.dashboard-positions-th{padding:.75rem .5rem;text-align:left;font-weight:600;color:#333;font-size:.9375rem;border-bottom:2px solid #e5e7eb;text-transform:none;letter-spacing:normal;background:#f8f9fa!important;white-space:nowrap;overflow:visible;text-overflow:clip}.dashboard-positions-th-sortable{-webkit-user-select:none;user-select:none;transition:background-color .2s ease}.dashboard-positions-th-sortable:hover{background-color:#e9ecef!important}.dashboard-sort-header{display:flex;align-items:center;gap:.5rem;justify-content:flex-start}.dashboard-sort-icon{display:inline-flex;align-items:center;color:#8b5cf6;font-size:.875rem}.dashboard-positions-th:nth-child(1){width:24%;padding-left:.75rem;padding-right:.5rem}.dashboard-positions-th:nth-child(2){width:8%;padding-left:.75rem;padding-right:.25rem}.dashboard-positions-th:nth-child(3){width:11%;padding-left:.25rem;padding-right:.5rem}.dashboard-positions-th:nth-child(4){width:11%;padding-left:.5rem;padding-right:.5rem}.dashboard-positions-th:nth-child(5){width:13%;padding-left:.5rem;padding-right:.5rem}.dashboard-positions-th:nth-child(6){width:7%;padding-left:.5rem;padding-right:.5rem;text-align:center!important}.dashboard-positions-th:nth-child(6) .dashboard-sort-header{justify-content:center}.dashboard-positions-th:nth-child(7){width:21%;padding-left:.5rem;padding-right:.75rem;text-align:center;overflow:visible}.dashboard-positions-th:nth-child(7) .dashboard-sort-header{justify-content:center}.dashboard-positions-tbody{background:#fff}.dashboard-positions-row{transition:background-color .2s ease;background-color:transparent;position:relative;cursor:pointer}.dashboard-positions-row:hover,.dashboard-positions-row:hover .dashboard-positions-td{background-color:#f8f9fa}.dashboard-positions-td{padding:.75rem .5rem;border-top:none;border-bottom:1px solid #e5e7eb;color:#333;vertical-align:middle;background:transparent;overflow:visible;text-overflow:clip}.dashboard-positions-td:nth-child(2){padding-left:.75rem;padding-right:.25rem}.dashboard-positions-td:nth-child(3),.dashboard-positions-td:nth-child(4),.dashboard-positions-td:nth-child(5){padding-left:.25rem;padding-right:.5rem}.dashboard-positions-td:nth-child(6){padding-left:.5rem;padding-right:.5rem}.dashboard-positions-td:nth-child(7){padding-left:.5rem;padding-right:.75rem;text-align:center;overflow:visible;word-wrap:break-word}.dashboard-positions-row:last-child .dashboard-positions-td{border-bottom:none}.dashboard-positions-row:first-child .dashboard-positions-td{border-top:none}.dashboard-positions-symbol-cell{font-weight:600;position:relative;padding-right:.5rem!important;overflow:hidden;min-width:0}.dashboard-symbol-content{display:flex;align-items:center;gap:.375rem;flex-wrap:nowrap;white-space:normal;overflow:hidden;min-width:0;max-width:100%}.dashboard-symbol-text{font-size:1rem;color:#333;font-weight:700;flex-shrink:0}.dashboard-currency-badge{display:inline-block;background:#f0f0f0;padding:.25rem .75rem;border-radius:4px;font-size:.85rem;font-weight:500;color:#666;white-space:nowrap}.dashboard-positions-td.dashboard-currency-cell{text-align:center!important}.dashboard-currency-cell .dashboard-currency-badge{display:inline-block;margin:0}.dashboard-positions-th:nth-child(6),.dashboard-positions-header-row .dashboard-positions-th:nth-child(6){text-align:center!important}.dashboard-exchange-badge{padding:.25rem .75rem;border-radius:4px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;flex-shrink:0;flex-grow:0}.dashboard-exchange-nyse{background:#f59e0b14;color:#d97706;border:1px solid rgba(245,158,11,.2)}.dashboard-exchange-nasdaq{background:#3b82f614;color:#3b82f6;border:1px solid rgba(59,130,246,.2)}.dashboard-exchange-tase{background:#8b5cf614;color:#8b5cf6;border:1px solid rgba(139,92,246,.2)}.dashboard-exchange-lse{background:#ec489914;color:#db2777;border:1px solid rgba(236,72,153,.2)}.dashboard-exchange-tse{background:#f9731614;color:#ea580c;border:1px solid rgba(249,115,22,.2)}.dashboard-exchange-hkex{background:#06b6d414;color:#0891b2;border:1px solid rgba(6,182,212,.2)}.dashboard-exchange-badge:not(.dashboard-exchange-nyse):not(.dashboard-exchange-nasdaq):not(.dashboard-exchange-tase):not(.dashboard-exchange-lse):not(.dashboard-exchange-tse):not(.dashboard-exchange-hkex){background:#64748b14;color:#64748b;border:1px solid rgba(100,116,139,.2)}.dashboard-percent-chip{padding:.2rem .55rem;border-radius:4px;font-size:.85rem;font-weight:600;white-space:nowrap;flex-shrink:0}.dashboard-profit-row .dashboard-percent-chip,.dashboard-profit-cell .dashboard-percent-chip{color:#0b9b6b!important;background:#e8f7f1!important}.dashboard-loss-row .dashboard-percent-chip,.dashboard-loss-cell .dashboard-percent-chip{color:#d23344!important;background:#fdecee!important}.dashboard-percent-chip.dashboard-profit-chip{color:#0b9b6b!important;background:#e8f7f1!important}.dashboard-percent-chip.dashboard-loss-chip{color:#d23344!important;background:#fdecee!important}.dashboard-table-value{font-weight:600;color:#333;font-size:.9375rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}.dashboard-table-value-empty{color:#999;font-style:italic;font-size:.9375rem}.dashboard-value-cell{font-weight:600;color:#333}.dashboard-profit-cell{color:#10b981}.dashboard-loss-cell{color:#ef4444}.dashboard-profit-loss-cell{display:flex;flex-direction:column;gap:.15rem;align-items:center;text-align:center;min-width:0;word-wrap:break-word;max-width:100%;width:100%;box-sizing:border-box}.dashboard-profit-loss-primary{font-weight:600;font-size:.9375rem;line-height:1.4;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;width:100%;box-sizing:border-box}.dashboard-profit-loss-secondary{font-size:.9em;font-weight:600;line-height:1.4;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;width:100%;box-sizing:border-box}.dashboard-price-change{display:inline-block}.dashboard-profit-value{color:#10b981!important}.dashboard-loss-value{color:#ef4444!important}.dashboard-fx-error{color:#ef4444;font-size:.85rem;margin-top:.25rem}.dashboard-expand-row{text-align:center;padding:1.5rem!important}.dashboard-expand-button-table{background:transparent;border:2px dashed #ddd;border-radius:8px;padding:1rem 2rem;cursor:pointer;display:inline-flex;align-items:center;gap:.75rem;color:#666;font-weight:500;transition:all .2s ease;font-family:inherit}.dashboard-expand-button-table:hover{border-color:#3b82f6;color:#3b82f6;background:#3b82f61a}.dashboard-expand-button-icon{font-size:1.5rem;font-weight:700;line-height:1;display:inline-flex;align-items:center}@media (max-width: 768px){.dashboard{padding:1rem}.dashboard-content{gap:1.5rem}.portfolio-summary-modern{grid-template-columns:1fr}.section-title-nav-style{font-size:1.125rem;flex-wrap:nowrap}.section-title-nav-style span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.section-title-icon{width:20px;height:20px;flex-shrink:0}.chart-section,.positions-section{padding:1rem;overflow:hidden}.chart-header{gap:1rem;margin-bottom:1.5rem}.chart-title-nav-style{max-width:50%}.chart-title-nav-style span{font-size:1.125rem}.chart-toggle{padding:.25rem;gap:.25rem;max-width:100%}.toggle-button{padding:.5rem .75rem;font-size:.75rem}.toggle-button span{display:none}.toggle-button svg{margin:0}.dashboard-table-container{overflow-x:auto;-webkit-overflow-scrolling:touch}.dashboard-positions-table{font-size:.875rem;min-width:700px}.dashboard-positions-th,.dashboard-positions-td{padding:.75rem .5rem;white-space:nowrap}.dashboard-positions-th:nth-child(1){min-width:150px}.dashboard-positions-th:nth-child(2),.dashboard-positions-th:nth-child(3),.dashboard-positions-th:nth-child(4){min-width:80px}.dashboard-positions-th:nth-child(5){min-width:100px}.dashboard-positions-th:nth-child(6){min-width:70px}.dashboard-positions-th:nth-child(7){min-width:140px}.dashboard-positions-symbol-cell{min-width:150px;max-width:150px;overflow:hidden;text-overflow:ellipsis}.value-card{padding:.875rem 1rem}.card-value{font-size:1.75rem}.card-value-amount{font-size:1.5rem}.view-toggle{order:-1;width:100%;justify-content:center;margin-bottom:.5rem}}@media (max-width: 480px){.dashboard{padding:.75rem}.portfolio-cards-container{padding:1rem;border-radius:12px}.value-card{padding:.75rem .875rem}.card-value{font-size:1.5rem}.card-value-amount{font-size:1.25rem}.section-title-nav-style{font-size:1rem}.section-title-icon{width:18px;height:18px}.chart-title-nav-style{max-width:40%}.chart-title-nav-style span{font-size:1rem}.dashboard-positions-table{font-size:.8125rem;min-width:650px}.dashboard-positions-th,.dashboard-positions-td{padding:.625rem .375rem;font-size:.75rem}.dashboard-positions-th:nth-child(1){min-width:130px}.dashboard-positions-th:nth-child(2),.dashboard-positions-th:nth-child(3),.dashboard-positions-th:nth-child(4),.dashboard-positions-th:nth-child(6){min-width:70px}.dashboard-positions-th:nth-child(5){min-width:90px}.dashboard-positions-th:nth-child(7){min-width:120px}.dashboard-positions-symbol-cell{min-width:130px;max-width:130px}.card-title{flex-wrap:wrap}.card-title-content{max-width:100%}.toggle-button{padding:.4rem .5rem;font-size:.7rem}.chart-toggle{padding:.2rem}}.position-card-compact{padding:.875rem;border-radius:8px;min-height:auto}.position-header-compact{margin-bottom:.75rem;padding-bottom:.5rem;gap:.4rem!important;flex-wrap:wrap;align-items:center}.position-header-compact .position-header-left{flex:0 1 auto;min-width:0;max-width:60%}.position-header-compact .position-header-right{flex-shrink:0;flex:0 0 auto}.position-header-compact .position-header-badges{gap:.3rem!important;flex-wrap:nowrap;display:flex;align-items:center}.position-symbol-compact{font-size:.9rem!important;font-weight:700;color:#111827;margin:0;line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}.position-details-compact,.detail-compact{gap:.5rem}.label-compact{color:#666;font-size:.75rem!important;font-weight:500}.value-compact{font-weight:600;color:#333;font-size:.8rem!important}.percent-chip-compact{padding:.15rem .4rem!important;border-radius:4px!important;font-size:.65rem!important;font-weight:700;line-height:1;white-space:nowrap;flex-shrink:0}.exchange-badge-compact{padding:.15rem .4rem!important;border-radius:4px!important;font-size:.6rem!important;font-weight:600;text-transform:uppercase;letter-spacing:.2px;line-height:1;white-space:nowrap;flex-shrink:0}.expand-card-compact{padding:1rem!important;min-height:auto!important}.expand-card-compact .expand-text{font-size:.875rem}@media (max-width: 768px){.positions-list-compact{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:.5rem}.position-card-compact{padding:.75rem}.position-symbol-compact{font-size:.85rem!important}.percent-chip-compact{font-size:.6rem!important;padding:.1rem .35rem!important}.exchange-badge-compact{font-size:.55rem!important;padding:.1rem .35rem!important}.label-compact{font-size:.7rem!important}.value-compact{font-size:.75rem!important}}.heatmap-container{width:100%;height:100%;min-height:500px;display:flex;flex-direction:column;gap:.75rem;padding:0;flex:1}.heatmap-grid{display:flex;flex-wrap:wrap;gap:.5rem;padding:.5rem;overflow-y:auto;flex:1;justify-content:flex-start;align-items:flex-start;align-content:flex-start;min-height:0}.heatmap-cell{display:flex;flex-direction:column;justify-content:center;align-items:center;padding:.5rem;border-radius:6px;text-decoration:none;color:#1e293b;transition:all .15s ease;box-shadow:0 1px 3px #0000001f,0 1px 2px #00000014;border:1px solid rgba(0,0,0,.08);position:relative;overflow:hidden;cursor:pointer;aspect-ratio:1}.heatmap-cell:hover{transform:scale(1.05);box-shadow:0 4px 12px #0003,0 2px 4px #00000026;z-index:10;border-color:#00000026}.heatmap-cell-content{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.25rem;width:100%;height:100%;z-index:1}.heatmap-symbol{font-weight:700;font-size:.875rem;color:#1e293b;text-align:center;line-height:1.2;white-space:nowrap;text-shadow:0 1px 2px rgba(255,255,255,.8)}.heatmap-profit-loss{font-size:.7rem;font-weight:700;padding:.15rem .35rem;border-radius:3px;text-align:center;white-space:nowrap;background-color:#ffffffe6;box-shadow:0 1px 2px #0000001a}.heatmap-profit-loss.profit{color:#059669}.heatmap-profit-loss.loss{color:#dc2626}.heatmap-value{font-size:.65rem;font-weight:600;color:#64748b;text-align:center;white-space:nowrap;text-shadow:0 1px 2px rgba(255,255,255,.8)}.heatmap-legend{display:flex;justify-content:center;align-items:center;gap:.75rem;padding:.75rem 1rem;background:#f8fafc;border-radius:8px;border:1px solid #E2E8F0;flex-wrap:wrap;flex-shrink:0}.heatmap-legend-label{font-size:.75rem;font-weight:600;color:#475569;margin-right:.5rem}.heatmap-legend-item{display:flex;align-items:center;gap:.4rem;font-size:.7rem;color:#64748b;font-weight:600}.heatmap-legend-color{width:20px;height:20px;border-radius:3px;border:1px solid rgba(0,0,0,.1);box-shadow:0 1px 2px #0000001a;flex-shrink:0}@media (max-width: 768px){.heatmap-container{min-height:400px;padding:.25rem}.heatmap-grid{gap:.4rem;padding:.25rem}.heatmap-cell{padding:.4rem;min-width:60px;min-height:60px}.heatmap-symbol{font-size:.75rem}.heatmap-profit-loss{font-size:.65rem;padding:.1rem .3rem}.heatmap-value{font-size:.6rem}.heatmap-legend{flex-direction:column;gap:.5rem;padding:.5rem}.heatmap-legend-label{margin-right:0;margin-bottom:.25rem}}@keyframes loss-glow-pulse{0%,to{box-shadow:0 0 #ef444400,0 8px 30px #ef444426,0 1px 3px #0000000d}50%{box-shadow:0 0 0 4px #ef44441f,0 8px 36px #ef444447,0 1px 3px #0000000d}}.loss-harvest-section{background:linear-gradient(135deg,#fff5f5fa,#ffededf2);border:1.5px solid rgba(239,68,68,.35);border-radius:20px;padding:1.25rem 1.75rem;position:relative;overflow:hidden;box-shadow:0 8px 30px #0000000f,0 1px 3px #0000000a;transition:box-shadow .3s ease,border-color .3s ease}.loss-harvest-section:hover{animation:loss-glow-pulse 3s ease-in-out infinite;border-color:#ef44448c}.loss-harvest-section:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#ef4444,#f97316,#ef4444);background-size:200% 100%;animation:shimmer-gradient 3s linear infinite}@keyframes shimmer-gradient{0%{background-position:200% 0}to{background-position:-200% 0}}.loss-harvest-header{display:flex;justify-content:space-between;align-items:flex-start;gap:.875rem;margin-bottom:1.1rem;flex-wrap:wrap}.loss-harvest-title-group{display:flex;align-items:center;gap:.875rem}.loss-harvest-icon-wrapper{display:flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:10px;background:linear-gradient(135deg,#ef4444,#dc2626);box-shadow:0 4px 12px #ef444466;flex-shrink:0}.loss-harvest-icon{color:#fff;font-size:1.125rem}.loss-harvest-title-text{display:flex;flex-direction:column;gap:.25rem}.loss-harvest-title{font-size:1.125rem;font-weight:700;color:#991b1b;letter-spacing:-.01em;line-height:1.3}.loss-harvest-subtitle{font-size:.75rem;color:#b45309;font-weight:500;line-height:1.4;max-width:480px}.loss-harvest-total{display:flex;flex-direction:column;align-items:flex-end;gap:.25rem;flex-shrink:0}.loss-harvest-total-label{font-size:.75rem;font-weight:600;color:#9ca3af;text-transform:uppercase;letter-spacing:.5px}.loss-harvest-total-value{display:flex;flex-direction:column;align-items:flex-end;gap:.1rem}.loss-harvest-total-usd{font-size:1.2rem;font-weight:800;color:#dc2626;letter-spacing:-.5px;line-height:1.2}.loss-harvest-total-ils{font-size:.8125rem;font-weight:600;color:#ef4444;opacity:.8}.loss-harvest-scroll{display:flex;gap:.875rem;overflow-x:auto;padding-bottom:.5rem;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch}.loss-harvest-scroll::-webkit-scrollbar{height:5px}.loss-harvest-scroll::-webkit-scrollbar-track{background:#ef444414;border-radius:99px}.loss-harvest-scroll::-webkit-scrollbar-thumb{background:#ef444459;border-radius:99px}.loss-harvest-card{flex:0 0 auto;width:160px;background:#fff;border-radius:12px;padding:.75rem .875rem;text-decoration:none;color:inherit;border:1.5px solid rgba(239,68,68,.2);box-shadow:0 2px 8px #ef444414;transition:all .25s cubic-bezier(.4,0,.2,1);scroll-snap-align:start;display:flex;flex-direction:column;gap:.5rem;position:relative;overflow:hidden}.loss-harvest-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#ef4444,#f97316);transform:scaleX(0);transform-origin:left;transition:transform .3s ease}.loss-harvest-card-even:before{background:linear-gradient(90deg,#f59e0b,#fbbf24)}.loss-harvest-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #ef444433;border-color:#ef444473}.loss-harvest-card:hover:before{transform:scaleX(1)}.loss-harvest-card-even{border-color:#f59e0b40;box-shadow:0 2px 8px #f59e0b14}.loss-harvest-card-even:hover{box-shadow:0 8px 24px #f59e0b33;border-color:#f59e0b80}.loss-harvest-card-top{display:flex;align-items:center;justify-content:space-between;gap:.375rem}.loss-harvest-card-symbol{font-size:1.0625rem;font-weight:800;color:#111827;letter-spacing:-.01em;line-height:1}.loss-harvest-exchange{padding:.2rem .5rem;border-radius:5px;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;flex-shrink:0}.loss-harvest-pct{font-size:1.375rem;font-weight:800;letter-spacing:-.5px;line-height:1}.loss-harvest-pct-loss{color:#dc2626}.loss-harvest-pct-even{color:#d97706}.loss-harvest-card-bottom{display:flex;flex-direction:column;gap:.25rem;padding-top:.4rem;border-top:1px solid rgba(239,68,68,.12)}.loss-harvest-card-even .loss-harvest-card-bottom{border-top-color:#f59e0b26}.loss-harvest-pl-row{display:flex;justify-content:space-between;align-items:center;gap:.25rem}.loss-harvest-pl-label{font-size:.725rem;font-weight:600;color:#9ca3af;text-transform:uppercase;letter-spacing:.4px}.loss-harvest-pl-val{font-size:.8125rem;font-weight:700}.loss-harvest-pl-val-neutral{font-size:.8125rem;font-weight:600;color:#4b5563}@media (max-width: 768px){.loss-harvest-section{padding:1rem .875rem;border-radius:16px}.loss-harvest-header{flex-direction:column;gap:.75rem;margin-bottom:.875rem}.loss-harvest-total{align-items:flex-start}.loss-harvest-card{width:142px;padding:.65rem .75rem}.loss-harvest-pct{font-size:1.2rem}}.transactions{padding:2rem;max-width:100%;margin:0 auto;box-sizing:border-box;background:linear-gradient(to bottom,#f9fafb,#fff);min-height:100vh;overflow-x:hidden}.transactions-header{margin-bottom:2rem}.page-title-nav-style{display:inline-flex;align-items:center;gap:.625rem;margin:0;padding:0}.page-title-nav-style .nav-icon{font-size:1.375rem;color:#8b5cf6;flex-shrink:0}.page-title-nav-style span{color:#1f2937;font-weight:600;font-size:1.25rem;letter-spacing:-.01em;line-height:1.4}.search-input{width:100%;max-width:100%;padding:.75rem 1rem;font-size:.9375rem;border:2px solid #e5e7eb;border-radius:8px;transition:all .2s ease;font-family:inherit;box-sizing:border-box;background:#f9fafb}.transactions-table{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000000d,0 4px 12px #00000014;overflow-x:auto;overflow-y:visible;-webkit-overflow-scrolling:touch;border:1px solid #e5e7eb;width:100%;max-width:100%}@media (max-width: 768px){.transactions-table{border-radius:8px}}.transactions-table::-webkit-scrollbar{height:12px}.transactions-table::-webkit-scrollbar-track{background:#6366f114;border-radius:6px;margin:0 10px}.transactions-table::-webkit-scrollbar-thumb{background:linear-gradient(135deg,#6366f180,#8b5cf680);border-radius:6px;border:2px solid rgba(255,255,255,.5)}.transactions-table::-webkit-scrollbar-thumb:hover{background:linear-gradient(135deg,#6366f1cc,#8b5cf6cc);border-color:#fffc}.transactions-table table{width:100%;min-width:1200px;border-collapse:collapse;display:table;table-layout:auto}th{padding:.875rem 1rem;font-weight:600;color:#333;border-bottom:2px solid #dee2e6;background:#f8f9fa!important;font-size:.875rem;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;vertical-align:middle;text-align:left}.transactions-table th:nth-child(1),.transactions-table td:nth-child(1){min-width:130px;width:auto;text-align:left;padding-left:1rem;padding-right:.75rem}.transactions-table th:nth-child(2),.transactions-table td:nth-child(2){min-width:100px;width:auto;text-align:center;padding-left:.75rem;padding-right:.75rem}.transactions-table th:nth-child(3),.transactions-table td:nth-child(3){min-width:90px;width:auto;text-align:center;padding-left:.75rem;padding-right:.75rem}.transactions-table th:nth-child(4),.transactions-table td:nth-child(4){min-width:90px;width:auto;text-align:right;padding-left:.75rem;padding-right:.75rem}.transactions-table th:nth-child(5),.transactions-table td:nth-child(5){min-width:120px;width:auto;text-align:right;padding-left:.75rem;padding-right:.75rem}.transactions-table th:nth-child(6),.transactions-table td:nth-child(6){min-width:130px;width:auto;text-align:right;padding-left:.75rem;padding-right:.75rem}.transactions-table th:nth-child(7),.transactions-table td:nth-child(7){min-width:120px;width:auto;text-align:center;padding-left:.75rem;padding-right:.75rem}.transactions-table th:nth-child(8),.transactions-table td:nth-child(8){min-width:180px;width:auto;text-align:left;padding-left:.75rem;padding-right:1rem}.transactions-table tbody tr{background:#fff;border-bottom:none!important;transition:background-color .15s ease}.transactions-table tbody tr:last-child{border-bottom:none!important}.transactions-table tbody td{border-bottom:none!important}tbody tr:hover td{background:#f8f9fa!important}td{padding:.875rem 1rem;color:#495057;vertical-align:middle;background:inherit;font-size:.9375rem;line-height:1.5;overflow:hidden;word-wrap:break-word}.date-cell,.transactions-table td:nth-child(1){white-space:nowrap!important;overflow:hidden;text-overflow:ellipsis;text-align:left}.symbol-cell{font-weight:700;color:#000;font-size:.9375rem;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.unknown-stock{color:#999;font-style:italic;font-weight:400}.type-badge{display:inline-block;padding:.3rem .65rem;border-radius:6px;border:1px solid;cursor:default;-webkit-user-select:none;user-select:none;font-size:.75rem;font-weight:600;text-transform:uppercase;white-space:nowrap;letter-spacing:.3px;margin:0 auto}td:nth-child(3){text-align:center}.type-badge.type-buy{background:#10b9811a;color:#059669;border-color:#10b9814d}.type-badge.type-sell{background:#ef44441a;color:#dc2626;border-color:#ef44444d}.type-badge.type-fee{background:#f59e0b1a;color:#d97706;border-color:#f59e0b4d}.type-badge.type-deposit{background:#3b82f61a;color:#2563eb;border-color:#3b82f64d}.type-badge.type-withdrawal{background:#8b5cf61a;color:#7c3aed;border-color:#8b5cf64d}.quantity-cell,.price-cell,.value-cell{font-weight:600;color:#212529;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-align:right}td:nth-child(4),td:nth-child(5),td:nth-child(6){text-align:right;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.note-cell{min-width:250px;white-space:nowrap;font-size:.875rem;color:#6c757d;padding:.875rem 1rem;line-height:1.5;overflow:visible}.action-buttons{display:flex;gap:.5rem;align-items:center;justify-content:center;flex-wrap:nowrap;max-width:100%;overflow:visible;box-sizing:border-box}.action-buttons>*{flex-shrink:0}.view-link{color:#1e40af;text-decoration:none;font-weight:500;display:inline-flex;align-items:center;justify-content:center;gap:.375rem;padding:.375rem .75rem;border-radius:4px;transition:all .2s;font-size:.875rem;white-space:nowrap;flex-shrink:0;background-color:#dbeafe;border:1px solid #93c5fd}.btn{padding:.5rem .875rem;border:none;border-radius:4px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;-webkit-transition:all .2s;font-family:inherit;box-sizing:border-box;white-space:nowrap;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;gap:.375rem;line-height:1.5;-webkit-appearance:none;-moz-appearance:none;appearance:none}.btn-export{background:linear-gradient(135deg,#34d399,#10b981);color:#fff;border:none;font-weight:600;box-shadow:0 2px 8px #10b98140;padding:.625rem 1.25rem;font-size:.9375rem}.btn-export:hover:not(:disabled){background:linear-gradient(135deg,#10b981,#059669);transform:translateY(-2px);-webkit-transform:translateY(-2px);box-shadow:0 4px 12px #10b98166}.btn-export:active:not(:disabled){transform:translateY(0);-webkit-transform:translateY(0);box-shadow:0 2px 6px #10b9814d}@media (max-width: 768px){.btn-export:hover:not(:disabled){transform:none;-webkit-transform:none}}.btn-edit{background-color:#fef3c7;color:#92400e;border:1px solid #fde68a;padding:.5rem .875rem;font-size:.875rem}.btn-delete{background-color:#fee2e2;color:#991b1b;border:1px solid #fecaca;padding:.5rem .875rem;font-size:.875rem}.action-buttons .btn{white-space:nowrap;flex-shrink:0;min-width:fit-content}.modal-content{background:#fff;border-radius:16px;box-shadow:0 8px 32px #0000001f,0 2px 8px #00000014;width:100%;max-width:500px;border:1px solid rgba(226,232,240,.8);animation:slideUp .3s cubic-bezier(.4,0,.2,1)}@keyframes slideUp{0%{transform:translateY(20px);-webkit-transform:translateY(20px);opacity:0}to{transform:translateY(0);-webkit-transform:translateY(0);opacity:1}}@-webkit-keyframes slideUp{0%{-webkit-transform:translateY(20px);opacity:0}to{-webkit-transform:translateY(0);opacity:1}}max-height: 90vh; overflow-y: auto; box-sizing: border-box; display: flex; flex-direction: column; } .modal-confirm{max-width:400px}.modal-close{background:none;border:none;font-size:1.75rem;color:#666;cursor:pointer;padding:0;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;line-height:1;transition:all .2s;border-radius:4px}.transaction-form{padding:1.5rem}.form-group input,.form-group textarea,.form-group select{width:100%;padding:.75rem;font-size:1rem;border:2px solid #dee2e6;border-radius:6px;transition:border-color .2s,box-shadow .2s;font-family:inherit;box-sizing:border-box;background-color:#fff}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-group input:disabled,.form-group textarea:disabled,.form-group select:disabled{background-color:#f8f9fa;cursor:not-allowed;opacity:.7}.form-group textarea{resize:vertical;min-height:80px;font-family:inherit}.transaction-form .form-actions{margin-top:1.5rem;padding-top:1.5rem;padding-left:0;padding-right:0;padding-bottom:0;border-top:1px solid #dee2e6}.stock-list{padding:2rem;max-width:100%;margin:0 auto;box-sizing:border-box;background:linear-gradient(to bottom,#f9fafb,#fff);min-height:100vh;overflow-x:hidden}.stock-list-header{margin-bottom:2rem}.stock-list-header h1{margin:0;color:#8b5cf6;font-size:2rem;font-weight:700;letter-spacing:-.5px}.toolbar{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.75rem;padding:1.25rem 1.5rem;background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000000d,0 4px 12px #00000014;border:1px solid #e5e7eb;flex-wrap:wrap}.toolbar-left{flex:1;min-width:250px}.toolbar-right{display:flex;gap:.875rem;align-items:center;flex-wrap:wrap}.empty-toolbar{display:flex;justify-content:center;margin-bottom:1.75rem;padding:1.25rem 1.5rem;background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000000d,0 4px 12px #00000014;border:1px solid #e5e7eb}.search-input{width:100%;max-width:100%;padding:.75rem 1rem;font-size:.9375rem;border:2px solid #e5e7eb;border-radius:8px;transition:all .2s ease;-webkit-transition:all .2s ease;font-family:inherit;box-sizing:border-box;background:#f9fafb;-webkit-appearance:none;-moz-appearance:none;appearance:none}.search-input:focus{outline:none;border-color:#3b82f6;background:#fff;box-shadow:0 0 0 3px #3b82f61a}.search-input::placeholder{color:#9ca3af;font-weight:400}.stocks-table{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000000d,0 4px 12px #00000014;overflow:hidden;overflow-x:auto;border:1px solid #e5e7eb;-webkit-overflow-scrolling:touch}@media (max-width: 768px){.stocks-table{border-radius:8px}}table{width:100%;border-collapse:collapse;min-width:950px;table-layout:auto}thead{background:#f8f9fa;position:sticky;top:0;z-index:10}thead tr{background:#f8f9fa}th{padding:.875rem 1rem;text-align:left;font-weight:600;color:#333;border-bottom:2px solid #dee2e6;background:#f8f9fa!important;font-size:.875rem;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}th:nth-child(1),td:nth-child(1){min-width:100px;width:auto}th:nth-child(2),td:nth-child(2){min-width:200px;width:auto}th:nth-child(3),td:nth-child(3){min-width:90px;width:auto;text-align:center}th:nth-child(4),td:nth-child(4){min-width:90px;width:auto;text-align:center}th:nth-child(5),td:nth-child(5){min-width:140px;width:auto;text-align:center}th:nth-child(6),td:nth-child(6){min-width:150px;width:auto}th:nth-child(5),th:nth-child(6){text-align:center}.exchange-cell{text-align:center}.exchange-badge{padding:.2rem .6rem;border-radius:4px;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.3px;white-space:nowrap;display:inline-block;cursor:default;-webkit-user-select:none;user-select:none}.currency-cell{text-align:center}.currency-badge{padding:.2rem .6rem;border-radius:4px;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.3px;white-space:nowrap;display:inline-block;background:#64748b14;color:#64748b;border:1px solid rgba(100,116,139,.2);cursor:default;-webkit-user-select:none;user-select:none}.price-symbol-cell{text-align:center}.price-symbol-tag{display:inline-block;padding:.2rem .6rem;background:#6366f114;color:#6366f1;border:1px solid rgba(99,102,241,.2);border-radius:4px;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.3px;white-space:nowrap;max-width:100%;cursor:default;-webkit-user-select:none;user-select:none}.price-symbol-empty{color:#999;font-style:italic}tbody{background:#fff}tbody tr{background:#fff;border-bottom:1px solid #e9ecef;transition:background-color .15s ease}tbody tr:last-child{border-bottom:none}tbody tr:hover{background:#f8f9fa}td{padding:.875rem 1rem;color:#495057;vertical-align:middle;background:inherit;font-size:.9375rem;line-height:1.5}tbody td{background:inherit}.symbol-cell{font-weight:700;color:#000;font-size:.9375rem}.symbol-cell strong{font-weight:700;color:#000}.action-buttons{display:flex;gap:.5rem;align-items:center;justify-content:center;flex-wrap:nowrap}.view-link{color:#1e40af;text-decoration:none;font-weight:500;display:inline-flex;align-items:center;justify-content:center;padding:.375rem .75rem;border-radius:4px;transition:all .2s;font-size:.875rem;white-space:nowrap;background-color:#dbeafe;border:1px solid #93c5fd;gap:.375rem}.view-link:hover{background-color:#93c5fd;color:#1e3a8a;text-decoration:none}.btn{padding:.5rem .875rem;border:none;border-radius:4px;font-size:.875rem;font-weight:500;transition:all .2s ease;-webkit-transition:all .2s ease;-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;transition:all .2s;font-family:inherit;box-sizing:border-box;white-space:nowrap;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;gap:.375rem;line-height:1.5}.action-buttons .btn,.action-buttons .view-link{padding:.5rem;font-size:1rem;width:36px;height:36px;gap:0;border-radius:6px}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,#60a5fa,#3b82f6);color:#fff;border:none;font-weight:600;box-shadow:0 2px 8px #3b82f640;padding:.625rem 1.25rem;font-size:.9375rem}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#3b82f6,#2563eb);transform:translateY(-2px);-webkit-transform:translateY(-2px);box-shadow:0 4px 12px #3b82f666}.btn-primary:active:not(:disabled){transform:translateY(0);-webkit-transform:translateY(0);box-shadow:0 2px 6px #3b82f64d}@media (max-width: 768px){.btn-primary:hover:not(:disabled){transform:none;-webkit-transform:none}}.btn-secondary{background-color:#6c757d;color:#fff}.btn-secondary:hover:not(:disabled){background-color:#545b62}.btn-edit{background-color:#fef3c7;color:#92400e;border:1px solid #fde68a}.btn-edit:hover:not(:disabled){background-color:#fde68a;color:#78350f;transform:translateY(-1px);-webkit-transform:translateY(-1px);box-shadow:0 2px 4px #fbbf2433}@media (max-width: 768px){.btn-edit:hover:not(:disabled){transform:none;-webkit-transform:none}}.btn-delete{background-color:#fee2e2;color:#991b1b;border:1px solid #fecaca}.btn-delete:hover:not(:disabled){background-color:#fecaca;color:#7f1d1d;transform:translateY(-1px);-webkit-transform:translateY(-1px);box-shadow:0 2px 4px #ef444433}@media (max-width: 768px){.btn-delete:hover:not(:disabled){transform:none;-webkit-transform:none}}.action-buttons .btn{white-space:nowrap;flex-shrink:0}.loading,.error{text-align:center;padding:3rem;font-size:1.1rem}.error{color:#d32f2f}.empty-state{text-align:center;padding:4rem 2rem;background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000000d,0 4px 12px #00000014;border:1px solid #e5e7eb}.empty-state p{color:#6b7280;margin:0;font-size:1.125rem}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#0f172a99;display:flex;justify-content:center;align-items:center;z-index:1000;padding:1rem;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);animation:fadeIn .2s ease}.modal-content{background:#fff;border-radius:16px;box-shadow:0 8px 32px #0000001f,0 2px 8px #00000014;width:100%;max-width:500px;max-height:90vh;overflow-y:auto;box-sizing:border-box;display:flex;flex-direction:column;border:1px solid rgba(226,232,240,.8);animation:slideUp .3s cubic-bezier(.4,0,.2,1)}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-confirm{max-width:400px}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #dee2e6}.modal-header h2{margin:0;color:#8b5cf6;font-size:1.5rem;font-weight:600}.modal-close{background:none;border:none;font-size:1.75rem;color:#666;cursor:pointer;padding:0;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;line-height:1;transition:color .2s;border-radius:4px}.modal-close:hover{color:#333;background-color:#f8f9fa}.modal-body{padding:1.5rem;flex:1}.modal-body p{margin:0;color:#666;line-height:1.6}.stock-form{padding:1.5rem}.form-group{margin-bottom:1.25rem}.form-group:last-of-type{margin-bottom:0}.form-group label{display:block;margin-bottom:.5rem;color:#333;font-weight:500;font-size:.9rem}.form-group input,.form-group select{width:100%;padding:.75rem;font-size:1rem;border:2px solid #dee2e6;border-radius:6px;transition:border-color .2s,box-shadow .2s;font-family:inherit;box-sizing:border-box;background-color:#fff}.form-group input:focus,.form-group select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-group input:disabled,.form-group select:disabled{background-color:#f8f9fa;cursor:not-allowed;opacity:.7}.form-group select{cursor:pointer}.form-error{background-color:#f8d7da;color:#721c24;padding:.75rem;border-radius:6px;margin-bottom:1rem;border:1px solid #f5c6cb;font-size:.9rem}.form-actions{display:flex;justify-content:flex-end;gap:.75rem;padding:1.5rem;border-top:1px solid #dee2e6;box-sizing:border-box;flex-shrink:0;margin-top:1rem}.stock-form .form-actions{margin-top:1.5rem;padding-top:1.5rem;padding-left:0;padding-right:0;padding-bottom:0;border-top:1px solid #dee2e6}@media (max-width: 768px){.toolbar{flex-direction:column;align-items:stretch}.toolbar-left{min-width:100%}.toolbar-right{width:100%;justify-content:stretch}.toolbar-right .btn{flex:1}}.transaction-timeline{background:#fff;border-radius:16px;padding:1.5rem;box-shadow:0 4px 6px #0000000d;margin-bottom:2rem}.chart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.transaction-timeline h3{margin:0;font-size:1.5rem;font-weight:700;background:linear-gradient(135deg,#6366f1,#8b5cf6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.volume-toggle{display:flex;align-items:center;gap:.5rem;cursor:pointer;-webkit-user-select:none;user-select:none;font-size:.875rem;color:#4b5563;font-weight:500;padding:.5rem .75rem;border-radius:8px;transition:background-color .2s ease}.volume-toggle:hover{background-color:#6366f10d}.volume-toggle input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:#6366f1}.volume-toggle span{cursor:pointer}.chart-container{width:100%;height:400px;margin-bottom:1rem;overflow:hidden;position:relative}.transaction-timeline-empty{padding:2rem;text-align:center;color:#6b7280;font-style:italic}.custom-tooltip{background:#fffffffa;border:2px solid #6366f1;border-radius:12px;padding:.75rem 1rem;box-shadow:0 8px 16px #6366f126;min-width:150px}.tooltip-date{font-weight:700;color:#1e293b;margin:0 0 .5rem;font-size:.875rem;border-bottom:1px solid #e5e7eb;padding-bottom:.5rem}.tooltip-type{display:inline-block;padding:.25rem .75rem;border-radius:6px;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem}.tooltip-type.buy{background:linear-gradient(135deg,#10b98126,#05966926);color:#059669;border:1px solid rgba(16,185,129,.3)}.tooltip-type.sell{background:linear-gradient(135deg,#ef444426,#dc262626);color:#dc2626;border:1px solid rgba(239,68,68,.3)}.tooltip-label{font-weight:600;color:#8b5cf6;margin:0 0 .25rem;font-size:.875rem}.tooltip-price{font-size:1.25rem;font-weight:700;color:#1e293b;margin:.25rem 0}.tooltip-price .currency-code{font-size:.875rem;font-weight:600;color:#6b7280;margin-left:.25rem}.tooltip-quantity{font-size:.875rem;color:#6b7280;margin:.25rem 0}.tooltip-note{font-size:.8rem;color:#9ca3af;margin:.5rem 0 0;padding-top:.5rem;border-top:1px solid #e5e7eb;font-style:italic}.chart-legend-custom{display:flex;justify-content:center;gap:2rem;padding:1rem;background:linear-gradient(135deg,#f8fafccc,#f1f5f9cc);border-radius:12px;margin-top:1rem}.legend-item{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:#4b5563;font-weight:500}.legend-dot{width:12px;height:12px;border-radius:50%;border:2px solid #fff;box-shadow:0 2px 4px #0000001a}.legend-dot.buy{background:#10b981}.legend-dot.sell{background:#ef4444}.legend-dot.current{background:#8b5cf6}.transaction-dot,.current-price-dot{transition:r .2s ease;cursor:pointer}.transaction-dot:hover,.current-price-dot:hover{r:7}.ghost-quantity-bar{pointer-events:none;transition:opacity .2s ease}@media (max-width: 768px){.transaction-timeline{padding:1rem}.chart-header{flex-direction:column;align-items:flex-start}.transaction-timeline h3{font-size:1.25rem}.chart-container{height:300px}.chart-legend-custom{flex-direction:column;gap:.75rem;align-items:flex-start}.custom-tooltip{font-size:.85rem;padding:.5rem .75rem}}.stock-detail{padding:2rem;max-width:1400px;margin:0 auto;min-height:100vh;background:linear-gradient(135deg,#f8f9fc,#e9ecf5);overflow-x:hidden}.stock-detail-nav{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;gap:1rem;flex-wrap:wrap}.back-link{display:inline-flex;align-items:center;gap:.75rem;color:#6366f1;text-decoration:none;font-weight:600;font-size:.95rem;padding:.75rem 1.25rem;background:#ffffffe6;border-radius:12px;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(99,102,241,.2);transition:all .3s ease;-webkit-transition:all .3s ease;box-shadow:0 2px 8px #6366f11a;cursor:pointer}.back-link:hover{background:#fff;transform:translate(-4px);-webkit-transform:translateX(-4px);box-shadow:0 4px 12px #6366f133;border-color:#6366f14d}@media (max-width: 768px){.back-link:hover{transform:none;-webkit-transform:none}}.stock-navigation{display:flex;align-items:center;gap:.75rem;background:#ffffffe6;padding:.5rem .75rem;border-radius:12px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(99,102,241,.2);box-shadow:0 2px 8px #6366f11a}.nav-arrow-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:transparent;border:none;border-radius:8px;color:#6366f1;font-weight:600;font-size:.9rem;cursor:pointer;transition:all .2s ease}.nav-arrow-btn:hover:not(:disabled){background:#6366f11a;transform:scale(1.05);-webkit-transform:scale(1.05)}@media (max-width: 768px){.nav-arrow-btn:hover:not(:disabled){transform:none;-webkit-transform:none}}.nav-arrow-btn:disabled{opacity:.3;cursor:not-allowed}.nav-arrow-btn svg{font-size:1.25rem}.nav-stock-label{font-size:.875rem;font-weight:700;color:#8b5cf6}.nav-position{padding:.25rem .75rem;background:#6366f11a;border-radius:6px;font-size:.875rem;font-weight:600;color:#6366f1;min-width:60px;text-align:center}.stock-hero{background:linear-gradient(135deg,#fffffff2,#f8fafcf2);padding:1rem 1.5rem;border-radius:16px;box-shadow:0 8px 30px #00000014,0 1px 3px #0000000d;margin-bottom:1rem;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.8);position:relative;overflow:hidden;transition:all .3s ease}.stock-hero:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#6366f1,#8b5cf6,#ec4899)}.stock-hero:hover{box-shadow:0 12px 40px #0000001f,0 2px 6px #0000000f;transform:translateY(-2px);-webkit-transform:translateY(-2px)}@media (max-width: 768px){.stock-hero:hover{transform:none;-webkit-transform:none}}.hero-title{display:flex;align-items:center;justify-content:space-between;gap:2rem;flex-wrap:wrap}.title-row{display:flex;align-items:center;gap:1rem;flex:1;min-width:0}.badges-group{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap;flex-shrink:0}.hero-title .exchange-badge,.hero-title .currency-badge,.hero-title .price-symbol-tag{padding:.4rem .8rem;border-radius:6px;font-size:.89rem;font-weight:800;text-transform:uppercase;letter-spacing:.3px;white-space:nowrap;cursor:default;-webkit-user-select:none;user-select:none}.badges-group .profit-badge{padding:.4rem .8rem;border-radius:6px;font-size:.89rem;font-weight:800;letter-spacing:.02em}.badges-group .profit-badge.profit{background:#10b9811a;color:#059669;border:1px solid rgba(16,185,129,.3)}.badges-group .profit-badge.loss{background:#ef44441a;color:#dc2626;border:1px solid rgba(239,68,68,.3)}.stock-hero h1{margin:0;color:#1e293b;font-size:1.75rem;font-weight:900;letter-spacing:-.03em;white-space:nowrap}.stock-name{color:#64748b;font-size:.9rem;margin:0;font-weight:600;letter-spacing:-.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.exchange-badge{display:inline-block;padding:.3rem .75rem;border-radius:6px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.3px;cursor:default;-webkit-user-select:none;user-select:none}.exchange-nyse{background:#f59e0b14;color:#d97706;border:1px solid rgba(245,158,11,.2)}.exchange-nasdaq{background:#3b82f614;color:#3b82f6;border:1px solid rgba(59,130,246,.2)}.exchange-tase{background:#8b5cf614;color:#8b5cf6;border:1px solid rgba(139,92,246,.2)}.exchange-lse{background:#ec489914;color:#db2777;border:1px solid rgba(236,72,153,.2)}.exchange-tse{background:#f9731614;color:#ea580c;border:1px solid rgba(249,115,22,.2)}.exchange-hkex{background:#06b6d414;color:#0891b2;border:1px solid rgba(6,182,212,.2)}.exchange-badge:not(.exchange-nyse):not(.exchange-nasdaq):not(.exchange-tase):not(.exchange-lse):not(.exchange-tse):not(.exchange-hkex){background:#64748b14;color:#64748b;border:1px solid rgba(100,116,139,.2)}.currency-badge{display:inline-block;padding:.3rem .75rem;background:#64748b14;color:#64748b;border:1px solid rgba(100,116,139,.2);border-radius:6px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.3px;cursor:default;-webkit-user-select:none;user-select:none}.stats-grid-compact{display:grid;grid-template-columns:minmax(360px,2fr) minmax(250px,1fr);gap:1rem;margin-bottom:1.25rem}.combined-card{background:linear-gradient(135deg,#fffffff2,#f8fafcf2);padding:1rem 1.25rem;border-radius:16px;box-shadow:0 8px 30px #00000014,0 1px 3px #0000000d;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.8);transition:all .3s ease;position:relative;overflow:hidden;display:flex;gap:1.25rem}.combined-card:hover{box-shadow:0 12px 40px #0000001f,0 2px 6px #0000000f;transform:translateY(-4px);-webkit-transform:translateY(-4px)}@media (max-width: 768px){.combined-card:hover{transform:none;-webkit-transform:none}}.combined-section{flex:1;min-width:0}.card-divider{width:1px;background:linear-gradient(180deg,transparent,rgba(99,102,241,.3),transparent);border-radius:1px;margin:0}.stat-card{background:linear-gradient(135deg,#fffffff2,#f8fafcf2);padding:2rem;border-radius:20px;box-shadow:0 8px 30px #00000014,0 1px 3px #0000000d;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.8);transition:all .3s ease;position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#6366f1,#8b5cf6)}.stat-card:hover{box-shadow:0 12px 40px #0000001f,0 2px 6px #0000000f;transform:translateY(-4px);-webkit-transform:translateY(-4px)}@media (max-width: 768px){.stat-card:hover{transform:none;-webkit-transform:none}}.stat-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.stat-label{color:#64748b;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em}.stat-timestamp{color:#94a3b8;font-size:.65rem;font-weight:500}.stat-value{font-size:1.5rem;font-weight:900;color:#1e293b;letter-spacing:-.02em;line-height:1.2}.stat-value.profit{color:#059669}.stat-value.loss{color:#dc2626}.stat-value.neutral{color:#1e293b}.stat-currency{font-size:1rem;font-weight:700;color:#64748b;margin-left:.4rem}.stat-secondary{font-size:.85rem;font-weight:700;margin-top:.35rem;opacity:.7}.stat-secondary.profit{color:#059669}.stat-secondary.loss{color:#dc2626}.stat-secondary.neutral{color:#475569;opacity:.9}.holdings-summary-card{min-width:250px}.price-symbol-tag{display:inline-block;padding:.3rem .75rem;background:#6366f114;color:#6366f1;border:1px solid rgba(99,102,241,.2);border-radius:6px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.3px;white-space:nowrap;cursor:default;-webkit-user-select:none;user-select:none}.tradingview-corner-link{display:inline-flex;align-items:center;justify-content:center;width:31px;height:31px;border-radius:6px;background:#131722;border:1px solid rgba(255,255,255,.12);text-decoration:none;line-height:0;transition:background .15s ease,border-color .15s ease,box-shadow .15s ease;box-shadow:0 1px 3px #0003}.tradingview-corner-link:hover{background:#1e222d;border-color:#2962ff73;box-shadow:0 2px 8px #00000040}.tradingview-corner-link:focus-visible{outline:2px solid #2962ff;outline-offset:2px}.tradingview-favicon{display:block;width:16px;height:16px;object-fit:contain}.price-card:before{background:linear-gradient(90deg,#3b82f6,#2563eb)}.profit-loss-card:before{background:linear-gradient(90deg,#10b981,#059669)}.loading-card,.error-card{display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:120px}.loading-text{font-size:1rem;color:#6366f1;font-weight:600;font-style:italic}.error-text{font-size:.9rem;color:#dc2626;font-weight:600;text-align:center;margin-bottom:.4rem}.error-hint{font-size:.75rem;color:#94a3b8;font-style:italic;text-align:center}.fx-loading,.fx-error{font-size:.75rem;margin-top:.5rem;font-style:italic}.fx-loading{color:#64748b}.fx-error{color:#dc2626}.performance-summary-card{background:linear-gradient(135deg,#6366f114,#8b5cf614);padding:.65rem 1.25rem;border-radius:10px;border:1px solid rgba(99,102,241,.2);margin-bottom:1.25rem;display:flex;align-items:center;justify-content:center;gap:2rem;transition:all .3s ease}.performance-summary-card:hover{background:linear-gradient(135deg,#6366f11f,#8b5cf61f);border-color:#6366f14d}.summary-item{display:flex;flex-direction:column;align-items:center;gap:.25rem}.summary-label{color:#64748b;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em}.summary-label-row{display:flex;align-items:center;gap:.35rem}.summary-help{position:relative;display:inline-flex;align-items:center}.summary-help-icon{display:inline-flex;align-items:center;justify-content:center;width:15px;height:15px;border-radius:999px;background:#6366f11f;color:#6366f1;border:1px solid rgba(99,102,241,.25);font-size:.6rem;font-weight:800;line-height:1;cursor:help}.summary-help-icon-alt{width:16px;height:16px;font-size:.68rem;font-weight:900}.summary-tooltip{position:absolute;left:50%;bottom:calc(100% + 8px);transform:translate(-50%) translateY(4px);background:#1e293b;color:#f8fafc;padding:.45rem .6rem;border-radius:6px;font-size:.68rem;font-weight:600;letter-spacing:.01em;text-transform:none;white-space:nowrap;box-shadow:0 8px 20px #0f172a47;pointer-events:none;opacity:0;visibility:hidden;transition:opacity .18s ease,transform .18s ease,visibility .18s ease;z-index:20}.summary-tooltip-wide{white-space:normal;width:max-content;max-width:360px;line-height:1.45;padding:.55rem .7rem}.summary-tooltip-line{display:block}.summary-tooltip-line+.summary-tooltip-line{margin-top:.2rem}.summary-tooltip-label{color:#cbd5e1;font-weight:800}.summary-tooltip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border-width:5px;border-style:solid;border-color:#1e293b transparent transparent transparent}.summary-help:hover .summary-tooltip,.summary-help:focus-within .summary-tooltip{opacity:1;visibility:visible;transform:translate(-50%) translateY(0)}.summary-value{color:#1e293b;font-size:.9rem;font-weight:800;letter-spacing:-.01em}.summary-value.profit{color:#059669}.summary-value.loss{color:#dc2626}.summary-value.neutral{color:#64748b}.summary-pending{font-weight:600;font-size:.82rem;letter-spacing:-.01em}.summary-percent-hint{font-weight:600;font-size:.62rem;color:#64748b;opacity:.95}.summary-subvalue{font-size:.75rem;font-weight:700}.summary-subvalue.profit{color:#059669}.summary-subvalue.loss{color:#dc2626}.summary-divider{width:1px;height:30px;background:linear-gradient(180deg,transparent,#6366f1,transparent);border-radius:1px}.chart-section,.prices-section,.transactions-section{background:linear-gradient(135deg,#fffffff2,#f8fafcf2);padding:1.5rem;border-radius:16px;box-shadow:0 8px 30px #00000014,0 1px 3px #0000000d;margin-bottom:1.25rem;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.8);transition:all .3s ease}.chart-section:hover,.prices-section:hover,.transactions-section:hover{box-shadow:0 12px 40px #0000001f,0 2px 6px #0000000f;transform:translateY(-2px);-webkit-transform:translateY(-2px)}@media (max-width: 768px){.transactions-section:hover{transform:none;-webkit-transform:none}}.chart-section h2,.prices-section h2,.transactions-section h2{margin-top:0;margin-bottom:1.25rem;color:#8b5cf6;font-size:1.5rem;font-weight:800;letter-spacing:-.02em}.chart-container{margin-top:2rem;padding:1rem;background:#ffffff80;border-radius:16px}.prices-table,.transactions-table{overflow-x:auto;border-radius:16px;background:#ffffff80;padding:0;margin-top:1rem;width:100%;max-width:100%;-webkit-overflow-scrolling:touch}@media (max-width: 768px){.prices-table,.transactions-table{border-radius:12px}}.prices-table::-webkit-scrollbar,.transactions-table::-webkit-scrollbar{height:12px}.prices-table::-webkit-scrollbar-track,.transactions-table::-webkit-scrollbar-track{background:#6366f114;border-radius:6px;margin:0 10px}.prices-table::-webkit-scrollbar-thumb,.transactions-table::-webkit-scrollbar-thumb{background:linear-gradient(135deg,#6366f180,#8b5cf680);border-radius:6px;border:2px solid rgba(255,255,255,.5)}.prices-table::-webkit-scrollbar-thumb:hover,.transactions-table::-webkit-scrollbar-thumb:hover{background:linear-gradient(135deg,#6366f1cc,#8b5cf6cc);border-color:#fffc}.prices-table table,.transactions-table table{width:100%;border-collapse:separate;border-spacing:0;min-width:fit-content;display:table}.prices-table thead,.transactions-table thead{background:linear-gradient(135deg,#f8fafcfa,#f1f5f9fa);position:sticky;top:0;z-index:10;box-shadow:0 2px 8px #0000000f}.prices-table thead tr,.transactions-table thead tr{border-radius:16px 16px 0 0}.prices-table th,.transactions-table th{padding:1rem .75rem;text-align:left;font-weight:800;color:#1e293b;border:none;font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;background:linear-gradient(135deg,#f8fafcfa,#f1f5f9fa);white-space:nowrap;border-bottom:2px solid rgba(99,102,241,.2)}.prices-table th:first-child,.transactions-table th:first-child{border-radius:16px 0 0;padding-left:1rem}.prices-table th:last-child,.transactions-table th:last-child{border-radius:0 16px 0 0;padding-right:1rem}.prices-table td,.transactions-table td{padding:.875rem .75rem;border:none;color:#475569;background:#ffffffe6;font-size:.875rem;font-weight:500;border-bottom:1px solid rgba(203,213,225,.3)}.transactions-table td:not(.note-cell){white-space:nowrap}.prices-table td:first-child,.transactions-table td:first-child{padding-left:1rem}.prices-table td:last-child,.transactions-table td:last-child{padding-right:1rem}.prices-table tbody tr,.transactions-table tbody tr{transition:all .2s ease}.prices-table tbody tr:last-child td,.transactions-table tbody tr:last-child td{border-bottom:none}.prices-table tbody tr:last-child td:first-child,.transactions-table tbody tr:last-child td:first-child{border-radius:0 0 0 16px}.prices-table tbody tr:last-child td:last-child,.transactions-table tbody tr:last-child td:last-child{border-radius:0 0 16px}.prices-table tbody tr:hover,.transactions-table tbody tr:hover{background:linear-gradient(135deg,#6366f114,#8b5cf614)}.prices-table tbody tr:hover td,.transactions-table tbody tr:hover td{background:transparent;border-bottom-color:#6366f133}.close-price{font-weight:700;color:#1e293b;font-size:.875rem}.transaction-type{display:inline-block;padding:.3rem .65rem;border-radius:6px;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.03em;border:1px solid;cursor:default;-webkit-user-select:none;user-select:none}.transaction-type.buy{background:#10b9811a;color:#059669;border-color:#10b9814d}.transaction-type.sell{background:#ef44441a;color:#dc2626;border-color:#ef44444d}.transaction-type.fee{background:#f59e0b1a;color:#d97706;border-color:#f59e0b4d}.transaction-type.deposit{background:#3b82f61a;color:#2563eb;border-color:#3b82f64d}.transaction-type.withdrawal{background:#8b5cf61a;color:#7c3aed;border-color:#8b5cf64d}.value-cell{font-weight:700;color:#1e293b;font-size:.875rem}.transactions-table th:nth-child(1),.transactions-table td:nth-child(1){width:110px;min-width:110px}.transactions-table th:nth-child(2),.transactions-table td:nth-child(2){width:80px;min-width:80px;text-align:center}.transactions-table th:nth-child(3),.transactions-table td:nth-child(3){width:100px;min-width:100px;text-align:right}.transactions-table th:nth-child(4),.transactions-table td:nth-child(4){width:120px;min-width:120px;text-align:right}.transactions-table th:nth-child(5),.transactions-table td:nth-child(5){width:90px;min-width:90px;text-align:right}.transactions-table th:nth-child(6),.transactions-table td:nth-child(6){width:120px;min-width:120px;text-align:right}.transactions-table th:nth-child(7),.transactions-table td:nth-child(7){width:auto;min-width:200px;white-space:normal}.note-cell{white-space:normal!important;word-wrap:break-word;color:#64748b;font-style:italic;overflow:visible;line-height:1.4}.loading,.error{text-align:center;padding:4rem 2rem;font-size:1.2rem;background:linear-gradient(135deg,#fffffff2,#f8fafcf2);border-radius:20px;box-shadow:0 8px 30px #00000014;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.8);font-weight:600}.loading{color:#6366f1}.error{color:#dc2626}.empty-state{text-align:center;padding:3rem 2rem;background:linear-gradient(135deg,#6366f10d,#8b5cf60d);border-radius:16px;border:2px dashed rgba(99,102,241,.2);color:#64748b;font-size:1.1rem;font-weight:500;transition:all .3s ease}.empty-state:hover{background:linear-gradient(135deg,#6366f114,#8b5cf614);border-color:#6366f14d}@media (max-width: 968px){.stock-detail-nav{flex-direction:column;align-items:stretch}.stock-navigation{justify-content:center;width:100%}.nav-stock-label{display:none}.stats-grid-compact{grid-template-columns:1fr}.combined-card{flex-direction:column;gap:1rem}.card-divider{width:100%;height:1px;background:linear-gradient(90deg,transparent,rgba(99,102,241,.3),transparent)}}@media (max-width: 768px){.stock-detail{padding:1.25rem}.stock-hero{padding:1rem 1.25rem}.tradingview-favicon{width:16px;height:16px}.hero-title{flex-direction:column;align-items:flex-start;gap:.75rem}.stock-hero h1{font-size:1.5rem}.stock-name{font-size:.85rem}.title-row{flex-direction:column;align-items:flex-start;gap:.35rem;width:100%}.stats-grid-compact{grid-template-columns:1fr;gap:.75rem}.combined-card{padding:1rem;flex-direction:column;gap:1rem}.card-divider{width:100%;height:1px;background:linear-gradient(90deg,transparent,rgba(99,102,241,.3),transparent)}.stat-value{font-size:1.5rem}.performance-summary-card{flex-direction:column;gap:1rem;padding:1rem}.summary-divider{width:80px;height:1px;background:linear-gradient(90deg,transparent,#6366f1,transparent)}.chart-section,.prices-section,.transactions-section{padding:1.25rem}.prices-table,.transactions-table{font-size:.85rem}.prices-table th,.transactions-table th,.prices-table td,.transactions-table td{padding:.75rem 1rem}.prices-table th:first-child,.transactions-table th:first-child,.prices-table td:first-child,.transactions-table td:first-child{padding-left:1rem}.prices-table th:last-child,.transactions-table th:last-child,.prices-table td:last-child,.transactions-table td:last-child{padding-right:1rem}}.settings-container{max-width:800px;margin:0 auto;padding:2rem}.settings-header{margin-bottom:2rem}.settings-title{font-size:2rem;font-weight:700;color:#1f2937;margin:0 0 .5rem;letter-spacing:-.5px}.settings-subtitle{font-size:1rem;color:#6b7280;margin:0}.settings-loading{display:flex;align-items:center;justify-content:center;padding:3rem;font-size:1rem;color:#6b7280}.settings-message{padding:1rem 1.5rem;border-radius:12px;font-size:.875rem;font-weight:500;margin-bottom:1.5rem;animation:slideIn .3s ease-out}.settings-message.settings-error{background:#fee2e2;color:#dc2626;border:1px solid #fecaca}.settings-message.settings-success{background:#d1fae5;color:#059669;border:1px solid #a7f3d0}@keyframes slideIn{0%{transform:translateY(-10px);opacity:0}to{transform:translateY(0);opacity:1}}.settings-form{background:#fff;border-radius:16px;padding:2rem;box-shadow:0 1px 3px #0000000d,0 1px 2px #00000008;border:1px solid rgba(226,232,240,.8)}.settings-section{display:flex;flex-direction:column;gap:2rem;margin-bottom:2rem}.settings-field{display:flex;flex-direction:column;gap:.5rem}.settings-label{font-size:.9375rem;font-weight:600;color:#1f2937;margin:0}.settings-description{font-size:.875rem;color:#6b7280;margin:0;line-height:1.5}.settings-input{width:100%;padding:.75rem 1rem;border:1px solid rgba(226,232,240,.8);border-radius:12px;background:#ffffffe6;color:#1f2937;font-size:1rem;font-weight:500;transition:all .2s ease;outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none}.settings-input:focus{background:#fff;border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.settings-input::placeholder{color:#9ca3af}.settings-meta{display:flex;flex-direction:column;gap:.75rem;padding:1.5rem;background:#f9fafb99;border-radius:12px;margin-bottom:2rem;border:1px solid rgba(226,232,240,.8)}.settings-meta-item{display:flex;justify-content:space-between;align-items:center;font-size:.875rem}.settings-meta-label{color:#6b7280;font-weight:500}.settings-meta-value{color:#1f2937;font-weight:600}.settings-actions{display:flex;justify-content:flex-end;gap:1rem}.settings-save-button{padding:.75rem 2rem;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border:none;border-radius:12px;font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);outline:none;box-shadow:0 4px 12px #6366f14d}.settings-save-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #6366f166}.settings-save-button:active:not(:disabled){transform:translateY(0)}.settings-save-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.settings-danger-section{margin-top:2.5rem;padding-top:2rem;border-top:1px solid rgba(226,232,240,.8);background:#fff;border-radius:16px;padding:2rem;box-shadow:0 1px 3px #0000000d,0 1px 2px #00000008;border:1px solid rgba(226,232,240,.8)}.settings-section-title{font-size:1.125rem;font-weight:600;color:#1f2937;margin:0 0 .5rem}.settings-danger-section .settings-description{margin-bottom:1rem}.settings-delete-button{padding:.75rem 2rem;background:#dc2626;color:#fff;border:none;border-radius:12px;font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .2s ease;outline:none}.settings-delete-button:hover:not(:disabled){background:#b91c1c;transform:translateY(-2px);box-shadow:0 4px 12px #dc262659}.settings-delete-button:active:not(:disabled){transform:translateY(0)}.settings-delete-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.settings-dialog-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.settings-dialog{background:#fff;border-radius:16px;padding:1.5rem 2rem;max-width:420px;width:100%;box-shadow:0 25px 50px -12px #00000040;animation:dialogSlideIn .25s ease-out}@keyframes dialogSlideIn{0%{transform:scale(.95);opacity:0}to{transform:scale(1);opacity:1}}.settings-dialog-title{font-size:1.25rem;font-weight:600;color:#1f2937;margin:0 0 .75rem}.settings-dialog-text{font-size:.9375rem;color:#6b7280;line-height:1.5;margin:0 0 1.25rem}.settings-dialog-error{margin-bottom:1rem}.settings-dialog-actions{display:flex;justify-content:flex-end;gap:.75rem}.settings-dialog-cancel{padding:.5rem 1.25rem;background:transparent;color:#6b7280;border:1px solid rgba(226,232,240,.8);border-radius:10px;font-size:.9375rem;font-weight:500;cursor:pointer;transition:all .2s ease}.settings-dialog-cancel:hover:not(:disabled){background:#f3f4f6;color:#1f2937}.settings-dialog-cancel:disabled{opacity:.6;cursor:not-allowed}.settings-dialog-confirm-delete{padding:.5rem 1.25rem;background:#dc2626;color:#fff;border:none;border-radius:10px;font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .2s ease}.settings-dialog-confirm-delete:hover:not(:disabled){background:#b91c1c}.settings-dialog-confirm-delete:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 768px){.settings-container{padding:1rem}.settings-title{font-size:1.75rem}.settings-form{padding:1.5rem}.settings-section{gap:1.5rem}.settings-actions{flex-direction:column}.settings-save-button{width:100%}.settings-danger-section{margin-top:2rem;padding:1.5rem}.settings-dialog{padding:1.25rem 1.5rem}.settings-dialog-actions{flex-direction:column-reverse}.settings-dialog-actions button{width:100%}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f0f4ff,#faf5ff,#f0fdf4);padding:1.5rem}[data-theme=dark] .login-page{background:linear-gradient(135deg,#0f172a,#1e1b4b,#0f172a)}.login-card{width:100%;max-width:420px;background:#ffffffeb;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border:1px solid rgba(226,232,240,.8);border-radius:20px;padding:2.5rem;box-shadow:0 4px 6px -1px #0000000f,0 20px 60px -10px #6366f11f,0 0 0 1px #ffffff80;animation:loginCardIn .4s cubic-bezier(.16,1,.3,1)}[data-theme=dark] .login-card{background:#1e293be6;border-color:#334155cc;box-shadow:0 4px 6px -1px #0000004d,0 20px 60px -10px #6366f133,0 0 0 1px #ffffff0a}@keyframes loginCardIn{0%{opacity:0;transform:translateY(16px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.login-brand{display:flex;align-items:center;gap:.875rem;margin-bottom:1.75rem}.login-brand-icon{width:48px;height:48px;border-radius:14px;background:linear-gradient(135deg,#6366f1,#8b5cf6);display:flex;align-items:center;justify-content:center;font-size:1.375rem;box-shadow:0 6px 16px #6366f159;flex-shrink:0}.login-brand-text{display:flex;flex-direction:column;gap:.1rem}.login-brand-title{font-size:1.25rem;font-weight:700;color:#1f2937;letter-spacing:-.5px;line-height:1.2}[data-theme=dark] .login-brand-title{color:#f1f5f9}.login-brand-subtitle{font-size:.6875rem;font-weight:500;color:#6b7280;text-transform:uppercase;letter-spacing:.5px}.login-heading{font-size:1.625rem;font-weight:700;color:#111827;letter-spacing:-.5px;margin-bottom:.375rem}[data-theme=dark] .login-heading{color:#f8fafc}.login-subheading{font-size:.9375rem;color:#6b7280;margin-bottom:2rem;line-height:1.5}[data-theme=dark] .login-subheading{color:#94a3b8}.login-form{display:flex;flex-direction:column;gap:1.25rem}.login-field{display:flex;flex-direction:column;gap:.5rem}.login-label{font-size:.875rem;font-weight:600;color:#374151;letter-spacing:.01em}[data-theme=dark] .login-label{color:#cbd5e1}.login-input{width:100%;padding:.8125rem 1rem;border:1.5px solid rgba(209,213,219,.8);border-radius:12px;background:#f9fafbcc;color:#111827;font-size:.9375rem;font-weight:500;transition:all .2s ease;outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none}[data-theme=dark] .login-input{background:#0f172a99;border-color:#334155cc;color:#f1f5f9}.login-input::placeholder{color:#9ca3af;font-weight:400}[data-theme=dark] .login-input::placeholder{color:#475569}.login-input:focus{background:#fff;border-color:#6366f1;box-shadow:0 0 0 3px #6366f126}[data-theme=dark] .login-input:focus{background:#0f172ae6;box-shadow:0 0 0 3px #6366f140}.login-input:disabled{opacity:.6;cursor:not-allowed}.login-error{display:flex;align-items:flex-start;gap:.5rem;padding:.875rem 1rem;background:#fee2e2cc;border:1px solid rgba(252,165,165,.6);border-radius:10px;color:#dc2626;font-size:.875rem;font-weight:500;line-height:1.5;animation:loginErrorIn .2s ease-out}[data-theme=dark] .login-error{background:#7f1d1d4d;border-color:#b91c1c66;color:#fca5a5}@keyframes loginErrorIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.login-error-icon{flex-shrink:0;font-style:normal;font-size:.9375rem;margin-top:.05rem}.login-submit{display:flex;align-items:center;justify-content:center;gap:.625rem;width:100%;padding:.875rem 1.5rem;margin-top:.25rem;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border:none;border-radius:12px;font-size:1rem;font-weight:600;letter-spacing:.01em;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 14px #6366f159;-webkit-appearance:none;-moz-appearance:none;appearance:none;min-height:52px}.login-submit:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 20px #6366f173}.login-submit:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 8px #6366f14d}.login-submit:disabled{opacity:.65;cursor:not-allowed;transform:none;box-shadow:0 2px 8px #6366f133}.login-btn-spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.35);border-top-color:#fff;border-radius:50%;animation:loginSpin .7s linear infinite;flex-shrink:0}@keyframes loginSpin{to{transform:rotate(360deg)}}.login-loading-spinner{width:40px;height:40px;border:3px solid rgba(99,102,241,.2);border-top-color:#6366f1;border-radius:50%;animation:loginSpin .8s linear infinite}@media (max-width: 480px){.login-card{padding:2rem 1.5rem;border-radius:16px}.login-heading{font-size:1.5rem}}.broker-view-fullscreen{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;background:linear-gradient(145deg,#0f172a,#1e293b 35%,#0f172a);overflow:hidden;padding:0;padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom);height:100vh;height:100dvh;display:flex;flex-direction:column;transition:background .25s ease}[data-theme=light] .broker-view-fullscreen{background:linear-gradient(145deg,#f8fafc,#f1f5f9 35%,#e2e8f0)}.broker-view-top-zone{position:fixed;top:0;left:0;right:0;height:100px;z-index:10000;pointer-events:auto}.broker-view-top-actions{position:fixed;top:0;right:0;z-index:10001;display:flex;align-items:center;gap:.75rem;padding:1rem 1.5rem;padding-top:calc(1rem + env(safe-area-inset-top));opacity:0;pointer-events:none;transition:opacity .3s ease}.broker-view-top-actions--visible{opacity:1;pointer-events:auto}.broker-view-theme-toggle{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#ffffff14;border:1px solid rgba(255,255,255,.15);border-radius:10px;color:#ffffffe6;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);box-shadow:0 4px 24px #0000004d}.broker-view-theme-toggle:hover{background:#ffffff1f;border-color:#ffffff40;color:#fff;transform:translateY(-1px);box-shadow:0 6px 28px #0000004d}.broker-view-theme-icon{font-size:1.1rem}[data-theme=light] .broker-view-theme-toggle,[data-theme=light] .broker-view-exit-btn{background:#ffffffe6;border-color:#0000001a;color:#1e293b;box-shadow:0 2px 12px #00000014}[data-theme=light] .broker-view-theme-toggle:hover,[data-theme=light] .broker-view-exit-btn:hover{background:#fff;border-color:#6366f1;color:#4338ca}.broker-view-exit-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;background:#ffffff14;border:1px solid rgba(255,255,255,.15);border-radius:10px;color:#ffffffe6;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);box-shadow:0 4px 24px #0000004d}.broker-view-exit-btn:hover{background:#ffffff1f;border-color:#ffffff40;color:#fff;transform:translateY(-1px);box-shadow:0 6px 28px #0006}.broker-view-exit-icon{font-size:1rem;opacity:.9}.broker-view-fullscreen-content{flex:1;min-height:0;padding:2.75rem .75rem .5rem;max-width:100%;overflow:hidden;display:flex;flex-direction:column;height:100%}.broker-view-fullscreen .dashboard.dashboard--fullscreen{max-width:none;margin:0;padding:0;min-height:0;flex:1;background:transparent;display:flex;flex-direction:column;overflow:hidden}.broker-view-fullscreen .dashboard.dashboard--fullscreen .dashboard-content{display:grid;grid-template-columns:repeat(6,1fr);grid-template-rows:auto 1fr;gap:16px;flex:1;min-height:0;overflow:hidden;height:100%}.broker-view-fullscreen .dashboard.dashboard--fullscreen .dashboard-content.broker-view-no-tax-loss .portfolio-cards-container{grid-column:1 / -1}.broker-view-fullscreen .dashboard.dashboard--fullscreen .portfolio-cards-container{grid-column:1 / 4;grid-row:1;padding:16px;margin:0;min-height:0;flex-shrink:0;align-self:start;max-width:100%}.broker-view-fullscreen .dashboard.dashboard--fullscreen .portfolio-cards-header{margin-bottom:.5rem}.broker-view-fullscreen .dashboard.dashboard--fullscreen .portfolio-cards-title{font-size:1rem}.broker-view-fullscreen .dashboard.dashboard--fullscreen .portfolio-summary-modern{grid-template-columns:repeat(3,minmax(180px,260px));gap:.5rem;justify-content:start}.broker-view-fullscreen .dashboard.dashboard--fullscreen .value-card{padding:.5rem .65rem}.broker-view-fullscreen .dashboard.dashboard--fullscreen .card-value{font-size:1.15rem}.broker-view-fullscreen .dashboard.dashboard--fullscreen .card-title span{font-size:.75rem}.broker-view-fullscreen .dashboard.dashboard--fullscreen .card-value-label,.broker-view-fullscreen .dashboard.dashboard--fullscreen .card-value-amount{font-size:.8rem}.broker-view-fullscreen .dashboard.dashboard--fullscreen .card-footer,.broker-view-fullscreen .dashboard.dashboard--fullscreen .date-label{font-size:.65rem}.broker-view-fullscreen .dashboard.dashboard--fullscreen .loss-harvest-section{grid-column:4 / 7;grid-row:1;padding:16px;min-height:0;flex-shrink:0;display:flex;flex-direction:column;align-items:flex-start;max-width:100%;justify-self:start;align-self:start;transform:scale(.8);transform-origin:top left}.broker-view-fullscreen .dashboard.dashboard--fullscreen .loss-harvest-scroll{width:max-content;max-width:100%}.broker-view-fullscreen{scrollbar-width:none;-ms-overflow-style:none}.broker-view-fullscreen::-webkit-scrollbar{display:none}.broker-view-fullscreen .dashboard.dashboard--fullscreen .chart-section{grid-column:1 / 3;grid-row:2;align-self:stretch;min-height:0;overflow:hidden;display:flex;flex-direction:column;padding:16px;flex:1}.broker-view-fullscreen .dashboard.dashboard--fullscreen .positions-section{grid-column:3 / 7;grid-row:2;align-self:stretch;min-height:0;overflow:hidden;display:flex;flex-direction:column;padding:16px;flex:1}.broker-view-fullscreen .dashboard.dashboard--fullscreen .chart-header,.broker-view-fullscreen .dashboard.dashboard--fullscreen .positions-section-header{flex-shrink:0}.broker-view-fullscreen .dashboard.dashboard--fullscreen .chart-title-nav-style,.broker-view-fullscreen .dashboard.dashboard--fullscreen .section-title-nav-style{font-size:.85rem}.broker-view-fullscreen .dashboard.dashboard--fullscreen .chart-toggle,.broker-view-fullscreen .dashboard.dashboard--fullscreen .view-toggle,.broker-view-fullscreen .dashboard.dashboard--fullscreen .positions-header-controls{gap:.35rem}.broker-view-fullscreen .dashboard.dashboard--fullscreen .toggle-button,.broker-view-fullscreen .dashboard.dashboard--fullscreen .view-toggle-btn{padding:.3rem .5rem;font-size:.7rem}.broker-view-fullscreen .dashboard.dashboard--fullscreen .chart-container{flex:1;min-height:0;height:100%;display:flex;flex-direction:column}.broker-view-fullscreen .dashboard.dashboard--fullscreen .chart-container .recharts-wrapper{width:100%!important;height:100%!important}.broker-view-fullscreen .dashboard.dashboard--fullscreen .chart-container .recharts-surface{overflow:visible}.broker-view-fullscreen .dashboard.dashboard--fullscreen .chart-container.chart-container-heatmap,.broker-view-fullscreen .dashboard.dashboard--fullscreen .chart-container .heatmap-container{min-height:0}.broker-view-fullscreen .dashboard.dashboard--fullscreen .positions-section .positions-table-view{flex:1;min-height:0;overflow:auto}.broker-view-fullscreen .dashboard.dashboard--fullscreen .positions-section .positions-list,.broker-view-fullscreen .dashboard.dashboard--fullscreen .positions-section .positions-list-compact{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden}.broker-view-fullscreen .dashboard.dashboard--fullscreen .dashboard-positions-table{font-size:.7rem}.broker-view-fullscreen .dashboard.dashboard--fullscreen .dashboard-positions-th,.broker-view-fullscreen .dashboard.dashboard--fullscreen .dashboard-positions-td{padding:.25rem .4rem}.broker-view-fullscreen .dashboard.dashboard--fullscreen .dashboard-symbol-text{font-size:.75rem}.broker-view-fullscreen .dashboard.dashboard--fullscreen .dashboard-table-value{font-size:.7rem}@media (max-width: 900px){.broker-view-fullscreen .dashboard.dashboard--fullscreen .dashboard-content{grid-template-columns:1fr;grid-template-rows:auto auto 1fr 1fr}.broker-view-fullscreen .dashboard.dashboard--fullscreen .portfolio-cards-container{grid-column:1;grid-row:1}.broker-view-fullscreen .dashboard.dashboard--fullscreen .loss-harvest-section{grid-column:1;grid-row:2}.broker-view-fullscreen .dashboard.dashboard--fullscreen .chart-section{grid-column:1;grid-row:3}.broker-view-fullscreen .dashboard.dashboard--fullscreen .positions-section{grid-column:1;grid-row:4}}[data-theme=dark] .broker-view-fullscreen .dashboard.dashboard--fullscreen .portfolio-cards-container{background:#1e293b99;border:1px solid rgba(255,255,255,.08);box-shadow:0 4px 24px #00000040}[data-theme=dark] .broker-view-fullscreen .dashboard.dashboard--fullscreen .portfolio-cards-title{color:#fffffff2}[data-theme=dark] .broker-view-fullscreen .dashboard.dashboard--fullscreen .value-card{background:#1e293b80;border-color:#ffffff0f}[data-theme=dark] .broker-view-fullscreen .dashboard.dashboard--fullscreen .card-title span,[data-theme=dark] .broker-view-fullscreen .dashboard.dashboard--fullscreen .card-value,[data-theme=dark] .broker-view-fullscreen .dashboard.dashboard--fullscreen .card-value-label,[data-theme=dark] .broker-view-fullscreen .dashboard.dashboard--fullscreen .card-value-amount{color:#ffffffe6}[data-theme=dark] .broker-view-fullscreen .dashboard.dashboard--fullscreen .date-label,[data-theme=dark] .broker-view-fullscreen .dashboard.dashboard--fullscreen .card-footer span{color:#ffffff80}[data-theme=dark] .broker-view-fullscreen .dashboard.dashboard--fullscreen .chart-section,[data-theme=dark] .broker-view-fullscreen .dashboard.dashboard--fullscreen .positions-section{background:#1e293b66;border:1px solid rgba(255,255,255,.06);border-radius:12px;padding:1rem;box-shadow:0 4px 20px #0003}[data-theme=dark] .broker-view-fullscreen .dashboard.dashboard--fullscreen .chart-title-nav-style,[data-theme=dark] .broker-view-fullscreen .dashboard.dashboard--fullscreen .section-title-nav-style{color:#fffffff2}[data-theme=dark] .broker-view-fullscreen .dashboard.dashboard--fullscreen .loss-harvest-section{background:#1e293b66;border:1px solid rgba(255,255,255,.06);border-radius:12px;padding:1rem}[data-theme=dark] .broker-view-fullscreen .dashboard.dashboard--fullscreen .loss-harvest-title{color:#fffffff2}[data-theme=dark] .broker-view-fullscreen .dashboard.dashboard--fullscreen .loss-harvest-subtitle{color:#fff9}[data-theme=dark] .broker-view-fullscreen .dashboard.dashboard--fullscreen .currency-toggle{background:#ffffff0f;border-color:#ffffff1a}[data-theme=dark] .broker-view-fullscreen .dashboard.dashboard--fullscreen .currency-toggle-btn{color:#ffffffb3}[data-theme=dark] .broker-view-fullscreen .dashboard.dashboard--fullscreen .currency-toggle-btn.active{background:#6366f159;color:#a5b4fc}[data-theme=dark] .broker-view-fullscreen .dashboard.dashboard--fullscreen .dashboard-positions-table{color:#ffffffe6}[data-theme=dark] .broker-view-fullscreen .dashboard.dashboard--fullscreen .dashboard-positions-thead{background:#0003}[data-theme=dark] .broker-view-fullscreen .dashboard.dashboard--fullscreen .dashboard-positions-th{color:#ffffffb3;border-color:#ffffff14}[data-theme=dark] .broker-view-fullscreen .dashboard.dashboard--fullscreen .dashboard-positions-row{border-color:#ffffff0f}[data-theme=dark] .broker-view-fullscreen .dashboard.dashboard--fullscreen .dashboard-positions-row:hover{background:#ffffff0d}[data-theme=dark] .broker-view-fullscreen .dashboard.dashboard--fullscreen .dashboard-table-value,[data-theme=dark] .broker-view-fullscreen .dashboard.dashboard--fullscreen .dashboard-symbol-text{color:#ffffffe6}[data-theme=dark] .broker-view-fullscreen .dashboard.dashboard--fullscreen .toggle-button,[data-theme=dark] .broker-view-fullscreen .dashboard.dashboard--fullscreen .view-toggle-btn{background:#ffffff0f;color:#fffc;border-color:#ffffff1a}[data-theme=dark] .broker-view-fullscreen .dashboard.dashboard--fullscreen .toggle-button.active,[data-theme=dark] .broker-view-fullscreen .dashboard.dashboard--fullscreen .view-toggle-btn.active{background:#6366f159;color:#c7d2fe;border-color:#6366f180}[data-theme=dark] .broker-view-fullscreen .dashboard.dashboard--fullscreen .loss-filter-button{background:#ffffff0f;color:#fffc;border-color:#ffffff1a}[data-theme=dark] .broker-view-fullscreen .dashboard.dashboard--fullscreen .loss-filter-button.loss-filter-button-active{background:#ef444440;color:#fca5a5}[data-theme=dark] .broker-view-fullscreen .dashboard.dashboard--fullscreen .daily-change-button{background:#ffffff0f;color:#fffc;border-color:#ffffff1a}[data-theme=dark] .broker-view-fullscreen .dashboard.dashboard--fullscreen .daily-change-button.daily-change-button-active{background:#2563eb40;color:#93c5fd}[data-theme=dark] .broker-view-fullscreen .dashboard.dashboard--fullscreen .exchange-filter-button{background:#ffffff0f;color:#fffc;border-color:#ffffff1a}[data-theme=dark] .broker-view-fullscreen .dashboard .loading,[data-theme=dark] .broker-view-fullscreen .dashboard .error{color:#ffffffe6}[data-theme=dark] .broker-view-fullscreen .dashboard .empty-state{color:#fff9}*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}html{padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left);-webkit-text-size-adjust:100%;-moz-text-size-adjust:100%;text-size-adjust:100%;scroll-behavior:smooth;-webkit-overflow-scrolling:touch}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f5f5;color:#333;overflow-x:hidden;-webkit-overflow-scrolling:touch}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}#root{min-height:100vh;min-height:-webkit-fill-available}button,a,input,select,textarea{-webkit-tap-highlight-color:rgba(139,92,246,.1);touch-action:manipulation}@media (max-width: 768px){button,a,.btn,.nav-link{min-height:44px;min-width:44px}}
