:root {
  --bg: #FFF9F3;
  --card: #FFFFFF;
  --accent: #F4D6B8;
  --accent-2: #F4B183;
  --muted: #9C8373;
  --text: #5C4033;
  --soft: #FCEED8;
  --success: #81C784;
  --radius: 14px;
  --gap: 12px;
  --shadow: 0 6px 18px rgba(92, 64, 51, 0.06);
}

/* ===== Общие стили приложения ===== */
body {
  background-color: #FFF9F3;
  color: #5C4033;
  font-family: 'Inter', sans-serif;
}

.container-main {
  max-width: 700px;
  margin: auto;
  padding: 1rem;
  background: #fff;
  border-radius: 1rem;
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.05);
}

/* ===== Заголовки и текст ===== */
h1,
h2,
h3,
h4,
h5,
h6 {
  color: #5C4033;
  font-weight: 600;
}

.text-muted {
  color: #9C8373 !important;
}

/* ===== Кнопки ===== */
.btn-primary {
  background-color: #83B7F4;
  border: none;
  color: #fff;
  transition: background-color 0.3s ease;
}

.btn-primary:hover {
  background-color: #5A9DEB;
}

.btn-warning {
  background-color: #F4B183;
  border: none;
  color: #fff;
  transition: background-color 0.3s ease;
}

.btn-warning:hover {
  background-color: #E59A63;
}

.btn-success {
  background-color: #A6D785;
  border: none;
  color: #fff;
  transition: background-color 0.3s ease;
}

.btn-success:hover {
  background-color: #8FC768;
}

/* ===== Аккордионы ===== */
.accordion-button {
  background-color: #FFF0E6;
  color: #5C4033;
  font-weight: 600;
  border: none;
  box-shadow: none;
  transition: background-color 0.3s ease;
}

.accordion-button:not(.collapsed) {
  background-color: #F4B183;
  color: #fff;
}

.accordion-item {
  border: none;
  border-radius: 0.75rem;
  margin-bottom: 0.5rem;
  overflow: hidden;
}

.accordion-body {
  background: #fff;
  border-top: 1px solid #F4B18333;
  padding: 1rem;
}

/* ===== Карточки и блоки ===== */
.card-custom {
  border: none;
  border-radius: 0.75rem;
  background: #FFF0E6;
  padding: 1rem;
  margin-bottom: 0.75rem;
}

.card-custom.active {
  background: #F3FFE6;
  border-left: 5px solid #A6D785;
}

.card-custom.sleep {
  border-left: 5px solid #F4B183;
}

.card-custom.awake {
  background: #E6F3FF;
  border-left: 5px solid #83B7F4;
}

/* ===== Разделители и даты ===== */
.date-divider {
  font-size: 0.9rem;
  font-weight: 600;
  color: #9C8373;
  margin: 1rem 0 0.5rem;
  text-align: center;
}

/* ===== Формы ===== */
.form-control {
  border-radius: 0.5rem;
  border: 1px solid #E0CFC1;
}

.form-control:focus {
  border-color: #F4B183;
  box-shadow: 0 0 0 0.25rem rgba(244, 177, 131, 0.25);
}

/* ===== Навигация / тулбар ===== */
.navbar-custom {
  background-color: #F4B183;
  color: #fff;
  border-bottom: 3px solid #E59A63;
}

.navbar-custom .nav-link {
  color: #fff !important;
  font-weight: 500;
}

.navbar-custom .nav-link.active {
  text-decoration: underline;
}

/* ===== Анимации и плавные переходы ===== */
.fade-enter-active,
.fade-leave-active {
  transition: opacity 0.3s ease;
}

.fade-enter-from,
.fade-leave-to {
  opacity: 0;
}

/* ===== Элементы уведомлений ===== */
.alert-custom {
  background-color: #FFF0E6;
  color: #5C4033;
  border-left: 5px solid #F4B183;
  border-radius: 0.75rem;
  padding: 0.75rem 1rem;
  margin-top: 0.5rem;
  animation: fadeOut 3s ease 2s forwards;
}

@keyframes fadeOut {
  to {
    opacity: 0;
    height: 0;
    margin: 0;
    padding: 0;
  }
}

/* ===== Таблицы ===== */
.table-custom th {
  background: #FFF0E6;
  color: #5C4033;
  border-bottom: 2px solid #F4B183;
}

.table-custom td {
  border-color: #F4B18333;
}

/* ===== Вспомогательные классы ===== */
.shadow-soft {
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.05);
}

.text-accent {
  color: #F4B183;
}

.bg-accent {
  background-color: #F4B183;
  color: #fff;
}

.icon-btn {
  background: transparent;
  border: none;
  color: #5C4033;
  font-size: 1.25rem;
  margin: 0 0.25rem;
  cursor: pointer;
  transition: all 0.2s ease;
}

.icon-btn:hover {
  color: #F4B183;
  transform: scale(1.1);
}

.icon-btn.delete:hover {
  color: #dc3545;
  /* Bootstrap danger color */
}

.sleep-container {
  background: #fff;
  border-radius: 1rem;
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.05);
  padding: 1rem;
}

.sleep-entry,
.awake-entry {
  border-radius: 0.75rem;
  padding: 1rem;
  margin-bottom: 0.75rem;
  text-align: center;
}

.action-icons {
  position: absolute;
  display: flex;
  bottom: 0.5rem;
  right: 0.5rem;
}

/* ===== Кнопка "Загрузить еще" ===== */
.load-more-btn {
  background-color: #F4B183 !important;
  border: none !important;
  color: #fff !important;
  font-weight: 600;
  border-radius: 12px !important;
  padding: 0.75rem 1.5rem !important;
  transition: all 0.3s ease !important;
  box-shadow: 0 4px 12px rgba(244, 177, 131, 0.3) !important;
  /* Для Android и мобильных устройств */
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
  user-select: none;
  -webkit-user-select: none;
  cursor: pointer;
  min-height: 44px;
  /* Минимальная высота для касания */
  min-width: 44px;
  /* Минимальная ширина для касания */
}

.load-more-btn:hover {
  background-color: #E59A63 !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 6px 16px rgba(244, 177, 131, 0.4) !important;
}

.load-more-btn:active {
  transform: translateY(0) !important;
  background-color: #D68A53 !important;
}

.load-more-btn:disabled {
  background-color: #9C8373 !important;
  cursor: not-allowed;
  opacity: 0.6;
}

/* Специальные стили для Android и мобильных устройств */
@media (hover: none) and (pointer: coarse) {
  .load-more-btn {
    background-color: #F4B183;
    -webkit-tap-highlight-color: rgba(244, 177, 131, 0.3);
  }

  .load-more-btn:active {
    background-color: #E59A63 !important;
  }
}

/* Улучшение для старых Android устройств */
.load-more-btn:focus {
  outline: 2px solid #E59A63;
  outline-offset: 2px;
}

/* Контейнер для кнопки */
.text-center.mt-3 {
  padding: 1rem 0;
}

/* Текст "Показано X дней" */
.text-muted.mb-2 {
  color: #9C8373 !important;
  font-size: 0.9rem;
  margin-bottom: 0.5rem !important;
}

.sleep-entry {
  position: relative;
}

@keyframes pulse-night {
  0% {
    box-shadow: 0 0 0 0 rgba(58, 122, 254, .25);
  }

  70% {
    box-shadow: 0 0 0 12px rgba(58, 122, 254, 0);
  }

  100% {
    box-shadow: 0 0 0 0 rgba(58, 122, 254, 0);
  }
}

.sleep-entry.night-sleep {
  background: #E6EEFF;
  border-left: 5px solid #6C8AE4;
  color: #2F3A66;

  .action-icons .icon-btn {
    color: #2F3A66;
  }

  .action-icons .icon-btn:hover {
    color: #4A6ED1;
  }
}

.sleep-entry.night-sleep.active-sleep {
  animation: pulse-night 2s infinite;
}

.sleep-entry.day-sleep {
  background: #FFF7E6;
  border-left: 5px solid #F4B183;
  color: #6B4A2D;

  .action-icons .icon-btn {
    color: #6B4A2D;
  }

  .action-icons .icon-btn:hover {
    color: #E59A63;
  }
}

.sleep-entry.day-sleep.active-sleep {
  animation: pulse 2s infinite;
}

@keyframes pulse {
  0%  {
    box-shadow: 0 0 0 0 rgba(244, 177, 131, .25);
  }

  70% {
    box-shadow: 0 0 0 12px rgba(244, 177, 131, 0);
  }

  100% {
    box-shadow: 0 0 0 0 rgba(244, 177, 131, 0);
  }
}


.awake-entry {
  background: #E9F7F0;
  border-left: 5px solid #4DB6AC;
  color: #1F4F46;

  .duration {
    color: #1F4F46;
  }
}

.awake-entry.active-awake {
  animation: pulse-awake 2s infinite;
}


@keyframes pulse-awake {
  0% {
    box-shadow: 0 0 0 0 rgba(76, 175, 169, .25);
  }

  70% {
    box-shadow: 0 0 0 12px rgba(76, 175, 169, 0);
  }

  100% {
    box-shadow: 0 0 0 0 rgba(76, 175, 169, 0);
  }
}

.duration {
  font-weight: 600;
  margin: 0.25rem 0;
}

.date-divider {
  font-size: 0.9rem;
  font-weight: 600;
  color: #9C8373;
  margin-top: 1rem;
  text-align: center;
}


.latest {
  background-color: #fef0f5;
  font-weight: bold;
}

.accordion-button:focus {
  box-shadow: none;
}

.btn-large {
  font-size: 1.5rem;
  padding: 1rem;
  width: 100%;
}

.auto-dismiss-slide {
  position: fixed;
  bottom: 20px;
  left: 50%;
  transform: translateX(-50%);
  max-width: 600px;
  /* ограничим ширину для читаемости */
  width: 90%;
  /* почти на всю ширину кнопки */
  z-index: 1050;
  overflow: hidden;
  max-height: 200px;
  opacity: 1;
  transition: max-height 0.1s ease, opacity 1s ease;
}

.auto-dismiss-slide.hide {
  max-height: 0;
  opacity: 0;
}

#trackerContainer {
  width: 300%;
  /* два блока */
  display: flex;
  transform: translateX(0%);
  transition: transform 0.3s ease;
}

.pane {
  width: 100%;
  flex-shrink: 0;
}

.scrollable-list {
  max-height: 70vh;
  /* ограничиваем высоту 60% экрана */
  overflow-y: auto;
}


/* #addForm {
  position: fixed;
  bottom: 100px;
  left: 50%;
  transform: translateX(-50%);
  max-width: 700px;
  z-index: 1060;
  margin: 0;
  pointer-events: auto;
} */

/* #addForm .btn {
  width: 100%;
  border-radius: 12px;
} */

/* give the tracker page extra bottom padding so content isn't hidden behind the fixed button */
/* #trackerWrapper {
  padding-bottom: 110px;
} */

/* @media (min-width: 768px) {
  #addForm { bottom: 28px; }
  #trackerWrapper { padding-bottom: 140px; }
} */

.nav-tabs {
  gap: 8px;
  border-bottom: 0px;
}

.nav-tabs .nav-link {
  color: #6c757d;
  border-radius: 12px;
  border-color: var(--accent);
  margin-bottom: 0px;
  cursor: pointer;
  padding: 0.75rem 1.25rem;
  transition: color 0.3s, background-color 0.3s;
}

.nav-tabs .nav-link.active {
  color: #fff;
  background-color: var(--accent);
  border-color: var(--accent);
  border-bottom: 1px;
}

.nav-tabs .nav-link:hover {
  color: #000;
}


.nav-tabs {
  overflow-x: auto;
  overflow-y: hidden;
  display: -webkit-box;
  display: -moz-box;
}

.nav-tabs>li {
  float: none;
}

#trackerTabs {
  overflow-x: auto;
  scroll-behavior: smooth;
  white-space: nowrap;
}

#trackerTabs::-webkit-scrollbar {
  display: none;
}

#trackerTabs::-webkit-scrollbar-thumb {
  display: none;
}