/**
 * ACCESFY Home Products Grid – Premium black & gold theme
 */

.accesfy-hpg {
	--hpg-bg: #000000;
	--hpg-card: #111111;
	--hpg-border: #1e1e1e;
	--hpg-text: #ffffff;
	--hpg-muted: #a1a1aa;
	--hpg-gold: #c9a962;
	--hpg-pink: #ff4da6;
	--hpg-radius: 14px;
	--hpg-ease: cubic-bezier(0.4, 0, 0.2, 1);
	--hpg-shadow: 0 8px 32px rgba(0, 0, 0, 0.45);
	--hpg-shadow-hover: 0 16px 48px rgba(0, 0, 0, 0.6);

	position: relative;
	background: var(--hpg-bg);
	color: var(--hpg-text);
	padding: 48px 16px 56px;
	font-family: Inter, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
	overflow: hidden;
}

.accesfy-hpg *,
.accesfy-hpg *::before,
.accesfy-hpg *::after {
	box-sizing: border-box;
}

.accesfy-hpg__gold {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 2px;
	background: linear-gradient(90deg, transparent, var(--hpg-gold) 20%, var(--hpg-pink) 50%, var(--hpg-gold) 80%, transparent);
}

/* Header */
.accesfy-hpg__header {
	text-align: center;
	max-width: 680px;
	margin: 0 auto 28px;
	padding: 0 8px;
}

.accesfy-hpg__eyebrow {
	margin: 0 0 8px;
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	color: var(--hpg-gold);
}

.accesfy-hpg__title {
	margin: 0 0 10px;
	font-size: clamp(1.6rem, 4vw, 2.25rem);
	font-weight: 600;
	letter-spacing: -0.03em;
	line-height: 1.15;
}

.accesfy-hpg__subtitle {
	margin: 0;
	font-size: 14px;
	line-height: 1.6;
	color: var(--hpg-muted);
}

/* Grid – mobile 2 cols × 5 rows (10 products) */
.accesfy-hpg__grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 12px;
	max-width: 1280px;
	margin: 0 auto;
}

@media (min-width: 768px) {
	.accesfy-hpg {
		padding: 56px 24px 64px;
	}

	.accesfy-hpg__grid {
		grid-template-columns: repeat(4, 1fr);
		gap: 16px;
	}
}

@media (min-width: 1024px) {
	.accesfy-hpg__grid {
		grid-template-columns: repeat(5, 1fr);
		gap: 18px;
	}
}

/* Scroll reveal */
.accesfy-hpg-reveal {
	opacity: 0;
	transform: translateY(28px);
	transition: opacity 0.7s var(--hpg-ease), transform 0.7s var(--hpg-ease);
}

.accesfy-hpg-reveal.is-visible {
	opacity: 1;
	transform: translateY(0);
}

.accesfy-hpg-reveal.is-visible .accesfy-hpg-card {
	animation: accesfyHpgCardIn 0.55s var(--hpg-ease) forwards;
	animation-delay: var(--hpg-delay, 0s);
}

@keyframes accesfyHpgCardIn {
	from {
		opacity: 0;
		transform: translateY(18px) scale(0.97);
	}
	to {
		opacity: 1;
		transform: translateY(0) scale(1);
	}
}

/* Product card */
.accesfy-hpg-card {
	background: var(--hpg-card);
	border: 1px solid var(--hpg-border);
	border-radius: var(--hpg-radius);
	overflow: hidden;
	opacity: 0;
	position: relative;
	transition: transform 0.4s var(--hpg-ease), box-shadow 0.4s var(--hpg-ease), border-color 0.35s ease;
	will-change: transform;
}

.accesfy-hpg-card.is-added {
	border-color: rgba(74, 222, 128, 0.65);
	box-shadow: 0 0 0 2px rgba(74, 222, 128, 0.2), var(--hpg-shadow-hover);
	animation: accesfyHpgCardPulse 0.65s var(--hpg-ease);
}

@keyframes accesfyHpgCardPulse {
	0% { transform: scale(1); }
	35% { transform: scale(1.02); }
	100% { transform: scale(1); }
}

.accesfy-hpg-card__added {
	position: absolute;
	inset: 0;
	z-index: 6;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 8px;
	background: rgba(0, 0, 0, 0.72);
	backdrop-filter: blur(4px);
	opacity: 0;
	pointer-events: none;
	transform: scale(0.92);
	transition: opacity 0.35s var(--hpg-ease), transform 0.35s var(--hpg-ease);
}

.accesfy-hpg-card.is-added .accesfy-hpg-card__added {
	opacity: 1;
	transform: scale(1);
}

.accesfy-hpg-card__added-icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 52px;
	height: 52px;
	border-radius: 50%;
	background: rgba(74, 222, 128, 0.15);
	border: 2px solid #4ade80;
	color: #4ade80;
	animation: accesfyHpgCheckPop 0.5s var(--hpg-ease);
}

@keyframes accesfyHpgCheckPop {
	0% { transform: scale(0.4); opacity: 0; }
	60% { transform: scale(1.12); }
	100% { transform: scale(1); opacity: 1; }
}

.accesfy-hpg-card__added-text {
	font-size: 13px;
	font-weight: 600;
	color: #fff;
	letter-spacing: 0.02em;
}

.accesfy-hpg-card:hover,
.accesfy-hpg-card.is-touched {
	transform: translateY(-6px);
	box-shadow: var(--hpg-shadow-hover);
	border-color: rgba(201, 169, 98, 0.35);
}

.accesfy-hpg-card__media {
	position: relative;
	aspect-ratio: 3 / 4;
	overflow: hidden;
	background: #0a0a0a;
}

.accesfy-hpg-card__image-link {
	display: block;
	width: 100%;
	height: 100%;
	position: relative;
}

.accesfy-hpg-card__image {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: opacity 0.55s var(--hpg-ease), transform 0.65s var(--hpg-ease);
}

.accesfy-hpg-card__image--main {
	opacity: 1;
	transform: scale(1);
	z-index: 1;
}

.accesfy-hpg-card__image--hover {
	opacity: 0;
	transform: scale(1.08);
	z-index: 2;
}

.accesfy-hpg-card:hover .accesfy-hpg-card__image--main,
.accesfy-hpg-card.is-touched .accesfy-hpg-card__image--main {
	opacity: 0;
	transform: scale(1.06);
}

.accesfy-hpg-card:hover .accesfy-hpg-card__image--hover,
.accesfy-hpg-card.is-touched .accesfy-hpg-card__image--hover,
.accesfy-hpg-card:hover .accesfy-hpg-card__image--main:only-of-type,
.accesfy-hpg-card.is-touched .accesfy-hpg-card__image--main:only-of-type {
	opacity: 1;
	transform: scale(1.06);
}

.accesfy-hpg-card__shine {
	position: absolute;
	inset: 0;
	z-index: 3;
	background: linear-gradient(105deg, transparent 40%, rgba(255, 255, 255, 0.12) 50%, transparent 60%);
	transform: translateX(-120%);
	transition: transform 0.75s var(--hpg-ease);
	pointer-events: none;
}

.accesfy-hpg-card:hover .accesfy-hpg-card__shine,
.accesfy-hpg-card.is-touched .accesfy-hpg-card__shine {
	transform: translateX(120%);
}

.accesfy-hpg-card__badge {
	position: absolute;
	top: 10px;
	left: 10px;
	z-index: 4;
	padding: 4px 8px;
	border-radius: 6px;
	font-size: 9px;
	font-weight: 700;
	letter-spacing: 0.08em;
}

.accesfy-hpg-card__badge--sale {
	background: rgba(255, 77, 166, 0.9);
	color: #fff;
}

.accesfy-hpg-card__actions {
	position: absolute;
	top: 10px;
	right: 10px;
	z-index: 4;
	opacity: 0;
	transform: translateX(10px);
	transition: opacity 0.35s var(--hpg-ease), transform 0.35s var(--hpg-ease);
}

.accesfy-hpg-card:hover .accesfy-hpg-card__actions,
.accesfy-hpg-card.is-touched .accesfy-hpg-card__actions {
	opacity: 1;
	transform: translateX(0);
}

@media (max-width: 767px) {
	.accesfy-hpg-card__actions {
		opacity: 1;
		transform: translateX(0);
	}
}

.accesfy-hpg-card__action {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	border: 1px solid var(--hpg-border);
	border-radius: 50%;
	background: rgba(0, 0, 0, 0.72);
	backdrop-filter: blur(8px);
	color: #fff;
	cursor: pointer;
	text-decoration: none;
	transition: background 0.25s, border-color 0.25s, color 0.25s, transform 0.25s;
}

.accesfy-hpg-card__action:hover {
	background: #fff;
	color: #000;
	border-color: #fff;
	transform: scale(1.08);
}

.accesfy-hpg-card__action.is-loading {
	pointer-events: none;
	opacity: 0.6;
}

.accesfy-hpg-card__body {
	padding: 12px 12px 14px;
}

.accesfy-hpg-card__rating {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	font-size: 11px;
	color: var(--hpg-gold);
	margin-bottom: 6px;
}

.accesfy-hpg-card__name {
	display: block;
	color: var(--hpg-text);
	text-decoration: none;
	font-size: 13px;
	font-weight: 500;
	line-height: 1.35;
	margin-bottom: 6px;
	transition: color 0.2s;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.accesfy-hpg-card__name:hover {
	color: var(--hpg-pink);
}

.accesfy-hpg-card__price {
	font-size: 13px;
	font-weight: 600;
	color: var(--hpg-text);
}

.accesfy-hpg-card__price del {
	color: var(--hpg-muted);
	font-weight: 400;
	font-size: 11px;
}

.accesfy-hpg-card__price ins {
	text-decoration: none;
	color: var(--hpg-pink);
}

/* Card action buttons */
.accesfy-hpg-card__btns {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 8px;
	margin-top: 10px;
}

.accesfy-hpg-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 6px;
	min-height: 36px;
	padding: 8px 10px;
	border-radius: 8px;
	font-size: 11px;
	font-weight: 600;
	letter-spacing: 0.03em;
	text-decoration: none;
	cursor: pointer;
	border: 1px solid transparent;
	transition: background 0.3s var(--hpg-ease), color 0.3s, border-color 0.3s, transform 0.25s, box-shadow 0.3s;
	position: relative;
	overflow: hidden;
}

.accesfy-hpg-btn--cart {
	background: #fff;
	color: #000;
	border-color: #fff;
}

.accesfy-hpg-btn--cart:hover {
	background: var(--hpg-gold);
	border-color: var(--hpg-gold);
	transform: translateY(-1px);
}

.accesfy-hpg-btn--buy {
	background: transparent;
	color: var(--hpg-gold);
	border-color: var(--hpg-gold);
}

.accesfy-hpg-btn--buy:hover {
	background: linear-gradient(135deg, var(--hpg-gold), var(--hpg-pink));
	color: #000;
	border-color: transparent;
	transform: translateY(-1px);
	box-shadow: 0 6px 20px rgba(201, 169, 98, 0.3);
}

.accesfy-hpg-btn.is-loading {
	pointer-events: none;
	opacity: 0.7;
}

.accesfy-hpg-btn.is-loading::after {
	content: '';
	position: absolute;
	width: 14px;
	height: 14px;
	border: 2px solid currentColor;
	border-top-color: transparent;
	border-radius: 50%;
	animation: accesfyHpgSpin 0.65s linear infinite;
}

@keyframes accesfyHpgSpin {
	to { transform: rotate(360deg); }
}

.accesfy-hpg-btn__success {
	display: none;
	align-items: center;
	gap: 4px;
}

.accesfy-hpg-btn.is-success {
	background: #4ade80 !important;
	border-color: #4ade80 !important;
	color: #000 !important;
	pointer-events: none;
}

.accesfy-hpg-btn.is-success .accesfy-hpg-btn__label {
	display: none;
}

.accesfy-hpg-btn.is-success .accesfy-hpg-btn__success {
	display: inline-flex;
	animation: accesfyHpgBtnSuccess 0.4s var(--hpg-ease);
}

@keyframes accesfyHpgBtnSuccess {
	from { transform: scale(0.85); opacity: 0; }
	to { transform: scale(1); opacity: 1; }
}

@media (max-width: 480px) {
	.accesfy-hpg-card__btns {
		grid-template-columns: 1fr;
	}

	.accesfy-hpg-btn {
		font-size: 12px;
		min-height: 38px;
	}
}

/* More products button */
.accesfy-hpg__footer {
	text-align: center;
	margin-top: 32px;
}

.accesfy-hpg__more {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	padding: 14px 32px;
	border: 2px solid var(--hpg-gold);
	border-radius: 999px;
	color: var(--hpg-text);
	text-decoration: none;
	font-size: 14px;
	font-weight: 600;
	letter-spacing: 0.04em;
	background: transparent;
	position: relative;
	overflow: hidden;
	transition: color 0.35s var(--hpg-ease), border-color 0.35s, transform 0.35s, box-shadow 0.35s;
}

.accesfy-hpg__more::before {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(135deg, var(--hpg-gold), var(--hpg-pink));
	transform: scaleX(0);
	transform-origin: left;
	transition: transform 0.4s var(--hpg-ease);
	z-index: 0;
}

.accesfy-hpg__more span,
.accesfy-hpg__more svg {
	position: relative;
	z-index: 1;
}

.accesfy-hpg__more svg {
	transition: transform 0.35s var(--hpg-ease);
}

.accesfy-hpg__more:hover {
	color: #000;
	border-color: transparent;
	transform: translateY(-2px);
	box-shadow: 0 8px 28px rgba(201, 169, 98, 0.35);
}

.accesfy-hpg__more:hover::before {
	transform: scaleX(1);
}

.accesfy-hpg__more:hover svg {
	transform: translateX(4px);
}

/* Toast */
.accesfy-hpg-toast {
	position: fixed;
	bottom: 90px;
	left: 50%;
	transform: translateX(-50%) translateY(20px);
	background: #111;
	border: 1px solid var(--hpg-gold);
	color: #fff;
	padding: 12px 20px;
	border-radius: 10px;
	font-size: 13px;
	z-index: 100200;
	opacity: 0;
	pointer-events: none;
	transition: opacity 0.3s, transform 0.3s;
}

.accesfy-hpg-toast.is-show {
	opacity: 1;
	transform: translateX(-50%) translateY(0);
}

.accesfy-hpg-toast--error {
	border-color: #f87171;
}

@media (prefers-reduced-motion: reduce) {
	.accesfy-hpg-reveal,
	.accesfy-hpg-card,
	.accesfy-hpg-card__image,
	.accesfy-hpg-card__shine,
	.accesfy-hpg__more {
		transition: none !important;
		animation: none !important;
	}

	.accesfy-hpg-reveal {
		opacity: 1;
		transform: none;
	}

	.accesfy-hpg-card {
		opacity: 1;
	}
}
