/* ============================================================
   Hooflakids — shop / archive
   ============================================================ */

.hk-shop {
	max-width: var(--hk-container-w, 100%);
	margin: 0 auto;
	padding: 32px var(--hk-container-pad, 48px) 64px;
}

/* Breadcrumb shared across all pages — actual styles live in style.css */

.hk-shop__head { margin-bottom: 28px; }

.hk-shop__head-row {
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	gap: 24px;
	flex-wrap: wrap;
}

.hk-shop__eyebrow {
	display: inline-block;
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--accent-deep);
	background: var(--accent-soft, rgba(0, 172, 138, 0.1));
	padding: 5px 12px;
	border-radius: 999px;
	margin: 0 0 12px;
}

.hk-shop__title {
	font-size: clamp(40px, 5vw, 64px);
	font-weight: 700;
	letter-spacing: -.02em;
	line-height: 1;
	margin: 0 0 8px;
}

.hk-shop__sub {
	margin: 0;
	color: var(--ink-soft);
	font-size: 15px;
}

.hk-shop__head-actions {
	display: flex;
	gap: 10px;
	flex-wrap: wrap;
}

.hk-btn-pill {
	background: #fff;
	border: 1px solid var(--line);
	border-radius: var(--radius-btn);
	padding: 12px 20px;
	font-size: 14px;
	font-weight: 600;
	color: var(--ink);
	cursor: pointer;
	transition: border-color .15s, box-shadow .15s;
	display: inline-flex;
	align-items: center;
	gap: 8px;
}

.hk-btn-pill:hover {
	border-color: var(--accent);
	box-shadow: var(--shadow-sm);
}

/* ----- Layout ----- */
.hk-shop__layout {
	display: grid;
	grid-template-columns: 280px 1fr;
	gap: 24px;
	align-items: start;
	overflow: visible;
}

/* Sticky filter — parents must allow overflow visible. */
.hk-shop, .hk-shop__layout, .hk-shop__sidebar { overflow: visible; }

.hk-shop__sidebar {
	position: -webkit-sticky;
	position: sticky;
	top: calc(var(--hk-header-h, 68px) + 16px);
	max-height: calc(100vh - var(--hk-header-h, 68px) - 32px);
	overflow-y: auto;
	align-self: start;
}

/* Hide scrollbar but keep scrollable. */
.hk-shop__sidebar::-webkit-scrollbar { width: 6px; }
.hk-shop__sidebar::-webkit-scrollbar-thumb { background: rgba(0,0,0,.1); border-radius: 999px; }

/* ----- Filter card ----- */
.hk-filter {
	background: #fff;
	border: 1px solid var(--line);
	border-radius: var(--radius-card);
	padding: 20px;
}

.hk-filter__head {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding-bottom: 16px;
	border-bottom: 1px solid var(--line);
	margin-bottom: 16px;
}

.hk-filter__head strong {
	font-size: 18px;
	font-weight: 700;
}

.hk-filter__reset {
	color: var(--accent-deep);
	font-size: 13px;
	font-weight: 600;
	text-decoration: none;
}

.hk-filter__group + .hk-filter__group {
	margin-top: 20px;
	padding-top: 20px;
	border-top: 1px solid var(--line);
}

.hk-filter__label {
	font-size: 11.5px;
	font-weight: 700;
	letter-spacing: .14em;
	text-transform: uppercase;
	color: var(--ink-mute);
	margin: 0 0 12px;
}

.hk-filter__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 4px;
}

.hk-filter__list a {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 10px 12px;
	border-radius: 10px;
	font-size: 14px;
	color: var(--ink);
	text-decoration: none;
	transition: background .15s;
}

.hk-filter__list a:hover {
	background: var(--accent-tint);
	color: var(--accent-deep);
}

.hk-filter__list a.is-active {
	background: var(--accent-soft);
	color: var(--accent-deep);
	font-weight: 600;
}

.hk-filter__list .count {
	color: var(--ink-mute);
	font-size: 13px;
}

.hk-filter__list a.is-active .count { color: var(--accent-deep); opacity: .8; }

.hk-filter__list--radio a {
	gap: 10px;
	justify-content: flex-start;
}

.hk-filter__list--radio .dot {
	width: 16px;
	height: 16px;
	border-radius: 50%;
	border: 2px solid var(--line);
	flex-shrink: 0;
}

.hk-filter__list--radio a.is-active .dot {
	border-color: var(--accent);
	box-shadow: inset 0 0 0 3px var(--accent);
}

/* ----- Toolbar ----- */
.hk-shop__toolbar {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	padding: 14px 20px;
	background: #fff;
	border: 1px solid var(--line);
	border-radius: var(--radius-card);
	margin-bottom: 20px;
}

.hk-shop__count {
	font-weight: 600;
	font-size: 14px;
	color: var(--ink-soft);
}

.hk-shop__sort .woocommerce-ordering { margin: 0; }

.hk-shop__sort select {
	background: var(--cream);
	border: 1px solid var(--line);
	border-radius: var(--radius-btn);
	padding: 8px 36px 8px 16px;
	font-size: 13px;
	font-weight: 600;
	color: var(--ink);
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8' fill='none'><path d='M1 1.5L6 6.5L11 1.5' stroke='%231a2a2a' stroke-width='2' stroke-linecap='round'/></svg>");
	background-repeat: no-repeat;
	background-position: right 14px center;
}

/* ----- Product grid ----- */
.hk-grid {
	display: grid !important;
	grid-template-columns: repeat(4, 1fr) !important;
	gap: 24px !important;
	list-style: none !important;
	margin: 0 !important;
	padding: 0 !important;
}

/* WC adds ul.products::before/::after clearfix that becomes a phantom grid cell. Kill it. */
.hk-grid::before,
.hk-grid::after { display: none !important; content: none !important; }

.hk-grid li.hk-card,
.hk-grid li.product {
	margin: 0 !important;
	padding: 0 !important;
	width: auto !important;
	float: none !important;
	clear: none !important;
	background: #fff;
	border-radius: var(--radius-card);
	overflow: hidden;
	transition: transform .15s ease, box-shadow .15s ease;
	display: flex;
	flex-direction: column;
}

.hk-grid li.hk-card:hover {
	transform: translateY(-4px);
	box-shadow: var(--shadow-md);
}

/* Card media */
.hk-card__media {
	position: relative;
	display: block;
	aspect-ratio: 1 / 1;
	background: var(--accent-tint);
	overflow: hidden;
}

.hk-card__media img,
.hk-card__media .hk-card__img,
.hk-card__media .attachment-woocommerce_thumbnail {
	width: 100% !important;
	height: 100% !important;
	object-fit: cover !important;
	display: block !important;
	margin: 0 !important;
	border-radius: 0 !important;
	transition: transform .3s ease;
}

.hk-grid li.hk-card:hover .hk-card__media img { transform: scale(1.04); }

.hk-card__placeholder {
	position: absolute;
	inset: 0;
	background: repeating-linear-gradient(135deg, var(--accent-soft) 0 16px, var(--accent-tint) 16px 32px);
}

/* Badges */
.hk-card__badges {
	position: absolute;
	top: 14px;
	left: 14px;
	display: flex;
	gap: 6px;
	z-index: 2;
}

.hk-badge {
	font-size: 11px;
	font-weight: 800;
	letter-spacing: .08em;
	padding: 4px 10px;
	border-radius: 999px;
}

.hk-badge--ink {
	background: var(--ink);
	color: #fff;
}

.hk-badge--coral {
	background: var(--coral);
	color: #fff;
}

/* Wishlist heart */
.hk-card__wish {
	position: absolute;
	top: 12px;
	right: 12px;
	width: 36px;
	height: 36px;
	border-radius: 50%;
	background: #fff !important;
	border: 0 !important;
	padding: 0 !important;
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	color: var(--ink) !important;
	cursor: pointer;
	z-index: 2;
	box-shadow: var(--shadow-sm);
	transition: color .15s ease, transform .15s ease;
}

.hk-card__wish svg {
	display: block !important;
	width: 18px !important;
	height: 18px !important;
	stroke: currentColor !important;
	fill: none !important;
}

.hk-card__wish:hover { color: var(--coral) !important; transform: scale(1.05); }
.hk-card__wish.is-active { color: var(--coral) !important; }
.hk-card__wish.is-active svg { fill: var(--coral) !important; }

/* Card body */
.hk-card__body {
	padding: 16px 18px 20px;
	display: flex;
	flex-direction: column;
	gap: 6px;
}

.hk-card__cat {
	font-size: 11px;
	font-weight: 700;
	letter-spacing: .12em;
	color: var(--ink-soft);
	margin: 0;
}

.hk-card__title {
	font-size: 16px;
	font-weight: 600;
	font-family: var(--font-body);
	line-height: 1.3;
	margin: 0;
}

.hk-card__title a {
	color: var(--ink);
	text-decoration: none;
}

.hk-card__title a:hover { color: var(--accent-deep); }

.hk-card__rating {
	display: flex;
	align-items: center;
	gap: 6px;
	font-size: 13px;
}

.hk-card__rating .star-rating {
	width: 76px;
	font-size: 13px;
	color: var(--sun);
}

.hk-card__rating-count {
	color: var(--ink-mute);
	font-size: 12.5px;
}

.hk-card__price {
	margin-top: 4px;
	font-size: 18px;
	font-weight: 700;
	color: var(--ink);
}

.hk-card__price del {
	color: var(--ink-mute);
	font-weight: 400;
	font-size: 14px;
	margin-left: 6px;
}

.hk-card__price ins {
	background: none;
	text-decoration: none;
}

.hk-card__stock {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	margin-top: 4px;
	font-size: 12.5px;
	font-weight: 500;
	color: var(--ink-soft);
}

.hk-card__stock .dot {
	width: 8px;
	height: 8px;
	border-radius: 50%;
	flex-shrink: 0;
}

.hk-card__stock.is-ok .dot   { background: #16a34a; }
.hk-card__stock.is-ok        { color: #15803d; }

.hk-card__stock.is-low .dot  { background: var(--coral); }
.hk-card__stock.is-low       { color: #c84e29; }

.hk-card__stock.is-out .dot  { background: var(--ink-mute); }
.hk-card__stock.is-out       { color: var(--ink-soft); }

/* Empty + pagination */
.hk-shop__empty {
	background: #fff;
	border: 1px solid var(--line);
	border-radius: var(--radius-card);
	padding: 48px;
	text-align: center;
	color: var(--ink-soft);
}

.hk-pagination-wrap { display: flex; justify-content: center; }
.hk-pagination-wrap--top    { margin: 0 0 24px; }
.hk-pagination-wrap--bottom { margin: 28px 0 0; }

.woocommerce-pagination,
.woocommerce nav.woocommerce-pagination {
	text-align: center;
	margin: 0 !important;
	border: 0 !important;
}

.woocommerce-pagination ul.page-numbers,
.woocommerce nav.woocommerce-pagination ul {
	display: inline-flex !important;
	gap: 8px !important;
	list-style: none !important;
	padding: 0 !important;
	margin: 0 !important;
	border: 0 !important;
}

.woocommerce-pagination ul.page-numbers li,
.woocommerce nav.woocommerce-pagination ul li {
	margin: 0 !important;
	padding: 0 !important;
	border: 0 !important;
	background: transparent !important;
	overflow: visible !important;
}

.hk-pagination-wrap nav.woocommerce-pagination ul.page-numbers li .page-numbers,
.hk-pagination-wrap nav.woocommerce-pagination ul.page-numbers li a.page-numbers,
.hk-pagination-wrap nav.woocommerce-pagination ul.page-numbers li span.page-numbers {
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	min-width: 40px !important;
	height: 40px !important;
	padding: 0 12px !important;
	border-radius: 999px !important;
	background: #fff !important;
	border: 1px solid var(--line) !important;
	color: var(--ink) !important;
	font-weight: 600 !important;
	font-size: 14px !important;
	text-decoration: none !important;
	line-height: 1 !important;
	transition: background .15s, color .15s, border-color .15s;
}

.hk-pagination-wrap nav.woocommerce-pagination ul.page-numbers li a.page-numbers:hover {
	background: var(--accent-soft) !important;
	color: var(--accent-deep) !important;
	border-color: var(--accent-soft) !important;
}

.hk-pagination-wrap nav.woocommerce-pagination ul.page-numbers li .page-numbers.current,
.hk-pagination-wrap nav.woocommerce-pagination ul.page-numbers li span.page-numbers.current {
	background: var(--accent) !important;
	color: #fff !important;
	border-color: var(--accent) !important;
}

/* ----- Responsive ----- */
/* ----- Wishlist page ----- */
.hk-wishlist-page {
	max-width: var(--hk-container-w, 100%);
	margin: 0 auto;
	padding: 32px var(--hk-container-pad, 100px) 80px;
}

.hk-wishlist-page__head {
	margin-bottom: 28px;
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.hk-wishlist-page__head h1 {
	font-size: clamp(40px, 5vw, 64px);
	font-weight: 700;
	letter-spacing: -.02em;
	line-height: 1;
	margin: 0;
}

.hk-wishlist-page__sub {
	color: var(--ink-soft);
	font-size: 15px;
	margin: 0;
}

.hk-wishlist-page__loading {
	text-align: center;
	color: var(--ink-mute);
	padding: 48px;
	grid-column: 1 / -1;
	list-style: none;
}

/* Skeleton placeholder cards while wishlist AJAX loads. Replaces plain
   "Memuat..." text — perceived perf wins via brand-shaped placeholders. */
.hk-card--skeleton {
	background: #fff;
	border-radius: var(--radius-card, 20px);
	overflow: hidden;
	list-style: none;
	pointer-events: none;
}

.hk-card--skeleton .hk-card__media {
	display: block;
	aspect-ratio: 1 / 1;
	background: linear-gradient(90deg, #f0ebde 0%, #f7f3e8 50%, #f0ebde 100%);
	background-size: 200% 100%;
	animation: hk-skeleton-shimmer 1.4s ease-in-out infinite;
}

.hk-card--skeleton .hk-card__body {
	padding: 14px 16px 18px;
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.hk-card--skeleton .hk-card__eyebrow,
.hk-card--skeleton .hk-card__name,
.hk-card--skeleton .hk-card__price {
	display: block;
	background: linear-gradient(90deg, #f0ebde 0%, #f7f3e8 50%, #f0ebde 100%);
	background-size: 200% 100%;
	animation: hk-skeleton-shimmer 1.4s ease-in-out infinite;
	border-radius: 4px;
}

.hk-card--skeleton .hk-card__eyebrow { height: 10px; width: 50%; }
.hk-card--skeleton .hk-card__name    { height: 14px; width: 80%; margin-top: 4px; }
.hk-card--skeleton .hk-card__price   { height: 16px; width: 60%; margin-top: 6px; }

@keyframes hk-skeleton-shimmer {
	0%   { background-position: 200% 0; }
	100% { background-position: -200% 0; }
}

.hk-wishlist-page__actions {
	margin-top: 28px;
	display: flex;
	gap: 12px;
	flex-wrap: wrap;
}

/* Filter toggle button + drawer-mode (mobile only) */
.hk-shop__filter-btn {
	display: none;
	align-items: center;
	gap: 6px;
	background: #fff;
	border: 1px solid var(--line);
	border-radius: 999px;
	padding: 8px 14px;
	font-weight: 600;
	font-size: 13.5px;
	color: var(--ink);
	cursor: pointer;
}

.hk-shop__filter-btn:hover { border-color: var(--accent); color: var(--accent-deep); }

.hk-filter__close {
	display: none;
	width: 32px;
	height: 32px;
	border: 0;
	background: transparent;
	color: var(--ink);
	border-radius: 50%;
	cursor: pointer;
	align-items: center;
	justify-content: center;
	margin-left: auto;
}

.hk-shop__filter-backdrop {
	position: fixed;
	inset: 0;
	background: rgba(0, 0, 0, .4);
	z-index: 1090;
	opacity: 0;
	transition: opacity .25s ease;
	pointer-events: none;
}

.hk-shop__filter-backdrop.is-open {
	opacity: 1;
	pointer-events: auto;
}

body.hk-shop-filter-locked { overflow: hidden; }

@media (max-width: 1280px) {
	.hk-grid { grid-template-columns: repeat(3, 1fr) !important; }
}

@media (max-width: 1024px) {
	.hk-shop__layout { grid-template-columns: 1fr; }
	.hk-shop__sidebar { position: static; max-height: none; }
	.hk-grid { grid-template-columns: repeat(2, 1fr) !important; }
}

@media (max-width: 768px) {
	.hk-shop__filter-btn { display: inline-flex; }
	.hk-filter__close { display: inline-flex; }
	.hk-shop__toolbar {
		gap: 10px;
		flex-wrap: wrap;
		justify-content: flex-start;
		padding: 12px 16px;
	}
	.hk-shop__count {
		margin-left: auto;
		padding-right: 4px;
	}
	.hk-shop__sort {
		flex-basis: 100%;
	}
	.hk-shop__sort .woocommerce-ordering,
	.hk-shop__sort select {
		width: 100%;
	}

	/* Sidebar → drawer slide-in from left */
	.hk-shop__sidebar {
		position: fixed !important;
		top: 0;
		left: 0;
		bottom: 0;
		width: min(85vw, 360px);
		background: var(--cream, #faf6ec);
		z-index: 1100;
		transform: translateX(-100%);
		transition: transform .3s cubic-bezier(.4, 0, .2, 1);
		max-height: none !important;
		overflow-y: auto;
		padding: 0 !important;
		box-shadow: 8px 0 32px rgba(0, 0, 0, .12);
	}

	.hk-shop__sidebar.is-open {
		transform: translateX(0);
	}

	.hk-filter {
		padding: 20px;
	}

	.hk-filter__head {
		position: sticky;
		top: 0;
		background: var(--cream, #faf6ec);
		padding: 4px 0 14px;
		z-index: 1;
		border-bottom: 1px solid var(--line);
		margin-bottom: 16px;
	}
}

@media (max-width: 640px) {
	.hk-shop { padding: 20px 16px 40px; }
	.hk-grid { grid-template-columns: repeat(2, minmax(0, 1fr)) !important; gap: 12px !important; }
	.hk-shop__title { font-size: 28px; }
	.hk-shop__count { font-size: 13px; }
}
