/**
 * BritWresCV Design System
 * Based on the "Professional Athletic Network" Stitch design system.
 * Minimalist, high-fidelity, strictly monochromatic (slate/gray) palette.
 * Loaded after frontend-styles.css and overrides legacy styling.
 */

/* ---------------------------------- Tokens --------------------------------- */
:root {
	--bw-surface: #f8fafc;               /* page background (Slate 50) */
	--bw-surface-card: #ffffff;          /* cards */
	--bw-surface-low: #f1f5f9;           /* chip fill / hover fills */
	--bw-surface-container: #eceef0;
	--bw-surface-high: #e6e8ea;
	--bw-on-surface: #191c1e;            /* main text */
	--bw-on-surface-variant: #4c5560;    /* supporting text */
	--bw-secondary: #475569;             /* secondary text/icons (Slate 600) */
	--bw-border: #e2e8f0;                /* card & input borders */
	--bw-outline: #94a3b8;
	--bw-primary: #000000;
	--bw-on-primary: #ffffff;
	--bw-error: #ba1a1a;

	--bw-radius: 4px;        /* buttons, inputs, chips */
	--bw-radius-lg: 8px;     /* cards */
	--bw-radius-xl: 12px;    /* hero cards */

	--bw-shadow-soft: 0px 1px 3px rgba(15, 23, 42, 0.08);
	--bw-shadow-hover: 0px 4px 12px rgba(0, 0, 0, 0.05);
	--bw-container: 1120px;
	--bw-gutter: 24px;

	--bw-font: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
}

/* ------------------------------- Global reset ------------------------------ */
body {
	background-color: var(--bw-surface) !important;
	color: var(--bw-on-surface);
	font-family: var(--bw-font) !important;
	font-size: 14px;
	line-height: 20px;
}

body h1, body h2, body h3, body h4, body h5, body h6 {
	font-family: var(--bw-font) !important;
	color: var(--bw-on-surface);
	letter-spacing: 0;
	font-weight: 700;
}

body a { color: var(--bw-on-surface); }
body a:hover { color: var(--bw-primary); }
body a:focus-visible,
body button:focus-visible,
body input:focus-visible,
body select:focus-visible,
body textarea:focus-visible,
[role="button"]:focus-visible {
	outline: 3px solid rgba(0, 0, 0, 0.35);
	outline-offset: 3px;
}

/* Harmonise the theme header/footer with the design */
.site-header, .main-header-bar, .ast-primary-header-bar {
	background-color: var(--bw-surface-card) !important;
	border-bottom: 1px solid var(--bw-border) !important;
	box-shadow: none !important;
}
.site-title a, .site-header .ast-site-title-wrap a {
	font-family: var(--bw-font) !important;
	font-weight: 900 !important;
	color: var(--bw-primary) !important;
	letter-spacing: 0;
}
.main-header-menu a, .ast-builder-menu a {
	font-family: var(--bw-font) !important;
	font-size: 12px !important;
	font-weight: 600 !important;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	color: var(--bw-secondary) !important;
}
.main-header-menu a:hover, .ast-builder-menu a:hover { color: var(--bw-primary) !important; }
.site-footer, .ast-footer-overlay {
	background-color: var(--bw-surface-card) !important;
	border-top: 1px solid var(--bw-border);
	color: var(--bw-secondary);
}

/* Nav login/logout buttons injected by the plugin */
.menu-item-button a {
	background: var(--bw-primary) !important;
	color: var(--bw-on-primary) !important;
	border-radius: var(--bw-radius) !important;
	border: 1px solid var(--bw-primary) !important;
	padding: 8px 20px !important;
	font-size: 12px !important;
	font-weight: 600 !important;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	transition: background 0.2s, color 0.2s;
}
.menu-item-button a:hover {
	background: var(--bw-surface-card) !important;
	color: var(--bw-primary) !important;
}

/* --------------------------------- Buttons --------------------------------- */
.bw-btn,
body .button,
body input[type="submit"],
body button[type="submit"] {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	padding: 10px 24px;
	background: var(--bw-primary);
	color: var(--bw-on-primary);
	border: 1px solid var(--bw-primary);
	border-radius: var(--bw-radius);
	font-family: var(--bw-font);
	font-size: 14px;
	font-weight: 500;
	line-height: 20px;
	text-decoration: none !important;
	cursor: pointer;
	min-height: 44px;
	transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}
.bw-btn:hover,
body .button:hover,
body input[type="submit"]:hover,
body button[type="submit"]:hover {
	background: #1e293b;
	border-color: #1e293b;
	color: var(--bw-on-primary);
}
.bw-btn--secondary {
	background: var(--bw-surface-card);
	color: var(--bw-on-surface);
	border: 1px solid var(--bw-border);
}
.bw-btn--secondary:hover {
	background: var(--bw-surface-low);
	border-color: var(--bw-outline);
	color: var(--bw-on-surface);
}

/* ----------------------------------- Cards --------------------------------- */
.bw-card {
	background: var(--bw-surface-card);
	border: 1px solid var(--bw-border);
	border-radius: var(--bw-radius-lg);
	transition: box-shadow 0.2s ease, border-color 0.2s ease;
}
.bw-card:hover { box-shadow: var(--bw-shadow-hover); }
.bw-card__pad { padding: 24px; }

/* ----------------------------------- Chips --------------------------------- */
.bw-chip {
	display: inline-block;
	padding: 4px 12px;
	background: var(--bw-surface-low);
	border: 1px solid var(--bw-border);
	border-radius: var(--bw-radius);
	color: var(--bw-secondary);
	font-size: 11px;
	font-weight: 500;
	line-height: 14px;
	white-space: nowrap;
}

/* --------------------------------- Headings -------------------------------- */
.bw-section-title {
	font-size: 20px;
	font-weight: 600;
	line-height: 28px;
	letter-spacing: 0;
	margin: 0 0 16px;
}
.bw-label {
	display: block;
	font-size: 12px;
	font-weight: 600;
	line-height: 16px;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	color: var(--bw-on-surface-variant);
	margin-bottom: 6px;
}

/* ---------------------------------- Inputs --------------------------------- */
body input[type="text"],
body input[type="email"],
body input[type="password"],
body input[type="url"],
body input[type="search"],
body input[type="date"],
body input[type="number"],
body select,
body textarea {
	background: var(--bw-surface-card);
	border: 1px solid var(--bw-border);
	border-radius: var(--bw-radius);
	padding: 10px 12px;
	font-family: var(--bw-font);
	font-size: 14px;
	color: var(--bw-on-surface);
	box-shadow: none;
	min-height: 44px;
	transition: border-color 0.2s ease;
}
body input:focus,
body select:focus,
body textarea:focus {
	border-color: var(--bw-primary) !important;
	outline: none;
	box-shadow: none !important;
}

/* ------------------------------- Image cropper ----------------------------- */
.bw-cropper {
	margin-top: 12px;
	padding: 16px;
	border: 1px solid var(--bw-border);
	border-radius: var(--bw-radius-lg);
	background: var(--bw-surface);
}
.bw-cropper[hidden] { display: none !important; }
.bw-cropper__stage {
	width: min(320px, 100%);
	aspect-ratio: 1;
	border: 1px solid var(--bw-border);
	border-radius: var(--bw-radius-lg);
	overflow: hidden;
	background: var(--bw-surface-card);
	cursor: grab;
	touch-action: none;
}
.bw-cropper__stage:active { cursor: grabbing; }
.bw-cropper canvas {
	display: block;
	width: 100%;
	height: 100%;
}
.bw-cropper__controls {
	display: flex;
	align-items: center;
	gap: 12px;
	flex-wrap: wrap;
	margin-top: 12px;
}
.bw-cropper__controls label {
	display: flex;
	align-items: center;
	gap: 8px;
	margin: 0;
	color: var(--bw-on-surface-variant);
	font-size: 13px;
}
.bw-cropper__controls input[type="range"] {
	width: 180px;
	min-height: 0;
	padding: 0;
}
.bw-cropper__hint {
	margin: 10px 0 0;
	color: var(--bw-on-surface-variant);
	font-size: 13px;
}

/* ----------------------------- Talent archive ------------------------------ */
.talent-archive-header {
	text-align: left;
	padding: 8px 0 24px;
	border: none;
	background: transparent;
	color: var(--bw-on-surface);
	margin-bottom: 0;
	border-radius: 0;
}
.talent-archive-header h1 {
	font-size: 32px;
	font-weight: 700;
	line-height: 40px;
	letter-spacing: 0;
	margin: 0 0 4px;
	color: var(--bw-on-surface);
}
.talent-archive-header p { color: var(--bw-secondary); font-size: 16px; margin: 0; }

.bw-archive-layout {
	display: grid;
	grid-template-columns: minmax(0, 3fr) minmax(0, 9fr);
	gap: var(--bw-gutter);
	align-items: start;
	max-width: var(--bw-container);
	margin: 0 auto;
}
@media (max-width: 1023px) {
	.bw-archive-layout { grid-template-columns: 1fr; }
}

/* Filters card (sidebar) — sticky only when shown as a side column */
@media (min-width: 1024px) {
	.bw-filters { position: sticky; top: 24px; }
}
.bw-filters__header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 16px;
	border-bottom: 1px solid var(--bw-border);
}
.bw-filters__header h2 { font-size: 20px; font-weight: 600; margin: 0; }
.bw-filters__header .clear-button {
	font-size: 11px;
	font-weight: 500;
	color: var(--bw-secondary);
	text-decoration: none;
}
.bw-filters__header .clear-button:hover { color: var(--bw-primary); }
.bw-filters__body { padding: 16px; display: flex; flex-direction: column; gap: 20px; }
.bw-filters__body .form-group { display: flex; flex-direction: column; gap: 6px; margin: 0; }
.bw-filters__body select,
.bw-filters__body input { width: 100%; }
.bw-filters__footer { padding: 16px; border-top: 1px solid var(--bw-border); }
.bw-filters__footer button { width: 100%; }

/* Role checkboxes as chips (legacy styles the inner span; restyle it) */
.roles-checkboxes { display: flex; flex-wrap: wrap; gap: 8px; }
.role-checkbox { display: inline-flex; align-items: center; cursor: pointer; margin: 0; user-select: none; }
.role-checkbox input[type="checkbox"] {
	display: inline-block !important;
	position: absolute;
	inline-size: 1px;
	block-size: 1px;
	overflow: hidden;
	clip: rect(0 0 0 0);
	white-space: nowrap;
	clip-path: inset(50%);
}
.role-checkbox span {
	padding: 4px 12px;
	background: var(--bw-surface-low);
	border: 1px solid var(--bw-border);
	border-radius: var(--bw-radius);
	font-size: 11px;
	font-weight: 500;
	line-height: 14px;
	color: var(--bw-on-surface);
	transition: background 0.2s, border-color 0.2s, color 0.2s;
}
.role-checkbox span:hover { background: var(--bw-surface-high); }
.role-checkbox input[type="checkbox"]:focus-visible + span {
	outline: 3px solid rgba(0, 0, 0, 0.35);
	outline-offset: 3px;
}
.role-checkbox input[type="checkbox"]:checked + span {
	background-color: var(--bw-primary);
	border-color: var(--bw-primary);
	color: var(--bw-on-primary);
}

.advanced-search-toggle {
	font-size: 12px;
	font-weight: 600;
	color: var(--bw-secondary);
	text-decoration: none;
}
.advanced-search-toggle:hover { color: var(--bw-primary); }

.search-results-count { color: var(--bw-secondary); font-size: 14px; margin: 0 0 16px; }

/* Talent result cards */
.wrestler-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
	gap: 16px;
	margin: 0;
}
.wrestler-card {
	background: var(--bw-surface-card);
	border: 1px solid var(--bw-border);
	border-radius: var(--bw-radius);
	overflow: hidden;
	box-shadow: none;
	transition: box-shadow 0.2s ease, border-color 0.2s ease;
}
.wrestler-card:hover {
	box-shadow: var(--bw-shadow-hover);
	border-color: var(--bw-outline);
	transform: none;
}
.wrestler-card a { text-decoration: none; color: inherit; display: flex; flex-direction: column; height: 100%; }
.wrestler-card-img-container {
	width: 100%;
	aspect-ratio: 1 / 1;
	background: var(--bw-surface-low);
	border-bottom: 1px solid var(--bw-border);
	overflow: hidden;
}
.wrestler-card-img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	filter: none;
}
.wrestler-card-content { padding: 16px; text-align: left; }
.wrestler-card-content h3 {
	font-size: 16px;
	font-weight: 600;
	line-height: 22px;
	letter-spacing: 0;
	margin: 0 0 2px;
	color: var(--bw-on-surface);
}
.wrestler-card-content p {
	font-size: 12px;
	color: var(--bw-secondary);
	margin: 0;
}
.bw-card-distance {
	color: var(--bw-on-surface-variant);
	font-weight: 600;
	white-space: nowrap;
}
.bw-card-distance::before { content: "·"; margin: 0 4px; }
.wrestler-card-badges { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 10px; }
.bw-avail-badge {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	padding: 4px 10px;
	border-radius: var(--bw-radius);
	background: #f0fdf4;
	border: 1px solid #bbf7d0;
	color: #166534;
	font-size: 11px;
	font-weight: 600;
	line-height: 14px;
}

/* ----------------------------- Shortlist toggle ---------------------------- */
.wrestler-card { position: relative; }
.bw-shortlist-toggle {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-family: var(--bw-font);
	font-size: 13px;
	font-weight: 500;
	cursor: pointer;
	transition: background 0.2s, color 0.2s, border-color 0.2s;
}
/* Card overlay variant: a round star button on the image, above the link. */
.bw-shortlist-toggle--card {
	position: absolute;
	top: 10px;
	right: 10px;
	z-index: 3;
	width: 34px;
	height: 34px;
	justify-content: center;
	gap: 0;
	padding: 0;
	border-radius: 9999px;
	background: var(--bw-surface-card);
	border: 1px solid var(--bw-border);
	color: var(--bw-secondary);
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.12);
}
.bw-shortlist-toggle--card .bw-shortlist-toggle__label { display: none; }
.bw-shortlist-toggle--card:hover { color: var(--bw-primary); border-color: var(--bw-outline); }
.bw-shortlist-toggle--card.is-on { background: var(--bw-primary); border-color: var(--bw-primary); color: #facc15; }

/* Profile/button variant: a full pill button matching .bw-btn--secondary. */
.bw-shortlist-toggle--profile {
	padding: 10px 24px;
	border-radius: var(--bw-radius);
	background: var(--bw-surface-card);
	border: 1px solid var(--bw-border);
	color: var(--bw-on-surface);
}
.bw-shortlist-toggle--profile:hover { background: var(--bw-surface-low); border-color: var(--bw-outline); }
.bw-shortlist-toggle--profile.is-on { background: var(--bw-primary); border-color: var(--bw-primary); color: var(--bw-on-primary); }
.bw-shortlist-toggle--profile.is-on i { color: #facc15; }

/* ------------------------------- Compare ----------------------------------- */
.bw-compare-check {
	display: flex;
	align-items: center;
	gap: 6px;
	padding: 8px 12px;
	border-top: 1px solid var(--bw-border);
	font-size: 12px;
	font-weight: 600;
	color: var(--bw-secondary);
	cursor: pointer;
	user-select: none;
}
.bw-compare-check input { margin: 0; accent-color: var(--bw-primary); }

#bw-compare-bar {
	position: fixed;
	bottom: 16px;
	left: 50%;
	transform: translateX(-50%);
	z-index: 9999;
	display: flex;
	align-items: center;
	gap: 12px;
	background: var(--bw-on-surface);
	color: var(--bw-on-primary);
	border-radius: 9999px;
	padding: 8px 8px 8px 20px;
	box-shadow: 0 6px 24px rgba(0, 0, 0, 0.25);
}
#bw-compare-bar .bw-compare-bar__count { font-size: 13px; font-weight: 600; }
#bw-compare-bar .bw-btn { padding: 8px 16px; }

.bw-compare-table-wrap { overflow-x: auto; }
.bw-compare-table {
	width: 100%;
	border-collapse: collapse;
	background: var(--bw-surface-card);
	border: 1px solid var(--bw-border);
	border-radius: var(--bw-radius-lg);
	overflow: hidden;
}
.bw-compare-table th,
.bw-compare-table td {
	padding: 14px 16px;
	border-bottom: 1px solid var(--bw-surface-container);
	text-align: left;
	font-size: 14px;
	vertical-align: top;
}
.bw-compare-table tbody th[scope="row"] {
	font-size: 11px;
	font-weight: 600;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	color: var(--bw-on-surface-variant);
	width: 140px;
	background: var(--bw-surface);
}
.bw-compare-table thead th { background: var(--bw-surface); border-bottom: 1px solid var(--bw-border); }
.bw-compare-head { display: flex; flex-direction: column; align-items: flex-start; gap: 8px; min-width: 140px; }
.bw-compare-head__img img { width: 64px; height: 64px; border-radius: 50%; object-fit: cover; border: 1px solid var(--bw-border); }
.bw-compare-head a { font-size: 16px; font-weight: 600; color: var(--bw-on-surface); }
.bw-compare-head a:hover { color: var(--bw-primary); }

/* --------------------- Mobile dropdown menu (HFE) -------------------------- */
/* HFE's mobile menu (≤1024px) defaults to Elementor's blue accent with
   low-contrast text. Restyle it as a clean monochrome list that matches the
   design system. Scoped to the breakpoint so the desktop header is untouched. */
@media (max-width: 1024px) {
	/* `body` prefix raises specificity so we reliably beat HFE/Elementor's
	   accent-colour rules without chasing their exact selectors. */
	body .elementor-widget-hfe-nav-menu .hfe-nav-menu-layout,
	body .hfe-nav-menu__layout-horizontal {
		background-color: var(--bw-surface-card) !important;
		border-bottom: 1px solid var(--bw-border) !important;
		box-shadow: 0 10px 20px rgba(0, 0, 0, 0.06);
	}
	/* Every item: same clean, readable treatment regardless of state. */
	body .elementor-widget-hfe-nav-menu .hfe-nav-menu .menu-item a,
	body .elementor-widget-hfe-nav-menu .hfe-nav-menu .menu-item a.hfe-menu-item,
	body .hfe-nav-menu .menu-item a {
		background-color: var(--bw-surface-card) !important;
		color: var(--bw-on-surface) !important;
		fill: var(--bw-on-surface) !important;
		font-family: var(--bw-font) !important;
		font-size: 15px !important;
		font-weight: 600 !important;
		letter-spacing: 0 !important;
		text-transform: none !important;
		padding: 15px 24px !important;
		border-bottom: 1px solid var(--bw-border) !important;
		border-radius: 0 !important;
		box-shadow: none !important;
		transition: background-color 0.15s ease, color 0.15s ease;
	}
	body .hfe-nav-menu > ul > .menu-item:last-child > a { border-bottom: none !important; }
	body .elementor-widget-hfe-nav-menu .hfe-nav-menu .menu-item a:hover,
	body .elementor-widget-hfe-nav-menu .hfe-nav-menu .menu-item a:focus,
	body .hfe-nav-menu .menu-item a:hover {
		background-color: var(--bw-surface-low) !important;
		color: var(--bw-primary) !important;
	}
	/* Current page: subtle left bar + light fill (stays readable). */
	body .elementor-widget-hfe-nav-menu .hfe-nav-menu .menu-item.current-menu-item > a,
	body .elementor-widget-hfe-nav-menu .hfe-nav-menu .menu-item.current_page_item > a,
	body .hfe-nav-menu .menu-item.current-menu-item > a {
		background-color: var(--bw-surface-low) !important;
		color: var(--bw-primary) !important;
		box-shadow: inset 3px 0 0 0 var(--bw-primary) !important;
	}
	/* Sub-menu items indented + muted. */
	body .hfe-nav-menu .sub-menu .menu-item a { padding-left: 40px !important; color: var(--bw-on-surface-variant) !important; }
	/* Hamburger + close icon in design colours. */
	.hfe-nav-menu-icon,
	.hfe-nav-menu__toggle .hfe-nav-menu-icon svg,
	.hfe-nav-menu__toggle svg,
	.hfe-nav-menu-icon svg {
		color: var(--bw-on-surface) !important;
		fill: var(--bw-on-surface) !important;
	}
}

/* Hide the theme's page title where a shortcode renders its own heading. */
.bw-hide-page-title .entry-header,
.bw-hide-page-title .entry-header .entry-title,
.bw-hide-page-title .ast-single-post .entry-title { display: none !important; }

/* ---------------------------- Saved searches ------------------------------- */
.bw-results-bar {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 16px;
	flex-wrap: wrap;
	margin-bottom: 16px;
}
.bw-results-bar .search-results-count { margin: 0; }
#bw-save-search.is-saved { background: var(--bw-surface-low); color: var(--bw-secondary); }

.bw-saved-list { display: flex; flex-direction: column; gap: 12px; }
.bw-saved-item {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 16px;
	flex-wrap: wrap;
}
.bw-saved-item__main h3 { font-size: 16px; font-weight: 600; margin: 0 0 2px; }
.bw-saved-item__main p { font-size: 13px; color: var(--bw-on-surface-variant); margin: 0; }
.bw-saved-item__actions { display: flex; align-items: center; gap: 12px; }
.bw-saved-alert { display: inline-flex; align-items: center; gap: 6px; font-size: 12px; font-weight: 600; color: var(--bw-secondary); cursor: pointer; }
.bw-saved-alert input { accent-color: var(--bw-primary); margin: 0; }
.bw-saved-delete {
	background: none;
	border: 1px solid var(--bw-border);
	border-radius: var(--bw-radius);
	width: 36px;
	height: 36px;
	color: var(--bw-secondary);
	cursor: pointer;
	transition: color 0.2s, border-color 0.2s;
}
.bw-saved-delete:hover { color: var(--bw-error); border-color: var(--bw-error); }

/* --------------------------- Credentials & reviews ------------------------- */
.bw-cred-badges { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 12px; }
.bw-cred-badge {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 4px 10px;
	border-radius: var(--bw-radius);
	background: var(--bw-surface-low);
	border: 1px solid var(--bw-border);
	color: var(--bw-on-surface-variant);
	font-size: 11px;
	font-weight: 600;
	line-height: 16px;
}
.bw-cred-badge.is-verified {
	background: #f0fdf4;
	border-color: #bbf7d0;
	color: #166534;
}
.bw-cred-badge__tick { color: #16a34a; }

.bw-profile-rating {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	margin-top: 12px;
	font-size: 14px;
	color: var(--bw-on-surface) !important;
	text-decoration: none;
}
.bw-stars { color: #f59e0b; font-size: 13px; letter-spacing: 1px; }
.bw-stars .fa-regular { color: var(--bw-border); }
.bw-profile-rating span { color: var(--bw-secondary); }

/* Reviews section */
.bw-reviews__head { display: flex; align-items: center; justify-content: space-between; gap: 12px; flex-wrap: wrap; }
.bw-reviews__summary { display: flex; align-items: center; gap: 8px; font-size: 14px; }
.bw-reviews__summary span { color: var(--bw-secondary); }
.bw-review-form {
	background: var(--bw-surface);
	border: 1px solid var(--bw-border);
	border-radius: var(--bw-radius-lg);
	padding: 16px;
	margin: 16px 0 24px;
}
.bw-review-form__label { font-weight: 600; margin: 0 0 8px; }
.bw-review-form textarea { width: 100%; margin: 8px 0; }
.bw-review-form__msg { display: block; margin-top: 8px; font-size: 13px; color: var(--bw-secondary); }

/* Star rating input (RTL trick for hover/checked highlighting) */
.bw-star-input { display: inline-flex; flex-direction: row-reverse; justify-content: flex-end; gap: 4px; }
.bw-star-input input { position: absolute; opacity: 0; width: 0; height: 0; }
.bw-star-input label { font-size: 22px; color: var(--bw-border); cursor: pointer; transition: color 0.15s; }
.bw-star-input label:hover,
.bw-star-input label:hover ~ label,
.bw-star-input input:checked ~ label { color: #f59e0b; }

.bw-reviews__list { display: flex; flex-direction: column; gap: 16px; margin-top: 8px; }
.bw-reviews__empty { color: var(--bw-secondary); font-size: 14px; }
.bw-review { border-top: 1px solid var(--bw-surface-container); padding-top: 16px; }
.bw-review:first-child { border-top: none; padding-top: 0; }
.bw-review__head { display: flex; align-items: center; gap: 10px; }
.bw-review__author { font-weight: 600; font-size: 14px; }
.bw-review__body { font-size: 14px; color: var(--bw-on-surface-variant); margin: 6px 0; }
.bw-review__date { font-size: 12px; color: var(--bw-secondary); }

/* Credential inputs in the edit form */
.britwres-credentials-fields .checkbox-label { display: inline-flex; align-items: center; gap: 8px; }

/* -------------------------------- Single CV -------------------------------- */
.britwres-cv-wrapper {
	max-width: var(--bw-container);
	margin: 32px auto;
	padding: 0 16px;
	font-family: var(--bw-font) !important;
	background: transparent !important;
	color: var(--bw-on-surface);
}

.bw-profile-card {
	background: var(--bw-surface-card);
	border: 1px solid var(--bw-border);
	border-radius: var(--bw-radius-xl);
	overflow: hidden;
	margin-bottom: 24px;
}
.bw-profile-cover {
	height: 260px;
	background-color: var(--bw-surface-high);
	background-size: cover;
	background-position: center;
	position: relative;
}
.bw-profile-cover::after {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(to top, rgba(0, 0, 0, 0.45), transparent 60%);
}
.bw-profile-details { padding: 0 24px 24px; position: relative; }
.bw-profile-avatar {
	width: 128px;
	height: 128px;
	border-radius: 50%;
	border: 4px solid var(--bw-surface-card);
	background: var(--bw-surface-high);
	overflow: hidden;
	margin-top: -64px;
	position: relative;
	z-index: 2;
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
}
.bw-profile-avatar img { width: 100%; height: 100%; object-fit: cover; display: block; }
.bw-profile-headline {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: flex-end;
	gap: 16px;
	margin-top: 12px;
}
.bw-profile-headline h1 {
	font-size: 32px;
	font-weight: 700;
	line-height: 40px;
	letter-spacing: 0;
	margin: 0;
	color: var(--bw-on-surface) !important;
}
.bw-profile-meta {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 8px;
	color: var(--bw-on-surface-variant);
	font-size: 14px;
	margin: 6px 0 0;
}
.bw-profile-meta .bw-dot {
	width: 4px;
	height: 4px;
	border-radius: 50%;
	background: var(--bw-border);
	display: inline-block;
}
.bw-profile-chips { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 16px; }
.bw-profile-actions { display: flex; gap: 12px; flex-wrap: wrap; }
.social-icons-list.bw-profile-socials,
.bw-profile-socials {
	display: flex;
	gap: 8px;
	margin: 22px 0 0;
	padding: 0;
	align-items: center;
	list-style: none;
}
.bw-profile-socials li {
	margin: 0;
	line-height: 1;
	list-style: none;
}
.bw-profile-socials li::marker { content: ""; }
.bw-profile-socials a {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	border: 1px solid var(--bw-border);
	border-radius: var(--bw-radius);
	background: var(--bw-surface-card);
	color: var(--bw-secondary) !important;
	font-size: 15px;
	transition: background 0.2s, color 0.2s, border-color 0.2s;
}
.bw-profile-socials a:hover {
	background: var(--bw-surface-low);
	color: var(--bw-primary) !important;
	border-color: var(--bw-outline);
	transform: none;
}

/* Two-column body grid */
.bw-cv-grid {
	display: grid;
	grid-template-columns: minmax(0, 8fr) minmax(0, 4fr);
	gap: var(--bw-gutter);
	align-items: start;
}
@media (max-width: 1023px) {
	.bw-cv-grid { grid-template-columns: 1fr; }
}
@media (max-width: 767px) {
	.britwres-cv-wrapper { margin: 24px auto; padding: 0 12px; }
	.bw-profile-cover { height: 180px; }
	.bw-profile-details { padding: 0 16px 20px; }
	.bw-profile-avatar { width: 104px; height: 104px; margin-top: -52px; }
	.bw-profile-headline { align-items: flex-start; }
	.bw-profile-headline h1 { font-size: 26px; line-height: 34px; }
	.bw-profile-actions,
	.bw-profile-actions .bw-btn { width: 100%; }
	.bw-cv-section { padding: 18px; }
	.bw-facts li { align-items: flex-start; flex-direction: column; gap: 4px; }
	.bw-facts .field-value { text-align: left; }
}
.bw-cv-col { display: flex; flex-direction: column; gap: var(--bw-gutter); min-width: 0; }

.bw-cv-section {
	background: var(--bw-surface-card);
	border: 1px solid var(--bw-border);
	border-radius: var(--bw-radius-lg);
	padding: 24px;
	transition: box-shadow 0.2s ease;
	color: var(--bw-on-surface);
}
.bw-cv-section:hover { box-shadow: var(--bw-shadow-hover); }
.bw-cv-section h3 {
	font-size: 20px;
	font-weight: 600;
	line-height: 28px;
	letter-spacing: 0;
	margin: 0 0 16px;
	padding: 0;
	border: none !important;
	color: var(--bw-on-surface) !important;
}
.bw-cv-section p { color: var(--bw-on-surface-variant); }

/* Key facts list */
.bw-facts { list-style: none; margin: 0; padding: 0; }
.bw-facts li {
	display: flex;
	justify-content: space-between;
	gap: 12px;
	padding: 12px 0;
	border-bottom: 1px solid var(--bw-surface-container);
	font-size: 14px;
}
.bw-facts li:last-child { border-bottom: none; }
.bw-facts strong {
	font-size: 11px;
	font-weight: 600;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	color: var(--bw-on-surface-variant);
	align-self: center;
}
.bw-facts .field-value { text-align: right; }

/* Experience table */
.bw-cv-section table {
	width: 100%;
	border-collapse: collapse;
	margin: 0;
	border: none;
	background: transparent;
}
.bw-cv-section table th {
	padding: 12px 0;
	font-size: 11px;
	font-weight: 600;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	color: var(--bw-on-surface-variant);
	text-align: left;
	border: none;
	border-bottom: 1px solid var(--bw-border);
	background: transparent;
}
.bw-cv-section table td {
	padding: 16px 0;
	font-size: 14px;
	border: none;
	border-bottom: 1px solid var(--bw-surface-container);
	background: transparent !important;
}
.bw-cv-section table tr:last-child td { border-bottom: none; }
.bw-cv-section table tbody tr:hover td { background: var(--bw-surface-low) !important; }

/* Media embeds & gallery */
.bw-cv-section .embed-responsive,
.bw-cv-section iframe {
	border-radius: var(--bw-radius-lg);
	overflow: hidden;
	max-width: 100%;
}
.bw-cv-section .embed-responsive iframe { width: 100%; aspect-ratio: 16 / 9; height: auto; }
.photo-gallery-carousel .carousel-cell,
.matches-carousel .carousel-cell {
	border: 1px solid var(--bw-border);
	border-radius: var(--bw-radius-lg);
	background: var(--bw-surface-low);
}

/* Compact sidebar bookings */
.bw-bookings-mini__head {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: 16px;
}
.bw-bookings-mini__head h3 { margin: 0 !important; }
.bw-bookings-mini__head button {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	background: var(--bw-surface-card);
	border: 1px solid var(--bw-border);
	border-radius: var(--bw-radius);
	padding: 4px 10px;
	font-family: var(--bw-font);
	font-size: 11px;
	font-weight: 500;
	color: var(--bw-secondary);
	cursor: pointer;
	transition: background 0.2s, color 0.2s, border-color 0.2s;
}
.bw-bookings-mini__head button:hover {
	background: var(--bw-surface-low);
	color: var(--bw-primary);
	border-color: var(--bw-outline);
}
.bw-bookings-list {
	display: flex;
	flex-direction: column;
	gap: 8px;
	list-style: none;
	margin: 0;
	padding: 0;
}
.bw-bookings-list li {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	background: var(--bw-surface);
	border: 1px solid var(--bw-border);
	border-radius: var(--bw-radius);
	padding: 10px 12px;
}
.bw-bookings-list__status {
	color: var(--bw-on-surface);
	font-size: 13px;
	font-weight: 600;
	line-height: 18px;
}
.bw-bookings-list__date {
	color: var(--bw-secondary);
	font-size: 13px;
	line-height: 18px;
	text-align: right;
}

/* Generic design-system modal (bookings full calendar) */
.bw-modal {
	display: none;
	position: fixed;
	inset: 0;
	background: rgba(0, 0, 0, 0.6);
	z-index: 100000;
	align-items: center;
	justify-content: center;
	padding: 24px;
}
.bw-modal.is-open { display: flex; }
.bw-modal__dialog {
	background: var(--bw-surface-card);
	border: 1px solid var(--bw-border);
	border-radius: var(--bw-radius-lg);
	width: min(960px, 100%);
	max-height: 90vh;
	overflow-y: auto;
	padding: 24px;
}
.bw-modal__head {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: 16px;
	padding-bottom: 12px;
	border-bottom: 1px solid var(--bw-border);
}
.bw-modal__head h3 {
	font-size: 20px;
	font-weight: 600;
	letter-spacing: 0;
	margin: 0;
}
.bw-modal__close {
	background: none;
	border: none;
	font-size: 28px;
	line-height: 1;
	color: var(--bw-secondary);
	cursor: pointer;
	padding: 0 4px;
}
.bw-modal__close:hover { color: var(--bw-primary); }

/* FullCalendar harmonisation */
.bw-cv-section .fc,
.bw-modal .fc {
	font-family: var(--bw-font);
	--fc-border-color: var(--bw-border);
	--fc-button-bg-color: var(--bw-primary);
	--fc-button-border-color: var(--bw-primary);
	--fc-button-hover-bg-color: #1e293b;
	--fc-button-hover-border-color: #1e293b;
	--fc-button-active-bg-color: #1e293b;
	--fc-button-active-border-color: #1e293b;
	--fc-event-bg-color: var(--bw-primary);
	--fc-event-border-color: var(--bw-primary);
	--fc-today-bg-color: var(--bw-surface-low);
}
.fc-toolbar-title { font-size: 20px !important; font-weight: 600; color: var(--bw-on-surface) !important; }

/* Edit pencil */
.editable-field:hover .edit-pencil { opacity: 1; }

/* Share toolbar */
#britwres-share-toolbar {
	background: var(--bw-surface-card) !important;
	border-top: 1px solid var(--bw-border) !important;
	border-bottom: none !important;
	box-shadow: 0 -4px 12px rgba(0, 0, 0, 0.05);
}
#britwres-share-toolbar span { font-family: var(--bw-font); }
.britwres-share-btn { color: var(--bw-secondary) !important; }
.britwres-share-btn:hover { color: var(--bw-primary) !important; }

/* Modals */
.britwres-modal-content,
#britwres-simple-share-popup {
	border-radius: var(--bw-radius-lg);
	border: 1px solid var(--bw-border);
	font-family: var(--bw-font);
}
.bw-share-art-modal {
	position: fixed;
	inset: 0;
	z-index: 10020;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 20px;
	background: rgba(15, 23, 42, 0.72);
}
.bw-share-art-modal[hidden] {
	display: none !important;
}
.bw-share-art-modal__dialog {
	width: min(920px, 100%);
	max-height: min(92vh, 920px);
	display: grid;
	grid-template-columns: minmax(0, 1fr) 320px;
	grid-template-areas:
		"head head"
		"preview tools"
		"preview actions";
	gap: 16px;
	padding: 20px;
	border: 1px solid var(--bw-border);
	border-radius: var(--bw-radius-lg);
	background: var(--bw-surface-card);
	box-shadow: 0 24px 80px rgba(0, 0, 0, 0.28);
	overflow: auto;
}
.bw-share-art-modal__head {
	grid-area: head;
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 16px;
	padding-bottom: 12px;
	border-bottom: 1px solid var(--bw-border);
}
.bw-share-art-modal__head h3 {
	margin: 0;
	font-size: 22px;
	line-height: 30px;
	letter-spacing: 0;
}
.bw-share-art-modal__head p {
	margin: 2px 0 0;
	color: var(--bw-on-surface-variant);
}
.bw-share-art-modal__close {
	border: 0;
	background: transparent;
	color: var(--bw-secondary);
	font-size: 30px;
	line-height: 1;
	cursor: pointer;
	padding: 0 4px;
}
.bw-share-art-modal__close:hover {
	color: var(--bw-primary);
}
.bw-share-art-modal__tools {
	grid-area: tools;
	display: grid;
	grid-template-columns: 1fr;
	align-content: start;
	gap: 8px;
}
.bw-share-art-modal__tools button {
	justify-content: center;
	min-height: 44px;
	border: 1px solid var(--bw-border);
	border-radius: var(--bw-radius);
	background: var(--bw-surface);
	color: var(--bw-on-surface);
	font-weight: 700;
	cursor: pointer;
}
.bw-share-art-modal__tools button.is-active,
.bw-share-art-modal__tools button:hover {
	border-color: var(--bw-primary);
	background: var(--bw-primary);
	color: var(--bw-on-primary);
}
.bw-share-art-modal__preview {
	grid-area: preview;
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 520px;
	padding: 16px;
	border: 1px solid var(--bw-border);
	border-radius: var(--bw-radius);
	background: var(--bw-surface-low);
}
.bw-share-art-modal__preview img {
	display: block;
	max-width: 100%;
	max-height: 68vh;
	width: auto;
	height: auto;
	border-radius: var(--bw-radius);
	box-shadow: 0 16px 40px rgba(0, 0, 0, 0.18);
}
.bw-share-art-modal__actions {
	grid-area: actions;
	display: flex;
	align-items: stretch;
	flex-direction: column;
	gap: 10px;
}
.bw-share-art-modal__actions .bw-btn {
	width: 100%;
	justify-content: center;
}
@media (max-width: 820px) {
	.bw-share-art-modal__dialog {
		grid-template-columns: 1fr;
		grid-template-areas:
			"head"
			"tools"
			"preview"
			"actions";
	}
	.bw-share-art-modal__tools {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
	.bw-share-art-modal__preview {
		min-height: 360px;
	}
}

/* ----------------------------------- Forms --------------------------------- */
.britwres-form-container {
	max-width: 640px;
	margin: 40px auto;
	background: var(--bw-surface-card);
	border: 1px solid var(--bw-border);
	border-radius: var(--bw-radius-lg);
	padding: 40px;
	box-shadow: none;
	font-family: var(--bw-font);
	color: var(--bw-on-surface);
}
@media (max-width: 767px) {
	.britwres-form-container {
		margin: 24px 12px;
		padding: 24px 18px;
	}
	.britwres-repeater-row {
		flex-direction: column;
		align-items: stretch;
	}
	.form-navigation {
		flex-direction: column-reverse;
	}
	.form-navigation button,
	.form-navigation .next-step,
	.form-navigation .submit-form {
		width: 100%;
	}
}
.britwres-form-container h1,
.britwres-form-container h2 {
	font-size: 24px;
	font-weight: 700;
	letter-spacing: 0;
	margin-top: 0;
}
.britwres-form-container h3,
.britwres-form-container h4 {
	font-size: 20px;
	font-weight: 600;
	letter-spacing: 0;
	color: var(--bw-on-surface);
}
.britwres-form-container label {
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	color: var(--bw-on-surface-variant);
}
.britwres-form-container .role-checkbox-label,
.britwres-form-container .checkbox-label {
	text-transform: none;
	letter-spacing: 0;
	font-size: 14px;
	font-weight: 400;
	color: var(--bw-on-surface);
}
.britwres-form-container small { color: var(--bw-secondary); }
.britwres-form-container input[type="text"],
.britwres-form-container input[type="email"],
.britwres-form-container input[type="password"],
.britwres-form-container input[type="url"],
.britwres-form-container select,
.britwres-form-container textarea {
	width: 100%;
	background: var(--bw-surface-card);
	border: 1px solid var(--bw-border);
	border-radius: var(--bw-radius);
	color: var(--bw-on-surface);
}
.britwres-form-container .form-group { margin-bottom: 20px; }
.bw-field-help {
	margin: 4px 0 12px;
	color: var(--bw-on-surface-variant);
	font-size: 13px;
	line-height: 18px;
}
.bw-role-picker {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 10px;
	margin-top: 8px;
}
.bw-role-option {
	position: relative;
	display: block;
	margin: 0 !important;
	cursor: pointer;
	text-transform: none !important;
	letter-spacing: 0 !important;
}
.bw-role-option input {
	position: absolute;
	inset: 0;
	opacity: 0;
	cursor: pointer;
}
.bw-role-option__body {
	display: flex;
	align-items: center;
	gap: 12px;
	min-height: 72px;
	padding: 12px;
	border: 1px solid var(--bw-border);
	border-radius: var(--bw-radius-lg);
	background: var(--bw-surface-card);
	color: var(--bw-on-surface);
	transition: background 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease;
}
.bw-role-option__body > i {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	border-radius: var(--bw-radius);
	background: var(--bw-surface-low);
	color: var(--bw-secondary);
	flex: 0 0 auto;
}
.bw-role-option__body span,
.bw-role-option__body strong,
.bw-role-option__body small {
	display: block;
}
.bw-role-option__body strong {
	font-size: 14px;
	font-weight: 700;
	line-height: 18px;
}
.bw-role-option__body small {
	margin-top: 2px;
	color: var(--bw-on-surface-variant);
	font-size: 12px;
	font-weight: 400;
	line-height: 16px;
}
.bw-role-option:hover .bw-role-option__body {
	background: var(--bw-surface-low);
	border-color: var(--bw-outline);
}
.bw-role-option input:focus-visible + .bw-role-option__body {
	outline: 3px solid rgba(0, 0, 0, 0.35);
	outline-offset: 3px;
}
.bw-role-option input:checked + .bw-role-option__body {
	background: var(--bw-primary);
	border-color: var(--bw-primary);
	color: var(--bw-on-primary);
	box-shadow: var(--bw-shadow-soft);
}
.bw-role-option input:checked + .bw-role-option__body > i {
	background: rgba(255, 255, 255, 0.14);
	color: var(--bw-on-primary);
}
.bw-role-option input:checked + .bw-role-option__body small {
	color: rgba(255, 255, 255, 0.72);
}
@media (max-width: 599px) {
	.bw-role-picker { grid-template-columns: 1fr; }
}

.britwres-errors {
	color: var(--bw-error) !important;
	border: 1px solid var(--bw-error) !important;
	background: #fff5f5;
	border-radius: var(--bw-radius);
	padding: 12px 16px !important;
	font-size: 14px;
}
.britwres-form-container .is-invalid { border-color: var(--bw-error) !important; }
.britwres-form-container .field-error { color: var(--bw-error); font-size: 12px; }

/* Progress bar */
.britwres-progress-bar {
	background: var(--bw-surface-container);
	border-radius: 9999px;
	height: 6px;
	overflow: hidden;
}
.britwres-progress-bar-fill {
	background: var(--bw-primary);
	height: 100%;
	border-radius: 9999px;
	transition: width 0.3s ease;
}

/* Repeaters */
.britwres-repeater-section {
	background: var(--bw-surface);
	border: 1px solid var(--bw-border);
	border-radius: var(--bw-radius-lg);
	padding: 16px;
}
.britwres-repeater-row {
	background: var(--bw-surface-card);
	border: 1px solid var(--bw-border);
	border-radius: var(--bw-radius);
	padding: 12px;
}
.britwres-repeater-add {
	background: var(--bw-surface-card) !important;
	color: var(--bw-on-surface) !important;
	border: 1px solid var(--bw-border) !important;
	border-radius: var(--bw-radius) !important;
}
.britwres-repeater-add:hover { background: var(--bw-surface-low) !important; }
.britwres-repeater-remove,
.remove-experience-row,
.remove-booking-row,
.remove-match-video-row {
	background: var(--bw-surface-card) !important;
	color: var(--bw-error) !important;
	border: 1px solid var(--bw-border) !important;
	border-radius: var(--bw-radius) !important;
}

.form-navigation { display: flex; justify-content: space-between; gap: 12px; margin-top: 24px; }
.form-navigation button,
.form-navigation .next-step,
.form-navigation .submit-form {
	background: var(--bw-primary) !important;
	color: var(--bw-on-primary) !important;
	border: 1px solid var(--bw-primary) !important;
	border-radius: var(--bw-radius) !important;
	padding: 10px 24px;
	font-family: var(--bw-font);
	font-size: 14px;
	font-weight: 500;
	cursor: pointer;
}
.form-navigation button:hover,
.form-navigation .next-step:hover,
.form-navigation .submit-form:hover {
	background: #1e293b !important;
	border-color: #1e293b !important;
}
.form-navigation .prev-step {
	background: var(--bw-surface-card) !important;
	color: var(--bw-on-surface) !important;
	border: 1px solid var(--bw-border) !important;
}
.form-navigation .prev-step:hover { background: var(--bw-surface-low) !important; }

/* Danger zone */
.danger-zone {
	border: 1px solid var(--bw-error);
	border-radius: var(--bw-radius-lg);
	padding: 24px;
	margin-top: 32px;
}
.danger-zone h2 { color: var(--bw-error) !important; }

/* Edit profile tabs */
.britwres-edit-cv-container {
	max-width: 960px;
}
.britwres-form-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	margin-bottom: 24px;
}
.britwres-form-header h1 {
	margin: 0;
}
.bw-edit-tabs {
	display: flex;
	flex-direction: column;
	gap: 24px;
}
.bw-edit-tabs__nav {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	padding: 6px;
	background: var(--bw-surface-container);
	border: 1px solid var(--bw-border);
	border-radius: var(--bw-radius-lg);
}
.bw-edit-tabs__tab {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	min-height: 40px;
	padding: 8px 14px;
	border: 1px solid transparent;
	border-radius: var(--bw-radius);
	background: transparent;
	color: var(--bw-secondary);
	font-family: var(--bw-font);
	font-size: 14px;
	font-weight: 600;
	line-height: 20px;
	cursor: pointer;
}
.bw-edit-tabs__tab:hover {
	background: var(--bw-surface-card);
	color: var(--bw-on-surface);
}
.bw-edit-tabs__tab.is-active {
	background: var(--bw-surface-card);
	border-color: var(--bw-border);
	color: var(--bw-on-surface);
	box-shadow: var(--bw-shadow-soft);
}
.bw-edit-tabs__panel {
	background: var(--bw-surface-card);
	border: 1px solid var(--bw-border);
	border-radius: var(--bw-radius-lg);
	padding: 24px;
}
.bw-edit-tabs__panel[hidden] {
	display: none;
}
.bw-edit-tabs__panel h2 {
	margin-bottom: 20px;
}
.bw-edit-form-actions {
	display: flex;
	justify-content: flex-end;
	margin-top: 24px;
}
.bw-edit-form-actions input[type="submit"] {
	min-width: 180px;
}
.britwres-edit-cv-container .experience-row,
.britwres-edit-cv-container .booking-row,
.britwres-edit-cv-container .match-video-row {
	background: var(--bw-surface);
	border: 1px solid var(--bw-border);
	border-radius: var(--bw-radius);
	padding: 12px;
}
.britwres-edit-cv-container #add-experience-row,
.britwres-edit-cv-container #add-booking-row,
.britwres-edit-cv-container #add-match-video-row {
	background: var(--bw-surface-card) !important;
	color: var(--bw-on-surface) !important;
	border: 1px solid var(--bw-border) !important;
	border-radius: var(--bw-radius) !important;
}
.britwres-edit-cv-container #add-experience-row:hover,
.britwres-edit-cv-container #add-booking-row:hover,
.britwres-edit-cv-container #add-match-video-row:hover {
	background: var(--bw-surface-low) !important;
}
@media (max-width: 767px) {
	.britwres-form-header {
		align-items: stretch;
		flex-direction: column;
	}
	.britwres-form-header .button,
	.bw-edit-tabs__tab,
	.bw-edit-form-actions input[type="submit"] {
		width: 100%;
	}
	.bw-edit-tabs__nav {
		display: grid;
		grid-template-columns: 1fr;
	}
	.bw-edit-tabs__panel {
		padding: 18px;
	}
	.britwres-edit-cv-container .experience-row,
	.britwres-edit-cv-container .booking-row,
	.britwres-edit-cv-container .match-video-row {
		flex-direction: column;
		align-items: stretch !important;
	}
}

/* Beta and feedback widgets */
.bw-beta-button,
.bw-feedback-button,
.beta-button,
.feedback-button,
a[href*="feedback"],
a[href*="beta"],
button[class*="feedback"],
button[class*="beta"],
.elementor-button[href*="feedback"],
.elementor-button[href*="beta"] {
	border-radius: var(--bw-radius) !important;
	font-family: var(--bw-font) !important;
	font-weight: 600 !important;
	letter-spacing: 0 !important;
	text-decoration: none !important;
}
.bw-beta-button,
.bw-feedback-button,
.beta-button,
.feedback-button,
.elementor-button[href*="feedback"],
.elementor-button[href*="beta"] {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	min-height: 44px;
	padding: 10px 18px !important;
	background: var(--bw-primary) !important;
	border: 1px solid var(--bw-primary) !important;
	color: var(--bw-on-primary) !important;
}
.bw-beta-button:hover,
.bw-feedback-button:hover,
.beta-button:hover,
.feedback-button:hover,
.elementor-button[href*="feedback"]:hover,
.elementor-button[href*="beta"]:hover {
	background: #1e293b !important;
	border-color: #1e293b !important;
	color: var(--bw-on-primary) !important;
}
.bw-feedback-form,
.bw-beta-form,
.feedback-form,
.beta-form,
.wpcf7 form:has(input[name*="feedback"]),
.wpcf7 form:has(textarea[name*="feedback"]),
.wpcf7 form:has(input[name*="beta"]),
.wpcf7 form:has(textarea[name*="beta"]) {
	background: var(--bw-surface-card);
	border: 1px solid var(--bw-border);
	border-radius: var(--bw-radius-lg);
	box-shadow: var(--bw-shadow-soft);
	color: var(--bw-on-surface);
	font-family: var(--bw-font);
	padding: 24px;
}
.bw-feedback-form label,
.bw-beta-form label,
.feedback-form label,
.beta-form label,
.wpcf7 form:has(input[name*="feedback"]) label,
.wpcf7 form:has(textarea[name*="feedback"]) label,
.wpcf7 form:has(input[name*="beta"]) label,
.wpcf7 form:has(textarea[name*="beta"]) label {
	color: var(--bw-on-surface-variant);
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 0.05em;
	text-transform: uppercase;
}
.bw-feedback-form input,
.bw-feedback-form textarea,
.bw-feedback-form select,
.bw-beta-form input,
.bw-beta-form textarea,
.bw-beta-form select,
.feedback-form input,
.feedback-form textarea,
.feedback-form select,
.beta-form input,
.beta-form textarea,
.beta-form select {
	border-color: var(--bw-border);
	border-radius: var(--bw-radius);
	color: var(--bw-on-surface);
}

/* ------------------------------ Login screen ------------------------------- */
.bw-login-wrap {
	max-width: 440px;
	margin: 48px auto;
}

/* Split layout: white form panel left, monochrome arena photo right */
.bw-login-split {
	display: grid;
	grid-template-columns: 1fr 1fr;
	max-width: var(--bw-container);
	margin: 48px auto;
	background: var(--bw-surface-card);
	border: 1px solid var(--bw-border);
	border-radius: var(--bw-radius-xl);
	overflow: hidden;
	min-height: 640px;
}
@media (max-width: 1023px) {
	.bw-login-split { grid-template-columns: 1fr; min-height: 0; }
	/* !important: the base .bw-login-visual{display:flex} is declared later in
	   the source, so it would otherwise win at equal specificity. */
	.bw-login-visual { display: none !important; }
	.bw-login-panel { border-right: none; }
}
.bw-login-panel {
	padding: 64px 56px;
	display: flex;
	flex-direction: column;
	justify-content: center;
	border-right: 1px solid var(--bw-border);
}
@media (max-width: 767px) {
	.bw-login-panel { padding: 40px 24px; }
}
.bw-login-panel__head { margin-bottom: 40px; }
.bw-login-panel #britwres-login-form input[type="submit"] { width: 100%; }

/* Role selection cards (link to register) */
.bw-login-roles {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 16px;
}
.bw-role-card {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 8px;
	padding: 16px;
	border: 1px solid var(--bw-border);
	border-radius: var(--bw-radius);
	background: var(--bw-surface-card);
	text-decoration: none;
	color: var(--bw-primary) !important;
	text-align: center;
	transition: border-color 0.2s, background 0.2s;
}
.bw-role-card:hover {
	border-color: var(--bw-primary);
	background: var(--bw-surface-low);
}
.bw-role-card i { font-size: 24px; }
.bw-role-card span {
	font-size: 20px;
	font-weight: 600;
	letter-spacing: 0;
	line-height: 28px;
}

/* Let the split card escape narrow Elementor columns: any container in its
   ancestry stretches to full width. */
.e-con:has(.bw-login-split),
.e-con-inner:has(.bw-login-split),
.elementor-widget:has(.bw-login-split),
.elementor-column:has(.bw-login-split),
.elementor-widget-container:has(.bw-login-split) {
	--width: 100% !important;
	--container-widget-width: 100% !important;
	width: 100% !important;
	max-width: 100% !important;
	flex: 1 1 100%;
}
/* Stack any sibling columns (e.g. intro copy) above the split, full width */
.e-con-parent:has(.bw-login-split),
.e-con-inner:has(.bw-login-split),
.e-con:has(> .bw-login-split-sibling) {
	flex-direction: column !important;
	flex-wrap: nowrap !important;
	align-items: stretch;
}
.e-con-parent:has(.bw-login-split) > .e-con,
.e-con-inner:has(.bw-login-split) > .e-con,
.e-con-parent:has(.bw-login-split) > .e-con-inner > .e-con {
	--width: 100% !important;
	width: 100% !important;
	max-width: 100% !important;
}

/* Register page reuses the split layout; strip the inner form card chrome */
.bw-register-split .britwres-form-container {
	max-width: none;
	margin: 0;
	background: transparent;
	border: none;
	border-radius: 0;
	box-shadow: none;
}
.bw-register-split .bw-login-panel { justify-content: flex-start; }
.bw-register-split .britwres-progress-bar { margin-bottom: 24px; }

/* Right visual panel: greyscale arena photo, caption bottom-left */
.bw-login-visual {
	position: relative;
	background:
		linear-gradient(to top, rgba(0, 0, 0, 0.65), rgba(0, 0, 0, 0.25)),
		url('../../uploads/2025/10/victoryprowrestling_1757415654_3717794180824636513_72793170052.jpg');
	background-size: cover;
	background-position: center;
	filter: grayscale(1);
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	padding: 64px;
}
.bw-login-visual__caption { max-width: 420px; }
.bw-login-visual__caption h2 {
	color: #ffffff;
	font-size: 32px;
	font-weight: 700;
	line-height: 40px;
	letter-spacing: 0;
	margin: 0 0 16px;
	text-shadow: 0 2px 8px rgba(0, 0, 0, 0.4);
}
.bw-login-visual__caption p {
	color: var(--bw-surface-high);
	font-size: 16px;
	line-height: 24px;
	margin: 0;
	text-shadow: 0 1px 4px rgba(0, 0, 0, 0.4);
}
.bw-login-brand {
	font-size: 32px;
	font-weight: 900;
	letter-spacing: 0;
	color: var(--bw-primary);
	margin: 0 0 4px;
}
.bw-login-tagline { color: var(--bw-secondary); font-size: 16px; margin: 0 0 32px; }
.bw-login-divider {
	display: flex;
	align-items: center;
	gap: 16px;
	margin: 24px 0;
	color: var(--bw-secondary);
	font-size: 11px;
	font-weight: 500;
	letter-spacing: 0.05em;
	text-transform: uppercase;
}
.bw-login-divider::before,
.bw-login-divider::after {
	content: '';
	flex: 1;
	height: 1px;
	background: var(--bw-border);
}

/* ----------------------- Page content (Elementor) colour ------------------- */
/* The legacy theme used a dark body with white inherited text. Surfaces are
   light now, so content defaults to on-surface ink. */
body {
	/* Re-token Elementor/Astra global colours (authored for the old dark theme). */
	--e-global-color-primary: var(--bw-on-surface);
	--e-global-color-secondary: var(--bw-secondary);
	--e-global-color-text: var(--bw-on-surface-variant);
	--ast-global-color-2: var(--bw-on-surface);
	--ast-global-color-3: var(--bw-on-surface-variant);
}
.ast-container,
.entry-content,
.elementor {
	color: var(--bw-on-surface);
}
/* Some headings/text were hard-coded white for the old dark background. */
.elementor .elementor-heading-title,
.elementor .elementor-widget-text-editor {
	color: var(--bw-on-surface) !important;
}
/* Exception: the homepage hero overlays text on a photo background. */
.elementor-element-73cb963,
.elementor-element-73cb963 .elementor-heading-title,
.elementor-element-73cb963 .elementor-widget-text-editor {
	color: #ffffff !important;
}

/* --------------------------- Header & footer (white) ----------------------- */
/* Elementor header template (post 571): navy section → white design-system nav */
header#masthead .elementor-element-22d1a77,
header#masthead [data-elementor-type] > .e-con {
	background-color: var(--bw-surface-card) !important;
	background-image: none !important;
	border-bottom: 1px solid var(--bw-border);
}
/* Interim: render the white-artwork logo as a black silhouette on the white nav.
   Remove this filter once a dark logo variant is uploaded. */
header#masthead img {
	filter: brightness(0);
}
/* Nav links, hamburger toggle and icons: slate on white */
header#masthead a,
header#masthead .elementor-icon,
header#masthead .hfe-nav-menu-icon,
header#masthead .hfe-nav-menu a {
	color: var(--bw-secondary) !important;
}
header#masthead a:hover,
header#masthead .hfe-nav-menu a:hover {
	color: var(--bw-primary) !important;
}
header#masthead .menu-item-button a,
header#masthead .menu-item-button a:hover,
header#masthead .menu-item-logout a,
header#masthead .menu-item-logout a:hover,
header#masthead a[href$="/register/"],
header#masthead a[href$="/register/"]:hover,
header#masthead a[href*="action=logout"],
header#masthead a[href*="action=logout"]:hover {
	color: var(--bw-on-primary) !important;
}
header#masthead a[href$="/register/"],
header#masthead .menu-item-logout a,
header#masthead a[href*="action=logout"] {
	background: var(--bw-primary) !important;
	border: 1px solid var(--bw-primary) !important;
	border-radius: var(--bw-radius) !important;
	padding: 8px 20px !important;
}
header#masthead .menu-item-button a:hover,
header#masthead a[href$="/register/"]:hover,
header#masthead .menu-item-logout a:hover,
header#masthead a[href*="action=logout"]:hover {
	background: #1e293b !important;
	border-color: #1e293b !important;
}
header#masthead svg,
header#masthead .hfe-nav-menu-icon svg {
	fill: var(--bw-on-surface) !important;
}

/* Astra builder footer rows: navy → white with slate text */
.site-footer .site-primary-footer-wrap,
.site-footer .site-above-footer-wrap,
.site-footer .site-below-footer-wrap {
	background-color: var(--bw-surface-card) !important;
	background-image: none !important;
	border-top: 1px solid var(--bw-border);
}
.site-footer,
.site-footer a,
.site-footer .ast-builder-menu a,
.site-footer .footer-copy-right,
.site-footer p {
	color: var(--bw-secondary) !important;
}
.site-footer a:hover { color: var(--bw-primary) !important; }
.site-footer img { filter: brightness(0); }

/* Elementor buttons follow the primary button spec */
.elementor-button,
.elementor a.elementor-button {
	background-color: var(--bw-primary) !important;
	color: var(--bw-on-primary) !important;
	border-radius: var(--bw-radius) !important;
	font-family: var(--bw-font) !important;
	font-weight: 500 !important;
}
.elementor-button:hover,
.elementor a.elementor-button:hover {
	background-color: #1e293b !important;
	color: var(--bw-on-primary) !important;
}

/* --------------------------------- Homepage -------------------------------- */
.bw-home {
	max-width: var(--bw-container);
	margin: 0 auto;
	padding: 0 16px 96px;
	display: flex;
	flex-direction: column;
	gap: 96px;
}
@media (max-width: 1023px) { .bw-home { gap: 64px; padding-bottom: 64px; } }
@media (max-width: 767px)  { .bw-home { gap: 48px; padding-bottom: 48px; } }

.bw-home-hero {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	gap: 24px;
	padding: 96px 0 32px;
}
.bw-home-hero h1 {
	font-size: 32px;
	font-weight: 700;
	line-height: 40px;
	letter-spacing: 0;
	max-width: 720px;
	margin: 0;
}
.bw-home-hero p {
	font-size: 16px;
	line-height: 24px;
	color: var(--bw-on-surface-variant);
	max-width: 600px;
	margin: 0;
}
.bw-home-hero__actions { display: flex; gap: 16px; flex-wrap: wrap; justify-content: center; padding-top: 8px; }
@media (max-width: 767px) {
	.bw-home-hero { padding-top: 48px; }
	.bw-home-hero h1 { font-size: 24px; line-height: 32px; letter-spacing: 0; }
}

.bw-home-section__head {
	display: flex;
	justify-content: space-between;
	align-items: center;
	border-bottom: 1px solid var(--bw-surface-high);
	padding-bottom: 16px;
	margin-bottom: 32px;
}
.bw-home-section__head h2 {
	font-size: 20px;
	font-weight: 600;
	line-height: 28px;
	letter-spacing: 0;
	margin: 0;
}
.bw-home-section__head a {
	font-size: 11px;
	font-weight: 500;
	color: var(--bw-on-surface-variant);
	text-decoration: none;
	display: inline-flex;
	align-items: center;
	gap: 6px;
}
.bw-home-section__head a:hover { color: var(--bw-primary); }

.bw-home-talent-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: var(--bw-gutter);
}
@media (max-width: 1023px) { .bw-home-talent-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 599px)  { .bw-home-talent-grid { grid-template-columns: 1fr; } }

.bw-home-talent-card {
	background: rgba(255, 255, 255, 0.9);
	border: 1px solid var(--bw-surface-high);
	border-radius: var(--bw-radius-lg);
	overflow: hidden;
	text-decoration: none;
	color: inherit;
	display: flex;
	flex-direction: column;
	box-shadow: 0px 4px 12px rgba(0, 0, 0, 0.02);
	transition: border-color 0.3s, box-shadow 0.3s;
}
.bw-home-talent-card:hover {
	border-color: var(--bw-outline);
	box-shadow: var(--bw-shadow-hover);
}
.bw-home-talent-card__img {
	aspect-ratio: 1 / 1;
	background: var(--bw-surface-low);
	overflow: hidden;
}
.bw-home-talent-card__img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	filter: grayscale(1);
	opacity: 0.9;
	transition: opacity 0.5s, transform 0.5s;
}
.bw-home-talent-card:hover .bw-home-talent-card__img img {
	opacity: 1;
	transform: scale(1.05);
}
.bw-home-talent-card__body { padding: 24px; display: flex; flex-direction: column; gap: 4px; }
.bw-home-talent-card__body h3 {
	font-size: 16px;
	font-weight: 700;
	line-height: 24px;
	margin: 0;
	color: var(--bw-primary);
}
.bw-home-talent-card__body p {
	font-size: 14px;
	line-height: 20px;
	color: var(--bw-on-surface-variant);
	margin: 0;
}
.bw-home-talent-card__chips { display: flex; flex-wrap: wrap; gap: 8px; padding-top: 8px; }

/* Built for Promoters */
.bw-home-promoters { padding: 48px; border-radius: var(--bw-radius-xl); }
@media (max-width: 767px) { .bw-home-promoters { padding: 24px; } }
.bw-home-promoters__grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 48px;
	align-items: center;
}
@media (max-width: 1023px) { .bw-home-promoters__grid { grid-template-columns: 1fr; } }
.bw-home-promoters__copy h2 {
	font-size: 32px;
	font-weight: 700;
	line-height: 40px;
	letter-spacing: 0;
	margin: 0 0 24px;
}
.bw-home-promoters__copy > p {
	font-size: 16px;
	line-height: 24px;
	color: var(--bw-on-surface-variant);
	margin: 0 0 24px;
}
.bw-home-promoters__copy ul { list-style: none; margin: 0 0 24px; padding: 0; display: flex; flex-direction: column; gap: 16px; }
.bw-home-promoters__copy li { display: flex; gap: 12px; align-items: flex-start; }
.bw-home-promoters__copy li i { color: var(--bw-primary); margin-top: 3px; }
.bw-home-promoters__copy li h3 {
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	margin: 0 0 2px;
}
.bw-home-promoters__copy li p { font-size: 14px; color: var(--bw-on-surface-variant); margin: 0; }
.bw-home-promoters__link {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	color: var(--bw-primary);
	border-bottom: 1px solid var(--bw-primary);
	padding-bottom: 4px;
	text-decoration: none;
}
.bw-home-promoters__link:hover { color: var(--bw-secondary); border-color: var(--bw-secondary); }

/* Promoter mock panel */
.bw-home-promoters__mock {
	background: var(--bw-surface-low);
	border: 1px solid var(--bw-border);
	border-radius: var(--bw-radius-lg);
	padding: 24px;
	background-image: radial-gradient(rgba(0, 0, 0, 0.05) 1px, transparent 1px);
	background-size: 16px 16px;
	display: flex;
	flex-direction: column;
	gap: 12px;
}
.bw-home-mock__head {
	display: flex;
	justify-content: space-between;
	align-items: center;
	border-bottom: 1px solid var(--bw-surface-high);
	padding-bottom: 8px;
}
.bw-home-mock__head h3 {
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	margin: 0;
}
.bw-home-mock__badge {
	background: var(--bw-primary);
	color: var(--bw-on-primary);
	padding: 2px 8px;
	border-radius: var(--bw-radius);
	font-size: 10px;
	font-weight: 600;
}
.bw-home-mock__row {
	background: var(--bw-surface-card);
	border: 1px solid var(--bw-border);
	border-radius: var(--bw-radius);
	padding: 12px;
	display: flex;
	justify-content: space-between;
	align-items: center;
}
.bw-home-mock__row-info { display: flex; align-items: center; gap: 12px; }
.bw-home-mock__avatar {
	width: 32px;
	height: 32px;
	border-radius: 50%;
	background: var(--bw-surface-high);
	display: inline-block;
}
.bw-home-mock__title { font-size: 11px; font-weight: 600; }
.bw-home-mock__sub { font-size: 10px; color: var(--bw-on-surface-variant); }
.bw-home-mock__btn {
	font-size: 12px;
	border: 1px solid var(--bw-outline);
	padding: 4px 8px;
	border-radius: var(--bw-radius);
}

/* ------------------------------ Hat switcher ------------------------------- */
.bw-hat-switcher {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	background: var(--bw-surface-container);
	border: 1px solid var(--bw-border);
	border-radius: 9999px;
	padding: 4px;
	margin-bottom: 24px;
}
.bw-hat-switcher__label {
	font-size: 11px;
	font-weight: 600;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	color: var(--bw-secondary);
	padding: 0 8px 0 10px;
}
.bw-hat-switcher__btn {
	font-size: 13px;
	font-weight: 600;
	padding: 6px 16px;
	border-radius: 9999px;
	color: var(--bw-secondary) !important;
	text-decoration: none;
	transition: background 0.2s, color 0.2s;
}
.bw-hat-switcher__btn:hover { color: var(--bw-primary) !important; }
.bw-hat-switcher__btn.is-active {
	background: var(--bw-primary);
	color: var(--bw-on-primary) !important;
}

/* Add-a-hat prompt card */
.bw-dash-addhat { text-align: center; }
.bw-dash-addhat i { font-size: 24px; color: var(--bw-outline); margin-bottom: 8px; }
.bw-dash-addhat h4 {
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	margin: 0 0 4px;
}
.bw-dash-addhat p { font-size: 13px; color: var(--bw-secondary); margin: 0 0 12px; }

/* --------------------------------- Dashboard ------------------------------- */
.bw-dash {
	max-width: var(--bw-container);
	margin: 0 auto;
	padding: 32px 16px 64px;
}
@media (max-width: 767px) {
	.bw-dash {
		padding: 24px 12px 48px;
	}
	.bw-dash-head h1 {
		font-size: 26px;
		line-height: 34px;
	}
	.bw-dash-profile__body,
	.bw-card__pad {
		padding: 18px;
	}
	.bw-dash-profile__body {
		padding-top: 0;
	}
}
.bw-dash-head {
	display: flex;
	align-items: flex-end;
	flex-wrap: wrap;
	justify-content: space-between;
	gap: 16px;
	margin-bottom: 32px;
}
.bw-dash-head__copy {
	min-width: 0;
}
.bw-dash-head h1 {
	font-size: 32px;
	font-weight: 700;
	line-height: 40px;
	letter-spacing: 0;
	margin: 0 0 8px;
}
.bw-dash-head p { font-size: 14px; color: var(--bw-on-surface-variant); margin: 0; }
.bw-promoter-tour-start,
.bw-talent-tour-start,
.bw-booking-tour-start {
	flex-shrink: 0;
}
.bw-dash-search {
	display: grid;
	flex: 1 1 100%;
	grid-template-columns: auto minmax(0, 1fr) auto;
	align-items: center;
	gap: 12px;
	max-width: 760px;
	margin-top: 24px;
	padding: 8px;
	background: var(--bw-surface-card);
	border: 1px solid var(--bw-border);
	border-radius: var(--bw-radius-lg);
	position: relative;
}
.bw-dash-search > i {
	color: var(--bw-secondary);
	padding-left: 8px;
}
.bw-dash-search input[type="search"] {
	border: none;
	min-height: 44px;
	padding-left: 0;
}
.bw-dash-search input[type="search"]:focus {
	border-color: transparent !important;
}
.bw-dash-search .bw-btn {
	min-width: 104px;
}
.bw-dash-search__results {
	position: absolute;
	top: calc(100% + 8px);
	left: 0;
	right: 0;
	z-index: 20;
	background: var(--bw-surface-card);
	border: 1px solid var(--bw-border);
	border-radius: var(--bw-radius-lg);
	box-shadow: 0 14px 30px rgba(15, 23, 42, 0.12);
	padding: 8px;
	max-height: 360px;
	overflow-y: auto;
}
.bw-dash-search__option {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 10px;
	border-radius: var(--bw-radius);
	color: var(--bw-on-surface) !important;
	text-decoration: none !important;
}
.bw-dash-search__option:hover,
.bw-dash-search__option.is-active {
	background: var(--bw-surface-low);
}
.bw-dash-search__option img {
	width: 48px;
	height: 48px;
	border-radius: 50%;
	object-fit: cover;
	border: 1px solid var(--bw-border);
	flex-shrink: 0;
}
.bw-dash-search__option-text {
	display: flex;
	flex-direction: column;
	gap: 2px;
	min-width: 0;
}
.bw-dash-search__option-text strong {
	font-size: 14px;
	line-height: 20px;
	color: var(--bw-on-surface);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}
.bw-dash-search__option-text span,
.bw-dash-search__empty {
	font-size: 12px;
	line-height: 18px;
	color: var(--bw-on-surface-variant);
}
.bw-dash-search__empty {
	padding: 12px;
	text-align: center;
}
@media (max-width: 599px) {
	.bw-dash-search {
		grid-template-columns: auto minmax(0, 1fr);
	}
	.bw-dash-search .bw-btn {
		grid-column: 1 / -1;
		width: 100%;
	}
}

.bw-dash-grid {
	display: grid;
	grid-template-columns: 3fr 6fr 3fr;
	gap: var(--bw-gutter);
	align-items: start;
}
@media (max-width: 1023px) { .bw-dash-grid { grid-template-columns: 1fr 1fr; } .bw-dash-col--main { grid-column: 1 / -1; order: -1; } }
@media (max-width: 767px)  { .bw-dash-grid { grid-template-columns: 1fr; } }
.bw-dash-col { display: flex; flex-direction: column; gap: var(--bw-gutter); min-width: 0; }

/* Profile snippet card */
.bw-dash-profile { overflow: hidden; }
.bw-dash-profile__cover {
	height: 96px;
	background-color: var(--bw-surface-high);
	background-size: cover;
	background-position: center;
}
.bw-dash-profile__body {
	padding: 0 24px 24px;
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
}
.bw-dash-profile__avatar {
	width: 80px;
	height: 80px;
	border-radius: 50%;
	border: 4px solid var(--bw-surface-card);
	background: var(--bw-surface-high);
	overflow: hidden;
	margin: -40px 0 12px;
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
}
.bw-dash-profile__avatar img { width: 100%; height: 100%; object-fit: cover; display: block; }
.bw-dash-profile__body h2 {
	font-size: 20px;
	font-weight: 600;
	line-height: 28px;
	letter-spacing: 0;
	margin: 0 0 2px;
}
.bw-dash-profile__body > p { font-size: 14px; color: var(--bw-secondary); margin: 0 0 16px; }
.bw-dash-profile__chips { display: flex; gap: 8px; flex-wrap: wrap; justify-content: center; margin-bottom: 24px; }
.bw-dash-profile__action {
	width: 100%;
	border-top: 1px solid var(--bw-border);
	padding-top: 16px;
}

/* Management menu */
.bw-dash-menu nav { display: flex; flex-direction: column; gap: 4px; margin-top: 12px; }
.bw-dash-menu nav a {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 8px 12px;
	border-radius: var(--bw-radius);
	font-size: 14px;
	white-space: nowrap;
	color: var(--bw-on-surface-variant) !important;
	text-decoration: none;
	transition: background 0.2s, color 0.2s;
}
.bw-dash-menu nav a:hover { background: var(--bw-surface-low); color: var(--bw-primary) !important; }
.bw-dash-menu nav a.is-active {
	background: var(--bw-surface-low);
	border: 1px solid var(--bw-border);
	color: var(--bw-primary) !important;
}
.bw-dash-menu nav a i { width: 20px; text-align: center; }

/* KPI cards */
.bw-dash-kpis { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
@media (max-width: 1100px) { .bw-dash-kpis { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 599px) { .bw-dash-kpis { grid-template-columns: 1fr; } }
.bw-dash-kpi { padding: 16px; }
.bw-dash-kpi:hover { border-color: var(--bw-outline); }
.bw-dash-kpi__head {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	margin-bottom: 8px;
}
.bw-dash-kpi__head span {
	font-size: 11px;
	font-weight: 500;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	color: var(--bw-secondary);
}
.bw-dash-kpi__head i { color: var(--bw-border); }
.bw-dash-kpi:hover .bw-dash-kpi__head i { color: var(--bw-primary); }
.bw-dash-kpi__value {
	font-size: 32px;
	font-weight: 700;
	line-height: 40px;
	letter-spacing: 0;
}
.bw-dash-kpi__sub {
	display: flex;
	align-items: center;
	gap: 6px;
	font-size: 11px;
	color: var(--bw-on-surface-variant);
	margin-top: 4px;
}

/* Activity timeline */
.bw-dash-activity__head {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: 24px;
}
.bw-dash-activity__head h3 {
	font-size: 20px;
	font-weight: 600;
	letter-spacing: 0;
	margin: 0;
}
.bw-dash-activity__head a {
	font-size: 11px;
	font-weight: 500;
	color: var(--bw-secondary);
	text-decoration: none;
}
.bw-dash-activity__head a:hover { color: var(--bw-primary); }

.bw-dash-timeline {
	position: relative;
	padding-left: 24px;
	display: flex;
	flex-direction: column;
	gap: 32px;
}
.bw-dash-timeline::before {
	content: '';
	position: absolute;
	left: 11px;
	top: 8px;
	bottom: 8px;
	width: 2px;
	background: var(--bw-surface-high);
}
.bw-dash-timeline__item { position: relative; }
.bw-dash-timeline__item::before {
	content: '';
	position: absolute;
	left: -21px;
	top: 4px;
	width: 12px;
	height: 12px;
	border-radius: 50%;
	background: var(--bw-surface-card);
	border: 2px solid var(--bw-border);
	z-index: 1;
}
.bw-dash-timeline__item.is-current::before { border-color: var(--bw-primary); background: var(--bw-primary); }
.bw-dash-timeline__date {
	display: block;
	font-size: 11px;
	color: var(--bw-secondary);
	margin-bottom: 4px;
}
.bw-dash-timeline__item h4 { font-size: 14px; font-weight: 600; margin: 0 0 4px; }
.bw-dash-timeline__item p { font-size: 14px; color: var(--bw-on-surface-variant); margin: 0; }
.bw-dash-timeline__thumbs { display: flex; gap: 8px; margin-top: 12px; }
.bw-dash-timeline__thumb {
	width: 64px;
	height: 48px;
	border-radius: var(--bw-radius);
	border: 1px solid var(--bw-border);
	overflow: hidden;
	background: var(--bw-surface-container);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-size: 11px;
	color: var(--bw-secondary);
}
.bw-dash-timeline__thumb img { width: 100%; height: 100%; object-fit: cover; filter: grayscale(1); }

/* Profile strength checklist */
.bw-dash-checklist__head {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: 12px;
	padding-bottom: 8px;
	border-bottom: 1px solid var(--bw-border);
}
.bw-dash-checklist__head h3 { margin: 0; }
.bw-dash-checklist__badge {
	background: var(--bw-primary);
	color: var(--bw-on-primary);
	font-size: 11px;
	font-weight: 600;
	padding: 2px 8px;
	border-radius: var(--bw-radius);
}
.bw-dash-checklist__bar {
	height: 6px;
	background: var(--bw-surface-container);
	border-radius: 9999px;
	overflow: hidden;
	margin-bottom: 16px;
}
.bw-dash-checklist__bar span { display: block; height: 100%; background: var(--bw-primary); border-radius: 9999px; }
.bw-dash-checklist ul { list-style: none; margin: 0 0 16px; padding: 0; display: flex; flex-direction: column; gap: 8px; }
.bw-dash-checklist li {
	display: flex;
	align-items: center;
	gap: 10px;
	font-size: 14px;
	color: var(--bw-on-surface);
}
.bw-dash-checklist li i { color: var(--bw-border); font-size: 14px; }
.bw-dash-checklist li.is-done { color: var(--bw-secondary); text-decoration: line-through; }
.bw-dash-checklist li.is-done i { color: var(--bw-primary); }

.bw-dash-tip {
	display: flex;
	gap: 12px;
	align-items: flex-start;
	padding: 12px;
	border: 1px dashed var(--bw-border);
	border-radius: var(--bw-radius);
	background: var(--bw-surface);
}
.bw-dash-tip i { color: var(--bw-secondary); margin-top: 2px; }
.bw-dash-tip p { font-size: 13px; color: var(--bw-on-surface-variant); margin: 0 0 4px; }
.bw-dash-tip p strong { color: var(--bw-on-surface); }
.bw-dash-tip a {
	font-size: 11px;
	font-weight: 600;
	color: var(--bw-primary);
	text-decoration: underline;
}

.bw-dash-empty {
	color: var(--bw-on-surface-variant);
	font-size: 14px;
	margin: 0;
}
.bw-dash-show-list,
.bw-dash-actions,
.bw-dash-reliability,
.bw-dash-notifications {
	display: flex;
	flex-direction: column;
	gap: 12px;
}
.bw-dash-show {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	padding: 12px 0;
	border-top: 1px solid var(--bw-border);
	color: var(--bw-on-surface);
	text-decoration: none !important;
}
.bw-dash-show:hover { color: var(--bw-primary); }
.bw-dash-show strong,
.bw-dash-show span {
	display: block;
}
.bw-dash-show span,
.bw-dash-show em {
	color: var(--bw-on-surface-variant);
	font-size: 13px;
	font-style: normal;
}
.bw-dash-panels {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
	gap: var(--bw-gutter);
}
.bw-dash-actions .bw-btn { width: 100%; }
.bw-dash-reliability > div {
	display: grid;
	grid-template-columns: minmax(0, 1fr) auto;
	gap: 2px 8px;
	padding-bottom: 10px;
	border-bottom: 1px solid var(--bw-border);
}
.bw-dash-reliability span {
	font-weight: 600;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}
.bw-dash-reliability small {
	grid-column: 1 / -1;
	color: var(--bw-on-surface-variant);
}
.bw-dash-note {
	display: flex;
	gap: 10px;
	align-items: flex-start;
	padding: 10px;
	border: 1px solid var(--bw-border);
	border-radius: var(--bw-radius);
	text-decoration: none !important;
	color: var(--bw-on-surface);
}
.bw-dash-note:hover {
	background: var(--bw-surface-low);
	color: var(--bw-on-surface);
}
.bw-dash-note i {
	color: var(--bw-secondary);
	margin-top: 3px;
}
.bw-dash-note span,
.bw-dash-note strong,
.bw-dash-note small {
	display: block;
}
.bw-dash-note small {
	color: var(--bw-on-surface-variant);
	font-size: 12px;
}
@media (max-width: 767px) {
	.bw-dash-panels { grid-template-columns: 1fr; }
}

/* Guided tours */
.bw-tour-overlay {
	position: fixed;
	inset: 0;
	z-index: 99980;
	background: rgba(15, 23, 42, 0.62);
	backdrop-filter: blur(2px);
}
.bw-tour-spotlight {
	position: fixed;
	z-index: 99990;
	border: 2px solid #fff;
	border-radius: 12px;
	box-shadow: 0 0 0 9999px rgba(15, 23, 42, 0.62), 0 20px 60px rgba(0, 0, 0, 0.28);
	pointer-events: none;
	transition: top 0.18s ease, left 0.18s ease, width 0.18s ease, height 0.18s ease;
}
.bw-tour-popover {
	position: fixed;
	z-index: 100000;
	width: min(360px, calc(100vw - 32px));
	padding: 18px;
	border: 1px solid var(--bw-border);
	border-radius: var(--bw-radius-lg);
	background: var(--bw-surface-card);
	color: var(--bw-on-surface);
	box-shadow: 0 24px 70px rgba(15, 23, 42, 0.28);
}
.bw-tour-popover__count {
	margin-bottom: 8px;
	color: var(--bw-secondary);
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.06em;
	text-transform: uppercase;
}
.bw-tour-popover h2 {
	margin: 0 0 8px;
	font-size: 20px;
	line-height: 26px;
	letter-spacing: 0;
}
.bw-tour-popover p {
	margin: 0;
	color: var(--bw-on-surface-variant);
	font-size: 14px;
	line-height: 20px;
}
.bw-tour-popover__actions {
	display: flex;
	align-items: center;
	gap: 8px;
	margin-top: 18px;
}
.bw-tour-spacer {
	flex: 1;
}
.bw-tour-popover button {
	border: 1px solid var(--bw-border);
	border-radius: var(--bw-radius);
	background: var(--bw-surface);
	color: var(--bw-on-surface);
	font-size: 13px;
	font-weight: 700;
	line-height: 1;
	padding: 10px 12px;
	cursor: pointer;
}
.bw-tour-popover button:hover,
.bw-tour-popover button:focus {
	border-color: var(--bw-outline);
}
.bw-tour-popover button:disabled {
	cursor: not-allowed;
	opacity: 0.45;
}
.bw-tour-popover .bw-tour-next {
	background: var(--bw-primary);
	border-color: var(--bw-primary);
	color: var(--bw-on-primary);
}
.bw-tour-popover .bw-tour-skip {
	border-color: transparent;
	background: transparent;
	color: var(--bw-secondary);
}
.bw-tour-overlay[hidden],
.bw-tour-spotlight[hidden],
.bw-tour-popover[hidden] {
	display: none !important;
}

@media (max-width: 767px) {
	.bw-dash-head {
		align-items: stretch;
		flex-direction: column;
	}
	.bw-promoter-tour-start,
	.bw-talent-tour-start {
		width: 100%;
	}
	.bw-tour-popover {
		left: 16px !important;
		right: 16px;
		width: auto;
	}
}

/* Promo / share card */
.bw-dash-promo { text-align: center; background: var(--bw-surface-container); }
.bw-dash-promo i { font-size: 24px; color: var(--bw-outline); margin-bottom: 8px; }
.bw-dash-promo h4 {
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	margin: 0 0 4px;
}
.bw-dash-promo p { font-size: 13px; color: var(--bw-secondary); margin: 0 0 12px; }

/* --------------------------------- Messaging ------------------------------- */
.bw-msg {
	display: grid;
	grid-template-columns: 3fr 6fr 3fr;
	gap: var(--bw-gutter);
	max-width: var(--bw-container);
	margin: 32px auto;
	height: calc(100vh - 220px);
	min-height: 480px;
	align-items: stretch;
}
@media (max-width: 1023px) {
	.bw-msg { grid-template-columns: 4fr 8fr; }
	.bw-msg-context { grid-column: 1 / -1; }
}
@media (max-width: 767px) {
	.bw-msg { grid-template-columns: 1fr; height: auto; }
	.bw-msg-list { max-height: 320px; }
	.bw-msg-thread { min-height: 480px; }
}

.bw-msg .bw-card { display: flex; flex-direction: column; overflow: hidden; min-height: 0; }
/* Honour the hidden attribute even though children set display:flex. */
.bw-msg [hidden] { display: none !important; }

/* ------------------------- Booking sheets/storylines ----------------------- */
.bw-booking-page {
	max-width: var(--bw-container);
	margin: 0 auto;
	padding: 32px var(--bw-gutter) 56px;
}
.bw-booking-head {
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	gap: 16px;
}
.bw-booking-head__actions {
	display: flex;
	align-items: center;
	justify-content: flex-end;
	gap: 10px;
	flex-wrap: wrap;
}
.bw-booking-layout {
	display: grid;
	grid-template-columns: minmax(260px, 320px) minmax(0, 1fr);
	gap: var(--bw-gutter);
	align-items: start;
}
.bw-booking-sidebar {
	position: sticky;
	top: 24px;
}
.bw-booking-new,
.bw-booking-show-list,
.bw-booking-reliability,
.bw-match-list,
.bw-storyline-list {
	display: flex;
	flex-direction: column;
	gap: 12px;
}
.bw-booking-new {
	margin-bottom: 20px;
	padding-bottom: 20px;
	border-bottom: 1px solid var(--bw-border);
}
.bw-booking-new input,
.bw-booking-new button {
	width: 100%;
}
.bw-booking-new button { margin-top: 4px; }
.bw-booking-show {
	display: block;
	padding: 12px;
	border: 1px solid var(--bw-border);
	border-radius: var(--bw-radius);
	text-decoration: none !important;
	color: var(--bw-on-surface);
}
.bw-booking-show:hover,
.bw-booking-show.is-active {
	background: var(--bw-surface-low);
	border-color: var(--bw-outline);
	color: var(--bw-on-surface);
}
.bw-booking-show strong,
.bw-booking-show span,
.bw-booking-show small {
	display: block;
}
.bw-booking-show span,
.bw-booking-show small,
.bw-booking-empty,
.bw-match-empty {
	color: var(--bw-on-surface-variant);
	font-size: 13px;
}
.bw-booking-reliability {
	margin-top: 20px;
	padding-top: 20px;
	border-top: 1px solid var(--bw-border);
}
.bw-booking-reliability__row {
	display: grid;
	grid-template-columns: minmax(0, 1fr) auto;
	gap: 2px 8px;
	padding: 10px 0;
	border-bottom: 1px solid var(--bw-border);
}
.bw-booking-reliability__row span {
	font-weight: 600;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}
.bw-booking-reliability__row strong {
	font-size: 14px;
}
.bw-booking-reliability__row small {
	grid-column: 1 / -1;
	color: var(--bw-on-surface-variant);
}
.bw-booking-notice {
	padding: 12px 16px;
	margin-bottom: 16px;
	border: 1px solid var(--bw-border);
	border-radius: var(--bw-radius);
	background: var(--bw-surface-card);
	font-weight: 600;
}
.bw-booking-editor__top,
.bw-booking-card-head,
.bw-booking-footer-actions,
.bw-storyline__head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
}
.bw-booking-editor__top h2,
.bw-storyline__head h2 {
	margin: 0;
	font-size: 24px;
	line-height: 32px;
}
.bw-booking-actions {
	display: flex;
	align-items: center;
	justify-content: flex-end;
	gap: 10px;
	flex-wrap: wrap;
}
.bw-booking-fields,
.bw-match__grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 12px;
	margin: 20px 0;
}
.bw-booking-fields label,
.bw-match label,
.bw-booking-retro {
	display: flex;
	flex-direction: column;
	gap: 6px;
	font-size: 12px;
	font-weight: 600;
	color: var(--bw-on-surface-variant);
}
.bw-booking-fields input,
.bw-booking-fields select,
.bw-match input,
.bw-match select,
.bw-match textarea,
.bw-booking-retro textarea {
	width: 100%;
	color: var(--bw-on-surface);
	font-weight: 400;
}
.bw-match {
	padding: 16px;
	border: 1px solid var(--bw-border);
	border-radius: var(--bw-radius-lg);
	background: var(--bw-surface);
}
.bw-match__head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-bottom: 12px;
}
.bw-match__remove,
.bw-booking-delete button {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	border: 0;
	background: transparent;
	color: var(--bw-secondary);
	cursor: pointer;
	padding: 6px;
}
.bw-match__remove:hover,
.bw-booking-delete button:hover {
	color: var(--bw-error);
}
.bw-booking-retro {
	margin-top: 20px;
}
.bw-booking-footer-actions {
	margin-top: 16px;
}
.bw-booking-delete {
	margin-top: 12px;
	text-align: right;
}
.bw-booking-blank {
	text-align: center;
	padding: 48px 16px;
}
.bw-booking-blank i {
	font-size: 32px;
	color: var(--bw-outline);
}
.bw-booking-blank p {
	color: var(--bw-on-surface-variant);
}
.bw-storyline__beats {
	display: flex;
	flex-direction: column;
	gap: 16px;
	margin-top: 20px;
}
.bw-storyline__beat {
	display: grid;
	grid-template-columns: 120px minmax(0, 1fr);
	gap: 16px;
	padding-top: 16px;
	border-top: 1px solid var(--bw-border);
}
.bw-storyline__beat h3 {
	margin: 0 0 4px;
	font-size: 16px;
	line-height: 22px;
}
.bw-storyline__beat p {
	margin: 4px 0 0;
	color: var(--bw-on-surface-variant);
}
.bw-storyline__date {
	font-size: 12px;
	font-weight: 700;
	color: var(--bw-secondary);
	text-transform: uppercase;
}
@media (max-width: 900px) {
	.bw-booking-layout,
	.bw-booking-fields,
	.bw-match__grid {
		grid-template-columns: 1fr;
	}
	.bw-booking-sidebar {
		position: static;
	}
}
@media (max-width: 640px) {
	.bw-booking-head,
	.bw-booking-editor__top,
	.bw-booking-card-head,
	.bw-booking-head__actions,
	.bw-booking-actions,
	.bw-storyline__head {
		align-items: stretch;
		flex-direction: column;
	}
	.bw-booking-tour-start {
		width: 100%;
	}
	.bw-storyline__beat {
		grid-template-columns: 1fr;
	}
}

/* Conversation list */
.bw-msg-list__head {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 16px;
	border-bottom: 1px solid var(--bw-border);
}
.bw-msg-list__head h2 { font-size: 20px; font-weight: 600; letter-spacing: 0; margin: 0; }
.bw-msg-lock {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-size: 11px;
	font-weight: 500;
	color: var(--bw-secondary);
}
.bw-msg-list__search { padding: 8px; border-bottom: 1px solid var(--bw-border); }
.bw-msg-list__search input { width: 100%; padding: 8px 12px; }
.bw-msg-group-card {
	padding: 8px;
	border-bottom: 1px solid var(--bw-border);
}
.bw-msg-group-card .bw-btn {
	width: 100%;
}
.bw-msg-list__items { flex: 1; overflow-y: auto; min-height: 0; }

.bw-msg-item {
	display: flex;
	gap: 12px;
	align-items: center;
	padding: 12px;
	border-left: 4px solid transparent;
	cursor: pointer;
	transition: background 0.2s;
	position: relative;
}
.bw-msg-item:hover { background: var(--bw-surface-low); }
.bw-msg-item.is-active { background: var(--bw-surface-low); border-left-color: var(--bw-primary); }
.bw-msg-item img {
	width: 48px;
	height: 48px;
	border-radius: 50%;
	object-fit: cover;
	border: 1px solid var(--bw-border);
	flex-shrink: 0;
}
.bw-msg-item__main { flex: 1; min-width: 0; }
.bw-msg-item__top { display: flex; justify-content: space-between; align-items: baseline; gap: 8px; }
.bw-msg-item__name {
	font-size: 14px;
	font-weight: 600;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}
.bw-msg-item__time { font-size: 11px; color: var(--bw-secondary); flex-shrink: 0; }
.bw-msg-item__preview {
	font-size: 13px;
	color: var(--bw-on-surface-variant);
	margin: 2px 0 0;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}
.bw-msg-item__badge {
	background: var(--bw-primary);
	color: var(--bw-on-primary);
	font-size: 10px;
	font-weight: 600;
	min-width: 18px;
	height: 18px;
	border-radius: 9999px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0 5px;
	flex-shrink: 0;
}

.bw-msg-group-panel {
	padding: 16px;
	border-bottom: 1px solid var(--bw-border);
	background: var(--bw-surface);
}
.bw-msg-group-panel__head {
	display: flex;
	justify-content: space-between;
	gap: 16px;
	margin-bottom: 12px;
}
.bw-msg-group-panel__head h3 {
	font-size: 18px;
	line-height: 24px;
	margin: 0;
}
.bw-msg-group-panel__head p {
	color: var(--bw-on-surface-variant);
	margin: 2px 0 0;
}
.bw-msg-group-recipients {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 8px;
	max-height: 220px;
	overflow: auto;
	margin-bottom: 12px;
}
.bw-msg-group-recipient {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 10px;
	border: 1px solid var(--bw-border);
	border-radius: var(--bw-radius);
	background: var(--bw-surface-card);
	cursor: pointer;
}
.bw-msg-group-recipient input {
	accent-color: var(--bw-primary);
	margin: 0;
}
.bw-msg-group-recipient span,
.bw-msg-group-recipient strong,
.bw-msg-group-recipient small {
	display: block;
}
.bw-msg-group-recipient small {
	color: var(--bw-on-surface-variant);
	font-size: 12px;
}
.bw-msg-group-panel textarea {
	width: 100%;
	margin-bottom: 12px;
}
.bw-msg-group-actions {
	display: flex;
	align-items: center;
	gap: 12px;
	flex-wrap: wrap;
}
.bw-msg-group-actions span {
	color: var(--bw-on-surface-variant);
	font-size: 13px;
}
@media (max-width: 767px) {
	.bw-msg-group-recipients { grid-template-columns: 1fr; }
}

/* Thread */
.bw-msg-thread__head {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 12px 16px;
	border-bottom: 1px solid var(--bw-border);
}
.bw-msg-thread__head img {
	width: 40px;
	height: 40px;
	border-radius: 50%;
	object-fit: cover;
	border: 1px solid var(--bw-border);
}
.bw-msg-thread__head h3 { font-size: 16px; font-weight: 600; margin: 0; line-height: 1.2; }
.bw-msg-thread__head span { font-size: 11px; color: var(--bw-on-surface-variant); }
.bw-msg-thread__body {
	flex: 1;
	overflow-y: auto;
	min-height: 0;
	padding: 16px;
	background: var(--bw-surface);
	display: flex;
	flex-direction: column;
	gap: 12px;
}

.bw-msg-thread-notice {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	padding: 12px 14px;
	border: 1px solid var(--bw-border);
	border-radius: var(--bw-radius);
	background: var(--bw-surface-card);
	color: var(--bw-on-surface-variant);
	font-size: 13px;
	line-height: 18px;
}
.bw-msg-thread-notice i {
	color: var(--bw-secondary);
	margin-top: 2px;
	flex-shrink: 0;
}

.bw-msg-bubble-row { display: flex; flex-direction: column; align-items: flex-start; gap: 4px; }
.bw-msg-bubble-row.is-mine { align-items: flex-end; }
.bw-msg-bubble {
	max-width: 80%;
	padding: 8px 16px;
	border-radius: var(--bw-radius-lg);
	border-top-left-radius: 0;
	background: var(--bw-surface-card);
	border: 1px solid var(--bw-border);
	font-size: 14px;
	line-height: 20px;
	white-space: pre-wrap;
	word-break: break-word;
	box-shadow: 0 1px 2px rgba(0, 0, 0, 0.04);
}
.bw-msg-bubble-row.is-mine .bw-msg-bubble {
	background: var(--bw-primary);
	border-color: var(--bw-primary);
	color: var(--bw-on-primary);
	border-radius: var(--bw-radius-lg);
	border-top-right-radius: 0;
}
.bw-msg-bubble__time { font-size: 11px; color: var(--bw-secondary); padding: 0 4px; }

.bw-msg-thread__input {
	display: flex;
	gap: 8px;
	align-items: flex-end;
	padding: 12px 16px;
	border-top: 1px solid var(--bw-border);
}
.bw-msg-thread__input textarea { flex: 1; resize: none; }
.bw-msg-thread__input textarea:disabled {
	background: var(--bw-surface-low);
	color: var(--bw-on-surface-variant);
	cursor: not-allowed;
}
.bw-msg-thread__input .bw-btn { flex-shrink: 0; }

/* Context panel */
.bw-msg-context { padding: 24px; align-items: center; text-align: center; overflow-y: auto; }
.bw-msg-context img {
	width: 96px;
	height: 96px;
	border-radius: 50%;
	object-fit: cover;
	border: 2px solid var(--bw-border);
	margin-bottom: 12px;
}
.bw-msg-context h3 { font-size: 20px; font-weight: 600; letter-spacing: 0; margin: 0 0 4px; }
.bw-msg-context > p { font-size: 14px; color: var(--bw-on-surface-variant); margin: 0 0 12px; }
.bw-msg-ctx__chips { display: flex; gap: 8px; flex-wrap: wrap; justify-content: center; margin-bottom: 16px; }
.bw-msg-ctx__stats {
	list-style: none;
	margin: 16px 0 0;
	padding: 16px 0 0;
	border-top: 1px solid var(--bw-border);
	width: 100%;
	display: flex;
	flex-direction: column;
	gap: 8px;
}
.bw-msg-ctx__stats li { display: flex; justify-content: space-between; font-size: 14px; }
.bw-msg-ctx__stats li span { color: var(--bw-secondary); }

.bw-msg-safety {
	width: 100%;
	margin-top: 16px;
	padding-top: 16px;
	border-top: 1px solid var(--bw-border);
}
.bw-msg-safety__actions {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 8px;
}
.bw-msg-safety-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 6px;
	min-height: 36px;
	padding: 8px 10px;
	border: 1px solid var(--bw-border);
	border-radius: var(--bw-radius);
	background: var(--bw-surface-card);
	color: var(--bw-on-surface);
	font-size: 12px;
	font-weight: 600;
	cursor: pointer;
}
.bw-msg-safety-btn:hover {
	border-color: var(--bw-outline);
	background: var(--bw-surface-low);
}
.bw-msg-safety-btn#bw-msg-block,
.bw-msg-safety-btn#bw-msg-report {
	color: var(--bw-error);
}
.bw-msg-report-panel {
	display: flex;
	flex-direction: column;
	gap: 8px;
	margin-top: 12px;
	padding: 12px;
	border: 1px solid var(--bw-border);
	border-radius: var(--bw-radius);
	background: var(--bw-surface-low);
	text-align: left;
}
.bw-msg-report-panel label {
	color: var(--bw-on-surface-variant);
	font-size: 12px;
	font-weight: 700;
}
.bw-msg-report-panel select,
.bw-msg-report-panel textarea {
	width: 100%;
}
.bw-msg-report-panel__actions {
	display: flex;
	justify-content: flex-end;
	gap: 8px;
	flex-wrap: wrap;
}
.bw-msg-report-panel__actions .bw-btn {
	width: auto;
	min-height: 36px;
	padding: 8px 12px;
	font-size: 12px;
}
.bw-msg-safety__status {
	min-height: 18px;
	margin: 10px 0 0;
	color: var(--bw-on-surface-variant);
	font-size: 12px;
	line-height: 18px;
}

.bw-msg-empty { color: var(--bw-secondary); font-size: 14px; text-align: center; padding: 16px; margin: 0; }

.bw-feature-paused {
	text-align: center;
}

/* ---------------------------- Privacy policy ------------------------------ */
.bw-policy-page {
	max-width: 980px;
	margin: 32px auto 64px;
	padding: 0 var(--bw-gutter);
}
.bw-policy-hero {
	margin-bottom: 24px;
	padding-bottom: 24px;
	border-bottom: 1px solid var(--bw-border);
}
.bw-policy-hero h1 {
	margin: 0 0 12px;
	font-size: clamp(32px, 5vw, 52px);
	line-height: 1.05;
	letter-spacing: 0;
}
.bw-policy-hero p {
	max-width: 720px;
	color: var(--bw-on-surface-variant);
	font-size: 16px;
	line-height: 24px;
}
.bw-policy-updated {
	margin-top: 12px;
	font-size: 13px !important;
}
.bw-policy-card {
	padding: 24px 0;
	border-bottom: 1px solid var(--bw-border);
}
.bw-policy-card h2 {
	margin: 0 0 12px;
	font-size: 22px;
	line-height: 30px;
	letter-spacing: 0;
}
.bw-policy-card p,
.bw-policy-card li {
	color: var(--bw-on-surface-variant);
	font-size: 15px;
	line-height: 24px;
}
.bw-policy-card ul {
	margin: 0;
	padding-left: 20px;
}
.bw-policy-card li + li {
	margin-top: 8px;
}
.bw-policy-table-wrap {
	overflow-x: auto;
	border: 1px solid var(--bw-border);
	border-radius: var(--bw-radius);
}
.bw-policy-table {
	width: 100%;
	min-width: 720px;
	border-collapse: collapse;
	background: var(--bw-surface-card);
}
.bw-policy-table th,
.bw-policy-table td {
	padding: 12px 14px;
	border-bottom: 1px solid var(--bw-border);
	text-align: left;
	vertical-align: top;
	font-size: 14px;
	line-height: 21px;
}
.bw-policy-table th {
	color: var(--bw-on-surface);
	background: var(--bw-surface-low);
	font-weight: 700;
}
.bw-policy-table td {
	color: var(--bw-on-surface-variant);
}
.bw-policy-table tr:last-child td {
	border-bottom: 0;
}
.bw-privacy-footer-link {
	padding: 16px;
	text-align: center;
	font-size: 13px;
}
.bw-privacy-footer-link a {
	color: var(--bw-secondary);
	text-decoration: underline;
}
.bw-policy-ack {
	width: 100%;
	margin: 4px 0 10px;
	color: var(--bw-on-surface-variant);
	font-size: 12px;
	line-height: 18px;
	text-align: center;
}
.bw-policy-ack a {
	color: var(--bw-primary);
	font-weight: 700;
}

/* ------------------------------ Misc / cleanup ----------------------------- */
.featured-talent-section h2 {
	font-size: 20px;
	font-weight: 600;
	letter-spacing: 0;
	text-align: left;
}
#britwres-toast-notification {
	background: var(--bw-on-surface) !important;
	border-radius: var(--bw-radius) !important;
	font-family: var(--bw-font);
}
