:root{--bg:#f4f7fb;--surface-soft:#f8fbff;--border:#d6deea;--text:#1a2233;--text-soft:#5b6577;--primary:#1f3c88;--primary-dark:#0f2350;--accent:#2f5aa6;--shadow-sm:0 2px 8px #0f235014;--shadow-md:0 10px 30px #0f23501f;--radius-lg:22px;--content-width:1280px}*{box-sizing:border-box}html,body{min-height:100%;margin:0}body{background:linear-gradient(180deg, #f8fbff 0%, var(--bg) 100%);color:var(--text);font-family:Yu Gothic UI,Meiryo,sans-serif}a{color:inherit;text-decoration:none}.page{min-height:100vh}.header{z-index:100;background:linear-gradient(135deg, var(--primary-dark) 0%, var(--primary) 100%);color:#fff;min-height:84px;box-shadow:var(--shadow-md);grid-template-columns:260px minmax(320px,620px) minmax(180px,1fr);align-items:center;gap:24px;padding:16px 32px;display:grid;position:sticky;top:0}.header-left{flex-direction:column;gap:2px;display:flex}.site-title{letter-spacing:.03em;margin:0;font-size:28px;font-weight:800}.site-subtitle{color:#ffffffc2;margin:0;font-size:13px}.header-search{background:#fffffff5;border-radius:999px;align-items:center;gap:10px;padding:8px;display:flex;box-shadow:0 10px 24px #0f235033}.header-search input{min-width:0;color:var(--text);background:0 0;border:none;outline:none;flex:1;padding:11px 16px}.header-search input::placeholder{color:#8b95a7}.header-search button{background:linear-gradient(135deg, var(--accent) 0%, var(--primary) 100%);color:#fff;cursor:pointer;border:none;border-radius:999px;padding:11px 20px;font-weight:700}.header-search button:hover{filter:brightness(1.08)}.header-actions{justify-content:flex-end;display:flex}.login-button{color:#fff;cursor:pointer;white-space:nowrap;background:#ffffff1f;border:1px solid #ffffff52;border-radius:999px;padding:11px 18px;font-weight:700}.login-button:hover{background:#ffffff38}.login-button:disabled{cursor:default;opacity:.72}.top-search-area{max-width:var(--content-width);margin:24px auto 0;padding:0 24px}.search-box{border:1px solid var(--border);box-shadow:var(--shadow-sm);background:#ffffffe0;border-radius:999px;align-items:center;gap:12px;padding:10px;display:flex}.search-box input{background:0 0;border:none;outline:none;flex:1;min-width:240px;padding:12px 16px}.search-box button{background:linear-gradient(135deg, var(--accent) 0%, var(--primary) 100%);color:#fff;cursor:pointer;border:none;border-radius:999px;padding:12px 22px;font-weight:700}.content-layout{max-width:var(--content-width);grid-template-columns:260px minmax(0,1fr);gap:24px;margin:24px auto 0;padding:0 24px 32px;display:grid}@media (max-width:900px){.header{grid-template-columns:1fr;gap:14px}.header-actions{justify-content:flex-start}.header-search{width:100%}}.sidebar{border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);background:#fffffff0;height:fit-content;padding:22px}.sidebar h2{color:var(--primary-dark);margin:0 0 18px;font-size:18px}.filter-group{flex-direction:column;gap:8px;margin-bottom:18px;display:flex}.filter-group label{color:var(--text-soft);font-size:14px;font-weight:700}.filter-group select{border:1px solid var(--border);background:var(--surface-soft);border-radius:12px;padding:11px 12px}.company-list{border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);background:#fffffff0;padding:22px}.company-list h2{color:var(--primary-dark);margin:0 0 16px;font-size:20px}.company-list table{border-collapse:collapse;width:100%}.company-list thead th{color:var(--text-soft);border-bottom:1px solid var(--border);background:#f0f4fb;font-size:13px;font-weight:700}.company-list th,.company-list td{text-align:left;padding:16px 14px}.company-list tbody tr{border-bottom:1px solid #edf2f8}.clickable-row:hover{background:#e8eefbb3}.company-row-link{width:100%;display:block}.pagination{color:var(--text-soft);justify-content:space-between;align-items:center;gap:16px;margin-top:18px;font-size:14px;font-weight:700;display:flex}.pagination-actions{align-items:center;gap:10px;display:flex}.pagination-button{border:1px solid var(--border);min-width:72px;min-height:36px;color:var(--primary);background:#f7faff;border-radius:10px;justify-content:center;align-items:center;display:inline-flex}.pagination-button.disabled{color:#a8b2c3;background:#f2f5f9}.pagination-current{text-align:center;min-width:72px;color:var(--primary-dark)}.detail-page{max-width:var(--content-width);margin:0 auto;padding:28px 24px 40px}.detail-back-card{border-radius:var(--radius-lg);box-shadow:none;background:0 0;border:none;margin-bottom:14px;padding:0 0 10px}.detail-header{border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);background:#fffffff2;margin-bottom:22px;padding:28px}.detail-header h1{color:var(--primary-dark);margin:4px 0 0;font-size:30px}.detail-header p{color:var(--text-soft);margin:8px 0}.login-required-panel{border:1px solid var(--border);border-radius:var(--radius-lg);max-width:640px;box-shadow:var(--shadow-sm);background:#fffffff2;padding:28px}.login-required-panel p{color:var(--text-soft);margin:0 0 18px;line-height:1.8}.primary-action-button{background:linear-gradient(135deg, var(--accent) 0%, var(--primary) 100%);color:#fff;cursor:pointer;border:none;border-radius:12px;padding:12px 18px;font-weight:700}.primary-action-button:hover{filter:brightness(1.08)}.auth-error-page{justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.auth-error-panel{border:1px solid var(--border);border-radius:var(--radius-lg);width:min(560px,100%);box-shadow:var(--shadow-sm);background:#fffffff5;padding:32px}.auth-error-panel h1{color:var(--primary-dark);margin:0 0 12px;font-size:26px}.auth-error-panel p{color:var(--text-soft);margin:0 0 20px;line-height:1.8}.auth-error-code{font-family:Consolas,Courier New,monospace;font-size:13px}.back-link{color:var(--primary);gap:6px;font-weight:700;display:inline-flex}.company-summary-row{grid-template-columns:minmax(320px,1fr) minmax(520px,1.45fr);align-items:stretch;gap:14px;display:grid}.company-name-block,.summary-block{background:#fbfdff;border:1px solid #edf2f8;border-radius:12px;padding:14px 16px}.company-name-block{min-width:0;min-height:266px}.company-summary-side{grid-template-rows:auto auto auto;gap:14px;min-width:0;display:grid}.summary-meta-row,.summary-metric-row{gap:14px;display:grid}.summary-meta-row{grid-template-columns:140px 150px minmax(180px,1fr)}.summary-metric-row{grid-template-columns:repeat(4,minmax(100px,1fr))}.summary-block{flex-direction:column;justify-content:center;min-height:82px;display:flex}.summary-label{color:var(--text-soft);margin-bottom:6px;font-size:12px;font-weight:700;display:block}.summary-block strong{color:var(--primary-dark);font-size:17px}.summary-reference-row{background:#fbfdff;border:1px solid #edf2f8;border-radius:12px;min-height:74px;padding:14px 16px}.summary-reference-row strong{color:var(--primary-dark);font-size:14px;line-height:1.6;display:block}.summary-code,.summary-market,.summary-industry,.summary-kpi{width:100%}.detail-graphs{grid-template-columns:1fr;gap:22px;display:grid}.graph-card{border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);background:#fffffff2;padding:24px}.graph-card h3{color:var(--primary-dark);margin:0 0 18px;font-size:20px}.graph-bars{border-top:1px solid #eef3f9;align-items:flex-end;gap:26px;min-height:280px;padding:20px 8px 4px;display:flex}.graph-bar-item{flex-direction:column;align-items:center;gap:10px;min-width:60px;display:flex}.graph-bar{background:linear-gradient(180deg, var(--accent) 0%, var(--primary-dark) 100%);border-radius:12px 12px 0 0;width:52px}.graph-bar-item span{color:var(--text-soft);font-size:13px;font-weight:700}.metric-table-card{border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);background:#fffffff2;padding:24px}.metric-table-card h2{color:var(--primary-dark);margin:0 0 18px;font-size:20px}.metric-table-wrap{overflow-x:auto}.metric-table{border-collapse:collapse;width:100%;min-width:880px}.metric-table thead th{color:var(--text-soft);border-bottom:1px solid var(--border);background:#f0f4fb;font-size:13px;font-weight:700}.metric-table th,.metric-table td{text-align:left;border-bottom:1px solid #edf2f8;padding:14px 12px}.metric-value{text-align:right;font-variant-numeric:tabular-nums}.detail-tabs{border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);background:#fffffff2;overflow:hidden}.detail-tabs>input{opacity:0;pointer-events:none;position:absolute}.tab-list{border-bottom:1px solid var(--border);background:#f7faff;gap:4px;padding:16px 18px 0;display:flex}.tab-button{min-width:128px;min-height:44px;color:var(--text-soft);cursor:pointer;border:1px solid #0000;border-bottom:none;border-radius:12px 12px 0 0;justify-content:center;align-items:center;padding:10px 18px;font-weight:700;display:inline-flex}#tab-revenue:checked~.tab-list label[for=tab-revenue],#tab-cashflow:checked~.tab-list label[for=tab-cashflow],#tab-finance:checked~.tab-list label[for=tab-finance],#tab-profile:checked~.tab-list label[for=tab-profile]{border-color:var(--border);color:var(--primary-dark);background:#fff}.tab-panels{padding:24px}.tab-panel{display:none}#tab-revenue:checked~.tab-panels .tab-panel-revenue,#tab-cashflow:checked~.tab-panels .tab-panel-cashflow,#tab-finance:checked~.tab-panels .tab-panel-finance,#tab-profile:checked~.tab-panels .tab-panel-profile{display:block}.tab-panel-content h2{color:var(--primary-dark);margin:0 0 18px;font-size:20px}.chart-card{margin-bottom:22px}.chart-card-header{justify-content:space-between;align-items:center;gap:18px;margin-bottom:14px;display:flex}.chart-card-header h2{margin:0}.chart-legend{color:var(--text-soft);flex-wrap:wrap;gap:12px;font-size:13px;font-weight:700;display:flex}.legend-item{align-items:center;gap:6px;display:inline-flex}.legend-swatch{border-radius:3px;width:14px;height:14px}.legend-sales{background:#315aa3}.legend-profit{background:#8f3559}.legend-cost{background:#6d6478}.legend-sga{background:#6a7a3d}.legend-operating-cf{background:#315aa3}.legend-investing-cf{background:#8f3559}.legend-financing-cf{background:#6d6478}.legend-line{background:#b34848;border-radius:999px;width:24px;height:3px}.revenue-chart-wrap{background:#fbfdff;border:1px solid #edf2f8;border-radius:14px;width:100%;max-width:940px;overflow-x:auto}.revenue-chart{width:100%;min-width:680px;height:auto;display:block}.revenue-chart text{fill:var(--text-soft);font-size:12px;font-weight:700}.revenue-chart .chart-axis-title{fill:var(--primary-dark);font-size:13px}.chart-grid{stroke:#e6edf6;stroke-width:1px}.chart-axis{stroke:#aeb9ca;stroke-width:1.2px}.chart-bar-sales{fill:#315aa3}.chart-bar-profit{fill:#8f3559}.chart-bar-cost{fill:#6d6478}.chart-bar-sga{fill:#6a7a3d}.chart-bar-operating-cf{fill:#315aa3}.chart-bar-investing-cf{fill:#8f3559}.chart-bar-financing-cf{fill:#6d6478}.chart-line{fill:none;stroke:#b34848;stroke-width:3px;stroke-linejoin:round;stroke-linecap:round}.chart-point{fill:#fff;stroke:#b34848;stroke-width:3px}.finance-chart-grid{grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:18px;display:grid}.finance-chart-card{background:#fbfdff;border:1px solid #edf2f8;border-radius:14px;padding:16px}.finance-chart-header{justify-content:space-between;align-items:center;gap:12px;margin-bottom:8px;display:flex}.finance-chart-header h3{color:var(--primary-dark);margin:0;font-size:16px}.finance-chart-header span,.finance-chart-latest{color:var(--text-soft);font-size:12px;font-weight:700}.finance-mini-chart{width:100%;height:auto;display:block}.finance-mini-chart text{fill:var(--text-soft);font-size:11px;font-weight:700}.finance-chart-line{fill:none;stroke:#315aa3;stroke-width:3px;stroke-linecap:round;stroke-linejoin:round}.finance-chart-point{fill:#fff;stroke:#315aa3;stroke-width:3px}.finance-chart-latest{text-align:right;margin-top:6px}.cashflow-chart-wrap{background:#fbfdff;border:1px solid #edf2f8;border-radius:14px;width:100%;max-width:940px;overflow-x:auto}.cashflow-chart{width:100%;min-width:680px;height:auto;display:block}.cashflow-chart text,.cashflow-scatter-chart text{fill:var(--text-soft);font-size:12px;font-weight:700}.cashflow-scatter-card{max-width:620px}.cashflow-scatter-wrap{background:#fbfdff;border:1px solid #edf2f8;border-radius:14px;width:100%;overflow-x:auto}.cashflow-scatter-chart{width:100%;min-width:420px;height:auto;display:block}.scatter-frame{fill:#0000;stroke:#e6edf6;stroke-width:1px}.scatter-grid{stroke:#eef3f9;stroke-width:1px}.scatter-point{fill:#315aa3;stroke:#fff;stroke-width:2px}.empty-panel{color:var(--text-soft);margin:0;padding:28px}.company-profile-list{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin:0;display:grid}.company-profile-list div{background:#fbfdff;border:1px solid #edf2f8;border-radius:12px;padding:14px 16px}.company-profile-list dt{color:var(--text-soft);margin-bottom:6px;font-size:13px;font-weight:700}.company-profile-list dd{color:var(--text);white-space:pre-wrap;margin:0;font-weight:700;line-height:1.7}.company-profile-wide{grid-column:1/-1}@media (max-width:980px){.company-summary-row{grid-template-columns:1fr}.company-name-block{min-height:auto}}@media (max-width:640px){.company-summary-row,.summary-meta-row,.summary-metric-row{grid-template-columns:1fr}}
