/* ============================================================
   Pricing Page — self-contained styles
   Scoped to .bk-pricing-page so the design system tokens and
   utility classes don't leak into the rest of the site or
   collide with the global header/footer chrome.
   ============================================================ */

/* ---------- Font notes ----------
   Inter is loaded globally via templates/core/fonts.twig in the full
   100–900 weight range for both styles — don't re-register locally.
   DM Serif Display Regular is loaded globally via templates/core/fonts.twig
   (only the headline use on this page needs it — italic is not used). */

/* ---------- Tokens ---------- */
.bk-pricing-page {
	--bk-blue: #008DF3;
	--bk-blue-light: #30B2FB;
	--bk-blue-deep: #1077D7;
	--bk-blue-hover: #229EE4;
	--bk-cyan: #7ECFFD;
	--bk-cyan-body: #A5DEFD;
	--bk-darkblue: #061A31;
	--bk-green: #31E48B;

	--bk-gradient-hero: linear-gradient(65deg, #061A31 0%, #004B87 66%, #008DF3 100%);
	--bk-gradient-cta-desktop: linear-gradient(152deg, #30B2FB 17.53%, #1077D7 86.53%);
	--bk-gradient-cta-hover: linear-gradient(100deg, #008DF3 17.53%, #229EE4 86.53%);
	--bk-gradient-title-vert: linear-gradient(180deg, #008DF3 5.71%, #7ECFFD 100%);
	--bk-gradient-title-horiz: linear-gradient(91deg, #061A31 0.07%, #008DF3 100.07%);

	--bk-text-default: #101828;
	--bk-text-heading: #061A31;
	--bk-text-cool: #304069;
	--bk-text-muted: #475467;
	--bk-text-meta-dark: #6A7695;
	--bk-bg-info-light: #EBF8FF;
	--bk-border: #ECF0F8;
	--bk-border-input: #DDE3F3;
	--bk-border-white-cta: #D0D5DD;

	--bk-shadow-micro: 0px 1px 2px 0px rgba(16, 24, 40, 0.05);
	--bk-shadow-testimonial: 0 4px 12px rgba(0, 0, 0, 0.06);
	--bk-shadow-testimonial-hover: 0 8px 24px rgba(0, 0, 0, 0.08);
	--bk-shadow-signature: 0px 24px 64px 0px rgba(0, 0, 0, 0.10);
	--bk-shadow-halo: 0px 0px 8px 8px rgba(0, 0, 0, 0.03);

	--bk-font-display: "DM Serif Display", Georgia, "Times New Roman", serif;
	--bk-font-body: "Inter", system-ui, -apple-system, "Segoe UI", sans-serif;

	font-family: var(--bk-font-body);
	color: var(--bk-text-default);
	-webkit-font-smoothing: antialiased;
	background: #fff;
	overflow-x: clip;
}

/* ---------- Box-sizing reset (scoped) ---------- */
.bk-pricing-page,
.bk-pricing-page *,
.bk-pricing-page *::before,
.bk-pricing-page *::after {
	box-sizing: border-box;
}

/* Reset element spacing inside the page so global theme rules
   (h1/h2 margins, p margins, ul/li padding) don't leak in. */
.bk-pricing-page h1,
.bk-pricing-page h2,
.bk-pricing-page h3,
.bk-pricing-page h4,
.bk-pricing-page p,
.bk-pricing-page ul,
.bk-pricing-page ol,
.bk-pricing-page li,
.bk-pricing-page table,
.bk-pricing-page th,
.bk-pricing-page td {
	margin: 0;
	padding: 0;
}

.bk-pricing-page ul { list-style: none; }
.bk-pricing-page img { max-width: 100%; display: block; }
.bk-pricing-page a { text-decoration: none; color: inherit; }
.bk-pricing-page a:hover { text-decoration: none; }
.bk-pricing-page button { font-family: inherit; cursor: pointer; border: 0; background: transparent; padding: 0; }

/* ---------- Layout primitives ---------- */
.bk-pricing-page .bk-in { max-width: 1220px; margin: 0 auto; padding: 0 24px; }
.bk-pricing-page .bk-in--narrow { max-width: 840px; margin: 0 auto; padding: 0 24px; }
.bk-pricing-page .bk-in--wide { max-width: 1332px; margin: 0 auto; padding: 0 24px; }

/* ---------- Buttons ---------- */
.bk-pricing-page .bk-btn {
	display: inline-flex; align-items: center; gap: 10px;
	padding: 14px 28px; border-radius: 8px;
	font-size: 16px; font-weight: 600;
	text-decoration: none; border: 0; line-height: 1.2;
	transition: transform .2s, box-shadow .2s, background .3s;
	font-family: inherit; cursor: pointer; white-space: nowrap;
}
.bk-pricing-page .bk-btn--large { padding: 18px 44px; font-size: 17px; }
.bk-pricing-page .bk-btn--gradient {
	background: var(--bk-gradient-cta-desktop);
	border: 1px solid var(--bk-blue);
	color: #fff;
	box-shadow: var(--bk-shadow-micro);
	position: relative; overflow: hidden;
}
.bk-pricing-page .bk-btn--gradient:hover {
	background: var(--bk-gradient-cta-hover);
	transform: translateY(-2px);
	color: #fff;
}
.bk-pricing-page .bk-btn--ghost-dark {
	background: transparent;
	border: 1px solid rgba(255,255,255,0.25);
	color: #fff; font-weight: 600;
}
.bk-pricing-page .bk-btn--ghost-dark:hover {
	border-color: rgba(255,255,255,0.6);
	background: rgba(255,255,255,0.04);
	color: #fff;
}
.bk-pricing-page .bk-btn--block { width: 100%; justify-content: center; }

/* ---------- Shared titleboxes ---------- */
.bk-pricing-page .bk-titlebox { margin-bottom: 56px; }
.bk-pricing-page .bk-titlebox--center {
	text-align: center; max-width: 720px;
	margin-left: auto; margin-right: auto; margin-bottom: 56px;
}
.bk-pricing-page .bk-titlebox .eyebrow {
	font-family: var(--bk-font-body);
	font-size: 13px; font-weight: 700;
	letter-spacing: 5px; text-transform: uppercase;
	color: var(--bk-blue); margin-bottom: 16px; display: block;
}
.bk-pricing-page .on-dark .bk-titlebox .eyebrow,
.bk-pricing-page .on-dark .eyebrow { color: var(--bk-cyan); }

.bk-pricing-page .bk-title--2 {
	font-family: var(--bk-font-display);
	font-size: clamp(40px, 5vw, 64px);
	line-height: 1.1; letter-spacing: -1px;
	margin: 0 0 16px; font-weight: 400;
	color: var(--bk-text-heading);
}
.bk-pricing-page .on-dark .bk-title--2 { color: #fff; }
.bk-pricing-page .bk-title--2 span,
.bk-pricing-page .bk-title--2 b,
.bk-pricing-page .bk-title--2 strong {
	background: var(--bk-gradient-title-vert);
	-webkit-background-clip: text;
	background-clip: text;
	-webkit-text-fill-color: transparent;
	color: transparent; font-weight: 400;
}

.bk-pricing-page .lede {
	font-family: var(--bk-font-body);
	font-size: 19px; line-height: 1.55;
	color: var(--bk-text-cool); font-weight: 300;
	max-width: 620px; margin: 0 auto;
}
.bk-pricing-page .on-dark .lede { color: var(--bk-cyan-body); }

/* ---------- Sections ---------- */
.bk-pricing-page section { position: relative; }
.bk-pricing-page .bk-section { padding: 120px 0; position: relative; }
.bk-pricing-page .bk-section--dark { background: var(--bk-darkblue); color: #fff; }
.bk-pricing-page .bk-section--dark-deeper { background: #051426; color: #fff; }
.bk-pricing-page .bk-section--light { background: #fff; color: var(--bk-text-default); }
.bk-pricing-page .bk-section--snow { background: #F7F9FC; color: var(--bk-text-default); }

/* ===============================================================
   S1 — Hero
   =============================================================== */
.bk-pricing-page .bk-hero {
	background: var(--bk-gradient-hero);
	background-size: 180% 180%;
	animation: bk-grad 9s ease infinite;
	color: #fff;
	padding: 128px 0 112px;
	position: relative; overflow: hidden;
}
@keyframes bk-grad {
	0%, 100% { background-position: 0% 50%; }
	50% { background-position: 100% 50%; }
}
.bk-pricing-page .bk-hero__glow {
	position: absolute; pointer-events: none;
	width: 1100px; height: 1100px; border-radius: 50%;
	background: radial-gradient(circle at center, rgba(126,207,253,0.18), transparent 60%);
	top: -40%; right: -25%; filter: blur(10px);
}
.bk-pricing-page .bk-hero__in {
	position: relative; z-index: 1;
	max-width: 1100px; margin: 0 auto; padding: 0 24px;
	text-align: center;
}
.bk-pricing-page .bk-hero__eyebrow {
	display: inline-flex; align-items: center; gap: 12px;
	background: rgba(255,255,255,0.08);
	border: 1px solid rgba(255,255,255,0.14);
	backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px);
	border-radius: 100px; padding: 7px 16px 7px 7px;
	font-size: 12px; color: #EAECF0; margin-bottom: 28px;
	letter-spacing: .4px;
}
.bk-pricing-page .bk-hero__eyebrow-pill {
	background: #fff; color: var(--bk-blue);
	border-radius: 100px; padding: 4px 12px;
	font-size: 10px; font-weight: 800; letter-spacing: 1px;
	text-transform: uppercase;
}
.bk-pricing-page .bk-hero__title {
	font-family: var(--bk-font-display);
	font-size: clamp(44px, 6.5vw, 88px);
	line-height: 1.05; letter-spacing: -1.8px;
	margin: 0 0 24px; font-weight: 400; color: #fff;
}
.bk-pricing-page .bk-hero__title span {
	background: var(--bk-gradient-title-vert);
	-webkit-background-clip: text; background-clip: text;
	-webkit-text-fill-color: transparent; color: transparent;
}
.bk-pricing-page .bk-hero__sub {
	font-size: 19px; line-height: 1.55; color: #EAECF0;
	max-width: 620px; margin: 0 auto 32px; font-weight: 300;
}
.bk-pricing-page .bk-hero__sub b { font-weight: 500; color: #fff; }
.bk-pricing-page .bk-hero__cta {
	display: inline-flex; gap: 12px; flex-wrap: wrap;
	justify-content: center; margin-bottom: 44px;
}
.bk-pricing-page .bk-hero__trust {
	display: flex; gap: 28px;
	justify-content: center; flex-wrap: wrap;
}
.bk-pricing-page .bk-hero__trust-item {
	display: flex; align-items: center; gap: 10px;
	font-size: 13px; color: rgba(234,236,240,0.82);
	font-weight: 500; letter-spacing: .2px;
}
.bk-pricing-page .bk-hero__trust-item svg { color: var(--bk-cyan); flex-shrink: 0; }

/* ===============================================================
   S2 — Plan context cards
   =============================================================== */
.bk-pricing-page .bk-plans-grid {
	display: grid;
	/* Column count tracks the live plan lineup. pricing.js sets --plan-count
	   from PLANS.length on render; fallback of 3 covers the post-May-2026
	   layout if the inline style is somehow absent. Mobile breakpoints below
	   override this to 2-col / 1-col. */
	grid-template-columns: repeat(var(--plan-count, 3), 1fr);
	gap: 20px;
}
.bk-pricing-page .bk-plan {
	background: rgba(255,255,255,0.03);
	border: 1px solid rgba(255,255,255,0.08);
	border-radius: 24px; padding: 28px;
	display: flex; flex-direction: column;
	transition: transform .25s, border-color .25s, background .25s;
	position: relative; overflow: hidden;
}
.bk-pricing-page .bk-plan:hover {
	transform: translateY(-4px);
	border-color: rgba(126,207,253,0.35);
	background: rgba(255,255,255,0.05);
}
.bk-pricing-page .bk-plan--feat {
	border-color: var(--bk-blue);
	background: linear-gradient(180deg, rgba(0,141,243,0.12), rgba(0,141,243,0.02));
}
.bk-pricing-page .bk-plan--feat::before {
	content: ""; position: absolute;
	top: 0; left: 24px; right: 24px; height: 4px;
	background: linear-gradient(91deg, var(--bk-darkblue) 0%, var(--bk-blue) 100%);
}
.bk-pricing-page .bk-plan__badge {
	display: inline-block;
	font-family: var(--bk-font-body);
	font-style: italic; font-weight: 400;
	text-transform: uppercase; letter-spacing: 2px;
	font-size: 10px; padding: 5px 10px;
	border-radius: 6px; margin-bottom: 14px;
	align-self: flex-start;
}
.bk-pricing-page .bk-plan__badge--popular { background: var(--bk-blue); color: #fff; }
.bk-pricing-page .bk-plan__badge--price {
	background: rgba(126,207,253,0.15);
	color: var(--bk-cyan);
	border: 1px solid rgba(126,207,253,0.25);
}
.bk-pricing-page .bk-plan__badge--ghost { visibility: hidden; }
.bk-pricing-page .bk-plan__name {
	font-family: var(--bk-font-display);
	font-size: 26px; line-height: 1.15; color: #fff;
	margin-bottom: 10px; font-weight: 400;
}
.bk-pricing-page .bk-plan__desc {
	font-size: 14px; color: var(--bk-cyan-body);
	line-height: 1.55; margin-bottom: 22px; font-weight: 300;
}
.bk-pricing-page .bk-plan__bestfor-label {
	font-family: var(--bk-font-body);
	font-style: italic; font-weight: 800;
	text-transform: uppercase; letter-spacing: 2px;
	font-size: 11px; color: var(--bk-cyan); margin-bottom: 12px;
}
.bk-pricing-page .bk-plan__bullets { list-style: none; padding: 0; margin: 0 0 20px; }
.bk-pricing-page .bk-plan__bullets li {
	font-size: 13.5px; color: #E3ECF4; line-height: 1.5;
	padding-left: 22px; position: relative;
	margin-bottom: 10px; font-weight: 300;
}
.bk-pricing-page .bk-plan__bullets li svg { position: absolute; left: 0; top: 3px; color: var(--bk-blue); }
.bk-pricing-page .bk-plan__tradeoff {
	margin-top: auto; padding-top: 18px;
	border-top: 1px solid rgba(255,255,255,0.08);
	font-size: 12.5px; color: rgba(165,222,253,0.75);
	line-height: 1.55;
}
.bk-pricing-page .bk-plan__tradeoff b {
	color: #fff; font-weight: 600;
	display: block; margin-bottom: 3px;
	font-size: 11px; text-transform: uppercase;
	letter-spacing: 1.5px; font-style: italic;
}
.bk-pricing-page .bk-plans-transition {
	text-align: center; margin-top: 48px;
	font-size: 15px; color: var(--bk-cyan-body); font-weight: 300;
}
.bk-pricing-page .bk-plans-transition a {
	color: var(--bk-cyan);
	border-bottom: 1px solid rgba(126,207,253,0.35);
	padding-bottom: 1px;
}
.bk-pricing-page .bk-plans-transition a:hover { border-bottom-color: var(--bk-cyan); }
.bk-pricing-page .bk-plans-transition-sep { display: inline-block; margin: 0 18px; opacity: .5; }

/* ===============================================================
   S3 — Plan finder (quiz)
   =============================================================== */
.bk-pricing-page .bk-quiz {
	max-width: 880px; margin: 0 auto;
	background: #fff; border-radius: 32px;
	border: 1px solid var(--bk-border);
	box-shadow: var(--bk-shadow-signature);
	padding: 48px; position: relative; overflow: hidden;
}
.bk-pricing-page .bk-quiz::before {
	content: ""; position: absolute;
	top: 0; left: 40px; right: 40px; height: 4px;
	background: linear-gradient(91deg, var(--bk-darkblue), var(--bk-blue));
}
.bk-pricing-page .bk-quiz__step { margin-bottom: 32px; }
.bk-pricing-page .bk-quiz__step:last-of-type { margin-bottom: 0; }
.bk-pricing-page .bk-quiz__label {
	display: flex; align-items: center; gap: 12px;
	font-family: var(--bk-font-body);
	font-style: italic; font-weight: 800;
	font-size: 14px; letter-spacing: 2px;
	text-transform: uppercase; color: var(--bk-text-heading);
	margin-bottom: 18px;
}
.bk-pricing-page .bk-quiz__num {
	width: 26px; height: 26px; border-radius: 50%;
	background: var(--bk-blue); color: #fff;
	display: inline-flex; align-items: center; justify-content: center;
	font-family: var(--bk-font-display);
	font-size: 14px; font-style: normal; letter-spacing: 0;
}
.bk-pricing-page .bk-quiz__opts {
	display: flex; gap: 8px; flex-wrap: wrap;
}
.bk-pricing-page .bk-pill {
	padding: 11px 20px; border-radius: 100px;
	background: #fff; border: 1px solid var(--bk-border-input);
	font-family: inherit; font-size: 14px; font-weight: 600;
	color: var(--bk-text-heading); transition: all .15s; cursor: pointer;
}
.bk-pricing-page .bk-pill:hover { border-color: var(--bk-blue); color: var(--bk-blue); }
.bk-pricing-page .bk-pill.is-active {
	background: var(--bk-blue); border-color: var(--bk-blue); color: #fff;
}
.bk-pricing-page .bk-quiz__cards {
	display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px;
}
.bk-pricing-page .bk-quiz__cards--3 { grid-template-columns: repeat(3, 1fr); }
.bk-pricing-page .bk-qcard {
	padding: 16px 18px; border-radius: 12px;
	background: #fff; border: 1px solid var(--bk-border-input);
	cursor: pointer; text-align: left;
	transition: all .15s; font-family: inherit;
}
.bk-pricing-page .bk-qcard:hover { border-color: var(--bk-blue); }
.bk-pricing-page .bk-qcard.is-active {
	border-color: var(--bk-blue);
	background: #EBF8FF;
	box-shadow: 0 0 0 3px rgba(0,141,243,0.10);
}
.bk-pricing-page .bk-qcard__title {
	font-size: 14px; font-weight: 700;
	color: var(--bk-text-heading); margin-bottom: 3px;
}
.bk-pricing-page .bk-qcard__desc {
	font-size: 12.5px; color: var(--bk-text-muted);
	line-height: 1.45; font-weight: 400;
}
.bk-pricing-page .bk-quiz__result {
	margin-top: 40px; background: var(--bk-darkblue);
	border-radius: 24px; padding: 36px; color: #fff;
	position: relative; overflow: hidden; display: none;
}
.bk-pricing-page .bk-quiz__result::before {
	content: ""; position: absolute; inset: 0;
	background: radial-gradient(circle at 85% 0%, rgba(0,141,243,0.3), transparent 60%);
	pointer-events: none;
}
.bk-pricing-page .bk-quiz__result.is-visible {
	display: block;
	animation: qr-in .35s cubic-bezier(.16, 1, .3, 1);
}
@keyframes qr-in {
	from { opacity: 0; transform: translateY(-10px); }
	to { opacity: 1; transform: translateY(0); }
}
.bk-pricing-page .bk-qr__grid {
	position: relative;
	display: grid; grid-template-columns: 1fr auto;
	gap: 32px; align-items: center;
}
.bk-pricing-page .bk-qr__label {
	font-family: var(--bk-font-body);
	font-style: italic; font-weight: 800;
	font-size: 11px; letter-spacing: 2px;
	text-transform: uppercase; color: var(--bk-cyan);
	margin-bottom: 8px;
}
.bk-pricing-page .bk-qr__plan {
	font-family: var(--bk-font-display);
	font-size: 36px; line-height: 1.1;
	margin-bottom: 6px; color: #fff;
}
.bk-pricing-page .bk-qr__specs {
	font-size: 14px; color: var(--bk-cyan-body); font-weight: 300;
}
.bk-pricing-page .bk-qr__right { text-align: right; }
.bk-pricing-page .bk-qr__price {
	font-family: var(--bk-font-display);
	font-size: 56px; line-height: 1;
	color: var(--bk-blue); margin-bottom: 4px;
}
.bk-pricing-page .bk-qr__price-label {
	font-size: 12px; color: var(--bk-cyan-body);
	text-transform: uppercase; letter-spacing: 1px;
	font-weight: 500; margin-bottom: 18px;
}
.bk-pricing-page .bk-qr__cta { display: inline-block; }
.bk-pricing-page .bk-qr__fallback {
	text-align: center; margin-top: 20px;
	font-size: 13px; color: var(--bk-cyan-body);
	font-weight: 300; position: relative;
}
.bk-pricing-page .bk-qr__fallback a {
	color: var(--bk-cyan);
	border-bottom: 1px solid rgba(126,207,253,0.4);
}

/* ===============================================================
   S4 — Pricing module
   =============================================================== */
.bk-pricing-page .bk-size-toolbar {
	display: flex; align-items: center; justify-content: center;
	gap: 6px;
	background: rgba(255,255,255,0.04);
	border: 1px solid rgba(255,255,255,0.08);
	border-radius: 100px; padding: 6px;
	margin: 0 auto 56px; max-width: fit-content;
}
.bk-pricing-page .bk-size-btn {
	background: transparent; border: 0;
	color: var(--bk-cyan-body);
	padding: 11px 22px; border-radius: 100px;
	font-family: inherit; font-size: 14px; font-weight: 600;
	cursor: pointer; transition: all .15s; white-space: nowrap;
}
.bk-pricing-page .bk-size-btn:hover { color: #fff; }
.bk-pricing-page .bk-size-btn.is-active {
	background: var(--bk-gradient-cta-desktop);
	color: #fff;
	box-shadow: 0 2px 12px rgba(0,141,243,0.35);
}

.bk-pricing-page .bk-price-grid {
	display: grid;
	/* Column count tracks the live plan lineup — same pattern as
	   .bk-plans-grid above. */
	grid-template-columns: repeat(var(--plan-count, 3), 1fr);
	gap: 20px;
}
.bk-pricing-page .bk-price {
	background: #0F2544;
	border: 1px solid rgba(255,255,255,0.08);
	border-radius: 24px; padding: 32px 28px;
	display: flex; flex-direction: column;
	position: relative;
	transition: transform .25s, border-color .25s, box-shadow .25s;
}
.bk-pricing-page .bk-price:hover {
	transform: translateY(-4px);
	border-color: rgba(126,207,253,0.3);
	box-shadow: 0 20px 48px rgba(0,0,0,0.35);
}
.bk-pricing-page .bk-price--feat {
	border-color: var(--bk-blue);
	background: linear-gradient(180deg, #14355E 0%, #0F2544 80%);
	box-shadow: 0 0 0 1px var(--bk-blue), 0 24px 64px rgba(0,141,243,0.18);
}
.bk-pricing-page .bk-price--feat::before {
	content: ""; position: absolute;
	top: 0; left: 32px; right: 32px; height: 4px;
	background: var(--bk-cyan);
	border-radius: 0 0 4px 4px;
}
.bk-pricing-page .bk-price--unavail {
	opacity: .35; pointer-events: none; filter: saturate(.4);
}
.bk-pricing-page .bk-price__badge-row { height: 24px; margin-bottom: 16px; }
.bk-pricing-page .bk-price__badge {
	display: inline-block;
	font-family: var(--bk-font-body);
	font-style: italic; font-weight: 400;
	text-transform: uppercase; letter-spacing: 2px;
	font-size: 10px; padding: 4px 10px; border-radius: 6px;
}
.bk-pricing-page .bk-price__badge--popular { background: var(--bk-blue); color: #fff; }
.bk-pricing-page .bk-price__badge--cheap {
	background: rgba(126,207,253,0.15);
	color: var(--bk-cyan);
	border: 1px solid rgba(126,207,253,0.25);
}
.bk-pricing-page .bk-price__name {
	font-family: var(--bk-font-display);
	font-size: 26px; color: #fff; line-height: 1.15;
	margin-bottom: 4px; font-weight: 400;
}
.bk-pricing-page .bk-price__kicker {
	font-size: 12px; color: var(--bk-cyan-body);
	text-transform: uppercase; letter-spacing: 1px;
	font-weight: 500; margin-bottom: 24px;
}
.bk-pricing-page .bk-price__amount {
	font-family: var(--bk-font-display);
	font-size: 56px; line-height: 1;
	color: var(--bk-blue); margin-bottom: 6px;
}
.bk-pricing-page .bk-price__amount--na { color: var(--bk-text-meta-dark); }
.bk-pricing-page .bk-price__amount-sub {
	font-size: 12px; color: var(--bk-cyan-body);
	margin-bottom: 28px;
	text-transform: uppercase; letter-spacing: 1px; font-weight: 500;
}
.bk-pricing-page .bk-price__specs {
	list-style: none; padding: 0; margin: 0 0 28px; flex: 1;
}
.bk-pricing-page .bk-price__specs li {
	display: flex; justify-content: space-between; align-items: baseline;
	padding: 12px 0;
	border-bottom: 1px dashed rgba(255,255,255,0.08);
	font-size: 13px;
}
.bk-pricing-page .bk-price__specs li:last-child { border-bottom: 0; }
.bk-pricing-page .bk-price__spec-label { color: var(--bk-cyan-body); font-weight: 400; }
.bk-pricing-page .bk-price__spec-value { color: #fff; font-weight: 600; }
.bk-pricing-page .bk-price__upgrade {
	text-align: center; font-size: 12px;
	color: var(--bk-cyan-body); margin-top: 14px; font-weight: 300;
}
.bk-pricing-page .bk-price__upgrade b { color: #fff; font-weight: 600; }
.bk-pricing-page .bk-price .bk-btn { padding: 14px 22px; font-size: 14px; }

/* ===============================================================
   S5 — Comparison table
   =============================================================== */
.bk-pricing-page .bk-comp {
	background: var(--bk-darkblue);
	border: 1px solid rgba(255,255,255,0.08);
	border-radius: 40px; padding: 32px;
	overflow: hidden; position: relative;
	box-shadow: var(--bk-shadow-signature);
}
.bk-pricing-page .bk-comp__in { overflow-x: auto; }
.bk-pricing-page .bk-comp table {
	width: 100%; border-collapse: separate; border-spacing: 0;
	min-width: 820px;
}
.bk-pricing-page .bk-comp thead th {
	font-family: var(--bk-font-body);
	font-weight: 600; font-size: 15px; color: #fff;
	padding: 18px 16px; text-align: center; vertical-align: bottom;
}
.bk-pricing-page .bk-comp thead th:first-child {
	text-align: left;
	color: var(--bk-cyan-body); font-weight: 500;
	font-size: 12px; text-transform: uppercase; letter-spacing: 1.5px;
}
.bk-pricing-page .bk-comp thead th .bk-plan__badge { margin-top: 8px; }
.bk-pricing-page .bk-comp thead th.is-pop {
	background: rgba(0,141,243,0.08);
	border-top-left-radius: 16px; border-top-right-radius: 16px;
	position: relative;
}
.bk-pricing-page .bk-comp thead th.is-pop::before {
	content: ""; position: absolute;
	top: 0; left: 12px; right: 12px; height: 3px;
	background: var(--bk-cyan);
	border-radius: 0 0 3px 3px;
}
.bk-pricing-page .bk-comp tbody td {
	padding: 14px 16px; text-align: center;
	border-top: 1px solid rgba(255,255,255,0.06);
	font-size: 14px; color: #fff; font-weight: 500;
}
.bk-pricing-page .bk-comp tbody td:first-child {
	text-align: left;
	color: var(--bk-cyan-body); font-weight: 400; font-size: 13px;
}
.bk-pricing-page .bk-comp td.is-pop { background: rgba(0,141,243,0.06); }
.bk-pricing-page .bk-comp .cat-header td {
	font-family: var(--bk-font-body);
	font-style: italic; font-weight: 800;
	text-transform: uppercase; letter-spacing: 2px;
	font-size: 12px; color: var(--bk-cyan);
	padding-top: 32px; padding-bottom: 8px;
	background: transparent; border-top: 0;
}
.bk-pricing-page .bk-comp .cat-header td:first-child { color: var(--bk-cyan); }
.bk-pricing-page .bk-comp .none-val {
	color: #31E48B; font-weight: 600;
	display: inline-flex; align-items: center; gap: 6px;
}
.bk-pricing-page .bk-comp .none-val::before {
	content: ""; width: 5px; height: 5px;
	border-radius: 50%; background: #31E48B;
	box-shadow: 0 0 8px rgba(49,228,139,0.6);
}
.bk-pricing-page .bk-comp .price-big {
	font-family: var(--bk-font-display);
	font-size: 26px; color: var(--bk-blue); line-height: 1;
}
.bk-pricing-page .bk-comp .price-sub {
	font-size: 11px; color: var(--bk-cyan-body);
	text-transform: uppercase; letter-spacing: 1px;
	font-weight: 500; display: block; margin-top: 4px;
}
.bk-pricing-page .bk-comp .bk-btn { padding: 11px 18px; font-size: 13px; }

/* ===============================================================
   S6 — Features
   =============================================================== */
.bk-pricing-page .bk-feats {
	display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px;
}
.bk-pricing-page .bk-feat {
	background: #fff;
	border: 1px solid var(--bk-border);
	border-radius: 24px; padding: 32px;
	position: relative; overflow: hidden;
	box-shadow: var(--bk-shadow-testimonial);
	transition: transform .25s, box-shadow .25s;
}
.bk-pricing-page .bk-feat::before {
	content: ""; position: absolute;
	top: 0; left: 24px; right: 24px; height: 4px;
	background: var(--bk-gradient-title-horiz);
}
.bk-pricing-page .bk-feat:hover {
	transform: translateY(-4px);
	box-shadow: var(--bk-shadow-testimonial-hover);
}
.bk-pricing-page .bk-feat__icon {
	width: 52px; height: 52px; border-radius: 14px;
	background: rgba(0,141,243,0.1);
	color: var(--bk-blue);
	display: inline-flex; align-items: center; justify-content: center;
	margin-bottom: 20px;
}
.bk-pricing-page .bk-feat__title {
	font-family: var(--bk-font-body);
	font-style: italic; font-weight: 800;
	text-transform: uppercase; letter-spacing: 2px;
	font-size: 16px; color: var(--bk-text-heading);
	margin-bottom: 12px; line-height: 1.3;
}
.bk-pricing-page .bk-feat__desc {
	font-size: 15px; line-height: 1.55;
	color: var(--bk-text-cool); margin: 0; font-weight: 400;
}

/* ===============================================================
   S7 — Trust
   =============================================================== */
.bk-pricing-page .bk-trust { position: relative; }
.bk-pricing-page .bk-stats {
	display: grid; grid-template-columns: repeat(4, 1fr);
	gap: 24px; margin-bottom: 80px;
	padding-bottom: 56px;
	border-bottom: 1px solid rgba(255,255,255,0.08);
}
.bk-pricing-page .bk-stat { text-align: center; }
.bk-pricing-page .bk-stat__num {
	font-family: var(--bk-font-display);
	font-size: clamp(40px, 5vw, 72px);
	line-height: 1; letter-spacing: -1px;
}
.bk-pricing-page .bk-stat__num span {
	background: var(--bk-gradient-title-vert);
	-webkit-background-clip: text; background-clip: text;
	-webkit-text-fill-color: transparent; color: transparent;
}
.bk-pricing-page .bk-stat__label {
	font-size: 12px; color: var(--bk-cyan-body);
	text-transform: uppercase; letter-spacing: 2px;
	margin-top: 12px; font-weight: 500;
}
.bk-pricing-page .bk-trust__body {
	display: grid; grid-template-columns: 1fr 1fr;
	gap: 72px; align-items: center;
	max-width: 1040px; margin: 0 auto;
}
.bk-pricing-page .bk-trust__logo { text-align: center; }
.bk-pricing-page .bk-trust__logo img { height: 56px; margin: 0 auto; opacity: .95; }
.bk-pricing-page .bk-trust__divider {
	font-size: 11px; letter-spacing: 3px;
	text-transform: uppercase; color: var(--bk-cyan);
	margin-top: 20px; font-weight: 700; font-style: italic;
}
.bk-pricing-page .bk-trust__copy .eyebrow { display: block; margin-bottom: 12px; }
.bk-pricing-page .bk-trust__copy h2 { margin-bottom: 16px; }
.bk-pricing-page .bk-trust__copy p {
	font-size: 17px; color: var(--bk-cyan-body);
	line-height: 1.6; font-weight: 300; margin-bottom: 20px;
}
.bk-pricing-page .bk-trust__discord {
	display: inline-flex; align-items: center; gap: 12px;
	background: rgba(88,101,242,0.12);
	border: 1px solid rgba(88,101,242,0.3);
	padding: 12px 18px; border-radius: 100px;
	font-size: 13px; color: #fff; font-weight: 500;
}
.bk-pricing-page .bk-trust__discord b { color: var(--bk-cyan); font-weight: 700; }
.bk-pricing-page .bk-trust__discord svg { color: #5865F2; }

/* ===============================================================
   S8 — FAQ
   =============================================================== */
.bk-pricing-page .bk-faq-wrap {
	display: grid; grid-template-columns: 1fr 1.8fr;
	gap: 72px; align-items: start;
}
.bk-pricing-page .bk-faq-head .eyebrow { display: block; margin-bottom: 12px; }
.bk-pricing-page .bk-faq-head h2 { margin-bottom: 16px; }
.bk-pricing-page .bk-faq-head p {
	font-size: 16px; color: var(--bk-text-cool);
	line-height: 1.55; font-weight: 400;
}
.bk-pricing-page .bk-faq {
	display: flex; flex-direction: column; gap: 12px;
}
.bk-pricing-page .bk-accordion {
	background: #fff;
	border: 1px solid rgba(0,141,243,0.3);
	border-radius: 20px;
	box-shadow: var(--bk-shadow-halo);
	overflow: hidden;
	transition: border-color .2s;
}
.bk-pricing-page .bk-accordion.is-open { border-color: var(--bk-blue); }
.bk-pricing-page .bk-accordion__head {
	width: 100%; background: transparent; border: 0;
	padding: 22px 28px;
	display: flex; align-items: center; justify-content: space-between;
	gap: 20px;
	font-family: inherit; font-size: 16px; font-weight: 600;
	color: var(--bk-text-heading);
	cursor: pointer; text-align: left; letter-spacing: .2px;
}
.bk-pricing-page .bk-accordion__head:hover { color: var(--bk-blue); }
.bk-pricing-page .bk-accordion__chev {
	color: var(--bk-blue);
	font-size: 24px; font-weight: 300; line-height: 1;
	flex-shrink: 0; transition: transform .25s;
}
.bk-pricing-page .bk-accordion.is-open .bk-accordion__chev { transform: rotate(45deg); }
.bk-pricing-page .bk-accordion__body {
	max-height: 0; overflow: hidden;
	transition: max-height .3s ease, padding .3s ease;
}
.bk-pricing-page .bk-accordion.is-open .bk-accordion__body { max-height: 400px; }
.bk-pricing-page .bk-accordion__body-inner {
	padding: 0 28px 22px;
	color: var(--bk-text-cool);
	font-size: 15px; line-height: 1.6; font-weight: 400;
}

/* ===============================================================
   S9 — Closing CTA
   =============================================================== */
.bk-pricing-page .bk-close-cta {
	background: linear-gradient(180deg, var(--bk-darkblue) 0%, #051426 100%);
	padding: 96px 0; color: #fff;
	text-align: center; position: relative; overflow: hidden;
}
.bk-pricing-page .bk-close-cta::before {
	content: ""; position: absolute;
	inset: -50% -20% auto -20%; height: 100%;
	background: radial-gradient(circle at 50% 0%, rgba(0,141,243,0.22), transparent 60%);
	pointer-events: none;
}
.bk-pricing-page .bk-close-cta__in {
	position: relative; max-width: 720px;
	margin: 0 auto; padding: 0 24px;
}
.bk-pricing-page .bk-close-cta .lede { margin: 0 auto 32px; color: var(--bk-cyan-body); }
.bk-pricing-page .bk-close-cta__actions {
	display: inline-flex; gap: 12px; flex-wrap: wrap; justify-content: center;
}
.bk-pricing-page .bk-close-cta__disc {
	max-width: 560px; margin: 40px auto 0;
	font-size: 12px; color: rgba(165,222,253,0.5);
	line-height: 1.6; font-weight: 300;
}

/* ===============================================================
   Responsive
   =============================================================== */
@media (max-width: 1080px) {
	.bk-pricing-page .bk-plans-grid,
	.bk-pricing-page .bk-price-grid { grid-template-columns: repeat(2, 1fr); }
	.bk-pricing-page .bk-feats { grid-template-columns: repeat(2, 1fr); }
	.bk-pricing-page .bk-trust__body { grid-template-columns: 1fr; gap: 32px; text-align: center; }
	.bk-pricing-page .bk-faq-wrap { grid-template-columns: 1fr; gap: 32px; }
	.bk-pricing-page .bk-stats { grid-template-columns: repeat(2, 1fr); }
	.bk-pricing-page .bk-qr__grid { grid-template-columns: 1fr; gap: 20px; text-align: left; }
	.bk-pricing-page .bk-qr__right { text-align: left; }
	.bk-pricing-page .bk-qr__cta { display: block; }
}
@media (max-width: 640px) {
	.bk-pricing-page .bk-section { padding: 80px 0; }
	.bk-pricing-page .bk-hero { padding: 96px 0 80px; }
	.bk-pricing-page .bk-plans-grid,
	.bk-pricing-page .bk-price-grid,
	.bk-pricing-page .bk-feats,
	.bk-pricing-page .bk-quiz__cards,
	.bk-pricing-page .bk-quiz__cards--3 { grid-template-columns: 1fr; }
	.bk-pricing-page .bk-stats { grid-template-columns: 1fr 1fr; gap: 20px; }
	.bk-pricing-page .bk-quiz { padding: 28px; }

	/* Size toolbar: keep all 6 buttons visible by allowing horizontal scroll
	   inside the pill instead of overflowing the section. */
	.bk-pricing-page .bk-size-toolbar {
		max-width: 100%;
		justify-content: flex-start;
		overflow-x: auto;
		-webkit-overflow-scrolling: touch;
		scrollbar-width: none;
	}
	.bk-pricing-page .bk-size-toolbar::-webkit-scrollbar { display: none; }
	.bk-pricing-page .bk-size-btn {
		flex-shrink: 0;
		padding: 11px 18px;
	}
}
