/* Shared schema-driven form styles — the structural look of every form field,
   section, choice list and answer box. Imported by BOTH the client portal and
   the admin app (read-only view), so a field looks identical in both. Relies on
   the --bl-* CSS variables, which each app defines with the same values.
   Link this BEFORE the app's own stylesheet so app-specific overrides
   (masquerade, print) win in the cascade. */

.dataform__head h1 {
  margin: 0 0 0.25rem;
}

.dataform__intro {
  margin: 0 0 0.75rem;
  color: var(--bl-text-soft);
  max-width: 70ch;
}

.dataform__bullets {
  list-style: none;
  margin: 0 0 1.25rem;
  padding: 0;
  color: var(--bl-text-soft);
}

.dataform__toolbar {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.75rem;
  padding: 0.75rem 0;
  margin-bottom: 0.5rem;
  border-top: 1px solid var(--bl-border);
  border-bottom: 1px solid var(--bl-border);
}

.dataform__history {
  font: inherit;
  font-size: 14px;
  padding: 8px 10px;
  border: 1px solid var(--bl-border);
  border-radius: 4px;
  background: #fff;
  color: var(--bl-text);
}

.dataform__viewing {
  font-size: 14px;
  font-style: italic;
  color: var(--bl-navy);
}

.dataform__field {
  display: block;
  padding: 1.25rem 0;
  border-top: 1px solid var(--bl-border);
}

.dataform__field:first-of-type {
  border-top: 0;
}

.dataform__label {
  display: block;
  font-weight: 700;
  margin-bottom: 0.5rem;
}

.dataform__sublabel {
  margin: -0.25rem 0 0.5rem;
  font-size: 14px;
  color: var(--bl-text-soft);
}

/* Section heading that groups the fields beneath it (Sleep Journal et al.). */
.dataform__section {
  margin: 1.5rem 0 0;
  padding-top: 1.25rem;
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--bl-navy);
  border-top: 1px solid var(--bl-border);
}
/* The field opening a section sits right under the heading, so it shouldn't
   draw its own top border on top of the section's. */
.dataform__section + .dataform__field {
  border-top: 0;
}

/* Radio / checkbox option lists. */
.dataform__choices {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.dataform__choice {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  cursor: pointer;
}
.dataform__choice input {
  width: 1.05rem;
  height: 1.05rem;
  margin: 0;
  flex: 0 0 auto;
  accent-color: var(--bl-teal-mid);
  cursor: pointer;
}
.dataform__choice input:disabled {
  cursor: default;
}

/* Multiple answer boxes for one prompt: stacked, sharing borders, with only
   the outer corners rounded — one visual control per prompt. */
.dataform__boxes .dataform__input {
  border-radius: 0;
}

.dataform__boxes .dataform__input + .dataform__input {
  margin-top: -1px;
}

.dataform__boxes .dataform__input:first-child {
  border-top-left-radius: 6px;
  border-top-right-radius: 6px;
}

.dataform__boxes .dataform__input:last-child {
  border-bottom-left-radius: 6px;
  border-bottom-right-radius: 6px;
}

.dataform__boxes .dataform__input:focus {
  position: relative;   /* lift the focused box's border above its neighbours */
  z-index: 1;
}

.dataform__input {
  display: block;
  width: 100%;
  box-sizing: border-box;
  font: inherit;
  padding: 10px 12px;
  border: 1px solid var(--bl-border);
  border-radius: 6px;
  resize: vertical;
}

.dataform__input:focus {
  outline: none;
  border-color: var(--bl-teal-mid);
}

.dataform__input:read-only {
  background: var(--bl-bg-soft);
  color: var(--bl-text-soft);
}

.dataform__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  padding-top: 1.25rem;
  border-top: 1px solid var(--bl-border);
}