@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&family=JetBrains+Mono:wght@400;500;600;700&display=swap";:root{--bg-deep: #0b0e11;--bg-primary: #0f1114;--bg-secondary: #161a1e;--bg-card: #1a1d23;--bg-card-hover: #1f2229;--bg-glass: rgba(26, 29, 35, .95);--bg-glass-border: rgba(255, 255, 255, .06);--bg-input: #1a1d23;--bg-elevated: #22252b;--bg-table-header: #141618;--bg-table-row-even: rgba(255, 255, 255, .015);--bg-table-hover: rgba(255, 255, 255, .04);--text-primary: #e5e7eb;--text-secondary: #9ca3af;--text-muted: #6b7280;--text-dim: #4b5563;--text-inverse: #111827;--accent-blue: #3b82f6;--accent-blue-soft: rgba(59, 130, 246, .1);--accent-blue-medium: rgba(59, 130, 246, .2);--accent-indigo: #6366f1;--accent-purple: #8b5cf6;--accent-cyan: #22d3ee;--color-up: #00c853;--color-up-bg: rgba(0, 200, 83, .1);--color-up-medium: rgba(0, 200, 83, .2);--color-down: #ff3d57;--color-down-bg: rgba(255, 61, 87, .1);--color-down-medium: rgba(255, 61, 87, .15);--color-neutral: #6b7280;--color-warning: #f59e0b;--shadow-xs: 0 1px 2px rgba(0,0,0,.3);--shadow-sm: 0 1px 3px rgba(0,0,0,.4), 0 1px 2px rgba(0,0,0,.3);--shadow-md: 0 4px 16px rgba(0,0,0,.5), 0 1px 4px rgba(0,0,0,.3);--shadow-lg: 0 12px 32px rgba(0,0,0,.6), 0 2px 8px rgba(0,0,0,.3);--shadow-xl: 0 24px 56px rgba(0,0,0,.7), 0 4px 16px rgba(0,0,0,.4);--shadow-card: 0 1px 3px rgba(0,0,0,.3), 0 0 0 1px rgba(255,255,255,.04);--shadow-glow-blue: 0 0 0 3px rgba(59,130,246,.2);--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--space-12: 48px;--space-16: 64px;--radius-xs: 4px;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-full: 9999px;--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "JetBrains Mono", "SF Mono", "Fira Code", monospace;--text-2xs: .625rem;--text-xs: .6875rem;--text-sm: .75rem;--text-base: .8125rem;--text-md: .875rem;--text-lg: 1rem;--text-xl: 1.125rem;--text-2xl: 1.375rem;--text-3xl: 1.75rem;--transition-fast: .1s ease;--transition-base: .2s ease;--transition-slow: .35s ease;--z-base: 1;--z-dropdown: 100;--z-sticky: 200;--z-modal: 500;--z-toast: 600}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}body{font-family:var(--font-family);background:var(--bg-deep);color:var(--text-primary);line-height:1.5;min-height:100vh;overflow-x:hidden}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#ffffff1f;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#fff3}*{scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.12) transparent}#app{display:flex;flex-direction:column;min-height:100vh}.app-main{max-width:1440px;margin:0 auto;padding:var(--space-5) var(--space-6);width:100%;display:flex;flex-direction:column;gap:var(--space-5)}.app-header{display:flex;align-items:center;padding:var(--space-3) var(--space-6);background:var(--bg-primary);border-bottom:1px solid rgba(255,255,255,.06);position:sticky;top:0;z-index:var(--z-sticky);min-height:52px;gap:var(--space-4);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.header-brand{display:flex;align-items:center;gap:var(--space-3);flex-shrink:0}.header-logo{width:36px;height:36px;border-radius:var(--radius-sm);background:linear-gradient(135deg,#3b82f6,#6366f1);display:flex;align-items:center;justify-content:center}.header-logo svg{width:18px;height:18px;color:#fff}.header-title{font-weight:800;font-size:var(--text-lg);color:var(--text-primary);letter-spacing:-.02em}.header-subtitle{font-size:var(--text-2xs);color:var(--text-dim);font-weight:600;text-transform:uppercase;letter-spacing:.08em}.header-center{flex:1;max-width:400px;margin:0 auto}.search-input-group{display:flex;align-items:center;gap:var(--space-2);background:var(--bg-secondary);border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-sm);padding:6px var(--space-3);transition:all var(--transition-fast)}.search-input-group:focus-within{border-color:var(--accent-blue);box-shadow:var(--shadow-glow-blue)}.search-icon{color:var(--text-dim);flex-shrink:0}.search-icon svg{width:14px;height:14px}.search-input{border:none;outline:none;background:transparent;font-family:var(--font-family);font-size:var(--text-sm);color:var(--text-primary);width:100%;min-width:0}.search-input::placeholder{color:var(--text-dim)}.search-shortcut{font-size:10px;font-family:var(--font-mono);color:var(--text-dim);background:#ffffff0f;padding:2px 6px;border-radius:var(--radius-xs);flex-shrink:0;border:1px solid rgba(255,255,255,.08)}.header-right{display:flex;align-items:center;gap:var(--space-3);flex-shrink:0}.market-status-badge{display:inline-flex;align-items:center;gap:var(--space-1);font-size:var(--text-xs);font-weight:700;padding:4px var(--space-3);border-radius:var(--radius-full);white-space:nowrap;text-transform:uppercase;letter-spacing:.04em}.market-status-badge.open{background:var(--color-up-bg);color:var(--color-up);border:1px solid rgba(0,200,83,.2)}.market-status-badge.closed{background:var(--color-down-bg);color:var(--color-down);border:1px solid rgba(255,61,87,.2)}.status-dot{width:6px;height:6px;border-radius:50%;animation:pulse-dot 2s ease-in-out infinite}.market-status-badge.open .status-dot{background:var(--color-up)}.market-status-badge.closed .status-dot{background:var(--color-down)}.last-update{font-size:var(--text-xs);font-family:var(--font-mono);color:var(--text-dim);white-space:nowrap}.search-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--bg-elevated);border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);max-height:320px;overflow-y:auto;z-index:var(--z-dropdown)}.search-result-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);cursor:pointer;transition:background var(--transition-fast);border-bottom:1px solid rgba(255,255,255,.04)}.search-result-item:hover,.search-result-item.active{background:var(--bg-table-hover)}.search-result-ticker{font-weight:700;font-family:var(--font-mono);font-size:var(--text-sm);color:var(--accent-blue);min-width:56px}.search-result-name{font-size:var(--text-xs);color:var(--text-muted);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.market-overview{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-4)}.overview-card{background:var(--bg-card);border:1px solid rgba(255,255,255,.06);border-radius:var(--radius-md);padding:var(--space-4) var(--space-5);position:relative;overflow:hidden;transition:all var(--transition-base)}.overview-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px}.overview-card.ihsg:before{background:linear-gradient(90deg,#3b82f6,#60a5fa)}.overview-card.lq45:before{background:linear-gradient(90deg,#10b981,#34d399)}.overview-card.idx30:before{background:linear-gradient(90deg,#6366f1,#818cf8)}.overview-card.stats:before{background:linear-gradient(90deg,#f59e0b,#fbbf24)}.overview-card:hover{border-color:#ffffff1a;transform:translateY(-1px);box-shadow:var(--shadow-md)}.overview-card-label{font-size:var(--text-xs);font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;display:flex;align-items:center;gap:var(--space-1);margin-bottom:var(--space-2)}.overview-card-label svg{width:14px;height:14px}.overview-card-value{font-size:var(--text-2xl);font-weight:800;font-family:var(--font-mono);letter-spacing:-.02em;color:var(--text-primary)}.overview-card-change{display:inline-flex;align-items:center;gap:var(--space-1);font-size:var(--text-sm);font-weight:700;padding:2px 0;margin-top:var(--space-1)}.overview-card-change.up{color:var(--color-up)}.overview-card-change.down{color:var(--color-down)}.overview-card-change.neutral{color:var(--color-neutral)}.overview-card-meta{display:flex;gap:var(--space-4);margin-top:var(--space-3);padding-top:var(--space-3);border-top:1px solid rgba(255,255,255,.06)}.overview-meta-item{display:flex;flex-direction:column;gap:2px}.overview-meta-label{font-size:var(--text-xs);color:var(--text-dim);font-weight:500}.overview-meta-value{font-size:var(--text-sm);font-weight:700;font-family:var(--font-mono);color:var(--text-secondary)}.stat-row{display:flex;gap:var(--space-6);margin-top:var(--space-2)}.stat-item{display:flex;align-items:center;gap:var(--space-1);font-size:var(--text-sm);font-weight:700}.stock-section{display:flex;flex-direction:column;gap:var(--space-3)}.stock-toolbar{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);flex-wrap:wrap}.toolbar-left{display:flex;align-items:center;gap:var(--space-3);flex-wrap:wrap}.toolbar-right{display:flex;align-items:center;gap:var(--space-3)}.sector-tabs{display:flex;gap:4px;overflow-x:auto;scrollbar-width:none;padding:2px}.sector-tabs::-webkit-scrollbar{display:none}.sector-tab{padding:5px 12px;font-size:var(--text-xs);font-weight:600;color:var(--text-muted);border:1px solid transparent;border-radius:var(--radius-full);cursor:pointer;white-space:nowrap;transition:all var(--transition-fast);background:transparent;font-family:var(--font-family)}.sector-tab:hover{color:var(--text-primary);background:#ffffff0f}.sector-tab.active{color:var(--accent-blue);background:var(--accent-blue-soft);border-color:#3b82f64d;font-weight:700}.stock-count-badge{font-size:var(--text-xs);font-weight:600;color:var(--text-dim);font-family:var(--font-mono)}.stock-table-container{border-radius:var(--radius-md);background:var(--bg-card);border:1px solid rgba(255,255,255,.06);overflow:hidden}.desktop-table{display:block}.mobile-cards{display:none}.stock-table{width:100%;border-collapse:collapse}.stock-table thead{position:sticky;top:0;z-index:2}.stock-table th.text-center,.stock-table td.text-center{text-align:center}.stock-table th{padding:8px 12px;background:var(--bg-table-header);font-size:var(--text-xs);font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;text-align:left;border-bottom:1px solid rgba(255,255,255,.08);white-space:nowrap;cursor:pointer;-webkit-user-select:none;user-select:none;transition:color var(--transition-fast)}.stock-table th:hover{color:var(--text-secondary)}.stock-table th.sorted{color:var(--accent-blue)}.sortable-th{cursor:pointer;-webkit-user-select:none;user-select:none}.sortable-th:hover{color:var(--text-primary)!important}.stock-table th.text-right,.stock-table td.text-right{text-align:right}.stock-table td{padding:6px 12px;font-size:var(--text-sm);border-bottom:1px solid rgba(255,255,255,.04);white-space:nowrap;transition:background var(--transition-fast);color:var(--text-secondary)}.stock-table tbody tr:nth-child(2n){background:var(--bg-table-row-even)}.stock-table tbody tr{cursor:pointer;transition:background var(--transition-fast)}.stock-table tbody tr:hover{background:var(--bg-table-hover)}.stock-table tbody tr:active{background:#ffffff0f}.col-rank{width:40px}.saham-cell{display:flex;align-items:center;gap:var(--space-2)}.saham-info{display:flex;flex-direction:column;gap:0;min-width:72px;flex-shrink:0}.saham-chart-change{display:flex;align-items:center;gap:6px;flex-shrink:0}.sparkline-canvas{width:40px;height:18px;display:block;flex-shrink:0}.rank-badge{font-size:var(--text-xs);font-weight:600;color:var(--text-dim);font-family:var(--font-mono)}.stock-ticker{font-weight:700;font-family:var(--font-mono);font-size:var(--text-sm);color:var(--accent-blue);letter-spacing:.01em;line-height:1.2}.stock-name{font-size:10px;color:var(--text-dim);max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.2}.stock-price{font-weight:700;font-family:var(--font-mono);font-size:var(--text-sm);color:var(--text-primary)}.stock-change{display:inline-flex;align-items:center;gap:2px;font-weight:600;font-size:var(--text-xs);font-family:var(--font-mono);white-space:nowrap}.stock-change.up{color:var(--color-up)}.stock-change.down{color:var(--color-down)}.stock-change.neutral{color:var(--color-neutral)}.stock-net-income{font-family:var(--font-mono);font-size:var(--text-sm);color:var(--text-secondary)}.stock-net-income.up{color:var(--color-up)}.stock-net-income.down{color:var(--color-down)}.stock-growth{font-family:var(--font-mono);font-size:var(--text-sm);font-weight:700;color:var(--text-dim)}.stock-growth.up{color:var(--color-up)}.stock-growth.down{color:var(--color-down)}.stock-volume,.stock-mcap,.stock-bid{font-family:var(--font-mono);font-size:var(--text-sm);color:var(--text-secondary)}.mobile-cards{width:100%;overflow:hidden}.stock-card{display:flex;flex-direction:column;gap:4px;padding:var(--space-3) var(--space-4);border-bottom:1px solid rgba(255,255,255,.04);cursor:pointer;transition:background var(--transition-fast);-webkit-tap-highlight-color:transparent;overflow:hidden;width:100%;box-sizing:border-box}.stock-card:active{background:#ffffff0f}.stock-card:last-child{border-bottom:none}.stock-card-top{display:flex;align-items:center;gap:var(--space-2);width:100%;min-width:0}.stock-card-rank{font-size:var(--text-xs);font-weight:600;color:var(--text-dim);font-family:var(--font-mono);flex-shrink:0;min-width:20px}.stock-card-ticker{font-weight:700;font-family:var(--font-mono);font-size:var(--text-sm);color:var(--accent-blue);flex-shrink:0}.stock-card-name{font-size:var(--text-xs);color:var(--text-dim);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0;flex:1}.stock-card-bottom{display:flex;align-items:center;justify-content:space-between;gap:var(--space-2);padding-left:28px;width:100%;min-width:0}.stock-card-price{font-weight:700;font-family:var(--font-mono);font-size:var(--text-sm);color:var(--text-primary);flex-shrink:0}.stock-card-bottom .stock-change{font-size:var(--text-xs);flex-shrink:0}.stock-card-mcap{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-muted);text-align:right;flex-shrink:0}.pagination{display:flex;align-items:center;justify-content:center;gap:var(--space-1);padding:var(--space-3) var(--space-4);border-top:1px solid rgba(255,255,255,.04)}.pagination-btn{display:inline-flex;align-items:center;justify-content:center;min-width:32px;height:32px;padding:0 var(--space-2);font-size:var(--text-xs);font-weight:600;font-family:var(--font-mono);color:var(--text-muted);background:transparent;border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast)}.pagination-btn:hover:not(:disabled){color:var(--text-primary);background:#ffffff0f;border-color:#ffffff26}.pagination-btn.active{background:var(--accent-blue);color:#fff;border-color:var(--accent-blue)}.pagination-btn:disabled{opacity:.3;cursor:not-allowed}.pagination-info{font-size:var(--text-xs);color:var(--text-dim);padding:0 var(--space-1)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;z-index:var(--z-modal);display:flex;align-items:center;justify-content:center;padding:var(--space-6);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .15s ease-out}.modal-content{background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid rgba(255,255,255,.08);max-width:720px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-xl);animation:scaleIn .2s ease-out}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-5) var(--space-6);border-bottom:1px solid rgba(255,255,255,.06)}.modal-title-group{display:flex;flex-direction:column;gap:2px}.modal-ticker{font-size:var(--text-2xl);font-weight:800;font-family:var(--font-mono);color:var(--text-primary);letter-spacing:-.01em}.modal-company-name{font-size:var(--text-sm);color:var(--text-muted)}.modal-close-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);border:1px solid rgba(255,255,255,.08);background:transparent;color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast)}.modal-close-btn:hover{background:#ffffff0f;color:var(--text-primary)}.modal-price-section{padding:var(--space-4) var(--space-6);border-bottom:1px solid rgba(255,255,255,.06);display:flex;align-items:baseline;gap:var(--space-3)}.modal-current-price{font-size:var(--text-3xl);font-weight:800;font-family:var(--font-mono);color:var(--text-primary)}.modal-price-change{font-size:var(--text-lg);font-weight:700;font-family:var(--font-mono)}.modal-price-change.up{color:var(--color-up)}.modal-price-change.down{color:var(--color-down)}.modal-tabs{display:flex;padding:var(--space-2) var(--space-6);border-bottom:1px solid rgba(255,255,255,.06);gap:var(--space-1)}.modal-tab{padding:var(--space-2) var(--space-4);font-size:var(--text-xs);font-weight:600;color:var(--text-muted);cursor:pointer;border-radius:var(--radius-sm);border:none;background:transparent;font-family:var(--font-family);transition:all var(--transition-fast)}.modal-tab:hover{color:var(--text-primary);background:#ffffff0a}.modal-tab.active{color:var(--text-primary);background:#ffffff14}.modal-tab-content{display:none}.modal-tab-content.active{display:block}.chart-container{width:100%;height:280px;padding:var(--space-4)}.chart-period-selector{display:flex;gap:var(--space-1);padding:0 var(--space-4) var(--space-3)}.period-btn{padding:4px 10px;font-size:var(--text-xs);font-family:var(--font-mono);font-weight:600;color:var(--text-muted);border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-sm);cursor:pointer;background:transparent;transition:all var(--transition-fast)}.period-btn:hover{color:var(--text-primary);border-color:#ffffff26}.period-btn.active{background:var(--accent-blue);color:#fff;border-color:var(--accent-blue)}.financials-section{display:flex;flex-direction:column;gap:var(--space-4)}.fin-table{width:100%;border-collapse:collapse;font-size:var(--text-sm);margin-top:var(--space-4)}.fin-table th{padding:var(--space-2) var(--space-3);text-align:right;font-size:var(--text-xs);font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid rgba(255,255,255,.08)}.fin-table th:first-child{text-align:left}.fin-table td{padding:var(--space-2) var(--space-3);text-align:right;font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-secondary);border-bottom:1px solid rgba(255,255,255,.03)}.fin-table td:first-child{text-align:left;font-family:var(--font-family);font-weight:600;color:var(--text-primary)}.fin-table td.up{color:var(--color-up);font-weight:700}.fin-table td.down{color:var(--color-down);font-weight:700}.fin-label{font-weight:600;color:var(--text-primary)}.modal-body{padding:var(--space-5) var(--space-6)}.detail-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--space-3)}.detail-card{padding:var(--space-4);border-radius:var(--radius-md);background:var(--bg-secondary);border:1px solid rgba(255,255,255,.04);display:flex;flex-direction:column;gap:var(--space-2);transition:all var(--transition-fast)}.detail-card:hover{border-color:#ffffff14;transform:translateY(-1px)}.detail-card-label{font-size:var(--text-xs);font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;display:flex;align-items:center;gap:var(--space-1)}.detail-card-label svg{width:12px;height:12px}.detail-card-value{font-size:var(--text-lg);font-weight:700;font-family:var(--font-mono);letter-spacing:-.01em;color:var(--text-primary)}.detail-card-sub{font-size:var(--text-xs);color:var(--text-dim)}.bid-ask-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4);margin-top:var(--space-4)}.bid-card{border-left:3px solid var(--color-up)}.ask-card{border-left:3px solid var(--color-down)}.skeleton{background:linear-gradient(90deg,#ffffff0a 25%,#ffffff14,#ffffff0a 75%);background-size:400% 100%;animation:shimmer 1.5s ease-in-out infinite;border-radius:var(--radius-sm)}.skeleton-text{height:16px;margin-bottom:var(--space-2)}.skeleton-text.lg{height:28px;width:60%}.skeleton-text.sm{height:12px;width:40%}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-16) var(--space-6);text-align:center;color:var(--text-muted)}.empty-state svg{width:48px;height:48px;color:var(--text-dim);margin-bottom:var(--space-4)}.empty-state-title{font-size:var(--text-lg);font-weight:700;margin-bottom:var(--space-2)}.empty-state-text{font-size:var(--text-sm);color:var(--text-dim)}.toast-container{position:fixed;bottom:var(--space-6);right:var(--space-6);z-index:var(--z-toast);display:flex;flex-direction:column;gap:var(--space-2)}.toast{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);background:var(--bg-elevated);border:1px solid rgba(255,255,255,.08);box-shadow:var(--shadow-lg);font-size:var(--text-sm);color:var(--text-primary);animation:slideInRight .3s ease-out;max-width:360px}.toast.success{border-left:3px solid var(--color-up)}.toast.error{border-left:3px solid var(--color-down)}.toast.info{border-left:3px solid var(--accent-blue)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{opacity:0;transform:scale(.96) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(24px)}to{opacity:1;transform:translate(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}@keyframes shimmer{0%{background-position:-400% 0}to{background-position:400% 0}}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.4}}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 1024px){.app-main{padding:var(--space-4);gap:var(--space-4)}.market-overview{grid-template-columns:repeat(2,1fr);gap:var(--space-3)}.overview-card{padding:var(--space-4)}.overview-card-value{font-size:var(--text-xl)}}@media (max-width: 768px){.app-header{flex-wrap:wrap;padding:var(--space-3) var(--space-4);gap:var(--space-2);min-height:48px}.header-center{order:3;max-width:100%;flex-basis:100%;margin-top:var(--space-1)}.header-title{font-size:var(--text-base)}.header-subtitle{display:none}.header-logo{width:32px;height:32px}.header-logo svg{width:16px;height:16px}.last-update{font-size:10px}.search-input-group{padding:8px var(--space-3)}.app-main{padding:var(--space-3);gap:var(--space-3)}.market-overview{display:flex;gap:var(--space-3);overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:var(--space-1)}.market-overview::-webkit-scrollbar{display:none}.overview-card{min-width:200px;flex-shrink:0;scroll-snap-align:start;padding:var(--space-3) var(--space-4)}.overview-card-value{font-size:var(--text-lg)}.overview-card-meta{gap:var(--space-3);margin-top:var(--space-2);padding-top:var(--space-2)}.overview-meta-label{font-size:10px}.overview-meta-value{font-size:var(--text-xs)}.stat-row{gap:var(--space-4)}.stat-item{font-size:var(--text-xs)}.stock-toolbar{flex-direction:column;align-items:stretch;gap:var(--space-2)}.toolbar-left{order:1}.toolbar-right{order:2;justify-content:flex-start}.sector-tabs{gap:4px;padding:2px 0}.sector-tab{padding:5px 10px;font-size:11px;border-radius:var(--radius-full)}.desktop-table{display:none!important}.mobile-cards{display:block!important}.stock-table-container{border-radius:var(--radius-md);overflow:hidden;max-width:100%;width:100%}.pagination{padding:var(--space-3);gap:var(--space-1)}.pagination-btn{min-width:32px;height:32px;font-size:var(--text-xs)}.modal-overlay{padding:0}.modal-content{max-width:100%;max-height:100dvh;height:100dvh;border-radius:0;animation:slideUp .3s ease-out}.modal-header{padding:var(--space-4)}.modal-ticker{font-size:var(--text-xl)}.modal-price-section{padding:var(--space-3) var(--space-4)}.modal-current-price{font-size:var(--text-2xl)}.modal-price-change{font-size:var(--text-base)}.modal-tabs{overflow-x:auto;padding:var(--space-2) var(--space-4);scrollbar-width:none;-webkit-overflow-scrolling:touch}.modal-tabs::-webkit-scrollbar{display:none}.modal-tab{padding:var(--space-2) var(--space-3);font-size:var(--text-xs);white-space:nowrap}.modal-body{padding:var(--space-4)}.chart-container{height:200px}.detail-grid{grid-template-columns:repeat(2,1fr);gap:var(--space-2)}.detail-card{padding:var(--space-3)}.detail-card-value{font-size:var(--text-base)}.bid-ask-row{gap:var(--space-2)}.financials-section{overflow-x:auto;-webkit-overflow-scrolling:touch}.fin-table{min-width:500px}.fin-table th,.fin-table td{padding:var(--space-2);font-size:10px}.toast-container{bottom:var(--space-4);right:var(--space-4);left:var(--space-4)}.toast{max-width:100%;font-size:var(--text-xs)}}@media (max-width: 480px){.app-main{padding:var(--space-2);gap:var(--space-2)}.overview-card{min-width:176px;padding:var(--space-3)}.overview-card-label{font-size:10px}.overview-card-value{font-size:var(--text-base)}.sector-tab{padding:4px 8px;font-size:10px}.stock-card{padding:var(--space-2) var(--space-3);gap:2px}.stock-card-rank{font-size:10px;min-width:16px}.stock-card-ticker{font-size:var(--text-xs)}.stock-card-name{font-size:9px}.stock-card-bottom{padding-left:24px}.stock-card-price{font-size:var(--text-xs)}.stock-card-bottom .stock-change{font-size:9px}.stock-card-mcap{font-size:10px}.detail-grid,.bid-ask-row{grid-template-columns:1fr}.modal-tabs{gap:0}.chart-container{height:180px}.chart-period-selector{flex-wrap:wrap}.period-btn{font-size:10px;padding:2px 6px}}@media (min-width: 1440px){.app-main{max-width:1600px;padding:var(--space-8)}}
