@import "https://fonts.googleapis.com/css2?family=Noto+Serif+TC:wght@300;400;600&family=Noto+Sans+TC:wght@300;400;500;700&family=Inter:wght@300;400;600&display=swap";:root{--bg-primary:#fafafa;--bg-secondary:#f3f4f6;--bg-card:#fff;--text-primary:#111;--text-secondary:#6b7280;--accent-matcha:#4a7c59;--accent-indigo:#1a1a2e;--accent-sakura:#f5e6e8;--accent-gold:#c9a84c;--accent-danger:#c0392b;--font-serif:"Noto Serif TC", serif;--font-sans:"Noto Sans TC", sans-serif;--shadow-sm:0 2px 4px #1c2e4a0d;--shadow-md:0 4px 12px #1c2e4a14;--shadow-lg:0 12px 24px #1c2e4a1f;--shadow-glow:0 0 20px #7b8b6f33;--transition-smooth:all .3s cubic-bezier(.4, 0, .2, 1)}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-primary);color:var(--text-primary);font-family:var(--font-sans);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;line-height:1.7}h1,h2,h3,h4,h5,h6{font-family:var(--font-serif);color:var(--accent-indigo);letter-spacing:.05em;font-weight:600}a{color:var(--accent-indigo);transition:var(--transition-smooth);text-decoration:none}button{font-family:var(--font-sans);cursor:pointer;background:0 0;border:none}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.animate-fade-in{animation:.6s ease-out forwards fadeIn}.animate-delay-100{opacity:0;animation-delay:.1s}.animate-delay-200{opacity:0;animation-delay:.2s}.animate-delay-300{opacity:0;animation-delay:.3s}.page-container{max-width:1200px;min-height:calc(100vh - 80px);margin:0 auto;padding:2rem}.section-title{color:var(--accent-indigo);margin-bottom:2rem;font-size:2.5rem;display:inline-block;position:relative}.section-title:after{content:"";background-color:var(--accent-gold);width:40px;height:2px;position:absolute;bottom:-4px;left:0}.card{background-color:var(--bg-card);box-shadow:var(--shadow-sm);transition:var(--transition-smooth);border:1px solid #e5e7eb;border-radius:4px;padding:2rem;position:relative;overflow:hidden}.card:before{content:"";background-color:var(--accent-gold);width:3px;height:0;transition:height .4s cubic-bezier(.4,0,.2,1);position:absolute;top:0;left:0}.card:hover{box-shadow:var(--shadow-md);border-color:#d1d5db;transform:translateY(-2px)}.card:hover:before{height:100%}.grid-3{grid-template-columns:repeat(1,1fr);gap:2rem;display:grid}@media (width>=768px){.grid-3{grid-template-columns:repeat(3,1fr)}}.nav-container{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);z-index:100;background-color:#fafafaeb;border-bottom:1px solid #e5e7eb;position:sticky;top:0}.nav-content{justify-content:space-between;align-items:center;max-width:1200px;height:64px;margin:0 auto;padding:0 2rem;display:flex}.nav-brand{flex-direction:column;gap:2px;display:flex}.nav-logo{font-family:var(--font-serif);color:var(--accent-indigo);letter-spacing:.03em;font-size:1.125rem;font-weight:600;line-height:1}.nav-subtitle{font-family:var(--font-sans);letter-spacing:.18em;text-transform:uppercase;color:var(--accent-gold);font-size:.65rem;font-weight:500}.nav-links{align-items:center;gap:2.5rem;display:flex}.nav-link{color:var(--text-secondary);letter-spacing:.04em;transition:var(--transition-smooth);align-items:center;gap:.4rem;padding:4px 0;font-size:.875rem;font-weight:500;display:flex;position:relative}.nav-link svg{opacity:.7;transition:var(--transition-smooth)}.nav-link:hover{color:var(--accent-indigo)}.nav-link:hover svg{opacity:1}.nav-link.active{color:var(--accent-indigo);font-weight:600}.nav-link.active svg{opacity:1}.nav-link:after{content:"";background-color:var(--accent-gold);width:0;height:1px;transition:width .3s;position:absolute;bottom:-2px;left:0}.nav-link.active:after,.nav-link:hover:after{width:100%}@media (width<=640px){.nav-content{padding:0 1rem}.nav-links{gap:1.5rem}.nav-link span{display:none}}.home-page{text-align:center;flex-direction:column;justify-content:center;align-items:center;min-height:70vh;padding:4rem 1rem;display:flex}.home-greeting{font-family:var(--font-sans);letter-spacing:.25em;text-transform:uppercase;color:var(--accent-gold);margin-bottom:1.5rem;font-size:.875rem;font-weight:500}.home-title{font-family:var(--font-serif);color:var(--accent-indigo);letter-spacing:-.02em;margin-bottom:1.5rem;font-size:clamp(3rem,8vw,5.5rem);font-weight:300;line-height:1.1}.home-title em{color:var(--accent-matcha);font-style:normal;display:inline-block;position:relative}.home-divider{background:var(--accent-gold);width:40px;height:1px;margin:2rem auto}.home-subtitle{font-family:var(--font-sans);color:var(--text-secondary);max-width:480px;margin-bottom:3rem;font-size:1.125rem;font-weight:300;line-height:1.8}.home-tags{flex-wrap:wrap;justify-content:center;gap:1rem;display:flex}.home-tag{letter-spacing:.1em;text-transform:uppercase;color:var(--text-secondary);transition:var(--transition-smooth);border:1px solid #e5e7eb;border-radius:2px;padding:.5rem 1.25rem;font-size:.8rem;font-weight:500}.home-tag:hover{border-color:var(--accent-gold);color:var(--accent-gold)}.tools-header{margin-bottom:4rem}.tools-eyebrow{letter-spacing:.25em;text-transform:uppercase;color:var(--accent-gold);margin-bottom:1rem;font-size:.75rem;font-weight:600;display:block}.tools-subtitle{color:var(--text-secondary);max-width:520px;font-size:1.125rem;font-weight:300;line-height:1.8}.tool-card{flex-direction:column;height:100%;display:flex}.tool-number{font-family:"Inter", var(--font-sans);letter-spacing:.15em;color:var(--accent-gold);margin-bottom:1.5rem;font-size:.75rem;font-weight:600;display:block}.tool-icon-wrapper{width:44px;height:44px;color:var(--accent-indigo);transition:var(--transition-smooth);justify-content:center;align-items:center;margin-bottom:1.25rem;display:flex}.card:hover .tool-icon-wrapper{color:var(--accent-matcha);transform:scale(1.1)}.tool-title{font-family:var(--font-serif);color:var(--text-primary);margin-bottom:.75rem;font-size:1.375rem;font-weight:600;line-height:1.3}.tool-desc{color:var(--text-secondary);flex-grow:1;margin-bottom:1.5rem;font-size:.9rem;line-height:1.8}.tool-tags{flex-wrap:wrap;gap:.4rem;margin-bottom:1.5rem;display:flex}.tool-tag{letter-spacing:.08em;background-color:var(--bg-secondary);color:var(--text-secondary);border-radius:2px;padding:.25rem .6rem;font-size:.7rem;font-weight:500}.tool-link-btn{color:var(--accent-indigo);letter-spacing:.05em;border-bottom:1px solid var(--accent-gold);width:fit-content;transition:var(--transition-smooth);align-items:center;gap:.5rem;padding-bottom:2px;font-size:.875rem;font-weight:600;display:inline-flex}.tool-link-btn:hover{color:var(--accent-matcha);border-color:var(--accent-matcha);gap:.75rem}.chip-panel{border-top:1px solid #e5e7eb;margin-top:1.5rem;padding-top:1.5rem}.chip-section-header{margin-bottom:1.25rem}.chip-section-title{font-family:var(--font-serif);color:var(--accent-indigo);margin:0;font-size:1.125rem;font-weight:600}.chip-section-subtitle{color:var(--text-secondary);margin:.25rem 0 0;font-size:.875rem}.chip-grid{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;display:grid}.chip-item{flex-direction:column;gap:.5rem;display:flex}.chip-label{letter-spacing:.05em;border-radius:2px;width:fit-content;padding:.25rem .5rem;font-size:.75rem;font-weight:600}.chip-label.main{color:#c62828;background-color:#ffebee}.chip-label.foreign{color:#1976d2;background-color:#e3f2fd}.chip-label.trust{color:#f57c00;background-color:#fff3e0}.chip-label.dealer{color:#7b1fa2;background-color:#f3e5f5}.chip-item.highlight{background:linear-gradient(90deg,#fff,#fcfcfc);border:1px solid #fee2e2;border-radius:8px;grid-column:1/-1;padding:1rem}.chip-item.highlight .chip-subchart{height:140px}.chip-subchart{background-color:var(--bg-card);border-radius:4px;width:100%;height:120px}.chart-container{flex-direction:column;gap:.75rem;width:100%;display:flex}.chart-header{border-bottom:1px solid #f0f0f0;flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:.5rem;padding-bottom:1.25rem;display:flex}.chart-title{font-family:var(--font-serif);color:var(--accent-indigo);letter-spacing:.03em;margin:0 0 .4rem;font-size:1.125rem;font-weight:600}.chart-price{font-family:"Inter", var(--font-sans);letter-spacing:-.02em;font-size:2.25rem;font-weight:300;line-height:1}.price-up{color:var(--accent-danger)}.price-down{color:var(--accent-matcha)}.price-summary-bar{align-items:center;gap:2rem;margin-top:.5rem;display:flex}.price-main{align-items:baseline;gap:1rem;display:flex}.price-details{font-family:var(--font-sans);color:var(--text-secondary);gap:1.5rem;display:flex}.detail-row{flex-direction:column;gap:.25rem;display:flex}.detail-item{white-space:nowrap;font-size:.85rem;font-weight:500}.detail-val{color:var(--text-primary);margin-left:.25rem;font-weight:600}.chart-title-row{align-items:baseline;gap:1rem;display:flex}.chart-date{color:var(--text-secondary);font-size:.85rem;font-weight:400}.price-diff{font-size:1.125rem;font-weight:600}.chart-controls{align-items:center;gap:.375rem;display:flex}.chart-btn{letter-spacing:.06em;color:var(--text-secondary);background-color:var(--bg-secondary);transition:var(--transition-smooth);border:1px solid #0000;border-radius:2px;padding:.45rem 1rem;font-size:.8rem;font-weight:500}.chart-btn:hover{color:var(--accent-indigo);border-color:#d1d5db}.chart-btn.active{background-color:var(--accent-indigo);color:#fff;border-color:var(--accent-indigo)}.chart-label{letter-spacing:.12em;text-transform:uppercase;color:var(--text-secondary);margin-bottom:.25rem;font-size:.7rem;font-weight:600;display:block}.main-chart{border-radius:2px;width:100%;height:380px;overflow:hidden}.sub-chart{border-top:1px solid #f0f0f0;border-radius:2px;width:100%;height:160px;padding-top:.25rem;overflow:hidden}.vol-chart{border-top:1px solid #f0f0f0;border-radius:2px;width:100%;height:100px;padding-top:.25rem;overflow:hidden}.mp-card{background:var(--bg-card);box-shadow:var(--shadow-sm);border:1px solid #e5e7eb;border-radius:4px;padding:1.5rem;position:relative;overflow:hidden}.mp-card:before{content:"";background:var(--accent-gold);opacity:.6;width:3px;height:100%;position:absolute;top:0;left:0}.mp-title{font-family:var(--font-serif);color:var(--accent-indigo);margin:0 0 .25rem;font-size:1rem;font-weight:600}.mp-subtitle{color:var(--text-secondary);letter-spacing:.05em;margin-bottom:1rem;font-size:.72rem}.mp-stat-row{gap:1.5rem;margin-bottom:.75rem;display:flex}.mp-stat{flex-direction:column;gap:2px;display:flex}.mp-stat-label{letter-spacing:.08em;text-transform:uppercase;color:var(--text-secondary);font-size:.7rem}.mp-stat-value{font-family:"Inter", var(--font-sans);letter-spacing:-.02em;color:var(--text-primary);font-size:1.4rem;font-weight:300}.mp-stat-value.up{color:var(--accent-danger)}.mp-stat-value.down{color:var(--accent-matcha)}.mp-chart{width:100%;height:160px;overflow:hidden}.dashboard-section{margin-top:3rem}.dashboard-eyebrow{letter-spacing:.25em;text-transform:uppercase;color:var(--accent-gold);margin-bottom:1rem;font-size:.75rem;font-weight:600;display:block}.dashboard-title{font-family:var(--font-serif);color:var(--accent-indigo);margin-bottom:.5rem;font-size:1.75rem}.dashboard-divider{background:var(--accent-gold);width:40px;height:1px;margin-bottom:2rem}.dashboard-grid{grid-template-columns:1fr;gap:1.5rem;display:grid}@media (width>=768px){.dashboard-grid{grid-template-columns:1fr 1fr}}.rocket-scanner-container{border-left:4px solid var(--accent-gold);background:linear-gradient(145deg,#fff 0%,#f9fafb 100%);margin-top:2rem;padding:2rem}.scanner-header{justify-content:space-between;align-items:flex-start;margin-bottom:2rem;display:flex}.scanner-title-group .scanner-badge{background-color:var(--accent-indigo);color:#fff;text-transform:uppercase;letter-spacing:1px;border-radius:2px;margin-bottom:.5rem;padding:2px 10px;font-size:.65rem;font-weight:700;display:inline-block}.scanner-title{margin-bottom:.25rem;font-size:1.5rem}.scanner-subtitle{color:var(--text-secondary);font-size:.9rem}.scan-btn{transition:var(--transition-smooth);border-radius:4px;padding:.75rem 1.5rem;font-size:.9rem;font-weight:600}.scan-btn.primary{background-color:var(--accent-indigo);color:#fff}.scan-btn.secondary{border:1px solid var(--accent-indigo);color:var(--accent-indigo)}.scan-btn:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.scanning-overlay{background:#1a1a2e05;border-radius:4px;flex-direction:column;justify-content:center;align-items:center;padding:4rem 2rem;display:flex}.scan-progress-box{text-align:center;width:100%;max-width:400px}.scan-loader{margin-bottom:2rem;position:relative}.scan-radar{border:2px solid var(--accent-gold);border-radius:50%;width:100px;height:100px;margin:0 auto 1.5rem;position:relative;overflow:hidden}.scan-radar:after{content:"";transform-origin:0 0;background:linear-gradient(#0000 60%,#c9a84c33 100%);width:100%;height:100%;animation:2s linear infinite rotate;position:absolute;top:50%;left:50%}@keyframes rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.scanning-text{color:var(--accent-indigo);font-family:Courier New,Courier,monospace;font-size:1rem;font-weight:700;display:block}.progress-bar-container{background:#e5e7eb;border-radius:2px;height:4px;margin-bottom:.5rem;overflow:hidden}.progress-bar{background:var(--accent-gold);height:100%;transition:width .1s linear}.progress-percentage{color:var(--text-secondary);font-size:.8rem;font-weight:600}.results-grid{grid-template-columns:1fr;gap:1rem;display:grid}.rocket-item{transition:var(--transition-smooth);opacity:0;background:#fff;border:1px solid #f3f4f6;border-radius:4px;grid-template-columns:180px 1fr 250px;align-items:center;padding:1rem;animation:.5s forwards fadeIn;display:grid}.rocket-item:hover{border-color:var(--accent-gold);box-shadow:var(--shadow-sm);transform:translate(4px)}.rocket-wrapper.expanded .rocket-item{border-color:var(--accent-gold);background:var(--bg-secondary);border-bottom:none;border-radius:4px 4px 0 0}.rocket-info{align-items:center;gap:1rem;display:flex}.rocket-rank{font-family:var(--font-serif);color:var(--accent-gold);width:40px;font-size:1.25rem;font-weight:700}.name-group{flex-direction:column;display:flex}.stock-symbol{color:var(--text-secondary);font-size:.75rem;font-weight:600}.stock-name{color:var(--accent-indigo);font-size:1.1rem;font-weight:700}.scan-date-badge{color:var(--accent-indigo);letter-spacing:.3px;white-space:nowrap;background:#f0f4ff;border:1px solid #c7d5f8;border-radius:3px;margin-top:.25rem;padding:1px 7px;font-size:.68rem;font-weight:600;display:inline-block}.rocket-stats{justify-content:center;gap:2rem;display:flex}.stat{flex-direction:column;min-width:80px;display:flex}.stat .label{color:var(--text-secondary);margin-bottom:.25rem;font-size:.7rem}.stat .value{font-size:1rem;font-weight:700}.stat .value.up{color:var(--accent-danger)}.stat .value.down{color:var(--accent-matcha)}.stat .value.pulse{animation:1.5s infinite pulse}@keyframes pulse{0%{transform:scale(1)}50%{color:var(--accent-gold);transform:scale(1.05)}to{transform:scale(1)}}.strength-bar-box{align-items:center;gap:.5rem;display:flex}.strength-bar{background:var(--accent-matcha);border-radius:3px;height:6px;box-shadow:0 0 10px #4a7c594d}.strength-value{color:var(--accent-matcha);font-size:.8rem;font-weight:700}.rocket-reason{border-left:1px solid #f3f4f6;gap:.75rem;padding-left:1.5rem;display:flex;position:relative}.reason-icon{font-size:1rem}.rocket-reason p{color:var(--text-secondary);margin-right:20px;font-size:.85rem;line-height:1.4}.expand-indicator{color:var(--accent-gold);font-size:.7rem;position:absolute;top:50%;right:0;transform:translateY(-50%)}.rocket-details-panel{border:1px solid var(--accent-gold);box-shadow:var(--shadow-sm);background:#fff;border-top:none;border-radius:0 0 4px 4px;margin-bottom:1rem;padding:1.5rem}.details-tabs{border-bottom:1px solid #f3f4f6;gap:1rem;margin-bottom:1.5rem;display:flex}.detail-tab-btn{color:var(--text-secondary);transition:var(--transition-smooth);border-bottom:2px solid #0000;padding:.5rem 1rem;font-size:.85rem;font-weight:600}.detail-tab-btn.active{color:var(--accent-indigo);border-bottom-color:var(--accent-gold)}.main-force-view .stats-row{background:#f9fafb;border-radius:4px;justify-content:space-between;align-items:center;margin-bottom:2rem;padding:1.5rem;display:flex}.big-stat{flex-direction:column;display:flex}.big-stat .stat-label{color:var(--text-secondary);font-size:.8rem;font-weight:600}.big-stat .stat-value{font-size:2rem;font-weight:700;font-family:var(--font-serif)}.big-stat .stat-value.up{color:var(--accent-danger)}.big-stat .stat-value.down{color:var(--accent-matcha)}.mini-stats{gap:2rem;display:flex}.mini-stat{text-align:right;flex-direction:column;display:flex}.mini-stat .m-label{color:var(--text-secondary);font-size:.7rem}.mini-stat span:not(.m-label){font-size:1.1rem;font-weight:700}.mini-stat .up{color:var(--accent-danger)}.mini-stat .down{color:var(--accent-matcha)}.history-table{width:100%}.h-row{border-bottom:1px solid #f9fafb;grid-template-columns:repeat(4,1fr);padding:.75rem;font-size:.85rem;display:grid}.h-header{color:var(--text-secondary);text-transform:uppercase;background:0 0;font-size:.75rem;font-weight:700}.h-date{color:var(--text-primary);font-weight:600}.h-row .up{color:var(--accent-danger)}.h-row .down{color:var(--accent-matcha)}.chips-grid{grid-template-columns:1fr 1fr;gap:1.5rem;display:grid}.chips-card{background:#f9fafb;border-radius:4px;padding:1.25rem}.chips-card h4{color:var(--accent-indigo);margin-bottom:1rem;font-size:.9rem}.progress-group{margin-bottom:1rem}.label-row{justify-content:space-between;margin-bottom:.4rem;font-size:.8rem;display:flex}.p-bar{background:#e5e7eb;border-radius:3px;height:6px;overflow:hidden}.p-fill{background:var(--accent-gold);height:100%}.broker-row{flex-direction:column;gap:.75rem;margin-bottom:1rem;display:flex}.broker-info{justify-content:space-between;font-size:.85rem;display:flex}.broker-info .up{color:var(--accent-danger);font-weight:700}.broker-info .down{color:var(--accent-matcha);font-weight:700}.chip-tip{color:var(--text-secondary);border-left:2px solid var(--accent-gold);background:#fff;border-radius:4px;padding:.75rem;font-size:.75rem}.scan-mode-tabs{border-bottom:1px solid #e5e7eb;gap:.5rem;margin-bottom:1.5rem;padding-bottom:1rem;display:flex}.scan-mode-btn{color:var(--text-secondary);transition:var(--transition-smooth);border:1px solid #e5e7eb;border-radius:20px;padding:.5rem 1.25rem;font-size:.85rem;font-weight:600}.scan-mode-btn.active{background-color:var(--accent-indigo);color:#fff;border-color:var(--accent-indigo)}.scan-mode-btn:not(.active):hover{border-color:var(--accent-gold);color:var(--accent-indigo)}.reversal-legend{color:var(--text-secondary);flex-wrap:wrap;align-items:center;gap:1.5rem;margin-bottom:1rem;font-size:.75rem;display:flex}.legend-item{align-items:center;gap:.4rem;display:flex}.legend-kd-badge{color:#8a6800;background:#fff3cd;border:1px solid #c9a82c;border-radius:3px;padding:1px 6px;font-size:.7rem;font-weight:700;display:inline-block}.dot{border-radius:50%;width:8px;height:8px;display:inline-block}.dot.low{background:var(--accent-matcha)}.dot.now{background:var(--accent-danger)}.kd-box{flex-direction:column;gap:.2rem;display:flex}.kd-values{color:var(--accent-indigo);font-size:.85rem;font-weight:700}.kd-badge{color:#8a6800;letter-spacing:.5px;background:#fff3cd;border:1px solid #c9a82c;border-radius:3px;padding:1px 6px;font-size:.65rem;font-weight:700;display:inline-block}.reversal-timeline{border-left:3px solid var(--accent-gold);background:#f9fafb;border-radius:4px;flex-direction:column;gap:.3rem;min-width:150px;margin-right:1rem;padding:.75rem;display:flex}.timeline-row{align-items:center;gap:.5rem;font-size:.8rem;display:flex}.tl-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.tl-dot.low{background:var(--accent-matcha)}.tl-dot.now{background:var(--accent-danger)}.tl-label{color:var(--text-secondary);flex:1;font-size:.75rem}.tl-price{font-size:.85rem;font-weight:700}.tl-price.up{color:var(--accent-danger)}.tl-price.down{color:var(--accent-matcha)}.timeline-arrow{color:var(--accent-danger);letter-spacing:.5px;padding-left:1.25rem;font-size:.75rem;font-weight:700}.reversal-item .rocket-reason{align-items:flex-start;gap:.75rem;display:flex}.reversal-item .rocket-reason p{flex:1}.scanner-placeholder{text-align:center;background:#f3f4f64d;border-radius:4px;padding:4rem 2rem}.placeholder-icon{filter:grayscale();opacity:.5;margin-bottom:1rem;font-size:2.5rem}.scanner-placeholder p{color:var(--text-secondary);font-style:italic}.mini-kline-wrap{padding-top:.5rem}.mini-kline-legend{flex-wrap:wrap;align-items:center;gap:1.25rem;margin-bottom:.5rem;padding-left:.25rem;font-size:.72rem;font-weight:600;display:flex}.mkl-item{white-space:nowrap}.mkl-up{color:#c0392b}.mkl-down{color:#4a7c59}.mkl-ma5{color:#e67e22}.mkl-ma10{color:#8e44ad}.mkl-range{color:var(--text-secondary);margin-left:auto;font-size:.68rem;font-weight:400}@media (width<=1024px){.rocket-item{grid-template-columns:1fr;gap:1.5rem}.rocket-stats{justify-content:flex-start}.rocket-reason{border-top:1px solid #f3f4f6;border-left:none;padding-top:1rem;padding-left:0}}.etf-tracker-container{border-left:4px solid var(--accent-gold);background:linear-gradient(145deg,#fff 0%,#f9fafb 100%);margin-top:2rem;padding:2rem}.etf-tracker-header{justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem;display:flex}.etf-tracker-badge{background-color:var(--accent-gold);color:#1a1a2e;text-transform:uppercase;letter-spacing:1px;border-radius:2px;margin-bottom:.5rem;padding:2px 10px;font-size:.65rem;font-weight:700;display:inline-block}.etf-tracker-title{margin-bottom:.25rem;font-size:1.5rem}.etf-tracker-subtitle{color:var(--text-secondary);font-size:.9rem}.etf-nav-group{flex-direction:column;align-items:flex-end;gap:.2rem;display:flex}.etf-nav-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-size:.7rem}.etf-nav-value{font-size:1.6rem;font-weight:700;font-family:var(--font-serif);color:var(--accent-indigo)}.etf-selector{gap:.5rem;margin-bottom:.75rem;display:flex}.etf-tab{color:var(--text-secondary);transition:var(--transition-smooth);letter-spacing:.5px;border:2px solid #e5e7eb;border-radius:4px;padding:.45rem 1.25rem;font-family:Courier New,monospace;font-size:.9rem;font-weight:700}.etf-tab.active{color:var(--accent-gold);background-color:#1a1a2e;border-color:#1a1a2e}.etf-tab:not(.active):hover{border-color:var(--accent-gold);color:var(--accent-indigo)}.etf-fullname{color:var(--text-secondary);margin-bottom:1.25rem;padding-left:.25rem;font-size:.8rem}.etf-section-toggle{gap:.5rem;margin-bottom:0;display:flex}.etf-toggle-btn{transition:var(--transition-smooth);color:var(--text-secondary);background:#f3f4f6;border:1px solid #e5e7eb;border-bottom:none;border-radius:4px 4px 0 0;flex:1;padding:.6rem 1rem;font-size:.85rem;font-weight:700}.etf-toggle-btn.buy.active{color:#ff7033;background:#1f1a14;border-color:#1f1a14}.etf-toggle-btn.sell.active{color:#33c058;background:#101e16;border-color:#101e16}.etf-toggle-btn:not(.active):hover{background:#e9ecef}.etf-section-banner{border-radius:0;flex-wrap:wrap;align-items:baseline;gap:.5rem;margin-bottom:0;padding:.75rem 1.25rem;display:flex}.etf-section-banner.buy{background:#1f1a14;border-top:2px solid #ff7033}.etf-section-banner.sell{background:#101e16;border-top:2px solid #33c058}.etf-banner-etf{color:var(--accent-gold);font-family:Courier New,monospace;font-size:.85rem;font-weight:700}.etf-section-banner.buy .etf-banner-dir{color:#ff7033;font-size:.85rem;font-weight:700}.etf-section-banner.sell .etf-banner-dir{color:#33c058;font-size:.85rem;font-weight:700}.etf-banner-summary{color:#c8c8d8;font-size:.82rem;font-weight:400}.etf-stock-list{flex-direction:column;gap:2px;margin-bottom:1rem;display:flex}.etf-stock-row{opacity:0;border-radius:0;grid-template-columns:36px 1fr 1fr 1fr auto;align-items:center;gap:.75rem;padding:.7rem 1.25rem;transition:filter .15s;animation:.4s forwards fadeIn;display:grid}.etf-stock-row.buy{background:#272115}.etf-stock-row.sell{background:#111d14}.etf-stock-row:last-child{border-radius:0 0 4px 4px}.etf-stock-row:hover{filter:brightness(1.18)}.etf-row-rank{color:#686878;font-family:Courier New,monospace;font-size:.8rem;font-weight:700}.etf-row-name{flex-direction:column;gap:.1rem;display:flex}.etf-row-stockname{color:#e8e8f0;font-size:.95rem;font-weight:700}.etf-row-code{color:#888898;font-size:.72rem}.etf-row-amount{flex-direction:column;gap:.1rem;display:flex}.etf-row-amt-val{font-size:1rem;font-weight:700}.etf-row-amt-val.buy{color:#ff7033}.etf-row-amt-val.sell{color:#33c058}.etf-row-shares{color:#888898;font-size:.72rem}.etf-row-tags{flex-wrap:wrap;gap:.35rem;display:flex}.etf-tag{color:#aac;letter-spacing:.3px;white-space:nowrap;background:#ffffff12;border:1px solid #ffffff1f;border-radius:3px;padding:2px 7px;font-size:.68rem;font-weight:600}.etf-row-weight{flex-direction:column;align-items:flex-end;gap:.15rem;display:flex}.etf-weight-label{color:#666676;text-transform:uppercase;letter-spacing:.3px;font-size:.65rem}.etf-weight-val{color:#c8c8d8;font-size:.82rem;font-weight:700}.etf-status-badge{color:#ff6060;background:#ff505026;border:1px solid #ff505066;border-radius:2px;margin-bottom:.1rem;padding:1px 5px;font-size:.62rem;font-weight:700}.etf-disclaimer{color:var(--text-secondary);border-top:1px solid #f3f4f6;margin-top:.5rem;padding-top:.75rem;font-size:.75rem;font-style:italic}@media (width<=900px){.etf-stock-row{grid-template-rows:auto auto;grid-template-columns:32px 1fr 1fr;gap:.5rem;padding:.75rem 1rem}.etf-row-tags{grid-column:1/-1}.etf-row-weight{flex-direction:row;grid-column:1/-1;justify-content:flex-start;gap:.5rem}}@media (width<=600px){.etf-tracker-header{flex-direction:column;gap:.75rem}.etf-nav-group{align-items:flex-start}.etf-banner-summary{display:none}}.investment-header{margin-bottom:2.5rem}.investment-eyebrow{letter-spacing:.25em;text-transform:uppercase;color:var(--accent-gold);margin-bottom:1rem;font-size:.75rem;font-weight:600;display:block}.investment-subtitle{color:var(--text-secondary);margin-top:.5rem;font-size:1rem;font-weight:300}.tabs-container{border-bottom:1px solid #e5e7eb;gap:.25rem;margin-bottom:1.5rem;padding-bottom:0;display:flex;overflow-x:auto}.tab-btn{letter-spacing:.04em;color:var(--text-secondary);transition:var(--transition-smooth);white-space:nowrap;background-color:#0000;border-bottom:2px solid #0000;border-radius:0;align-items:center;gap:.5rem;margin-bottom:-1px;padding:.75rem 1.5rem;font-size:.875rem;font-weight:500;display:flex}.tab-btn:hover{color:var(--accent-indigo)}.tab-btn.active{color:var(--accent-indigo);border-bottom-color:var(--accent-gold);font-weight:600}.tab-content{background-color:var(--bg-card);box-shadow:var(--shadow-sm);border:1px solid #e5e7eb;border-radius:4px;padding:2rem}.data-disclaimer{color:var(--text-secondary);text-align:right;letter-spacing:.03em;margin-top:1.5rem;font-size:.75rem}.cal-page{max-width:1100px}.cal-page-header{margin-bottom:2rem}.cal-eyebrow{background-color:var(--accent-indigo);color:#fff;text-transform:uppercase;letter-spacing:1px;border-radius:2px;margin-bottom:.5rem;padding:2px 10px;font-size:.65rem;font-weight:700;display:inline-block}.cal-subtitle{color:var(--text-secondary);margin-top:.25rem;font-size:.9rem}.cal-controls{border-bottom:1px solid #e5e7eb;flex-wrap:wrap;align-items:center;gap:1rem;margin-bottom:1.5rem;padding-bottom:1rem;display:flex}.cal-month-nav{align-items:center;gap:.75rem;display:flex}.cal-nav-btn{width:32px;height:32px;color:var(--accent-indigo);transition:var(--transition-smooth);border:1px solid #e5e7eb;border-radius:50%;justify-content:center;align-items:center;font-size:1.1rem;display:flex}.cal-nav-btn:hover:not(:disabled){border-color:var(--accent-gold);background:var(--bg-secondary)}.cal-nav-btn:disabled{opacity:.3;cursor:not-allowed}.cal-month-label{font-size:1.1rem;font-weight:700;font-family:var(--font-serif);color:var(--accent-indigo);text-align:center;min-width:120px}.cal-view-toggle{border:1px solid #e5e7eb;border-radius:6px;display:flex;overflow:hidden}.cal-toggle-btn{color:var(--text-secondary);transition:var(--transition-smooth);padding:.4rem .9rem;font-size:.82rem;font-weight:600}.cal-toggle-btn.active{background:var(--accent-indigo);color:#fff}.cal-filter{flex-wrap:wrap;gap:.4rem;display:flex}.cal-filter-btn{color:var(--text-secondary);transition:var(--transition-smooth);border:1px solid #e5e7eb;border-radius:20px;padding:.35rem .85rem;font-size:.8rem;font-weight:600}.cal-filter-btn.active{color:#fff;background:#1a1a2e;border-color:#1a1a2e}.cal-filter-btn.filter-US.active{background:#1a56a3;border-color:#1a56a3}.cal-filter-btn.filter-JP.active{background:#b22222;border-color:#b22222}.cal-filter-btn.filter-TW.active{background:#1a7a40;border-color:#1a7a40}.cal-filter-btn:not(.active):hover{border-color:var(--accent-gold)}.cal-layout{grid-template-columns:1fr 320px;align-items:start;gap:1.5rem;display:grid}.cal-grid-wrap{background:#fff;border:1px solid #e5e7eb;border-radius:8px;overflow:hidden}.cal-dow-row{background:#f9fafb;border-bottom:1px solid #e5e7eb;grid-template-columns:repeat(7,1fr);display:grid}.cal-dow{text-align:center;color:var(--text-secondary);padding:.6rem 0;font-size:.75rem;font-weight:700}.cal-week{border-bottom:1px solid #f3f4f6;grid-template-columns:repeat(7,1fr);display:grid}.cal-week:last-child{border-bottom:none}.cal-day{cursor:pointer;border-right:1px solid #f3f4f6;min-height:80px;padding:.5rem;transition:background .15s;position:relative}.cal-day:last-child{border-right:none}.cal-day.empty{cursor:default;background:#fafafa}.cal-day:not(.empty):hover{background:#f0f4ff}.cal-day.today .cal-day-num{background:var(--accent-indigo);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:26px;height:26px;display:flex}.cal-day.past{background:#fafafa}.cal-day.past .cal-day-num{color:#bbb}.cal-day.selected{border:2px solid var(--accent-indigo);z-index:1;background:#eff3ff;margin:-1px}.cal-day-num{color:var(--text-primary);margin-bottom:.35rem;font-size:.85rem;font-weight:600;display:block}.cal-dots{flex-wrap:wrap;gap:3px;display:flex}.cal-dot{border-radius:50%;width:7px;height:7px;display:inline-block}.cal-dot.dot-high{width:9px;height:9px}.cal-dot.dot-US{background:#2980b9}.cal-dot.dot-JP{background:#c0392b}.cal-dot.dot-TW{background:#27ae60}.cal-dot-more{color:var(--text-secondary);font-size:.6rem;font-weight:700}.cal-day-panel{background:#fff;border:1px solid #e5e7eb;border-radius:8px;max-height:600px;overflow:hidden auto}.cal-panel-header{z-index:5;background:#f9fafb;border-bottom:1px solid #e5e7eb;padding:1rem;position:sticky;top:0}.cal-panel-date{color:var(--accent-indigo);font-size:.9rem;font-weight:700}.cal-panel-empty{color:var(--text-secondary);margin-top:.25rem;font-size:.8rem;font-style:italic}.cal-panel-events{flex-direction:column;gap:.5rem;padding:.75rem;display:flex}.cal-list-view{flex-direction:column;gap:1.5rem;display:flex}.cal-list-empty{text-align:center;color:var(--text-secondary);padding:3rem;font-style:italic}.cal-list-group{padding:0}.cal-list-date-row{border-bottom:2px solid #e5e7eb;align-items:center;gap:.75rem;margin-bottom:.75rem;padding-bottom:.5rem;display:flex}.cal-list-group.list-today .cal-list-date-row{border-bottom-color:var(--accent-indigo)}.cal-list-date-label{font-size:1rem;font-weight:700;font-family:var(--font-serif);color:var(--text-primary)}.cal-list-group.list-past .cal-list-date-label{color:#999}.cal-today-badge{background:var(--accent-indigo);color:#fff;text-transform:uppercase;letter-spacing:.5px;border-radius:10px;padding:2px 8px;font-size:.65rem;font-weight:700}.cal-past-badge{color:#999;background:#e5e7eb;border-radius:10px;padding:2px 8px;font-size:.65rem;font-weight:600}.cal-list-events{flex-direction:column;gap:.5rem;display:flex}.ev-card{transition:var(--transition-smooth);background:#f9fafb;border-left:3px solid #e5e7eb;border-radius:0 6px 6px 0;padding:.75rem 1rem}.ev-card:hover{box-shadow:var(--shadow-sm);transform:translate(2px)}.ev-card.ev-US{border-left-color:#2980b9}.ev-card.ev-JP{border-left-color:#c0392b}.ev-card.ev-TW{border-left-color:#27ae60}.ev-card.ev-high{background:#fff;box-shadow:0 1px 4px #0000000f}.ev-card.ev-past{opacity:.85}.ev-card-top{justify-content:space-between;align-items:center;margin-bottom:.35rem;display:flex}.ev-badges{align-items:center;gap:.4rem;display:flex}.ev-imp{letter-spacing:.3px;border-radius:3px;padding:1px 6px;font-size:.65rem;font-weight:700}.ev-imp-high{color:#c0392b;background:#fde8e8}.ev-imp-medium{color:#b07d00;background:#fef3cd}.ev-imp-low{color:#6b7280;background:#f3f4f6}.ev-flag{font-size:.9rem}.ev-cat-icon{font-size:.85rem}.ev-time{color:var(--text-secondary);background:#e5e7eb;border-radius:3px;padding:1px 6px;font-family:Courier New,monospace;font-size:.7rem;font-weight:600}.ev-title{color:var(--text-primary);margin-bottom:.3rem;font-size:.9rem;font-weight:700;line-height:1.3}.ev-desc{color:var(--text-secondary);margin-bottom:.5rem;font-size:.78rem;line-height:1.45}.ev-data-row{flex-wrap:wrap;gap:.5rem;display:flex}.ev-data{border-radius:4px;flex-direction:column;flex:1;gap:.1rem;min-width:70px;padding:.3rem .6rem;font-size:.78rem;font-weight:700;display:flex}.ev-data span:first-child{text-transform:uppercase;letter-spacing:.5px;opacity:.7;font-size:.62rem;font-weight:600}.ev-data.actual{color:#065f46;background:#d1fae5}.ev-data.forecast{color:#1e40af;background:#eff6ff}.ev-data.previous{color:#374151;background:#f3f4f6}.cal-legend{color:var(--text-secondary);border-top:1px solid #f3f4f6;flex-wrap:wrap;align-items:center;gap:1.25rem;margin-top:1.5rem;padding-top:1rem;font-size:.75rem;display:flex}.cal-legend .legend-item{align-items:center;gap:.4rem;display:flex}.cal-legend-sep{margin-left:auto;font-size:.7rem;font-style:italic}@media (width<=900px){.cal-layout{grid-template-columns:1fr}.cal-day-panel{max-height:none}.cal-controls{flex-direction:column;align-items:flex-start}}@media (width<=600px){.cal-day{min-height:55px;padding:.3rem}.cal-day-num{font-size:.75rem}.cal-dot{width:5px;height:5px}.cal-dot.dot-high{width:7px;height:7px}}.app-layout{flex-direction:column;min-height:100vh;display:flex}
