/* ===== OPTIMIZED STYLE.CSS =====
 * Версия: 2026-01-12 (Оптимизирована)
 * Удалены дубликаты, улучшена адаптивность
 * Сгруппированы связанные стили
 * ============================= */

@import url("design-tokens.css");

/* ===== ИМПОРТ ШРИФТОВ ===== */
@import url("https://fonts.googleapis.com/css2?family=Inter:wght@100..900&family=JetBrains+Mono:wght@400..700&family=Rubik:wght@300..900&family=Manrope:wght@200..800&display=swap");

/* ===== CSS ПЕРЕМЕННЫЕ ===== */
:root {
  /* Цветовая палитра - Premium & Trust */
  --primary-color: #2a4b7c;
  --primary-hover: #1f3a5c;
  --primary-light: #3d6ba3;
  --primary-dark: #1a2f4a;
  --primary-rgb: 42, 75, 124;

  /* Интерактив: hover/focus без «синей» окантовки — нейтральные серые + мягкое кольцо */
  --border-hover: #bdbdbd;
  --border-focus: #9e9e9e;
  --focus-ring-soft: 0 0 0 3px rgba(0, 0, 0, 0.07);
  --focus-ring-tight: 0 0 0 2px rgba(0, 0, 0, 0.1);
  --shadow-card-hover: 0 6px 18px rgba(0, 0, 0, 0.08);
  --shadow-card-hover-sm: 0 4px 12px rgba(0, 0, 0, 0.06);

  --secondary-color: #e8e8e8;
  --secondary-hover: #d4d4d4;
  --secondary-light: #f5f5f5;
  --secondary-dark: #c0c0c0;

  --accent-color: #d4af37;
  --accent-hover: #c9a02e;
  --accent-light: #e8c547;
  --accent-dark: #b8941f;

  --accent-mint: #7dd4c4;
  --accent-mint-light: #a8e6d8;
  --accent-mint-dark: #5ac4b3;

  --accent-blue: #2a4b7c;
  --accent-blue-light: #4a6ba3;
  --accent-blue-dark: #1a2f4a;

  /* Градиенты - обновлены */
  --gradient-primary: linear-gradient(135deg, #2a4b7c 0%, #3d6ba3 100%);
  --gradient-secondary: linear-gradient(135deg, #e8e8e8 0%, #d4d4d4 100%);
  --gradient-success: linear-gradient(135deg, #22c55e 0%, #16a34a 100%);
  --gradient-warm: linear-gradient(135deg, #d4af37 0%, #e8c547 100%);
  --gradient-teal-fuchsia: linear-gradient(135deg, #2a4b7c 0%, #d4af37 100%);
  --gradient-danger: linear-gradient(135deg, #ef4444 0%, #dc2626 100%);
  --gradient-warning: linear-gradient(135deg, #eab308 0%, #ca8a04 100%);
  --gradient-info: linear-gradient(135deg, #2a4b7c 0%, #3d6ba3 100%);

  /* Текст - усилена контрастность */
  --text-primary: #212121;
  --text-secondary: #424242;
  --text-muted: #757575;
  --text-white: #ffffff;

  /* Фоны - премиальный стиль */
  --bg-primary: #ffffff;
  --bg-secondary: #f9f9f9;
  --bg-tertiary: #e8e8e8;
  --bg-dark: #212121;
  --bg-card: #ffffff;

  /* Тени - более выраженные */
  --shadow-sm: 0 1px 3px rgba(0, 0, 0, 0.08);
  --shadow-md:
    0 4px 8px -1px rgba(0, 0, 0, 0.12), 0 2px 4px -1px rgba(0, 0, 0, 0.08);
  --shadow-lg:
    0 10px 20px -3px rgba(0, 0, 0, 0.15), 0 4px 6px -2px rgba(0, 0, 0, 0.08);
  --shadow-xl:
    0 20px 30px -5px rgba(0, 0, 0, 0.2), 0 10px 10px -5px rgba(0, 0, 0, 0.1);
  --shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, 0.3);
  --shadow-colored: 0 10px 25px -5px rgba(42, 75, 124, 0.25);

  /* Скругления - премиальный стиль */
  --radius-sm: 0.375rem;
  --radius-md: 0.5rem;
  --radius-lg: 0.75rem;
  --radius-xl: 1rem;
  --radius-2xl: 1.5rem;
  --radius-full: 9999px;
  --border-radius: 8px;

  /* Шрифты */
  --font-primary:
    -apple-system, BlinkMacSystemFont, "Segoe UI", "Helvetica Neue",
    Arial, sans-serif;
  --font-secondary:
    "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", "Helvetica Neue",
    Arial, sans-serif;
  --font-accent:
    -apple-system, BlinkMacSystemFont, "Segoe UI", "Helvetica Neue",
    Arial, sans-serif;
  --font-mono:
    "JetBrains Mono", "Fira Code", "SF Mono", "Monaco", "Inconsolata",
    "Roboto Mono", "Consolas", monospace;

  /* Размеры текста */
  --text-xs: 0.75rem;
  --text-sm: 0.875rem;
  --text-base: 1rem;
  --text-lg: 1.125rem;
  --text-xl: 1.25rem;
  --text-2xl: 1.5rem;
  --text-3xl: 1.875rem;
  --text-4xl: 2.25rem;
  --text-5xl: 3rem;
  --text-6xl: 3.75rem;

  /* Межстрочный интервал */
  --leading-none: 1;
  --leading-tight: 1.25;
  --leading-snug: 1.375;
  --leading-normal: 1.5;
  --leading-relaxed: 1.625;
  --leading-loose: 2;

  /* Переходы */
  --transition-fast: 0.15s ease-out;
  --transition-normal: 0.3s ease-out;
  --transition-slow: 0.5s ease-out;

  /* Z-индексы */
  --z-dropdown: 1000;
  --z-sticky: 1020;
  --z-fixed: 1030;
  --z-modal: 1040;
  --z-popover: 1050;
  --z-tooltip: 1060;

  /* Контейнер */
  --container-padding: 1.5rem;
  --container-max-width: 1280px;

  /* Границы - премиальный стиль */
  --border-color: #d4d4d4;

  /* Семантика для алертов и выделенных блоков */
  --color-success: #059669;
  --color-success-bg: rgba(5, 150, 105, 0.1);
  --color-danger: #dc2626;
  --color-danger-bg: rgba(220, 38, 38, 0.1);
  --color-warning: #ca8a04;
  --color-warning-bg: rgba(212, 175, 55, 0.12);
  --color-info-bg: rgba(42, 75, 124, 0.08);

  /* Select2 переменные */
  --select2-border-color: #d4d4d4;
  --select2-focus-color: #2a4b7c;
  --select2-focus-light: #3d6ba3;
  --select2-text-primary: #212121;
  --select2-text-muted: #757575;
  --select2-bg-primary: #ffffff;
  --select2-bg-secondary: #f9f9f9;
  --select2-radius-lg: 8px;
}

/* ===== СБРОС И ОСНОВНЫЕ СТИЛИ ===== */
*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  scroll-behavior: smooth;
  font-size: 16px;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}

body {
  font-family: var(--font-primary);
            
  background: var(--gradient-secondary); 

  color: var(--text-primary);
  line-height: var(--leading-relaxed);
  min-height: 100vh;
  position: relative;
  display: flex;
  flex-direction: column;
}

/* Фон: сетка ~200 ячеек, по одной иконке (аренда/прокат), приглушённый слой + динамика при скролле */
.bg-icons-layer {
  position: fixed;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  overflow: hidden;
  /* Лёгкий параллакс при скролле (движение по плоскости) */
  transform: translateY(calc(var(--scroll-y, 0) * 0.06px));
  will-change: transform;
}

.bg-icons-layer i {
  position: absolute;
  font-size: clamp(1.2rem, 4.2vw, 2.8rem);
  color: #a8a8a8;
  opacity: 0.14;
  transform: translate(-50%, -50%) rotate(calc(var(--scroll-y, 0) * 0.025deg));
  font-family: "Font Awesome 6 Pro", "Font Awesome 5 Pro", "Font Awesome 6 Free", var(--font-primary);
  will-change: transform;
}

/* Разброс прозрачности и базового поворота */
.bg-icons-layer i:nth-child(4n) { opacity: 0.1; }
.bg-icons-layer i:nth-child(4n + 2) { opacity: 0.18; }
.bg-icons-layer i:nth-child(5n) { transform: translate(-50%, -50%) rotate(calc(-6deg + var(--scroll-y, 0) * 0.02deg)); }
.bg-icons-layer i:nth-child(5n + 3) { transform: translate(-50%, -50%) rotate(calc(5deg + var(--scroll-y, 0) * 0.03deg)); }
.bg-icons-layer i:nth-child(7n + 1) { transform: translate(-50%, -50%) rotate(calc(3deg + var(--scroll-y, 0) * -0.02deg)); }

.container {
  width: 100%;
  max-width: var(--container-max-width);
  margin: 0 auto;
  padding: 0 var(--container-padding);
  overflow-x: visible;
}

main {
  flex: 1 0 auto;
  padding: 2rem 0;
  overflow-x: visible;
}

/* ===== ТИПОГРАФИЯ ===== */
h1,
h2,
h3,
h4,
h5,
h6 {
  font-family: var(--font-accent);
  font-weight: 600;
  line-height: var(--leading-tight);
  letter-spacing: -0.01em;
/*   color: var(--text-primary); */
  margin-bottom: 1rem;
}

h1 {
  font-size: var(--text-5xl);
  font-weight: 700;
}
h2 {
  font-size: var(--text-4xl);
}
h3 {
  font-size: var(--text-3xl);
}
h4 {
  font-size: var(--text-2xl);
}
h5 {
  font-size: var(--text-xl);
}
h6 {
  font-size: var(--text-lg);
}

p {
  font-family: var(--font-secondary);
  line-height: var(--leading-relaxed);
  color: var(--text-primary);
  margin-bottom: 1rem;
}

a {
  color: var(--primary-color);
  text-decoration: none;
  transition: color var(--transition-fast);
}

a:hover {
  color: var(--primary-hover);
}

strong {
  font-weight: 600;
}
em {
  font-style: italic;
}
code {
  font-family: var(--font-mono);
  font-size: 0.9em;
  padding: 0.2em 0.4em;
  background: var(--bg-tertiary);
  border-radius: var(--radius-sm);
  color: var(--accent-color);
}

pre {
  font-family: var(--font-mono);
  padding: 1rem;
  background: var(--bg-tertiary);
  border-radius: var(--radius-lg);
  overflow-x: auto;
  margin-bottom: 1rem;
}

blockquote {
  padding: 1rem 1.5rem;
  /*  */
  background: var(--bg-secondary);
  border-radius: var(--radius-md);
  margin-bottom: 1rem;
  font-style: italic;
  color: var(--text-secondary);
}

hr {
  border: none;
  height: 2px;
  background: var(--bg-tertiary);
  margin: 2rem 0;
}

ul,
ol {
  padding-left: 1.5rem;
  margin-bottom: 1rem;
}

li {
  margin-bottom: 0.5rem;
  line-height: var(--leading-relaxed);
}

/* ===== НАВИГАЦИЯ ===== */
nav ul {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.25rem;
  list-style: none;
}

nav ul li a {
  display: block;
  padding: 0.4rem 0.6rem;
  font-size: var(--text-xs);
  color: var(--text-white);
  border-radius: var(--radius-sm);
  transition: all var(--transition-fast);
}

nav ul li a:hover {
  background: rgba(255, 255, 255, 0.15);
  color: var(--text-white);
}

nav ul li a.active {
  background: rgba(255, 255, 255, 0.2);
  color: var(--text-white);
  font-weight: 600;
}

.nav-tabs {
  display: flex;
  overflow-x: auto;
  margin-bottom: 1.5rem;
  scrollbar-width: none;
}

.nav-tabs::-webkit-scrollbar {
  display: none;
}

.nav-link {
  padding: 1rem 1.5rem;
  color: var(--text-muted);
  border: none;
  background: none;
  cursor: pointer;
  font-weight: 500;
  position: relative;
  transition: all var(--transition-fast);
  white-space: nowrap;
  font-family: var(--font-secondary);
}

.nav-link:hover {
  color: var(--text-primary);
}

.nav-link.active {
  color: var(--primary-color);
}

.nav-link.active::after {
  content: "";
  position: absolute;
  bottom: -2px;
  left: 0;
  right: 0;
  height: 3px;
  background: var(--gradient-primary);
  border-radius: var(--radius-sm) var(--radius-sm) 0 0;
}

/* ===== КНОПКИ ===== */
.btn {
  border: none;
  border-radius: var(--radius-token-md, var(--radius-lg));
  font-weight: 600;
  font-family: var(--font-sans, var(--font-secondary));
  letter-spacing: 0.025em;
  cursor: pointer;
  transition: all var(--transition-fast);
  position: relative;
  overflow: hidden;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  box-shadow: var(--shadow-md);
  text-align: center;
}

.btn::before {
  content: "";
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: rgba(255, 255, 255, 0.2);
  transition: left var(--transition-fast);
  z-index: 1;
}

.btn > * {
  position: relative;
  z-index: 2;
}

.btn:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-lg);
}

.btn:hover::before {
  left: 100%;
}

.btn:active {
  transform: translateY(-1px);
  box-shadow: var(--shadow-md);
}

.btn:disabled {
  opacity: 0.6;
  cursor: not-allowed;
  transform: none;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.05);
}

/* Размеры кнопок */
.btn-sm {
  padding: 0.5rem 1rem;
  font-size: var(--text-xs);
  border-radius: var(--radius-md);
}

.btn-lg {
  padding: 1rem 2rem;
  font-size: var(--text-base);
  border-radius: var(--radius-xl);
}

.btn:not(.btn-sm):not(.btn-lg) {
  padding: 0.75rem 1.5rem;
  font-size: var(--text-sm);
}

/* Варианты кнопок */
.btn-primary {
  background: var(--gradient-primary);
  color: var(--text-white);
}

.btn-primary:hover {
  box-shadow: 0 12px 30px rgba(13, 95, 111, 0.3);
}

.btn-secondary {
  background: var(--gradient-warm);
  color: var(--text-white);
}

.btn-success {
  background: var(--gradient-success);
  color: var(--text-white);
}

.btn-danger {
  background: var(--gradient-danger);
  color: var(--text-white);
}

.btn-warning {
  background: var(--gradient-warning);
  color: #1f2937;
}

.btn-warning:hover {
  color: var(--text-white);
}

.btn-info {
  background: var(--gradient-info);
  color: var(--text-white);
}

.btn-outline {
  background: transparent;
  border: 2px solid var(--primary-color);
  color: var(--primary-color);
  box-shadow: none;
}

.btn-outline:hover {
  background: var(--primary-color);
  color: var(--text-white);
}

/* Outline-кнопки: перекрытие Bootstrap 5, палитра проекта */
.btn-outline-primary {
  background: transparent !important;
  border: 2px solid var(--primary-color) !important;
  color: var(--primary-color) !important;
  box-shadow: none !important;
}

.btn-outline-primary:hover {
  background: var(--primary-color) !important;
  border-color: var(--primary-color) !important;
  color: var(--text-white) !important;
  box-shadow: var(--shadow-colored) !important;
}

.btn-outline-primary:focus-visible {
  box-shadow: var(--focus-ring-soft) !important;
  outline: none !important;
}

.btn-outline-primary.active {
  background: var(--primary-color) !important;
  border-color: var(--primary-color) !important;
  color: var(--text-white) !important;
}

.btn-outline-secondary {
  background: transparent !important;
  border: 2px solid var(--accent-color) !important;
  color: var(--accent-dark) !important;
  box-shadow: none !important;
}

.btn-outline-secondary:hover {
  background: var(--gradient-warm) !important;
  border-color: var(--accent-color) !important;
  color: var(--text-white) !important;
  box-shadow: 0 8px 20px rgba(212, 175, 55, 0.3) !important;
}

.btn-outline-success {
  background: transparent !important;
  border: 2px solid var(--color-success) !important;
  color: var(--color-success) !important;
  box-shadow: none !important;
}

.btn-outline-success:hover {
  background: var(--gradient-success) !important;
  border-color: var(--color-success) !important;
  color: var(--text-white) !important;
  box-shadow: 0 8px 20px rgba(5, 150, 105, 0.25) !important;
}

.btn-outline-danger {
  background: transparent !important;
  border: 2px solid var(--color-danger) !important;
  color: var(--color-danger) !important;
  box-shadow: none !important;
}

.btn-outline-danger:hover {
  background: var(--gradient-danger) !important;
  border-color: var(--color-danger) !important;
  color: var(--text-white) !important;
  box-shadow: 0 8px 20px rgba(220, 38, 38, 0.25) !important;
}

.btn-outline-warning {
  background: transparent !important;
  border: 2px solid var(--color-warning) !important;
  color: #92400e !important;
  box-shadow: none !important;
}

.btn-outline-warning:hover {
  background: var(--gradient-warning) !important;
  border-color: var(--color-warning) !important;
  color: var(--text-white) !important;
  box-shadow: 0 8px 20px rgba(202, 138, 4, 0.25) !important;
}

.btn-outline-info {
  background: transparent !important;
  border: 2px solid var(--primary-light) !important;
  color: var(--primary-color) !important;
  box-shadow: none !important;
}

.btn-outline-info:hover {
  background: var(--gradient-info) !important;
  border-color: var(--primary-light) !important;
  color: var(--text-white) !important;
  box-shadow: var(--shadow-colored) !important;
}

.btn-outline-light {
  background: transparent !important;
  border: 2px solid var(--secondary-dark) !important;
  color: var(--text-secondary) !important;
  box-shadow: none !important;
}

.btn-outline-light:hover {
  background: var(--secondary-color) !important;
  border-color: var(--secondary-dark) !important;
  color: var(--text-primary) !important;
  box-shadow: var(--shadow-md) !important;
}

.btn-outline-dark {
  background: transparent !important;
  border: 2px solid var(--bg-dark) !important;
  color: var(--bg-dark) !important;
  box-shadow: none !important;
}

.btn-outline-dark:hover {
  background: var(--bg-dark) !important;
  border-color: var(--bg-dark) !important;
  color: var(--text-white) !important;
  box-shadow: 0 8px 20px rgba(33, 33, 33, 0.3) !important;
}

/* Отключённое состояние для outline-кнопок */
.btn-outline-primary:disabled,
.btn-outline-secondary:disabled,
.btn-outline-success:disabled,
.btn-outline-danger:disabled,
.btn-outline-warning:disabled,
.btn-outline-info:disabled,
.btn-outline-light:disabled,
.btn-outline-dark:disabled {
  background: transparent !important;
  border-color: var(--border-color) !important;
  color: var(--text-muted) !important;
  box-shadow: none !important;
}

/* Кнопка-ссылка: перекрытие Bootstrap 5, цвета из профиля проекта */
.btn.btn-link,
a.btn.btn-link {
  background-color: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  color: var(--primary-color) !important;
  text-decoration: underline;
  text-underline-offset: 0.2em;
  font-weight: 600;
  padding: 0.25rem 0.5rem;
  min-height: auto;
  transform: none;
}

.btn.btn-link:hover,
a.btn.btn-link:hover {
  background-color: transparent !important;
  box-shadow: none !important;
  color: var(--primary-hover) !important;
  text-decoration: underline;
  transform: none;
}

.btn.btn-link:focus-visible,
a.btn.btn-link:focus-visible {
  outline: 2px solid var(--primary-color);
  outline-offset: 2px;
  color: var(--primary-color) !important;
}

.btn.btn-link:active,
a.btn.btn-link:active {
  color: var(--primary-dark) !important;
  transform: none;
}

.btn.btn-link:disabled,
a.btn.btn-link:disabled {
  color: var(--text-muted) !important;
  opacity: 0.7;
  text-decoration: none;
}

/* ===== ФОРМЫ ===== */
.form-group {
  margin-bottom: 1.5rem;
}

.form-label {
  display: block;
  margin-bottom: 0.5rem;
  font-family: var(--font-secondary);
  font-size: var(--text-sm);
  font-weight: 500;
  letter-spacing: 0.025em;
  color: var(--text-primary);
}

.form-control {
  width: 100%;
  padding: 0.75rem 1rem;
  background-color: var(--bg-tertiary);
  border: 2px solid var(--border-color);
  border-radius: var(--radius-lg);
  font-size: var(--text-base);
  color: var(--text-primary);
  font-family: var(--font-secondary);
  transition: all var(--transition-fast);
}

.form-control:hover {
  border-color: var(--border-hover);
}

.form-control:focus,
.form-control:focus-visible {
  outline: none;
  border-color: var(--border-focus);
  box-shadow: var(--focus-ring-soft);
  background: var(--bg-primary);
}

.form-control::placeholder {
  color: var(--text-muted);
  opacity: 0.7;
}

textarea.form-control {
  resize: vertical;
  min-height: 120px;
}

select.form-control {
  cursor: pointer;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='%230d5f6f' viewBox='0 0 16 16'%3E%3Cpath d='M7.247 11.14 2.451 5.658C1.885 5.013 2.345 4 3.204 4h9.592a1 1 0 0 1 .753 1.659l-4.796 5.48a1 1 0 0 1-1.506 0z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 1rem center;
  background-size: 16px;
  padding-right: 2.5rem;
}

/* ===== ТАБЛИЦЫ ===== */
.table {
  width: 100%;
  border-collapse: collapse;
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
}

.table th {
  background: var(--bg-tertiary);
  padding: 1rem;
  text-align: left;
  font-weight: 600;
  color: var(--text-primary);
  font-family: var(--font-secondary);
}

.table td {
  padding: 1rem;
  border-bottom: 1px solid var(--bg-tertiary);
  font-family: var(--font-secondary);
}

.table tbody tr {
  transition: background var(--transition-fast);
}

.table tbody tr:hover {
  background: var(--bg-tertiary);
}

.table tbody tr:last-child td {
  border-bottom: none;
}

/* Пагинация таблиц (бронирования и др.) */
.rentals-pagination {
  margin-top: 1.5rem;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 1rem;
}

.pagination-list {
  display: flex;
  list-style: none;
  margin: 0;
  padding: 0;
  gap: 0.25rem;
}

.pagination-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 2.25rem;
  height: 2.25rem;
  padding: 0 0.5rem;
  border-radius: var(--radius-md);
  background: var(--bg-secondary);
  color: var(--text-primary);
  text-decoration: none;
  font-weight: 500;
  transition: background var(--transition-fast), color var(--transition-fast);
}

.pagination-link:hover:not(.disabled):not(.active) {
  background: var(--primary-light);
  color: var(--text-white);
}

.pagination-link.active {
  background: var(--primary-color);
  color: var(--text-white);
  pointer-events: none;
}

.pagination-link.disabled {
  opacity: 0.5;
  cursor: not-allowed;
  pointer-events: none;
}

.pagination-info {
  margin: 0;
  font-size: var(--text-sm);
  color: var(--text-muted);
}

/* ===== КАРТОЧКИ ===== */
.items-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 1.5rem;
  margin-bottom: 2rem;
}

.item-card {
  background: var(--bg-card);
  border-radius: var(--radius-xl);
  border: 1px solid var(--border-color);
  overflow: hidden;
  transition: all var(--transition-normal);
  box-shadow: var(--shadow-sm);
}

.item-card:hover {
  transform: translateY(-8px);
  box-shadow: var(--shadow-xl);
  border-color: var(--primary-light);
}

.item-image {
  height: 200px;
  overflow: hidden;
}

.item-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transition-slow);
}

.item-card:hover .item-image img {
  transform: scale(1.05);
}

.item-content {
  padding: 1.25rem;
}

.item-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 1rem;
  margin-bottom: 1rem;
}

.item-title {
  font-size: var(--text-base);
  font-weight: 600;
  color: var(--text-primary);
  margin: 0 0 0.5rem 0;
  line-height: 1.4;
}

.item-title a {
  color: inherit;
  transition: color var(--transition-fast);
}

.item-title a:hover {
  color: var(--primary-color);
}

.item-rating {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.stars {
  color: #fbbf24;
  font-size: var(--text-sm);
}

.rating-text {
  font-weight: 600;
  font-size: var(--text-sm);
  color: var(--text-primary);
}

.review-count {
  font-size: var(--text-xs);
  color: var(--text-muted);
}

.item-price {
  margin-bottom: 1rem;
}

.price-amount {
  font-size: var(--text-lg);
  font-weight: 700;
  color: var(--primary-color);
}

.price-period {
  font-size: var(--text-sm);
  color: var(--text-secondary);
  margin-left: 0.25rem;
}

/* Блок цены товара: прогрессивная или базовая + неделя/месяц (includes/item_price_display.php) */
.item-price-block {
  line-height: 1.3;
}
.item-price-block .item-price-main {
  display: block;
  font-weight: 700;
  color: var(--primary-color);
}
.item-price-block .item-price-amount {
  font-size: var(--text-lg);
  font-weight: 700;
  color: var(--primary-color);
}
.item-price-block .item-price-period {
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--text-secondary);
  margin-left: 0.25rem;
}
.item-price-block .item-price-extra {
  display: block;
  font-size: var(--text-xs, 0.75rem);
  color: var(--text-muted);
  margin-top: 2px;
}
.item-price-block .item-price-sep {
  margin: 0 4px;
}
.item-price-block .item-price-progressive-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: var(--text-sm);
  font-weight: 600;
  background: linear-gradient(135deg, var(--accent-light) 0%, var(--accent-color) 100%);
  color: var(--text-primary);
  padding: 4px 10px;
  border-radius: var(--radius-md, 8px);
  margin-bottom: 4px;
}
.item-price-block .item-price-from {
  display: block;
  font-size: var(--text-base);
  font-weight: 600;
  color: var(--primary-color);
}
.item-price-block .item-price-range-desc {
  display: block;
  font-size: var(--text-xs);
  font-weight: 500;
  color: var(--text-secondary);
  margin-top: 2px;
}
.item-price-block .item-price-note {
  font-size: var(--text-xs);
  color: var(--text-muted);
  margin-top: 4px;
}
.item-price-block .item-price-note i {
  margin-right: 4px;
  opacity: 0.9;
}

.item-owner,
.item-location {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: var(--text-sm);
  color: var(--text-secondary);
  margin-bottom: 0.5rem;
}

.item-owner i,
.item-location i {
  color: var(--primary-color);
  width: 16px;
}

.item-stats {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  margin-top: 1rem;
  padding-top: 1rem;
  border-top: 1px solid var(--bg-tertiary);
}

.item-stat {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: var(--text-sm);
  color: var(--text-secondary);
}

.item-stat i {
  color: var(--primary-color);
}

/* Блок кнопок условий/политик: по центру, в один ряд с адаптивным переносом */
.terms-actions {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0.75rem;
  flex-wrap: wrap;
}

.terms-actions .btn {
  min-width: 220px;
}

/* ===== СТАТУСЫ ===== */
.status-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.4rem 0.8rem;
  font-size: var(--text-xs);
  font-weight: 600;
  border-radius: var(--radius-full);
  white-space: nowrap;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  transition: all var(--transition-fast);
}

/* СОВРЕМЕННЫЕ СТАТУСЫ - ЯРКИЕ И ВИДИМЫЕ */
.status-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.5rem 1rem;
  font-size: var(--text-xs);
  font-weight: 600;
  border-radius: var(--radius-full);
  white-space: nowrap;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  transition: all var(--transition-fast);
  position: relative;
  overflow: hidden;
}

.status-badge::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    135deg,
    rgba(255, 255, 255, 0.2) 0%,
    transparent 100%
  );
  pointer-events: none;
}

.status-badge > * {
  position: relative;
  z-index: 1;
}

/* ✅ ДОСТУПНО - ЗЕЛЕНЫЙ */
.status-available {
  background: #22c55e;
  color: white;
  box-shadow: 0 4px 12px rgba(34, 197, 94, 0.4);
}

.status-available::after {
  content: "\2713"; /* ✓ галочка через Unicode escape — без искажений на хостинге */
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  background: rgba(255, 255, 255, 0.3);
  border-radius: 50%;
  font-size: 12px;
  font-weight: 700;
  margin-left: 0.25rem;
}

/* ⏳ ОЖИДАНИЕ - ОРАНЖЕВЫЙ */
.status-awaiting {
  background: #f59e0b;
  color: white;
  box-shadow: 0 4px 12px rgba(245, 158, 11, 0.4);
}

.status-awaiting::after {
  content: "⏳";
  display: inline-block;
  margin-left: 0.25rem;
  animation: pulse 2s ease-in-out infinite;
}

/* 🔴 СДАНО В АРЕНДУ - КРАСНЫЙ */
.status-rented {
  background: #ef4444;
  color: white;
  box-shadow: 0 4px 12px rgba(239, 68, 68, 0.4);
}

.status-rented::after {
  content: "🔴";
  display: inline-block;
  margin-left: 0.25rem;
}

/* 🔧 ТЕХНИЧЕСКОЕ ОБСЛУЖИВАНИЕ - ГОЛУБОЙ */
.status-maintenance {
  background: #0ea5e9;
  color: white;
  box-shadow: 0 4px 12px rgba(14, 165, 233, 0.4);
}

.status-maintenance::after {
  content: "🔧";
  display: inline-block;
  margin-left: 0.25rem;
}

/* ⚫ НЕАКТИВНО - СЕРЫЙ */
.status-inactive {
  background: #6b7280;
  color: white;
  box-shadow: 0 4px 12px rgba(107, 114, 128, 0.4);
}

.status-inactive::after {
  content: "⚫";
  display: inline-block;
  margin-left: 0.25rem;
}

/* ⏱️ ОЖИДАЕТ ПОДТВЕРЖДЕНИЯ - СИНИЙ */
.status-pending {
  background: #3b82f6;
  color: white;
  box-shadow: 0 4px 12px rgba(59, 130, 246, 0.4);
}

.status-pending::after {
  content: "⏱️";
  display: inline-block;
  margin-left: 0.25rem;
}

/* ✔️ ПОДТВЕРЖДЕНО - ЗЕЛЕНЫЙ */
.status-confirmed {
  background: #10b981;
  color: white;
  box-shadow: 0 4px 12px rgba(16, 185, 129, 0.4);
}

.status-confirmed::after {
  content: "✔️";
  display: inline-block;
  margin-left: 0.25rem;
}

/* 🟢 АКТИВНО - ЯРКО-ЗЕЛЕНЫЙ */
.status-active {
  background: #16a34a;
  color: white;
  box-shadow: 0 4px 12px rgba(22, 163, 74, 0.4);
}

.status-active::after {
  content: "🟢";
  display: inline-block;
  margin-left: 0.25rem;
  animation: pulse 2s ease-in-out infinite;
}

/* ✅ ЗАВЕРШЕНО - ТЕМНО-СЕРЫЙ */
.status-completed {
  background: #4b5563;
  color: white;
  box-shadow: 0 4px 12px rgba(75, 85, 99, 0.4);
}

.status-completed::after {
  content: "✅";
  display: inline-block;
  margin-left: 0.25rem;
}

/* ❌ ОТМЕНЕНО - ТЕМНО-КРАСНЫЙ */
.status-cancelled {
  background: #dc2626;
  color: white;
  box-shadow: 0 4px 12px rgba(220, 38, 38, 0.4);
}

.status-cancelled::after {
  content: "❌";
  display: inline-block;
  margin-left: 0.25rem;
}

/* 🚫 ОТКЛОНЕНО - ТЕМНО-КРАСНЫЙ */
.status-rejected {
  background: #991b1b;
  color: white;
  box-shadow: 0 4px 12px rgba(153, 27, 27, 0.4);
}

.status-rejected::after {
  content: "🚫";
  display: inline-block;
  margin-left: 0.25rem;
}

/* 📋 ОЖИДАЕТ ПОДТВЕРЖДЕНИЯ (бронирование) - БИРЮЗОВЫЙ */
.status-awaiting_confirmation {
  background: #0d9488;
  color: white;
  box-shadow: 0 4px 12px rgba(13, 148, 136, 0.4);
}

.status-awaiting_confirmation::after {
  content: "📋";
  display: inline-block;
  margin-left: 0.25rem;
}

/* ⏳ ОТМЕНА - ОРАНЖЕВЫЙ */
.status-cancelling {
  background: #ea580c;
  color: white;
  box-shadow: 0 4px 12px rgba(234, 88, 12, 0.4);
}

.status-cancelling::after {
  content: "⏳";
  display: inline-block;
  margin-left: 0.25rem;
}

/* ⚠️ ПРОБЛЕМА - ТЕМНО-КРАСНЫЙ */
.status-problem {
  background: #b91c1c;
  color: white;
  box-shadow: 0 4px 12px rgba(185, 28, 28, 0.4);
}

.status-problem::after {
  content: "⚠️";
  display: inline-block;
  margin-left: 0.25rem;
  animation: pulse 2s ease-in-out infinite;
}

/* 🔒 НЕДОСТУПНО - КРАСНЫЙ */
.status-unavailable {
  background: #dc3545;
  color: white;
  box-shadow: 0 4px 12px rgba(220, 53, 69, 0.4);
}

.status-unavailable::after {
  content: "🔒";
  display: inline-block;
  margin-left: 0.25rem;
}

/* 📋 НЕ РАЗМЕЩЕНО - СЕРЫЙ */
.status-not-placed {
  background: #6c757d;
  color: white;
  box-shadow: 0 4px 12px rgba(108, 117, 125, 0.4);
}

.status-not-placed::after {
  content: "📋";
  display: inline-block;
  margin-left: 0.25rem;
}

/* 📌 ЗАБРОНИРОВАНО - ОРАНЖЕВЫЙ */
.status-booked {
  background: #fd7e14;
  color: white;
  box-shadow: 0 4px 12px rgba(253, 126, 20, 0.4);
}

.status-booked::after {
  content: "📌";
  display: inline-block;
  margin-left: 0.25rem;
}

/* ⚠️ ОГРАНИЧЕННОЕ КОЛИЧЕСТВО - ЖЕЛТЫЙ */
.status-limited {
  background: #fbbf24;
  color: #1f2937;
  box-shadow: 0 4px 12px rgba(251, 191, 36, 0.4);
}

.status-limited::after {
  content: "⚠️";
  display: inline-block;
  margin-left: 0.25rem;
}

/* 🔥 ПОПУЛЯРНО - ГРАДИЕНТ */
.status-popular {
  background: linear-gradient(135deg, #ff6b35 0%, #ff8c42 100%);
  color: white;
  box-shadow: 0 4px 12px rgba(255, 107, 53, 0.4);
}

.status-popular::after {
  content: "🔥";
  display: inline-block;
  margin-left: 0.25rem;
  animation: bounce 1s ease-in-out infinite;
}

/* ===== АНИМАЦИИ ДЛЯ СТАТУСОВ ===== */
@keyframes pulse {
  0%,
  100% {
    opacity: 1;
  }
  50% {
    opacity: 0.7;
  }
}

@keyframes bounce {
  0%,
  100% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-3px);
  }
}

/* Hover эффект для всех статусов */
.status-badge:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 16px rgba(0, 0, 0, 0.2) !important;
}

/* Адаптивность: пропорциональное уменьшение на узких экранах */
@media (max-width: 640px) {
  .status-badge {
    padding: 0.35rem 0.65rem;
    font-size: 0.65rem;
  }
  .status-badge.status-available::after,
  .status-badge.status-awaiting::after {
    width: 14px;
    height: 14px;
    font-size: 10px;
  }
}

/* На мобильном: для статусов с иконкой — только иконка (текст в title) */
@media (max-width: 480px) {
  .status-badge.status-available .status-badge__text,
  .status-badge.status-awaiting .status-badge__text {
    display: none;
  }
  .status-badge.status-available,
  .status-badge.status-awaiting {
    padding: 0.5rem;
    min-width: 36px;
    min-height: 36px;
    justify-content: center;
  }
  .status-badge.status-available::after,
  .status-badge.status-awaiting::after {
    margin-left: 0;
    width: 18px;
    height: 18px;
    font-size: 12px;
  }
  .status-badge i {
    margin-right: 0;
  }
  /* Остальные статусы — уменьшенный текст, чтобы не выходил за рамки */
  .status-badge:not(.status-available):not(.status-awaiting) {
    padding: 0.35rem 0.5rem;
    font-size: 0.6rem;
    max-width: 100%;
  }
  .status-badge:not(.status-available):not(.status-awaiting) .status-badge__text {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    max-width: 120px;
  }
}

/* ===== ГАЛЕРЕЯ ===== */
.gallery {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
  gap: 0.75rem;
  margin-bottom: 2rem;
}

.gallery-image {
  width: 100%;
  height: 150px;
  object-fit: cover;
  border-radius: var(--radius-md);
  cursor: pointer;
  border: 2px solid transparent;
  transition: all var(--transition-normal);
}

.gallery-image:hover {
  transform: scale(1.05);
  border-color: var(--primary-color);
  box-shadow: var(--shadow-md);
}

.gallery-image.primary {
  border-color: var(--primary-color);
  box-shadow: var(--shadow-sm);
}

/* ===== ПРОФИЛЬ ===== */
.profile-container {
  background: var(--bg-card);
  border-radius: var(--radius-2xl);
  box-shadow: var(--shadow-lg);
  overflow: hidden;
  margin-bottom: 2rem;
}

.profile-header {
  padding: 2rem;
  background: var(--gradient-primary);
  position: relative;
  overflow: hidden;
}

.profile-header::before {
  content: "";
  position: absolute;
  top: -50%;
  right: -50%;
  width: 200%;
  height: 200%;
  background: radial-gradient(
    circle,
    rgba(255, 255, 255, 0.1) 0%,
    transparent 70%
  );
  animation: float 6s ease-in-out infinite;
}

.profile-avatar {
  width: 80px;
  height: 80px;
  border-radius: 50%;
  overflow: hidden;
  border: 4px solid var(--text-white);
  transition: transform var(--transition-normal);
}

.profile-avatar:hover {
  transform: scale(1.05);
}

.profile-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.profile-info {
  position: relative;
  z-index: 1;
  color: var(--text-white);
}

.profile-info h1 {
  color: inherit;
  margin-bottom: 0.5rem;
}

/* ===== МОДАЛЬНЫЕ ОКНА ===== */

/* --- Bootstrap modal + backdrop: раз и навсегда (в т.ч. мобильные) --- */
.modal-backdrop {
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  z-index: 1040 !important;
  width: 100vw !important;
  height: 100vh !important;
  pointer-events: auto !important;
}
.modal-backdrop.fade { opacity: 0; }
.modal-backdrop.show { opacity: 0.5; }

/* Модал всегда выше backdrop и поверх всего; при .show — гарантированно виден */
.modal {
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  z-index: 1050 !important;
  width: 100% !important;
  height: 100% !important;
  overflow-x: hidden !important;
  overflow-y: auto !important;
  outline: 0 !important;
}
.modal.fade { transition: opacity 0.15s linear; }
.modal.show { display: block !important; visibility: visible !important; opacity: 1 !important; }
.modal .modal-dialog {
  position: relative;
  width: auto;
  max-width: 500px;
  margin: 1.75rem auto;
  min-height: calc(100vh - 3.5rem);
  display: flex;
  align-items: center;
}

/* Мобильные: окно в зоне видимости, без «уезжания» и без блокировки только затемнением */
@media (max-width: 767px) {
  .modal.show {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    padding: 0.5rem !important;
  }
  .modal .modal-dialog {
    margin: 0.5rem auto !important;
    max-height: calc(100vh - 1rem) !important;
    min-height: 0 !important;
    align-items: flex-start !important;
  }
  .modal .modal-content {
    max-height: calc(100vh - 1rem) !important;
    overflow-y: auto !important;
  }
}

.modal-overlay {
  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: var(--z-modal);
  padding: 1rem;
  opacity: 0;
  visibility: hidden;
  transition: all var(--transition-normal);
  backdrop-filter: blur(4px);
}

.modal-overlay.show {
  opacity: 1;
  visibility: visible;
}

.modal-content {
  background: var(--bg-card);
  border-radius: var(--radius-xl);
  padding: 2rem;
  max-width: 500px;
  width: 100%;
  max-height: 90vh;
  overflow-y: auto;
  box-shadow: var(--shadow-2xl);
  animation: modalSlideIn 0.3s ease-out;
}

/* Полноэкранное модальное окно (договор и др.): на весь экран по высоте и ширине */
.modal-dialog.modal-fullscreen {
  width: 100vw;
  max-width: none;
  height: 100vh;
  max-height: none;
  margin: 0;
}

.modal-dialog.modal-fullscreen .modal-content {
  max-width: none;
  width: 100%;
  max-height: none;
  height: 100%;
  min-height: 100vh;
  border-radius: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
}

.modal-dialog.modal-fullscreen .modal-header {
  flex-shrink: 0;
  padding: 1rem 1.5rem;
  border-bottom: 1px solid var(--border-color, #dee2e6);
}

.modal-dialog.modal-fullscreen .modal-body {
  flex: 1 1 0;
  min-height: 0;
  height: 100%;
  overflow-y: auto;
  padding: 1.5rem 2rem;
}

.modal-dialog.modal-fullscreen .modal-footer {
  flex-shrink: 0;
  padding: 1rem 1.5rem;
  border-top: 1px solid var(--border-color, #dee2e6);
  gap: 0.5rem;
}

.modal-title {
  font-family: var(--font-accent);
  font-weight: 600;
  letter-spacing: -0.01em;
  margin-bottom: 1.5rem;
  font-size: var(--text-2xl);
  color: var(--text-primary);
}

.modal-body {
  font-family: var(--font-secondary);
  line-height: var(--leading-relaxed);
  color: var(--text-primary);
}

/* ===== УВЕДОМЛЕНИЯ (алерты) — в стиле палитры проекта ===== */
.alert {
  padding: 1rem 1.25rem;
  border-radius: var(--radius-lg);
  display: flex;
  align-items: flex-start;
  gap: 1rem;
  margin-bottom: 1rem;
  animation: slideInRight 0.3s ease-out;
  border: 1px solid transparent;
  font-size: var(--text-sm);
  line-height: var(--leading-relaxed);
}

.alert.success {
  background: var(--color-success-bg);
  color: var(--color-success);
  border-left: 4px solid var(--color-success);
  border-color: rgba(5, 150, 105, 0.2);
}

.alert.error {
  background: var(--color-danger-bg);
  color: var(--color-danger);
  border-left: 4px solid var(--color-danger);
  border-color: rgba(220, 38, 38, 0.2);
}

.alert.warning {
  background: var(--color-warning-bg);
  color: var(--color-warning);
  border-left: 4px solid var(--accent-color);
  border-color: rgba(212, 175, 55, 0.25);
}

.alert.info {
  background: var(--color-info-bg);
  color: var(--primary-color);
  border-left: 4px solid var(--primary-color);
  border-color: rgba(42, 75, 124, 0.2);
}

/* Совместимость с Bootstrap alert-* классов (в контенте страниц) */
.alert.alert-success { background: var(--color-success-bg); color: #0f5132; border-left: 4px solid var(--color-success); border-color: rgba(5, 150, 105, 0.2); }
.alert.alert-danger { background: var(--color-danger-bg); color: #842029; border-left: 4px solid var(--color-danger); border-color: rgba(220, 38, 38, 0.2); }
.alert.alert-warning { background: var(--color-warning-bg); color: #664d03; border-left: 4px solid var(--color-warning); border-color: rgba(202, 138, 4, 0.25); }
.alert.alert-info { background: var(--color-info-bg); color: var(--primary-color); border-left: 4px solid var(--primary-color); border-color: rgba(42, 75, 124, 0.2); }

/* ===== TOAST-УВЕДОМЛЕНИЯ (flash) — палитра проекта ===== */
.toast-container {
  --toast-radius: var(--radius-lg);
  --toast-shadow: var(--shadow-lg);
  --toast-font: var(--font-secondary);
}
.toast-container .toast {
  border: none;
  border-radius: var(--toast-radius);
  box-shadow: var(--toast-shadow), 0 0 0 1px rgba(0, 0, 0, 0.06);
  font-family: var(--toast-font);
  font-size: var(--text-sm);
  overflow: hidden;
}
.toast-container .toast .toast-header {
  border-bottom: 1px solid rgba(255, 255, 255, 0.2);
  padding: 0.75rem 1rem;
  font-weight: 600;
}
.toast-container .toast .toast-body {
  padding: 1rem;
  color: rgba(255, 255, 255, 0.95);
}
.toast-container .toast .btn-close-white {
  filter: brightness(0) invert(1);
  opacity: 0.85;
}
.toast-container .toast.bg-success,
.toast-container .toast.bg-success .toast-header {
  background: var(--gradient-success) !important;
  color: #fff !important;
}
.toast-container .toast.bg-danger,
.toast-container .toast.bg-danger .toast-header {
  background: var(--gradient-danger) !important;
  color: #fff !important;
}
.toast-container .toast.bg-warning,
.toast-container .toast.bg-warning .toast-header {
  background: var(--gradient-warning) !important;
  color: #1c1917 !important;
}
.toast-container .toast.bg-warning .toast-body { color: rgba(28, 25, 23, 0.9); }
.toast-container .toast.bg-info,
.toast-container .toast.bg-info .toast-header {
  background: var(--gradient-info) !important;
  color: #fff !important;
}

/* ===== ВЫДЕЛЕННЫЙ БЛОК (общий акцентный блок контента) ===== */
.highlight-block {
  padding: 1.25rem 1.5rem;
  border-radius: var(--radius-lg);
  background: linear-gradient(135deg, rgba(42, 75, 124, 0.06) 0%, rgba(61, 107, 163, 0.04) 100%);
  border-left: 4px solid var(--primary-color);
  border: 1px solid rgba(42, 75, 124, 0.15);
  border-left-width: 4px;
  color: var(--text-primary);
  margin-bottom: 1.5rem;
}

.highlight-block .highlight-block__title {
  font-size: var(--text-lg);
  font-weight: 600;
  color: var(--primary-dark);
  margin-bottom: 0.5rem;
}

.highlight-block p {
  color: var(--text-secondary);
  margin: 0;
  font-size: var(--text-sm);
  line-height: var(--leading-relaxed);
}

.highlight-block--accent {
  background: linear-gradient(135deg, rgba(212, 175, 55, 0.08) 0%, rgba(232, 197, 71, 0.05) 100%);
  border-left-color: var(--accent-color);
  border-color: rgba(212, 175, 55, 0.2);
}

.highlight-block--accent .highlight-block__title {
  color: var(--accent-dark);
}

.highlight-block--warning {
  background: var(--color-warning-bg);
  border-left-color: var(--color-warning);
  border-color: rgba(202, 138, 4, 0.25);
}

.highlight-block--warning .highlight-block__title {
  color: var(--color-warning);
}

.highlight-block--warning p {
  color: var(--text-secondary);
}

/* ===== ХЛЕБНЫЕ КРОШКИ ===== */
.breadcrumb {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-bottom: 1.5rem;
  font-family: var(--font-secondary);
  font-size: var(--text-sm);
  color: var(--text-secondary);
}

.breadcrumb a {
  color: inherit;
  transition: color var(--transition-fast);
}

.breadcrumb a:hover {
  color: var(--primary-color);
}

.breadcrumb-separator {
  color: var(--text-muted);
}

/* Хлебные крошки (generate_breadcrumbs): без нумерации, в одну строку со слэшем */
.breadcrumbs {
  margin-bottom: 1.5rem;
}

.breadcrumbs .breadcrumb-list {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  list-style: none;
  padding-left: 0;
  margin: 0;
  align-items: center;
  font-size: 0.95rem;
  color: var(--text-secondary);
}

.breadcrumbs .breadcrumb-item {
  display: flex;
  align-items: center;
}

.breadcrumbs .breadcrumb-item:not(:last-child)::after {
  content: "/";
  margin-left: 0.5rem;
  color: var(--text-muted);
  font-weight: 300;
}

.breadcrumbs .breadcrumb-item a {
  color: var(--primary-color);
  text-decoration: none;
}

.breadcrumbs .breadcrumb-item a:hover {
  color: var(--primary-hover);
}

.breadcrumbs .breadcrumb-item.active span {
  color: var(--text-primary);
  font-weight: 500;
}

/* ===== ПУСТЫЕ СОСТОЯНИЯ ===== */
.empty-state {
  text-align: center;
  padding: 3rem 1rem;
  color: var(--text-secondary);
}

.empty-state i {
  font-size: 4rem;
  color: var(--text-muted);
  margin-bottom: 1.5rem;
  opacity: 0.5;
}

.empty-state h3 {
  font-size: var(--text-xl);
  font-weight: 600;
  color: var(--text-primary);
  margin-bottom: 0.75rem;
}

.empty-state p {
  font-size: var(--text-base);
  color: var(--text-secondary);
  margin-bottom: 1.5rem;
  max-width: 400px;
  margin-left: auto;
  margin-right: auto;
}

/* ===== ВЫПАДАЮЩИЕ МЕНЮ ===== */
.dropdown {
  position: relative;
  display: inline-block;
}

.dropdown-toggle {
  background: none;
  border: none;
  cursor: pointer;
  padding: 0.5rem;
  color: var(--text-secondary);
  transition: color var(--transition-fast);
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.dropdown-toggle:hover {
  color: var(--text-primary);
}

.dropdown-menu {
  position: absolute;
  top: 100%;
  right: 0;
  background: var(--bg-card);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-xl);
  min-width: 200px;
  padding: 0.5rem;
  z-index: var(--z-dropdown);
  opacity: 0;
  visibility: hidden;
  transform: translateY(-10px);
  transition: all var(--transition-fast);
  border: 1px solid var(--border-color);
}

.dropdown-menu.show {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.dropdown-item {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.75rem 1rem;
  border-radius: var(--radius-md);
  font-size: var(--text-sm);
  color: var(--text-primary);
  cursor: pointer;
  transition: all var(--transition-fast);
  border: none;
  background: none;
  width: 100%;
  text-align: left;
}

.dropdown-item:hover {
  background: var(--bg-secondary);
  color: var(--primary-color);
}

.dropdown-item i {
  width: 16px;
  text-align: center;
}

.dropdown-item.text-danger {
  color: #dc2626;
}

.dropdown-item.text-danger:hover {
  background: rgba(239, 68, 68, 0.1);
}

.dropdown-divider {
  height: 1px;
  background: var(--bg-tertiary);
  margin: 0.5rem 0;
}

/* ===== ЗАГОЛОВКИ СТРАНИЦ ===== */
.page-header {
  margin-bottom: 2rem;
  padding-bottom: 1rem;
  border-bottom: 2px solid var(--bg-tertiary);
}

.page-header h1 {
  font-family: var(--font-accent);
  font-weight: 700;
  letter-spacing: -0.02em;
  margin-bottom: 0.5rem;
}

.page-header p {
  font-family: var(--font-secondary);
  font-size: var(--text-base);
  max-width: 600px;
}

/* ===== ФИЛЬТРЫ (стекло, мокрое стекло, 3D тень) ===== */
.items-filter {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 2rem;
  padding: 1.5rem 2.5rem;
  background: rgba(255, 255, 255, 0.18);
  backdrop-filter: blur(12px) saturate(160%);
  -webkit-backdrop-filter: blur(12px) saturate(160%);
  border: 1px solid rgba(255, 255, 255, 0.45);
  border-radius: var(--radius-xl);
  box-shadow:
    0 4px 14px rgba(0, 0, 0, 0.08),
    0 2px 6px rgba(0, 0, 0, 0.04),
    inset 0 1px 0 rgba(255, 255, 255, 0.35);
  overflow: visible;
  min-width: 0;
  width: 100%;
  box-sizing: border-box;
}

.filter-buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  justify-content: center;
  width: 100%;
}

.filter-btn {
  padding: 0.5rem 1rem;
  border: 2px solid var(--bg-tertiary);
  background: transparent;
  border-radius: var(--radius-lg);
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--text-secondary);
  cursor: pointer;
  transition: all var(--transition-fast);
  font-family: var(--font-secondary);
}

.filter-btn:hover {
  border-color: var(--primary-color);
  color: var(--primary-color);
}

.filter-btn.active {
  background: var(--gradient-primary);
  border-color: transparent;
  color: var(--text-white);
}

.search-box {
  position: relative;
  flex: 1;
  min-width: 250px;
}

.search-box input {
  width: 100%;
  padding: 0.75rem 1rem 0.75rem 2.5rem;
  border: 2px solid var(--bg-tertiary);
  border-radius: var(--radius-lg);
  font-size: var(--text-sm);
  transition: all var(--transition-fast);
  background: var(--bg-primary);
}

.search-box input:focus {
  border-color: var(--primary-color);
  box-shadow: 0 0 0 4px rgba(13, 95, 111, 0.1);
  outline: none;
}

.search-box i {
  position: absolute;
  left: 1rem;
  top: 50%;
  transform: translateY(-50%);
  color: var(--text-muted);
  pointer-events: none;
}

/* ===== УТИЛИТЫ ===== */
.text-center {
  text-align: center;
}
.text-left {
  text-align: left;
}
.text-right {
  text-align: right;
}
.text-primary {
  color: var(--primary-color);
}
.text-secondary {
  color: var(--text-secondary);
}
.text-muted {
  color: var(--text-muted);
}
.text-danger {
  color: #dc2626;
}
.text-success {
  color: #10b981;
}
.text-warning {
  color: #f59e0b;
}
.text-info {
  color: #3b82f6;
}

.fw-bold {
  font-weight: 700;
}
.fw-semibold {
  font-weight: 600;
}
.fw-medium {
  font-weight: 500;
}
.fw-normal {
  font-weight: 400;
}

.d-grid {
  display: grid;
}
.d-flex {
  display: flex;
}
.d-block {
  display: block;
}
.d-none {
  display: none;
}

.align-items-center {
  align-items: center;
}
.justify-content-center {
  justify-content: center;
}
.justify-content-between {
  justify-content: space-between;
}
.flex-wrap {
  flex-wrap: wrap;
}
.flex-column {
  flex-direction: column;
}

.gap-1 {
  gap: 0.5rem;
}
.gap-2 {
  gap: 1rem;
}
.gap-3 {
  gap: 1.5rem;
}
.gap-4 {
  gap: 2rem;
}

.mb-1 {
  margin-bottom: 0.5rem;
}
.mb-2 {
  margin-bottom: 1rem;
}
.mb-3 {
  margin-bottom: 1.5rem;
}
.mb-4 {
  margin-bottom: 2rem;
}

.mt-1 {
  margin-top: 0.5rem;
}
.mt-2 {
  margin-top: 1rem;
}
.mt-3 {
  margin-top: 1.5rem;
}
.mt-4 {
  margin-top: 2rem;
}

.p-1 {
  padding: 0.5rem;
}
.p-2 {
  padding: 1rem;
}
.p-3 {
  padding: 1.5rem;
}
.p-4 {
  padding: 2rem;
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
}

/* ===== ДОСТУПНОСТЬ ===== */
/* Клавиатурный фокус — нейтральная обводка; поля .form-control — см. выше */
:focus-visible {
  outline: 2px solid var(--border-focus);
  outline-offset: 2px;
}

:focus:not(:focus-visible) {
  outline: none;
}

.btn:focus,
.btn:focus-visible,
.nav-link:focus,
.nav-link:focus-visible,
.dropdown-toggle:focus,
.dropdown-toggle:focus-visible {
  outline: none;
  box-shadow: var(--focus-ring-soft);
}

/* ===== СКРОЛЛБАР ===== */
::-webkit-scrollbar {
  width: 10px;
  height: 10px;
}

::-webkit-scrollbar-track {
  background: var(--bg-tertiary);
  border-radius: var(--radius-full);
}

::-webkit-scrollbar-thumb {
  background: var(--border-strong, #9ca3af);
  border-radius: var(--radius-full);
  transition: background var(--transition-fast);
}

::-webkit-scrollbar-thumb:hover {
  background: var(--text-muted);
}

/* ===== АНИМАЦИИ ===== */
@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes slideInRight {
  from {
    opacity: 0;
    transform: translateX(20px);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}

@keyframes modalSlideIn {
  from {
    opacity: 0;
    transform: translateY(-20px) scale(0.95);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

@keyframes float {
  0%,
  100% {
    transform: translate(0, 0);
  }
  50% {
    transform: translate(10px, 10px);
  }
}

@keyframes spin {
  to {
    transform: rotate(360deg);
  }
}

@keyframes shimmer {
  0% {
    transform: translateX(-100%);
  }
  100% {
    transform: translateX(200%);
  }
}

/* ===== ИНТРО-ПРИВЕТСТВИЕ (лого, 1 раз для неавторизованных) — выделенные стили проекта ===== */
.intro-overlay {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  pointer-events: none;
  opacity: 0;
  visibility: hidden;
  transition: opacity var(--transition-slow), visibility var(--transition-slow);
}

.intro-overlay.intro-overlay--visible {
  pointer-events: auto;
  opacity: 1;
  visibility: visible;
}

.intro-overlay.intro-overlay--out {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition-duration: 0.5s;
}

/* Светлый туманный фон с акцентом primary (выделенный стиль) */
.intro-backdrop {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg,
    rgba(var(--primary-rgb), 0.04) 0%,
    rgba(255, 255, 255, 0.98) 18%,
    rgba(248, 250, 252, 0.99) 50%,
    rgba(255, 255, 255, 0.98) 82%,
    rgba(var(--primary-rgb), 0.05) 100%);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
}

/* Контейнер лого (без рамки) */
.intro-content {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  padding: 2rem;
  box-sizing: border-box;
}

.intro-logo {
  position: relative;
  z-index: 1;
  width: 80vw;
  max-width: 80%;
  height: auto;
  max-height: 45vh;
  object-fit: contain;
  object-position: center;
  animation: introLogoIn 1.2s ease-out forwards;
  opacity: 0;
  filter: drop-shadow(0 4px 12px rgba(var(--primary-rgb), 0.15));
}

@keyframes introLogoIn {
  from {
    opacity: 0;
    transform: scale(0.92);
  }
  to {
    opacity: 1;
    transform: scale(1);
  }
}

@media (max-width: 768px) {
  .intro-logo {
    width: 88vw;
    max-width: 88%;
    max-height: 40vh;
  }
  .intro-content {
    padding: 1.25rem;
  }
}

.fade-in-up {
  animation: fadeInUp 0.6s ease-out;
}
.slide-in-right {
  animation: slideInRight 0.6s ease-out;
}

/* ===== СОСТОЯНИЕ ЗАГРУЗКИ ===== */
.loading {
  position: relative;
  overflow: hidden;
}

.loading::after {
  content: "";
  position: absolute;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(
    90deg,
    transparent,
    rgba(255, 255, 255, 0.4),
    transparent
  );
  animation: shimmer 1.5s infinite;
}

/* ===== АВАТАР ПОЛЬЗОВАТЕЛЯ ===== */
.user-avatar-with-badge {
  position: relative;
  display: inline-block;
  flex-shrink: 0;
}

.user-avatar-wrapper {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  overflow: hidden;
  background: var(--gradient-primary);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transition: transform var(--transition-fast);
}

/* Бейдж рейтинга на аватаре: золотой ТОП-10, серебряный ТОП-100, синий ТОП-500 (кубок + цифра) */
.avatar-rank-badge {
  position: absolute;
  top: -5px;
  right: -5px;
  min-width: 22px;
  height: 22px;
  padding: 0 3px;
  border-radius: 50%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  font-size: 8px;
  font-weight: 700;
  line-height: 1;
  color: #fff;
  box-shadow: 0 1px 4px rgba(0, 0, 0, 0.35);
  pointer-events: none;
}

.avatar-rank-badge i {
  font-size: 10px;
  line-height: 1;
  margin-bottom: -1px;
}

.avatar-rank-badge__num {
  font-family: var(--font-secondary);
  font-size: 7px;
  letter-spacing: -0.5px;
}

.avatar-rank-badge--gold {
  background: linear-gradient(135deg, #d4af37 0%, #f4e4a6 50%, #b8941f 100%);
  color: #1a1505;
}

.avatar-rank-badge--silver {
  background: linear-gradient(135deg, #c0c0c0 0%, #e8e8e8 50%, #909090 100%);
  color: #2a2a2a;
}

.avatar-rank-badge--blue {
  background: linear-gradient(135deg, #2a4b7c 0%, #3d6ba3 50%, #1a2f4a 100%);
  color: #fff;
}

/* В карточках товаров аватар меньше — бейдж компактнее */
.item-card .user-avatar-with-badge .avatar-rank-badge {
  min-width: 18px;
  height: 18px;
  top: -4px;
  right: -4px;
  padding: 0 2px;
  font-size: 6px;
}
.item-card .user-avatar-with-badge .avatar-rank-badge i {
  font-size: 8px;
}
.item-card .user-avatar-with-badge .avatar-rank-badge__num {
  font-size: 6px;
}

.user-avatar-header {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.avatar-placeholder {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--gradient-primary);
  color: var(--text-white);
  font-weight: 600;
  font-size: var(--text-sm);
}

.user-menu:hover .user-avatar-wrapper {
  transform: scale(1.1);
  box-shadow: var(--shadow-colored);
}

/* Модальное окно «Сообщить об ошибке» — одна кнопка в техподдержку */
.bug-report-modal {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: var(--z-modal, 1050);
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 1rem;
  visibility: hidden;
  opacity: 0;
  transition: visibility 0.2s, opacity 0.2s ease-out;
}
.bug-report-modal.bug-report-modal--open {
  visibility: visible;
  opacity: 1;
}
.bug-report-modal__backdrop {
  position: absolute;
  inset: 0;
  background-color: rgba(var(--primary-rgb, 42, 75, 124), 0.35);
  backdrop-filter: blur(4px);
}
.bug-report-modal__box {
  position: relative;
  background: var(--bg-card);
  border-radius: var(--radius-xl);
  width: 100%;
  max-width: 440px;
  box-shadow: var(--shadow-2xl);
  border: 1px solid var(--border-color);
  overflow: hidden;
  animation: modalSlideIn 0.25s ease-out;
}
.bug-report-modal__header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1rem 1.25rem;
  border-bottom: 1px solid var(--border-color);
  background: var(--bg-secondary);
}
.bug-report-modal__title {
  margin: 0;
  font-size: var(--text-lg);
  font-weight: 600;
  color: var(--text-primary);
  font-family: var(--font-accent);
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.bug-report-modal__title i {
  color: var(--color-danger, #dc2626);
}
.bug-report-modal__close {
  background: transparent;
  border: 1px solid transparent;
  font-size: 1.5rem;
  line-height: 1;
  cursor: pointer;
  color: var(--text-secondary);
  padding: 0;
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius-md);
  transition: all var(--transition-fast);
}
.bug-report-modal__close:hover {
  background: var(--secondary-light);
  color: var(--text-primary);
}
.bug-report-modal__lead {
  margin: 0;
  padding: 1rem 1.25rem;
  font-size: var(--text-sm);
  color: var(--text-secondary);
  line-height: var(--leading-relaxed);
  border-bottom: 1px solid var(--border-color);
}
.bug-report-form {
  padding: 1.25rem;
}
.bug-report-form__group {
  margin-bottom: 1rem;
}
.bug-report-form__label {
  display: block;
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--text-primary);
  margin-bottom: 0.375rem;
}
.bug-report-form__textarea {
  width: 100%;
  padding: 0.75rem 1rem;
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  font-family: var(--font-secondary);
  font-size: var(--text-sm);
  resize: vertical;
  min-height: 80px;
}
.bug-report-form__textarea:focus {
  outline: none;
  border-color: var(--primary-color);
  box-shadow: 0 0 0 3px rgba(var(--primary-rgb, 42, 75, 124), 0.15);
}
.bug-report-status {
  font-size: var(--text-sm);
  margin-bottom: 1rem;
  min-height: 1.25rem;
}
.bug-report-status--success {
  color: var(--color-success);
}
.bug-report-status--error {
  color: var(--color-danger);
}
.bug-report-form__actions {
  display: flex;
  gap: 0.75rem;
  justify-content: flex-end;
  flex-wrap: wrap;
}

/* Модальное окно для шаринга — в стиле проекта */
.share-modal {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(var(--primary-rgb, 42, 75, 124), 0.35);
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: var(--z-modal, 1050);
  padding: 1rem;
  backdrop-filter: blur(4px);
  animation: shareModalOverlayIn 0.25s ease-out;
}

@keyframes shareModalOverlayIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}

.share-modal-content {
  background: var(--bg-card);
  border-radius: var(--radius-xl);
  width: 100%;
  max-width: 420px;
  box-shadow: var(--shadow-2xl);
  border: 1px solid var(--border-color);
  overflow: hidden;
  animation: modalSlideIn 0.3s ease-out;
}

.share-modal-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1.25rem 1.5rem;
  border-bottom: 1px solid var(--border-color);
  background: var(--bg-secondary);
}

.share-modal-header h3 {
  margin: 0;
  font-size: var(--text-xl);
  font-weight: 600;
  color: var(--text-primary);
  font-family: var(--font-accent);
  letter-spacing: -0.01em;
}

.share-modal-close {
  background: transparent;
  border: 1px solid transparent;
  font-size: 1.5rem;
  line-height: 1;
  cursor: pointer;
  color: var(--text-secondary);
  padding: 0;
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius-md);
  transition: all var(--transition-fast);
}

.share-modal-close:hover {
  background: var(--secondary-light);
  color: var(--text-primary);
  border-color: var(--border-color);
}

.share-options {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1rem;
  padding: 1.5rem;
}

.share-option {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 1.25rem 0.75rem;
  background: var(--bg-primary);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-lg);
  cursor: pointer;
  transition: all var(--transition-fast);
}

.share-option:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
  border-color: var(--primary-color);
  background: linear-gradient(
    135deg,
    rgba(var(--primary-rgb, 42, 75, 124), 0.04) 0%,
    rgba(var(--primary-rgb, 42, 75, 124), 0.02) 100%
  );
}

.share-option i {
  font-size: 1.5rem;
  margin-bottom: 0.5rem;
}

.share-option span {
  font-size: var(--text-xs);
  font-weight: 500;
  color: var(--text-primary);
}

/* Цвета иконок соцсетей */
.share-option:nth-child(1) i {
  color: #25d366;
} /* WhatsApp */
.share-option:nth-child(2) i {
  color: #ea4335;
} /* Email */
.share-option:nth-child(3) i {
  color: #0088cc;
} /* Telegram */
.share-option:nth-child(4) i {
  color: var(--text-muted);
} /* Copy */
.share-option:nth-child(5) i {
  color: #4c75a3;
} /* VK */

/* Адаптивность модального окна шаринга */
@media (max-width: 480px) {
  .share-options {
    grid-template-columns: repeat(2, 1fr);
    padding: 1rem;
  }
  .share-modal-header {
    padding: 1rem 1.25rem;
  }
}

/* ===== КАЛЕНДАРЬ ===== */
.calendar-view-mode .fc-daygrid-day.fc-day-other {
  display: none !important;
}

/* ===== АДАПТИВНОСТЬ ===== */
@media (max-width: 1200px) {
  .items-grid {
    grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
  }
}

@media (max-width: 992px) {
  :root {
    --container-padding: 1rem;
  }

  h1 {
    font-size: var(--text-4xl);
  }
  h2 {
    font-size: var(--text-3xl);
  }
  h3 {
    font-size: var(--text-2xl);
  }

  .items-grid {
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: 1rem;
  }

  .gallery {
    grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
  }
}

@media (max-width: 768px) {
  html {
    font-size: 14px;
  }

  .container {
    padding: 0 1rem;
  }

  .items-grid {
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  }

  .item-image {
    height: 160px;
  }

  .profile-avatar {
    width: 60px;
    height: 60px;
  }

  .modal-content {
    padding: 1.5rem;
    margin: 0.5rem;
  }

  .user-name {
    display: none;
  }

  .nav-link {
    padding: 0.75rem 1rem;
    font-size: var(--text-sm);
  }

  .btn-lg {
    padding: 0.875rem 1.5rem;
  }
}

@media (max-width: 576px) {
  .items-grid {
    grid-template-columns: 1fr;
    gap: 1rem;
  }

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

  .gallery-image {
    height: 120px;
  }

  .item-header {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.5rem;
  }

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

  .search-box {
    min-width: 100%;
  }

  .filter-buttons {
    justify-content: flex-start;
    overflow-x: auto;
    padding-bottom: 0.5rem;
  }

  .profile-header {
    padding: 1.5rem;
  }

  .user-avatar-wrapper {
    width: 32px;
    height: 32px;
  }

  .avatar-rank-badge {
    min-width: 18px;
    height: 18px;
    top: -3px;
    right: -3px;
    font-size: 7px;
  }

  .avatar-rank-badge i {
    font-size: 8px;
  }

  .avatar-rank-badge__num {
    font-size: 6px;
  }

  .avatar-placeholder {
    font-size: var(--text-xs);
  }

  .table {
    display: block;
    overflow-x: auto;
  }

  .btn:not(.btn-sm):not(.btn-lg) {
    padding: 0.625rem 1.25rem;
    font-size: var(--text-xs);
  }
}

@media (max-width: 400px) {
  .gallery {
    grid-template-columns: 1fr;
  }

  .gallery-image {
    height: 150px;
  }

  .modal-content {
    padding: 1rem;
  }
}

/* ===== ТЕМНАЯ ТЕМА ===== */
@media (prefers-color-scheme: dark) {
  :root {
    --text-primary: #f3f4f6;
    --text-secondary: #d1d5db;
    --text-muted: #9ca3af;
    --bg-primary: #111827;
    --bg-secondary: #1f2937;
    --bg-tertiary: #374151;
    --bg-card: #1f2937;
    --border-color: #4b5563;
  }

  .form-control {
    background-color: var(--bg-tertiary);
    color: var(--text-primary);
  }

  .item-card {
    background: var(--bg-card);
    border-color: var(--border-color);
  }

  .table th {
    background: var(--bg-tertiary);
    color: var(--text-primary);
  }

  .table td {
    border-color: var(--border-color);
  }
}

/* ===== PRINT STYLES ===== */
@media print {
  .nav-tabs,
  .items-filter,
  .btn,
  .share-modal-overlay,
  .modal-overlay {
    display: none !important;
  }

  body {
    font-size: 12pt;
    background: white;
    color: black;
  }

  .container {
    max-width: 100%;
    padding: 0;
  }

  a {
    color: black;
    text-decoration: underline;
  }
}

/* ✅ КОНТЕЙНЕР ДЛЯ УВЕДОМЛЕНИЙ */
#notifications-container {
  position: fixed;
  top: 20px;
  right: 20px;
  left: 20px;
  z-index: 99999;
  pointer-events: none;
  display: flex;
  flex-direction: column;
  gap: 10px;
  max-width: 500px;
  margin-left: auto;
  margin-right: auto;
}

/* ✅ СТИЛЬ УВЕДОМЛЕНИЯ */
.notification {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 16px 20px;
  border-radius: 8px;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
  font-weight: 500;
  font-size: 14px;
  line-height: 1.5;
  animation: slideInRight 0.3s ease-out;
  pointer-events: auto;
  word-break: break-word;
  position: relative;
}

.notification i {
  font-size: 18px;
  flex-shrink: 0;
}

.notification span {
  flex: 1;
}

.notification-close {
  background: none;
  border: none;
  font-size: 24px;
  cursor: pointer;
  padding: 0;
  margin: 0;
  margin-left: 10px;
  flex-shrink: 0;
  opacity: 0.7;
  transition: opacity 0.2s;
  line-height: 1;
}

.notification-close:hover {
  opacity: 1;
}

/* ✅ ТИПЫ УВЕДОМЛЕНИЙ */
.notification-success {
  background: #d4edda;
  color: #155724;
  border: 1px solid #c3e6cb;
}

.notification-success .notification-close {
  color: #155724;
}

.notification-error {
  background: #f8d7da;
  color: #721c24;
  border: 1px solid #f5c6cb;
}

.notification-error .notification-close {
  color: #721c24;
}

.notification-info {
  background: #d1ecf1;
  color: #0c5460;
  border: 1px solid #bee5eb;
}

.notification-info .notification-close {
  color: #0c5460;
}

/* ✅ АНИМАЦИИ */
@keyframes slideInRight {
  from {
    transform: translateX(100%);
    opacity: 0;
  }
  to {
    transform: translateX(0);
    opacity: 1;
  }
}

@keyframes slideOutRight {
  from {
    transform: translateX(0);
    opacity: 1;
  }
  to {
    transform: translateX(100%);
    opacity: 0;
  }
}

/* ✅ АДАПТИВНОСТЬ ДЛЯ ПЛАНШЕТОВ */
@media (max-width: 768px) {
  #notifications-container {
    top: 15px;
    right: 15px;
    left: 15px;
    max-width: none;
  }

  .notification {
    padding: 14px 16px;
    font-size: 13px;
  }

  .notification i {
    font-size: 16px;
  }
}

/* ✅ АДАПТИВНОСТЬ ДЛЯ МОБИЛЬНЫХ */
@media (max-width: 480px) {
  #notifications-container {
    top: 10px;
    right: 10px;
    left: 10px;
    gap: 8px;
  }

  .notification {
    padding: 12px 14px;
    font-size: 12px;
    border-radius: 6px;
  }

  .notification i {
    font-size: 14px;
  }

  .notification-close {
    font-size: 20px;
    margin-left: 8px;
  }
}

/* ===== COLLAPSIBLE SEARCH (иконка → выезжающее поле) ===== */
.collapsible-search {
  display: inline-flex;
  align-items: center;
  gap: 0;
  direction: ltr;
}
.collapsible-search__trigger {
  flex-shrink: 0;
  width: 44px;
  height: 44px;
  min-width: 44px;
  min-height: 44px;
  padding: 0;
  border: none;
  border-radius: var(--radius-lg, 10px);
  background: var(--primary-color, #2a4b7c);
  color: #fff;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.2s, transform 0.15s;
}
.collapsible-search__trigger:hover {
  background: var(--primary-hover, #1f3a5c);
}
.collapsible-search__trigger:focus {
  outline: 2px solid var(--primary-color);
  outline-offset: 2px;
}
.collapsible-search__trigger i {
  font-size: 1.1rem;
}
.collapsible-search__wrap {
  overflow: hidden;
  width: 0;
  max-width: 0;
  opacity: 0;
  transition: width 0.3s ease, max-width 0.3s ease, opacity 0.2s ease, margin-left 0.3s ease;
}
.collapsible-search--expanded .collapsible-search__wrap {
  width: 220px;
  max-width: min(220px, 100vw - 120px);
  opacity: 1;
  margin-left: 0.5rem;
}
.collapsible-search__input {
  width: 100%;
  min-width: 180px;
  height: 44px;
  padding: 0.5rem 1rem;
  border: 1px solid var(--secondary-dark, #c0c0c0);
  border-radius: var(--radius-lg, 10px);
  font-size: 0.95rem;
}
.collapsible-search__input:focus {
  outline: none;
  border-color: var(--primary-color);
  box-shadow: 0 0 0 2px rgba(42, 75, 124, 0.2);
}
@media (max-width: 480px) {
  .collapsible-search--expanded .collapsible-search__wrap {
    width: 180px;
    max-width: calc(100vw - 100px);
  }
}

/* ===== COLLAPSIBLE STATUS (иконка → выезжающие варианты статуса) ===== */
.collapsible-status {
  display: inline-flex;
  align-items: center;
  gap: 0;
  direction: ltr;
  min-width: 0;
  box-sizing: border-box;
}
.collapsible-status__trigger {
  flex-shrink: 0;
  width: 44px;
  height: 44px;
  min-width: 44px;
  min-height: 44px;
  padding: 0;
  border: none;
  border-radius: var(--radius-lg, 10px);
  background: var(--primary-color, #2a4b7c);
  color: #fff;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.2s, transform 0.15s;
}
.collapsible-status__trigger:hover {
  background: var(--primary-hover, #1f3a5c);
}
.collapsible-status__trigger:focus {
  outline: 2px solid var(--primary-color);
  outline-offset: 2px;
}
.collapsible-status__trigger i {
  font-size: 1.1rem;
}
.collapsible-status__wrap {
  overflow: hidden;
  width: 0;
  max-width: 0;
  opacity: 0;
  transition: width 0.3s ease, max-width 0.3s ease, opacity 0.2s ease, margin-left 0.3s ease;
}
.collapsible-status--expanded .collapsible-status__wrap {
  /* Достаточно ширины под все кнопки; не обрезаем контент */
  width: min(56rem, calc(100vw - 5.5rem));
  max-width: calc(100vw - 5.5rem);
  opacity: 1;
  margin-left: 0.5rem;
  overflow-x: auto;
  overflow-y: visible;
  -webkit-overflow-scrolling: touch;
  box-sizing: border-box;
}
.collapsible-status__options {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  padding: 0.25rem 0;
  min-width: 0;
}
.collapsible-status__options .filter-btn {
  padding: 0.5rem 0.75rem;
  font-size: 0.9rem;
  flex-shrink: 0;
}
/* В колонке фильтров (как на /items/my): триггер + поле не дают wrap 100% ширины строки */
@media (max-width: 768px) {
  .items-filter .collapsible-status {
    display: flex;
    width: 100%;
    max-width: 100%;
    min-width: 0;
  }
  .collapsible-status--expanded .collapsible-status__wrap {
    flex: 1 1 0%;
    width: auto;
    min-width: 0;
    max-width: none;
  }
}
@media (max-width: 480px) {
  .collapsible-status--expanded .collapsible-status__wrap {
    max-width: 100%;
  }
}

/* ===== БЛОК ДОСТАВНОСТИ И УВЕДОМЛЕНИЙ (item view) — привязка к профилю проекта ===== */
.availability-section {
  margin-top: 1rem;
}
.availability-section h3 {
  font-family: var(--font-accent);
  font-weight: 600;
  color: var(--text-primary);
  margin-bottom: 1rem;
}

.owner-availability-notice {
  margin-bottom: 1.25rem;
}
.notice-box {
  background: var(--color-info-bg);
  border-left: 4px solid var(--primary-color);
  padding: 1rem 1.25rem;
  border-radius: var(--radius-md);
  margin-bottom: 1.25rem;
  box-shadow: var(--shadow-sm);
}
.notice-box__inner {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
}
.notice-box__icon {
  color: var(--primary-color);
  font-size: 1.125rem;
  margin-top: 0.125rem;
  flex-shrink: 0;
}
.notice-box__title {
  margin: 0 0 0.5rem 0;
  color: var(--primary-dark);
  font-weight: 600;
  font-size: var(--text-base);
}
.notice-box__text {
  margin: 0 0 0.75rem 0;
  color: var(--text-secondary);
  font-size: var(--text-sm);
  line-height: var(--leading-relaxed);
}
.notice-box .btn-primary {
  display: inline-block;
  padding: 0.5rem 1rem;
  font-size: var(--text-sm);
  text-decoration: none;
  border-radius: var(--radius-md);
}

.calendar-legend {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  margin-bottom: 1.25rem;
  padding: 0.75rem 0;
}
.legend-item {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: var(--text-sm);
  color: var(--text-secondary);
}
.legend-color {
  width: 1rem;
  height: 1rem;
  border-radius: var(--radius-sm);
  flex-shrink: 0;
}
.legend-available {
  background: var(--color-success-bg);
  border: 1px solid var(--color-success);
}
.legend-booked {
  background: var(--color-danger-bg);
  border: 1px solid var(--color-danger);
}
.legend-past {
  background: var(--bg-tertiary);
  border: 1px solid var(--secondary-dark);
}
.legend-limited {
  background: var(--color-warning-bg);
  border: 1px solid var(--color-warning);
}

/* Доп. опции (карточки) — строка с ценой и типом */
.condition-card .option-price-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 0.625rem;
  padding-top: 0.625rem;
  border-top: 1px solid var(--border-color);
}
.condition-card .option-price {
  font-weight: 600;
  color: var(--primary-color);
}
.condition-card .option-badge {
  font-size: var(--text-xs);
  color: var(--text-muted);
  background: var(--bg-secondary);
  padding: 0.25rem 0.5rem;
  border-radius: var(--radius-sm);
}
.condition-card .option-description {
  font-size: var(--text-sm);
  color: var(--text-secondary);
  margin-bottom: 0.5rem;
}
.conditions-block--options {
  margin-top: 1.875rem;
}

/* Звёзды в доп. опциях — золотой круг и золотая иконка */
.conditions-block--options .condition-icon {
  background: linear-gradient(135deg, #d4af37 0%, #b8962e 100%);
  color: #fff;
  box-shadow: 0 4px 12px rgba(201, 162, 39, 0.35);
}
.conditions-block--options .condition-icon i.fa-star {
  color: #f5d654;
}
.conditions-block--options .condition-card:hover .condition-icon {
  box-shadow: 0 6px 16px rgba(201, 162, 39, 0.45);
}

/* Условия доставки в форме аренды */
.delivery-conditions-box {
  padding: 0.75rem 1rem;
  background: var(--color-info-bg);
  border-radius: var(--radius-md);
  border-left: 3px solid var(--primary-color);
  margin-bottom: 1rem;
}
.delivery-conditions-box .delivery-conditions-title {
  margin: 0 0 0.5rem 0;
  font-weight: 600;
  color: var(--text-primary);
}
.delivery-conditions-box p {
  margin: 0;
  line-height: var(--leading-relaxed);
  color: var(--text-secondary);
  font-size: var(--text-sm);
}
.delivery-conditions-box .delivery-radius {
  margin: 0.5rem 0 0 0;
  color: var(--text-muted);
  font-size: var(--text-xs);
}
.delivery-block {
  margin-top: 1rem;
}
.form-group small.text-muted,
.rental-summary .text-muted {
  color: var(--text-muted);
  display: block;
  margin-top: 0.25rem;
  font-size: var(--text-xs);
}


/* Анимационное лого */

/***************************************************
 * Generated by SVG Artista on 2/15/2026, 1:56:15 PM
 * MIT license (https://opensource.org/licenses/MIT)
 * W. https://svgartista.net
 **************************************************/

 svg .svg-elem-1 {
  fill: transparent;
  -webkit-transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 0.8s;
          transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 0.8s;
}

svg.active .svg-elem-1 {
  fill: rgb(0, 0, 0);
}

svg .svg-elem-2 {
  fill: transparent;
  -webkit-transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 0.9s;
          transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 0.9s;
}

svg.active .svg-elem-2 {
  fill: rgb(0, 0, 0);
}

svg .svg-elem-3 {
  fill: transparent;
  -webkit-transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 1s;
          transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 1s;
}

svg.active .svg-elem-3 {
  fill: rgb(0, 0, 0);
}

svg .svg-elem-4 {
  fill: transparent;
  -webkit-transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 1.1s;
          transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 1.1s;
}

svg.active .svg-elem-4 {
  fill: rgb(0, 0, 0);
}

svg .svg-elem-5 {
  fill: transparent;
  -webkit-transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 1.2000000000000002s;
          transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 1.2000000000000002s;
}

svg.active .svg-elem-5 {
  fill: rgb(0, 0, 0);
}

svg .svg-elem-6 {
  fill: transparent;
  -webkit-transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 1.3s;
          transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 1.3s;
}

svg.active .svg-elem-6 {
  fill: rgb(0, 0, 0);
}

svg .svg-elem-7 {
  fill: transparent;
  -webkit-transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 1.4000000000000001s;
          transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 1.4000000000000001s;
}

svg.active .svg-elem-7 {
  fill: rgb(74, 107, 163);
}

svg .svg-elem-8 {
  fill: transparent;
  -webkit-transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 1.5s;
          transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 1.5s;
}

svg.active .svg-elem-8 {
  fill: rgb(74, 107, 163);
}

svg .svg-elem-9 {
  fill: transparent;
  -webkit-transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 1.6s;
          transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 1.6s;
}

svg.active .svg-elem-9 {
  fill: rgb(74, 107, 163);
}

svg .svg-elem-10 {
  fill: transparent;
  -webkit-transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 1.7000000000000002s;
          transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 1.7000000000000002s;
}

svg.active .svg-elem-10 {
  fill: rgb(74, 107, 163);
}

svg .svg-elem-11 {
  fill: transparent;
  -webkit-transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 1.8s;
          transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 1.8s;
}

svg.active .svg-elem-11 {
  fill: rgb(74, 107, 163);
}

svg .svg-elem-12 {
  fill: transparent;
  -webkit-transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 1.9000000000000001s;
          transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 1.9000000000000001s;
}

svg.active .svg-elem-12 {
  fill: rgb(74, 107, 163);
}

svg .svg-elem-13 {
  fill: transparent;
  -webkit-transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 2s;
          transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 2s;
}

svg.active .svg-elem-13 {
  fill: rgb(74, 107, 163);
}

svg .svg-elem-14 {
  fill: transparent;
  -webkit-transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 2.1s;
          transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 2.1s;
}

svg.active .svg-elem-14 {
  fill: rgb(74, 107, 163);
}

svg .svg-elem-15 {
  fill: transparent;
  -webkit-transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 2.2s;
          transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 2.2s;
}

svg.active .svg-elem-15 {
  fill: rgb(74, 107, 163);
}

svg .svg-elem-16 {
  fill: transparent;
  -webkit-transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 2.3s;
          transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 2.3s;
}

svg.active .svg-elem-16 {
  fill: rgb(74, 107, 163);
}

svg .svg-elem-17 {
  fill: transparent;
  -webkit-transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 2.4000000000000004s;
          transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 2.4000000000000004s;
}

svg.active .svg-elem-17 {
  fill: rgb(212, 175, 55);
}

svg .svg-elem-18 {
  fill: transparent;
  -webkit-transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 2.5s;
          transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 2.5s;
}

svg.active .svg-elem-18 {
  fill: rgb(212, 175, 55);
}

svg .svg-elem-19 {
  fill: transparent;
  -webkit-transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 2.6s;
          transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 2.6s;
}

svg.active .svg-elem-19 {
  fill: rgb(212, 175, 55);
}

svg .svg-elem-20 {
  fill: transparent;
  -webkit-transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 2.7s;
          transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 2.7s;
}

svg.active .svg-elem-20 {
  fill: rgb(212, 175, 55);
}

svg .svg-elem-21 {
  fill: transparent;
  -webkit-transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 2.8s;
          transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 2.8s;
}

svg.active .svg-elem-21 {
  fill: rgb(212, 175, 55);
}

svg .svg-elem-22 {
  fill: transparent;
  -webkit-transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 2.9000000000000004s;
          transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 2.9000000000000004s;
}

svg.active .svg-elem-22 {
  fill: rgb(212, 175, 55);
}

svg .svg-elem-23 {
  fill: transparent;
  -webkit-transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 3s;
          transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 3s;
}

svg.active .svg-elem-23 {
  fill: rgb(212, 175, 55);
}

svg .svg-elem-24 {
  fill: transparent;
  -webkit-transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 3.1000000000000005s;
          transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 3.1000000000000005s;
}

svg.active .svg-elem-24 {
  fill: rgb(212, 175, 55);
}

svg .svg-elem-25 {
  fill: transparent;
  -webkit-transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 3.2s;
          transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 3.2s;
}

svg.active .svg-elem-25 {
  fill: rgb(212, 175, 55);
}

svg .svg-elem-26 {
  fill: transparent;
  -webkit-transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 3.3s;
          transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 3.3s;
}

svg.active .svg-elem-26 {
  fill: rgb(212, 175, 55);
}

svg .svg-elem-27 {
  fill: transparent;
  -webkit-transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 3.4000000000000004s;
          transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 3.4000000000000004s;
}

svg.active .svg-elem-27 {
  fill: rgb(212, 175, 55);
}

svg .svg-elem-28 {
  fill: transparent;
  -webkit-transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 3.5s;
          transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 3.5s;
}

svg.active .svg-elem-28 {
  fill: rgb(212, 175, 55);
}

svg .svg-elem-29 {
  fill: transparent;
  -webkit-transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 3.6000000000000005s;
          transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 3.6000000000000005s;
}

svg.active .svg-elem-29 {
  fill: rgb(212, 175, 55);
}

svg .svg-elem-30 {
  fill: transparent;
  -webkit-transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 3.7s;
          transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 3.7s;
}

svg.active .svg-elem-30 {
  fill: rgb(212, 175, 55);
}

svg .svg-elem-31 {
  fill: transparent;
  -webkit-transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 3.8s;
          transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 3.8s;
}

svg.active .svg-elem-31 {
  fill: rgb(42, 75, 124);
}

svg .svg-elem-32 {
  fill: transparent;
  -webkit-transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 3.9000000000000004s;
          transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 3.9000000000000004s;
}

svg.active .svg-elem-32 {
  fill: rgb(212, 175, 55);
}

svg .svg-elem-33 {
  fill: transparent;
  -webkit-transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 4s;
          transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 4s;
}

svg.active .svg-elem-33 {
  fill: rgb(74, 107, 163);
}

/* ===== Кнопка «В избранное» — сердце (Uiverse.io / barisdogansutcu) ===== */
:root {
  --favorite-heart-color: hsl(347, 81%, 61%);
  --favorite-heart-glow: hsl(347, 99%, 72%);
  --favorite-heart-border: #9ca3af;
}

.favorite-heart-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0;
  padding: 0;
  border: none;
  background: transparent;
  cursor: pointer;
  color: inherit;
}

.favorite-btn-wrapper .favorite-heart-btn {
  width: 2.5rem;
  height: 2.5rem;
  border-radius: var(--radius-full);
}

/* Пустые <i> не участвуют в форме сердца — скрываем из потока */
.favorite-heart-btn .love-heart .left,
.favorite-heart-btn .love-heart .right {
  position: absolute;
  width: 0;
  height: 0;
  overflow: hidden;
  opacity: 0;
  pointer-events: none;
}

.favorite-heart-btn .love-heart,
.favorite-heart-btn .love-heart::after {
  box-sizing: border-box;
  border: 1px solid;
  border-color: var(--border-color, var(--favorite-heart-border));
  border-top-left-radius: 100px;
  border-top-right-radius: 100px;
  width: 10px;
  height: 8px;
  border-bottom: 0;
}

.favorite-heart-btn .love-heart {
  position: relative;
  overflow: visible;
  /* Центр вращения — низ центра (визуальный центр формы сердца) */
  transform-origin: 50% 100%;
  transform: rotate(-45deg) scale(1.2) translate(1px, -2px);
  display: block;
  cursor: pointer;
  flex-shrink: 0;
}

.favorite-heart-btn .love-heart::before {
  display: none;
}

.favorite-heart-btn .love-heart::after,
.favorite-heart-btn .love-heart .bottom {
  content: "";
  display: block;
  box-sizing: border-box;
  position: absolute;
  border-color: var(--border-color, var(--favorite-heart-border));
}

.favorite-heart-btn .love-heart::after {
  right: -9px;
  transform: rotate(90deg);
  top: 7px;
  width: 10px;
  height: 8px;
  border: 1px solid;
  border-bottom: 0;
  border-top-left-radius: 100px;
  border-top-right-radius: 100px;
}

.favorite-heart-btn .love-heart .bottom {
  width: 11px;
  height: 11px;
  border-left: 1px solid;
  border-bottom: 1px solid;
  left: -1px;
  top: 5px;
  border-radius: 0 0 0 5px;
}

.favorite-heart-btn .round {
  position: absolute;
  z-index: 1;
  width: 8px;
  height: 8px;
  background: var(--bg-primary, #fff);
  box-shadow: 0 0 4px rgba(0, 0, 0, 0.24);
  border-radius: 100%;
  left: 0;
  bottom: -1px;
  transition: all 0.5s ease;
}

.favorite-heart-btn:not(.is-favorite) .round {
  animation: favorite-check-animation2 0.5s forwards;
}

.favorite-heart-btn.is-favorite .round {
  transform: translate(7px, 7px);
  animation: favorite-check-animation 0.5s forwards;
  background-color: var(--bg-primary, #fff);
}

.favorite-heart-btn.is-favorite .love-heart,
.favorite-heart-btn.is-favorite .love-heart::after,
.favorite-heart-btn.is-favorite .love-heart .bottom {
  border-color: var(--favorite-heart-color, var(--color-danger));
  box-shadow: inset 6px -5px 0 2px var(--favorite-heart-glow);
}

@keyframes favorite-check-animation {
  0% { transform: translate(0, 0); }
  50% { transform: translate(0, 7px); }
  100% { transform: translate(7px, 7px); }
}

@keyframes favorite-check-animation2 {
  0% { transform: translate(7px, 7px); }
  50% { transform: translate(0, 7px); }
  100% { transform: translate(0, 0); }
}

.favorite-heart-btn--full .love-heart {
  margin: 0;
}
