﻿:root {
  --bg: #f3f7fb;
  --panel: rgba(255, 255, 255, 0.9);
  --panel-strong: #ffffff;
  --line: rgba(14, 31, 53, 0.1);
  --text: #17304a;
  --muted: #69809a;
  --accent: #0c7d7b;
  --accent-deep: #145d66;
  --accent-soft: rgba(12, 125, 123, 0.12);
  --warn: #a95b17;
  --warn-soft: rgba(169, 91, 23, 0.12);
  --danger: #9d2f2f;
  --shadow: 0 24px 60px rgba(15, 31, 56, 0.08);
  --excel-col-number: clamp(34px, 2.4vw, 42px);
  --excel-col-fio: clamp(95px, 8vw, 130px);
  --excel-col-birth: clamp(58px, 4.4vw, 64px);
  --excel-col-registration: clamp(96px, 8vw, 155px);
  --excel-col-category: clamp(80px, 6vw, 110px);
  --excel-col-reference: clamp(42px, 3.8vw, 58px);
  --excel-col-gynecologist: clamp(28px, 2.2vw, 42px);
  --excel-col-stomatologist: clamp(28px, 2.2vw, 42px);
  --excel-col-dermatologist: clamp(28px, 2.2vw, 42px);
  --excel-col-neurologist: clamp(28px, 2.2vw, 42px);
  --excel-col-surgeon: clamp(28px, 2.2vw, 42px);
  --excel-col-otolaryngologist: clamp(28px, 2.2vw, 42px);
  --excel-col-ophthalmologist: clamp(28px, 2.2vw, 42px);
  --excel-col-therapist: clamp(28px, 2.2vw, 42px);
  --excel-col-psychiatrist: clamp(28px, 2.2vw, 42px);
  --excel-col-infectionist: clamp(28px, 2.2vw, 42px);
  --excel-col-phthisiatrician: clamp(28px, 2.2vw, 42px);
  --excel-col-uzist: clamp(28px, 2.2vw, 42px);
  --excel-col-chairman: clamp(28px, 2.2vw, 42px);
  --excel-col-stamp: clamp(28px, 2.2vw, 42px);
  --excel-col-note: clamp(120px, 9vw, 165px);
  --excel-col-encounterDate: clamp(58px, 4.8vw, 72px);
  --excel-col-cardNumber: clamp(54px, 4.4vw, 68px);
  --excel-col-organization: clamp(88px, 7vw, 120px);
  --excel-col-agent: clamp(88px, 7vw, 120px);
  --excel-col-serviceId: 72px;
  --excel-col-serviceName: 340px;
  --excel-col-serviceGroup: 190px;
  --excel-col-servicePrice: 130px;
  --excel-col-serviceRecall: 140px;
  --excel-col-serviceNote: 320px;
  --excel-col-serviceDoctors: 330px;
  --excel-col-serviceStatus: 130px;
  font-family: "Segoe UI", sans-serif;
  color: var(--text);
}

* {
  box-sizing: border-box;
}

body {
  margin: 0;
  min-height: 100vh;
  background: #f5f7fa;
}

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

.hidden {
  display: none !important;
}

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

.sidebar {
  background: linear-gradient(180deg, #14334f 0%, #10263f 100%);
  color: #f7fbfd;
  padding: 16px 10px;
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.brand {
  display: grid;
  gap: 8px;
  justify-items: start;
}

.brand__badge {
  width: 42px;
  height: 42px;
  border-radius: 14px;
  display: grid;
  place-items: center;
  background: linear-gradient(135deg, #2fd1d3 0%, #9ce9d5 100%);
  color: #14334f;
  font-weight: 800;
  font-size: 20px;
}

.brand__title {
  font-size: 16px;
  font-weight: 700;
}

.brand__subtitle {
  color: rgba(247, 251, 253, 0.68);
  font-size: 11px;
  margin-top: 2px;
}

.nav {
  display: grid;
  gap: 10px;
}

.nav button {
  border: 0;
  background: transparent;
  color: rgba(247, 251, 253, 0.82);
  text-align: left;
  padding: 10px 12px;
  border-radius: 12px;
  cursor: pointer;
  font-size: 14px;
}

.nav button:hover,
.nav button.active {
  background: rgba(255, 255, 255, 0.12);
  color: #ffffff;
}

.nav-group {
  display: grid;
  gap: 6px;
}

.nav-link-button {
  padding: 8px 10px;
  border-radius: 10px;
}

.nav-notes {
  display: grid;
  gap: 6px;
  padding-left: 10px;
  color: rgba(247, 251, 253, 0.82);
  font-size: 13px;
}

.sidebar-card {
  margin-top: auto;
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 16px;
  padding: 10px;
}

.sidebar-card__label {
  color: rgba(247, 251, 253, 0.62);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.sidebar-card__value {
  margin-top: 8px;
  font-size: 13px;
  font-weight: 700;
}

.sidebar-card p {
  color: rgba(247, 251, 253, 0.72);
  line-height: 1.35;
  font-size: 11px;
}

.main {
  padding: 18px;
}

.topbar {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 16px;
}

.eyebrow {
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-size: 12px;
}

.topbar h1 {
  margin: 8px 0 0;
  font-size: 38px;
  line-height: 1.05;
}

.topbar-actions {
  display: flex;
  gap: 12px;
  align-items: center;
}

.center-pill {
  padding: 10px 14px;
  border-radius: 999px;
  background: var(--panel);
  border: 1px solid var(--line);
  box-shadow: var(--shadow);
}

.center-select {
  color: var(--text);
  min-width: 170px;
}

.ghost-button,
.primary-button,
.secondary-button {
  border: 0;
  border-radius: 14px;
  padding: 12px 16px;
  cursor: pointer;
}

.ghost-button {
  background: var(--panel);
  color: var(--text);
  border: 1px solid var(--line);
}

.primary-button {
  background: linear-gradient(135deg, var(--accent) 0%, var(--accent-deep) 100%);
  color: #ffffff;
}

.secondary-button {
  background: var(--accent-soft);
  color: var(--accent-deep);
}

.content {
  margin-top: 14px;
  display: grid;
  gap: 18px;
}

.hero {
  background: linear-gradient(135deg, #133956 0%, #0c7d7b 100%);
  color: #ffffff;
  border-radius: 28px;
  padding: 28px;
  box-shadow: var(--shadow);
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 18px;
}

.hero h2 {
  margin: 0 0 12px;
  font-size: 34px;
}

.hero p {
  margin: 0 0 18px;
  line-height: 1.6;
  color: rgba(255, 255, 255, 0.82);
}

.hero-grid,
.stats-grid,
.cards-grid,
.two-col,
.three-col {
  display: grid;
  gap: 16px;
}

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

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

.template-page-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
  flex-wrap: wrap;
}

.template-page-head .muted {
  max-width: 820px;
}

.template-status {
  margin: 14px 0;
  border: 1px solid #e4c76a;
  border-radius: 12px;
  background: #fff6cf;
  color: #594711;
  padding: 11px 14px;
  font-size: 14px;
}

.document-template-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  margin-top: 18px;
}

.document-template-card {
  display: grid;
  gap: 10px;
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: #ffffff;
  padding: 15px;
}

.document-template-card strong,
.document-template-card span,
.document-template-card small {
  min-width: 0;
  overflow-wrap: anywhere;
}

.document-template-card span,
.document-template-card small {
  display: block;
  color: var(--muted);
}

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

.document-template-card__actions .ghost-button {
  border-radius: 10px;
  padding: 9px 10px;
}

.two-col {
  grid-template-columns: 1.1fr 1fr;
}

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

.card,
.table-card,
.form-card,
.summary-card,
.mini-card {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 24px;
  box-shadow: var(--shadow);
}

.summary-card,
.mini-card {
  padding: 18px;
}

.summary-card__label {
  color: var(--muted);
  font-size: 13px;
}

.summary-card__value {
  margin-top: 10px;
  font-size: 30px;
  font-weight: 700;
}

.summary-card__meta {
  margin-top: 8px;
  color: var(--muted);
  font-size: 14px;
}

.card,
.table-card,
.form-card {
  padding: 22px;
}

.card h3,
.table-card h3,
.form-card h3,
.mini-card h3 {
  margin: 0 0 12px;
  font-size: 22px;
}

.muted {
  color: var(--muted);
}

.badge-row {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 16px;
}

.blanks-page__header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 16px;
}

.tabs {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 16px;
}

.tabs__item {
  border: 1px solid #cfd7e3;
  background: #fff;
  color: #18324b;
  border-radius: 999px;
  padding: 10px 16px;
  cursor: pointer;
  font: inherit;
}

.tabs__item--active {
  background: #18324b;
  color: #fff;
  border-color: #18324b;
}

.blanks-section-head {
  display: flex;
  justify-content: flex-end;
  margin-bottom: 12px;
}

.blanks-batch-form {
  margin-bottom: 16px;
}

.visit-form__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 12px;
}

.visit-form__wide {
  grid-column: 1 / -1;
}

.visit-form__actions {
  display: flex;
  justify-content: flex-end;
  margin-top: 12px;
}

.blanks-filters {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 12px;
  margin-bottom: 16px;
}

.blanks-filters__search {
  grid-column: 1 / -1;
}

.data-table {
  overflow-x: auto;
}

.data-table table {
  width: 100%;
  border-collapse: collapse;
  min-width: 880px;
}

.data-table th,
.data-table td {
  padding: 10px 12px;
  border-bottom: 1px solid #e4e9f0;
  text-align: left;
  vertical-align: top;
}

.data-table th {
  color: #5f6f82;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.blank-status {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 4px 10px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 600;
}

.blank-status--free {
  background: #e7f6eb;
  color: #1d6b36;
}

.blank-status--issued {
  background: #e7eefb;
  color: #214b8f;
}

.blank-status--spoiled {
  background: #fdeaea;
  color: #a33737;
}

.blank-status--cancelled {
  background: #f1f2f4;
  color: #576273;
}

.blank-badge {
  display: inline-flex;
  align-items: center;
  margin-top: 6px;
  padding: 4px 10px;
  border-radius: 999px;
  background: #e7eefb;
  color: #214b8f;
  font-size: 12px;
  font-weight: 600;
}

.form-error {
  margin-top: 12px;
  padding: 10px 12px;
  border-radius: 12px;
  background: #fdeaea;
  color: #a33737;
}

.operator-service-card-btn {
  background: transparent;
  border: 1px solid #cbd5e0;
  color: #2c5282;
  border-radius: 6px;
  padding: 4px 10px;
  font-size: 12px;
  cursor: pointer;
  white-space: nowrap;
}

.operator-service-card-btn:hover {
  background: #ebf4ff;
  border-color: #2b6cb0;
}

.sport-card-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(20, 25, 45, 0.45);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 2000;
  padding: 16px;
}

.sport-card-window {
  background: #fff;
  border-radius: 8px;
  width: 920px;
  max-width: 100%;
  max-height: 92vh;
  overflow: auto;
  box-shadow: 0 16px 32px rgba(20, 25, 45, 0.25);
}

.sport-card-window--placeholder {
  width: 460px;
}

.sport-card-titlebar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 16px;
  background: #2c5282;
  color: #fff;
}

.sport-card-title {
  font-weight: 600;
}

.sport-card-close {
  background: transparent;
  border: none;
  color: #fff;
  font-size: 22px;
  cursor: pointer;
  line-height: 1;
}

.sport-card-form {
  padding: 16px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.sport-card-top {
  display: grid;
  grid-template-columns: 140px 1fr auto;
  gap: 12px;
  align-items: end;
}

.sport-card-field {
  display: flex;
  flex-direction: column;
  gap: 4px;
  font-size: 12px;
  color: #4a5568;
}

.sport-card-field input,
.sport-card-form textarea {
  font-size: 13px;
  padding: 6px 10px;
  border: 1px solid #cbd5e0;
  border-radius: 6px;
}

.sport-card-flags {
  display: flex;
  gap: 12px;
  padding-bottom: 6px;
}

.sport-checkbox {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  color: #2d3748;
  cursor: pointer;
}

.sport-card-row {
  display: flex;
  flex-direction: column;
  gap: 4px;
  font-size: 12px;
  color: #4a5568;
}

.sport-card-row label,
.sport-card-row legend {
  font-weight: 600;
  color: #2d3748;
}

.sport-card-row textarea {
  resize: vertical;
}

.sport-card-row--wide textarea {
  min-height: 80px;
}

.sport-card-grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr 1fr;
  gap: 12px;
}

.sport-card-field--wide {
  grid-column: span 4;
}

.sport-card-conclusion {
  display: flex;
  gap: 8px;
  align-items: stretch;
}

.sport-card-conclusion textarea {
  flex: 1;
  min-height: 70px;
}

.sport-card-pick {
  width: 36px;
  background: #ebf4ff;
  border: 1px solid #2b6cb0;
  color: #2c5282;
  border-radius: 6px;
  font-size: 18px;
  cursor: pointer;
}

.sport-card-decision {
  display: flex;
  gap: 16px;
}

.sport-card-radio {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 14px;
  cursor: pointer;
}

.sport-card-actions {
  display: flex;
  gap: 8px;
  justify-content: flex-end;
  padding-top: 8px;
  border-top: 1px solid #e2e6ee;
}

.sport-card-placeholder {
  padding: 18px;
  line-height: 1.5;
}

.sport-phrase-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(20, 25, 45, 0.55);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 2100;
  padding: 16px;
}

.sport-phrase-window {
  background: #fff;
  border-radius: 8px;
  width: 540px;
  max-width: 100%;
  max-height: 80vh;
  display: flex;
  flex-direction: column;
  box-shadow: 0 16px 32px rgba(20, 25, 45, 0.25);
  overflow: hidden;
}

.sport-phrase-titlebar {
  background: #2c5282;
  color: #fff;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 10px 16px;
}

.sport-phrase-title {
  font-weight: 600;
}

.sport-phrase-close {
  background: transparent;
  border: none;
  color: #fff;
  font-size: 22px;
  cursor: pointer;
  line-height: 1;
}

.sport-phrase-hint {
  padding: 8px 16px;
  color: #4a5568;
  font-size: 13px;
  border-bottom: 1px solid #edf0f7;
}

.sport-phrase-search {
  display: flex;
  gap: 8px;
  padding: 8px 16px;
  border-bottom: 1px solid #edf0f7;
}

.sport-phrase-search input {
  flex: 1;
  padding: 6px 10px;
  border: 1px solid #cbd5e0;
  border-radius: 6px;
}

.sport-phrase-add {
  width: 36px;
  background: #38a169;
  color: #fff;
  border: none;
  border-radius: 6px;
  font-size: 18px;
  cursor: pointer;
}

.sport-phrase-list {
  flex: 1;
  overflow: auto;
  padding: 4px 8px;
}

.sport-phrase-item {
  display: block;
  width: 100%;
  text-align: left;
  background: transparent;
  border: 1px solid transparent;
  padding: 6px 10px;
  margin: 2px 0;
  cursor: pointer;
  font-size: 13px;
  color: #2d3748;
  border-radius: 4px;
}

.sport-phrase-item:hover {
  background: #f8fafc;
}

.sport-phrase-item--active {
  background: #ebf4ff;
  border-color: #2b6cb0;
  color: #1a365d;
}

.sport-phrase-selected {
  padding: 8px 16px;
  border-top: 1px solid #edf0f7;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.sport-phrase-selected label {
  font-size: 12px;
  color: #4a5568;
}

.sport-phrase-selected textarea {
  border: 1px solid #cbd5e0;
  border-radius: 6px;
  padding: 6px 10px;
  font-size: 13px;
  resize: vertical;
}

.sport-phrase-actions {
  display: flex;
  gap: 8px;
  justify-content: flex-end;
  padding: 8px 16px;
  border-top: 1px solid #edf0f7;
}

@media (max-width: 900px) {
  .sport-card-grid {
    grid-template-columns: 1fr 1fr;
  }

  .sport-card-field--wide {
    grid-column: span 2;
  }

  .sport-card-top {
    grid-template-columns: 1fr;
  }
}

.doctor-card__field {
  display: grid;
  gap: 6px;
  margin-top: 10px;
}

.doctor-card__caption {
  color: var(--muted);
  font-size: 12px;
}

.doctor-card__input {
  width: 100%;
  padding: 10px 12px;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.95);
  color: var(--text);
}

.doctor-card__input:focus {
  outline: 2px solid rgba(12, 125, 123, 0.18);
  border-color: var(--accent);
}

.badge {
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.12);
  color: #ffffff;
}

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

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

.field {
  display: grid;
  gap: 8px;
}

.field span {
  font-size: 14px;
  color: var(--muted);
}

.field input,
.field select,
.field textarea {
  width: 100%;
  border-radius: 14px;
  border: 1px solid var(--line);
  background: #ffffff;
  padding: 12px 14px;
}

.field textarea {
  min-height: 96px;
  resize: vertical;
}

.actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 18px;
}

.table {
  display: grid;
  gap: 12px;
}

.table-row {
  display: grid;
  gap: 4px;
  padding: 16px;
  border-radius: 18px;
  background: var(--panel-strong);
  border: 1px solid var(--line);
}

.table-row.clickable {
  cursor: pointer;
}

.table-row.clickable:hover,
.client-row--active {
  outline: 2px solid rgba(12, 125, 123, 0.18);
}

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

.table-row__title {
  font-size: 17px;
  font-weight: 700;
}

.table-row__meta {
  color: var(--muted);
  font-size: 14px;
}

.status {
  padding: 8px 12px;
  border-radius: 999px;
  font-size: 13px;
  font-weight: 600;
}

.status.ok {
  background: var(--accent-soft);
  color: var(--accent-deep);
}

.status.warn {
  background: var(--warn-soft);
  color: var(--warn);
}

.status.danger {
  background: rgba(157, 47, 47, 0.12);
  color: var(--danger);
}

.timeline {
  display: grid;
  gap: 12px;
}

.timeline-item {
  padding-left: 18px;
  border-left: 3px solid rgba(12, 125, 123, 0.22);
}

.timeline-item strong {
  display: block;
  margin-bottom: 6px;
}

.list {
  margin: 0;
  padding-left: 18px;
  display: grid;
  gap: 10px;
}

.modal {
  position: fixed;
  inset: 0;
  z-index: 20;
}

.modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(10, 19, 32, 0.45);
}

.modal__card {
  position: relative;
  width: min(460px, calc(100% - 32px));
  margin: 80px auto;
  background: #ffffff;
  border-radius: 26px;
  box-shadow: 0 40px 80px rgba(10, 19, 32, 0.28);
  overflow: hidden;
}

#actionModal .modal__card {
  width: min(1640px, calc(100% - 32px));
  max-height: calc(100vh - 32px);
  margin: 8px auto;
  overflow: auto;
  border: 1px solid rgba(23, 48, 74, 0.08);
  background:
    radial-gradient(circle at top left, rgba(12, 125, 123, 0.08), transparent 28%),
    linear-gradient(180deg, #fcfeff 0%, #f4f8fc 100%);
}

.modal__header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 18px 22px;
  border-bottom: 1px solid var(--line);
}

.icon-button {
  width: 40px;
  height: 40px;
  border-radius: 12px;
  border: 0;
  background: rgba(23, 48, 74, 0.08);
  cursor: pointer;
  font-size: 22px;
}

.login-card {
  padding: 18px;
  display: grid;
  gap: 12px;
}

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

.client-create-shell {
  display: grid;
  gap: 10px;
}

.client-create-section {
  display: grid;
  gap: 10px;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

.client-create-section--accent {
  background: transparent;
}

.client-create-section__head {
  display: none;
}

.client-create-section__head strong {
  display: block;
  color: #17304a;
  font-size: 19px;
}

.client-create-section__eyebrow {
  display: block;
  margin-bottom: 4px;
  color: #5f748b;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.client-create-section__badge {
  padding: 7px 11px;
  border: 1px solid rgba(12, 125, 123, 0.18);
  border-radius: 999px;
  background: rgba(12, 125, 123, 0.08);
  color: #0c6765;
  font-size: 12px;
  font-weight: 800;
  white-space: nowrap;
}

.client-create-grid {
  display: grid;
  gap: 10px;
}

.client-create-grid--names {
  grid-template-columns: 1.3fr 1fr 1fr;
}

.client-create-grid--top {
  grid-template-columns: 160px 120px minmax(280px, 1fr);
}

.client-create-grid--document {
  grid-template-columns: 180px 110px 140px 150px minmax(260px, 1fr);
}

.client-create-grid--address {
  grid-template-columns: 90px 180px 180px 170px minmax(220px, 1fr) 72px 72px 72px;
}

.client-create-grid--contacts {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.field--wide {
  grid-column: span 2;
}

.client-create-actions {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  padding: 10px 4px 2px;
}

.client-services-block {
  display: grid;
  gap: 8px;
  padding: 10px 12px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: rgba(23, 48, 74, 0.03);
}

.client-services-block__title {
  font-size: 14px;
  font-weight: 700;
  color: var(--text);
}

.client-services-list {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.client-service-chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 10px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: #ffffff;
  cursor: pointer;
}

.client-service-chip input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.client-service-chip--active {
  border-color: rgba(12, 125, 123, 0.35);
  background: rgba(12, 125, 123, 0.08);
  color: #0c7d7b;
}

.client-service-chip__remove {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  border-radius: 999px;
  background: rgba(12, 125, 123, 0.14);
  color: #0c7d7b;
  font-size: 14px;
  font-weight: 700;
  line-height: 1;
  flex: 0 0 auto;
}

.client-payment-block {
  display: grid;
  gap: 10px;
  padding: 10px 12px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: #ffffff;
}

.client-payment-block__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  font-size: 15px;
}

.client-payment-block__head span {
  color: var(--muted);
}

.client-payment-block__head > span {
  display: none;
}

.client-payment-total {
  display: grid;
  grid-template-columns: auto 130px auto;
  gap: 6px;
  align-items: center;
  margin-left: auto;
}

.client-payment-total input {
  min-height: 34px;
  border: 1px solid #cbd5e1;
  border-radius: 6px;
  padding: 5px 8px;
  text-align: right;
}

.client-payment-list {
  display: grid;
  gap: 8px;
}

.client-payment-row {
  display: grid;
  grid-template-columns: minmax(240px, 1fr) 110px 110px minmax(220px, 0.8fr);
  gap: 8px;
  align-items: end;
  padding: 8px;
  border: 1px solid rgba(148, 163, 184, 0.35);
  border-radius: 8px;
  background: #f8fafc;
}

.client-payment-row__service {
  align-self: center;
  font-weight: 700;
  line-height: 1.25;
}

.client-payment-row .field {
  gap: 3px;
}

.client-payment-row .field span {
  font-size: 12px;
}

.client-payment-row input,
.client-payment-row select {
  min-height: 34px;
}

.cash-page {
  display: grid;
  gap: 14px;
}

.cash-toolbar {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 16px;
}

.cash-toolbar h3 {
  margin: 0 0 6px;
}

.cash-toolbar p {
  margin: 0;
}

.cash-toolbar__filters {
  display: grid;
  grid-template-columns: repeat(3, minmax(140px, auto));
  gap: 10px;
  align-items: end;
}

.cash-summary {
  display: grid;
  grid-template-columns: repeat(4, minmax(160px, 1fr));
  gap: 10px;
}

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

.cash-row {
  display: grid;
  gap: 10px;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--panel-strong);
}

.cash-row__head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
}

.cash-row__head strong,
.cash-row__total strong {
  display: block;
}

.cash-row__head span,
.cash-row__total span,
.cash-service-line small {
  color: var(--muted);
}

.cash-row__total {
  min-width: 140px;
  text-align: right;
}

.cash-services {
  display: grid;
  gap: 6px;
}

.cash-service-line {
  display: grid;
  grid-template-columns: minmax(240px, 1fr) 110px 120px 110px 90px minmax(180px, 0.8fr);
  gap: 8px;
  align-items: center;
  padding: 8px 10px;
  border: 1px solid rgba(14, 31, 53, 0.08);
  border-radius: 6px;
  background: #f8fbfd;
}

.cash-service-line span {
  font-weight: 700;
}

.cash-service-line em {
  font-style: normal;
  color: var(--text);
}

.cash-service-line__discount {
  color: var(--danger) !important;
  font-weight: 700;
}

.cash-row__comment {
  padding: 8px 10px;
  border-radius: 6px;
  background: var(--accent-soft);
  color: var(--accent-deep);
}

.client-driver-classic {
  border: 1px solid rgba(23, 48, 74, 0.12);
  border-radius: 24px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.96) 0%, rgba(242, 247, 252, 0.96) 100%);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.9);
  color: #111827;
  font-size: 22px;
  overflow: hidden;
}

.client-driver-tabs {
  display: flex;
  align-items: flex-end;
  gap: 0;
  min-height: 42px;
  padding: 10px 10px 0;
  border-bottom: 1px solid rgba(23, 48, 74, 0.08);
  background: linear-gradient(180deg, rgba(12, 125, 123, 0.08) 0%, rgba(12, 125, 123, 0.02) 100%);
}

.client-driver-tabs button {
  min-height: 32px;
  padding: 5px 14px;
  border: 1px solid rgba(23, 48, 74, 0.12);
  border-bottom: 0;
  border-top-left-radius: 12px;
  border-top-right-radius: 12px;
  background: rgba(255, 255, 255, 0.72);
  color: #37506a;
  font-size: 13px;
  font-weight: 700;
  cursor: default;
}

.client-driver-tabs button.active {
  background: #ffffff;
  color: #17304a;
}

.client-driver-layout {
  display: grid;
  grid-template-columns: 380px 170px minmax(360px, 1fr) minmax(330px, 0.86fr);
  min-height: 360px;
  gap: 12px;
  padding: 16px;
}

.client-driver-doctors {
  display: grid;
  align-content: start;
  gap: 2px;
}

.client-driver-doctor-field {
  display: grid;
  gap: 2px;
  font-size: 24px;
  font-weight: 500;
}

.client-driver-doctor-field select,
.client-driver-doctor-field input,
.client-driver-chief input {
  width: 100%;
  min-height: 40px;
  border: 1px solid #a7a7a7;
  border-radius: 0;
  background: #ffffff;
  color: #111827;
  font: inherit;
}

.client-driver-categories {
  display: grid;
  grid-template-rows: repeat(3, 1fr);
  padding: 12px;
  border: 1px solid rgba(23, 48, 74, 0.12);
  border-radius: 18px;
  background: linear-gradient(180deg, #ffffff 0%, #f6fafc 100%);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.85);
}

.client-driver-category-row {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  align-items: start;
  justify-items: center;
  gap: 10px;
  padding: 8px 6px 0;
}

.client-driver-category-row--top {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.client-classic-checkbox {
  display: grid;
  gap: 7px;
  align-content: start;
  color: #111827;
  justify-items: center;
  min-width: 0;
  padding: 8px 6px;
  border: 1px solid rgba(23, 48, 74, 0.08);
  border-radius: 14px;
  background: rgba(247, 251, 253, 0.92);
  font-size: 24px;
  line-height: 1.2;
}

.client-classic-checkbox input {
  width: 18px;
  height: 18px;
  margin: 0;
}

.client-driver-box {
  position: relative;
  display: grid;
  align-content: start;
  gap: 10px;
  padding: 14px 14px 16px;
  border-radius: 18px;
  background: linear-gradient(180deg, #ffffff 0%, #f7fafc 100%);
}

.client-driver-box strong {
  display: block;
  margin-bottom: 8px;
  text-align: left;
  font-size: 16px;
  line-height: 1.3;
}

.client-driver-box--limits {
  border: 2px solid #2636b7;
}

.client-driver-box--limits strong {
  color: #2636b7;
}

.client-driver-box--indications {
  border: 2px solid #dc2626;
}

.client-driver-box--indications strong {
  color: #dc2626;
}

.client-driver-red-dot {
  position: absolute;
  left: 18px;
  bottom: 24px;
  color: #dc2626;
  font-size: 24px;
}

.client-driver-footer {
  display: grid;
  grid-template-columns: 360px minmax(360px, 460px);
  gap: 18px;
  align-items: start;
  padding: 0 16px 18px;
}

.client-classic-checkbox--inline {
  grid-template-columns: 1fr;
  justify-items: start;
  font-size: 20px;
}

.client-driver-chief {
  display: grid;
  gap: 3px;
  font-size: 24px;
}

.client-driver-tabs,
.client-driver-doctors,
.client-driver-box,
.client-driver-footer {
  display: none;
}

.client-driver-classic {
  display: inline-block;
  padding: 4px;
}

.client-driver-layout {
  grid-template-columns: 170px;
  min-height: auto;
  padding: 0;
}

.note {
  padding: 14px 16px;
  border-radius: 16px;
  background: rgba(12, 125, 123, 0.08);
  color: var(--accent-deep);
  border: 1px solid rgba(12, 125, 123, 0.14);
}

.toolbar {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 14px;
}

.toolbar .field {
  min-width: 220px;
  flex: 1;
}

.kpi-line {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 14px;
}

.kpi-chip {
  border-radius: 999px;
  padding: 9px 12px;
  background: rgba(23, 48, 74, 0.06);
  color: var(--text);
}

.toast {
  position: fixed;
  right: 24px;
  bottom: 24px;
  z-index: 30;
  min-width: 280px;
  max-width: 420px;
  padding: 14px 16px;
  border-radius: 16px;
  background: #16324f;
  color: #ffffff;
  box-shadow: 0 24px 60px rgba(10, 19, 32, 0.25);
}

.empty {
  padding: 26px;
  text-align: center;
  color: var(--muted);
  border: 1px dashed rgba(23, 48, 74, 0.18);
  border-radius: 18px;
}

.sketch-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 18px;
}

.sketch-sidebar,
.sketch-panel {
  background: #ffffff;
  border: 1px solid var(--line);
  border-radius: 24px;
  box-shadow: var(--shadow);
}

.sketch-sidebar {
  padding: 18px;
  display: grid;
  gap: 18px;
  align-self: start;
}

.sketch-button,
.doctor-pill {
  border: 1px solid var(--line);
  background: #ffffff;
  color: var(--text);
  border-radius: 14px;
  padding: 12px 14px;
  text-align: left;
  cursor: pointer;
}

.sketch-button:hover,
.doctor-pill:hover {
  border-color: rgba(23, 48, 74, 0.16);
  background: #f3f5f7;
}

.sketch-button--muted {
  background: #f6f7f9;
}

.sketch-divider {
  height: 1px;
  background: rgba(23, 48, 74, 0.12);
}

.sketch-main {
  display: grid;
  gap: 18px;
}

.sketch-main--full {
  width: 100%;
}

.sketch-panel {
  padding: 14px;
}

.sketch-toolbar {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  gap: 16px;
  margin-bottom: 16px;
}

.sketch-toolbar__title,
.sketch-client-card h3 {
  margin: 0;
  font-size: 20px;
  font-weight: 500;
}

.sketch-client-card__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.sketch-search {
  min-width: 360px;
  max-width: 420px;
}

.sketch-search span {
  display: none;
}

.duplicate-panel {
  display: grid;
  gap: 8px;
  margin: -4px 0 14px;
  padding: 10px;
  border: 1px solid rgba(169, 91, 23, 0.22);
  border-radius: 14px;
  background: rgba(169, 91, 23, 0.07);
}

.duplicate-panel__title {
  font-size: 13px;
  font-weight: 700;
  color: var(--warn);
}

.duplicate-panel__list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.duplicate-card {
  display: grid;
  gap: 3px;
  min-width: 260px;
  border: 1px solid rgba(169, 91, 23, 0.2);
  border-radius: 12px;
  padding: 8px 10px;
  background: #ffffff;
  color: var(--text);
  text-align: left;
  cursor: pointer;
}

.duplicate-card span {
  font-size: 12px;
  color: var(--muted);
}

.sketch-table {
  display: grid;
  gap: 10px;
}

.sketch-table--excel {
  width: 100%;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: #ffffff;
}

.sketch-table__grid {
  min-width: 0;
  width: 100%;
  display: grid;
  grid-template-columns:
    var(--excel-col-number)
    var(--excel-col-fio)
    var(--excel-col-birth)
    var(--excel-col-registration)
    var(--excel-col-category)
    var(--excel-col-reference)
    var(--excel-col-gynecologist)
    var(--excel-col-stomatologist)
    var(--excel-col-dermatologist)
    var(--excel-col-neurologist)
    var(--excel-col-surgeon)
    var(--excel-col-otolaryngologist)
    var(--excel-col-ophthalmologist)
    var(--excel-col-therapist)
    var(--excel-col-psychiatrist)
    var(--excel-col-infectionist)
    var(--excel-col-phthisiatrician)
    var(--excel-col-uzist)
    var(--excel-col-chairman)
    var(--excel-col-stamp)
    var(--excel-col-note)
    var(--excel-col-encounterDate)
    var(--excel-col-cardNumber)
    var(--excel-col-organization)
    var(--excel-col-agent);
  align-items: stretch;
}

.sketch-table__grid > span {
  padding: 6px 4px;
  border-right: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  font-size: 10px;
  line-height: 1.1;
  overflow: hidden;
}

.sketch-table__grid--head {
  background: #f7f8fa;
  font-weight: 700;
}

.sketch-table__grid--head > span {
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  min-height: 38px;
}

.sketch-head-cell {
  position: relative;
}

.sketch-head-cell--resizable {
  padding-right: 12px !important;
}

.encounter-date-filter-button {
  position: relative;
  z-index: 1;
  display: grid;
  place-items: center;
  gap: 2px;
  width: 100%;
  min-height: 100%;
  border: 0;
  padding: 4px 8px;
  background: transparent;
  color: inherit;
  font: inherit;
  cursor: pointer;
}

.encounter-date-filter-button:hover {
  color: #136f63;
}

.encounter-date-filter-button small {
  font-size: 10px;
  font-weight: 600;
  color: #136f63;
}

.encounter-date-filter-input {
  position: absolute;
  inset: 0 10px 0 0;
  z-index: 2;
  width: calc(100% - 10px);
  height: 100%;
  border: 0;
  padding: 0;
  opacity: 0;
  cursor: pointer;
}

.encounter-date-filter-clear {
  position: absolute;
  z-index: 3;
  right: 12px;
  bottom: 3px;
  display: grid;
  place-items: center;
  width: 18px;
  height: 18px;
  border: 1px solid rgba(19, 111, 99, 0.25);
  border-radius: 999px;
  padding: 0;
  background: #ffffff;
  color: #136f63;
  font-size: 14px;
  line-height: 1;
  cursor: pointer;
}

.col-resize-handle {
  position: absolute;
  top: 0;
  right: 0;
  z-index: 4;
  width: 10px;
  height: 100%;
  border: 0;
  padding: 0;
  background: transparent;
  cursor: col-resize;
}

.col-resize-handle::after {
  content: "";
  position: absolute;
  top: 8px;
  bottom: 8px;
  right: 3px;
  width: 2px;
  background: rgba(23, 48, 74, 0.16);
  border-radius: 999px;
}

.sketch-table__grid--head > span:nth-child(n + 7):nth-child(-n + 20) {
  writing-mode: vertical-rl;
  text-orientation: mixed;
  min-height: 92px;
  padding: 4px 1px;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.02em;
}

.sketch-table__grid--head > span:nth-child(n + 7):nth-child(-n + 20) .col-resize-handle {
  width: 8px;
}

.sketch-table__grid--row {
  width: 100%;
  border: 0;
  background: #ffffff;
  text-align: left;
  cursor: pointer;
}

.sketch-table__grid--row > span {
  display: flex;
  align-items: center;
  white-space: nowrap;
}

.sketch-table__grid--row:hover,
.sketch-table__grid--active {
  background: #f3f5f7;
}

.sketch-table__grid--row:hover > span,
.sketch-table__grid--active > span {
  background: transparent;
}

.excel-doctor-mark {
  justify-content: center;
  font-weight: 700;
}

.excel-doctor-mark--done {
  color: #11623a;
}

.excel-doctor-mark--required {
  color: #8a5200;
}

.sketch-table__grid--skeleton {
  cursor: default;
  pointer-events: none;
}

.dashboard-table-skeleton-bar {
  display: block;
  width: min(74%, 84px);
  height: 8px;
  border-radius: 999px;
  background: linear-gradient(90deg, #e5e9ed 25%, #f4f6f8 50%, #e5e9ed 75%);
  background-size: 200% 100%;
  animation: dashboard-table-skeleton-pulse 1.2s ease-in-out infinite;
}

.sketch-table__grid--skeleton > span:nth-child(n + 7):nth-child(-n + 19) .dashboard-table-skeleton-bar {
  width: 8px;
  margin-inline: auto;
}

@keyframes dashboard-table-skeleton-pulse {
  from {
    background-position: 200% 0;
  }

  to {
    background-position: -200% 0;
  }
}

.sketch-toolbar__meta {
  margin-left: auto;
  font-size: 13px;
  color: var(--muted);
}

.table-pagination {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
}

.table-pagination__pages {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.table-pagination__button,
.table-pagination__page {
  min-width: 42px;
}

.table-pagination__page {
  border: 1px solid var(--line);
  border-radius: 10px;
  background: #ffffff;
  color: var(--text);
  padding: 8px 12px;
  cursor: pointer;
  font: inherit;
}

.table-pagination__page--active {
  background: var(--accent);
  color: #ffffff;
  border-color: var(--accent);
}

.table-pagination__page:disabled,
.table-pagination__button:disabled {
  opacity: 0.45;
  cursor: default;
}

.services-page {
  display: flex;
  flex-direction: column;
  min-height: calc(100vh - 96px);
  height: calc(100vh - 96px);
}

.services-page__header {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  gap: 12px;
  margin-bottom: 16px;
  flex-wrap: wrap;
}

.services-add-inline {
  margin-left: 4px;
}

.services-table {
  flex: 1 1 auto;
  width: 100%;
  min-width: 760px;
  min-height: 460px;
  height: calc(100vh - 235px);
  max-height: none;
  overflow: auto;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: #ffffff;
}

.services-table__grid {
  min-width: 1480px;
  display: grid;
  grid-template-columns:
    var(--excel-col-serviceId)
    var(--excel-col-serviceName)
    var(--excel-col-serviceGroup)
    var(--excel-col-servicePrice)
    var(--excel-col-serviceRecall)
    var(--excel-col-serviceNote)
    var(--excel-col-serviceDoctors)
    var(--excel-col-serviceStatus);
  align-items: stretch;
  width: 100%;
}

.services-table__grid > span {
  min-width: 0;
  padding: 9px 10px;
  border-right: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  overflow: hidden;
  text-overflow: ellipsis;
}

.services-table__grid > span:last-child {
  border-right: 0;
}

.services-table__grid--head {
  position: sticky;
  top: 0;
  z-index: 2;
  background: #f4f6f8;
  font-weight: 700;
}

.services-table__grid--head > span {
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  min-height: 42px;
  text-align: center;
  white-space: nowrap;
}

.services-table__grid--row {
  width: 100%;
  border: 0;
  padding: 0;
  background: #ffffff;
  color: var(--text);
  font: inherit;
  text-align: left;
  cursor: pointer;
  appearance: none;
}

.services-table__grid--row > span {
  min-height: 40px;
  font-size: 13px;
  line-height: 1.25;
}

.services-table__grid--row > span:nth-child(2),
.services-table__grid--row > span:nth-child(6),
.services-table__grid--row > span:nth-child(7) {
  white-space: normal;
}

.services-table__grid--row:hover {
  background: rgba(12, 125, 123, 0.06);
}

.sketch-doctors-block {
  margin-bottom: 12px;
}

.sketch-doctors {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 14px;
}

.sketch-doctors--top {
  margin-top: 0;
  max-width: 100%;
}

.doctor-pill {
  border-radius: 999px;
  min-height: 32px;
  padding: 6px 12px;
  text-align: center;
  font-size: 14px;
  font-weight: 600;
}

.doctor-pill--completed {
  border-color: rgba(25, 135, 84, 0.35);
  background: #eaf6ef;
  color: #11623a;
}

.doctor-pill--draft {
  border-color: rgba(194, 123, 0, 0.38);
  background: #fff7e6;
  color: #7a4b00;
}

.doctor-pill--draft-history {
  border-color: rgba(151, 111, 43, 0.42);
  background: linear-gradient(90deg, #fff7e6 0%, #eef4fb 100%);
  color: #5f481e;
}

.doctor-pill--history {
  border-color: rgba(74, 111, 165, 0.32);
  background: #eef4fb;
  color: #31527d;
}

.doctor-pill--wide {
  text-align: left;
}

.doctor-classic-backdrop,
.chairman-backdrop,
.psychiatrist-backdrop {
  position: fixed;
  inset: 0;
  z-index: 80;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
  background: rgba(11, 25, 38, 0.42);
}

.doctor-classic-window,
.chairman-window,
.psychiatrist-window {
  width: min(1120px, 96vw);
  max-height: 92vh;
  overflow: auto;
  border: 1px solid rgba(23, 48, 74, 0.24);
  border-radius: 14px;
  background: #fffdf7;
  box-shadow: 0 24px 80px rgba(11, 25, 38, 0.28);
}

.doctor-classic-titlebar,
.chairman-titlebar,
.psychiatrist-titlebar {
  position: sticky;
  top: 0;
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 12px 16px;
  border-bottom: 1px solid rgba(23, 48, 74, 0.18);
  background: #17304a;
  color: #fff;
}

.doctor-classic-title,
.chairman-title,
.psychiatrist-title {
  font-size: 18px;
  font-weight: 700;
}

.doctor-classic-title--stacked {
  display: grid;
  gap: 2px;
  line-height: 1.2;
}

.doctor-classic-title--stacked small {
  color: rgba(255, 255, 255, 0.72);
  font-size: 12px;
  font-weight: 500;
}

.doctor-classic-close,
.chairman-close,
.psychiatrist-close {
  width: 34px;
  height: 34px;
  border: 0;
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.16);
  color: #fff;
  cursor: pointer;
  font-size: 22px;
}

.doctor-classic-form,
.chairman-form,
.psychiatrist-form {
  padding: 16px;
}

.chairman-form-context {
  display: grid;
  gap: 4px;
  margin-bottom: 12px;
  padding: 10px 12px;
  border: 1px solid rgba(23, 48, 74, 0.16);
  border-radius: 8px;
  background: #f6f8fa;
}

.chairman-form-context strong {
  color: #17304a;
  font-size: 14px;
}

.chairman-form-context span {
  color: #5a6673;
  font-size: 12px;
}

.chairman-blood .doctor-classic-select {
  min-width: 136px;
  padding-right: 34px;
  appearance: auto;
  cursor: pointer;
}

.chairman-blood-row label {
  cursor: default;
}

.chairman-form--lmk .chairman-conclusion-right,
.chairman-form--prof .chairman-conclusion-right,
.chairman-form--marine .chairman-conclusion-right,
.chairman-form--drug .chairman-conclusion-right,
.chairman-form--sport .chairman-conclusion-right {
  display: none;
}

.chairman-form--lmk .chairman-footer,
.chairman-form--prof .chairman-footer,
.chairman-form--marine .chairman-footer,
.chairman-form--drug .chairman-footer,
.chairman-form--sport .chairman-footer {
  grid-template-columns: repeat(2, minmax(0, max-content));
}

.doctor-classic-body {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 210px;
  gap: 16px;
}

.doctor-classic-main,
.chairman-main,
.psychiatrist-main {
  display: grid;
  gap: 10px;
}

.doctor-classic-row,
.chairman-row,
.psychiatrist-row {
  display: grid;
  grid-template-columns: 120px minmax(0, 1fr);
  align-items: start;
  gap: 10px;
}

.doctor-classic-label,
.chairman-label,
.psychiatrist-label {
  padding-top: 7px;
  color: #26394a;
  font-size: 14px;
  font-weight: 700;
}

.doctor-classic-field,
.chairman-field,
.psychiatrist-field {
  min-width: 0;
}

.doctor-classic-input,
.doctor-classic-select,
.doctor-classic-textarea,
.chairman-input,
.chairman-select,
.chairman-textarea,
.psychiatrist-input,
.psychiatrist-select,
.psychiatrist-textarea {
  width: 100%;
  border: 1px solid rgba(23, 48, 74, 0.24);
  border-radius: 9px;
  padding: 7px 9px;
  background: #ffffff;
  color: var(--text);
  font: inherit;
}

.doctor-classic-textarea,
.chairman-textarea,
.psychiatrist-textarea {
  min-height: 58px;
  resize: vertical;
}

.doctor-classic-textarea--diagnosis {
  min-height: 78px;
}

.doctor-classic-complaints-left,
.doctor-classic-complaints-right,
.doctor-classic-bottom-line {
  display: grid;
  gap: 8px;
}

.doctor-classic-field--complaints {
  display: grid;
  grid-template-columns: 180px minmax(0, 1fr);
  gap: 10px;
}

.doctor-classic-radio-group,
.chairman-checkboxes,
.psychiatrist-checkboxes {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 14px;
}

.doctor-classic-radio,
.chairman-checkbox,
.psychiatrist-checkbox {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 14px;
}

.doctor-classic-sidebar {
  display: grid;
  align-content: start;
  gap: 8px;
}

.doctor-classic-sidebtn {
  border: 1px solid rgba(23, 48, 74, 0.18);
  border-radius: 10px;
  padding: 9px 10px;
  background: #f5efe2;
  color: #17304a;
  cursor: pointer;
  font-weight: 700;
}

.medical-requirements-picker {
  position: fixed;
  inset: 0;
  z-index: 3200;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 16px;
  background: rgba(210, 218, 224, 0.5);
}

.medical-requirements-picker__panel {
  width: min(760px, 94vw);
  min-height: 360px;
  border: 2px solid #8a969f;
  background: #eef3f6;
  box-shadow: 8px 8px 18px rgba(0, 0, 0, 0.24);
  color: #111827;
  font: 14px Arial, sans-serif;
}

.medical-requirements-picker__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 8px 10px;
}

.medical-requirements-picker__close {
  width: 28px;
  height: 28px;
  border: 1px solid #95a0a8;
  background: #e5ebef;
  cursor: pointer;
  font-size: 20px;
  line-height: 1;
}

.medical-requirements-picker__label {
  display: block;
  padding: 0 10px 4px;
  font-weight: 700;
}

.medical-requirements-picker__top {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 40px 40px 112px;
  gap: 10px;
  padding: 0 10px 10px;
}

.medical-requirements-picker__search {
  min-height: 36px;
  border: 2px inset #d2d8dd;
  background: #fff;
  padding: 6px 8px;
  font: inherit;
}

.medical-requirements-picker__small,
.medical-requirements-picker__ok {
  border: 2px outset #d2d8dd;
  background: #e6ecef;
  cursor: pointer;
  font: inherit;
  font-weight: 700;
}

.medical-requirements-picker__list {
  height: 260px;
  margin: 0 10px 10px;
  overflow: auto;
  border: 2px inset #d2d8dd;
  background: #f8fbfd;
}

.medical-requirements-picker__item {
  display: grid;
  width: 100%;
  border: 0;
  padding: 5px 8px;
  background: transparent;
  color: #111827;
  cursor: pointer;
  text-align: left;
  font: inherit;
}

.medical-requirements-picker__item:hover,
.medical-requirements-picker__item--active {
  background: #d4e2ef;
}

.medical-requirements-picker__empty {
  padding: 10px;
  color: #52616d;
}

[data-doctor-exam-delete] {
  display: none !important;
}

.doctor-classic-actions,
.chairman-actions,
.psychiatrist-actions {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  margin-top: 16px;
}

.doctor-classic-bottom-line {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.therapist-window {
  width: min(1180px, 96vw);
}

.therapist-body {
  grid-template-columns: minmax(0, 1fr) 180px;
}

.therapist-row {
  grid-template-columns: 178px minmax(0, 1fr);
}

.therapist-textarea--short {
  min-height: 48px;
}

.therapist-section-label {
  color: #26394a;
  font-size: 14px;
  font-weight: 700;
}

.therapist-objective-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 8px 20px;
  margin-left: 178px;
}

.therapist-field {
  display: grid;
  grid-template-columns: 120px minmax(0, 1fr);
  align-items: center;
  gap: 8px;
}

.therapist-field label {
  color: #26394a;
  font-size: 14px;
  font-weight: 700;
  text-align: right;
}

.therapist-bottom-line {
  grid-template-columns: 150px minmax(160px, auto) minmax(180px, 1fr);
  align-items: center;
}

.sectioned-doctor-window {
  width: min(1160px, 96vw);
}

.sectioned-doctor-body {
  grid-template-columns: minmax(0, 1fr) 180px;
}

.sectioned-doctor-row {
  grid-template-columns: 178px minmax(0, 1fr);
}

.sectioned-doctor-section {
  display: grid;
  gap: 8px;
}

.sectioned-doctor-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 8px 20px;
  margin-left: 178px;
}

.sectioned-doctor-grid--single {
  grid-template-columns: 1fr;
}

.sectioned-doctor-field {
  display: grid;
  grid-template-columns: 140px minmax(0, 1fr);
  align-items: center;
  gap: 8px;
}

.sectioned-doctor-field--full {
  grid-column: 1 / -1;
  align-items: start;
}

.sectioned-doctor-field label {
  color: #26394a;
  font-size: 14px;
  font-weight: 700;
  text-align: right;
}

.sectioned-doctor-textarea {
  min-height: 82px;
}

.sectioned-doctor-bottom-line {
  grid-template-columns: 150px minmax(160px, auto) minmax(180px, 1fr);
  align-items: center;
}

@media (max-width: 860px) {
  .therapist-body,
  .doctor-classic-body {
    grid-template-columns: 1fr;
  }

  .therapist-row,
  .doctor-classic-row {
    grid-template-columns: 1fr;
  }

  .therapist-objective-grid {
    grid-template-columns: 1fr;
    margin-left: 0;
  }

  .therapist-field {
    grid-template-columns: 1fr;
  }

  .therapist-field label {
    text-align: left;
  }

  .therapist-bottom-line {
    grid-template-columns: 1fr;
  }

  .sectioned-doctor-body {
    grid-template-columns: 1fr;
  }

  .sectioned-doctor-row {
    grid-template-columns: 1fr;
  }

  .sectioned-doctor-grid {
    grid-template-columns: 1fr;
    margin-left: 0;
  }

  .sectioned-doctor-field {
    grid-template-columns: 1fr;
  }

  .sectioned-doctor-field label {
    text-align: left;
  }

  .sectioned-doctor-bottom-line {
    grid-template-columns: 1fr;
  }
}

.psy-window {
  width: min(1120px, 96vw);
  max-height: 92vh;
  overflow: auto;
  border: 1px solid rgba(23, 48, 74, 0.24);
  border-radius: 14px;
  background: #fffdf7;
  box-shadow: 0 24px 80px rgba(11, 25, 38, 0.28);
}

.psy-form {
  padding: 16px;
}

.psy-top,
.psy-content,
.psy-body {
  display: grid;
  gap: 10px;
}

.psy-row {
  display: grid;
  grid-template-columns: 120px minmax(0, 1fr);
  align-items: start;
  gap: 10px;
}

.psy-label,
.psy-small-label {
  color: #26394a;
  font-size: 14px;
  font-weight: 700;
}

.psy-label {
  padding-top: 7px;
}

.psy-field-main,
.psy-meta-item,
.psy-field,
.psy-complaints-left,
.psy-complaints-right {
  min-width: 0;
}

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

.psy-meta-item {
  display: grid;
  gap: 5px;
}

.psy-meta-item--address {
  grid-column: span 2;
}

.psy-row--complaints {
  grid-template-columns: 180px minmax(0, 1fr);
}

.psy-complaints-left,
.psy-complaints-right {
  display: grid;
  gap: 5px;
}

.psy-row--tabs {
  display: block;
}

.psy-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  border-bottom: 1px solid rgba(23, 48, 74, 0.18);
}

.psy-tab {
  border: 1px solid rgba(23, 48, 74, 0.16);
  border-bottom: 0;
  border-radius: 10px 10px 0 0;
  padding: 7px 12px;
  background: #f5efe2;
  color: #17304a;
  cursor: pointer;
  font-weight: 700;
}

.psy-tab--active {
  background: #ffffff;
  color: var(--accent-deep);
}

.psy-main-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 170px;
  gap: 16px;
  margin-top: 12px;
}

.psy-panel {
  display: grid;
  gap: 10px;
}

.psy-grid {
  display: grid;
  gap: 10px;
}

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

.psy-grid--single {
  grid-template-columns: 1fr;
}

.psy-field {
  display: grid;
  gap: 5px;
}

.psy-field--full {
  grid-column: 1 / -1;
}

.psy-textarea,
.psy-issued-textarea,
.psy-note-textarea {
  min-height: 74px;
}

.psy-footer-box,
.psy-note-block {
  display: grid;
  gap: 8px;
  padding: 12px;
  border: 1px solid rgba(23, 48, 74, 0.12);
  border-radius: 12px;
  background: rgba(245, 239, 226, 0.45);
}

.psy-footer-title {
  font-weight: 700;
}

.psy-conclusion-inline {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px 12px;
}

.psy-sidebar {
  display: grid;
  align-content: start;
  gap: 8px;
}

.psy-sidebar-meta {
  display: grid;
  gap: 8px;
  margin-top: 8px;
}

.psy-sidebar-meta__row {
  display: grid;
  gap: 5px;
}
.client-facts {
  display: grid;
  gap: 10px;
  margin-top: 14px;
  color: var(--text);
}

.encounter-panel {
  display: grid;
  gap: 12px;
  margin-top: 16px;
  padding: 14px;
  border: 1px solid rgba(23, 48, 74, 0.14);
  border-radius: 14px;
  background: #fffaf0;
}

.encounter-panel__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
}

.encounter-panel__head > div {
  display: grid;
  gap: 4px;
}

.encounter-panel__head span,
.encounter-grid span {
  color: var(--muted);
  font-size: 13px;
}

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

.encounter-grid > div {
  display: grid;
  gap: 4px;
  padding: 10px;
  border-radius: 12px;
  background: #ffffff;
}

.encounter-services,
.document-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.document-history {
  display: grid;
  gap: 10px;
  margin-top: 16px;
  padding: 14px;
  border: 1px solid rgba(23, 48, 74, 0.12);
  border-radius: 14px;
  background: #fbfdff;
}

.document-history__row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  border: 1px solid rgba(23, 48, 74, 0.1);
  border-radius: 12px;
  padding: 10px 12px;
  background: #ffffff;
  color: var(--text);
  text-align: left;
  cursor: pointer;
}

.document-history__row span {
  font-weight: 700;
}

.document-history__row small {
  color: var(--muted);
}

.encounter-services span {
  padding: 6px 10px;
  border-radius: 999px;
  background: #eaf5f4;
  color: #17304a;
  font-size: 13px;
  font-weight: 700;
}

.encounter-history {
  display: grid;
  gap: 8px;
}

.encounter-history button {
  border: 1px solid rgba(23, 48, 74, 0.14);
  border-radius: 10px;
  padding: 8px 10px;
  background: #fff;
  text-align: left;
  cursor: pointer;
}

.encounter-history button.active {
  border-color: #0c7d7b;
  background: rgba(12, 125, 123, 0.08);
}

.encounter-panel > .encounter-grid,
.encounter-panel > .encounter-services {
  display: none;
}

.operator-visit-form > .encounter-grid {
  display: grid;
}

.operator-visit-form {
  display: grid;
  gap: 12px;
  margin-top: 2px;
  padding: 14px;
  border: 1px solid rgba(12, 125, 123, 0.16);
  border-radius: 16px;
  background: #ffffff;
  box-shadow: 0 16px 34px rgba(23, 48, 74, 0.07);
}

.operator-visit-form__title {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
}

.operator-visit-form__title span {
  color: var(--muted);
  font-size: 13px;
}

.operator-visit-form .encounter-grid label,
.operator-comment {
  display: grid;
  gap: 5px;
}

.operator-visit-form input,
.operator-visit-form select,
.operator-visit-form textarea {
  width: 100%;
  border: 1px solid rgba(23, 48, 74, 0.16);
  border-radius: 10px;
  padding: 8px 10px;
  background: #fbfdff;
  color: var(--text);
}

.operator-services {
  display: grid;
  gap: 10px;
}

.operator-services__top {
  display: grid;
  grid-template-columns: minmax(150px, 0.7fr) minmax(180px, 1fr);
  gap: 10px;
  align-items: center;
}

.operator-service-groups {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.operator-service-groups button {
  border: 1px solid rgba(23, 48, 74, 0.12);
  border-radius: 999px;
  padding: 6px 10px;
  background: #f7fafc;
  color: var(--text);
  cursor: pointer;
}

.operator-service-groups button.active {
  border-color: rgba(12, 125, 123, 0.32);
  background: rgba(12, 125, 123, 0.1);
  color: var(--accent-deep);
  font-weight: 700;
}

.operator-service-list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  max-height: 260px;
  overflow: auto;
  padding-right: 4px;
  align-content: flex-start;
}

.operator-service-chip {
  max-width: 100%;
}

.operator-service-chip strong {
  color: var(--accent-deep);
  font-size: 13px;
  font-weight: 600;
}

.driver-category-panel {
  margin-top: 12px;
  padding: 12px;
  border: 1px solid #cfd7e6;
  border-radius: 8px;
  background: #f8fafc;
}

.driver-category-panel__head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 10px;
}

.driver-category-panel__head span,
.driver-category-price span {
  color: #64748b;
  font-size: 12px;
}

.driver-category-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.driver-category-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-height: 32px;
  padding: 4px 10px;
  border: 1px solid #cbd5e1;
  border-radius: 6px;
  background: #fff;
  font-weight: 600;
}

.driver-category-price {
  display: grid;
  grid-template-columns: minmax(120px, 180px) 1fr;
  gap: 12px;
  margin-top: 12px;
  align-items: end;
}

.driver-category-price label,
.driver-category-price div {
  display: grid;
  gap: 4px;
}

.driver-category-price input {
  width: 100%;
  min-height: 34px;
  border: 1px solid #cbd5e1;
  border-radius: 6px;
  padding: 6px 8px;
}

.operator-visit-summary {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.operator-visit-summary > div {
  display: grid;
  gap: 4px;
  padding: 10px;
  border-radius: 12px;
  background: rgba(12, 125, 123, 0.07);
}

.operator-visit-summary span {
  color: var(--muted);
  font-size: 12px;
}

.operator-visit-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 8px;
}

.document-panel {
  margin-top: 18px;
}

.document-preview {
  max-height: 56vh;
  overflow: auto;
  padding: 14px;
  border-radius: 12px;
  background: #111827;
  color: #f8fafc;
  white-space: pre-wrap;
  font: 14px/1.55 "Consolas", monospace;
}

.modal--driver-print .modal__backdrop {
  background: transparent;
}

.modal--driver-print .modal__card {
  width: 382px;
  top: 50%;
  margin: 0 auto;
  transform: translateY(-50%);
  border-radius: 10px;
  border: 1px solid #9aa3ad;
  background: linear-gradient(180deg, #eef2f5 0%, #d9dee3 100%);
  box-shadow: 0 18px 42px rgba(15, 23, 42, 0.28), 0 1px 0 #ffffff inset;
  overflow: hidden;
}

.modal--driver-print .modal__header {
  min-height: 34px;
  padding: 7px 10px 5px 12px;
  border-bottom: 1px solid #b8c0c8;
  background: linear-gradient(180deg, #f8fafc 0%, #d7dde4 100%);
}

.modal--driver-print .modal__header h2 {
  margin: 0;
  color: #1f2933;
  font: 700 14px/1.2 Arial, sans-serif;
}

.modal--driver-print .icon-button {
  width: 24px;
  height: 24px;
  border: 1px solid #aeb6bf;
  border-radius: 5px;
  background: linear-gradient(180deg, #ffffff 0%, #d9dee4 100%);
  color: #2f3a45;
  font: 700 19px/19px Arial, sans-serif;
}

.modal--driver-print .login-card {
  display: block;
  padding: 12px 14px 14px;
  background: transparent;
}

.driver-print-classic {
  color: #1f2933;
  font: 700 13px/1.2 Arial, sans-serif;
}

.driver-print-classic__fio,
.driver-print-classic__input {
  height: 36px;
  border: 1px solid #9da7b1;
  border-radius: 4px;
  background: linear-gradient(180deg, #ffffff 0%, #eef1f4 100%);
  color: #17202a;
  font: 700 16px/1 Arial, sans-serif;
  padding: 4px 8px;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.08) inset;
}

.driver-print-classic__fio {
  display: block;
  width: 100%;
  margin-bottom: 14px;
  font-size: 18px;
}

.driver-print-classic__caption {
  margin: 0 0 7px 4px;
  color: #2c3742;
}

.driver-print-classic__caption--primary {
  margin-top: 9px;
  margin-left: 4px;
  font-size: 12px;
}

.driver-print-classic__lookup {
  display: grid;
  grid-template-columns: 72px 108px 1fr;
  gap: 9px;
  align-items: center;
  margin-bottom: 9px;
}

.driver-print-classic__input {
  width: 100%;
  font-size: 16px;
}

.driver-print-classic__input--series {
  text-align: center;
}

.driver-print-classic__input--date {
  font-size: 14px;
}

.driver-print-classic__button {
  min-height: 34px;
  border: 1px solid #8e98a3;
  border-radius: 5px;
  background: linear-gradient(180deg, #ffffff 0%, #d8dde3 100%);
  color: #202a35;
  font: 700 12px/1.05 Arial, sans-serif;
  cursor: pointer;
  padding: 4px 8px;
  box-shadow: 0 1px 0 #ffffff inset, 0 1px 2px rgba(15, 23, 42, 0.16);
}

.driver-print-classic__button:hover:not(:disabled) {
  background: linear-gradient(180deg, #ffffff 0%, #cfd7df 100%);
  border-color: #6f7d89;
}

.driver-print-classic__button:active:not(:disabled) {
  background: linear-gradient(180deg, #c7d0d9 0%, #edf1f5 100%);
  box-shadow: 0 1px 3px rgba(15, 23, 42, 0.22) inset;
}

.driver-print-classic__button:disabled {
  color: #7d8791;
  opacity: 0.78;
  cursor: default;
}

.driver-print-classic__button--find {
  height: 36px;
}

.driver-print-classic__button--duplicate {
  width: 132px;
  height: 27px;
  min-height: 27px;
  margin-left: 4px;
  padding: 2px 6px;
}

.driver-print-classic__primary {
  display: grid;
  grid-template-columns: 60px 112px 92px;
  gap: 9px;
  align-items: center;
  margin: 0 0 13px 45px;
}

.driver-print-classic__actions {
  display: grid;
  gap: 10px;
}

.driver-print-classic__actions--driver {
  grid-template-columns: 1fr 1fr;
  gap: 9px;
  margin-bottom: 11px;
}

.driver-print-classic__button--wide {
  display: block;
  width: 188px;
  margin: 0 auto 9px;
}

.driver-print-classic__error {
  margin: 0 0 9px;
  padding: 6px 8px;
  border: 1px solid #b45353;
  border-radius: 5px;
  background: #f8e1e1;
  color: #6e1111;
  font-size: 12px;
}

.driver-series-picker {
  position: fixed;
  inset: 0;
  z-index: 3000;
  display: grid;
  place-items: center;
  background: rgba(15, 23, 42, 0.08);
}

.driver-series-picker__panel {
  width: min(820px, calc(100vw - 40px));
  height: min(620px, calc(100vh - 48px));
  display: grid;
  grid-template-rows: auto auto 1fr auto;
  border: 2px solid #a4adb6;
  border-radius: 4px;
  background: #eef3f6;
  box-shadow: 3px 4px 0 rgba(15, 23, 42, 0.16), 0 20px 42px rgba(15, 23, 42, 0.22);
  color: #1f2933;
  font: 700 13px/1.2 Arial, sans-serif;
  padding: 12px;
}

.driver-series-picker__head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 28px;
  gap: 10px;
  align-items: center;
  margin-bottom: 9px;
}

.driver-series-picker__close {
  width: 28px;
  height: 26px;
  border: 1px solid #9aa5b0;
  border-radius: 4px;
  background: linear-gradient(180deg, #ffffff 0%, #d9dee4 100%);
  color: #1f2933;
  font: 700 18px/1 Arial, sans-serif;
  cursor: pointer;
}

.driver-series-picker__top {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 136px;
  gap: 16px;
  align-items: start;
  margin-bottom: 14px;
}

.driver-series-picker__search {
  height: 88px;
  border: 2px inset #f4f7fa;
  background: #f4f8fa;
  color: #1f2933;
  font: 700 14px/1 Arial, sans-serif;
  padding: 10px;
}

.driver-series-picker__ok {
  height: 84px;
  border: 1px solid #8e98a3;
  border-radius: 3px;
  background: linear-gradient(180deg, #ffffff 0%, #d8dde3 100%);
  color: #202a35;
  font: 700 13px/1 Arial, sans-serif;
  cursor: pointer;
}

.driver-series-picker__list {
  overflow-y: auto;
  border: 2px inset #f4f7fa;
  background: #f7fafc;
  padding: 4px;
}

.driver-series-picker__item {
  display: block;
  width: 100%;
  min-height: 24px;
  border: 0;
  background: transparent;
  color: #1f2933;
  font: 700 13px/1.1 Arial, sans-serif;
  text-align: left;
  cursor: pointer;
  padding: 4px 8px;
}

.driver-series-picker__item:hover,
.driver-series-picker__item--active {
  background: #d8e4ef;
}

.driver-series-picker__selected {
  min-height: 24px;
  margin-top: 8px;
  color: #2b3845;
  font: 700 13px/1.2 Arial, sans-serif;
}

.modal--print-instruction .modal__backdrop {
  background: transparent;
}

.modal--print-instruction .modal__card {
  width: min(760px, calc(100vw - 34px));
  top: 8%;
  margin: 0 auto;
  border-radius: 0;
  border: 2px solid #a8a8a8;
  background: #e6e6e6;
  box-shadow: 3px 4px 0 rgba(0, 0, 0, 0.18), 0 18px 38px rgba(15, 23, 42, 0.22);
  overflow: hidden;
}

.modal--print-instruction .modal__header {
  min-height: 30px;
  padding: 5px 8px;
  border-bottom: 1px solid #b8b8b8;
  background: #e6e6e6;
}

.modal--print-instruction .modal__header h2 {
  margin: 0;
  color: #2a2a2a;
  font: 400 14px/1.2 Arial, sans-serif;
}

.modal--print-instruction .icon-button {
  width: 22px;
  height: 22px;
  border: 0;
  border-radius: 0;
  background: transparent;
  color: #4a4a4a;
  font: 400 22px/20px Arial, sans-serif;
}

.modal--print-instruction .login-card {
  display: block;
  padding: 8px 10px 10px;
  background: #e6e6e6;
}

.driver-print-instruction {
  color: #202020;
  font: 13px/1.25 Arial, sans-serif;
}

.driver-print-instruction__intro {
  min-height: 62px;
  padding: 14px 18px;
  border: 2px inset #f5f5f5;
  background: #e9e9e9;
}

.driver-print-instruction__steps {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 6px;
  margin-top: 18px;
}

.driver-print-instruction__step {
  min-height: 285px;
  border: 2px inset #f5f5f5;
  background: #e3e3e3;
  padding: 12px 10px;
  position: relative;
}

.driver-print-instruction__head {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr);
  gap: 10px;
  align-items: start;
  min-height: 82px;
}

.driver-print-instruction__head p {
  margin: 0;
  color: #272727;
}

.driver-print-instruction__number {
  display: inline-flex;
  width: 31px;
  height: 31px;
  align-items: center;
  justify-content: center;
  border: 2px outset #2f5399;
  background: #002b8f;
  color: #ffffff;
  font: 700 24px/1 Arial, sans-serif;
  box-shadow: 1px 1px 0 #001850;
}

.driver-print-instruction__footer {
  display: flex;
  justify-content: flex-end;
  padding: 12px 6px 0;
}

.driver-print-instruction__button {
  min-width: 86px;
  min-height: 28px;
  border: 2px outset #f0f0f0;
  background: #e2e2e2;
  color: #1f1f1f;
  font: 400 13px/1 Arial, sans-serif;
  cursor: pointer;
}

.printer-illustration {
  width: 155px;
  height: 118px;
  margin: 76px auto 0;
  position: relative;
}

.printer-illustration__body {
  width: 112px;
  height: 78px;
  position: absolute;
  left: 18px;
  top: 20px;
  border: 3px solid #5e6268;
  border-radius: 8px 8px 4px 4px;
  background: linear-gradient(180deg, #9da3aa 0%, #777e86 58%, #60676f 100%);
  box-shadow: 5px 6px 0 rgba(0, 0, 0, 0.14);
}

.printer-illustration__top-paper {
  position: absolute;
  left: 26px;
  top: 6px;
  width: 61px;
  height: 19px;
  border: 2px solid #3b3f45;
  background: linear-gradient(135deg, #f6f9fb 0%, #cfd8df 100%);
  transform: skewX(-12deg);
}

.printer-illustration__slot {
  position: absolute;
  left: 17px;
  top: 31px;
  width: 75px;
  height: 9px;
  border-radius: 9px;
  background: #22272d;
}

.printer-illustration__tray {
  position: absolute;
  right: -24px;
  bottom: -13px;
  width: 76px;
  height: 31px;
  border: 3px solid #5e6268;
  background: #87909a;
  transform: skewY(-7deg);
}

.printer-illustration__paper {
  position: absolute;
  right: -17px;
  bottom: -7px;
  width: 58px;
  height: 18px;
  background: #dfe9df;
  border: 1px solid #8fa58c;
  transform: skewY(-7deg);
}

.printer-illustration__arrow {
  position: absolute;
  width: 40px;
  height: 40px;
}

.printer-illustration__arrow::before {
  content: "";
  position: absolute;
  width: 38px;
  height: 25px;
  border-right: 5px solid #4f9d3a;
  border-bottom: 5px solid #4f9d3a;
}

.printer-illustration__arrow::after {
  content: "";
  position: absolute;
  width: 0;
  height: 0;
  border: 9px solid transparent;
}

.printer-illustration__arrow--out {
  right: 4px;
  bottom: 5px;
}

.printer-illustration__arrow--out::before {
  transform: rotate(-12deg);
}

.printer-illustration__arrow--out::after {
  right: -6px;
  bottom: -7px;
  border-left-color: #4f9d3a;
}

.printer-illustration__arrow--in {
  right: 4px;
  top: 42px;
}

.printer-illustration__arrow--in::before {
  transform: rotate(52deg);
}

.printer-illustration__arrow--in::after {
  right: 3px;
  top: -8px;
  border-bottom-color: #4f9d3a;
}

.modal--front-print-check .modal__backdrop {
  background: transparent;
}

#actionModal.modal--front-print-check .modal__card {
  width: 374px;
  max-height: none;
  top: 50%;
  left: 50%;
  margin: 0;
  transform: translate(-2%, -50%);
  overflow: hidden;
}

.modal--front-print-check .modal__card {
  width: 374px;
  top: 50%;
  left: 50%;
  margin: 0;
  transform: translate(-2%, -50%);
  border-radius: 0;
  border: 2px solid #a8a8a8;
  background: #e6e6e6;
  box-shadow: 3px 4px 0 rgba(0, 0, 0, 0.18), 0 16px 32px rgba(15, 23, 42, 0.18);
  overflow: hidden;
}

.modal--front-print-check .modal__header {
  min-height: 28px;
  padding: 4px 7px;
  border-bottom: 1px solid #bebebe;
  background: #e6e6e6;
}

.modal--front-print-check .modal__header h2 {
  margin: 0;
  color: #2a2a2a;
  font: 400 14px/1.2 Arial, sans-serif;
}

.modal--front-print-check .icon-button {
  width: 22px;
  height: 22px;
  border: 0;
  border-radius: 0;
  background: transparent;
  color: #6a6a6a;
  font: 400 22px/20px Arial, sans-serif;
}

.modal--front-print-check .login-card {
  display: block;
  padding: 16px 14px 10px;
  background: #e6e6e6;
}

.driver-front-check {
  display: grid;
  grid-template-columns: 48px minmax(0, 1fr);
  column-gap: 12px;
  color: #202020;
  font: 12px/1.25 Arial, sans-serif;
}

.driver-front-check__icon {
  width: 38px;
  height: 38px;
  align-self: start;
  justify-self: center;
  border-radius: 50%;
  border: 2px solid #7f8ba0;
  background: radial-gradient(circle at 35% 30%, #4d82c7 0%, #0b4d9f 54%, #07306c 100%);
  box-shadow: 1px 2px 0 rgba(0, 0, 0, 0.28);
  color: #ffffff;
  text-align: center;
  font: 700 31px/38px Arial, sans-serif;
}

.driver-front-check__text p {
  margin: 0;
}

.driver-front-check__actions {
  grid-column: 1 / -1;
  display: flex;
  justify-content: flex-end;
  gap: 12px;
  margin-top: 16px;
  padding-right: 4px;
}

.driver-front-check__button {
  min-width: 88px;
  min-height: 27px;
  border: 2px outset #f0f0f0;
  background: #e2e2e2;
  color: #1f1f1f;
  font: 400 13px/1 Arial, sans-serif;
  cursor: pointer;
}

.driver-front-check__button:active {
  border-style: inset;
}

.calendar-page {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.calendar-page__header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
}

.calendar-page__header h3 {
  margin: 0;
  font-size: 26px;
}

.calendar-page__header p {
  margin: 6px 0 0;
}

.calendar-summary {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.calendar-summary > div {
  padding: 16px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: #ffffff;
}

.calendar-summary span {
  display: block;
  color: var(--muted);
  font-size: 13px;
}

.calendar-summary strong {
  display: block;
  margin-top: 6px;
  font-size: 28px;
}

.calendar-filters,
.calendar-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.calendar-filters--groups {
  margin-top: -6px;
}

.calendar-filters button,
.calendar-actions button {
  border: 1px solid var(--line);
  background: #ffffff;
  color: var(--text);
  border-radius: 10px;
  padding: 8px 11px;
  cursor: pointer;
}

.calendar-filters button.active,
.calendar-actions button:hover {
  background: var(--accent-soft);
  border-color: rgba(12, 125, 123, 0.4);
}

.calendar-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.calendar-row {
  display: grid;
  grid-template-columns: 140px minmax(240px, 1fr) 170px 120px minmax(230px, auto);
  gap: 12px;
  align-items: center;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: #ffffff;
}

.calendar-row__date strong,
.calendar-row__date span,
.calendar-row__main span,
.calendar-row__main small {
  display: block;
}

.calendar-row__date span,
.calendar-row__main small,
.calendar-row__phone {
  color: var(--muted);
  font-size: 13px;
}

.calendar-row__client {
  border: 0;
  padding: 0;
  background: transparent;
  color: var(--accent-deep);
  font: inherit;
  font-weight: 700;
  text-align: left;
  cursor: pointer;
}

.calendar-status {
  justify-self: start;
  border-radius: 999px;
  padding: 7px 10px;
  font-size: 13px;
  font-weight: 700;
}

.calendar-status--overdue {
  background: rgba(157, 47, 47, 0.12);
  color: var(--danger);
}

.calendar-status--today,
.calendar-status--soon {
  background: var(--warn-soft);
  color: var(--warn);
}

.calendar-status--planned,
.calendar-status--rescheduled {
  background: var(--accent-soft);
  color: var(--accent-deep);
}

.calendar-status--done,
.calendar-status--skipped {
  background: rgba(105, 128, 154, 0.14);
  color: var(--muted);
}

.chart-page {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.chart-page__header,
.chart-page__actions,
.chart-list__row,
.chart-visit-meta {
  display: flex;
  gap: 12px;
}

.chart-page__header {
  align-items: flex-start;
  justify-content: space-between;
  flex-wrap: wrap;
}

.chart-page__header h3 {
  margin: 0;
  font-size: 26px;
}

.chart-page__header p {
  margin: 6px 0 0;
}

.chart-page__actions {
  flex-wrap: wrap;
}

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

.chart-main-grid {
  align-items: start;
}

.chart-profile-card {
  min-height: 100%;
}

.chart-record-card {
  padding-bottom: 14px;
}

.chart-record-entries {
  margin-top: 14px;
  overflow: auto;
  min-height: 160px;
  max-height: 520px;
  padding-right: 4px;
}

.chart-record-resizer {
  width: 100%;
  height: 12px;
  margin-top: 8px;
  border: 0;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(23, 48, 74, 0.08), rgba(12, 125, 123, 0.18), rgba(23, 48, 74, 0.08));
  cursor: ns-resize;
}

.chart-record-resizer:hover {
  background: linear-gradient(90deg, rgba(23, 48, 74, 0.14), rgba(12, 125, 123, 0.26), rgba(23, 48, 74, 0.14));
}

.ambulatory-sheet {
  border-radius: 8px;
  background:
    linear-gradient(#f5f1df 1px, transparent 1px) 0 0 / 100% 34px,
    linear-gradient(90deg, rgba(82, 79, 58, 0.08) 1px, transparent 1px) 0 0 / 34px 100%,
    #fbf8eb;
  border: 1px solid rgba(81, 70, 42, 0.24);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.55);
}

.ambulatory-sheet__toolbar {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  margin-top: 14px;
  flex-wrap: wrap;
}

.ambulatory-sheet__toolbar-text {
  display: grid;
  gap: 4px;
}

.ambulatory-sheet__toolbar-text strong {
  color: #2f2a1d;
}

.ambulatory-sheet__toolbar-text span {
  color: #5d5644;
  font-size: 12px;
}

.ambulatory-sheet__topline,
.ambulatory-sheet__header,
.ambulatory-sheet__grid,
.ambulatory-sheet__table,
.ambulatory-sheet__signatures,
.ambulatory-entry__head,
.ambulatory-entry__footer {
  display: grid;
}

.ambulatory-sheet__topline {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
  padding-bottom: 10px;
  border-bottom: 1px solid rgba(81, 70, 42, 0.28);
  font-size: 12px;
  color: #564d38;
}

.ambulatory-sheet__topline span:last-child {
  text-align: right;
}

.ambulatory-sheet__header {
  grid-template-columns: minmax(220px, 0.9fr) minmax(360px, 1.4fr);
  gap: 16px;
  padding: 16px 0 18px;
  align-items: start;
  border-bottom: 1px solid rgba(81, 70, 42, 0.28);
}

.ambulatory-sheet__clinic strong,
.ambulatory-sheet__clinic span,
.ambulatory-sheet__title div {
  display: block;
}

.ambulatory-sheet__clinic strong {
  font-size: 16px;
  margin-bottom: 6px;
}

.ambulatory-sheet__clinic span {
  color: #5d5644;
  line-height: 1.45;
}

.ambulatory-sheet__title {
  text-align: center;
  font-weight: 700;
  line-height: 1.35;
}

.ambulatory-sheet__title div:last-child {
  margin-top: 6px;
}

.ambulatory-sheet__subtitle {
  margin-top: 6px;
  font-size: 12px;
  font-weight: 500;
}

.ambulatory-sheet__grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0;
  border-left: 1px solid rgba(81, 70, 42, 0.28);
  border-top: 1px solid rgba(81, 70, 42, 0.28);
}

.ambulatory-sheet__grid--compact {
  margin-top: 16px;
}

.ambulatory-sheet__line {
  min-height: 66px;
  padding: 8px 10px;
  border-right: 1px solid rgba(81, 70, 42, 0.28);
  border-bottom: 1px solid rgba(81, 70, 42, 0.28);
}

.ambulatory-sheet__line--wide {
  grid-column: span 2;
}

.ambulatory-sheet__line span,
.ambulatory-entry__line span,
.ambulatory-entry__row span {
  display: block;
  margin-bottom: 4px;
  color: #5d5644;
  font-size: 12px;
}

.ambulatory-sheet__line strong,
.ambulatory-entry__line strong {
  display: block;
  color: #1d2025;
  font-size: 14px;
  line-height: 1.45;
  font-weight: 600;
}

.ambulatory-sheet__control {
  width: 100%;
  min-height: 36px;
  border: 1px solid rgba(81, 70, 42, 0.28);
  border-radius: 8px;
  padding: 8px 10px;
  background: rgba(255, 255, 255, 0.92);
  color: #1d2025;
  font: inherit;
}

.ambulatory-sheet__control--textarea {
  min-height: 80px;
  resize: vertical;
}

.ambulatory-sheet__control--inline {
  display: inline-block;
  width: auto;
  min-width: 140px;
  margin-left: 6px;
  vertical-align: middle;
}

.ambulatory-sheet__table-cell-edit .ambulatory-sheet__control {
  min-height: 34px;
}

.ambulatory-sheet__section {
  margin-top: 16px;
}

.ambulatory-sheet__single-field {
  min-height: 48px;
  padding: 8px 10px;
  border: 1px solid rgba(81, 70, 42, 0.28);
  background: rgba(255, 255, 255, 0.34);
}

.ambulatory-sheet__section-title {
  padding: 8px 10px;
  border: 1px solid rgba(81, 70, 42, 0.28);
  border-bottom: 0;
  font-size: 13px;
  font-weight: 700;
  background: rgba(255, 255, 255, 0.3);
}

.ambulatory-sheet__table {
  border-left: 1px solid rgba(81, 70, 42, 0.28);
  border-top: 1px solid rgba(81, 70, 42, 0.28);
  font-size: 13px;
}

.ambulatory-sheet__table--dispensary {
  grid-template-columns: 0.9fr 0.9fr 1.6fr 0.8fr 1fr;
}

.ambulatory-sheet__table--diagnosis {
  grid-template-columns: 0.9fr 1.8fr 1fr 0.9fr;
}

.ambulatory-sheet__table > div {
  min-height: 52px;
  padding: 8px 10px;
  border-right: 1px solid rgba(81, 70, 42, 0.28);
  border-bottom: 1px solid rgba(81, 70, 42, 0.28);
  line-height: 1.4;
}

.ambulatory-sheet__table > div:nth-child(-n + 5),
.ambulatory-sheet__table--diagnosis > div:nth-child(-n + 4) {
  font-weight: 700;
  background: rgba(255, 255, 255, 0.38);
}

.ambulatory-sheet__factors,
.ambulatory-sheet__signature-table,
.ambulatory-sheet__commission-grid {
  display: grid;
}

.ambulatory-sheet__factors {
  grid-template-columns: 1fr 1fr 0.8fr 1.3fr 1.2fr;
  border-left: 1px solid rgba(81, 70, 42, 0.28);
  border-top: 1px solid rgba(81, 70, 42, 0.28);
  margin-top: 12px;
}

.ambulatory-sheet__factors > div {
  min-height: 44px;
  padding: 8px 10px;
  border-right: 1px solid rgba(81, 70, 42, 0.28);
  border-bottom: 1px solid rgba(81, 70, 42, 0.28);
  line-height: 1.4;
}

.ambulatory-sheet__factors-head {
  font-weight: 700;
  background: rgba(255, 255, 255, 0.38);
}

.ambulatory-sheet__entries {
  overflow: auto;
  border: 1px solid rgba(81, 70, 42, 0.28);
  border-top: 0;
  padding: 12px;
  background: rgba(255, 255, 255, 0.24);
}

.ambulatory-entry {
  border: 1px solid rgba(81, 70, 42, 0.28);
  background: rgba(255, 255, 255, 0.54);
}

.ambulatory-entry + .ambulatory-entry {
  margin-top: 12px;
}

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

.ambulatory-entry__line,
.ambulatory-entry__row {
  padding: 10px;
  border-bottom: 1px solid rgba(81, 70, 42, 0.18);
}

.ambulatory-entry__head .ambulatory-entry__line:first-child,
.ambulatory-entry__footer .ambulatory-entry__line:first-child {
  border-right: 1px solid rgba(81, 70, 42, 0.18);
}

.ambulatory-entry__line--wide {
  grid-column: 1 / -1;
}

.ambulatory-entry__row p {
  margin: 0;
  line-height: 1.5;
  white-space: pre-wrap;
}

.ambulatory-entry__row .ambulatory-sheet__control,
.ambulatory-entry__line .ambulatory-sheet__control {
  margin-top: 2px;
}

.ambulatory-entry--blank {
  opacity: 0.8;
}

.ambulatory-sheet__commission {
  border: 1px solid rgba(81, 70, 42, 0.28);
  border-top: 0;
}

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

.ambulatory-sheet__commission-grid--triple {
  grid-template-columns: 0.9fr 1.5fr 0.8fr;
}

.ambulatory-sheet__footer-note {
  min-height: 92px;
  padding: 12px 10px;
  border-top: 1px solid rgba(81, 70, 42, 0.28);
  line-height: 1.5;
  white-space: pre-wrap;
}

.ambulatory-sheet__signature-table {
  grid-template-columns: 1fr 0.7fr 1fr;
  border-top: 1px solid rgba(81, 70, 42, 0.28);
}

.ambulatory-sheet__signature-table > div {
  min-height: 52px;
  padding: 10px;
  border-right: 1px solid rgba(81, 70, 42, 0.28);
  border-bottom: 1px solid rgba(81, 70, 42, 0.28);
}

.ambulatory-sheet__signature-table > div:nth-child(3n) {
  border-right: 0;
}

.ambulatory-sheet__signature-label,
.ambulatory-sheet__signature-sign,
.ambulatory-sheet__signature-name {
  display: flex;
  align-items: center;
}

.ambulatory-sheet__stamp-line {
  margin-top: 10px;
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  font-size: 12px;
}

.ambulatory-sheet__stamp-line strong {
  font-weight: 700;
}

.ambulatory-sheet__signatures {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  border-top: 1px solid rgba(81, 70, 42, 0.28);
}

.ambulatory-sheet__signatures > div {
  min-height: 64px;
  padding: 10px;
}

.ambulatory-sheet__signatures > div + div {
  border-left: 1px solid rgba(81, 70, 42, 0.28);
}

.chart-fields {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px 16px;
}

.chart-fields span,
.chart-note span {
  display: block;
  color: var(--muted);
  font-size: 13px;
}

.chart-fields strong {
  display: block;
  margin-top: 4px;
  font-size: 15px;
  line-height: 1.4;
}

.chart-note {
  margin-top: 16px;
  padding-top: 16px;
  border-top: 1px solid var(--line);
}

.chart-note p {
  margin: 6px 0 0;
  line-height: 1.5;
}

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

.chart-list__row {
  align-items: center;
  justify-content: space-between;
  padding: 12px 14px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: #ffffff;
}

.chart-list__row > div {
  min-width: 0;
}

.chart-list__row strong,
.chart-list__row small {
  display: block;
}

.chart-list__row small {
  margin-top: 4px;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.4;
}

.chart-visit-meta {
  align-items: flex-end;
  flex-direction: column;
  white-space: nowrap;
}

.import-page {
  display: grid;
  gap: 16px;
}

.import-page__header,
.import-upload-box__actions,
.import-preview-row,
.import-preview-row__meta {
  display: flex;
  gap: 12px;
}

.import-page__header {
  align-items: flex-start;
  justify-content: space-between;
  flex-wrap: wrap;
}

.import-page__header h3 {
  margin: 0;
  font-size: 26px;
}

.import-page__header p {
  margin: 6px 0 0;
}

.import-help {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
  margin-top: 18px;
}

.import-help strong {
  display: block;
  margin-bottom: 8px;
}

.import-help ol,
.import-help ul {
  margin: 0;
  padding-left: 18px;
  color: var(--muted);
  line-height: 1.6;
}

.import-upload-box {
  display: grid;
  gap: 12px;
  margin-top: 18px;
  padding: 16px;
  border: 1px dashed rgba(12, 125, 123, 0.35);
  border-radius: 14px;
  background: rgba(12, 125, 123, 0.04);
}

.import-upload-box__actions {
  flex-wrap: wrap;
}

.import-success {
  margin-top: 14px;
  padding: 12px 14px;
  border-radius: 12px;
  background: rgba(12, 125, 123, 0.08);
  color: var(--accent-deep);
}

.import-stats-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  margin-bottom: 16px;
}

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

.import-preview-row {
  align-items: center;
  justify-content: space-between;
  padding: 12px 14px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: #ffffff;
}

.import-preview-row strong,
.import-preview-row small {
  display: block;
}

.import-preview-row small {
  margin-top: 4px;
  color: var(--muted);
  font-size: 13px;
}

.import-preview-row__meta {
  align-items: flex-end;
  flex-direction: column;
}

.employee-grid,
.employee-card-grid {
  display: grid;
  gap: 16px;
  margin-top: 18px;
}

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

.employee-card-grid {
  grid-template-columns: 0.85fr 1.15fr;
}

.employee-note {
  margin-top: 16px;
}

.employee-note--error {
  background: rgba(157, 47, 47, 0.12);
  color: var(--danger);
  border-color: rgba(157, 47, 47, 0.2);
}

.sketch-client-card--full {
  width: 100%;
}

@media (max-width: 1180px) {
  .hero,
  .two-col,
  .cards-grid,
  .three-col {
    grid-template-columns: 1fr;
  }

  .ambulatory-sheet__header,
  .ambulatory-sheet__topline,
  .ambulatory-entry__head,
  .ambulatory-entry__footer,
  .ambulatory-sheet__signatures,
  .ambulatory-sheet__commission-grid,
  .ambulatory-sheet__signature-table {
    grid-template-columns: 1fr;
  }

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

  .ambulatory-sheet__line--wide {
    grid-column: span 2;
  }

  .ambulatory-sheet__table--dispensary,
  .ambulatory-sheet__table--diagnosis,
  .ambulatory-sheet__factors {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

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

  .sidebar {
    gap: 18px;
  }

  .topbar {
    flex-direction: column;
  }

  .hero-grid,
  .stats-grid,
  .field-grid.cols-2,
  .sketch-layout,
  .employee-grid,
  .employee-card-grid {
    grid-template-columns: 1fr;
  }

  .sketch-toolbar {
    flex-direction: column;
    align-items: stretch;
  }

  .sketch-search {
    min-width: 0;
  }

  .sketch-doctors {
    grid-template-columns: 1fr;
  }

  .doctor-classic-body,
  .doctor-classic-row,
  .psy-main-layout,
  .psy-row,
  .psy-row--meta-grid,
  .psy-row--complaints,
  .psy-grid--two,
  .chairman-row,
  .psychiatrist-row,
  .doctor-classic-field--complaints,
  .doctor-classic-bottom-line {
    grid-template-columns: 1fr;
  }

  .psy-meta-item--address {
    grid-column: auto;
  }

  .encounter-grid {
    grid-template-columns: 1fr;
  }

  .operator-services__top,
  .operator-service-list,
  .client-payment-row,
  .cash-toolbar__filters,
  .cash-summary,
  .cash-service-line,
  .client-driver-layout,
  .client-driver-footer,
  .driver-category-price,
  .operator-visit-summary,
  .calendar-summary,
  .calendar-row,
  .chart-summary-grid,
  .chart-main-grid,
  .chart-fields,
  .document-template-grid,
  .import-help,
  .import-stats-grid {
    grid-template-columns: 1fr;
  }

  .calendar-row {
    align-items: start;
  }

  .client-driver-layout {
    min-height: auto;
  }

  .client-driver-footer {
    padding: 8px;
  }

  .chart-list__row,
  .chart-page__header,
  .cash-toolbar,
  .cash-row__head,
  .import-page__header,
  .import-preview-row {
    flex-direction: column;
    align-items: stretch;
  }

  .chart-visit-meta,
  .import-preview-row__meta {
    align-items: flex-start;
  }

  .ambulatory-sheet {
    padding: 14px;
  }

  .ambulatory-sheet__grid,
  .ambulatory-sheet__table--dispensary,
  .ambulatory-sheet__table--diagnosis,
  .ambulatory-sheet__factors,
  .ambulatory-sheet__commission-grid--triple,
  .ambulatory-sheet__signature-table {
    grid-template-columns: 1fr;
  }

  .ambulatory-sheet__line--wide {
    grid-column: auto;
  }

  .services-page {
    min-height: auto;
    height: auto;
  }

  .services-table {
    min-width: 0;
    min-height: 420px;
    height: 62vh;
  }

  .services-table__grid {
    min-width: 1180px;
  }
}


