/* =========================================================
   HivePress Categories Homepage – Frontend Styles
   ========================================================= */

/* ---------- Variables base ---------- */
.hpch-section {
	--hpch-radius:   12px;
	--hpch-gap:      1.25rem;
	--hpch-bg:       #f8f9fa;
	--hpch-text:     #1a1a2e;
	--hpch-muted:    #6c757d;
	--hpch-border:   #e9ecef;
	--hpch-shadow:   0 4px 20px rgba(0,0,0,.08);
	--hpch-hover-y:  -6px;
	--hpch-speed:    .25s;

	font-family: inherit;
	padding: 3rem 1rem;
	box-sizing: border-box;
}

/* ---------- Header ---------- */
.hpch-header {
	text-align: center;
	margin-bottom: 2.5rem;
}

.hpch-title {
	font-size: clamp(1.6rem, 4vw, 2.4rem);
	font-weight: 700;
	color: var(--hpch-text);
	margin: 0 0 .5rem;
	line-height: 1.2;
}

.hpch-subtitle {
	font-size: 1.05rem;
	color: var(--hpch-muted);
	margin: 0;
}

/* ---------- Grid de columnas ---------- */
.hpch-grid {
	display: grid;
	gap: var(--hpch-gap);
	max-width: 1200px;
	margin: 0 auto;
}

.hpch-cols-2 { grid-template-columns: repeat(2, 1fr); }
.hpch-cols-3 { grid-template-columns: repeat(3, 1fr); }
.hpch-cols-4 { grid-template-columns: repeat(4, 1fr); }
.hpch-cols-5 { grid-template-columns: repeat(5, 1fr); }
.hpch-cols-6 { grid-template-columns: repeat(6, 1fr); }

@media (max-width: 1024px) {
	.hpch-cols-5,
	.hpch-cols-6 { grid-template-columns: repeat(3, 1fr); }
	.hpch-cols-4 { grid-template-columns: repeat(3, 1fr); }
}

@media (max-width: 768px) {
	.hpch-cols-3,
	.hpch-cols-4,
	.hpch-cols-5,
	.hpch-cols-6 { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 480px) {
	.hpch-grid { grid-template-columns: 1fr !important; }
}

/* =========================================================
   ESTILO: CARDS
   ========================================================= */
.hpch-style-cards .hpch-card {
	display: block;
	text-decoration: none;
	color: var(--hpch-text);
	background: #fff;
	border: 1px solid var(--hpch-border);
	border-radius: var(--hpch-radius);
	overflow: hidden;
	box-shadow: var(--hpch-shadow);
	transition: transform var(--hpch-speed) ease, box-shadow var(--hpch-speed) ease;
	position: relative;
}

.hpch-style-cards .hpch-card::before {
	content: '';
	display: block;
	height: 4px;
	background: var(--hpch-accent, #4ECDC4);
	transition: height var(--hpch-speed) ease;
}

.hpch-style-cards .hpch-card:hover {
	transform: translateY(var(--hpch-hover-y));
	box-shadow: 0 12px 40px rgba(0,0,0,.14);
}

.hpch-style-cards .hpch-card:hover::before {
	height: 6px;
}

.hpch-style-cards .hpch-card-inner {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	padding: 1.75rem 1.25rem;
	gap: .75rem;
}

.hpch-style-cards .hpch-arrow {
	display: inline-block;
	font-size: 1.1rem;
	color: var(--hpch-accent, #4ECDC4);
	opacity: 0;
	transform: translateX(-6px);
	transition: opacity var(--hpch-speed), transform var(--hpch-speed);
}

.hpch-style-cards .hpch-card:hover .hpch-arrow {
	opacity: 1;
	transform: translateX(0);
}

/* =========================================================
   ESTILO: PILLS
   ========================================================= */
.hpch-style-pills .hpch-grid {
	display: flex;
	flex-wrap: wrap;
	gap: .75rem;
	justify-content: center;
}

.hpch-style-pills .hpch-card {
	display: inline-flex;
	text-decoration: none;
	color: var(--hpch-accent, #4ECDC4);
	background: transparent;
	border: 2px solid var(--hpch-accent, #4ECDC4);
	border-radius: 999px;
	padding: .55rem 1.2rem;
	font-weight: 600;
	font-size: .9rem;
	transition: background var(--hpch-speed), color var(--hpch-speed), transform var(--hpch-speed);
	white-space: nowrap;
}

.hpch-style-pills .hpch-card:hover {
	background: var(--hpch-accent, #4ECDC4);
	color: #fff;
	transform: scale(1.05);
}

.hpch-style-pills .hpch-icon-wrap,
.hpch-style-pills .hpch-arrow { display: none; }

.hpch-style-pills .hpch-card-inner {
	display: flex;
	align-items: center;
	gap: .45rem;
}

.hpch-style-pills .hpch-cat-count {
	font-size: .75rem;
	opacity: .8;
}

/* =========================================================
   ESTILO: GRID COMPACTO
   ========================================================= */
.hpch-style-grid .hpch-card {
	display: block;
	text-decoration: none;
	color: #fff;
	background: var(--hpch-accent, #4ECDC4);
	border-radius: var(--hpch-radius);
	transition: filter var(--hpch-speed), transform var(--hpch-speed);
	aspect-ratio: 1 / .7;
	position: relative;
	overflow: hidden;
}

.hpch-style-grid .hpch-card::after {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(135deg, rgba(255,255,255,.12) 0%, transparent 60%);
}

.hpch-style-grid .hpch-card:hover {
	filter: brightness(1.1);
	transform: scale(1.03);
}

.hpch-style-grid .hpch-card-inner {
	position: absolute;
	inset: 0;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	padding: 1rem;
	gap: .25rem;
}

.hpch-style-grid .hpch-cat-name {
	font-weight: 700;
	font-size: 1rem;
	text-shadow: 0 1px 3px rgba(0,0,0,.3);
}

.hpch-style-grid .hpch-cat-count {
	font-size: .78rem;
	opacity: .85;
}

.hpch-style-grid .hpch-arrow {
	display: none;
}

/* =========================================================
   ICONOS E IMÁGENES
   ========================================================= */
.hpch-icon-wrap {
	width: 64px;
	height: 64px;
	border-radius: 50%;
	background: color-mix(in srgb, var(--hpch-accent, #4ECDC4) 15%, white);
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	transition: background var(--hpch-speed);
}

.hpch-card:hover .hpch-icon-wrap {
	background: color-mix(in srgb, var(--hpch-accent, #4ECDC4) 25%, white);
}

.hpch-icon-default svg,
.hpch-icon { color: var(--hpch-accent, #4ECDC4); }

.hpch-cat-img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	border-radius: 50%;
}

/* =========================================================
   TEXTO DE CATEGORÍA
   ========================================================= */
.hpch-card-text {
	display: flex;
	flex-direction: column;
	gap: .2rem;
}

.hpch-cat-name {
	font-weight: 600;
	font-size: 1rem;
	line-height: 1.3;
}

.hpch-cat-count {
	font-size: .78rem;
	color: var(--hpch-muted);
}

.hpch-style-grid .hpch-cat-count { color: rgba(255,255,255,.85); }

/* =========================================================
   ESQUEMA DE COLORES: MONO
   ========================================================= */
.hpch-scheme-mono .hpch-card {
	--hpch-accent: #3a3a5c;
}

/* =========================================================
   ESQUEMA DE COLORES: GRADIENT
   ========================================================= */
.hpch-scheme-gradient .hpch-style-cards .hpch-card::before {
	background: linear-gradient(90deg, var(--hpch-accent), color-mix(in srgb, var(--hpch-accent) 60%, white));
}

.hpch-scheme-gradient .hpch-style-grid .hpch-card {
	background: linear-gradient(135deg, var(--hpch-accent), color-mix(in srgb, var(--hpch-accent) 60%, #000));
}

/* =========================================================
   ESTADO VACÍO
   ========================================================= */
.hpch-empty {
	text-align: center;
	color: var(--hpch-muted);
	padding: 2rem;
	border: 1px dashed var(--hpch-border);
	border-radius: var(--hpch-radius);
}
