:root {
  /* Общие переменные */
  --card-gap: 6px;
  --card-border: #ccc;
  --card-radius: 6px;
  --card-text-height: 80px;

  --card-bg: #dfe3f0;
  --card-bg-hover: #f7f7f7;

  --line1-color: #333;
  --line1-hover: #66cc33;
  --line2-color: #666;
  --line2-hover: #000;
  --line3-color: #999;
  --line3-hover: #444;

  /* Инфо-карточка */
  --info-border: 2px dashed #999;
  --info-border-radius: 6px;
  --info-bg: #f9f9f9;
  --info-color: #333;
  --info-hover-bg: #eee;
  --info-hover-color: #000;

  /* Трансишн */
  --transition: 0.25s;
}

/* === Контейнеры === */
.cards-container-4321,
.cards-container-421,
.cards-container-321,
.cards-container-21,
.cards-container-54321,
.cards-container-654321,
.cards-container-6421 {
  display: grid;
  grid-gap: var(--card-gap);
  max-width: 986px;
  margin: 0 auto;
  box-sizing: border-box;
}

/* — подсказки для JS — */
.cards-container-4321::after  { content: "4"; display: none; }
.cards-container-421::after   { content: "4"; display: none; }
.cards-container-321::after   { content: "3"; display: none; }
.cards-container-21::after    { content: "2"; display: none; }
.cards-container-54321::after { content: "5"; display: none; }
.cards-container-654321::after{ content: "6"; display: none; }
.cards-container-6421::after  { content: "6"; display: none; }

/* === Обычные карточки === */
.card-normal {
  border: 1px solid var(--card-border);
  border-radius: var(--card-radius);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  cursor: default;
  text-decoration: none;
  color: inherit;
  background: var(--card-bg);
  transition: transform 0.2s ease, background var(--transition), box-shadow var(--transition);
  box-sizing: border-box;
}

a.card-normal { cursor: pointer; }

.card-normal img {
  width: 100%;
  height: auto;
  object-fit: cover;
  display: block;
}

.normal-text {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  min-height: var(--card-text-height);
  height: 100%;
  padding: 8px;
  box-sizing: border-box;
}

.normal-top,
.normal-top ul li,
.normal-top ol li {
  font-weight: bold;
  color: var(--line1-color);
}

.normal-mid,
.normal-mid ul li,
.normal-mid ol li {
  font-size: 0.85em;
  color: var(--line2-color);
}

.normal-bottom,
.normal-bottom ul li,
.normal-bottom ol li {
  font-size: 0.85em;
  color: var(--line3-color);
  margin-top: auto;
}

.card-text i {
  font-size: 0.9em;
  color: inherit;
}

/* Hover для <a> */
a.card-normal:hover {
  background-color: var(--card-bg-hover);
  box-shadow: 0 2px 6px rgba(0,0,0,0.35);
  text-decoration: none;
}

a.card-normal:hover .card-text-top    { color: var(--line1-hover); }
a.card-normal:hover .card-text-mid    { color: var(--line2-hover); }
a.card-normal:hover .card-text-bottom { color: var(--line3-hover); }

/* === Инфо-карточка === */

.card-info {
  border: var(--info-border);
  border-radius: var(--info-border-radius);
  background: var(--info-bg);
  color: var(--info-color);
  font-weight: normal;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  padding: 1rem;
  box-sizing: border-box;
  height: auto;
  min-height: 0;
  transition: background 0.18s ease, color 0.18s ease;
}

a.card-info:hover {
  background: var(--info-hover-bg);
  color: var(--info-hover-color);
  text-decoration: none;
}

.card-info .info-top {
  font-size: 1rem;
  font-weight: bold;
  margin-bottom: 0.5rem;
  line-height: 1.2;
}

.card-info .info-flex {
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  min-height: 0;
}

.card-info .info-mid {
  flex: 1 1 auto;
  min-height: 0;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  padding: 0.25rem;
  font-size: 0.75rem;
  box-sizing: border-box;
  border-radius: var(--info-border-radius);
  line-height: 1.2;
  word-break: break-word;
}

.card-info .info-mid span.no-wrap { white-space: nowrap; }

.card-info .info-bottom {
  font-size: 0.85rem;
  margin-top: 0.5rem;
  line-height: 1.2;
}

/* === Greedy-карточка === */
.card-greedy {
  /* сама растяжка делается JS */
}

/* === Сетки === */
.cards-container-4321   { grid-template-columns: repeat(4, 1fr); }
.cards-container-421    { grid-template-columns: repeat(4, 1fr); }
.cards-container-321    { grid-template-columns: repeat(3, 1fr); }
.cards-container-21     { grid-template-columns: repeat(2, 1fr); }
.cards-container-54321  { grid-template-columns: repeat(5, 1fr); }
.cards-container-654321 { grid-template-columns: repeat(6, 1fr); }
.cards-container-6421   { grid-template-columns: repeat(6, 1fr); }

/* === Media queries === */
@media (max-width:1200px) {
  .cards-container-4321   { grid-template-columns: repeat(3, 1fr); }
  .cards-container-421    { grid-template-columns: repeat(2, 1fr); }
  .cards-container-321    { grid-template-columns: repeat(2, 1fr); }
  .cards-container-21     { grid-template-columns: 1fr; }
  .cards-container-54321  { grid-template-columns: repeat(4, 1fr); }
  .cards-container-654321 { grid-template-columns: repeat(5, 1fr); }
  .cards-container-6421   { grid-template-columns: repeat(5, 1fr); }

  .cards-container-4321::after   { content: "3"; }
  .cards-container-421::after    { content: "2"; }
  .cards-container-321::after    { content: "2"; }
  .cards-container-21::after     { content: "1"; }
  .cards-container-54321::after  { content: "4"; }
  .cards-container-654321::after { content: "5"; }
  .cards-container-6421::after   { content: "5"; }
}

@media (max-width:900px) {
  .cards-container-4321,
  .cards-container-421,
  .cards-container-321,
  .cards-container-54321,
  .cards-container-654321,
  .cards-container-6421 { grid-template-columns: repeat(2, 1fr); }

  .cards-container-4321::after,
  .cards-container-421::after,
  .cards-container-321::after,
  .cards-container-54321::after,
  .cards-container-654321::after,
  .cards-container-6421::after { content: "2"; }

  .cards-container-21 { grid-template-columns: 1fr; }
  .cards-container-21::after { content: "1"; }
}

@media (max-width:600px) {
  .cards-container-4321,
  .cards-container-421,
  .cards-container-321,
  .cards-container-21,
  .cards-container-54321,
  .cards-container-654321,
  .cards-container-6421 { grid-template-columns: 1fr; }

  .cards-container-4321::after,
  .cards-container-421::after,
  .cards-container-321::after,
  .cards-container-21::after,
  .cards-container-54321::after,
  .cards-container-654321::after,
  .cards-container-6421::after { content: "1"; }
}
