:root {
  /* Палитра */
  --color-black-main: #1e1e1e;
  --color-black-dark: #141414;
  --color-purple-accent: #a855f7; /* Яркий фиолетовый */
  --color-purple-hover: #8b45e7;
  --color-text-light: #f0f0f0;
  --color-text-dimmed: #b3b3b3;
  --color-border: #333;
}

/* Сброс и базовые стили */
* {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html,
body {
  height: 100%; /* Гарантируем полную высоту для app-container */
  overflow: hidden; /* Запрещаем прокрутку body, прокрутка будет внутри main-content */
}

body {
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica,
    Arial, sans-serif;
  background-color: var(--color-black-main);
  color: var(--color-text-light);
}

a {
  color: var(--color-purple-accent);
  text-decoration: none;
}

a:hover {
  color: var(--color-purple-hover);
  text-decoration: underline;
}

article {
  /* Firefox */
  scrollbar-width: none; 
  /* IE и Edge */
  -ms-overflow-style: none; 
}

/* Chrome, Safari, Opera */
article::-webkit-scrollbar {
  display: none;
  /* Или width: 0; */
}

/* Макет GitBook Style */
.app-container {
  display: flex;
  height: 100vh; /* Занимаем всю высоту вьюпорта */
}

/* Сайдбар (без изменений) */
.sidebar {
  width: 300px;
  background-color: var(--color-black-dark);
  border-right: 1px solid var(--color-border);
  flex-shrink: 0;
  overflow-y: auto;
  padding: 20px 0;
  /* ... остальные стили сайдбара из первого ответа ... */
}
/* Стили навигации (немного доработаны для класса nav-link) */
.sidebar-header {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 0 20px 20px 20px;
  border-bottom: 1px solid var(--color-border);
  margin-bottom: 15px;
}
.sidebar h3 {
  color: var(--color-purple-accent);
  font-weight: 600;
}
#welcome {
  h2 {
    width: 100% !important;
    text-align: start;
  }
}
.sidebar-nav ul {
  list-style: none;
}
.sidebar-nav li a {
  display: block;
  padding: 10px 20px;
  color: var(--color-text-light);
  font-size: 14px;
  transition: background-color 0.2s, color 0.2s;
}
.sidebar-nav li a:hover {
  background-color: #2a2a2a;
  color: var(--color-purple-accent);
  text-decoration: none;
}
.sidebar-nav a.active {
  background-color: #2a2a2a;
  color: var(--color-purple-accent);
  border-left: 3px solid var(--color-purple-accent);
  padding-left: 17px;
}
.sidebar-nav .submenu {
  list-style: none;
  padding-left: 15px;
  display: none;
}
.sidebar-nav .submenu.active {
  display: block;
}
.sidebar-nav .submenu li a {
  padding: 8px 20px 8px 35px;
  color: var(--color-text-dimmed);
}
.sidebar-nav .section-title i {
  float: right;
  margin-top: 2px;
  font-size: 12px;
  transition: transform 0.2s;
}
.sidebar-nav .section-title.open i {
  transform: rotate(90deg);
}

/* Основное содержимое */
.content-wrapper {
  flex-grow: 1;
  display: flex;
  flex-direction: column;
  min-width: 0;
}

/* Навбар (без изменений) */
.navbar {
  height: 60px;
  background-color: var(--color-black-dark);
  border-bottom: 1px solid var(--color-border);
  padding: 0 20px;
  display: flex;
  align-items: center;
  flex-shrink: 0;
}
.navbar-search input {
  width: 250px;
  padding: 8px 15px;
  border: 1px solid var(--color-border);
  background-color: #2a2a2a;
  color: var(--color-text-light);
  border-radius: 4px;
  transition: border-color 0.2s;
}
.navbar-search input:focus {
  border-color: var(--color-purple-accent);
  outline: none;
}
.menu-toggle {
  display: none;
}

/* --- Ключевые изменения для "одного пункта на экране" --- */

.main-content {
  flex-grow: 1;
  /* Убираем прокрутку здесь, так как она будет в самой статье */
  position: relative; /* Для позиционирования статей */
}

.doc-page {
  /* Каждая статья занимает все доступное пространство в main-content */
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;

  /* Скрытие по умолчанию */
  opacity: 0;
  visibility: hidden;
  pointer-events: none; /* Запрещаем взаимодействие со скрытыми статьями */
  transition: opacity 0.3s ease-in-out;

  /* Внутренняя прокрутка для самой статьи */
  overflow-y: auto;

  /* Внутреннее форматирование контента */
  padding: 40px;
  max-width: 900px; /* Ограничиваем ширину для лучшей читаемости */
  margin: 0 auto;
}

/* Активная (видимая) страница */
.doc-page.active-page {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

/* Стили для контента (заголовки, код) */
.doc-page h1,
.doc-page h2,
.doc-page h3 {
  color: var(--color-purple-accent);
  padding-bottom: 10px;
  margin-top: 20px;
}
.doc-page h1 {
  font-size: 2.5em;
  border-bottom: 1px solid var(--color-border);
  padding-bottom: 20px;
  margin-bottom: 30px;
}
.doc-page p {
  line-height: 1.6;
  margin-bottom: 15px;
  color: var(--color-text-light);
}
pre {
  background-color: #0d0d0d;
  padding: 15px;
  border-radius: 4px;
  overflow-x: auto;
  margin-bottom: 20px;
}
code {
  font-family: "Consolas", "Courier New", monospace;
  color: var(--color-purple-hover);
}

/* Адаптивность */
@media (max-width: 900px) {
  
  .logo {
    width: 150px !important;
    margin: 0 !important;
    margin-top: 5px !important;
    height: auto !important;
    left: 25px !important;
  }
  #welcome{
    padding: 20px !important;
  }
  img {
    width: 100% !important;
    height: auto;
    border-radius: 10px;
    margin-top: 15px;
    margin-bottom: 15px;
  }
  .sidebar {
    position: fixed;
    left: -300px;
    top: 0;
    bottom: 0;
    transition: left 0.3s ease-in-out;
    z-index: 10;
  }

  .sidebar.open {
    left: 0;
  }

  .content-wrapper {
    width: 100%;
  }

  .menu-toggle {
    display: block;
    background: none;
    border: none;
    color: var(--color-text-light);
    font-size: 1.5rem;
    cursor: pointer;
    margin-right: 15px;
  }
}
 @media (min-width: 1600px) {
  img {
    width: auto !important;
    height: auto;
    border-radius: 10px;
    margin-top: 15px;
    margin-bottom: 15px;
  }
  .doc-page {
    padding: 60px;
  }
  .sidebar {
    .section-title{
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 15px;
    }
  }
  body {
    padding-left: 20%;
    padding-right: 20%;
  }
}