*{margin:0;padding:0;box-sizing:border-box}:root{--bg:#121212;--card:#171717;--border:#292929;--text:#e2e8f0;--muted:#a8a3a3;--green:#10b981;--red:#ef4444;--blue:#3b82f6;--yellow:#f59e0b;--sidebar-w:220px}@keyframes livePulseAnim{0%,100%{opacity:1}50%{opacity:0.5}}body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;background:var(--bg);color:var(--text);min-height:100vh;display:flex}a{color:var(--blue);text-decoration:none}.sidebar{width:var(--sidebar-w);min-height:100vh;background:var(--card);border-right:1px solid var(--border);display:flex;flex-direction:column;position:fixed;top:0;left:0;z-index:50;transition:transform .2s}.sidebar-logo{padding:20px 20px 24px;cursor:pointer}.sidebar-logo svg{display:block}.sidebar-section{padding:0 12px;margin-bottom:24px}.sidebar-label{font-size:0.65rem;font-weight:600;text-transform:uppercase;letter-spacing:0.08em;color:var(--muted);padding:0 8px;margin-bottom:8px}.sidebar-nav{list-style:none}.sidebar-nav li a{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:8px;color:var(--muted);font-size:0.88rem;font-weight:500;transition:all .15s;cursor:pointer;text-decoration:none}.sidebar-nav li a:hover{color:var(--text);background:rgba(255,255,255,0.04)}.sidebar-nav li a.active{color:var(--text);background:rgba(255,255,255,0.07)}.sidebar-nav li a .nav-icon{width:20px;text-align:center;flex-shrink:0;display:flex;align-items:center;justify-content:center}.sidebar-status{margin-top:auto;padding:16px 20px;border-top:1px solid var(--border)}.sidebar-status .status-label{font-size:0.65rem;font-weight:600;text-transform:uppercase;letter-spacing:0.08em;color:var(--muted);margin-bottom:8px}.sidebar-status .status-item{display:flex;align-items:center;gap:8px;font-size:0.85rem;font-weight:500}.sidebar-status .status-dot{width:8px;height:8px;border-radius:50%;background:var(--muted)}.sidebar-status .status-dot.closed{background:var(--muted)}.sidebar-status .status-dot.open{background:var(--green)}.sidebar-status .status-dot.live{background:var(--green);animation:livePulse 2s ease-in-out infinite}@keyframes livePulse{0%,100%{box-shadow:0 0 0 0 rgba(16,185,129,.5)}50%{box-shadow:0 0 0 6px rgba(16,185,129,0)}}@keyframes priceFlash{0%{background:rgba(16,185,129,.25)}100%{background:transparent}}.stock-card.flash-up{animation:priceFlash .8s ease-out}@keyframes priceFlashDown{0%{background:rgba(239,68,68,.25)}100%{background:transparent}}.stock-card.flash-down{animation:priceFlashDown .8s ease-out}tr.flash-up td{animation:priceFlash .8s ease-out}tr.flash-down td{animation:priceFlashDown .8s ease-out}.data-toggle{display:inline-flex;border:1px solid var(--border);border-radius:6px;overflow:hidden}.data-toggle button{background:none;border:none;color:var(--muted);padding:6px 12px;font-size:0.82rem;cursor:pointer;transition:all .15s}.data-toggle button.active{background:var(--blue);color:#fff}.data-toggle button:hover:not(.active){color:var(--text)}.sidebar-status .status-updated{font-size:0.75rem;color:var(--muted);margin-top:4px}.sidebar-refresh{padding:12px 20px 20px}.sidebar-refresh button{background:none;border:none;color:var(--muted);font-size:0.85rem;cursor:pointer;display:flex;align-items:center;gap:8px;padding:0;transition:color .15s}.sidebar-refresh button:hover{color:var(--text)}.main{margin-left:var(--sidebar-w);flex:1;min-height:100vh}.topbar{display:flex;align-items:center;padding:12px 28px;gap:16px;border-bottom:1px solid var(--border)}.topbar .sidebar-toggle{background:none;border:1px solid var(--border);color:var(--muted);width:34px;height:34px;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1rem;transition:all .15s;flex-shrink:0}.topbar .sidebar-toggle:hover{color:var(--text);border-color:var(--text)}.topbar .search-bar{flex:1;display:flex;align-items:center;justify-content:center}.topbar .search-trigger{display:flex;align-items:center;gap:10px;background:var(--card);border:1px solid var(--border);border-radius:10px;padding:9px 18px;color:var(--muted);font-size:0.88rem;cursor:pointer;min-width:360px;transition:border-color .15s}.topbar .search-trigger:hover{border-color:var(--blue)}.topbar .search-trigger .search-icon{font-size:0.9rem}.topbar .search-trigger .search-text{flex:1}.topbar .search-trigger kbd{background:var(--bg);border:1px solid var(--border);border-radius:4px;padding:2px 7px;font-size:0.7rem;font-family:inherit;color:var(--muted)}.topbar .settings-btn{background:none;border:none;color:var(--muted);font-size:1.2rem;cursor:pointer;padding:6px;transition:color .15s}.topbar .settings-btn:hover{color:var(--text)}.content{padding:28px}.page-title{font-size:1.6rem;font-weight:700;margin-bottom:4px}.page-subtitle{color:var(--muted);font-size:0.9rem;display:flex;align-items:center;gap:6px;margin-bottom:28px}.section-card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:20px;margin-bottom:20px}.section-header{display:flex;align-items:center;gap:10px;font-size:1.05rem;font-weight:700;cursor:pointer;user-select:none}.section-header .section-icon{font-size:1.1rem}.market-charts{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:20px}.market-chart-card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:20px}.market-chart-card h3{display:flex;align-items:center;gap:8px;font-size:1rem;font-weight:700;margin-bottom:4px}.market-chart-card h3 .mc-icon{font-size:1rem}.market-chart-card .mc-total{font-size:0.85rem;color:var(--muted);margin-bottom:16px}.donut-wrap{display:flex;flex-direction:column;align-items:center;gap:16px;position:relative}.donut-wrap canvas{max-width:200px;max-height:200px;cursor:pointer}.donut-tooltip{display:none;position:absolute;background:var(--card);border:1px solid var(--border);border-radius:8px;padding:8px 12px;font-size:0.78rem;pointer-events:none;z-index:10;white-space:nowrap;box-shadow:0 4px 12px rgba(0,0,0,0.3)}.donut-tooltip .dt-sym{font-weight:700;font-size:0.88rem;margin-bottom:2px}.donut-tooltip .dt-val{color:var(--muted)}.donut-legend{display:grid;grid-template-columns:1fr 1fr;gap:4px 20px;font-size:0.78rem;width:100%}.donut-legend-item{display:flex;align-items:center;gap:6px}.donut-legend-item .dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.donut-legend-item .sym{color:var(--text);font-weight:600}.donut-legend-item .pct{margin-left:auto;color:var(--muted)}.movers-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:20px}.mover-card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:20px}.mover-card h3{display:flex;align-items:center;gap:8px;font-size:1rem;font-weight:700;margin-bottom:16px}.mover-card h3 .mover-icon{font-size:1rem}.mover-row{display:flex;align-items:center;padding:10px 0;border-bottom:1px solid var(--border);gap:10px;cursor:pointer;transition:background .15s}.mover-row:last-child{border-bottom:none}.mover-row:hover{background:rgba(59,130,246,0.05);margin:0 -8px;padding:10px 8px;border-radius:6px}.mover-row .rank{color:var(--muted);font-size:0.8rem;min-width:20px;text-align:center}.mover-row .mover-info{flex:1;min-width:0}.mover-row .mover-sym{font-weight:700;font-size:0.9rem;display:flex;align-items:center;gap:6px}.mover-row .mover-sym .mkt-badge{font-size:0.65rem;font-weight:600;text-transform:uppercase;background:var(--border);color:var(--muted);padding:2px 6px;border-radius:4px}.mover-row .mover-name{font-size:0.75rem;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mover-row .mover-price{text-align:right;font-weight:600;font-size:0.9rem}.mover-row .mover-chg{text-align:right;font-size:0.8rem;font-weight:600}.indices-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;flex-wrap:wrap;gap:8px}.indices-header h2{font-size:1rem;font-weight:700}.idx-period-toggle{display:flex;background:var(--bg);border:1px solid var(--border);border-radius:7px;padding:2px;gap:1px}.idx-period-toggle button{background:none;border:none;color:var(--muted);padding:4px 9px;border-radius:5px;cursor:pointer;font-size:0.68rem;font-weight:600;transition:all .15s}.idx-period-toggle button.active{background:var(--blue);color:#fff}.idx-period-toggle button:hover:not(.active){color:var(--text)}.idx-list{display:flex;flex-direction:column;gap:0}.idx-row{display:flex;align-items:center;gap:14px;padding:9px 0;border-bottom:1px solid var(--border)}.idx-row:last-child{border-bottom:none}.idx-info{min-width:180px;flex-shrink:0}.idx-name-row{display:flex;align-items:center;gap:6px;margin-bottom:1px}.idx-name-row .idx-icon{color:var(--blue);font-size:0.75rem}.idx-name-row .idx-title{font-size:0.82rem;font-weight:700}.idx-name-row .idx-badge{font-size:0.65rem;font-weight:700;padding:1px 6px;border-radius:4px;white-space:nowrap}.idx-name-row .idx-badge.up{background:rgba(16,185,129,0.12);color:var(--green)}.idx-name-row .idx-badge.down{background:rgba(239,68,68,0.12);color:var(--red)}.idx-name-row .idx-badge.neutral{background:rgba(100,116,139,0.12);color:var(--muted)}.idx-details{font-size:0.72rem;line-height:1.4}.idx-details .idx-points{color:var(--text)}.idx-details .idx-points span{font-weight:700}.idx-details .idx-vol{color:var(--text)}.idx-details .idx-vol span{font-weight:700}.idx-spark-area{flex:1;height:38px;min-width:120px}.idx-spark-area canvas{width:100%;height:100%;display:block}
.mobile-header{display:none !important}
.mobile-tab-bar{display:none !important}
.mobile-more-menu{display:none !important}
.sidebar-overlay{display:none !important}
@media(max-width:768px){.idx-row{flex-direction:column;align-items:flex-start}.idx-info{min-width:auto;width:100%}.idx-spark-area{width:100%;height:34px}}.date-nav{display:flex;align-items:center;gap:8px;margin-bottom:24px;flex-wrap:wrap}.date-nav button{background:var(--card);border:1px solid var(--border);color:var(--text);padding:8px 14px;border-radius:8px;cursor:pointer;font-size:0.85rem;transition:all .15s}.date-nav button:hover{border-color:var(--blue);color:var(--blue)}.date-nav button:disabled{opacity:.3;cursor:not-allowed}.date-nav button:disabled:hover{border-color:var(--border);color:var(--text)}.date-nav input[type="date"]{background:var(--card);border:1px solid var(--border);color:var(--text);padding:8px 12px;border-radius:8px;font-size:0.85rem;outline:none;color-scheme:dark}.date-nav input[type="date"]:focus{border-color:var(--blue)}.date-nav .date-range{color:var(--muted);font-size:0.8rem;margin-left:auto}.controls{display:flex;gap:12px;margin-bottom:20px;flex-wrap:wrap;align-items:center}.controls input,.controls select{background:var(--card);border:1px solid var(--border);color:var(--text);padding:10px 14px;border-radius:8px;font-size:0.9rem;outline:none}.controls input:focus,.controls select:focus{border-color:var(--blue)}.controls input{flex:1;min-width:200px}.controls select{min-width:120px}.controls .count{color:var(--muted);font-size:0.85rem;margin-left:auto;white-space:nowrap}.market-tabs{display:flex;gap:4px;background:var(--card);border:1px solid var(--border);border-radius:8px;padding:3px}.market-tabs button{background:none;border:none;color:var(--muted);padding:8px 16px;border-radius:6px;cursor:pointer;font-size:0.85rem;font-weight:500;transition:all .15s}.market-tabs button.active{background:var(--blue);color:#fff}.market-tabs button:hover:not(.active){color:var(--text)}.stock-table{width:100%;border-collapse:collapse;font-size:0.875rem}.stock-table thead{position:sticky;top:0;z-index:1}.stock-table th{background:var(--card);color:var(--muted);font-size:0.7rem;text-transform:uppercase;letter-spacing:0.05em;padding:12px 14px;text-align:left;border-bottom:1px solid var(--border);cursor:pointer;user-select:none;white-space:nowrap}.stock-table th:hover{color:var(--text)}.stock-table td{padding:12px 14px;border-bottom:1px solid var(--border);white-space:nowrap}.stock-table tbody tr{transition:background .15s}.stock-table tbody tr:hover{background:rgba(59,130,246,0.05)}.stock-table .symbol{font-weight:700;color:var(--blue);cursor:pointer}.stock-table .price{font-weight:600}.table-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:10px;background:var(--card)}.up{color:var(--green)}.down{color:var(--red)}.neutral{color:var(--muted)}.query-tool{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:24px;margin-bottom:28px}.query-tool h2{font-size:1.1rem;font-weight:700;margin-bottom:16px}.query-form{display:flex;gap:10px;flex-wrap:wrap;align-items:flex-end}.query-form .field{display:flex;flex-direction:column;gap:4px}.query-form .field label{font-size:0.7rem;color:var(--muted);text-transform:uppercase;letter-spacing:0.05em}.query-form .field input,.query-form .field select{background:var(--bg);border:1px solid var(--border);color:var(--text);padding:9px 12px;border-radius:8px;font-size:0.85rem;outline:none;color-scheme:dark}.query-form .field input:focus,.query-form .field select:focus{border-color:var(--blue)}.query-form .field input[type="text"]{min-width:120px}.query-form button.query-btn{background:var(--blue);border:none;color:#fff;padding:10px 20px;border-radius:8px;cursor:pointer;font-size:0.85rem;font-weight:600;transition:all .15s;align-self:flex-end}.query-form button.query-btn:hover{opacity:.9}.query-results{margin-top:20px;display:none}.query-results.active{display:block}.query-results .qr-header{display:flex;align-items:baseline;gap:12px;margin-bottom:16px;flex-wrap:wrap}.query-results .qr-header h3{font-size:1.1rem;font-weight:700}.query-results .qr-header .qr-range{color:var(--muted);font-size:0.85rem}.qr-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;margin-bottom:20px}.qr-stat{background:var(--bg);border-radius:8px;padding:14px}.qr-stat .label{font-size:0.7rem;color:var(--muted);text-transform:uppercase;letter-spacing:0.05em}.qr-stat .val{font-size:1.15rem;font-weight:700;margin-top:4px}.qr-chart{height:200px;margin-bottom:20px}.stock-page{display:none}.stock-page.active{display:block}.stock-page .back-link{color:var(--muted);font-size:0.85rem;cursor:pointer;margin-bottom:16px;display:inline-block}.stock-page .back-link:hover{color:var(--blue)}.stock-page .sp-header{display:flex;align-items:baseline;gap:16px;margin-bottom:8px;flex-wrap:wrap}.stock-page .sp-header h2{font-size:1.8rem;font-weight:700}.stock-page .sp-header .sp-market{color:var(--muted);font-size:0.85rem;text-transform:capitalize}.stock-page .sp-price-row{display:flex;align-items:baseline;gap:12px;margin-bottom:24px;flex-wrap:wrap}.stock-page .sp-price{font-size:2rem;font-weight:700}.stock-page .sp-change{font-size:1.1rem;font-weight:600}.stock-page .sp-chart{height:320px;margin-bottom:24px}.stock-page .sp-period{display:flex;gap:4px;margin-bottom:16px}.stock-page .sp-period button{background:var(--card);border:1px solid var(--border);color:var(--muted);padding:6px 14px;border-radius:6px;cursor:pointer;font-size:0.8rem;font-weight:600;transition:all .15s}.stock-page .sp-period button.active{background:var(--blue);color:#fff}.stock-page .sp-period button:hover:not(.active){color:var(--text)}.detail-grid{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:12px;margin-bottom:0}.detail-item{background:var(--card);border:1px solid var(--border);border-radius:8px;padding:14px}.detail-item .label{font-size:0.7rem;color:var(--muted);text-transform:uppercase;letter-spacing:0.05em}.detail-item .val{font-size:1.05rem;font-weight:600;margin-top:4px}.sp-tabs{display:flex;gap:0;border-bottom:2px solid var(--border);margin:24px 0 0}.sp-tabs button{background:none;border:none;color:var(--muted);padding:12px 20px;font-size:0.85rem;font-weight:600;cursor:pointer;position:relative;transition:color .15s}.sp-tabs button:hover{color:var(--text)}.sp-tabs button.active{color:var(--blue)}.sp-tabs button.active::after{content:'';position:absolute;bottom:-2px;left:0;right:0;height:2px;background:var(--blue);border-radius:1px}.sp-tabs button .tab-badge{display:inline-block;background:var(--border);color:var(--muted);font-size:0.65rem;padding:2px 6px;border-radius:10px;margin-left:6px;font-weight:700;vertical-align:middle}.sp-tabs button.active .tab-badge{background:rgba(59,130,246,0.15);color:var(--blue)}.sp-tab-content{display:none;padding-top:20px}.sp-tab-content.active{display:block}.chart-container{background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:16px;position:relative}.chart-container canvas{width:100%!important;height:100%!important;cursor:crosshair}.chart-tooltip{display:none;position:absolute;background:var(--card);border:1px solid var(--border);border-radius:8px;padding:8px 12px;font-size:0.8rem;pointer-events:none;z-index:10;white-space:nowrap}.chart-tooltip .tt-date{color:var(--muted);font-size:0.7rem}.chart-tooltip .tt-price{font-weight:700;font-size:1rem;margin-top:2px}.chart-tooltip .tt-change{font-size:0.75rem;margin-top:2px}.jtrader-section{margin-bottom:28px}.jt-date-nav{display:flex;align-items:center;gap:8px;margin-bottom:16px;flex-wrap:wrap}.jt-date-nav input[type="date"]{background:var(--card);border:1px solid var(--border);color:var(--text);padding:7px 12px;border-radius:8px;font-size:0.82rem;outline:none;color-scheme:dark}.jt-date-nav input[type="date"]:focus{border-color:var(--blue)}.jt-date-nav button{background:var(--card);border:1px solid var(--border);color:var(--text);padding:7px 12px;border-radius:8px;cursor:pointer;font-size:0.82rem;transition:all .15s}.jt-date-nav button:hover{border-color:var(--blue);color:var(--blue)}.jt-date-nav .jt-date-label{color:var(--muted);font-size:0.8rem}.order-book{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:24px}.order-book .ob-col h4{font-size:0.8rem;font-weight:700;text-transform:uppercase;letter-spacing:0.05em;padding-bottom:8px;margin-bottom:4px}.order-book .ob-col.buy h4{color:var(--green);border-bottom:2px solid var(--green)}.order-book .ob-col.sell h4{color:var(--red);border-bottom:2px solid var(--red)}.ob-row{display:flex;align-items:center;padding:6px 0;border-bottom:1px solid var(--border);font-size:0.85rem;gap:8px}.ob-row .ob-price{font-weight:600;min-width:80px}.ob-row .ob-qty{color:var(--muted);min-width:70px;text-align:right}.ob-row .ob-val{margin-left:auto;font-size:0.8rem;color:var(--text);opacity:0.7;text-align:right;min-width:90px}.ob-bar{position:relative;padding:6px 8px;border-bottom:1px solid rgba(30,42,58,0.5)}.ob-bar .ob-bg{position:absolute;top:0;bottom:0;left:0;opacity:0.08;border-radius:4px}.ob-col.buy .ob-bar .ob-bg{background:var(--green)}.ob-col.sell .ob-bar .ob-bg{background:var(--red)}.ob-total{display:flex;justify-content:space-between;align-items:center;padding:10px 8px;margin-top:4px;border-top:2px solid var(--border);font-size:0.8rem;font-weight:700}.ob-total .ob-total-label{color:var(--muted);text-transform:uppercase;letter-spacing:0.03em;font-size:0.7rem}.ob-col.buy .ob-total .ob-total-val{color:var(--green)}.ob-col.sell .ob-total .ob-total-val{color:var(--red)}.jt-trades-table .stock-table td,.jt-trades-table .stock-table th{padding:8px 12px;font-size:0.8rem}.jt-empty{color:var(--muted);font-size:0.85rem;padding:16px 0;text-align:center}.ownership-section{margin-bottom:24px}.ownership-section h3{font-size:0.95rem;font-weight:700;margin-bottom:12px;display:flex;align-items:center;gap:8px}.ownership-section h3 .os-icon{font-size:1rem}.director-card{background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:14px 16px;margin-bottom:8px;transition:background .15s}.director-card:hover{background:rgba(59,130,246,0.03)}.director-card .dc-top{display:flex;align-items:center;gap:12px}.director-card .dc-avatar{width:36px;height:36px;border-radius:50%;background:var(--border);display:flex;align-items:center;justify-content:center;font-size:0.8rem;font-weight:700;color:var(--muted);flex-shrink:0}.director-card .dc-info{flex:1;min-width:0}.director-card .dc-name{font-weight:600;font-size:0.9rem}.director-card .dc-title{font-size:0.78rem;color:var(--muted)}.director-card .dc-type{font-size:0.6rem;text-transform:uppercase;letter-spacing:0.05em;padding:2px 8px;border-radius:10px;font-weight:700;display:inline-block;margin-top:2px}.dc-type.chairman{background:rgba(245,158,11,0.12);color:var(--yellow)}.dc-type.executive{background:rgba(59,130,246,0.12);color:var(--blue)}.dc-type.independent{background:rgba(16,185,129,0.12);color:var(--green)}.dc-type.non-executive{background:rgba(168,163,163,0.12);color:var(--muted)}.director-card .dc-boards{margin-top:8px;padding-top:8px;border-top:1px solid var(--border)}.director-card .dc-boards .dc-board-label{font-size:0.65rem;color:var(--muted);text-transform:uppercase;letter-spacing:0.04em;margin-bottom:4px}.director-card .dc-board-item{display:inline-flex;align-items:center;gap:4px;background:var(--card);border:1px solid var(--border);border-radius:6px;padding:3px 8px;font-size:0.72rem;margin:2px 4px 2px 0;cursor:pointer;transition:border-color .15s}.director-card .dc-board-item:hover{border-color:var(--blue)}.director-card .dc-board-item .brd-sym{font-weight:700;color:var(--blue)}.director-card .dc-board-item .brd-role{color:var(--muted)}.shareholder-row{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--bg);border:1px solid var(--border);border-radius:10px;margin-bottom:6px;transition:background .15s}.shareholder-row:hover{background:rgba(59,130,246,0.03)}.shareholder-row .sh-rank{width:24px;text-align:center;font-size:0.75rem;font-weight:700;color:var(--muted);flex-shrink:0}.shareholder-row .sh-info{flex:1;min-width:0}.shareholder-row .sh-name{font-weight:600;font-size:0.88rem}.shareholder-row .sh-type{font-size:0.65rem;text-transform:uppercase;color:var(--muted);letter-spacing:0.04em}.shareholder-row .sh-pct{font-size:1.1rem;font-weight:700;min-width:65px;text-align:right;flex-shrink:0}.shareholder-row .sh-bar{flex:0 0 120px;height:6px;background:var(--border);border-radius:3px;overflow:hidden}.shareholder-row .sh-bar-fill{height:100%;border-radius:3px;background:var(--blue);transition:width .3s ease}.shareholder-row .sh-holdings{margin-top:4px}.sh-cross-link{display:inline-flex;align-items:center;gap:3px;font-size:0.7rem;background:var(--card);border:1px solid var(--border);border-radius:5px;padding:2px 6px;margin:2px 3px 2px 0;cursor:pointer;transition:border-color .15s}.sh-cross-link:hover{border-color:var(--blue)}.sh-cross-link .scl-sym{font-weight:700;color:var(--blue)}.sh-cross-link .scl-pct{color:var(--muted)}.ownership-empty{color:var(--muted);font-size:0.88rem;text-align:center;padding:40px 20px}.placeholder-page{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;color:var(--muted);text-align:center;gap:12px}.placeholder-page .ph-icon{opacity:0.5;display:flex;justify-content:center}.placeholder-page .ph-icon svg{width:48px;height:48px}.placeholder-page p{font-size:0.95rem}.cmd-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.6);z-index:100;backdrop-filter:blur(4px)}.cmd-overlay.open{display:flex;justify-content:center;padding-top:min(20vh,160px)}.cmd-box{background:var(--card);border:1px solid var(--border);border-radius:14px;width:min(560px,90vw);max-height:420px;display:flex;flex-direction:column;box-shadow:0 20px 60px rgba(0,0,0,0.5);animation:cmdIn .15s ease-out}@keyframes cmdIn{from{opacity:0;transform:scale(0.97) translateY(-8px)}to{opacity:1;transform:none}}.cmd-input-wrap{display:flex;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border);gap:12px}.cmd-input-wrap .cmd-icon{color:var(--muted);font-size:1.1rem;flex-shrink:0}.cmd-input-wrap input{flex:1;background:none;border:none;color:var(--text);font-size:1rem;outline:none}.cmd-input-wrap input::placeholder{color:var(--muted)}.cmd-input-wrap .cmd-hint{color:var(--muted);font-size:0.7rem;background:var(--bg);padding:3px 8px;border-radius:4px;white-space:nowrap}.cmd-results{overflow-y:auto;padding:8px}.cmd-results:empty::after{content:'Type to search...';display:block;padding:24px;text-align:center;color:var(--muted);font-size:0.85rem}.cmd-item{display:flex;align-items:center;gap:12px;padding:10px 14px;border-radius:8px;cursor:pointer;transition:background .1s}.cmd-item:hover,.cmd-item.selected{background:rgba(59,130,246,0.1)}.cmd-item .cmd-sym{font-weight:700;font-size:0.95rem;min-width:70px;color:var(--blue)}.cmd-item .cmd-price{margin-left:auto;font-weight:600;font-size:0.9rem}.cmd-item .cmd-chg{font-size:0.8rem;min-width:60px;text-align:right}.cmd-item .cmd-mkt{color:var(--muted);font-size:0.75rem;text-transform:capitalize}.cmd-no-results{padding:24px;text-align:center;color:var(--muted);font-size:0.85rem}.loading{text-align:center;padding:60px;color:var(--muted)}.loading .spinner{display:inline-block;width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--blue);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.empty{text-align:center;padding:60px;color:var(--muted)}.settings-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.6);z-index:100;backdrop-filter:blur(4px)}.settings-overlay.open{display:flex;justify-content:center;align-items:center}.settings-box{background:var(--card);border:1px solid var(--border);border-radius:14px;width:min(400px,90vw);padding:24px;box-shadow:0 20px 60px rgba(0,0,0,0.5)}.settings-box h3{font-size:1.1rem;font-weight:700;margin-bottom:16px}.settings-box .setting-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid var(--border)}.settings-box .setting-row:last-child{border-bottom:none}.settings-box .setting-label{font-size:0.88rem}.settings-box .close-btn{margin-top:16px;background:var(--border);border:none;color:var(--text);padding:8px 20px;border-radius:8px;cursor:pointer;font-size:0.85rem;width:100%}.market-toolbar{display:flex;align-items:center;gap:12px;margin-bottom:24px;flex-wrap:wrap}.market-toolbar select{background:var(--card);border:1px solid var(--border);color:var(--text);padding:10px 16px;border-radius:10px;font-size:0.88rem;outline:none;cursor:pointer;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}.market-toolbar select:focus{border-color:var(--blue)}.market-toolbar .toolbar-right{margin-left:auto;display:flex;align-items:center;gap:12px}.market-toolbar .stock-count{color:var(--muted);font-size:0.88rem;font-weight:500}.view-toggle{display:flex;background:var(--card);border:1px solid var(--border);border-radius:10px;overflow:hidden}.view-toggle button{background:none;border:none;color:var(--muted);padding:9px 14px;cursor:pointer;font-size:1rem;transition:all .15s;display:flex;align-items:center;justify-content:center}.view-toggle button.active{background:var(--blue);color:#fff}.view-toggle button:hover:not(.active){color:var(--text)}.toolbar-refresh{display:flex;align-items:center;gap:6px;background:var(--card);border:1px solid var(--border);color:var(--text);padding:9px 16px;border-radius:10px;cursor:pointer;font-size:0.88rem;font-weight:500;transition:all .15s}.toolbar-refresh:hover{border-color:var(--blue);color:var(--blue)}.market-status-bar{display:flex;align-items:center;gap:8px;color:var(--muted);font-size:0.88rem}.market-status-bar .status-dot{width:8px;height:8px;border-radius:50%;background:var(--muted)}.stock-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:14px}.stock-card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:16px;cursor:pointer;transition:all .15s;display:flex;flex-direction:column;min-height:180px}.stock-card:hover{border-color:var(--blue);transform:translateY(-1px);box-shadow:0 4px 16px rgba(0,0,0,0.2)}.heatmap-mode{grid-template-columns:repeat(12,1fr)!important;grid-auto-rows:minmax(180px,auto)}.heatmap-mode .stock-card{grid-column:span 2;grid-row:span 1}.heatmap-mode .card-xl{grid-column:span 4;grid-row:span 2;min-height:280px}.heatmap-mode .card-xl .sc-symbol{font-size:1.4rem}.heatmap-mode .card-xl .sc-badge{font-size:0.85rem;padding:3px 10px}.heatmap-mode .card-lg{grid-column:span 3;grid-row:span 1;min-height:200px}.heatmap-mode .card-lg .sc-symbol{font-size:1.2rem}.heatmap-mode .card-md{grid-column:span 2;grid-row:span 1}@media(max-width:768px){.heatmap-mode{grid-template-columns:repeat(6,1fr)!important}.heatmap-mode .card-xl{grid-column:span 6}.heatmap-mode .card-lg{grid-column:span 3}.heatmap-mode .card-md{grid-column:span 3}.heatmap-mode .stock-card{grid-column:span 2}}.sc-header{display:flex;align-items:center;gap:8px;margin-bottom:4px;flex-wrap:wrap}.sc-symbol{font-size:1.05rem;font-weight:800;letter-spacing:0.02em}.sc-badge{font-size:0.7rem;font-weight:700;padding:2px 8px;border-radius:4px;white-space:nowrap}.sc-badge.up{background:rgba(16,185,129,0.15);color:var(--green)}.sc-badge.down{background:rgba(239,68,68,0.15);color:var(--red)}.sc-badge.neutral{background:rgba(100,116,139,0.15);color:var(--muted)}.sc-market{font-size:0.7rem;font-weight:700;color:var(--muted);background:var(--border);padding:2px 6px;border-radius:4px;margin-left:auto}.sc-name{font-size:0.75rem;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:8px;text-transform:uppercase}.sc-spark{flex:1;min-height:40px;margin-bottom:10px}.sc-spark canvas{width:100%;height:100%;display:block}.sc-stats{display:flex;gap:12px;font-size:0.75rem;border-top:1px solid var(--border);padding-top:10px}.sc-stat{display:flex;flex-direction:column;gap:2px}.sc-stat .sc-label{color:var(--muted);font-weight:500}.sc-stat .sc-val{font-weight:600;color:var(--text)}body.sidebar-collapsed .sidebar{transform:translateX(-100%)}body.sidebar-collapsed .main{margin-left:0}@media(max-width:1024px){.market-charts,.movers-grid{grid-template-columns:1fr}}@media(max-width:768px){.sidebar{transform:translateX(-100%)}.sidebar.open{transform:translateX(0)}.main{margin-left:0}.detail-grid{grid-template-columns:1fr 1fr}.stock-table{font-size:0.8rem}.stock-table th,.stock-table td{padding:10px 8px}.stock-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}.topbar .search-trigger{min-width:auto;flex:1}.stock-page .sp-chart{height:220px}body{padding-top:env(safe-area-inset-top);padding-bottom:0}.topbar{padding:10px 16px 10px calc(16px+env(safe-area-inset-left));padding-right:calc(16px+env(safe-area-inset-right))}.content{padding:20px 16px calc(72px+env(safe-area-inset-bottom));padding-left:calc(16px+env(safe-area-inset-left));padding-right:calc(16px+env(safe-area-inset-right))}.mobile-tab-bar{display:flex!important;position:fixed;bottom:0;left:0;right:0;background:var(--card);border-top:1px solid var(--border);z-index:60;padding:6px 0 calc(6px+env(safe-area-inset-bottom));justify-content:space-around;align-items:stretch;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);background:rgba(23,23,23,0.92)}.mobile-tab-bar .tab-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:6px 0;min-width:56px;color:var(--muted);font-size:0.62rem;font-weight:600;text-decoration:none;-webkit-tap-highlight-color:transparent;transition:color .15s}.mobile-tab-bar .tab-item.active{color:var(--blue)}.mobile-tab-bar .tab-item svg{width:22px;height:22px}.topbar .sidebar-toggle{display:none}.topbar .search-trigger kbd{display:none}.topbar .search-trigger .search-text{font-size:0.82rem}.topbar .settings-btn{display:none}.topbar{gap:10px;padding-top:8px;padding-bottom:8px}.date-nav button,.market-tabs button,.sp-period button,.idx-period-toggle button,.wl-pill,.news-filter-btn{min-height:44px;min-width:44px}.pf-holding-actions button{min-height:36px;min-width:44px;padding:6px 12px;font-size:0.78rem}.wl-stock-remove{opacity:1;min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center;font-size:1.1rem}.pf-holding-actions{opacity:1}.mobile-tab-bar .tab-item:active{transform:scale(0.92);opacity:0.7}button:active,.wl-stock-card:active,.pf-holding:active,.stock-grid .sc:active,.news-card:active{transform:scale(0.98);transition:transform 0.08s}.sidebar-nav li a:active{background:rgba(255,255,255,0.1)}.page-title{font-size:1.35rem;margin-bottom:2px}.page-subtitle{font-size:0.78rem;margin-bottom:16px}.stock-page .sp-header h2{font-size:1.5rem}.stock-page .sp-price{font-size:2.2rem}.stock-page .sp-change{font-size:1rem}.stock-page .sp-price-row{margin-bottom:16px}.stock-page .sp-period{overflow-x:auto;-webkit-overflow-scrolling:touch;gap:6px;padding-bottom:4px;margin-bottom:12px}.stock-page .sp-period button{flex-shrink:0;padding:8px 16px;min-height:44px}.stock-page .back-link{min-height:44px;display:inline-flex;align-items:center;font-size:0.9rem}.sp-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;gap:0;flex-wrap:nowrap}.sp-tabs button{flex-shrink:0;padding:12px 16px;white-space:nowrap;min-height:44px}.stock-grid{grid-template-columns:1fr 1fr;gap:10px}.sc{padding:12px}.section-card{padding:16px;margin-bottom:16px}.cmd-overlay.open{padding-top:0;align-items:flex-start}.cmd-box{width:100vw;max-height:100vh;height:100vh;border-radius:0;border:none;box-shadow:none}.cmd-input-wrap{padding:14px 16px;padding-top:calc(14px+env(safe-area-inset-top))}.cmd-input-wrap input{font-size:1.1rem}.cmd-results{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch}.cmd-item{padding:14px 16px;min-height:48px}.auth-overlay.active{align-items:flex-end}.auth-box{width:100%;max-width:100vw;border-radius:20px 20px 0 0;padding:24px 20px calc(24px+env(safe-area-inset-bottom));max-height:90vh;overflow-y:auto;animation:sheetUp .25s ease-out}.auth-box input{padding:14px 14px;font-size:1rem;min-height:48px}.auth-box .auth-btn{padding:14px;font-size:1rem;min-height:48px}.edit-overlay.active{align-items:flex-end}.edit-box{width:100%;max-width:100vw;border-radius:20px 20px 0 0;padding:24px 20px calc(24px+env(safe-area-inset-bottom));max-height:90vh;overflow-y:auto;animation:sheetUp .25s ease-out}.edit-box input{padding:14px 14px;font-size:1rem;min-height:48px}.edit-box .edit-actions button{padding:14px;font-size:1rem;min-height:48px}@keyframes sheetUp{from{transform:translateY(100%)}to{transform:translateY(0)}}.pf-summary{grid-template-columns:1fr 1fr;gap:10px}.pf-stat{padding:14px}.pf-stat .pf-val{font-size:1.15rem}.pf-holding{padding:14px;gap:12px}.pf-holding .pf-sym{min-width:70px;font-size:0.95rem}.wl-lists{gap:6px;overflow-x:auto;-webkit-overflow-scrolling:touch;flex-wrap:nowrap;padding-bottom:4px}.wl-pill{flex-shrink:0}.wl-stocks{grid-template-columns:1fr;gap:8px}.wl-stock-card{padding:14px}.wl-add-stock{flex-direction:column;gap:6px}.wl-add-stock input{max-width:100%}.wl-suggestions{width:100%;max-width:100%}.news-grid{grid-template-columns:1fr;gap:12px}.news-card-img{height:140px}.news-controls{gap:8px}.news-filter-btn{padding:8px 12px;font-size:0.78rem}.order-book{grid-template-columns:1fr;gap:12px}.idx-period-toggle{overflow-x:auto;-webkit-overflow-scrolling:touch;flex-wrap:nowrap}.idx-period-toggle button{flex-shrink:0}.indices-header{gap:6px}.controls{gap:8px}.controls input{min-width:0;flex:1}.controls select{min-width:100px}.market-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;flex-wrap:nowrap}.market-tabs button{flex-shrink:0;white-space:nowrap}.admin-grid{grid-template-columns:1fr}.ptr-indicator{display:flex!important;justify-content:center;padding:0;height:0;overflow:hidden;transition:height .2s,padding .2s;color:var(--muted);font-size:0.82rem;align-items:center;gap:8px}.ptr-indicator.pulling{height:40px;padding:8px 0}.ptr-indicator.refreshing{height:40px;padding:8px 0}.ptr-indicator .ptr-spinner{width:18px;height:18px;border:2px solid var(--border);border-top-color:var(--blue);border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.content{-webkit-overflow-scrolling:touch}.donut-wrap canvas{width:160px!important;height:160px!important}.fin-metrics{grid-template-columns:1fr!important}}.auth-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.7);z-index:200;align-items:center;justify-content:center}.auth-overlay.active{display:flex}.auth-box{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:32px;width:380px;max-width:90vw}.auth-box h2{font-size:1.2rem;font-weight:700;margin-bottom:4px}.auth-box .auth-sub{color:var(--muted);font-size:0.82rem;margin-bottom:20px}.auth-box label{display:block;font-size:0.78rem;font-weight:600;color:var(--muted);margin-bottom:4px;margin-top:12px}.auth-box input{width:100%;padding:10px 12px;background:var(--bg);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:0.88rem;outline:none;box-sizing:border-box}.auth-box input:focus{border-color:var(--blue)}.auth-box .auth-btn{width:100%;padding:11px;background:var(--blue);color:#fff;border:none;border-radius:8px;font-size:0.9rem;font-weight:600;cursor:pointer;margin-top:20px;transition:opacity .15s}.auth-box .auth-btn:hover{opacity:0.9}.auth-box .auth-btn:disabled{opacity:0.5;cursor:not-allowed}.auth-box .auth-toggle{text-align:center;margin-top:14px;font-size:0.82rem;color:var(--muted)}.auth-box .auth-toggle a{color:var(--blue);cursor:pointer;text-decoration:none}.auth-box .auth-error{color:var(--red);font-size:0.8rem;margin-top:10px;display:none}.edit-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.7);z-index:200;align-items:center;justify-content:center}.edit-overlay.active{display:flex}.edit-box{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:28px;width:400px;max-width:90vw}.edit-box h3{font-size:1.1rem;font-weight:700;margin-bottom:16px;display:flex;align-items:center;justify-content:space-between}.edit-box h3 .close-btn{background:none;border:none;color:var(--muted);font-size:1.3rem;cursor:pointer;padding:0 4px;transition:color .15s}.edit-box h3 .close-btn:hover{color:var(--text)}.edit-box label{display:block;font-size:0.78rem;font-weight:600;color:var(--muted);margin-bottom:4px;margin-top:12px}.edit-box input{width:100%;padding:10px 12px;background:var(--bg);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:0.88rem;outline:none;box-sizing:border-box}.edit-box input:focus{border-color:var(--blue)}.edit-box .edit-actions{display:flex;gap:10px;margin-top:20px}.edit-box .edit-actions button{flex:1;padding:11px;border:none;border-radius:8px;font-size:0.88rem;font-weight:600;cursor:pointer;transition:opacity .15s}.edit-box .edit-actions .save-btn{background:var(--blue);color:#fff}.edit-box .edit-actions .save-btn:hover{opacity:0.9}.edit-box .edit-actions .cancel-btn{background:var(--bg);color:var(--muted);border:1px solid var(--border)}.edit-box .edit-actions .cancel-btn:hover{color:var(--text)}.user-menu{position:relative;margin-left:8px}.user-avatar{width:32px;height:32px;border-radius:50%;background:var(--blue);color:#fff;display:flex;align-items:center;justify-content:center;font-size:0.78rem;font-weight:700;cursor:pointer;border:none;transition:opacity .15s}.user-avatar:hover{opacity:0.85}.user-dropdown{display:none;position:absolute;right:0;top:40px;background:var(--card);border:1px solid var(--border);border-radius:10px;min-width:200px;padding:8px 0;z-index:100;box-shadow:0 8px 24px rgba(0,0,0,0.4)}.user-dropdown.open{display:block}.user-dropdown .ud-header{padding:10px 16px;border-bottom:1px solid var(--border)}.user-dropdown .ud-name{font-weight:600;font-size:0.88rem}.user-dropdown .ud-email{color:var(--muted);font-size:0.75rem}.user-dropdown .ud-role{display:inline-block;font-size:0.65rem;font-weight:700;padding:1px 6px;border-radius:4px;margin-top:4px;text-transform:uppercase}.user-dropdown .ud-role.admin{background:rgba(59,130,246,0.15);color:var(--blue)}.user-dropdown .ud-role.user{background:rgba(100,116,139,0.15);color:var(--muted)}.user-dropdown a{display:block;padding:8px 16px;color:var(--text);font-size:0.85rem;text-decoration:none;cursor:pointer;transition:background .1s}.user-dropdown a:hover{background:rgba(255,255,255,0.04)}.user-dropdown .ud-sep{border-top:1px solid var(--border);margin:4px 0}.login-btn{background:none;border:1px solid var(--border);color:var(--text);padding:6px 14px;border-radius:8px;font-size:0.82rem;font-weight:500;cursor:pointer;transition:all .15s}.login-btn:hover{border-color:var(--blue);color:var(--blue)}.admin-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;margin-bottom:24px}.admin-card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:20px}.admin-card h3{font-size:0.95rem;font-weight:700;margin-bottom:12px;display:flex;align-items:center;gap:8px}.admin-card .ac-stat{font-size:1.8rem;font-weight:800;margin-bottom:4px}.admin-card .ac-label{font-size:0.78rem;color:var(--muted)}.admin-table{width:100%;border-collapse:collapse;font-size:0.82rem}.admin-table th{text-align:left;padding:8px 12px;color:var(--muted);font-weight:600;font-size:0.72rem;text-transform:uppercase;border-bottom:1px solid var(--border)}.admin-table td{padding:8px 12px;border-bottom:1px solid var(--border)}.admin-table tr:last-child td{border-bottom:none}.admin-actions{display:flex;gap:8px;margin-top:16px;flex-wrap:wrap}.admin-actions button{padding:8px 16px;border-radius:8px;border:1px solid var(--border);background:none;color:var(--text);font-size:0.82rem;cursor:pointer;font-weight:500;transition:all .15s}.admin-actions button:hover{border-color:var(--blue);color:var(--blue)}.wl-lists{display:flex;gap:8px;margin-bottom:20px;flex-wrap:wrap;align-items:center}.wl-pill{padding:7px 16px;border-radius:20px;border:1px solid var(--border);background:none;color:var(--muted);font-size:0.82rem;font-weight:500;cursor:pointer;transition:all .15s}.wl-pill:hover{border-color:var(--text);color:var(--text)}.wl-pill.active{background:var(--blue);border-color:var(--blue);color:#fff}.wl-pill.add{border-style:dashed;font-size:0.9rem}.wl-header{display:flex;align-items:center;gap:12px;margin-bottom:16px;flex-wrap:wrap}.wl-header h2{font-size:1.1rem;font-weight:700}.wl-header .wl-count{color:var(--muted);font-size:0.82rem}.wl-header-actions{margin-left:auto;display:flex;gap:8px;align-items:center}.wl-header-actions button{background:none;border:1px solid var(--border);color:var(--muted);padding:5px 10px;border-radius:6px;font-size:0.78rem;cursor:pointer;transition:all .15s}.wl-header-actions button:hover{color:var(--text);border-color:var(--text)}.wl-add-stock{display:flex;gap:8px;margin-bottom:20px;position:relative}.wl-add-stock input{flex:1;max-width:320px;padding:9px 14px;background:var(--bg);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:0.85rem;outline:none}.wl-add-stock input:focus{border-color:var(--blue)}.wl-add-stock button{padding:9px 18px;background:var(--blue);color:#fff;border:none;border-radius:8px;font-size:0.85rem;font-weight:600;cursor:pointer}.wl-suggestions{position:absolute;top:100%;left:0;width:320px;max-height:240px;overflow-y:auto;background:var(--card);border:1px solid var(--border);border-radius:8px;z-index:50;box-shadow:0 8px 24px rgba(0,0,0,0.4);display:none}.wl-suggestions.open{display:block}.wl-sug-item{display:flex;align-items:center;justify-content:space-between;padding:8px 14px;cursor:pointer;font-size:0.85rem;transition:background .1s}.wl-sug-item:hover{background:rgba(59,130,246,0.1)}.wl-sug-item .sug-sym{font-weight:600}.wl-sug-item .sug-mkt{color:var(--muted);font-size:0.72rem;text-transform:capitalize}.wl-stocks{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px}.wl-stock-card{background:var(--card);border:1px solid var(--border);border-radius:10px;padding:14px 16px;display:flex;align-items:center;gap:14px;cursor:pointer;transition:border-color .15s}.wl-stock-card:hover{border-color:var(--blue)}.wl-stock-info{flex:1;min-width:0}.wl-stock-sym{font-weight:700;font-size:0.95rem}.wl-stock-mkt{color:var(--muted);font-size:0.72rem;text-transform:capitalize}.wl-stock-price{text-align:right}.wl-stock-price .wl-price{font-weight:600;font-size:0.95rem}.wl-stock-price .wl-change{font-size:0.78rem;font-weight:600}.wl-stock-remove{background:none;border:none;color:var(--muted);cursor:pointer;padding:4px;font-size:0.9rem;opacity:0;transition:opacity .15s}.wl-stock-card:hover .wl-stock-remove{opacity:1}.wl-stock-remove:hover{color:var(--red)}.wl-empty{text-align:center;padding:40px;color:var(--muted);font-size:0.88rem}.wl-login-prompt{text-align:center;padding:40px;color:var(--muted)}.wl-login-prompt button{margin-top:12px;padding:9px 20px;background:var(--blue);color:#fff;border:none;border-radius:8px;font-size:0.88rem;cursor:pointer;font-weight:600}.pf-layout{display:grid;grid-template-columns:1fr 340px;gap:20px;margin-bottom:20px}.pf-main{min-width:0}.pf-sidebar{display:flex;flex-direction:column;gap:16px}.pf-summary-panel{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:20px;border-left:3px solid var(--border)}.pf-summary-panel.in-profit{border-left-color:var(--green)}.pf-summary-panel.in-loss{border-left-color:var(--red)}.pf-summary-panel h3{font-size:0.85rem;font-weight:700;margin-bottom:16px}.pf-sr{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid var(--border)}.pf-sr:last-child{border-bottom:none}.pf-sr .pf-sr-label{font-size:0.8rem;color:var(--muted)}.pf-sr .pf-sr-val{font-size:0.92rem;font-weight:700}.pf-stats-panel{background:var(--card);border:1px solid var(--border);border-radius:12px;overflow:hidden}.pf-stats-toggle{width:100%;background:none;border:none;color:var(--text);padding:16px 20px;display:flex;justify-content:space-between;align-items:center;cursor:pointer;font-size:0.85rem;font-weight:700}.pf-stats-toggle svg{transition:transform .2s}.pf-stats-panel.open .pf-stats-toggle svg{transform:rotate(180deg)}.pf-stats-body{padding:0 20px 16px;display:none}.pf-stats-panel.open .pf-stats-body{display:block}.pf-stats-body .pf-sr{padding:7px 0}.pf-chart-area{display:flex;gap:24px;align-items:flex-start;margin-bottom:24px;background:var(--card);border:1px solid var(--border);border-radius:12px;padding:24px}.pf-chart-area canvas{max-width:200px;max-height:200px;flex-shrink:0}.pf-alloc-legend{flex:1;display:grid;grid-template-columns:1fr 1fr;gap:6px 16px;font-size:0.8rem}.pf-holdings-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;margin-bottom:20px}.pf-card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:18px;position:relative;transition:border-color .15s}.pf-card:hover{border-color:var(--blue)}.pf-card-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:10px}.pf-card-sym{font-weight:800;font-size:1.15rem;line-height:1.2}.pf-card-name{font-size:0.7rem;color:var(--muted);margin-top:2px;font-weight:400;max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pf-card-actions{display:flex;gap:4px;opacity:0;transition:opacity .15s;position:absolute;top:10px;right:10px}.pf-card:hover .pf-card-actions{opacity:1}.pf-card-actions button{background:var(--bg);border:1px solid var(--border);color:var(--muted);padding:3px 8px;border-radius:5px;font-size:0.7rem;cursor:pointer;transition:all .15s}.pf-card-actions button:hover{color:var(--text);border-color:var(--text)}.pf-card-actions button.del:hover{color:var(--red);border-color:var(--red)}.pf-card-trade{display:flex;gap:4px;margin-top:10px;padding-top:10px;border-top:1px solid var(--border)}.pf-card-trade button{flex:1;padding:6px 0;border-radius:6px;font-size:0.72rem;font-weight:700;cursor:pointer;border:none;transition:opacity .15s}.pf-card-trade button:hover{opacity:0.85}.pf-card-trade .pf-buy-btn{background:rgba(16,185,129,0.15);color:var(--green)}.pf-card-trade .pf-sell-btn{background:rgba(239,68,68,0.15);color:var(--red)}.pf-inline-form{display:none;margin-top:10px;padding:12px;background:var(--bg);border:1px solid var(--border);border-radius:8px}.pf-inline-form.open{display:block}.pf-inline-form h4{font-size:0.78rem;font-weight:700;margin:0 0 10px;display:flex;justify-content:space-between;align-items:center}.pf-inline-form h4 button{background:none;border:none;color:var(--muted);cursor:pointer;font-size:1rem;line-height:1}.pf-inline-fields{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:10px}.pf-inline-fields label{font-size:0.62rem;color:var(--muted);text-transform:uppercase;display:block;margin-bottom:2px}.pf-inline-fields input{width:100%;background:var(--card);border:1px solid var(--border);color:var(--text);padding:6px 8px;border-radius:5px;font-size:0.8rem;outline:none;box-sizing:border-box}.pf-inline-fields input:focus{border-color:var(--blue)}.pf-inline-submit{width:100%;padding:7px;border:none;border-radius:6px;font-size:0.8rem;font-weight:700;cursor:pointer;color:#fff}.pf-inline-submit.buy{background:var(--green)}.pf-inline-submit.sell{background:var(--red)}.pf-card-badges{display:flex;gap:6px;margin-bottom:14px}.pf-badge{font-size:0.72rem;font-weight:700;padding:4px 10px;border-radius:6px;white-space:nowrap}.pf-badge.up{background:rgba(16,185,129,0.15);color:var(--green)}.pf-badge.down{background:rgba(239,68,68,0.15);color:var(--red)}.pf-card-stats{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px 12px}.pf-cs-label{font-size:0.62rem;color:var(--muted);text-transform:uppercase;letter-spacing:0.04em}.pf-cs-val{font-size:0.88rem;font-weight:700;margin-top:2px}.pf-card-spark{margin-top:14px;height:40px;overflow:hidden}.pf-card-spark canvas{width:100%;height:100%;display:block}.pf-lots{margin-top:12px;border-top:1px solid var(--border);padding-top:10px}.pf-lots-toggle{display:flex;align-items:center;gap:6px;background:none;border:none;color:var(--muted);font-size:0.72rem;font-weight:600;cursor:pointer;padding:0;width:100%;text-align:left;transition:color .15s}.pf-lots-toggle:hover{color:var(--text)}.pf-lots-toggle svg{transition:transform .2s;flex-shrink:0}.pf-lots-toggle.open svg{transform:rotate(180deg)}.pf-lots-list{display:none;margin-top:8px}.pf-lots-toggle.open+.pf-lots-list{display:block}.pf-lot-actions{display:flex;gap:2px;margin-left:auto;align-items:center}
.pf-lot-edit{background:none;border:none;color:var(--muted);cursor:pointer;padding:2px 4px;opacity:0;transition:opacity .15s,color .15s}.pf-lot:hover .pf-lot-edit{opacity:1}.pf-lot-edit:hover{color:var(--blue)}
.pf-lot-edit-form{display:flex;flex-wrap:wrap;gap:6px;align-items:center;padding:8px 0}
.pf-lot-edit-form input{background:var(--bg);border:1px solid var(--border);color:var(--text);padding:5px 8px;border-radius:6px;font-size:0.78rem;width:100px}
.pf-lot-edit-form button{padding:4px 12px;border-radius:6px;font-size:0.78rem;font-weight:600;cursor:pointer;border:none}
.pf-lot-edit-form .lot-save{background:var(--blue);color:#fff}
.pf-lot-edit-form .lot-cancel{background:transparent;color:var(--muted);border:1px solid var(--border)}
.pf-lot-del{background:none;border:none;color:var(--muted);cursor:pointer;font-size:1.1rem;padding:0 4px;margin-left:auto;opacity:0;transition:opacity .15s,color .15s}.pf-lot:hover .pf-lot-actions{display:flex;gap:2px;margin-left:auto;align-items:center}
.pf-lot-edit{background:none;border:none;color:var(--muted);cursor:pointer;padding:2px 4px;opacity:0;transition:opacity .15s,color .15s}.pf-lot:hover .pf-lot-edit{opacity:1}.pf-lot-edit:hover{color:var(--blue)}
.pf-lot-edit-form{display:flex;flex-wrap:wrap;gap:6px;align-items:center;padding:8px 0}
.pf-lot-edit-form input{background:var(--bg);border:1px solid var(--border);color:var(--text);padding:5px 8px;border-radius:6px;font-size:0.78rem;width:100px}
.pf-lot-edit-form button{padding:4px 12px;border-radius:6px;font-size:0.78rem;font-weight:600;cursor:pointer;border:none}
.pf-lot-edit-form .lot-save{background:var(--blue);color:#fff}
.pf-lot-edit-form .lot-cancel{background:transparent;color:var(--muted);border:1px solid var(--border)}
.pf-lot-del{opacity:1}.pf-lot-del:hover{color:var(--red)}
.pf-lot{display:flex;justify-content:space-between;align-items:center;padding:5px 0;border-bottom:1px solid var(--border);font-size:0.72rem}.pf-lot:last-child{border-bottom:none}.pf-lot-date{color:var(--muted);min-width:75px}.pf-lot-detail{font-weight:600;color:var(--green)}.pf-lot-note{color:var(--muted);font-style:italic;margin-left:8px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100px}.gate-blur{filter:blur(5px) !important;pointer-events:none !important;user-select:none !important}
.gate-banner{text-align:center;padding:30px 20px;border-top:1px solid var(--border)}
.gate-banner h3{margin-bottom:6px;font-size:1rem}
.gate-banner p{color:var(--muted);font-size:0.85rem;margin-bottom:16px}
.gate-banner button{padding:8px 24px;border-radius:8px;font-size:0.88rem;font-weight:700;cursor:pointer;border:none}
.gate-banner .gate-register{background:var(--green);color:#fff;margin-right:8px}
.gate-banner .gate-signin{background:transparent;color:var(--blue);border:1px solid var(--blue)}
.pf-add-card{background:transparent;border:2px dashed var(--border);border-radius:12px;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:220px;cursor:pointer;transition:border-color .15s,background .15s;gap:12px;color:var(--muted)}.pf-add-card:hover{border-color:var(--blue);background:rgba(59,130,246,0.05);color:var(--blue)}.pf-add-icon{width:48px;height:48px;border-radius:50%;border:2px solid currentColor;display:flex;align-items:center;justify-content:center}.pf-add-icon svg{width:24px;height:24px}.pf-add-text{font-size:0.85rem;font-weight:600}.pf-txn-toggle{display:flex;gap:0;margin-bottom:14px;border-radius:8px;overflow:hidden;border:1px solid var(--border);width:fit-content}.pf-txn-toggle button{padding:6px 20px;font-size:0.8rem;font-weight:700;border:none;cursor:pointer;transition:all .15s;background:var(--bg);color:var(--muted)}.pf-txn-toggle button.active-buy{background:var(--green);color:#fff}.pf-txn-toggle button.active-sell{background:var(--red);color:#fff}.pf-add-form{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:18px;margin-bottom:16px;display:none}.pf-add-form.open{display:block}.pf-add-form h3{font-size:0.9rem;font-weight:700;margin-bottom:12px}.pf-form-grid{display:grid;grid-template-columns:1fr 1fr 1fr 1fr 1fr auto;gap:10px;align-items:end}.pf-form-grid .field{display:flex;flex-direction:column;gap:4px}.pf-form-grid .field label{font-size:0.68rem;color:var(--muted);text-transform:uppercase}.pf-form-grid .field input{background:var(--bg);border:1px solid var(--border);color:var(--text);padding:8px 10px;border-radius:6px;font-size:0.82rem;outline:none;width:100%}.pf-form-grid .field input:focus{border-color:var(--blue)}.pf-form-grid button{padding:8px 16px;background:var(--blue);color:#fff;border:none;border-radius:6px;font-size:0.82rem;font-weight:600;cursor:pointer;white-space:nowrap}.pf-summary{display:none}.pf-holdings{margin-bottom:20px}.pf-alloc{display:none}@media(max-width:1024px){.pf-layout{grid-template-columns:1fr}.pf-sidebar{order:-1;display:grid;grid-template-columns:1fr 1fr;gap:12px}.pf-form-grid{grid-template-columns:1fr 1fr 1fr}}@media(max-width:600px){.pf-sidebar{grid-template-columns:1fr}.pf-form-grid{grid-template-columns:1fr 1fr}.pf-chart-area{flex-direction:column;align-items:center}.pf-holdings-grid{grid-template-columns:1fr}}.news-controls{display:flex;gap:12px;margin-bottom:20px;flex-wrap:wrap;align-items:center}.news-filter-btn{background:var(--bg);border:1px solid var(--border);color:var(--muted);padding:7px 16px;border-radius:8px;cursor:pointer;font-size:0.82rem;font-weight:600;transition:all .15s}.news-filter-btn:hover{color:var(--text);border-color:var(--text)}.news-filter-btn.active{background:var(--blue);color:#fff;border-color:var(--blue)}.news-search{flex:1;min-width:200px;background:var(--bg);border:1px solid var(--border);color:var(--text);padding:8px 14px;border-radius:8px;font-size:0.85rem;outline:none}.news-search:focus{border-color:var(--blue)}.news-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:16px}.news-card{background:var(--card);border:1px solid var(--border);border-radius:12px;overflow:hidden;transition:border-color .15s;cursor:pointer;text-decoration:none;color:inherit;display:flex;flex-direction:column}.news-card:hover{border-color:var(--blue)}.news-card-img{width:100%;height:160px;object-fit:cover;background:var(--bg)}.news-card-body{padding:16px;flex:1;display:flex;flex-direction:column}.news-card-source{font-size:0.72rem;font-weight:600;text-transform:uppercase;letter-spacing:0.05em;margin-bottom:6px;display:flex;align-items:center;gap:6px}.news-card-source .src-dot{width:6px;height:6px;border-radius:50%}.news-card-source .src-gleaner{background:#e63946}.news-card-source .src-observer{background:#457b9d}.news-card-source .src-jse{background:#2a9d8f}.news-card-title{font-size:0.95rem;font-weight:600;line-height:1.35;margin-bottom:8px;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.news-card-summary{font-size:0.82rem;color:var(--muted);line-height:1.45;flex:1;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.news-card-meta{font-size:0.72rem;color:var(--muted);margin-top:10px;display:flex;justify-content:space-between;align-items:center}.news-load-more{display:block;margin:20px auto;background:var(--card);border:1px solid var(--border);color:var(--text);padding:10px 28px;border-radius:8px;cursor:pointer;font-size:0.85rem;transition:all .15s}.news-load-more:hover{border-color:var(--blue);color:var(--blue)}.news-empty{text-align:center;padding:60px 20px;color:var(--muted)}.news-scrape-btn{background:var(--blue);color:#fff;border:none;padding:8px 18px;border-radius:8px;cursor:pointer;font-size:0.82rem;font-weight:600;transition:opacity .15s}.news-scrape-btn:hover{opacity:0.85}.news-scrape-btn:disabled{opacity:0.5;cursor:not-allowed}.ob-analysis{margin-bottom:24px}.pressure-bar-wrap{margin-bottom:16px}.pressure-bar-label{display:flex;justify-content:space-between;font-size:0.8rem;font-weight:600;margin-bottom:6px}.pressure-bar{height:28px;border-radius:8px;overflow:hidden;display:flex;position:relative}.pressure-bar .buy-fill{background:var(--green);display:flex;align-items:center;justify-content:center;font-size:0.75rem;font-weight:700;color:#fff;transition:width .4s}.pressure-bar .sell-fill{background:var(--red);display:flex;align-items:center;justify-content:center;font-size:0.75rem;font-weight:700;color:#fff;flex:1}.ob-metrics{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:10px;margin-bottom:20px}.ob-metric{background:var(--card);border:1px solid var(--border);border-radius:10px;padding:14px 16px;text-align:center}.ob-metric .metric-label{font-size:0.7rem;font-weight:600;text-transform:uppercase;letter-spacing:0.05em;color:var(--muted);margin-bottom:4px}.ob-metric .metric-val{font-size:1.15rem;font-weight:700}.ob-metric .metric-val.up{color:var(--green)}.ob-metric .metric-val.down{color:var(--red)}.imbalance-badge{display:inline-block;padding:3px 10px;border-radius:20px;font-size:0.75rem;font-weight:700}.imbalance-badge.bullish{background:rgba(16,185,129,0.15);color:var(--green)}.imbalance-badge.bearish{background:rgba(239,68,68,0.15);color:var(--red)}.imbalance-badge.balanced{background:rgba(168,163,163,0.15);color:var(--muted)}.imbalance-badge.strong-buy{background:rgba(16,185,129,0.25);color:var(--green)}.imbalance-badge.strong-sell{background:rgba(239,68,68,0.25);color:var(--red)}.ob-depth{margin-bottom:20px}.ob-depth h4{font-size:0.85rem;font-weight:700;margin-bottom:10px;color:var(--muted)}.depth-chart{display:flex;flex-direction:column;gap:3px}.depth-row{display:flex;align-items:center;height:22px;font-size:0.75rem;gap:6px}.depth-row .depth-price{width:70px;text-align:right;font-weight:600;flex-shrink:0}.depth-row .depth-bar-wrap{flex:1;height:16px;border-radius:4px;overflow:hidden;position:relative;background:rgba(255,255,255,0.03)}.depth-row .depth-bar{height:100%;border-radius:4px;transition:width .3s}.depth-row .depth-bar.buy{background:rgba(16,185,129,0.35)}.depth-row .depth-bar.sell{background:rgba(239,68,68,0.35)}.depth-row .depth-val{width:80px;font-size:0.7rem;color:var(--muted);flex-shrink:0}.depth-spread-line{text-align:center;font-size:0.7rem;color:var(--muted);padding:4px 0;border-top:1px dashed var(--border);border-bottom:1px dashed var(--border);margin:2px 0}.sr-levels{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:20px}.sr-col h4{font-size:0.85rem;font-weight:700;margin-bottom:8px}.sr-col h4.support{color:var(--green)}.sr-col h4.resistance{color:var(--red)}.sr-level{display:flex;justify-content:space-between;padding:6px 10px;border-radius:6px;font-size:0.8rem;margin-bottom:4px;background:rgba(255,255,255,0.03)}.sr-level .sr-price{font-weight:700}.sr-level .sr-qty{color:var(--muted)}.sr-level .sr-val{font-weight:600}@media(max-width:768px){.ob-metrics{grid-template-columns:1fr 1fr}.sr-levels{grid-template-columns:1fr}}.logo-drop{position:relative;cursor:default;transition:all .15s}.logo-drop.admin-drop{cursor:copy}.logo-drop.drag-over{outline:2px dashed var(--green);outline-offset:3px;border-radius:10px}.logo-drop.drag-over::after{content:"Drop";position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(16,185,129,0.25);border-radius:8px;font-size:0.6rem;font-weight:800;color:var(--green);letter-spacing:0.05em}.logo-drop-placeholder{width:40px;height:40px;border-radius:8px;border:2px dashed var(--border);display:flex;align-items:center;justify-content:center;cursor:copy;transition:all .15s}.logo-drop-placeholder:hover{border-color:var(--muted)}.logo-drop-placeholder svg{color:var(--muted)}body.docs-mode .sidebar{display:none}body.docs-mode .content{margin-left:0}body.docs-mode .mobile-tab-bar{display:none}

/* === Additional inline styles === */

#moverMarketFilter button{background:none;border:none;color:var(--muted);padding:6px 14px;font-size:0.78rem;font-weight:600;cursor:pointer;transition:all .15s}#moverMarketFilter button:hover{color:var(--text)}#moverMarketFilter button.active{background:var(--border);color:var(--text)}

/* === Additional inline styles === */

@keyframes spin{to{transform:rotate(360deg)}}
/* ─── Analysis Page ─── */
.analysis-picker{max-width:900px;margin:0 auto;padding:20px}
.analysis-search-wrap{margin-bottom:24px}
.analysis-search-input{width:100%;padding:12px 16px;background:var(--card);border:1px solid var(--border);border-radius:10px;color:var(--text);font-size:0.95rem;outline:none;transition:border-color .15s}
.analysis-search-input:focus{border-color:var(--blue)}
.analysis-stock-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px}
.analysis-stock-card{display:block;padding:14px;background:var(--card);border:1px solid var(--border);border-radius:10px;text-decoration:none;transition:all .15s;cursor:pointer}
.analysis-stock-card:hover{border-color:var(--blue);background:rgba(59,130,246,0.05)}
.asc-symbol{font-weight:800;font-size:0.95rem;color:var(--text)}
.asc-name{font-size:0.72rem;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:6px}
.asc-price{font-weight:700;font-size:0.88rem;color:var(--text)}
.asc-change{font-size:0.78rem;font-weight:600}
.asc-change.up{color:var(--green)}.asc-change.down{color:var(--red)}.asc-change.neutral{color:var(--muted)}

.an-header{margin-bottom:20px;padding:0 4px}
.an-back{font-size:0.82rem;color:var(--blue);cursor:pointer;margin-bottom:12px;display:inline-block}
.an-back:hover{text-decoration:underline}
.an-title-row{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:12px}
.an-symbol{font-size:1.6rem;font-weight:800;margin:0;line-height:1.1}
.an-company{font-size:0.85rem;color:var(--muted);margin-top:2px}
.an-price-badge{text-align:right}
.an-curr-price{font-size:1.4rem;font-weight:800;display:block}
.an-curr-change{font-size:0.88rem;font-weight:600}
.an-curr-change.up{color:var(--green)}.an-curr-change.down{color:var(--red)}.an-curr-change.neutral{color:var(--muted)}
.an-date{font-size:0.78rem;color:var(--muted);margin-top:6px}

.an-layout{display:grid;grid-template-columns:1.2fr 1fr 1fr;gap:16px;align-items:start}
.an-panel{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:16px;min-width:0}
.an-panel-header{font-weight:700;font-size:0.92rem;margin-bottom:14px;display:flex;align-items:center;gap:8px}
.an-panel-date{font-size:0.72rem;color:var(--muted);font-weight:400}

.an-stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(70px,1fr));gap:8px;margin-bottom:14px}
.an-stat{text-align:center;padding:6px 4px;background:var(--bg);border-radius:8px}
.an-stat-label{font-size:0.62rem;color:var(--muted);text-transform:uppercase;letter-spacing:0.04em;margin-bottom:2px}
.an-stat-val{font-size:0.82rem;font-weight:700}
.an-stat-val.up{color:var(--green)}.an-stat-val.down{color:var(--red)}

.an-price-limits{margin-bottom:14px}
.an-pl-labels{display:flex;justify-content:space-between;font-size:0.68rem;color:var(--muted);margin-bottom:4px}
.an-pl-bar{position:relative;height:8px;background:var(--bg);border-radius:4px;overflow:visible}
.an-pl-fill{height:100%;background:linear-gradient(90deg,var(--red),var(--yellow),var(--green));border-radius:4px;opacity:0.6}
.an-pl-marker{position:absolute;top:-4px;width:4px;height:16px;background:var(--text);border-radius:2px;transform:translateX(-50%)}
.an-pl-marker-label{position:absolute;top:-18px;left:50%;transform:translateX(-50%);font-size:0.68rem;font-weight:700;color:var(--text);white-space:nowrap}

.an-chart-controls{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;flex-wrap:wrap;gap:8px}
.an-chart-toggle,.an-chart-intervals{display:flex;gap:3px}
.an-chart-toggle button,.an-chart-intervals button{background:var(--bg);color:var(--muted);border:1px solid var(--border);border-radius:6px;padding:4px 10px;font-size:0.72rem;cursor:pointer;font-weight:500;transition:all .15s}
.an-chart-toggle button.active,.an-chart-intervals button.active{background:var(--blue);color:#fff;border-color:var(--blue);font-weight:600}
.an-chart-wrap{position:relative;height:260px}
.an-chart-wrap canvas{width:100%;height:100%}

.an-trade-summary{display:grid;grid-template-columns:1fr 1fr 1fr;gap:6px;margin-bottom:12px}
.an-ts-item{background:var(--bg);border-radius:6px;padding:6px 8px;text-align:center}
.an-ts-label{font-size:0.62rem;color:var(--muted);text-transform:uppercase;display:block}
.an-ts-val{font-size:0.82rem;font-weight:700;display:block}

.an-trades-scroll{max-height:600px;overflow-y:auto;border-radius:8px}
.an-trades-table{width:100%;border-collapse:collapse;font-size:0.76rem}
.an-trades-table thead{position:sticky;top:0;z-index:2}
.an-trades-table th{background:var(--bg);color:var(--muted);font-weight:600;padding:6px 6px;text-align:left;font-size:0.68rem;text-transform:uppercase;letter-spacing:0.03em;border-bottom:1px solid var(--border)}
.an-trades-table td{padding:5px 6px;border-bottom:1px solid rgba(255,255,255,0.03)}
.an-trades-table tr:hover{background:rgba(255,255,255,0.02)}
.an-num{color:var(--muted);font-size:0.68rem}
.an-price{font-weight:600}
.an-time{color:var(--muted);font-size:0.72rem}
.an-trades-table .up{color:var(--green)}.an-trades-table .down{color:var(--red)}.an-trades-table .neutral{color:var(--muted)}

.an-oq-summary{margin-bottom:14px}
.an-oq-row{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-bottom:6px}
.an-oq-item{padding:6px 8px;border-radius:6px;display:flex;justify-content:space-between;align-items:center}
.an-oq-item.demand{background:rgba(16,185,129,0.08);border:1px solid rgba(16,185,129,0.15)}
.an-oq-item.supply{background:rgba(239,68,68,0.08);border:1px solid rgba(239,68,68,0.15)}
.an-oq-label{font-size:0.65rem;color:var(--muted);text-transform:uppercase}
.an-oq-val{font-size:0.82rem;font-weight:700}
.an-oq-item.demand .an-oq-val{color:var(--green)}
.an-oq-item.supply .an-oq-val{color:var(--red)}

.an-orders-scroll{max-height:500px;overflow-y:auto;border-radius:8px}
.an-orders-table{width:100%;border-collapse:collapse;font-size:0.76rem}
.an-orders-table thead{position:sticky;top:0;z-index:2}
.an-orders-table thead tr:first-child th{position:sticky;top:0;z-index:3;background:var(--card)}
.an-orders-table thead tr:nth-child(2) th{position:sticky;top:28px;z-index:3;background:var(--card)}
.an-orders-table th{padding:6px 6px;font-weight:600;font-size:0.68rem;text-transform:uppercase;letter-spacing:0.03em;border-bottom:1px solid var(--border)}
.an-demand-th{background:rgba(16,185,129,0.1);color:var(--green)}
.an-supply-th{background:rgba(239,68,68,0.1);color:var(--red)}
.an-orders-table td{padding:5px 6px;border-bottom:1px solid rgba(255,255,255,0.03)}
.an-demand-cell{background:rgba(16,185,129,0.03)}
.an-supply-cell{background:rgba(239,68,68,0.03)}
.an-orders-table tr:hover .an-demand-cell{background:rgba(16,185,129,0.08)}
.an-orders-table tr:hover .an-supply-cell{background:rgba(239,68,68,0.08)}

@media(max-width:1200px){.an-layout{grid-template-columns:1fr 1fr}.an-panel-left{grid-column:1/-1}}
@media(max-width:768px){.an-layout{grid-template-columns:1fr}.an-panel{grid-column:1/-1}.an-title-row{flex-direction:column}.an-price-badge{text-align:left}.analysis-stock-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}}
.an-date-nav{display:flex;align-items:center;gap:10px;margin-top:4px}.an-date-btn{background:var(--card);border:1px solid var(--border);color:var(--text);padding:6px 12px;border-radius:6px;cursor:pointer;font-size:0.9rem;font-weight:700;transition:all .15s}.an-date-btn:hover:not(:disabled){background:var(--blue);color:#fff;border-color:var(--blue)}.an-date-btn:disabled{opacity:0.3;cursor:not-allowed}.an-range-btn{background:var(--card);border:1px solid var(--border);color:var(--muted);padding:5px 12px;border-radius:6px;cursor:pointer;font-size:0.75rem;font-weight:600;transition:all .15s}.an-range-btn:hover{color:var(--text);border-color:var(--text)}.an-range-btn.active{background:var(--blue);color:#fff;border-color:var(--blue)}.an-panel-right{order:-1}.an-panel-left{order:0}.an-panel-mid{order:1}
.news-list-mode{display:flex;flex-direction:column;gap:1px}
.news-list-mode .news-card{display:flex;flex-direction:row;border-radius:8px;overflow:hidden}
.news-list-mode .news-card-img{width:160px;min-width:160px;height:auto;min-height:100px;object-fit:cover}
.news-list-mode .news-card-body{padding:12px 16px;flex:1}
.news-list-mode .news-card-summary{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.news-grid-mode{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:16px}
.news-view-btn{background:var(--card);border:1px solid var(--border);color:var(--muted);padding:6px 8px;border-radius:6px;cursor:pointer;transition:all .15s;display:flex;align-items:center}
.news-view-btn:hover{color:var(--text)}
.news-view-btn.active{background:var(--blue);color:#fff;border-color:var(--blue)}

[data-theme="light"]{--bg:#f5f5f5;--card:#ffffff;--border:#e0e0e0;--text:#1a1a1a;--muted:#666666;--green:#059669;--red:#dc2626;--blue:#2563eb;--yellow:#d97706}
[data-theme="light"] .sidebar{background:#fff;border-color:#e0e0e0}
[data-theme="light"] .sidebar-nav li a:hover{background:rgba(0,0,0,0.04)}
[data-theme="light"] .sidebar-nav li a.active{background:rgba(0,0,0,0.06)}
[data-theme="light"] .news-card{background:#fff;border-color:#e0e0e0}
[data-theme="light"] .stock-card{background:#fff;border-color:#e0e0e0}
[data-theme="light"] .an-panel{background:#fff;border-color:#e0e0e0}
[data-theme="light"] input,[data-theme="light"] select{background:#fff !important;color:#1a1a1a !important;border-color:#d0d0d0 !important}
[data-theme="light"] .stock-table th{background:#f0f0f0;color:#333}
[data-theme="light"] .stock-table td{border-color:#eee}
[data-theme="light"] .auth-box{background:#fff;border-color:#e0e0e0}
[data-theme="light"] canvas{filter:none}
[data-theme="light"] .sc-spark{background:rgba(0,0,0,0.02)}
[data-theme="light"] .an-stat{background:#f8f8f8;border-color:#e0e0e0}
[data-theme="light"] .an-demand-cell{background:rgba(5,150,105,0.06) !important}
[data-theme="light"] .an-supply-cell{background:rgba(220,38,38,0.06) !important}
[data-theme="light"] .an-demand-th{background:rgba(5,150,105,0.12) !important}
[data-theme="light"] .an-supply-th{background:rgba(220,38,38,0.12) !important}
@media(max-width:768px){.news-list-mode .news-card{flex-direction:column}.news-list-mode .news-card-img{width:100%;min-width:unset;height:140px}}
@keyframes pfHighlight{0%{box-shadow:0 0 0 3px var(--blue)}50%{box-shadow:0 0 20px 3px var(--blue)}100%{box-shadow:none}}
/* --- Shared Page Styles --- */
.blur-amount { filter: blur(8px); user-select: none; pointer-events: none; }
.shared-page { max-width: 900px; margin: 0 auto; padding: 24px 16px; }
.shared-header { text-align: center; margin-bottom: 32px; padding: 24px; background: var(--card); border: 1px solid var(--border); border-radius: 12px; }
.shared-header h1 { font-size: 1.5rem; margin: 0 0 8px; color: var(--text); }
.shared-header .shared-meta { color: var(--muted); font-size: 0.85rem; }
.shared-header .shared-expiry { display: inline-block; margin-top: 8px; padding: 4px 12px; border-radius: 20px; font-size: 0.75rem; background: rgba(59,130,246,0.1); color: var(--blue); }
.shared-table { width: 100%; border-collapse: collapse; background: var(--card); border: 1px solid var(--border); border-radius: 12px; overflow: hidden; }
.shared-table th { text-align: left; padding: 12px 16px; font-size: 0.75rem; text-transform: uppercase; color: var(--muted); background: rgba(255,255,255,0.03); border-bottom: 1px solid var(--border); font-weight: 600; }
.shared-table td { padding: 12px 16px; font-size: 0.88rem; border-bottom: 1px solid var(--border); }
.shared-table tr:last-child td { border-bottom: none; }
.shared-table .up { color: var(--green); }
.shared-table .down { color: var(--red); }
.shared-footer { text-align: center; margin-top: 32px; padding: 20px; color: var(--muted); font-size: 0.82rem; }
.shared-footer a { color: var(--blue); text-decoration: none; font-weight: 600; }
.shared-footer a:hover { text-decoration: underline; }
.shared-stock-header { display: flex; align-items: baseline; gap: 12px; margin-bottom: 16px; }
.shared-stock-price { font-size: 2rem; font-weight: 800; }
.shared-stock-change { font-size: 1.1rem; font-weight: 600; }
.shared-stats-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); gap: 12px; margin: 20px 0; }
.shared-stat { background: var(--card); border: 1px solid var(--border); border-radius: 10px; padding: 14px; }
.shared-stat-label { font-size: 0.72rem; text-transform: uppercase; color: var(--muted); margin-bottom: 4px; }
.shared-stat-value { font-size: 1rem; font-weight: 700; }
.share-modal-overlay { position: fixed; inset: 0; background: rgba(0,0,0,0.6); z-index: 1000; display: flex; align-items: center; justify-content: center; }
.share-modal { background: var(--card); border: 1px solid var(--border); border-radius: 14px; padding: 28px; width: 90%; max-width: 480px; max-height: 85vh; overflow-y: auto; }
.share-modal h3 { margin: 0 0 20px; font-size: 1.1rem; }
.share-modal .share-option { display: flex; align-items: center; justify-content: space-between; padding: 12px 0; border-bottom: 1px solid var(--border); }
.share-modal .share-option:last-child { border-bottom: none; }
.share-modal .share-option label { font-size: 0.88rem; color: var(--text); }
.share-modal .share-option .share-desc { font-size: 0.75rem; color: var(--muted); margin-top: 2px; }
.share-modal select { background: var(--bg); color: var(--text); border: 1px solid var(--border); border-radius: 8px; padding: 8px 12px; font-size: 0.85rem; }
.share-modal .share-url-box { background: var(--bg); border: 1px solid var(--border); border-radius: 8px; padding: 12px; margin-top: 16px; display: flex; align-items: center; gap: 8px; }
.share-modal .share-url-box input { flex: 1; background: transparent; border: none; color: var(--text); font-size: 0.82rem; outline: none; font-family: monospace; }
.share-modal .share-url-box button { background: var(--blue); color: #fff; border: none; border-radius: 6px; padding: 6px 14px; font-size: 0.8rem; cursor: pointer; font-weight: 600; white-space: nowrap; }
.share-modal .share-btn-primary { width: 100%; padding: 12px; background: var(--green); color: #fff; border: none; border-radius: 8px; font-size: 0.9rem; font-weight: 700; cursor: pointer; margin-top: 16px; }
.share-modal .share-btn-primary:hover { opacity: 0.9; }
.share-modal .share-active-links { margin-top: 20px; }
.share-modal .share-active-links h4 { font-size: 0.82rem; color: var(--muted); text-transform: uppercase; margin: 0 0 10px; }
.share-modal .share-link-item { display: flex; align-items: center; justify-content: space-between; padding: 8px 0; border-bottom: 1px solid var(--border); font-size: 0.82rem; }
.share-modal .share-link-item:last-child { border-bottom: none; }
.share-modal .share-link-revoke { background: none; border: none; color: var(--red); cursor: pointer; font-size: 0.78rem; font-weight: 600; }
.share-toggle { position: relative; width: 44px; height: 24px; background: var(--border); border-radius: 12px; cursor: pointer; transition: background .2s; flex-shrink: 0; }
.share-toggle.on { background: var(--green); }
.share-toggle::after { content: ""; position: absolute; top: 2px; left: 2px; width: 20px; height: 20px; background: #fff; border-radius: 50%; transition: transform .2s; }
.share-toggle.on::after { transform: translateX(20px); }
.pf-share-btn { background: var(--card); border: 1px solid var(--border); border-radius: 8px; padding: 6px 12px; cursor: pointer; display: inline-flex; align-items: center; gap: 5px; font-size: 0.78rem; color: var(--blue); font-weight: 600; transition: all .15s; }
.pf-share-btn:hover { border-color: var(--blue); }
@media(max-width:600px) {
  .shared-stats-grid { grid-template-columns: repeat(2, 1fr); }
  .shared-table { font-size: 0.8rem; }
  .shared-table th, .shared-table td { padding: 8px 10px; }
}

/* ===== MOBILE HEADER BAR ===== */
.mobile-header{display:none}
.mobile-sidebar-overlay{display:none}

@media(max-width:768px){

/* --- Mobile Header --- */
.mobile-header{display:flex;align-items:center;position:fixed;top:0;left:0;right:0;height:52px;background:var(--card);border-bottom:1px solid var(--border);z-index:55;padding:0 12px;padding-top:env(safe-area-inset-top);gap:10px;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);background:rgba(23,23,23,0.95)}
.mobile-hamburger{background:none;border:none;color:var(--text);cursor:pointer;padding:8px;min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent;border-radius:8px}
.mobile-hamburger:active{background:rgba(255,255,255,0.08)}
.mobile-header-logo{cursor:pointer;flex-shrink:0;display:flex;align-items:center}
.mobile-page-title{font-size:0.82rem;font-weight:600;color:var(--muted);margin-left:auto;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mobile-search-btn{background:none;border:none;color:var(--muted);cursor:pointer;padding:8px;min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent;border-radius:8px}
.mobile-search-btn:active{background:rgba(255,255,255,0.08)}

/* --- Sidebar overlay for mobile --- */
.mobile-sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.5);z-index:49;opacity:0;transition:opacity .2s}
.mobile-sidebar-overlay.active{display:block;opacity:1}

/* --- Adjust body and main for mobile header --- */
body{padding-top:calc(52px + env(safe-area-inset-top))!important}
.topbar{display:none!important}
.content{padding-top:12px!important;padding-bottom:calc(80px + env(safe-area-inset-bottom))!important}

/* --- Sidebar improvements for mobile --- */
.sidebar{z-index:51;padding-top:calc(8px + env(safe-area-inset-top));height:100vh;height:100dvh}
.sidebar.open{box-shadow:8px 0 32px rgba(0,0,0,0.3)}

/* --- Content area padding --- */
.page-content{padding:0 2px}
.page-title{font-size:1.2rem!important;line-height:1.3}
.page-subtitle{font-size:0.75rem!important;margin-bottom:12px!important}

/* --- Market toolbar mobile --- */
.market-toolbar{flex-direction:column;align-items:stretch;gap:8px}
.market-toolbar select{width:100%;font-size:0.82rem;min-height:44px}
.market-toolbar .toolbar-right{width:100%;justify-content:space-between}
.data-toggle{width:100%}
.data-toggle button{flex:1}

/* --- Stock grid: 1 column on small screens --- */
.stock-grid{grid-template-columns:1fr!important;gap:8px!important}

/* --- Stock cards compact --- */
.sc{padding:14px!important}
.sc .sym{font-size:0.9rem}
.sc .name{font-size:0.72rem}
.sc .price{font-size:1.05rem}

/* --- Tables horizontal scroll --- */
.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:0 -16px;padding:0 16px}
.stock-table{min-width:600px}

/* --- Stock detail page --- */
.stock-page .sp-header{flex-direction:column;gap:4px;align-items:flex-start}
.stock-page .sp-header h2{font-size:1.3rem!important}
.stock-page .sp-header .sp-market{font-size:0.78rem}
.stock-page .sp-price-row{flex-direction:column;gap:4px;align-items:flex-start}
.stock-page .sp-price{font-size:1.8rem!important}
.stock-page .sp-change{font-size:0.9rem!important}
.stock-page .sp-actions{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:16px}
.stock-page .sp-actions button,.stock-page .sp-actions a{min-height:44px;padding:10px 14px!important;font-size:0.8rem!important}
.stock-page .sp-chart{height:200px!important;margin:0 -8px}
.stock-page .sp-chart canvas{width:100%!important}

/* --- Detail grid: 2 columns --- */
.detail-grid{grid-template-columns:1fr 1fr!important;gap:8px!important}
.detail-item{padding:10px!important}
.detail-item .label{font-size:0.65rem!important}
.detail-item .value{font-size:0.85rem!important}

/* --- Stock page tabs horizontal scroll --- */
.sp-tabs{overflow-x:auto!important;-webkit-overflow-scrolling:touch;flex-wrap:nowrap!important;gap:0!important;scrollbar-width:none;-ms-overflow-style:none}
.sp-tabs::-webkit-scrollbar{display:none}
.sp-tabs button{flex-shrink:0!important;white-space:nowrap!important;padding:10px 16px!important;min-height:44px!important;font-size:0.8rem!important}

/* --- Analysis page --- */
.an-layout{grid-template-columns:1fr!important}
.an-panel{grid-column:1!important}
.an-panel-left{grid-column:1!important}
.an-panel-wide{grid-column:1!important}
.an-stats-row{grid-template-columns:repeat(2,1fr)!important}
.an-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
.an-table-wrap table{min-width:500px}

/* --- Portfolio page --- */
.pf-layout{grid-template-columns:1fr!important}
.pf-sidebar{order:-1!important;grid-template-columns:1fr!important}
.pf-summary{grid-template-columns:1fr!important;gap:8px!important}
.pf-stat{padding:16px!important}
.pf-stat .pf-val{font-size:1.2rem!important}
.pf-stat .pf-label{font-size:0.7rem!important}
.pf-form-grid{grid-template-columns:1fr!important}
.pf-form-grid input,.pf-form-grid select,.pf-form-grid button{min-height:48px!important;font-size:0.9rem!important;padding:12px!important}
.pf-holding{flex-direction:column!important;align-items:flex-start!important;padding:16px!important}
.pf-holding .pf-sym{min-width:auto!important}
.pf-holding-row{width:100%;display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px}
.pf-holding-actions{width:100%;justify-content:flex-end}

/* --- News page --- */
.news-grid{grid-template-columns:1fr!important;gap:10px!important}
.news-list-mode .news-card{flex-direction:column!important}
.news-list-mode .news-card-img{width:100%!important;height:160px!important;border-radius:10px 10px 0 0!important}
.news-list-mode .news-card-body{padding:14px!important}
.news-card-title{font-size:0.88rem!important;line-height:1.4!important}
.news-card-excerpt{font-size:0.78rem!important}
.news-controls{flex-wrap:wrap!important;gap:6px!important}
.news-search{width:100%!important;max-width:100%!important;min-height:44px!important}
.news-filter-btn{min-height:40px!important;padding:8px 14px!important}

/* --- Dividends page mobile --- */
.div-calendar-grid{grid-template-columns:1fr!important}
.div-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}

/* --- Touch improvements --- */
button,a,.sc,.news-card,.wl-stock-card,.pf-holding{-webkit-tap-highlight-color:transparent}
input,select,textarea{font-size:16px!important}
.content{-webkit-overflow-scrolling:touch;overflow-y:auto}
*{-webkit-touch-callout:none}
a,button{touch-action:manipulation}

/* --- Market charts stacking --- */
.market-charts{grid-template-columns:1fr!important;gap:12px!important}
.market-chart-card{padding:16px!important}

/* --- Movers grid --- */
.movers-grid{grid-template-columns:1fr!important;gap:10px!important}
.mover-card{padding:14px!important}

/* --- Indices --- */
.idx-list{gap:8px!important}
.idx-card{min-width:140px!important;padding:12px!important}
.indices-header{flex-direction:column!important;align-items:flex-start!important;gap:8px!important}

/* --- Section cards --- */
.section-card{padding:14px!important;border-radius:10px!important}

/* --- Command palette mobile fix --- */
.cmd-box{margin-top:0!important}

/* --- Order book on stock detail --- */
.order-book{grid-template-columns:1fr!important;gap:10px!important}
.ob-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
.ob-table{min-width:300px}
.ob-metrics{grid-template-columns:1fr!important;gap:8px!important}

/* --- Alerts page --- */
.alerts-grid{grid-template-columns:1fr!important}
.alert-card{padding:14px!important}

/* --- API/Developers page mobile --- */
#page-developers > div[style*="grid-template-columns"]{grid-template-columns:1fr!important}
#page-developers > div[style*="grid-template-columns:1fr 1fr"]{grid-template-columns:1fr!important}

/* --- Docs page mobile --- */
#page-docs div[style*="grid-template-columns:1fr 1fr"]{grid-template-columns:1fr!important}
#page-docs pre{font-size:0.72rem!important}
#page-docs code{font-size:0.75rem!important;word-break:break-all}

/* --- Admin tabs scroll --- */
#adminTabs{overflow-x:auto;-webkit-overflow-scrolling:touch;width:100%!important;flex-wrap:nowrap!important}
#adminTabs button{flex-shrink:0;white-space:nowrap}

/* --- Mobile More Menu --- */
.mobile-more-menu{display:none;position:fixed;inset:0;z-index:65}
.mobile-more-menu.open{display:block !important}
.mobile-more-backdrop{position:absolute;inset:0;background:rgba(0,0,0,0.4)}
.mobile-more-sheet{position:absolute;bottom:0;left:0;right:0;background:var(--card);border-radius:16px 16px 0 0;padding:8px 0 calc(16px + env(safe-area-inset-bottom));animation:sheetUp .2s ease-out;max-height:60vh;overflow-y:auto}
.mobile-more-handle{width:36px;height:4px;background:var(--border);border-radius:2px;margin:6px auto 12px}
.mobile-more-item{display:flex;align-items:center;gap:14px;padding:14px 24px;color:var(--text);font-size:0.9rem;font-weight:500;text-decoration:none;-webkit-tap-highlight-color:transparent;min-height:48px}
.mobile-more-item:active{background:rgba(255,255,255,0.05)}
.mobile-more-item svg{color:var(--muted);flex-shrink:0}
.mobile-more-item.active{color:var(--blue)}
.mobile-more-item.active svg{color:var(--blue)}

/* --- Smooth scrolling --- */
html{scroll-behavior:smooth;-webkit-overflow-scrolling:touch}

/* --- Prevent content overflow --- */
.main{overflow-x:hidden!important;width:100%!important;max-width:100vw!important}

/* --- Shared stats grid mobile --- */
.shared-stats-grid{grid-template-columns:repeat(2,1fr)!important}

/* --- Mover Market Filter mobile --- */
#moverMarketFilter{width:100%;justify-content:center}
#moverMarketFilter button{flex:1;min-height:40px;text-align:center}

}

/* ===== EXTRA SMALL SCREENS ===== */
@media(max-width:400px){
.stock-grid{grid-template-columns:1fr!important}
.detail-grid{grid-template-columns:1fr!important}
.pf-summary{grid-template-columns:1fr!important}
.mobile-tab-bar .tab-item span{font-size:0.58rem!important}
.mobile-tab-bar .tab-item svg{width:20px!important;height:20px!important}
.mobile-tab-bar .tab-item{min-width:48px!important}
.mobile-header-logo svg{width:70px}
.page-title{font-size:1.1rem!important}
.an-stats-row{grid-template-columns:1fr!important}
}
.sp-chart #spChartContainer,.an-chart-wrap #anChartContainer{width:100%!important;height:100%!important;cursor:crosshair}
.sp-chart .tv-lightweight-charts{border-radius:6px}
