.vstep-page {
    background: #ffffff;
    color: #254552;
    max-width: 100vw;
    overflow-x: hidden;
}

.vstep-page a {
    text-decoration: none;
}

.vstep-hero {
    background-image:
        linear-gradient(90deg, rgba(9, 43, 52, .91), rgba(9, 43, 52, .72), rgba(9, 43, 52, .32)),
        url("/assets/images/vstep-img1.png");
    background-position: center;
    background-size: cover;
    color: #ffffff;
    min-height: 520px;
    padding: 92px 0 58px;
}

.vstep-breadcrumb {
    margin-bottom: 24px;
}

.vstep-breadcrumb-list {
    background: transparent;
    font-size: 13px;
    margin: 0;
    padding: 0;
}

.vstep-breadcrumb-list .breadcrumb-item,
.vstep-breadcrumb-list .breadcrumb-item::before,
.vstep-breadcrumb-list .breadcrumb-item.active {
    color: rgba(255, 255, 255, .78);
}

.vstep-breadcrumb-list a {
    color: #b8f3e7;
}

.vstep-hero-copy {
    max-width: 760px;
    min-width: 0;
}

.vstep-kicker,
.vstep-section-label {
    align-items: center;
    border-radius: 999px;
    display: inline-flex;
    font-size: .8rem;
    font-weight: 850;
    line-height: 1;
    padding: 7px 11px;
    text-transform: uppercase;
}

.vstep-kicker {
    background: rgba(255, 255, 255, .16);
    border: 1px solid rgba(255, 255, 255, .32);
    color: #d6fff6;
    margin-bottom: 14px;
}

.vstep-hero h1 {
    color: #ffffff;
    font-size: 2.6rem;
    font-weight: 900;
    line-height: 1.12;
    margin: 0 0 16px;
    max-width: 720px;
    overflow-wrap: anywhere;
    white-space: normal;
}

.vstep-hero p {
    color: rgba(255, 255, 255, .9);
    font-size: 1.08rem;
    line-height: 1.62;
    margin: 0;
    max-width: 710px;
    overflow-wrap: anywhere;
    white-space: normal;
}

.vstep-hero-actions,
.vstep-final-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 24px;
}

.vstep-hero-support-links,
.vstep-final-support-links {
    display: flex;
    flex-wrap: wrap;
    gap: 10px 14px;
    margin-top: 12px;
}

.vstep-hero-support-links a,
.vstep-final-support-links a {
    color: #d6fff6;
    font-size: .93rem;
    font-weight: 850;
    text-decoration: underline;
    text-underline-offset: 3px;
}

.vstep-hero-support-links a:hover,
.vstep-final-support-links a:hover {
    color: #ffffff;
}

.vstep-btn {
    align-items: center;
    border-radius: 999px;
    display: inline-flex;
    font-weight: 850;
    gap: 8px;
    justify-content: center;
    min-height: 46px;
    padding: 12px 18px;
    transition: background-color .2s ease, border-color .2s ease, color .2s ease, transform .2s ease;
}

.vstep-btn:hover {
    transform: translateY(-1px);
}

.vstep-btn-primary {
    background: #14b8a6;
    border: 1px solid #14b8a6;
    color: #ffffff;
}

.vstep-btn-primary:hover {
    background: #0f766e;
    border-color: #0f766e;
    color: #ffffff;
}

.vstep-btn-secondary {
    background: rgba(255, 255, 255, .12);
    border: 1px solid rgba(255, 255, 255, .42);
    color: #ffffff;
}

.vstep-btn-secondary:hover {
    background: #ffffff;
    border-color: #ffffff;
    color: #124e57;
}

.vstep-hero-facts {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 22px;
}

.vstep-hero-facts span {
    background: rgba(255, 255, 255, .12);
    border: 1px solid rgba(255, 255, 255, .24);
    border-radius: 999px;
    color: #ffffff;
    font-size: .88rem;
    font-weight: 750;
    line-height: 1.35;
    padding: 7px 11px;
}

.vstep-section {
    padding: 58px 0;
}

.vstep-section-head {
    margin: 0 auto 26px;
    max-width: 840px;
    text-align: center;
}

.vstep-section-label {
    background: #e7fbf6;
    border: 1px solid #a7eadb;
    color: #0f766e;
    margin-bottom: 12px;
}

.vstep-section-head h2,
.vstep-full-copy h2,
.vstep-final-cta h2 {
    color: #123846;
    font-size: 2rem;
    font-weight: 900;
    line-height: 1.18;
    margin: 0 0 10px;
}

.vstep-section-head p,
.vstep-full-copy p,
.vstep-final-cta p {
    color: #58707a;
    font-size: 1rem;
    line-height: 1.62;
    margin: 0 auto;
    max-width: 760px;
}

.vstep-skills {
    background: #f7fbfb;
}

.vstep-skill-grid {
    display: grid;
    gap: 14px;
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.vstep-skill-card {
    background: #ffffff;
    border: 1px solid #d8e5e7;
    border-radius: 8px;
    box-shadow: 0 12px 24px rgba(21, 50, 62, .07);
    color: #254552;
    display: flex;
    flex-direction: column;
    min-height: 360px;
    padding: 18px;
    transition: border-color .2s ease, box-shadow .2s ease, transform .2s ease;
}

.vstep-skill-card:hover {
    border-color: var(--skill-color);
    box-shadow: 0 16px 30px rgba(21, 50, 62, .14);
    color: #254552;
    transform: translateY(-2px);
}

.vstep-card-icon {
    align-items: center;
    background: var(--skill-color);
    border-radius: 8px;
    color: #ffffff;
    display: inline-flex;
    font-size: 1.35rem;
    height: 48px;
    justify-content: center;
    margin-bottom: 16px;
    width: 48px;
}

.vstep-skill-card h3 {
    color: var(--skill-color);
    font-size: 1.22rem;
    font-weight: 900;
    line-height: 1.25;
    margin: 0 0 9px;
}

.vstep-skill-card p {
    color: #516b76;
    line-height: 1.5;
    margin: 0 0 12px;
}

.vstep-skill-card ul {
    color: #5f747c;
    line-height: 1.45;
    margin: 0 0 16px;
    padding-left: 18px;
}

.vstep-skill-card li + li {
    margin-top: 6px;
}

.vstep-card-cta {
    align-items: center;
    color: var(--skill-color);
    display: inline-flex;
    font-weight: 900;
    gap: 7px;
    margin-top: auto;
}

.skill-speaking {
    --skill-color: #2563eb;
}

.skill-listening {
    --skill-color: #0284c7;
}

.skill-reading {
    --skill-color: #16a34a;
}

.skill-writing {
    --skill-color: #0d9488;
}

.vstep-full-test {
    background: #ffffff;
}

.vstep-full-layout {
    align-items: stretch;
    display: grid;
    gap: 22px;
    grid-template-columns: minmax(0, .92fr) minmax(320px, 1.08fr);
}

.vstep-full-copy {
    border-left: 5px solid #0f766e;
    padding: 4px 0 4px 18px;
}

.vstep-full-note {
    background: #ecfdf5;
    border: 1px solid #a7f3d0;
    border-radius: 8px;
    color: #0f5f4e;
    font-size: .95rem;
    font-weight: 750;
    margin-top: 14px;
    padding: 10px 12px;
}

.vstep-full-actions {
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.vstep-full-link {
    align-items: center;
    background: #ffffff;
    border: 1px solid #d8e5e7;
    border-radius: 8px;
    box-shadow: 0 12px 24px rgba(21, 50, 62, .07);
    color: #254552;
    display: grid;
    gap: 13px;
    grid-template-columns: 52px 1fr;
    min-height: 130px;
    padding: 16px;
    transition: border-color .2s ease, box-shadow .2s ease, transform .2s ease;
}

.vstep-full-link:hover {
    border-color: var(--full-color);
    box-shadow: 0 16px 30px rgba(21, 50, 62, .13);
    color: #254552;
    transform: translateY(-2px);
}

.vstep-full-link i {
    align-items: center;
    background: var(--full-color);
    border-radius: 8px;
    color: #ffffff;
    display: inline-flex;
    font-size: 1.35rem;
    height: 52px;
    justify-content: center;
    width: 52px;
}

.vstep-full-link strong {
    color: var(--full-color);
    display: block;
    font-size: 1.06rem;
    line-height: 1.3;
    margin-bottom: 4px;
}

.vstep-full-link small {
    color: #5f747c;
    display: block;
    line-height: 1.42;
}

.full-reading {
    --full-color: #16a34a;
}

.full-listening {
    --full-color: #0284c7;
}

.full-speaking {
    --full-color: #2563eb;
}

.full-writing {
    --full-color: #0d9488;
}

.vstep-resources {
    background: #f9fbff;
}

.vstep-resource-grid {
    display: grid;
    gap: 14px;
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.vstep-resource-item {
    background: #ffffff;
    border: 1px solid #dbe7ef;
    border-radius: 8px;
    min-height: 218px;
    padding: 18px;
}

.vstep-resource-item h3 {
    color: #123846;
    font-size: 1.08rem;
    font-weight: 900;
    margin: 0 0 8px;
}

.vstep-resource-item p {
    color: #58707a;
    line-height: 1.55;
    margin: 0 0 14px;
}

.vstep-resource-item a {
    color: #0f766e;
    font-weight: 900;
}

.vstep-roadmap {
    background: #f5fbf7;
}

.vstep-roadmap-list {
    display: grid;
    gap: 14px;
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.vstep-roadmap-step {
    background: #ffffff;
    border: 1px solid #d7e8dc;
    border-radius: 8px;
    min-height: 230px;
    padding: 18px;
}

.vstep-roadmap-step span {
    align-items: center;
    background: #dcfce7;
    border-radius: 999px;
    color: #15803d;
    display: inline-flex;
    font-weight: 900;
    height: 34px;
    justify-content: center;
    margin-bottom: 12px;
    width: 34px;
}

.vstep-roadmap-step h3 {
    color: #15803d;
    font-size: 1.06rem;
    font-weight: 900;
    margin: 0 0 8px;
}

.vstep-roadmap-step p {
    color: #58705d;
    line-height: 1.55;
    margin: 0;
}

.vstep-faq {
    background: #ffffff;
}

.vstep-faq .accordion {
    border-radius: 8px;
    box-shadow: 0 12px 24px rgba(21, 50, 62, .07);
    overflow: hidden;
}

.vstep-faq .accordion-button {
    color: #123846;
    font-weight: 850;
    line-height: 1.35;
}

.vstep-faq .accordion-body {
    color: #58707a;
    line-height: 1.62;
}

.vstep-final-cta {
    background: #124e57;
    color: #ffffff;
    padding: 56px 0;
    text-align: center;
}

.vstep-final-cta h2,
.vstep-final-cta p {
    color: #ffffff;
}

.vstep-final-cta p {
    opacity: .9;
}

.vstep-final-cta .vstep-final-actions {
    justify-content: center;
}

.vstep-final-support-links {
    justify-content: center;
}

.vstep-article-page {
    background: #f8fbfb;
}

.vstep-article-hero {
    background-image:
        linear-gradient(90deg, rgba(9, 43, 52, .94), rgba(9, 43, 52, .76), rgba(9, 43, 52, .42)),
        url("/assets/images/vstep-img2.png");
    background-position: center;
    background-size: cover;
    color: #ffffff;
    min-height: 440px;
    padding: 92px 0 58px;
}

.vstep-scoring-hero {
    background-image:
        linear-gradient(90deg, rgba(9, 43, 52, .94), rgba(9, 43, 52, .78), rgba(9, 43, 52, .48)),
        url("/assets/images/vstep-img1.png");
}

.vstep-article-hero-copy {
    max-width: 820px;
    min-width: 0;
}

.vstep-article-hero h1 {
    color: #ffffff;
    font-size: 2.45rem;
    font-weight: 900;
    line-height: 1.12;
    margin: 0 0 16px;
    overflow-wrap: anywhere;
}

.vstep-article-hero p {
    color: rgba(255, 255, 255, .91);
    font-size: 1.06rem;
    line-height: 1.62;
    margin: 0;
    max-width: 760px;
}

.vstep-article-updated {
    color: rgba(255, 255, 255, .76) !important;
    font-size: .92rem !important;
    margin-top: 16px !important;
}

.vstep-article-layout {
    align-items: start;
    display: grid;
    gap: 28px;
    grid-template-columns: minmax(0, 1fr) 292px;
}

.vstep-article-content {
    min-width: 0;
}

.vstep-article-content > section {
    background: #ffffff;
    border: 1px solid #dce8ea;
    border-radius: 8px;
    box-shadow: 0 12px 24px rgba(21, 50, 62, .06);
    margin-bottom: 18px;
    padding: 24px;
}

.vstep-article-content h2 {
    color: #123846;
    font-size: 1.72rem;
    font-weight: 900;
    line-height: 1.22;
    margin: 0 0 12px;
}

.vstep-article-content h3 {
    color: #0f766e;
    font-size: 1.08rem;
    font-weight: 900;
    line-height: 1.28;
    margin: 0 0 9px;
}

.vstep-article-content p {
    color: #516b76;
    line-height: 1.68;
    margin: 0 0 13px;
}

.vstep-article-content p:last-child {
    margin-bottom: 0;
}

.vstep-article-content a {
    color: #0f766e;
    font-weight: 850;
}

.vstep-table-wrap {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

.vstep-table {
    border-collapse: collapse;
    color: #254552;
    min-width: 760px;
    width: 100%;
}

.vstep-table caption {
    color: #58707a;
    font-size: .92rem;
    font-weight: 700;
    margin-bottom: 8px;
    text-align: left;
}

.vstep-table th,
.vstep-table td {
    border: 1px solid #d8e5e7;
    line-height: 1.45;
    padding: 13px 14px;
    text-align: left;
    vertical-align: top;
}

.vstep-table thead th {
    background: #e7fbf6;
    color: #0f766e;
    font-weight: 900;
}

.vstep-table tbody th {
    color: #123846;
    font-weight: 900;
}

.vstep-table tbody tr:nth-child(even) {
    background: #f7fbfb;
}

.vstep-score-table {
    min-width: 680px;
}

.vstep-split-cards {
    display: grid;
    gap: 14px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.vstep-info-card {
    background: #f8fbfb;
    border: 1px solid #d8e5e7;
    border-radius: 8px;
    min-width: 0;
    padding: 18px;
}

.vstep-info-card p {
    margin-bottom: 12px;
}

.vstep-check-list {
    color: #516b76;
    line-height: 1.65;
    margin: 0 0 14px;
    padding-left: 22px;
}

.vstep-check-list li + li {
    margin-top: 7px;
}

.vstep-article-cta {
    background: #123846 !important;
    border-color: #123846 !important;
    color: #ffffff;
}

.vstep-article-cta h2,
.vstep-article-cta p {
    color: #ffffff;
}

.vstep-article-cta p {
    opacity: .9;
}

.vstep-link-grid {
    display: grid;
    gap: 10px;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    margin-top: 18px;
}

.vstep-link-grid a {
    align-items: center;
    background: #ffffff;
    border: 1px solid rgba(255, 255, 255, .35);
    border-radius: 8px;
    color: #0f766e;
    display: inline-flex;
    font-weight: 900;
    justify-content: center;
    min-height: 48px;
    padding: 10px 12px;
    text-align: center;
}

.vstep-link-grid a:hover {
    background: #e7fbf6;
    color: #0f766e;
}

.vstep-formula-box {
    background: #ecfdf5;
    border: 1px solid #a7f3d0;
    border-radius: 8px;
    color: #0f5f4e;
    margin: 0 0 14px;
    padding: 14px 16px;
}

.vstep-article-faq details {
    border: 1px solid #d8e5e7;
    border-radius: 8px;
    background: #ffffff;
    margin-top: 10px;
    padding: 0;
}

.vstep-article-faq summary {
    color: #123846;
    cursor: pointer;
    font-weight: 900;
    line-height: 1.35;
    padding: 15px 16px;
}

.vstep-article-faq details[open] summary {
    border-bottom: 1px solid #d8e5e7;
}

.vstep-article-faq details p {
    padding: 14px 16px;
}

.vstep-article-aside {
    min-width: 0;
}

.vstep-sticky-panel {
    background: #ffffff;
    border: 1px solid #d8e5e7;
    border-radius: 8px;
    box-shadow: 0 12px 24px rgba(21, 50, 62, .06);
    padding: 18px;
    position: sticky;
    top: 96px;
}

.vstep-sticky-panel h2 {
    color: #123846;
    font-size: 1.05rem;
    font-weight: 900;
    margin: 0 0 10px;
}

.vstep-sticky-panel a {
    border-radius: 8px;
    color: #516b76;
    display: block;
    font-weight: 800;
    line-height: 1.35;
    padding: 9px 10px;
}

.vstep-sticky-panel a:hover {
    background: #e7fbf6;
    color: #0f766e;
}

.vstep-sticky-panel hr {
    border: 0;
    border-top: 1px solid #d8e5e7;
    margin: 10px 0;
}

.vstep-sticky-panel .vstep-sticky-primary {
    background: #0f766e;
    color: #ffffff;
}

.vstep-sticky-panel .vstep-sticky-primary:hover {
    background: #115e59;
    color: #ffffff;
}

@media (max-width: 1199.98px) {
    .vstep-skill-grid,
    .vstep-resource-grid,
    .vstep-roadmap-list {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .vstep-link-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 991.98px) {
    .vstep-hero {
        background-image:
            linear-gradient(90deg, rgba(9, 43, 52, .94), rgba(9, 43, 52, .7)),
            url("/assets/images/vstep-img1.png");
        min-height: 0;
        padding: 82px 0 48px;
    }

    .vstep-hero h1 {
        font-size: 2.2rem;
    }

    .vstep-full-layout {
        grid-template-columns: 1fr;
    }

    .vstep-article-hero {
        min-height: 0;
        padding: 82px 0 48px;
    }

    .vstep-article-hero h1 {
        font-size: 2.15rem;
    }

    .vstep-article-layout {
        grid-template-columns: 1fr;
    }

    .vstep-sticky-panel {
        position: static;
    }
}

@media (max-width: 767.98px) {
    .vstep-hero {
        padding: 72px 0 42px;
    }

    .vstep-hero-copy,
    .vstep-article-hero-copy,
    .vstep-hero-actions,
    .vstep-hero-support-links,
    .vstep-hero-facts {
        max-width: calc(100vw - 24px);
        width: calc(100vw - 24px);
    }

    .vstep-article-hero {
        padding: 72px 0 42px;
    }

    .vstep-hero h1 {
        font-size: 1.88rem;
        max-width: 100%;
        width: 100%;
    }

    .vstep-article-hero h1 {
        font-size: 1.86rem;
        max-width: 100%;
        width: 100%;
    }

    .vstep-hero p,
    .vstep-article-hero p,
    .vstep-section-head p,
    .vstep-full-copy p,
    .vstep-final-cta p {
        font-size: .98rem;
    }

    .vstep-hero-actions,
    .vstep-final-actions {
        align-items: stretch;
        flex-direction: column;
        width: 100%;
    }

    .vstep-btn {
        max-width: 100%;
        min-width: 0;
        white-space: normal;
        width: 100%;
    }

    .vstep-hero-facts span {
        max-width: 100%;
        overflow-wrap: anywhere;
        white-space: normal;
    }

    .vstep-section {
        padding: 46px 0;
    }

    .vstep-section-head h2,
    .vstep-full-copy h2,
    .vstep-final-cta h2 {
        font-size: 1.55rem;
    }

    .vstep-skill-grid,
    .vstep-full-actions,
    .vstep-resource-grid,
    .vstep-roadmap-list,
    .vstep-split-cards,
    .vstep-link-grid {
        grid-template-columns: 1fr;
    }

    .vstep-skill-card {
        min-height: 0;
    }

    .vstep-article-content > section {
        padding: 18px;
    }

    .vstep-article-content h2 {
        font-size: 1.45rem;
    }

    .vstep-table {
        min-width: 640px;
    }
}

@media (max-device-width: 767.98px) {
    .vstep-hero-copy,
    .vstep-article-hero-copy,
    .vstep-hero-actions,
    .vstep-hero-support-links,
    .vstep-hero-facts {
        max-width: min(366px, calc(100vw - 24px));
        width: min(366px, calc(100vw - 24px));
    }
}
