/*
 * MM font test: JetBrains Mono, inspired by MikroTik.
 * Rollback: remove the mm-font-test enqueue in inc/static.php.
 */

@font-face {
    font-family: 'JetBrains Mono';
    font-style: normal;
    font-weight: 300 700;
    font-display: swap;
    src: url('../fonts/JetBrainsMono-latin.woff2') format('woff2');
}

:root {
    --mm-code-font: 'JetBrains Mono', ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, 'Liberation Mono', 'Courier New', monospace;
    --mm-display-font: XWZar, Arial, Helvetica, sans-serif;
    --mm-page-gutter: clamp(18px, 3vw, 44px);
    --mm-section-space: clamp(70px, 8vw, 150px);
    --mm-copy-size: clamp(16px, .95vw, 18px);
    --mm-copy-leading: 1.68;
    --mm-copy-block-size: clamp(15px, 1.05vw, 20px);
    --mm-copy-block-leading: 1.58;
}

body,
button,
input,
select,
optgroup,
textarea,
.site-header,
.site-footer,
.menu-item,
.elementor-widget-text-editor,
.project-category,
.project-excerpt,
.project-button,
.text-wrapper .text-p,
.text-wrapper .p-small,
.text-wrapper .p-large {
    font-family: var(--mm-code-font) !important;
}

body {
    font-size: var(--mm-copy-size);
    line-height: var(--mm-copy-leading);
}

p,
.text-p,
.elementor-widget-text-editor {
    font-size: var(--mm-copy-size);
    line-height: var(--mm-copy-leading);
}

body,
p,
li,
h1,
h2,
h3,
h4,
h5,
h6,
.text-wrapper,
.text-wrapper > *,
.elementor-widget-text-editor,
.elementor-widget-text-editor * {
    -webkit-hyphens: none !important;
    -ms-hyphens: none !important;
    hyphens: none !important;
    word-break: normal !important;
    overflow-wrap: normal !important;
    word-wrap: normal !important;
}

main p:not(.text-h1):not(.text-h2):not(.text-h3):not(.text-h4):not(.text-h5):not(.text-h6),
main .elementor-widget-text-editor p,
main .text-wrapper p:not(.text-h1):not(.text-h2):not(.text-h3):not(.text-h4):not(.text-h5):not(.text-h6) {
    text-align: justify !important;
    text-align-last: left;
    hyphens: none !important;
    overflow-wrap: normal !important;
}

.p-large {
    font-size: clamp(18px, 1.16vw, 22px);
    line-height: 1.58;
}

.p-small {
    font-size: clamp(14px, .84vw, 16px);
    line-height: 1.62;
}

h1,
h2,
h3,
h4,
h5,
h6,
.text-h1,
.text-h2,
.text-h3,
.text-h4,
.text-h5,
.text-h6,
.elementor-heading-title,
.project-title,
.accordion-toggle {
    font-family: var(--mm-display-font) !important;
    letter-spacing: 0 !important;
}

h1,
.text-h1 {
    font-size: clamp(58px, 8.5vw, 132px);
    line-height: 1;
}

h2,
.text-h2 {
    font-size: clamp(44px, 6.4vw, 98px);
    line-height: 1.04;
}

h3,
.text-h3 {
    font-size: clamp(34px, 4.6vw, 70px);
    line-height: 1.08;
}

h4,
.text-h4 {
    font-size: clamp(28px, 3.2vw, 48px);
    line-height: 1.14;
}

h5,
.text-h5 {
    font-size: clamp(22px, 2.1vw, 34px);
    line-height: 1.2;
}

h6,
.text-h6 {
    font-size: clamp(18px, 1.35vw, 24px);
    line-height: 1.25;
}

main .text-wrapper p:not(.text-h1):not(.text-h2):not(.text-h3):not(.text-h4),
main .text-wrapper h5,
main .text-wrapper h6,
main .text-wrapper .text-h5,
main .text-wrapper .text-h6 {
    font-family: var(--mm-code-font) !important;
    font-size: var(--mm-copy-block-size) !important;
    line-height: var(--mm-copy-block-leading) !important;
    letter-spacing: 0 !important;
    font-weight: 400 !important;
}

.text-wrapper > * {
    margin-top: 0;
}

.text-wrapper > * + *,
.elementor-widget-text-editor p + p {
    margin-top: clamp(12px, 1.3vw, 22px);
}

.text-wrapper > *:last-child,
.elementor-widget-text-editor p:last-child {
    margin-bottom: 0;
}

.pe-wrapper {
    padding-left: var(--mm-page-gutter);
    padding-right: var(--mm-page-gutter);
}

.pe-wrapper .pe-wrapper,
.pe-col-12 .pe-col-12 {
    padding-left: 0;
    padding-right: 0;
}

.elementor .e-con {
    min-width: 0;
}

body.elementor-page .entry-content > .elementor > .e-con.e-parent,
body.single-portfolio .project-page-content > .elementor > .e-con.e-parent {
    padding-left: max(var(--mm-page-gutter), var(--padding-left, 0px));
    padding-right: max(var(--mm-page-gutter), var(--padding-right, 0px));
}

.elementor-11886 .elementor-element.elementor-element-00e1cfb {
    display: grid !important;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: clamp(24px, 3vw, 64px);
    width: 100%;
    max-width: 1920px;
    margin-left: auto !important;
    margin-right: auto !important;
    padding-left: clamp(36px, 4vw, 92px) !important;
    padding-right: clamp(36px, 4vw, 92px) !important;
    box-sizing: border-box;
    align-items: start !important;
    justify-content: initial !important;
}

.elementor-11886 .elementor-element.elementor-element-1cb37f7,
.elementor-11886 .elementor-element.elementor-element-c9f8bba,
.elementor-11886 .elementor-element.elementor-element-bf684ed,
.elementor-11886 .elementor-element.elementor-element-6a59243,
.elementor-11886 .elementor-element.elementor-element-0131b5a {
    flex: none !important;
    width: auto !important;
    min-width: 0 !important;
    max-width: none !important;
}

.elementor-11886 .elementor-element.elementor-element-1cb37f7 > .elementor-widget-container,
.elementor-11886 .elementor-element.elementor-element-c9f8bba > .elementor-widget-container,
.elementor-11886 .elementor-element.elementor-element-bf684ed > .elementor-widget-container,
.elementor-11886 .elementor-element.elementor-element-6a59243 > .elementor-widget-container,
.elementor-11886 .elementor-element.elementor-element-0131b5a > .elementor-widget-container {
    padding: clamp(18px, 1.7vw, 30px) !important;
}

.elementor-11886 .elementor-element.elementor-element-1cb37f7 .text-wrapper,
.elementor-11886 .elementor-element.elementor-element-c9f8bba .text-wrapper,
.elementor-11886 .elementor-element.elementor-element-bf684ed .text-wrapper,
.elementor-11886 .elementor-element.elementor-element-6a59243 .text-wrapper,
.elementor-11886 .elementor-element.elementor-element-0131b5a .text-wrapper {
    height: 100%;
    text-align: left !important;
}

.elementor-11886 .elementor-element.elementor-element-1cb37f7 .text-wrapper p,
.elementor-11886 .elementor-element.elementor-element-c9f8bba .text-wrapper p,
.elementor-11886 .elementor-element.elementor-element-bf684ed .text-wrapper p,
.elementor-11886 .elementor-element.elementor-element-6a59243 .text-wrapper p,
.elementor-11886 .elementor-element.elementor-element-0131b5a .text-wrapper p {
    max-width: 30ch;
    margin-left: auto;
    margin-right: auto;
    word-spacing: normal !important;
    text-wrap: balance;
}

.elementor-6175 .elementor-element.elementor-element-ed1d227 {
    max-width: calc(100vw - (var(--mm-page-gutter) * 2)) !important;
    min-width: 0;
    width: 100% !important;
}

.elementor-6175 .elementor-element.elementor-element-ed1d227 .text-wrapper,
.elementor-6175 .elementor-element.elementor-element-ed1d227 .text-wrapper p {
    max-width: 100%;
    width: 100%;
}

.elementor-6175 .elementor-element.elementor-element-ed1d227 .text-wrapper p,
.elementor-6175 .elementor-element.elementor-element-ed1d227 .text-wrapper > * {
    font-family: var(--mm-display-font) !important;
    font-size: clamp(58px, 12vw, 220px) !important;
    line-height: .92;
    white-space: nowrap;
    word-break: keep-all;
    overflow-wrap: normal;
    hyphens: none;
}

@media only screen and (max-width: 1024px) {
    :root {
        --mm-page-gutter: clamp(18px, 4vw, 34px);
        --mm-copy-size: clamp(15px, 1.55vw, 17px);
        --mm-copy-leading: 1.66;
        --mm-copy-block-size: clamp(15px, 1.75vw, 18px);
        --mm-copy-block-leading: 1.58;
    }

    h1,
    .text-h1 {
        font-size: clamp(48px, 9.6vw, 104px);
    }

    h2,
    .text-h2 {
        font-size: clamp(38px, 7.3vw, 76px);
    }

    h3,
    .text-h3 {
        font-size: clamp(30px, 5.5vw, 58px);
    }

    .elementor-11886 .elementor-element.elementor-element-00e1cfb {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media only screen and (max-width: 767px) {
    :root {
        --mm-page-gutter: clamp(16px, 5vw, 24px);
        --mm-section-space: clamp(58px, 16vw, 100px);
        --mm-copy-size: clamp(15px, 4vw, 17px);
        --mm-copy-leading: 1.62;
        --mm-copy-block-size: clamp(14px, 4vw, 16px);
        --mm-copy-block-leading: 1.56;
    }

    h1,
    .text-h1 {
        font-size: clamp(42px, 14vw, 74px);
        line-height: .98;
    }

    h2,
    .text-h2 {
        font-size: clamp(34px, 11vw, 58px);
    }

    h3,
    .text-h3 {
        font-size: clamp(28px, 8vw, 44px);
    }

    h4,
    .text-h4 {
        font-size: clamp(24px, 6.5vw, 34px);
    }

    .p-large {
        font-size: clamp(16px, 4.5vw, 19px);
    }

    .p-small {
        font-size: clamp(13px, 3.8vw, 15px);
    }

    .elementor-11886 .elementor-element.elementor-element-00e1cfb {
        grid-template-columns: 1fr;
        padding-left: var(--mm-page-gutter) !important;
        padding-right: var(--mm-page-gutter) !important;
    }

    .elementor-11886 .elementor-element.elementor-element-1cb37f7,
    .elementor-11886 .elementor-element.elementor-element-c9f8bba,
    .elementor-11886 .elementor-element.elementor-element-bf684ed,
    .elementor-11886 .elementor-element.elementor-element-6a59243,
    .elementor-11886 .elementor-element.elementor-element-0131b5a {
        min-width: 100%;
    }

    .elementor-11886 .elementor-element.elementor-element-1cb37f7 .text-wrapper p,
    .elementor-11886 .elementor-element.elementor-element-c9f8bba .text-wrapper p,
    .elementor-11886 .elementor-element.elementor-element-bf684ed .text-wrapper p,
    .elementor-11886 .elementor-element.elementor-element-6a59243 .text-wrapper p,
    .elementor-11886 .elementor-element.elementor-element-0131b5a .text-wrapper p {
        max-width: 100%;
    }

    .elementor-6175 .elementor-element.elementor-element-ed1d227 {
        max-width: calc(100vw - 32px) !important;
        width: 100% !important;
    }

    .elementor-6175 .elementor-element.elementor-element-ed1d227 .text-wrapper p,
    .elementor-6175 .elementor-element.elementor-element-ed1d227 .text-wrapper > * {
        font-size: clamp(34px, 10.2vw, 54px) !important;
        line-height: .95;
    }
}

/*
 * Voucher Cloud & Cybersecurity page.
 * The Elementor template uses these classes only for this landing page.
 */
.mm-voucher-page {
    --mm-voucher-paper: #ebebeb;
    --mm-voucher-ink: #101010;
    --mm-voucher-muted: #787878;
    --mm-voucher-dark: #151515;
    --mm-voucher-line: rgba(16, 16, 16, .14);
    --mm-voucher-gutter: clamp(18px, 4vw, 56px);
    background: var(--mm-voucher-paper);
    color: var(--mm-voucher-ink);
    font-family: var(--mm-code-font) !important;
    overflow: hidden;
}

.mm-voucher-page *,
.mm-voucher-page *::before,
.mm-voucher-page *::after {
    hyphens: none !important;
    word-break: normal !important;
    overflow-wrap: normal !important;
}

.mm-voucher-page .elementor-heading-title,
.mm-voucher-page h1,
.mm-voucher-page h2,
.mm-voucher-page h3 {
    color: var(--mm-voucher-ink) !important;
    font-family: var(--mm-display-font) !important;
    font-weight: 400 !important;
    letter-spacing: 0 !important;
    line-height: 1 !important;
}

.mm-voucher-page p {
    color: var(--mm-voucher-muted) !important;
    font-family: var(--mm-code-font) !important;
    font-size: clamp(16px, 1.15vw, 20px);
    line-height: 1.62;
    text-align: justify;
    text-align-last: left;
}

.mm-voucher-section {
    padding: clamp(72px, 9vw, 160px) var(--mm-voucher-gutter) !important;
}

.mm-voucher-hero {
    min-height: calc(100svh - 86px);
    padding: clamp(38px, 6vw, 98px) var(--mm-voucher-gutter) clamp(54px, 7vw, 120px) !important;
    justify-content: center !important;
    gap: clamp(18px, 2.2vw, 30px) !important;
}

.mm-voucher-hero h1,
.mm-voucher-hero .elementor-heading-title {
    max-width: 11.4ch;
    font-size: clamp(58px, 10vw, 168px) !important;
}

.mm-voucher-page h2,
.mm-voucher-page .mm-voucher-section > .elementor-widget-heading .elementor-heading-title {
    font-size: clamp(42px, 6.8vw, 112px) !important;
}

.mm-voucher-page h3,
.mm-voucher-page .mm-card .elementor-widget-heading:not(.mm-eyebrow) .elementor-heading-title,
.mm-voucher-page .mm-step .elementor-widget-heading:not(.mm-step-num) .elementor-heading-title {
    font-size: clamp(26px, 2.6vw, 42px) !important;
    line-height: 1.08 !important;
}

.mm-voucher-page .mm-eyebrow .elementor-heading-title,
.mm-voucher-page .mm-eyebrow {
    color: var(--mm-voucher-muted) !important;
    font-family: var(--mm-code-font) !important;
    font-size: clamp(13px, 1.1vw, 17px) !important;
    line-height: 1.35 !important;
    text-transform: uppercase;
}

.mm-voucher-page .mm-lead p {
    max-width: 66ch;
    color: #5f5f5f !important;
    font-size: clamp(18px, 1.45vw, 26px) !important;
}

.mm-voucher-page .mm-rounded img {
    width: 100%;
    border-radius: clamp(28px, 4vw, 64px);
    aspect-ratio: 16 / 9;
    object-fit: cover;
}

.mm-voucher-page .mm-button .elementor-button {
    min-height: 46px;
    border-radius: 999px !important;
    background: var(--mm-voucher-dark) !important;
    color: #f5f5f5 !important;
    padding: .9em 1.35em !important;
    font-family: var(--mm-code-font) !important;
    font-size: clamp(14px, 1vw, 16px) !important;
    line-height: 1 !important;
    white-space: nowrap;
}

.mm-voucher-page .mm-button .elementor-button:hover {
    background: #000 !important;
}

.mm-stats {
    display: grid !important;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1px !important;
    margin: 0 var(--mm-voucher-gutter) !important;
    background: var(--mm-voucher-line);
    border-top: 1px solid var(--mm-voucher-line);
    border-bottom: 1px solid var(--mm-voucher-line);
}

.mm-stats > .e-con,
.mm-stat {
    width: auto !important;
    min-width: 0 !important;
}

.mm-stat {
    min-height: 150px;
    padding: clamp(22px, 2.5vw, 42px) !important;
    background: var(--mm-voucher-paper);
    justify-content: space-between !important;
}

.mm-stat-value .elementor-heading-title {
    font-size: clamp(34px, 4vw, 78px) !important;
    line-height: .95 !important;
}

.mm-stat-label p {
    color: var(--mm-voucher-muted) !important;
    font-size: clamp(13px, .95vw, 16px) !important;
    text-align: left !important;
}

.mm-head {
    display: grid !important;
    grid-template-columns: minmax(0, .9fr) minmax(300px, .8fr);
    gap: clamp(30px, 6vw, 96px) !important;
    align-items: end !important;
    margin-bottom: clamp(36px, 5vw, 78px) !important;
}

.mm-card-grid {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: clamp(16px, 2vw, 28px) !important;
}

.mm-card-grid > .e-con,
.mm-card {
    width: auto !important;
    min-width: 0 !important;
}

.mm-card {
    min-height: 320px;
    padding: clamp(24px, 2.7vw, 46px) !important;
    border: 1px solid var(--mm-voucher-line);
    border-radius: 8px;
    background: rgba(255, 255, 255, .18);
    justify-content: space-between !important;
}

.mm-card p {
    font-size: clamp(14px, 1vw, 17px) !important;
}

.mm-split {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) minmax(320px, .9fr);
    gap: clamp(34px, 6vw, 98px) !important;
    align-items: center !important;
}

.mm-split > .e-con,
.mm-split > .elementor-widget {
    width: auto !important;
    min-width: 0 !important;
}

.mm-split-img img {
    width: 100%;
    border-radius: clamp(22px, 3vw, 44px);
    aspect-ratio: 16 / 10;
    object-fit: cover;
}

.mm-dark {
    background: var(--mm-voucher-dark);
    color: #f1f1f1;
}

.mm-dark .elementor-heading-title {
    color: #f1f1f1 !important;
}

.mm-dark p,
.mm-dark .mm-eyebrow,
.mm-dark .mm-eyebrow .elementor-heading-title {
    color: #a8a8a8 !important;
}

.mm-dark .mm-card {
    background: #191919;
    border-color: rgba(255, 255, 255, .12);
}

.mm-steps {
    gap: 1px !important;
    background: rgba(255, 255, 255, .13);
    border-top: 1px solid rgba(255, 255, 255, .13);
    border-bottom: 1px solid rgba(255, 255, 255, .13);
}

.mm-step {
    display: grid !important;
    grid-template-columns: 100px minmax(0, 1fr) minmax(280px, .7fr);
    gap: clamp(20px, 3vw, 48px) !important;
    align-items: start !important;
    padding: clamp(26px, 3vw, 44px) 0 !important;
    background: var(--mm-voucher-dark);
}

.mm-step > .elementor-widget {
    width: auto !important;
    min-width: 0 !important;
}

.mm-step-num .elementor-heading-title {
    color: #f1f1f1 !important;
    font-family: var(--mm-code-font) !important;
    font-size: clamp(22px, 2vw, 32px) !important;
}

.mm-cta {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 24px !important;
    align-items: center !important;
    margin: 0 var(--mm-voucher-gutter) !important;
    padding: clamp(34px, 5vw, 70px) !important;
    border-radius: clamp(24px, 4vw, 54px);
    background: #dcdcdc;
}

.mm-cta h2,
.mm-cta .elementor-heading-title {
    max-width: 11ch;
    font-size: clamp(38px, 6vw, 96px) !important;
}

.mm-faq {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: clamp(18px, 2vw, 28px) !important;
}

.mm-faq > .e-con {
    width: auto !important;
    min-width: 0 !important;
}

.mm-source p {
    color: var(--mm-voucher-muted) !important;
    font-size: 13px !important;
    text-align: left !important;
}

@media only screen and (max-width: 1024px) {
    .mm-stats,
    .mm-card-grid,
    .mm-faq {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .mm-head,
    .mm-split {
        grid-template-columns: 1fr;
    }

    .mm-step {
        grid-template-columns: 70px minmax(0, 1fr);
    }

    .mm-step .elementor-widget-text-editor {
        grid-column: 2;
    }
}

@media only screen and (max-width: 680px) {
    .mm-voucher-hero {
        min-height: auto;
    }

    .mm-voucher-hero h1,
    .mm-voucher-hero .elementor-heading-title {
        font-size: clamp(46px, 15vw, 76px) !important;
    }

    .mm-voucher-page p,
    .mm-voucher-page .mm-lead p {
        text-align: left;
    }

    .mm-stats,
    .mm-card-grid,
    .mm-faq,
    .mm-step,
    .mm-cta {
        grid-template-columns: 1fr;
    }

    .mm-step .elementor-widget-text-editor {
        grid-column: auto;
    }

    .mm-card {
        min-height: auto;
    }
}

/* Elementor prints boxed containers with an inner wrapper; keep the Voucher layout tied to that real DOM. */
.mm-voucher-page > .e-con-inner,
.mm-voucher-hero > .e-con-inner,
.mm-voucher-section > .e-con-inner,
.mm-dark > .e-con-inner {
    width: min(100%, 1280px) !important;
    max-width: none !important;
    margin-inline: auto !important;
}

.mm-voucher-hero > .e-con-inner {
    display: flex !important;
    flex-direction: column !important;
    gap: clamp(18px, 2.2vw, 30px) !important;
}

.mm-head > .e-con-inner {
    display: grid !important;
    grid-template-columns: minmax(0, .9fr) minmax(300px, .8fr) !important;
    gap: clamp(30px, 6vw, 96px) !important;
    align-items: end !important;
}

.mm-stats {
    display: block !important;
}

.mm-stats > .e-con-inner {
    display: grid !important;
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    gap: 1px !important;
    width: min(100%, 1280px) !important;
    max-width: none !important;
    margin-inline: auto !important;
    background: var(--mm-voucher-line) !important;
}

.mm-card-grid > .e-con-inner,
.mm-faq > .e-con-inner {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: clamp(16px, 2vw, 28px) !important;
    width: 100% !important;
    max-width: none !important;
}

.mm-faq > .e-con-inner {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
}

.mm-split > .e-con-inner {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) minmax(320px, .9fr) !important;
    gap: clamp(34px, 6vw, 98px) !important;
    align-items: center !important;
    width: 100% !important;
    max-width: none !important;
}

.mm-steps > .e-con-inner {
    display: grid !important;
    gap: 1px !important;
    width: 100% !important;
    max-width: none !important;
}

.mm-cta > .e-con-inner {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) auto !important;
    gap: 24px !important;
    align-items: center !important;
    width: 100% !important;
    max-width: none !important;
}

.mm-voucher-page .elementor-widget-button .elementor-button {
    min-height: 46px;
    border-radius: 999px !important;
    background: var(--mm-voucher-dark) !important;
    color: #f5f5f5 !important;
    padding: .9em 1.35em !important;
    font-family: var(--mm-code-font) !important;
    font-size: clamp(14px, 1vw, 16px) !important;
    line-height: 1 !important;
    white-space: nowrap;
}

@media only screen and (max-width: 1024px) {
    .mm-head > .e-con-inner,
    .mm-split > .e-con-inner {
        grid-template-columns: 1fr !important;
    }

    .mm-stats > .e-con-inner,
    .mm-card-grid > .e-con-inner,
    .mm-faq > .e-con-inner {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }
}

@media only screen and (max-width: 680px) {
    .mm-stats > .e-con-inner,
    .mm-card-grid > .e-con-inner,
    .mm-faq > .e-con-inner,
    .mm-cta > .e-con-inner {
        grid-template-columns: 1fr !important;
    }
}

/*
 * Voucher live fallback.
 * Elementor 4 kept custom classes on widgets but dropped them from containers on the imported live page.
 * These selectors target the current page structure so the landing can render correctly without another re-import.
 */
.elementor-13050 {
    --mm-voucher-paper: #ebebeb;
    --mm-voucher-ink: #101010;
    --mm-voucher-muted: #787878;
    --mm-voucher-dark: #151515;
    --mm-voucher-line: rgba(16, 16, 16, .14);
    --mm-voucher-gutter: clamp(18px, 4vw, 56px);
    background: var(--mm-voucher-paper);
    color: var(--mm-voucher-ink);
    font-family: var(--mm-code-font) !important;
    overflow: hidden;
}

.elementor-13050 *,
.elementor-13050 *::before,
.elementor-13050 *::after {
    hyphens: none !important;
    word-break: normal !important;
    overflow-wrap: normal !important;
}

.elementor-13050 .elementor-heading-title,
.elementor-13050 h1,
.elementor-13050 h2,
.elementor-13050 h3 {
    color: var(--mm-voucher-ink) !important;
    font-family: var(--mm-display-font) !important;
    font-weight: 400 !important;
    letter-spacing: 0 !important;
    line-height: 1 !important;
}

.elementor-13050 p {
    color: var(--mm-voucher-muted) !important;
    font-family: var(--mm-code-font) !important;
    font-size: clamp(16px, 1.15vw, 20px) !important;
    line-height: 1.62 !important;
    text-align: justify;
    text-align-last: left;
}

.elementor-13050 .elementor-element-3623a616 > .e-con-inner {
    width: 100% !important;
    max-width: none !important;
}

.elementor-13050 .elementor-element-1a740401,
.elementor-13050 .elementor-element-7cbd4916,
.elementor-13050 .elementor-element-3b5a4de6,
.elementor-13050 .elementor-element-3b397cd8,
.elementor-13050 .elementor-element-3ec7219d,
.elementor-13050 .elementor-element-69038150,
.elementor-13050 .elementor-element-7d33b0d7 {
    padding: clamp(72px, 9vw, 160px) var(--mm-voucher-gutter) !important;
}

.elementor-13050 .elementor-element-1a740401 > .e-con-inner,
.elementor-13050 .elementor-element-7cbd4916 > .e-con-inner,
.elementor-13050 .elementor-element-3b5a4de6 > .e-con-inner,
.elementor-13050 .elementor-element-3b397cd8 > .e-con-inner,
.elementor-13050 .elementor-element-3ec7219d > .e-con-inner,
.elementor-13050 .elementor-element-69038150 > .e-con-inner,
.elementor-13050 .elementor-element-7d33b0d7 > .e-con-inner {
    width: min(100%, 1280px) !important;
    max-width: none !important;
    margin-inline: auto !important;
}

.elementor-13050 .elementor-element-1a740401 {
    min-height: calc(100svh - 86px);
    justify-content: center !important;
}

.elementor-13050 .elementor-element-1a740401 > .e-con-inner {
    display: flex !important;
    flex-direction: column !important;
    gap: clamp(18px, 2.2vw, 30px) !important;
}

.elementor-13050 .elementor-element-1a740401 h1 {
    max-width: 11.4ch;
    font-size: clamp(58px, 10vw, 168px) !important;
}

.elementor-13050 .mm-eyebrow .elementor-heading-title,
.elementor-13050 .mm-eyebrow {
    color: var(--mm-voucher-muted) !important;
    font-family: var(--mm-code-font) !important;
    font-size: clamp(13px, 1.1vw, 17px) !important;
    line-height: 1.35 !important;
    text-transform: uppercase;
}

.elementor-13050 .mm-lead p {
    max-width: 66ch;
    color: #5f5f5f !important;
    font-size: clamp(18px, 1.45vw, 26px) !important;
}

.elementor-13050 .mm-rounded img {
    width: 100%;
    border-radius: clamp(28px, 4vw, 64px);
    aspect-ratio: 16 / 9;
    object-fit: cover;
}

.elementor-13050 .elementor-widget-button .elementor-button {
    min-height: 46px;
    border-radius: 999px !important;
    background: var(--mm-voucher-dark) !important;
    color: #f5f5f5 !important;
    padding: .9em 1.35em !important;
    font-family: var(--mm-code-font) !important;
    font-size: clamp(14px, 1vw, 16px) !important;
    line-height: 1 !important;
    white-space: nowrap;
}

.elementor-13050 .elementor-element-398d6632 {
    display: block !important;
    margin: 0 var(--mm-voucher-gutter) !important;
    background: var(--mm-voucher-line);
    border-top: 1px solid var(--mm-voucher-line);
    border-bottom: 1px solid var(--mm-voucher-line);
}

.elementor-13050 .elementor-element-398d6632 > .e-con-inner {
    display: grid !important;
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    gap: 1px !important;
    width: min(100%, 1280px) !important;
    max-width: none !important;
    margin-inline: auto !important;
}

.elementor-13050 .elementor-element-398d6632 > .e-con-inner > .e-con {
    width: auto !important;
    min-width: 0 !important;
    min-height: 150px;
    padding: clamp(22px, 2.5vw, 42px) !important;
    background: var(--mm-voucher-paper);
    justify-content: space-between !important;
}

.elementor-13050 .mm-stat-value .elementor-heading-title {
    font-size: clamp(34px, 4vw, 78px) !important;
    line-height: .95 !important;
}

.elementor-13050 .mm-stat-label p {
    color: var(--mm-voucher-muted) !important;
    font-size: clamp(13px, .95vw, 16px) !important;
    text-align: left !important;
}

.elementor-13050 .elementor-element-78a5b188 > .e-con-inner,
.elementor-13050 .elementor-element-75062b16 > .e-con-inner,
.elementor-13050 .elementor-element-312b599a > .e-con-inner,
.elementor-13050 .elementor-element-28bbad31 > .e-con-inner {
    display: grid !important;
    grid-template-columns: minmax(0, .9fr) minmax(300px, .8fr) !important;
    gap: clamp(30px, 6vw, 96px) !important;
    align-items: end !important;
    margin-bottom: clamp(36px, 5vw, 78px) !important;
    width: 100% !important;
    max-width: none !important;
}

.elementor-13050 .elementor-element-3278a7d > .e-con-inner,
.elementor-13050 .elementor-element-42dbca07 > .e-con-inner {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: clamp(16px, 2vw, 28px) !important;
    width: 100% !important;
    max-width: none !important;
}

.elementor-13050 .elementor-element-3278a7d > .e-con-inner > .e-con,
.elementor-13050 .elementor-element-42dbca07 > .e-con-inner > .e-con,
.elementor-13050 .elementor-element-5cac371e > .e-con-inner > .e-con {
    width: auto !important;
    min-width: 0 !important;
    min-height: 320px;
    padding: clamp(24px, 2.7vw, 46px) !important;
    border: 1px solid var(--mm-voucher-line);
    border-radius: 8px;
    background: rgba(255, 255, 255, .18);
    justify-content: space-between !important;
}

.elementor-13050 .elementor-element-7a2a8442 > .e-con-inner,
.elementor-13050 .elementor-element-644733f5 > .e-con-inner {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) minmax(320px, .9fr) !important;
    gap: clamp(34px, 6vw, 98px) !important;
    align-items: center !important;
    width: 100% !important;
    max-width: none !important;
}

.elementor-13050 .mm-split-img img {
    width: 100%;
    border-radius: clamp(22px, 3vw, 44px);
    aspect-ratio: 16 / 10;
    object-fit: cover;
}

.elementor-13050 .elementor-element-3b5a4de6,
.elementor-13050 .elementor-element-3ec7219d {
    background: var(--mm-voucher-dark);
    color: #f1f1f1;
}

.elementor-13050 .elementor-element-3b5a4de6 .elementor-heading-title,
.elementor-13050 .elementor-element-3ec7219d .elementor-heading-title {
    color: #f1f1f1 !important;
}

.elementor-13050 .elementor-element-3b5a4de6 p,
.elementor-13050 .elementor-element-3ec7219d p,
.elementor-13050 .elementor-element-3b5a4de6 .mm-eyebrow .elementor-heading-title,
.elementor-13050 .elementor-element-3ec7219d .mm-eyebrow .elementor-heading-title {
    color: #a8a8a8 !important;
}

.elementor-13050 .elementor-element-7810054 > .e-con-inner {
    display: grid !important;
    gap: 1px !important;
    width: 100% !important;
    max-width: none !important;
    background: rgba(255, 255, 255, .13);
    border-top: 1px solid rgba(255, 255, 255, .13);
    border-bottom: 1px solid rgba(255, 255, 255, .13);
}

.elementor-13050 .elementor-element-7810054 > .e-con-inner > .e-con {
    display: grid !important;
    grid-template-columns: 100px minmax(0, 1fr) minmax(280px, .7fr);
    gap: clamp(20px, 3vw, 48px) !important;
    align-items: start !important;
    padding: clamp(26px, 3vw, 44px) 0 !important;
    background: var(--mm-voucher-dark);
    width: auto !important;
    min-width: 0 !important;
}

.elementor-13050 .mm-step-num .elementor-heading-title {
    color: #f1f1f1 !important;
    font-family: var(--mm-code-font) !important;
    font-size: clamp(22px, 2vw, 32px) !important;
}

.elementor-13050 .elementor-element-7730c3ed > .e-con-inner {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) auto !important;
    gap: 24px !important;
    align-items: center !important;
    width: 100% !important;
    max-width: none !important;
}

.elementor-13050 .elementor-element-7730c3ed {
    padding: clamp(34px, 5vw, 70px) !important;
    border-radius: clamp(24px, 4vw, 54px);
    background: #dcdcdc;
}

.elementor-13050 .elementor-element-5cac371e > .e-con-inner {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: clamp(18px, 2vw, 28px) !important;
    width: 100% !important;
    max-width: none !important;
}

.elementor-13050 .mm-source p {
    color: var(--mm-voucher-muted) !important;
    font-size: 13px !important;
    text-align: left !important;
}

@media only screen and (max-width: 1024px) {
    .elementor-13050 .elementor-element-78a5b188 > .e-con-inner,
    .elementor-13050 .elementor-element-75062b16 > .e-con-inner,
    .elementor-13050 .elementor-element-312b599a > .e-con-inner,
    .elementor-13050 .elementor-element-28bbad31 > .e-con-inner,
    .elementor-13050 .elementor-element-7a2a8442 > .e-con-inner,
    .elementor-13050 .elementor-element-644733f5 > .e-con-inner {
        grid-template-columns: 1fr !important;
    }

    .elementor-13050 .elementor-element-398d6632 > .e-con-inner,
    .elementor-13050 .elementor-element-3278a7d > .e-con-inner,
    .elementor-13050 .elementor-element-42dbca07 > .e-con-inner,
    .elementor-13050 .elementor-element-5cac371e > .e-con-inner {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }

    .elementor-13050 .elementor-element-7810054 > .e-con-inner > .e-con {
        grid-template-columns: 70px minmax(0, 1fr);
    }

    .elementor-13050 .elementor-element-7810054 > .e-con-inner > .e-con .elementor-widget-text-editor {
        grid-column: 2;
    }
}

@media only screen and (max-width: 680px) {
    .elementor-13050 .elementor-element-1a740401 {
        min-height: auto;
    }

    .elementor-13050 .elementor-element-1a740401 h1 {
        font-size: clamp(46px, 15vw, 76px) !important;
    }

    .elementor-13050 p,
    .elementor-13050 .mm-lead p {
        text-align: left;
    }

    .elementor-13050 .elementor-element-398d6632 > .e-con-inner,
    .elementor-13050 .elementor-element-3278a7d > .e-con-inner,
    .elementor-13050 .elementor-element-42dbca07 > .e-con-inner,
    .elementor-13050 .elementor-element-5cac371e > .e-con-inner,
    .elementor-13050 .elementor-element-7810054 > .e-con-inner > .e-con,
    .elementor-13050 .elementor-element-7730c3ed > .e-con-inner {
        grid-template-columns: 1fr !important;
    }

    .elementor-13050 .elementor-element-3278a7d > .e-con-inner > .e-con,
    .elementor-13050 .elementor-element-42dbca07 > .e-con-inner > .e-con,
    .elementor-13050 .elementor-element-5cac371e > .e-con-inner > .e-con {
        min-height: auto;
    }

    .elementor-13050 .elementor-element-7810054 > .e-con-inner > .e-con .elementor-widget-text-editor {
        grid-column: auto;
    }
}

/*
 * Voucher live tuning.
 * Softer proportions after the emergency fallback above: smaller headings, no justified mono text,
 * earlier single-column layout, and no cramped step/card grids.
 */
.elementor-13050 .elementor-element-1a740401 {
    min-height: auto !important;
    padding-top: clamp(124px, 10vw, 170px) !important;
    padding-bottom: clamp(42px, 6vw, 86px) !important;
}

.elementor-13050 p {
    text-align: left !important;
    text-align-last: left !important;
    font-size: clamp(15px, 1vw, 18px) !important;
    line-height: 1.58 !important;
}

.elementor-13050 .elementor-heading-title {
    font-size: clamp(24px, 3.2vw, 52px) !important;
    line-height: 1.08 !important;
}

.elementor-13050 .elementor-element-1a740401 h1 {
    max-width: 12.5ch;
    font-size: clamp(50px, 8.4vw, 118px) !important;
    line-height: .98 !important;
}

.elementor-13050 .elementor-element-5aef6f18 .elementor-heading-title,
.elementor-13050 .elementor-element-68e41a8 .elementor-heading-title,
.elementor-13050 .elementor-element-5f760df8 .elementor-heading-title,
.elementor-13050 .elementor-element-670715ce .elementor-heading-title,
.elementor-13050 .elementor-element-642ba4bc .elementor-heading-title,
.elementor-13050 .elementor-element-6c1313d7 .elementor-heading-title {
    font-size: clamp(34px, 4.5vw, 72px) !important;
    line-height: 1.02 !important;
}

.elementor-13050 .elementor-element-383559f9 .elementor-heading-title,
.elementor-13050 .elementor-element-305e41ba .elementor-heading-title,
.elementor-13050 .elementor-element-52076c6a .elementor-heading-title,
.elementor-13050 .elementor-element-42d1caa6 .elementor-heading-title,
.elementor-13050 .elementor-element-5431baf2 .elementor-heading-title,
.elementor-13050 .elementor-element-6b4b17c7 .elementor-heading-title,
.elementor-13050 .elementor-element-18bbaa0b .elementor-heading-title,
.elementor-13050 .elementor-element-598f5413 .elementor-heading-title,
.elementor-13050 .elementor-element-362fa467 .elementor-heading-title,
.elementor-13050 .elementor-element-3f64e351 .elementor-heading-title,
.elementor-13050 .elementor-element-2e19613e .elementor-heading-title,
.elementor-13050 .elementor-element-5fda0d51 .elementor-heading-title,
.elementor-13050 .elementor-element-27605bf4 .elementor-heading-title,
.elementor-13050 .elementor-element-733d7fa7 .elementor-heading-title,
.elementor-13050 .elementor-element-7ca93a0b .elementor-heading-title {
    font-size: clamp(24px, 2.45vw, 36px) !important;
    line-height: 1.12 !important;
}

.elementor-13050 .mm-eyebrow .elementor-heading-title,
.elementor-13050 .mm-eyebrow {
    font-size: clamp(12px, .92vw, 15px) !important;
    line-height: 1.35 !important;
}

.elementor-13050 .mm-stat-value .elementor-heading-title {
    font-size: clamp(30px, 3vw, 56px) !important;
}

.elementor-13050 .mm-step-num .elementor-heading-title {
    font-size: clamp(18px, 1.5vw, 26px) !important;
}

.elementor-13050 .elementor-element-3278a7d > .e-con-inner > .e-con,
.elementor-13050 .elementor-element-42dbca07 > .e-con-inner > .e-con,
.elementor-13050 .elementor-element-5cac371e > .e-con-inner > .e-con {
    min-height: auto !important;
}

@media only screen and (max-width: 1100px) {
    .elementor-13050 .elementor-element-1a740401,
    .elementor-13050 .elementor-element-7cbd4916,
    .elementor-13050 .elementor-element-3b5a4de6,
    .elementor-13050 .elementor-element-3b397cd8,
    .elementor-13050 .elementor-element-3ec7219d,
    .elementor-13050 .elementor-element-69038150,
    .elementor-13050 .elementor-element-7d33b0d7 {
        padding-left: clamp(24px, 5vw, 44px) !important;
        padding-right: clamp(24px, 5vw, 44px) !important;
    }

    .elementor-13050 .elementor-element-3278a7d > .e-con-inner,
    .elementor-13050 .elementor-element-42dbca07 > .e-con-inner,
    .elementor-13050 .elementor-element-5cac371e > .e-con-inner {
        grid-template-columns: 1fr !important;
    }

    .elementor-13050 .elementor-element-398d6632 > .e-con-inner {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }

    .elementor-13050 .elementor-element-7810054 > .e-con-inner > .e-con {
        display: block !important;
        padding: clamp(26px, 5vw, 42px) !important;
    }

    .elementor-13050 .elementor-element-7810054 > .e-con-inner > .e-con .elementor-widget {
        width: 100% !important;
    }
}

@media only screen and (max-width: 760px) {
    .elementor-13050 .elementor-element-1a740401 {
        padding-top: 116px !important;
    }

    .elementor-13050 .elementor-element-1a740401 h1 {
        font-size: clamp(44px, 13vw, 66px) !important;
    }

    .elementor-13050 .elementor-element-5aef6f18 .elementor-heading-title,
    .elementor-13050 .elementor-element-68e41a8 .elementor-heading-title,
    .elementor-13050 .elementor-element-5f760df8 .elementor-heading-title,
    .elementor-13050 .elementor-element-670715ce .elementor-heading-title,
    .elementor-13050 .elementor-element-642ba4bc .elementor-heading-title,
    .elementor-13050 .elementor-element-6c1313d7 .elementor-heading-title {
        font-size: clamp(32px, 9vw, 46px) !important;
    }

    .elementor-13050 .elementor-element-398d6632 > .e-con-inner {
        grid-template-columns: 1fr !important;
    }

    .elementor-13050 .elementor-element-398d6632 {
        margin-inline: clamp(18px, 5vw, 28px) !important;
    }
}

/*
 * Voucher final stabilizer.
 * Keep the page tied to Leksa's layout switcher and use calmer type scales.
 */
.elementor-13050 {
    --mm-voucher-paper: var(--mainBackground, #ebebeb);
    --mm-voucher-ink: var(--mainColor, #101010);
    --mm-voucher-muted: #787878;
    --mm-voucher-muted: color-mix(in srgb, var(--mainColor, #101010) 56%, var(--mainBackground, #ebebeb));
    --mm-voucher-dark: var(--mainColor, #151515);
    --mm-voucher-line: rgba(16, 16, 16, .14);
    --mm-voucher-line: color-mix(in srgb, var(--mainColor, #101010) 14%, transparent);
    background: var(--mm-voucher-paper) !important;
    color: var(--mm-voucher-ink) !important;
}

.elementor-13050 .elementor-heading-title {
    color: var(--mm-voucher-ink) !important;
    font-size: clamp(22px, 2.55vw, 42px) !important;
    line-height: 1.12 !important;
}

.elementor-13050 .elementor-element-1a740401 {
    padding-top: clamp(148px, 11vw, 188px) !important;
    padding-bottom: clamp(42px, 6vw, 76px) !important;
}

.elementor-13050 .elementor-element-1a740401 h1 {
    max-width: 13ch;
    font-size: clamp(46px, 7.2vw, 96px) !important;
    line-height: 1 !important;
}

.elementor-13050 .elementor-element-5aef6f18 .elementor-heading-title,
.elementor-13050 .elementor-element-68e41a8 .elementor-heading-title,
.elementor-13050 .elementor-element-5f760df8 .elementor-heading-title,
.elementor-13050 .elementor-element-670715ce .elementor-heading-title,
.elementor-13050 .elementor-element-642ba4bc .elementor-heading-title,
.elementor-13050 .elementor-element-6c1313d7 .elementor-heading-title {
    font-size: clamp(30px, 3.7vw, 56px) !important;
    line-height: 1.06 !important;
}

.elementor-13050 .elementor-element-383559f9 .elementor-heading-title,
.elementor-13050 .elementor-element-305e41ba .elementor-heading-title,
.elementor-13050 .elementor-element-52076c6a .elementor-heading-title,
.elementor-13050 .elementor-element-42d1caa6 .elementor-heading-title,
.elementor-13050 .elementor-element-5431baf2 .elementor-heading-title,
.elementor-13050 .elementor-element-6b4b17c7 .elementor-heading-title,
.elementor-13050 .elementor-element-18bbaa0b .elementor-heading-title,
.elementor-13050 .elementor-element-598f5413 .elementor-heading-title,
.elementor-13050 .elementor-element-362fa467 .elementor-heading-title,
.elementor-13050 .elementor-element-3f64e351 .elementor-heading-title,
.elementor-13050 .elementor-element-2e19613e .elementor-heading-title,
.elementor-13050 .elementor-element-5fda0d51 .elementor-heading-title,
.elementor-13050 .elementor-element-27605bf4 .elementor-heading-title,
.elementor-13050 .elementor-element-733d7fa7 .elementor-heading-title,
.elementor-13050 .elementor-element-7ca93a0b .elementor-heading-title {
    font-size: clamp(22px, 2vw, 30px) !important;
    line-height: 1.16 !important;
}

.elementor-13050 p,
.elementor-13050 .mm-lead p {
    color: var(--mm-voucher-muted) !important;
    text-align: left !important;
    text-align-last: left !important;
}

.elementor-13050 .mm-lead p {
    font-size: clamp(16px, 1.25vw, 21px) !important;
}

.elementor-13050 .elementor-widget-button .elementor-button {
    background: var(--mm-voucher-ink) !important;
    color: var(--mm-voucher-paper) !important;
}

.elementor-13050 .elementor-element-398d6632 > .e-con-inner > .e-con,
.elementor-13050 .elementor-element-3278a7d > .e-con-inner > .e-con,
.elementor-13050 .elementor-element-42dbca07 > .e-con-inner > .e-con,
.elementor-13050 .elementor-element-5cac371e > .e-con-inner > .e-con {
    background: var(--mm-voucher-paper) !important;
    border-color: var(--mm-voucher-line) !important;
}

.elementor-13050 .elementor-element-3b5a4de6,
.elementor-13050 .elementor-element-3ec7219d {
    background: var(--mm-voucher-ink) !important;
    color: var(--mm-voucher-paper) !important;
}

.elementor-13050 .elementor-element-3b5a4de6 .elementor-heading-title,
.elementor-13050 .elementor-element-3ec7219d .elementor-heading-title,
.elementor-13050 .elementor-element-3b5a4de6 .mm-step-num .elementor-heading-title,
.elementor-13050 .elementor-element-3ec7219d .mm-step-num .elementor-heading-title {
    color: var(--mm-voucher-paper) !important;
}

.elementor-13050 .elementor-element-3b5a4de6 p,
.elementor-13050 .elementor-element-3ec7219d p,
.elementor-13050 .elementor-element-3b5a4de6 .mm-eyebrow .elementor-heading-title,
.elementor-13050 .elementor-element-3ec7219d .mm-eyebrow .elementor-heading-title {
    color: rgba(235, 235, 235, .72) !important;
    color: color-mix(in srgb, var(--mm-voucher-paper) 62%, var(--mm-voucher-ink)) !important;
}

.elementor-13050 .elementor-element-7810054 > .e-con-inner > .e-con {
    background: var(--mm-voucher-ink) !important;
}

.elementor-13050 .elementor-element-7730c3ed {
    background: rgba(16, 16, 16, .06) !important;
    background: color-mix(in srgb, var(--mm-voucher-ink) 10%, var(--mm-voucher-paper)) !important;
}

@media only screen and (max-width: 1180px) {
    .elementor-13050 .elementor-element-78a5b188 > .e-con-inner,
    .elementor-13050 .elementor-element-75062b16 > .e-con-inner,
    .elementor-13050 .elementor-element-312b599a > .e-con-inner,
    .elementor-13050 .elementor-element-28bbad31 > .e-con-inner,
    .elementor-13050 .elementor-element-7a2a8442 > .e-con-inner,
    .elementor-13050 .elementor-element-644733f5 > .e-con-inner,
    .elementor-13050 .elementor-element-7730c3ed > .e-con-inner {
        grid-template-columns: 1fr !important;
    }
}

@media only screen and (max-width: 900px) {
    .elementor-13050 .elementor-element-3278a7d > .e-con-inner,
    .elementor-13050 .elementor-element-42dbca07 > .e-con-inner,
    .elementor-13050 .elementor-element-5cac371e > .e-con-inner,
    .elementor-13050 .elementor-element-398d6632 > .e-con-inner {
        grid-template-columns: 1fr !important;
    }

    .elementor-13050 .elementor-element-1a740401,
    .elementor-13050 .elementor-element-7cbd4916,
    .elementor-13050 .elementor-element-3b5a4de6,
    .elementor-13050 .elementor-element-3b397cd8,
    .elementor-13050 .elementor-element-3ec7219d,
    .elementor-13050 .elementor-element-69038150,
    .elementor-13050 .elementor-element-7d33b0d7 {
        padding-left: clamp(22px, 5vw, 34px) !important;
        padding-right: clamp(22px, 5vw, 34px) !important;
    }
}

@media only screen and (max-width: 560px) {
    .elementor-13050 .elementor-element-1a740401 {
        padding-top: 128px !important;
    }

    .elementor-13050 .elementor-element-1a740401 h1 {
        font-size: clamp(38px, 11vw, 54px) !important;
    }
}

/*
 * Voucher readability hotfix.
 * Prevent Elementor flex columns from squeezing cards into unreadable strips.
 */
.elementor-13050 .elementor-element-644733f5 > .e-con-inner {
    grid-template-columns: minmax(0, 1fr) !important;
    gap: clamp(34px, 5vw, 74px) !important;
}

.elementor-13050 .elementor-element-42dbca07,
.elementor-13050 .elementor-element-42dbca07 > .e-con-inner,
.elementor-13050 .elementor-element-7810054,
.elementor-13050 .elementor-element-7810054 > .e-con-inner {
    width: 100% !important;
    max-width: 1180px !important;
    margin-inline: auto !important;
}

.elementor-13050 .elementor-element-42dbca07 > .e-con-inner,
.elementor-13050 .elementor-element-7810054 > .e-con-inner {
    display: grid !important;
    grid-template-columns: repeat(auto-fit, minmax(min(100%, 280px), 1fr)) !important;
    gap: clamp(18px, 2.4vw, 28px) !important;
    align-items: stretch !important;
}

.elementor-13050 .elementor-element-42dbca07 > .e-con-inner > .e-con,
.elementor-13050 .elementor-element-7810054 > .e-con-inner > .e-con {
    width: 100% !important;
    min-width: 0 !important;
    padding: clamp(24px, 3vw, 38px) !important;
    overflow: hidden !important;
}

.elementor-13050 .elementor-element-42dbca07 > .e-con-inner > .e-con > .elementor-element,
.elementor-13050 .elementor-element-42dbca07 > .e-con-inner > .e-con .elementor-widget,
.elementor-13050 .elementor-element-42dbca07 > .e-con-inner > .e-con .elementor-widget-container,
.elementor-13050 .elementor-element-7810054 > .e-con-inner > .e-con > .elementor-element,
.elementor-13050 .elementor-element-7810054 > .e-con-inner > .e-con .elementor-widget,
.elementor-13050 .elementor-element-7810054 > .e-con-inner > .e-con .elementor-widget-container {
    width: 100% !important;
    max-width: 100% !important;
    flex-basis: auto !important;
    align-self: stretch !important;
    --container-widget-width: 100% !important;
}

.elementor-13050 .elementor-element-42dbca07 .elementor-heading-title,
.elementor-13050 .elementor-element-7810054 .elementor-heading-title {
    overflow-wrap: normal !important;
    word-break: normal !important;
    hyphens: none !important;
}

.elementor-13050 .elementor-element-5431baf2 .elementor-heading-title,
.elementor-13050 .elementor-element-6b4b17c7 .elementor-heading-title,
.elementor-13050 .elementor-element-18bbaa0b .elementor-heading-title,
.elementor-13050 .elementor-element-598f5413 .elementor-heading-title,
.elementor-13050 .elementor-element-362fa467 .elementor-heading-title,
.elementor-13050 .elementor-element-3f64e351 .elementor-heading-title,
.elementor-13050 .elementor-element-2e19613e .elementor-heading-title {
    font-size: clamp(20px, 1.45vw, 26px) !important;
    line-height: 1.18 !important;
}

.elementor-13050 .elementor-element-42dbca07 p,
.elementor-13050 .elementor-element-7810054 p {
    max-width: 100% !important;
    font-size: clamp(15px, 1vw, 18px) !important;
    line-height: 1.55 !important;
    overflow-wrap: normal !important;
    word-break: normal !important;
    hyphens: none !important;
}

.elementor-13050 .elementor-element-644733f5 .elementor-widget-image img {
    width: min(100%, 920px) !important;
    margin-inline: auto !important;
    display: block !important;
}

@media only screen and (max-width: 760px) {
    .elementor-13050 .elementor-element-42dbca07 > .e-con-inner,
    .elementor-13050 .elementor-element-7810054 > .e-con-inner {
        grid-template-columns: 1fr !important;
    }
}

/*
 * Voucher process grid.
 * Keep the four method steps readable: 4 columns on wide screens, 2+2 on tablet,
 * 1 column on mobile.
 */
.elementor-13050 .elementor-element-3ec7219d .elementor-element-7810054,
.elementor-13050 .elementor-element-3ec7219d .elementor-element-7810054 > .e-con-inner {
    width: 100% !important;
    max-width: min(100%, 1320px) !important;
    margin-inline: auto !important;
}

.elementor-13050 .elementor-element-3ec7219d .elementor-element-7810054 > .e-con-inner {
    display: grid !important;
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    gap: clamp(18px, 1.8vw, 28px) !important;
    align-items: stretch !important;
    background: transparent !important;
}

.elementor-13050 .elementor-element-3ec7219d .elementor-element-7810054 > .e-con-inner > .e-con {
    display: flex !important;
    flex-direction: column !important;
    width: auto !important;
    min-width: 0 !important;
    min-height: clamp(300px, 22vw, 370px) !important;
    padding: clamp(24px, 2.15vw, 36px) !important;
    border: 1px solid rgba(235, 235, 235, .16) !important;
    border-color: color-mix(in srgb, var(--mm-voucher-paper) 16%, transparent) !important;
    background: rgba(235, 235, 235, .035) !important;
    background: color-mix(in srgb, var(--mm-voucher-paper) 4%, transparent) !important;
    overflow: hidden !important;
}

.elementor-13050 .elementor-element-3ec7219d .elementor-element-7810054 > .e-con-inner > .e-con > .e-con-inner {
    width: 100% !important;
    max-width: 100% !important;
}

.elementor-13050 .elementor-element-3ec7219d .elementor-element-7810054 .elementor-heading-title {
    max-width: 100% !important;
    overflow-wrap: normal !important;
    word-break: normal !important;
    hyphens: none !important;
}

.elementor-13050 .elementor-element-3ec7219d .elementor-element-7810054 .mm-step-num .elementor-heading-title {
    font-size: clamp(18px, 1.1vw, 22px) !important;
    line-height: 1 !important;
}

.elementor-13050 .elementor-element-3ec7219d .elementor-element-7810054 .elementor-widget-heading:not(.mm-step-num) .elementor-heading-title {
    font-size: clamp(21px, 1.35vw, 27px) !important;
    line-height: 1.15 !important;
}

.elementor-13050 .elementor-element-3ec7219d .elementor-element-7810054 p {
    max-width: 34ch !important;
    text-align: left !important;
    text-align-last: left !important;
    word-spacing: normal !important;
    letter-spacing: 0 !important;
    overflow-wrap: normal !important;
    word-break: normal !important;
    hyphens: none !important;
    font-size: clamp(14px, .92vw, 16px) !important;
    line-height: 1.55 !important;
}

@media only screen and (max-width: 1280px) {
    .elementor-13050 .elementor-element-3ec7219d .elementor-element-7810054 {
        max-width: min(100%, 900px) !important;
    }

    .elementor-13050 .elementor-element-3ec7219d .elementor-element-7810054 > .e-con-inner {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }

    .elementor-13050 .elementor-element-3ec7219d .elementor-element-7810054 > .e-con-inner > .e-con {
        min-height: auto !important;
    }
}

@media only screen and (max-width: 700px) {
    .elementor-13050 .elementor-element-3ec7219d .elementor-element-7810054 {
        max-width: 100% !important;
    }

    .elementor-13050 .elementor-element-3ec7219d .elementor-element-7810054 > .e-con-inner {
        grid-template-columns: 1fr !important;
    }
}

/*
 * Footer layout switch sync.
 * The footer must follow Leksa's color switch, including the oversized brand text.
 */
.site-footer,
.site-footer.footer--overlay {
    background: var(--mainBackground) !important;
    color: var(--mainColor) !important;
}

body .site-footer.site-footer .elementor,
body .site-footer.site-footer .elementor-element,
body .site-footer.site-footer .elementor-widget,
body .site-footer.site-footer .elementor-widget-container,
body .site-footer.site-footer .e-con,
body .site-footer.site-footer h1,
body .site-footer.site-footer h2,
body .site-footer.site-footer h3,
body .site-footer.site-footer h4,
body .site-footer.site-footer h5,
body .site-footer.site-footer h6,
body .site-footer.site-footer p,
body .site-footer.site-footer a,
body .site-footer.site-footer span,
body .site-footer.site-footer .elementor-heading-title,
body .site-footer.site-footer .elementor-widget-heading .elementor-heading-title,
body .site-footer.site-footer .elementor-widget-text-editor,
body .site-footer.site-footer .elementor-widget-text-editor *,
body .site-footer.site-footer .text-wrapper,
body .site-footer.site-footer .text-wrapper *,
body .site-footer.site-footer .text-h1,
body .site-footer.site-footer .text-h2,
body .site-footer.site-footer .text-h3,
body .site-footer.site-footer .text-h4,
body .site-footer.site-footer .text-h5,
body .site-footer.site-footer .text-h6,
body .site-footer.site-footer .text-p,
body .site-footer.site-footer [class^="text-"],
body .site-footer.site-footer [class*=" text-"],
body .site-footer.site-footer .site-info,
body .site-footer.site-footer .site-info * {
    color: var(--mainColor) !important;
    -webkit-text-fill-color: var(--mainColor) !important;
}

body .site-footer.site-footer .bg--color,
body .site-footer.site-footer .e-con.bg--color,
body .site-footer.site-footer .elementor-section.bg--color {
    background: var(--mainBackground) !important;
}

body .site-footer.site-footer a:hover {
    color: var(--mainColor) !important;
}

/*
 * Voucher page footer override.
 * Elementor page 13050 applies stronger colors to the shared footer template,
 * so repeat the switch-aware footer colors with page-level specificity.
 */
body.page-id-13050 .site-footer.site-footer,
body.page-id-13050 .site-footer.site-footer .elementor,
body.page-id-13050 .site-footer.site-footer .elementor-element,
body.page-id-13050 .site-footer.site-footer .elementor-widget,
body.page-id-13050 .site-footer.site-footer .elementor-widget-container,
body.page-id-13050 .site-footer.site-footer .e-con,
body.page-id-13050 .site-footer.site-footer h1,
body.page-id-13050 .site-footer.site-footer h2,
body.page-id-13050 .site-footer.site-footer h3,
body.page-id-13050 .site-footer.site-footer h4,
body.page-id-13050 .site-footer.site-footer h5,
body.page-id-13050 .site-footer.site-footer h6,
body.page-id-13050 .site-footer.site-footer p,
body.page-id-13050 .site-footer.site-footer a,
body.page-id-13050 .site-footer.site-footer span,
body.page-id-13050 .site-footer.site-footer .elementor-heading-title,
body.page-id-13050 .site-footer.site-footer .text-wrapper,
body.page-id-13050 .site-footer.site-footer .text-wrapper *,
body.page-id-13050 .site-footer.site-footer .text-h1,
body.page-id-13050 .site-footer.site-footer .text-p,
body.page-id-13050 .site-footer.site-footer [class^="text-"],
body.page-id-13050 .site-footer.site-footer [class*=" text-"] {
    color: var(--mainColor) !important;
    -webkit-text-fill-color: var(--mainColor) !important;
}

body.page-id-13050 .site-footer.site-footer,
body.page-id-13050 .site-footer.site-footer .bg--color,
body.page-id-13050 .site-footer.site-footer .e-con.bg--color,
body.page-id-13050 .site-footer.site-footer .elementor-section.bg--color {
    background: var(--mainBackground) !important;
}

/*
 * Footer switch hard sync.
 * Some Elementor footer containers redefine --mainColor internally. Use footer
 * scoped literals so descendants cannot resolve the switch color back to black.
 */
body .site-footer.site-footer {
    --mm-footer-bg: #f0f0f0;
    --mm-footer-color: #070707;
}

body.layout--switched .site-footer.site-footer {
    --mm-footer-bg: #141414;
    --mm-footer-color: #dddddd;
}

body .site-footer.site-footer,
body .site-footer.site-footer .elementor,
body .site-footer.site-footer .elementor-element,
body .site-footer.site-footer .elementor-widget,
body .site-footer.site-footer .elementor-widget-container,
body .site-footer.site-footer .e-con,
body .site-footer.site-footer .text-wrapper,
body .site-footer.site-footer .text-wrapper *,
body .site-footer.site-footer [class^="text-"],
body .site-footer.site-footer [class*=" text-"],
body.page-id-13050 .site-footer.site-footer,
body.page-id-13050 .site-footer.site-footer .elementor,
body.page-id-13050 .site-footer.site-footer .elementor-element,
body.page-id-13050 .site-footer.site-footer .elementor-widget,
body.page-id-13050 .site-footer.site-footer .elementor-widget-container,
body.page-id-13050 .site-footer.site-footer .e-con,
body.page-id-13050 .site-footer.site-footer .text-wrapper,
body.page-id-13050 .site-footer.site-footer .text-wrapper *,
body.page-id-13050 .site-footer.site-footer [class^="text-"],
body.page-id-13050 .site-footer.site-footer [class*=" text-"] {
    --mainColor: var(--mm-footer-color) !important;
    --mainBackground: var(--mm-footer-bg) !important;
    color: var(--mm-footer-color) !important;
    -webkit-text-fill-color: var(--mm-footer-color) !important;
}

body .site-footer.site-footer,
body .site-footer.site-footer .bg--color,
body .site-footer.site-footer .e-con.bg--color,
body.page-id-13050 .site-footer.site-footer,
body.page-id-13050 .site-footer.site-footer .bg--color,
body.page-id-13050 .site-footer.site-footer .e-con.bg--color {
    background: var(--mm-footer-bg) !important;
}

/*
 * Footer back-to-top icon switch sync.
 * The circular footer buttons must invert together with the footer theme.
 */
body .site-footer.site-footer .pe--icon.has-bg,
body .site-footer.site-footer .pe--icon.has-bg .pe--icon--bg {
    background: var(--mm-footer-color) !important;
}

body .site-footer.site-footer .pe--icon.has-bg,
body .site-footer.site-footer .pe--icon.has-bg i,
body .site-footer.site-footer .pe--icon.has-bg svg,
body .site-footer.site-footer .pe--icon.has-bg svg * {
    color: var(--mm-footer-bg) !important;
    fill: var(--mm-footer-bg) !important;
    stroke: var(--mm-footer-bg) !important;
    -webkit-text-fill-color: var(--mm-footer-bg) !important;
}
