/**
 * BroFPV design system + page styles.
 *
 * Recreates the "Pro FPV" Claude Design prototype (light, Apple-style,
 * blue #1f5cff + red #ff2d46) for the brofpv_taydolab WooCommerce theme.
 * Loaded site-wide; styles native WooCommerce markup plus the theme's
 * custom front-page / account / blog templates.
 *
 * @package BroFPV___Tay_Do_Labs
 */

/* ===================================================================
   Design tokens
   =================================================================== */
:root {
	--bf-blue: #1f5cff;
	--bf-blue-dark: #1850e6;
	--bf-blue-soft: #5b8cff;
	--bf-red: #ff2d46;
	--bf-red-dark: #e51d36;
	--bf-ink: #0b1020;
	--bf-ink-soft: #1a2030;
	--bf-bg: #fbfbfd;
	--bf-surface: #fff;
	--bf-muted: #5b6478;
	--bf-muted-2: #8a93a6;
	--bf-muted-3: #9aa3b5;
	--bf-muted-4: #aab2c2;
	--bf-line: #ececf2;
	--bf-line-2: #d9deea;
	--bf-tint-blue: #eef2ff;
	--bf-tint-blue-2: #f6f9ff;
	--bf-border-blue: #dde4ff;
	--bf-tint-red: #fff0f2;
	--bf-border-red: #ffd9df;
	--bf-green: #2bb673;
	--bf-amber: #ffb020;

	--bf-radius-card: 18px;
	--bf-radius-lg: 22px;
	--bf-radius-input: 11px;
	--bf-radius-btn: 13px;

	--bf-display: "Space Grotesk", system-ui, sans-serif;
	--bf-body: "Plus Jakarta Sans", system-ui, sans-serif;
	--bf-mono: ui-monospace, "SF Mono", Menlo, monospace;

	--bf-max: 1240px;
	--bf-sticky-top: 84px;

	--bf-shadow-card: 0 20px 44px -24px rgba(16, 24, 64, .34);
	--bf-shadow-btn-blue: 0 12px 28px -12px rgba(31, 92, 255, .7);
	--bf-shadow-btn-red: 0 12px 26px -14px rgba(255, 45, 70, .7);

	/* Striped placeholder used for images that have no thumbnail. */
	--bf-stripe: repeating-linear-gradient(135deg, #f4f6fb, #f4f6fb 10px, #eef1f8 10px, #eef1f8 20px);
	--bf-stripe-cool: repeating-linear-gradient(135deg, #eef1f8, #eef1f8 12px, #e7ebf5 12px, #e7ebf5 24px);
}

/* ===================================================================
   Base
   =================================================================== */
body.brofpv,
body.woocommerce-active {
	background: var(--bf-bg);
	color: var(--bf-ink);
	font-family: var(--bf-body);
	-webkit-font-smoothing: antialiased;
}

.brofpv * {
	box-sizing: border-box;
}

.brofpv a {
	color: var(--bf-blue);
	text-decoration: none;
}

.brofpv h1,
.brofpv h2,
.brofpv h3,
.brofpv h4 {
	font-family: var(--bf-display);
	letter-spacing: -.02em;
	color: var(--bf-ink);
}

.bf-wrap {
	max-width: var(--bf-max);
	margin: 0 auto;
	padding-left: 28px;
	padding-right: 28px;
}

.bf-muted { color: var(--bf-muted-2); }
.bf-accent { color: var(--bf-blue); }
.bf-screen-reader { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(0 0 0 0); }

/* ===================================================================
   Buttons
   =================================================================== */
.bf-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	padding: 14px 26px;
	border: none;
	border-radius: var(--bf-radius-btn);
	font: 700 15px/1 var(--bf-body);
	cursor: pointer;
	transition: .18s ease;
	text-align: center;
}
.bf-btn--primary {
	background: var(--bf-blue);
	color: #fff;
	box-shadow: var(--bf-shadow-btn-blue);
}
.bf-btn--primary:hover { background: var(--bf-blue-dark); color: #fff; transform: translateY(-1px); }
.bf-btn--red {
	background: var(--bf-red);
	color: #fff;
	box-shadow: var(--bf-shadow-btn-red);
}
.bf-btn--red:hover { background: var(--bf-red-dark); color: #fff; }
.bf-btn--dark { background: var(--bf-ink); color: #fff; }
.bf-btn--dark:hover { background: var(--bf-ink-soft); color: #fff; }
.bf-btn--ghost {
	background: var(--bf-surface);
	color: var(--bf-ink);
	border: 1px solid var(--bf-line-2);
	box-shadow: none;
}
.bf-btn--ghost:hover { border-color: var(--bf-ink); color: var(--bf-ink); }
.bf-btn--soft {
	background: #f0f2f8;
	color: var(--bf-ink);
	box-shadow: none;
}
.bf-btn--soft:hover { background: #e7eaf2; }
.bf-btn--block { width: 100%; }

/* Beat the generic `.brofpv a` color rule for link-styled buttons. */
.brofpv a.bf-btn--primary,
.brofpv a.bf-btn--red,
.brofpv a.bf-btn--dark { color: #fff; }
.brofpv a.bf-btn--ghost,
.brofpv a.bf-btn--soft { color: var(--bf-ink); }
.brofpv a.bf-btn--ghost:hover,
.brofpv a.bf-btn--soft:hover { color: var(--bf-ink); }
/* Header action links are anchors too — beat `.brofpv a` blue. */
.brofpv a.bf-header__btn,
.brofpv a.bf-header__btn:hover { color: var(--bf-ink); }
.brofpv a.bf-header__cart,
.brofpv a.bf-header__cart:hover { color: #fff; }

.bf-eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	background: var(--bf-tint-blue);
	border: 1px solid var(--bf-border-blue);
	border-radius: 999px;
	padding: 7px 14px;
	font: 600 12px/1 var(--bf-body);
	color: var(--bf-blue);
	letter-spacing: .04em;
}
.bf-eyebrow--red {
	background: var(--bf-tint-red);
	border-color: var(--bf-border-red);
	color: var(--bf-red);
}

/* Section heading row */
.bf-section { max-width: var(--bf-max); margin: 0 auto; padding: 48px 28px 24px; }
.bf-section__head {
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	gap: 20px;
	margin-bottom: 24px;
	flex-wrap: wrap;
}
.bf-section__title { margin: 0 0 6px; font: 700 30px/1.1 var(--bf-display); }
.bf-section__sub { margin: 0; font: 400 15px/1.5 var(--bf-body); color: var(--bf-muted-2); }
.bf-section__link {
	background: none; border: none; cursor: pointer;
	font: 600 14px/1 var(--bf-body); color: var(--bf-blue); padding: 8px;
}
.bf-section__link:hover { opacity: .7; }

/* ===================================================================
   Header
   =================================================================== */
.bf-header {
	position: sticky;
	top: 0;
	z-index: 60;
	background: rgba(251, 251, 253, .82);
	backdrop-filter: blur(16px);
	-webkit-backdrop-filter: blur(16px);
	border-bottom: 1px solid var(--bf-line);
}
.bf-header__inner {
	max-width: var(--bf-max);
	margin: 0 auto;
	padding: 0 28px;
	height: 68px;
	display: flex;
	align-items: center;
	gap: 24px;
}
.bf-logo { display: flex; align-items: center; gap: 11px; flex-shrink: 0; }
.bf-logo__mark {
	width: 34px; height: 34px; border-radius: 10px;
	background: linear-gradient(135deg, var(--bf-blue), var(--bf-red));
	display: flex; align-items: center; justify-content: center;
	font: 800 18px/1 var(--bf-display); color: #fff;
	box-shadow: 0 6px 16px -6px rgba(31, 92, 255, .6);
}
.bf-logo__text { font: 700 20px/1 var(--bf-display); letter-spacing: -.01em; color: var(--bf-ink); }
.bf-logo__text span { color: var(--bf-blue); }

.bf-nav { display: flex; align-items: center; gap: 4px; }
.bf-nav ul { display: flex; align-items: center; gap: 4px; list-style: none; margin: 0; padding: 0; }
.bf-nav a {
	display: block; padding: 8px 14px; border-radius: 9px;
	font: 500 14.5px/1 var(--bf-body); color: #3a4255;
}
.bf-nav a:hover, .bf-nav .current-menu-item > a { background: #f0f2f8; color: var(--bf-ink); }

.bf-header__actions { margin-left: auto; display: flex; align-items: center; gap: 14px; }
.bf-search {
	display: flex; align-items: center; gap: 8px;
	background: #f0f2f8; border: 1px solid transparent;
	border-radius: var(--bf-radius-input); padding: 9px 14px; width: 248px;
}
.bf-search:focus-within { border-color: var(--bf-blue); background: #fff; }
.bf-search span { color: var(--bf-muted-3); font: 600 13px/1 var(--bf-body); flex-shrink: 0; }
.brofpv .bf-search input[type=search] {
	-webkit-appearance: none; appearance: none;
	border: none; background: none; box-shadow: none; min-width: 0; width: 100%;
	padding: 0; border-radius: 0;
	font: 500 13.5px/1 var(--bf-body); color: var(--bf-ink);
}
.brofpv .bf-search input[type=search]:focus { box-shadow: none; }
.bf-search input::-webkit-search-decoration,
.bf-search input::-webkit-search-cancel-button { -webkit-appearance: none; }
.bf-search input:focus { outline: none; }

.bf-header__btn {
	display: flex; align-items: center; gap: 8px;
	background: #f0f2f8; border: 1px solid transparent; cursor: pointer;
	padding: 10px 14px; border-radius: var(--bf-radius-input);
	color: var(--bf-ink); font: 600 13.5px/1 var(--bf-body);
}
.bf-header__btn:hover { background: #e7eaf2; color: var(--bf-ink); }
.bf-header__btn .bf-ic { font: 600 14px/1 var(--bf-display); color: var(--bf-blue); }
.bf-header__user { padding-left: 6px; }
.bf-header__avatar {
	width: 26px; height: 26px; border-radius: 50%; flex: 0 0 auto;
	background: linear-gradient(135deg, var(--bf-blue), var(--bf-red));
	display: inline-flex; align-items: center; justify-content: center;
	color: #fff; font: 700 12px/1 var(--bf-display);
}
.bf-header__user-name { max-width: 120px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
/* WooCommerce show/hide-password toggle: default WC CSS is disabled, so it renders
   as an empty grey box below the field. Hide it. */
.bf-auth .show-password-input { display: none; }
.bf-header__cart {
	position: relative; display: flex; align-items: center; gap: 8px;
	background: var(--bf-ink); border: none; cursor: pointer;
	padding: 10px 16px; border-radius: var(--bf-radius-input);
	color: #fff; font: 600 13.5px/1 var(--bf-body);
}
.bf-header__cart:hover { background: var(--bf-ink-soft); color: #fff; }
.bf-header__cart-count {
	min-width: 20px; height: 20px; padding: 0 6px; border-radius: 999px;
	background: var(--bf-red); display: inline-flex; align-items: center; justify-content: center;
	font: 700 12px/1 var(--bf-body); color: #fff;
}
.bf-menu-toggle { display: none; }

/* ===================================================================
   Footer
   =================================================================== */
.bf-footer { background: var(--bf-ink); margin-top: 64px; }
.bf-footer__top {
	max-width: var(--bf-max); margin: 0 auto; padding: 54px 28px 32px;
	display: grid; grid-template-columns: 1.6fr 1fr 1fr 1fr; gap: 40px;
}
.bf-footer__brand .bf-logo__text { color: #fff; }
.bf-footer__brand .bf-logo__text span { color: var(--bf-blue-soft); }
.bf-footer__brand p { margin: 16px 0 18px; font: 400 14px/1.6 var(--bf-body); color: var(--bf-muted-2); max-width: 280px; }
.bf-footer__social { display: flex; gap: 9px; }
.bf-footer__social span {
	width: 36px; height: 36px; border-radius: 10px; background: rgba(255, 255, 255, .07);
	display: flex; align-items: center; justify-content: center;
	font: 700 13px/1 var(--bf-display); color: #aab4cc;
}
.bf-footer__col h3 {
	font: 700 13px/1 var(--bf-body); color: #fff; text-transform: uppercase;
	letter-spacing: .06em; margin: 0 0 16px;
}
.bf-footer__col ul { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 11px; }
.bf-footer__col a { font: 500 13.5px/1 var(--bf-body); color: var(--bf-muted-2); }
.bf-footer__col a:hover { color: #fff; }
.bf-footer__bar { border-top: 1px solid rgba(255, 255, 255, .08); }
.bf-footer__bar-inner {
	max-width: var(--bf-max); margin: 0 auto; padding: 20px 28px;
	display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 10px;
}
.bf-footer__bar-inner span { font: 500 12.5px/1 var(--bf-body); color: #6b748a; }

/* ===================================================================
   Home: hero
   =================================================================== */
.bf-hero {
	max-width: var(--bf-max); margin: 0 auto; padding: 64px 28px 40px;
	display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: center;
}
.bf-hero h1 { margin: 18px 0; font: 700 58px/1.04 var(--bf-display); }
.bf-hero h1 span { color: var(--bf-blue); }
.bf-hero p { margin: 0 0 30px; font: 400 18px/1.6 var(--bf-body); color: var(--bf-muted); max-width: 440px; }
.bf-hero__cta { display: flex; gap: 12px; margin-bottom: 34px; flex-wrap: wrap; }
.bf-hero__stats { display: flex; gap: 30px; flex-wrap: wrap; }
.bf-hero__stats .n { font: 700 24px/1 var(--bf-display); color: var(--bf-ink); }
.bf-hero__stats .n.is-accent { color: var(--bf-blue); }
.bf-hero__stats .l { font: 500 13px/1 var(--bf-body); color: var(--bf-muted-2); margin-top: 5px; }
.bf-hero__media { position: relative; }
.bf-hero__frame {
	aspect-ratio: 5/4; border-radius: 24px; background: var(--bf-stripe-cool);
	border: 1px solid #e4e8f1; display: flex; align-items: center; justify-content: center;
	overflow: hidden; position: relative;
}
.bf-hero__frame::after {
	content: ""; position: absolute; inset: 0;
	background: radial-gradient(120% 90% at 70% 20%, rgba(31, 92, 255, .12), transparent 55%),
		radial-gradient(90% 80% at 20% 90%, rgba(255, 45, 70, .1), transparent 55%);
}
.bf-hero__frame img { width: 100%; height: 100%; object-fit: cover; position: relative; }
.bf-ph { font: 500 13px/1 var(--bf-mono); color: var(--bf-muted-3); letter-spacing: .06em; position: relative; }
.bf-hero__chip {
	position: absolute; background: #fff; border: 1px solid var(--bf-line); border-radius: 14px;
	padding: 13px 16px; box-shadow: 0 18px 40px -22px rgba(16, 24, 64, .4);
}
.bf-hero__chip--tl { top: 22px; left: -18px; }
.bf-hero__chip--br { bottom: 24px; right: -16px; }
.bf-hero__chip .k { font: 500 11px/1 var(--bf-body); color: var(--bf-muted-2); margin-bottom: 5px; }
.bf-hero__chip .v { font: 700 18px/1 var(--bf-display); color: var(--bf-ink); }
.bf-hero__chip .v small { font-size: 12px; color: var(--bf-muted-2); }
.bf-hero__chip .dot { width: 8px; height: 8px; border-radius: 50%; background: var(--bf-red); display: inline-block; }

/* ===================================================================
   Category tiles
   =================================================================== */
.bf-cats { display: grid; grid-template-columns: repeat(6, 1fr); gap: 16px; }
.bf-cat {
	position: relative; aspect-ratio: 4/5; border-radius: 20px; overflow: hidden;
	display: block; border: 1px solid #e6e9f1; transition: .2s;
}
.bf-cat:hover { transform: translateY(-3px); box-shadow: 0 24px 48px -24px rgba(16, 24, 64, .4); }
.bf-cat__img { position: absolute; inset: 0; background: var(--bf-stripe); background-size: cover; background-position: center; }
.bf-cat__img img { width: 100%; height: 100%; object-fit: cover; }
.bf-cat__scrim {
	position: absolute; inset: 0;
	background: linear-gradient(180deg, transparent 30%, rgba(11, 16, 32, .72) 100%);
}
.bf-cat:nth-child(odd) .bf-cat__scrim { background: linear-gradient(180deg, rgba(31, 92, 255, .12) 0%, rgba(31, 92, 255, .82) 100%); }
.bf-cat:nth-child(even) .bf-cat__scrim { background: linear-gradient(180deg, rgba(255, 45, 70, .1) 0%, rgba(255, 45, 70, .8) 100%); }
.bf-cat__arrow {
	position: absolute; top: 14px; right: 14px; width: 32px; height: 32px; border-radius: 50%;
	background: rgba(255, 255, 255, .9); box-shadow: 0 4px 12px -4px rgba(16, 24, 64, .25);
	display: flex; align-items: center; justify-content: center; font: 600 15px/1 var(--bf-display); color: var(--bf-blue);
}
.bf-cat__body { position: absolute; left: 0; right: 0; bottom: 0; padding: 18px 17px; }
.bf-cat__name { font: 700 18px/1.12 var(--bf-display); color: #fff; margin-bottom: 8px; text-shadow: 0 1px 8px rgba(0, 0, 0, .12); }
.bf-cat__count {
	display: inline-block; font: 600 11px/1 var(--bf-body); color: #fff;
	background: rgba(255, 255, 255, .22); padding: 6px 10px; border-radius: 8px; backdrop-filter: blur(4px);
}

/* ===================================================================
   Product cards (grid)
   =================================================================== */
.bf-products { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.bf-products--3 { grid-template-columns: repeat(3, 1fr); }
.bf-product {
	background: #fff; border: 1px solid var(--bf-line); border-radius: var(--bf-radius-card);
	overflow: hidden; display: flex; flex-direction: column; transition: .2s; position: relative;
}
.bf-product:hover { box-shadow: var(--bf-shadow-card); transform: translateY(-3px); border-color: #e1e5ef; }
.bf-product__media {
	position: relative; aspect-ratio: 4/3; background: var(--bf-stripe);
	display: flex; align-items: center; justify-content: center; overflow: hidden;
}
.bf-product__media img { width: 100%; height: 100%; object-fit: cover; }
.bf-product__badge {
	position: absolute; top: 12px; left: 12px; background: var(--bf-red); color: #fff;
	font: 700 10.5px/1 var(--bf-body); padding: 6px 10px; border-radius: 999px;
	letter-spacing: .03em; text-transform: uppercase; z-index: 2;
}
.bf-product__body { padding: 15px 15px 17px; display: flex; flex-direction: column; gap: 7px; flex: 1; }
.bf-product__cat { font: 600 10.5px/1 var(--bf-body); color: var(--bf-blue); text-transform: uppercase; letter-spacing: .06em; }
.bf-product__name { margin: 0; font: 600 15.5px/1.3 var(--bf-display); color: var(--bf-ink); display: -webkit-box; -webkit-line-clamp: 2; line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; min-height: calc(2 * 1.3em); }
.bf-product__name a { color: inherit; }
.bf-product__rating { display: flex; align-items: center; gap: 5px; color: var(--bf-muted-2); font: 500 12.5px/1 var(--bf-body); }
.bf-product__rating .star { color: var(--bf-amber); }
.bf-product__rating .sep { color: #c3c9d6; }
.bf-product__foot { margin-top: auto; padding-top: 9px; display: flex; align-items: center; justify-content: space-between; gap: 8px; }
.bf-product__price { font: 700 16.5px/1 var(--bf-display); color: var(--bf-ink); }
.bf-product__price del { color: var(--bf-muted-3); font-weight: 500; font-size: 13px; margin-right: 4px; }
.bf-product__price ins { text-decoration: none; }
.bf-product__add {
	display: inline-flex; align-items: center; justify-content: center; width: 36px; height: 36px;
	background: var(--bf-tint-blue); color: var(--bf-blue); border: none; border-radius: 10px;
	font: 700 18px/1 var(--bf-body); cursor: pointer; transition: .15s;
}
.bf-product__add:hover { background: var(--bf-blue); color: #fff; }
.bf-product__add.loading, .bf-product__add.added { background: var(--bf-blue); color: #fff; }

/* ===================================================================
   Audience cards
   =================================================================== */
.bf-audience { max-width: var(--bf-max); margin: 0 auto; padding: 48px 28px; }
.bf-audience__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.bf-aud {
	position: relative; overflow: hidden; border-radius: 20px; padding: 28px;
	min-height: 188px; display: flex; flex-direction: column; transition: .2s;
}
.bf-aud:hover { transform: translateY(-2px); }
.bf-aud--blue { background: var(--bf-tint-blue); border: 1px solid var(--bf-border-blue); }
.bf-aud--red { background: var(--bf-tint-red); border: 1px solid var(--bf-border-red); }
.bf-aud--ink { background: #f5f7fb; border: 1px solid #e6e9f1; }
.bf-aud__tag { font: 600 11px/1 var(--bf-body); text-transform: uppercase; letter-spacing: .08em; margin-bottom: 10px; }
.bf-aud--blue .bf-aud__tag, .bf-aud--blue .bf-aud__cta { color: var(--bf-blue); }
.bf-aud--red .bf-aud__tag, .bf-aud--red .bf-aud__cta { color: var(--bf-red); }
.bf-aud--ink .bf-aud__tag, .bf-aud--ink .bf-aud__cta { color: var(--bf-ink); }
.bf-aud h3 { margin: 0 0 8px; font: 700 22px/1.15 var(--bf-display); }
.bf-aud p { margin: 0; font: 400 14px/1.5 var(--bf-body); color: var(--bf-muted); max-width: 240px; }
.bf-aud__cta { margin-top: auto; padding-top: 16px; font: 600 13.5px/1 var(--bf-body); }

/* ===================================================================
   DIY banner + trust strip
   =================================================================== */
.bf-diy { max-width: var(--bf-max); margin: 0 auto; padding: 8px 28px 56px; }
.bf-diy__inner {
	position: relative; overflow: hidden; border-radius: 24px; background: var(--bf-ink);
	padding: 48px 52px; display: grid; grid-template-columns: 1.2fr 1fr; gap: 40px; align-items: center;
}
.bf-diy__inner::before {
	content: ""; position: absolute; inset: 0;
	background: radial-gradient(80% 120% at 90% 10%, rgba(31, 92, 255, .4), transparent 55%),
		radial-gradient(70% 100% at 0% 100%, rgba(255, 45, 70, .32), transparent 55%);
}
.bf-diy__copy { position: relative; }
.bf-diy__copy .bf-eyebrow { background: rgba(255, 255, 255, .1); border-color: rgba(255, 255, 255, .16); color: #fff; }
.bf-diy__copy h2 { margin: 18px 0 14px; font: 700 38px/1.08 var(--bf-display); color: #fff; }
.bf-diy__copy p { margin: 0 0 26px; font: 400 16px/1.6 var(--bf-body); color: #aab4cc; max-width: 420px; }
.bf-diy__copy .bf-btn { background: #fff; color: var(--bf-ink); box-shadow: none; }
.bf-diy__copy .bf-btn:hover { background: var(--bf-tint-blue); }
.bf-diy__grid { position: relative; display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.bf-diy__tile { background: rgba(255, 255, 255, .07); border: 1px solid rgba(255, 255, 255, .12); border-radius: 14px; padding: 16px; }
.bf-diy__tile:hover { background: rgba(255, 255, 255, .13); }
.bf-diy__tile .n { font: 700 15px/1.2 var(--bf-display); color: #fff; margin-bottom: 5px; }
.bf-diy__tile .f { font: 500 12.5px/1 var(--bf-body); color: var(--bf-muted-2); }

.bf-trust { border-top: 1px solid var(--bf-line); border-bottom: 1px solid var(--bf-line); background: #fff; }
.bf-trust__inner { max-width: var(--bf-max); margin: 0 auto; padding: 30px 28px; display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
.bf-trust__item { display: flex; align-items: center; gap: 13px; }
.bf-trust__glyph {
	width: 42px; height: 42px; border-radius: 12px; background: var(--bf-tint-blue);
	display: flex; align-items: center; justify-content: center; font: 700 17px/1 var(--bf-display);
	color: var(--bf-blue); flex-shrink: 0;
}
.bf-trust__item .t { font: 600 14.5px/1.2 var(--bf-body); color: var(--bf-ink); margin-bottom: 3px; }
.bf-trust__item .d { font: 500 12.5px/1.3 var(--bf-body); color: var(--bf-muted-2); }

/* ===================================================================
   Learn block (videos + articles) on home
   =================================================================== */
.bf-learn__grid { display: grid; grid-template-columns: 1.35fr 1fr; gap: 18px; align-items: stretch; }
.bf-learn__feature {
	background: #fff; border: 1px solid var(--bf-line); border-radius: 20px; overflow: hidden;
	display: flex; flex-direction: column; transition: .2s;
}
.bf-learn__feature:hover { box-shadow: 0 22px 46px -26px rgba(16, 24, 64, .34); border-color: #e1e5ef; }
.bf-learn__articles { display: flex; flex-direction: column; gap: 11px; }
.bf-learn__article {
	flex: 1; background: #fff; border: 1px solid var(--bf-line); border-radius: 16px; padding: 14px;
	display: flex; gap: 14px; align-items: center; transition: .2s;
}
.bf-learn__article:hover { box-shadow: 0 16px 34px -22px rgba(16, 24, 64, .3); border-color: #e1e5ef; }
.bf-learn__article-thumb { width: 84px; height: 64px; border-radius: 11px; background: var(--bf-stripe); background-size: cover; flex-shrink: 0; }
.bf-learn__article h3 { margin: 0 0 5px; font: 600 14.5px/1.3 var(--bf-display); color: var(--bf-ink); }
.bf-learn__article .meta { font: 500 12px/1 var(--bf-body); color: var(--bf-muted-3); }

/* ===================================================================
   Video / play affordances
   =================================================================== */
.bf-video-thumb {
	position: relative; aspect-ratio: 16/9; background: var(--bf-stripe-cool);
	display: flex; align-items: center; justify-content: center; overflow: hidden;
}
.bf-video-thumb img { width: 100%; height: 100%; object-fit: cover; }
.bf-play {
	position: relative; width: 66px; height: 66px; border-radius: 50%; background: rgba(255, 255, 255, .92);
	box-shadow: 0 14px 30px -10px rgba(16, 24, 64, .5); display: flex; align-items: center; justify-content: center;
	font: 600 23px/1 var(--bf-display); color: var(--bf-blue); padding-left: 5px;
}
.bf-play--sm { width: 54px; height: 54px; font-size: 19px; }
.bf-duration {
	position: absolute; bottom: 12px; right: 12px; background: rgba(11, 16, 32, .82); color: #fff;
	font: 600 12px/1 var(--bf-body); padding: 6px 10px; border-radius: 8px;
}
.bf-level {
	position: absolute; top: 12px; left: 12px; background: var(--bf-tint-blue); color: var(--bf-blue);
	font: 700 11px/1 var(--bf-body); padding: 6px 11px; border-radius: 999px;
}

/* ===================================================================
   Breadcrumb
   =================================================================== */
.bf-breadcrumb, .brofpv .woocommerce-breadcrumb {
	font: 500 13px/1.5 var(--bf-body); color: var(--bf-muted-2); margin-bottom: 16px;
}
.bf-breadcrumb a, .brofpv .woocommerce-breadcrumb a { color: var(--bf-blue); }

/* ===================================================================
   Pill / chip tabs
   =================================================================== */
.bf-pill {
	padding: 9px 17px; border-radius: 999px; border: 1px solid var(--bf-line-2);
	background: #fff; color: var(--bf-muted); font: 600 13.5px/1 var(--bf-body); cursor: pointer;
}
.bf-pill:hover { border-color: var(--bf-ink); color: var(--bf-ink); }
.bf-pill.is-active { background: var(--bf-blue); border-color: var(--bf-blue); color: #fff; }

/* ===================================================================
   WooCommerce: shop / archive
   =================================================================== */
.brofpv.woocommerce .site-main,
.brofpv.woocommerce-page .site-main { max-width: var(--bf-max); margin: 0 auto; padding: 30px 28px 60px; }

.bf-shop__head { display: flex; align-items: flex-end; justify-content: space-between; gap: 20px; margin-bottom: 26px; flex-wrap: wrap; }
.bf-shop__head h1 { margin: 0 0 6px; font: 700 36px/1.05 var(--bf-display); }
.bf-shop__head p { margin: 0; font: 400 15px/1 var(--bf-body); color: var(--bf-muted-2); }
.bf-shop__layout { display: grid; grid-template-columns: 230px 1fr; gap: 30px; align-items: start; }
.bf-shop__sidebar {
	position: sticky; top: var(--bf-sticky-top); background: #fff; border: 1px solid var(--bf-line);
	border-radius: var(--bf-radius-card); padding: 20px;
}
.bf-shop__sidebar h2 { font: 700 13px/1 var(--bf-body); color: var(--bf-ink); text-transform: uppercase; letter-spacing: .06em; margin: 0 0 14px; }
.bf-shop__filter { display: flex; flex-direction: column; gap: 2px; margin: 0; padding: 0; }
.bf-shop__filter-all { display: block; padding: 9px 12px; border-radius: 9px; font: 600 13.5px/1 var(--bf-body); color: var(--bf-muted); margin-bottom: 4px; }
.bf-shop__filter-all:hover, .bf-shop__filter-all.is-active { background: var(--bf-tint-blue); color: var(--bf-blue); }
.bf-check { position: relative; display: flex; align-items: center; gap: 10px; padding: 8px 12px; border-radius: 9px; cursor: pointer; font: 600 13.5px/1 var(--bf-body); color: var(--bf-muted); transition: background .15s ease; }
.bf-check:hover { background: var(--bf-tint-blue-2); }
.bf-check input { position: absolute; opacity: 0; width: 0; height: 0; }
.bf-check__box { width: 18px; height: 18px; border: 1.5px solid var(--bf-line-2); border-radius: 6px; flex-shrink: 0; display: flex; align-items: center; justify-content: center; transition: .15s; }
.bf-check__box::after { content: "✓"; font: 700 11px/1 var(--bf-body); color: #fff; opacity: 0; }
.bf-check input:checked ~ .bf-check__box { background: var(--bf-blue); border-color: var(--bf-blue); }
.bf-check input:checked ~ .bf-check__box::after { opacity: 1; }
.bf-check input:focus-visible ~ .bf-check__box { outline: 2px solid var(--bf-blue-soft); outline-offset: 2px; }
.bf-check input:checked ~ .bf-check__label { color: var(--bf-ink); }
.bf-check__label { flex: 1; }
.bf-shop__filter .count { font-size: 12px; color: var(--bf-muted-4); font-weight: 500; }
.bf-shop__filter-apply { margin-top: 14px; width: 100%; height: 40px; border: none; border-radius: 10px; background: var(--bf-blue); color: #fff; font: 700 13.5px/1 var(--bf-body); cursor: pointer; box-shadow: var(--bf-shadow-btn-blue); transition: background .15s ease; }
.bf-shop__filter-apply:hover { background: var(--bf-blue-dark); }
.bf-shop__tags { display: flex; flex-wrap: wrap; gap: 7px; }
.bf-shop__tags span { padding: 7px 12px; border: 1px solid #e6e9f0; background: #f6f7fb; color: var(--bf-muted); border-radius: 999px; font: 600 12px/1 var(--bf-body); }
.bf-shop__tags span.is-active { border-color: var(--bf-border-blue); background: var(--bf-tint-blue); color: var(--bf-blue); }

/* Woo ordering select restyled */
.brofpv .woocommerce-ordering select {
	appearance: none; -webkit-appearance: none; padding: 9px 34px 9px 14px;
	border: 1px solid var(--bf-line-2); border-radius: 9px; background: #fff;
	font: 600 13px/1 var(--bf-body); color: var(--bf-ink); cursor: pointer;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%238a93a6' stroke-width='1.6' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
	background-repeat: no-repeat; background-position: right 13px center;
}
.brofpv .woocommerce-result-count { font: 500 13px/1 var(--bf-body); color: var(--bf-muted-2); }

/* Woo native product grid -> bf cards */
.brofpv.woocommerce ul.products {
	display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; list-style: none; margin: 0; padding: 0;
}
.brofpv.woocommerce ul.products::before,
.brofpv.woocommerce ul.products::after { display: none; }
.brofpv.woocommerce ul.products li.product { width: auto; margin: 0; float: none; }

/* ===================================================================
   WooCommerce: single product
   =================================================================== */
.brofpv.single-product div.product {
	display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: start;
	position: relative;
}
.brofpv.single-product div.product > .onsale {
	position: absolute; top: 16px; left: 16px; z-index: 2; margin: 0;
	background: var(--bf-red); color: #fff;
	font: 700 11px/1 var(--bf-body); padding: 7px 12px; border-radius: 999px;
	letter-spacing: .03em; text-transform: uppercase;
}
.brofpv.single-product div.product .woocommerce-product-gallery {
	position: sticky; top: var(--bf-sticky-top); align-self: start;
	float: none; width: 100% !important; margin: 0;
}
.brofpv.single-product .woocommerce-product-gallery__image,
.brofpv.single-product .woocommerce-product-gallery__wrapper { border-radius: var(--bf-radius-lg); overflow: hidden; }
.brofpv.single-product .woocommerce-product-gallery img { border-radius: var(--bf-radius-lg); }

/* thumbnail strip: 4-column grid per design */
.brofpv.single-product div.product .woocommerce-product-gallery .flex-control-thumbs {
	display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px;
	margin: 14px 0 0; padding: 0; list-style: none; float: none;
}
/* The extra --with-images qualifier outweighs WooCommerce's
 * .--columns-N li { width: 22.15% } rule (same base specificity, loaded later),
 * which otherwise resolves against the grid track and shrinks the thumb. */
.brofpv.single-product div.product .woocommerce-product-gallery.woocommerce-product-gallery--with-images .flex-control-thumbs li {
	width: 100%; float: none; margin: 0; list-style: none;
}
.brofpv.single-product div.product .woocommerce-product-gallery.woocommerce-product-gallery--with-images .flex-control-thumbs img {
	display: block; width: 100%; height: auto;
	border-radius: 12px; border: 2px solid transparent; aspect-ratio: 1; object-fit: cover; opacity: 1; cursor: pointer;
}
.brofpv.single-product div.product .woocommerce-product-gallery .flex-control-thumbs img.flex-active,
.brofpv.single-product div.product .woocommerce-product-gallery .flex-control-thumbs img:hover {
	border-color: var(--bf-blue); opacity: 1;
}
.brofpv.single-product div.product .summary { margin: 0; width: 100%; float: none; }

/* eyebrow: category label + sale/featured badge */
.bf-pdp__eyebrow { display: flex; align-items: center; gap: 10px; margin-bottom: 14px; }
.bf-pdp__cat { font: 600 11px/1 var(--bf-body); color: var(--bf-blue); text-transform: uppercase; letter-spacing: .06em; text-decoration: none; }
.bf-pdp__cat:hover { color: var(--bf-blue-dark); }
.bf-pdp__badge { background: var(--bf-tint-red); color: var(--bf-red); font: 700 10.5px/1 var(--bf-body); padding: 5px 10px; border-radius: 999px; text-transform: uppercase; letter-spacing: .03em; }

.brofpv.single-product .product_title { margin: 0 0 12px; font: 700 40px/1.06 var(--bf-display); letter-spacing: -.02em; color: var(--bf-ink); }

.bf-pdp__rating { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.bf-pdp__stars { display: flex; align-items: center; gap: 5px; font: 600 14px/1 var(--bf-body); color: var(--bf-ink); }
.bf-pdp__stars .star { color: var(--bf-amber); }
.bf-pdp__reviews { font: 500 13px/1 var(--bf-body); color: var(--bf-muted-2); }

.bf-pdp__short { font: 400 16px/1.6 var(--bf-body); color: var(--bf-muted); margin-bottom: 24px; }

.bf-pdp__pricing { display: flex; align-items: baseline; gap: 12px; margin-bottom: 24px; flex-wrap: wrap; }
.bf-pdp__stock { font: 500 13px/1 var(--bf-body); color: var(--bf-green); }
.bf-pdp__stock--out { color: var(--bf-red); }
.brofpv.single-product .price {
	font: 700 34px/1 var(--bf-display) !important; color: var(--bf-ink) !important; margin: 0;
}
.brofpv.single-product .price del { color: var(--bf-muted-3); font-size: 20px; }
.brofpv.single-product .price ins { text-decoration: none; }
.brofpv.single-product .woocommerce-product-details__short-description {
	font: 400 16px/1.6 var(--bf-body); color: var(--bf-muted); margin-bottom: 24px;
}

/* add-to-cart row: quantity stepper + add + buy-now */
.brofpv.single-product form.cart:not(.variations_form) { display: flex; align-items: center; gap: 12px; margin-bottom: 24px; flex-wrap: wrap; }
.brofpv.single-product form.variations_form { margin-bottom: 24px; }
.brofpv.single-product .woocommerce-variation-add-to-cart { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; margin-top: 8px; }
.brofpv.single-product .cart .quantity { display: flex; align-items: center; border: 1px solid var(--bf-line-2); border-radius: 12px; overflow: hidden; }
.brofpv.single-product .cart .quantity input.qty {
	width: 48px; height: 48px; border: none; text-align: center; font: 700 16px/1 var(--bf-display);
	color: var(--bf-ink); background: #fff; -moz-appearance: textfield; appearance: textfield;
}
.brofpv.single-product .cart .quantity input.qty::-webkit-outer-spin-button,
.brofpv.single-product .cart .quantity input.qty::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.bf-qty-btn { width: 44px; height: 48px; border: none; background: #fff; cursor: pointer; font: 600 20px/1 var(--bf-body); color: var(--bf-muted); display: flex; align-items: center; justify-content: center; }
.bf-qty-btn:hover { background: #f0f2f8; }
.brofpv.single-product .single_add_to_cart_button {
	flex: 1; min-width: 180px; height: 48px; background: var(--bf-blue); color: #fff; border: none;
	border-radius: 12px; font: 700 15px/1 var(--bf-body); cursor: pointer; box-shadow: var(--bf-shadow-btn-blue);
}
.brofpv.single-product .single_add_to_cart_button:hover { background: var(--bf-blue-dark); }
.bf-buy-now { height: 48px; padding: 0 22px; background: var(--bf-ink); color: #fff; border: none; border-radius: 12px; font: 700 15px/1 var(--bf-body); cursor: pointer; }
.bf-buy-now:hover { background: var(--bf-ink-soft); }
.brofpv.single-product .product_meta { display: none; }

/* variation swatches (replace the attribute <select> dropdowns) */
.brofpv.single-product table.variations { width: 100%; border: none; margin: 0 0 8px; }
.brofpv.single-product table.variations tbody { display: block; }
/* Label + swatches share one row: label left, options right. */
.brofpv.single-product table.variations tr {
	display: flex; align-items: center; gap: 12px; margin: 0 0 10px;
}
.brofpv.single-product table.variations th,
.brofpv.single-product table.variations td { padding: 0; border: none; text-align: left; }
.brofpv.single-product table.variations th.label { flex: 0 0 auto; min-width: 56px; }
.brofpv.single-product table.variations td.value { flex: 1 1 auto; }
.brofpv.single-product table.variations .label label { font: 600 13px/1.4 var(--bf-body); color: var(--bf-muted); margin: 0; display: block; }
/* Once swatches are built, the native control is purely a value holder. */
.brofpv.single-product form.bf-has-swatches table.variations select { display: none; }
.brofpv.single-product .reset_variations { display: none !important; }
.bf-swatches { display: flex; flex-wrap: wrap; gap: 8px; }
.bf-swatch {
	min-width: 56px; padding: 0 16px; height: 44px; border: 1px solid var(--bf-line-2); background: #fff;
	border-radius: var(--bf-radius-input); font: 600 14px/1 var(--bf-body); color: var(--bf-ink);
	cursor: pointer; transition: border-color .15s ease, background .15s ease, color .15s ease;
}
.bf-swatch:hover { border-color: var(--bf-blue-soft); }
.bf-swatch.is-active { border-color: var(--bf-blue); background: var(--bf-tint-blue); color: var(--bf-blue-dark); }
.bf-swatch.is-disabled,
.bf-swatch:disabled { opacity: .4; cursor: not-allowed; text-decoration: line-through; }
.brofpv.single-product .single_add_to_cart_button.loading { opacity: .7; cursor: wait; }

/* perks injected by theme hook */
.bf-perks { display: flex; gap: 18px; padding: 16px 0; border-top: 1px solid var(--bf-line); border-bottom: 1px solid var(--bf-line); margin-bottom: 28px; flex-wrap: wrap; }
.bf-perks span { display: flex; align-items: center; gap: 8px; font: 500 13px/1.3 var(--bf-body); color: var(--bf-muted); }
.bf-perks span::before { content: "✓"; color: var(--bf-blue); font-weight: 700; }

/* inline specs (replaces the Additional Information tab) */
.bf-pdp__specs-title { margin: 8px 0 14px; font: 700 18px/1 var(--bf-display); color: var(--bf-ink); }
.bf-pdp__specs { background: #fff; border: 1px solid var(--bf-line); border-radius: 16px; overflow: hidden; }
.bf-pdp__spec-row { display: flex; justify-content: space-between; gap: 16px; padding: 13px 18px; }
.bf-pdp__spec-row:nth-child(even) { background: #fafbfd; }
.bf-pdp__spec-k { font: 500 13.5px/1.4 var(--bf-body); color: var(--bf-muted-2); }
.bf-pdp__spec-v { font: 600 13.5px/1.4 var(--bf-body); color: var(--bf-ink); text-align: right; }
.brofpv.single-product .shop_attributes { width: 100%; border: 1px solid var(--bf-line); border-radius: 16px; overflow: hidden; border-collapse: collapse; }
.brofpv.single-product .shop_attributes th, .brofpv.single-product .shop_attributes td { padding: 13px 18px; font: 500 13.5px/1.4 var(--bf-body); text-align: left; border: none; }
.brofpv.single-product .shop_attributes tr:nth-child(odd) { background: #fafbfd; }
.brofpv.single-product .shop_attributes th { color: var(--bf-muted-2); font-weight: 500; width: 40%; }
.brofpv.single-product .shop_attributes td { color: var(--bf-ink); font-weight: 600; }
.brofpv.single-product .shop_attributes td p { margin: 0; }

/* full-width sections below the two-column grid */
.brofpv.single-product .bf-pdp__description { margin-top: 56px; }
.brofpv.single-product .bf-pdp__description > h2 { font: 700 26px/1.1 var(--bf-display); letter-spacing: -.02em; margin: 0 0 18px; color: var(--bf-ink); }
.brofpv.single-product .bf-pdp__description-body { font: 400 16px/1.7 var(--bf-body); color: var(--bf-muted); max-width: 820px; }
.brofpv.single-product .bf-pdp__description-body :is(h2, h3, h4) { color: var(--bf-ink); font-family: var(--bf-display); margin: 1.4em 0 .5em; }
.brofpv.single-product .bf-pdp__description-body p { margin: 0 0 1em; }
.brofpv.single-product .bf-pdp__description-body img { max-width: 100%; height: auto; border-radius: var(--bf-radius-card); }
.brofpv.single-product .related, .brofpv.single-product .upsells { margin-top: 56px; }
.brofpv.single-product .related h2, .brofpv.single-product .upsells h2 { font: 700 26px/1.1 var(--bf-display); letter-spacing: -.02em; margin: 0 0 20px; }
.brofpv.single-product .related ul.products, .brofpv.single-product .upsells ul.products { grid-template-columns: repeat(4, 1fr); }

/* ===================================================================
   WooCommerce: cart
   =================================================================== */
.brofpv.woocommerce-cart .site-main { max-width: var(--bf-max); }
.bf-cart-title { margin: 0 0 26px; font: 700 36px/1.05 var(--bf-display); }
.bf-cart { display: grid; grid-template-columns: 1fr 360px; gap: 28px; align-items: start; }
.bf-cart__lines { display: flex; flex-direction: column; gap: 12px; }
.bf-cart-line {
	background: #fff; border: 1px solid var(--bf-line); border-radius: var(--bf-radius-card);
	padding: 16px; display: flex; gap: 16px; align-items: center;
}
.bf-cart-line__thumb { width: 92px; height: 80px; border-radius: 12px; background: var(--bf-stripe); flex-shrink: 0; overflow: hidden; display: flex; align-items: center; justify-content: center; }
.bf-cart-line__thumb img { width: 100%; height: 100%; object-fit: cover; }
.bf-cart-line__info { flex: 1; min-width: 0; }
.bf-cart-line__cat { font: 600 10.5px/1 var(--bf-body); color: var(--bf-blue); text-transform: uppercase; letter-spacing: .06em; margin-bottom: 5px; }
.bf-cart-line__name { font: 600 16px/1.2 var(--bf-display); color: var(--bf-ink); margin-bottom: 6px; }
.bf-cart-line__name a { color: inherit; }
/* Variation attributes (Size: 2 inch) — keep label + value on one line. */
.bf-cart-line__name .variation { display: flex; flex-wrap: wrap; gap: 2px 10px; margin: 5px 0 0; font: 500 12.5px/1.4 var(--bf-body); color: var(--bf-muted-2); }
.bf-cart-line__name .variation dt { margin: 0; font-weight: 600; }
.bf-cart-line__name .variation dd { margin: 0; }
.bf-cart-line__name .variation dd p { margin: 0; }
.bf-cart-line__unit { font: 500 13px/1 var(--bf-body); color: var(--bf-muted-2); }
.bf-cart-line .quantity { display: flex; align-items: center; border: 1px solid var(--bf-line-2); border-radius: 10px; overflow: hidden; }
.bf-cart-line .quantity input.qty { width: 46px; height: 38px; border: none; text-align: center; font: 700 14px/1 var(--bf-display); background: #fff; }
.bf-cart-line__total { width: 120px; text-align: right; font: 700 16px/1 var(--bf-display); color: var(--bf-ink); }
.bf-cart-line__remove { width: 34px; height: 34px; border: none; background: none; cursor: pointer; color: var(--bf-muted-4); font: 600 20px/1 var(--bf-body); border-radius: 9px; text-align: center; }
.bf-cart-line__remove:hover { background: var(--bf-tint-red); color: var(--bf-red); }

.bf-summary { position: sticky; top: var(--bf-sticky-top); background: #fff; border: 1px solid var(--bf-line); border-radius: 20px; padding: 24px; }
.bf-summary h2 { font: 700 18px/1 var(--bf-display); color: var(--bf-ink); margin: 0 0 18px; }
.bf-summary__row { display: flex; justify-content: space-between; margin-bottom: 12px; font: 500 14px/1.4 var(--bf-body); color: var(--bf-muted); }
.bf-summary__row span:last-child { color: var(--bf-ink); font-weight: 600; }
.bf-summary__rule { height: 1px; background: var(--bf-line); margin: 16px 0; }
.bf-summary__total { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 20px; }
.bf-summary__total .l { font: 600 15px/1 var(--bf-body); color: var(--bf-ink); }
.bf-summary__total .v { font: 700 24px/1 var(--bf-display); color: var(--bf-ink); }

.bf-empty {
	background: #fff; border: 1px solid var(--bf-line); border-radius: 20px; padding: 64px 40px; text-align: center;
}
.bf-empty__glyph { width: 60px; height: 60px; border-radius: 16px; background: #f0f2f8; display: flex; align-items: center; justify-content: center; margin: 0 auto 18px; font: 600 26px/1 var(--bf-display); color: var(--bf-muted-4); }
.bf-empty h2 { font: 700 22px/1.2 var(--bf-display); color: var(--bf-ink); margin: 0 0 10px; }
.bf-empty p { margin: 0 0 24px; font: 400 15px/1.5 var(--bf-body); color: var(--bf-muted-2); }

/* ===================================================================
   WooCommerce: checkout
   =================================================================== */
.brofpv.woocommerce-checkout .site-main { max-width: var(--bf-max); }
.brofpv.woocommerce-checkout h1.entry-title { margin: 0 0 26px; font: 700 36px/1.05 var(--bf-display); }
/*
 * The coupon block is a sibling <form> before form.checkout (can't be nested
 * inside it). Make form.checkout `display: contents` so its children join the
 * grid at the .woocommerce level — letting the coupon sit in the right column
 * above the order summary without nesting forms.
 */
/* Explicit row tracks + a trailing 1fr filler. #customer_details (left) is far
 * taller than the right-hand stack; spanning it across auto rows made the grid
 * distribute its extra height into every empty right-column row (a visible gap
 * above the order summary when the coupon form is collapsed). Pinning the right
 * rows to min-content and sending the overflow to the 1fr row removes it. */
.brofpv.woocommerce-checkout .woocommerce { display: grid; grid-template-columns: 1fr 360px; grid-template-rows: min-content min-content min-content min-content min-content 1fr; column-gap: 28px; align-items: start; align-content: start; }
.brofpv.woocommerce-checkout form.checkout { display: contents; }
.brofpv.woocommerce-checkout .woocommerce-notices-wrapper:empty { display: none; }
/* Notices (e.g. "added to cart") must span both columns at the top; without an
 * explicit placement they get auto-placed into a content cell and overlap it. */
.brofpv.woocommerce-checkout .woocommerce-notices-wrapper { grid-column: 1 / -1; grid-row: 1; margin: 0 0 18px; }
.brofpv.woocommerce-checkout #customer_details { grid-column: 1; grid-row: 2 / 7; }
.brofpv.woocommerce-checkout .woocommerce-form-coupon-toggle { grid-column: 2; grid-row: 2; margin: 0 0 16px; }
.brofpv.woocommerce-checkout form.checkout_coupon { grid-column: 2; grid-row: 3; margin: 0 0 16px; }
.brofpv.woocommerce-checkout #order_review_heading { grid-column: 2; grid-row: 4; margin: 0 0 16px; }
.brofpv.woocommerce-checkout #order_review { grid-column: 2; grid-row: 5; align-self: start; }
.brofpv.woocommerce-checkout .col2-set .col-1,
.brofpv.woocommerce-checkout .col2-set .col-2 { width: 100%; float: none; }
.brofpv.woocommerce-checkout .woocommerce-billing-fields,
.brofpv.woocommerce-checkout .woocommerce-shipping-fields,
.brofpv.woocommerce-checkout .woocommerce-additional-fields {
	background: #fff; border: 1px solid var(--bf-line); border-radius: var(--bf-radius-card); padding: 24px; margin-bottom: 20px;
}
/* Hide the shipping-fields card when it has no fields to show. WooCommerce
 * leaves whitespace text nodes inside the wrapper, so :empty never matches;
 * :not(:has(*)) catches the "no element children" case it misses. */
.brofpv.woocommerce-checkout .woocommerce-shipping-fields:empty,
.brofpv.woocommerce-checkout .woocommerce-shipping-fields:not(:has(*)) { display: none; }
.brofpv.woocommerce-checkout h3 { font: 700 16px/1 var(--bf-display); color: var(--bf-ink); margin: 0 0 18px; }
.brofpv.woocommerce-checkout #order_review { position: sticky; top: var(--bf-sticky-top); background: #fff; border: 1px solid var(--bf-line); border-radius: 20px; padding: 24px; }
.brofpv.woocommerce-checkout .shop_table { width: 100%; border-collapse: collapse; }
.brofpv.woocommerce-checkout .shop_table th, .brofpv.woocommerce-checkout .shop_table td { padding: 10px 0; font: 500 14px/1.4 var(--bf-body); text-align: left; border-bottom: 1px solid var(--bf-line); }
/* Right-align the value column; bold the table head ("Sản phẩm" / "Tạm tính"). */
.brofpv.woocommerce-checkout .shop_table th:last-child,
.brofpv.woocommerce-checkout .shop_table td:last-child { text-align: right; }
.brofpv.woocommerce-checkout .shop_table thead th { font-weight: 700; }
.brofpv.woocommerce-checkout .order-total .amount { font: 700 22px/1 var(--bf-display); color: var(--bf-blue); }
.brofpv.woocommerce-checkout #payment { background: transparent; border-radius: 0; }
.brofpv.woocommerce-checkout #payment ul.payment_methods { border: none; padding: 0; margin: 0 0 16px; list-style: none; }
.brofpv.woocommerce-checkout #payment ul.payment_methods li {
	border: 1.5px solid var(--bf-line-2); border-radius: 13px; padding: 15px 16px; margin-bottom: 10px;
}
.brofpv.woocommerce-checkout #payment ul.payment_methods li label { font: 500 14px/1.4 var(--bf-body); color: var(--bf-ink); }
.brofpv.woocommerce-checkout #payment ul.payment_methods li input[type=radio]:checked + label { color: var(--bf-blue); }
/* COD description + privacy notice were rendering at the 16px browser default,
 * out of step with the 13–14px checkout scale. Pull them onto the theme type. */
.brofpv.woocommerce-checkout #payment .payment_box,
.brofpv.woocommerce-checkout #payment .payment_box p { font: 400 13px/1.5 var(--bf-body); color: var(--bf-muted); margin: 6px 0 0; }
.brofpv.woocommerce-checkout .woocommerce-privacy-policy-text,
.brofpv.woocommerce-checkout .woocommerce-privacy-policy-text p { font: 400 13px/1.5 var(--bf-body); color: var(--bf-muted); }
.brofpv.woocommerce-checkout #place_order {
	width: 100%; height: 52px; background: var(--bf-red); color: #fff; border: none; border-radius: 13px;
	font: 700 15px/1 var(--bf-body); cursor: pointer; box-shadow: var(--bf-shadow-btn-red);
}
.brofpv.woocommerce-checkout #place_order:hover { background: var(--bf-red-dark); }
/* Coupon toggle ("Bạn có mã ưu đãi?") — WC ships it as a bare .woocommerce-info
 * with no theme styling; give it a soft card to match the summary. */
.brofpv.woocommerce-checkout .woocommerce-form-coupon-toggle .woocommerce-info {
	margin: 0; padding: 13px 16px; background: #f6f8fb;
	border: 1px solid var(--bf-line); border-radius: 12px;
	font: 500 13.5px/1.4 var(--bf-body); color: var(--bf-muted);
}
.brofpv.woocommerce-checkout .woocommerce-form-coupon-toggle .woocommerce-info::before { content: none; }
.brofpv.woocommerce-checkout .woocommerce-form-coupon-toggle .woocommerce-info a { color: var(--bf-blue); font-weight: 600; }
/* Coupon form: WC stacks the input and button as two .form-row <p> blocks.
 * Lay them on one row and give the button the theme's blue secondary style. */
.brofpv.woocommerce-checkout form.checkout_coupon { display: flex; gap: 10px; align-items: stretch; }
.brofpv.woocommerce-checkout form.checkout_coupon .form-row { margin: 0; padding: 0; width: auto; }
.brofpv.woocommerce-checkout form.checkout_coupon .form-row-first { flex: 1 1 auto; }
.brofpv.woocommerce-checkout form.checkout_coupon .form-row-last { flex: 0 0 auto; display: flex; }
.brofpv.woocommerce-checkout form.checkout_coupon .input-text { margin: 0; }
.brofpv.woocommerce-checkout form.checkout_coupon .button {
	align-self: stretch; padding: 0 22px; background: var(--bf-blue); color: #fff; border: none;
	border-radius: var(--bf-radius-input); font: 600 14px/1 var(--bf-body); cursor: pointer; white-space: nowrap;
}
.brofpv.woocommerce-checkout form.checkout_coupon .button:hover { background: var(--bf-blue-dark); }

/* ===================================================================
   Shared form fields (checkout, account, edit address)
   =================================================================== */
.brofpv .woocommerce form .form-row,
.brofpv .form-row { margin: 0 0 14px; padding: 0; }
.brofpv .woocommerce form .form-row label,
.brofpv form .form-row label { display: block; font: 600 12.5px/1 var(--bf-body); color: var(--bf-muted); margin-bottom: 7px; }
.brofpv input[type=text], .brofpv input[type=email], .brofpv input[type=tel],
.brofpv input[type=password], .brofpv input[type=number], .brofpv input[type=url],
.brofpv input[type=search], .brofpv textarea, .brofpv select,
.brofpv .woocommerce form .form-row input.input-text,
.brofpv .select2-container .select2-selection {
	width: 100%; padding: 12px 14px; border: 1px solid var(--bf-line-2);
	border-radius: var(--bf-radius-input); font: 500 14px/1.3 var(--bf-body);
	color: var(--bf-ink); background: #fff;
}
.brofpv input:focus, .brofpv textarea:focus, .brofpv select:focus {
	outline: none; border-color: var(--bf-blue); box-shadow: 0 0 0 3px rgba(31, 92, 255, .12);
}
.brofpv select {
	appearance: none; -webkit-appearance: none;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%238a93a6' stroke-width='1.6' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
	background-repeat: no-repeat; background-position: right 14px center; padding-right: 36px;
}
/* select2 (country/state dropdowns) — align its single-select box with the
 * native input styling. The generic .select2-selection rule above applies the
 * input's 12px vertical padding on top of select2's fixed 28px height, which
 * clips the text and floats the arrow; reset to a flex-centred 46px box. */
.brofpv .select2-container--default .select2-selection--single {
	height: auto; min-height: 46px; display: flex; align-items: center;
	padding: 0 14px; border: 1px solid var(--bf-line-2); border-radius: var(--bf-radius-input); background: #fff;
}
.brofpv .select2-container--default .select2-selection--single .select2-selection__rendered {
	padding: 0; line-height: 1.3; color: var(--bf-ink); font: 500 14px/1.3 var(--bf-body);
}
.brofpv .select2-container--default .select2-selection--single .select2-selection__arrow {
	height: 100%; top: 0; right: 10px;
}
.brofpv .select2-container--default.select2-container--open .select2-selection--single {
	border-color: var(--bf-blue); box-shadow: 0 0 0 3px rgba(31, 92, 255, .12);
}

/* Field validation states. WooCommerce only paints a thin inset bar on invalid
 * fields by default — replace it with a full red/green border + soft ring so
 * the state reads clearly and matches the theme's focus styling. */
.brofpv .woocommerce form .form-row.woocommerce-invalid input.input-text,
.brofpv .woocommerce form .form-row.woocommerce-invalid select,
.brofpv .woocommerce form .form-row.woocommerce-invalid textarea,
.brofpv .form-row.woocommerce-invalid input.input-text,
.brofpv .form-row.woocommerce-invalid select,
.brofpv .form-row.woocommerce-invalid textarea {
	border-color: var(--bf-red);
	box-shadow: 0 0 0 3px rgba(255, 45, 70, .12);
}
.brofpv .woocommerce-invalid .select2-container--default .select2-selection--single {
	border-color: var(--bf-red);
	box-shadow: 0 0 0 3px rgba(255, 45, 70, .12);
}
.brofpv .woocommerce form .form-row.woocommerce-validated input.input-text,
.brofpv .woocommerce form .form-row.woocommerce-validated select,
.brofpv .woocommerce form .form-row.woocommerce-validated textarea,
.brofpv .form-row.woocommerce-validated input.input-text,
.brofpv .form-row.woocommerce-validated select,
.brofpv .form-row.woocommerce-validated textarea {
	border-color: var(--bf-green);
}
.brofpv .woocommerce-validated .select2-container--default .select2-selection--single {
	border-color: var(--bf-green);
}

/* Required-field errors: hide the top list (brofpv.js mirrors each message
 * inline under its field) but keep genuine non-field errors visible. The group
 * collapses only when it holds nothing but field errors. */
.brofpv.woocommerce-checkout .woocommerce-error li[data-id] { display: none; }
.brofpv.woocommerce-checkout .woocommerce-NoticeGroup-checkout:not(:has(.woocommerce-message)):not(:has(.woocommerce-info)):not(:has(.woocommerce-error li:not([data-id]))) {
	display: none;
}
/* Non-field error notices (coupon, payment, generic) stay as a compact red card. */
.brofpv.woocommerce-checkout .woocommerce-error {
	margin: 0 0 18px; padding: 12px 16px; list-style: none;
	background: rgba(255, 45, 70, .06); border: 1px solid rgba(255, 45, 70, .25);
	border-radius: 12px;
}
.brofpv.woocommerce-checkout .woocommerce-error li {
	margin: 0; padding: 3px 0; list-style: none;
	font: 500 12.5px/1.45 var(--bf-body); color: var(--bf-red);
}
.brofpv.woocommerce-checkout .woocommerce-error li a,
.brofpv.woocommerce-checkout .woocommerce-error li strong {
	color: var(--bf-red); font-weight: 600; text-decoration: none;
}
/* Inline per-field error message injected below the input by brofpv.js. */
.brofpv.woocommerce-checkout .form-row .bf-field-error {
	display: block; margin-top: 6px;
	font: 500 12px/1.4 var(--bf-body); color: var(--bf-red);
}

/* ===================================================================
   WooCommerce: order received / thankyou
   =================================================================== */
/* Order-received reuses the .woocommerce-checkout body class, which drives the
   two-column checkout grid; reset it so the thankyou card can center. */
.brofpv.woocommerce-order-received .woocommerce { display: block; }
.bf-thankyou { max-width: 620px; margin: 0 auto; padding: 80px 28px; text-align: center; }
.bf-thankyou__check {
	width: 72px; height: 72px; border-radius: 50%; background: #eafaf1; border: 1px solid #c5edd6;
	display: flex; align-items: center; justify-content: center; margin: 0 auto 24px;
	font: 700 32px/1 var(--bf-display); color: var(--bf-green);
}
.bf-thankyou h1 { margin: 0 0 12px; font: 700 34px/1.1 var(--bf-display); }
.bf-thankyou p { margin: 0 0 8px; font: 400 16px/1.6 var(--bf-body); color: var(--bf-muted); }
.bf-thankyou__no { font: 700 22px/1 var(--bf-display); color: var(--bf-blue); margin: 8px 0 28px; }
.bf-thankyou__actions { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; margin-top: 24px; }

/* Payment-method note from the gateway (COD: "Trả tiền mặt khi giao hàng."),
   output as a bare <p> right after the actions row. Render as a pill badge. */
.bf-thankyou .bf-thankyou__actions + p {
	display: inline-block;
	margin: 24px 0 0;
	padding: 8px 16px;
	border-radius: 999px;
	background: var(--bf-blue-tint, #eef3ff);
	border: 1px solid var(--bf-line);
	font: 600 13.5px/1.3 var(--bf-body);
	color: var(--bf-blue);
}

/* Order + customer detail blocks (WC default templates, unstyled here). */
.bf-thankyou .woocommerce-order-details,
.bf-thankyou .woocommerce-customer-details {
	text-align: left;
	margin-top: 40px;
	background: #fff;
	border: 1px solid var(--bf-line);
	border-radius: 16px;
	padding: 24px;
}
.bf-thankyou .woocommerce-order-details__title,
.bf-thankyou .woocommerce-column__title {
	margin: 0 0 16px;
	font: 700 18px/1.2 var(--bf-display);
	color: var(--bf-ink);
}
.bf-thankyou table.order_details {
	width: 100%;
	margin: 0;
	border: none;
	border-collapse: collapse;
	font: 400 14.5px/1.5 var(--bf-body);
}
.bf-thankyou table.order_details th,
.bf-thankyou table.order_details td {
	padding: 12px 0;
	border-bottom: 1px solid var(--bf-line);
	vertical-align: top;
	text-align: left;
}
.bf-thankyou table.order_details thead th {
	font: 600 12px/1.4 var(--bf-body);
	text-transform: uppercase;
	letter-spacing: .04em;
	color: var(--bf-muted-2);
}
.bf-thankyou table.order_details .product-total,
.bf-thankyou table.order_details td.product-total,
.bf-thankyou table.order_details tfoot td { text-align: right; white-space: nowrap; }
.bf-thankyou table.order_details .product-name { color: var(--bf-ink); font-weight: 600; }
.bf-thankyou table.order_details .product-name a { color: var(--bf-ink); text-decoration: none; }
.bf-thankyou table.order_details .wc-item-meta {
	margin: 6px 0 0; padding: 0; list-style: none;
	font: 400 13px/1.5 var(--bf-body); color: var(--bf-muted);
}
.bf-thankyou table.order_details .wc-item-meta p,
.bf-thankyou table.order_details .wc-item-meta strong { margin: 0; font-weight: 500; display: inline; }
.bf-thankyou table.order_details tfoot th {
	font: 600 14.5px/1.5 var(--bf-body); color: var(--bf-muted);
}
.bf-thankyou table.order_details tfoot tr:last-child th,
.bf-thankyou table.order_details tfoot tr:last-child td {
	border-bottom: none; font-weight: 700; color: var(--bf-ink); font-size: 16px;
}
.bf-thankyou .woocommerce-customer-details address {
	font: 400 14.5px/1.7 var(--bf-body); color: var(--bf-muted);
	font-style: normal; border: none; padding: 0;
}

/* ===================================================================
   WooCommerce: My Account
   =================================================================== */
.brofpv.woocommerce-account .site-header,
.brofpv.woocommerce-account .bf-header { /* keep store header */ }
.bf-account__bar { background: #fff; border-bottom: 1px solid var(--bf-line); position: sticky; top: 68px; z-index: 50; }
.bf-account__bar-inner { max-width: var(--bf-max); margin: 0 auto; padding: 0 28px; display: flex; align-items: center; gap: 4px; flex-wrap: wrap; }
.brofpv.woocommerce-account .woocommerce { max-width: var(--bf-max); margin: 0 auto; padding: 30px 28px 72px; }
.brofpv.woocommerce-account .woocommerce-MyAccount-navigation { float: none; width: 100%; margin: 0 0 24px; }
.brofpv.woocommerce-account .woocommerce-MyAccount-navigation ul {
	display: flex; align-items: center; gap: 4px; list-style: none; margin: 0; padding: 0;
	border-bottom: 1px solid var(--bf-line); flex-wrap: wrap;
}
.brofpv.woocommerce-account .woocommerce-MyAccount-navigation li a {
	display: block; padding: 14px 16px; font: 600 14.5px/1 var(--bf-body); color: var(--bf-muted);
	border-bottom: 2.5px solid transparent;
}
.brofpv.woocommerce-account .woocommerce-MyAccount-navigation li.is-active a,
.brofpv.woocommerce-account .woocommerce-MyAccount-navigation li a:hover { color: var(--bf-ink); border-color: var(--bf-blue); }
.brofpv.woocommerce-account .woocommerce-MyAccount-navigation li--logout a { color: var(--bf-red); border-color: transparent; }
.brofpv.woocommerce-account .woocommerce-MyAccount-content { float: none; width: 100%; }
.brofpv.woocommerce-account .woocommerce-MyAccount-content h2,
.brofpv.woocommerce-account .woocommerce-MyAccount-content h3 { font-family: var(--bf-display); }

.bf-acct-hero {
	position: relative; overflow: hidden; border-radius: var(--bf-radius-lg); background: var(--bf-ink);
	padding: 32px 36px; margin-bottom: 22px; display: flex; align-items: center; justify-content: space-between;
	gap: 24px; flex-wrap: wrap;
}
.bf-acct-hero::before {
	content: ""; position: absolute; inset: 0;
	background: radial-gradient(70% 130% at 90% 10%, rgba(31, 92, 255, .4), transparent 55%),
		radial-gradient(60% 120% at 0% 100%, rgba(255, 45, 70, .3), transparent 55%);
}
.bf-acct-hero__copy { position: relative; }
.bf-acct-hero .eyebrow { font: 600 12px/1 var(--bf-body); color: #7b849a; text-transform: uppercase; letter-spacing: .08em; margin-bottom: 10px; }
.bf-acct-hero h1 { margin: 0 0 8px; font: 700 30px/1.1 var(--bf-display); color: #fff; }
.bf-acct-hero p { margin: 0; font: 400 14.5px/1.5 var(--bf-body); color: #aab4cc; }
.bf-acct-hero .bf-btn { position: relative; background: #fff; color: var(--bf-ink); box-shadow: none; }

.bf-stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; margin-bottom: 22px; }
.bf-stat { background: #fff; border: 1px solid var(--bf-line); border-radius: 16px; padding: 20px; }
.bf-stat__glyph { width: 38px; height: 38px; border-radius: 11px; background: var(--bf-tint-blue); display: flex; align-items: center; justify-content: center; font: 700 16px/1 var(--bf-display); color: var(--bf-blue); margin-bottom: 14px; }
.bf-stat__glyph--red { background: var(--bf-tint-red); color: var(--bf-red); }
.bf-stat__n { font: 700 26px/1 var(--bf-display); color: var(--bf-ink); margin-bottom: 5px; }
.bf-stat__l { font: 500 13px/1 var(--bf-body); color: var(--bf-muted-2); }

.bf-card { background: #fff; border: 1px solid var(--bf-line); border-radius: var(--bf-radius-card); padding: 22px 24px; }
.bf-card__head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 16px; }
.bf-card__head h2 { margin: 0; font: 700 17px/1 var(--bf-display); color: var(--bf-ink); }
.bf-grid-2 { display: grid; grid-template-columns: 1fr 340px; gap: 18px; align-items: start; }
.bf-stack { display: flex; flex-direction: column; gap: 18px; }

/* status badges */
.bf-status { display: inline-flex; align-items: center; gap: 6px; padding: 5px 11px; border-radius: 999px; font: 600 12px/1 var(--bf-body); white-space: nowrap; }
.bf-status::before { content: ""; width: 6px; height: 6px; border-radius: 50%; background: currentColor; }
.bf-status--processing, .bf-status--on-hold { background: #fff6e6; color: #b9791a; }
.bf-status--completed { background: #e9f8ef; color: #1f9d57; }
.bf-status--shipping, .bf-status--out-for-delivery { background: var(--bf-tint-blue); color: var(--bf-blue); }
.bf-status--cancelled, .bf-status--failed, .bf-status--refunded { background: var(--bf-tint-red); color: var(--bf-red); }
.bf-status--pending { background: #f0f2f8; color: var(--bf-muted); }

/* orders table -> cards (My Account orders) */
.brofpv .woocommerce-orders-table { width: 100%; border-collapse: separate; border-spacing: 0 14px; }
.brofpv .woocommerce-orders-table thead { display: none; }
.brofpv .woocommerce-orders-table tbody tr {
	display: grid; grid-template-columns: repeat(2, auto) 1fr auto auto; gap: 14px; align-items: center;
	background: #fff; border: 1px solid var(--bf-line); border-radius: var(--bf-radius-card); padding: 16px 22px;
}
.brofpv .woocommerce-orders-table td { border: none; padding: 0; font: 500 13.5px/1.3 var(--bf-body); color: var(--bf-muted); }
.brofpv .woocommerce-orders-table td.woocommerce-orders-table__cell-order-number a { font: 700 15px/1 var(--bf-display); color: var(--bf-ink); }
.brofpv .woocommerce-orders-table td.woocommerce-orders-table__cell-order-total { font: 700 15px/1 var(--bf-display); color: var(--bf-ink); }
.brofpv .woocommerce-orders-table td.woocommerce-orders-table__cell-order-actions { text-align: right; }
.brofpv .woocommerce-orders-table .woocommerce-button {
	display: inline-block; padding: 9px 16px; border-radius: 10px; background: var(--bf-blue); color: #fff;
	font: 600 13px/1 var(--bf-body); border: none; cursor: pointer; margin-left: 6px;
}
.brofpv .woocommerce-orders-table .woocommerce-button.view { background: var(--bf-blue); }
.brofpv .woocommerce-orders-table .woocommerce-button:hover { background: var(--bf-blue-dark); color: #fff; }

/* address cards */
.brofpv.woocommerce-account .addresses .col2-set { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.brofpv.woocommerce-account .addresses .col-1, .brofpv.woocommerce-account .addresses .col-2 { width: 100%; float: none; }
.brofpv .woocommerce-Address { background: #fff; border: 1px solid var(--bf-line); border-radius: var(--bf-radius-card); padding: 22px 24px; }
.brofpv .woocommerce-Address address { font: 500 13.5px/1.6 var(--bf-body); color: var(--bf-muted); font-style: normal; }

/* dashboard recent order rows */
.bf-recent { display: flex; flex-direction: column; }
.bf-recent__row { display: flex; align-items: center; gap: 14px; padding: 14px 0; border-top: 1px solid #f1f2f6; }
.bf-recent__thumb { width: 46px; height: 46px; border-radius: 11px; background: var(--bf-stripe); flex-shrink: 0; }
.bf-recent__no { font: 600 14px/1.2 var(--bf-display); color: var(--bf-ink); margin-bottom: 4px; }
.bf-recent__meta { font: 500 12.5px/1 var(--bf-body); color: var(--bf-muted-2); }
.bf-recent__total { width: 110px; text-align: right; font: 700 14.5px/1 var(--bf-display); color: var(--bf-ink); }

/* shipping tracker */
.bf-tracker { background: var(--bf-tint-blue-2); border: 1px solid #e1ebff; border-radius: 14px; padding: 17px 20px 19px; margin-top: 14px; }
.bf-tracker__head { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 18px; flex-wrap: wrap; }
.bf-tracker__note { font: 600 13px/1.3 var(--bf-body); color: var(--bf-blue); }
.bf-tracker__eta { font: 500 12.5px/1 var(--bf-body); color: var(--bf-muted-2); }
.bf-tracker__rail { position: relative; }
.bf-tracker__line { position: absolute; top: 8px; left: 12.5%; width: 75%; height: 2px; background: #d3e1ff; }
.bf-tracker__fill { position: absolute; top: 8px; left: 12.5%; height: 2px; background: var(--bf-blue); }
.bf-tracker__steps { position: relative; display: flex; }
.bf-tracker__step { width: 25%; display: flex; flex-direction: column; align-items: center; gap: 9px; }
.bf-tracker__dot { width: 18px; height: 18px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font: 700 9px/1 var(--bf-display); color: #fff; box-shadow: 0 0 0 4px var(--bf-tint-blue-2); background: #cdd7ea; border: 2px solid #cdd7ea; }
.bf-tracker__step.is-done .bf-tracker__dot { background: var(--bf-blue); border-color: var(--bf-blue); }
.bf-tracker__label { font: 600 11.5px/1.2 var(--bf-body); color: var(--bf-muted-2); text-align: center; }
.bf-tracker__step.is-done .bf-tracker__label { color: var(--bf-ink); }

/* ===================================================================
   Blog
   =================================================================== */
.brofpv.blog .site-main, .brofpv.archive .site-main, .brofpv.single-post .site-main,
.brofpv.search .site-main { max-width: var(--bf-max); margin: 0 auto; padding: 30px 28px 64px; }
.bf-blog__intro { margin-bottom: 26px; }
.bf-blog__intro h1 { margin: 14px 0 8px; font: 700 38px/1.05 var(--bf-display); }
.bf-blog__intro p { margin: 0; font: 400 16px/1.5 var(--bf-body); color: var(--bf-muted-2); max-width: 580px; }
.bf-articles { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.bf-article {
	background: #fff; border: 1px solid var(--bf-line); border-radius: var(--bf-radius-card); overflow: hidden;
	display: flex; flex-direction: column; transition: .2s;
}
.bf-article:hover { box-shadow: var(--bf-shadow-card); transform: translateY(-3px); border-color: #e1e5ef; }
.bf-article__media { position: relative; aspect-ratio: 16/10; background: var(--bf-stripe); overflow: hidden; }
.bf-article__media img { width: 100%; height: 100%; object-fit: cover; }
.bf-article__cat { position: absolute; top: 12px; left: 12px; background: var(--bf-tint-blue); color: var(--bf-blue); font: 700 10.5px/1 var(--bf-body); padding: 5px 10px; border-radius: 999px; text-transform: uppercase; letter-spacing: .04em; }
.bf-article__body { padding: 16px 16px 18px; display: flex; flex-direction: column; gap: 9px; flex: 1; }
.bf-article__body h2, .bf-article__body h3 { margin: 0; font: 600 16px/1.3 var(--bf-display); }
.bf-article__body h2 a, .bf-article__body h3 a { color: var(--bf-ink); }
.bf-article__excerpt { margin: 0; font: 400 13.5px/1.55 var(--bf-body); color: var(--bf-muted); }
.bf-article__meta { margin-top: auto; padding-top: 6px; font: 500 12px/1 var(--bf-body); color: var(--bf-muted-3); }

/* featured article */
.bf-feature-article { display: grid; grid-template-columns: 1.3fr 1fr; border: 1px solid var(--bf-line); border-radius: var(--bf-radius-lg); overflow: hidden; background: #fff; margin-bottom: 34px; transition: .2s; }
.bf-feature-article:hover { box-shadow: 0 24px 50px -28px rgba(16, 24, 64, .34); border-color: #e1e5ef; }
.bf-feature-article__media { position: relative; aspect-ratio: 16/10; background: var(--bf-stripe-cool); overflow: hidden; }
.bf-feature-article__media img { width: 100%; height: 100%; object-fit: cover; }
.bf-feature-article__body { padding: 32px 30px; display: flex; flex-direction: column; justify-content: center; }
.bf-feature-article__body .tag { font: 700 11px/1 var(--bf-body); color: var(--bf-red); text-transform: uppercase; letter-spacing: .06em; margin-bottom: 13px; }
.bf-feature-article__body h2 { margin: 0 0 12px; font: 700 26px/1.2 var(--bf-display); }
.bf-feature-article__body h2 a { color: var(--bf-ink); }
.bf-feature-article__body p { margin: 0 0 18px; font: 400 15px/1.6 var(--bf-body); color: var(--bf-muted); }
.bf-feature-article__body .meta { font: 500 13px/1 var(--bf-body); color: var(--bf-muted-2); margin-bottom: 18px; }

/* single post */
.bf-post { max-width: 760px; margin: 0 auto; }
.bf-post__cat { display: inline-block; background: var(--bf-tint-blue); color: var(--bf-blue); font: 700 11px/1 var(--bf-body); padding: 7px 13px; border-radius: 999px; text-transform: uppercase; letter-spacing: .04em; margin-bottom: 18px; }
.bf-post h1.entry-title { margin: 0 0 16px; font: 700 40px/1.14 var(--bf-display); }
.bf-post__meta { display: flex; align-items: center; gap: 10px; font: 500 13.5px/1 var(--bf-body); color: var(--bf-muted-2); margin-bottom: 26px; flex-wrap: wrap; }
.bf-post__meta .author { font-weight: 600; color: #3a4255; }
.bf-post__hero { aspect-ratio: 16/9; border-radius: 20px; overflow: hidden; background: var(--bf-stripe-cool); border: 1px solid #e4e8f1; margin-bottom: 32px; }
.bf-post__hero img { width: 100%; height: 100%; object-fit: cover; }
.bf-post .entry-content { font: 400 16.5px/1.75 var(--bf-body); color: #3a4255; }
.bf-post .entry-content h2 { margin: 30px 0 12px; font: 700 23px/1.3 var(--bf-display); }
.bf-post .entry-content p { margin: 0 0 18px; }
.bf-post .entry-content blockquote {
	display: flex; gap: 13px; background: #f4f8ff; border: 1px solid #dde9ff; border-left: 4px solid var(--bf-blue);
	border-radius: 14px; padding: 16px 18px; margin: 6px 0 24px; font: 500 15px/1.65 var(--bf-body); color: #2a3550;
}

/* ===================================================================
   Video CPT
   =================================================================== */
.bf-videos { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.bf-video-card { background: #fff; border: 1px solid var(--bf-line); border-radius: var(--bf-radius-card); overflow: hidden; transition: .2s; }
.bf-video-card:hover { box-shadow: var(--bf-shadow-card); transform: translateY(-3px); border-color: #e1e5ef; }
.bf-video-card__body { padding: 14px 15px 16px; }
.bf-video-card__body h3 { margin: 0 0 7px; font: 600 15.5px/1.32 var(--bf-display); }
.bf-video-card__body h3 a { color: var(--bf-ink); }
.bf-video-card__meta { font: 500 12.5px/1 var(--bf-body); color: var(--bf-muted-2); }
.bf-feature-video { display: grid; grid-template-columns: 1.6fr 1fr; border: 1px solid var(--bf-line); border-radius: var(--bf-radius-lg); overflow: hidden; background: #fff; margin-bottom: 34px; transition: .2s; }
.bf-feature-video:hover { box-shadow: 0 24px 50px -28px rgba(16, 24, 64, .34); border-color: #e1e5ef; }
.bf-feature-video__body { padding: 32px 30px; display: flex; flex-direction: column; justify-content: center; }
.bf-feature-video__body h2 { margin: 0 0 12px; font: 700 27px/1.18 var(--bf-display); }
.bf-feature-video__body h2 a { color: var(--bf-ink); }
.bf-video-single { display: grid; grid-template-columns: 1fr 348px; gap: 32px; align-items: start; }
.bf-video-player { position: relative; aspect-ratio: 16/9; border-radius: 20px; overflow: hidden; background: #000; margin-bottom: 22px; }
.bf-video-player iframe { width: 100%; height: 100%; border: 0; display: block; }
.bf-video-single h1 { margin: 12px 0 10px; font: 700 30px/1.12 var(--bf-display); }
.bf-chapters { border: 1px solid var(--bf-line); border-radius: 16px; overflow: hidden; margin-bottom: 32px; }
.bf-chapter { display: flex; align-items: center; gap: 14px; padding: 13px 16px; border-bottom: 1px solid #f2f3f8; }
.bf-chapter:last-child { border-bottom: none; }
.bf-chapter .time { font: 700 12.5px/1 var(--bf-mono); color: var(--bf-blue); background: var(--bf-tint-blue); padding: 6px 9px; border-radius: 8px; flex-shrink: 0; }
.bf-chapter .label { font: 500 14px/1.3 var(--bf-body); color: #3a4255; }
.bf-video-aside { position: sticky; top: var(--bf-sticky-top); background: #fff; border: 1px solid var(--bf-line); border-radius: var(--bf-radius-card); padding: 18px; }
.bf-video-aside h2 { font: 700 14px/1 var(--bf-display); margin: 0 0 15px; }
.bf-upnext { display: flex; gap: 11px; margin-bottom: 13px; }
.bf-upnext__thumb { position: relative; width: 122px; height: 69px; border-radius: 11px; overflow: hidden; background: var(--bf-stripe-cool); flex-shrink: 0; }
.bf-upnext__thumb img { width: 100%; height: 100%; object-fit: cover; }
.bf-upnext h4 { margin: 0 0 5px; font: 600 13px/1.3 var(--bf-display); }
.bf-upnext h4 a { color: var(--bf-ink); }
.bf-upnext .views { font: 500 11.5px/1 var(--bf-body); color: var(--bf-muted-3); }

/* ===================================================================
   Toast (add-to-cart feedback)
   =================================================================== */
.bf-toast {
	position: fixed; bottom: 28px; left: 50%; transform: translateX(-50%) translateY(20px);
	z-index: 90; background: var(--bf-ink); color: #fff; padding: 14px 22px; border-radius: 14px;
	display: flex; align-items: center; gap: 10px; font: 600 14px/1 var(--bf-body);
	box-shadow: 0 18px 40px -16px rgba(0, 0, 0, .5); opacity: 0; pointer-events: none; transition: .25s ease;
}
.bf-toast.is-visible { opacity: 1; transform: translateX(-50%) translateY(0); }
.bf-toast__check { width: 20px; height: 20px; border-radius: 50%; background: var(--bf-green); display: flex; align-items: center; justify-content: center; font: 700 12px/1 var(--bf-display); }

/* ===================================================================
   WooCommerce notices
   =================================================================== */
.brofpv .woocommerce-message, .brofpv .woocommerce-info, .brofpv .woocommerce-error {
	border: 1px solid var(--bf-line); border-radius: var(--bf-radius-input); padding: 14px 18px;
	font: 500 14px/1.5 var(--bf-body); background: #fff; border-top: 3px solid var(--bf-blue); list-style: none;
}
.brofpv .woocommerce-error { border-top-color: var(--bf-red); color: var(--bf-red); }
.brofpv .woocommerce-message { border-top-color: var(--bf-green); }

/* ===================================================================
   Auth (login / register)
   =================================================================== */
.bf-auth {
	display: grid; grid-template-columns: 46% 1fr; gap: 0; border-radius: var(--bf-radius-lg);
	overflow: hidden; border: 1px solid var(--bf-line); background: #fff; margin: 10px 0 0;
}
.bf-auth__brand {
	position: relative; overflow: hidden; background: var(--bf-ink);
	display: flex; flex-direction: column; justify-content: space-between; gap: 30px; padding: 48px 52px;
}
.bf-auth__brand::before {
	content: ""; position: absolute; inset: 0;
	background: radial-gradient(80% 100% at 85% 8%, rgba(31, 92, 255, .42), transparent 55%),
		radial-gradient(70% 90% at 5% 100%, rgba(255, 45, 70, .34), transparent 55%);
}
.bf-auth__brand > * { position: relative; }
.bf-auth__brand-copy h2 { margin: 0 0 16px; font: 700 34px/1.1 var(--bf-display); color: #fff; }
.bf-auth__brand-copy p { margin: 0; font: 400 15.5px/1.6 var(--bf-body); color: #aab4cc; max-width: 380px; }
.bf-auth__perks { display: flex; gap: 26px; }
.bf-auth__perks .k { font: 700 17px/1 var(--bf-display); color: #fff; margin-bottom: 5px; }
.bf-auth__perks .v { font: 500 12px/1.3 var(--bf-body); color: #7b849a; }
.bf-auth__panel { padding: 48px 40px; display: flex; flex-direction: column; justify-content: center; }
.bf-auth__forms { display: grid; gap: 24px; max-width: 880px; margin: 0 auto; width: 100%; }
.bf-auth__card { background: #fff; }
/* Login / register as toggled tabs (CSS-only via hidden radios). */
.bf-auth__forms.has-register { display: block; max-width: 460px; }
.bf-auth__tabin { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0 0 0 0); border: 0; }
.bf-auth__tabs { display: flex; gap: 4px; background: #f0f2f8; padding: 4px; border-radius: 12px; margin-bottom: 24px; }
.bf-auth__tabs label { flex: 1; text-align: center; padding: 11px 10px; border-radius: 9px; font: 600 14px/1 var(--bf-body); color: var(--bf-muted); cursor: pointer; transition: .15s; }
#bf-tab-login:checked ~ .bf-auth__tabs label[for="bf-tab-login"],
#bf-tab-register:checked ~ .bf-auth__tabs label[for="bf-tab-register"] { background: #fff; color: var(--bf-ink); box-shadow: 0 1px 3px rgba(16, 24, 64, .12); }
.bf-auth__tabin:focus-visible ~ .bf-auth__tabs label { outline: 2px solid var(--bf-blue-soft); outline-offset: 2px; }
.bf-auth__forms.has-register .bf-auth__card { display: none; }
.bf-auth__forms.has-register #bf-tab-login:checked ~ .bf-auth__card--login,
.bf-auth__forms.has-register #bf-tab-register:checked ~ .bf-auth__card--register { display: block; }
.bf-auth__card h1 { margin: 0 0 7px; font: 700 25px/1.1 var(--bf-display); }
.bf-auth__sub { margin: 0 0 22px; font: 400 14.5px/1.5 var(--bf-body); color: var(--bf-muted-2); }
.bf-auth__foot { text-align: center; margin-top: 22px; font: 500 12.5px/1 var(--bf-body); }
.bf-auth__foot a { color: var(--bf-muted-2); }
.bf-auth__foot a:hover { color: var(--bf-blue); }

/* ===================================================================
   WooCommerce button + control normalization
   =================================================================== */
.brofpv.woocommerce .button,
.brofpv.woocommerce a.button,
.brofpv.woocommerce button.button,
.brofpv.woocommerce input.button {
	background: var(--bf-blue); color: #fff; border: none; border-radius: var(--bf-radius-input);
	padding: 12px 22px; font: 700 14px/1 var(--bf-body); cursor: pointer; box-shadow: none;
	transition: .15s; text-shadow: none; text-decoration: none;
}
.brofpv.woocommerce .button:hover,
.brofpv.woocommerce a.button:hover,
.brofpv.woocommerce button.button:hover,
.brofpv.woocommerce input.button:hover { background: var(--bf-blue-dark); color: #fff; }
.brofpv.woocommerce .button.alt { background: var(--bf-blue); }

/* Proceed to checkout button in cart summary */
.brofpv .bf-summary .checkout-button,
.brofpv .wc-proceed-to-checkout .checkout-button {
	display: block; width: 100%; height: 50px; line-height: 26px; background: var(--bf-blue); color: #fff;
	border-radius: var(--bf-radius-btn); font: 700 15px/1 var(--bf-body); text-align: center;
	box-shadow: var(--bf-shadow-btn-blue); padding: 12px;
}
.brofpv .wc-proceed-to-checkout { padding: 0; margin: 0; }

/* qty input default */
.brofpv .quantity input.qty {
	border: 1px solid var(--bf-line-2); border-radius: 10px; height: 42px; width: 64px; text-align: center;
	font: 700 14px/1 var(--bf-display); color: var(--bf-ink);
}
.brofpv.single-product .quantity input.qty { border: none; }

/* "View cart" link after ajax add */
.brofpv .added_to_cart {
	display: inline-block; margin-left: 8px; font: 600 12px/1 var(--bf-body); color: var(--bf-blue);
	background: var(--bf-tint-blue); padding: 8px 12px; border-radius: 9px;
}

/* placeholder block */
.bf-ph-block {
	aspect-ratio: 4/3; background: var(--bf-stripe); display: flex; align-items: center; justify-content: center;
	border-radius: var(--bf-radius-card);
}

/* pagination */
.brofpv.woocommerce nav.woocommerce-pagination { margin-top: 28px; }
.brofpv.woocommerce nav.woocommerce-pagination ul { border: none; display: flex; flex-wrap: wrap; gap: 6px; justify-content: center; margin: 0; padding: 0; list-style: none; }
.brofpv.woocommerce nav.woocommerce-pagination ul li { border: none; margin: 0; }
.brofpv.woocommerce nav.woocommerce-pagination ul li a,
.brofpv.woocommerce nav.woocommerce-pagination ul li span {
	display: flex; align-items: center; justify-content: center; min-width: 40px; height: 40px; padding: 0 12px;
	border: 1px solid var(--bf-line); border-radius: 10px; font: 600 14px/1 var(--bf-body);
	background: #fff; color: var(--bf-ink); transition: border-color .15s ease, color .15s ease, background .15s ease;
}
.brofpv.woocommerce nav.woocommerce-pagination ul li a:hover { border-color: var(--bf-blue); color: var(--bf-blue); background: var(--bf-tint-blue); }
.brofpv.woocommerce nav.woocommerce-pagination ul li span.current { background: var(--bf-blue); color: #fff; border-color: var(--bf-blue); }

/* ===================================================================
   Responsive
   =================================================================== */
@media (max-width: 1024px) {
	.bf-cats, .bf-products { grid-template-columns: repeat(3, 1fr); }
	.bf-stats { grid-template-columns: repeat(2, 1fr); }
	.bf-trust__inner { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 860px) {
	.bf-hero, .bf-diy__inner, .bf-cart, .bf-learn__grid, .bf-grid-2,
	.bf-feature-article, .bf-feature-video, .bf-video-single, .bf-auth,
	.brofpv.single-product div.product,
	.brofpv.woocommerce-checkout .woocommerce { grid-template-columns: 1fr; }
	.brofpv.woocommerce-checkout #customer_details,
	.brofpv.woocommerce-checkout .woocommerce-form-coupon-toggle,
	.brofpv.woocommerce-checkout form.checkout_coupon,
	.brofpv.woocommerce-checkout #order_review_heading,
	.brofpv.woocommerce-checkout #order_review { grid-column: 1; grid-row: auto; }
	.bf-hero h1 { font-size: 42px; }
	.bf-shop__layout { grid-template-columns: 1fr; }
	.bf-shop__sidebar { position: static; }
	.brofpv.woocommerce-checkout #order_review,
	.brofpv.woocommerce-checkout #order_review_heading { grid-column: 1; }
	.bf-products, .bf-cats, .bf-articles, .bf-videos,
	.brofpv.woocommerce ul.products { grid-template-columns: repeat(2, 1fr); }
	.bf-summary, .bf-video-aside, .brofpv.single-product div.product .woocommerce-product-gallery { position: static; }
	.bf-header__inner { gap: 14px; }
	.bf-search { display: none; }
	.bf-nav { display: none; }
	.bf-menu-toggle { display: inline-flex; }
}
@media (max-width: 560px) {
	.bf-wrap, .bf-section, .bf-hero, .bf-audience, .bf-diy,
	.brofpv.woocommerce .site-main { padding-left: 18px; padding-right: 18px; }
	.bf-products, .bf-cats, .bf-articles, .bf-videos, .bf-stats,
	.brofpv.woocommerce ul.products, .bf-footer__top { grid-template-columns: 1fr; }
	.bf-cart-line { flex-wrap: wrap; }
	.bf-cart-line__total { width: auto; }
}
