:root {
  --bg: #eef3f8;
  --bg-strong: #dfe8f1;
  --sidebar: #102033;
  --sidebar-2: #132943;
  --panel: #ffffff;
  --panel-soft: #f6f8fb;
  --line: #d9e2ec;
  --line-strong: #c6d2df;
  --ink: #172033;
  --sub: #627184;
  --muted: #95a3b5;
  --primary: #2563eb;
  --primary-dark: #1e40af;
  --primary-soft: #dbeafe;
  --sky: #0284c7;
  --sky-soft: #e0f2fe;
  --green: #16a34a;
  --green-soft: #dcfce7;
  --amber: #d97706;
  --amber-soft: #ffedd5;
  --red: #dc2626;
  --red-soft: #fee2e2;
  --purple: #7c3aed;
  --purple-soft: #ede9fe;
  --shadow-sm: 0 1px 2px rgba(15, 23, 42, 0.06);
  --shadow-md: 0 12px 28px rgba(20, 35, 58, 0.1);
}

* {
  box-sizing: border-box;
}

html {
  background: var(--bg);
}

body {
  margin: 0;
  min-height: 100vh;
  color: var(--ink);
  background:
    linear-gradient(180deg, rgba(37, 99, 235, 0.07), transparent 320px),
    linear-gradient(90deg, rgba(2, 132, 199, 0.06), transparent 38%),
    var(--bg);
  font-family: Inter, Pretendard, "Noto Sans KR", Arial, sans-serif;
}

button,
input {
  font: inherit;
}

button {
  border: 0;
  cursor: pointer;
}

.admin-shell {
  display: grid;
  grid-template-columns: 280px minmax(0, 1fr);
  min-height: 100vh;
}

.sidebar {
  position: sticky;
  top: 0;
  height: 100vh;
  overflow: hidden;
  padding: 24px 18px;
  color: #fff;
  background:
    linear-gradient(180deg, rgba(96, 165, 250, 0.14), transparent 38%),
    linear-gradient(160deg, var(--sidebar), var(--sidebar-2));
  box-shadow: 10px 0 36px rgba(15, 23, 42, 0.16);
}

.sidebar::before {
  position: absolute;
  inset: -90px -120px auto auto;
  width: 260px;
  height: 260px;
  border-radius: 50%;
  background: rgba(125, 211, 252, 0.16);
  content: "";
}

.brand {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  gap: 13px;
  padding: 6px 8px 26px;
}

.brand-mark {
  display: grid;
  place-items: center;
  width: 46px;
  height: 46px;
  border: 1px solid rgba(191, 219, 254, 0.45);
  border-radius: 8px;
  color: #0f2a43;
  background: linear-gradient(145deg, #ffffff, #bfdbfe);
  box-shadow: 0 10px 24px rgba(14, 165, 233, 0.2);
  font-size: 14px;
  font-weight: 950;
}

.brand strong,
.brand span {
  display: block;
}

.brand strong {
  font-size: 19px;
  line-height: 1.1;
}

.brand span {
  margin-top: 4px;
  color: #b8c7d9;
  font-size: 12px;
  font-weight: 800;
}

.side-nav {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 7px;
}

.side-item {
  display: flex;
  align-items: center;
  width: 100%;
  min-height: 46px;
  padding: 0 12px;
  border: 1px solid transparent;
  border-radius: 8px;
  background: transparent;
  color: #cbd5e1;
  text-align: left;
  font-size: 14px;
  font-weight: 850;
}

.side-item::before {
  display: grid;
  place-items: center;
  width: 26px;
  height: 26px;
  margin-right: 10px;
  border-radius: 7px;
  background: rgba(255, 255, 255, 0.08);
  color: #93c5fd;
  font-size: 11px;
  font-weight: 950;
  content: "A";
}

.side-item:nth-child(1)::before { content: "DB"; }
.side-item:nth-child(2)::before { content: "US"; }
.side-item:nth-child(3)::before { content: "RQ"; }
.side-item:nth-child(4)::before { content: "VS"; }
.side-item:nth-child(5)::before { content: "AI"; }
.side-item:nth-child(6)::before { content: "AS"; }
.side-item:nth-child(7)::before { content: "CK"; }
.side-item:nth-child(8)::before { content: "AL"; }
.side-item:nth-child(9)::before { content: "NT"; }
.side-item:nth-child(10)::before { content: "SY"; }

.side-item:hover,
.side-item.active {
  border-color: rgba(147, 197, 253, 0.25);
  background: rgba(255, 255, 255, 0.1);
  color: #fff;
  box-shadow: inset 3px 0 0 #7dd3fc;
}

.side-item.active::before {
  background: #dbeafe;
  color: var(--primary-dark);
}

.api-card {
  position: absolute;
  right: 18px;
  bottom: 20px;
  left: 18px;
  z-index: 1;
  padding: 15px;
  border: 1px solid rgba(148, 163, 184, 0.2);
  border-radius: 8px;
  background: rgba(15, 23, 42, 0.45);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.06);
}

.api-card span,
.api-card small {
  display: block;
}

.api-card span {
  color: #9fb4ce;
  font-size: 11px;
  font-weight: 950;
}

.api-card strong {
  display: block;
  margin-top: 7px;
  font-size: 15px;
}

.api-card small {
  overflow: hidden;
  margin-top: 7px;
  color: #c5d4e5;
  font-size: 11px;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.main {
  min-width: 0;
  padding: 28px;
}

.topbar {
  display: flex;
  gap: 22px;
  align-items: flex-start;
  justify-content: space-between;
  padding: 20px;
  margin-bottom: 18px;
  border: 1px solid rgba(198, 210, 223, 0.75);
  border-radius: 8px;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.98), rgba(248, 250, 252, 0.94)),
    var(--panel);
  box-shadow: var(--shadow-md);
}

.eyebrow {
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  padding: 0 10px;
  margin: 0 0 9px;
  border-radius: 999px;
  background: var(--primary-soft);
  color: var(--primary-dark);
  font-size: 11px;
  font-weight: 950;
}

h1 {
  margin: 0;
  color: #111827;
  font-size: 31px;
  line-height: 1.18;
}

.page-sub {
  margin: 9px 0 0;
  color: var(--sub);
  font-size: 14px;
  font-weight: 750;
}

.top-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 10px;
}

.search-box {
  display: flex;
  align-items: center;
  gap: 9px;
  min-width: 300px;
  height: 44px;
  padding: 0 13px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  color: var(--muted);
  box-shadow: var(--shadow-sm);
  font-size: 13px;
  font-weight: 850;
}

.search-box input {
  min-width: 0;
  flex: 1;
  border: 0;
  outline: 0;
  background: transparent;
  color: var(--ink);
}

.period-toggle {
  display: flex;
  gap: 4px;
  height: 44px;
  padding: 4px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  box-shadow: var(--shadow-sm);
}

.period {
  min-width: 62px;
  border-radius: 6px;
  background: transparent;
  color: var(--sub);
  font-size: 13px;
  font-weight: 950;
}

.period.active {
  background: var(--primary);
  color: #fff;
  box-shadow: 0 8px 18px rgba(37, 99, 235, 0.24);
}

.refresh-btn {
  height: 44px;
  padding: 0 16px;
  border-radius: 8px;
  background: #111827;
  color: #fff;
  box-shadow: 0 10px 20px rgba(15, 23, 42, 0.2);
  font-size: 13px;
  font-weight: 950;
}

.refresh-btn:hover {
  background: #020617;
}

.status-strip,
.kpi-grid,
.content-grid,
.table-grid,
.chart-grid {
  display: grid;
  gap: 14px;
}

.status-strip {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  margin-bottom: 14px;
}

.status-card,
.panel,
.kpi-card {
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.96);
  box-shadow: var(--shadow-md);
}

.status-card {
  position: relative;
  display: flex;
  align-items: center;
  gap: 13px;
  overflow: hidden;
  padding: 15px;
}

.status-card::after {
  position: absolute;
  inset: 0 0 auto;
  height: 3px;
  background: linear-gradient(90deg, #60a5fa, #38bdf8);
  content: "";
}

.status-icon {
  display: grid;
  place-items: center;
  width: 42px;
  height: 42px;
  border-radius: 8px;
  background: var(--primary-soft);
  color: var(--primary);
  font-weight: 950;
}

.status-icon.ok {
  background: var(--green-soft);
  color: var(--green);
}

.status-icon.progress {
  background: var(--sky-soft);
  color: var(--sky);
}

.status-icon.wait {
  background: var(--amber-soft);
  color: var(--amber);
}

.status-icon.danger {
  background: var(--red-soft);
  color: var(--red);
}

.status-card strong,
.status-card span {
  display: block;
}

.status-card strong {
  font-size: 23px;
  line-height: 1;
}

.status-card span {
  margin-top: 5px;
  color: var(--sub);
  font-size: 12px;
  font-weight: 850;
}

.content {
  display: grid;
  gap: 14px;
}

.kpi-grid {
  grid-template-columns: repeat(5, minmax(0, 1fr));
}

.micro-chart-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 12px;
}

.micro-chart-card {
  min-width: 0;
  padding: 13px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.96);
  box-shadow: var(--shadow-sm);
}

.micro-chart-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  margin-bottom: 10px;
}

.micro-chart-head span {
  color: var(--sub);
  font-size: 12px;
  font-weight: 950;
}

.micro-chart-head strong {
  color: #0f172a;
  font-size: 20px;
}

.micro-bars {
  display: grid;
  gap: 7px;
}

.micro-row {
  display: grid;
  grid-template-columns: 62px 1fr 28px;
  align-items: center;
  gap: 7px;
  font-size: 10px;
  font-weight: 850;
}

.micro-row span {
  overflow: hidden;
  color: #475569;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.micro-row strong {
  color: #0f172a;
  text-align: right;
}

.micro-track {
  overflow: hidden;
  height: 7px;
  border-radius: 999px;
  background: #e9eef5;
}

.micro-track div {
  height: 100%;
  border-radius: inherit;
}

.micro-empty {
  padding: 14px 0;
  color: var(--muted);
  font-size: 12px;
  font-weight: 850;
  text-align: center;
}

.ops-focus-grid {
  display: grid;
  grid-template-columns: minmax(0, 0.95fr) minmax(0, 1.05fr);
  gap: 14px;
}

.chart-mosaic {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  grid-auto-rows: minmax(210px, auto);
  gap: 14px;
}

.mosaic-card {
  min-width: 0;
  overflow: hidden;
  padding: 16px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.96);
  box-shadow: var(--shadow-md);
}

.mosaic-card.large {
  grid-column: span 2;
  grid-row: span 2;
}

.mosaic-card.wide {
  grid-column: span 3;
}

.mosaic-card.donut,
.mosaic-card.stacked,
.mosaic-card.heatmap {
  grid-column: span 2;
}

.mosaic-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  margin-bottom: 14px;
}

.mosaic-head strong,
.mosaic-head span {
  display: block;
}

.mosaic-head strong {
  color: #0f172a;
  font-size: 17px;
}

.mosaic-head span {
  margin-top: 5px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
}

.gauge-wrap {
  position: relative;
  display: grid;
  min-height: 270px;
  place-items: center;
}

.gauge-svg {
  width: min(230px, 100%);
  transform: rotate(-90deg);
}

.gauge-bg,
.gauge-fg {
  fill: none;
  stroke-width: 12;
}

.gauge-bg {
  stroke: #e8eef5;
}

.gauge-fg {
  stroke: var(--green);
  stroke-linecap: round;
}

.gauge-center {
  position: absolute;
  display: grid;
  place-items: center;
}

.gauge-center strong {
  color: #0f172a;
  font-size: 42px;
  line-height: 1;
}

.gauge-center span {
  margin-top: 6px;
  color: var(--sub);
  font-weight: 900;
}

.donut-layout {
  display: grid;
  grid-template-columns: 138px 1fr;
  gap: 12px;
  align-items: center;
}

.donut-svg {
  width: 138px;
  transform: rotate(-90deg);
}

.donut-base,
.donut-seg {
  fill: none;
  stroke-width: 18;
}

.donut-base {
  stroke: #e8eef5;
}

.donut-seg {
  stroke-linecap: butt;
}

.donut-legend {
  display: grid;
  gap: 8px;
}

.donut-legend span {
  display: flex;
  align-items: center;
  gap: 7px;
  color: #334155;
  font-size: 12px;
  font-weight: 850;
}

.donut-legend i {
  width: 9px;
  height: 9px;
  border-radius: 50%;
}

.funnel-chart {
  display: grid;
  gap: 10px;
}

.funnel-row {
  display: grid;
  grid-template-columns: 120px 1fr;
  gap: 10px;
  align-items: center;
}

.funnel-row span {
  color: var(--sub);
  font-size: 12px;
  font-weight: 900;
}

.funnel-row div {
  min-height: 28px;
  padding: 6px 10px;
  border-radius: 8px;
  color: #fff;
  font-size: 12px;
  font-weight: 950;
  text-align: right;
}

.spark-wrap {
  display: grid;
  gap: 8px;
}

.spark-svg {
  width: 100%;
  min-height: 180px;
}

.spark-line {
  fill: none;
  stroke: var(--primary);
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-width: 4;
}

.spark-dot {
  fill: #fff;
  stroke: var(--primary);
  stroke-width: 3;
}

.spark-labels {
  display: flex;
  justify-content: space-between;
  color: var(--muted);
  font-size: 11px;
  font-weight: 850;
}

.stacked-chart {
  display: flex;
  align-items: end;
  gap: 9px;
  min-height: 170px;
}

.stacked-col {
  display: flex;
  flex: 1;
  min-width: 0;
  flex-direction: column;
  align-items: center;
  gap: 8px;
}

.stacked-bar {
  display: flex;
  overflow: hidden;
  width: 100%;
  max-width: 36px;
  flex-direction: column-reverse;
  border-radius: 7px 7px 0 0;
  background: #e8eef5;
}

.stacked-bar i {
  display: block;
  width: 100%;
}

.stacked-col span {
  max-width: 46px;
  color: var(--muted);
  font-size: 10px;
  font-weight: 850;
  text-align: center;
}

.heatmap-chart {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
}

.heat-cell {
  min-height: 54px;
  padding: 8px;
  border: 1px solid rgba(37, 99, 235, 0.12);
  border-radius: 8px;
  color: #0f172a;
}

.heat-cell strong,
.heat-cell span {
  display: block;
}

.heat-cell strong {
  font-size: 18px;
}

.heat-cell span {
  margin-top: 4px;
  font-size: 11px;
  font-weight: 900;
}

.kpi-card {
  position: relative;
  overflow: hidden;
  padding: 18px;
}

.kpi-card::before {
  position: absolute;
  top: 16px;
  right: 16px;
  width: 34px;
  height: 34px;
  border-radius: 8px;
  background: var(--primary-soft);
  content: "";
}

.kpi-card span {
  color: var(--sub);
  font-size: 12px;
  font-weight: 950;
}

.kpi-card strong {
  display: block;
  margin-top: 10px;
  color: #0f172a;
  font-size: 34px;
  line-height: 1;
}

.kpi-card small {
  display: block;
  margin-top: 10px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

.panel {
  min-width: 0;
  overflow: hidden;
  padding: 0;
}

.panel-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  padding: 16px 18px;
  border-bottom: 1px solid var(--line);
  background: linear-gradient(180deg, #ffffff, #f8fafc);
}

.panel h2 {
  margin: 0;
  color: #111827;
  font-size: 18px;
}

.panel p {
  margin: 5px 0 0;
  color: var(--sub);
  font-size: 13px;
  font-weight: 750;
}

.panel > :not(.panel-head) {
  margin: 16px 18px 18px;
}

.content-grid {
  grid-template-columns: minmax(0, 1.15fr) minmax(340px, 0.85fr);
}

.ops-list,
.timeline-list {
  display: grid;
  gap: 10px;
}

.ops-item {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  padding: 12px;
  border: 1px solid var(--line);
  border-left: 4px solid var(--muted);
  border-radius: 8px;
  background: #fff;
}

.ops-item.danger {
  border-left-color: var(--red);
}

.ops-item.wait {
  border-left-color: var(--amber);
}

.ops-item.progress {
  border-left-color: var(--sky);
}

.ops-item.ok {
  border-left-color: var(--green);
}

.ops-item strong,
.ops-item span {
  display: block;
}

.ops-item strong {
  color: #0f172a;
  font-size: 15px;
}

.ops-item span {
  margin-top: 4px;
  color: var(--sub);
  font-size: 12px;
  font-weight: 800;
}

.ops-item p,
.timeline-item p {
  margin: 7px 0 0;
  color: #334155;
  font-size: 13px;
  font-weight: 750;
  line-height: 1.45;
}

.timeline-item {
  position: relative;
  display: grid;
  grid-template-columns: 18px 1fr;
  gap: 9px;
  padding: 11px 12px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
}

.timeline-dot {
  width: 10px;
  height: 10px;
  margin-top: 5px;
  border-radius: 50%;
  background: var(--sky);
  box-shadow: 0 0 0 4px var(--sky-soft);
}

.timeline-item strong,
.timeline-item span {
  display: block;
}

.timeline-item strong {
  color: #0f172a;
  font-size: 14px;
}

.timeline-item span {
  margin-top: 4px;
  color: var(--sub);
  font-size: 12px;
  font-weight: 850;
}

.chart-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.bar-list {
  display: grid;
  gap: 13px;
}

.bar-row {
  display: grid;
  grid-template-columns: 118px 1fr 58px;
  align-items: center;
  gap: 12px;
  font-size: 13px;
  font-weight: 850;
}

.bar-row > span {
  color: #334155;
}

.bar-row strong {
  color: #0f172a;
  text-align: right;
}

.bar-track {
  overflow: hidden;
  height: 12px;
  border-radius: 999px;
  background: #e9eef5;
  box-shadow: inset 0 1px 2px rgba(15, 23, 42, 0.08);
}

.bar-fill {
  height: 100%;
  border-radius: inherit;
  background: var(--primary);
}

.mini-chart {
  display: flex;
  align-items: end;
  gap: 8px;
  min-height: 190px;
  padding: 10px 0 0;
}

.mini-col {
  display: flex;
  flex: 1;
  min-width: 0;
  flex-direction: column;
  align-items: center;
  gap: 8px;
}

.mini-bar {
  width: 100%;
  min-height: 6px;
  border-radius: 7px 7px 0 0;
  background: linear-gradient(180deg, #38bdf8, #2563eb);
  box-shadow: 0 8px 16px rgba(37, 99, 235, 0.16);
}

.mini-col span {
  max-width: 54px;
  color: var(--muted);
  font-size: 10px;
  font-weight: 850;
  text-align: center;
}

.table-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.visit-workspace {
  display: grid;
  grid-template-columns: minmax(360px, 0.88fr) minmax(420px, 1.12fr);
  gap: 14px;
  align-items: start;
}

.visit-card-list {
  display: grid;
  gap: 12px;
}

.visit-admin-card {
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  box-shadow: var(--shadow-sm);
}

.visit-card-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  padding: 15px;
  border-bottom: 1px solid #e8eef5;
}

.visit-card-top strong,
.visit-card-top span {
  display: block;
}

.visit-card-top strong {
  color: #0f172a;
  font-size: 17px;
}

.visit-card-top span {
  margin-top: 5px;
  color: var(--sub);
  font-size: 12px;
  font-weight: 800;
}

.visit-meta-grid,
.detail-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  padding: 14px 15px;
}

.meta-item {
  min-width: 0;
  padding: 10px;
  border: 1px solid #e8eef5;
  border-radius: 8px;
  background: #f8fafc;
}

.meta-item span,
.meta-item strong {
  display: block;
}

.meta-item span {
  color: var(--muted);
  font-size: 11px;
  font-weight: 950;
}

.meta-item strong {
  overflow: hidden;
  margin-top: 5px;
  color: #1f2937;
  font-size: 13px;
  font-weight: 850;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.visit-note-box {
  margin: 0 15px 10px;
  padding: 11px 12px;
  border: 1px solid #e8eef5;
  border-radius: 8px;
  background: #fbfdff;
}

.visit-note-box span {
  display: block;
  color: var(--muted);
  font-size: 11px;
  font-weight: 950;
}

.visit-note-box p {
  margin: 6px 0 0;
  color: #334155;
  font-size: 13px;
  font-weight: 750;
  line-height: 1.45;
}

.visit-card-actions {
  padding: 0 15px 15px;
}

.action-btn {
  width: 100%;
  min-height: 40px;
  border-radius: 8px;
  background: var(--primary);
  color: #fff;
  box-shadow: 0 8px 18px rgba(37, 99, 235, 0.2);
  font-size: 13px;
  font-weight: 950;
}

.action-btn:hover {
  background: var(--primary-dark);
}

.senior-detail {
  display: grid;
  gap: 13px;
}

.senior-detail-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  padding: 14px;
  border: 1px solid #dbeafe;
  border-radius: 8px;
  background: linear-gradient(135deg, #eff6ff, #f8fbff);
}

.senior-detail-head strong,
.senior-detail-head span {
  display: block;
}

.senior-detail-head strong {
  color: #0f172a;
  font-size: 20px;
}

.senior-detail-head span {
  margin-top: 5px;
  color: var(--sub);
  font-size: 13px;
  font-weight: 800;
}

.senior-detail .detail-grid {
  padding: 0;
}

.senior-detail h3 {
  margin: 4px 0 -5px;
  color: #111827;
  font-size: 15px;
}

.alert-card-list,
.operation-card-list {
  display: grid;
  gap: 12px;
}

.alert-admin-card,
.operation-card {
  border: 1px solid var(--line);
  border-left: 4px solid var(--muted);
  border-radius: 8px;
  background: #fff;
  box-shadow: var(--shadow-sm);
}

.operation-card {
  border-left-color: var(--primary);
}

.alert-admin-card.danger {
  border-left-color: var(--red);
}

.alert-admin-card.wait {
  border-left-color: var(--amber);
}

.alert-admin-card.ok {
  border-left-color: var(--green);
}

.alert-admin-card.progress {
  border-left-color: var(--sky);
}

.alert-card-top,
.operation-card-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  padding: 15px 15px 10px;
}

.alert-card-top strong,
.alert-card-top span,
.operation-card-top strong,
.operation-card-top span {
  display: block;
}

.alert-card-top strong,
.operation-card-top strong {
  color: #0f172a;
  font-size: 17px;
}

.alert-card-top span,
.operation-card-top span {
  margin-top: 5px;
  color: var(--sub);
  font-size: 12px;
  font-weight: 800;
}

.alert-badges {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 6px;
}

.alert-message {
  margin: 0 15px 10px;
  padding: 12px;
  border-radius: 8px;
  background: #f8fafc;
  color: #334155;
  font-size: 14px;
  font-weight: 800;
  line-height: 1.55;
}

.alert-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  padding: 0 15px 15px;
}

.mini-action {
  min-height: 34px;
  padding: 0 11px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  color: #334155;
  font-size: 12px;
  font-weight: 950;
}

.mini-action:hover {
  border-color: #93c5fd;
  background: #eff6ff;
  color: var(--primary-dark);
}

.saving-text {
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
}

.data-table {
  overflow: auto;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
}

table {
  width: 100%;
  border-collapse: collapse;
}

th,
td {
  padding: 13px 14px;
  border-bottom: 1px solid #e8eef5;
  font-size: 13px;
  text-align: left;
  vertical-align: top;
}

th {
  position: sticky;
  top: 0;
  z-index: 1;
  background: #f1f5f9;
  color: #475569;
  font-weight: 950;
  white-space: nowrap;
}

td {
  color: var(--ink);
  font-weight: 750;
}

tbody tr:hover {
  background: #f8fbff;
}

tr:last-child td {
  border-bottom: 0;
}

.badge {
  position: relative;
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 0 10px;
  border-radius: 999px;
  background: var(--panel-soft);
  color: var(--sub);
  font-size: 12px;
  font-weight: 950;
  white-space: nowrap;
}

.badge.ok {
  background: var(--green-soft);
  color: var(--green);
}

.badge.progress {
  padding-left: 25px;
  background: var(--sky-soft);
  color: var(--sky);
}

.badge.progress::before {
  position: absolute;
  left: 10px;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--sky);
  box-shadow: 0 0 0 0 rgba(2, 132, 199, 0.42);
  animation: pulseStatus 1.4s infinite;
  content: "";
}

.badge.wait {
  background: var(--amber-soft);
  color: var(--amber);
}

.badge.danger {
  background: var(--red-soft);
  color: var(--red);
}

.badge.done {
  background: var(--purple-soft);
  color: var(--purple);
}

.empty {
  padding: 26px;
  border: 1px dashed var(--line-strong);
  border-radius: 8px;
  color: var(--muted);
  background: var(--panel-soft);
  font-weight: 850;
  text-align: center;
}

.system-list {
  display: grid;
  gap: 10px;
}

.system-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 13px 14px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--panel-soft);
  font-weight: 850;
}

.system-row strong {
  color: #0f172a;
  text-align: right;
}

@keyframes pulseStatus {
  0% {
    box-shadow: 0 0 0 0 rgba(2, 132, 199, 0.38);
  }
  70% {
    box-shadow: 0 0 0 7px rgba(2, 132, 199, 0);
  }
  100% {
    box-shadow: 0 0 0 0 rgba(2, 132, 199, 0);
  }
}

/* Compact operations dashboard pass */
.status-strip {
  gap: 9px;
  margin-bottom: 10px;
}

.status-card {
  gap: 10px;
  padding: 10px 12px;
}

.status-icon {
  width: 34px;
  height: 34px;
}

.status-card strong {
  font-size: 19px;
}

.status-card span {
  margin-top: 3px;
  font-size: 11px;
}

.content {
  gap: 10px;
}

.kpi-grid {
  gap: 9px;
}

.kpi-card {
  padding: 12px 13px;
}

.kpi-card::before {
  top: 12px;
  right: 12px;
  width: 24px;
  height: 24px;
}

.kpi-card strong {
  margin-top: 7px;
  font-size: 25px;
}

.kpi-card small {
  margin-top: 6px;
  font-size: 11px;
}

.micro-chart-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 9px;
}

.micro-chart-card {
  min-height: 106px;
  padding: 9px 10px;
}

.micro-chart-head {
  margin-bottom: 6px;
}

.micro-chart-head span {
  font-size: 11px;
}

.micro-chart-head strong {
  font-size: 17px;
}

.micro-bars {
  gap: 5px;
}

.micro-row {
  grid-template-columns: 58px 1fr 24px;
  gap: 6px;
  font-size: 9px;
}

.chart-mosaic {
  grid-auto-rows: minmax(150px, auto);
  gap: 9px;
}

.mosaic-card {
  padding: 10px 11px;
}

.mosaic-head {
  margin-bottom: 8px;
}

.mosaic-head strong {
  font-size: 14px;
}

.mosaic-head span {
  margin-top: 3px;
  font-size: 11px;
}

.gauge-wrap {
  min-height: 198px;
}

.gauge-svg {
  width: min(164px, 100%);
}

.gauge-center strong {
  font-size: 30px;
}

.donut-layout {
  grid-template-columns: 102px 1fr;
  gap: 8px;
}

.donut-svg {
  width: 102px;
}

.donut-legend {
  gap: 5px;
}

.donut-legend span {
  font-size: 10px;
}

.funnel-chart {
  gap: 7px;
}

.funnel-row {
  grid-template-columns: 92px 1fr;
  gap: 8px;
}

.funnel-row div {
  min-height: 23px;
  padding: 4px 8px;
  font-size: 11px;
}

.spark-svg {
  min-height: 118px;
}

.stacked-chart {
  min-height: 122px;
}

.heatmap-chart {
  gap: 6px;
}

.heat-cell {
  min-height: 42px;
  padding: 6px;
}

.heat-cell strong {
  font-size: 14px;
}

@media (max-width: 1180px) {
  .admin-shell {
    grid-template-columns: 1fr;
  }

  .sidebar {
    position: static;
    height: auto;
  }

  .api-card {
    position: static;
    margin-top: 16px;
  }

  .status-strip,
  .kpi-grid,
  .micro-chart-grid,
  .chart-mosaic,
  .ops-focus-grid,
  .content-grid,
  .table-grid,
  .chart-grid,
  .visit-workspace,
  .visit-meta-grid,
  .detail-grid {
    grid-template-columns: 1fr;
  }

  .mosaic-card.large,
  .mosaic-card.wide,
  .mosaic-card.donut,
  .mosaic-card.stacked,
  .mosaic-card.heatmap {
    grid-column: auto;
    grid-row: auto;
  }

  .topbar {
    flex-direction: column;
  }

  .top-actions {
    width: 100%;
    justify-content: flex-start;
  }

  .search-box {
    min-width: min(100%, 320px);
  }
}


/* ===== CareBridge365 Product Dashboard V3 ===== */
body{background:#f3f8fe!important}
.admin-shell{grid-template-columns:220px minmax(0,1fr)!important}
.sidebar{width:220px!important;padding:24px 14px!important;background:linear-gradient(180deg,#061e3c,#04162d)!important}
.brand-logo-full{display:flex!important;align-items:center!important;justify-content:center!important;min-height:84px!important;margin-bottom:12px!important}
.brand-logo-full img{width:170px;max-height:74px;object-fit:contain;filter:drop-shadow(0 5px 14px rgba(0,0,0,.42))}
.side-item{min-height:43px!important;border-radius:12px!important}
.side-item.active{background:linear-gradient(90deg,#2f6df6,#1d83ff)!important;box-shadow:0 8px 20px rgba(47,109,246,.28)!important}
.main{padding:24px 28px!important}
.topbar{min-height:auto!important;padding:0!important;margin-bottom:18px!important;border:0!important;background:transparent!important;box-shadow:none!important}
.eyebrow,#pageSub{display:none!important}
#pageTitle{font-size:26px!important;font-weight:950!important;margin:0!important;letter-spacing:-.7px!important}
.top-actions{gap:12px!important}
.search-box{width:280px!important;height:40px!important;border-radius:13px!important;background:#fff!important;border:1px solid #dce6f2!important;box-shadow:0 6px 16px rgba(29,58,102,.06)!important}
.search-box span{display:none!important}.search-box input{padding:0 14px!important}
.period-toggle{height:40px!important;border-radius:13px!important;background:#fff!important;border:1px solid #dce6f2!important;box-shadow:0 6px 16px rgba(29,58,102,.06)!important}
.period{min-width:56px!important;border-radius:10px!important}
.period.active{background:#2f6df6!important;color:#fff!important;box-shadow:0 8px 18px rgba(47,109,246,.3)!important}
.refresh-btn{height:40px!important;border-radius:13px!important;background:#0f172a!important;color:#fff!important;box-shadow:0 10px 18px rgba(15,23,42,.18)!important}
.status-strip{display:none!important}.content{display:block!important}

.product-dashboard{--blue:#2f6df6;--cyan:#59cbd3;--pink:#ff6b91;--purple:#7d6bf2;--orange:#ffb454;--text:#102033;--muted:#6b7b91;--shadow:0 10px 28px rgba(29,58,102,.08);color:var(--text)}
.product-hero{min-height:178px;background:linear-gradient(90deg,#dceeff,#eaf6ff 56%,#d9ecff);border-radius:18px;padding:24px 28px;display:grid;grid-template-columns:minmax(360px,1.02fr) 410px 390px;gap:18px;align-items:center;position:relative;overflow:hidden;box-shadow:var(--shadow);margin-bottom:16px}
.product-hero:after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 52% 18%,rgba(255,255,255,.82),transparent 26%),radial-gradient(circle at 90% 88%,rgba(255,255,255,.55),transparent 28%);pointer-events:none}
.product-hero-copy,.product-family-art,.product-alert-card{position:relative;z-index:2}
.product-kicker{margin:0 0 10px;font-size:15px;font-weight:900;color:#1f3b61}
.product-hero h2{margin:0 0 14px;font-size:30px;line-height:1.32;font-weight:950;letter-spacing:-1.1px;color:#102b55}
.product-desc{margin:0;font-size:15px;color:#314967;font-weight:700}
.product-family-art{height:170px;align-self:end}
.product-family-art svg{width:100%;height:100%;display:block}
.product-alert-card{align-self:center;min-height:132px;padding:18px 20px;border-radius:16px;background:rgba(255,255,255,.88);border:1px solid rgba(255,255,255,.82);backdrop-filter:blur(8px);box-shadow:0 10px 24px rgba(46,75,112,.08)}
.product-alert-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.product-alert-head strong{font-size:16px}.product-alert-head span{font-size:12px;color:#44576e;font-weight:900}
.product-alert-row{display:grid;grid-template-columns:14px 1fr 24px;gap:8px;align-items:center;margin:10px 0;font-size:12px;color:#344860;font-weight:800}
.product-alert-row em{font-style:normal}.product-alert-row span{width:8px;height:8px;border-radius:50%;background:#5b8cf7}.product-alert-row span.pink{background:#ff5573}.product-alert-row span.gold{background:#d6c97b}
.product-alert-row b{width:22px;height:22px;border-radius:50%;display:grid;place-items:center;background:#d8e7ff;color:#2f6df6;font-size:11px}

.product-kpi-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin-bottom:14px}
.product-kpi{background:#fff;border-radius:15px;padding:18px 20px;box-shadow:var(--shadow);display:flex;align-items:center;justify-content:space-between;min-height:98px}
.product-kpi span{display:block;font-size:13px;color:#40536b;font-weight:900;margin-bottom:8px}
.product-kpi strong{font-size:26px;font-weight:950;letter-spacing:-.6px}
.product-kpi small{display:block;margin-top:6px;color:#21a88f;font-size:12px;font-weight:900}
.product-kpi i{width:56px;height:56px;border-radius:50%;display:grid;place-items:center;font-style:normal;background:#e9f1ff;color:#2f6df6;font-size:25px}
.product-kpi:nth-child(2) i{background:#dcf8f3;color:#25bfa6}.product-kpi:nth-child(3) i{background:#eeeaff;color:#765ff1}.product-kpi:nth-child(4) i{background:#fff0d8;color:#f6a72d}.product-kpi:nth-child(5) i{background:#ffe7ee;color:#f04f75}

.product-main-grid{display:grid;grid-template-columns:2fr 1.35fr 1.55fr;gap:14px;align-items:start}
.product-bottom-grid{display:grid;grid-template-columns:1.15fr 1fr 1fr 1.1fr;gap:14px;margin-top:14px}
.product-footer-grid{display:grid;grid-template-columns:1fr 1.35fr;gap:14px;margin-top:14px}
.product-card{background:#fff;border-radius:16px;padding:18px 20px;box-shadow:var(--shadow);min-height:190px}
.product-card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.product-card-head h3{margin:0;font-size:16px;font-weight:950;letter-spacing:-.3px}
.product-card-head span{font-size:12px;color:#334b65;font-weight:900}
.product-line-card,.product-donut-card,.product-map-card{min-height:278px}
.product-legend{display:flex;gap:18px;justify-content:center;font-size:12px;font-weight:900;color:#62758c;margin-bottom:5px}
.product-legend i{width:9px;height:9px;border-radius:50%;display:inline-block;margin-right:-12px;margin-top:3px}.product-legend .blue{background:#2f6df6}.product-legend .cyan{background:#59cbd3}.product-legend .pink{background:#ff6b91}
.product-line-svg{width:100%;height:220px}

.product-donut-row{display:flex;align-items:center;justify-content:center;gap:18px;height:210px}
.product-donut{width:168px;height:168px;border-radius:50%;background:conic-gradient(#2f6df6 0 35%,#59cbd3 35% 61%,#8a77ee 61% 78%,#ff6b91 78% 91%,#ffb454 91% 100%);position:relative}
.product-donut:after{content:"";position:absolute;inset:34px;border-radius:50%;background:#fff}
.product-donut div{position:absolute;inset:38px;z-index:1;display:grid;place-items:center;text-align:center;font-weight:900;font-size:15px;line-height:1.35;color:#25364a}
.product-donut div b{font-size:19px}
.product-donut-list{font-size:12px;color:#44576e;font-weight:850;min-width:135px}
.product-donut-list p{display:flex;justify-content:space-between;gap:14px;margin:9px 0}
.product-donut-list i{width:8px;height:8px;border-radius:50%;display:inline-block;margin-right:6px}

.product-map-row{display:grid;grid-template-columns:1fr 150px;gap:12px;align-items:center}
.product-map-svg{height:204px}
.product-map-svg svg{width:100%;height:100%;display:block}
.product-region-list{font-size:12px;color:#455a72;font-weight:900}
.product-region-list p{display:flex;justify-content:space-between;margin:8px 0}
.product-region-list i{width:8px;height:8px;border-radius:50%;display:inline-block;background:#2f6df6;margin-right:6px}

.product-bars{height:160px;display:flex;align-items:flex-end;gap:23px;padding:16px 20px 0;border-left:1px solid #eef2f7;border-bottom:1px solid #eef2f7}
.product-bars i{width:34px;border-radius:7px 7px 0 0;background:linear-gradient(180deg,#7d93ff,#5478f8)}
.product-rank{display:grid;grid-template-columns:20px 1fr 120px 52px;gap:10px;align-items:center;margin:13px 0;font-size:12px;font-weight:900;color:#40536b}
.product-rank i{height:18px;border-radius:5px;background:linear-gradient(90deg,#2f6df6,#5a96ff)}
.product-rank em{font-style:normal}
.product-funnel{height:170px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px}
.product-funnel div{height:34px;border-radius:8px;color:#fff;font-weight:950;font-size:12px;display:grid;place-items:center;clip-path:polygon(0 0,100% 0,88% 100%,12% 100%)}
.product-funnel div:nth-child(1){width:185px;background:#2f6df6}.product-funnel div:nth-child(2){width:160px;background:#5d91f8}.product-funnel div:nth-child(3){width:132px;background:#59cbd3}.product-funnel div:nth-child(4){width:105px;background:#ffb454}
.product-heat{display:grid;grid-template-columns:repeat(7,1fr);grid-template-rows:repeat(5,24px);gap:4px;margin-top:16px}
.product-heat i{border-radius:3px;background:#dbe9ff}.product-heat .lv1{background:#b7d0f5}.product-heat .lv2{background:#74a6fb}.product-heat .lv3{background:#2f6df6}
.product-notice p{display:flex;justify-content:space-between;gap:18px;padding:8px 0;margin:0;font-size:13px;font-weight:850;color:#33475e}
.product-quick>div{display:grid;grid-template-columns:repeat(5,1fr);gap:16px}
.product-quick button{background:transparent;border:0;color:#25364a;font-weight:950;text-align:center;font-size:13px;cursor:pointer}
.product-quick button span{display:block;margin-top:8px}

@media(max-width:1480px){
  .product-hero{grid-template-columns:1fr 330px 360px}
  .product-hero h2{font-size:27px}
}
@media(max-width:1280px){
  .product-kpi-grid{grid-template-columns:repeat(3,1fr)}
  .product-main-grid,.product-bottom-grid,.product-footer-grid{grid-template-columns:1fr}
  .product-hero{grid-template-columns:1fr}
  .product-family-art{display:none}
  .product-alert-card{max-width:none}
}

/* Notice/Event admin board */
.side-item:nth-child(9)::before { content: "SY"; }
.side-item:nth-child(8)::before { content: "NT"; }

.board-manager {
  display: grid;
  gap: 18px;
}

.board-tabs {
  display: flex;
  gap: 10px;
  padding: 8px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.72);
  box-shadow: var(--shadow-sm);
}

.board-tabs button {
  min-width: 120px;
  padding: 12px 16px;
  border-radius: 12px;
  background: transparent;
  color: var(--sub);
  font-weight: 950;
}

.board-tabs button.active {
  background: var(--primary);
  color: #fff;
  box-shadow: 0 10px 22px rgba(37, 99, 235, 0.22);
}

.board-workspace {
  display: grid;
  grid-template-columns: minmax(340px, 0.9fr) minmax(0, 1.35fr);
  gap: 18px;
  align-items: start;
}

.board-form {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  padding: 18px;
}

.board-form label {
  display: grid;
  gap: 7px;
  color: var(--sub);
  font-size: 13px;
  font-weight: 900;
}

.board-form label.wide {
  grid-column: 1 / -1;
}

.board-form input,
.board-form select,
.board-form textarea {
  width: 100%;
  border: 1px solid var(--line-strong);
  border-radius: 12px;
  background: #fff;
  color: var(--ink);
  outline: none;
  padding: 12px 13px;
  font-weight: 750;
}

.board-form textarea {
  min-height: 220px;
  line-height: 1.6;
  resize: vertical;
}

.board-form input:focus,
.board-form select:focus,
.board-form textarea:focus {
  border-color: var(--primary);
  box-shadow: 0 0 0 4px rgba(37, 99, 235, 0.12);
}

.board-actions {
  grid-column: 1 / -1;
  display: flex;
  gap: 10px;
  justify-content: flex-end;
}

.primary-action,
.ghost-action {
  min-height: 44px;
  padding: 0 16px;
  border-radius: 12px;
  font-weight: 950;
}

.primary-action {
  background: var(--primary);
  color: #fff;
}

.ghost-action {
  border: 1px solid var(--line-strong);
  background: #fff;
  color: var(--sub);
}

.primary-action:disabled,
.board-row-actions button:disabled {
  cursor: default;
  opacity: 0.62;
}

.board-list {
  display: grid;
  gap: 12px;
  padding: 18px;
}

.board-row-card {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 14px;
  align-items: center;
  padding: 16px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: linear-gradient(180deg, #fff, #f8fbff);
  box-shadow: var(--shadow-sm);
}

.board-row-top {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  align-items: center;
  margin-bottom: 8px;
}

.board-row-card strong {
  display: block;
  color: var(--ink);
  font-size: 17px;
  line-height: 1.35;
}

.board-row-card p {
  display: -webkit-box;
  overflow: hidden;
  margin: 7px 0 0;
  color: var(--sub);
  font-size: 13px;
  line-height: 1.55;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}

.board-row-actions {
  display: flex;
  gap: 8px;
}

.board-row-actions button {
  min-width: 64px;
  height: 38px;
  border-radius: 10px;
  background: var(--primary-soft);
  color: var(--primary-dark);
  font-weight: 950;
}

.board-row-actions button.danger {
  background: var(--red-soft);
  color: var(--red);
}

@media (max-width: 1100px) {
  .board-workspace {
    grid-template-columns: 1fr;
  }
}


/* Notice/Event write form improvements */
.board-form .board-check-line {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 12px;
  min-height: 44px;
  white-space: nowrap;
}

.board-form .board-check-line input[type="checkbox"] {
  width: 22px;
  height: 22px;
  flex: 0 0 22px;
  accent-color: var(--primary);
  cursor: pointer;
}

.board-form .board-check-line span {
  color: var(--sub);
  font-size: 14px;
  font-weight: 900;
  line-height: 1.25;
}

.board-form [hidden] {
  display: none !important;
}

/* 2026-05-05 안심신호 관리자 화면 */
.care-signal-kpis {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
  margin-bottom: 18px;
}

.care-signal-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.45fr) minmax(360px, .75fr);
  gap: 18px;
  align-items: start;
}

.care-signal-card-list {
  display: grid;
  gap: 14px;
}

.care-signal-card {
  padding: 18px;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: linear-gradient(180deg, #ffffff, #f8fbff);
  box-shadow: var(--shadow-sm);
}

.care-signal-card.selected {
  border-color: rgba(37, 99, 235, .48);
  box-shadow: 0 14px 32px rgba(37, 99, 235, .14);
}

.care-signal-card-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.care-signal-card-top strong {
  display: block;
  color: var(--ink);
  font-size: 18px;
  font-weight: 950;
}

.care-signal-card-top span:not(.badge) {
  display: block;
  margin-top: 5px;
  color: var(--sub);
  font-size: 13px;
  font-weight: 750;
}

.care-signal-message {
  margin: 14px 0 12px;
  color: var(--ink);
  font-size: 15px;
  font-weight: 850;
}

.care-signal-times {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 14px;
}

.care-signal-times span {
  padding: 7px 10px;
  border-radius: 999px;
  background: var(--primary-soft);
  color: var(--primary-dark);
  font-size: 12px;
  font-weight: 900;
}

.care-signal-form {
  display: grid;
  gap: 14px;
}

.care-signal-form label {
  display: grid;
  gap: 7px;
  color: var(--sub);
  font-size: 13px;
  font-weight: 900;
}

.care-signal-form input[type="time"] {
  width: 100%;
  min-height: 46px;
  padding: 0 14px;
  border: 1px solid var(--line-strong);
  border-radius: 12px;
  background: #fff;
  color: var(--ink);
  font-size: 16px;
  font-weight: 900;
}

.care-signal-selected {
  padding: 15px;
  border: 1px solid rgba(37, 99, 235, .18);
  border-radius: 16px;
  background: var(--primary-soft);
}

.care-signal-selected span {
  display: block;
  color: var(--primary-dark);
  font-size: 12px;
  font-weight: 900;
}

.care-signal-selected strong {
  display: block;
  margin-top: 5px;
  color: var(--ink);
  font-size: 20px;
  font-weight: 950;
}

.care-signal-note {
  padding: 13px 14px;
  border-radius: 14px;
  background: var(--amber-soft);
  color: #92400e;
  font-size: 13px;
  font-weight: 800;
  line-height: 1.55;
}

@media (max-width: 1180px) {
  .care-signal-layout,
  .care-signal-kpis {
    grid-template-columns: 1fr;
  }
}


/* Restored admin + CareTalk/Notification monitor */
.admin-monitor-card { min-height: 520px; }
.monitor-split { display: grid; grid-template-columns: minmax(260px, 360px) 1fr; gap: 18px; align-items: stretch; }
.monitor-list { display: flex; flex-direction: column; gap: 10px; max-height: 620px; overflow: auto; padding-right: 4px; }
.monitor-row { text-align: left; border: 1px solid rgba(148,163,184,.24); background: #fff; border-radius: 18px; padding: 14px; cursor: pointer; box-shadow: 0 10px 24px rgba(15,23,42,.06); }
.monitor-row.active { border-color: rgba(37,99,235,.55); background: #eef6ff; }
.monitor-row strong, .monitor-row span, .monitor-row small { display: block; }
.monitor-row strong { color: #0f172a; font-size: 15px; }
.monitor-row span { color: #64748b; margin-top: 5px; font-size: 13px; }
.monitor-row small { color: #94a3b8; margin-top: 8px; line-height: 1.4; }
.monitor-detail { border: 1px solid rgba(148,163,184,.24); border-radius: 22px; padding: 18px; background: linear-gradient(180deg,#ffffff,#f8fbff); min-height: 520px; }
.chat-title { display: flex; justify-content: space-between; align-items: center; gap: 12px; padding-bottom: 14px; border-bottom: 1px solid rgba(148,163,184,.2); }
.chat-title strong { font-size: 18px; color: #0f172a; }
.chat-title span { color: #64748b; font-size: 13px; }
.chat-log { display: flex; flex-direction: column; gap: 12px; padding-top: 16px; max-height: 540px; overflow: auto; }
.chat-message { max-width: 78%; border-radius: 18px; padding: 12px 14px; background: #f1f5f9; color: #0f172a; }
.chat-message.guardian { margin-left: auto; background: #dbeafe; }
.chat-message.partner { margin-right: auto; background: #ecfdf5; }
.chat-message b { display:block; font-size:12px; color:#475569; margin-bottom:5px; }
.chat-message p { margin:0; white-space:pre-wrap; line-height:1.5; }
.chat-message small { display:block; margin-top:6px; color:#64748b; font-size:11px; }
.notification-list { display:flex; flex-direction:column; gap:12px; }
.notification-row { display:flex; justify-content:space-between; gap:16px; border:1px solid rgba(148,163,184,.22); border-radius:20px; padding:16px; background:#fff; box-shadow:0 12px 28px rgba(15,23,42,.06); }
.notification-row.unread { border-color:rgba(37,99,235,.35); background:#f8fbff; }
.notification-row strong { color:#0f172a; font-size:16px; }
.notification-row p { margin:7px 0; color:#334155; line-height:1.5; }
.notification-row small { color:#64748b; }
.notification-actions { display:flex; align-items:center; gap:8px; flex-shrink:0; }
@media (max-width: 980px) { .monitor-split { grid-template-columns: 1fr; } .chat-message { max-width: 92%; } .notification-row { flex-direction:column; } }
