/**
 * Solar Kết Nối — layout trang nội dung (chuẩn: Giới thiệu)
 * WordPress + Django /hub/. Token: /assets/skn-tokens.css
 */

body.skn-front-page #primary {
	margin: 0;
	padding: 0;
}

body.skn-front-page .ast-article-single,
body.skn-front-page .entry-content {
	margin: 0;
	padding: 0;
}

/* ---- Shell ---- */
.skn-landing {
	position: relative;
	font-family: var(--skn-font);
	color: var(--skn-text);
	line-height: var(--skn-text-leading);
	background: transparent !important;
	background-image: none !important;
}

#skn-main-content {
	background: transparent !important;
	background-image: none !important;
	margin: 0;
	padding: 0;
}

body.skn-site-page #page,
body.skn-site-page .site-content,
body.skn-site-page #primary,
body.skn-site-page .ast-container,
body.skn-landing-page #page,
body.skn-landing-page .site-content,
body.skn-landing-page #primary,
body.skn-landing-page .ast-container {
	margin: 0;
	padding-left: 0;
	padding-right: 0;
	max-width: none;
}

.skn-landing__glow {
	position: fixed;
	inset: 0;
	pointer-events: none;
	z-index: 0;
	background:
		radial-gradient(ellipse 70% 55% at 20% 5%, rgb(56 189 248 / 32%), transparent 52%),
		radial-gradient(ellipse 65% 50% at 85% 15%, rgb(14 165 233 / 26%), transparent 50%),
		radial-gradient(ellipse 80% 55% at 50% 95%, rgb(2 132 199 / 22%), transparent 58%);
}

.skn-landing > section,
.skn-landing > .skn-landing__glow {
	position: relative;
	z-index: 1;
}

.skn-container {
	width: var(--skn-container);
	max-width: 100%;
	margin-inline: auto;
	padding-inline: var(--skn-container-pad, 18px);
}

.skn-landing h1,
.skn-landing h2,
.skn-landing h3,
.skn-landing .skn-btn,
.skn-landing .skn-section__eyebrow,
.skn-landing .skn-stat-card__value {
	font-family: var(--skn-font-display);
}

/* ---- Pulse ---- */
.skn-pulse {
	display: inline-block;
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background: var(--skn-accent);
	box-shadow: 0 0 10px var(--skn-accent);
	flex-shrink: 0;
	animation: skn-pulse 2s ease-in-out infinite;
}

.skn-pulse--green {
	background: var(--skn-green);
	box-shadow: 0 0 10px var(--skn-green);
}

@keyframes skn-pulse {
	0%, 100% { opacity: 1; transform: scale(1); }
	50%      { opacity: 0.55; transform: scale(0.88); }
}

/* ---- Buttons (dùng chung WP + /hub/) ---- */
.skn-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.35rem;
	padding: 0.5rem 1rem;
	border-radius: 8px;
	font-family: var(--skn-font-display);
	font-size: 0.9375rem;
	font-weight: 600;
	line-height: 1.25;
	text-decoration: none;
	border: 1px solid transparent;
	cursor: pointer;
	white-space: nowrap;
	min-height: 2.125rem;
	transition:
		background var(--skn-transition),
		color var(--skn-transition),
		border-color var(--skn-transition),
		box-shadow var(--skn-transition);
}

.skn-btn:focus-visible {
	outline: 2px solid var(--skn-accent);
	outline-offset: 2px;
}

.skn-btn--sm {
	padding: 0.22rem 0.5rem;
	font-size: 0.75rem;
	min-height: 1.5rem;
	border-radius: 6px;
	gap: 0.25rem;
}

.skn-btn--lg {
	padding: 0.75rem 1.5rem;
	font-size: 1rem;
	min-height: 2.5rem;
	border-radius: var(--skn-radius);
}

.skn-btn--primary {
	background: linear-gradient(135deg, #38bdf8 0%, #0ea5e9 45%, #0369a1 100%);
	color: #fff;
	border-color: rgb(56 189 248 / 40%);
	box-shadow: var(--skn-glow), 0 0 16px rgb(251 191 36 / 10%);
}

.skn-btn--primary:hover {
	background: linear-gradient(135deg, #7dd3fc 0%, #38bdf8 50%, #0284c7 100%);
	box-shadow: 0 4px 16px rgb(56 189 248 / 30%);
	color: #fff;
	text-decoration: none;
}

.skn-btn--primary.skn-btn--sm:hover,
.skn-btn--success.skn-btn--sm:hover,
.skn-btn--danger.skn-btn--sm:hover,
.skn-btn--ghost.skn-btn--sm:hover {
	transform: none;
}

.skn-btn--secondary {
	background: var(--skn-surface);
	color: var(--skn-text);
	border-color: var(--skn-border-strong);
}

.skn-btn--secondary:hover {
	background: var(--skn-bg-elevated);
	border-color: var(--skn-accent);
	color: var(--skn-accent);
	text-decoration: none;
}

.skn-btn--ghost {
	background: rgb(255 255 255 / 6%);
	color: var(--skn-text);
	border-color: rgb(255 255 255 / 22%);
}

.skn-btn--ghost:hover {
	background: rgb(255 255 255 / 12%);
	border-color: var(--skn-accent);
	color: var(--skn-text);
	text-decoration: none;
}

.skn-btn--success {
	background: var(--skn-green);
	color: #fff;
	border-color: var(--skn-green);
}

.skn-btn--success:hover {
	background: #16a34a;
	border-color: #16a34a;
	color: #fff;
}

.skn-btn--danger {
	background: #b91c1c;
	color: #fff;
	border-color: #b91c1c;
}

.skn-btn--danger:hover {
	background: #991b1b;
	border-color: #991b1b;
	color: #fff;
}

.skn-btn--amber {
	background: #b45309;
	color: #fff;
	border-color: var(--skn-amber);
}

.skn-btn--lg.skn-btn--primary:hover {
	transform: translateY(-1px);
	box-shadow: 0 8px 24px rgb(56 189 248 / 32%);
}

.skn-btn__icon {
	flex-shrink: 0;
}

/* Nhóm nút nằm ngang (bảng, toolbar) */
.skn-btn-row {
	display: inline-flex;
	flex-wrap: nowrap;
	align-items: center;
	gap: 0.2rem;
	max-width: 100%;
}

.skn-btn-row--end {
	justify-content: flex-end;
}

.skn-btn-row > form,
.skn-btn-row > details,
.skn-btn-row > a.skn-btn {
	display: inline-flex;
	margin: 0;
	flex-shrink: 0;
}

.skn-btn-group {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.5rem;
	margin-bottom: 1rem;
}

.skn-input--sm {
	padding: 0.22rem 0.45rem;
	font-size: 0.75rem;
	line-height: 1.3;
	min-height: 1.5rem;
	border-radius: 6px;
}

/* Popup từ chối trong ô thao tác bảng */
.skn-action-pop {
	position: relative;
	display: inline-flex;
}

.skn-action-pop > summary {
	list-style: none;
}

.skn-action-pop > summary::-webkit-details-marker {
	display: none;
}

.skn-action-pop__body {
	position: absolute;
	right: 0;
	top: calc(100% + 0.25rem);
	z-index: 30;
	display: none;
	align-items: center;
	gap: 0.25rem;
	padding: 0.35rem;
	min-width: 10rem;
	background: var(--skn-surface);
	border: 1px solid var(--skn-border);
	border-radius: 8px;
	box-shadow: 0 8px 24px rgb(0 0 0 / 35%);
}

.skn-action-pop[open] .skn-action-pop__body {
	display: flex;
}

.skn-action-pop__body form {
	display: flex;
	align-items: center;
	gap: 0.25rem;
	width: 100%;
	margin: 0;
}

.skn-action-pop__body .skn-input--sm {
	flex: 1;
	min-width: 5rem;
}

.skn-link {
	display: inline-block;
	margin-top: 1.25rem;
	font-weight: 600;
	font-size: 0.9375rem;
	color: var(--skn-accent);
	text-decoration: none;
	transition: color var(--skn-transition);
}

.skn-link:hover {
	color: var(--skn-cyan);
	text-decoration: underline;
	text-underline-offset: 0.2em;
}

/* ---- Sections ---- */
.skn-section {
	padding-block: clamp(3rem, 8vw, 5rem);
}

.skn-section-band {
	border-block: 1px solid var(--skn-border-strong);
	background: var(--skn-gradient-band);
	box-shadow: inset 0 1px 0 rgb(56 189 248 / 12%);
}

.skn-section__header {
	text-align: center;
	max-width: 40rem;
	margin-inline: auto;
	margin-bottom: 2.5rem;
}

.skn-section__eyebrow {
	display: inline-block;
	margin-bottom: 0.75rem;
	padding: 0.25rem 0.75rem;
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--skn-accent);
	background: var(--skn-accent-soft);
	border: 1px solid var(--skn-border-strong);
	border-radius: var(--skn-radius-pill);
}

.skn-section__title {
	margin: 0;
	font-size: var(--skn-h2-size);
	font-weight: 700;
	line-height: var(--skn-heading-leading);
	color: var(--skn-text);
}

/* ---- Hero ---- */
.skn-hero {
	position: relative;
	padding-block: clamp(2.5rem, 6vw, 4.5rem) clamp(2rem, 5vw, 3.5rem);
	overflow: hidden;
	background: transparent;
}

.skn-hero__inner {
	position: relative;
	z-index: 1;
}

.skn-hero__bg {
	position: absolute;
	inset: 0;
	background: var(--skn-gradient-hero);
	pointer-events: none;
}

.skn-hero__bg::after {
	content: "";
	position: absolute;
	inset: 0;
	background: radial-gradient(ellipse 90% 70% at 50% 20%, rgb(56 189 248 / 18%), transparent 70%);
	pointer-events: none;
}

.skn-hero__layout {
	position: relative;
	display: grid;
	gap: 2rem;
	align-items: center;
}

.skn-hero__content {
	text-align: center;
}

.skn-hero__badge {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.4rem 1rem;
	margin-bottom: 1.25rem;
	border-radius: var(--skn-radius-pill);
	font-size: 0.8125rem;
	font-weight: 600;
	color: var(--skn-accent);
	background: var(--skn-accent-soft);
	border: 1px solid var(--skn-border-strong);
}

.skn-hero__title {
	margin: 0 0 1rem;
	font-family: var(--skn-font-display);
	font-size: var(--skn-h1-size);
	font-weight: 800;
	line-height: var(--skn-heading-leading);
	color: var(--skn-text);
}

.skn-hero__lead {
	margin: 0 auto 1.75rem;
	max-width: 36rem;
	font-size: clamp(1rem, 2.2vw, 1.125rem);
	color: var(--skn-text-muted);
}

.skn-hero__cta {
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
	align-items: stretch;
	margin-bottom: 1.75rem;
}

.skn-hero__cta--center {
	justify-content: center;
}

.skn-hero__trust {
	display: flex;
	flex-direction: column;
	gap: 0.625rem;
	margin: 0;
	padding: 0;
	list-style: none;
	font-size: 0.875rem;
	color: var(--skn-text-dim);
}

.skn-hero__trust li {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
}

.skn-hero__trust svg {
	color: var(--skn-accent);
	flex-shrink: 0;
}

/* Hero side panel */
.skn-hero__panel {
	padding: 1.5rem;
	border-radius: var(--skn-radius-lg);
	background: var(--skn-gradient-card);
	border: 1px solid var(--skn-border-strong);
	box-shadow: var(--skn-shadow-lg);
	backdrop-filter: blur(12px);
}

.skn-hero__panel-label {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	margin: 0 0 1rem;
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--skn-green);
}

.skn-hero__panel-stats {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 0.75rem;
	margin: 0 0 1rem;
	padding: 0;
	list-style: none;
}

.skn-hero__panel-stats li {
	text-align: center;
	padding: 0.75rem 0.5rem;
	border-radius: var(--skn-radius);
	background: rgb(0 0 0 / 25%);
	border: 1px solid var(--skn-border);
}

.skn-hero__panel-value {
	display: block;
	font-size: clamp(1.5rem, 4vw, 2rem);
	font-weight: 800;
	color: var(--skn-text);
	font-variant-numeric: tabular-nums;
}

.skn-hero__panel-desc {
	display: block;
	margin-top: 0.25rem;
	font-size: 0.6875rem;
	color: var(--skn-text-muted);
	line-height: 1.3;
}

.skn-hero__panel-note {
	margin: 0;
	font-size: 0.8125rem;
	text-align: center;
	color: var(--skn-text-dim);
}

/* ---- Stats ---- */
.skn-stats {
	padding-block: clamp(2.5rem, 6vw, 4rem);
}

.skn-stats__header {
	text-align: center;
	margin-bottom: 2rem;
}

.skn-stats__live {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	margin-bottom: 0.75rem;
	font-size: 0.75rem;
	font-weight: 700;
	color: var(--skn-green);
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.skn-stats__title {
	margin: 0;
	font-size: var(--skn-h2-size);
	font-weight: 700;
	color: var(--skn-text);
}

.skn-stats__grid {
	display: grid;
	gap: 1rem;
}

.skn-stat-card {
	padding: 1.5rem;
	border-radius: var(--skn-radius-lg);
	background: var(--skn-gradient-card);
	border: 1px solid var(--skn-border);
	backdrop-filter: blur(8px);
	transition: border-color var(--skn-transition), box-shadow var(--skn-transition);
}

.skn-stat-card:hover {
	border-color: var(--skn-border-strong);
	box-shadow: var(--skn-glow);
}

.skn-stat-card--accent {
	background: linear-gradient(145deg, rgb(14 165 233 / 22%), rgb(6 11 18 / 80%));
	border-color: var(--skn-border-strong);
}

.skn-stat-card__value {
	margin: 0 0 0.25rem;
	font-size: clamp(2rem, 6vw, 2.75rem);
	font-weight: 800;
	line-height: 1;
	color: var(--skn-text);
	font-variant-numeric: tabular-nums;
}

.skn-stat-card__label {
	margin: 0 0 0.5rem;
	font-size: 1rem;
	font-weight: 600;
	color: var(--skn-accent);
}

.skn-stat-card__desc {
	margin: 0;
	font-size: 0.875rem;
	color: var(--skn-text-muted);
	line-height: 1.5;
}

/* ---- Process ---- */
.skn-process {
	background: var(--skn-gradient-section);
}

.skn-steps {
	display: grid;
	gap: 1.25rem;
	margin: 0;
	padding: 0;
	list-style: none;
}

.skn-step {
	position: relative;
	padding: 1.5rem 1.5rem 1.5rem 1.75rem;
	background: var(--skn-gradient-card);
	border-radius: var(--skn-radius-lg);
	border: 1px solid var(--skn-border);
	box-shadow: var(--skn-shadow);
}

.skn-step::before {
	content: "";
	position: absolute;
	left: 0;
	top: 1rem;
	bottom: 1rem;
	width: 3px;
	border-radius: 3px;
	background: linear-gradient(180deg, var(--skn-accent), var(--skn-cyan-dim));
}

.skn-step__num {
	display: block;
	margin-bottom: 0.75rem;
	font-size: 0.75rem;
	font-weight: 800;
	letter-spacing: 0.12em;
	color: var(--skn-accent);
}

.skn-step__title {
	margin: 0 0 0.5rem;
	font-size: 1.125rem;
	font-weight: 700;
	color: var(--skn-text);
}

.skn-step__text {
	margin: 0;
	font-size: 0.9375rem;
	color: var(--skn-text-muted);
}

/* ---- Audience ---- */
.skn-audience {
	background: transparent;
}

.skn-audience__grid {
	display: grid;
	gap: 1.25rem;
}

.skn-audience-card {
	padding: 1.75rem;
	border-radius: var(--skn-radius-lg);
	border: 1px solid var(--skn-border);
	background: var(--skn-gradient-card);
	box-shadow: var(--skn-shadow);
	transition: border-color var(--skn-transition), box-shadow var(--skn-transition);
}

.skn-audience-card:hover {
	border-color: var(--skn-border-strong);
	box-shadow: var(--skn-glow);
}

.skn-audience-card__icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 3rem;
	height: 3rem;
	margin-bottom: 1rem;
	border-radius: var(--skn-radius);
}

.skn-audience-card__icon--owner {
	background: var(--skn-accent-soft);
	color: var(--skn-accent);
	border: 1px solid var(--skn-border-strong);
}

.skn-audience-card__icon--tech {
	background: rgb(52 211 153 / 12%);
	color: var(--skn-green);
	border: 1px solid rgb(52 211 153 / 30%);
}

.skn-audience-card__title {
	margin: 0 0 1rem;
	font-size: 1.25rem;
	font-weight: 700;
	color: var(--skn-text);
}

.skn-audience-card__list {
	margin: 0;
	padding: 0 0 0 1.125rem;
	font-size: 0.9375rem;
	color: var(--skn-text-muted);
}

.skn-audience-card__list li + li {
	margin-top: 0.5rem;
}

/* ---- Trust ---- */
.skn-trust {
	background: var(--skn-surface-2);
	border-block: 1px solid var(--skn-border);
}

.skn-trust__inner {
	display: grid;
	gap: 2rem;
}

.skn-trust__lead {
	margin: 1rem 0 0;
	font-size: 1rem;
	color: var(--skn-text-muted);
	max-width: 32rem;
}

.skn-trust__grid {
	display: grid;
	gap: 1rem;
	margin: 0;
	padding: 0;
	list-style: none;
}

.skn-trust-item {
	display: flex;
	gap: 1rem;
	padding: 1.25rem;
	background: var(--skn-gradient-card);
	border-radius: var(--skn-radius);
	border: 1px solid var(--skn-border);
}

.skn-trust-item__icon {
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	width: 2.75rem;
	height: 2.75rem;
	border-radius: 10px;
	background: var(--skn-accent-soft);
	color: var(--skn-accent);
	border: 1px solid var(--skn-border-strong);
}

.skn-trust-item strong {
	display: block;
	margin-bottom: 0.25rem;
	font-size: 0.9375rem;
	font-weight: 600;
	color: var(--skn-text);
}

.skn-trust-item p {
	margin: 0;
	font-size: 0.875rem;
	color: var(--skn-text-muted);
}

/* ---- Final CTA ---- */
.skn-cta-final {
	padding-block: clamp(3rem, 8vw, 5rem);
	background: var(--skn-gradient-cta);
	border-top: 1px solid var(--skn-border-strong);
	box-shadow: inset 0 1px 0 rgb(56 189 248 / 20%), var(--skn-glow-strong);
}

.skn-cta-final__inner {
	text-align: center;
}

.skn-cta-final__title {
	margin: 0 0 0.75rem;
	font-size: var(--skn-h2-size);
	font-weight: 800;
	color: var(--skn-text);
}

.skn-cta-final__text {
	margin: 0 auto 2rem;
	max-width: 32rem;
	font-size: 1rem;
	color: var(--skn-text-muted);
}

/* ---- Responsive ---- */
@media (min-width: 640px) {
	.skn-hero__cta {
		flex-direction: row;
		justify-content: center;
		align-items: center;
	}

	.skn-hero__cta .skn-btn {
		min-width: 11rem;
	}

	.skn-hero__trust {
		flex-direction: row;
		justify-content: center;
		flex-wrap: wrap;
		gap: 1.5rem;
	}

	.skn-stats__grid {
		grid-template-columns: repeat(3, 1fr);
		gap: 1.25rem;
	}

	.skn-steps {
		grid-template-columns: repeat(3, 1fr);
		gap: 1.5rem;
	}

	.skn-audience__grid {
		grid-template-columns: repeat(2, 1fr);
		gap: 1.5rem;
	}

	.skn-trust__grid {
		grid-template-columns: repeat(3, 1fr);
	}
}

@media (min-width: 960px) {
	.skn-hero__layout {
		grid-template-columns: 1.15fr 0.85fr;
		gap: 2.5rem;
	}

	.skn-hero__content {
		text-align: left;
	}

	.skn-hero__lead {
		margin-inline: 0;
	}

	.skn-hero__cta {
		justify-content: flex-start;
	}

	.skn-hero__trust li {
		justify-content: flex-start;
	}

	.skn-trust__inner {
		grid-template-columns: 1fr 1.35fr;
		align-items: start;
		gap: 3rem;
	}
}

/* ---- Sub-pages (blog, about…) ---- */
.skn-hero--sub {
	padding-block: 2.5rem 3rem;
}

.skn-hero--sub .skn-hero__lead,
.skn-hero--sub .skn-hero__disclaimer,
.skn-hero--sub .skn-hero__quote {
	margin-inline: 0;
	margin-bottom: 0;
	max-width: 40rem;
}

.skn-hero__badge--green {
	color: var(--skn-green);
	background: rgb(52 211 153 / 12%);
	border-color: rgb(52 211 153 / 35%);
}

.skn-steps--4 {
	grid-template-columns: 1fr;
}

.skn-hero__quote {
	font-family: var(--skn-font-display);
	font-size: clamp(1.25rem, 3vw, 1.75rem);
	color: var(--skn-accent);
	margin-bottom: 1rem !important;
}

.skn-hero--compact {
	padding-block: 2rem 1.5rem;
}

.skn-blog-grid {
	display: grid;
	gap: 1.25rem;
}

.skn-blog-card {
	padding: 0;
	border: 1px solid var(--skn-border);
	border-radius: var(--skn-radius-lg);
	background: var(--skn-gradient-card);
	overflow: hidden;
	transition: border-color var(--skn-transition), box-shadow var(--skn-transition);
}

.skn-blog-card__thumb {
	display: block;
	aspect-ratio: 16 / 9;
	overflow: hidden;
	border-bottom: 1px solid var(--skn-border);
}

.skn-blog-card__thumb img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform var(--skn-transition);
}

.skn-blog-card:hover .skn-blog-card__thumb img {
	transform: scale(1.03);
}

.skn-blog-card__title,
.skn-blog-card__date,
.skn-blog-card__excerpt,
.skn-blog-card > .skn-link {
	padding-inline: 1.25rem;
}

.skn-blog-card__title {
	padding-top: 1.25rem;
}

.skn-blog-card > .skn-link {
	display: inline-block;
	padding-bottom: 1.25rem;
}

.skn-post-cover {
	margin: 0 0 1.75rem;
	border-radius: var(--skn-radius-lg);
	overflow: hidden;
	border: 1px solid var(--skn-border-strong);
}

.skn-post-cover__img {
	display: block;
	width: 100%;
	height: auto;
}

.skn-blog-card:hover {
	border-color: var(--skn-border-strong);
	box-shadow: var(--skn-glow);
}

.skn-blog-card__title {
	margin: 0 0 0.5rem;
	font-family: var(--skn-font-display);
	font-size: 1.375rem;
}

.skn-blog-card__title a {
	color: var(--skn-text);
	text-decoration: none;
}

.skn-blog-card__title a:hover {
	color: var(--skn-accent);
}

.skn-blog-card__date {
	display: block;
	margin-bottom: 0.75rem;
	font-size: 0.875rem;
	color: var(--skn-text-dim);
}

.skn-blog-card__excerpt {
	margin: 0 0 0.75rem;
	font-size: 0.9375rem;
	color: var(--skn-text-muted);
}

.skn-empty-state {
	padding: 2.5rem;
	text-align: center;
	border: 1px dashed var(--skn-border);
	border-radius: var(--skn-radius-lg);
	color: var(--skn-text-muted);
}

.skn-contact-grid {
	display: grid;
	gap: 1rem;
}

.skn-prose {
	max-width: 48rem;
	font-size: 1.0625rem;
	line-height: 1.75;
	color: var(--skn-text-muted);
}

.skn-prose > :first-child {
	margin-top: 0;
}

.skn-prose h2 {
	margin: 2rem 0 0.75rem;
	font-family: var(--skn-font-display);
	font-size: 1.5rem;
	font-weight: 600;
	color: var(--skn-text);
}

.skn-prose h3 {
	margin: 1.5rem 0 0.5rem;
	font-family: var(--skn-font-display);
	font-size: 1.25rem;
	font-weight: 600;
	color: var(--skn-text);
}

.skn-prose p {
	margin: 0 0 1rem;
}

.skn-prose ul,
.skn-prose ol {
	margin: 0 0 1.25rem;
	padding-left: 1.5rem;
}

.skn-prose li + li {
	margin-top: 0.375rem;
}

.skn-prose a {
	color: var(--skn-accent);
	text-decoration: underline;
	text-underline-offset: 2px;
}

.skn-prose em {
	color: var(--skn-text-dim);
}

@media (min-width: 640px) {
	.skn-audience__grid:has(.skn-audience-card:only-child) {
		grid-template-columns: 1fr;
	}

	.skn-section .skn-audience__grid {
		grid-template-columns: repeat(auto-fit, minmax(16rem, 1fr));
	}

	.skn-steps--4 {
		grid-template-columns: repeat(2, 1fr);
	}

	.skn-blog-grid {
		grid-template-columns: repeat(2, 1fr);
	}

	.skn-contact-grid {
		grid-template-columns: repeat(3, 1fr);
	}
}

@media (min-width: 1024px) {
	.skn-steps--4 {
		grid-template-columns: repeat(4, 1fr);
	}

	.skn-blog-grid {
		grid-template-columns: repeat(3, 1fr);
	}
}

@media (prefers-reduced-motion: reduce) {
	.skn-pulse {
		animation: none;
	}

	.skn-btn:hover {
		transform: none;
	}
}

/* ---- Django /hub/ — map component app sang layout Giới thiệu ---- */
.skn-landing .skn-card,
.skn-landing .skn-list > li.skn-card {
	padding: 1.75rem;
	border-radius: var(--skn-radius-lg);
	border: 1px solid var(--skn-border);
	background: var(--skn-gradient-card);
	box-shadow: var(--skn-shadow);
	transition: border-color var(--skn-transition), box-shadow var(--skn-transition);
	list-style: none;
	margin: 0;
}

.skn-landing .skn-card:hover,
.skn-landing .skn-list > li.skn-card:hover {
	border-color: var(--skn-border-strong);
	box-shadow: var(--skn-glow);
}

.skn-landing .skn-list {
	margin: 0;
	padding: 0;
	display: grid;
	gap: 1rem;
}

.skn-landing .skn-card__title {
	margin: 0 0 0.5rem;
	font-family: var(--skn-font-display);
	font-size: 1.25rem;
	font-weight: 700;
	color: var(--skn-text);
	text-decoration: none;
}

.skn-landing .skn-card__title:hover {
	color: var(--skn-accent);
}

.skn-landing .skn-card__meta {
	font-size: 0.9375rem;
	color: var(--skn-text-muted);
}

.skn-landing .skn-badge {
	display: inline-block;
	padding: 0.2rem 0.65rem;
	border-radius: var(--skn-radius-pill);
	font-size: 0.75rem;
	font-weight: 600;
	background: var(--skn-accent-soft);
	color: var(--skn-accent);
	border: 1px solid var(--skn-border-strong);
}

.skn-landing .skn-stats-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(8rem, 1fr));
	gap: 1rem;
	margin-bottom: 1.5rem;
}

.skn-landing .skn-stats-grid .skn-stat-card {
	text-align: center;
	padding: 1.25rem 1rem;
}

.skn-landing .skn-stats-grid .skn-stat-card__value {
	font-size: clamp(1.5rem, 4vw, 2rem);
	margin: 0;
}

.skn-landing .skn-stats-grid .skn-stat-card__label {
	font-size: 0.875rem;
	margin: 0 0 0.35rem;
}

.skn-landing .skn-btn-group {
	display: flex;
	flex-wrap: wrap;
	gap: 0.75rem;
	margin-bottom: 1.25rem;
}

.skn-landing .skn-form {
	max-width: 28rem;
}

.skn-landing .skn-field {
	margin-bottom: 1rem;
}

.skn-landing .skn-field label {
	display: block;
	margin-bottom: 0.35rem;
	font-size: 0.9375rem;
	font-weight: 600;
	color: var(--skn-text);
}

.skn-landing .skn-input,
.skn-landing .skn-textarea,
.skn-landing .skn-select {
	width: 100%;
	padding: 0.65rem 0.85rem;
	border-radius: var(--skn-radius);
	border: 1px solid var(--skn-border);
	background: var(--skn-surface);
	color: var(--skn-text);
	font-family: var(--skn-font-body);
	font-size: 1rem;
}

.skn-landing .skn-input:focus,
.skn-landing .skn-textarea:focus,
.skn-landing .skn-select:focus {
	outline: none;
	border-color: var(--skn-accent);
	box-shadow: 0 0 0 3px rgb(56 189 248 / 18%);
}

.skn-landing .skn-alert {
	padding: 0.75rem 1rem;
	border-radius: var(--skn-radius);
	border: 1px solid var(--skn-border);
	margin-bottom: 1rem;
	font-size: 0.9375rem;
}

.skn-landing .skn-alert--info,
.skn-landing .skn-alert--warn,
.skn-landing .skn-alert--error {
	background: var(--skn-gradient-card);
	color: var(--skn-text-muted);
}

.skn-landing .skn-alert--warn,
.skn-landing .skn-alert--error {
	border-color: rgb(251 191 36 / 45%);
	color: var(--skn-amber);
}

.skn-landing .skn-tech-nav,
.skn-landing .skn-admin-nav {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.125rem;
	margin: 0 0 1.5rem;
	padding-bottom: 1rem;
	border-bottom: 1px solid var(--skn-border);
}

.skn-landing .skn-tech-nav a,
.skn-landing .skn-admin-nav a,
.skn-landing .skn-admin-nav .skn-admin-nav__link {
	display: inline-flex;
	align-items: center;
	padding: 0.5rem 1rem;
	border-radius: var(--skn-radius-pill);
	font-family: var(--skn-font-body);
	font-size: 1rem;
	font-weight: 500;
	color: var(--skn-text-muted);
	text-decoration: none;
	border: 1px solid transparent;
	transition:
		background var(--skn-transition),
		color var(--skn-transition),
		border-color var(--skn-transition);
}

.skn-landing .skn-tech-nav a:hover,
.skn-landing .skn-admin-nav a:hover,
.skn-landing .skn-tech-nav a.is-active,
.skn-landing .skn-admin-nav a.is-active,
.skn-landing .skn-admin-nav .skn-admin-nav__link--active {
	color: var(--skn-accent);
	background: var(--skn-accent-soft);
	border-color: var(--skn-border-strong);
	text-decoration: underline;
	text-underline-offset: 0.2em;
}

.skn-landing .skn-lead,
.skn-landing .skn-form-footer {
	color: var(--skn-text-muted);
	font-size: clamp(1rem, 2.2vw, 1.125rem);
	line-height: var(--skn-text-leading);
}

.skn-landing .skn-section-title {
	margin: 0 0 1rem;
	font-family: var(--skn-font-display);
	font-size: var(--skn-h3-size);
	font-weight: 700;
	line-height: var(--skn-heading-leading);
	color: var(--skn-text);
}

.skn-landing .skn-form-footer a {
	color: var(--skn-accent);
}

.skn-landing .skn-form-hint {
	margin: 0 0 1rem;
	font-size: 0.875rem;
	color: var(--skn-text-dim);
	line-height: 1.5;
}

.skn-landing .skn-dl {
	display: grid;
	gap: 0.75rem;
}

.skn-landing .skn-dl dt {
	font-weight: 600;
	color: var(--skn-text);
}

.skn-landing .skn-dl dd {
	margin: 0;
	color: var(--skn-text-muted);
}

.skn-landing .skn-messages {
	max-width: none;
	margin: 0;
	padding: 0;
	list-style: none;
}

.skn-app__messages-bar {
	padding-block: 0.625rem 0;
}

.skn-hero__disclaimer {
	margin: 1rem 0 0;
	max-width: 40rem;
	font-size: clamp(1rem, 2.2vw, 1.125rem);
	line-height: var(--skn-text-leading);
	color: var(--skn-text-muted);
}

/* ---- Illustrations & split sections ---- */
.skn-figure {
	margin: 0;
	overflow: hidden;
	border-radius: var(--skn-radius-lg);
	border: 1px solid var(--skn-border-strong);
	box-shadow: var(--skn-shadow-lg);
	background: var(--skn-surface);
}

.skn-figure__img {
	display: block;
	width: 100%;
	height: auto;
	object-fit: cover;
}

.skn-figure__caption {
	margin: 0;
	padding: 0.75rem 1rem;
	font-size: 0.8125rem;
	color: var(--skn-text-dim);
	text-align: center;
	background: rgb(0 0 0 / 35%);
	border-top: 1px solid var(--skn-border);
}

.skn-figure--wide {
	border-radius: var(--skn-radius-lg);
}

.skn-figure--rounded .skn-figure__img {
	aspect-ratio: 4 / 3;
}

.skn-figure--inset {
	box-shadow: var(--skn-glow);
}

.skn-hero__aside {
	display: flex;
	flex-direction: column;
	gap: 1.25rem;
}

.skn-hero__visual {
	margin-top: 1.5rem;
}

.skn-hero__aside .skn-hero__visual {
	margin-top: 0;
}

.skn-hero__aside .skn-hero__panel {
	margin-top: 0;
}

.skn-split {
	display: grid;
	gap: 2rem;
	align-items: center;
}

.skn-split__content .skn-section__title {
	text-align: left;
}

.skn-split__content .skn-section__intro {
	text-align: left;
	margin-inline: 0;
}

.skn-highlight-list {
	margin: 1.25rem 0 0;
	padding: 0;
	list-style: none;
}

.skn-highlight-list li {
	position: relative;
	padding-left: 1.5rem;
	margin-top: 0.625rem;
	font-size: 0.9375rem;
	color: var(--skn-text-muted);
}

.skn-highlight-list li::before {
	content: "";
	position: absolute;
	left: 0;
	top: 0.55em;
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background: linear-gradient(135deg, var(--skn-solar-gold), var(--skn-accent));
	box-shadow: 0 0 8px rgb(251 191 36 / 45%);
}

.skn-community {
	background: var(--skn-gradient-warm), var(--skn-gradient-section);
	border-block: 1px solid var(--skn-border-strong);
}

.skn-community__quote {
	margin: 1rem 0 0;
	padding: 1rem 1.25rem;
	border-left: 3px solid var(--skn-solar-gold);
	border-radius: 0 var(--skn-radius) var(--skn-radius) 0;
	font-size: 1.0625rem;
	font-style: italic;
	color: var(--skn-text);
	background: rgb(251 191 36 / 8%);
}

.skn-banner-urgent {
	padding: 1.25rem 1.5rem;
	border-radius: var(--skn-radius-lg);
	border: 1px solid rgb(251 191 36 / 45%);
	background: linear-gradient(135deg, rgb(251 191 36 / 18%) 0%, rgb(14 165 233 / 12%) 100%);
	box-shadow: var(--skn-glow);
}

.skn-banner-urgent__badge {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	margin-bottom: 0.5rem;
	padding: 0.25rem 0.75rem;
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--skn-solar-gold);
	background: rgb(0 0 0 / 30%);
	border-radius: var(--skn-radius-pill);
}

.skn-banner-urgent__title {
	margin: 0 0 0.5rem;
	font-family: var(--skn-font-display);
	font-size: 1.25rem;
	font-weight: 700;
	color: var(--skn-text);
}

.skn-banner-urgent__text {
	margin: 0;
	font-size: 0.9375rem;
	color: var(--skn-text-muted);
	line-height: 1.6;
}

.skn-banner-urgent__slots {
	display: inline-block;
	margin-top: 0.75rem;
	font-weight: 700;
	color: var(--skn-accent);
}

.skn-audience-card--community {
	border-color: rgb(251 191 36 / 35%);
	background: linear-gradient(155deg, rgb(251 191 36 / 10%) 0%, var(--skn-gradient-card) 55%);
}

.skn-audience-card__icon--community {
	background: rgb(251 191 36 / 14%);
	color: var(--skn-solar-gold);
	border-color: rgb(251 191 36 / 35%);
}

@media (min-width: 960px) {
	.skn-split {
		grid-template-columns: 1fr 1fr;
		gap: 2.5rem;
	}

	.skn-hero__layout--visual {
		grid-template-columns: 1fr 1fr;
	}

	.skn-hero__visual {
		margin-top: 0;
	}
}

@media (min-width: 640px) {
	.skn-split--reverse .skn-split__media {
		order: 2;
	}
}

.skn-hero--center .skn-figure,
.skn-hero--center .skn-banner-urgent {
	max-width: 40rem;
	margin-inline: auto;
}

.skn-hero--center .skn-figure {
	margin-top: 1.5rem;
}

.skn-hero--center .skn-banner-urgent {
	margin-top: 1.25rem;
	text-align: left;
}

/* ---- FAQ (SEO) ---- */
.skn-faq {
	background: var(--skn-surface-2);
	border-block: 1px solid var(--skn-border);
}

.skn-faq__list {
	display: grid;
	gap: 0.75rem;
	max-width: 48rem;
	margin-inline: auto;
}

.skn-faq__item {
	border: 1px solid var(--skn-border);
	border-radius: var(--skn-radius);
	background: var(--skn-gradient-card);
	overflow: hidden;
}

.skn-faq__question {
	padding: 1rem 1.25rem;
	font-family: var(--skn-font-display);
	font-size: 1rem;
	font-weight: 600;
	color: var(--skn-text);
	cursor: pointer;
	list-style: none;
}

.skn-faq__question::-webkit-details-marker {
	display: none;
}

.skn-faq__question::after {
	content: "+";
	float: right;
	color: var(--skn-accent);
	font-weight: 700;
}

.skn-faq__item[open] .skn-faq__question::after {
	content: "−";
}

.skn-faq__answer {
	padding: 0 1.25rem 1rem;
	font-size: 0.9375rem;
	color: var(--skn-text-muted);
	line-height: 1.65;
}

.skn-faq__answer p {
	margin: 0;
}

.skn-hero__tagline {
	margin: 0 0 0.75rem;
	font-family: var(--skn-font-display);
	font-size: clamp(1.125rem, 2.5vw, 1.375rem);
	font-weight: 700;
	color: var(--skn-solar-gold, var(--skn-accent));
}
