/* Базовые настройки шрифтов и контейнера */
:root {
   --bg-dark: #0f0f1a;
   --card-bg: #161625;
   --accent-gold: #f39c12;
   --accent-blue: #3498db;
   --accent-purple: #9b59b6;
   --accent-red: #e74c3c;
   --accent-green: #2ecc71;
   --text-main: #cbd5e0;
}

body {
   font-size: 1.15rem;
   /* Увеличиваем общий размер текста */
   line-height: 1.7;
}

.fragment-container {
   width: 95%;
   /* Поля по 2.5% с каждой стороны */
   max-width: 1600px;
   /* Ограничиваем на очень широких 4К мониторах для читаемости */
   margin: 0 auto;
   background: var(--card-bg);
   border-radius: 20px;
   overflow: hidden;
   box-shadow: 0 25px 50px rgba(0, 0, 0, 0.6);
}

/* 1. ОБЛОЖКА БЕЗ ОБРЕЗКИ */
.fragment-cover {
   width: 100%;
   height: auto;
   background: #000;
   line-height: 0;
   /* Убирает лишние отступы снизу */
}

.fragment-cover img {
   width: 100%;
   height: auto;
   /* Не более 80% высоты экрана, чтобы не скроллить вечность */
   object-fit: contain;
   /* Показывает картинку целиком */
   display: block;
}

/* 2. ТИП СУЩЕСТВА (Крупно и ярко) */
.race-classification {
   margin: 20px 0 40px 0;
   padding: 25px;
   background: linear-gradient(135deg, rgba(52, 152, 219, 0.15) 0%, transparent 100%);
   border: 1px solid rgba(52, 152, 219, 0.3);
   border-left: 6px solid var(--accent-blue);
   border-radius: 8px;
}

.race-classification label {
   font-size: 0.9rem;
   color: var(--accent-blue);
   text-transform: uppercase;
   letter-spacing: 3px;
   font-weight: 800;
   display: block;
   margin-bottom: 8px;
}

.race-classification .value {
   font-size: 1.6rem;
   /* Крупный текст */
   color: #fff;
   font-weight: 700;
   text-shadow: 0 0 15px rgba(52, 152, 219, 0.4);
}

/* 3. ОБТЕКАНИЕ КАРТИНКАМИ */
/* РЕШЕНИЕ ПРОБЛЕМЫ 3 (Абзацы) */
.rich-text p {
   display: block;
   /* Возвращаем блочность для абзацев */
   margin-bottom: 1.2rem;
}

/* РЕШЕНИЕ ПРОБЛЕМЫ 4 (Обтекание без пустот) */
.rich-text img {
   height: auto !important;
}

/* Прижимаем картинки, которым в редакторе задали float */
.rich-text img[style*="float: right"] {
   float: right !important;
   margin-left: 20px !important;
   margin-bottom: 15px !important;
   max-width: 40%;
}

.rich-text img[style*="float: left"] {
   float: left !important;
   margin-right: 20px !important;
   margin-bottom: 15px !important;
   max-width: 40%;
}

/* Очистка после блоков с обтеканием */
.rich-text::after {
   content: "";
   display: table;
   clear: both;
}

/* Чтобы текст в превью редактора тоже выглядел нормально */
.rich-text-preview img {
   max-width: 100%;
   height: auto;
}

/* 4. УЛУЧШЕННЫЕ НИЖНИЕ БЛОКИ (Карточный стиль) */
.section-label {
   font-size: 1.3rem;
   color: var(--accent-gold);
   border-bottom: 1px solid rgba(243, 156, 18, 0.2);
   padding-bottom: 10px;
   margin-bottom: 25px;
   text-transform: uppercase;
   letter-spacing: 1.5px;
}

/* Общий стиль для элементов списков */
.info-item-card {
   background: rgba(255, 255, 255, 0.03);
   border: 1px solid rgba(255, 255, 255, 0.07);
   border-radius: 12px;
   padding: 25px;
   transition: all 0.3s ease;
   /* height: 100%; - удаляем */
}

/* Для всех строк с карточками (g-3, g-4 и т.д.) */
.row.g-3,
.row.g-4 {
   display: flex;
   flex-wrap: wrap;
}

.row.g-3>[class*="col-"],
.row.g-4>[class*="col-"] {
   display: flex;
   flex-direction: column;
}

.info-item-card {
   flex: 1 1 auto;
   /* растягивается по высоте колонки */
}

/* Сетка для карточек (автоматическое распределение) */
.card-grid {
   display: grid;
   grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
   gap: 1rem;
   margin-bottom: 1.5rem;
}

.card-grid .info-item-card {
   height: 100%;
   margin-bottom: 0;
   /* убираем лишние отступы, если были */
}

.info-item-card:hover {
   background: rgba(255, 255, 255, 0.05);
   transform: translateY(-5px);
}

/* Цветовые маркеры для разных типов данных */
.subrace-card {
   border-top: 4px solid var(--accent-purple);
}

.relation-card {
   border-top: 4px solid var(--accent-red);
}

.talent-card {
   border-top: 4px solid var(--accent-green);
}

.info-item-card h5 {
   font-size: 1.4rem;
   margin-bottom: 15px;
   color: #fff;
}

.info-item-card p {
   font-size: 1.1rem;
   color: var(--text-main);
   margin: 0;
}

/* Биологические параметры */
.physiology-card {
   background: rgba(255, 255, 255, 0.03);
   border: 1px solid rgba(255, 255, 255, 0.07);
   border-top: 4px solid var(--accent-blue);
   /* синяя линия, как у заголовка */
   border-radius: 12px;
   padding: 25px;
   transition: all 0.3s ease;
}

.physiology-card:hover {
   background: rgba(255, 255, 255, 0.05);
   transform: translateY(-5px);
}

.fragment-content table {
   width: 100%;
   border-collapse: collapse;
   margin: 20px 0;
   background: rgba(0, 0, 0, 0.2);
}

.fragment-content td,
.fragment-content th {
   border: 1px solid var(--border-color);
   padding: 12px;
}

/*-----------стиль таблиц в шаблоне---------------------*/
/* Общие стили для таблиц внутри контента */
.info-item-card table {
   width: 100% !important;
   border-collapse: collapse;
   margin: 1rem 0;
   background: rgba(255, 255, 255, 0.03);
   /* Легкий фон */
   border: 1px solid rgba(255, 255, 255, 0.1);
   color: #e0e0e0;
   border-radius: 8px;
   overflow: hidden;
}

.info-item-card table th,
.info-item-card table td {
   padding: 12px 15px;
   border: 1px solid rgba(255, 255, 255, 0.1);
   text-align: left;
}

/* Шапка таблицы */
.info-item-card table tr:first-child td,
.info-item-card table th {
   background: rgba(255, 255, 255, 0.07);
   color: var(--accent-gold, #ffcc33);
   /* Золотистый акцент для заголовков */
   font-weight: bold;
   text-transform: uppercase;
   font-size: 0.85rem;
   letter-spacing: 1px;
}

/* Зебра-эффект для строк */
.info-item-card table tr:nth-child(even) {
   background: rgba(255, 255, 255, 0.02);
}

/* Подсветка при наведении */
.info-item-card table tr:hover {
   background: rgba(255, 255, 255, 0.05);
   transition: background 0.3s ease;
}

/* Адаптивность для мобилок */
@media (max-width: 768px) {
   .info-item-card table {
      display: block;
      overflow-x: auto;
      white-space: nowrap;
   }

   /* Уменьшаем отступы внутри карточек */
   .info-item-card,
   .physiology-card {
      padding: 15px;
   }

   /* Чуть уменьшаем заголовки секций */
   .section-label {
      font-size: 1.1rem;
      margin-bottom: 15px;
   }

   /* В блоке физиологии, если нужны дополнительные правки */
   .physiology-card .rich-text {
      font-size: 1rem;
   }

   /* Опционально: уменьшаем шрифт в карточках */
   .info-item-card p {
      font-size: 0.95rem;
   }
}

/*-------------*/
/* Добавьте в конец файла fragments/public/assets/css/view-item.css */

/* Стили для таблиц классов */
.class-view table {
   width: 100% !important;
   border-collapse: collapse;
   margin: 1rem 0;
   background: rgba(255, 255, 255, 0.03);
   border: 1px solid rgba(255, 255, 255, 0.1);
   color: #e0e0e0;
   border-radius: 8px;
   overflow: hidden;
}

.class-view table th,
.class-view table td {
   padding: 12px 15px;
   border: 1px solid rgba(255, 255, 255, 0.1);
   text-align: left;
}

.class-view table tr:first-child td,
.class-view table th {
   background: rgba(255, 255, 255, 0.07);
   color: var(--accent-gold, #ffcc33);
   font-weight: bold;
   text-transform: uppercase;
   font-size: 0.85rem;
   letter-spacing: 1px;
}

.class-view table tr:nth-child(even) {
   background: rgba(255, 255, 255, 0.02);
}

.class-view table tr:hover {
   background: rgba(255, 255, 255, 0.05);
   transition: background 0.3s ease;
}

@media (max-width: 768px) {
   .class-view table {
      display: block;
      overflow-x: auto;
      white-space: nowrap;
   }
}

/* Специально для узких экранов (325px – 425px) */
@media (max-width: 425px) {
   .fragment-container {
      width: 100%;
      /* убираем боковые отступы, чтобы использовать всю ширину */
      border-radius: 0;
      /* опционально: убрать скругление на мобильных */
   }

   .race-classification {
      padding: 15px;
      /* уменьшаем паддинги */
   }

   .race-classification .value {
      font-size: 1.3rem;
      /* чуть меньше шрифт */
   }

   .info-item-card,
   .physiology-card {
      padding: 12px;
      /* ещё меньше внутренние отступы */
   }

   .section-label {
      font-size: 1rem;
      /* уменьшаем заголовки секций */
      margin-bottom: 12px;
   }

   /* Если используются иконки Bootstrap, уменьшаем их размер */
   .bi {
      font-size: 1rem;
   }

   /* Для очень узких экранов можно увеличить минимальную ширину колонок в grid */
   .card-grid {
      grid-template-columns: 1fr;
      /* все карточки в один столбец */
      gap: 0.75rem;
   }

   /* Текст в карточках */
   .info-item-card p,
   .physiology-card .rich-text {
      font-size: 0.9rem;
      line-height: 1.5;
   }

   /* Связанные публикации: ссылки */
   .info-item-card a {
      font-size: 0.95rem;
   }
}

@media (max-width: 375px) {

   .info-item-card,
   .physiology-card {
      padding: 10px;
   }

   .race-classification .value {
      font-size: 1.2rem;
   }
}

.info-item-card a {
   display: inline-block;
   min-height: 44px;
   /* рекомендация Apple для тач-целей */
   line-height: 1.2;
}


.text-muted {
   --bs-text-opacity: 1;
   color: rgb(255 255 255 / 75%) !important;
}