/* =========================================================
   SITE.CSS — базовые стили проекта (матовый тёмный, плавающий хедер)
   ========================================================= */

/* ---------- БАЗА HTML / ТИПОГРАФИЯ ---------- */
html { font-size: 14px; }
@media (min-width: 768px){
  html { font-size: 16px; }
}

html { position: relative; min-height: 100%; }

/* Убрали лишний отступ снизу, который давал «продолжение страницы» */
body {
  margin: 0;
}

/* Фокус Bootstrap (можно смягчить при желании) */
.btn:focus,
.btn:active:focus,
.btn-link.nav-link:focus,
.form-control:focus,
.form-check-input:focus{
  box-shadow: 0 0 0 0.1rem white, 0 0 0 0.25rem #258cfb;
}

/* Плейсхолдеры во float-формах */
.form-floating > .form-control-plaintext::placeholder,
.form-floating > .form-control::placeholder{
  color: var(--bs-secondary-color);
  text-align: end;
}
.form-floating > .form-control-plaintext:focus::placeholder,
.form-floating > .form-control:focus::placeholder{
  text-align: start;
}

/* База для страницы Контактов (деталь — в contacts.css) */
.body-contacts{
  background-color:#212529;
  color:#fff;
  min-height:100vh;
  padding-top:30px;
}

/* =========================================================
   Плавающий хедер, body padding, main reset, мобильная вуаль —
   всё в layout.css.  Переменные навигации — в theme.css.
   ========================================================= */

/* =========================================================
   МОБИЛЬНОЕ МЕНЮ / ДРОПДАУНЫ — ПОРТРЕТНЫЙ РЕЖИМ
   Чёрный фон, белый текст, читаемые ховеры
   ========================================================= */
@media (max-width: 991.98px) and (orientation: portrait){

  /* Фон раскрытого меню (collapsible) под фикс-хедером */
  .navbar.navbar-floating .navbar-collapse{
    background:#000;
    color:#fff;
    border-top:1px solid #2a2a2a;
    box-shadow:0 10px 24px rgba(0,0,0,.5);
  }

  /* Ссылки верхнего уровня */
  .navbar-dark .navbar-nav .nav-link{
    color:#fff !important;
  }
  .navbar-dark .navbar-nav .nav-link:hover,
  .navbar-dark .navbar-nav .nav-link:focus,
  .navbar-dark .navbar-nav .nav-link.active{
    color:#f1f1f1 !important;
    background:#0f0f0f;
    border-radius:8px;
  }

  /* Дропдауны */
  .navbar-dark .dropdown-menu,
  .dropdown-menu{
    background:#000;
    border:1px solid #2a2a2a;
  }
  .dropdown-menu .dropdown-item{
    color:#fff;
  }
  .dropdown-menu .dropdown-item:hover,
  .dropdown-menu .dropdown-item:focus,
  .dropdown-menu .dropdown-item.active{
    color:#fff;
    background:#111;
  }
  .dropdown-divider{ border-top-color:#2a2a2a; }

  /* Если используешь Offcanvas для меню */
  .offcanvas,
  .offcanvas.offcanvas-start,
  .offcanvas.offcanvas-end{
    background:#000;
    color:#fff;
  }
}

/* =========================================================
   СВЕТЛАЯ КНОПКА-БУРГЕР (в нашем матовом стиле)
   ========================================================= */

/* Общий вид кнопки */
.navbar-dark .navbar-toggler{
  border-color: rgba(255,255,255,.55);
  background: rgba(255,255,255,.06);
  border-radius: 12px;
  padding: .45rem .6rem;
  transition: background .18s ease, border-color .18s ease, box-shadow .18s ease, transform .14s ease;
}
.navbar-dark .navbar-toggler:hover{
  background: rgba(255,255,255,.12);
  transform: translateY(-1px);
}
.navbar-dark .navbar-toggler:active{
  background: rgba(255,255,255,.16);
  transform: translateY(0);
}
.navbar-dark .navbar-toggler:focus{
  outline: none;
  border-color: #e0d7c4; /* тёплый контур под наш стиль */
  box-shadow: 0 0 0 3px rgba(224,215,196,.35);
}

/* Светлая иконка «три полоски» (перекрашиваем встроенный SVG Bootstrap) */
.navbar-dark .navbar-toggler .navbar-toggler-icon{
  background-image:
          url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='%23f8fafc' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2.4' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");
  filter: none; /* на всякий случай снимаем invert */
  width: 1.5rem; height: 1.5rem; /* слегка крупнее */
}

/* Гарантируем контраст на чёрном бэкграунде меню в портретном мобайле */
@media (max-width: 991.98px) and (orientation: portrait){
  .navbar.navbar-floating .navbar-collapse{
    background:#000;
    color:#fff;
  }
  .navbar-dark .navbar-toggler{
    border-color: rgba(255,255,255,.6);
    background: rgba(255,255,255,.08);
  }
  .navbar-dark .navbar-toggler:hover{
    background: rgba(255,255,255,.14);
  }
}

/* Offcanvas — светлая кнопка закрытия */
.offcanvas .btn-close{
  filter: invert(1) grayscale(100%); /* белый «крестик» */
  opacity: .95;
}
.offcanvas .btn-close:hover{ opacity: 1; }

/* =========================================================
   ДОП. УТИЛИТЫ
   ========================================================= */

/* Матовый тёмный фон для общих тёмных страниц */
.page-dark{
  background:#212529;
  color:#e5e7eb;
}

/* Плавная прокрутка (по желанию) */
html { scroll-behavior: smooth; }
