/* ====== TIMER ====== */

.deadline-timer-container {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin: 40px 0;
  font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI",
    sans-serif;
  color: #1f2933;
}

.timer-grid {
  display: flex;
  align-items: flex-start;
  justify-content: center;
  gap: 28px;
  width: 100%;
  opacity: 0;
  transform: translateY(-40px);
  transition: all 0.6s ease-in-out;
}

.timer-grid.timer-grid-loaded {
  opacity: 1;
  transform: translateY(0);
}

.timer-unit {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.timer-value-wrapper {
  display: flex;
  align-items: center;
  justify-content: center;
}

.timer-value {
  display: flex;
  gap: 6px;
}

/* Один разряд */
.digit-wrapper {
  position: relative;
  width: 2.5ch; /* ширина под одну цифру */
  height: 48px; /* ВАЖНО: совпадает с translateY(48px) в JS */
  overflow: hidden; /* прячем выезжающие цифры */
}

.digit-placeholder {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 42px;
  font-weight: 600;
  color: var(--primary-dark);
  line-height: 48px;
  z-index: 1;
}

/* Анимация для переключения цифры (падение сверху) */
.digit-animate {
  animation: slide-down 0.5s ease-in-out forwards;
  z-index: 0;
}

/* Двоеточия между блоками */
.timer-separator {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 40px;
  font-weight: 600;
  margin-top: 0;
  line-height: 48px;
  vertical-align: middle;
  margin-bottom: 0;
  color: var(--primary-dark);
}

.timer-label {
  font-size: 15px;
  letter-spacing: 0.1em;
  font-weight: 600;
  text-transform: uppercase;
  color: #6b7280;
}

.deadline-ended {
  margin-top: 16px;
  font-size: 14px;
  color: #b91c1c;
}

/* Адаптивные стили для экранов до 768px */
@media (max-width: 768px) {
  .deadline-timer-container {
    margin: 20px 15px;
    padding: 10px; /* Плавные отступы */
  }

  .timer-grid {
    gap: 16px; /* Уменьшаем расстояние между блоками */
    justify-content: center; /* Центрируем таймер */
  }

  .digit-wrapper {
    height: 40px; /* Уменьшаем высоту цифр */
  }

  .digit-placeholder,
  .timer-separator {
    font-size: 30px; /* Уменьшаем размер цифр */
    line-height: 40px; /* Адаптированный размер */
  }

  .timer-label {
    font-size: 12px; /* Меньший шрифт для подписей */
  }
}

/* Адаптивные стили для экранов до 480px (мобильные устройства) */
@media (max-width: 480px) {
  .deadline-timer-container {
    margin-top: 2rem;
    padding: 5px; /* Сокращенные отступы */
  }

  .timer-grid {
    gap: 9px;
    justify-content: center;
  }

  .timer-value {
    gap: 3px; /* Уменьшаем отступы между цифрами */
  }

  .digit-wrapper {
    height: 32px;
    width: 1.8ch;
  }

  .digit-placeholder {
    font-size: 22px; /* Уменьшаем размер цифр */
  }

  .timer-separator {
    font-size: 28px;
    line-height: 30px;
  }

  .timer-label {
    font-size: 10px; /* Уменьшаем размер подписей */
  }
}

@media (max-width: 320px) {
  .deadline-timer-container {
    margin: 1rem;
    padding: 5px;
  }

  .timer-grid {
    margin-top: 25px;
    gap: 8px;
    justify-content: center;
  }

  .digit-wrapper {
    width: 1.8ch;
  }
  .timer-separator {
    line-height: 28px;
    width: 20px;
  }

  .timer-value {
    gap: 0;
  }

  .digit-placeholder {
    font-size: 18px; /* Очень маленький шрифт */
  }

  .timer-separator {
    font-size: 26px; /* Очень маленький шрифт для двоеточий */
  }

  .timer-label {
    font-size: 8px; /* Минимальный размер шрифта */
  }
}

/* Анимация падения сверху */
@keyframes slide-down {
  0% {
    transform: translateY(-48px); /* Начинаем с верхней позиции */
  }
  100% {
    transform: translateY(0); /* Плавное падение до нормальной позиции */
  }
}
