
.inactivity-warning-overlay[data-v-6cd1be1f] {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.7);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 9999;
  backdrop-filter: blur(4px);
}
.inactivity-warning-modal[data-v-6cd1be1f] {
  background: white;
  border-radius: 16px;
  padding: 2rem;
  max-width: 400px;
  width: 90%;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
  text-align: center;
  animation: slideIn-6cd1be1f 0.3s ease-out;
}
@keyframes slideIn-6cd1be1f {
from {
    opacity: 0;
    transform: translateY(-20px) scale(0.95);
}
to {
    opacity: 1;
    transform: translateY(0) scale(1);
}
}
.warning-icon[data-v-6cd1be1f] {
  font-size: 4rem;
  margin-bottom: 1rem;
  animation: pulse-6cd1be1f 2s ease-in-out infinite;
}
@keyframes pulse-6cd1be1f {
0%, 100% {
    transform: scale(1);
}
50% {
    transform: scale(1.1);
}
}
.warning-title[data-v-6cd1be1f] {
  font-size: 1.5rem;
  font-weight: 700;
  color: #dc2626;
  margin: 0 0 1rem 0;
}
.warning-message[data-v-6cd1be1f] {
  font-size: 1rem;
  color: #4b5563;
  margin: 0 0 1.5rem 0;
  line-height: 1.5;
}
.warning-timer[data-v-6cd1be1f] {
  margin-bottom: 1.5rem;
}
.timer-circle[data-v-6cd1be1f] {
  width: 80px;
  height: 80px;
  border-radius: 50%;
  background: linear-gradient(135deg, #ef4444 0%, #dc2626 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto;
  box-shadow: 0 4px 12px rgba(239, 68, 68, 0.3);
}
.timer-text[data-v-6cd1be1f] {
  font-size: 1.5rem;
  font-weight: 700;
  color: white;
}
.continue-button[data-v-6cd1be1f] {
  width: 100%;
  padding: 0.875rem 1.5rem;
  background: linear-gradient(135deg, #2563EB 0%, #A855F7 100%);
  color: white;
  border: none;
  border-radius: 8px;
  font-size: 1rem;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s ease;
}
.continue-button[data-v-6cd1be1f]:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 16px rgba(37, 99, 235, 0.3);
}
.continue-button[data-v-6cd1be1f]:active {
  transform: translateY(0);
}

/* Анимация появления/исчезновения */
.fade-enter-active[data-v-6cd1be1f],
.fade-leave-active[data-v-6cd1be1f] {
  transition: opacity 0.3s ease;
}
.fade-enter-from[data-v-6cd1be1f],
.fade-leave-to[data-v-6cd1be1f] {
  opacity: 0;
}

/* Темная тема */
@media (prefers-color-scheme: dark) {
.inactivity-warning-modal[data-v-6cd1be1f] {
    background: #1f2937;
    color: white;
}
.warning-message[data-v-6cd1be1f] {
    color: #d1d5db;
}
}


* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}
body {
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', 'Roboto', 'Oxygen',
    'Ubuntu', 'Cantarell', 'Fira Sans', 'Droid Sans', 'Helvetica Neue',
    sans-serif;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  background-color: #f8f9fa;
}
#app {
  min-height: 100vh;
}


.language-switcher[data-v-7b1336fd] {
  display: inline-flex;
  align-items: center;
  gap: 0;
  background: rgba(255, 255, 255, 0.15);
  border-radius: 10px;
  padding: 0;
  border: 1px solid rgba(255, 255, 255, 0.25);
  overflow: hidden;
}
.lang-button[data-v-7b1336fd] {
  background: transparent;
  border: none;
  color: white;
  cursor: pointer;
  font-size: 0.85rem;
  font-weight: 700;
  letter-spacing: 0.3px;
  padding: 0.4rem 0.75rem;
  transition: all 0.2s ease;
  border-right: 1px solid rgba(255, 255, 255, 0.25);
  opacity: 0.7;
}
.lang-button[data-v-7b1336fd]:last-child {
  border-right: none;
}
.lang-button[data-v-7b1336fd]:hover {
  background: rgba(255, 255, 255, 0.2);
  opacity: 1;
}
.lang-button.active[data-v-7b1336fd] {
  background: rgba(255, 255, 255, 0.3);
  opacity: 1;
  font-weight: 800;
}
.lang-button[data-v-7b1336fd]:active {
  transform: scale(0.98);
}


.home-page[data-v-14c615b0] {
  --accent: #2563eb;
  --accent-hover: #1d4ed8;
  --accent-soft: #eff6ff;
  --surface: #ffffff;
  --surface-muted: #f8fafc;
  --border: #e2e8f0;
  --border-strong: #cbd5e1;
  --text-primary: #0f172a;
  --text-secondary: #475569;

  min-height: 100vh;
  background: linear-gradient(180deg, #f8fafc 0%, #f1f5f9 100%);
  color: var(--text-primary);
}

/* Header */
.header[data-v-14c615b0] {
  background: linear-gradient(90deg, #1e3a8a 0%, #1e40af 45%, #2563eb 100%);
  color: #f8fafc;
  padding: 1rem 0;
  border-bottom: 1px solid rgba(255, 255, 255, 0.2);
  box-shadow: 0 8px 28px rgba(30, 64, 175, 0.22);
}
.header-content[data-v-14c615b0] {
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0 1rem;
}
.title-section[data-v-14c615b0] {
  flex: 1;
}
.title[data-v-14c615b0] {
  font-size: 1.5rem;
  font-weight: 700;
  letter-spacing: 0.25px;
  margin-bottom: 0.35rem;
}
.welcome-text[data-v-14c615b0] {
  font-size: 0.9rem;
  opacity: 0.88;
}
.user-name-accent[data-v-14c615b0] {
  font-weight: 700;
  color: #dbeafe;
}
.header-actions[data-v-14c615b0] {
  display: flex;
  align-items: center;
  gap: 1.5rem;
}
.datetime-widget[data-v-14c615b0] {
  text-align: center;
  padding: 0.5rem 1rem;
  background: rgba(255, 255, 255, 0.14);
  border-radius: 8px;
  border: 1px solid rgba(255, 255, 255, 0.28);
}
.current-time[data-v-14c615b0] {
  font-size: 1.2rem;
  font-weight: 700;
  font-family: 'Courier New', monospace;
  margin-bottom: 0.25rem;
}
.current-date[data-v-14c615b0] {
  font-size: 0.75rem;
  opacity: 0.9;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}



/* Пользовательское меню */
.user-menu[data-v-14c615b0] {
  position: relative;
}
.user-avatar[data-v-14c615b0] {
  width: 40px;
  height: 40px;
  background: rgba(255, 255, 255, 0.15);
  border: 2px solid rgba(255, 255, 255, 0.35);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s ease;
  font-size: 1rem;
}
.user-avatar[data-v-14c615b0]:hover {
  background: rgba(255, 255, 255, 0.24);
  transform: scale(1.05);
}
.user-dropdown[data-v-14c615b0] {
  position: absolute;
  top: 50px;
  right: 0;
  background: var(--surface);
  color: var(--text-primary);
  border-radius: 12px;
  box-shadow: 0 20px 40px rgba(15, 23, 42, 0.18);
  min-width: 200px;
  z-index: 1000;
  border: 1px solid var(--border);
  overflow: hidden;
  animation: slideDown-14c615b0 0.2s ease-out;
}
.user-info[data-v-14c615b0] {
  padding: 1rem;
  background: var(--surface-muted);
}
.user-name[data-v-14c615b0] {
  display: block;
  font-weight: 600;
  color: var(--text-primary);
  font-size: 0.875rem;
  margin-bottom: 0.25rem;
}
.user-email[data-v-14c615b0] {
  display: block;
  color: var(--text-secondary);
  font-size: 0.75rem;
}
.user-specialization[data-v-14c615b0] {
  display: block;
  color: var(--accent);
  font-size: 0.7rem;
  font-weight: 600;
  margin-top: 0.25rem;
}
.user-clinic[data-v-14c615b0] {
  margin-top: 0.5rem;
  padding-top: 0.5rem;
  border-top: 1px solid var(--border);
}
.user-clinic .clinic-name[data-v-14c615b0] {
  display: block;
  color: var(--text-primary);
  font-size: 0.75rem;
  font-weight: 500;
  margin-bottom: 0.25rem;
}
.clinic-region[data-v-14c615b0] {
  display: block;
  color: var(--text-secondary);
  font-size: 0.7rem;
}
.dropdown-divider[data-v-14c615b0] {
  margin: 0;
  border: none;
  border-top: 1px solid var(--border);
}
.logout-btn[data-v-14c615b0] {
  width: 100%;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.75rem 1rem;
  background: none;
  border: none;
  color: #b91c1c;
  font-size: 0.875rem;
  cursor: pointer;
  transition: background-color 0.2s ease;
}
.logout-btn[data-v-14c615b0]:hover {
  background: #fee2e2;
}
.logout-icon[data-v-14c615b0] {
  font-size: 1rem;
}

/* Основной контент */
.main-content[data-v-14c615b0] {
  max-width: 1200px;
  margin: 0 auto;
  padding: 2.75rem 1rem;
}

/* Секция поиска */
.search-section[data-v-14c615b0] {
  background: var(--surface);
  border-radius: 16px;
  padding: 2rem;
  border: 1px solid var(--border);
  box-shadow: 0 16px 40px rgba(15, 23, 42, 0.08);
  margin-bottom: 2rem;
}
.search-intro[data-v-14c615b0] {
  text-align: center;
  margin-bottom: 2rem;
}
.search-title[data-v-14c615b0] {
  font-size: 1.875rem;
  font-weight: 700;
  color: var(--text-primary);
  margin-bottom: 0.5rem;
}
.search-subtitle[data-v-14c615b0] {
  font-size: 1rem;
  color: var(--text-secondary);
  font-weight: 400;
}

/* Поисковик */
.search-container[data-v-14c615b0] {
  position: relative;
  max-width: 600px;
  margin: 0 auto 2rem;
}
.search-wrapper[data-v-14c615b0] {
  position: relative;
}
.search-input-wrapper[data-v-14c615b0] {
  display: flex;
  background: var(--surface);
  border: 1px solid var(--border-strong);
  border-radius: 10px;
  padding: 0.75rem 1rem;
  transition: all 0.2s ease;
}
.search-input-wrapper[data-v-14c615b0]:focus-within {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.12);
}
.search-input[data-v-14c615b0] {
  flex: 1;
  background: transparent;
  border: none;
  color: var(--text-primary);
  font-size: 1rem;
  padding: 0.5rem;
  outline: none;
  font-weight: 500;
}
.search-input[data-v-14c615b0]::-moz-placeholder {
  color: #94a3b8;
  font-weight: 400;
}
.search-input[data-v-14c615b0]::placeholder {
  color: #94a3b8;
  font-weight: 400;
}
.search-btn[data-v-14c615b0] {
  background: var(--accent);
  border: none;
  color: white;
  padding: 0.55rem 1rem;
  border-radius: 8px;
  font-size: 0.95rem;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s ease;
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 88px;
}
.search-btn[data-v-14c615b0]:hover {
  background: var(--accent-hover);
  transform: translateY(-1px);
  box-shadow: 0 10px 20px rgba(37, 99, 235, 0.24);
}
.search-btn[data-v-14c615b0]:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}
.search-spinner[data-v-14c615b0] {
  width: 16px;
  height: 16px;
  border: 2px solid rgba(37, 99, 235, 0.22);
  border-top: 2px solid var(--accent);
  border-radius: 50%;
  animation: spin-14c615b0 1s linear infinite;
}
.search-btn .search-spinner[data-v-14c615b0] {
  border-color: rgba(255, 255, 255, 0.35);
  border-top-color: #ffffff;
}

/* Dropdown поиска */
.search-dropdown[data-v-14c615b0] {
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  background: var(--surface);
  border-radius: 12px;
  box-shadow: 0 24px 36px rgba(15, 23, 42, 0.16);
  border: 1px solid var(--border);
  overflow: hidden;
  z-index: 1000;
  margin-top: 4px;
  animation: slideDownFade-14c615b0 0.2s ease-out;
  max-height: 400px;
  overflow-y: auto;
}
.dropdown-header[data-v-14c615b0] {
  padding: 0.75rem 1rem;
  background: var(--surface-muted);
  border-bottom: 1px solid var(--border);
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.results-count[data-v-14c615b0] {
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--text-primary);
}
.showing-limit[data-v-14c615b0] {
  font-size: 0.75rem;
  color: var(--text-secondary);
  font-style: italic;
}
.dropdown-list[data-v-14c615b0] {
  max-height: 320px;
  overflow-y: auto;
}
.dropdown-item[data-v-14c615b0] {
  display: flex;
  align-items: center;
  padding: 0.875rem 1rem;
  cursor: pointer;
  transition: all 0.2s ease;
  border-bottom: 1px solid var(--border);
}
.dropdown-item[data-v-14c615b0]:last-child {
  border-bottom: none;
}
.dropdown-item[data-v-14c615b0]:hover {
  background: var(--surface-muted);
  transform: translateX(2px);
}
.dropdown-patient-info[data-v-14c615b0] {
  flex: 1;
}
.dropdown-patient-name[data-v-14c615b0] {
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--text-primary);
  margin-bottom: 0.25rem;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex-wrap: wrap;
}
.my-patient-badge[data-v-14c615b0] {
  font-size: 0.7rem;
  background: var(--accent-soft);
  color: var(--accent-hover);
  padding: 0.125rem 0.375rem;
  border-radius: 4px;
  font-weight: 500;
  border: 1px solid rgba(37, 99, 235, 0.25);
}
.other-patient-badge[data-v-14c615b0] {
  font-size: 0.7rem;
  background: #f1f5f9;
  color: var(--text-secondary);
  padding: 0.125rem 0.375rem;
  border-radius: 4px;
  font-weight: 500;
  border: 1px solid var(--border);
}
.dropdown-patient-details[data-v-14c615b0] {
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
}
.dropdown-iin[data-v-14c615b0],
.dropdown-birth[data-v-14c615b0] {
  font-size: 0.75rem;
  color: var(--text-secondary);
}
.dropdown-select-icon[data-v-14c615b0] {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  color: var(--accent);
  font-weight: bold;
  margin-left: 1rem;
}
.dropdown-no-results[data-v-14c615b0] {
  padding: 1.5rem;
  text-align: center;
  color: var(--text-secondary);
}
.dropdown-no-results p[data-v-14c615b0] {
  font-size: 0.85rem;
  margin-top: 0.5rem;
  opacity: 0.8;
}
.dropdown-loading[data-v-14c615b0] {
  padding: 1rem;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  color: var(--text-secondary);
  font-size: 0.875rem;
}

/* Действия */
.actions-section[data-v-14c615b0] {
  text-align: center;
  display: flex;
  justify-content: center;
  gap: 0.75rem;
  flex-wrap: wrap;
}
.patients-list-btn[data-v-14c615b0],
.create-patient-btn[data-v-14c615b0],
.statistics-btn[data-v-14c615b0],
.survey-statistics-btn[data-v-14c615b0] {
  display: inline-flex;
  align-items: center;
  gap: 0;
  padding: 0.7rem 1.25rem;
  background: var(--surface);
  color: var(--accent);
  border: 1px solid var(--border-strong);
  border-radius: 10px;
  font-size: 0.9rem;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s ease;
  text-decoration: none;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.06);
}
.patients-list-btn[data-v-14c615b0]:hover,
.create-patient-btn[data-v-14c615b0]:hover,
.statistics-btn[data-v-14c615b0]:hover,
.survey-statistics-btn[data-v-14c615b0]:hover {
  background: var(--accent-soft);
  border-color: rgba(37, 99, 235, 0.45);
  color: var(--accent-hover);
  transform: translateY(-1px);
  box-shadow: 0 10px 24px rgba(37, 99, 235, 0.16);
}
.action-icon[data-v-14c615b0] {
  display: none;
}



/* Модальное окно (переиспользуем стили) */
.modal-overlay[data-v-14c615b0] {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(15, 23, 42, 0.48);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 2000;
}
.modal-content[data-v-14c615b0] {
  background: var(--surface);
  border-radius: 16px;
  width: 90%;
  max-width: 500px;
  max-height: 80vh;
  overflow-y: auto;
  border: 1px solid var(--border);
  box-shadow: 0 24px 52px rgba(15, 23, 42, 0.24);
}
.modal-header[data-v-14c615b0] {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1.5rem;
  border-bottom: 1px solid var(--border);
}
.modal-header h3[data-v-14c615b0] {
  margin: 0;
  font-size: 1.25rem;
  font-weight: 600;
  color: var(--text-primary);
}
.close-btn[data-v-14c615b0] {
  background: none;
  border: 1px solid var(--border);
  font-size: 1.25rem;
  color: var(--text-secondary);
  cursor: pointer;
  padding: 0;
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 8px;
  transition: all 0.2s ease;
}
.close-btn[data-v-14c615b0]:hover {
  background: var(--surface-muted);
  border-color: var(--border-strong);
}
.modal-body[data-v-14c615b0] {
  padding: 1.5rem;
  color: var(--text-primary);
}
.form-group[data-v-14c615b0] {
  margin-bottom: 1rem;
}
.form-group label[data-v-14c615b0] {
  display: block;
  margin-bottom: 0.5rem;
  font-weight: 500;
  color: var(--text-primary);
  font-size: 0.9rem;
}
.form-input[data-v-14c615b0] {
  width: 100%;
  padding: 0.75rem 1rem;
  border: 1px solid var(--border-strong);
  border-radius: 8px;
  font-size: 0.9rem;
  transition: border-color 0.2s ease;
}
.form-input[data-v-14c615b0]:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.12);
}
.required[data-v-14c615b0] {
  color: #ef4444;
  font-weight: bold;
}
.field-error[data-v-14c615b0] {
  color: #ef4444;
  font-size: 0.8rem;
  margin-top: 0.25rem;
  font-weight: 500;
}
.field-note[data-v-14c615b0] {
  color: var(--text-secondary);
  font-size: 0.75rem;
  margin-top: 0.25rem;
  font-style: italic;
  display: block;
}
.modal-footer[data-v-14c615b0] {
  display: flex;
  justify-content: flex-end;
  gap: 0.75rem;
  padding: 1.5rem;
  border-top: 1px solid var(--border);
  background: var(--surface-muted);
}
.btn[data-v-14c615b0] {
  padding: 0.75rem 1.5rem;
  border: none;
  border-radius: 8px;
  font-size: 0.9rem;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.2s ease;
}
.btn-cancel[data-v-14c615b0] {
  background: var(--surface);
  color: var(--text-primary);
  border: 1px solid var(--border-strong);
}
.btn-cancel[data-v-14c615b0]:hover {
  background: var(--surface-muted);
}
.btn-primary[data-v-14c615b0] {
  background: var(--accent);
  color: white;
}
.btn-primary[data-v-14c615b0]:hover {
  background: var(--accent-hover);
}
.btn-primary[data-v-14c615b0]:disabled {
  background: #D1D5DB;
  cursor: not-allowed;
}

/* Информация о поликлинике в форме */
.clinic-info[data-v-14c615b0] {
  background: var(--surface-muted);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 1rem;
  margin-top: 0.5rem;
}
.info-label[data-v-14c615b0] {
  display: block;
  margin-bottom: 0.75rem;
  font-weight: 600;
  color: var(--text-primary);
  font-size: 0.9rem;
}
.clinic-assignment[data-v-14c615b0] {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  margin-bottom: 0.75rem;
}
.clinic-item[data-v-14c615b0],
.region-item[data-v-14c615b0] {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.5rem;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 6px;
}
.clinic-icon[data-v-14c615b0],
.region-icon[data-v-14c615b0] {
  font-size: 1rem;
}
.clinic-assignment .clinic-name[data-v-14c615b0],
.region-name[data-v-14c615b0] {
  font-size: 0.9rem;
  color: var(--text-primary);
  font-weight: 500;
}
.assignment-note[data-v-14c615b0] {
  font-size: 0.8rem;
  color: var(--text-secondary);
  font-style: italic;
  margin: 0;
  text-align: center;
}

/* Анимации */
@keyframes slideDown-14c615b0 {
from {
    opacity: 0;
    transform: translateY(-10px);
}
to {
    opacity: 1;
    transform: translateY(0);
}
}
@keyframes slideDownFade-14c615b0 {
from {
    opacity: 0;
    transform: translateY(-20px);
}
to {
    opacity: 1;
    transform: translateY(0);
}
}
@keyframes spin-14c615b0 {
0% { transform: rotate(0deg);
}
100% { transform: rotate(360deg);
}
}

/* Адаптивность */
@media (max-width: 768px) {
.header-content[data-v-14c615b0] {
    flex-direction: column;
    align-items: flex-start;
    gap: 1rem;
}
.header-actions[data-v-14c615b0] {
    width: 100%;
    justify-content: space-between;
    gap: 1rem;
}
.search-title[data-v-14c615b0] {
    font-size: 1.5rem;
}
.search-section[data-v-14c615b0] {
    padding: 1.5rem;
}
.main-content[data-v-14c615b0] {
    padding: 2rem 1rem;
}
}
@media (max-width: 480px) {
.header[data-v-14c615b0] {
    padding: 0.75rem 0;
}
.title[data-v-14c615b0] {
    font-size: 1.25rem;
}
.search-section[data-v-14c615b0] {
    padding: 1rem;
}
.search-title[data-v-14c615b0] {
    font-size: 1.25rem;
}
.search-subtitle[data-v-14c615b0] {
    font-size: 0.9rem;
}
.main-content[data-v-14c615b0] {
    padding: 1.5rem 0.75rem;
}
.datetime-widget[data-v-14c615b0] {
    min-width: auto;
}
}


/* Minimalist layout */
.identification-tab[data-v-4af8463a] {
  padding: 0;
  max-width: 1200px;
  margin: 0 auto;
  position: relative;
}

/* Локальный индикатор загрузки */
.tab-loading-overlay[data-v-4af8463a] {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(255, 255, 255, 0.9);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 100;
  backdrop-filter: blur(2px);
}
.tab-spinner[data-v-4af8463a] {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1rem;
  padding: 2rem;
  background: white;
  border-radius: 12px;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
  border: 1px solid #E5E7EB;
}
.spinner-circle[data-v-4af8463a] {
  width: 32px;
  height: 32px;
  border: 3px solid #F3F4F6;
  border-top: 3px solid #2563EB;
  border-radius: 50%;
  animation: spin-4af8463a 1s linear infinite;
}
@keyframes spin-4af8463a {
0% { transform: rotate(0deg);
}
100% { transform: rotate(360deg);
}
}
.loading-text[data-v-4af8463a] {
  margin: 0;
  font-size: 0.875rem;
  color: #6B7280;
  font-weight: 500;
}
.main-layout.loading[data-v-4af8463a] {
  opacity: 0.6;
  pointer-events: none;
}
.main-layout[data-v-4af8463a] {
  padding: 1rem;
  background: transparent;
}
.top-section[data-v-4af8463a] {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
  margin-bottom: 1rem;
}
.bottom-section[data-v-4af8463a] {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
}
.left-bottom[data-v-4af8463a] {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.right-bottom[data-v-4af8463a] {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.section[data-v-4af8463a] {
  margin-bottom: 0;
  padding: 1.25rem;
  background: white;
  border-radius: 8px;
  border: 1px solid #E5E7EB;
  transition: border-color 0.2s ease;
}
.section[data-v-4af8463a]:hover {
  border-color: #D1D5DB;
}
.basic-section[data-v-4af8463a] {
  padding: 1rem;
  background: white;
  border-radius: 8px;
  border: 1px solid #e5e7eb;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
}
.contact-section[data-v-4af8463a] {
  padding: 1rem;
  background: white;
  border-radius: 8px;
  border: 1px solid #e5e7eb;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
}

/* Minimalist section headers */
.section-header[data-v-4af8463a] {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0 0 0.75rem 0;
  margin: 0 0 1rem 0;
  border-bottom: 1px solid #F3F4F6;
}
.section-title[data-v-4af8463a] {
  font-size: 0.75rem;
  font-weight: 600;
  color: #6B7280;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin: 0;
}
.clear-section-btn[data-v-4af8463a] {
  background: none;
  border: 1px solid #E5E7EB;
  color: #9CA3AF;
  font-size: 14px;
  width: 24px;
  height: 24px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.2s ease;
  font-weight: 400;
  border-radius: 4px;
}
.clear-section-btn[data-v-4af8463a]:hover {
  background: #F9FAFB;
  border-color: #DC2626;
  color: #DC2626;
}
.basic-section .form-group[data-v-4af8463a] {
  margin-bottom: 1rem;
}
.contact-section .form-group[data-v-4af8463a] {
  margin-bottom: 1rem;
}

/* Minimalist forms */
.form-group[data-v-4af8463a] {
  margin-bottom: 0.75rem;
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}
.field-label[data-v-4af8463a] {
  font-size: 0.75rem;
  color: #6B7280;
  font-weight: 500;
  margin-bottom: 0.25rem;
  display: block;
}
.required[data-v-4af8463a] {
  color: #EF4444;
  font-weight: 600;
}
.form-input[data-v-4af8463a] {
  padding: 0.5rem 0.75rem;
  border: 1px solid #E5E7EB;
  border-radius: 6px;
  font-size: 0.875rem;
  transition: border-color 0.2s ease;
  width: 100%;
  background: white;
}
.form-input[data-v-4af8463a]:focus {
  outline: none;
  border-color: #2563EB;
}
.form-input.error[data-v-4af8463a] {
  border-color: #EF4444;
}
.radio-group.error[data-v-4af8463a] {
  border: 1px solid #EF4444;
  border-radius: 6px;
  padding: 0.5rem;
  background-color: rgba(239, 68, 68, 0.05);
}
.radio-group.error .radio-label[data-v-4af8463a] {
  color: #EF4444;
}
.form-input[data-v-4af8463a]::-moz-placeholder {
  color: #9CA3AF;
}
.form-input[data-v-4af8463a]::placeholder {
  color: #9CA3AF;
}
.readonly-field[data-v-4af8463a] {
  background: #F9FAFB;
  color: #6B7280;
  cursor: not-allowed;
}

/* Белое поле ИМТ */
.bmi-display[data-v-4af8463a] {
  background: white;
  border-color: #E5E7EB;
  color: #374151;
  font-weight: 500;
}
.form-input.small[data-v-4af8463a] {
  max-width: 120px;
}

/* Minimalist radio buttons */
.radio-group[data-v-4af8463a] {
  display: flex;
  gap: 0.5rem;
  flex-wrap: wrap;
  margin-top: 0.25rem;
}
.radio-label[data-v-4af8463a] {
  display: flex;
  align-items: center;
  cursor: pointer;
  gap: 0.375rem;
  padding: 0.25rem 0.5rem;
  border-radius: 4px;
  transition: background-color 0.2s ease;
}
.radio-label[data-v-4af8463a]:hover {
  background: #F9FAFB;
}
.radio-label input[type="radio"][data-v-4af8463a] {
  margin: 0;
  opacity: 0;
  position: absolute;
}
.radio-visual[data-v-4af8463a] {
  width: 16px;
  height: 16px;
  border: 1px solid #D1D5DB;
  border-radius: 50%;
  position: relative;
  background: white;
  transition: all 0.2s ease;
}
.radio-label input[type="radio"]:checked + .radio-visual[data-v-4af8463a] {
  border-color: #2563EB;
  background: #2563EB;
}
.radio-label input[type="radio"]:checked + .radio-visual[data-v-4af8463a]::after {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: white;
}
.radio-text[data-v-4af8463a] {
  font-size: 0.8rem;
  color: #374151;
  font-weight: 400;
}
.radio-label input[type="radio"]:checked ~ .radio-text[data-v-4af8463a] {
  color: #1F2937;
  font-weight: 500;
}
.error-message[data-v-4af8463a] {
  color: #EF4444;
  font-size: 0.7rem;
  margin-top: 0.25rem;
}
.weight-input[data-v-4af8463a] {
  display: flex;
  gap: 0.5rem;
  align-items: flex-start;
}
.weight-input .form-input[data-v-4af8463a] {
  flex: 1;
}
.calculate-btn[data-v-4af8463a] {
  padding: 0.5rem 1rem;
  background: #10B981;
  color: white;
  border: none;
  border-radius: 6px;
  font-size: 0.8rem;
  font-weight: 500;
  cursor: pointer;
  transition: background-color 0.2s ease;
  white-space: nowrap;
}
.calculate-btn[data-v-4af8463a]:hover:not(:disabled) {
  background: #059669;
}
.calculate-btn[data-v-4af8463a]:disabled {
  background: #D1D5DB;
  color: #9CA3AF;
  cursor: not-allowed;
}
.form-select[data-v-4af8463a] {
  background-image: url("data:image/svg+xml,%3csvg xmlns=%27http://www.w3.org/2000/svg%27 fill=%27none%27 viewBox=%270 0 20 20%27%3e%3cpath stroke=%27%236b7280%27 stroke-linecap=%27round%27 stroke-linejoin=%27round%27 stroke-width=%271.5%27 d=%27m6 8 4 4 4-4%27/%3e%3c/svg%3e");
  background-position: right 0.75rem center;
  background-repeat: no-repeat;
  background-size: 1.2em 1.2em;
  padding-right: 2.5rem;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
}
.imt-group[data-v-4af8463a] {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

/* Minimalist BMI scale */
.imt-scale[data-v-4af8463a] {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 0.25rem;
  margin-top: 0.75rem;
  padding: 0.75rem;
  background: #FAFAFA;
  border-radius: 6px;
  border: 1px solid #F3F4F6;
}
.scale-item[data-v-4af8463a] {
  text-align: center;
  padding: 0.5rem 0.25rem;
  border-radius: 4px;
  border: 1px solid #E5E7EB;
  background: white;
  transition: all 0.2s ease;
  cursor: default;
}

/* Цветные индикаторы ИМТ в зависимости от категории */
.scale-item.underweight.active[data-v-4af8463a] {
  background: #E0F2FE;
  color: #0F4F75;
  border-color: #7DD3FC;
}
.scale-item.normal.active[data-v-4af8463a] {
  background: #DCFCE7;
  color: #166534;
  border-color: #86EFAC;
}
.scale-item.overweight.active[data-v-4af8463a] {
  background: #FEF3C7;
  color: #92400E;
  border-color: #FCD34D;
}
.scale-item.obese1.active[data-v-4af8463a] {
  background: #FEE2E2;
  color: #991B1B;
  border-color: #FCA5A5;
}
.scale-item.obese2.active[data-v-4af8463a] {
  background: #FECACA;
  color: #7F1D1D;
  border-color: #F87171;
}
.scale-item.obese3.active[data-v-4af8463a] {
  background: #FCA5A5;
  color: #7F1D1D;
  border-color: #EF4444;
}
.scale-label[data-v-4af8463a] {
  font-size: 0.65rem;
  margin-bottom: 0.25rem;
  font-weight: 500;
  line-height: 1.1;
  white-space: pre-line;
  color: inherit;
}
.scale-value[data-v-4af8463a] {
  font-size: 0.7rem;
  font-weight: 600;
  color: inherit;
}
.year-group[data-v-4af8463a] {
  display: flex;
  gap: 0.5rem;
}
.year-group input[data-v-4af8463a] {
  flex: 1;
}

/* Minimalist save section */
.save-actions[data-v-4af8463a] {
  margin-top: 1rem;
  padding: 1rem;
  display: flex;
  align-items: center;
  gap: 1rem;
  background: white;
  border-radius: 8px;
  border: 1px solid #E5E7EB;
}
.save-btn[data-v-4af8463a] {
  background: #2563EB;
  color: white;
  border: none;
  padding: 0.625rem 1.25rem;
  border-radius: 6px;
  font-size: 0.875rem;
  font-weight: 500;
  cursor: pointer;
  transition: background-color 0.2s ease;
}
.save-btn[data-v-4af8463a]:hover:not(:disabled) {
  background: #1D4ED8;
}
.save-btn[data-v-4af8463a]:disabled {
  background: #D1D5DB;
  color: #9CA3AF;
  cursor: not-allowed;
}
.save-status[data-v-4af8463a] {
  padding: 0.5rem 1rem;
  border-radius: 6px;
  font-size: 0.8rem;
  font-weight: 500;
  display: flex;
  align-items: center;
  gap: 0.375rem;
}
.save-status.success[data-v-4af8463a] {
  background: #D1FAE5;
  color: #065F46;
  border: 1px solid #10B981;
}
.save-status.success[data-v-4af8463a]::before {
  content: "✓";
  font-size: 0.875rem;
}
.save-status.error[data-v-4af8463a] {
  background: #FEF2F2;
  color: #991B1B;
  border: 1px solid #EF4444;
}
.save-status.error[data-v-4af8463a]::before {
  content: "✗";
  font-size: 0.875rem;
}

/* Responsive design */
@media (max-width: 768px) {
.main-layout[data-v-4af8463a] {
    padding: 0.75rem;
}
.top-section[data-v-4af8463a],
  .bottom-section[data-v-4af8463a] {
    grid-template-columns: 1fr;
    gap: 0.75rem;
}
.section[data-v-4af8463a] {
    padding: 1rem;
}
.section-header[data-v-4af8463a] {
    margin-bottom: 0.75rem;
}
.weight-input[data-v-4af8463a] {
    flex-direction: column;
    gap: 0.375rem;
}
.imt-scale[data-v-4af8463a] {
    grid-template-columns: repeat(2, 1fr);
    gap: 0.25rem;
    padding: 0.5rem;
}
.radio-group[data-v-4af8463a] {
    gap: 0.375rem;
}
.save-actions[data-v-4af8463a] {
    padding: 0.75rem;
}
}

/* Large screens */
@media (min-width: 1200px) {
.identification-tab[data-v-4af8463a] {
    max-width: 1400px;
}
.main-layout[data-v-4af8463a] {
    padding: 1.25rem;
}
.top-section[data-v-4af8463a],
  .bottom-section[data-v-4af8463a] {
    gap: 1.25rem;
}
.section[data-v-4af8463a] {
    padding: 1.5rem;
}
}


/* Основной контейнер вкладки */
.anamnesis-tab[data-v-24da793a] {
  padding: 0;
  background: #f8f9fa;
  position: relative;
}
.anamnesis-container[data-v-24da793a] {
  padding: 1rem;
  background: transparent;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  max-width: 1200px;
  margin: 0 auto;
}

/* Заголовок страницы */
.page-header[data-v-24da793a] {
  margin-bottom: 1rem;
}
.page-header h2[data-v-24da793a] {
  font-size: 1.25rem;
  font-weight: 600;
  color: #333;
  margin: 0;
}

/* Вкладки */
.sub-tabs[data-v-24da793a] {
  display: flex;
  gap: 0.5rem;
  margin-bottom: 1.5rem;
  background: white;
  border-radius: 6px;
  border: 1px solid #e0e0e0;
  padding: 0.5rem;
  overflow-x: auto;
}
.sub-tab[data-v-24da793a] {
  padding: 0.75rem 1rem;
  border: none;
  background: transparent;
  color: #666;
  font-size: 0.9rem;
  font-weight: 500;
  cursor: pointer;
  border-radius: 4px;
  transition: all 0.2s ease;
  white-space: nowrap;
  flex-shrink: 0;
}
.sub-tab[data-v-24da793a]:hover {
  background: #f8f9fa;
  color: #333;
}
.sub-tab.active[data-v-24da793a] {
  background: #2563EB;
  color: white;
  box-shadow: 0 2px 4px rgba(37, 99, 235, 0.2);
}
.sub-tab.active[data-v-24da793a]:hover {
  background: #1D4ED8;
}

/* Контент вкладок */
.tab-content[data-v-24da793a] {
  background: white;
  border-radius: 6px;
  border: 1px solid #e0e0e0;
  overflow: hidden;
  margin-bottom: 1rem;
}
.tab-panel[data-v-24da793a] {
  padding: 1.25rem;
}

/* Секции */
.section[data-v-24da793a] {
  margin-bottom: 0;
  padding: 0;
  background: transparent;
  border: none;
}
.section-content[data-v-24da793a] {
  padding: 0;
}

/* Контейнер группы полей */
.form-group-container[data-v-24da793a] {
  margin-bottom: 1.5rem;
}
.form-group-container[data-v-24da793a]:last-child {
  margin-bottom: 0;
}
.form-group-container h3.section-title[data-v-24da793a] {
  font-size: 0.75rem;
  font-weight: 600;
  color: #6B7280;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin: 0 0 1.25rem 0;
  padding-bottom: 0.75rem;
  border-bottom: 1px solid #F3F4F6;
}
.section-title[data-v-24da793a] {
  font-size: 0.75rem;
  font-weight: 600;
  color: #6B7280;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin: 0 0 1rem 0;
}

/* Ряд полей */
.form-row[data-v-24da793a] {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 1rem;
  margin-bottom: 1rem;
}

/* Группа полей */
.form-group[data-v-24da793a] {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  margin-bottom: 1rem;
}
.form-group[data-v-24da793a]:last-child {
  margin-bottom: 0;
}
.field-label[data-v-24da793a] {
  font-size: 0.75rem;
  font-weight: 500;
  color: #6B7280;
  margin-bottom: 0.25rem;
  display: block;
}
.form-group label[data-v-24da793a]:not(.field-label) {
  font-size: 0.75rem;
  font-weight: 500;
  color: #6B7280;
  margin-bottom: 0.25rem;
}
.form-group label.required[data-v-24da793a]::after {
  content: '';
}
.required[data-v-24da793a] {
  position: relative;
}


/* Инпуты */
.form-input[data-v-24da793a],
.form-select[data-v-24da793a],
.form-textarea[data-v-24da793a] {
  padding: 0.625rem 0.75rem;
  border: 1px solid #E5E7EB;
  border-radius: 6px;
  font-size: 0.875rem;
  font-family: inherit;
  color: #374151;
  background: white;
  transition: all 0.2s ease;
  width: 100%;
}
.form-input[data-v-24da793a]:hover,
.form-select[data-v-24da793a]:hover,
.form-textarea[data-v-24da793a]:hover {
  border-color: #D1D5DB;
}
.form-input[data-v-24da793a]:focus,
.form-select[data-v-24da793a]:focus,
.form-textarea[data-v-24da793a]:focus {
  outline: none;
  border-color: #2563EB;
  box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.1);
}
.form-input.error[data-v-24da793a],
.form-select.error[data-v-24da793a],
.form-textarea.error[data-v-24da793a] {
  border-color: #EF4444;
  background-color: #FEF2F2;
}
.form-input.error[data-v-24da793a]:focus,
.form-select.error[data-v-24da793a]:focus,
.form-textarea.error[data-v-24da793a]:focus {
  border-color: #DC2626;
  box-shadow: 0 0 0 3px rgba(239, 68, 68, 0.1);
}
.form-textarea[data-v-24da793a] {
  resize: vertical;
  min-height: 80px;
  line-height: 1.5;
}
.input-with-unit[data-v-24da793a] {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.input-with-unit .form-input[data-v-24da793a] {
  flex: 1;
}
.input-with-unit .unit[data-v-24da793a] {
  color: #6B7280;
  font-size: 0.875rem;
  white-space: nowrap;
  font-weight: 500;
}

/* Группы радио-кнопок и чекбоксов */
.radio-group[data-v-24da793a],
.checkbox-group[data-v-24da793a] {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  margin-top: 0.75rem;
}
.radio-label[data-v-24da793a],
.checkbox-label[data-v-24da793a] {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  cursor: pointer;
  padding: 0.5rem;
  border-radius: 4px;
  transition: background-color 0.2s ease;
}
.radio-label[data-v-24da793a]:hover,
.checkbox-label[data-v-24da793a]:hover {
  background: #F9FAFB;
}
.radio-label.suggested[data-v-24da793a] {
  background-color: #EFF6FF;
  border: 1px solid #2563EB;
}
.radio-label input[type="radio"][data-v-24da793a],
.checkbox-label input[type="checkbox"][data-v-24da793a] {
  cursor: pointer;
  width: 16px;
  height: 16px;
  accent-color: #2563EB;
}
.radio-label span[data-v-24da793a],
.checkbox-label span[data-v-24da793a] {
  font-size: 0.875rem;
  color: #374151;
}


/* Сообщения */
.error-message[data-v-24da793a] {
  color: #DC2626;
  font-size: 0.75rem;
  margin-top: 0.5rem;
  display: block;
}
.success-message[data-v-24da793a] {
  padding: 0.75rem;
  background: #ECFDF5;
  border-left: 3px solid #10B981;
  color: #065F46;
  border-radius: 4px;
  margin-top: 1rem;
  margin-bottom: 0.5rem;
  font-size: 0.875rem;
}
.info-message[data-v-24da793a] {
  padding: 0.75rem;
  background: #EFF6FF;
  border-left: 3px solid #3B82F6;
  color: #1E40AF;
  border-radius: 4px;
  margin-top: 1rem;
  margin-bottom: 0.5rem;
  font-size: 0.875rem;
}
.warning-message[data-v-24da793a] {
  padding: 0.75rem;
  background: #FEF3C7;
  border-left: 3px solid #F59E0B;
  color: #92400E;
  border-radius: 4px;
  margin-top: 1rem;
  margin-bottom: 0.5rem;
  font-size: 0.875rem;
}

/* Детали блоков */
.smoking-details[data-v-24da793a],
.alcohol-details[data-v-24da793a],
.alcohol-abuse-details[data-v-24da793a],
.treatment-details[data-v-24da793a],
.menopause-details[data-v-24da793a],
.hrt-details[data-v-24da793a] {
  margin-top: 1.25rem;
  margin-bottom: 0.5rem;
  padding: 1.25rem;
  background: #FAFAFA;
  border-radius: 6px;
  border: 1px solid #E5E7EB;
}

/* Индекс курильщика */
.smoking-index[data-v-24da793a] {
  margin: 1rem 0;
}
.index-display[data-v-24da793a] {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 1rem;
  border-radius: 6px;
  font-size: 0.875rem;
  font-weight: 500;
}
.index-display.low-risk[data-v-24da793a] {
  background: #ECFDF5;
  border-left: 3px solid #10B981;
  color: #065F46;
}
.index-display.medium-risk[data-v-24da793a] {
  background: #FEF3C7;
  border-left: 3px solid #F59E0B;
  color: #92400E;
}
.index-display.high-risk[data-v-24da793a] {
  background: #FEE2E2;
  border-left: 3px solid #DC2626;
  color: #991B1B;
}
.index-label[data-v-24da793a] {
  color: inherit;
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.index-value[data-v-24da793a] {
  font-size: 1.25rem;
  font-weight: 600;
  color: inherit;
}
.risk-indicator[data-v-24da793a] {
  font-size: 0.875rem;
  font-weight: 600;
}

/* Поля только для чтения */
.readonly-field[data-v-24da793a] {
  margin: 1rem 0;
}
.readonly-field label.field-label[data-v-24da793a] {
  font-size: 0.75rem;
  font-weight: 500;
  color: #6B7280;
  display: block;
  margin-bottom: 0.5rem;
}
.readonly-value[data-v-24da793a] {
  padding: 0.625rem 0.75rem;
  background: #F3F4F6;
  border-radius: 6px;
  color: #6B7280;
  font-style: italic;
  font-size: 0.875rem;
  border: 1px solid #E5E7EB;
}

/* Секция сохранения */
.save-actions[data-v-24da793a] {
  margin-top: 1rem;
  padding: 1rem;
  background: white;
  border-radius: 8px;
  border: 1px solid #E5E7EB;
  max-width: 1200px;
  margin-left: auto;
  margin-right: auto;
}
.save-controls[data-v-24da793a] {
  display: flex;
  align-items: center;
  gap: 1rem;
  flex-wrap: wrap;
}
.save-btn[data-v-24da793a] {
  background: #2563EB;
  color: white;
  border: none;
  padding: 0.625rem 1.25rem;
  border-radius: 6px;
  font-size: 0.875rem;
  font-weight: 500;
  cursor: pointer;
  transition: background-color 0.2s ease;
}
.save-btn[data-v-24da793a]:hover:not(:disabled) {
  background: #1D4ED8;
}
.save-btn[data-v-24da793a]:disabled {
  background: #D1D5DB;
  color: #9CA3AF;
  cursor: not-allowed;
}
.save-status[data-v-24da793a] {
  padding: 0.5rem 1rem;
  border-radius: 6px;
  font-size: 0.875rem;
  font-weight: 500;
  transition: all 0.3s ease;
  margin-top: 0.75rem;
}
.save-status.success[data-v-24da793a] {
  background: #D1FAE5;
  color: #065F46;
  border: 1px solid #A7F3D0;
}
.save-status.error[data-v-24da793a] {
  background: #FEE2E2;
  color: #991B1B;
  border: 1px solid #FECACA;
}

/* Автосохранение информация */
.autosave-info[data-v-24da793a] {
  flex: 1;
  display: flex;
  align-items: center;
  min-width: 250px;
}
.autosave-text[data-v-24da793a] {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.75rem;
  color: #6B7280;
  font-style: italic;
  line-height: 1.3;
}
.autosave-icon[data-v-24da793a] {
  width: 16px;
  height: 16px;
  color: #10B981;
  flex-shrink: 0;
}

/* Адаптивность */
@media (max-width: 768px) {
.form-row[data-v-24da793a] {
    grid-template-columns: 1fr;
}
.anamnesis-container[data-v-24da793a] {
    padding: 0.5rem;
}
.section[data-v-24da793a] {
    padding: 1rem;
}
.index-display[data-v-24da793a] {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.5rem;
}
.sub-tabs[data-v-24da793a] {
    flex-direction: column;
}
.sub-tab[data-v-24da793a] {
    text-align: center;
}
.save-controls[data-v-24da793a] {
    flex-direction: column;
    align-items: stretch;
    gap: 0.75rem;
}
.autosave-info[data-v-24da793a] {
    min-width: auto;
}
.autosave-text[data-v-24da793a] {
    font-size: 0.7rem;
    justify-content: center;
}
}

/* Стили для аллергий */
.allergy-list[data-v-24da793a] {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}
.allergy-item[data-v-24da793a] {
  display: flex;
  gap: 0.5rem;
  align-items: flex-start;
  padding: 0.75rem;
  background: #FAFAFA;
  border-radius: 6px;
  border: 1px solid #E5E7EB;
}
.allergy-item-content[data-v-24da793a] {
  display: grid;
  grid-template-columns: 150px 1fr 1fr 1fr;
  gap: 0.5rem;
  flex: 1;
}
.allergy-type-select[data-v-24da793a] {
  min-width: 150px;
  width: 150px;
}
.remove-allergy-btn[data-v-24da793a] {
  padding: 0.5rem;
  background: #FEE2E2;
  color: #DC2626;
  border: 1px solid #FCA5A5;
  border-radius: 4px;
  cursor: pointer;
  font-size: 1.25rem;
  line-height: 1;
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.2s ease;
}
.remove-allergy-btn[data-v-24da793a]:hover {
  background: #DC2626;
  color: white;
}
.add-allergy-btn[data-v-24da793a] {
  padding: 0.625rem 1rem;
  background: #F3F4F6;
  color: #374151;
  border: 1px dashed #D1D5DB;
  border-radius: 6px;
  cursor: pointer;
  font-size: 0.875rem;
  transition: all 0.2s ease;
  text-align: center;
}
.add-allergy-btn[data-v-24da793a]:hover {
  background: #E5E7EB;
  border-color: #9CA3AF;
}
@media (max-width: 768px) {
.allergy-item-content[data-v-24da793a] {
    grid-template-columns: 1fr;
}
}

/* Стили для аккордеона репродуктивного анамнеза */
.accordion-item[data-v-24da793a] {
  margin-bottom: 0.75rem;
  border: 1px solid #E5E7EB;
  border-radius: 6px;
  overflow: hidden;
  background: white;
}
.accordion-header[data-v-24da793a] {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0.75rem 1rem;
  background: #F9FAFB;
  cursor: pointer;
  transition: background-color 0.2s ease;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
}
.accordion-header[data-v-24da793a]:hover {
  background: #F3F4F6;
}
.accordion-title[data-v-24da793a] {
  font-size: 0.875rem;
  font-weight: 600;
  color: #374151;
  margin: 0;
}
.accordion-icon[data-v-24da793a] {
  font-size: 0.75rem;
  color: #6B7280;
  transition: transform 0.2s ease;
}
.accordion-content[data-v-24da793a] {
  padding: 1rem;
  background: white;
  border-top: 1px solid #E5E7EB;
}

/* --- СТИЛИ ПЕРЕНЕСЕННЫЕ ИЗ DISEASES TAB (МКБ и прочее) --- */

/* Multi-select container */
.multi-select-container[data-v-24da793a] {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.selected-tags[data-v-24da793a] {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  min-height: 2rem;
  padding: 0.5rem;
  border: 1px solid #e5e7eb;
  border-radius: 4px;
  background: #f9fafb;
}
.tag[data-v-24da793a] {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  background: #2563EB;
  color: white;
  padding: 0.25rem 0.75rem;
  border-radius: 20px;
  font-size: 0.875rem;
}
.tag-remove[data-v-24da793a] {
  background: none;
  border: none;
  color: white;
  cursor: pointer;
  font-size: 1.2rem;
  padding: 0;
  margin-left: 0.25rem;
}
.tag-remove[data-v-24da793a]:hover {
  background: rgba(255, 255, 255, 0.2);
  border-radius: 50%;
  width: 20px;
  height: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.no-selection[data-v-24da793a] {
  color: #6b7280;
  font-style: italic;
  padding: 0.25rem;
}
.checkbox-list[data-v-24da793a] {
  max-height: 240px;
  overflow-y: auto;
  border: 1px solid #e5e7eb;
  border-radius: 4px;
  padding: 0.5rem;
}
.checkbox-item[data-v-24da793a] {
  margin-bottom: 0.5rem;
}
.checkbox-label[data-v-24da793a] {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  cursor: pointer;
  padding: 0.25rem;
  border-radius: 4px;
  transition: background-color 0.2s;
}
.checkbox-label[data-v-24da793a]:hover {
  background: #f3f4f6;
}
.checkbox-label input[type="checkbox"][data-v-24da793a],
.checkbox-zone input[type="checkbox"][data-v-24da793a] {
  display: none;
}
.checkbox-custom[data-v-24da793a] {
  width: 16px;
  height: 16px;
  border: 2px solid #d1d5db;
  border-radius: 3px;
  position: relative;
  transition: all 0.2s;
}
.checkbox-label input[type="checkbox"]:checked + .checkbox-custom[data-v-24da793a],
.checkbox-zone input[type="checkbox"]:checked + .checkbox-custom[data-v-24da793a] {
  background: #2563EB;
  border-color: #2563EB;
}
.checkbox-label input[type="checkbox"]:checked + .checkbox-custom[data-v-24da793a]::after,
.checkbox-zone input[type="checkbox"]:checked + .checkbox-custom[data-v-24da793a]::after {
  content: '✓';
  position: absolute;
  top: -2px;
  left: 2px;
  color: white;
  font-size: 12px;
  font-weight: bold;
}
.checkbox-text[data-v-24da793a] {
  font-size: 0.875rem;
  color: #374151;
}
.loading-placeholder[data-v-24da793a] {
  text-align: center;
  color: #6b7280;
  font-style: italic;
  padding: 2rem;
}

/* МКБ дерево стили */
.mkb-tree-container[data-v-24da793a] {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.mkb-level[data-v-24da793a] {
  border: 1px solid #E5E7EB;
  border-radius: 6px;
  padding: 1rem;
  background: #FAFAFA;
}
.mkb-level-title[data-v-24da793a] {
  font-size: 0.875rem;
  font-weight: 600;
  color: #374151;
  margin: 0 0 0.75rem 0;
  padding-bottom: 0.5rem;
  border-bottom: 1px solid #E5E7EB;
}

/* Стили для поиска МКБ кодов */
.mkb-search-section[data-v-24da793a] {
  margin-bottom: 1.5rem;
  padding: 1rem;
  background: #F9FAFB;
  border-radius: 8px;
  border: 1px solid #E5E7EB;
}
.search-title[data-v-24da793a] {
  font-size: 0.875rem;
  font-weight: 600;
  color: #6B7280;
  margin: 0 0 1rem 0;
}
.search-container[data-v-24da793a] {
  background: white;
  border: 1px solid #E5E7EB;
  border-radius: 8px;
  padding: 1rem;
}
.search-input-group[data-v-24da793a] {
  position: relative;
  margin-bottom: 1rem;
}
.search-input[data-v-24da793a] {
  width: 100%;
  height: 40px;
  padding: 8px 40px 8px 12px;
  border: 1px solid #D1D5DB;
  border-radius: 6px;
  font-size: 14px;
  color: #1F2937;
  background: white;
  transition: border-color 0.2s;
}
.search-input[data-v-24da793a]:focus {
  outline: none;
  border-color: #2563EB;
  box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.1);
}
.clear-search-btn[data-v-24da793a] {
  position: absolute;
  right: 8px;
  top: 50%;
  transform: translateY(-50%);
  background: none;
  border: none;
  color: #9CA3AF;
  font-size: 18px;
  cursor: pointer;
  width: 24px;
  height: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 4px;
  transition: all 0.2s;
}
.clear-search-btn[data-v-24da793a]:hover {
  background: #F3F4F6;
  color: #6B7280;
}
.search-loading[data-v-24da793a] {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  color: #6B7280;
  font-size: 0.875rem;
}
.search-spinner[data-v-24da793a] {
  width: 16px;
  height: 16px;
  border: 2px solid #F3F4F6;
  border-top: 2px solid #2563EB;
  border-radius: 50%;
  animation: spin 1s linear infinite;
}
.search-results[data-v-24da793a] {
  margin-top: 1rem;
}
.results-title[data-v-24da793a] {
  font-size: 0.875rem;
  font-weight: 600;
  color: #374151;
  margin: 0 0 0.75rem 0;
}
.search-results-list[data-v-24da793a] {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.search-result-item[data-v-24da793a] {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0.75rem;
  background: #F9FAFB;
  border: 1px solid #E5E7EB;
  border-radius: 6px;
  transition: border-color 0.2s;
}
.search-result-item[data-v-24da793a]:hover {
  border-color: #D1D5DB;
}
.result-name[data-v-24da793a] {
  font-size: 0.875rem;
  color: #1F2937;
  font-weight: 500;
}
.add-code-btn[data-v-24da793a] {
  background: #10B981;
  color: white;
  border: none;
  padding: 0.375rem 0.75rem;
  border-radius: 4px;
  font-size: 0.75rem;
  cursor: pointer;
  transition: background-color 0.2s;
  white-space: nowrap;
}
.add-code-btn[data-v-24da793a]:hover {
  background: #059669;
}
.no-results[data-v-24da793a] {
  text-align: center;
  padding: 1rem;
  color: #6B7280;
  font-size: 0.875rem;
}
.no-results p[data-v-24da793a] {
  margin: 0;
}

/* Стили для кнопок управления кодами */
.mkb-code-actions[data-v-24da793a] {
  display: flex;
  gap: 0.5rem;
  align-items: center;
  flex-shrink: 0;
}
.remove-code-btn[data-v-24da793a] {
  background: #FEF3C7;
  color: #D97706;
  border: 1px solid #FCD34D;
  padding: 0.25rem 0.5rem;
  border-radius: 4px;
  font-size: 0.75rem;
  cursor: pointer;
  transition: all 0.2s;
  font-weight: 500;
}
.remove-code-btn[data-v-24da793a]:hover {
  background: #FDE68A;
  border-color: #F59E0B;
  color: #B45309;
}

/* Стили для иерархической структуры МКБ кодов */
.mkb-item-container[data-v-24da793a] {
  margin-bottom: 0.5rem;
}
.parent-item[data-v-24da793a] {
  background: #f8fafc;
  border: 1px solid #e5e7eb;
  border-radius: 6px;
  padding: 0.5rem;
  margin-bottom: 0.25rem;
}
.parent-item-content[data-v-24da793a] {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  width: 100%;
}
.checkbox-zone[data-v-24da793a] {
  display: flex;
  align-items: center;
  cursor: pointer;
  flex-shrink: 0;
}
.text-zone[data-v-24da793a] {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex: 1;
  cursor: pointer;
  padding: 0.25rem 0.5rem;
  border-radius: 4px;
  transition: background-color 0.2s ease;
  font-weight: 600;
  color: #374151;
}
.text-zone[data-v-24da793a]:hover {
  background: rgba(37, 99, 235, 0.05);
}
.children-container[data-v-24da793a] {
  margin-left: 1.5rem;
  margin-top: 0.25rem;
  border-left: 2px solid #e5e7eb;
  padding-left: 1rem;
}
.child-item[data-v-24da793a] {
  background: white;
  border: 1px solid #f3f4f6;
  border-radius: 4px;
  padding: 0.375rem 0.5rem;
  margin-bottom: 0.25rem;
  transition: all 0.2s ease;
}
.child-item[data-v-24da793a]:hover {
  background: #f8fafc;
  border-color: #d1d5db;
}
.child-item .checkbox-label[data-v-24da793a] {
  font-weight: 500;
  color: #6b7280;
  font-size: 0.875rem;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  cursor: pointer;
  padding: 0.25rem;
  border-radius: 4px;
  transition: background-color 0.2s;
  width: 100%;
}
.no-children-message[data-v-24da793a] {
  margin-left: 1rem;
  margin-top: 8px;
  padding: 8px 12px;
  color: #666;
  font-style: italic;
  font-size: 14px;
  background-color: #f9fafb;
  border-radius: 4px;
  border: 1px solid #e5e7eb;
}

/* Адаптивность для поиска */
@media (max-width: 768px) {
.search-result-item[data-v-24da793a] {
    flex-direction: column;
    gap: 0.5rem;
    align-items: stretch;
}
.add-code-btn[data-v-24da793a] {
    width: 100%;
}
.mkb-code-actions[data-v-24da793a] {
    flex-direction: column;
    gap: 0.25rem;
    margin-left: 0;
    margin-top: 0.5rem;
}
.remove-code-btn[data-v-24da793a] {
    width: 100%;
    text-align: center;
}
}

/* Стили для кнопки добавления реакции */
.reaction-select-wrapper[data-v-24da793a] {
  display: flex;
  gap: 0.5rem;
  align-items: center;
}
.reaction-select-wrapper .form-select[data-v-24da793a] {
  flex: 1;
}
.add-reaction-btn[data-v-24da793a] {
  padding: 0.5rem 0.75rem;
  background: #2563EB;
  color: white;
  border: none;
  border-radius: 6px;
  cursor: pointer;
  font-size: 1.25rem;
  line-height: 1;
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.2s ease;
  flex-shrink: 0;
}
.add-reaction-btn[data-v-24da793a]:hover {
  background: #1D4ED8;
  transform: scale(1.05);
}
.add-reaction-btn[data-v-24da793a]:active {
  transform: scale(0.95);
}

/* Стили для модального окна */
.modal-overlay[data-v-24da793a] {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.5);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1000;
  backdrop-filter: blur(2px);
}
.modal-content[data-v-24da793a] {
  background: white;
  border-radius: 12px;
  box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04);
  width: 90%;
  max-width: 500px;
  max-height: 90vh;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
}
.modal-header[data-v-24da793a] {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1.5rem;
  border-bottom: 1px solid #E5E7EB;
}
.modal-header h3[data-v-24da793a] {
  margin: 0;
  font-size: 1.25rem;
  font-weight: 600;
  color: #1F2937;
}
.modal-close-btn[data-v-24da793a] {
  background: none;
  border: none;
  font-size: 1.5rem;
  color: #6B7280;
  cursor: pointer;
  padding: 0;
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 4px;
  transition: all 0.2s ease;
}
.modal-close-btn[data-v-24da793a]:hover {
  background: #F3F4F6;
  color: #1F2937;
}
.modal-body[data-v-24da793a] {
  padding: 1.5rem;
  flex: 1;
  overflow-y: auto;
}
.modal-footer[data-v-24da793a] {
  display: flex;
  justify-content: flex-end;
  gap: 0.75rem;
  padding: 1.5rem;
  border-top: 1px solid #E5E7EB;
}
.btn-cancel[data-v-24da793a] {
  padding: 0.625rem 1.25rem;
  background: #F3F4F6;
  color: #374151;
  border: 1px solid #D1D5DB;
  border-radius: 6px;
  cursor: pointer;
  font-size: 0.875rem;
  font-weight: 500;
  transition: all 0.2s ease;
}
.btn-cancel[data-v-24da793a]:hover {
  background: #E5E7EB;
  border-color: #9CA3AF;
}
.btn-save[data-v-24da793a] {
  padding: 0.625rem 1.25rem;
  background: #2563EB;
  color: white;
  border: none;
  border-radius: 6px;
  cursor: pointer;
  font-size: 0.875rem;
  font-weight: 500;
  transition: all 0.2s ease;
}
.btn-save[data-v-24da793a]:hover:not(:disabled) {
  background: #1D4ED8;
}
.btn-save[data-v-24da793a]:disabled {
  background: #D1D5DB;
  color: #9CA3AF;
  cursor: not-allowed;
}
@media (max-width: 768px) {
.modal-content[data-v-24da793a] {
    width: 95%;
    max-height: 95vh;
}
.reaction-select-wrapper[data-v-24da793a] {
    flex-direction: column;
}
.add-reaction-btn[data-v-24da793a] {
    width: 100%;
}
}


.analysis-tab[data-v-a3189ace] {
  padding: 1rem;
  background: #f8f9fa;
  height: 100%;
  overflow-y: auto;
  position: relative;
}

/* Локальный индикатор загрузки */
.tab-loading-overlay[data-v-a3189ace] {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(248, 249, 250, 0.9);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 100;
  backdrop-filter: blur(2px);
}
.tab-spinner[data-v-a3189ace] {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1rem;
  padding: 2rem;
  background: white;
  border-radius: 12px;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
  border: 1px solid #E5E7EB;
}
.spinner-circle[data-v-a3189ace] {
  width: 32px;
  height: 32px;
  border: 3px solid #F3F4F6;
  border-top: 3px solid #2563EB;
  border-radius: 50%;
  animation: spin-a3189ace 1s linear infinite;
}
@keyframes spin-a3189ace {
0% { transform: rotate(0deg);
}
100% { transform: rotate(360deg);
}
}
.loading-text[data-v-a3189ace] {
  margin: 0;
  font-size: 0.875rem;
  color: #6B7280;
  font-weight: 500;
}
.sub-tabs.loading[data-v-a3189ace],
.tab-content.loading[data-v-a3189ace] {
  opacity: 0.6;
  pointer-events: none;
}
.page-header[data-v-a3189ace] {
  margin-bottom: 1rem;
}
.page-header h2[data-v-a3189ace] {
  font-size: 1.25rem;
  font-weight: 600;
  color: #333;
  margin: 0;
}
.sub-tabs[data-v-a3189ace] {
  display: flex;
  gap: 0.5rem;
  margin-bottom: 1rem;
  background: white;
  border-radius: 6px;
  padding: 0.25rem;
  border: 1px solid #e0e0e0;
  overflow-x: auto;
}
.sub-tab[data-v-a3189ace] {
  padding: 0.5rem 0.75rem;
  background: transparent;
  border: none;
  border-radius: 4px;
  font-size: 0.75rem;
  font-weight: 500;
  color: #666;
  cursor: pointer;
  transition: all 0.2s ease;
  white-space: nowrap;
  flex-shrink: 0;
}
.sub-tab[data-v-a3189ace]:hover {
  background: #f5f5f5;
}
.sub-tab.active[data-v-a3189ace] {
  background: #2563EB;
  color: white;
}
.tab-content[data-v-a3189ace] {
  background: white;
  border-radius: 6px;
  border: 1px solid #e0e0e0;
  overflow: hidden;
}
.analysis-section[data-v-a3189ace] {
  margin-bottom: 1.5rem;
}
.section-header[data-v-a3189ace] {
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: #f5f5f5;
  padding: 0.75rem 1rem;
  border-bottom: 1px solid #e0e0e0;
  position: relative;
}
.section-title h3[data-v-a3189ace] {
  font-size: 0.8rem;
  font-weight: 600;
  color: #333;
  margin: 0;
  text-transform: uppercase;
}
.section-controls[data-v-a3189ace] {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}
.date-picker[data-v-a3189ace] {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  position: relative;
}
.date-input[data-v-a3189ace] {
  padding: 0.375rem 0.5rem;
  border: 1px solid #ddd;
  border-radius: 4px;
  font-size: 0.75rem;
  width: 140px;
  background: white;
}
.date-input[data-v-a3189ace]:focus {
  outline: none;
  border-color: #2563EB;
}
.search-icon[data-v-a3189ace] {
  font-size: 0.75rem;
  color: #666;
}
.clear-section-btn[data-v-a3189ace] {
  background: none;
  border: none;
  color: #EF4444;
  font-size: 18px;
  width: 24px;
  height: 24px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.2s;
  font-weight: bold;
  border-radius: 4px;
}
.clear-section-btn[data-v-a3189ace]:hover {
  background: #FEE2E2;
  color: #DC2626;
}
.chevron-btn[data-v-a3189ace] {
  background: none;
  border: none;
  font-size: 1rem;
  color: #666;
  cursor: pointer;
  padding: 0.25rem;
  border-radius: 4px;
  transition: all 0.2s ease;
}
.chevron-btn[data-v-a3189ace]:hover {
  background: #e0e0e0;
  color: #333;
}
.analysis-table[data-v-a3189ace] {
  padding: 1rem;
}
.analysis-table table[data-v-a3189ace] {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.75rem;
}
.analysis-table th[data-v-a3189ace] {
  background: #eeeeee;
  padding: 0.75rem;
  text-align: left;
  font-weight: 600;
  color: #333;
  border-bottom: 1px solid #e0e0e0;
}
.analysis-table td[data-v-a3189ace] {
  padding: 0.75rem;
  border-bottom: 1px solid #e0e0e0;
  color: #666;
}
.analysis-table tr[data-v-a3189ace]:hover {
  background: #f8f9fa;
}
.value-input[data-v-a3189ace] {
  width: 100%;
  padding: 0.375rem 0.5rem;
  border: 1px solid #ddd;
  border-radius: 4px;
  font-size: 0.75rem;
  background: white;
  max-width: 100px;
}
.value-input[data-v-a3189ace]:focus {
  outline: none;
  border-color: #2563EB;
}
.value-input[data-v-a3189ace]::-moz-placeholder {
  color: #999;
}
.value-input[data-v-a3189ace]::placeholder {
  color: #999;
}
.loading-placeholder[data-v-a3189ace] {
  padding: 2rem;
  text-align: center;
  color: #666;
  font-size: 0.875rem;
}

/* Minimalist save section */
.save-actions[data-v-a3189ace] {
  margin-top: 1rem;
  padding: 1rem;
  background: white;
  border-radius: 8px;
  border: 1px solid #E5E7EB;
  max-width: 1200px;
  margin-left: auto;
  margin-right: auto;
}
.save-controls[data-v-a3189ace] {
  display: flex;
  align-items: center;
  gap: 1rem;
  flex-wrap: wrap;
}
.save-btn[data-v-a3189ace] {
  background: #2563EB;
  color: white;
  border: none;
  padding: 0.625rem 1.25rem;
  border-radius: 6px;
  font-size: 0.875rem;
  font-weight: 500;
  cursor: pointer;
  transition: background-color 0.2s ease;
}
.save-btn[data-v-a3189ace]:hover:not(:disabled) {
  background: #1D4ED8;
}
.save-btn[data-v-a3189ace]:disabled {
  background: #D1D5DB;
  color: #9CA3AF;
  cursor: not-allowed;
}
.save-status[data-v-a3189ace] {
  padding: 0.5rem 1rem;
  border-radius: 6px;
  font-size: 0.875rem;
  font-weight: 500;
  transition: all 0.3s ease;
}
.save-status.success[data-v-a3189ace] {
  background: #D1FAE5;
  color: #065F46;
  border: 1px solid #A7F3D0;
}
.save-status.error[data-v-a3189ace] {
  background: #FEE2E2;
  color: #991B1B;
  border: 1px solid #FECACA;
}

/* Автосохранение информация */
.autosave-info[data-v-a3189ace] {
  flex: 1;
  display: flex;
  align-items: center;
  min-width: 250px;
}
.autosave-text[data-v-a3189ace] {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.75rem;
  color: #6B7280;
  font-style: italic;
  line-height: 1.3;
}
.autosave-icon[data-v-a3189ace] {
  width: 16px;
  height: 16px;
  color: #10B981;
  flex-shrink: 0;
}

/* Адаптивность */
@media (max-width: 768px) {
.sub-tabs[data-v-a3189ace] {
    flex-direction: column;
}
.sub-tab[data-v-a3189ace] {
    text-align: center;
}
.section-header[data-v-a3189ace] {
    flex-direction: column;
    gap: 0.5rem;
    align-items: flex-start;
}
.section-controls[data-v-a3189ace] {
    width: 100%;
    justify-content: space-between;
}
.analysis-table[data-v-a3189ace] {
    overflow-x: auto;
}
.analysis-table table[data-v-a3189ace] {
    min-width: 500px;
}
.save-controls[data-v-a3189ace] {
    flex-direction: column;
    align-items: stretch;
    gap: 0.75rem;
}
.autosave-info[data-v-a3189ace] {
    min-width: auto;
}
.autosave-text[data-v-a3189ace] {
    font-size: 0.7rem;
    justify-content: center;
}
}

/* Адаптивность для больших экранов */
@media (min-width: 1400px) {
.analysis-tab[data-v-a3189ace] {
    max-width: 1300px;
    margin: 0 auto;
}
.analysis-content[data-v-a3189ace] {
    padding: 2rem;
}
.section[data-v-a3189ace] {
    margin-bottom: 2rem;
}
.analysis-table table[data-v-a3189ace] {
    font-size: 0.9rem;
}
.analysis-table th[data-v-a3189ace],
  .analysis-table td[data-v-a3189ace] {
    padding: 0.75rem;
}
}
@media (min-width: 1600px) {
.analysis-tab[data-v-a3189ace] {
    max-width: 1500px;
}
.analysis-content[data-v-a3189ace] {
    padding: 2.5rem;
}
.section[data-v-a3189ace] {
    margin-bottom: 2.5rem;
}
.analysis-table table[data-v-a3189ace] {
    font-size: 0.95rem;
}
.analysis-table th[data-v-a3189ace],
  .analysis-table td[data-v-a3189ace] {
    padding: 1rem;
}
.sub-tab[data-v-a3189ace] {
    padding: 0.75rem 1.5rem;
    font-size: 0.9rem;
}
}
@media (min-width: 1920px) {
.analysis-tab[data-v-a3189ace] {
    max-width: 1700px;
}
.analysis-content[data-v-a3189ace] {
    padding: 3rem;
}
.section[data-v-a3189ace] {
    margin-bottom: 3rem;
}
.analysis-table table[data-v-a3189ace] {
    font-size: 1rem;
}
.analysis-table th[data-v-a3189ace],
  .analysis-table td[data-v-a3189ace] {
    padding: 1.25rem;
}
.sub-tab[data-v-a3189ace] {
    padding: 1rem 2rem;
    font-size: 1rem;
}
}


.radiography-tab[data-v-46157a19] {
  padding: 1rem;
  background: #f8f9fa;
  height: 100%;
  overflow-y: auto;
  position: relative;
}

/* Заголовок основной секции */
.radiography-tab > .section-header[data-v-46157a19] {
  background: white;
  border-radius: 6px;
  border: 1px solid #e0e0e0;
  margin-bottom: 1.5rem;
}

/* Подвкладки */
.sub-tabs[data-v-46157a19] {
  display: flex;
  gap: 0.5rem;
  margin-bottom: 1.5rem;
  background: white;
  border-radius: 6px;
  border: 1px solid #e0e0e0;
  padding: 0.5rem;
  overflow-x: auto;
}
.sub-tab[data-v-46157a19] {
  padding: 0.75rem 1rem;
  border: none;
  background: transparent;
  color: #666;
  font-size: 0.9rem;
  font-weight: 500;
  cursor: pointer;
  border-radius: 4px;
  transition: all 0.2s ease;
  white-space: nowrap;
  flex-shrink: 0;
}
.sub-tab[data-v-46157a19]:hover {
  background: #f8f9fa;
  color: #333;
}
.sub-tab.active[data-v-46157a19] {
  background: #2563EB;
  color: white;
  box-shadow: 0 2px 4px rgba(37, 99, 235, 0.2);
}
.sub-tab.active[data-v-46157a19]:hover {
  background: #1D4ED8;
}

/* Форма загрузки */
.upload-form[data-v-46157a19] {
  background: white;
  border-radius: 6px;
  border: 1px solid #e0e0e0;
  margin-bottom: 1.5rem;
  overflow: hidden;
}
.upload-form-content[data-v-46157a19] {
  padding: 1.5rem;
}
.upload-form-content h4[data-v-46157a19] {
  margin: 0 0 1rem 0;
  font-size: 1rem;
  font-weight: 600;
  color: #333;
}
.form-group[data-v-46157a19] {
  margin-bottom: 1rem;
}
.form-group[data-v-46157a19]:last-child {
  margin-bottom: 0;
}
.form-group label[data-v-46157a19] {
  display: block;
  margin-bottom: 0.5rem;
  font-weight: 500;
  color: #555;
  font-size: 0.9rem;
}
.form-input[data-v-46157a19] {
  width: 100%;
  padding: 0.75rem;
  border: 1px solid #ddd;
  border-radius: 4px;
  font-size: 0.9rem;
  transition: border-color 0.2s ease;
  background: white;
}
.form-input[data-v-46157a19]:focus {
  outline: none;
  border-color: #2563EB;
  box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.1);
}
.form-textarea[data-v-46157a19] {
  min-height: 100px;
  resize: vertical;
}
.form-help[data-v-46157a19] {
  display: block;
  margin-top: 0.25rem;
  color: #666;
  font-size: 0.8rem;
  line-height: 1.3;
}

/* Стили для выпадающего списка */
select.form-input[data-v-46157a19] {
  cursor: pointer;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  background-image: url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns=%27http://www.w3.org/2000/svg%27 viewBox=%270 0 24 24%27 fill=%27none%27 stroke=%27currentColor%27 stroke-width=%272%27 stroke-linecap=%27round%27 stroke-linejoin=%27round%27%3e%3cpolyline points=%276,9 12,15 18,9%27%3e%3c/polyline%3e%3c/svg%3e");
  background-repeat: no-repeat;
  background-position: right 0.75rem center;
  background-size: 1rem;
  padding-right: 2.5rem;
}
select.form-input option[data-v-46157a19] {
  padding: 0.5rem;
  color: #333;
  background: white;
}
select.form-input option[data-v-46157a19]:hover {
  background: #f8f9fa;
}
.form-actions[data-v-46157a19] {
  display: flex;
  gap: 1rem;
  justify-content: flex-end;
  margin-top: 1.5rem;
  padding-top: 1rem;
  border-top: 1px solid #f0f0f0;
}
.selected-file[data-v-46157a19] {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 1rem;
  background: #f8f9fa;
  border: 2px dashed #2563EB;
  border-radius: 4px;
}
.file-icon[data-v-46157a19] {
  font-size: 2rem;
  color: #2563EB;
}
.file-info p[data-v-46157a19] {
  margin: 0;
  font-weight: 500;
  color: #333;
}
.file-info small[data-v-46157a19] {
  color: #666;
}
.upload-placeholder[data-v-46157a19] {
  text-align: center;
  padding: 2rem;
  border: 2px dashed #e0e0e0;
  border-radius: 4px;
  transition: all 0.2s ease;
}
.upload-area:hover .upload-placeholder[data-v-46157a19] {
  border-color: #2563EB;
  background: #f8f9fa;
}

/* Состояния загрузки файла */
.file-uploading[data-v-46157a19],
.file-uploaded[data-v-46157a19],
.file-error[data-v-46157a19] {
  border: 1px solid #e0e0e0;
  border-radius: 4px;
  overflow: hidden;
}
.upload-status[data-v-46157a19] {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 1rem;
  background: #f8f9fa;
}
.file-icon.uploading[data-v-46157a19] {
  font-size: 2rem;
  animation: spin-46157a19 1s linear infinite;
}
@keyframes spin-46157a19 {
from { transform: rotate(0deg);
}
to { transform: rotate(360deg);
}
}
.file-icon.success[data-v-46157a19] {
  font-size: 2rem;
  color: #28a745;
}
.file-icon.error[data-v-46157a19] {
  font-size: 2rem;
  color: #dc3545;
}

/* Превью загруженного изображения */
.file-uploaded[data-v-46157a19] {
  display: flex;
  gap: 1rem;
  align-items: flex-start;
}
.uploaded-preview[data-v-46157a19] {
  position: relative;
  flex-shrink: 0;
  width: 120px;
  height: 120px;
  border-radius: 4px;
  overflow: hidden;
  background: #f0f0f0;
  cursor: pointer;
}
.preview-image[data-v-46157a19] {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  transition: transform 0.2s ease;
}
.preview-image[data-v-46157a19]:hover {
  transform: scale(1.05);
}
.preview-overlay[data-v-46157a19] {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.3);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: opacity 0.2s ease;
}
.uploaded-preview:hover .preview-overlay[data-v-46157a19] {
  opacity: 1;
}
.preview-icon[data-v-46157a19] {
  color: white;
  font-size: 1.5rem;
}
.uploaded-info[data-v-46157a19] {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.file-success[data-v-46157a19] {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 0.5rem;
}

/* Ошибка загрузки */
.file-error[data-v-46157a19] {
  padding: 1rem;
  background: #fff5f5;
  border-color: #fed7d7;
}
.selected-file.error[data-v-46157a19] {
  background: transparent;
  border: none;
  padding: 0;
  margin-bottom: 0.5rem;
}

/* Размеры кнопок */
.btn-sm[data-v-46157a19] {
  padding: 0.375rem 0.75rem;
  font-size: 0.875rem;
}

/* Список рентгенов */
.xray-list[data-v-46157a19] {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.radiography-section[data-v-46157a19] {
  background: white;
  border-radius: 6px;
  border: 1px solid #e0e0e0;
  overflow: hidden;
}

/* Пустое состояние */
.empty-state[data-v-46157a19] {
  text-align: center;
  padding: 3rem 1rem;
  background: white;
  border-radius: 6px;
  border: 1px solid #e0e0e0;
}
.empty-content[data-v-46157a19] {
  max-width: 400px;
  margin: 0 auto;
}
.empty-icon[data-v-46157a19] {
  font-size: 4rem;
  margin-bottom: 1rem;
  color: #ccc;
}
.empty-content h4[data-v-46157a19] {
  margin: 0 0 0.5rem 0;
  font-size: 1.2rem;
  color: #666;
}
.empty-content p[data-v-46157a19] {
  margin: 0;
  color: #888;
}
.section-header[data-v-46157a19] {
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: #f5f5f5;
  padding: 0.75rem 1rem;
  border-bottom: 1px solid #e0e0e0;
  position: relative;
}
.section-title h3[data-v-46157a19] {
  font-size: 0.8rem;
  font-weight: 600;
  color: #333;
  margin: 0;
  text-transform: uppercase;
}
.section-controls[data-v-46157a19] {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}
.date-picker[data-v-46157a19] {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  position: relative;
}
.date-input[data-v-46157a19] {
  padding: 0.375rem 0.5rem;
  border: 1px solid #ddd;
  border-radius: 4px;
  font-size: 0.75rem;
  width: 140px;
  background: white;
}
.date-input[data-v-46157a19]:focus {
  outline: none;
  border-color: #2563EB;
}
.search-icon[data-v-46157a19] {
  font-size: 0.75rem;
  color: #666;
}
.chevron-btn[data-v-46157a19] {
  background: none;
  border: none;
  font-size: 1rem;
  color: #666;
  cursor: pointer;
  padding: 0.25rem;
  border-radius: 4px;
  transition: all 0.2s ease;
}
.chevron-btn[data-v-46157a19]:hover {
  background: #e0e0e0;
  color: #333;
}
.radiography-content[data-v-46157a19] {
  padding: 1rem;
}

/* Секция с текстовым заключением */
.report-section[data-v-46157a19] {
  margin-bottom: 1.5rem;
  padding: 1rem;
  background: #f8f9fa;
  border-radius: 6px;
  border: 1px solid #e9ecef;
}
.report-title[data-v-46157a19] {
  margin: 0 0 0.75rem 0;
  font-size: 0.9rem;
  font-weight: 600;
  color: #495057;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.report-content[data-v-46157a19] {
  color: #333;
  line-height: 1.6;
  font-size: 0.9rem;
  white-space: pre-wrap;
  word-wrap: break-word;
}

/* Действия для блоков только с текстом */
.text-only-actions[data-v-46157a19] {
  display: flex;
  justify-content: center;
  padding-top: 1rem;
  border-top: 1px solid #e9ecef;
  margin-top: 1rem;
}
.image-viewer[data-v-46157a19] {
  position: relative;
  max-width: 600px;
  margin: 0 auto;
  border-radius: 4px;
  overflow: hidden;
  background: #1a1a1a;
}
.xray-image[data-v-46157a19] {
  width: 100%;
  height: auto;
  display: block;
  cursor: pointer;
  transition: transform 0.2s ease;
}
.xray-image[data-v-46157a19]:hover {
  transform: scale(1.02);
}
.fullscreen-overlay[data-v-46157a19] {
  position: absolute;
  top: 0;
  right: 0;
  padding: 0.5rem;
  background: rgba(0, 0, 0, 0.3);
  border-radius: 0 0 0 4px;
  opacity: 0;
  transition: opacity 0.2s ease;
  cursor: pointer;
}
.image-viewer:hover .fullscreen-overlay[data-v-46157a19] {
  opacity: 1;
}
.fullscreen-icon[data-v-46157a19] {
  color: white;
  font-size: 1.2rem;
  display: block;
}
.image-actions[data-v-46157a19] {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  background: rgba(0, 0, 0, 0.8);
  padding: 0.5rem;
  display: flex;
  gap: 0.5rem;
  justify-content: center;
  opacity: 0;
  transition: opacity 0.2s ease;
}
.image-viewer:hover .image-actions[data-v-46157a19] {
  opacity: 1;
}
.btn[data-v-46157a19] {
  padding: 0.25rem 0.75rem;
  border: none;
  border-radius: 4px;
  font-size: 0.75rem;
  cursor: pointer;
  transition: all 0.2s ease;
}
.btn-danger[data-v-46157a19] {
  background: #dc3545;
  color: white;
}
.btn-danger[data-v-46157a19]:hover {
  background: #c82333;
}
.btn-secondary[data-v-46157a19] {
  background: #6c757d;
  color: white;
}
.btn-primary[data-v-46157a19] {
  background: #2563EB;
  color: white;
}
.btn-primary[data-v-46157a19]:hover {
  background: #1D4ED8;
}
.btn-secondary[data-v-46157a19]:hover {
  background: #5a6268;
}
.btn[data-v-46157a19]:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}
.upload-area[data-v-46157a19] {
  cursor: pointer;
  transition: all 0.2s ease;
}
.upload-icon[data-v-46157a19] {
  font-size: 3rem;
  margin-bottom: 1rem;
  color: #666;
}
.upload-area p[data-v-46157a19] {
  margin: 0 0 0.5rem 0;
  font-size: 1rem;
  color: #333;
}
.upload-area small[data-v-46157a19] {
  color: #666;
  font-size: 0.875rem;
}
.upload-progress[data-v-46157a19] {
  margin-top: 1rem;
  display: flex;
  align-items: center;
  gap: 1rem;
}
.progress-bar[data-v-46157a19] {
  flex: 1;
  height: 4px;
  background: #e0e0e0;
  border-radius: 2px;
  overflow: hidden;
}
.progress-fill[data-v-46157a19] {
  height: 100%;
  background: #2563EB;
  transition: width 0.3s ease;
}
.loading-overlay[data-v-46157a19] {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(255, 255, 255, 0.8);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 100;
}
.loading-spinner[data-v-46157a19] {
  padding: 1rem 2rem;
  background: white;
  border-radius: 4px;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
  font-weight: 500;
}

/* Lightbox */
.lightbox-overlay[data-v-46157a19] {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.9);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1000;
  cursor: pointer;
}
.lightbox-content[data-v-46157a19] {
  position: relative;
  max-width: 90%;
  max-height: 90%;
  cursor: default;
}
.lightbox-image[data-v-46157a19] {
  max-width: 100%;
  max-height: 100%;
  border-radius: 4px;
}
.lightbox-close[data-v-46157a19] {
  position: absolute;
  top: -40px;
  right: -40px;
  width: 40px;
  height: 40px;
  background: rgba(255, 255, 255, 0.2);
  border: none;
  border-radius: 50%;
  color: white;
  font-size: 1.5rem;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.2s ease;
}
.lightbox-close[data-v-46157a19]:hover {
  background: rgba(255, 255, 255, 0.3);
}

/* Адаптивность */
@media (max-width: 768px) {
.radiography-tab[data-v-46157a19] {
    padding: 0.5rem;
}
.section-header[data-v-46157a19] {
    flex-direction: column;
    gap: 0.5rem;
    align-items: flex-start;
}
.section-controls[data-v-46157a19] {
    width: 100%;
    justify-content: space-between;
}
.form-actions[data-v-46157a19] {
    flex-direction: column;
    gap: 0.5rem;
}
.form-actions .btn[data-v-46157a19] {
    width: 100%;
}
.upload-form-content[data-v-46157a19] {
    padding: 1rem;
}
.image-viewer[data-v-46157a19] {
    max-width: 100%;
}
.lightbox-content[data-v-46157a19] {
    max-width: 95%;
    max-height: 95%;
}
.lightbox-close[data-v-46157a19] {
    top: -30px;
    right: -30px;
    width: 30px;
    height: 30px;
    font-size: 1.2rem;
}
.image-actions[data-v-46157a19] {
    position: static;
    opacity: 1;
    background: rgba(0, 0, 0, 0.9);
    margin-top: 0.5rem;
}
.selected-file[data-v-46157a19] {
    flex-direction: column;
    text-align: center;
    gap: 0.5rem;
}
.file-uploaded[data-v-46157a19] {
    flex-direction: column;
    align-items: center;
}
.uploaded-preview[data-v-46157a19] {
    width: 100px;
    height: 100px;
}
.uploaded-info[data-v-46157a19] {
    text-align: center;
    width: 100%;
}
.file-success[data-v-46157a19] {
    flex-direction: column;
    text-align: center;
    gap: 0.5rem;
}
}

/* Адаптивность для больших экранов */
@media (min-width: 1400px) {
.radiography-tab[data-v-46157a19] {
    max-width: 1300px;
    margin: 0 auto;
    padding: 2rem;
}
.radiography-content[data-v-46157a19] {
    padding: 2rem;
}
.section[data-v-46157a19] {
    margin-bottom: 2rem;
}
.image-viewer[data-v-46157a19] {
    max-width: 700px;
}
}
@media (min-width: 1600px) {
.radiography-tab[data-v-46157a19] {
    max-width: 1500px;
    padding: 2.5rem;
}
.radiography-content[data-v-46157a19] {
    padding: 2.5rem;
}
.section[data-v-46157a19] {
    margin-bottom: 2.5rem;
}
.image-viewer[data-v-46157a19] {
    max-width: 800px;
}
.lightbox-content[data-v-46157a19] {
    max-width: 90%;
    max-height: 90%;
}
}
@media (min-width: 1920px) {
.radiography-tab[data-v-46157a19] {
    max-width: 1700px;
    padding: 3rem;
}
.radiography-content[data-v-46157a19] {
    padding: 3rem;
}
.section[data-v-46157a19] {
    margin-bottom: 3rem;
}
.image-viewer[data-v-46157a19] {
    max-width: 900px;
}
.lightbox-content[data-v-46157a19] {
    max-width: 85%;
    max-height: 85%;
}
}

/* Анимации */
@keyframes fadeIn-46157a19 {
from {
    opacity: 0;
    transform: translateY(-10px);
}
to {
    opacity: 1;
    transform: translateY(0);
}
}
.radiography-content[data-v-46157a19] {
  animation: fadeIn-46157a19 0.3s ease;
}

/* Accessibility */
.xray-image[data-v-46157a19]:focus,
.chevron-btn[data-v-46157a19]:focus,
.date-input[data-v-46157a19]:focus,
.btn[data-v-46157a19]:focus {
  outline: 2px solid #2563EB;
  outline-offset: 2px;
}
@media (prefers-reduced-motion: reduce) {
.xray-image[data-v-46157a19] {
    transition: none;
}
.radiography-content[data-v-46157a19] {
    animation: none;
}
}


/* Minimalist layout */
.examination-tab[data-v-bf9a584c] {
  padding: 0;
  max-width: 1200px;
  margin: 0 auto;
  position: relative;
}

/* Локальный индикатор загрузки */
.tab-loading-overlay[data-v-bf9a584c] {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(255, 255, 255, 0.9);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 100;
  backdrop-filter: blur(2px);
}
.tab-spinner[data-v-bf9a584c] {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1rem;
  padding: 2rem;
  background: white;
  border-radius: 12px;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
  border: 1px solid #E5E7EB;
}
.spinner-circle[data-v-bf9a584c] {
  width: 32px;
  height: 32px;
  border: 3px solid #F3F4F6;
  border-top: 3px solid #2563EB;
  border-radius: 50%;
  animation: spin-bf9a584c 1s linear infinite;
}
@keyframes spin-bf9a584c {
0% { transform: rotate(0deg);
}
100% { transform: rotate(360deg);
}
}
.loading-text[data-v-bf9a584c] {
  margin: 0;
  font-size: 0.875rem;
  color: #6B7280;
  font-weight: 500;
}
.main-layout.loading[data-v-bf9a584c] {
  opacity: 0.6;
  pointer-events: none;
}
.main-layout[data-v-bf9a584c] {
  padding: 1rem;
  background: transparent;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.section[data-v-bf9a584c] {
  margin-bottom: 0;
  padding: 1.25rem;
  background: white;
  border-radius: 8px;
  border: 1px solid #E5E7EB;
  transition: border-color 0.2s ease;
}
.section[data-v-bf9a584c]:hover {
  border-color: #D1D5DB;
}

/* Minimalist section headers */
.section-header[data-v-bf9a584c] {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0 0 0.75rem 0;
  margin: 0 0 1rem 0;
  border-bottom: 1px solid #F3F4F6;
}
.section-title[data-v-bf9a584c] {
  font-size: 0.75rem;
  font-weight: 600;
  color: #6B7280;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin: 0;
}
.clear-section-btn[data-v-bf9a584c] {
  background: none;
  border: 1px solid #E5E7EB;
  color: #9CA3AF;
  font-size: 14px;
  width: 24px;
  height: 24px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.2s ease;
  font-weight: 400;
  border-radius: 4px;
}
.clear-section-btn[data-v-bf9a584c]:hover {
  background: #F9FAFB;
  border-color: #DC2626;
  color: #DC2626;
}

/* Minimalist forms */
.form-group[data-v-bf9a584c] {
  margin-bottom: 0.75rem;
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}
.field-label[data-v-bf9a584c] {
  font-size: 0.75rem;
  color: #6B7280;
  font-weight: 500;
  margin-bottom: 0.25rem;
  display: block;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

/* Multi-select container - стили из DiseasesTab */
.multi-select-container[data-v-bf9a584c] {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.selected-tags[data-v-bf9a584c] {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  min-height: 2rem;
  padding: 0.5rem;
  border: 1px solid #e5e7eb;
  border-radius: 4px;
  background: #f9fafb;
}
.tag[data-v-bf9a584c], .joint-tag[data-v-bf9a584c] {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  background: #1D4ED8;
  color: white;
  padding: 0.25rem 0.75rem;
  border-radius: 20px;
  font-size: 0.875rem;
}
.tag-remove[data-v-bf9a584c] {
  background: none;
  border: none;
  color: white;
  cursor: pointer;
  font-size: 1.2rem;
  padding: 0;
  margin-left: 0.25rem;
}
.tag-remove[data-v-bf9a584c]:hover {
  background: rgba(255, 255, 255, 0.2);
  border-radius: 50%;
  width: 20px;
  height: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.no-selection[data-v-bf9a584c], .no-joints[data-v-bf9a584c] {
  color: #6b7280;
  font-style: italic;
  padding: 0.25rem;
}
.checkbox-list[data-v-bf9a584c] {
  max-height: 240px;
  overflow-y: auto;
  border: 1px solid #e5e7eb;
  border-radius: 4px;
  padding: 0.5rem;
}

/* Чекбоксы */
.checkbox-item[data-v-bf9a584c] {
  display: flex;
  align-items: center;
  cursor: pointer;
  padding: 4px 0;
  margin-bottom: 0.5rem;
}
.checkbox-item[data-v-bf9a584c]:hover {
  background: #f3f4f6;
  border-radius: 4px;
  padding-left: 0.25rem;
}
.checkbox-item input[type="checkbox"][data-v-bf9a584c] {
  position: absolute;
  opacity: 0;
  cursor: pointer;
}
.checkbox-mark[data-v-bf9a584c] {
  width: 16px;
  height: 16px;
  border: 2px solid #E5E7EB;
  border-radius: 2px;
  margin-right: 8px;
  position: relative;
  transition: all 0.2s;
}
.checkbox-item input[type="checkbox"]:checked ~ .checkbox-mark[data-v-bf9a584c] {
  background-color: #1D4ED8;
  border-color: #1D4ED8;
}
.checkbox-item input[type="checkbox"]:checked ~ .checkbox-mark[data-v-bf9a584c]::after {
  content: "✓";
  position: absolute;
  top: -2px;
  left: 2px;
  color: white;
  font-size: 12px;
  font-weight: bold;
}
.checkbox-text[data-v-bf9a584c] {
  font-size: 12px;
  color: #1F2937;
}

/* Переключатели */
.toggle-buttons[data-v-bf9a584c] {
  display: flex;
  gap: 8px;
}
.toggle-btn[data-v-bf9a584c] {
  padding: 8px 16px;
  border: none;
  border-radius: 6px;
  font-size: 14px;
  cursor: pointer;
  transition: all 0.2s;
  background: #E5E7EB;
  color: #6B7280;
}
.toggle-btn.active[data-v-bf9a584c] {
  background: #1D4ED8;
  color: white;
}

/* Кнопки длительности утренней скованности */
.stiffness-duration-selector[data-v-bf9a584c] {
  margin-top: 8px;
}
.duration-options[data-v-bf9a584c] {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}
.duration-btn[data-v-bf9a584c] {
  padding: 10px 16px;
  border: 1px solid #D1D5DB;
  border-radius: 6px;
  font-size: 14px;
  cursor: pointer;
  transition: all 0.2s;
  background: white;
  color: #374151;
}
.duration-btn[data-v-bf9a584c]:hover {
  border-color: #1D4ED8;
  background: #F3F4F6;
}
.duration-btn.active[data-v-bf9a584c] {
  background: #1D4ED8;
  color: white;
  border-color: #1D4ED8;
}

/* Слайдеры оценки */
.assessment-slider[data-v-bf9a584c] {
  position: relative;
}
.slider-value[data-v-bf9a584c] {
  font-size: 16px;
  font-weight: bold;
  color: #1F2937;
  margin-bottom: 8px;
}
.slider[data-v-bf9a584c] {
  width: 100%;
  height: 6px;
  border-radius: 3px;
  background: linear-gradient(to right, #1D4ED8, #2563EB);
  outline: none;
  -webkit-appearance: none;
  -moz-appearance: none;
       appearance: none;
}
.slider[data-v-bf9a584c]::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: white;
  cursor: pointer;
  border: 2px solid #1D4ED8;
  box-shadow: 0 2px 4px rgba(0,0,0,0.2);
}
.slider[data-v-bf9a584c]::-moz-range-thumb {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: white;
  cursor: pointer;
  border: 2px solid #1D4ED8;
  box-shadow: 0 2px 4px rgba(0,0,0,0.2);
}
.slider-labels[data-v-bf9a584c] {
  display: flex;
  justify-content: space-between;
  margin-top: 8px;
}
.label-left[data-v-bf9a584c],
.label-right[data-v-bf9a584c] {
  font-size: 10px;
  color: #6B7280;
  max-width: 200px;
  text-align: left;
}
.label-right[data-v-bf9a584c] {
  text-align: right;
}

/* Диаграммы тела */
.body-diagrams[data-v-bf9a584c] {
  display: flex;
  gap: 48px;
  justify-content: center;
  margin: 32px 0;
  flex-wrap: wrap;
}
.diagram-container[data-v-bf9a584c] {
  text-align: center;
  flex: 1;
  min-width: 300px;
}
.diagram-wrapper[data-v-bf9a584c] {
  position: relative;
  display: inline-block;
  margin-bottom: 16px;
}
.body-image[data-v-bf9a584c] {
  width: 300px;
  height: auto;
  display: block;
}
.joint-point[data-v-bf9a584c] {
  position: absolute;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  border: 2px solid #1D4ED8;
  background: white;
  cursor: grab;
  transition: all 0.2s;
  transform: translate(-50%, -50%);
  z-index: 5;
}
.joint-point[data-v-bf9a584c]:active {
  cursor: grabbing;
}
.joint-point[data-v-bf9a584c]:hover {
  transform: translate(-50%, -50%) scale(1.5);
  z-index: 15;
  box-shadow: 0 0 0 2px rgba(107, 70, 193, 0.3);
}
.joint-point.active[data-v-bf9a584c] {
  background: #1D4ED8;
  border-color: #5B3BA4;
  box-shadow: 0 0 0 2px rgba(107, 70, 193, 0.4);
  z-index: 10;
}
.joint-point.active[data-v-bf9a584c]:hover {
  transform: translate(-50%, -50%) scale(1.5);
  box-shadow: 0 0 0 3px rgba(107, 70, 193, 0.6);
  z-index: 15;
}
.joint-point.dragging[data-v-bf9a584c] {
  cursor: grabbing !important;
  z-index: 20 !important;
  transform: translate(-50%, -50%) scale(1.8);
  box-shadow: 0 0 0 4px rgba(107, 70, 193, 0.8);
  border-color: #10B981;
  background: #10B981;
}
.coords-display[data-v-bf9a584c] {
  position: absolute;
  top: -25px;
  left: 50%;
  transform: translateX(-50%);
  background: rgba(16, 185, 129, 0.95);
  color: white;
  padding: 2px 6px;
  border-radius: 4px;
  font-size: 10px;
  font-weight: bold;
  white-space: nowrap;
  pointer-events: none;
  z-index: 25;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
}
.diagram-title[data-v-bf9a584c] {
  font-size: 14px;
  font-weight: bold;
  color: #1F2937;
  margin: 8px 0;
  text-transform: uppercase;
}
.selected-joints[data-v-bf9a584c] {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  min-height: 2rem;
  padding: 0.5rem;
  border: 1px solid #e5e7eb;
  border-radius: 4px;
  background: #f9fafb;
  margin-bottom: 16px;
}
.diagram-controls[data-v-bf9a584c] {
  display: flex;
  gap: 8px;
  justify-content: center;
}
.control-btn[data-v-bf9a584c] {
  padding: 6px 12px;
  border: none;
  border-radius: 6px;
  font-size: 12px;
  cursor: pointer;
  transition: all 0.2s;
}
.control-btn.primary[data-v-bf9a584c] {
  background: #1D4ED8;
  color: white;
}
.control-btn.secondary[data-v-bf9a584c] {
  background: #E5E7EB;
  color: #374151;
}

/* Медицинские шкалы */
.medical-scales[data-v-bf9a584c] {
  margin-top: 32px;
}
.scale-item[data-v-bf9a584c] {
  margin-bottom: 16px;
}
.scale-header[data-v-bf9a584c] {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 8px;
}
.scale-title[data-v-bf9a584c] {
  font-size: 14px;
  font-weight: bold;
  color: #1F2937;
  margin: 0;
  text-transform: uppercase;
}
.scale-value[data-v-bf9a584c] {
  font-size: 16px;
  font-weight: bold;
  color: #1D4ED8;
}
.scale-value-input[data-v-bf9a584c] {
  display: flex;
  align-items: center;
  gap: 8px;
}
.value-input[data-v-bf9a584c] {
  width: 60px;
  padding: 6px 8px;
  border: 2px solid #1D4ED8;
  border-radius: 6px;
  text-align: center;
  font-size: 14px;
  font-weight: bold;
  color: #1F2937;
  background: white;
  transition: all 0.2s;
}
.value-input[data-v-bf9a584c]:focus {
  outline: none;
  border-color: #2563EB;
  box-shadow: 0 0 0 3px rgba(107, 70, 193, 0.1);
}
.value-unit[data-v-bf9a584c] {
  font-size: 14px;
  font-weight: bold;
  color: #1F2937;
}
.assessment-slider[data-v-bf9a584c] {
  position: relative;
}
.color-scale[data-v-bf9a584c] {
  display: flex;
  height: 24px;
  border-radius: 4px;
  overflow: hidden;
  position: relative;
  border: 1px solid #E5E7EB;
}
.scale-segment[data-v-bf9a584c] {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 10px;
  color: white;
  font-weight: bold;
}
.scale-segment.blue[data-v-bf9a584c] {
  background: #1D4ED8;
}
.scale-segment.green[data-v-bf9a584c] {
  background: #10B981;
}
.scale-segment.yellow[data-v-bf9a584c] {
  background: #F59E0B;
}
.scale-segment.red[data-v-bf9a584c] {
  background: #EF4444;
}
.scale-label[data-v-bf9a584c] {
  text-shadow: 1px 1px 2px rgba(0,0,0,0.5);
}
.scale-segment.active[data-v-bf9a584c] {
  border: 3px solid #1F2937;
  box-shadow: 0 0 10px rgba(0,0,0,0.3);
  transform: scale(1.02);
  transition: all 0.2s ease;
}
.scale-value-display[data-v-bf9a584c] {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.calculated-value[data-v-bf9a584c] {
  font-size: 1.5rem;
  font-weight: bold;
  color: #1D4ED8;
  min-width: 60px;
  text-align: right;
}
.scale-marker[data-v-bf9a584c] {
  position: absolute;
  top: -4px;
  transform: translateX(-50%);
  width: 0;
  height: 0;
  border-left: 6px solid transparent;
  border-right: 6px solid transparent;
  border-bottom: 8px solid #1F2937;
  z-index: 1;
}

/* Раскрывающиеся секции */
.expandable-section[data-v-bf9a584c] {
  margin-bottom: 8px;
  border: 1px solid #E5E7EB;
  border-radius: 4px;
  overflow: hidden;
}
.section-header[data-v-bf9a584c] {
  display: flex;
  align-items: center;
  padding: 12px 16px;
  background: white;
  cursor: pointer;
  transition: background-color 0.2s;
}
.section-header[data-v-bf9a584c]:hover {
  background: #F9FAFB;
}
.section-check[data-v-bf9a584c] {
  margin-right: 8px;
  font-size: 14px;
  color: #1D4ED8;
}
.section-name[data-v-bf9a584c] {
  flex: 1;
  font-size: 14px;
  font-weight: 500;
  color: #1F2937;
  text-transform: uppercase;
}
.add-btn[data-v-bf9a584c] {
  padding: 4px 8px;
  background: #E5E7EB;
  border: none;
  border-radius: 4px;
  font-size: 12px;
  color: #374151;
  cursor: pointer;
}
.section-content[data-v-bf9a584c] {
  padding: 16px;
  background: #FAFAFA;
}
.subsection-item[data-v-bf9a584c] {
  margin-bottom: 12px;
  border: 1px solid #E5E7EB;
  border-radius: 4px;
  overflow: hidden;
}
.subsection-header[data-v-bf9a584c] {
  display: flex;
  align-items: center;
  padding: 8px 12px;
  background: white;
  cursor: pointer;
}
.subsection-name[data-v-bf9a584c] {
  flex: 1;
  font-size: 13px;
  color: #1F2937;
}
.subsection-content[data-v-bf9a584c] {
  padding: 12px;
  background: white;
}

/* Специальные секции */
.weight-section[data-v-bf9a584c] {
  margin-bottom: 16px;
}
.weight-controls[data-v-bf9a584c] {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  font-size: 12px;
  color: #1F2937;
}
.number-input[data-v-bf9a584c] {
  width: 80px;
  padding: 4px 8px;
  border: 1px solid #1D4ED8;
  border-radius: 4px;
  text-align: center;
}
.date-input[data-v-bf9a584c] {
  padding: 4px 8px;
  border: 1px solid #E5E7EB;
  border-radius: 4px;
  font-size: 12px;
}

/* Формы состояний */
.condition-form[data-v-bf9a584c] {
  background: white;
  padding: 16px;
  border-radius: 4px;
}
.form-row[data-v-bf9a584c] {
  margin-bottom: 12px;
}
.form-label[data-v-bf9a584c] {
  display: block;
  font-size: 12px;
  font-weight: bold;
  color: #1F2937;
  margin-bottom: 4px;
  text-transform: uppercase;
}
.form-input[data-v-bf9a584c] {
  width: 100%;
  padding: 8px 12px;
  border: 1px solid #E5E7EB;
  border-radius: 4px;
  font-size: 14px;
}
.input-with-delete[data-v-bf9a584c] {
  position: relative;
}
.delete-btn[data-v-bf9a584c] {
  position: absolute;
  right: 8px;
  top: 50%;
  transform: translateY(-50%);
  background: none;
  border: none;
  color: #EF4444;
  cursor: pointer;
  font-size: 16px;
}
.highlighted[data-v-bf9a584c] {
  text-decoration: underline;
  color: #1D4ED8;
}
.activity-buttons[data-v-bf9a584c] {
  display: flex;
  gap: 8px;
  margin: 12px 0;
}
.activity-btn[data-v-bf9a584c] {
  padding: 6px 12px;
  border: none;
  border-radius: 4px;
  font-size: 12px;
  cursor: pointer;
  background: #E5E7EB;
  color: #374151;
}
.activity-btn.active[data-v-bf9a584c] {
  background: #1D4ED8;
  color: white;
}
.add-form-btn[data-v-bf9a584c] {
  padding: 8px 16px;
  background: #E5E7EB;
  border: none;
  border-radius: 4px;
  font-size: 14px;
  color: #374151;
  cursor: pointer;
  margin-top: 12px;
}

/* Адаптивность */
@media (max-width: 768px) {
.examination-form[data-v-bf9a584c] {
    padding: 16px;
}
.body-diagrams[data-v-bf9a584c] {
    flex-direction: column;
    gap: 24px;
}
.diagram-container[data-v-bf9a584c] {
    min-width: auto;
}
.body-image[data-v-bf9a584c] {
    width: 250px;
}
.save-button-container[data-v-bf9a584c] {
    flex-direction: column;
    align-items: stretch;
    gap: 0.75rem;
}
.autosave-info[data-v-bf9a584c] {
    min-width: auto;
}
.autosave-text[data-v-bf9a584c] {
    font-size: 0.7rem;
    justify-content: center;
}
  
  /* Увеличиваем точки суставов для удобства тапа на мобильных */
.joint-point[data-v-bf9a584c] {
    width: 14px;
    height: 14px;
    border-width: 3px;
}
.joint-point[data-v-bf9a584c]:hover {
    transform: translate(-50%, -50%) scale(1.3);
}
.joint-point.active[data-v-bf9a584c]:hover {
    transform: translate(-50%, -50%) scale(1.3);
}
.weight-controls[data-v-bf9a584c] {
    flex-direction: column;
    align-items: stretch;
}
.slider-labels[data-v-bf9a584c] {
    flex-direction: column;
    gap: 4px;
}
.label-left[data-v-bf9a584c],
  .label-right[data-v-bf9a584c] {
    text-align: left;
    max-width: none;
}
}
@media (max-width: 480px) {
.body-image[data-v-bf9a584c] {
    width: 200px;
}
  
  /* Еще больше увеличиваем точки для очень маленьких экранов */
.joint-point[data-v-bf9a584c] {
    width: 16px;
    height: 16px;
    border-width: 3px;
}
}

/* Адаптивность для больших экранов */
@media (min-width: 1400px) {
.examination-form[data-v-bf9a584c] {
    max-width: 1300px;
    margin: 0 auto;
    padding: 32px;
}
.body-diagrams[data-v-bf9a584c] {
    gap: 48px;
}
.body-image[data-v-bf9a584c] {
    width: 380px;
}
.joint-point[data-v-bf9a584c] {
    width: 12px;
    height: 12px;
}
}
@media (min-width: 1600px) {
.examination-form[data-v-bf9a584c] {
    max-width: 1500px;
    padding: 40px;
}
.body-diagrams[data-v-bf9a584c] {
    gap: 60px;
}
.body-image[data-v-bf9a584c] {
    width: 420px;
}
.diagram-container[data-v-bf9a584c] {
    min-width: 450px;
}
}
@media (min-width: 1920px) {
.examination-form[data-v-bf9a584c] {
    max-width: 1700px;
    padding: 48px;
}
.body-diagrams[data-v-bf9a584c] {
    gap: 80px;
}
.body-image[data-v-bf9a584c] {
    width: 480px;
}
.diagram-container[data-v-bf9a584c] {
    min-width: 520px;
}
.weight-controls[data-v-bf9a584c] {
    gap: 24px;
}
}

/* Панель разработчика */
.developer-panel[data-v-bf9a584c] {
  background: #f0f0f0;
  border: 2px dashed #1D4ED8;
  padding: 16px;
  margin-bottom: 20px;
  border-radius: 8px;
}
.dev-btn[data-v-bf9a584c] {
  background: #1D4ED8;
  color: white;
  border: none;
  padding: 8px 16px;
  border-radius: 4px;
  cursor: pointer;
  margin-right: 8px;
  margin-bottom: 8px;
  font-size: 14px;
  transition: all 0.2s;
}
.dev-btn[data-v-bf9a584c]:hover {
  background: #5B3BA4;
}
.dev-btn.active[data-v-bf9a584c] {
  background: #10B981;
  box-shadow: 0 0 0 2px rgba(16, 185, 129, 0.3);
}
.dev-btn.clear[data-v-bf9a584c] {
  background: #EF4444;
}
.dev-btn.clear[data-v-bf9a584c]:hover {
  background: #DC2626;
}
.dev-btn.copy[data-v-bf9a584c] {
  background: #F59E0B;
}
.dev-btn.copy[data-v-bf9a584c]:hover {
  background: #D97706;
}
.dev-controls[data-v-bf9a584c] {
  margin-top: 12px;
}
.dev-controls p[data-v-bf9a584c] {
  margin: 0 0 12px 0;
  font-size: 14px;
  color: #666;
}
.coordinates-list[data-v-bf9a584c] {
  margin-top: 16px;
  background: white;
  padding: 12px;
  border-radius: 4px;
  max-height: 200px;
  overflow-y: auto;
}
.coordinates-list h4[data-v-bf9a584c] {
  margin: 0 0 8px 0;
  font-size: 14px;
  color: #1D4ED8;
}
.coord-item[data-v-bf9a584c] {
  font-family: monospace;
  font-size: 12px;
  padding: 4px 0;
  border-bottom: 1px solid #eee;
}
.coord-item[data-v-bf9a584c]:last-child {
  border-bottom: none;
}
.all-coordinates-list[data-v-bf9a584c] {
  margin-top: 20px;
  background: white;
  padding: 16px;
  border-radius: 4px;
  border: 1px solid #E5E7EB;
}
.coordinates-textarea-wrapper[data-v-bf9a584c] {
  margin-top: 8px;
}
.coordinates-textarea[data-v-bf9a584c] {
  width: 100%;
  min-height: 300px;
  padding: 12px;
  border: 2px solid #1D4ED8;
  border-radius: 4px;
  font-family: 'Courier New', monospace;
  font-size: 12px;
  line-height: 1.6;
  background: #F9FAFB;
  color: #1F2937;
  resize: vertical;
  cursor: text;
}
.coordinates-textarea[data-v-bf9a584c]:focus {
  outline: none;
  border-color: #10B981;
  background: white;
  box-shadow: 0 0 0 3px rgba(16, 185, 129, 0.1);
}

/* Кликнутые точки */
.clicked-point[data-v-bf9a584c] {
  position: absolute;
  width: 20px;
  height: 20px;
  background: #EF4444;
  color: white;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 10px;
  font-weight: bold;
  transform: translate(-50%, -50%);
  z-index: 20;
  cursor: pointer;
  box-shadow: 0 2px 4px rgba(0,0,0,0.3);
}
.clicked-point[data-v-bf9a584c]:hover {
  transform: translate(-50%, -50%) scale(1.2);
}
.instruction-box[data-v-bf9a584c] {
  background: #F3F4F6;
  border-left: 4px solid #1D4ED8;
  padding: 12px;
  margin-bottom: 16px;
  border-radius: 4px;
}
.instruction-box p[data-v-bf9a584c] {
  margin: 0 0 8px 0;
  font-size: 14px;
  color: #374151;
}
.instruction-box ol[data-v-bf9a584c] {
  margin: 8px 0;
  padding-left: 20px;
  font-size: 13px;
  color: #6B7280;
}
.instruction-box li[data-v-bf9a584c] {
  margin-bottom: 4px;
}
.instruction-box em[data-v-bf9a584c] {
  font-size: 12px;
  color: #9CA3AF;
  display: block;
  margin-top: 8px;
}

/* Индикатор загрузки */
.loading-indicator[data-v-bf9a584c] {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
  background: #f9fafb;
  border-radius: 8px;
  margin-bottom: 24px;
  gap: 12px;
}
.spinner[data-v-bf9a584c] {
  width: 20px;
  height: 20px;
  border: 2px solid #e5e7eb;
  border-top: 2px solid #1D4ED8;
  border-radius: 50%;
  animation: spin-bf9a584c 1s linear infinite;
}
@keyframes spin-bf9a584c {
0% { transform: rotate(0deg);
}
100% { transform: rotate(360deg);
}
}

/* Адаптивность */

/* Секция сохранения */
.save-section[data-v-bf9a584c] {
  margin-top: 32px;
  padding: 24px;
  background: #F9FAFB;
  border-radius: 8px;
  border: 1px solid #E5E7EB;
}
.save-controls[data-v-bf9a584c] {
  text-align: center;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.save-button-container[data-v-bf9a584c] {
  display: flex;
  align-items: center;
  gap: 1rem;
  justify-content: center;
  flex-wrap: wrap;
}
.save-btn[data-v-bf9a584c] {
  background: #10B981;
  color: white;
  border: none;
  padding: 12px 24px;
  border-radius: 8px;
  font-size: 16px;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s;
  min-width: 200px;
}
.save-btn[data-v-bf9a584c]:hover:not(:disabled) {
  background: #059669;
  transform: translateY(-1px);
  box-shadow: 0 4px 8px rgba(16, 185, 129, 0.3);
}
.save-btn[data-v-bf9a584c]:disabled {
  background: #9CA3AF;
  cursor: not-allowed;
  transform: none;
  box-shadow: none;
}
.save-status[data-v-bf9a584c] {
  margin-top: 12px;
  font-size: 14px;
  color: #6B7280;
  font-style: italic;
}
.debug-info[data-v-bf9a584c] {
  margin-top: 12px;
  font-size: 14px;
  color: #6B7280;
  font-style: italic;
}

/* Автосохранение информация */
.autosave-info[data-v-bf9a584c] {
  display: flex;
  align-items: center;
  min-width: 250px;
}
.autosave-text[data-v-bf9a584c] {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.75rem;
  color: #6B7280;
  font-style: italic;
  line-height: 1.3;
}
.autosave-icon[data-v-bf9a584c] {
  width: 16px;
  height: 16px;
  color: #10B981;
  flex-shrink: 0;
}
.test-save-btn[data-v-bf9a584c] {
  background: #F59E0B;
  color: white;
  border: none;
  padding: 12px 24px;
  border-radius: 8px;
  font-size: 16px;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s;
  min-width: 200px;
}
.test-save-btn[data-v-bf9a584c]:hover:not(:disabled) {
  background: #D97706;
  transform: translateY(-1px);
  box-shadow: 0 4px 8px rgba(213, 145, 16, 0.3);
}
.test-save-btn[data-v-bf9a584c]:disabled {
  background: #9CA3AF;
  cursor: not-allowed;
  transform: none;
  box-shadow: none;
}

/* Стили для конструктора осмотра */
.block[data-v-bf9a584c] {
  margin-bottom: 1.5rem;
  padding: 1rem;
  background: white;
  border: 1px solid #E5E7EB;
  border-radius: 8px;
}
.block-title[data-v-bf9a584c] {
  font-size: 1rem;
  font-weight: 600;
  color: #1F2937;
  margin-bottom: 0.5rem;
}
.block-description[data-v-bf9a584c] {
  font-size: 0.875rem;
  color: #6B7280;
  margin-bottom: 1rem;
}
.question-group[data-v-bf9a584c] {
  margin-bottom: 1.25rem;
}
.question-label[data-v-bf9a584c] {
  display: block;
  font-size: 0.875rem;
  font-weight: 500;
  color: #374151;
  margin-bottom: 0.5rem;
}
.question-hint[data-v-bf9a584c] {
  font-size: 0.75rem;
  color: #6B7280;
  font-style: italic;
  margin-bottom: 0.5rem;
}
.question-input[data-v-bf9a584c] {
  margin-top: 0.5rem;
}
.buttons-input[data-v-bf9a584c] {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}
.option-btn[data-v-bf9a584c] {
  padding: 0.5rem 1rem;
  border: 1px solid #E5E7EB;
  border-radius: 6px;
  background: white;
  color: #374151;
  font-size: 0.875rem;
  cursor: pointer;
  transition: all 0.2s ease;
}
.option-btn[data-v-bf9a584c]:hover {
  border-color: #1D4ED8;
  background: #F8FAFC;
}
.option-btn.active[data-v-bf9a584c] {
  background: #1D4ED8;
  color: white;
  border-color: #1D4ED8;
}
.reference-input[data-v-bf9a584c],
.reference-with-date-input[data-v-bf9a584c] {
  margin-top: 0.5rem;
}
.reference-date-list[data-v-bf9a584c] {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}
.reference-date-item[data-v-bf9a584c] {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}
.date-input-small[data-v-bf9a584c] {
  padding: 0.375rem 0.5rem;
  border: 1px solid #E5E7EB;
  border-radius: 4px;
  font-size: 0.875rem;
}
.text-input[data-v-bf9a584c],
.number-input[data-v-bf9a584c],
.date-input[data-v-bf9a584c] {
  width: 100%;
  padding: 0.5rem 0.75rem;
  border: 1px solid #E5E7EB;
  border-radius: 6px;
  font-size: 0.875rem;
  transition: border-color 0.2s ease;
}
.text-input[data-v-bf9a584c]:focus,
.number-input[data-v-bf9a584c]:focus,
.date-input[data-v-bf9a584c]:focus {
  outline: none;
  border-color: #1D4ED8;
}
.boolean-input[data-v-bf9a584c] {
  display: flex;
  gap: 0.5rem;
}
.toggle-btn[data-v-bf9a584c] {
  padding: 0.5rem 1rem;
  border: 1px solid #E5E7EB;
  border-radius: 6px;
  background: white;
  color: #374151;
  font-size: 0.875rem;
  cursor: pointer;
  transition: all 0.2s ease;
}
.toggle-btn[data-v-bf9a584c]:hover {
  border-color: #1D4ED8;
  background: #F8FAFC;
}
.toggle-btn.active[data-v-bf9a584c] {
  background: #1D4ED8;
  color: white;
  border-color: #1D4ED8;
}
.section-description[data-v-bf9a584c] {
  font-size: 0.875rem;
  color: #6B7280;
  margin-top: 0.25rem;
  font-style: italic;
}


/* Minimalist layout */
.treatment-tab[data-v-cee0fe40] {
  padding: 0;
  max-width: 1200px;
  margin: 0 auto;
  position: relative;
}

/* Локальный индикатор загрузки */
.tab-loading-overlay[data-v-cee0fe40] {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(255, 255, 255, 0.9);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 100;
  backdrop-filter: blur(2px);
}
.tab-spinner[data-v-cee0fe40] {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1rem;
  padding: 2rem;
  background: white;
  border-radius: 12px;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
  border: 1px solid #E5E7EB;
}
.spinner-circle[data-v-cee0fe40] {
  width: 32px;
  height: 32px;
  border: 3px solid #F3F4F6;
  border-top: 3px solid #2563EB;
  border-radius: 50%;
  animation: spin-cee0fe40 1s linear infinite;
}
@keyframes spin-cee0fe40 {
0% { transform: rotate(0deg);
}
100% { transform: rotate(360deg);
}
}
.loading-text[data-v-cee0fe40] {
  margin: 0;
  font-size: 0.875rem;
  color: #6B7280;
  font-weight: 500;
}
.main-layout.loading[data-v-cee0fe40] {
  opacity: 0.6;
  pointer-events: none;
}
.main-layout[data-v-cee0fe40] {
  padding: 1rem;
  background: transparent;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.section[data-v-cee0fe40] {
  margin-bottom: 0;
  padding: 1.25rem;
  background: white;
  border-radius: 8px;
  border: 1px solid #E5E7EB;
  transition: border-color 0.2s ease;
}
.section[data-v-cee0fe40]:hover {
  border-color: #D1D5DB;
}

/* Minimalist section headers */
.section-header[data-v-cee0fe40] {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0 0 0.75rem 0;
  margin: 0 0 1rem 0;
  border-bottom: 1px solid #F3F4F6;
}
.section-title[data-v-cee0fe40] {
  font-size: 0.75rem;
  font-weight: 600;
  color: #6B7280;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin: 0;
}
.clear-section-btn[data-v-cee0fe40] {
  background: none;
  border: 1px solid #E5E7EB;
  color: #9CA3AF;
  font-size: 14px;
  width: 24px;
  height: 24px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.2s ease;
  font-weight: 400;
  border-radius: 4px;
}
.clear-section-btn[data-v-cee0fe40]:hover {
  background: #F9FAFB;
  border-color: #DC2626;
  color: #DC2626;
}
.medications-section[data-v-cee0fe40] {
  width: 100%;
  margin: 0;
  padding: 0 20px;
}
.section-header[data-v-cee0fe40] {
  background: #F3F4F6;
  padding: 16px;
  margin-bottom: 24px;
  border-radius: 8px;
}
.section-header h3[data-v-cee0fe40] {
  font-size: 14px;
  font-weight: 600;
  color: #1F2937;
  margin: 0;
}
.debug-info[data-v-cee0fe40] {
  margin-top: 8px;
  font-size: 12px;
  color: #6B7280;
}
.debug-info p[data-v-cee0fe40] {
  margin: 2px 0;
}
.no-drugs[data-v-cee0fe40] {
  text-align: center;
  padding: 40px;
  color: #6B7280;
}
.medication-list[data-v-cee0fe40] {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.medication-card[data-v-cee0fe40] {
  background: white;
  border: 1px solid #E5E7EB;
  border-radius: 8px;
  padding: 20px;
  position: relative;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
  transition: box-shadow 0.2s;
}
.medication-card[data-v-cee0fe40]:hover {
  box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
}
.medication-header[data-v-cee0fe40] {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 16px;
}
.medication-name[data-v-cee0fe40] {
  font-size: 16px;
  font-weight: 600;
  color: #1F2937;
}
.delete-btn[data-v-cee0fe40] {
  background: none;
  border: none;
  color: #EF4444;
  font-size: 20px;
  width: 24px;
  height: 24px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.2s;
  font-weight: bold;
  border-radius: 4px;
}
.delete-btn[data-v-cee0fe40]:hover {
  background: #FEE2E2;
  color: #DC2626;
}
.fields-grid[data-v-cee0fe40] {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}
.field-group[data-v-cee0fe40] {
  display: flex;
  flex-direction: column;
}
.field-label[data-v-cee0fe40] {
  font-size: 12px;
  color: #6B7280;
  margin-bottom: 6px;
  font-weight: 500;
}
.date-field[data-v-cee0fe40] {
  position: relative;
  display: flex;
  align-items: center;
}
.date-input[data-v-cee0fe40], .text-input[data-v-cee0fe40] {
  width: 100%;
  height: 40px;
  padding: 8px 12px;
  border: 1px solid #D1D5DB;
  border-radius: 6px;
  font-size: 14px;
  color: #1F2937;
  background: white;
  transition: border-color 0.2s;
}
.date-input[data-v-cee0fe40]:focus, .text-input[data-v-cee0fe40]:focus {
  outline: none;
  border-color: #1D4ED8;
  box-shadow: 0 0 0 3px rgba(107, 70, 193, 0.1);
}
.date-input[data-v-cee0fe40]::-moz-placeholder, .text-input[data-v-cee0fe40]::-moz-placeholder {
  color: #9CA3AF;
}
.date-input[data-v-cee0fe40]::placeholder, .text-input[data-v-cee0fe40]::placeholder {
  color: #9CA3AF;
}
.card-actions[data-v-cee0fe40] {
  display: flex;
  gap: 8px;
  margin-top: 16px;
  padding-top: 16px;
  border-top: 1px solid #E5E7EB;
}
.save-btn[data-v-cee0fe40] {
  background: #10B981;
  color: white;
  border: none;
  padding: 8px 16px;
  border-radius: 6px;
  cursor: pointer;
  font-size: 14px;
  transition: background-color 0.2s;
}
.save-btn[data-v-cee0fe40]:hover:not(:disabled) {
  background: #059669;
}
.save-btn[data-v-cee0fe40]:disabled {
  background: #9CA3AF;
  cursor: not-allowed;
}
.cancel-btn[data-v-cee0fe40] {
  background: #6B7280;
  color: white;
  border: none;
  padding: 8px 16px;
  border-radius: 6px;
  cursor: pointer;
  font-size: 14px;
  transition: background-color 0.2s;
}
.cancel-btn[data-v-cee0fe40]:hover {
  background: #4B5563;
}
.global-save-section[data-v-cee0fe40] {
  margin-top: 24px;
  padding: 16px;
  background: #F3F4F6;
  border-radius: 8px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
}
.save-controls[data-v-cee0fe40] {
  display: flex;
  gap: 12px;
  width: 100%;
  justify-content: center;
}
.global-save-btn[data-v-cee0fe40] {
  background: #3B82F6;
  color: white;
  border: none;
  padding: 8px 16px;
  border-radius: 6px;
  cursor: pointer;
  font-size: 14px;
  transition: background-color 0.2s;
  flex: 1;
}
.global-save-btn[data-v-cee0fe40]:hover:not(:disabled) {
  background: #2563EB;
}
.global-save-btn[data-v-cee0fe40]:disabled {
  background: #9CA3AF;
  cursor: not-allowed;
}
.reset-all-btn[data-v-cee0fe40] {
  background: #EF4444;
  color: white;
  border: none;
  padding: 8px 16px;
  border-radius: 6px;
  cursor: pointer;
  font-size: 14px;
  transition: background-color 0.2s;
  flex: 1;
}
.reset-all-btn[data-v-cee0fe40]:hover {
  background: #DC2626;
}
.modifications-info[data-v-cee0fe40] {
  font-size: 12px;
  color: #6B7280;
  text-align: center;
}
.debug-controls[data-v-cee0fe40] {
  margin-top: 24px;
  text-align: center;
}
.debug-btn[data-v-cee0fe40] {
  background: #F3F4F6;
  color: #6B7280;
  border: none;
  padding: 6px 12px;
  border-radius: 4px;
  cursor: pointer;
  font-size: 12px;
}
.debug-btn[data-v-cee0fe40]:hover {
  background: #E5E7EB;
}

/* Адаптивность */
@media (max-width: 768px) {
.medications-section[data-v-cee0fe40] {
    padding: 0 12px;
}
.medication-card[data-v-cee0fe40] {
    padding: 16px;
}
.fields-grid[data-v-cee0fe40] {
    grid-template-columns: 1fr;
    gap: 12px;
}
.page-header h1[data-v-cee0fe40] {
    font-size: 20px;
}
.medication-name[data-v-cee0fe40] {
    font-size: 14px;
}
}

/* Адаптивность для больших экранов */
@media (min-width: 1400px) {
.treatment-tab[data-v-cee0fe40] {
    max-width: 1300px;
    margin: 0 auto;
}
.medications-section[data-v-cee0fe40] {
    padding: 2rem;
}
.medication-card[data-v-cee0fe40] {
    padding: 1.5rem;
}
.fields-grid[data-v-cee0fe40] {
    gap: 1.5rem;
}
}
@media (min-width: 1600px) {
.treatment-tab[data-v-cee0fe40] {
    max-width: 1500px;
}
.medications-section[data-v-cee0fe40] {
    padding: 2.5rem;
}
.medication-card[data-v-cee0fe40] {
    padding: 2rem;
}
.fields-grid[data-v-cee0fe40] {
    gap: 2rem;
}
.page-header h1[data-v-cee0fe40] {
    font-size: 1.5rem;
}
.medication-name[data-v-cee0fe40] {
    font-size: 1rem;
}
}
@media (min-width: 1920px) {
.treatment-tab[data-v-cee0fe40] {
    max-width: 1700px;
}
.medications-section[data-v-cee0fe40] {
    padding: 3rem;
}
.medication-card[data-v-cee0fe40] {
    padding: 2.5rem;
}
.fields-grid[data-v-cee0fe40] {
    gap: 2.5rem;
}
.page-header h1[data-v-cee0fe40] {
    font-size: 1.75rem;
}
.medication-name[data-v-cee0fe40] {
    font-size: 1.125rem;
}
}

/* Minimalist save section */
.save-actions[data-v-cee0fe40] {
  margin-top: 1rem;
  padding: 1rem;
  display: flex;
  align-items: center;
  gap: 1rem;
  background: white;
  border-radius: 8px;
  border: 1px solid #E5E7EB;
  max-width: 1200px;
  margin-left: auto;
  margin-right: auto;
}
.save-btn[data-v-cee0fe40] {
  background: #2563EB;
  color: white;
  border: none;
  padding: 0.625rem 1.25rem;
  border-radius: 6px;
  font-size: 0.875rem;
  font-weight: 500;
  cursor: pointer;
  transition: background-color 0.2s ease;
}
.save-btn[data-v-cee0fe40]:hover:not(:disabled) {
  background: #1D4ED8;
}
.save-btn[data-v-cee0fe40]:disabled {
  background: #D1D5DB;
  color: #9CA3AF;
  cursor: not-allowed;
}

/* Стили для списка добавленных лекарств */
.medications-list[data-v-cee0fe40] {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  margin-top: 1rem;
}

/* Стили для поиска лекарств */
.drug-search-section[data-v-cee0fe40] {
  margin-bottom: 1.5rem;
}
.search-container[data-v-cee0fe40] {
  background: #F9FAFB;
  border: 1px solid #E5E7EB;
  border-radius: 8px;
  padding: 1rem;
}
.search-input-group[data-v-cee0fe40] {
  position: relative;
}
.search-input[data-v-cee0fe40] {
  width: 100%;
  height: 40px;
  padding: 8px 40px 8px 12px;
  border: 1px solid #D1D5DB;
  border-radius: 6px;
  font-size: 14px;
  color: #1F2937;
  background: white;
  transition: border-color 0.2s;
}
.search-input[data-v-cee0fe40]:focus {
  outline: none;
  border-color: #2563EB;
  box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.1);
}
.clear-search-btn[data-v-cee0fe40] {
  position: absolute;
  right: 8px;
  top: 50%;
  transform: translateY(-50%);
  background: none;
  border: none;
  color: #9CA3AF;
  font-size: 18px;
  cursor: pointer;
  width: 24px;
  height: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 4px;
  transition: all 0.2s;
}
.clear-search-btn[data-v-cee0fe40]:hover {
  background: #F3F4F6;
  color: #6B7280;
}
.search-spinner[data-v-cee0fe40] {
  width: 16px;
  height: 16px;
  border: 2px solid #F3F4F6;
  border-top: 2px solid #2563EB;
  border-radius: 50%;
  animation: spin-cee0fe40 1s linear infinite;
}
.no-results[data-v-cee0fe40] {
  text-align: center;
  padding: 1rem;
  color: #6B7280;
  font-size: 0.875rem;
}
.no-results p[data-v-cee0fe40] {
  margin: 0;
}

/* Стили для классов лекарств */
.drug-classes-section[data-v-cee0fe40] {
  margin-bottom: 1.5rem;
}
.loading-classes[data-v-cee0fe40] {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  color: #6B7280;
  font-size: 0.875rem;
  padding: 1rem;
  justify-content: center;
}
.drug-classes-list[data-v-cee0fe40] {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.drug-class-item[data-v-cee0fe40] {
  background: white;
  border: 1px solid #E5E7EB;
  border-radius: 8px;
  overflow: hidden;
  transition: border-color 0.2s;
}
.drug-class-item[data-v-cee0fe40]:hover {
  border-color: #D1D5DB;
}
.drug-class-header[data-v-cee0fe40] {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1rem;
  cursor: pointer;
  background: #F9FAFB;
  transition: background-color 0.2s;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
}
.drug-class-header[data-v-cee0fe40]:hover {
  background: #F3F4F6;
}
.class-name[data-v-cee0fe40] {
  font-size: 0.875rem;
  font-weight: 600;
  color: #1F2937;
}
.class-arrow[data-v-cee0fe40] {
  font-size: 0.75rem;
  color: #6B7280;
  transition: transform 0.2s;
  transform: rotate(-90deg);
}
.class-arrow.expanded[data-v-cee0fe40] {
  transform: rotate(0deg);
}
.drug-class-content[data-v-cee0fe40] {
  padding: 0.75rem 1rem;
  background: white;
  border-top: 1px solid #E5E7EB;
}
.atx-groups-list[data-v-cee0fe40] {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}
.atx-group-item[data-v-cee0fe40] {
  border: 1px solid #E5E7EB;
  border-radius: 6px;
  overflow: hidden;
  background: white;
}
.atx-group-header[data-v-cee0fe40] {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 0.75rem;
  padding: 0.875rem 1rem;
  background: #F9FAFB;
  cursor: pointer;
  transition: background-color 0.2s;
}
.atx-group-header[data-v-cee0fe40]:hover {
  background: #F3F4F6;
}
.atx-group-name[data-v-cee0fe40] {
  font-size: 0.875rem;
  font-weight: 600;
  color: #1F2937;
}
.atx-group-content[data-v-cee0fe40] {
  padding: 0.75rem 1rem;
  border-top: 1px solid #E5E7EB;
  background: white;
}
.loading-drugs[data-v-cee0fe40] {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  color: #6B7280;
  font-size: 0.75rem;
  padding: 0.5rem;
  justify-content: center;
}
.no-drugs-in-class[data-v-cee0fe40] {
  text-align: center;
  padding: 1rem;
  color: #9CA3AF;
  font-size: 0.875rem;
}
.drugs-list[data-v-cee0fe40] {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.drug-item-wrapper[data-v-cee0fe40] {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.drug-item[data-v-cee0fe40] {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0.75rem;
  background: #F9FAFB;
  border: 1px solid #E5E7EB;
  border-radius: 6px;
  transition: border-color 0.2s;
}
.drug-item[data-v-cee0fe40]:hover {
  border-color: #D1D5DB;
  background: #F3F4F6;
}

/* Inline форма для недавно добавленного лекарства */
.inline-drug-form[data-v-cee0fe40] {
  background: #F0F9FF;
  border: 2px solid #2563EB;
  border-radius: 8px;
  padding: 1rem;
  margin-top: 0.5rem;
  animation: slideDown-cee0fe40 0.3s ease-out;
}
@keyframes slideDown-cee0fe40 {
from {
    opacity: 0;
    transform: translateY(-10px);
}
to {
    opacity: 1;
    transform: translateY(0);
}
}
.inline-form-header[data-v-cee0fe40] {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 1rem;
  padding-bottom: 0.5rem;
  border-bottom: 1px solid #E5E7EB;
}
.inline-form-title[data-v-cee0fe40] {
  font-size: 0.875rem;
  font-weight: 600;
  color: #1F2937;
}
.inline-form-close[data-v-cee0fe40] {
  background: none;
  border: none;
  color: #6B7280;
  font-size: 20px;
  width: 24px;
  height: 24px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 4px;
  transition: all 0.2s;
}
.inline-form-close[data-v-cee0fe40]:hover {
  background: #FEE2E2;
  color: #DC2626;
}
.inline-form-fields[data-v-cee0fe40] {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
}
.inline-field-group[data-v-cee0fe40] {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.inline-field-label[data-v-cee0fe40] {
  font-size: 0.75rem;
  color: #6B7280;
  font-weight: 500;
  text-transform: uppercase;
}
.inline-date-input[data-v-cee0fe40] {
  width: 100%;
  height: 36px;
  padding: 6px 10px;
  border: 1px solid #D1D5DB;
  border-radius: 6px;
  font-size: 0.875rem;
  color: #1F2937;
  background: white;
  transition: border-color 0.2s;
}
.inline-date-input[data-v-cee0fe40]:focus {
  outline: none;
  border-color: #2563EB;
  box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.1);
}
.inline-button-group[data-v-cee0fe40] {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}
.inline-dose-method-btn[data-v-cee0fe40] {
  padding: 0.375rem 0.75rem;
  border: 1px solid #D1D5DB;
  border-radius: 6px;
  font-size: 0.75rem;
  color: #374151;
  background: white;
  cursor: pointer;
  transition: all 0.2s ease;
  font-weight: 500;
}
.inline-dose-method-btn[data-v-cee0fe40]:hover {
  background: #F3F4F6;
  border-color: #9CA3AF;
}
.inline-dose-method-btn.active[data-v-cee0fe40] {
  background: #2563EB;
  color: white;
  border-color: #2563EB;
}
.inline-no-data[data-v-cee0fe40] {
  font-size: 0.75rem;
  color: #9CA3AF;
  padding: 0.5rem;
  text-align: center;
  width: 100%;
}

/* Кнопки действий в inline форме */
.inline-form-actions[data-v-cee0fe40] {
  display: flex;
  gap: 0.5rem;
  margin-top: 1rem;
  padding-top: 1rem;
  border-top: 1px solid #E5E7EB;
  justify-content: flex-end;
}
.inline-clear-btn[data-v-cee0fe40] {
  background: #F3F4F6;
  color: #374151;
  border: 1px solid #D1D5DB;
  padding: 0.5rem 1rem;
  border-radius: 6px;
  font-size: 0.875rem;
  cursor: pointer;
  transition: all 0.2s;
  font-weight: 500;
}
.inline-clear-btn[data-v-cee0fe40]:hover {
  background: #E5E7EB;
  border-color: #9CA3AF;
}
.inline-delete-btn[data-v-cee0fe40] {
  background: #FEE2E2;
  color: #DC2626;
  border: 1px solid #FECACA;
  padding: 0.5rem 1rem;
  border-radius: 6px;
  font-size: 0.875rem;
  cursor: pointer;
  transition: all 0.2s;
  font-weight: 500;
}
.inline-delete-btn[data-v-cee0fe40]:hover {
  background: #FECACA;
  border-color: #F87171;
  color: #B91C1C;
}

/* Стили для ошибок валидации */
.inline-field-group.has-error .inline-field-label[data-v-cee0fe40] {
  color: #DC2626;
}
.error-required[data-v-cee0fe40] {
  color: #DC2626;
  font-weight: bold;
  margin-left: 0.25rem;
}
.error-input[data-v-cee0fe40] {
  border-color: #DC2626 !important;
  background-color: #FEF2F2;
}
.error-input[data-v-cee0fe40]:focus {
  border-color: #DC2626 !important;
  box-shadow: 0 0 0 3px rgba(220, 38, 38, 0.1) !important;
}
.error-message[data-v-cee0fe40] {
  font-size: 0.75rem;
  color: #DC2626;
  margin-top: 0.25rem;
}
.inline-dose-method-btn.error-btn[data-v-cee0fe40] {
  border-color: #DC2626;
  background-color: #FEF2F2;
}

/* Стили для нижнего списка добавленных лекарств */
.completed-drugs-section[data-v-cee0fe40] {
  margin-top: 1.5rem;
}
.completed-drugs-list[data-v-cee0fe40] {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}
.completed-drug-card[data-v-cee0fe40] {
  background: white;
  border: 1px solid #E5E7EB;
  border-radius: 8px;
  padding: 1rem;
  transition: border-color 0.2s;
}
.completed-drug-card[data-v-cee0fe40]:hover {
  border-color: #D1D5DB;
}
.completed-drug-card.has-validation-errors[data-v-cee0fe40] {
  border-color: #DC2626;
  background: #FEF2F2;
}
.completed-drug-card.has-validation-errors[data-v-cee0fe40]:hover {
  border-color: #B91C1C;
}
.completed-drug-header[data-v-cee0fe40] {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 0.75rem;
  padding-bottom: 0.5rem;
  border-bottom: 1px solid #F3F4F6;
}
.completed-drug-name[data-v-cee0fe40] {
  font-size: 0.875rem;
  font-weight: 600;
  color: #1F2937;
}
.completed-drug-remove[data-v-cee0fe40] {
  background: none;
  border: none;
  color: #EF4444;
  font-size: 18px;
  width: 24px;
  height: 24px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 4px;
  transition: all 0.2s;
  font-weight: bold;
}
.completed-drug-remove[data-v-cee0fe40]:hover {
  background: #FEE2E2;
  color: #DC2626;
}
.completed-drug-info[data-v-cee0fe40] {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0.75rem;
}
.completed-drug-field[data-v-cee0fe40] {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}
.completed-field-label[data-v-cee0fe40] {
  font-size: 0.75rem;
  color: #6B7280;
  font-weight: 500;
  text-transform: uppercase;
}
.completed-field-value[data-v-cee0fe40] {
  font-size: 0.875rem;
  color: #1F2937;
  font-weight: 500;
}
.completed-field-value.error-value[data-v-cee0fe40] {
  color: #DC2626;
  font-weight: 600;
}
.completed-drug-field.has-error .completed-field-label[data-v-cee0fe40] {
  color: #DC2626;
}
.completed-error-message[data-v-cee0fe40] {
  font-size: 0.75rem;
  color: #DC2626;
  margin-top: 0.25rem;
  font-weight: 500;
}

/* Стили для автоскролла и подсветки ошибок */
.inline-drug-form.scroll-highlight[data-v-cee0fe40] {
  animation: highlightError-cee0fe40 0.5s ease-in-out;
  border-color: #DC2626 !important;
  box-shadow: 0 0 0 3px rgba(220, 38, 38, 0.2);
}
@keyframes highlightError-cee0fe40 {
0%, 100% {
    transform: scale(1);
}
50% {
    transform: scale(1.02);
}
}
.inline-drug-form.has-validation-errors[data-v-cee0fe40] {
  border-color: #DC2626;
  border-width: 2px;
  background: #FEF2F2;
  box-shadow: 0 0 0 3px rgba(220, 38, 38, 0.1);
}

/* Стили для уведомления об успешном сохранении */
.success-notification[data-v-cee0fe40] {
  position: fixed;
  top: 20px;
  right: 20px;
  background: #10B981;
  color: white;
  padding: 1rem 1.5rem;
  border-radius: 8px;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
  z-index: 10000;
  font-size: 0.875rem;
  font-weight: 500;
  opacity: 0;
  transform: translateX(100%);
  transition: all 0.3s ease;
  display: flex;
  align-items: center;
  gap: 0.75rem;
  min-width: 250px;
}
.success-notification.show[data-v-cee0fe40] {
  opacity: 1;
  transform: translateX(0);
}
.success-notification-icon[data-v-cee0fe40] {
  font-size: 1.25rem;
  font-weight: bold;
  width: 24px;
  height: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(255, 255, 255, 0.2);
  border-radius: 50%;
  flex-shrink: 0;
}
.success-notification-text[data-v-cee0fe40] {
  flex: 1;
}

/* Стили для глобального сообщения об ошибке */
.error-message-global[data-v-cee0fe40] {
  margin-top: 0.75rem;
  padding: 0.75rem 1rem;
  background: #FEE2E2;
  border: 1px solid #FECACA;
  border-radius: 6px;
  color: #DC2626;
  font-size: 0.875rem;
  font-weight: 500;
}

/* Стили для предупреждающего тостера (аллергия на препарат) */
.warning-notification[data-v-cee0fe40] {
  position: fixed;
  top: 20px;
  right: 20px;
  background: #FDBA74;
  color: #7C2D12;
  padding: 1rem 1.5rem;
  border-radius: 8px;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
  z-index: 10001;
  font-size: 0.875rem;
  font-weight: 500;
  opacity: 0;
  transform: translateX(100%);
  transition: all 0.3s ease;
  display: flex;
  align-items: center;
  gap: 0.75rem;
  min-width: 260px;
}
.warning-notification.show[data-v-cee0fe40] {
  opacity: 1;
  transform: translateX(0);
}
.warning-notification-icon[data-v-cee0fe40] {
  font-size: 1.1rem;
  font-weight: bold;
  width: 24px;
  height: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(124, 45, 18, 0.1);
  border-radius: 50%;
  flex-shrink: 0;
}
.warning-notification-text[data-v-cee0fe40] {
  flex: 1;
}
.success-notification-icon[data-v-cee0fe40] {
  font-size: 1.25rem;
  font-weight: bold;
  width: 24px;
  height: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(255, 255, 255, 0.2);
  border-radius: 50%;
  flex-shrink: 0;
}
.success-notification-text[data-v-cee0fe40] {
  flex: 1;
}

/* Стили для глобального сообщения об ошибке */
.error-message-global[data-v-cee0fe40] {
  margin-top: 0.75rem;
  padding: 0.75rem 1rem;
  background: #FEE2E2;
  border: 1px solid #FECACA;
  border-radius: 6px;
  color: #DC2626;
  font-size: 0.875rem;
  font-weight: 500;
}
.drug-name[data-v-cee0fe40] {
  font-size: 0.875rem;
  color: #1F2937;
  font-weight: 500;
}
.drug-item-actions[data-v-cee0fe40] {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin-left: 0.75rem;
}
.drug-info-btn[data-v-cee0fe40] {
  background: #EFF6FF;
  color: #1D4ED8;
  border: 1px solid #BFDBFE;
  padding: 0.375rem 0.75rem;
  border-radius: 4px;
  font-size: 0.75rem;
  cursor: pointer;
  transition: all 0.2s;
  white-space: nowrap;
}
.drug-info-btn[data-v-cee0fe40]:hover:not(:disabled) {
  background: #DBEAFE;
  border-color: #93C5FD;
}
.drug-info-btn[data-v-cee0fe40]:disabled {
  background: #F3F4F6;
  color: #9CA3AF;
  border-color: #E5E7EB;
  cursor: not-allowed;
}
.result-name[data-v-cee0fe40] {
  font-size: 0.875rem;
  color: #1F2937;
  font-weight: 500;
}
.add-drug-btn[data-v-cee0fe40] {
  background: #10B981;
  color: white;
  border: none;
  padding: 0.375rem 0.75rem;
  border-radius: 4px;
  font-size: 0.75rem;
  cursor: pointer;
  transition: background-color 0.2s;
  white-space: nowrap;
}
.add-drug-btn[data-v-cee0fe40]:hover:not(:disabled) {
  background: #059669;
}
.add-drug-btn[data-v-cee0fe40]:disabled {
  background: #D1D5DB;
  color: #9CA3AF;
  cursor: not-allowed;
}
.no-results[data-v-cee0fe40] {
  text-align: center;
  padding: 1rem;
  color: #6B7280;
  font-size: 0.875rem;
}
.no-results p[data-v-cee0fe40] {
  margin: 0;
}

/* Стили для кнопок управления лекарствами */
.card-actions[data-v-cee0fe40] {
  display: flex;
  gap: 0.5rem;
  align-items: center;
}
.remove-drug-btn[data-v-cee0fe40] {
  background: #FEF3C7;
  color: #D97706;
  border: 1px solid #FCD34D;
  padding: 0.375rem 0.75rem;
  border-radius: 4px;
  font-size: 0.75rem;
  cursor: pointer;
  transition: all 0.2s;
  font-weight: 500;
}
.remove-drug-btn[data-v-cee0fe40]:hover {
  background: #FDE68A;
  border-color: #F59E0B;
  color: #B45309;
}
.drug-info-modal-overlay[data-v-cee0fe40] {
  position: fixed;
  inset: 0;
  background: rgba(15, 23, 42, 0.55);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1rem;
  z-index: 1100;
}
.drug-info-modal[data-v-cee0fe40] {
  width: min(980px, 100%);
  max-height: 92vh;
  background: #FFFFFF;
  border: 1px solid #E5E7EB;
  border-radius: 12px;
  box-shadow: 0 20px 36px rgba(15, 23, 42, 0.28);
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.drug-info-modal-header[data-v-cee0fe40] {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  padding: 1rem 1.25rem;
  border-bottom: 1px solid #E5E7EB;
  background: #F8FAFC;
}
.drug-info-modal-title[data-v-cee0fe40] {
  margin: 0;
  font-size: 1rem;
  font-weight: 700;
  color: #0F172A;
}
.drug-info-modal-subtitle[data-v-cee0fe40] {
  margin: 0.25rem 0 0;
  font-size: 0.875rem;
  color: #475569;
  font-weight: 500;
}
.drug-info-modal-close[data-v-cee0fe40] {
  background: transparent;
  border: 1px solid #CBD5E1;
  color: #475569;
  width: 30px;
  height: 30px;
  border-radius: 6px;
  cursor: pointer;
  font-size: 1.125rem;
  line-height: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.drug-info-modal-close[data-v-cee0fe40]:hover {
  background: #EFF6FF;
  border-color: #93C5FD;
  color: #1D4ED8;
}
.drug-info-modal-body[data-v-cee0fe40] {
  overflow-y: auto;
  padding: 1rem 1.25rem 1.25rem;
}
.drug-info-loading[data-v-cee0fe40],
.drug-info-empty[data-v-cee0fe40],
.drug-info-error[data-v-cee0fe40] {
  padding: 1rem;
  border-radius: 8px;
  font-size: 0.875rem;
}
.drug-info-loading[data-v-cee0fe40] {
  background: #EFF6FF;
  color: #1D4ED8;
  border: 1px solid #BFDBFE;
}
.drug-info-error[data-v-cee0fe40] {
  background: #FEF2F2;
  color: #B91C1C;
  border: 1px solid #FECACA;
}
.drug-info-empty[data-v-cee0fe40] {
  background: #F8FAFC;
  color: #475569;
  border: 1px solid #E2E8F0;
}
.drug-info-grid[data-v-cee0fe40] {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}
.drug-info-field[data-v-cee0fe40] {
  border: 1px solid #E2E8F0;
  border-radius: 10px;
  background: #FFFFFF;
  padding: 0.875rem;
}
.drug-info-field-title[data-v-cee0fe40] {
  margin: 0 0 0.5rem;
  font-size: 0.875rem;
  font-weight: 700;
  color: #1E293B;
}
.drug-info-field-content[data-v-cee0fe40] {
  font-size: 0.875rem;
  line-height: 1.55;
  color: #334155;
  position: relative;
}
.drug-info-field-content.collapsed[data-v-cee0fe40] {
  max-height: 12rem;
  overflow: hidden;
}
.drug-info-field-content.collapsed[data-v-cee0fe40]::after {
  content: '...';
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 2.5rem;
  padding-right: 0.25rem;
  display: flex;
  align-items: flex-end;
  justify-content: flex-end;
  background: linear-gradient(to bottom, rgba(255, 255, 255, 0), #ffffff 70%);
  color: #64748B;
  font-weight: 700;
}
.drug-info-field-content[data-v-cee0fe40] p {
  margin: 0 0 0.55rem;
}
.drug-info-field-content[data-v-cee0fe40] p:last-child {
  margin-bottom: 0;
}
.drug-info-field-content[data-v-cee0fe40] ul,
.drug-info-field-content[data-v-cee0fe40] ol {
  margin: 0.2rem 0 0.55rem 1rem;
  padding: 0;
}
.drug-info-field-content[data-v-cee0fe40] li {
  margin-bottom: 0.3rem;
}
.drug-info-field-content[data-v-cee0fe40] br {
  content: '';
}
.drug-info-toggle-btn[data-v-cee0fe40] {
  margin-top: 0.5rem;
  border: none;
  background: transparent;
  color: #1D4ED8;
  font-size: 0.75rem;
  font-weight: 600;
  cursor: pointer;
  padding: 0;
}
.drug-info-toggle-btn[data-v-cee0fe40]:hover {
  color: #1E40AF;
  text-decoration: underline;
}
.drug-info-empty-field[data-v-cee0fe40] {
  font-size: 0.8125rem;
  color: #94A3B8;
}

/* Стили для кнопки очистки полей */
.clear-btn[data-v-cee0fe40] {
  background: none;
  border: none;
  color: #EF4444;
  font-size: 16px;
  width: 20px;
  height: 20px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.2s;
  font-weight: bold;
  border-radius: 4px;
}
.clear-btn[data-v-cee0fe40]:hover {
  background: #FEE2E2;
  color: #DC2626;
}

/* Стили для select элементов */
.form-select[data-v-cee0fe40] {
  width: 100%;
  height: 40px;
  padding: 8px 12px;
  border: 1px solid #D1D5DB;
  border-radius: 6px;
  font-size: 14px;
  color: #1F2937;
  background: white;
  cursor: pointer;
  transition: border-color 0.2s;
}
.form-select[data-v-cee0fe40]:focus {
  outline: none;
  border-color: #1D4ED8;
  box-shadow: 0 0 0 3px rgba(107, 70, 193, 0.1);
}

/* Стили для группы кнопок дозировки и метода применения */
.button-group[data-v-cee0fe40] {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-top: 0.25rem;
}
.dose-method-btn[data-v-cee0fe40] {
  padding: 0.5rem 1rem;
  border: 1px solid #D1D5DB;
  border-radius: 6px;
  font-size: 0.875rem;
  color: #374151;
  background: white;
  cursor: pointer;
  transition: all 0.2s ease;
  font-weight: 500;
}
.dose-method-btn[data-v-cee0fe40]:hover {
  background: #F3F4F6;
  border-color: #9CA3AF;
  transform: translateY(-1px);
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}
.dose-method-btn.active[data-v-cee0fe40] {
  background: #2563EB;
  color: white;
  border-color: #2563EB;
  box-shadow: 0 2px 4px rgba(37, 99, 235, 0.3);
}
.dose-method-btn.active[data-v-cee0fe40]:hover {
  background: #1D4ED8;
  border-color: #1D4ED8;
}
.no-data-message[data-v-cee0fe40] {
  font-size: 12px;
  color: #9CA3AF;
  margin-top: 4px;
  padding: 0.5rem;
  text-align: center;
  width: 100%;
}



/* Адаптивность */
@media (max-width: 768px) {
.drug-item[data-v-cee0fe40] {
    flex-direction: column;
    gap: 0.5rem;
    align-items: stretch;
}
.drug-item-actions[data-v-cee0fe40] {
    margin-left: 0;
    width: 100%;
    flex-direction: column;
    gap: 0.375rem;
}
.drug-info-btn[data-v-cee0fe40],
  .add-drug-btn[data-v-cee0fe40] {
    width: 100%;
}
.card-actions[data-v-cee0fe40] {
    flex-direction: column;
    gap: 0.5rem;
}
.remove-drug-btn[data-v-cee0fe40] {
    width: 100%;
    text-align: center;
}
.drug-class-header[data-v-cee0fe40] {
    padding: 0.75rem;
}
.drug-class-content[data-v-cee0fe40] {
    padding: 0.5rem 0.75rem;
}
.inline-form-fields[data-v-cee0fe40] {
    grid-template-columns: 1fr;
    gap: 0.75rem;
}
.inline-form-actions[data-v-cee0fe40] {
    flex-direction: column;
}
.inline-clear-btn[data-v-cee0fe40],
  .inline-delete-btn[data-v-cee0fe40] {
    width: 100%;
}
.completed-drug-info[data-v-cee0fe40] {
    grid-template-columns: 1fr;
}
.drug-info-modal[data-v-cee0fe40] {
    width: 100%;
    max-height: 95vh;
}
.drug-info-modal-header[data-v-cee0fe40],
  .drug-info-modal-body[data-v-cee0fe40] {
    padding: 0.875rem;
}
}


.success-notification {
  position: fixed;
  top: 20px;
  right: 20px;
  background: #10B981;
  color: white;
  padding: 1rem 1.5rem;
  border-radius: 8px;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
  z-index: 10000;
  font-size: 0.875rem;
  font-weight: 500;
  opacity: 0;
  transform: translateX(100%);
  transition: all 0.3s ease;
  display: flex;
  align-items: center;
  gap: 0.75rem;
  min-width: 250px;
}
.success-notification.show {
  opacity: 1;
  transform: translateX(0);
}
.success-notification-icon {
  font-size: 1.25rem;
  font-weight: bold;
  width: 24px;
  height: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(255, 255, 255, 0.2);
  border-radius: 50%;
  flex-shrink: 0;
}
.success-notification-text {
  flex: 1;
}
.gos-badge {
  display: inline-block;
  background-color: #10b981;
  color: white;
  font-size: 0.65rem;
  font-weight: 700;
  padding: 1px 4px;
  border-radius: 4px;
  margin-left: 6px;
  vertical-align: middle;
  line-height: 1.2;
}
.warning-notification {
  position: fixed;
  top: 20px;
  right: 20px;
  background: #FDBA74;
  color: #7C2D12;
  padding: 1rem 1.5rem;
  border-radius: 8px;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
  z-index: 10001;
  font-size: 0.875rem;
  font-weight: 500;
  opacity: 0;
  transform: translateX(100%);
  transition: all 0.3s ease;
  display: flex;
  align-items: center;
  gap: 0.75rem;
  min-width: 260px;
}
.warning-notification.show {
  opacity: 1;
  transform: translateX(0);
}
.warning-notification-icon {
  font-size: 1.1rem;
  font-weight: bold;
  width: 24px;
  height: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(124, 45, 18, 0.1);
  border-radius: 50%;
  flex-shrink: 0;
}
.warning-notification-text {
  flex: 1;
}


/* Minimalist layout */
.nao-tab[data-v-47f52070] {
  padding: 0;
  max-width: 1200px;
  margin: 0 auto;
  position: relative;
}

/* Локальный индикатор загрузки */
.tab-loading-overlay[data-v-47f52070] {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(255, 255, 255, 0.9);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 100;
  backdrop-filter: blur(2px);
}
.tab-spinner[data-v-47f52070] {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1rem;
  padding: 2rem;
  background: white;
  border-radius: 12px;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
  border: 1px solid #E5E7EB;
}
.spinner-circle[data-v-47f52070] {
  width: 32px;
  height: 32px;
  border: 3px solid #F3F4F6;
  border-top: 3px solid #2563EB;
  border-radius: 50%;
  animation: spin-47f52070 1s linear infinite;
}
@keyframes spin-47f52070 {
0% { transform: rotate(0deg);
}
100% { transform: rotate(360deg);
}
}
.loading-text[data-v-47f52070] {
  margin: 0;
  font-size: 0.875rem;
  color: #6B7280;
  font-weight: 500;
}
.haq-toolbar[data-v-47f52070] {
  padding: 1rem;
  margin: 0 1rem 0.75rem;
  background: #FFFFFF;
  border: 1px solid #E5E7EB;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
}
.source-visit-info[data-v-47f52070] {
  font-size: 0.875rem;
  color: #374151;
}
.source-visit-date[data-v-47f52070] {
  margin-left: 0.25rem;
  color: #1D4ED8;
  font-weight: 600;
}
.new-questionnaire-btn[data-v-47f52070] {
  background: #EFF6FF;
  color: #1D4ED8;
  border: 1px solid #BFDBFE;
  padding: 0.5rem 0.875rem;
  border-radius: 6px;
  font-size: 0.8125rem;
  font-weight: 600;
  cursor: pointer;
  transition: background-color 0.2s ease, border-color 0.2s ease;
  white-space: nowrap;
}
.new-questionnaire-btn[data-v-47f52070]:hover:not(:disabled) {
  background: #DBEAFE;
  border-color: #93C5FD;
}
.new-questionnaire-btn[data-v-47f52070]:disabled {
  background: #F3F4F6;
  border-color: #E5E7EB;
  color: #9CA3AF;
  cursor: not-allowed;
}
.main-layout.loading[data-v-47f52070] {
  opacity: 0.6;
  pointer-events: none;
}
.main-layout[data-v-47f52070] {
  padding: 1rem;
  background: transparent;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.section[data-v-47f52070] {
  margin-bottom: 0;
  padding: 1.25rem;
  background: white;
  border-radius: 8px;
  border: 1px solid #E5E7EB;
  transition: border-color 0.2s ease;
}
.section[data-v-47f52070]:hover {
  border-color: #D1D5DB;
}

/* Minimalist section headers */
.section-header[data-v-47f52070] {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0 0 0.75rem 0;
  margin: 0 0 1rem 0;
  border-bottom: 1px solid #F3F4F6;
}
.section-title[data-v-47f52070] {
  font-size: 0.75rem;
  font-weight: 600;
  color: #6B7280;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin: 0;
}
.clear-section-btn[data-v-47f52070] {
  background: none;
  border: 1px solid #E5E7EB;
  color: #9CA3AF;
  font-size: 14px;
  width: 24px;
  height: 24px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.2s ease;
  font-weight: 400;
  border-radius: 4px;
}
.clear-section-btn[data-v-47f52070]:hover {
  background: #F9FAFB;
  border-color: #DC2626;
  color: #DC2626;
}
.section-content[data-v-47f52070] {
  padding: 0;
}
.question[data-v-47f52070] {
  margin-bottom: 20px;
}
.question-text[data-v-47f52070] {
  font-size: 12px;
  color: #1F2937;
  margin-bottom: 12px;
  line-height: 1.4;
}
.answer-buttons[data-v-47f52070] {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}
.answer-btn[data-v-47f52070] {
  padding: 8px 16px;
  border-radius: 20px;
  border: none;
  font-size: 11px;
  cursor: pointer;
  background: #E5E7EB;
  color: #374151;
  transition: all 0.2s ease;
}
.answer-btn[data-v-47f52070]:hover {
  background: #D1D5DB;
}
.answer-btn.active[data-v-47f52070] {
  background: #1D4ED8;
  color: white;
}
.checkbox-list[data-v-47f52070] {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-bottom: 16px;
}
.checkbox-item[data-v-47f52070] {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  cursor: pointer;
  font-size: 12px;
  color: #1F2937;
  line-height: 1.4;
}
.checkbox-item input[type="checkbox"][data-v-47f52070] {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  width: 16px;
  height: 16px;
  border: 1px solid #D1D5DB;
  border-radius: 3px;
  background: white;
  position: relative;
  cursor: pointer;
  flex-shrink: 0;
  margin-top: 2px;
}
.checkbox-item input[type="checkbox"][data-v-47f52070]:checked {
  background: #3B82F6;
  border-color: #3B82F6;
}
.checkbox-item input[type="checkbox"][data-v-47f52070]:checked::after {
  content: '✓';
  position: absolute;
  top: -1px;
  left: 2px;
  color: white;
  font-size: 11px;
  font-weight: bold;
}
.checkmark[data-v-47f52070] {
  /* Hidden as we use CSS pseudo-element instead */
  display: none;
}
.other-input[data-v-47f52070] {
  margin: 12px 0;
}
.other-text-input[data-v-47f52070] {
  width: 100%;
  max-width: 400px;
  padding: 8px 12px;
  border: 1px solid #D1D5DB;
  border-radius: 6px;
  font-size: 12px;
  background: white;
}
.other-text-input[data-v-47f52070]:focus {
  outline: none;
  border-color: #1D4ED8;
  box-shadow: 0 0 0 2px rgba(107, 70, 193, 0.1);
}

/* Стили для текстовых полей */
.text-input[data-v-47f52070] {
  margin: 12px 0;
}
.text-field[data-v-47f52070] {
  width: 100%;
  max-width: 400px;
  padding: 8px 12px;
  border: 1px solid #D1D5DB;
  border-radius: 6px;
  font-size: 12px;
  background: white;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}
.text-field[data-v-47f52070]:focus {
  outline: none;
  border-color: #1D4ED8;
  box-shadow: 0 0 0 2px rgba(107, 70, 193, 0.1);
}
.add-btn[data-v-47f52070] {
  background: #F3F4F6;
  color: #374151;
  border: none;
  padding: 8px 16px;
  border-radius: 6px;
  font-size: 12px;
  cursor: pointer;
  transition: background 0.2s ease;
}
.add-btn[data-v-47f52070]:hover {
  background: #E5E7EB;
}
.save-section[data-v-47f52070] {
  margin-top: 3rem;
  text-align: center;
  padding: 2rem 0;
  border-top: 1px solid #E5E7EB;
}
.save-btn[data-v-47f52070] {
  background: #1D4ED8;
  color: white;
  border: none;
  padding: 12px 32px;
  border-radius: 8px;
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s ease;
  min-width: 120px;
}
.save-btn[data-v-47f52070]:hover:not(:disabled) {
  background: #553C9A;
  transform: translateY(-1px);
}
.save-btn[data-v-47f52070]:disabled {
  background: #9CA3AF;
  cursor: not-allowed;
  transform: none;
}
@media (max-width: 768px) {
.nao-tab[data-v-47f52070] {
    padding: 1rem;
}
.haq-toolbar[data-v-47f52070] {
    margin: 0 0 0.75rem;
    flex-direction: column;
    align-items: stretch;
}
.new-questionnaire-btn[data-v-47f52070] {
    width: 100%;
}
.answer-buttons[data-v-47f52070] {
    flex-direction: column;
    align-items: flex-start;
}
.answer-btn[data-v-47f52070] {
    width: auto;
    min-width: 180px;
}
}

/* Адаптивность для больших экранов */
@media (min-width: 1400px) {
.nao-tab[data-v-47f52070] {
    max-width: 1300px;
    margin: 0 auto;
}
.questionnaire[data-v-47f52070] {
    padding: 2rem;
}
.section[data-v-47f52070] {
    padding: 1.5rem;
    margin-bottom: 2rem;
}
.question[data-v-47f52070] {
    margin-bottom: 2rem;
}
.question-text[data-v-47f52070] {
    font-size: 0.9rem;
    margin-bottom: 1rem;
}
}
@media (min-width: 1600px) {
.nao-tab[data-v-47f52070] {
    max-width: 1500px;
}
.questionnaire[data-v-47f52070] {
    padding: 2.5rem;
}
.section[data-v-47f52070] {
    padding: 2rem;
    margin-bottom: 2.5rem;
}
.question[data-v-47f52070] {
    margin-bottom: 2.5rem;
}
.question-text[data-v-47f52070] {
    font-size: 0.95rem;
    margin-bottom: 1.25rem;
}
.answer-btn[data-v-47f52070] {
    padding: 0.75rem 1.25rem;
    font-size: 0.85rem;
}
}
@media (min-width: 1920px) {
.nao-tab[data-v-47f52070] {
    max-width: 1700px;
}
.questionnaire[data-v-47f52070] {
    padding: 3rem;
}
.section[data-v-47f52070] {
    padding: 2.5rem;
    margin-bottom: 3rem;
}
.question[data-v-47f52070] {
    margin-bottom: 3rem;
}
.question-text[data-v-47f52070] {
    font-size: 1rem;
    margin-bottom: 1.5rem;
}
.answer-btn[data-v-47f52070] {
    padding: 0.9rem 1.5rem;
    font-size: 0.9rem;
}
.page-header h1[data-v-47f52070] {
    font-size: 1.75rem;
}
}

/* Minimalist save section */
.save-actions[data-v-47f52070] {
  margin-top: 1rem;
  padding: 1rem;
  display: flex;
  align-items: center;
  gap: 1rem;
  background: white;
  border-radius: 8px;
  border: 1px solid #E5E7EB;
  max-width: 1200px;
  margin-left: auto;
  margin-right: auto;
}
.save-btn[data-v-47f52070] {
  background: #2563EB;
  color: white;
  border: none;
  padding: 0.625rem 1.25rem;
  border-radius: 6px;
  font-size: 0.875rem;
  font-weight: 500;
  cursor: pointer;
  transition: background-color 0.2s ease;
}
.save-btn[data-v-47f52070]:hover:not(:disabled) {
  background: #1D4ED8;
}
.save-btn[data-v-47f52070]:disabled {
  background: #D1D5DB;
  color: #9CA3AF;
  cursor: not-allowed;
}
.unsaved-indicator[data-v-47f52070] {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.75rem;
  color: #F59E0B;
  margin-left: 1rem;
}
.unsaved-dot[data-v-47f52070] {
  color: #F59E0B;
  font-size: 1rem;
  animation: blink-47f52070 1.5s infinite;
}
@keyframes blink-47f52070 {
0%, 50% { opacity: 1;
}
51%, 100% { opacity: 0.3;
}
}
.unsaved-text[data-v-47f52070] {
  font-weight: 500;
}


.autosave-notification-container[data-v-bd7574e0] {
  position: fixed;
  top: 20px;
  right: 20px;
  z-index: 9999;
  pointer-events: none;
}
.autosave-notification[data-v-bd7574e0] {
  background: white;
  border-radius: 12px;
  padding: 16px 20px;
  box-shadow: 0 10px 25px rgba(0, 0, 0, 0.15);
  border: 1px solid #E5E7EB;
  min-width: 280px;
  max-width: 400px;
  pointer-events: auto;
  position: relative;
  overflow: hidden;
}
.autosave-notification[data-v-bd7574e0]::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: #10B981;
  border-radius: 12px 12px 0 0;
}
.notification-saving[data-v-bd7574e0]::before {
  background: #2563EB;
}
.notification-error[data-v-bd7574e0]::before {
  background: #EF4444;
}
.notification-content[data-v-bd7574e0] {
  display: flex;
  align-items: center;
  gap: 12px;
}
.notification-icon[data-v-bd7574e0] {
  flex-shrink: 0;
  width: 24px;
  height: 24px;
  color: #10B981;
}
.notification-saving .notification-icon[data-v-bd7574e0] {
  color: #2563EB;
}
.notification-error .notification-icon[data-v-bd7574e0] {
  color: #EF4444;
}
.spinner[data-v-bd7574e0] {
  animation: spin-bd7574e0 1s linear infinite;
}
.spinner circle[data-v-bd7574e0] {
  animation: dash-bd7574e0 1.5s ease-in-out infinite;
}
@keyframes spin-bd7574e0 {
0% { transform: rotate(0deg);
}
100% { transform: rotate(360deg);
}
}
@keyframes dash-bd7574e0 {
0% {
    stroke-dasharray: 1, 150;
    stroke-dashoffset: 0;
}
50% {
    stroke-dasharray: 90, 150;
    stroke-dashoffset: -35;
}
100% {
    stroke-dasharray: 90, 150;
    stroke-dashoffset: -124;
}
}
.notification-text[data-v-bd7574e0] {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.notification-title[data-v-bd7574e0] {
  font-size: 14px;
  font-weight: 600;
  color: #1F2937;
  line-height: 1.2;
}
.notification-subtitle[data-v-bd7574e0] {
  font-size: 12px;
  color: #6B7280;
  line-height: 1.2;
}

/* Анимации */
.slide-fade-enter-active[data-v-bd7574e0] {
  transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1);
}
.slide-fade-leave-active[data-v-bd7574e0] {
  transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1);
}
.slide-fade-enter-from[data-v-bd7574e0] {
  transform: translateX(100%);
  opacity: 0;
}
.slide-fade-leave-to[data-v-bd7574e0] {
  transform: translateX(100%);
  opacity: 0;
}

/* Адаптивность для мобильных */
@media (max-width: 480px) {
.autosave-notification-container[data-v-bd7574e0] {
    top: 10px;
    right: 10px;
    left: 10px;
}
.autosave-notification[data-v-bd7574e0] {
    min-width: auto;
    max-width: none;
    width: 100%;
}
}


.patient-profile[data-v-5610aac2] {
  --accent: #2563eb;
  --accent-hover: #1d4ed8;
  --accent-soft: #eff6ff;
  --surface: #ffffff;
  --surface-muted: #f8fafc;
  --border: #e2e8f0;
  --border-strong: #cbd5e1;
  --text-primary: #0f172a;
  --text-secondary: #475569;

  min-height: 100vh;
  background: linear-gradient(180deg, #f8fafc 0%, #f1f5f9 100%);
}
.header[data-v-5610aac2] {
  background: linear-gradient(90deg, #1e3a8a 0%, #1e40af 45%, #2563eb 100%);
  color: #f8fafc;
  padding: 0.75rem 0;
  border-bottom: 1px solid rgba(255, 255, 255, 0.2);
  box-shadow: 0 8px 28px rgba(30, 64, 175, 0.22);
}
.header-content[data-v-5610aac2] {
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0 1rem;
}
.title-section[data-v-5610aac2] {
  flex: 1;
}
.title[data-v-5610aac2] {
  font-size: 1.25rem;
  font-weight: 700;
  letter-spacing: 0.25px;
  margin-bottom: 0.25rem;
}
.breadcrumb[data-v-5610aac2] {
  font-size: 0.8rem;
  opacity: 0.9;
}
.patient-name-accent[data-v-5610aac2] {
  font-weight: 700;
  color: #dbeafe;
}
.header-actions[data-v-5610aac2] {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}
.search-container[data-v-5610aac2] {
  position: relative;
  display: flex;
  align-items: center;
  background: rgba(255,255,255,0.15);
  border-radius: 6px;
  padding: 0.375rem 0.5rem;
}
.search-container .search-input[data-v-5610aac2]::-moz-placeholder {
  color: white !important;
  opacity: 1 !important;
}
.search-container .search-input[data-v-5610aac2]::placeholder {
  color: white !important;
  opacity: 1 !important;
}
.search-container .search-input[data-v-5610aac2]::-webkit-input-placeholder {
  color: white !important;
  opacity: 1 !important;
}
.search-container .search-input[data-v-5610aac2]::-moz-placeholder {
  color: white !important;
  opacity: 1 !important;
}
.search-container .search-input[data-v-5610aac2]:-ms-input-placeholder {
  color: white !important;
  opacity: 1 !important;
}
.search-input[data-v-5610aac2] {
  background: transparent;
  border: none;
  color: white;
  padding: 0.25rem 0.5rem;
  font-size: 0.875rem;
  outline: none;
  min-width: 180px;
}
.search-input[data-v-5610aac2]::-moz-placeholder {
  color: white !important;
  opacity: 1 !important;
}
.search-input[data-v-5610aac2]::placeholder {
  color: white !important;
  opacity: 1 !important;
}
.search-input[data-v-5610aac2]::-webkit-input-placeholder {
  color: white !important;
  opacity: 1 !important;
}
.search-input[data-v-5610aac2]::-moz-placeholder {
  color: white !important;
  opacity: 1 !important;
}
.search-input[data-v-5610aac2]:-ms-input-placeholder {
  color: white !important;
  opacity: 1 !important;
}
.search-btn[data-v-5610aac2] {
  background: none;
  border: none;
  color: white;
  font-size: 1rem;
  cursor: pointer;
  padding: 0.25rem;
}
.navigation-buttons[data-v-5610aac2] {
  display: flex;
  gap: 0.5rem;
}
.nav-btn[data-v-5610aac2] {
  background: rgba(255,255,255,0.15);
  border: 1px solid rgba(255,255,255,0.25);
  color: white;
  padding: 0.5rem 0.75rem;
  border-radius: 6px;
  font-size: 0.875rem;
  cursor: pointer;
  transition: all 0.2s ease;
  display: flex;
  align-items: center;
  justify-content: center;
  white-space: nowrap;
}
.nav-btn[data-v-5610aac2]:hover {
  background: rgba(255,255,255,0.25);
  transform: translateY(-1px);
}



/* Стили для dropdown поиска */
.search-dropdown[data-v-5610aac2] {
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  background: white;
  border-radius: 8px;
  box-shadow: 0 10px 25px rgba(0,0,0,0.15);
  border: 1px solid #e5e7eb;
  overflow: hidden;
  z-index: 1000;
  margin-top: 4px;
  animation: slideDownFade-5610aac2 0.2s ease-out;
  max-height: 400px;
  overflow-y: auto;
}
@keyframes slideDownFade-5610aac2 {
from {
    opacity: 0;
    transform: translateY(-10px);
}
to {
    opacity: 1;
    transform: translateY(0);
}
}
.dropdown-header[data-v-5610aac2] {
  padding: 0.75rem 1rem;
  background: #f8fafc;
  border-bottom: 1px solid #e5e7eb;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.results-count[data-v-5610aac2] {
  font-size: 0.8rem;
  font-weight: 600;
  color: #374151;
}
.showing-limit[data-v-5610aac2] {
  font-size: 0.75rem;
  color: #6b7280;
  font-style: italic;
}
.dropdown-list[data-v-5610aac2] {
  max-height: 320px;
  overflow-y: auto;
}
.dropdown-item[data-v-5610aac2] {
  display: flex;
  align-items: center;
  padding: 0.875rem 1rem;
  cursor: pointer;
  transition: all 0.2s ease;
  border-bottom: 1px solid #f3f4f6;
}
.dropdown-item[data-v-5610aac2]:last-child {
  border-bottom: none;
}
.dropdown-item[data-v-5610aac2]:hover {
  background: #f8fafc;
  transform: translateX(2px);
}
.dropdown-item.active[data-v-5610aac2] {
  background: rgba(37, 99, 235, 0.08);
  border-left: 3px solid #2563EB;
}
.dropdown-patient-info[data-v-5610aac2] {
  flex: 1;
}
.dropdown-patient-name[data-v-5610aac2] {
  font-size: 0.9rem;
  font-weight: 600;
  color: #1f2937;
  margin-bottom: 0.25rem;
}
.dropdown-patient-details[data-v-5610aac2] {
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
}
.dropdown-iin[data-v-5610aac2],
.dropdown-birth[data-v-5610aac2] {
  font-size: 0.75rem;
  color: #6b7280;
}
.dropdown-select-icon[data-v-5610aac2] {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  color: #2563EB;
  font-weight: bold;
  margin-left: 1rem;
}
.dropdown-item.active .dropdown-select-icon[data-v-5610aac2] {
  color: #2563EB;
}
.dropdown-no-results[data-v-5610aac2] {
  padding: 1.5rem;
  text-align: center;
  color: #6b7280;
  font-size: 0.875rem;
  font-style: italic;
}
.dropdown-loading[data-v-5610aac2] {
  padding: 1rem;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  color: #6b7280;
  font-size: 0.875rem;
}
.create-patient-btn[data-v-5610aac2] {
  background: rgba(255,255,255,0.15);
  border: 1px solid rgba(255,255,255,0.25);
  color: white;
  padding: 0.5rem 1rem;
  border-radius: 6px;
  font-size: 0.8rem;
  font-weight: 500;
  cursor: pointer;
  transition: background-color 0.2s ease;
}
.create-patient-btn[data-v-5610aac2]:hover {
  background: rgba(255,255,255,0.25);
}
.test-patient-btn[data-v-5610aac2] {
  background: rgba(245, 158, 11, 0.9);
  border: 1px solid rgba(245, 158, 11, 0.3);
  color: white;
  padding: 0.75rem 1.5rem;
  border-radius: 8px;
  font-size: 0.9rem;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.3s ease;
  margin-left: 0.5rem;
}
.test-patient-btn[data-v-5610aac2]:hover {
  background: rgba(217, 119, 6, 0.9);
}
.user-menu[data-v-5610aac2] {
  position: relative;
}
.user-avatar[data-v-5610aac2] {
  width: 40px;
  height: 40px;
  background: rgba(255, 255, 255, 0.2);
  border: 2px solid rgba(255, 255, 255, 0.3);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s ease;
  font-size: 1rem;
}
.user-avatar[data-v-5610aac2]:hover {
  background: rgba(255,255,255,0.3);
  transform: scale(1.05);
}
.user-dropdown[data-v-5610aac2] {
  position: absolute;
  top: 50px;
  right: 0;
  background: white;
  border-radius: 8px;
  box-shadow: 0 10px 25px rgba(0,0,0,0.15);
  min-width: 200px;
  z-index: 1000;
  border: 1px solid #e5e7eb;
  overflow: hidden;
  animation: slideDown-5610aac2 0.2s ease-out;
}
@keyframes slideDown-5610aac2 {
from {
    opacity: 0;
    transform: translateY(-10px);
}
to {
    opacity: 1;
    transform: translateY(0);
}
}
.user-info[data-v-5610aac2] {
  padding: 1rem;
  background: #f9fafb;
}
.user-name[data-v-5610aac2] {
  display: block;
  font-weight: 600;
  color: #1f2937;
  font-size: 0.875rem;
  margin-bottom: 0.25rem;
}
.user-email[data-v-5610aac2] {
  display: block;
  color: #6b7280;
  font-size: 0.75rem;
}
.user-specialization[data-v-5610aac2] {
  display: block;
  color: #2563EB;
  font-size: 0.7rem;
  font-weight: 500;
  margin-top: 0.25rem;
  font-style: italic;
}
.user-clinic[data-v-5610aac2] {
  margin-top: 0.5rem;
  padding-top: 0.5rem;
  border-top: 1px solid #f3f4f6;
}
.clinic-name[data-v-5610aac2] {
  display: block;
  color: #374151;
  font-size: 0.75rem;
  font-weight: 500;
  margin-bottom: 0.25rem;
}
.clinic-region[data-v-5610aac2] {
  display: block;
  color: #6b7280;
  font-size: 0.7rem;
}
.dropdown-divider[data-v-5610aac2] {
  margin: 0;
  border: none;
  border-top: 1px solid #e5e7eb;
}
.logout-btn[data-v-5610aac2] {
  width: 100%;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.75rem 1rem;
  background: none;
  border: none;
  color: #dc2626;
  font-size: 0.875rem;
  cursor: pointer;
  transition: background-color 0.2s ease;
}
.logout-btn[data-v-5610aac2]:hover {
  background: #fef2f2;
}
.logout-icon[data-v-5610aac2] {
  font-size: 1rem;
}
.main-content[data-v-5610aac2] {
  display: flex;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0.75rem;
  gap: 0.75rem;
}
.sidebar[data-v-5610aac2] {
  width: 200px;
  background: white;
  border-radius: 8px;
  padding: 1rem;
  border: 1px solid #E5E7EB;
  height: -moz-fit-content;
  height: fit-content;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
}
.sidebar-header[data-v-5610aac2] {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 0.75rem;
  padding-bottom: 0.5rem;
  border-bottom: 1px solid #F3F4F6;
}
.sidebar-title[data-v-5610aac2] {
  font-size: 0.75rem;
  font-weight: 700;
  color: #374151;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.create-visit-btn[data-v-5610aac2] {
  width: 24px;
  height: 24px;
  border: 1px solid #2563EB;
  border-radius: 6px;
  background: #2563EB;
  color: white;
  font-size: 14px;
  font-weight: 700;
  cursor: pointer;
  transition: all 0.2s ease;
  display: flex;
  align-items: center;
  justify-content: center;
}
.create-visit-btn[data-v-5610aac2]:hover {
  background: #1D4ED8;
  border-color: #1D4ED8;
  transform: scale(1.05);
}
.create-visit-btn[data-v-5610aac2]:disabled {
  background: #D1D5DB;
  border-color: #D1D5DB;
  color: #9CA3AF;
  cursor: not-allowed;
  transform: none;
}
.visits-list[data-v-5610aac2] {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}
.visit-item[data-v-5610aac2] {
  position: relative;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.75rem;
  margin-bottom: 0.25rem;
  border-radius: 8px;
  cursor: pointer;
  transition: all 0.2s ease;
  background: white;
  border: 1px solid #E5E7EB;
}
.visit-item[data-v-5610aac2]:hover {
  border-color: #2563EB;
  background: #F8FAFC;
  transform: translateX(2px);
}
.visit-item.active[data-v-5610aac2] {
  background: #2563EB;
  color: white;
  border-color: #2563EB;
  box-shadow: 0 2px 4px rgba(37, 99, 235, 0.2);
}
.visit-item:hover .delete-visit-btn[data-v-5610aac2] {
  opacity: 1;
}
.delete-visit-btn[data-v-5610aac2] {
  position: absolute;
  right: 8px;
  top: 50%;
  transform: translateY(-50%);
  width: 20px;
  height: 20px;
  border: 1px solid #E5E7EB;
  border-radius: 4px;
  background: white;
  color: #6B7280;
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  opacity: 0;
  transition: all 0.2s ease;
  display: flex;
  align-items: center;
  justify-content: center;
}
.delete-visit-btn[data-v-5610aac2]:hover {
  background: #FEF2F2;
  border-color: #EF4444;
  color: #EF4444;
}
.visit-item.active .delete-visit-btn[data-v-5610aac2] {
  opacity: 1;
  background: rgba(255, 255, 255, 0.2);
  border-color: rgba(255, 255, 255, 0.3);
  color: white;
}
.visit-item.active .delete-visit-btn[data-v-5610aac2]:hover {
  background: rgba(255, 255, 255, 0.3);
}
.no-visits[data-v-5610aac2],
.no-patient-selected[data-v-5610aac2],
.no-visits-in-range[data-v-5610aac2] {
  text-align: center;
  padding: 1.5rem 1rem;
  color: #6B7280;
  background: #F9FAFB;
  border-radius: 6px;
  border: 1px solid #F3F4F6;
}
.no-visits p[data-v-5610aac2],
.no-patient-selected p[data-v-5610aac2],
.no-visits-in-range p[data-v-5610aac2] {
  font-size: 0.8rem;
  margin: 0.25rem 0;
  font-weight: 500;
}
.no-visits-in-range p[data-v-5610aac2]:first-child {
  color: #1F2937;
  font-weight: 600;
  font-size: 0.85rem;
}
.no-visits-hint[data-v-5610aac2] {
  font-size: 0.75rem !important;
  color: #9CA3AF !important;
  font-weight: 400 !important;
  margin-top: 0.5rem !important;
}
.loading-visits[data-v-5610aac2] {
  text-align: center;
  padding: 1rem;
  color: #6b7280;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.5rem;
}
.loading-visits p[data-v-5610aac2] {
  font-size: 0.75rem;
  margin: 0;
}
.spinner-small[data-v-5610aac2] {
  width: 16px;
  height: 16px;
  border: 2px solid #f3f3f3;
  border-top: 2px solid #2563EB;
  border-radius: 50%;
  animation: spin-5610aac2 1s linear infinite;
}
.visit-details[data-v-5610aac2] {
  flex: 1;
}
.visit-name[data-v-5610aac2] {
  font-size: 0.8rem;
  font-weight: 600;
  margin-bottom: 0.25rem;
  color: #1F2937;
}
.visit-item.active .visit-name[data-v-5610aac2] {
  color: white;
}
.visit-date[data-v-5610aac2] {
  font-size: 0.7rem;
  color: #6B7280;
  font-weight: 500;
}
.visit-item.active .visit-date[data-v-5610aac2] {
  color: rgba(255, 255, 255, 0.9);
}

/* Календарь приемов */
.visits-calendar[data-v-5610aac2] {
  margin-bottom: 1rem;
  padding: 0.75rem;
  background: white;
  border: 1px solid #E5E7EB;
  border-radius: 8px;
}
.calendar-header[data-v-5610aac2] {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 0.75rem;
  gap: 0.25rem;
  flex-wrap: wrap;
}
.calendar-month-year[data-v-5610aac2] {
  flex: 1;
  text-align: center;
  font-size: 0.75rem;
  font-weight: 600;
  color: #1F2937;
  text-transform: capitalize;
  min-width: 0;
}
.calendar-nav-btn[data-v-5610aac2] {
  background: #F3F4F6;
  border: 1px solid #E5E7EB;
  border-radius: 4px;
  width: 24px;
  height: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  font-size: 1rem;
  color: #6B7280;
  transition: all 0.2s ease;
  flex-shrink: 0;
}
.calendar-nav-btn[data-v-5610aac2]:hover {
  background: #E5E7EB;
  color: #1F2937;
}
.calendar-grid[data-v-5610aac2] {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 2px;
}
.calendar-weekday[data-v-5610aac2] {
  text-align: center;
  font-size: 0.7rem;
  font-weight: 600;
  color: #6B7280;
  padding: 0.25rem 0;
}
.calendar-day[data-v-5610aac2] {
  aspect-ratio: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.75rem;
  color: #1F2937;
  cursor: pointer;
  border-radius: 4px;
  transition: all 0.2s ease;
  background: #F9FAFB;
  flex-direction: column;
  padding: 2px 0;
}
.calendar-day.empty[data-v-5610aac2] {
  background: transparent;
  cursor: default;
}
.calendar-day-number[data-v-5610aac2] {
  line-height: 1;
}
.calendar-day-dot[data-v-5610aac2] {
  width: 4px;
  height: 4px;
  border-radius: 999px;
  background: #2563EB;
  margin-top: 2px;
}
.calendar-day[data-v-5610aac2]:not(.empty):hover {
  background: #E5E7EB;
  transform: scale(1.05);
}
.calendar-day.has-visit[data-v-5610aac2] {
  background: #EFF6FF;
  color: #1D4ED8;
  font-weight: 600;
}
.calendar-day.has-visit[data-v-5610aac2]:hover {
  background: #DBEAFE;
  transform: scale(1.1);
}
.calendar-day.today[data-v-5610aac2] {
  background: #2563EB;
  color: white;
  font-weight: 600;
}
.calendar-day.today.has-visit[data-v-5610aac2] {
  background: #1D4ED8;
  color: white;
}

/* Выделение выбранных дат в календаре */
.calendar-day.selected-from[data-v-5610aac2] {
  background: #2563EB;
  color: white;
  font-weight: 700;
  box-shadow: 0 0 0 2px #2563EB;
}
.calendar-day.selected-to[data-v-5610aac2] {
  background: #2563EB;
  color: white;
  font-weight: 700;
  box-shadow: 0 0 0 2px #2563EB;
}
.calendar-day.in-range[data-v-5610aac2] {
  background: #EFF6FF;
  color: #1D4ED8;
  font-weight: 600;
}
.calendar-day.in-range.has-visit[data-v-5610aac2] {
  background: #DBEAFE;
  color: #1E40AF;
}
.calendar-day.selected-from.has-visit[data-v-5610aac2],
.calendar-day.selected-to.has-visit[data-v-5610aac2] {
  background: #1D4ED8;
  color: white;
}
.calendar-day.today.selected-from[data-v-5610aac2],
.calendar-day.today.selected-to[data-v-5610aac2] {
  background: #1E40AF;
  color: white;
}

/* Информация о выбранном диапазоне */
.date-range-info[data-v-5610aac2] {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.5rem;
  margin-top: 0.75rem;
  padding: 0.5rem;
  background: #F3F4F6;
  border-radius: 6px;
  border: 1px solid #E5E7EB;
}
.date-range-text[data-v-5610aac2] {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  font-size: 0.7rem;
  color: #1F2937;
  flex: 1;
  min-width: 0;
  flex-wrap: wrap;
}
.date-range-text span[data-v-5610aac2] {
  font-weight: 600;
  color: #1D4ED8;
  white-space: nowrap;
}
.date-filter-clear-btn[data-v-5610aac2] {
  background: white;
  border: 1px solid #E5E7EB;
  border-radius: 4px;
  width: 24px;
  height: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  font-size: 0.9rem;
  color: #6B7280;
  transition: all 0.2s ease;
  flex-shrink: 0;
}
.date-filter-clear-btn[data-v-5610aac2]:hover {
  background: #EF4444;
  color: white;
  border-color: #EF4444;
}

/* Пагинация приемов */
.visits-pagination[data-v-5610aac2] {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.75rem;
  margin-top: 0.75rem;
  padding: 0.5rem;
  background: #F9FAFB;
  border-radius: 6px;
  border: 1px solid #E5E7EB;
}
.pagination-btn[data-v-5610aac2] {
  background: white;
  border: 1px solid #E5E7EB;
  border-radius: 4px;
  width: 28px;
  height: 28px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  font-size: 1.2rem;
  color: #6B7280;
  transition: all 0.2s ease;
}
.pagination-btn[data-v-5610aac2]:hover:not(:disabled) {
  background: #E5E7EB;
  color: #1F2937;
}
.pagination-btn[data-v-5610aac2]:disabled {
  opacity: 0.4;
  cursor: not-allowed;
}
.pagination-info[data-v-5610aac2] {
  font-size: 0.75rem;
  font-weight: 600;
  color: #6B7280;
  min-width: 50px;
  text-align: center;
}
.content[data-v-5610aac2] {
  flex: 1;
  background: white;
  border-radius: 8px;
  border: 1px solid #E5E7EB;
  overflow: hidden;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
}
.patient-header[data-v-5610aac2] {
  padding: 1.15rem 1.25rem;
  border-bottom: 1px solid #E5E7EB;
  background: #FAFAFA;
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
}
.patient-header-left[data-v-5610aac2] {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
}
.patient-actions[data-v-5610aac2] {
  display: flex;
  gap: 0.5rem;
  align-items: center;
  align-self: flex-end;
}
.pdf-download-btn[data-v-5610aac2] {
  width: 46px;
  height: 46px;
  min-width: 46px;
  padding: 0;
  border-radius: 10px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.pdf-download-icon[data-v-5610aac2] {
  display: block;
}
.patient-name[data-v-5610aac2] {
  font-size: 1.25rem;
  font-weight: 600;
  color: var(--text-primary, #0f172a);
  margin-bottom: 0.375rem;
}
.patient-info[data-v-5610aac2] {
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
}
.patient-detail[data-v-5610aac2] {
  display: flex;
  flex-direction: column;
  gap: 0.125rem;
}
.label[data-v-5610aac2] {
  font-size: 0.65rem;
  color: #6B7280;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.25px;
}
.value[data-v-5610aac2] {
  font-size: 0.8rem;
  color: #1F2937;
  font-weight: 500;
}
.tabs[data-v-5610aac2] {
  display: flex;
  background: #F8FAFC;
  border-bottom: 1px solid #E5E7EB;
  overflow-x: auto;
}
.tab[data-v-5610aac2] {
  padding: 0.75rem 1rem;
  border: none;
  background: transparent;
  font-size: 0.75rem;
  font-weight: 500;
  color: #6B7280;
  cursor: pointer;
  transition: all 0.2s ease;
  white-space: pre-line;
  border-bottom: 2px solid transparent;
  flex: 1;
  min-width: 0;
  position: relative;
}
.tab[data-v-5610aac2]:hover {
  color: #2563EB;
  background: rgba(37, 99, 235, 0.08);
}
.tab.active[data-v-5610aac2] {
  color: #2563EB;
  background: white;
  border-bottom-color: #2563EB;
  font-weight: 600;
}
.tab-content[data-v-5610aac2] {
  padding: 0;
  min-height: 400px;
  background: #FAFAFA;
}

/* Состояния загрузки и ошибок */
.loading-state[data-v-5610aac2] {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 2rem;
  color: #666;
}
.spinner[data-v-5610aac2] {
  width: 24px;
  height: 24px;
  border: 3px solid #f3f3f3;
  border-top: 3px solid #2563EB;
  border-radius: 50%;
  animation: spin-5610aac2 1s linear infinite;
  margin-right: 1rem;
}
@keyframes spin-5610aac2 {
0% { transform: rotate(0deg);
}
100% { transform: rotate(360deg);
}
}
.error-state[data-v-5610aac2] {
  background: #fee;
  border: 1px solid #fcc;
  color: #c00;
  padding: 1rem;
  border-radius: 8px;
  margin: 1rem 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.retry-btn[data-v-5610aac2] {
  background: #c00;
  color: white;
  border: none;
  padding: 0.5rem 1rem;
  border-radius: 4px;
  cursor: pointer;
  font-size: 0.9rem;
}
.retry-btn[data-v-5610aac2]:hover {
  background: #a00;
}
.empty-state[data-v-5610aac2] {
  text-align: center;
  padding: 2rem;
  color: #666;
  font-size: 1.1rem;
}

/* Кнопки с отключенным состоянием */
.search-btn[data-v-5610aac2]:disabled,
.create-patient-btn[data-v-5610aac2]:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}



/* Минималистичное модальное окно */
.modal-overlay[data-v-5610aac2] {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.4);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1000;
}
.modal-content[data-v-5610aac2] {
  background: white;
  border-radius: 8px;
  width: 90%;
  max-width: 450px;
  max-height: 80vh;
  overflow-y: auto;
  border: 1px solid #E5E7EB;
}
.modal-header[data-v-5610aac2] {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1rem;
  border-bottom: 1px solid #F3F4F6;
}
.modal-header h3[data-v-5610aac2] {
  margin: 0;
  font-size: 1.125rem;
  font-weight: 600;
  color: #1F2937;
}
.close-btn[data-v-5610aac2] {
  background: none;
  border: 1px solid #E5E7EB;
  font-size: 1.25rem;
  color: #6B7280;
  cursor: pointer;
  padding: 0;
  width: 28px;
  height: 28px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 4px;
  transition: all 0.2s ease;
}
.close-btn[data-v-5610aac2]:hover {
  background: #F9FAFB;
  border-color: #D1D5DB;
}
.modal-body[data-v-5610aac2] {
  padding: 1rem;
}
.form-group[data-v-5610aac2] {
  margin-bottom: 0.875rem;
}
.form-group label[data-v-5610aac2] {
  display: block;
  margin-bottom: 0.375rem;
  font-weight: 500;
  color: #374151;
  font-size: 0.8rem;
}
.form-select[data-v-5610aac2],
.form-input[data-v-5610aac2] {
  width: 100%;
  padding: 0.5rem 0.75rem;
  border: 1px solid #E5E7EB;
  border-radius: 6px;
  font-size: 0.875rem;
  transition: border-color 0.2s ease;
}
.form-select[data-v-5610aac2]:focus,
.form-input[data-v-5610aac2]:focus {
  outline: none;
  border-color: #2563EB;
}

/* Информация о враче в форме создания приема */
.doctor-info[data-v-5610aac2] {
  background: #f8fafc;
  border: 1px solid #e2e8f0;
  border-radius: 8px;
  padding: 1rem;
  margin-bottom: 1rem;
}
.info-label[data-v-5610aac2] {
  display: block;
  margin-bottom: 0.75rem;
  font-weight: 600;
  color: #374151;
  font-size: 0.9rem;
}
.assigned-doctor[data-v-5610aac2] {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.75rem;
  background: white;
  border: 1px solid #e5e7eb;
  border-radius: 6px;
  margin-bottom: 0.75rem;
}
.doctor-icon[data-v-5610aac2] {
  font-size: 1.2rem;
}
.doctor-name[data-v-5610aac2] {
  font-size: 0.9rem;
  color: #374151;
  font-weight: 500;
}
.auto-assignment-note[data-v-5610aac2] {
  font-size: 0.8rem;
  color: #6b7280;
  font-style: italic;
  margin: 0;
  text-align: center;
}
.modal-footer[data-v-5610aac2] {
  display: flex;
  justify-content: flex-end;
  gap: 0.75rem;
  padding: 1rem;
  border-top: 1px solid #F3F4F6;
  background: #FAFAFA;
}
.btn[data-v-5610aac2] {
  padding: 0.5rem 1rem;
  border: none;
  border-radius: 6px;
  font-size: 0.8rem;
  font-weight: 500;
  cursor: pointer;
  transition: background-color 0.2s ease;
}
.btn-cancel[data-v-5610aac2] {
  background: #F3F4F6;
  color: #374151;
  border: 1px solid #E5E7EB;
}
.btn-cancel[data-v-5610aac2]:hover {
  background: #E5E7EB;
}
.btn-primary[data-v-5610aac2] {
  background: #2563EB;
  color: white;
}
.btn-primary[data-v-5610aac2]:hover {
  background: #1D4ED8;
}
.btn-primary[data-v-5610aac2]:disabled {
  background: #D1D5DB;
  cursor: not-allowed;
}
.btn-secondary[data-v-5610aac2] {
  background: #EFF6FF;
  color: #1D4ED8;
  border: 1px solid #BFDBFE;
}
.btn-secondary[data-v-5610aac2]:hover {
  background: #DBEAFE;
}
.btn-secondary[data-v-5610aac2]:disabled {
  background: #EFF6FF;
  color: #93C5FD;
  border-color: #DBEAFE;
  cursor: not-allowed;
}

/* Стили для формы создания пациента */
.required[data-v-5610aac2] {
  color: #ef4444;
  font-weight: bold;
}
.field-error[data-v-5610aac2] {
  color: #ef4444;
  font-size: 0.75rem;
  margin-top: 0.25rem;
  font-weight: 500;
}
.form-input.error[data-v-5610aac2] {
  border-color: #ef4444;
  box-shadow: 0 0 0 3px rgba(239, 68, 68, 0.1);
}

/* Стили для модального окна выбора приема */
.visit-selection-modal[data-v-5610aac2] {
  max-width: 500px;
}
.visits-section[data-v-5610aac2] {
  margin-bottom: 1rem;
}
.section-title[data-v-5610aac2] {
  font-size: 0.875rem;
  font-weight: 600;
  color: #374151;
  margin-bottom: 0.75rem;
  margin-top: 0;
}
.visits-list-modal[data-v-5610aac2] {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  max-height: 300px;
  overflow-y: auto;
  padding: 0.25rem;
}
.visit-item-modal[data-v-5610aac2] {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.875rem 1rem;
  border: 1px solid #E5E7EB;
  border-radius: 8px;
  cursor: pointer;
  transition: all 0.2s ease;
  background: white;
}
.visit-item-modal[data-v-5610aac2]:hover {
  border-color: #2563EB;
  background: #F8FAFC;
  transform: translateX(2px);
  box-shadow: 0 2px 4px rgba(37, 99, 235, 0.1);
}
.visit-info[data-v-5610aac2] {
  flex: 1;
}
.visit-name-modal[data-v-5610aac2] {
  font-size: 0.875rem;
  font-weight: 600;
  color: #1F2937;
  margin-bottom: 0.25rem;
}
.visit-date-modal[data-v-5610aac2] {
  font-size: 0.75rem;
  color: #6B7280;
  font-weight: 500;
}
.visit-select-icon[data-v-5610aac2] {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  color: #2563EB;
  font-weight: bold;
  margin-left: 1rem;
  font-size: 1.125rem;
}
.no-visits-section[data-v-5610aac2] {
  padding: 2rem 1rem;
  text-align: center;
}
.no-visits-message[data-v-5610aac2] {
  background: #F9FAFB;
  border: 1px solid #F3F4F6;
  border-radius: 8px;
  padding: 1.5rem;
}
.no-visits-message p[data-v-5610aac2] {
  color: #6B7280;
  font-size: 0.875rem;
  margin: 0.25rem 0;
  font-weight: 500;
}
.btn-success[data-v-5610aac2] {
  background: #2563EB;
  color: white;
}
.btn-success[data-v-5610aac2]:hover {
  background: #1D4ED8;
}

/* Стили для улучшенного пустого состояния */
.empty-state[data-v-5610aac2] {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 400px;
  padding: 2rem;
}
.empty-state-content[data-v-5610aac2] {
  text-align: center;
  max-width: 400px;
}
.empty-state-icon[data-v-5610aac2] {
  font-size: 4rem;
  margin-bottom: 1rem;
  opacity: 0.6;
}
.empty-state-title[data-v-5610aac2] {
  font-size: 1.5rem;
  font-weight: 600;
  color: #374151;
  margin-bottom: 0.5rem;
}
.empty-state-subtitle[data-v-5610aac2] {
  font-size: 1rem;
  color: #6b7280;
  margin-bottom: 2rem;
  line-height: 1.5;
}
.empty-state-actions[data-v-5610aac2] {
  display: flex;
  gap: 1rem;
  justify-content: center;
  flex-wrap: wrap;
}
.btn-select-patient[data-v-5610aac2],
.btn-create-patient[data-v-5610aac2] {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.75rem 1.5rem;
  border: none;
  border-radius: 8px;
  font-size: 0.9rem;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.2s ease;
  text-decoration: none;
}
.btn-select-patient[data-v-5610aac2] {
  background: #2563EB;
  color: white;
}
.btn-select-patient[data-v-5610aac2]:hover {
  background: #1D4ED8;
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(37, 99, 235, 0.3);
}
.btn-create-patient[data-v-5610aac2] {
  background: #2563EB;
  color: white;
}
.btn-create-patient[data-v-5610aac2]:hover {
  background: #1D4ED8;
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(37, 99, 235, 0.3);
}
.btn-icon[data-v-5610aac2] {
  font-size: 1rem;
}

/* Стили для модального окна выбора пациента */
.patient-selection-modal[data-v-5610aac2] {
  max-width: 800px;
  max-height: 90vh;
}
.patient-search-section[data-v-5610aac2] {
  margin-bottom: 1.5rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid #e5e7eb;
}
.search-input-wrapper[data-v-5610aac2] {
  display: flex;
  background: white;
  border: 2px solid #E5E7EB;
  border-radius: 8px;
  padding: 0.5rem;
  transition: all 0.2s ease;
}
.search-input-wrapper[data-v-5610aac2]:focus-within {
  border-color: #2563EB;
  box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.1);
}
.search-input[data-v-5610aac2] {
  flex: 1;
  background: transparent;
  border: none;
  color: #1f2937;
  font-size: 0.9rem;
  padding: 0.5rem;
  outline: none;
}
.search-input[data-v-5610aac2]::-moz-placeholder {
  color: #9ca3af;
}
.search-input[data-v-5610aac2]::placeholder {
  color: #9ca3af;
}
.search-btn[data-v-5610aac2] {
  background: #2563EB;
  border: none;
  color: white;
  padding: 0.5rem 1rem;
  border-radius: 6px;
  font-size: 0.9rem;
  cursor: pointer;
  transition: all 0.2s ease;
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 40px;
}
.search-btn[data-v-5610aac2]:hover {
  background: #1D4ED8;
}
.search-btn[data-v-5610aac2]:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}
.search-spinner[data-v-5610aac2] {
  width: 14px;
  height: 14px;
  border: 2px solid rgba(255, 255, 255, 0.3);
  border-top: 2px solid white;
  border-radius: 50%;
  animation: spin-5610aac2 1s linear infinite;
}
.patients-section[data-v-5610aac2] {
  min-height: 300px;
}
.patients-header[data-v-5610aac2] {
  margin-bottom: 1rem;
}
.section-title[data-v-5610aac2] {
  font-size: 1rem;
  font-weight: 600;
  color: #374151;
  margin: 0;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.patients-count[data-v-5610aac2] {
  font-size: 0.8rem;
  font-weight: 400;
  color: #6b7280;
}
.patients-list-modal[data-v-5610aac2] {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  max-height: 400px;
  overflow-y: auto;
  padding: 0.25rem;
}
.patient-item-modal[data-v-5610aac2] {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1rem;
  border: 1px solid #E5E7EB;
  border-radius: 8px;
  cursor: pointer;
  transition: all 0.2s ease;
  background: white;
}
.patient-item-modal[data-v-5610aac2]:hover {
  border-color: #2563EB;
  background: #F8FAFC;
  transform: translateX(2px);
  box-shadow: 0 2px 4px rgba(37, 99, 235, 0.1);
}
.patient-info[data-v-5610aac2] {
  flex: 1;
}
.patient-name-modal[data-v-5610aac2] {
  font-size: 1rem;
  font-weight: 600;
  color: #1F2937;
  margin-bottom: 0.25rem;
}
.patient-details-modal[data-v-5610aac2] {
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
}
.patient-iin[data-v-5610aac2],
.patient-birth[data-v-5610aac2] {
  font-size: 0.8rem;
  color: #6B7280;
}
.patient-select-icon[data-v-5610aac2] {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  color: #2563EB;
  font-weight: bold;
  margin-left: 1rem;
  font-size: 1.125rem;
}
.no-patients-found[data-v-5610aac2] {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 200px;
  padding: 2rem;
}
.no-patients-message[data-v-5610aac2] {
  text-align: center;
  max-width: 300px;
}
.no-patients-icon[data-v-5610aac2] {
  font-size: 2.5rem;
  margin-bottom: 1rem;
  opacity: 0.6;
}
.no-patients-message p[data-v-5610aac2] {
  font-size: 1rem;
  color: #6B7280;
  margin: 0.5rem 0;
  font-weight: 500;
}
.no-patients-subtitle[data-v-5610aac2] {
  font-size: 0.9rem !important;
  opacity: 0.8;
}
.patients-loading[data-v-5610aac2] {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.75rem;
  min-height: 200px;
  color: #6b7280;
  font-size: 0.9rem;
}

/* Стили для секции выбранного пациента */
.selected-patient-section[data-v-5610aac2] {
  min-height: 400px;
}
.selected-patient-info[data-v-5610aac2] {
  margin-bottom: 1.5rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid #e5e7eb;
}
.selected-patient-header[data-v-5610aac2] {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 0.75rem;
}
.selected-patient-title[data-v-5610aac2] {
  font-size: 1rem;
  font-weight: 600;
  color: #374151;
  margin: 0;
}
.back-to-patients-btn[data-v-5610aac2] {
  background: #f3f4f6;
  border: 1px solid #e5e7eb;
  color: #374151;
  padding: 0.5rem 0.75rem;
  border-radius: 6px;
  font-size: 0.8rem;
  cursor: pointer;
  transition: all 0.2s ease;
}
.back-to-patients-btn[data-v-5610aac2]:hover {
  background: #e5e7eb;
  color: #1f2937;
}
.selected-patient-card[data-v-5610aac2] {
  background: #f8fafc;
  border: 1px solid #e5e7eb;
  border-radius: 8px;
  padding: 1rem;
}
.selected-patient-name[data-v-5610aac2] {
  font-size: 1.1rem;
  font-weight: 600;
  color: #1f2937;
  margin-bottom: 0.5rem;
}
.selected-patient-details[data-v-5610aac2] {
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
}
.selected-patient-iin[data-v-5610aac2],
.selected-patient-birth[data-v-5610aac2] {
  font-size: 0.85rem;
  color: #6b7280;
  font-weight: 500;
}

/* Стили для секции приемов */
.patient-visits-section[data-v-5610aac2] {
  min-height: 200px;
}
.visits-header[data-v-5610aac2] {
  margin-bottom: 1rem;
}
.visits-count[data-v-5610aac2] {
  font-size: 0.8rem;
  font-weight: 400;
  color: #6b7280;
}
.visits-loading[data-v-5610aac2] {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.75rem;
  min-height: 150px;
  color: #6b7280;
  font-size: 0.9rem;
}
.visits-list-modal[data-v-5610aac2] {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  max-height: 300px;
  overflow-y: auto;
  padding: 0.25rem;
  margin-bottom: 1rem;
}

/* Компактные элементы приемов */
.visit-item-compact[data-v-5610aac2] {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.75rem 1rem;
  border: 1px solid #e5e7eb;
  border-radius: 6px;
  cursor: pointer;
  transition: all 0.2s ease;
  background: white;
}
.visit-item-compact[data-v-5610aac2]:hover {
  border-color: #2563EB;
  background: #f8fafc;
  transform: translateX(2px);
  box-shadow: 0 2px 4px rgba(37, 99, 235, 0.1);
}
.visit-compact-info[data-v-5610aac2] {
  flex: 1;
}
.visit-compact-name[data-v-5610aac2] {
  font-size: 0.9rem;
  font-weight: 600;
  color: #1f2937;
  margin-bottom: 0.25rem;
}
.visit-compact-date[data-v-5610aac2] {
  font-size: 0.8rem;
  color: #6b7280;
}
.visit-compact-icon[data-v-5610aac2] {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 20px;
  height: 20px;
  color: #2563EB;
  font-weight: bold;
  margin-left: 1rem;
}

/* Стили для состояния "нет приемов" */
.no-visits-found[data-v-5610aac2] {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 150px;
  padding: 1.5rem;
}
.no-visits-message[data-v-5610aac2] {
  text-align: center;
  max-width: 280px;
}
.no-visits-icon[data-v-5610aac2] {
  font-size: 2rem;
  margin-bottom: 0.75rem;
  opacity: 0.6;
}
.no-visits-message p[data-v-5610aac2] {
  font-size: 0.9rem;
  color: #6b7280;
  margin: 0.5rem 0;
  font-weight: 500;
}
.no-visits-subtitle[data-v-5610aac2] {
  font-size: 0.8rem !important;
  opacity: 0.8;
}

/* Кнопка создания приема */
.create-visit-section[data-v-5610aac2] {
  text-align: center;
  padding-top: 1rem;
  border-top: 1px solid #f3f4f6;
}
.btn-create-visit-modal[data-v-5610aac2] {
  display: inline-flex;
  align-items: center;
  padding: 0.75rem 1.5rem;
  background: #2563EB;
  color: white;
  border: none;
  border-radius: 8px;
  font-size: 0.9rem;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.2s ease;
}
.btn-create-visit-modal[data-v-5610aac2]:hover {
  background: #1D4ED8;
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(37, 99, 235, 0.3);
}
.pdf-preparation-overlay[data-v-5610aac2] {
  background: rgba(15, 23, 42, 0.34);
  backdrop-filter: blur(6px);
  z-index: 1100;
}
.pdf-preparation-card[data-v-5610aac2] {
  width: min(420px, calc(100vw - 2rem));
  border-radius: 22px;
  padding: 1.35rem 1.35rem 1.2rem;
  background:
    radial-gradient(circle at top left, rgba(219, 234, 254, 0.95) 0%, rgba(255, 255, 255, 0.98) 36%, #F8FBFF 100%);
  border: 1px solid rgba(191, 219, 254, 0.9);
  box-shadow: 0 28px 65px rgba(15, 23, 42, 0.22);
}
.pdf-preparation-badge[data-v-5610aac2] {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 42px;
  padding: 0.28rem 0.62rem;
  border-radius: 999px;
  background: #EFF6FF;
  border: 1px solid #BFDBFE;
  color: #1D4ED8;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.pdf-preparation-orbit[data-v-5610aac2] {
  position: relative;
  width: 66px;
  height: 66px;
  margin: 1rem 0 0.8rem;
}
.pdf-preparation-orbit-ring[data-v-5610aac2],
.pdf-preparation-orbit-core[data-v-5610aac2] {
  position: absolute;
  inset: 0;
  border-radius: 50%;
}
.pdf-preparation-orbit-ring[data-v-5610aac2] {
  border: 2px solid rgba(37, 99, 235, 0.14);
}
.pdf-preparation-orbit-ring[data-v-5610aac2]::after {
  content: '';
  position: absolute;
  inset: -2px;
  border-radius: 50%;
  border: 2px solid transparent;
  border-top-color: #2563EB;
  border-right-color: rgba(59, 130, 246, 0.48);
  animation: spin-5610aac2 1.1s linear infinite;
}
.pdf-preparation-orbit-core[data-v-5610aac2] {
  inset: 13px;
  background: radial-gradient(circle at 35% 35%, #FFFFFF 0%, #DBEAFE 48%, #60A5FA 100%);
  box-shadow: inset 0 0 0 1px rgba(147, 197, 253, 0.7);
}
.pdf-preparation-title[data-v-5610aac2] {
  margin: 0;
  color: #0F172A;
  font-size: 1.08rem;
  font-weight: 700;
  line-height: 1.25;
}
.pdf-preparation-status[data-v-5610aac2] {
  margin: 0.7rem 0 0;
  color: #1E293B;
  font-size: 0.92rem;
  font-weight: 600;
  line-height: 1.4;
}
.pdf-preparation-detail[data-v-5610aac2] {
  margin: 0.28rem 0 0;
  color: #64748B;
  font-size: 0.82rem;
  line-height: 1.45;
}
.pdf-preparation-progress[data-v-5610aac2] {
  margin-top: 1rem;
  height: 8px;
  border-radius: 999px;
  background: rgba(226, 232, 240, 0.95);
  overflow: hidden;
}
.pdf-preparation-progress-bar[data-v-5610aac2] {
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, #2563EB 0%, #60A5FA 100%);
  transition: width 0.28s ease;
}
.pdf-preparation-meta[data-v-5610aac2] {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.8rem;
  margin-top: 0.75rem;
  color: #475569;
  font-size: 0.78rem;
  font-weight: 600;
}
.pdf-preparation-dots[data-v-5610aac2] {
  display: inline-flex;
  align-items: center;
  gap: 0.32rem;
}
.pdf-preparation-dots span[data-v-5610aac2] {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: #60A5FA;
  animation: pdfPreparationPulse-5610aac2 1.1s ease-in-out infinite;
}
.pdf-preparation-dots span[data-v-5610aac2]:nth-child(2) {
  animation-delay: 0.18s;
}
.pdf-preparation-dots span[data-v-5610aac2]:nth-child(3) {
  animation-delay: 0.36s;
}
@keyframes pdfPreparationPulse-5610aac2 {
0%, 100% {
    transform: translateY(0);
    opacity: 0.35;
}
50% {
    transform: translateY(-2px);
    opacity: 1;
}
}
.pdf-editor-modal[data-v-5610aac2] {
  width: min(1220px, 96vw);
  max-width: 1220px;
  max-height: 92vh;
  border-radius: 14px;
  border: 1px solid #D6E0EE;
  box-shadow: 0 26px 60px rgba(15, 23, 42, 0.26);
  overflow: hidden;
  display: flex;
  flex-direction: column;
}
.pdf-editor-header[data-v-5610aac2] {
  background: linear-gradient(180deg, #F8FBFF 0%, #EEF4FF 100%);
  border-bottom: 1px solid #D6E0EE;
  padding: 1rem 1.25rem;
  position: sticky;
  top: 0;
  z-index: 4;
}
.pdf-editor-header-main[data-v-5610aac2] {
  display: flex;
  flex-direction: column;
  gap: 0.3rem;
}
.pdf-editor-header h3[data-v-5610aac2] {
  font-size: 1.2rem;
  font-weight: 700;
  color: #1E293B;
}
.pdf-editor-subtitle[data-v-5610aac2] {
  margin: 0;
  font-size: 0.84rem;
  color: #475569;
  line-height: 1.35;
}
.pdf-editor-modal .modal-body[data-v-5610aac2] {
  background: radial-gradient(circle at 8% 4%, #F6FAFF 0%, #EEF4FB 52%, #EAF1F9 100%);
  padding: 1rem 1.1rem 1.2rem;
  overflow-y: auto;
}
.pdf-editor-layout[data-v-5610aac2] {
  display: grid;
  grid-template-columns: minmax(0, 1.28fr) minmax(320px, 0.92fr);
  gap: 1rem;
  align-items: start;
}
.pdf-editor-main[data-v-5610aac2] {
  min-width: 0;
}
.pdf-editor-section[data-v-5610aac2] {
  background: #FFFFFF;
  border: 1px solid #DDE5F1;
  border-radius: 12px;
  padding: 0.95rem;
}
.pdf-editor-section + .pdf-editor-section[data-v-5610aac2] {
  margin-top: 0.85rem;
}
.pdf-editor-section-head[data-v-5610aac2] {
  margin-bottom: 0.75rem;
}
.pdf-editor-section-title[data-v-5610aac2] {
  font-size: 0.86rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: #334155;
  margin-bottom: 0.8rem;
  padding-bottom: 0.55rem;
  border-bottom: 1px solid #E7EDF6;
}
.pdf-editor-section-note[data-v-5610aac2] {
  margin-top: -0.25rem;
  font-size: 0.76rem;
  color: #64748B;
}
.pdf-editor-grid[data-v-5610aac2] {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.82rem 0.95rem;
}
.pdf-editor-modal .form-group[data-v-5610aac2] {
  margin-bottom: 0;
}
.pdf-editor-modal .form-group label[data-v-5610aac2] {
  margin-bottom: 0.38rem;
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.015em;
  color: #334155;
}
.pdf-editor-modal .form-input[data-v-5610aac2] {
  border-color: #CBD7E6;
  background: #FBFDFF;
  border-radius: 8px;
  min-height: 40px;
  color: #0F172A;
}
.pdf-editor-modal .form-input[data-v-5610aac2]::-moz-placeholder {
  color: #94A3B8;
}
.pdf-editor-modal .form-input[data-v-5610aac2]::placeholder {
  color: #94A3B8;
}
.pdf-editor-modal .form-input[data-v-5610aac2]:focus {
  border-color: #2563EB;
  box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.12);
}
.pdf-editor-grid .full-width[data-v-5610aac2] {
  grid-column: 1 / -1;
}
.pdf-editor-label-row[data-v-5610aac2] {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
}
.pdf-editor-label-actions[data-v-5610aac2] {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 0.5rem;
  flex-wrap: wrap;
}
.pdf-supplement-toggle[data-v-5610aac2] {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  border: 1px solid #BFDBFE;
  background: #EFF6FF;
  color: #1D4ED8;
  border-radius: 999px;
  padding: 0.22rem 0.6rem;
  font-size: 0.72rem;
  font-weight: 600;
  line-height: 1.2;
  cursor: pointer;
  transition: background-color 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}
.pdf-supplement-toggle[data-v-5610aac2]:hover {
  background: #DBEAFE;
  border-color: #93C5FD;
}
.pdf-supplement-toggle[data-v-5610aac2]:focus-visible {
  outline: 2px solid rgba(29, 78, 216, 0.18);
  outline-offset: 2px;
}
.pdf-field-count[data-v-5610aac2] {
  font-size: 0.68rem;
  line-height: 1;
  color: #64748B;
  background: #F1F5F9;
  border: 1px solid #D9E2EE;
  border-radius: 999px;
  padding: 0.22rem 0.45rem;
}
.pdf-field-badge[data-v-5610aac2] {
  font-size: 0.68rem;
  line-height: 1;
  color: #1D4ED8;
  background: #EFF6FF;
  border: 1px solid #BFDBFE;
  border-radius: 999px;
  padding: 0.22rem 0.45rem;
}
.pdf-editor-textarea[data-v-5610aac2] {
  min-height: 110px;
  resize: none;
  overflow: hidden;
  line-height: 1.45;
}
.pdf-editor-readonly-input[data-v-5610aac2] {
  background: #F8FAFC !important;
  color: #475569 !important;
  border-style: dashed;
}
.pdf-editor-readonly-input[data-v-5610aac2]:focus {
  border-color: #CBD7E6 !important;
  box-shadow: none !important;
}
.pdf-editor-supplement-row[data-v-5610aac2] {
  margin-top: 0.55rem;
}
.pdf-editor-supplement-label[data-v-5610aac2] {
  color: #1D4ED8 !important;
}
.pdf-editor-textarea-lg[data-v-5610aac2] {
  min-height: 170px;
}
.pdf-editor-hint[data-v-5610aac2] {
  grid-column: 1 / -1;
  margin: 0;
  margin-top: 0.1rem;
  font-size: 0.78rem;
  color: #475569;
  line-height: 1.4;
}
.pdf-editor-preview[data-v-5610aac2] {
  position: sticky;
  top: 0;
  background: linear-gradient(180deg, #0F274D 0%, #132F5B 100%);
  color: #DCE8FB;
  border: 1px solid #1D447A;
  border-radius: 12px;
  padding: 0.85rem;
}
.pdf-preview-title[data-v-5610aac2] {
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}
.pdf-preview-subtitle[data-v-5610aac2] {
  margin-top: 0.3rem;
  font-size: 0.74rem;
  color: #BDD0F2;
  line-height: 1.35;
}
.pdf-preview-paper[data-v-5610aac2] {
  margin-top: 0.7rem;
  background: #FFFFFF;
  color: #0F172A;
  border: 1px solid #D9E2EC;
  border-radius: 10px;
  padding: 1rem 1rem 1.05rem;
  font-family: "Roboto", "Segoe UI", Arial, sans-serif;
  max-height: 62vh;
  overflow-y: auto;
}
.pdf-preview-head[data-v-5610aac2] {
  margin-bottom: 0.3rem;
}
.pdf-preview-org[data-v-5610aac2] {
  margin: 0;
  font-size: 0.86rem;
  font-weight: 700;
  line-height: 1.2;
}
.pdf-preview-meta[data-v-5610aac2] {
  margin: 0.12rem 0 0;
  font-size: 0.78rem;
  font-weight: 400;
  color: #475569;
  line-height: 1.28;
}
.pdf-preview-doc-title[data-v-5610aac2] {
  margin: 1rem 0 0.85rem;
  text-align: center;
  font-size: 1.02rem;
  font-weight: 700;
  letter-spacing: 0.04em;
}
.pdf-preview-summary-grid[data-v-5610aac2] {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.65rem 0.85rem;
}
.pdf-preview-summary-cell[data-v-5610aac2] {
  min-width: 0;
}
.pdf-preview-summary-label[data-v-5610aac2] {
  display: block;
  margin-bottom: 0.18rem;
  font-size: 0.72rem;
  font-weight: 700;
  color: #64748B;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}
.pdf-preview-summary-value[data-v-5610aac2] {
  display: block;
  font-size: 0.88rem;
  line-height: 1.3;
  color: #0F172A;
  word-break: break-word;
}
.pdf-preview-divider[data-v-5610aac2] {
  border-top: 1px solid #E2E8F0;
  margin: 0.8rem 0 0.85rem;
}
.pdf-preview-section + .pdf-preview-section[data-v-5610aac2] {
  margin-top: 0.85rem;
}
.pdf-preview-section-title[data-v-5610aac2] {
  margin: 0;
  font-size: 0.82rem;
  font-weight: 700;
  line-height: 1.3;
  color: #0F172A;
}
.pdf-preview-section-label[data-v-5610aac2] {
  margin: 0.35rem 0 0.24rem;
  font-size: 0.74rem;
  line-height: 1.25;
  color: #475569;
}
.pdf-preview-block[data-v-5610aac2] {
  margin: 0 0 0.44rem;
  font-size: 0.86rem;
  line-height: 1.38;
  color: #334155;
  white-space: pre-wrap;
}
.pdf-preview-empty[data-v-5610aac2] {
  margin-top: 0.3rem !important;
  color: #64748B;
  font-style: italic;
}
.pdf-editor-footer[data-v-5610aac2] {
  border-top: 1px solid #D6E0EE;
  background: linear-gradient(180deg, #F9FBFF 0%, #EFF4FC 100%);
  position: sticky;
  bottom: 0;
  z-index: 4;
  padding: 0.9rem 1.1rem;
}
.pdf-clear-action[data-v-5610aac2] {
  margin-right: auto;
}
.pdf-editor-action-group[data-v-5610aac2] {
  display: flex;
  gap: 0.65rem;
  flex-wrap: wrap;
  justify-content: flex-end;
}
.pdf-save-action[data-v-5610aac2],
.pdf-download-action[data-v-5610aac2] {
  min-width: 210px;
  font-weight: 600;
}
.pdf-download-action[data-v-5610aac2] {
  box-shadow: 0 8px 16px rgba(37, 99, 235, 0.2);
}
@media (max-width: 1180px) {
.pdf-editor-layout[data-v-5610aac2] {
    grid-template-columns: minmax(0, 1fr);
}
.pdf-editor-preview[data-v-5610aac2] {
    position: static;
}
.pdf-preview-paper[data-v-5610aac2] {
    max-height: none;
}
}
@media (max-width: 640px) {
.pdf-preview-summary-grid[data-v-5610aac2] {
    grid-template-columns: minmax(0, 1fr);
}
}

/* Адаптивность */
@media (min-width: 1400px) {
.header-content[data-v-5610aac2] {
    max-width: 1400px;
    padding: 0 1.25rem;
}
.main-content[data-v-5610aac2] {
    max-width: 1400px;
    padding: 1rem;
}
.sidebar[data-v-5610aac2] {
    width: 200px;
}
.patient-header[data-v-5610aac2] {
    padding: 1.15rem 1.25rem;
}
}
@media (min-width: 1600px) {
.header-content[data-v-5610aac2] {
    max-width: 1600px;
}
.main-content[data-v-5610aac2] {
    max-width: 1600px;
    gap: 1rem;
}
.sidebar[data-v-5610aac2] {
    width: 220px;
    padding: 1rem;
}
.patient-name[data-v-5610aac2] {
    font-size: 1.375rem;
}
}
@media (max-width: 900px) {
.pdf-preparation-card[data-v-5610aac2] {
    width: min(100vw - 1.4rem, 100vw - 1.4rem);
    border-radius: 18px;
    padding: 1.15rem 1rem 1rem;
}
.pdf-editor-modal[data-v-5610aac2] {
    width: min(96vw, 96vw);
    max-height: 94vh;
}
.pdf-editor-header[data-v-5610aac2] {
    padding: 0.85rem 0.95rem;
}
.pdf-editor-modal .modal-body[data-v-5610aac2] {
    padding: 0.85rem;
}
.pdf-editor-section[data-v-5610aac2] {
    padding: 0.78rem;
}
.pdf-editor-preview[data-v-5610aac2] {
    padding: 0.75rem;
}
.pdf-editor-footer[data-v-5610aac2] {
    padding: 0.8rem;
    flex-wrap: wrap;
}
.pdf-clear-action[data-v-5610aac2] {
    margin-right: 0;
}
.pdf-editor-action-group[data-v-5610aac2] {
    width: 100%;
}
.pdf-editor-action-group .btn[data-v-5610aac2] {
    flex: 1 1 180px;
}
.pdf-editor-grid[data-v-5610aac2] {
    grid-template-columns: 1fr;
    gap: 0.72rem;
}
}


.patient-name[data-v-5610aac2] {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  flex-wrap: wrap;
  font-size: 1.5rem;
  font-weight: 700;
  color: #1F2937;
  margin: 0 0 0.3rem 0;
  line-height: 1.2;
}
.status-badge[data-v-5610aac2] {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  padding: 0.25rem 0.625rem;
  background: var(--accent-soft, #eff6ff);
  color: var(--accent-hover, #1d4ed8);
  border-radius: 999px;
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  border: 1px solid rgba(37, 99, 235, 0.25);
  box-shadow: 0 2px 4px rgba(37, 99, 235, 0.08);
  vertical-align: middle;
}
.status-dot[data-v-5610aac2] {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background-color: var(--accent, #2563eb);
  box-shadow: 0 0 0 rgba(37, 99, 235, 0.4);
  animation: pulse-dot-5610aac2 2s infinite;
}
@keyframes pulse-dot-5610aac2 {
0% {
    box-shadow: 0 0 0 0 rgba(37, 99, 235, 0.4);
}
70% {
    box-shadow: 0 0 0 4px rgba(37, 99, 235, 0);
}
100% {
    box-shadow: 0 0 0 0 rgba(37, 99, 235, 0);
}
}



.patients-page[data-v-008b16ad] {
  --accent: #2563eb;
  --accent-hover: #1d4ed8;
  --accent-soft: #eff6ff;
  --surface: #ffffff;
  --surface-muted: #f8fafc;
  --border: #e2e8f0;
  --border-strong: #cbd5e1;
  --text-primary: #0f172a;
  --text-secondary: #475569;

  min-height: 100vh;
  background: linear-gradient(180deg, #f8fafc 0%, #f1f5f9 100%);
  color: var(--text-primary);
}

/* Header */
.header[data-v-008b16ad] {
  background: linear-gradient(90deg, #1e3a8a 0%, #1e40af 45%, #2563eb 100%);
  color: #f8fafc;
  padding: 1rem 0;
  border-bottom: 1px solid rgba(255, 255, 255, 0.2);
  box-shadow: 0 8px 28px rgba(30, 64, 175, 0.22);
}
.header-content[data-v-008b16ad] {
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0 1rem;
}
.title-section[data-v-008b16ad] {
  flex: 1;
}
.title[data-v-008b16ad] {
  font-size: 1.5rem;
  font-weight: 700;
  letter-spacing: 0.25px;
  margin-bottom: 0.35rem;
}
.subtitle[data-v-008b16ad] {
  font-size: 0.9rem;
  opacity: 0.88;
}
.doctor-name[data-v-008b16ad] {
  font-weight: 700;
  color: #dbeafe;
}
.title-section .clinic-name[data-v-008b16ad] {
  font-weight: 500;
  color: #bfdbfe;
  opacity: 1;
}
.header-actions[data-v-008b16ad] {
  display: flex;
  align-items: center;
  gap: 1.5rem;
}
.home-btn[data-v-008b16ad] {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  background: rgba(255, 255, 255, 0.14);
  border: 1px solid rgba(255, 255, 255, 0.28);
  color: #f8fafc;
  padding: 0.5rem 1rem;
  border-radius: 8px;
  font-size: 0.9rem;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s ease;
}
.home-btn[data-v-008b16ad]:hover {
  background: rgba(255, 255, 255, 0.24);
  transform: translateY(-1px);
}
.datetime-widget[data-v-008b16ad] {
  text-align: center;
  padding: 0.5rem 1rem;
  background: rgba(255, 255, 255, 0.1);
  border-radius: 8px;
  border: 1px solid rgba(255, 255, 255, 0.2);
}
.current-time[data-v-008b16ad] {
  font-size: 1rem;
  font-weight: 700;
  font-family: 'Courier New', monospace;
  margin-bottom: 0.25rem;
}
.current-date[data-v-008b16ad] {
  font-size: 0.65rem;
  opacity: 0.9;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.btn-icon[data-v-008b16ad] {
  font-size: 1rem;
}

/* User menu (переиспользуем стили) */
.user-menu[data-v-008b16ad] {
  position: relative;
}
.user-avatar[data-v-008b16ad] {
  width: 40px;
  height: 40px;
  background: rgba(255, 255, 255, 0.15);
  border: 2px solid rgba(255, 255, 255, 0.35);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s ease;
  font-size: 1rem;
}
.user-avatar[data-v-008b16ad]:hover {
  background: rgba(255, 255, 255, 0.24);
  transform: scale(1.05);
}
.user-dropdown[data-v-008b16ad] {
  position: absolute;
  top: 50px;
  right: 0;
  background: var(--surface);
  color: var(--text-primary);
  border-radius: 12px;
  box-shadow: 0 20px 40px rgba(15, 23, 42, 0.18);
  min-width: 200px;
  z-index: 1000;
  border: 1px solid var(--border);
  overflow: hidden;
  animation: slideDown-008b16ad 0.2s ease-out;
}
@keyframes slideDown-008b16ad {
from {
    opacity: 0;
    transform: translateY(-10px);
}
to {
    opacity: 1;
    transform: translateY(0);
}
}
.user-info[data-v-008b16ad] {
  padding: 1rem;
  background: var(--surface-muted);
}
.user-name[data-v-008b16ad] {
  display: block;
  font-weight: 600;
  color: var(--text-primary);
  font-size: 0.875rem;
  margin-bottom: 0.25rem;
}
.user-email[data-v-008b16ad] {
  display: block;
  color: var(--text-secondary);
  font-size: 0.75rem;
}
.user-specialization[data-v-008b16ad] {
  display: block;
  color: var(--accent);
  font-size: 0.7rem;
  font-weight: 600;
  margin-top: 0.25rem;
}
.user-clinic[data-v-008b16ad] {
  margin-top: 0.5rem;
  padding-top: 0.5rem;
  border-top: 1px solid var(--border);
}
.user-clinic .clinic-name[data-v-008b16ad] {
  display: block;
  color: var(--text-primary);
  font-size: 0.75rem;
  font-weight: 500;
  margin-bottom: 0.25rem;
}
.clinic-region[data-v-008b16ad] {
  display: block;
  color: var(--text-secondary);
  font-size: 0.7rem;
}
.dropdown-divider[data-v-008b16ad] {
  margin: 0;
  border: none;
  border-top: 1px solid var(--border);
}
.logout-btn[data-v-008b16ad] {
  width: 100%;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.75rem 1rem;
  background: none;
  border: none;
  color: #b91c1c;
  font-size: 0.875rem;
  cursor: pointer;
  transition: background-color 0.2s ease;
}
.logout-btn[data-v-008b16ad]:hover {
  background: #fee2e2;
}
.logout-icon[data-v-008b16ad] {
  font-size: 1rem;
}

/* Main content */
.main-content[data-v-008b16ad] {
  max-width: 1200px;
  margin: 0 auto;
  padding: 2.75rem 1rem;
}

/* Stats section */
.stats-section[data-v-008b16ad] {
  margin-bottom: 2rem;
}
.stats-cards[data-v-008b16ad] {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 1rem;
}
.stat-card[data-v-008b16ad] {
  background: var(--surface);
  padding: 1.5rem;
  border-radius: 14px;
  border: 1px solid var(--border);
  box-shadow: 0 16px 32px rgba(15, 23, 42, 0.08);
  display: flex;
  align-items: center;
  gap: 1rem;
  transition: all 0.2s ease;
}
.stat-card[data-v-008b16ad]:hover {
  transform: translateY(-2px);
  box-shadow: 0 16px 32px rgba(37, 99, 235, 0.16);
}
.stat-icon[data-v-008b16ad] {
  font-size: 2rem;
  opacity: 0.8;
}
.stat-content[data-v-008b16ad] {
  flex: 1;
}
.stat-number[data-v-008b16ad] {
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--text-primary);
  margin-bottom: 0.25rem;
}
.stat-label[data-v-008b16ad] {
  font-size: 0.875rem;
  color: var(--text-secondary);
  font-weight: 500;
}

/* Filters section */
.filters-section[data-v-008b16ad] {
  background: var(--surface);
  padding: 1.5rem;
  border-radius: 16px;
  border: 1px solid var(--border);
  box-shadow: 0 16px 40px rgba(15, 23, 42, 0.08);
  margin-bottom: 1.5rem;
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  align-items: center;
}
.search-container[data-v-008b16ad] {
  flex: 1;
  min-width: 300px;
}
.search-tools[data-v-008b16ad] {
  margin-top: 0.5rem;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.search-input-wrapper[data-v-008b16ad] {
  display: flex;
  background: var(--surface);
  border: 1px solid var(--border-strong);
  border-radius: 10px;
  padding: 0.75rem 1rem;
  transition: all 0.2s ease;
}
.search-input-wrapper[data-v-008b16ad]:focus-within {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.12);
}
.search-input[data-v-008b16ad] {
  flex: 1;
  background: transparent;
  border: none;
  color: var(--text-primary);
  font-size: 1rem;
  padding: 0.5rem;
  outline: none;
  font-weight: 500;
}
.search-input[data-v-008b16ad]::-moz-placeholder {
  color: #94a3b8;
}
.search-input[data-v-008b16ad]::placeholder {
  color: #94a3b8;
}
.search-btn[data-v-008b16ad] {
  background: var(--accent);
  border: none;
  color: white;
  padding: 0.55rem 1rem;
  border-radius: 8px;
  font-size: 0.95rem;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s ease;
  min-width: 88px;
}
.search-btn[data-v-008b16ad]:hover {
  background: var(--accent-hover);
  transform: translateY(-1px);
  box-shadow: 0 10px 20px rgba(37, 99, 235, 0.24);
}
.global-search-btn[data-v-008b16ad] {
  background: var(--surface);
  border: 1px solid var(--border-strong);
  color: var(--text-secondary);
  padding: 0.45rem 0.8rem;
  border-radius: 999px;
  font-size: 0.8rem;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s ease;
}
.global-search-btn[data-v-008b16ad]:hover {
  border-color: var(--accent);
  color: var(--accent-hover);
}
.global-search-btn.active[data-v-008b16ad] {
  background: var(--accent-soft);
  border-color: var(--accent);
  color: var(--accent-hover);
  box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.12);
}
.filters-container[data-v-008b16ad] {
  display: flex;
  gap: 1rem;
  align-items: center;
  flex-wrap: wrap;
}
.filter-select[data-v-008b16ad] {
  padding: 0.5rem 1rem;
  border: 1px solid var(--border-strong);
  border-radius: 8px;
  background: var(--surface);
  color: var(--text-primary);
  font-size: 0.875rem;
  font-weight: 500;
  cursor: pointer;
  transition: border-color 0.2s ease;
  min-width: 120px;
}
.filter-select[data-v-008b16ad]:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.12);
}
.reset-filters-btn[data-v-008b16ad] {
  padding: 0.5rem 1rem;
  background: var(--surface);
  border: 1px solid var(--border-strong);
  border-radius: 8px;
  color: var(--accent);
  font-size: 0.875rem;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s ease;
}
.reset-filters-btn[data-v-008b16ad]:hover {
  background: var(--accent-soft);
  border-color: rgba(37, 99, 235, 0.45);
  color: var(--accent-hover);
}

/* Patients section */
.patients-section[data-v-008b16ad] {
  background: var(--surface);
  border-radius: 16px;
  border: 1px solid var(--border);
  box-shadow: 0 16px 40px rgba(15, 23, 42, 0.08);
  overflow: hidden;
}

/* Loading and error states */
.loading-state[data-v-008b16ad] {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 3rem;
  gap: 1rem;
  color: var(--text-secondary);
}
.spinner[data-v-008b16ad] {
  width: 24px;
  height: 24px;
  border: 3px solid var(--border);
  border-top: 3px solid var(--accent);
  border-radius: 50%;
  animation: spin-008b16ad 1s linear infinite;
}
@keyframes spin-008b16ad {
0% { transform: rotate(0deg);
}
100% { transform: rotate(360deg);
}
}
.error-state[data-v-008b16ad] {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 3rem;
  text-align: center;
}
.error-icon[data-v-008b16ad] {
  font-size: 3rem;
  margin-bottom: 1rem;
}
.error-content h3[data-v-008b16ad] {
  color: #dc2626;
  margin-bottom: 0.5rem;
  font-size: 1.25rem;
}
.error-content p[data-v-008b16ad] {
  color: var(--text-secondary);
  margin-bottom: 1rem;
}
.retry-btn[data-v-008b16ad] {
  background: var(--accent);
  color: white;
  border: none;
  padding: 0.75rem 1.5rem;
  border-radius: 8px;
  cursor: pointer;
  font-weight: 500;
  transition: background-color 0.2s ease;
}
.retry-btn[data-v-008b16ad]:hover {
  background: var(--accent-hover);
  transform: translateY(-1px);
}

/* Table */
.patients-table-container[data-v-008b16ad] {
  overflow-x: auto;
}
.patients-table[data-v-008b16ad] {
  width: 100%;
  border-collapse: collapse;
}
.patients-table th[data-v-008b16ad] {
  background: var(--surface-muted);
  padding: 1rem;
  text-align: left;
  font-weight: 600;
  color: var(--text-primary);
  font-size: 0.875rem;
  border-bottom: 1px solid var(--border);
  white-space: nowrap;
}
.patients-table td[data-v-008b16ad] {
  padding: 1rem;
  border-bottom: 1px solid var(--border);
  font-size: 0.875rem;
  color: var(--text-primary);
}
.patient-row[data-v-008b16ad] {
  cursor: pointer;
  transition: background-color 0.2s ease;
}
.patient-row[data-v-008b16ad]:hover {
  background: var(--surface-muted);
}
.patient-name[data-v-008b16ad] {
  min-width: 200px;
}
.name-container[data-v-008b16ad] {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.full-name[data-v-008b16ad] {
  font-weight: 500;
  color: var(--text-primary);
}
.gender-badge[data-v-008b16ad] {
  font-size: 0.8rem;
}
.gender-badge.male[data-v-008b16ad] {
  color: #3b82f6;
}
.gender-badge.female[data-v-008b16ad] {
  color: #ec4899;
}
.patient-iin[data-v-008b16ad] {
  font-family: monospace;
  color: var(--text-secondary);
}
.patient-actions[data-v-008b16ad] {
  width: 120px;
  text-align: right;
}
.action-buttons[data-v-008b16ad] {
  display: flex;
  gap: 0.5rem;
  justify-content: flex-end;
  align-items: center;
}
.action-btn[data-v-008b16ad] {
  background: var(--surface-muted);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 0.5rem;
  cursor: pointer;
  transition: all 0.2s ease;
  font-size: 1rem;
  font-weight: 500;
  white-space: nowrap;
  min-width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.edit-btn[data-v-008b16ad] {
  background: #10B981;
  color: white;
  border-color: #10B981;
}
.visit-btn[data-v-008b16ad] {
  background: var(--accent);
  color: white;
  border-color: var(--accent);
}
.edit-btn[data-v-008b16ad]:hover {
  background: #059669;
  border-color: #047857;
  transform: translateY(-1px);
  box-shadow: 0 2px 8px rgba(16, 185, 129, 0.3);
}
.visit-btn[data-v-008b16ad]:hover {
  background: var(--accent-hover);
  border-color: #1e40af;
  transform: translateY(-1px);
  box-shadow: 0 2px 8px rgba(37, 99, 235, 0.3);
}
.registry-btn[data-v-008b16ad] {
  background: var(--accent);
  color: white;
  border-color: var(--accent);
}
.registry-btn[data-v-008b16ad]:hover {
  background: var(--accent-hover);
  border-color: var(--accent-hover);
  transform: translateY(-1px);
}

/* Pagination */
.pagination[data-v-008b16ad] {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1.5rem;
  border-top: 1px solid var(--border);
  background: var(--surface-muted);
}
.pagination-btn[data-v-008b16ad] {
  background: var(--accent);
  color: white;
  border: none;
  padding: 0.5rem 1rem;
  border-radius: 8px;
  cursor: pointer;
  font-weight: 500;
  transition: all 0.2s ease;
}
.pagination-btn[data-v-008b16ad]:hover:not(:disabled) {
  background: var(--accent-hover);
  transform: translateY(-1px);
  box-shadow: 0 10px 20px rgba(37, 99, 235, 0.24);
}
.pagination-btn[data-v-008b16ad]:disabled {
  background: #d1d5db;
  cursor: not-allowed;
  transform: none;
}
.pagination-info[data-v-008b16ad] {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.25rem;
  font-size: 0.875rem;
  color: var(--text-secondary);
}
.pagination-total[data-v-008b16ad] {
  font-size: 0.75rem;
  opacity: 0.8;
}

/* Empty state */
.empty-state[data-v-008b16ad] {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 4rem 2rem;
}
.empty-state-content[data-v-008b16ad] {
  text-align: center;
  max-width: 400px;
}
.empty-state-icon[data-v-008b16ad] {
  font-size: 4rem;
  margin-bottom: 1rem;
  opacity: 0.6;
}
.empty-state-title[data-v-008b16ad] {
  font-size: 1.5rem;
  font-weight: 600;
  color: var(--text-primary);
  margin-bottom: 0.5rem;
}
.empty-state-subtitle[data-v-008b16ad] {
  font-size: 1rem;
  color: var(--text-secondary);
  margin-bottom: 1.5rem;
  line-height: 1.5;
}
.btn-reset[data-v-008b16ad] {
  background: var(--accent);
  color: white;
  border: none;
  padding: 0.75rem 1.5rem;
  border-radius: 8px;
  cursor: pointer;
  font-weight: 500;
  transition: all 0.2s ease;
}
.btn-reset[data-v-008b16ad]:hover {
  background: var(--accent-hover);
  transform: translateY(-1px);
}

/* Responsive design */
@media (max-width: 768px) {
.header-content[data-v-008b16ad] {
    flex-direction: column;
    gap: 1rem;
    align-items: stretch;
}
.header-actions[data-v-008b16ad] {
    justify-content: space-between;
}
.main-content[data-v-008b16ad] {
    padding: 1rem;
}
.stats-cards[data-v-008b16ad] {
    grid-template-columns: repeat(2, 1fr);
}
.filters-section[data-v-008b16ad] {
    flex-direction: column;
    align-items: stretch;
}
.search-container[data-v-008b16ad] {
    min-width: auto;
}
.search-tools[data-v-008b16ad] {
    justify-content: center;
}
.filters-container[data-v-008b16ad] {
    justify-content: center;
}
.patients-table th[data-v-008b16ad],
  .patients-table td[data-v-008b16ad] {
    padding: 0.75rem 0.5rem;
    font-size: 0.8rem;
}
.pagination[data-v-008b16ad] {
    flex-direction: column;
    gap: 1rem;
}
.empty-state[data-v-008b16ad] {
    padding: 3rem 1rem;
}
}
@media (max-width: 480px) {
.stats-cards[data-v-008b16ad] {
    grid-template-columns: 1fr;
}
.title[data-v-008b16ad] {
    font-size: 1.25rem;
}
.subtitle[data-v-008b16ad] {
    font-size: 0.8rem;
}
.filters-container[data-v-008b16ad] {
    flex-direction: column;
    align-items: stretch;
}
.filter-select[data-v-008b16ad] {
    min-width: auto;
}
.action-buttons[data-v-008b16ad] {
    flex-direction: row;
    gap: 0.25rem;
}
.action-btn[data-v-008b16ad] {
    font-size: 0.9rem;
    min-width: 28px;
    height: 28px;
    padding: 0.25rem;
}
.patient-actions[data-v-008b16ad] {
    width: 180px;
}
}

/* Модальное окно редактирования */
.modal-overlay[data-v-008b16ad] {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(15, 23, 42, 0.48);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 2000;
}
.modal-content[data-v-008b16ad] {
  background: var(--surface);
  border-radius: 16px;
  width: 90%;
  max-width: 500px;
  max-height: 80vh;
  overflow-y: auto;
  border: 1px solid var(--border);
  box-shadow: 0 24px 52px rgba(15, 23, 42, 0.24);
}
.modal-header[data-v-008b16ad] {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1.5rem;
  border-bottom: 1px solid var(--border);
}
.modal-header h3[data-v-008b16ad] {
  margin: 0;
  font-size: 1.25rem;
  font-weight: 600;
  color: var(--text-primary);
}
.close-btn[data-v-008b16ad] {
  background: none;
  border: 1px solid var(--border);
  font-size: 1.25rem;
  color: var(--text-secondary);
  cursor: pointer;
  padding: 0;
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 8px;
  transition: all 0.2s ease;
}
.close-btn[data-v-008b16ad]:hover {
  background: var(--surface-muted);
  border-color: var(--border-strong);
}
.modal-body[data-v-008b16ad] {
  padding: 1.5rem;
  color: var(--text-primary);
}
.form-group[data-v-008b16ad] {
  margin-bottom: 1rem;
}
.form-group label[data-v-008b16ad] {
  display: block;
  margin-bottom: 0.5rem;
  font-weight: 500;
  color: var(--text-primary);
  font-size: 0.9rem;
}
.form-input[data-v-008b16ad],
.form-select[data-v-008b16ad] {
  width: 100%;
  padding: 0.75rem 1rem;
  border: 1px solid var(--border-strong);
  border-radius: 8px;
  font-size: 0.9rem;
  transition: border-color 0.2s ease;
  color: var(--text-primary);
  background: var(--surface);
}
.form-input[data-v-008b16ad]:focus,
.form-select[data-v-008b16ad]:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.12);
}
.form-input.error[data-v-008b16ad] {
  border-color: #ef4444;
  box-shadow: 0 0 0 3px rgba(239, 68, 68, 0.1);
}
.required[data-v-008b16ad] {
  color: #ef4444;
  font-weight: bold;
}
.field-error[data-v-008b16ad] {
  color: #ef4444;
  font-size: 0.8rem;
  margin-top: 0.25rem;
  font-weight: 500;
}
.field-note[data-v-008b16ad] {
  color: var(--text-secondary);
  font-size: 0.75rem;
  margin-top: 0.25rem;
  font-style: italic;
  display: block;
}
.modal-footer[data-v-008b16ad] {
  display: flex;
  justify-content: flex-end;
  gap: 0.75rem;
  padding: 1.5rem;
  border-top: 1px solid var(--border);
  background: var(--surface-muted);
}
.btn[data-v-008b16ad] {
  padding: 0.75rem 1.5rem;
  border: none;
  border-radius: 8px;
  font-size: 0.9rem;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.2s ease;
}
.btn-cancel[data-v-008b16ad] {
  background: var(--surface);
  color: var(--text-primary);
  border: 1px solid var(--border-strong);
}
.btn-cancel[data-v-008b16ad]:hover {
  background: var(--surface-muted);
}
.btn-primary[data-v-008b16ad] {
  background: var(--accent);
  color: white;
}
.btn-primary[data-v-008b16ad]:hover {
  background: var(--accent-hover);
}
.btn-primary[data-v-008b16ad]:disabled {
  background: #D1D5DB;
  cursor: not-allowed;
}


.debug-page[data-v-1f1084f6] {
  --accent: #2563eb;
  --accent-hover: #1d4ed8;
  --accent-soft: #eff6ff;
  --surface: #ffffff;
  --surface-muted: #f8fafc;
  --border: #e2e8f0;
  --border-strong: #cbd5e1;
  --text-primary: #0f172a;
  --text-secondary: #475569;

  min-height: 100vh;
  background: linear-gradient(180deg, #f8fafc 0%, #f1f5f9 100%);
  padding: 2rem;
  color: var(--text-primary);
}
.debug-container[data-v-1f1084f6] {
  max-width: 960px;
  margin: 0 auto;
}
.debug-container h1[data-v-1f1084f6] {
  text-align: center;
  color: var(--text-primary);
  font-size: 1.6rem;
  letter-spacing: 0.2px;
  margin-bottom: 2rem;
}
.status-card[data-v-1f1084f6], .action-card[data-v-1f1084f6], .result-card[data-v-1f1084f6], .info-card[data-v-1f1084f6] {
  background: var(--surface);
  border-radius: 16px;
  border: 1px solid var(--border);
  padding: 1.5rem;
  margin-bottom: 1.5rem;
  box-shadow: 0 16px 32px rgba(15, 23, 42, 0.08);
}
.status-card h2[data-v-1f1084f6], .action-card h2[data-v-1f1084f6], .result-card h2[data-v-1f1084f6], .info-card h2[data-v-1f1084f6] {
  margin-bottom: 1rem;
  color: var(--text-primary);
  font-size: 1.2rem;
}
.debug-section[data-v-1f1084f6] {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 1.5rem;
  margin-bottom: 1.5rem;
  box-shadow: 0 16px 32px rgba(15, 23, 42, 0.08);
}
.debug-section h3[data-v-1f1084f6] {
  margin: 0 0 1rem 0;
  color: var(--text-primary);
}
.status-info[data-v-1f1084f6] {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}
.status-item[data-v-1f1084f6] {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0.6rem 0.75rem;
  background: var(--surface-muted);
  border: 1px solid var(--border);
  border-radius: 8px;
}
.status-item label[data-v-1f1084f6] {
  font-weight: 500;
  color: var(--text-secondary);
}
.status-ok[data-v-1f1084f6] {
  color: #059669;
  font-weight: 600;
}
.status-error[data-v-1f1084f6] {
  color: #dc2626;
  font-weight: 600;
}
.actions[data-v-1f1084f6] {
  display: flex;
  gap: 0.75rem;
  flex-wrap: wrap;
}
.action-btn[data-v-1f1084f6] {
  padding: 0.65rem 1rem;
  border: none;
  border-radius: 10px;
  cursor: pointer;
  font-weight: 600;
  transition: all 0.2s ease;
}
.action-btn.primary[data-v-1f1084f6] {
  background-color: var(--accent);
  color: white;
}
.action-btn.primary[data-v-1f1084f6]:hover {
  background-color: var(--accent-hover);
  transform: translateY(-1px);
  box-shadow: 0 10px 20px rgba(37, 99, 235, 0.24);
}
.action-btn.danger[data-v-1f1084f6] {
  background-color: #dc2626;
  color: white;
}
.action-btn.danger[data-v-1f1084f6]:hover {
  background-color: #b91c1c;
  transform: translateY(-1px);
}
.test-result[data-v-1f1084f6] {
  position: relative;
  background-color: var(--surface-muted);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 1rem;
  margin-top: 0.75rem;
}
.test-result pre[data-v-1f1084f6] {
  margin: 0;
  white-space: pre-wrap;
  word-wrap: break-word;
  max-height: 300px;
  overflow-y: auto;
}
.copy-btn[data-v-1f1084f6] {
  position: absolute;
  top: 0.75rem;
  right: 0.75rem;
  background-color: var(--accent);
  color: white;
  border: none;
  border-radius: 8px;
  padding: 0.3rem 0.55rem;
  cursor: pointer;
  font-size: 0.72rem;
  font-weight: 600;
}
.copy-btn[data-v-1f1084f6]:hover {
  background-color: var(--accent-hover);
}
.test-btn[data-v-1f1084f6], .clear-btn[data-v-1f1084f6], .login-btn[data-v-1f1084f6] {
  padding: 0.75rem 1.5rem;
  border: none;
  border-radius: 10px;
  font-weight: 600;
  cursor: pointer;
  text-decoration: none;
  display: inline-block;
  text-align: center;
  transition: all 0.2s;
}
.test-btn[data-v-1f1084f6] {
  background: var(--accent);
  color: white;
}
.test-btn[data-v-1f1084f6]:hover:not(:disabled) {
  background: var(--accent-hover);
}
.test-btn[data-v-1f1084f6]:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}
.clear-btn[data-v-1f1084f6] {
  background: #f3f4f6;
  color: var(--text-primary);
  border: 1px solid var(--border);
}
.clear-btn[data-v-1f1084f6]:hover {
  background: #e5e7eb;
}
.login-btn[data-v-1f1084f6] {
  background: #10b981;
  color: white;
}
.login-btn[data-v-1f1084f6]:hover {
  background: #059669;
}
.result-card pre[data-v-1f1084f6] {
  background: var(--surface-muted);
  border: 1px solid var(--border);
  padding: 1rem;
  border-radius: 8px;
  overflow-x: auto;
  font-size: 0.9rem;
}
.info-card ul[data-v-1f1084f6] {
  margin: 1rem 0;
  padding-left: 1.5rem;
}
.info-card li[data-v-1f1084f6] {
  margin-bottom: 0.5rem;
  color: var(--text-secondary);
}
.info-card p[data-v-1f1084f6] {
  color: var(--text-secondary);
  line-height: 1.6;
}
.credentials-info[data-v-1f1084f6] {
  margin-top: 1.5rem;
  padding-top: 1.5rem;
  border-top: 1px solid var(--border);
}
.credentials-info h3[data-v-1f1084f6] {
  margin-bottom: 0.75rem;
  color: var(--text-primary);
}
.credentials-info p[data-v-1f1084f6] {
  color: var(--text-secondary);
  font-style: italic;
}
@media (max-width: 600px) {
.debug-page[data-v-1f1084f6] {
    padding: 1rem;
}
.actions[data-v-1f1084f6] {
    flex-direction: column;
}
.test-btn[data-v-1f1084f6], .clear-btn[data-v-1f1084f6], .login-btn[data-v-1f1084f6] {
    width: 100%;
}
}


.login-page[data-v-7bf83fdc] {
  --accent: #2563eb;
  --accent-hover: #1d4ed8;
  --accent-soft: #eff6ff;
  --surface: #ffffff;
  --surface-muted: #f8fafc;
  --border: #e2e8f0;
  --border-strong: #cbd5e1;
  --text-primary: #0f172a;
  --text-secondary: #475569;
  --danger: #dc2626;

  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  background:
    radial-gradient(circle at 15% 15%, rgba(37, 99, 235, 0.14) 0%, transparent 42%),
    radial-gradient(circle at 85% 80%, rgba(30, 64, 175, 0.14) 0%, transparent 40%),
    linear-gradient(180deg, #f8fafc 0%, #f1f5f9 100%);
  padding: 1rem;
  position: relative;
  overflow: hidden;
  color: var(--text-primary);
}

/* Переключатель языка в правом верхнем углу */
.language-switcher-wrapper[data-v-7bf83fdc] {
  position: absolute;
  top: 1.5rem;
  right: 1.5rem;
  z-index: 100;
}
.login-container[data-v-7bf83fdc] {
  background: var(--surface);
  border-radius: 16px;
  border: 1px solid var(--border);
  box-shadow: 0 24px 52px rgba(15, 23, 42, 0.18);
  overflow: hidden;
  max-width: 420px;
  width: 100%;
  position: relative;
  z-index: 10;
}
.login-header[data-v-7bf83fdc] {
  background: linear-gradient(90deg, #1e3a8a 0%, #1e40af 45%, #2563eb 100%);
  color: #f8fafc;
  text-align: center;
  padding: 2rem 1rem 1.5rem;
  border-bottom: 1px solid rgba(255, 255, 255, 0.2);
}
.logo-icon[data-v-7bf83fdc] {
  font-size: 3rem;
  margin-bottom: 0.5rem;
}
.logo-title[data-v-7bf83fdc] {
  font-size: 1.5rem;
  font-weight: 700;
  margin: 0 0 0.25rem 0;
  letter-spacing: 0.25px;
}
.logo-subtitle[data-v-7bf83fdc] {
  font-size: 0.875rem;
  opacity: 0.88;
  margin: 0;
  font-weight: 400;
}
.login-form-container[data-v-7bf83fdc] {
  padding: 2rem;
}
.form-title[data-v-7bf83fdc] {
  font-size: 1.5rem;
  font-weight: 600;
  color: var(--text-primary);
  margin: 0 0 1.5rem 0;
  text-align: center;
}
.form-group[data-v-7bf83fdc] {
  margin-bottom: 1.5rem;
}
.form-label[data-v-7bf83fdc] {
  display: block;
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--text-primary);
  margin-bottom: 0.5rem;
}
.form-input[data-v-7bf83fdc] {
  width: 100%;
  padding: 0.75rem 1rem;
  border: 1px solid var(--border-strong);
  border-radius: 8px;
  font-size: 1rem;
  transition: all 0.2s ease;
  background: var(--surface);
  color: var(--text-primary);
}
.form-input[data-v-7bf83fdc]:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.12);
}
.form-input.error[data-v-7bf83fdc] {
  border-color: #ef4444;
  background: #fef2f2;
}
.password-input-container[data-v-7bf83fdc] {
  position: relative;
}
.password-toggle[data-v-7bf83fdc] {
  position: absolute;
  right: 0.75rem;
  top: 50%;
  transform: translateY(-50%);
  width: 34px;
  height: 34px;
  background: none;
  border: none;
  border-radius: 8px;
  cursor: pointer;
  color: var(--text-secondary);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: color 0.2s ease, background-color 0.2s ease;
}
.password-toggle[data-v-7bf83fdc]:hover {
  color: var(--accent);
  background: var(--surface-muted);
}
.password-toggle-icon[data-v-7bf83fdc] {
  width: 18px;
  height: 18px;
}
.checkbox-label[data-v-7bf83fdc] {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  cursor: pointer;
  font-size: 0.875rem;
  color: var(--text-secondary);
}
.checkbox-text[data-v-7bf83fdc] {
  color: var(--text-secondary);
}
.checkbox-input[data-v-7bf83fdc] {
  display: none;
}
.checkbox-custom[data-v-7bf83fdc] {
  width: 18px;
  height: 18px;
  border: 2px solid var(--border-strong);
  border-radius: 4px;
  position: relative;
  transition: all 0.2s ease;
}
.checkbox-input:checked + .checkbox-custom[data-v-7bf83fdc] {
  background: var(--accent);
  border-color: var(--accent);
}
.checkbox-input:checked + .checkbox-custom[data-v-7bf83fdc]::after {
  content: '✓';
  position: absolute;
  top: -2px;
  left: 2px;
  color: white;
  font-size: 12px;
  font-weight: bold;
}
.error-message[data-v-7bf83fdc] {
  display: block;
  color: #ef4444;
  font-size: 0.75rem;
  margin-top: 0.25rem;
}
.error-alert[data-v-7bf83fdc] {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  background: #fef2f2;
  border: 1px solid #fecaca;
  border-radius: 6px;
  padding: 0.75rem;
  color: var(--danger);
  font-size: 0.875rem;
  margin-bottom: 1rem;
}
.loading-alert[data-v-7bf83fdc] {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  background: var(--accent-soft);
  border: 1px solid rgba(37, 99, 235, 0.25);
  border-radius: 6px;
  padding: 0.75rem;
  color: var(--accent-hover);
  font-size: 0.875rem;
  margin-bottom: 1rem;
}
.loading-spinner[data-v-7bf83fdc] {
  width: 16px;
  height: 16px;
  border: 2px solid rgba(37, 99, 235, 0.22);
  border-top: 2px solid var(--accent);
  border-radius: 50%;
  animation: spin-7bf83fdc 1s linear infinite;
}
@keyframes spin-7bf83fdc {
0% { transform: rotate(0deg);
}
100% { transform: rotate(360deg);
}
}
.login-button[data-v-7bf83fdc] {
  width: 100%;
  padding: 0.875rem 1.5rem;
  background: var(--accent);
  color: white;
  border: none;
  border-radius: 8px;
  font-size: 1rem;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s ease;
  margin-bottom: 1rem;
}
.login-button[data-v-7bf83fdc]:hover:not(:disabled) {
  background: var(--accent-hover);
  transform: translateY(-1px);
  box-shadow: 0 10px 22px rgba(37, 99, 235, 0.26);
}
.login-button[data-v-7bf83fdc]:disabled {
  opacity: 0.6;
  cursor: not-allowed;
  transform: none;
  box-shadow: none;
}
.login-footer[data-v-7bf83fdc] {
  text-align: center;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.forgot-password-link[data-v-7bf83fdc], .debug-link[data-v-7bf83fdc] {
  color: var(--accent);
  text-decoration: none;
  font-size: 0.875rem;
  transition: color 0.2s ease;
}
.forgot-password-link[data-v-7bf83fdc]:hover, .debug-link[data-v-7bf83fdc]:hover {
  color: var(--accent-hover);
  text-decoration: underline;
}
.debug-link[data-v-7bf83fdc] {
  color: var(--text-secondary);
  font-size: 0.75rem;
}

/* Фоновые декорации */
.background-decoration[data-v-7bf83fdc] {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 1;
}
.decoration-circle[data-v-7bf83fdc] {
  position: absolute;
  border-radius: 50%;
  background: rgba(37, 99, 235, 0.12);
  border: 1px solid rgba(37, 99, 235, 0.18);
  animation: float-7bf83fdc 6s ease-in-out infinite;
}
.circle-1[data-v-7bf83fdc] {
  width: 200px;
  height: 200px;
  top: 10%;
  left: 10%;
  animation-delay: 0s;
}
.circle-2[data-v-7bf83fdc] {
  width: 150px;
  height: 150px;
  top: 60%;
  right: 15%;
  animation-delay: 2s;
}
.circle-3[data-v-7bf83fdc] {
  width: 100px;
  height: 100px;
  bottom: 20%;
  left: 20%;
  animation-delay: 4s;
}
@keyframes float-7bf83fdc {
0%, 100% {
    transform: translateY(0px) rotate(0deg);
}
50% {
    transform: translateY(-20px) rotate(180deg);
}
}

/* Адаптивность */
@media (max-width: 480px) {
.login-page[data-v-7bf83fdc] {
    padding: 0.5rem;
}
.login-container[data-v-7bf83fdc] {
    max-width: 100%;
    border-radius: 12px;
}
.login-header[data-v-7bf83fdc] {
    padding: 1.5rem 1rem 1rem;
}
.logo-title[data-v-7bf83fdc] {
    font-size: 1.25rem;
}
.login-form-container[data-v-7bf83fdc] {
    padding: 1.5rem;
}
.decoration-circle[data-v-7bf83fdc] {
    display: none;
}
}

/* Анимация входа */
.login-container[data-v-7bf83fdc] {
  animation: slideIn-7bf83fdc 0.5s ease-out;
}
@keyframes slideIn-7bf83fdc {
from {
    opacity: 0;
    transform: translateY(30px);
}
to {
    opacity: 1;
    transform: translateY(0);
}
}


.survey-statistics-page[data-v-4ab594a6] {
  --accent: #2563eb;
  --accent-hover: #1d4ed8;
  --accent-soft: #eff6ff;
  --surface: #ffffff;
  --surface-muted: #f8fafc;
  --border: #e2e8f0;
  --border-strong: #cbd5e1;
  --text-primary: #0f172a;
  --text-secondary: #475569;

  min-height: 100vh;
  background: linear-gradient(180deg, #f8fafc 0%, #f1f5f9 100%);
  color: var(--text-primary);
}

/* Header */
.header[data-v-4ab594a6] {
  background: linear-gradient(90deg, #1e3a8a 0%, #1e40af 45%, #2563eb 100%);
  color: #f8fafc;
  padding: 1rem 0;
  border-bottom: 1px solid rgba(255, 255, 255, 0.2);
  box-shadow: 0 8px 28px rgba(30, 64, 175, 0.22);
}
.header-content[data-v-4ab594a6] {
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0 1rem;
}
.title-section[data-v-4ab594a6] {
  flex: 1;
}
.title[data-v-4ab594a6] {
  font-size: 1.5rem;
  font-weight: 700;
  letter-spacing: 0.25px;
  margin-bottom: 0.35rem;
}
.subtitle[data-v-4ab594a6] {
  font-size: 0.9rem;
  opacity: 0.88;
}
.header-actions[data-v-4ab594a6] {
  display: flex;
  align-items: center;
  gap: 1.5rem;
}
.datetime-widget[data-v-4ab594a6] {
  text-align: center;
  padding: 0.5rem 1rem;
  background: rgba(255, 255, 255, 0.1);
  border-radius: 8px;
  border: 1px solid rgba(255, 255, 255, 0.2);
}
.current-time[data-v-4ab594a6] {
  font-size: 1.2rem;
  font-weight: 700;
  font-family: 'Courier New', monospace;
  margin-bottom: 0.25rem;
}
.current-date[data-v-4ab594a6] {
  font-size: 0.75rem;
  opacity: 0.9;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.action-buttons[data-v-4ab594a6] {
  display: flex;
  align-items: center;
  gap: 1rem;
}
.btn-export[data-v-4ab594a6],
.btn-back[data-v-4ab594a6] {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.75rem 1.25rem;
  background: rgba(255, 255, 255, 0.1);
  border: 1px solid rgba(255, 255, 255, 0.2);
  color: white;
  border-radius: 8px;
  cursor: pointer;
  transition: all 0.2s ease;
  font-size: 0.9rem;
  font-weight: 600;
}
.btn-export[data-v-4ab594a6]:hover,
.btn-back[data-v-4ab594a6]:hover {
  background: rgba(255, 255, 255, 0.2);
  transform: translateY(-1px);
}
.btn-export[data-v-4ab594a6]:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}

/* Main Content */
.main-content[data-v-4ab594a6] {
  max-width: 1200px;
  margin: 0 auto;
  padding: 2.75rem 1rem;
}

/* Loading */
.loading-container[data-v-4ab594a6] {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 4rem 2rem;
}
.loading-spinner[data-v-4ab594a6] {
  width: 48px;
  height: 48px;
  border: 4px solid var(--border);
  border-top: 4px solid var(--accent);
  border-radius: 50%;
  animation: spin-4ab594a6 1s linear infinite;
  margin-bottom: 1rem;
}
.loading-text[data-v-4ab594a6] {
  font-size: 1.1rem;
  color: var(--text-secondary);
  font-weight: 500;
}

/* Error */
.error-container[data-v-4ab594a6] {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 4rem 2rem;
  text-align: center;
}
.error-icon[data-v-4ab594a6] {
  font-size: 3rem;
  margin-bottom: 1rem;
}
.error-message[data-v-4ab594a6] {
  font-size: 1.1rem;
  color: #dc2626;
  margin-bottom: 2rem;
  max-width: 500px;
}
.btn-retry[data-v-4ab594a6] {
  padding: 0.75rem 1.5rem;
  background: var(--accent);
  color: white;
  border: none;
  border-radius: 8px;
  font-size: 0.9rem;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s ease;
}
.btn-retry[data-v-4ab594a6]:hover {
  background: var(--accent-hover);
  transform: translateY(-1px);
}

/* Statistics Container */
.statistics-container[data-v-4ab594a6] {
  animation: fadeIn-4ab594a6 0.5s ease-out;
}

/* Фильтры */
.filters-panel[data-v-4ab594a6] {
  display: flex;
  gap: 1.5rem;
  margin-bottom: 2.5rem;
  padding: 1.5rem;
  background: var(--surface);
  border-radius: 16px;
  border: 1px solid var(--border);
  box-shadow: 0 16px 40px rgba(15, 23, 42, 0.08);
}
.filter-group[data-v-4ab594a6] {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  min-width: 200px;
}
.filter-group label[data-v-4ab594a6] {
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--text-secondary);
}
.filter-group select[data-v-4ab594a6] {
  padding: 0.75rem;
  border: 1px solid var(--border-strong);
  border-radius: 8px;
  background-color: var(--surface);
  color: var(--text-primary);
  font-size: 0.95rem;
  outline: none;
  transition: all 0.2s ease;
  cursor: pointer;
}
.filter-group select[data-v-4ab594a6]:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.12);
  background-color: var(--surface);
}

/* Summary Panel */
.summary-panel[data-v-4ab594a6] {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: 1.5rem;
  margin-bottom: 2.5rem;
}
.summary-card[data-v-4ab594a6] {
  background: var(--surface);
  border-radius: 16px;
  padding: 1.5rem;
  border: 1px solid var(--border);
  box-shadow: 0 16px 32px rgba(15, 23, 42, 0.08);
  display: flex;
  align-items: center;
  gap: 1rem;
  transition: all 0.2s ease;
}
.summary-card[data-v-4ab594a6]:hover {
  transform: translateY(-2px);
  box-shadow: 0 16px 32px rgba(37, 99, 235, 0.16);
}
.summary-icon[data-v-4ab594a6] {
  font-size: 2.5rem;
  width: 60px;
  height: 60px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 12px;
  background: var(--surface-muted);
}
.total-responses .summary-icon[data-v-4ab594a6] {
  background: #dbeafe;
}
.completion-rate .summary-icon[data-v-4ab594a6] {
  background: #dcfce7;
}
.average-score .summary-icon[data-v-4ab594a6] {
  background: #fef3c7;
}
.disability-level .summary-icon[data-v-4ab594a6] {
  background: #eff6ff;
}
.summary-content[data-v-4ab594a6] {
  flex: 1;
}
.summary-value[data-v-4ab594a6] {
  font-size: 2rem;
  font-weight: 700;
  color: var(--text-primary);
  margin-bottom: 0.25rem;
}
.summary-label[data-v-4ab594a6] {
  font-size: 0.9rem;
  color: var(--text-secondary);
  font-weight: 500;
}

/* HAQ Distribution Section */
.haq-distribution-section[data-v-4ab594a6] {
  margin: 3rem 0;
}
.section-header[data-v-4ab594a6] {
  text-align: center;
  margin-bottom: 2.5rem;
}
.section-title[data-v-4ab594a6] {
  font-size: 1.75rem;
  font-weight: 700;
  color: var(--text-primary);
  margin-bottom: 0.5rem;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.75rem;
}
.section-icon[data-v-4ab594a6] {
  font-size: 2rem;
}
.section-subtitle[data-v-4ab594a6] {
  font-size: 1rem;
  color: var(--text-secondary);
  font-weight: 500;
}
.haq-levels-grid[data-v-4ab594a6] {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 1.5rem;
}
.haq-level-card[data-v-4ab594a6] {
  background: var(--surface);
  border-radius: 16px;
  padding: 1.5rem;
  border: 1px solid var(--border);
  box-shadow: 0 16px 32px rgba(15, 23, 42, 0.08);
  transition: all 0.3s ease;
}
.haq-level-card[data-v-4ab594a6]:hover {
  transform: translateY(-4px);
  box-shadow: 0 16px 32px rgba(37, 99, 235, 0.16);
}
.level-header[data-v-4ab594a6] {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 1rem;
}
.level-name[data-v-4ab594a6] {
  font-size: 1.125rem;
  font-weight: 600;
  color: var(--text-primary);
}
.level-range[data-v-4ab594a6] {
  font-size: 0.875rem;
  color: var(--text-secondary);
  background: var(--surface-muted);
  padding: 0.25rem 0.5rem;
  border-radius: 4px;
}
.level-stats[data-v-4ab594a6] {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 1rem;
}
.level-count[data-v-4ab594a6] {
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--text-primary);
}
.level-percentage[data-v-4ab594a6] {
  font-size: 1.25rem;
  font-weight: 600;
  color: var(--accent);
}
.level-progress-bar[data-v-4ab594a6] {
  height: 8px;
  background: var(--border);
  border-radius: 4px;
  overflow: hidden;
  margin-bottom: 1rem;
}
.level-progress[data-v-4ab594a6] {
  height: 100%;
  border-radius: 4px;
  transition: width 1s ease;
}
.level-progress.no-disability[data-v-4ab594a6] {
  background: linear-gradient(90deg, #10B981, #34D399);
}
.level-progress.mild-disability[data-v-4ab594a6] {
  background: linear-gradient(90deg, #F59E0B, #FBBF24);
}
.level-progress.moderate-disability[data-v-4ab594a6] {
  background: linear-gradient(90deg, #EF4444, #F87171);
}
.level-progress.severe-disability[data-v-4ab594a6] {
  background: linear-gradient(90deg, #7C2D12, #DC2626);
}
.level-description[data-v-4ab594a6] {
  font-size: 0.875rem;
  color: var(--text-secondary);
  line-height: 1.4;
}

/* Blocks Statistics Section */
.blocks-statistics-section[data-v-4ab594a6] {
  margin: 3rem 0;
}
.blocks-grid[data-v-4ab594a6] {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
  gap: 2rem;
}
.block-card[data-v-4ab594a6] {
  background: var(--surface);
  border-radius: 16px;
  padding: 1.5rem;
  border: 1px solid var(--border);
  box-shadow: 0 16px 32px rgba(15, 23, 42, 0.08);
  transition: all 0.3s ease;
}
.block-card[data-v-4ab594a6]:hover {
  transform: translateY(-2px);
  box-shadow: 0 16px 32px rgba(37, 99, 235, 0.16);
}
.block-header[data-v-4ab594a6] {
  display: flex;
  align-items: flex-start;
  gap: 1rem;
  margin-bottom: 1.5rem;
}
.block-icon[data-v-4ab594a6] {
  font-size: 2rem;
  width: 50px;
  height: 50px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--surface-muted);
  border-radius: 12px;
  flex-shrink: 0;
}
.block-info[data-v-4ab594a6] {
  flex: 1;
}
.block-name[data-v-4ab594a6] {
  font-size: 1rem;
  font-weight: 600;
  color: var(--text-primary);
  margin-bottom: 0.25rem;
}
.block-subtitle[data-v-4ab594a6] {
  font-size: 0.875rem;
  color: var(--text-secondary);
  line-height: 1.4;
}
.block-score[data-v-4ab594a6] {
  text-align: center;
}
.score-value[data-v-4ab594a6] {
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--accent);
}
.score-label[data-v-4ab594a6] {
  font-size: 0.75rem;
  color: var(--text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.block-stats[data-v-4ab594a6] {
  display: flex;
  justify-content: space-between;
  margin-bottom: 1.5rem;
  padding: 1rem;
  background: var(--surface-muted);
  border-radius: 8px;
}
.stat-item[data-v-4ab594a6] {
  text-align: center;
}
.stat-label[data-v-4ab594a6] {
  display: block;
  font-size: 0.75rem;
  color: var(--text-secondary);
  margin-bottom: 0.25rem;
}
.stat-value[data-v-4ab594a6] {
  font-size: 1rem;
  font-weight: 600;
  color: var(--text-primary);
}
.difficulty-distribution[data-v-4ab594a6] {
  margin-top: 1.5rem;
}
.distribution-title[data-v-4ab594a6] {
  font-size: 1rem;
  font-weight: 600;
  color: var(--text-primary);
  margin-bottom: 1rem;
}
.difficulty-bars[data-v-4ab594a6] {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}
.difficulty-bar[data-v-4ab594a6] {
  display: flex;
  align-items: center;
  gap: 1rem;
}
.difficulty-info[data-v-4ab594a6] {
  min-width: 180px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.difficulty-name[data-v-4ab594a6] {
  font-size: 0.875rem;
  color: var(--text-secondary);
}
.difficulty-count[data-v-4ab594a6] {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--text-primary);
}
.difficulty-progress[data-v-4ab594a6] {
  flex: 1;
  height: 8px;
  background: var(--border);
  border-radius: 4px;
  overflow: hidden;
}
.progress-fill[data-v-4ab594a6] {
  height: 100%;
  border-radius: 4px;
  transition: width 1s ease;
}
.progress-fill.no-difficulty[data-v-4ab594a6] {
  background: linear-gradient(90deg, #10B981, #34D399);
}
.progress-fill.some-difficulty[data-v-4ab594a6] {
  background: linear-gradient(90deg, #F59E0B, #FBBF24);
}
.progress-fill.much-difficulty[data-v-4ab594a6] {
  background: linear-gradient(90deg, #EF4444, #F87171);
}
.progress-fill.unable[data-v-4ab594a6] {
  background: linear-gradient(90deg, #7C2D12, #DC2626);
}

/* Temporal Statistics Section */
.temporal-statistics-section[data-v-4ab594a6] {
  margin: 3rem 0;
}
.temporal-grid[data-v-4ab594a6] {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(400px, 1fr));
  gap: 2rem;
}
.temporal-card[data-v-4ab594a6] {
  background: var(--surface);
  border-radius: 16px;
  padding: 1.5rem;
  border: 1px solid var(--border);
  box-shadow: 0 16px 32px rgba(15, 23, 42, 0.08);
}
.temporal-title[data-v-4ab594a6] {
  font-size: 1.25rem;
  font-weight: 600;
  color: var(--text-primary);
  margin-bottom: 1.5rem;
  text-align: center;
}
.chart-container[data-v-4ab594a6] {
  position: relative;
  height: 250px;
}
.weekday-stats[data-v-4ab594a6] {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.weekday-item[data-v-4ab594a6] {
  display: flex;
  align-items: center;
  gap: 1rem;
}
.weekday-name[data-v-4ab594a6] {
  min-width: 40px;
  font-weight: 600;
  color: var(--text-primary);
}
.weekday-bar[data-v-4ab594a6] {
  flex: 1;
  height: 12px;
  background: var(--border);
  border-radius: 6px;
  overflow: hidden;
}
.weekday-progress[data-v-4ab594a6] {
  height: 100%;
  background: linear-gradient(90deg, #1d4ed8, #2563eb);
  border-radius: 6px;
  transition: width 1s ease;
}
.weekday-count[data-v-4ab594a6] {
  min-width: 30px;
  text-align: right;
  font-weight: 600;
  color: var(--text-primary);
}

/* Animations */
@keyframes spin-4ab594a6 {
0% { transform: rotate(0deg);
}
100% { transform: rotate(360deg);
}
}
@keyframes fadeIn-4ab594a6 {
from {
    opacity: 0;
    transform: translateY(20px);
}
to {
    opacity: 1;
    transform: translateY(0);
}
}

/* Responsive */
@media (max-width: 768px) {
.header-content[data-v-4ab594a6] {
    flex-direction: column;
    align-items: flex-start;
    gap: 1rem;
}
.header-actions[data-v-4ab594a6] {
    width: 100%;
    justify-content: space-between;
    gap: 1rem;
}
.action-buttons[data-v-4ab594a6] {
    flex-direction: column;
    gap: 0.75rem;
    width: 100%;
}
.btn-export[data-v-4ab594a6],
  .btn-back[data-v-4ab594a6] {
    width: 100%;
    justify-content: center;
    padding: 0.625rem 1rem;
    font-size: 0.85rem;
}
.title[data-v-4ab594a6] {
    font-size: 1.5rem;
}
.summary-panel[data-v-4ab594a6] {
    grid-template-columns: 1fr;
    gap: 1rem;
}
.haq-levels-grid[data-v-4ab594a6] {
    grid-template-columns: 1fr;
    gap: 1rem;
}
.blocks-grid[data-v-4ab594a6] {
    grid-template-columns: 1fr;
    gap: 1.5rem;
}
.temporal-grid[data-v-4ab594a6] {
    grid-template-columns: 1fr;
    gap: 1.5rem;
}
}
@media (max-width: 480px) {
.main-content[data-v-4ab594a6] {
    padding: 1.5rem 0.75rem;
}
.title[data-v-4ab594a6] {
    font-size: 1.25rem;
}
.subtitle[data-v-4ab594a6] {
    font-size: 0.9rem;
}
}


.statistics-page[data-v-6014aa47] {
  --accent: #2563eb;
  --accent-hover: #1d4ed8;
  --accent-soft: #eff6ff;
  --surface: #ffffff;
  --surface-muted: #f8fafc;
  --border: #e2e8f0;
  --border-strong: #cbd5e1;
  --text-primary: #0f172a;
  --text-secondary: #475569;

  min-height: 100vh;
  background: linear-gradient(180deg, #f8fafc 0%, #f1f5f9 100%);
  color: var(--text-primary);
}

/* Header */
.header[data-v-6014aa47] {
  background: linear-gradient(90deg, #1e3a8a 0%, #1e40af 45%, #2563eb 100%);
  color: #f8fafc;
  padding: 1rem 0;
  border-bottom: 1px solid rgba(255, 255, 255, 0.2);
  box-shadow: 0 8px 28px rgba(30, 64, 175, 0.22);
}
.header-content[data-v-6014aa47] {
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0 1rem;
}
.title-section[data-v-6014aa47] {
  flex: 1;
}
.title[data-v-6014aa47] {
  font-size: 1.5rem;
  font-weight: 700;
  letter-spacing: 0.25px;
  margin-bottom: 0.35rem;
}
.subtitle[data-v-6014aa47] {
  font-size: 0.9rem;
  opacity: 0.88;
}
.header-actions[data-v-6014aa47] {
  display: flex;
  align-items: center;
  gap: 1.5rem;
}
.datetime-widget[data-v-6014aa47] {
  text-align: center;
  padding: 0.5rem 1rem;
  background: rgba(255, 255, 255, 0.1);
  border-radius: 8px;
  border: 1px solid rgba(255, 255, 255, 0.2);
}
.current-time[data-v-6014aa47] {
  font-size: 1.2rem;
  font-weight: 700;
  font-family: 'Courier New', monospace;
  margin-bottom: 0.25rem;
}
.current-date[data-v-6014aa47] {
  font-size: 0.75rem;
  opacity: 0.9;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.action-buttons[data-v-6014aa47] {
  display: flex;
  align-items: center;
  gap: 1rem;
}
.btn-export[data-v-6014aa47],
.btn-back[data-v-6014aa47] {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.75rem 1.25rem;
  background: rgba(255, 255, 255, 0.1);
  border: 1px solid rgba(255, 255, 255, 0.2);
  color: white;
  border-radius: 8px;
  cursor: pointer;
  transition: all 0.2s ease;
  font-size: 0.9rem;
  font-weight: 600;
}
.btn-export[data-v-6014aa47]:hover,
.btn-back[data-v-6014aa47]:hover {
  background: rgba(255, 255, 255, 0.2);
  transform: translateY(-1px);
}
.btn-export[data-v-6014aa47]:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}
.btn-export[data-v-6014aa47]:disabled:hover {
  background: rgba(255, 255, 255, 0.1);
}

/* Main Content */
.main-content[data-v-6014aa47] {
  max-width: 1200px;
  margin: 0 auto;
  padding: 2.75rem 1rem;
}

/* Loading */
.loading-container[data-v-6014aa47] {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 4rem 2rem;
}
.loading-spinner[data-v-6014aa47] {
  width: 48px;
  height: 48px;
  border: 4px solid var(--border);
  border-top: 4px solid var(--accent);
  border-radius: 50%;
  animation: spin-6014aa47 1s linear infinite;
  margin-bottom: 1rem;
}
.loading-text[data-v-6014aa47] {
  font-size: 1.1rem;
  color: var(--text-secondary);
  font-weight: 500;
}

/* Error */
.error-container[data-v-6014aa47] {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 4rem 2rem;
  text-align: center;
}
.error-icon[data-v-6014aa47] {
  font-size: 3rem;
  margin-bottom: 1rem;
}
.error-message[data-v-6014aa47] {
  font-size: 1.1rem;
  color: #dc2626;
  margin-bottom: 2rem;
  max-width: 500px;
}
.btn-retry[data-v-6014aa47] {
  padding: 0.75rem 1.5rem;
  background: var(--accent);
  color: white;
  border: none;
  border-radius: 8px;
  font-size: 0.9rem;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s ease;
}
.btn-retry[data-v-6014aa47]:hover {
  background: var(--accent-hover);
  transform: translateY(-1px);
}

/* Statistics Container */
.statistics-container[data-v-6014aa47] {
  animation: fadeIn-6014aa47 0.5s ease-out;
}

/* Фильтры */
.filters-panel[data-v-6014aa47] {
  display: flex;
  gap: 1.5rem;
  margin-bottom: 2.5rem;
  padding: 1.5rem;
  background: var(--surface);
  border-radius: 16px;
  border: 1px solid var(--border);
  box-shadow: 0 16px 40px rgba(15, 23, 42, 0.08);
}
.filter-group[data-v-6014aa47] {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  min-width: 200px;
}
.filter-group label[data-v-6014aa47] {
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--text-secondary);
}
.filter-group select[data-v-6014aa47] {
  padding: 0.75rem;
  border: 1px solid var(--border-strong);
  border-radius: 8px;
  background-color: var(--surface);
  color: var(--text-primary);
  font-size: 0.95rem;
  outline: none;
  transition: all 0.2s ease;
  cursor: pointer;
}
.filter-group select[data-v-6014aa47]:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.12);
  background-color: var(--surface);
}

/* Summary Panel */
.summary-panel[data-v-6014aa47] {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: 1.5rem;
  margin-bottom: 2.5rem;
}
.summary-card[data-v-6014aa47] {
  background: var(--surface);
  border-radius: 16px;
  padding: 1.5rem;
  border: 1px solid var(--border);
  box-shadow: 0 16px 32px rgba(15, 23, 42, 0.08);
  display: flex;
  align-items: center;
  gap: 1rem;
  transition: all 0.2s ease;
}
.summary-card[data-v-6014aa47]:hover {
  transform: translateY(-2px);
  box-shadow: 0 16px 32px rgba(37, 99, 235, 0.16);
}
.summary-icon[data-v-6014aa47] {
  font-size: 2.5rem;
  width: 60px;
  height: 60px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 12px;
  background: var(--surface-muted);
}
.total-patients .summary-icon[data-v-6014aa47] {
  background: #dbeafe;
}
.average-age .summary-icon[data-v-6014aa47] {
  background: #dcfce7;
}
.gender-modern .summary-icon[data-v-6014aa47] {
  background: #f3f4f6;
}
.summary-content[data-v-6014aa47] {
  flex: 1;
}
.summary-value[data-v-6014aa47] {
  font-size: 2rem;
  font-weight: 700;
  color: var(--text-primary);
  margin-bottom: 0.25rem;
}

/* Стили для современной гендерной карточки */
.gender-modern[data-v-6014aa47] {
  min-width: 280px;
}
.gender-modern .summary-label[data-v-6014aa47] {
  margin-bottom: 1rem;
  font-weight: 600;
  color: var(--text-primary);
}
.gender-stats[data-v-6014aa47] {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.gender-item[data-v-6014aa47] {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.gender-info[data-v-6014aa47] {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.gender-icon[data-v-6014aa47] {
  font-size: 1.2rem;
}
.gender-count[data-v-6014aa47] {
  font-size: 1.5rem;
  font-weight: 700;
  min-width: 60px;
}
.gender-label[data-v-6014aa47] {
  font-size: 0.875rem;
  color: var(--text-secondary);
  flex: 1;
}
.gender-percent[data-v-6014aa47] {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--text-primary);
  margin-left: auto;
}
.gender-bar[data-v-6014aa47] {
  height: 8px;
  background: var(--border);
  border-radius: 4px;
  overflow: hidden;
}
.gender-progress[data-v-6014aa47] {
  height: 100%;
  border-radius: 4px;
  transition: width 0.8s ease;
}
.gender-progress.men[data-v-6014aa47] {
  background: linear-gradient(90deg, #3B82F6, #60A5FA);
}
.gender-progress.women[data-v-6014aa47] {
  background: linear-gradient(90deg, #EC4899, #F472B6);
}
.gender-item:first-child .gender-count[data-v-6014aa47] {
  color: #3B82F6;
}
.gender-item:last-child .gender-count[data-v-6014aa47] {
  color: #EC4899;
}
.summary-label[data-v-6014aa47] {
  font-size: 0.9rem;
  color: var(--text-secondary);
  font-weight: 500;
}

/* Charts Grid */
.charts-grid[data-v-6014aa47] {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(400px, 1fr));
  gap: 2rem;
}
.chart-card[data-v-6014aa47] {
  background: var(--surface);
  border-radius: 16px;
  padding: 1.5rem;
  border: 1px solid var(--border);
  box-shadow: 0 16px 32px rgba(15, 23, 42, 0.08);
  transition: all 0.2s ease;
}
.chart-card[data-v-6014aa47]:hover {
  transform: translateY(-2px);
  box-shadow: 0 16px 32px rgba(37, 99, 235, 0.16);
}
.chart-card.large[data-v-6014aa47] {
  grid-column: 1 / -1;
}
.chart-header[data-v-6014aa47] {
  margin-bottom: 1.5rem;
}
.chart-title[data-v-6014aa47] {
  font-size: 1.25rem;
  font-weight: 600;
  color: var(--text-primary);
  margin: 0;
  display: flex;
  align-items: center;
  gap: 0.75rem;
}
.chart-icon[data-v-6014aa47] {
  font-size: 1.5rem;
}
.chart-container[data-v-6014aa47] {
  position: relative;
  height: 300px;
}
.chart-card.large .chart-container[data-v-6014aa47] {
  height: 400px;
}

/* Animations */
@keyframes spin-6014aa47 {
0% { transform: rotate(0deg);
}
100% { transform: rotate(360deg);
}
}
@keyframes fadeIn-6014aa47 {
from {
    opacity: 0;
    transform: translateY(20px);
}
to {
    opacity: 1;
    transform: translateY(0);
}
}

/* Responsive */
@media (max-width: 768px) {
.header-content[data-v-6014aa47] {
    flex-direction: column;
    align-items: flex-start;
    gap: 1rem;
}
.header-actions[data-v-6014aa47] {
    width: 100%;
    justify-content: space-between;
    gap: 1rem;
}
.action-buttons[data-v-6014aa47] {
    flex-direction: column;
    gap: 0.75rem;
    width: 100%;
}
.btn-export[data-v-6014aa47],
  .btn-back[data-v-6014aa47] {
    width: 100%;
    justify-content: center;
    padding: 0.625rem 1rem;
    font-size: 0.85rem;
}
.title[data-v-6014aa47] {
    font-size: 1.5rem;
}
.charts-grid[data-v-6014aa47] {
    grid-template-columns: 1fr;
    gap: 1.5rem;
}
.chart-card[data-v-6014aa47] {
    padding: 1rem;
}
.chart-container[data-v-6014aa47] {
    height: 250px;
}
.chart-card.large .chart-container[data-v-6014aa47] {
    height: 300px;
}
.summary-panel[data-v-6014aa47] {
    grid-template-columns: 1fr;
    gap: 1rem;
}
.summary-card[data-v-6014aa47] {
    padding: 1rem;
}
.summary-icon[data-v-6014aa47] {
    font-size: 2rem;
    width: 50px;
    height: 50px;
}
.summary-value[data-v-6014aa47] {
    font-size: 1.5rem;
}
}
@media (max-width: 480px) {
.main-content[data-v-6014aa47] {
    padding: 1.5rem 0.75rem;
}
.title[data-v-6014aa47] {
    font-size: 1.25rem;
}
.subtitle[data-v-6014aa47] {
    font-size: 0.9rem;
}
}


.statistics-page[data-v-346c0782] {
  --accent: #2563eb;
  --accent-hover: #1d4ed8;
  --accent-soft: #eff6ff;
  --surface: #ffffff;
  --surface-muted: #f8fafc;
  --border: #e2e8f0;
  --border-strong: #cbd5e1;
  --text-primary: #0f172a;
  --text-secondary: #475569;

  min-height: 100vh;
  background: linear-gradient(180deg, #f8fafc 0%, #f1f5f9 100%);
  color: var(--text-primary);
}

/* Header */
.header[data-v-346c0782] {
  background: linear-gradient(90deg, #1e3a8a 0%, #1e40af 45%, #2563eb 100%);
  color: #f8fafc;
  padding: 1rem 0;
  border-bottom: 1px solid rgba(255, 255, 255, 0.2);
  box-shadow: 0 8px 28px rgba(30, 64, 175, 0.22);
}
.header-content[data-v-346c0782] {
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0 1rem;
}
.title-section[data-v-346c0782] {
  flex: 1;
}
.title[data-v-346c0782] {
  font-size: 1.5rem;
  font-weight: 700;
  letter-spacing: 0.25px;
  margin-bottom: 0.35rem;
}
.subtitle[data-v-346c0782] {
  font-size: 0.9rem;
  opacity: 0.88;
}
.header-actions[data-v-346c0782] {
  display: flex;
  align-items: center;
  gap: 1.5rem;
}
.datetime-widget[data-v-346c0782] {
  text-align: center;
  padding: 0.5rem 1rem;
  background: rgba(255, 255, 255, 0.1);
  border-radius: 8px;
  border: 1px solid rgba(255, 255, 255, 0.2);
}
.current-time[data-v-346c0782] {
  font-size: 1.2rem;
  font-weight: 700;
  font-family: 'Courier New', monospace;
  margin-bottom: 0.25rem;
}
.current-date[data-v-346c0782] {
  font-size: 0.75rem;
  opacity: 0.9;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.action-buttons[data-v-346c0782] {
  display: flex;
  align-items: center;
  gap: 1rem;
}
.btn-export[data-v-346c0782],
.btn-back[data-v-346c0782] {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.75rem 1.25rem;
  background: rgba(255, 255, 255, 0.1);
  border: 1px solid rgba(255, 255, 255, 0.2);
  color: white;
  border-radius: 8px;
  cursor: pointer;
  transition: all 0.2s ease;
  font-size: 0.9rem;
  font-weight: 600;
}
.btn-export[data-v-346c0782]:hover,
.btn-back[data-v-346c0782]:hover {
  background: rgba(255, 255, 255, 0.2);
  transform: translateY(-1px);
}
.btn-export[data-v-346c0782]:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}
.btn-export[data-v-346c0782]:disabled:hover {
  background: rgba(255, 255, 255, 0.1);
}

/* Main Content */
.main-content[data-v-346c0782] {
  max-width: 1200px;
  margin: 0 auto;
  padding: 2.75rem 1rem;
}

/* Loading */
.loading-container[data-v-346c0782] {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 4rem 2rem;
}
.loading-spinner[data-v-346c0782] {
  width: 48px;
  height: 48px;
  border: 4px solid var(--border);
  border-top: 4px solid var(--accent);
  border-radius: 50%;
  animation: spin-346c0782 1s linear infinite;
  margin-bottom: 1rem;
}
.loading-text[data-v-346c0782] {
  font-size: 1.1rem;
  color: var(--text-secondary);
  font-weight: 500;
}

/* Error */
.error-container[data-v-346c0782] {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 4rem 2rem;
  text-align: center;
}
.error-icon[data-v-346c0782] {
  font-size: 3rem;
  margin-bottom: 1rem;
}
.error-message[data-v-346c0782] {
  font-size: 1.1rem;
  color: #dc2626;
  margin-bottom: 2rem;
  max-width: 500px;
}
.btn-retry[data-v-346c0782] {
  padding: 0.75rem 1.5rem;
  background: var(--accent);
  color: white;
  border: none;
  border-radius: 8px;
  font-size: 0.9rem;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s ease;
}
.btn-retry[data-v-346c0782]:hover {
  background: var(--accent-hover);
  transform: translateY(-1px);
}

/* Statistics Container */
.statistics-container[data-v-346c0782] {
  animation: fadeIn-346c0782 0.5s ease-out;
}

/* Фильтры */
.filters-panel[data-v-346c0782] {
  display: flex;
  gap: 1.5rem;
  margin-bottom: 2.5rem;
  padding: 1.5rem;
  background: var(--surface);
  border-radius: 16px;
  border: 1px solid var(--border);
  box-shadow: 0 16px 40px rgba(15, 23, 42, 0.08);
}
.filter-group[data-v-346c0782] {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  min-width: 200px;
}
.filter-group label[data-v-346c0782] {
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--text-secondary);
}
.filter-group select[data-v-346c0782] {
  padding: 0.75rem;
  border: 1px solid var(--border-strong);
  border-radius: 8px;
  background-color: var(--surface);
  color: var(--text-primary);
  font-size: 0.95rem;
  outline: none;
  transition: all 0.2s ease;
  cursor: pointer;
}
.filter-group select[data-v-346c0782]:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.12);
  background-color: var(--surface);
}

/* Summary Panel */
.summary-panel[data-v-346c0782] {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: 1.5rem;
  margin-bottom: 2.5rem;
}
.summary-card[data-v-346c0782] {
  background: var(--surface);
  border-radius: 16px;
  padding: 1.5rem;
  border: 1px solid var(--border);
  box-shadow: 0 16px 32px rgba(15, 23, 42, 0.08);
  display: flex;
  align-items: center;
  gap: 1rem;
  transition: all 0.2s ease;
}
.summary-card[data-v-346c0782]:hover {
  transform: translateY(-2px);
  box-shadow: 0 16px 32px rgba(37, 99, 235, 0.16);
}
.summary-icon[data-v-346c0782] {
  font-size: 2.5rem;
  width: 60px;
  height: 60px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 12px;
  background: var(--surface-muted);
}
.total-patients .summary-icon[data-v-346c0782] {
  background: #dbeafe;
}
.average-age .summary-icon[data-v-346c0782] {
  background: #dcfce7;
}
.gender-modern .summary-icon[data-v-346c0782] {
  background: #f3f4f6;
}
.summary-content[data-v-346c0782] {
  flex: 1;
}
.summary-value[data-v-346c0782] {
  font-size: 2rem;
  font-weight: 700;
  color: var(--text-primary);
  margin-bottom: 0.25rem;
}

/* Стили для современной гендерной карточки */
.gender-modern[data-v-346c0782] {
  min-width: 280px;
}
.gender-modern .summary-label[data-v-346c0782] {
  margin-bottom: 1rem;
  font-weight: 600;
  color: var(--text-primary);
}
.gender-stats[data-v-346c0782] {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.gender-item[data-v-346c0782] {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.gender-info[data-v-346c0782] {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.gender-icon[data-v-346c0782] {
  font-size: 1.2rem;
}
.gender-count[data-v-346c0782] {
  font-size: 1.5rem;
  font-weight: 700;
  min-width: 60px;
}
.gender-label[data-v-346c0782] {
  font-size: 0.875rem;
  color: var(--text-secondary);
  flex: 1;
}
.gender-percent[data-v-346c0782] {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--text-primary);
  margin-left: auto;
}
.gender-bar[data-v-346c0782] {
  height: 8px;
  background: var(--border);
  border-radius: 4px;
  overflow: hidden;
}
.gender-progress[data-v-346c0782] {
  height: 100%;
  border-radius: 4px;
  transition: width 0.8s ease;
}
.gender-progress.men[data-v-346c0782] {
  background: linear-gradient(90deg, #3B82F6, #60A5FA);
}
.gender-progress.women[data-v-346c0782] {
  background: linear-gradient(90deg, #EC4899, #F472B6);
}
.gender-item:first-child .gender-count[data-v-346c0782] {
  color: #3B82F6;
}
.gender-item:last-child .gender-count[data-v-346c0782] {
  color: #EC4899;
}
.summary-label[data-v-346c0782] {
  font-size: 0.9rem;
  color: var(--text-secondary);
  font-weight: 500;
}

/* Charts Grid */
.charts-grid[data-v-346c0782] {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(400px, 1fr));
  gap: 2rem;
}
.chart-card[data-v-346c0782] {
  background: var(--surface);
  border-radius: 16px;
  padding: 1.5rem;
  border: 1px solid var(--border);
  box-shadow: 0 16px 32px rgba(15, 23, 42, 0.08);
  transition: all 0.2s ease;
}
.chart-card[data-v-346c0782]:hover {
  transform: translateY(-2px);
  box-shadow: 0 16px 32px rgba(37, 99, 235, 0.16);
}
.chart-card.large[data-v-346c0782] {
  grid-column: 1 / -1;
}
.chart-header[data-v-346c0782] {
  margin-bottom: 1.5rem;
}
.chart-title[data-v-346c0782] {
  font-size: 1.25rem;
  font-weight: 600;
  color: var(--text-primary);
  margin: 0;
  display: flex;
  align-items: center;
  gap: 0.75rem;
}
.chart-icon[data-v-346c0782] {
  font-size: 1.5rem;
}
.chart-container[data-v-346c0782] {
  position: relative;
  height: 300px;
}
.chart-card.large .chart-container[data-v-346c0782] {
  height: 400px;
}

/* Animations */
@keyframes spin-346c0782 {
0% { transform: rotate(0deg);
}
100% { transform: rotate(360deg);
}
}
@keyframes fadeIn-346c0782 {
from {
    opacity: 0;
    transform: translateY(20px);
}
to {
    opacity: 1;
    transform: translateY(0);
}
}

/* Responsive */
@media (max-width: 768px) {
.header-content[data-v-346c0782] {
    flex-direction: column;
    align-items: flex-start;
    gap: 1rem;
}
.header-actions[data-v-346c0782] {
    width: 100%;
    justify-content: space-between;
    gap: 1rem;
}
.action-buttons[data-v-346c0782] {
    flex-direction: column;
    gap: 0.75rem;
    width: 100%;
}
.btn-export[data-v-346c0782],
  .btn-back[data-v-346c0782] {
    width: 100%;
    justify-content: center;
    padding: 0.625rem 1rem;
    font-size: 0.85rem;
}
.title[data-v-346c0782] {
    font-size: 1.5rem;
}
.charts-grid[data-v-346c0782] {
    grid-template-columns: 1fr;
    gap: 1.5rem;
}
.chart-card[data-v-346c0782] {
    padding: 1rem;
}
.chart-container[data-v-346c0782] {
    height: 250px;
}
.chart-card.large .chart-container[data-v-346c0782] {
    height: 300px;
}
.summary-panel[data-v-346c0782] {
    grid-template-columns: 1fr;
    gap: 1rem;
}
.summary-card[data-v-346c0782] {
    padding: 1rem;
}
.summary-icon[data-v-346c0782] {
    font-size: 2rem;
    width: 50px;
    height: 50px;
}
.summary-value[data-v-346c0782] {
    font-size: 1.5rem;
}
}
@media (max-width: 480px) {
.main-content[data-v-346c0782] {
    padding: 1.5rem 0.75rem;
}
.title[data-v-346c0782] {
    font-size: 1.25rem;
}
.subtitle[data-v-346c0782] {
    font-size: 0.9rem;
}
}

/* sass-plugin-1:/Users/maronato/Developer/vue-toastification/src/scss/index.scss */
.Vue-Toastification__container {
  z-index: 9999;
  position: fixed;
  padding: 4px;
  width: 600px;
  box-sizing: border-box;
  display: flex;
  min-height: 100%;
  color: #fff;
  flex-direction: column;
  pointer-events: none;
}
@media only screen and (min-width : 600px) {
  .Vue-Toastification__container.top-left,
  .Vue-Toastification__container.top-right,
  .Vue-Toastification__container.top-center {
    top: 1em;
  }
  .Vue-Toastification__container.bottom-left,
  .Vue-Toastification__container.bottom-right,
  .Vue-Toastification__container.bottom-center {
    bottom: 1em;
    flex-direction: column-reverse;
  }
  .Vue-Toastification__container.top-left,
  .Vue-Toastification__container.bottom-left {
    left: 1em;
  }
  .Vue-Toastification__container.top-left .Vue-Toastification__toast,
  .Vue-Toastification__container.bottom-left .Vue-Toastification__toast {
    margin-right: auto;
  }
  @supports not (-moz-appearance: none) {
    .Vue-Toastification__container.top-left .Vue-Toastification__toast--rtl,
    .Vue-Toastification__container.bottom-left .Vue-Toastification__toast--rtl {
      margin-right: unset;
      margin-left: auto;
    }
  }
  .Vue-Toastification__container.top-right,
  .Vue-Toastification__container.bottom-right {
    right: 1em;
  }
  .Vue-Toastification__container.top-right .Vue-Toastification__toast,
  .Vue-Toastification__container.bottom-right .Vue-Toastification__toast {
    margin-left: auto;
  }
  @supports not (-moz-appearance: none) {
    .Vue-Toastification__container.top-right .Vue-Toastification__toast--rtl,
    .Vue-Toastification__container.bottom-right .Vue-Toastification__toast--rtl {
      margin-left: unset;
      margin-right: auto;
    }
  }
  .Vue-Toastification__container.top-center,
  .Vue-Toastification__container.bottom-center {
    left: 50%;
    margin-left: -300px;
  }
  .Vue-Toastification__container.top-center .Vue-Toastification__toast,
  .Vue-Toastification__container.bottom-center .Vue-Toastification__toast {
    margin-left: auto;
    margin-right: auto;
  }
}
@media only screen and (max-width : 600px) {
  .Vue-Toastification__container {
    width: 100vw;
    padding: 0;
    left: 0;
    margin: 0;
  }
  .Vue-Toastification__container .Vue-Toastification__toast {
    width: 100%;
  }
  .Vue-Toastification__container.top-left,
  .Vue-Toastification__container.top-right,
  .Vue-Toastification__container.top-center {
    top: 0;
  }
  .Vue-Toastification__container.bottom-left,
  .Vue-Toastification__container.bottom-right,
  .Vue-Toastification__container.bottom-center {
    bottom: 0;
    flex-direction: column-reverse;
  }
}
.Vue-Toastification__toast {
  display: inline-flex;
  position: relative;
  max-height: 800px;
  min-height: 64px;
  box-sizing: border-box;
  margin-bottom: 1rem;
  padding: 22px 24px;
  border-radius: 8px;
  box-shadow: 0 1px 10px 0 rgba(0, 0, 0, 0.1), 0 2px 15px 0 rgba(0, 0, 0, 0.05);
  justify-content: space-between;
  font-family:
    "Lato",
    Helvetica,
    "Roboto",
    Arial,
    sans-serif;
  max-width: 600px;
  min-width: 326px;
  pointer-events: auto;
  overflow: hidden;
  transform: translateZ(0);
  direction: ltr;
}
.Vue-Toastification__toast--rtl {
  direction: rtl;
}
.Vue-Toastification__toast--default {
  background-color: #1976d2;
  color: #fff;
}
.Vue-Toastification__toast--info {
  background-color: #2196f3;
  color: #fff;
}
.Vue-Toastification__toast--success {
  background-color: #4caf50;
  color: #fff;
}
.Vue-Toastification__toast--error {
  background-color: #ff5252;
  color: #fff;
}
.Vue-Toastification__toast--warning {
  background-color: #ffc107;
  color: #fff;
}
@media only screen and (max-width : 600px) {
  .Vue-Toastification__toast {
    border-radius: 0px;
    margin-bottom: 0.5rem;
  }
}
.Vue-Toastification__toast-body {
  flex: 1;
  line-height: 24px;
  font-size: 16px;
  word-break: break-word;
  white-space: pre-wrap;
}
.Vue-Toastification__toast-component-body {
  flex: 1;
}
.Vue-Toastification__toast.disable-transition {
  animation: none !important;
}
.Vue-Toastification__close-button {
  font-weight: bold;
  font-size: 24px;
  line-height: 24px;
  background: transparent;
  outline: none;
  border: none;
  padding: 0;
  padding-left: 10px;
  cursor: pointer;
  transition: 0.3s ease;
  align-items: center;
  color: #fff;
  opacity: 0.3;
  transition: visibility 0s, opacity 0.2s linear;
}
.Vue-Toastification__close-button:hover,
.Vue-Toastification__close-button:focus {
  opacity: 1;
}
.Vue-Toastification__toast:not(:hover) .Vue-Toastification__close-button.show-on-hover {
  opacity: 0;
}
.Vue-Toastification__toast--rtl .Vue-Toastification__close-button {
  padding-left: unset;
  padding-right: 10px;
}
@keyframes scale-x-frames {
  0% {
    transform: scaleX(1);
  }
  100% {
    transform: scaleX(0);
  }
}
.Vue-Toastification__progress-bar {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 5px;
  z-index: 10000;
  background-color: rgba(255, 255, 255, 0.7);
  transform-origin: left;
  animation: scale-x-frames linear 1 forwards;
}
.Vue-Toastification__toast--rtl .Vue-Toastification__progress-bar {
  right: 0;
  left: unset;
  transform-origin: right;
}
.Vue-Toastification__icon {
  margin: auto 18px auto 0px;
  background: transparent;
  outline: none;
  border: none;
  padding: 0;
  transition: 0.3s ease;
  align-items: center;
  width: 20px;
  height: 100%;
}
.Vue-Toastification__toast--rtl .Vue-Toastification__icon {
  margin: auto 0px auto 18px;
}
@keyframes bounceInRight {
  from, 60%, 75%, 90%, to {
    animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
  }
  from {
    opacity: 0;
    transform: translate3d(3000px, 0, 0);
  }
  60% {
    opacity: 1;
    transform: translate3d(-25px, 0, 0);
  }
  75% {
    transform: translate3d(10px, 0, 0);
  }
  90% {
    transform: translate3d(-5px, 0, 0);
  }
  to {
    transform: none;
  }
}
@keyframes bounceOutRight {
  40% {
    opacity: 1;
    transform: translate3d(-20px, 0, 0);
  }
  to {
    opacity: 0;
    transform: translate3d(1000px, 0, 0);
  }
}
@keyframes bounceInLeft {
  from, 60%, 75%, 90%, to {
    animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
  }
  0% {
    opacity: 0;
    transform: translate3d(-3000px, 0, 0);
  }
  60% {
    opacity: 1;
    transform: translate3d(25px, 0, 0);
  }
  75% {
    transform: translate3d(-10px, 0, 0);
  }
  90% {
    transform: translate3d(5px, 0, 0);
  }
  to {
    transform: none;
  }
}
@keyframes bounceOutLeft {
  20% {
    opacity: 1;
    transform: translate3d(20px, 0, 0);
  }
  to {
    opacity: 0;
    transform: translate3d(-2000px, 0, 0);
  }
}
@keyframes bounceInUp {
  from, 60%, 75%, 90%, to {
    animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
  }
  from {
    opacity: 0;
    transform: translate3d(0, 3000px, 0);
  }
  60% {
    opacity: 1;
    transform: translate3d(0, -20px, 0);
  }
  75% {
    transform: translate3d(0, 10px, 0);
  }
  90% {
    transform: translate3d(0, -5px, 0);
  }
  to {
    transform: translate3d(0, 0, 0);
  }
}
@keyframes bounceOutUp {
  20% {
    transform: translate3d(0, -10px, 0);
  }
  40%, 45% {
    opacity: 1;
    transform: translate3d(0, 20px, 0);
  }
  to {
    opacity: 0;
    transform: translate3d(0, -2000px, 0);
  }
}
@keyframes bounceInDown {
  from, 60%, 75%, 90%, to {
    animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
  }
  0% {
    opacity: 0;
    transform: translate3d(0, -3000px, 0);
  }
  60% {
    opacity: 1;
    transform: translate3d(0, 25px, 0);
  }
  75% {
    transform: translate3d(0, -10px, 0);
  }
  90% {
    transform: translate3d(0, 5px, 0);
  }
  to {
    transform: none;
  }
}
@keyframes bounceOutDown {
  20% {
    transform: translate3d(0, 10px, 0);
  }
  40%, 45% {
    opacity: 1;
    transform: translate3d(0, -20px, 0);
  }
  to {
    opacity: 0;
    transform: translate3d(0, 2000px, 0);
  }
}
.Vue-Toastification__bounce-enter-active.top-left,
.Vue-Toastification__bounce-enter-active.bottom-left {
  animation-name: bounceInLeft;
}
.Vue-Toastification__bounce-enter-active.top-right,
.Vue-Toastification__bounce-enter-active.bottom-right {
  animation-name: bounceInRight;
}
.Vue-Toastification__bounce-enter-active.top-center {
  animation-name: bounceInDown;
}
.Vue-Toastification__bounce-enter-active.bottom-center {
  animation-name: bounceInUp;
}
.Vue-Toastification__bounce-leave-active:not(.disable-transition).top-left,
.Vue-Toastification__bounce-leave-active:not(.disable-transition).bottom-left {
  animation-name: bounceOutLeft;
}
.Vue-Toastification__bounce-leave-active:not(.disable-transition).top-right,
.Vue-Toastification__bounce-leave-active:not(.disable-transition).bottom-right {
  animation-name: bounceOutRight;
}
.Vue-Toastification__bounce-leave-active:not(.disable-transition).top-center {
  animation-name: bounceOutUp;
}
.Vue-Toastification__bounce-leave-active:not(.disable-transition).bottom-center {
  animation-name: bounceOutDown;
}
.Vue-Toastification__bounce-leave-active,
.Vue-Toastification__bounce-enter-active {
  animation-duration: 750ms;
  animation-fill-mode: both;
}
.Vue-Toastification__bounce-move {
  transition-timing-function: ease-in-out;
  transition-property: all;
  transition-duration: 400ms;
}
@keyframes fadeOutTop {
  0% {
    transform: translateY(0);
    opacity: 1;
  }
  100% {
    transform: translateY(-50px);
    opacity: 0;
  }
}
@keyframes fadeOutLeft {
  0% {
    transform: translateX(0);
    opacity: 1;
  }
  100% {
    transform: translateX(-50px);
    opacity: 0;
  }
}
@keyframes fadeOutBottom {
  0% {
    transform: translateY(0);
    opacity: 1;
  }
  100% {
    transform: translateY(50px);
    opacity: 0;
  }
}
@keyframes fadeOutRight {
  0% {
    transform: translateX(0);
    opacity: 1;
  }
  100% {
    transform: translateX(50px);
    opacity: 0;
  }
}
@keyframes fadeInLeft {
  0% {
    transform: translateX(-50px);
    opacity: 0;
  }
  100% {
    transform: translateX(0);
    opacity: 1;
  }
}
@keyframes fadeInRight {
  0% {
    transform: translateX(50px);
    opacity: 0;
  }
  100% {
    transform: translateX(0);
    opacity: 1;
  }
}
@keyframes fadeInTop {
  0% {
    transform: translateY(-50px);
    opacity: 0;
  }
  100% {
    transform: translateY(0);
    opacity: 1;
  }
}
@keyframes fadeInBottom {
  0% {
    transform: translateY(50px);
    opacity: 0;
  }
  100% {
    transform: translateY(0);
    opacity: 1;
  }
}
.Vue-Toastification__fade-enter-active.top-left,
.Vue-Toastification__fade-enter-active.bottom-left {
  animation-name: fadeInLeft;
}
.Vue-Toastification__fade-enter-active.top-right,
.Vue-Toastification__fade-enter-active.bottom-right {
  animation-name: fadeInRight;
}
.Vue-Toastification__fade-enter-active.top-center {
  animation-name: fadeInTop;
}
.Vue-Toastification__fade-enter-active.bottom-center {
  animation-name: fadeInBottom;
}
.Vue-Toastification__fade-leave-active:not(.disable-transition).top-left,
.Vue-Toastification__fade-leave-active:not(.disable-transition).bottom-left {
  animation-name: fadeOutLeft;
}
.Vue-Toastification__fade-leave-active:not(.disable-transition).top-right,
.Vue-Toastification__fade-leave-active:not(.disable-transition).bottom-right {
  animation-name: fadeOutRight;
}
.Vue-Toastification__fade-leave-active:not(.disable-transition).top-center {
  animation-name: fadeOutTop;
}
.Vue-Toastification__fade-leave-active:not(.disable-transition).bottom-center {
  animation-name: fadeOutBottom;
}
.Vue-Toastification__fade-leave-active,
.Vue-Toastification__fade-enter-active {
  animation-duration: 750ms;
  animation-fill-mode: both;
}
.Vue-Toastification__fade-move {
  transition-timing-function: ease-in-out;
  transition-property: all;
  transition-duration: 400ms;
}
@keyframes slideInBlurredLeft {
  0% {
    transform: translateX(-1000px) scaleX(2.5) scaleY(0.2);
    transform-origin: 100% 50%;
    filter: blur(40px);
    opacity: 0;
  }
  100% {
    transform: translateX(0) scaleY(1) scaleX(1);
    transform-origin: 50% 50%;
    filter: blur(0);
    opacity: 1;
  }
}
@keyframes slideInBlurredTop {
  0% {
    transform: translateY(-1000px) scaleY(2.5) scaleX(0.2);
    transform-origin: 50% 0%;
    filter: blur(240px);
    opacity: 0;
  }
  100% {
    transform: translateY(0) scaleY(1) scaleX(1);
    transform-origin: 50% 50%;
    filter: blur(0);
    opacity: 1;
  }
}
@keyframes slideInBlurredRight {
  0% {
    transform: translateX(1000px) scaleX(2.5) scaleY(0.2);
    transform-origin: 0% 50%;
    filter: blur(40px);
    opacity: 0;
  }
  100% {
    transform: translateX(0) scaleY(1) scaleX(1);
    transform-origin: 50% 50%;
    filter: blur(0);
    opacity: 1;
  }
}
@keyframes slideInBlurredBottom {
  0% {
    transform: translateY(1000px) scaleY(2.5) scaleX(0.2);
    transform-origin: 50% 100%;
    filter: blur(240px);
    opacity: 0;
  }
  100% {
    transform: translateY(0) scaleY(1) scaleX(1);
    transform-origin: 50% 50%;
    filter: blur(0);
    opacity: 1;
  }
}
@keyframes slideOutBlurredTop {
  0% {
    transform: translateY(0) scaleY(1) scaleX(1);
    transform-origin: 50% 0%;
    filter: blur(0);
    opacity: 1;
  }
  100% {
    transform: translateY(-1000px) scaleY(2) scaleX(0.2);
    transform-origin: 50% 0%;
    filter: blur(240px);
    opacity: 0;
  }
}
@keyframes slideOutBlurredBottom {
  0% {
    transform: translateY(0) scaleY(1) scaleX(1);
    transform-origin: 50% 50%;
    filter: blur(0);
    opacity: 1;
  }
  100% {
    transform: translateY(1000px) scaleY(2) scaleX(0.2);
    transform-origin: 50% 100%;
    filter: blur(240px);
    opacity: 0;
  }
}
@keyframes slideOutBlurredLeft {
  0% {
    transform: translateX(0) scaleY(1) scaleX(1);
    transform-origin: 50% 50%;
    filter: blur(0);
    opacity: 1;
  }
  100% {
    transform: translateX(-1000px) scaleX(2) scaleY(0.2);
    transform-origin: 100% 50%;
    filter: blur(40px);
    opacity: 0;
  }
}
@keyframes slideOutBlurredRight {
  0% {
    transform: translateX(0) scaleY(1) scaleX(1);
    transform-origin: 50% 50%;
    filter: blur(0);
    opacity: 1;
  }
  100% {
    transform: translateX(1000px) scaleX(2) scaleY(0.2);
    transform-origin: 0% 50%;
    filter: blur(40px);
    opacity: 0;
  }
}
.Vue-Toastification__slideBlurred-enter-active.top-left,
.Vue-Toastification__slideBlurred-enter-active.bottom-left {
  animation-name: slideInBlurredLeft;
}
.Vue-Toastification__slideBlurred-enter-active.top-right,
.Vue-Toastification__slideBlurred-enter-active.bottom-right {
  animation-name: slideInBlurredRight;
}
.Vue-Toastification__slideBlurred-enter-active.top-center {
  animation-name: slideInBlurredTop;
}
.Vue-Toastification__slideBlurred-enter-active.bottom-center {
  animation-name: slideInBlurredBottom;
}
.Vue-Toastification__slideBlurred-leave-active:not(.disable-transition).top-left,
.Vue-Toastification__slideBlurred-leave-active:not(.disable-transition).bottom-left {
  animation-name: slideOutBlurredLeft;
}
.Vue-Toastification__slideBlurred-leave-active:not(.disable-transition).top-right,
.Vue-Toastification__slideBlurred-leave-active:not(.disable-transition).bottom-right {
  animation-name: slideOutBlurredRight;
}
.Vue-Toastification__slideBlurred-leave-active:not(.disable-transition).top-center {
  animation-name: slideOutBlurredTop;
}
.Vue-Toastification__slideBlurred-leave-active:not(.disable-transition).bottom-center {
  animation-name: slideOutBlurredBottom;
}
.Vue-Toastification__slideBlurred-leave-active,
.Vue-Toastification__slideBlurred-enter-active {
  animation-duration: 750ms;
  animation-fill-mode: both;
}
.Vue-Toastification__slideBlurred-move {
  transition-timing-function: ease-in-out;
  transition-property: all;
  transition-duration: 400ms;
}

