.site {
	min-height: 100vh;
	overflow-x: clip;
	background: var(--jai-color-bg);
	color: var(--jai-color-text);
}

.site-main {
	background: var(--jai-color-bg);
}

/* Containers */
.jai-container {
	width: min(calc(100% - 2rem), var(--jai-container));
	margin-inline: auto;
}

.jai-container--wide {
	width: min(calc(100% - 2rem), var(--jai-container-wide));
}

.jai-container--content {
	width: min(calc(100% - 2rem), var(--jai-container-content));
}

/* Sections */
.section {
	padding: var(--jai-space-3xl) 0;
	scroll-margin-top: 6rem;
}

.section--surface {
	background: var(--jai-color-surface);
}

.section--dark {
	background: var(--jai-gradient-dark);
	color: rgba(241, 245, 249, 0.78);
}

.section--dark h2,
.section--dark h3,
.section--dark h4,
.section--dark .section-eyebrow {
	color: #f8fafc;
}

.section-eyebrow {
	display: inline-block;
	margin-bottom: var(--jai-space-sm);
	color: var(--jai-color-brand-600);
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 0.18em;
	text-transform: uppercase;
}

html.dark .section-eyebrow {
	color: var(--jai-color-brand-400);
}

.section--dark .section-eyebrow {
	color: var(--jai-color-brand-300);
}

.section-heading {
	max-width: 780px;
	margin-bottom: var(--jai-space-2xl);
}

.section-heading p:last-child {
	color: var(--jai-color-muted);
	font-size: var(--jai-font-size-lg);
}

.section--dark .section-heading p:last-child {
	color: rgba(241, 245, 249, 0.72);
}

/* Page hero (interior pages) */
.page-hero {
	padding: calc(var(--jai-space-4xl) + 3rem) 0 var(--jai-space-3xl);
	background: var(--jai-gradient-dark);
	color: rgba(241, 245, 249, 0.82);
}

.page-hero--compact {
	padding-bottom: var(--jai-space-2xl);
}

.page-hero--center {
	min-height: 64vh;
	display: grid;
	place-items: center;
	text-align: center;
}

.page-hero h1,
.page-hero .section-eyebrow {
	color: #f8fafc;
}

.page-hero .section-eyebrow {
	color: var(--jai-color-brand-300);
}

.page-hero p,
.page-hero__description {
	max-width: 720px;
	color: rgba(241, 245, 249, 0.78);
	font-size: var(--jai-font-size-lg);
}

.page-hero--center p {
	margin-inline: auto;
}

/* Buttons */
.jai-button {
	position: relative;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	min-height: 2.9rem;
	padding: 0.75rem 1.25rem;
	border: 1px solid transparent;
	border-radius: var(--jai-radius-lg);
	background: var(--jai-color-brand-600);
	color: #ffffff;
	font-weight: 600;
	font-size: 0.95rem;
	line-height: 1.2;
	text-decoration: none;
	box-shadow: 0 8px 24px rgba(124, 58, 237, 0.25);
	transition: transform var(--jai-transition), background var(--jai-transition), border-color var(--jai-transition), box-shadow var(--jai-transition), color var(--jai-transition);
}

.jai-button:hover {
	background: var(--jai-color-brand-700);
	color: #ffffff;
	transform: translateY(-1px);
	box-shadow: var(--jai-shadow-glow-strong);
}

.jai-button__icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 1.1rem;
	height: 1.1rem;
}

.jai-button__icon svg,
.jai-button__icon img {
	width: 100%;
	height: 100%;
}

.jai-button--secondary {
	background: transparent;
	border-color: var(--jai-color-border-strong);
	color: var(--jai-color-text);
	box-shadow: none;
}

.jai-button--secondary:hover {
	background: transparent;
	border-color: var(--jai-color-brand-600);
	color: var(--jai-color-brand-600);
	box-shadow: none;
}

.jai-button--ghost {
	background: transparent;
	border-color: transparent;
	color: var(--jai-color-text);
	box-shadow: none;
}

.jai-button--ghost:hover {
	background: transparent;
	color: var(--jai-color-brand-600);
	box-shadow: none;
}

.jai-button--white {
	background: #ffffff;
	color: var(--jai-color-brand-700);
	border-color: transparent;
}

.jai-button--white:hover {
	background: var(--jai-color-brand-50);
	color: var(--jai-color-brand-800);
}

.jai-button--lg {
	min-height: 3.25rem;
	padding: 0.9rem 1.5rem;
	font-size: 1rem;
}

/* Grids */
.archive-grid,
.service-grid,
.work-grid {
	display: grid;
	gap: var(--jai-space-lg);
}

.archive-grid {
	grid-template-columns: repeat(auto-fit, minmax(min(100%, 18rem), 1fr));
}

/* Shared card surface */
.card-post,
.card-service,
.work-card,
.testimonial-card,
.empty-state {
	border: 1px solid var(--jai-color-border);
	border-radius: var(--jai-radius-xl);
	background: var(--jai-color-bg);
	box-shadow: var(--jai-shadow-soft);
	transition: border-color var(--jai-transition), transform var(--jai-transition), box-shadow var(--jai-transition);
}

html.dark .card-post,
html.dark .card-service,
html.dark .work-card,
html.dark .testimonial-card,
html.dark .empty-state {
	background: var(--jai-color-surface);
}

.card-post {
	overflow: hidden;
}

.card-post:hover,
.card-service:hover {
	border-color: var(--jai-color-brand-300);
	transform: translateY(-2px);
}

.card-post__media {
	display: block;
	aspect-ratio: 16 / 10;
	overflow: hidden;
	background: var(--jai-color-surface);
}

.card-post__image {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform var(--jai-transition-slow);
}

.card-post:hover .card-post__image {
	transform: scale(1.04);
}

.card-post__body {
	padding: var(--jai-space-lg);
}

.card-post__title {
	font-size: 1.25rem;
}

.card-post__title a {
	text-decoration: none;
}

.card-post__title a:hover {
	color: var(--jai-color-brand-600);
}

.card-post__excerpt,
.card-post__meta {
	color: var(--jai-color-muted);
}

.card-post__meta,
.single-header__meta {
	display: flex;
	flex-wrap: wrap;
	gap: var(--jai-space-xs);
	align-items: center;
	font-size: var(--jai-font-size-sm);
}

.entry-categories {
	display: flex;
	flex-wrap: wrap;
	gap: var(--jai-space-xs);
	margin-bottom: var(--jai-space-md);
}

.entry-category {
	display: inline-flex;
	padding: 0.28rem 0.65rem;
	border-radius: var(--jai-radius-full);
	background: var(--jai-color-brand-50);
	color: var(--jai-color-brand-700);
	font-size: 0.75rem;
	font-weight: 600;
	letter-spacing: 0.02em;
	text-decoration: none;
}

html.dark .entry-category {
	background: rgba(124, 58, 237, 0.18);
	color: var(--jai-color-brand-200);
}

.empty-state {
	max-width: 720px;
	margin-inline: auto;
	padding: var(--jai-space-2xl);
	text-align: center;
}

.pagination-wrap {
	margin-top: var(--jai-space-2xl);
}

.pagination .nav-links {
	display: flex;
	flex-wrap: wrap;
	gap: var(--jai-space-xs);
	justify-content: center;
}

.page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 2.6rem;
	min-height: 2.6rem;
	padding: 0.5rem 0.75rem;
	border: 1px solid var(--jai-color-border);
	border-radius: var(--jai-radius-md);
	background: var(--jai-color-bg);
	color: var(--jai-color-text);
	text-decoration: none;
	transition: background var(--jai-transition), color var(--jai-transition), border-color var(--jai-transition);
}

.page-numbers:hover {
	border-color: var(--jai-color-brand-400);
	color: var(--jai-color-brand-600);
}

.page-numbers.current {
	background: var(--jai-color-brand-600);
	border-color: var(--jai-color-brand-600);
	color: #ffffff;
}

.breadcrumbs {
	display: flex;
	flex-wrap: wrap;
	gap: var(--jai-space-xs);
	margin-bottom: var(--jai-space-lg);
	color: rgba(241, 245, 249, 0.74);
	font-size: var(--jai-font-size-sm);
}

.breadcrumbs a {
	color: #f8fafc;
	text-decoration: none;
}

.breadcrumbs a:hover {
	color: var(--jai-color-brand-300);
}

@media (min-width: 760px) {
	.service-grid,
	.work-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (min-width: 1024px) {
	.service-grid,
	.work-grid {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}

	.section {
		padding: var(--jai-space-4xl) 0;
	}
}
