/**
 * Shop 페이지 — Woodmart 스타일 상품 그리드
 *
 * 호버 시 가격 하단에서 Add to Cart 버튼 슬라이드 업
 * 글로벌 디자인 토큰 (var(--color-*)) 사용
 */

/* =============================================================================
   Shop 페이지 컨테이너
   ============================================================================= */
/* 전체 배경 그레이 */
body.post-type-archive-product,
body.tax-product_cat,
body.tax-product_tag {
	background: #F7F8FA !important;
}

/* Sticky footer — shop 페이지 전체 높이를 viewport에 맞춤 */
body.post-type-archive-product,
body.tax-product_cat,
body.tax-product_tag {
	display: flex !important;
	flex-direction: column !important;
	min-height: 100vh !important;
}
body.post-type-archive-product #content,
body.post-type-archive-product .site-content,
body.post-type-archive-product main#main,
body.tax-product_cat #content,
body.tax-product_cat .site-content,
body.tax-product_cat main#main,
body.tax-product_tag #content,
body.tax-product_tag .site-content,
body.tax-product_tag main#main {
	flex: 1 0 auto !important;
}
body.post-type-archive-product footer.site-footer,
body.post-type-archive-product .hello-child-footer,
body.tax-product_cat footer.site-footer,
body.tax-product_cat .hello-child-footer,
body.tax-product_tag footer.site-footer,
body.tax-product_tag .hello-child-footer {
	flex-shrink: 0 !important;
}

/* Shop 콘텐츠 너비 1200px + 상단 패딩 50 */
body.post-type-archive-product main.site-main,
body.post-type-archive-product #primary.content-area,
body.post-type-archive-product .site-main > .woocommerce,
body.tax-product_cat main.site-main,
body.tax-product_cat #primary.content-area,
body.tax-product_cat .site-main > .woocommerce,
body.tax-product_tag main.site-main,
body.tax-product_tag #primary.content-area,
body.tax-product_tag .site-main > .woocommerce {
	max-width: 1200px !important;
	margin-left: auto !important;
	margin-right: auto !important;
	padding-top: 50px !important;
	padding-left: 24px !important;
	padding-right: 24px !important;
	padding-bottom: 50px !important;
	box-sizing: border-box !important;
}

/* ul.products 자체에도 직접 적용 — fallback */
body.post-type-archive-product ul.products,
body.tax-product_cat ul.products,
body.tax-product_tag ul.products {
	max-width: 1200px !important;
	margin-left: auto !important;
	margin-right: auto !important;
	box-sizing: border-box !important;
}

/* parent theme의 100% 강제 무력화 */
body.woocommerce-page main#main.site-main {
	max-width: 1200px !important;
}

/* =============================================================================
   상품 그리드
   ============================================================================= */
ul.products {
	display: grid !important;
	grid-template-columns: repeat(4, 1fr);
	gap: 24px;
	list-style: none !important;
	padding: 0 !important;
	margin: 0 0 40px !important;
}

ul.products::before,
ul.products::after {
	display: none !important;
}

/* =============================================================================
   상품 카드 — terra-tosspay 오버라이드
   ============================================================================= */
body.woocommerce ul.products li.product.hc-product-card {
	width: auto !important;
	margin: 0 !important;
	padding: 0 !important;
	float: none !important;
	display: block !important;
	border: 1px solid var(--color-border, #E5E8EB) !important;
	border-radius: 12px !important;
	box-shadow: none !important;
	transform: none !important;
	animation: none !important;
	overflow: hidden !important;
	background: var(--color-bg-primary, #fff) !important;
}

body.woocommerce ul.products li.product.hc-product-card:hover {
	border-color: var(--color-primary, #0064FF) !important;
	box-shadow: 0 8px 24px rgba(0, 100, 255, 0.10) !important;
	transform: none !important;
}

.hc-product-card__inner {
	position: relative;
	background: var(--color-bg-primary, #fff);
}

/* =============================================================================
   이미지 영역
   ============================================================================= */
.hc-product-card__image-wrap {
	position: relative;
	overflow: hidden;
	background: var(--color-bg-secondary, #F8F9FA);
}

.hc-product-card__image-link {
	display: block;
}

.hc-product-card__img {
	width: 100%;
	height: auto;
	display: block;
	aspect-ratio: 3 / 2 !important;
	object-fit: cover;
	transition: transform 0.4s ease;
}

.hc-product-card__inner:hover .hc-product-card__img {
	transform: scale(1.03);
}

/* =============================================================================
   할인 배지
   ============================================================================= */
.hc-product-card__badge {
	position: absolute;
	top: 12px;
	left: 12px;
	background: var(--color-primary, #0064FF);
	color: #fff;
	font-size: 12px;
	font-weight: 700;
	padding: 4px 10px;
	border-radius: 4px;
	z-index: 2;
	line-height: 1;
}

/* WooCommerce 기본 세일 배지 숨김 */
.hc-product-card .onsale {
	display: none !important;
}

/* =============================================================================
   상품 정보 영역 — 호버 시 위로 슬라이드 (썸네일 위 덮음)
   ============================================================================= */
.hc-product-card__info {
	position: relative;
	z-index: 4;
	padding: 15px 12px 8px;
	text-align: left;
	background: var(--color-bg-primary, #fff);
	transition: transform 0.3s ease;
}

.hc-product-card__inner:hover .hc-product-card__info {
	transform: translateY(-20px);
}

/* 카테고리 숨김 */
.hc-product-card__category {
	display: none;
}

.hc-product-card__title-link {
	text-decoration: none;
	color: inherit;
}

body.woocommerce ul.products li.product.hc-product-card .hc-product-card__title {
	font-size: 14px !important;

	font-weight: 600 !important;
	color: var(--color-text-primary, #191F28) !important;
	margin: 0 0 6px !important;
	padding: 0 !important;
	line-height: 1.4;
	text-align: left;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.hc-product-card__title-link:hover .hc-product-card__title {
	color: var(--color-primary, #0064FF) !important;
}

/* =============================================================================
   가격 — 왼쪽 정렬, terra-tosspay 오버라이드
   ============================================================================= */
body.woocommerce ul.products li.product.hc-product-card .hc-product-card__price {
	font-size: 15px !important;
	font-weight: 700 !important;
	color: var(--color-text-primary, #191F28) !important;
	line-height: 1.4 !important;
	display: block !important;
	text-align: left !important;
	margin: 0 0 20px !important;
	padding: 0 !important;
}

body.woocommerce ul.products li.product.hc-product-card .hc-product-card__price .woocommerce-Price-amount {
	color: var(--color-text-primary, #191F28) !important;
	font-size: 15px !important;
	font-weight: 700 !important;
}

body.woocommerce ul.products li.product.hc-product-card .hc-product-card__price del,
body.woocommerce ul.products li.product.hc-product-card .hc-product-card__price del .woocommerce-Price-amount {
	color: var(--color-text-tertiary, #8B95A1) !important;
	font-weight: 400 !important;
	font-size: 13px !important;
	text-decoration: line-through !important;
	margin-right: 6px;
}

body.woocommerce ul.products li.product.hc-product-card .hc-product-card__price ins {
	text-decoration: none !important;
}

body.woocommerce ul.products li.product.hc-product-card .hc-product-card__price ins .woocommerce-Price-amount {
	color: var(--color-error, #F04452) !important;
	font-weight: 700 !important;
	font-size: 15px !important;
}

/* =============================================================================
   호버 액션 — info와 함께 위로 슬라이드, 버튼은 아래에서 나타남
   검수 미통과 #109: hover 시 max-height 0→50px 변화로 카드 높이가 늘어나
   페이지 전체 높이가 변하면서 sticky footer가 아래로 밀리는 layout shift 발생.
   → 공간(50px)을 항상 예약하고 opacity만 토글한다.
   ============================================================================= */
.hc-product-card__actions {
	overflow: hidden;
	max-height: 50px;
	opacity: 0;
	padding: 0 12px;
	transition: opacity 0.25s ease;
	pointer-events: none;
}

.hc-product-card__inner:hover .hc-product-card__actions {
	opacity: 1;
	pointer-events: auto;
}

/* 바로구매 버튼 — 전체 너비 */
body.woocommerce ul.products li.product.hc-product-card .hc-product-card__actions .hc-product-card__buy-now {
	display: block !important;
	width: 100% !important;
	padding: 10px 16px !important;
	background: var(--color-primary, #0064FF) !important;
	color: #fff !important;
	font-size: 13px !important;
	font-weight: 600 !important;
	text-align: center !important;
	text-decoration: none !important;
	border-radius: 8px !important;
	border: none !important;
	cursor: pointer !important;
	transition: background 0.2s ease !important;
	box-sizing: border-box !important;
	line-height: 1.4 !important;
	margin: 0 !important;
}

body.woocommerce ul.products li.product.hc-product-card .hc-product-card__actions .hc-product-card__buy-now:hover {
	background: var(--color-primary-hover, #0050CC) !important;
	color: #fff !important;
}

body.woocommerce ul.products li.product.hc-product-card .hc-product-card__buy-now--disabled {
	background: var(--color-text-secondary, #4E5968) !important;
}

body.woocommerce ul.products li.product.hc-product-card .hc-product-card__buy-now--disabled:hover {
	background: var(--color-text-primary, #191F28) !important;
}

@keyframes hc-spin {
	to { transform: rotate(360deg); }
}

/* =============================================================================
   반응형 — 태블릿
   ============================================================================= */
@media (max-width: 1024px) {
	ul.products {
		grid-template-columns: repeat(3, 1fr);
		gap: 20px;
	}
}

/* =============================================================================
   반응형 — 모바일
   ============================================================================= */
@media (max-width: 768px) {
	ul.products {
		grid-template-columns: repeat(2, 1fr);
		gap: 16px;
	}

	.hc-product-card__img {
		aspect-ratio: 3 / 2 !important;
		height: auto !important;
		width: 100% !important;
	}

	.hc-product-card__info {
		padding: 12px;
		display: flex;
		flex-direction: column;
		min-height: 130px;
	}

	body.woocommerce ul.products li.product.hc-product-card .hc-product-card__title {
		font-size: 14px !important;
		min-height: 2.8em;
	}

	body.woocommerce ul.products li.product.hc-product-card .hc-product-card__price {
		font-size: 13px !important;
		font-weight: 400 !important;
		margin-bottom: 0 !important;
	}

	body.woocommerce ul.products li.product.hc-product-card .hc-product-card__price .woocommerce-Price-amount {
		font-size: 13px !important;
		font-weight: 400 !important;
	}

	/* 모바일: 항상 버튼 표시, 하단 고정 */
	.hc-product-card__actions {
		max-height: 50px !important;
		opacity: 1 !important;
		padding: 0 !important;
		margin-top: auto;
	}

	body.woocommerce ul.products li.product.hc-product-card .hc-product-card__actions .hc-product-card__buy-now {
		background: #F2F4F6 !important;
		color: #191F28 !important;
	}

	body.woocommerce ul.products li.product.hc-product-card .hc-product-card__actions .hc-product-card__buy-now:hover {
		background: #E5E8EB !important;
		color: #191F28 !important;
	}
}

@media (max-width: 480px) {
	.woocommerce-page.post-type-archive-product .site-main,
	.woocommerce-page.tax-product_cat .site-main {
		padding: 0 16px !important;
	}

	body.woocommerce ul.products,
	body .woocommerce ul.products,
	ul.products {
		grid-template-columns: repeat(2, 1fr) !important;
		gap: 12px !important;
	}

	.hc-product-card__info {
		padding: 10px;
	}

	.hc-product-card__badge {
		font-size: 11px;
		padding: 3px 8px;
		top: 8px;
		left: 8px;
	}
}

/* =============================================================================
   WooCommerce 기본 스타일 오버라이드
   ============================================================================= */
.woocommerce ul.products li.product {
	width: auto !important;
	margin: 0 !important;
	padding: 0 !important;
	float: none !important;
}

/* 페이지네이션 */
.woocommerce nav.woocommerce-pagination {
	margin: 40px 0;
	text-align: center;
}

.woocommerce nav.woocommerce-pagination ul {
	display: inline-flex;
	gap: 8px;
	border: none;
}

.woocommerce nav.woocommerce-pagination ul li {
	border: none;
}

.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span {
	padding: 8px 14px;
	border: 1px solid var(--color-border, #E5E8EB);
	border-radius: 6px;
	font-size: 14px;
	color: var(--color-text-secondary, #4E5968);
	background: #fff;
	text-decoration: none;
	min-width: auto;
}

.woocommerce nav.woocommerce-pagination ul li a:hover {
	background: var(--color-primary, #0064FF);
	color: #fff;
	border-color: var(--color-primary, #0064FF);
}

.woocommerce nav.woocommerce-pagination ul li span.current {
	background: var(--color-primary, #0064FF);
	color: #fff;
	border-color: var(--color-primary, #0064FF);
}
