body {
    font-family: "Helvetica Neue", Arial, sans-serif;
}
header {
    height: 55px;
}
.navbar {
    border-bottom: 1px solid #ffffff1a;
}
.navbar-dark .navbar-nav .nav-link {
    color: #729aa8;
}
.navbar-light .navbar-nav .nav-link {
    color: #729aa8;
    padding-left: 0;
    padding-right: 0;
    margin: 0;
}
.navbar-light .navbar-nav .nav-item {
    width: 306px;
}
.header-ban {
    background-image: url('https://dev.efimchenko.ru/uploads/images/header1.jpg');
    background-size: cover;
    height: 350px;
}
.container-fluid {
    max-width: 1000px; 
    margin: 0 auto; 
    padding: 0 20px; 
    padding-top: 2px;
}
.site-logo img {
    width: 138px; 
    opacity: 0.9;
}
#header-navbar-menu {
    align-items: center; 
    font-size: 13px; 
    padding-left: 1rem;
}
.dropdown-toggle {
    border: 1px solid rgba(42, 127, 221, 0.2);
    border-radius: 3px;
    padding: 0.1rem 1rem; 
}
.dropdown-toggle::after {
    margin-left: 0.5em; 
    vertical-align: middle;
    border-top: 0.6em solid; 
    border-right: 0.3em solid transparent; 
    border-bottom: 0; 
    border-left: 0.3em solid transparent; 
    display: inline-block; 
    content: "";
}
.dropdown-menu.show {
    box-shadow: 0 5px 10px rgb(0 0 0 / 20%);
    position: absolute;
    left: -155px;
    right: 20px;
    background: white;
    z-index: 99;
    border-radius: 3px;
    border: 1px solid rgba(0, 0, 0, 0.1);
    padding: 29px;
    margin-bottom: 41px;
    font-size: 14px;
    line-height: 18px;
    width: 960px;
}
#header-image-container {
    margin: 0 auto; 
    padding-top: 75px;
}
.content {
    max-width: 1000px; 
    margin: 0 auto; 
    padding: 0 20px;
}
.promo-text {
    color: #fff;
    font-size: 33px;
    line-height: 40px;
    max-width: 780px;
    margin-bottom: 40px;
    text-align: center;
    text-shadow: 0 5px 8px #000;
}
.promo-text-info {
    color: #fff;
    opacity: .9;
    font-size: 20px;
    line-height: 33px;
    text-align: center;
    max-width: 780px;
}
.resorts-front-page {
    font-size: 14px; 
    line-height: 18px; 
    margin-top: 47px;
}
.resorts-front-page-h1 {
    margin: 10px 0 13px 0; 
    font-size: 36px; 
    color: #000;
}
.resorts-category {
    margin-bottom: 26px;
}
.resorts-front-page-title {
    color: #000;
    font-size: 18px; 
    line-height: 30px; 
    border-bottom: 1px solid rgba(0, 0, 0, 0.1); 
    margin-bottom: 22px; 
    margin-right: 20px;
}
.resorts-front-page-title.dropdown {
    color: #aaa;
}
.col-md-4.resorts {
    width: 306.66px; 
    padding-left: 0; 
    padding-right: 0;
}
.col-md-4.resorts.dropdown {
    width: 290px; 
    padding-left: 0; 
    padding-right: 0;
}
.resorts-list-title-text {
    border-bottom: 1px solid rgba(0, 0, 0, 0.1); 
    padding-bottom: 5px; 
    margin-bottom: 10px;
}
.resorts-list-title-text.dropdown {
    color: #aaa;
    width: 90%;
}
ul.list-unstyled.last-articles-links li {
    padding-left: 0;
    margin: 0;
}
ul.list-unstyled li {
    margin: 0 0 9px;
}
ul.list-unstyled li a {
    color: #729aa8;
    text-decoration: none;
    margin: 0 0 5px;
}
ul.list-unstyled li a:hover {
    color: #e28315;
}

.btn-animate {
    background-color: #4ab857;
    transition: all 0.3s ease;
    transform: translateY(0);
    font-size: 18px;
    border: none;
}
.btn-animate:hover {
    background-color: #41aa4d;
    transform: translateY(0);
}
.btn-animate:active {
    transform: translateY(4px);
}
.no-highlight:focus,
.no-highlight:active {
    background-color: #41aa4d;
    outline: none !important;
    box-shadow: none !important;
}
.publish-object-section {
  background: #e9f0fa;
  padding: 15px 0;
}
.col-sm-6.text-publish {
    padding-left: 0;
}
.publish-object-text {
    width: 90%; 
    font-size: 24px; 
    margin-top: 10px;
}
.publish-object-button {
    float: right; 
    margin-top: 25px;
}
.button-add-block {
    width: 100%; 
    height: 10px; 
    background-color: #159c26; 
    margin-top: -6px; 
    border-radius: 4px; 
}
.last-objects-h1 {
    margin-bottom: 30px; 
    margin-top: 60px; 
    font-size: 30px; 
    color: #000;
}
.col-sm-4.frame {
    margin: 0 0 20px;
}
.card-body {
    padding: 9px;
    transition: all 0.3s ease-in-out;
}
.card-body:hover {
    box-shadow: 0 5px 10px rgb(0 0 0 / 20%);
}
.card-title.overflow-text {
    margin-top: -6px;
}
.card-text-link {
    text-decoration: none; 
    font-size: 14px; 
    color: #729aa8;
}
.card-text-link:hover {
    color: #e28315;
}
.card-text-address {
    font-size: 12px; 
    line-height: 1.2; 
    color: #aaa; 
    height: 15px;
}
.card-text-cost {
    line-height: 0; 
    text-align: right; 
    padding-top: 12px; 
    font-size: 14px
}
.fixed-size-image {
  height: 80px; 
  width: 80px; 
  object-fit: cover;
}
.overflow-text {
  white-space: nowrap;
  overflow: hidden; 
  text-overflow: ellipsis; 
}
.last-articles-h1 {
    margin-bottom: 12px; 
    margin-top: 20px; 
    font-size: 30px; 
    color: #000;
}
.row.article-link {
    font-size: 14px; 
    line-height: 1.64;
}
.col-md-6.article-link {
    padding: 0 0 0 24px;
}
.asked-questions-h1 {
    margin-top: 5px; 
    margin-bottom: 15px; 
    font-size: 30px; 
    line-height: 1; 
    color: #000;
}
.asked-question-container {
    font-size: 14px; 
    line-height: 22px; 
    color: #000;
}
.col-md-6.answer-item-padding {
    padding: 0 0 0 24px;
}
.footer-item-container{
    background-color: #e9f0fa; 
    margin-bottom: 1px;
}
.row.py-2.social {
    justify-content: center; 
    align-items: center;
}
.span-social {
    font-weight: 700; 
    font-size: 16px; 
}
.social-icons a img {
    height: 36px;
}
.row.py-2.info {
    justify-content: space-between;
}
.btn.btn-primary.footer {
    padding: 8px 20px;
}
.align-items-center img {
    width: 20px; 
    top: 4px; 
    right: 10px;
}
.col-md-4.text-center.info {
    line-height: 1;
}
.footer-info-links {
    text-decoration: none; 
    font-size: 13px; 
    color: #729aa8;
}
.footer-info-links:hover {
    color: #e28315;
}
.footer-span-trade {
    font-size: 12px;
}
.white-line {
  position: absolute;
  left: 0;
  right: 0;
  width: 100%;
  height: 1px;
  color: #fff;
  border-bottom: 2px solid #fff;
  margin-top: 0;
}

@media (max-width: 768px) {
    .col-md-6.answer-item-padding {
        padding: 0 0 0 10px;
    }
    .col-md-6.article-link {
        padding: 0 0 0 10px;
    }
    .promo-text {
        font-size: 25px;
        line-height: 35px;
    }
    .promo-text-info {
        font-size: 16px;
        line-height: 26px;
    }
}
@media (max-width: 643px) {
    .resorts-front-page-h1 {
        margin: 65px 0 13px 0;
    }
}
@media (max-width: 450px) {
    .promo-text {
        font-size: 25px;
        line-height: 30px;
    }
    .promo-text-info {
        font-size: 16px;
        line-height: 20px;
    }
}
@media (max-width: 576px) {
    .fixed-size-image {
        height: 180px; 
        width: 220px; 
        object-fit: cover;
      }
}