:root {
  color-scheme: light;
  --bg: #f3f8fc;
  --surface: #ffffff;
  --ink: #122033;
  --muted: #5b718a;
  --line: #cfe0ee;
  --accent: #1769aa;
  --accent-strong: #0a4f86;
  --green: #0f7a55;
  --yellow: #a76b00;
  --orange: #bd4b17;
  --red: #b91c1c;
  --black: #111111;
  --shadow: 0 10px 30px rgba(18, 32, 51, 0.09);
  --text-xs: 0.72rem;
  --text-sm: 0.82rem;
  --text-md: 0.94rem;
  --text-lg: 1.08rem;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

.orientation-title p {
  margin: 0;
  color: var(--muted);
  font-size: 0.95rem;
}

.orientation-panel {
  border-radius: 18px;
  padding: 1.25rem;
  color: #ffffff;
  background: linear-gradient(135deg, #0f766e, #164e63);
  box-shadow: 0 18px 44px rgba(15, 23, 42, 0.18);
}

.orientation-panel.watch {
  background: linear-gradient(135deg, #a16207, #854d0e);
}

.orientation-panel.high {
  background: linear-gradient(135deg, #b45309, #9a3412);
}

.orientation-panel.critical {
  background: linear-gradient(135deg, #b91c1c, #7f1d1d);
}

.orientation-kicker {
  margin-bottom: 0.35rem;
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  opacity: 0.86;
}

.orientation-panel strong {
  display: block;
  font-size: clamp(1.55rem, 4vw, 2.35rem);
  line-height: 1.05;
}

.orientation-panel p {
  margin: 0.65rem 0 0;
  max-width: 46rem;
  color: rgba(255, 255, 255, 0.88);
}

.orientation-grid {
  display: grid;
  gap: 1rem;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  margin-top: 1rem;
}

.orientation-card {
  border: 1px solid var(--line);
  border-radius: 16px;
  padding: 1rem;
  background: var(--surface);
}

.orientation-card h3 {
  margin: 0 0 0.75rem;
  font-size: 1rem;
}

.orientation-stack {
  display: grid;
  gap: 0.65rem;
}

.orientation-limit {
  margin-top: 1rem;
}

.orientation-limit p {
  margin: 0;
  color: var(--muted);
}

@media (max-width: 760px) {
  .orientation-grid {
    grid-template-columns: 1fr;
  }
}

* {
  box-sizing: border-box;
}

html,
body {
  overscroll-behavior-y: none;
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

body {
  margin: 0;
  min-height: 100vh;
  background: var(--bg);
  color: var(--ink);
}

body.revenox-hide-echo-ai .epkb-ai-chat-widget {
  display: none !important;
}

body.revenox-hide-cookieyes .cky-consent-container,
body.revenox-hide-cookieyes .cky-btn-revisit-wrapper,
body.revenox-hide-cookieyes .cky-modal {
  display: none !important;
}

button,
input,
select,
textarea {
  font: inherit;
}

button {
  border: 0;
  border-radius: 8px;
  min-height: 44px;
  padding: 0 14px;
  background: var(--accent);
  color: #fff;
  font-weight: 750;
}

button:disabled {
  opacity: 0.45;
}

.secondary-button {
  background: #e9eeee;
  color: var(--ink);
}

.respira-app {
  max-width: 980px;
  margin: 0 auto;
  padding-bottom: calc(146px + env(safe-area-inset-bottom));
  padding-bottom: calc(146px + constant(safe-area-inset-bottom));
  overscroll-behavior: contain;
  overscroll-behavior-y: contain;
  touch-action: pan-y;
}

.revenox-lite-plugin-root {
  padding-bottom: calc(96px + env(safe-area-inset-bottom));
  padding-bottom: calc(96px + constant(safe-area-inset-bottom));
}

.access-gate,
.disclaimer-gate,
.session-gate {
  position: fixed;
  inset: 0;
  z-index: 100;
  display: grid;
  place-items: center;
  padding: 16px;
  background: rgba(18, 32, 51, 0.74);
}

.access-gate[hidden],
.disclaimer-gate[hidden],
.session-gate[hidden] {
  display: none;
}

.access-gate {
  z-index: 104;
}

.access-panel,
.disclaimer-panel,
.session-panel {
  display: grid;
  gap: 14px;
  width: min(100%, 680px);
  max-height: min(86vh, 760px);
  overflow: auto;
  padding: 18px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--surface);
  box-shadow: var(--shadow);
}

.access-panel {
  width: min(100%, 420px);
}

.access-panel h2,
.disclaimer-panel h2,
.session-panel h2 {
  margin-bottom: 0;
  font-size: 1.35rem;
}

.access-panel p {
  margin: 0;
  color: #24384f;
  line-height: 1.45;
}

.access-form {
  display: grid;
  gap: 10px;
}

.access-form input {
  width: 100%;
  min-height: 44px;
  padding: 0 12px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #ffffff;
  color: var(--ink);
}

.access-status {
  min-height: 20px;
  color: var(--red);
  font-size: var(--text-sm);
  font-weight: 850;
}

.disclaimer-text,
.session-text {
  display: grid;
  gap: 10px;
  color: #24384f;
  line-height: 1.45;
}

.disclaimer-text p,
.session-text p {
  margin: 0;
}

.disclaimer-actions,
.session-actions {
  display: grid;
  grid-template-columns: minmax(96px, 0.4fr) minmax(0, 1fr);
  gap: 10px;
  align-items: center;
}

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

.session-actions button {
  width: 100%;
  min-width: 0;
  min-height: 52px;
  height: 100%;
  padding: 10px 12px;
  line-height: 1.15;
  white-space: normal;
  overflow-wrap: anywhere;
}

.session-gate {
  z-index: 99;
  background: rgba(10, 79, 134, 0.52);
}

#session-summary {
  padding: 10px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: #f3f8fc;
  color: var(--accent-strong);
  font-weight: 700;
}

.disclaimer-closed {
  min-height: 100vh;
  display: grid;
  place-items: center;
  padding: 24px;
  background: var(--bg);
  color: var(--ink);
  text-align: center;
}

.bug-report-box {
  display: grid;
  gap: 10px;
  margin: 12px 0;
  padding: 10px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #f7fbff;
}

.bug-report-box > button {
  width: 100%;
}

.bug-report-form {
  display: grid;
  gap: 9px;
}

.bug-report-form[hidden] {
  display: none;
}

.bug-report-form label {
  color: #24384f;
  font-size: var(--text-sm);
  font-weight: 750;
}

.bug-report-form textarea {
  width: 100%;
  min-width: 0;
  resize: vertical;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 10px;
  color: var(--ink);
  background: #fff;
  font-weight: 500;
}

.bug-context-button {
  width: 100%;
  border: 1px solid #bed8ec;
  background: #edf6fd;
  color: var(--accent-strong);
}

.bug-context-button.active {
  border-color: rgba(15, 122, 85, 0.32);
  background: #e8f7ef;
  color: var(--green);
}

.bug-context-note {
  margin: 0;
  padding: 8px;
  border-radius: 6px;
  background: #fff8e8;
  color: #76520f;
  font-size: var(--text-sm);
}

.bug-consent {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 8px;
  align-items: start;
  font-weight: 650;
}

.bug-report-status {
  margin: 0;
  color: var(--muted);
  font-size: var(--text-sm);
}

.bug-report-status.warn {
  color: var(--yellow);
}

.bug-report-status.ok {
  color: var(--green);
}

.revenox-update-overlay {
  position: fixed;
  inset: 0;
  z-index: 220;
  display: grid;
  place-items: center;
  padding: 18px;
  background: rgba(15, 23, 42, 0.28);
}

.revenox-update-panel {
  display: grid;
  gap: 10px;
  width: min(520px, 100%);
  max-height: min(86vh, 680px);
  overflow: auto;
  padding: 18px;
  border: 1px solid #bad9eb;
  border-left: 6px solid #3c7499;
  border-radius: 10px;
  background: #ffffff;
  color: var(--ink);
  box-shadow: 0 22px 70px rgba(18, 32, 51, 0.26);
}

.revenox-update-overlay.warning .revenox-update-panel,
.revenox-update-overlay.security .revenox-update-panel {
  border-left-color: #d97706;
}

.revenox-update-overlay.urgent .revenox-update-panel {
  border-left-color: var(--red);
}

.revenox-update-panel h2 {
  margin: 0;
  color: var(--accent-strong);
  font-size: var(--text-xl);
}

.revenox-update-panel small {
  color: var(--muted);
  font-weight: 800;
}

.revenox-update-panel p {
  margin: 0;
  color: #334155;
  line-height: 1.4;
}

.revenox-update-panel details {
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 8px;
  background: #f8fbfd;
}

.revenox-update-panel summary,
.updates-help-fold summary {
  cursor: pointer;
  color: var(--accent-strong);
  font-weight: 950;
}

.revenox-update-close {
  justify-self: end;
  min-height: 40px;
  padding: 0 16px;
  border-radius: 8px;
  background: var(--accent-strong);
  color: #ffffff;
}

.updates-help-fold {
  margin: 12px 0;
  padding: 10px;
  border: 1px solid #bad9eb;
  border-radius: 8px;
  background: #f8fbfd;
}

.updates-list {
  display: grid;
  gap: 8px;
  margin-top: 8px;
}

.updates-item {
  display: grid;
  gap: 3px;
  padding: 8px;
  border: 1px solid var(--line);
  border-left: 4px solid #3c7499;
  border-radius: 8px;
  background: #ffffff;
}

.updates-item.warning,
.updates-item.security {
  border-left-color: #d97706;
}

.updates-item.urgent {
  border-left-color: var(--red);
}

.updates-item strong {
  color: var(--ink);
  font-size: var(--text-sm);
}

.updates-item span {
  color: var(--muted);
  font-size: var(--text-xs);
  font-weight: 850;
}

.updates-item p {
  margin: 0;
  color: #334155;
  font-size: var(--text-sm);
  line-height: 1.35;
}

.app-header {
  position: sticky;
  top: 0;
  z-index: 10;
  padding: 12px;
  background: rgba(243, 248, 252, 0.96);
  border-bottom: 1px solid var(--line);
  backdrop-filter: blur(12px);
}

.brand-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.brand-lockup {
  display: grid;
  grid-template-columns: minmax(128px, 2fr) minmax(0, 2fr) minmax(42px, 1fr);
  grid-template-areas: "left logo icon";
  align-items: center;
  column-gap: 12px;
  width: 100%;
}

.brand-left {
  grid-area: left;
  display: grid;
  gap: 0;
  color: var(--muted);
  font-size: clamp(0.64rem, 1.8vw, 0.72rem);
  font-weight: 900;
  line-height: 1.02;
  min-width: 0;
}

.brand-left span {
  white-space: nowrap;
}

.brand-left strong {
  color: var(--accent-strong);
}

.brand-logo-button {
  grid-area: logo;
  display: grid;
  justify-items: center;
  align-items: center;
  min-width: 0;
  min-height: 0;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
}

.brand-center-logo {
  display: block;
  justify-self: center;
  width: min(100%, 340px);
  max-height: 54px;
  object-fit: contain;
  mix-blend-mode: multiply;
  filter: saturate(1.08) contrast(1.05);
}

.revenox-lite-plugin-root .brand-center-logo,
.revenox-lite-plugin-root .brand-respira-icon {
  display: block;
  visibility: visible;
  opacity: 1;
}

.brand-respira-icon {
  grid-area: icon;
  justify-self: end;
  width: clamp(42px, 10vw, 62px);
  aspect-ratio: 1;
  object-fit: cover;
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.34);
  box-shadow: 0 4px 12px rgba(18, 32, 51, 0.1);
  mix-blend-mode: multiply;
}

.brand-right {
  grid-area: right;
  display: grid;
  justify-items: end;
  color: var(--accent-strong);
  line-height: 0.95;
  min-height: 0;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  text-align: right;
}

.brand-right strong {
  font-size: 1.1rem;
  font-weight: 900;
}

.brand-right:active,
.brand-logo-button:active {
  transform: scale(0.98);
}

.eyebrow {
  margin: 0 0 2px;
  color: var(--muted);
  font-size: 0.75rem;
  font-weight: 800;
  text-transform: uppercase;
}

h1,
h2,
h3,
p {
  margin-top: 0;
}

h1 {
  margin-bottom: 0;
  font-size: 1.45rem;
}

h2 {
  font-size: var(--text-lg);
}

.title-hint {
  color: #344252;
  font-size: var(--text-sm);
  font-weight: 750;
}

.title-with-info {
  display: flex;
  align-items: center;
  gap: 8px;
}

.info-button {
  display: inline-grid;
  place-items: center;
  width: 24px;
  min-height: 24px;
  padding: 0;
  border-radius: 999px;
  background: #e8f0f7;
  color: var(--accent-strong);
  font-size: 0.85rem;
  font-weight: 900;
}

.info-popover {
  display: grid;
  gap: 6px;
  margin: 8px 0 10px;
  padding: 10px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #f7fbff;
  color: #344252;
}

.info-popover[hidden] {
  display: none;
}

.info-popover p {
  margin: 0;
}

.info-popover.compact {
  margin: 6px 0 8px;
  padding: 8px;
  font-size: var(--text-xs);
}

.compact-reminder-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 5px 10px;
  margin: 0;
  padding-left: 16px;
}

.compact-reminder-list li {
  min-width: 0;
}

.inline-title {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.inline-info-button {
  min-height: 28px;
  padding: 0 8px;
  border-radius: 999px;
  background: #e8f0f7;
  color: var(--accent-strong);
  font-size: var(--text-xs);
}

.clinical-output,
.screen-content {
  background: var(--surface);
  border: 1px solid var(--line);
  box-shadow: var(--shadow);
}

.field-group {
  display: grid;
  gap: 8px;
  margin-bottom: 14px;
}

.field-group label,
.field-label {
  color: var(--muted);
  font-size: var(--text-sm);
  font-weight: 800;
}

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

.fio2-evolution-heading {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 5px;
  min-width: 0;
  white-space: nowrap;
}

.fio2-evolution-heading label {
  flex: 0 0 auto;
}

.quick-fio2-buttons {
  display: flex;
  flex: 1 1 auto;
  flex-wrap: nowrap;
  justify-content: flex-start;
  gap: 3px;
  min-width: 0;
}

.quick-fio2-buttons span {
  align-self: center;
  flex: 0 0 auto;
  color: var(--muted);
  font-size: 0.62rem;
  font-weight: 800;
}

.quick-fio2-buttons button {
  flex: 1 1 0;
  min-width: 0;
  min-height: 22px;
  padding: 3px 4px;
  border: 1px solid #cfd6df;
  border-radius: 999px;
  background: #eef1f5;
  color: #4d5968;
  font-size: 0.62rem;
  font-weight: 850;
  line-height: 1;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.quick-fio2-buttons button.active {
  border-color: #8f9baa;
  background: #dfe5eb;
  color: #283241;
}

.respira-app input[type="range"] {
  width: 100%;
  min-width: 0;
  height: 34px;
  accent-color: var(--accent);
  background: transparent;
  cursor: pointer;
  -webkit-appearance: none;
  appearance: none;
}

.respira-app input[type="range"]::-webkit-slider-runnable-track {
  height: 8px;
  border-radius: 999px;
  background: #d8e8f4;
}

.respira-app input[type="range"]::-webkit-slider-thumb {
  width: 24px;
  height: 24px;
  margin-top: -8px;
  border: 2px solid #ffffff;
  border-radius: 999px;
  background: var(--accent);
  box-shadow: 0 2px 8px rgba(18, 32, 51, 0.2);
  -webkit-appearance: none;
  appearance: none;
}

.respira-app input[type="range"]::-moz-range-track {
  height: 8px;
  border-radius: 999px;
  background: #d8e8f4;
}

.respira-app input[type="range"]::-moz-range-thumb {
  width: 22px;
  height: 22px;
  border: 2px solid #ffffff;
  border-radius: 999px;
  background: var(--accent);
  box-shadow: 0 2px 8px rgba(18, 32, 51, 0.2);
}

.respira-app .range-warning input[type="range"] {
  accent-color: var(--yellow);
}

.respira-app .range-warning input[type="range"]::-webkit-slider-thumb {
  background: var(--yellow);
}

.respira-app .range-warning input[type="range"]::-moz-range-thumb {
  background: var(--yellow);
}

.respira-app .range-warning output {
  color: var(--yellow);
}

.respira-app .range-danger input[type="range"] {
  accent-color: var(--red);
}

.respira-app .range-danger input[type="range"]::-webkit-slider-thumb {
  background: var(--red);
}

.respira-app .range-danger input[type="range"]::-moz-range-thumb {
  background: var(--red);
}

.respira-app .range-danger output {
  color: var(--red);
}

output {
  color: var(--accent-strong);
  font-weight: 850;
  text-align: right;
  min-width: 0;
  overflow-wrap: anywhere;
}

.metrics-grid,
.clinical-hud {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 4px;
}

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

.metrics-grid article,
.clinical-hud article {
  min-width: 0;
  min-height: 44px;
  padding: 5px 3px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #f9fcff;
  text-align: center;
}

.metrics-grid span,
.clinical-hud span {
  display: block;
  color: var(--muted);
  font-size: 0.62rem;
  font-weight: 800;
  line-height: 1.05;
  white-space: nowrap;
}

.metrics-grid strong,
.clinical-hud strong {
  display: block;
  min-height: 1.05em;
  overflow: hidden;
  text-overflow: ellipsis;
  font-size: 0.76rem;
  line-height: 1.05;
  white-space: nowrap;
}

.clinical-hud {
  margin-top: 10px;
  padding: 6px;
  border: 1px solid var(--line);
  border-bottom: 0;
  border-radius: 8px 8px 0 0;
  background: var(--surface);
}

.timer-main-button {
  background: var(--accent-strong);
  font-size: 0.86rem !important;
  font-variant-numeric: tabular-nums;
}

.floating-timer {
  position: fixed;
  right: 12px;
  bottom: 126px;
  z-index: 30;
  display: grid;
  justify-items: end;
  gap: 6px;
  max-width: calc(100vw - 24px);
  touch-action: none;
}

.respira-app.vent-mode-active .floating-timer {
  z-index: 100;
}

.reevaluation-warning {
  position: fixed;
  left: 50%;
  top: 50%;
  z-index: 120;
  display: grid;
  width: min(360px, calc(100vw - 28px));
  gap: 10px;
  padding: 16px;
  border: 2px solid #22b8c8;
  border-radius: 14px;
  background: #e9fbfd;
  color: #075d67;
  text-align: center;
  box-shadow: 0 18px 40px rgba(8, 47, 73, 0.22);
  transform: translate(-50%, -50%);
  animation: reevaluationTurquoisePulse 1.8s infinite;
}

.reevaluation-warning strong {
  font-size: 1.15rem;
  font-weight: 1000;
}

.reevaluation-warning span {
  font-size: var(--text-sm);
  font-weight: 800;
}

.reevaluation-warning button {
  min-height: 42px;
  border-radius: 999px;
  background: #0f9faf;
  color: #ffffff;
  font-weight: 1000;
}

@keyframes reevaluationTurquoisePulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(34, 184, 200, 0.18), 0 18px 40px rgba(8, 47, 73, 0.22); }
  50% { box-shadow: 0 0 0 9px rgba(34, 184, 200, 0.12), 0 18px 40px rgba(8, 47, 73, 0.22); }
}

.dev-jump-menu {
  position: fixed;
  top: 96px;
  right: 12px;
  z-index: 120;
  display: none;
  justify-items: end;
  gap: 6px;
}

.dev-jump-toggle {
  min-height: 38px;
  padding: 0 12px;
  border: 2px solid #111827;
  border-radius: 999px;
  background: #ffffff;
  color: #111827;
  font-size: var(--text-xs);
  font-weight: 1000;
  box-shadow: var(--shadow);
}

.dev-jump-panel {
  display: grid;
  gap: 5px;
  width: 150px;
  padding: 8px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.98);
  box-shadow: var(--shadow);
}

.dev-jump-panel[hidden] {
  display: none;
}

.dev-jump-panel button {
  min-height: 34px;
  padding: 0 8px;
  border-radius: 7px;
  font-size: var(--text-xs);
}

.timer-toggle {
  width: 46px;
  min-height: 46px;
  padding: 0;
  border-radius: 999px;
  background: var(--accent-strong);
  box-shadow: var(--shadow);
  font-size: 1.25rem;
}

.timer-controls {
  display: grid;
  grid-template-columns: minmax(74px, 1fr);
  width: min(104px, calc(100vw - 28px));
  max-width: calc(100vw - 28px);
  gap: 6px;
  padding: 6px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--surface);
  box-shadow: var(--shadow);
}

.timer-main-button {
  pointer-events: none;
}

.timer-controls[hidden] {
  display: none;
}

.reevaluation-reminder-button {
  width: 100%;
  min-height: 46px;
  background: var(--accent-strong);
}

.pcr-module {
  position: fixed;
  inset: 0;
  z-index: 80;
  display: grid;
  grid-template-rows: auto auto minmax(0, 1fr) auto;
  gap: 10px;
  overflow: hidden;
  padding: 12px;
  padding-bottom: calc(12px + env(safe-area-inset-bottom));
  background: #07111f;
  color: #eaf4ff;
}

.pcr-module[hidden] {
  display: none;
}

.pcr-module.rosc-view {
  grid-template-rows: auto minmax(0, 1fr) auto;
}

.vent-mode-module {
  position: fixed;
  inset: 0;
  z-index: 80;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  gap: 10px;
  overflow: hidden;
  padding: 12px;
  padding-bottom: calc(12px + env(safe-area-inset-bottom));
  background:
    linear-gradient(180deg, rgba(238, 247, 252, 0.95), rgba(248, 251, 253, 0.98)),
    var(--bg);
  color: var(--ink);
}

.respira-app.vent-mode-active .vent-mode-module {
  padding-bottom: calc(88px + env(safe-area-inset-bottom));
}

.vent-mode-module[hidden] {
  display: none;
}

.vent-mode-brand {
  padding: 10px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: #ffffff;
  box-shadow: var(--shadow-soft);
}

.vent-mode-brand .brand-left {
  color: var(--muted);
}

.vent-mode-brand .brand-left strong,
.vent-mode-brand .brand-right {
  color: var(--accent);
}

.vent-mode-content {
  display: grid;
  gap: 10px;
  min-height: 0;
  overflow: auto;
}

.pcr-brand {
  padding: 10px;
  border: 1px solid #20344d;
  border-radius: 8px;
  background: #0b1728;
}

.pcr-brand .brand-left {
  color: #b8cbe2;
}

.pcr-brand .brand-left strong,
.pcr-brand .brand-right,
.pcr-brand .brand-logo-button {
  color: #8fd1ff;
}

.pcr-brand .brand-center-logo {
  mix-blend-mode: screen;
  opacity: 0.92;
  filter: saturate(1.05) contrast(1.08);
}

.pcr-brand .brand-respira-icon {
  mix-blend-mode: normal;
  background: rgba(255, 255, 255, 0.92);
  box-shadow: 0 0 0 1px rgba(143, 209, 255, 0.22), 0 6px 14px rgba(0, 0, 0, 0.28);
}

.pcr-header {
  display: grid;
  grid-template-columns: minmax(92px, 1fr) auto auto auto;
  align-items: center;
  gap: 6px;
  padding: 8px;
  border: 1px solid #20344d;
  border-radius: 8px;
  background: #081322;
}

.pcr-header[hidden] {
  display: none;
}

.pcr-header h2 {
  margin: 0;
  font-size: var(--text-md);
  line-height: 1;
}

.pcr-episode-badge {
  display: inline-grid;
  place-items: center;
  width: 22px;
  min-height: 22px;
  margin-left: 5px;
  padding: 0;
  border: 2px solid #8fd1ff;
  border-radius: 999px;
  background: #07111f;
  color: #8fd1ff;
  font-size: 0.78rem;
  font-weight: 1000;
  vertical-align: middle;
}

.pcr-episode-badge[hidden],
.pcr-episode-info[hidden] {
  display: none;
}

.pcr-episode-info {
  display: block;
  margin-top: 3px;
  color: #ffd49a;
  font-size: 0.62rem;
  font-weight: 900;
  line-height: 1.05;
}

.pcr-header-clock {
  position: relative;
  display: grid;
  justify-items: center;
  min-width: 72px;
  padding: 5px 7px;
  border: 1px solid #2b4260;
  border-radius: 8px;
  background: #0d1c31;
}

.pcr-header-clock span {
  color: #9eb6d4;
  font-size: var(--text-xs);
  font-weight: 800;
}

.pcr-header-clock strong {
  color: #8fd1ff;
  font-size: 1rem;
  font-variant-numeric: tabular-nums;
}

.pmd-info-button {
  min-height: auto;
  padding: 0;
  background: transparent;
  color: #b8cbe2;
  font-size: var(--text-xs);
}

.pcr-header-clock small {
  position: absolute;
  top: calc(100% + 6px);
  right: 0;
  z-index: 2;
  width: max-content;
  max-width: 220px;
  padding: 6px 8px;
  border: 1px solid #2b4260;
  border-radius: 8px;
  background: #0d1c31;
  color: #eaf4ff;
  box-shadow: var(--shadow);
}

.pcr-content {
  display: grid;
  gap: 10px;
  min-height: 0;
  overflow: auto;
}

.pcr-main-screen,
.pcr-rosc-screen {
  display: grid;
  gap: 10px;
}

.pcr-main-screen[hidden],
.pcr-rosc-screen[hidden] {
  display: none;
}

.pcr-start-banner {
  display: flex;
  gap: 8px;
  align-items: center;
  justify-content: space-between;
  padding: 7px 9px;
  border: 2px solid #000;
  border-radius: 8px;
  background: #f8fafc;
  color: #111827;
  cursor: pointer;
  animation: pcrBlackBurst 1.25s infinite;
}

.pcr-start-banner[hidden] {
  display: none;
}

.pcr-start-banner strong {
  font-size: var(--text-sm);
  line-height: 1;
}

.pcr-start-banner span {
  color: currentColor;
  font-size: var(--text-xs);
  font-weight: 800;
  text-align: right;
}

.pcr-start-banner b {
  color: #000;
  font-size: 1.05rem;
}

.pcr-panel {
  display: grid;
  gap: 10px;
  min-width: 0;
  padding: 12px;
  border: 1px solid #20344d;
  border-radius: 8px;
  background: #0b1728;
}

.pcr-panel h3 {
  margin: 0;
  font-size: var(--text-md);
}

.pcr-panel-compact {
  gap: 7px;
  padding: 9px;
}

.pcr-panel-compact h3 {
  display: flex;
  gap: 6px;
  align-items: baseline;
  flex-wrap: wrap;
  font-size: var(--text-sm);
  line-height: 1.05;
}

.pcr-panel-compact h3 span {
  color: #9eb6d4;
  font-size: var(--text-xs);
  font-weight: 800;
}

.pcr-panel-compact .field-group {
  gap: 5px;
  min-width: 0;
  margin-bottom: 0;
}

.pcr-panel-compact select {
  width: 100%;
  max-width: 100%;
  min-width: 0;
  min-height: 38px;
  border-color: #2b4260;
  background: #07111f;
  color: #eaf4ff;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.pcr-risk-button-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 6px;
  min-width: 0;
}

.pcr-risk-button-grid button {
  min-width: 0;
  min-height: 38px;
  padding: 6px 7px;
  border: 1px solid #2b4260;
  border-radius: 8px;
  background: #07111f;
  color: #eaf4ff;
  font-size: var(--text-xs);
  font-weight: 850;
  line-height: 1.1;
  overflow-wrap: anywhere;
}

.pcr-risk-button-grid button.is-selected {
  border-color: #8fd1ff;
  background: rgba(143, 209, 255, 0.18);
  color: #dff3ff;
}

.pcr-risk-button-grid button[data-value="none"].is-selected {
  border-color: #86c79d;
  background: rgba(34, 197, 94, 0.16);
  color: #bbf7d0;
}

.pcr-panel-compact .sex-grid {
  gap: 6px;
}

.pcr-panel-compact .sex-card {
  min-height: 34px;
  padding: 4px 6px;
}

.pcr-panel-compact .sex-icon {
  font-size: 1.15rem;
  font-weight: 1000;
  text-shadow: 0 0 0 currentColor, 0.4px 0 currentColor, -0.4px 0 currentColor;
}

.pcr-panel-compact .range-row {
  grid-template-columns: 1fr 78px;
  gap: 8px;
}

.pcr-panel-compact .range-row output {
  font-size: var(--text-xs);
  font-weight: 900;
  color: #eaf4ff;
}

.pcr-panel input[type="range"] {
  accent-color: #8fd1ff;
}

.pcr-panel input[type="range"].neonatal-locked {
  accent-color: #8fd1ff;
  background:
    linear-gradient(90deg, #5f6977 0 31.5%, transparent 31.5% 100%);
  border-radius: 999px;
}

.pcr-panel input[type="range"].neonatal-unlocked {
  accent-color: #fbbf24;
}

.pcr-panel input[type="range"]:disabled {
  opacity: 0.45;
}

.pcr-height-lock-note {
  display: grid;
  gap: 6px;
  color: #9eb6d4;
  font-size: var(--text-xs);
  font-weight: 800;
  text-align: right;
}

.pcr-height-lock-note.unlocked {
  color: #fbbf24;
}

.pcr-neonatal-unlock-panel {
  display: grid;
  gap: 7px;
  padding: 8px;
  border: 1px solid #fbbf24;
  border-radius: 8px;
  background: rgba(251, 191, 36, 0.14);
  color: #fde68a;
  text-align: left;
}

.pcr-neonatal-unlock-controls {
  display: grid;
  grid-template-columns: minmax(58px, 0.8fr) 1fr 1fr;
  gap: 6px;
}

.pcr-neonatal-unlock-controls input,
.pcr-neonatal-unlock-controls button {
  min-width: 0;
  min-height: 36px;
  border-radius: 7px;
  font-weight: 900;
}

.pcr-neonatal-unlock-controls input {
  border: 1px solid #fbbf24;
  background: #07111f;
  color: #fef3c7;
  text-align: center;
  text-transform: uppercase;
}

.pcr-neonatal-unlock-controls button {
  border: 1px solid #38516f;
  background: #101d31;
  color: #eaf4ff;
}

.pcr-neonatal-unlock-controls button:last-child {
  border-color: #fbbf24;
  background: #2a1f06;
  color: #fde68a;
}

.pcr-size-panel {
  display: grid;
  gap: 7px;
}

.pcr-size-panel[hidden] {
  display: none;
}

.pcr-neonatal-size-card {
  display: grid;
  gap: 8px;
  padding: 8px;
  border: 1px solid #38516f;
  border-radius: 8px;
  background: #07111f;
}

.pcr-neonatal-size-card label {
  display: grid;
  gap: 5px;
}

.pcr-neonatal-size-card label span,
.pcr-proportional-row span {
  color: #cbdcf0;
  font-size: var(--text-xs);
  font-weight: 850;
}

.pcr-neonatal-size-card input,
.pcr-neonatal-size-card select {
  min-height: 38px;
  border: 1px solid #2b4260;
  border-radius: 7px;
  background: #0b1728;
  color: #eaf4ff;
  font-weight: 850;
}

.pcr-weight-control {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px;
  align-items: end;
}

.pcr-weight-unit-row,
.pcr-proportional-row {
  display: flex;
  gap: 6px;
  align-items: center;
  flex-wrap: wrap;
}

.pcr-weight-unit-row button,
.pcr-proportional-row button {
  min-height: 36px;
  min-width: 48px;
  border: 1px solid #38516f;
  border-radius: 7px;
  background: #101d31;
  color: #eaf4ff;
  font-weight: 900;
}

.pcr-weight-unit-row .unit-kg.active {
  border-color: #fca5a5;
  background: rgba(239, 68, 68, 0.18);
  color: #fecaca;
}

.pcr-weight-unit-row .unit-g.active {
  border-color: #f472b6;
  background: rgba(236, 72, 153, 0.26);
  color: #fbcfe8;
}

.pcr-proportional-row button.active {
  border-color: #8fd1ff;
  background: rgba(143, 209, 255, 0.18);
  color: #dff3ff;
}

.pcr-hud-lock-note {
  margin: 0;
  padding: 8px 10px;
  border: 1px solid #e8a35f;
  border-radius: 8px;
  background: rgba(251, 146, 60, 0.14);
  color: #fed7aa;
  font-size: var(--text-xs);
  font-weight: 850;
  text-align: center;
}

.pcr-bottom-hud {
  display: grid;
  gap: 8px;
  max-width: 760px;
  width: 100%;
  margin: 0 auto;
  padding: 8px;
  border: 1px solid #2b4260;
  border-radius: 8px;
  background: rgba(5, 13, 24, 0.96);
  box-shadow: var(--shadow);
}

.pcr-bottom-hud[hidden] {
  display: none;
}

.pcr-bottom-metrics {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 6px;
}

.pcr-bottom-metrics article {
  min-height: 44px;
  padding: 6px;
  border: 1px solid #20344d;
  border-radius: 8px;
  background: #0b1728;
  text-align: center;
}

.pcr-bottom-metrics article[data-status="pending"] strong {
  color: var(--muted);
}

.pcr-bottom-metrics article[data-status="ok"] strong {
  color: var(--green);
}

.pcr-bottom-metrics article[data-status="danger"] strong,
.pcr-bottom-metrics article[data-status="iot"] strong {
  color: var(--red);
}

.pcr-bottom-metrics article[data-status="danger"] strong {
  text-decoration: line-through;
}

.pcr-bottom-metrics article[data-status="dsg"] strong {
  color: var(--accent-strong);
}

.pcr-bottom-metrics article[data-status="tracheostomy"] strong {
  color: #c05621;
}

.pcr-bottom-metrics span {
  display: block;
  color: #9eb6d4;
  font-size: var(--text-xs);
  font-weight: 900;
}

.pcr-bottom-metrics strong {
  display: block;
  font-size: var(--text-sm);
}

.pcr-mode-row {
  display: grid;
  grid-template-columns: 1fr;
  gap: 6px;
}

.pcr-mode-row:has(#pcr-assist-button:not([hidden])) {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.pcr-mode-button {
  width: 100%;
  min-height: 46px;
  border: 1px solid var(--accent-strong);
  border-radius: 8px;
  background: var(--accent-strong);
  color: #fff;
  font-size: var(--text-sm);
  font-weight: 900;
}

.pcr-mode-button.secondary {
  border-color: #3a6f9f;
  background: #0d2742;
  color: #8fd1ff;
}

.pcr-mode-button.is-checked {
  border-color: var(--green);
  background: #e8f7ee;
  color: #166534;
}

.pcr-mode-button.is-checked::before {
  content: "✓";
  margin-right: 6px;
  color: var(--green);
  font-weight: 900;
}

.pcr-mode-button span {
  color: #000;
}

.pcr-rosc-hud {
  display: grid;
  grid-template-columns: 1fr;
  gap: 8px;
  width: 100%;
  max-width: 760px;
  margin: 0 auto;
  align-self: end;
}

.pcr-rosc-hud[hidden] {
  display: none;
}

.pcr-rosc-hud button {
  width: 100%;
  min-height: 46px;
  border: 2px solid #f7b267;
  border-radius: 8px;
  background: #fff4e5;
  color: #7c3f00;
  font-size: var(--text-md);
  font-weight: 1000;
}

.pcr-rosc-hud button[data-rosc-nav] {
  display: none;
}

.pcr-module.rosc-view .pcr-rosc-hud {
  grid-template-columns: 1fr 0.72fr 1fr;
}

.pcr-rosc-decision-hud {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 6px;
  width: 100%;
  max-width: 760px;
  margin: 0 auto;
}

.pcr-rosc-decision-hud[hidden] {
  display: none;
}

.pcr-rosc-decision-hud article {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 6px;
  align-items: center;
  min-height: 38px;
  padding: 7px 9px;
  border: 1px solid #e59a35;
  border-radius: 8px;
  background: #fff8e8;
  color: #6f3b00;
  font-size: var(--text-xs);
  font-weight: 1000;
  line-height: 1.08;
}

.pcr-rosc-decision-hud:has(> article.danger + .rosc-alerts-fold) {
  grid-template-columns: minmax(0, 1fr) minmax(0, 0.82fr);
  align-items: stretch;
}

.pcr-rosc-decision-hud:has(> article.danger + .rosc-alerts-fold) > article.danger {
  min-height: 42px;
  height: 42px;
  align-content: center;
}

.pcr-rosc-decision-hud article.danger {
  border-color: #7f1d1d;
  background: #dc2626;
  color: #ffffff;
  animation: roscDangerPulse 0.9s infinite;
}

.pcr-rosc-decision-hud article.warn {
  border-color: #d97706;
  background: #fff0d6;
  color: #7c3f00;
}

.pcr-rosc-decision-hud article.stable {
  border-color: #86c79d;
  background: #e9f8ee;
  color: #166534;
}

.pcr-rosc-decision-hud article.info {
  border-color: #3c7499;
  background: #e7f2fb;
  color: #1d4f70;
}

.rosc-alerts-fold {
  display: grid;
  gap: 6px;
}

.pcr-rosc-decision-hud:has(> article.danger + .rosc-alerts-fold) .rosc-alerts-fold {
  grid-column: 2;
}

.rosc-alerts-fold summary {
  display: flex;
  gap: 8px;
  align-items: center;
  justify-content: space-between;
  min-height: 38px;
  height: 100%;
  padding: 7px 9px;
  border: 1px solid #e59a35;
  border-radius: 8px;
  background: #fffaf2;
  color: #6f3b00;
  cursor: pointer;
  font-size: var(--text-sm);
  font-weight: 1000;
  list-style: none;
  min-width: 0;
}

.pcr-rosc-decision-hud:has(> article.danger + .rosc-alerts-fold) .rosc-alerts-fold summary {
  min-height: 42px;
  height: 42px;
  padding-inline: 7px;
  font-size: var(--text-xs);
}

.pcr-rosc-decision-hud:has(> article.danger + .rosc-alerts-fold) .rosc-alerts-fold summary::before {
  margin-right: 4px;
}

.rosc-alerts-fold summary::-webkit-details-marker {
  display: none;
}

.rosc-alerts-fold summary::before {
  content: "▸";
  margin-right: auto;
  color: #8a5a00;
}

.rosc-alerts-fold[open] summary::before {
  transform: rotate(90deg);
}

.rosc-alerts-fold > div {
  display: grid;
  gap: 6px;
}

.pcr-rosc-decision-hud:has(> article.danger + .rosc-alerts-fold) .rosc-alerts-fold[open] {
  grid-column: 1 / -1;
}

.rosc-alert-badges {
  display: inline-flex;
  gap: 4px;
  align-items: center;
}

.rosc-alert-badge {
  display: inline-grid;
  place-items: center;
  min-width: 20px;
  height: 20px;
  border-radius: 999px;
  color: #fff;
  font-size: 0.72rem;
  font-weight: 1000;
  line-height: 1;
}

.rosc-alert-badge.warn {
  background: #d97706;
}

.rosc-alert-badge.stable {
  background: #16a34a;
}

.rosc-alert-badge.info {
  background: #3c7499;
}

.pcr-rosc-decision-hud button {
  min-height: 30px;
  border: 0;
  border-radius: 7px;
  background: #166534;
  color: #ffffff;
  font-size: var(--text-xs);
  font-weight: 900;
}

.pcr-module.rosc-view .pcr-rosc-hud button[data-rosc-nav] {
  display: block;
  border-color: #e3a044;
  background: #fffaf2;
  color: #7c4a10;
  font-size: var(--text-sm);
}

.pcr-module.rosc-view .pcr-rosc-hud button.rosc-clinical-ready {
  border-color: #f59e0b;
  background: #fff7ed;
  color: #7c2d12;
  animation: roscClinicalDoubleBurst 1.55s infinite;
}

.pcr-rosc-clinical-warning {
  width: 100%;
  max-width: 760px;
  margin: 0 auto;
  padding: 8px 10px;
  border: 1px solid #f59e0b;
  border-radius: 8px;
  background: #fff7ed;
  color: #7c2d12;
  font-size: var(--text-sm);
  font-weight: 900;
  text-align: center;
  animation: roscClinicalDoubleBurst 1.55s infinite;
}

.pcr-rosc-clinical-warning[hidden] {
  display: none;
}

.pcr-module.rosc-view #pcr-rosc-button {
  border-color: #dc2626;
  background: #fff1f2;
  color: #991b1b;
}

.pcr-rosc-hero,
.pcr-rosc-panel,
.pcr-rosc-card {
  border: 1px solid #e59a35;
  border-radius: 8px;
  background: #fff6e8;
  color: #6f3b00;
}

.pcr-rosc-hero {
  display: grid;
  gap: 6px;
  padding: 14px;
}

.pcr-rosc-hero h2,
.pcr-rosc-hero p {
  margin: 0;
}

.pcr-rosc-hero p {
  color: #8a5a00;
  font-weight: 750;
}

.rosc-xabcde-trigger {
  appearance: none;
  border: 0;
  background: transparent;
  color: inherit;
  cursor: pointer;
  font: inherit;
  padding: 0;
  text-decoration: underline;
  text-underline-offset: 2px;
}

.pcr-rosc-xabcde-reminder {
  display: grid;
  gap: 5px;
  padding-top: 4px;
  color: #70430b;
  font-size: var(--text-sm);
  font-weight: 400;
  line-height: 1.34;
}

.pcr-rosc-xabcde-reminder[hidden] {
  display: none;
}

.pcr-rosc-xabcde-reminder p {
  margin: 0;
  font-weight: 400;
}

.pcr-rosc-watch {
  min-height: 46px;
  padding: 10px 12px;
  border: 1px solid #f7b267;
  border-radius: 8px;
  background: #fff0d6;
  color: #8a4b00;
  text-align: center;
  animation: roscOrangePulse 1.8s infinite;
}

.pcr-rosc-watch strong,
.pcr-rosc-watch span {
  display: block;
}

.pcr-rosc-watch strong {
  font-weight: 1000;
}

.pcr-rosc-watch span {
  margin-top: 2px;
  font-size: var(--text-xs);
  font-weight: 700;
}

.rosc-panel-heading {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  color: #6f3b00;
  font-weight: 900;
  text-align: left;
}

.rosc-step {
  display: inline-grid;
  place-items: center;
  min-width: 1.35em;
  min-height: 1.35em;
  margin-right: 5px;
  border-radius: 999px;
  background: #ffe6bd;
  color: #7c3f00;
  font-size: 0.72em;
  font-weight: 1000;
}

.pcr-rosc-grid,
.pcr-rosc-option-grid,
.pcr-rosc-binary {
  display: grid;
  gap: 8px;
}

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

.rosc-consciousness-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.pcr-rosc-card,
.pcr-rosc-option-grid button,
.pcr-rosc-binary button {
  min-height: 52px;
  padding: 9px;
  color: #6f3b00;
  font-weight: 900;
  text-align: center;
}

@media (max-width: 520px) {
  .rosc-consciousness-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 5px;
  }

  .rosc-consciousness-grid button {
    min-height: 46px;
    padding: 6px 3px;
    font-size: clamp(0.58rem, 2.6vw, 0.74rem);
    line-height: 1.08;
  }
}

.pcr-rosc-card {
  display: flex;
  align-items: center;
  justify-content: flex-start;
}

.pcr-ovas-title {
  display: flex;
  gap: 8px;
  align-items: center;
  justify-content: flex-start;
  flex-wrap: wrap;
}

.rosc-text-toggle {
  appearance: none;
  border: 0;
  background: transparent;
  color: #7c4a10;
  cursor: pointer;
  font: inherit;
  font-size: var(--text-xs);
  font-weight: 700;
  padding: 0;
}

.rosc-text-toggle span {
  display: inline-block;
  transform: rotate(0deg);
  transition: transform 0.15s ease;
}

.rosc-text-toggle.is-open span {
  transform: rotate(90deg);
}

.pcr-rosc-binary {
  width: 100%;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.pcr-rosc-binary button,
.pcr-rosc-option-grid button {
  border: 1px solid #e59a35;
  border-radius: 8px;
  background: #fffaf2;
  color: #6f3b00;
}

.pcr-rosc-option-grid button.is-selected {
  border-color: #3c7499;
  background: #e7f2fb;
  color: #1d4f70;
}

.pcr-rosc-binary button[data-rosc-ovas="true"] {
  border-color: var(--red);
  background: #fff1f2;
  color: #b91c1c;
  font-weight: 1000;
}

.pcr-rosc-binary button.is-selected {
  border-width: 2px;
  background: #e7f2fb;
}

.pcr-rosc-binary button[data-rosc-ovas="true"].is-selected {
  background: #fee2e2;
  color: #7f1d1d;
}

.rosc-indicators-none-button {
  width: 100%;
  min-height: 44px;
  border: 1px solid #86c79d;
  border-radius: 8px;
  background: #fffaf2;
  color: #166534;
  font-size: var(--text-sm);
  font-weight: 900;
  text-align: center;
}

.rosc-indicators-none-button.is-selected {
  border-width: 2px;
  background: #dcfce7;
  color: #14532d;
}

.rosc-panel-hint {
  margin: -4px 0 0;
  color: #6b7280;
  font-size: var(--text-xs);
  font-weight: 750;
}

.pcr-rosc-panel {
  display: grid;
  gap: 10px;
  padding: 10px;
}

.pcr-rosc-reminder {
  display: grid;
  gap: 4px;
  width: 100%;
  color: #7c4a10;
  font-size: var(--text-xs);
  text-align: left;
}

.pcr-rosc-reminder[hidden] {
  display: none;
}

.pcr-rosc-reminder span {
  padding: 3px 6px;
  border-radius: 6px;
  background: #ffe6bd;
}

.pcr-rosc-reminder.danger span {
  border: 2px solid #7f1d1d;
  background: #dc2626;
  color: #ffffff;
  box-shadow: 0 0 0 0 rgba(220, 38, 38, 0.45);
  font-size: var(--text-md);
  font-weight: 1000;
  text-align: center;
  animation: roscDangerPulse 0.9s infinite;
}

.pcr-rosc-reminder.notice span {
  border: 1px solid #3c7499;
  background: #e7f2fb;
  color: #1d4f70;
  font-size: var(--text-sm);
  font-weight: 1000;
  text-align: center;
}

.rosc-clinical-mode-button {
  width: 100%;
  min-height: 42px;
  border: 1px solid #3c7499;
  border-radius: 8px;
  background: #3c7499;
  color: #ffffff;
  font-weight: 900;
}

.pcr-rosc-panel .toggle-card {
  width: 100%;
  border-color: #e59a35;
  background: #fffaf2;
  color: #6f3b00;
}

.pcr-rosc-panel .toggle-card.is-selected {
  border-color: var(--accent);
  background: #e7f2fb;
  color: var(--accent-strong);
}

.pcr-rosc-panel .toggle-card:disabled {
  opacity: 0.42;
  cursor: not-allowed;
  filter: grayscale(0.35);
}

.mode-hero {
  display: grid;
  gap: 5px;
  min-height: auto;
  padding: 14px;
  border: 1px solid var(--mode-border, #d8e5ef);
  border-radius: 8px;
  background: linear-gradient(90deg, var(--mode-ribbon, #eef7fb) 0 7px, var(--mode-bg, var(--surface)) 7px 100%);
  color: var(--mode-ink, var(--ink));
  overflow: hidden;
}

.mode-hero span {
  font-size: var(--text-xs);
  font-weight: 1000;
  text-transform: uppercase;
  color: var(--mode-accent, var(--accent-strong));
}

.mode-hero h2,
.mode-hero p {
  margin: 0;
}

.mode-hero h2 {
  font-size: var(--text-lg);
  letter-spacing: 0;
}

.mode-hero p {
  max-width: 36rem;
  color: var(--muted);
  font-size: var(--text-sm);
  font-weight: 700;
}

.mode-cpap {
  --mode-bg: var(--surface);
  --mode-ribbon: #dff3fb;
  --mode-border: #c8e4ee;
  --mode-ink: var(--ink);
  --mode-accent: #1878a8;
  box-shadow: none;
}

.mode-cpap-ps {
  --mode-bg: var(--surface);
  --mode-ribbon: #dff3ea;
  --mode-border: #c7e4d5;
  --mode-ink: var(--ink);
  --mode-accent: #1d7b5a;
}

.mode-vc {
  --mode-bg: var(--surface);
  --mode-ribbon: #d8e0ec;
  --mode-border: #c2ccda;
  --mode-ink: var(--ink);
  --mode-accent: #34516f;
}

.mode-vc p {
  color: var(--muted);
}

.mode-layout {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}

.mode-panel {
  display: grid;
  gap: 5px;
  min-height: 84px;
  padding: 10px;
  border: 1px solid var(--mode-panel-border, #cfe4ef);
  border-radius: 8px;
  background: var(--mode-panel-bg, #ffffff);
  color: var(--mode-panel-ink, #17324d);
}

.mode-panel strong {
  font-size: var(--text-sm);
}

.mode-panel span {
  color: inherit;
  font-size: var(--text-xs);
  font-weight: 750;
}

.mode-cpap-screen .mode-panel {
  --mode-panel-border: #c8e4ee;
  --mode-panel-bg: #ffffff;
  --mode-panel-ink: var(--ink);
}

.mode-cpap-ps-screen .mode-panel {
  --mode-panel-border: #c7e4d5;
  --mode-panel-bg: #ffffff;
  --mode-panel-ink: var(--ink);
}

#pcr-vc-simv-screen .mode-panel {
  --mode-panel-border: #c2ccda;
  --mode-panel-bg: #f7f9fc;
  --mode-panel-ink: #26384f;
}

.mode-wave {
  min-height: 44px;
  border-radius: 8px;
  background:
    radial-gradient(circle at 10% 50%, rgba(46, 144, 191, 0.2), transparent 18%),
    repeating-linear-gradient(90deg, rgba(24, 120, 168, 0), rgba(24, 120, 168, 0) 18px, rgba(24, 120, 168, 0.18) 19px, rgba(24, 120, 168, 0) 40px),
    #f8fdff;
  border: 1px solid #bfe8f7;
}

.cpap-environment {
  display: grid;
  gap: 10px;
  padding-bottom: 74px;
  color: var(--ink);
  --mode-accent-local: #1878a8;
  --mode-field-border: #c8e4ee;
  --mode-soft-bg: #eef8fc;
}

.cpap-environment.peep-contraindicated {
  box-shadow: inset 0 0 0 4px rgba(185, 28, 28, 0.28);
}

.cpap-hero {
  min-height: 0;
}

.cpap-soft-warning,
.cpap-critical-warning,
.cpap-blocker,
.cpap-red-note {
  padding: 9px 10px;
  border-radius: 8px;
  font-size: var(--text-sm);
  font-weight: 850;
}

.cpap-soft-warning {
  border: 1px solid #f4c56b;
  background: #fff8e8;
  color: #8a5a00;
}

.cpap-critical-warning,
.cpap-blocker,
.cpap-red-note {
  border: 1px solid var(--red);
  background: #fff1f1;
  color: var(--red);
}

.cpap-critical-warning {
  animation: pcrRedBlackFlash 0.75s infinite;
  text-align: center;
}

.cpap-card {
  display: grid;
  gap: 10px;
  padding: 12px;
  border: 1px solid var(--mode-card-border, var(--line));
  border-radius: 8px;
  background: var(--surface);
  color: var(--ink);
}

.cpap-card h3,
.cpap-card h4,
.cpap-card p {
  margin: 0;
}

.cpap-card h3 {
  font-size: var(--text-md);
}

.cpap-card h4 {
  color: var(--ink);
  font-size: var(--text-sm);
}

.cpap-card h4 span {
  color: var(--muted);
  font-size: var(--text-xs);
}

.cpap-fold,
.cpap-inline-fold,
.cpap-fold-card {
  min-width: 0;
}

.cpap-fold summary,
.cpap-inline-fold summary,
.cpap-fold-card summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  min-height: 38px;
  padding: 8px 10px;
  border: 1px solid var(--mode-field-border, var(--line));
  border-radius: 8px;
  background: var(--mode-soft-bg, #e7f2fb);
  color: var(--ink);
  font-size: var(--text-sm);
  font-weight: 1000;
  cursor: pointer;
}

.cpap-important-fold summary {
  border-color: #f4c56b;
  background: #fff8e8;
  color: #8a5a00;
}

.cpap-contra-fold summary {
  border-color: #f3b4b4;
  background: #fff5f5;
  color: #a82222;
}

.cpap-fold summary::after,
.cpap-inline-fold summary::after,
.cpap-fold-card summary::after {
  content: "+";
  display: grid;
  place-items: center;
  width: 22px;
  min-width: 22px;
  height: 22px;
  border-radius: 999px;
  background: #ffffff;
  color: currentColor;
  font-weight: 1000;
}

.cpap-fold[open] summary::after,
.cpap-inline-fold[open] summary::after,
.cpap-fold-card[open] summary::after {
  content: "−";
}

.cpap-fold summary::-webkit-details-marker,
.cpap-inline-fold summary::-webkit-details-marker,
.cpap-fold-card summary::-webkit-details-marker {
  display: none;
}

.cpap-fold > p,
.cpap-fold-card > p,
.cpap-fold-card > .cpap-context-grid {
  margin-top: 8px;
}

.cpap-inline-fold {
  display: grid;
  gap: 7px;
}

.cpap-inline-fold[open] {
  gap: 8px;
}

.cpap-prestart-stack {
  display: grid;
  gap: 8px;
}

.cpap-inline-fold summary span {
  color: var(--muted);
  font-size: var(--text-xs);
}

.cpap-access-wizard {
  gap: 8px;
}

.cpap-wizard-stage,
.cpap-wizard-stack,
.cpap-wizard-final {
  display: grid;
  gap: 9px;
  margin-top: 8px;
}

.cpap-wizard-primary,
.cpap-wizard-pair button,
.cpap-screen-buttons button,
.cpap-pressure-button,
.cpap-param-strip {
  width: 100%;
  min-height: 48px;
  border-radius: 8px;
  font-size: var(--text-sm);
  font-weight: 1000;
}

.cpap-wizard-pair {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.cpap-wizard-pair.three {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.cpap-wizard-pair button.active {
  background: var(--mode-accent-local, var(--accent-strong));
  color: #ffffff;
}

.cpap-screen-buttons {
  display: grid;
  gap: 8px;
}

.cpap-screen-buttons button {
  background: #e5e7eb;
  color: #4b5563;
}

.cpap-screen-buttons button.active {
  background: var(--mode-accent-local, var(--accent-strong));
  color: #ffffff;
}

.cpap-pressure-button {
  border: 2px solid #3c7499;
  background: #e7f2fb;
  color: #12385a;
}

.cpap-pressure-button.blue-burst {
  animation: cpapBlueDoubleBurst 1.1s infinite;
}

.cpap-pressure-button.slow-yellow {
  border-color: #f4c56b;
  background: #fff8e8;
  color: #8a5a00;
  animation: cpapYellowSlowPulse 1.25s infinite;
}

.cpap-pressure-button.fixed-yellow {
  border-color: #f4c56b;
  background: #ffd76f;
  color: #2f2200;
}

.cpap-param-strip {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 6px;
  padding: 8px;
  background: #f8fbfd;
  color: var(--ink);
}

.cpap-param-strip span {
  display: grid;
  place-items: center;
  min-height: 36px;
  border: 1px solid var(--mode-field-border, var(--line));
  border-radius: 7px;
  background: #ffffff;
}

.cpap-wizard-final {
  padding: 10px;
  border: 1px solid #b8ddc9;
  border-radius: 8px;
  background: #f4fbf7;
  color: #166534;
}

.cpap-wizard-final span {
  color: #315f42;
  font-size: var(--text-sm);
  font-weight: 800;
}

.cpap-wizard-interface {
  display: grid;
  gap: 8px;
  padding: 10px;
  border: 1px solid var(--mode-field-border, var(--line));
  border-radius: 8px;
  background: #ffffff;
}

.cpap-card-toggle {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  width: 100%;
  min-height: 42px;
  padding: 8px 10px;
  border: 1px solid var(--mode-field-border, var(--line));
  border-radius: 8px;
  background: var(--mode-soft-bg, #e7f2fb);
  color: var(--ink);
  font-weight: 1000;
}

.cpap-card-toggle strong {
  display: grid;
  place-items: center;
  width: 24px;
  height: 24px;
  border-radius: 999px;
  background: #ffffff;
  color: currentColor;
}

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

.cpap-setting-pill {
  position: relative;
  display: grid;
  gap: 4px;
  min-height: 72px;
  min-width: 0;
  overflow: hidden;
  padding: 9px;
  border: 1px solid var(--mode-field-border, var(--line));
  border-radius: 8px;
  background: #ffffff;
  color: var(--ink);
  text-align: left;
}

.cpap-setting-pill span,
.cpap-setting-pill small {
  position: relative;
  z-index: 1;
  color: var(--muted);
  font-size: var(--text-xs);
  font-weight: 900;
}

.cpap-setting-pill strong {
  position: relative;
  z-index: 1;
  color: var(--mode-accent-local, var(--accent-strong));
  font-size: var(--text-sm);
}

.cpap-setting-pill.mode strong {
  animation: cpapBlueSlowPulse 1.7s infinite;
}

.cpap-setting-pill.peep::before {
  content: "";
  position: absolute;
  inset: auto 0 0 0;
  height: 0%;
  background: linear-gradient(180deg, rgba(160, 211, 238, 0.35), rgba(60, 116, 153, 0.42));
  animation: cpapPeepFill 4.2s ease-in-out infinite;
}

.cpap-setting-pill.peep.contraindicated {
  border-color: var(--red);
  background: #fff1f1;
  animation: cpapPeepContraindicatedFlash 0.85s infinite;
}

.cpap-setting-pill.peep.contraindicated::before {
  display: none;
}

.cpap-setting-pill.peep.contraindicated strong {
  color: var(--red);
  font-size: var(--text-lg);
}

.cpap-setting-pill.peep.contraindicated small {
  color: var(--red);
}

.cpap-setting-pill.niv {
  cursor: pointer;
  animation: cpapNivOffCycle 1.8s infinite;
}

.cpap-setting-pill.niv.on {
  border-color: #97d2ae;
  background: #f3fbf6;
  animation: cpapNivOnPulse 1.7s infinite;
}

.cpap-setting-pill.niv.off strong {
  color: var(--red);
}

.cpap-setting-pill.niv.on strong {
  color: #166534;
}

.cpap-niv-status {
  padding: 8px 10px;
  border-radius: 8px;
  font-size: var(--text-sm);
  font-weight: 900;
}

.cpap-niv-status.off,
.cpap-niv-status.danger {
  border: 1px solid var(--red);
  background: #fff1f1;
  color: var(--red);
}

.cpap-niv-status.on {
  border: 1px solid #b8ddc9;
  background: #f4fbf7;
  color: #166534;
}

.cpap-niv-status.warn {
  border: 1px solid #f4c56b;
  background: #fff8e8;
  color: #8a5a00;
  animation: cpapYellowSlowPulse 1.35s infinite;
}

.cpap-pneumothorax-gate {
  border-color: var(--red);
  background: #fff7f7;
}

.cpap-pneumothorax-gate.resolved {
  border-color: #f4c56b;
  background: #fffaf0;
}

.cpap-pneumothorax-gate > strong {
  color: var(--red);
  font-size: var(--text-md);
}

.cpap-pneumothorax-gate .cpap-wizard-pair button.active {
  background: #166534;
  color: #ffffff;
}

.cpap-pneumothorax-gate .cpap-wizard-pair button.danger {
  background: var(--red);
  color: #ffffff;
}

.cpap-application-steps {
  gap: 8px;
}

.cpap-application-step {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 8px;
  padding: 8px 9px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #ffffff;
  color: var(--muted);
  font-size: var(--text-sm);
  font-weight: 900;
}

.cpap-application-step.active {
  border-color: var(--mode-field-border, var(--line));
  background: var(--mode-soft-bg, #e7f2fb);
  color: var(--ink);
}

.cpap-application-step.done {
  border-color: #b8ddc9;
  background: #f4fbf7;
  color: #166534;
}

.cpap-application-step button {
  min-height: 32px;
  padding: 5px 10px;
  border-radius: 999px;
  background: var(--mode-accent-local, var(--accent-strong));
  color: #ffffff;
  font-size: var(--text-xs);
}

.cpap-monitor-control {
  display: grid;
  gap: 8px;
  padding: 9px;
  border: 1px solid var(--mode-field-border, var(--line));
  border-radius: 8px;
  background: #ffffff;
}

.cpap-monitor-control.tone-ok {
  border-color: #b8ddc9;
  background: #f4fbf7;
}

.cpap-monitor-control.tone-warn {
  border-color: #f4d77b;
  background: #fffbea;
}

.cpap-monitor-control.tone-orange {
  border-color: #f4b66f;
  background: #fff6ec;
}

.cpap-monitor-control.tone-danger {
  border-color: #ef9a9a;
  background: #fff1f1;
}

.cpap-monitor-control.tone-empty {
  border-color: var(--mode-field-border, var(--line));
  background: #ffffff;
}

.cpap-monitor-control > button,
.cpap-monitor-main,
.cpap-monitor-control.fixed {
  display: grid;
  align-items: center;
  justify-content: center;
  gap: 4px;
  min-height: 42px;
  padding: 0;
  background: transparent;
  color: var(--ink);
  text-align: center;
}

.cpap-monitor-header {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 34px;
  gap: 7px;
  align-items: center;
}

.cpap-monitor-control > button span,
.cpap-monitor-main span,
.cpap-monitor-control.fixed span {
  color: var(--muted);
  font-size: var(--text-xs);
  font-weight: 900;
  line-height: 1.05;
  text-align: center;
}

.cpap-monitor-control > button strong,
.cpap-monitor-main strong,
.cpap-monitor-control.fixed strong {
  color: var(--mode-accent-local, var(--accent-strong));
  font-size: var(--text-md);
  line-height: 1.05;
  text-align: center;
}

.cpap-info-dot {
  width: 30px;
  height: 30px;
  border: 0;
  border-radius: 10px;
  background: transparent;
  color: var(--mode-accent-local, var(--accent-strong));
  font-weight: 1000;
  font-size: 1.05rem;
  line-height: 1;
}

.cpap-info-bubble {
  grid-column: 1 / -1;
  padding: 8px 10px;
  border: 1px solid #bad9eb;
  border-radius: 8px;
  background: #f4fbff;
  color: #23425b;
  font-size: var(--text-sm);
  font-weight: 700;
  line-height: 1.35;
}

.cpap-monitor-slider {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 72px;
  align-items: center;
  gap: 8px;
}

.respira-app .cpap-monitor-row-editor .cpap-monitor-slider {
  grid-template-columns: minmax(0, 1fr) minmax(64px, 84px);
}

.respira-app .cpap-monitor-row-editor input[type="range"] {
  width: 100%;
}

.cpap-monitor-editor {
  width: 100%;
  display: grid;
  gap: 10px;
  padding: 10px;
  border: 1px solid #c2ccda;
  border-radius: 8px;
  background: #f8fafc;
}

.cpap-monitor-row-editor {
  grid-column: 1 / -1;
}

.cpap-safety-mode-controls {
  display: grid;
  gap: 8px;
}

.cpap-safety-mode-editor {
  width: 100%;
}

.cpap-safety-mode-editor .cpap-monitor-editor {
  width: 100%;
}

.cpap-ps-select-helper {
  margin: 0 0 6px;
  color: #334155;
  font-size: var(--text-sm);
  font-weight: 400;
  line-height: 1.25;
}

.cpap-monitor-slider output {
  color: var(--mode-accent-local, var(--accent-strong));
  font-weight: 950;
  text-align: right;
}

.cpap-monitor-control select {
  width: 100%;
  min-height: 42px;
  border: 1px solid var(--mode-field-border, var(--line));
  border-radius: 8px;
  background: #ffffff;
  color: var(--ink);
  font-weight: 850;
}

.cpap-monitor-control.vte-low {
  border-color: var(--red);
  animation: cpapVteLowPulse 1.35s infinite;
}

.cpap-monitor-control.open,
.cpap-monitor-control.info-open {
  z-index: 1;
}

.cpap-monitor-trend {
  display: grid;
  gap: 7px;
  padding: 8px;
  border: 1px solid var(--mode-field-border, var(--line));
  border-radius: 8px;
  background: #f8fcff;
}

.cpap-trend-chart-card {
  position: relative;
}

.cpap-chart-expand {
  position: absolute;
  top: 8px;
  left: 8px;
  z-index: 2;
  display: grid;
  width: 32px;
  min-height: 32px;
  place-items: center;
  padding: 0;
  border: 1px solid #bad9eb;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.94);
  color: var(--mode-accent-local, var(--accent-strong));
  font-size: 1rem;
  font-weight: 900;
  box-shadow: 0 6px 18px rgba(18, 32, 51, 0.12);
}

.cpap-trend-chart-card.fullscreen {
  position: fixed;
  inset: 10px;
  z-index: 130;
  display: grid;
  align-content: start;
  gap: 10px;
  overflow: auto;
  padding: 12px;
  border: 1px solid #bad9eb;
  border-radius: 12px;
  background: #f8fcff;
  box-shadow: 0 20px 60px rgba(18, 32, 51, 0.28);
}

.cpap-trend-chart-card.fullscreen .cpap-chart {
  min-height: min(72vh, 620px);
}

.cpap-trend-chart-card.fullscreen .cpap-chart-expand {
  position: sticky;
  top: 0;
  left: 0;
  justify-self: start;
}

.cpap-chart-legend {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  color: var(--muted);
  font-size: var(--text-xs);
  font-weight: 900;
}

.cpap-chart-legend span {
  padding: 2px 6px;
  border-radius: 999px;
  background: #ffffff;
}

.cpap-monitor-groups {
  display: grid;
  gap: 9px;
}

.cpap-monitor-group {
  display: grid;
  gap: 7px;
}

.cpap-monitor-group h4 {
  margin: 0;
  color: var(--mode-accent-local, var(--accent-strong));
  font-size: var(--text-sm);
}

.cpap-monitor-chip-row {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 7px;
}

.cpap-monitor-chip-row.three {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.cpap-monitor-chip-row.vc-simv-interface-row {
  grid-template-columns: minmax(0, 0.82fr) minmax(0, 0.82fr) minmax(0, 1.36fr);
}

.vc-simv-interface-row .cpap-monitor-control > button strong,
.vc-simv-interface-row .cpap-monitor-control.fixed strong {
  font-size: clamp(0.72rem, 2.7vw, var(--text-md));
  overflow-wrap: anywhere;
}

.cpap-monitor-chip-row.two {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.cpap-monitor-chip-row.four {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.cpap-monitor-reference .cpap-monitor-control {
  max-width: none;
}

.cpap-thoracostomy-emergency {
  padding: 10px;
  border: 2px solid var(--red);
  border-radius: 8px;
  background: #140303;
  color: #ffffff;
  font-size: var(--text-md);
  font-weight: 1000;
  text-align: center;
  animation: pcrRedBlackFlash 0.75s infinite;
}

.cpap-context-grid,
.cpap-settings-grid,
.cpap-monitor-grid,
.cpap-safety-grid,
.cpap-two-columns,
.cpap-step-list,
.cpap-quick-row {
  display: grid;
  gap: 8px;
}

.cpap-context-grid,
.cpap-settings-grid,
.cpap-monitor-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.cpap-two-columns {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  align-items: start;
}

.cpap-safety-grid,
.cpap-step-list {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.cpap-quick-row {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.cpap-context-grid span,
.cpap-fixed-value,
.cpap-number-input,
.cpap-number-control {
  display: grid;
  gap: 4px;
  min-width: 0;
  padding: 9px;
  border: 1px solid var(--mode-field-border, var(--line));
  border-radius: 8px;
  background: #ffffff;
}

.cpap-context-grid strong,
.cpap-fixed-value strong {
  color: var(--mode-accent-local, var(--accent-strong));
  font-size: var(--text-md);
}

.cpap-check {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 8px;
  align-items: center;
  min-height: 42px;
  padding: 8px;
  border: 1px solid var(--mode-field-border, var(--line));
  border-radius: 8px;
  background: #ffffff;
  font-weight: 750;
}

.cpap-check input {
  width: 18px;
  height: 18px;
  accent-color: var(--mode-accent-local, var(--accent-strong));
}

.pressure-light-row {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.pressure-light {
  display: grid;
  place-items: center;
  min-height: 42px;
  border-radius: 8px;
  background: #fff5cc;
  color: #8a5a00;
  font-weight: 1000;
}

.pressure-light.blinking {
  border: 2px solid var(--red);
  animation: roscOrangePulse 0.9s infinite;
}

.pressure-light.fixed {
  border: 2px solid var(--green);
  color: #166534;
}

.cpap-number-control > div,
.cpap-number-input > div,
.cpap-segmented {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto auto;
  gap: 6px;
  align-items: center;
}

.cpap-number-control input,
.cpap-number-input input,
.cpap-number-input select,
.cpap-observations textarea {
  width: 100%;
  min-width: 0;
  border: 1px solid var(--mode-field-border, var(--line));
  border-radius: 7px;
  background: #fff;
  color: #17324d;
}

.cpap-number-control button,
.cpap-quick-row button,
.cpap-message button,
.cpap-confirm,
.cpap-bottom-nav button {
  min-height: 38px;
  border-radius: 7px;
  background: var(--mode-accent-local, var(--accent-strong));
  color: #fff;
  font-weight: 900;
}

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

.cpap-segmented button {
  min-height: 38px;
  border-radius: 7px;
  background: var(--mode-soft-bg, #e7f2fb);
  color: var(--mode-accent-local, var(--accent-strong));
}

.cpap-segmented button.active {
  background: var(--mode-accent-local, var(--accent-strong));
  color: #fff;
}

.cpap-segmented button.danger {
  background: var(--red);
}

.cpap-help-text {
  color: var(--muted);
  font-size: var(--text-sm);
  font-weight: 700;
}

.cpap-observations {
  display: grid;
  gap: 7px;
  font-weight: 800;
}

.cpap-observations-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.cpap-observations-head span {
  color: var(--ink);
  font-size: var(--text-sm);
  font-weight: 850;
}

.cpap-observations-head button {
  min-height: 30px;
  padding: 0 10px;
  border: 1px solid var(--mode-field-border, var(--line));
  border-radius: 999px;
  background: #f4fbff;
  color: var(--mode-accent-local, var(--accent-strong));
  font-size: var(--text-xs);
  font-weight: 850;
}

.cpap-observations textarea {
  min-height: 92px;
  max-height: 45vh;
  padding: 8px;
  padding-bottom: 20px;
  resize: vertical;
  font-weight: 400;
  overflow: auto;
  touch-action: pan-y;
  background:
    linear-gradient(135deg, transparent calc(100% - 16px), #9bc9dd calc(100% - 15px), #9bc9dd calc(100% - 12px), transparent calc(100% - 11px)),
    #ffffff;
}

.cpap-observations-status {
  color: #166534;
  font-size: var(--text-xs);
  font-weight: 900;
}

.cpap-resize-hint {
  justify-self: end;
  margin-top: -4px;
  color: #3c7499;
  font-size: var(--text-xs);
  font-weight: 750;
}

.cpap-observations-history {
  display: grid;
  gap: 6px;
  padding: 8px;
  border: 1px solid var(--mode-field-border, var(--line));
  border-radius: 8px;
  background: #f8fcff;
}

.cpap-observations-history ul {
  display: grid;
  gap: 6px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.cpap-observations-history li {
  display: grid;
  grid-template-columns: 48px minmax(0, 1fr);
  gap: 8px;
  padding: 7px;
  border-radius: 7px;
  background: #ffffff;
  color: var(--ink);
  font-size: var(--text-sm);
  font-weight: 650;
}

.cpap-observations-history time {
  color: var(--mode-accent-local, var(--accent-strong));
  font-weight: 850;
}

.cpap-observation-empty {
  margin: 0;
  color: var(--muted);
  font-size: var(--text-sm);
  font-weight: 650;
}

.cpap-reevaluation-button {
  min-height: 42px;
  border-radius: 8px;
  background: var(--mode-accent-local, var(--accent-strong));
  color: #ffffff;
  font-weight: 950;
}

.cpap-message-stack {
  display: grid;
  gap: 7px;
}

.cpap-help-toggle {
  grid-template-columns: minmax(0, 1fr) auto auto;
}

.cpap-help-badges {
  display: flex;
  gap: 4px;
  align-items: center;
}

.cpap-help-badges i {
  display: grid;
  min-width: 23px;
  height: 23px;
  place-items: center;
  border-radius: 999px;
  color: #ffffff;
  font-size: var(--text-xs);
  font-style: normal;
  font-weight: 1000;
}

.cpap-help-badges .red {
  background: var(--red);
}

.cpap-help-badges .yellow {
  background: #d18b00;
}

.cpap-help-badges .green {
  background: #168a4a;
}

.cpap-help-badges .blue {
  background: #3c7499;
}

.cpap-message {
  display: grid;
  gap: 7px;
  padding: 10px;
  border-radius: 8px;
  font-weight: 800;
}

.cpap-message.stable {
  border: 1px solid #b8ddc9;
  background: #f4fbf7;
  color: #166534;
}

.cpap-message.warn {
  border: 1px solid #f4c56b;
  background: #fff8e8;
  color: #8a5a00;
}

.cpap-message.watch {
  border: 1px solid #f2d76b;
  background: #fffbea;
  color: #6b5b00;
}

.cpap-message.danger {
  border: 1px solid var(--red);
  background: #fff1f1;
  color: var(--red);
}

.cpap-chart,
.cpap-empty-chart {
  width: 100%;
  background: #fff;
}

.cpap-empty-chart {
  display: grid;
  place-items: center;
  color: #5a7c92;
  font-weight: 800;
}

.cpap-interpretation {
  padding: 9px;
  border-radius: 8px;
  background: var(--mode-soft-bg, #e7f2fb);
  color: var(--mode-accent-local, var(--accent-strong));
  font-weight: 900;
}

.cpap-bottom-nav {
  position: fixed;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 95;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
  max-width: 980px;
  margin: 0 auto;
  padding: 10px 12px calc(10px + env(safe-area-inset-bottom));
  border-top: 1px solid var(--line);
  background: rgba(255, 255, 255, 0.96);
  backdrop-filter: blur(12px);
}

.cpap-bottom-nav button {
  min-width: 0;
  padding: 0 8px;
}

.cpap-bottom-nav button:first-child,
.cpap-bottom-nav button:nth-child(2) {
  background: #e9eeee;
  color: var(--ink);
}

.cpap-bottom-nav button:nth-child(3) {
  background: var(--black);
  color: #ffffff;
}

.cpap-confirm:disabled {
  opacity: 0.45;
  cursor: not-allowed;
}

.cpap-confirm.configured {
  border: 1px solid #97d2ae;
  background: #166534;
  color: #ffffff;
}

/* CPAP visual normalization: keep the environment dense but consistent. */
.cpap-environment {
  --cpap-radius: 8px;
  --cpap-gap: 10px;
  --cpap-pad: 11px;
  font-size: var(--text-sm);
  line-height: 1.32;
}

.cpap-environment :is(.cpap-card, .cpap-fold-card, .cpap-pneumothorax-gate) {
  gap: var(--cpap-gap);
  padding: var(--cpap-pad);
  border-radius: var(--cpap-radius);
}

.cpap-environment :is(h3, h4, p, strong, span) {
  letter-spacing: 0;
}

.cpap-environment h3 {
  color: var(--ink);
  font-size: 0.98rem;
  font-weight: 850;
  line-height: 1.18;
}

.cpap-environment h4,
.cpap-monitor-group h4 {
  color: var(--mode-accent-local, var(--accent-strong));
  font-size: 0.82rem;
  font-weight: 850;
  line-height: 1.16;
}

.cpap-environment :is(p, .cpap-help-text, .cpap-wizard-final span, .cpap-message span, .cpap-info-bubble) {
  font-size: var(--text-sm);
  font-weight: 650;
  line-height: 1.36;
}

.cpap-environment :is(
  .cpap-fold summary,
  .cpap-inline-fold summary,
  .cpap-fold-card summary,
  .cpap-card-toggle
) {
  min-height: 40px;
  padding: 8px 10px;
  border-radius: var(--cpap-radius);
  font-size: var(--text-sm);
  font-weight: 850;
  line-height: 1.12;
}

.cpap-environment :is(
  .cpap-wizard-primary,
  .cpap-wizard-pair button,
  .cpap-screen-buttons button,
  .cpap-pressure-button,
  .cpap-param-strip,
  .cpap-confirm,
  .cpap-reevaluation-button,
  .cpap-bottom-nav button,
  .cpap-message button
) {
  border-radius: var(--cpap-radius);
  font-size: var(--text-sm);
  font-weight: 850;
  line-height: 1.1;
}

.cpap-environment :is(.cpap-check, .cpap-application-step, .cpap-number-input, .cpap-number-control, .cpap-context-grid span) {
  border-radius: var(--cpap-radius);
  font-size: var(--text-sm);
  font-weight: 700;
  line-height: 1.24;
}

.cpap-environment .cpap-check span {
  font-weight: 700;
}

.cpap-environment .cpap-check.cpap-check-danger {
  border-color: rgba(185, 28, 28, 0.36);
  background: #fff1f1;
  color: #8f1212;
}

.cpap-environment .cpap-check.cpap-check-danger:has(input:checked) {
  border-color: #b91c1c;
  background: #fee2e2;
  box-shadow: 0 0 0 2px rgba(185, 28, 28, 0.12);
}

.cpap-environment :is(.cpap-soft-warning, .cpap-critical-warning, .cpap-blocker, .cpap-red-note, .cpap-niv-status, .cpap-message) {
  border-radius: var(--cpap-radius);
  font-size: var(--text-sm);
  font-weight: 750;
  line-height: 1.32;
}

.cpap-monitor-control {
  padding: 9px;
  border-radius: var(--cpap-radius);
}

.cpap-monitor-control > button span,
.cpap-monitor-main span,
.cpap-monitor-control.fixed span,
.cpap-setting-pill span,
.cpap-setting-pill small {
  font-size: var(--text-xs);
  font-weight: 800;
  line-height: 1.08;
}

.cpap-monitor-control > button strong,
.cpap-monitor-main strong,
.cpap-monitor-control.fixed strong,
.cpap-setting-pill strong {
  font-size: var(--text-md);
  font-weight: 850;
  line-height: 1.08;
}

.cpap-help-badges i {
  font-weight: 850;
}

.cpap-ps-environment {
  display: grid;
  gap: 10px;
  padding-bottom: 74px;
  color: var(--ink);
  --mode-accent-local: #1d7b5a;
  --mode-field-border: #c7e4d5;
  --mode-soft-bg: #edf8f2;
}

.cpap-ps-hero {
  min-height: 0;
  box-shadow: none;
}

.vc-simv-environment {
  --mode-accent-local: #34516f;
  --mode-field-border: #c2ccda;
  --mode-soft-bg: #f2f5f9;
}

.vc-simv-hero {
  border-color: #c2ccda;
  background:
    linear-gradient(180deg, rgba(248, 250, 252, 0.95), rgba(241, 245, 249, 0.98)),
    #ffffff;
  box-shadow: none;
}

.vc-simv-settings .cpap-monitor-control {
  border-color: #c2ccda;
  background: #f8fafc;
}

.vc-simv-reminder {
  display: grid;
  gap: 8px;
  padding: 12px;
  border: 1px solid #c2ccda;
  border-radius: 8px;
  background: #f8fafc;
  color: #1f2937;
  font-size: var(--text-sm);
  line-height: 1.35;
}

.vc-simv-reminder strong {
  color: #2b4260;
}

.vc-simv-native-summary {
  margin-top: 2px;
}

.vc-simv-native-summary summary {
  cursor: pointer;
  color: #2b4260;
  font-weight: 750;
}

.vc-simv-native-summary summary::marker {
  color: #3c7499;
}

.vc-simv-inline-help {
  appearance: none;
  min-height: 0;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  color: inherit;
  font: inherit;
  font-weight: inherit;
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 2px;
  cursor: pointer;
}

.cpap-application-step .vc-simv-inline-help {
  min-height: 0;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  color: inherit;
  font-size: inherit;
}

.vc-simv-application-note {
  margin-top: 6px;
  color: #475569;
  font-size: var(--text-sm);
  font-weight: 400;
  line-height: 1.35;
}

.vc-simv-settings-block {
  display: grid;
  gap: 10px;
  padding: 10px;
  border: 1px solid #c2ccda;
  border-radius: 8px;
  background: #f8fafc;
}

.vc-simv-parameter-grid {
  display: grid;
  gap: 8px;
}

.vc-simv-settings-overview {
  grid-template-columns: 1fr;
}

.cpap-settings-overview.vc-simv-settings-overview {
  grid-template-columns: 1fr;
}

.cpap-settings-overview.vc-simv-settings-overview > * {
  grid-column: 1 / -1;
}

.vc-simv-setting-row {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
  min-width: 0;
}

.vc-simv-setting-row > .cpap-setting-pill {
  width: 100%;
  height: 100%;
}

@media (max-width: 420px) {
  .vc-simv-setting-row {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

.vc-simv-parameter-grid .cpap-setting-pill.warn {
  border-color: #f59e0b;
  background: #fff7ed;
}

.vc-simv-parameter-grid .cpap-setting-pill.fixed-vc {
  min-height: 82px;
  overflow: visible;
  gap: 5px;
  border-color: #c2ccda;
  background: linear-gradient(180deg, #f8fafc 0%, #eef2f7 100%);
  align-content: center;
}

.vc-simv-parameter-grid .cpap-setting-pill.fixed-vc strong {
  color: #34516f;
}

.vc-simv-parameter-grid .cpap-setting-pill.fixed-vc small {
  display: block;
  line-height: 1.18;
  white-space: normal;
}

.vc-simv-niv-device-box {
  display: grid;
  gap: 8px;
  padding: 10px;
  border: 1px solid #c2ccda;
  border-radius: 8px;
  background: #f8fafc;
}

.vc-simv-inline-panel {
  display: grid;
  gap: 10px;
  padding: 10px;
  border: 1px solid #c2ccda;
  border-radius: 8px;
  background: #f8fafc;
}

.vc-simv-settings-block h4 {
  margin: 0;
  color: #2b4260;
  font-size: var(--text-sm);
}

.vc-simv-settings-notes {
  display: grid;
  gap: 4px;
  color: #334155;
  font-size: var(--text-sm);
  font-weight: 400;
  line-height: 1.32;
}

.vc-simv-settings-notes p {
  margin: 0;
}

.vc-simv-pause-vent {
  width: 100%;
  min-height: 48px;
  border: 2px solid #3c7499;
  border-radius: 8px;
  background: rgba(231, 242, 251, 0.82);
  color: #12385a;
  font-size: var(--text-sm);
  font-weight: 1000;
  animation: vcSimvPauseCrystalBurst 1s infinite;
}

.vc-simv-pause-vent.active {
  border-color: #1f2937;
  background: #ef4444;
  color: #111827;
  animation: vcSimvPauseRedBurst 1s infinite;
}

.cpap-ps-concept .cpap-context-grid span {
  border-color: var(--mode-field-border);
  background: #ffffff;
}

.cpap-ps-concept .cpap-context-grid strong {
  display: block;
  margin-bottom: 4px;
  color: #1d7b5a;
}

.cpap-ps-param-strip {
  grid-template-columns: repeat(6, minmax(0, 1fr));
}

.vc-simv-param-strip {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.vc-simv-param-strip .niv-dual {
  background: linear-gradient(135deg, #dff7ed 0 50%, #fff1d6 50% 100%);
  border-color: #8bc8b7;
  color: #153f3d;
}

.cpap-ps-settings-overview {
  grid-template-columns: minmax(0, 0.82fr) minmax(0, 1.18fr);
}

.cpap-ps-settings-overview .wide {
  grid-column: span 1;
}

.cpap-ps-settings-overview .compact {
  min-height: 50px;
  gap: 2px;
  padding: 7px 8px;
}

.cpap-ps-settings-overview .compact span,
.cpap-ps-settings-overview .compact small {
  font-size: 0.62rem;
  line-height: 1.05;
}

.cpap-ps-settings-overview .compact strong {
  font-size: 0.84rem;
  line-height: 1.05;
}

.cpap-ps-settings-overview .compact.mode strong {
  font-size: 0.78rem;
}

.cpap-setting-pill.ps {
  overflow: hidden;
  border-color: #b7e4d1;
  background: linear-gradient(180deg, #ffffff 0%, #edf8f2 100%);
}

.cpap-setting-pill.ps::before {
  content: "";
  position: absolute;
  inset: auto 0 0 0;
  height: 0%;
  background: linear-gradient(180deg, rgba(183, 228, 209, 0.2), rgba(29, 123, 90, 0.3));
  animation: cpapPsFill 9s ease-in-out infinite;
}

.cpap-setting-pill.ps.on {
  border-color: #1d7b5a;
  background: #e6f6ee;
}

.cpap-setting-pill.ps.warn {
  border-color: #f59e0b;
  background: #fff7ed;
}

.cpap-setting-pill.trigger {
  border-color: #b7d8ee;
  background: linear-gradient(180deg, #ffffff 0%, #eef8fc 100%);
}

.cpap-setting-pill.trigger strong {
  color: #2f6f95;
}

@media (max-width: 760px) {
  .cpap-ps-settings-overview {
    grid-template-columns: minmax(0, 0.82fr) minmax(0, 1.18fr);
  }

  .cpap-settings-overview.vc-simv-settings-overview {
    grid-template-columns: 1fr;
  }
}

.cpap-ps-hint {
  margin: 0;
  color: #334155;
  font-size: var(--text-sm);
  font-weight: 400;
  line-height: 1.35;
}

.cpap-environment .cpap-ps-hint {
  font-weight: 400;
}

.cpap-environment .cpap-help-text.no-bold,
.cpap-help-text.no-bold {
  font-weight: 400;
}

.cpap-ps-info-fold {
  margin: -2px 0 2px 10px;
  color: #334155;
}

.cpap-ps-info-fold summary {
  cursor: pointer;
  color: #334155;
  font-size: var(--text-sm);
  font-weight: 400;
  line-height: 1.25;
}

.cpap-ps-info-fold p {
  margin: 6px 0 0 12px;
}

.cpap-ps-vte-slider {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 76px;
  gap: 8px;
  align-items: end;
}

.cpap-ps-vte-track {
  position: relative;
  display: grid;
  align-items: end;
  padding-top: 54px;
}

.cpap-ps-vte-slider input {
  width: 100%;
}

.cpap-ps-vte-slider output {
  color: var(--mode-accent-local, var(--accent-strong));
  font-weight: 900;
  text-align: right;
}

.cpap-ps-vte-marker {
  position: absolute;
  top: 0;
  transform: translateX(-50%);
  display: grid;
  gap: 1px;
  min-width: 54px;
  max-width: 76px;
  color: #1d7b5a;
  font-size: 0.62rem;
  font-weight: 850;
  text-align: center;
  pointer-events: none;
  line-height: 1.05;
}

.cpap-ps-vte-marker::after {
  content: "";
  justify-self: center;
  width: 2px;
  height: 26px;
  background: rgba(29, 123, 90, 0.7);
}

.cpap-ps-vte-marker.vt8 {
  color: #2f6f95;
}

.cpap-ps-vte-marker.vt8::after {
  background: rgba(47, 111, 149, 0.7);
}

.cpap-ps-vte-marker.stagger-low {
  top: 24px;
  transform: translateX(-82%);
}

.cpap-ps-vte-marker.stagger-high {
  top: -4px;
  transform: translateX(-18%);
}

.cpap-ps-vte-marker.edge-left {
  transform: translateX(0);
  text-align: left;
}

.cpap-ps-vte-marker.edge-right {
  transform: translateX(-100%);
  text-align: right;
}

.cpap-ps-vte-marker.stagger-low.edge-left {
  transform: translateX(0);
}

.cpap-ps-vte-marker.stagger-high.edge-right {
  transform: translateX(-100%);
}

.cpap-ps-vte-marker i {
  font-style: normal;
  color: #334155;
}

.guided-steps {
  display: grid;
  gap: 6px;
  margin: 0;
  padding-left: 22px;
  color: #174a3a;
  font-weight: 750;
}

.assisted-adjustment-card {
  margin-top: 10px;
}

.assisted-adjustment-card .field-group {
  margin-top: 8px;
}

.assisted-adjustment-card select {
  width: 100%;
  min-height: 42px;
  border: 1px solid var(--mode-field-border, var(--line));
  border-radius: 8px;
  background: #ffffff;
  color: var(--ink);
  font-weight: 750;
}

.cpap-ps-bottom-nav {
  grid-template-columns: repeat(6, minmax(0, 1fr));
}

.inline-info-button.dark {
  border-color: #2b4260;
  background: #07111f;
  color: #8fd1ff;
}

.pcr-mode-button.is-flashing-fast {
  animation: pcrFastFlash 0.45s infinite;
}

.pcr-mode-button.is-flashing-slow {
  animation: pcrSlowBlueFlash 1.4s infinite;
}

.pcr-mode-config {
  display: grid;
  gap: 2px;
  padding: 8px 10px;
  border: 1px solid #3a6f9f;
  border-radius: 8px;
  background: #0d2742;
  color: #8fd1ff;
  font-size: var(--text-sm);
  font-weight: 900;
  text-align: center;
}

.pcr-mode-config span {
  color: #b8cbe2;
  font-size: var(--text-xs);
}

.pcr-thoracostomy-alert {
  width: 100%;
  min-height: 46px;
  border: 2px solid #000;
  border-radius: 8px;
  background: #111;
  color: #fff;
  font-size: var(--text-md);
  font-weight: 1000;
  text-align: center;
  animation: pcrRedBlackFlash 0.42s infinite;
}

.pcr-thoracostomy-alert[hidden] {
  display: none;
}

.pcr-thoracostomy-alert.is-done {
  border-color: var(--orange);
  background: #fff3e8;
  color: var(--orange);
  animation: none;
}

.pcr-cycle-warning {
  position: fixed;
  top: 50%;
  left: 50%;
  z-index: 90;
  display: grid;
  grid-template-columns: minmax(64px, max-content) 1fr;
  gap: 8px;
  align-items: center;
  width: min(92vw, 520px);
  padding: 14px;
  border-radius: 8px;
  background: #fff8e8;
  color: #8a5a00;
  box-shadow: var(--shadow);
  transform: translate(-50%, -50%);
  animation: pcrPrechargePulse 1.4s infinite;
}

.pcr-cycle-warning[hidden] {
  display: none;
}

.pcr-cycle-warning.precharge-phase {
  background: #fff8e8;
  color: #8a5a00;
  animation: pcrPrechargePulse 1.4s infinite;
}

.pcr-cycle-warning.stop-phase {
  background: #fff1f1;
  color: var(--red);
  animation: pcrStopFlash 0.65s infinite;
}

.pcr-cycle-warning.stop-phase > #pcr-cycle-countdown {
  background: var(--red);
  color: #111;
}

.pcr-cycle-warning #pcr-cycle-countdown {
  display: grid;
  place-items: center;
  min-width: 64px;
  min-height: 36px;
  padding: 0 8px;
  border-radius: 999px;
  background: var(--accent-strong);
  color: #fff;
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
  line-height: 1;
}

.pcr-cycle-warning #pcr-cycle-message {
  display: grid;
  gap: 2px;
  align-items: center;
  min-width: 0;
  font-weight: 800;
  white-space: normal;
  line-height: 1.08;
}

.pcr-cycle-warning.stop-phase #pcr-cycle-message {
  font-weight: 800;
}

.pcr-cycle-warning #pcr-cycle-message strong,
.pcr-cycle-warning #pcr-cycle-message span {
  display: block;
  white-space: nowrap;
  line-height: 1.02;
}

.pcr-cycle-warning #pcr-cycle-message strong {
  padding: 0;
  border-radius: 0;
  background: transparent;
  color: inherit;
  font-size: clamp(0.9rem, 3.5vw, 1.08rem);
}

.pcr-cycle-warning #pcr-cycle-message span {
  font-size: clamp(0.76rem, 3vw, 0.96rem);
}

@media (max-width: 520px) {
  .pcr-cycle-warning {
    grid-template-columns: minmax(62px, max-content) 1fr;
    gap: 6px;
    padding: 12px 10px;
  }

  .pcr-cycle-warning #pcr-cycle-message {
    font-size: clamp(0.72rem, 3.2vw, 0.92rem);
    letter-spacing: 0;
  }

  .pcr-cycle-warning #pcr-cycle-message strong {
    font-size: clamp(0.74rem, 3.55vw, 0.9rem);
  }

  .pcr-cycle-warning #pcr-cycle-message span {
    font-size: clamp(0.66rem, 3.05vw, 0.78rem);
  }
}

.pcr-checklist {
  grid-column: 1 / -1;
  display: grid;
  gap: 8px;
}

.pcr-checklist label.pcr-required-check::before {
  content: "➜";
  position: absolute;
  left: 8px;
  color: var(--red);
  font-weight: 900;
  animation: requiredArrowBlink 0.8s infinite;
}

.pcr-checklist button {
  display: flex;
  gap: 8px;
  align-items: center;
  justify-content: center;
  min-height: 52px;
  padding: 12px 10px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  color: var(--text);
  font-size: var(--text-sm);
  font-weight: 800;
  line-height: 1.1;
  text-align: center;
  cursor: pointer;
}

.pcr-checklist button:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.pcr-checklist button.is-checked {
  border-color: var(--green);
  background: #e8f7ee;
  color: #166534;
}

.pcr-checklist button.pcr-required-check {
  position: relative;
  padding-left: 32px;
  opacity: 1;
}

.pcr-checklist button.pcr-required-check::before {
  content: ">";
  position: absolute;
  left: 8px;
  color: var(--red);
  font-weight: 900;
  animation: requiredArrowBlink 0.8s infinite;
}

@keyframes pcrPulse {
  0%, 100% {
    box-shadow: 0 0 0 0 rgba(23, 105, 170, 0.2);
  }
  50% {
    box-shadow: 0 0 0 8px rgba(23, 105, 170, 0.08);
  }
}

@keyframes pcrPrechargePulse {
  0%, 100% {
    box-shadow: 0 0 0 0 rgba(167, 107, 0, 0.2);
  }
  50% {
    box-shadow: 0 0 0 8px rgba(167, 107, 0, 0.08);
  }
}

@keyframes pcrStopFlash {
  0%, 100% {
    background: #fff1f1;
    box-shadow: 0 0 0 0 rgba(185, 28, 28, 0.22);
  }
  50% {
    background: #e7f2fb;
    box-shadow: 0 0 0 8px rgba(23, 105, 170, 0.14);
  }
}

@keyframes pcrFastFlash {
  0%, 100% {
    filter: brightness(1);
    box-shadow: 0 0 0 0 rgba(23, 105, 170, 0.25);
  }
  50% {
    filter: brightness(1.25);
    box-shadow: 0 0 0 7px rgba(23, 105, 170, 0.1);
  }
}

@keyframes pcrSlowBlueFlash {
  0%, 100% {
    background: #e7f2fb;
    box-shadow: 0 0 0 0 rgba(23, 105, 170, 0.18);
  }
  50% {
    background: #cfe8fb;
    box-shadow: 0 0 0 8px rgba(23, 105, 170, 0.08);
  }
}

@keyframes roscOrangePulse {
  0%, 100% {
    box-shadow: 0 0 0 0 rgba(247, 178, 103, 0.12);
    filter: brightness(0.96);
  }
  50% {
    box-shadow: 0 0 0 7px rgba(247, 178, 103, 0.22);
    filter: brightness(1.12);
  }
}

@keyframes roscDangerPulse {
  0%, 100% {
    transform: scale(1);
    box-shadow: 0 0 0 0 rgba(220, 38, 38, 0.35);
    filter: brightness(0.96);
  }
  50% {
    transform: scale(1.01);
    box-shadow: 0 0 0 7px rgba(220, 38, 38, 0.2);
    filter: brightness(1.16);
  }
}

@keyframes roscClinicalDoubleBurst {
  0%, 100% {
    box-shadow: 0 0 0 rgba(245, 158, 11, 0);
    filter: brightness(1);
  }
  8%, 18% {
    box-shadow: 0 0 14px rgba(245, 158, 11, 0.58);
    filter: brightness(1.08);
  }
  13%, 23% {
    box-shadow: 0 0 2px rgba(245, 158, 11, 0.22);
    filter: brightness(1);
  }
}

@keyframes pcrBlackBurst {
  0%, 18%, 36%, 100% {
    background: #ffffff;
    border-color: #000;
    box-shadow: 0 0 0 0 rgba(0, 0, 0, 0.35);
    color: #000;
  }
  8%, 26% {
    background: #111827;
    border-color: #000;
    box-shadow: 0 0 0 8px rgba(0, 0, 0, 0.16);
    color: #fff;
  }
}

@keyframes pcrRedBlackFlash {
  0%, 100% {
    background: #000;
    border-color: #000;
    color: #fff;
    box-shadow: 0 0 0 0 rgba(185, 28, 28, 0.3);
  }
  50% {
    background: var(--red);
    border-color: #000;
    color: #fff;
    box-shadow: 0 0 0 8px rgba(185, 28, 28, 0.18);
  }
}

@keyframes cpapBlueDoubleBurst {
  0%, 18%, 36%, 100% {
    box-shadow: 0 0 0 0 rgba(60, 116, 153, 0);
    filter: brightness(1);
  }
  9%, 27% {
    box-shadow: 0 0 0 7px rgba(60, 116, 153, 0.2);
    filter: brightness(1.08);
  }
}

@keyframes cpapYellowSlowPulse {
  0%, 100% {
    box-shadow: 0 0 0 0 rgba(244, 197, 107, 0.08);
  }
  50% {
    box-shadow: 0 0 0 8px rgba(244, 197, 107, 0.24);
  }
}

@keyframes cpapBlueSlowPulse {
  0%, 100% {
    text-shadow: 0 0 0 rgba(60, 116, 153, 0);
    filter: brightness(1);
  }
  50% {
    text-shadow: 0 0 10px rgba(60, 116, 153, 0.35);
    filter: brightness(1.08);
  }
}

@keyframes cpapNivOffCycle {
  0%, 100% {
    border-color: #f4c56b;
    box-shadow: 0 0 0 0 rgba(244, 197, 107, 0.08);
  }
  50% {
    border-color: var(--red);
    box-shadow: 0 0 0 6px rgba(185, 28, 28, 0.08);
  }
}

@keyframes cpapNivOnPulse {
  0%, 100% {
    box-shadow: 0 0 0 0 rgba(22, 101, 52, 0.08);
  }
  50% {
    box-shadow: 0 0 0 7px rgba(22, 101, 52, 0.16);
  }
}

@keyframes vcSimvPauseCrystalBurst {
  0%, 18%, 36%, 100% {
    box-shadow: 0 0 0 0 rgba(60, 116, 153, 0);
    background: rgba(231, 242, 251, 0.82);
  }
  8%, 26%, 44% {
    box-shadow: 0 0 0 7px rgba(60, 116, 153, 0.2);
    background: rgba(207, 232, 247, 0.96);
  }
}

@keyframes vcSimvPauseRedBurst {
  0%, 18%, 36%, 100% {
    box-shadow: 0 0 0 0 rgba(239, 68, 68, 0);
  }
  8%, 26%, 44% {
    box-shadow: 0 0 0 8px rgba(239, 68, 68, 0.32);
  }
}

@keyframes cpapPeepFill {
  0%, 12% {
    height: 0%;
  }
  70%, 100% {
    height: 100%;
  }
}

@keyframes cpapPsFill {
  0%, 18% {
    height: 0%;
  }
  76%, 100% {
    height: 100%;
  }
}

@keyframes cpapPeepContraindicatedFlash {
  0%, 100% {
    background: #fff1f1;
    box-shadow: 0 0 0 0 rgba(185, 28, 28, 0.08);
  }
  50% {
    background: #ffe0e0;
    box-shadow: 0 0 0 7px rgba(185, 28, 28, 0.16);
  }
}

@keyframes cpapVteLowPulse {
  0%, 100% {
    box-shadow: 0 0 0 0 rgba(185, 28, 28, 0.08);
  }
  50% {
    box-shadow: 0 0 0 7px rgba(185, 28, 28, 0.18);
  }
}

@keyframes requiredArrowBlink {
  0%, 100% {
    opacity: 0.15;
    transform: translateX(0);
  }
  50% {
    opacity: 1;
    transform: translateX(4px);
  }
}

.priority-banner {
  display: grid;
  gap: 2px;
  margin-top: 4px;
  padding: 5px 8px;
  border-radius: 0 0 8px 8px;
  color: #fff;
}

.priority-banner[hidden] {
  display: none;
}

.priority-banner span {
  font-size: var(--text-xs);
  font-weight: 900;
}

.priority-banner strong {
  font-size: var(--text-sm);
  line-height: 1.12;
}

.priority-banner.stable {
  background: var(--green);
}

.priority-banner.watch {
  background: var(--yellow);
}

.priority-banner.high {
  background: var(--orange);
}

.priority-banner.critical {
  background: var(--red);
}

.screen-shell {
  display: grid;
  gap: 12px;
  padding: 12px;
}

.screen-progress {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  color: var(--muted);
}

.screen-progress span {
  flex: 0 0 auto;
  white-space: nowrap;
}

.screen-progress strong {
  min-width: 0;
  color: var(--ink);
  text-align: right;
  overflow-wrap: anywhere;
}

.screen-content {
  padding: 14px;
  border-radius: 8px;
}

.section-title {
  margin-bottom: 12px;
}

.control-grid {
  display: grid;
  gap: 12px;
}

.choice-grid,
.toggle-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

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

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

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

.str-trend-grid .choice-card {
  min-height: 62px;
  padding: 7px;
}

.str-trend-grid .choice-card span {
  font-size: var(--text-sm);
  line-height: 1.12;
}

.str-trend-grid .choice-card small {
  font-size: var(--text-xs);
  line-height: 1.12;
}

.compact-indicator-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.phenotype-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 6px;
}

.phenotype-grid .toggle-card {
  place-items: center;
  min-height: 44px;
  padding: 7px;
  text-align: center;
}

.phenotype-grid .toggle-card span {
  font-size: var(--text-sm);
  line-height: 1.08;
}

.phenotype-grid .toggle-card small {
  font-size: var(--text-xs);
  line-height: 1.08;
}

.phenotype-grid .toggle-card:last-child {
  grid-column: 1 / -1;
}

.phenotype-grid .phenotype-smoke {
  border-color: #cfd6dc;
  background: #f2f4f5;
}

.phenotype-grid .phenotype-smoke:has(input:checked) {
  border-color: #7b8794;
  background: #e5e9ec;
  color: #374151;
}

.phenotype-grid .phenotype-pregnant {
  border-color: #f4bfd4;
  background: #fff2f7;
}

.phenotype-grid .phenotype-pregnant:has(input:checked) {
  border-color: #d96c9b;
  background: #ffe1ec;
  color: #9d2f63;
}

.phenotype-grid .phenotype-pediatric {
  border-color: #f3d98b;
  background: #fff8df;
}

.phenotype-grid .phenotype-pediatric:has(input:checked) {
  border-color: #d7a900;
  background: #ffefb3;
  color: #7a5600;
}

.phenotype-grid .phenotype-obese {
  border-color: #d8c0a4;
  background: #f6eee6;
}

.phenotype-grid .phenotype-obese:has(input:checked) {
  border-color: #a66d3c;
  background: #ead7c4;
  color: #6f3f1d;
}

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

.cyanosis-grid .toggle-card {
  place-items: center;
  min-height: 42px;
  padding: 7px 5px;
  text-align: center;
}

.cyanosis-grid .toggle-card span {
  font-size: var(--text-sm);
  line-height: 1.05;
}

.air-entry-grid .choice-card {
  place-items: center;
  text-align: center;
}

.work-signs-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 6px;
}

.work-signs-grid .toggle-card {
  place-items: center;
  min-height: 46px;
  padding: 7px;
  text-align: center;
}

.work-signs-grid .toggle-card span {
  font-size: var(--text-sm);
  line-height: 1.08;
}

.work-signs-grid .toggle-card:last-child {
  grid-column: 1 / -1;
}

.choice-card,
.toggle-card {
  display: grid;
  gap: 4px;
  min-height: 56px;
  padding: 10px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #f9fcff;
}

.choice-card input,
.toggle-card input {
  position: absolute;
  opacity: 0;
}

.choice-card:has(input:checked),
.toggle-card:has(input:checked) {
  border-color: var(--accent);
  background: #e7f2fb;
  color: var(--accent-strong);
}

.choice-card span,
.toggle-card span {
  font-weight: 800;
}

.choice-card small,
.toggle-card small {
  color: var(--muted);
  font-weight: 650;
}

.compact-indicator-grid .toggle-card {
  min-height: 68px;
  padding: 7px 5px;
  text-align: center;
}

.compact-indicator-grid .toggle-card span {
  font-size: var(--text-sm);
  line-height: 1.12;
}

.compact-indicator-grid .toggle-card small {
  font-size: var(--text-xs);
  line-height: 1.15;
}

.support-indicators-none-button {
  width: 100%;
  min-height: 42px;
  margin-top: 8px;
  border: 1px solid #86c79d;
  border-radius: 8px;
  background: #fff;
  color: #166534;
  font-size: var(--text-sm);
  font-weight: 900;
  text-align: center;
}

.support-indicators-none-button.is-selected {
  border-width: 2px;
  background: #dcfce7;
  color: #14532d;
}

.step-lock-note {
  margin: 10px 0 0;
  padding: 9px 10px;
  border: 1px solid #f0c36a;
  border-radius: 8px;
  background: #fff8e8;
  color: #76520f;
  font-size: var(--text-sm);
  font-weight: 750;
}

.indicator-card.dark {
  border-color: #b9c2cc;
}

.indicator-card.dark span {
  color: #344252;
}

.indicator-card.blue {
  border-color: #a9cce8;
}

.indicator-card.blue span {
  color: var(--accent-strong);
}

.indicator-card.red {
  border-color: #efb4b4;
}

.indicator-card.red span {
  color: var(--red);
}

.indicator-card.orange {
  border-color: #f1bd9e;
}

.indicator-card.orange span {
  color: var(--orange);
}

.indicator-card.dark:has(input:checked) {
  border-color: #344252;
  background: #eef1f4;
}

.indicator-card.blue:has(input:checked) {
  border-color: var(--accent-strong);
  background: #e7f2fb;
}

.indicator-card.red:has(input:checked) {
  border-color: var(--red);
  background: #fff1f1;
}

.indicator-card.orange:has(input:checked) {
  border-color: var(--orange);
  background: #fff4ed;
}

.binary-card {
  min-height: 58px;
  padding: 8px;
  text-align: center;
}

.binary-card span {
  font-size: var(--text-md);
}

.binary-card.danger {
  border-color: #efb4b4;
}

.binary-card.danger span {
  color: var(--red);
}

.binary-card.danger:has(input:checked) {
  border-color: var(--red);
  background: #fff1f1;
}

.binary-card.no:has(input:checked) {
  border-color: var(--green);
  background: #eefaf2;
}

.sex-card {
  place-items: center;
  min-height: 82px;
  padding: 8px;
  text-align: center;
}

.sex-card .sex-icon {
  font-size: 2.3rem;
  line-height: 1;
}

.sex-card.male {
  border-color: #b8d7f0;
}

.sex-card.male .sex-icon,
.sex-card.male span:last-child {
  color: #1769aa;
}

.sex-card.female {
  border-color: #f4bfd4;
}

.sex-card.female .sex-icon,
.sex-card.female span:last-child {
  color: #c03f7b;
}

.sex-card.male:has(input:checked) {
  border-color: #1769aa;
  background: #e7f2fb;
}

.sex-card.female:has(input:checked) {
  border-color: #c03f7b;
  background: #fdebf3;
}

.inline-controls {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.inline-help {
  margin: 6px 0 8px;
  color: var(--muted);
  font-size: var(--text-xs);
  line-height: 1.32;
}

.evolution-trend-panel {
  display: grid;
  gap: 10px;
  padding: 10px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #f8fbff;
}

.section-title.compact h3 {
  margin: 0;
  font-size: var(--text-md);
}

.trend-chart-card {
  position: relative;
  display: grid;
  gap: 6px;
  overflow: hidden;
}

.trend-chart {
  width: 100%;
  min-height: 190px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
}

.trend-axis {
  stroke: #9fb4c8;
  stroke-width: 1;
}

.trend-tick,
.trend-y-label {
  fill: var(--muted);
  font-size: 0.58rem;
  font-weight: 800;
}

.trend-line {
  fill: none;
  stroke-width: 3;
  stroke-linecap: round;
  stroke-linejoin: round;
  pointer-events: none;
}

.trend-hit-line {
  stroke: transparent;
  stroke-width: 18;
  stroke-linecap: round;
  cursor: pointer;
}

.trend-dot {
  cursor: pointer;
}

.trend-line.sat {
  stroke: #11837a;
}

.trend-dot.sat {
  fill: #11837a;
}

.trend-line.fio2 {
  stroke: #6d5bd0;
}

.trend-dot.fio2 {
  fill: #6d5bd0;
}

.trend-line.etco2 {
  stroke: #111;
}

.trend-dot.etco2 {
  fill: #111;
}

.trend-line.rr {
  stroke: var(--accent-strong);
}

.trend-dot.rr {
  fill: var(--accent-strong);
}

.trend-line.rr {
  stroke-dasharray: 7 5;
}

.trend-line.peep {
  stroke: #1d7b5a;
}

.trend-dot.peep {
  fill: #1d7b5a;
}

.trend-line.vte {
  stroke: #3c7499;
}

.trend-dot.vte {
  fill: #3c7499;
}

.trend-line.ps {
  stroke: #0f766e;
}

.trend-dot.ps {
  fill: #0f766e;
}

.trend-line.trigger {
  stroke: #64748b;
  stroke-dasharray: 4 4;
}

.trend-dot.trigger {
  fill: #64748b;
}

.trend-legend {
  margin-top: 6px;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 5px;
}

.trend-legend span {
  min-height: 28px;
  display: grid;
  place-items: center;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  font-size: var(--text-xs);
  font-weight: 900;
}

.trend-legend .sat { color: #11837a; }
.trend-legend .fio2 { color: #6d5bd0; }
.trend-legend .etco2 { color: #111; }
.trend-legend .rr { color: var(--accent-strong); }
.trend-legend .peep { color: #1d7b5a; }
.trend-legend .vte { color: #3c7499; }
.trend-legend .ps { color: #0f766e; }
.trend-legend .trigger { color: #64748b; }

.trend-selection {
  margin: 0;
  padding: 7px 8px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #eef6fc;
  color: var(--accent-strong);
  font-size: var(--text-sm);
  font-weight: 900;
  text-align: center;
}

.trend-selection[hidden] {
  display: none;
}

.trend-legend-panel {
  display: grid;
  gap: 6px;
}

.trend-legend-panel summary {
  position: absolute;
  top: 8px;
  right: 8px;
  z-index: 2;
  width: 34px;
  min-height: 34px;
  display: flex;
  gap: 3px;
  align-items: center;
  place-items: center;
  justify-content: center;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: #fff;
  color: #3c7499;
  cursor: pointer;
  list-style: none;
  box-shadow: var(--shadow);
}

.trend-legend-panel summary span {
  width: 5px;
  height: 5px;
  border-radius: 999px;
  background: #3c7499;
}

.trend-legend-panel summary::-webkit-details-marker {
  display: none;
}

.trend-legend-panel[open] summary {
  border-color: #3c7499;
  background: #e7f2fb;
}

.str-marker.mild,
.str-marker.worse {
  fill: #7a4a2a;
}

.str-marker.severe {
  fill: var(--red);
}

.str-marker.improve {
  fill: var(--green);
}

.str-legend {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 5px;
}

.str-legend span {
  min-height: 26px;
  display: flex;
  gap: 6px;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  font-size: var(--text-xs);
  font-weight: 850;
  text-align: center;
}

.str-dot {
  width: 9px;
  height: 9px;
  flex: 0 0 auto;
  border-radius: 999px;
}

.str-dot.mild {
  background: #7a4a2a;
}

.str-dot.severe {
  background: var(--red);
}

.str-triangle {
  width: 0;
  height: 0;
  flex: 0 0 auto;
}

.str-triangle.up {
  border-right: 6px solid transparent;
  border-bottom: 11px solid #7a4a2a;
  border-left: 6px solid transparent;
}

.str-triangle.down {
  border-top: 11px solid var(--green);
  border-right: 6px solid transparent;
  border-left: 6px solid transparent;
}

.trend-form {
  display: grid;
  gap: 8px;
}

.trend-time-field,
.trend-time-auto {
  display: grid;
  gap: 5px;
}

.trend-time-auto {
  grid-template-columns: 1fr auto;
  align-items: center;
  padding: 8px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
}

.trend-time-auto span {
  color: var(--muted);
  font-size: var(--text-sm);
  font-weight: 800;
}

.trend-time-auto strong {
  color: var(--accent-strong);
  font-variant-numeric: tabular-nums;
}

.trend-summary {
  display: grid;
  gap: 4px;
  padding: 8px;
  border-radius: 8px;
  background: #eef6fc;
  color: #24384f;
  font-size: var(--text-sm);
}

.trend-summary p {
  margin: 0;
}

.trend-error {
  margin: 0;
  padding: 8px;
  border: 1px solid var(--yellow);
  border-radius: 8px;
  background: #fff8e8;
  color: #8a5a00;
  font-size: var(--text-sm);
  font-weight: 900;
  text-align: center;
}

.trend-error[hidden] {
  display: none;
}

.str-signs-control {
  display: grid;
  gap: 8px;
}

.pediatric-age-control .range-row {
  grid-template-columns: minmax(0, 1fr) minmax(86px, 36%);
}

.pediatric-age-control output {
  font-size: 0.78rem;
  line-height: 1.15;
}

.text-input,
select,
textarea {
  width: 100%;
  min-height: 44px;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 10px;
  background: #fff;
  color: var(--ink);
}

.hidden {
  display: none !important;
}

.clinical-output {
  position: fixed;
  right: 0;
  bottom: 66px;
  left: 0;
  z-index: 19;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 6px;
  max-width: 980px;
  margin: 0 auto;
  padding: 8px 12px;
  border-radius: 0;
  background: rgba(255, 255, 255, 0.96);
  backdrop-filter: blur(12px);
}

.clinical-output h2 {
  margin: 0;
  font-size: var(--text-xs);
  line-height: 1.05;
}

.output-stack {
  display: grid;
  gap: 8px;
}

.summary-section {
  position: relative;
  min-width: 0;
  min-height: 44px;
  padding: 8px 28px 8px 8px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #f9fcff;
  box-shadow: none;
}

.summary-section::after {
  content: attr(data-count);
  position: absolute;
  top: 5px;
  right: 6px;
  display: grid;
  place-items: center;
  min-width: 20px;
  height: 20px;
  padding: 0 5px;
  border-radius: 999px;
  background: var(--green);
  color: #fff;
  font-size: var(--text-xs);
  font-weight: 900;
}

.summary-section[data-level="watch"]::after {
  background: var(--yellow);
}

.summary-section[data-level="high"]::after {
  background: var(--orange);
}

.summary-section[data-level="critical"]::after {
  background: var(--red);
}

.summary-section[data-level="watch"] {
  border-color: var(--yellow);
}

.summary-section[data-level="high"] {
  border-color: var(--orange);
}

.summary-section[data-level="critical"] {
  border-color: var(--red);
}

.summary-section .output-stack {
  display: none;
}

.summary-section.expanded .output-stack {
  position: fixed;
  right: auto;
  bottom: 132px;
  left: 50%;
  z-index: 35;
  display: grid;
  width: min(calc(100vw - 24px), 520px);
  max-height: min(48vh, 420px);
  min-width: 0;
  overflow: auto;
  padding: 8px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--surface);
  box-shadow: var(--shadow);
  transform: translateX(-50%);
}

.summary-section:nth-child(1).expanded .output-stack {
  right: auto;
  left: 50%;
}

.summary-section:nth-child(3).expanded .output-stack {
  left: 50%;
}

.output-item {
  padding: 10px;
  border-radius: 8px;
  border-left: 5px solid var(--accent);
  background: #f7fbff;
  font-weight: 750;
}

.output-item.critical {
  border-color: var(--red);
  background: #fff1f1;
}

.output-item.high {
  border-color: var(--orange);
  background: #fff4ed;
}

.output-item.watch {
  border-color: var(--yellow);
  background: #fff8e8;
}

.output-item.stable {
  border-color: var(--green);
  background: #eefaf2;
}

.pneumothorax-warning {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 8px;
  border-color: var(--red);
  background: #1a0505;
  color: #fff;
  animation: pneumothoraxFlash 0.62s infinite alternate;
}

.priority-banner .pneumothorax-warning-text {
  color: #fff;
}

.pneumothorax-warning-text {
  font-weight: 950;
}

.pneumothorax-warning button,
.priority-banner [data-resolve-pneumothorax] {
  min-height: 30px;
  padding: 5px 8px;
  border: 1px solid #fff;
  border-radius: 8px;
  background: #fff;
  color: var(--red);
  font-size: var(--text-xs);
  font-weight: 900;
}

.ovas-immediate-warning {
  border-color: var(--red);
  background: #1a0505;
  color: #fff;
  font-weight: 950;
  letter-spacing: 0;
  text-align: center;
  animation: ovasImmediateFlash 0.72s infinite alternate;
}

@keyframes ovasImmediateFlash {
  from {
    background: #1a0505;
    box-shadow: 0 0 0 rgba(185, 28, 28, 0);
  }
  to {
    background: var(--red);
    box-shadow: 0 0 16px rgba(185, 28, 28, 0.65);
  }
}

@keyframes pneumothoraxFlash {
  from {
    background: #1a0505;
    box-shadow: 0 0 0 rgba(185, 28, 28, 0);
  }
  to {
    background: var(--red);
    box-shadow: 0 0 18px rgba(185, 28, 28, 0.75);
  }
}

.recommendation-actions {
  display: grid;
  grid-template-columns: minmax(0, 0.45fr) minmax(0, 1fr);
  gap: 6px;
  margin-top: 8px;
}

.recommendation-actions button {
  min-height: 32px;
  padding: 6px;
  border-radius: 8px;
  font-size: var(--text-xs);
}

.recommendation-actions button:first-child {
  background: var(--green);
}

.recommendation-actions button.danger-action {
  background: var(--red);
}

.recommendation-actions button:last-child {
  background: #e9eeee;
  color: var(--ink);
}

.acute-ovas-resolve {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 8px;
  background: #fff1f1;
}

.acute-ovas-resolve button {
  padding: 5px 8px;
  min-height: 32px;
  border-radius: 8px;
  background: var(--red);
  color: #fff;
  font-size: var(--text-xs);
  font-weight: 900;
  animation: ovasResolvePulse 0.72s infinite alternate;
}

@keyframes ovasResolvePulse {
  from {
    transform: scale(1);
    box-shadow: 0 0 0 rgba(185, 28, 28, 0);
  }
  to {
    transform: scale(1.04);
    box-shadow: 0 0 14px rgba(185, 28, 28, 0.55);
  }
}

.report-panel {
  display: grid;
  gap: 12px;
  width: 100%;
  max-width: 100%;
  min-width: 0;
  overflow-x: visible;
}

.transfer-signature-controls {
  display: grid;
  grid-template-columns: minmax(72px, 0.22fr) minmax(0, 1fr);
  gap: 8px;
  min-width: 0;
}

.transfer-signature-controls > * {
  min-width: 0;
}

.transfer-signature-controls .text-input {
  width: 100%;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
}

.transfer-report-actions {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 156px), 1fr));
  gap: 8px;
  width: 100%;
  max-width: 100%;
  min-width: 0;
}

.transfer-report-actions button {
  width: 100%;
  min-width: 0;
  min-height: 42px;
  white-space: normal;
  overflow-wrap: anywhere;
}

.transfer-report-actions .danger-soft-button {
  border: 1px solid rgba(185, 28, 28, 0.28);
  background: #fff1f1;
  color: #8f1111;
}

.transfer-report-actions .danger-soft-button[data-confirm="true"] {
  background: var(--red);
  color: #fff;
}

.report-preview {
  display: grid;
  gap: 14px;
  width: 100%;
  max-width: 100%;
  min-width: 0;
  box-sizing: border-box;
  padding: 18px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: #fff;
  color: #172033;
  user-select: text;
  overflow-x: hidden;
  overflow-wrap: anywhere;
  word-break: normal;
}

.clinical-report {
  display: grid;
  gap: 14px;
  width: 100%;
  max-width: 100%;
  min-width: 0;
  overflow-wrap: anywhere;
  word-break: normal;
  font-family: Arial, Helvetica, sans-serif;
  font-size: 0.92rem;
  line-height: 1.45;
}

.clinical-report p,
.clinical-report ul,
.clinical-report ol,
.clinical-report dl {
  margin: 0;
  max-width: 100%;
  min-width: 0;
  overflow-wrap: anywhere;
}

.clinical-report-header {
  display: grid;
  gap: 3px;
  padding-bottom: 10px;
  border-bottom: 2px solid #1f5f8b;
}

.clinical-report-header h2 {
  margin: 0;
  color: #123a5a;
  font-size: 1.45rem;
  letter-spacing: 0;
}

.clinical-report-kicker {
  color: #3c7499;
  font-size: 0.78rem;
  font-weight: 700;
  text-transform: uppercase;
}

.clinical-report-section {
  display: grid;
  gap: 8px;
  min-width: 0;
  max-width: 100%;
  padding: 10px 0;
  border-bottom: 1px solid #dce8f2;
  page-break-inside: avoid;
}

.clinical-report-section h3 {
  margin: 0;
  color: #123a5a;
  font-size: 1rem;
}

.clinical-report-section h4 {
  margin: 0 0 4px;
  color: #24465f;
  font-size: 0.88rem;
}

.clinical-report-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 6px 10px;
  min-width: 0;
  max-width: 100%;
}

.clinical-report-grid div {
  min-width: 0;
  padding: 6px 8px;
  border: 1px solid #e1edf5;
  border-radius: 4px;
  background: #fbfdff;
}

.clinical-report-grid dt {
  color: #5a6b78;
  font-size: 0.72rem;
  text-transform: uppercase;
}

.clinical-report-grid dd {
  margin: 2px 0 0;
  overflow-wrap: anywhere;
}

.clinical-report-columns {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  min-width: 0;
  max-width: 100%;
}

.clinical-report-columns > *,
.clinical-report-section > *,
.clinical-report-grid > * {
  min-width: 0;
  max-width: 100%;
}

.clinical-report li {
  margin-bottom: 3px;
}

.clinical-report-visual {
  page-break-inside: auto;
}

.report-signature {
  margin-top: 8px;
  padding-top: 8px;
  border-top: 1px solid var(--line);
}

.pdf-disclaimer {
  display: grid;
  gap: 6px;
  margin-top: 10px;
  padding: 10px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #f7fbff;
  font-size: 0.78rem;
  line-height: 1.35;
}

.pdf-disclaimer p,
.pdf-footer p {
  margin: 0;
}

.pdf-footer {
  display: grid;
  gap: 3px;
  max-width: 100%;
  min-width: 0;
  margin-top: 12px;
  padding-top: 10px;
  border-top: 1px solid var(--line);
  color: var(--muted);
  font-size: 0.78rem;
  text-align: center;
}

.pdf-footer img {
  width: min(100%, 620px);
  max-height: 120px;
  object-fit: contain;
}

.pdf-footer a {
  color: inherit;
  overflow-wrap: anywhere;
}

.pdf-footer-logo {
  display: block;
  justify-self: center;
}

.pdf-trend-section .trend-chart-card {
  page-break-inside: avoid;
  width: 100%;
  max-width: 100%;
  min-width: 0;
  overflow-x: auto;
  overflow-y: visible;
  -webkit-overflow-scrolling: touch;
}

.pdf-trend-section .trend-chart {
  display: block;
  width: 100%;
  max-width: 100%;
  min-height: 220px;
  height: auto;
}

.trend-legend.report-visible,
.str-legend.report-visible {
  display: grid;
  width: 100%;
  max-width: 100%;
  min-width: 0;
  overflow: visible;
}

.pdf-trend-section .trend-legend.report-visible {
  grid-template-columns: repeat(auto-fit, minmax(72px, 1fr));
}

.pdf-trend-section .str-legend.report-visible {
  grid-template-columns: repeat(auto-fit, minmax(132px, 1fr));
}

.pdf-trend-section .trend-legend.report-visible span,
.pdf-trend-section .str-legend.report-visible span {
  min-width: 0;
  white-space: normal;
  overflow-wrap: anywhere;
  text-align: center;
}

.evolution-table {
  width: 100%;
  max-width: 100%;
  min-width: 0;
  table-layout: fixed;
  border-collapse: collapse;
  font-size: 0.78rem;
}

.evolution-table th,
.evolution-table td {
  padding: 6px;
  border: 1px solid var(--line);
  text-align: left;
  overflow-wrap: anywhere;
  word-break: normal;
}

.evolution-table th {
  background: #eef6fc;
  color: var(--accent-strong);
}

.compact-report-table {
  display: grid;
  gap: 6px;
  min-width: 0;
  max-width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  page-break-inside: avoid;
}

.compact-report-table h3 {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  margin-bottom: 0;
}

.compact-report-table table {
  width: 100%;
  table-layout: fixed;
  border-collapse: collapse;
  font-size: clamp(0.52rem, 1.8vw, 0.68rem);
}

.compact-report-table th,
.compact-report-table td {
  padding: 4px 3px;
  border: 1px solid var(--line);
  text-align: left;
  vertical-align: top;
  overflow-wrap: anywhere;
}

.compact-report-table th {
  background: #eef6fc;
  color: var(--accent-strong);
}

.syndrome-timeline {
  display: grid;
  gap: 6px;
  min-width: 0;
  max-width: 100%;
  padding-left: 0;
  list-style: none;
  overflow-wrap: anywhere;
}

.syndrome-timeline li {
  min-width: 0;
  max-width: 100%;
  padding: 7px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #f9fcff;
  overflow-wrap: anywhere;
}

.timeline-list {
  display: grid;
  gap: 8px;
  min-width: 0;
  max-width: 100%;
  padding-left: 0;
  list-style: none;
  overflow-wrap: anywhere;
}

.timeline-list li {
  min-width: 0;
  max-width: 100%;
  padding: 8px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #f9fcff;
  overflow-wrap: anywhere;
}

.revenox-lite-bottom-nav {
  position: fixed;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 2147483000;
  display: grid !important;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
  max-width: 980px;
  margin: 0 auto;
  padding: 10px 12px calc(10px + env(safe-area-inset-bottom));
  padding: 10px 12px calc(10px + constant(safe-area-inset-bottom));
  background: rgba(255, 255, 255, 0.96);
  border-top: 1px solid var(--line);
  backdrop-filter: blur(12px);
  transform: translateZ(0);
}

.respira-app.vent-mode-active .revenox-lite-bottom-nav {
  z-index: 95;
}

.revenox-lite-bottom-nav button {
  min-width: 0;
  padding: 0 8px;
}

.revenox-lite-bottom-nav button:first-child,
.revenox-lite-bottom-nav button:nth-child(2) {
  background: #e9eeee;
  color: var(--ink);
}

dialog {
  width: min(92vw, 420px);
  max-height: 82vh;
  overflow: auto;
  border: 1px solid var(--line);
  border-radius: 8px;
  box-shadow: var(--shadow);
}

dialog::backdrop {
  background: rgba(0, 0, 0, 0.35);
}

.help-list {
  display: grid;
  gap: 10px;
  margin: 0 0 14px;
  padding-left: 18px;
  line-height: 1.38;
}

.help-list li {
  padding-left: 2px;
}

.help-error-contact {
  margin: 12px 0 0;
  padding-top: 10px;
  border-top: 1px solid var(--line);
  color: var(--muted);
  font-size: var(--text-sm);
  font-weight: 750;
}

.help-error-contact a {
  color: var(--accent-strong);
  overflow-wrap: anywhere;
}

@media (min-width: 820px) {
  .screen-shell {
    grid-template-columns: minmax(0, 1fr);
    align-items: start;
  }

  .screen-progress {
    grid-column: 1 / -1;
  }

  .metrics-grid.compact {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}

@media (max-width: 430px) {
  .brand-lockup {
    grid-template-columns: minmax(112px, 2fr) minmax(0, 2fr) minmax(36px, 1fr);
    column-gap: 6px;
  }

  .brand-left {
    font-size: clamp(0.52rem, 2.35vw, 0.64rem);
  }

  .brand-center-logo {
    max-height: 38px;
  }

  .brand-respira-icon {
    width: clamp(36px, 11vw, 46px);
    border-radius: 10px;
  }

  .pcr-header {
    grid-template-columns: minmax(78px, 1fr) auto auto auto;
    gap: 4px;
  }

  .pcr-header h2 {
    font-size: 0.82rem;
  }

  .pcr-header-clock {
    min-width: 56px;
    padding: 4px;
  }

  .pcr-header-clock strong {
    font-size: 0.84rem;
  }

  .pmd-info-button,
  .pcr-header-clock span {
    font-size: 0.62rem;
  }

  .pcr-header > .secondary-button {
    min-height: 38px;
    padding: 6px 8px;
    font-size: 0.74rem;
  }

  .clinical-hud {
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 3px;
  }

  .clinical-hud article {
    min-height: 42px;
    padding: 5px 2px;
  }

  .clinical-hud span {
    font-size: 0.58rem;
  }

  .clinical-hud strong {
    font-size: 0.7rem;
  }

  .choice-grid,
  .toggle-grid {
    grid-template-columns: 1fr;
  }

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

  .phenotype-grid .toggle-card:last-child {
    grid-column: 1 / -1;
  }

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

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

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

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

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

  .str-trend-grid .choice-card {
    min-height: 66px;
    padding: 6px;
  }

  .str-trend-grid .choice-card span {
    font-size: 0.76rem;
  }

  .str-trend-grid .choice-card small {
    font-size: 0.64rem;
  }

  .compact-indicator-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .compact-indicator-grid .toggle-card {
    min-height: 70px;
    padding: 6px 4px;
  }

  .compact-indicator-grid .toggle-card span {
    font-size: 0.76rem;
  }

  .compact-indicator-grid .toggle-card small {
    font-size: 0.64rem;
  }

  .sex-card {
    min-height: 76px;
  }

  .sex-card .sex-icon {
    font-size: 2rem;
  }

  .pediatric-age-control .range-row {
    grid-template-columns: 1fr;
  }

  .pediatric-age-control output {
    text-align: left;
  }

  .revenox-lite-bottom-nav {
    gap: 6px;
  }

  .revenox-lite-bottom-nav button {
    font-size: 0.8rem;
  }

  .pcr-rosc-grid,
  .pcr-rosc-option-grid {
    gap: 6px;
  }

  .pcr-rosc-card,
  .pcr-rosc-option-grid button,
  .pcr-rosc-binary button {
    min-height: 48px;
    padding: 7px 5px;
    font-size: 0.76rem;
    line-height: 1.12;
  }

  .mode-layout {
    grid-template-columns: 1fr;
    gap: 6px;
  }

  .mode-hero {
    min-height: 112px;
    padding: 14px;
  }

  .mode-hero h2 {
    font-size: 1.35rem;
  }

  .cpap-context-grid,
  .cpap-settings-grid,
  .cpap-monitor-grid,
  .cpap-two-columns,
  .cpap-safety-grid,
  .cpap-step-list,
  .cpap-quick-row {
    grid-template-columns: 1fr;
  }

  .cpap-bottom-nav {
    right: 0;
    bottom: 0;
    left: 0;
    gap: 8px;
    padding: 10px 12px calc(10px + env(safe-area-inset-bottom));
  }

  .cpap-bottom-nav button {
    min-height: 44px;
    padding: 0 8px;
    font-size: var(--text-sm);
    line-height: 1.1;
  }

  .cpap-monitor-chip-row.four {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .cpap-ps-bottom-nav {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .clinical-output {
    bottom: 62px;
    grid-template-columns: minmax(0, 1.2fr) minmax(54px, 0.72fr) minmax(0, 1.35fr);
    gap: 4px;
    padding: 6px 8px;
  }

  .summary-section {
    min-height: 42px;
    padding: 7px 26px 7px 6px;
  }

  .priority-summary,
  .recommendations-summary {
    padding-right: 30px;
  }

  .alerts-summary {
    padding-right: 22px;
  }

  .clinical-output h2 {
    font-size: 0.68rem;
  }

  .alerts-summary h2 {
    font-size: 0.62rem;
  }

  .summary-section::after {
    top: 4px;
    right: 4px;
    min-width: 18px;
    height: 18px;
    padding: 0 4px;
    font-size: 0.64rem;
  }

  .summary-section.expanded .output-stack {
    bottom: 124px;
    width: calc(100vw - 16px);
    max-height: 46vh;
  }

  .disclaimer-actions,
  .session-actions {
    grid-template-columns: 1fr;
  }

  .transfer-signature-controls {
    grid-template-columns: minmax(58px, 68px) minmax(0, 1fr);
  }

  .transfer-report-actions,
  .clinical-report-grid,
  .clinical-report-columns {
    grid-template-columns: 1fr;
  }

  .report-preview {
    padding: 12px;
  }

  .pdf-trend-section .trend-chart {
    min-height: 170px;
  }

  .pdf-trend-section .trend-legend.report-visible {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .pdf-trend-section .str-legend.report-visible {
    grid-template-columns: 1fr;
  }
}
