﻿/* ===================================================================
   bbco-store-core CSS â€” split into two scopes:

   1) .bbco-core-*   Frontend dashboard / quote / messaging UI.
                     Uses theme tokens directly (--bbco-*).
                     Avoid duplicate color alias layers under
                     --bbco-core-*; keep only component-private constants.
   2) .bbco-admin-*  wp-admin only. Uses WordPress admin palette
                     (#dcdcde, #f6f7f7, #646970, â€¦) on purpose to blend
                     with core WP screens â€” do NOT migrate these to the
                     theme tokens.
   =================================================================== */

/* ---------- 1) Frontend (.bbco-core-*) ---------- */

:root {
	/* Frontend private constants only (theme palette/semantic tokens use --bbco-* directly). */
	--bbco-core-space-2: 2px;
	--bbco-core-space-6: 6px;
	--bbco-core-space-10: 10px;
	--bbco-core-space-14: 14px;
	--bbco-core-size-20: 20px;
	--bbco-core-size-18: 18px;
	--bbco-core-size-24: 24px;
	--bbco-core-size-28: 28px;
	--bbco-core-size-32: 32px;
	--bbco-core-size-36: 36px;
	--bbco-core-size-40: 40px;
	--bbco-core-size-56: 56px;
	--bbco-core-size-72: 72px;
	--bbco-core-compare-slot-size: var(--bbco-core-size-72);
	--bbco-core-compare-slot-size-sm: var(--bbco-core-size-56);
	--bbco-core-compare-remove-size: var(--bbco-core-size-28);
	--bbco-core-compare-collapse-size: var(--bbco-core-size-32);
	--bbco-core-overlay-soft: color-mix(in srgb, var(--bbco-ink) 16%, transparent);
	--bbco-core-overlay-medium: color-mix(in srgb, var(--bbco-ink) 48%, transparent);
	--bbco-core-overlay-strong: color-mix(in srgb, var(--bbco-ink) 55%, transparent);
}

.bbco-core-dashboard {
	display: grid;
	gap: var(--bbco-space-24, 24px);
}

.bbco-core-panel,
.bbco-core-gate {
	background: var(--bbco-surface);
	border: 1px solid var(--bbco-border);
	border-radius: var(--bbco-radius);
	padding: clamp(18px, 3vw, 28px);
	box-shadow: 0 14px 36px color-mix(in srgb, var(--bbco-text) 6%, transparent);
}

.bbco-core-panel__head {
	align-items: center;
	display: flex;
	gap: var(--bbco-space-16, 16px);
	justify-content: space-between;
	margin-bottom: var(--bbco-space-20, 20px);
}

.bbco-core-panel__head h2,
.bbco-core-gate h2 {
	font-size: var(--bbco-text-xl, 1.5rem);
	line-height: 1.2;
	margin: 0;
}

.bbco-core-muted {
	color: var(--bbco-muted);
	margin: 0;
}

.bbco-core-stats {
	display: grid;
	gap: var(--bbco-space-12, 12px);
	grid-template-columns: repeat(3, minmax(0, 1fr));
}

.bbco-core-stats div {
	background: color-mix(in srgb, var(--bbco-primary) 7%, var(--bbco-surface));
	border: 1px solid color-mix(in srgb, var(--bbco-primary) 15%, var(--bbco-border));
	border-radius: var(--bbco-radius);
	padding: var(--bbco-space-16, 16px);
}

.bbco-core-stats strong {
	color: var(--bbco-text);
	display: block;
	font-size: var(--bbco-text-2xl, 2rem);
	line-height: 1;
}

.bbco-core-stats span {
	color: var(--bbco-muted);
	display: block;
	font-size: var(--bbco-text-sm, 0.875rem);
	margin-top: var(--bbco-space-8, 8px);
}

.bbco-core-form {
	display: grid;
	gap: var(--bbco-space-16, 16px);
}

.bbco-core-form-grid {
	display: grid;
	gap: var(--bbco-space-16, 16px);
	grid-template-columns: repeat(2, minmax(0, 1fr));
}

.bbco-core-form .bbco-core-field {
	position: relative;
	gap: 0;
	color: var(--bbco-muted);
	font-size: var(--bbco-text-sm, 0.875rem);
	font-weight: var(--bbco-weight-medium, 500);
}

.bbco-core-form .bbco-core-field > span {
	position: absolute;
	top: 0;
	left: var(--bbco-space-12, 12px);
	z-index: 1;
	transform: translateY(-50%);
	padding: 0 var(--bbco-space-4, 4px);
	background: var(--bbco-surface);
	color: var(--bbco-muted);
	font-size: var(--bbco-text-sm, 0.875rem);
	font-weight: var(--bbco-weight-semibold, 600);
	line-height: 1.1;
	pointer-events: none;
}

.bbco-core-form input,
.bbco-core-form select,
.bbco-core-form textarea,
.bbco-core-message-form textarea {
	background: var(--bbco-surface);
	border: 1px solid var(--bbco-border);
	border-radius: var(--bbco-radius);
	color: var(--bbco-text);
	font: inherit;
	min-height: 44px;
	padding: var(--bbco-space-8, 8px) var(--bbco-space-12, 12px);
	width: 100%;
}

/* Floating-label fields: keep default border at rest,
   switch to secondary only on focus (no thick primary halo). */
.bbco-core-form .bbco-core-field > input,
.bbco-core-form .bbco-core-field > select,
.bbco-core-form .bbco-core-field > textarea {
	border: 1px solid var(--bbco-border);
}

.bbco-core-form .bbco-core-field > input:focus,
.bbco-core-form .bbco-core-field > select:focus,
.bbco-core-form .bbco-core-field > textarea:focus {
	border-color: var(--bbco-secondary, #374B5C);
	box-shadow: none;
}

.bbco-core-form textarea,
.bbco-core-message-form textarea {
	resize: vertical;
}

.bbco-core-hp,
.bbco-core-sr-only {
	border: 0;
	clip: rect(0, 0, 0, 0);
	clip-path: inset(50%);
	height: 1px;
	margin: -1px;
	overflow: hidden;
	padding: 0;
	position: absolute;
	white-space: nowrap;
	width: 1px;
}

.bbco-core-table-wrap {
	overflow-x: auto;
}

.bbco-core-table {
	border-collapse: collapse;
	font-size: var(--bbco-text-sm, 0.875rem);
	min-width: 620px;
	width: 100%;
}

.bbco-core-table th,
.bbco-core-table td {
	border-bottom: 1px solid var(--bbco-border);
	padding: var(--bbco-space-12, 12px);
	text-align: left;
	vertical-align: top;
}

.bbco-core-table th {
	color: var(--bbco-muted);
	font-size: var(--bbco-text-xs, 0.75rem);
	letter-spacing: 0;
	text-transform: uppercase;
}

.bbco-core-table a {
	color: var(--bbco-primary);
	font-weight: var(--bbco-weight-bold, 700);
	text-decoration: none;
}

.bbco-core-compare-cell {
	align-items: flex-start;
	display: flex;
	gap: var(--bbco-space-8, 8px);
	justify-content: space-between;
}

.bbco-core-table a.bbco-core-compare-remove {
	align-items: center;
	background: color-mix(in srgb, var(--bbco-danger) 12%, transparent);
	border-radius: var(--bbco-radius-pill);
	color: var(--bbco-danger);
	display: inline-flex;
	flex: 0 0 auto;
	font-size: 16px;
	height: 22px;
	justify-content: center;
	line-height: 1;
	width: 22px;
}

.bbco-core-table a.bbco-core-compare-remove:hover {
	background: var(--bbco-danger);
	color: var(--bbco-on-dark-strong);
}

.bbco-core-product-list {
	display: grid;
	gap: var(--bbco-space-12, 12px);
	grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
}

.bbco-core-product-list a {
	border: 1px solid var(--bbco-border);
	border-radius: var(--bbco-radius);
	color: inherit;
	display: grid;
	gap: var(--bbco-space-8, 8px);
	padding: var(--bbco-space-12, 12px);
	text-decoration: none;
}

.bbco-core-product-list span {
	color: var(--bbco-muted);
}

.bbco-core-conversations {
	display: grid;
	gap: var(--bbco-space-16, 16px);
}

.bbco-core-conversation {
	border: 1px solid var(--bbco-border);
	border-radius: var(--bbco-radius);
	display: grid;
	gap: var(--bbco-space-16, 16px);
	padding: var(--bbco-space-16, 16px);
}

.bbco-core-conversation header {
	align-items: start;
	display: flex;
	gap: var(--bbco-space-12, 12px);
	justify-content: space-between;
}

.bbco-core-conversation header strong,
.bbco-core-conversation header a,
.bbco-core-conversation header span {
	display: block;
}

.bbco-core-conversation header a {
	color: var(--bbco-primary);
	font-size: var(--bbco-text-sm, 0.875rem);
	margin-top: var(--bbco-space-4, 4px);
	text-decoration: none;
}

.bbco-core-conversation header span {
	color: var(--bbco-muted);
	font-size: var(--bbco-text-sm, 0.875rem);
	text-align: right;
}

.bbco-core-thread {
	background: color-mix(in srgb, var(--bbco-border) 22%, var(--bbco-surface));
	border-radius: var(--bbco-radius);
	display: grid;
	gap: var(--bbco-space-8, 8px);
	max-height: 320px;
	overflow: auto;
	padding: var(--bbco-space-12, 12px);
}

.bbco-core-message {
	background: var(--bbco-surface);
	border: 1px solid var(--bbco-border);
	border-radius: var(--bbco-radius);
	max-width: 78%;
	padding: var(--bbco-space-8, 8px) var(--bbco-space-12, 12px);
}

.bbco-core-message.is-mine {
	background: color-mix(in srgb, var(--bbco-primary) 10%, var(--bbco-surface));
	justify-self: end;
}

.bbco-core-message span {
	color: var(--bbco-muted);
	display: block;
	font-size: var(--bbco-text-xs, 0.75rem);
	font-weight: var(--bbco-weight-bold, 700);
	margin-bottom: var(--bbco-space-4, 4px);
}

.bbco-core-message p {
	margin: 0;
}

.bbco-core-message-form {
	align-items: end;
	display: grid;
	gap: var(--bbco-space-8, 8px);
	grid-template-columns: 1fr auto;
}

.bbco-core-message-form .bbco-btn {
	min-height: 44px;
}

.bbco-core-workspace-head {
	align-items: center;
	background: var(--bbco-surface);
	border: 1px solid var(--bbco-border);
	border-radius: var(--bbco-radius);
	box-shadow: 0 14px 36px color-mix(in srgb, var(--bbco-text) 5%, transparent);
	display: flex;
	gap: var(--bbco-space-20, 20px);
	justify-content: space-between;
	padding: clamp(16px, 2.5vw, 24px);
}

.bbco-core-workspace-head h2 {
	font-size: var(--bbco-text-xl, 1.5rem);
	line-height: 1.2;
	margin: 0;
}

.bbco-core-account-summary,
.bbco-core-account-media {
	align-items: center;
	display: flex;
	gap: var(--bbco-space-16, 16px);
	min-width: 0;
}

.bbco-core-account-avatar {
	align-items: center;
	aspect-ratio: 1;
	background: linear-gradient(135deg, var(--bbco-primary), var(--bbco-secondary));
	border-radius: 50%;
	color: var(--bbco-surface);
	display: inline-flex;
	flex: 0 0 72px;
	font-size: var(--bbco-text-xl, 1.5rem);
	font-weight: var(--bbco-weight-bold, 700);
	height: 72px;
	justify-content: center;
	letter-spacing: 0.02em;
	overflow: hidden;
	text-transform: uppercase;
	width: 72px;
}

.bbco-core-account-avatar--lg {
	flex-basis: 96px;
	font-size: var(--bbco-text-2xl, 2rem);
	height: 96px;
	width: 96px;
}

.bbco-core-account-avatar img {
	display: block;
	height: 100%;
	object-fit: cover;
	width: 100%;
}

.bbco-core-account-media {
	align-items: flex-start;
	background: color-mix(in srgb, var(--bbco-primary) 5%, var(--bbco-surface));
	border: 1px solid color-mix(in srgb, var(--bbco-primary) 12%, var(--bbco-border));
	border-radius: var(--bbco-radius);
	padding: var(--bbco-space-16, 16px);
}

.bbco-core-account-media__body,
.bbco-core-file-field {
	display: grid;
	gap: var(--bbco-space-8, 8px);
}

.bbco-core-file-field > span {
	color: var(--bbco-text);
	font-weight: var(--bbco-weight-bold, 700);
}

.bbco-core-check {
	align-items: center;
	color: var(--bbco-text);
	display: inline-flex;
	gap: var(--bbco-space-8, 8px);
	font-size: var(--bbco-text-sm, 0.875rem);
	font-weight: var(--bbco-weight-medium, 500);
}

.bbco-core-check input {
	flex: 0 0 auto;
	min-height: auto;
	width: auto;
}

.bbco-core-workspace-head .bbco-core-seller-switch {
	max-width: 280px;
	min-width: min(280px, 100%);
}

@media (max-width: 720px) {
	.bbco-core-panel__head,
	.bbco-core-conversation header,
	.bbco-core-message-form {
		align-items: stretch;
		display: grid;
	}

	.bbco-core-stats,
	.bbco-core-form-grid {
		grid-template-columns: 1fr;
	}

	.bbco-core-filterbar {
		align-items: stretch;
		flex-direction: column;
	}

	.bbco-core-filterbar__search {
		flex-direction: column;
	}

	.bbco-core-conversation header span {
		text-align: left;
	}

	.bbco-core-message {
		max-width: 100%;
	}

	.bbco-core-workspace-head {
		align-items: stretch;
		flex-direction: column;
	}

	.bbco-core-account-media {
		align-items: stretch;
		flex-direction: column;
	}

	.bbco-core-workspace-head .bbco-core-seller-switch {
		max-width: none;
	}
}

.bbco-core-row-actions {
	align-items: center;
	display: flex;
	flex-wrap: wrap;
	gap: var(--bbco-space-8, 8px);
}

/* Keep the three 34px icon actions on one row inside table cells. */
.bbco-core-table td.bbco-core-row-actions {
	min-width: 150px;
}

.bbco-core-inline-form {
	display: inline;
	margin: 0;
}

.bbco-core-row-actions .bbco-core-inline-form {
	display: inline-flex;
}

.bbco-core-table .bbco-core-icon-action,
.bbco-core-icon-action {
	align-items: center;
	background: color-mix(in srgb, var(--bbco-primary) 8%, var(--bbco-surface));
	border: 1px solid color-mix(in srgb, var(--bbco-primary) 18%, var(--bbco-border));
	border-radius: var(--bbco-radius-sm, 6px);
	color: var(--bbco-primary);
	cursor: pointer;
	display: inline-flex;
	height: 34px;
	justify-content: center;
	line-height: 1;
	padding: 0;
	position: relative;
	text-decoration: none;
	width: 34px;
}

.bbco-core-table .bbco-core-icon-action:hover,
.bbco-core-icon-action:hover,
.bbco-core-icon-action:focus-visible {
	background: var(--bbco-primary);
	border-color: var(--bbco-primary);
	color: var(--bbco-on-dark-strong);
	text-decoration: none;
}

.bbco-core-icon-action--delete {
	background: color-mix(in srgb, var(--bbco-danger) 8%, var(--bbco-surface));
	border-color: color-mix(in srgb, var(--bbco-danger) 20%, var(--bbco-border));
	color: var(--bbco-danger);
}

.bbco-core-icon-action--delete:hover,
.bbco-core-icon-action--delete:focus-visible {
	background: var(--bbco-danger);
	border-color: var(--bbco-danger);
	color: var(--bbco-on-dark-strong);
}

.bbco-core-icon-action svg {
	fill: none;
	height: 18px;
	pointer-events: none;
	stroke: currentColor;
	stroke-linecap: round;
	stroke-linejoin: round;
	stroke-width: 2;
	width: 18px;
}

.bbco-core-icon-action::before,
.bbco-core-icon-action::after {
	left: 50%;
	opacity: 0;
	pointer-events: none;
	position: absolute;
	transform: translate(-50%, 4px);
	transition: opacity var(--bbco-dur-fast, 160ms) var(--bbco-ease, ease), transform var(--bbco-dur-fast, 160ms) var(--bbco-ease, ease);
	z-index: 20;
}

.bbco-core-icon-action::before {
	border: 5px solid transparent;
	border-top-color: var(--bbco-ink);
	bottom: calc(100% + 2px);
	content: "";
}

.bbco-core-icon-action::after {
	background: var(--bbco-ink);
	border-radius: var(--bbco-radius-sm, 6px);
	bottom: calc(100% + 12px);
	color: var(--bbco-on-dark-strong);
	content: attr(data-bbco-tooltip);
	font-size: var(--bbco-text-xs, 0.75rem);
	font-weight: var(--bbco-weight-semibold, 600);
	line-height: 1;
	padding: var(--bbco-core-space-6) var(--bbco-space-8, 8px);
	white-space: nowrap;
}

.bbco-core-icon-action:hover::before,
.bbco-core-icon-action:hover::after,
.bbco-core-icon-action:focus-visible::before,
.bbco-core-icon-action:focus-visible::after {
	opacity: 1;
	transform: translate(-50%, 0);
}

.bbco-core-linkbtn {
	background: none;
	border: 0;
	color: var(--bbco-danger);
	cursor: pointer;
	font-size: inherit;
	font-weight: var(--bbco-weight-bold, 700);
	padding: 0;
}

.bbco-core-linkbtn:hover {
	text-decoration: underline;
}

.bbco-core-status-form select {
	max-width: 180px;
}

.bbco-media-field {
	display: grid;
	gap: var(--bbco-space-8, 8px);
	margin-top: var(--bbco-space-16, 16px);
}

.bbco-media-field__label {
	color: var(--bbco-muted);
	font-size: var(--bbco-text-xs, 0.75rem);
	font-weight: var(--bbco-weight-bold, 700);
	letter-spacing: 0;
	text-transform: uppercase;
}

.bbco-media-field__list {
	display: flex;
	flex-wrap: wrap;
	gap: var(--bbco-space-8, 8px);
	list-style: none;
	margin: 0;
	padding: 0;
}

.bbco-media-field__item {
	align-items: center;
	background: var(--bbco-surface-alt);
	border: 1px solid var(--bbco-border);
	border-radius: var(--bbco-radius-sm);
	display: flex;
	gap: var(--bbco-space-8, 8px);
	max-width: 220px;
	padding: var(--bbco-space-8, 8px);
}

.bbco-media-field__thumb {
	border-radius: var(--bbco-radius-sm);
	display: block;
	height: 48px;
	object-fit: cover;
	width: 48px;
}

.bbco-media-field__file {
	font-size: var(--bbco-text-sm, 0.875rem);
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.bbco-media-field__remove {
	background: none;
	border: 0;
	color: var(--bbco-danger);
	cursor: pointer;
	font-size: var(--bbco-core-size-18);
	line-height: 1;
	margin-left: auto;
	padding: 0 var(--bbco-space-4, 4px);
}

.bbco-core-specgroup {
	border: 1px solid var(--bbco-border);
	border-radius: var(--bbco-radius-md);
	margin: var(--bbco-space-16, 16px) 0 0;
	padding: var(--bbco-space-16, 16px);
}

.bbco-core-specgroup > legend {
	font-weight: 600;
	padding: 0 var(--bbco-space-8, 8px);
}

/* KPI cards */
.bbco-core-kpi-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
	gap: var(--bbco-space-16, 16px);
}

.bbco-core-kpi {
	background: var(--bbco-surface);
	border: 1px solid var(--bbco-border);
	border-radius: var(--bbco-radius-md);
	padding: var(--bbco-space-20, 20px);
	display: flex;
	flex-direction: column;
	gap: var(--bbco-space-4, 4px);
}

.bbco-core-kpi__label {
	color: var(--bbco-muted);
	font-size: var(--bbco-text-sm, 0.875rem);
}

.bbco-core-kpi__value {
	font-size: var(--bbco-text-2xl, 1.75rem);
	font-weight: var(--bbco-weight-bold, 700);
	line-height: 1.1;
}

.bbco-core-kpi__meta {
	color: var(--bbco-muted);
	font-size: var(--bbco-text-sm, 0.875rem);
}

.bbco-core-kpi__meta.is-up {
	color: var(--bbco-success);
}

.bbco-core-kpi__meta.is-down {
	color: var(--bbco-danger);
}

/* Filter bar */
.bbco-core-filterbar {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: var(--bbco-space-12, 12px);
	margin-bottom: var(--bbco-space-16, 16px);
}

.bbco-core-filterbar__statuses {
	display: flex;
	flex-wrap: wrap;
	gap: var(--bbco-space-8, 8px);
}

.bbco-core-chip {
	border: 1px solid var(--bbco-border);
	border-radius: 999px;
	cursor: pointer;
	font-size: var(--bbco-text-sm, 0.875rem);
	padding: var(--bbco-space-4, 4px) var(--bbco-space-12, 12px);
	/* Containing block for the visually-hidden radio, otherwise the
	   theme's global input { width: 100% } sizes it to the viewport. */
	position: relative;
}

.bbco-core-chip.is-active {
	background: var(--bbco-primary);
	border-color: var(--bbco-primary);
	color: var(--bbco-on-dark-strong);
}

.bbco-core-chip input {
	position: absolute;
	opacity: 0;
	pointer-events: none;
}

.bbco-core-filterbar__search {
	display: flex;
	gap: var(--bbco-space-8, 8px);
}

/* Product cell */
.bbco-core-product-cell {
	display: flex;
	align-items: center;
	gap: var(--bbco-space-12, 12px);
}

.bbco-core-product-cell img,
.bbco-core-product-cell__noimg {
	border-radius: var(--bbco-radius-sm, 6px);
	height: 48px;
	width: 48px;
	object-fit: cover;
	flex: 0 0 auto;
}

.bbco-core-product-cell__noimg {
	background: var(--bbco-border);
	display: inline-block;
}

/* Status badges */
.bbco-core-badge {
	border-radius: 999px;
	display: inline-block;
	font-size: var(--bbco-text-sm, 0.875rem);
	font-weight: var(--bbco-weight-bold, 700);
	padding: var(--bbco-space-4, 4px) var(--bbco-space-12, 12px);
}

.bbco-core-badge.is-published,
.bbco-core-badge.is-won {
	background: color-mix(in srgb, var(--bbco-success) 14%, transparent);
	color: var(--bbco-success);
}

.bbco-core-badge.is-pending,
.bbco-core-badge.is-new,
.bbco-core-badge.is-reviewing,
.bbco-core-badge.is-negotiating {
	background: color-mix(in srgb, var(--bbco-primary) 14%, transparent);
	color: var(--bbco-primary);
}

.bbco-core-badge.is-quoted {
	background: color-mix(in srgb, var(--bbco-primary) 14%, transparent);
	color: var(--bbco-primary);
}

.bbco-core-badge.is-draft,
.bbco-core-badge.is-lost,
.bbco-core-badge.is-cancelled {
	background: color-mix(in srgb, var(--bbco-danger) 12%, transparent);
	color: var(--bbco-danger);
}

.bbco-core-status-select {
	border: 1px solid var(--bbco-border);
	border-radius: var(--bbco-radius-sm, 6px);
	padding: var(--bbco-space-4, 4px) var(--bbco-space-8, 8px);
}

/* Sectioned product form */
.bbco-core-formsection {
	border: 1px solid var(--bbco-border);
	border-radius: var(--bbco-radius-md);
	margin: 0 0 var(--bbco-space-16, 16px);
	padding: var(--bbco-space-20, 20px);
}

.bbco-core-formsection > legend {
	font-size: var(--bbco-text-base, 1rem);
	font-weight: var(--bbco-weight-bold, 700);
	padding: 0 var(--bbco-space-8, 8px);
}

.bbco-core-savebar {
	background: var(--bbco-surface);
	border-top: 1px solid var(--bbco-border);
	bottom: 0;
	display: flex;
	justify-content: flex-end;
	padding: var(--bbco-space-12, 12px) 0;
	position: sticky;
	z-index: 5;
}

/* ---------- 2) wp-admin (.bbco-admin-*) ---------- */
/* These intentionally use the WordPress admin palette so the plugin
   screens blend with WP core. Do not migrate to theme tokens. */

.bbco-admin-cards {
	display: grid;
	gap: 16px;
	grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
	margin-top: 20px;
	max-width: 920px;
}

.bbco-admin-card,
.bbco-admin-box {
	background: #ffffff;
	border: 1px solid #dcdcde;
	border-radius: 8px;
	padding: 16px;
}

.bbco-admin-card strong {
	display: block;
	font-size: 2rem;
	line-height: 1;
}

.bbco-admin-card span {
	color: #646970;
	display: block;
	margin-top: 8px;
}

.bbco-admin-health {
	margin-top: 12px;
	max-width: 980px;
}

.bbco-admin-status {
	border-radius: 999px;
	display: inline-block;
	font-size: 12px;
	font-weight: 700;
	padding: 3px 8px;
}

.bbco-admin-status.is-ok {
	background: #dcfce7;
	color: #166534;
}

.bbco-admin-status.is-warning {
	background: #fef3c7;
	color: #92400e;
}

.bbco-admin-grid {
	display: grid;
	gap: 14px;
	grid-template-columns: repeat(2, minmax(0, 1fr));
}

.bbco-admin-field,
.bbco-admin-check {
	display: grid;
	gap: 6px;
}

.bbco-admin-field--wide {
	grid-column: 1 / -1;
}

.bbco-admin-field span,
.bbco-admin-check span {
	font-weight: 600;
}

.bbco-admin-field input,
.bbco-admin-field select,
.bbco-admin-field textarea {
	max-width: 100%;
	width: 100%;
}

.bbco-admin-media-field {
	align-content: start;
	background: #fff;
	border: 1px solid #dcdcde;
	border-radius: 8px;
	padding: 12px;
}

.bbco-admin-media-preview {
	display: grid;
	gap: 10px;
	grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
	min-height: 54px;
}

.bbco-admin-media-item {
	align-items: center;
	background: #f6f7f7;
	border: 1px solid #dcdcde;
	border-radius: 6px;
	display: grid;
	gap: 10px;
	grid-template-columns: 54px minmax(0, 1fr) auto;
	padding: 8px;
}

.bbco-admin-media-thumb {
	align-items: center;
	background: #fff;
	border: 1px solid #dcdcde;
	border-radius: 5px;
	display: flex;
	height: 54px;
	justify-content: center;
	overflow: hidden;
	width: 54px;
}

.bbco-admin-media-thumb img {
	display: block;
	height: 100%;
	object-fit: cover;
	width: 100%;
}

.bbco-admin-media-thumb .dashicons {
	color: #646970;
	font-size: 24px;
	height: 24px;
	width: 24px;
}

.bbco-admin-media-meta {
	min-width: 0;
}

.bbco-admin-media-meta strong,
.bbco-admin-media-meta small {
	display: block;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.bbco-admin-media-meta small {
	color: #646970;
	margin-top: 3px;
}

.bbco-admin-media-empty {
	align-items: center;
	background: #f6f7f7;
	border: 1px dashed #c3c4c7;
	border-radius: 6px;
	color: #646970;
	display: flex;
	min-height: 52px;
	padding: 0 12px;
}

.bbco-admin-media-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}

.bbco-term-form-field .bbco-admin-media-field,
.bbco-term-form-row .bbco-admin-media-field {
	max-width: 640px;
}

.bbco-admin-term-image {
	border: 1px solid #dcdcde;
	border-radius: 5px;
	height: 42px;
	object-fit: cover;
	width: 42px;
}

.bbco-admin-term-svg {
	align-items: center;
	background: #f6f7f7;
	border: 1px solid #dcdcde;
	border-radius: 5px;
	display: inline-flex;
	height: 42px;
	justify-content: center;
	overflow: hidden;
	width: 42px;
}

.bbco-admin-term-svg svg {
	display: block;
	height: 32px;
	width: 32px;
}

.bbco-admin-term-empty {
	color: #a7aaad;
	font-size: 24px;
	height: 24px;
	width: 24px;
}

.bbco-field-builder-form {
	max-width: 1240px;
}

.bbco-builder-shell {
	background: #fff;
	border: 1px solid #dcdcde;
	border-radius: 8px;
	margin-top: 16px;
	overflow: hidden;
}

.bbco-builder-toolbar {
	align-items: center;
	background: #f6f7f7;
	border-bottom: 1px solid #dcdcde;
	display: flex;
	gap: 16px;
	justify-content: space-between;
	padding: 16px;
}

.bbco-builder-toolbar h2,
.bbco-builder-toolbar p {
	margin: 0;
}

.bbco-builder-toolbar p {
	color: #646970;
	margin-top: 4px;
}

.bbco-builder-groups {
	display: grid;
	gap: 14px;
	padding: 16px;
}

.bbco-builder-group {
	background: #fff;
	border: 1px solid #dcdcde;
	border-radius: 10px;
	overflow: hidden;
	padding: 0;
}

.bbco-builder-group summary,
.bbco-builder-field summary {
	cursor: pointer;
	list-style: none;
}

.bbco-builder-group summary::-webkit-details-marker,
.bbco-builder-field summary::-webkit-details-marker {
	display: none;
}

.bbco-builder-group-summary {
	align-items: center;
	display: flex;
	gap: 16px;
	justify-content: space-between;
	padding: 14px 16px;
}

.bbco-builder-group[open] > .bbco-builder-group-summary {
	border-bottom: 1px solid #eceef1;
}

.bbco-builder-group-summary::after,
.bbco-builder-field-summary::after {
	color: #50575e;
	content: '+';
	font-size: 18px;
	font-weight: 700;
	line-height: 1;
	margin-left: auto;
}

.bbco-builder-group[open] > .bbco-builder-group-summary::after,
.bbco-builder-field[open] > .bbco-builder-field-summary::after {
	content: 'â€“';
}

.bbco-builder-group-summary-text,
.bbco-builder-field-summary-text {
	display: grid;
	gap: 4px;
	min-width: 0;
}

.bbco-builder-group-summary-text strong,
.bbco-builder-field-summary-text strong {
	color: #1d2327;
	font-size: 14px;
	font-weight: 700;
}

.bbco-builder-group-summary-text small,
.bbco-builder-field-summary-text small {
	color: #646970;
}

.bbco-builder-chip {
	background: #f0f6fc;
	border: 1px solid #c3d9f2;
	border-radius: 999px;
	color: #0a4b78;
	font-size: 12px;
	font-weight: 600;
	padding: 4px 10px;
	white-space: nowrap;
}

.bbco-builder-group-body {
	display: grid;
	gap: 14px;
	padding: 16px;
}

.bbco-builder-group-actions {
	display: flex;
	justify-content: flex-end;
}

.bbco-builder-tabs {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}

.bbco-builder-tab {
	background: #f6f7f7;
	border: 1px solid #dcdcde;
	border-radius: 999px;
	color: #1d2327;
	cursor: pointer;
	font-size: 13px;
	font-weight: 600;
	padding: 8px 14px;
}

.bbco-builder-tab.is-active {
	background: #1d2327;
	border-color: #1d2327;
	color: #fff;
}

.bbco-builder-tab-panels {
	display: grid;
}

.bbco-builder-tab-panel {
	display: none;
}

.bbco-builder-tab-panel.is-active {
	display: block;
}

.bbco-builder-group-head {
	align-items: start;
	display: grid;
	gap: 12px;
	grid-template-columns: minmax(0, 1fr) auto;
}

.bbco-builder-group-fields,
.bbco-builder-field-main {
	display: grid;
	gap: 10px;
	grid-template-columns: repeat(2, minmax(0, 1fr));
}

.bbco-builder-group-fields__full {
	grid-column: 1 / -1;
}

.bbco-builder-fields {
	display: grid;
	gap: 12px;
	margin-bottom: 12px;
}

.bbco-builder-field {
	background: #fbfbfc;
	border: 1px solid #e2e4e7;
	border-radius: 8px;
	overflow: hidden;
	padding: 0;
}

.bbco-builder-field-summary {
	align-items: center;
	display: flex;
	gap: 12px;
	padding: 12px 14px;
}

.bbco-builder-field[open] > .bbco-builder-field-summary {
	border-bottom: 1px solid #e6e8eb;
}

.bbco-builder-field-body {
	display: grid;
	gap: 10px;
	padding: 12px;
}

.bbco-builder-field-main {
	grid-template-columns: minmax(180px, 1.4fr) minmax(160px, 1fr) minmax(130px, 0.8fr) minmax(100px, 0.6fr);
}

.bbco-builder-group label,
.bbco-builder-options {
	display: grid;
	gap: 5px;
}

.bbco-builder-group label span,
.bbco-builder-options span {
	color: #1d2327;
	font-weight: 600;
}

.bbco-builder-group input[type="text"],
.bbco-builder-group input[type="number"],
.bbco-builder-group select,
.bbco-builder-group textarea {
	width: 100%;
}

.bbco-builder-flags {
	align-items: center;
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
}

.bbco-builder-flags label {
	align-items: center;
	display: flex;
	gap: 5px;
}

.bbco-builder-empty {
	background: #f6f7f7;
	border: 1px dashed #c3c4c7;
	border-radius: 6px;
	color: #646970;
	padding: 14px;
}

.bbco-builder-conditions {
	display: grid;
	gap: 10px;
}

.bbco-builder-help {
	color: #646970;
	margin: 0;
}

.bbco-builder-json {
	margin-top: 16px;
}

.bbco-builder-json summary {
	cursor: pointer;
	font-weight: 600;
	margin-bottom: 8px;
}

@media (max-width: 720px) {
	.bbco-admin-grid {
		grid-template-columns: 1fr;
	}

	.bbco-builder-toolbar,
	.bbco-builder-group-head {
		align-items: stretch;
		display: grid;
		grid-template-columns: 1fr;
	}

	.bbco-builder-group-fields,
	.bbco-builder-field-main {
		grid-template-columns: 1fr;
	}

	.bbco-admin-media-preview {
		grid-template-columns: 1fr;
	}
}

/* Structured Field Builder upgrades */
.bbco-admin-specs {
	background: #fff;
	border: 1px solid var(--bbco-border, #e2e8f0);
	border-radius: var(--bbco-radius-md, 10px);
	margin-top: 18px;
	padding: 18px;
}

.bbco-admin-specs > h3 {
	margin-top: 0;
}

.bbco-spec-input small {
	color: var(--bbco-muted, #64748b);
	display: block;
	font-size: 12px;
	margin-top: 5px;
}

.bbco-spec-input.is-required > span::after {
	color: var(--bbco-danger, #dc2626);
	content: '';
}

.bbco-admin-recommendation-status {
	border-radius: var(--bbco-radius-md, 10px);
	margin-top: 14px;
	padding: 12px 14px;
}

.bbco-admin-recommendation-status.is-ready {
	background: #ecfdf5;
	border: 1px solid #bbf7d0;
	color: #166534;
}

.bbco-admin-recommendation-status.is-missing {
	background: #fff7ed;
	border: 1px solid #fed7aa;
	color: #9a3412;
}

.bbco-admin-recommendation-status p {
	margin: 4px 0 0;
}

.bbco-builder-conditions {
	background: #f8fafc;
	border: 1px solid #e2e8f0;
	border-radius: 10px;
	margin: 12px 0 16px;
	padding: 12px;
}

.bbco-builder-category-list {
	display: flex;
	flex-wrap: wrap;
	gap: 8px 14px;
	margin: 10px 0;
}

.bbco-builder-category-list label,
.bbco-builder-flags label {
	align-items: center;
	display: inline-flex;
	gap: 5px;
}

.bbco-builder-help {
	color: #64748b;
	font-size: 12px;
	margin: 8px 0 0;
}

.bbco-builder-field-main--advanced {
	margin-top: 10px;
}

.bbco-core-specsection [data-bbco-spec-group].is-hidden,
.bbco-core-empty.is-hidden {
	display: none !important;
}

.bbco-core-empty {
	margin: var(--bbco-space-12, 12px) 0 0;
	padding: var(--bbco-core-space-14) var(--bbco-space-16, 16px);
	border-radius: var(--bbco-radius-md);
	background: color-mix(in srgb, var(--bbco-surface-alt) 95%, transparent);
	color: var(--bbco-muted);
}

/* Compare UX */
.bbco-product-card__quick-btn.is-active,
.bbco-inline-actions [data-bbco-compare-toggle].is-active {
	background: color-mix(in srgb, var(--bbco-primary) 10%, var(--bbco-surface));
	border-color: color-mix(in srgb, var(--bbco-primary) 32%, var(--bbco-border));
	color: var(--bbco-primary);
}

.bbco-compare-dock {
	position: fixed;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: calc(var(--bbco-z-toast) - 1);
	padding: 0;
	background: var(--bbco-surface);
	border-top: 1px solid color-mix(in srgb, var(--bbco-border) 85%, white);
	box-shadow: 0 -12px 34px var(--bbco-core-overlay-soft);
}

.bbco-compare-dock.is-hidden {
	display: none;
}

.bbco-compare-dock__inner {
	display: flex;
	align-items: center;
	gap: var(--bbco-space-24, 24px);
	background: transparent;
	border: 0;
	border-radius: 0;
	box-shadow: none;
	padding: var(--bbco-space-20, 20px) 0;
}

.bbco-compare-dock__slots {
	display: flex;
	align-items: center;
	gap: var(--bbco-space-12, 12px);
	flex-wrap: wrap;
	flex: 1 1 auto;
	min-width: 0;
}

.bbco-compare-dock__item,
.bbco-compare-dock__ghost {
	width: var(--bbco-core-compare-slot-size);
	height: var(--bbco-core-compare-slot-size);
	border-radius: var(--bbco-radius-md);
	position: relative;
	flex: 0 0 auto;
}

.bbco-compare-dock__ghost {
	border: 2px dashed var(--bbco-border);
	background: var(--bbco-soft);
}

.bbco-compare-dock__thumb {
	display: block;
	width: 100%;
	height: 100%;
	border-radius: inherit;
	overflow: hidden;
	background: var(--bbco-soft);
}

.bbco-compare-dock__thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.bbco-compare-dock__placeholder-text {
	display: grid;
	place-items: center;
	width: 100%;
	height: 100%;
	font-size: var(--bbco-text-lg, 1.25rem);
	font-weight: var(--bbco-weight-bold);
	color: var(--bbco-secondary);
}

.bbco-compare-dock__remove {
	position: absolute;
	top: calc(var(--bbco-space-8, 8px) * -1);
	right: calc(var(--bbco-space-8, 8px) * -1);
	width: var(--bbco-core-compare-remove-size);
	height: var(--bbco-core-compare-remove-size);
	border: 1px solid color-mix(in srgb, var(--bbco-border) 70%, white);
	border-radius: 50%;
	background: var(--bbco-surface);
	color: var(--bbco-ink);
	font-size: var(--bbco-core-size-20);
	line-height: 1;
	box-shadow: var(--bbco-shadow-sm);
}

.bbco-compare-dock__summary {
	flex: 0 0 auto;
	font-size: var(--bbco-text-md, 1.125rem);
	font-weight: var(--bbco-weight-regular);
	color: var(--bbco-ink);
	white-space: nowrap;
}

.bbco-compare-dock__actions {
	display: flex;
	align-items: center;
	gap: var(--bbco-space-16, 16px);
	margin-left: auto;
	flex: 0 0 auto;
}

.bbco-compare-dock__actions .bbco-btn {
	min-width: 132px;
}

.bbco-compare-dock__actions .bbco-btn:disabled,
.bbco-compare-dock__actions .bbco-btn[disabled] {
	cursor: not-allowed;
	opacity: 0.55;
	pointer-events: none;
}

.bbco-compare-dock__clear,
.bbco-compare-modal__remove {
	border: 0;
	background: transparent;
	color: var(--bbco-ink);
	font-weight: var(--bbco-weight-medium);
}

.bbco-compare-dock__inner > .bbco-compare-dock__clear {
	flex: 0 0 auto;
	margin-left: calc(var(--bbco-space-8, 8px) * -1);
	padding: var(--bbco-core-space-6) var(--bbco-space-4, 4px);
}

.bbco-compare-dock__collapse {
	display: none;
}

.bbco-compare-modal[hidden] {
	display: none;
}

.bbco-compare-modal {
	position: fixed;
	inset: 0;
	z-index: var(--bbco-z-toast);
}

.bbco-compare-modal__backdrop {
	position: absolute;
	inset: 0;
	background: var(--bbco-core-overlay-medium);
}

.bbco-compare-modal__dialog {
	position: relative;
	width: min(1180px, calc(100% - var(--bbco-space-24, 24px)));
	max-height: calc(100vh - var(--bbco-space-48, 48px));
	margin: var(--bbco-space-24, 24px) auto;
	background: var(--bbco-surface);
	border-radius: var(--bbco-core-size-20);
	box-shadow: var(--bbco-shadow-md);
	overflow: hidden;
	display: flex;
	flex-direction: column;
}

.bbco-compare-modal__head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--bbco-space-16, 16px);
	padding: var(--bbco-space-24, 24px) var(--bbco-space-24, 24px) var(--bbco-space-16, 16px);
	border-bottom: 1px solid var(--bbco-border);
}

.bbco-compare-modal__head h2 {
	margin: var(--bbco-core-space-6) 0 0;
}

.bbco-compare-modal__head-actions {
	display: flex;
	align-items: center;
	gap: var(--bbco-space-12, 12px);
}

.bbco-compare-modal__close {
	width: var(--bbco-core-size-40);
	height: var(--bbco-core-size-40);
	border: 1px solid var(--bbco-border);
	border-radius: 50%;
	background: var(--bbco-surface);
	font-size: var(--bbco-core-size-28);
	line-height: 1;
	color: var(--bbco-ink);
}

.bbco-compare-modal__body {
	padding: var(--bbco-space-24, 24px);
	overflow: auto;
}

.bbco-compare-modal__cards {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
	gap: var(--bbco-space-16, 16px);
	margin-bottom: var(--bbco-space-20, 20px);
}

.bbco-compare-modal__card {
	border: 1px solid var(--bbco-border);
	border-radius: var(--bbco-space-16, 16px);
	overflow: hidden;
	background: var(--bbco-soft);
}

.bbco-compare-modal__card-media {
	display: block;
	aspect-ratio: 1 / 1;
	background: var(--bbco-surface);
}

.bbco-compare-modal__card-media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.bbco-compare-modal__card-body {
	padding: var(--bbco-space-12, 12px);
	display: grid;
	gap: var(--bbco-space-8, 8px);
}

.bbco-compare-modal__card-body h3 {
	margin: 0;
	font-size: var(--bbco-text-base, 1rem);
}

.bbco-compare-modal__card-body p {
	margin: 0;
	color: var(--bbco-muted);
}

.bbco-compare-modal__remove {
	justify-self: start;
	padding: 0;
	color: var(--bbco-primary);
}

.bbco-compare-table-wrap {
	margin-top: var(--bbco-space-4, 4px);
}

.bbco-core-table.bbco-core-compare.is-modal th {
	min-width: 170px;
}

@media (max-width: 900px) {
	.bbco-compare-dock__inner {
		gap: var(--bbco-space-16, 16px);
		padding: var(--bbco-space-16, 16px) 0;
		flex-wrap: wrap;
	}

	.bbco-compare-dock__summary {
		order: 2;
	}

	.bbco-compare-dock__actions {
		order: 3;
		width: 100%;
		justify-content: flex-end;
	}

	.bbco-compare-dock__inner > .bbco-compare-dock__clear {
		order: 4;
		margin-left: auto;
		padding: var(--bbco-space-4, 4px) var(--bbco-space-4, 4px) 0;
	}
}

@media (max-width: 640px) {
	.bbco-compare-dock {
		bottom: 0;
		padding: 0;
	}

	.bbco-compare-dock__inner {
		padding: var(--bbco-space-12, 12px) 0;
		border-radius: 0;
		flex-wrap: wrap;
		gap: var(--bbco-space-12, 12px);
		align-items: center;
	}

	.bbco-compare-dock__summary {
		order: 1;
		flex: 1 1 0;
		min-width: 0;
		font-size: var(--bbco-text-base, 1rem);
		white-space: nowrap;
		overflow: hidden;
		text-overflow: ellipsis;
	}

	.bbco-compare-dock__actions {
		order: 2;
		flex: 0 0 auto;
		flex-wrap: nowrap;
		width: auto;
		margin-left: 0;
		gap: var(--bbco-space-8, 8px);
		justify-content: flex-end;
		align-items: center;
		white-space: nowrap;
	}

	.bbco-compare-dock__actions .bbco-btn {
		min-width: 0;
		padding-left: var(--bbco-space-16, 16px);
		padding-right: var(--bbco-space-16, 16px);
		white-space: nowrap;
	}

	.bbco-compare-dock__slots {
		order: 3;
		flex: 1 1 100%;
		gap: var(--bbco-space-8, 8px);
		padding-top: var(--bbco-space-12, 12px);
		border-top: 1px solid var(--bbco-border);
	}

	.bbco-compare-dock__item,
	.bbco-compare-dock__ghost {
		width: var(--bbco-core-compare-slot-size-sm);
		height: var(--bbco-core-compare-slot-size-sm);
	}

	.bbco-compare-dock__clear {
		order: 99;
		flex: 1 1 100%;
		text-align: right;
		padding: var(--bbco-core-space-10) 0 var(--bbco-core-space-2);
		border-top: 1px solid var(--bbco-border);
	}

	.bbco-compare-dock__collapse {
		display: inline-flex;
		align-items: center;
		justify-content: center;
		width: var(--bbco-core-compare-collapse-size);
		height: var(--bbco-core-compare-collapse-size);
		padding: 0;
		border: 0;
		background: transparent;
		color: var(--bbco-ink);
		cursor: pointer;
	}

.bbco-compare-dock__collapse svg {
		transition: transform var(--bbco-dur-base) var(--bbco-ease, ease);
	}

	.bbco-compare-dock:not(.is-collapsed) .bbco-compare-dock__collapse svg {
		transform: rotate(180deg);
	}

	.bbco-compare-dock.is-collapsed .bbco-compare-dock__slots,
	.bbco-compare-dock.is-collapsed .bbco-compare-dock__clear {
		display: none;
	}

	.bbco-compare-modal__dialog {
		width: calc(100% - var(--bbco-space-12, 12px));
		max-height: calc(100vh - var(--bbco-space-12, 12px));
		margin: var(--bbco-core-space-6) auto;
		border-radius: var(--bbco-radius-lg);
	}

	.bbco-compare-modal__head,
	.bbco-compare-modal__body {
		padding: var(--bbco-space-16, 16px);
	}
}

body.bbco-compare-modal-open { overflow: hidden; }

/* =====================================================================
 * Product reviews
 * ===================================================================== */
.bbco-reviews {
	display: grid;
	gap: var(--bbco-space-32, 32px);
}

.bbco-reviews__summary {
	display: grid;
	grid-template-columns: minmax(220px, 1fr) minmax(0, 1.4fr) auto;
	align-items: center;
	gap: var(--bbco-space-32, 32px);
	padding: var(--bbco-space-32, 32px);
	background: var(--bbco-surface);
	border: 1px solid var(--bbco-border);
	border-radius: var(--bbco-radius-lg);
}

.bbco-reviews__title {
	margin: 0 0 var(--bbco-space-12, 12px);
	text-align: center;
	font-size: var(--bbco-text-xl, 1.5rem);
	font-weight: var(--bbco-weight-bold, 700);
	color: var(--bbco-ink);
}

.bbco-reviews__hero {
	display: grid;
	justify-items: center;
	gap: var(--bbco-space-16, 16px);
}

.bbco-reviews__score {
	display: inline-flex;
	align-items: center;
	gap: var(--bbco-space-8, 8px);
	font-size: var(--bbco-text-lg, 1.25rem);
}

.bbco-reviews__score strong {
	font-size: var(--bbco-text-2xl, 2rem);
	font-weight: var(--bbco-weight-bold, 700);
	color: var(--bbco-ink);
	line-height: 1;
}

.bbco-reviews__count {
	color: var(--bbco-muted);
	font-size: var(--bbco-text-sm, 0.875rem);
}

.bbco-reviews__hero-thumb {
	width: 96px;
	height: 96px;
	border-radius: var(--bbco-radius, 8px);
	overflow: hidden;
	background: var(--bbco-soft);
}

.bbco-reviews__hero-thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.bbco-reviews__bars {
	display: grid;
	gap: var(--bbco-space-12, 12px);
	min-width: min(100%, 380px);
}

.bbco-reviews__bar-row {
	display: grid;
	grid-template-columns: 48px minmax(140px, 1fr) 34px;
	align-items: center;
	gap: var(--bbco-space-12, 12px);
	font-size: var(--bbco-text-base, 1rem);
	color: var(--bbco-muted);
}

.bbco-reviews__bar-label {
	display: inline-flex;
	align-items: center;
	gap: var(--bbco-space-4, 4px);
	color: var(--bbco-ink);
	font-weight: var(--bbco-weight-semibold, 600);
}

.bbco-reviews__bar-track {
	position: relative;
	height: 8px;
	background: var(--bbco-soft);
	background: color-mix(in srgb, var(--bbco-accent) 14%, var(--bbco-surface));
	border-radius: var(--bbco-radius-pill);
	overflow: hidden;
}

.bbco-reviews__bar-fill {
	position: absolute;
	inset: 0;
	width: var(--bbco-bar, 0%);
	background: var(--bbco-accent);
	border-radius: inherit;
	min-width: 0;
	transition: width var(--bbco-dur-base) var(--bbco-ease, ease);
}

.bbco-reviews__bar-count {
	text-align: right;
	color: var(--bbco-muted);
	font-size: var(--bbco-text-base, 1rem);
	font-weight: var(--bbco-weight-semibold, 600);
	font-variant-numeric: tabular-nums;
}

.bbco-reviews__cta {
	display: grid;
	justify-items: stretch;
}

.bbco-reviews__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	gap: var(--bbco-space-20, 20px);
}

.bbco-reviews__item {
	padding: var(--bbco-space-20, 20px) 0;
	border-bottom: 1px solid var(--bbco-border);
	display: grid;
	gap: var(--bbco-space-8, 8px);
}

.bbco-reviews__item:last-child {
	border-bottom: 0;
}

.bbco-reviews__item-stars {
	display: inline-flex;
	gap: var(--bbco-core-space-2);
	color: var(--bbco-accent);
}

.bbco-reviews__item-meta {
	display: grid;
	gap: var(--bbco-core-space-2);
}

.bbco-reviews__item-meta strong {
	color: var(--bbco-ink);
	font-weight: var(--bbco-weight-bold, 700);
}

.bbco-reviews__item-meta time {
	color: var(--bbco-muted);
	font-size: var(--bbco-text-sm, 0.875rem);
}

.bbco-reviews__item-body {
	margin: 0;
	color: var(--bbco-text);
	line-height: 1.55;
}

.bbco-reviews__replies {
	list-style: none;
	margin: var(--bbco-space-16, 16px) 0 0;
	padding: 0;
	display: grid;
	gap: var(--bbco-space-12, 12px);
	border-left: 3px solid var(--bbco-border);
	padding-left: var(--bbco-space-16, 16px);
}

.bbco-reviews__reply {
	background: var(--bbco-soft);
	padding: var(--bbco-space-12, 12px) var(--bbco-space-16, 16px);
	border-radius: var(--bbco-radius, 8px);
}

.bbco-reviews__reply-meta {
	display: inline-flex;
	flex-wrap: wrap;
	align-items: center;
	gap: var(--bbco-space-8, 8px);
	margin-bottom: var(--bbco-space-4, 4px);
	font-size: var(--bbco-text-sm, 0.875rem);
}

.bbco-reviews__reply-meta strong {
	color: var(--bbco-ink);
	font-weight: var(--bbco-weight-bold, 700);
}

.bbco-reviews__reply-meta time {
	color: var(--bbco-muted);
}

.bbco-reviews__reply-badge {
	display: inline-flex;
	align-items: center;
	gap: var(--bbco-space-4, 4px);
	padding: var(--bbco-core-space-2) var(--bbco-space-8, 8px);
	background: var(--bbco-ink);
	color: var(--bbco-on-dark-strong);
	border-radius: var(--bbco-radius-pill);
	font-size: var(--bbco-text-xs, 0.75rem);
	font-weight: var(--bbco-weight-bold, 700);
	letter-spacing: 0.02em;
}

.bbco-reviews__reply-body {
	color: var(--bbco-text);
	line-height: 1.55;
}

.bbco-reviews__reply-body p:last-child {
	margin-bottom: 0;
}

.bbco-reviews__empty {
	margin: 0;
	padding: var(--bbco-space-24, 24px);
	text-align: center;
	color: var(--bbco-muted);
	background: var(--bbco-soft);
	border-radius: var(--bbco-radius, 8px);
}

/* Star icon defaults â€” outline by default, accent when filled */
.bbco-star {
	color: var(--bbco-accent);
	flex: 0 0 auto;
}

.bbco-star:not(.is-filled) {
	color: var(--bbco-accent);
}

/* Review modal */
.bbco-review-modal[hidden] {
	display: none;
}

.bbco-review-modal {
	position: fixed;
	inset: 0;
	z-index: var(--bbco-z-toast, 1100);
	display: flex;
	align-items: center;
	justify-content: center;
	padding: var(--bbco-space-16, 16px);
}

.bbco-review-modal__backdrop {
	position: absolute;
	inset: 0;
	background: var(--bbco-core-overlay-strong);
}

.bbco-review-modal__dialog {
	position: relative;
	width: min(560px, 100%);
	max-height: calc(100vh - 32px);
	overflow: auto;
	background: var(--bbco-surface);
	border-radius: var(--bbco-radius-lg);
	box-shadow: var(--bbco-shadow-ink-md);
	padding: var(--bbco-space-32, 32px);
	display: flex;
	flex-direction: column;
	gap: var(--bbco-space-24, 24px);
}

.bbco-review-modal__close {
	position: absolute;
	top: var(--bbco-space-16, 16px);
	right: var(--bbco-space-16, 16px);
	width: var(--bbco-core-size-36);
	height: var(--bbco-core-size-36);
	border: 0;
	border-radius: 50%;
	background: transparent;
	color: var(--bbco-ink);
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	justify-content: center;
}

.bbco-review-modal__close:hover {
	background: var(--bbco-soft);
}

.bbco-review-form {
	display: contents;
}

.bbco-review-step {
	display: none;
	gap: var(--bbco-space-20, 20px);
	flex-direction: column;
	align-items: center;
	text-align: center;
}

.bbco-review-step.is-active {
	display: flex;
}

.bbco-review-step__head h2 {
	margin: 0;
	font-size: var(--bbco-text-xl, 1.5rem);
	font-weight: var(--bbco-weight-bold, 700);
	color: var(--bbco-ink);
}

.bbco-review-step__head p {
	margin: var(--bbco-space-8, 8px) auto 0;
	max-width: 420px;
	color: var(--bbco-muted);
	line-height: 1.55;
}

.bbco-review-step__head--compact h2 {
	font-size: var(--bbco-text-md, 1.125rem);
}

.bbco-review-step__thumb {
	margin: 0;
	width: 180px;
	height: 180px;
	border-radius: var(--bbco-radius-lg, 18px);
	overflow: hidden;
	background: var(--bbco-soft);
}

.bbco-review-step__thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.bbco-review-step__product {
	margin: 0;
	font-size: var(--bbco-text-md, 1.125rem);
	font-weight: var(--bbco-weight-bold, 700);
	color: var(--bbco-ink);
}

.bbco-review-stars {
	display: inline-flex;
	gap: var(--bbco-space-8, 8px);
	align-items: center;
}

.bbco-review-stars__btn {
	border: 0;
	background: transparent;
	padding: 0;
	cursor: pointer;
	color: var(--bbco-accent);
	line-height: 0;
	border-radius: 4px;
	transition: transform var(--bbco-dur-fast) var(--bbco-ease, ease);
}

.bbco-review-stars__btn:hover,
.bbco-review-stars__btn:focus-visible {
	transform: scale(1.08);
	outline: none;
}

.bbco-review-stars__btn .bbco-star {
	pointer-events: none;
}

.bbco-review-stars--display .bbco-review-stars__btn {
	cursor: default;
	transform: none;
}

.bbco-review-stars__hint {
	display: flex;
	justify-content: space-between;
	width: 100%;
	max-width: 280px;
	margin: 0 auto;
	font-size: var(--bbco-text-sm, 0.875rem);
	font-weight: var(--bbco-weight-bold, 700);
	color: var(--bbco-ink);
}

.bbco-review-field {
	display: grid;
	gap: var(--bbco-space-8, 8px);
	width: 100%;
	text-align: left;
}

.bbco-review-field > span {
	font-weight: var(--bbco-weight-bold, 700);
	color: var(--bbco-ink);
}

.bbco-review-field textarea,
.bbco-review-field input {
	width: 100%;
	padding: var(--bbco-space-12, 12px) var(--bbco-space-16, 16px);
	border: 1px solid var(--bbco-border);
	border-radius: var(--bbco-radius-lg, 18px);
	background: var(--bbco-soft);
	font: inherit;
	color: var(--bbco-text);
	resize: vertical;
}

.bbco-review-field textarea {
	min-height: 160px;
	border-radius: var(--bbco-radius, 8px);
}

.bbco-review-field textarea:focus,
.bbco-review-field input:focus {
	outline: none;
	border-color: var(--bbco-ink);
	background: var(--bbco-surface);
}

.bbco-review-field small {
	color: var(--bbco-muted);
	font-size: var(--bbco-text-sm, 0.875rem);
}

.bbco-review-check {
	display: inline-flex;
	align-items: center;
	gap: var(--bbco-space-12, 12px);
	width: 100%;
	color: var(--bbco-ink);
	cursor: pointer;
}

.bbco-review-check input {
	width: 18px;
	height: 18px;
	accent-color: var(--bbco-ink);
}

.bbco-review-fine {
	margin: 0;
	text-align: center;
	color: var(--bbco-muted);
	font-size: var(--bbco-text-sm, 0.875rem);
	line-height: 1.5;
}

.bbco-review-fine a {
	color: var(--bbco-ink);
	text-decoration: underline;
}

.bbco-review-modal__foot {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--bbco-space-12, 12px);
	margin-top: var(--bbco-space-8, 8px);
}

.bbco-review-modal__back {
	border: 0;
	background: transparent;
	color: var(--bbco-ink);
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	gap: var(--bbco-space-8, 8px);
	padding: var(--bbco-space-8, 8px) var(--bbco-space-12, 12px);
	border-radius: var(--bbco-radius-pill);
	font-weight: var(--bbco-weight-medium, 500);
}

.bbco-review-modal__back:hover {
	background: var(--bbco-soft);
}

.bbco-review-modal__back[hidden],
.bbco-review-modal__next[hidden],
.bbco-review-modal__submit[hidden] {
	display: none !important;
}

.bbco-review-modal__next,
.bbco-review-modal__submit {
	margin-left: auto;
	border-radius: var(--bbco-radius-pill);
	min-width: 120px;
}

body.bbco-review-modal-open { overflow: hidden; }

@media (max-width: 720px) {
	.bbco-reviews__summary {
		grid-template-columns: 1fr;
		gap: var(--bbco-space-24, 24px);
		padding: var(--bbco-space-24, 24px);
	}

	.bbco-reviews__hero {
		order: -1;
	}

	.bbco-reviews__cta .bbco-btn {
		width: 100%;
	}

	.bbco-review-modal__dialog {
		padding: var(--bbco-space-24, 24px);
	}

	.bbco-review-step__thumb {
		width: 140px;
		height: 140px;
	}
}

/* Toast notifications */
.bbco-toast-container {
	position: fixed;
	bottom: var(--bbco-space-24, 24px);
	left: 50%;
	transform: translateX(-50%);
	z-index: calc(var(--bbco-z-toast) + 10);
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--bbco-space-12, 12px);
	pointer-events: none;
	max-width: min(420px, calc(100vw - 32px));
	width: max-content;
}

.bbco-toast {
	pointer-events: auto;
	display: flex;
	align-items: flex-start;
	gap: var(--bbco-space-12, 12px);
	min-width: 260px;
	max-width: 100%;
	padding: var(--bbco-space-12, 12px) 14px;
	background: var(--bbco-surface);
	color: var(--bbco-ink);
	border: 1px solid var(--bbco-border);
	border-left: 4px solid var(--bbco-muted);
	border-radius: var(--bbco-radius-md);
	box-shadow: 0 12px 30px var(--bbco-core-overlay-soft);
	font-size: var(--bbco-text-toast);
	line-height: 1.45;
	transform: translateY(var(--bbco-space-12, 12px));
	opacity: 0;
	transition: transform var(--bbco-dur-base) var(--bbco-ease, ease), opacity var(--bbco-dur-base) var(--bbco-ease, ease);
}

.bbco-toast.is-visible {
	transform: translateY(0);
	opacity: 1;
}

.bbco-toast.is-leaving {
	transform: translateY(var(--bbco-space-12, 12px));
	opacity: 0;
}

.bbco-toast--success {
	border-left-color: var(--bbco-success);
}

.bbco-toast--error {
	border-left-color: var(--bbco-danger);
}

.bbco-toast--info {
	border-left-color: var(--bbco-primary);
}

.bbco-toast--warning {
	border-left-color: var(--bbco-warning);
}

.bbco-toast__icon {
	flex: 0 0 auto;
	width: var(--bbco-core-size-20);
	height: var(--bbco-core-size-20);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	margin-top: 1px;
}

.bbco-toast--success .bbco-toast__icon { color: var(--bbco-success); }
.bbco-toast--error .bbco-toast__icon { color: var(--bbco-danger); }
.bbco-toast--info .bbco-toast__icon { color: var(--bbco-primary); }
.bbco-toast--warning .bbco-toast__icon { color: var(--bbco-warning); }

.bbco-toast__body {
	flex: 1 1 auto;
	min-width: 0;
}

.bbco-toast__close {
	flex: 0 0 auto;
	width: var(--bbco-core-size-24);
	height: var(--bbco-core-size-24);
	padding: 0;
	border: 0;
	background: transparent;
	color: var(--bbco-muted);
	font-size: var(--bbco-core-size-18);
	line-height: 1;
	cursor: pointer;
	border-radius: 50%;
}

.bbco-toast__close:hover {
	background: color-mix(in srgb, var(--bbco-border) 50%, transparent);
	color: var(--bbco-ink);
}

@media (max-width: 640px) {
	.bbco-toast-container {
		bottom: var(--bbco-space-12, 12px);
		left: var(--bbco-space-12, 12px);
		right: var(--bbco-space-12, 12px);
		transform: none;
		width: auto;
		max-width: none;
	}

	.bbco-toast {
		min-width: 0;
		width: 100%;
	}
}

