:root {
  --text: #000000;
  --grid: #d9d9d9;
  --blue: #063cff;
  --yellow: #ffff33;
  --cyan: #62f4ff;
  --low: #00d800;
  --high: #ff0000;
  --orange: #ff8a00;
}
* { box-sizing: border-box; }
body {
  margin: 0;
  background: #f2f2f2;
  color: var(--text);
  font-family: Arial, Helvetica, sans-serif;
}
.excel-page {
  padding: 10px;
  display: flex;
  justify-content: center;
}
.worksheet-frame {
  width: 1420px;
  min-height: 860px;
  background: #ffffff;
  border: 2px solid #000;
  padding: 14px 16px 12px;
  position: relative;
  box-shadow: 0 0 0 1px #888;
}
.main-title {
  width: 1110px; /* Align title width with the chart/graph column, not the full worksheet. */
  text-align: center;
  font-size: 29px;
  font-weight: 700;
  margin: 0 0 7px;
}
.top-strip.excel-top-layout {
  display: grid;
  grid-template-columns: 300px 205px 285px 226px;
  gap: 8px;
  align-items: center;
  margin-left: 49px;
  margin-bottom: 8px;
}
.ga-strip {
  display: grid;
  grid-template-columns: 80px 54px 48px 48px;
  gap: 8px;
  align-items: center;
  justify-content: start;
  padding: 10px 10px;
  min-height: 74px;
  border: 1px solid #999;
  background: #fff;
}
.ga-label {
  font-size: 15px;
  line-height: 1.15;
  text-align: right;
  font-weight: 700;
}
.ga-label span { font-size: 12px; font-weight: 400; }
.ga-cell {
  appearance: none;
  background: #fff;
  border: 3px solid #000;
  width: 100%;
  height: 34px;
  color: var(--blue);
  font-size: 22px;
  line-height: 1;
  text-align: center;
  text-align-last: center;
  font-weight: 700;
  padding: 0 2px;
  border-radius: 0;
}
.excel-grid.excel-grid-left-data {
  display: grid;
  grid-template-columns: 1110px 245px;
  gap: 16px;
  align-items: start;
}
.left-column {
  align-self: start;
  grid-column: 2;
  grid-row: 1;
}


.chart-wrap {
  width: 1110px;
  height: 610px;
  border-left: 0;
  border-bottom: 0;
  position: relative;
}
#chartCanvas {
  width: 100% !important;
  height: 100% !important;
}

.demo-note strong { font-weight: 700; }
.excel-box {
  border: 2px solid #000;
  background: #fff;
  padding: 5px 5px;
}
.light-box {
  border: 1px solid #bfbfbf;
  background: #fff;
  padding: 6px 7px;
  min-height: 52px;
}
.box-title {
  font-size: 16px;
  font-weight: 700;
  margin-bottom: 5px;
  color: #001a80;
}
.controls-box label, .xaxis-controls label {
  display: flex;
  align-items: center;
  gap: 5px;
  min-height: 22px;
  font-size: 13px;
  white-space: nowrap;
}
.controls-box label:has(input:checked), .xaxis-controls label:has(input:checked) { font-weight: 700; }
.control-label {
  font-size: 14px;
  font-weight: 700;
  margin-bottom: 3px;
  color: #001a80;
}
input[type="radio"] {
  width: 14px;
  height: 14px;
  margin: 0;
}
.legend-line {
  margin-left: auto;
  width: 54px;
  height: 0;
  border-top-style: solid;
  border-top-width: 6px;
  display: inline-block;
  flex: 0 0 54px;
}
.legend-line.low { border-top-color: var(--low); }
.legend-line.high { border-top-color: var(--high); }
.legend-line.dashed { border-top-style: dashed; border-top-width: 3px; }
.legend-box { padding-top: 5px; }
.legend-item {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  margin: 5px 0;
  line-height: 1.15;
}
.legend-dot {
  width: 11px;
  height: 11px;
  border-radius: 50%;
  border: 1px solid #000;
  display: inline-block;
  flex: 0 0 11px;
}
.legend-dot.tsb { background: var(--orange); }
.legend-dot.tcb { background: var(--blue); }
.data-panel { padding: 5px 5px 6px; height: 610px; }
.data-header-row {
  display: flex;
  align-items: center;
  gap: 4px;
  margin-bottom: 3px;
}
.data-header-row .box-title { margin: 0; font-size: 14px; white-space: nowrap; }
.button-row {
  margin-left: auto;
  display: flex;
  gap: 3px;
}
button {
  height: 21px;
  border: 1px solid #999;
  border-radius: 0;
  background: #e6e6e6;
  color: #000;
  font-weight: 700;
  padding: 0 4px;
  font-size: 9px;
  cursor: pointer;
}
button.secondary { background: #f0f0f0; color: #000; }
.data-table {
  width: 100%;
  table-layout: fixed;
  border-collapse: collapse;
}
.data-table th, .data-table td {
  border: 1px solid #bfbfbf;
  padding: 0 1px;
  font-size: 10px;
  line-height: 1.0;
  height: 17.9px;
  text-align: center;
}
.data-table th {
  background: #e7e6e6;
  font-weight: 700;
  height: 25px;
}
.data-table input {
  width: 100%;
  height: 17px;
  padding: 0 1px;
  border: 0;
  border-radius: 0;
  background: #ffffff;
  font-size: 10px;
  text-align: center;
}
.data-table input:focus {
  outline: 2px solid #1c61ff;
  outline-offset: -2px;
}
.data-table th:nth-child(1), .data-table td:nth-child(1) { width: 18px; }
.data-table th:nth-child(2), .data-table td:nth-child(2) { width: 42px; }
.data-table th:nth-child(3), .data-table td:nth-child(3) { width: 27px; }
.data-table th:nth-child(4), .data-table td:nth-child(4) { width: 34px; }
.data-table th:nth-child(5), .data-table td:nth-child(5) { width: 34px; }
.row-number { color: #000; background: #f7f7f7; }
.xaxis-controls {
  margin: 8px auto 0;
  width: 820px;
  min-height: 48px;
  display: grid;
  grid-template-columns: 130px 135px 125px 1fr;
  gap: 10px;
  align-items: center;
}
.xaxis-controls .control-label { margin: 0; }
@media (max-width: 1100px) {
  .worksheet-frame { width: 100%; overflow-x: auto; }
  .excel-grid.excel-grid-left-data { grid-template-columns: 1110px 245px; }
}
.guideline-box, .risk-box, .legend-box { min-height: 52px; padding-top: 5px; padding-bottom: 4px; }
.risk-box .legend-line { width: 48px; flex-basis: 48px; }
.xaxis-controls { background: #eeeeee !important; border: 1px solid #9d9d9d; }


/* v25 patient-data refinements */

/* Remove spinner/data selector controls from patient-data numeric boxes, including TSB/TcB. */
.patient-table input[type="number"]::-webkit-outer-spin-button,
.patient-table input[type="number"]::-webkit-inner-spin-button,
.patient-data input[type="number"]::-webkit-outer-spin-button,
.patient-data input[type="number"]::-webkit-inner-spin-button,
#patientData input[type="number"]::-webkit-outer-spin-button,
#patientData input[type="number"]::-webkit-inner-spin-button,
td input[type="number"]::-webkit-outer-spin-button,
td input[type="number"]::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

.patient-table input[type="number"],
.patient-data input[type="number"],
#patientData input[type="number"],
td input[type="number"] {
  -moz-appearance: textfield;
  appearance: textfield;
}

/* 10-second pending-sort visual cue. */
.pending-sort-row,
.pending-sort-row td,
tr.pending-sort-row td {
  background-color: #d9ecff !important;
}

.plain-header-note {
  font-weight: 400;
  font-style: normal;
  color: inherit;
}


/* v26 patient-data workflow */
.pending-sort-row td { background-color: #d9ecff !important; }
.plain-header-note { font-weight: 400; font-style: normal; color: inherit; font-size: 12px; }
#patientTable input[type="number"]::-webkit-outer-spin-button,
#patientTable input[type="number"]::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
#patientTable input[type="number"] { -moz-appearance: textfield; appearance: textfield; }


/* v28: Hours subnote under header, 2 points smaller than header text */



/* v34: plain subheaders under Age and Hours */


/* v34: highlight entire Patient Data row when any field in that row is active */



/* v36: header subnotes (days) and (≤168) same size and bold */
.header-subnote-bold {
  font-size: calc(1em - 0.5pt);
  font-weight: 700;
  font-style: normal;
  line-height: 1.0;
}


/* v37: blue fill for active Patient Data row data cells */




/* v38: active/delayed Patient Data row fill */





























/* v47: note lives inside chart area and is centered under the graph/X-axis area */
.chart-area .demo-note {
  width: calc(100% - 58px);
  max-width: calc(100% - 58px);
  box-sizing: border-box;
  margin: 16px 0 0 58px;
  border: none !important;
  padding: 0 4px;
  text-align: center;
  line-height: 1.25;
}

.chart-area 

.no-break {
  white-space: nowrap;
}


/* v49: blue fill for active/current Patient Data row */
#patientTable tbody tr.active-data-row > td {
  background-color: #d9ecff !important;
}
#patientTable tbody tr.active-data-row > td input {
  background-color: #d9ecff !important;
}


/* v50: Patient Data table without # column; 26 rows aligned to graph */
.data-panel {
  height: 100% !important;
}

.data-table {
  table-layout: fixed !important;
  width: 100% !important;
}

/* Four remaining columns fill the unchanged Patient Data object width */
.data-table th:nth-child(1),
.data-table td:nth-child(1) {
  width: 28% !important; /* Age */
}
.data-table th:nth-child(2),
.data-table td:nth-child(2) {
  width: 24% !important; /* Hours */
}
.data-table th:nth-child(3),
.data-table td:nth-child(3) {
  width: 24% !important; /* TSB */
}
.data-table th:nth-child(4),
.data-table td:nth-child(4) {
  width: 24% !important; /* TcB */
}

/* Slightly taller rows to balance 26 rows vertically */
.data-table th,
.data-table td {
  height: 18.6px !important;
  padding-top: 1px !important;
  padding-bottom: 1px !important;
}

/* Align Patient Data panel with graph vertically */
.left-column {
  align-self: stretch !important;
}
.excel-grid-left-data {
  align-items: stretch !important;
}








/* v53: Patient Data frame is positioned/sized by Chart.js plot area */
.data-panel {
  box-sizing: border-box !important;
  overflow: hidden !important;
  display: flex !important;
  flex-direction: column !important;
}

.data-table {
  table-layout: fixed !important;
  width: 100% !important;
  flex: 1 1 auto !important;
}

.data-table tbody {
  overflow: hidden !important;
}

.data-table th,
.data-table td {
  box-sizing: border-box !important;
  line-height: 1.05 !important;
}

/* v53: do not force Legend height; match via normal top-strip alignment */
.top-strip {
  align-items: stretch !important;
}

.top-strip .light-box,
.top-strip .controls-box,
.top-strip .legend-box,
.top-legend {
  align-self: stretch !important;
  height: auto !important;
  min-height: 0 !important;
  max-height: none !important;
}


/* v54: active Patient Data row fill support */
#patientTable tbody tr.active-data-row > td {
  background-color: #d9ecff !important;
}
#patientTable tbody tr.active-data-row > td input {
  background-color: #d9ecff !important;
}

/* remove grey borders from top boxes */
.light-box, .controls-box, .legend-box {
  border: none !important;
}

/* unified top strip border */


/* tighten risk line spacing */
.risk-line {
  margin-left: 6px !important;
}


/* v56: borders */
.data-panel {
  border: 2px solid #999 !important;
}

/* Top control strip is one bordered group sized by JS to chart X-axis width */
.top-strip {
  border: 2px solid #999 !important;
  padding: 6px !important;
  box-sizing: border-box !important;
  align-items: stretch !important;
}

/* Remove individual grey borders including GA Weeks/Days */
.top-strip .light-box,
.top-strip .controls-box,
.top-strip .legend-box,
.top-strip .ga-box,
.ga-box,
.ga-control,
.ga-panel {
  border: none !important;
  box-shadow: none !important;
}

/* Pull risk legend lines closer to text */
.risk-box label {
  display: flex !important;
  align-items: center !important;
  gap: 4px !important;
}

.risk-box .legend-line,
#riskLowLine,
#riskHighLine {
  margin-left: 4px !important;
}




/* v58: remove GA Weeks/Days frame completely */
.top-strip > :first-child,
.top-strip > :first-child.light-box,
.top-strip > :first-child.controls-box,
.ga-box,
.ga-panel,
.ga-control,
.ga-section,
.ga-input-box {
  border: none !important;
  outline: none !important;
  box-shadow: none !important;
  background-clip: padding-box !important;
}

/* v58: remove visual gridlines below Patient Data row 22'; v156: changed to n+18 */
#patientTable tbody tr:nth-child(n+18) td {
  border-left: none !important;
  border-right: none !important;
  border-top: none !important;
  border-bottom: none !important;
  background: transparent !important;
}
#patientTable tbody tr:nth-child(n+18) input {
  border: none !important;
  outline: none !important;
  box-shadow: none !important;
  background: transparent !important;
  color: transparent !important;
  pointer-events: none !important;
}

/* v58: lighter added borders */
.data-panel {
  border: 2px solid #999 !important;
}
.top-strip {
  border: 2px solid #999 !important;
  padding: 6px !important;
  box-sizing: border-box !important;
}

/* v58: exact two-line bottom note */
/* v59: bottom note lines fit within chart width */
/* v60: slightly larger bottom text */

/* v63: preserve v61 bottom note font size */
.demo-line {
  display: block;
  text-align: center !important;
  white-space: nowrap;
  font-size: 13.2px !important;
  line-height: 1.2 !important;
}


/* v65: fixed left anchor for Risk legend lines; radio/text layout unchanged */
.risk-box {
  position: relative !important;
}

.risk-box label {
  display: block !important;
  position: relative !important;
  padding-left: 0 !important;
  white-space: nowrap !important;
}

.risk-box .legend-line,
#riskLowLine,
#riskHighLine {
  position: absolute !important;
  left: 183px !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
}


/* v73: draw top-strip frame inside the object to prevent right-edge clipping */
.top-strip {
  border: none !important;
  box-shadow: inset 0 0 0 2px #999 !important;
  overflow: visible !important;
  box-sizing: border-box !important;
}

.current-axis-option {
  white-space: nowrap;
}

.current-axis-combo {
  position: relative;
  display: inline-flex;
  align-items: stretch;
  margin: 0 3px;
  vertical-align: middle;
}

.current-axis-days-input {
  width: 5.8em;
  height: 2.45em;
  min-height: 2.45em;
  font: inherit;
  font-weight: inherit;
  text-align: center;
  padding: 4px 8px;
  box-sizing: border-box;
  border: 1px solid #777;
  border-right: 0;
  border-radius: 3px 0 0 3px;
}

.current-axis-dropdown-button {
  width: 2.4em;
  height: 2.45em;
  min-height: 2.45em;
  font: inherit;
  font-weight: 700;
  line-height: 1;
  padding: 0;
  border: 1px solid #777;
  border-radius: 0 3px 3px 0;
  background: #f7f7f7;
  cursor: pointer;
}

.current-axis-dropdown {
  position: absolute;
  left: 0;
  top: auto;
  bottom: calc(100% + 2px);
  width: 8.2em;
  max-height: 18em;
  overflow-y: auto;
  z-index: 10000;
  background: #ffffff;
  border: 1px solid #777;
  box-shadow: 0 3px 8px rgba(0,0,0,0.25);
}

.current-axis-dropdown-item {
  display: block;
  width: 100%;
  padding: 5px 8px;
  text-align: center;
  font: inherit;
  border: 0;
  background: #ffffff;
  cursor: pointer;
}

.current-axis-dropdown-item:hover,
.current-axis-dropdown-item.selected {
  background: #dfefff;
}


/* v81: open the current-age day selector upward and center a wider X-axis panel under the graph's active area. */
.current-axis-dropdown {
  top: auto !important;
  bottom: calc(100% + 2px) !important;
}
.xaxis-controls {
  width: 820px !important;
  min-height: 48px !important;
  grid-template-columns: 130px 135px 125px 1fr !important;
  gap: 10px !important;
}

/* v82: center the X-axis control contents within a panel that is aligned to the chart X-axis. */
.xaxis-controls {
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  gap: 38px !important;
  width: auto !important;
  min-height: 48px !important;
  padding-left: 10px !important;
  padding-right: 10px !important;
}
.xaxis-controls .control-label,
.xaxis-controls label {
  flex: 0 0 auto !important;
}


/* v98: bottom demonstration note link styling */
.about-info-link,
.about-info-link:visited {
  color: #0057ff;
  text-decoration: underline;
  font-weight: 400;
}

.about-info-link:hover,
.about-info-link:active {
  color: #003cc0;
  text-decoration: underline;
}

/* v103: restore Patient Data header button proportions while allowing browser wrapping. */
.data-header-row .button-row {
  flex: 1 1 auto;
  min-width: 0;
  justify-content: flex-end;
}
.data-header-row .button-row button {
  white-space: nowrap;
  overflow: visible;
  text-overflow: clip;
  flex: 0 0 auto;
  height: 22px;
  line-height: 1.05;
  font-size: 9px;
  padding: 0 1px;
  letter-spacing: 0;
}
#loadDemoButton { width: 84px; }
#clearButton { width: 58px; }


/* v103/v8: scale the fixed Excel-like GUI as one unit for narrow desktop windows and phones. */
html, body {
  min-width: 0 !important;
  overflow: auto;
}
.excel-page {
  min-width: 0 !important;
  align-items: flex-start;
}
.autoscale-shell {
  position: relative;
  flex: 0 0 auto;
}
@media (max-width: 1100px) {
  .worksheet-frame {
    width: 1420px !important;
    overflow: visible !important;
  }
}

/* v103/v9: in-page About/Information panel for mobile-safe display. */
.about-modal-overlay {
  position: fixed;
  inset: 0;
  z-index: 99999;
  display: none;
  align-items: center;
  justify-content: center;
  box-sizing: border-box;
  padding: 14px;
  background: rgba(0, 0, 0, 0.28);
  overflow: auto;
  -webkit-overflow-scrolling: touch;
}
.about-modal-panel {
  width: min(760px, 96vw);
  max-height: 92vh;
  box-sizing: border-box;
  padding: 30px 42px 18px;
  background: #fff;
  color: #000;
  border: 1px solid #777;
  box-shadow: 0 4px 18px rgba(0, 0, 0, 0.30);
  overflow: auto;
  -webkit-overflow-scrolling: touch;
  font-family: "Times New Roman", Times, serif;
}
.about-modal-content {
  font-size: 18px;
  line-height: 1.35;
}
.about-modal-content p {
  margin: 0 0 24px;
}
.about-modal-content .about-title {
  margin-bottom: 18px;
  font-size: 19px;
}
.about-modal-content ul {
  margin: -16px 0 24px 26px;
  padding-left: 22px;
}
.about-modal-content li {
  margin: 0 0 10px;
  padding-left: 8px;
}
.about-modal-button-row {
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px solid #ddd;
  text-align: right;
  font-family: Arial, Helvetica, sans-serif;
}
.about-modal-button-row button {
  min-width: 82px;
  height: 28px;
  font-size: 13px;
  font-weight: 700;
  border: 1px solid #999;
  background: #e6e6e6;
  cursor: pointer;
}
@media (max-width: 700px), (max-height: 520px) {
  .about-modal-overlay {
    align-items: flex-start;
    justify-content: center;
    padding: 8px;
  }
  .about-modal-panel {
    width: 98vw;
    max-height: 96vh;
    padding: 16px 18px 12px;
  }
  .about-modal-content {
    font-size: 15px;
    line-height: 1.28;
  }
  .about-modal-content .about-title {
    font-size: 16px;
    margin-bottom: 12px;
  }
  .about-modal-content p {
    margin-bottom: 14px;
  }
  .about-modal-content ul {
    margin: -8px 0 14px 18px;
    padding-left: 18px;
  }
  .about-modal-content li {
    margin-bottom: 7px;
    padding-left: 4px;
  }
}


/* v103/v10: make the Information panel open already fit-to-phone. */
.about-modal-panel {
  transform-origin: top center;
}
@media (max-width: 700px), (max-height: 520px) {
  .about-modal-overlay {
    align-items: flex-start !important;
    justify-content: center !important;
    padding: 4px !important;
  }
  .about-modal-panel {
    width: 96vw !important;
    max-width: 96vw !important;
    max-height: none !important;
    padding: 10px 12px 8px !important;
    overflow: visible !important;
  }
  .about-modal-content {
    font-size: 11.5px !important;
    line-height: 1.16 !important;
  }
  .about-modal-content .about-title {
    font-size: 12.5px !important;
    margin-bottom: 7px !important;
  }
  .about-modal-content p {
    margin-bottom: 8px !important;
  }
  .about-modal-content ul {
    margin: -4px 0 8px 12px !important;
    padding-left: 12px !important;
  }
  .about-modal-content li {
    margin-bottom: 4px !important;
    padding-left: 2px !important;
  }
  .about-modal-button-row {
    position: relative !important;
    margin-top: 4px !important;
    padding-top: 5px !important;
    text-align: right !important;
  }
  .about-copyright {
    position: absolute !important;
    left: 0;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    text-align: center;
    font-size: 10px;
    color: #777;
    pointer-events: none;
  }
  .about-modal-button-row button {
    height: 22px !important;
    min-width: 62px !important;
    font-size: 10.5px !important;
  }
}


/* v84: top control frame aligns with the chart box below. */
.top-strip.excel-top-layout {
  margin-left: 49px !important;
  width: 1052px !important;
  max-width: 1052px !important;
}




/* v156: stable 18 visible Patient Data rows; rows 19+ are hidden. */
#patientTable tbody tr:nth-child(-n+18) {
  display: table-row !important;
}
#patientTable tbody tr:nth-child(-n+18) td {
  border: 1px solid #bfbfbf !important;
  background: #fff;
}
#patientTable tbody tr:nth-child(-n+18) input {
  color: #000 !important;
  pointer-events: auto !important;
  background: #fff !important;
}
#patientTable tbody tr:nth-child(n+18) {
  display: none !important;
}
#patientTable tbody tr:nth-child(n+18) td,
#patientTable tbody tr:nth-child(n+18) input {
  border: none !important;
  outline: none !important;
  box-shadow: none !important;
  background: transparent !important;
  color: transparent !important;
  pointer-events: none !important;
}

/* Release 0.2: clinical access / registration overlay */
.clinical-access-overlay {
  position: fixed;
  inset: 0;
  z-index: 100000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 18px;
  background: rgba(0,0,0,0.38);
  box-sizing: border-box;
}
.clinical-access-overlay.hidden {
  display: none !important;
}
.clinical-access-card {
  width: min(680px, 96vw);
  max-height: 94vh;
  overflow: auto;
  background: #fff;
  border: 2px solid #333;
  box-shadow: 0 6px 22px rgba(0,0,0,0.35);
  padding: 24px 30px 22px;
  font-family: Arial, Helvetica, sans-serif;
  color: #000;
}
.clinical-access-card h1 {
  margin: 0 0 12px;
  font-size: 24px;
  text-align: center;
}
.clinical-access-card h2 {
  margin: 0 0 10px;
  font-size: 17px;
  color: #001a80;
}
.clinical-access-intro {
  margin: 0 0 18px;
  font-size: 14px;
  line-height: 1.35;
}
.clinical-access-section {
  border: 1px solid #bfbfbf;
  padding: 14px;
  margin: 10px 0;
}
.clinical-access-label {
  display: block;
  margin-bottom: 5px;
  font-weight: 700;
  font-size: 13px;
}
.clinical-code-row {
  display: flex;
  gap: 10px;
  align-items: center;
}
.clinical-code-input {
  width: 112px;
  height: 34px;
  border: 2px solid #000;
  text-align: center;
  font-size: 22px;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
}
.clinical-access-button {
  min-width: 110px;
  height: 32px;
  padding: 0 14px;
  font-size: 13px;
  font-weight: 700;
  border: 1px solid #777;
  background: #e6e6e6;
  cursor: pointer;
}
.clinical-access-button:disabled {
  opacity: 0.55;
  cursor: default;
}
.clinical-access-divider {
  margin: 14px 0 8px;
  text-align: center;
  font-weight: 700;
  color: #333;
}
.clinical-role-list label {
  display: block;
  margin: 7px 0;
  font-size: 14px;
}
.clinical-role-other {
  width: 230px;
  height: 24px;
  margin-left: 5px;
  font-size: 13px;
}
.clinical-tos-row {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  margin: 12px 0;
  font-size: 14px;
  line-height: 1.3;
}
.clinical-register-button {
  min-width: 205px;
}
.clinical-access-message {
  margin-top: 12px;
  min-height: 22px;
  font-size: 14px;
  line-height: 1.35;
  text-align: center;
}
.clinical-access-message.error {
  color: #b00000;
  font-weight: 700;
}
.clinical-access-message.success {
  color: #004a00;
  font-weight: 700;
}
.clinical-user-code-display {
  display: inline-block;
  margin: 4px 0;
  padding: 4px 10px;
  border: 2px solid #000;
  font-size: 24px;
  letter-spacing: 2px;
  background: #ffffcc;
}
@media (max-width: 700px), (max-height: 520px) {
  .clinical-access-card {
    padding: 14px 16px 12px;
  }
  .clinical-access-card h1 {
    font-size: 19px;
  }
  .clinical-access-intro,
  .clinical-role-list label,
  .clinical-tos-row,
  .clinical-access-message {
    font-size: 12.5px;
  }
  .clinical-code-row {
    flex-wrap: wrap;
  }
}


/* Release 0.3e: refined clinical workspace layout per Excel reference.
   - GA Range radio buttons sit under GA Weeks/Days with no label, aligned with second top-control radio row.
   - Age Calculator top/bottom aligns with the top control frame and uses the 3-row Excel layout.
   - Patient Data frame top/bottom aligns with the graph frame and shows 17 equal-height rows without scrolling.
*/

/* Top control strip: fixed frame above graph. */
.top-strip.excel-top-layout {
  height: 74px !important;
  min-height: 74px !important;
  width: 1052px !important;
  max-width: 1052px !important;
  margin-left: 49px !important;
  margin-bottom: 8px !important;
  grid-template-columns: 300px 205px 285px 226px !important;
  gap: 8px !important;
  padding: 4px 6px !important;
  align-items: stretch !important;
  box-sizing: border-box !important;
  overflow: visible !important;
}
.top-strip .guideline-box,
.top-strip .risk-box,
.top-strip .legend-box,
.top-strip .light-box {
  height: 62px !important;
  min-height: 62px !important;
  max-height: 62px !important;
  padding-top: 3px !important;
  padding-bottom: 3px !important;
  box-sizing: border-box !important;
  overflow: visible !important;
}

/* GA Weeks/Days with GA Range below, aligned with Exchange/High-risk row. */
.clinical-ga-combined {
  height: 62px !important;
  min-height: 62px !important;
  max-height: 62px !important;
  padding: 3px 6px !important;
  box-sizing: border-box !important;
  display: grid !important;
  grid-template-columns: 80px 54px 48px 48px !important;
  grid-template-rows: 30px 24px !important;
  column-gap: 8px !important;
  row-gap: 0 !important;
  align-items: center !important;
  overflow: visible !important;
}
.clinical-ga-combined .ga-label { font-size: 13px !important; line-height: 1.05 !important; }
.clinical-ga-combined .ga-label span { font-size: 11px !important; }
.clinical-ga-combined .ga-cell {
  height: 28px !important;
  font-size: 18px !important;
  border-width: 2px !important;
}
.clinical-ga-combined .ga-range-box {
  grid-column: 1 / -1 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: 10px !important;
  padding: 0 !important;
  margin: 4px 0 0 0 !important;
  white-space: nowrap !important;
  font-size: 12px !important;
  line-height: 1 !important;
}
.clinical-ga-combined .ga-range-box .control-label { display: none !important; }
.clinical-ga-combined .ga-range-box label {
  display: inline-flex !important;
  align-items: center !important;
  gap: 4px !important;
  min-height: 18px !important;
  margin: 0 !important;
  font-size: 12px !important;
  white-space: nowrap !important;
}
.clinical-ga-combined .ga-range-box input[type="radio"] {
  width: 14px !important;
  height: 14px !important;
}
.ga-cell-disabled { background: #e7e6e6 !important; color: #777 !important; }

/* Match top control text proportions. */
.guideline-box .control-label,
.risk-box .control-label,
.legend-box .box-title { font-size: 13px !important; margin-bottom: 2px !important; }
.guideline-box label,
.risk-box label { min-height: 18px !important; font-size: 12px !important; }
.legend-item { margin: 4px 0 !important; font-size: 11px !important; }
.risk-box .legend-line,
#riskLowLine,
#riskHighLine { left: 178px !important; }

/* Right-side clinical column: preserves original graph-aligned Patient Data position. */
.clinical-left-column {
  align-self: start !important;
  position: relative !important;
  grid-column: 2 !important;
  grid-row: 1 !important;
}
.clinical-side-panel {
  position: relative !important;
  width: 245px !important;
  height: 610px !important;
  min-height: 610px !important;
  max-height: 610px !important;
}

/* Age Calculator: top/bottom aligned with the top control frame; no header; three rows. */
.age-calculator {
  position: absolute !important;
  left: 0 !important;
  right: 0 !important;
  top: -82px !important;
  height: 74px !important;
  min-height: 74px !important;
  max-height: 74px !important;
  box-sizing: border-box !important;
  margin: 0 !important;
  padding: 6px 6px !important;
  border: 2px solid #999 !important;
  background: #fff !important;
  overflow: visible !important;
}
.age-calc-title { display: none !important; }
.age-calc-grid {
  display: grid !important;
  grid-template-columns: 1fr !important;
  grid-template-rows: 19px 19px 19px !important;
  gap: 2px !important;
  align-items: center !important;
}
.age-calc-row {
  display: grid !important;
  grid-template-columns: 64px 1fr 58px !important;
  gap: 4px !important;
  align-items: center !important;
  min-height: 19px !important;
}
.age-calc-row-final { grid-template-columns: 64px 48px 34px 78px !important; }
.age-calc-label {
  font-size: 13px !important;
  font-weight: 700 !important;
  line-height: 1 !important;
  white-space: nowrap !important;
  text-align: right !important;
}
.age-calc-grid input {
  width: 100% !important;
  height: 18px !important;
  min-height: 18px !important;
  box-sizing: border-box !important;
  border: 1px solid #999 !important;
  font-size: 11px !important;
  padding: 0 2px !important;
  background: #fff !important;
}
#calculatedAgeDays {
  text-align: center !important;
  font-weight: 700 !important;
  color: #063cff !important;
}
.age-calc-unit {
  font-size: 12px !important;
  font-weight: 700 !important;
  line-height: 1 !important;
  white-space: nowrap !important;
}
#createAgeRecordButton {
  width: 100% !important;
  height: 20px !important;
  min-height: 20px !important;
  font-size: 8.5px !important;
  line-height: 1 !important;
  padding: 0 1px !important;
  white-space: nowrap !important;
}
.age-calc-message {
  position: absolute !important;
  left: 0 !important;
  right: 0 !important;
  top: 76px !important;
  min-height: 10px !important;
  margin: 0 !important;
  font-size: 8px !important;
  line-height: 1 !important;
  background: transparent !important;
}
.age-calc-message.error { color: #b00000 !important; font-weight: 700 !important; }
.age-calc-message.success { color: #004a00 !important; font-weight: 700 !important; }

/* Patient Data frame: exactly aligned with graph frame. */
.clinical-data-panel,
.data-panel.clinical-data-panel {
  position: relative !important;
  top: 0 !important;
  height: 610px !important;
  min-height: 610px !important;
  max-height: 610px !important;
  margin: 0 !important;
  padding: 5px !important;
  border: 2px solid #999 !important;
  box-sizing: border-box !important;
  display: flex !important;
  flex-direction: column !important;
  overflow: hidden !important;
  background: #fff !important;
}
.clinical-data-title-row {
  flex: 0 0 22px !important;
  height: 22px !important;
  min-height: 22px !important;
  margin: 0 0 4px !important;
  justify-content: space-between !important;
}
.clinical-current-user {
  font-size: 9px !important;
  text-align: right !important;
  white-space: nowrap !important;
}
.patient-table-scroll {
  flex: 1 1 auto !important;
  height: auto !important;
  min-height: 0 !important;
  max-height: none !important;
  overflow-y: hidden !important;
}
#patientTable tbody tr:nth-child(-n+17) { display: table-row !important; }
#patientTable tbody tr:nth-child(n+18) { display: none !important; }
#patientTable tbody tr:nth-child(-n+17) td,
#patientTable tbody tr:nth-child(-n+17) input {
  box-sizing: border-box !important;
}

/* Buttons below/outside Patient Data frame. */
.clinical-data-button-row {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 4px !important;
  margin-top: 6px !important;
}
.clinical-data-button-row button {
  height: 23px !important;
  font-size: 8.5px !important;
  padding: 0 2px !important;
  white-space: nowrap !important;
}

.clinical-remember-row {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  margin: 8px 0 2px;
  font-size: 13px;
  line-height: 1.25;
}
.clinical-storage-note {
  margin: 0 0 10px 24px;
  font-size: 12px;
  line-height: 1.25;
  color: #333;
}


/* Release 0.3f: final layout refinements from user feedback.
   - GA Range radio buttons: no label, same font as top-control radio labels, All aligned with GA Weeks select box.
   - Patient Data/User Code typography and 17 equal rows.
   - Clinical action button sizing refinements.
*/
.clinical-ga-combined .ga-range-box {
  margin-top: 3px !important;
  margin-left: 88px !important; /* align All radio with left edge of GA Weeks select box */
  gap: 13px !important;
  font-size: 12px !important;
}
.clinical-ga-combined .ga-range-box .control-label,
.clinical-ga-combined .ga-range-title,
.clinical-ga-combined .ga-range-label-title {
  display: none !important;
}
.clinical-ga-combined .ga-range-box label {
  font-size: 12px !important;
  font-weight: 400 !important;
  min-height: 18px !important;
  line-height: 1 !important;
}
.clinical-ga-combined .ga-range-box label:has(input:checked) {
  font-weight: 700 !important;
}

.clinical-current-user {
  font-size: 12px !important;
  font-weight: 700 !important;
  color: #001a80 !important;
}

.clinical-data-panel,
.data-panel.clinical-data-panel {
  height: 610px !important;
  min-height: 610px !important;
  max-height: 610px !important;
}
.clinical-data-title-row {
  flex: 0 0 24px !important;
  height: 24px !important;
  min-height: 24px !important;
  margin-bottom: 3px !important;
}
.patient-table-scroll {
  flex: 1 1 auto !important;
  min-height: 0 !important;
  overflow: hidden !important;
}
#patientTable {
  height: 100% !important;
  table-layout: fixed !important;
  border-collapse: collapse !important;
}
#patientTable thead tr,
#patientTable thead th {
  height: 28px !important;
  min-height: 28px !important;
  max-height: 28px !important;
}
#patientTable tbody tr:nth-child(-n+17) {
  display: table-row !important;
}
#patientTable tbody tr:nth-child(n+18) {
  display: none !important;
}

.clinical-data-button-row {
  grid-template-columns: 1fr 1fr !important;
  gap: 4px !important;
  margin-top: 6px !important;
}
.clinical-data-button-row button {
  width: 100% !important;
  min-width: 0 !important;
  box-sizing: border-box !important;
  white-space: nowrap !important;
}
#storedRecordsButton,
#saveDataButton {
  height: 27px !important;
  min-height: 27px !important;
  font-size: 10px !important;
  font-weight: 700 !important;
}
#removePatientButton,
#clearButton {
  height: 21px !important;
  min-height: 21px !important;
  font-size: 8.5px !important;
  font-weight: 700 !important;
}

/* Release 0.3g: targeted layout corrections.
   - GA Range aligns under GA Weeks/Days: All begins at GA Weeks box; ≥35 weeks ends at Days box.
   - Patient Data frame uses original graph-aligned height and 17 equal data rows.
   - Age Calculator date/time controls use black text; date is narrower and time is wider.
*/
.clinical-ga-combined .ga-range-box {
  grid-column: 1 / -1 !important;
  margin-left: 88px !important;              /* left edge of GA Weeks select */
  width: 166px !important;                   /* right edge aligned to Days select */
  max-width: 166px !important;
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  gap: 0 !important;
  font-size: 12px !important;
  line-height: 1 !important;
  padding: 0 !important;
}
.clinical-ga-combined .ga-range-box label {
  font-size: 12px !important;
  line-height: 1 !important;
  font-weight: 400 !important;
  gap: 3px !important;
  min-height: 18px !important;
  padding: 0 !important;
  margin: 0 !important;
  white-space: nowrap !important;
}
.clinical-ga-combined .ga-range-box label:has(input:checked) { font-weight: 700 !important; }
.clinical-ga-combined .ga-range-box label:last-child { text-align: right !important; }

.age-calc-row {
  grid-template-columns: 58px 102px 68px !important;
  gap: 4px !important;
}
.age-calc-row-final {
  grid-template-columns: 58px 48px 38px 90px !important;
}
.age-calc-grid input,
.age-calc-grid input[type="date"],
.age-calc-grid input[type="time"] {
  color: #000 !important;
  -webkit-text-fill-color: #000 !important;
  opacity: 1 !important;
  font-size: 11px !important;
}
.age-calc-grid input[type="date"] { min-width: 0 !important; }
.age-calc-grid input[type="time"] { min-width: 0 !important; }

.clinical-left-column,
.left-column.clinical-left-column {
  align-self: start !important;
  grid-column: 2 !important;
  grid-row: 1 !important;
}
.clinical-side-panel {
  height: 610px !important;
  min-height: 610px !important;
  max-height: 610px !important;
}
.clinical-data-panel,
.data-panel.clinical-data-panel {
  top: 0 !important;
  height: 610px !important;
  min-height: 610px !important;
  max-height: 610px !important;
  margin-top: 0 !important;
  margin-bottom: 0 !important;
  overflow: hidden !important;
}
#patientTable tbody tr:nth-child(-n+17),
#patientTable tbody tr:nth-child(-n+17) td,
#patientTable tbody tr:nth-child(-n+17) input {
  height: 31px !important;
  min-height: 31px !important;
  max-height: 31px !important;
}
#patientTable tbody tr:nth-child(-n+17) td {
  padding-top: 0 !important;
  padding-bottom: 0 !important;
  line-height: 1.05 !important;
}
#patientTable tbody tr:nth-child(-n+17) input {
  height: 29px !important;
  min-height: 29px !important;
  max-height: 29px !important;
  line-height: 1.05 !important;
}


/* Release 0.3h: restore demo top-control proportions and refine clinical layout.
   Based on Object sizes.pdf: demo top object height was 1.15 in; new object was 1.01 in.
*/
.top-strip.excel-top-layout {
  height: 84px !important;
  min-height: 84px !important;
  max-height: 84px !important;
  padding: 6px !important;
  margin-bottom: 8px !important;
}
.top-strip .guideline-box,
.top-strip .risk-box,
.top-strip .legend-box,
.top-strip .light-box {
  height: 72px !important;
  min-height: 72px !important;
  max-height: 72px !important;
  padding-top: 5px !important;
  padding-bottom: 5px !important;
}
.clinical-ga-combined {
  height: 72px !important;
  min-height: 72px !important;
  max-height: 72px !important;
  grid-template-rows: 38px 26px !important;
  padding: 5px 6px !important;
}
.clinical-ga-combined .ga-label { font-size: 15px !important; line-height: 1.1 !important; }
.clinical-ga-combined .ga-label span { font-size: 12px !important; }
.clinical-ga-combined .ga-cell {
  height: 34px !important;
  font-size: 22px !important;
  border-width: 3px !important;
}
.guideline-box .control-label,
.risk-box .control-label,
.legend-box .box-title {
  font-size: 16px !important;
  margin-bottom: 5px !important;
}
.guideline-box label,
.risk-box label {
  min-height: 22px !important;
  font-size: 13px !important;
}
.legend-item {
  margin: 5px 0 !important;
  font-size: 12px !important;
}
.risk-box .legend-line,
#riskLowLine,
#riskHighLine { left: 183px !important; }

/* GA range fits between GA Weeks and Days controls using shorter labels. */
.clinical-ga-combined .ga-range-box {
  grid-column: 1 / -1 !important;
  margin-left: 88px !important;
  width: 166px !important;
  max-width: 166px !important;
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  padding: 0 !important;
  gap: 0 !important;
  font-size: 13px !important;
  line-height: 1 !important;
}
.clinical-ga-combined .ga-range-box label {
  font-size: 13px !important;
  font-weight: 400 !important;
  min-height: 20px !important;
  line-height: 1 !important;
  gap: 3px !important;
  padding: 0 !important;
  margin: 0 !important;
  white-space: nowrap !important;
}
.clinical-ga-combined .ga-range-box input[type="radio"] {
  width: 14px !important;
  height: 14px !important;
}

/* Age calculator: same height as top strip, wider usable fields, no default-looking grey text. */
.age-calculator {
  top: -92px !important;
  height: 84px !important;
  min-height: 84px !important;
  max-height: 84px !important;
  padding: 7px 5px !important;
}
.age-calc-grid {
  grid-template-rows: 22px 22px 22px !important;
  gap: 2px !important;
}
.age-calc-row {
  grid-template-columns: 52px 88px 84px !important;
  gap: 5px !important;
  min-height: 22px !important;
}
.age-calc-row-final {
  grid-template-columns: 52px 48px 38px 84px !important;
  gap: 4px !important;
}
.age-calc-label {
  font-size: 13px !important;
  font-weight: 400 !important;
  text-align: right !important;
  line-height: 1 !important;
}
.age-calc-grid input,
.age-calc-grid input[type="date"],
.age-calc-grid input[type="time"] {
  height: 21px !important;
  min-height: 21px !important;
  max-height: 21px !important;
  font-size: 12px !important;
  color: #000 !important;
  -webkit-text-fill-color: #000 !important;
  background: #fff !important;
  opacity: 1 !important;
  padding: 0 2px !important;
}
.age-calc-unit { font-size: 12px !important; font-weight: 400 !important; }
#createAgeRecordButton {
  height: 22px !important;
  min-height: 22px !important;
  max-height: 22px !important;
  font-size: 8.5px !important;
  padding: 0 1px !important;
  width: 100% !important;
  overflow: hidden !important;
}
.age-calc-message { top: 86px !important; }

/* Restore Patient Data to demo-like graph-frame alignment. The JS also enforces this. */
.clinical-side-panel {
  position: relative !important;
  height: 610px !important;
  min-height: 610px !important;
  max-height: 610px !important;
}
.clinical-data-panel,
.data-panel.clinical-data-panel {
  position: absolute !important;
  left: 0 !important;
  right: 0 !important;
  top: 0 !important;
  bottom: 0 !important;
  height: auto !important;
  min-height: 0 !important;
  max-height: none !important;
}
.clinical-data-button-row {
  position: absolute !important;
  left: 0 !important;
  right: 0 !important;
  top: 616px !important;
  margin-top: 0 !important;
}


/* Release 0.3i: requested layout refinements. */
/* GA Range: move left, spread labels, and align final label to Days field right edge. */
.clinical-ga-combined .ga-range-box {
  margin-left: 56px !important;      /* All radio under the "k" in Weeks */
  width: 198px !important;           /* span to the right edge of Days select */
  max-width: 198px !important;
  justify-content: space-between !important;
  font-size: 13px !important;
}
.clinical-ga-combined .ga-range-box label {
  font-size: 13px !important;
  gap: 4px !important;
}
.clinical-ga-combined .ga-range-box label:last-child {
  text-align: right !important;
}

/* Legend label font should match the other radio-button labels in the top object. */
.legend-item,
.legend-item span {
  font-size: 13px !important;
  line-height: 1.15 !important;
}

/* Age Calculator: no apparent default time; narrower time fields; more internal spacing. */
.age-calculator {
  padding-left: 7px !important;
  padding-right: 7px !important;
}
.age-calc-row {
  grid-template-columns: 48px 94px 72px !important;
  gap: 7px !important;
}
.age-calc-row-final {
  grid-template-columns: 48px 54px 42px 82px !important;
  gap: 5px !important;
}
.age-calc-label {
  font-weight: 400 !important;
  text-align: right !important;
}
.age-calc-grid input,
.age-calc-grid input[type="date"],
.age-calc-grid input[type="text"] {
  padding-left: 4px !important;
  padding-right: 4px !important;
}
#dobTime,
#dataTime {
  width: 72px !important;
  max-width: 72px !important;
}
#createAgeRecordButton {
  font-size: 8px !important;
}

/* Patient Data: restore demo-style vertical position and height relative to graph plot frame. */
.clinical-data-panel,
.data-panel.clinical-data-panel {
  top: 9px !important;
  bottom: auto !important;
  height: 552px !important;
  min-height: 552px !important;
  max-height: 552px !important;
}
.clinical-data-button-row {
  top: 567px !important;
}


/* Release 0.3j: targeted layout refinements after 0.3i.
   - GA Range spacing and alignment.
   - Top radio/legend row icon vertical centering.
   - Age Calculator label/date/time/button fit.
   - Patient Data 17-row fit inside graph-aligned frame.
*/
.clinical-ga-combined .ga-range-box {
  margin-left: 34px !important;
  gap: 20px !important;
  font-size: 12px !important;
}
.clinical-ga-combined .ga-range-box label {
  font-size: 12px !important;
  gap: 3px !important;
}

.guideline-box,
.risk-box,
.legend-box {
  display: grid !important;
  grid-template-rows: 18px 20px 20px !important;
  align-content: center !important;
  row-gap: 1px !important;
}
.guideline-box .control-label,
.risk-box .control-label,
.legend-box .box-title {
  align-self: end !important;
}
.guideline-box label,
.risk-box label,
.legend-item {
  display: flex !important;
  align-items: center !important;
  min-height: 20px !important;
  height: 20px !important;
  line-height: 1.05 !important;
  margin-top: 0 !important;
  margin-bottom: 0 !important;
}
.guideline-box input[type="radio"],
.risk-box input[type="radio"],
.legend-dot {
  align-self: center !important;
  flex: 0 0 auto !important;
}
.legend-item { font-size: 12px !important; }

.age-calculator {
  padding-left: 7px !important;
  padding-right: 7px !important;
}
.age-calc-grid {
  grid-template-rows: 19px 19px 19px !important;
  gap: 2px !important;
}
.age-calc-row {
  grid-template-columns: 58px 98px 54px !important;
  column-gap: 6px !important;
}
.age-calc-row-final {
  grid-template-columns: 58px 46px 43px 68px !important;
  column-gap: 4px !important;
}
.age-calc-label {
  text-align: right !important;
  font-weight: 400 !important;
  padding-right: 2px !important;
}
.age-calc-grid input {
  padding-left: 4px !important;
  padding-right: 4px !important;
}
#dobTime,
#dataTime {
  width: 54px !important;
  max-width: 54px !important;
}
#createAgeRecordButton {
  width: 68px !important;
  max-width: 68px !important;
  min-width: 68px !important;
  box-sizing: border-box !important;
  font-size: 8px !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}

.clinical-data-title-row {
  flex: 0 0 20px !important;
  height: 20px !important;
  min-height: 20px !important;
  margin-bottom: 2px !important;
}
.patient-table-scroll {
  overflow: hidden !important;
}
.data-table th {
  height: 23px !important;
  min-height: 23px !important;
  max-height: 23px !important;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
  line-height: 1.0 !important;
}
#patientTable tbody tr:nth-child(-n+17) td {
  padding-top: 0 !important;
  padding-bottom: 0 !important;
  line-height: 1.0 !important;
}
#patientTable tbody tr:nth-child(-n+17) input {
  padding-top: 0 !important;
  padding-bottom: 0 !important;
  line-height: 1.0 !important;
}

/* Release 0.3k: alignment correction based on Alignment.pdf.
   - Center top-row radio buttons / risk lines / legend dots on two shared row centerlines.
   - Preserve correct Patient Data frame alignment while reducing row height so 17 rows display.
   - Refine Age Calculator label/field/button alignment.
*/

/* Top-control two-row alignment */
.guideline-box,
.risk-box,
.legend-box {
  display: grid !important;
  grid-template-rows: 24px 22px 22px !important;
  align-content: center !important;
  row-gap: 1px !important;
  padding-top: 3px !important;
  padding-bottom: 3px !important;
}
.guideline-box .control-label,
.risk-box .control-label,
.legend-box .box-title {
  align-self: center !important;
  margin: 0 !important;
  line-height: 1.05 !important;
}
.guideline-box label,
.risk-box label,
.legend-item {
  display: flex !important;
  align-items: center !important;
  height: 22px !important;
  min-height: 22px !important;
  max-height: 22px !important;
  margin: 0 !important;
  line-height: 1.05 !important;
  box-sizing: border-box !important;
}
.guideline-box input[type="radio"],
.risk-box input[type="radio"],
.legend-dot {
  align-self: center !important;
  flex: 0 0 auto !important;
  margin-top: 0 !important;
  margin-bottom: 0 !important;
}
.risk-box .legend-line,
#riskLowLine,
#riskHighLine {
  top: 50% !important;
  transform: translateY(-50%) !important;
}
.legend-item,
.legend-item span {
  font-size: 13px !important;
}

/* GA Range spacing retained from 0.3j with compact labels. */
.clinical-ga-combined .ga-range-box {
  margin-left: 34px !important;
  gap: 20px !important;
  font-size: 12px !important;
}
.clinical-ga-combined .ga-range-box label {
  font-size: 12px !important;
  gap: 3px !important;
}

/* Age Calculator: label alignment and contained Create Record button. */
.age-calc-row {
  grid-template-columns: 62px 96px 54px !important;
  column-gap: 5px !important;
}
.age-calc-row-final {
  grid-template-columns: 62px 44px 40px 64px !important;
  column-gap: 4px !important;
}
.age-calc-label {
  text-align: right !important;
  font-weight: 400 !important;
  padding-right: 4px !important;
}
.age-calc-grid input {
  padding-left: 5px !important;
  padding-right: 5px !important;
}
#dobTime,
#dataTime {
  width: 54px !important;
  max-width: 54px !important;
}
#createAgeRecordButton {
  width: 64px !important;
  min-width: 64px !important;
  max-width: 64px !important;
  font-size: 7.8px !important;
  padding: 0 !important;
  box-sizing: border-box !important;
  overflow: hidden !important;
}

/* Patient Data: keep the correct graph-aligned box, but force 17 equal visible rows. */
.clinical-data-panel,
.data-panel.clinical-data-panel {
  top: 9px !important;
  height: 552px !important;
  min-height: 552px !important;
  max-height: 552px !important;
  overflow: hidden !important;
}
.clinical-data-title-row {
  flex: 0 0 20px !important;
  height: 20px !important;
  min-height: 20px !important;
  max-height: 20px !important;
  margin-bottom: 2px !important;
}
.patient-table-scroll {
  flex: 0 0 auto !important;
  height: 518px !important;
  min-height: 518px !important;
  max-height: 518px !important;
  overflow: hidden !important;
}
#patientTable {
  height: auto !important;
  table-layout: fixed !important;
  border-collapse: collapse !important;
}
#patientTable thead tr,
#patientTable thead th {
  height: 25px !important;
  min-height: 25px !important;
  max-height: 25px !important;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
  line-height: 1.0 !important;
}
#patientTable tbody tr:nth-child(-n+17) {
  display: table-row !important;
  height: 28px !important;
  min-height: 28px !important;
  max-height: 28px !important;
}
#patientTable tbody tr:nth-child(-n+17) td {
  height: 28px !important;
  min-height: 28px !important;
  max-height: 28px !important;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
  line-height: 1.0 !important;
}
#patientTable tbody tr:nth-child(-n+17) input {
  height: 26px !important;
  min-height: 26px !important;
  max-height: 26px !important;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
  line-height: 1.0 !important;
}
#patientTable tbody tr:nth-child(n+18) {
  display: none !important;
}

/* Release 0.3L: GA-range row-2 alignment, calculator/time parsing layout, and 17-row Patient Data fit. */

/* Include GA Range radio buttons on the same Row-2 centerline as Exchange / High risk / TcB. */
.clinical-ga-combined {
  position: relative !important;
}
.clinical-ga-combined .ga-range-box {
  position: absolute !important;
  left: 54px !important;
  right: auto !important;
  bottom: 3px !important;
  width: 202px !important;
  height: 22px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  line-height: 1 !important;
}
.clinical-ga-combined .ga-range-box label {
  height: 22px !important;
  min-height: 22px !important;
  display: inline-flex !important;
  align-items: center !important;
  font-size: 13px !important;
  line-height: 1 !important;
  gap: 4px !important;
  margin: 0 !important;
  padding: 0 !important;
  white-space: nowrap !important;
}
.clinical-ga-combined .ga-range-box input[type="radio"] {
  width: 14px !important;
  height: 14px !important;
  margin: 0 !important;
  align-self: center !important;
}

/* 0.3N: Age Calculator New Record button label and narrower width. */
.age-calculator {
  padding: 8px 7px !important;
}
.age-calc-grid {
  grid-template-rows: 20px 20px 20px !important;
  row-gap: 4px !important;
  align-content: center !important;
}
.age-calc-row {
  grid-template-columns: 56px 92px 58px !important;
  column-gap: 5px !important;
  min-height: 20px !important;
  height: 20px !important;
  align-items: center !important;
}
.age-calc-row-final {
  grid-template-columns: 56px 42px 30px 72px !important;
  column-gap: 5px !important;
  min-height: 20px !important;
  height: 20px !important;
  align-items: center !important;
}
.age-calc-label {
  text-align: right !important;
  font-weight: 400 !important;
  font-size: 13px !important;
  padding-right: 4px !important;
  line-height: 1 !important;
  white-space: nowrap !important;
}
.age-calc-grid input,
.age-calc-grid input[type="date"],
.age-calc-grid input[type="text"] {
  height: 20px !important;
  min-height: 20px !important;
  max-height: 20px !important;
  font-size: 12px !important;
  padding-left: 4px !important;
  padding-right: 4px !important;
  color: #000 !important;
  -webkit-text-fill-color: #000 !important;
  background-color: #fff !important;
}
#dobDate,
#dataDate {
  width: 92px !important;
  max-width: 92px !important;
}
#dobTime,
#dataTime {
  width: 58px !important;
  max-width: 58px !important;
}
#calculatedAgeDays {
  width: 42px !important;
  max-width: 42px !important;
}
.age-calc-unit {
  font-size: 12px !important;
  line-height: 1 !important;
}
#createAgeRecordButton {
  width: 72px !important;
  min-width: 72px !important;
  max-width: 72px !important;
  height: 20px !important;
  min-height: 20px !important;
  max-height: 20px !important;
  font-size: 9.5px !important;
  line-height: 1 !important;
  padding: 0 !important;
  overflow: hidden !important;
}

/* Patient Data: keep the correct top/bottom frame alignment and reduce equal row height so 17 rows display. */
.patient-table-scroll {
  flex: 0 0 auto !important;
  height: 518px !important;
  min-height: 518px !important;
  max-height: 518px !important;
  overflow: hidden !important;
}
#patientTable thead tr,
#patientTable thead th {
  height: 24px !important;
  min-height: 24px !important;
  max-height: 24px !important;
  line-height: 1.0 !important;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
}
#patientTable tbody tr:nth-child(-n+17) {
  display: table-row !important;
  height: 25px !important;
  min-height: 25px !important;
  max-height: 25px !important;
}
#patientTable tbody tr:nth-child(-n+17) td {
  height: 25px !important;
  min-height: 25px !important;
  max-height: 25px !important;
  line-height: 1.0 !important;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
}
#patientTable tbody tr:nth-child(-n+17) input {
  height: 23px !important;
  min-height: 23px !important;
  max-height: 23px !important;
  line-height: 1.0 !important;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
}
#patientTable tbody tr:nth-child(n+18) {
  display: none !important;
}

/* Release 0.3M: Age Calculator label alignment and date/time entry fixes. */
.age-calc-row,
.age-calc-row-final {
  grid-template-columns: 64px 88px 54px !important;
  column-gap: 7px !important;
}
.age-calc-row-final {
  grid-template-columns: 64px 38px 34px 92px !important;
}
.age-calc-label {
  text-align: right !important;
  justify-self: stretch !important;
  padding-right: 7px !important;
  display: block !important;
  width: 64px !important;
  min-width: 64px !important;
  max-width: 64px !important;
}
#dobDate,
#dataDate {
  width: 88px !important;
  max-width: 88px !important;
}
#dobTime,
#dataTime {
  width: 54px !important;
  max-width: 54px !important;
}
#calculatedAgeDays {
  width: 38px !important;
  max-width: 38px !important;
}
#createAgeRecordButton {
  width: 92px !important;
  min-width: 92px !important;
  max-width: 92px !important;
  font-size: 9.5px !important;
}

/* Release 0.3O: tighten Age Calculator final row so New Record stays inside frame. */
.age-calc-row,
.age-calc-row-final {
  column-gap: 6px !important;
}
.age-calc-row {
  grid-template-columns: 58px 82px 50px !important;
}
.age-calc-row-final {
  grid-template-columns: 58px 36px 28px 76px !important;
}
.age-calc-label {
  width: 58px !important;
  min-width: 58px !important;
  max-width: 58px !important;
  text-align: right !important;
  padding-right: 8px !important;
  justify-self: stretch !important;
}
#dobDate,
#dataDate {
  width: 82px !important;
  max-width: 82px !important;
}
#dobTime,
#dataTime {
  width: 50px !important;
  max-width: 50px !important;
}
#calculatedAgeDays {
  width: 36px !important;
  max-width: 36px !important;
}
.age-calc-unit {
  margin-left: -2px !important;
  width: 28px !important;
  min-width: 28px !important;
  max-width: 28px !important;
  text-align: left !important;
}
#createAgeRecordButton {
  width: 76px !important;
  min-width: 76px !important;
  max-width: 76px !important;
  justify-self: end !important;
  font-size: 9.4px !important;
  padding-left: 1px !important;
  padding-right: 1px !important;
  overflow: hidden !important;
  box-sizing: border-box !important;
}


/* Release 0.3P: exact Age Calculator alignment per screenshot.
   - left labels right-aligned
   - Age value + (days) occupy the date-column width
   - New Record button starts at the same left edge as the time boxes above */
.age-calc-row,
.age-calc-row-final {
  grid-template-columns: 58px 82px 50px !important;
  column-gap: 6px !important;
  align-items: center !important;
}
.age-calc-label {
  width: 58px !important;
  min-width: 58px !important;
  max-width: 58px !important;
  text-align: right !important;
  padding-right: 8px !important;
  justify-self: stretch !important;
}
#dobDate,
#dataDate {
  width: 82px !important;
  max-width: 82px !important;
}
#dobTime,
#dataTime {
  width: 50px !important;
  max-width: 50px !important;
}
.age-calc-value-unit {
  width: 82px !important;
  max-width: 82px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 4px !important;
}
#calculatedAgeDays {
  width: 36px !important;
  max-width: 36px !important;
  flex: 0 0 36px !important;
}
.age-calc-unit {
  flex: 1 1 auto !important;
  width: auto !important;
  min-width: 0 !important;
  max-width: none !important;
  margin-left: 0 !important;
  text-align: right !important;
  font-size: 12px !important;
  font-weight: 400 !important;
}
#createAgeRecordButton {
  grid-column: 3 !important;
  justify-self: start !important;
  width: 76px !important;
  min-width: 76px !important;
  max-width: 76px !important;
  font-size: 9.4px !important;
  padding-left: 2px !important;
  padding-right: 2px !important;
}

/* Release 0.3Q: final Age Calculator label alignment and slightly taller controls.
   Force labels into a true right-aligned fixed-width column and increase box/button height modestly. */
.age-calc-row,
.age-calc-row-final {
  grid-template-columns: 62px 80px 52px !important;
  column-gap: 6px !important;
  align-items: center !important;
}
.age-calc-label {
  width: 62px !important;
  min-width: 62px !important;
  max-width: 62px !important;
  box-sizing: border-box !important;
  padding-right: 8px !important;
  text-align: right !important;
  display: flex !important;
  justify-content: flex-end !important;
  align-items: center !important;
  white-space: nowrap !important;
}
#dobDate,
#dataDate {
  width: 80px !important;
  max-width: 80px !important;
}
#dobTime,
#dataTime {
  width: 52px !important;
  max-width: 52px !important;
}
.age-calc-grid input,
.age-calc-grid input[type="date"],
.age-calc-grid input[type="text"] {
  height: 25px !important;
  min-height: 25px !important;
  max-height: 25px !important;
  line-height: 25px !important;
  box-sizing: border-box !important;
}
.age-calc-value-unit {
  width: 80px !important;
  max-width: 80px !important;
}
#calculatedAgeDays {
  width: 34px !important;
  max-width: 34px !important;
  flex: 0 0 34px !important;
}
.age-calc-unit {
  text-align: right !important;
  padding-right: 0 !important;
}
#createAgeRecordButton {
  grid-column: 3 !important;
  justify-self: start !important;
  width: 76px !important;
  min-width: 76px !important;
  max-width: 76px !important;
  height: 25px !important;
  min-height: 25px !important;
  max-height: 25px !important;
  line-height: 1.05 !important;
  box-sizing: border-box !important;
  overflow: hidden !important;
}

/* Release 0.3R: Age Calculator final spacing correction.
   - wider fixed label column so DOB/Data date/Age are visibly right-aligned
   - smaller gap between labels and boxes
   - reduced input/button height after 0.3Q was too tall
   - additional left margin for the Data date label within the frame */
.age-calc-row,
.age-calc-row-final {
  grid-template-columns: 86px 76px 48px !important;
  column-gap: 4px !important;
  align-items: center !important;
}
.age-calc-label {
  width: 86px !important;
  min-width: 86px !important;
  max-width: 86px !important;
  display: block !important;
  box-sizing: border-box !important;
  text-align: right !important;
  padding-right: 6px !important;
  white-space: nowrap !important;
  line-height: 22px !important;
}
#dobDate,
#dataDate {
  width: 76px !important;
  max-width: 76px !important;
}
#dobTime,
#dataTime {
  width: 48px !important;
  max-width: 48px !important;
}
.age-calc-grid input,
.age-calc-grid input[type="date"],
.age-calc-grid input[type="text"] {
  height: 22px !important;
  min-height: 22px !important;
  max-height: 22px !important;
  line-height: 22px !important;
  box-sizing: border-box !important;
}
.age-calc-value-unit {
  width: 76px !important;
  max-width: 76px !important;
}
#calculatedAgeDays {
  width: 32px !important;
  max-width: 32px !important;
  flex: 0 0 32px !important;
  height: 22px !important;
  line-height: 22px !important;
}
.age-calc-unit {
  margin-left: 3px !important;
  text-align: right !important;
  padding-right: 0 !important;
}
#createAgeRecordButton {
  grid-column: 3 !important;
  justify-self: start !important;
  width: 72px !important;
  min-width: 72px !important;
  max-width: 72px !important;
  height: 22px !important;
  min-height: 22px !important;
  max-height: 22px !important;
  line-height: 1.05 !important;
  box-sizing: border-box !important;
  overflow: hidden !important;
  font-size: 9.1px !important;
}


/* Release 0.3S: Age Calculator vertical centering, wider fields, restored date pickers.
   - group shifted slightly upward in the calculator frame
   - labels moved left but remain right-aligned
   - date/time/age fields widened
   - browser date selector restored through date input type in index.html */
.age-calculator {
  padding: 4px 7px !important;
  overflow: visible !important;
}
.age-calc-grid {
  display: grid !important;
  grid-template-columns: 1fr !important;
  grid-template-rows: 20px 20px 20px !important;
  row-gap: 4px !important;
  transform: translateY(-3px) !important;
}
.age-calc-row,
.age-calc-row-final {
  display: grid !important;
  grid-template-columns: 72px 84px 56px !important;
  column-gap: 5px !important;
  align-items: center !important;
  min-height: 20px !important;
}
.age-calc-label {
  width: 72px !important;
  min-width: 72px !important;
  max-width: 72px !important;
  text-align: right !important;
  padding-right: 5px !important;
  box-sizing: border-box !important;
  white-space: nowrap !important;
  line-height: 20px !important;
}
#dobDate,
#dataDate {
  width: 84px !important;
  max-width: 84px !important;
}
#dobTime,
#dataTime {
  width: 56px !important;
  max-width: 56px !important;
}
.age-calc-grid input,
.age-calc-grid input[type="date"],
.age-calc-grid input[type="text"] {
  height: 22px !important;
  min-height: 22px !important;
  max-height: 22px !important;
  line-height: 20px !important;
  box-sizing: border-box !important;
  padding: 0 3px !important;
}
.age-calc-value-unit {
  width: 84px !important;
  max-width: 84px !important;
  display: flex !important;
  align-items: center !important;
}
#calculatedAgeDays {
  width: 42px !important;
  max-width: 42px !important;
  flex: 0 0 42px !important;
}
.age-calc-unit {
  margin-left: 5px !important;
  flex: 1 1 auto !important;
  text-align: right !important;
}
#createAgeRecordButton {
  grid-column: 3 !important;
  justify-self: start !important;
  width: 78px !important;
  min-width: 78px !important;
  max-width: 78px !important;
  height: 22px !important;
  min-height: 22px !important;
  max-height: 22px !important;
  line-height: 1.05 !important;
  box-sizing: border-box !important;
  font-size: 9.1px !important;
  overflow: hidden !important;
}
.age-calc-message {
  top: 76px !important;
}

/* Release 0.3T: final Age Calculator geometry from 0.3S baseline.
   - group shifted slightly downward compared with 0.3S
   - fields shifted left by narrowing label column
   - HH:MM fields widened
   - date-to-time gap reduced
   - date inputs remain type=date in index.html to preserve calendar selector */
.age-calc-grid {
  transform: translateY(0px) !important;
}
.age-calc-row,
.age-calc-row-final {
  grid-template-columns: 64px 84px 68px !important;
  column-gap: 4px !important;
}
.age-calc-label {
  width: 64px !important;
  min-width: 64px !important;
  max-width: 64px !important;
  text-align: right !important;
  padding-right: 5px !important;
}
#dobDate,
#dataDate {
  width: 84px !important;
  max-width: 84px !important;
}
#dobTime,
#dataTime {
  width: 68px !important;
  max-width: 68px !important;
}
.age-calc-value-unit {
  width: 84px !important;
  max-width: 84px !important;
}
#createAgeRecordButton {
  grid-column: 3 !important;
  justify-self: start !important;
  width: 68px !important;
  min-width: 68px !important;
  max-width: 68px !important;
  font-size: 8.8px !important;
  overflow: hidden !important;
}

/* Release 0.3V: age-calculator validation message placement.
   Display messages in the gap between the Age Calculator frame and the Patient Data frame. */
.age-calc-message {
  position: absolute !important;
  left: 2px !important;
  right: 2px !important;
  top: 80px !important;
  min-height: 14px !important;
  max-height: 28px !important;
  margin: 0 !important;
  padding: 0 2px !important;
  box-sizing: border-box !important;
  font-size: 9.2px !important;
  line-height: 1.15 !important;
  background: #ffffff !important;
  z-index: 20 !important;
  white-space: normal !important;
  overflow: visible !important;
  text-align: left !important;
}

/* Release 0.3W: age-calculator validation placement and alignment refinement */
.age-calc-message {
  position: absolute !important;
  left: 0 !important;
  right: 0 !important;
  top: calc(100% + 8px) !important;
  width: 100% !important;
  text-align: center !important;
  margin: 0 !important;
  line-height: 1.15 !important;
  white-space: normal !important;
  overflow: visible !important;
  z-index: 5 !important;
}


/* Release 0.3X: age-calculator date parsing/validation message refinement */
.age-calc-message {
  top: calc(100% + 2px) !important;
  left: 50% !important;
  right: auto !important;
  transform: translateX(-50%) !important;
  width: 92% !important;
  max-width: 230px !important;
  text-align: center !important;
  font-size: 10.5px !important;
  line-height: 1.1 !important;
  z-index: 8 !important;
}


/* Release 0.3Y: validation message one pixel lower than 0.3X. */
.age-calc-message {
  top: calc(100% + 3px) !important;
}

/* Release 0.3AA: validation message placement. */
.age-calc-message { top: 87px !important; }


/* Release 0.3AC: age-calculator message display and placement.
   Empty message is hidden by JavaScript so it cannot obscure Patient Data frame. */
.age-calc-message {
  top: calc(100% + 4px) !important;
  left: 50% !important;
  right: auto !important;
  transform: translateX(-50%) !important;
  width: 92% !important;
  max-width: 230px !important;
  text-align: center !important;
  z-index: 8 !important;
}

/* Release 0.3AH: final Age Calculator polish.
   Move the (days) label closer to the Age field and farther from the New Record button. */
.age-calc-value-unit {
  justify-content: flex-start !important;
  gap: 3px !important;
}
.age-calc-unit {
  margin-left: 2px !important;
  flex: 0 0 auto !important;
  width: auto !important;
  min-width: 0 !important;
  max-width: none !important;
  text-align: left !important;
}

/* Release 0.4A: basic clinical modal dialogs */
.clinical-modal-overlay {
  position: fixed;
  inset: 0;
  z-index: 100000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 18px;
  background: rgba(0,0,0,0.28);
  box-sizing: border-box;
}
.clinical-modal-panel {
  width: min(520px, 96vw);
  max-height: 92vh;
  overflow: auto;
  background: #fff;
  color: #000;
  border: 2px solid #777;
  padding: 16px 18px 14px;
  box-shadow: 0 4px 18px rgba(0,0,0,0.30);
  font-family: Arial, Helvetica, sans-serif;
  box-sizing: border-box;
}
.clinical-modal-title {
  font-size: 18px;
  font-weight: 700;
  margin: 0 0 12px;
}
.clinical-form-row {
  display: grid;
  grid-template-columns: 100px 1fr;
  gap: 10px;
  align-items: center;
  margin: 8px 0;
  font-size: 14px;
}
.clinical-form-row label {
  text-align: right;
  font-weight: 700;
}
.clinical-form-row input {
  height: 26px;
  font-size: 15px;
  padding: 2px 6px;
  box-sizing: border-box;
}
.clinical-modal-check {
  display: flex;
  align-items: center;
  gap: 6px;
  margin: 10px 0;
  font-size: 14px;
}
.clinical-modal-actions {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  margin-top: 14px;
}

.clinical-modal-actions button:disabled,
.clinical-modal-panel button:disabled {
  background: #c8c8c8 !important;
  color: #777 !important;
  border-color: #aaa !important;
  cursor: default !important;
}

.clinical-modal-actions button,
.clinical-modal-panel > button {
  min-width: 96px;
  height: 28px;
  font-size: 13px;
  padding: 0 8px;
}
.clinical-modal-message {
  margin-top: 10px;
  min-height: 18px;
  text-align: center;
  font-size: 13px;
}
.clinical-modal-message.error { color: #b00000; font-weight: 700; }
.clinical-modal-message.success { color: #006400; font-weight: 700; }
.clinical-modal-note {
  margin-top: 10px;
  font-size: 12px;
  text-align: center;
}
.clinical-save-alert {
  font-size: 16px;
  line-height: 1.5;
  margin: 10px 0 14px;
  text-align: center;
}
.clinical-team-results {
  margin-top: 12px;
  max-height: 260px;
  overflow: auto;
}
.clinical-team-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
}
.clinical-team-table th,
.clinical-team-table td {
  border: 1px solid #aaa;
  padding: 4px 6px;
  text-align: center;
}
.clinical-team-table tbody tr { cursor: pointer; }
.clinical-team-table tbody tr:hover { background: #dfefff; }

/* Release 0.4B: Excel-style Save Data and Stored Records dialogs */
.clinical-modal-overlay {
  background: rgba(0,0,0,0.18) !important;
}
.clinical-modal-panel.clinical-save-panel {
  width: 430px !important;
  max-height: none !important;
  overflow: visible !important;
  padding: 18px 18px 16px !important;
  background: #eeeeee !important;
  border: 2px solid #666 !important;
  box-shadow: none !important;
  font-size: 14px !important;
}
.clinical-modal-panel.clinical-stored-panel {
  width: 300px !important;
  max-height: none !important;
  overflow: visible !important;
  padding: 18px 16px 16px !important;
  background: #eeeeee !important;
  border: 2px solid #666 !important;
  box-shadow: none !important;
  font-size: 14px !important;
}
.clinical-save-panel .save-dialog-panel-inner {
  display: block;
}
.clinical-save-panel .save-form-row {
  display: grid;
  grid-template-columns: 100px 112px auto;
  align-items: center;
  column-gap: 9px;
  margin: 10px 0;
}
.clinical-save-panel .save-form-row > label:first-child {
  text-align: right;
  font-weight: 700;
}
.clinical-save-panel .save-code-field {
  width: 104px;
  height: 30px;
  text-align: center;
  font-size: 18px;
  font-weight: 700;
  padding: 2px 4px;
  box-sizing: border-box;
}
.clinical-save-panel .save-auto {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 13px;
  font-weight: 400;
  white-space: nowrap;
}
.clinical-save-panel .save-ga-box {
  grid-column: 2 / span 2;
  display: flex;
  align-items: center;
  gap: 5px;
}
.clinical-save-panel .save-ga-box strong {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  min-width: 34px;
  height: 28px;
  border: 1px solid #aaa;
  background: #fff;
  font-size: 17px;
}
.clinical-save-panel .save-unit {
  font-size: 12px;
  margin-right: 4px;
}
.clinical-save-panel .save-risk-row {
  grid-template-columns: 100px auto auto;
  column-gap: 12px;
  font-size: 13px;
}
.clinical-save-panel .save-risk-row label:not(:first-child) {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  font-weight: 700;
  white-space: nowrap;
}
.clinical-save-panel .save-instructions {
  margin: 26px 8px 6px;
  text-align: center;
  font-size: 12px;
  line-height: 1.25;
}
.clinical-save-panel .save-copy-link {
  display: block;
  text-align: center;
  font-size: 13px;
  font-weight: 700;
  color: #0645d9 !important;
  text-decoration: underline;
  margin: 0 0 18px;
  white-space: nowrap;
}
.clinical-save-panel .save-copy-link.disabled {
  color: #888 !important;
  pointer-events: none;
  text-decoration: none;
}
.clinical-save-panel .save-actions {
  flex-direction: column;
  align-items: center;
  gap: 10px;
  margin-top: 0;
}
.clinical-save-panel .save-actions button {
  width: 104px;
  height: 34px;
  font-weight: 700;
}
.clinical-save-panel .save-actions button.secondary {
  height: 30px;
  color: #fff;
  background: #aaa;
  border-color: #888;
}
.clinical-save-panel .clinical-modal-message {
  min-height: 34px;
  margin-top: 18px;
  font-size: 12px;
  line-height: 1.2;
}
.clinical-save-panel .clinical-modal-message.error {
  color: #d00000;
}
.clinical-stored-panel {
  width: 305px !important;
}
.clinical-stored-panel .stored-start-title {
  text-align: center;
  color: #0645d9;
  font-weight: 700;
  margin: 8px 0 18px;
}
.clinical-stored-panel .clinical-form-row {
  grid-template-columns: 92px 96px;
  justify-content: center;
  gap: 10px;
  margin: 12px 0;
}
.clinical-stored-panel .clinical-form-row label {
  font-weight: 400;
}
.clinical-stored-panel .clinical-form-row input {
  width: 92px;
  height: 30px;
  text-align: center;
  font-size: 16px;
  font-weight: 700;
}
.clinical-stored-panel .stored-actions {
  flex-direction: column;
  align-items: center;
  margin: 28px 0 0;
  gap: 12px;
}
.clinical-stored-panel .stored-actions button {
  width: 105px;
  height: 34px;
  font-weight: 700;
}
.clinical-stored-panel .stored-actions button.secondary {
  height: 30px;
  color: #fff;
  background: #aaa;
  border-color: #888;
}
.clinical-stored-panel .clinical-team-results {
  margin-top: 18px;
  max-height: 360px;
}
.clinical-stored-panel .stored-team-title {
  text-align: center;
  margin: 6px 0 10px;
  font-size: 14px;
}
.clinical-stored-panel .stored-team-note {
  text-align: center;
  color: #0645d9;
  font-size: 11px;
  margin-bottom: 8px;
}
.clinical-stored-panel .clinical-team-table {
  font-size: 12px;
  background: #fff;
}
.clinical-stored-panel .clinical-team-table th {
  font-weight: 700;
  cursor: pointer;
  background: #f7f7f7;
}
.clinical-stored-panel .clinical-modal-message {
  min-height: 28px;
  font-size: 12px;
}


/* Release 0.4C: Save/Stored Records refinements */
.clinical-current-user {
  font-size: 18px;
  color: #0a2b8f;
  font-weight: 700;
  white-space: nowrap;
}
.clinical-modal-panel.clinical-stored-team-panel {
  width: 620px !important;
  max-width: 680px !important;
  max-height: none !important;
  overflow: visible !important;
  padding: 18px 22px 22px !important;
  background: #eeeeee !important;
  border: 2px solid #666 !important;
  box-shadow: none !important;
  font-size: 13px !important;
}
.clinical-stored-team-panel .stored-team-search-row {
  display: grid;
  grid-template-columns: 110px 90px 155px 90px 100px;
  align-items: center;
  gap: 10px;
  margin: 0 0 12px;
}
.clinical-stored-team-panel .stored-team-search-row label,
.clinical-stored-team-panel .stored-team-or {
  font-size: 13px;
  text-align: right;
}
.clinical-stored-team-panel .stored-team-search-row input {
  width: 88px;
  height: 28px;
  text-align: center;
  font-size: 16px;
  font-weight: 700;
  box-sizing: border-box;
}
.clinical-stored-team-panel #showStoredDataWideButton {
  width: 96px;
  height: 34px;
  font-weight: 700;
  color: #fff;
  background: #666;
  border: 1px solid #333;
  border-radius: 4px;
}
.clinical-stored-team-panel .stored-team-code-note {
  font-size: 11px;
  margin: 4px 0 14px;
}
.clinical-stored-team-panel .stored-team-table-wrap {
  width: 430px;
  max-height: 502px;
  margin: 0 auto;
  overflow-y: auto;
  border: 1px solid #aaa;
  background: #fff;
}
.clinical-stored-team-panel .stored-team-table {
  width: 100%;
  margin: 0;
  border-collapse: collapse;
  background: #fff;
  font-size: 13px;
}
.clinical-stored-team-panel .stored-team-table th,
.clinical-stored-team-panel .stored-team-table td {
  border: 1px solid #aaa;
  height: 30px;
  padding: 4px 8px;
  text-align: center;
}
.clinical-stored-team-panel .stored-team-table th {
  font-weight: 700;
  cursor: pointer;
  background: #f7f7f7;
  position: sticky;
  top: 0;
  z-index: 1;
}
.clinical-stored-team-panel .stored-team-note {
  color: #0645d9;
  font-size: 11px;
  text-align: center;
  margin: 0 0 8px;
}
.clinical-stored-team-panel .clinical-modal-message {
  min-height: 22px;
  margin-top: 10px;
  font-size: 12px;
  text-align: center;
}

/* Release 0.4F: Rob test corrections */
.clinical-current-user {
  font-size: 18px !important;
  line-height: 22px !important;
  color: #0a2b8f !important;
  font-weight: 700 !important;
  text-align: left !important;
  white-space: nowrap !important;
  width: 100% !important;
}
.clinical-data-title-row .box-title[style*="display: none"] + .clinical-current-user {
  text-align: left !important;
}
.clinical-modal-panel.clinical-save-panel {
  width: 455px !important;
  padding: 22px 22px 18px !important;
}
.clinical-save-panel .save-form-row {
  grid-template-columns: 112px 124px auto !important;
  margin: 11px 0 !important;
}
.clinical-save-panel .save-ga-box {
  grid-column: 2 / span 2 !important;
  gap: 6px !important;
}
.clinical-save-panel .save-ga-select {
  width: 54px !important;
  height: 30px !important;
  text-align: center !important;
  font-size: 17px !important;
  font-weight: 700 !important;
  background: #fff !important;
  border: 1px solid #aaa !important;
}
.clinical-save-panel .save-ga-select.ga-cell-disabled {
  background: #ddd !important;
  color: #666 !important;
}
.clinical-modal-panel.clinical-transient-panel {
  width: 170px !important;
  padding: 18px 22px !important;
  background: #eeeeee !important;
  border: 2px solid #666 !important;
  box-shadow: none !important;
}
.clinical-transient-message {
  text-align: center !important;
  font-size: 16px !important;
  font-weight: 700 !important;
}


/* Release 0.4G: Rob test corrections */
/* Main GA Days field: when GA Weeks is >=35, retain the gray cell but hide the 0. */
#gaDays.ga-cell-disabled,
#gaDays:disabled.ga-cell-disabled {
  background: #e7e6e6 !important;
  color: #e7e6e6 !important;
  -webkit-text-fill-color: #e7e6e6 !important;
  opacity: 1 !important;
}
/* Save dialog GA days field uses the same hidden-zero convention when disabled. */
.clinical-save-panel .save-ga-select.ga-cell-disabled,
.clinical-save-panel .save-ga-select:disabled.ga-cell-disabled {
  background: #ddd !important;
  color: #ddd !important;
  -webkit-text-fill-color: #ddd !important;
  opacity: 1 !important;
}
/* Match saved-patient header to the existing Patient Data label size. */
.clinical-current-user {
  font-size: 14px !important;
  line-height: 17px !important;
  color: #0a2b8f !important;
  font-weight: 700 !important;
  text-align: left !important;
  white-space: nowrap !important;
  width: 100% !important;
}
/* Save dialog: closer to the Save worksheet mockup. */
.clinical-modal-panel.clinical-save-panel {
  width: 355px !important;
  padding: 22px 18px 16px !important;
  background: #eeeeee !important;
  border: 2px solid #666 !important;
  box-shadow: none !important;
  font-size: 13px !important;
}
.clinical-save-panel .save-form-row {
  grid-template-columns: 88px 104px auto !important;
  column-gap: 8px !important;
  margin: 10px 0 !important;
}
.clinical-save-panel .save-form-row > label:first-child {
  font-size: 13px !important;
  font-weight: 400 !important;
  text-align: right !important;
}
.clinical-save-panel .save-code-field {
  width: 100px !important;
  height: 31px !important;
  font-size: 16px !important;
  font-weight: 700 !important;
}
.clinical-save-panel .save-auto {
  font-size: 12px !important;
  gap: 4px !important;
}
.clinical-save-panel .save-ga-box {
  grid-column: 2 / span 2 !important;
  gap: 5px !important;
}
.clinical-save-panel .save-ga-select {
  width: 50px !important;
  height: 31px !important;
  font-size: 16px !important;
  font-weight: 700 !important;
  text-align: center !important;
  background: #fff !important;
  border: 1px solid #aaa !important;
}
.clinical-save-panel .save-unit {
  font-size: 12px !important;
  margin-right: 5px !important;
}
.clinical-save-panel .save-risk-row {
  grid-template-columns: 88px auto auto !important;
  column-gap: 8px !important;
  font-size: 12px !important;
}
.clinical-save-panel .save-risk-row label:not(:first-child) {
  font-size: 12px !important;
  font-weight: 700 !important;
  gap: 3px !important;
}
.clinical-save-panel .save-instructions {
  margin: 28px 4px 6px !important;
  font-size: 12px !important;
  line-height: 1.25 !important;
}
.clinical-save-panel .save-copy-link {
  font-size: 12px !important;
  margin: 0 0 18px !important;
  color: #0645d9 !important;
  white-space: nowrap !important;
}
.clinical-save-panel .save-actions {
  flex-direction: column !important;
  align-items: center !important;
  gap: 10px !important;
}
.clinical-save-panel .save-actions button {
  width: 105px !important;
  height: 34px !important;
  border-radius: 4px !important;
  font-size: 13px !important;
  font-weight: 700 !important;
}
.clinical-save-panel .save-actions button.secondary {
  width: 82px !important;
  height: 30px !important;
}
.clinical-save-panel .clinical-modal-message {
  min-height: 30px !important;
  margin-top: 16px !important;
  font-size: 12px !important;
  line-height: 1.2 !important;
  color: #d00000 !important;
  text-align: center !important;
}


/* Release 0.4H: Save dialog positioned and sized to match the Excel Save mockup. */
.clinical-modal-overlay-clinical-save-panel {
  background: transparent !important;
  align-items: flex-start !important;
  justify-content: flex-end !important;
  padding-top: 226px !important;
  padding-right: max(24px, calc((100vw - 1420px) / 2 + 26px)) !important;
  padding-left: 0 !important;
  padding-bottom: 0 !important;
}
.clinical-modal-overlay-clinical-save-panel .clinical-save-panel {
  width: 292px !important;
  min-height: 470px !important;
  max-height: none !important;
  overflow: visible !important;
  padding: 48px 16px 20px !important;
  background: #eeeeee !important;
  border: 2px solid #6b6b6b !important;
  box-shadow: none !important;
  box-sizing: border-box !important;
  font-family: Arial, Helvetica, sans-serif !important;
  font-size: 12px !important;
  line-height: 1.2 !important;
  color: #000 !important;
}
.clinical-save-panel .save-dialog-panel-inner {
  display: block !important;
  width: 100% !important;
}
.clinical-save-panel .save-form-row {
  display: grid !important;
  grid-template-columns: 82px 92px 1fr !important;
  align-items: center !important;
  column-gap: 6px !important;
  margin: 8px 0 !important;
}
.clinical-save-panel .save-form-row > label:first-child {
  text-align: right !important;
  font-size: 12px !important;
  font-weight: 400 !important;
  white-space: nowrap !important;
}
.clinical-save-panel .save-code-field {
  width: 92px !important;
  height: 29px !important;
  padding: 1px 3px !important;
  box-sizing: border-box !important;
  text-align: center !important;
  font-size: 16px !important;
  font-weight: 700 !important;
  border: 1px solid #b9b9b9 !important;
  background: #fff !important;
}
.clinical-save-panel .save-auto {
  display: inline-flex !important;
  align-items: center !important;
  gap: 3px !important;
  font-size: 11px !important;
  font-weight: 400 !important;
  white-space: nowrap !important;
}
.clinical-save-panel .save-auto input {
  width: 13px !important;
  height: 13px !important;
  margin: 0 !important;
}
.clinical-save-panel .save-ga-box {
  grid-column: 2 / span 2 !important;
  display: flex !important;
  align-items: center !important;
  gap: 5px !important;
}
.clinical-save-panel .save-ga-select {
  width: 46px !important;
  height: 29px !important;
  padding: 0 2px !important;
  box-sizing: border-box !important;
  text-align: center !important;
  font-size: 16px !important;
  font-weight: 700 !important;
  border: 1px solid #b9b9b9 !important;
  background: #fff !important;
}
.clinical-save-panel .save-ga-select.ga-cell-disabled,
.clinical-save-panel .save-ga-select:disabled.ga-cell-disabled {
  background: #ddd !important;
  color: #ddd !important;
  -webkit-text-fill-color: #ddd !important;
  opacity: 1 !important;
}
.clinical-save-panel .save-unit {
  font-size: 11px !important;
  margin: 0 5px 0 0 !important;
  white-space: nowrap !important;
}
.clinical-save-panel .save-risk-row {
  grid-template-columns: 82px auto auto !important;
  column-gap: 8px !important;
  margin-top: 12px !important;
  font-size: 12px !important;
}
.clinical-save-panel .save-risk-row > label:first-child {
  font-size: 12px !important;
  white-space: nowrap !important;
}
.clinical-save-panel .save-risk-row label:not(:first-child) {
  display: inline-flex !important;
  align-items: center !important;
  gap: 3px !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  white-space: nowrap !important;
}
.clinical-save-panel .save-risk-row input[type="radio"] {
  width: 13px !important;
  height: 13px !important;
  margin: 0 !important;
}
.clinical-save-panel .save-instructions {
  margin: 31px 8px 7px !important;
  text-align: center !important;
  font-size: 11px !important;
  line-height: 1.25 !important;
  font-weight: 400 !important;
}
.clinical-save-panel .save-copy-link {
  display: block !important;
  text-align: center !important;
  margin: 0 0 23px !important;
  color: #0645d9 !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  text-decoration: underline !important;
  white-space: nowrap !important;
}
.clinical-save-panel .save-actions {
  display: flex !important;
  flex-direction: column !important;
  justify-content: flex-start !important;
  align-items: center !important;
  gap: 12px !important;
  margin: 0 !important;
}
.clinical-save-panel .save-actions button {
  width: 102px !important;
  height: 34px !important;
  padding: 0 !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  border-radius: 4px !important;
  border: 1px solid #555 !important;
  background: #777 !important;
  color: #fff !important;
}
.clinical-save-panel .save-actions button:disabled {
  background: #c8c8c8 !important;
  color: #777 !important;
  border-color: #aaa !important;
}
.clinical-save-panel .save-actions button.secondary {
  width: 76px !important;
  height: 30px !important;
  background: #b5b5b5 !important;
  color: #fff !important;
  border-color: #8a8a8a !important;
}
.clinical-save-panel .clinical-modal-message {
  min-height: 32px !important;
  margin: 22px 0 0 !important;
  text-align: center !important;
  color: #d00000 !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  line-height: 1.2 !important;
}
@media (max-width: 900px) {
  .clinical-modal-overlay-clinical-save-panel {
    justify-content: center !important;
    padding: 90px 10px 0 !important;
  }
}


/* Release 0.4J: Anchor Save Data dialog over Patient Data list and refine Save dialog controls. */
#clinicalModalRoot {
  position: static !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-modal-overlay-clinical-save-panel {
  position: absolute !important;
  inset: 0 !important;
  z-index: 100000 !important;
  display: block !important;
  padding: 0 !important;
  margin: 0 !important;
  background: transparent !important;
  pointer-events: none !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-modal-overlay-clinical-save-panel .clinical-save-panel {
  position: absolute !important;
  left: 1120px !important;
  top: 222px !important;
  width: 245px !important;
  min-height: 354px !important;
  height: 354px !important;
  padding: 31px 12px 12px !important;
  margin: 0 !important;
  background: #eeeeee !important;
  border: 2px solid #666 !important;
  box-shadow: none !important;
  box-sizing: border-box !important;
  pointer-events: auto !important;
  font-family: Arial, Helvetica, sans-serif !important;
  font-size: 12px !important;
  line-height: 1.15 !important;
  overflow: hidden !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-form-row {
  grid-template-columns: 74px 86px 1fr !important;
  column-gap: 5px !important;
  margin: 7px 0 !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-form-row > label:first-child {
  font-size: 12px !important;
  font-weight: 400 !important;
  text-align: right !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-code-field {
  width: 82px !important;
  height: 28px !important;
  font-size: 15px !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-auto {
  font-size: 11px !important;
  gap: 3px !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-ga-box {
  gap: 4px !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-ga-select {
  width: 52px !important;
  height: 28px !important;
  font-size: 15px !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-unit {
  font-size: 11px !important;
  margin-right: 3px !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-risk-row {
  grid-template-columns: 74px 86px 1fr !important;
  column-gap: 5px !important;
  margin-top: 9px !important;
}

.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-risk-row label:nth-child(2) {
  grid-column: 2 !important;
  justify-self: start !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-risk-row label:nth-child(3) {
  grid-column: 3 !important;
  justify-self: start !important;
}

.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-risk-row label:not(:first-child) {
  font-size: 11px !important;
  font-weight: 700 !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-instructions {
  margin: 24px 6px 5px !important;
  font-size: 11px !important;
  line-height: 1.18 !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-copy-link {
  font-size: 11px !important;
  margin: 0 0 16px !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-actions {
  gap: 10px !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-actions button {
  width: 92px !important;
  height: 30px !important;
  font-size: 12px !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-actions button.secondary {
  width: 72px !important;
  height: 27px !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .clinical-modal-message {
  min-height: 28px !important;
  margin: 15px 0 0 !important;
  font-size: 11px !important;
  line-height: 1.15 !important;
}

/* Release 0.4K: Save dialog top-aligned with Patient Data box, widened, and right-aligned to Patient Data border. */
.worksheet-frame > #clinicalModalRoot .clinical-modal-overlay-clinical-save-panel .clinical-save-panel {
  /* Patient Data right edge is approximately x=1365 in the worksheet coordinate system. */
  left: 1045px !important;
  top: 207px !important;
  width: 320px !important;
  min-height: 354px !important;
  height: 354px !important;
  padding: 31px 14px 12px !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-form-row {
  grid-template-columns: 92px 100px 1fr !important;
  column-gap: 7px !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-form-row > label:first-child {
  white-space: nowrap !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-code-field {
  width: 96px !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-ga-select {
  width: 58px !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-ga-box {
  gap: 5px !important;
  white-space: nowrap !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-auto {
  white-space: nowrap !important;
  justify-self: start !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-risk-row {
  grid-template-columns: 92px 100px 1fr !important;
  column-gap: 7px !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-risk-row label:nth-child(3) {
  justify-self: start !important;
  white-space: nowrap !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-instructions,
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-copy-link {
  white-space: nowrap !important;
}


/* Release 0.4L: Save dialog alignment and spacing refinements. */
.worksheet-frame > #clinicalModalRoot .clinical-modal-overlay-clinical-save-panel .clinical-save-panel {
  /* Align the top and right edges with the Patient Data frame; extend leftward into the graph. */
  left: 1025px !important;
  top: 216px !important;
  width: 340px !important;
  min-height: 354px !important;
  height: 354px !important;
  padding: 31px 17px 12px !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-form-row {
  grid-template-columns: 92px 102px 1fr !important;
  column-gap: 6px !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-risk-row {
  grid-template-columns: 92px auto auto !important;
  column-gap: 8px !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-risk-row label:nth-child(2) {
  justify-self: start !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-risk-row label:nth-child(3) {
  justify-self: start !important;
  margin-left: 2px !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-risk-row label:not(:first-child) {
  gap: 2px !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-instructions {
  width: 270px !important;
  margin: 24px auto 5px !important;
  white-space: normal !important;
  text-align: center !important;
  line-height: 1.16 !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-copy-link {
  white-space: nowrap !important;
}


/* Release 0.4N: actual Save dialog anchoring and final Excel-layout refinements. */
.worksheet-frame > #clinicalModalRoot .clinical-modal-overlay-clinical-save-panel {
  position: absolute !important;
  inset: 0 !important;
  z-index: 100000 !important;
  display: block !important;
  padding: 0 !important;
  margin: 0 !important;
  background: transparent !important;
  pointer-events: none !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-modal-overlay-clinical-save-panel .clinical-save-panel {
  position: absolute !important;
  min-height: 354px !important;
  height: 354px !important;
  padding: 31px 18px 12px !important;
  margin: 0 !important;
  background: #eeeeee !important;
  border: 2px solid #666 !important;
  box-shadow: none !important;
  box-sizing: border-box !important;
  pointer-events: auto !important;
  font-family: Arial, Helvetica, sans-serif !important;
  font-size: 12px !important;
  line-height: 1.15 !important;
  overflow: hidden !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-form-row {
  grid-template-columns: 96px 104px 1fr !important;
  column-gap: 7px !important;
  margin: 7px 0 !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-form-row > label:first-child {
  font-size: 12px !important;
  font-weight: 400 !important;
  text-align: right !important;
  white-space: nowrap !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-code-field {
  width: 98px !important;
  height: 28px !important;
  font-size: 15px !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-auto {
  font-size: 11px !important;
  gap: 3px !important;
  white-space: nowrap !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-ga-box {
  gap: 4px !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-ga-select {
  width: 54px !important;
  height: 28px !important;
  font-size: 15px !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-risk-row {
  grid-template-columns: 96px max-content max-content !important;
  column-gap: 10px !important;
  margin-top: 9px !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-risk-row label:nth-child(2),
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-risk-row label:nth-child(3) {
  justify-self: start !important;
  margin-left: 0 !important;
  white-space: nowrap !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-risk-row label:not(:first-child) {
  font-size: 11px !important;
  font-weight: 700 !important;
  gap: 2px !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-instructions {
  width: auto !important;
  margin: 26px auto 13px !important;
  white-space: normal !important;
  text-align: center !important;
  font-size: 11px !important;
  line-height: 1.18 !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-copy-link {
  display: block !important;
  white-space: nowrap !important;
  font-size: 11px !important;
  margin: 0 0 16px !important;
}


/* Release 0.4O: final Save dialog layout overrides. */
.worksheet-frame > #clinicalModalRoot .clinical-modal-overlay-clinical-save-panel .clinical-save-panel {
  min-height: 354px !important;
  height: 354px !important;
  padding: 31px 16px 12px !important;
  overflow: hidden !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-form-row {
  grid-template-columns: 82px 104px 1fr !important;
  column-gap: 6px !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-risk-row {
  grid-template-columns: 82px auto auto !important;
  column-gap: 12px !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-risk-row label:nth-child(2),
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-risk-row label:nth-child(3) {
  grid-column: auto !important;
  justify-self: start !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-ga-select {
  width: 58px !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-instructions {
  margin: 25px 8px 14px !important;
  text-align: center !important;
  white-space: normal !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-copy-link {
  margin: 0 0 18px !important;
  display: block !important;
  text-align: center !important;
}


/* Release 0.4P: Save dialog placement and Excel-layout refinements. */
.worksheet-frame > #clinicalModalRoot {
  position: absolute !important;
  left: 0 !important;
  top: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  width: 100% !important;
  height: 100% !important;
  pointer-events: none !important;
  z-index: 100000 !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-modal-overlay-clinical-save-panel {
  position: absolute !important;
  left: 0 !important;
  top: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  display: block !important;
  align-items: initial !important;
  justify-content: initial !important;
  padding: 0 !important;
  margin: 0 !important;
  background: transparent !important;
  pointer-events: none !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-modal-overlay-clinical-save-panel .clinical-save-panel {
  position: absolute !important;
  width: 430px !important;
  min-height: 354px !important;
  height: 354px !important;
  padding: 31px 20px 12px !important;
  margin: 0 !important;
  transform: none !important;
  background: #eeeeee !important;
  border: 2px solid #666 !important;
  box-shadow: none !important;
  pointer-events: auto !important;
  box-sizing: border-box !important;
  overflow: hidden !important;
  font-family: Arial, Helvetica, sans-serif !important;
  font-size: 12px !important;
  line-height: 1.15 !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-form-row {
  display: grid !important;
  grid-template-columns: 96px 112px 1fr !important;
  column-gap: 8px !important;
  align-items: center !important;
  margin: 7px 0 !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-form-row > label:first-child {
  font-size: 12px !important;
  font-weight: 400 !important;
  text-align: right !important;
  white-space: nowrap !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-code-field {
  width: 104px !important;
  height: 28px !important;
  font-size: 15px !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-auto {
  justify-self: start !important;
  margin-left: 0 !important;
  gap: 3px !important;
  font-size: 11px !important;
  white-space: nowrap !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-ga-box {
  display: flex !important;
  align-items: center !important;
  gap: 4px !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-ga-select {
  width: 60px !important;
  height: 28px !important;
  font-size: 15px !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-risk-row {
  grid-template-columns: 96px max-content max-content !important;
  column-gap: 5px !important;
  margin-top: 9px !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-risk-row label:not(:first-child) {
  justify-self: start !important;
  margin-left: 0 !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  white-space: nowrap !important;
  gap: 2px !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-instructions {
  margin: 26px 8px 20px !important;
  text-align: center !important;
  white-space: normal !important;
  font-size: 11px !important;
  line-height: 1.2 !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-copy-link {
  display: block !important;
  margin: 0 0 16px !important;
  text-align: center !important;
  white-space: nowrap !important;
  font-size: 11px !important;
}


/* Release 0.4Q: Save dialog fine-tuning from 0.4P screenshot. */
.worksheet-frame > #clinicalModalRoot .clinical-modal-overlay-clinical-save-panel .clinical-save-panel {
  padding: 31px 20px 12px !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-form-row {
  grid-template-columns: 118px 112px 1fr !important;
  column-gap: 8px !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-form-row > label:first-child {
  font-size: 13px !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-auto {
  font-size: 12px !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-unit {
  font-size: 12px !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-risk-row {
  grid-template-columns: 118px max-content max-content !important;
  column-gap: 4px !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-risk-row label:not(:first-child) {
  font-size: 12px !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-instructions {
  font-size: 12px !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-copy-link {
  font-size: 12px !important;
}

/* Release 0.4R: Save dialog fine-tuning per 2026-06-29 feedback. */
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-form-row {
  grid-template-columns: 128px 112px 1fr !important;
  column-gap: 8px !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-code-field {
  width: 108px !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-ga-select {
  width: 60px !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-auto,
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-unit,
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-risk-row label:not(:first-child),
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-instructions,
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-copy-link {
  font-size: 12px !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-risk-row {
  grid-template-columns: 128px max-content max-content !important;
  column-gap: 14px !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-risk-row label:not(:first-child) {
  gap: 4px !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-instructions {
  line-height: 1.2 !important;
}

/* Release 0.4S: re-center Save dialog and final dialog typography/field positioning. */
.worksheet-frame > #clinicalModalRoot .clinical-modal-overlay-clinical-save-panel {
  position: absolute !important;
  left: 0 !important;
  top: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 !important;
  margin: 0 !important;
  background: transparent !important;
  pointer-events: none !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-modal-overlay-clinical-save-panel .clinical-save-panel {
  position: relative !important;
  left: auto !important;
  top: auto !important;
  right: auto !important;
  width: 430px !important;
  height: 354px !important;
  min-height: 354px !important;
  margin: 0 !important;
  transform: none !important;
  pointer-events: auto !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-form-row {
  grid-template-columns: 136px 112px 1fr !important;
  column-gap: 8px !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-risk-row {
  grid-template-columns: 136px max-content max-content !important;
  column-gap: 18px !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-auto,
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-unit,
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-risk-row label:not(:first-child),
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-instructions,
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-copy-link {
  font-size: 13px !important;
}
.worksheet-frame > #clinicalModalRoot .clinical-save-panel .save-risk-row label:not(:first-child) {
  gap: 5px !important;
}
