
* {
  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-7b9e57f9] {
  min-height: 100vh;
  background-color: #ffffff;
  color: #1f2937;
}

/* Header */
.header[data-v-7b9e57f9] {
  background: #8B5CF6;
  color: white;
  padding: 1rem 0;
  border-bottom: 1px solid #E5E7EB;
}
.header-content[data-v-7b9e57f9] {
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0 1rem;
}
.title-section[data-v-7b9e57f9] {
  flex: 1;
}
.title[data-v-7b9e57f9] {
  font-size: 1.5rem;
  font-weight: 600;
  letter-spacing: 0.25px;
  margin-bottom: 0.5rem;
}
.welcome-text[data-v-7b9e57f9] {
  font-size: 0.9rem;
  opacity: 0.9;
}
.user-name-accent[data-v-7b9e57f9] {
  font-weight: 600;
  color: #e3f2fd;
}
.header-actions[data-v-7b9e57f9] {
  display: flex;
  align-items: center;
  gap: 1.5rem;
}
.datetime-widget[data-v-7b9e57f9] {
  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-7b9e57f9] {
  font-size: 1.2rem;
  font-weight: 700;
  font-family: 'Courier New', monospace;
  margin-bottom: 0.25rem;
}
.current-date[data-v-7b9e57f9] {
  font-size: 0.75rem;
  opacity: 0.9;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}



/* Пользовательское меню */
.user-menu[data-v-7b9e57f9] {
  position: relative;
}
.user-avatar[data-v-7b9e57f9] {
  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-7b9e57f9]:hover {
  background: rgba(255, 255, 255, 0.3);
  transform: scale(1.05);
}
.user-dropdown[data-v-7b9e57f9] {
  position: absolute;
  top: 50px;
  right: 0;
  background: white;
  color: #333;
  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-7b9e57f9 0.2s ease-out;
}
.user-info[data-v-7b9e57f9] {
  padding: 1rem;
  background: #f9fafb;
}
.user-name[data-v-7b9e57f9] {
  display: block;
  font-weight: 600;
  color: #1f2937;
  font-size: 0.875rem;
  margin-bottom: 0.25rem;
}
.user-email[data-v-7b9e57f9] {
  display: block;
  color: #6b7280;
  font-size: 0.75rem;
}
.user-specialization[data-v-7b9e57f9] {
  display: block;
  color: #8B5CF6;
  font-size: 0.7rem;
  font-weight: 500;
  margin-top: 0.25rem;
  font-style: italic;
}
.user-clinic[data-v-7b9e57f9] {
  margin-top: 0.5rem;
  padding-top: 0.5rem;
  border-top: 1px solid #f3f4f6;
}
.clinic-name[data-v-7b9e57f9] {
  display: block;
  color: #374151;
  font-size: 0.75rem;
  font-weight: 500;
  margin-bottom: 0.25rem;
}
.clinic-region[data-v-7b9e57f9] {
  display: block;
  color: #6b7280;
  font-size: 0.7rem;
}
.dropdown-divider[data-v-7b9e57f9] {
  margin: 0;
  border: none;
  border-top: 1px solid #e5e7eb;
}
.logout-btn[data-v-7b9e57f9] {
  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-7b9e57f9]:hover {
  background: #fef2f2;
}
.logout-icon[data-v-7b9e57f9] {
  font-size: 1rem;
}

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

/* Секция поиска */
.search-section[data-v-7b9e57f9] {
  background: white;
  border-radius: 12px;
  padding: 2rem;
  border: 1px solid #E5E7EB;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);
  margin-bottom: 2rem;
}
.search-intro[data-v-7b9e57f9] {
  text-align: center;
  margin-bottom: 2rem;
}
.search-title[data-v-7b9e57f9] {
  font-size: 1.875rem;
  font-weight: 700;
  color: #1f2937;
  margin-bottom: 0.5rem;
}
.search-subtitle[data-v-7b9e57f9] {
  font-size: 1rem;
  color: #6b7280;
  font-weight: 400;
}

/* Поисковик */
.search-container[data-v-7b9e57f9] {
  position: relative;
  max-width: 600px;
  margin: 0 auto 2rem;
}
.search-wrapper[data-v-7b9e57f9] {
  position: relative;
}
.search-input-wrapper[data-v-7b9e57f9] {
  display: flex;
  background: white;
  border: 2px solid #E5E7EB;
  border-radius: 8px;
  padding: 0.75rem 1rem;
  transition: all 0.2s ease;
}
.search-input-wrapper[data-v-7b9e57f9]:focus-within {
  border-color: #8B5CF6;
  box-shadow: 0 0 0 3px rgba(139, 92, 246, 0.1);
}
.search-input[data-v-7b9e57f9] {
  flex: 1;
  background: transparent;
  border: none;
  color: #1f2937;
  font-size: 1rem;
  padding: 0.5rem;
  outline: none;
  font-weight: 500;
}
.search-input[data-v-7b9e57f9]::-moz-placeholder {
  color: #9ca3af;
  font-weight: 400;
}
.search-input[data-v-7b9e57f9]::placeholder {
  color: #9ca3af;
  font-weight: 400;
}
.search-btn[data-v-7b9e57f9] {
  background: #8B5CF6;
  border: none;
  color: white;
  padding: 0.5rem 1rem;
  border-radius: 6px;
  font-size: 1rem;
  cursor: pointer;
  transition: all 0.2s ease;
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 44px;
}
.search-btn[data-v-7b9e57f9]:hover {
  background: #7C3AED;
}
.search-btn[data-v-7b9e57f9]:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}
.search-spinner[data-v-7b9e57f9] {
  width: 16px;
  height: 16px;
  border: 2px solid rgba(255, 255, 255, 0.3);
  border-top: 2px solid white;
  border-radius: 50%;
  animation: spin-7b9e57f9 1s linear infinite;
}

/* Dropdown поиска */
.search-dropdown[data-v-7b9e57f9] {
  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-7b9e57f9 0.2s ease-out;
  max-height: 400px;
  overflow-y: auto;
}
.dropdown-header[data-v-7b9e57f9] {
  padding: 0.75rem 1rem;
  background: #f8fafc;
  border-bottom: 1px solid #e5e7eb;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.results-count[data-v-7b9e57f9] {
  font-size: 0.8rem;
  font-weight: 600;
  color: #374151;
}
.showing-limit[data-v-7b9e57f9] {
  font-size: 0.75rem;
  color: #6b7280;
  font-style: italic;
}
.dropdown-list[data-v-7b9e57f9] {
  max-height: 320px;
  overflow-y: auto;
}
.dropdown-item[data-v-7b9e57f9] {
  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-7b9e57f9]:last-child {
  border-bottom: none;
}
.dropdown-item[data-v-7b9e57f9]:hover {
  background: #f8fafc;
  transform: translateX(2px);
}
.dropdown-patient-info[data-v-7b9e57f9] {
  flex: 1;
}
.dropdown-patient-name[data-v-7b9e57f9] {
  font-size: 0.9rem;
  font-weight: 600;
  color: #1f2937;
  margin-bottom: 0.25rem;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex-wrap: wrap;
}
.my-patient-badge[data-v-7b9e57f9] {
  font-size: 0.7rem;
  background: #dcfce7;
  color: #16a34a;
  padding: 0.125rem 0.375rem;
  border-radius: 4px;
  font-weight: 500;
  border: 1px solid #bbf7d0;
}
.other-patient-badge[data-v-7b9e57f9] {
  font-size: 0.7rem;
  background: #fef2f2;
  color: #dc2626;
  padding: 0.125rem 0.375rem;
  border-radius: 4px;
  font-weight: 500;
  border: 1px solid #fecaca;
}
.dropdown-patient-details[data-v-7b9e57f9] {
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
}
.dropdown-iin[data-v-7b9e57f9],
.dropdown-birth[data-v-7b9e57f9] {
  font-size: 0.75rem;
  color: #6b7280;
}
.dropdown-select-icon[data-v-7b9e57f9] {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  color: #8B5CF6;
  font-weight: bold;
  margin-left: 1rem;
}
.dropdown-no-results[data-v-7b9e57f9] {
  padding: 1.5rem;
  text-align: center;
  color: #6b7280;
}
.dropdown-no-results p[data-v-7b9e57f9] {
  font-size: 0.85rem;
  margin-top: 0.5rem;
  opacity: 0.8;
}
.dropdown-loading[data-v-7b9e57f9] {
  padding: 1rem;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  color: #6b7280;
  font-size: 0.875rem;
}

/* Действия */
.actions-section[data-v-7b9e57f9] {
  text-align: center;
  display: flex;
  justify-content: center;
  gap: 1rem;
  flex-wrap: wrap;
}
.patients-list-btn[data-v-7b9e57f9],
.create-patient-btn[data-v-7b9e57f9],
.statistics-btn[data-v-7b9e57f9],
.survey-statistics-btn[data-v-7b9e57f9] {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.75rem 1.5rem;
  background: #10B981;
  color: white;
  border: none;
  border-radius: 8px;
  font-size: 0.9rem;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s ease;
  text-decoration: none;
}
.patients-list-btn[data-v-7b9e57f9] {
  background: #8B5CF6;
}
.statistics-btn[data-v-7b9e57f9] {
  background: #F59E0B;
}
.survey-statistics-btn[data-v-7b9e57f9] {
  background: #6366F1;
}
.patients-list-btn[data-v-7b9e57f9]:hover {
  background: #7C3AED;
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(139, 92, 246, 0.3);
}
.create-patient-btn[data-v-7b9e57f9]:hover {
  background: #059669;
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(16, 185, 129, 0.3);
}
.statistics-btn[data-v-7b9e57f9]:hover {
  background: #D97706;
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(245, 158, 11, 0.3);
}
.survey-statistics-btn[data-v-7b9e57f9]:hover {
  background: #4F46E5;
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(99, 102, 241, 0.3);
}
.action-icon[data-v-7b9e57f9] {
  font-size: 1rem;
}



/* Модальное окно (переиспользуем стили) */
.modal-overlay[data-v-7b9e57f9] {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.5);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 2000;
}
.modal-content[data-v-7b9e57f9] {
  background: white;
  border-radius: 20px;
  width: 90%;
  max-width: 500px;
  max-height: 80vh;
  overflow-y: auto;
  border: 1px solid #E5E7EB;
  box-shadow: 0 25px 50px rgba(0,0,0,0.25);
}
.modal-header[data-v-7b9e57f9] {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1.5rem;
  border-bottom: 1px solid #F3F4F6;
}
.modal-header h3[data-v-7b9e57f9] {
  margin: 0;
  font-size: 1.25rem;
  font-weight: 600;
  color: #1F2937;
}
.close-btn[data-v-7b9e57f9] {
  background: none;
  border: 1px solid #E5E7EB;
  font-size: 1.25rem;
  color: #6B7280;
  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-7b9e57f9]:hover {
  background: #F9FAFB;
  border-color: #D1D5DB;
}
.modal-body[data-v-7b9e57f9] {
  padding: 1.5rem;
  color: #333;
}
.form-group[data-v-7b9e57f9] {
  margin-bottom: 1rem;
}
.form-group label[data-v-7b9e57f9] {
  display: block;
  margin-bottom: 0.5rem;
  font-weight: 500;
  color: #374151;
  font-size: 0.9rem;
}
.form-input[data-v-7b9e57f9] {
  width: 100%;
  padding: 0.75rem 1rem;
  border: 1px solid #E5E7EB;
  border-radius: 8px;
  font-size: 0.9rem;
  transition: border-color 0.2s ease;
}
.form-input[data-v-7b9e57f9]:focus {
  outline: none;
  border-color: #8B5CF6;
  box-shadow: 0 0 0 3px rgba(139, 92, 246, 0.1);
}
.required[data-v-7b9e57f9] {
  color: #ef4444;
  font-weight: bold;
}
.field-error[data-v-7b9e57f9] {
  color: #ef4444;
  font-size: 0.8rem;
  margin-top: 0.25rem;
  font-weight: 500;
}
.field-note[data-v-7b9e57f9] {
  color: #6b7280;
  font-size: 0.75rem;
  margin-top: 0.25rem;
  font-style: italic;
  display: block;
}
.modal-footer[data-v-7b9e57f9] {
  display: flex;
  justify-content: flex-end;
  gap: 0.75rem;
  padding: 1.5rem;
  border-top: 1px solid #F3F4F6;
  background: #FAFAFA;
}
.btn[data-v-7b9e57f9] {
  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-7b9e57f9] {
  background: #F3F4F6;
  color: #374151;
  border: 1px solid #E5E7EB;
}
.btn-cancel[data-v-7b9e57f9]:hover {
  background: #E5E7EB;
}
.btn-primary[data-v-7b9e57f9] {
  background: #8B5CF6;
  color: white;
}
.btn-primary[data-v-7b9e57f9]:hover {
  background: #7C3AED;
}
.btn-primary[data-v-7b9e57f9]:disabled {
  background: #D1D5DB;
  cursor: not-allowed;
}

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

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

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


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

/* Локальный индикатор загрузки */
.tab-loading-overlay[data-v-431a1fb2] {
  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-431a1fb2] {
  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-431a1fb2] {
  width: 32px;
  height: 32px;
  border: 3px solid #F3F4F6;
  border-top: 3px solid #8B5CF6;
  border-radius: 50%;
  animation: spin-431a1fb2 1s linear infinite;
}
@keyframes spin-431a1fb2 {
0% { transform: rotate(0deg);
}
100% { transform: rotate(360deg);
}
}
.loading-text[data-v-431a1fb2] {
  margin: 0;
  font-size: 0.875rem;
  color: #6B7280;
  font-weight: 500;
}
.main-layout.loading[data-v-431a1fb2] {
  opacity: 0.6;
  pointer-events: none;
}
.main-layout[data-v-431a1fb2] {
  padding: 1rem;
  background: transparent;
}
.top-section[data-v-431a1fb2] {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
  margin-bottom: 1rem;
}
.bottom-section[data-v-431a1fb2] {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
}
.left-bottom[data-v-431a1fb2] {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.right-bottom[data-v-431a1fb2] {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.section[data-v-431a1fb2] {
  margin-bottom: 0;
  padding: 1.25rem;
  background: white;
  border-radius: 8px;
  border: 1px solid #E5E7EB;
  transition: border-color 0.2s ease;
}
.section[data-v-431a1fb2]:hover {
  border-color: #D1D5DB;
}
.basic-section[data-v-431a1fb2] {
  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-431a1fb2] {
  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-431a1fb2] {
  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-431a1fb2] {
  font-size: 0.75rem;
  font-weight: 600;
  color: #6B7280;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin: 0;
}
.clear-section-btn[data-v-431a1fb2] {
  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-431a1fb2]:hover {
  background: #F9FAFB;
  border-color: #DC2626;
  color: #DC2626;
}
.basic-section .form-group[data-v-431a1fb2] {
  margin-bottom: 1rem;
}
.contact-section .form-group[data-v-431a1fb2] {
  margin-bottom: 1rem;
}

/* Minimalist forms */
.form-group[data-v-431a1fb2] {
  margin-bottom: 0.75rem;
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}
.field-label[data-v-431a1fb2] {
  font-size: 0.75rem;
  color: #6B7280;
  font-weight: 500;
  margin-bottom: 0.25rem;
  display: block;
}
.required[data-v-431a1fb2] {
  color: #EF4444;
  font-weight: 600;
}
.form-input[data-v-431a1fb2] {
  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-431a1fb2]:focus {
  outline: none;
  border-color: #8B5CF6;
}
.form-input.error[data-v-431a1fb2] {
  border-color: #EF4444;
}
.radio-group.error[data-v-431a1fb2] {
  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-431a1fb2] {
  color: #EF4444;
}
.form-input[data-v-431a1fb2]::-moz-placeholder {
  color: #9CA3AF;
}
.form-input[data-v-431a1fb2]::placeholder {
  color: #9CA3AF;
}
.readonly-field[data-v-431a1fb2] {
  background: #F9FAFB;
  color: #6B7280;
  cursor: not-allowed;
}

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

/* Minimalist radio buttons */
.radio-group[data-v-431a1fb2] {
  display: flex;
  gap: 0.5rem;
  flex-wrap: wrap;
  margin-top: 0.25rem;
}
.radio-label[data-v-431a1fb2] {
  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-431a1fb2]:hover {
  background: #F9FAFB;
}
.radio-label input[type="radio"][data-v-431a1fb2] {
  margin: 0;
  opacity: 0;
  position: absolute;
}
.radio-visual[data-v-431a1fb2] {
  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-431a1fb2] {
  border-color: #8B5CF6;
  background: #8B5CF6;
}
.radio-label input[type="radio"]:checked + .radio-visual[data-v-431a1fb2]::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-431a1fb2] {
  font-size: 0.8rem;
  color: #374151;
  font-weight: 400;
}
.radio-label input[type="radio"]:checked ~ .radio-text[data-v-431a1fb2] {
  color: #1F2937;
  font-weight: 500;
}
.error-message[data-v-431a1fb2] {
  color: #EF4444;
  font-size: 0.7rem;
  margin-top: 0.25rem;
}
.weight-input[data-v-431a1fb2] {
  display: flex;
  gap: 0.5rem;
  align-items: flex-start;
}
.weight-input .form-input[data-v-431a1fb2] {
  flex: 1;
}
.calculate-btn[data-v-431a1fb2] {
  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-431a1fb2]:hover:not(:disabled) {
  background: #059669;
}
.calculate-btn[data-v-431a1fb2]:disabled {
  background: #D1D5DB;
  color: #9CA3AF;
  cursor: not-allowed;
}
.form-select[data-v-431a1fb2] {
  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-431a1fb2] {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

/* Minimalist BMI scale */
.imt-scale[data-v-431a1fb2] {
  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-431a1fb2] {
  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-431a1fb2] {
  background: #E0F2FE;
  color: #0F4F75;
  border-color: #7DD3FC;
}
.scale-item.normal.active[data-v-431a1fb2] {
  background: #DCFCE7;
  color: #166534;
  border-color: #86EFAC;
}
.scale-item.overweight.active[data-v-431a1fb2] {
  background: #FEF3C7;
  color: #92400E;
  border-color: #FCD34D;
}
.scale-item.obese1.active[data-v-431a1fb2] {
  background: #FEE2E2;
  color: #991B1B;
  border-color: #FCA5A5;
}
.scale-item.obese2.active[data-v-431a1fb2] {
  background: #FECACA;
  color: #7F1D1D;
  border-color: #F87171;
}
.scale-item.obese3.active[data-v-431a1fb2] {
  background: #FCA5A5;
  color: #7F1D1D;
  border-color: #EF4444;
}
.scale-label[data-v-431a1fb2] {
  font-size: 0.65rem;
  margin-bottom: 0.25rem;
  font-weight: 500;
  line-height: 1.1;
  color: inherit;
}
.scale-value[data-v-431a1fb2] {
  font-size: 0.7rem;
  font-weight: 600;
  color: inherit;
}
.year-group[data-v-431a1fb2] {
  display: flex;
  gap: 0.5rem;
}
.year-group input[data-v-431a1fb2] {
  flex: 1;
}

/* Minimalist save section */
.save-actions[data-v-431a1fb2] {
  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-431a1fb2] {
  background: #8B5CF6;
  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-431a1fb2]:hover:not(:disabled) {
  background: #7C3AED;
}
.save-btn[data-v-431a1fb2]:disabled {
  background: #D1D5DB;
  color: #9CA3AF;
  cursor: not-allowed;
}
.save-status[data-v-431a1fb2] {
  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-431a1fb2] {
  background: #D1FAE5;
  color: #065F46;
  border: 1px solid #10B981;
}
.save-status.success[data-v-431a1fb2]::before {
  content: "✓";
  font-size: 0.875rem;
}
.save-status.error[data-v-431a1fb2] {
  background: #FEF2F2;
  color: #991B1B;
  border: 1px solid #EF4444;
}
.save-status.error[data-v-431a1fb2]::before {
  content: "✗";
  font-size: 0.875rem;
}

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

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


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

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

/* Вкладки */
.sub-tabs[data-v-23523c50] {
  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-23523c50] {
  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-23523c50]:hover {
  background: #f8f9fa;
  color: #333;
}
.sub-tab.active[data-v-23523c50] {
  background: #8B5CF6;
  color: white;
  box-shadow: 0 2px 4px rgba(139, 92, 246, 0.2);
}
.sub-tab.active[data-v-23523c50]:hover {
  background: #7C3AED;
}

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

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

/* Контейнер группы полей */
.form-group-container[data-v-23523c50] {
  margin-bottom: 1.5rem;
}
.form-group-container[data-v-23523c50]:last-child {
  margin-bottom: 0;
}
.form-group-container h3.section-title[data-v-23523c50] {
  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-23523c50] {
  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-23523c50] {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 1rem;
  margin-bottom: 1rem;
}

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


/* Инпуты */
.form-input[data-v-23523c50],
.form-select[data-v-23523c50],
.form-textarea[data-v-23523c50] {
  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-23523c50]:hover,
.form-select[data-v-23523c50]:hover,
.form-textarea[data-v-23523c50]:hover {
  border-color: #D1D5DB;
}
.form-input[data-v-23523c50]:focus,
.form-select[data-v-23523c50]:focus,
.form-textarea[data-v-23523c50]:focus {
  outline: none;
  border-color: #8B5CF6;
  box-shadow: 0 0 0 3px rgba(139, 92, 246, 0.1);
}
.form-input.error[data-v-23523c50],
.form-select.error[data-v-23523c50],
.form-textarea.error[data-v-23523c50] {
  border-color: #EF4444;
  background-color: #FEF2F2;
}
.form-input.error[data-v-23523c50]:focus,
.form-select.error[data-v-23523c50]:focus,
.form-textarea.error[data-v-23523c50]:focus {
  border-color: #DC2626;
  box-shadow: 0 0 0 3px rgba(239, 68, 68, 0.1);
}
.form-textarea[data-v-23523c50] {
  resize: vertical;
  min-height: 80px;
  line-height: 1.5;
}
.input-with-unit[data-v-23523c50] {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.input-with-unit .form-input[data-v-23523c50] {
  flex: 1;
}
.input-with-unit .unit[data-v-23523c50] {
  color: #6B7280;
  font-size: 0.875rem;
  white-space: nowrap;
  font-weight: 500;
}

/* Группы радио-кнопок и чекбоксов */
.radio-group[data-v-23523c50],
.checkbox-group[data-v-23523c50] {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  margin-top: 0.75rem;
}
.radio-label[data-v-23523c50],
.checkbox-label[data-v-23523c50] {
  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-23523c50]:hover,
.checkbox-label[data-v-23523c50]:hover {
  background: #F9FAFB;
}
.radio-label.suggested[data-v-23523c50] {
  background-color: #EDE9FE;
  border: 1px solid #8B5CF6;
}
.radio-label input[type="radio"][data-v-23523c50],
.checkbox-label input[type="checkbox"][data-v-23523c50] {
  cursor: pointer;
  width: 16px;
  height: 16px;
  accent-color: #8B5CF6;
}
.radio-label span[data-v-23523c50],
.checkbox-label span[data-v-23523c50] {
  font-size: 0.875rem;
  color: #374151;
}


/* Сообщения */
.error-message[data-v-23523c50] {
  color: #DC2626;
  font-size: 0.75rem;
  margin-top: 0.5rem;
  display: block;
}
.success-message[data-v-23523c50] {
  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-23523c50] {
  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-23523c50] {
  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-23523c50],
.alcohol-details[data-v-23523c50],
.alcohol-abuse-details[data-v-23523c50],
.treatment-details[data-v-23523c50],
.menopause-details[data-v-23523c50],
.hrt-details[data-v-23523c50] {
  margin-top: 1.25rem;
  margin-bottom: 0.5rem;
  padding: 1.25rem;
  background: #FAFAFA;
  border-radius: 6px;
  border: 1px solid #E5E7EB;
}

/* Индекс курильщика */
.smoking-index[data-v-23523c50] {
  margin: 1rem 0;
}
.index-display[data-v-23523c50] {
  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-23523c50] {
  background: #ECFDF5;
  border-left: 3px solid #10B981;
  color: #065F46;
}
.index-display.medium-risk[data-v-23523c50] {
  background: #FEF3C7;
  border-left: 3px solid #F59E0B;
  color: #92400E;
}
.index-display.high-risk[data-v-23523c50] {
  background: #FEE2E2;
  border-left: 3px solid #DC2626;
  color: #991B1B;
}
.index-label[data-v-23523c50] {
  color: inherit;
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.index-value[data-v-23523c50] {
  font-size: 1.25rem;
  font-weight: 600;
  color: inherit;
}
.risk-indicator[data-v-23523c50] {
  font-size: 0.875rem;
  font-weight: 600;
}

/* Поля только для чтения */
.readonly-field[data-v-23523c50] {
  margin: 1rem 0;
}
.readonly-field label.field-label[data-v-23523c50] {
  font-size: 0.75rem;
  font-weight: 500;
  color: #6B7280;
  display: block;
  margin-bottom: 0.5rem;
}
.readonly-value[data-v-23523c50] {
  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-23523c50] {
  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-23523c50] {
  display: flex;
  align-items: center;
  gap: 1rem;
  flex-wrap: wrap;
}
.save-btn[data-v-23523c50] {
  background: #8B5CF6;
  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-23523c50]:hover:not(:disabled) {
  background: #7C3AED;
}
.save-btn[data-v-23523c50]:disabled {
  background: #D1D5DB;
  color: #9CA3AF;
  cursor: not-allowed;
}
.save-status[data-v-23523c50] {
  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-23523c50] {
  background: #D1FAE5;
  color: #065F46;
  border: 1px solid #A7F3D0;
}
.save-status.error[data-v-23523c50] {
  background: #FEE2E2;
  color: #991B1B;
  border: 1px solid #FECACA;
}

/* Автосохранение информация */
.autosave-info[data-v-23523c50] {
  flex: 1;
  display: flex;
  align-items: center;
  min-width: 250px;
}
.autosave-text[data-v-23523c50] {
  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-23523c50] {
  width: 16px;
  height: 16px;
  color: #10B981;
  flex-shrink: 0;
}

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

/* Стили для аллергий */
.allergy-list[data-v-23523c50] {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}
.allergy-item[data-v-23523c50] {
  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-23523c50] {
  display: grid;
  grid-template-columns: 150px 1fr 1fr 1fr;
  gap: 0.5rem;
  flex: 1;
}
.allergy-type-select[data-v-23523c50] {
  min-width: 150px;
  width: 150px;
}
.remove-allergy-btn[data-v-23523c50] {
  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-23523c50]:hover {
  background: #DC2626;
  color: white;
}
.add-allergy-btn[data-v-23523c50] {
  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-23523c50]:hover {
  background: #E5E7EB;
  border-color: #9CA3AF;
}
@media (max-width: 768px) {
.allergy-item-content[data-v-23523c50] {
    grid-template-columns: 1fr;
}
}

/* Стили для аккордеона репродуктивного анамнеза */
.accordion-item[data-v-23523c50] {
  margin-bottom: 0.75rem;
  border: 1px solid #E5E7EB;
  border-radius: 6px;
  overflow: hidden;
  background: white;
}
.accordion-header[data-v-23523c50] {
  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-23523c50]:hover {
  background: #F3F4F6;
}
.accordion-title[data-v-23523c50] {
  font-size: 0.875rem;
  font-weight: 600;
  color: #374151;
  margin: 0;
}
.accordion-icon[data-v-23523c50] {
  font-size: 0.75rem;
  color: #6B7280;
  transition: transform 0.2s ease;
}
.accordion-content[data-v-23523c50] {
  padding: 1rem;
  background: white;
  border-top: 1px solid #E5E7EB;
}

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

/* Multi-select container */
.multi-select-container[data-v-23523c50] {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.selected-tags[data-v-23523c50] {
  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-23523c50] {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  background: #8B5CF6;
  color: white;
  padding: 0.25rem 0.75rem;
  border-radius: 20px;
  font-size: 0.875rem;
}
.tag-remove[data-v-23523c50] {
  background: none;
  border: none;
  color: white;
  cursor: pointer;
  font-size: 1.2rem;
  padding: 0;
  margin-left: 0.25rem;
}
.tag-remove[data-v-23523c50]: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-23523c50] {
  color: #6b7280;
  font-style: italic;
  padding: 0.25rem;
}
.checkbox-list[data-v-23523c50] {
  max-height: 240px;
  overflow-y: auto;
  border: 1px solid #e5e7eb;
  border-radius: 4px;
  padding: 0.5rem;
}
.checkbox-item[data-v-23523c50] {
  margin-bottom: 0.5rem;
}
.checkbox-label[data-v-23523c50] {
  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-23523c50]:hover {
  background: #f3f4f6;
}
.checkbox-label input[type="checkbox"][data-v-23523c50],
.checkbox-zone input[type="checkbox"][data-v-23523c50] {
  display: none;
}
.checkbox-custom[data-v-23523c50] {
  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-23523c50],
.checkbox-zone input[type="checkbox"]:checked + .checkbox-custom[data-v-23523c50] {
  background: #8B5CF6;
  border-color: #8B5CF6;
}
.checkbox-label input[type="checkbox"]:checked + .checkbox-custom[data-v-23523c50]::after,
.checkbox-zone input[type="checkbox"]:checked + .checkbox-custom[data-v-23523c50]::after {
  content: '✓';
  position: absolute;
  top: -2px;
  left: 2px;
  color: white;
  font-size: 12px;
  font-weight: bold;
}
.checkbox-text[data-v-23523c50] {
  font-size: 0.875rem;
  color: #374151;
}
.loading-placeholder[data-v-23523c50] {
  text-align: center;
  color: #6b7280;
  font-style: italic;
  padding: 2rem;
}

/* МКБ дерево стили */
.mkb-tree-container[data-v-23523c50] {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.mkb-level[data-v-23523c50] {
  border: 1px solid #E5E7EB;
  border-radius: 6px;
  padding: 1rem;
  background: #FAFAFA;
}
.mkb-level-title[data-v-23523c50] {
  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-23523c50] {
  margin-bottom: 1.5rem;
  padding: 1rem;
  background: #F9FAFB;
  border-radius: 8px;
  border: 1px solid #E5E7EB;
}
.search-title[data-v-23523c50] {
  font-size: 0.875rem;
  font-weight: 600;
  color: #6B7280;
  margin: 0 0 1rem 0;
}
.search-container[data-v-23523c50] {
  background: white;
  border: 1px solid #E5E7EB;
  border-radius: 8px;
  padding: 1rem;
}
.search-input-group[data-v-23523c50] {
  position: relative;
  margin-bottom: 1rem;
}
.search-input[data-v-23523c50] {
  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-23523c50]:focus {
  outline: none;
  border-color: #8B5CF6;
  box-shadow: 0 0 0 3px rgba(139, 92, 246, 0.1);
}
.clear-search-btn[data-v-23523c50] {
  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-23523c50]:hover {
  background: #F3F4F6;
  color: #6B7280;
}
.search-loading[data-v-23523c50] {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  color: #6B7280;
  font-size: 0.875rem;
}
.search-spinner[data-v-23523c50] {
  width: 16px;
  height: 16px;
  border: 2px solid #F3F4F6;
  border-top: 2px solid #8B5CF6;
  border-radius: 50%;
  animation: spin 1s linear infinite;
}
.search-results[data-v-23523c50] {
  margin-top: 1rem;
}
.results-title[data-v-23523c50] {
  font-size: 0.875rem;
  font-weight: 600;
  color: #374151;
  margin: 0 0 0.75rem 0;
}
.search-results-list[data-v-23523c50] {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.search-result-item[data-v-23523c50] {
  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-23523c50]:hover {
  border-color: #D1D5DB;
}
.result-name[data-v-23523c50] {
  font-size: 0.875rem;
  color: #1F2937;
  font-weight: 500;
}
.add-code-btn[data-v-23523c50] {
  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-23523c50]:hover {
  background: #059669;
}
.no-results[data-v-23523c50] {
  text-align: center;
  padding: 1rem;
  color: #6B7280;
  font-size: 0.875rem;
}
.no-results p[data-v-23523c50] {
  margin: 0;
}

/* Стили для кнопок управления кодами */
.mkb-code-actions[data-v-23523c50] {
  display: flex;
  gap: 0.5rem;
  align-items: center;
  flex-shrink: 0;
}
.remove-code-btn[data-v-23523c50] {
  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-23523c50]:hover {
  background: #FDE68A;
  border-color: #F59E0B;
  color: #B45309;
}

/* Стили для иерархической структуры МКБ кодов */
.mkb-item-container[data-v-23523c50] {
  margin-bottom: 0.5rem;
}
.parent-item[data-v-23523c50] {
  background: #f8fafc;
  border: 1px solid #e5e7eb;
  border-radius: 6px;
  padding: 0.5rem;
  margin-bottom: 0.25rem;
}
.parent-item-content[data-v-23523c50] {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  width: 100%;
}
.checkbox-zone[data-v-23523c50] {
  display: flex;
  align-items: center;
  cursor: pointer;
  flex-shrink: 0;
}
.text-zone[data-v-23523c50] {
  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-23523c50]:hover {
  background: rgba(139, 92, 246, 0.05);
}
.children-container[data-v-23523c50] {
  margin-left: 1.5rem;
  margin-top: 0.25rem;
  border-left: 2px solid #e5e7eb;
  padding-left: 1rem;
}
.child-item[data-v-23523c50] {
  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-23523c50]:hover {
  background: #f8fafc;
  border-color: #d1d5db;
}
.child-item .checkbox-label[data-v-23523c50] {
  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-23523c50] {
  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-23523c50] {
    flex-direction: column;
    gap: 0.5rem;
    align-items: stretch;
}
.add-code-btn[data-v-23523c50] {
    width: 100%;
}
.mkb-code-actions[data-v-23523c50] {
    flex-direction: column;
    gap: 0.25rem;
    margin-left: 0;
    margin-top: 0.5rem;
}
.remove-code-btn[data-v-23523c50] {
    width: 100%;
    text-align: center;
}
}

/* Стили для кнопки добавления реакции */
.reaction-select-wrapper[data-v-23523c50] {
  display: flex;
  gap: 0.5rem;
  align-items: center;
}
.reaction-select-wrapper .form-select[data-v-23523c50] {
  flex: 1;
}
.add-reaction-btn[data-v-23523c50] {
  padding: 0.5rem 0.75rem;
  background: #8B5CF6;
  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-23523c50]:hover {
  background: #7C3AED;
  transform: scale(1.05);
}
.add-reaction-btn[data-v-23523c50]:active {
  transform: scale(0.95);
}

/* Стили для модального окна */
.modal-overlay[data-v-23523c50] {
  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-23523c50] {
  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-23523c50] {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1.5rem;
  border-bottom: 1px solid #E5E7EB;
}
.modal-header h3[data-v-23523c50] {
  margin: 0;
  font-size: 1.25rem;
  font-weight: 600;
  color: #1F2937;
}
.modal-close-btn[data-v-23523c50] {
  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-23523c50]:hover {
  background: #F3F4F6;
  color: #1F2937;
}
.modal-body[data-v-23523c50] {
  padding: 1.5rem;
  flex: 1;
  overflow-y: auto;
}
.modal-footer[data-v-23523c50] {
  display: flex;
  justify-content: flex-end;
  gap: 0.75rem;
  padding: 1.5rem;
  border-top: 1px solid #E5E7EB;
}
.btn-cancel[data-v-23523c50] {
  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-23523c50]:hover {
  background: #E5E7EB;
  border-color: #9CA3AF;
}
.btn-save[data-v-23523c50] {
  padding: 0.625rem 1.25rem;
  background: #8B5CF6;
  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-23523c50]:hover:not(:disabled) {
  background: #7C3AED;
}
.btn-save[data-v-23523c50]:disabled {
  background: #D1D5DB;
  color: #9CA3AF;
  cursor: not-allowed;
}
@media (max-width: 768px) {
.modal-content[data-v-23523c50] {
    width: 95%;
    max-height: 95vh;
}
.reaction-select-wrapper[data-v-23523c50] {
    flex-direction: column;
}
.add-reaction-btn[data-v-23523c50] {
    width: 100%;
}
}


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

/* Локальный индикатор загрузки */
.tab-loading-overlay[data-v-1b6ee7d6] {
  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-1b6ee7d6] {
  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-1b6ee7d6] {
  width: 32px;
  height: 32px;
  border: 3px solid #F3F4F6;
  border-top: 3px solid #8B5CF6;
  border-radius: 50%;
  animation: spin-1b6ee7d6 1s linear infinite;
}
@keyframes spin-1b6ee7d6 {
0% { transform: rotate(0deg);
}
100% { transform: rotate(360deg);
}
}
.loading-text[data-v-1b6ee7d6] {
  margin: 0;
  font-size: 0.875rem;
  color: #6B7280;
  font-weight: 500;
}
.sub-tabs.loading[data-v-1b6ee7d6],
.tab-content.loading[data-v-1b6ee7d6] {
  opacity: 0.6;
  pointer-events: none;
}
.page-header[data-v-1b6ee7d6] {
  margin-bottom: 1rem;
}
.page-header h2[data-v-1b6ee7d6] {
  font-size: 1.25rem;
  font-weight: 600;
  color: #333;
  margin: 0;
}
.sub-tabs[data-v-1b6ee7d6] {
  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-1b6ee7d6] {
  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-1b6ee7d6]:hover {
  background: #f5f5f5;
}
.sub-tab.active[data-v-1b6ee7d6] {
  background: #8B5CF6;
  color: white;
}
.tab-content[data-v-1b6ee7d6] {
  background: white;
  border-radius: 6px;
  border: 1px solid #e0e0e0;
  overflow: hidden;
}
.analysis-section[data-v-1b6ee7d6] {
  margin-bottom: 1.5rem;
}
.section-header[data-v-1b6ee7d6] {
  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-1b6ee7d6] {
  font-size: 0.8rem;
  font-weight: 600;
  color: #333;
  margin: 0;
  text-transform: uppercase;
}
.section-controls[data-v-1b6ee7d6] {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}
.date-picker[data-v-1b6ee7d6] {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  position: relative;
}
.date-input[data-v-1b6ee7d6] {
  padding: 0.375rem 0.5rem;
  border: 1px solid #ddd;
  border-radius: 4px;
  font-size: 0.75rem;
  width: 140px;
  background: white;
}
.date-input[data-v-1b6ee7d6]:focus {
  outline: none;
  border-color: #8B5CF6;
}
.search-icon[data-v-1b6ee7d6] {
  font-size: 0.75rem;
  color: #666;
}
.clear-section-btn[data-v-1b6ee7d6] {
  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-1b6ee7d6]:hover {
  background: #FEE2E2;
  color: #DC2626;
}
.chevron-btn[data-v-1b6ee7d6] {
  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-1b6ee7d6]:hover {
  background: #e0e0e0;
  color: #333;
}
.analysis-table[data-v-1b6ee7d6] {
  padding: 1rem;
}
.analysis-table table[data-v-1b6ee7d6] {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.75rem;
}
.analysis-table th[data-v-1b6ee7d6] {
  background: #eeeeee;
  padding: 0.75rem;
  text-align: left;
  font-weight: 600;
  color: #333;
  border-bottom: 1px solid #e0e0e0;
}
.analysis-table td[data-v-1b6ee7d6] {
  padding: 0.75rem;
  border-bottom: 1px solid #e0e0e0;
  color: #666;
}
.analysis-table tr[data-v-1b6ee7d6]:hover {
  background: #f8f9fa;
}
.value-input[data-v-1b6ee7d6] {
  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-1b6ee7d6]:focus {
  outline: none;
  border-color: #8B5CF6;
}
.value-input[data-v-1b6ee7d6]::-moz-placeholder {
  color: #999;
}
.value-input[data-v-1b6ee7d6]::placeholder {
  color: #999;
}
.loading-placeholder[data-v-1b6ee7d6] {
  padding: 2rem;
  text-align: center;
  color: #666;
  font-size: 0.875rem;
}

/* Minimalist save section */
.save-actions[data-v-1b6ee7d6] {
  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-1b6ee7d6] {
  display: flex;
  align-items: center;
  gap: 1rem;
  flex-wrap: wrap;
}
.save-btn[data-v-1b6ee7d6] {
  background: #8B5CF6;
  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-1b6ee7d6]:hover:not(:disabled) {
  background: #7C3AED;
}
.save-btn[data-v-1b6ee7d6]:disabled {
  background: #D1D5DB;
  color: #9CA3AF;
  cursor: not-allowed;
}
.save-status[data-v-1b6ee7d6] {
  padding: 0.5rem 1rem;
  border-radius: 6px;
  font-size: 0.875rem;
  font-weight: 500;
  transition: all 0.3s ease;
}
.save-status.success[data-v-1b6ee7d6] {
  background: #D1FAE5;
  color: #065F46;
  border: 1px solid #A7F3D0;
}
.save-status.error[data-v-1b6ee7d6] {
  background: #FEE2E2;
  color: #991B1B;
  border: 1px solid #FECACA;
}

/* Автосохранение информация */
.autosave-info[data-v-1b6ee7d6] {
  flex: 1;
  display: flex;
  align-items: center;
  min-width: 250px;
}
.autosave-text[data-v-1b6ee7d6] {
  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-1b6ee7d6] {
  width: 16px;
  height: 16px;
  color: #10B981;
  flex-shrink: 0;
}

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

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


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

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

/* Подвкладки */
.sub-tabs[data-v-70b807b8] {
  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-70b807b8] {
  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-70b807b8]:hover {
  background: #f8f9fa;
  color: #333;
}
.sub-tab.active[data-v-70b807b8] {
  background: #8B5CF6;
  color: white;
  box-shadow: 0 2px 4px rgba(139, 92, 246, 0.2);
}
.sub-tab.active[data-v-70b807b8]:hover {
  background: #7C3AED;
}

/* Форма загрузки */
.upload-form[data-v-70b807b8] {
  background: white;
  border-radius: 6px;
  border: 1px solid #e0e0e0;
  margin-bottom: 1.5rem;
  overflow: hidden;
}
.upload-form-content[data-v-70b807b8] {
  padding: 1.5rem;
}
.upload-form-content h4[data-v-70b807b8] {
  margin: 0 0 1rem 0;
  font-size: 1rem;
  font-weight: 600;
  color: #333;
}
.form-group[data-v-70b807b8] {
  margin-bottom: 1rem;
}
.form-group[data-v-70b807b8]:last-child {
  margin-bottom: 0;
}
.form-group label[data-v-70b807b8] {
  display: block;
  margin-bottom: 0.5rem;
  font-weight: 500;
  color: #555;
  font-size: 0.9rem;
}
.form-input[data-v-70b807b8] {
  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-70b807b8]:focus {
  outline: none;
  border-color: #8B5CF6;
  box-shadow: 0 0 0 3px rgba(139, 92, 246, 0.1);
}
.form-textarea[data-v-70b807b8] {
  min-height: 100px;
  resize: vertical;
}
.form-help[data-v-70b807b8] {
  display: block;
  margin-top: 0.25rem;
  color: #666;
  font-size: 0.8rem;
  line-height: 1.3;
}

/* Стили для выпадающего списка */
select.form-input[data-v-70b807b8] {
  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-70b807b8] {
  padding: 0.5rem;
  color: #333;
  background: white;
}
select.form-input option[data-v-70b807b8]:hover {
  background: #f8f9fa;
}
.form-actions[data-v-70b807b8] {
  display: flex;
  gap: 1rem;
  justify-content: flex-end;
  margin-top: 1.5rem;
  padding-top: 1rem;
  border-top: 1px solid #f0f0f0;
}
.selected-file[data-v-70b807b8] {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 1rem;
  background: #f8f9fa;
  border: 2px dashed #8B5CF6;
  border-radius: 4px;
}
.file-icon[data-v-70b807b8] {
  font-size: 2rem;
  color: #8B5CF6;
}
.file-info p[data-v-70b807b8] {
  margin: 0;
  font-weight: 500;
  color: #333;
}
.file-info small[data-v-70b807b8] {
  color: #666;
}
.upload-placeholder[data-v-70b807b8] {
  text-align: center;
  padding: 2rem;
  border: 2px dashed #e0e0e0;
  border-radius: 4px;
  transition: all 0.2s ease;
}
.upload-area:hover .upload-placeholder[data-v-70b807b8] {
  border-color: #8B5CF6;
  background: #f8f9fa;
}

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

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

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

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

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

/* Пустое состояние */
.empty-state[data-v-70b807b8] {
  text-align: center;
  padding: 3rem 1rem;
  background: white;
  border-radius: 6px;
  border: 1px solid #e0e0e0;
}
.empty-content[data-v-70b807b8] {
  max-width: 400px;
  margin: 0 auto;
}
.empty-icon[data-v-70b807b8] {
  font-size: 4rem;
  margin-bottom: 1rem;
  color: #ccc;
}
.empty-content h4[data-v-70b807b8] {
  margin: 0 0 0.5rem 0;
  font-size: 1.2rem;
  color: #666;
}
.empty-content p[data-v-70b807b8] {
  margin: 0;
  color: #888;
}
.section-header[data-v-70b807b8] {
  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-70b807b8] {
  font-size: 0.8rem;
  font-weight: 600;
  color: #333;
  margin: 0;
  text-transform: uppercase;
}
.section-controls[data-v-70b807b8] {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}
.date-picker[data-v-70b807b8] {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  position: relative;
}
.date-input[data-v-70b807b8] {
  padding: 0.375rem 0.5rem;
  border: 1px solid #ddd;
  border-radius: 4px;
  font-size: 0.75rem;
  width: 140px;
  background: white;
}
.date-input[data-v-70b807b8]:focus {
  outline: none;
  border-color: #8B5CF6;
}
.search-icon[data-v-70b807b8] {
  font-size: 0.75rem;
  color: #666;
}
.chevron-btn[data-v-70b807b8] {
  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-70b807b8]:hover {
  background: #e0e0e0;
  color: #333;
}
.radiography-content[data-v-70b807b8] {
  padding: 1rem;
}

/* Секция с текстовым заключением */
.report-section[data-v-70b807b8] {
  margin-bottom: 1.5rem;
  padding: 1rem;
  background: #f8f9fa;
  border-radius: 6px;
  border: 1px solid #e9ecef;
}
.report-title[data-v-70b807b8] {
  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-70b807b8] {
  color: #333;
  line-height: 1.6;
  font-size: 0.9rem;
  white-space: pre-wrap;
  word-wrap: break-word;
}

/* Действия для блоков только с текстом */
.text-only-actions[data-v-70b807b8] {
  display: flex;
  justify-content: center;
  padding-top: 1rem;
  border-top: 1px solid #e9ecef;
  margin-top: 1rem;
}
.image-viewer[data-v-70b807b8] {
  position: relative;
  max-width: 600px;
  margin: 0 auto;
  border-radius: 4px;
  overflow: hidden;
  background: #1a1a1a;
}
.xray-image[data-v-70b807b8] {
  width: 100%;
  height: auto;
  display: block;
  cursor: pointer;
  transition: transform 0.2s ease;
}
.xray-image[data-v-70b807b8]:hover {
  transform: scale(1.02);
}
.fullscreen-overlay[data-v-70b807b8] {
  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-70b807b8] {
  opacity: 1;
}
.fullscreen-icon[data-v-70b807b8] {
  color: white;
  font-size: 1.2rem;
  display: block;
}
.image-actions[data-v-70b807b8] {
  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-70b807b8] {
  opacity: 1;
}
.btn[data-v-70b807b8] {
  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-70b807b8] {
  background: #dc3545;
  color: white;
}
.btn-danger[data-v-70b807b8]:hover {
  background: #c82333;
}
.btn-secondary[data-v-70b807b8] {
  background: #6c757d;
  color: white;
}
.btn-primary[data-v-70b807b8] {
  background: #8B5CF6;
  color: white;
}
.btn-primary[data-v-70b807b8]:hover {
  background: #7C3AED;
}
.btn-secondary[data-v-70b807b8]:hover {
  background: #5a6268;
}
.btn[data-v-70b807b8]:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}
.upload-area[data-v-70b807b8] {
  cursor: pointer;
  transition: all 0.2s ease;
}
.upload-icon[data-v-70b807b8] {
  font-size: 3rem;
  margin-bottom: 1rem;
  color: #666;
}
.upload-area p[data-v-70b807b8] {
  margin: 0 0 0.5rem 0;
  font-size: 1rem;
  color: #333;
}
.upload-area small[data-v-70b807b8] {
  color: #666;
  font-size: 0.875rem;
}
.upload-progress[data-v-70b807b8] {
  margin-top: 1rem;
  display: flex;
  align-items: center;
  gap: 1rem;
}
.progress-bar[data-v-70b807b8] {
  flex: 1;
  height: 4px;
  background: #e0e0e0;
  border-radius: 2px;
  overflow: hidden;
}
.progress-fill[data-v-70b807b8] {
  height: 100%;
  background: #8B5CF6;
  transition: width 0.3s ease;
}
.loading-overlay[data-v-70b807b8] {
  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-70b807b8] {
  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-70b807b8] {
  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-70b807b8] {
  position: relative;
  max-width: 90%;
  max-height: 90%;
  cursor: default;
}
.lightbox-image[data-v-70b807b8] {
  max-width: 100%;
  max-height: 100%;
  border-radius: 4px;
}
.lightbox-close[data-v-70b807b8] {
  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-70b807b8]:hover {
  background: rgba(255, 255, 255, 0.3);
}

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

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

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

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


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

/* Локальный индикатор загрузки */
.tab-loading-overlay[data-v-c38a1bea] {
  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-c38a1bea] {
  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-c38a1bea] {
  width: 32px;
  height: 32px;
  border: 3px solid #F3F4F6;
  border-top: 3px solid #8B5CF6;
  border-radius: 50%;
  animation: spin-c38a1bea 1s linear infinite;
}
@keyframes spin-c38a1bea {
0% { transform: rotate(0deg);
}
100% { transform: rotate(360deg);
}
}
.loading-text[data-v-c38a1bea] {
  margin: 0;
  font-size: 0.875rem;
  color: #6B7280;
  font-weight: 500;
}
.main-layout.loading[data-v-c38a1bea] {
  opacity: 0.6;
  pointer-events: none;
}
.main-layout[data-v-c38a1bea] {
  padding: 1rem;
  background: transparent;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.section[data-v-c38a1bea] {
  margin-bottom: 0;
  padding: 1.25rem;
  background: white;
  border-radius: 8px;
  border: 1px solid #E5E7EB;
  transition: border-color 0.2s ease;
}
.section[data-v-c38a1bea]:hover {
  border-color: #D1D5DB;
}

/* Minimalist section headers */
.section-header[data-v-c38a1bea] {
  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-c38a1bea] {
  font-size: 0.75rem;
  font-weight: 600;
  color: #6B7280;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin: 0;
}
.clear-section-btn[data-v-c38a1bea] {
  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-c38a1bea]:hover {
  background: #F9FAFB;
  border-color: #DC2626;
  color: #DC2626;
}

/* Minimalist forms */
.form-group[data-v-c38a1bea] {
  margin-bottom: 0.75rem;
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}
.field-label[data-v-c38a1bea] {
  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-c38a1bea] {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.selected-tags[data-v-c38a1bea] {
  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-c38a1bea], .joint-tag[data-v-c38a1bea] {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  background: #6B46C1;
  color: white;
  padding: 0.25rem 0.75rem;
  border-radius: 20px;
  font-size: 0.875rem;
}
.tag-remove[data-v-c38a1bea] {
  background: none;
  border: none;
  color: white;
  cursor: pointer;
  font-size: 1.2rem;
  padding: 0;
  margin-left: 0.25rem;
}
.tag-remove[data-v-c38a1bea]: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-c38a1bea], .no-joints[data-v-c38a1bea] {
  color: #6b7280;
  font-style: italic;
  padding: 0.25rem;
}
.checkbox-list[data-v-c38a1bea] {
  max-height: 240px;
  overflow-y: auto;
  border: 1px solid #e5e7eb;
  border-radius: 4px;
  padding: 0.5rem;
}

/* Чекбоксы */
.checkbox-item[data-v-c38a1bea] {
  display: flex;
  align-items: center;
  cursor: pointer;
  padding: 4px 0;
  margin-bottom: 0.5rem;
}
.checkbox-item[data-v-c38a1bea]:hover {
  background: #f3f4f6;
  border-radius: 4px;
  padding-left: 0.25rem;
}
.checkbox-item input[type="checkbox"][data-v-c38a1bea] {
  position: absolute;
  opacity: 0;
  cursor: pointer;
}
.checkbox-mark[data-v-c38a1bea] {
  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-c38a1bea] {
  background-color: #6B46C1;
  border-color: #6B46C1;
}
.checkbox-item input[type="checkbox"]:checked ~ .checkbox-mark[data-v-c38a1bea]::after {
  content: "✓";
  position: absolute;
  top: -2px;
  left: 2px;
  color: white;
  font-size: 12px;
  font-weight: bold;
}
.checkbox-text[data-v-c38a1bea] {
  font-size: 12px;
  color: #1F2937;
}

/* Переключатели */
.toggle-buttons[data-v-c38a1bea] {
  display: flex;
  gap: 8px;
}
.toggle-btn[data-v-c38a1bea] {
  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-c38a1bea] {
  background: #6B46C1;
  color: white;
}

/* Кнопки длительности утренней скованности */
.stiffness-duration-selector[data-v-c38a1bea] {
  margin-top: 8px;
}
.duration-options[data-v-c38a1bea] {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}
.duration-btn[data-v-c38a1bea] {
  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-c38a1bea]:hover {
  border-color: #6B46C1;
  background: #F3F4F6;
}
.duration-btn.active[data-v-c38a1bea] {
  background: #6B46C1;
  color: white;
  border-color: #6B46C1;
}

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

/* Диаграммы тела */
.body-diagrams[data-v-c38a1bea] {
  display: flex;
  gap: 48px;
  justify-content: center;
  margin: 32px 0;
  flex-wrap: wrap;
}
.diagram-container[data-v-c38a1bea] {
  text-align: center;
  flex: 1;
  min-width: 300px;
}
.diagram-wrapper[data-v-c38a1bea] {
  position: relative;
  display: inline-block;
  margin-bottom: 16px;
}
.body-image[data-v-c38a1bea] {
  width: 300px;
  height: auto;
  display: block;
}
.joint-point[data-v-c38a1bea] {
  position: absolute;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  border: 2px solid #6B46C1;
  background: white;
  cursor: grab;
  transition: all 0.2s;
  transform: translate(-50%, -50%);
  z-index: 5;
}
.joint-point[data-v-c38a1bea]:active {
  cursor: grabbing;
}
.joint-point[data-v-c38a1bea]: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-c38a1bea] {
  background: #6B46C1;
  border-color: #5B3BA4;
  box-shadow: 0 0 0 2px rgba(107, 70, 193, 0.4);
  z-index: 10;
}
.joint-point.active[data-v-c38a1bea]: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-c38a1bea] {
  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-c38a1bea] {
  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-c38a1bea] {
  font-size: 14px;
  font-weight: bold;
  color: #1F2937;
  margin: 8px 0;
  text-transform: uppercase;
}
.selected-joints[data-v-c38a1bea] {
  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-c38a1bea] {
  display: flex;
  gap: 8px;
  justify-content: center;
}
.control-btn[data-v-c38a1bea] {
  padding: 6px 12px;
  border: none;
  border-radius: 6px;
  font-size: 12px;
  cursor: pointer;
  transition: all 0.2s;
}
.control-btn.primary[data-v-c38a1bea] {
  background: #6B46C1;
  color: white;
}
.control-btn.secondary[data-v-c38a1bea] {
  background: #E5E7EB;
  color: #374151;
}

/* Медицинские шкалы */
.medical-scales[data-v-c38a1bea] {
  margin-top: 32px;
}
.scale-item[data-v-c38a1bea] {
  margin-bottom: 16px;
}
.scale-header[data-v-c38a1bea] {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 8px;
}
.scale-title[data-v-c38a1bea] {
  font-size: 14px;
  font-weight: bold;
  color: #1F2937;
  margin: 0;
  text-transform: uppercase;
}
.scale-value[data-v-c38a1bea] {
  font-size: 16px;
  font-weight: bold;
  color: #6B46C1;
}
.scale-value-input[data-v-c38a1bea] {
  display: flex;
  align-items: center;
  gap: 8px;
}
.value-input[data-v-c38a1bea] {
  width: 60px;
  padding: 6px 8px;
  border: 2px solid #6B46C1;
  border-radius: 6px;
  text-align: center;
  font-size: 14px;
  font-weight: bold;
  color: #1F2937;
  background: white;
  transition: all 0.2s;
}
.value-input[data-v-c38a1bea]:focus {
  outline: none;
  border-color: #8B5CF6;
  box-shadow: 0 0 0 3px rgba(107, 70, 193, 0.1);
}
.value-unit[data-v-c38a1bea] {
  font-size: 14px;
  font-weight: bold;
  color: #1F2937;
}
.assessment-slider[data-v-c38a1bea] {
  position: relative;
}
.color-scale[data-v-c38a1bea] {
  display: flex;
  height: 24px;
  border-radius: 4px;
  overflow: hidden;
  position: relative;
  border: 1px solid #E5E7EB;
}
.scale-segment[data-v-c38a1bea] {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 10px;
  color: white;
  font-weight: bold;
}
.scale-segment.blue[data-v-c38a1bea] {
  background: #6B46C1;
}
.scale-segment.green[data-v-c38a1bea] {
  background: #10B981;
}
.scale-segment.yellow[data-v-c38a1bea] {
  background: #F59E0B;
}
.scale-segment.red[data-v-c38a1bea] {
  background: #EF4444;
}
.scale-label[data-v-c38a1bea] {
  text-shadow: 1px 1px 2px rgba(0,0,0,0.5);
}
.scale-segment.active[data-v-c38a1bea] {
  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-c38a1bea] {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.calculated-value[data-v-c38a1bea] {
  font-size: 1.5rem;
  font-weight: bold;
  color: #6B46C1;
  min-width: 60px;
  text-align: right;
}
.scale-marker[data-v-c38a1bea] {
  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-c38a1bea] {
  margin-bottom: 8px;
  border: 1px solid #E5E7EB;
  border-radius: 4px;
  overflow: hidden;
}
.section-header[data-v-c38a1bea] {
  display: flex;
  align-items: center;
  padding: 12px 16px;
  background: white;
  cursor: pointer;
  transition: background-color 0.2s;
}
.section-header[data-v-c38a1bea]:hover {
  background: #F9FAFB;
}
.section-check[data-v-c38a1bea] {
  margin-right: 8px;
  font-size: 14px;
  color: #6B46C1;
}
.section-name[data-v-c38a1bea] {
  flex: 1;
  font-size: 14px;
  font-weight: 500;
  color: #1F2937;
  text-transform: uppercase;
}
.add-btn[data-v-c38a1bea] {
  padding: 4px 8px;
  background: #E5E7EB;
  border: none;
  border-radius: 4px;
  font-size: 12px;
  color: #374151;
  cursor: pointer;
}
.section-content[data-v-c38a1bea] {
  padding: 16px;
  background: #FAFAFA;
}
.subsection-item[data-v-c38a1bea] {
  margin-bottom: 12px;
  border: 1px solid #E5E7EB;
  border-radius: 4px;
  overflow: hidden;
}
.subsection-header[data-v-c38a1bea] {
  display: flex;
  align-items: center;
  padding: 8px 12px;
  background: white;
  cursor: pointer;
}
.subsection-name[data-v-c38a1bea] {
  flex: 1;
  font-size: 13px;
  color: #1F2937;
}
.subsection-content[data-v-c38a1bea] {
  padding: 12px;
  background: white;
}

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

/* Формы состояний */
.condition-form[data-v-c38a1bea] {
  background: white;
  padding: 16px;
  border-radius: 4px;
}
.form-row[data-v-c38a1bea] {
  margin-bottom: 12px;
}
.form-label[data-v-c38a1bea] {
  display: block;
  font-size: 12px;
  font-weight: bold;
  color: #1F2937;
  margin-bottom: 4px;
  text-transform: uppercase;
}
.form-input[data-v-c38a1bea] {
  width: 100%;
  padding: 8px 12px;
  border: 1px solid #E5E7EB;
  border-radius: 4px;
  font-size: 14px;
}
.input-with-delete[data-v-c38a1bea] {
  position: relative;
}
.delete-btn[data-v-c38a1bea] {
  position: absolute;
  right: 8px;
  top: 50%;
  transform: translateY(-50%);
  background: none;
  border: none;
  color: #EF4444;
  cursor: pointer;
  font-size: 16px;
}
.highlighted[data-v-c38a1bea] {
  text-decoration: underline;
  color: #6B46C1;
}
.activity-buttons[data-v-c38a1bea] {
  display: flex;
  gap: 8px;
  margin: 12px 0;
}
.activity-btn[data-v-c38a1bea] {
  padding: 6px 12px;
  border: none;
  border-radius: 4px;
  font-size: 12px;
  cursor: pointer;
  background: #E5E7EB;
  color: #374151;
}
.activity-btn.active[data-v-c38a1bea] {
  background: #6B46C1;
  color: white;
}
.add-form-btn[data-v-c38a1bea] {
  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-c38a1bea] {
    padding: 16px;
}
.body-diagrams[data-v-c38a1bea] {
    flex-direction: column;
    gap: 24px;
}
.diagram-container[data-v-c38a1bea] {
    min-width: auto;
}
.body-image[data-v-c38a1bea] {
    width: 250px;
}
.save-button-container[data-v-c38a1bea] {
    flex-direction: column;
    align-items: stretch;
    gap: 0.75rem;
}
.autosave-info[data-v-c38a1bea] {
    min-width: auto;
}
.autosave-text[data-v-c38a1bea] {
    font-size: 0.7rem;
    justify-content: center;
}
  
  /* Увеличиваем точки суставов для удобства тапа на мобильных */
.joint-point[data-v-c38a1bea] {
    width: 14px;
    height: 14px;
    border-width: 3px;
}
.joint-point[data-v-c38a1bea]:hover {
    transform: translate(-50%, -50%) scale(1.3);
}
.joint-point.active[data-v-c38a1bea]:hover {
    transform: translate(-50%, -50%) scale(1.3);
}
.weight-controls[data-v-c38a1bea] {
    flex-direction: column;
    align-items: stretch;
}
.slider-labels[data-v-c38a1bea] {
    flex-direction: column;
    gap: 4px;
}
.label-left[data-v-c38a1bea],
  .label-right[data-v-c38a1bea] {
    text-align: left;
    max-width: none;
}
}
@media (max-width: 480px) {
.body-image[data-v-c38a1bea] {
    width: 200px;
}
  
  /* Еще больше увеличиваем точки для очень маленьких экранов */
.joint-point[data-v-c38a1bea] {
    width: 16px;
    height: 16px;
    border-width: 3px;
}
}

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

/* Панель разработчика */
.developer-panel[data-v-c38a1bea] {
  background: #f0f0f0;
  border: 2px dashed #6B46C1;
  padding: 16px;
  margin-bottom: 20px;
  border-radius: 8px;
}
.dev-btn[data-v-c38a1bea] {
  background: #6B46C1;
  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-c38a1bea]:hover {
  background: #5B3BA4;
}
.dev-btn.active[data-v-c38a1bea] {
  background: #10B981;
  box-shadow: 0 0 0 2px rgba(16, 185, 129, 0.3);
}
.dev-btn.clear[data-v-c38a1bea] {
  background: #EF4444;
}
.dev-btn.clear[data-v-c38a1bea]:hover {
  background: #DC2626;
}
.dev-btn.copy[data-v-c38a1bea] {
  background: #F59E0B;
}
.dev-btn.copy[data-v-c38a1bea]:hover {
  background: #D97706;
}
.dev-controls[data-v-c38a1bea] {
  margin-top: 12px;
}
.dev-controls p[data-v-c38a1bea] {
  margin: 0 0 12px 0;
  font-size: 14px;
  color: #666;
}
.coordinates-list[data-v-c38a1bea] {
  margin-top: 16px;
  background: white;
  padding: 12px;
  border-radius: 4px;
  max-height: 200px;
  overflow-y: auto;
}
.coordinates-list h4[data-v-c38a1bea] {
  margin: 0 0 8px 0;
  font-size: 14px;
  color: #6B46C1;
}
.coord-item[data-v-c38a1bea] {
  font-family: monospace;
  font-size: 12px;
  padding: 4px 0;
  border-bottom: 1px solid #eee;
}
.coord-item[data-v-c38a1bea]:last-child {
  border-bottom: none;
}
.all-coordinates-list[data-v-c38a1bea] {
  margin-top: 20px;
  background: white;
  padding: 16px;
  border-radius: 4px;
  border: 1px solid #E5E7EB;
}
.coordinates-textarea-wrapper[data-v-c38a1bea] {
  margin-top: 8px;
}
.coordinates-textarea[data-v-c38a1bea] {
  width: 100%;
  min-height: 300px;
  padding: 12px;
  border: 2px solid #6B46C1;
  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-c38a1bea]:focus {
  outline: none;
  border-color: #10B981;
  background: white;
  box-shadow: 0 0 0 3px rgba(16, 185, 129, 0.1);
}

/* Кликнутые точки */
.clicked-point[data-v-c38a1bea] {
  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-c38a1bea]:hover {
  transform: translate(-50%, -50%) scale(1.2);
}
.instruction-box[data-v-c38a1bea] {
  background: #F3F4F6;
  border-left: 4px solid #6B46C1;
  padding: 12px;
  margin-bottom: 16px;
  border-radius: 4px;
}
.instruction-box p[data-v-c38a1bea] {
  margin: 0 0 8px 0;
  font-size: 14px;
  color: #374151;
}
.instruction-box ol[data-v-c38a1bea] {
  margin: 8px 0;
  padding-left: 20px;
  font-size: 13px;
  color: #6B7280;
}
.instruction-box li[data-v-c38a1bea] {
  margin-bottom: 4px;
}
.instruction-box em[data-v-c38a1bea] {
  font-size: 12px;
  color: #9CA3AF;
  display: block;
  margin-top: 8px;
}

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

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

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

/* Автосохранение информация */
.autosave-info[data-v-c38a1bea] {
  display: flex;
  align-items: center;
  min-width: 250px;
}
.autosave-text[data-v-c38a1bea] {
  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-c38a1bea] {
  width: 16px;
  height: 16px;
  color: #10B981;
  flex-shrink: 0;
}
.test-save-btn[data-v-c38a1bea] {
  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-c38a1bea]:hover:not(:disabled) {
  background: #D97706;
  transform: translateY(-1px);
  box-shadow: 0 4px 8px rgba(213, 145, 16, 0.3);
}
.test-save-btn[data-v-c38a1bea]:disabled {
  background: #9CA3AF;
  cursor: not-allowed;
  transform: none;
  box-shadow: none;
}

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


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

/* Локальный индикатор загрузки */
.tab-loading-overlay[data-v-0d8a72e0] {
  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-0d8a72e0] {
  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-0d8a72e0] {
  width: 32px;
  height: 32px;
  border: 3px solid #F3F4F6;
  border-top: 3px solid #8B5CF6;
  border-radius: 50%;
  animation: spin-0d8a72e0 1s linear infinite;
}
@keyframes spin-0d8a72e0 {
0% { transform: rotate(0deg);
}
100% { transform: rotate(360deg);
}
}
.loading-text[data-v-0d8a72e0] {
  margin: 0;
  font-size: 0.875rem;
  color: #6B7280;
  font-weight: 500;
}
.main-layout.loading[data-v-0d8a72e0] {
  opacity: 0.6;
  pointer-events: none;
}
.main-layout[data-v-0d8a72e0] {
  padding: 1rem;
  background: transparent;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.section[data-v-0d8a72e0] {
  margin-bottom: 0;
  padding: 1.25rem;
  background: white;
  border-radius: 8px;
  border: 1px solid #E5E7EB;
  transition: border-color 0.2s ease;
}
.section[data-v-0d8a72e0]:hover {
  border-color: #D1D5DB;
}

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

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

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

/* Minimalist save section */
.save-actions[data-v-0d8a72e0] {
  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-0d8a72e0] {
  background: #8B5CF6;
  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-0d8a72e0]:hover:not(:disabled) {
  background: #7C3AED;
}
.save-btn[data-v-0d8a72e0]:disabled {
  background: #D1D5DB;
  color: #9CA3AF;
  cursor: not-allowed;
}

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

/* Стили для поиска лекарств */
.drug-search-section[data-v-0d8a72e0] {
  margin-bottom: 1.5rem;
}
.search-container[data-v-0d8a72e0] {
  background: #F9FAFB;
  border: 1px solid #E5E7EB;
  border-radius: 8px;
  padding: 1rem;
}
.search-input-group[data-v-0d8a72e0] {
  position: relative;
}
.search-input[data-v-0d8a72e0] {
  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-0d8a72e0]:focus {
  outline: none;
  border-color: #8B5CF6;
  box-shadow: 0 0 0 3px rgba(139, 92, 246, 0.1);
}
.clear-search-btn[data-v-0d8a72e0] {
  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-0d8a72e0]:hover {
  background: #F3F4F6;
  color: #6B7280;
}
.search-spinner[data-v-0d8a72e0] {
  width: 16px;
  height: 16px;
  border: 2px solid #F3F4F6;
  border-top: 2px solid #8B5CF6;
  border-radius: 50%;
  animation: spin-0d8a72e0 1s linear infinite;
}
.no-results[data-v-0d8a72e0] {
  text-align: center;
  padding: 1rem;
  color: #6B7280;
  font-size: 0.875rem;
}
.no-results p[data-v-0d8a72e0] {
  margin: 0;
}

/* Стили для классов лекарств */
.drug-classes-section[data-v-0d8a72e0] {
  margin-bottom: 1.5rem;
}
.loading-classes[data-v-0d8a72e0] {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  color: #6B7280;
  font-size: 0.875rem;
  padding: 1rem;
  justify-content: center;
}
.drug-classes-list[data-v-0d8a72e0] {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.drug-class-item[data-v-0d8a72e0] {
  background: white;
  border: 1px solid #E5E7EB;
  border-radius: 8px;
  overflow: hidden;
  transition: border-color 0.2s;
}
.drug-class-item[data-v-0d8a72e0]:hover {
  border-color: #D1D5DB;
}
.drug-class-header[data-v-0d8a72e0] {
  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-0d8a72e0]:hover {
  background: #F3F4F6;
}
.class-name[data-v-0d8a72e0] {
  font-size: 0.875rem;
  font-weight: 600;
  color: #1F2937;
}
.class-arrow[data-v-0d8a72e0] {
  font-size: 0.75rem;
  color: #6B7280;
  transition: transform 0.2s;
  transform: rotate(-90deg);
}
.class-arrow.expanded[data-v-0d8a72e0] {
  transform: rotate(0deg);
}
.drug-class-content[data-v-0d8a72e0] {
  padding: 0.75rem 1rem;
  background: white;
  border-top: 1px solid #E5E7EB;
}
.loading-drugs[data-v-0d8a72e0] {
  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-0d8a72e0] {
  text-align: center;
  padding: 1rem;
  color: #9CA3AF;
  font-size: 0.875rem;
}
.drugs-list[data-v-0d8a72e0] {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.drug-item-wrapper[data-v-0d8a72e0] {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.drug-item[data-v-0d8a72e0] {
  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-0d8a72e0]:hover {
  border-color: #D1D5DB;
  background: #F3F4F6;
}

/* Inline форма для недавно добавленного лекарства */
.inline-drug-form[data-v-0d8a72e0] {
  background: #F0F9FF;
  border: 2px solid #8B5CF6;
  border-radius: 8px;
  padding: 1rem;
  margin-top: 0.5rem;
  animation: slideDown-0d8a72e0 0.3s ease-out;
}
@keyframes slideDown-0d8a72e0 {
from {
    opacity: 0;
    transform: translateY(-10px);
}
to {
    opacity: 1;
    transform: translateY(0);
}
}
.inline-form-header[data-v-0d8a72e0] {
  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-0d8a72e0] {
  font-size: 0.875rem;
  font-weight: 600;
  color: #1F2937;
}
.inline-form-close[data-v-0d8a72e0] {
  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-0d8a72e0]:hover {
  background: #FEE2E2;
  color: #DC2626;
}
.inline-form-fields[data-v-0d8a72e0] {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
}
.inline-field-group[data-v-0d8a72e0] {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.inline-field-label[data-v-0d8a72e0] {
  font-size: 0.75rem;
  color: #6B7280;
  font-weight: 500;
  text-transform: uppercase;
}
.inline-date-input[data-v-0d8a72e0] {
  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-0d8a72e0]:focus {
  outline: none;
  border-color: #8B5CF6;
  box-shadow: 0 0 0 3px rgba(139, 92, 246, 0.1);
}
.inline-button-group[data-v-0d8a72e0] {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}
.inline-dose-method-btn[data-v-0d8a72e0] {
  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-0d8a72e0]:hover {
  background: #F3F4F6;
  border-color: #9CA3AF;
}
.inline-dose-method-btn.active[data-v-0d8a72e0] {
  background: #8B5CF6;
  color: white;
  border-color: #8B5CF6;
}
.inline-no-data[data-v-0d8a72e0] {
  font-size: 0.75rem;
  color: #9CA3AF;
  padding: 0.5rem;
  text-align: center;
  width: 100%;
}

/* Кнопки действий в inline форме */
.inline-form-actions[data-v-0d8a72e0] {
  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-0d8a72e0] {
  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-0d8a72e0]:hover {
  background: #E5E7EB;
  border-color: #9CA3AF;
}
.inline-delete-btn[data-v-0d8a72e0] {
  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-0d8a72e0]:hover {
  background: #FECACA;
  border-color: #F87171;
  color: #B91C1C;
}

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

/* Стили для нижнего списка добавленных лекарств */
.completed-drugs-section[data-v-0d8a72e0] {
  margin-top: 1.5rem;
}
.completed-drugs-list[data-v-0d8a72e0] {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}
.completed-drug-card[data-v-0d8a72e0] {
  background: white;
  border: 1px solid #E5E7EB;
  border-radius: 8px;
  padding: 1rem;
  transition: border-color 0.2s;
}
.completed-drug-card[data-v-0d8a72e0]:hover {
  border-color: #D1D5DB;
}
.completed-drug-card.has-validation-errors[data-v-0d8a72e0] {
  border-color: #DC2626;
  background: #FEF2F2;
}
.completed-drug-card.has-validation-errors[data-v-0d8a72e0]:hover {
  border-color: #B91C1C;
}
.completed-drug-header[data-v-0d8a72e0] {
  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-0d8a72e0] {
  font-size: 0.875rem;
  font-weight: 600;
  color: #1F2937;
}
.completed-drug-remove[data-v-0d8a72e0] {
  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-0d8a72e0]:hover {
  background: #FEE2E2;
  color: #DC2626;
}
.completed-drug-info[data-v-0d8a72e0] {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0.75rem;
}
.completed-drug-field[data-v-0d8a72e0] {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}
.completed-field-label[data-v-0d8a72e0] {
  font-size: 0.75rem;
  color: #6B7280;
  font-weight: 500;
  text-transform: uppercase;
}
.completed-field-value[data-v-0d8a72e0] {
  font-size: 0.875rem;
  color: #1F2937;
  font-weight: 500;
}
.completed-field-value.error-value[data-v-0d8a72e0] {
  color: #DC2626;
  font-weight: 600;
}
.completed-drug-field.has-error .completed-field-label[data-v-0d8a72e0] {
  color: #DC2626;
}
.completed-error-message[data-v-0d8a72e0] {
  font-size: 0.75rem;
  color: #DC2626;
  margin-top: 0.25rem;
  font-weight: 500;
}

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

/* Стили для уведомления об успешном сохранении */
.success-notification[data-v-0d8a72e0] {
  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-0d8a72e0] {
  opacity: 1;
  transform: translateX(0);
}
.success-notification-icon[data-v-0d8a72e0] {
  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-0d8a72e0] {
  flex: 1;
}

/* Стили для глобального сообщения об ошибке */
.error-message-global[data-v-0d8a72e0] {
  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-0d8a72e0] {
  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-0d8a72e0] {
  opacity: 1;
  transform: translateX(0);
}
.warning-notification-icon[data-v-0d8a72e0] {
  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-0d8a72e0] {
  flex: 1;
}
.success-notification-icon[data-v-0d8a72e0] {
  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-0d8a72e0] {
  flex: 1;
}

/* Стили для глобального сообщения об ошибке */
.error-message-global[data-v-0d8a72e0] {
  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-0d8a72e0] {
  font-size: 0.875rem;
  color: #1F2937;
  font-weight: 500;
}
.result-name[data-v-0d8a72e0] {
  font-size: 0.875rem;
  color: #1F2937;
  font-weight: 500;
}
.add-drug-btn[data-v-0d8a72e0] {
  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-0d8a72e0]:hover:not(:disabled) {
  background: #059669;
}
.add-drug-btn[data-v-0d8a72e0]:disabled {
  background: #D1D5DB;
  color: #9CA3AF;
  cursor: not-allowed;
}
.no-results[data-v-0d8a72e0] {
  text-align: center;
  padding: 1rem;
  color: #6B7280;
  font-size: 0.875rem;
}
.no-results p[data-v-0d8a72e0] {
  margin: 0;
}

/* Стили для кнопок управления лекарствами */
.card-actions[data-v-0d8a72e0] {
  display: flex;
  gap: 0.5rem;
  align-items: center;
}
.remove-drug-btn[data-v-0d8a72e0] {
  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-0d8a72e0]:hover {
  background: #FDE68A;
  border-color: #F59E0B;
  color: #B45309;
}

/* Стили для кнопки очистки полей */
.clear-btn[data-v-0d8a72e0] {
  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-0d8a72e0]:hover {
  background: #FEE2E2;
  color: #DC2626;
}

/* Стили для select элементов */
.form-select[data-v-0d8a72e0] {
  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-0d8a72e0]:focus {
  outline: none;
  border-color: #6B46C1;
  box-shadow: 0 0 0 3px rgba(107, 70, 193, 0.1);
}

/* Стили для группы кнопок дозировки и метода применения */
.button-group[data-v-0d8a72e0] {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-top: 0.25rem;
}
.dose-method-btn[data-v-0d8a72e0] {
  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-0d8a72e0]: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-0d8a72e0] {
  background: #8B5CF6;
  color: white;
  border-color: #8B5CF6;
  box-shadow: 0 2px 4px rgba(139, 92, 246, 0.3);
}
.dose-method-btn.active[data-v-0d8a72e0]:hover {
  background: #7C3AED;
  border-color: #7C3AED;
}
.no-data-message[data-v-0d8a72e0] {
  font-size: 12px;
  color: #9CA3AF;
  margin-top: 4px;
  padding: 0.5rem;
  text-align: center;
  width: 100%;
}



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


.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;
}
.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-466fed4a] {
  padding: 0;
  max-width: 1200px;
  margin: 0 auto;
  position: relative;
}

/* Локальный индикатор загрузки */
.tab-loading-overlay[data-v-466fed4a] {
  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-466fed4a] {
  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-466fed4a] {
  width: 32px;
  height: 32px;
  border: 3px solid #F3F4F6;
  border-top: 3px solid #8B5CF6;
  border-radius: 50%;
  animation: spin-466fed4a 1s linear infinite;
}
@keyframes spin-466fed4a {
0% { transform: rotate(0deg);
}
100% { transform: rotate(360deg);
}
}
.loading-text[data-v-466fed4a] {
  margin: 0;
  font-size: 0.875rem;
  color: #6B7280;
  font-weight: 500;
}
.main-layout.loading[data-v-466fed4a] {
  opacity: 0.6;
  pointer-events: none;
}
.main-layout[data-v-466fed4a] {
  padding: 1rem;
  background: transparent;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.section[data-v-466fed4a] {
  margin-bottom: 0;
  padding: 1.25rem;
  background: white;
  border-radius: 8px;
  border: 1px solid #E5E7EB;
  transition: border-color 0.2s ease;
}
.section[data-v-466fed4a]:hover {
  border-color: #D1D5DB;
}

/* Minimalist section headers */
.section-header[data-v-466fed4a] {
  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-466fed4a] {
  font-size: 0.75rem;
  font-weight: 600;
  color: #6B7280;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin: 0;
}
.clear-section-btn[data-v-466fed4a] {
  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-466fed4a]:hover {
  background: #F9FAFB;
  border-color: #DC2626;
  color: #DC2626;
}
.section-content[data-v-466fed4a] {
  padding: 0;
}
.question[data-v-466fed4a] {
  margin-bottom: 20px;
}
.question-text[data-v-466fed4a] {
  font-size: 12px;
  color: #1F2937;
  margin-bottom: 12px;
  line-height: 1.4;
}
.answer-buttons[data-v-466fed4a] {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}
.answer-btn[data-v-466fed4a] {
  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-466fed4a]:hover {
  background: #D1D5DB;
}
.answer-btn.active[data-v-466fed4a] {
  background: #6B46C1;
  color: white;
}
.checkbox-list[data-v-466fed4a] {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-bottom: 16px;
}
.checkbox-item[data-v-466fed4a] {
  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-466fed4a] {
  -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-466fed4a]:checked {
  background: #3B82F6;
  border-color: #3B82F6;
}
.checkbox-item input[type="checkbox"][data-v-466fed4a]:checked::after {
  content: '✓';
  position: absolute;
  top: -1px;
  left: 2px;
  color: white;
  font-size: 11px;
  font-weight: bold;
}
.checkmark[data-v-466fed4a] {
  /* Hidden as we use CSS pseudo-element instead */
  display: none;
}
.other-input[data-v-466fed4a] {
  margin: 12px 0;
}
.other-text-input[data-v-466fed4a] {
  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-466fed4a]:focus {
  outline: none;
  border-color: #6B46C1;
  box-shadow: 0 0 0 2px rgba(107, 70, 193, 0.1);
}

/* Стили для текстовых полей */
.text-input[data-v-466fed4a] {
  margin: 12px 0;
}
.text-field[data-v-466fed4a] {
  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-466fed4a]:focus {
  outline: none;
  border-color: #6B46C1;
  box-shadow: 0 0 0 2px rgba(107, 70, 193, 0.1);
}
.add-btn[data-v-466fed4a] {
  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-466fed4a]:hover {
  background: #E5E7EB;
}
.save-section[data-v-466fed4a] {
  margin-top: 3rem;
  text-align: center;
  padding: 2rem 0;
  border-top: 1px solid #E5E7EB;
}
.save-btn[data-v-466fed4a] {
  background: #6B46C1;
  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-466fed4a]:hover:not(:disabled) {
  background: #553C9A;
  transform: translateY(-1px);
}
.save-btn[data-v-466fed4a]:disabled {
  background: #9CA3AF;
  cursor: not-allowed;
  transform: none;
}
@media (max-width: 768px) {
.nao-tab[data-v-466fed4a] {
    padding: 1rem;
}
.answer-buttons[data-v-466fed4a] {
    flex-direction: column;
    align-items: flex-start;
}
.answer-btn[data-v-466fed4a] {
    width: auto;
    min-width: 180px;
}
}

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

/* Minimalist save section */
.save-actions[data-v-466fed4a] {
  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-466fed4a] {
  background: #8B5CF6;
  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-466fed4a]:hover:not(:disabled) {
  background: #7C3AED;
}
.save-btn[data-v-466fed4a]:disabled {
  background: #D1D5DB;
  color: #9CA3AF;
  cursor: not-allowed;
}
.unsaved-indicator[data-v-466fed4a] {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.75rem;
  color: #F59E0B;
  margin-left: 1rem;
}
.unsaved-dot[data-v-466fed4a] {
  color: #F59E0B;
  font-size: 1rem;
  animation: blink-466fed4a 1.5s infinite;
}
@keyframes blink-466fed4a {
0%, 50% { opacity: 1;
}
51%, 100% { opacity: 0.3;
}
}
.unsaved-text[data-v-466fed4a] {
  font-weight: 500;
}


.autosave-notification-container[data-v-38ccbb0c] {
  position: fixed;
  top: 20px;
  right: 20px;
  z-index: 9999;
  pointer-events: none;
}
.autosave-notification[data-v-38ccbb0c] {
  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-38ccbb0c]::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: #10B981;
  border-radius: 12px 12px 0 0;
}
.notification-saving[data-v-38ccbb0c]::before {
  background: #8B5CF6;
}
.notification-error[data-v-38ccbb0c]::before {
  background: #EF4444;
}
.notification-content[data-v-38ccbb0c] {
  display: flex;
  align-items: center;
  gap: 12px;
}
.notification-icon[data-v-38ccbb0c] {
  flex-shrink: 0;
  width: 24px;
  height: 24px;
  color: #10B981;
}
.notification-saving .notification-icon[data-v-38ccbb0c] {
  color: #8B5CF6;
}
.notification-error .notification-icon[data-v-38ccbb0c] {
  color: #EF4444;
}
.spinner[data-v-38ccbb0c] {
  animation: spin-38ccbb0c 1s linear infinite;
}
.spinner circle[data-v-38ccbb0c] {
  animation: dash-38ccbb0c 1.5s ease-in-out infinite;
}
@keyframes spin-38ccbb0c {
0% { transform: rotate(0deg);
}
100% { transform: rotate(360deg);
}
}
@keyframes dash-38ccbb0c {
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-38ccbb0c] {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.notification-title[data-v-38ccbb0c] {
  font-size: 14px;
  font-weight: 600;
  color: #1F2937;
  line-height: 1.2;
}
.notification-subtitle[data-v-38ccbb0c] {
  font-size: 12px;
  color: #6B7280;
  line-height: 1.2;
}

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

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


.patient-profile[data-v-32fd69dc] {
  min-height: 100vh;
  background-color: #ffffff;
}
.header[data-v-32fd69dc] {
  background: #8B5CF6;
  color: white;
  padding: 0.75rem 0;
  border-bottom: 1px solid #E5E7EB;
}
.header-content[data-v-32fd69dc] {
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0 1rem;
}
.title-section[data-v-32fd69dc] {
  flex: 1;
}
.title[data-v-32fd69dc] {
  font-size: 1.25rem;
  font-weight: 600;
  letter-spacing: 0.25px;
  margin-bottom: 0.25rem;
}
.breadcrumb[data-v-32fd69dc] {
  font-size: 0.8rem;
  opacity: 0.9;
}
.patient-name-accent[data-v-32fd69dc] {
  font-weight: 600;
  color: #e3f2fd;
}
.header-actions[data-v-32fd69dc] {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}
.search-container[data-v-32fd69dc] {
  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-32fd69dc]::-moz-placeholder {
  color: white !important;
  opacity: 1 !important;
}
.search-container .search-input[data-v-32fd69dc]::placeholder {
  color: white !important;
  opacity: 1 !important;
}
.search-container .search-input[data-v-32fd69dc]::-webkit-input-placeholder {
  color: white !important;
  opacity: 1 !important;
}
.search-container .search-input[data-v-32fd69dc]::-moz-placeholder {
  color: white !important;
  opacity: 1 !important;
}
.search-container .search-input[data-v-32fd69dc]:-ms-input-placeholder {
  color: white !important;
  opacity: 1 !important;
}
.search-input[data-v-32fd69dc] {
  background: transparent;
  border: none;
  color: white;
  padding: 0.25rem 0.5rem;
  font-size: 0.875rem;
  outline: none;
  min-width: 180px;
}
.search-input[data-v-32fd69dc]::-moz-placeholder {
  color: white !important;
  opacity: 1 !important;
}
.search-input[data-v-32fd69dc]::placeholder {
  color: white !important;
  opacity: 1 !important;
}
.search-input[data-v-32fd69dc]::-webkit-input-placeholder {
  color: white !important;
  opacity: 1 !important;
}
.search-input[data-v-32fd69dc]::-moz-placeholder {
  color: white !important;
  opacity: 1 !important;
}
.search-input[data-v-32fd69dc]:-ms-input-placeholder {
  color: white !important;
  opacity: 1 !important;
}
.search-btn[data-v-32fd69dc] {
  background: none;
  border: none;
  color: white;
  font-size: 1rem;
  cursor: pointer;
  padding: 0.25rem;
}
.navigation-buttons[data-v-32fd69dc] {
  display: flex;
  gap: 0.5rem;
}
.nav-btn[data-v-32fd69dc] {
  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-32fd69dc]:hover {
  background: rgba(255,255,255,0.25);
  transform: translateY(-1px);
}



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

/* Календарь приемов */
.visits-calendar[data-v-32fd69dc] {
  margin-bottom: 1rem;
  padding: 0.75rem;
  background: white;
  border: 1px solid #E5E7EB;
  border-radius: 8px;
}
.calendar-header[data-v-32fd69dc] {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 0.75rem;
  gap: 0.25rem;
  flex-wrap: wrap;
}
.calendar-month-year[data-v-32fd69dc] {
  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-32fd69dc] {
  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-32fd69dc]:hover {
  background: #E5E7EB;
  color: #1F2937;
}
.calendar-grid[data-v-32fd69dc] {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 2px;
}
.calendar-weekday[data-v-32fd69dc] {
  text-align: center;
  font-size: 0.7rem;
  font-weight: 600;
  color: #6B7280;
  padding: 0.25rem 0;
}
.calendar-day[data-v-32fd69dc] {
  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-32fd69dc] {
  background: transparent;
  cursor: default;
}
.calendar-day-number[data-v-32fd69dc] {
  line-height: 1;
}
.calendar-day-dot[data-v-32fd69dc] {
  width: 4px;
  height: 4px;
  border-radius: 999px;
  background: #8B5CF6;
  margin-top: 2px;
}
.calendar-day[data-v-32fd69dc]:not(.empty):hover {
  background: #E5E7EB;
  transform: scale(1.05);
}
.calendar-day.has-visit[data-v-32fd69dc] {
  background: #EDE9FE;
  color: #7C3AED;
  font-weight: 600;
}
.calendar-day.has-visit[data-v-32fd69dc]:hover {
  background: #DDD6FE;
  transform: scale(1.1);
}
.calendar-day.today[data-v-32fd69dc] {
  background: #8B5CF6;
  color: white;
  font-weight: 600;
}
.calendar-day.today.has-visit[data-v-32fd69dc] {
  background: #7C3AED;
  color: white;
}

/* Выделение выбранных дат в календаре */
.calendar-day.selected-from[data-v-32fd69dc] {
  background: #8B5CF6;
  color: white;
  font-weight: 700;
  box-shadow: 0 0 0 2px #8B5CF6;
}
.calendar-day.selected-to[data-v-32fd69dc] {
  background: #8B5CF6;
  color: white;
  font-weight: 700;
  box-shadow: 0 0 0 2px #8B5CF6;
}
.calendar-day.in-range[data-v-32fd69dc] {
  background: #EDE9FE;
  color: #7C3AED;
  font-weight: 600;
}
.calendar-day.in-range.has-visit[data-v-32fd69dc] {
  background: #DDD6FE;
  color: #6D28D9;
}
.calendar-day.selected-from.has-visit[data-v-32fd69dc],
.calendar-day.selected-to.has-visit[data-v-32fd69dc] {
  background: #7C3AED;
  color: white;
}
.calendar-day.today.selected-from[data-v-32fd69dc],
.calendar-day.today.selected-to[data-v-32fd69dc] {
  background: #6D28D9;
  color: white;
}

/* Информация о выбранном диапазоне */
.date-range-info[data-v-32fd69dc] {
  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-32fd69dc] {
  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-32fd69dc] {
  font-weight: 600;
  color: #7C3AED;
  white-space: nowrap;
}
.date-filter-clear-btn[data-v-32fd69dc] {
  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-32fd69dc]:hover {
  background: #EF4444;
  color: white;
  border-color: #EF4444;
}

/* Пагинация приемов */
.visits-pagination[data-v-32fd69dc] {
  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-32fd69dc] {
  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-32fd69dc]:hover:not(:disabled) {
  background: #E5E7EB;
  color: #1F2937;
}
.pagination-btn[data-v-32fd69dc]:disabled {
  opacity: 0.4;
  cursor: not-allowed;
}
.pagination-info[data-v-32fd69dc] {
  font-size: 0.75rem;
  font-weight: 600;
  color: #6B7280;
  min-width: 50px;
  text-align: center;
}
.content[data-v-32fd69dc] {
  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-32fd69dc] {
  padding: 1rem 1.25rem;
  border-bottom: 1px solid #E5E7EB;
  background: #FAFAFA;
}
.patient-name[data-v-32fd69dc] {
  font-size: 1.25rem;
  font-weight: 600;
  color: #1F2937;
  margin-bottom: 0.375rem;
}
.patient-info[data-v-32fd69dc] {
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
}
.patient-detail[data-v-32fd69dc] {
  display: flex;
  flex-direction: column;
  gap: 0.125rem;
}
.label[data-v-32fd69dc] {
  font-size: 0.65rem;
  color: #6B7280;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.25px;
}
.value[data-v-32fd69dc] {
  font-size: 0.8rem;
  color: #1F2937;
  font-weight: 500;
}
.tabs[data-v-32fd69dc] {
  display: flex;
  background: #F8FAFC;
  border-bottom: 1px solid #E5E7EB;
  overflow-x: auto;
}
.tab[data-v-32fd69dc] {
  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-32fd69dc]:hover {
  color: #8B5CF6;
  background: rgba(139, 92, 246, 0.08);
}
.tab.active[data-v-32fd69dc] {
  color: #8B5CF6;
  background: white;
  border-bottom-color: #8B5CF6;
  font-weight: 600;
}
.tab-content[data-v-32fd69dc] {
  padding: 0;
  min-height: 400px;
  background: #FAFAFA;
}

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

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



/* Минималистичное модальное окно */
.modal-overlay[data-v-32fd69dc] {
  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-32fd69dc] {
  background: white;
  border-radius: 8px;
  width: 90%;
  max-width: 450px;
  max-height: 80vh;
  overflow-y: auto;
  border: 1px solid #E5E7EB;
}
.modal-header[data-v-32fd69dc] {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1rem;
  border-bottom: 1px solid #F3F4F6;
}
.modal-header h3[data-v-32fd69dc] {
  margin: 0;
  font-size: 1.125rem;
  font-weight: 600;
  color: #1F2937;
}
.close-btn[data-v-32fd69dc] {
  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-32fd69dc]:hover {
  background: #F9FAFB;
  border-color: #D1D5DB;
}
.modal-body[data-v-32fd69dc] {
  padding: 1rem;
}
.form-group[data-v-32fd69dc] {
  margin-bottom: 0.875rem;
}
.form-group label[data-v-32fd69dc] {
  display: block;
  margin-bottom: 0.375rem;
  font-weight: 500;
  color: #374151;
  font-size: 0.8rem;
}
.form-select[data-v-32fd69dc],
.form-input[data-v-32fd69dc] {
  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-32fd69dc]:focus,
.form-input[data-v-32fd69dc]:focus {
  outline: none;
  border-color: #8B5CF6;
}

/* Информация о враче в форме создания приема */
.doctor-info[data-v-32fd69dc] {
  background: #f8fafc;
  border: 1px solid #e2e8f0;
  border-radius: 8px;
  padding: 1rem;
  margin-bottom: 1rem;
}
.info-label[data-v-32fd69dc] {
  display: block;
  margin-bottom: 0.75rem;
  font-weight: 600;
  color: #374151;
  font-size: 0.9rem;
}
.assigned-doctor[data-v-32fd69dc] {
  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-32fd69dc] {
  font-size: 1.2rem;
}
.doctor-name[data-v-32fd69dc] {
  font-size: 0.9rem;
  color: #374151;
  font-weight: 500;
}
.auto-assignment-note[data-v-32fd69dc] {
  font-size: 0.8rem;
  color: #6b7280;
  font-style: italic;
  margin: 0;
  text-align: center;
}
.modal-footer[data-v-32fd69dc] {
  display: flex;
  justify-content: flex-end;
  gap: 0.75rem;
  padding: 1rem;
  border-top: 1px solid #F3F4F6;
  background: #FAFAFA;
}
.btn[data-v-32fd69dc] {
  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-32fd69dc] {
  background: #F3F4F6;
  color: #374151;
  border: 1px solid #E5E7EB;
}
.btn-cancel[data-v-32fd69dc]:hover {
  background: #E5E7EB;
}
.btn-primary[data-v-32fd69dc] {
  background: #8B5CF6;
  color: white;
}
.btn-primary[data-v-32fd69dc]:hover {
  background: #7C3AED;
}
.btn-primary[data-v-32fd69dc]:disabled {
  background: #D1D5DB;
  cursor: not-allowed;
}

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

/* Стили для модального окна выбора приема */
.visit-selection-modal[data-v-32fd69dc] {
  max-width: 500px;
}
.visits-section[data-v-32fd69dc] {
  margin-bottom: 1rem;
}
.section-title[data-v-32fd69dc] {
  font-size: 0.875rem;
  font-weight: 600;
  color: #374151;
  margin-bottom: 0.75rem;
  margin-top: 0;
}
.visits-list-modal[data-v-32fd69dc] {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  max-height: 300px;
  overflow-y: auto;
  padding: 0.25rem;
}
.visit-item-modal[data-v-32fd69dc] {
  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-32fd69dc]:hover {
  border-color: #8B5CF6;
  background: #F8FAFC;
  transform: translateX(2px);
  box-shadow: 0 2px 4px rgba(139, 92, 246, 0.1);
}
.visit-info[data-v-32fd69dc] {
  flex: 1;
}
.visit-name-modal[data-v-32fd69dc] {
  font-size: 0.875rem;
  font-weight: 600;
  color: #1F2937;
  margin-bottom: 0.25rem;
}
.visit-date-modal[data-v-32fd69dc] {
  font-size: 0.75rem;
  color: #6B7280;
  font-weight: 500;
}
.visit-select-icon[data-v-32fd69dc] {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  color: #8B5CF6;
  font-weight: bold;
  margin-left: 1rem;
  font-size: 1.125rem;
}
.no-visits-section[data-v-32fd69dc] {
  padding: 2rem 1rem;
  text-align: center;
}
.no-visits-message[data-v-32fd69dc] {
  background: #F9FAFB;
  border: 1px solid #F3F4F6;
  border-radius: 8px;
  padding: 1.5rem;
}
.no-visits-message p[data-v-32fd69dc] {
  color: #6B7280;
  font-size: 0.875rem;
  margin: 0.25rem 0;
  font-weight: 500;
}
.btn-success[data-v-32fd69dc] {
  background: #10B981;
  color: white;
}
.btn-success[data-v-32fd69dc]:hover {
  background: #059669;
}

/* Стили для улучшенного пустого состояния */
.empty-state[data-v-32fd69dc] {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 400px;
  padding: 2rem;
}
.empty-state-content[data-v-32fd69dc] {
  text-align: center;
  max-width: 400px;
}
.empty-state-icon[data-v-32fd69dc] {
  font-size: 4rem;
  margin-bottom: 1rem;
  opacity: 0.6;
}
.empty-state-title[data-v-32fd69dc] {
  font-size: 1.5rem;
  font-weight: 600;
  color: #374151;
  margin-bottom: 0.5rem;
}
.empty-state-subtitle[data-v-32fd69dc] {
  font-size: 1rem;
  color: #6b7280;
  margin-bottom: 2rem;
  line-height: 1.5;
}
.empty-state-actions[data-v-32fd69dc] {
  display: flex;
  gap: 1rem;
  justify-content: center;
  flex-wrap: wrap;
}
.btn-select-patient[data-v-32fd69dc],
.btn-create-patient[data-v-32fd69dc] {
  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-32fd69dc] {
  background: #8B5CF6;
  color: white;
}
.btn-select-patient[data-v-32fd69dc]:hover {
  background: #7C3AED;
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(139, 92, 246, 0.3);
}
.btn-create-patient[data-v-32fd69dc] {
  background: #10B981;
  color: white;
}
.btn-create-patient[data-v-32fd69dc]:hover {
  background: #059669;
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(16, 185, 129, 0.3);
}
.btn-icon[data-v-32fd69dc] {
  font-size: 1rem;
}

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

/* Стили для секции приемов */
.patient-visits-section[data-v-32fd69dc] {
  min-height: 200px;
}
.visits-header[data-v-32fd69dc] {
  margin-bottom: 1rem;
}
.visits-count[data-v-32fd69dc] {
  font-size: 0.8rem;
  font-weight: 400;
  color: #6b7280;
}
.visits-loading[data-v-32fd69dc] {
  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-32fd69dc] {
  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-32fd69dc] {
  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-32fd69dc]:hover {
  border-color: #8B5CF6;
  background: #f8fafc;
  transform: translateX(2px);
  box-shadow: 0 2px 4px rgba(139, 92, 246, 0.1);
}
.visit-compact-info[data-v-32fd69dc] {
  flex: 1;
}
.visit-compact-name[data-v-32fd69dc] {
  font-size: 0.9rem;
  font-weight: 600;
  color: #1f2937;
  margin-bottom: 0.25rem;
}
.visit-compact-date[data-v-32fd69dc] {
  font-size: 0.8rem;
  color: #6b7280;
}
.visit-compact-icon[data-v-32fd69dc] {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 20px;
  height: 20px;
  color: #8B5CF6;
  font-weight: bold;
  margin-left: 1rem;
}

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

/* Кнопка создания приема */
.create-visit-section[data-v-32fd69dc] {
  text-align: center;
  padding-top: 1rem;
  border-top: 1px solid #f3f4f6;
}
.btn-create-visit-modal[data-v-32fd69dc] {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.75rem 1.5rem;
  background: #10B981;
  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-32fd69dc]:hover {
  background: #059669;
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(16, 185, 129, 0.3);
}
.btn-create-visit-modal .btn-icon[data-v-32fd69dc] {
  font-size: 1rem;
}

/* Адаптивность */
@media (min-width: 1400px) {
.header-content[data-v-32fd69dc] {
    max-width: 1400px;
    padding: 0 1.25rem;
}
.main-content[data-v-32fd69dc] {
    max-width: 1400px;
    padding: 1rem;
}
.sidebar[data-v-32fd69dc] {
    width: 200px;
}
.patient-header[data-v-32fd69dc] {
    padding: 1rem 1.25rem;
}
}
@media (min-width: 1600px) {
.header-content[data-v-32fd69dc] {
    max-width: 1600px;
}
.main-content[data-v-32fd69dc] {
    max-width: 1600px;
    gap: 1rem;
}
.sidebar[data-v-32fd69dc] {
    width: 220px;
    padding: 1rem;
}
.patient-name[data-v-32fd69dc] {
    font-size: 1.375rem;
}
}


.patients-page[data-v-3289eb4c] {
  min-height: 100vh;
  background-color: #f8fafc;
  color: #1f2937;
}

/* Header */
.header[data-v-3289eb4c] {
  background: #8B5CF6;
  color: white;
  padding: 1rem 0;
  border-bottom: 1px solid #E5E7EB;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}
.header-content[data-v-3289eb4c] {
  max-width: 1400px;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0 1rem;
}
.title-section[data-v-3289eb4c] {
  flex: 1;
}
.title[data-v-3289eb4c] {
  font-size: 1.5rem;
  font-weight: 700;
  letter-spacing: 0.5px;
  margin-bottom: 0.5rem;
}
.subtitle[data-v-3289eb4c] {
  font-size: 0.9rem;
  opacity: 0.9;
}
.doctor-name[data-v-3289eb4c] {
  font-weight: 600;
}
.clinic-name[data-v-3289eb4c] {
  font-weight: 400;
  opacity: 0.8;
}
.header-actions[data-v-3289eb4c] {
  display: flex;
  align-items: center;
  gap: 1rem;
}
.home-btn[data-v-3289eb4c] {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  background: rgba(255,255,255,0.15);
  border: 1px solid rgba(255,255,255,0.25);
  color: white;
  padding: 0.5rem 1rem;
  border-radius: 8px;
  font-size: 0.9rem;
  cursor: pointer;
  transition: all 0.2s ease;
}
.home-btn[data-v-3289eb4c]:hover {
  background: rgba(255,255,255,0.25);
  transform: translateY(-1px);
}
.datetime-widget[data-v-3289eb4c] {
  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-3289eb4c] {
  font-size: 1rem;
  font-weight: 700;
  font-family: 'Courier New', monospace;
  margin-bottom: 0.25rem;
}
.current-date[data-v-3289eb4c] {
  font-size: 0.65rem;
  opacity: 0.9;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.btn-icon[data-v-3289eb4c] {
  font-size: 1rem;
}

/* User menu (переиспользуем стили) */
.user-menu[data-v-3289eb4c] {
  position: relative;
}
.user-avatar[data-v-3289eb4c] {
  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-3289eb4c]:hover {
  background: rgba(255,255,255,0.3);
  transform: scale(1.05);
}
.user-dropdown[data-v-3289eb4c] {
  position: absolute;
  top: 50px;
  right: 0;
  background: white;
  color: #333;
  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-3289eb4c 0.2s ease-out;
}
@keyframes slideDown-3289eb4c {
from {
    opacity: 0;
    transform: translateY(-10px);
}
to {
    opacity: 1;
    transform: translateY(0);
}
}
.user-info[data-v-3289eb4c] {
  padding: 1rem;
  background: #f9fafb;
}
.user-name[data-v-3289eb4c] {
  display: block;
  font-weight: 600;
  color: #1f2937;
  font-size: 0.875rem;
  margin-bottom: 0.25rem;
}
.user-email[data-v-3289eb4c] {
  display: block;
  color: #6b7280;
  font-size: 0.75rem;
}
.user-specialization[data-v-3289eb4c] {
  display: block;
  color: #8B5CF6;
  font-size: 0.7rem;
  font-weight: 500;
  margin-top: 0.25rem;
  font-style: italic;
}
.user-clinic[data-v-3289eb4c] {
  margin-top: 0.5rem;
  padding-top: 0.5rem;
  border-top: 1px solid #f3f4f6;
}
.user-clinic .clinic-name[data-v-3289eb4c] {
  display: block;
  color: #374151;
  font-size: 0.75rem;
  font-weight: 500;
  margin-bottom: 0.25rem;
}
.clinic-region[data-v-3289eb4c] {
  display: block;
  color: #6b7280;
  font-size: 0.7rem;
}
.dropdown-divider[data-v-3289eb4c] {
  margin: 0;
  border: none;
  border-top: 1px solid #e5e7eb;
}
.logout-btn[data-v-3289eb4c] {
  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-3289eb4c]:hover {
  background: #fef2f2;
}
.logout-icon[data-v-3289eb4c] {
  font-size: 1rem;
}

/* Main content */
.main-content[data-v-3289eb4c] {
  max-width: 1400px;
  margin: 0 auto;
  padding: 2rem 1rem;
}

/* Stats section */
.stats-section[data-v-3289eb4c] {
  margin-bottom: 2rem;
}
.stats-cards[data-v-3289eb4c] {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 1rem;
}
.stat-card[data-v-3289eb4c] {
  background: white;
  padding: 1.5rem;
  border-radius: 12px;
  border: 1px solid #e5e7eb;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);
  display: flex;
  align-items: center;
  gap: 1rem;
  transition: all 0.2s ease;
}
.stat-card[data-v-3289eb4c]:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}
.stat-icon[data-v-3289eb4c] {
  font-size: 2rem;
  opacity: 0.8;
}
.stat-content[data-v-3289eb4c] {
  flex: 1;
}
.stat-number[data-v-3289eb4c] {
  font-size: 1.5rem;
  font-weight: 700;
  color: #1f2937;
  margin-bottom: 0.25rem;
}
.stat-label[data-v-3289eb4c] {
  font-size: 0.875rem;
  color: #6b7280;
  font-weight: 500;
}

/* Filters section */
.filters-section[data-v-3289eb4c] {
  background: white;
  padding: 1.5rem;
  border-radius: 12px;
  border: 1px solid #e5e7eb;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);
  margin-bottom: 1.5rem;
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  align-items: center;
}
.search-container[data-v-3289eb4c] {
  flex: 1;
  min-width: 300px;
}
.search-input-wrapper[data-v-3289eb4c] {
  display: flex;
  background: #f8fafc;
  border: 2px solid #e5e7eb;
  border-radius: 8px;
  padding: 0.5rem;
  transition: all 0.2s ease;
}
.search-input-wrapper[data-v-3289eb4c]:focus-within {
  border-color: #8B5CF6;
  box-shadow: 0 0 0 3px rgba(139, 92, 246, 0.1);
}
.search-input[data-v-3289eb4c] {
  flex: 1;
  background: transparent;
  border: none;
  color: #1f2937;
  font-size: 0.9rem;
  padding: 0.5rem;
  outline: none;
}
.search-input[data-v-3289eb4c]::-moz-placeholder {
  color: #9ca3af;
}
.search-input[data-v-3289eb4c]::placeholder {
  color: #9ca3af;
}
.search-btn[data-v-3289eb4c] {
  background: #8B5CF6;
  border: none;
  color: white;
  padding: 0.5rem;
  border-radius: 6px;
  font-size: 0.9rem;
  cursor: pointer;
  transition: all 0.2s ease;
  min-width: 40px;
}
.search-btn[data-v-3289eb4c]:hover {
  background: #7C3AED;
}
.filters-container[data-v-3289eb4c] {
  display: flex;
  gap: 1rem;
  align-items: center;
  flex-wrap: wrap;
}
.filter-select[data-v-3289eb4c] {
  padding: 0.5rem 1rem;
  border: 1px solid #e5e7eb;
  border-radius: 6px;
  background: white;
  color: #1f2937;
  font-size: 0.875rem;
  cursor: pointer;
  transition: border-color 0.2s ease;
  min-width: 120px;
}
.filter-select[data-v-3289eb4c]:focus {
  outline: none;
  border-color: #8B5CF6;
}
.reset-filters-btn[data-v-3289eb4c] {
  padding: 0.5rem 1rem;
  background: #f3f4f6;
  border: 1px solid #e5e7eb;
  border-radius: 6px;
  color: #374151;
  font-size: 0.875rem;
  cursor: pointer;
  transition: all 0.2s ease;
}
.reset-filters-btn[data-v-3289eb4c]:hover {
  background: #e5e7eb;
  color: #1f2937;
}

/* Patients section */
.patients-section[data-v-3289eb4c] {
  background: white;
  border-radius: 12px;
  border: 1px solid #e5e7eb;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);
  overflow: hidden;
}

/* Loading and error states */
.loading-state[data-v-3289eb4c] {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 3rem;
  gap: 1rem;
  color: #6b7280;
}
.spinner[data-v-3289eb4c] {
  width: 24px;
  height: 24px;
  border: 3px solid #f3f3f3;
  border-top: 3px solid #8B5CF6;
  border-radius: 50%;
  animation: spin-3289eb4c 1s linear infinite;
}
@keyframes spin-3289eb4c {
0% { transform: rotate(0deg);
}
100% { transform: rotate(360deg);
}
}
.error-state[data-v-3289eb4c] {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 3rem;
  text-align: center;
}
.error-icon[data-v-3289eb4c] {
  font-size: 3rem;
  margin-bottom: 1rem;
}
.error-content h3[data-v-3289eb4c] {
  color: #dc2626;
  margin-bottom: 0.5rem;
  font-size: 1.25rem;
}
.error-content p[data-v-3289eb4c] {
  color: #6b7280;
  margin-bottom: 1rem;
}
.retry-btn[data-v-3289eb4c] {
  background: #8B5CF6;
  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-3289eb4c]:hover {
  background: #7C3AED;
}

/* Table */
.patients-table-container[data-v-3289eb4c] {
  overflow-x: auto;
}
.patients-table[data-v-3289eb4c] {
  width: 100%;
  border-collapse: collapse;
}
.patients-table th[data-v-3289eb4c] {
  background: #f8fafc;
  padding: 1rem;
  text-align: left;
  font-weight: 600;
  color: #374151;
  font-size: 0.875rem;
  border-bottom: 1px solid #e5e7eb;
  white-space: nowrap;
}
.patients-table td[data-v-3289eb4c] {
  padding: 1rem;
  border-bottom: 1px solid #f3f4f6;
  font-size: 0.875rem;
}
.patient-row[data-v-3289eb4c] {
  cursor: pointer;
  transition: background-color 0.2s ease;
}
.patient-row[data-v-3289eb4c]:hover {
  background: #f8fafc;
}
.patient-name[data-v-3289eb4c] {
  min-width: 200px;
}
.name-container[data-v-3289eb4c] {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.full-name[data-v-3289eb4c] {
  font-weight: 500;
  color: #1f2937;
}
.gender-badge[data-v-3289eb4c] {
  font-size: 0.8rem;
}
.gender-badge.male[data-v-3289eb4c] {
  color: #3b82f6;
}
.gender-badge.female[data-v-3289eb4c] {
  color: #ec4899;
}
.patient-iin[data-v-3289eb4c] {
  font-family: monospace;
  color: #6b7280;
}
.patient-actions[data-v-3289eb4c] {
  width: 150px;
}
.action-buttons[data-v-3289eb4c] {
  display: flex;
  gap: 0.5rem;
  justify-content: center;
  align-items: center;
}
.action-btn[data-v-3289eb4c] {
  background: #f3f4f6;
  border: 1px solid #e5e7eb;
  border-radius: 6px;
  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-3289eb4c] {
  background: #10B981;
  color: white;
  border-color: #10B981;
}
.edit-btn[data-v-3289eb4c]:hover {
  background: #059669;
  border-color: #047857;
  transform: translateY(-1px);
  box-shadow: 0 2px 8px rgba(16, 185, 129, 0.3);
}
.registry-btn[data-v-3289eb4c] {
  background: #8B5CF6;
  color: white;
  border-color: #8B5CF6;
}
.registry-btn[data-v-3289eb4c]:hover {
  background: #7C3AED;
  border-color: #7C3AED;
  transform: translateY(-1px);
}

/* Pagination */
.pagination[data-v-3289eb4c] {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1.5rem;
  border-top: 1px solid #f3f4f6;
  background: #f8fafc;
}
.pagination-btn[data-v-3289eb4c] {
  background: #8B5CF6;
  color: white;
  border: none;
  padding: 0.5rem 1rem;
  border-radius: 6px;
  cursor: pointer;
  font-weight: 500;
  transition: all 0.2s ease;
}
.pagination-btn[data-v-3289eb4c]:hover:not(:disabled) {
  background: #7C3AED;
  transform: translateY(-1px);
}
.pagination-btn[data-v-3289eb4c]:disabled {
  background: #d1d5db;
  cursor: not-allowed;
  transform: none;
}
.pagination-info[data-v-3289eb4c] {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.25rem;
  font-size: 0.875rem;
  color: #6b7280;
}
.pagination-total[data-v-3289eb4c] {
  font-size: 0.75rem;
  opacity: 0.8;
}

/* Empty state */
.empty-state[data-v-3289eb4c] {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 4rem 2rem;
}
.empty-state-content[data-v-3289eb4c] {
  text-align: center;
  max-width: 400px;
}
.empty-state-icon[data-v-3289eb4c] {
  font-size: 4rem;
  margin-bottom: 1rem;
  opacity: 0.6;
}
.empty-state-title[data-v-3289eb4c] {
  font-size: 1.5rem;
  font-weight: 600;
  color: #374151;
  margin-bottom: 0.5rem;
}
.empty-state-subtitle[data-v-3289eb4c] {
  font-size: 1rem;
  color: #6b7280;
  margin-bottom: 1.5rem;
  line-height: 1.5;
}
.btn-reset[data-v-3289eb4c] {
  background: #8B5CF6;
  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-3289eb4c]:hover {
  background: #7C3AED;
  transform: translateY(-1px);
}

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

/* Модальное окно редактирования */
.modal-overlay[data-v-3289eb4c] {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.5);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 2000;
}
.modal-content[data-v-3289eb4c] {
  background: white;
  border-radius: 20px;
  width: 90%;
  max-width: 500px;
  max-height: 80vh;
  overflow-y: auto;
  border: 1px solid #E5E7EB;
  box-shadow: 0 25px 50px rgba(0,0,0,0.25);
}
.modal-header[data-v-3289eb4c] {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1.5rem;
  border-bottom: 1px solid #F3F4F6;
}
.modal-header h3[data-v-3289eb4c] {
  margin: 0;
  font-size: 1.25rem;
  font-weight: 600;
  color: #1F2937;
}
.close-btn[data-v-3289eb4c] {
  background: none;
  border: 1px solid #E5E7EB;
  font-size: 1.25rem;
  color: #6B7280;
  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-3289eb4c]:hover {
  background: #F9FAFB;
  border-color: #D1D5DB;
}
.modal-body[data-v-3289eb4c] {
  padding: 1.5rem;
  color: #333;
}
.form-group[data-v-3289eb4c] {
  margin-bottom: 1rem;
}
.form-group label[data-v-3289eb4c] {
  display: block;
  margin-bottom: 0.5rem;
  font-weight: 500;
  color: #374151;
  font-size: 0.9rem;
}
.form-input[data-v-3289eb4c],
.form-select[data-v-3289eb4c] {
  width: 100%;
  padding: 0.75rem 1rem;
  border: 1px solid #E5E7EB;
  border-radius: 8px;
  font-size: 0.9rem;
  transition: border-color 0.2s ease;
}
.form-input[data-v-3289eb4c]:focus,
.form-select[data-v-3289eb4c]:focus {
  outline: none;
  border-color: #8B5CF6;
  box-shadow: 0 0 0 3px rgba(139, 92, 246, 0.1);
}
.form-input.error[data-v-3289eb4c] {
  border-color: #ef4444;
  box-shadow: 0 0 0 3px rgba(239, 68, 68, 0.1);
}
.required[data-v-3289eb4c] {
  color: #ef4444;
  font-weight: bold;
}
.field-error[data-v-3289eb4c] {
  color: #ef4444;
  font-size: 0.8rem;
  margin-top: 0.25rem;
  font-weight: 500;
}
.field-note[data-v-3289eb4c] {
  color: #6b7280;
  font-size: 0.75rem;
  margin-top: 0.25rem;
  font-style: italic;
  display: block;
}
.modal-footer[data-v-3289eb4c] {
  display: flex;
  justify-content: flex-end;
  gap: 0.75rem;
  padding: 1.5rem;
  border-top: 1px solid #F3F4F6;
  background: #FAFAFA;
}
.btn[data-v-3289eb4c] {
  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-3289eb4c] {
  background: #F3F4F6;
  color: #374151;
  border: 1px solid #E5E7EB;
}
.btn-cancel[data-v-3289eb4c]:hover {
  background: #E5E7EB;
}
.btn-primary[data-v-3289eb4c] {
  background: #8B5CF6;
  color: white;
}
.btn-primary[data-v-3289eb4c]:hover {
  background: #7C3AED;
}
.btn-primary[data-v-3289eb4c]:disabled {
  background: #D1D5DB;
  cursor: not-allowed;
}


.debug-page[data-v-08e3265b] {
  min-height: 100vh;
  background: #f5f5f5;
  padding: 2rem;
}
.debug-container[data-v-08e3265b] {
  max-width: 800px;
  margin: 0 auto;
}
.debug-container h1[data-v-08e3265b] {
  text-align: center;
  color: #333;
  margin-bottom: 2rem;
}
.status-card[data-v-08e3265b], .action-card[data-v-08e3265b], .result-card[data-v-08e3265b], .info-card[data-v-08e3265b] {
  background: white;
  border-radius: 8px;
  padding: 1.5rem;
  margin-bottom: 1.5rem;
  box-shadow: 0 2px 4px rgba(0,0,0,0.1);
}
.status-card h2[data-v-08e3265b], .action-card h2[data-v-08e3265b], .result-card h2[data-v-08e3265b], .info-card h2[data-v-08e3265b] {
  margin-bottom: 1rem;
  color: #333;
  font-size: 1.2rem;
}
.status-info[data-v-08e3265b] {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}
.status-item[data-v-08e3265b] {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0.5rem;
  background: #f8f9fa;
  border-radius: 4px;
}
.status-item label[data-v-08e3265b] {
  font-weight: 500;
  color: #666;
}
.status-ok[data-v-08e3265b] {
  color: #28a745;
  font-weight: 500;
}
.status-error[data-v-08e3265b] {
  color: #dc3545;
  font-weight: 500;
}
.actions[data-v-08e3265b] {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}
.action-btn[data-v-08e3265b] {
  padding: 10px 20px;
  border: none;
  border-radius: 5px;
  cursor: pointer;
  font-weight: 500;
  transition: all 0.3s ease;
}
.action-btn.primary[data-v-08e3265b] {
  background-color: #007bff;
  color: white;
}
.action-btn.primary[data-v-08e3265b]:hover {
  background-color: #0056b3;
}
.action-btn.danger[data-v-08e3265b] {
  background-color: #dc3545;
  color: white;
}
.action-btn.danger[data-v-08e3265b]:hover {
  background-color: #c82333;
}
.test-result[data-v-08e3265b] {
  position: relative;
  background-color: #f8f9fa;
  border: 1px solid #e9ecef;
  border-radius: 5px;
  padding: 15px;
  margin-top: 10px;
}
.test-result pre[data-v-08e3265b] {
  margin: 0;
  white-space: pre-wrap;
  word-wrap: break-word;
  max-height: 300px;
  overflow-y: auto;
}
.copy-btn[data-v-08e3265b] {
  position: absolute;
  top: 10px;
  right: 10px;
  background-color: #6c757d;
  color: white;
  border: none;
  border-radius: 3px;
  padding: 5px 10px;
  cursor: pointer;
  font-size: 12px;
}
.copy-btn[data-v-08e3265b]:hover {
  background-color: #5a6268;
}
.test-btn[data-v-08e3265b], .clear-btn[data-v-08e3265b], .login-btn[data-v-08e3265b] {
  padding: 0.75rem 1.5rem;
  border: none;
  border-radius: 6px;
  font-weight: 500;
  cursor: pointer;
  text-decoration: none;
  display: inline-block;
  text-align: center;
  transition: all 0.2s;
}
.test-btn[data-v-08e3265b] {
  background: #007bff;
  color: white;
}
.test-btn[data-v-08e3265b]:hover:not(:disabled) {
  background: #0056b3;
}
.test-btn[data-v-08e3265b]:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}
.clear-btn[data-v-08e3265b] {
  background: #ffc107;
  color: #333;
}
.clear-btn[data-v-08e3265b]:hover {
  background: #e0a800;
}
.login-btn[data-v-08e3265b] {
  background: #28a745;
  color: white;
}
.login-btn[data-v-08e3265b]:hover {
  background: #1e7e34;
}
.result-card pre[data-v-08e3265b] {
  background: #f8f9fa;
  padding: 1rem;
  border-radius: 4px;
  overflow-x: auto;
  font-size: 0.9rem;
}
.info-card ul[data-v-08e3265b] {
  margin: 1rem 0;
  padding-left: 1.5rem;
}
.info-card li[data-v-08e3265b] {
  margin-bottom: 0.5rem;
  color: #666;
}
.info-card p[data-v-08e3265b] {
  color: #666;
  line-height: 1.6;
}
.credentials-info[data-v-08e3265b] {
  margin-top: 1.5rem;
  padding-top: 1.5rem;
  border-top: 1px solid #eee;
}
.credentials-info h3[data-v-08e3265b] {
  margin-bottom: 0.75rem;
  color: #333;
}
.credentials-info p[data-v-08e3265b] {
  color: #666;
  font-style: italic;
}
@media (max-width: 600px) {
.debug-page[data-v-08e3265b] {
    padding: 1rem;
}
.actions[data-v-08e3265b] {
    flex-direction: column;
}
.test-btn[data-v-08e3265b], .clear-btn[data-v-08e3265b], .login-btn[data-v-08e3265b] {
    width: 100%;
}
}


.login-page[data-v-6b4e0784] {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
  padding: 1rem;
  position: relative;
  overflow: hidden;
}

/* Переключатель языка в правом верхнем углу */
.language-switcher-wrapper[data-v-6b4e0784] {
  position: absolute;
  top: 1.5rem;
  right: 1.5rem;
  z-index: 100;
}
.login-container[data-v-6b4e0784] {
  background: white;
  border-radius: 16px;
  box-shadow: 0 20px 40px rgba(0, 0, 0, 0.1);
  overflow: hidden;
  max-width: 400px;
  width: 100%;
  position: relative;
  z-index: 10;
}
.login-header[data-v-6b4e0784] {
  background: linear-gradient(135deg, #8B5CF6 0%, #A855F7 100%);
  color: white;
  text-align: center;
  padding: 2rem 1rem 1.5rem;
}
.logo-icon[data-v-6b4e0784] {
  font-size: 3rem;
  margin-bottom: 0.5rem;
}
.logo-title[data-v-6b4e0784] {
  font-size: 1.5rem;
  font-weight: 700;
  margin: 0 0 0.25rem 0;
  letter-spacing: 0.5px;
}
.logo-subtitle[data-v-6b4e0784] {
  font-size: 0.875rem;
  opacity: 0.9;
  margin: 0;
  font-weight: 400;
}
.login-form-container[data-v-6b4e0784] {
  padding: 2rem;
}
.form-title[data-v-6b4e0784] {
  font-size: 1.5rem;
  font-weight: 600;
  color: #1f2937;
  margin: 0 0 1.5rem 0;
  text-align: center;
}
.form-group[data-v-6b4e0784] {
  margin-bottom: 1.5rem;
}
.form-label[data-v-6b4e0784] {
  display: block;
  font-size: 0.875rem;
  font-weight: 500;
  color: #374151;
  margin-bottom: 0.5rem;
}
.form-input[data-v-6b4e0784] {
  width: 100%;
  padding: 0.75rem 1rem;
  border: 2px solid #e5e7eb;
  border-radius: 8px;
  font-size: 1rem;
  transition: all 0.2s ease;
  background: #f9fafb;
}
.form-input[data-v-6b4e0784]:focus {
  outline: none;
  border-color: #8B5CF6;
  background: white;
  box-shadow: 0 0 0 3px rgba(139, 92, 246, 0.1);
}
.form-input.error[data-v-6b4e0784] {
  border-color: #ef4444;
  background: #fef2f2;
}
.password-input-container[data-v-6b4e0784] {
  position: relative;
}
.password-toggle[data-v-6b4e0784] {
  position: absolute;
  right: 0.75rem;
  top: 50%;
  transform: translateY(-50%);
  background: none;
  border: none;
  font-size: 1.25rem;
  cursor: pointer;
  color: #6b7280;
  transition: color 0.2s ease;
}
.password-toggle[data-v-6b4e0784]:hover {
  color: #8B5CF6;
}
.checkbox-label[data-v-6b4e0784] {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  cursor: pointer;
  font-size: 0.875rem;
  color: #374151;
}
.checkbox-input[data-v-6b4e0784] {
  display: none;
}
.checkbox-custom[data-v-6b4e0784] {
  width: 18px;
  height: 18px;
  border: 2px solid #d1d5db;
  border-radius: 4px;
  position: relative;
  transition: all 0.2s ease;
}
.checkbox-input:checked + .checkbox-custom[data-v-6b4e0784] {
  background: #8B5CF6;
  border-color: #8B5CF6;
}
.checkbox-input:checked + .checkbox-custom[data-v-6b4e0784]::after {
  content: '✓';
  position: absolute;
  top: -2px;
  left: 2px;
  color: white;
  font-size: 12px;
  font-weight: bold;
}
.error-message[data-v-6b4e0784] {
  display: block;
  color: #ef4444;
  font-size: 0.75rem;
  margin-top: 0.25rem;
}
.error-alert[data-v-6b4e0784] {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  background: #fef2f2;
  border: 1px solid #fecaca;
  border-radius: 6px;
  padding: 0.75rem;
  color: #dc2626;
  font-size: 0.875rem;
  margin-bottom: 1rem;
}
.loading-alert[data-v-6b4e0784] {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  background: #f0f9ff;
  border: 1px solid #bae6fd;
  border-radius: 6px;
  padding: 0.75rem;
  color: #0369a1;
  font-size: 0.875rem;
  margin-bottom: 1rem;
}
.loading-spinner[data-v-6b4e0784] {
  width: 16px;
  height: 16px;
  border: 2px solid #e5e7eb;
  border-top: 2px solid #8B5CF6;
  border-radius: 50%;
  animation: spin-6b4e0784 1s linear infinite;
}
@keyframes spin-6b4e0784 {
0% { transform: rotate(0deg);
}
100% { transform: rotate(360deg);
}
}
.login-button[data-v-6b4e0784] {
  width: 100%;
  padding: 0.875rem 1.5rem;
  background: linear-gradient(135deg, #8B5CF6 0%, #A855F7 100%);
  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-6b4e0784]:hover:not(:disabled) {
  transform: translateY(-1px);
  box-shadow: 0 8px 16px rgba(139, 92, 246, 0.3);
}
.login-button[data-v-6b4e0784]:disabled {
  opacity: 0.6;
  cursor: not-allowed;
  transform: none;
  box-shadow: none;
}
.login-footer[data-v-6b4e0784] {
  text-align: center;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.forgot-password-link[data-v-6b4e0784], .debug-link[data-v-6b4e0784] {
  color: #8B5CF6;
  text-decoration: none;
  font-size: 0.875rem;
  transition: color 0.2s ease;
}
.forgot-password-link[data-v-6b4e0784]:hover, .debug-link[data-v-6b4e0784]:hover {
  color: #7C3AED;
  text-decoration: underline;
}
.debug-link[data-v-6b4e0784] {
  color: #6b7280;
  font-size: 0.75rem;
}

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

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

/* Темная тема */
@media (prefers-color-scheme: dark) {
.login-container[data-v-6b4e0784] {
    background: #1f2937;
    color: white;
}
.form-title[data-v-6b4e0784] {
    color: white;
}
.form-label[data-v-6b4e0784] {
    color: #d1d5db;
}
.form-input[data-v-6b4e0784] {
    background: #374151;
    border-color: #4b5563;
    color: white;
}
.form-input[data-v-6b4e0784]:focus {
    background: #374151;
}
.checkbox-text[data-v-6b4e0784] {
    color: #d1d5db;
}
}

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


.survey-statistics-page[data-v-c1b7b492] {
  min-height: 100vh;
  background-color: #f8f9fa;
  color: #1f2937;
}

/* Header */
.header[data-v-c1b7b492] {
  background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
  color: white;
  padding: 1rem 0;
  border-bottom: 1px solid #E5E7EB;
}
.header-content[data-v-c1b7b492] {
  max-width: 1400px;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0 1rem;
}
.title-section[data-v-c1b7b492] {
  flex: 1;
}
.title[data-v-c1b7b492] {
  font-size: 1.75rem;
  font-weight: 700;
  letter-spacing: 0.25px;
  margin-bottom: 0.5rem;
}
.subtitle[data-v-c1b7b492] {
  font-size: 1rem;
  opacity: 0.9;
}
.header-actions[data-v-c1b7b492] {
  display: flex;
  align-items: center;
  gap: 1.5rem;
}
.datetime-widget[data-v-c1b7b492] {
  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-c1b7b492] {
  font-size: 1.2rem;
  font-weight: 700;
  font-family: 'Courier New', monospace;
  margin-bottom: 0.25rem;
}
.current-date[data-v-c1b7b492] {
  font-size: 0.75rem;
  opacity: 0.9;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.action-buttons[data-v-c1b7b492] {
  display: flex;
  align-items: center;
  gap: 1rem;
}
.btn-export[data-v-c1b7b492],
.btn-back[data-v-c1b7b492] {
  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: 500;
}
.btn-export[data-v-c1b7b492]:hover,
.btn-back[data-v-c1b7b492]:hover {
  background: rgba(255, 255, 255, 0.2);
}
.btn-export[data-v-c1b7b492]:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}

/* Main Content */
.main-content[data-v-c1b7b492] {
  max-width: 1400px;
  margin: 0 auto;
  padding: 2rem 1rem;
}

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

/* Error */
.error-container[data-v-c1b7b492] {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 4rem 2rem;
  text-align: center;
}
.error-icon[data-v-c1b7b492] {
  font-size: 3rem;
  margin-bottom: 1rem;
}
.error-message[data-v-c1b7b492] {
  font-size: 1.1rem;
  color: #dc2626;
  margin-bottom: 2rem;
  max-width: 500px;
}
.btn-retry[data-v-c1b7b492] {
  padding: 0.75rem 1.5rem;
  background: #667eea;
  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-c1b7b492]:hover {
  background: #5a67d8;
  transform: translateY(-1px);
}

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

/* Summary Panel */
.summary-panel[data-v-c1b7b492] {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: 1.5rem;
  margin-bottom: 2.5rem;
}
.summary-card[data-v-c1b7b492] {
  background: white;
  border-radius: 16px;
  padding: 1.5rem;
  border: 1px solid #e5e7eb;
  box-shadow: 0 4px 6px rgba(0, 0, 0, 0.05);
  display: flex;
  align-items: center;
  gap: 1rem;
  transition: all 0.2s ease;
}
.summary-card[data-v-c1b7b492]:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 25px rgba(0, 0, 0, 0.1);
}
.summary-icon[data-v-c1b7b492] {
  font-size: 2.5rem;
  width: 60px;
  height: 60px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 12px;
  background: #f8fafc;
}
.total-responses .summary-icon[data-v-c1b7b492] {
  background: #dbeafe;
}
.completion-rate .summary-icon[data-v-c1b7b492] {
  background: #dcfce7;
}
.average-score .summary-icon[data-v-c1b7b492] {
  background: #fef3c7;
}
.disability-level .summary-icon[data-v-c1b7b492] {
  background: #f3e8ff;
}
.summary-content[data-v-c1b7b492] {
  flex: 1;
}
.summary-value[data-v-c1b7b492] {
  font-size: 2rem;
  font-weight: 700;
  color: #1f2937;
  margin-bottom: 0.25rem;
}
.summary-label[data-v-c1b7b492] {
  font-size: 0.9rem;
  color: #6b7280;
  font-weight: 500;
}

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

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

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

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

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


.statistics-page[data-v-11d22fc0] {
  min-height: 100vh;
  background-color: #f8f9fa;
  color: #1f2937;
}

/* Header */
.header[data-v-11d22fc0] {
  background: #8B5CF6;
  color: white;
  padding: 1rem 0;
  border-bottom: 1px solid #E5E7EB;
}
.header-content[data-v-11d22fc0] {
  max-width: 1400px;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0 1rem;
}
.title-section[data-v-11d22fc0] {
  flex: 1;
}
.title[data-v-11d22fc0] {
  font-size: 1.75rem;
  font-weight: 700;
  letter-spacing: 0.25px;
  margin-bottom: 0.5rem;
}
.subtitle[data-v-11d22fc0] {
  font-size: 1rem;
  opacity: 0.9;
}
.header-actions[data-v-11d22fc0] {
  display: flex;
  align-items: center;
  gap: 1.5rem;
}
.datetime-widget[data-v-11d22fc0] {
  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-11d22fc0] {
  font-size: 1.2rem;
  font-weight: 700;
  font-family: 'Courier New', monospace;
  margin-bottom: 0.25rem;
}
.current-date[data-v-11d22fc0] {
  font-size: 0.75rem;
  opacity: 0.9;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.action-buttons[data-v-11d22fc0] {
  display: flex;
  align-items: center;
  gap: 1rem;
}
.btn-export[data-v-11d22fc0],
.btn-back[data-v-11d22fc0] {
  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: 500;
}
.btn-export[data-v-11d22fc0]:hover,
.btn-back[data-v-11d22fc0]:hover {
  background: rgba(255, 255, 255, 0.2);
}
.btn-export[data-v-11d22fc0]:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}
.btn-export[data-v-11d22fc0]:disabled:hover {
  background: rgba(255, 255, 255, 0.1);
}

/* Main Content */
.main-content[data-v-11d22fc0] {
  max-width: 1400px;
  margin: 0 auto;
  padding: 2rem 1rem;
}

/* Loading */
.loading-container[data-v-11d22fc0] {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 4rem 2rem;
}
.loading-spinner[data-v-11d22fc0] {
  width: 48px;
  height: 48px;
  border: 4px solid #e5e7eb;
  border-top: 4px solid #8B5CF6;
  border-radius: 50%;
  animation: spin-11d22fc0 1s linear infinite;
  margin-bottom: 1rem;
}
.loading-text[data-v-11d22fc0] {
  font-size: 1.1rem;
  color: #6b7280;
  font-weight: 500;
}

/* Error */
.error-container[data-v-11d22fc0] {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 4rem 2rem;
  text-align: center;
}
.error-icon[data-v-11d22fc0] {
  font-size: 3rem;
  margin-bottom: 1rem;
}
.error-message[data-v-11d22fc0] {
  font-size: 1.1rem;
  color: #dc2626;
  margin-bottom: 2rem;
  max-width: 500px;
}
.btn-retry[data-v-11d22fc0] {
  padding: 0.75rem 1.5rem;
  background: #8B5CF6;
  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-11d22fc0]:hover {
  background: #7C3AED;
  transform: translateY(-1px);
}

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

/* Summary Panel */
.summary-panel[data-v-11d22fc0] {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: 1.5rem;
  margin-bottom: 2.5rem;
}
.summary-card[data-v-11d22fc0] {
  background: white;
  border-radius: 16px;
  padding: 1.5rem;
  border: 1px solid #e5e7eb;
  box-shadow: 0 4px 6px rgba(0, 0, 0, 0.05);
  display: flex;
  align-items: center;
  gap: 1rem;
  transition: all 0.2s ease;
}
.summary-card[data-v-11d22fc0]:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 25px rgba(0, 0, 0, 0.1);
}
.summary-icon[data-v-11d22fc0] {
  font-size: 2.5rem;
  width: 60px;
  height: 60px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 12px;
  background: #f8fafc;
}
.total-patients .summary-icon[data-v-11d22fc0] {
  background: #dbeafe;
}
.average-age .summary-icon[data-v-11d22fc0] {
  background: #dcfce7;
}
.gender-modern .summary-icon[data-v-11d22fc0] {
  background: #f3f4f6;
}
.summary-content[data-v-11d22fc0] {
  flex: 1;
}
.summary-value[data-v-11d22fc0] {
  font-size: 2rem;
  font-weight: 700;
  color: #1f2937;
  margin-bottom: 0.25rem;
}

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

/* Charts Grid */
.charts-grid[data-v-11d22fc0] {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(400px, 1fr));
  gap: 2rem;
}
.chart-card[data-v-11d22fc0] {
  background: white;
  border-radius: 16px;
  padding: 1.5rem;
  border: 1px solid #e5e7eb;
  box-shadow: 0 4px 6px rgba(0, 0, 0, 0.05);
  transition: all 0.2s ease;
}
.chart-card[data-v-11d22fc0]:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 25px rgba(0, 0, 0, 0.1);
}
.chart-card.large[data-v-11d22fc0] {
  grid-column: 1 / -1;
}
.chart-header[data-v-11d22fc0] {
  margin-bottom: 1.5rem;
}
.chart-title[data-v-11d22fc0] {
  font-size: 1.25rem;
  font-weight: 600;
  color: #1f2937;
  margin: 0;
  display: flex;
  align-items: center;
  gap: 0.75rem;
}
.chart-icon[data-v-11d22fc0] {
  font-size: 1.5rem;
}
.chart-container[data-v-11d22fc0] {
  position: relative;
  height: 300px;
}
.chart-card.large .chart-container[data-v-11d22fc0] {
  height: 400px;
}

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

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

