.sweep-page {
    min-height: 100vh;
    overflow: hidden;
    color: #172033;
    background: #f4f7fb;
}

.sweep-container {
    width: min(1180px, calc(100% - 32px));
    margin: 0 auto;
}

.sweep-hero {
    position: relative;
    padding: 72px 0 46px;
    background:
        linear-gradient(115deg, rgba(20, 122, 104, 0.09), transparent 34%),
        linear-gradient(180deg, #ffffff 0%, #eef5ff 100%);
}

.sweep-hero::after {
    position: absolute;
    right: -8vw;
    bottom: -190px;
    width: 52vw;
    height: 310px;
    content: "";
    transform: rotate(-7deg);
    background: repeating-linear-gradient(
        90deg,
        rgba(240, 185, 11, 0.28) 0 20px,
        rgba(20, 122, 104, 0.16) 20px 34px
    );
    opacity: 0.42;
}

.sweep-hero__grid {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(320px, 420px);
    gap: 58px;
    align-items: center;
}

.sweep-status {
    display: inline-flex;
    align-items: center;
    gap: 9px;
    margin-bottom: 20px;
    padding: 8px 12px;
    border: 1px solid rgba(20, 122, 104, 0.18);
    border-radius: 999px;
    color: #146b5c;
    background: rgba(255, 255, 255, 0.82);
    font-size: 13px;
    font-weight: 800;
}

.sweep-language {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    width: fit-content;
    max-width: 100%;
    margin-bottom: 18px;
    padding: 4px;
    border: 1px solid rgba(20, 122, 104, 0.18);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.76);
}

.sweep-language a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 42px;
    height: 32px;
    border-radius: 999px;
    color: #146b5c;
    font-size: 13px;
    font-weight: 800;
    text-decoration: none;
}

.sweep-language a.is-active {
    color: #ffffff;
    background: #147a68;
}

.sweep-status__dot {
    width: 9px;
    height: 9px;
    border-radius: 50%;
    background: #14a36f;
    box-shadow: 0 0 0 8px rgba(20, 163, 111, 0.14);
}

.sweep-hero h1 {
    max-width: 760px;
    margin: 0;
    color: #101827;
    font-size: clamp(42px, 6.4vw, 76px);
    line-height: 0.96;
    letter-spacing: 0;
}

.sweep-hero__text {
    max-width: 660px;
    margin: 26px 0 0;
    color: #4d5c73;
    font-size: 18px;
    line-height: 1.75;
}

.sweep-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 18px;
    align-items: center;
    margin-top: 30px;
}

.sweep-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 50px;
    padding: 0 24px;
    border-radius: 7px;
    font-weight: 800;
    text-decoration: none;
}

.sweep-link {
    color: #172033;
    font-weight: 800;
    text-decoration-color: rgba(20, 122, 104, 0.38);
    text-underline-offset: 5px;
}

.sweep-metrics {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    max-width: 650px;
    margin-top: 36px;
    border-top: 1px solid rgba(85, 98, 118, 0.16);
    border-bottom: 1px solid rgba(85, 98, 118, 0.16);
}

.sweep-metrics div {
    padding: 18px 18px 18px 0;
}

.sweep-metrics strong,
.sweep-metrics span {
    display: block;
}

.sweep-metrics strong {
    color: #101827;
    font-size: 20px;
}

.sweep-metrics span {
    margin-top: 3px;
    color: #66758a;
    font-size: 13px;
}

.sweep-ticket {
    position: relative;
    min-height: 520px;
    padding: 28px;
    border: 1px solid rgba(126, 92, 0, 0.22);
    border-radius: 8px;
    background:
        linear-gradient(160deg, rgba(255, 234, 176, 0.98), rgba(240, 185, 11, 0.96) 58%, #f06b3a 132%);
    box-shadow: 0 28px 80px rgba(31, 45, 72, 0.2);
    transform: rotate(2deg);
}

.sweep-ticket::before,
.sweep-ticket::after {
    position: absolute;
    top: 50%;
    width: 44px;
    height: 78px;
    content: "";
    transform: translateY(-50%);
    background: #eef5ff;
}

.sweep-ticket::before {
    left: -1px;
    border-radius: 0 999px 999px 0;
}

.sweep-ticket::after {
    right: -1px;
    border-radius: 999px 0 0 999px;
}

.sweep-ticket__top,
.sweep-ticket__footer {
    position: relative;
    z-index: 1;
    display: flex;
    justify-content: space-between;
    gap: 14px;
    color: #172033;
    font-weight: 800;
}

.sweep-ticket__top span:last-child {
    padding: 5px 10px;
    border-radius: 999px;
    color: #ffffff;
    background: #147a68;
    font-size: 12px;
}

.sweep-ticket__scratch {
    position: relative;
    z-index: 1;
    min-height: 310px;
    margin: 46px 0 34px;
    overflow: hidden;
    border: 2px dashed rgba(23, 32, 51, 0.28);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.42);
}

.sweep-ticket__prize {
    position: absolute;
    inset: 0;
    z-index: 1;
    display: grid;
    place-items: center;
    align-content: center;
    gap: 14px;
    padding: 28px;
    text-align: center;
}

.sweep-ticket__prize span {
    color: #6f4b00;
    font-size: 13px;
    font-weight: 900;
    text-transform: uppercase;
}

.sweep-ticket__prize strong {
    color: #101827;
    font-size: 38px;
    line-height: 1.05;
}

.sweep-ticket__prize .sweep-button {
    margin-top: 6px;
}

.sweep-ticket canvas {
    position: absolute;
    inset: 0;
    z-index: 2;
    width: 100%;
    height: 100%;
    cursor: grab;
    touch-action: none;
}

.sweep-ticket.is-revealed canvas {
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.25s ease;
}

.sweep-band {
    position: relative;
    z-index: 2;
    padding: 18px 0;
    color: #ffffff;
    background: #111827;
}

.sweep-band__grid {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 26px;
    align-items: center;
}

.sweep-band p {
    margin: 0;
    color: #d7deea;
    line-height: 1.6;
}

.sweep-timer {
    display: flex;
    align-items: center;
    gap: 14px;
    padding-right: 24px;
    border-right: 1px solid rgba(255, 255, 255, 0.18);
    white-space: nowrap;
}

.sweep-timer span {
    color: #aab5c7;
    font-size: 13px;
    font-weight: 700;
}

.sweep-timer strong {
    color: #f0b90b;
    font-size: 28px;
    letter-spacing: 0;
}

.sweep-section {
    padding: 68px 0;
}

.sweep-quiz {
    background: #ffffff;
}

.sweep-quiz__grid {
    display: grid;
    grid-template-columns: 0.72fr 1fr;
    gap: 46px;
    align-items: center;
}

.sweep-quiz__intro h2 {
    max-width: 470px;
    margin: 0;
    color: #101827;
    font-size: 38px;
    line-height: 1.08;
    letter-spacing: 0;
}

.sweep-quiz__intro p {
    max-width: 500px;
    margin: 18px 0 0;
    color: #5f6b7a;
    font-size: 17px;
    line-height: 1.7;
}

.sweep-quiz__panel {
    min-height: 390px;
    padding: 30px;
    border: 1px solid #dce4ef;
    border-radius: 8px;
    background:
        linear-gradient(135deg, rgba(20, 122, 104, 0.08), transparent 42%),
        #f8fbff;
    box-shadow: 0 22px 54px rgba(20, 32, 51, 0.08);
}

.sweep-quiz__progress {
    display: grid;
    gap: 10px;
    margin-bottom: 34px;
}

.sweep-quiz__progress span {
    color: #147a68;
    font-size: 13px;
    font-weight: 800;
    text-transform: uppercase;
}

.sweep-quiz__progress div {
    height: 9px;
    overflow: hidden;
    border-radius: 999px;
    background: #dce4ef;
}

.sweep-quiz__progress i {
    display: block;
    width: 33.33%;
    height: 100%;
    border-radius: inherit;
    background: #147a68;
    transition: width 0.25s ease;
}

.sweep-quiz__step,
.sweep-quiz__result {
    display: none;
}

.sweep-quiz__step.is-active,
.sweep-quiz__result.is-active {
    display: block;
}

.sweep-quiz h3 {
    margin: 0;
    color: #101827;
    font-size: 30px;
    line-height: 1.15;
}

.sweep-quiz__step p,
.sweep-quiz__result p {
    max-width: 620px;
    margin: 14px 0 0;
    color: #5f6b7a;
    font-size: 16px;
    line-height: 1.7;
}

.sweep-quiz__answers {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
    margin-top: 28px;
}

.sweep-quiz__answers button {
    min-height: 54px;
    padding: 0 18px;
    border: 1px solid #c9d4e4;
    border-radius: 7px;
    color: #172033;
    background: #ffffff;
    cursor: pointer;
    font: inherit;
    font-weight: 800;
    text-align: left;
    transition: border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}

.sweep-quiz__answers button:hover,
.sweep-quiz__answers button:focus {
    border-color: #147a68;
    box-shadow: 0 10px 26px rgba(20, 122, 104, 0.12);
    outline: none;
    transform: translateY(-1px);
}

.sweep-quiz__result-icon {
    display: grid;
    place-items: center;
    width: 68px;
    height: 68px;
    margin-bottom: 22px;
    border-radius: 50%;
    color: #ffffff;
    background: #147a68;
    font-size: 30px;
}

.sweep-quiz__result .sweep-button {
    margin-top: 24px;
}

.sweep-story {
    display: grid;
    grid-template-columns: 1.08fr 0.9fr 0.9fr;
    gap: 18px;
    align-items: stretch;
}

.sweep-story__item {
    min-height: 230px;
    padding: 28px;
    border: 1px solid #dce4ef;
    border-radius: 8px;
    background: #ffffff;
    box-shadow: 0 18px 44px rgba(20, 32, 51, 0.06);
}

.sweep-story__item_primary {
    position: relative;
    grid-row: span 2;
    display: flex;
    flex-direction: column;
    justify-content: center;
    min-height: 360px;
    color: #ffffff;
    background:
        radial-gradient(circle at 82% 18%, rgba(255, 255, 255, 0.16), transparent 24%),
        linear-gradient(180deg, rgba(17, 24, 39, 0.04), rgba(17, 24, 39, 0.5)),
        linear-gradient(135deg, #147a68, #1c9a82);
}

.sweep-story__symbol {
    display: grid;
    place-items: center;
    width: 82px;
    height: 82px;
    margin-bottom: 28px;
    border: 1px solid rgba(255, 255, 255, 0.28);
    border-radius: 50%;
    color: #147a68;
    background: rgba(255, 255, 255, 0.92);
    font-size: 34px;
    box-shadow: 0 18px 38px rgba(9, 55, 49, 0.22);
}

.sweep-story__item_dark {
    color: #ffffff;
    background: #111827;
}

.sweep-pill,
.sweep-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: fit-content;
    margin-bottom: 22px;
    border-radius: 999px;
    font-weight: 800;
}

.sweep-pill {
    padding: 8px 12px;
    color: #0f6658;
    background: #dff8ee;
    font-size: 13px;
}

.sweep-icon {
    width: 44px;
    height: 44px;
    color: #ffffff;
    background: #147a68;
    font-size: 22px;
}

.sweep-story h2,
.sweep-story h3,
.sweep-checks h2,
.sweep-faq h2 {
    margin: 0;
    font-size: 28px;
    line-height: 1.15;
    letter-spacing: 0;
}

.sweep-story h3 {
    font-size: 23px;
}

.sweep-story p,
.sweep-checks p,
.sweep-faq p {
    margin: 14px 0 0;
    color: #5f6b7a;
    font-size: 16px;
    line-height: 1.7;
}

.sweep-story__item_primary p,
.sweep-story__item_dark p {
    color: #dce8f4;
}

.sweep-mini-list {
    display: grid;
    gap: 10px;
    margin: 24px 0 0;
    padding: 0;
    list-style: none;
}

.sweep-mini-list li {
    border: 1px solid rgba(255, 255, 255, 0.18);
    border-radius: 7px;
    background: rgba(255, 255, 255, 0.1);
}

.sweep-mini-list a {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    padding: 11px 13px;
    color: #f7fbff;
    font-weight: 800;
    text-decoration: none;
}

.sweep-mini-list a::after {
    content: "\f061";
    flex: 0 0 auto;
    color: rgba(255, 255, 255, 0.78);
    font-family: "Font Awesome 6 Free";
    font-weight: 900;
}

.sweep-mini-list a:hover,
.sweep-mini-list a:focus {
    background: rgba(255, 255, 255, 0.12);
    outline: none;
}

.sweep-story__item_dark .sweep-button {
    margin-top: 20px;
}

.sweep-checks {
    background: #ffffff;
}

.sweep-final {
    padding-top: 0;
}

.sweep-final__box {
    display: grid;
    place-items: center;
    min-height: 360px;
    padding: 44px 24px;
    border-radius: 8px;
    text-align: center;
    color: #ffffff;
    background:
        radial-gradient(circle at 50% 0%, rgba(240, 185, 11, 0.24), transparent 36%),
        linear-gradient(135deg, #147a68, #111827);
    box-shadow: 0 24px 70px rgba(20, 32, 51, 0.16);
}

.sweep-final__icon {
    display: grid;
    place-items: center;
    width: 74px;
    height: 74px;
    margin-bottom: 20px;
    border-radius: 50%;
    color: #147a68;
    background: #ffffff;
    font-size: 30px;
}

.sweep-final .sweep-eyebrow,
.sweep-final h2 {
    color: #ffffff;
}

.sweep-final h2 {
    max-width: 680px;
    margin: 0;
    font-size: 38px;
    line-height: 1.12;
}

.sweep-final p:not(.sweep-eyebrow) {
    max-width: 560px;
    margin: 16px 0 0;
    color: #dce8f4;
    font-size: 17px;
    line-height: 1.7;
}

.sweep-final .sweep-button {
    margin-top: 28px;
}

.sweep-checks__grid {
    display: grid;
    grid-template-columns: 0.78fr 1fr;
    gap: 48px;
    align-items: center;
}

.sweep-path {
    display: grid;
    grid-template-columns: 0.72fr 1fr;
    gap: 46px;
    align-items: center;
}

.sweep-path > div:first-child > p:last-child,
.sweep-reasons > div:first-child > p {
    max-width: 520px;
    margin: 16px 0 0;
    color: #5f6b7a;
    font-size: 17px;
    line-height: 1.7;
}

.sweep-path__steps {
    display: grid;
    gap: 14px;
}

.sweep-path__steps article {
    display: grid;
    grid-template-columns: 52px minmax(0, 1fr);
    gap: 16px;
    align-items: center;
    padding: 18px;
    border: 1px solid #dce4ef;
    border-radius: 8px;
    background: #f8fbff;
}

.sweep-path__steps i {
    display: grid;
    place-items: center;
    width: 52px;
    height: 52px;
    border-radius: 8px;
    color: #ffffff;
    background: #147a68;
    font-size: 20px;
}

.sweep-path__steps h3,
.sweep-reasons__grid strong {
    margin: 0;
    color: #101827;
    font-size: 20px;
    line-height: 1.2;
}

.sweep-path__steps p {
    margin: 6px 0 0;
    color: #5f6b7a;
    line-height: 1.6;
}

.sweep-eyebrow {
    margin: 0 0 12px;
    color: #147a68;
    font-size: 13px;
    font-weight: 800;
    letter-spacing: 0;
    text-transform: uppercase;
}

.sweep-checklist {
    display: grid;
    gap: 12px;
}

.sweep-checklist label {
    display: flex;
    gap: 12px;
    align-items: center;
    padding: 16px 18px;
    border: 1px solid #dce4ef;
    border-radius: 8px;
    color: #29364b;
    background: #f8fbff;
    font-weight: 700;
}

.sweep-checklist input {
    width: 20px;
    height: 20px;
    accent-color: #147a68;
}

.sweep-faq {
    display: grid;
    grid-template-columns: 0.62fr 1fr;
    gap: 50px;
}

.sweep-reasons {
    display: grid;
    grid-template-columns: 0.68fr 1fr;
    gap: 46px;
    align-items: stretch;
    padding: 38px;
    border-radius: 8px;
    color: #ffffff;
    background:
        linear-gradient(135deg, rgba(20, 122, 104, 0.86), rgba(17, 24, 39, 0.96)),
        #111827;
}

.sweep-reasons h2,
.sweep-reasons .sweep-eyebrow {
    color: #ffffff;
}

.sweep-reasons > div:first-child > p {
    color: #dce8f4;
}

.sweep-reasons .sweep-button {
    margin-top: 24px;
}

.sweep-reasons__grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
}

.sweep-reasons__grid article {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    min-height: 190px;
    padding: 22px;
    border: 1px solid rgba(255, 255, 255, 0.16);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.1);
}

.sweep-reasons__grid strong {
    color: #ffffff;
    font-size: 34px;
}

.sweep-reasons__grid span {
    margin-top: 22px;
    color: #dce8f4;
    font-weight: 800;
    line-height: 1.45;
}

.sweep-faq__items {
    display: grid;
    gap: 12px;
}

.sweep-faq details {
    border: 1px solid #dce4ef;
    border-radius: 8px;
    background: #ffffff;
    box-shadow: 0 14px 34px rgba(20, 32, 51, 0.05);
}

.sweep-faq summary {
    cursor: pointer;
    padding: 18px 20px;
    color: #101827;
    font-weight: 800;
}

.sweep-faq details p {
    margin: 0;
    padding: 0 20px 20px;
}

@media (max-width: 920px) {
    .sweep-hero__grid,
    .sweep-band__grid,
    .sweep-quiz__grid,
    .sweep-checks__grid,
    .sweep-path,
    .sweep-faq,
    .sweep-reasons {
        grid-template-columns: 1fr;
    }

    .sweep-ticket {
        min-height: 440px;
        transform: none;
    }

    .sweep-story {
        grid-template-columns: 1fr 1fr;
    }

    .sweep-story__item_primary {
        grid-column: span 2;
        min-height: 360px;
    }

    .sweep-timer {
        border-right: 0;
        padding-right: 0;
    }

    .sweep-reasons__grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 620px) {
    .sweep-hero {
        padding-top: 44px;
    }

    .sweep-hero h1 {
        font-size: 40px;
    }

    .sweep-metrics,
    .sweep-story,
    .sweep-path__steps article {
        grid-template-columns: 1fr;
    }

    .sweep-story__item_primary {
        grid-column: auto;
    }

    .sweep-actions,
    .sweep-actions .sweep-button,
    .sweep-quiz__answers {
        width: 100%;
    }

    .sweep-quiz__panel {
        padding: 24px 18px;
    }

    .sweep-quiz__answers {
        grid-template-columns: 1fr;
    }

    .sweep-ticket {
        min-height: 390px;
        padding: 22px;
    }

    .sweep-ticket__coin {
        width: 136px;
        height: 136px;
        margin: 56px auto 44px;
        font-size: 70px;
    }
}
