.app{flex-direction:column;min-height:100vh;display:flex}.commodity-section{margin-bottom:40px}.section-header{align-items:center;gap:12px;margin-bottom:12px;display:flex}.accent{border-radius:99px;width:6px;height:22px}.accent-gold{background:var(--accent-gold)}.accent-cyan{background:var(--accent-cyan)}.section-icon{color:#9ca3af;font-size:14px}.section-label{font-family:var(--font-display);letter-spacing:.08em;text-transform:uppercase;font-size:13px;font-weight:700}.section-label-gold{color:var(--accent-gold);text-shadow:0 0 14px #d9770633}.section-label-cyan{color:var(--accent-cyan);text-shadow:0 0 14px #1bd48833}.section-line{background:var(--section-line-bg);flex:1;height:1px}.section-count{letter-spacing:.06em;color:var(--text-secondary);font-size:11px;font-weight:600}.commodity-group{margin-bottom:20px}.commodity-group-header{font-family:var(--font-display);letter-spacing:.08em;color:var(--text-primary);text-transform:uppercase;border-left:3px solid var(--accent-gold);background:var(--section-bg);border-top:1px solid var(--section-border);border-right:1px solid var(--section-border);border-bottom:1px solid var(--section-border);border-radius:8px;margin-bottom:8px;padding:7px 10px;font-size:12px;font-weight:700}.commodity-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:10px;display:grid}.route-loading-fallback{min-height:60vh}.crypto-table-wrap{border:1px solid var(--section-border);border-radius:8px;overflow-x:auto}.crypto-table{border-collapse:collapse;width:100%;font-family:var(--font-mono);font-size:12px}.crypto-th{background:var(--bg-panel);color:var(--text-secondary);font-family:var(--font-display);letter-spacing:.06em;text-transform:uppercase;white-space:nowrap;border-bottom:1px solid var(--section-border);-webkit-user-select:none;user-select:none;padding:9px 12px;font-size:11px;font-weight:700}.crypto-th--left{text-align:left}.crypto-th--right{text-align:right}.crypto-th--center{text-align:center}.crypto-th--sortable{cursor:pointer}.crypto-th--sortable:hover{color:var(--text-primary);background:var(--bg-card)}.crypto-th--active{color:#f7931a}.crypto-th-sort{opacity:.6;font-size:10px}.crypto-tr{border-bottom:1px solid var(--section-line-bg);cursor:pointer;transition:background .12s}.crypto-tr:last-child{border-bottom:none}.crypto-tr:hover{background:var(--bg-card)}.crypto-tr--fav{background:#f7931a0d}.crypto-tr--fav:hover{background:#f7931a1a}.crypto-td{vertical-align:middle;white-space:nowrap;color:var(--text-primary);padding:8px 12px}.crypto-td--center{text-align:center}.crypto-td--right{text-align:right}.crypto-td--rank{color:var(--text-muted);min-width:32px;font-size:11px}.crypto-td--name{flex-direction:column;gap:2px;min-width:110px;display:flex}.crypto-symbol{font-family:var(--font-display);color:var(--text-primary);letter-spacing:.04em;font-size:13px;font-weight:700}.crypto-name-sub{color:var(--text-muted);letter-spacing:.03em;font-size:10px}.crypto-td--price{color:#f7931a;font-weight:600}.crypto-td--pos{color:var(--accent-cyan)}.crypto-td--neg{color:var(--accent-red)}.crypto-td--pos-soft{color:var(--accent-cyan);opacity:.8}.crypto-td--neg-soft{color:var(--accent-red);opacity:.8}.crypto-td--muted{color:var(--text-secondary)}.crypto-spark-loading{width:110px;color:var(--text-muted);text-align:center;font-size:11px;display:inline-block}@media (width<=640px){.crypto-table{font-size:11px}.crypto-th,.crypto-td{padding:7px 8px}}:root{--bg-root:#0b0f0b;--bg-panel:#121812;--bg-card:#1a2217;--border-bright:#33412c;--accent-cyan:#9df74f;--accent-cyan-dim:#9df74f73;--accent-gold:#d5b23d;--accent-red:#ff6b6b;--accent-red-dim:#ff6b6b73;--text-primary:#ebf7db;--text-secondary:#9cb08f;--text-muted:#6d7d65;--font-display:system-ui, -apple-system, BlinkMacSystemFont, "SF Pro Text", "Segoe UI", sans-serif;--font-mono:"JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--body-bg:radial-gradient(circle at top, #181f14 0, #0b0f0b 58%, #080a08 100%);--header-bg:radial-gradient(circle at top left, #9df74f29, transparent 55%), #101510;--btn-bg:#171f14e6;--btn-border:#9cb08f66;--card-bg:#161e13d1;--card-border:#9cb08f2e;--section-bg:#141b119e;--section-border:#9cb08f29;--section-line-bg:#9cb08f33;--code-bg:#141b11d6;--footer-border:#9cb08f40;--footer-line:#9cb08f1f;--spinner-color:var(--accent-cyan);--theme-toggle-icon:"☀️";--sidebar-surface-start:#151f10f7;--sidebar-surface-end:#0e140cfc;--sidebar-topbar-bg:#10180df2;--sidebar-soft-border:#9cb08f3d;--sidebar-soft-bg:#9cb08f14;--sidebar-soft-bg-hover:#9cb08f24;--sidebar-label:#95ab84;--sidebar-title:#d1e1ba;--sidebar-text:#eaf7d6;--sidebar-text-muted:#a7bb97;--sidebar-chevron:#95ab84;--sidebar-accent-soft:#9df74f29;--sidebar-accent-border:#9df74f66;--sidebar-active-gradient-start:#9df74f4d;--sidebar-active-gradient-end:#9df74f1f;--sidebar-active-line:#9df74ff2;--sidebar-active-text:#f7ffe7;--sidebar-active-subtext:#daf9b6;--page-tab-wrap-bg:#19221494;--page-tab-wrap-border:#9cb08f3d;--page-tab-bg:#222e1b7a;--page-tab-border:#9cb08f47;--page-tab-text:#c6dbb3;--page-tab-text-hover:#f2ffdd;--page-tab-active-bg:linear-gradient(135deg, #9df74f47 0%, #9df74f1f 100%);--page-tab-active-border:#9df74f8f;--page-tab-active-shadow:#9df74f52;--sector-label-text:#dffac0;--sector-label-bg:#9df74f29;--sector-label-border:#9df74f6b}[data-theme=light]{--bg-root:#fbfcfc;--bg-panel:#e0e5e9;--bg-card:#fff;--border-bright:#b2c9c5;--accent-cyan:#1bd488;--accent-cyan-dim:#1bd48866;--accent-gold:#d97706;--accent-red:#dc2626;--accent-red-dim:#dc262666;--text-primary:#055b65;--text-secondary:#45828b;--text-muted:#b2c9c5;--body-bg:#fbfcfc;--header-bg:linear-gradient(to right, #1bd48812, transparent 60%), #fbfcfc;--btn-bg:#fffffff2;--btn-border:#45828b73;--card-bg:#ffffffeb;--card-border:#b2c9c58c;--section-bg:#fbfcfcd9;--section-border:#b2c9c573;--section-line-bg:#b2c9c58c;--code-bg:#e0e5e9;--footer-border:#45828b59;--footer-line:#45828b2e;--spinner-color:var(--accent-cyan);--theme-toggle-icon:"🌙";--sidebar-surface-start:#055b65f7;--sidebar-surface-end:#03444cfa;--sidebar-topbar-bg:#04505af2;--sidebar-soft-border:#b2c9c547;--sidebar-soft-bg:#ffffff14;--sidebar-soft-bg-hover:#ffffff24;--sidebar-label:#b2c9c5;--sidebar-title:#e0f2ef;--sidebar-text:#f0faf8;--sidebar-text-muted:#b2c9c5;--sidebar-chevron:#8ab8b2;--sidebar-accent-soft:#1bd48829;--sidebar-accent-border:#1bd48885;--sidebar-active-gradient-start:#1bd48847;--sidebar-active-gradient-end:#1bd4881a;--sidebar-active-line:#1bd488eb;--sidebar-active-text:#fff;--sidebar-active-subtext:#c8f5e8;--page-tab-wrap-bg:#e0e5e9e0;--page-tab-wrap-border:#b2c9c58c;--page-tab-bg:#fbfcfcf7;--page-tab-border:#b2c9c58c;--page-tab-text:#45828b;--page-tab-text-hover:#055b65;--page-tab-active-bg:linear-gradient(135deg, #1bd48847 0%, #1bd4881f 100%);--page-tab-active-border:#1bd4889e;--page-tab-active-shadow:#1bd48852;--sector-label-text:#055b65;--sector-label-bg:#1bd4881f;--sector-label-border:#1bd4886b}*,:before,:after{box-sizing:border-box}body{background:var(--body-bg);color:var(--text-primary);font-family:var(--font-display);margin:0;padding:0;transition:background .3s,color .3s}code{font-family:var(--font-mono)}button{font-family:inherit}.main{flex:1;width:100%;max-width:1600px;margin:0 auto;padding:12px 15px}.loading-wrap{justify-content:center;align-items:center;min-height:60vh;display:flex}.loading-box{text-align:center;border:1px solid var(--border-bright);background:var(--bg-panel);padding:48px}.spinner{color:var(--accent-cyan);text-shadow:0 0 30px var(--accent-cyan);margin-bottom:16px;font-size:48px;display:block}.loading-text{font-family:var(--font-display);color:var(--accent-cyan);letter-spacing:.08em;margin-bottom:8px;font-size:13px}.loading-sub-text{color:var(--text-secondary);letter-spacing:.03em;font-size:13px}.error-wrap{justify-content:center;align-items:center;min-height:60vh;display:flex}.error-box{text-align:center;border:1px solid var(--accent-red-dim);background:#a0002a14;max-width:500px;padding:48px}.error-icon{color:var(--accent-red);margin-bottom:12px;font-size:40px}.error-title{font-family:var(--font-display);letter-spacing:.06em;color:var(--text-primary);margin-bottom:10px;font-size:13px}.error-msg{color:var(--accent-red);margin-bottom:18px;font-size:13px}.error-hint{color:var(--text-secondary);margin-bottom:18px;font-size:13px}.retry-btn{font-family:var(--font-mono);letter-spacing:.05em;border:1px solid var(--btn-border);background:var(--btn-bg);color:var(--text-primary);cursor:pointer;border-radius:999px;padding:6px 14px;font-size:12px}.page-tabs{border:1px solid var(--page-tab-wrap-border);background:var(--page-tab-wrap-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:14px;flex-wrap:wrap;gap:8px;width:fit-content;margin-bottom:22px;padding:6px;display:flex}.page-tab{cursor:pointer;border:1px solid var(--page-tab-border);background:var(--page-tab-bg);letter-spacing:.05em;color:var(--page-tab-text);border-radius:999px;justify-content:center;align-items:center;padding:7px 15px;font-size:13px;font-weight:600;text-decoration:none;transition:color .18s,background .18s,border-color .18s,transform .18s,box-shadow .18s;display:inline-flex;position:relative}.page-tab:hover{color:var(--page-tab-text-hover);border-color:var(--page-tab-active-border);transform:translateY(-1px)}.page-tab.active{color:var(--page-tab-text-hover);background:var(--page-tab-active-bg);border-color:var(--page-tab-active-border);box-shadow:0 8px 22px -14px var(--page-tab-active-shadow), inset 0 -1px 0 #ffffff47}.page-tab.active:after{content:"";opacity:.45;background:currentColor;border-radius:999px;height:2px;position:absolute;bottom:2px;left:14px;right:14px}.tabs-row{align-items:center;gap:8px;margin-bottom:16px;display:flex}.tab{border:1px solid var(--btn-border);background:var(--btn-bg);color:var(--text-secondary);font-family:var(--font-mono);letter-spacing:.04em;cursor:pointer;border-radius:999px;padding:5px 12px;font-size:12px}.tab.active{border-color:var(--accent-cyan);color:var(--text-primary);background:var(--card-bg)}.spacer{flex:1}.meta{align-items:baseline;gap:8px;display:flex}.meta-label{letter-spacing:.05em;color:var(--text-muted);font-size:11px}.meta-value{font-family:var(--font-mono);color:var(--text-primary);font-size:13px}.state-box{letter-spacing:.04em;color:var(--text-secondary);margin-top:16px;font-size:13px}.error-box{color:var(--accent-red);margin-top:16px;font-size:13px}.header{border-bottom:1px solid var(--section-border);background:var(--header-bg);z-index:10;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);justify-content:space-between;align-items:center;gap:24px;padding:14px 28px;transition:background .3s;display:flex;position:sticky;top:0}.header-left{flex-shrink:0;align-items:center;gap:12px;display:flex}.brand-pulse{background:var(--accent-cyan);border-radius:999px;flex-shrink:0;width:8px;height:8px;animation:2.5s ease-in-out infinite pulse-glow;box-shadow:0 0 10px #9df74fcc,0 0 20px #9df74f52}@keyframes pulse-glow{0%,to{box-shadow:0 0 10px #9df74fcc,0 0 20px #9df74f52}50%{box-shadow:0 0 16px #9df74f,0 0 32px #9df74f85}}.title{font-family:var(--font-display);letter-spacing:.12em;color:var(--text-primary);text-transform:uppercase;font-size:13px;font-weight:700}.subtitle{letter-spacing:.08em;text-transform:uppercase;color:var(--accent-cyan);opacity:.8;margin-top:2px;font-size:10px;font-weight:500}.header-center{flex-direction:column;flex:1;align-items:center;gap:2px;display:flex}.meta-label{letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);font-size:10px;font-weight:600}.meta-value{font-family:var(--font-mono);letter-spacing:.04em;color:var(--text-primary);font-size:13px}.status-label{letter-spacing:.05em;color:var(--text-muted);font-size:10px}.status-value{font-family:var(--font-mono);letter-spacing:.05em;color:var(--text-primary);font-size:13px}.header-right{flex-shrink:0;align-items:center;display:flex}.header-actions{align-items:center;gap:6px;display:flex}.header-username{font-family:var(--font-mono);color:var(--text-secondary);letter-spacing:.06em;padding:0 4px;font-size:12px}.meta-row{align-items:baseline;gap:8px;display:flex}.refresh-btn{font-family:var(--font-mono);letter-spacing:.05em;border:1px solid var(--btn-border);background:var(--btn-bg);color:var(--text-secondary);cursor:pointer;white-space:nowrap;border-radius:6px;padding:5px 13px;font-size:11px;font-weight:500;transition:background .15s,color .15s,border-color .15s}.refresh-btn:hover{color:var(--text-primary);border-color:var(--accent-cyan);background:#9df74f1a}.refresh-btn--accent{border-color:var(--accent-cyan);color:var(--accent-cyan)}.refresh-btn--accent:hover{background:#9df74f24}.theme-toggle-btn{letter-spacing:0;padding:5px 10px;font-size:13px}.footer{border-top:1px solid var(--footer-border);margin-top:auto;padding:22px 24px}.footer-line{background:var(--footer-line);height:1px;margin-bottom:14px}.footer-inner{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;display:flex}.footer-mid{color:var(--text-secondary);font-size:12px}.code{font-family:var(--font-mono);background:var(--code-bg);border-radius:3px;padding:2px 4px;font-size:13px}.index-detail-page{flex:1;width:100%;max-width:1600px;margin:0 auto;padding:32px 24px}.index-detail-page-header{align-items:center;gap:16px;margin-bottom:24px;display:flex}.index-detail-back-btn{font-family:var(--font-mono);letter-spacing:.04em;border:1px solid var(--btn-border);background:var(--btn-bg);color:var(--text-primary);cursor:pointer;border-radius:999px;padding:6px 14px;font-size:12px}.index-detail-title{color:var(--text-primary);margin:0;font-size:28px;font-weight:600}.index-detail-subtitle{color:var(--text-secondary);font-size:13px}.index-detail-first-row{align-items:stretch;gap:24px;margin-bottom:24px;display:flex}.index-detail-section{background:radial-gradient(circle at 100% 0,#9df74f1c,#0000 45%),linear-gradient(165deg,#182113d6,#0e140ce6);border:1px solid #94a3b840;border-radius:14px;min-width:0;padding:14px;position:relative;overflow:hidden;box-shadow:0 14px 34px #05080461}.index-detail-section:before{content:"";opacity:.85;background:linear-gradient(90deg,#9df74f,#7fe246,#d5b23d);height:2px;position:absolute;top:0;left:0;right:0}.index-detail-section--details{flex:4}.index-detail-section--chart{flex:6}.index-detail-section-header{border-bottom:1px solid #94a3b833;justify-content:space-between;align-items:center;margin-bottom:12px;padding-bottom:10px;display:flex}.index-detail-section-title{letter-spacing:.08em;text-transform:uppercase;color:var(--text-primary);font-size:13px;font-weight:700}.index-detail-loading-badge{letter-spacing:.04em;color:var(--accent-cyan);background:var(--accent-cyan-dim);border-radius:999px;padding:3px 8px;font-size:11px}.index-detail-error-badge{letter-spacing:.04em;color:var(--accent-red);background:var(--accent-red-dim);border-radius:999px;padding:3px 8px;font-size:11px}.index-detail-detail-grid{grid-template-columns:1fr 1fr;gap:9px;display:grid}.index-detail-detail-row{background:linear-gradient(#0f172a8c,#0f172a4d);border:1px solid #94a3b833;border-radius:10px;justify-content:space-between;align-items:center;min-height:40px;padding:9px 11px;transition:border-color .18s,transform .18s,background .18s;display:flex}.index-detail-detail-row:hover{background:linear-gradient(#222e1b9e,#1821136b);border-color:#9df74f73;transform:translateY(-1px)}.index-detail-detail-label{letter-spacing:.03em;color:var(--text-secondary);font-size:12px}.index-detail-detail-value{font-family:var(--font-mono);color:var(--text-primary);text-align:right;margin-left:12px;font-size:14px;font-weight:600}.index-detail-range-buttons{flex-wrap:wrap;justify-content:flex-end;gap:8px;display:flex}.index-detail-range-btn{font-family:var(--font-mono);letter-spacing:.04em;color:var(--text-primary);cursor:pointer;background:#0f172ab8;border:1px solid #94a3b873;border-radius:999px;padding:5px 12px;font-size:11px;font-weight:600;transition:all .2s}.index-detail-range-btn:hover{background:#222e1bdb;border-color:#9df74fa6;transform:translateY(-1px)}.index-detail-range-btn.active{color:#f7ffe8;background:linear-gradient(135deg,#5e9e2f85,#4570267a);border-color:#9df74fe0;box-shadow:inset 0 0 0 1px #9df74f42}.index-detail-realtime-stats{grid-template-columns:repeat(auto-fit,minmax(128px,1fr));gap:8px;margin-bottom:12px;display:grid}.index-detail-realtime-stat{background:linear-gradient(#0f172a85,#0f172a47);border:1px solid #94a3b83d;border-radius:10px;padding:8px 10px}.index-detail-realtime-label{letter-spacing:.05em;color:var(--text-secondary);margin-bottom:4px;font-size:11px}.index-detail-realtime-value{font-family:var(--font-mono);color:var(--text-primary);font-size:14px;font-weight:700}[data-theme=light] .index-detail-section{background:radial-gradient(circle at 100% 0,#1bd4881a,#0000 45%),linear-gradient(160deg,#fffffff2,#f0f8f6f5);border-color:#b2c9c573;box-shadow:0 10px 26px #055b6514}[data-theme=light] .index-detail-section-header{border-bottom-color:#b2c9c566}[data-theme=light] .index-detail-detail-row{background:linear-gradient(#fbfcfcf7,#f0f8f6e6);border-color:#b2c9c561}[data-theme=light] .index-detail-detail-row:hover{background:linear-gradient(#f0fcf7f7,#e6faf2eb);border-color:#1bd48873}[data-theme=light] .index-detail-range-btn{background:#ffffffeb;border-color:#b2c9c580}[data-theme=light] .index-detail-range-btn:hover{background:#f0fcf7f2;border-color:#1bd4888c}[data-theme=light] .index-detail-range-btn.active{color:#fff;border-color:#1bd488d1}[data-theme=light] .index-detail-realtime-stat{background:linear-gradient(#fcfefef5,#f3faf8e6);border-color:#b2c9c55c}.index-detail-tickers-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px;display:grid}.index-detail-tickers-list{flex-wrap:wrap;gap:10px;display:flex}.index-detail-tickers-list .favorites-ticker-card{flex:200px;min-width:200px;max-width:300px}.tickers-sector-group{margin-bottom:18px}.tickers-sector-label{font-family:var(--font-mono);letter-spacing:.06em;text-transform:uppercase;color:var(--sector-label-text);border:1px solid var(--sector-label-border);border-left:3px solid var(--accent-cyan);background:var(--sector-label-bg);text-shadow:0 1px #0003;border-radius:999px;align-items:center;margin-bottom:10px;padding:4px 10px 4px 9px;font-size:12px;font-weight:700;display:inline-flex}.heat-chart-sector-group{margin-bottom:16px}.heat-chart-sector-label{font-family:var(--font-mono);letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);border-left:2px solid var(--accent-cyan-dim);margin-bottom:6px;padding-left:7px;font-size:10px;font-weight:700}.heat-chart-grid{flex-wrap:wrap;gap:4px;margin-bottom:12px;display:flex}.heat-chart-tile{cursor:pointer;border-radius:6px;flex-direction:column;flex:80px;justify-content:center;align-items:center;gap:3px;min-width:72px;max-width:110px;height:68px;padding:4px;transition:opacity .15s,transform .15s;display:flex;overflow:hidden}.heat-chart-tile:hover{opacity:.82;transform:scale(1.04)}.heat-chart-tile-symbol{font-family:var(--font-mono);letter-spacing:.04em;white-space:nowrap;text-overflow:ellipsis;text-align:center;max-width:100%;font-size:10px;font-weight:700;overflow:hidden}.heat-chart-tile-change{font-family:var(--font-mono);font-size:12px;font-weight:600}.heat-chart-state{font-family:var(--font-mono);color:var(--text-secondary);letter-spacing:.04em;text-align:center;padding:24px 0;font-size:12px}.heat-chart-state--error{color:var(--accent-red)}.heat-chart-legend{align-items:center;gap:8px;margin-top:4px;display:flex}.heat-chart-legend-label{font-family:var(--font-mono);color:var(--text-muted);white-space:nowrap;font-size:10px}.heat-chart-legend-track{border-radius:3px;flex:1;gap:1px;height:6px;display:flex;overflow:hidden}.heat-chart-legend-segment{flex:1;height:100%}.ticker-card{background:var(--card-bg);border:1px solid var(--card-border);cursor:pointer;border-radius:12px;padding:16px;transition:background .2s,border-color .2s,transform .15s}.ticker-card:hover{background:var(--btn-bg);border-color:var(--accent-cyan-dim);transform:translateY(-1px)}.ticker-card-header{justify-content:space-between;align-items:center;gap:8px;margin-bottom:10px;display:flex}.ticker-card-identity{flex:1;align-items:center;gap:10px;min-width:0;display:flex}.ticker-card-logo{color:#fff;letter-spacing:.02em;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:15px;font-weight:700;display:flex}.ticker-logo-img{object-fit:contain;background:#fff;border-radius:8px;flex-shrink:0;width:36px;height:36px}.ticker-card-company{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:600;overflow:hidden}.ticker-card-spark{width:100%;margin-top:10px}.ticker-card-spark>div{margin-top:0!important}.ticker-card-stats{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:4px;display:flex}.ticker-card-stat-row{justify-content:space-between;align-items:center;display:flex}.ticker-card-stat-label{color:var(--text-secondary);font-size:12px}.ticker-card-stat-price{font-family:var(--font-mono);color:var(--text-primary);font-size:15px;font-weight:600}.ticker-card-stat-return{font-family:var(--font-mono);font-size:13px;font-weight:600}.ticker-card-stat-return.positive{color:#22c55e}.ticker-card-stat-return.negative{color:#f97373}.index-detail-modal-content{padding:24px}.index-detail-modal-header{margin-bottom:16px}.index-detail-modal-title{color:var(--text-primary);margin:0;font-size:17px;font-weight:600}.index-detail-modal-subtitle{color:var(--text-secondary);font-size:13px}.index-detail-modal-range-buttons{gap:8px;margin-bottom:16px;display:flex}@media (width<=768px){.index-detail-page{padding:16px 12px}.index-detail-page-header{flex-direction:column;align-items:flex-start;gap:8px}.index-detail-title{font-size:23px}.index-detail-subtitle{font-size:15px}.index-detail-first-row{flex-direction:column;gap:16px}.index-detail-section{padding:16px}.index-detail-detail-grid{grid-template-columns:1fr}.index-detail-tickers-grid,.favorites-ticker-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:10px}.ticker-card{padding:12px}.ticker-card-logo{width:30px;height:30px;font-size:13px}.ticker-card-company{font-size:13px}.ticker-card-stat-label{font-size:11px}.ticker-card-stat-price{font-size:13px}.ticker-card-stat-return{font-size:11px}}@media (width<=480px){.index-detail-tickers-grid,.favorites-ticker-grid{grid-template-columns:1fr}}.favorites-section{margin-bottom:0}.favorites-ticker-list{flex-wrap:wrap;gap:10px;display:flex}.favorites-ticker-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:10px;display:grid}.favorites-section .ticker-card{border-radius:8px;padding:11px}.favorites-section .ticker-card-header{gap:5px;margin-bottom:7px}.favorites-section .ticker-card-identity{gap:7px}.favorites-section .ticker-card-logo{width:20px;height:20px;font-size:8px}.favorites-section .ticker-logo-img{width:20px;height:20px}.favorites-section .ticker-card-company{font-size:11px}.favorites-section .ticker-card-stats{gap:3px}.favorites-section .ticker-card-stat-price{font-size:10px}.favorites-section .ticker-card-stat-return{font-size:9px}.favorites-section .ticker-card-spark{margin-top:7px}.favorites-empty{color:var(--text-muted);padding:4px 0 8px;font-size:13px}.favorites-ticker-card{background:var(--bg-card);border:1px solid var(--card-border);cursor:pointer;border-radius:8px;flex:200px;align-items:center;gap:10px;min-width:200px;max-width:280px;padding:10px 14px;transition:border-color .15s,background .15s;display:flex}.favorites-ticker-card:hover{border-color:var(--accent-cyan-dim);background:#9df74f0a}.favorites-ticker-card-info{flex:1;min-width:0}.favorites-ticker-card-symbol{color:var(--text-primary);font-size:13px;font-weight:600;font-family:var(--font-mono);display:block}.favorites-ticker-card-name{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;font-size:11px;display:block;overflow:hidden}.favorites-ticker-card-price{text-align:right;flex-shrink:0}.favorites-ticker-card-price-value{color:var(--text-primary);font-size:13px;font-weight:500;display:block}.favorites-ticker-card-change{font-size:12px;display:block}.favorites-ticker-card-change.positive{color:#22c55e}.favorites-ticker-card-change.negative{color:var(--accent-red)}.ticker-search-wrapper{margin-bottom:16px;position:relative}.ticker-search-input{background:var(--bg-card);border:1px solid var(--section-border);width:100%;color:var(--text-primary);font-family:var(--font-display);box-sizing:border-box;border-radius:8px;outline:none;padding:10px 14px 10px 36px;font-size:14px;transition:border-color .2s,box-shadow .2s}.ticker-search-input::placeholder{color:var(--text-muted)}.ticker-search-input:focus{border-color:var(--accent-cyan-dim);box-shadow:0 0 0 3px #9df74f1a}.ticker-search-icon{color:var(--text-muted);pointer-events:none;font-size:15px;line-height:1;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.ticker-search-clear{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:2px 4px;font-size:16px;line-height:1;position:absolute;top:50%;right:10px;transform:translateY(-50%)}.ticker-search-clear:hover{color:var(--text-primary)}.ticker-search-dropdown{background:var(--bg-panel);border:1px solid var(--section-border);z-index:200;border-radius:8px;max-height:380px;position:absolute;top:calc(100% + 4px);left:0;right:0;overflow-y:auto;box-shadow:0 8px 24px #00000080}.ticker-search-loading,.ticker-search-empty{color:var(--text-muted);text-align:center;padding:14px 16px;font-size:13px}.ticker-search-item{border-bottom:1px solid var(--section-line-bg);align-items:center;display:flex}.ticker-search-item:last-child{border-bottom:none}.ticker-search-item-nav{cursor:pointer;flex:1;align-items:center;gap:10px;min-width:0;padding:9px 14px;transition:background .15s;display:flex}.ticker-search-item-nav:hover{background:#9df74f0f}.ticker-search-item>button{flex-shrink:0;padding:8px 12px!important}.ticker-search-item-info{flex:1;min-width:0}.ticker-search-item-symbol{color:var(--text-primary);font-size:13px;font-weight:600;font-family:var(--font-mono)}.ticker-search-item-name{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;font-size:12px;overflow:hidden}.ticker-search-item-price{text-align:right;flex-shrink:0}.ticker-search-item-price-value{color:var(--text-primary);font-size:13px;font-weight:500;display:block}.ticker-search-item-change{font-size:12px;display:block}.ticker-search-item-change.positive{color:#22c55e}.ticker-search-item-change.negative{color:var(--accent-red)}.ticker-detail-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px;display:grid}.ticker-detail-chart-section{grid-column:1/-1}.ticker-detail-hero-copy{flex:1;min-width:0}.ticker-detail-hero-headline{flex-wrap:wrap;align-items:baseline;gap:12px;display:flex}.ticker-detail-hero-symbol{font-family:var(--font-mono);color:#22d3ee;font-size:14px}.ticker-detail-hero-chip{color:#6b7280;font-size:12px;font-family:var(--font-mono)}.ticker-detail-hero-chip--type{background:#374151;border-radius:4px;padding:1px 6px}.ticker-detail-price-hero{text-align:right;flex-shrink:0}.ticker-detail-price-hero__value{font-family:var(--font-mono);color:#e5e7eb;font-size:28px;font-weight:700}.ticker-detail-price-hero__delta{font-family:var(--font-mono);font-size:14px}.ticker-detail-card{border:1px solid var(--section-border);background:var(--section-bg);border-radius:8px;padding:18px 20px}.ticker-detail-card-full{grid-column:1/-1}.ticker-detail-card-header{border-bottom:1px solid var(--section-line-bg);justify-content:space-between;align-items:center;margin-bottom:14px;padding-bottom:10px;display:flex}.ticker-detail-card-title{letter-spacing:.06em;color:#a613a5;font-size:16px;font-weight:bolder;font-family:var(--font-display);text-transform:uppercase}.ticker-detail-rows{flex-direction:column;gap:6px;display:flex}.ticker-detail-row{justify-content:space-between;align-items:center;min-height:22px;display:flex}.ticker-detail-label{color:var(--text-muted);flex-shrink:0;margin-right:8px;font-size:12px}.ticker-detail-value{font-family:var(--font-mono);color:var(--text-primary);text-align:right;font-size:13px}.ticker-detail-summary{color:#9ca3af;border-top:1px solid #94a3b814;margin:14px 0 0;padding-top:12px;font-size:13px;line-height:1.7}.ticker-detail-52w-bar-wrap{align-items:center;gap:8px;display:flex}.ticker-detail-52w-edge{font-family:var(--font-mono);color:#6b7280;white-space:nowrap;font-size:12px}.ticker-detail-52w-bar{background:#94a3b826;border-radius:999px;flex:1;height:4px;position:relative}.ticker-detail-52w-fill{background:#9df74f;border-radius:999px;width:10px;height:10px;position:absolute;top:-3px;transform:translate(-50%);box-shadow:0 0 6px #9df74fb3}.ticker-ownership-wrap{align-items:center;gap:14px;margin:2px 0 10px;padding:4px 0;display:flex}.ticker-ownership-pie{border:1px solid #94a3b840;border-radius:50%;flex-shrink:0;width:74px;height:74px;box-shadow:inset 0 0 0 1px #02061747}.ticker-ownership-legend{grid-template-columns:1fr;gap:4px;width:100%;display:grid}.ticker-ownership-legend-item{grid-template-columns:auto 1fr auto;align-items:center;gap:8px;min-height:18px;display:grid}.ticker-ownership-legend-dot{border-radius:50%;width:9px;height:9px}.ticker-ownership-legend-label{color:var(--text-secondary);font-size:11px}.ticker-ownership-legend-value{font-family:var(--font-mono);color:var(--text-primary);font-size:11px}.ticker-tooltip-wrap{vertical-align:middle;align-items:center;margin-left:4px;display:inline-flex;position:relative}.ticker-tooltip-icon{color:#6b7280;cursor:help;width:13px;height:13px;font-size:9px;font-weight:700;font-family:var(--font-display);background:#94a3b81f;border:1px solid #94a3b847;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;line-height:1;transition:background .15s,border-color .15s,color .15s;display:inline-flex}.ticker-tooltip-icon:hover{color:#9df74f;background:#9df74f26;border-color:#9df74f66}.ticker-tooltip-box{color:#d1d5db;z-index:200;pointer-events:none;white-space:normal;min-width:200px;max-width:270px;font-size:12px;line-height:1.55;font-family:var(--font-display);background:#0f172a;border:1px solid #94a3b840;border-radius:6px;padding:8px 10px;display:none;position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%);box-shadow:0 4px 20px #0009}.ticker-tooltip-wrap:hover .ticker-tooltip-box{display:block}.ticker-news-list{flex-direction:column;gap:0;display:flex}.ticker-news-item{border-bottom:1px solid #94a3b814;border-radius:4px;flex-direction:column;gap:4px;padding:12px 8px;text-decoration:none;transition:background .15s;display:flex}.ticker-news-item:last-child{border-bottom:none}.ticker-news-item:hover{background:#9df74f0d}.ticker-news-title{color:#e5e7eb;font-size:14px;line-height:1.5;font-family:var(--font-display)}.ticker-news-item:hover .ticker-news-title{color:#9df74f}.ticker-news-summary{color:#9ca3af;-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-top:4px;font-size:12px;line-height:1.5;display:-webkit-box;overflow:hidden}.ticker-news-meta{align-items:center;gap:10px;display:flex}.ticker-news-publisher{font-size:11px;font-family:var(--font-mono);color:#9df74f;text-transform:uppercase;letter-spacing:.04em}.ticker-news-time{font-size:11px;font-family:var(--font-mono);color:#6b7280}@media (width<=768px){.ticker-detail-grid{grid-template-columns:1fr}.ticker-ownership-wrap{align-items:flex-start}.ticker-ownership-pie{width:64px;height:64px}}.app-body{flex:1;align-items:flex-start;min-height:0;display:flex}.app-content{flex-direction:column;flex:1;min-width:0;display:flex}.bottom-nav,.mobile-markets-sheet{display:none}.tsb{background:linear-gradient(180deg, var(--sidebar-surface-start) 0%, var(--sidebar-surface-end) 100%), var(--bg-panel);border-right:1px solid var(--section-border);flex-shrink:0;width:272px;max-height:calc(100vh - 72px);transition:width .22s,box-shadow .22s;position:sticky;top:72px;overflow-y:auto;box-shadow:inset -1px 0 #94a3b814}.tsb--collapsed{width:54px}.tsb-navlink-row{background:var(--sidebar-topbar-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:1;align-items:center;gap:6px;padding:10px 8px 8px;display:flex;position:sticky;top:0}.tsb-navlink-row .tsb-navlink{flex:1;width:auto;margin:0}.tsb-navlink-row .tsb-toggle{flex-shrink:0}.tsb-toggle{background:var(--sidebar-soft-bg);border:1px solid var(--sidebar-soft-border);width:28px;height:28px;color:var(--sidebar-text);cursor:pointer;border-radius:8px;justify-content:center;align-items:center;padding:0;font-size:13px;line-height:1;transition:color .15s,border-color .15s,background .15s,transform .15s;display:inline-flex}.tsb-toggle:hover{color:var(--sidebar-active-text);border-color:var(--sidebar-accent-border);background:var(--sidebar-accent-soft);transform:translateY(-1px)}.tsb-navlink{background:var(--sidebar-soft-bg);border:1px solid var(--sidebar-soft-border);width:calc(100% - 16px);color:var(--sidebar-text);cursor:pointer;text-align:left;letter-spacing:.03em;border-radius:10px;align-items:center;gap:10px;margin:10px 8px 8px;padding:10px 11px;font-size:12px;font-weight:600;transition:background .15s,color .15s,border-color .15s,box-shadow .15s;display:flex}.tsb-navlink:hover{background:var(--sidebar-accent-soft);border-color:var(--sidebar-accent-border);color:var(--sidebar-active-text)}.tsb-navlink--active{color:var(--sidebar-active-text);background:linear-gradient(90deg, var(--sidebar-active-gradient-start) 0%, var(--sidebar-active-gradient-end) 100%);border-color:var(--sidebar-accent-border);box-shadow:inset 2px 0 0 var(--sidebar-active-line)}.tsb-navlink-icon{text-align:center;opacity:.95;flex-shrink:0;width:20px;font-size:16px;line-height:1}.tsb--collapsed .tsb-navlink{justify-content:center;width:38px;margin:0;padding:9px 0}.tsb--collapsed .tsb-navlink-row{flex-direction:column;gap:6px;padding:10px 6px 8px}.tsb-navlink-label{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.tsb-groups{padding:0 0 14px}.tsb-divider{background:linear-gradient(90deg,#0000 0%,#94a3b829 18% 82%,#0000 100%);height:1px;margin:6px 10px 0}.tsb-section-label{letter-spacing:.11em;color:var(--sidebar-label);text-transform:uppercase;padding:12px 14px 8px;font-size:10px;font-weight:700}.tsb-group{margin-bottom:2px}.tsb-group-header{width:calc(100% - 10px);color:var(--sidebar-text-muted);cursor:pointer;text-align:left;letter-spacing:.06em;text-transform:uppercase;background:0 0;border:1px solid #0000;border-radius:8px;align-items:center;gap:9px;margin:0 5px;padding:8px 10px;font-size:11px;font-weight:600;transition:color .15s,background .15s,border-color .15s;display:flex}.tsb-group-header:hover{color:var(--sidebar-active-text);background:var(--sidebar-soft-bg-hover);border-color:var(--sidebar-soft-border)}.tsb-group-icon{flex-shrink:0;font-size:12px;line-height:1}.tsb-group-label{white-space:nowrap;text-overflow:ellipsis;flex:1;overflow:hidden}.tsb-group-chevron{color:var(--sidebar-chevron);flex-shrink:0;font-size:12px}.tsb-item-list{margin:0;padding:2px 5px 4px;list-style:none}.tsb-item{width:100%;color:var(--sidebar-text-muted);cursor:pointer;text-align:left;background:0 0;border:1px solid #0000;border-radius:8px;align-items:flex-start;gap:8px;padding:7px 10px 7px 28px;font-size:12px;transition:color .15s,background .15s,border-color .15s,transform .15s;display:flex}.tsb-item:hover{color:var(--sidebar-active-text);background:var(--sidebar-soft-bg-hover);border-color:var(--sidebar-soft-border);transform:translate(1px)}.tsb-item--active{color:var(--sidebar-active-text);background:linear-gradient(90deg, var(--sidebar-active-gradient-start) 0%, var(--sidebar-active-gradient-end) 100%);border-color:var(--sidebar-accent-border);box-shadow:inset 2px 0 0 var(--sidebar-active-line)}.tsb-item-icon{text-align:center;flex-shrink:0;width:16px;margin-top:2px;font-size:13px;line-height:1}.tsb-item-text{flex-direction:column;flex:1;gap:1px;min-width:0;display:flex}.tsb-item-name{letter-spacing:.02em;white-space:nowrap;text-overflow:ellipsis;font-size:12px;font-weight:600;overflow:hidden}.tsb-item-symbol{font-family:var(--font-mono);color:var(--sidebar-chevron);letter-spacing:.03em;white-space:nowrap;text-overflow:ellipsis;font-size:10px;overflow:hidden}.tsb-item--active .tsb-item-symbol{color:var(--sidebar-active-subtext)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}input[type=email]:focus,input[type=password]:focus,input[type=text]:focus{background:#9df74f14!important;border-color:#9df74f80!important;box-shadow:0 0 20px #9df74f26!important}button[type=submit]:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 24px #9df74f59!important}button[type=submit]:active:not(:disabled){transform:translateY(0)}button[type=submit]:disabled{opacity:.6;cursor:not-allowed}button[style*=absolute][style*="top: 16px"]{transition:all .25s}button[style*=absolute][style*="top: 16px"]:hover{color:var(--accent-cyan)!important;background:#9df74f33!important}@media (width<=768px){.tsb{width:54px}.tsb:not(.tsb--collapsed){width:250px}}@media (width<=640px){.main{padding:20px 16px}.header{align-items:flex-start;gap:12px;padding:12px 16px}.header-center{display:none}.header-left{flex:1;min-width:0}.header-right{width:auto}.header-actions{flex-wrap:wrap;justify-content:flex-end;gap:4px}.header-username{display:none}.refresh-btn{min-height:40px;padding:8px 10px}.theme-toggle-btn{min-width:40px}.page-tabs{width:100%}.page-tab{text-align:center;flex:1 1 0;min-height:42px;padding:9px 12px}.footer{padding:22px 16px calc(96px + env(safe-area-inset-bottom))}.index-detail-page{padding:16px 12px}.index-detail-page-header{gap:10px}.index-detail-back-btn{min-height:42px}.index-detail-section-header{flex-direction:column;align-items:flex-start;gap:8px}.index-detail-range-buttons{justify-content:flex-start}.index-detail-range-btn{min-height:38px;padding:8px 12px}.index-detail-tickers-list .favorites-ticker-card,.favorites-ticker-card{min-width:100%;max-width:none}.ticker-search-input{min-height:44px}.ticker-search-clear{min-width:32px;min-height:32px}.ticker-detail-card{padding:16px}.auth-modal-tabs{flex-wrap:wrap;gap:6px;margin-bottom:20px;padding-bottom:12px}.auth-modal-container{padding:24px!important}.auth-modal-tab{flex:calc(50% - 6px);min-height:42px;padding:10px 12px!important;font-size:13px!important}.auth-modal-tab:last-child{flex-basis:100%}button[type=submit]{min-height:46px}.ticker-detail-hero-headline{gap:8px}.ticker-detail-hero-symbol{font-size:12px}.ticker-detail-hero-chip{font-size:11px}.ticker-detail-price-hero{text-align:left;width:100%}.ticker-detail-price-hero__value{font-size:24px}.ticker-detail-price-hero__delta{font-size:13px}.ticker-detail-row{align-items:flex-start;gap:8px}.ticker-detail-value{overflow-wrap:anywhere;max-width:58%}.ticker-news-title{font-size:13px}.tsb{display:none}.bottom-nav{z-index:40;padding:10px 12px calc(10px + env(safe-area-inset-bottom));border-top:1px solid var(--section-border);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:linear-gradient(#0b0f0bd1,#0b0f0bf5);grid-template-columns:repeat(3,1fr);gap:8px;display:grid;position:fixed;bottom:0;left:0;right:0}[data-theme=light] .bottom-nav{background:linear-gradient(#fbfcfcd1,#fbfcfcf5)}.bottom-nav__item{border:1px solid var(--btn-border);background:var(--btn-bg);min-height:56px;color:var(--text-secondary);cursor:pointer;border-radius:14px;flex-direction:column;justify-content:center;align-items:center;gap:4px;padding:8px 10px;display:flex}.bottom-nav__item.is-active{border-color:var(--accent-cyan);color:var(--text-primary);background:#9df74f1f}.bottom-nav__icon{font-size:16px;line-height:1}.bottom-nav__label{letter-spacing:.04em;text-transform:uppercase;text-align:center;font-size:10px;font-weight:700}.mobile-markets-sheet{z-index:45;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0000008c;justify-content:center;align-items:flex-end;display:flex;position:fixed;inset:0}.mobile-markets-sheet__panel{background:var(--bg-panel);border-top:1px solid var(--section-border);border-radius:22px 22px 0 0;width:100%;max-height:min(78vh,720px);animation:.22s ease-out slideUp;overflow:hidden;box-shadow:0 -16px 40px #00000059}.mobile-markets-sheet__handle{background:var(--section-line-bg);border-radius:999px;width:44px;height:5px;margin:10px auto 4px}.mobile-markets-sheet__header{justify-content:space-between;align-items:flex-start;gap:12px;padding:12px 16px 10px;display:flex}.mobile-markets-sheet__title{letter-spacing:.08em;text-transform:uppercase;color:var(--text-primary);font-size:13px;font-weight:700}.mobile-markets-sheet__subtitle{color:var(--text-secondary);margin-top:4px;font-size:12px}.mobile-markets-sheet__close{border:1px solid var(--btn-border);background:var(--btn-bg);min-height:40px;color:var(--text-primary);border-radius:999px;padding:8px 12px}.mobile-markets-sheet__search-wrap{padding:0 16px 12px;position:relative}.mobile-markets-sheet__search-icon{color:var(--text-muted);position:absolute;top:50%;left:28px;transform:translateY(calc(-50% - 6px))}.mobile-markets-sheet__search{border:1px solid var(--section-border);background:var(--card-bg);width:100%;min-height:46px;color:var(--text-primary);border-radius:12px;padding:12px 14px 12px 38px;font-size:14px}.mobile-markets-sheet__content{max-height:calc(min(78vh,720px) - 126px);padding:0 16px calc(84px + env(safe-area-inset-bottom));overflow-y:auto}.mobile-markets-sheet__group{margin-bottom:16px}.mobile-markets-sheet__group-title{letter-spacing:.08em;text-transform:uppercase;color:var(--text-secondary);align-items:center;gap:8px;margin-bottom:8px;font-size:11px;font-weight:700;display:flex}.mobile-markets-sheet__group-grid{grid-template-columns:1fr;gap:8px;display:grid}.mobile-markets-sheet__item{border:1px solid var(--card-border);background:var(--card-bg);width:100%;min-height:52px;color:var(--text-primary);text-align:left;border-radius:12px;align-items:center;gap:10px;padding:10px 12px;display:flex}.mobile-markets-sheet__item.is-active{border-color:var(--accent-cyan);background:#9df74f1f}.mobile-markets-sheet__item-extra{font-size:16px;line-height:1}.mobile-markets-sheet__item-text{flex-direction:column;min-width:0;display:flex}.mobile-markets-sheet__item-name{white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.mobile-markets-sheet__item-symbol{font-family:var(--font-mono);color:var(--text-secondary);margin-top:2px;font-size:10px}.mobile-markets-sheet__empty{color:var(--text-secondary);padding:12px 0;font-size:13px}}
