/**
 * Hingenia Apps · estilos públicos
 *
 * Estilo claro de Hingenia (blanco + azul #2563eb + tarjetas redondeadas).
 * Convención: todas las clases con prefijo .hsi__ para no chocar con
 * estilos del tema.
 */

:root {
	--hsi-blue:   #2563eb;
	--hsi-blue-d: #1d4ed8;
	--hsi-blue-s: #eff4ff;
	--hsi-ink:    #0b0b12;
	--hsi-ink2:   #33415c;
	--hsi-mut:    #7a879c;
	--hsi-line:   #e6eaf2;
	--hsi-line2:  #eef1f6;
	--hsi-bg:     #f6f7fb;
	--hsi-card:   #fff;
	--hsi-green:  #16a34a;
	--hsi-amb-d:  #92400e;
	--hsi-amb-s:  #fef3c7;
	--hsi-vio:    #7c3aed;
	--hsi-vio-s:  #f3edff;
	--hsi-soon:   #94a3b8;
	--hsi-rad:    14px;
}

.hsi { font-family: 'Inter', system-ui, -apple-system, sans-serif; color: var(--hsi-ink); }
.hsi *, .hsi *::before, .hsi *::after { box-sizing: border-box; }

.hsi-archive,
.hsi-single,
.hsi-misMemorias {
	max-width: 1240px;
	margin: 0 auto;
	padding: 40px 24px 60px;
}

/* ───────────── Hero ───────────── */

.hsi__hero { text-align: center; margin-bottom: 40px; }
.hsi__badge {
	display: inline-flex; align-items: center; gap: 8px;
	border: 1px solid var(--hsi-line); background: var(--hsi-card);
	border-radius: 999px; padding: 7px 16px;
	font-size: 11.5px; font-weight: 600; letter-spacing: .1em;
	text-transform: uppercase; color: var(--hsi-mut);
}
.hsi__badge .dot {
	width: 6px; height: 6px; border-radius: 50%;
	background: var(--hsi-blue); box-shadow: 0 0 8px var(--hsi-blue);
}
.hsi__title {
	margin: 22px auto 0; max-width: 18ch;
	font-size: clamp(34px, 5vw, 60px);
	font-weight: 900; letter-spacing: -.035em; line-height: 1.02;
}
.hsi__title .accent { color: var(--hsi-blue); }
.hsi__subtitle {
	margin: 18px auto 0; max-width: 60ch;
	font-size: 16.5px; color: var(--hsi-mut); line-height: 1.55;
}
.hsi__subtitle b { color: var(--hsi-ink); font-weight: 700; }

/* ───────────── Featured ───────────── */

.hsi__featured {
	display: grid; grid-template-columns: 1.1fr 1fr;
	gap: 0; background: var(--hsi-card);
	border: 1px solid var(--hsi-line); border-radius: 18px;
	overflow: hidden;
	box-shadow: 0 30px 60px -36px rgba(13, 20, 45, .25);
	margin: 30px auto 48px; max-width: 1040px;
}
@media (max-width: 880px) { .hsi__featured { grid-template-columns: 1fr; } }
.hsi__featured-l {
	padding: 30px 32px;
	border-right: 1px solid var(--hsi-line2);
	display: flex; flex-direction: column; gap: 14px; align-items: flex-start;
}
@media (max-width: 880px) {
	.hsi__featured-l { border-right: 0; border-bottom: 1px solid var(--hsi-line2); }
}
.hsi__tag {
	display: inline-flex; align-items: center; gap: 7px;
	font-size: 10.5px; font-weight: 800; letter-spacing: .08em;
	text-transform: uppercase; color: var(--hsi-green);
	background: #e9f9ef; border: 1px solid #b9ecc7;
	padding: 4px 10px; border-radius: 999px;
}
.hsi__featured-l h2 {
	font-size: 30px; font-weight: 900;
	letter-spacing: -.03em; line-height: 1.05; margin: 0;
}
.hsi__featured-l p {
	font-size: 14.5px; color: var(--hsi-ink2);
	line-height: 1.55; margin: 0;
}
.hsi__featured-r {
	background: linear-gradient(180deg, #f9fafb, #fff);
	padding: 24px; display: grid; place-items: center;
}
.hsi__stats {
	display: grid; grid-template-columns: 1fr 1fr;
	gap: 14px; width: 100%; max-width: 380px;
}
.hsi__stats > div {
	background: var(--hsi-card);
	border: 1px solid var(--hsi-line); border-radius: 12px;
	padding: 12px 14px;
}
.hsi__stats .k {
	display: block; font-size: 10.5px; font-weight: 700;
	color: var(--hsi-mut); letter-spacing: .08em;
	text-transform: uppercase; margin-bottom: 5px;
	font-family: ui-monospace, monospace;
}
.hsi__stats .v {
	display: block; font-size: 24px; font-weight: 900;
	letter-spacing: -.025em; color: var(--hsi-ink);
}

/* ───────────── Catálogo ───────────── */

.hsi__catalog { margin-top: 30px; }
.hsi__cats {
	display: flex; gap: 8px; flex-wrap: wrap;
	justify-content: center; margin-bottom: 28px;
}
.hsi__cat {
	background: var(--hsi-card);
	border: 1px solid var(--hsi-line);
	border-radius: 999px; padding: 8px 16px;
	font-size: 13px; font-weight: 700; color: #4b5563;
	cursor: pointer; transition: .12s;
	display: inline-flex; align-items: center; gap: 7px;
	font-family: inherit;
	--cat-color: var(--hsi-blue);
}
.hsi__cat:hover {
	border-color: var(--cat-color); color: var(--hsi-ink);
}
.hsi__cat.is-on {
	background: var(--hsi-ink); color: #fff; border-color: var(--hsi-ink);
}
.hsi__cat .ct {
	font-size: 10.5px; font-weight: 800;
	padding: 1px 7px; border-radius: 999px;
	background: var(--hsi-blue-s); color: var(--hsi-blue);
}
.hsi__cat.is-on .ct {
	background: rgba(255, 255, 255, .16); color: #fff;
}

.hsi__grid {
	display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px;
}
@media (max-width: 1080px) { .hsi__grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 640px)  { .hsi__grid { grid-template-columns: 1fr; } }

.hsi__app {
	background: var(--hsi-card);
	border: 1px solid var(--hsi-line);
	border-left: 3px solid var(--hsi-blue);
	border-radius: 16px; padding: 20px;
	display: flex; flex-direction: column; gap: 12px;
	transition: .14s; text-decoration: none; color: inherit;
	position: relative;
}
.hsi__app:hover {
	transform: translateY(-3px);
	box-shadow: 0 22px 44px -28px rgba(13, 20, 45, .26);
}
.hsi__app.is-soon { opacity: .6; cursor: not-allowed; border-left-color: var(--hsi-soon); }
.hsi__app.is-soon:hover { transform: none; box-shadow: none; }

.hsi__app-top { display: flex; align-items: flex-start; justify-content: space-between; gap: 10px; }
.hsi__app-ic {
	width: 42px; height: 42px; border-radius: 12px;
	background: var(--hsi-blue-s); color: var(--hsi-blue);
	display: grid; place-items: center; flex-shrink: 0;
}
.hsi__app-ic img { width: 100%; height: 100%; object-fit: cover; border-radius: 12px; }
.hsi__app.is-soon .hsi__app-ic { background: #f1f3f7; color: var(--hsi-soon); }

.hsi__st {
	font-size: 9.5px; font-weight: 800; letter-spacing: .06em;
	text-transform: uppercase; padding: 3px 9px; border-radius: 999px;
	display: inline-flex; align-items: center; gap: 5px;
}
.hsi__st--live { color: var(--hsi-green); background: #e9f9ef; border: 1px solid #b9ecc7; }
.hsi__st--live::before {
	content: ''; width: 5px; height: 5px; border-radius: 50%;
	background: var(--hsi-green); box-shadow: 0 0 6px var(--hsi-green);
}
.hsi__st--beta { color: var(--hsi-amb-d); background: var(--hsi-amb-s); border: 1px solid #f6d989; }
.hsi__st--new  { color: var(--hsi-vio); background: var(--hsi-vio-s); border: 1px solid #d8c8ff; }
.hsi__st--soon { color: var(--hsi-mut); background: var(--hsi-bg); border: 1px solid var(--hsi-line); }

.hsi__app-name { font-size: 16px; font-weight: 900; letter-spacing: -.015em; line-height: 1.2; margin: 0; }
.hsi__app-desc { font-size: 13.5px; color: #475068; line-height: 1.55; flex: 1; margin: 0; }
.hsi__app-foot {
	display: flex; justify-content: space-between; align-items: center;
	padding-top: 12px; border-top: 1px solid var(--hsi-line2);
}
.hsi__app-norma {
	font-size: 11px; font-weight: 700; color: var(--hsi-ink);
	font-family: ui-monospace, monospace; letter-spacing: .02em;
}
.hsi__app-norma .dl { color: var(--hsi-mut); font-weight: 400; }
.hsi__app-go {
	font-size: 12.5px; font-weight: 800; color: var(--hsi-blue);
	display: inline-flex; align-items: center; gap: 6px; transition: .18s;
}
.hsi__app:hover .hsi__app-go { gap: 9px; }
.hsi__app.is-soon .hsi__app-go { color: var(--hsi-mut); }

.hsi__app-premium {
	position: absolute; top: 12px; right: 14px;
	font-size: 14px; color: #d97706; font-weight: 900;
}

.hsi__empty {
	grid-column: 1 / -1; text-align: center;
	background: var(--hsi-card);
	border: 1px dashed var(--hsi-line); border-radius: 16px;
	padding: 40px 24px; color: var(--hsi-mut);
}
.hsi__empty h3 { color: var(--hsi-ink); margin: 0 0 8px; font-size: 17px; }
.hsi__empty p  { margin: 0 0 16px; }

/* ───────────── Single app ───────────── */

.hsi__breadcrumb {
	font-size: 13px; font-weight: 700; margin-bottom: 18px;
}
.hsi__breadcrumb a { color: var(--hsi-blue); text-decoration: none; }
.hsi__breadcrumb a:hover { color: var(--hsi-blue-d); }

.hsi__notice {
	border-radius: 12px; padding: 16px 18px; margin: 10px 0;
	font-size: 14px; color: var(--hsi-ink2);
	background: var(--hsi-bg); border: 1px solid var(--hsi-line);
}
.hsi__notice--warn {
	background: var(--hsi-amb-s); border-color: #f6d989; color: var(--hsi-amb-d);
}
.hsi__notice strong { display: block; margin-bottom: 4px; }

.hsi__gate {
	background: var(--hsi-card);
	border: 1px solid var(--hsi-line); border-radius: 18px;
	padding: 40px 32px; text-align: center;
	box-shadow: 0 20px 40px -28px rgba(13, 20, 45, .2);
}
.hsi__gate h1 { font-size: 28px; font-weight: 900; letter-spacing: -.025em; margin: 0 0 8px; }
.hsi__gate .hsi__excerpt { color: var(--hsi-mut); font-size: 15px; margin: 0 0 24px; }
.hsi__gate-cta { padding-top: 20px; border-top: 1px solid var(--hsi-line2); }
.hsi__gate-cta h2 { font-size: 22px; font-weight: 800; margin: 0 0 8px; letter-spacing: -.02em; }
.hsi__gate-cta p  { color: var(--hsi-mut); max-width: 50ch; margin: 0 auto 20px; }

/* App container (renderer mount) */
.hsi-app__head { margin-bottom: 16px; }
.hsi-app__head h1 { font-size: 26px; font-weight: 900; letter-spacing: -.025em; margin: 0 0 6px; }
.hsi-app__excerpt { font-size: 14.5px; color: var(--hsi-mut); margin: 0 0 6px; }
.hsi-app__access { font-size: 12px; color: var(--hsi-mut); }
.hsi-app__access code {
	background: var(--hsi-bg); padding: 2px 6px; border-radius: 4px;
	font-size: 11px; color: var(--hsi-ink2);
}
.hsi-app__mount {
	background: var(--hsi-card);
	border: 1px solid var(--hsi-line); border-radius: 16px;
	padding: 24px; margin-top: 16px;
}

/* ───────────── Botones ───────────── */

.hsi__btn {
	display: inline-flex; align-items: center; gap: 8px;
	font-family: inherit; font-weight: 700;
	cursor: pointer; border: 1px solid transparent;
	font-size: 14px; padding: 11px 18px; border-radius: 12px;
	transition: .13s; text-decoration: none;
}
.hsi__btn + .hsi__btn { margin-left: 8px; }
.hsi__btn--primary {
	background: var(--hsi-blue); color: #fff;
	box-shadow: 0 12px 24px -14px rgba(37, 99, 235, .55);
}
.hsi__btn--primary:hover { background: var(--hsi-blue-d); color: #fff; }
.hsi__btn--ghost {
	background: var(--hsi-card); border-color: var(--hsi-line); color: var(--hsi-ink);
}
.hsi__btn--ghost:hover { background: var(--hsi-bg); }

/* ───────────── Mis Memorias ───────────── */

.hsi__head h1 { font-size: 28px; font-weight: 900; letter-spacing: -.025em; margin: 0 0 4px; }
.hsi__head p  { color: var(--hsi-mut); font-size: 14.5px; margin: 0; }

.hsi__memorias-stats { margin: 24px 0; }
.hsi__memorias-stats .kpi {
	display: inline-flex; flex-direction: column;
	background: var(--hsi-card); border: 1px solid var(--hsi-line);
	border-radius: 14px; padding: 14px 20px; min-width: 200px;
}
.hsi__memorias-stats .k { font-size: 11px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--hsi-mut); font-family: ui-monospace, monospace; }
.hsi__memorias-stats .v { font-size: 32px; font-weight: 900; letter-spacing: -.03em; margin-top: 6px; }

.hsi__memorias-grid {
	display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px;
}
@media (max-width: 1000px) { .hsi__memorias-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 640px)  { .hsi__memorias-grid { grid-template-columns: 1fr; } }

.hsi__memoria {
	background: var(--hsi-card); border: 1px solid var(--hsi-line);
	border-radius: 14px; padding: 16px 18px;
	display: flex; flex-direction: column; gap: 8px;
}
.hsi__memoria header {
	display: flex; justify-content: space-between; align-items: center;
	font-size: 11.5px; font-family: ui-monospace, monospace;
	color: var(--hsi-mut);
}
.hsi__memoria-code { color: var(--hsi-blue); font-weight: 700; }
.hsi__memoria h3 { font-size: 15.5px; font-weight: 800; margin: 0; letter-spacing: -.01em; line-height: 1.3; }
.hsi__memoria-app { font-size: 12.5px; color: var(--hsi-mut); margin: 0; }
.hsi__memoria footer { padding-top: 8px; border-top: 1px solid var(--hsi-line2); }
