/**
 * Envision Quotation Builder — front-end wizard.
 * Native CSS, no external libs. Inherits the theme's design tokens
 * (with safe fallbacks) so it matches the site automatically.
 */
.eqb {
	--eqb-primary: var(--color-primary, var(--burgundy-700, #740C3E));
	--eqb-accent: var(--color-secondary, var(--teal-400, #00CED1));
	--eqb-ink: var(--ink-900, #222222);
	--eqb-paper: #ffffff;
	--eqb-cream: var(--cream, var(--color-neutral, #F4EDEA));
	--eqb-line: rgba(116, 12, 62, 0.14);
	--eqb-radius: 14px;
	--eqb-shadow: 0 10px 30px rgba(34, 34, 34, 0.08);

	font-family: var(--font-body, inherit);
	color: var(--eqb-ink);
	max-width: 920px;
	margin: 0 auto;
	padding: 48px 20px 72px;
	position: relative;
}

/* Header + steps */
.eqb-head { text-align: center; margin-bottom: 28px; }
.eqb-title { font-family: var(--font-display, inherit); font-size: clamp(1.6rem, 3.5vw, 2.4rem); font-weight: 800; margin: 0 0 8px; color: var(--eqb-ink); }
.eqb-sub { color: rgba(34, 34, 34, 0.65); margin: 0 0 20px; font-size: 0.95rem; }

.eqb-steps { list-style: none; display: flex; justify-content: center; gap: 8px; padding: 0; margin: 0; flex-wrap: wrap; }
.eqb-steps li { display: flex; align-items: center; gap: 8px; font-size: 0.82rem; font-weight: 600; color: rgba(34, 34, 34, 0.5); padding: 6px 14px; border-radius: 999px; background: var(--eqb-cream); }
.eqb-steps li span { width: 22px; height: 22px; border-radius: 50%; display: grid; place-items: center; background: #fff; color: rgba(34, 34, 34, 0.5); font-size: 0.78rem; border: 1px solid var(--eqb-line); }
.eqb-steps li.is-active { color: #fff; background: var(--eqb-primary); }
.eqb-steps li.is-active span { background: #fff; color: var(--eqb-primary); border-color: transparent; }
.eqb-steps li.is-done span { background: var(--eqb-accent); color: #fff; }

/* Steps */
.eqb-step { display: none; animation: eqb-fade 0.35s ease; }
.eqb-step.is-active { display: block; }
@keyframes eqb-fade { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: none; } }
.eqb-step-top { display: flex; align-items: center; justify-content: space-between; gap: 12px; flex-wrap: wrap; margin-bottom: 16px; }
.eqb-step-h { font-family: var(--font-display, inherit); font-size: 1.2rem; font-weight: 700; margin: 0; }

.eqb-cur select { border: 1px solid var(--eqb-line); border-radius: 10px; padding: 8px 12px; background: #fff; font: inherit; color: var(--eqb-ink); cursor: pointer; }

/* Modern dropdowns (native <select>, no JS library) — custom chevron + focus ring */
.eqb select {
	-webkit-appearance: none; -moz-appearance: none; appearance: none;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='none' stroke='%23740C3E' stroke-width='2' stroke-linecap='round' stroke-linejoin='round' d='M1 1.5 6 6.5 11 1.5'/%3E%3C/svg%3E");
	background-repeat: no-repeat; background-position: right 13px center; background-size: 12px;
	padding-inline-end: 36px; transition: border-color 0.15s, box-shadow 0.15s;
}
.eqb[dir="rtl"] select { background-position: left 13px center; }
.eqb select:hover { border-color: var(--eqb-primary); }
.eqb select:focus { outline: none; border-color: var(--eqb-primary); box-shadow: 0 0 0 3px rgba(116, 12, 62, 0.13); }
.eqb select::-ms-expand { display: none; }

/* Service cards */
.eqb-services-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 14px; align-items: start; grid-auto-flow: row dense; }
.eqb-card { border: 1.5px solid var(--eqb-line); border-radius: var(--eqb-radius); background: var(--eqb-paper); overflow: hidden; transition: border-color 0.2s, box-shadow 0.2s, transform 0.2s; }
.eqb-card:hover { box-shadow: var(--eqb-shadow); transform: translateY(-2px); }
.eqb-card.is-selected { border-color: var(--eqb-accent); box-shadow: 0 0 0 3px rgba(0, 206, 209, 0.15); }
/* A selected rich card (has options/add-ons) expands to full width so its config
   gets room and the remaining short cards pack into a clean aligned row. */
.eqb-card.eqb-rich.is-selected { grid-column: 1 / -1; transform: none; }
.eqb-card.is-selected .eqb-optgroups { flex-direction: row; flex-wrap: wrap; gap: 14px; }
.eqb-card.is-selected .eqb-optgroup { flex: 1 1 220px; min-width: 0; }
.eqb-card-pick { display: block; padding: 16px; cursor: pointer; position: relative; }
.eqb-card-pick > input { position: absolute; inset-inline-start: 14px; top: 16px; width: 18px; height: 18px; accent-color: var(--eqb-primary); }
.eqb-card-box { display: block; padding-inline-start: 28px; }
.eqb-card-title { display: block; font-weight: 700; font-size: 1rem; }
.eqb-card-desc { display: block; font-size: 0.84rem; color: rgba(34, 34, 34, 0.6); margin: 4px 0 8px; line-height: 1.5; }
.eqb-card-price { display: block; font-weight: 800; color: var(--eqb-primary) !important; }
.eqb-card-price small { font-weight: 600; color: rgba(34, 34, 34, 0.5); font-size: 0.72rem; }

.eqb-card-config { border-top: 1px dashed var(--eqb-line); padding: 14px 16px; background: var(--eqb-cream); }
.eqb-optgroups { display: flex; flex-direction: column; gap: 10px; margin-bottom: 12px; }
.eqb-opt-label { display: block; font-size: 0.8rem; font-weight: 700; margin-bottom: 4px; color: rgba(34,34,34,0.72); }
.eqb-opt-select { width: 100%; border: 1.5px solid var(--eqb-line); border-radius: 10px; padding: 9px 10px; font: inherit; background: #fff; color: var(--eqb-ink); cursor: pointer; }
.eqb-opt-custom { display: flex; align-items: center; gap: 8px; margin-top: 7px; }
.eqb-opt-custom[hidden] { display: none; }
.eqb-opt-custom input { width: 96px; border: 1.5px solid var(--eqb-line); border-radius: 8px; padding: 7px 9px; font: inherit; }
.eqb-opt-hint { font-size: 0.8rem; color: var(--eqb-primary); font-weight: 600; }
.eqb-qty { display: flex; align-items: center; gap: 8px; font-size: 0.84rem; font-weight: 600; margin-bottom: 10px; }
.eqb-qty-btn { width: 30px; height: 30px; border: 1px solid var(--eqb-line); background: #fff; border-radius: 8px; cursor: pointer; font-size: 1rem; line-height: 1; color: var(--eqb-primary); }
.eqb-qty-input { width: 52px; text-align: center; border: 1px solid var(--eqb-line); border-radius: 8px; padding: 6px; font: inherit; }
.eqb-addons-fs { border: 0; padding: 0; margin: 0; display: grid; grid-template-columns: repeat(auto-fill, minmax(215px, 1fr)); gap: 8px 14px; }
.eqb-addons-fs legend { grid-column: 1 / -1; float: none; width: 100%; font-size: 0.78rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.04em; color: rgba(34, 34, 34, 0.55); margin-bottom: 2px; padding: 0; }
.eqb-addon-pick { display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: 9px; padding: 9px 11px; font-size: 0.84rem; line-height: 1.3; cursor: pointer; border: 1.5px solid var(--eqb-line); border-radius: 10px; background: #fff; transition: border-color 0.15s, background 0.15s; }
.eqb-addon-pick:hover { border-color: var(--eqb-primary); }
.eqb-addon-pick:has(input:checked) { border-color: var(--eqb-primary); background: var(--eqb-cream); }
.eqb-addon-pick input { accent-color: var(--eqb-primary); }
.eqb-addon-pick > span:not(.eqb-addon-price) { min-width: 0; word-break: break-word; }
.eqb-addon-price { white-space: nowrap; font-weight: 700; color: var(--eqb-primary); font-size: 0.8rem; text-align: end; }
.eqb-addon-price .eqb-was { font-weight: 600; }
.eqb-was { color: rgba(34,34,34,0.4); font-weight: 500; text-decoration: line-through; margin-inline-end: 4px; }

/* Fields */
.eqb-fields { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.eqb-field { display: flex; flex-direction: column; gap: 6px; font-size: 0.86rem; font-weight: 600; color: rgba(34, 34, 34, 0.75); }
.eqb-field-full { grid-column: 1 / -1; }
.eqb-field input, .eqb-field textarea, .eqb-field select { border: 1.5px solid var(--eqb-line); border-radius: 11px; padding: 11px 14px; font: inherit; color: var(--eqb-ink); background-color: var(--eqb-cream); outline: none; transition: border-color 0.2s, box-shadow 0.2s, background 0.2s; width: 100%; box-sizing: border-box; cursor: pointer; }
.eqb-field select { background-color: var(--eqb-cream); padding-inline-end: 38px; }
.eqb-field input:focus, .eqb-field textarea:focus, .eqb-field select:focus { border-color: var(--eqb-accent); box-shadow: 0 0 0 3px rgba(0, 206, 209, 0.15); background-color: #fff; }
.eqb-field.is-invalid input, .eqb-field.is-invalid textarea { border-color: #e53e3e; box-shadow: 0 0 0 3px rgba(229, 62, 62, 0.12); }

/* Review */
.eqb-review { border: 1px solid var(--eqb-line); border-radius: var(--eqb-radius); background: #fff; padding: 18px; }
.eqb-review-row { display: flex; justify-content: space-between; gap: 12px; padding: 8px 0; border-bottom: 1px solid var(--eqb-line); font-size: 0.92rem; }
.eqb-review-row:last-child { border-bottom: 0; }
.eqb-review-row .eqb-rl-name { font-weight: 600; }
.eqb-review-row .eqb-rl-sub { display: block; font-size: 0.78rem; color: rgba(34, 34, 34, 0.55); font-weight: 400; }
.eqb-review-tot { display: flex; justify-content: space-between; padding: 8px 0; font-size: 0.95rem; }
.eqb-review-tot.is-grand { font-size: 1.15rem; font-weight: 800; color: var(--eqb-primary); border-top: 2px solid var(--eqb-line); margin-top: 6px; padding-top: 12px; }

/* Sticky total + nav */
.eqb-bar { position: sticky; bottom: 0; display: flex; align-items: center; justify-content: space-between; gap: 14px; flex-wrap: wrap; background: #fff; border: 1px solid var(--eqb-line); border-radius: var(--eqb-radius); box-shadow: var(--eqb-shadow); padding: 14px 18px; margin-top: 22px; z-index: 5; }
.eqb-bar-label { display: block; font-size: 0.74rem; text-transform: uppercase; letter-spacing: 0.06em; color: rgba(34, 34, 34, 0.55); }
.eqb-bar-exvat { text-transform: none; letter-spacing: 0; font-weight: 600; opacity: 0.8; }
.eqb-bar-total strong { font-size: 1.5rem; font-weight: 800; color: var(--eqb-primary); }
.eqb-bar-recurring { display: block; font-size: 0.82rem; color: rgba(34, 34, 34, 0.6); }
.eqb-nav { display: flex; gap: 10px; align-items: center; }
/* Theme .edv-btn sets display, which overrides the [hidden] attribute — force it. */
.eqb-nav [hidden] { display: none !important; }
.eqb-btn-ghost { background: transparent; border: 1.5px solid var(--eqb-line); border-radius: 999px; padding: 11px 22px; font: inherit; font-weight: 600; cursor: pointer; color: var(--eqb-ink); }
.eqb-btn-ghost:hover { border-color: var(--eqb-primary); color: var(--eqb-primary); }

.eqb-trust { text-align: center; font-size: 0.82rem; color: rgba(34, 34, 34, 0.55); margin: 12px 0 0; }
.eqb-error { color: #c53030; font-size: 0.85rem; margin: 12px 0 0; font-weight: 600; }

/* Honeypot — visually hidden but present for bots */
.eqb-hp { position: absolute !important; left: -9999px !important; width: 1px; height: 1px; overflow: hidden; }

/* Success */
.eqb-success { text-align: center; border: 1px solid var(--eqb-line); border-radius: var(--eqb-radius); background: #fff; box-shadow: var(--eqb-shadow); padding: 40px 24px; }
.eqb-success-ic { width: 64px; height: 64px; border-radius: 50%; display: grid; place-items: center; margin: 0 auto 16px; color: #fff; font-size: 30px; background: linear-gradient(135deg, var(--eqb-primary), var(--eqb-accent)); }
.eqb-success h3 { font-family: var(--font-display, inherit); font-size: 1.5rem; margin: 0 0 6px; }
.eqb-success-id { font-weight: 800; color: var(--eqb-primary); letter-spacing: 0.04em; margin: 0 0 10px; }
.eqb-success-actions { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; margin-top: 18px; }
.eqb-btn-wa { display: inline-flex; align-items: center; gap: 8px; background: #25D366; color: #fff !important; padding: 12px 22px; border-radius: 999px; font-weight: 700; text-decoration: none; }

/* Exit-intent modal */
.eqb-exit { position: fixed; inset: 0; z-index: 9999; display: flex; align-items: center; justify-content: center; background: rgba(34, 34, 34, 0.55); padding: 20px; animation: eqb-fade 0.25s ease; }
.eqb-exit-box { position: relative; background: #fff; border-radius: 18px; max-width: 440px; width: 100%; padding: 32px 28px; box-shadow: 0 24px 70px rgba(0, 0, 0, 0.3); text-align: center; }
.eqb-exit-box h3 { font-family: var(--font-display, inherit); font-size: 1.4rem; margin: 0 0 8px; color: var(--eqb-ink); }
.eqb-exit-box p { color: rgba(34, 34, 34, 0.7); margin: 0 0 16px; font-size: 0.92rem; }
.eqb-exit-row { display: flex; gap: 8px; flex-wrap: wrap; }
.eqb-exit-row input { flex: 1; min-width: 160px; border: 1.5px solid var(--eqb-line); border-radius: 11px; padding: 12px 14px; font: inherit; }
.eqb-exit-close { position: absolute; top: 10px; inset-inline-end: 14px; background: none; border: 0; font-size: 26px; line-height: 1; cursor: pointer; color: rgba(34, 34, 34, 0.5); }
.eqb-exit-note { font-size: 0.84rem; margin: 12px 0 0; min-height: 1em; }
.eqb-exit-note.is-ok { color: #00845f; }

/* Loading state on buttons */
.edv-btn.is-loading, .eqb-btn-ghost.is-loading { opacity: 0.7; pointer-events: none; }

/* Responsive */
@media (max-width: 600px) {
	.eqb-fields { grid-template-columns: 1fr; }
	.eqb-bar { flex-direction: column; align-items: stretch; text-align: center; }
	.eqb-nav { justify-content: center; }
	.eqb-nav .edv-btn, .eqb-nav .eqb-btn-ghost { flex: 1; }
}

/* Budget over-limit warning */
.eqb-budget-warn { display: flex; align-items: flex-start; gap: 12px; margin-top: 14px; padding: 14px 16px; border: 1.5px solid #d97706; border-radius: var(--eqb-radius); background: #fffbeb; color: #92400e; font-size: 0.9rem; }
.eqb-budget-warn .eqb-bw-icon { font-size: 1.3rem; flex-shrink: 0; line-height: 1; }
.eqb-budget-warn strong { display: block; font-weight: 700; margin-bottom: 4px; }
.eqb-budget-warn p { margin: 0; }

/* VAT breakdown in review */
.eqb-review-sub { opacity: 0.7; font-size: 0.9rem; }
.eqb-incvat { font-weight: 400; font-size: 0.78em; opacity: 0.65; }

/* Project details */
.eqb-project { margin-top: 16px; border: 1px solid var(--eqb-line); border-radius: var(--eqb-radius); padding: 12px 16px; background: var(--eqb-paper); }
.eqb-project > summary { cursor: pointer; font-weight: 700; color: var(--eqb-primary); }
.eqb-project .eqb-fields { margin-top: 14px; }
.eqb-checks { display: flex; flex-wrap: wrap; gap: 8px 16px; }
.eqb-check { display: inline-flex; align-items: center; gap: 6px; font-weight: 500; font-size: 0.88rem; }
.eqb-check input { accent-color: var(--eqb-primary); }

/* Bundle presets */
.eqb-bundles { margin-bottom: 24px; }
.eqb-bundles-h { font-family: var(--font-display, inherit); font-size: 1rem; font-weight: 800; color: var(--eqb-ink); margin-bottom: 10px; }
.eqb-bundles-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }
.eqb-bundle-card { -webkit-appearance: none; appearance: none; position: relative; display: flex; flex-direction: column; gap: 4px; padding: 14px 14px 16px; border: 2px solid var(--eqb-line) !important; border-radius: 14px !important; background: #ffffff !important; color: var(--eqb-ink) !important; cursor: pointer; text-align: start; transition: border-color 0.15s, box-shadow 0.15s; }
.eqb-bundle-card:hover { border-color: color-mix(in srgb, var(--eqb-primary) 50%, transparent) !important; }
.eqb-bundle-card.is-active { border-color: var(--eqb-primary) !important; box-shadow: 0 0 0 1px var(--eqb-primary); background: color-mix(in srgb, var(--eqb-primary) 5%, #fff) !important; }
.eqb-bundle-badge { display: inline-block; background: var(--eqb-primary); color: #fff; font-size: 0.72rem; font-weight: 700; padding: 2px 8px; border-radius: 999px; margin-bottom: 4px; text-transform: uppercase; letter-spacing: 0.5px; }
.eqb-bundle-name { font-weight: 800; font-size: 1rem; color: var(--eqb-ink) !important; }
.eqb-bundle-desc { font-size: 0.8rem; color: rgba(34,34,34,0.65) !important; line-height: 1.4; }
.eqb-bundles-note { font-size: 0.82rem; color: rgba(34,34,34,0.55); margin: 8px 0 0; }
@media (max-width: 600px) { .eqb-bundles-grid { grid-template-columns: 1fr; } }

/* Add-on categories */
/* Override the original fieldset grid — categories stack vertically; items grid inside each one */
.eqb-addons-fs { display: block !important; margin-top: 14px; }
.eqb-addons-h { font-weight: 700; font-size: 0.9rem; color: var(--eqb-primary); margin-bottom: 8px; }
.eqb-addon-cat { border: 1px solid var(--eqb-line); border-radius: 10px; margin-bottom: 8px; overflow: hidden; }
.eqb-addon-cat-h { cursor: pointer; padding: 9px 12px; font-weight: 700; font-size: 0.88rem; color: var(--eqb-ink); background: var(--eqb-cream); list-style: none; display: flex; justify-content: space-between; align-items: center; user-select: none; }
.eqb-addon-cat-h::after { content: "\25BE"; font-size: 0.8rem; transition: transform 0.2s; }
.eqb-addon-cat[open] > .eqb-addon-cat-h::after { transform: rotate(180deg); }
/* Items inside each category use the original responsive grid */
.eqb-addon-cat-body { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 6px 10px; padding: 10px 10px 12px; }
@media (max-width: 640px) {
	.eqb-addon-cat-body { grid-template-columns: 1fr; }
	.eqb-addon-cat[open] > .eqb-addon-cat-h { background: color-mix(in srgb, var(--eqb-primary) 8%, #fff); }
}

/* Social proof trust block (step 3) */
.eqb-trust-block { margin-top: 18px; padding: 16px 18px; border: 1px solid var(--eqb-line); border-radius: var(--eqb-radius); background: var(--eqb-cream); }
.eqb-tb-badge { display: flex; align-items: center; gap: 8px; margin-bottom: 10px; }
.eqb-tb-stars { color: #f59e0b; font-size: 1rem; letter-spacing: 1px; }
.eqb-tb-rating { font-weight: 700; font-size: 0.88rem; color: var(--eqb-ink); }
.eqb-tb-quote { margin: 0 0 10px; padding: 0; border: none; }
.eqb-tb-quote p { font-style: italic; color: rgba(34,34,34,0.8); font-size: 0.9rem; margin: 0 0 4px; line-height: 1.5; }
.eqb-tb-quote cite { font-size: 0.82rem; font-style: normal; color: rgba(34,34,34,0.55); font-weight: 600; }
.eqb-tb-reassure { margin: 0; font-size: 0.84rem; font-weight: 600; color: #00845f; }

/* Installment plan picker */
.eqb-plan-pick { margin-top: 18px; border: 1px solid var(--eqb-line); border-radius: var(--eqb-radius); padding: 16px 18px; background: var(--eqb-cream); }
.eqb-plan-title { font-weight: 800; color: var(--eqb-primary); margin-bottom: 4px; }
.eqb-plan-note { font-size: 0.85rem; color: rgba(34,34,34,0.6); margin: 0 0 12px; }
.eqb-plan-opt { display: flex; align-items: center; gap: 9px; padding: 8px 10px; border: 1.5px solid var(--eqb-line); border-radius: 10px; background: #fff; margin-bottom: 8px; cursor: pointer; font-weight: 600; }
.eqb-plan-opt input { accent-color: var(--eqb-primary); }
.eqb-plan-detail:not(:empty) { margin-top: 10px; background: #fff; border-radius: 10px; padding: 12px 14px; border: 1px solid var(--eqb-line); }
.eqb-plan-sum { display: flex; justify-content: space-between; font-size: 0.95rem; padding: 3px 0; }
.eqb-plan-sum strong { color: var(--eqb-primary); }
.eqb-plan-table { width: 100%; border-collapse: collapse; margin-top: 8px; }
.eqb-plan-table td { padding: 6px 8px; border-top: 1px solid var(--eqb-line); font-size: 0.88rem; }
.eqb-plan-table td:last-child { text-align: end; font-weight: 600; }

/* Domain selection */
.eqb-domain { margin-top: 16px; border: 1px solid var(--eqb-line); border-radius: var(--eqb-radius); padding: 16px 18px; background: var(--eqb-cream); }
.eqb-domain-h { font-weight: 800; color: var(--eqb-primary); }
.eqb-domain-sub { font-size: 0.85rem; color: rgba(34,34,34,0.6); margin: 4px 0 12px; }
.eqb-domain-modes { display: flex; flex-wrap: wrap; gap: 8px 14px; margin-bottom: 12px; }
.eqb-dm-opt { display: inline-flex; align-items: center; gap: 8px; padding: 8px 12px; border: 1.5px solid var(--eqb-line); border-radius: 10px; background: #fff; cursor: pointer; font-weight: 600; font-size: 0.9rem; }
.eqb-dm-opt input { accent-color: var(--eqb-primary); }
.eqb-domain-search { display: flex; gap: 8px; flex-wrap: wrap; }
.eqb-domain-search input, .eqb-domain-existing input { flex: 1; min-width: 180px; border: 1.5px solid var(--eqb-line); border-radius: 11px; padding: 12px 14px; font: inherit; }
.eqb-domain-search .edv-btn { white-space: nowrap; }
.eqb-domain-result { margin-top: 12px; font-size: 0.9rem; }
.eqb-domain-result.is-bad { color: #b3261e; }
.eqb-domain-result.is-warn { color: #8a6d00; }
.eqb-domain-result.is-loading { color: rgba(34,34,34,0.6); }
.eqb-dr-row { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.eqb-dr-name { font-weight: 700; }
.eqb-dr-tag { background: #00845f; color: #fff; border-radius: 999px; padding: 2px 10px; font-size: 0.78rem; font-weight: 700; }
.eqb-dr-price { font-weight: 700; color: var(--eqb-primary); }
.eqb-dr-pick { margin-top: 10px; }
.eqb-domain-note { font-size: 0.82rem; color: rgba(34,34,34,0.6); margin: 8px 0 0; }

/* Final step: payment / callback */
.eqb-final { margin-top: 18px; border: 1px solid var(--eqb-line); border-radius: var(--eqb-radius); padding: 16px 18px; background: var(--eqb-paper); }
.eqb-final-h { font-weight: 800; color: var(--eqb-primary); margin-bottom: 12px; }
.eqb-final-modes { display: flex; flex-direction: column; gap: 10px; margin-bottom: 14px; }
.eqb-fm-opt { display: flex; align-items: flex-start; gap: 12px; padding: 14px 16px; border: 1.5px solid var(--eqb-line); border-radius: 12px; background: #fff; cursor: pointer; }
.eqb-fm-opt input { accent-color: var(--eqb-primary); margin-top: 3px; flex-shrink: 0; }
.eqb-fm-inner { display: flex; flex-direction: column; gap: 2px; }
.eqb-fm-title { font-weight: 700; font-size: 0.97rem; }
.eqb-fm-sub { font-size: 0.82rem; color: rgba(34,34,34,0.6); }
.eqb-fm-primary { border-color: var(--eqb-primary); background: color-mix(in srgb, var(--eqb-primary) 5%, #fff); }
.eqb-fm-primary .eqb-fm-title { color: var(--eqb-primary); }
.eqb-fm-secondary { opacity: 0.85; }
.eqb-fm-opt:has(input:checked) { border-color: var(--eqb-primary); background: color-mix(in srgb, var(--eqb-primary) 7%, #fff); box-shadow: 0 0 0 1px var(--eqb-primary); }
.eqb-pay-pick { display: flex; flex-direction: column; gap: 6px; font-weight: 600; max-width: 320px; }
.eqb-pay-pick select { border: 1.5px solid var(--eqb-line); border-radius: 11px; padding: 11px 12px; font: inherit; background-color: #fff; padding-inline-end: 36px; }
.eqb-pay-info:not(:empty) { margin-top: 14px; background: var(--eqb-cream); border: 1px solid var(--eqb-line); border-radius: 12px; padding: 14px 16px; }
.eqb-pi-num { display: flex; align-items: center; justify-content: space-between; gap: 12px; flex-wrap: wrap; }
.eqb-pi-label { display: block; font-size: 0.78rem; color: rgba(34,34,34,0.6); }
.eqb-pi-val { font-weight: 800; color: var(--eqb-primary); font-size: 1.02rem; letter-spacing: 0.3px; }
.eqb-pi-copy { border: 1.5px solid var(--eqb-primary); color: var(--eqb-primary); background: #fff; border-radius: 9px; padding: 7px 14px; font: inherit; font-weight: 700; cursor: pointer; }
.eqb-pi-hint { font-size: 0.82rem; color: rgba(34,34,34,0.65); margin: 10px 0 0; }
.eqb-pi-qr { text-align: center; margin-bottom: 12px; }
.eqb-pi-qr img { width: 180px; height: 180px; border-radius: 12px; background: #fff; padding: 8px; border: 1px solid var(--eqb-line); }
.eqb-pi-bank { font-size: 0.9rem; line-height: 1.6; }

/* Screen-reader helper if the theme lacks one */
.eqb .screen-reader-text { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(1px, 1px, 1px, 1px); white-space: nowrap; }
