/**
 * Banaco shop – tokens aligned to design mockup
 *
 * Mockup reference:
 * - Page bg:     #f8f8f8
 * - Card/panel:  #ffffff + soft shadow
 * - Text:        #222 / muted #777
 * - Accent:      #1a8769 (active category bar)
 * - Grid gutter: 24px
 * - Sidebar gap: 40px from main, 20px between panels
 */

:root {
	--banaco-text: #222222;
	--banaco-muted: #777777;
	--banaco-bg: #f8f8f8;
	--banaco-white: #ffffff;
	--banaco-border: #e8e8e8;
	--banaco-accent: #1a8769;
	--banaco-primary: #1a8769;
	--banaco-image-bg: #f5f0e8;

	/* Spacing scale (8px base) */
	--banaco-space-xs: 8px;
	--banaco-space-sm: 12px;
	--banaco-space-md: 16px;
	--banaco-space-lg: 24px;
	--banaco-space-xl: 32px;
	--banaco-space-2xl: 48px;

	--banaco-sidebar-gap: 40px;
	--banaco-panel-gap: 20px;
	--banaco-grid-gutter: 24px;
	--banaco-radius-sm: 4px;
	--banaco-radius-md: 6px;
	--banaco-shadow-card: 0 1px 3px rgba(0, 0, 0, 0.06), 0 1px 2px rgba(0, 0, 0, 0.04);
}

/* ─── Page ─── */
body.banaco-shop-layout {
	background: var(--banaco-bg);
}

body.banaco-shop-layout .shop-container,
body.banaco-shop-layout #wrapper,
body.banaco-shop-layout .page-wrapper,
body.banaco-shop-layout .shop-container .row-main {
	background: var(--banaco-bg);
}

body.banaco-shop-layout .shop-container {
	padding-top: 0;
	background: transparent !important;
}

body.banaco-shop-layout .shop-page-title.category-page-title {
	display: none !important;
}

/* Cùng container Flatsome với phần còn lại của trang */
body.banaco-shop-layout .banaco-shop-container {
	background: transparent;
	padding-top: var(--banaco-space-xl);
	padding-bottom: var(--banaco-space-2xl);
}

.banaco-shop-shell {
	background: transparent;
}

/* ─── Top banner (UX Block) – full width, sibling of .banaco-shop-container ─── */
.banaco-shop-banner-wrap {
	width: 100vw;
	max-width: 100vw;
	position: relative;
	left: 50%;
	right: 50%;
	margin-left: -50vw;
	margin-right: -50vw;
	margin-bottom: var(--banaco-space-lg);
	overflow: hidden;
}

.banaco-shop-banner-wrap .banaco-shop-banner,
.banaco-shop-banner-wrap .ux-block,
.banaco-shop-banner-wrap .banner,
.banaco-shop-banner-wrap .row {
	width: 100%;
	max-width: none;
}

.banaco-shop-banner-wrap .banner-inner,
.banaco-shop-banner-wrap .ux-banner {
	border-radius: 0;
}

.banaco-shop-banner .ux-block,
.banaco-shop-banner .banner {
	margin-bottom: 0;
}

/* ─── Breadcrumbs: trong .container, trên grid ─── */
.banaco-shop-topbar-row {
	margin-bottom: var(--banaco-space-lg);
}

.banaco-shop-topbar-row > .col {
	padding-bottom: 0;
}

.banaco-breadcrumb {
	display: block;
	width: 100%;
	background: transparent !important;
}
	font-size: 13px;
	line-height: 1.5;
	color: var(--banaco-muted);
	margin: 0;
}

.banaco-breadcrumb a {
	color: var(--banaco-muted);
	text-decoration: none;
}

.banaco-breadcrumb a:hover {
	color: var(--banaco-text);
}

.banaco-breadcrumb .breadcrumb_last,
.banaco-breadcrumb strong {
	color: var(--banaco-text);
	font-weight: 400;
}

.banaco-breadcrumb__sep {
	margin: 0 6px;
	color: #aaa;
}

/* ─── Grid (sidebar ~25% / main ~75%) ─── */
body.banaco-shop-layout .banaco-shop-grid {
	align-items: flex-start;
}

body.banaco-shop-layout .banaco-shop-sidebar-col {
	padding-right: var(--banaco-sidebar-gap);
}

body.banaco-shop-layout .banaco-shop-sidebar-col > .col-inner {
	padding: 0;
}

body.banaco-shop-layout .banaco-shop-main,
body.banaco-shop-layout .banaco-shop-main > .shop-container,
body.banaco-shop-layout .banaco-shop-main #primary,
body.banaco-shop-layout .banaco-shop-main .site-main {
	padding-left: 0;
	background: transparent !important;
	box-shadow: none !important;
}

body.banaco-shop-layout .banaco-shop-main .shop-container {
	padding: 0 !important;
	margin: 0 !important;
	max-width: none !important;
}

/* ─── Sidebar panels (white on #f8f8f8, soft elevation) ─── */
body.banaco-shop-layout .banaco-shop-sidebar,
body.banaco-shop-layout #shop-sidebar {
	background: transparent;
	border: none;
	padding: 0;
	margin: 0;
}

.banaco-shop-sidebar-panels {
	display: flex;
	flex-direction: column;
	gap: var(--banaco-panel-gap);
}

.banaco-sidebar-panel {
	background: var(--banaco-white);
	border: 1px solid var(--banaco-border);
	border-radius: var(--banaco-radius-md);
	box-shadow: var(--banaco-shadow-card);
	padding: var(--banaco-space-lg) 20px;
}

.banaco-sidebar-heading {
	font-size: 13px;
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--banaco-text);
	margin: 0 0 var(--banaco-space-md);
	line-height: 1.2;
}

/* ─── Categories ─── */
.banaco-sidebar-panel--categories {
	position: relative;
	overflow: visible;
}

.banaco-category-list {
	list-style: none;
	margin: 0;
	padding: 0;
}

.banaco-category-item {
	margin: 0;
	position: relative;
}

.banaco-category-item a {
	display: block;
	padding: 6px 16px 6px 0;
	font-size: 15px;
	font-weight: 400;
	color: var(--banaco-text);
	text-decoration: none;
	line-height: 1.5;
}

.banaco-category-item a:hover {
	color: var(--banaco-accent);
}

.banaco-category-item.is-active a {
	font-weight: 700;
	color: var(--banaco-text);
}

/* Active bar: flush right edge of panel, accent green */
.banaco-category-item.is-active::after {
	content: '';
	position: absolute;
	top: 3px;
	bottom: 3px;
	right: -20px;
	width: 3px;
	background: var(--banaco-accent);
	border-radius: 1px;
}

/* ─── Filters ─── */
.banaco-filter-group {
	margin: 0 0 var(--banaco-space-md);
}

.banaco-filter-group:last-of-type {
	margin-bottom: var(--banaco-space-lg);
}

.banaco-filter-group-title {
	font-size: 15px;
	font-weight: 700;
	color: var(--banaco-text);
	margin: 0 0 var(--banaco-space-sm);
	line-height: 1.35;
}

.banaco-filter-list {
	list-style: none;
	margin: 0;
	padding: 0;
}

.banaco-filter-list li {
	margin: 0 0 var(--banaco-space-xs);
}

.banaco-filter-item {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	text-decoration: none;
	color: var(--banaco-text);
	font-size: 15px;
	font-weight: 400;
	line-height: 1.45;
}

.banaco-filter-item:hover {
	color: var(--banaco-accent);
}

.banaco-filter-checkbox {
	flex-shrink: 0;
	width: 15px;
	height: 15px;
	margin-top: 3px;
	border: 1.5px solid #333;
	border-radius: 2px;
	background: var(--banaco-white);
	position: relative;
}

.banaco-filter-item.is-active .banaco-filter-checkbox {
	background: var(--banaco-accent);
	border-color: var(--banaco-accent);
}

.banaco-filter-item.is-active .banaco-filter-checkbox::after {
	content: '';
	position: absolute;
	left: 4px;
	top: 1px;
	width: 4px;
	height: 8px;
	border: solid var(--banaco-white);
	border-width: 0 2px 2px 0;
	transform: rotate(45deg);
}

.banaco-filter-reset {
	display: block;
	width: 100%;
	margin: 0;
	padding: 12px 16px;
	text-align: center;
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	text-decoration: none;
	color: var(--banaco-text);
	background: var(--banaco-white);
	border: 1px solid #333;
	border-radius: var(--banaco-radius-sm);
	box-sizing: border-box;
	line-height: 1.2;
}

.banaco-filter-reset:hover {
	background: #fafafa;
	color: var(--banaco-text);
}

/* ─── Toolbar (24px below, 13px muted text) ─── */
.banaco-shop-toolbar {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--banaco-space-md);
	margin-bottom: var(--banaco-space-lg);
}

.banaco-shop-toolbar .woocommerce-result-count,
.banaco-shop-toolbar .banaco-result-count {
	margin: 0;
	font-size: 13px;
	color: var(--banaco-muted);
	display: block !important;
	font-weight: 400;
}

.banaco-shop-toolbar__sort {
	display: flex;
	align-items: center;
	gap: var(--banaco-space-xs);
	flex-shrink: 0;
}

.banaco-sort-label {
	font-size: 13px;
	color: var(--banaco-muted);
	white-space: nowrap;
}

.banaco-shop-toolbar .woocommerce-ordering {
	margin: 0;
	float: none;
}

.banaco-shop-toolbar .woocommerce-ordering select {
	font-size: 13px;
	border: 1px solid var(--banaco-border);
	border-radius: var(--banaco-radius-sm);
	padding: 8px 36px 8px 12px;
	min-height: 38px;
	background: var(--banaco-white);
	color: var(--banaco-text);
	min-width: 130px;
	box-shadow: none;
}

/* ─── Product grid (24px gutter) ─── */
body.banaco-shop-layout .banaco-shop-main .products.row {
	margin-left: calc(var(--banaco-grid-gutter) / -2);
	margin-right: calc(var(--banaco-grid-gutter) / -2);
}

body.banaco-shop-layout .banaco-shop-main .products.row > .product-small.col {
	padding: 0 calc(var(--banaco-grid-gutter) / 2) var(--banaco-grid-gutter);
}

body.banaco-shop-layout .product-small > .col-inner {
	padding: 0;
	background: transparent;
}

@media (min-width: 850px) {
	body.banaco-shop-layout .filter-button {
		display: none !important;
	}
}

@media (max-width: 849px) {
	body.banaco-shop-layout .banaco-shop-container {
		padding-left: 14px;
		padding-right: 14px;
	}

	body.banaco-shop-layout .banaco-shop-shell > .row {
		margin-left: 0;
		margin-right: 0;
	}

	body.banaco-shop-layout .banaco-shop-shell > .row > .col {
		padding-left: 0;
		padding-right: 0;
	}

	body.banaco-shop-layout .banaco-shop-main .products.row {
		margin-left: -6px;
		margin-right: -6px;
	}

	body.banaco-shop-layout .banaco-shop-main .products.row > .product-small.col {
		padding: 0 6px 12px;
	}

	body.banaco-shop-layout .banaco-shop-sidebar-col {
		padding-right: 0;
		margin-bottom: var(--banaco-space-lg);
	}

	.banaco-shop-toolbar {
		flex-wrap: wrap;
	}

	.banaco-shop-toolbar__sort {
		width: 100%;
		justify-content: space-between;
	}

	.banaco-category-item.is-active::after {
		right: 0;
	}
}
