:root {
    --color-primary: #000;

    --color-accent: #1771F1;
    --color-accent-hover: #0043A4;

    --color-success: #4BB543;
    --color-success-dark: #44A33C;

    --color-error: #ff6b6b;
    --color-error-dark: #ff4757;

    --color-black: #000;
    --color-gray: #E6E7E8;
    --color-white: #fff;
    --color-red: #f00;

    --color-light-gray: #F2F3F3;
    --color-dark-gray: #737474;

    --font-family-primary: "Montserrat", serif;
    --font-family-secondary: "Montserrat", serif;

    --font-weight-normal: 400;
    --font-weight-bold: 500;

    --line-height-normal: 1.75;

    --border-radius: 4px;

    --spacing-lg: 60px;
    --spacing-md: 30px;
    --spacing-sm: 15px;

    --container-padding-top: var(--spacing-lg);
    --container-padding-bottom: var(--spacing-lg);

    --container-width: 1600px;
}

* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

body {
    font-family: var(--font-family-primary);
    font-weight: var(--font-weight-normal);
    font-style: normal;
    font-size: 16px;
    color: var(--color-primary);
    background-color: var(--color-white);
    line-height: var(--line-height-normal);
}

h1,h2,h3 {
    font-weight: var(--font-weight-bold);
    color: var(--color-primary);
}

h1,h2,h3 {
    line-height: 1.5;
}

b {
    font-weight: var(--font-weight-bold);
}

.container {
    max-width: var(--container-width);
    margin: 0 auto;
    padding: 0 15px;
}

.btn {
    text-decoration: none;
    display: inline-block;
    border-radius: var(--border-radius);
    color: var(--color-white);
    background: var(--color-accent);
    border: 1px solid var(--color-accent);
    padding: 7px 20px;
    transition: .2s linear;
    font: inherit;
    font-size: 1rem;
    font-weight: var(--font-weight-normal);
    line-height: var(--line-height-normal);
    cursor: pointer;
}

.btn:hover {
    background: var(--color-accent-hover);
    border: 1px solid var(--color-accent-hover);
}

.btn-gray {
    color: var(--color-primary);
    background: var(--color-light-gray);
    border: 1px solid var(--color-light-gray);
}

.btn-gray:hover {
    background: var(--color-gray);
    border: 1px solid var(--color-gray);
}

.btn-primary {
    color: var(--color-white);
    background-color: var(--color-primary);
}

.link {
    color: var(--color-accent);
    text-decoration: underline;
}

.link:hover {
    color: var(--color-accent-hover);
}

.input-group {
    width: 100%;
}

.input-group + .input-group {
    padding-top: var(--spacing-md);
}

.password-input-group {
    position: relative;
}

.password-visibility-btn {
    position: absolute;
    top: 13px;
    right: 10px;
    user-select: none;
    cursor: pointer;
}

.closed-eye-icon,
.opened-eye-icon {
    fill: var(--color-dark-gray);
    color: var(--color-dark-gray);
    width: 20px;
    height: 20px;
}

.closed-eye-icon:hover,
.opened-eye-icon:hover {
    opacity: 0.6;
}

.opened-eye-icon {
    margin-top: 2px;
    display: block;
}

.closed-eye-icon {
    margin-top: 0;
    display: none;
}

.show-password .opened-eye-icon {
    display: none;
}

.show-password .closed-eye-icon {
    display: block;
}

.password-help {
    font-size: 0.8rem;
    color: var(--color-dark-gray);
}

.form-control {
    font-family: var(--font-family-primary);
    width: 100%;
    padding: 10px 20px;
    font-size: 1rem;
    border: 1px solid var(--color-dark-gray);
    border-radius: var(--border-radius);
    outline: none;
    transition: border-color 0.5s, box-shadow 0.3s;
}

.form-control:focus {
    border: 1px solid var(--color-accent)!important;
}

.form-control:focus::placeholder {
    opacity: 0;
}

.is-invalid {
    border: 1px solid var(--color-red)!important;
}

.form-control-errors {
    list-style-type: none;
    margin: 0;
    padding: 0;
    font-size: 0.8rem;
    color: var(--color-red);
}

.hidden {
    display: none;
}

.page-header {
    padding-top: var(--spacing-lg);
    text-align: center;
    text-transform: uppercase;
}

.page-header-with-description {
    padding-top: var(--container-padding-top);
    padding-bottom: var(--container-padding-bottom);
    text-align: center;
    color: var(--color-white);
    background-color: var(--color-accent);
}

.page-header-with-description__header {
    padding: var(--spacing-sm);
    color: var(--color-white);
    font-family: var(--font-family-secondary);
    font-size: 3rem;
    font-weight: 600;
}

.page-header-with-description__text {
    padding: var(--spacing-sm);
    font-size: 1.4rem;
}

@media (max-width: 800px) {
    .page-header-with-description__header {
        font-size: 2.2rem;
    }

    .page-header-with-description__text {
        font-size: 1.2rem;
    }
}


/** Заголовок сайта */

header {
    background-color: var(--color-white);
    position: sticky;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 2;
    padding: 15px 0;
    box-shadow: 0 6px 14px #0000001a;
}

.header-menu {
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 100%;
    text-transform: uppercase;
}

.header-logo {
    display: flex;
    align-items: center;
    font-family: var(--font-family-secondary);
}

.header-logo__link {
    text-decoration: none;
    line-height: 1;
    text-wrap: nowrap;
}

.header-logo__img {
    height: 40px;
}

.header-logo__name {
    font-size: 1.8rem;
    font-weight: var(--font-weight-bold);
    color: var(--color-primary);
}

.header-menu__list {
    list-style-type: none;
    margin: 0;
    padding: 0;
}

.header-menu__item {
    display: inline-block;
}

.header-menu__link {
    text-decoration: none;
    display: flex;
    width: 100%;
    color: var(--color-primary);
    border-radius: var(--border-radius);
    font-weight: var(--font-weight-normal);
    padding: 5px 10px;
}

.header-menu__link:hover {
    color: var(--color-accent);
}

.header-menu__link-accent {
    color: var(--color-white);
}

.header-menu__link-accent:hover {
    color: var(--color-white);
}

.header-menu__rotate-icon-chevron-down {
    display: inline-block;
    width: 12px;
    height: 12px;
    margin-left: 5px;
    margin-top: 6px;
    fill: var(--color-primary);
    transition: transform 0.5s ease;
}

.header-menu__link:hover .header-menu__rotate-icon-chevron-down {
    fill: var(--color-accent);
    transform: rotate(180deg); /* Поворот на 180 градусов */
}

.header-menu__dropdown {
    position: relative;
}

.header-menu__dropdown-content {
    display: none;
    position: absolute;
    flex-direction: column;
    background-color: var(--color-white);
    border-radius: var(--border-radius);
    box-shadow: 0 0 10px 4px rgba(0, 0, 0, 0.1);
    z-index: 1;
    padding: 10px 0;
}

.header-menu__dropdown-content-min-width {
    min-width: 350px;
}

.header-menu__dropdown-content-item {
    padding: 5px 10px;
}

.header-menu__dropdown:hover .header-menu__dropdown-content {
    display: flex;
}

.menu-toggle {
    display: none;
    font-size: 36px;
    background: none;
    color: var(--color-primary);
    border: none;
    cursor: pointer;
}

.header-menu__icon-menu {
    width: 36px;
    height: 36px;
}

.menu-toggle:hover .header-menu__icon-menu {
    color: var(--color-accent);
}

@media (max-width: 1000px) {
    .menu-toggle {
        display: flex;
    }

    .header-menu {
        flex-wrap: wrap;
    }

    .header-menu__main {
        display: none;
        width: 100%;
        background-color: var(--color-white);
        padding: 10px 0;
        box-shadow: none;
        order: 2;
    }

    .header-menu__main.open {
        display: flex;
        flex-direction: column;
        gap: 10px;

        max-height: 100dvh;
        overflow-y: auto;
        overscroll-behavior: contain;
        -webkit-overflow-scrolling: touch;
    }

    .header-menu__dropdown:hover .header-menu__dropdown-content {
        display: none;
    }

    .header-menu__dropdown.open-dropdown .header-menu__dropdown-content {
        display: flex;
    }

    .header-menu__main .header-menu__dropdown-content {
        position: inherit;
        min-width: auto;
        box-shadow: none;
        flex-direction: column;
        padding: 10px 0;
    }
}

/** Приветствие */

.welcome {
    background-image: url("../img/welcome_background.jpg");
    background-size: cover;
    background-position: center;
    color: var(--color-white);
    text-align: center;
}

.welcome__container {
    padding-top: var(--container-padding-top);
    padding-bottom: var(--container-padding-bottom);
}

.welcome__header {
    font-family: var(--font-family-secondary);
    font-size: 2.2rem;
    padding: var(--spacing-sm);
}

.welcome__h1 {
    font-weight: 600;
    color: var(--color-white);
}

.welcome__body {
    font-size: 1.6rem;
    padding: var(--spacing-md);
}

.welcome__footer {
    padding: var(--spacing-sm);
}

.welcome__btn {
    font-size: 1.3rem;
    margin: var(--spacing-sm);
}

.welcome__second-btn {
    color: var(--color-white);
    background-color: unset;
    border: 1px solid var(--color-white);
    border-radius: var(--border-radius);
}

.welcome__second-btn:hover {
    background-color: var(--color-primary);
    border: 1px solid var(--color-white);
}

@media (max-width: 800px) {
    .welcome__header {
        font-size: 1.5rem;
        padding: 0;
    }

    .welcome__body {
        font-size: 1.4rem;
        padding: var(--spacing-md) 0;
    }

    .welcome__footer {
        padding: 0;
    }
}

@media (max-width: 600px) {
    .welcome__header {
        font-size: 1.3rem;
        padding: 0;
    }

    .welcome__body {
        font-size: 1.2rem;
        padding: var(--spacing-sm) 0;
    }
}


/** Услуги */

.services-info {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
}

.services-info__even {
    background-color: var(--color-gray);
}

.services-info__item {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: var(--spacing-md);
    padding-top: var(--container-padding-top);
    padding-bottom: var(--container-padding-bottom);
}

.services-info__text,
.services-info__image {
    display: flex;
    flex-direction: column;
    justify-content: center;
    text-align: center;
}

.services-info__text {
    width: calc(40% - (var(--spacing-md) / 2));
}

.services-info__image {
    width: calc(60% - (var(--spacing-md) / 2));
}

.services-info__image img {
    width: 100%;
}

.services-info__name {
    padding-bottom: var(--spacing-lg);
}

.services-info__description {
    text-align: left;
    padding-bottom: var(--spacing-lg);
}

@media (max-width: 800px) {
    .services-info__text,
    .services-info__image {
        width: 100%;
    }

    .services-info__image {
        order: 2;
    }
}


/** Этапы работы */

.stages-of-works {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
}

.stages-of-works__container {
    padding-top: var(--container-padding-top);
    padding-bottom: var(--container-padding-bottom);
}

.stages-of-works__header {
    text-align: center;
    padding-bottom: var(--spacing-md);
}

.stages-of-works__body {
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: var(--spacing-md);
    margin-top: var(--spacing-md);
}

.stages-of-works__item {
    display: flex;
    justify-content: space-between;
    flex: 1;
}

.stages-of-works__item-1 .stages-of-works__item-icon,
.stages-of-works__item-1 .stages-of-works__item-description {
    background-color: var(--color-gray);
}

.stages-of-works__item-2 .stages-of-works__item-icon,
.stages-of-works__item-2 .stages-of-works__item-description {
    background-color: var(--color-gray);
}

.stages-of-works__item-3 .stages-of-works__item-icon,
.stages-of-works__item-3 .stages-of-works__item-description {
    background-color: var(--color-gray);
}

.stages-of-works__item-4 .stages-of-works__item-icon,
.stages-of-works__item-4 .stages-of-works__item-description {
    background-color: var(--color-gray);
}

.stages-of-works__item-icon {
    display: flex;
    justify-content: center;
    align-items: center;
    padding: var(--spacing-md);
    border-radius: var(--border-radius) 0 0 var(--border-radius);
    flex: 1;
}

.stages-of-works__item-icon .material-symbols-outlined {
    text-align: center;
    font-size: 52px;
    font-variation-settings: 'FILL' 0, 'wght' 275, 'GRAD' 0, 'opsz' 50;
}

.stages-of-works__item-icon .stages-of-works__item-mobile-number {
    display: none;
    font-size: 2.5rem;
}

.stages-of-works__item-number {
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 2.5rem;
    padding: var(--spacing-md);
    text-align: center;
    flex: 1;
    z-index: 1;
    box-shadow: -15px 0 15px -15px rgba(0, 0, 0, 0.15), /* тень слева */ 15px 0 15px -15px rgba(0, 0, 0, 0.15); /* тень справа */
}

.stages-of-works__item-description {
    padding: var(--spacing-md);
    border-radius: 0 var(--border-radius) var(--border-radius) 0;
    flex: 8;
}

@media (max-width: 800px) {
    .stages-of-works__item-icon .material-symbols-outlined {
        display: none;
    }

    .stages-of-works__item-icon .stages-of-works__item-mobile-number {
        display: initial;
    }

    .stages-of-works__item-number {
        display: none;
    }
}


/** Готовы начать? */

.ready-to-order {
    background: var(--color-accent);
    color: var(--color-white);
}

.ready-to-order__container {
    padding-top: var(--container-padding-top);
    padding-bottom: var(--container-padding-bottom);
}

.ready-to-order__header {
    text-align: center;
    padding-bottom: var(--spacing-md);
}

.ready-to-order__h2 {
    color: var(--color-white);
}

.ready-to-order__body {
    font-size: 1.2rem;
    text-align: center;
    padding-bottom: var(--spacing-md);
}

.ready-to-order__footer {
    font-size: 1.2rem;
    text-align: center;
}

.ready-to-order__btn {
    font-size: 1.3rem;
    margin: var(--spacing-sm);
}

.ready-to-order__second-btn {
    color: var(--color-white);
    background-color: unset;
    border: 1px solid var(--color-white);
}

.ready-to-order__second-btn:hover {
    background-color: var(--color-primary);
    border: 1px solid var(--color-white);
}


/** Подвал сайта */

footer {
    background-color: var(--color-primary);
    color: var(--color-white);
}

.footer__container {
    padding-top: var(--container-padding-top);
    padding-bottom: var(--container-padding-bottom);
}

.footer__columns {
    display: flex;
    justify-content: space-between;
    gap: var(--spacing-md);
}

.footer__column {
    min-width: 200px;
}

.footer__h3 {
    margin-bottom: var(--spacing-sm);
    color: var(--color-white);
}

.footer-menu__list {
    list-style-type: none;
    margin: 0;
    padding: 0;
}

.footer-menu__item {
    padding: 5px 0;
}

.footer-menu__list a {
    text-decoration: none;
    font-size: 0.9rem;
    color: var(--color-gray);
    margin: 5px 0;
    transition: color 0.3s;
}

.footer-menu__list a:hover {
    color: var(--color-accent);
    transition: color, background-color 0.7s ease;
}

.footer__social {
    display: flex;
    gap: var(--spacing-sm);
    margin-top: var(--spacing-md);
    width: 100%;
}

.footer__social-img {
    width: 30px;
    height: 30px;
    fill: var(--color-white);
}

.footer__contacts {
    margin-top: var(--spacing-md);
    font-size: 0.9rem;
}

.footer__contacts-email + .footer__contacts-phone {
    padding-top: var(--spacing-sm);
}

.footer__contacts-link {
    color: var(--color-white);
    text-decoration: none;
    transition: color, background-color 0.7s ease;
}

.footer__contacts-link:hover {
    color: var(--color-accent);
}

.footer__row {
    font-size: 0.8rem;
    text-align: center;
    margin-top: var(--spacing-md);
}

@media (max-width: 800px) {
    .footer__columns {
        flex-direction: column;
        gap: var(--spacing-md);
    }
}


/** Портфолио - меню */

.portfolio-menu__container {
    padding-top: var(--container-padding-top);
/*  padding-bottom: var(--container-padding-bottom); */
}

.portfolio-menu__list {
    list-style-type: none;
    margin: 0;
    padding: 0;
    text-align: center;
}

.portfolio-menu__item {
    display: inline-block;
    padding: var(--spacing-sm);
}

.portfolio-menu__btn {
    padding: 7px 10px;
}


/** Портфолио - контент */

.portfolio__container {
    padding-top: var(--container-padding-top);
    padding-bottom: var(--container-padding-bottom);
}

.portfolio__service-header {
    margin-top: var(--spacing-lg);
}

.portfolio__service-example {
    margin-top: var(--spacing-md);
}

.portfolio__service-example-single {
    width: 100%;
}


/** Проекты портфолио */

.portfolio-projects__container {
    padding-top: var(--container-padding-top);
    padding-bottom: var(--container-padding-bottom);
}

.portfolio-projects__gallery {
    column-count: 3;
    column-gap: var(--spacing-sm);
}

.portfolio-projects__gallery-link {
    display: block;
    width: 100%;
    margin-bottom: var(--spacing-sm);
    break-inside: avoid;
}

.portfolio-projects__gallery-img {
    width: 100%;
    height: auto;
    display: block;
}

@media (max-width: 800px) {
    .portfolio-projects__gallery {
        column-count: 2;
    }
}


/** Контакты */

.contact-us__description {
    text-align: center;
    font-size: 1.4rem;
    padding: var(--spacing-md);
}

.contact-us__container {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    padding-top: var(--container-padding-top);
    padding-bottom: var(--container-padding-bottom);
}

.contact-us__form-block {
    width: 60%;
    background: var(--color-gray);
    padding: var(--spacing-lg);
    border-radius: var(--border-radius) 0 0 var(--border-radius);
}

.contact-us__info-block {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
    width: 40%;
    color: var(--color-white);
    background: var(--color-accent);
    padding: var(--spacing-lg);
    border-radius: 0 var(--border-radius) var(--border-radius) 0;
}

.contact-us__form {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}

.contact-us__submit {
    float: right
}

.contact-us__info-h2 {
    color: var(--color-white);
}

.contact-us__link {
    color: var(--color-white);
    text-decoration: none;
    transition: color, background-color 0.7s ease;
}

.contact-us__icons {
    display: flex;
    gap: var(--spacing-sm);
}

.contact-us__social-icon {
    width: 32px;
    height: 32px;
    fill: var(--color-white);
}

.file-uploader__drop-zone {
    border: 1px dashed var(--color-accent);
    border-radius: var(--border-radius);
    padding: var(--spacing-md);
    text-align: center;
    cursor: pointer;
    transition: all 0.3s ease;
    background: var(--color-white);
}

.file-uploader__drop-zone:hover {
    background: var(--color-light-gray);
    border-color: var(--color-accent-hover);
}

.file-uploader__drop-zone.dragover {
    background: var(--color-light-gray);
    border-color: var(--color-accent-hover);
    transform: scale(1.02);
}

.file-uploader__icon-upload {
    width: 48px;
    height: 48px;
    fill: var(--color-primary);
}

.file-uploader__list {
    text-align: left;
}

.file-uploader__item {
    display: flex;
    align-items: center;
    padding: var(--spacing-sm);
    background: var(--color-light-gray);
    border-radius: var(--border-radius);
    margin-top: var(--spacing-sm);
    animation: fadeIn 0.3s ease;
}

.file-uploader__icon-file {
    display: flex;
    padding: 5px;
}

.file-uploader__icon-remove {
    display: flex;
    color: var(--color-error);
    cursor: pointer;
    transition: color 0.3s ease;
    padding: 5px;
}

.file-uploader__icon-remove:hover {
    color: var(--color-error-dark);
}

.file-uploader__icon-svg {
    width: 28px;
    height: 28px;
}

.file-uploader__details {
    flex-grow: 1;
}

.file-uploader__name {
    font-weight: var(--font-weight-bold);
    color: #333;
}

.file-uploader__size {
    font-size: 0.9em;
    color: #666;
}

@media (max-width: 800px) {
    .contact-us__form-block,
    .contact-us__info-block {
        width: 100%;
        border-radius: unset;
    }
}

@media (max-width: 600px) {
    .contact-us__form-block,
    .contact-us__info-block {
        padding: var(--spacing-md);
    }
}


/** Авторизация */

.auth {
    background: var(--color-gray);
}

.auth__container {
    display: flex;
    justify-content: center;
    align-items: center;
    padding-top: var(--container-padding-top);
    padding-bottom: var(--container-padding-bottom);
}

.auth__inner-container {
    padding: var(--spacing-lg);
    width: 420px;
    border-radius: var(--border-radius);
    border: 1px solid var(--color-dark-gray);
    background: var(--color-white);
}

.auth__header {
    text-align: center;
    padding-bottom: var(--spacing-md);
}

.auth__body {
}

.auth__form {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}

.auth__form .input-group + .input-group {
    padding-top: 30px;
}

.auth__remember-me,
.auth__forgotten {
    margin-top: 5px;
    font-size: 0.95rem;
}

.auth__remember-me {
    float: left;
    opacity: 0.8;
}

.auth__remember-me input {
    margin-right: 3px;
}

.auth__forgotten {
    float: right;
}

.auth__btn {
    width: 100%;
}

.auth__separator {
    display: flex;
    align-items: center;
    margin-top: var(--spacing-md);
    margin-bottom: var(--spacing-md);
    color: var(--color-dark-gray);
}

.auth__separator::before,
.auth__separator::after {
    content: "";
    flex: 1;
    height: 1px;
    background: var(--color-dark-gray);
}

.auth__separator-text {
    padding: 0 12px;
    font-size: 0.875rem;
}

.auth__footer {
    text-align: center;
}

.auth__social {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}

.google-signin-button {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-sm);
    width: 100%;
    padding: 12px;
    background: var(--color-white);
    border: 1px solid #dadce0;
    border-radius: var(--border-radius);
    font-family: 'Roboto', sans-serif;
    font-size: 14px;
    color: var(--color-dark-gray);
    cursor: pointer;
    transition:
        background-color 0.3s,
        box-shadow 0.3s;
}

.google-signin-button:hover {
    background: #f8f9fa;
    box-shadow: 0 1px 3px rgba(0,0,0,0.1);
}

.google-signin-button:active {
    background: #f1f3f4;
}

.google-icon {
    width: 18px;
    height: 18px;
}

.auth__registration {
    margin-top: var(--spacing-md);
    text-align: center;
    font-size: 0.95rem;
    opacity: 0.8;
}

@media (max-width: 600px) {
    .auth__inner-container {
        padding: var(--spacing-lg);
    }
}


/** Услуги и цены - описание */

.service-description__container {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: var(--spacing-lg);
    padding-top: var(--container-padding-top);
    padding-bottom: var(--container-padding-bottom);
}

.service-description__example {
    flex-basis: calc(50% - (var(--spacing-lg) / 2));
    border-radius: var(--border-radius);
    overflow: hidden;
    text-align: center;
}

.service-description__example-single {
    width: 100%;
}

.service-description__text {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
    flex-basis: calc(50% - (var(--spacing-lg) / 2));
    text-align: justify;
}

.service-description__text h2 {
    margin-bottom: var(--spacing-sm);
}

@media (max-width: 1000px) {
    .service-description__example,
    .service-description__text {
        flex-basis: 100%;
    }
}


/** Услуги и цены - проекты */

.portfolio-projects__container {
    padding-top: var(--container-padding-top);
    padding-bottom: var(--container-padding-bottom);
}

.portfolio-projects__header {
    text-align: center;
    margin-bottom: var(--spacing-lg);
}

.portfolio-projects__body {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    gap: var(--spacing-md);
    user-select: none;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
}

.portfolio-projects__item {
    flex-basis: calc(33.333% - (var(--spacing-md) / 3 * 2));
    text-align: center;
}

.portfolio-projects__item-link {
    font-size: 1.3rem;
    color: var(--color-primary);
    text-decoration: none;
    display: block;
}

.portfolio-projects__item-link:hover {
    color: var(--color-accent);
}

.portfolio-projects__img-wrapper {
    overflow: hidden;
    display: block;
    aspect-ratio: 500 / 665;
    border-radius: var(--border-radius);
}

.portfolio-projects__item-img {
    width: 100%;
    border-radius: var(--border-radius);
    transition: transform 0.4s ease;
}

.portfolio-projects__item-img:hover {
    transform: scale(1.1);
}

.portfolio-projects__name {
    margin-top: var(--spacing-sm);
}

@media (max-width: 700px) {
    .portfolio-projects__item {
        flex-basis: 100%;
    }
}


/** Услуги и цены - преимущества */

.service-features__container {
    padding-top: var(--container-padding-top);
    padding-bottom: var(--container-padding-bottom);
}

.service-features__header {
    text-align: center;
    margin-bottom: var(--spacing-lg);
}

.service-features__body {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: var(--spacing-md);
    text-align: center;
}

.service-features__item {
    flex-basis: calc(50% - (var(--spacing-md) / 2));
    padding: var(--spacing-md);
    background: var(--color-gray);
    border-radius: var(--border-radius);
}

.service-features__icon {
    padding: var(--spacing-sm) 0;
}

.service-features__icon-svg {
    width: 70px;
    height: 70px;
}

.service-features__name {
    padding: var(--spacing-sm) 0;
}

@media (max-width: 800px) {
    .service-features__item {
        flex-basis: calc(50% - (var(--spacing-md) / 2));
    }
}

@media (max-width: 700px) {
    .service-features__item {
        flex-basis: 100%;
    }
}


/** Услуги и цены - цены */

.service-prices__container {
    padding-top: var(--container-padding-top);
    padding-bottom: var(--container-padding-bottom);
}

.service-prices__header {
    text-align: center;
    margin-bottom: var(--spacing-lg);
}

.service-prices__body {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    gap: var(--spacing-md);
    text-align: center;
}

.service-prices__plan {
    flex-basis: 33.3%;
    padding: var(--spacing-md);
    border-radius: var(--border-radius);
}

.service-prices__plan-primary {
   background: var(--color-gray);
}

.service-prices__plan-accent {
    color: var(--color-white);
    background: var(--color-accent);
}

.service-prices__plan-name {
    font-size: 1.2rem;
}

.service-prices__plan-hr {
    margin-top: var(--spacing-sm);
    margin-bottom: var(--spacing-md);
}

.service-prices__plan-price {
    font-size: 1.6rem;
    padding-bottom: var(--spacing-lg);
}

.service-prices__plan-description {
    padding-bottom: var(--spacing-md);
    height: 120px;
}

.service-prices__plan-list {
    list-style-type: none;
    margin: 0;
    padding: 0;
}

.service-prices__plan-item {
    display: flex;
    text-align: left;
}

.service-prices__plan-icon {
    width: 25px;
    min-width: 25px;
    height: 25px;
    color: var(--color-success);
    margin-right: 5px;
}

.service-prices__plan-button {
    width: 100%;
}

@media (max-width: 1000px) {
    .service-prices__plan {
        flex-basis: calc(50% - (var(--spacing-md) / 2));
    }
}

@media (max-width: 650px) {
    .service-prices__plan {
        flex-basis: 100%;
    }
}


/** Услуги и цены - примеры */

.service-examples__container {
    padding-top: var(--container-padding-top);
    padding-bottom: var(--container-padding-bottom);
}

.service-examples__header {
    text-align: center;
    margin-bottom: var(--spacing-lg);
}

.service-examples__body {
}

.service-examples__item {
    margin-top: var(--spacing-md);
}

.service-examples__example-single {
    width: 100%;
}


/** Услуги и цены - другие услуги */

.service-others {
    background: var(--color-gray);
}

.service-others__container {
    padding-top: var(--container-padding-top);
    padding-bottom: var(--container-padding-bottom);
}

.service-others__header {
    text-align: center;
    margin-bottom: var(--spacing-lg);
}

.service-others__body {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    gap: var(--spacing-lg);
    user-select: none;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
}

.service-others__service {
    width: calc(25% - var(--spacing-lg));
    text-align: center;
}

.service-others__service-link {
    font-size: 1.2rem;
    line-height: 1.25;
    color: var(--color-primary);
    text-decoration: none;
    display: block;
}

.service-others__service-link:hover {
    color: var(--color-accent);
}

.service-others__img-wrapper {
    overflow: hidden;
    display: block;
    aspect-ratio: 350 / 197;
    border-radius: var(--border-radius);
}

.service-others__service-img {
    width: 100%;
    border-radius: var(--border-radius);
    transition: transform 0.4s ease;
}

.service-others__service-img:hover {
    transform: scale(1.1);
}

.service-others__name {
    margin-top: 5px;
}

@media (max-width: 1000px) {
    .service-others__body {
        gap: var(--spacing-md);
    }

    .service-others__service {
        width: calc(25% - var(--spacing-md));
    }
}

@media (max-width: 800px) {
    .service-others__service {
        flex-basis: calc(50% - (var(--spacing-lg) / 2));
    }
}


/** Как сделать заказ? - Что Вам нужно подготовить? */

.order-preparation__container {
    padding-top: var(--container-padding-top);
    padding-bottom: var(--container-padding-bottom);
}

.order-preparation__header {
    text-align: center;
    padding-bottom: var(--spacing-lg);
}

.order-preparation__body {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
}

.order-preparation__item {
    display: flex;
    gap: var(--spacing-md);
}

.order-preparation__item-number {
    width: 50px;
}

.order-preparation__item-number-border {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 50px;
    height: 50px;
    border: 2px solid var(--color-accent);
    border-radius: 50px;
    color: var(--color-accent);
    background-color: var(--color-white);
}

.order-preparation__item-text {
}

.order-preparation__item-name {
    margin-bottom: var(--spacing-sm);
}

.order-preparation__item-list {
    list-style-type: none;
}

.order-preparation__item-list li {
    display: flex;
    align-items: start;
}

.order-preparation__item-list li::before {
    content: "—";
    flex-shrink: 0;
    margin-right: 10px;
}


/** Как сделать заказ? - Выберите способ связи */

.order-contact-methods {
    background: var(--color-gray);
}

.order-contact-methods__container {
    padding-top: var(--container-padding-top);
    padding-bottom: var(--container-padding-bottom);
}

.order-contact-methods__header {
    text-align: center;
    padding-bottom: var(--spacing-md);
}

.order-contact-methods__body {
    padding-left: calc(50px + var(--spacing-md));
}

.order-contact-methods__list {
    padding-left: 20px;
}

.order-contact-methods__list li {
    padding-bottom: 5px;
}

.order-contact-methods__buttons {
    display: flex;
    gap: var(--spacing-md);
    padding-top: var(--spacing-sm);
}

.order-contact-methods__button {
    width: 20%;
}

.order-contact-methods__btn {
    width: 100%;
    text-align: center;
}

@media (max-width: 800px) {
    .order-contact-methods__button {
        width: 50%;
    }
}

@media (max-width: 600px) {
    .order-contact-methods__body {
        padding-left: 0;
    }
}


/** Как сделать заказ? - Этапы работы */

.order-stages__container {
    padding-top: var(--container-padding-top);
    padding-bottom: var(--container-padding-bottom);
}

.order-stages__header {
    text-align: center;
    padding-bottom: var(--spacing-lg);
}

.order-stages__body {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    gap: var(--spacing-md);
}

.order-stages__item {
    flex: 0 0 calc(33.333% - var(--spacing-md));
    max-width: calc(33.333% - var(--spacing-md));
    box-sizing: border-box;
}

.order-stages__item-number {
    display: flex;
    justify-content: center;
    margin-bottom: var(--spacing-md);
}

.order-stages__item-number-border {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 80px;
    height: 80px;
    border-radius: 80px;
    font-size: 1.4rem;
    color: var(--color-white);
    background-color: var(--color-accent);
}

.order-stages__item-text {
    text-align: center;
}

.order-stages__item-name {
    margin-bottom: var(--spacing-sm);
    height: 56px;
    max-height: 56px;
}

.order-stages__item-description {

}

@media (max-width: 800px) {
    .order-stages__item {
        flex: 0 0 100%;
        max-width: 100%;
        box-sizing: border-box;
    }
}
