.common-heading {
    max-width: 60em
}

.card_swiper {
    margin: 0 auto;
    max-width: 1380px;
    padding: 0 40px;
}

@media screen and (max-width: 860px) {
    .card_swiper {
        padding: 0 24px;
    }
}


.common-heading--centered {
    margin-left: auto;
    margin-right: auto;
    text-align: center
}

.common-heading__title {
    margin: auto auto .5em
}

.common-heading__title:last-child {
    margin-bottom: auto
}

.common-heading__description strong {
    font-weight: 600
}

.common-heading__description li,
.common-heading__description ol,
.common-heading__description p,
.common-heading__description ul {
    line-height: 1.33
}

.common-heading__description ol:not(:last-child),
.common-heading__description p:not(:last-child),
.common-heading__description ul:not(:last-child) {
    margin-bottom: .75em
}

.common-heading__description li:not(:last-child) {
    margin-bottom: .375em
}

.common-heading__description p {
    padding: 0
}

.common-heading__description p:first-child {
    margin-top: 0 !important
}

.common-heading__description p:last-child {
    margin-bottom: 0 !important
}

.common-heading__description a {
    color: var(--theme-link)
}

.common-heading__description a:hover {
    color: var(--theme-link-hover);
    -webkit-text-decoration: underline;
    text-decoration: underline;
    text-decoration-color: var(--theme-link-hover)
}

.common-heading__description a:active {
    color: var(--theme-link-active);
    -webkit-text-decoration: underline;
    text-decoration: underline;
    text-decoration-color: var(--theme-link-active)
}

.common-heading__description ol,
.common-heading__description ul {
    list-style: disc none outside;
    padding: 0 0 0 1em
}

.common-heading__description ol li,
.common-heading__description ul li {
    line-height: inherit;
    padding-left: .5em
}

.common-heading__description ul {
    list-style: disc none outside
}

.common-heading__description ol {
    list-style: decimal none outside
}

.common-heading--gradients .common-heading__title em {
    -webkit-background-clip: text;
    background-clip: text;
    background-image: var(--theme-em-gradient);
    color: transparent;
    display: inline;
    font-style: normal !important;
    font-weight: inherit !important
}

.common-heading__description {
    margin: 0 auto
}

.common-heading__description a {
    -webkit-text-decoration: underline;
    text-decoration: underline
}

.common-heading__description a:hover {
    color: var(--theme-link)
}

.common-heading--compact .common-heading__title {
    margin: auto auto .25em
}

.common-heading--compact .common-heading__title:last-child {
    margin-bottom: auto
}

.common-heading--slide .common-heading__title {
    font-size: max(32px, min(3.125vw, 60px));
    font-weight: 400;
    line-height: 1;
    margin-bottom: .5em;
    margin-top: 0
}

.common-heading--slide .common-heading__title em {
    -webkit-background-clip: text;
    background-clip: text;
    background-image: var(--theme-em-gradient);
    color: transparent;
    display: inline;
    font-style: normal !important;
    font-weight: inherit !important
}

.common-heading--slide .common-heading__title p {
    line-height: inherit;
    margin: 0;
    padding: 0
}

.common-heading--slide .common-heading__description {
    display: inline;
    font-size: inherit;
    position: relative;
    width: calc(100% + 2em);
    z-index: 1
}

.common-heading--description-lg .common-heading__description>div {
    font-size: 1.5em
}

.common-heading--bold .common-heading__description,
.common-heading--bold .common-heading__title,
.common-heading--description-bold .common-heading__description,
.common-heading--title-bold .common-heading__title {
    font-weight: 600
}

.common-arrow-button {
    cursor: pointer;
    height: 3.5em;
    width: 3.5em
}

.common-arrow-button__button {
    background-color: var(--theme-page-bg);
    border-radius: 50%;
    box-shadow: 0 6px 7.5px -2px rgba(0, 0, 0, .075), 0 12.5px 19px 0 rgba(0, 0, 0, .023), 0 4.5px 25px 0 rgba(0, 0, 0, .023);
    color: var(--theme-page-fg);
    display: block;
    height: 100%;
    position: relative;
    transform: scale(1) translateY(0);
    transition: box-shadow .15s cubic-bezier(.165, .84, .44, 1) 0ms, transform .15s cubic-bezier(.165, .84, .44, 1) 0ms;
    width: 100%
}

.common-arrow-button:hover .common-arrow-button__button {
    box-shadow: 0 9px 11.5px -3px rgba(0, 0, 0, .15), 0 18.5px 28.5px 0 rgba(0, 0, 0, .051), 0 7px 37.5px 0 rgba(0, 0, 0, .039);
    transform: scale(1.033)
}

.common-arrow-button:active .common-arrow-button__button {
    box-shadow: 0 6px 7.5px -2px rgba(0, 0, 0, .038), 0 12.5px 19px 0 rgba(0, 0, 0, .011), 0 4.5px 25px 0 rgba(0, 0, 0, .011);
    transform: scale(.98)
}

.common-arrow-button__icon {
    left: 50%;
    position: absolute;
    top: 50%;
    transform: translate(-50%, -50%)
}

.common-pager {
    display: grid;
    grid-template-areas: "prev pages next";
    grid-template-columns: 0 100% 0;
    grid-template-rows: auto;
    position: relative
}

.common-pager__next,
.common-pager__prev {
    align-items: center;
    display: flex;
    position: relative
}

.common-pager__prev {
    grid-area: prev
}

.common-pager__next {
    grid-area: next
}

.common-pager__button {
    align-self: center;
    position: relative;
    transition: opacity .5s cubic-bezier(.165, .84, .44, 1) 0ms, visibility .5s cubic-bezier(.165, .84, .44, 1) 0ms;
    z-index: 100
}

.common-pager__button--float {
    left: 50%;
    position: absolute;
    top: 50%;
    transform: translate(-50%, -50%)
}

.common-pager__button:disabled {
    opacity: 0;
    pointer-events: none;
    visibility: hidden
}

.common-pager__button--prev {
    grid-area: prev
}

.common-pager__button--prev.common-pager__button--float {
    left: 0;
    position: absolute;
    top: .5;
    transform: translateY(-.5)
}

.common-pager__button--next {
    grid-area: next
}

.common-pager__pages {
    align-items: stretch;
    display: grid;
    grid-area: pages;
    grid-template-columns: auto;
    grid-template-rows: auto;
    position: relative
}

.common-pager__page {
    grid-area: 1/1;
    height: 100%;
    width: 100%;
    position: relative;
}

.common-pager__page--active {
    opacity: 1;
    transition: transform 1.5s cubic-bezier(.075, .82, .165, 1) 0ms, opacity 1.5s cubic-bezier(.075, .82, .165, 1) 0ms;
    z-index: 10
}

.common-pager__page--before {
    transform: translateX(-100px);
}

.common-pager__page--after,
.common-pager__page--before {
    opacity: 0;
    transition: transform 1s cubic-bezier(.075, .82, .165, 1) 0ms, opacity 1s cubic-bezier(.075, .82, .165, 1) 0ms;
    z-index: -1;
}

.common-pager__page--after {
    transform: translateX(100px)
}

.common-pager__page-inner {
    height: 100%
}

.px-card-grid {
    max-width: 100%;
    width: 100%
}

.px-card-grid__grid {
    grid-gap: var(--gap);
    display: grid;
    justify-content: center;
    margin: 0 auto
}

.px-card-grid__row {
    display: contents
}

.px-card-grid__space {
    grid-gap: var(--gap);
    align-items: stretch;
    display: flex;
    flex-direction: column;
    gap: var(--gap);
    justify-content: stretch;
    position: relative
}

.px-card-grid__space--layout-stacked {
    aspect-ratio: var(--aspect);
    display: grid;
    grid-column: span 1/auto;
    grid-template-areas: "top" "bottom";
    grid-template-columns: 100%;
    grid-template-rows: minmax(0, 1fr) minmax(0, 1fr)
}

.px-card-grid__space--layout-default {
    aspect-ratio: var(--aspect);
    display: grid;
    grid-column: span 1;
    grid-template-areas: "card";
    grid-template-columns: 100%;
    grid-template-rows: minmax(0, 1fr)
}

.px-card-grid__space--layout-wide {
    display: grid;
    grid-column: span 2;
    grid-template-areas: "card";
    grid-template-columns: 100%;
    grid-template-rows: minmax(0, 1fr)
}

.px-card-grid__card {
    align-items: stretch;
    display: grid;
    flex: 1;
    grid-template-columns: 100%;
    grid-template-rows: auto;
    justify-content: stretch;
    position: relative
}

.px-card-grid__card>* {
    width: 100%
}

.px-card-grid__grid--cols-2 .px-card-grid__space--layout-wide {
    aspect-ratio: var(--aspect-wide)
}

.px-card-grid--debug .px-card-grid__card:after {
    background-color: rgba(255, 0, 0, .05);
    border: 2px dashed rgba(255, 0, 0, .2);
    border-radius: 5px;
    bottom: 0;
    content: "";
    display: block;
    left: 0;
    pointer-events: none;
    position: absolute;
    right: 0;
    top: 0
}

.px-auto-clamp {
    padding: 0;
    position: relative
}

.px-auto-clamp,
.px-auto-clamp__clamp {
    text-align: justify;
    display: block;
    display: -webkit-box;
    overflow: hidden
}

.px-auto-clamp__clamp {
    -webkit-box-orient: vertical;
    height: auto;
    left: 0;
    max-height: 100%;
    position: absolute;
    top: 0;
    width: 100%
}