.landing-layout{color:#1e293b;background-color:#fff;flex-direction:column;min-height:100vh;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;display:flex}.landing-container{width:100%;max-width:1200px;margin:0 auto;padding:0 2rem}.landing-header{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;background-color:#fffffff2;border-bottom:1px solid #f1f5f9;align-items:center;height:80px;display:flex;position:sticky;top:0}.header-inner{justify-content:space-between;align-items:center;width:100%;display:flex}.landing-logo{color:#1e293b;align-items:center;gap:.75rem;text-decoration:none;display:flex}.logo-img{width:auto;height:40px}.logo-text{letter-spacing:-.025em;font-size:1.25rem;font-weight:700}.landing-nav{align-items:center;gap:2rem;display:flex}.nav-item{color:#64748b;font-size:.95rem;font-weight:500;text-decoration:none;transition:color .2s}.nav-item:hover{color:#0f172a}.nav-item.login-btn{color:#fff;background-color:#0f172a;border-radius:8px;padding:.6rem 1.25rem;transition:transform .2s,background-color .2s}.nav-item.login-btn:hover{background-color:#1e293b;transform:translateY(-1px)}.landing-content{flex:1}.landing-footer{background-color:#f8fafc;border-top:1px solid #f1f5f9;padding:4rem 0 2rem}.footer-inner{flex-direction:column;gap:3rem;display:flex}.footer-links{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:2rem;display:grid}.footer-column{flex-direction:column;gap:1rem;display:flex}.footer-column h4{text-transform:uppercase;color:#94a3b8;letter-spacing:.05em;margin-bottom:.5rem;font-size:.9rem;font-weight:700}.footer-column a{color:#475569;font-size:.9rem;text-decoration:none;transition:color .2s}.footer-column a:hover{color:#0f172a}.footer-bottom{text-align:center;border-top:1px solid #e2e8f0;padding-top:2rem}.footer-bottom p{color:#94a3b8;font-size:.875rem}.legal-page-container{max-width:800px;margin:0 auto;padding:4rem 0}.legal-card{background:#fff;border:1px solid #f1f5f9;border-radius:16px;padding:3rem;box-shadow:0 4px 6px -1px #0000001a}.legal-card h1{text-align:center;margin-bottom:2rem;font-size:2rem}.legal-content h4{color:#0f172a;margin:2rem 0 1rem;font-size:1.1rem}.legal-content p{color:#475569;margin-bottom:1rem;line-height:1.7}.legal-table{border-collapse:collapse;width:100%;margin:1.5rem 0}.legal-table th,.legal-table td{text-align:left;border:1px solid #e2e8f0;padding:1rem}.legal-table th{background-color:#f8fafc;width:30%;font-weight:600}.landing-page-hero{text-align:center;background:radial-gradient(circle at 100% 0,#f8fafc 0%,#fff 100%);padding:8rem 0 6rem}.hero-tagline{color:#0f172a;letter-spacing:-.04em;margin-bottom:1.5rem;font-size:3rem;font-weight:800;line-height:1.2}.hero-sub{color:#64748b;margin-bottom:3rem;font-size:1.25rem;line-height:1.6}.cta-group{justify-content:center;gap:1.5rem;display:flex}.btn-hero-primary{color:#fff;background-color:#3b82f6;border-radius:12px;padding:1rem 2.5rem;font-size:1.1rem;font-weight:700;text-decoration:none;transition:all .2s;box-shadow:0 10px 15px -3px #3b82f64d}.btn-hero-primary:hover{background-color:#2563eb;transform:translateY(-2px);box-shadow:0 20px 25px -5px #3b82f666}.btn-hero-secondary{color:#475569;background-color:#f1f5f9;border-radius:12px;padding:1rem 2.5rem;font-size:1.1rem;font-weight:700;text-decoration:none;transition:all .2s}.btn-hero-secondary:hover{color:#0f172a;background-color:#e2e8f0}.features-section,.pricing-section{padding:6rem 0}.section-header{text-align:center;margin-bottom:4rem}.section-title{color:#0f172a;margin-bottom:1rem;font-size:2.25rem;font-weight:800}.section-subtitle{color:#64748b;font-size:1.1rem}.feature-grid{grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:2rem;display:grid}.feature-card{text-align:center;background:#fff;border:1px solid #f1f5f9;border-radius:24px;padding:3rem 2rem;transition:all .3s}.feature-card:hover{border-color:#3b82f6;transform:translateY(-8px);box-shadow:0 20px 25px -5px #0000000d}.feature-icon{margin-bottom:1.5rem;font-size:3rem}.feature-title{color:#0f172a;margin-bottom:1rem;font-size:1.5rem;font-weight:700}.feature-desc{color:#475569;line-height:1.7}.pricing-section{background-color:#f8fafc}.pricing-card-wrapper{max-width:500px;margin:0 auto}.pricing-card{color:#fff;text-align:center;background:linear-gradient(145deg,#0f172a 0%,#1e293b 100%);border-radius:32px;padding:4rem 3rem;position:relative;overflow:hidden;box-shadow:0 25px 50px -12px #00000040}.pricing-card:before{content:"";background:radial-gradient(circle,#3b82f61a 0%,#0000 50%);width:200%;height:200%;position:absolute;top:-50%;left:-50%}.pricing-badge{background:linear-gradient(135deg,#3b82f6,#8b5cf6);border-radius:100px;margin-bottom:2rem;padding:.5rem 1.5rem;font-size:.85rem;font-weight:700;display:inline-block}.pricing-amount{color:#60a5fa;margin-bottom:2.5rem;font-size:3.5rem;font-weight:800}.pricing-period{color:#94a3b8;font-size:1.25rem;font-weight:400}.pricing-features{text-align:left;margin:0 0 3rem;padding:0;list-style:none}.pricing-features li{color:#cbd5e1;padding:.75rem 0 .75rem 2rem;font-size:1.05rem;position:relative}.pricing-features li:before{content:"✓";color:#34d399;font-weight:900;position:absolute;left:0}.btn-pricing-cta{color:#fff;background-color:#3b82f6;border-radius:16px;padding:1.25rem;font-size:1.15rem;font-weight:800;text-decoration:none;transition:all .2s;display:block;position:relative}.btn-pricing-cta:hover{background-color:#2563eb;transform:scale(1.02)}@media (width<=768px){.hero-tagline{font-size:2.25rem}.cta-group{flex-direction:column;padding:0 2rem}}.login-page-container{background-color:#f8fafc;justify-content:center;align-items:center;min-height:calc(100vh - 80px);padding:6rem 1rem;display:flex}.login-card{background:#fff;border:1px solid #f1f5f9;border-radius:24px;width:100%;max-width:440px;padding:3rem;box-shadow:0 20px 25px -5px #0000000d,0 10px 10px -5px #00000005}.login-tabs{background-color:#f1f5f9;border-radius:12px;margin-bottom:2.5rem;padding:.25rem;display:flex}.login-tab{color:#64748b;cursor:pointer;background:0 0;border:none;border-radius:10px;flex:1;padding:.6rem;font-size:.9rem;font-weight:600;transition:all .2s}.login-tab.active{color:#0f172a;background-color:#fff;box-shadow:0 4px 6px -1px #0000001a}.login-title{color:#0f172a;text-align:center;margin-bottom:.5rem;font-size:1.75rem;font-weight:800}.login-subtitle{color:#64748b;text-align:center;margin-bottom:2rem;font-size:.95rem}.auth-alert{border-radius:12px;margin-bottom:1.5rem;padding:1rem;font-size:.9rem;font-weight:500}.auth-alert.error{color:#991b1b;background-color:#fef2f2;border:1px solid #fecaca}.auth-alert.success{color:#166534;background-color:#f0fdf4;border:1px solid #bbf7d0}.login-form{flex-direction:column;gap:1.25rem;display:flex}.form-group input{border:1px solid #e2e8f0;border-radius:10px;padding:.75rem 1rem;font-size:1rem;transition:border-color .2s,box-shadow .2s}.form-group input:focus{border-color:#3b82f6;outline:none;box-shadow:0 0 0 3px #3b82f61a}.auth-submit-btn{color:#fff;cursor:pointer;background-color:#0f172a;border:none;border-radius:12px;margin-top:1rem;padding:1rem;font-size:1rem;font-weight:700;transition:background-color .2s,transform .1s}.auth-submit-btn:hover{background-color:#1e293b}.auth-submit-btn:active{transform:scale(.98)}.auth-submit-btn:disabled{opacity:.7;cursor:not-allowed}.auth-footer{text-align:center;color:#64748b;margin-top:2rem;font-size:.9rem}.auth-link{color:#3b82f6;cursor:pointer;font-weight:600}.auth-link:hover{text-decoration:underline}.metric-header{flex-direction:column;gap:1.5rem;padding:1.5rem;display:flex}.metric-row{flex-wrap:wrap;gap:2rem;display:flex}.metric-col{flex-direction:column;flex:1;min-width:200px;display:flex}.metric-label{color:var(--text-muted);margin-bottom:.25rem;font-size:.85rem}.metric-value{color:var(--text-dark);align-items:baseline;gap:.25rem;font-size:2.2rem;font-weight:500;line-height:1.1;display:flex}.metric-unit{font-size:1rem;font-weight:400}.metric-bubble{border-radius:6px;align-self:flex-start;align-items:center;margin-top:.5rem;padding:.2rem .6rem;font-size:.85rem;font-weight:500;display:inline-flex}.delta-up{background-color:var(--chart-up-bg);color:var(--chart-up)}.delta-down{background-color:var(--chart-down-bg);color:var(--chart-down)}.neutral{color:var(--text-dark);background-color:#94a3b81a}.metric-divider{background-color:var(--border-color);width:100%;height:1px}.metric-row.compact{gap:1.5rem}.metric-col-small{flex:1;min-width:100px}.metric-value-small{color:var(--text-dark);font-size:1.25rem;font-weight:600}.financial-table-wrapper{border:1px solid var(--border-color);border-radius:8px;overflow-x:auto}.financial-table{border-collapse:collapse;text-align:right;width:100%;font-family:Inter,sans-serif;font-size:.9rem}.financial-table th,.financial-table td{border-bottom:1px solid var(--border-color);padding:.75rem 1rem}.financial-table th{color:var(--text-muted);text-align:right;white-space:nowrap;background-color:#f8fafc;font-weight:500}.financial-table th:first-child,.financial-table td:first-child{text-align:left;font-family:Noto Sans JP,sans-serif}.financial-table tbody tr:hover{background-color:#f1f5f9}.financial-table tbody tr:last-child td{border-bottom:none}.row-forecast{background-color:#3b82f608}.badge-forecast{color:#4f46e5;vertical-align:middle;background-color:#e0e7ff;border-radius:4px;margin-left:.5rem;padding:.1rem .4rem;font-size:.75rem;font-weight:600;display:inline-block}.financial-loading,.financial-empty,.financial-error{text-align:center;color:var(--text-muted);border:1px dashed var(--border-color);background-color:#f8fafc;border-radius:8px;padding:2rem}.financial-error{color:var(--chart-down);border-color:var(--chart-down-bg);background-color:#fef2f2}.indicator-container{flex-direction:column;gap:1rem;display:flex}.indicator-tabs{border-bottom:1px solid var(--border-color);gap:.5rem;padding-bottom:0;display:flex}.tab-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;padding:.75rem 1.5rem;font-size:.95rem;font-weight:500;transition:all .2s}.tab-btn:hover{color:var(--text-dark)}.tab-btn.active{color:var(--primary-color);border-bottom-color:var(--primary-color);font-weight:600}.indicator-table{border-collapse:collapse;width:100%}.indicator-table th,.indicator-table td{border-bottom:1px solid var(--border-color);text-align:left;padding:1rem}.indicator-table th{color:var(--text-muted);background-color:#f8fafc;font-size:.9rem;font-weight:500}.ind-name{color:var(--text-dark);font-weight:500}.ind-value{color:var(--text-dark);font-size:1.1rem}.signal-badge{border-radius:20px;padding:.35rem .75rem;font-size:.85rem;font-weight:600;display:inline-block}.signal-badge.success{background-color:var(--chart-up-bg);color:var(--chart-up)}.signal-badge.danger{background-color:var(--chart-down-bg);color:var(--chart-down)}.signal-badge.warning{color:#d97706;background-color:#f59e0b1a}.signal-badge.neutral{color:var(--text-muted);background-color:#f1f5f9}.add-to-bookmark-container{display:inline-block;position:relative}.bookmark-trigger-btn{cursor:pointer;color:#64748b;background:#fff;border:1px solid #e2e8f0;border-radius:8px;justify-content:center;align-items:center;gap:8px;transition:all .2s;display:flex}.bookmark-trigger-btn.icon{width:36px;height:36px;padding:0}.bookmark-trigger-btn.text{white-space:nowrap;min-width:max-content;padding:8px 16px;font-size:.9rem;font-weight:500}.bookmark-trigger-btn:hover{color:#3b82f6;background:#f8fafc;border-color:#3b82f6;transform:translateY(-1px)}.bookmark-trigger-btn.active{color:#3b82f6;background:#eff6ff;border-color:#3b82f6}.bookmark-trigger-btn.success{color:#fff;background:#10b981;border-color:#10b981}.bookmark-dropdown{z-index:1000;width:240px;padding:0;animation:.2s ease-out dropdownIn;position:absolute;top:calc(100% + 8px);right:0;overflow:hidden;box-shadow:0 10px 25px #0000001a}@keyframes dropdownIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.dropdown-header{background:#f8fafc;border-bottom:1px solid #f1f5f9;padding:12px 16px}.dropdown-header h4{color:#64748b;text-transform:uppercase;letter-spacing:.025em;margin:0;font-size:.85rem}.folder-list{max-height:240px;padding:4px;overflow-y:auto}.empty-hint{text-align:center;color:#94a3b8;padding:16px;font-size:.85rem}.folder-item{cursor:pointer;color:#334155;text-align:left;background:0 0;border:none;border-radius:6px;justify-content:space-between;align-items:center;width:100%;padding:10px 12px;transition:background .15s;display:flex}.folder-item:hover{background:#f1f5f9}.folder-item:disabled{opacity:.7;cursor:not-allowed}.folder-item-info{flex-direction:column;max-width:180px;display:flex}.folder-name{font-size:.9rem;font-weight:500}.folder-count{color:#94a3b8;font-size:.75rem}.dropdown-footer{background:#f8fafc;border-top:1px solid #f1f5f9;padding:8px}.create-folder-trigger{color:#64748b;cursor:pointer;background:0 0;border:1px dashed #cbd5e1;border-radius:6px;align-items:center;gap:8px;width:100%;padding:8px 12px;font-size:.85rem;transition:all .2s;display:flex}.create-folder-trigger:hover{color:#3b82f6;background:#fff;border-color:#3b82f6}.create-folder-form{flex-direction:column;gap:6px;display:flex}.create-folder-form input{border:1px solid #e2e8f0;border-radius:4px;outline:none;padding:8px;font-size:.85rem}.create-folder-form input:focus{ring:2px solid #eff6ff;border-color:#3b82f6}.btn-confirm{color:#fff;cursor:pointer;background:#3b82f6;border:none;border-radius:4px;padding:6px;font-size:.85rem}.btn-cancel{color:#94a3b8;cursor:pointer;background:0 0;border:none;font-size:.75rem;text-decoration:underline}.spinner{animation:1s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.stock-analysis-page{flex-direction:column;gap:1.5rem;max-width:1440px;margin:0 auto;padding:1.5rem;display:flex}.page-header{flex-direction:column;gap:1rem;display:flex}.page-header h1{color:var(--text-dark);flex-wrap:wrap;align-items:center;font-size:1.5rem;display:flex}.stock-title-link{color:inherit;cursor:pointer;text-decoration:none;transition:color .2s}.stock-title-link:hover{color:var(--primary-color);text-decoration:underline}.controls-container{box-sizing:border-box;z-index:100;background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;flex-wrap:wrap;align-items:center;gap:2rem;width:100%;padding:1.25rem 2rem;display:flex;position:relative;box-shadow:0 1px 3px #0000000d;overflow:visible!important}.search-bar{flex:1;align-items:center;gap:.5rem;display:flex;position:relative}.search-icon{color:var(--text-muted);position:absolute;left:.75rem}.search-bar input{border:1px solid var(--border-color);border-radius:6px;flex:1;padding:.6rem .6rem .6rem 2.5rem;font-size:1rem}.search-bar input:focus{border-color:var(--primary-color);outline:none}.period-selector label{color:var(--text-muted);font-size:.9rem;font-weight:500}.period-selector select{border:1px solid var(--border-color);background-color:#fff;border-radius:6px;min-width:120px;padding:.5rem;font-size:.9rem}.loading-state{color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:1rem;padding:4rem;display:flex}.error-state{border-left:4px solid var(--chart-down)}.debug-info{background-color:#f1f5f9;border:1px dashed #cbd5e1}.debug-info p{margin-bottom:.5rem}.chart-placeholder{min-height:400px;color:var(--text-muted);border:1px dashed var(--border-color);background-color:#f8fafc;justify-content:center;align-items:center;display:flex}.analysis-content{flex-direction:column;gap:1.5rem;display:flex}.chart-section{flex-direction:column;gap:1rem;display:flex}.section-title{color:var(--text-dark);margin-bottom:.5rem;font-size:1.25rem}.chart-controls{border-bottom:1px solid var(--border-color);flex-wrap:wrap;align-items:center;gap:1.5rem;padding-bottom:1rem;display:flex}.checkbox-label{color:var(--text-dark);cursor:pointer;align-items:center;gap:.5rem;font-size:.9rem;display:flex}.checkbox-label input{cursor:pointer}.sub-chart-selector{align-items:center;gap:.5rem;margin-left:auto;display:flex}.sub-chart-selector label{color:var(--text-muted);font-size:.9rem}.sub-chart-selector select{border:1px solid var(--border-color);background-color:#fff;border-radius:6px;padding:.4rem;font-size:.9rem}.search-wrapper{flex:1;min-width:300px;position:relative}.search-dropdown-menu{border:1px solid var(--border-color);z-index:9999;background-color:#fff;border-radius:6px;max-height:350px;margin:8px 0 0;padding:0;list-style:none;position:absolute;top:100%;left:0;right:0;overflow-y:auto;box-shadow:0 10px 25px #00000026}.search-dropdown-menu li{cursor:pointer;border-bottom:1px solid #00000008;justify-content:space-between;padding:.75rem 1rem;display:flex}.search-dropdown-menu li:last-child{border-bottom:none}.search-dropdown-menu li:hover,.search-dropdown-menu li.active{background-color:#f1f5f9}.search-dropdown-menu li.active{border-left:4px solid var(--primary-color);padding-left:calc(1rem - 4px)}.dropdown-code{color:var(--primary-color);font-weight:600}.dropdown-name{color:var(--text-dark)}.market-badge-new{color:#334155;vertical-align:middle;background-color:#f1f5f9;border:1px solid #e2e8f0;border-radius:4px;align-items:center;margin-left:12px;padding:.2rem .6rem;font-size:.85rem;font-weight:600;line-height:1.4;display:inline-flex}.company-website-link{color:#64748b;align-items:center;margin-left:.5rem;transition:color .2s;display:inline-flex}.company-website-link:hover{color:var(--primary-color)}.tags-section{border:1px solid var(--border-color);background-color:#fff;border-radius:8px}.tags-container{flex-wrap:wrap;gap:.5rem;margin-top:.5rem;display:flex}.theme-tag-badge{color:#1e293b;cursor:default;background-color:#f1f5f9;border:1px solid #e2e8f0;border-radius:9999px;padding:.4rem .8rem;font-size:.85rem;transition:all .2s;display:inline-block}.theme-tag-badge:hover{color:#0f172a;background-color:#e2e8f0}.no-tags-message{color:var(--text-muted);margin:0;font-size:.9rem}.market-overview-page{max-width:1400px;margin:0 auto;padding:1.5rem}.overview-content{flex-direction:column;gap:1.5rem;margin-top:1.5rem;display:flex}.controls-container{box-sizing:border-box;background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;flex-wrap:wrap;align-items:center;width:100%;margin-top:1rem;padding:1.25rem 2rem;display:flex;box-shadow:0 1px 3px #0000000d}.period-selector{align-items:center;gap:1.5rem;display:flex}.period-selector label{color:var(--text-secondary);font-weight:600}.period-radio-group{flex-direction:row;align-items:center;gap:1.5rem;display:flex}.radio-label{cursor:pointer;align-items:center;gap:.5rem;font-size:.95rem;display:flex}.section-header{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.index-summary{margin-bottom:1rem}.index-value{font-size:1.5rem;font-weight:600}.index-delta{margin-left:.5rem;font-size:1.2rem}.index-delta.up{color:#26a69a}.index-delta.down{color:#ef5350}.tengraku-header{margin-bottom:1rem}.tengraku-grid{grid-template-columns:2fr 1fr;gap:1.5rem;display:grid}.tengraku-summary .summary-box{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;padding:1rem}.summary-metrics{flex-direction:column;gap:1rem;margin-top:1rem;display:flex}.summary-metric .metric-label{color:var(--text-secondary);font-size:.9rem}.summary-metric .metric-value{font-size:1.8rem;font-weight:700}.summary-metric .metric-value span{color:var(--text-secondary);font-size:1rem;font-weight:400}.summary-metric .metric-value.up{color:#26a69a}.summary-metric .metric-value.down{color:#ef5350}.industry-ranking{border-top:1px solid var(--border-color);margin-top:1.5rem;padding-top:1.5rem}.ranking-grid{grid-template-columns:1fr 1fr;gap:2rem;margin-top:1rem;display:grid}.ranking-item{border-bottom:1px solid var(--border-color);align-items:center;padding:.5rem;display:flex}.ranking-item:last-child{border-bottom:none}.rank-name{flex:1;font-weight:600}.rank-val{margin:0 .5rem;font-weight:700}.rank-desc{color:var(--text-secondary);font-size:.85rem}.macro-grid{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;display:grid}.macro-card{flex-direction:column;display:flex}.macro-title{color:var(--text-secondary);margin-bottom:.5rem;font-size:1rem}.macro-metrics{align-items:baseline;gap:.5rem;display:flex}.macro-value{font-size:2rem;font-weight:700}.macro-change{font-size:1.1rem;font-weight:600}.macro-nodata{color:var(--text-secondary);padding:1rem 0;font-style:italic}.featured-stocks-page{animation:.3s ease-in-out fadeIn}.featured-stocks-page .tabs-header{border-bottom:2px solid var(--border-color);gap:10px;margin-bottom:20px;display:flex}.featured-stocks-page .tab-btn{cursor:pointer;color:var(--text-secondary);background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-2px;padding:12px 24px;font-size:1rem;font-weight:500;transition:all .2s}.featured-stocks-page .tab-btn:hover{color:var(--primary-color)}.featured-stocks-page .tab-btn.active{color:var(--primary-color);border-bottom-color:var(--primary-color)}.featured-stocks-page .metric-card{text-align:center;flex:1;padding:15px 20px}.featured-stocks-page .metric-label{color:var(--text-secondary);margin-bottom:5px;font-size:.9rem}.featured-stocks-page .metric-value{color:var(--text-primary);font-size:1.8rem;font-weight:700}.featured-stocks-page .metric-unit{color:var(--text-secondary);font-size:1rem;font-weight:400}.featured-stocks-page .market-badge{color:#4a5568;background:#edf2f7;border-radius:4px;padding:4px 8px;font-size:.85rem;font-weight:500;display:inline-block}.featured-stocks-page .status-badge{border-radius:4px;padding:4px 8px;font-size:.85rem;font-weight:600;display:inline-block}.featured-stocks-page .status-badge.sticky{color:#e53e3e;background:#e53e3e1a}.featured-stocks-page .status-badge.normal{color:#dd6b20;background:#dd6b201a}.featured-stocks-page .status-badge.touch{color:#d69e2e;background:#d69e2e1a}.featured-stocks-page .table-container{overflow-x:auto}.featured-stocks-page .data-table{border-collapse:collapse;width:100%}.featured-stocks-page .data-table th,.featured-stocks-page .data-table td{border-bottom:1px solid var(--border-color);text-align:left;padding:12px 15px}.featured-stocks-page .data-table th{background:var(--bg-tertiary);color:var(--text-secondary);z-index:10;white-space:normal;vertical-align:middle;text-overflow:ellipsis;min-width:80px;max-width:120px;height:2.8rem;font-weight:600;line-height:1.2;position:sticky;top:0;overflow:hidden}.featured-stocks-page .data-table tbody tr:hover{background:#00000005}.featured-stocks-page .data-table td:nth-child(2){white-space:nowrap;font-weight:600}.dark-mode .featured-stocks-page .data-table tbody tr:hover{background:#ffffff0d}.performance-page{flex-direction:column;gap:1.5rem;max-width:1400px;margin:0 auto;padding:1.5rem;display:flex}.page-header h1{color:#1e293b;align-items:center;gap:.75rem;font-size:2rem;font-weight:700;display:flex}.subtitle{color:#64748b;margin-top:.25rem}.card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;overflow:hidden;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.card.highlight{color:#fff;background:linear-gradient(135deg,#1e293b 0%,#334155 100%)}.filter-card{transition:all .3s}.filter-card .card-header{cursor:pointer;background-color:#f8fafc;border-bottom:1px solid #e2e8f0;justify-content:space-between;align-items:center;padding:1rem 1.5rem;display:flex}.header-title{color:#334155;align-items:center;gap:.5rem;font-weight:600;display:flex}.filter-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1.5rem;padding:1.5rem;display:grid}.filter-group{flex-direction:column;gap:.5rem;display:flex}.filter-group label{color:#64748b;font-size:.85rem;font-weight:600}.filter-group select{color:#1e293b;background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:.6rem;font-size:.95rem}.tab-nav{border-bottom:2px solid #e2e8f0;gap:1rem;margin-bottom:1rem;display:flex}.tab-btn{cursor:pointer;color:#64748b;background:0 0;border:none;padding:.75rem 1.5rem;font-weight:600;transition:all .2s}.tab-btn.active{color:#3b82f6;border-bottom:3px solid #3b82f6}.kpi-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1rem;margin-bottom:1.5rem;display:grid}.kpi-card{flex-direction:column;gap:.25rem;padding:1.25rem;display:flex}.kpi-card.highlight{color:#fff;background:#1e293b;grid-column:span 2}.kpi-card .label{color:#64748b;font-size:.8rem;font-weight:600}.kpi-card.highlight .label{color:#94a3b8}.kpi-card .value{font-size:1.5rem;font-weight:700}.kpi-card .value.plus{color:#ef4444}.kpi-card .value.minus{color:#3b82f6}.kpi-card .sub{color:#94a3b8;font-size:.75rem}.progress-bar{background-color:#f1f5f9;border-radius:2px;height:4px;margin-top:.5rem}.progress-bar .fill{background:linear-gradient(90deg,#3b82f6,#60a5fa);border-radius:2px;height:100%}.chart-container{flex-direction:column;width:100%;min-width:0;min-height:580px;padding:1.5rem;display:flex}.chart-container h3{color:#334155;align-items:center;gap:.5rem;margin-bottom:1rem;font-size:1.1rem;display:flex}.chart-row{grid-template-columns:2fr 1fr;gap:1.5rem;margin-bottom:1.5rem;display:grid}.correlation-analysis-section{margin-top:2rem}.section-header h2{color:#1e293b;align-items:center;gap:.5rem;margin-bottom:.5rem;font-size:1.4rem;display:flex}.section-header p{color:#64748b;margin-bottom:1.5rem;font-size:.9rem}.correlation-grid{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;display:grid}.corr-card{flex-direction:column;min-height:400px;padding:1.25rem;display:flex}.corr-card h3{color:#475569;margin-bottom:1rem;font-size:1rem}.corr-card .hint{color:#94a3b8;margin-top:.75rem;font-size:.75rem}.interpretation-card{border-left:6px solid #3b82f6;margin-bottom:2rem;padding:1.5rem}.interpretation-grid{grid-template-columns:1fr 1fr;gap:1.5rem;margin:1rem 0;display:grid}.pattern{cursor:pointer;background-color:#f8fafc;border:2px solid #0000;border-radius:10px;padding:1.25rem;transition:all .2s}.pattern:hover{background-color:#f1f5f9}.pattern.active{background-color:#eff6ff;border-color:#3b82f6}.badge{border-radius:15px;width:fit-content;margin-bottom:.75rem;padding:.3rem .6rem;font-size:.8rem;font-weight:700;display:block}.badge.success{color:#b91c1c;background:#fecaca}.badge.warning{color:#1d4ed8;background:#dbeafe}.pattern ul{color:#475569;margin:.75rem 0;padding-left:1.25rem;font-size:.9rem}.pattern .result{color:#1e293b;font-weight:700}.pdp-grid{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;margin-top:1rem;display:grid}.pdp-item{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:1rem}.analysis-grid{flex-direction:column;gap:2rem;width:100%;display:flex}.distribution-row{flex-direction:row;gap:1.5rem;width:100%;display:flex}.distribution-row>div{flex:1;min-width:0}.dist-plot{padding:1rem}.dist-plot h4{color:#475569;align-items:center;gap:.5rem;margin-bottom:1rem;font-size:1rem;display:flex}.interactive-tree-wrapper{background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;margin:1rem 0;padding:2rem;overflow:auto}.svg-node-container{cursor:pointer}.svg-node-content{transition:transform .3s cubic-bezier(.4,0,.2,1)}.svg-node-container:hover .svg-node-content{filter:drop-shadow(0 10px 15px #0000004d);transform:scale(2)}.svg-node-container:hover{z-index:100}.empty-ai{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:1.5rem;padding:5rem 2rem;display:flex}.empty-ai h2{color:#1e293b;font-size:1.75rem;font-weight:700}.empty-ai p{color:#64748b;max-width:500px;line-height:1.6}.icon-pulse{color:#3b82f6;animation:2s infinite pulse}@keyframes pulse{0%{opacity:.8;transform:scale(1)}50%{opacity:1;transform:scale(1.1)}to{opacity:.8;transform:scale(1)}}.loading-overlay{flex-direction:column;justify-content:center;align-items:center;gap:1rem;padding:4rem;display:flex}.spinner{border:4px solid #f3f3f3;border-top-color:#3b82f6;border-radius:50%;width:40px;height:40px;animation:1s linear infinite spin}.error-card{text-align:center;background:#fffcfc;border-color:#fee2e2;padding:2rem}.error-message{color:#b91c1c;margin-bottom:1rem;font-weight:600}.table-filter-ui{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding:1rem 1.5rem;display:flex}.filter-options{flex-wrap:wrap;gap:1.5rem;display:flex}.radio-label{cursor:pointer;color:#475569;align-items:center;gap:.5rem;font-size:.9rem;font-weight:500;display:flex}.radio-label input[type=radio]{cursor:pointer;width:1.1rem;height:1.1rem}.current-stats{color:#64748b;font-size:.85rem;font-weight:600}.trade-list-wrapper{margin-top:1rem;overflow-x:auto}.trade-table{border-collapse:collapse;width:100%;font-size:.9rem}.trade-table th{text-align:left;color:#475569;background:#f1f5f9;border-bottom:2px solid #e2e8f0;padding:.75rem 1rem;font-weight:600}.trade-table td{border-bottom:1px solid #f1f5f9;padding:.75rem 1rem}.trade-table tr:hover{background-color:#f8faff}.ticker-info{flex-direction:column;display:flex}.ticker-info .code{color:#3b82f6;font-weight:700}.ticker-info .name{color:#64748b;font-size:.75rem}.row-win{background-color:#10b98105}.row-loss{background-color:#ef444405}.corr-card.clickable{cursor:pointer;transition:transform .2s,box-shadow .2s}.corr-card.clickable:hover{border-color:#3b82f6;transform:translateY(-2px);box-shadow:0 10px 15px -3px #0000001a}.correlation-detail-panel{margin-top:2rem;animation:.4s ease-out slideDown}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.panel-content{padding:1.5rem}.detail-controls{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;flex-wrap:wrap;align-items:flex-end;gap:2rem;margin-bottom:2rem;padding:1.25rem;display:flex}.detail-controls .control-group{flex-direction:column;gap:.5rem;display:flex}.detail-controls label{color:#64748b;font-size:.8rem;font-weight:700}.detail-controls select{background:#fff;border:1px solid #cbd5e1;border-radius:8px;min-width:180px;padding:.6rem 1rem}.corr-value-badge{color:#1e40af;background:#eff6ff;border:1px solid #bfdbfe;border-radius:9999px;padding:.75rem 1.5rem;font-size:1rem}.ai-re-run-bar{justify-content:flex-end;margin-bottom:1rem;display:flex}.view-toggle-group{align-items:center;gap:1.5rem;display:flex}.trade-table.extended{min-width:3200px}.group-header-row th{text-align:center;border-bottom:2px solid #cbd5e1;padding:.4rem;font-size:.8rem}.group-base{color:#475569;background-color:#f1f5f9}.group-ext{border-left:2px solid #fff}.group-ext:nth-child(2){color:#166534;background-color:#f0fdf4}.group-ext:nth-child(3){color:#1e40af;background-color:#eff6ff}.group-ext:nth-child(4){color:#9a3412;background-color:#fff7ed}.group-ext:nth-child(5){color:#5b21b6;background-color:#f5f3ff}.group-ext:nth-child(6){color:#334155;background-color:#f8fafc}.trade-table th,.trade-table td{white-space:nowrap}.trade-table .memo-cell{white-space:normal;word-break:break-all;max-width:300px;font-size:.8rem;line-height:1.4}@media (width<=1024px){.distribution-row,.chart-row,.interpretation-grid{flex-direction:column;grid-template-columns:1fr}.table-filter-ui{flex-direction:column;align-items:flex-start;gap:1rem}.filter-options{gap:.75rem}.view-toggle-group{justify-content:space-between;width:100%}.detail-controls{gap:1rem}}.data-management-page{color:#1e293b;max-width:1200px;margin:0 auto;padding:2rem}.page-header{margin-bottom:2.5rem}.page-header h1{background:linear-gradient(135deg,#1e293b 0%,#3b82f6 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin-bottom:.5rem;font-size:2.2rem;font-weight:800}.page-header p{color:#64748b;font-size:1.1rem}.header-main{justify-content:space-between;align-items:center;display:flex}.user-badge{color:#475569;background-color:#f1f5f9;border:1px solid #e2e8f0;border-radius:20px;padding:.5rem 1rem;font-size:.85rem;font-weight:600}.message-banner{border-radius:12px;align-items:center;gap:.75rem;margin-bottom:2rem;padding:1rem 1.5rem;animation:.3s ease-out slideDown;display:flex}.message-banner.success{color:#166534;background-color:#f0fdf4;border:1px solid #bbf7d0}.message-banner.error{color:#991b1b;background-color:#fef2f2;border:1px solid #fecaca}.tabs-container{background:#fff;border:1px solid #f1f5f9;border-radius:20px;overflow:hidden;box-shadow:0 10px 30px #0000000d}.tabs{background-color:#f8fafc;border-bottom:1px solid #f1f5f9;gap:.5rem;padding:.5rem;display:flex}.tab{cursor:pointer;color:#64748b;background:0 0;border:none;border-radius:12px;align-items:center;gap:.75rem;padding:.8rem 1.5rem;font-weight:600;transition:all .2s;display:flex}.tab:hover{color:#1e293b;background-color:#f1f5f9}.tab.active{color:#3b82f6;background-color:#fff;box-shadow:0 4px 12px #3b82f61a}.tab-content{padding:2rem}.tab-loading,.tab-error{border-radius:12px;align-items:center;gap:.75rem;margin-bottom:1.5rem;padding:1rem;font-size:.9rem;display:flex}.tab-loading{color:#64748b;background-color:#f8fafc}.tab-error{color:#991b1b;background-color:#fef2f2;border:1px solid #fecaca}.spin{animation:1s linear infinite spin}.section-info{margin-bottom:2rem}.section-info h3{margin-bottom:.5rem;font-size:1.5rem;font-weight:700}.section-info p{color:#64748b}.management-toolbar{flex-wrap:wrap;gap:.75rem;margin-bottom:1.5rem;display:flex}.tool-btn{color:#475569;cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:10px;align-items:center;gap:.5rem;padding:.6rem 1rem;font-size:.9rem;font-weight:600;transition:all .2s;display:flex}.tool-btn:hover{background-color:#f8fafc;border-color:#cbd5e1}.tool-btn.active{color:#fff;background-color:#1e293b;border-color:#1e293b}.card{background:#fff;border:1px solid #f1f5f9;border-radius:16px;margin-bottom:2rem;padding:1.5rem}.management-form h4{color:#1e293b;margin-bottom:1.5rem;font-size:1.1rem}.form-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1.5rem;margin-bottom:1.5rem;display:grid}.form-grid.mini{grid-template-columns:1fr 1fr 2fr 2fr;gap:1rem}.form-group{flex-direction:column;gap:.5rem;display:flex}.form-group.full-width{grid-column:1/-1}.form-group label{color:#64748b;font-size:.85rem;font-weight:600}.form-group input,.form-group select,textarea{border:1px solid #e2e8f0;border-radius:10px;padding:.75rem 1rem;font-size:.95rem;transition:all .2s}.form-group input:focus,.form-group select:focus,textarea:focus{border-color:#3b82f6;outline:none;box-shadow:0 0 0 4px #3b82f61a}.form-actions{justify-content:flex-end;display:flex}.import-section{text-align:center}.file-drop-zone{color:#64748b;border:2px dashed #e2e8f0;border-radius:16px;flex-direction:column;align-items:center;gap:1rem;margin:1.5rem 0;padding:3rem;transition:all .2s;display:flex}.file-drop-zone:hover{background-color:#eff6ff;border-color:#3b82f6}textarea{resize:vertical;width:100%;margin-bottom:1rem;font-family:monospace}.alert-box{border-radius:10px;align-items:center;gap:1rem;margin-bottom:1rem;padding:1rem;font-size:.9rem;display:flex}.alert-box.info{color:#1e40af;background-color:#eff6ff;border:1px solid #dbeafe}.alert-box.warning{color:#92400e;background-color:#fffbeb;border:1px solid #fef3c7}.delete-group{margin:1.5rem 0}.delete-group.danger{background-color:#fef2f2;border:1px solid #fee2e2;border-radius:12px;padding:1.5rem}.delete-group h5{color:#991b1b;margin-bottom:1rem}.radio-group,.checkbox-label{flex-direction:column;gap:.75rem;margin-bottom:1.5rem;font-size:.9rem;display:flex}.checkbox-label{flex-direction:row;align-items:center}.mini-table{border-collapse:collapse;width:100%}.mini-table th{text-align:left;color:#64748b;text-transform:uppercase;letter-spacing:.05em;background-color:#f8fafc;border-bottom:1px solid #e2e8f0;padding:.75rem 1rem;font-size:.8rem;font-weight:600}.mini-table td{border-bottom:1px solid #f1f5f9;padding:1rem;font-size:.9rem}.mini-table .empty-text{text-align:center;color:#94a3b8;padding:3rem}.settings-grid{grid-template-columns:1fr 1fr;gap:2rem;display:grid}.settings-section.full-width{grid-column:1/-1}.path-input-group{gap:.5rem;margin-top:1rem;display:flex}.path-input-group input{flex:1}.btn{cursor:pointer;border:none;border-radius:10px;justify-content:center;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-size:.95rem;font-weight:600;transition:all .2s;display:inline-flex}.btn-primary{color:#fff;background-color:#3b82f6}.btn-primary:hover{background-color:#2563eb;transform:translateY(-1px);box-shadow:0 4px 12px #2563eb33}.btn-outline{color:#475569;background-color:#fff;border:1px solid #e2e8f0}.btn-outline:hover{background-color:#f8fafc;border-color:#cbd5e1}.btn-danger{color:#fff;background-color:#ef4444}.btn-danger:hover:not(:disabled){background-color:#dc2626}.btn-danger:disabled{opacity:.5;cursor:not-allowed}.btn-sm{padding:.4rem .8rem;font-size:.85rem}.full-width{width:100%}.hint{color:#94a3b8;margin-top:.25rem;font-size:.85rem}.asset-management-grid{grid-template-columns:1fr 2fr;gap:2rem;display:grid}.tag-selector{background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;flex-wrap:wrap;gap:.5rem;padding:.5rem;display:flex}.tag-chip{border:1px solid var(--tag-color,#3b82f6);color:var(--tag-color,#3b82f6);cursor:pointer;background-color:#fff;border-radius:20px;padding:.4rem .8rem;font-size:.85rem;font-weight:600;transition:all .2s}.tag-chip.active{background-color:var(--tag-color,#3b82f6);color:#fff}.loading-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#ffffffb3;flex-direction:column;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.spinner{border:4px solid #f3f3f3;border-top-color:#3b82f6;border-radius:50%;width:40px;height:40px;margin-bottom:1rem;animation:1s linear infinite spin}.scrollable{max-height:400px;overflow-y:auto}.icon-btn{cursor:pointer;color:#64748b;background:0 0;border:none;border-radius:6px;padding:.4rem;transition:all .2s}.icon-btn:hover{color:#1e293b;background-color:#f1f5f9}.icon-btn.danger:hover{color:#ef4444;background-color:#fef2f2}.tag-form{flex-wrap:wrap;align-items:center;gap:1rem;margin-bottom:2rem;display:flex}.tag-form input[type=color]{width:50px;height:40px;padding:2px}.tag-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem;display:grid}.tag-item{background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;justify-content:space-between;align-items:center;padding:.75rem 1rem;display:flex}.tag-cat{color:#94a3b8;flex:1;margin-left:.5rem;font-size:.75rem}.tag-actions{gap:.25rem;display:flex}.settings-list{flex-direction:column;gap:.5rem;margin-top:1.5rem;display:flex}.list-item{background-color:#f8fafc;border-radius:10px;justify-content:space-between;align-items:center;padding:.75rem 1rem;font-size:.9rem;display:flex}.text-plus{color:#166534;font-weight:600}.text-minus{color:#991b1b;font-weight:600}@media (width<=1024px){.settings-grid,.asset-management-grid{grid-template-columns:1fr}.tag-form{flex-direction:column;align-items:stretch}}.table-wrapper{border:1px solid #e2e8f0;border-radius:8px;overflow-x:auto}.horizontal-scroll table{min-width:1400px}.code-name{flex-direction:column;display:flex}.code-name strong{color:#1e293b}.btn-outline{color:#475569;background:#fff;border:1px solid #cbd5e1}.btn-outline.active{background:#f1f5f9;border-color:#94a3b8}.kabuplus-card{border:1px solid #e2e8f0;transition:transform .2s,box-shadow .2s}.kabuplus-card:hover{box-shadow:0 12px 40px #00000014}.status-banner{border-radius:12px;align-items:center;gap:1rem;margin-bottom:1.5rem;padding:1.25rem;display:flex}.status-banner.linked{background-color:#f0fdf4;border:1px solid #bbf7d0}.status-banner.not-linked{background-color:#fffbeb;border:1px solid #fef3c7}.status-info{flex-direction:column;flex:1;gap:.25rem;display:flex}.status-info strong{color:#1e293b;font-size:1rem}.status-info p{color:#64748b;margin:0;font-size:.85rem}.status-info .timestamp{color:#94a3b8;margin-top:.25rem;font-size:.75rem}.status-info .badge{text-transform:uppercase;border-radius:4px;width:fit-content;padding:.2rem .5rem;font-size:.7rem;font-weight:700;display:inline-block}.kabuplus-form{background-color:#f8fafc;border-radius:12px;padding:1.5rem}.loading-placeholder{text-align:center;color:#94a3b8;background:#f8fafc;border-radius:12px;margin-top:1rem;padding:2rem}.import-progress-container{text-align:left;background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;margin:1.5rem 0;padding:1rem}.progress-labels{color:#475569;justify-content:space-between;margin-bottom:.75rem;font-size:.9rem;font-weight:600;display:flex}.progress-bar-bg{background-color:#e2e8f0;border-radius:6px;width:100%;height:12px;margin-bottom:.75rem;overflow:hidden}.progress-bar-fill{background:linear-gradient(90deg,#3b82f6 0%,#60a5fa 100%);height:100%;transition:width .3s;position:relative}.progress-bar-fill:after{content:"";background:linear-gradient(90deg,#fff0 0%,#ffffff4d 50%,#fff0 100%);animation:1.5s infinite shimmer;position:absolute;inset:0}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.eta-label{color:#64748b;text-align:right;font-size:.8rem;font-style:italic}.bookmark-page{max-width:1400px;margin:0 auto;padding:2rem}.page-header{justify-content:space-between;align-items:center;margin-bottom:2rem;display:flex}.page-header h1{color:#1e293b;font-size:2rem;font-weight:800}.folder-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem;display:grid}.folder-card{cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:16px;flex-direction:column;gap:1rem;padding:1.5rem;transition:all .2s;display:flex}.folder-card:hover{border-color:#3b82f6;transform:translateY(-4px);box-shadow:0 10px 25px #0000000d}.folder-card-top{justify-content:space-between;align-items:flex-start;display:flex}.folder-delete-btn{opacity:0;padding:.5rem;transition:opacity .2s}.folder-card:hover .folder-delete-btn{opacity:1}.folder-icon{color:#3b82f6;background-color:#eff6ff;border-radius:12px;justify-content:center;align-items:center;width:48px;height:48px;display:flex}.folder-info h3{color:#1e293b;margin-bottom:.25rem;font-size:1.25rem;font-weight:700}.folder-info p{color:#64748b;font-size:.9rem;line-height:1.4}.folder-stats{color:#94a3b8;justify-content:space-between;align-items:center;margin-top:auto;font-size:.85rem;font-weight:600;display:flex}.detail-header{margin-bottom:2rem}.back-btn{color:#64748b;cursor:pointer;text-underline-offset:4px;background:0 0;border:none;align-items:center;gap:.5rem;margin-bottom:1rem;margin-left:16px;font-size:.9rem;font-weight:600;text-decoration:underline;display:flex}.back-btn:hover{color:#1e293b}.folder-title-area{justify-content:space-between;align-items:flex-end;display:flex}.folder-title-area h2{color:#1e293b;font-size:1.75rem;font-weight:800}.tabs{border-bottom:1px solid #e2e8f0;gap:1rem;margin-bottom:2rem;display:flex}.tab{color:#64748b;cursor:pointer;background:0 0;border:none;padding:.75rem 1.5rem;font-size:.95rem;font-weight:600;position:relative}.tab.active{color:#3b82f6}.tab.active:after{content:"";background-color:#3b82f6;height:2px;position:absolute;bottom:-1px;left:0;right:0}.chart-grid{grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem;display:grid}.chart-card{background:#fff;border:1px solid #e2e8f0;border-radius:16px;padding:1.25rem}.chart-card-header{justify-content:space-between;margin-bottom:1rem;display:flex}.stock-info h4{font-size:1.1rem;font-weight:700}.stock-info span{color:#64748b;font-size:.85rem}.stock-price{text-align:right}.price-value{font-size:1.1rem;font-weight:700}.chart-container{height:150px;margin-bottom:1rem}.memo-table-container{background:#fff;border:1px solid #e2e8f0;border-radius:16px;overflow:hidden}.memo-table{border-collapse:collapse;width:100%}.memo-table th{text-align:left;color:#475569;text-transform:uppercase;letter-spacing:.05em;background-color:#f8fafc;border-bottom:1px solid #e2e8f0;padding:1rem;font-size:.8rem;font-weight:700}.memo-table td{border-bottom:1px solid #f1f5f9;padding:1rem;font-size:.9rem}.memo-table input,.memo-table select{border:1px solid #0000;border-radius:4px;width:100%;padding:.4rem}.memo-table input:focus,.memo-table select:focus{background-color:#f0f7ff;border-color:#3b82f6;outline:none}.action-bar{justify-content:space-between;margin-bottom:1.5rem;display:flex}.btn-icon{align-items:center;gap:.5rem;display:flex}.modal-overlay{z-index:1000;background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-content{background:#fff;border-radius:20px;width:400px;max-width:90%;padding:2rem}.timeframe-btn{transition:all .2s}.timeframe-btn:hover:not(.active){color:#3b82f6!important;background:#ffffff80!important}.timeframe-btn.active{box-shadow:0 1px 3px #0000001a!important}.chart-card-footer{border-top:1px solid #f1f5f9;justify-content:flex-end;padding-top:8px;display:flex}.global-top-bar{background-color:var(--bg-card,#fff);border-bottom:1px solid var(--border-color,#e2e8f0);z-index:900;flex-shrink:0;justify-content:space-between;align-items:center;height:44px;padding:0 1.5rem 0 64px;display:flex}.breadcrumbs{color:#64748b;align-items:center;font-size:.85rem;display:flex}.app-name{color:var(--primary-color,#3b82f6);letter-spacing:.02em;font-weight:600}.breadcrumb-separator{opacity:.5;margin:0 8px}.category-name{color:#64748b;font-weight:500}.current-page{color:var(--text-dark,#1e293b);font-weight:600}.top-bar-actions{align-items:center;gap:.5rem;display:flex}.action-item{position:relative}.action-btn{color:#64748b;cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;transition:all .2s;display:flex}.action-btn:hover{color:#0f172a;background-color:#f1f5f9}.notification-badge{color:#fff;background-color:#ef4444;border:2px solid #fff;border-radius:50%;justify-content:center;align-items:center;width:14px;height:14px;font-size:10px;font-weight:700;display:flex;position:absolute;top:2px;right:2px}.notification-popover{z-index:1000;background-color:#fff;border:1px solid #e2e8f0;border-radius:16px;width:320px;position:absolute;top:40px;right:0;overflow:hidden;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d}.popover-header{color:#0f172a;border-bottom:1px solid #f1f5f9;padding:1rem;font-size:.9rem;font-weight:700}.popover-content{max-height:400px;overflow-y:auto}.notification-item{cursor:pointer;border-bottom:1px solid #f8fafc;padding:1rem;transition:background-color .2s}.notification-item:hover{background-color:#f8fafc}.notif-category{color:#3b82f6;margin-bottom:.25rem;font-size:.75rem;font-weight:700}.notif-title{color:#1e293b;margin-bottom:.4rem;font-size:.85rem;font-weight:600;line-height:1.4}.notif-date{color:#94a3b8;align-items:center;gap:.3rem;font-size:.75rem;display:flex}.no-notifications{text-align:center;color:#94a3b8;padding:2rem;font-size:.85rem}.app-layout{background-color:var(--bg-main);height:100vh;display:flex;overflow:hidden}.sidebar-wrapper{z-index:1000;width:64px;transition:width;position:fixed;top:0;bottom:0;left:0}.sidebar-wrapper:hover{width:var(--sidebar-width)}.sidebar{height:100%;width:var(--sidebar-width);color:#f8fafc;background-color:#0f172a;flex-direction:column;flex-shrink:0;transition:transform .3s cubic-bezier(.4,0,.2,1),box-shadow .3s;display:flex;transform:translate(-100%)}.sidebar-wrapper:hover .sidebar{transition-delay:0s;transform:translate(0);box-shadow:8px 0 24px #0000004d}.sidebar-trigger{color:#fff;cursor:pointer;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background-color:#0f172ad9;border:1px solid #ffffff1a;border-radius:10px;justify-content:center;align-items:center;width:48px;height:48px;transition:opacity .2s,transform .2s;display:flex;position:absolute;top:60px;left:8px;box-shadow:4px 0 12px #0003}.sidebar-wrapper:hover .sidebar-trigger{opacity:0;pointer-events:none;transform:scale(.9)}.sidebar-header{border-bottom:1px solid #1e293b;padding:1.5rem}.sidebar-header h2{color:#fff;margin-bottom:.5rem;font-size:1.2rem}.user-badge{color:#94a3b8;background-color:#1e293b;border-radius:4px;padding:.2rem .6rem;font-size:.8rem;display:inline-block}.sidebar-nav{flex:1;padding:1rem 0;overflow-y:auto}.nav-group h3{color:#64748b;text-transform:uppercase;letter-spacing:.05em;margin:1rem 0 .5rem;padding:0 1.5rem;font-size:.75rem}.nav-item{color:#cbd5e1;align-items:center;gap:.75rem;padding:.75rem 1.5rem;text-decoration:none;transition:all .2s;display:flex}.nav-item:hover{color:#fff;background-color:#1e293b}.nav-item.active{background-color:var(--primary-color);color:#fff;font-weight:600}.nav-item.disabled{opacity:.5;cursor:not-allowed}.sidebar-footer{border-top:1px solid #1e293b;padding:1rem}.logout-btn{color:#cbd5e1;cursor:pointer;background:0 0;border:none;border-radius:6px;align-items:center;gap:.5rem;width:100%;padding:.75rem;transition:all .2s;display:flex}.logout-btn:hover{color:#fff;background-color:#1e293b}.main-content{flex:1;width:100%;padding:2rem;overflow-y:auto}:root{--primary-color:#3b82f6;--primary-hover:#2563eb;--bg-main:#f8fafc;--bg-card:#fff;--text-dark:#1e293b;--text-muted:#64748b;--border-color:#e2e8f0;--chart-up:#26a69a;--chart-down:#ef5350;--chart-up-bg:#26a69a1a;--chart-down-bg:#ef53501a;--sidebar-width:260px}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-main);color:var(--text-dark);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Noto Sans JP,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif}h1,h2,h3,h4,h5,h6{color:var(--text-dark);font-weight:700}.metric-number{font-family:Inter,sans-serif}.container{max-width:1200px;margin:0 auto;padding:0 1rem}.card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;padding:1.5rem;box-shadow:0 1px 3px #0000000d}.btn{cursor:pointer;border:none;border-radius:6px;justify-content:center;align-items:center;padding:.5rem 1rem;font-family:inherit;font-weight:600;transition:all .2s;display:inline-flex}.btn-primary{background-color:var(--primary-color);color:#fff}.btn-primary:hover{background-color:var(--primary-hover)}.btn-outline{border:1px solid var(--border-color);color:var(--text-dark);background-color:#0000}.btn-outline:hover{background-color:#f1f5f9}
