/* ================================================================
   Website Services — /website-services/
   Page-specific CSS. Uses lib.css variables.
   ================================================================ */

/* ── Hero ── */
.ws-hero {
	background: var(--wp--preset--gradient--hero);
	padding: 80px 24px 72px;
	position: relative;
	overflow: hidden;
}
.ws-hero-bg {
	position: absolute;
	inset: 0;
	background: url('/wp-content/uploads/website-hero-options-e1760913692760.webp') right center/contain no-repeat;
	opacity: 0.25;
}
.ws-hero-circle {
	position: absolute;
	top: -200px;
	right: -150px;
	width: 500px;
	height: 500px;
	border-radius: 50%;
	background: rgba(78,165,156,0.08);
	z-index: 1;
}
.ws-hero-inner {
	max-width: 1100px;
	margin: 0 auto;
	position: relative;
	z-index: 2;
}
.ws-hero-content {
	max-width: 680px;
}
.ws-hero-eyebrow {
	font-family: var(--wp--preset--font-family--body) !important;
	font-size: 11px !important;
	font-weight: 700 !important;
	letter-spacing: 0.14em !important;
	text-transform: uppercase !important;
	color: var(--wp--preset--color--salmon) !important;
	margin-bottom: 16px !important;
}
.ws-hero h1,
.ws-hero .wp-block-heading {
	font-family: var(--wp--preset--font-family--display) !important;
	font-size: clamp(2rem, 4vw, 3rem) !important;
	font-weight: 400 !important;
	color: #fff !important;
	letter-spacing: -0.02em !important;
	line-height: 1.1 !important;
	margin-bottom: 20px !important;
}
.ws-hero h1 em,
.ws-hero .wp-block-heading em {
	font-style: italic;
	color: var(--wp--preset--color--salmon) !important;
}
.ws-hero-lead {
	font-size: 17px !important;
	color: rgba(255,255,255,0.80) !important;
	line-height: 1.7 !important;
	max-width: 580px;
	margin-bottom: 24px !important;
}
.ws-hero-meta {
	display: flex;
	gap: 24px;
	flex-wrap: wrap;
	margin-bottom: 32px !important;
	font-size: 13px !important;
	color: rgba(255,255,255,0.6) !important;
}
.ws-hero-meta svg {
	flex-shrink: 0;
	opacity: 0.6;
}
.ws-hero .wp-block-buttons {
	gap: 12px;
}
.ws-hero .wp-block-button__link {
	font-family: var(--wp--preset--font-family--body) !important;
}
.ws-hero .ws-btn-primary .wp-block-button__link {
	background: var(--wp--preset--color--teal) !important;
	color: #fff !important;
	font-size: 16px !important;
	font-weight: 600 !important;
	padding: 14px 36px !important;
	border-radius: 100px !important;
	box-shadow: var(--shadow-teal) !important;
	transition: all 0.2s cubic-bezier(0.34,1.56,0.64,1) !important;
}
.ws-hero .ws-btn-primary .wp-block-button__link:hover {
	background: var(--wp--preset--color--teal-dark) !important;
	transform: translateY(-2px);
}
.ws-hero .ws-btn-ghost .wp-block-button__link {
	background: transparent !important;
	color: rgba(255,255,255,0.8) !important;
	font-size: 14px !important;
	font-weight: 600 !important;
	padding: 10px 24px !important;
	border-radius: 100px !important;
	border: 1.5px solid rgba(255,255,255,0.3) !important;
	transition: all 0.2s !important;
}
.ws-hero .ws-btn-ghost .wp-block-button__link:hover {
	background: rgba(255,255,255,0.1) !important;
}

/* ── Social proof strip ── */
.ws-social-proof {
	background: #ffffff;
	border-bottom: 1px solid var(--border);
	padding: 20px 24px;
}
.ws-social-proof-inner {
	max-width: 1100px;
	margin: 0 auto;
	display: flex;
	justify-content: center;
	gap: 48px;
	flex-wrap: wrap;
}
.ws-social-proof-inner p {
	font-size: 14px !important;
	color: var(--wp--preset--color--mid-grey) !important;
	margin: 0 !important;
}
.ws-social-proof-inner strong {
	font-size: 20px;
	font-weight: 600;
	color: var(--wp--preset--color--teal-dark);
}

/* ── Orientation / Problem section ── */
.ws-orientation {
	background: #ffffff;
	padding: 72px 24px;
}
.ws-orientation-inner {
	max-width: 900px;
	margin: 0 auto;
}
.ws-orientation-grid.wp-block-columns {
	display: grid !important;
	grid-template-columns: 1fr 1fr;
	gap: 48px;
	align-items: start;
}
.ws-orientation-grid.wp-block-columns > .wp-block-column {
	flex-basis: unset !important;
	min-width: unset !important;
	max-width: none !important;
}
.ws-orientation .ws-eyebrow-teal {
	font-family: var(--wp--preset--font-family--body) !important;
	font-size: 11px !important;
	font-weight: 700 !important;
	letter-spacing: 0.14em !important;
	text-transform: uppercase !important;
	color: var(--wp--preset--color--teal) !important;
	margin-bottom: 12px !important;
}
.ws-orientation h2,
.ws-orientation .wp-block-heading {
	font-family: var(--wp--preset--font-family--display) !important;
	font-size: clamp(1.4rem, 2.5vw, 1.8rem) !important;
	font-weight: 400 !important;
	color: var(--wp--preset--color--primary) !important;
	letter-spacing: -0.02em !important;
	line-height: 1.2 !important;
	margin-bottom: 16px !important;
}
.ws-orientation h2 em,
.ws-orientation .wp-block-heading em {
	font-style: italic;
	color: var(--wp--preset--color--teal) !important;
}
.ws-orientation p {
	font-size: 15px !important;
	color: var(--wp--preset--color--mid-grey) !important;
	line-height: 1.7 !important;
	margin-bottom: 14px !important;
}
.ws-orientation-highlight {
	background: var(--wp--preset--color--teal-light);
	border-left: 3px solid var(--wp--preset--color--teal);
	padding: 20px 24px;
	border-radius: 0 10px 10px 0;
	margin-top: 8px;
}
.ws-orientation-highlight p {
	font-size: 14px !important;
	color: var(--wp--preset--color--teal-dark) !important;
	font-weight: 500 !important;
	margin-bottom: 0 !important;
}
.ws-orientation-note {
	margin-top: 20px !important;
	font-size: 14px !important;
	color: var(--wp--preset--color--mid-grey) !important;
}

/* ── Three models ── */
.ws-models {
	background: var(--wp--preset--color--off-white);
	padding: 80px 24px;
}
.ws-models-header {
	text-align: center;
	margin-bottom: 48px;
}
.ws-models-header .ws-eyebrow-teal {
	font-family: var(--wp--preset--font-family--body) !important;
	font-size: 11px !important;
	font-weight: 700 !important;
	letter-spacing: 0.14em !important;
	text-transform: uppercase !important;
	color: var(--wp--preset--color--teal) !important;
	margin-bottom: 12px !important;
}
.ws-models-header h2,
.ws-models-header .wp-block-heading {
	font-family: var(--wp--preset--font-family--display) !important;
	font-size: clamp(1.5rem, 3vw, 2.2rem) !important;
	font-weight: 400 !important;
	color: var(--wp--preset--color--primary) !important;
	letter-spacing: -0.02em !important;
	line-height: 1.15 !important;
	margin-bottom: 12px !important;
}
.ws-models-header h2 em,
.ws-models-header .wp-block-heading em {
	font-style: italic;
	color: var(--wp--preset--color--teal) !important;
}
.ws-models-header .ws-section-lead {
	color: var(--wp--preset--color--mid-grey) !important;
	font-size: 15px !important;
	line-height: 1.7 !important;
	max-width: 640px;
	margin: 0 auto !important;
}

/* ── Model cards — uses wp:html for complex structure ── */
.ws-models-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 24px;
	max-width: 1100px;
	margin: 0 auto;
}
.ws-model-card {
	background: #ffffff;
	border: 1.5px solid var(--border);
	border-radius: 16px;
	overflow: hidden;
	display: flex;
	flex-direction: column;
	transition: box-shadow 0.2s, transform 0.2s;
}
.ws-model-card:hover {
	box-shadow: 0 4px 20px rgba(10,30,63,0.08), 0 1px 4px rgba(10,30,63,0.04);
	transform: translateY(-2px);
}
.ws-model-card.ws-model-featured {
	border-color: var(--wp--preset--color--teal);
	border-width: 2px;
}
.ws-model-card-header {
	padding: 28px 24px 0;
}
.ws-model-card-icon {
	width: 48px;
	height: 48px;
	border-radius: 12px;
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 16px;
}
.ws-icon-teal { background: rgba(78,165,156,0.10); }
.ws-icon-salmon { background: rgba(249,130,119,0.10); }
.ws-icon-navy { background: rgba(10,30,63,0.08); }
.ws-model-card-badge {
	font-size: 10px;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	padding: 4px 12px;
	border-radius: 100px;
	display: inline-block;
	margin-bottom: 12px;
}
.ws-badge-teal { background: rgba(78,165,156,0.10); color: var(--wp--preset--color--teal-dark); }
.ws-badge-salmon { background: rgba(249,130,119,0.10); color: var(--wp--preset--color--salmon-dark); }
.ws-badge-navy { background: rgba(10,30,63,0.08); color: var(--wp--preset--color--deep-navy); }
.ws-model-card h3 {
	font-family: var(--wp--preset--font-family--display);
	font-size: 1.3rem;
	font-weight: 400;
	color: var(--wp--preset--color--primary);
	margin-bottom: 8px;
	letter-spacing: -0.02em;
}
.ws-model-card-sub {
	font-size: 13px;
	color: #6B7280;
	margin-bottom: 16px;
}
.ws-model-card-body {
	padding: 0 24px 24px;
	flex: 1;
	display: flex;
	flex-direction: column;
}
.ws-model-card-body > p {
	font-size: 14px;
	color: var(--wp--preset--color--mid-grey);
	line-height: 1.7;
	margin-bottom: 16px;
}
.ws-model-card-list {
	list-style: none;
	padding: 0;
	margin: 0 0 20px;
}
.ws-model-card-list li {
	font-size: 13px;
	color: var(--wp--preset--color--mid-grey);
	padding: 6px 0;
	display: flex;
	align-items: flex-start;
	gap: 8px;
}
.ws-model-card-list li::before {
	content: '';
	display: inline-block;
	width: 16px;
	height: 16px;
	background: var(--wp--preset--color--teal);
	border-radius: 50%;
	flex-shrink: 0;
	margin-top: 2px;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: center;
	background-size: 9px;
}
.ws-model-card-price {
	font-family: var(--wp--preset--font-family--display);
	font-size: 1.5rem;
	font-weight: 400;
	color: var(--wp--preset--color--primary);
	margin-bottom: 4px;
	margin-top: auto;
}
.ws-model-card-price-unit {
	font-size: 13px;
	color: #6B7280;
	margin-bottom: 16px;
}
.ws-model-card-pairs {
	font-size: 12px;
	color: var(--wp--preset--color--teal-dark);
	background: var(--wp--preset--color--teal-light);
	padding: 10px 14px;
	border-radius: 8px;
	margin-bottom: 16px;
	line-height: 1.5;
}
.ws-model-card-cta {
	display: block;
	text-align: center;
	background: var(--wp--preset--color--deep-navy);
	color: #fff;
	font-family: var(--wp--preset--font-family--body);
	font-size: 14px;
	font-weight: 600;
	padding: 12px;
	border-radius: 100px;
	text-decoration: none;
	transition: all 0.2s;
	margin-top: 12px;
}
.ws-model-card-cta:hover {
	background: #0d2a52;
	color: #fff;
}

/* ── Models footer note ── */
.ws-models-note {
	text-align: center;
	font-size: 14px !important;
	color: #6B7280 !important;
	margin-top: 24px !important;
	max-width: 600px;
	margin-left: auto !important;
	margin-right: auto !important;
}

/* ── Quick fix callout ── */
.ws-quickfix {
	max-width: 1100px;
	margin: 32px auto 0;
	text-align: center;
}
.ws-quickfix-inner {
	background: #ffffff;
	border: 1px solid var(--border);
	border-radius: 16px;
	padding: 20px 28px;
	display: inline-flex;
	align-items: center;
	gap: 16px;
	flex-wrap: wrap;
	justify-content: center;
}
.ws-quickfix-inner p {
	font-size: 14px !important;
	color: var(--wp--preset--color--mid-grey) !important;
	margin: 0 !important;
}
.ws-quickfix-inner strong {
	color: var(--wp--preset--color--primary);
}
.ws-quickfix-inner a.ws-btn-ghost-sm {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	background: transparent;
	color: var(--wp--preset--color--teal);
	font-family: var(--wp--preset--font-family--body);
	font-size: 13px;
	font-weight: 600;
	padding: 8px 20px;
	border-radius: 100px;
	border: 1.5px solid var(--wp--preset--color--teal);
	text-decoration: none;
	transition: all 0.2s;
}
.ws-quickfix-inner a.ws-btn-ghost-sm:hover {
	background: var(--wp--preset--color--teal-light);
	color: var(--wp--preset--color--teal-dark);
}

/* ── Services grid ── */
.ws-services {
	background: #ffffff;
	padding: 80px 24px;
}
.ws-services-header {
	text-align: center;
	margin-bottom: 48px;
}
.ws-services-header .ws-eyebrow-teal,
.ws-hiw-header .ws-eyebrow-teal,
.ws-portfolio-header .ws-eyebrow-teal {
	font-family: var(--wp--preset--font-family--body) !important;
	font-size: 11px !important;
	font-weight: 700 !important;
	letter-spacing: 0.14em !important;
	text-transform: uppercase !important;
	color: var(--wp--preset--color--teal) !important;
	margin-bottom: 12px !important;
}
.ws-services-header h2,
.ws-services-header .wp-block-heading,
.ws-hiw-header h2,
.ws-hiw-header .wp-block-heading,
.ws-portfolio-header h2,
.ws-portfolio-header .wp-block-heading {
	font-family: var(--wp--preset--font-family--display) !important;
	font-size: clamp(1.5rem, 3vw, 2.2rem) !important;
	font-weight: 400 !important;
	color: var(--wp--preset--color--primary) !important;
	letter-spacing: -0.02em !important;
	line-height: 1.15 !important;
	margin-bottom: 12px !important;
}
.ws-services-header h2 em,
.ws-services-header .wp-block-heading em,
.ws-hiw-header h2 em,
.ws-hiw-header .wp-block-heading em,
.ws-portfolio-header h2 em,
.ws-portfolio-header .wp-block-heading em {
	font-style: italic;
	color: var(--wp--preset--color--teal) !important;
}
.ws-services-header .ws-section-lead,
.ws-portfolio-header .ws-section-lead {
	color: var(--wp--preset--color--mid-grey) !important;
	font-size: 15px !important;
	line-height: 1.7 !important;
	max-width: 640px;
	margin: 0 auto !important;
}

/* Service items — uses wp:html */
.ws-services-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 20px;
	max-width: 1100px;
	margin: 0 auto;
}
.ws-service-item {
	background: var(--wp--preset--color--off-white);
	border: 1px solid var(--border);
	border-radius: 16px;
	padding: 24px;
	transition: box-shadow 0.2s;
}
.ws-service-item:hover {
	box-shadow: 0 1px 4px rgba(10,30,63,0.06), 0 1px 2px rgba(10,30,63,0.04);
}
.ws-service-icon {
	width: 44px;
	height: 44px;
	border-radius: 10px;
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 14px;
}
.ws-service-item h4 {
	font-family: var(--wp--preset--font-family--body);
	font-size: 15px;
	font-weight: 600;
	color: var(--wp--preset--color--primary);
	margin-bottom: 6px;
}
.ws-service-item p {
	font-size: 13px;
	color: var(--wp--preset--color--mid-grey);
	line-height: 1.6;
	margin: 0;
}

/* ── How it works ── */
.ws-hiw {
	background: var(--wp--preset--color--off-white);
	padding: 80px 24px;
}
.ws-hiw-header {
	text-align: center;
	margin-bottom: 48px;
}
.ws-steps {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 32px;
	max-width: 900px;
	margin: 0 auto;
	position: relative;
}
.ws-steps::before {
	content: '';
	position: absolute;
	top: 24px;
	left: calc(16.7% + 24px);
	right: calc(16.7% + 24px);
	height: 2px;
	background: var(--border);
	z-index: 0;
}
.ws-step {
	text-align: center;
	position: relative;
	z-index: 1;
}
.ws-step-number {
	width: 48px;
	height: 48px;
	border-radius: 50%;
	background: var(--wp--preset--color--teal);
	color: #fff;
	font-family: var(--wp--preset--font-family--display);
	font-size: 1.2rem;
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 auto 16px;
}
.ws-step h4 {
	font-family: var(--wp--preset--font-family--body);
	font-size: 15px;
	font-weight: 600;
	color: var(--wp--preset--color--primary);
	margin-bottom: 8px;
}
.ws-step p {
	font-size: 13px;
	color: var(--wp--preset--color--mid-grey);
	line-height: 1.6;
	max-width: 240px;
	margin: 0 auto;
}

/* ── Portfolio ── */
.ws-portfolio {
	background: var(--wp--preset--color--off-white);
	padding: 80px 24px;
}
.ws-portfolio-header {
	text-align: center;
	margin-bottom: 48px;
}
.ws-portfolio-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 20px;
	max-width: 1100px;
	margin: 0 auto;
}
.ws-portfolio-card {
	background: #ffffff;
	border: 1px solid var(--border);
	border-radius: 16px;
	overflow: hidden;
	transition: box-shadow 0.2s, transform 0.2s;
}
.ws-portfolio-card:hover {
	box-shadow: 0 4px 20px rgba(10,30,63,0.08), 0 1px 4px rgba(10,30,63,0.04);
	transform: translateY(-2px);
}
.ws-portfolio-card-img {
	height: 200px;
	overflow: hidden;
}
.ws-portfolio-card-img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: top;
}
.ws-portfolio-card-body {
	padding: 20px;
}
.ws-portfolio-label {
	font-size: 10px;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--wp--preset--color--teal-dark);
	background: rgba(78,165,156,0.10);
	padding: 3px 10px;
	border-radius: 100px;
	display: inline-block;
	margin-bottom: 8px;
}
.ws-portfolio-card-body h4 {
	font-family: var(--wp--preset--font-family--body);
	font-size: 15px;
	font-weight: 600;
	color: var(--wp--preset--color--primary);
	margin-bottom: 4px;
}
.ws-portfolio-card-body p {
	font-size: 13px;
	color: #6B7280;
	margin: 0;
}
.ws-portfolio-footer {
	text-align: center;
	margin-top: 32px;
}
.ws-portfolio-footer a.ws-btn-ghost {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	background: transparent;
	color: var(--wp--preset--color--teal);
	font-family: var(--wp--preset--font-family--body);
	font-size: 14px;
	font-weight: 600;
	padding: 10px 24px;
	border-radius: 100px;
	border: 1.5px solid var(--wp--preset--color--teal);
	text-decoration: none;
	transition: all 0.2s;
}
.ws-portfolio-footer a.ws-btn-ghost:hover {
	background: var(--wp--preset--color--teal-light);
	color: var(--wp--preset--color--teal-dark);
}

/* ── Testimonial ── */
.ws-testimonial {
	background: var(--wp--preset--color--deep-navy);
	padding: 80px 24px;
	position: relative;
	overflow: hidden;
}
.ws-testimonial-circle {
	position: absolute;
	top: -100px;
	left: -100px;
	width: 400px;
	height: 400px;
	border-radius: 50%;
	background: rgba(78,165,156,0.06);
}
.ws-testimonial-inner {
	max-width: 900px;
	margin: 0 auto;
	position: relative;
	z-index: 1;
}
.ws-testimonial-card {
	background: rgba(255,255,255,0.08);
	border: 1px solid rgba(255,255,255,0.12);
	border-radius: 16px;
	padding: 32px;
	display: grid;
	grid-template-columns: auto 1fr;
	gap: 28px;
	align-items: start;
}
.ws-testimonial-card img {
	width: 120px;
	height: 120px;
	border-radius: 16px;
	object-fit: cover;
	border: 2px solid rgba(255,255,255,0.15);
}
.ws-testimonial-stars {
	color: var(--wp--preset--color--orange);
	font-size: 16px;
	letter-spacing: 2px;
	margin-bottom: 8px;
}
.ws-testimonial-card blockquote {
	font-size: 16px;
	color: rgba(255,255,255,0.9);
	line-height: 1.7;
	font-style: italic;
	margin: 0 0 16px;
	padding: 0;
	border: none;
}
.ws-testimonial-name {
	font-size: 14px;
	font-weight: 600;
	color: var(--wp--preset--color--teal-light);
}
.ws-testimonial-role {
	font-size: 13px;
	color: rgba(255,255,255,0.5);
}

/* ── Final CTA ── */
.ws-cta {
	background: #ffffff;
	padding: 64px 24px;
	text-align: center;
	border-top: 1px solid var(--border);
}
.ws-cta-inner {
	max-width: 640px;
	margin: 0 auto;
}
.ws-cta h2,
.ws-cta .wp-block-heading {
	font-family: var(--wp--preset--font-family--display) !important;
	font-size: clamp(1.5rem, 3vw, 2.2rem) !important;
	font-weight: 400 !important;
	color: var(--wp--preset--color--primary) !important;
	letter-spacing: -0.02em !important;
	line-height: 1.15 !important;
	margin-bottom: 12px !important;
}
.ws-cta h2 em,
.ws-cta .wp-block-heading em {
	font-style: italic;
	color: var(--wp--preset--color--teal) !important;
}
.ws-cta-text {
	font-size: 15px !important;
	color: var(--wp--preset--color--mid-grey) !important;
	line-height: 1.7 !important;
	margin-bottom: 28px !important;
}
.ws-cta .wp-block-buttons {
	justify-content: center;
	gap: 12px;
}
.ws-cta .ws-btn-salmon .wp-block-button__link {
	background: var(--wp--preset--color--salmon) !important;
	color: #fff !important;
	font-size: 16px !important;
	font-weight: 600 !important;
	padding: 14px 36px !important;
	border-radius: 100px !important;
	box-shadow: 0 6px 20px rgba(249,130,119,0.28) !important;
	transition: all 0.2s !important;
}
.ws-cta .ws-btn-salmon .wp-block-button__link:hover {
	background: var(--wp--preset--color--salmon-dark) !important;
	transform: translateY(-2px);
}
.ws-cta .ws-btn-ghost-cta .wp-block-button__link {
	background: transparent !important;
	color: var(--wp--preset--color--teal) !important;
	font-size: 14px !important;
	font-weight: 600 !important;
	padding: 10px 24px !important;
	border-radius: 100px !important;
	border: 1.5px solid var(--wp--preset--color--teal) !important;
	transition: all 0.2s !important;
}
.ws-cta .ws-btn-ghost-cta .wp-block-button__link:hover {
	background: var(--wp--preset--color--teal-light) !important;
	color: var(--wp--preset--color--teal-dark) !important;
}
.ws-cta-links {
	margin-top: 20px;
	display: flex;
	gap: 24px;
	justify-content: center;
	flex-wrap: wrap;
}
.ws-cta-links a {
	font-size: 13px;
	color: var(--wp--preset--color--teal);
	text-decoration: none;
}
.ws-cta-links a:hover {
	color: var(--wp--preset--color--teal-dark);
}

/* ── Responsive ── */
@media (max-width: 900px) {
	.ws-orientation-grid.wp-block-columns {
		grid-template-columns: 1fr !important;
	}
	.ws-models-grid {
		grid-template-columns: 1fr;
		max-width: 420px;
		margin: 0 auto;
	}
	.ws-services-grid {
		grid-template-columns: 1fr 1fr;
	}
	.ws-portfolio-grid {
		grid-template-columns: 1fr 1fr;
	}
	.ws-steps {
		grid-template-columns: 1fr;
		gap: 24px;
	}
	.ws-steps::before {
		display: none;
	}
	.ws-testimonial-card {
		grid-template-columns: 1fr;
		text-align: center;
	}
	.ws-testimonial-card img {
		margin: 0 auto;
	}
}
@media (max-width: 600px) {
	.ws-hero {
		padding: 56px 20px 48px;
	}
	.ws-hero h1,
	.ws-hero .wp-block-heading {
		font-size: clamp(1.6rem, 6vw, 2.2rem) !important;
	}
	.ws-hero-meta {
		gap: 12px;
	}
	.ws-services-grid {
		grid-template-columns: 1fr;
	}
	.ws-portfolio-grid {
		grid-template-columns: 1fr;
	}
	.ws-social-proof-inner {
		gap: 24px;
	}
}
