﻿@charset "UTF-8";

@keyframes fadeIn {
    0% {
        opacity: 0
    }

    to {
        opacity: 1
    }
    .b-step-itogi td.score:before {
        content: "Количество баллов"
    }
}

@keyframes mainMenuDrop {
    0% {
        opacity: 0;
        transform: translateY(-10%) scale(.99)
    }

    to {
        opacity: 1;
        transform: translateY(0) scale(1)
    }
}

.b-main-menu__close,
.b-main-menu__menu span {
    color: transparent;
    font: 0/0 a;
    text-shadow: none
}

@font-face {
    font-family: "b-rub";
    src: url(../fonts/alsrubl-arial-bold.eot);
    src: url(../fonts/alsrubl-arial-bold.eot?#iefix) format("embedded-opentype"), url(../fonts/alsrubl-arial-bold.woff2) format("woff2"), url(../fonts/alsrubl-arial-bold.woff) format("woff"), url(../fonts/alsrubl-arial-bold.svg#robotomedium_italic) format("svg");
    font-weight: 700;
    font-style: normal
}

.icons-arrow-left,
.swiper-button-prev {
    background: url(../img/sprite.svg) 0 0 no-repeat;
    width: 34.34px;
    height: 65.34px
}

.icons-arrow-right,
.swiper-button-next {
    background: url(../img/sprite.svg) 16.8333333333% 0 no-repeat;
    width: 34px;
    height: 65px
}

.icons-heart {
    background: url(../img/sprite.svg) 98.3733333333% 61.4634146341% no-repeat;
    width: 13px;
    height: 13px
}
.b-work-rating.is-active .icons-heart,
.b-work-rating.is-active .icons-heart-big,
.b-pub-stat--like.is-active i {
    filter: invert(26%) sepia(83%) saturate(3538%) hue-rotate(309deg) brightness(92%) contrast(91%)
}

.b-work-rating.is-active .b-like-icon,
.b-pub-stat--like.is-active .b-like-icon {
    filter: invert(26%) sepia(83%) saturate(3538%) hue-rotate(309deg) brightness(92%) contrast(91%)
}

.b-mini-panel__like--works.is-active .b-like-icon {
    filter: invert(26%) sepia(83%) saturate(3538%) hue-rotate(309deg) brightness(92%) contrast(91%)
}

.icons-heart-big {
    background: url(../img/sprite.svg) 0 99.6632653061% no-repeat;
    width: 22px;
    height: 22px
}

.icons-search {
    background: url(../img/sprite.svg) 95.953271028% 86.5979381443% no-repeat;
    width: 24px;
    height: 24px
}

.icons-user {
    background: url(../img/sprite.svg) 98.2488038278% 15.873015873% no-repeat;
    width: 29px;
    height: 29px
}

.icons-user-white {
    background: url(../img/sprite.svg) 98.2488038278% 31.2169312169% no-repeat;
    width: 29px;
    height: 29px
}

.icons-write {
    background: url(../img/sprite.svg) 82.5242718447% 85.8191489362% no-repeat;
    width: 32px;
    height: 30px
}

.icons-write-white {
    background: url(../img/sprite.svg) 99.6796116505% 0 no-repeat;
    width: 32px;
    height: 30px
}

.icons-next {
    background: url(../img/sprite.svg) 14.2180094787% 67.988700565% no-repeat;
    width: 27px;
    height: 41px
}

.icons-prev {
    background: url(../img/sprite.svg) 26.8867924528% 67.988700565% no-repeat;
    width: 26px;
    height: 41px
}

.b-article__time .cell:before,
.icons-calendar {
    background: url(../img/sprite.svg) 96.858490566% 73.9583333333% no-repeat;
    width: 26px;
    height: 26px
}

.b-article__link.add:before,
.icons-add {
    background: url(../img/sprite.svg) 0 40.0858895706% no-repeat;
    width: 55px;
    height: 55px
}

.b-article__link.job::before {
    content: "";
    display: block; /* ВАЖНО: block, чтобы ушло на строку выше */
    background: url("/static/img/job.png") no-repeat center;
    background-size: contain;
    width: 55px;
    height: 50px;
    margin: 0 auto 5px auto; /* центрирование + отступ вниз */
  }

.b-article__link.wallet:before,
.icons-wallet {
    background: url(../img/sprite.svg) 30.0546448087% 38.8928571429% no-repeat;
    width: 55px;
    height: 50px
}

.b-article__link.paint:before,
.icons-paint {
    background: url(../img/sprite.svg) 59.4594594595% 37.7687861272% no-repeat;
    width: 53px;
    height: 45px
}

.b-article__link.doc:before,
.icons-doc {
    background: url(../img/sprite.svg) 62.0846560847% 0 no-repeat;
    width: 49px;
    height: 60px
}

.b-article__text blockquote:after,
.b-article__wrapper blockquote:after,
.icons-quote {
    background: url(../img/sprite.svg) 81.9408866995% 62.1621621622% no-repeat;
    width: 35px;
    height: 33px
}

.icons-pdf {
    background: url(../img/sprite.svg) 79.9711538462% 43.0939226519% no-repeat;
    width: 30px;
    height: 37px
}

.b-article__link.read:before,
.icons-blank {
    background: url(../img/sprite.svg) 36.1587301587% 0 no-repeat;
    width: 49px;
    height: 60px
}

.icons-arrow_up {
    background: url(../img/sprite.svg) 0 87.6847826087% no-repeat;
    width: 34px;
    height: 34px
}

.no-svg .icons-arrow-left,
.no-svg .swiper-button-prev {
    background-image: url(../images/sprite.png);
    background-position: -110px -53px;
    width: 32px;
    height: 63px
}

.no-svg .icons-arrow-right,
.no-svg .icons-heart,
.no-svg .swiper-button-next {
    background-image: url(../images/sprite.png);
    background-position: -168px 0;
    width: 32px;
    height: 63px
}

.no-svg .icons-heart {
    background-position: -58px -105px;
    width: 11px;
    height: 11px
}

.no-svg .icons-heart-big,
.no-svg .icons-search {
    background-image: url(../images/sprite.png);
    background-position: -205px -169px;
    width: 20px;
    height: 20px
}

.no-svg .icons-search {
    background-position: -205px -117px;
    width: 22px;
    height: 22px
}

.no-svg .icons-user,
.no-svg .icons-user-white {
    background-image: url(../images/sprite.png);
    background-position: -140px -167px;
    width: 27px;
    height: 27px
}

.no-svg .icons-user-white {
    background-position: -108px -167px
}

.no-svg .icons-write,
.no-svg .icons-write-white {
    background-image: url(../images/sprite.png);
    background-position: -38px -167px;
    width: 30px;
    height: 28px
}

.no-svg .icons-write-white {
    background-position: -73px -167px
}

.no-svg .icons-next,
.no-svg .icons-prev {
    background-image: url(../images/sprite.png);
    background-position: -205px -144px;
    width: 20px;
    height: 20px
}

.no-svg .icons-next,
.no-svg .icons-prev {
    background-position: -205px -44px;
    width: 24px;
    height: 39px
}

.no-svg .icons-prev {
    background-position: -205px 0
}

.b-article__time .no-svg .cell:before,
.no-svg .b-article__time .cell:before,
.no-svg .icons-calendar {
    background-image: url(../images/sprite.png);
    background-position: -205px -88px;
    width: 24px;
    height: 24px
}

.no-svg .b-article__link.add:before,
.no-svg .icons-add {
    background-image: url(../images/sprite.png);
    background-position: 0 0;
    width: 53px;
    height: 53px
}

.no-svg .b-article__link.wallet:before,
.no-svg .icons-wallet {
    background-image: url(../images/sprite.png);
    background-position: -110px 0;
    width: 53px;
    height: 48px
}

.no-svg .b-article__link.paint:before,
.no-svg .icons-paint {
    background-image: url(../images/sprite.png);
    background-position: 0 -121px;
    width: 49px;
    height: 41px
}

.no-svg .b-article__link.doc:before,
.no-svg .icons-doc {
    background-image: url(../images/sprite.png);
    background-position: -58px 0;
    width: 47px;
    height: 58px
}

.b-article__text .no-svg blockquote:after,
.b-article__wrapper .no-svg blockquote:after,
.no-svg .b-article__text blockquote:after,
.no-svg .b-article__wrapper blockquote:after,
.no-svg .icons-pdf,
.no-svg .icons-quote {
    background-image: url(../images/sprite.png);
    background-position: 0 -167px;
    width: 33px;
    height: 31px
}

.no-svg .icons-pdf {
    background-position: -168px -68px;
    width: 28px;
    height: 35px
}

.no-svg .b-article__link.read:before,
.no-svg .icons-blank {
    background-image: url(../images/sprite.png);
    background-position: 0 -58px;
    width: 47px;
    height: 58px
}

html {
    font: 100%/1.5 sans-serif;
    margin: 0;
    min-width: 320px
}

body {
    padding: 0;
    -ms-text-size-adjust: 100%;
    -webkit-text-size-adjust: 100%;
    -webkit-font-smoothing: antialiased;
    background: #fff;
    color: #010101;
    font-family: "Roboto", sans-serif;
    font-size: 17px;
    margin: 0;
    line-height: 1.3
}

html.has-page-transition .b-page {
    opacity: 0;
    transform: translateY(4px);
}

html.has-page-transition.is-page-ready .b-page {
    opacity: 1;
    transform: translateY(0);
    transition: opacity .18s ease-out, transform .18s ease-out;
}

@media (prefers-reduced-motion: reduce) {
    html.has-page-transition .b-page,
    html.has-page-transition.is-page-ready .b-page {
        opacity: 1;
        transform: none;
        transition: none;
    }
}

body.is-offcanvas {
    overflow: hidden
}

.wrapper--outer {
    overflow-x: hidden
}

img {
    max-width: 100%;
    height: auto;
    border: 0
}

a {
    color: #3da2d6;
    text-decoration: none;
    background-color: transparent
}

a:hover {
    text-decoration: underline
}

.b-slider .swiper-nav,
.b-slider .swiper-pagination,
.b-slider-contents .b-module__title,
.wrapper {
    max-width: 1180px;
    padding-left: 10px;
    padding-right: 10px;
    margin: auto
}

@media screen and (max-width:870px) {
    .wrapper--outer {
        width: 100%;
        position: relative;
        overflow: hidden
    }

    .wrapper--inner {
        left: 0;
        transform: translate3d(0, 0, 0);
        transition: transform .5s ease;
        backface-visibility: hidden
    }

    .no-csstransforms3d .wrapper--inner {
        left: 0;
        transform: translateX(0)
    }

    .no-csstransforms3d.no-csstransforms .wrapper--inner {
        left: 0
    }

    body.is-offcanvas .wrapper--inner {
        transform: translate3d(80%, 0, 0) scale3d(1, 1, 1);
        position: relative
    }

    body.is-offcanvas .wrapper--inner:after {
        content: "";
        position: absolute;
        top: 0;
        bottom: 0;
        left: 0;
        right: 0;
        z-index: 1000;
        background: rgba(0, 0, 0, .5)
    }

    .no-csstransforms3d body.is-offcanvas .wrapper--inner {
        transform: translateX(80%)
    }

    .no-csstransforms3d.no-csstransforms body.is-offcanvas .wrapper--inner {
        left: 80%
    }
}

.b-main {
      padding: 55px 0;
      background: #e4ecf0
  }

@media screen and (max-width:480px) {
    .b-main {
        padding: 35px 0
    }
}

a,
a:active,
a:hover,
img {
    outline: 0
}

abbr[title] {
    border-bottom: 1px dotted
}

dfn {
    font-style: italic
}

mark {
    background: #ff0;
    color: #000
}

small {
    font-size: 80%
}

sub,
sup {
    font-size: 75%;
    line-height: 0;
    position: relative;
    vertical-align: baseline
}

sup {
    top: -.5em
}

sub {
    bottom: -.25em
}

svg:not(:root) {
    overflow: hidden
}

dl,
figure,
ol,
ul {
    margin: 1em 0
}

hr {
    box-sizing: content-box;
    height: 0
}

.mfp-figure figure,
button,
input,
optgroup,
select,
textarea {
    margin: 0
}

button {
    overflow: visible
}

button,
select {
    text-transform: none
}

button,
html input[type=button],
input[type=reset],
input[type=submit] {
    -webkit-appearance: button;
    cursor: pointer
}

button[disabled],
html input[disabled] {
    cursor: default
}

::-moz-focus-inner,
input::-moz-focus-inner {
    border: 0;
    padding: 0
}

input {
    line-height: normal
}

input[type=checkbox],
input[type=radio] {
    box-sizing: border-box;
    padding: 0
}

input[type=number]::-webkit-inner-spin-button,
input[type=number]::-webkit-outer-spin-button {
    height: auto
}

input[type=search] {
    -webkit-appearance: textfield
}

input[type=search]::-webkit-search-cancel-button,
input[type=search]::-webkit-search-decoration {
    -webkit-appearance: none
}

fieldset,
legend {
    border: 0;
    padding: 0
}

optgroup {
    font-weight: 700
}

iframe {
    border: 0
}

input[type=email],
input[type=password],
input[type=phone],
input[type=search],
input[type=tel],
input[type=text] {
    border-radius: 12px;
    padding: 8px 15px;
    box-sizing: border-box
}

input[type=email],
input[type=password],
input[type=phone],
input[type=search],
input[type=tel],
input[type=text],
select,
textarea {
    line-height: 1;
    background: 0 0;
    border: 1px solid #c4c4c4;
    outline: 0;
    font-size: 17px;
    vertical-align: middle;
    color: #010101;
    max-width: 100%;
    transition: border .3s ease;
    font-family: "Roboto", sans-serif
}

select {
    border-radius: 12px;
    padding: 8px 15px
}

input[type=email]:focus,
input[type=password]:focus,
input[type=phone]:focus,
input[type=search]:focus,
input[type=tel]:focus,
input[type=text]:focus,
select:focus,
textarea:focus {
    border-color: #3da2d6
}

.green input[type=email],
.green input[type=password],
.green input[type=phone],
.green input[type=search],
.green input[type=tel],
.green input[type=text],
.green select,
.green textarea {
    border: 2px solid #fff;
    color: #fff
}

.green input[type=email]:focus,
.green input[type=password]:focus,
.green input[type=phone]:focus,
.green input[type=search]:focus,
.green input[type=tel]:focus,
.green input[type=text]:focus,
.green select:focus,
.green textarea:focus {
    border-color: #ebebeb
}

input[type=email]::-webkit-input-placeholder,
input[type=password]::-webkit-input-placeholder,
input[type=phone]::-webkit-input-placeholder,
input[type=search]::-webkit-input-placeholder,
input[type=tel]::-webkit-input-placeholder,
input[type=text]::-webkit-input-placeholder,
select::-webkit-input-placeholder,
textarea::-webkit-input-placeholder {
    color: #969696;
    opacity: 1;
    font-family: "Roboto", sans-serif
}

input[type=email]:-moz-placeholder,
input[type=password]:-moz-placeholder,
input[type=phone]:-moz-placeholder,
input[type=search]:-moz-placeholder,
input[type=tel]:-moz-placeholder,
input[type=text]:-moz-placeholder,
select:-moz-placeholder,
textarea:-moz-placeholder {
    color: #969696;
    opacity: 1;
    font-family: "Roboto", sans-serif
}

input[type=email]::-moz-placeholder,
input[type=password]::-moz-placeholder,
input[type=phone]::-moz-placeholder,
input[type=search]::-moz-placeholder,
input[type=tel]::-moz-placeholder,
input[type=text]::-moz-placeholder,
select::-moz-placeholder,
textarea::-moz-placeholder {
    color: #969696;
    opacity: 1;
    font-family: "Roboto", sans-serif
}

input[type=email]:-ms-input-placeholder,
input[type=password]:-ms-input-placeholder,
input[type=phone]:-ms-input-placeholder,
input[type=search]:-ms-input-placeholder,
input[type=tel]:-ms-input-placeholder,
input[type=text]:-ms-input-placeholder,
select:-ms-input-placeholder,
textarea:-ms-input-placeholder {
    color: #969696;
    opacity: 1;
    font-family: "Roboto", sans-serif
}

input[type=email].placeholder,
input[type=password].placeholder,
input[type=phone].placeholder,
input[type=search].placeholder,
input[type=tel].placeholder,
input[type=text].placeholder,
select.placeholder,
textarea.placeholder {
    color: #969696;
    opacity: 1;
    font-family: "Roboto", sans-serif
}

input[type=email].error,
input[type=password].error,
input[type=phone].error,
input[type=search].error,
input[type=tel].error,
input[type=text].error,
select.error,
textarea.error {
    border: 1px solid #c01f6f;
    background: #f7e2e1
}

textarea {
    height: auto;
    overflow: auto;
    padding: 10px 15px;
    border-radius: 8px
}

.b-form legend {
    color: #010101;
    font-size: 18px;
    font-weight: 700;
    padding-top: 20px;
    display: block
}

.b-form fieldset {
    margin: 0;
    padding: 0
}

.b-form__row {
    margin-top: 20px;
    font-size: 16px
}

.b-form__row:first-child,
.profile fieldset:first-child {
    margin-top: 0
}

.b-form__row label {
    display: block;
    cursor: pointer;
    color: #010101;
    margin-bottom: 5px
}

.btn,
.btn:hover {
    color: #fff;
    text-decoration: none
}

.btn {
    text-align: center;
    line-height: 1;
    border: 0;
    border-radius: 12px;
    background-color: #3da2d6;
    font-family: "Raleway", sans-serif;
    font-size: 19px;
    font-weight: 700;
    padding: 10px 33px;
    box-sizing: border-box;
    transition: background-color .3s ease;
    display: inline-block;
    outline: 0
}

.btn:hover {
    background-color: #bbdff1
}

.btn.btn-small {
    font-size: 15px;
    font-weight: 500;
    padding: 5px 20px;
    border-radius: 5px
}

.btn.big {
    padding: 17px 47px 18px;
    font-size: 25px;
    line-height: 1
}

@media screen and (max-width:380px) {
    .btn.big {
        font-size: 23px
    }
}

.btn.white {
    background: #fff;
    color: #000
}

.btn.white:hover {
    background: #efefef;
    color: #000
}

.btn.full {
    width: 100%;
    text-align: center;
    font-weight: 400
}

.btn.grey {
    background: #efefef ;
    color: #000;
    cursor: pointer
}

.btn.grey:hover {
    background: #cacaca;
    color: #000
}

.form-horizontal .control-group {
    margin-bottom: 20px
}

.clearfix:after,
.clearfix:before,
.form-horizontal .control-group.footer:after,
.form-horizontal .control-group.footer:before,
.form-horizontal .control-group:after,
.form-horizontal .control-group:before {
    content: ".";
    display: block;
    height: 0;
    overflow: hidden
}

.clearfix:after,
.form-horizontal .control-group.footer:after,
.form-horizontal .control-group:after {
    clear: both
}

.form-horizontal .control-group:last-child,
p:last-child {
    margin-bottom: 0
}

.form-horizontal .control-group.footer .white {
    float: right
}

.form-horizontal .control-label {
    display: block;
    margin-bottom: 5px
}

svg {
    max-height: 100%
}

input,
select,
textarea {
    box-sizing: border-box;
    margin-top: 0;
    margin-bottom: 0
}

fieldset {
    box-sizing: border-box;
    margin: 0
}

select:not([multiple]) {
    vertical-align: middle
}

table {
    border-collapse: separate;
    border-spacing: 0;
    max-width: 100%;
    width: 100%
}

td,
th {
    padding: 5px 10px;
    line-height: inherit
}

th {
    text-align: left;
    font-weight: 700;
    vertical-align: bottom
}

td {
    vertical-align: top
}

h1,
h2,
h3,
h4,
h5,
h6 {
    font-weight: 700;
    line-height: 1.3;
    margin: 0 0 30px
}

p {
    margin: 0 0 30px
}

ul {
    list-style: disc
}

ol {
    list-style: decimal
}

h1 {
    font-size: 32px
}

h2 {
    font-size: 24px
}

h3 {
    font-size: 20px
}

h4 {
    font-size: 18px
}

.center {
    text-align: center
}

.relative {
    position: relative
}

.label {
    display: inline-block;
    vertical-align: middle;
    padding: 1px 5px;
    border-radius: 2px;
    background: #f2f2f2;
    color: #000
}

.b-rub {
    font-family: "b-rub", Arial, sans-serif;
    font-style: normal
}

.icon-edit {
    display: inline-block;
    position: relative;
    top: -11px;
    left: -14px
}

.icon-edit:before {
    content: "Ред.";
    font-weight: 400;
    font-size: 14px
}

.profile fieldset {
    margin-top: 35px;
    border-top: 1px solid #3da2d6
}

.profile legend {
    font-size: 18px;
    font-weight: 700;
    padding-right: 15px;
    background: #f2f2f2;
    margin-bottom: 20px
}

.profile label {
    font-weight: 500
}

fieldset+.control-group {
    margin-top: 20px
}

[itemprop=articleBody] ul li {
    position: relative;
    padding-left: 1.6em
}

[itemprop=articleBody] ul li:after {
    content: "—";
    position: absolute;
    left: 0;
    top: 2px
}

[itemprop=articleBody] ul li+li {
    margin-top: .25em
}

.swiper,
.swiper-wrapper {
    position: relative;
    z-index: 1
}

.swiper {
    display: block;
    overflow: hidden;
    overflow: clip;
    margin-right: auto;
    margin-left: auto;
    padding: 0;
    list-style: none
}

.swiper-vertical>.swiper-wrapper {
    flex-direction: column
}

.swiper-wrapper {
    display: flex;
    box-sizing: content-box;
    width: 100%;
    height: 100%;
    transition-timing-function: var(--swiper-wrapper-transition-timing-function, initial);
    transition-property: transform
}

.swiper-android .swiper-slide,
.swiper-ios .swiper-slide,
.swiper-wrapper {
    transform: translate3d(0, 0, 0)
}

.swiper-horizontal {
    touch-action: pan-y
}

.swiper-vertical {
    touch-action: pan-x
}

.swiper-slide {
    position: relative;
    display: block;
    flex-shrink: 0;
    width: 100%;
    height: 100%;
    transition-property: transform
}

.swiper-slide-invisible-blank {
    visibility: hidden
}

.swiper-autoheight,
.swiper-autoheight .swiper-slide {
    height: auto
}

.swiper-autoheight .swiper-wrapper {
    align-items: flex-start;
    transition-property: transform, height
}

.swiper-backface-hidden .swiper-slide {
    transform: translateZ(0);
    backface-visibility: hidden
}

.swiper-3d,
.swiper-3d.swiper-css-mode .swiper-wrapper {
    perspective: 1200px
}

.swiper-3d .swiper-cube-shadow,
.swiper-3d .swiper-slide,
.swiper-3d .swiper-wrapper {
    transform-style: preserve-3d
}

:root {
    --swiper-navigation-size: 44px;
    --swiper-navigation-top-offset: 50%;
    --swiper-navigation-sides-offset: 10px;
    --swiper-navigation-color: var(--swiper-theme-color)
}

.swiper-button-prev {
    left: -42px
}

.swiper-button-next,
.swiper-button-prev {
    position: absolute;
    z-index: 500;
    margin-top: -32px;
    top: var(--swiper-navigation-top-offset, 50%);
    display: flex;
    align-items: center;
    justify-content: center;
    box-sizing: border-box;
    padding: 0;
    cursor: pointer;
    color: var(--swiper-navigation-color, var(--swiper-theme-color));
    border: 0;
    outline: 0;
    -webkit-tap-highlight-color: transparent
}

.swiper-button-next.swiper-button-disabled,
.swiper-button-prev.swiper-button-disabled {
    cursor: auto;
    pointer-events: none;
    opacity: .35
}

.swiper-button-next.swiper-button-hidden,
.swiper-button-prev.swiper-button-hidden {
    cursor: auto;
    pointer-events: none;
    opacity: 0
}

.swiper-navigation-disabled .swiper-button-next,
.swiper-navigation-disabled .swiper-button-prev {
    display: none !important
}

.swiper-button-next svg,
.swiper-button-prev svg {
    width: 100%;
    height: 100%;
    transform-origin: center;
    object-fit: contain
}

.swiper-rtl .swiper-button-next svg,
.swiper-rtl .swiper-button-prev svg {
    transform: rotate(180deg)
}

.swiper-button-prev,
.swiper-rtl .swiper-button-next {
    right: auto;
    left: var(--swiper-navigation-sides-offset, 10px)
}

.swiper-button-next,
.swiper-rtl .swiper-button-prev {
    right: var(--swiper-navigation-sides-offset, 10px);
    left: auto
}

.swiper-button-lock {
    display: none
}

:root {
    --swiper-pagination-color: #3DA2D6;
    --swiper-pagination-left: auto;
    --swiper-pagination-right: 8px;
    --swiper-pagination-bottom: 8px;
    --swiper-pagination-top: auto;
    --swiper-pagination-fraction-color: inherit;
    --swiper-pagination-progressbar-bg-color: rgba(0, 0, 0, 0.25);
    --swiper-pagination-progressbar-size: 4px;
    --swiper-pagination-bullet-size: 8px;
    --swiper-pagination-bullet-width: 8px;
    --swiper-pagination-bullet-height: 8px;
    --swiper-pagination-bullet-border-radius: 50%;
    --swiper-pagination-bullet-inactive-color: #408985;
    --swiper-pagination-bullet-inactive-opacity: 1;
    --swiper-pagination-bullet-opacity: 1;
    --swiper-pagination-bullet-horizontal-gap: 4px;
    --swiper-pagination-bullet-vertical-gap: 6px
}

.swiper-pagination {
    position: relative;
    z-index: 10;
    transition: 300ms opacity;
    transform: translate3d(0, 0, 0);
    text-align: center
}

.swiper-pagination.swiper-pagination-hidden {
    opacity: 0
}

.swiper-pagination-disabled>.swiper-pagination,
.swiper-pagination.swiper-pagination-disabled {
    display: none !important
}

.swiper-horizontal>.swiper-pagination-bullets,
.swiper-pagination-bullets.swiper-pagination-horizontal,
.swiper-pagination-custom,
.swiper-pagination-fraction {
    left: 0;
    width: 100%
}

.swiper-pagination-bullets-dynamic {
    font-size: 0;
    overflow: hidden
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
    position: relative;
    transform: scale(.33)
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active,
.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-main {
    transform: scale(1)
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev {
    transform: scale(.66)
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev-prev {
    transform: scale(.33)
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next {
    transform: scale(.66)
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next-next {
    transform: scale(.33)
}

.swiper-pagination-bullet {
    display: inline-block;
    width: var(--swiper-pagination-bullet-width, var(--swiper-pagination-bullet-size, 8px));
    height: var(--swiper-pagination-bullet-height, var(--swiper-pagination-bullet-size, 8px));
    opacity: var(--swiper-pagination-bullet-inactive-opacity, 0.2);
    border-radius: var(--swiper-pagination-bullet-border-radius, 50%);
    background: var(--swiper-pagination-bullet-inactive-color, #000)
}

.swiper-pagination--white .swiper-pagination-bullet {
    background: #fff;
    opacity: .7
}

button.swiper-pagination-bullet {
    border: 0;
    margin: 0;
    padding: 0;
    box-shadow: none;
    appearance: none
}

.swiper-pagination-clickable .swiper-pagination-bullet {
    cursor: pointer
}

.swiper-pagination-bullet:only-child {
    display: none !important
}

.swiper-pagination-bullet-active {
    opacity: var(--swiper-pagination-bullet-opacity, 1);
    background: var(--swiper-pagination-color, var(--swiper-theme-color))
}

.swiper-pagination--white .swiper-pagination-bullet-active {
    background: #fff
}

.swiper-pagination-vertical.swiper-pagination-bullets,
.swiper-vertical>.swiper-pagination-bullets {
    top: 50%;
    right: var(--swiper-pagination-right, 8px);
    left: var(--swiper-pagination-left, auto);
    transform: translate3d(0, -50%, 0)
}

.swiper-pagination-vertical.swiper-pagination-bullets .swiper-pagination-bullet,
.swiper-vertical>.swiper-pagination-bullets .swiper-pagination-bullet {
    display: block;
    margin: var(--swiper-pagination-bullet-vertical-gap, 6px) 0
}

.swiper-pagination-vertical.swiper-pagination-bullets.swiper-pagination-bullets-dynamic,
.swiper-vertical>.swiper-pagination-bullets.swiper-pagination-bullets-dynamic {
    top: 50%;
    width: 8px;
    transform: translateY(-50%)
}

.swiper-pagination-vertical.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet,
.swiper-vertical>.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
    display: inline-block;
    transition: 200ms transform, 200ms top
}

.swiper-horizontal>.swiper-pagination-bullets .swiper-pagination-bullet,
.swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet {
    margin: 0 var(--swiper-pagination-bullet-horizontal-gap, 4px)
}

.swiper-horizontal>.swiper-pagination-bullets.swiper-pagination-bullets-dynamic,
.swiper-pagination-horizontal.swiper-pagination-bullets.swiper-pagination-bullets-dynamic {
    left: 50%;
    transform: translateX(-50%);
    white-space: nowrap
}

.swiper-horizontal>.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet,
.swiper-pagination-horizontal.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
    transition: 200ms transform, 200ms left
}

.swiper-horizontal.swiper-rtl>.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
    transition: 200ms transform, 200ms right
}

.swiper-pagination-fraction {
    color: var(--swiper-pagination-fraction-color, inherit)
}

.swiper-pagination-progressbar {
    position: absolute;
    background: var(--swiper-pagination-progressbar-bg-color, rgba(0, 0, 0, 0.25))
}

.swiper-pagination-progressbar .swiper-pagination-progressbar-fill {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    transform: scale(0);
    transform-origin: left top;
    background: var(--swiper-pagination-color, var(--swiper-theme-color))
}

.swiper-rtl .swiper-pagination-progressbar .swiper-pagination-progressbar-fill {
    transform-origin: right top
}

.swiper-horizontal>.swiper-pagination-progressbar,
.swiper-pagination-progressbar.swiper-pagination-horizontal,
.swiper-pagination-progressbar.swiper-pagination-vertical.swiper-pagination-progressbar-opposite,
.swiper-vertical>.swiper-pagination-progressbar.swiper-pagination-progressbar-opposite {
    top: 0;
    left: 0;
    width: 100%;
    height: var(--swiper-pagination-progressbar-size, 4px)
}

.swiper-horizontal>.swiper-pagination-progressbar.swiper-pagination-progressbar-opposite,
.swiper-pagination-progressbar.swiper-pagination-horizontal.swiper-pagination-progressbar-opposite,
.swiper-pagination-progressbar.swiper-pagination-vertical,
.swiper-vertical>.swiper-pagination-progressbar {
    top: 0;
    left: 0;
    width: var(--swiper-pagination-progressbar-size, 4px);
    height: 100%
}

.mfp-align-top .mfp-container:before,
.swiper-pagination-lock {
    display: none
}

.mfp-bg {
    z-index: 1042;
    overflow: hidden;
    position: fixed;
    background: #32aea8;
    opacity: .8;
    filter: alpha(opacity=80)
}

.mfp-bg,
.mfp-container,
.mfp-wrap {
    width: 100%;
    height: 100%;
    left: 0;
    top: 0
}

.mfp-wrap {
    z-index: 1043;
    position: fixed;
    outline: 0 !important;
    -webkit-backface-visibility: hidden;
    -moz-backface-visibility: visible
}

.mfp-container {
    text-align: center;
    position: absolute;
    padding: 0 70px;
    box-sizing: border-box
}

.mfp-container:before,
.mfp-content {
    display: inline-block;
    vertical-align: middle
}

.mfp-container:before {
    content: "";
    height: 100%
}

.mfp-content {
    position: relative;
    margin: 0 auto;
    text-align: left;
    z-index: 1045
}

.mfp-ajax-holder .mfp-content,
.mfp-inline-holder .mfp-content {
    padding: 10px 0;
    cursor: auto
}

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

    .mfp-ajax-holder.mfp-container,
    .mfp-inline-holder.mfp-container {
        padding-left: 5px;
        padding-right: 5px
    }

    .mfp-ajax-holder.mfp-container .mfp-close,
    .mfp-inline-holder.mfp-container .mfp-close {
        right: 25px;
        top: 37px;
        color: #000
    }
}

.mfp-ajax-cur {
    cursor: progress
}

.mfp-zoom-out-cur {
    cursor: zoom-out
}

.mfp-zoom {
    cursor: pointer;
    cursor: zoom-in
}

.mfp-auto-cursor .mfp-content {
    cursor: auto
}

.mfp-arrow,
.mfp-close,
.mfp-counter,
.mfp-preloader {
    -webkit-user-select: none;
    user-select: none
}

.mfp-loading.mfp-figure,
.mfp-s-error .mfp-content,
.mfp-s-ready .mfp-preloader {
    display: none
}

.mfp-hide {
    display: none !important
}

.mfp-preloader {
    color: #ccc;
    position: absolute;
    top: 50%;
    width: auto;
    text-align: center;
    margin-top: -.8em;
    left: 8px;
    right: 8px;
    z-index: 1044
}

.mfp-preloader a {
    color: #ccc
}

.mfp-preloader a:hover {
    color: #fff
}

button.mfp-arrow,
button.mfp-close {
    overflow: visible;
    cursor: pointer;
    border: 0;
    -webkit-appearance: none;
    display: block;
    outline: 0;
    padding: 0;
    z-index: 1046;
    box-shadow: none
}

button::-moz-focus-inner {
    padding: 0;
    border: 0
}

.mfp-close {
    position: absolute;
    right: -46px;
    top: 35px;
    text-decoration: none;
    padding: 0 0 0 2px;
    box-sizing: border-box;
    color: #fff;
    font-style: normal;
    cursor: pointer;
    background: 0 0;
    border: 2px solid #fff;
    border-radius: 50%;
    width: 30px;
    height: 30px;
    font-size: 48px;
    line-height: 29px;
    text-align: center
}

.mfp-close-btn-in .mfp-close {
    color: #333
}

.mfp-counter {
    position: absolute;
    top: 0;
    right: 0;
    color: #ccc;
    font-size: 12px;
    line-height: 18px;
    white-space: nowrap
}

.mfp-arrow {
    position: absolute;
    opacity: .65;
    filter: alpha(opacity=65);
    top: 50%;
    margin: -55px 0 0;
    padding: 0;
    width: 90px;
    height: 110px;
    -webkit-tap-highlight-color: transparent;
    background: 0 0
}

.mfp-arrow:active {
    margin-top: -54px
}

.mfp-arrow:focus,
.mfp-arrow:hover {
    opacity: 1;
    filter: alpha(opacity=100)
}

.mfp-arrow:before {
    content: "";
    display: block;
    width: 0;
    height: 0;
    position: absolute;
    left: 0;
    top: 0;
    margin-top: 35px;
    margin-left: 35px;
    border: medium inset transparent
}

.mfp-arrow .mfp-b {
    top: 0
}

.mfp-arrow .mfp-a,
.mfp-arrow .mfp-b,
.mfp-arrow:after {
    content: "";
    display: block;
    width: 0;
    height: 0;
    position: absolute;
    left: 0;
    margin-top: 35px;
    margin-left: 35px;
    border: medium inset transparent
}

.mfp-arrow .mfp-a,
.mfp-arrow:after {
    border-top-width: 13px;
    border-bottom-width: 13px;
    top: 8px
}

.mfp-arrow .mfp-b,
.mfp-arrow:before {
    border-top-width: 21px;
    border-bottom-width: 21px;
    opacity: .7
}

.mfp-arrow-left {
    left: 0
}

.mfp-arrow-left .mfp-a,
.mfp-arrow-left:after {
    border-right: 17px solid #fff;
    margin-left: 31px
}

.mfp-arrow-left .mfp-b,
.mfp-arrow-left:before {
    margin-left: 25px;
    border-right: 27px solid #3f3f3f
}

.mfp-arrow-right {
    right: 0
}

.mfp-arrow-right .mfp-a,
.mfp-arrow-right:after {
    border-left: 17px solid #fff;
    margin-left: 39px
}

.mfp-arrow-right .mfp-b,
.mfp-arrow-right:before {
    border-left: 27px solid #3f3f3f
}

.mfp-iframe-holder {
    padding-top: 40px;
    padding-bottom: 40px
}

.mfp-iframe-holder .mfp-content {
    line-height: 0;
    width: 100%;
    max-width: 900px
}

.mfp-iframe-holder .mfp-close {
    top: -40px
}

.mfp-iframe-scaler {
    width: 100%;
    height: 0;
    overflow: hidden;
    padding-top: 56.25%
}

.mfp-iframe-scaler iframe {
    position: absolute;
    display: block;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    box-shadow: 0 0 8px rgba(0, 0, 0, .6);
    background: #000
}

.mfp-figure:after,
img.mfp-img {
    display: block;
    width: auto;
    height: auto
}

img.mfp-img {
    box-sizing: border-box;
    padding: 40px 0;
    margin: 0 auto
}

.mfp-figure,
img.mfp-img {
    line-height: 0
}

.mfp-figure:after {
    content: "";
    position: absolute;
    left: 0;
    top: 40px;
    bottom: 40px;
    right: 0;
    z-index: -1;
    box-shadow: 0 0 8px rgba(0, 0, 0, .6);
    background: #444
}

.mfp-figure small {
    color: #bdbdbd;
    display: block;
    font-size: 12px;
    line-height: 14px
}

.mfp-bottom-bar {
    margin-top: -36px;
    position: absolute;
    top: 100%;
    left: 0;
    width: 100%;
    cursor: auto
}

.mfp-title {
    text-align: left;
    line-height: 18px;
    color: #f3f3f3;
    word-wrap: break-word;
    padding-right: 36px
}

.mfp-image-holder .mfp-content,
img.mfp-img {
    max-width: 100%
}

.b-step-itogi tr.header,
.mfp-image-holder .mfp-figure {
    background: 0 0
}

.mfp-image-holder .mfp-close {
    font-size: 24px
}

.mfp-gallery .mfp-image-holder .mfp-figure {
    cursor: pointer;
    animation: navigationAnimation .5s ease;
    animation-fill-mode: both;
    -webkit-backface-visibility: hidden;
    -moz-backface-visibility: hidden;
    -ms-backface-visibility: hidden
}

@media screen and (max-width:800px) and (orientation:landscape),
screen and (max-height:300px) {
    .mfp-img-mobile .mfp-image-holder {
        padding-left: 0;
        padding-right: 0
    }

    .mfp-img-mobile img.mfp-img {
        padding: 0
    }

    .mfp-img-mobile .mfp-figure:after {
        top: 0;
        bottom: 0
    }

    .mfp-img-mobile .mfp-figure small {
        display: inline;
        margin-left: 5px
    }

    .mfp-img-mobile .mfp-bottom-bar {
        background: rgba(0, 0, 0, .6);
        bottom: 0;
        margin: 0;
        top: auto;
        padding: 3px 5px;
        position: fixed;
        box-sizing: border-box
    }

    .mfp-img-mobile .mfp-bottom-bar:empty {
        padding: 0
    }

    .mfp-img-mobile .mfp-counter {
        right: 5px;
        top: 3px
    }

    .mfp-img-mobile .mfp-close {
        top: 0;
        right: 0
    }
}

@media all and (max-width:900px) {
    .mfp-arrow {
        transform: scale(.75)
    }

    .mfp-arrow-left {
        transform-origin: 0
    }

    .mfp-arrow-right {
        transform-origin: 100%
    }

    .mfp-container {
        padding-left: 45px;
        padding-right: 45px
    }
}

.mfp-ie7 .mfp-img {
    padding: 0
}

.mfp-ie7 .mfp-bottom-bar {
    width: 600px;
    left: 50%;
    margin-left: -300px;
    margin-top: 5px;
    padding-bottom: 5px
}

.mfp-ie7 .mfp-container {
    padding: 0
}

.mfp-ie7 .mfp-content {
    padding-top: 44px
}

.mfp-ie7 .mfp-close {
    top: 0;
    right: 0;
    padding-top: 0
}

.modal-animation .mfp-close,
.modal-animation .mfp-content,
.modal-animation .modal-close {
    opacity: 0;
    transition: transform .5s ease-out, opacity .5s ease-out;
    transform: scale(.8)
}

.modal-animation.mfp-ready .mfp-close,
.modal-animation.mfp-ready .mfp-content,
.modal-animation.mfp-ready .modal-close {
    opacity: 1;
    transform: scale(1)
}

.modal-animation.mfp-removing .mfp-close,
.modal-animation.mfp-removing .mfp-content,
.modal-animation.mfp-removing .modal-close {
    opacity: 0;
    transform: scale(.8)
}

.modal-animation.mfp-bg {
    opacity: 0;
    transition: opacity .5s ease-out
}

.modal-animation.mfp-ready.mfp-bg {
    opacity: .8
}

.modal-animation.mfp-removing.mfp-bg {
    opacity: 0
}

.mfp-with-zoom .mfp-close,
.mfp-with-zoom .mfp-container,
.mfp-with-zoom.mfp-bg {
    opacity: 0;
    -webkit-backface-visibility: hidden;
    transition: transform .3s ease-out
}

.mfp-with-zoom.mfp-ready .mfp-close,
.mfp-with-zoom.mfp-ready .mfp-container {
    opacity: 1
}

.mfp-with-zoom.mfp-ready.mfp-bg {
    opacity: .8
}

.mfp-with-zoom.mfp-removing .mfp-close,
.mfp-with-zoom.mfp-removing .mfp-container,
.mfp-with-zoom.mfp-removing.mfp-bg,
.tooltip {
    opacity: 0
}

.tooltip {
    position: absolute;
    z-index: 1070;
    display: block;
    font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
    font-style: normal;
    font-weight: 400;
    letter-spacing: normal;
    line-break: auto;
    line-height: 1.42857143;
    text-align: left;
    text-align: start;
    text-decoration: none;
    text-shadow: none;
    text-transform: none;
    white-space: normal;
    word-break: normal;
    word-spacing: normal;
    word-wrap: normal;
    font-size: 12px;
    filter: alpha(opacity=0)
}

.tooltip.in {
    opacity: .9;
    filter: alpha(opacity=90)
}

.tooltip.top {
    margin-top: -3px;
    padding: 5px 0
}

.tooltip.right {
    margin-left: 3px;
    padding: 0 5px
}

.tooltip.bottom {
    margin-top: 3px;
    padding: 5px 0
}

.tooltip.left {
    margin-left: -3px;
    padding: 0 5px
}

.tooltip-inner {
    max-width: 200px;
    padding: 3px 8px;
    color: #fff;
    text-align: center;
    background-color: #000;
    border-radius: 4px
}

.tooltip-arrow {
    position: absolute;
    width: 0;
    height: 0;
    border-color: transparent;
    border-style: solid
}

.tooltip.top .tooltip-arrow {
    bottom: 0;
    left: 50%;
    margin-left: -5px;
    border-width: 5px 5px 0;
    border-top-color: #000
}

.tooltip.top-left .tooltip-arrow,
.tooltip.top-right .tooltip-arrow {
    bottom: 0;
    margin-bottom: -5px;
    border-width: 5px 5px 0;
    border-top-color: #000
}

.tooltip.top-left .tooltip-arrow {
    right: 5px
}

.tooltip.top-right .tooltip-arrow {
    left: 5px
}

.tooltip.right .tooltip-arrow {
    top: 50%;
    left: 0;
    margin-top: -5px;
    border-width: 5px 5px 5px 0;
    border-right-color: #000
}

.tooltip.left .tooltip-arrow {
    top: 50%;
    right: 0;
    margin-top: -5px;
    border-width: 5px 0 5px 5px;
    border-left-color: #000
}

.tooltip.bottom .tooltip-arrow {
    top: 0;
    left: 50%;
    margin-left: -5px;
    border-width: 0 5px 5px;
    border-bottom-color: #000
}

.tooltip.bottom-left .tooltip-arrow {
    top: 0;
    right: 5px;
    margin-top: -5px;
    border-width: 0 5px 5px;
    border-bottom-color: #000
}

.tooltip.bottom-right .tooltip-arrow {
    top: 0;
    left: 5px;
    margin-top: -5px;
    border-width: 0 5px 5px;
    border-bottom-color: #000
}

.popover {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 1060;
    display: none;
    max-width: 276px;
    padding: 1px;
    font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
    font-style: normal;
    font-weight: 400;
    letter-spacing: normal;
    line-break: auto;
    line-height: 1.42857143;
    text-align: left;
    text-align: start;
    text-decoration: none;
    text-shadow: none;
    text-transform: none;
    white-space: normal;
    word-break: normal;
    word-spacing: normal;
    word-wrap: normal;
    font-size: 14px;
    background-color: #fff;
    -webkit-background-clip: padding-box;
    background-clip: padding-box;
    border: 1px solid #ccc;
    border: 1px solid rgba(0, 0, 0, .2);
    border-radius: 6px;
    box-shadow: 0 5px 10px rgba(0, 0, 0, .2)
}

.popover.top {
    margin-top: -10px
}

.popover.right {
    margin-left: 10px
}

.popover.bottom {
    margin-top: 10px
}

.popover.left {
    margin-left: -10px
}

.popover-title {
    margin: 0;
    padding: 8px 14px;
    font-size: 14px;
    background-color: #f7f7f7;
    border-bottom: 1px solid #ebebeb;
    border-radius: 5px 5px 0 0
}

.popover-content {
    padding: 9px 14px
}

.popover>.arrow,
.popover>.arrow:after {
    position: absolute;
    display: block;
    width: 0;
    height: 0;
    border-color: transparent;
    border-style: solid
}

.popover>.arrow {
    border-width: 11px
}

.popover>.arrow:after {
    border-width: 10px;
    content: ""
}

.popover.top>.arrow {
    left: 50%;
    margin-left: -11px;
    border-bottom-width: 0;
    border-top-color: #999;
    border-top-color: rgba(0, 0, 0, .25);
    bottom: -11px
}

.popover.top>.arrow:after {
    content: " ";
    bottom: 1px;
    margin-left: -10px;
    border-bottom-width: 0;
    border-top-color: #fff
}

.popover.right>.arrow {
    top: 50%;
    left: -11px;
    margin-top: -11px;
    border-left-width: 0;
    border-right-color: #999;
    border-right-color: rgba(0, 0, 0, .25)
}

.popover.right>.arrow:after {
    content: " ";
    left: 1px;
    bottom: -10px;
    border-left-width: 0;
    border-right-color: #fff
}

.popover.bottom>.arrow {
    left: 50%;
    margin-left: -11px;
    border-top-width: 0;
    border-bottom-color: #999;
    border-bottom-color: rgba(0, 0, 0, .25);
    top: -11px
}

.popover.bottom>.arrow:after {
    content: " ";
    top: 1px;
    margin-left: -10px;
    border-top-width: 0;
    border-bottom-color: #fff
}

.popover.left>.arrow {
    top: 50%;
    right: -11px;
    margin-top: -11px;
    border-right-width: 0;
    border-left-color: #999;
    border-left-color: rgba(0, 0, 0, .25)
}

.popover.left>.arrow:after {
    content: " ";
    right: 1px;
    border-right-width: 0;
    border-left-color: #fff;
    bottom: -10px
}

.odometer.odometer-auto-theme,
.odometer.odometer-auto-theme .odometer-digit,
.odometer.odometer-theme-minimal,
.odometer.odometer-theme-minimal .odometer-digit {
    display: inline-block;
    vertical-align: middle;
    position: relative
}

.odometer.odometer-auto-theme .odometer-digit .odometer-digit-spacer,
.odometer.odometer-theme-minimal .odometer-digit .odometer-digit-spacer {
    display: inline-block;
    vertical-align: middle;
    visibility: hidden
}

.odometer.odometer-auto-theme .odometer-digit .odometer-digit-inner,
.odometer.odometer-theme-minimal .odometer-digit .odometer-digit-inner {
    text-align: left;
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    overflow: hidden
}

#b_scroller i,
.b-work-panel__list li b,
.odometer.odometer-auto-theme .odometer-digit .odometer-ribbon,
.odometer.odometer-theme-minimal .odometer-digit .odometer-ribbon {
    display: block
}

.odometer.odometer-auto-theme .odometer-digit .odometer-ribbon-inner,
.odometer.odometer-theme-minimal .odometer-digit .odometer-ribbon-inner {
    display: block;
    -webkit-backface-visibility: hidden
}

.odometer.odometer-auto-theme .odometer-digit .odometer-value,
.odometer.odometer-theme-minimal .odometer-digit .odometer-value {
    display: block;
    -webkit-transform: translateZ(0)
}

.odometer.odometer-auto-theme .odometer-digit .odometer-value.odometer-last-value,
.odometer.odometer-theme-minimal .odometer-digit .odometer-value.odometer-last-value {
    position: absolute
}

.odometer.odometer-auto-theme.odometer-animating-up .odometer-ribbon-inner,
.odometer.odometer-theme-minimal.odometer-animating-up .odometer-ribbon-inner {
    transition: transform 2s
}

.odometer.odometer-auto-theme.odometer-animating-down .odometer-ribbon-inner,
.odometer.odometer-auto-theme.odometer-animating-up.odometer-animating .odometer-ribbon-inner,
.odometer.odometer-theme-minimal.odometer-animating-down .odometer-ribbon-inner,
.odometer.odometer-theme-minimal.odometer-animating-up.odometer-animating .odometer-ribbon-inner {
    transform: translateY(-100%)
}

.odometer.odometer-auto-theme.odometer-animating-down.odometer-animating .odometer-ribbon-inner,
.odometer.odometer-theme-minimal.odometer-animating-down.odometer-animating .odometer-ribbon-inner {
    transition: transform 2s;
    transform: translateY(0)
}

.jq-checkbox {
    top: -1px;
    vertical-align: middle;
    width: 17px;
    height: 17px;
    margin: 0 4px 0 0;
    border: 1px solid #c4c4c4;
    border-radius: 2px;
    background: 0 0;
    cursor: pointer;
    transition: border .3s ease, background .3s ease;
    position: relative
}

.jq-checkbox.checked {
    background: #3da2d6;
    border-color: #3da2d6
}

.jq-checkbox.checked .jq-checkbox__div {
    background: url(../img/sprite.svg) 98.8125% 55.5555555556% no-repeat;
    width: 14px;
    height: 11px;
    position: absolute;
    top: 4px;
    left: 1px
}

.no-svg .jq-checkbox.checked .jq-checkbox__div {
    background-image: url(../images/sprite.png);
    background-position: -147px -104px;
    width: 12px;
    height: 11px
}

.jq-checkbox.focused {
    border: 1px solid #3da2d6
}

.jq-checkbox.disabled {
    opacity: .55
}

.b-header {
    padding: 26px 0 30px;
    position: relative
}

@media screen and (max-width:640px) {
    .b-header {
        padding: 10px 0
    }
}

.b-logo {
    float: left;
    text-decoration: none;
    display: block
}

.b-logo:after,
.b-logo:before {
    content: ".";
    display: block;
    height: 0;
    overflow: hidden
}

.b-logo:after {
    clear: both
}

.b-headerbar p,
.b-logo p {
    margin: 0
}

@media screen and (max-width:640px) {
    .b-logo {
        float: none;
        text-align: center
    }
}

.b-logo__img {
    float: left
}

@media screen and (max-width:640px) {
    .b-logo__img {
        float: none
    }
}

.login-greeting {
    margin-bottom: 5px
}

.login-greeting+.ul-jlslogin li {
    padding-bottom: 5px
}

.b-headerbar {
    float: right;
    display: flex;
    padding: 27px 0 0;
    align-items: flex-start
}

@media screen and (max-width:950px) {
    .b-headerbar {
        margin-top: 7px
    }
}

@media screen and (max-width:870px) {
    .b-headerbar {
        float: none;
        flex-direction: column;
        margin-top: 0
    }
}

.b-headerbar .jlslogin {
    margin-left: 10px
}

.b-headerbar>.btn {
    margin-left: 16px;
}

@media screen and (max-width:870px) {
    .b-headerbar>.btn {
        margin-left: 0;
        margin-bottom: 8px;
    }
}

@media screen and (max-width:870px) {
    .b-headerbar .jlslogin {
        margin-left: 0;
        width: 100%
    }
}

.b-headerbar .ul-jlslogin {
    margin: 0 0 0 5px;
    padding: 0;
    list-style: none
}

.b-headerbar__link {
    display: inline-block;
    position: relative;
    color: #000;
    font-size: 16px;
    font-weight: 500;
    padding-left: 43px;
    margin-left: 46px;
    text-decoration: none;
    transition: opacity .3s ease
}

@media screen and (max-width:1055px) {
    .b-headerbar__link {
        margin-left: 10px;
        font-size: 14px
    }
}

@media screen and (max-width:1005px) {
    .b-headerbar__link {
        padding-right: 0
    }
}

@media screen and (max-width:870px) {
    .b-headerbar__link {
        margin: 0 0 5px;
        padding-left: 0
    }
}

.b-headerbar__link:first-child {
    margin-left: 0
}

.b-headerbar__link:hover {
    opacity: .7;
    text-decoration: none
}

.no-opacity .b-headerbar__link:hover {
    color: #2d2d2d
}

.b-headerbar__link i,
.b-main-menu ul.menu ul {
    position: absolute;
    display: inline-block;
    left: 0;
    top: -4px
}

.b-headerbar__icon {
    position: absolute;
    display: block;
    left: 0;
    top: -2px;
    width: 28px;
    height: 28px;
}

@media screen and (max-width:1005px) {
    .b-headerbar__link i {
        position: relative;
        display: block;
        margin: auto;
        top: auto;
        right: auto
    }
}

@media screen and (max-width:870px) {
    .b-headerbar__link i.icons-user {
        background: url(../img/sprite.svg) 98.2488038278% 31.2169312169% no-repeat;
        width: 29px;
        height: 29px
    }

    .b-headerbar__link i.icons-write {
        position: relative;
        display: inline-block;
        vertical-align: middle
    }

    .b-headerbar__icon {
        position: relative;
        display: inline-block;
        vertical-align: middle;
        top: auto;
        left: auto;
        margin-right: 8px;
    }
}

.b-main-menu {
    background: #3da2d6;
    position: relative;
    z-index: 110;
    font-family: "Raleway", sans-serif
}

.b-main-menu:after,
.b-main-menu:before {
    content: ".";
    display: block;
    height: 0;
    overflow: hidden
}

.b-main-menu:after {
    clear: both
}

.b-main-menu ul {
    list-style: none;
    margin: 0;
    padding: 0
}

.b-main-menu ul li {
    position: relative;
    z-index: 1
}

.b-main-menu ul li:hover {
    z-index: 50
}

.b-main-menu ul li:hover>ul {
    display: block;
    animation: mainMenuDrop .4s ease
}

.b-main-menu ul.menu {
    font-size: 0
}

.b-main-menu ul.menu>li {
    font-size: 19px;
    display: inline-block;
    box-sizing: border-box
}

@media screen and (max-width:1140px) {
    .b-main-menu ul.menu>li {
        font-size: 16px
    }
}

@media screen and (max-width:980px) {
    .b-main-menu ul.menu>li {
        font-size: 15px
    }
}

.b-main-menu ul.menu>li>a {
    font-size: 19px;
    font-weight: 400;
    line-height: 1;
    text-decoration: none;
    color: #fff;
    text-align: center;
    display: block;
    padding: 19px 18px 21px;
    border-top: 2px solid #3da2d6;
    transition: background .3s ease, color .3s ease, border .3s ease
}

@media screen and (max-width:1140px) {
    .b-main-menu ul.menu>li>a {
        font-size: 16px;
        padding: 19px 15px 21px
    }
}

@media screen and (max-width:980px) {
    .b-main-menu ul.menu>li>a {
        font-size: 15px;
        padding: 19px 10px 21px
    }
}

.b-main-menu ul.menu>li.active>a,
.b-main-menu ul.menu>li:hover>a {
    border-top: 2px solid #bbdff1;
    background: #bbdff1;
    color: #3da2d6
}

.b-main-menu ul.menu>li.parent>a span {
    position: relative;
    display: inline-block;
    padding-right: 13px
}

.b-main-menu ul.menu>li.parent>a span:after {
    content: "";
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 4px 3.5px 0;
    border-color: #fff transparent transparent;
    position: absolute;
    right: 0;
    top: 8px
}

@media screen and (max-width:1140px) {
    .b-main-menu ul.menu>li.parent>a span:after {
        top: 6px
    }
}

@media screen and (max-width:980px) {
    .b-main-menu ul.menu>li.parent>a span:after {
        top: 5px
    }
}

.no-rgba .b-main-menu ul.menu>li.parent>a span:after {
    border-color: #fff transparent transparent
}

.b-main-menu ul.menu>li.parent:hover>a {
    border-top: 2px solid #3da2d6;
    color: #3da2d6;
    background: #fff
}

.b-main-menu ul.menu>li.parent:hover>a span:after,
.no-rgba .b-main-menu ul.menu>li.parent:hover>a span:after {
    border-color: #3da2d6 transparent transparent
}

.b-main-menu ul.menu .nav-child {
    box-shadow: 0 3px 6px rgba(0, 0, 0, .25)
}

.b-main-menu ul.menu ul {
    top: 100%;
    background: #fff;
    min-width: 322px;
    display: none;
    border-top: 0
}

.b-main-menu ul.menu ul ul {
    top: 0;
    left: 100%
}

.b-main-menu ul.menu ul a {
    display: block;
    text-decoration: none;
    padding: 10px 12px;
    color: #3da2d6;
    background: #fff;
    transition: background .4s ease, color .4s ease
}

.b-main-menu ul.menu ul li.active>a,
.b-main-menu ul.menu ul li:hover>a {
    color: #154a65;
    background: #effef6
}

@media screen and (max-width:870px) {
    .b-main-menu__nav {
        transform: translate3d(-150%, 0, 0);
        transition: transform .5s ease;
        backface-visibility: hidden;
        position: fixed;
        top: 0;
        bottom: 0;
        width: 80%;
        overflow-y: auto;
        padding: 7px 0 25px
    }

    .overflowscrolling .b-main-menu__nav {
        overflow-y: scroll;
        -webkit-overflow-scrolling: touch
    }

    .no-csstransforms3d .b-main-menu__nav {
        transform: translateX(-150%)
    }

    .no-csstransforms3d.no-csstransforms .b-main-menu__nav {
        left: -150%
    }

    body.is-offcanvas .b-main-menu__nav {
        left: 0;
        transform: translate3d(0, 0, 0)
    }

    .no-csstransforms3d body.is-offcanvas .b-main-menu__nav {
        left: 0;
        transform: translateX(0)
    }

    .no-csstransforms3d.no-csstransforms body.is-offcanvas .b-main-menu__nav {
        left: 0
    }

    .b-main-menu__nav ul.menu {
        margin: 0;
        padding: 0;
        list-style: none
    }

    .b-main-menu__nav ul.menu,
    .b-main-menu__nav ul.menu li {
        border-top: 1px solid #d4d4d4
    }

    .b-main-menu__nav ul.menu li:first-child {
        border-top: 0
    }

    .b-main-menu__nav ul.menu a {
        padding: 13px 15px;
        text-decoration: none;
        color: #3c3c3c;
        font-size: 16px;
        font-weight: 700;
        display: block
    }

    .b-main-menu__nav ul.menu a:hover {
        color: #3da2d6
    }

    .b-main-menu__nav ul.menu ul {
        margin: 0;
        padding: 0 0 0 10px;
        list-style: none;
        border-top: 1px solid #d4d4d4
    }

    .b-main-menu__nav ul.menu ul li {
        border: 0
    }

    .b-main-menu__nav ul.menu ul a {
        font-weight: 400;
        padding: 10px 16px
    }

    .b-main-menu__nav ul.menu li.parent>a {
        padding-right: 38px;
        position: relative
    }

    .b-main-menu__nav ul.menu li.active>a {
        color: #00acf1
    }
}

.b-main-menu__menu {
    display: none;
    visibility: hidden
}

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

    .b-main-menu__menu {
        display: block;
        visibility: visible
    }
}

.b-main-menu__menu {
    float: left;
    width: 60px;
    height: 60px;
    color: #fff;
    text-decoration: none;
    position: relative;
    overflow: hidden;
    opacity: 1
}

.b-main-menu__menu span,
.b-main-menu__menu:after,
.b-main-menu__menu:before {
    width: 30px;
    height: 4px;
    background: #fff;
    display: block;
    position: absolute;
    top: 50%
}

.b-main-menu__menu:after,
.b-main-menu__menu:before {
    content: "";
    transform: rotate(0deg);
    transition: transform .3s ease, margin .3s ease
}

.b-main-menu__menu:before {
    margin-top: -10px
}

.b-main-menu__menu:after {
    margin-top: 6px
}

.b-main-menu__menu span {
    margin-top: -2px;
    transition: opacity .3s ease, transform .3s ease
}

.b-main-menu__menu.is-active:before {
    transform: rotate(45deg);
    margin-top: 0
}

.b-main-menu__menu.is-active:after {
    transform: rotate(-45deg);
    margin-top: 0
}

.b-main-menu__menu.is-active span {
    opacity: 0;
    transform: translate3d(-100%, 0, 0)
}

.b-main-menu__close {
    position: absolute;
    display: block;
    width: 60px;
    height: 60px;
    top: -8px;
    right: -8px
}

.b-main-menu__close:after,
.b-main-menu__close:before {
    content: "";
    width: 30px;
    height: 4px;
    margin-top: 0;
    left: 15px;
    background: #3c3c3c;
    display: block;
    position: absolute;
    top: 50%;
    transition: transform .3s ease, margin .3s ease
}

.b-main-menu__close:before {
    transform: rotate(45deg)
}

.b-main-menu__close:after {
    transform: rotate(-45deg)
}

.b-main-menu__nav .jlslogin {
    padding: 1em
}

@media screen and (max-width:870px) {
    .b-main-menu__nav .jlslogin {
        padding: 15px
    }
}

.b-main-menu__nav .jlslogin .login-greeting {
    font-size: 18px;
    font-weight: 700;
    font-family: "Raleway", sans-serif
}

.b-main-menu__nav .jlslogin ul {
    padding: 0;
    list-style: none;
    margin: .5em 0
}

.b-main-menu__nav .jlslogin ul li+li {
    margin-top: .25em
}

.b-grid:after,
.b-grid:before {
    content: ".";
    display: block;
    height: 0;
    overflow: hidden
}

.b-grid:after {
    clear: both
}

.b-grid__wrapper {
    margin: -10px
}

.b-grid__item {
    display: inline-block;
    padding: 10px;
    margin-right: -4px;
    box-sizing: border-box;
    vertical-align: top;
    width: 100%
}

.cell-2 .b-grid__item {
    width: 50%
}

@media screen and (max-width:660px) {
    .cell-2 .b-grid__item {
        width: 100%
    }
}

.cell-3 .b-grid__item {
    width: 33.333332%
}

@media screen and (max-width:660px) {
    .cell-3 .b-grid__item {
        width: 50%
    }
}

@media screen and (max-width:424px) {
    .cell-3 .b-grid__item {
        width: 100%
    }
}

.cell-4 .b-grid__item {
    width: 25%
}

@media screen and (max-width:990px) {
    .cell-4 .b-grid__item {
        width: 33.333332%
    }
}

@media screen and (max-width:660px) {
    .cell-4 .b-grid__item {
        width: 50%
    }
}

@media screen and (max-width:424px) {
    .cell-4 .b-grid__item {
        width: 100%
    }
}

.cell-5 .b-grid__item {
    width: 20%
}

@media screen and (max-width:990px) {
    .cell-5 .b-grid__item {
        width: 33.333332%
    }
}

@media screen and (max-width:660px) {
    .cell-5 .b-grid__item {
        width: 50%
    }
}

@media screen and (max-width:424px) {
    .cell-5 .b-grid__item {
        width: 100%
    }
}

.b-slider {
    margin-bottom: 0 !important;
    padding-bottom: 0 !important;
    background: transparent !important;
    overflow: hidden;
  }

.b-slider,
.b-slider .b-slider-contents .b-module__title,
.b-slider .swiper-nav,
.b-slider .swiper-pagination,
.b-slider .wrapper,
.b-slider-contents .b-slider .b-module__title {
    position: relative
}

.b-slider .swiper-nav .swiper-button-next,
.b-slider .swiper-nav .swiper-button-prev {
    margin-top: -112px
}

@media screen and (max-width:1305px) {
    .b-slider .swiper-nav {
        display: none
    }
}

.b-slider .swiper-pagination {
    position: absolute;
    bottom: 10px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 10;
    width: auto;
    display: flex;
    gap: 6px;
  }

/*@media screen and (max-width:1305px) {
    .b-slider .swiper-pagination {
        display: block
    }
}*/

.b-slider__bg {
    background: url(../images/rocket.svg) no-repeat 0 0;
    position: absolute;
    bottom: -56px;
    right: 0;
    width: 610px;
    height: 583px;
    background-size: contain;
    z-index: 0;
    display: block
}

@media screen and (max-width:1105px) {
    .b-slider__bg {
        right: -160px
    }
}

@media screen and (max-width:955px) {
    .b-slider__bg {
        right: 0;
        width: 410px;
        height: 383px
    }
}

@media screen and (max-width:770px) {
    .b-slider__bg {
        display: none
    }
}

.no-svg .b-slider__bg {
    background: url(../images/rocket.png) no-repeat 0 0
}

.b-slider__rose {
    background: url(../images/butterfly.svg) no-repeat 0 0;
    position: absolute;
    top: 20px;
    left: -90px;
    width: 218px;
    height: 184px;
    background-size: contain;
    z-index: 1;
    display: block
}

.b-slider__wrapper {
    white-space: nowrap;
    overflow: hidden
}

.b-slider__wrapper.owl-loaded,
.cke_show_borders .b-slider__wrapper {
    white-space: normal;
    display: block !important;
    visibility: visible !important
}

.b-slider__item {
    white-space: normal;
    width: 100%;
    vertical-align: top;
    display: inline-block;
    padding: 47px 0 70px;
    transform: translateZ(0)
}

@media screen and (max-width:485px) {
    .b-slider__item {
        padding: 25px 0
    }
}

.cke_show_borders .b-slider__item {
    margin-bottom: 30px
}

.b-slider__item p {
    max-width: 652px
}

.b-slider__date {
    font-size: 16px
}

.b-slider__title {
    max-width: 549px;
    font-family: "Raleway", sans-serif;
    font-size: 37px;
    font-weight: 700;
    line-height: 50px;
    margin: 36px 0
}

.b-slider__title.small {
    font-size: 1.5rem;
    line-height: 125%;
    max-width: 652px
}

@media screen and (max-width:770px) {
    .b-slider__title {
        max-width: 90%
    }
}

@media screen and (max-width:485px) {
    .b-slider__title {
        font-size: 26px;
        line-height: 1.3;
        margin: 20px 0
    }
}

.b-slider__link {
    margin-top: 58px
}

@media screen and (max-width:485px) {
    .b-slider__link {
        margin-top: 30px
    }
}

.b-slider-contents {
    padding: 2rem 1rem !important;
    overflow: hidden
}

.b-slider-contents .b-module__title {
    margin-bottom: 30px
}

.b-contents-slider {
    padding: 0 1rem
}

.b-contents-slider .swiper {
    margin: 0 -10px;
    overflow: visible
}

.b-contents-slider .swiper-wrapper {
    align-items: stretch
}

.b-contents-slider .swiper:not(.swiper-initialized) .swiper-wrapper {
    gap: 16px;
}

.b-contents-slider .swiper:not(.swiper-initialized) .swiper-slide {
    flex-shrink: 0;
}

.b-contents-slider .swiper-slide {
    width: 50%;
    box-sizing: border-box
}

@media screen and (min-width:421px) {
    .b-contents-slider .swiper-slide {
        width: 33.3333333333%
    }
}

@media screen and (min-width:831px) {
    .b-contents-slider .swiper-slide {
        width: 25%
    }
}

@media screen and (min-width:1025px) {
    .b-contents-slider .swiper-slide {
        width: 20%
    }
}

.b-contents-slider .swiper-pagination {
    margin-top: 20px
}

.b-contents-slider .item {
    background: #fff;
    border: 1px solid #dedede;
    border-radius: 6px;
    margin: 0 10px;
    box-sizing: border-box;
    display: flex;
    flex-flow: column nowrap;
    justify-content: flex-start;
    align-items: stretch
}

.b-contents-slider .item .text {
    padding: 1em
}

.b-contents-slider .item .img img {
    width: 100%;
    vertical-align: top;
    border-radius: 6px 6px 0 0
}

.b-contents-slider .item .title {
    overflow: hidden;
    height: 78px;
    line-height: 152%
}

@media screen and (max-width:770px) {
    .b-contents-slider .item .title {
        height: 87px;
        line-height: 123%
    }
}

.b-contents-slider .item .name {
    color: #010101;
    font-size: 18px
}

@media screen and (max-width:770px) {
    .b-contents-slider .item .name {
        font-size: 1em
    }
}

.b-contents-slider .item .date {
    margin-top: 1em;
    color: #010101;
    font-size: .8125em
}

@media screen and (max-width:770px) {
    .b-contents-slider .item .date {
        font-size: .75em
    }
}

.b-contents-slider .owl-dots {
    position: relative;
    top: 8px
}

.b-module__wrapper {
    padding: 50px 0
}

@media screen and (max-width:530px) {
    .b-module__wrapper {
        padding: 20px 0
    }
}

.b-module__wrapper.green {
    color: #fff;
    background: #3da2d6
}

.b-module__wrapper.grey {
    background: #f2f2f2
}

.b-module__title {
    font-family: "Raleway", sans-serif;
    font-size: 30px;
    font-weight: 700;
    margin: 0 0 30px
}

@media screen and (max-width:910px) {
    .b-module__title {
        font-size: 24px
    }
}

@media screen and (max-width:730px) {
    .b-module__title {
        font-size: 18px
    }
}

.b-mod-button {
    margin-top: 30px;
    text-align: center
}

.b-panel {
    background-color: #fff;
    border-radius: 6px;
    padding: 20px 20px 55px;
    box-sizing: border-box;
    position: relative;
    transform: translateZ(0)
}

.b-mini-panel {
    background: #fff;
    border: 1px solid #dedede;
    border-radius: 6px;
    padding: 18px;
    box-sizing: border-box
}

.b-mini-panel__like {
    margin-top: 7px;
    font-size: 15px;
    font-weight: 700
}

.b-mini-panel__like a {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    color: #000;
    transition: color .3s ease
}

.b-mini-panel__like a:hover {
    text-decoration: none;
    color: #3da2d6
}

.b-mini-panel__like--works .b-like-icon--small {
    width: 21px;
    height: 21px;
}

.b-mini-panel__like i {
    display: inline-block;
    vertical-align: sub;
    margin-right: 2px
}

.b-comment-panel__header {
    display: table;
    width: 100%;
    table-layout: fixed
}

.b-tabs:after,
.b-tabs:before {
    content: ".";
    display: block;
    height: 0;
    overflow: hidden
}

.b-tabs:after {
    clear: both
}

.b-tabs__item {
    display: none
}

.b-tabs__item:first-child {
    display: block
}

.b-tabs__link {
    float: left;
    margin-left: 40px;
    padding-left: 40px;
    position: relative
}

@media screen and (max-width:910px) {
    .b-tabs__link {
        margin-left: 20px;
        padding-left: 20px
    }
}

@media screen and (max-width:530px) {
    .b-tabs__link {
        float: none;
        margin: 8px 0 0;
        padding-left: 0
    }

    .b-tabs__link:first-child {
        margin-top: 0
    }
}

.b-tabs__link:after {
    content: "";
    width: 9px;
    height: 9px;
    background: #3da2d6;
    position: absolute;
    left: -5px;
    top: 50%;
    margin-top: -5px;
    border-radius: 50%
}

@media screen and (max-width:530px) {
    .b-tabs__link:after {
        display: none
    }
}

.green .b-tabs__link:after {
    background: #fff
}

.b-tabs__link:first-child {
    margin-left: 0;
    padding-left: 0
}

.b-tabs__link:first-child:after {
    display: none
}

.b-tabs__link a {
    text-decoration: none;
    font-family: "Raleway", sans-serif;
    font-size: 30px;
    font-weight: 700;
    color: #3da2d6;
    transition: color .3s ease
}

@media screen and (max-width:910px) {
    .b-tabs__link a {
        font-size: 24px
    }
}

@media screen and (max-width:730px) {
    .b-tabs__link a {
        font-size: 18px
    }
}

.b-tabs__link a.active,
.b-tabs__link a:hover {
    color: #030303;
    text-decoration: none
}

.green .b-tabs__link a {
    color: #fff
}

.green .b-tabs__link a.active,
.green .b-tabs__link a:hover {
    color: #154a65
}

.b-footer {
    margin: 36px 0
}

.b-footer:after,
.b-footer:before,
.b-footer__menu ul:after,
.b-footer__menu ul:before {
    content: ".";
    display: block;
    height: 0;
    overflow: hidden
}

.b-footer:after,
.b-footer__menu ul:after {
    clear: both
}

.b-footer__copyright,
.b-footer__menu ul li {
    float: left;
    font-weight: 400;
    box-sizing: border-box
}

.b-footer__copyright {
    width: 33.9%;
    padding-right: 20px;
    font-size: 14px
}

@media screen and (max-width:760px) {
    .b-footer__copyright {
        width: 50%
    }
}

@media screen and (max-width:640px) {
    .b-footer__copyright {
        width: 100%
    }
}

.b-footer__copyright p {
    margin-bottom: .4em
}

.b-footer__copyright h3,
.b-footer__copyright h4,
.b-footer__copyright h5 {
    margin-top: 0;
    font-size: 17px;
    font-weight: 500
}

.b-footer__menu {
    float: left;
    width: 40.35%
}

@media screen and (max-width:760px) {
    .b-footer__menu {
        width: 50%
    }
}

@media screen and (max-width:640px) {
    .b-footer__menu {
        margin-top: 20px;
        width: 100%
    }
}

.b-footer__menu ul {
    margin: 0 -5px;
    padding: 0;
    list-style: none
}

.b-footer__menu ul li {
    width: 50%;
    color: #3da2d6;
    font-size: 17px;
    margin-bottom: 6px;
    padding: 0 5px
}

@media screen and (max-width:360px) {
    .b-footer__menu ul li {
        width: 100%
    }
}

.b-footer__info {
    float: right;
    width: 25.4%
}

@media screen and (max-width:760px) {
    .b-footer__info {
        width: 100%;
        margin-top: 20px
    }
}

.b-article__wrapper ol li:first-child,
.b-article__wrapper ol li:first-child {
    margin-top: 0
}

.b__cat2 .b-article__wrapper a:hover,
.b__cat37 .b-article__wrapper a:hover,
.b__cat39 .b-article__wrapper a:hover {
    border-bottom-color: #3da2d6;
    text-decoration: none
}

#b_scroller {
    bottom: -5rem;
    cursor: pointer;
    opacity: 0;
    position: fixed;
    right: 1rem;
    transition: bottom .4s ease 0s, opacity 1s ease 0s, visible 1s ease 0s;
    visibility: hidden;
    z-index: 3
}

#b_scroller.show {
    bottom: 1rem;
    opacity: 1;
    transition: bottom 1s ease 0s, opacity .3s ease 0s, visible 1s ease 0s;
    visibility: visible
}

#b_scroller {
    display: inline-block
}

.b-breadcrumb {
    list-style: none;
    display: block;
    margin: 0 0 15px;
    padding: 0;
    font-size: 16px;
    color: #dedede
}

.b-breadcrumb__item {
    display: inline;
    padding-left: 4px
}

.b-breadcrumb__item.active span {
    color: #a6d5f3;
  }  

.b-breadcrumb__item:first-child {
    padding-left: 0
}

.b-breadcrumb__separator {
    font-size: 17px;
    display: inline;
    vertical-align: middle;
    position: relative;
    top: -2px;
    padding-left: 4px;
    font-family: Arial, Helvetica, sans-serif
}

.pagination {
    margin-top: 22px;
    margin-bottom: -8px;
    text-align: center
}

.pagination .step-links {
    display: inline-flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: 10px;
}

.pagination .current {
    display: inline-block;
}

.b-pagination {
    text-align: center;
    list-style: none;
    margin: 22px 0 0;
    padding: 0 245px;
    position: relative
}

@media screen and (max-width:830px) {
    .b-pagination {
        padding: 0
    }
}

.b-pagination__link {
    display: inline-block;
    margin: 8px
}

.b-pagination__link a,
.b-pagination__link.active span {
    border: 1px solid #3da2d6;
    display: block;
    text-align: center;
    line-height: 38px;
    text-decoration: none;
    padding: 0 14px;
    box-sizing: border-box;
    transition: background .3s ease, color .3s ease
}

.b-pagination__link.active span {
    color: #fff;
    background: #3da2d6
}

.b-pagination__link a {
    color: #3da2d6
}

.b-pagination__link a:hover {
    background: #3da2d6;
    color: #fff
}

.pagination__wrapper {
    display: block
}

.pagination-toolbar {
    width: 100%
}

.b-pagination__link a,
.b-pagination__link span {
    min-width: 42px
}

.b-pagination__link--ellipsis span {
    min-width: 0;
    border: 0;
    padding: 0 4px;
    color: #7c7c7c;
    background: transparent;
    line-height: 38px;
    cursor: default
}

.alert {
    margin-bottom: 0;
    text-shadow: 0 1px 0 rgba(255, 255, 255, .5);
    background-color: #fcf8e3;
    font-size: 18px;
    padding: 8px 16px
}

.alert a {
    text-decoration: underline
}

.alert a:hover,
.b-add-form-tab ul li a:hover,
.b-article__text a:hover {
    text-decoration: none
}

.alert.alert-no-items {
    color: #010101
}

.alert__inner {
    position: relative;
    padding: 18px 35px 18px 0
}

.alert,
.alert a,
.alert h4,
.alert h4 a {
    color: #c09853
}

.alert h4 {
    margin: 0
}

.alert .close {
    position: absolute;
    top: 50%;
    text-decoration: none;
    right: 0;
    line-height: 20px;
    font-size: 22px;
    cursor: pointer;
    margin-top: -10px
}

.alert-success {
    color: #468847;
    background-color: #dff0d8
}

.alert-success a,
.alert-success h4 {
    color: #468847
}

.alert-danger,
.alert-error {
    color: #b94a48;
    background-color: #f2dede
}

.alert-danger a,
.alert-danger h4,
.alert-error a,
.alert-error h4 {
    color: #b94a48
}

.alert-info {
    background-color: #d9edf7
}

.alert-info,
.alert-info a,
.alert-info h4 {
    color: #3a87ad
}

.alert-block {
    padding-top: 14px;
    padding-bottom: 14px
}

.alert-block>p,
.alert-block>ul {
    margin-bottom: 0
}

.alert-block p+p {
    margin-top: 5px
}

.easy_entries .easy_frame,
[name=gbookForm] {
    background: #fff;
    border: 1px solid #dedede;
    border-radius: 6px;
    padding: 18px;
    box-sizing: border-box
}

.easy_entries .easy_frame {
    margin-bottom: 1.7em
}

.easy_entries .easy_top {
    display: flex;
    justify-content: space-between;
    margin-bottom: .5em
}

.easy_entries .easy_content,
.easy_entries .easy_top_left,
.easy_entries .easy_top_right {
    padding: 0
}

.easy_entries .easy_top_left .easy_big {
    vertical-align: inherit
}

.easy_entries .easy_top_left .easy_small {
    font-size: inherit;
    font-weight: 400
}

[name=gbookForm] {
    max-width: 600px
}

[name=gbookForm] .control-group {
    display: flex
}

[name=gbookForm] .control-group .control-label {
    margin-bottom: 0
}

[name=gbookForm] .control-group .controls {
    margin-left: 0 !important
}

.b-article:after,
.b-article:before {
    content: ".";
    display: block;
    height: 0;
    overflow: hidden
}

.b-article:after {
    clear: both
}

.b-article__title {
    max-width: 940px;
    font-family: "Raleway", sans-serif;
    font-size: 39px;
    font-weight: 700;
    line-height: 1.15;
    margin-bottom: 30px
}

@media screen and (max-width:790px) {
    .b-article__title {
        font-size: 32px;
        margin-bottom: 25px
    }
}

@media screen and (max-width:480px) {
    .b-article__title {
        font-size: 26px;
        margin-bottom: 20px
    }
}

.b-article__wrapper {
    position: relative
}

.b-article__wrapper ul {
    list-style: none;
    padding: 0;
    margin-bottom: 30px
}

.b-article__text ol li:last-child,
.b-article__text ul li:last-child,
.b-article__wrapper ol:last-child,
.b-article__wrapper ul:last-child {
    margin-bottom: 0
}

.b-article__wrapper ol {
    list-style: none;
    padding: 0;
    margin-bottom: 30px;
    counter-reset: ol-counter
}

.b-article__wrapper ol li {
    position: relative;
    padding-left: 39px;
    margin-top: 16px
}

.b-article__wrapper ol li:after {
    content: counter(ol-counter);
    counter-increment: ol-counter;
    position: absolute;
    left: 0;
    top: 0;
    color: #7f7f7f
}

.b-article__wrapper blockquote {
    background: #3da2d6;
    color: #fff;
    padding: 15px 27px 20px 72px;
    font-size: 16px;
    line-height: 1.6;
    position: relative;
    margin: 0 -80px -29px -34px
}

@media screen and (max-width:970px) {
    .b-article__wrapper blockquote {
        margin: 0 -30px -30px
    }
}

@media screen and (max-width:790px) {
    .b-article__wrapper blockquote {
        margin: 0 -15px -15px
    }
}

.b-article__text blockquote:after,
.b-article__wrapper blockquote:after {
    content: " ";
    position: absolute;
    top: 16px;
    left: 24px
}

.b-add-form-tab ul li.active a,
.b-article__wrapper blockquote a {
    color: #fff
}

.b-article__text {
    background: #fff;
    padding: 29px 34px;
    box-sizing: border-box;
    line-height: 1.4
}

.b-contests-list-intro {
    border-radius: 10px;
    box-shadow: 0 12px 28px rgba(15, 23, 42, .06);
}

@media screen and (max-width:970px) {
    .b-article__text {
        padding: 30px
    }
}

@media screen and (max-width:790px) {
    .b-article__text {
        padding: 15px
    }
}

.b-article__text a {
    text-decoration: underline
}

.is-sticky+.b-article__text {
    margin-right: 240px
}

@media screen and (max-width:790px) {
    .is-sticky+.b-article__text {
        margin-right: 0
    }
}

.b-article__text h2 {
    margin-bottom: .5rem
}

.b-article__text ul {
    padding: 0;
    margin: 0 0 1.5rem;
    list-style: none
}

.b-article__text ul li {
    margin: 0 0 .5em 1.6rem;
    list-style: none
}

.b-article__text ul li:before {
    content: "—";
    float: left;
    margin-left: -1.55em;
    color: #3da2d6
}

.b-article__text ol li {
    margin: 0 0 .5em
}

.b-article__text blockquote {
    background: #3da2d6;
    color: #fff;
    padding: 1rem 34px 1rem 72px;
    font-size: 16px;
    line-height: 1.6;
    position: relative;
    margin: 0 -34px -29px
}

.b-article__text blockquote a {
    text-decoration: none;
    color: #fff;
    border-bottom: 1px solid #fff
}

.b-article__text blockquote a:hover,
.b__cat38 blockquote a:hover {
    border-bottom-color: transparent
}

.b-article__sidebar {
    float: right;
    width: 220px
}

@media screen and (max-width:790px) {
    .b-article__sidebar {
        display: block;
        float: none;
        text-align: center;
        width: auto;
        margin-bottom: 14px
    }
}

@media screen and (max-width:480px) {
    .b-article__sidebar {
        display: flex;
        align-items: stretch;
        justify-content: space-between;
        align-content: center
    }
}

.b-article__sidebar+.b-article__text {
    margin-right: 240px
}

@media screen and (max-width:790px) {
    .b-article__sidebar+.b-article__text {
        margin-right: 0
    }
}

.b-article__link {
    padding: 20px 8px;
    display: block;
    text-decoration: none;
    color: #fff;
    text-align: center;
    background: #3da2d6;
    font-size: 20px;
    font-weight: 700;
    transition: background .3s ease;
    margin-top: 23px
}

.b-article__link:first-child,
.b-work-panel__list li:first-child {
    margin-top: 0
}

@media screen and (max-width:790px) {
    .b-article__link {
        display: inline-block;
        vertical-align: top;
        width: 160px;
        margin: 7px 14px 7px 0
    }
}

@media screen and (max-width:420px) {
    .b-article__link {
        width: 30%;
        margin: 0;
        font-size: 15px;
        box-sizing: border-box
    }
}

.b-article__link:hover {
    text-decoration: none;
    background: #bbdff1
}

.b-article__link.add,
.b-article__link.wallet {
    padding-top: 90px;
    position: relative
}

.b-article__link.add:before,
.b-article__link.paint:before,
.b-article__link.wallet:before {
    content: " ";
    position: absolute;
    top: 28px;
    left: 50%;
    margin-left: -26.5px
}

.b-article__link.paint {
    padding-top: 68px;
    position: relative
}

.b-article__link.paint:before {
    top: 17px;
    margin-left: -25.5px
}

.b-article__link.doc,
.b-article__link.read {
    padding-top: 90px;
    position: relative
}

.b-article__link.doc:before,
.b-article__link.read:before {
    content: " ";
    position: absolute;
    top: 19px;
    left: 50%;
    margin-left: -21.5px
}

.b-article__time {
    margin-bottom: 30px;
    margin-right: -72px
}

@media screen and (max-width:970px) {
    .b-article__time {
        margin-right: 0
    }
}

.b-article__time .cell {
    width: 36.133333%;
    display: inline-block;
    vertical-align: top;
    box-sizing: border-box;
    margin-right: -11px;
    padding: 0 10px 0 41px;
    position: relative;
    line-height: 1.5
}

@media screen and (max-width:970px) {
    .b-article__time .cell {
        width: 100%;
        padding: 0 0 0 42px;
        margin-top: 15px
    }

    .b-article__time .cell:first-child {
        margin-top: 0
    }
}

.b-article__time .cell:first-child {
    padding-left: 42px;
    width: 28.133333%
}

.b-article__time .cell:before {
    content: " ";
    position: absolute;
    top: 2px;
    left: 0
}

.b__cat38 .b-article__wrapper {
    background: #fff;
    box-sizing: border-box;
    line-height: 1.4;
    padding: 1.8125rem
}

@media screen and (max-width:600px) {
    .b__cat38 .b-article__wrapper {
        padding: 1.8125rem 15px
    }
}

.b__cat38 table {
    border: 0;
    border-spacing: 0;
    width: 100%
}

.b__cat38 table tr:nth-child(2n) td {
    background: #f6fbfc
}

.b__cat38 table th {
    padding: .75rem .5rem;
    color: #fff;
    background: #3da2d6;
    vertical-align: top
}

.b__cat38 table td {
    vertical-align: middle;
    padding: .75rem .5rem
}

.b__cat38 table td:first-child {
    white-space: nowrap
}

.b__cat38 table td:last-child {
    white-space: nowrap
}

.b__cat38 table h2,
.b__cat38 table h3 {
    margin: 1rem 0 .5rem
}

.b__cat2 .b-article__wrapper blockquote,
.b__cat37 .b-article__wrapper blockquote,
.b__cat38 blockquote,
.b__cat39 .b-article__wrapper blockquote {
    margin: 0 -1.8125rem -1.8125rem
}

.b__cat38 blockquote a {
    text-decoration: none;
    border-bottom: 1px solid #fff
}

.b__cat38 h2.big-font {
    margin: 2rem 0
}

.b__cat2 .b-article__wrapper,
.b__cat37 .b-article__wrapper,
.b__cat39 .b-article__wrapper {
    background: #fff;
    box-sizing: border-box;
    line-height: 1.4;
    padding: 1.8125rem
}

.b__cat2 .b-article__wrapper a,
.b__cat37 .b-article__wrapper a,
.b__cat39 .b-article__wrapper a {
    border-bottom: 1px solid rgba(91, 196, 191, .3)
}

.b__cat2 .b-article__wrapper blockquote a,
.b__cat37 .b-article__wrapper blockquote a,
.b__cat39 .b-article__wrapper blockquote a {
    text-decoration: none;
    border-bottom: 1px solid rgba(255, 255, 255, .3)
}

.b__cat2 .b-article__wrapper blockquote a:hover,
.b__cat37 .b-article__wrapper blockquote a:hover,
.b__cat39 .b-article__wrapper blockquote a:hover {
    border-bottom-color: #fff
}

.b-slider .b__newsp .b-main .swiper-nav,
.b-slider .b__newsp .b-main .swiper-pagination,
.b-slider-contents .b__newsp .b-main .b-module__title,
.b__newsp .b-main .b-slider .swiper-nav,
.b__newsp .b-main .b-slider .swiper-pagination,
.b__newsp .b-main .b-slider-contents .b-module__title,
.b__newsp .b-main .wrapper {
    max-width: 980px
}

.b__newsp .b-main .b-article {
    background: #fff;
    padding: 29px 34px
}

.b__newsp .b-main .b-article h3 {
    margin-bottom: .25rem
}

.b-step-final__info dl {
    margin: 0
}

.b-contest-category__list {
    position: relative
}

.b-contest-category__list:after,
.b-contest-category__list:before {
    content: ".";
    display: block;
    height: 0;
    overflow: hidden
}

.b-contest-category__list:after {
    clear: both
}

.b-contest-category__image img {
    width: 100%
}

.b-contest-category__text {
    padding: 20px 20px 30px;
    font-size: 15px;
    color: #2f2f2f
}

.b-contest-category__text p {
    margin: 8px 0 0
}

.b-contest-category__item {
    background: #fff
}

.b-contest-category__title {
    font-size: 16px;
    margin: 0;
    font-weight: 500;
    display: block;
    overflow: hidden;
    height: 64px
}

.b-contest-category__title a {
    color: #010101
}

.b-contest-category__title a:hover {
    text-decoration: underline;
    border-bottom-color: #010101
}

.b-contest-category__meta {
    font-size: 14px;
    margin-bottom: 15px;
    color: #666
}

.b-contest-category__meta strong {
    display: block;
    font-weight: 500
}

.b-contest-category__date {
    margin-top: 8px;
    font-size: 12px;
    color: #666
}

.b-contest-category__date.big {
    font-size: 17px;
    margin-bottom: 30px
}

@media screen and (max-width:480px) {
    .b-contest-category__date.big {
        margin-bottom: 10px;
        text-align: center
    }
}

.b-article__text-img {
    float: right;
    margin: 0 0 1em 1em
}

@media screen and (max-width:480px) {
    .b-article__text-img {
        margin-left: 0
    }
}

.b-contest-category__description {
    margin-bottom: 35px
}

.b-contest-category__description:after,
.b-contest-category__description:before {
    content: ".";
    display: block;
    height: 0;
    overflow: hidden
}

.b-contest-category__description:after {
    clear: both
}

.b-contest-category__description .content_block {
    overflow: inherit;
    position: relative
}

.b-contest-category__description .content_block.hid {
    overflow: hidden;
    height: 450px
}

.b-contest-category__description .content_block.hid:after {
    content: "";
    display: block;
    height: 100px;
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    background-image: linear-gradient(to bottom, rgba(255, 255, 255, 0), #fff 75%)
}

.b-work {
    display: table;
    width: 100%;
    table-layout: fixed;
    position: relative
}

@media screen and (max-width:740px) {
    .b-work {
        display: block;
        width: auto
    }
}

.b-work__text {
    display: table-cell;
    vertical-align: top;
    width: 100%
}

@media screen and (max-width:740px) {
    .b-work__text {
        display: block;
        width: auto
    }
}

.b-work__content {
    background: #fff;
    box-shadow: 0 12px 28px rgba(15, 23, 42, .06);
    border-radius: 10px;
    overflow: hidden;
    position: relative
}

.b-work--best .b-work__content {
    box-shadow: 0 14px 34px rgba(15, 23, 42, .08), 0 0 0 1px rgba(251, 209, 75, .34), 0 0 0 4px rgba(251, 209, 75, .07), 0 0 24px rgba(251, 209, 75, .16)
}

.b-work__best-badge {
    position: absolute;
    top: 12px;
    right: 18px;
    z-index: 5;
    display: inline-flex;
    align-items: center;
    gap: 0;
    max-width: calc(100% - 36px);
    min-height: 30px;
    padding: 4px 16px;
    border: 0;
    border-radius: 10px;
    background: #fbd14b;
    box-shadow: 0 12px 24px rgba(251, 209, 75, .32);
    line-height: 1.2;
    overflow: visible
}

.b-work__best-icon {
    position: absolute;
    top: 10px;
    left: 18px;
    z-index: 5;
    width: 72px;
    height: 72px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: transparent
}

.b-work__best-icon img {
    display: block;
    width: 72px;
    height: 72px;
    object-fit: contain;
    filter: drop-shadow(0 10px 18px rgba(15, 23, 42, .18)) drop-shadow(0 4px 10px rgba(251, 209, 75, .28))
}

.b-work__best-badge-text {
    position: relative;
    z-index: 1;
    display: inline-flex;
    align-items: center;
    color: #fff;
    font-size: 15px;
    font-weight: 400;
    letter-spacing: .01em;
    white-space: nowrap
}

.b-work__best-sparkle {
    position: absolute;
    z-index: 4;
    width: var(--sparkle-size, 30px);
    height: var(--sparkle-size, 30px);
    pointer-events: none;
    opacity: 0;
    object-fit: contain;
    transform: scale(.45) rotate(var(--sparkle-rotate, 0deg));
    filter: drop-shadow(0 0 12px rgba(251, 209, 75, .42)) drop-shadow(0 4px 10px rgba(251, 209, 75, .28))
}

.b-work--best-animated .b-work__best-sparkle {
    animation: b-work-best-badge-sparkle 1.45s ease-out var(--sparkle-delay, 0s) 1 forwards
}

.b-work__sidebar {
    display: table-cell;
    vertical-align: top;
    width: 380px;
    padding-left: 20px
}

@media screen and (max-width:940px) {
    .b-work__sidebar {
        width: 320px
    }
}

@media screen and (max-width:740px) {
    .b-work__sidebar {
        display: block;
        width: auto;
        margin-top: 20px;
        padding-left: 0
    }
}

.b-work__desc {
    font-size: 18px;
    padding: 30px;
    color: #010101;
    font-family: "Raleway", sans-serif;
    line-height: 1.7222222222
}

@media screen and (max-width:640px) {
    .b-work__desc {
        padding: 15px
    }
}

@media screen and (max-width:640px) {
    .b-work__best-badge {
        top: 10px;
        right: 12px;
        max-width: calc(100% - 24px);
        min-height: 24px;
        padding: 3px 12px
    }

    .b-work__best-icon {
        top: 10px;
        left: 12px;
        width: 52px;
        height: 52px
    }

    .b-work__best-icon img {
        width: 52px;
        height: 52px
    }

    .b-work__best-badge-text {
        font-size: 12px;
        font-weight: 400
    }

}

.b-add-form-panel__text p:last-child,
.b-work__desc>:last-child {
    margin-bottom: 0
}

.b-step-itogi tr,
.b-work-panel {
    background: #fff;
    box-shadow: 0 12px 28px rgba(15, 23, 42, .06);
    border-radius: 10px
}

.b-work-panel__list {
    list-style: none;
    margin: 0;
    padding: 35px 30px
}

@media screen and (max-width:640px) {
    .b-work-panel__list {
        padding: 20px 15px
    }
}

.b-work-panel__list li {
    margin-top: 35px
}

.b-work-panel__footer {
    padding: 28px 30px;
    border-top: 1px solid #dfdfdf
}

@media screen and (max-width:640px) {
    .b-work-panel__footer {
        padding: 20px 15px
    }
}

.b-work-panel__links {
    padding: 28px 30px;
    border-top: 1px solid #dfdfdf
}

@media screen and (max-width:640px) {
    .b-work-panel__links {
        padding: 20px 15px
    }
}

@keyframes b-work-best-badge-sparkle {
    0% {
        opacity: 0;
        transform: scale(.45) rotate(var(--sparkle-rotate, 0deg))
    }

    30% {
        opacity: 1;
        transform: scale(1) rotate(var(--sparkle-rotate, 0deg))
    }

    100% {
        opacity: 0;
        transform: scale(1.3) rotate(calc(var(--sparkle-rotate, 0deg) + 8deg))
    }
}

.b-work-rating {
    display: table;
    width: 100%
}

@media screen and (max-width:420px) {
    .b-work-rating {
        display: block
    }
}

.b-work-rating__body {
    display: table-cell;
    vertical-align: middle
    
}

@media screen and (max-width:420px) {
    .b-work-rating__body {
        display: block;
        text-align: center
    }
}

.b-work-rating__body strong,
.no-opacity .b-step-four__sidebar .jq-radio.checked+label:before,
.no-rgba .b-add-form-tab ul li.active:before {
    display: block
}

.b-work-rating__count {
    padding-left: 33px;
    color: #010101;
    font-family: "Raleway", sans-serif;
    font-size: 25px;
    font-weight: 700;
    line-height: 1.24;
    position: relative
}

@media screen and (max-width:420px) {
    .b-work-rating__count {
        display: inline-block;
        margin-left: -7px
    }
}

.b-work-rating__count i {
    display: block;
    top: 5px;
    left: 0;
    position: absolute
}

.b-work-rating__count .b-like-icon {
    display: block;
    top: 3px;
    left: 0;
    position: absolute;
}

.b-add-form__line div {
    position: relative
}

.b-comments {
    margin-top: 40px
}

@media screen and (max-width:740px) {
    .b-comments {
        margin-top: 20px
    }
}

.b-comments__title {
    font-family: "Raleway", sans-serif;
    font-size: 30px;
    font-weight: 700;
    color: #010101;
    margin-bottom: 0;
    padding-bottom: 18px
}

.b-comments__title span {
    color: #3da2d6
}

.b-comments__list {
    margin: 0;
    padding: 0;
    list-style: none;
    display: grid;
    gap: 10px
}

.b-comments__item {
    border: 1px solid rgba(229, 231, 235, .9);
    border-radius: 18px;
    box-shadow: 0 12px 28px rgba(15, 23, 42, .06);
    padding: 20px 22px;
    font-size: 16px;
    position: relative;
    background: #fff;
    line-height: 1.5;
    margin-top: 0
}

@media screen and (max-width:640px) {
    .b-comments__item {
        padding: 16px 18px
    }
}

.b-comments__item:after,
.b-comments__item:before {
    display: none
}

.b-comments__item:first-child,
.b-comments__row:first-child {
    margin-top: 0
}

.b-comments__meta {
    margin-top: 0;
    margin-bottom: 12px;
    color: #6b7280;
    font-size: 14px;
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap
}

.b-comments__meta:after,
.b-comments__meta:before {
    content: ".";
    display: block;
    height: 0;
    overflow: hidden
}

.b-comments__meta:after {
    clear: both
}

.b-comments__meta a,
.b-comments__meta span {
    margin-right: 5px
}

.b-comments__meta .b-avatar {
    display: inline-block;
    width: 30px;
    height: 30px;
    border-radius: 50%;
    overflow: hidden;
    vertical-align: middle
}
.b-comments__meta .b-avatar img {
    display: block;
    width: 30px;
    height: 30px;
    object-fit: cover;
    border-radius: 50%
}

.b-comments__author {
    color: #111827;
    font-weight: 700
}

.b-comments__date {
    margin-left: auto;
    margin-right: 0;
    white-space: nowrap
}

.b-comments__text {
    color: #374151;
    line-height: 1.6
}

.b-comments .b-comments__item,
.b-comments .b-comments__form {
    border: 1px solid #e5e7eb;
    box-shadow: 0 12px 28px rgba(15, 23, 42, .06);
}

.b-comments .b-comments__form {
    border-radius: 10px;
}

.b-contents-slider .swiper-slide .b-mini-panel {
    box-shadow: 0 12px 28px rgba(15, 23, 42, .06);
}

.b-comments__form {
    background: #fff;
    padding: 25px;
    margin-top: 10px;
    border: 1px solid rgba(229, 231, 235, .9);
    box-shadow: 0 12px 28px rgba(15, 23, 42, .06)
}

@media screen and (max-width:640px) {
    .b-comments__form {
        padding: 15px
    }
}

.b-comments__row {
    margin-top: 25px
}

#comments-form-message+.b-comments__row {
    margin-top: 0
}

.b-comments__row label {
    display: block;
    color: #010101;
    font-family: "Raleway", sans-serif;
    font-size: 17px;
    font-weight: 700;
    line-height: 1.3529411765;
    margin-bottom: 19px
}

.b-comments__row.inline label {
    display: inline;
    margin-bottom: 0;
    font-weight: 400
}

.b-comments__row.button {
    text-align: right
}

.b-comments__row textarea {
    width: 100%;
    border: 1px solid #c4c4c4;
    padding: 12px
}

.b-add-form {
    display: table;
    width: 100%;
    table-layout: fixed;
    color: #000
}

.b-add-form__main {
    display: table-cell;
    vertical-align: top
}

@media screen and (max-width:980px) {
    .b-add-form__main {
        display: block;
        width: auto
    }
}

.b-add-form__sidebar {
    display: table-cell;
    width: 300px;
    vertical-align: top;
    padding-left: 20px
}

@media screen and (max-width:980px) {
    .b-add-form__sidebar {
        display: block;
        width: auto;
        padding-left: 0;
        margin-top: 20px
    }
}

@media screen and (max-width:980px) and (max-width:790px) {
    .b-add-form__sidebar {
        margin-top: 15px
    }
}

.b-add-form__sidebar.is-active {
    margin-left: 25.1%
}

@media screen and (max-width:790px) {
    .b-add-form__sidebar.is-active {
        margin-left: 0
    }
}

.b-add-form__row {
    display: block;
    margin-top: 20px
}

@media screen and (max-width:790px) {
    .b-add-form__row {
        margin-top: 15px
    }
}

.b-add-form__row.footer {
    margin-top: 40px;
    text-align: center
}

@media screen and (max-width:790px) {
    .b-add-form__row.footer {
        margin-top: 30px
    }
}

.b-add-form__row.footer .btn {
    margin-bottom: 49px
}

@media screen and (max-width:790px) {
    .b-add-form__row.footer .btn {
        margin-bottom: 30px
    }
}

.b-add-form__row.footer sup {
    font-weight: 700;
    color: #3da2d6
}

.b-add-form__row:first-child {
    margin-top: 0
}

.b-add-form__row input[type=email],
.b-add-form__row input[type=password],
.b-add-form__row input[type=phone],
.b-add-form__row input[type=search],
.b-add-form__row input[type=tel],
.b-add-form__row input[type=text],
.b-add-form__row select,
.b-add-form__row textarea {
    border: 1px solid #bababa;
    background: #fff
}

.b-add-form__row input[type=email]:focus,
.b-add-form__row input[type=password]:focus,
.b-add-form__row input[type=phone]:focus,
.b-add-form__row input[type=search]:focus,
.b-add-form__row input[type=tel]:focus,
.b-add-form__row input[type=text]:focus,
.b-add-form__row select:focus,
.b-add-form__row textarea:focus {
    border-color: #3da2d6
}

.b-add-form__row input[type=email].error,
.b-add-form__row input[type=password].error,
.b-add-form__row input[type=phone].error,
.b-add-form__row input[type=search].error,
.b-add-form__row input[type=tel].error,
.b-add-form__row input[type=text].error,
.b-add-form__row select.error,
.b-add-form__row textarea.error {
    border: 1px solid #c01f6f;
    background: #f7e2e1
}

.b-add-form__label {
    display: inline-block;
    width: 29.1%;
    margin-right: -4px;
    font-size: 16px;
    font-weight: 400;
    padding-right: 10px;
    box-sizing: border-box;
    vertical-align: middle;
    padding-top: 0
}

@media screen and (max-width:1080px) {
    .b-add-form__label {
        font-size: 14px;
        width: 25.1%
    }
}

@media screen and (max-width:790px) {
    .b-add-form__label {
        width: auto;
        margin-bottom: 10px;
        display: block;
        font-size: 16px
    }
}

.no-mediaqueries .b-add-form__label {
    font-size: 14px
}

.b-add-form__label sup {
    color: #40aba6;
    font-weight: 700
}

.b-add-form__text {
    display: inline-block;
    width: 70.9%;
    margin-right: -4px
}

@media screen and (max-width:790px) {
    .b-add-form__text {
        width: auto;
        margin-bottom: 10px;
        display: block
    }
}

.b-add-form__input {
    display: inline-block;
    width: 44.8%;
    margin-right: -4px;
    font-size: 16px;
    color: #000;
    font-weight: 400;
    vertical-align: middle;
    padding-right: 16px;
    box-sizing: border-box
}

@media screen and (max-width:1080px) {
    .b-add-form__input {
        width: 40.8%
    }
}

@media screen and (max-width:790px) {
    .b-add-form__input {
        width: auto;
        margin-bottom: 10px;
        display: block
    }
}

.b-add-form__input input,
.b-add-form__input textarea {
    width: 100%;
    max-width: 100%
}

.b-add-form__input textarea {
    min-height: 84px
}

.b-add-form__input label.error {
    color: #c01f6f;
    font-size: 12px;
    font-weight: 400;
    text-align: right;
    display: block !important;
    margin-top: 5px
}

.b-add-form__button {
    display: inline-block;
    width: 26%;
    margin-right: -4px;
    font-size: 16px;
    color: #000;
    font-weight: 400;
    vertical-align: top
}

@media screen and (max-width:1080px) {
    .b-add-form__button {
        width: 34%
    }
}

@media screen and (max-width:790px) {
    .b-add-form__button {
        width: auto;
        display: block
    }
}

.b-add-form__button .btn {
    padding: 8px 15px;
    font-size: 14px;
    cursor: pointer
}

.b-add-form__button .btn span {
    font-weight: 400;
    font-size: 16px
}

@media screen and (max-width:790px) {
    .b-add-form__button .btn {
        width: 100%
    }
}

.b-add-form__close {
    position: absolute;
    right: -39px;
    display: block;
    top: 6px;
    width: 18px;
    height: 18px;
    border: 2px solid #c01f6f;
    border-radius: 50%;
    text-align: center;
    line-height: 16px;
    font-weight: 400;
    color: #c01f6f;
    opacity: 1;
    font-size: 14px;
    transition: opacify .3s ease;
    will-change: opacity;
    cursor: pointer
}

@media screen and (max-width:790px) {
    .b-add-form__close {
        position: relative;
        display: block;
        top: 0;
        right: auto;
        margin-top: 10px;
        width: auto;
        height: 30px;
        line-height: 30px;
        border-radius: 30px;
        margin-bottom: 20px
    }
}

.b-add-form__close:hover {
    opacity: .7;
    text-decoration: none
}

.b-add-form__line {
    margin-left: -10px;
    margin-right: -10px;
    padding-left: 10px;
    padding-right: 10px;
    position: relative
}

.b-add-form__line:first-child .b-add-form__close {
    display: none;
    visibility: hidden
}

.b-add-form__line+.b-add-form__line {
    margin-top: 10px;
    padding-top: 9px;
    border-top: 1px solid #3da2d6
}

.b-add-form-panel {
    background: #fff;
    border-radius: 10px;
    box-shadow: 0 12px 28px rgba(15, 23, 42, .06)
}

.b-add-form-panel__header {
    background: #3da2d6;
    color: #fff;
    padding: 24px;
    border-radius: 10px 10px 0 0
}

.b-add-form-panel__header.light {
    background: #b4c45b
}

.b-add-form-panel__title {
    color: #fff;
    font-size: 21px;
    font-weight: 400;
    line-height: 1.2380952381;
    margin: 0
}

.b-add-form-panel__date {
    margin-top: 10px;
    color: #fff;
    font-size: 15px
}

.b-add-form-panel__header .b-add-form-panel__date {
    color: #fff !important
}

.light .b-add-form-panel__date {
    color: #eaf1c2
}

.b-add-form-panel__text {
    padding: 24px;
    font-size: 14px;
    color: #000
}

.b-add-form-panel__text p {
    margin-bottom: 24px
}

.b-add-form-panel__text a {
    color: #000;
    border-bottom: 1px solid #000;
    transition: border .3s ease;
    text-decoration: none
}

.b-add-form-panel__text a:hover {
    text-decoration: none;
    border-bottom-color: transparent
}

.work_data {
    border-bottom: 1px solid #3da2d6;
    margin: 0 0 20px -10px;
    padding: 0 0 19px 10px;
    counter-increment: my-awesome-counter;
    position: relative
}

.work_data .b-add-form__row:first-child .b-add-form__label .star:before {
    content: "№" counter(my-awesome-counter);
    margin: 0 .25rem;
    font-weight: 700
}

.work_data+.work_data .b-add-form__close {
    display: block;
    visibility: visible
}

.b-add-form-panel__footer {
    padding: 24px;
    border-top: 1px solid #e5e5e5
}

.b-add-form-panel__price {
    font-size: 14px
}

.b-add-form-panel__price:after,
.b-add-form-panel__price:before {
    content: ".";
    display: block;
    height: 0;
    overflow: hidden
}

.b-add-form-panel__price:after {
    clear: both
}

.b-add-form-panel__price>span {
    float: right;
    font-weight: 700
}

.b-add-form-panel__price .b-rub {
    color: #3da2d6;
    font-weight: 400
}

.b-add-form-panel__price+.b-add-form-panel__price {
    margin-top: 20px
}

.b-add-form-panel__price.big {
    font-weight: 700;
    vertical-align: middle;
    padding-top: 10px;
    line-height: 1
}

.b-add-form-panel__price.big>span {
    margin-top: -10px;
    font-size: 32px
}

.b-add-form-panel__price .odometer {
    margin-top: -6px
}

.b-add-form-tab {
    position: relative
}

.b-add-form-tab ul {
    list-style: none;
    padding: 0;
    margin: 0 0 27px;
    border-radius: 40px;
    display: inline-block;
    vertical-align: top
}

@media screen and (max-width:790px) {
    .b-add-form-tab ul {
        width: 100%
    }
}

.b-add-form-tab ul li {
    background: #fff;
    border-radius: 0 40px 40px 0;
    float: left;
    margin-top: 0;
    vertical-align: top;
    padding: 0;
    transition: background .5s ease;
    border: 2px solid #3da2d6;
    position: relative
}

@media screen and (max-width:790px) {
    .b-add-form-tab ul li {
        width: 50%;
        box-sizing: border-box;
        text-align: center
    }
}

.b-add-form-tab ul li:after {
    display: none
}

.b-add-form-tab ul li:before {
    content: "";
    opacity: 0;
    transition: opacity .5s ease;
    position: absolute;
    width: 0;
    bottom: -11px;
    left: 50%;
    margin-left: -11px;
    height: 0;
    border-style: solid;
    border-width: 12px 11px 0;
    border-color: #3da2d6 transparent transparent
}

.no-rgba .b-add-form-tab ul li:before {
    display: none;
    border-color: #3da2d6 transparent transparent
}

.b-add-form-tab ul li:first-child {
    border-radius: 40px 0 0 40px
}

.b-add-form-tab ul li a {
    line-height: 35px;
    padding: 0 35px;
    font-size: 16px;
    color: #3da2d6;
    display: block;
    -webkit-user-select: none;
    user-select: none;
    transition: color .5s ease
}

@media screen and (max-width:790px) {
    .b-add-form-tab ul li a {
        font-size: 18px;
        line-height: 45px;
        padding: 0 10px
    }
}

.b-add-form-tab ul li:hover {
    background: #f8f8f8
}

.b-add-form-tab ul li.active {
    background: #3da2d6
}

.b-add-form-tab ul li.active:before,
.b-step-four__sidebar .jq-radio.checked+label:before {
    opacity: 1
}

.b-add-form-tab__subtext {
    position: absolute;
    top: -8px;
    left: 330px;
    width: 225px;
    color: #565656;
    font-size: 14px;
    font-style: italic;
    line-height: 17px
}

@media screen and (max-width:1100px) {
    .b-add-form-tab__subtext {
        display: none;
        visibility: hidden
    }
}

.b-add-form-tab__subtext:after {
    content: "";
    display: none
}

.b-add-form__helper {
    color: #565656;
    font-size: 14px
}

.b-add-form__helper p {
    margin-bottom: 0
}

.b-step-final__description a {
    text-decoration: none;
    color: #398581;
    border-bottom: 1px solid #398581;
    transition: border .3s ease
}

.b-step-final__description a:hover {
    border-bottom-color: transparent
}
.no-opacity .b-step-four__sidebar label:before {
    display: none
}

.b-step-slider {
    position: relative;
    margin-bottom: 60px
}

@media screen and (max-width:555px) {
    .b-step-slider {
        margin-bottom: 30px
    }
}

.b-step-slider__label {
    float: left;
    display: block;
    width: 210px;
    color: #000;
    font-size: 23px;
    font-weight: 700;
    line-height: 27px
}

@media screen and (max-width:555px) {
    .b-step-slider__label {
        float: none;
        width: auto;
        margin-bottom: 10px
    }
}

.b-step-slider__main {
    margin-left: 210px;
    padding-top: 10px
}

@media screen and (max-width:555px) {
    .b-step-slider__main {
        margin-left: 0
    }
}

.b-step-slider__range {
    width: 100%;
    position: relative;
    height: 9px;
    border-radius: 9px;
    background-color: #dfdfdf
}

.b-step-slider__range-inner {
    background: #3da2d6;
    height: 9px;
    border-radius: 9px;
    position: absolute;
    top: 0;
    left: 0
}

.b-step-slider__range-inner i {
    border-radius: 50%;
    position: absolute;
    margin-top: -17px;
    top: 50%;
    right: -17px;
    width: 34px;
    height: 34px;
    display: block;
    background-color: #6ad6d1
}

@media screen and (max-width:555px) {
    .b-step-slider__range-inner i {
        margin-top: -11px;
        right: -11px;
        width: 22px;
        height: 22px
    }
}

.b-step-four__main {
    display: table;
    table-layout: fixed;
    width: 100%
}

.b-step-four__text {
    display: table-cell;
    background: #fff;
    border-radius: 10px;
    box-shadow: 0 12px 28px rgba(15, 23, 42, .06);
    padding: 32px;
    width: 60%
}

@media screen and (max-width:750px) {
    .b-step-four__text {
        display: block;
        padding: 20px
    }
}

.b-step-four__text h3 {
    color: #000;
    font-size: 25px;
    font-weight: 400;
    line-height: 35px;
    margin: 0
}

.b-step-four__sidebar {
    width: 396px;
    padding-left: 24px;
    display: table-cell;
    vertical-align: top;
    position: relative
}

.b-step-four--start .b-step-four__sidebar {
    vertical-align: middle;
}

.b-step-four--start .b-step-four__sidebar::before {
    display: none;
}

.b-step-four--start .b-step-four__sidebar h4 {
    display: none;
}

.b-step-four--start .b-step-four__sidebar > .b-step-four__row {
    margin-top: 0;
    margin-bottom: 0;
    margin-left: 0;
    margin-right: 0;
}

@media screen and (max-width:750px) {
    .b-step-four__main {
        display: block;
    }

    .b-step-four__sidebar {
        display: block;
        padding-left: 0;
        padding-top: 12px;
        padding-bottom: 12px;
        margin-top: 20px;
        width: auto
    }
}

.b-step-four__sidebar > h4,
.b-step-four__sidebar > form,
.b-step-four__sidebar > .b-step-four__row {
    position: relative;
    z-index: 1;
    margin-left: 24px;
    margin-right: 24px;
    margin-bottom: 24px;
}

.b-step-four__sidebar::before {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 24px;
    background: #fff;
    border-radius: 10px;
    box-shadow: 0 12px 28px rgba(15, 23, 42, .06);
}

@media screen and (max-width:750px) {
    .b-step-four__sidebar::before {
        left: 0;
    }

    .b-step-four__sidebar > h4,
    .b-step-four__sidebar > form,
    .b-step-four__sidebar > .b-step-four__row {
        margin-left: 20px;
        margin-right: 20px;
        margin-bottom: 20px;
    }

    .b-step-four--start .b-step-four__sidebar > .b-step-four__row {
        margin-top: 20px;
        margin-bottom: 20px;
    }

    .b-step-four--start .b-step-four__sidebar::before {
        display: none;
    }

    .b-step-four--start .b-step-four__sidebar > .b-step-four__row {
        margin-left: 0;
        margin-right: 0;
    }
}

.b-step-four__sidebar h4 {
    margin-top: 24px;
    margin-bottom: 16px;
    color: #000;
    font-size: 16px;
    font-weight: 700;
    line-height: 27px
}

@media screen and (max-width:750px) {
    .b-step-four__sidebar h4 {
        margin-top: 20px;
        margin-bottom: 12px;
        padding-left: 8px;
        padding-right: 8px
    }
}

.b-step-four__sidebar .jq-radio {
    display: none !important
}

.b-step-four__sidebar .jq-radio.checked+label {
    border-color: #3da2d6;
    color: #398581
}

.b-step-four__sidebar label {
    padding: 16px 16px 16px 55px;
    border: 2px solid #fff;
    position: relative;
    background: #fff;
    font-size: 16px;
    color: #000;
    line-height: 1.1;
    display: block;
    cursor: pointer;
    transition: border .3s ease, color .3s ease
}

.b-step-four__sidebar label:after {
    content: " ";
    border: 1px solid #707070;
    border-radius: 50%;
    display: block;
    width: 16px;
    height: 16px;
    position: absolute;
    top: 16px;
    left: 16px
}

.b-step-four__sidebar label:before {
    content: " ";
    position: absolute;
    width: 8px;
    height: 8px;
    background: #3da2d6;
    border-radius: 50%;
    top: 21px;
    left: 21px;
    transition: opacity .3s ease;
    opacity: 0
}

.b-step-four__row {
    margin-bottom: 18px
}

.b-step-four__row [type=radio] {
    display: none
}

.b-step-four__row [type=radio]:checked+label:before {
    opacity: 1
}

.b-step-four__row .btn {
    font-size: 21px;
    font-weight: 400;
    width: 100%;
    font-family: "Roboto", sans-serif
}

.b-step-four__row.footer,
.b-step-four__row:last-child {
    margin-bottom: 0
}

@media screen and (max-width:750px) {
    .b-step-slider {
        margin-bottom: 24px;
    }

    .b-step-four__text h3 {
        font-size: 21px;
        line-height: 1.45;
    }

    .b-step-four__sidebar label {
        padding: 14px 14px 14px 48px;
        font-size: 15px;
        line-height: 1.35;
    }

    .b-step-four__sidebar label:after {
        top: 14px;
        left: 14px;
    }

    .b-step-four__sidebar label:before {
        top: 19px;
        left: 19px;
    }

    .b-step-four__row {
        margin-bottom: 14px;
    }

    .b-step-four__row .btn {
        font-size: 18px;
        line-height: 1.35;
    }
}

@media screen and (max-width:480px) {
    .b-step-four__text {
        padding: 16px;
    }

    .b-step-four__sidebar {
        padding-top: 8px;
        padding-bottom: 8px;
        margin-top: 16px;
    }

    .b-step-four__sidebar > h4,
    .b-step-four__sidebar > form,
    .b-step-four__sidebar > .b-step-four__row {
        margin-left: 16px;
        margin-right: 16px;
        margin-bottom: 16px;
    }

    .b-step-four--start .b-step-four__sidebar > .b-step-four__row {
        margin-top: 16px;
        margin-bottom: 16px;
    }

    .b-step-four--start .b-step-four__sidebar::before {
        display: none;
    }

    .b-step-four--start .b-step-four__sidebar > .b-step-four__row {
        margin-left: 0;
        margin-right: 0;
    }

    .b-step-four__sidebar h4 {
        margin-top: 20px;
        margin-bottom: 12px;
        line-height: 1.4;
        padding-left: 8px;
        padding-right: 8px;
    }

    .b-step-four__sidebar label {
        padding: 12px 12px 12px 44px;
        font-size: 14px;
    }

    .b-step-four__sidebar label:after {
        top: 12px;
        left: 12px;
    }

    .b-step-four__sidebar label:before {
        top: 17px;
        left: 17px;
    }

    .b-step-four__row .btn {
        font-size: 16px;
    }

    .b-step-four__sidebar > form {
        padding-bottom: 4px;
    }
}

.b-step-final__header {
    margin-bottom: 57px;
    position: relative;
    font-size: 15px;
    color: #000;
    background: #fff;
    border-radius: 10px;
    box-shadow: 0 12px 28px rgba(15, 23, 42, .06);
    padding: 32px
}

.b-step-final__header:after,
.b-step-final__header:before {
    content: ".";
    display: block;
    height: 0;
    overflow: hidden
}

.b-step-final__header:after {
    clear: both
}

@media screen and (max-width:1000px) {
    .b-step-final__header {
        font-size: 14px
    }
}

@media screen and (max-width:450px) {
    .b-step-final__header {
        margin-bottom: 25px;
        padding: 20px
    }
}

.b-step-final__description {
    width: 50%;
    float: left;
    vertical-align: top;
    padding-right: 30px;
    box-sizing: border-box;
    line-height: 1.7
}

@media screen and (max-width:920px) {
    .b-step-final__description {
        width: auto;
        float: none;
        padding-right: 0
    }
}

.b-step-final__info {
    max-width: 50%;
    padding-left: 30px;
    float: right;
    box-sizing: border-box;
    margin-bottom: -8px
}

@media screen and (max-width:920px) {
    .b-step-final__info {
        width: auto;
        float: none;
        padding: 0;
        max-width: 100%
    }
}

@media screen and (max-width:920px) {
    .b-step-final__info dl {
        width: 100%;
        display: block
    }
}

.b-step-final__info dl dd,
.b-step-final__info dl dt {
    display: inline-block;
    box-sizing: border-box;
    vertical-align: top
}

.b-step-final__info dl dt {
    margin-right: 0 -4px 8px 0;
    width: 40%;
    margin-bottom: 13px;
    padding-right: 5px
}

@media screen and (max-width:920px) {
    .b-step-final__info dl dt {
        text-align: right
    }
}

@media screen and (max-width:450px) {
    .b-step-final__info dl dt {
        display: block;
        margin: 0 0 5px;
        text-align: left;
        padding-right: 0
    }
}

.b-step-final__info dl dd {
    margin: 0 -4px 8px 0;
    width: 60%;
    font-weight: 700;
    padding-left: 5px
}

@media screen and (max-width:450px) {
    .b-step-final__info dl dd {
        display: block;
        margin: 0 0 8px;
        padding-left: 0
    }
}

@media screen and (max-width:750px) {
    .b-step-final__description,
    .b-step-final__info {
        width: 100%;
        max-width: 100%;
    }
}

.b-step-final__bg {
    position: absolute;
    top: 0;
    bottom: 0;
    left: 50%;
    z-index: 1;
    background: #c5c5c5;
    display: block;
    width: 1px
}

@media screen and (max-width:920px) {
    .b-step-final__bg {
        width: 100%;
        display: block;
        position: relative;
        height: 1px;
        margin: 30px 0;
        left: auto;
        top: auto;
        bottom: auto
    }
}

.b-step-final__text {
    background: #fff;
    border-radius: 10px;
    box-shadow: 0 12px 28px rgba(15, 23, 42, .06);
    padding: 60px
}

@media screen and (max-width:670px) {
    .b-step-final__text {
        padding: 25px
    }
}

@media screen and (max-width:480px) {
    .b-step-final__header {
        padding: 16px;
    }

    .b-step-final__bg {
        margin: 20px 0;
    }

    .b-step-final__text {
        padding: 20px 16px;
    }
}

.b-step-final__title {
    margin: 0 0 10px;
    font-weight: 400;
    color: #3da2d6;
    font-size: 26px;
    text-align: center
}

@media screen and (max-width:450px) {
    .b-step-final__title {
        font-size: 24px
    }
}

.b-step-final__subtitle {
    color: #000;
    font-weight: 400;
    font-size: 15px;
    text-align: center
}

.b-step-itogi th.last {
    text-align: center
}

.b-step-final__footer {
    margin-top: 60px;
    text-align: center
}

.b-step-final__footer .btn {
    font-weight: 400;
    font-size: 21px
}

.b-step-itogi {
    font-size: 16px
}

@media screen and (max-width:850px) {
    .b-step-itogi {
        display: block;
        background: transparent;
        border-radius: 0;
        box-shadow: none;
        overflow: visible;
        width: 100%;
        table-layout: auto;
    }

    .b-step-itogi tbody,
    .b-step-itogi tr {
        display: flex;
        flex-direction: column;
        width: 100%;
    }
}

.b-step-itogi th {
    vertical-align: bottom;
    color: #9a9a9a;
    font-weight: 400;
    padding: 2px 15px 10px
}

.b-step-itogi tr.header th:first-child {
    border-radius: 10px 0 0 0
}

.b-step-itogi tr.header th:last-child {
    border-radius: 0 10px 0 0
}

.b-step-itogi tr.header th {
    box-shadow: none
}

tr.b-step-itogi__head-gap {
    background: #f3f4f6
}

tr.b-step-itogi__head-gap td {
    height: 15px !important;
    min-height: 15px !important;
    max-height: 15px !important;
    line-height: 15px !important;
    font-size: 0 !important;
    padding: 0 !important;
    border: 0 !important;
    background: transparent !important
}

.b-step-itogi tbody tr:nth-last-child(2) td:first-child {
    border-radius: 0 0 0 10px
}

.b-step-itogi tbody tr:nth-last-child(2) td:last-child {
    border-radius: 0 0 10px 0
}

.b-step-itogi tbody tr:not(.b-step-itogi__head-gap):not(.b-step-itogi__separator) td {
    box-shadow: none
}

.b-step-itogi th.country span {
    display: inline-block;
    min-width: 140px
}

.b-step-itogi td {
    vertical-align: middle;
    padding: 15px 0 15px 15px
}

.b-step-itogi td.name,
.b-step-itogi td.subname {
    width: 250px
}

@media screen and (max-width:850px) {
    .b-step-itogi td {
        display: block;
        margin-right: 0;
        vertical-align: top;
        padding: 15px 10px;
        border-top: 1px solid #eaeaea;
        width: 100%;
        box-sizing: border-box
    }

    .b-step-itogi td:first-child {
        border-top: 0
    }

    .b-step-itogi td:before {
        display: block;
        color: #000;
        margin-bottom: 10px;
        font-weight: 700;
        font-size: 16px
    }

    .b-step-itogi td.name,
    .b-step-itogi td.subname {
        width: 100%
    }

    .b-step-itogi td.name:before {
        content: "ФИО участника"
    }

    .b-step-itogi td [hidden] {
        display: block
    }

    .b-step-itogi td.subname:before {
        content: "ФИО руководителя"
    }

    .b-step-itogi td.description:before {
        content: "Наименование ОУ"
    }

    .b-step-itogi td.country:before {
        content: "Страна"
    }
}

.b-step-itogi td.last {
    width: 76px;
    color: #fff;
    background: #3da2d6;
    font-size: 28px;
    text-align: center;
    padding-right: 15px
}

.b-step-itogi__mobile-last-label {
    display: none
}

.b-step-itogi__mobile-result {
    display: none
}

@media screen and (max-width:850px) {
    .b-step-itogi td.last {
        display: none !important;
    }

    .b-step-itogi td.url {
        text-align: left !important;
    }
}

@media screen and (max-width:850px) {
    .b-step-itogi tbody tr:not(.b-step-itogi__head-gap):not(.b-step-itogi__separator) td,
    .b-step-itogi tr.header th {
        box-shadow: none;
    }
}

.b-step-itogi td.grey {
    color: #737373
}

@media screen and (max-width:850px) {
    .b-step-itogi tr.header {
        display: none
    }

    .b-step-itogi tr {
        position: relative;
        display: block
    }

    .b-step-itogi tr.active {
        border-bottom: 1px solid #3da2d6
    }
}

@media screen and (max-width:850px) {
    .b-step-itogi__mobile-result {
        display: block !important;
        width: 100%;
        margin: 0 !important;
        padding: 0 !important;
        border-radius: 0 !important;
        box-shadow: none !important;
        background: transparent !important;
    }

    .b-step-itogi__mobile-result td {
        display: block;
        width: 100%;
        box-sizing: border-box;
        padding: 12px 15px !important;
        background: #3da2d6 !important;
        color: #fff !important;
        border: 0 !important;
        border-radius: 10px 10px 0 0;
    }

    .b-step-itogi__mobile-result + tr td,
    .b-step-itogi__mobile-result + tr td:first-child,
    .b-step-itogi__mobile-result + tr td:last-child {
        border-radius: 0 !important;
    }

    .b-step-itogi tbody tr:not(.header):not(.b-step-itogi__head-gap):not(.b-step-itogi__separator):not(.b-step-itogi__mobile-result) {
        display: flex !important;
        flex-direction: column !important;
        width: 100% !important;
        position: static !important;
        margin: 0 !important;
        padding: 0 !important;
        border-radius: 0 !important;
        box-shadow: none !important;
        background: transparent !important;
        overflow: visible !important;
    }

    .b-step-itogi tbody tr:not(.header):not(.b-step-itogi__head-gap):not(.b-step-itogi__separator):not(.b-step-itogi__mobile-result) td {
        width: 100% !important;
        margin-right: 0 !important;
        box-sizing: border-box !important;
        border-radius: 0 !important;
        box-shadow: none !important;
        background: #fff !important;
        clip-path: none !important;
    }

    .b-step-itogi__mobile-last-label {
        display: block;
        margin-bottom: 4px;
        color: rgba(255,255,255,.92);
        font-size: 12px;
        font-weight: 600;
        line-height: 1.2;
        text-transform: uppercase;
        letter-spacing: .04em;
    }

    .b-step-itogi__mobile-last-value {
        display: block;
        color: #fff;
        font-size: 20px;
        font-weight: 700;
        line-height: 1.2;
    }

    .b-step-itogi tbody tr:not(.header):not(.b-step-itogi__head-gap):not(.b-step-itogi__separator):not(.b-step-itogi__mobile-result) td.name {
        border-top: 0 !important;
    }

    .b-step-itogi tbody tr:not(.b-step-itogi__mobile-result) td:first-child,
    .b-step-itogi tbody tr:not(.b-step-itogi__mobile-result) td:last-child {
        border-radius: 0 !important;
    }

    .b-step-itogi__mobile-result + tr,
    .b-step-itogi__mobile-result + tr td,
    .b-step-itogi__mobile-result + tr td.name,
    .b-step-itogi__mobile-result + tr td:first-child,
    .b-step-itogi__mobile-result + tr td:last-child {
        border-radius: 0 !important;
        box-shadow: none !important;
    }
}

@media screen and (max-width:850px) {
    .b-step-itogi tbody tr:not(.header):not(.b-step-itogi__head-gap):not(.b-step-itogi__separator):not(.b-step-itogi__mobile-result) {
        display: grid !important;
        grid-template-columns: 1fr;
        column-gap: 18px;
        row-gap: 0;
        align-items: start;
    }

    .b-step-itogi tbody tr:not(.header):not(.b-step-itogi__head-gap):not(.b-step-itogi__separator):not(.b-step-itogi__mobile-result) td {
        width: 100% !important;
    }
}

@media screen and (max-width:560px) {
    .b-step-itogi tbody tr:not(.header):not(.b-step-itogi__head-gap):not(.b-step-itogi__separator):not(.b-step-itogi__mobile-result) {
        display: grid !important;
        grid-template-columns: 1fr;
        align-items: center;
    }

    .b-step-itogi tbody tr:not(.header):not(.b-step-itogi__head-gap):not(.b-step-itogi__separator):not(.b-step-itogi__mobile-result) td {
        text-align: center;
    }

    .b-step-itogi td:before {
        text-align: center;
    }

    .b-step-itogi td.score:before {
        content: "Количество баллов";
    }
}

@media screen and (max-width:850px) {
    .wrapStepItogi tbody tr:not(.header):not(.b-step-itogi__head-gap):not(.b-step-itogi__separator):not(.b-step-itogi__mobile-result) {
        display: grid !important;
        grid-template-columns: 1fr !important;
        row-gap: 0;
    }

    .wrapStepItogi tbody tr:not(.header):not(.b-step-itogi__head-gap):not(.b-step-itogi__separator):not(.b-step-itogi__mobile-result) td {
        text-align: left !important;
    }

    .wrapStepItogi td:before {
        text-align: left !important;
    }

    .wrapStepItogi td[data-label]:before {
        content: attr(data-label);
        display: block;
        color: #000;
        margin-bottom: 10px;
        font-weight: 700;
        font-size: 16px;
        text-align: left !important;
    }

    .wrapStepItogi .b-work-document {
        display: block;
        width: 100%;
    }

    .wrapStepItogi .b-work-document + .b-work-document {
        margin-top: 10px;
    }
}

@media screen and (min-width:851px) and (max-width:1199px) {
    .b-table-scroll {
        width: 100%;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }

    .b-table-scroll .wrapStepItogi {
        min-width: 1100px;
    }
}

.b-step-itogi tr.active td {
    border: 1px solid #3da2d6;
    border-left: 0;
    border-right: 0
}

@media screen and (max-width:850px) {
    .b-step-itogi tr.active td {
        border-bottom: 0;
        border-top: 1px solid #eaeaea;
        border-left: 1px solid #3da2d6;
        border-right: 1px solid #3da2d6
    }
}

.b-step-itogi tr.active td:first-child {
    border-left: 1px solid #3da2d6
}

@media screen and (max-width:850px) {
    .b-step-itogi tr.active td:first-child {
        border-top: 1px solid #3da2d6
    }
}

.b-step-itogi tr.active+.active td {
    border-top: 0
}

.b-step-itogi .icon-arrow-down-3,
.b-step-itogi .icon-arrow-up-3 {
    display: inline-block;
    margin-left: 5px;
    height: 8px;
    line-height: 1;
    vertical-align: middle
}

.b-step-itogi .icon-arrow-down-3:before,
.b-step-itogi .icon-arrow-up-3:before {
    content: " ";
    width: 14px;
    height: 8px;
    display: inline-block;
    vertical-align: sub
}

.b-step-itogi .icon-arrow-down-3 {
    background: url(../images/down-ancor.svg) no-repeat 0 0
}

.no-svg .b-step-itogi .icon-arrow-down-3 {
    background: url(../images/down-ancor.png) no-repeat 0 0
}

.b-step-itogi .icon-arrow-up-3 {
    background: url(../images/up-ancor.svg) no-repeat 0 0;
    margin-top: -2px
}

.no-svg .b-step-itogi .icon-arrow-up-3 {
    background: url(../images/up-ancor.png) no-repeat 0 0
}

.b-step-itogi .js-stools-column-order {
    white-space: nowrap
}

tr.b-step-itogi__separator {
    background: 0 0
}

tr.b-step-itogi__separator td {
    height: 15px !important;
    min-height: 15px !important;
    max-height: 15px !important;
    line-height: 15px !important;
    font-size: 0 !important;
    padding: 0 !important;
    border: 0 !important;
    background: transparent !important
}

@media screen and (max-width:850px) {
    .b-step-itogi tbody tr:not(.header):not(.b-step-itogi__head-gap):not(.b-step-itogi__separator) {
        display: flex !important;
        flex-direction: column !important;
        position: static !important;
        width: 100% !important;
    }

    .b-step-itogi tbody tr:not(.header):not(.b-step-itogi__head-gap):not(.b-step-itogi__separator) td {
        width: 100% !important;
        margin-right: 0 !important;
        box-sizing: border-box !important;
    }

    .b-step-itogi tbody tr:not(.header):not(.b-step-itogi__head-gap):not(.b-step-itogi__separator) td.last {
        display: block !important;
        order: -1 !important;
        background: #3da2d6 !important;
        color: #fff !important;
        text-align: left !important;
        padding: 12px 15px !important;
        border-radius: 10px 10px 0 0 !important;
        font-size: 18px !important;
        line-height: 1.3 !important;
        border-top: 0 !important;
    }

    .b-step-itogi tbody tr:not(.header):not(.b-step-itogi__head-gap):not(.b-step-itogi__separator) td.last:before {
        display: none !important;
    }

    .b-step-itogi tbody tr:not(.header):not(.b-step-itogi__head-gap):not(.b-step-itogi__separator) td.name {
        border-top: 0 !important;
    }
}

.b-work-document {
    padding-left: 50px;
    position: relative;
    min-height: 37px
}

.b-work-document+.b-work-document {
    margin-top: 1em
}

.b-step-itogi__link {
    text-decoration: underline;
    text-decoration-style: dotted;
    color: #000
}

.b-step-itogi .b-step-itogi__link {
    position: relative;
    display: inline-block;
    padding-left: 40px;
    vertical-align: middle
}

.b-step-itogi__link i {
    display: block;
    position: absolute;
    left: 0;
    top: 50%;
    margin-top: -18px
}

.b-step-itogi__link:hover {
    text-decoration: none
}

.b-step-itogi__link.nolink {
    padding-left: 0
}

.b-step-itogi__link.nolink span {
    border-bottom-color: transparent;
    margin-left: 0
}

.wrapStepItogi {
    font-size: 14px;
}

.hide {
    display: none;
}

.hidden {
    display: none;
}

.visually-hidden {
    display: none;
}

.chosen-container-multi .chosen-choices {
    box-shadow: none;
    border: 0;
}

.chosen-container-multi .chosen-choices li.search-choice {
    border: 0;
    background: #3da2d6;
    color: #fff;
    box-shadow: none;
    border-radius: 25px;
    display: block;
    padding: 3px 20px;
}

.chosen-container .chosen-drop {
    border: 0;
}

.chosen-container .chosen-results li.highlighted {
    background-color: #fff;
    background-image: linear-gradient(#3da2d6 20%, #3da2d6 90%);
}

.js-stools .chosen-container {
    width: 100% !important;
}

.js-stools .js-stools-container-filters-visible {
    display: grid !important;
}

.load-more-container {
    display: flex;
    justify-content: center;
    margin-top: 50px;
}

.redact {
    display: block;
    font-size: 13px;
    white-space: nowrap;
}

.linkpdf {
    display: flex;
    align-items: center;
    gap: 5px;
}

.linkpdf svg {
    flex: 1;
    width: 100%;
    max-width: 30px;
}

.linkpdf span {
    flex: 1;
}

.b__contact {
    background: #fff;
    padding: 1.5rem;
    border-radius: 10px;
    box-shadow: 0 12px 28px rgba(15, 23, 42, .06)
}

.b__contact .b__contact-info {
    float: left;
    width: 48%
}

.b__contact .b__contact-form {
    margin-left: 52%
}

.b__contact .b__contact-form .control-group {
    margin-bottom: .5rem
}

.b__contact .b__contact-form .control-label {
    margin-bottom: .25rem
}

.b__contact .b__contact-form .text {
    font-size: .75rem;
    color: #666
}

.b__contact .b__contact-form input[type=email],
.b__contact .b__contact-form input[type=text],
.b__contact .b__contact-form textarea {
    box-sizing: border-box;
    width: 100%;
    background: #f2f2f2
}

.b-slider {
    position: relative;
    z-index: 1;
}

/* ОБЩИЙ КОНТЕЙНЕР СЛАЙДЕРА */
.topSlide {
  position: relative;
  width: 100%;
  height: 330px;
  overflow: hidden;
}

.topSlide .bg-image {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: 0;
}

.slide-content {
  position: relative;
  z-index: 2;
  display: flex;
  justify-content: space-between;
  align-items: center;
  height: 330px;
  padding: 20px 5% 56px;
  box-sizing: border-box;
}

#main-slider {
  margin-bottom: 0 !important;
  padding-bottom: 0 !important;
  overflow: hidden;
}

#main-slider .swiper-wrapper {
  align-items: stretch;
}

#main-slider .swiper-slide {
  height: 330px !important;
  overflow: hidden;
}

/* MOBILE */
@media (max-width: 768px) {
  .topSlide {
    height: auto;
    min-height: 330px;
  }

  .topSlide .bg-image {
    height: 100%;
  }

  .slide-content {
    height: auto;
    min-height: 330px;
    padding: 30px 20px 70px;
    align-items: flex-start;
  }

  #main-slider .swiper-slide {
    height: auto !important;
  }

  #main-slider .swiper-wrapper {
    height: auto !important;
  }

  .txtBlock .name {
    margin-top: 0;
    line-height: 1.25;
  }
}

/* Левая часть — текст (2/3) */
.txtBlock {
  flex: 0 0 66.66%;
  color: white;
  max-width: none;
  min-width: 0;
}

/* Заголовок */
.txtBlock .name {
  font-size: 36px;
  font-weight: 700;
  line-height: 1.3;
  margin-bottom: 15px;
}

/* Подзаголовок */
.txtBlock .txtText {
  font-size: 18px;
  font-weight: 400;
  line-height: 1.6;
  margin-bottom: 25px;
  overflow-wrap: anywhere;
}

/* Кнопка */
.linkSlider {
  display: inline-block;
  background-color: #fdd835;
  color: #000;
  font-weight: 600;
  font-size: 16px;
  padding: 12px 24px;
  border-radius: 12px;
  text-decoration: none;
  transition: background-color 0.3s ease;
}

.linkSlider:hover {
  background-color: #fbc02d;
}

/* Правая часть — картинка (1/3) */
.rightImage {
  flex: 0 0 33.33%;
  display: flex;
  justify-content: flex-end;
  align-items: center;
}

.rightImage img {
  max-height: 100%;
  max-width: 100%;
  object-fit: contain;
}

/* Прев и некст — белые стрелки */
.swiper-button-prev,
.swiper-button-next {
  color: #fff !important; /* Делаем стрелки белыми */
  fill: #fff !important;  /* Для SVG */
}

/* Можно увеличить размер, если нужно */
.swiper-button-prev::after,
.swiper-button-next::after {
  font-size: 24px; /* Или больше, если надо */
}


/* ==== ПАГИНАЦИЯ СЛАЙДЕРА (SWIPER PAGINATION) ==== */

.b-slider .swiper-pagination {
    position: absolute;
    bottom: 10px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 11;
    width: auto;
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 0;
    margin: 0;
    pointer-events: auto;
  }
  
  .b-slider .swiper-pagination-bullet {
    background: #ffffff;
    opacity: 0.6;
    margin: 0 5px;
    width: 10px;
    height: 10px;
    border-radius: 50%;
    transition: all 0.3s ease;
  }
  
  .b-slider .swiper-pagination-bullet-active {
    opacity: 1;
    transform: scale(1.2);
    background: #fff;
  }
  
  /* Пагинация Swiper — принудительное позиционирование */

#main-slider {
    margin-bottom: 0 !important;
    padding-bottom: 0 !important;
    background-color: transparent !important;
    overflow: hidden;
  }

  #main-slider .swiper-slide {
    height: 330px !important; /* если фиксирована */
    overflow: hidden;
  }
  
  #main-slider .swiper-wrapper {
    height: 330px !important;
  }

#main-slider .swiper-pagination {
    position: absolute !important;
    bottom: 15px !important;
    left: 50% !important;
    transform: translateX(-50%) !important;
    z-index: 20 !important;
    display: flex !important;
    justify-content: center;
    align-items: center;
    width: auto !important;
    pointer-events: auto;
    height: auto;
  }
  
  /* Стиль точек */
  #main-slider .swiper-pagination-bullet {
    background: #fff !important;
    opacity: 0.6 !important;
    width: 10px !important;
    height: 10px !important;
    border-radius: 50% !important;
    margin: 0 5px !important;
    transition: all 0.3s ease;
  }
  
  /* Активная точка */
  #main-slider .swiper-pagination-bullet-active {
    opacity: 1 !important;
    transform: scale(1.2) !important;
  }
  

/* КОНЕЦ ОБЩЕГО КОНТЕЙНЕРА СЛАЙДЕРА */

/* КАРТОЧКИ ПРЕВЬЮ КОНКУРСОВ */

/* Заголовок */
.b-section__head.inside-dark {
    padding: 0 0 40px 20px; /* или как в остальной секции */
  }
  
  .b-section__title.white {
    color: #fff;
    margin: 0;
    font-size: 28px;
    font-weight: bold;
  }
  

.item--wider {
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  }
  
  .item--wider .img img {
    width: 100%;            /* изображение растягивается по карточке */
    height: auto;
  }  
  
  /* Тег внутри изображения */
  .img {
    position: relative;
  }
  
  .contest-tag {
    position: absolute;
    top: 5px;
    left: 5px;
    padding: 4px 8px;
    font-size: 14px; /* было 12px, увеличено на 50% */
    border-radius: 4px;
    z-index: 2;
  }

  .item .img .contest-tags,
  .b-contest-grid__item .img .contest-tags,
  .contests-swiper .img .contest-tags {
    position: absolute;
    top: 5px;
    left: 5px;
    z-index: 2;
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
    max-width: calc(100% - 10px);
  }

  .item .img .contest-tags .contest-tag,
  .b-contest-grid__item .img .contest-tags .contest-tag,
  .contests-swiper .img .contest-tags .contest-tag {
    position: static;
    top: auto;
    left: auto;
    z-index: auto;
    opacity: 0.85;
  }

  .contest-tag--icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    min-width: 32px;
    min-height: 32px;
    padding: 4px;
    line-height: 0;
  }

  .contest-tag--icon .contest-tag__icon {
    display: block;
    width: 24px;
    height: 24px;
    max-width: 24px;
    max-height: 24px;
    object-fit: contain;
    flex: 0 0 24px;
  }
  
  /* Даты + Осталось */
  .date-row {
    color: #000;
    font-size: 14px;
    margin-top: 5px;
    line-height: 1.4;
  }
  
  .links-single {
    margin-top: 10px;           /* отступ сверху */
    font-size: 14px;            /* уменьшенный шрифт */
    text-align: left;           /* можно оставить по умолчанию */
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
  }

  .separator {
    margin: 0 5px;
  }  

  /*СЛАЙДЕР КОНКУРСОВ НА ГЛАВНОЙ*/
  .contests-swiper .swiper-slide {
    width: 350px; /* Ширина карточки */
    flex-shrink: 0;
    margin-right: 20px; /* Дополнительный отступ */
  }
  
  /* Контейнер слайдера */
.b-slider-contents {
    padding: 20px 0;
    overflow: hidden;
    position: relative;
  }
  
  /* Сам слайдер (обязателен overflow: visible!) */
  .contests-swiper {
    overflow: visible;
  }
  
  /* Wrapper */
  .contests-swiper .swiper-wrapper {
    display: flex;
    flex-wrap: nowrap;
    align-items: stretch;
  }
  
  /* Слайды */
  .contests-swiper .swiper-slide {
    width: 50%;
    flex-shrink: 0;
    margin-right: 0;
  }
  
  /* Карточка */
  .contests-swiper .item--wider {
    max-width: 100%;
    width: 100%;
    display: flex;
    flex-direction: column;
  }
  
  /* Последняя карточка без отступа */
  .contests-swiper .swiper-slide:last-child {
    margin-right: 0;
  }
  
  /* Адаптив — если нужно подогнать размер под ширину экрана */
  @media screen and (min-width:421px) {
    .contests-swiper .swiper-slide {
      width: 33.3333333333%;
    }
  }

  @media screen and (min-width:831px) {
    .contests-swiper .swiper-slide {
      width: 25%;
    }
  }

  @media screen and (min-width:1280px) {
    .contests-swiper .swiper-slide {
      width: 20%;
    }
  }

  @media screen and (max-width: 768px) {
    .contests-swiper .item--wider {
      width: 100%;
    }
  }
  
  @media screen and (max-width: 480px) {
    .contests-swiper .item--wider {
      width: 100%;
    }
  }
  
/*СТРАНИЦА КОНКУРСА*/
  .b-article__more-content {
    margin-top: 2em;
  }
  .b-article__more-content h3 {
    margin-top: 1.5em;
  }
  .b-article__more-content ul {
    padding-left: 1.2em;
    list-style: disc;
  }
  
  .b-contest-description {
    margin-bottom: 60px;
  }
  
/*СТРАНИЦА С КОНКУРСНЫМИ РАБОТАМИ*/
.b-filter-form {
    margin-bottom: 2em;
  }

.b-results-intro {
    padding: 24px 28px;
    background: #fff;
    border-radius: 10px;
    box-shadow: 0 12px 28px rgba(15, 23, 42, .06);
}

.b-results-detail-intro {
    padding: 24px 28px;
    background: #fff;
    border-radius: 10px;
    box-shadow: 0 12px 28px rgba(15, 23, 42, .06);
}

.b-works-intro {
    padding: 24px 28px;
    background: #fff;
    border-radius: 10px;
    box-shadow: 0 12px 28px rgba(15, 23, 42, .06);
}

.b-contest-tag-intro {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 200px;
    gap: 24px;
    align-items: start;
}

.b-contest-tag-intro__content {
    min-width: 0;
}

.b-contest-tag-intro__media {
    width: 200px;
    max-width: 100%;
    justify-self: end;
}

.b-contest-tag-intro__image {
    display: block;
    width: 100%;
    max-width: 200px;
    height: auto;
    border-radius: 10px;
    box-shadow: 0 12px 28px rgba(15, 23, 42, .08);
}

.b-auth-card {
    border-radius: 10px;
    box-shadow: 0 12px 28px rgba(15, 23, 42, .06);
}

  .b-filter-form__row {
    display: flex;
    flex-wrap: wrap;
    gap: 1em;
    align-items: flex-end;
  }

  .b-contest-category__item {
    width: 100%;
    max-width: 320px;
    height: 420px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    padding: 0;
    margin: 0;
    box-sizing: border-box;
  }
  
  .b-contest-category__image {
    width: 100%;
    height: 220px;
    overflow: hidden;
  }
  
  .b-contest-category__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
  }
  
  .b-contest-category__text {
    flex-grow: 1;
    padding: 0.8em 0 0;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
  }
  
  /*СЛАЙДЕР ЛУЧШИХ КОНКУРСНЫХ РАБОТ*/
  .best-works-swiper .swiper-slide {
    width: 360px !important;
    display: flex;
    justify-content: center;
    padding: 10px 0px !important;  /* ← аккуратные отступы вокруг каждой карточки */
    box-sizing: border-box;
  }

  .best-works-swiper .swiper-slide > .b-works-card {
    width: 100%;
  }

  @media (max-width: 767px) {
    .best-works-swiper .swiper-slide {
      width: min(300px, calc(100vw - 48px)) !important;
    }

    .best-works-swiper .swiper-slide > .b-works-card {
      width: 100%;
    }
  }
  

/*ОТОБРАЖЕНИЕ ВЬЮХ КОНКУРСОВ*/
.b-contest-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 20px;
    margin-top: 2em;
  }
  
  .b-contest-grid__item {
    min-width: 0;
    box-sizing: border-box;
    display: flex;
    flex-direction: column;
  }
  
  /* Планшеты (3 карточки) */
  @media (max-width: 1199px) {
    .b-contest-grid {
      grid-template-columns: repeat(3, minmax(0, 1fr));
    }
  }
  
  /* Меньше — 2 карточки */
  @media (max-width: 900px) {
    .b-contest-grid {
      grid-template-columns: repeat(2, minmax(0, 1fr));
    }
  }
  
  /* Мобильные — 1 карточка */
  @media (max-width: 600px) {
    .b-contest-grid {
      grid-template-columns: 1fr;
    }
  }

  .b-contest-grid__item.placeholder {
    visibility: hidden;
    pointer-events: none;
  }
  
  /* Поведение — только в последнем ряду для выравнивания */
  .b-contest-grid__item.placeholder::before {
    content: '';
    display: block;
    padding-bottom: 100%; /* сохраняет пропорции */
  }
  
  /* Поддерживает размеры обычной карточки */
  .b-contest-grid__item.placeholder .item--wider {
    display: none;
  }
  
  
  .b-contest-grid__item .item--wider {
    width: 100%;
    max-width: 100%;
    display: flex;
    flex-direction: column;
    background: #fff;
    border-radius: 10px;
    padding: 0;
    box-shadow: 0 12px 28px rgba(15, 23, 42, .06);
    box-sizing: border-box;
    height: 100%;
  }

  .b-result-card {
    box-shadow: 0 12px 28px rgba(15, 23, 42, .06);
  }

  .b-result-card__text {
    border-radius: 0 0 10px 10px;
  }
  
  .b-contest-grid__item .img {
    position: relative;
    overflow: hidden;
    border-radius: 10px 10px 0 0;
  }
  
  .b-contest-grid__item .img img {
    width: 100%;
    height: auto;
    display: block;
  }
  
  .b-contest-grid__item .contest-tag {
    position: absolute;
    top: 5px;
    left: 5px;
    padding: 4px 8px;
    font-size: 13px;
    border-radius: 4px;
    background: #ddd;
    z-index: 2;
  }
  
  .b-contest-grid__item .text {
    display: flex;
    flex-direction: column;
    flex-grow: 1;
    padding: 10px;
  }
  
  .b-contest-grid__item .title {
    height: 54px;
    overflow: hidden;
    line-height: 1.5;
    max-width: 100%;
    margin-bottom: 0;
    padding-bottom: 15px;
  }
  
  .b-contest-grid__item .title .name {
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    overflow: hidden;
    text-overflow: ellipsis;
    font-size: 16px;
    font-weight: bold;
    color: #333;
    margin: 10px 0 5px;
    line-height: 1.5;
  }
  
  .b-contest-grid__item .date-row {
    color: #333;
    font-size: 14px;
    line-height: 1.4;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 1;
    overflow: hidden;
  }
  
  .b-contest-grid__item .links-single {
    margin-top: auto;
    font-size: 14px;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px;
    padding-top: 10px;
  }

  .b-quiz-card__footer {
    margin-top: auto;
    margin-top: 12px;
    padding-top: 12px;
    border-top: 1px solid rgba(0,0,0,.08);
  }

  .b-quiz-card__footer-links {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
    font-size: 14px;
    line-height: 1.4;
  }

  .b-quiz-card__footer-links .underline {
    font-size: inherit;
    line-height: inherit;
  }
  
  .b-contest-grid__item .underline {
    text-decoration: none;
    color: #3da2d6;
  }
  
  .b-contest-grid__item .separator {
    margin: 0;
    color: #ffffff;
  }

  .contests-swiper .item--wider {
    width: 100%;
    max-width: 100%;
    display: flex;
    flex-direction: column;
    background: #fff;
    border-radius: 10px;
    padding: 0;
    box-shadow: 0 12px 28px rgba(15, 23, 42, .06);
    box-sizing: border-box;
    height: 100%;
  }

  .contests-swiper .img {
    position: relative;
    overflow: hidden;
    border-radius: 10px 10px 0 0;
  }

  .contests-swiper .img img {
    width: 100%;
    height: auto;
    display: block;
  }

  .contests-swiper .contest-tag {
    position: absolute;
    top: 5px;
    left: 5px;
    padding: 4px 8px;
    font-size: 13px;
    border-radius: 4px;
    background: #ddd;
    z-index: 2;
  }

  .item .img .contest-tags .contest-tag--icon,
  .b-contest-grid__item .img .contest-tags .contest-tag--icon,
  .contests-swiper .img .contest-tags .contest-tag--icon {
    width: 32px;
    height: 32px;
    min-width: 32px;
    min-height: 32px;
    padding: 4px;
  }

  .item .img .contest-tags .contest-tag--icon .contest-tag__icon,
  .b-contest-grid__item .img .contest-tags .contest-tag--icon .contest-tag__icon,
  .contests-swiper .img .contest-tags .contest-tag--icon .contest-tag__icon {
    width: 24px;
    height: 24px;
    max-width: 24px;
    max-height: 24px;
    object-fit: contain;
  }

  .contests-swiper .text {
    display: flex;
    flex-direction: column;
    flex-grow: 1;
    padding: 10px;
  }

  .contests-swiper .title {
    height: 54px;
    overflow: hidden;
    line-height: 1.5;
    max-width: 100%;
    margin-bottom: 0;
    padding-bottom: 15px;
  }

  .contests-swiper .title .name {
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    overflow: hidden;
    text-overflow: ellipsis;
    font-size: 16px;
    font-weight: bold;
    color: #333;
    margin: 10px 0 5px;
    line-height: 1.5;
  }

  .contests-swiper .date-row {
    color: #333;
    font-size: 14px;
    line-height: 1.4;
  }

  .contests-swiper .links-single {
    margin-top: auto;
    font-size: 14px;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px;
    padding-top: 10px;
  }

  .contests-swiper .underline {
    text-decoration: none;
    color: #3da2d6;
  }

  .contests-swiper .separator {
    margin: 0;
    color: #ffffff;
  }

  .contests-swiper .swiper-slide > .item.item--wider,
  .contests-swiper .swiper-slide > .item--wider {
    background: #fff;
    border: 0;
    border-radius: 10px;
    margin: 0 10px;
    padding: 0;
    box-shadow: 0 12px 28px rgba(15, 23, 42, .06);
  }

  .b-quiz-card__footer-links .separator {
    margin: 0;
    color: #9ca3af;
  }

  .b-works-card {
    box-shadow: 0 12px 28px rgba(15, 23, 42, .06);
  }

  .b-section--best-works .b-works-card {
    box-shadow: 0 12px 28px rgba(15, 23, 42, .08), 0 0 18px rgba(251, 209, 75, .16), 0 0 34px rgba(251, 209, 75, .10) !important;
  }

  @media (max-width: 767px) {
    .b-results-intro {
      padding: 18px 16px;
    }

    .b-results-detail-intro {
      padding: 18px 16px;
    }

    .b-works-intro {
      padding: 18px 16px;
    }

  }


    /* Сообщение для завершённого конкурса */
  .b-notify {
    background-color: #f0f8ff;
    border-left: 5px solid #42a5f5;
    padding: 1em;
    margin-bottom: 1.5em;
    font-size: 1em;
    line-height: 1.5;
  }
  

  /* ЛИЧНЫЙ КАБИЕНТ: Каркас двух колонок */
  .l-dashboard {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 100px; /* правая колонка 100px, как в старых стилях */
    gap: 24px;
  }
  
  /* Левая (контент) шире, правая уже */
  .l-dashboard__content {
    min-width: 0;           /* важно для грид-детей */
    overflow-x: auto;       /* если таблица шире — появится горизонтальная прокрутка, не наедет на сайдбар */
  }

  .l-dashboard__sidebar {
    flex: 0 0 280px; /* ширина правой панели */
  }
  
  /* Фиксация правой панели */
  .b-add-form__sidebar {
    position: sticky;
    top: 20px;
  }

/* внутри ЛК правая панель не table-cell */
.l-dashboard .b-add-form__sidebar {
    display: block !important;
    width: 100px !important;
    padding-left: 0 !important;
    position: sticky; /* если нужна фиксация */
    top: 20px;
  }
  
  /* Таблица на всю доступную ширину левой колонки */
.l-dashboard__content .b-step-itogi {
  width: 100%;
  table-layout: fixed;
}
  
  /* Линк "иконка + текст" в ячейках ФИО */
  /* Меню ЛК */
  .b-lk-menu {
    list-style: none;
    margin: 0;
    padding: 0;
  }
  .b-lk-menu__item + .b-lk-menu__item {
    margin-top: 8px;
  }

  .b-lk-menu__link:hover {
    color: #3da2d6;
  }
  .b-lk-menu__link.is-active {
    color: #3da2d6;
    font-weight: 600;
  }

  /*ГЛАВНАЯ СТРАНИЦА ЛИЧНЫЙ КАБИНЕТ*/
  /* Панели */
.b-panel { border-radius: 12px; }
.b-panel--white { background:#fff; box-shadow:0 6px 20px rgba(0,0,0,.06); }
.b-panel--pad { padding:24px; }

/* Аккаунт */
.b-account__head { display:grid; grid-template-columns: 96px minmax(0, 1fr) 220px; gap:20px; align-items:start; }
.b-account__avatar-img { width:96px; height:96px; object-fit:cover; border-radius:50%; display:block; }
.b-account__name { font-size:20px; font-weight:700; margin-bottom:6px; }
.b-account__meta { display:flex; flex-wrap:wrap; gap:6px; margin-bottom:10px; }
.b-account__tag { background:#f4f6f8; border-radius:999px; padding:4px 10px; font-size:12px; color:#4b5563; }
.b-account__list { margin:0; padding:0; list-style:none; display:grid; gap:6px; }
.b-account__label { color:#6b7280; margin-right:6px; }
.b-account__info { min-width: 0; }

.b-account__actions { display:flex; flex-direction:column; gap:12px; align-items:stretch; width:100%; max-width:220px; justify-self:end; }
.b-account__actions .b-button,
.b-account__actions .btn,
.b-account__support-button { width:100%; text-align:center; }
.b-iconbtn { display:flex; align-items:center; gap:8px; text-decoration:none; padding:8px 12px; border-radius:999px; border:1px solid #e5e7eb; }
.b-iconbtn__icon { line-height:1; }
.b-iconbtn__text { font-size:14px; color:#111827; }

/* Ссылки-разделы */
.b-account-section { margin-top:20px; }
.b-account-links { display:flex; flex-wrap:wrap; gap:12px; }

@media (max-width: 960px) {
  .b-account__head {
    grid-template-columns: 96px minmax(0, 1fr);
  }

  .b-account__actions,
  .b-account__actions--secondary {
    grid-column: 1 / -1;
    width: 100%;
    max-width: none;
    justify-self: stretch;
    margin-top: 8px;
  }
}

@media (max-width: 768px) {
  .b-account__head { grid-template-columns: 64px 1fr; }
  .b-account__actions { grid-column: 1 / -1; justify-content:space-between; margin-top:8px; }
  .b-account__avatar-img { width:64px; height:64px; }
}

/* === МОБИЛЬНОЕ МЕНЮ (офф-канвас) — оптимизировано === */

/* Переключатели видимости оболочек */
.l-only-desktop { display: none; }
.l-only-mobile  { display: block; }
@media (min-width: 871px) {
  .l-only-desktop { display: block; }
  .l-only-mobile  { display: none; }
}

/* Крестик: скрыт на десктопе, виден на мобилке */
.b-main-menu__close { display: none !important; }
@media (max-width: 870px) {
  .b-main-menu__close { display: inline-block !important; }
}

/* ---------- ТОЛЬКО МОБИЛЬНАЯ ПАНЕЛЬ ---------- */
@media (max-width: 870px) {

  /* Фуллскрин-контейнер офф-канваса фиксируем к вьюпорту */
  .b-offcanvas{
    position: fixed;
    inset: 0;                 /* top:0; right:0; bottom:0; left:0 */
    z-index: 11040;           /* ниже панели, но выше контента */
    pointer-events: none;     /* клики сквозь контейнер */
    transform: none !important;
  }

  /* Сама панель (внутри .b-offcanvas) */
  .b-offcanvas .b-main-menu__nav{
    position: fixed;
    top: 0; left: 0; bottom: 0;
    width: min(82vw, 360px);
    max-width: 360px;
    background: #fff;
    box-shadow: 4px 0 24px rgba(0,0,0,.12);
    box-sizing: border-box;

    /* место под крестик + безопасная зона внизу */
    padding: 70px 12px calc(28px + env(safe-area-inset-bottom, 0px)) 12px;

    /* фиксированная к экрану высота и прокрутка внутри панели */
    height: 100svh;           /* актуальные моб. браузеры */
    min-height: 100dvh;       /* fallback */
    height: 100vh;            /* fallback */
    overflow-y: auto;
    overscroll-behavior-y: auto;      /* chain-scroll в страницу */
    -webkit-overflow-scrolling: touch;

    pointer-events: auto;      /* клики по панели активны */
    z-index: 11050;

    transform: translateX(-100%);     /* спрятано слева */
    transition: transform .25s ease;
  }

  /* Открытое состояние: панель выезжает */
  .b-offcanvas.is-open .b-main-menu__nav,
  .b-offcanvas .b-main-menu__nav.is-open{
    transform: translateX(0);
  }

  /* Крестик — всегда сверху и кликабелен */
  .b-offcanvas .b-main-menu__close{
    position: fixed;   /* фиксируем к экрану, а не к контенту */
    top: 8px; right: 10px;
    z-index: 11100;
    padding: 8px;
    line-height: 1;
    cursor: pointer;
    -webkit-tap-highlight-color: transparent;
    pointer-events: auto;
  }

  /* Сброс десктопной "выпадашки" и вертикальная раскладка */
  .b-offcanvas .b-main-menu__nav .nav.menu,
  .b-offcanvas .b-main-menu__nav .nav.menu ul{
    position: static !important;
    display: block !important;
    float: none !important;
    width: auto !important;
    max-width: none !important;
  }

  /* Разделы (верхний уровень) — жирным, построчно */
  .b-offcanvas .b-main-menu__nav .nav.menu > li{
    display: block !important;
    margin: 0;
    border-top: 1px solid #e6e6e6;
  }
  .b-offcanvas .b-main-menu__nav .nav.menu > li:first-child{ border-top: 0; }
  .b-offcanvas .b-main-menu__nav .nav.menu > li > a{
    display: block;
    padding: 12px 16px;
  }
  .b-offcanvas .b-main-menu__nav .nav.menu > li > a span{
    font-weight: 700;
  }

  /* Подразделы — обычным, со сдвигом вправо */
  .b-offcanvas .b-main-menu__nav .nav-child{
    margin: 4px 0 10px 0;
    padding-left: 20px;
    border: 0;
  }
  .b-offcanvas .b-main-menu__nav .nav-child > li{ display: block; }
  .b-offcanvas .b-main-menu__nav .nav-child > li > a{
    display: block;
    padding: 10px 16px 10px 28px; /* шире зона тапа */
  }
  .b-offcanvas .b-main-menu__nav .nav-child > li > a span{
    font-weight: 400;
  }

  /* Подсветка активного пункта (верх и низ) */
  .b-offcanvas .nav.menu > li.is-active > a,
  .b-offcanvas .nav.menu > li.is-active > a span,
  .b-offcanvas .nav-child > li.is-active > a span{
    color: #3DA2D6;
  }
  .b-offcanvas .nav.menu > li.is-active{
    border-color: #3DA2D6;
  }

  /* Гарантия, что текст не «прозрачный» из глобальных стилей */
  .b-offcanvas .b-main-menu__nav .nav.menu a,
  .b-offcanvas .b-main-menu__nav .nav.menu a span{
    color: inherit;
    font: inherit;
    text-shadow: none;
  }

  /* Низ списка не «режется» краем экрана */
  .b-offcanvas .b-main-menu__nav .nav.menu > li:last-child{
    margin-bottom: 12px;
  }
}


/* Материалы: белая подложка под контент */
.b-article.item-page .b-article__wrapper {
    background: #fff;
    box-sizing: border-box;
    line-height: 1.4;
    padding: 1.8125rem;          /* ~29px */
    border-radius: 8px;           /* если нужны мягкие углы */
    /* box-shadow: 0 6px 24px rgba(0,0,0,.06);  // если нужна лёгкая тень — раскомментируй */
  }
  
  /* Чтобы фон не “прилипал” к заголовку и к низу страницы */
  .b-article__title { margin-bottom: 1rem; }
  .b-article.item-page .b-article__more,
  .b-article.item-page .b-article__attachments { margin-top: 1.25rem; }
  

/* Сетка списка материалов с равномерными отступами */
.b-articles__list {
    display: grid;
    grid-template-columns: 1fr;     /* 1 колонка по умолчанию (мобилка) */
    gap: 16px;                       /* отступы между карточками */
    margin: 16px 0 24px;
  }
  
  /* На широких экранах можно сделать 2 колонки */
  @media (min-width: 992px) {
    .b-articles__list {
      grid-template-columns: 1fr 1fr;
      gap: 20px;
    }
  }
  
  /* ТИПЫ МАТЕРИАЛОВ В ПУНКТЕ МЕНЮ: Белая подложка карточки + внутренние отступы */
  .b-articles__list {
    display: block;              /* важно: не grid/флекс */
    list-style: none;
    margin: 20px 0 24px;
    padding: 0;
  }
  
  /* Один материал — белая карточка со ступенькой 60px сверху */
  .b-articles__item {
    margin-top: 30px;            /* отступ между карточками */
  }
  .b-articles__item:first-child {
    margin-top: 0;               /* у первой — без отступа сверху */
  }
  
  /* Белая подложка карточки */
  .b-article-card--solid {
    background: #fff;
    border-radius: 8px;
    box-sizing: border-box;
    /* box-shadow: 0 6px 24px rgba(0,0,0,.06);  // если нужна лёгкая тень — включи */
  }
  .b-article-card__inner {
    padding: 24px 28px;          /* можно уменьшить/увеличить по вкусу */
  }
  
  /* Заголовок/анонс/кнопка внутри карточки */
  .b-article-card__title { margin: 0 0 10px 0; line-height: 1.25; }
  .b-article-card__excerpt { margin-top: 6px; line-height: 1.45; }
  .b-article-card__actions { margin-top: 14px; }
  
  /* Отступ под вводным описанием раздела (если есть) */
  .b-article__wrapper + .b-articles { margin-top: 40px; }
 
  /* Теги олимпиад и викторин */  
.contest-tag--quiz { background:#a5ce58; color:#fff; }
.contest-tag--olympiad { background:#0bbcbe; color:#fff; }

/* Патч модификаторов бейджа типа теста — сильнее базовых правил */
.b-contest-grid .item .img .contest-tag.contest-tag--quiz,
.item .img .contest-tag.contest-tag--quiz {
  background-color: #a5ce58;
  border-color: #a5ce58;
  color: #fff;
}

.b-contest-grid .item .img .contest-tag.contest-tag--olympiad,
.item .img .contest-tag.contest-tag--olympiad {
  background-color: #0bbcbe;
  border-color: #0bbcbe;
  color: #fff;
}

/* На случай, если где-то задан полупрозрачный фон или градиент */
.item .img .contest-tag.contest-tag--quiz,
.item .img .contest-tag.contest-tag--olympiad {
  background-image: none;
  opacity: 1;
}


/* викторины — базовый крестик удаления блока участника */
.b-add-form__close{
    position:absolute;
    right:-12px;   /* справа на десктопе */
    top:-12px;
    width:24px;height:24px;
    line-height:24px;
    text-align:center;
    background:#fff;
    border:1px solid #e5e5e5;
    border-radius:50%;
    color:#333;
    box-shadow:0 1px 2px rgba(0,0,0,.06);
    cursor:pointer;
    z-index:2;
  }
  
  /* мобильная адаптация: не выезжает за контент */
  @media (max-width: 768px){
    .b-add-form__close{
      right:8px;  /* внутри блока */
      top:8px;
    }
  }
  
/* ===========================
   PUBLICATIONS (FINAL v3)
   3 columns + list cards
   =========================== */

/* 1) 3-column layout */
.b-layout.b-layout--publications{
    display:flex;
    gap:20px;
    align-items:flex-start;
  }
  
  .b-layout.b-layout--publications .b-layout__left{
    flex:0 0 220px;
    width:220px;
  }
  
  .b-layout.b-layout--publications .b-layout__right{
    flex:0 0 195px;
    width:195px;
  }
  
  .b-layout.b-layout--publications .b-layout__center{
    flex:1 1 auto;
    min-width:0;
  }
  
  /* 2) White boxes inside grey page area */
  .b-pubs-box{
    background:#fff;
    border-radius:10px;
    padding:16px;
    box-shadow: 0 12px 28px rgba(15, 23, 42, .06);
  }
  
  .b-pubs-box--spaced{ padding:18px; }
  
  /* wrapper for list: no white background (cards only) */
  .b-pubs-list-wrap{
    background:transparent;
    padding:0;
  }
  
  /* 3) Left column nav */
  .b-pub-left__block{ margin:0 0 18px; }
  .b-pub-left__title{ font-weight:700; margin:0 0 10px; }
  .b-pub-left__list{ list-style:none; padding:0; margin:0; }
  .b-pub-left__item{ margin:0 0 6px; }
  .b-pub-left__link{
    display:flex;
    align-items:flex-start;
    gap:8px;
    min-width:0;
    color:#222;
    font-size:13px;
    line-height:1.35;
    text-decoration:none;
    overflow-wrap:anywhere;
    border-radius:6px;
    padding:7px 9px;
    transition:background-color .2s ease, color .2s ease;
  }
  .b-pub-left__link:hover,
  .b-pub-left__link:focus-visible{
    background:rgba(15, 23, 42, .06);
    color:#2455a6;
  }

  .b-pub-left__item.is-active .b-pub-left__link{
    background:rgba(36, 85, 166, .1);
    color:#2455a6;
    font-weight:700;
  }

  .b-layout--publications .b-filter-form__row{
    gap:12px !important;
  }

  .b-layout--publications #pub-filter-q{
    width:220px !important;
    max-width:220px;
    box-sizing:border-box;
  }

  .b-layout--publications #pub-filter-category,
  .b-layout--publications #pub-filter-type,
  .b-layout--publications #pub-filter-class{
    width:220px !important;
    max-width:220px;
    min-width:0;
    box-sizing:border-box;
    overflow:hidden;
    text-overflow:ellipsis;
    white-space:nowrap;
  }

  .b-layout--publications .b-filter-form,
  .b-layout--publications .b-filter-form__row{
    max-width:100%;
    box-sizing:border-box;
  }
  
  /* 4) Right column */
  .b-pub-right__block{ margin:0 0 18px; }
  .b-pub-right__title{ font-weight:700; margin:0 0 10px; }
  .b-pub-right__text{ margin:0 0 12px; opacity:.9; }
  .b-pub-right__link{ text-decoration:none; }
  
  /* 5) Publications list (1 column) */
  .b-pub-list__grid{
    display:grid;
    grid-template-columns:1fr;
    gap:18px;
  }
  
  /* Card */
  .b-pub-card{
    background:#fff;
    border-radius:10px;
    padding:16px;
    box-shadow: 0 12px 28px rgba(15, 23, 42, .06);
  }
  
  /* Top: cover + content */
  .b-pub-card__wrap{
    display:flex;
    gap:16px;
    align-items:flex-start;
  }
  
  /* cover: square bigger */
  .b-pub-card__cover{
    flex:0 0 135px;
    width:135px;
    height:135px;
    display:block;
    border-radius:10px;
    overflow:hidden;
    background:#f3f3f3;
  }
  
  .b-pub-card__cover-img{
    width:100%;
    height:100%;
    object-fit:cover;
    display:block;
  }
  
  /* content: MUST be relative for date absolute */
  .b-pub-card__content{
    flex:1 1 auto;
    min-width:0;
    position:relative;
    padding-right:90px; /* резерв чтобы заголовок не залезал под дату */
  }
  
  /* title: separate line */
  .b-pub-card__title{
    display:block;
    font-weight:700;
    text-decoration:none;
    line-height:1.25;
    margin:0 0 10px;
    font-size:17px;
  }
  
  /* author row */
  .b-pub-card__author-row{
    display:flex;
    gap:10px;
    align-items:center;
    margin:0 0 10px;
  }
  
  .b-pub-card__avatar{
    flex:0 0 36px;
    width:36px;
    height:36px;
    border-radius:50%;
    overflow:hidden;
    background:#f3f3f3;
  }
  
  .b-pub-card__avatar-img{
    width:100%;
    height:100%;
    object-fit:cover;
    display:block;
  }
  
  .b-pub-card__author{
    font-size:13px;
    opacity:.9;
  }
  
  /* annotation smaller than author + italic */
  .b-pub-card__text{
    font-size:12px;
    font-style:italic;
    opacity:.85;
    margin:0 0 8px;
  }
  
  /* tags close to annotation */
  .b-pub-card__tags{
    display:flex;
    gap:8px;
    flex-wrap:wrap;
    margin:0;
  }
  
  .b-pub-tag{
    display:inline-block;
    padding:3px 8px;
    border-radius:999px;
    font-size:12px;
    opacity:.95;
    text-decoration:none;
  }
  
  /* DATE: top-right corner */
  .b-pub-card__date{
    font-size:12px;
    color:#8a8a8a;
  }
  
  .b-pub-card__date--top{
    position:absolute;
    top:0;
    right:0;
    white-space:nowrap;
  }
  
  /* remove old meta-row spacing if it still exists in html */
  /* footer: actions left, stats right-bottom */
  .b-pub-card__footer{
    margin-top:12px;
    padding-top:12px;
    border-top:1px solid rgba(0,0,0,.08);
    display:flex;
    justify-content:space-between;
    align-items:flex-end;
    gap:12px;
    flex-wrap:wrap;
  }
  
  .b-pub-card__footer-links{
    display:flex;
    gap:10px;
    align-items:center;
    flex-wrap:wrap;
  }
  
  .b-pub-card__footer-stats{
    display:inline-flex;
    gap:14px;
    align-items:center;
    justify-content:flex-end;
    white-space:nowrap;
  }
  
  /* stats: icons not squashed, numbers same muted as date */
  .b-pub-stat{
    display:inline-flex;
    align-items:center;
    gap:6px;
  }
  
  .b-pub-stat__icon{
    width:16px;
    height:16px;
    display:block;
  }
  
  .b-pub-stat__num{
    font-size:12px;
    color:#8a8a8a;
  }
  .b-pub-stat--like{
    cursor:pointer;
  }
  .b-pub-stat--like i{
    vertical-align:middle;
    font-size:18px;
    line-height:1;
  }

  .b-pub-stat--like .b-like-icon{
    width:16px;
    height:16px;
    display:block;
  }
  
  /* ===== Publication detail ===== */

.b-pub-detail__top{
    display:flex;
    gap:18px;
    align-items:flex-start;
  }
  
  .b-pub-detail__top-left{
    flex:1 1 auto;
    min-width:0;
  }
  
  .b-pub-detail__authorline{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:14px;
  }
  
  .b-pub-detail__author{
    display:flex;
    align-items:center;
    gap:10px;
    min-width:0;
  }
  
  .b-pub-detail__avatar{
    width:34px;
    height:34px;
    border-radius:50%;
    overflow:hidden;
    background:#f3f3f3;
    flex:0 0 34px;
  }
  
  .b-pub-detail__avatar-img{
    width:100%;
    height:100%;
    object-fit:cover;
    display:block;
  }
  
  .b-pub-detail__author-name{
    font-weight:700;
  }
  
  .b-pub-detail__date{
    font-size:12px;
    color:#8a8a8a;
    white-space:nowrap;
  }
  
  .b-pub-detail__hr{
    height:1px;
    background:rgba(0,0,0,.08);
    margin:12px 0;
  }
  
  .b-pub-detail__annotation{
    margin:0 0 12px;
  }
  
  /* ===== FIX: detail props inline, clickable only values ===== */

.b-pub-detail__props{
    display:flex;           /* переопределяем grid */
    flex-wrap:wrap;
    gap:10px 18px;
    margin:10px 0 10px;
  }
  
  .b-pub-detail__prop{
    display:flex;
    gap:6px;
    align-items:baseline;
    flex-wrap:wrap;
  }
  
  .b-pub-detail__prop-label{
    font-size:12px;
    color:#8a8a8a;
    margin-right:0;         /* переопределяем старое */
  }
  
  .b-pub-detail__prop-value{
    font-size:12px;
    color:#000;
    font-weight:700;
  }
  
  /* кликабельное ТОЛЬКО значение (цвет как в списке — через underline) */
  .b-pub-detail__prop-value-link{
    font-size:12px;
    font-weight:700;
    text-decoration:none;
  }
  
  /* старый вариант (когда кликабельна вся строка) отключаем */
  .b-pub-detail__cover{
    width:100%;
    aspect-ratio:1 / 1;
    border-radius:10px;
    overflow:hidden;
    background:#f3f3f3;
  }
  
  .b-pub-detail__cover-img{
    width:100%;
    height:100%;
    object-fit:cover;
    display:block;
  }
  
  .b-pub-detail__cover-img--placeholder{
    object-fit:contain;
    padding:18px;
    box-sizing:border-box;
  }
  
  /* Viewer */
  .b-pub-viewer__frame{
    width:100%;
    border-radius:10px;
    overflow:hidden;
    background:#f3f3f3;
  }
  
  .b-pub-viewer__iframe{
    width:100%;
    height:680px;
    display:block;
    border:0;
  }
  
  .b-pub-viewer__actions{
    margin-top:12px;
    display:flex;
    justify-content:space-between;
    gap:12px;
    align-items:center;
    flex-wrap:wrap;
  }
  
  .b-pub-viewer__actions-left{
    display:flex;
    gap:10px;
    flex-wrap:wrap;
    align-items:center;
  }
  
  .b-pub-viewer__actions-right{
    display:inline-flex;
    gap:14px;
    align-items:center;
    justify-content:flex-end;
  }
  
.b-pub-viewer__stat{
    display:inline-flex;
    gap:6px;
    align-items:center;
  }

  .b-pub-stat--like [data-like-btn]{
    display:inline-flex;
    gap:6px;
    align-items:center;
  }
  
  .b-pub-viewer__icon{
    width:16px;
    height:16px;
    display:block;
  }
  
  .b-pub-viewer__num{
    font-size:12px;
    color:#8a8a8a;
  }

  .b-pub-viewer--detail{
    position: relative;
    z-index: 2;
    clear: both;
    isolation: isolate;
    margin-top: 18px;
  }

  .b-pub-viewer--detail .b-pub-viewer__frame{
    position: relative;
    z-index: 1;
  }

  /* Similar cards */
  .b-pub-similar-card{
    display:block;
    background:#fff;
    border-radius:12px;
    padding:18px;                 /* было 12px */
    text-decoration:none;
    box-sizing:border-box;
  }
  
  .b-pub-similar-card__img{
    width:100%;
    aspect-ratio:1 / 1;
    border-radius:12px;
    overflow:hidden;
    background:#f3f3f3;
    margin:0 0 14px;              /* было 10px */
  }
  
  .b-pub-similar-card__img img{
    width:100%;
    height:100%;
    object-fit:cover;
    display:block;
  }
  
  .b-pub-similar-card__title{
    font-weight:700;
    font-size:15px;               /* было “по умолчанию” */
    line-height:1.25;
    margin:0 0 12px;
  }
  
  .b-pub-similar-card__author{
    display:flex;
    align-items:center;
    gap:10px;                     /* было 8px */
    opacity:.92;
  }
  
  .b-pub-similar-card__avatar{
    width:34px;                   /* было 28px */
    height:34px;
    border-radius:50%;
    overflow:hidden;
    background:#f3f3f3;
    flex:0 0 34px;
  }
  
  .b-pub-similar-card__avatar img{
    width:100%;
    height:100%;
    object-fit:cover;
    display:block;
  }
  
  .b-pub-similar-card__name{
    font-size:13px;               /* было 12px */
  }

  /* ===== Detail: links props under author line ===== */

.b-pub-detail__props--links{
    display:flex;
    flex-wrap:wrap;
    gap:10px 14px;
    margin:10px 0 12px;
  }
  
/* ===== Similar: bigger spacing from viewer (FIX) ===== */
.b-pub-similar__wrap{
    margin-top: 48px !important;   /* гарантированно оторвём от viewer */
    padding-top: 8px;              /* на случай коллапса маржинов */
  }
  
  .b-pub-similar__wrap .b-module__title{
    margin-bottom: 18px;           /* воздух под заголовком */
  }

  /* ===== FIX: detail cover float (wrap text) ===== */

.b-pub-detail__cover--float{
    float:right;
    width:25%;              /* 1/4 ширины блока */
    max-width:240px;
    min-width:160px;
    margin:0 0 12px 18px;   /* слева отступ чтобы текст не лип */
    aspect-ratio:1 / 1;
    border-radius:10px;
    overflow:hidden;
    background:#f3f3f3;
  }
  
  /* когда аннотация "ниже картинки" — даём ей занять всю ширину */
  .b-pub-detail__annotation::after{
    content:"";
    display:block;
    clear:both;
  }
  
  /* mobile: убираем float */
  /* =========================================================
   PUBLICATIONS — MOBILE (<= 720px)
   Вставить в конец template.css
   ========================================================= */
@media (max-width: 720px) {

    /* ---------- 1) Базовая сетка / отступы страницы ---------- */
    .b-layout.b-layout--publications {
      display: flex !important;
      flex-direction: column !important;
      gap: 16px;
      align-items: stretch;
      padding-left: 12px;
      padding-right: 12px;
    }
  
    /* Если внутри есть общий контейнер колонок */
    /* ---------- 2) Складной layout: 3 колонки -> 1 колонка ---------- */
    .b-layout.b-layout--publications .b-layout__left,
    .b-layout.b-layout--publications .b-layout__center,
    .b-layout.b-layout--publications .b-layout__right {
      width: 100% !important;
      flex: auto !important;
      min-width: 0;
      box-sizing: border-box;
    }
  
    /* Порядок блоков на мобиле: фильтры -> контент -> правый сайдбар */
    .b-layout.b-layout--publications .b-layout__left { order: 3; }
    .b-layout.b-layout--publications .b-layout__center { order: 2; }
    .b-layout.b-layout--publications .b-layout__right { order: 1; }
  
    /* Убираем “липкие”/фиксированные эффекты у сайдбаров, если были */
    .b-layout.b-layout--publications .b-layout__left,
    .b-layout.b-layout--publications .b-layout__right {
      position: static !important;
      top: auto !important;
    }
  
    .b-layout.b-layout--publications .b-layout__right .b-pubs-box {
      display: none !important;
    }

    .b-layout.b-layout--publications .b-layout__right .b-pub-float-btn {
      display: block;
      width: 100%;
      text-align: center;
      box-sizing: border-box;
      margin: 0;
    }
  
    /* Правый сайдбар (кнопка + инфо) */
    .b-pub-right {
      border-radius: 12px;
    }
  
    /* =========================================================
       3) Список публикаций — карточка (.b-pub-card…)
       ========================================================= */
  
    /* Если карточка на desktop сделана flex-строкой — на мобиле в колонку */
    .b-pub-card {
      display: flex;
      flex-direction: column;
    }

    .b-pub-card__wrap {
      flex-direction: row;
      align-items: flex-start;
      gap: 12px;
    }
  
    /* Обложка сверху, 100% ширины */
    .b-pub-card__cover {
      width: 96px !important;
      max-width: 96px !important;
      height: 96px;
      flex: 0 0 96px;
    }
  
    /* Квадратная обложка на мобиле: безопасный вариант через aspect-ratio */
    .b-pub-card__cover {
      aspect-ratio: 1 / 1;
      overflow: hidden;
      border-radius: 12px;
    }
  
    .b-pub-card__cover img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      display: block;
    }

    .b-pub-card__content {
      padding-right: 0 !important;
    }

    .b-pub-card__date--top {
      position: static !important;
      display: block;
      margin: 0 0 8px;
      text-align: left;
    }

    .b-pub-card__title,
    .b-pub-card__author,
    .b-pub-card__text {
      word-break: break-word;
      overflow-wrap: anywhere;
    }

    .b-pub-card__author-row {
      align-items: flex-start;
      gap: 8px;
      margin: 0 0 8px;
    }

    .b-pub-card__avatar {
      flex: 0 0 28px;
      width: 28px;
      height: 28px;
    }

    .b-pub-card__title {
      font-size: 15px;
      margin: 0 0 8px;
    }

    .b-pub-card__text {
      line-height: 1.4;
    }
  
    /* Тело карточки */
    /* Верхняя мета-строка (дата справа сверху) — пусть нормально переносится */
    /* Автор (аватар+ФИО) — переносим, чтобы не ломалось */
    .b-pub-card__author {
      display: flex;
      align-items: center;
      gap: 10px;
      min-width: 0;
    }
  
    /* Аннотация — чуть компактнее */
    /* Подвал карточки: перенос строк, ссылки и счётчики не ломаются */
    .b-pub-card__footer {
      display: flex;
      align-items: flex-start;
      justify-content: space-between;
      gap: 12px;
      flex-wrap: wrap;
      padding-top: 10px;
    }

    .b-pub-card__footer-stats {
      width: 100%;
      justify-content: flex-start;
    }

    .b-pub-card__footer-links {
      width: 100%;
      flex-direction: row;
      flex-wrap: wrap;
      align-items: flex-start;
      gap: 8px;
    }

    .b-pub-card__footer-links .separator {
      display: none;
    }
  
    /* Ссылки в подвале — на мобиле в строку/две, удобные тапы */
    /* Счётчики (просмотры/скачивания) — при переносе остаются читаемыми */
    /* =========================================================
       4) Детальная страница (.b-pub-detail…)
       ========================================================= */
  
    /* Шапка (аватар + ФИО + дата) — разрешаем перенос */
    .b-pub-detail__top {
      display: flex;
      align-items: flex-start;
      justify-content: flex-start;
      gap: 12px;
    }
  
    .b-pub-detail__author {
      min-width: 0;
    }

    .b-pub-detail__authorline {
      align-items: flex-start;
      gap: 10px;
      flex-wrap: wrap;
    }
  
    /* Отключаем float-обложку: становится 100% ширины */
    .b-pub-detail__cover--float {
      float: right !important;
      width: 36% !important;
      max-width: 140px !important;
      min-width: 96px !important;
      margin: 0 0 10px 12px !important;
    }
  
    .b-pub-detail__cover--float img {
      width: 100%;
      height: auto;
      display: block;
      border-radius: 12px;
    }
  
    /* Аннотация / описание — чтобы не “рвалось” */
    .b-pub-detail__annotation {
      word-break: break-word;
    }
  
    /* props (Категория/Разработка/Возраст) — из flex-строки в вертикальные строки */
    .b-pub-detail__props {
      display: flex;
      flex-direction: row;
      flex-wrap: wrap;
      gap: 8px 14px;
    }
  
    .b-pub-detail__prop {
      display: flex;
      gap: 6px;
      flex-wrap: wrap;
    }
  
    /* Кликабельны только значения — на мобиле чуть удобнее */
    .b-pub-detail__prop a.underline {
      padding: 4px 0;
    }
  
    /* =========================================================
       5) Viewer (.b-pub-viewer…)
       ========================================================= */
  
    .b-pub-viewer {
      width: auto;
      max-width: 100%;
      box-sizing: border-box;
      border-radius: 12px;
      overflow: hidden;
    }
  
    /* iframe / embed — адаптивная высота */
    .b-pub-viewer__iframe,
    .b-pub-viewer iframe,
    .b-pub-viewer embed {
      width: 100% !important;
      height: 62vh;         /* комфортно на мобиле */
      min-height: 420px;    /* чтобы не было “узкой щели” */
      max-height: 760px;    /* чтобы не улетало */
      border: 0;
      display: block;
    }

    .b-pub-viewer__actions {
      flex-direction: row;
      align-items: center;
      justify-content: space-between;
    }

    .b-pub-viewer__actions-left {
      justify-content: flex-start;
    }

    .b-pub-viewer__actions-left .btn {
      width: auto;
      text-align: center;
    }
  
    .b-pub-viewer__actions-right {
      width: auto;
      justify-content: flex-start;
      flex-wrap: wrap;
    }
  
    /* =========================================================
       6) Похожие публикации (.b-pub-similar…)
       ========================================================= */
  
    .b-pub-similar__wrap {
      margin-top: 32px !important; /* на мобиле чуть меньше, чем на desktop */
    }
  
    /* Сетка похожих: 2 -> 1 колонка */
    .b-pub-similar__grid,
    .b-pub-similar__list {
      display: grid;
      grid-template-columns: 1fr !important;
      gap: 14px;
    }

    .b-pub-similar__wrap .b-grid__wrapper {
      display: grid !important;
      grid-template-columns: 1fr !important;
      gap: 14px !important;
    }

    .b-pub-similar__wrap .b-grid__item {
      width: auto !important;
    }
  
    /* Карточка похожей — в колонку, превью сверху */
    .b-pub-similar-card {
      display: flex;
      flex-direction: column;
    }
  
  }

    /* Publications: right sidebar media */
.b-pub-right__media { display:block; margin-top:12px; }
.b-pub-right__img { display:block; width:100%; height:auto; border-radius:10px; }

.b-pub-right__banner { display:block; border-radius:10px; overflow:hidden; }
.b-pub-right__banner-img { display:block; width:100%; height:auto; }

/* Publications: sidebar banners swiper */
.b-pub-right__swiper { width:100%; margin-top:12px; }
.b-pub-right__swiper .swiper-slide { height:auto; }
.b-pub-right__pagination { margin-top:10px; text-align:center; }

  /* =========================================================
   PUBLICATIONS — TABLET (2 columns)
   CENTER + RIGHT in first row, LEFT goes under RIGHT (second row)
   ========================================================= */
@media screen and (min-width: 721px) and (max-width: 1024px){

    /* Общий layout: остаётся flex, но разрешаем перенос на 2 строки */
    .b-layout.b-layout--publications{
      display:flex;
      flex-wrap:wrap;
      gap:20px;
      align-items:flex-start;
    }
  
    /* ПЕРВАЯ СТРОКА: CENTER + RIGHT */
    .b-layout.b-layout--publications .b-layout__center{
      order:1;
      flex: 1 1 0;
      min-width: 0;
    }
  
    .b-layout.b-layout--publications .b-layout__right{
      order:2;
      flex: 0 0 240px;   /* можно 220–280 под твой дизайн */
      width: 240px;
    }
  
    /* ВТОРАЯ СТРОКА: LEFT (под правой, но фактически — после блока RIGHT) */
    .b-layout.b-layout--publications .b-layout__left{
      order:3;
      flex: 0 0 100%;
      width: 100%;
    }
  
    /* Чуть аккуратнее коробки на планшете */
    .b-layout.b-layout--publications .b-pubs-box{
      border-radius:10px;
    }
  
    /* Похожие публикации: 2 колонки на планшете
       (у тебя там .b-grid__wrapper cell-4) */
    .b-pub-similar__wrap .b-grid__wrapper{
      display:grid !important;
      grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
      gap:16px !important;
    }
  
    .b-pub-similar__wrap .b-grid__item{
      width:auto !important;
    }
  }

  /* =========================================================
   PUBLICATIONS — MOBILE (<= 720px)
   Order: RIGHT (only add button) -> CENTER -> LEFT
   ========================================================= */

  /* отступы для блока с другими работами */
  .b-work__after-comments {
    margin-top: 30px;
  }
  
#b-work-rating_btn {
  cursor: pointer;
}
#b-work-rating_btn[aria-disabled="true"],
#b-work-rating_btn.disabled {
  cursor: not-allowed;
}

.b-reviews {
  padding: 30px 0;
}
.b-reviews__head {
  margin-bottom: 16px;
}
.b-reviews__title {
  margin: 0;
}
.b-reviews__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}
.b-review-card__top {
  align-items: baseline;
}
.b-review-card__author {
  font-weight: 700;
}
.b-review-card__date {
  opacity: .7;
}

.b-page-heading {
  margin: 0 0 24px;
  font-family: "Raleway", sans-serif;
  font-size: 32px;
  font-weight: 700;
  line-height: 1.15;
}

.b-article__title.b-page-heading,
.componentheading.b-page-heading {
  font-size: inherit;
  line-height: inherit;
  margin-bottom: inherit;
}

@media screen and (max-width:790px) {
  .b-page-heading {
    font-size: 28px;
    margin-bottom: 20px;
  }

  .b-article__title.b-page-heading,
  .componentheading.b-page-heading {
    font-size: inherit;
    margin-bottom: inherit;
  }
}

@media screen and (max-width:480px) {
  .b-page-heading {
    font-size: 24px;
    margin-bottom: 18px;
  }

  .b-article__title.b-page-heading,
  .componentheading.b-page-heading {
    font-size: inherit;
    margin-bottom: inherit;
  }
}

.easy_entries.b-card-list .easy_frame.b-card {
  border: 1px solid #e5e7eb;
  border-radius: 18px;
  box-shadow: 0 12px 28px rgba(15, 23, 42, .06);
  margin-bottom: 0;
}
.b-form {
  max-width: 720px;
}
.b-form__row {
  margin-bottom: 14px;
}
.b-form__label,
.form-vertical .control-label {
  display: block;
  margin-bottom: 6px;
  font-weight: 700;
}
.b-form__input,
.b-form__textarea {
  width: 100%;
  border: 1px solid rgba(0,0,0,.15);
  border-radius: 10px;
  padding: 10px 12px;
  background: #fff;
  outline: none;
}
.b-form__textarea {
  resize: vertical;
}
.b-form__error {
  margin-top: 6px;
  color: #b00020;
  font-size: 13px;
}
.b-form__actions {
  margin-top: 18px;
}
.b-form__row--hp {
  display: none;
}
.b-form__profile-row {
  display: grid;
  grid-template-columns: 240px minmax(0, 620px);
  gap: 10px 20px;
  align-items: start;
  margin: 0 0 18px;
}

.b-form__profile-label {
  margin: 0;
  padding-top: 12px;
  font-weight: 600;
  line-height: 1.4;
}

.b-form__profile-control {
  width: 100%;
  max-width: 620px;
}

.b-form__profile-control > input,
.b-form__profile-control > select,
.b-form__profile-control > textarea,
.b-form__profile-control > .django-ckeditor-widget,
.b-form__profile-control > .related-widget-wrapper {
  width: 100%;
  max-width: 620px;
}

.b-form__profile-control > input[type="file"] {
  padding-top: 8px;
  padding-bottom: 8px;
}

.b-form__profile-help {
  color: #6b7280;
  font-size: 13px;
  line-height: 1.45;
  margin-top: 8px;
}

.b-form__profile-error {
  color: #b00020;
  font-size: 13px;
  margin-top: 8px;
}

.b-form--profile .b-form__actions {
  margin-top: 28px;
  padding-left: 260px;
}

.b-form--lk-edit {
  max-width: 920px;
}

.b-form--lk-edit .b-form-errors,
.b-form--lk-edit .b-form__errors {
  margin-bottom: 18px;
}

.b-form--lk-edit .b-add-form__row {
  display: grid;
  grid-template-columns: 240px minmax(0, 620px);
  gap: 10px 20px;
  align-items: start;
  margin: 0 0 18px;
}

.b-form--lk-edit .b-add-form__row:empty {
  display: none;
}

.b-form--lk-edit .b-add-form__label {
  float: none;
  width: auto;
  margin: 0;
  padding: 12px 0 0;
  font-weight: 600;
  line-height: 1.4;
}

.b-form--lk-edit .b-add-form__label label {
  margin: 0;
}

.b-form--lk-edit .b-add-form__input {
  float: none;
  width: 100%;
  max-width: 620px;
  margin: 0;
}

.b-form--lk-edit .b-add-form__input > input,
.b-form--lk-edit .b-add-form__input > select,
.b-form--lk-edit .b-add-form__input > textarea,
.b-form--lk-edit .b-add-form__input > .django-ckeditor-widget,
.b-form--lk-edit .b-add-form__input > .related-widget-wrapper {
  width: 100%;
  max-width: 620px;
}

.b-form--lk-edit .b-add-form__input > input[type="file"] {
  width: 100%;
  max-width: 620px;
  padding: 10px 12px;
  border: 1px dashed #cbd5e1;
  border-radius: 12px;
  background: #f8fafc;
}

.b-form--lk-edit .b-add-form__input .error {
  color: #b00020;
  font-size: 13px;
  margin-top: 8px;
}

.b-form--lk-edit .b-add-form__input br + a,
.b-form--lk-edit .b-add-form__input br + strong,
.b-form--lk-edit .b-add-form__input br + span {
  display: inline-block;
  margin-top: 6px;
}

.b-form--lk-edit .b-add-form__row.footer {
  display: block;
  margin-top: 28px;
  padding-left: 260px;
}

.b-form__profile-file {
  display: grid;
  gap: 12px;
}

.b-form__profile-file-meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 12px 20px;
  padding: 12px 14px;
  border: 1px solid #e5e7eb;
  border-radius: 12px;
  background: #fff;
}

.b-form__profile-file-current {
  display: flex;
  flex: 1 1 280px;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px 10px;
  min-width: 0;
}

.b-form__profile-file-caption {
  color: #374151;
  font-weight: 500;
  line-height: 1.4;
}

.b-form__profile-file-link {
  min-width: 0;
  word-break: break-word;
}

.b-form__profile-file-preview,
.b-form-current-file__preview {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  min-width: 0;
  color: #2563eb;
  text-decoration: none;
}

.b-form__profile-file-preview:hover,
.b-form-current-file__preview:hover {
  text-decoration: underline;
}

.b-form__profile-file-thumb,
.b-form-current-file__thumb {
  width: 72px;
  height: 72px;
  flex: 0 0 72px;
  border: 1px solid #d8dee4;
  border-radius: 12px;
  object-fit: cover;
  background: #f8fafc;
}

.b-form-current-file {
  margin-top: 12px;
  padding: 12px 14px;
  border: 1px solid #e5e7eb;
  border-radius: 12px;
  background: #fff;
}

.b-form-current-file__label {
  margin-bottom: 8px;
  color: #374151;
  font-weight: 600;
  line-height: 1.4;
}

.b-form-current-file__name {
  min-width: 0;
  overflow-wrap: anywhere;
  word-break: break-word;
}

.b-form__profile-file-clear {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-left: auto;
}

.b-form__profile-file-clear input[type="checkbox"] {
  width: 16px;
  height: 16px;
  margin: 0;
}

.b-form__profile-file-clear label {
  margin: 0;
  font-weight: 500;
  line-height: 1.4;
}

.b-form__profile-file-picker {
  display: grid;
  gap: 8px;
}

.b-form__profile-file-picker input[type="file"] {
  width: 100%;
  max-width: 620px;
  padding: 10px 12px;
  border: 1px dashed #cbd5e1;
  border-radius: 12px;
  background: #f8fafc;
}

@media (max-width: 900px) {
  .b-form__profile-row {
    grid-template-columns: 1fr;
    gap: 8px;
  }

  .b-form__profile-label,
  .b-form__profile-control,
  .b-form__profile-control > input,
  .b-form__profile-control > select,
  .b-form__profile-control > textarea,
  .b-form__profile-control > .django-ckeditor-widget,
  .b-form__profile-control > .related-widget-wrapper {
    max-width: none;
  }

  .b-form__profile-label {
    padding-top: 0;
  }

  .b-form__profile-file-meta {
    align-items: flex-start;
  }

  .b-form__profile-file-clear {
    margin-left: 0;
  }

  .b-form--profile .b-form__actions {
    padding-left: 0;
  }

  .b-form--lk-edit {
    max-width: none;
  }

  .b-form--lk-edit .b-add-form__row {
    grid-template-columns: 1fr;
    gap: 8px;
  }

  .b-form--lk-edit .b-add-form__label {
    padding-top: 0;
  }

  .b-form--lk-edit .b-add-form__input,
  .b-form--lk-edit .b-add-form__input > input,
  .b-form--lk-edit .b-add-form__input > select,
  .b-form--lk-edit .b-add-form__input > textarea,
  .b-form--lk-edit .b-add-form__input > .django-ckeditor-widget,
  .b-form--lk-edit .b-add-form__input > .related-widget-wrapper {
    max-width: none;
  }

  .b-form--lk-edit .b-add-form__row.footer {
    padding-left: 0;
  }
}
@media (max-width: 1024px) {
  .b-reviews__grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px) {
  .b-reviews__grid { grid-template-columns: 1fr; }
}
.easy_entrylink--spaced {
  margin-bottom: 16px;
}
.b-rating {
  display: inline-flex;
  flex-direction: row-reverse;
  gap: 6px;
}
.b-rating input {
  display: none;
}
.b-rating label {
  width: 20px;
  height: 20px;
  display: inline-block;
  cursor: pointer;
  opacity: .35;
}
.b-rating input:checked ~ label,
.b-rating label:hover,
.b-rating label:hover ~ label {
  opacity: 1;
  filter: invert(26%) sepia(83%) saturate(3538%) hue-rotate(309deg) brightness(92%) contrast(91%);
}
.b-rating-display {
  display: inline-flex;
  gap: 4px;
}
.easy_top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.easy_top_left {
  display: flex;
  align-items: center;
  gap: 8px;
  float: none;
}
.easy_top_right {
  float: none;
  margin-left: auto;
}
.b-rating-star {
  width: 16px;
  height: 16px;
  display: inline-block;
}

.b-rating label,
.b-rating-star {
  background: url(../img/zvzda.svg) center/contain no-repeat;
}
.easybook-page {
  background: #fff;
  padding: 20px;
  border-radius: 10px;
  border: none;
  box-shadow: none;
  max-width: 1200px;
  margin: 0 auto;
}
.easybook-form {
  border: none;
  box-shadow: none;
  max-width: 1200px;
}
.easybook-form .b-add-form__row {
  display: flex;
  align-items: flex-start;
  gap: 16px;
}
.easybook-form .b-add-form__label {
  width: 32%;
}
.easybook-form .b-add-form__input {
  width: 68%;
}
.easybook-form .b-add-form__input input,
.easybook-form .b-add-form__input textarea,
.easybook-form .b-add-form__input select {
  width: 100%;
}
.form-vertical .controls {
  margin-bottom: 14px;
}
.easybook-page .easybook-form {
  max-width: 100%;
}
.easy_top_left .b-pub-card__avatar {
  display: inline-block;
  margin-right: 8px;
  vertical-align: middle;
}
.easy_top_left .b-pub-card__avatar-img {
  vertical-align: middle;
}

/* === LK notifications drawer === */
.is-drawer-open {
  overflow: hidden;
}

.b-lk-bell {
  position: relative;
  width: 30px;
  height: 30px;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  padding: 0;
}

.b-headerbar__bell {
  margin-left: 20px;
  margin-top: 4px;
  flex: 0 0 auto;
}

.b-lk-bell__icon {
  line-height: 1;
  display: inline-flex;
}

.b-lk-bell__icon img {
  width: 30px;
  height: 30px;
  display: block;
}

.b-like-icon {
  display: inline-block;
  flex: 0 0 auto;
}

.b-like-icon--small {
  width: 16px;
  height: 16px;
}

.b-like-icon--big {
  width: 26px;
  height: 26px;
}

.b-lk-bell__dot {
  position: absolute;
  top: -2px;
  right: -4px;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: #dc2626;
}

.b-drawer {
  position: fixed;
  inset: 0;
  z-index: 11120;
}

.b-drawer[hidden] {
  display: none;
}

.b-drawer__overlay {
  position: absolute;
  inset: 0;
  border: 0;
  background: rgba(15, 23, 42, .42);
  opacity: 0;
  transition: opacity .2s ease;
}

.b-drawer__panel {
  position: absolute;
  top: 0;
  right: 0;
  width: min(460px, 100vw);
  height: 100%;
  max-height: 100dvh;
  background: #fff;
  box-shadow: -16px 0 40px rgba(15, 23, 42, .16);
  transform: translateX(100%);
  transition: transform .22s ease;
  display: flex;
  flex-direction: column;
}

.b-drawer.is-open .b-drawer__overlay {
  opacity: 1;
}

.b-drawer.is-open .b-drawer__panel {
  transform: translateX(0);
}

.b-drawer__header,
.b-drawer__footer {
  padding: 20px 24px;
  border-bottom: 1px solid #e5e7eb;
}

.b-drawer__footer {
  border-top: 1px solid #e5e7eb;
  border-bottom: 0;
}

.b-drawer__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.b-drawer__header-actions {
  display: flex;
  align-items: center;
  gap: 12px;
}

.b-drawer__title {
  margin: 0;
  font-size: 24px;
}

.b-drawer__close {
  width: 40px;
  height: 40px;
  border: 0;
  border-radius: 50%;
  background: #f3f4f6;
  font-size: 28px;
  line-height: 1;
  cursor: pointer;
}

.b-drawer__body {
  flex: 1;
  min-height: 0;
  overflow-y: auto;
  overscroll-behavior-y: contain;
  -webkit-overflow-scrolling: touch;
  padding: 24px;
}

.b-drawer__more,
.b-button--full {
  width: 100%;
}

.b-notif-list {
  display: grid;
  gap: 16px;
}

.b-notif-item {
  padding: 18px;
  border: 1px solid #e5e7eb;
  border-radius: 16px;
  background: #fff;
}

.b-notif-item--unread {
  border-color: #93c5fd;
  box-shadow: 0 8px 20px rgba(59, 130, 246, .08);
}

.b-notif-item__meta {
  margin-bottom: 8px;
  color: #6b7280;
  font-size: 13px;
}

.b-notif-item__title {
  margin-bottom: 10px;
  font-size: 18px;
  font-weight: 700;
  color: #111827;
}

.b-notif-item__text {
  color: #374151;
  line-height: 1.6;
}

.b-notif-item__text p {
  margin: 0 0 10px;
}

.b-notif-item__action {
  margin-top: 16px;
}

.b-notif-item__footer {
  margin-top: 16px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
}

.b-notif-item__status-wrap {
  display: flex;
  align-items: center;
}

.b-notif-item__read-btn {
  padding: 0;
  border: 0;
  background: transparent;
  color: #2563eb;
  font-size: 14px;
  font-weight: 500;
  text-decoration: underline;
  text-underline-offset: 3px;
  cursor: pointer;
}

.b-notif-item__read-state {
  color: #6b7280;
  font-size: 14px;
  font-weight: 500;
}

.b-notif-item__footer .b-notif-item__action {
  margin-top: 0;
  margin-left: auto;
}

.b-notif-list__empty {
  padding: 24px;
  border-radius: 16px;
  background: #f9fafb;
  color: #6b7280;
  text-align: center;
}

.b-account__support-link {
  color: #2563eb;
  font-weight: 600;
  text-decoration: none;
}

.b-account__support-link:hover {
  text-decoration: underline;
}

/* === LK support === */
.b-support-page {
  display: grid;
  gap: 24px;
}

.b-support-page__head,
.b-support-thread__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

.b-support-page__head {
  margin-bottom: 18px;
}

.b-support-cards,
.b-card-list {
  display: grid;
  gap: 18px;
}

.b-support-card,
.b-card,
.b-review-card {
  background: #fff;
  border: 1px solid #e5e7eb;
  border-radius: 18px;
  padding: 20px 22px;
  box-shadow: 0 12px 28px rgba(15, 23, 42, .06);
}

.b-support-card--unread,
.b-card--unread {
  border-color: #93c5fd;
}

.b-support-card__top,
.b-card__top,
.b-review-card__top {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 10px;
}

.b-support-card__title,
.b-card__title {
  margin: 0;
  font-size: 22px;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.b-support-card__date,
.b-card__date,
.b-review-card__date {
  color: #6b7280;
  white-space: nowrap;
}

.b-support-card__text,
.b-card__text {
  color: #374151;
  line-height: 1.6;
  margin-bottom: 16px;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.b-review-card__author {
  margin: 0;
  font-size: 14px;
  font-weight: 700;
}

.b-review-card__text {
  color: #374151;
  font-size: 12px;
  line-height: 1.45;
  margin-bottom: 16px;
  height: calc(1.45em * 3);
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.b-review-card__date {
  margin-top: 10px;
  font-size: 13px;
}

.b-support-empty {
  padding: 24px;
}

.b-support-empty__actions {
  margin-top: 16px;
}

.b-support-thread__messages {
  display: grid;
  gap: 14px;
  margin-bottom: 24px;
}

.b-support-thread__message {
  padding: 18px;
  border-radius: 16px;
  max-width: 820px;
}

.b-support-thread__message--user {
  background: #eff6ff;
  margin-left: auto;
}

.b-support-thread__message--staff {
  background: #f9fafb;
  border: 1px solid #e5e7eb;
}

.b-support-thread__meta {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 8px;
  font-size: 13px;
  color: #6b7280;
}

.b-support-thread__author {
  font-weight: 700;
  color: #111827;
}

.b-support-thread__text {
  color: #111827;
  line-height: 1.6;
}

.b-support-thread__form {
  display: grid;
  gap: 14px;
  justify-items: center;
}

.b-support-thread__form textarea,
.b-support-form-page input,
.b-support-form-page textarea {
  width: 100%;
  border: 1px solid #d1d5db;
  border-radius: 12px;
  padding: 14px 16px;
  font: inherit;
}

.b-support-form-page .b-add-form__row {
  display: flex;
  align-items: flex-start;
  gap: 18px;
}

.b-support-page--panel {
  background: #fff;
  border-radius: 10px;
  box-shadow: 0 12px 28px rgba(15, 23, 42, .06);
  padding: 24px 28px;
}

.b-support-form-page .b-add-form__label {
  width: 180px;
  flex: 0 0 180px;
  padding-right: 0;
}

.b-support-form-page .b-add-form__input {
  width: auto;
  flex: 1 1 auto;
  max-width: 720px;
  padding-right: 0;
}

.b-support-form-page .b-add-form__row.footer {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 16px;
  text-align: center;
}

.b-support-form-page .b-add-form__row.footer .btn {
  margin-bottom: 0;
}

.b-support-thread__form .b-form-field {
  width: min(1000px, 100%);
}

.b-support-thread__form textarea {
  width: 100%;
  min-height: 140px;
}

.b-support-thread__form .btn {
  width: auto;
}

@media (max-width: 1024px) {
  body.is-drawer-open {
    position: fixed;
    inset: 0;
    width: 100%;
  }

  .b-drawer__overlay {
    position: fixed;
  }

  .b-drawer__panel {
    position: fixed;
    top: 0;
    bottom: 0;
    height: 100dvh;
    max-height: 100dvh;
  }
}

@media (max-width: 900px) {
  .b-headerbar__bell {
    margin-left: 12px;
    margin-top: 0;
  }

  .b-drawer__panel {
    right: auto;
    left: 0;
    width: 88vw;
    max-width: 420px;
    height: 100dvh;
    max-height: 100dvh;
    transform: translateX(-100%);
  }

  .b-drawer.is-open .b-drawer__panel {
    transform: translateX(0);
  }

  .b-support-page__head,
  .b-support-thread__head,
  .b-support-card__top {
    flex-direction: column;
    align-items: flex-start;
  }

  .b-drawer__header {
    align-items: flex-start;
  }

  .b-drawer__header-actions {
    width: 100%;
    justify-content: space-between;
  }

  .b-support-thread__message {
    max-width: 100%;
  }

  .b-support-form-page .b-add-form__row {
    display: block;
  }

  .b-support-page--panel {
    padding: 20px;
  }

  .b-support-form-page .b-add-form__label,
  .b-support-form-page .b-add-form__input {
    width: 100%;
    max-width: none;
    flex: none;
  }

  .b-support-form-page .b-add-form__row.footer {
    flex-direction: column;
  }
}

/* Materials: support-style cards + floating detail panels */
.b-article-card--solid {
  border: 1px solid #e5e7eb;
  border-radius: 18px;
  box-shadow: 0 12px 28px rgba(15, 23, 42, .06);
}

.b-article.item-page .b-article__wrapper,
.b-article.item-page .b-article__attachments {
  border-radius: 10px;
  box-shadow: 0 12px 28px rgba(15, 23, 42, .06);
}

@media screen and (max-width:850px) {
  .b-step-itogi td.score:before {
    content: "Количество баллов";
  }

  .b-step-itogi td.url:before {
    content: "Работа";
  }

  .b-step-itogi td.work-title:before {
    content: "Название работы";
  }

  .b-step-itogi td.last:before {
    content: "Результат";
  }
}

.b-pub-float-btn {
  border-radius: 10px;
  box-shadow: 0 12px 28px rgba(15, 23, 42, .06);
}

.b-tests-intro {
  border-radius: 10px;
  box-shadow: 0 12px 28px rgba(15, 23, 42, .06);
}

.b-contest-category__description .b-article__text,
.b-contest-category__description .b-article__link {
  border-radius: 10px;
}

.b-contest-category__description .b-article__text,
.b-contest-category__description .b-article__link {
  box-shadow: 0 12px 28px rgba(15, 23, 42, .06);
}

.b-contest-category__description .b-article__link {
  display: block;
  border-radius: 10px;
  box-shadow: 0 12px 28px rgba(15, 23, 42, .1);
  overflow: hidden;
}

.b-contest-category__description .b-article__sidebar {
  background: transparent;
}

.b-contest-category__description .b-article__sidebar .b-article__link + .b-article__link {
  margin-top: 14px;
}

.b-step-itogi tr.header {
  background: #3da2d6 !important;
  margin-bottom: 12px;
}

.b-step-itogi tr.header th {
  color: #fff;
}

.b-step-itogi tr.header th span {
  position: relative;
  top: 2px;
}

@media screen and (max-width:850px) {
    .b-step-itogi tbody tr:not(.header):not(.b-step-itogi__head-gap):not(.b-step-itogi__separator) {
        display: flex !important;
        flex-direction: column !important;
        width: 100% !important;
    }

    .b-step-itogi tbody tr:not(.header):not(.b-step-itogi__head-gap):not(.b-step-itogi__separator) td.last {
        order: -1 !important;
        width: 100% !important;
    }
}

.b-step-itogi tr.b-step-itogi__head-gap,
.b-step-itogi tr.b-step-itogi__separator,
.b-step-itogi tr.b-step-itogi__head-gap td,
.b-step-itogi tr.b-step-itogi__separator td {
  background: transparent !important;
  box-shadow: none !important;
  border-radius: 0 !important;
}



.b-article-card__top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
}

.b-article-card__top .b-article-card__title {
  flex: 1 1 auto;
  margin-bottom: 0;
}

.b-article-card__title,
.b-article-card__title a,
.b-article-card__link {
  color: #111827;
  font-weight: 700;
}

.b-article-card__title a:hover,
.b-article-card__link:hover {
  color: #111827;
}

.b-article-card__date {
  flex: 0 0 auto;
  color: #6b7280;
  font-size: 14px;
  line-height: 1.4;
  text-align: right;
  white-space: nowrap;
}

.b-article-card__excerpt--clamp {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
  margin-top: 12px;
}

.b-article__wrapper blockquote {
  box-sizing: border-box;
  width: calc(100% + 68px);
  max-width: none;
  margin: 0 0 -29px -34px;
  border-radius: 0 0 10px 10px;
}

@media screen and (max-width: 970px) {
  .b-article__wrapper blockquote {
    width: calc(100% + 60px);
    max-width: none;
    margin: 0 0 -30px -30px;
    border-radius: 0 0 10px 10px;
  }
}

@media screen and (max-width: 790px) {
  .b-article-card__top {
    flex-direction: column;
    gap: 8px;
  }

  .b-article-card__date {
    text-align: left;
    white-space: normal;
  }

  .b-article__wrapper blockquote {
    width: calc(100% + 30px);
    max-width: none;
    margin: 0 0 -15px -15px;
    border-radius: 0 0 10px 10px;
  }
}


/* Homepage stage 1 */
.b-home-page {
    padding-bottom: 40px;
}

.b-home-section {
    padding: 10px 0;
}

.b-home-section--directions {
    background: #e4ecf0;
    padding-top: 10px;
    padding-bottom: 30px;
}

.b-section--best-works.b-home-section .b-module__wrapper {
    background: #e4ecf0;
}

.b-section--best-works.b-home-section {
    background: #e4ecf0;
    padding-top: 0;
}

.b-section--contests.b-home-section {
    background: #3da2d6;
    padding-top: 0;
    padding-bottom: 0;
}
/*Заголовок секции Главной страницы*/
.b-home-page .b-home-section__header,
.b-home-page .b-home-section__head,
.b-home-page .b-section__head.inside-dark {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    max-width: 1280px;
    padding-left: 0px;
    padding-right: 10px;
    margin: 0 auto 10px;
    box-sizing: border-box;
}

.b-home-card-slider {
    max-width: 1440px;
    padding-left: 34px;
    padding-right: 130px;
    margin-left: auto;
    margin-right: auto;
    margin-top: 0 !important;
    margin-bottom: 20px !important;
    box-sizing: border-box;
}

@media screen and (max-width:870px) {
    .b-home-card-slider {
        padding-left: 10px;
        padding-right: 10px;
    }
}

.b-home-page .b-home-section__heading,
.b-home-page .b-home-section__title,
.b-home-page .b-section__head.inside-dark h2,
.b-home-page .b-section__head.inside-dark .b-section__title {
    margin: 0;
    font-size: 28px;
    font-weight: bold;
    line-height: 1.3;
}

.b-home-page .b-home-section__heading--light,
.b-home-page .b-home-section__title,
.b-home-page .b-section--best-works .b-section__head.inside-dark h2 {
    color: #111827;
}

.b-home-page .b-home-section__heading--dark,
.b-home-page .b-section--contests .b-section__head.inside-dark h2,
.b-home-page .b-section--contests .b-section__head.inside-dark .b-section__title,
.b-home-page .b-home-section--quizzes .b-home-section__title {
    color: #fff;
}

.b-home-section__button-space {
    padding-top: 20px;
    padding-bottom: 40px;
}

/*Описания секции Главной страницы*/
.b-home-page .b-home-section__intro,
.b-home-page .b-home-section__intro-text {
    max-width: 1280px;
    margin: 0 auto 24px;
    padding-left: 0px;
    padding-right: 10px;
    box-sizing: border-box;
}


.b-home-page .b-home-section__intro p,
.b-home-page .b-home-section__intro-text p {
    margin: 0 0 12px;
}

.b-home-page .b-home-section__intro p:last-child,
.b-home-page .b-home-section__intro-text p:last-child {
    margin-bottom: 0;
}

@media screen and (max-width:870px) {
    .b-home-page .b-home-section__intro,
    .b-home-page .b-home-section__intro-text {
        padding-left: 10px;
        padding-right: 10px;
    }
}

.b-home-section__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 14px;
    margin-top: 24px;
}

.b-home-section__actions--center {
    justify-content: center;
}

.b-home-section__actions--reviews-top {
    margin-top: 0;
    margin-bottom: 24px;
}

.b-home-section__subhead {
    display: flex;
    justify-content: center;
    margin-top: -30px;
    margin-bottom: 44px;
}

.b-home-section__subtitle {
    margin: 0;
    font-size: 22px;
    font-weight: 700;
    line-height: 1.3;
    color: #111827;
    text-align: center;
}

.b-home-section--reviews .b-home-reviews-grid {
    margin-bottom: 50px;
}

.b-home-section--reviews .b-home-section__actions {
    margin-top: 0;
    margin-bottom: 70px;
}

.b-home-section--quizzes,
.b-home-section--materials {
    background: #3da2d6;
    color: #fff;
}

.b-home-section--quizzes {
    padding-bottom: 10px;
}

.b-home-section--awards,
.b-home-section--faq,
.b-home-section--publications {
    background: #e4ecf0;
}

.b-home-section--materials .b-section__head.inside-dark,
.b-home-section--awards .b-section__head.inside-dark,
.b-home-section--faq .b-section__head.inside-dark {
    margin: 0 auto 10px !important;
    padding-left: 10px !important;
    padding-right: 10px !important;
    box-sizing: border-box;
}

.b-home-section--materials .b-section__head.inside-dark,
.b-home-section--awards .b-section__head.inside-dark {
    max-width: 1300px !important;
}

.b-home-section--awards .b-home-section__title {
    margin: 0 !important;
    font-size: 28px !important;
    font-weight: 700 !important;
    line-height: 1.3 !important;
    color: #111827 !important;
}

.b-home-section--faq .b-section__head.inside-dark {
    max-width: 1180px !important;
}

.b-home-section--publications .b-home-section__head {
    margin-bottom: 0 !important;
    padding-bottom: 10px !important;
}

.b-home-section--publications .b-home-card-slider {
    padding-top: 0 !important;
    padding-bottom: 20px !important;
}

.b-home-section--quizzes .b-home-section__head {
    max-width: 1180px;
    padding-left: 10px;
    padding-right: 10px;
    margin: 0 auto 10px;
    box-sizing: border-box;
}

.b-home-section--quizzes .b-home-section__title {
    color: #fff;
}

.b-home-section--quizzes .b-home-quiz-grid {
    margin-top: 0;
    padding-top: 0 !important;
}

.b-home-section--quizzes .b-home-quiz-grid__item .item--wider {
    background: #fff;
    border-radius: 10px;
    box-shadow: 0 12px 28px rgba(15, 23, 42, .06);
    overflow: hidden;
}

.b-home-section--quizzes .b-home-quiz-grid__item .img {
    border-radius: 10px 10px 0 0;
    overflow: hidden;
}

.b-home-section--quizzes .b-home-quiz-grid__item .img img {
    display: block;
    width: 100%;
}

.b-home-section--quizzes .b-home-quiz-grid__item .text {
    padding: 10px;
}

.b-home-section--quizzes .b-home-quiz-grid__item .title {
    height: 54px;
    overflow: hidden;
    line-height: 1.5;
    max-width: 100%;
    margin-bottom: 0;
    padding-bottom: 15px;
}

.b-home-section--quizzes .b-home-quiz-grid__item .title .name {
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    overflow: hidden;
    text-overflow: ellipsis;
    font-size: 16px;
    font-weight: bold;
    color: #333;
    margin: 10px 0 5px;
    line-height: 1.5;
}

.b-home-section--quizzes .b-quiz-card__footer {
    border-top: 1px solid #e5e7eb;
    margin-top: 12px;
    padding-top: 12px;
}

.b-home-section--quizzes .b-home-empty {
    background: #fff;
}

.b-home-link {
    color: #1f2937;
    font-weight: 700;
    text-decoration: underline;
    text-underline-offset: 3px;
}

.b-home-empty {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 180px;
    padding: 28px;
    background: #fff;
    border-radius: 18px;
    color: #4b5563;
    box-shadow: 0 12px 28px rgba(15, 23, 42, .06);
}

.b-home-directions {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 40px;
    padding-top: 30px;
    margin-bottom: 30px;
    width: min(1280px, calc(100% - 120px));
    margin-left: auto;
    margin-right: auto;
    box-sizing: border-box;
}

.b-home-directions__item,
.b-home-how__card,
.b-home-vk {
    display: block;
    padding: 30px 28px;
    background: #fff;
    color: #111827;
    border-radius: 18px;
    box-shadow: 0 12px 28px rgba(15, 23, 42, .06);
}

.b-home-directions__item:hover {
    transform: translateY(-2px);
}

.b-home-directions__title,
.b-home-vk__title,
.b-home-materials__title {
    display: block;
    margin-bottom: 10px;
    font-size: 24px;
    line-height: 1.2;
    font-weight: 800;
}

.b-home-directions__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 42px;
    height: 42px;
    margin-bottom: 0;
    border-radius: 0;
}

.b-home-directions__head-row {
    display: flex;
    align-items: center;
    gap: 14px;
    margin-bottom: 14px;
}

.b-home-directions__icon img {
    width: 42px;
    height: 42px;
    display: block;
}

.b-home-directions__icon--contests,
.b-home-directions__icon--quizzes,
.b-home-directions__icon--olympiads,
.b-home-directions__icon--publications {
    background: transparent;
}


.b-home-directions__text,
.b-home-vk__text,
.b-home-awards__text {
    display: block;
    color: #4b5563;
    line-height: 1.65;
}

.b-works-card__contest-link {
    color: #111827;
}

.b-works-card__contest-link:hover {
    color: #111827;
}

.b-works-card .b-contest-category__title {
    height: auto;
    margin-bottom: 4px;
}

.b-works-card .b-contest-category__title a {
    display: -webkit-box;
    overflow: hidden;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
}

.b-works-card .b-contest-category__meta {
    margin-bottom: 0;
}

.b-works-card .b-contest-category__meta span {
    display: -webkit-box;
    overflow: hidden;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 1;
}

.b-works-card .b-contest-category__meta + .b-contest-category__meta {
    margin-top: 14px;
}

.b-works-card .b-works-card__contest-link {
    display: -webkit-box;
    overflow: hidden;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3;
}

.b-home-quiz-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 22px;
    width: calc(100% - 300px);
    max-width: 1280px;
    margin-left: auto;
    margin-right: auto;
    box-sizing: border-box;
}

.b-home-quiz-grid__item .item--wider {
    height: 100%;
}

.b-home-publications-slider .swiper-slide,
.b-home-quiz-grid__item {
    height: auto;
}

.b-home-publications-slider .swiper-slide {
    width: clamp(384px, 28.8vw, 480px) !important;
}

.b-pub-card--home {
    height: 100%;
    padding: 14px;
}

.b-pub-card__wrap--home {
    display: grid;
    grid-template-columns: 120px minmax(0, 1fr);
    gap: 14px;
    align-items: start;
}

.b-pub-card__cover--home {
    display: block;
    width: 120px;
    height: 160px;
    margin-bottom: 0;
}

.b-pub-card__content--home {
    position: relative;
    min-width: 0;
}

.b-pub-card__title--home {
    display: -webkit-box;
    margin-top: 0;
    overflow: hidden;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
}

.b-pub-card__author-row--home {
    margin-top: 10px;
    margin-bottom: 0;
}

.b-pub-card__text--home {
    display: -webkit-box;
    min-height: 2.9em;
    margin-top: 8px;
    overflow: hidden;
    font-style: normal;
    line-height: 1.45;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
}

.b-pub-card__footer--home {
    margin-top: 14px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}

.b-pub-card__footer-links--home {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    flex: 0 0 auto;
}

.b-pub-card__footer-stats--home {
    flex: 1 1 auto;
    justify-content: flex-end;
}

@media screen and (max-width:870px) {
    .b-home-publications-slider .swiper-slide {
        width: clamp(256px, 73.6vw, 416px) !important;
    }

    .b-pub-card__wrap--home {
        grid-template-columns: 1fr;
        gap: 12px;
    }

    .b-pub-card__cover--home {
        width: 100%;
        height: 180px;
    }

    .b-pub-card__footer--home {
        align-items: flex-start;
        flex-direction: column;
    }

    .b-pub-card__footer-stats--home {
        width: 100%;
        justify-content: flex-start;
    }
}

.b-home-how-wrap {
    max-width: 1000px;
    margin: 0 auto;
    padding: 0 10px;
    box-sizing: border-box;
}

.b-home-how {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 40px;
    color: #374151;
    line-height: 1.7;
    padding-top: 30px;
    padding-bottom: 30px;
}

.b-home-how__card {
    background: transparent;
    box-shadow: none;
    border-radius: 0;
    padding: 0;
}

.b-home-how__benefit {
    display: flex;
    align-items: flex-start;
    gap: 25px;
    padding: 0;
    background: transparent;
    border-radius: 0;
    box-shadow: none;
    max-width: 100%;
}

.b-home-how__benefit-icon {
    width: 52px;
    height: 52px;
    flex: 0 0 52px;
    object-fit: contain;
}

.b-home-how__benefit-text {
    color: #374151;
}

.b-home-reviews-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.b-home-materials,
.b-home-awards,
.b-home-faq {
    max-width: 1180px;
    box-sizing: border-box;
}

.b-home-materials {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 28px;
    margin: 0 auto 50px;
    padding: 0 10px;
}

.b-home-materials__title-row {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 14px;
    margin-bottom: 18px;
}

.b-home-materials__title-link {
    font-size: 22px;
    font-weight: 400;
    line-height: 1.3;
    color: #fff;
    text-decoration: underline;
    text-underline-offset: 3px;
}

.b-home-materials__list {
    display: grid;
    gap: 18px;
}

.b-home-section--materials .b-article-card__title,
.b-home-section--materials .b-article-card__title a,
.b-home-section--materials .b-article-card__link,
.b-home-section--materials .b-article-card__excerpt,
.b-home-section--materials .b-article-card__date {
    color: #111827;
}

.b-home-section--materials .b-article-card__excerpt--clamp {
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 4;
    overflow: hidden;
    margin-top: 12px;
    position: relative;
    min-height: calc(1.45em * 4);
    line-height: 1.45;
    -webkit-mask-image: linear-gradient(to bottom, #000 0%, #000 68%, rgba(0, 0, 0, .35) 88%, transparent 100%);
    mask-image: linear-gradient(to bottom, #000 0%, #000 68%, rgba(0, 0, 0, .35) 88%, transparent 100%);
}

.b-home-awards {
    position: relative;
    margin: 0 auto 50px;
    padding: 30px 64px 20px;
}

.b-home-awards__item {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(280px, 420px);
    gap: 40px;
    align-items: center;
}

.b-home-awards__content {
    color: #111827;
}

.b-home-awards__title {
    margin: 0 0 16px;
    font-size: 24px;
    font-weight: 700;
    line-height: 1.3;
}

.b-home-awards__actions {
    margin-top: 44px;
}

.b-home-awards__media {
    display: flex;
    justify-content: center;
    padding: 30px;
    box-sizing: border-box;
}

.b-home-awards__media img {
    max-width: 100%;
    max-height: 420px;
    object-fit: contain;
    display: block;
    border-radius: 10px;
    box-shadow: 0 12px 28px rgba(15, 23, 42, .06);
}

.b-home-awards__nav {
    position: absolute;
    top: 50%;
    left: 0;
    right: 0;
    display: flex;
    align-items: center;
    justify-content: space-between;
    transform: translateY(-50%);
    pointer-events: none;
}

.b-home-awards__prev,
.b-home-awards__next {
    pointer-events: auto;
    background: none !important;
    background-image: none !important;
    width: auto !important;
    height: auto !important;
}

.b-home-awards__prev::after,
.b-home-awards__next::after {
    display: block;
}

.b-home-faq {
    margin: 0 auto;
    padding: 30px 10px 20px;
}

.b-home-faq__item {
    border-bottom: 1px solid rgba(17, 24, 39, .12);
}

.b-home-faq__question {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 20px 0;
    background: transparent;
    border: 0;
    color: #111827;
    text-align: left;
    cursor: pointer;
}

.b-home-faq__question-text {
    font-size: 20px;
    font-weight: 700;
    line-height: 1.4;
}

.b-home-faq__icon {
    width: 18px;
    height: 18px;
    flex: 0 0 18px;
    object-fit: contain;
}

.b-home-faq__icon--down {
    display: none;
}

.b-home-faq__item.is-open .b-home-faq__icon--right {
    display: none;
}

.b-home-faq__item.is-open .b-home-faq__icon--down {
    display: block;
}

.b-home-faq__answer {
    padding: 0 0 20px;
    color: #374151;
    line-height: 1.7;
}

.b-home-faq__answer p:first-child {
    margin-top: 0;
}

.b-faq-page-card {
    background: #fff;
    border-radius: 10px;
    box-shadow: 0 12px 28px rgba(15, 23, 42, .06);
    padding: 10px 24px 20px;
}

.b-home-vk {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
    background: linear-gradient(135deg, #ffffff 0%, #f5fbff 100%);
}

.b-home-section--vk {
    padding-top: 80px;
    padding-bottom: 80px;
}

.b-home-vk__content {
    max-width: 760px;
}

.b-home-vk__title {
    margin-bottom: 12px;
}

.b-home-hero .slide-content--empty {
    min-height: 430px;
    align-items: center;
}

@media screen and (max-width: 1199px) {
    .b-home-directions,
    .b-home-quiz-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        width: calc(100% - 120px);
    }

    .b-home-awards__item {
        grid-template-columns: 1fr;
    }

    .b-home-awards__content {
        text-align: center;
    }

    .b-home-awards__actions {
        display: flex;
        justify-content: center;
    }

    .b-home-reviews-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .b-home-how {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 30px;
    }

    .b-home-materials {
        gap: 24px;
    }
}

@media screen and (max-width: 1399px) {
    .b-home-directions {
        gap: 24px;
    }
}

@media screen and (max-width: 767px) {
    .b-home-section {
        padding: 24px 0;
    }

    .b-home-section__head {
        margin-bottom: 18px;
    }

    .b-home-directions,
    .b-home-quiz-grid {
        grid-template-columns: 1fr;
        gap: 16px;
        width: 100%;
    }

    .b-home-awards {
        padding: 24px 10px 20px;
    }

    .b-home-awards__title {
        font-size: 20px;
    }

    .b-home-awards__media {
        padding: 10px;
    }

    .b-home-awards__nav {
        display: none;
    }

    .b-home-faq__question-text {
        font-size: 18px;
    }

    .b-home-directions__item,
    .b-home-how__card,
    .b-home-vk {
        padding: 22px;
        border-radius: 14px;
    }

    .b-home-directions__title,
    .b-home-vk__title,
    .b-home-materials__title {
        font-size: 22px;
    }

    .b-home-materials__title-row,
    .b-home-vk,
    .b-home-section__actions {
        align-items: flex-start;
        flex-direction: column;
    }

    .b-home-reviews-grid,
    .b-home-how,
    .b-home-materials {
        grid-template-columns: 1fr;
    }

    .b-home-how {
        gap: 24px;
    }

    .b-home-section__actions .btn,
    .b-home-vk__actions .btn {
        width: 100%;
    }
}

#main-slider .swiper-button-prev,
#main-slider .swiper-button-next {
    background: none !important;
}

#main-slider .swiper-container,
#main-slider .swiper-wrapper,
#main-slider .swiper-slide {
    height: auto !important;
}

#main-slider .swiper-wrapper,
#main-slider .swiper-slide,
#main-slider .topSlide,
#main-slider .slide-content {
    min-height: 330px;
}

#main-slider .swiper-wrapper {
    align-items: stretch;
}

#main-slider .slide-content {
    align-items: center;
    padding-top: 20px;
    padding-bottom: 56px;
}

@media screen and (max-width: 1199px) {
    #main-slider .swiper-wrapper,
    #main-slider .swiper-slide,
    #main-slider .topSlide,
    #main-slider .slide-content {
        min-height: 390px;
    }

    #main-slider .slide-content {
        align-items: flex-start;
        padding-top: 30px;
        padding-bottom: 68px;
    }

    #main-slider .txtBlock {
        flex-basis: min(100%, 720px);
    }

    #main-slider .txtBlock .name {
        font-size: clamp(28px, 4vw, 36px);
    }

    #main-slider .txtBlock .txtText {
        font-size: 16px;
        line-height: 1.55;
    }
}

@media screen and (max-width: 860px) {
    #main-slider .swiper-wrapper,
    #main-slider .swiper-slide,
    #main-slider .topSlide,
    #main-slider .slide-content {
        min-height: 0;
    }

    #main-slider .slide-content {
        flex-direction: column;
        justify-content: center;
        gap: 20px;
        padding: 24px 5% 64px;
    }

    #main-slider .txtBlock,
    #main-slider .rightImage {
        flex: 0 0 auto;
        width: 100%;
    }

    #main-slider .rightImage {
        justify-content: center;
    }

    #main-slider .rightImage img {
        max-height: 180px;
    }
}

@media screen and (min-width:831px) and (max-width:1279px) {
    .contests-swiper .swiper-slide {
        width: 25%;
    }
}

@media screen and (min-width:1280px) {
    .contests-swiper .swiper-slide {
        width: 20%;
    }
}

.b-section--contests .contests-swiper .swiper-slide {
    width: clamp(240px, 22vw, 320px) !important;
    height: auto;
}

.b-section--contests .contests-swiper .swiper-slide > .item.item--wider,
.b-section--contests .contests-swiper .swiper-slide > .item--wider {
    width: 100%;
    margin: 0;
}

@media screen and (max-width:1024px) {
    .b-section--contests .contests-swiper .swiper-slide {
        width: clamp(220px, 42vw, 300px) !important;
    }
}

@media screen and (max-width:767px) {
    .b-section--contests .contests-swiper .swiper-slide {
        width: clamp(210px, 78vw, 260px) !important;
    }
}

.page-expert {
  background: #f2f2f2;
}

.b-expert-shell {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

.b-expert-header {
  padding: 18px 0 10px;
}

.b-expert-header .wrapper {
  max-width: none;
  margin: 0;
  padding-left: 20px;
  padding-right: 20px;
}

.b-expert-header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
}

.b-expert-header__brand {
  display: inline-flex;
  align-items: center;
}

.b-expert-header__logo {
  width: 160px;
  height: auto;
  display: block;
}

.b-iconbtn--expert-back {
  background: #fff;
}

.b-expert-main {
  flex: 1 1 auto;
}

.b-expert-footer-note {
  padding: 20px 16px 24px;
  text-align: center;
  font-size: 13px;
  line-height: 1.4;
  color: #7a8699;
  letter-spacing: .04em;
}

.b-expert-page {
  padding-bottom: 20px;
}

.b-expert-page__head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 20px;
  margin-bottom: 20px;
}

.b-expert-page__lead {
  margin: 8px 0 0;
  color: #607085;
}

.b-expert-page__backlink {
  display: inline-block;
  margin-bottom: 8px;
  color: #3da2d6;
  font-size: 12px;
  text-decoration: none;
}

.b-expert-page__backlink:hover,
.b-expert-sortlink:hover {
  text-decoration: underline;
}

.b-expert-filters__form {
  display: grid;
  gap: 18px;
}

.b-expert-filters__grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px 16px;
}

.b-expert-filters__field {
  display: grid;
  gap: 6px;
}

.b-expert-filters__field--search {
  grid-column: span 2;
}

.b-expert-filters__label,
.b-expert-form__label {
  font-size: 13px;
  line-height: 1.4;
  color: #5e6c80;
}

.b-expert-filters__control,
.b-expert-form__control,
.b-expert-form__textarea {
  width: 100%;
  min-height: 44px;
  padding: 10px 12px;
  border: 1px solid #dbe3ed;
  border-radius: 10px;
  background: #fff;
  color: #1b2430;
  font: inherit;
  box-sizing: border-box;
}

.b-expert-form__textarea {
  min-height: 132px;
  resize: vertical;
}

.b-expert-filters__control:focus,
.b-expert-form__control:focus,
.b-expert-form__textarea:focus {
  outline: none;
  border-color: #3da2d6;
  box-shadow: 0 0 0 3px rgba(61, 162, 214, .14);
}

.b-expert-filters__actions {
  display: flex;
  gap: 12px;
  align-items: center;
}

.b-step-itogi--expert th,
.b-step-itogi--expert td {
  vertical-align: top;
}

.b-step-itogi--expert .b-step-itogi__link--expert-open {
  white-space: nowrap;
}

.b-expert-sortlink {
  color: #1f3145;
  text-decoration: none;
}

.b-work--expert {
  align-items: flex-start;
}

.b-work-panel--expert {
  width: 100%;
}

.b-expert-info {
  display: grid;
  gap: 18px;
}

.b-expert-info__block + .b-expert-info__block {
  padding-top: 18px;
  border-top: 1px solid #e7edf5;
}

.b-expert-info__title {
  margin: 0 0 12px;
  font-size: 18px;
  line-height: 1.3;
  color: #1f3145;
}

.b-work__desc--expert {
  margin-top: 24px;
}

.b-expert-form {
  display: grid;
  gap: 14px;
}

.b-expert-form__field {
  display: grid;
  gap: 6px;
}

.b-expert-form__hint {
  margin: 0;
  font-size: 13px;
  line-height: 1.5;
  color: #6b778a;
}

.b-expert-form__errors ul,
.b-expert-form__field ul.errorlist {
  margin: 4px 0 0;
  padding: 0;
  list-style: none;
  color: #b42318;
  font-size: 13px;
}

.b-expert-file {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 16px 18px;
  border: 1px solid #dbe3ed;
  border-radius: 12px;
  background: #f9fbfd;
}

.b-expert-file__meta {
  display: grid;
  gap: 4px;
}

.b-expert-file__type {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: fit-content;
  min-width: 52px;
  padding: 4px 8px;
  border-radius: 999px;
  background: #e8f4fa;
  color: #2a80a9;
  font-size: 12px;
  font-weight: 700;
}

.b-expert-file__name,
.b-expert-work-preview__linkline {
  color: #607085;
}

.b-expert-empty {
  padding: 18px;
  border-radius: 12px;
  background: #f9fbfd;
  color: #607085;
}

@media (max-width: 1100px) {
  .b-expert-filters__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 900px) {
  .b-expert-header__inner,
  .b-expert-page__head,
  .b-expert-filters__actions,
  .b-expert-file {
    flex-direction: column;
    align-items: flex-start;
  }

  .b-work--expert {
    display: block;
  }

  .b-work--expert .b-work__sidebar {
    margin-top: 20px;
  }
}

@media (max-width: 640px) {
  .b-expert-header__logo {
    width: 132px;
  }

  .b-expert-filters__grid {
    grid-template-columns: 1fr;
  }

  .b-expert-filters__field--search {
    grid-column: auto;
  }

  .b-step-itogi--expert {
    min-width: 1080px;
  }
}

.b-expert-panel__head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 16px;
}

.b-expert-side-note {
  margin: 0;
  color: #607085;
  font-size: 13px;
}

.b-expert-filters__period {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: 10px;
  align-items: center;
}

.b-expert-filters__period-sep {
  color: #8b98ab;
}

.b-expert-bulk__form {
  display: grid;
  gap: 18px;
}

.b-expert-bulk__controls {
  display: grid;
  grid-template-columns: 1.2fr 1fr auto;
  gap: 14px 16px;
  align-items: end;
}

.b-expert-bulk__item {
  display: grid;
  gap: 6px;
}

.b-expert-bulk__item--actions {
  display: flex;
  gap: 12px;
  align-items: center;
  justify-content: flex-end;
}

.b-expert-bulk__danger {
  margin-left: auto;
  border-color: #f1b3b0;
  color: #b42318;
}

.b-expert-bulk__danger:hover {
  background: #fff5f5;
}

.b-expert-check {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  cursor: pointer;
}

.b-expert-check input {
  width: 16px;
  height: 16px;
}

.b-expert-work-link {
  color: #1f3145;
  text-decoration: none;
  border-bottom: 1px solid rgba(31, 49, 69, .18);
  font-weight: 700;
}

.b-expert-work-link:hover {
  color: #3da2d6;
  border-color: rgba(61, 162, 214, .28);
}

.b-expert-comment-link {
  color: #1f3145;
  text-decoration: none;
  border-bottom: 1px solid rgba(31, 49, 69, .14);
}

.b-expert-comment-link:hover {
  color: #3da2d6;
  border-color: rgba(61, 162, 214, .28);
}

.b-expert-comment-hint {
  margin-top: 2px;
  color: #8b98ab;
  font-size: 12px;
  line-height: 1.3;
}

.b-expert-comment-preview {
  font-size: 12px;
  line-height: 1.35;
  color: #1f3145;
}

.b-expert-comment-head {
  display: grid;
  gap: 4px;
  margin-bottom: 10px;
}

.b-expert-comment-head__title {
  margin: 0;
}

.b-expert-comment-info {
  display: grid;
  gap: 6px;
}

.b-expert-comment-info__row {
  display: flex;
  gap: 8px;
  align-items: baseline;
  flex-wrap: wrap;
}

.b-expert-comment-info__label {
  color: #607085;
  font-size: 12px;
  line-height: 1.3;
}

.b-expert-comment-info__value {
  color: #1f3145;
  font-size: 12px;
  line-height: 1.3;
}

.b-expert-comment-body {
  font-size: 13px;
  line-height: 1.45;
  color: #1f3145;
  white-space: normal;
}

.b-expert-col--check {
  width: 46px;
}

.b-expert-col--id {
  width: 70px;
  text-align: right;
}

.b-expert-col--open {
  width: 110px;
  text-align: right;
}

.b-expert-col--stars {
  width: 120px;
  white-space: nowrap;
}

.b-expert-col--supportstate {
  width: 72px;
  text-align: center;
}

.b-expert-row--accent td {
  font-weight: 700;
}

.b-expert-supportstate {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border-radius: 999px;
  font-weight: 800;
  font-size: 14px;
}

.b-expert-supportstate--new {
  background: #15476c;
  color: #ffffff;
  box-shadow: 0 10px 18px rgba(21, 71, 108, .22);
}

.b-expert-supportstate--alert {
  background: #15476c;
  color: #ffffff;
  opacity: 0.75;
  box-shadow: 0 10px 18px rgba(21, 71, 108, .12);
}

.b-expert-supportstate--done {
  background: #edf1f5;
  color: #64748b;
}

.b-expert-supportstate--closed {
  background: #fff1f2;
  color: #be123c;
}

.b-expert-supportstate--new::before { content: "!"; }
.b-expert-supportstate--alert::before { content: "!"; }
.b-expert-supportstate--done::before { content: "✓"; }
.b-expert-supportstate--closed::before { content: "×"; }

.b-expert-supportstate--new::before {
  font-size: 18px;
  line-height: 1;
}

.b-expert-supportstate--alert::before {
  font-size: 18px;
  line-height: 1;
  font-weight: 600;
}

.b-expert-supportmeta {
  display: flex;
  gap: 12px;
  align-items: center;
  flex-wrap: wrap;
}

.b-expert-supportstatus {
  margin-top: 10px;
}

.b-expert-supportstatus__row {
  display: flex;
  gap: 10px;
  align-items: center;
  flex-wrap: wrap;
}

.b-expert-hidden {
  display: none;
}

.b-expert-filterbox__submit--mini {
  padding: 6px 10px;
  font-size: 12px;
  line-height: 1.2;
}

.b-expert-bulkbox__toolbar {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}

.b-expert-bulkbox__inline {
  display: flex;
  align-items: center;
  gap: 10px;
}

.b-expert-bulkbox__select {
  width: 260px;
  max-width: 260px;
}

.b-expert-flag {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  font-weight: 700;
  font-size: 14px;
}

.b-expert-flag--yes {
  background: #e7f8ee;
  color: #18834f;
}

.b-expert-flag--no {
  background: #edf1f5;
  color: #7b8798;
}

.b-expert-flagform {
  display: inline-flex;
  margin: 0;
}

.b-expert-flagbtn {
  display: inline-flex;
  padding: 0;
  border: 0;
  background: transparent;
  cursor: pointer;
  border-radius: 999px;
}

.b-expert-flagbtn:focus-visible {
  outline: 2px solid #15476c;
  outline-offset: 2px;
}

.b-expert-flagbtn:hover .b-expert-flag {
  box-shadow: 0 0 0 2px rgba(21, 71, 108, .12);
}

.b-expert-muted {
  color: #8b98ab;
}

.b-expert-summary {
  margin-bottom: 20px;
}

.b-expert-summary,
.b-expert-detail {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(380px, 1.08fr);
  gap: 20px;
}

.b-expert-summary__left,
.b-expert-summary__right {
  display: grid;
  gap: 14px;
}

.b-expert-summary__item {
  display: grid;
  gap: 4px;
}

.b-expert-summary__label {
  color: #607085;
  font-size: 13px;
  line-height: 1.4;
}

.b-expert-summary__value {
  color: #1f3145;
  line-height: 1.5;
}

.b-expert-summary__prepared {
  display: grid;
  gap: 4px;
}

.b-expert-summary__prepared-note {
  color: #8b98ab;
  font-size: 12px;
}

.b-expert-detail__main,
.b-expert-detail__aside {
  min-width: 0;
}

.b-expert-media__visual {
  overflow: hidden;
  border-radius: 14px;
  background: #f4f7fb;
}

.b-expert-media__visual--secondary,
.b-expert-file--secondary {
  margin-top: 18px;
}

.b-expert-media__image,
.b-expert-media__frame {
  width: 100%;
  display: block;
  border: 0;
}

.b-expert-media__frame {
  min-height: 520px;
}

.b-expert-media__admin-tools {
  display: grid;
  gap: 12px;
  margin-top: 18px;
}

.b-expert-media__service-row {
  display: grid;
  gap: 4px;
  padding: 12px 14px;
  border-radius: 12px;
  background: #f8fafc;
}

.b-expert-media__service-row a {
  color: #3da2d6;
  overflow-wrap: anywhere;
}

.b-expert-media__service-col {
  display: grid;
  gap: 6px;
}

.b-expert-media__description {
  margin-top: 22px;
}

.b-expert-sideform {
  display: grid;
  gap: 18px;
}

.b-expert-review,
.b-expert-criteria,
.b-expert-actions {
  height: fit-content;
}

.b-expert-criteria__list {
  display: grid;
  gap: 12px;
}

.b-expert-criteria__item {
  display: grid;
  gap: 12px;
  padding: 14px;
  border: 1px solid #e7edf5;
  border-radius: 14px;
  background: #fbfcfe;
}

.b-expert-criteria__titleline {
  display: flex;
  align-items: center;
  gap: 10px;
}

.b-expert-criteria__title {
  color: #1f3145;
  font-weight: 700;
}

.b-expert-criteria__info {
  width: 24px;
  height: 24px;
  padding: 0;
  border: 1px solid #d4deea;
  border-radius: 50%;
  background: #fff;
  color: #607085;
  font-weight: 700;
  cursor: pointer;
}

.b-expert-criteria__description {
  margin-top: 8px;
  color: #607085;
  font-size: 13px;
  line-height: 1.5;
}

.b-expert-criteria__scores {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.b-expert-criteria__score {
  position: relative;
}

.b-expert-criteria__score input {
  position: absolute;
  inset: 0;
  opacity: 0;
}

.b-expert-criteria__score span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 42px;
  height: 42px;
  border-radius: 12px;
  border: 1px solid #d4deea;
  background: #fff;
  color: #607085;
  font-weight: 700;
}

.b-expert-criteria__score input:focus + span {
  border-color: #3da2d6;
  box-shadow: 0 0 0 3px rgba(61, 162, 214, .14);
}

.b-expert-criteria__score input:checked + span {
  border-color: #3da2d6;
  background: #e8f4fa;
  color: #1f3145;
}

.b-expert-criteria__total {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-top: 18px;
  padding-top: 16px;
  border-top: 1px solid #e7edf5;
}

.b-expert-criteria__total-label {
  color: #607085;
}

.b-expert-criteria__total-value {
  font-size: 24px;
  color: #1f3145;
}

.b-expert-actions__row,
.b-expert-actions__stack {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}

.b-expert-actions__stack {
  flex-direction: column;
}

@media (max-width: 1200px) {
  .b-expert-summary,
  .b-expert-detail {
    grid-template-columns: 1fr;
  }

  .b-expert-bulk__controls {
    grid-template-columns: 1fr 1fr;
  }

  .b-expert-bulk__item--actions {
    grid-column: 1 / -1;
    justify-content: flex-start;
  }
}

@media (max-width: 900px) {
  .b-expert-actions__row {
    flex-direction: column;
    align-items: stretch;
  }

  .b-expert-bulk__controls {
    grid-template-columns: 1fr;
  }

  .b-expert-filters__period {
    grid-template-columns: 1fr;
  }

  .b-expert-filters__period-sep {
    display: none;
  }
}

@media (max-width: 640px) {
  .b-step-itogi--expert {
    min-width: 1800px;
  }

  .b-expert-media__frame {
    min-height: 320px;
  }

  .b-expert-panel__head {
    flex-direction: column;
    align-items: flex-start;
  }
}

.b-expert-admin-page {
  padding: 0 20px 24px;
}

.b-expert-page--admin {
  padding-bottom: 16px;
}

.b-expert-page__head--admin {
  margin-bottom: 14px;
  display: grid;
  gap: 10px;
}

.b-expert-page__head-main {
  min-width: 0;
}

.b-expert-admin-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin: 8px 0 12px;
  flex-wrap: wrap;
}

.b-expert-admin-toolbar__main,
.b-expert-admin-toolbar__side {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.b-expert-admin-toolbar .b-expert-filterbox__submit,
.b-expert-admin-toolbar .b-expert-bulkbox__danger {
  width: auto;
}

.b-expert-admin-toolbar__main--right {
  justify-content: flex-end;
  width: 100%;
}

.b-expert-admin-titlebar {
  display: grid;
  gap: 4px;
}

.b-expert-admin-titlebar__row {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
}

.b-expert-admin-titlebar__title {
  margin: 0;
}

.b-expert-admin-titlebar__edit {
  flex: 1 1 auto;
  min-width: 280px;
}

.b-expert-admin-titlebar__edit .b-expert-form__control {
  width: 100%;
}

.b-expert-admin-titlebar__toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  padding: 0;
  border: 1px solid #c8d5e2;
  border-radius: 8px;
  background: #fff;
  color: #15476c;
  font-size: 16px;
  line-height: 1;
  cursor: pointer;
}

.b-expert-admin-titlebar__toggle:hover {
  border-color: #3da2d6;
  background: #f4faff;
}

.b-expert-admin-date {
  display: grid;
  justify-items: end;
  gap: 4px;
}

.b-expert-admin-date__label {
  color: #607085;
  font-size: 12px;
  line-height: 1.2;
}

.b-expert-admin-date__value {
  color: #1f3145;
  font-size: 13px;
  font-weight: 600;
  line-height: 1.2;
  white-space: nowrap;
}

.b-expert-admin-panel {
  margin-bottom: 14px;
}

.b-expert-admin-panel--filters.b-panel--pad {
  padding-bottom: 4px;
}

.b-expert-admin-nav {
  padding: 10px 0 0;
}

.b-expert-admin-nav__list {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin: 0;
  padding: 0;
  list-style: none;
  justify-content: center;
}

.b-expert-admin-nav__link {
  display: inline-flex;
  align-items: center;
  min-height: 44px;
  padding: 0 22px;
  border: 1px solid #9aa8b8;
  border-radius: 8px;
  color: #15476c;
  font-size: 16px;
  font-weight: 600;
  text-decoration: none;
  background: #fff;
}

.b-expert-admin-nav__link:hover {
  border-color: #3da2d6;
  background: #f4faff;
  text-decoration: none;
}

.b-expert-admin-nav__link.is-active {
  border-color: #3da2d6;
  background: #e9f6ff;
}

.b-expert-admin-home {
  margin-top: 14px;
}

.b-expert-admin-home__title {
  margin: 0;
  text-align: center;
}

.b-expert-admin-home__hint {
  margin: 8px 0 0;
  color: #607085;
  font-size: 13px;
}

.b-expert-admin-home__grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  margin-top: 14px;
}

.b-expert-admin-home__tile {
  display: block;
  padding: 14px 14px 12px;
  border-radius: 12px;
  background: #f7fafc;
  border: 1px solid rgba(21, 71, 108, .14);
  color: inherit;
  text-decoration: none;
  transition: transform .12s ease, box-shadow .12s ease, border-color .12s ease;
}

.b-expert-admin-home__tile:hover {
  transform: translateY(-1px);
  border-color: rgba(21, 71, 108, .28);
  box-shadow: 0 12px 24px rgba(15, 23, 42, .10);
}

.b-expert-admin-home__tile-title {
  font-weight: 800;
  font-size: 16px;
  line-height: 1.2;
}

.b-expert-admin-home__tile-hint {
  margin-top: 6px;
  font-size: 12px;
  line-height: 1.3;
  color: #64748b;
}

@media (max-width: 980px) {
  .b-expert-admin-home__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 640px) {
  .b-expert-admin-home__grid {
    grid-template-columns: 1fr;
  }
}

.b-expert-admin-panel--bulk {
  position: sticky;
  top: 10px;
  z-index: 40;
}

.b-expert-admin-panel--bulk.b-panel--pad {
  padding: 10px 12px;
}

.b-expert-admin-panel--bulk.is-sticky-fixed {
  position: fixed;
  z-index: 60;
  margin-bottom: 0;
  border: 1px solid #d7e0ea;
  box-shadow: 0 12px 24px rgba(27, 36, 48, .14);
}

.b-expert-sticky-spacer {
  height: 0;
}

.b-expert-admin-panel .b-title--h2,
.b-expert-summary--admin .b-title--h2,
.b-expert-detail--admin .b-title--h2 {
  font-size: 24px;
}

.b-expert-panel__head--compact {
  margin-bottom: 12px;
}

.b-expert-panel__head--subtle .b-title--h2 {
  font-size: 17px;
  line-height: 1.2;
}

.b-expert-filters__form--admin,
.b-expert-bulk__form--admin,
.b-expert-admin-form {
  gap: 12px;
}

.b-expert-filterbox {
  display: grid;
  gap: 10px;
}

.b-expert-filterbox__toolbar {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 12px;
  flex-wrap: nowrap;
}

.b-expert-filterbox__details {
  flex: 1 1 100%;
  min-width: 0;
  width: 100%;
}

.b-expert-filterbox__summary {
  list-style: none;
  cursor: pointer;
}

.b-expert-filterbox__summary::marker,
.b-expert-filterbox__summary::-webkit-details-marker {
  display: none;
}

.b-expert-filterbox__trigger {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  color: #15476c;
  font-size: 16px;
  font-weight: 700;
  line-height: 1.2;
}

.b-expert-filterbox__trigger::after {
  content: "▾";
  display: inline-block;
  font-size: 15px;
  line-height: 1;
  transition: transform .2s ease;
}

.b-expert-filterbox__details[open] .b-expert-filterbox__trigger::after {
  transform: rotate(180deg);
}

.b-expert-filterbox__dropdown {
  margin-top: 10px;
  padding: 12px;
  border: 1px solid #e2e8f0;
  border-radius: 12px;
  background: #f9fbfd;
}

.b-expert-filterbox__footer {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
  margin-top: 10px;
  flex-wrap: wrap;
}

.b-expert-filterbox__perpage {
  display: flex;
  align-items: center;
  gap: 8px;
}

.b-expert-filterbox__perpage-label {
  color: #607085;
  font-size: 13px;
  white-space: nowrap;
}

.b-expert-filterbox__perpage .b-expert-filters__control {
  min-width: 92px;
}

.b-expert-bulkbox {
  display: grid;
  gap: 5px;
}

.b-expert-bulkbox__toolbar {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 8px;
}

.b-expert-bulkbox__title {
  display: inline-flex;
  align-items: center;
  color: #15476c;
  font-size: 15px;
  font-weight: 700;
  line-height: 1.2;
}

.b-expert-bulkbox__danger {
  min-height: 27px;
  padding: 0 14px;
  margin-left: auto;
  border: 1px solid #e31920;
  border-radius: 8px;
  background: #e31920;
  color: #fff;
  font: inherit;
  font-size: 13px;
  font-weight: 700;
  line-height: 1;
  cursor: pointer;
  transition: background-color .2s ease, border-color .2s ease;
}

.b-expert-bulkbox__danger:hover {
  background: #c9151b;
  border-color: #c9151b;
  color: #fff;
}

.b-expert-filters__grid--admin {
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 10px 12px;
}

.b-expert-filters__grid--jury {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px 12px;
}

.b-expert-filters__grid--jury .b-expert-filters__field--search,
.b-expert-filters__grid--jury .b-expert-filters__field--period {
  grid-column: span 2;
}

.b-expert-jury-start {
  display: flex;
  justify-content: center;
  margin: 0 0 14px;
}

.b-expert-jury-start__button {
  min-width: 260px;
  text-align: center;
}

.b-expert-jury-nav {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 20px;
  margin: 0 0 18px;
}

.b-expert-jury-nav__side {
  flex: 1 1 50%;
  display: flex;
}

.b-expert-jury-nav__side--right {
  justify-content: flex-end;
}

.b-expert-jury-nav__button {
  min-width: 260px;
  text-align: center;
}

.b-expert-jury-apply {
  display: flex;
  justify-content: flex-end;
  margin-top: 14px;
}

.b-expert-jury-table__status {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 5px 10px;
  border-radius: 999px;
  background: #eef6fb;
  color: #15476c;
  font-size: 12px;
  font-weight: 700;
  line-height: 1.2;
}

.b-expert-jury-table__link {
  display: inline-flex;
  flex-direction: column;
  gap: 4px;
}

.b-expert-jury-table__work-title {
  font-weight: 700;
}

.b-expert-jury-table__work-action {
  display: none;
  color: #3da2d6;
  font-size: 12px;
  font-weight: 700;
  line-height: 1.2;
}

.b-expert-jury-mobile-summary,
.b-expert-jury-mobile-actions {
  display: none;
}

.b-expert-jury-mobile-summary__head,
.b-expert-jury-review__head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.b-expert-jury-mobile-summary__titlebox {
  min-width: 0;
}

.b-expert-jury-mobile-summary__work {
  margin-top: 6px;
  color: #1f3145;
  font-size: 15px;
  font-weight: 700;
  line-height: 1.35;
}

.b-expert-jury-mobile-summary__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.b-expert-jury-mobile-summary__item {
  display: grid;
  gap: 4px;
  padding: 12px 14px;
  border: 1px solid #e2e8f0;
  border-radius: 12px;
  background: #f8fbfd;
}

.b-expert-jury-mobile-summary__item--wide {
  grid-column: 1 / -1;
}

.b-expert-jury-mobile-summary__label {
  color: #607085;
  font-size: 12px;
  line-height: 1.25;
}

.b-expert-jury-mobile-summary__value {
  color: #1b2634;
  font-size: 14px;
  font-weight: 600;
  line-height: 1.35;
  overflow-wrap: anywhere;
}

.b-expert-jury-fold__toggle {
  display: none;
  align-items: center;
  justify-content: center;
  min-height: 40px;
  padding: 0 14px;
  border: 1px solid #c8d5e2;
  border-radius: 10px;
  background: #fff;
  color: #15476c;
  font-size: 13px;
  font-weight: 700;
  line-height: 1;
  white-space: nowrap;
}

.b-expert-jury-fold__toggle:hover {
  border-color: #3da2d6;
  background: #f4faff;
}

.b-expert-jury-mobile-actions__stack {
  display: grid;
  gap: 10px;
}

.b-expert-jury-mobile-actions__button {
  width: 100%;
  text-align: center;
}

.b-expert-jury-mobile-actions__button--primary {
  min-height: 52px;
}

.b-expert-jury-toolbar__button--save-close {
  white-space: nowrap;
}

.b-expert-page__backlink--toolbar {
  margin: 0;
  white-space: nowrap;
}

.b-expert-filters__grid--admin .b-expert-filters__field {
  min-width: 0;
  display: block;
}

.b-expert-filters__microtitle {
  display: block;
  margin-bottom: 6px;
  color: #607085;
  font-size: 12px;
  line-height: 1.25;
}

.b-expert-filters__grid--admin .b-expert-filters__field--search {
  grid-column: span 1;
}

.b-expert-filters__grid--admin .b-expert-filters__field--period {
  grid-column: span 2;
}

.b-expert-filters__form--admin .b-expert-filters__label,
.b-expert-bulk__form--admin .b-expert-filters__label,
.b-expert-summary--admin .b-expert-summary__label,
.b-expert-form__hint,
.b-expert-side-note {
  font-size: 12px;
}

.b-expert-filters__form--admin .b-expert-filters__control,
.b-expert-bulk__form--admin .b-expert-filters__control,
.b-expert-summary--admin .b-expert-form__control,
.b-expert-detail--admin .b-expert-form__control,
.b-expert-detail--admin .b-expert-form__textarea {
  min-height: 40px;
  padding: 8px 10px;
  border-radius: 8px;
  font-size: 14px;
}

.b-expert-filters__form--admin input::placeholder {
  color: #6f7f93;
  opacity: 1;
}

.is-js .b-expert-filters__control--multiple {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  border: 0;
}

.b-expert-multiselect {
  position: relative;
  min-width: 0;
}

.b-expert-multiselect__control {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
  min-height: 44px;
  padding: 6px 36px 6px 8px;
  overflow: hidden;
  border: 1px solid #c8d5e2;
  border-radius: 10px;
  background: linear-gradient(180deg, rgba(255, 255, 255, .98), rgba(244, 248, 252, .98));
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, .65);
  cursor: text;
}

.b-expert-multiselect.is-open .b-expert-multiselect__control,
.b-expert-multiselect__control:focus-within {
  border-color: #3da2d6;
  box-shadow: 0 0 0 3px rgba(61, 162, 214, .14), inset 0 1px 0 rgba(255, 255, 255, .65);
}

.b-expert-multiselect__control::after {
  content: "▾";
  position: absolute;
  top: 14px;
  right: 12px;
  color: #6f7f93;
  font-size: 13px;
  line-height: 1;
  pointer-events: none;
  transition: transform .2s ease;
}

.b-expert-multiselect.is-open .b-expert-multiselect__control::after {
  transform: rotate(180deg);
}

.b-expert-multiselect__tag {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  max-width: calc(100% - 8px);
  padding: 5px 9px;
  border-radius: 999px;
  background: #15476c;
  color: #fff;
  font-size: 12px;
  line-height: 1.2;
}

.b-expert-multiselect__tag-label {
  max-width: min(100%, 180px);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.b-expert-multiselect__tag-remove {
  padding: 0;
  border: 0;
  background: transparent;
  color: #fff;
  font-size: 15px;
  line-height: 1;
  cursor: pointer;
}

.b-expert-multiselect__search {
  flex: 1 1 90px;
  min-width: 90px;
  max-width: 100%;
  height: 30px;
  padding: 0 0 0 2px;
  border: 0;
  background: transparent;
  color: #24415d;
  font: inherit;
  font-size: 13px;
}

.b-expert-multiselect__search:focus {
  outline: none;
}

.b-expert-multiselect__drop {
  position: absolute;
  z-index: 30;
  top: calc(100% + 6px);
  left: 0;
  right: 0;
  display: none;
  min-width: 0;
  padding: 6px;
  border: 1px solid #c8d5e2;
  border-radius: 10px;
  background: #fff;
  box-shadow: 0 12px 24px rgba(27, 36, 48, .14);
}

.b-expert-multiselect.is-open .b-expert-multiselect__drop {
  display: block;
}

.b-expert-multiselect__results {
  max-height: 210px;
  margin: 0;
  padding: 0;
  overflow-y: auto;
  list-style: none;
  scrollbar-width: thin;
  scrollbar-color: #9fb4c7 #eef3f7;
}

.b-expert-multiselect__results::-webkit-scrollbar {
  width: 10px;
}

.b-expert-multiselect__results::-webkit-scrollbar-track {
  background: #eef3f7;
  border-radius: 999px;
}

.b-expert-multiselect__results::-webkit-scrollbar-thumb {
  background: #9fb4c7;
  border-radius: 999px;
  border: 2px solid #eef3f7;
}

.b-expert-multiselect__option {
  display: block;
  width: 100%;
  padding: 8px 10px;
  border: 0;
  border-radius: 8px;
  background: transparent;
  color: #24415d;
  text-align: left;
  font: inherit;
  font-size: 13px;
  line-height: 1.35;
  cursor: pointer;
}

.b-expert-multiselect__option:hover,
.b-expert-multiselect__option:focus {
  background: #e5eef6;
  color: #15476c;
  outline: none;
}

.b-expert-multiselect__option.is-selected {
  background: linear-gradient(180deg, #1e5d8d, #15476c);
  color: #fff;
}

.b-expert-multiselect__empty {
  padding: 8px 10px;
  color: #6f7f93;
  font-size: 13px;
}

.b-expert-filterbox__submit {
  min-height: 27px;
  padding: 0 14px;
  border: 1px solid #15476c;
  border-radius: 8px;
  background: #15476c;
  color: #fff;
  font: inherit;
  font-size: 13px;
  font-weight: 700;
  cursor: pointer;
  transition: background-color .2s ease, border-color .2s ease;
}

.b-expert-filterbox__submit:hover {
  background: #1b5a89;
  border-color: #1b5a89;
}

.b-expert-filters__actions--admin {
  margin-top: 14px;
}

.b-expert-detail--admin .b-expert-form__textarea {
  min-height: 120px;
}

.b-expert-filters__actions--admin {
  gap: 10px;
}

.b-expert-bulk__row {
  display: grid;
  grid-template-columns: repeat(2, minmax(280px, 360px)) auto;
  gap: 6px 12px;
  align-items: start;
  justify-content: start;
}

.b-expert-bulk__item--actions-top {
  display: grid;
  gap: 4px;
  align-self: start;
  justify-items: start;
}

.b-expert-bulk__item--actions-top .b-expert-bulk__item {
  display: grid;
  gap: 0;
  padding: 0;
  border: 1px solid #e2e8f0;
  border-radius: 10px;
  background: #f9fbfd;
}

.b-expert-bulk__item--actions-top .b-expert-filters__control {
  min-width: 280px;
}

.b-expert-bulk__item--actions-top .b-expert-filterbox__submit {
  width: auto;
  justify-self: start;
}

.b-expert-bulk__apply {
  display: flex;
  align-items: flex-start;
  justify-content: flex-end;
  padding-top: 1px;
}

.b-table-scroll--expert-admin {
  overflow-x: auto;
  padding: 0;
  background: transparent;
  box-shadow: none;
}

.b-expert-admin-count {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 16px;
  align-items: center;
  justify-content: space-between;
  margin: 14px 0 10px;
  color: #4b5563;
  font-size: 14px;
}

.b-expert-admin-count--bottom {
  margin: 10px 0 14px;
}

.b-expert-admin-count__main strong {
  color: #111827;
  font-weight: 700;
}

.b-expert-admin-count__page {
  color: #6b7280;
}

.b-expert-table-shell {
  display: block;
  margin: 0 -20px 0;
  padding: 0 20px 0 40px;
}

.b-step-itogi--expert-admin {
  width: 100%;
  min-width: 1560px;
  border-collapse: separate;
}

.b-step-itogi--expert-jury {
  min-width: 1320px;
}

.b-expert-bulk__row--jury {
  grid-template-columns: minmax(280px, 360px) auto;
}

.b-step-itogi--expert-admin th,
.b-step-itogi--expert-admin td {
  padding: 10px 8px;
  font-size: 14px;
  line-height: 1.35;
}

.b-step-itogi--expert-admin th {
  padding-top: 16px;
  white-space: nowrap;
  color: #fff;
}

.b-step-itogi--expert-admin th .b-expert-sortlink {
  color: inherit;
}

.b-step-itogi--expert-admin th .b-expert-check {
  display: inline-flex;
  margin-top: 6px;
}


.b-expert-admin-table__col--check {
  width: 84px;
}

.b-expert-admin-table__col--tiny {
  width: 74px;
}

.b-expert-admin-table__col--title {
  min-width: 220px;
}

.b-expert-summary--admin,
.b-expert-detail--admin {
  gap: 14px;
}

.b-expert-admin-headmeta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  margin-top: 8px;
  flex-wrap: wrap;
}

.b-expert-admin-headmeta__slug {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.b-expert-admin-headmeta__contest {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.b-expert-admin-headmeta__published {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.b-expert-admin-headmeta__label {
  color: #607085;
  font-size: 12px;
  line-height: 1.2;
}

.b-expert-admin-headmeta__slug .b-expert-form__control {
  width: 240px;
  min-height: 32px;
  padding: 6px 10px;
  font-size: 13px;
}

.b-expert-admin-headmeta__contest .b-expert-form__control {
  width: 280px;
  min-height: 32px;
  padding: 6px 10px;
  font-size: 13px;
}

.b-expert-admin-headmeta__visit {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 32px;
  padding: 0 14px;
  border: 1px solid #9aa8b8;
  border-radius: 8px;
  font-size: 13px;
  font-weight: 700;
  line-height: 1;
  text-decoration: none;
  white-space: nowrap;
}

.b-expert-admin-headmeta__visit--draft {
  background: #e0e4e8;
  border-color: #c5ccd4;
  color: #6c7784;
}

.b-expert-admin-headmeta__visit--published {
  background: #3da2d6;
  border-color: #3da2d6;
  color: #fff;
}

.b-expert-admin-card {
  margin-bottom: 14px;
}

.b-expert-admin-card.b-panel--pad {
  padding-bottom: 10px;
}

.b-expert-admin-infogrid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 20px;
  align-items: start;
}

.b-expert-admin-infogrid--single {
  grid-template-columns: 1fr;
}

.b-expert-admin-infogrid__col {
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.b-expert-admin-inlinegroup {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}

.b-expert-admin-inlinegroup .b-expert-admin-inforow {
  grid-template-columns: 112px minmax(0, 1fr);
  padding: 1px 8px;
}

.b-expert-admin-inlinegroup .b-expert-admin-inforow__label {
  font-size: 10px;
}

.b-expert-admin-inlinegroup .b-expert-admin-inforow__value {
  font-size: 11px;
}

.b-expert-admin-inlinegroup .b-expert-admin-inforow .b-expert-form__control {
  min-height: 26px;
  padding: 3px 7px;
  font-size: 11px;
}

.b-expert-admin-asidegrid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
  margin-bottom: 16px;
  align-items: start;
}

.b-expert-tests-participantgrid {
  display: grid;
  grid-template-columns: 2fr 3fr;
  gap: 16px;
  margin: 16px 20px 24px;
  align-items: start;
}

.b-expert-tests-participantgrid .b-expert-admin-inforow {
  grid-template-columns: 170px minmax(0, 1fr);
}

.b-expert-tests-participantgrid .b-expert-admin-inforow__value {
  overflow-wrap: anywhere;
}

.b-expert-tests-participantgrid .b-expert-admin-inforow__value a {
  overflow-wrap: anywhere;
  word-break: break-word;
}

.b-expert-admin-inforow--tight {
  grid-template-columns: 170px minmax(0, 1fr);
}

.b-expert-admin-inforow--tight .b-expert-form__control {
  width: 100%;
}

.b-expert-tests-qa {
  margin-top: 14px;
}

.b-expert-tests-q {
  padding: 10px 12px;
  border: 1px solid #e2e8f0;
  border-radius: 12px;
  background: #f7f9fb;
  margin-top: 10px;
}

.b-expert-tests-q__title {
  font-size: 12px;
  line-height: 1.25;
  font-weight: 600;
  color: #1b2634;
  margin-bottom: 8px;
}

.b-expert-tests-q__answers {
  display: grid;
  gap: 6px;
}

.b-expert-tests-q__answer {
  font-size: 12px;
  line-height: 1.2;
  padding: 6px 8px;
  border-radius: 10px;
  border: 1px solid #e2e8f0;
  background: #fff;
}

.b-expert-tests-q__answer.is-selected {
  border-color: #3da2d6;
  background: #eef7fc;
}

.b-expert-tests-q__answer.is-correct {
  border-color: #2f8f4e;
  background: #eefaf2;
}

.b-expert-tests-q__answer.is-selected.is-correct {
  border-color: #1c7a3b;
  background: #e7f8ee;
}

.b-expert-tests-q__answer.is-selected:not(.is-correct) {
  border-color: #e31920;
  background: #fff1f2;
}

.b-expert-admin-inforow {
  display: grid;
  grid-template-columns: 144px minmax(0, 1fr);
  gap: 4px;
  min-width: 0;
  padding: 1px 10px;
  border: 1px solid #e2e8f0;
  border-radius: 12px;
  background: #f7f9fb;
  align-items: center;
}

.b-expert-admin-inforow--title {
  background: #f2f6fa;
}

.b-expert-admin-inforow--compact {
  min-height: 100%;
}

.b-expert-admin-inforow__label {
  color: #607085;
  font-size: 11px;
  line-height: 1.25;
  white-space: nowrap;
}

.b-expert-admin-inforow__value {
  min-width: 0;
  color: #1b2634;
  font-size: 12px;
  line-height: 1.2;
}

.b-expert-admin-inforow__hint {
  margin: 6px 0 0;
  color: #607085;
  font-size: 11px;
  line-height: 1.35;
}

.b-expert-admin-inforow__value--inline {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
}

.b-expert-admin-inforow .b-expert-form__control {
  width: 100%;
  min-height: 28px;
  padding: 4px 8px;
  font-size: 12px;
  border-radius: 8px;
}

.b-expert-admin-info__receipt {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  color: #15476c;
  font-size: 13px;
  font-weight: 500;
}

.b-expert-admin-info__receipt:hover {
  text-decoration: none;
}

.b-expert-admin-info__receipt-icon {
  position: relative;
  display: inline-block;
  width: 14px;
  height: 16px;
  border: 1px solid #6b7c8f;
  border-radius: 3px;
  background: #fff;
}

.b-expert-admin-info__receipt-icon::after {
  content: "";
  position: absolute;
  top: -1px;
  right: -1px;
  width: 6px;
  height: 6px;
  background: linear-gradient(135deg, #dfe6ee 50%, transparent 50%);
  border-top-right-radius: 2px;
}

.b-expert-admin-inforow--visit .b-expert-admin-headmeta__visit {
  display: inline-flex;
  align-self: flex-start;
}

.b-expert-admin-cardhead {
  display: grid;
  gap: 8px;
  min-width: 0;
  flex: 1 1 auto;
}

.b-expert-panel__head--admin-card {
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.b-expert-admin-date--card {
  flex: 0 0 auto;
}

.b-expert-admin-tablecard {
  overflow: hidden;
  border: 1px solid #e2e8f0;
  border-radius: 12px;
}

.b-expert-admin-tablecard--scroll {
  overflow-x: auto;
}

.b-expert-admin-tablecard__table {
  width: 100%;
  min-width: 1480px;
  border-collapse: collapse;
}

.b-expert-admin-tablecard__table th,
.b-expert-admin-tablecard__table td {
  padding: 6px 10px;
  border-bottom: 1px solid #e2e8f0;
  vertical-align: middle;
  text-align: left;
}

.b-expert-admin-tablecard__table th {
  color: #fff;
  font-size: 13px;
  font-weight: 600;
  background: #3da2d6;
  white-space: nowrap;
}

.b-expert-admin-tablecard__table td {
  background: #fff;
  min-width: 160px;
  font-size: 12px;
}

.b-expert-admin-tablecard__table .b-expert-form__control {
  width: 100%;
  min-width: 140px;
  min-height: 28px;
  padding: 4px 8px;
  font-size: 12px;
}

.b-expert-summary--admin {
  margin-bottom: 14px;
  grid-template-columns: minmax(0, .92fr) minmax(0, 1.08fr);
}

.b-expert-summary--admin .b-expert-summary__left,
.b-expert-summary--admin .b-expert-summary__right {
  gap: 10px;
}

.b-expert-summary--admin .b-expert-summary__value {
  font-size: 15px;
}

.b-expert-detail--admin {
  grid-template-columns: minmax(0, .95fr) minmax(420px, 1.15fr);
}

.b-expert-detail__main--admin,
.b-expert-detail__aside--admin {
  min-width: 0;
}

.b-expert-media--admin .b-expert-media__frame {
  min-height: 620px;
}

.b-expert-media__admin-tools--full {
  margin-top: 14px;
}

.b-expert-content-head {
  display: grid;
  gap: 10px;
  margin-bottom: 14px;
}

.b-expert-content-head__row {
  display: flex;
  align-items: center;
  gap: 10px;
}

.b-expert-content-head__text.is-hidden {
  display: none;
}

.b-expert-content-head__text {
  position: relative;
  padding-right: 42px;
}

.b-expert-content-head__toggle {
  position: absolute;
  top: 0;
  right: 0;
}

.b-expert-content-head__textbody {
  color: #1f3145;
  font-size: 14px;
  line-height: 1.55;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 5;
  overflow: hidden;
}

.b-expert-content-head__textbody.is-expanded {
  display: block;
  overflow: visible;
}

.b-expert-content-head__more {
  margin-top: 6px;
  padding: 0;
  border: 0;
  background: transparent;
  color: #15476c;
  font-size: 13px;
  font-weight: 700;
  cursor: pointer;
}

.b-expert-content-head__edit .b-expert-form__textarea {
  min-height: 120px;
}

.b-expert-review--admin,
.b-expert-criteria--admin,
.b-expert-actions--admin {
  height: fit-content;
}

.b-expert-review__topfields {
  display: grid;
  gap: 8px;
  margin-bottom: 14px;
}

.b-expert-review__toprow {
  display: grid;
  grid-template-columns: 132px minmax(0, 1fr);
  gap: 10px;
  align-items: center;
}

.b-expert-review__toplabel {
  color: #1f3145;
  font-size: 14px;
  font-weight: 600;
  line-height: 1.3;
}

.b-expert-review__topcontrol {
  min-width: 0;
}

.b-expert-review__topcontrol .b-expert-form__control {
  width: 100%;
}

.b-expert-review__ratinghint {
  margin-bottom: 14px;
}

.b-expert-review--comment {
  margin-top: 14px;
}

.b-expert-admin-metrics {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  margin-bottom: 14px;
}

.b-expert-admin-metrics__item {
  display: grid;
  gap: 4px;
  padding: 10px 12px;
  border: 1px solid #e2e8f0;
  border-radius: 12px;
  background: #f9fbfd;
}

.b-expert-admin-metrics__label {
  color: #607085;
  font-size: 12px;
  line-height: 1.3;
}

.b-expert-admin-metrics__value {
  color: #1f3145;
  font-size: 14px;
  line-height: 1.1;
  font-weight: 700;
}

.b-expert-admin-headmeta__published .b-expert-form__control {
  width: 160px;
  min-height: 32px;
  padding: 6px 10px;
  font-size: 13px;
}

.b-expert-criteria--admin .b-expert-criteria__item {
  padding: 12px;
  gap: 10px;
}

.b-expert-criteria--admin .b-expert-criteria__scores ul {
  display: flex;
  gap: 8px;
  margin: 0;
  padding: 0;
  list-style: none;
  flex-wrap: wrap;
}

.b-expert-criteria--admin .b-expert-criteria__scores li {
  margin: 0;
}

.b-expert-criteria--admin .b-expert-criteria__score span,
.b-expert-criteria--admin .b-expert-criteria__scores label span {
  width: 38px;
  height: 38px;
  border-radius: 10px;
}

.b-expert-actions--admin .b-expert-actions__stack {
  gap: 10px;
}

@media (max-width: 1380px) {
  .b-expert-filters__grid--admin {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .b-expert-filters__grid--admin .b-expert-filters__field--search,
  .b-expert-filters__grid--admin .b-expert-filters__field--period {
    grid-column: span 2;
  }

  .b-expert-filters__grid--jury {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .b-expert-filters__grid--jury .b-expert-filters__field--search,
  .b-expert-filters__grid--jury .b-expert-filters__field--period {
    grid-column: span 2;
  }

  .b-expert-summary--admin,
  .b-expert-detail--admin {
    grid-template-columns: 1fr;
  }

  .b-expert-admin-date {
    justify-items: start;
  }
}

@media (max-width: 1180px) {
  .b-expert-admin-card--jury-head {
    display: none;
  }

  .b-expert-jury-mobile-summary,
  .b-expert-jury-mobile-actions {
    display: block;
  }

  .is-js .b-expert-jury-fold__toggle {
    display: inline-flex;
  }

  .b-expert-jury-mobile-summary {
    margin-bottom: 14px;
  }

  .b-expert-jury-mobile-summary__grid {
    margin-top: 12px;
  }

  .b-expert-jury-detail {
    grid-template-columns: 1fr;
  }

  .b-expert-jury-participant-desktop {
    display: none;
  }

  .b-expert-jury-media .b-expert-content-head {
    margin-bottom: 12px;
  }

  .b-expert-jury-media .b-media-viewer__frame,
  .b-expert-jury-media .b-expert-media__frame {
    min-height: 440px;
  }

  .b-expert-jury-media .b-media-viewer__actions {
    display: grid;
    gap: 10px;
  }

  .b-expert-jury-media .b-media-viewer__actions .btn {
    width: 100%;
    text-align: center;
  }

  .b-expert-jury-criteria .b-expert-admin-inforow--compact {
    margin-bottom: 2px;
  }

  .b-expert-jury-criteria .b-expert-criteria__scores,
  .b-expert-jury-criteria .b-expert-criteria__scores ul {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 8px;
    width: 100%;
  }

  .b-expert-jury-criteria .b-expert-criteria__scores li {
    width: 100%;
  }

  .b-expert-jury-criteria .b-expert-criteria__score,
  .b-expert-jury-criteria .b-expert-criteria__scores label {
    display: block;
    width: 100%;
  }

  .b-expert-jury-criteria .b-expert-criteria__score span,
  .b-expert-jury-criteria .b-expert-criteria__scores label span {
    width: 100%;
    min-width: 0;
    height: 50px;
    font-size: 16px;
  }

  .b-expert-jury-criteria .b-expert-criteria__description {
    font-size: 14px;
  }

  .b-expert-jury-review {
    margin-top: 14px;
  }

  .b-expert-jury-table__scroll {
    overflow: visible;
  }

  .b-expert-jury-table__table,
  .b-expert-jury-table__table thead,
  .b-expert-jury-table__table tbody {
    display: block;
    width: 100%;
  }

  .b-expert-jury-table__table {
    min-width: 0;
  }

  .b-step-itogi--expert-jury thead {
    display: none;
  }

  .b-step-itogi--expert-jury .b-step-itogi__head-gap,
  .b-step-itogi--expert-jury .b-step-itogi__separator {
    display: none;
  }

  .b-expert-jury-table__row {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px 12px;
    margin-bottom: 12px;
    padding: 14px;
    border: 1px solid #dde6f0;
    border-radius: 16px;
    background: linear-gradient(180deg, #ffffff 0%, #f8fbfd 100%);
    box-shadow: 0 10px 24px rgba(15, 23, 42, .06);
  }

  .b-expert-jury-table__cell {
    display: grid;
    gap: 4px;
    min-width: 0;
    padding: 0;
    border: 0;
    background: transparent;
    text-align: left;
  }

  .b-expert-jury-table__cell::before {
    content: attr(data-label);
    color: #607085;
    font-size: 11px;
    font-weight: 600;
    line-height: 1.25;
  }

  .b-expert-jury-table__cell--status,
  .b-expert-jury-table__cell--work,
  .b-expert-jury-table__cell--participant,
  .b-expert-jury-table__cell--contest {
    grid-column: 1 / -1;
  }

  .b-expert-jury-table__cell--work {
    gap: 6px;
  }

  .b-expert-jury-table__link {
    gap: 6px;
  }

  .b-expert-jury-table__work-title {
    color: #15476c;
    font-size: 17px;
    line-height: 1.3;
  }

  .b-expert-jury-table__work-action {
    display: inline-flex;
  }

  .b-expert-jury-table__cell--points,
  .b-expert-jury-table__cell--max-points,
  .b-expert-jury-table__cell--percent {
    padding: 10px 12px;
    border-radius: 12px;
    background: #f1f7fb;
  }

  .b-step-itogi--expert-jury tbody > tr:not(.b-expert-jury-table__row):not(.b-step-itogi__separator):not(.b-step-itogi__head-gap) {
    display: block;
  }

  .b-step-itogi--expert-jury tbody > tr:not(.b-expert-jury-table__row):not(.b-step-itogi__separator):not(.b-step-itogi__head-gap) > td {
    display: block;
  }

  .b-expert-admin-toolbar--jury-detail .b-expert-admin-toolbar__main,
  .b-expert-admin-toolbar--jury-detail .b-expert-admin-toolbar__side,
  .b-expert-admin-toolbar--jury-detail .b-expert-filterbox__submit,
  .b-expert-admin-toolbar--jury-detail .b-expert-page__backlink--toolbar {
    width: 100%;
  }

  .b-expert-admin-toolbar--jury-detail .b-expert-filterbox__submit,
  .b-expert-admin-toolbar--jury-detail .b-expert-page__backlink--toolbar {
    text-align: center;
  }

  .b-expert-admin-toolbar--jury-detail {
    margin: 4px 0 10px;
  }

  .b-expert-admin-toolbar--jury-detail .b-expert-admin-toolbar__main {
    justify-content: flex-end;
  }

  .b-expert-admin-toolbar--jury-detail .b-expert-jury-toolbar__button--save,
  .b-expert-admin-toolbar--jury-detail .b-expert-jury-toolbar__backlink,
  .b-expert-jury-apply__button,
  .b-expert-jury-mobile-actions__button--save-scores {
    display: none;
  }

  .b-expert-admin-toolbar--jury-detail .b-expert-jury-toolbar__button--save-close {
    width: auto;
    min-height: 32px;
    padding: 0 12px;
    margin-left: auto;
    border-radius: 999px;
    font-size: 12px;
    line-height: 1;
  }
}

@media (max-width: 980px) {
  .b-expert-admin-page {
    padding-left: 14px;
    padding-right: 14px;
  }

  .b-expert-header .wrapper {
    padding-left: 14px;
    padding-right: 14px;
  }

  .b-expert-table-shell {
    margin-left: -14px;
    margin-right: -14px;
    padding-left: 34px;
    padding-right: 14px;
  }

  .b-expert-filters__grid--admin {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .b-expert-filters__grid--jury {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .b-expert-admin-panel--bulk {
    overflow-x: auto;
  }

  .b-expert-tests-participantgrid {
    grid-template-columns: 1fr;
    margin-left: 14px;
    margin-right: 14px;
  }

  .b-expert-bulkbox {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: nowrap;
    min-width: max-content;
    overflow-x: auto;
  }

  .b-expert-bulkbox__toolbar {
    flex: 0 0 auto;
    align-items: center;
    gap: 10px;
    flex-wrap: nowrap;
  }

  .b-expert-bulk__row {
    display: flex;
    align-items: center;
    gap: 10px;
    flex: 0 0 auto;
    grid-template-columns: none;
  }

  .b-expert-bulk__item--actions-top {
    flex: 0 0 auto;
  }

  .b-expert-bulk__item--actions-top .b-expert-filters__control {
    min-width: 140px;
  }

  .b-expert-bulkbox__danger {
    display: none;
  }

  .b-expert-bulk__row {
    justify-content: flex-start;
  }

  .b-expert-bulk__apply {
    flex: 0 0 auto;
    justify-content: flex-start;
    align-items: center;
    padding-top: 0;
  }

  .b-expert-filterbox__toolbar,
  .b-expert-filterbox__footer {
    align-items: stretch;
    flex-direction: column;
  }

  .b-expert-filterbox__toolbar {
    flex-wrap: wrap;
  }

  .b-expert-admin-metrics {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .b-expert-admin-headmeta {
    align-items: flex-start;
    gap: 10px;
  }

  .b-expert-content-head__row {
    align-items: flex-start;
  }

  .b-expert-review__toprow {
    grid-template-columns: 120px minmax(0, 1fr);
  }

  .b-expert-admin-toolbar {
    align-items: flex-start;
    flex-direction: column;
  }

  .b-expert-admin-toolbar__main,
  .b-expert-admin-toolbar__side {
    width: 100%;
  }

  .b-expert-admin-titlebar__row {
    align-items: flex-start;
    flex-wrap: wrap;
  }

  .b-expert-admin-titlebar__edit {
    min-width: 220px;
  }

  .b-expert-jury-media .b-media-viewer__frame,
  .b-expert-jury-media .b-expert-media__frame {
    min-height: 360px;
  }
}

@media (max-width: 640px) {
  .b-expert-admin-page {
    padding-left: 10px;
    padding-right: 10px;
  }

  .b-expert-header .wrapper {
    padding-left: 10px;
    padding-right: 10px;
  }

  .b-expert-table-shell {
    margin-left: -10px;
    margin-right: -10px;
    padding-left: 30px;
    padding-right: 10px;
  }

  .b-expert-bulkbox.is-sticky-fallback {
    left: 10px;
    right: 10px;
  }

  .b-expert-bulkbox {
    gap: 8px;
  }

  .b-expert-bulkbox__title {
    font-size: 14px;
  }

  .b-expert-bulk__row {
    gap: 8px;
  }

  .b-expert-bulk__item--actions-top .b-expert-filters__control {
    min-width: 110px;
  }

  .b-expert-filters__grid--admin {
    grid-template-columns: 1fr;
  }

  .b-expert-filters__grid--jury {
    grid-template-columns: 1fr;
  }

  .b-expert-filters__grid--admin .b-expert-filters__field--search {
    grid-column: auto;
  }

  .b-expert-filters__grid--admin .b-expert-filters__field--period {
    grid-column: auto;
  }

  .b-expert-filters__grid--jury .b-expert-filters__field--search,
  .b-expert-filters__grid--jury .b-expert-filters__field--period {
    grid-column: auto;
  }

  .b-expert-jury-start__button {
    min-width: 100%;
  }

  .b-expert-jury-nav {
    gap: 12px;
  }

  .b-expert-jury-nav__button {
    min-width: 220px;
  }

  .b-expert-jury-apply {
    justify-content: stretch;
  }

  .b-expert-jury-apply .b-expert-filterbox__submit {
    width: 100%;
  }

  .b-expert-admin-metrics {
    grid-template-columns: 1fr;
  }

  .b-expert-admin-headmeta {
    align-items: flex-start;
    flex-direction: column;
  }

  .b-expert-panel__head--admin-card {
    flex-direction: column;
  }

  .b-expert-review__toprow {
    grid-template-columns: 1fr;
    gap: 4px;
  }

  .b-expert-admin-cardhead {
    width: 100%;
  }

  .b-expert-admin-infogrid {
    grid-template-columns: 1fr;
  }

  .b-expert-admin-inforow {
    grid-template-columns: 1fr;
    gap: 4px;
  }

  .b-expert-admin-inlinegroup {
    grid-template-columns: 1fr;
  }

  .b-expert-admin-asidegrid {
    grid-template-columns: 1fr;
  }

  .b-expert-admin-headmeta__slug {
    width: 100%;
  }

  .b-expert-admin-headmeta__contest {
    width: 100%;
    align-items: flex-start;
    flex-direction: column;
  }

  .b-expert-admin-headmeta__published {
    width: 100%;
    align-items: flex-start;
    flex-direction: column;
  }

  .b-expert-admin-headmeta__slug .b-expert-form__control {
    width: 100%;
  }

  .b-expert-admin-headmeta__contest .b-expert-form__control {
    width: 100%;
  }

  .b-expert-admin-headmeta__published .b-expert-form__control {
    width: 100%;
  }

  .b-expert-admin-titlebar__edit {
    min-width: 0;
    width: 100%;
  }

  .b-expert-admin-toolbar__main--right {
    justify-content: stretch;
  }

  .b-expert-jury-nav {
    flex-direction: column;
    align-items: stretch;
  }

  .b-expert-jury-nav__side,
  .b-expert-jury-nav__side--right {
    justify-content: stretch;
  }

  .b-expert-jury-nav__button {
    width: 100%;
    min-width: 0;
  }

  .b-expert-jury-mobile-summary__grid,
  .b-expert-jury-table__row,
  .b-expert-jury-criteria .b-expert-criteria__scores,
  .b-expert-jury-criteria .b-expert-criteria__scores ul {
    grid-template-columns: 1fr;
  }

  .b-expert-jury-mobile-summary__head,
  .b-expert-jury-review__head {
    flex-direction: column;
    align-items: stretch;
  }

  .b-expert-jury-fold__toggle {
    width: 100%;
  }

  .b-expert-admin-toolbar--jury-detail .b-expert-jury-toolbar__button--save-close {
    width: auto;
    max-width: 100%;
    margin-left: auto;
  }

  .b-step-itogi--expert-admin {
    min-width: 1480px;
  }

  .b-expert-media--admin .b-expert-media__frame {
    min-height: 340px;
  }

  .b-expert-jury-media .b-media-viewer__frame,
  .b-expert-jury-media .b-expert-media__frame {
    min-height: 300px;
  }
}

.b-dashboard-page {
  padding-top: 53px;
  padding-bottom: 69px;
}

.b-dashboard-page__header {
  margin-bottom: 53px;
}

.b-dashboard-page__eyebrow {
  margin-bottom: 10px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: #6b7280;
}

.b-dashboard-page__hint {
  margin: 10px 0 0;
  max-width: 720px;
  color: #64748b;
  line-height: 1.6;
}

.b-dashboard-sections {
  display: grid;
  gap: 46px;
}

.b-dashboard-section {
  display: grid;
  gap: 20px;
}

.b-dashboard-section + .b-dashboard-section {
  padding-top: 18px;
}

.b-dashboard-section__title {
  margin: 0;
  color: #0f172a;
  font-size: 26px;
  font-weight: 800;
  line-height: 1.25;
}

.b-dashboard-empty {
  padding: 22px 24px;
  border: 1px solid rgba(226, 232, 240, .9);
  border-radius: 20px;
  background: #fff;
  color: #64748b;
  font-size: 15px;
  line-height: 1.5;
}

.b-dashboard-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  column-gap: 28px;
  row-gap: 28px;
  align-items: start;
}

.b-dashboard-card {
  display: flex;
  flex-direction: column;
  min-height: 100%;
  padding: 24px;
  position: relative;
  overflow: hidden;
  border: 1px solid rgba(226, 232, 240, .9);
  border-radius: 24px;
  background: #fff;
  isolation: isolate;
  box-shadow: 0 12px 28px rgba(15, 23, 42, .06);
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}

.b-dashboard-card:hover {
  box-shadow: 0 18px 32px rgba(15, 23, 42, .09);
  border-color: rgba(148, 163, 184, .45);
}

.b-dashboard-card--accent,
.b-dashboard-card--kpi,
.b-dashboard-card--fallback {
  background: #fff;
}

.b-dashboard-card__head {
  margin-bottom: 22px;
}

.b-dashboard-card__title {
  display: inline-flex;
  margin: 0 0 14px;
  color: #111827;
  font-size: 22px;
  font-weight: 700;
  line-height: 1.3;
  text-decoration: none;
}

.b-dashboard-card__title:hover {
  color: #0f766e;
}

.b-dashboard-card__total {
  margin-bottom: 6px;
  color: #0f172a;
  font-size: clamp(34px, 4vw, 42px);
  font-weight: 800;
  line-height: 1;
  letter-spacing: -.03em;
}

.b-dashboard-card__submeta {
  margin-bottom: 8px;
  color: #0f766e;
  font-size: 15px;
  font-weight: 700;
}

.b-dashboard-card__meta {
  color: #64748b;
  font-size: 14px;
  line-height: 1.55;
}

.b-dashboard-card__list {
  display: grid;
  gap: 12px;
}

.b-dashboard-card__item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 14px 16px;
  border-radius: 18px;
  background: #f8fafc;
  color: #0f172a;
  text-decoration: none;
  transition: background-color .2s ease, color .2s ease, transform .2s ease;
}

.b-dashboard-card__item:hover {
  background: #eef6ff;
  color: #0f172a;
}

.b-dashboard-card__item--fallback {
  background: #f8fafc;
}

.b-dashboard-card__item--fallback:hover {
  background: #f1f5f9;
}

.b-dashboard-card__label {
  min-width: 0;
  color: #334155;
  font-size: 15px;
  line-height: 1.45;
}

.b-dashboard-card__value {
  flex-shrink: 0;
  color: #0f172a;
  font-size: 18px;
  font-weight: 700;
  text-align: right;
}

.b-dashboard-card__footer {
  margin-top: auto;
  padding-top: 22px;
}

.b-dashboard-card__action {
  display: inline-flex;
  align-items: center;
  color: #0f766e;
  font-size: 14px;
  font-weight: 700;
  text-decoration: none;
}

.b-dashboard-card__action:hover {
  color: #115e59;
}

.b-card-media {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  min-height: 220px;
  overflow: hidden;
  background: #f5f7fb;
}

.b-card-media--work,
.b-card-media--publication {
  border-radius: 14px;
}

.b-card-media__image {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.b-card-media__fallback {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 10px;
  width: 100%;
  height: 100%;
  min-height: 220px;
  padding: 0;
  box-sizing: border-box;
  background: #f5f7fb;
}

.b-card-media__fallback--publication {
  min-height: 100%;
}

.b-card-media__icon {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.b-card-media__badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 56px;
  padding: 6px 12px;
  border-radius: 999px;
  background: #ffffff;
  color: #47637f;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .03em;
  text-transform: uppercase;
}

.b-media-viewer {
  display: grid;
  gap: 18px;
}

.b-media-viewer__visual,
.b-media-viewer__fallback,
.b-media-viewer__empty {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  width: 100%;
  min-height: 320px;
  padding: 0;
  border-radius: 14px;
  background: #f5f7fb;
  box-sizing: border-box;
  overflow: hidden;
}

.b-media-viewer__visual--interactive {
  position: relative;
  align-items: stretch;
  justify-content: stretch;
  min-height: clamp(720px, 88vh, 1200px);
}

.b-media-viewer__visual--image {
  padding: 24px;
}

.b-media-viewer__image,
.b-media-viewer__object,
.b-media-viewer__frame,
.b-media-viewer__video {
  display: block;
  width: 100%;
}

.b-media-viewer__image {
  width: auto;
  max-width: 100%;
  max-height: 760px;
  height: auto;
  object-fit: contain;
}

.b-media-viewer__frame {
  min-height: clamp(720px, 88vh, 1200px);
  height: clamp(720px, 88vh, 1200px);
  border: 0;
}

.b-media-viewer__frame--pdfjs {
  min-height: 640px;
  height: 960px;
  background: #eef3f8;
  overflow: hidden;
}

.b-media-viewer__object {
  min-height: clamp(720px, 88vh, 1200px);
  height: clamp(720px, 88vh, 1200px);
  border: 0;
}

.b-media-viewer__video {
  max-height: 760px;
}

.b-media-viewer__audio {
  width: 100%;
}

.b-media-viewer__zoom {
  position: absolute;
  top: 12px;
  right: 12px;
  z-index: 3;
  display: inline-flex;
  gap: 6px;
}

.b-media-viewer__zoom-btn {
  width: 32px;
  height: 32px;
  border: 1px solid rgba(36, 52, 71, 0.14);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.92);
  color: #243447;
  font-size: 20px;
  line-height: 1;
  cursor: pointer;
  box-shadow: 0 4px 12px rgba(36, 52, 71, 0.12);
}

.b-media-viewer__zoom-btn:hover {
  background: #ffffff;
}

.b-media-viewer__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: center;
}

.b-media-viewer__note {
  padding: 14px 16px;
  border-radius: 10px;
  background: #f7f8fb;
  color: #5f6d7b;
  font-size: 14px;
  line-height: 1.55;
}

.b-media-conversion {
  margin-top: 18px;
  padding: 16px 18px;
  border: 1px solid #d8e2f0;
  border-radius: 16px;
  background: #f7fafc;
}

.b-media-conversion--failed {
  border-color: #efc2c2;
  background: #fff7f7;
}

.b-media-conversion--processing,
.b-media-conversion--pending {
  border-color: #cfe0f3;
  background: #f5f9ff;
}

.b-media-conversion__head {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 14px;
  align-items: center;
}

.b-media-conversion__status {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 0 12px;
  border-radius: 999px;
  background: #e7eef6;
  color: #27415d;
  font-size: 13px;
  font-weight: 700;
}

.b-media-conversion__meta {
  color: #5b6b7f;
  font-size: 13px;
}

.b-media-conversion__message {
  margin-top: 10px;
  color: #2f3e4d;
  font-size: 15px;
  line-height: 1.55;
}

.b-media-conversion__error {
  margin-top: 10px;
  padding: 10px 12px;
  border-radius: 12px;
  background: rgba(176, 38, 38, 0.08);
  color: #7d1f1f;
  font-size: 14px;
  line-height: 1.5;
  word-break: break-word;
}

.b-media-conversion__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 14px;
}

.b-media-conversion__form {
  margin: 0;
}

.b-media-viewer__fallback .b-media-viewer__icon,
.b-media-viewer__empty .b-media-viewer__icon {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

@media (max-width: 1199px) {
  .b-dashboard-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    column-gap: 24px;
    row-gap: 49px;
  }
}

@media (max-width: 767px) {
  .b-dashboard-page {
    padding-top: 33px;
    padding-bottom: 45px;
  }

  .b-dashboard-grid {
    grid-template-columns: 1fr;
    row-gap: 33px;
  }

  .b-dashboard-card {
    padding: 22px 18px;
    border-radius: 20px;
  }

  .b-dashboard-card__title {
    font-size: 20px;
  }

  .b-dashboard-card__item {
    gap: 12px;
    padding: 13px 14px;
  }

  .b-dashboard-card__value {
    font-size: 17px;
  }

  .b-card-media,
  .b-card-media__fallback {
    min-height: 180px;
  }

  .b-card-media__icon {
    width: 100%;
    height: 100%;
  }

  .b-media-viewer__visual,
  .b-media-viewer__fallback,
  .b-media-viewer__empty {
    min-height: 240px;
  }

  .b-media-viewer__fallback .b-media-viewer__icon,
  .b-media-viewer__empty .b-media-viewer__icon {
    width: 100%;
    height: 100%;
  }

  .b-media-viewer__frame {
    min-height: min(78vh, 820px);
    height: min(78vh, 820px);
  }

  .b-media-viewer__frame--pdfjs {
    min-height: 420px;
    height: 640px;
  }

  .b-media-viewer__object {
    min-height: min(78vh, 820px);
    height: min(78vh, 820px);
  }
}

.b-pub-similar__wrap--detail{
  position: relative;
  z-index: 1;
  clear: both;
}

@media screen and (max-width:1280px) and (min-width:1025px) {
  .b-layout.b-layout--publications .b-layout__center > .wrapper.b-pub-similar__wrap--detail {
    position: relative;
    left: -240px;
    width: calc(100vw - max((100vw - 1180px) / 2, 0px) - 10px);
    max-width: calc(100vw - max((100vw - 1180px) / 2, 0px) - 10px);
    margin-left: 0;
    box-sizing: border-box;
  }
}

@media screen and (max-width:1024px) and (min-width:871px) {
  .b-layout.b-layout--publications .b-layout__center > .wrapper.b-pub-similar__wrap--detail {
    position: relative;
    left: 0;
    width: calc(100vw - max((100vw - 1180px) / 2, 0px) - 10px);
    max-width: calc(100vw - max((100vw - 1180px) / 2, 0px) - 10px);
    margin-left: 0;
    box-sizing: border-box;
  }
}


.b-contents-slider--pub-related{
  position: relative;
  overflow: hidden;
  padding-bottom: 36px;
}

.b-contents-slider--pub-related .swiper{
  position: relative;
  z-index: 1;
  overflow: hidden;
  margin: 0;
}

.b-contents-slider--pub-related .swiper-pagination{
  position: relative;
  z-index: 2;
  margin-top: 18px;
}

.b-contents-slider--work-related {
  position: relative;
  clear: both;
  overflow: hidden;
  padding-bottom: 28px;
}

.b-contents-slider--work-related .swiper {
  position: relative;
  z-index: 1;
  overflow: hidden;
}

.b-contents-slider--work-related .swiper-pagination {
  position: relative;
  z-index: 2;
  margin-top: 18px;
}

.b-pagination__prev {
  left: 5px;
}

.b-pagination__next {
  right: 5px;
}

.b-list-page {
  padding-bottom: 40px;
}

.b-list-page .b-contest-grid,
.b-list-page .b-pubs-list-wrap,
.b-list-page .b-pub-list {
  margin-bottom: 0;
}

.b-list-page .pagination {
  margin-top: 28px;
  margin-bottom: 0;
  padding-bottom: 0;
}

.b-contests-layout {
  display: grid;
  grid-template-columns: minmax(190px, 240px) minmax(0, 1fr);
  gap: 34px;
  align-items: start;
  margin-top: 24px;
}

.b-contests-layout__sidebar,
.b-contests-layout__content {
  min-width: 0;
}

.b-contests-layout__content .b-filter-form {
  background: #fff;
  border-radius: 10px;
  padding: 18px;
  box-shadow: 0 12px 28px rgba(15, 23, 42, .06);
  box-sizing: border-box;
  max-width: 100%;
  margin: 0 0 24px !important;
  overflow: visible;
}

.b-contests-layout__content .b-filter-form__row {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) auto;
  gap: 12px !important;
  align-items: stretch !important;
}

.b-contests-layout__content .b-filter-form__row > select,
.b-contests-layout__content .b-filter-form__row > input,
.b-contests-layout__content .b-filter-form__row > div {
  min-width: 0;
  max-width: 100%;
  box-sizing: border-box;
}

.b-contests-layout__content .b-filter-form__row select,
.b-contests-layout__content .b-filter-form__row .btn {
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
  white-space: normal;
}

.b-contests-layout__content .b-contest-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  margin-top: 24px;
}

.b-contest-sidebar {
  background: #fff;
  border: 1px solid rgba(15, 23, 42, .08);
  border-radius: 8px;
  padding: 18px;
  box-shadow: 0 10px 24px rgba(15, 23, 42, .05);
}

.b-contest-sidebar__title {
  margin: 0 0 14px;
  font-size: 18px;
  line-height: 1.25;
  font-weight: 700;
}

.b-contest-sidebar__list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.b-contest-sidebar__item + .b-contest-sidebar__item {
  margin-top: 4px;
}

.b-contest-sidebar__link {
  display: block;
  border-radius: 6px;
  padding: 8px 10px;
  color: inherit;
  line-height: 1.3;
  text-decoration: none;
  overflow-wrap: anywhere;
  transition: background-color .2s ease, color .2s ease;
}

.b-contest-sidebar__link:hover,
.b-contest-sidebar__link:focus-visible {
  background: rgba(15, 23, 42, .06);
  color: #2455a6;
}

.b-contest-sidebar__link--active {
  background: rgba(36, 85, 166, .1);
  color: #2455a6;
  font-weight: 700;
}

.b-contest-sidebar__divider {
  height: 1px;
  margin: 18px 0 14px;
  background: rgba(15, 23, 42, .12);
}

.b-contest-sidebar__info {
  margin: 0;
  color: rgba(15, 23, 42, .72);
  font-size: 13px;
  line-height: 1.55;
  overflow-wrap: anywhere;
}

.b-sidebar-slider {
  width: 100%;
  max-width: 100%;
  margin: 18px 0 0;
  overflow: hidden;
}

.b-contest-sidebar > .b-sidebar-slider:first-child {
  margin-top: 0;
}

.b-sidebar-slider__container,
.b-sidebar-slider__single {
  width: 100%;
  max-width: 100%;
  overflow: hidden;
  border-radius: 8px;
}

.b-sidebar-slider__slide {
  width: 100%;
}

.b-sidebar-slider__link {
  display: block;
  width: 100%;
}

.b-sidebar-slider__image {
  display: block;
  width: 100%;
  height: auto;
  max-width: 100%;
  border-radius: 8px;
  object-fit: cover;
}

.b-sidebar-slider__pagination {
  position: relative;
  margin-top: 10px;
  text-align: center;
}

.b-sidebar-slider__pagination.swiper-pagination-bullets.swiper-pagination-horizontal {
  bottom: auto;
}

@media (max-width: 1024px) {
  .b-contests-layout__content .b-filter-form__row {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .b-contests-layout__content .b-contest-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 860px) {
  .b-contests-layout {
    grid-template-columns: 1fr;
    gap: 18px;
  }

  .b-contests-layout__content {
    order: 1;
  }

  .b-contests-layout__sidebar {
    order: 2;
    width: 100%;
  }

  .b-contest-sidebar {
    padding: 16px;
  }

  .b-contest-sidebar > .b-sidebar-slider:first-child,
  .b-contest-sidebar > .b-sidebar-slider:first-child + .b-contest-sidebar__divider {
    display: none;
  }
}

@media (max-width: 720px) {
  .b-contests-layout__content .b-filter-form {
    padding: 14px;
  }

  .b-contests-layout__content .b-filter-form__row {
    grid-template-columns: 1fr !important;
  }

  .b-contests-layout__content .b-filter-form__row select,
  .b-contests-layout__content .b-filter-form__row input,
  .b-contests-layout__content .b-filter-form__row .btn {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0;
  }

  .b-contests-layout__content .b-contest-grid {
    grid-template-columns: 1fr;
  }
}

.b-filter-form,
.b-filter-form__row,
.b-filter-form__row > select,
.b-filter-form__row > input,
.b-filter-form__row > div,
.b-filter-form .btn,
.b-select {
  max-width: 100%;
  box-sizing: border-box;
}

.b-filter-form__row > select,
.b-filter-form .btn,
.b-select {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
}

.b-expert-multiselect__drop,
.b-expert-multiselect__results {
  max-width: min(100vw - 32px, 100%);
  box-sizing: border-box;
}

@media (max-width: 767px) {
  .b-filter-form__row > select,
  .b-filter-form__row > input,
  .b-filter-form__row > div,
  .b-filter-form .btn,
  .b-select {
    width: 100%;
  }
}

.b-expert-landing,
.b-expert-info,
.b-expert-apply,
.b-account-expert {
  border-radius: 26px;
}

.b-expert-landing__hero {
  position: relative;
  overflow: hidden;
  margin-bottom: 28px;
  padding: 34px 38px;
  border-radius: 24px;
  background:
    radial-gradient(circle at top right, rgba(61, 162, 214, 0.22), transparent 34%),
    linear-gradient(135deg, #f7fbfe 0%, #eef6fb 44%, #ffffff 100%);
}

.b-expert-landing__content,
.b-expert-info__body,
.b-expert-apply__head,
.b-account-expert__intro,
.b-account-expert__body {
  min-width: 0;
}

.b-expert-landing__title {
  margin-bottom: 18px;
}

.b-expert-landing__lead,
.b-expert-apply__lead,
.b-expert-info__body p,
.b-account-expert__text,
.b-account-expert__note,
.b-account-expert__comment {
  margin: 0;
  color: #425466;
  line-height: 1.65;
}

.b-expert-landing__lead--sub {
  margin-top: 14px;
  max-width: 860px;
  color: #5d7084;
  font-size: 15px;
}

.b-expert-apply__lead--warning {
  margin-top: 14px;
  color: #8a4b0f;
}

.b-expert-landing__meta {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  margin: 24px 0;
}

.b-expert-landing__meta-item,
.b-expert-landing__card,
.b-account-expert__status,
.b-account-expert__comment {
  border: 1px solid #d9e4ef;
  background: #fff;
  box-shadow: 0 14px 34px rgba(17, 24, 39, 0.06);
}

.b-expert-landing__meta-item {
  padding: 18px 20px;
  border-radius: 18px;
}

.b-expert-landing__meta-label {
  display: block;
  margin-bottom: 8px;
  color: #5d7084;
  font-size: 14px;
}

.b-expert-landing__meta-value {
  color: #18344d;
  font-size: 22px;
  line-height: 1.2;
}

.b-expert-landing__actions,
.b-expert-info__actions,
.b-expert-apply-form__actions,
.b-account-expert__actions,
.b-account-links {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: center;
}

.b-expert-landing__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 22px;
}

.b-expert-landing__card {
  padding: 24px 26px;
  border-radius: 22px;
}

.b-expert-landing__card .b-title,
.b-expert-info .b-title,
.b-account-expert__title {
  margin-bottom: 16px;
}

.b-expert-landing__list {
  margin: 0;
  padding-left: 24px;
  color: #243447;
  line-height: 1.7;
}

.b-expert-landing__list li + li,
.b-expert-info__body p + p {
  margin-top: 10px;
}

.b-expert-landing__list--plain {
  list-style: disc;
}

.b-expert-info__actions {
  margin-top: 24px;
}

.b-expert-apply__head {
  margin-bottom: 28px;
}

.b-expert-apply-form__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px 20px;
}

.b-expert-apply-form__field {
  display: grid;
  gap: 8px;
}

.b-expert-apply-form__field--full {
  grid-column: 1 / -1;
}

.b-expert-apply-form__label,
.b-account-expert__label,
.b-account-expert__comment-label {
  color: #19344b;
  font-weight: 700;
}

.b-expert-apply-form__control {
  width: 100%;
  min-height: 48px;
  padding: 12px 14px;
  border: 1px solid #c8d7e5;
  border-radius: 14px;
  background: #fdfefe;
  box-sizing: border-box;
}

.b-expert-apply-form__control--textarea {
  min-height: 148px;
  resize: vertical;
}

.b-expert-apply-form__hint {
  color: #66788b;
  font-size: 14px;
  line-height: 1.5;
}

.b-expert-apply-form__choices {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin-top: 4px;
}

.b-expert-apply-form__choice {
  display: grid;
  grid-template-columns: 24px minmax(0, 1fr);
  gap: 12px;
  align-items: flex-start;
  padding: 14px 16px;
  border: 1px solid #d9e4ef;
  border-radius: 16px;
  background: #f9fbfd;
  cursor: pointer;
  transition: border-color .2s ease, background-color .2s ease, box-shadow .2s ease;
}

.b-expert-apply-form__choice:hover {
  border-color: #3da2d6;
  background: #f4faff;
  box-shadow: 0 10px 22px rgba(17, 24, 39, 0.05);
}

.b-expert-apply-form__choice-input {
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding-top: 2px;
}

.b-expert-apply-form__choice-input input[type=checkbox] {
  width: 18px;
  height: 18px;
  margin: 0;
}

.b-expert-apply-form__choice-title {
  display: block;
  color: #19344b;
  font-weight: 700;
  line-height: 1.45;
}

.b-expert-apply-form__empty {
  padding: 14px 16px;
  border: 1px dashed #c8d7e5;
  border-radius: 16px;
  color: #66788b;
  background: #fdfefe;
}

.b-expert-apply-form__consent {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  margin-top: 22px;
  color: #243447;
  line-height: 1.5;
}

.b-expert-apply-form__checkbox {
  margin-top: 4px;
}

.b-expert-apply-form__actions {
  margin-top: 28px;
}

.b-account__tag--expert {
  background: #e8f7f0;
  color: #176345;
}

.b-account-expert {
  margin-top: 26px;
}

.b-account-expert__head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 18px;
  margin-bottom: 20px;
}

.b-account-expert__status {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  gap: 18px;
  align-items: center;
  padding: 24px 26px;
  border-radius: 24px;
}

.b-account-expert__status--approved {
  background: linear-gradient(135deg, #f4fcf7 0%, #ffffff 100%);
}

.b-account-expert__status--payment {
  background: linear-gradient(135deg, #fff8eb 0%, #ffffff 100%);
}

.b-account-expert__status--review {
  background: linear-gradient(135deg, #eef6ff 0%, #ffffff 100%);
}

.b-account-expert__status--rejected {
  background: linear-gradient(135deg, #fff5f5 0%, #ffffff 100%);
}

.b-account-expert__badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 150px;
  min-height: 44px;
  padding: 0 18px;
  border-radius: 999px;
  background: #18344d;
  color: #fff;
  font-size: 14px;
  font-weight: 700;
  text-align: center;
}

.b-account-expert__comment {
  margin-top: 14px;
  padding: 14px 16px;
  border-radius: 16px;
}

@media (max-width: 1024px) {
  .b-expert-landing__hero,
  .b-expert-landing__card,
  .b-account-expert__status {
    padding: 24px;
  }

  .b-expert-landing__grid,
  .b-expert-apply-form__grid,
  .b-expert-apply-form__choices {
    grid-template-columns: 1fr;
  }

  .b-expert-landing__meta {
    grid-template-columns: 1fr;
  }

  .b-account-expert__status {
    grid-template-columns: 1fr;
    align-items: flex-start;
  }
}

@media (max-width: 767px) {
  .b-expert-landing,
  .b-expert-info,
  .b-expert-apply,
  .b-account-expert {
    border-radius: 20px;
  }

  .b-expert-landing__hero,
  .b-expert-landing__card,
  .b-account-expert__status {
    padding: 18px;
    border-radius: 18px;
  }

  .b-expert-landing__actions,
  .b-expert-info__actions,
  .b-expert-apply-form__actions,
  .b-account-expert__actions,
  .b-account-expert__head,
  .b-account-links {
    align-items: stretch;
    flex-direction: column;
  }

  .b-expert-landing__actions .b-button,
  .b-expert-landing__actions .btn,
  .b-expert-info__actions .b-button,
  .b-expert-apply-form__actions .b-button,
  .b-expert-apply-form__actions .btn,
  .b-account-expert__actions .b-button,
  .b-account-expert__head .b-button,
  .b-account-links .b-button {
    width: 100%;
  }

  .b-account-expert__badge {
    min-width: 0;
    width: 100%;
  }
}
.b-period-admin-card {
  margin: 24px 0;
  padding: 24px;
  border: 1px solid #d7dde6;
  border-radius: 20px;
  background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
  box-shadow: 0 10px 24px rgba(21, 44, 71, 0.06);
}

.b-period-admin-card__head {
  margin-bottom: 24px;
}

/* === Пользовательские таблицы: аудит и унификация === */
.b-table-scroll--results,
.b-table-scroll--dashboard {
  width: 100%;
  max-width: 100%;
  overflow-x: auto;
  overflow-y: hidden;
  -webkit-overflow-scrolling: touch;
  scrollbar-gutter: stable both-edges;
}

.b-table-scroll--dashboard {
  padding-bottom: 4px;
}

.b-step-itogi--results {
  width: 100%;
  min-width: 980px;
}

.b-step-itogi--results td.last {
  width: 112px;
  padding: 15px 16px;
  font-size: 16px !important;
  font-weight: 700;
  line-height: 1.45 !important;
}

.b-step-itogi--results .b-step-itogi__mobile-last-value {
  font-size: 16px !important;
  line-height: 1.45 !important;
  font-weight: 700;
}

.b-step-itogi--results .b-step-itogi__cell--work-link {
  padding: 12px 8px;
  text-align: center;
}

.b-results-work-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  max-width: 100%;
  color: #3da2d6;
  font-size: 14px;
  font-weight: 700;
  line-height: 1.25;
  text-decoration: none;
}

.b-results-work-link:hover,
.b-results-work-link:focus {
  color: #1f7fb0;
  text-decoration: underline;
}

.b-results-work-link__icon {
  flex: 0 0 auto;
  font-size: 17px;
  line-height: 1;
}

.b-results-work-link__text {
  overflow-wrap: anywhere;
}

.b-results-work-link--disabled {
  color: #9aa5ad;
  cursor: default;
}

.b-step-itogi--dashboard {
  width: 100%;
  font-size: 14px;
  line-height: 1.45;
}

.b-step-itogi--dashboard th {
  padding: 2px 12px 10px;
  font-size: 13px;
  line-height: 1.35;
}

.b-step-itogi--dashboard td {
  padding: 12px 0 12px 12px;
  font-size: 14px;
}

.b-step-itogi--dashboard td.name,
.b-step-itogi--dashboard td.subname {
  width: auto;
}

.b-step-itogi--dashboard .b-step-itogi__link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  max-width: 100%;
}

.b-step-itogi--dashboard .b-step-itogi__link span {
  overflow-wrap: anywhere;
}

.b-step-itogi--dashboard .b-btn,
.b-step-itogi--dashboard .btn {
  white-space: nowrap;
}

.b-step-itogi--dashboard .b-work-document + .b-work-document {
  margin-top: 8px;
}

.b-step-itogi__cell--icon {
  width: 60px;
  min-width: 60px;
  text-align: center;
}

.b-step-itogi__cell--nowrap {
  white-space: nowrap;
}

.b-step-itogi__cell--text-wrap {
  overflow-wrap: anywhere;
  word-break: break-word;
}

.b-step-itogi__cell--ellipsis {
  max-width: 240px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.b-step-itogi__cell--documents {
  min-width: 210px;
}

.b-step-itogi__cell--actions {
  width: 88px;
  min-width: 88px;
  white-space: nowrap;
  text-align: center;
}

.b-step-itogi--dashboard-competitions {
  min-width: 1120px;
}

.b-table-scroll--dashboard-competitions {
  overflow-x: visible;
}

.b-lk-table--competition-applications {
  width: 100%;
  min-width: 0;
  table-layout: fixed;
}

.b-lk-table--competition-applications th,
.b-lk-table--competition-applications td {
  box-sizing: border-box;
}

.b-lk-table--competition-applications .b-lk-table__col--icon {
  width: 4.5%;
}

.b-lk-table--competition-applications .b-lk-table__col--participant {
  width: 12%;
}

.b-lk-table--competition-applications .b-lk-table__col--curator {
  width: 10%;
}

.b-lk-table--competition-applications .b-lk-table__col--work {
  width: 13%;
}

.b-lk-table--competition-applications .b-lk-table__col--contest {
  width: 12%;
}

.b-lk-table--competition-applications .b-lk-table__col--status {
  width: 8%;
}

.b-lk-table--competition-applications .b-lk-table__col--payment {
  width: 12%;
}

.b-lk-table--competition-applications .b-lk-table__col--date {
  width: 8%;
}

.b-lk-table--competition-applications .b-lk-table__col--documents {
  width: 14%;
}

.b-lk-table--competition-applications .b-lk-table__col--actions {
  width: 6.5%;
}

.b-lk-table--competition-applications .name,
.b-lk-table--competition-applications .subname,
.b-lk-table--competition-applications .work-title,
.b-lk-table--competition-applications .b-lk-table__cell--participant,
.b-lk-table--competition-applications .b-lk-table__cell--curator,
.b-lk-table--competition-applications .b-lk-table__cell--work,
.b-lk-table--competition-applications .b-lk-table__cell--contest,
.b-lk-table--competition-applications .b-lk-table__cell--status,
.b-lk-table--competition-applications .b-lk-table__cell--payment,
.b-lk-table--competition-applications .b-lk-table__cell--documents {
  overflow-wrap: anywhere;
  word-break: break-word;
}

.b-lk-table--competition-applications .b-lk-table__cell--participant,
.b-lk-table--competition-applications .b-lk-table__cell--status {
  white-space: normal;
}

.b-lk-table--competition-applications .b-lk-table__cell--status {
  line-height: 1.35;
}

.b-lk-table--competition-applications .b-lk-table__cell--payment,
.b-lk-table--competition-applications .b-lk-table__cell--documents {
  font-size: 13px;
}

.b-lk-table--competition-applications th span {
  display: block;
  white-space: normal;
  overflow-wrap: break-word;
}

.b-lk-table--competition-applications .b-lk-table__cell--date,
.b-lk-table--competition-applications .b-lk-table__cell--actions {
  white-space: nowrap;
}

.b-lk-table--competition-applications .b-step-itogi__cell--documents {
  min-width: 0;
  white-space: normal;
  overflow-wrap: normal;
  word-break: normal;
}

.b-lk-table--competition-applications .b-step-itogi__cell--actions {
  min-width: 84px;
  width: auto;
}

.b-lk-table--competition-applications .b-step-itogi__link {
  gap: 6px;
  align-items: flex-start;
  white-space: normal;
}

.b-lk-table--competition-applications .b-step-itogi__cell--documents .b-step-itogi__link span {
  overflow-wrap: break-word;
  word-break: normal;
}

.b-lk-table--competition-applications .b-lk-table__result {
  margin-bottom: 8px;
  padding-left: 40px;
  color: #000;
  font-size: 16px;
  line-height: 1.35;
  font-weight: 700;
}

.b-lk-table--competition-applications .b-btn,
.b-lk-table--competition-applications .btn {
  padding-left: 10px;
  padding-right: 10px;
}

@media (max-width: 1199px) {
  .b-table-scroll--dashboard-competitions {
    overflow-x: auto;
  }

  .b-lk-table--competition-applications {
    min-width: 1080px;
  }
}

.b-step-itogi--dashboard-tests {
  min-width: 940px;
}

.b-step-itogi--dashboard-publications {
  min-width: 1040px;
}

.b-step-itogi--dashboard-tests th:last-child,
.b-step-itogi--dashboard-tests td:last-child,
.b-step-itogi--dashboard-publications th:last-child,
.b-step-itogi--dashboard-publications td:last-child {
  padding-right: 14px;
}

.b-step-itogi--dashboard-rewards {
  min-width: 860px;
}

.b-step-itogi--dashboard-participants {
  min-width: 980px;
}

.b-step-itogi--dashboard-participants td.last,
.b-step-itogi--dashboard-participants .b-step-itogi__mobile-last-value {
  font-size: 16px !important;
  line-height: 1.45 !important;
  font-weight: 700;
}

.b-account__actions {
  flex-wrap: wrap;
}

.b-account__actions .b-button,
.b-account__actions .btn,
.b-account__support-button {
  max-width: 100%;
}

.b-account__support-button {
  white-space: normal;
  text-align: center;
}

/* === Publications cards: list, detail slider, home slider === */
.b-pub-list__grid {
  row-gap: 18px !important;
  column-gap: 18px;
}

.b-pub-card--list {
  display: block;
  height: auto;
  padding: 16px;
}

.b-pub-card__wrap--list {
  display: flex;
  gap: 16px;
  align-items: flex-start;
}

.b-pub-card__cover--list {
  width: 180px !important;
  max-width: 180px !important;
  height: auto !important;
  aspect-ratio: 16 / 9 !important;
  flex: 0 0 180px !important;
}

.b-pub-card__content--list {
  display: block;
  min-width: 0;
  position: relative;
  padding-right: 90px;
}

.b-pub-card--list .b-pub-card__date--top {
  position: absolute;
  top: 0;
  right: 0;
  white-space: nowrap;
}

.b-pub-card__title--list {
  display: block;
  margin: 0 0 10px;
  overflow: hidden;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}

.b-pub-card__text--list {
  display: -webkit-box;
  margin: 0 0 8px;
  overflow: hidden;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}

.b-pub-card__footer--list {
  margin-top: 12px;
}

.b-pub-similar-card {
  display: flex;
  flex-direction: column;
  height: 100%;
}

.b-pub-similar-card__img {
  aspect-ratio: 16 / 9;
}

.b-pub-similar-card__title {
  display: -webkit-box;
  min-height: calc(1.25em * 4);
  overflow: hidden;
  -webkit-line-clamp: 4;
  -webkit-box-orient: vertical;
}

.b-home-publications-slider .swiper-slide {
  height: auto;
  display: flex;
}

.b-home-publications-slider .swiper-slide > .b-pub-card--home {
  width: 100%;
}

.b-pub-card--home {
  display: flex;
  flex-direction: column;
  height: 100%;
}

.b-pub-card__wrap--home {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
  align-items: start;
  flex: 1 1 auto;
}

.b-pub-card__cover--home {
  width: 100%;
  height: auto;
  aspect-ratio: 16 / 9;
}

.b-pub-card__title--home {
  display: -webkit-box;
  margin-top: 0;
  margin-bottom: 0;
  overflow: hidden;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}

.b-pub-card__date--top {
  position: static;
  white-space: nowrap;
}

.b-pub-card__author-row--home {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 0;
  padding-right: 0;
  min-height: 0;
}

.b-pub-card__text--home {
  display: -webkit-box;
  min-height: calc(1.45em * 3);
  margin-top: 0;
  overflow: hidden;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
}

.b-pub-card__footer--home {
  margin-top: auto;
}

@media (max-width: 1199px) {
  .b-pub-card__wrap--list {
    display: grid;
    grid-template-columns: 180px minmax(0, 1fr);
    grid-template-areas:
      "cover author"
      "cover date"
      "cover title"
      "cover text"
      "cover tags";
    gap: 10px 16px;
  }

  .b-pub-card__cover--list {
    grid-area: cover;
  }

  .b-pub-card__content--list {
    display: contents;
  }

  .b-pub-card__author-row--list {
    grid-area: author;
    margin: 0;
  }

  .b-pub-card--list .b-pub-card__date--top {
    position: static;
    grid-area: date;
  }

  .b-pub-card__title--list {
    grid-area: title;
  }

  .b-pub-card__text--list {
    grid-area: text;
  }

  .b-pub-card--list .b-pub-card__tags {
    grid-area: tags;
  }
}

@media (max-width: 870px) {
  .b-pub-card__cover--home {
    aspect-ratio: 16 / 9;
  }
}

@media (max-width: 767px) {
  .b-pub-card--list {
    padding: 16px;
  }

  .b-pub-card__wrap--list {
    grid-template-columns: 1fr;
    grid-template-areas:
      "cover"
      "author"
      "date"
      "title"
      "text"
      "tags";
    gap: 14px;
  }

  .b-pub-card__cover--list {
    width: 100% !important;
    max-width: none !important;
    height: auto !important;
    flex: 0 0 auto !important;
    aspect-ratio: 16 / 9 !important;
  }

  .b-pub-card__author-row--list,
  .b-pub-card--list .b-pub-card__date--top,
  .b-pub-card__title--list,
  .b-pub-card__text--list,
  .b-pub-card--list .b-pub-card__tags {
    grid-column: 1;
  }

  .b-pub-card__title--list {
    margin: 0 0 8px;
  }

  .b-pub-card__text--list {
    margin: 0;
  }

  .b-pub-card__footer--list {
    margin-top: 12px;
  }

}

@media (max-width: 1024px) {
  .b-account__actions {
    align-items: stretch;
  }

  .b-account__actions .b-button,
  .b-account__actions .btn,
  .b-account__support-button {
    width: 100%;
  }
}

@media screen and (max-width:850px) {
  .b-table-scroll--results,
  .b-table-scroll--dashboard {
    overflow: visible;
    scrollbar-gutter: auto;
  }

  .b-step-itogi--results,
  .b-step-itogi--dashboard,
  .b-step-itogi--dashboard-competitions,
  .b-step-itogi--dashboard-tests,
  .b-step-itogi--dashboard-publications,
  .b-step-itogi--dashboard-rewards,
  .b-step-itogi--dashboard-participants {
    min-width: 0;
  }

  .b-table-scroll--dashboard-competitions {
    overflow-x: auto;
  }

  .b-lk-table--competition-applications {
    min-width: 0;
    table-layout: auto;
  }

  .b-step-itogi--dashboard td,
  .b-step-itogi--dashboard .b-step-itogi__cell--nowrap,
  .b-step-itogi--dashboard .b-step-itogi__cell--actions {
    white-space: normal;
  }

  .b-step-itogi__cell--documents,
  .b-step-itogi__cell--actions,
  .b-step-itogi__cell--icon {
    width: 100%;
    min-width: 0;
  }

  .b-account__support-button {
    width: 100%;
  }
}

/* Mobile fixes: results search, publication filters, homepage publications */
@media (max-width: 767px) {
  .b-filter {
    display: grid;
    gap: 12px;
  }

  .b-filter input[type="text"],
  .b-filter input[type="search"],
  .b-filter .btn,
  .b-filter a.btn {
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
  }

  .b-filter-form__row {
    align-items: stretch;
  }

  .b-filter-form__row > select,
  .b-filter-form__row > input,
  .b-filter-form__row > div,
  #pub-filter-category,
  #pub-filter-type,
  #pub-filter-class {
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
  }

  #pub-filter-q {
    width: 100% !important;
    max-width: 100%;
    box-sizing: border-box;
  }

  .b-filter-form__row > div[style*="flex: 1 1 200px"] {
    flex: 1 1 100%;
    width: 100%;
  }

  .b-filter-form__row > div[style*="display:flex; gap:0.75em;"] {
    display: flex;
    flex-direction: column;
    gap: 12px;
    width: 100%;
  }

  #pub-filter-apply,
  #pub-filter-clear {
    width: 100%;
  }

  .b-home-section--publications .b-home-publications-slider .swiper-slide {
    width: min(100%, 416px) !important;
  }

  .b-home-section--publications .b-pub-card__wrap--home {
    grid-template-columns: 1fr !important;
    gap: 12px;
  }

  .b-home-section--publications .b-pub-card__cover--home {
    width: 100% !important;
    max-width: none !important;
    height: auto !important;
    aspect-ratio: 16 / 9 !important;
  }

  .b-home-section--publications .b-pub-card__content--home {
    display: block;
    min-width: 0;
  }

  .b-home-section--publications .b-pub-card__footer--home {
    flex-direction: column;
    align-items: flex-start;
  }

  .b-home-section--publications .b-pub-card__footer-stats--home {
    width: 100%;
    justify-content: flex-start;
  }
}

/* Compact homepage publication slider cards without affecting regular publication cards. */
.b-home-publications-slider .swiper-slide {
  width: clamp(326px, 24.5vw, 408px) !important;
}

.b-home-publications-slider .b-pub-card--slider {
  padding: 12px;
}

.b-home-publications-slider .b-pub-card--slider .b-pub-card__wrap--home {
  gap: 10px;
}

.b-home-publications-slider .b-pub-card--slider .b-pub-card__title--home {
  font-size: 15px;
  line-height: 1.24;
}

.b-home-publications-slider .b-pub-card--slider .b-pub-card__cover--home {
  aspect-ratio: 16 / 8.7;
}

.b-home-publications-slider .b-pub-card--slider .b-pub-card__date--top {
  font-size: 11px;
}

.b-home-publications-slider .b-pub-card--slider .b-pub-card__author-row--home {
  gap: 8px;
}

.b-home-publications-slider .b-pub-card--slider .b-pub-card__avatar {
  flex-basis: 30px;
  width: 30px;
  height: 30px;
}

.b-home-publications-slider .b-pub-card--slider .b-pub-card__author {
  font-size: 12px;
}

.b-home-publications-slider .b-pub-card--slider .b-pub-card__text--home {
  min-height: calc(1.4em * 2);
  font-size: 11.5px;
  line-height: 1.4;
  -webkit-line-clamp: 2;
}

.b-home-publications-slider .b-pub-card--slider .b-pub-card__footer--home {
  gap: 10px;
  padding-top: 10px;
}

.b-home-publications-slider .b-pub-card--slider .b-pub-card__footer-stats--home {
  gap: 10px;
}

@media (max-width: 870px) {
  .b-home-publications-slider .swiper-slide {
    width: clamp(244px, 70vw, 360px) !important;
  }

  .b-contest-tag-intro {
    grid-template-columns: 1fr;
  }

  .b-contest-tag-intro__media {
    justify-self: start;
    width: min(100%, 200px);
  }
}

@media (max-width: 767px) {
  .b-home-section--publications .b-home-publications-slider .swiper-slide {
    width: min(100%, 360px) !important;
  }

  .b-home-publications-slider .b-pub-card--slider {
    padding: 12px;
  }

  .b-home-publications-slider .b-pub-card--slider .b-pub-card__cover--home {
    aspect-ratio: 16 / 9;
  }

  .b-home-publications-slider .b-pub-card--slider .b-pub-card__text--home {
    min-height: 0;
  }
}

.b-period-admin-card__title {
  margin: 0 0 8px;
  font-size: 28px;
  line-height: 1.2;
  color: #17324d;
}

.b-period-admin-card__text {
  margin: 0;
  max-width: 920px;
  font-size: 15px;
  line-height: 1.6;
  color: #47627f;
}

.b-period-admin-card__links {
  display: flex;
  gap: 12px;
  margin-top: 16px;
  flex-wrap: wrap;
}

.b-period-admin-card__link,
.b-period-admin-tools__button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 40px;
  padding: 0 16px;
  border-radius: 999px;
  background: #1f6aa5;
  color: #fff !important;
  text-decoration: none;
  font-weight: 600;
}

.b-period-admin-grid {
  display: grid;
  gap: 20px;
}

.b-period-admin-direction {
  padding: 20px;
  border: 1px solid #d8e1ea;
  border-radius: 18px;
  background: #fff;
}

.b-period-admin-direction__head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 16px;
  margin-bottom: 12px;
}

.b-period-admin-direction__title {
  margin: 0;
  font-size: 22px;
  line-height: 1.25;
  color: #14324e;
}

.b-period-admin-direction__meta {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
  margin-top: 8px;
  font-size: 14px;
  color: #597694;
}

.b-period-admin-direction__nominations {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 14px;
}

.b-period-admin-direction__tag {
  padding: 6px 10px;
  border-radius: 999px;
  background: #edf5fb;
  color: #1f507a;
  font-size: 13px;
  line-height: 1.3;
}

.b-period-admin-direction__selector .selector {
  width: 100%;
}

.b-period-admin-direction__selector .selector-available,
.b-period-admin-direction__selector .selector-chosen {
  width: calc(50% - 20px);
}

.b-period-admin-direction__selector .selector select {
  min-height: 260px;
}

.b-period-admin-direction__hint {
  margin: 12px 0 0;
  font-size: 13px;
  line-height: 1.5;
  color: #5c748f;
}

.b-period-admin-empty {
  padding: 20px;
  border-radius: 16px;
  background: #fff4de;
  color: #7a5510;
  font-size: 15px;
  line-height: 1.5;
}

@media (max-width: 1024px) {
  .b-period-admin-card {
    padding: 18px;
  }

  .b-period-admin-card__title {
    font-size: 24px;
  }

  .b-period-admin-direction__selector .selector-available,
  .b-period-admin-direction__selector .selector-chosen {
    width: 100%;
    float: none;
  }
}
.b-expert-checkline {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-size: 14px;
  line-height: 1.4;
}

.b-expert-checkline input[type="checkbox"] {
  margin: 0;
}

.b-bonus-campaign {
  max-width: 960px;
  margin: 40px auto 80px;
}

.b-bonus-campaign__hero {
  padding: 36px 40px;
  border-radius: 28px;
  background: linear-gradient(135deg, #eaf5ff 0%, #fff4e8 100%);
  box-shadow: 0 22px 60px rgba(20, 50, 78, 0.08);
}

.b-bonus-campaign__eyebrow {
  margin: 0 0 10px;
  font-size: 13px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #1f6aa5;
}

.b-bonus-campaign__title {
  margin: 0;
  color: #14324e;
}

.b-bonus-campaign__intro {
  margin-top: 18px;
  color: #32516e;
  line-height: 1.7;
}

.b-bonus-campaign__card {
  margin-top: 24px;
  padding: 32px 36px;
  border-radius: 28px;
  background: #fff;
  box-shadow: 0 18px 48px rgba(20, 50, 78, 0.08);
}

.b-bonus-campaign-form__row {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: 18px;
}

.b-bonus-campaign-form__label {
  font-size: 14px;
  font-weight: 700;
  color: #14324e;
}

.b-bonus-campaign-form__input,
.b-bonus-campaign-form__textarea,
.b-bonus-campaign-form input[type="file"] {
  width: 100%;
  min-height: 48px;
  padding: 12px 14px;
  border: 1px solid #d5dfeb;
  border-radius: 16px;
  background: #fff;
  color: #14324e;
}

.b-bonus-campaign-form__textarea {
  min-height: 120px;
  resize: vertical;
}

.b-bonus-campaign-form__submit {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: 0 22px;
  border: 0;
  border-radius: 999px;
  background: #1f6aa5;
  color: #fff;
  font-weight: 700;
  cursor: pointer;
}

.b-bonus-campaign-form__errors,
.b-bonus-campaign-form__error {
  color: #a03535;
}

.b-bonus-campaign__legal,
.b-bonus-campaign-form__hint {
  color: #5b738e;
  font-size: 13px;
  line-height: 1.6;
}

.b-bonus-codes {
  display: grid;
  gap: 10px;
  margin-top: 10px;
}

.b-bonus-codes__item {
  padding: 10px 12px;
  border-radius: 14px;
  background: #f3f8fc;
}

@media (max-width: 767px) {
  .b-bonus-campaign {
    margin: 24px auto 48px;
  }

  .b-bonus-campaign__hero,
  .b-bonus-campaign__card {
    padding: 24px 20px;
    border-radius: 22px;
  }
}
.b-payment-items {
  display: grid;
  gap: 14px;
  margin: 18px 0;
}

.b-payment-item {
  border: 1px solid #e2e8ef;
  border-radius: 8px;
  padding: 14px 16px;
}

.b-payment-item p {
  margin-bottom: 8px;
}

.b-payment-item p:last-child {
  margin-bottom: 0;
}

.b-payment-state {
  align-items: center;
  display: inline-flex;
  flex-wrap: wrap;
  gap: 5px;
  line-height: 1.2;
  max-width: 100%;
  min-width: 0;
}

.b-payment-state__dot {
  align-items: center;
  border-radius: 50%;
  display: inline-flex;
  font-size: 12px;
  font-weight: 700;
  height: 22px;
  justify-content: center;
  width: 22px;
}

.b-payment-state--paid .b-payment-state__dot {
  background: #e4f6eb;
  color: #177a3b;
}

.b-payment-state--unpaid .b-payment-state__dot {
  background: #eef1f4;
  color: #6f7b86;
}

.b-payment-state--pending .b-payment-state__dot {
  background: #fff3cd;
  color: #946200;
}

.b-payment-state__text {
  flex: 1 1 auto;
  font-size: 13px;
  min-width: 0;
}

.b-payment-state__method {
  background: #f2f5f8;
  border-radius: 4px;
  color: #52606d;
  display: block;
  flex: 1 0 100%;
  font-size: 12px;
  max-width: 100%;
  padding: 2px 6px;
  text-align: center;
  white-space: nowrap;
}

.b-notifications {
  box-sizing: border-box;
  max-width: 100%;
  overflow-x: hidden;
}

.b-notifications__head {
  align-items: flex-start;
  display: flex;
  gap: 14px;
  justify-content: space-between;
  max-width: 100%;
}

.b-notifications__list {
  display: grid;
  gap: 14px;
  max-width: 100%;
  min-width: 0;
}

.b-notification {
  border: 1px solid #e3e8ee;
  border-radius: 8px;
  box-sizing: border-box;
  max-width: 100%;
  min-width: 0;
  overflow: hidden;
  padding: 16px;
}

.b-notification--unread {
  border-color: #9bd3e8;
  background: #f5fbfd;
}

.b-notification__meta {
  align-items: center;
  color: #71808d;
  display: flex;
  flex-wrap: wrap;
  font-size: 13px;
  gap: 8px;
  margin-bottom: 8px;
}

.b-notification__badge {
  background: #edf1f5;
  border-radius: 4px;
  color: #52606d;
  padding: 2px 6px;
}

.b-notification__badge--unread {
  background: #e2f4fb;
  color: #176f91;
}

.b-notification__title {
  font-weight: 700;
  margin-bottom: 8px;
  max-width: 100%;
  overflow-wrap: anywhere;
}

.b-notification__body {
  max-width: 100%;
  min-width: 0;
  overflow-wrap: anywhere;
  word-break: normal;
}

.b-notification__body a {
  max-width: 100%;
  overflow-wrap: anywhere;
  word-break: break-word;
}

.b-notification__body img,
.b-notification__body iframe {
  max-width: 100%;
}

.b-notification__body table {
  display: block;
  max-width: 100%;
  overflow-x: auto;
}

.b-notification__body pre,
.b-notification__body code {
  max-width: 100%;
  overflow-x: auto;
  white-space: pre-wrap;
  word-break: break-word;
}

.b-notification__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 12px;
}

.b-notifications__empty {
  color: #71808d;
}

@media screen and (max-width: 640px) {
  .b-notifications__head {
    display: block;
  }

  .b-notifications__actions {
    margin-top: 12px;
  }

  .b-notification {
    padding: 12px;
  }
}

/* Обязательная защита legacy-аккаунта */
.legacy-security {
  padding: 28px 0 56px;
}

.legacy-security__card {
  box-sizing: border-box;
  max-width: 760px;
  padding: 30px;
  border: 1px solid #d8dde5;
  border-radius: 8px;
  background: #fff;
  overflow-wrap: anywhere;
}

.legacy-security__title {
  margin-top: 0;
}

.legacy-security__message {
  margin: 18px 0;
  padding: 14px 16px;
  border-left: 4px solid #3478bd;
  background: #eef6ff;
}

.legacy-security__message--success {
  border-color: #2f8a52;
  background: #eef9f2;
}

.legacy-security__message--warning {
  border-color: #b56b19;
  background: #fff7e8;
}

.legacy-security__form,
.legacy-security__actions {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 14px;
}

.legacy-security__field {
  width: 100%;
}

.legacy-security__field input {
  box-sizing: border-box;
  width: 100%;
  max-width: 480px;
}

.legacy-security__email {
  word-break: break-all;
}

@media (max-width: 640px) {
  .legacy-security {
    padding: 16px 0 32px;
  }

  .legacy-security__card {
    width: 100%;
    padding: 20px 16px;
  }

  .legacy-security__form .btn,
  .legacy-security__actions .btn {
    box-sizing: border-box;
    max-width: 100%;
    white-space: normal;
  }
}

/* Email confirmation */
.b-email-confirmation,
.b-email-confirmation-banner,
.b-email-confirmation *,
.b-email-confirmation-banner * { box-sizing: border-box; }
.b-email-confirmation {
  max-width: 780px;
  margin: 0 auto 32px;
}
.b-email-confirmation p {
  max-width: 680px;
  color: #374151;
  line-height: 1.65;
}
.b-email-confirmation__actions,
.b-email-confirmation-banner__actions { display: flex; flex-wrap: wrap; align-items: center; gap: 12px; margin-top: 18px; }
.b-email-confirmation__actions form,
.b-email-confirmation-banner__actions form { margin: 0; }
.b-email-confirmation .b-button,
.b-email-confirmation-banner .b-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 11px 20px;
  border: 1px solid transparent;
  border-radius: 999px;
  font-weight: 700;
  line-height: 1.25;
  text-decoration: none;
  cursor: pointer;
  transition: background .2s ease, border-color .2s ease, color .2s ease, box-shadow .2s ease;
}
.b-email-confirmation .b-button--primary,
.b-email-confirmation-banner .b-button--primary {
  background: #3da2d6;
  border-color: #3da2d6;
  color: #fff;
  box-shadow: 0 8px 18px rgba(61, 162, 214, .22);
}
.b-email-confirmation .b-button--primary:hover,
.b-email-confirmation .b-button--primary:focus,
.b-email-confirmation-banner .b-button--primary:hover,
.b-email-confirmation-banner .b-button--primary:focus {
  background: #2589bd;
  border-color: #2589bd;
  color: #fff;
}
.b-email-confirmation .b-button--ghost,
.b-email-confirmation-banner .b-button--ghost {
  background: #fff;
  border-color: #d7e1e8;
  color: #226f98;
}
.b-email-confirmation .b-button--ghost:hover,
.b-email-confirmation .b-button--ghost:focus,
.b-email-confirmation-banner .b-button--ghost:hover,
.b-email-confirmation-banner .b-button--ghost:focus {
  background: #eef8fd;
  border-color: #a9d8ef;
  color: #145f86;
}
.b-email-confirmation-banner { display: flex; justify-content: space-between; gap: 24px; margin: 0 0 24px; padding: 22px 24px; border: 1px solid #e0aa3e; border-radius: 12px; background: #fff8e8; box-shadow: 0 8px 22px rgba(97, 72, 15, .08); }
.b-email-confirmation-banner__body { max-width: 760px; }
.b-email-confirmation-banner__title { margin: 0 0 8px; font-size: 22px; line-height: 1.25; color: #3c2b05; }
.b-email-confirmation-banner__text { margin: 0; color: #61480f; line-height: 1.6; }
.b-email-confirmation-note,
.b-reward-lock { padding: 12px 16px; border-radius: 6px; background: #fff8e8; color: #61480f; }
.b-email-confirmation__form { max-width: 680px; }
@media (max-width: 720px) {
  .b-email-confirmation-banner { flex-direction: column; padding: 16px; }
  .b-email-confirmation__actions,
  .b-email-confirmation-banner__actions { align-items: stretch; flex-direction: column; }
  .b-email-confirmation__actions .b-button,
  .b-email-confirmation-banner__actions .b-button { width: 100%; box-sizing: border-box; text-align: center; }
}
.b-smartcaptcha {
  box-sizing: border-box;
  max-width: 100%;
  margin: 0 0 12px;
}

.b-smartcaptcha__widget {
  max-width: 100%;
}

.b-smartcaptcha__status {
  min-height: 1.4em;
  margin-top: 8px;
  color: #4a5568;
  overflow-wrap: anywhere;
}

.b-smartcaptcha__status--error {
  color: #b42318;
}

.b-smartcaptcha--challenge-visible {
  position: relative;
  z-index: 20;
}

[data-smartcaptcha-form] button.is-loading {
  cursor: wait;
  opacity: .72;
}

@media (max-width: 640px) {
  .b-smartcaptcha,
  .b-smartcaptcha__widget,
  .b-smartcaptcha iframe {
    width: 100%;
    max-width: 100%;
  }
}

/* Cookie banner */
.b-cookie-banner {
  position: fixed;
  right: 24px;
  bottom: 24px;
  z-index: 1000;
  box-sizing: border-box;
  display: flex;
  align-items: center;
  max-width: 720px;
  gap: 18px;
  padding: 18px 20px;
  border: 1px solid #d7e6ef;
  border-radius: 12px;
  background: #ffffff;
  box-shadow: 0 12px 32px rgba(20, 57, 81, .18);
}

.b-cookie-banner[hidden] {
  display: none;
}

.b-cookie-banner__text {
  color: #243747;
  font-size: 15px;
  line-height: 1.45;
}

.b-cookie-banner__link {
  color: #176c9f;
  text-decoration: underline;
}

.b-cookie-banner__button {
  flex: 0 0 auto;
  padding: 10px 18px;
  border: 0;
  border-radius: 8px;
  background: #3da2d6;
  color: #ffffff;
  cursor: pointer;
  font-weight: 700;
}

@media (max-width: 720px) {
  .b-cookie-banner {
    right: 12px;
    bottom: 12px;
    left: 12px;
    flex-direction: column;
    align-items: stretch;
  }

  .b-cookie-banner__button {
    width: 100%;
  }
}
