/* ════════════════════════════════════════════════════════════════
   SIADE Portal — estilo de la cara pública
   Gobierno Departamental de Chiquimula
   Paleta: navy #0A2647 · navy2 #144272 · dorado #C99700 · celeste #2C74B3
   Tipos: Fraunces (display institucional) · Inter (cuerpo)
   ════════════════════════════════════════════════════════════════ */

:root {
	--navy: #0A2647;
	--navy-2: #144272;
	--celeste: #2C74B3;
	--celeste-claro: #5BA4D4;
	--gold: #C99700;
	--gold-suave: #E9C46A;
	--papel: #F4F7FA;
	--tinta: #0a1320;
	--linea: #E3E9EF;
}

.siade-home {
	font-family: 'Inter', system-ui, -apple-system, sans-serif;
	color: var(--tinta);
	margin: 0;
	background: var(--papel);
	overflow-x: hidden;
}
.siade-home * { box-sizing: border-box; }

/* ── Héroe ── */
.siade-hero {
	position: relative;
	background: linear-gradient(165deg, #0A2647 0%, #144272 60%, #0d2f57 100%);
	padding: clamp(60px, 12vh, 130px) 24px clamp(80px, 14vh, 150px);
	overflow: hidden;
	text-align: center;
}
/* Silueta de cerros (Chiquimula es oriente montañoso) */
.siade-hero__cerros {
	position: absolute; left: 0; right: 0; bottom: 0; height: 280px;
	background:
		radial-gradient(80% 120% at 15% 100%, rgba(201,151,0,0.10) 0%, transparent 55%),
		radial-gradient(90% 130% at 50% 100%, rgba(44,116,179,0.22) 0%, transparent 58%),
		radial-gradient(80% 120% at 88% 100%, rgba(91,164,212,0.12) 0%, transparent 55%);
	pointer-events: none;
}
.siade-hero__cerros::after {
	content: ""; position: absolute; left: 0; right: 0; bottom: 0; height: 120px;
	background: linear-gradient(to top, rgba(13,47,87,0.5), transparent);
}
.siade-hero__inner { position: relative; max-width: 760px; margin: 0 auto; }
.siade-hero__escudo {
	width: 104px; height: 104px; object-fit: contain; margin: 0 auto 22px;
	display: block; filter: drop-shadow(0 6px 18px rgba(0,0,0,0.3));
}
.siade-hero__eyebrow {
	font-size: 12px; letter-spacing: 0.22em; text-transform: uppercase;
	color: var(--celeste-claro); font-weight: 700; margin-bottom: 14px;
}
.siade-hero__titulo {
	font-family: 'Fraunces', Georgia, serif;
	font-size: clamp(48px, 9vw, 88px); font-weight: 600; color: #fff;
	margin: 0 0 20px; line-height: 1.02; letter-spacing: -0.01em;
}
.siade-hero__lema {
	font-size: clamp(15px, 2.2vw, 18px); color: rgba(255,255,255,0.78);
	line-height: 1.6; max-width: 600px; margin: 0 auto 34px;
}
.siade-hero__acciones { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; }

/* Botones */
.siade-btn {
	display: inline-block; padding: 14px 28px; border-radius: 12px;
	font-weight: 700; font-size: 15px; text-decoration: none;
	transition: transform .15s ease, box-shadow .15s ease, background .15s ease;
	cursor: pointer;
}
.siade-btn--oro {
	background: linear-gradient(135deg, var(--gold), var(--gold-suave));
	color: #3a2c00; box-shadow: 0 8px 24px rgba(201,151,0,0.35);
}
.siade-btn--oro:hover { transform: translateY(-2px); box-shadow: 0 12px 30px rgba(201,151,0,0.45); }
.siade-btn--linea {
	background: rgba(255,255,255,0.08); color: #fff;
	border: 1.5px solid rgba(255,255,255,0.35);
}
.siade-btn--linea:hover { background: rgba(255,255,255,0.16); }

/* ── Franja de cifras ── */
.siade-franja {
	background: #fff; display: grid; grid-template-columns: repeat(4, 1fr);
	max-width: 1080px; margin: -54px auto 0; position: relative;
	border-radius: 16px; box-shadow: 0 16px 50px rgba(10,38,71,0.12);
	border: 1px solid var(--linea); overflow: hidden;
}
.siade-franja__item {
	padding: 26px 18px; text-align: center;
	border-right: 1px solid var(--linea);
}
.siade-franja__item:last-child { border-right: none; }
.siade-franja__num {
	display: block; font-family: 'Fraunces', serif; font-size: 40px;
	font-weight: 600; color: var(--navy); line-height: 1;
}
.siade-franja__lbl {
	display: block; font-size: 12.5px; color: #64748b; margin-top: 8px;
	font-weight: 500;
}

/* ── Secciones ── */
.siade-secciones { max-width: 1080px; margin: 0 auto; padding: 80px 24px 40px; }
.siade-secciones__head { text-align: center; max-width: 640px; margin: 0 auto 44px; }
.siade-eyebrow-dark {
	font-size: 12px; letter-spacing: 0.2em; text-transform: uppercase;
	color: var(--gold); font-weight: 700; margin-bottom: 12px;
}
.siade-h2 {
	font-family: 'Fraunces', serif; font-size: clamp(28px, 4.5vw, 40px);
	font-weight: 600; color: var(--navy); margin: 0 0 14px; line-height: 1.15;
}
.siade-sub { font-size: 16px; color: #475569; line-height: 1.6; margin: 0; }

.siade-grid {
	display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px;
}
.siade-card {
	background: #fff; border-radius: 16px; border: 1px solid var(--linea);
	padding: 28px 24px; transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.siade-card:hover {
	transform: translateY(-4px); box-shadow: 0 16px 40px rgba(10,38,71,0.12);
	border-color: var(--celeste-claro);
}
.siade-card__icon {
	width: 52px; height: 52px; border-radius: 13px;
	background: linear-gradient(135deg, var(--navy), var(--navy-2));
	color: var(--gold-suave); display: flex; align-items: center; justify-content: center;
	font-size: 24px; margin-bottom: 18px;
}
.siade-card__titulo {
	font-family: 'Fraunces', serif; font-size: 21px; font-weight: 600;
	color: var(--navy); margin: 0 0 10px;
}
.siade-card__txt { font-size: 14px; color: #475569; line-height: 1.6; margin: 0; }

/* ── CTA ── */
.siade-cta { padding: 70px 24px; }
.siade-cta__inner {
	max-width: 760px; margin: 0 auto; text-align: center;
	background: linear-gradient(135deg, #0A2647, #144272);
	border-radius: 22px; padding: 54px 40px;
	position: relative; overflow: hidden;
}
.siade-cta__inner::before {
	content: ""; position: absolute; top: -60px; right: -60px;
	width: 260px; height: 260px; border-radius: 50%;
	background: radial-gradient(circle, rgba(201,151,0,0.18), transparent 70%);
}
.siade-cta__titulo {
	font-family: 'Fraunces', serif; font-size: clamp(24px, 4vw, 34px);
	font-weight: 600; color: #fff; margin: 0 0 14px; position: relative;
}
.siade-cta__txt {
	font-size: 16px; color: rgba(255,255,255,0.78); line-height: 1.6;
	margin: 0 auto 28px; max-width: 520px; position: relative;
}

/* ── Pie ── */
.siade-pie { background: #07182e; padding: 34px 24px; }
.siade-pie__inner {
	max-width: 1080px; margin: 0 auto; display: flex; justify-content: space-between;
	align-items: center; flex-wrap: wrap; gap: 16px;
}
.siade-pie__titulo { font-family: 'Fraunces', serif; font-size: 17px; color: #fff; font-weight: 600; }
.siade-pie__txt { font-size: 13px; color: rgba(255,255,255,0.55); margin-top: 4px; }

/* ── Responsive ── */
@media (max-width: 860px) {
	.siade-grid { grid-template-columns: repeat(2, 1fr); }
	.siade-franja { grid-template-columns: repeat(2, 1fr); }
	.siade-franja__item:nth-child(2) { border-right: none; }
	.siade-franja__item:nth-child(1), .siade-franja__item:nth-child(2) { border-bottom: 1px solid var(--linea); }
}
@media (max-width: 560px) {
	.siade-grid { grid-template-columns: 1fr; }
	.siade-pie__inner { flex-direction: column; text-align: center; }
}

/* ════════════════════════════════════════════════════════════════
   Panel interno (destino tras el ingreso)
   ════════════════════════════════════════════════════════════════ */
.siade-panel { min-height: 100vh; background: var(--papel); font-family: 'Inter', system-ui, sans-serif; }

.siade-panel__top {
	background: linear-gradient(135deg, #0A2647, #144272);
	padding: 16px 28px; display: flex; justify-content: space-between; align-items: center;
	flex-wrap: wrap; gap: 12px;
}
.siade-panel__brand { display: flex; align-items: center; gap: 13px; }
.siade-panel__brand img { width: 44px; height: 44px; object-fit: contain; }
.siade-panel__brand-eyebrow { font-size: 10.5px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--celeste-claro); font-weight: 700; }
.siade-panel__brand-title { font-family: 'Fraunces', serif; font-size: 19px; color: #fff; font-weight: 600; }
.siade-panel__user { display: flex; align-items: center; gap: 16px; }
.siade-panel__hola { font-size: 14px; color: rgba(255,255,255,0.85); }
.siade-panel__hola strong { color: #fff; }
.siade-panel__salir {
	font-size: 13px; font-weight: 600; color: #fff; text-decoration: none;
	border: 1.5px solid rgba(255,255,255,0.3); border-radius: 8px; padding: 7px 15px;
	transition: background .15s;
}
.siade-panel__salir:hover { background: rgba(255,255,255,0.12); }

.siade-panel__main { max-width: 1060px; margin: 0 auto; padding: 44px 24px 60px; }
.siade-panel__intro { margin-bottom: 32px; }
.siade-panel__h1 { font-family: 'Fraunces', serif; font-size: clamp(26px, 4vw, 36px); font-weight: 600; color: var(--navy); margin: 0 0 8px; }
.siade-panel__sub { font-size: 15.5px; color: #475569; margin: 0; line-height: 1.55; }

.siade-panel__grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; }

.siade-seccion-card {
	display: flex; align-items: center; gap: 16px; padding: 20px 22px;
	background: #fff; border: 1px solid var(--linea); border-radius: 15px;
	text-decoration: none; color: var(--tinta);
	transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease;
	position: relative;
}
.siade-seccion-card:not(.is-pronto):hover {
	transform: translateY(-3px); box-shadow: 0 14px 36px rgba(10,38,71,0.12);
	border-color: var(--celeste-claro);
}
.siade-seccion-card.is-pronto { opacity: 0.62; }
.siade-seccion-card__icon {
	width: 50px; height: 50px; border-radius: 13px; flex-shrink: 0;
	background: linear-gradient(135deg, var(--navy), var(--navy-2));
	color: var(--gold-suave); display: flex; align-items: center; justify-content: center;
	font-size: 23px;
}
.siade-seccion-card__titulo { font-family: 'Fraunces', serif; font-size: 18px; font-weight: 600; color: var(--navy); }
.siade-seccion-card__desc { font-size: 13px; color: #64748b; margin-top: 3px; line-height: 1.45; }
.siade-seccion-card__badge {
	position: absolute; top: 12px; right: 14px; font-size: 10px; font-weight: 700;
	text-transform: uppercase; letter-spacing: 0.05em; color: var(--gold);
	background: #FBF1D8; padding: 3px 9px; border-radius: 20px;
}

@media (max-width: 680px) {
	.siade-panel__grid { grid-template-columns: 1fr; }
}

/* ════════════════════════════════════════════════════════════════
   Panel del Portal (app React con menú lateral) — responsive
   ════════════════════════════════════════════════════════════════ */
.siade-portal-root { background: #eef2f7; }

/* Escritorio: el sidebar siempre visible (la app lo posiciona fixed) */
@media (min-width: 901px) {
	.siade-aside { transform: translateX(0) !important; }
	.siade-hamburguesa { display: none !important; }
}

/* Móvil/tablet: sidebar oculto, contenido a ancho completo */
@media (max-width: 900px) {
	.siade-contenido { margin-left: 0 !important; }
	.siade-hamburguesa { display: block !important; }
	.siade-kpis { grid-template-columns: repeat(2, 1fr) !important; }
	.siade-atajos { grid-template-columns: 1fr !important; }
	.siade-org { display: none !important; }
}
@media (max-width: 560px) {
	.siade-kpis { grid-template-columns: 1fr !important; }
}

/* Calendario — responsive */
@media (max-width: 700px) {
	.siade-cal-cell, .siade-cal-grid > div { min-height: 64px !important; }
	.siade-cal-cell span { font-size: 9.5px !important; }
}
