.vs-ethical-banner,
.vs-local-callout,
.vs-how-it-works,
.vs-trust-panel,
.vs-micro-actions,
.vs-benefit-note{
    border:1px solid #dce9f5;
    background:#fff;
    box-shadow:0 14px 34px rgba(15,23,42,.08);
}

.vs-ethical-banner{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:14px;
    border-radius:22px;
    padding:16px;
    margin:12px 0 18px;
    background:linear-gradient(135deg,#ffffff,#f4fbff);
}

.vs-ethical-banner__icon{
    width:48px;
    height:48px;
    border-radius:16px;
    display:flex;
    align-items:center;
    justify-content:center;
    flex:0 0 auto;
    background:#dcfce7;
    color:#16a34a;
    font-size:22px;
}

.vs-ethical-banner__copy{
    flex:1;
    min-width:0;
}

.vs-ethical-banner__copy strong,
.vs-local-callout strong,
.vs-how-it-works h3,
.vs-trust-panel strong{
    display:block;
    color:#0f172a;
    font-weight:950;
    line-height:1.2;
}

.vs-ethical-banner__copy span,
.vs-local-callout span,
.vs-trust-panel span{
    display:block;
    margin-top:4px;
    color:#64748b;
    font-size:13px;
    line-height:1.45;
}

.vs-ethical-banner__link,
.vs-trust-link{
    min-height:40px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:8px;
    flex:0 0 auto;
    border-radius:14px;
    padding:0 14px;
    background:#16a34a;
    color:#fff !important;
    text-decoration:none !important;
    font-weight:900;
    border:0;
}

.vs-local-callout{
    border-radius:24px;
    padding:20px;
    margin:16px 0 20px;
    background:linear-gradient(135deg,#071b3a,#0f766e);
    color:#fff;
    overflow:hidden;
}

.vs-local-callout strong{
    color:#fff;
    font-size:22px;
}

.vs-local-callout span{
    color:#dbeafe;
    max-width:720px;
}

.vs-local-tags{
    display:flex;
    flex-wrap:wrap;
    gap:8px;
    margin-top:14px;
}

.vs-local-tags em,
.vs-proof-badge{
    display:inline-flex;
    align-items:center;
    gap:6px;
    padding:7px 10px;
    border-radius:999px;
    background:rgba(255,255,255,.12);
    color:#fff;
    font-style:normal;
    font-size:12px;
    font-weight:900;
}

.vs-how-it-works{
    border-radius:24px;
    padding:18px;
    margin:16px 0 22px;
}

.vs-how-it-works__head{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:12px;
    margin-bottom:14px;
}

.vs-how-it-works h3{
    margin:0;
    font-size:20px;
}

.vs-steps{
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:10px;
}

.vs-step{
    padding:14px;
    border-radius:18px;
    background:#f8fafc;
    border:1px solid #e5edf6;
}

.vs-step i{
    width:38px;
    height:38px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    border-radius:14px;
    background:#dcfce7;
    color:#16a34a;
    margin-bottom:10px;
}

.vs-step strong{
    display:block;
    color:#0f172a;
    font-weight:950;
}

.vs-step span{
    display:block;
    color:#64748b;
    font-size:12px;
    line-height:1.4;
    margin-top:4px;
}

.vs-trust-panel{
    border-radius:18px;
    padding:14px;
    margin:14px 0;
    background:#f8fbff;
}

.vs-trust-panel__grid{
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:8px;
    margin-top:12px;
}

.vs-trust-item{
    display:flex;
    align-items:flex-start;
    gap:8px;
    padding:10px;
    border-radius:14px;
    background:#fff;
    color:#334155;
    font-size:12px;
    font-weight:850;
}

.vs-trust-item i{
    color:#16a34a;
    margin-top:2px;
}

.vs-micro-actions{
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:8px;
    border-radius:18px;
    padding:10px;
    margin:14px 0;
    background:#f8fafc;
}

.vs-micro-actions a,
.vs-micro-actions button{
    min-height:42px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:7px;
    border:1px solid #e2e8f0;
    border-radius:14px;
    background:#fff;
    color:#0f172a;
    text-decoration:none !important;
    font-weight:900;
    font-size:12px;
}

.vs-benefit-note{
    border-radius:18px;
    padding:13px;
    margin:12px 0;
    background:#fffdf2;
    border-color:#fde68a;
    color:#92400e;
    font-size:13px;
    font-weight:850;
    line-height:1.45;
}

.vs-toast{
    position:fixed;
    left:50%;
    bottom:calc(92px + env(safe-area-inset-bottom));
    z-index:10080;
    width:min(92vw,420px);
    transform:translate(-50%,18px);
    opacity:0;
    pointer-events:none;
    border-radius:18px;
    padding:13px 15px;
    background:#0f172a;
    color:#fff;
    box-shadow:0 22px 50px rgba(15,23,42,.28);
    font-weight:850;
    transition:.22s ease;
}

.vs-toast.is-visible{
    opacity:1;
    transform:translate(-50%,0);
}

@media(max-width:767px){
    .vs-ethical-banner{
        align-items:flex-start;
        border-radius:18px;
    }

    .vs-ethical-banner__link{
        display:none;
    }

    .vs-local-callout{
        border-radius:20px;
        padding:18px;
    }

    .vs-local-callout strong{
        font-size:19px;
    }

    .vs-how-it-works{
        border-radius:20px;
        padding:15px;
    }

    .vs-how-it-works__head{
        display:block;
    }

    .vs-trust-link{
        margin-top:10px;
        width:100%;
    }

    .vs-steps,
    .vs-trust-panel__grid,
    .vs-micro-actions{
        grid-template-columns:1fr;
    }
}
