.charter-page {
    color: #11263e;
    font-family: "Roboto", sans-serif;
}

.charter-page section {
    position: relative;
}

.charter-page .charter-hero,
.charter-page .charter-intro,
.charter-page .charter-vessels,
.charter-page .charter-helm,
.charter-page .charter-process,
.charter-page .charter-destinations,
.charter-page .charter-summary,
.charter-page .charter-pricing,
.charter-page .charter-form-section,
.charter-page .charter-faq,
.charter-page .charter-max {
    width: min(1236px, calc(100% - 48px));
    margin: 0 auto;
}

.charter-page .charter-hero {
    margin-top: 24px;
}

.charter-page .charter-hero__frame {
    position: relative;
    min-height: 573px;
    border-radius: 28px;
    overflow: hidden;
    background: #091a2c;
}

.charter-page .charter-hero__frame picture,
.charter-page .charter-hero__frame img {
    display: block;
    width: 100%;
    height: 100%;
}

.charter-page .charter-hero__frame picture {
    position: absolute;
    inset: 0;
}

.charter-page .charter-hero__frame img {
    position: absolute;
    inset: 0;
    width: 100% !important;
    max-width: none !important;
    object-fit: cover;
}

.charter-page .charter-hero__overlay {
    position: absolute;
    inset: 0;
    background:
        linear-gradient(90deg, rgba(10, 25, 44, 0.54) 0%, rgba(10, 25, 44, 0.26) 24%, rgba(10, 25, 44, 0.1) 56%, rgba(10, 25, 44, 0.03) 100%);
}

.charter-page .charter-hero__content {
    position: relative;
    z-index: 1;
    max-width: 560px;
    padding: 124px 96px 72px;
    color: #fff;
}

@media (min-width: 992px) {
    .charter-page .charter-hero__content {
        position: absolute;
        left: 0;
        bottom: 0;
        width: min(560px, 100%);
        padding: 0 60px 84px;
    }
}

.charter-page .charter-hero h1 {
    margin: 0 0 18px;
    color: #fff;
    font-size: 58px;
    line-height: 1.08;
    font-weight: 600;
    text-transform: none;
}

.charter-page .charter-hero__subtitle {
    margin: 0 0 26px;
    max-width: 470px;
    color: #fff;
    font-size: 20px;
    line-height: 1.4;
    font-weight: 500;
}

.charter-page .charter-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 14px;
    padding: 0 32px;
    min-height: 48px;
    border-radius: 999px;
    background: #ee3b2f;
    color: #fff;
    font-size: 18px;
    font-weight: 500;
    text-decoration: none;
    transition: transform .2s ease, box-shadow .2s ease, background .2s ease;
}

.charter-page .charter-button:hover,
.charter-page .charter-button:focus {
    color: #fff;
    text-decoration: none;
    background: #d93025;
    box-shadow: 0 14px 28px rgba(238, 59, 47, 0.24);
    transform: translateY(-1px);
}

.charter-page .charter-button__arrow {
    width: 20px;
    height: 2px;
    background: currentColor;
    position: relative;
    display: inline-block;
}

.charter-page .charter-button__arrow::after {
    content: '';
    position: absolute;
    right: -1px;
    top: 50%;
    width: 7px;
    height: 7px;
    border-top: 2px solid currentColor;
    border-right: 2px solid currentColor;
    transform: translateY(-50%) rotate(45deg);
}

.charter-page .charter-running-line {
    margin: 18px auto 0;
    width: min(1368px, calc(100% - 16px));
    overflow: hidden;
    overflow-x: clip;
    contain: layout paint;
    white-space: nowrap;
    padding: 12px 0;
    background: #ee3b2f;
    color: #fff;
    font-size: 18px;
    font-weight: 500;
}

.charter-page .charter-running-line__track {
    display: flex;
    width: max-content;
    min-width: max-content;
    animation: charter-running-line 42s linear infinite;
    will-change: transform;
}

.charter-page .charter-running-line__group {
    display: flex;
    flex: 0 0 auto;
    gap: 28px;
    padding-right: 28px;
}

.charter-page .charter-running-line__track span {
    flex: 0 0 auto;
    padding-right: 0;
}

.charter-page .charter-running-line__track span::after {
    content: '\2693';
    margin-left: 18px;
    font-size: 18px;
    line-height: 1;
    vertical-align: middle;
}

@keyframes charter-running-line {
    from {
        transform: translate3d(0, 0, 0);
    }

    to {
        transform: translate3d(-50%, 0, 0);
    }
}

@media (prefers-reduced-motion: reduce) {
    .charter-page .charter-running-line__track {
        animation: none;
        transform: none;
    }
}

.charter-page .charter-intro > .charter-section-title,
.charter-page .charter-vessels > .charter-section-title,
.charter-page .charter-helm .charter-section-title,
.charter-page .charter-process .charter-section-title,
.charter-page .charter-destinations .charter-section-title,
.charter-page .charter-summary .charter-section-title,
.charter-page .charter-pricing .charter-section-title,
.charter-page .charter-faq h2 {
    text-align: center;
}

.charter-page .charter-section-title {
    margin: 0 0 38px;
    color: #11263e;
    font-size: 44px;
    line-height: 1.08;
    font-weight: 700;
    text-transform: none !important;
    letter-spacing: 0 !important;
}

.charter-page .charter-intro {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: 36px;
    padding-top: 62px;
}

.charter-page .charter-intro__copy {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: 36px;
    color: #23384c;
    font-size: 22px;
    line-height: 1.15;
}

.charter-page .charter-intro__copy p {
    margin: 0;
}

.charter-page .charter-text-accent {
    color: #ee3b2f;
    font-weight: 700;
}

.charter-page .charter-intro__visuals {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 24px;
}

.charter-page .charter-intro__visuals picture,
.charter-page .charter-intro__visuals img {
    display: block;
    width: 100%;
}

.charter-page .charter-intro__visuals img {
    height: 330px;
    object-fit: cover;
    border-radius: 20px;
}

.charter-page .charter-vessels {
    padding-top: 92px;
}

.charter-page .charter-vessels__grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 18px 14px;
    align-items: start;
}

.charter-page .charter-vessel-card {
    display: block;
    text-decoration: none;
    color: #11263e;
    background: transparent;
}

.charter-page .charter-vessel-card__media {
    position: relative;
    height: auto;
    aspect-ratio: 596 / 754;
    overflow: hidden;
    border-radius: 13px;
    line-height: 0;
}

.charter-page .charter-vessel-card picture,
.charter-page .charter-vessel-card img {
    display: block;
    width: 100%;
}

.charter-page .charter-vessel-card picture {
    height: 100%;
}

.charter-page .charter-vessel-card img {
    position: static;
    height: 100%;
    object-fit: cover;
    border-radius: inherit;
}

.charter-page .charter-vessel-card::after {
    display: none;
}

.charter-page .charter-vessel-card__content {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
}

.charter-page .charter-vessel-card h3 {
    position: relative;
    display: flex;
    align-items: center;
    margin: 0;
    min-height: 32px;
    padding: 7px 44px 7px 14px;
    border-radius: 12px 12px 0 0;
    background:
        linear-gradient(110deg, rgb(212 244 252 / 68%) 0%, rgba(190, 232, 246, 0.8) 48%, rgb(120 199 222 / 48%) 100%);
    color: #11263e;
    font-size: 14px;
    line-height: 1.15;
    font-weight: 600;
    text-transform: none;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.35);
}

.charter-page .charter-vessel-card h3::before {
    content: '';
    position: absolute;
    right: 20px;
    top: 50%;
    width: 20px;
    height: 2px;
    background: currentColor;
    transform: translateY(-50%);
}

.charter-page .charter-vessel-card h3::after {
    content: '';
    position: absolute;
    right: 18px;
    top: 50%;
    width: 8px;
    height: 8px;
    border-top: 2px solid currentColor;
    border-right: 2px solid currentColor;
    transform: translateY(-50%) rotate(45deg);
}

.charter-page .charter-vessel-card p {
    margin: 14px auto 0;
    max-width: 260px;
    color: #111;
    text-align: center;
    font-size: 16px;
    line-height: 1.32;
}

.charter-page .charter-vessel-card__arrow {
    display: none;
}

.charter-page .charter-vessel-card:hover,
.charter-page .charter-vessel-card:focus {
    color: #11263e;
    text-decoration: none;
}

.charter-page .charter-helm,
.charter-page .charter-process {
    padding-top: 92px;
}

.charter-page .charter-helm .charter-section-title {
    margin-bottom: 28px;
    text-align: left;
}

.charter-page .charter-helm__title-icon {
    display: inline-block;
    width: 34px;
    height: 34px;
    margin-left: 10px;
    object-fit: contain;
    vertical-align: -4px;
}

.charter-page .charter-helm__grid {
    display: grid;
    grid-template-columns: .9fr 1.1fr;
    gap: 36px;
    align-items: end;
}

@media (min-width: 992px) {
    .charter-page .charter-helm {
        display: grid;
        grid-template-columns: minmax(0, 540px) minmax(0, 604px);
        column-gap: 72px;
        align-items: start;
    }

    .charter-page .charter-helm .charter-section-title {
        grid-column: 1;
        grid-row: 1;
        margin-bottom: 24px;
    }

    .charter-page .charter-helm__grid {
        display: contents;
    }

    .charter-page .charter-helm__content {
        grid-column: 1;
        grid-row: 2;
    }

    .charter-page .charter-helm__image {
        grid-column: 2;
        grid-row: 1 / span 2;
    }

    .charter-page .charter-helm__image img {
        height: 420px;
        min-height: 0 !important;
    }

    .charter-page .charter-helm__note {
        margin-left: 28px !important;
        max-width: 492px !important;
    }
}

.charter-page .charter-helm__image picture,
.charter-page .charter-helm__image img {
    display: block;
    width: 100%;
}

.charter-page .charter-helm__image img {
    border-radius: 24px;
    object-fit: cover;
    min-height: 486px;
}

.charter-page .charter-helm__content {
    display: grid;
    gap: 16px;
}

.charter-page .charter-helm__item {
    position: relative;
    padding: 22px 24px 22px 22px;
    border-radius: 22px;
    background: #f9f9f9;
}

.charter-page .charter-helm__item::before {
    content: '';
    position: absolute;
    right: 18px;
    top: 18px;
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: #ee3b2f;
}

.charter-page .charter-helm__item h3 {
    margin: 0 0 10px;
    color: #111;
    font-size: 20px;
    line-height: 1.16;
    font-weight: 700;
    text-transform: none;
}

.charter-page .charter-helm__item p {
    margin: 0;
    color: #23384c;
    font-size: 16px;
    line-height: 1.25;
}

.charter-page .charter-helm__note {
    margin: 8px 0 0;
    max-width: 520px;
    color: #111;
    font-size: 14px;
    line-height: 1.22;
    font-weight: 700;
    font-style: italic;
}

.charter-page .charter-helm__note a {
    color: #ee3b2f;
    text-decoration: underline;
    text-decoration-thickness: 1px;
    text-underline-offset: 2px;
    border: 0;
}

.charter-page .charter-helm__note a:hover,
.charter-page .charter-helm__note a:focus {
    color: #ee3b2f;
    text-decoration: underline;
}

.charter-page .charter-process .charter-section-title {
    margin-bottom: 32px;
}

.charter-page .charter-process__cards {
    display: grid;
    gap: 26px;
}

.charter-page .charter-process__card {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 40px;
    align-items: center;
    padding: 34px 40px;
    border-radius: 28px;
    background: #f9f9f9;
}

.charter-page .charter-process__card--align-right {
    max-width: 970px;
    margin-left: auto;
}

.charter-page .charter-process__card--align-left {
    max-width: 1085px;
    margin-right: auto;
}

.charter-page .charter-process__card--reverse .charter-process__card-copy {
    order: 1;
}

.charter-page .charter-process__card--reverse .charter-process__card-image {
    order: 2;
}

.charter-page .charter-process__card-image picture,
.charter-page .charter-process__card-image img {
    display: block;
    width: 100%;
}

.charter-page .charter-process__card-image img {
    height: 316px;
    border-radius: 22px;
    object-fit: cover;
}

.charter-page .charter-process__card-copy h3 {
    margin: 0 0 18px;
    color: #111;
    font-size: 20px;
    line-height: 1.25;
    font-weight: 700;
    text-transform: none;
}

.charter-page .charter-process__card-copy p {
    margin: 0 0 14px;
    color: #23384c;
    font-size: 16px;
    line-height: 1.25;
}

.charter-page .charter-process__card-copy p:last-child {
    margin-bottom: 0;
}

.charter-page .charter-destinations {
    padding-top: 104px;
}

.charter-page .charter-destinations .charter-section-title {
    max-width: 900px;
    margin-inline: auto;
}

.charter-page .charter-destinations__layout {
    display: grid;
    grid-template-columns: minmax(0, 687px) minmax(360px, 497px);
    gap: 50px;
    align-items: center;
}

.charter-page .charter-destinations__media img,
.charter-page .charter-destinations__item img {
    display: block;
    width: 100%;
}

.charter-page .charter-destinations__media img {
    height: 485px;
    border-radius: 18px;
    object-fit: cover;
}

.charter-page .charter-destinations__list {
    display: grid;
    gap: 12px;
}

.charter-page .charter-destinations__item {
    display: grid;
    grid-template-columns: 56px minmax(0, 1fr);
    gap: 18px;
    align-items: center;
    min-height: 113px;
    margin: 0;
    padding: 18px 22px;
    border-radius: 10px;
    background: #f8f8f8;
}

.charter-page .charter-destinations__item img {
    width: 56px;
    height: 51px;
    object-fit: contain;
}

.charter-page .charter-destinations__item p {
    margin: 0;
    color: #11263e;
    font-size: 22px;
    line-height: 1.28;
    font-weight: 500;
}

.charter-page .charter-summary {
    padding: 104px 0 0;
}

.charter-page .charter-summary__panel {
    padding: 42px 54px 180px;
    border-radius: 30px;
    background: #f7f8fa;
    text-align: center;
}

.charter-page .charter-summary__panel .charter-section-title {
    margin-bottom: 18px;
}

.charter-page .charter-summary__panel p {
    max-width: 890px;
    margin: 0 auto;
    color: #11263e;
    font-size: 20px;
    line-height: 1.5;
}

.charter-page .charter-summary__gallery {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 22px;
    margin: -144px auto 0;
    width: min(1148px, calc(100% - 48px));
}

.charter-page .charter-summary__gallery img {
    display: block;
    width: 100%;
    height: 292px;
    border-radius: 24px;
    object-fit: cover;
}

.charter-page .charter-pricing {
    padding-top: 104px;
}

.charter-page .charter-pricing .charter-section-title {
    padding-left: 0 !important;
}

.charter-page .charter-pricing__layout {
    display: grid;
    grid-template-columns: minmax(0, 514px) minmax(0, 695px);
    gap: 28px;
    align-items: center;
}

.charter-page .charter-pricing__cards {
    display: grid;
    align-content: center;
    gap: 22px;
}

.charter-page .charter-pricing__card {
    display: grid;
    align-items: center;
    min-height: 179px;
    margin: 0;
    padding: 28px 34px;
    border-radius: 8px;
    background: #f8f8f8;
    color: #11263e;
    text-align: center;
}

.charter-page .charter-pricing__card--text {
    min-height: auto;
    padding: 0 0 2px;
    border-radius: 0;
    background: transparent;
}

.charter-page .charter-pricing__card--price {
    justify-items: center;
    gap: 16px;
    padding: 30px 34px;
}

.charter-page .charter-pricing__card img {
    display: block;
    width: 58px;
    height: 58px;
    object-fit: contain;
}

.charter-page .charter-pricing__card p {
    margin: 0;
    font-size: 22px;
    line-height: 1.22;
    font-weight: 700;
}

.charter-page .charter-pricing__card--text p {
    font-size: 20px;
    line-height: 1.25;
}

.charter-page .charter-pricing__media img {
    display: block;
    width: 100%;
    height: 463px;
    border-radius: 12px;
    object-fit: cover;
}

.charter-page .charter-form-section {
    margin-top: 104px;
    padding: 0;
}

.charter-page .charter-form-section__frame {
    position: relative;
    border: 6px solid #ee3b2f;
    border-radius: 32px;
    overflow: hidden;
    background: #fff;
    min-height: 983px;
}

.charter-page .charter-form-section__bg {
    position: absolute;
    inset: 10px;
    border-radius: 24px;
    overflow: hidden;
}

.charter-page .charter-form-section__bg picture,
.charter-page .charter-form-section__bg img {
    display: block;
    width: 100%;
    height: 100%;
}

.charter-page .charter-form-section__bg img {
    width: 100% !important;
    max-width: none !important;
    object-fit: cover;
}

.charter-page .charter-form-section__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(10, 25, 44, 0.06) 0%, rgba(10, 25, 44, 0.14) 100%);
}

.charter-page .charter-form-section__content {
    position: relative;
    z-index: 1;
    width: min(530px, calc(100% - 48px));
    margin: 44px auto 0;
    padding: 24px 28px 26px;
    border-radius: 24px;
    background: rgba(255, 255, 255, 0.98);
    border: 1px solid rgba(17, 38, 62, 0.16);
    box-shadow: 0 24px 64px rgba(17, 38, 62, 0.2);
}

.charter-page .charter-form-section__head {
    margin-bottom: 18px;
    text-align: center;
    color: #111;
}

.charter-page .charter-form-section__head h2 {
    max-width: 300px;
    margin: 0 auto !important;
    padding: 0 !important;
    color: #111;
    font-size: 32px;
    line-height: 1.12;
    font-weight: 700;
    text-transform: none;
}

.charter-page .charter-form-section__head p {
    margin: 0;
    color: #66788b;
    font-size: 16px;
    line-height: 1.45;
}

.charter-page .charter-form__module-inner .rsform {
    border-radius: 0;
    background: transparent;
    padding: 0;
    box-shadow: none;
}

.charter-page .charter-form__module-inner form h2 {
    display: none;
}

.charter-page .charter-form__module-inner .formContainer {
    display: block;
}

.charter-page .charter-form__module-inner .form-row + .form-row {
    margin-top: 0;
}

.charter-page .charter-form__module-inner .col-md-12,
.charter-page .charter-form__module-inner .col-md-6 {
    max-width: none;
    flex: none;
    padding: 0;
}

.charter-page .charter-form__module-inner .form-group {
    margin-bottom: 6px;
}

.charter-page .charter-form__module-inner label.control-label {
    display: block;
    margin-bottom: 8px;
    color: #11263e;
    font-size: 15px;
    line-height: 1.4;
    font-weight: 500;
}

.charter-page .charter-form__module-inner input[type="text"],
.charter-page .charter-form__module-inner input[type="email"],
.charter-page .charter-form__module-inner input[type="tel"],
.charter-page .charter-form__module-inner input[type="date"],
.charter-page .charter-form__module-inner select,
.charter-page .charter-form__module-inner textarea {
    width: 100%;
    min-height: 42px;
    border: 1px solid rgba(17, 38, 62, 0.14);
    border-radius: 2px;
    background: #fff;
    box-shadow: none;
    color: #11263e;
    font-size: 14px;
    padding: 8px 12px;
}

.charter-page .charter-form__module-inner select,
.charter-page .charter-form__module-inner input[type="date"] {
    background-color: #c8f1ff;
}

.charter-page .charter-form__module-inner select.has-value,
.charter-page .charter-form__module-inner input[type="date"].has-value {
    border-color: #78cbe3;
    background-color: #b5ecff;
    color: #11263e;
    font-weight: 500;
    box-shadow: inset 0 0 0 1px rgba(120, 203, 227, 0.28);
}

.charter-page .charter-form__module-inner select {
    appearance: none;
    background-image:
        linear-gradient(45deg, transparent 50%, #11263e 50%),
        linear-gradient(135deg, #11263e 50%, transparent 50%);
    background-position:
        calc(100% - 22px) calc(50% - 4px),
        calc(100% - 16px) calc(50% - 4px);
    background-size: 6px 6px, 6px 6px;
    background-repeat: no-repeat;
    padding-right: 34px;
}

.charter-page .charter-region-select {
    position: relative;
}

.charter-page .charter-select-search {
    display: none;
}

.charter-page .charter-region-select__native {
    position: absolute !important;
    left: 0;
    top: 0;
    width: 1px !important;
    height: 1px !important;
    opacity: 0;
    pointer-events: none;
}

.charter-page .charter-region-picker {
    position: relative;
}

.charter-page .charter-region-picker__button {
    position: relative;
    display: flex;
    align-items: center;
    gap: 10px;
    width: 100%;
    min-height: 42px;
    border: 1px solid rgba(17, 38, 62, 0.14);
    border-radius: 2px;
    background: #c8f1ff;
    color: #11263e;
    font-family: "PT Sans", sans-serif;
    font-size: 14px;
    font-weight: 400;
    line-height: 1.5;
    text-align: left;
    padding: 8px 34px 8px 12px;
    box-shadow: none;
    cursor: pointer;
}

.charter-page .charter-region-picker__button::after {
    content: '';
    position: absolute;
    right: 17px;
    top: 50%;
    width: 0;
    height: 0;
    border-left: 5px solid transparent;
    border-right: 5px solid transparent;
    border-top: 6px solid #11263e;
    transform: translateY(-35%);
}

.charter-page .charter-region-picker__button.has-value {
    border-color: #78cbe3;
    background: #b5ecff;
    color: #11263e;
    font-weight: 500;
    box-shadow: inset 0 0 0 1px rgba(120, 203, 227, 0.28);
}

.charter-page .charter-region-select.has-error .charter-region-picker__button {
    border-color: #ee3b2f;
    box-shadow: inset 0 0 0 1px rgba(238, 59, 47, 0.28);
}

.charter-page .charter-region-picker__button-flag,
.charter-page .charter-region-picker__flag {
    display: inline-flex;
    flex: 0 0 26px;
    width: 26px;
    height: 18px;
}

.charter-page .charter-region-picker__button-flag:empty {
    display: none;
}

.charter-page .charter-region-picker__flag {
    border-radius: 2px;
    background: #fff;
    object-fit: cover;
    box-shadow: 0 0 0 1px rgba(17, 38, 62, 0.16);
}

.charter-page .charter-region-picker__button-text,
.charter-page .charter-region-picker__option-text {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.charter-page .charter-region-picker__button-text {
    flex: 1 1 auto;
}

.charter-page .charter-region-picker__list {
    position: absolute;
    left: 0;
    right: 0;
    top: calc(100% + 4px);
    z-index: 40;
    display: none;
    max-height: 262px;
    overflow-y: auto;
    padding: 4px;
    border: 1px solid rgba(17, 38, 62, 0.14);
    border-radius: 4px;
    background: #fff;
    box-shadow: 0 18px 34px rgba(17, 38, 62, 0.16);
    scrollbar-color: #78cbe3 #eef9fc;
    scrollbar-width: thin;
}

.charter-page .charter-region-picker__list::-webkit-scrollbar {
    width: 8px;
}

.charter-page .charter-region-picker__list::-webkit-scrollbar-track {
    border-radius: 8px;
    background: #eef9fc;
}

.charter-page .charter-region-picker__list::-webkit-scrollbar-thumb {
    border: 2px solid #eef9fc;
    border-radius: 8px;
    background: #78cbe3;
}

.charter-page .charter-region-select.is-open .charter-region-picker__list {
    display: block;
}

.charter-page .charter-region-select.opens-up .charter-region-picker__list {
    top: auto;
    bottom: calc(100% + 4px);
}

.charter-page .charter-region-picker__option {
    display: flex;
    align-items: center;
    gap: 10px;
    width: 100%;
    min-height: 38px;
    border: 0;
    border-radius: 2px;
    background: transparent;
    color: #11263e;
    font-size: 14px;
    line-height: 1.2;
    text-align: left;
    padding: 8px 10px;
    cursor: pointer;
}

.charter-page .charter-region-picker__option:hover,
.charter-page .charter-region-picker__option:focus,
.charter-page .charter-region-picker__option.is-selected {
    background: #eaf8ff;
    outline: 0;
}

.charter-page .charter-form__module-inner .rsform-block-charter-date-start {
    position: relative;
}

.charter-page .charter-form__module-inner .rsform-block-charter-date-start.is-empty-date input[type="date"] {
    color: transparent;
}

.charter-page .charter-form__module-inner .charter-date-placeholder {
    position: absolute;
    left: 12px;
    top: 50%;
    transform: translateY(-50%);
    max-width: calc(100% - 52px);
    color: rgba(17, 38, 62, 0.72);
    font-size: 14px;
    line-height: 1;
    pointer-events: none;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.charter-page .charter-form__module-inner .rsform-block-charter-date-start:not(.is-empty-date) .charter-date-placeholder {
    display: none;
}

.charter-page .charter-form__date-summary {
    display: none;
}

.charter-page .charter-form__module-inner .rsform-block-charter-consent-terms .formControls label,
.charter-page .charter-form__module-inner .rsform-block-charter-consent-privacy .formControls label {
    display: flex;
    gap: 8px;
    align-items: flex-start;
    color: #23384c;
    font-size: 13px;
    line-height: 1.35;
    padding: 2px 0;
    cursor: pointer;
}

.charter-page .charter-form__module-inner .rsform-block-charter-consent-terms input,
.charter-page .charter-form__module-inner .rsform-block-charter-consent-privacy input {
    appearance: none;
    -webkit-appearance: none;
    width: 16px;
    height: 16px;
    flex: 0 0 16px;
    margin: 1px 0 0;
    border: 1px solid #b7c7d8;
    border-radius: 1px;
    background: #fff;
    position: relative;
    box-shadow: none;
}

.charter-page .charter-form__module-inner .rsform-block-charter-consent-terms input:checked,
.charter-page .charter-form__module-inner .rsform-block-charter-consent-privacy input:checked {
    border-color: #ee3b2f;
    background: #ee3b2f;
}

.charter-page .charter-form__module-inner .rsform-block-charter-consent-terms input:checked::after,
.charter-page .charter-form__module-inner .rsform-block-charter-consent-privacy input:checked::after {
    content: '';
    position: absolute;
    left: 5px;
    top: 2px;
    width: 5px;
    height: 9px;
    border-right: 2px solid #fff;
    border-bottom: 2px solid #fff;
    transform: rotate(45deg);
}

@media (max-width: 767px) {
    .charter-page .charter-form__module-inner .rsform-block-charter-consent-terms .formControls label,
    .charter-page .charter-form__module-inner .rsform-block-charter-consent-privacy .formControls label {
        gap: 10px;
        font-size: 14px;
        line-height: 1.35;
        padding: 3px 0;
    }

    .charter-page .charter-form__module-inner .rsform-block-charter-consent-terms input,
    .charter-page .charter-form__module-inner .rsform-block-charter-consent-privacy input {
        width: 18px;
        height: 18px;
        flex: 0 0 18px;
        margin-top: 0;
    }

    .charter-page .charter-form__module-inner .rsform-block-charter-consent-terms input:checked::after,
    .charter-page .charter-form__module-inner .rsform-block-charter-consent-privacy input:checked::after {
        left: 6px;
        top: 2px;
        width: 5px;
        height: 10px;
    }
}

.charter-page .charter-form__module-inner .rsform-block-charter-consent-terms input:focus,
.charter-page .charter-form__module-inner .rsform-block-charter-consent-privacy input:focus {
    outline: none;
    box-shadow: 0 0 0 3px rgba(238, 59, 47, 0.14);
}

.charter-page .charter-form__module-inner .rsform-block-charter-consent-terms a,
.charter-page .charter-form__module-inner .rsform-block-charter-consent-privacy a {
    color: #11263e;
    text-decoration: underline;
}

.charter-page .charter-form__module-inner .rsform-submit-button {
    display: flex;
    align-items: center;
    justify-content: center;
    width: fit-content;
    min-width: 230px;
    min-height: 44px;
    margin: 8px auto 0;
    padding: 0 28px;
    border: 0;
    border-radius: 999px;
    background: #ee3b2f;
    color: #fff;
    font-size: 15px;
    font-weight: 500;
}

.charter-page .charter-form__module-inner .rsform-submit-button::after {
    content: '\2192';
    margin-left: 12px;
}

.charter-page .charter-form__module-inner .rsform-submit-button[disabled] {
    opacity: .55;
    cursor: not-allowed;
}

.charter-page .charter-form__module-inner .charter-form__thankyou {
    text-align: center;
    color: #11263e;
    padding: 20px 8px;
}

.charter-page .charter-form__module-inner .charter-form__thankyou h3 {
    margin: 0 0 12px;
    color: #ee3b2f;
    font-size: 30px;
}

.charter-page .charter-form__module-inner .charter-form__thankyou p {
    margin: 0;
    color: #536579;
    font-size: 17px;
    line-height: 1.6;
}

.charter-page .charter-max {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 499px;
    gap: 36px;
    align-items: center;
    margin-top: 92px;
    padding: 44px;
    border-radius: 28px;
    background: #f7f8fa;
}

.charter-page .charter-max__visual picture,
.charter-page .charter-max__visual img {
    display: block;
    width: 100%;
}

.charter-page .charter-max__visual img {
    height: 289px;
    border-radius: 22px;
    object-fit: cover;
}

.charter-page .charter-max__content h2 {
    max-width: 650px;
    margin: 0 0 28px;
    font-size: 32px;
    line-height: 1.18;
    font-weight: 700;
    text-transform: none;
    background: linear-gradient(90deg, #5a8cff 0%, #845bff 100%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
}

.charter-page .charter-max__contacts {
    display: flex;
    flex-wrap: wrap;
    gap: 10px 32px;
    align-items: center;
    margin-top: 10px;
}

.charter-page .charter-max__contacts-title {
    margin: 32px 0 0;
    color: #111;
    font-size: 18px;
    line-height: 1.2;
    font-weight: 700;
}

.charter-page .charter-max__contacts a {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: #111;
    font-size: 18px;
    line-height: 1.2;
    font-weight: 700;
    text-decoration: none;
    border-bottom: 0;
}

.charter-page .charter-max__contacts a::before {
    content: "";
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 24px;
    height: 24px;
    flex: 0 0 24px;
    border-radius: 50%;
    background: #e72d28;
    background-position: center;
    background-repeat: no-repeat;
    background-size: 13px 13px;
}

.charter-page .charter-max__contacts a[href^="mailto:"]::before {
    background-image: url("data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2024%2024%22%3E%3Cpath%20fill%3D%22%23fff%22%20d%3D%22M3%206.5A2.5%202.5%200%200%201%205.5%204h13A2.5%202.5%200%200%201%2021%206.5v11A2.5%202.5%200%200%201%2018.5%2020h-13A2.5%202.5%200%200%201%203%2017.5v-11Zm2.4-.5%206.6%205.2L18.6%206H5.4Zm13.6%202.1-6.4%205a1%201%200%200%201-1.2%200L5%208.1v9.4c0%20.3.2.5.5.5h13c.3%200%20.5-.2.5-.5V8.1Z%22%2F%3E%3C%2Fsvg%3E");
}

.charter-page .charter-max__contacts a[href^="tel:"]::before {
    background-image: url("data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2024%2024%22%3E%3Cpath%20fill%3D%22%23fff%22%20d%3D%22M6.6%202.5%209.7%205.6c.7.7.8%201.8.2%202.6l-1%201.4c1.3%202.4%203.1%204.2%205.5%205.5l1.4-1c.8-.6%201.9-.5%202.6.2l3.1%203.1c.6.6.7%201.6.2%202.3-1%201.4-2.7%202.1-4.4%201.8C9.7%2020.2%203.8%2014.3%202.5%206.7%202.2%205%202.9%203.3%204.3%202.3c.7-.5%201.7-.4%202.3.2Z%22%2F%3E%3C%2Fsvg%3E");
}

.charter-page .charter-max .charter-button {
    background: linear-gradient(90deg, #5f8eff 0%, #8658ff 100%);
    box-shadow: none;
}

.charter-page .charter-max .charter-button:hover,
.charter-page .charter-max .charter-button:focus {
    background: linear-gradient(90deg, #4d7df2 0%, #7648f2 100%);
    box-shadow: none;
}

.charter-page .charter-faq {
    padding-top: 92px;
}

.charter-page .charter-faq h2 {
    margin: 0 0 34px;
    color: #11263e;
    font-size: 42px;
    line-height: 1.15;
    font-weight: 700;
    text-align: center;
    text-transform: none;
}

.charter-page .faq-item {
    margin-bottom: 12px;
    border: 0;
    border-radius: 18px;
    background: #fafafa;
    overflow: hidden;
}

.charter-page .faq-question {
    position: relative;
    width: 100%;
    padding: 24px 62px 24px 20px;
    border: 0;
    background: transparent;
    color: #11263e;
    text-align: left;
    font-size: 20px;
    line-height: 1.35;
    font-weight: 400;
    text-transform: none;
}

.charter-page .faq-question::before,
.charter-page .faq-question::after {
    content: '';
    position: absolute;
    right: 8px;
    top: 50%;
    width: 18px;
    height: 2px;
    background: #858585;
    transform: translateY(-50%);
    transition: transform .2s ease;
}

.charter-page .faq-question::after {
    transform: translateY(-50%) rotate(90deg);
}

.charter-page .faq-item.is-open .faq-question::after {
    transform: translateY(-50%) rotate(0);
}

.charter-page .faq-answer {
    display: none;
    padding: 0 20px 22px;
    max-height: none;
    margin-top: 0;
    overflow: visible;
}

.charter-page .faq-item.is-open .faq-answer {
    display: block;
    max-height: none;
    margin-top: 0;
    overflow: visible;
}

.charter-page .faq-answer p,
.charter-page .faq-answer li {
    color: #536579;
    font-size: 18px;
    line-height: 1.75;
}

.charter-page .faq-answer ul {
    margin: 16px 0 0;
    padding-left: 22px;
}

@media (max-width: 1199px) {
    .charter-page .charter-hero h1,
    .charter-page .charter-section-title,
    .charter-page .charter-faq h2,
    .charter-page .charter-form-section__head h2,
    .charter-page .charter-max__content h2 {
        font-size: 38px;
    }

    .charter-page .charter-vessels__grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .charter-page .charter-max {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 991px) {
    .charter-page .charter-page,
    .charter-page .charter-hero,
    .charter-page .charter-intro,
    .charter-page .charter-vessels,
    .charter-page .charter-helm,
    .charter-page .charter-process,
    .charter-page .charter-destinations,
    .charter-page .charter-summary,
    .charter-page .charter-pricing,
    .charter-page .charter-form-section,
    .charter-page .charter-faq,
    .charter-page .charter-max {
        width: min(100%, calc(100% - 32px));
    }

    .charter-page .charter-hero__frame {
        min-height: 533px;
    }

    .charter-page .charter-hero__content {
        padding: 78px 34px 48px;
        max-width: 360px;
    }

    .charter-page .charter-hero h1 {
        font-size: 42px;
    }

    .charter-page .charter-hero__subtitle,
    .charter-page .charter-intro__copy,
    .charter-page .charter-process__card-copy p,
    .charter-page .charter-destinations__item p,
    .charter-page .charter-summary__panel p,
    .charter-page .charter-pricing__card p,
    .charter-page .charter-helm__item p,
    .charter-page .faq-answer p,
    .charter-page .faq-answer li {
        font-size: 18px;
    }

    .charter-page .charter-intro__copy,
    .charter-page .charter-helm__grid,
    .charter-page .charter-process__card,
    .charter-page .charter-destinations__layout,
    .charter-page .charter-pricing__layout {
        grid-template-columns: 1fr;
    }

    .charter-page .charter-process__card {
        gap: 24px;
        padding: 28px;
    }

    .charter-page .charter-process__card--reverse .charter-process__card-copy,
    .charter-page .charter-process__card--reverse .charter-process__card-image {
        order: initial;
    }

    .charter-page .charter-summary__panel {
        padding: 34px 32px 148px;
    }

    .charter-page .charter-summary__gallery {
        gap: 16px;
        margin-top: -116px;
        width: min(100%, calc(100% - 32px));
    }

    .charter-page .charter-summary__gallery img {
        height: 260px;
    }

    .charter-page .charter-pricing__media img {
        height: 360px;
    }

    .charter-page .charter-form-section__frame {
        min-height: auto;
    }

    .charter-page .charter-form-section__content {
        margin-top: 32px;
    }
}

@media (min-width: 768px) and (max-width: 991px) {
    .charter-page .charter-hero__content {
        position: absolute;
        left: 0;
        bottom: 0;
        width: min(420px, 100%);
        padding: 0 34px 48px;
    }
}

@media (max-width: 767px) {
    .charter-page .charter-hero {
        width: min(100%, calc(100% - 16px));
        margin-top: 12px;
    }

    .charter-page .charter-hero__frame {
        min-height: 533px;
        border-radius: 22px;
    }

    .charter-page .charter-hero__overlay {
        background: linear-gradient(180deg, rgba(10, 25, 44, 0.05) 0%, rgba(10, 25, 44, 0.22) 56%, rgba(10, 25, 44, 0.62) 100%);
    }

    .charter-page .charter-hero__content {
        max-width: 100%;
        padding: 342px 18px 30px;
    }

    .charter-page .charter-hero h1 {
        margin-bottom: 12px;
        font-size: 32px;
        line-height: 1.18;
    }

    .charter-page .charter-hero__subtitle {
        margin-bottom: 18px;
        font-size: 14px;
        line-height: 1.5;
    }

    .charter-page .charter-button {
        min-height: 48px;
        padding: 0 24px;
        font-size: 16px;
    }

    .charter-page .charter-running-line {
        margin-top: 14px;
        font-size: 14px;
        padding: 10px 0;
    }

    .charter-page .charter-running-line__track {
        justify-content: flex-start;
    }

    .charter-page .charter-running-line__group {
        gap: 18px;
        padding-right: 18px;
    }

    .charter-page .charter-section-title,
    .charter-page .charter-faq h2,
    .charter-page .charter-form-section__head h2,
    .charter-page .charter-max__content h2 {
        font-size: 26px;
        line-height: 1.18;
    }

    .charter-page .charter-pricing .charter-section-title {
        margin-bottom: 18px;
        font-size: 18px;
        line-height: 1.2;
    }

    .charter-page .charter-intro,
    .charter-page .charter-vessels,
    .charter-page .charter-helm,
    .charter-page .charter-process,
    .charter-page .charter-destinations,
    .charter-page .charter-summary,
    .charter-page .charter-pricing,
    .charter-page .charter-faq {
        padding-top: 56px;
    }

    .charter-page .charter-intro__copy,
    .charter-page .charter-vessels__grid,
    .charter-page .charter-process__cards {
        grid-template-columns: 1fr;
        gap: 16px;
    }

    .charter-page .charter-intro {
        display: flex;
        flex-direction: column;
        gap: 16px;
    }

    .charter-page .charter-intro__copy,
    .charter-page .charter-intro__visuals {
        display: contents;
    }

    .charter-page .charter-intro__copy p:first-child {
        order: 1;
    }

    .charter-page .charter-intro__visuals picture:first-child {
        order: 2;
    }

    .charter-page .charter-intro__copy p:last-child {
        order: 3;
    }

    .charter-page .charter-intro__visuals picture:last-child {
        order: 4;
    }

    .charter-page .charter-intro__visuals img {
        height: 215px;
        border-radius: 18px;
    }

    .charter-page .charter-vessel-card {
        min-height: auto;
    }

    .charter-page .charter-vessel-card img {
        height: 100%;
        border-radius: inherit;
    }

    .charter-page .charter-vessel-card__media {
        height: auto;
        aspect-ratio: 658 / 754;
        border-radius: 13px;
    }

    .charter-page .charter-vessel-card h3 {
        min-height: 33px;
        padding: 5px 36px 5px 12px;
        font-size: 15px;
        line-height: 1.12;
        border-radius: 10px 10px 0 0;
    }

    .charter-page .charter-vessel-card h3::before {
        right: 14px;
        width: 16px;
    }

    .charter-page .charter-vessel-card h3::after {
        right: 12px;
        width: 7px;
        height: 7px;
    }

    .charter-page .charter-vessel-card p,
    .charter-page .charter-intro__copy,
    .charter-page .charter-process__card-copy p,
    .charter-page .charter-destinations__item p,
    .charter-page .charter-summary__panel p,
    .charter-page .charter-pricing__card p,
    .charter-page .charter-helm__item p,
    .charter-page .faq-answer p,
    .charter-page .faq-answer li {
        font-size: 16px;
        line-height: 1.5;
    }

    .charter-page .charter-helm .charter-section-title {
        text-align: center;
    }

    .charter-page .charter-helm__grid {
        grid-template-columns: 1fr;
        gap: 24px;
    }

    .charter-page .charter-helm__image img {
        min-height: 300px;
        border-radius: 20px;
    }

    .charter-page .charter-process__card {
        gap: 16px;
        padding: 20px 16px;
        border-radius: 22px;
    }

    .charter-page .charter-process__card-image img {
        height: 250px;
        border-radius: 18px;
    }

    .charter-page .charter-destinations__layout {
        display: flex;
        flex-direction: column;
        gap: 18px;
    }

    .charter-page .charter-destinations__list {
        order: 1;
        width: 100%;
        gap: 8px;
    }

    .charter-page .charter-destinations__media {
        order: 2;
        width: 100%;
    }

    .charter-page .charter-destinations__media img {
        height: 212px;
        border-radius: 18px;
    }

    .charter-page .charter-destinations__item {
        grid-template-columns: 56px minmax(0, 1fr);
        gap: 14px;
        min-height: 96px;
        padding: 14px 16px;
    }

    .charter-page .charter-destinations__item p {
        font-size: 16px;
    }

    .charter-page .charter-process__card-copy h3 {
        font-size: 18px;
        line-height: 1.28;
    }

    .charter-page .charter-summary__panel {
        padding: 28px 18px;
        border-radius: 20px;
    }

    .charter-page .charter-summary__gallery {
        display: grid;
        grid-template-columns: 1fr;
        gap: 14px;
        margin: 18px 0 0;
        width: 100%;
    }

    .charter-page .charter-summary__gallery img {
        height: 341px;
        border-radius: 18px;
    }

    .charter-page .charter-pricing__layout {
        gap: 14px;
    }

    .charter-page .charter-pricing__cards {
        gap: 8px;
    }

    .charter-page .charter-pricing__card {
        min-height: auto;
        padding: 18px;
        border-radius: 8px;
    }

    .charter-page .charter-pricing__card--text {
        padding: 0 0 4px;
    }

    .charter-page .charter-pricing__card--price {
        min-height: 96px;
        grid-template-columns: 1fr;
        gap: 6px;
        padding: 12px 16px;
    }

    .charter-page .charter-pricing__card img {
        width: 34px;
        height: 34px;
    }

    .charter-page .charter-pricing__card p {
        font-size: 13px;
        line-height: 1.22;
    }

    .charter-page .charter-pricing__card--text p {
        font-size: 12px;
        line-height: 1.25;
    }

    .charter-page .charter-pricing__media img {
        height: 233px;
        border-radius: 10px;
    }

    .charter-page .charter-form-section {
        width: min(100%, calc(100% - 16px));
        margin-top: 68px;
        padding-top: 0;
        margin-inline: auto;
    }

    .charter-page .charter-form-section__frame {
        border-radius: 22px;
        border-width: 4px;
        background: #fff;
        min-height: auto;
    }

    .charter-page .charter-form-section__bg {
        inset: 12px;
        border-radius: 18px;
    }

    .charter-page .charter-form-section__overlay {
        background: linear-gradient(180deg, rgba(10, 25, 44, 0.08) 0%, rgba(10, 25, 44, 0.24) 100%);
    }

    .charter-page .charter-form-section__content {
        width: min(100%, calc(100% - 28px));
        margin-top: 18px;
        padding: 22px 14px 20px;
        border-radius: 20px;
    }

    .charter-page .charter-form__module-inner .rsform {
        padding: 0;
        border-radius: 0;
    }

    .charter-page .charter-form-section__head h2 {
        max-width: 190px;
        font-size: 20px;
        line-height: 1.15;
    }

    .charter-page .charter-form-section__head p {
        font-size: 14px;
        line-height: 1.5;
    }

    .charter-page .charter-form__module-inner input[type="text"],
    .charter-page .charter-form__module-inner input[type="email"],
    .charter-page .charter-form__module-inner input[type="tel"],
    .charter-page .charter-form__module-inner input[type="date"],
    .charter-page .charter-form__module-inner select,
    .charter-page .charter-form__module-inner textarea {
        min-height: 38px;
        border-radius: 2px;
        font-size: 12px;
        padding: 7px 10px;
    }

    .charter-page .charter-region-picker__button {
        min-height: 38px;
        font-size: 12px;
        line-height: 18px;
        padding: 7px 34px 7px 10px;
    }

    .charter-page .charter-form__module-inner .charter-date-placeholder {
        left: 10px;
        max-width: calc(100% - 46px);
        font-size: 12px;
    }

    .charter-page .charter-form__module-inner label.control-label {
        font-size: 13px;
        margin-bottom: 6px;
    }

    .charter-page .charter-form__module-inner .form-group {
        margin-bottom: 5px;
    }

    .charter-page .charter-form__module-inner .rsform-block-charter-consent-terms .formControls label,
    .charter-page .charter-form__module-inner .rsform-block-charter-consent-privacy .formControls label {
        font-size: 14px;
        line-height: 1.35;
    }

    .charter-page .charter-form__module-inner .rsform-submit-button {
        min-width: 178px;
        min-height: 38px;
        margin-top: 8px;
        font-size: 13px;
    }

    .charter-page .charter-max {
        width: min(100%, calc(100% - 16px));
        margin-top: 68px;
        padding: 28px 16px;
        border-radius: 22px;
        text-align: center;
    }

    .charter-page .charter-max__content {
        display: flex;
        flex-direction: column;
        align-items: center;
    }

    .charter-page .charter-max__content h2 {
        max-width: 310px;
        margin-right: auto;
        margin-left: auto;
        text-align: center;
    }

    .charter-page .charter-max .charter-button {
        margin-right: auto;
        margin-left: auto;
    }

    .charter-page .charter-max__contacts-title {
        margin-top: 22px;
        font-size: 13px;
        text-align: center;
    }

    .charter-page .charter-max__contacts {
        flex-direction: column;
        justify-content: center;
        align-items: center;
        gap: 8px;
        margin-top: 8px;
    }

    .charter-page .charter-max__contacts a {
        gap: 6px;
        font-size: 12px;
    }

    .charter-page .charter-max__contacts a::before {
        width: 16px;
        height: 16px;
        flex-basis: 16px;
        font-size: 8px;
    }

    .charter-page .charter-max__visual img {
        height: auto;
        border-radius: 18px;
    }

    .charter-page .faq-question {
        padding: 20px 46px 20px 16px;
        font-size: 18px;
        line-height: 1.35;
    }
}

@media (min-width: 560px) and (max-width: 767px) {
    .charter-page .charter-vessels__grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}
