

/* Start:/local/js/airws/lazyload/lazyload.css?17619905961041*/
/*********************************************************
    Lazy loading
*********************************************************/

.lazy-loading {
    opacity: 0;
    transition: opacity 0.3s ease;
}

.lazy-loading-active {
    opacity: 0.5;
}

.lazy-loaded {
    opacity: 1;
}

.lazy-load-error {
    border: 2px dashed #ff6b6b;
}

.lazy-load-failed {
    background-color: #f8f9fa;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #6c757d;
}

.lazy-loading[data-src] {
    filter: blur(10px);
    transform: scale(1.02);
    transition: filter 0.3s ease, transform 0.3s ease;
}

.lazy-loaded[data-src] {
    filter: blur(0);
    transform: scale(1);
}

.lazy-container {
    position: relative;
    overflow: hidden;
}

.lazy-container::before {
    content: '';
    display: block;
    padding-top: 56.25%;
}

.lazy-container img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}
/* End */


/* Start:/local/js/airws/modal/modal.css?17619782103745*/
/*********************************************************
    Modals
*********************************************************/

.bx-modal {
    display: none;
    flex-direction: column;
    align-items: center;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 1000;
    overflow-x: hidden;
    overflow-y: auto;
    padding: 20px 0;
}

.bx-modal--open {
    display: flex;
}

.bx-modal-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.4);
    z-index: 1;
}

.bx-modal-content {
    margin: auto;
    max-width: calc(100% - 32px);
    flex: none;
    z-index: 2;
}

.bx-modal-header {
    font-family: var(--second-family);
    font-weight: 500;
    font-size: 35px;
    line-height: normal;
    color: var(--siniy);
    margin-bottom: 20px;
}

.bx-modal-body {
    position: relative;
    width: 484px;
    padding: 40px;
    border-radius: 8px;
    background: var(--belyy);
    max-width: 100%;
    font-size: 16px;
    line-height: 120%;
    color: var(--chernyy);
}

.bx-modal-body--small {
    width: 436px;
}

.bx-modal-body--medium {
    width: 700px;
}

.bx-modal-body--medium-lg {
    width: 689px;
}

.bx-modal-body--medium-xl {
    width: 705px;
}

.bx-modal-body--large {
    width: 910px;
}

.bx-modal-body--xlarge {
    width: 1010px;
}

.bx-modal-body--auto {
    width: auto;
}

.bx-modal-close {
    position: absolute;
    top: 40px;
    right: 40px;
    width: 24px;
    height: 24px;
    background: transparent;
    border: none;
    padding: 0;
    outline: none;
    cursor: pointer;
    z-index: 10;
}

.bx-modal-close::before,
.bx-modal-close::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    margin-right: -50%;
    width: 22px;
    height: 2px;
    background: var(--siniy);
}

.bx-modal-close::before {
    transform: translate(-50%, -50%) rotate(45deg);
}

.bx-modal-close::after {
    transform: translate(-50%, -50%) rotate(-45deg);
}

.bx-modal__title {
    font-weight: 700;
    font-size: 18px;
    line-height: 120%;
    text-align: center;
    margin: 0 0 40px;
}

body.bx-modal-open {
    overflow: hidden;
}

@keyframes modalFadeIn {
    from {
        opacity: 0;
        transform: translateY(-20px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.bx-modal--open .bx-modal-content {
    animation: modalFadeIn 0.3s ease-out;
}

.bx-modal-message {
    text-align: center;
    padding: 2rem;
    max-width: 400px;
    margin: 0 auto;
}

.bx-modal-message__header {
    margin-bottom: 1.5rem;
}

.bx-modal-message__icon {
    width: 64px;
    height: 64px;
    margin: 0 auto 1rem;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
}

.bx-modal-message__title {
    font-size: 1.5rem;
    font-weight: 600;
    margin: 0;
}

.bx-modal-message__content {
    margin-bottom: 2rem;
    line-height: 1.5;
}

.bx-modal-message__footer {
    display: flex;
    justify-content: center;
    gap: 1rem;
}

/* Темы для разных типов сообщений */
.bx-modal-message--success .bx-modal-message__icon {
    background: #d4edda;
    color: #155724;
}

.bx-modal-message--error .bx-modal-message__icon {
    background: #f8d7da;
    color: #721c24;
}

.bx-modal-message--info .bx-modal-message__icon {
    background: #d1ecf1;
    color: #0c5460;
}

.bx-modal-message--warning .bx-modal-message__icon {
    background: #fff3cd;
    color: #856404;
}
/* End */


/* Start:/local/templates/airws_solution/assets/css/reset.css?17611180197203*/
/* resset.dev • v5.0.2 */

/* # =================================================================
   # Global selectors
   # ================================================================= */

html {
    box-sizing: border-box;
    -webkit-text-size-adjust: 100%; /* Prevent adjustments of font size after orientation changes in iOS */
    word-break: normal;
    -moz-tab-size: 4;
    tab-size: 4;
}

*,
::before,
::after {
    background-repeat: no-repeat; /* Set `background-repeat: no-repeat` to all elements and pseudo elements */
    box-sizing: border-box;
}

::before,
::after {
    text-decoration: inherit; /* Inherit text-decoration and vertical align to ::before and ::after pseudo elements */
    vertical-align: inherit;
}

* {
    padding: 0; /* Reset `padding` and `margin` of all elements */
    margin: 0;
}

/* # =================================================================
   # General elements
   # ================================================================= */

hr {
    overflow: visible; /* Show the overflow in Edge and IE */
    height: 0; /* Add the correct box sizing in Firefox */
    color: inherit; /* Correct border color in Firefox. */
}

details,
main {
    display: block; /* Render the `main` element consistently in IE. */
}

summary {
    display: list-item; /* Add the correct display in all browsers */
}

small {
    font-size: 80%; /* Set font-size to 80% in `small` elements */
}

[hidden] {
    display: none; /* Add the correct display in IE */
}

abbr[title] {
    border-bottom: none; /* Remove the bottom border in Chrome 57 */
    /* Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari */
    text-decoration: underline;
    text-decoration: underline dotted;
}

a {
    background-color: transparent; /* Remove the gray background on active links in IE 10 */
}

a:active,
a:hover {
    outline-width: 0; /* Remove the outline when hovering in all browsers */
}

code,
kbd,
pre,
samp {
    font-family: monospace, monospace; /* Specify the font family of code elements */
}

pre {
    font-size: 1em; /* Correct the odd `em` font sizing in all browsers */
}

b,
strong {
    font-weight: bolder; /* Add the correct font weight in Chrome, Edge, and Safari */
}

/* https://gist.github.com/unruthless/413930 */
sub,
sup {
    font-size: 75%;
    line-height: 0;
    position: relative;
    vertical-align: baseline;
}

sub {
    bottom: -0.25em;
}

sup {
    top: -0.5em;
}

table {
    border-color: inherit; /* Correct border color in all Chrome, Edge, and Safari. */
    text-indent: 0; /* Remove text indentation in Chrome, Edge, and Safari */
}

iframe {
    border-style: none;
}

/* # =================================================================
   # Forms
   # ================================================================= */

input {
    border-radius: 0;
}

[type='number']::-webkit-inner-spin-button,
[type='number']::-webkit-outer-spin-button {
    height: auto; /* Correct the cursor style of increment and decrement buttons in Chrome */
}

[type='search'] {
    -webkit-appearance: textfield; /* Correct the odd appearance in Chrome and Safari */
    outline-offset: -2px; /* Correct the outline style in Safari */
}

[type='search']::-webkit-search-decoration {
    -webkit-appearance: none; /* Remove the inner padding in Chrome and Safari on macOS */
}

textarea {
    overflow: auto; /* Internet Explorer 11+ */
    resize: vertical; /* Specify textarea resizability */
}

button,
input,
optgroup,
select,
textarea {
    font: inherit; /* Specify font inheritance of form elements */
}

optgroup {
    font-weight: bold; /* Restore the font weight unset by the previous rule */
}

button {
    overflow: visible; /* Address `overflow` set to `hidden` in IE 8/9/10/11 */
}

button,
select {
    text-transform: none; /* Firefox 40+, Internet Explorer 11- */
}

/* Apply cursor pointer to button elements */
button,
[type='button'],
[type='reset'],
[type='submit'],
[role='button'] {
    cursor: pointer;
}

/* Remove inner padding and border in Firefox 4+ */
button::-moz-focus-inner,
[type='button']::-moz-focus-inner,
[type='reset']::-moz-focus-inner,
[type='submit']::-moz-focus-inner {
    border-style: none;
    padding: 0;
}

/* Replace focus style removed in the border reset above */
button:-moz-focusring,
[type='button']::-moz-focus-inner,
[type='reset']::-moz-focus-inner,
[type='submit']::-moz-focus-inner {
    outline: 1px dotted ButtonText;
}

button,
html [type='button'], /* Prevent a WebKit bug where (2) destroys native `audio` and `video`controls in Android 4 */
[type='reset'],
[type='submit'] {
    -webkit-appearance: button; /* Correct the inability to style clickable types in iOS */
}

/* Remove the default button styling in all browsers */
button,
input,
select,
textarea {
    background-color: transparent;
    border-style: none;
}

a:focus,
button:focus,
input:focus,
select:focus,
textarea:focus {
    outline-width: 0;
}

/* Style select like a standard input */
select {
    -moz-appearance: none; /* Firefox 36+ */
    -webkit-appearance: none; /* Chrome 41+ */
}

select::-ms-expand {
    display: none; /* Internet Explorer 11+ */
}

select::-ms-value {
    color: currentColor; /* Internet Explorer 11+ */
}

legend {
    border: 0; /* Correct `color` not being inherited in IE 8/9/10/11 */
    color: inherit; /* Correct the color inheritance from `fieldset` elements in IE */
    display: table; /* Correct the text wrapping in Edge and IE */
    max-width: 100%; /* Correct the text wrapping in Edge and IE */
    white-space: normal; /* Correct the text wrapping in Edge and IE */
    max-width: 100%; /* Correct the text wrapping in Edge 18- and IE */
}

::-webkit-file-upload-button {
    /* Correct the inability to style clickable types in iOS and Safari */
    -webkit-appearance: button;
    color: inherit;
    font: inherit; /* Change font properties to `inherit` in Chrome and Safari */
}

/* Replace pointer cursor in disabled elements */
[disabled] {
    cursor: default;
}

/* # =================================================================
   # Specify media element style
   # ================================================================= */

img {
    border-style: none; /* Remove border when inside `a` element in IE 8/9/10 */
}

/* Add the correct vertical alignment in Chrome, Firefox, and Opera */
progress {
    vertical-align: baseline;
}

/* # =================================================================
   # Accessibility
   # ================================================================= */

/* Specify the progress cursor of updating elements */
[aria-busy='true'] {
    cursor: progress;
}

/* Specify the pointer cursor of trigger elements */
[aria-controls] {
    cursor: pointer;
}

/* Specify the unstyled cursor of disabled, not-editable, or otherwise inoperable elements */
[aria-disabled='true'] {
    cursor: default;
}
/* End */


/* Start:/local/templates/airws_solution/assets/css/helpers.css?176240627727592*/
/*********************************************************
    Container
*********************************************************/

.container {
    max-width: 100%;
    width: 1600px;
    margin-left: auto;
    margin-right: auto;
    padding-left: 0;
    padding-right: 0;
}

@media (max-width: 1632px) {
    .container {
        padding-left: 16px;
        padding-right: 16px;
    }
}

@media (max-width: 767px) {
    .container {
        width: 100%;
        padding-left: 10px;
        padding-right: 10px;
    }
}
/*********************************************************
    View
*********************************************************/

@media (min-width: 1632px) {
    .visible-lg {
        display: none !important;
    }
}

@media (max-width: 1632px) {
    .hidden-lg {
        display: none !important;
    }
}

@media (min-width: 1024px) {
    .visible-md {
        display: none !important;
    }
}

@media (max-width: 1023px) {
    .hidden-md {
        display: none !important;
    }
}

@media (min-width: 768px) {
    .visible-sm {
        display: none !important;
    }
}

@media (max-width: 767px) {
    .hidden-sm {
        display: none !important;
    }
}

body {
    overflow-x: hidden;
}

.mt-15px {
    margin-top: 15px !important;
}

/*********************************************************
    Display
*********************************************************/

.d-block {
    display: block !important;
}

.d-inline {
    display: inline !important;
}

.d-inline-block {
    display: inline-block !important;
}

.d-flex {
    display: flex !important;
}

.d-grid {
    display: grid !important;
}

.d-grid-inline {
    display: inline-grid !important;
}
/*********************************************************
    Flex
*********************************************************/
.flex-rows {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    width: auto;
    -ms-flex-flow: row wrap;
    flex-flow: row wrap;
    margin-left: -10px;
    margin-right: -10px;
    box-sizing: border-box;
}

[class*="flex-cols"] {
    position: relative;
    padding-left: 10px;
    padding-right: 10px;
}

@media (max-width: 1023px) {
    .flex-rows {
        margin-left: -6px;
        margin-right: -6px;
    }

    [class*="flex-cols"] {
        padding-left: 6px;
        padding-right: 6px;
    }
}

@media (max-width: 767px) {
    .flex-rows {
        margin-left: -5px;
        margin-right: -5px;
    }

    [class*="flex-cols"] {
        padding-left: 5px;
        padding-right: 5px;
    }
}

.flex-rows .flex-cols--12 {
    -ms-flex-preferred-size: 100%;
    flex-basis: 100%;
    max-width: 100%;
}

.flex-rows .flex-cols--11 {
    -ms-flex-preferred-size: 91.66666667%;
    flex-basis: 91.66666667%;
    max-width: 91.66666667%;
}

.flex-rows .flex-cols--10 {
    -ms-flex-preferred-size: 83.33333333%;
    flex-basis: 83.33333333%;
    max-width: 83.33333333%;
}

.flex-rows .flex-cols--9 {
    -ms-flex-preferred-size: 75%;
    flex-basis: 75%;
    max-width: 75%;
}

.flex-rows .flex-cols--8 {
    -ms-flex-preferred-size: 66.66666667%;
    flex-basis: 66.66666667%;
    max-width: 66.66666667%;
}

.flex-rows .flex-cols--7 {
    -ms-flex-preferred-size: 58.33333333%;
    flex-basis: 58.33333333%;
    max-width: 58.33333333%;
}

.flex-rows .flex-cols--6 {
    -ms-flex-preferred-size: 50%;
    flex-basis: 50%;
    max-width: 50%;
}

.flex-rows .flex-cols--5 {
    -ms-flex-preferred-size: 41.66666667%;
    flex-basis: 41.66666667%;
    max-width: 41.66666667%;
}

.flex-rows .flex-cols--4 {
    -ms-flex-preferred-size: 33.33333333%;
    flex-basis: 33.33333333%;
    max-width: 33.33333333%;
}

.flex-rows .flex-cols--3 {
    -ms-flex-preferred-size: 25%;
    flex-basis: 25%;
    max-width: 25%;
}

.flex-rows .flex-cols--2 {
    -ms-flex-preferred-size: 16.66666667%;
    flex-basis: 16.66666667%;
    max-width: 16.66666667%;
}

.flex-rows .flex-cols--1 {
    -ms-flex-preferred-size: 8.33333333%;
    flex-basis: 8.33333333%;
    max-width: 8.33333333%;
}

@media (max-width: 1519px) {
    .flex-rows .flex-cols--lg-12 {
        -ms-flex-preferred-size: 100%;
        flex-basis: 100%;
        max-width: 100%;
    }

    .flex-rows .flex-cols--lg-11 {
        -ms-flex-preferred-size: 91.66666667%;
        flex-basis: 91.66666667%;
        max-width: 91.66666667%;
    }

    .flex-rows .flex-cols--lg-10 {
        -ms-flex-preferred-size: 83.33333333%;
        flex-basis: 83.33333333%;
        max-width: 83.33333333%;
    }

    .flex-rows .flex-cols--lg-9 {
        -ms-flex-preferred-size: 75%;
        flex-basis: 75%;
        max-width: 75%;
    }

    .flex-rows .flex-cols--lg-8 {
        -ms-flex-preferred-size: 66.66666667%;
        flex-basis: 66.66666667%;
        max-width: 66.66666667%;
    }

    .flex-rows .flex-cols--lg-7 {
        -ms-flex-preferred-size: 58.33333333%;
        flex-basis: 58.33333333%;
        max-width: 58.33333333%;
    }

    .flex-rows .flex-cols--lg-6 {
        -ms-flex-preferred-size: 50%;
        flex-basis: 50%;
        max-width: 50%;
    }

    .flex-rows .flex-cols--lg-5 {
        -ms-flex-preferred-size: 41.66666667%;
        flex-basis: 41.66666667%;
        max-width: 41.66666667%;
    }

    .flex-rows .flex-cols--lg-4 {
        -ms-flex-preferred-size: 33.33333333%;
        flex-basis: 33.33333333%;
        max-width: 33.33333333%;
    }

    .flex-rows .flex-cols--lg-3 {
        -ms-flex-preferred-size: 25%;
        flex-basis: 25%;
        max-width: 25%;
    }

    .flex-rows .flex-cols--lg-2 {
        -ms-flex-preferred-size: 16.66666667%;
        flex-basis: 16.66666667%;
        max-width: 16.66666667%;
    }

    .flex-rows .flex-cols--lg-1 {
        -ms-flex-preferred-size: 8.33333333%;
        flex-basis: 8.33333333%;
        max-width: 8.33333333%;
    }
}

@media (max-width: 1023px) {
    .flex-rows .flex-cols--md-8 {
        -ms-flex-preferred-size: 100%;
        flex-basis: 100%;
        max-width: 100%;
    }

    .flex-rows .flex-cols--md-7 {
        -ms-flex-preferred-size: 87.5%;
        flex-basis: 87.5%;
        max-width: 87.5%;
    }

    .flex-rows .flex-cols--md-6 {
        -ms-flex-preferred-size: 75%;
        flex-basis: 75%;
        max-width: 75%;
    }

    .flex-rows .flex-cols--md-5 {
        -ms-flex-preferred-size: 62.5%;
        flex-basis: 62.5%;
        max-width: 62.5%;
    }

    .flex-rows .flex-cols--md-4 {
        -ms-flex-preferred-size: 50%;
        flex-basis: 50%;
        max-width: 50%;
    }

    .flex-rows .flex-cols--md-3 {
        -ms-flex-preferred-size: 37.5%;
        flex-basis: 37.5%;
        max-width: 37.5%;
    }

    .flex-rows .flex-cols--md-2 {
        -ms-flex-preferred-size: 25%;
        flex-basis: 25%;
        max-width: 25%;
    }

    .flex-rows .flex-cols--md-1 {
        -ms-flex-preferred-size: 12.5%;
        flex-basis: 12.5%;
        max-width: 12.5%;
    }
}

@media (max-width: 767px) {
    .flex-rows .flex-cols--sm-6 {
        -ms-flex-preferred-size: 100%;
        flex-basis: 100%;
        max-width: 100%;
    }

    .flex-rows .flex-cols--sm-5 {
        -ms-flex-preferred-size: 83.33333333%;
        flex-basis: 83.33333333%;
        max-width: 83.33333333%;
    }

    .flex-rows .flex-cols--sm-4 {
        -ms-flex-preferred-size: 66.66666667%;
        flex-basis: 66.66666667%;
        max-width: 66.66666667%;
    }

    .flex-rows .flex-cols--sm-3 {
        -ms-flex-preferred-size: 50%;
        flex-basis: 50%;
        max-width: 50%;
    }

    .flex-rows .flex-cols--sm-2 {
        -ms-flex-preferred-size: 33.33333333%;
        flex-basis: 33.33333333%;
        max-width: 33.33333333%;
    }

    .flex-rows .flex-cols--sm-1 {
        -ms-flex-preferred-size: 16.66666667%;
        flex-basis: 16.66666667%;
        max-width: 16.66666667%;
    }
}

/*********************************************************
    Grid
*********************************************************/

/* ===== GRID TEMPLATE COLUMNS ===== */
.grid-cols-1 {
    grid-template-columns: repeat(1, minmax(0, 1fr));
}
.grid-cols-2 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}
.grid-cols-3 {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}
.grid-cols-4 {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}
.grid-cols-5 {
    grid-template-columns: repeat(5, minmax(0, 1fr));
}
.grid-cols-6 {
    grid-template-columns: repeat(6, minmax(0, 1fr));
}
.grid-cols-7 {
    grid-template-columns: repeat(7, minmax(0, 1fr));
}
.grid-cols-8 {
    grid-template-columns: repeat(8, minmax(0, 1fr));
}
.grid-cols-9 {
    grid-template-columns: repeat(9, minmax(0, 1fr));
}
.grid-cols-10 {
    grid-template-columns: repeat(10, minmax(0, 1fr));
}
.grid-cols-11 {
    grid-template-columns: repeat(11, minmax(0, 1fr));
}
.grid-cols-12 {
    grid-template-columns: repeat(12, minmax(0, 1fr));
}
.grid-cols-none {
    grid-template-columns: none;
}

/* ===== GRID TEMPLATE ROWS ===== */
.grid-rows-1 {
    grid-template-rows: repeat(1, minmax(0, 1fr));
}
.grid-rows-2 {
    grid-template-rows: repeat(2, minmax(0, 1fr));
}
.grid-rows-3 {
    grid-template-rows: repeat(3, minmax(0, 1fr));
}
.grid-rows-4 {
    grid-template-rows: repeat(4, minmax(0, 1fr));
}
.grid-rows-5 {
    grid-template-rows: repeat(5, minmax(0, 1fr));
}
.grid-rows-6 {
    grid-template-rows: repeat(6, minmax(0, 1fr));
}
.grid-rows-none {
    grid-template-rows: none;
}

/* ===== GRID ROW PLACEMENT ===== */
.row-auto {
    grid-row: auto;
}
.row-span-1 {
    grid-row: span 1 / span 1;
}
.row-span-2 {
    grid-row: span 2 / span 2;
}
.row-span-3 {
    grid-row: span 3 / span 3;
}
.row-span-4 {
    grid-row: span 4 / span 4;
}
.row-span-5 {
    grid-row: span 5 / span 5;
}
.row-span-6 {
    grid-row: span 6 / span 6;
}
.row-span-full {
    grid-row: 1 / -1;
}

.row-start-1 {
    grid-row-start: 1;
}
.row-start-2 {
    grid-row-start: 2;
}
.row-start-3 {
    grid-row-start: 3;
}
.row-start-4 {
    grid-row-start: 4;
}
.row-start-5 {
    grid-row-start: 5;
}
.row-start-6 {
    grid-row-start: 6;
}
.row-start-7 {
    grid-row-start: 7;
}
.row-start-auto {
    grid-row-start: auto;
}

.row-end-1 {
    grid-row-end: 1;
}
.row-end-2 {
    grid-row-end: 2;
}
.row-end-3 {
    grid-row-end: 3;
}
.row-end-4 {
    grid-row-end: 4;
}
.row-end-5 {
    grid-row-end: 5;
}
.row-end-6 {
    grid-row-end: 6;
}
.row-end-7 {
    grid-row-end: 7;
}
.row-end-auto {
    grid-row-end: auto;
}

/* ===== GRID COLUMN PLACEMENT ===== */
.col-auto {
    grid-column: auto;
}
.col-span-1 {
    grid-column: span 1 / span 1;
}
.col-span-2 {
    grid-column: span 2 / span 2;
}
.col-span-3 {
    grid-column: span 3 / span 3;
}
.col-span-4 {
    grid-column: span 4 / span 4;
}
.col-span-5 {
    grid-column: span 5 / span 5;
}
.col-span-6 {
    grid-column: span 6 / span 6;
}
.col-span-7 {
    grid-column: span 7 / span 7;
}
.col-span-8 {
    grid-column: span 8 / span 8;
}
.col-span-9 {
    grid-column: span 9 / span 9;
}
.col-span-10 {
    grid-column: span 10 / span 10;
}
.col-span-11 {
    grid-column: span 11 / span 11;
}
.col-span-12 {
    grid-column: span 12 / span 12;
}
.col-span-full {
    grid-column: 1 / -1;
}

.col-start-1 {
    grid-column-start: 1;
}
.col-start-2 {
    grid-column-start: 2;
}
.col-start-3 {
    grid-column-start: 3;
}
.col-start-4 {
    grid-column-start: 4;
}
.col-start-5 {
    grid-column-start: 5;
}
.col-start-6 {
    grid-column-start: 6;
}
.col-start-7 {
    grid-column-start: 7;
}
.col-start-8 {
    grid-column-start: 8;
}
.col-start-9 {
    grid-column-start: 9;
}
.col-start-10 {
    grid-column-start: 10;
}
.col-start-11 {
    grid-column-start: 11;
}
.col-start-12 {
    grid-column-start: 12;
}
.col-start-13 {
    grid-column-start: 13;
}
.col-start-auto {
    grid-column-start: auto;
}

.col-end-1 {
    grid-column-end: 1;
}
.col-end-2 {
    grid-column-end: 2;
}
.col-end-3 {
    grid-column-end: 3;
}
.col-end-4 {
    grid-column-end: 4;
}
.col-end-5 {
    grid-column-end: 5;
}
.col-end-6 {
    grid-column-end: 6;
}
.col-end-7 {
    grid-column-end: 7;
}
.col-end-8 {
    grid-column-end: 8;
}
.col-end-9 {
    grid-column-end: 9;
}
.col-end-10 {
    grid-column-end: 10;
}
.col-end-11 {
    grid-column-end: 11;
}
.col-end-12 {
    grid-column-end: 12;
}
.col-end-13 {
    grid-column-end: 13;
}
.col-end-auto {
    grid-column-end: auto;
}

/* ===== GRID AUTO FLOW ===== */
.grid-flow-row {
    grid-auto-flow: row;
}
.grid-flow-col {
    grid-auto-flow: column;
}
.grid-flow-dense {
    grid-auto-flow: dense;
}
.grid-flow-row-dense {
    grid-auto-flow: row dense;
}
.grid-flow-col-dense {
    grid-auto-flow: column dense;
}

/* ===== GRID AUTO COLUMNS ===== */
.auto-cols-auto {
    grid-auto-columns: auto;
}
.auto-cols-min {
    grid-auto-columns: min-content;
}
.auto-cols-max {
    grid-auto-columns: max-content;
}
.auto-cols-fr {
    grid-auto-columns: minmax(0, 1fr);
}

/* ===== GRID AUTO ROWS ===== */
.auto-rows-auto {
    grid-auto-rows: auto;
}
.auto-rows-min {
    grid-auto-rows: min-content;
}
.auto-rows-max {
    grid-auto-rows: max-content;
}
.auto-rows-fr {
    grid-auto-rows: minmax(0, 1fr);
}

/* ===== RESPONSIVE GRID COLUMNS ===== */

@media (max-width: 1632px) {
    .lg\:grid-cols-1 { grid-template-columns: repeat(1, minmax(0, 1fr)); }
    .lg\:grid-cols-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .lg\:grid-cols-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
    .lg\:grid-cols-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
    .lg\:grid-cols-5 { grid-template-columns: repeat(5, minmax(0, 1fr)); }
    .lg\:grid-cols-6 { grid-template-columns: repeat(6, minmax(0, 1fr)); }
    .lg\:grid-cols-7 { grid-template-columns: repeat(7, minmax(0, 1fr)); }
    .lg\:grid-cols-8 { grid-template-columns: repeat(8, minmax(0, 1fr)); }
    .lg\:grid-cols-9 { grid-template-columns: repeat(9, minmax(0, 1fr)); }
    .lg\:grid-cols-10 { grid-template-columns: repeat(10, minmax(0, 1fr)); }
    .lg\:grid-cols-11 { grid-template-columns: repeat(11, minmax(0, 1fr)); }
    .lg\:grid-cols-12 { grid-template-columns: repeat(12, minmax(0, 1fr)); }

    .lg\:col-span-1 { grid-column: span 1 / span 1; }
    .lg\:col-span-2 { grid-column: span 2 / span 2; }
    .lg\:col-span-3 { grid-column: span 3 / span 3; }
    .lg\:col-span-4 { grid-column: span 4 / span 4; }
    .lg\:col-span-5 { grid-column: span 5 / span 5; }
    .lg\:col-span-6 { grid-column: span 6 / span 6; }
    .lg\:col-span-7 { grid-column: span 7 / span 7; }
    .lg\:col-span-8 { grid-column: span 8 / span 8; }
    .lg\:col-span-9 { grid-column: span 9 / span 9; }
    .lg\:col-span-10 { grid-column: span 10 / span 10; }
    .lg\:col-span-11 { grid-column: span 11 / span 11; }
    .lg\:col-span-12 { grid-column: span 12 / span 12; }
}

@media (max-width: 1023px) {
    .md\:grid-cols-1 { grid-template-columns: repeat(1, minmax(0, 1fr)); }
    .md\:grid-cols-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .md\:grid-cols-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
    .md\:grid-cols-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
    .md\:grid-cols-5 { grid-template-columns: repeat(5, minmax(0, 1fr)); }
    .md\:grid-cols-6 { grid-template-columns: repeat(6, minmax(0, 1fr)); }
    .md\:grid-cols-7 { grid-template-columns: repeat(7, minmax(0, 1fr)); }
    .md\:grid-cols-8 { grid-template-columns: repeat(8, minmax(0, 1fr)); }
    .md\:grid-cols-9 { grid-template-columns: repeat(9, minmax(0, 1fr)); }
    .md\:grid-cols-10 { grid-template-columns: repeat(10, minmax(0, 1fr)); }
    .md\:grid-cols-11 { grid-template-columns: repeat(11, minmax(0, 1fr)); }
    .md\:grid-cols-12 { grid-template-columns: repeat(12, minmax(0, 1fr)); }

    .md\:col-span-1 { grid-column: span 1 / span 1; }
    .md\:col-span-2 { grid-column: span 2 / span 2; }
    .md\:col-span-3 { grid-column: span 3 / span 3; }
    .md\:col-span-4 { grid-column: span 4 / span 4; }
    .md\:col-span-5 { grid-column: span 5 / span 5; }
    .md\:col-span-6 { grid-column: span 6 / span 6; }
    .md\:col-span-7 { grid-column: span 7 / span 7; }
    .md\:col-span-8 { grid-column: span 8 / span 8; }
    .md\:col-span-9 { grid-column: span 9 / span 9; }
    .md\:col-span-10 { grid-column: span 10 / span 10; }
    .md\:col-span-11 { grid-column: span 11 / span 11; }
    .md\:col-span-12 { grid-column: span 12 / span 12; }
}

@media (max-width: 767px) {
    .sm\:grid-cols-1 { grid-template-columns: repeat(1, minmax(0, 1fr)); }
    .sm\:grid-cols-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .sm\:grid-cols-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
    .sm\:grid-cols-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
    .sm\:grid-cols-5 { grid-template-columns: repeat(5, minmax(0, 1fr)); }
    .sm\:grid-cols-6 { grid-template-columns: repeat(6, minmax(0, 1fr)); }
    .sm\:grid-cols-7 { grid-template-columns: repeat(7, minmax(0, 1fr)); }
    .sm\:grid-cols-8 { grid-template-columns: repeat(8, minmax(0, 1fr)); }
    .sm\:grid-cols-9 { grid-template-columns: repeat(9, minmax(0, 1fr)); }
    .sm\:grid-cols-10 { grid-template-columns: repeat(10, minmax(0, 1fr)); }
    .sm\:grid-cols-11 { grid-template-columns: repeat(11, minmax(0, 1fr)); }
    .sm\:grid-cols-12 { grid-template-columns: repeat(12, minmax(0, 1fr)); }

    .sm\:col-span-1 { grid-column: span 1 / span 1; }
    .sm\:col-span-2 { grid-column: span 2 / span 2; }
    .sm\:col-span-3 { grid-column: span 3 / span 3; }
    .sm\:col-span-4 { grid-column: span 4 / span 4; }
    .sm\:col-span-5 { grid-column: span 5 / span 5; }
    .sm\:col-span-6 { grid-column: span 6 / span 6; }
    .sm\:col-span-7 { grid-column: span 7 / span 7; }
    .sm\:col-span-8 { grid-column: span 8 / span 8; }
    .sm\:col-span-9 { grid-column: span 9 / span 9; }
    .sm\:col-span-10 { grid-column: span 10 / span 10; }
    .sm\:col-span-11 { grid-column: span 11 / span 11; }
    .sm\:col-span-12 { grid-column: span 12 / span 12; }
}

/* ===== COMMON GRID PATTERNS ===== */
.grid-auto-fit {
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
}

.grid-auto-fill {
    grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
}

.grid-sidebar {
    grid-template-columns: 250px 1fr;
}

.grid-sidebar-right {
    grid-template-columns: 1fr 250px;
}

.grid-three-column {
    grid-template-columns: 250px 1fr 250px;
}

.grid-hero {
    grid-template-columns: 1fr;
    grid-template-rows: auto 1fr auto;
}

.grid-card {
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
}

.grid-masonry {
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    grid-auto-rows: 10px;
}

/* ===== GRID AREAS ===== */
.grid-areas-header-main {
    grid-template-areas:
        "header header header"
        "main main main"
        "footer footer footer";
}

.grid-areas-sidebar {
    grid-template-areas:
        "sidebar main main"
        "sidebar main main"
        "footer footer footer";
}

.area-header { grid-area: header; }
.area-sidebar { grid-area: sidebar; }
.area-main { grid-area: main; }
.area-footer { grid-area: footer; }

/* ===== GRID DEBUGGING ===== */
.grid-debug * {
    outline: 1px solid red;
    background-color: rgba(255, 0, 0, 0.1);
}

.grid-debug > *::before {
    content: attr(class);
    position: absolute;
    top: 0;
    left: 0;
    background: rgba(0, 0, 0, 0.8);
    color: white;
    padding: 2px 4px;
    font-size: 10px;
    z-index: 1000;
}

/* ===== GRID MINIMAL ===== */
.grid-minimal {
    display: grid;
    gap: 1rem;
}

.grid-minimal-2 {
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
}

.grid-minimal-3 {
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
}

/* ===== GRID LAYOUTS ===== */
.grid-layout-centered {
    display: grid;
    place-items: center;
    min-height: 100vh;
}

.grid-layout-stacked {
    display: grid;
    grid-template-areas: "stack";
}

.grid-layout-stacked > * {
    grid-area: stack;
}

.grid-layout-holy-grail {
    display: grid;
    grid-template:
        "header header header" auto
        "nav main aside" 1fr
        "footer footer footer" auto
        / 200px 1fr 200px;
}

/*********************************************************
    Flex and Grid
*********************************************************/

.gap-00 {
    gap: 0 !important;
}
.gap-10 {
    gap: 10px !important;
}
.gap-16 {
    gap: 16px !important;
}
.gap-20 {
    gap: 20px !important;
}
.gap-30 {
    gap: 30px !important;
}

/* Column Gap */
.gap-x-00 {
    column-gap: 0 !important;
}
.gap-x-10 {
    column-gap: 10px !important;
}
.gap-x-16 {
    column-gap: 16px !important;
}
.gap-x-20 {
    column-gap: 20px !important;
}
.gap-x-30 {
    column-gap: 30px !important;
}
.gap-x-40 {
    column-gap: 40px !important;
}

/* Row Gap */
.gap-y-00 {
    row-gap: 0 !important;
}
.gap-y-10 {
    row-gap: 10px !important;
}
.gap-y-16 {
    row-gap: 16px !important;
}
.gap-y-20 {
    row-gap: 20px !important;
}
.gap-y-30 {
    row-gap: 30px !important;
}
.gap-y-40 {
    row-gap: 40px !important;
}

@media (max-width: 767px) {
    .gap-sm-00 {
        gap: 0 !important;
    }
    .gap-sm-10 {
        gap: 10px !important;
    }
    .gap-sm-16 {
        gap: 16px !important;
    }
    .gap-sm-20 {
        gap: 20px !important;
    }
    .gap-sm-30 {
        gap: 30px !important;
    }
    .gap-sm-40 {
        gap: 40px !important;
    }
    /* Column Gap */
    .gap-sm-x-00 {
        column-gap: 0 !important;
    }
    .gap-sm-x-10 {
        column-gap: 10px !important;
    }
    .gap-sm-x-16 {
        column-gap: 16px !important;
    }
    .gap-sm-x-20 {
        column-gap: 20px !important;
    }
    .gap-sm-x-30 {
        column-gap: 30px !important;
    }
    .gap-sm-x-40 {
        column-gap: 40px !important;
    }

    /* Row Gap */
    .gap-sm-y-00 {
        row-gap: 0 !important;
    }
    .gap-sm-y-40 {
        row-gap: 10px !important;
    }
    .gap-sm-y-16 {
        row-gap: 16px !important;
    }
    .gap-sm-y-20 {
        row-gap: 20px !important;
    }
    .gap-sm-y-30 {
        row-gap: 30px !important;
    }
    .gap-sm-y-40 {
        row-gap: 40px !important;
    }
}

/* ===== JUSTIFY ITEMS ===== */
.justify-items-start {
    justify-items: start;
}
.justify-items-end {
    justify-items: end;
}
.justify-items-center {
    justify-items: center;
}
.justify-items-stretch {
    justify-items: stretch;
}

/* ===== ALIGN ITEMS ===== */
.items-start {
    align-items: start;
}
.items-end {
    align-items: end;
}
.items-center {
    align-items: center;
}
.items-stretch {
    align-items: stretch;
}
.items-baseline {
    align-items: baseline;
}

/* ===== JUSTIFY CONTENT ===== */
.justify-start {
    justify-content: start;
}
.justify-end {
    justify-content: end;
}
.justify-center {
    justify-content: center;
}
.justify-between {
    justify-content: space-between;
}
.justify-around {
    justify-content: space-around;
}
.justify-evenly {
    justify-content: space-evenly;
}
.justify-stretch {
    justify-content: stretch;
}

/* ===== ALIGN CONTENT ===== */
.content-start {
    align-content: start;
}
.content-end {
    align-content: end;
}
.content-center {
    align-content: center;
}
.content-between {
    align-content: space-between;
}
.content-around {
    align-content: space-around;
}
.content-evenly {
    align-content: space-evenly;
}
.content-stretch {
    align-content: stretch;
}

/* ===== JUSTIFY SELF ===== */
.justify-self-auto {
    justify-self: auto;
}
.justify-self-start {
    justify-self: start;
}
.justify-self-end {
    justify-self: end;
}
.justify-self-center {
    justify-self: center;
}
.justify-self-stretch {
    justify-self: stretch;
}

/* ===== ALIGN SELF ===== */
.self-auto {
    align-self: auto;
}
.self-start {
    align-self: start;
}
.self-end {
    align-self: end;
}
.self-center {
    align-self: center;
}
.self-stretch {
    align-self: stretch;
}
.self-baseline {
    align-self: baseline;
}

/* ===== WRAP ===== */
.flex-wrap {
    flex-wrap: wrap;
}
.flex-nowrap {
    flex-wrap: nowrap;
}

/*********************************************************
    Text align
*********************************************************/

.text-start {
    text-align: left !important;
}

.text-end {
    text-align: right !important;
}

.text-middle {
    text-align: center !important;
}

/*********************************************************
    Line height
*********************************************************/

.lh-10 {
    line-height: 1 !important;
}

.lh-11 {
    line-height: 1.1 !important;
}

.lh-12 {
    line-height: 1.2 !important;
}

.lh-13 {
    line-height: 1.3 !important;
}

.lh-14 {
    line-height: 1.4 !important;
}

/*********************************************************
    Width
*********************************************************/

.w-25 {
    width: 25% !important;
}

@media (max-width: 767px) {
    .w-sm-25 {
        width: 25% !important;
    }
}

.w-50 {
    width: 50% !important;
}

@media (max-width: 767px) {
    .w-sm-50 {
        width: 50% !important;
    }
}

.w-75 {
    width: 75% !important;
}

@media (max-width: 767px) {
    .w-sm-75 {
        width: 75% !important;
    }
}

.w-100 {
    width: 100% !important;
}

@media (max-width: 767px) {
    .w-sm-100 {
        width: 100% !important;
    }
}

.w-auto {
    width: auto !important;
}

@media (max-width: 767px) {
    .w-auto {
        width: auto !important;
    }
}

.mw-100 {
    max-width: 100% !important;
}

@media (max-width: 767px) {
    .mw-sm-100 {
        max-width: 100% !important;
    }
}

.vw-100 {
    width: 100vw !important;
}

@media (max-width: 767px) {
    .vw-sm-100 {
        max-width: 100vw !important;
    }
}

.min-vw-100 {
    min-width: 100vw !important;
}

.h-25 {
    height: 25% !important;
}

.h-50 {
    height: 50% !important;
}

.h-75 {
    height: 75% !important;
}

.h-100 {
    height: 100% !important;
}

.h-auto {
    height: auto !important;
}

.mh-100 {
    max-height: 100% !important;
}

.vh-100 {
    height: 100vh !important;
}

.min-vh-100 {
    min-height: 100vh !important;
}

/*********************************************************
    Position
*********************************************************/

.position-relative {
    position: relative !important;
}

.position-absolute {
    position: absolute !important;
}

/* End */


/* Start:/local/templates/airws_solution/themes/default/variables.css?17624034332083*/
:root {
    --color-primary: #2c3e50;
    --color-secondary: #3498db;
    --color-accent: #e74c3c;
    --color-light: #ecf0f1;
    --color-dark: #2c3e50;
    --color-gray: #95a5a6;
    --color-border: #bdc3c7;

    --chernyy: #000;
    --temnyy-seryy: #4d4d4d;
    --belyy: #fff;
    --siniy: #5b7fff;
    --seryy: #888;
    --svetloseryy: #d1d1d1;
    --zelenyy: #7ac74f;
    --zheltyy: #ffc857;
    --ochen-svetlyy-seryy: #f4f4f4;
    --siniy2: #274cd5;
    --biryuza: #26a3e3;
    --krasnyy: #e7362d;
    --zelenyy-temnyy: #779d1b;
    --sredneseryy: #efefef;
    --zheltyy-2: #ffdf9e;
    --korichnevyy: #79560a;
    --filtry: #f3f5ff;
    --sero-goluboy: #f3f5ff;
    --fiolteovy: #9747ff;
    --rozovyy: #fff6f6;
    --oranzhevyy: #fe995b;

    --font-family: "Noto Sans", sans-serif;
    --second-family: "Inter", sans-serif;
    --third-family: "SF UI Display", sans-serif;

    /* Typography */
    --font-size-xs: 0.75rem; /* 12px */
    --font-size-sm: 0.875rem; /* 14px */
    --font-size-base: 1rem; /* 16px */
    --font-size-lg: 1.125rem; /* 18px */
    --font-size-xl: 1.25rem; /* 20px */
    --font-size-2xl: 1.5rem; /* 24px */
    --font-size-3xl: 1.875rem; /* 30px */

    /* Spacing */
    --space-xs: 0.25rem; /* 4px */
    --space-sm: 0.5rem; /* 8px */
    --space-md: 1rem; /* 16px */
    --space-lg: 1.5rem; /* 24px */
    --space-xl: 2rem; /* 32px */
    --space-2xl: 3rem; /* 48px */

    /* Borders */
    --border-radius: 0.375rem;
    --border-radius-sm: 0.25rem;
    --border-radius-lg: 0.5rem;
    --border-radius-xl: 1rem;

    /* Shadows */
    --shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
    --shadow: 0 1px 3px 0 rgba(0, 0, 0, 0.1), 0 1px 2px 0 rgba(0, 0, 0, 0.06);
    --shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
    --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);

    /* Transitions */
    --transition: all 0.3s ease;
    --transition-fast: all 0.15s ease;
    --transition-slow: all 0.3s ease;
}
/* End */


/* Start:/local/templates/airws_solution/assets/css/main.css?17625235826076*/
body, html {
    height: 100%;
    font-size: 14px;
    line-height: normal;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    box-sizing: border-box;
    color: var(--temnyy-seryy);
    background: #fff;
}

body {
    font-family: var(--font-family);
}

.page, body {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-direction: column;
    flex-direction: column;
    position: relative
}

.page, .main {
    -webkit-box-flex: 1;
    -ms-flex: 1 0 auto;
    flex: 1 0 auto;
    -ms-flex-negative: 0;
    flex-shrink: 0
}

.page:not(.page--has-banner) .main {
    padding: 20px 0 80px;
}

.main {
    padding-top: 37px;
}

/*********************************************************
    Typography
*********************************************************/

.page-title {
    margin-bottom: 40px;
}

p {
    margin: 27px 0;
}

b, strong {
    font-weight: 600;
}

/*********************************************************
    Titles
*********************************************************/

h1, .h1 {
    font-family: var(--font-family);
    font-weight: 500;
    font-size: 55px;
    line-height: 1.49;
    color: var(--chernyy);
}

h2, .h2 {
    font-family: var(--font-family);
    font-weight: 500;
    font-size: 35px;
    color: var(--chernyy);
}

h3, .h3 {
    font-family: var(--font-family);
    font-weight: 900;
    font-size: 24px;
    line-height: 120%;
}

h4, .h4 {
    font-family: var(--font-family);
    font-weight: 900;
    font-size: 20px;
    line-height: 120%;
}

h5, .h5 {
    font-family: var(--font-family);
    font-weight: 900;
    font-size: 16px;
    line-height: 120%;
}

/*********************************************************
    Links
*********************************************************/

a {
    text-decoration: none;
    color: var(--siniy);
}

a:hover {
    text-decoration-skip-ink: none;
    text-decoration: none;
}

/*********************************************************
    Buttons
*********************************************************/

.btn {
    border-radius: 8px;
    padding: 10px 20px;
    border: none;
    font-weight: 500;
    font-size: 16px;
    text-align: center;
    text-decoration: none;
    cursor: pointer;
    transition: all 0.3s ease;
    position: relative;
    overflow: hidden;
    outline: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
}

.btn svg {
    transition: .3s ease all;
}

.btn[aria-disabled], .btn[disabled], .btn.btn-disabled {
    pointer-events: none;
}

.btn[aria-disabled]:after, .btn[disabled]:after, .btn.btn-disabled:after {
    display: none;
}

/*********************************************************
    Button effect: fill
*********************************************************/

.btn-fill {
    position: relative;
    z-index: 1;
}

.btn-fill::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 0%;
    height: 100%;
    transition: all 0.5s;
    z-index: -1;
}

.btn-fill:hover {

}

.btn-fill:hover::before {
    width: 100%;
}

.btn-wave {
    overflow: hidden;
}

/*********************************************************
    Button effect: wave
*********************************************************/

.btn-wave span {
    position: relative;
    z-index: 1;
}

.btn-wave::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    width: 5px;
    height: 5px;
    opacity: 0;
    border-radius: 100%;
    transform: scale(1, 1) translate(-50%);
    transform-origin: 50% 50%;
}

.btn-wave:hover::after {
    animation: ripple 1s ease-out;
}

@keyframes ripple {
    0% {
        transform: scale(0, 0);
        opacity: 0.5;
    }
    100% {
        transform: scale(20, 20);
        opacity: 0;
    }
}

/*********************************************************
    Button sizes
*********************************************************/

.btn-sm {
    font-weight: 400;
    font-size: 14px;
    border-radius: 4px;
    padding: 4px 16px;
}

.btn-lg {
    font-weight: 500;
    font-size: 16px;
    padding: 14px 28.5px;
}

.btn-link {
    padding: 0;
    border: none;
    gap: 15px;
    background: none;
}

/*********************************************************
    Sliders
*********************************************************/

.sliders-container {
    width: 100%;
    max-width: 1900px;
    margin: 0 auto;
    display: flex;
    gap: 20px;
    padding: 0 20px;
}

.swiper-button-next, .swiper-button-prev {
    width: 40px;
    height: 40px;
    background: white;
    border-radius: 50%;
    margin-top: -20px;
}

.swiper-button-next:after, .swiper-button-prev:after {
    font-size: 16px;
    color: var(--chernyy);
    font-weight: bold;
}

/*********************************************************
    Lazy loading
*********************************************************/

.bx-lazy-loading {
    opacity: 0;
    transition: opacity 0.3s ease;
}

.bx-lazy-loading-active {
    opacity: 0.5;
}

.bx-lazy-loaded {
    opacity: 1;
}

.bx-lazy-load-error {
}

.bx-lazy-load-failed {
    background-color: #f8f9fa;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #6c757d;
}

.bx-lazy-loading[data-src] {
    filter: blur(10px);
    transform: scale(1.02);
    transition: filter 0.3s ease, transform 0.3s ease;
}

.bx-lazy-loaded[data-src] {
    filter: blur(0);
    transform: scale(1);
}

.bx-lazy-container {
    position: relative;
    overflow: hidden;
}

.bx-lazy-container::before {
    content: '';
    display: block;
    padding-top: 56.25%;
}

.bx-lazy-container img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}
/* End */


/* Start:/local/templates/airws_solution/assets/css/header.css?17625032886806*/
.header {
    position: relative;
    z-index: 100;
}

/* Верхний блок */
.header__top {
    background-color: var(--belyy);
    padding: 10px 0;
    font-size: 14px;
    position: relative;
    z-index: 100;
    height: 53px;
    display: flex;
    align-items: center;
}

.header__top-container {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.header__nav {
    display: flex;
}

.header__nav-list {
    display: flex;
    list-style: none;
    font-weight: 400;
    font-size: 13px;
}

.header__nav-item {
    margin-right: 40px;
    position: relative;
}

.header__nav-link {
    text-decoration: none;
    fill: currentColor;
    transition: color 0.3s;
}

.header__nav-link:hover,
.header__nav-link:focus {
    color: var(--siniy);
}

.header__contacts {
    display: flex;
    align-items: center;
    font-weight: 400;
    font-size: 13px;
}

.header__city {
    margin-right: 40px;
    display: flex;
    align-items: center;
    cursor: pointer;
}

.header__city-icon {
    margin-right: 8px;
    width: 20px;
    height: 20px;
    fill: currentColor;
}

.header__city-caret {
    margin-left: 5px;
    width: 16px;
    height: 18px;
    fill: currentColor;
}

.header__contact-info {
    display: flex;
    align-items: center;
    gap: 40px;
    margin-right: 28px;
}

.header__contact-info a {
    color: currentColor;
}

.header__contact-info a:hover {
    color: var(--siniy);
}

.header__email,
.header__phone {
    display: flex;
    align-items: center;
}

.header__contact-icon {
    margin-right: 8px;
    width: 20px;
    height: 20px;
    color: var(--siniy);
}

.header__callback {
    color: var(--siniy);
    text-decoration: none;
    font-weight: 500;
    transition: border-bottom-color 0.3s;
    border-bottom: 1px solid;
}

.header__callback:hover,
.header__callback:focus {
    color: var(--siniy);
    border-color: transparent;
}

/* Средний блок */
.header__middle {
    padding: 19px 0;
    border-top: 1px solid var(--svetloseryy);
    background-color: var(--belyy);
    position: relative;
    z-index: 100;
}

.header__middle-container {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.header__logo {
    display: flex;
    align-items: center;
    font-size: 24px;
    font-weight: 700;
    color: var(--siniy);
    text-decoration: none;
}

.header__logo-icon {
    margin-right: 10px;
    max-height: 50px;
    fill: var(--color-secondary);
}

.header__search {
    display: flex;
    align-items: center;
    flex-grow: 1;
    max-width: 938px;
    margin: 0 20px;
}

.header__catalog-btn {
    height: 48px;
    padding: 12px 22px 12px 16px;
    border-radius: 8px;
    margin-right: 20px;
    font-weight: 500;
    font-size: 16px;
    gap: 12px;
}

.header__catalog-btn-icon {
    width: 24px;
    height: 24px;
    fill: var(--belyy);
}

.header__search-form {
    display: flex;
    flex-grow: 1;
    background: var(--ochen-svetlyy-seryy);
    border-radius: 8px;
    height: 48px;
}

.header__search-input {
    flex-grow: 1;
    height: 48px;
    padding: 8px 32px;
    border: 1px solid transparent;
    border-left: none;
    border-right: none;
    outline: none;
    font-family: inherit;
}

.header__search-input:focus {
    border-color: var(--siniy);
}

.header__search-btn {
    background-color: transparent;
    border: none;
    padding: 0 25px;
    border-radius: 0 8px 8px 0;
    cursor: pointer;
    height: 48px;
}

.header__search-btn-icon {
    width: 24px;
    height: 24px;
    fill: currentColor;
}

.header__actions {
    display: flex;
    align-items: center;
    gap: 20px;
}

.header__action {
    display: flex;
    flex-direction: column;
    align-items: center;
    cursor: pointer;
    transition: color 0.3s;
    text-align: center;
    min-width: 60px;
    text-decoration: none;
    color: inherit;
}

.header__action:hover,
.header__action:focus {
    color: var(--siniy);
}

.header__action-icon {
    width: 24px;
    height: 24px;
    fill: currentColor;
    stroke: currentColor;
}

.header__action-text {
    font-size: 13px;
}

.header__cart-count {
    position: absolute;
    top: -11px;
    right: 11px;
    background-color: var(--siniy);
    color: white;
    border-radius: 50%;
    width: 20px;
    height: 20px;
    font-size: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.header__action--cart {
    position: relative;
}

/* Нижний блок */
.header__bottom {
    background-color: var(--siniy);
    position: relative;
    z-index: 100;
}

.header__bottom-container {
    display: flex;
    justify-content: center;
}

.header__menu {
    display: flex;
    list-style: none;
    width: 100%;
    justify-content: space-around;
    gap: 40px;
}

.header__menu-item {
}

.header__menu-link {
    display: flex;
    color: white;
    text-decoration: none;
    font-weight: 500;
    font-size: 16px;
    padding: 17px 24px;
    transition: all 0.3s;
    white-space: nowrap;
}

.header__menu-link:hover {
    background-color: var(--belyy);
    color: var(--siniy);
}

/* Стили для меню каталога */
.catalog-menu {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background-color: white;
    display: none;
    z-index: 99;
}

.header.active .catalog-menu {
    display: block;
}

.catalog-overlay {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: var(--temnyy-seryy);
    opacity: 0.4;
    z-index: -1;
    display: none;
}

.header.active .catalog-overlay {
    display: block;
}

.catalog-container {
    margin: 0 auto;
    position: relative;
    z-index: 100;
    background-color: var(--belyy);
    padding: 32px 60px;
    border-radius: 0 0 16px 16px;
}

.catalog-columns {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 30px;
}

.catalog-column {
    display: flex;
    flex-direction: column;
}

.catalog-category {
    margin: 0 0 15px 0;
    font-size: 18px;
    font-weight: 600;
    color: currentColor;
    padding-bottom: 5px;
}

.catalog-subcategories {
    list-style: none;
    margin: 0;
    padding: 0;
}

.catalog-subcategory {
    margin-bottom: 8px;
}

.catalog-subcategory-link {
    text-decoration: none;
    color: #555;
    transition: color 0.2s;
    display: block;
    padding: 5px 0;
}

.catalog-subcategory-link:hover {
    color: #ff6b6b;
}
/* End */


/* Start:/local/templates/airws_solution/themes/default/base.css?17625249422974*/
/*********************************************************
    Buttons
*********************************************************/

/* Кнопка: дефолтный стиль */

.btn.btn-default {
    background-color: var(--siniy);
    color: var(--belyy);
}

.btn.btn-default:hover {
    background-color: var(--siniy2);
}

.btn.btn-default[aria-disabled], .btn.btn-default[disabled], .btn.btn-default.btn-disabled {
    opacity: 0.5;
}

/* Кнопка: Эффект заполнения */

.btn.btn-default.btn-fill:hover {
    background-color: var(--siniy);
}

.btn.btn-default.btn-fill:hover:before {
    background-color: var(--siniy2);
}

/* Кнопка: Эффект волны */

.btn.btn-default.btn-wave:hover {
    transition: .3s ease background-color;
    transition-delay: .4s;
}

.btn.btn-default.btn-wave:after {
    background-color: var(--siniy2);
}

/* Кнопка: с границами цветная при ховере */

.btn.btn-default-outline {
    background-color: transparent;
    color: var(--siniy);
    border: 1px solid var(--siniy);
}

.btn.btn-default-outline:hover {
    background-color: var(--siniy);
    border-color: var(--siniy);
    color: var(--belyy);
}

.btn.btn-default-outline svg {
    fill: var(--siniy);
}

.btn.btn-default-outline:hover svg {
    fill: var(--belyy);
    transition-delay: .2s;
}

.btn.btn-default-outline[aria-disabled], .btn.btn-default-outline[disabled], .btn.btn-default-outline.btn-disabled {
    opacity: 0.5;
}

/* Кнопка: Эффект заполнения */

.btn.btn-default-outline.btn-fill:hover {
    background-color: transparent;
}

.btn.btn-default-outline.btn-fill:hover:before {
    background-color: var(--siniy);
}

/* Кнопка: Эффект волны */

.btn.btn-default-outline.btn-wave:hover {
    transition: .4s ease background-color, .4s ease color;
    transition-delay: .2s;
}

.btn.btn-default-outline.btn-wave:after {
    background-color: var(--siniy);
}

/* Кнопка: с тенью */

.btn.btn-shadow {
    color: var(--temnyy-seryy);
    border: none;
    backdrop-filter: blur(12px);
    box-shadow: 0 0 20px 0 rgba(35, 51, 87, 0.1);
    background: rgba(255, 255, 255, 0.85);
}

.btn.btn-shadow:hover {
    background: rgba(91, 127, 255, 0.85);
    color: var(--belyy);
}

.btn.btn-shadow svg {
    fill: var(--temnyy-seryy);
}

.btn.btn-shadow:hover svg {
    fill: var(--belyy);
}

/* Кнопка: ссылка */

.btn.btn-link {
    color: var(--seryy);
}

.btn.btn-link svg {
    fill: var(--seryy);
}

.btn.btn-link:hover {
    color: var(--siniy);
}

.btn.btn-link:hover svg {
    fill: var(--siniy);
}

.btn.btn-link[aria-disabled], .btn.btn-link[disabled], .btn.btn-link.btn-disabled {
    color: var(--seryy);
}

.swiper-button-next, .swiper-button-prev {
    border-color:  var(--svetloseryy);
}
/* End */
/* /local/js/airws/lazyload/lazyload.css?17619905961041 */
/* /local/js/airws/modal/modal.css?17619782103745 */
/* /local/templates/airws_solution/assets/css/reset.css?17611180197203 */
/* /local/templates/airws_solution/assets/css/helpers.css?176240627727592 */
/* /local/templates/airws_solution/themes/default/variables.css?17624034332083 */
/* /local/templates/airws_solution/assets/css/main.css?17625235826076 */
/* /local/templates/airws_solution/assets/css/header.css?17625032886806 */
/* /local/templates/airws_solution/themes/default/base.css?17625249422974 */
