/* AI 放課後 / Operational Console — リアルタイム稼働画面
   既存 style.css を拡張する形で console 専用スタイルを定義。 */

.console-body { background: var(--bg); }

.console-header {
  position: sticky; top: 0; z-index: 50;
  background: rgba(10,22,40,.92);
  backdrop-filter: blur(8px);
  border-bottom: 1px solid var(--border);
}

.live-badge {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 4px 12px;
  background: rgba(231, 111, 81, .15);
  border: 1px solid rgba(231, 111, 81, .4);
  border-radius: 999px;
  font-size: 12px; font-weight: 600;
  color: var(--warn); letter-spacing: .08em;
}
.live-dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--warn);
  animation: pulse 1.6s ease-in-out infinite;
}
.live-badge-inline {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 2px 8px; margin-right: 8px;
  background: rgba(231, 111, 81, .15);
  border: 1px solid rgba(231, 111, 81, .4);
  border-radius: 999px;
  font-size: 11px; font-weight: 600;
  color: var(--warn); letter-spacing: .08em;
  vertical-align: middle;
}
.live-badge-inline .live-dot { width: 6px; height: 6px; }
@keyframes pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: .4; transform: scale(.85); }
}

.console-main { padding: 40px 0 80px; }

.console-hero { margin-bottom: 56px; }
.console-hero h1 {
  margin: 8px 0 16px;
  font-size: clamp(28px, 4vw, 40px);
  font-weight: 700; letter-spacing: -.01em;
}
.console-lead { color: var(--text-muted); margin: 0 0 16px; }
.console-meta {
  margin: 0; font-size: 13px; color: var(--text-subtle);
  font-family: var(--font-en);
}
.console-meta time { color: var(--accent); }
.dot-sep { margin: 0 8px; color: var(--border); }

.console-section { margin-bottom: 56px; }
.console-section .section-head { text-align: left; max-width: none; margin-bottom: 24px; }
.console-section h2 { font-size: clamp(20px, 2.5vw, 28px); }

/* === Active Shift === */
.active-shift {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 16px;
}
.shift-agent-card {
  display: flex; align-items: center; gap: 16px;
  padding: 20px;
  background: var(--bg-elev);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  transition: border-color .2s;
}
.shift-agent-card.active { border-color: var(--accent); }
.shift-agent-card.design-only { opacity: 0.55; pointer-events: none; }
.shift-agent-card.active::before {
  content: ""; width: 8px; height: 8px; border-radius: 50%;
  background: var(--success); flex-shrink: 0;
  box-shadow: 0 0 8px var(--success);
}
.shift-agent-card img {
  width: 56px; height: 56px; border-radius: 12px;
  background: var(--bg-elev-2); object-fit: contain;
}
.shift-agent-info { flex: 1; min-width: 0; }
.shift-agent-name { font-weight: 700; font-size: 16px; margin: 0 0 4px; }
.shift-agent-role {
  font-size: 12px; color: var(--accent);
  letter-spacing: .03em; margin: 0 0 4px;
}
.shift-agent-status { font-size: 12px; color: var(--text-muted); margin: 0; }

/* === Metrics === */
.console-metrics {
  display: grid; gap: 16px; margin: 0;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
}
.metric-card {
  padding: 24px;
  background: var(--bg-elev);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
}
.metric-card dt {
  font-size: 12px; color: var(--text-muted);
  letter-spacing: .05em; text-transform: uppercase;
  margin-bottom: 12px;
}
.metric-card dd {
  margin: 0 0 8px;
  font-size: clamp(28px, 4vw, 40px);
  font-weight: 700; color: var(--accent);
  font-family: var(--font-en); line-height: 1;
}
.metric-desc { margin: 0; font-size: 13px; color: var(--text-subtle); }

/* === Incident Timeline === */
.incident-timeline {
  list-style: none; margin: 0; padding: 0;
  display: grid; gap: 16px;
}
.incident-card {
  padding: 20px;
  background: var(--bg-elev);
  border: 1px solid var(--border);
  border-left: 4px solid var(--text-subtle);
  border-radius: var(--radius);
}
.incident-card.severity-high { border-left-color: var(--warn); }
.incident-card.severity-mid { border-left-color: var(--accent); }
.incident-card.severity-low { border-left-color: var(--success); }
.incident-meta {
  display: flex; flex-wrap: wrap; gap: 12px;
  font-size: 12px; color: var(--text-muted);
  margin-bottom: 12px;
}
.incident-meta time { font-family: var(--font-en); color: var(--accent); }
.incident-tag {
  padding: 2px 10px;
  background: var(--bg-elev-2);
  border-radius: 999px;
  font-size: 11px; color: var(--text);
}
.incident-title { margin: 0 0 12px; font-size: 16px; font-weight: 700; }
.incident-post {
  margin: 0 0 16px; padding: 12px;
  background: var(--bg-elev-2);
  border-left: 2px solid var(--text-muted);
  border-radius: 4px;
  font-size: 13px; line-height: 1.7; color: var(--text-muted);
  font-style: italic;
}
.incident-score {
  display: inline-flex; align-items: baseline; gap: 8px;
  margin-bottom: 12px;
}
.incident-score-num {
  font-size: 32px; font-weight: 700;
  color: var(--accent); font-family: var(--font-en);
}
.incident-score-label { font-size: 13px; color: var(--text-muted); }
.incident-summary {
  margin: 0; font-size: 14px; line-height: 1.8;
  color: var(--text);
}

/* === Nocturne Countdown === */
.console-section-nocturne {
  background: linear-gradient(135deg,
    rgba(244,162,97,.06) 0%,
    rgba(99,102,241,.04) 100%);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 32px;
  margin-bottom: 56px;
}
.console-section-nocturne .section-head { margin-bottom: 16px; }
.nocturne-countdown { text-align: center; }
.countdown-display {
  display: inline-flex; align-items: baseline; gap: 8px;
  margin-bottom: 16px;
}
.countdown-display span:not(.countdown-unit) {
  font-size: clamp(48px, 8vw, 80px);
  font-weight: 700; color: var(--accent);
  font-family: var(--font-en); line-height: 1;
}
.countdown-unit {
  font-size: 16px; color: var(--text-muted);
  margin-right: 12px;
}
.countdown-info {
  margin: 0 0 12px; font-size: 14px; color: var(--text);
}
.countdown-info strong { color: var(--accent); margin: 0 4px; }
.countdown-detail {
  margin: 0; font-size: 13px; color: var(--text-muted);
  max-width: 480px; margin: 0 auto;
}

.console-footer-note {
  margin: 32px 0 0;
  padding: 16px;
  background: rgba(42, 157, 143, .06);
  border: 1px solid rgba(42, 157, 143, .25);
  border-radius: var(--radius);
  font-size: 13px; color: var(--text);
  display: flex; align-items: flex-start; gap: 8px;
  line-height: 1.7;
}

.loading {
  padding: 40px; text-align: center;
  color: var(--text-muted); font-size: 14px;
}

@media (max-width: 640px) {
  .console-meta { display: flex; flex-direction: column; gap: 4px; }
  .dot-sep { display: none; }
  .countdown-display { gap: 4px; }
  .countdown-unit { font-size: 14px; margin-right: 8px; }
}
