/* ============================================================
 * Canada Cannabis Brands — Custom Styles
 * Editorial, structured-data aesthetic. Forest + amber + cream.
 * ============================================================ */

:root {
	--ccb-cream:       #FAF7F2;
	--ccb-cream-2:     #F2EDE2;
	--ccb-forest:      #1A2B1F;
	--ccb-forest-2:    #243829;
	--ccb-forest-3:    #0F1A12;
	--ccb-amber:       #C8973F;
	--ccb-amber-soft:  #E5C892;
	--ccb-terracotta:  #B5573A;
	--ccb-ink:         #131814;
	--ccb-ink-2:       #2A312C;
	--ccb-muted:       #6B736D;
	--ccb-rule:        #E5DFD2;
	--ccb-leaf:        #4A6B4F;
	--ccb-leaf-soft:   #C9D6BD;
}

/* Apply our typography to brand pages without breaking Kadence on other pages */
.single-brand,
.post-type-archive-brand,
.tax-brand_category,
.tax-brand_province {
	font-family: 'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif;
	background: var(--ccb-cream);
	color: var(--ccb-ink);
}

.single-brand h1,
.single-brand h2,
.single-brand h3,
.post-type-archive-brand h1,
.post-type-archive-brand h2,
.tax-brand_category h1,
.tax-brand_province h1 {
	font-family: 'Fraunces', Georgia, serif;
	font-weight: 400;
	letter-spacing: -0.02em;
	color: var(--ccb-forest);
}

/* ============================================================
 * Shared components
 * ============================================================ */

.ccb-breadcrumb {
	font-family: 'JetBrains Mono', monospace;
	font-size: 11px;
	color: var(--ccb-muted);
	letter-spacing: 0.05em;
	margin-bottom: 20px;
}
.ccb-breadcrumb a { color: var(--ccb-muted); text-decoration: none; }
.ccb-breadcrumb a:hover { color: var(--ccb-forest); }
.ccb-breadcrumb .sep { margin: 0 8px; color: var(--ccb-rule); }
.ccb-breadcrumb .current { color: var(--ccb-forest); }

.ccb-eyebrow {
	font-family: 'JetBrains Mono', monospace;
	font-size: 11px;
	letter-spacing: 0.18em;
	color: var(--ccb-amber);
	text-transform: uppercase;
	margin-bottom: 12px;
}
/* Larger AVAILABILITY kicker on the brand "Where to buy" section (scoped so the hero eyebrow stays 11px) */
#availability .ccb-eyebrow { font-size: 16px; }

.ccb-btn {
	display: inline-block;
	padding: 10px 22px;
	border-radius: 999px;
	font-size: 14px;
	font-weight: 500;
	text-decoration: none;
	transition: opacity 0.2s, transform 0.2s;
	cursor: pointer;
	border: none;
	font-family: inherit;
}
.ccb-btn:hover { transform: translateY(-1px); }
.ccb-btn-primary {
	background: var(--ccb-forest);
	color: var(--ccb-cream);
}
.ccb-btn-primary:hover { background: var(--ccb-forest-2); color: var(--ccb-cream); }
.ccb-btn-ghost {
	background: transparent;
	color: var(--ccb-forest);
	border: 1px solid var(--ccb-forest);
}

/* ============================================================
 * SINGLE BRAND PAGE
 * ============================================================ */

.ccb-bd-hero {
	background: var(--ccb-forest);
	color: var(--ccb-cream);
	padding: 60px 32px 0;
	position: relative;
	overflow: hidden;
}
.ccb-bd-hero::before {
	content: "";
	position: absolute;
	bottom: -100px; right: -100px;
	width: 400px; height: 400px;
	background: radial-gradient(circle, rgba(200,151,63,0.12), transparent 70%);
	pointer-events: none;
}
.ccb-bd-hero-inner {
	max-width: 1280px;
	margin: 0 auto 40px;
	position: relative;
}
.ccb-bd-hero .ccb-breadcrumb { color: var(--ccb-leaf-soft); margin-bottom: 32px; }
.ccb-bd-hero .ccb-breadcrumb a { color: var(--ccb-leaf-soft); }
.ccb-bd-hero .ccb-breadcrumb a:hover { color: var(--ccb-cream); }
.ccb-bd-hero .ccb-breadcrumb .current { color: var(--ccb-cream); }
.ccb-bd-hero .ccb-breadcrumb .sep { color: rgba(255,255,255,0.2); }

.ccb-bd-header {
	display: grid;
	grid-template-columns: 140px 1fr auto;
	gap: 32px;
	align-items: center;
}
.ccb-bd-header.ccb-bd-header-no-logo {
	grid-template-columns: 1fr auto;
}
.ccb-bd-actions {
	display: flex;
	flex-direction: column;
	gap: 8px;
	align-self: center;
}
.ccb-bd-actions-hidden { display: none; }
.ccb-btn-amber {
	background: var(--ccb-amber);
	color: var(--ccb-forest);
	padding: 10px 22px;
	border-radius: 999px;
	font-weight: 500;
	font-size: 13px;
	text-align: center;
	text-decoration: none;
	transition: background 0.15s;
}
.ccb-btn-amber:hover { background: var(--ccb-amber-soft); color: var(--ccb-forest); }
.ccb-btn-ghost-light {
	background: transparent;
	color: var(--ccb-cream);
	border: 1px solid rgba(255,255,255,0.25);
	padding: 10px 22px;
	border-radius: 999px;
	font-weight: 500;
	font-size: 13px;
	text-align: center;
	text-decoration: none;
	transition: background 0.15s, border-color 0.15s;
}
.ccb-btn-ghost-light:hover { background: rgba(255,255,255,0.06); border-color: rgba(255,255,255,0.4); color: var(--ccb-cream); }

.ccb-bd-logo,
.ccb-bd-logo-mark {
	width: 140px;
	height: 140px;
	border-radius: 16px;
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
}
.ccb-bd-logo img {
	max-width: 80%;
	max-height: 80%;
	object-fit: contain;
}
.ccb-bd-logo-mark {
	font-family: 'Fraunces', serif;
	font-size: 52px;
	font-weight: 500;
	color: var(--ccb-cream);
	letter-spacing: -0.04em;
}

.ccb-bd-meta h1 {
	font-size: 60px;
	font-weight: 400;
	line-height: 1;
	color: var(--ccb-cream);
	margin: 0 0 16px;
	letter-spacing: -0.03em;
}
.ccb-bd-meta .ccb-eyebrow { color: var(--ccb-amber); }
.ccb-bd-meta .ccb-tagline {
	font-size: 16px;
	color: var(--ccb-leaf-soft);
	max-width: 560px;
	line-height: 1.5;
	margin: 0;
}

/* Legacy .ccb-bd-actions block-level rule removed — it was duplicating .ccb-bd-actions
   defined above and its display:flex was overriding .ccb-bd-actions-hidden's
   display:none, causing the Find a Store / Shop Online buttons to show even
   when the hidden class was applied. Button-specific selectors retained below
   for any legacy button-class usage. */
.ccb-bd-actions .ccb-btn-primary {
	background: var(--ccb-amber);
	color: var(--ccb-forest);
}
.ccb-bd-actions .ccb-btn-ghost {
	color: var(--ccb-cream);
	border: 1px solid rgba(255,255,255,0.2);
}

/* Quick facts strip */
.ccb-bd-quickfacts {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
	gap: 1px;
	background: rgba(255,255,255,0.08);
	border: 1px solid rgba(255,255,255,0.08);
	border-radius: 12px;
	overflow: hidden;
	max-width: 1280px;
	margin: 24px auto 0;
	position: relative;
	z-index: 2;
	background-color: var(--ccb-forest);
}
.ccb-qf-item {
	background: var(--ccb-forest);
	padding: 20px 24px;
}
.ccb-qf-label {
	font-family: 'JetBrains Mono', monospace;
	font-size: 10px;
	letter-spacing: 0.12em;
	color: var(--ccb-leaf-soft);
	text-transform: uppercase;
	margin-bottom: 8px;
}
.ccb-qf-value {
	font-family: 'Fraunces', serif;
	font-size: 18px;
	font-weight: 500;
	color: var(--ccb-cream);
	letter-spacing: -0.01em;
}
/* Hero quick-fact values that link out (Category, Producer Province) — cream with an amber underline */
.ccb-qf-value a {
	color: inherit;
	text-decoration: none;
	border-bottom: 1px solid rgba(200, 151, 63, 0.45);
	transition: color 0.15s, border-color 0.15s;
}
.ccb-qf-value a:hover {
	color: var(--ccb-amber);
	border-bottom-color: var(--ccb-amber);
}

/* Body content */
.ccb-bd-body {
	padding: 48px 32px 80px;
	background: var(--ccb-cream);
}
.ccb-sidebar-card .ccb-info-row .v a {
	color: inherit;
	text-decoration: none;
}
.ccb-sidebar-card .ccb-info-row .v a:hover {
	color: var(--ccb-forest);
}
.ccb-bd-body-inner {
	max-width: 1280px;
	margin: 0 auto;
	display: grid;
	grid-template-columns: 1fr 320px;
	gap: 60px;
}

.ccb-bd-section { margin-bottom: 48px; }
.ccb-bd-section-title {
	font-size: 28px;
	font-weight: 500;
	color: var(--ccb-forest);
	margin: 0 0 20px;
	display: flex;
	align-items: baseline;
	gap: 16px;
}
.ccb-bd-section-title .num {
	font-family: 'JetBrains Mono', monospace;
	font-size: 12px;
	color: var(--ccb-amber);
	letter-spacing: 0.1em;
	font-weight: 400;
}

.ccb-bd-description {
	font-size: 16px;
	line-height: 1.7;
	color: var(--ccb-ink-2);
}
.ccb-bd-description p { margin-bottom: 16px; }
.ccb-bd-description p:last-child { margin-bottom: 0; }

.ccb-bd-section-sparse .ccb-sparse-message {
	font-style: italic;
	color: var(--ccb-muted);
	font-size: 16px;
	line-height: 1.7;
	padding: 20px;
	background: var(--ccb-cream-2);
	border-radius: 8px;
	border-left: 3px solid var(--ccb-amber);
}

/* Products grid */
.ccb-product-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: 16px;
}
.ccb-product-card {
	background: var(--ccb-cream-2);
	border: 1px solid var(--ccb-rule);
	border-radius: 10px;
	padding: 20px;
	display: flex;
	gap: 16px;
}
.ccb-product-img {
	width: 80px; height: 80px;
	border-radius: 8px;
	flex-shrink: 0;
}
.ccb-product-name {
	font-family: 'Fraunces', serif;
	font-size: 17px;
	font-weight: 500;
	color: var(--ccb-forest);
	margin-bottom: 4px;
}
.ccb-product-format {
	font-size: 11px;
	color: var(--ccb-muted);
	font-family: 'JetBrains Mono', monospace;
	letter-spacing: 0.04em;
	margin-bottom: 8px;
}
.ccb-product-thc {
	font-size: 12px;
	color: var(--ccb-ink-2);
}
.ccb-product-thc strong { color: var(--ccb-terracotta); font-weight: 600; }

/* Availability grid */
.ccb-availability-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(110px, 1fr));
	gap: 8px;
}
.ccb-avail-item {
	background: var(--ccb-cream-2);
	border: 1px solid var(--ccb-rule);
	border-radius: 8px;
	padding: 14px;
	text-align: center;
}
.ccb-avail-code {
	font-family: 'Fraunces', serif;
	font-size: 20px;
	color: var(--ccb-forest);
	font-weight: 500;
	margin-bottom: 4px;
}
.ccb-avail-name {
	font-size: 11px;
	color: var(--ccb-muted);
	font-family: 'JetBrains Mono', monospace;
	letter-spacing: 0.03em;
}
.ccb-avail-unavail {
	opacity: 0.35;
	background: transparent;
}
.ccb-avail-unavail .ccb-avail-name { color: var(--ccb-terracotta); }

/* Sidebar */
.ccb-bd-sidebar > div {
	background: var(--ccb-cream-2);
	border-radius: 12px;
	padding: 24px;
	margin-bottom: 16px;
	border: 1px solid var(--ccb-rule);
}
.ccb-bd-sidebar h4 {
	font-family: 'JetBrains Mono', monospace;
	font-size: 11px;
	color: var(--ccb-amber);
	letter-spacing: 0.12em;
	margin: 0 0 16px;
	text-transform: uppercase;
	font-weight: 500;
}
.ccb-info-row {
	display: flex;
	justify-content: space-between;
	padding: 10px 0;
	border-bottom: 1px solid var(--ccb-rule);
	font-size: 13px;
	gap: 12px;
}
.ccb-info-row:last-child { border-bottom: none; }
.ccb-info-row .k { color: var(--ccb-muted); white-space: nowrap; }
.ccb-info-row .v {
	color: var(--ccb-ink);
	font-weight: 500;
	text-align: right;
	overflow-wrap: break-word;
	word-break: break-word;
}

.ccb-related-brand {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 12px 0;
	border-bottom: 1px solid var(--ccb-rule);
	font-size: 13px;
	text-decoration: none;
	color: inherit;
	transition: opacity 0.2s;
}
.ccb-related-brand:hover { opacity: 0.7; color: inherit; }
.ccb-related-brand:last-child { border-bottom: none; }
.ccb-mini-logo {
	width: 36px; height: 36px;
	border-radius: 6px;
	display: flex;
	align-items: center;
	justify-content: center;
	font-family: 'Fraunces', serif;
	color: var(--ccb-cream);
	font-size: 13px;
	font-weight: 500;
	flex-shrink: 0;
}
.ccb-rb-name { font-weight: 500; color: var(--ccb-ink); }
.ccb-rb-cat { font-size: 11px; color: var(--ccb-muted); margin-top: 2px; }

/* ============================================================
 * BRAND DIRECTORY (ARCHIVE)
 * ============================================================ */

.ccb-directory-hero {
	background: var(--ccb-cream);
	padding: 60px 32px 40px;
	border-bottom: 1px solid var(--ccb-rule);
}
.ccb-directory-hero-inner { max-width: 1280px; margin: 0 auto; }
.ccb-directory-hero h1 {
	font-size: 56px;
	font-weight: 400;
	line-height: 1;
	margin: 0 0 16px;
	letter-spacing: -0.03em;
	color: var(--ccb-forest);
}
.ccb-directory-hero h1 em {
	font-style: italic;
	color: var(--ccb-terracotta);
	font-weight: 400;
}
.ccb-directory-hero .ccb-lead {
	font-size: 17px;
	color: var(--ccb-ink-2);
	max-width: 600px;
	margin: 0 0 32px;
}

.ccb-directory-search-bar {
	display: flex;
	gap: 10px;
	background: white;
	border: 1px solid var(--ccb-rule);
	border-radius: 12px;
	padding: 6px 6px 6px 18px;
	max-width: 720px;
	align-items: center;
	box-shadow: 0 4px 14px -4px rgba(0,0,0,0.06);
}
.ccb-directory-search-bar input[type="search"] {
	flex: 1;
	border: none;
	outline: none;
	padding: 10px 0;
	font-size: 15px;
	font-family: inherit;
	background: transparent;
}

.ccb-directory-body {
	background: var(--ccb-cream-2);
	padding: 40px 32px 80px;
}
.ccb-directory-layout {
	display: grid;
	grid-template-columns: 260px 1fr;
	gap: 40px;
	max-width: 1280px;
	margin: 0 auto;
}

.ccb-directory-filters {
	background: var(--ccb-cream);
	border: 1px solid var(--ccb-rule);
	border-radius: 12px;
	padding: 24px;
	position: sticky;
	top: 20px;
	align-self: start;
	max-height: calc(100vh - 40px);
	overflow-y: auto;
}
.ccb-filter-group { margin-bottom: 28px; }
.ccb-filter-group h4 {
	font-family: 'JetBrains Mono', monospace;
	font-size: 11px;
	color: var(--ccb-amber);
	letter-spacing: 0.12em;
	margin: 0 0 14px;
	text-transform: uppercase;
	font-weight: 500;
}
.ccb-filter-link {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 6px 0;
	font-size: 13px;
	color: var(--ccb-ink-2);
	text-decoration: none;
}
.ccb-filter-link:hover { color: var(--ccb-forest); }
.ccb-filter-link .count {
	font-family: 'JetBrains Mono', monospace;
	font-size: 11px;
	color: var(--ccb-muted);
}

.ccb-directory-results-head {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: 24px;
	flex-wrap: wrap;
	gap: 12px;
}
.ccb-results-count { font-size: 14px; color: var(--ccb-ink-2); }
.ccb-results-count strong { color: var(--ccb-forest); }
.ccb-sort-select {
	display: flex;
	align-items: center;
	gap: 10px;
	font-size: 13px;
	color: var(--ccb-muted);
}
.ccb-sort-select select {
	border: 1px solid var(--ccb-rule);
	background: white;
	border-radius: 6px;
	padding: 6px 12px;
	font-family: inherit;
	font-size: 13px;
}

.ccb-directory-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
	gap: 16px;
}

.ccb-dir-brand-card {
	background: var(--ccb-cream);
	border: 1px solid var(--ccb-rule);
	border-radius: 12px;
	overflow: hidden;
	display: flex;
	flex-direction: column;
	text-decoration: none;
	color: inherit;
	transition: transform 0.2s, box-shadow 0.2s;
}
.ccb-dir-brand-card:hover {
	transform: translateY(-2px);
	box-shadow: 0 8px 24px -8px rgba(0,0,0,0.1);
	color: inherit;
}

.ccb-dir-visual {
	height: 100px;
	display: flex;
	align-items: center;
	justify-content: center;
	font-family: 'Fraunces', serif;
	color: var(--ccb-cream);
	font-size: 24px;
	font-weight: 500;
	letter-spacing: -0.02em;
	overflow: hidden;
}
.ccb-dir-visual-logo {
	background: var(--ccb-cream-2);
}
.ccb-dir-visual-logo img {
	max-width: 70%;
	max-height: 70%;
	object-fit: contain;
}

.ccb-dir-info {
	padding: 16px;
	flex: 1;
	display: flex;
	flex-direction: column;
}
.ccb-dir-name {
	font-family: 'Fraunces', serif;
	font-size: 18px;
	font-weight: 500;
	color: var(--ccb-forest);
	margin-bottom: 2px;
	letter-spacing: -0.01em;
}
.ccb-dir-parent {
	font-size: 11px;
	color: var(--ccb-muted);
	font-family: 'JetBrains Mono', monospace;
	letter-spacing: 0.03em;
	margin-bottom: 10px;
}
.ccb-dir-tags {
	display: flex;
	flex-wrap: wrap;
	gap: 5px;
	margin-bottom: 12px;
}
.ccb-tag-sm {
	background: var(--ccb-cream-2);
	border-radius: 999px;
	padding: 2px 8px;
	font-size: 11px;
	color: var(--ccb-ink-2);
	font-weight: 500;
}
.ccb-dir-meta {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-top: auto;
	padding-top: 10px;
	border-top: 1px solid var(--ccb-rule);
	font-size: 11px;
	color: var(--ccb-muted);
	font-family: 'JetBrains Mono', monospace;
}
.ccb-prov-badge {
	background: var(--ccb-leaf-soft);
	color: var(--ccb-forest);
	padding: 2px 7px;
	border-radius: 3px;
	font-weight: 600;
}
.ccb-prov-badge-empty { background: transparent; color: var(--ccb-muted); }

/* Pagination */
.ccb-pagination {
	margin-top: 40px;
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 6px;
}
.ccb-pagination .page-numbers {
	min-width: 36px;
	height: 36px;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 6px;
	font-size: 13px;
	color: var(--ccb-ink);
	font-family: 'JetBrains Mono', monospace;
	text-decoration: none;
	padding: 0 10px;
}
.ccb-pagination .page-numbers.current {
	background: var(--ccb-forest);
	color: var(--ccb-cream);
}
.ccb-pagination .page-numbers:hover {
	background: var(--ccb-cream);
}

.ccb-no-results {
	text-align: center;
	padding: 60px 20px;
	color: var(--ccb-muted);
	font-size: 16px;
}

/* ============================================================
 * RESPONSIVE — Mobile
 * ============================================================ */

@media (max-width: 900px) {

	/* Single brand */
	.ccb-bd-hero { padding: 32px 16px 0; }
	.ccb-bd-header {
		grid-template-columns: 1fr;
		gap: 20px;
	}
	.ccb-bd-logo,
	.ccb-bd-logo-mark {
		width: 90px; height: 90px;
		font-size: 36px;
	}
	.ccb-bd-meta h1 { font-size: 40px; }
	.ccb-bd-meta .ccb-tagline { font-size: 14px; }
	.ccb-bd-actions { flex-direction: row; }
	.ccb-bd-actions .ccb-btn {
		flex: 1; text-align: center;
		padding: 10px 14px; font-size: 13px;
	}
	.ccb-bd-quickfacts {
		grid-template-columns: 1fr 1fr;
		margin: 24px 16px 0;
		transform: none;
	}
	.ccb-qf-item { padding: 14px 16px; }
	.ccb-qf-value { font-size: 15px; }
	.ccb-bd-body {
		padding: 32px 16px 40px;
	}
	.ccb-bd-body-inner {
		grid-template-columns: 1fr;
		gap: 32px;
	}
	.ccb-bd-section-title { font-size: 22px; }
	.ccb-availability-grid {
		grid-template-columns: repeat(3, 1fr);
	}

	/* Directory */
	.ccb-directory-hero { padding: 32px 16px 24px; }
	.ccb-directory-hero h1 { font-size: 36px; }
	.ccb-directory-hero .ccb-lead { font-size: 14px; }
	.ccb-directory-search-bar {
		padding: 4px 4px 4px 14px;
		flex-wrap: nowrap;
	}
	.ccb-directory-search-bar input[type="search"] { font-size: 13px; min-width: 0; }
	.ccb-directory-body { padding: 24px 16px 40px; }
	.ccb-directory-layout {
		grid-template-columns: 1fr;
		gap: 24px;
	}
	.ccb-directory-filters {
		position: static;
		max-height: none;
	}
	.ccb-directory-grid {
		grid-template-columns: 1fr 1fr;
		gap: 10px;
	}
	.ccb-dir-visual { height: 80px; font-size: 18px; }
	.ccb-dir-info { padding: 12px; }
	.ccb-dir-name { font-size: 15px; }
	.ccb-dir-parent { font-size: 10px; }
	.ccb-tag-sm { font-size: 10px; padding: 1px 6px; }
	.ccb-dir-meta { font-size: 10px; padding-top: 8px; }
}

@media (max-width: 480px) {
	.ccb-directory-grid {
		grid-template-columns: 1fr;
	}
}

/* =============================================================
 * PREMIUM & PUBLIC LP — Badges, Pills, Filter Chips, Table
 * Added by the Premium tier system
 * ============================================================= */

/* Directory card corner badges */
.ccb-dir-brand-card { position: relative; }

.ccb-premium-corner {
	position: absolute;
	top: 8px;
	right: 8px;
	z-index: 2;
	width: 24px;
	height: 24px;
	background: var(--ccb-amber);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--ccb-forest);
	font-size: 12px;
	font-weight: 700;
	box-shadow: 0 2px 6px rgba(200, 151, 63, 0.4);
}
.ccb-premium-corner::before { content: "★"; }

.ccb-lp-corner {
	position: absolute;
	top: 8px;
	left: 8px;
	z-index: 2;
	background: #3A5566;
	color: #fff;
	padding: 3px 7px;
	border-radius: 4px;
	font-family: 'JetBrains Mono', monospace;
	font-size: 10px;
	font-weight: 600;
	letter-spacing: 0.05em;
	box-shadow: 0 2px 6px rgba(58, 85, 102, 0.3);
}

/* Pills on single brand page hero */
.ccb-premium-pill {
	display: inline-flex;
	align-items: center;
	background: var(--ccb-amber);
	color: var(--ccb-forest);
	padding: 4px 12px;
	border-radius: 999px;
	font-family: 'JetBrains Mono', monospace;
	font-size: 10px;
	font-weight: 600;
	letter-spacing: 0.1em;
	margin-left: 12px;
	vertical-align: middle;
	text-transform: uppercase;
	line-height: 1;
}

.ccb-lp-pill {
	display: inline-flex;
	align-items: center;
	background: rgba(255,255,255,0.1);
	color: var(--ccb-leaf-soft);
	border: 1px solid rgba(255,255,255,0.2);
	padding: 3px 11px;
	border-radius: 999px;
	font-family: 'JetBrains Mono', monospace;
	font-size: 10px;
	font-weight: 500;
	letter-spacing: 0.1em;
	margin-left: 8px;
	vertical-align: middle;
	text-transform: uppercase;
	line-height: 1;
}

/* Filter chips on directory hero */
.ccb-tier-filters {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin-bottom: 24px;
}

.ccb-tier-chip {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 7px 14px;
	border-radius: 999px;
	font-family: 'JetBrains Mono', monospace;
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 0.05em;
	text-decoration: none;
	transition: all 0.2s;
}

.ccb-tier-chip-premium {
	background: rgba(200, 151, 63, 0.12);
	color: var(--ccb-amber);
	border: 1px solid rgba(200, 151, 63, 0.3);
}
.ccb-tier-chip-premium:hover,
.ccb-tier-chip-premium.is-active {
	background: var(--ccb-amber);
	color: var(--ccb-forest);
}

.ccb-tier-chip-featured {
	background: rgba(74, 107, 79, 0.10);
	color: var(--ccb-forest);
	border: 1px solid rgba(74, 107, 79, 0.30);
}
.ccb-tier-chip-featured:hover,
.ccb-tier-chip-featured.is-active {
	background: var(--ccb-forest);
	color: var(--ccb-cream);
}

.ccb-tier-chip-lp {
	background: rgba(58, 85, 102, 0.08);
	color: #3A5566;
	border: 1px solid rgba(58, 85, 102, 0.25);
}
.ccb-tier-chip-lp:hover,
.ccb-tier-chip-lp.is-active {
	background: #3A5566;
	color: #fff;
}

.ccb-tier-chip-clear {
	background: transparent;
	color: var(--ccb-terracotta);
	border: 1px solid rgba(181, 87, 58, 0.35);
}
.ccb-tier-chip-clear:hover {
	background: var(--ccb-terracotta);
	color: var(--ccb-cream);
	border-color: var(--ccb-terracotta);
}

/* =============================================================
 * MAJOR CANNABIS PRODUCERS TABLE
 * Rendered by [ccb_major_cannabis_producers] shortcode (Snippet 06)
 * Uses the v2 design language: forest + cream + amber + terracotta,
 * Fraunces / DM Sans / JetBrains Mono. Structure: centered company
 * cell with name below image (linking to website), no Site column,
 * search box in top toolbar, read more as inline text.
 * ============================================================= */
.ccb-mcp-section {
	font-family: 'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif;
	color: var(--ccb-ink);
	margin: 56px 0 64px;
}
.ccb-mcp-head { margin-bottom: 24px; max-width: 760px; }
.ccb-mcp-eyebrow {
	font-family: 'JetBrains Mono', monospace;
	font-size: 11px;
	letter-spacing: 0.15em;
	text-transform: uppercase;
	color: var(--ccb-amber);
	margin-bottom: 12px;
}
.ccb-mcp-title {
	font-family: 'Fraunces', Georgia, serif;
	font-weight: 400;
	font-size: 38px;
	letter-spacing: -0.02em;
	color: var(--ccb-forest);
	margin: 0 0 10px;
	line-height: 1.05;
}
.ccb-mcp-title em { font-style: italic; color: var(--ccb-terracotta); font-weight: 400; }
.ccb-mcp-intro {
	font-size: 15px;
	color: var(--ccb-ink-2);
	line-height: 1.55;
	margin: 0;
}

/* Toolbar — cream pill matching the brand directory pattern */
.ccb-mcp-toolbar {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 16px;
	flex-wrap: wrap;
	margin: 0;
	padding: 12px 16px;
	background: var(--ccb-cream-2);
	border: 1px solid var(--ccb-rule);
	border-bottom: none;
	border-top-left-radius: 12px;
	border-top-right-radius: 12px;
}
.ccb-mcp-search-box {
	display: flex;
	align-items: center;
	gap: 10px;
	background: var(--ccb-cream);
	border: 1px solid var(--ccb-rule);
	border-radius: 999px;
	padding: 8px 14px;
	min-width: 240px;
	max-width: 360px;
	flex: 1;
}
.ccb-mcp-search-box svg { color: var(--ccb-muted); flex-shrink: 0; }
.ccb-mcp-search {
	border: none;
	outline: none;
	background: transparent;
	font-family: 'DM Sans', sans-serif;
	font-size: 14px;
	color: var(--ccb-ink);
	flex: 1;
}
.ccb-mcp-meta {
	font-family: 'JetBrains Mono', monospace;
	font-size: 11px;
	color: var(--ccb-muted);
	letter-spacing: 0.08em;
	text-transform: uppercase;
}
.ccb-mcp-count [data-mcp-count] { color: var(--ccb-forest); font-weight: 600; }

/* Table */
.ccb-mcp-table-wrap {
	background: var(--ccb-cream);
	border: 1px solid var(--ccb-rule);
	border-radius: 0 0 12px 12px;
	overflow: auto;
}
.ccb-mcp-table {
	width: 100%;
	border-collapse: separate;
	border-spacing: 0;
	font-family: 'DM Sans', sans-serif;
	font-size: 14px;
}
.ccb-mcp-table thead th {
	position: sticky;
	top: 0;
	background: var(--ccb-forest);
	text-align: left;
	padding: 14px 16px;
	font-family: 'JetBrains Mono', monospace;
	font-weight: 500;
	font-size: 11px;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--ccb-amber-soft);
	border-bottom: 1px solid rgba(255,255,255,0.06);
	white-space: nowrap;
	user-select: none;
}
.ccb-mcp-table th[data-sort] { cursor: pointer; }
.ccb-mcp-table th[data-sort]:hover { background: var(--ccb-forest-2); color: var(--ccb-cream); }
.ccb-mcp-table th .ccb-mcp-arrow {
	display: inline-block;
	width: 10px;
	margin-left: 4px;
	color: rgba(255,255,255,0.3);
}
.ccb-mcp-table th.is-sort-asc .ccb-mcp-arrow::after { content: "↑"; color: var(--ccb-amber); }
.ccb-mcp-table th.is-sort-desc .ccb-mcp-arrow::after { content: "↓"; color: var(--ccb-amber); }
.ccb-mcp-table tbody td {
	padding: 16px;
	border-bottom: 1px solid var(--ccb-rule);
	vertical-align: middle;
	color: var(--ccb-ink-2);
	line-height: 1.55;
}
.ccb-mcp-table tbody tr:last-child td { border-bottom: none; }
.ccb-mcp-table tbody tr:nth-child(even) td { background: rgba(242,237,226,0.45); }
.ccb-mcp-table tbody tr:hover td { background: rgba(200,151,63,0.08); }
.ccb-mcp-table tbody tr:target td { background: rgba(200,151,63,0.14); box-shadow: inset 3px 0 0 var(--ccb-amber); }

/* Company cell — vertical stack, image on top, name centered below */
.ccb-mcp-td-company {
	min-width: 160px;
	padding-right: 24px;
	text-align: center;
}
.ccb-mcp-company-link {
	display: inline-flex;
	flex-direction: column;
	align-items: center;
	gap: 8px;
	text-decoration: none;
	color: var(--ccb-forest);
}
.ccb-mcp-td-company > .ccb-mcp-thumb,
.ccb-mcp-td-company > .ccb-mcp-name {
	display: inline-flex;
	flex-direction: column;
	align-items: center;
	gap: 8px;
}
.ccb-mcp-thumb {
	width: 96px;
	height: 70px;
	border-radius: 8px;
	object-fit: cover;
	border: 1px solid var(--ccb-rule);
	background: var(--ccb-cream-2);
}
.ccb-mcp-thumb-empty {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: linear-gradient(135deg, var(--ccb-forest), var(--ccb-forest-2));
	color: var(--ccb-amber);
	font-family: 'Fraunces', serif;
	font-size: 24px;
	font-weight: 500;
	letter-spacing: -0.02em;
	border-color: var(--ccb-forest);
}
.ccb-mcp-name {
	font-family: 'Fraunces', Georgia, serif;
	font-weight: 500;
	font-size: 17px;
	line-height: 1.2;
	color: var(--ccb-forest);
	letter-spacing: -0.01em;
	text-align: center;
}
.ccb-mcp-company-link:hover .ccb-mcp-name { color: var(--ccb-terracotta); }

/* Description + read more */
.ccb-mcp-td-desc { max-width: 540px; font-size: 14px; }
.ccb-mcp-desc-text { display: inline; }
.ccb-mcp-expand {
	display: inline;
	font-family: 'DM Sans', sans-serif;
	font-size: 13px;
	font-weight: 500;
	color: var(--ccb-muted);
	cursor: pointer;
	margin-left: 4px;
	text-decoration: underline;
	text-underline-offset: 2px;
	text-decoration-color: var(--ccb-amber-soft);
}
.ccb-mcp-expand:hover { color: var(--ccb-forest); text-decoration-color: var(--ccb-amber); }

/* Ticker + HQ — JetBrains Mono, matching v2 brand-page sidebar style */
.ccb-mcp-table th.ccb-mcp-th-hq,
.ccb-mcp-table th.ccb-mcp-th-ticker { white-space: nowrap; }
.ccb-mcp-td-ticker,
.ccb-mcp-td-hq {
	font-family: 'JetBrains Mono', monospace;
	font-size: 12px;
	color: var(--ccb-ink-2);
	white-space: nowrap;
	letter-spacing: 0.02em;
}

.ccb-mcp-muted { color: var(--ccb-rule); }
.ccb-mcp-credit {
	margin-top: 12px;
	text-align: right;
}
.ccb-mcp-eyebrow-sm {
	font-family: 'JetBrains Mono', monospace;
	font-size: 10px;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--ccb-muted);
}
.ccb-mcp-empty {
	background: rgba(200,151,63,0.08);
	border-left: 3px solid var(--ccb-amber);
	border-radius: 0 6px 6px 0;
	padding: 14px 18px;
	color: var(--ccb-ink-2);
	font-size: 14px;
}
.ccb-mcp-empty code {
	background: var(--ccb-cream-2);
	padding: 1px 6px;
	border-radius: 3px;
	font-family: 'JetBrains Mono', monospace;
	font-size: 12px;
}

/* Mobile: stack as cards */
@media (max-width: 680px) {
	.ccb-mcp-title { font-size: 26px; }
	.ccb-mcp-intro { font-size: 14px; }
	.ccb-mcp-toolbar { flex-direction: column; align-items: stretch; gap: 10px; padding: 12px; }
	.ccb-mcp-search-box { max-width: none; }
	.ccb-mcp-table-wrap { background: transparent; border: none; border-radius: 0; padding: 0; overflow: visible; }
	.ccb-mcp-table thead { display: none; }
	.ccb-mcp-table, .ccb-mcp-table tbody, .ccb-mcp-table tr, .ccb-mcp-table td { display: block; width: 100%; }
	.ccb-mcp-table tbody tr {
		background: var(--ccb-cream);
		border: 1px solid var(--ccb-rule);
		border-radius: 10px;
		padding: 16px;
		margin-bottom: 12px;
	}
	.ccb-mcp-table tbody tr:nth-child(even) td { background: transparent; }
	.ccb-mcp-table tbody tr:hover td { background: transparent; }
	.ccb-mcp-table td { padding: 6px 0; border: none; background: transparent; }
	.ccb-mcp-td-company { padding-bottom: 12px; border-bottom: 1px solid var(--ccb-rule); margin-bottom: 10px; text-align: center; }
	.ccb-mcp-td-ticker::before {
		content: "Ticker · ";
		color: var(--ccb-muted);
		font-family: 'JetBrains Mono', monospace;
		font-size: 10px;
		letter-spacing: 0.12em;
		text-transform: uppercase;
	}
	.ccb-mcp-td-hq::before {
		content: "HQ · ";
		color: var(--ccb-muted);
		font-family: 'JetBrains Mono', monospace;
		font-size: 10px;
		letter-spacing: 0.12em;
		text-transform: uppercase;
	}
}

/* =============================================================
 * PREMIUM BRANDS TABLE — Replaces Aiboostify plugin
 * Used by [ccb_premium_brands_table] shortcode
 * ============================================================= */
.ccb-pbt-wrapper {
	font-family: 'DM Sans', -apple-system, sans-serif;
	color: var(--ccb-ink);
	margin: 0 0 24px;
}
.ccb-pbt-toolbar {
	display: flex;
	justify-content: flex-end;
	background: var(--ccb-cream-2);
	padding: 12px 16px;
	border: 1px solid var(--ccb-rule);
	border-bottom: none;
	border-radius: 12px 12px 0 0;
}
.ccb-pbt-search {
	padding: 10px 16px;
	border: 1px solid var(--ccb-rule);
	border-radius: 999px;
	background: #fff;
	font-family: inherit;
	font-size: 14px;
	color: var(--ccb-ink);
	min-width: 260px;
	outline: none;
	transition: border-color 0.2s;
}
.ccb-pbt-search:focus {
	border-color: var(--ccb-amber);
	box-shadow: 0 0 0 3px rgba(200, 151, 63, 0.12);
}
.ccb-pbt-search::placeholder { color: var(--ccb-muted); }
.ccb-pbt-scroll {
	overflow: auto;
	border: 1px solid var(--ccb-rule);
	border-radius: 0 0 12px 12px;
	background: #fff;
}
.ccb-pbt-table {
	width: 100%;
	border-collapse: separate;
	border-spacing: 0;
	font-size: 14px;
}
.ccb-pbt-table thead th {
	position: sticky;
	top: 0;
	background: var(--ccb-cream-2);
	text-align: left;
	padding: 14px 16px;
	font-family: 'JetBrains Mono', monospace;
	font-size: 11px;
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--ccb-muted);
	border-bottom: 1px solid var(--ccb-rule);
	cursor: pointer;
	user-select: none;
	transition: color 0.2s;
	white-space: nowrap;
}
.ccb-pbt-table thead th:hover { color: var(--ccb-forest); }
.ccb-pbt-table thead th[data-key="description"] { cursor: default; }
.ccb-pbt-table thead th[data-asc="true"],
.ccb-pbt-table thead th[data-asc="false"] { color: var(--ccb-forest); }
.ccb-pbt-sort { color: var(--ccb-amber); font-size: 10px; display: inline-block; }
.ccb-pbt-table tbody td {
	padding: 16px;
	border-bottom: 1px solid var(--ccb-rule);
	vertical-align: middle;
	color: var(--ccb-ink-2);
	line-height: 1.5;
}
.ccb-pbt-table tbody tr:last-child td { border-bottom: none; }
.ccb-pbt-table tbody tr:hover { background: var(--ccb-cream); }
.ccb-pbt-table td a {
	color: var(--ccb-forest);
	text-decoration: none;
	border-bottom: 1px solid transparent;
	transition: border-color 0.2s;
}
.ccb-pbt-table td a:hover { border-bottom-color: var(--ccb-amber); }
.ccb-pbt-brand {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 8px;
	text-align: center;
	max-width: 140px;
}
.ccb-pbt-brand:hover { border-bottom-color: transparent !important; }
.ccb-pbt-brand-name {
	font-family: 'Fraunces', Georgia, serif;
	font-size: 15px;
	font-weight: 500;
	color: var(--ccb-forest);
	line-height: 1.2;
	letter-spacing: -0.01em;
	display: inline-flex;
	align-items: center;
	gap: 6px;
	flex-wrap: wrap;
	justify-content: center;
}
.ccb-pbt-brand:hover .ccb-pbt-brand-name { color: var(--ccb-terracotta); text-decoration: underline; text-underline-offset: 3px; }
.ccb-pbt-brand img {
	width: 96px;
	height: 70px;
	border-radius: 6px;
	object-fit: cover;
	border: 1px solid var(--ccb-rule);
	background: var(--ccb-cream-2);
}
.ccb-pbt-thumb-fallback {
	width: 96px;
	height: 70px;
	border-radius: 6px;
	border: 1px solid var(--ccb-rule);
	display: flex;
	align-items: center;
	justify-content: center;
	font-family: 'Fraunces', serif;
	color: var(--ccb-cream);
	font-size: 24px;
	font-weight: 500;
	letter-spacing: -0.02em;
}
.ccb-pbt-lp-badge {
	display: inline-block;
	background: #3A5566;
	color: #fff;
	padding: 1px 6px;
	border-radius: 3px;
	font-family: 'JetBrains Mono', monospace;
	font-size: 9px;
	font-weight: 600;
	letter-spacing: 0.08em;
	vertical-align: middle;
	cursor: help;
}
.ccb-pbt-table td[data-key="description"] {
	font-size: 13px;
	color: var(--ccb-ink-2);
	line-height: 1.5;
	max-width: 380px;
}
.ccb-pbt-table td[data-key="ticker"] {
	font-family: 'JetBrains Mono', monospace;
	font-size: 12px;
	color: var(--ccb-forest);
	font-weight: 500;
	white-space: nowrap;
}
.ccb-pbt-table td[data-key="hq"] {
	font-size: 13px;
	color: var(--ccb-ink-2);
	white-space: nowrap;
}
.ccb-pbt-table td[data-key="site"] a { font-size: 13px; }
.ccb-pbt-empty {
	padding: 32px;
	text-align: center;
	background: var(--ccb-cream-2);
	border: 1px solid var(--ccb-rule);
	border-radius: 12px;
	color: var(--ccb-muted);
	font-style: italic;
}
@media (max-width: 680px) {
	.ccb-pbt-toolbar { padding: 10px 12px; }
	.ccb-pbt-search { min-width: 0; width: 100%; }
	.ccb-pbt-table thead { display: none; }
	.ccb-pbt-table,
	.ccb-pbt-table tbody,
	.ccb-pbt-table tr,
	.ccb-pbt-table td { display: block; width: 100%; }
	.ccb-pbt-table tr {
		padding: 16px;
		border-bottom: 1px solid var(--ccb-rule);
	}
	.ccb-pbt-table tbody td { border-bottom: none; padding: 4px 0; }
	.ccb-pbt-table tbody td:not([data-key="brand"]):not([data-key="description"])::before {
		content: attr(data-key) ": ";
		text-transform: uppercase;
		font-family: 'JetBrains Mono', monospace;
		font-size: 10px;
		letter-spacing: 0.08em;
		color: var(--ccb-muted);
		margin-right: 6px;
	}
	.ccb-pbt-brand {
		flex-direction: row;
		align-items: center;
		gap: 12px;
		max-width: none;
		margin-bottom: 10px;
	}
	.ccb-pbt-brand img,
	.ccb-pbt-thumb-fallback {
		width: 60px;
		height: 44px;
		flex-shrink: 0;
	}
	.ccb-pbt-brand-name { text-align: left; font-size: 16px; }
	.ccb-pbt-table td[data-key="description"] { margin: 8px 0; font-size: 13px; }
}

/* =============================================================
 * Brand Research display (partial) — social links
 * Added by Snippet 05 partial patches
 * ============================================================= */

.ccb-bd-social {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin-top: 18px;
}

.ccb-social-link {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	padding: 6px 12px;
	background: rgba(255, 255, 255, 0.08);
	border: 1px solid rgba(255, 255, 255, 0.15);
	border-radius: 999px;
	color: var(--ccb-leaf-soft);
	text-decoration: none;
	font-family: 'JetBrains Mono', monospace;
	font-size: 11px;
	letter-spacing: 0.05em;
	transition: all 0.2s;
}

.ccb-social-link:hover {
	background: rgba(200, 151, 63, 0.2);
	border-color: var(--ccb-amber);
	color: var(--ccb-cream);
}

.ccb-social-instagram::before { content: "📷 "; font-size: 10px; }
.ccb-social-facebook::before  { content: "f "; font-weight: 700; }
.ccb-social-tiktok::before    { content: "♪ "; }
.ccb-social-linkedin::before  { content: "in "; font-weight: 700; font-style: italic; }

@media (max-width: 900px) {
	.ccb-bd-social { gap: 6px; }
	.ccb-social-link { padding: 5px 10px; font-size: 10px; }
}

/* =============================================================================
 * [ccb_brands_table] — province brands table (Snippet 22)
 * Matches the Data Manager v2 table skin: forest header with mono uppercase
 * left-aligned labels, cream body, #E5DFD2 rules, rounded corners + soft shadow.
 * ========================================================================== */
.ccb-bt-wrap { font-family: 'DM Sans', sans-serif; margin: 24px 0; }
.ccb-bt-toolbar { display: flex; align-items: center; gap: 12px; margin: 0 0 12px; flex-wrap: wrap; }
.ccb-bt-search {
	font-family: 'DM Sans', sans-serif; font-size: 14px; color: #131814;
	background: #FAF7F2; border: 1px solid #E5DFD2; border-radius: 999px;
	padding: 10px 16px; min-width: 260px; max-width: 100%;
}
.ccb-bt-search:focus { outline: none; border-color: #1A2B1F; }
.ccb-bt-count { font-size: 13px; color: #6B736D; }

.ccb-bt-scroll {
	border: 1px solid #E5DFD2; border-radius: 12px;
	box-shadow: 0 8px 20px rgba(26, 43, 31, 0.06);
}
.ccb-bt-table { width: 100%; border-collapse: collapse; background: #FAF7F2; }
.ccb-bt-table thead th {
	background: #1A2B1F; color: #FAF7F2;
	font-family: 'JetBrains Mono', monospace; font-size: 11px;
	letter-spacing: 0.12em; text-transform: uppercase; font-weight: 500;
	text-align: left; padding: 14px 18px; white-space: nowrap;
	position: sticky; top: 0; z-index: 3; cursor: default;
}
.ccb-bt-table thead th[tabindex] { cursor: pointer; }
.ccb-bt-table thead th:first-child { border-top-left-radius: 12px; }
.ccb-bt-table thead th:last-child { border-top-right-radius: 12px; }
.ccb-bt-table thead th, .ccb-bt-table thead th * { color: #FAF7F2 !important; }
.ccb-bt-table td {
	padding: 14px 18px; font-size: 14px; color: #2A312C;
	border-bottom: 1px solid #E5DFD2; vertical-align: top; text-align: left;
}
.ccb-bt-table tbody tr:hover { background: #F2EDE2; }
.ccb-bt-table tbody tr:last-child td { border-bottom: none; }
.ccb-bt-table tbody tr:last-child td:first-child { border-bottom-left-radius: 12px; }
.ccb-bt-table tbody tr:last-child td:last-child { border-bottom-right-radius: 12px; }
.ccb-bt-brand { font-weight: 600; color: #1A2B1F; text-decoration: none; }
.ccb-bt-brand:hover { color: #B5573A; }
.ccb-bt-table td a { color: #B5573A; text-decoration: none; }
.ccb-bt-table td a:hover { color: #1A2B1F; }
.ccb-bt-empty { padding: 16px; color: #6B736D; }
@media (max-width: 900px) {
	.ccb-bt-scroll { overflow-x: auto; }
	.ccb-bt-table { font-size: 13px; }
	.ccb-bt-table thead th, .ccb-bt-table td { padding: 10px 12px; }
}