/*
Theme Name: prostu - 2026 
Theme URI:  
Description: The original prostu.ru  theme.
Version: 2026
Author: alisa
*/

/* CSS Document */




  /*Убрать обводку браузера*/
a.active.focus,
a.active:focus,
a.focus,
a:active.focus,
a:active:focus,
a:focus,
button.active.focus,
button.active:focus,
button.focus,
button:active.focus,
button:active:focus,
button:focus,
.btn.active.focus,
.btn.active:focus,
.btn.focus,
.btn:active.focus,
.btn:active:focus,
.btn:focus {
outline: 0!important;
outline-color: transparent!important;
outline-width: 0!important;
outline-style: none!important;
box-shadow: 0 0 0 0 rgba(0,123,255,0)!important;
}
/*Конец Убрать обводку браузера*/
:focus {
    outline-style: none;
   /* outline-width: 0px !important;  */
    outline-color: none !important;
}

               @media (min-width: 768px) {
  .site-wrapper {
   zoom: 0.8;
  }
}


 

 @media only screen and  (min-width: 2000px) { 

.lg100.w-100 {
max-width: 2000px;
    height: auto;
    margin: 0 auto;
}
}


.paddingnone {
padding-left: 0px;
padding-right: 0px;
}

.row {
margin-left: 0px;
margin-right: 0px;
}

 
:root {
    --orange: #ff4f00;
    --dark: #0e0e0e;
    --dark-2: #1a1a1a;
    --gray: #2a2a2a;
}

* { box-sizing: border-box; }

@font-face {
  font-family: 'HelveticaNeueCyr';
  src: url('/wp-content/themes/prostu-2026/fonts/HelveticaNeueCyr-Roman.otf') format('opentype');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'HelveticaNeueCyr';
  src: url('/wp-content/themes/prostu-2026/fonts/HelveticaNeueCyr-Medium.otf') format('opentype');
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'HelveticaNeueCyr';
  src: url('/wp-content/themes/prostu-2026/fonts/HelveticaNeueCyr-Bold.otf') format('opentype');
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

body {
   font-family: 'HelveticaNeueCyr', sans-serif;
    background: url(img/fon-stranic.jpg) top center repeat; 
    color: #fff;
    margin: 0;
     font-weight: 400;
}

a { text-decoration: none; color: inherit; }

.orange { color: var(--orange); }

.btn-orange {
    background: var(--orange);
    color: #fff;
    border: none;
    border-radius: 34px;
    padding: 10px 20px;
 
    font-size: 24px;
    transition: .2s;
}
.btn-orange:hover { background: #e64600; color: #fff; }


.btn-dark {
    background: #444a52;
    color: #fff;
    border: none;
    border-radius: 6px;
    padding: 10px 20px;
     display: inline-block;
    font-size: 24px;
    transition: .2s;
}
.btn-dark:hover { background: #e64600; color: #fff; }

/* HEADER */
.site-header { /*background: var(--dark)*/; position: relative; }

.container.menu {
    z-index: 1000;
    position: relative;
}

.container, .container-lg, .container-md, .container-sm, .container-xl, .container-xxl {
        max-width: 1800px;
    }
    
    
    header.sticky {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
 
 background: url(img/back.jpg) top center repeat;
 z-index: 1000;
}

.logo-mark { display: inline-flex; align-items: center; gap: 4px; }
.logo-mark img {
width: 280px;
height: auto;
}

.sticky .logo-mark img {
    width: 150px;
    height: auto;
}

.logo-pro { color: var(--orange); font-weight: 900; font-size: 22px; letter-spacing: 1px; }
.logo-studio { color: #fff; font-weight: 900; font-size: 22px; letter-spacing: 1px; }

.header-phone { color: #ff4f00; font-size: 42px; font-weight: 700; }
.header-phone i { color: var(--orange); }

.main-nav a {
    color: #fff;
    margin: 0 14px;
    font-size: 24px;
    transition: .2s;
}
.main-nav a:hover { color: var(--orange); }

.header-socials a {
    color: #fff;
    margin: 0 6px;
    font-size: 18px;
    transition: .2s;
}
.header-socials a:hover { color: var(--orange); }

.header-phone-mobile {
    color: #fff;
    display: flex;
    align-items: center;
    gap: 6px;
    font-weight: 700;
    font-size: 15px;
}
.header-phone-mobile i { color: var(--orange); }

.burger {
    background: transparent;
    border: none;
    width: 36px;
    height: 30px;
    position: relative;
    padding: 0;
    cursor: pointer;
}
.burger span {
    display: block;
    height: 3px;
    background: var(--orange);
    margin: 5px 0;
    border-radius: 2px;
    transition: .3s;
}
.burger.active span:nth-child(1) { transform: translateY(8px) rotate(45deg); }
.burger.active span:nth-child(2) { opacity: 0; }
.burger.active span:nth-child(3) { transform: translateY(-8px) rotate(-45deg); }

.mobile-menu {
    max-height: 0;
    overflow: hidden;
    transition: max-height .35s ease;
    background: var(--dark-2);
    margin: 0 -15px;
    padding: 0 20px;
}
.mobile-menu.open {
    max-height: 500px;
    padding: 15px 20px 20px;
}
.mobile-menu a {
    display: block;
    color: #fff;
    padding: 12px 0;
    border-bottom: 1px solid #2a2a2a;
    font-size: 16px;
}



.mobile-menu a.btn-orange { border: none; text-align: center; }

/* HERO SLIDER */
.hero-slider { position: relative; height: 125vh; overflow: hidden;     margin-top: -150px; }
.hero-slider .carousel-inner,
.hero-slider .carousel-item { height: 125vh; }
.hero-slider .carousel-item {
    background-size: cover;
    background-position: center;
}
.hero-slider .carousel-item::after {
    content: "";
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,.45);
}

.post-template-page-usl-php  .hero-slider .carousel-item { height: 60vh; }
.post-template-page-usl-php .hero-slider { position: relative;  height: 60vh; overflow: hidden;     margin-top: -150px; margin-bottom:60px;}


.post-template-page-67-php  .hero-slider .carousel-item { height: 60vh; }

.post-template-page-67-php .hero-slider { position: relative;  height: 60vh; overflow: hidden;     margin-top: -150px; margin-bottom:60px;}

.mb30 {
margin-bottom: 30px;
margin-top: 10px;
}

.hero-overlay {
    position: absolute;
    inset: 0;
    z-index: 5;
    display: flex;
    align-items: center;
    justify-content: center;
    pointer-events: none;
}
.hero-overlay h1 {
    font-size: 60px;
    font-weight: 900;
    color: #fff;
    text-shadow: 0 2px 12px rgba(0,0,0,.6);
    line-height: 1.15;
}

      .allpage    h1 {
            font-size: 42px;
    font-weight: 900;
    text-align: center;
    text-transform: uppercase;
          }
          
             .allpage    h2 {
            font-size: 42px;
    font-weight: 900;
    text-align: center;
    text-transform: uppercase;
    color: #ff4f00;
          }
          
        .allpage    .site-header {
    margin-bottom: 60px;
}


.post-template-page-usl-php      .site-header {
    margin-bottom:  0px;
}

.post-template-page-67-php   .site-header {
    margin-bottom:  0px;
}

.max {
 background: url(img/max.png) top center;
 width: 56px;
 height: 56px;
 display: inline-block;
}

.vk {
 background: url(img/vk.png) top center;
  width: 56px;
 height: 56px;
 display: inline-block;
}

/* SECTIONS */
.section-title {
    font-size: 42px;
    font-weight: 800;
    color: #ff4f00;
    text-transform: uppercase;
    letter-spacing: 1px;
        margin-bottom: 60px;
}

/* SERVICES */
.services-section {  
    margin-top: 30px;
}   
.service-card {
    display: block;
    position: relative;
    height: 296px;
    border-radius: 8px;
    background-size: cover;
    background-position: center;
    overflow: hidden;
    transition: transform .25s;
}
.service-card::before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(0,0,0,.85) 0%, rgba(0,0,0,.25) 60%, rgba(0,0,0,.1) 100%);
}
.service-card span {
    position: absolute;
    /*left: 12px;
    right: 12px; */
    bottom: 25px;
          Padding: 0px 20px;
    color: #fff;
    font-weight: 700;
    font-size: 20px;
    z-index: 2;
    line-height: 1.2;
    width: 100%;
    text-align: center;
    backdrop-filter: blur(6px);
    padding: 15px 0px;
}
a.service-card:hover { transform: translateY(-3px); }
a.service-card:hover::before {
    background: linear-gradient(to top, rgba(255,79,0,.85) 0%, rgba(0,0,0,.2) 100%);
}


.gallery-item img {
  border: none !important;
  width: 95%;
  height: auto;
  border-radius: 6px;
}

.usl-box h2 {
 margin: 30px 0px 60px 0px;
}

.form-back h2 {
text-align: left;
margin: 0px;
}

.form-back {
    background: url(img/back.jpg) top center repeat;
    padding: 28px;
    border-top-left-radius: 6px;
border-bottom-left-radius: 6px;
    line-height: 1.6;
    color: #fff;
    font-size: 22px;
}

span.wpcf7-list-item-label {
    font-size: 16px;
}

.wpcf7-submit {
 background: #eb6020;
 border-radius: 25px;
 color: #fff;
 padding: 5px 35px;
}

.wpcf7-text {
    width: 100%;
    background: none;
    border: none;
    border-bottom: 2px solid #fff;
    color: #fff;
}

.wpcf7-text::placeholder {
    color: #fff; /* Ваш цвет */
    opacity: 1;    /* Для Firefox, иначе цвет будет бледным */
}

/* ABOUT */
.about-section, .client-section {  }
.about-text {
   background: url(img/back.jpg) top center repeat; 
    padding: 28px;
    border-radius: 8px;
    line-height: 1.6;
    color: #fff;
    font-size: 22px;
    padding: 15%;
}

/* WHY */
.why-section {   }
.why-card {
    background: url(img/back.jpg) top center repeat;
    padding:  5%;
    border-radius: 8px;
    height: 100%;
     /* padding-bottom: 60px; */
     min-height: 200px;
}


.modal-content {
    background: url(img/back.jpg) top center repeat;
}

.modal-content .col-md-6 {
width: 100%;
}

#callbackModal .btn-close {
    filter: invert(1) grayscale(100%) brightness(200%);
    opacity: 1;
}

.why-card h5 {
    color: #fff;
    font-size: 20px;
    font-weight: 700;
    margin-bottom: 6px;
    line-height: 1.5;
    text-transform: uppercase;
}
.why-card p { color: #fff; margin: 0; font-size: 18px; }

/* CONTACT BAR */
.contact-bar {
    background: var(--dark-2);
    padding: 22px 28px;
    border-radius: 8px;
}
.contact-phone {
    color: #ff4f00;
    font-size: 48px;
    font-weight: 800;
    display: block;
}
.contact-email { color: #fff; font-size: 24px; }
.contact-address { color: #fff; font-size: 24px; margin-bottom: 30px;}

/* MAP */
.map-section iframe { display: block; filter: grayscale(.3); }



/* FOOTER */
.site-footer {
    background: url(img/back.jpg) top center repeat; 
    color: #fff;
    font-size: 24px;
}

.allpage .site-footer {
margin-top: 60px;
}

.site-footer .logo-mark img {
    width: 94%;
    height: auto;
}

.site-footer h6 {
    color: #ff4f00;
    font-weight: 700;
    margin-bottom: 24px;
 font-size: 24px;
    border-bottom: 1px solid #ff4f00;
    padding-bottom: 24px;
    width: 95%;
   
}
.site-footer a {
    display: block;
    color: #fff;
    padding: 4px 0;
    transition: .2s;
}
.site-footer a:hover { color: var(--orange); }
.footer-phone {
    color: #ff4f00 !important;
    font-size: 48px;
    font-weight: 800;
}
.footer-socials a {
    display: inline-block;
    color: #fff;
    margin-right: 10px;
    font-size: 18px;
}
.footer-bottom {
     
    color: #fff;
    font-size: 16px;
}

.footer-bottom a {
display: inline;
}

/* RESPONSIVE TUNING */
@media (max-width: 991px) {
    .header-inner { flex-wrap: wrap; }
    
    
    .about-text  {
    padding: 15px;
    /*text-align: center; */
    font-size: 18px;
    }
    
    .py-5 {
  padding-top: 1rem !important; 
     padding-bottom: 1rem !important;  
}
}
@media (max-width: 575px) {
    .service-card { height: 130px; }
    .service-card span { font-size: 15px; right: 0px; left: 0px; padding: 0px;}
    .section-title { font-size: 18px; margin-bottom: 0px;}
    
    #services {
    margin-top: 30px;
    margin-bottom: 30px;
    }
    
    .why-card h5 {
 
    font-size: 18px;
    
}

.why-section .col-md-6 {
padding: 0px;
}

.why-card {
padding: 15px;
    min-height: 120px;
}

}


   .cookie-popup {
        display: none;
        left: 0px !important;
        right: 0px !important;
        font-size: 12px !important;
        padding: 10px !important;
        width: 100%;
        position: fixed;
        z-index: 100;
        background: #fff;
        text-align: center;
        bottom: 0;
        color: #000;
            
    }

    .cookie-popup p {
        margin: 0;
        font-size: 14px;
        color: #000;
    }

    .cookie-popup button {
        margin-top: 10px;
        padding: 5px 10px;
        background-color: #ff0909;
        color: #fff;
        border: none;
        border-radius: 3px;
        cursor: pointer;
    }
    
    
    @media screen and (min-width: 480px) {
    /* Смартфоны побольше */
}
@media screen and (min-width: 768px) {
    /* Планшеты */
}
@media screen and (max-width: 1355px) {
      .header-phone {
    color: #ff4f00;
    font-size: 28px;
    font-weight: 700;
}

.btn-orange {
    font-size: 16px;
}
 

.vk, .max {
 
  width: 46px;
 height: 46px;
 background-size: cover;
}

a.logo.d-flex.align-items-center {
    width: 15%;
}

.logo-mark img {
    width: 100%;
    height: auto;
}

.hero-slider {
    position: relative;
    height: 896px;
    overflow: hidden;
    margin-top: -150px;
}
}





@media screen and (max-width: 1800px) {
  /* .aboutimg.col-lg-6 {
    width: 30%;
   }
   
   .aboutext.col-lg-6 {
      width: 70%;
   }
   
   .about-section .col-8, .client-section .col-8 {
     width: 80%;
   }   */
}

@media screen and (max-width: 1738px) {
 .footer-phone {
    font-size: 38px;
}
.about-section .col-8, .client-section .col-8 {
     width: 80%;
   } 
   
   .why-section  .col-8 {
     width: 80%;
   } 
}

@media screen and (max-width: 1550px) {
   .header-phone {
    color: #ff4f00;
    font-size: 32px;
    font-weight: 700;
}

.btn-orange {
    font-size: 18px;
}

.client-section .col-6 {
  width: 80%;
}

.site-footer {
    font-size: 20px;
}

 .footer-phone {
    font-size: 32px;
}
}

@media screen and (max-width: 1237px) {

 .footer-phone {
    font-size: 22px;
}

.site-footer {
    font-size: 18px;
}

.why-section .col-8 {
 width: 90%;
}
    .about-section .col-8, .client-section .col-8 {
        width: 90%;
    }

      .header-phone {
    color: #ff4f00;
    font-size: 22px;
    font-weight: 700;
}

.btn-orange {
    font-size: 12px;
}
 
 
 .main-nav a {
 
    font-size: 18px;
 
}

.vk, .max {
 
  width: 36px;
 height: 36px;
 background-size: cover;
}

a.logo.d-flex.align-items-center {
    width: 15%;
}

.logo-mark img {
    width: 100%;
    height: auto;
}

.hero-slider {
    position: relative;
    height: 696px;
    overflow: hidden;
    margin-top: -150px;
}
}

          @media (max-width: 768px) {
    .hero-slider, .hero-slider .carousel-inner, .hero-slider .carousel-item { height: 420px; margin-top: 0px; }
    .hero-overlay h1 { font-size: 24px; }
    
    
    .carousel-control-prev, .carousel-control-next  {
display: none;
}

a.logo.d-flex.align-items-center {
    width: 35%;
}

.logo-mark img {
    width: 100%;
    height: auto;
}


.sticky .logo-mark img {
 width: 80%;
    height: auto;
}

     .about-section .col-8, .client-section .col-8, .why-section .col-8 {
        width: 100%;
    }
    
        .aboutimg.col-lg-6 {
        width: 100%;
    }
        .aboutext.col-lg-6 {
        width: 100%;
    }
    .client-section .col-6 {
        width: 100%;
    }
    
    .contact-phone {
    font-size: 32px;

}

.contact-address {
 
    font-size: 20px;
 
}  
.btn-dark {
 
    font-size: 18px;
 
}

section#contacts {
padding-top: 0px !important;
}

.mt-5 {
    margin-top: 0rem !important;  
}
     .uslblockfooter .col-md-6 {
    padding: 0px;
     }
     
     .site-footer .logo-mark img {
    width: 100%;
    height: auto;
}

.site-footer .text-end {
    text-align: center !important;
}
}


#preloader {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: #000000; /* Цвет фона экрана загрузки */
    display: flex;
    justify-content: center;
    align-items: center;
    z-index: 9999; /* Чтобы быть выше всех элементов */
    transition: opacity 4.5s ease, visibility 4.5s;
}

.preloader-logo img {
    width: 500px; /* Размер вашего логотипа */
    animation: pulse 7.5s infinite ease-in-out; /* Эффект пульсации (опционально) */
}

 @media (max-width: 768px) {
    
    .preloader-logo img {
    width: 100%; /* Размер вашего логотипа */
  
}
     }

/* Анимация пульсации */
@keyframes pulse {
    0% { transform: scale(0.95); opacity: 0.7; }
    50% { transform: scale(1); opacity: 1; }
    100% { transform: scale(0.95); opacity: 0.7; }
}

/* Класс для скрытия */
.preloader-hidden {
    opacity: 0;
    visibility: hidden;
}