/**
 * PCTC Tabs Carousel – Styles
 */

.pctc-widget {
	--pctc-tab-bg: #f0f0f0;
	--pctc-tab-color: #333;
	--pctc-tab-active-bg: #f5d033;
	--pctc-tab-active-color: #fff;
	--pctc-header-color: #222;
	--pctc-accent-bar: #f5d033;
	--pctc-price-color: #c00;
	--pctc-sale-percent-bg: #ffe9e2;
	--pctc-sale-percent-color: #f65723;
	--pctc-spacing: 16px;
	box-sizing: border-box;
}

.pctc-widget *,
.pctc-widget *::before,
.pctc-widget *::after {
	box-sizing: border-box;
}

.pctc-empty {
	margin: 0;
	padding: 1em;
	text-align: center;
	color: #666;
}

/* Header: accent bar + title + view all */
.pctc-header {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 12px;
	margin-bottom: 16px;
}

.pctc-header-accent {
	width: 6px;
	min-width: 6px;
	height: 1.2em;
	background-color: var(--pctc-accent-bar);
	border-radius: 2px;
}

.pctc-header-title {
	margin: 0;
	font-size: 20px !important;
	border-right: 1px solid #cccccc;
    padding-right: 16px;
	font-weight: 700;
	color: var(--pctc-header-color);
	text-transform: uppercase;
	letter-spacing: 0.02em;
}

.pctc-view-all {
	font-size: 0.9rem;
	color: #555;
	text-decoration: none;
	margin-left: auto;
	display: inline-flex;
	align-items: center;
	gap: 4px;
}

.pctc-view-all:hover {
	text-decoration: underline;
	color: #333;
}

/* Nút Xem tất cả dưới carousel – ẩn desktop, hiển thị mobile */
.pctc-view-all-bottom {
	display: none;
}

/* Mobile: nút Xem tất cả xuống dưới sản phẩm + căn giữa + danh mục con trượt ngang */
@media (max-width: 767px) {
	/* Ẩn nút Xem tất cả trong header */
	.pctc-header .pctc-view-all {
		display: none;
	}

	/* Hiển thị nút Xem tất cả dưới carousel, căn giữa */
	.pctc-view-all-bottom {
		display: flex;
		justify-content: center;
		margin-top: 16px;
		margin-bottom: 8px;
	}
	.pctc-view-all-bottom .pctc-view-all {
		margin-left: 0;
	}

	/* Danh mục con cùng một hàng, trượt ngang khi vượt chiều rộng */
	.pctc-tabs {
		flex-wrap: nowrap !important;
		overflow-x: auto !important;
		-webkit-overflow-scrolling: touch;
		max-width: 100% !important;
		min-width: 0 !important;
	}
	.pctc-tab {
		flex-shrink: 0;
		white-space: nowrap;
	}
}

.pctc-view-all-icon,
.pctc-view-all-arrow {
	display: inline-flex;
	align-items: center;
	vertical-align: middle;
}

.pctc-view-all-icon svg {
	width: 1em;
	height: 1em;
}

/* Tabs – nằm cùng hàng với tiêu đề trong .pctc-header */
.pctc-tabs {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	flex: 1 1 auto;
	min-width: 0;
	align-items: center;
}

.pctc-tab {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 8px 16px;
	font-size: 0.9rem !important;
	font-weight: 500 !important;
	border: none;
	background-color: var(--pctc-tab-bg);
	color: var(--pctc-tab-color);
	border-radius: 6px;
	cursor: pointer;
	transition: background-color 0.2s, color 0.2s;
}

.pctc-tab:hover {
	opacity: 0.9;
}

.pctc-tab.is-active {
	background-color: var(--pctc-tab-active-bg);
	color: var(--pctc-tab-active-color);
}

/* Filter row */
.pctc-filter-row {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 16px;
	margin-bottom: 16px;
	font-size: 0.9rem;
	color: #555;
}

.pctc-sale-filter {
	display: inline-flex;
	align-items: center;
	gap: 8px;
}

.pctc-sale-filter-label {
	font-size: 0.9rem;
	color: #555;
	white-space: nowrap;
	line-height: 1;
	align-self: center;
}

/* Toggler thay checkbox Giảm giá – nhấn cả track lẫn chữ đều bật/tắt */
.pctc-sale-toggler {
	margin: 0;
	flex-shrink: 0;
}

.pctc-sale-toggler .pctc-sale-checkbox {
	display: none;
}

.pctc-sale-toggler label {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	cursor: pointer;
}

.pctc-sale-toggler .pctc-toggler-track {
	position: relative;
	display: block;
	width: 48px;
	min-width: 48px;
	height: 24px;
	border: 1px solid #d6d6d6;
	border-radius: 24px;
	background: #e4e8e8;
	box-sizing: border-box;
}

.pctc-sale-toggler .pctc-toggler-track::after {
	display: block;
	box-sizing: border-box;
	border-radius: 50%;
	background-color: #d7062a;
	content: '';
	animation-name: pctc-toggler-size;
	animation-duration: 0.15s;
	animation-timing-function: ease-out;
	animation-direction: forwards;
	animation-iteration-count: 1;
	animation-play-state: running;
	min-width: 18px;
	min-height: 18px;
}

.pctc-sale-toggler .pctc-toggler-track::after,
.pctc-sale-toggler .pctc-toggler-track .toggler-on,
.pctc-sale-toggler .pctc-toggler-track .toggler-off {
	position: absolute;
	top: 50%;
	left: 25%;
	width: 18px;
	height: 18px;
	min-width: 18px;
	min-height: 18px;
	transform: translateY(-50%) translateX(-50%);
	transition: left 0.15s ease-in-out, background-color 0.2s ease-out, width 0.15s ease-in-out, height 0.15s ease-in-out, opacity 0.15s ease-in-out;
}

.pctc-sale-toggler .pctc-sale-checkbox:checked + label .pctc-toggler-track::after,
.pctc-sale-toggler .pctc-sale-checkbox:checked + label .pctc-toggler-track .toggler-on,
.pctc-sale-toggler .pctc-sale-checkbox:checked + label .pctc-toggler-track .toggler-off {
	left: 75%;
}

.pctc-sale-toggler .pctc-sale-checkbox:checked + label .pctc-toggler-track::after {
	background-color: #50ac5d;
	animation-name: pctc-toggler-size2;
}

.pctc-sale-toggler .pctc-toggler-track .toggler-on,
.pctc-sale-toggler .pctc-toggler-track .toggler-off {
	opacity: 1;
	z-index: 2;
}

.pctc-sale-toggler .pctc-sale-checkbox:checked + label .pctc-toggler-track .toggler-off,
.pctc-sale-toggler .pctc-sale-checkbox:not(:checked) + label .pctc-toggler-track .toggler-on {
	width: 0;
	height: 0;
	opacity: 0;
}

.pctc-sale-toggler .path {
	fill: none;
	stroke: #fefefe;
	stroke-width: 5px;
	stroke-linecap: round;
	stroke-miterlimit: 10;
}

@keyframes pctc-toggler-size {
	0%, 100% { width: 18px; height: 18px; }
	50% { width: 14px; height: 14px; }
}

@keyframes pctc-toggler-size2 {
	0%, 100% { width: 18px; height: 18px; }
	50% { width: 14px; height: 14px; }
}

/* Carousel wrap */
.pctc-carousel-wrap {
	position: relative;
}

.pctc-swiper {
	overflow: hidden;
	padding: 8px 0;
}

.pctc-swiper .swiper-wrapper {
	display: flex;
	align-items: stretch;
}

.pctc-swiper .swiper-slide {
	height: auto;
	flex-shrink: 0;
}

/* Product card */
.pctc-product-card {
	height: 100%;
	display: flex;
	flex-direction: column;
	background: #fff;
	overflow: hidden;
	border: 1px solid #d9d9d9;
	padding: 16px;
}

.pctc-product-card:hover {
	border: 1px solid #1835C3;
}

.pctc-product-link {
	text-decoration: none;
	color: inherit;
	display: block;
	flex: 1;
}

.pctc-product-image-wrap {
	position: relative;
	aspect-ratio: 1;
	overflow: hidden;
}

.pctc-product-image-wrap img {
	width: 100%;
	height: 100%;
	object-fit: contain;
	display: block;
	border-bottom: 1px solid #d9d9d9;
}

.pctc-badge {
	position: absolute;
	top: 0px;
	left: 0px;
	padding: 4px 8px;
	font-size: 0.75rem;
	font-weight: 600;
	color: #fff;
	border-radius: 4px;
	line-height: 1.2;
}

.pctc-badge-sale {
	background-color: #ffe9e2;
	color: #f65723;
}

.pctc-product-title {
	margin: 10px 0;
	font-size: 14px !important;
	font-weight: 600;
	line-height: 1.2 em;
	letter-spacing: -0.5px;
	color: #333;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
	text-overflow: ellipsis;
}

.pctc-product-price-wrap {
	margin-top: auto;
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 8px;
	font-weight: 700;
	color: red ;
}

.pctc-product-price-wrap del {
	color: #a4a4a4 !important;
	font-weight: 400;
	font-size: 14px !important;
	margin-right: 6px;
}

.pctc-product-price-wrap ins {
	text-decoration: none !important;
	font-size: 16px;
}

.pctc-sale-percent {
	display: inline-block;
	padding: 2px 6px;
	font-size: 0.8rem;
	font-weight: 600;
	color: var(--pctc-sale-percent-color);
	background-color: var(--pctc-sale-percent-bg);
	border-radius: 999px;
}

.pctc-no-products {
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 120px;
	color: #666;
	font-size: 0.95rem;
}

/* Swiper nav buttons: nút nằm trong .pctc-carousel-wrap để không bị overflow cắt */
.pctc-carousel-wrap .swiper-button-prev,
.pctc-carousel-wrap .swiper-button-next {
	width: 40px;
	height: 40px;
	margin-top: -20px;
	border-radius: 50%;
	background: #fff;
	color: #333;
	transition: background 0.2s, color 0.2s;
	display: flex;
	align-items: center;
	justify-content: center;
	border: none;
	cursor: pointer;
	z-index: 15;
}

.pctc-carousel-wrap .swiper-button-prev::after,
.pctc-carousel-wrap .swiper-button-next::after {
	font-size: 18px;
	font-weight: 700;
}

/* Khi chọn icon tùy chọn: nút = chính icon đó (không còn vòng tròn + mũi tên bên trong) */
.pctc-carousel-wrap .swiper-button-prev.pctc-has-custom-icon,
.pctc-carousel-wrap .swiper-button-next.pctc-has-custom-icon {
	background: transparent;
	box-shadow: none;
	border-radius: 0;
}
.pctc-carousel-wrap .swiper-button-prev.pctc-has-custom-icon::after,
.pctc-carousel-wrap .swiper-button-next.pctc-has-custom-icon::after {
	content: none;
	display: none;
}

.pctc-nav-icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 100%;
	line-height: 1;
}

.pctc-nav-icon svg {
	width: 100%;
	height: 100%;
	object-fit: contain;
}

.pctc-carousel-wrap .swiper-button-prev:hover,
.pctc-carousel-wrap .swiper-button-next:hover {
	color: #fff;
}

.pctc-carousel-wrap .swiper-button-disabled {
	opacity: 0.35;
	cursor: not-allowed;
	pointer-events: none;
}

/* Vị trí ngang: trong / ngoài carousel (nút nằm trong wrap nên không bị swiper overflow cắt) */
.pctc-nav-h-inside .pctc-carousel-wrap .swiper-button-prev {
	left: 10px;
}
.pctc-nav-h-inside .pctc-carousel-wrap .swiper-button-next {
	right: 10px;
}
.pctc-nav-h-outside .pctc-carousel-wrap .swiper-button-prev {
	left: -20px;
}
.pctc-nav-h-outside .pctc-carousel-wrap .swiper-button-next {
	right: -18px;
}

/* Vị trí dọc: trên / giữa / dưới */
.pctc-widget.pctc-nav-v-top .pctc-carousel-wrap .swiper-button-prev,
.pctc-widget.pctc-nav-v-top .pctc-carousel-wrap .swiper-button-next {
	top: 20px;
	bottom: auto;
	margin-top: 0;
}
.pctc-widget.pctc-nav-v-center .pctc-carousel-wrap .swiper-button-prev,
.pctc-widget.pctc-nav-v-center .pctc-carousel-wrap .swiper-button-next {
	top: 50%;
	bottom: auto;
	margin-top: 0;
	transform: translateY(-50%);
}
.pctc-widget.pctc-nav-v-bottom .pctc-carousel-wrap .swiper-button-prev,
.pctc-widget.pctc-nav-v-bottom .pctc-carousel-wrap .swiper-button-next {
	top: auto;
	bottom: 20px;
	margin-top: 0;
}

/* Loading: spinner xoay, không nền mờ */
.pctc-loading {
	position: absolute;
	inset: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	background: rgba(255, 255, 255, 0.9);
	z-index: 10;
	pointer-events: none;
}

.pctc-loading .loader {
	width: 48px;
	height: 48px;
	border-radius: 50%;
	position: relative;
	animation: pctc-rotate 1s linear infinite;
}
.pctc-loading .loader::before,
.pctc-loading .loader::after {
	content: "";
	box-sizing: border-box;
	position: absolute;
	inset: 0;
	border-radius: 50%;
	border: 5px solid #fff;
	animation: pctc-prixClipFix 2s linear infinite;
}
.pctc-loading .loader::after {
	inset: 8px;
	transform: rotate3d(90, 90, 0, 180deg);
	border-color: #ff3d00;
}

@keyframes pctc-rotate {
	0%   { transform: rotate(0deg); }
	100% { transform: rotate(360deg); }
}
@keyframes pctc-prixClipFix {
	0%   { clip-path: polygon(50% 50%, 0 0, 0 0, 0 0, 0 0, 0 0); }
	50%  { clip-path: polygon(50% 50%, 0 0, 100% 0, 100% 0, 100% 0, 100% 0); }
	75%, 100% { clip-path: polygon(50% 50%, 0 0, 100% 0, 100% 100%, 100% 100%, 100% 100%); }
}

.pctc-carousel-wrap.is-loading .pctc-swiper {
	pointer-events: none;
}

.pctc-carousel-wrap.is-loading .pctc-loading {
	display: flex;
}
