:root {
	--color-bg: #faf5ee;
	--color-surface: #fffdf9;
	--color-surface-strong: #f4eadf;
	--color-sand: #e9dccf;
	--color-accent: #d97a5f;
	--color-accent-dark: #b45d45;
	--color-deep: #4e342e;
	--color-text: #2c2522;
	--color-muted: #6d625d;
	--color-border: rgba(78, 52, 46, 0.12);
	--shadow-soft: 0 18px 40px rgba(78, 52, 46, 0.1);
	--shadow-hover: 0 24px 50px rgba(78, 52, 46, 0.15);
	--radius-card: 24px;
	--radius-image: 32px;
	--radius-pill: 999px;
	--container-width: 1200px;
	--transition: 220ms ease;
}

*,
*::before,
*::after {
	box-sizing: border-box;
}

html {
	scroll-behavior: smooth;
}

body {
	margin: 0;
	font-family: "Inter", sans-serif;
	color: var(--color-text);
	background:
		radial-gradient(circle at top left, rgba(217, 122, 95, 0.12), transparent 28%),
		radial-gradient(circle at 85% 15%, rgba(185, 193, 178, 0.18), transparent 24%),
		linear-gradient(180deg, #fdf8f2 0%, var(--color-bg) 100%);
}

.custom-builder-main {
	min-height: 60vh;
}

.custom-builder-main .elementor-heading-title,
.custom-builder-main .elementor-widget-heading h1,
.custom-builder-main .elementor-widget-heading h2,
.custom-builder-main .elementor-widget-heading h3,
.custom-builder-main .elementor-widget-heading h4 {
	font-family: "Cormorant Garamond", serif;
	color: var(--color-deep);
	letter-spacing: -0.02em;
}

.custom-builder-main .elementor-widget-text-editor,
.custom-builder-main .elementor-widget-text-editor p,
.custom-builder-main .elementor-widget-text-editor li {
	color: var(--color-muted);
	font-size: 1.05rem;
	line-height: 1.8;
}

.custom-builder-main .elementor-widget-button .elementor-button {
	min-height: 54px;
	padding: 14px 24px;
	border-radius: var(--radius-pill);
	border: 1px solid transparent;
	background: var(--color-accent);
	color: #fffaf7;
	font-weight: 600;
	box-shadow: var(--shadow-soft);
	transition: transform var(--transition), background-color var(--transition), box-shadow var(--transition);
}

.custom-builder-main .elementor-widget-button .elementor-button:hover,
.custom-builder-main .elementor-widget-button .elementor-button:focus-visible {
	transform: translateY(-4px);
	background: var(--color-accent-dark);
	box-shadow: var(--shadow-hover);
}

.custom-builder-main .elementor-widget-image img {
	border-radius: var(--radius-image);
}

.custom-builder-main .elementor-element.elementor-widget:not(:last-child) {
	margin-bottom: 18px;
}

.ellis-peek-wireframe main h1,
.ellis-peek-wireframe main h2,
.ellis-peek-wireframe main h3,
.ellis-peek-wireframe main p,
.ellis-peek-wireframe main li,
.ellis-peek-wireframe main .eyebrow,
.ellis-peek-wireframe main .floating-label,
.ellis-peek-wireframe main .service-label,
.ellis-peek-wireframe main .step-number,
.ellis-peek-wireframe main .stars,
.ellis-peek-wireframe main .text-link,
.ellis-peek-wireframe main strong,
.ellis-peek-wireframe main label,
.ellis-peek-wireframe main input,
.ellis-peek-wireframe main textarea {
	color: transparent !important;
	text-shadow: none !important;
}

.ellis-peek-wireframe main .button,
.ellis-peek-wireframe main .nav-cta {
	color: #fffaf7 !important;
}

.ellis-peek-wireframe main .button-secondary {
	color: var(--color-deep) !important;
}

.ellis-peek-wireframe main img {
	opacity: 0;
}

.ellis-peek-wireframe main .image-card,
.ellis-peek-wireframe main .page-hero-visual,
.ellis-peek-wireframe main .hero-visual figure,
.ellis-peek-wireframe main .faux-form input,
.ellis-peek-wireframe main .faux-form textarea {
	background: linear-gradient(180deg, #efe2d6 0%, #e7d9cb 100%);
}

.ellis-peek-wireframe main .floating-card,
.ellis-peek-wireframe main .stat-panel,
.ellis-peek-wireframe main .challenge-card,
.ellis-peek-wireframe main .service-card,
.ellis-peek-wireframe main .usp-item,
.ellis-peek-wireframe main .testimonial-card,
.ellis-peek-wireframe main .process-card,
.ellis-peek-wireframe main .detail-card,
.ellis-peek-wireframe main .metric-card,
.ellis-peek-wireframe main .case-card,
.ellis-peek-wireframe main .service-detail-card,
.ellis-peek-wireframe main .contact-cta-card,
.ellis-peek-wireframe main .content-card {
	background: rgba(255, 253, 249, 0.92);
}

.ellis-peek-wireframe main .text-link::after {
	color: transparent;
}

img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

a {
	color: inherit;
	text-decoration: none;
}

button,
input,
textarea {
	font: inherit;
}

.shell {
	width: min(calc(100% - 40px), var(--container-width));
	margin: 0 auto;
}

.section {
	padding: 96px 0;
}

.eyebrow {
	margin: 0 0 14px;
	font-size: 0.82rem;
	font-weight: 600;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--color-accent-dark);
}

h1,
h2,
h3,
blockquote {
	margin: 0;
	font-family: "Cormorant Garamond", serif;
	font-weight: 600;
	letter-spacing: -0.02em;
	color: var(--color-deep);
}

h1 {
	font-size: clamp(3rem, 6vw, 4.75rem);
	line-height: 0.98;
}

h2 {
	font-size: clamp(2.4rem, 4.5vw, 3.55rem);
	line-height: 1.04;
}

h3 {
	font-size: clamp(1.6rem, 2vw, 2rem);
	line-height: 1.15;
}

p,
li {
	margin: 0;
	color: var(--color-muted);
	font-size: 1.05rem;
	line-height: 1.8;
}

.lead {
	font-size: 1.15rem;
	max-width: 38rem;
}

.button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 54px;
	padding: 0 24px;
	border-radius: var(--radius-pill);
	border: 1px solid transparent;
	font-weight: 600;
	transition: transform var(--transition), background-color var(--transition), color var(--transition), border-color var(--transition), box-shadow var(--transition);
	cursor: pointer;
}

.button:hover,
.button:focus-visible,
.service-card:hover,
.challenge-card:hover,
.testimonial-card:hover,
.process-card:hover,
.usp-item:hover,
.detail-card:hover,
.case-card:hover,
.metric-card:hover,
.service-detail-card:hover {
	transform: translateY(-4px);
	box-shadow: var(--shadow-hover);
}

.button-primary {
	background: var(--color-accent);
	color: #fffaf7;
	box-shadow: var(--shadow-soft);
}

.button-secondary {
	background: rgba(255, 253, 249, 0.85);
	border-color: var(--color-border);
	color: var(--color-deep);
}

.text-link {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	margin-top: 24px;
	color: var(--color-deep);
	font-weight: 600;
}

.text-link::after {
	content: "->";
}

.site-header {
	position: sticky;
	top: 0;
	z-index: 20;
	padding: 18px 0;
	background: rgba(250, 245, 238, 0.7);
	backdrop-filter: blur(16px);
	border-bottom: 1px solid transparent;
	transition: padding var(--transition), border-color var(--transition), background-color var(--transition);
}

.site-header.is-scrolled {
	padding: 12px 0;
	border-color: var(--color-border);
	background: rgba(250, 245, 238, 0.92);
}

.header-inner,
.footer-inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 24px;
}

.brand {
	display: inline-flex;
	align-items: center;
	gap: 14px;
}

.brand-mark {
	display: grid;
	place-items: center;
	width: 46px;
	height: 46px;
	border-radius: 50%;
	background: linear-gradient(135deg, var(--color-accent), #e59f7d);
	color: #fffaf7;
	font-family: "Cormorant Garamond", serif;
	font-size: 1.3rem;
	font-weight: 700;
}

.brand-text {
	display: grid;
	gap: 2px;
}

.brand-text strong {
	font-size: 1rem;
	color: var(--color-deep);
}

.brand-text span {
	font-size: 0.9rem;
	color: var(--color-muted);
}

.site-nav {
	display: flex;
	align-items: center;
	gap: 24px;
}

.menu-fallback {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 20px;
	list-style: none;
	margin: 0;
	padding: 0;
}

.menu-fallback a {
	position: relative;
	color: var(--color-deep);
	font-size: 0.98rem;
}

.menu-fallback a::after {
	content: "";
	position: absolute;
	left: 0;
	bottom: -6px;
	width: 100%;
	height: 1px;
	background: var(--color-accent);
	transform: scaleX(0);
	transform-origin: left;
	transition: transform var(--transition);
}

.menu-fallback a:hover::after,
.menu-fallback a:focus-visible::after {
	transform: scaleX(1);
}

.nav-toggle {
	display: none;
	padding: 0;
	border: 0;
	background: transparent;
}

.nav-toggle span {
	display: block;
	width: 28px;
	height: 2px;
	margin: 5px 0;
	border-radius: 999px;
	background: var(--color-deep);
}

.hero {
	padding-top: 54px;
}

.hero-grid,
.intro-grid,
.why-grid,
.page-hero-card,
.story-grid,
.contact-layout,
.contact-cta-card {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 48px;
	align-items: center;
}

.hero-copy,
.intro-content,
.why-content,
.page-hero-copy,
.story-copy {
	display: grid;
	gap: 20px;
}

.hero-actions,
.contact-meta,
.trust-tags,
.footer-links {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
}

.hero-note {
	color: var(--color-deep);
	font-size: 0.95rem;
}

.hero-visual,
.intro-side {
	position: relative;
}

.image-card,
.floating-card,
.stat-panel,
.contact-form,
.testimonial-card,
.service-card,
.challenge-card,
.process-card,
.usp-item,
.detail-card,
.case-card,
.metric-card,
.service-detail-card,
.content-card,
.contact-info-card,
.page-hero-card {
	background: rgba(255, 253, 249, 0.92);
	border: 1px solid var(--color-border);
	box-shadow: var(--shadow-soft);
}

.image-card {
	overflow: hidden;
}

.image-card-large {
	height: 680px;
	border-radius: 42px 42px 18px 42px;
}

.image-card-medium {
	height: 500px;
	border-radius: var(--radius-image);
}

.image-card-tall {
	height: 640px;
	border-radius: 18px 42px 42px 42px;
}

.floating-card {
	position: absolute;
	right: -16px;
	bottom: 32px;
	width: min(280px, calc(100% - 28px));
	padding: 24px;
	border-radius: 22px;
}

.floating-label,
.service-label,
.step-number {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 42px;
	height: 42px;
	padding: 0 12px;
	border-radius: var(--radius-pill);
	background: rgba(217, 122, 95, 0.14);
	color: var(--color-accent-dark);
	font-size: 0.9rem;
	font-weight: 700;
}

.stat-panel {
	display: grid;
	gap: 16px;
	margin-top: -72px;
	margin-left: 48px;
	padding: 28px;
	border-radius: 24px;
}

.stat-panel div,
.contact-info-item {
	display: grid;
	gap: 6px;
}

.section-heading {
	display: grid;
	gap: 18px;
	max-width: 760px;
	margin-bottom: 40px;
}

.split-heading {
	max-width: none;
	grid-template-columns: 1.25fr 0.9fr;
	align-items: end;
}

.challenge-grid {
	display: grid;
	grid-template-columns: repeat(5, minmax(0, 1fr));
	gap: 18px;
}

.services-grid,
.testimonial-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 24px;
}

.services-grid {
	grid-template-columns: repeat(2, minmax(0, 1fr));
}

.process-grid,
.detail-grid,
.metric-grid,
.service-detail-grid,
.case-grid,
.training-grid,
.blog-grid,
.cv-layout {
	display: grid;
	gap: 24px;
}

.process-grid {
	grid-template-columns: repeat(4, minmax(0, 1fr));
}

.detail-grid,
.metric-grid {
	grid-template-columns: repeat(3, minmax(0, 1fr));
}

.service-detail-grid,
.case-grid {
	grid-template-columns: repeat(2, minmax(0, 1fr));
}

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

.cv-layout {
	grid-template-columns: 1.15fr 0.85fr;
	align-items: start;
}

.challenge-card,
.service-card,
.testimonial-card,
.process-card,
.usp-item,
.detail-card,
.case-card,
.metric-card,
.service-detail-card,
.training-card,
.blog-card,
.contact-info-card,
.content-card,
.contact-form {
	padding: 28px;
	border-radius: var(--radius-card);
}

.challenge-card,
.service-card,
.testimonial-card,
.process-card,
.usp-item,
.detail-card,
.case-card,
.metric-card,
.service-detail-card,
.training-card,
.blog-card,
.contact-info-card,
.page-hero-copy,
.content-card {
	display: grid;
	gap: 16px;
}

.training-card,
.blog-card,
.cv-frame {
	background: rgba(255, 253, 249, 0.92);
	border: 1px solid var(--color-border);
	box-shadow: var(--shadow-soft);
}

.tag-list {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
}

.tag-list span {
	display: inline-flex;
	align-items: center;
	min-height: 36px;
	padding: 0 14px;
	border-radius: var(--radius-pill);
	background: rgba(217, 122, 95, 0.12);
	color: var(--color-accent-dark);
	font-size: 0.92rem;
	font-weight: 600;
}

.blog-card a {
	color: inherit;
}

.cv-frame {
	padding: 24px;
	border-radius: 32px;
}

.cv-image {
	width: 100%;
	height: auto;
	border-radius: 18px;
}

.trust-section {
	padding: 44px 0 96px;
}

.trust-grid {
	display: grid;
	grid-template-columns: 1.1fr 1fr;
	gap: 24px;
	padding: 34px;
	border: 1px solid var(--color-border);
	border-radius: 32px;
	background: rgba(244, 234, 223, 0.72);
}

.trust-tags span,
.contact-meta span {
	display: inline-flex;
	align-items: center;
	min-height: 40px;
	padding: 0 16px;
	border-radius: var(--radius-pill);
	background: rgba(255, 253, 249, 0.86);
	border: 1px solid var(--color-border);
	color: var(--color-deep);
	font-size: 0.95rem;
	font-weight: 500;
}

.stars {
	color: var(--color-accent);
	letter-spacing: 0.18em;
	font-size: 0.95rem;
}

.page-hero {
	padding: 72px 0 48px;
}

.page-hero-card {
	padding: 44px;
	border-radius: 36px;
}

.post-shell {
	max-width: 960px;
}

.contact-form label {
	display: grid;
	gap: 10px;
	color: var(--color-deep);
	font-size: 0.96rem;
	font-weight: 600;
}

.contact-form input,
.contact-form textarea {
	width: 100%;
	padding: 16px 18px;
	border: 1px solid rgba(78, 52, 46, 0.14);
	border-radius: 18px;
	background: #fffdfb;
	color: var(--color-text);
}

.faux-form input:disabled,
.faux-form textarea:disabled {
	opacity: 0.9;
	cursor: not-allowed;
}

.info-label,
.case-label {
	font-size: 0.82rem;
	font-weight: 700;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: var(--color-accent-dark);
}

.site-footer {
	padding: 28px 0 40px;
}

.footer-inner {
	padding-top: 28px;
	border-top: 1px solid var(--color-border);
	align-items: flex-start;
}

@media (max-width: 1100px) {
	.challenge-grid {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}

	.process-grid,
	.detail-grid,
	.metric-grid,
	.service-detail-grid,
	.case-grid,
	.training-grid,
	.blog-grid,
	.cv-layout {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.cv-layout {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 980px) {
	.site-nav {
		position: absolute;
		top: calc(100% + 12px);
		right: 20px;
		left: 20px;
		display: none;
		flex-direction: column;
		align-items: stretch;
		padding: 20px;
		border-radius: 24px;
		border: 1px solid var(--color-border);
		background: rgba(255, 253, 249, 0.98);
		box-shadow: var(--shadow-soft);
	}

	.site-nav.is-open {
		display: flex;
	}

	.nav-toggle {
		display: inline-block;
	}

	.hero-grid,
	.intro-grid,
	.why-grid,
	.page-hero-card,
	.story-grid,
	.contact-layout,
	.contact-cta-card,
	.split-heading,
	.trust-grid {
		grid-template-columns: 1fr;
	}

	.challenge-grid,
	.services-grid,
	.testimonial-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.image-card-large {
		height: 560px;
	}

	.stat-panel {
		margin: 24px 0 0;
	}
}

@media (max-width: 720px) {
	.section {
		padding: 72px 0;
	}

	.shell {
		width: min(calc(100% - 24px), var(--container-width));
	}

	.hero-actions,
	.contact-meta,
	.trust-tags,
	.footer-links {
		flex-direction: column;
		align-items: stretch;
	}

	.image-card-large,
	.image-card-medium,
	.image-card-tall {
		height: 420px;
	}

	.challenge-grid,
	.services-grid,
	.testimonial-grid,
	.process-grid,
	.detail-grid,
	.metric-grid,
	.service-detail-grid,
	.case-grid,
	.training-grid,
	.blog-grid,
	.cv-layout {
		grid-template-columns: 1fr;
	}

	.page-hero-card,
	.content-card,
	.contact-form,
	.contact-info-card,
	.detail-card,
	.case-card,
	.metric-card,
	.service-detail-card,
	.training-card,
	.blog-card,
	.cv-frame {
		padding: 24px;
	}

	.footer-inner {
		flex-direction: column;
	}
}
