/*!
 * BuildBarn Native Home — home.css
 *
 * The ONE stylesheet the native homepage depends on.  Covers:
 *   - CSS custom properties (BuildBarn tokens, with fallbacks so it works
 *     independently of `buildbarn-tokens.css` if that ever disappears)
 *   - Native header (single-line, dropdown mega menu, mobile drawer)
 *   - All 7 home sections (hero, services, categories, featured,
 *     testimonials, faq, blog)
 *   - Native footer (newsletter, 5-col grid, payment, copyright)
 *
 * Mobile-first; desktop overrides gated behind `@media (min-width: ...)`.
 * No framework, no resets (we include a small one inline below).
 * Font stack leans on our self-hosted Plus Jakarta Sans + Fraunces with
 * metric-matched Fallback faces declared elsewhere.
 */

/* ------------------------------------------------------------------
 * 1.  Tokens — mapped to BuildBarn SSOT palette from `buildbarn-tokens.css`
 *    (warm brown / cream coffee theme, matches Porto 812 baseline).
 *    Every var() has a hard-coded hex fallback so the homepage still
 *    renders correctly if the site-wide tokens file fails to load.
 * ------------------------------------------------------------------ */
:root {
	--bb-color-primary:     var(--bb-brand-accent-strong, #6c4f36);
	--bb-color-primary-700: var(--bb-text-primary,        #2e2118);
	/* 2026-04-19 Accessibility: darkened from #9a7657 (3.48:1 contrast
	 * on the cream page bg) to #855d3b (5.23:1 on cream, 6.10:1 on
	 * white) so small-uppercase eyebrow labels —
	 *   .bb-native-hero-eyebrow, .bb-native-cat-edit-eyebrow,
	 *   .bb-native-service-eyebrow, .bb-native-product-card-cat,
	 *   .bb-native-section-eyebrow
	 * — pass WCAG AA 4.5:1 for normal text.  Still visibly warmer than
	 * --bb-color-primary (#6c4f36) so eyebrow vs primary keep their
	 * existing hierarchy. */
	--bb-color-accent-warm: #855d3b;
	--bb-color-ink:         var(--bb-text-primary,        #2e2118);
	--bb-color-ink-soft:    var(--bb-text-secondary,      #6c5645);
	--bb-color-muted:       var(--bb-text-muted,          #6f574a);
	--bb-color-line:        var(--bb-border-soft,         #d8cbbf);
	--bb-color-line-strong: var(--bb-border-strong,       #c7b4a3);
	--bb-color-bg:          var(--bb-bg-page,             #f3efe6);
	--bb-color-bg-card:     var(--bb-bg-card,             #fbf8f1);
	--bb-color-bg-soft:     var(--bb-bg-soft,             #ece4d7);
	--bb-color-accent:      #d4a04a;

	--bb-color-footer-bg:        var(--bb-footer-bg,       #5f4632);
	--bb-color-footer-text:      var(--bb-footer-text,     #f7f0e8);
	--bb-color-footer-link:      var(--bb-footer-link,     #f3e6d8);
	--bb-color-footer-link-hover:var(--bb-footer-link-hover,#ffffff);
	--bb-color-footer-muted:     var(--bb-footer-muted,    rgba(245,245,243,.78));
	--bb-color-footer-accent:    var(--bb-footer-accent,   #d2b293);
	--bb-color-footer-divider:   var(--bb-footer-divider,  rgba(255,255,255,.14));

	--bb-font-sans: "Plus Jakarta Sans", "Plus Jakarta Sans Fallback", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
	--bb-font-display: "Fraunces", "Fraunces Fallback", Georgia, "Times New Roman", serif;

	--bb-radius-sm: 6px;
	--bb-radius:    12px;
	--bb-radius-lg: 20px;
	--bb-radius-xl: 28px;

	--bb-shadow-sm: 0 1px 2px rgba(95,70,50,.08);
	--bb-shadow:    0 10px 22px rgba(95,70,50,.10);

	--bb-container: 1200px;
	--bb-gap:       24px;
	--bb-gap-sm:    12px;
	--bb-gap-lg:    40px;
}

/* ------------------------------------------------------------------
 * 2.  Reset & base
 * ------------------------------------------------------------------ */
.bb-native-body {
	margin: 0;
	padding: 0;
	background: var(--bb-color-bg);
	color: var(--bb-color-ink);
	font-family: var(--bb-font-sans);
	font-size: 16px;
	line-height: 1.5;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}
.bb-native-body *,
.bb-native-body *::before,
.bb-native-body *::after { box-sizing: border-box; }
.bb-native-body img { max-width: 100%; height: auto; display: block; }
.bb-native-body a { text-decoration: none; color: currentColor; }
.bb-native-body a:hover { color: var(--bb-color-accent-warm); }
.bb-native-body ul,
.bb-native-body ol { margin: 0; padding: 0; list-style: none; }
.bb-native-body h1, .bb-native-body h2,
.bb-native-body h3, .bb-native-body h4,
.bb-native-body h5, .bb-native-body h6 {
	font-family: var(--bb-font-display);
	font-weight: 700;
	line-height: 1.2;
	margin: 0;
}
.bb-native-body button { font: inherit; cursor: pointer; }
.bb-native-body .screen-reader-text {
	position: absolute; left: -9999px; width: 1px; height: 1px; overflow: hidden;
}
.bb-native-container {
	max-width: var(--bb-container);
	margin: 0 auto;
	padding: 0 16px;
}
@media (min-width: 768px) {
	.bb-native-container { padding: 0 24px; }
}

/* ------------------------------------------------------------------
 * 3.  Header
 * ------------------------------------------------------------------ */
.bb-native-topbar {
	background: #ffffff;
	border-bottom: 1px solid var(--bb-color-line);
	font-size: 13px;
}
.bb-native-topbar-inner {
	display: flex; align-items: center; justify-content: center;
	gap: 24px;
	padding: 10px 16px;
	flex-wrap: wrap;
	color: var(--bb-color-ink-soft);
}
.bb-native-topbar-link {
	display: inline-flex; align-items: center; gap: 6px;
	color: var(--bb-color-ink-soft);
}
.bb-native-topbar-link:hover { color: var(--bb-color-primary); }
.bb-native-topbar-phone { font-weight: 600; color: var(--bb-color-ink); }
.bb-native-header {
	background: #fff;
	border-bottom: 1px solid var(--bb-color-line);
	position: sticky; top: 0; z-index: 100;
	min-height: 70px;    /* CLS reservation */
}
.bb-native-header-row-1 {
	display: flex;
	align-items: center;
	gap: 16px;
	padding: 11px 16px;
	min-height: 70px;    /* matches reservation above */
}
.bb-native-menu-toggle {
	background: transparent; border: 0; color: var(--bb-color-ink);
	width: 40px; height: 40px;
	display: inline-flex; align-items: center; justify-content: center;
	border-radius: var(--bb-radius-sm);
}
.bb-native-menu-toggle:hover { background: var(--bb-color-bg-soft); }
@media (min-width: 992px) {
	.bb-native-menu-toggle { display: none; }
}
.bb-native-brand {
	display: inline-flex; align-items: center;
	flex-shrink: 0;
}
.bb-native-brand img {
	height: 48px; width: auto;
	max-width: 180px;
}

/* Advanced search */
.bb-native-search {
	flex: 1 1 auto;
	display: flex;
	align-items: stretch;
	max-width: 836px;
	margin: 0 20px;
	border: 2px solid var(--bb-color-primary);
	border-radius: 5px;
	overflow: hidden;
	background: #fff;
	height: 45px;
}
@media (max-width: 991px) {
	.bb-native-search { display: none; }  /* header row gets a dedicated mobile search below, kept off for now */
}
.bb-native-search-cat {
	display: inline-flex;
	align-items: center;
	border-right: 1px solid var(--bb-color-line);
	padding: 0 8px 0 20px;
	background: #fff;
	flex: 0 0 168px;
}
.bb-native-search-cat select {
	border: 0; background: transparent;
	font-size: 13px; color: var(--bb-color-ink);
	padding: 0 4px;
	width: 100%;
	appearance: none;
	-webkit-appearance: none;
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' width='14' height='14' fill='%23222'><path d='M7.41 8.59L12 13.17l4.59-4.58L18 10l-6 6-6-6 1.41-1.41z'/></svg>");
	background-repeat: no-repeat;
	background-position: right 0 center;
	padding-right: 16px;
}
.bb-native-search-input {
	flex: 1; border: 0; padding: 0 15px; font-size: 14px; color: var(--bb-color-ink);
	background: #fff;
}
/* Don't draw the UA default outline (it clashes with the search pill),
 * but keep a visible AA-compliant focus indicator via box-shadow so
 * keyboard users still see focus state. */
.bb-native-search-input:focus-visible {
	outline: none;
	box-shadow: inset 0 0 0 2px var(--bb-color-primary);
}
.bb-native-search-submit {
	background: var(--bb-color-primary); color: #fff; border: 0;
	padding: 0 20px;
	display: inline-flex; align-items: center; justify-content: center;
}
.bb-native-search-submit:hover { background: var(--bb-color-primary-700); }

/* Meta (address + phone) */
.bb-native-meta {
	display: none;
	flex-direction: column;
	font-size: 12px;
	line-height: 1.2;
	gap: 4px;
	color: var(--bb-color-ink-soft);
}
@media (min-width: 1280px) {
	.bb-native-meta { display: flex; }
}
.bb-native-meta-link {
	display: inline-flex; align-items: center; gap: 6px;
	color: var(--bb-color-ink-soft);
}
.bb-native-meta-link:hover { color: var(--bb-color-primary); }
.bb-native-meta-phone { font-weight: 600; color: var(--bb-color-ink); font-size: 13px; }

/* Actions: account / wishlist / cart */
.bb-native-actions {
	display: flex; align-items: center; gap: 12px;
	margin-left: auto;
}
.bb-native-action {
	position: relative;
	display: inline-flex; flex-direction: column; align-items: center;
	color: var(--bb-color-ink);
	padding: 4px 6px;
	font-size: 11px; line-height: 1.1;
	min-width: 48px;
}
.bb-native-action svg { display: block; }
.bb-native-action-label { margin-top: 2px; color: var(--bb-color-ink-soft); }
.bb-native-action:hover { color: var(--bb-color-primary); }
.bb-native-action:hover .bb-native-action-label { color: var(--bb-color-primary); }
.bb-native-cart { }
.bb-native-cart-count {
	position: absolute;
	top: -2px; right: 0;
	min-width: 18px; height: 18px;
	background: var(--bb-color-primary); color: #fff;
	font-size: 10px; font-weight: 700; line-height: 18px;
	border-radius: 50%;
	text-align: center; padding: 0 4px;
}
@media (max-width: 575px) {
	/* Visually hide the action label on narrow screens, but keep it in
	 * the accessibility tree so screen readers and Lighthouse can still
	 * read "Account" / "Wishlist" / "Cart" as the link's accessible
	 * name.  `display: none` would strip it from the a11y tree entirely
	 * and leave us with icon-only links that fail `link-name`. */
	.bb-native-action-label {
		position: absolute !important;
		width: 1px;
		height: 1px;
		padding: 0;
		margin: -1px;
		overflow: hidden;
		clip: rect(0, 0, 0, 0);
		white-space: nowrap;
		border: 0;
	}
	.bb-native-actions { gap: 4px; }
	.bb-native-action { min-width: 40px; }
}

/* Nav row — desktop only */
.bb-native-nav {
	display: none;
	border-bottom: 1px solid var(--bb-color-line);
	background: #fff;
}
@media (min-width: 992px) {
	.bb-native-nav { display: block; }
}
.bb-native-nav-inner {
	display: flex;
	align-items: stretch;
	gap: 14px;
	padding-bottom: 13px;
	min-height: 44px;
}
.bb-native-allcats {
	position: relative;
	flex: 0 0 280px;
}
.bb-native-allcats-btn {
	width: 100%;
	background: var(--bb-color-primary);
	color: #fff;
	border: 0;
	height: 44px;
	display: flex; align-items: center; gap: 10px;
	padding: 0 16px;
	font-weight: 700; font-size: 14px;
	letter-spacing: -0.35px;
	border-radius: 3px;
}
.bb-native-allcats-btn span { flex: 1; text-align: left; }
.bb-native-allcats-btn:hover { background: var(--bb-color-primary-700); }
.bb-native-allcats-panel {
	position: absolute;
	top: 100%;
	left: 0;
	width: 280px;
	background: #fff;
	border: 1px solid var(--bb-color-line);
	box-shadow: var(--bb-shadow);
	padding: 8px 0;
	max-height: 0;
	overflow: hidden;
	opacity: 0;
	visibility: hidden;
	transition: opacity .2s, visibility .2s, max-height .2s;
	z-index: 110;
}
.bb-native-allcats:hover .bb-native-allcats-panel,
.bb-native-allcats:focus-within .bb-native-allcats-panel,
.bb-native-allcats.open .bb-native-allcats-panel {
	opacity: 1;
	visibility: visible;
	max-height: 70vh;
	overflow-y: auto;
}

/* Menus */
.bb-native-menu {
	display: flex;
	gap: 6px;
	align-items: stretch;
}
.bb-native-menu-horizontal {
	flex: 1;
}
.bb-native-menu-vertical {
	flex-direction: column;
	gap: 0;
}
.bb-native-menu-item { position: relative; }
.bb-native-menu-item > a {
	display: inline-flex; align-items: center; gap: 4px;
	padding: 0 15px;
	height: 44px;
	font-size: 14px;
	color: var(--bb-color-ink);
	white-space: nowrap;
	text-transform: none;
}
.bb-native-menu-horizontal .bb-native-menu-item > a { font-weight: 500; }
.bb-native-menu-vertical .bb-native-menu-item > a {
	width: 100%; height: auto;
	padding: 10px 16px;
	font-size: 14px;
	border-bottom: 1px solid var(--bb-color-line);
}
.bb-native-menu-vertical .bb-native-menu-item:last-child > a { border-bottom: 0; }
.bb-native-menu-item > a:hover { color: var(--bb-color-primary); background: var(--bb-color-bg-soft); }
.bb-native-menu-item.active > a { color: var(--bb-color-primary); }

.bb-native-submenu {
	position: absolute;
	top: 100%; left: 0;
	min-width: 240px;
	background: #fff;
	border: 1px solid var(--bb-color-line);
	box-shadow: var(--bb-shadow);
	padding: 8px 0;
	opacity: 0; visibility: hidden;
	transform: translateY(4px);
	transition: opacity .2s, visibility .2s, transform .2s;
	z-index: 120;
	flex-direction: column;
	display: flex;
	gap: 0;
}
.bb-native-menu-horizontal .bb-native-menu-item:hover > .bb-native-submenu,
.bb-native-menu-horizontal .bb-native-menu-item:focus-within > .bb-native-submenu,
.bb-native-menu-horizontal .bb-native-menu-item.open > .bb-native-submenu {
	opacity: 1; visibility: visible; transform: translateY(0);
}
.bb-native-menu-vertical .bb-native-menu-item.has-children > .bb-native-submenu {
	position: static;
	box-shadow: none;
	border: 0;
	background: var(--bb-color-bg-soft);
	opacity: 1; visibility: visible; transform: none;
	display: none;
	padding: 0;
}
.bb-native-menu-vertical .bb-native-menu-item.has-children:hover > .bb-native-submenu,
.bb-native-menu-vertical .bb-native-menu-item.has-children.open > .bb-native-submenu {
	display: flex;
}
.bb-native-submenu .bb-native-menu-item > a {
	padding: 8px 16px;
	height: auto; width: 100%;
	font-size: 13.5px; font-weight: 400;
	white-space: normal;
}
.bb-native-submenu .bb-native-submenu {
	position: static; box-shadow: none; border: 0;
	background: var(--bb-color-bg-soft);
	opacity: 1; visibility: visible; transform: none;
	padding: 0;
}
.bb-native-chev { flex-shrink: 0; opacity: .7; }

/* All-categories panel reuses the walker's vertical menu */
.bb-native-allcats-panel .bb-native-menu-vertical { display: flex; }

/* Fallback <ul class="bb-native-cat-list"> */
.bb-native-cat-list li { border-bottom: 1px solid var(--bb-color-line); }
.bb-native-cat-list li:last-child { border: 0; }
.bb-native-cat-list a { display: block; padding: 10px 16px; font-size: 14px; }
.bb-native-cat-list a:hover { background: var(--bb-color-bg-soft); color: var(--bb-color-primary); }

/* Mobile drawer */
.bb-native-drawer {
	position: fixed; top: 0; left: 0;
	width: min(85vw, 360px); height: 100vh;
	background: #fff;
	box-shadow: var(--bb-shadow);
	transform: translateX(-100%);
	transition: transform .25s ease;
	z-index: 1001;
	display: flex; flex-direction: column;
	overflow: hidden;
}
.bb-native-drawer.open { transform: translateX(0); }
.bb-native-drawer-header {
	display: flex; align-items: center; justify-content: space-between;
	padding: 12px 16px;
	border-bottom: 1px solid var(--bb-color-line);
	min-height: 64px;
}
.bb-native-drawer-close {
	background: transparent; border: 0;
	width: 40px; height: 40px;
	display: inline-flex; align-items: center; justify-content: center;
	border-radius: var(--bb-radius-sm);
}
.bb-native-drawer-close:hover { background: var(--bb-color-bg-soft); }
.bb-native-drawer-body {
	flex: 1;
	overflow-y: auto;
	padding-bottom: 24px;
}
.bb-native-drawer-body .bb-native-menu-drawer {
	flex-direction: column;
	gap: 0;
}
.bb-native-drawer-body .bb-native-menu-drawer > li > a {
	height: auto;
	padding: 14px 16px;
	width: 100%;
	justify-content: space-between;
	border-bottom: 1px solid var(--bb-color-line);
}
.bb-native-drawer-body .bb-native-menu-drawer .bb-native-submenu {
	position: static;
	box-shadow: none;
	border: 0;
	padding: 0 0 0 16px;
	opacity: 1; visibility: visible; transform: none;
	display: none;
	background: var(--bb-color-bg-soft);
}
.bb-native-drawer-body .bb-native-menu-drawer .bb-native-menu-item.open > .bb-native-submenu {
	display: flex;
	flex-direction: column;
}
.bb-native-drawer-meta {
	padding: 16px;
	display: flex; flex-direction: column; gap: 8px;
	font-size: 14px;
	border-top: 1px solid var(--bb-color-line);
}
.bb-native-drawer-meta a {
	display: inline-flex; align-items: center; gap: 8px;
}
.bb-native-drawer-backdrop {
	position: fixed; inset: 0;
	background: rgba(0,0,0,.4);
	opacity: 0; visibility: hidden;
	transition: opacity .25s, visibility .25s;
	z-index: 1000;
}
.bb-native-drawer-backdrop.open { opacity: 1; visibility: visible; }

/* ------------------------------------------------------------------
 * 4.  Main section shell
 * ------------------------------------------------------------------ */
.bb-native-main { display: block; }
.bb-native-section {
	padding: 48px 0;
}
@media (max-width: 767px) {
	.bb-native-section { padding: 32px 0; }
}
.bb-native-section-head {
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	margin: 0 0 32px;
	gap: 24px;
	flex-wrap: wrap;
}
.bb-native-section-head--center {
	justify-content: center;
	text-align: center;
}
.bb-native-section-head--center > div { max-width: 640px; margin: 0 auto; }
.bb-native-section-head > div { display: flex; flex-direction: column; gap: 6px; min-width: 0; }
.bb-native-section-eyebrow {
	margin: 0;
	text-transform: uppercase;
	letter-spacing: .14em;
	font-size: 12px;
	font-weight: 600;
	color: var(--bb-color-accent-warm);
	display: inline-flex; align-items: center; gap: 8px;
}
.bb-native-section-eyebrow::before {
	content: '';
	width: 22px; height: 1px;
	background: var(--bb-color-accent-warm);
	display: inline-block;
}
.bb-native-section-head--center .bb-native-section-eyebrow {
	justify-content: center;
}
.bb-native-section-head--center .bb-native-section-eyebrow::before { display: none; }
.bb-native-section-title {
	font-size: clamp(1.75rem, 3vw, 2.5rem);
	font-family: var(--bb-font-display);
	font-weight: 700;
	color: var(--bb-color-ink);
	margin: 0;
	line-height: 1.15;
	letter-spacing: -.01em;
}
.bb-native-section-sub {
	margin: 4px 0 0;
	font-size: 15px;
	color: var(--bb-color-ink-soft);
	max-width: 56ch;
	line-height: 1.55;
}
a.bb-native-section-link,
.bb-native-section-link {
	display: inline-flex; align-items: center; gap: 6px;
	font-size: 14px;
	font-weight: 600;
	color: var(--bb-color-primary);
	padding: 10px 18px;
	border: 1px solid var(--bb-color-line-strong);
	border-radius: 999px;
	background: var(--bb-color-bg-card);
	transition: background .2s, border-color .2s, color .2s, transform .2s;
	flex-shrink: 0;
}
a.bb-native-section-link:hover,
.bb-native-section-link:hover {
	background: var(--bb-color-primary-700);
	color: #ffffff;
	border-color: var(--bb-color-primary-700);
	transform: translateY(-1px);
}
a.bb-native-section-link svg,
.bb-native-section-link svg { transition: transform .2s; }
a.bb-native-section-link:hover svg,
.bb-native-section-link:hover svg { transform: translateX(3px); }

/* ------------------------------------------------------------------
 * 5.  Hero
 * ------------------------------------------------------------------ */
.bb-native-hero {
	padding: 20px 0 20px;
	background: var(--bb-color-bg);
}
.bb-native-hero-inner {
	display: grid;
	grid-template-columns: 1fr;
	gap: 24px;
	align-items: center;
	background: var(--bb-color-bg-card);
	border: 1px solid var(--bb-color-line);
	border-radius: var(--bb-radius-xl);
	padding: 32px 28px;
}
@media (min-width: 768px) {
	.bb-native-hero-inner { padding: 48px 48px; }
}
@media (min-width: 992px) {
	.bb-native-hero-inner {
		grid-template-columns: 1.15fr 1fr;
		gap: 56px;
		padding: 64px 64px;
	}
}
.bb-native-hero-eyebrow {
	margin: 0 0 18px;
	text-transform: uppercase;
	letter-spacing: .14em;
	font-size: 12.5px;
	font-weight: 600;
	color: var(--bb-color-accent-warm);
	display: inline-flex; align-items: center; gap: 12px;
}
.bb-native-hero-eyebrow-line {
	width: 28px; height: 1px;
	background: var(--bb-color-accent-warm);
	display: inline-block;
}
.bb-native-hero-title {
	font-size: clamp(1.75rem, 3.5vw, 2.75rem);
	font-family: var(--bb-font-display);
	font-weight: 700;
	line-height: 1.15;
	color: var(--bb-color-ink);
	margin: 0 0 16px;
	min-height: 1.15em;  /* reserve height so font-face swap doesn't cause CLS */
}
.bb-native-hero-sub {
	font-size: clamp(1rem, 1.4vw, 1.125rem);
	color: var(--bb-color-ink-soft);
	max-width: 56ch;
	margin: 0 0 24px;
}
.bb-native-hero-ctas {
	display: flex; flex-wrap: wrap; gap: 12px;
	margin: 0 0 24px;
}
.bb-native-btn {
	display: inline-flex; align-items: center; justify-content: center;
	gap: 10px;
	padding: 14px 28px;
	font-size: 14.5px;
	font-weight: 600;
	letter-spacing: .01em;
	border-radius: 10px;
	border: 1.5px solid transparent;
	text-transform: none;
	transition: background .2s, color .2s, border-color .2s, transform .2s;
	min-height: 50px;
	font-family: var(--bb-font-sans);
}
.bb-native-btn svg { transition: transform .2s; flex-shrink: 0; }
.bb-native-btn:hover svg { transform: translateX(3px); }
.bb-native-btn.bb-native-btn-primary {
	background: var(--bb-color-primary-700);
	color: #ffffff;
	border-color: var(--bb-color-primary-700);
}
.bb-native-btn.bb-native-btn-primary:hover {
	background: var(--bb-color-primary);
	border-color: var(--bb-color-primary);
	color: #ffffff;
}
.bb-native-btn.bb-native-btn-ghost {
	background: transparent;
	color: var(--bb-color-ink);
	border-color: var(--bb-color-line-strong);
}
.bb-native-btn.bb-native-btn-ghost:hover {
	background: var(--bb-color-ink);
	color: #ffffff;
	border-color: var(--bb-color-ink);
}
.bb-native-hero-badges {
	display: flex; flex-direction: column; gap: 12px;
	font-size: 14.5px;
	color: var(--bb-color-ink-soft);
	margin: 0;
}
.bb-native-hero-badges li {
	display: inline-flex; align-items: center; gap: 10px;
}
.bb-native-hero-badges li svg {
	color: var(--bb-color-primary);
	flex-shrink: 0;
	background: rgba(108, 79, 54, .12);
	border-radius: 50%;
	padding: 5px;
	box-sizing: content-box;
}
.bb-native-hero-art img {
	width: 100%; height: auto;
	border-radius: var(--bb-radius-lg);
	aspect-ratio: 4 / 3;
	object-fit: cover;
}

/* ------------------------------------------------------------------
 * 6.  Services — premium 4-up card strip with eyebrow + monoline icons
 * ------------------------------------------------------------------ */
.bb-native-services {
	padding: 20px 0 20px;
}
.bb-native-services-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 18px;
}
@media (min-width: 576px) {
	.bb-native-services-grid { grid-template-columns: repeat(2, 1fr); gap: 18px; }
}
@media (min-width: 992px) {
	.bb-native-services-grid { grid-template-columns: repeat(4, 1fr); gap: 22px; }
}
.bb-native-service {
	display: flex; align-items: flex-start; gap: 16px;
	padding: 24px;
	background: var(--bb-color-bg-card);
	border: 1px solid var(--bb-color-line);
	border-radius: var(--bb-radius);
	transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.bb-native-service:hover {
	transform: translateY(-2px);
	box-shadow: var(--bb-shadow);
	border-color: var(--bb-color-primary);
}
.bb-native-service-icon {
	width: 52px; height: 52px;
	display: inline-flex; align-items: center; justify-content: center;
	color: var(--bb-color-primary-700);
	background: linear-gradient(135deg, var(--bb-color-bg-soft) 0%, rgba(208,178,147,.35) 100%);
	border-radius: 14px;
	flex-shrink: 0;
	transition: background .25s ease, color .25s ease;
}
.bb-native-service:hover .bb-native-service-icon {
	background: linear-gradient(135deg, var(--bb-color-primary-700) 0%, var(--bb-color-primary) 100%);
	color: #ffffff;
}
.bb-native-service-copy { display: flex; flex-direction: column; gap: 4px; min-width: 0; }
.bb-native-service-eyebrow {
	font-size: 11.5px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: .12em;
	color: var(--bb-color-accent-warm);
}
.bb-native-service-title { font-size: 15px; font-weight: 700; color: var(--bb-color-ink); font-family: var(--bb-font-sans); line-height: 1.3; }
.bb-native-service-desc { font-size: 13.5px; color: var(--bb-color-ink-soft); line-height: 1.5; }

/* ------------------------------------------------------------------
 * 6b. Promo banner — featured-collection split card
 * ------------------------------------------------------------------ */
.bb-native-promo {
	padding: 16px 0 24px;
}
.bb-native-promo-card {
	display: grid;
	grid-template-columns: 1fr;
	background: linear-gradient(135deg, var(--bb-color-primary-700) 0%, #3d2a1c 60%, #4a3322 100%);
	color: #f7f0e8;
	border-radius: var(--bb-radius-xl);
	overflow: hidden;
	box-shadow: var(--bb-shadow);
	position: relative;
}
@media (min-width: 768px) {
	.bb-native-promo-card { grid-template-columns: 1fr 1fr; min-height: 360px; }
}
@media (min-width: 1080px) {
	.bb-native-promo-card { grid-template-columns: 1.1fr 1fr; min-height: 420px; }
}
.bb-native-promo-copy {
	padding: 32px 28px;
	display: flex; flex-direction: column;
	gap: 14px;
	position: relative;
	z-index: 1;
}
@media (min-width: 768px) {
	.bb-native-promo-copy { padding: 48px 44px; gap: 16px; justify-content: center; }
}
@media (min-width: 1080px) {
	.bb-native-promo-copy { padding: 56px 56px; }
}
.bb-native-promo-eyebrow {
	margin: 0;
	text-transform: uppercase;
	letter-spacing: .14em;
	font-size: 12px;
	font-weight: 600;
	color: var(--bb-color-footer-accent);
}
.bb-native-promo-tag {
	display: inline-flex; align-items: center; gap: 6px;
	background: var(--bb-color-footer-accent);
	color: var(--bb-color-primary-700);
	padding: 7px 14px;
	border-radius: 999px;
	font-size: 13px; font-weight: 700;
	letter-spacing: .02em;
	width: fit-content;
}
.bb-native-promo-title {
	font-family: var(--bb-font-display);
	font-size: clamp(2rem, 4vw, 3.25rem);
	font-weight: 700;
	line-height: 1.05;
	letter-spacing: -.02em;
	color: #ffffff;
	margin: 4px 0 4px;
}
.bb-native-promo-sub {
	font-size: 15.5px;
	line-height: 1.55;
	color: rgba(247, 240, 232, .82);
	margin: 0;
	max-width: 46ch;
}
a.bb-native-promo-cta,
.bb-native-promo-cta {
	display: inline-flex; align-items: center; gap: 10px;
	padding: 14px 26px;
	background: var(--bb-color-footer-accent);
	color: var(--bb-color-primary-700);
	border-radius: 10px;
	font-weight: 600; font-size: 14.5px;
	border: 1.5px solid var(--bb-color-footer-accent);
	transition: background .2s, color .2s, transform .2s;
	width: fit-content;
	margin-top: 4px;
}
a.bb-native-promo-cta:hover,
.bb-native-promo-cta:hover {
	background: #ffffff;
	border-color: #ffffff;
	color: var(--bb-color-primary-700);
	transform: translateY(-1px);
}
a.bb-native-promo-cta svg,
.bb-native-promo-cta svg { transition: transform .2s; }
a.bb-native-promo-cta:hover svg,
.bb-native-promo-cta:hover svg { transform: translateX(4px); }
.bb-native-promo-badge {
	margin: 6px 0 0;
	display: inline-flex; align-items: center; gap: 8px;
	font-size: 13px;
	color: rgba(247, 240, 232, .72);
}
.bb-native-promo-badge svg {
	color: var(--bb-color-footer-accent);
	flex-shrink: 0;
}
.bb-native-promo-art {
	position: relative;
	min-height: 240px;
	overflow: hidden;
	background: rgba(0,0,0,.18);
}
.bb-native-promo-art img {
	width: 100%; height: 100%;
	object-fit: cover;
	display: block;
}
.bb-native-promo-caption {
	position: absolute;
	right: 16px; bottom: 16px;
	background: rgba(46, 33, 24, .82);
	color: #f7f0e8;
	padding: 10px 16px;
	border-radius: 10px;
	font-size: 13px;
	font-weight: 600;
	display: flex; flex-direction: column; gap: 2px;
	backdrop-filter: blur(6px);
}
.bb-native-promo-caption em {
	font-style: normal;
	font-weight: 400;
	font-size: 12px;
	color: var(--bb-color-footer-accent);
}

/* ------------------------------------------------------------------
 * 7.  Categories — editorial 6-card layout
 * ------------------------------------------------------------------ */
.bb-native-cat-edit-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 22px;
	margin: 0;
	padding: 0;
	list-style: none;
}
@media (min-width: 576px) { .bb-native-cat-edit-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 992px) { .bb-native-cat-edit-grid { grid-template-columns: repeat(3, 1fr); gap: 28px; } }
.bb-native-cat-edit-card {
	background: var(--bb-color-bg-card);
	border: 1px solid var(--bb-color-line);
	border-radius: var(--bb-radius-lg);
	overflow: hidden;
	transition: border-color .25s ease, box-shadow .25s ease, transform .25s ease;
	list-style: none;
}
.bb-native-cat-edit-card:hover {
	border-color: var(--bb-color-primary);
	box-shadow: var(--bb-shadow);
	transform: translateY(-3px);
}
.bb-native-cat-edit-link {
	display: flex; flex-direction: column;
	color: var(--bb-color-ink);
	height: 100%;
}
.bb-native-cat-edit-thumb {
	display: block;
	aspect-ratio: 4 / 3;
	overflow: hidden;
	background: var(--bb-color-bg-soft);
	position: relative;
}
.bb-native-cat-edit-thumb img {
	width: 100%; height: 100%; object-fit: cover;
	transition: transform .5s ease;
}
.bb-native-cat-edit-card:hover .bb-native-cat-edit-thumb img {
	transform: scale(1.06);
}
.bb-native-cat-edit-thumb::after {
	content: '';
	position: absolute; inset: 0;
	background: linear-gradient(180deg, rgba(46,33,24,0) 55%, rgba(46,33,24,.25) 100%);
	pointer-events: none;
}
.bb-native-cat-edit-body {
	display: flex; flex-direction: column; gap: 8px;
	padding: 22px 24px 26px;
	flex: 1;
}
.bb-native-cat-edit-eyebrow {
	font-size: 11.5px;
	text-transform: uppercase;
	letter-spacing: .14em;
	font-weight: 600;
	color: var(--bb-color-accent-warm);
}
.bb-native-cat-edit-title {
	font-family: var(--bb-font-display);
	font-size: 1.5rem;
	font-weight: 700;
	line-height: 1.2;
	color: var(--bb-color-ink);
	letter-spacing: -.01em;
}
.bb-native-cat-edit-desc {
	font-size: 14.5px;
	color: var(--bb-color-ink-soft);
	line-height: 1.55;
	margin: 2px 0 8px;
}
.bb-native-cat-edit-cta {
	margin-top: auto;
	display: inline-flex; align-items: center; gap: 6px;
	font-size: 13.5px; font-weight: 600;
	color: var(--bb-color-primary-700);
	padding-top: 6px;
	border-top: 1px solid var(--bb-color-line);
}
.bb-native-cat-edit-cta svg { transition: transform .2s ease; }
.bb-native-cat-edit-card:hover .bb-native-cat-edit-cta svg { transform: translateX(4px); }

/* Legacy small-icon grid — kept for fallback use only */
.bb-native-category-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 16px;
}
@media (min-width: 576px) { .bb-native-category-grid { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 768px) { .bb-native-category-grid { grid-template-columns: repeat(4, 1fr); } }
@media (min-width: 992px) { .bb-native-category-grid { grid-template-columns: repeat(7, 1fr); } }
.bb-native-category-card { text-align: center; }
.bb-native-category-card a {
	display: flex; flex-direction: column; align-items: center; gap: 8px;
	color: var(--bb-color-ink);
}
.bb-native-category-thumb {
	width: 100%; aspect-ratio: 1 / 1;
	display: flex; align-items: center; justify-content: center;
	background: var(--bb-color-bg-card);
	border: 1px solid var(--bb-color-line);
	border-radius: var(--bb-radius);
	overflow: hidden;
	transition: transform .2s, border-color .2s, box-shadow .2s;
}
.bb-native-category-thumb img { width: 100%; height: 100%; object-fit: cover; }
.bb-native-category-card a:hover .bb-native-category-thumb {
	transform: translateY(-2px);
	border-color: var(--bb-color-primary);
	box-shadow: var(--bb-shadow-sm);
}
.bb-native-category-name {
	font-size: 13.5px; font-weight: 600; line-height: 1.3;
	color: var(--bb-color-ink);
}

/* ------------------------------------------------------------------
 * 8.  Featured products
 * ------------------------------------------------------------------ */
.bb-native-product-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 20px;
}
@media (min-width: 576px) { .bb-native-product-grid { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 992px) { .bb-native-product-grid { grid-template-columns: repeat(4, 1fr); } }
.bb-native-product-card {
	background: var(--bb-color-bg-card);
	border: 1px solid var(--bb-color-line);
	border-radius: var(--bb-radius);
	overflow: hidden;
	display: flex; flex-direction: column;
	transition: box-shadow .2s, transform .2s, border-color .2s;
}
.bb-native-product-card:hover { border-color: var(--bb-color-primary); }
.bb-native-product-card:hover { box-shadow: var(--bb-shadow); transform: translateY(-2px); }
.bb-native-product-card-link {
	display: flex; flex-direction: column;
	color: var(--bb-color-ink);
}
.bb-native-product-card-thumb {
	position: relative;
	display: block;
	background: var(--bb-color-bg-soft);
	aspect-ratio: 1 / 1;
	overflow: hidden;
}
.bb-native-product-card-thumb img {
	width: 100%; height: 100%; object-fit: cover;
	transition: transform .5s ease;
}
.bb-native-product-card:hover .bb-native-product-card-thumb img {
	transform: scale(1.06);
}
.bb-native-product-card-badge {
	position: absolute; top: 12px; left: 12px;
	display: inline-flex; align-items: center; gap: 4px;
	background: var(--bb-color-accent-warm); color: #fff;
	font-size: 11px; font-weight: 700;
	padding: 5px 10px;
	border-radius: 999px;
	letter-spacing: .04em;
	text-transform: uppercase;
	box-shadow: 0 2px 8px rgba(0,0,0,.12);
	z-index: 2;
}
.bb-native-product-card-badge svg { flex-shrink: 0; }
.bb-native-product-card-overlay {
	position: absolute; inset: 0;
	display: flex; align-items: flex-end; justify-content: center;
	padding: 16px;
	background: linear-gradient(180deg, rgba(46,33,24,0) 40%, rgba(46,33,24,.55) 100%);
	opacity: 0;
	transition: opacity .25s ease;
	pointer-events: none;
}
.bb-native-product-card:hover .bb-native-product-card-overlay {
	opacity: 1;
}
.bb-native-product-card-overlay-cta {
	display: inline-flex; align-items: center; gap: 6px;
	background: #ffffff;
	color: var(--bb-color-primary-700);
	padding: 9px 16px;
	border-radius: 999px;
	font-size: 12.5px;
	font-weight: 600;
	box-shadow: 0 2px 12px rgba(0,0,0,.14);
	transform: translateY(8px);
	transition: transform .25s ease;
}
.bb-native-product-card:hover .bb-native-product-card-overlay-cta {
	transform: translateY(0);
}
.bb-native-product-card-body {
	display: flex; flex-direction: column; gap: 4px;
	padding: 16px 14px 8px;
}
.bb-native-product-card-cat {
	font-size: 11px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: .12em;
	color: var(--bb-color-accent-warm);
	margin-bottom: 2px;
}
.bb-native-product-card-title {
	font-size: 14.5px; font-weight: 600;
	line-height: 1.35;
	color: var(--bb-color-ink);
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
	min-height: 2.7em;
	font-family: var(--bb-font-sans);
}
.bb-native-product-card-price {
	display: block;
	font-size: 16px;
	font-weight: 700;
	color: var(--bb-color-primary-700);
	font-family: var(--bb-font-display);
}
.bb-native-product-card-price .woocommerce-Price-amount { color: var(--bb-color-primary-700); }
.bb-native-product-card-price del { color: var(--bb-color-muted); font-weight: 400; margin-right: 6px; font-size: 13px; }
.bb-native-product-card-price ins { text-decoration: none; color: var(--bb-color-accent-warm); }
a.bb-native-product-card-atc,
.bb-native-product-card-atc {
	margin: 4px 14px 14px;
	padding: 11px 12px;
	background: transparent;
	color: var(--bb-color-primary-700);
	border: 1.5px solid var(--bb-color-line-strong);
	border-radius: 8px;
	font-size: 13px; font-weight: 600;
	text-align: center;
	text-transform: none;
	letter-spacing: .01em;
	display: inline-flex; align-items: center; justify-content: center; gap: 6px;
	transition: background .2s, color .2s, border-color .2s;
}
a.bb-native-product-card-atc:hover,
.bb-native-product-card-atc:hover {
	background: var(--bb-color-primary-700);
	color: #ffffff;
	border-color: var(--bb-color-primary-700);
}
.bb-native-product-card-atc.loading { opacity: .7; pointer-events: none; }
.bb-native-product-card-atc.added { background: #28a745; }

/* ------------------------------------------------------------------
 * 9.  Testimonials
 * ------------------------------------------------------------------ */
.bb-native-testimonials { background: var(--bb-color-bg-soft); }
.bb-native-testimonial-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 22px;
	list-style: none;
	margin: 0;
	padding: 0;
}
@media (min-width: 768px) { .bb-native-testimonial-grid { grid-template-columns: repeat(3, 1fr); } }
.bb-native-testimonial {
	background: var(--bb-color-bg-card);
	border: 1px solid var(--bb-color-line);
	border-radius: var(--bb-radius-lg);
	padding: 32px 28px 28px;
	box-shadow: var(--bb-shadow-sm);
	display: flex; flex-direction: column; gap: 16px;
	position: relative;
	transition: border-color .25s, transform .25s, box-shadow .25s;
}
.bb-native-testimonial:hover {
	border-color: var(--bb-color-primary);
	transform: translateY(-2px);
	box-shadow: var(--bb-shadow);
}
.bb-native-testimonial-quotemark {
	position: absolute;
	top: 8px; right: 22px;
	font-family: var(--bb-font-display);
	font-size: 72px;
	line-height: 1;
	color: var(--bb-color-accent-warm);
	opacity: .18;
	pointer-events: none;
	user-select: none;
}
.bb-native-testimonial-stars {
	display: inline-flex; gap: 3px;
	color: var(--bb-color-accent-warm);
}
.bb-native-testimonial-stars svg { fill: var(--bb-color-accent-warm); stroke: var(--bb-color-accent-warm); }
.bb-native-testimonial-quote {
	margin: 0;
	font-size: 15px;
	color: var(--bb-color-ink);
	line-height: 1.6;
	font-family: var(--bb-font-display);
	font-weight: 400;
	font-style: italic;
}
.bb-native-testimonial-cite {
	display: flex; align-items: center; gap: 12px;
	font-size: 13px;
	color: var(--bb-color-muted);
	margin-top: auto;
	padding-top: 12px;
	border-top: 1px solid var(--bb-color-line);
}
.bb-native-testimonial-avatar {
	width: 40px; height: 40px;
	border-radius: 50%;
	background: linear-gradient(135deg, var(--bb-color-primary-700), var(--bb-color-primary));
	color: #ffffff;
	font-weight: 700;
	font-family: var(--bb-font-display);
	display: inline-flex; align-items: center; justify-content: center;
	font-size: 16px;
	flex-shrink: 0;
}
.bb-native-testimonial-cite-text { display: flex; flex-direction: column; gap: 1px; }
.bb-native-testimonial-cite-text strong { color: var(--bb-color-ink); font-size: 14px; font-weight: 700; }

/* ------------------------------------------------------------------
 * 10.  FAQ
 * ------------------------------------------------------------------ */
.bb-native-faq-list {
	max-width: 860px;
	margin: 0 auto;
	display: flex; flex-direction: column; gap: 12px;
}
.bb-native-faq-item {
	background: var(--bb-color-bg-card);
	border: 1px solid var(--bb-color-line);
	border-radius: var(--bb-radius);
	transition: border-color .2s, box-shadow .2s;
}
.bb-native-faq-item[open] {
	border-color: var(--bb-color-primary);
	box-shadow: var(--bb-shadow-sm);
}
.bb-native-faq-q {
	display: flex; align-items: center; justify-content: space-between;
	gap: 16px;
	padding: 20px 24px;
	font-size: 15.5px; font-weight: 600;
	color: var(--bb-color-ink);
	cursor: pointer;
	list-style: none;
	font-family: var(--bb-font-sans);
}
.bb-native-faq-q::-webkit-details-marker { display: none; }
.bb-native-faq-chev {
	display: inline-flex; align-items: center; justify-content: center;
	width: 32px; height: 32px;
	border-radius: 50%;
	background: var(--bb-color-bg-soft);
	color: var(--bb-color-primary-700);
	transition: transform .25s ease, background .2s ease;
	flex-shrink: 0;
}
.bb-native-faq-item[open] .bb-native-faq-chev {
	transform: rotate(180deg);
	background: var(--bb-color-primary-700);
	color: #ffffff;
}
.bb-native-faq-a {
	padding: 0 24px 22px;
	font-size: 14.5px;
	line-height: 1.65;
	color: var(--bb-color-ink-soft);
}

/* ------------------------------------------------------------------
 * 11.  Blog teaser
 * ------------------------------------------------------------------ */
.bb-native-blog-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 20px;
}
@media (min-width: 768px) { .bb-native-blog-grid { grid-template-columns: repeat(3, 1fr); } }
.bb-native-blog-card {
	background: var(--bb-color-bg-card);
	border: 1px solid var(--bb-color-line);
	border-radius: var(--bb-radius);
	overflow: hidden;
	transition: box-shadow .2s, transform .2s, border-color .2s;
}
.bb-native-blog-card:hover { box-shadow: var(--bb-shadow); transform: translateY(-2px); border-color: var(--bb-color-primary); }
.bb-native-blog-card-link { display: flex; flex-direction: column; }
.bb-native-blog-card-thumb { display: block; aspect-ratio: 3 / 2; background: var(--bb-color-bg-soft); }
.bb-native-blog-card-thumb img { width: 100%; height: 100%; object-fit: cover; }
.bb-native-blog-card-body { padding: 18px; display: flex; flex-direction: column; gap: 6px; }
.bb-native-blog-card-date { margin: 0; font-size: 12px; color: var(--bb-color-muted); text-transform: uppercase; letter-spacing: .05em; }
.bb-native-blog-card-title { font-size: 1.1rem; line-height: 1.3; margin: 0; }
.bb-native-blog-card-excerpt { margin: 6px 0 0; font-size: 13.5px; color: var(--bb-color-ink-soft); line-height: 1.5; }

/* ------------------------------------------------------------------
 * 12.  Footer
 * ------------------------------------------------------------------ */
.bb-native-footer {
	background: var(--bb-color-footer-bg);
	color: var(--bb-color-footer-text);
	margin-top: 40px;
}
.bb-native-footer a { color: var(--bb-color-footer-link); }
.bb-native-footer a:hover { color: var(--bb-color-footer-link-hover); }
.bb-native-footer-newsletter {
	padding: 48px 0 36px;
	border-bottom: 1px solid var(--bb-color-footer-divider);
}
.bb-native-footer-newsletter-inner {
	display: grid;
	grid-template-columns: 1fr;
	gap: 24px;
	align-items: center;
}
@media (min-width: 992px) {
	.bb-native-footer-newsletter-inner {
		grid-template-columns: 1fr 2fr;
		gap: 40px;
	}
}
.bb-native-footer-newsletter-copy {
	display: flex; align-items: center; gap: 16px;
	color: var(--bb-color-footer-text);
}
.bb-native-footer-newsletter-icon {
	color: var(--bb-color-footer-accent);
	flex-shrink: 0;
}
.bb-native-footer-newsletter-title {
	font-family: var(--bb-font-display);
	font-size: 20px; font-weight: 700; margin: 0 0 4px;
	color: var(--bb-color-footer-text);
}
.bb-native-footer-newsletter-sub {
	font-size: 13.5px;
	color: var(--bb-color-footer-muted);
	margin: 0;
}
.bb-native-footer-newsletter-form .wpcf7-form,
.bb-native-footer-newsletter-fallback {
	display: flex;
	gap: 0;
	height: 48px;
}
.bb-native-footer-newsletter-form .wysija-paragraph {
	flex: 1;
}
.bb-native-footer-newsletter-form input[type=email],
.bb-native-footer-newsletter-fallback input[type=email] {
	width: 100%;
	height: 48px;
	border: 1px solid rgba(255,255,255,.22);
	border-right: 0;
	border-radius: 8px 0 0 8px;
	padding: 0 16px;
	font-size: 14px;
	background: rgba(255,255,255,.08);
	color: var(--bb-color-footer-text);
}
.bb-native-footer-newsletter-form input[type=email]::placeholder,
.bb-native-footer-newsletter-fallback input[type=email]::placeholder {
	color: var(--bb-color-footer-muted);
}
.bb-native-footer-newsletter-form input[type=email]:focus,
.bb-native-footer-newsletter-fallback input[type=email]:focus {
	outline: none;
	border-color: var(--bb-color-footer-accent);
	background: rgba(255,255,255,.14);
}
.bb-native-footer-newsletter-form input[type=submit],
.bb-native-footer-newsletter-form button[type=submit],
.bb-native-footer-newsletter-fallback button[type=submit] {
	height: 48px;
	background: var(--bb-color-footer-accent);
	color: var(--bb-color-primary-700);
	border: 0;
	padding: 0 28px;
	font-weight: 600;
	font-size: 14px;
	border-radius: 0 8px 8px 0;
	text-transform: none;
	letter-spacing: 0;
	cursor: pointer;
}
.bb-native-footer-newsletter-form input[type=submit]:hover,
.bb-native-footer-newsletter-form button[type=submit]:hover,
.bb-native-footer-newsletter-fallback button[type=submit]:hover {
	background: #ffffff;
	color: var(--bb-color-primary-700);
}
.bb-native-footer-newsletter-form .wpcf7-response-output,
.bb-native-footer-newsletter-form .wpcf7-not-valid-tip {
	font-size: 12px; color: #a00; margin: 8px 0 0;
}

.bb-native-footer-grid-section { padding: 48px 0; }
.bb-native-footer-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 32px;
}
@media (min-width: 768px) { .bb-native-footer-grid { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 1080px) { .bb-native-footer-grid { grid-template-columns: repeat(5, 1fr); } }
.bb-native-footer-col {
	display: flex; flex-direction: column; gap: 12px;
}
.bb-native-footer-col-about { grid-column: 1 / -1; }
@media (min-width: 1080px) { .bb-native-footer-col-about { grid-column: auto; } }
.bb-native-footer-address {
	font-family: var(--bb-font-sans);
	font-weight: 600;
	font-size: 15px;
	color: var(--bb-color-footer-text);
	margin: 0 0 4px;
	line-height: 1.45;
}
.bb-native-footer-phone {
	margin: 0 0 12px;
	font-size: 14.5px;
	font-weight: 600;
	color: var(--bb-color-footer-accent);
}
.bb-native-footer-phone a { color: var(--bb-color-footer-accent); }
.bb-native-footer-phone a:hover { color: var(--bb-color-footer-link-hover); }
.bb-native-footer-badge {
	width: 180px; height: auto; max-width: 100%;
	filter: brightness(0) invert(1) opacity(.85);
}
.bb-native-footer-heading {
	font-family: var(--bb-font-display);
	font-size: 14px;
	font-weight: 700;
	text-transform: uppercase;
	color: var(--bb-color-footer-accent);
	margin: 0 0 4px;
	letter-spacing: .08em;
}
.bb-native-footer-list {
	display: flex; flex-direction: column; gap: 8px;
	font-size: 13.5px;
	color: var(--bb-color-footer-link);
}
.bb-native-footer-list a:hover { color: var(--bb-color-footer-link-hover); }
.bb-native-footer-hours li { font-size: 13px; color: var(--bb-color-footer-muted); }
.bb-native-footer-social {
	display: flex; gap: 8px;
	flex-wrap: wrap;
}
.bb-native-footer-social a {
	width: 40px; height: 40px;
	border: 1px solid rgba(255,255,255,.20);
	border-radius: 50%;
	display: inline-flex; align-items: center; justify-content: center;
	color: var(--bb-color-footer-link);
	transition: background .2s, color .2s, border-color .2s;
}
.bb-native-footer-social a:hover {
	background: var(--bb-color-footer-accent);
	color: var(--bb-color-primary-700);
	border-color: var(--bb-color-footer-accent);
}
.bb-native-footer-payment-section {
	border-top: 1px solid var(--bb-color-footer-divider);
	padding: 24px 0;
	color: var(--bb-color-footer-muted);
}
.bb-native-footer-payment {
	display: flex; align-items: center; justify-content: flex-end;
	gap: 16px;
	flex-wrap: wrap;
}
.bb-native-footer-payment-icons {
	display: flex; gap: 8px; flex-wrap: wrap;
}
.bb-native-footer-payment-icons li {
	display: inline-flex;
	filter: brightness(0) invert(1) opacity(.72);
}
.bb-native-footer-copy {
	background: rgba(0,0,0,.18);
	padding: 28px 0;
	text-align: center;
	border-top: 1px solid var(--bb-color-footer-divider);
}
.bb-native-footer-copy p {
	margin: 0; font-size: 13px; color: var(--bb-color-footer-muted);
}
.bb-native-footer-copy a { color: var(--bb-color-footer-link); }

/* ------------------------------------------------------------------
 * A11y guardrails — homepage version.
 *
 *   - Site-wide visible keyboard focus ring on any interactive element
 *     we didn't already style with a custom ring.  Scoped to
 *     `body.bb-native-body` so it doesn't spill into admin/Porto.
 *   - `prefers-reduced-motion` honours the OS setting and flattens our
 *     hover transforms / fade-ins.
 * ------------------------------------------------------------------ */

body.bb-native-body a:focus-visible,
body.bb-native-body button:focus-visible,
body.bb-native-body input:focus-visible,
body.bb-native-body select:focus-visible,
body.bb-native-body textarea:focus-visible,
body.bb-native-body [tabindex]:focus-visible,
body.bb-native-body summary:focus-visible {
	outline: 2px solid var(--bb-color-primary);
	outline-offset: 2px;
	border-radius: 4px;
}

@media (prefers-reduced-motion: reduce) {
	body.bb-native-body *,
	body.bb-native-body *::before,
	body.bb-native-body *::after {
		animation-duration: 0.01ms !important;
		animation-iteration-count: 1 !important;
		transition-duration: 0.01ms !important;
		scroll-behavior: auto !important;
	}
}
