:root {
  /* Основные цвета */
  --background-color: #f8f8f8;
  --text-color: #333333;
  --heading-color: #180773;
  
  /* Акцентные цвета */
  --primary-accent: #3498db;
  --secondary-accent: #2ecc71;
  
  /* Цвета для элементов интерфейса */
  --button-bg: #3498db;
  --button-text: #ffffff;
  --input-border: #cccccc;
  --input-focus: #3498db;
  --icon-color: #FFD700; /* Золотистый цвет для иконок fas */
  
  /* Цвета для навигации */
  --nav-bg: #3f51b5;
  --nav-text: #333333;
  --nav-hover: #3498db;
  
  /* Цвета для ссылок */
  --link-color: #3498db;
  --link-hover: #2980b9;
}

  body {
   font-family: Arial, sans-serif;
   margin: 0;
   padding: 39px 0 0;
   background-color: #f8f8f8;
   color: #333;
  }
  .container {
   max-width: 1200px;
   margin: 0 auto;
   padding: 0 15px;
  }
  nav {
   background-color: #3f51b5;
   position: fixed;
   top: 0;
   left: 0;
   right: 0;
   z-index: 1000;
  }
  nav ul {
   list-style-type: none;
   padding: 0;
   margin: 0;
   display: flex;
   justify-content: center;
   font-weight: bold;
  }
  nav ul li {
   position: relative;
   display: inline-block;
   margin-right: 20px;
  }
  nav ul li a {
   color: #ffffff;
   text-decoration: none;
   padding: 10px;
   display: block;
  }
  nav ul li:hover {
   background-color: #3f51b5;
  }
  nav ul li:hover > ul {
   display: block;
  }
  nav ul ul {
   display: none;
   position: absolute;
   background-color: #3f51b5;
   top: 100%;
   left: 0;
   width: 150px;
   z-index: 1000;
  }
  nav ul ul li:hover {
   width: 100%;
   background-color: #1a237e;
  }
  a:-webkit-any-link {
   color: #f6f7f9;
   cursor: pointer;
   text-decoration: none;
  }
  
  a {
    color: #3498db; /* Основной цвет ссылки */
    transition: color 0.3s ease; /* Плавный переход цвета */
    }

    a:hover {
    color: #2980b9; /* Цвет ссылки при наведении */
    }

  .hamburger {
   display: none;
   cursor: pointer;
   padding: 15px;
   color: #ffffff;
  }
  .side-menu {
   display: none;
   position: fixed;
   top: 0;
   left: -250px;
   width: 250px;
   height: 100%;
   background-color: #303f9f;
   transition: 0.3s;
   z-index: 1001;
   overflow-y: auto;
  }
  .side-menu.active {
   left: 0;
  }
  .side-menu ul {
   margin: 0;
   flex-direction: column;
   background-color: #303f9f;
  }
  .side-menu ul ul {
   padding: 0;
   margin: 0;
   position: static;
   width: 100%;
  }
  .side-menu ul li a {
   padding: 12px 15px;
   margin: 0;
   color: #ffffff;
   text-decoration: none;
   display: block;
   border-bottom: 1px solid rgba(255, 255, 255, 0.1);
  }
  
  /* Уменьшаем интервал между подпунктами в боковом меню */
  .side-menu ul ul li a {
   padding: 8px 15px 8px 30px;
   font-size: 14px;
   border-bottom: 1px solid rgba(255, 255, 255, 0.05);
  }
  

  .side-menu ul li:hover {
   background-color: #1a237e;
  }
  
  .side-menu ul li.active > ul {
   display: block;
  }
  
  .side-menu ul ul {
   display: none;
  }
  .close-btn {
   z-index: 1002;
   color: #ffffff;
   position: absolute;
   top: 15px;
   right: 15px;
   cursor: pointer;
   font-size: 20px;
   font-weight: bold;
   background: rgba(0, 0, 0, 0.3);
   border-radius: 50%;
   width: 30px;
   height: 30px;
   display: flex;
   align-items: center;
   justify-content: center;
  }
  header, footer {
   background-color: #180773;
   padding: 0;
  }
  .row {
   display: flex;
   justify-content: space-between;
  }
  .col {
   flex: 1;
  }
  main {
   padding: 40px 0;
   background-color: #ffffff;
  }
  main img {
   max-width: 100%;
   height: auto;
   display: block;
   margin: 0 auto 20px;
  }
  main p {
   text-align: justify;
  }
  h1, h2, h3 {
   color: #180773;
  }

  /* Styles for mobile devices */
  @media (max-width: 768px) {
   nav {
    position: static;
   }
   body {
    padding-top: 0;
   }
   nav ul {
    display: none;
   }
   .hamburger {
    display: block;
   }
   .side-menu {
    display: block;
   }
   header .row, footer .row {
    flex-direction: column;
    text-align: center;
   }
   .col {
    margin-bottom: 15px;
   }
  }
  .custom-table {
   width: 100%;
   border-collapse: collapse;
  }
  .custom-table td {
   width: 25%;
   background: #180773;
   color: #ffffff;
   text-align: center;
   vertical-align: middle;
   padding: 10px 20px;
  }
  .custom-table img {
   max-width: 100%;
   height: auto;
  }
  .custom-table a {
   color: #ffffff;
   text-decoration: none;
  }
  .custom-table a:hover {
   text-decoration: underline;
  }  
  .custom-img {
    max-width: 50% !important;
    height: auto;
  }
  .custom-text {
   font-size: 14px;
  }
  .fa-map-marker:before {
   content: "\f041";
  }   
  .fa-envelope:before {
   content: "\f0e0";
  }
  .fa-phone:before {
   content: "\f095";
  }  
  .fa-shopping-cart:before {
   content: "\f07a";
  }
  .fa-file-invoice:before {
   content: "\f570";
  }
  .align-right {
   text-align: right !important;
   padding: 0 !important;
  }
  
  /* Footer styles */
  footer, header {
    background-color: #180773;
    padding: 0 0;
  }

  /* Header and Footer styles */
  .header-container, .footer-container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 39px 15px;
    /* Обновленные стили для header и footer */
    margin-top: 0px; /* Добавлен отступ сверху */
    }
  .header-row, .footer-row {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
  }
  .header-item, .footer-item {
  flex: 1 1 auto;
  padding: 10px;
  box-sizing: border-box;
  color: #ffffff;
  text-align: center;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  height: 100%;
}

.header-item img, .footer-item img {
  color: var(--icon-color);
  max-width: 100%;
  height: auto;
  margin: 0 auto;
}

.header-item a, .footer-item a {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
  margin-bottom: 0px;
  color: #ffffff;
  text-decoration: none;
}

.header-item p, .footer-item p {
  margin: 5px 0;
}
  h1, h2, h3, h4, h5 {
    text-align: center;
  }

  
  /* Responsive styles */
  @media (min-width: 576px) {
    .header-item, .footer-item {
      flex-basis: 50%;
    }
  }
  @media (min-width: 992px) {
    .header-row, .footer-row {
      height: 100px; /* Adjust this value as needed */
    }
    .header-item, .footer-item {
      flex-basis: 25%;
    }
  }

  .row {
  display: flex;
  flex-wrap: wrap;
  margin: 0px;
}

.row > * {
  flex: 1 1 100%;
  padding: 10px;
}

/* Медиа-запрос для экранов шириной от 768px */
@media (min-width: 768px) {
  .row > * {
    flex-basis: 50%;
  }
}

/* Медиа-запрос для экранов шириной от 1024px */
@media (min-width: 1024px) {
  .row > * {
    flex-basis: 33.333%;
  }
}
body {
  background-color: var(--background-color);
  color: var(--text-color);
}

h1, h2, h3, h4, h5, h6 {
  color: var(--heading-color);
}

a {
  color: var(--link-color);
}

a:hover {
  color: var(--link-hover);
}

button, .button {
  background-color: var(--button-bg);
  color: var(--button-text);
}

input, textarea, select {
  border-color: var(--input-border);
}

input:focus, textarea:focus, select:focus {
  border-color: var(--input-focus);
}

nav {
  background-color: var(--nav-bg);
}

nav a {
  color: var(--nav-text);
}

nav a:hover {
  color: var(--nav-hover);
}
.fas {
    color: var(--icon-color);
  }
/* Обновленные стили для header и footer */
.header-container, .footer-container {
  max-width: 100%;
  padding: 0 15px;
}

.header-row, .footer-row {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
}

/* Обновленные стили для основного контента */
.container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 15px;
}

.row {
  display: flex;
  flex-wrap: wrap;
  margin: -10px;
}

.row > * {
  flex: 1 1 100%;
  padding: 10px;
}

/* Медиа-запросы для адаптивности */
@media (min-width: 768px) {
  .row > * {
    flex-basis: calc(50% - 20px);
  }
}

@media (min-width: 1024px) {
  .row > * {
    flex-basis: calc(33.333% - 20px);
  }
}

/* Дополнительные стили для изображений */
.main-image {
  max-width: 100%;
  height: auto;
  padding-left: 0;
}

.main-image img {
    max-width: 100%;
    height: auto;
    display: block;
    margin: 0 auto;
}

img {
  max-width: 100%;
  height: auto;
}

body {
  font-family: Arial, sans-serif;
  margin: 0;
  padding: 39px 0 0;
  background-color: #f8f8f8;
  color: #333;
  font-size: 16px; /* Базовый размер шрифта */
  line-height: 1.6; /* Увеличенная высота строки для лучшей читаемости */
}

h1 {
  font-size: 28px;
  margin-bottom: 20px;
}

h2 {
  font-size: 24px;
  margin-top: 30px;
  margin-bottom: 15px;
}

h3 {
  font-size: 20px;
  margin-top: 25px;
  margin-bottom: 10px;
}

p {
  margin-bottom: 15px;
}

.container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 20px; /* Увеличенные отступы по бокам */
}

nav ul li a {
  font-size: 15px; /* Немного увеличенный размер шрифта в навигации */
  padding: 12px 15px; /* Увеличенные отступы для пунктов меню */
}

.header-item p, .footer-item p {
  font-size: 14px; /* Уменьшенный размер шрифта для шапки и подвала */
}

.custom-text {
  font-size: 14px;
}

@media (max-width: 768px) {
  body {
    font-size: 15px; /* Немного уменьшенный размер шрифта для мобильных устройств */
  }

  h1 {
    font-size: 24px;
  }

  h2 {
    font-size: 20px;
  }

  h3 {
    font-size: 18px;
  }

  .container {
    padding: 0 15px;
  }
}
  /* Обновленные стили для навигации */
  nav ul li {
    position: relative;
    display: inline-block;
    margin-right: 10px; /* Уменьшено расстояние между пунктами меню */
  }

  nav ul li a {
    color: #ffffff;
    text-decoration: none;
    padding: 15px 10px; /* Увеличена вертикальная область прикосновения */
    display: block;
    font-size: 16px; /* Увеличен размер шрифта для лучшей читаемости */
  }

  nav ul ul {
    display: none;
    position: absolute;
    background-color: #3f51b5;
    top: 100%;
    left: 0;
    width: 200px; /* Увеличена ширина выпадающего меню */
    z-index: 1000;
  }

  nav ul ul li {
    display: block;
    width: 100%;
  }

  nav ul ul li a {
    padding: 12px 15px; /* Увеличена область прикосновения для подменю */
  }

  /* Стили для мобильного меню */
  @media (max-width: 768px) {
    body {
        padding: 39px 0 0;
    }

    
    .side-menu ul li a {
      padding: 15px 10px; /* Увеличена область прикосновения для мобильного меню */
      font-size: 16px; /* Увеличен размер шрифта */
    }

        .side-menu ul ul li a {
     padding: 8px 15px 8px 30px; /* Уменьшенные отступы для подменю в мобильной версии */
     font-size: 14px;
     border-bottom: 1px solid rgba(255, 255, 255, 0.05);
    }
  }

  /* Дополнительные стили для улучшения доступности */
  nav ul li:hover > a,
  nav ul li:focus-within > a,
  .side-menu ul li:hover > a,
  .side-menu ul li:focus-within > a {
    background-color: #1a237e; /* Цвет фона при наведении/фокусе */
  }

  nav ul li:hover > ul,
  nav ul li:focus-within > ul,
  .side-menu ul li:hover > ul,
  .side-menu ul li:focus-within > ul {
    display: block;
  }
/* Header and Footer styles */
.header-container, .footer-container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0px 15px;
  margin-top: 39px; /* Добавлен отступ сверху */
}

/* Обновленные стили для навигации */
nav {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1000;
  background-color: var(--nav-bg);
}

body {
  padding-top: 9px; /* Добавлен отступ сверху для body */
}

@media (max-width: 768px) {
  .header-container {
    margin-top: 0; /* Убираем отступ для мобильных устройств */
  }
  
  body {
    padding-top: 0; /* Убираем отступ для body на мобильных устройствах */
  }
  
  nav {
    position: static; /* Меняем позиционирование на статическое для мобильных устройств */
  }
}
/* Header and Footer styles */
.header-container, .footer-container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0px 15px;
  margin-top: 39px; /* Добавлен отступ сверху */
}

/* Добавляем отступ снизу для header-container */
.header-container {
  margin-bottom: 1px;
}

/* Обновленные стили для основного контента */
.container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 15px;
}

/* ... existing code ... */

/* Header and Footer styles */
.header-container, .footer-container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0px 15px;
  margin-top: 39px; /* Добавлен отступ сверху */
}

/* Добавляем отступ снизу для header-container */
.header-container {
  margin-bottom: 1px;
}

/* Обновленные стили для основного контента */
.container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 15px;
}

/* Остальные стили остаются без изменений */

@media (max-width: 768px) {
  .header-container {
    margin-top: 0; /* Убираем отступ для мобильных устройств */
    margin-bottom: 1px; /* Сохраняем отступ снизу для мобильных устройств */
  }
  
  body {
    padding-top: 0; /* Убираем отступ для body на мобильных устройствах */
  }
  
  nav {
    position: static; /* Меняем позиционирование на статическое для мобильных устройств */
  }
}