/* --- Навигация --- */
.nav-link {
  display: flex;
  align-items: center;
  gap: 0.625rem;
  padding: 0.65rem 0.75rem;
  border-radius: 0.5rem;
  color: rgb(71 85 105);
  font-weight: 500;
  min-height: 44px; /* touch target */
}
.nav-link:hover {
  background: rgb(248 250 252);
  color: rgb(15 23 42);
}
.nav-active {
  background: rgb(253 247 238);
  color: rgb(168 101 26);
}
.nav-active:hover {
  background: rgb(249 235 210);
  color: rgb(168 101 26);
}

/* --- Кнопки (touch-friendly) --- */
.btn { display: inline-flex; align-items: center; justify-content: center; gap: 0.5rem; padding: 0.65rem 1rem; border-radius: 0.5rem; font-weight: 500; font-size: 0.875rem; transition: all 0.15s; min-height: 40px; }
@media (max-width: 640px) { .btn { padding: 0.75rem 1rem; min-height: 44px; } .btn-full-mobile { width: 100%; } }
.btn-primary { background: rgb(201 131 33); color: white; }
.btn-primary:hover { background: rgb(168 101 26); }
.btn-secondary { background: white; color: rgb(51 65 85); border: 1px solid rgb(226 232 240); }
.btn-secondary:hover { background: rgb(248 250 252); }
.btn-danger { background: rgb(225 29 72); color: white; }
.btn-danger:hover { background: rgb(190 18 60); }

.card { background: white; border: 1px solid rgb(226 232 240); border-radius: 0.75rem; }

/* --- Формы (16px шрифт на мобиле отключает zoom iOS) --- */
.form-input, .form-select, .form-textarea {
  width: 100%;
  padding: 0.65rem 0.75rem;
  border: 1px solid rgb(203 213 225);
  border-radius: 0.5rem;
  font-size: 0.875rem;
  background: white;
  min-height: 42px;
}
@media (max-width: 640px) {
  .form-input, .form-select, .form-textarea { font-size: 16px; min-height: 44px; }
}
.form-input:focus, .form-select:focus, .form-textarea:focus {
  outline: none;
  border-color: rgb(201 131 33);
  box-shadow: 0 0 0 3px rgb(253 247 238);
}
.form-label { display: block; font-size: 0.875rem; font-weight: 500; color: rgb(51 65 85); margin-bottom: 0.375rem; }

/* --- Таблицы --- */
.table { width: 100%; border-collapse: collapse; }
.table th { text-align: left; font-size: 0.75rem; text-transform: uppercase; letter-spacing: 0.05em; color: rgb(100 116 139); font-weight: 600; padding: 0.625rem 0.75rem; border-bottom: 1px solid rgb(226 232 240); background: rgb(248 250 252); }
.table td { padding: 0.75rem; border-bottom: 1px solid rgb(241 245 249); font-size: 0.875rem; }
.table tr:hover td { background: rgb(248 250 252); }

/* Обёртка для горизонтального скролла таблиц на маленьких экранах */
.table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; border-radius: 0.75rem; }
.table-wrap .table { min-width: 560px; }

/* Mobile cards: в ряде таблиц на мобильных показываем карточки вместо таблицы */
.mobile-list { display: none; }
@media (max-width: 768px) {
  .table-desktop-only { display: none; }
  .mobile-list { display: flex; flex-direction: column; gap: 0.5rem; }
}
.mobile-card { background: white; border: 1px solid rgb(226 232 240); border-radius: 0.75rem; padding: 0.875rem 1rem; }
.mobile-card .row { display: flex; justify-content: space-between; align-items: center; gap: 0.75rem; padding: 0.25rem 0; font-size: 0.875rem; }
.mobile-card .row .lbl { color: rgb(100 116 139); font-size: 0.75rem; }
.mobile-card .row .val { font-weight: 500; text-align: right; }
.mobile-card .title-row { font-weight: 600; font-size: 0.95rem; margin-bottom: 0.25rem; display: flex; justify-content: space-between; align-items: center; gap: 0.5rem; }

.badge { display: inline-flex; align-items: center; padding: 0.125rem 0.5rem; border-radius: 9999px; font-size: 0.75rem; font-weight: 500; }

@media print {
  aside, header, .no-print { display: none !important; }
  main { padding: 0 !important; }
  body { background: white; }
}
