/* Общие стили */
body {
    font-family: 'Roboto', sans-serif;
    background-color: #f8f9fa;
}

/* Раскрываем всю страницу по высоте */
html, body {
  height: 100%;
  margin: 0;
}

/* Основной контейнер должен занимать доступную высоту */
.main-wrapper {
  display: flex;
  flex-direction: column;
  height: 100%;
}

body.map-page .main-wrapper {
  display:flex; flex-direction:column; height:100vh;
}
body.map-page #map {
  flex:1; height:auto;
}

/* Если вы всё ещё используете .main-content внутри, дайте ему тоже высоту 100% */
.main-content {
  flex: 1;           /* займёт всё доступное место */
  min-height: 0;     /* чтобы внутренние элементы с высотой 100% не «выскакивали» */
  display: flex;     /* если у вас ещё вложенные флекс-контейнеры */
  flex-direction: column;
}

/* Обёртка карты */
.map-wrapper {
  flex: 1;           /* займёт всё пространство .main-content */
  min-height: 0;     /* важно для корректной работы flex */
}

/* Сам контейнер Leaflet */
#map {
  width: 100%;
  height: 100%;
}

/* Стили для карточек персонажей */
.character-card {
    border: 1px solid #111;
    border-radius: 10px;
    background-color: #fff;
    box-shadow: 2px 2px 0 #000;
    font-family: 'Courier New', monospace;
    transition: transform 0.2s ease-in-out;
}

.character-card:hover {
    transform: rotate(-1deg) scale(1.02);
    box-shadow: 4px 4px 0 #000;
}

.icon-label {
    width: 18px;
    height: 18px;
    margin-right: 2px;
    vertical-align: middle;
}

/* Стили для таблиц */
.table-responsive {
    margin-bottom: 0;
}

/* Стили для футера */
footer {
    margin-top: 2rem;
}

/* Карта */
#map-container {
    border: 1px solid #ddd;
    border-radius: 4px;
    overflow: hidden;
}

/* Стили для значков сложности */
.difficulty-badge {
    padding: 0.25rem 0.5rem;
    border-radius: 4px;
    display: inline-block;
    font-size: 0.85rem;
}

.difficulty-1 { background-color: #bce7d5; color: #1e7e5a; }
.difficulty-2 { background-color: #c5e0fa; color: #2168a2; }
.difficulty-3 { background-color: #fff3cd; color: #856404; }
.difficulty-4 { background-color: #f8d7da; color: #721c24; }
.difficulty-5 { background-color: #c3adf1; color: #5a2ca2; }

/* Jumbotron для Bootstrap 5 */
.jumbotron {
    padding: 2rem;
    margin-bottom: 2rem;
    background-color: #e9ecef;
    border-radius: 0.3rem;
}

.character-marker {
    transition: all 1s ease;
}

.character-marker {
  transition: transform 0.2s ease-out;
}

.character-marker img {
    border: 2px solid transparent;
    transition: all 0.3s ease;
}

.character-marker.moving img {
    border-color: #ffeb3b;
    filter: drop-shadow(0 0 8px rgba(255,235,59,0.5));
}

/* сам контейнер слайдов будет auto-ширины */
.random-swiper .swiper-slide {
  width: 200px;
  text-align: center;
  position: relative;
  border-radius: 8px;
  overflow: hidden;
}

/* Простая flicker-анимация огня */
.fire-effect::before {
  content: "";
  position: absolute;
  top: -20%; left: -20%;
  width: 140%; height: 140%;
  pointer-events: none;
  background: url('/static/images/like.png') center/cover no-repeat;
  mix-blend-mode: screen;
  animation: flicker 1s infinite;
}

@keyframes flicker {
  0%,100% { opacity: 0.4; }
  50%     { opacity: 0.8; }
}

/* Стили для изображения и подписи */
.random-swiper img {
  display: block;
  width: 100%;
  border-radius: 8px;
}
.random-swiper h5 {
  margin: 8px 0;
  color: #fff;
  text-shadow: 0 0 6px rgba(0,0,0,0.6);
}

.h1-image {
    height: 32px;
    margin-right: 10px;
    vertical-align: middle;
}

.btn-like.liked {
  background-color: #dc3545;
  color: white;
  border-color: #dc3545;
}

.news-card {
  border: 1px solid #ddd;
  border-radius: 10px;
  background: #fff;
  box-shadow: 2px 2px 6px rgba(0,0,0,0.05);
  transition: transform 0.2s ease;
}
.news-card:hover {
  transform: translateY(-4px);
}
.news-card .card-title {
  font-weight: 600;
}
.news-card small {
  color: #888;
}

.news-card {
  transition: transform 0.2s ease;
  cursor: pointer;
}
.news-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 12px rgba(0,0,0,0.1);
}

.random-swiper .swiper-slide {
  width: 200px;
  text-align: center;
  position: relative;
  border-radius: 12px;
  overflow: hidden;
  border: 2px solid #000;
  background-color: #111;
  box-shadow: 0 0 10px rgba(0,0,0,0.4);
  transition: transform 0.3s ease;
}

.random-swiper .swiper-slide:hover {
  transform: scale(1.05);
}

.random-swiper img {
  width: 100%;
  object-fit: cover;
  aspect-ratio: 3 / 4;
  border-radius: 12px;
  border: 2px solid white;
}

.random-swiper h5 {
  color: white;
  font-family: 'Courier New', monospace;
  text-shadow: 0 0 4px black;
  margin-top: 8px;
}

.btn.back-to-news {
  background-color: #000;
  color: #fff;
  border: 2px solid #000;
  transition: background-color 0.2s, color 0.2s;
  margin-bottom: 3rem;
}

.btn.back-to-news:hover {
  background-color: #fff;
  color: #000;
}

.btn.remove-filters {
  background-color: #000;
  color: #fff;
  border: 2px solid #000;
  transition: background-color 0.2s, color 0.2s;
}
.btn.remove-filters:hover {
  background-color: #fff;
  color: #000;
}

.card-header {
  margin-bottom: 0px;
}

.btn-primary {
  background-color: #000000;
  color: #fff;
  border: 2px solid #000;
  transition: background-color 0.2s, color 0.2s;
}
.btn.btn-primary:hover {
  background-color: #fff;
  color: #000;
  border-color: #000;
}

