/* ==========================================================================
 * Project: Triage (.c-urgency)
 * AI問診 — 緊急度表示スタイル
 * ========================================================================== */

/* --- Urgency label --- */
.c-urgency {
  display: inline-block;
  padding: var(--spacing-xs, 4px) var(--spacing-md, 12px);
  border-radius: var(--radius-sm, 4px);
  font-weight: var(--font-weight-bold, 700);
  font-size: var(--font-size-lg, 1.125rem);
}

.c-urgency--low {
  color: var(--color-success, #198754);
  background: color-mix(in srgb, var(--color-success, #198754) 12%, transparent);
}

.c-urgency--medium {
  color: var(--color-warning-text, #856404);
  background: color-mix(in srgb, var(--color-warning, #ffc107) 18%, transparent);
}

.c-urgency--high {
  color: var(--color-caution, #fd7e14);
  background: color-mix(in srgb, var(--color-caution, #fd7e14) 12%, transparent);
}

.c-urgency--critical {
  color: var(--color-error, #dc3545);
  background: color-mix(in srgb, var(--color-error, #dc3545) 12%, transparent);
}

/* --- Triage index page --- */
.triage-alert {
  margin-block-start: var(--sz-space-lg, 1.5rem);
}

.triage-category-heading {
  margin-block-start: var(--sz-space-xl, 2rem);
  font-size: clamp(1.125rem, 1rem + 0.5vw, 1.375rem);
  font-weight: var(--font-weight-bold, 700);
}

.triage-category-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--sz-space-md, 1rem);
  margin-block-start: var(--sz-space-lg, 1.5rem);
}

@media (min-width: 600px) {
  .triage-category-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

@media (min-width: 1024px) {
  .triage-category-grid {
    grid-template-columns: repeat(4, 1fr);
  }
}

.triage-category-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--sz-space-xs, 0.5rem);
  padding: var(--sz-space-lg, 1.5rem) var(--sz-space-md, 1rem);
  border: 1px solid var(--color-border, #dee2e6);
  border-radius: var(--radius-md, 8px);
  background: var(--color-surface, #fff);
  text-decoration: none;
  color: var(--color-text, #333);
  transition: box-shadow 0.2s ease, border-color 0.2s ease;
  min-height: 48px;
}

.triage-category-card:hover,
.triage-category-card:focus-visible {
  border-color: var(--color-primary, #1a6b3c);
  box-shadow: 0 4px 12px rgb(0 0 0 / 0.08);
}

.triage-category-card__icon {
  font-size: 2rem;
  color: var(--color-primary, #1a6b3c);
}

.triage-category-card__name {
  margin: 0;
  font-size: var(--font-size-sm, 0.875rem);
  font-weight: var(--font-weight-medium, 500);
  text-align: center;
}

.triage-empty {
  margin-block-start: var(--sz-space-xl, 2rem);
}

/* --- Questionnaire form --- */
.triage-form {
  margin-block-start: var(--sz-space-xl, 2rem);
}

.triage-result {
  margin-block-start: var(--sz-space-xl, 2rem);
}

.triage-result__dept {
  margin-block-start: var(--sz-space-md, 1rem);
}

.triage-result__actions {
  margin-block-start: var(--sz-space-lg, 1.5rem);
}

/* --- Result page detail styles --- */
.triage-result-box {
  margin-block-start: var(--sz-space-lg, 1.5rem);
}

.triage-result-recommendation {
  margin-block-start: var(--sz-space-sm, 0.75rem);
}

.triage-result-dept-icon {
  vertical-align: middle;
}

.triage-result-answer {
  padding-block: var(--sz-space-xs, 0.5rem);
  border-block-end: 1px solid var(--sz-border, #eee);
}

.triage-result-score {
  margin-block-start: var(--sz-space-sm, 0.75rem);
  color: var(--sz-text-muted, #666);
}

.triage-result-emergency {
  margin-block-start: var(--sz-space-lg, 1.5rem);
}

.triage-result-emergency__tel {
  margin-block-start: var(--sz-space-sm, 0.75rem);
}

.triage-result-actions {
  margin-block-start: var(--sz-space-xl, 2rem);
}

.triage-result-disclaimer {
  margin-block-start: var(--sz-space-lg, 1.5rem);
}
