/*стили для шаблона главной страницы услуг*/

@import url('https://fonts.googleapis.com/css2?family=Inter:ital,opsz,wght@0,14..32,100..900;1,14..32,100..900&family=Montserrat:ital,wght@0,100..900;1,100..900&display=swap');

:root {
    --color-accent: #0077FF;
    --color-dark: #181D23;
    --color-light: #FFFFFF;
    --base-radius: 20px;
    --sm-radius: 10px;
    --fs-h1: clamp(30.6px, calc(28.636364px + 0.613636vw), 36px);
    --fs-sm: 14px;
    --fs-shadow: clamp(50px, calc(90px + 0.272727vw), 90px);
    --color-shadow: #F9F9F9;
    --fw-shadow: 700;
    --fw-medium: 500;
    --fw-heading: 600;
    --bg-dark: #181D23;
    --bg-light: #FFFFFF;
    --mw-default: 1300px;
    --bs-line-height: 1.1;
    --padding-base: 25px;
    --gap-base: 20px;
    --color-hover: rgb(0, 119, 255,0.8);
}

h1,
h2,
h3,
h4,
h5,
h6,
p,
ul,
ol,
li,
blockquote,
.row>* {
    margin: 0;
    padding: 0;
    line-height: var(--bs-line-height);
}

.w-30 {
    width: 30%;
}

.w-40 {
    width: 40%;
}

.w-55 {
    width: 55%;
}

.w-60 {
    width: 60%;
}

.w-65 {
    width: 65%;
}

.w-70 {
    width: 70%;
}

.object-fit-cover {
    object-fit: cover;
}

/*весь основной контент страницы*/
.content-container {
    width: 100vw;
    margin-left: calc(-50vw + 50%);
    padding: 20px;
    padding-top: 40px;
}

.container {
    width: 1320px;
    margin: 0 auto;
}

/* Общий класс для всех блоков */
.block {
    margin: 0 auto;
    margin-bottom: 30px;
}

p {
    /* учитывает переносы \n как новые строки */
    white-space: pre-line;
}

/*ховер акцентного цвета*/
.bg-hover-accent:hover {
    background-color: var(--color-hover) !important;
    color: var(--color-light) !important;
}

.container.mb-5 {
    margin-bottom: 0 !important;
}

footer.mt-5 {
    margin-top: 0 !important;
}

/*обложка - первый блок*/
.cover__block {
    grid-template-columns: 577px 703px;
    gap: var(--gap-base);
}

.cover__content {
    padding: var(--padding-base);
    background-color: var(--bg-light);
    border-radius: var(--base-radius);
}

.cover__title {
    font-size: var(--fs-h1);
    font-weight: var(--fw-heading);
}

.cover__subtitle {
    font-size: 16px;
    line-height: 18px;
}

.cover__list {
    gap: var(--gap-base);
}

.cover__item-count {
    margin-bottom: 2px;
    font-size: 24px;
    line-height: 26px;
    font-weight: var(--fw-heading);
    color: #232A32;
}

.cover__item {
    max-width: 152px;
    padding: 10px;
    border: 2px solid var(--color-accent);
    border-radius: var(--sm-radius);
}

.cover__item-text {
    font-size: 16px;
    line-height: 18px;
}

.cover__images img {
    object-fit: cover;
    border-radius: var(--base-radius)
}

.services {
    padding: 0 25px;
}

.services .accordion {
    display: flex;
    flex-direction: column;
    gap: var(--gap-base);
}

.services .accordion-item {
    border: none;
    border-radius: var(--base-radius) !important;
}

.services .accordion-header {
    padding: 0;
    border-radius: var(--base-radius) !important;
}

.services .accordion-button {
    padding: 25px;
    border-radius: var(--base-radius) !important;
}

.services .accordion-header:hover {
    background-color: var(--color-accent);
}

.services .accordion-title {
    font-size: 24px;
    line-height: 26px;
    font-weight: 600;
    color: var(--MaybeBlack);
}

.services .preview-text {
    font-size: 14px;
    line-height: 16px;
    font-weight: 400;
    color: var(--ThisIsGrey);
}

.services .accordion-header:hover .accordion-title,
.services .accordion-header:hover .preview-text {
    color: var(--color-light);
}

.services .accordion-button:focus {
    box-shadow: none;
}

.services .accordion-header:hover .accordion-button {
    background-color: var(--color-accent);
}

.services .accordion-button:not(.collapsed) {
    background-color: transparent;
    box-shadow: none;
}

.services .accordion-button::after {
    background-image: url('/local/templates/cirspb_2021/svg/arrow-down--grey.svg');
    width: 35px;
    height: 35px;
    background-color: var(--SaintGrey);
    background-position: center;
    border-radius: 3px;
    transition: transform 0.5s ease-in-out;
}

/* hover (только если ЗАКРЫТ) */
.services .accordion-button.collapsed:hover::after {
    background-color: var(--color-light);
}

/* открыт */
.services .accordion-button:not(.collapsed)::after {
    background-image: url('/local/templates/cirspb_2021/svg/arrow-down--white.svg');
    background-color: var(--color-accent);
}

/* закрыт + hover */
.services .accordion-button:.collapsed:hover::after {
    background-color: var(--color-light);
}

.services .accordion-body {
    padding: 15px 25px 25px 25px;
}

.services .accordion-body li {
    padding: 20px;
    font-size: 18px;
    line-height: 21px;
    font-weight: 500;
    color: var(--ThisIsGrey);
    /*border-bottom: 1px solid var(--SaintGrey);*/
}

.accordion-body .first-item {
    font-weight: 600 !important;
}

.services .accordion-body a:hover {
    color: var(--MaybeBlack);
}


@media (max-width: 1399px) {
    .cover__block {
        display: flex !important;
        flex-direction: column;
    }
    
    .cover__title,
    .cover__subtitle {
        width: 75%;
    }
    
    .cover__list {
        justify-content: flex-start !important;
        margin-top: 15px;
    }
    
    .cover__images img {
        width: 100%
    }
}

@media (max-width: 767px) {
    :root {
        --gap-base: 15px;
        --padding-base: 20px;
    }
    .container {
        width: 100%;
        padding: 0;
    }
    
    .block {
        margin-bottom: 40px;
    }
    
    .title {
        margin-left: 0 !important;
    }
    
    .cover__title,
    .cover__subtitle {
        width: 100%;
        line-height: 1.1 !important;
    }
    
    .mobile-title {
        font-size: 20px;
    }
    
    .cover__subtitle {
        font-size: var(--fs-sm);
    }
    
    .cover__list {
        flex-wrap: wrap;
    }
    
    .cover__item {
        max-width: 132px;
    }
    
    .cover__images img {
        height: 50%;
        border-radius: var(--sm-radius);
    }
    
    .services {
        padding: 0;
    }
    
    .services .accordion-button {
        padding: 15px;
    }
    
    .services .accordion-title {
        font-size: 16px;
        line-height: 18px;
    }
    
    .services .accordion-title img {
        width: 30px;
        height: 30px;
    }
    
    .services .accordion-button::after {
        background-color: transparent;
    }
    
    .services .accordion-body {
        padding: 15px;
    }
    
    .services .accordion-body li {
        padding: 10px;
        font-size: 14px;
        line-height: 16px;
    }
}

@media (max-width: 575px) {
    .cover__list {
        width: 100%;
        justify-content: space-between !important;
        column-gap: 0;
    }
    
    .cover__item {
        max-width: 100%;
        width: 48%;
    }
    
    .cover__list .cover__item:nth-child(n+3) {
        max-width: 100%;
        width: 100%;
    }
    
    .cover__item-text {
        font-size: 10px;
    }
}