*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}body,html{margin:0;padding:0;font-family:-apple-system,BlinkMacSystemFont,Hiragino Sans,Noto Sans JP,sans-serif;background:#0f1419;color:#e5e7eb;-webkit-font-smoothing:antialiased;min-height:100vh}.container{max-width:1400px;margin:0 auto;padding:0 24px}header.app-header{background:linear-gradient(180deg,#131826,#0f1419);border-bottom:1px solid #1f2937;position:-webkit-sticky;position:sticky;top:0;z-index:50;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.header-inner{max-width:1400px;margin:0 auto;padding:0 24px;gap:32px;height:60px}.app-brand,.header-inner{display:flex;align-items:center}.app-brand{gap:10px;flex-shrink:0}.app-brand .logo{width:30px;height:30px;background:linear-gradient(135deg,#fbbf24,#f59e0b);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:15px;box-shadow:0 2px 8px rgba(251,191,36,.3)}.app-brand h1{font-size:17px;font-weight:700;margin:0;letter-spacing:-.01em;color:#f9fafb;white-space:nowrap}.app-brand .ver{font-size:10px;color:#6b7280;margin-left:4px;font-weight:500}nav.tabs{display:flex;gap:4px;flex:1 1}nav.tabs a{padding:20px 16px;font-size:13px;font-weight:600;color:#6b7280;text-decoration:none;border-bottom:2px solid transparent;transition:color .15s ease,border-color .15s ease;white-space:nowrap}nav.tabs a:hover{color:#d1d5db}nav.tabs a.active{color:#fbbf24;border-bottom-color:#fbbf24}.header-meta{text-align:right;font-size:11px;line-height:1.4;flex-shrink:0}.header-meta .time{color:#6b7280;font-feature-settings:"tnum"}main{padding:24px 0 48px}.kpi-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:16px;gap:16px;margin-bottom:28px}.kpi-card{background:#1a2030;border:1px solid #1f2937;border-radius:14px;padding:18px 20px;position:relative;overflow:hidden;transition:border-color .2s ease}.kpi-card:hover{border-color:#374151}.kpi-card .kpi-label{font-size:11px;color:#9ca3af;margin-bottom:10px;display:flex;align-items:center;gap:4px;font-weight:500}.kpi-card .kpi-value{font-size:28px;font-weight:700;color:#f9fafb;letter-spacing:-.02em;line-height:1.1;font-feature-settings:"tnum"}.kpi-card .kpi-value .unit{font-size:13px;color:#9ca3af;font-weight:500;margin-left:3px}.kpi-card .kpi-sub{font-size:11px;color:#6b7280;margin-top:6px}.kpi-card.candidate .kpi-value{color:#f9fafb}.kpi-card.candidate.zero .kpi-value{color:#6b7280}.kpi-card .mini-badges{display:flex;gap:5px;margin-top:8px}.mini-badges .mb{font-size:10px;padding:2px 7px;border-radius:5px;font-weight:600;background:#111827}.mini-badges .mb.g{color:#10b981;border:1px solid #064e3b}.mini-badges .mb.b{color:#3b82f6;border:1px solid #1e3a8a}.mini-badges .mb.r{color:#ef4444;border:1px solid #7f1d1d}.kpi-card.time .kpi-value{color:#fbbf24}.kpi-card.cheap .kpi-value{font-size:20px;line-height:1.3}.kpi-card.cheap .kpi-value .code{font-size:13px;color:#9ca3af;font-weight:600;margin-right:6px}.kpi-card.cheap .kpi-value .gap{font-feature-settings:"tnum"}.kpi-card.cheap.has .kpi-value .gap{color:#10b981}.kpi-card.cheap.miss .kpi-value .gap{color:#ef4444}section.block{margin-bottom:28px}.section-title{font-size:15px;font-weight:700;color:#f9fafb;margin:0 0 14px;display:flex;align-items:center;gap:10px;letter-spacing:-.01em}.section-title .count{font-size:11px;background:#111827;color:#9ca3af;padding:2px 9px;border-radius:999px;font-weight:600;border:1px solid #1f2937}.section-title .accent{color:#fbbf24;font-size:12px;margin-left:auto;font-weight:500}.empty-state{background:linear-gradient(135deg,#131826,#0f1419);border:1px dashed #374151;border-radius:14px;padding:32px 20px;text-align:center;color:#9ca3af;font-size:13px;line-height:1.7}.empty-state .em{font-size:30px;margin-bottom:6px}.empty-state strong{color:#f9fafb;font-size:14px;display:block;margin-bottom:5px}.empty-state .sub{font-size:12px;color:#6b7280}.badge{display:inline-flex;align-items:center;justify-content:center;padding:4px 11px;border-radius:999px;font-size:11px;font-weight:700;color:#fff;letter-spacing:.02em;white-space:nowrap}.badge.sm{padding:3px 9px;font-size:10px}.badge.red{background:#ef4444}.badge.blue{background:#3b82f6}.badge.green{background:#10b981}.badge.gray{background:#1f2937;color:#6b7280;border:1px solid #374151}.candidate-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));grid-gap:6px;gap:6px}.candidate-item{display:flex;align-items:center;gap:8px;padding:6px 10px;background:#131826;border:1px solid #1f2937;border-radius:7px;text-decoration:none;transition:border-color .15s ease,background .15s ease;cursor:pointer}.candidate-item:hover{border-color:#fbbf24;background:#161c2c}.candidate-item .cand-code{font-size:11px;color:#6b7280;font-weight:600;font-feature-settings:"tnum"}.candidate-item .cand-name{font-size:12px;color:#f9fafb;font-weight:600;flex:1 1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.candidate-item .cand-yield{font-size:12px;font-weight:700;color:#fbbf24;font-feature-settings:"tnum"}.controls{display:flex;gap:10px;margin-bottom:14px;flex-wrap:wrap;align-items:center}.controls select{background:#131826;border:1px solid #1f2937;border-radius:9px;padding:9px 32px 9px 12px;font-size:12px;color:#e5e7eb;font-family:inherit;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%239ca3af'%3e%3cpath d='M7 10l5 5 5-5z'/%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right 8px center;cursor:pointer;min-width:160px}.controls select:hover{border-color:#374151}.controls select:focus{outline:none;border-color:#fbbf24}.controls .sort-hint{font-size:11px;color:#6b7280;margin-left:auto}.controls .sort-hint b{color:#fbbf24;font-weight:600}.stock-table-wrap{background:#131826;border:1px solid #1f2937;border-radius:14px;overflow:hidden}table.stock-table{width:100%;border-collapse:collapse;font-size:13px}table.stock-table thead th{background:#0f1419;color:#6b7280;font-weight:600;font-size:10px;text-transform:uppercase;letter-spacing:.06em;padding:12px 14px;text-align:right;border-bottom:1px solid #1f2937;white-space:nowrap;-webkit-user-select:none;-moz-user-select:none;user-select:none}table.stock-table thead th.col-lg-sector,table.stock-table thead th:first-child,table.stock-table thead th:nth-child(2){text-align:left}table.stock-table thead th.col-judge{text-align:center}table.stock-table thead th.chev-cell{width:32px;text-align:center}th.sortable{cursor:pointer;transition:color .15s ease,background .15s ease}th.sortable:hover{color:#d1d5db;background:#131826}th.sortable .sort-arrow{display:inline-block;width:10px;margin-left:3px;opacity:.35;font-size:9px;vertical-align:middle}th.sortable.active{color:#fbbf24;background:rgba(251,191,36,.05)}th.sortable.active .sort-arrow{opacity:1;color:#fbbf24}table.stock-table tbody tr.row-main{cursor:pointer;transition:background .15s ease;border-bottom:1px solid #1f2937}table.stock-table tbody tr.row-main.expanded,table.stock-table tbody tr.row-main:hover{background:#161c2c}table.stock-table tbody tr.row-main.expanded td{border-bottom-color:#fbbf24}table.stock-table tbody tr.row-main td{padding:14px;color:#e5e7eb;font-feature-settings:"tnum";text-align:right;white-space:nowrap}table.stock-table tbody tr.row-main td.code-cell,table.stock-table tbody tr.row-main td.name-cell,table.stock-table tbody tr.row-main td.sector-cell{text-align:left}table.stock-table tbody tr.row-main td.judge-cell{text-align:center}td.code-cell{font-size:12px;color:#6b7280;font-weight:600}td.name-cell{font-weight:600;color:#f9fafb}td.sector-cell{font-size:12px;color:#9ca3af}td.yield-cell{font-weight:700;color:#f9fafb;font-size:14px}td.yield-cell .unit{font-size:11px;color:#9ca3af;font-weight:500;margin-left:1px}td.yield-target{color:#10b981}td.yield-avg{color:#d1d5db}td.yield-p20{color:#3b82f6}td.yield-p40{color:#ef4444}td.gap-cell{font-weight:700;font-size:13px;font-feature-settings:"tnum"}table.stock-table tbody td.gap-cell.pos{color:#ef4444}table.stock-table tbody td.gap-cell.neg{color:#10b981}table.stock-table tbody td.gap-cell.zero{color:#f9fafb}td.gap-cell .arr{display:inline-block;margin-right:3px;font-size:11px;font-weight:700}td.price-change-cell{font-weight:700;font-size:12px;font-feature-settings:"tnum"}table.stock-table tbody td.price-change-cell.up{color:#ef4444}table.stock-table tbody td.price-change-cell.down{color:#10b981}table.stock-table tbody td.price-change-cell.zero{color:#9ca3af}table.stock-table tbody td.price-change-cell.none{color:#4b5563}td.price-change-cell .arr{display:inline-block;margin-right:2px;font-size:10px;font-weight:700}.chev-cell{width:32px;text-align:center!important}.chev{width:18px;height:18px;color:#4b5563;transition:transform .25s ease;vertical-align:middle}tr.row-main.expanded .chev{transform:rotate(180deg);color:#fbbf24}tr.row-detail{display:none}tr.row-detail.show{display:table-row}tr.row-detail>td{padding:0!important;background:#0f1419;border-bottom:1px solid #1f2937}.detail-inner{padding:22px 24px 26px}.detail-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.2fr);grid-gap:28px;gap:28px}.detail-block-title{font-size:11px;font-weight:700;color:#9ca3af;text-transform:uppercase;letter-spacing:.08em;margin:0 0 10px;display:flex;align-items:center;gap:6px}.detail-block-title:before{content:"";width:3px;height:12px;background:#fbbf24;border-radius:2px}.detail-block-title.mt{margin-top:18px}.kv-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-gap:6px;gap:6px}.kv{background:#131826;border-radius:8px;padding:8px 10px;border:1px solid #1f2937}.kv .k{font-size:9px;color:#6b7280;margin-bottom:2px}.kv .v{font-size:13px;font-weight:700;color:#f9fafb;font-feature-settings:"tnum";letter-spacing:-.01em}.kv .v.accent{color:#fbbf24}.kv .v small{font-size:9px;font-weight:500;color:#9ca3af;margin-left:2px}table.yield-table{width:100%;border-collapse:collapse;background:#131826;border-radius:9px;overflow:hidden;border:1px solid #1f2937;font-size:12px}table.yield-table td,table.yield-table th{padding:9px 12px;text-align:right;font-feature-settings:"tnum";color:#d1d5db}table.yield-table td:first-child,table.yield-table th:first-child{text-align:left}table.yield-table thead th{background:#0f1419;color:#6b7280;font-weight:600;font-size:10px;text-transform:uppercase;letter-spacing:.06em}table.yield-table tbody tr,table.yield-table thead th{border-bottom:1px solid #1f2937}table.yield-table tbody tr:last-child{border-bottom:none}table.yield-table tr.now{background:rgba(251,191,36,.08)}table.yield-table tr.now td{font-weight:700;color:#fbbf24}table.yield-table td.dot:before{content:"";display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:7px;vertical-align:middle}table.yield-table tr.lv-now td.dot:before{background:#fbbf24}table.yield-table tr.lv-avg td.dot:before{background:#9ca3af}table.yield-table tr.lv-p20 td.dot:before{background:#3b82f6}table.yield-table tr.lv-p40 td.dot:before{background:#ef4444}table.yield-table tr.lv-target td.dot:before{background:#10b981}table.yield-table tr.lv-gap td.dot:before{background:#fbbf24;opacity:.6}table.yield-table td.gap-val.pos{color:#ef4444;font-weight:700}table.yield-table td.gap-val.neg{color:#10b981;font-weight:700}table.yield-table td.gap-val.zero{color:#f9fafb;font-weight:700}.chart-wrap{background:#131826;border-radius:11px;padding:14px 14px 6px;border:1px solid #1f2937;display:flex;flex-direction:column}.chart-canvas-box{position:relative;height:220px}.chart-wrap canvas{max-height:220px}.chart-note{font-size:10px;color:#6b7280;text-align:right;padding:6px 4px 2px}.ext-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:4px}.ext-btn,.ext-row{align-items:center}.ext-btn{display:inline-flex;justify-content:center;width:38px;height:38px;background:#131826;border:1px solid #1f2937;border-radius:10px;text-decoration:none;transition:border-color .15s ease,transform .15s ease,background .15s ease;cursor:pointer}.ext-btn:hover{border-color:#fbbf24;background:#161c2c;transform:translateY(-1px)}.ext-btn img{width:20px;height:20px;display:block}.ext-btn .emoji{font-size:18px;line-height:1}.referrer-chip{display:inline-flex;align-items:center;gap:5px;font-size:11px;color:#9ca3af;background:#131826;border:1px solid #1f2937;border-radius:999px;padding:5px 11px;white-space:nowrap;max-width:50%;overflow:hidden;text-overflow:ellipsis}.detail-right{display:flex;flex-direction:column}.referrer-bottom{margin-top:auto;display:flex;justify-content:flex-end;padding-top:14px}.referrer-chip .from{color:#6b7280;font-size:10px}.referrer-chip .name{color:#d1d5db;font-weight:600}footer{padding:24px 0 32px;text-align:center;color:#6b7280;font-size:11px;line-height:1.7;border-top:1px solid #1f2937;margin-top:24px}footer .src{font-weight:600;color:#9ca3af}@media (max-width:1024px){.container,.header-inner{padding:0 20px}.header-inner{gap:20px;height:56px}nav.tabs a{padding:18px 12px;font-size:12px}.kpi-grid{grid-template-columns:repeat(2,1fr);gap:12px}.kpi-card{padding:14px 16px}.kpi-card .kpi-value{font-size:24px}.kpi-card.cheap .kpi-value{font-size:17px}table.stock-table td.col-lg,table.stock-table th.col-lg{display:none}.detail-grid{grid-template-columns:1fr;gap:18px}.kv-grid{grid-template-columns:1fr 1fr}}@media (max-width:640px){body{background:#0f1419}.container{padding:0 12px}header.app-header{position:relative}.header-inner{padding:12px 14px 0;flex-direction:column;align-items:stretch;gap:0;height:auto}.header-top-mobile{display:flex;justify-content:space-between;align-items:center;padding-bottom:10px}.app-brand .logo{width:26px;height:26px;font-size:14px;border-radius:7px}.app-brand h1{font-size:16px}.app-brand .ver{font-size:9px}.header-meta{font-size:10px}nav.tabs{border-top:1px solid #1f2937;padding:0;gap:0}nav.tabs a{padding:10px 12px;font-size:12px}main{padding:14px 0 36px}.kpi-grid{grid-template-columns:1fr 1fr;gap:8px;margin-bottom:18px}.kpi-card{padding:12px;border-radius:12px}.kpi-card .kpi-label{font-size:10px;margin-bottom:6px}.kpi-card .kpi-value{font-size:22px}.kpi-card .kpi-value .unit{font-size:11px}.kpi-card .kpi-sub{font-size:10px;margin-top:4px}.kpi-card.cheap .kpi-value{font-size:14px}.kpi-card.cheap .kpi-value .code{font-size:11px}.mini-badges .mb{font-size:9px;padding:1px 5px}.section-title{font-size:13px}.section-title .count{font-size:10px;padding:2px 8px}.section-title .accent{font-size:11px}.empty-state{padding:22px 14px;font-size:12px;border-radius:12px}.empty-state .em{font-size:24px}.empty-state strong{font-size:13px}.empty-state .sub{font-size:11px}.controls{gap:6px;margin-bottom:10px}.controls select{flex:1 1;min-width:0;font-size:11px;padding:7px 24px 7px 9px;border-radius:8px}.controls .sort-hint,table.stock-table td.col-md,table.stock-table th.col-md{display:none}table.stock-table thead th{padding:9px 8px;font-size:9px}table.stock-table tbody tr.row-main td{padding:11px 8px;font-size:12px}td.name-cell{font-size:12px}td.yield-cell{font-size:13px}td.gap-cell{font-size:12px}.badge{padding:3px 8px;font-size:10px}.chev-cell{width:22px}.chev{width:16px;height:16px}.stock-table-wrap{border-radius:12px}.detail-inner{padding:14px 12px 16px}.detail-block-title{font-size:10px}.detail-block-title.mt{margin-top:14px}.kv-grid{grid-template-columns:1fr 1fr;gap:6px}.kv{padding:9px 11px;border-radius:8px}.kv .k{font-size:9px}.kv .v{font-size:14px}.kv .v small{font-size:9px}table.yield-table{font-size:11px}table.yield-table td,table.yield-table th{padding:7px 10px}table.yield-table thead th{font-size:9px}table.yield-table td.dot:before{width:7px;height:7px;margin-right:6px}.chart-wrap{padding:10px 8px 4px;border-radius:10px}.chart-canvas-box{min-height:0}.chart-wrap canvas{max-height:180px}.chart-note{font-size:9px}.ext-btn{width:34px;height:34px;border-radius:9px}.ext-btn img{width:18px;height:18px}.ext-btn .emoji{font-size:16px}.ext-row{gap:8px}.referrer-chip{font-size:10px;padding:4px 9px;max-width:45%}.referrer-chip .from{font-size:9px}footer{padding:18px 12px 28px;font-size:10px}}.pc-only{display:contents}.mobile-only{display:none}@media (max-width:640px){.pc-only{display:none}.mobile-only{display:contents}}