/* ==========================================================================
 * 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);
  background: color-mix(in srgb, var(--color-success) 12%, transparent);
}

.c-urgency--medium {
  color: var(--color-warning-text);
  background: color-mix(in srgb, var(--color-warning) 18%, transparent);
}

.c-urgency--high {
  color: var(--color-caution);
  background: color-mix(in srgb, var(--color-caution) 12%, transparent);
}

.c-urgency--critical {
  color: var(--color-error);
  background: color-mix(in srgb, var(--color-error) 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);
  border-radius: var(--radius-md, 8px);
  background: var(--color-surface);
  text-decoration: none;
  color: var(--color-text);
  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);
  box-shadow: 0 4px 12px rgb(0 0 0 / 0.08);
}

.triage-category-card__icon {
  font-size: 2rem;
  color: var(--color-primary);
}

.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);
}

/* --- Diagnosis & self-care sections --- */
.triage-result__diagnosis,
.triage-result__selfcare {
  margin-block-start: var(--sz-space-md, 1rem);
  padding: var(--sz-space-md, 1rem);
  border-radius: var(--radius-sm, 4px);
  background: color-mix(in srgb, var(--color-primary) 5%, var(--color-surface));
  border-inline-start: 4px solid var(--color-primary);
}

.triage-result__diagnosis-title,
.triage-result__selfcare-title {
  display: flex;
  align-items: center;
  gap: var(--sz-space-xs, 0.5rem);
  font-size: var(--font-size-base, 1rem);
  font-weight: var(--font-weight-bold, 700);
  margin: 0 0 var(--sz-space-xs, 0.5rem);
  color: var(--color-primary);
}

.triage-result__diagnosis-title .material-symbols-outlined,
.triage-result__selfcare-title .material-symbols-outlined {
  font-size: 1.25rem;
}

.triage-result__diagnosis p,
.triage-result__selfcare p {
  margin: 0;
  line-height: 1.6;
}

/* --- Patient info --- */
.triage-result-patient {
  margin: 0;
}

.triage-result-patient__item {
  display: flex;
  gap: var(--sz-space-md, 1rem);
  padding-block: var(--sz-space-xs, 0.5rem);
  border-block-end: 1px solid var(--color-border);
}

.triage-result-patient__item dt {
  font-weight: var(--font-weight-bold, 700);
  min-width: 5rem;
  color: var(--color-text-muted);
}

.triage-result-patient__item dd {
  margin: 0;
}

/* ========== Wearable (≤279px): トリアージ最小表示 ========== */
@media (max-width: 279px) {
  .triage-container {
    padding: var(--space-watch-sm, 0.25rem);
  }

  .triage-step__icon {
    display: none;
  }

  .triage-step__title {
    font-size: var(--font-watch-sm, 0.75rem);
  }

  .triage-btn {
    font-size: var(--font-watch-sm, 0.75rem);
    min-height: 2rem;
    width: 100%;
  }
}

/* --- Progress Bar (.c-progress) --- */
.c-progress {
  position: sticky;
  inset-block-start: 0;
  z-index: 10;
  background-color: var(--color-gray-200);
  border-radius: var(--radius-sm, 0.25rem);
  overflow: hidden;
  margin-block-end: var(--spacing-md, 1rem);
}

.c-progress__bar {
  block-size: 0.5rem;
  background-color: var(--color-primary);
  border-radius: var(--radius-sm, 0.25rem);
  inline-size: var(--progress, 0%);
  transition: inline-size 0.3s ease;
}

.c-progress__label {
  display: block;
  text-align: center;
  font-size: clamp(0.6875rem, 0.625rem + 0.2vw, 0.8125rem);
  color: var(--color-text-muted);
  padding-block: var(--spacing-xs, 0.25rem);
}
