/* Gartproject Pipeline - frontend factsheet block */

.gtp-fs {
	--gtp-fs-bg: #ffffff;
	--gtp-fs-bg-soft: #f6f8fb;
	--gtp-fs-border: #e3e8ef;
	--gtp-fs-border-soft: #eef2f7;
	--gtp-fs-text: #0f172a;
	--gtp-fs-muted: #64748b;
	--gtp-fs-accent: #0ea5a8;
	--gtp-fs-accent-soft: #ccfbf1;
	--gtp-fs-accent-dark: #0f766e;
	--gtp-fs-warn: #f59e0b;
	--gtp-fs-warn-soft: #fef3c7;
	--gtp-fs-danger: #dc2626;
	--gtp-fs-danger-soft: #fee2e2;
	--gtp-fs-info: #2563eb;
	--gtp-fs-info-soft: #dbeafe;
	--gtp-fs-radius: 14px;
	--gtp-fs-radius-sm: 8px;
	--gtp-fs-shadow: 0 2px 12px rgba(15, 23, 42, .06);

	margin: 2.5em 0 1em;
	padding: 24px;
	background: var(--gtp-fs-bg);
	border: 1px solid var(--gtp-fs-border);
	border-radius: var(--gtp-fs-radius);
	box-shadow: var(--gtp-fs-shadow);
	color: var(--gtp-fs-text);
	font-size: 15px;
	line-height: 1.55;
}

.gtp-fs * { box-sizing: border-box; }

.gtp-fs h2,
.gtp-fs h3,
.gtp-fs h4 {
	color: var(--gtp-fs-text);
	font-family: inherit;
	line-height: 1.25;
}

.gtp-fs h2 { font-size: 22px; margin: 0; }
.gtp-fs h3 { font-size: 16px; margin: 0 0 12px; display: flex; align-items: center; gap: 8px; }
.gtp-fs h4 { font-size: 13px; margin: 0 0 8px; text-transform: uppercase; letter-spacing: .04em; color: var(--gtp-fs-muted); }

.gtp-fs__h-ico {
	display: inline-flex;
	width: 24px; height: 24px;
	align-items: center; justify-content: center;
	background: var(--gtp-fs-accent-soft);
	color: var(--gtp-fs-accent-dark);
	border-radius: 6px;
	font-size: 14px;
}

/* HEADER */
.gtp-fs__head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	padding-bottom: 16px;
	margin-bottom: 16px;
	border-bottom: 1px solid var(--gtp-fs-border-soft);
}

.gtp-fs__title { display: flex; align-items: center; gap: 12px; }

.gtp-fs__icon {
	width: 38px; height: 38px;
	display: inline-flex;
	align-items: center; justify-content: center;
	background: linear-gradient(135deg, var(--gtp-fs-accent) 0%, var(--gtp-fs-accent-dark) 100%);
	color: #fff;
	border-radius: 50%;
	flex: none;
}
.gtp-fs__icon svg { width: 22px; height: 22px; }

.gtp-fs__badge {
	display: inline-flex;
	align-items: baseline;
	gap: 6px;
	padding: 8px 14px;
	background: var(--gtp-fs-accent-soft);
	color: var(--gtp-fs-accent-dark);
	border-radius: 999px;
	font-weight: 600;
}
.gtp-fs__badge strong { font-size: 20px; line-height: 1; }
.gtp-fs__badge span { font-size: 13px; opacity: .85; }

/* SECTIONS */
.gtp-fs__section { margin: 22px 0; }
.gtp-fs__section:first-of-type { margin-top: 0; }
.gtp-fs__section:last-of-type { margin-bottom: 0; }

.gtp-fs__summary p {
	margin: 0;
	padding: 16px 18px;
	background: var(--gtp-fs-bg-soft);
	border-left: 4px solid var(--gtp-fs-accent);
	border-radius: var(--gtp-fs-radius-sm);
	font-size: 15px;
}

/* KEY FACTS */
.gtp-fs__facts {
	list-style: none;
	counter-reset: gtp-fact;
	padding: 0;
	margin: 0;
	display: grid;
	gap: 12px;
}
.gtp-fs__fact {
	counter-increment: gtp-fact;
	position: relative;
	padding: 14px 16px 14px 56px;
	background: var(--gtp-fs-bg);
	border: 1px solid var(--gtp-fs-border);
	border-radius: var(--gtp-fs-radius-sm);
	transition: border-color .15s, box-shadow .15s;
}
.gtp-fs__fact:hover { border-color: var(--gtp-fs-accent); box-shadow: 0 4px 14px rgba(14, 165, 168, .08); }
.gtp-fs__fact::before {
	content: counter(gtp-fact);
	position: absolute;
	top: 14px;
	left: 14px;
	width: 30px; height: 30px;
	background: var(--gtp-fs-accent);
	color: #fff;
	border-radius: 50%;
	font-weight: 700;
	font-size: 13px;
	display: inline-flex;
	align-items: center; justify-content: center;
}
.gtp-fs__fact-claim { color: var(--gtp-fs-text); }
.gtp-fs__fact-src {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	margin-top: 10px;
	padding: 6px 10px;
	font-size: 13px;
	color: var(--gtp-fs-muted);
	background: var(--gtp-fs-bg-soft);
	border-radius: 6px;
	text-decoration: none;
	transition: background .15s, color .15s;
}
.gtp-fs__fact-src:hover { background: var(--gtp-fs-accent-soft); color: var(--gtp-fs-accent-dark); }
.gtp-fs__fact-src-ico { font-size: 14px; }
.gtp-fs__fact-src-text { display: flex; flex-direction: column; line-height: 1.25; }
.gtp-fs__fact-src-title { font-weight: 600; color: inherit; }
.gtp-fs__fact-src-host { font-size: 11px; opacity: .75; }

/* NUMBERS */
.gtp-fs__numbers {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
	gap: 10px;
}
.gtp-fs__num {
	padding: 14px;
	border: 1px solid var(--gtp-fs-border);
	border-radius: var(--gtp-fs-radius-sm);
	background: linear-gradient(180deg, #ffffff 0%, var(--gtp-fs-bg-soft) 100%);
	display: flex;
	flex-direction: column;
	gap: 6px;
}
.gtp-fs__num-val {
	font-size: 24px;
	font-weight: 800;
	color: var(--gtp-fs-accent-dark);
	line-height: 1.1;
}
.gtp-fs__num-ctx {
	font-size: 13px;
	color: var(--gtp-fs-muted);
	line-height: 1.4;
}
.gtp-fs__num-src {
	margin-top: auto;
	font-size: 11px;
	color: var(--gtp-fs-muted);
	text-decoration: none;
	border-top: 1px dashed var(--gtp-fs-border-soft);
	padding-top: 6px;
}
.gtp-fs__num-src:hover { color: var(--gtp-fs-accent-dark); }

/* TIMELINE */
.gtp-fs__timeline {
	list-style: none;
	padding: 0;
	margin: 0;
	position: relative;
}
.gtp-fs__timeline::before {
	content: "";
	position: absolute;
	left: 11px;
	top: 6px;
	bottom: 6px;
	width: 2px;
	background: var(--gtp-fs-border);
}
.gtp-fs__tl-item {
	position: relative;
	padding: 0 0 16px 32px;
}
.gtp-fs__tl-item:last-child { padding-bottom: 0; }
.gtp-fs__tl-dot {
	position: absolute;
	left: 4px;
	top: 6px;
	width: 16px; height: 16px;
	background: var(--gtp-fs-accent);
	border: 3px solid #fff;
	box-shadow: 0 0 0 2px var(--gtp-fs-accent);
	border-radius: 50%;
}
.gtp-fs__tl-date {
	display: inline-block;
	font-size: 12px;
	font-weight: 700;
	letter-spacing: .03em;
	color: var(--gtp-fs-accent-dark);
	background: var(--gtp-fs-accent-soft);
	padding: 2px 8px;
	border-radius: 4px;
	margin-bottom: 4px;
}
.gtp-fs__tl-event { color: var(--gtp-fs-text); }

/* ENTITIES */
.gtp-fs__ent {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 16px;
}
.gtp-fs__ent-group {
	padding: 14px;
	background: var(--gtp-fs-bg-soft);
	border-radius: var(--gtp-fs-radius-sm);
}
.gtp-fs__ent-list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 8px;
}
.gtp-fs__ent-list--inline { flex-direction: row; flex-wrap: wrap; }
.gtp-fs__ent-list li { display: flex; flex-direction: column; gap: 2px; }
.gtp-fs__ent-list--inline li { display: inline-flex; }

.gtp-fs__tag {
	display: inline-block;
	padding: 3px 10px;
	font-size: 13px;
	font-weight: 600;
	background: #fff;
	border: 1px solid var(--gtp-fs-border);
	border-radius: 999px;
	color: var(--gtp-fs-text);
}
.gtp-fs__tag--person { background: var(--gtp-fs-info-soft); border-color: transparent; color: var(--gtp-fs-info); }
.gtp-fs__tag--org    { background: #ede9fe; border-color: transparent; color: #6d28d9; }
.gtp-fs__tag--loc    { background: var(--gtp-fs-accent-soft); border-color: transparent; color: var(--gtp-fs-accent-dark); }
.gtp-fs__tag--risk   { background: var(--gtp-fs-warn-soft); border-color: transparent; color: #92400e; }

.gtp-fs__ent-role {
	font-size: 12px;
	color: var(--gtp-fs-muted);
	padding-left: 4px;
}

/* SLOVAK ANGLE */
.gtp-fs__angle p {
	margin: 0;
	padding: 16px 18px;
	background: linear-gradient(135deg, #fff7ed 0%, #ffedd5 100%);
	border-left: 4px solid #ea580c;
	border-radius: var(--gtp-fs-radius-sm);
}

/* OPEN QUESTIONS */
.gtp-fs__questions {
	list-style: none;
	padding: 0;
	margin: 0;
	display: grid;
	gap: 8px;
}
.gtp-fs__questions li {
	position: relative;
	padding: 10px 14px 10px 36px;
	background: var(--gtp-fs-bg-soft);
	border-radius: var(--gtp-fs-radius-sm);
	color: var(--gtp-fs-text);
}
.gtp-fs__questions li::before {
	content: "?";
	position: absolute;
	left: 10px;
	top: 50%;
	transform: translateY(-50%);
	width: 20px; height: 20px;
	background: var(--gtp-fs-info);
	color: #fff;
	border-radius: 50%;
	font-weight: 700;
	font-size: 13px;
	display: inline-flex;
	align-items: center; justify-content: center;
}

/* RISK FLAGS */
.gtp-fs__risk-list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: grid;
	gap: 10px;
}
.gtp-fs__risk {
	padding: 12px 14px;
	background: var(--gtp-fs-warn-soft);
	border-radius: var(--gtp-fs-radius-sm);
	border-left: 4px solid var(--gtp-fs-warn);
}
.gtp-fs__risk-head { display: flex; align-items: center; gap: 8px; margin-bottom: 6px; flex-wrap: wrap; }
.gtp-fs__risk-note { font-size: 14px; color: #78350f; }

.gtp-fs__sev {
	font-size: 11px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .05em;
	padding: 2px 8px;
	border-radius: 4px;
}
.gtp-fs__sev--low    { background: #dcfce7; color: #166534; }
.gtp-fs__sev--medium { background: var(--gtp-fs-warn-soft); color: #92400e; }
.gtp-fs__sev--high   { background: var(--gtp-fs-danger-soft); color: var(--gtp-fs-danger); }

/* SOURCES LIST */
.gtp-fs__sources {
	padding: 18px;
	background: var(--gtp-fs-bg-soft);
	border-radius: var(--gtp-fs-radius);
}
.gtp-fs__src-list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
	gap: 10px;
}
.gtp-fs__src-link {
	display: flex;
	gap: 12px;
	align-items: flex-start;
	padding: 12px 14px;
	background: #fff;
	border: 1px solid var(--gtp-fs-border);
	border-radius: var(--gtp-fs-radius-sm);
	text-decoration: none;
	color: var(--gtp-fs-text);
	transition: border-color .15s, transform .15s, box-shadow .15s;
}
.gtp-fs__src-link:hover {
	border-color: var(--gtp-fs-accent);
	box-shadow: 0 4px 14px rgba(14, 165, 168, .1);
	transform: translateY(-1px);
}
.gtp-fs__src-fav {
	width: 20px; height: 20px;
	flex: none;
	margin-top: 2px;
	border-radius: 4px;
	background: #fff;
}
.gtp-fs__src-body { display: flex; flex-direction: column; gap: 4px; min-width: 0; flex: 1; }
.gtp-fs__src-title {
	font-weight: 600;
	font-size: 14px;
	color: var(--gtp-fs-text);
	overflow: hidden;
	text-overflow: ellipsis;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
}
.gtp-fs__src-meta {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
	align-items: center;
	font-size: 11px;
	color: var(--gtp-fs-muted);
}
.gtp-fs__src-host { font-weight: 500; }
.gtp-fs__src-pub::before { content: "·"; margin-right: 6px; }
.gtp-fs__src-lang,
.gtp-fs__src-cred {
	padding: 1px 6px;
	border-radius: 3px;
	background: var(--gtp-fs-bg-soft);
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: .04em;
}
.gtp-fs__src-cred--high   { background: #dcfce7; color: #166534; }
.gtp-fs__src-cred--medium { background: var(--gtp-fs-warn-soft); color: #92400e; }
.gtp-fs__src-cred--low    { background: var(--gtp-fs-danger-soft); color: var(--gtp-fs-danger); }

/* FOOT */
.gtp-fs__foot {
	margin-top: 18px;
	padding-top: 14px;
	border-top: 1px solid var(--gtp-fs-border-soft);
	color: var(--gtp-fs-muted);
	font-size: 12px;
	text-align: center;
}

/* RESPONSIVE */
@media (max-width: 600px) {
	.gtp-fs { padding: 18px; }
	.gtp-fs h2 { font-size: 19px; }
	.gtp-fs__fact { padding-left: 50px; }
	.gtp-fs__numbers { grid-template-columns: 1fr 1fr; }
	.gtp-fs__src-list { grid-template-columns: 1fr; }
}

/* DARK MODE */
@media (prefers-color-scheme: dark) {
	.gtp-fs {
		--gtp-fs-bg: #0f172a;
		--gtp-fs-bg-soft: #1e293b;
		--gtp-fs-border: #334155;
		--gtp-fs-border-soft: #1e293b;
		--gtp-fs-text: #f1f5f9;
		--gtp-fs-muted: #94a3b8;
		--gtp-fs-accent-soft: rgba(20, 184, 166, .15);
	}
	.gtp-fs__src-link,
	.gtp-fs__num,
	.gtp-fs__fact { background: #1e293b; }
	.gtp-fs__angle p { background: linear-gradient(135deg, rgba(234, 88, 12, .15) 0%, rgba(234, 88, 12, .05) 100%); color: #fed7aa; }
	.gtp-fs__risk { background: rgba(245, 158, 11, .12); }
	.gtp-fs__risk-note { color: #fde68a; }
}
