/* ============================================================
   BrandVerify — Business Setup + Compliance Checklist (CaaS)
   Loads after scanner-page.css + theme.css. Uses shared tokens.
   Namespaces: bvchk-* (checklist), bvcaas-* (business setup).
   ============================================================ */

/* ---- Shared page hero ---- */
.bvcaas-hero { padding: 4rem 0 2.5rem; text-align: center; }
.bvcaas-hero .container { max-width: 760px; }
.bvcaas-eyebrow {
    display: inline-flex; align-items: center; gap: .45rem;
    font-size: .78rem; font-weight: 700; letter-spacing: .06em; text-transform: uppercase;
    color: var(--primary-600); background: var(--primary-50);
    padding: .4rem .9rem; border-radius: 999px; margin-bottom: 1.1rem;
}
.bvcaas-h1 {
    font-family: 'Outfit', sans-serif; font-weight: 800;
    font-size: clamp(2rem, 5vw, 3rem); line-height: 1.1; color: var(--gray-900); margin: 0 0 1rem;
}
.bvcaas-h1 .text-gradient { background: var(--gradient-1); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }
.bvcaas-sub { color: var(--gray-600); font-size: 1.1rem; line-height: 1.7; margin: 0 auto 1.75rem; max-width: 620px; }

/* ============ Compliance Checklist ============ */
.bvchk-wrap { max-width: 760px; margin: 0 auto; padding-bottom: 4rem; }
.bvchk-progress { background: var(--white); border: 1px solid var(--gray-200); border-radius: 16px; padding: 1.25rem 1.5rem; margin-bottom: 1.75rem; box-shadow: 0 10px 25px -18px rgba(37,99,235,.25); position: sticky; top: 80px; z-index: 5; }
.bvchk-progress-top { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: .65rem; }
.bvchk-progress-label { font-weight: 700; color: var(--gray-900); font-size: .98rem; }
.bvchk-progress-count { font-weight: 800; color: var(--primary-600); font-family: 'Outfit', sans-serif; }
.bvchk-bar { height: 9px; background: var(--gray-100); border-radius: 999px; overflow: hidden; }
.bvchk-bar-fill { height: 100%; width: 0; background: var(--gradient-1); border-radius: 999px; transition: width .4s ease; }

.bvchk-item { display: flex; gap: 1rem; background: var(--white); border: 1px solid var(--gray-200); border-radius: 16px; padding: 1.25rem 1.4rem; margin-bottom: 1rem; transition: border-color .2s, box-shadow .2s, background .2s; }
.bvchk-item.done { border-color: rgba(16,185,129,.4); background: rgba(16,185,129,.04); }
.bvchk-check { flex: 0 0 auto; width: 30px; height: 30px; border-radius: 50%; border: 2px solid var(--gray-300); background: var(--white); cursor: pointer; display: flex; align-items: center; justify-content: center; color: transparent; font-size: .8rem; transition: all .2s; margin-top: 2px; }
.bvchk-check:hover { border-color: var(--primary-400); }
.bvchk-item.done .bvchk-check { background: var(--success); border-color: var(--success); color: #fff; }
.bvchk-body { flex: 1; }
.bvchk-title { font-weight: 700; color: var(--gray-900); font-size: 1.05rem; margin: 0 0 .3rem; display: flex; align-items: center; gap: .5rem; flex-wrap: wrap; }
.bvchk-tag { font-size: .68rem; font-weight: 700; text-transform: uppercase; letter-spacing: .04em; padding: .15rem .5rem; border-radius: 6px; background: var(--primary-50); color: var(--primary-600); }
.bvchk-tag.free { background: rgba(16,185,129,.12); color: var(--success); }
.bvchk-desc { color: var(--gray-600); font-size: .94rem; line-height: 1.6; margin: 0 0 .65rem; }
.bvchk-cta { font-weight: 700; font-size: .9rem; color: var(--primary-600); text-decoration: none; display: inline-flex; align-items: center; gap: .3rem; }
.bvchk-cta:hover { color: var(--primary-700); }
.bvchk-item.done .bvchk-cta { color: var(--success); }

/* ============ Business Setup hub ============ */
.bvcaas-section { padding: 1rem 0 4rem; }

/* Hero kit card */
.bvkit { max-width: 880px; margin: 0 auto 3.5rem; background: var(--white); border-radius: 24px; border: 2px solid var(--primary-200); box-shadow: 0 30px 60px -30px rgba(37,99,235,.35); overflow: hidden; }
.bvkit-head { background: var(--gradient-1); color: #fff; padding: 2rem 2.25rem; display: flex; justify-content: space-between; align-items: center; gap: 1rem; flex-wrap: wrap; }
.bvkit-head-l h3 { font-family: 'Outfit', sans-serif; font-weight: 800; font-size: 1.6rem; margin: 0 0 .35rem; color: #fff !important; }
.bvkit-head-l p { margin: 0; opacity: .92; font-size: .98rem; color: #fff !important; }
/* gradient header is fixed-blue in BOTH themes -> keep all header text white */
.bvkit-head, .bvkit-head * { color: #fff !important; }
.bvkit-price { text-align: right; }
.bvkit-price .amt { font-family: 'Outfit', sans-serif; font-weight: 800; font-size: 2.4rem; line-height: 1; }
.bvkit-price .note { display: block; font-size: .8rem; opacity: .9; margin-top: .25rem; }
.bvkit-body { padding: 2rem 2.25rem; }
.bvkit-grid { display: grid; grid-template-columns: 1fr 1fr; gap: .8rem 2rem; margin-bottom: 1.75rem; }
.bvkit-grid li { list-style: none; display: flex; gap: .6rem; align-items: flex-start; color: var(--gray-700); font-size: .98rem; line-height: 1.5; }
.bvkit-grid li i { color: var(--success); margin-top: .25rem; flex: 0 0 auto; }
.bvkit-foot { display: flex; align-items: center; gap: 1rem; flex-wrap: wrap; }

/* Service cards */
.bvsvc-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.25rem; max-width: 1080px; margin: 0 auto; }
.bvsvc-card { background: var(--white); border: 1px solid var(--gray-200); border-radius: 18px; padding: 1.6rem; display: flex; flex-direction: column; transition: border-color .2s, box-shadow .2s, transform .2s; }
.bvsvc-card:hover { border-color: var(--primary-200); box-shadow: 0 18px 35px -22px rgba(37,99,235,.3); transform: translateY(-3px); }
.bvsvc-icon { width: 46px; height: 46px; border-radius: 12px; background: var(--primary-50); color: var(--primary-600); display: flex; align-items: center; justify-content: center; font-size: 1.2rem; margin-bottom: 1rem; }
.bvsvc-name { font-weight: 700; color: var(--gray-900); font-size: 1.1rem; margin: 0 0 .3rem; }
.bvsvc-price { font-family: 'Outfit', sans-serif; font-weight: 800; color: var(--primary-600); font-size: 1.4rem; margin: 0 0 .6rem; }
.bvsvc-price small { font-size: .8rem; font-weight: 600; color: var(--gray-500); }
.bvsvc-desc { color: var(--gray-600); font-size: .92rem; line-height: 1.6; margin: 0 0 1.25rem; flex: 1; }

/* Trust row + disclaimer */
.bvcaas-trust { display: flex; justify-content: center; gap: 2.5rem; flex-wrap: wrap; max-width: 880px; margin: 0 auto 1rem; }
.bvcaas-trust div { display: flex; align-items: center; gap: .6rem; color: var(--gray-600); font-size: .95rem; font-weight: 600; }
.bvcaas-trust i { color: var(--success); }
.bvcaas-disclaimer { max-width: 760px; margin: 2.5rem auto 0; padding: 1.1rem 1.4rem; background: var(--gray-50); border: 1px solid var(--gray-200); border-radius: 12px; color: var(--gray-500); font-size: .85rem; line-height: 1.6; text-align: center; }

/* ---- Illustrated steps (homepage .steps + an illustration on top) ---- */
.bvsteps-ill .step-img { width: 112px; height: 112px; margin: 0 auto .5rem; display: block; }
.bvsteps-ill .step-img img { width: 100%; height: 100%; object-fit: contain; filter: drop-shadow(0 14px 22px rgba(37,99,235,.16)); }
.bvsteps-ill .step-num { width: 30px; height: 30px; font-size: .95rem; margin: 0 auto .9rem; box-shadow: 0 6px 16px rgba(59,130,246,.3); }

/* ---- Product UI mockup (reuses .preview-card; Stripe-style) ---- */
.bvmock-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 3.5rem; align-items: center; max-width: 1040px; margin: 0 auto; }
.bvmock-grid .bvmock-copy h2 { font-family: 'Outfit', sans-serif; font-weight: 800; font-size: clamp(1.5rem, 3vw, 2.1rem); color: var(--gray-900); margin: 0 0 1rem; line-height: 1.15; }
.bvmock-grid .bvmock-copy p { color: var(--gray-600); font-size: 1.05rem; line-height: 1.7; margin: 0 0 1.25rem; }
.bvmock-list { list-style: none; padding: 0; margin: 0; display: grid; gap: .7rem; }
.bvmock-list li { display: flex; gap: .65rem; align-items: flex-start; color: var(--gray-700); font-size: .98rem; }
.bvmock-list li i { color: var(--success); margin-top: .25rem; }
.bvmock-status { font-size: .68rem; font-weight: 700; padding: .2rem .55rem; border-radius: 6px; white-space: nowrap; }
.bvmock-status.done { background: rgba(16,185,129,.12); color: var(--success); }
.bvmock-status.prog { background: rgba(245,158,11,.14); color: #d97706; }
.bvmock-status.wait { background: var(--gray-100); color: var(--gray-500); }
.bvmock-bar { height: 8px; background: var(--gray-100); border-radius: 999px; overflow: hidden; margin-top: 1rem; }
.bvmock-bar span { display: block; height: 100%; width: 75%; background: var(--gradient-1); border-radius: 999px; }

@media (max-width: 860px) {
    .bvmock-grid { grid-template-columns: 1fr; gap: 2rem; }
    .bvsteps-ill .step-img { width: 92px; height: 92px; }
}

/* Waitlist modal (reuses simple overlay) */
.bvwl-overlay { position: fixed; inset: 0; background: rgba(15,23,42,.6); display: none; align-items: center; justify-content: center; z-index: 1000; padding: 1.25rem; }
.bvwl-overlay.is-open { display: flex; }
.bvwl-box { background: var(--white); border-radius: 20px; max-width: 420px; width: 100%; padding: 2rem; box-shadow: 0 30px 70px -20px rgba(0,0,0,.4); }
.bvwl-box h3 { font-family: 'Outfit', sans-serif; font-weight: 800; color: var(--gray-900); margin: 0 0 .5rem; font-size: 1.3rem; }
.bvwl-box p { color: var(--gray-600); font-size: .95rem; line-height: 1.6; margin: 0 0 1.25rem; }
.bvwl-box input { width: 100%; box-sizing: border-box; border: 1.5px solid var(--gray-200); border-radius: 10px; padding: .8rem 1rem; font-family: inherit; font-size: 1rem; background: var(--gray-50); color: var(--gray-900); margin-bottom: 1rem; }
.bvwl-box input:focus { outline: none; border-color: var(--primary-500); background: var(--white); box-shadow: 0 0 0 3px rgba(59,130,246,.12); }
.bvwl-close { background: none; border: none; color: var(--gray-400); cursor: pointer; font-size: .85rem; margin-top: .5rem; width: 100%; }

@media (max-width: 860px) {
    .bvsvc-grid { grid-template-columns: 1fr; }
    .bvkit-grid { grid-template-columns: 1fr; }
    .bvkit-head { flex-direction: column; align-items: flex-start; }
    .bvkit-price { text-align: left; }
    .bvchk-progress { position: static; }
}
