:root{--color-bg: #f4f6f8;--color-surface: #ffffff;--color-border: #dde3ea;--color-text: #1f2937;--color-text-muted: #6b7280;--color-accent: #2563eb;--color-accent-dark: #1d4ed8;--color-success: #16a34a;--color-success-bg: #ecfdf3;--color-error: #dc2626;--color-error-bg: #fef2f2;--color-warn: #d97706;--color-warn-bg: #fffbeb;--color-gray-bg: #eef1f4;--radius: 8px;--shadow-sm: 0 1px 2px rgba(15, 23, 42, .06)}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;background:var(--color-bg);color:var(--color-text);font-family:Hiragino Kaku Gothic ProN,Yu Gothic,Meiryo,Segoe UI,sans-serif;font-size:14px;line-height:1.5}button{font-family:inherit}.app-loading{display:flex;align-items:center;justify-content:center;height:100vh;color:var(--color-text-muted);font-size:16px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 16px;border-radius:var(--radius);border:1px solid transparent;font-size:14px;font-weight:600;cursor:pointer;transition:background-color .15s ease,border-color .15s ease,opacity .15s ease}.btn:disabled{cursor:not-allowed;opacity:.5}.btn--primary{background:var(--color-accent);color:#fff}.btn--primary:hover:not(:disabled){background:var(--color-accent-dark)}.btn--secondary{background:var(--color-surface);color:var(--color-accent);border-color:var(--color-accent)}.btn--secondary:hover:not(:disabled){background:#eff4ff}.btn--ghost{background:transparent;color:var(--color-text-muted);border-color:var(--color-border)}.btn--ghost:hover:not(:disabled){background:var(--color-gray-bg)}.hint-text{color:var(--color-text-muted);font-size:13px;margin:4px 0}.hint-text--warn{color:var(--color-warn)}.error-text{color:var(--color-error);background:var(--color-error-bg);border:1px solid #fecaca;border-radius:var(--radius);padding:8px 12px;font-size:13px;margin:8px 0}.section-heading{font-size:14px;font-weight:700;margin:16px 0 8px;color:var(--color-text)}.status-badge{display:inline-block;padding:2px 10px;border-radius:999px;font-size:12px;font-weight:600;white-space:nowrap}.status-badge--not-started{background:var(--color-gray-bg);color:var(--color-text-muted)}.status-badge--draft{background:var(--color-warn-bg);color:var(--color-warn)}.status-badge--done{background:var(--color-success-bg);color:var(--color-success)}.portal-header{display:flex;align-items:center;justify-content:space-between;padding:12px 24px;background:var(--color-surface);border-bottom:1px solid var(--color-border)}.portal-header__titles{display:flex;align-items:baseline;gap:12px}.portal-header__actions{display:flex;align-items:center;gap:8px}.portal-title{font-size:18px;font-weight:700}.portal-subtitle{font-size:13px;color:var(--color-text-muted)}.closed-banner{background:var(--color-error-bg);color:var(--color-error);text-align:center;padding:8px;font-weight:600;border-bottom:1px solid #fecaca}.toast-host{position:fixed;top:16px;right:16px;display:flex;flex-direction:column;gap:8px;z-index:1000}.toast{min-width:220px;max-width:360px;padding:10px 16px;border-radius:var(--radius);box-shadow:0 4px 12px #0f172a26;font-size:13px;font-weight:600;color:#fff;animation:toast-in .15s ease-out}@keyframes toast-in{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.toast--success{background:var(--color-success)}.toast--error{background:var(--color-error)}.toast--info{background:#334155}.login-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}.login-card{width:100%;max-width:380px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;box-shadow:var(--shadow-sm);padding:32px}.login-title{font-size:18px;font-weight:700;text-align:center;margin:0 0 16px}.config-banner{text-align:center;font-size:13px;padding:8px 12px;border-radius:var(--radius);margin-bottom:20px}.config-banner--open{background:var(--color-success-bg);color:var(--color-success)}.config-banner--closed{background:var(--color-gray-bg);color:var(--color-text-muted)}.login-tabs{display:flex;border:1px solid var(--color-border);border-radius:var(--radius);overflow:hidden;margin-bottom:20px}.login-tab{flex:1;padding:10px;background:var(--color-surface);border:none;cursor:pointer;font-size:13px;font-weight:600;color:var(--color-text-muted)}.login-tab--active{background:var(--color-accent);color:#fff}.login-form{display:flex;flex-direction:column;gap:14px}.login-field{display:flex;flex-direction:column;gap:6px;font-size:13px;font-weight:600;color:var(--color-text-muted)}.login-field input{padding:9px 12px;border:1px solid var(--color-border);border-radius:var(--radius);font-size:14px;color:var(--color-text)}.login-field input:focus{outline:2px solid var(--color-accent);outline-offset:1px}.login-error{color:var(--color-error);font-size:13px;margin:0}.login-form .btn{margin-top:4px}.evaluator-portal{min-height:100vh;display:flex;flex-direction:column}.evaluator-columns{flex:1;display:grid;grid-template-columns:300px 1fr 380px;gap:16px;padding:16px;align-items:start}.column{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:16px}.column--list{display:flex;flex-direction:column;max-height:calc(100vh - 100px)}.counts-row{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:12px}.count-tile{background:var(--color-gray-bg);border-radius:var(--radius);padding:8px;display:flex;flex-direction:column;align-items:center;gap:2px}.count-tile__label{font-size:11px;color:var(--color-text-muted)}.count-tile__value{font-size:18px;font-weight:700}.evaluee-list{list-style:none;margin:0;padding:0;overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:4px}.evaluee-item{width:100%;display:flex;align-items:center;gap:8px;padding:8px 10px;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);cursor:pointer;text-align:left;font-size:13px}.evaluee-item:hover{border-color:var(--color-accent)}.evaluee-item--active{border-color:var(--color-accent);background:#eff4ff}.evaluee-item__id{color:var(--color-text-muted);font-size:12px;flex-shrink:0}.evaluee-item__name{flex:1;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.empty-state{display:flex;align-items:center;justify-content:center;height:200px;color:var(--color-text-muted);font-size:13px;text-align:center}.evaluee-info{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:0}.evaluee-info div{display:flex;flex-direction:column;gap:2px}.evaluee-info dt{font-size:11px;color:var(--color-text-muted)}.evaluee-info dd{margin:0;font-size:14px;font-weight:600}.pdf-link-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:8px}.pdf-link-card{display:flex;align-items:center;justify-content:center;padding:12px 8px;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-gray-bg);color:var(--color-accent);font-size:13px;font-weight:600;text-decoration:none;text-align:center}.pdf-link-card:hover{border-color:var(--color-accent);background:#eff4ff}.score-form{display:flex;flex-direction:column;gap:14px}.score-option-group__label{display:block;font-size:12px;font-weight:700;color:var(--color-text-muted);margin-bottom:6px}.score-option-group__buttons{display:flex;flex-wrap:wrap;gap:6px}.score-option{min-width:42px;padding:6px 10px;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);cursor:pointer;font-size:13px;font-weight:600}.score-option:hover:not(:disabled){border-color:var(--color-accent)}.score-option--active{background:var(--color-accent);border-color:var(--color-accent);color:#fff}.score-option:disabled{cursor:not-allowed;opacity:.5}.comment-field{display:flex;flex-direction:column;gap:6px;font-size:12px;font-weight:700;color:var(--color-text-muted)}.comment-field textarea{font-family:inherit;font-size:13px;color:var(--color-text);padding:10px;border:1px solid var(--color-border);border-radius:var(--radius);resize:vertical}.comment-field textarea:focus{outline:2px solid var(--color-accent);outline-offset:1px}.score-preview{display:flex;gap:12px;background:var(--color-gray-bg);border-radius:var(--radius);padding:12px}.score-preview>div{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px}.score-preview__label{font-size:11px;color:var(--color-text-muted)}.score-preview__value{font-size:24px;font-weight:700}.score-preview__value--rank{font-size:24px}.rank-S{color:#c026d3}.rank-A{color:var(--color-accent)}.rank-B{color:var(--color-success)}.rank-C{color:var(--color-text-muted)}.save-buttons{display:flex;gap:10px}.save-buttons .btn{flex:1}.admin-portal{min-height:100vh;display:flex;flex-direction:column}.admin-topbar{background:var(--color-surface);border-bottom:1px solid var(--color-border);padding:16px 24px;display:flex;flex-direction:column;gap:12px}.admin-topbar__meta{display:flex;align-items:center;gap:16px;font-size:13px;color:var(--color-text-muted)}.admin-topbar__month{font-weight:700;color:var(--color-text)}.status-pill{display:inline-block;padding:3px 12px;border-radius:999px;font-size:12px;font-weight:700}.status-pill--open{background:var(--color-success-bg);color:var(--color-success)}.status-pill--closed{background:var(--color-gray-bg);color:var(--color-text-muted)}.kpi-row{display:grid;grid-template-columns:repeat(6,1fr);gap:10px}.kpi-tile{background:var(--color-gray-bg);border-radius:var(--radius);padding:12px;display:flex;flex-direction:column;gap:4px}.kpi-tile--warn{background:var(--color-warn-bg)}.kpi-tile--warn .kpi-tile__value{color:var(--color-warn)}.kpi-tile__label{font-size:11px;color:var(--color-text-muted)}.kpi-tile__value{font-size:22px;font-weight:700}.admin-main{flex:1;display:grid;grid-template-columns:1fr 340px;gap:16px;padding:16px 24px;align-items:start}.admin-center,.admin-right{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:16px}.progress-table{width:100%;border-collapse:collapse;font-size:13px}.progress-table th,.progress-table td{padding:8px 10px;border-bottom:1px solid var(--color-border);text-align:left}.progress-table th{color:var(--color-text-muted);font-weight:600;font-size:12px}.progress-row--complete{color:var(--color-text-muted)}.admin-right{display:flex;flex-direction:column;gap:12px}.remind-preview{display:flex;flex-direction:column;gap:8px}.remind-message{white-space:pre-wrap;word-break:break-word;background:var(--color-gray-bg);border:1px solid var(--color-border);border-radius:var(--radius);padding:12px;font-size:13px;font-family:inherit;margin:0}
