/* Theme & Logo Customizations */

/* Default Base styling overrides for Page & Header */
body.page-strategy-planning {
	/* Default Purple Theme */
	--hero-bg: #351965;
	--hero-text: #ffffff;
	--hero-copy-p: rgba(255, 255, 255, 0.88);
	--brand-kicker: #f9981d;
	--brand-accent: #af4bac;
	--brand-bg-light: #f7f2f7;
	--brand-bg-alt: #f4f4f4;
	--text-dark: #28272d;
	--text-dark-muted: rgba(40, 39, 45, 0.64);
	--border-color: rgba(40, 39, 45, 0.12);
	--header-bg: #ffffff;
	--header-text: #28272d;
	--logo-letter-color: #000000;
	--logo-spinner-color: #f9981d;
	--card-bg: #ffffff;
}

/* Ocean & Slate Theme */
body.page-strategy-planning.theme-ocean-slate {
	--hero-bg: #0f172a;
	--hero-text: #ffffff;
	--hero-copy-p: rgba(241, 245, 249, 0.88);
	--brand-kicker: #38bdf8;
	--brand-accent: #0ea5e9;
	--brand-bg-light: #f8fafc;
	--brand-bg-alt: #e2e8f0;
	--text-dark: #1e293b;
	--text-dark-muted: rgba(30, 41, 59, 0.65);
	--border-color: rgba(30, 41, 59, 0.12);
	--header-bg: #1e293b;
	--header-text: #f1f5f9;
	--logo-letter-color: #06b6d4;
	--logo-spinner-color: #38bdf8;
	--card-bg: #ffffff;
}

/* Terracotta & Cream Theme */
body.page-strategy-planning.theme-terracotta {
	--hero-bg: #431407;
	--hero-text: #ffffff;
	--hero-copy-p: rgba(254, 243, 199, 0.88);
	--brand-kicker: #fdba74;
	--brand-accent: #ea580c;
	--brand-bg-light: #fffbeb;
	--brand-bg-alt: #fef3c7;
	--text-dark: #292524;
	--text-dark-muted: rgba(41, 37, 36, 0.65);
	--border-color: rgba(41, 37, 36, 0.12);
	--header-bg: #fdfbf7;
	--header-text: #292524;
	--logo-letter-color: #c2410c;
	--logo-spinner-color: #eab308;
	--card-bg: #ffffff;
}

/* Midnight & Gold Theme */
body.page-strategy-planning.theme-midnight {
	--hero-bg: #111111;
	--hero-text: #ffffff;
	--hero-copy-p: rgba(255, 255, 255, 0.88);
	--brand-kicker: #fbbf24;
	--brand-accent: #d97706;
	--brand-bg-light: #18181b;
	--brand-bg-alt: #27272a;
	--text-dark: #e4e4e7;
	--text-dark-muted: rgba(228, 228, 231, 0.65);
	--border-color: rgba(228, 228, 231, 0.12);
	--header-bg: #000000;
	--header-text: #ffffff;
	--logo-letter-color: #fbbf24;
	--logo-spinner-color: #fbbf24;
	--card-bg: #18181b;
}

/* Forest & Sage Theme */
body.page-strategy-planning.theme-forest-moss {
	--hero-bg: #14532d;
	--hero-text: #ffffff;
	--hero-copy-p: rgba(240, 253, 244, 0.88);
	--brand-kicker: #86efac;
	--brand-accent: #16a34a;
	--brand-bg-light: #f4f4f5;
	--brand-bg-alt: #e4e4e7;
	--text-dark: #1c1917;
	--text-dark-muted: rgba(28, 25, 23, 0.65);
	--border-color: rgba(28, 25, 23, 0.12);
	--header-bg: #fafaf9;
	--header-text: #1c1917;
	--logo-letter-color: #15803d;
	--logo-spinner-color: #86efac;
	--card-bg: #ffffff;
}

/* Base Theme overrides */
body.page-strategy-planning header#viv-main-header {
	background: var(--header-bg) !important;
	transition: background-color 0.4s ease;
}
body.page-strategy-planning header#viv-main-header #main-menu-w ul li a {
	color: var(--header-text) !important;
	transition: color 0.4s ease;
}
body.page-strategy-planning header#viv-main-header #logo-text {
	color: var(--header-text) !important;
	transition: color 0.4s ease;
}
body.page-strategy-planning header#viv-main-header #burger-menu span {
	background: var(--brand-accent) !important;
	transition: background-color 0.4s ease;
}

/* Logo specific customization styles */
body.page-strategy-planning #logo-w svg polygon:not(#e6le5vDntqN4),
body.page-strategy-planning #logo-w svg circle {
	fill: var(--logo-letter-color) !important;
	transition: fill 0.4s ease, stroke 0.4s ease;
}

/* Default colors rule to preserve original SVGator color loop if desired */
body.page-strategy-planning:not(.logo-default-colors) #logo-w svg #e6le5vDntqN4 {
	fill: var(--logo-spinner-color) !important;
}

/* Override strategy section background colors to support dark modes */
body.page-strategy-planning.theme-midnight .strategy-section,
body.page-strategy-planning.theme-midnight .strategy-testimonial,
body.page-strategy-planning.theme-midnight .strategy-principles,
body.page-strategy-planning.theme-midnight .case-study-more,
body.page-strategy-planning.theme-midnight .strategy-cta {
	background: #000000 !important;
	color: var(--text-dark) !important;
}
body.page-strategy-planning.theme-midnight .strategy-step,
body.page-strategy-planning.theme-midnight .strategy-more-intro,
body.page-strategy-planning.theme-midnight .strategy-service-group,
body.page-strategy-planning.theme-midnight .strategy-full-service-card,
body.page-strategy-planning.theme-midnight .strategy-process-card,
body.page-strategy-planning.theme-midnight .case-study-image-card,
body.page-strategy-planning.theme-midnight .case-study-gallery-grid img {
	background: var(--card-bg) !important;
}
body.page-strategy-planning.theme-midnight .strategy-next-solution {
	background: #18181b !important;
	border-color: #27272a !important;
	color: #ffffff !important;
}
body.page-strategy-planning.theme-midnight .strategy-next-solution span {
	color: #a1a1aa !important;
}
body.page-strategy-planning.theme-midnight .strategy-next-solution:hover {
	background: var(--brand-accent) !important;
}
body.page-strategy-planning.theme-midnight .strategy-testimonial .testim-con-in {
	color: #ffffff !important;
}
body.page-strategy-planning.theme-midnight .strategy-testimonial .testim-meta > span {
	color: #ffffff !important;
}

/* ==========================================================================
   LOGO ANIMATION & STYLE STYLES
   ========================================================================== */

/* 1. Pulse Animation */
@keyframes logoPulse {
	0%, 100% {
		transform: scale(1);
	}
	50% {
		transform: scale(1.08);
	}
}
body.page-strategy-planning.logo-anim-pulse #logo-w svg {
	transform-origin: center;
	animation: logoPulse 3s ease-in-out infinite;
}

/* 2. Neon Glow Animation */
@keyframes logoNeonGlow {
	0%, 100% {
		filter: drop-shadow(0 0 2px var(--brand-accent)) drop-shadow(0 0 4px var(--brand-accent));
	}
	50% {
		filter: drop-shadow(0 0 5px var(--brand-accent)) drop-shadow(0 0 12px var(--brand-accent));
	}
}
body.page-strategy-planning.logo-anim-neon #logo-w svg polygon:not(#e6le5vDntqN4),
body.page-strategy-planning.logo-anim-neon #logo-w svg circle {
	animation: logoNeonGlow 2s ease-in-out infinite;
}

/* 3. Outline Draw Animation */
@keyframes logoStrokeDraw {
	0% {
		stroke-dashoffset: 600;
		fill: transparent !important;
	}
	70% {
		stroke-dashoffset: 0;
		fill: transparent !important;
	}
	100% {
		stroke-dashoffset: 0;
		fill: var(--logo-letter-color) !important;
	}
}
body.page-strategy-planning.logo-anim-draw #logo-w svg polygon:not(#e6le5vDntqN4),
body.page-strategy-planning.logo-anim-draw #logo-w svg circle {
	stroke: var(--logo-letter-color) !important;
	stroke-width: 2px !important;
	stroke-dasharray: 600 !important;
	stroke-dashoffset: 600 !important;
	animation: logoStrokeDraw 4s ease-out forwards;
}

/* 4. Hover Tilt Wobble */
body.page-strategy-planning.logo-anim-wobble #logo-w {
	perspective: 600px;
}
body.page-strategy-planning.logo-anim-wobble #logo {
	transition: transform 0.5s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}
body.page-strategy-planning.logo-anim-wobble #logo:hover {
	transform: rotateY(15deg) rotateX(-10deg) scale(1.05);
	opacity: 1 !important;
}

/* 5. Custom Fast Spin override */
body.page-strategy-planning.logo-anim-spin-speed #logo-w svg #e6le5vDntqN4 {
	/* Standard spin animation is controlled by SVGator, but we can override or rotate it */
	animation: logoSpinFast 1.5s linear infinite;
	transform-origin: 153px 126px; /* center of polygon */
}
@keyframes logoSpinFast {
	from { transform: rotate(0deg); }
	to { transform: rotate(360deg); }
}

/* Solution landing pages */

.page-strategy-planning #new-title-area-w,
.page-resource-library #new-title-area-w,
.page-directory-filterable-maps #new-title-area-w,
.page-custom-calendar-tools #new-title-area-w,
.page-data-dashboard #new-title-area-w,
.page-submission-approval-portal #new-title-area-w,
.page-automated-translation-tools #new-title-area-w,
.page-taxonomy-tagging-tools #new-title-area-w,
.page-full-service-website-design-development #new-title-area-w,
.page-optimization-site-health #new-title-area-w,
.page-branding-design #new-title-area-w,
.page-hosting-web-maintenance #new-title-area-w,
.page-portfolio-concepts #new-title-area-w,
.page-northeastern-its-concept #new-title-area-w,
.page-climate-xchange-concept #new-title-area-w,
.page-barcc-walk-for-change-concept #new-title-area-w {
	display: none;
}

.page-hosting-web-maintenance-alt #new-title-area-w {
	display: none;
}

.page-strategy-planning #viv-content,
.page-resource-library #viv-content,
.page-directory-filterable-maps #viv-content,
.page-custom-calendar-tools #viv-content,
.page-data-dashboard #viv-content,
.page-submission-approval-portal #viv-content,
.page-automated-translation-tools #viv-content,
.page-taxonomy-tagging-tools #viv-content,
.page-full-service-website-design-development #viv-content,
.page-optimization-site-health #viv-content,
.page-branding-design #viv-content,
.page-hosting-web-maintenance #viv-content,
.page-portfolio-concepts #viv-content,
.page-northeastern-its-concept #viv-content,
.page-climate-xchange-concept #viv-content,
.page-barcc-walk-for-change-concept #viv-content {
	padding-top: 0;
}

.page-hosting-web-maintenance-alt #viv-content {
	padding-top: 0;
}

.strategy-landing {
	color: var(--text-dark, #28272d);
	font-size: 18px;
	line-height: 1.65;
}

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

.strategy-landing a {
	color: inherit;
}

.strategy-next-solution {
	align-items: center;
	background: #fff;
	border: 1px solid var(--border-color, rgba(40, 39, 45, 0.12));
	box-shadow: 0 16px 32px rgba(40, 39, 45, 0.18), 0 4px 10px rgba(40, 39, 45, 0.1);
	color: var(--text-dark, #28272d) !important;
	display: grid;
	gap: 2px;
	min-width: 190px;
	padding: 15px 48px 14px 18px;
	position: fixed;
	right: 24px;
	text-decoration: none;
	top: calc(100vh - 118px);
	transition: background-color 0.2s ease, color 0.2s ease, transform 0.2s ease;
	z-index: 50;
}

.strategy-next-solution::after {
	color: var(--brand-accent, #af4bac);
	content: '\2192';
	font-size: 28px;
	line-height: 1;
	position: absolute;
	right: 18px;
	top: 50%;
	transform: translateY(-50%);
}

.strategy-next-solution span {
	color: var(--text-dark-muted, rgba(40, 39, 45, 0.64));
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.14em;
	line-height: 1.2;
	text-transform: uppercase;
}

.strategy-next-solution strong {
	font-size: 18px;
	font-weight: 700;
	line-height: 1.15;
}

.strategy-next-solution:hover,
.strategy-next-solution:focus {
	background: var(--hero-bg, #351965);
	color: #fff !important;
	text-decoration: none;
	transform: translateY(-2px);
}

.strategy-next-solution:hover span,
.strategy-next-solution:focus span,
.strategy-next-solution:hover::after,
.strategy-next-solution:focus::after {
	color: rgba(255, 255, 255, 0.78);
}

.strategy-hero,
.strategy-section,
.strategy-band,
.strategy-proof,
.strategy-testimonial,
.strategy-more-solutions,
.strategy-full-service-link,
.strategy-process-deep,
.strategy-principles,
.strategy-logo-proof,
.strategy-portfolio-links,
.case-study-gallery,
.case-study-more,
.strategy-cta {
	padding-left: max(24px, calc((100vw - 1180px) / 2));
	padding-right: max(24px, calc((100vw - 1180px) / 2));
}

.strategy-hero {
	background: var(--hero-bg, #351965);
	color: #fff;
	display: grid;
	gap: 44px;
	grid-template-columns: minmax(0, 1.08fr) minmax(280px, 0.92fr);
	min-height: 560px;
	padding-bottom: 86px;
	padding-top: 112px;
	position: relative;
}

.strategy-eyebrow,
.strategy-kicker {
	color: var(--brand-kicker, #f9981d);
	font-size: 14px;
	font-weight: 700;
	letter-spacing: 0.14em;
	margin: 0 0 18px;
	text-transform: uppercase;
}

.strategy-section .strategy-kicker,
.strategy-band .strategy-kicker,
.strategy-testimonial .strategy-kicker,
.strategy-more-intro .strategy-kicker,
.strategy-cta .strategy-kicker {
	color: var(--hero-bg, #351965);
}

#viv-cont-w .strategy-landing .strategy-hero h1 {
	color: inherit;
	font-size: clamp(32px, 4vw, 54px);
	font-weight: 500;
	line-height: 1.05;
	margin: 0;
	max-width: 820px;
}

.strategy-hero-title {
	grid-template-columns: minmax(0, 0.72fr) minmax(260px, 0.28fr);
	min-height: 520px;
}

#viv-cont-w .strategy-landing .strategy-hero-title h1 {
	font-size: clamp(38px, 5.4vw, 72px);
	line-height: 1;
	max-width: 980px;
}

.strategy-hero-title .strategy-hero-copy {
	align-self: center;
	border-left: 4px solid var(--brand-kicker, #f9981d);
	padding-left: 28px;
}

.strategy-hero-title .strategy-hero-copy p {
	font-size: 24px;
}

.strategy-hero-note {
	color: rgba(255, 255, 255, 0.72);
	display: block;
	font-size: 15px;
	font-weight: 700;
	letter-spacing: 0.12em;
	margin-top: 28px;
	text-transform: uppercase;
}

.strategy-hero-copy {
	align-self: end;
	max-width: 500px;
}

.strategy-hero-copy p {
	color: rgba(255, 255, 255, 0.88);
	font-size: 23px;
	line-height: 1.45;
	margin: 0 0 28px;
}

.strategy-button {
	background: var(--brand-accent, #af4bac);
	border: 2px solid var(--brand-accent, #af4bac);
	border-radius: 999px;
	color: #fff !important;
	display: inline-block;
	font-size: 15px;
	font-weight: 700;
	letter-spacing: 0.08em;
	padding: 15px 24px 13px;
	text-decoration: none;
	text-transform: uppercase;
	transition: background-color 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}

.strategy-button:hover {
	background: #fff;
	border-color: #fff;
	color: var(--hero-bg, #351965) !important;
	text-decoration: none;
}

.strategy-button-dark {
	background: var(--hero-bg, #351965);
	border-color: var(--hero-bg, #351965);
}

.strategy-button-dark:hover {
	background: var(--brand-accent, #af4bac);
	border-color: var(--brand-accent, #af4bac);
	color: #fff !important;
}

.strategy-section {
	background: #fff;
	padding-bottom: 86px;
	padding-top: 86px;
}

.strategy-split {
	display: grid;
	gap: 54px;
	grid-template-columns: minmax(230px, 0.38fr) minmax(0, 0.62fr);
}

.strategy-section h2,
.strategy-band h2,
.strategy-cta h2 {
	color: var(--text-dark, #28272d);
	font-size: clamp(34px, 4vw, 58px);
	font-weight: 500;
	line-height: 1.04;
	margin: 0;
}

.strategy-section p,
.strategy-band p,
.strategy-cta p {
	margin: 0 0 20px;
}

.strategy-lede {
	font-size: 24px;
	line-height: 1.45;
}

.strategy-services {
	display: grid;
	gap: 22px;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	margin-top: 44px;
}

.strategy-card {
	background: var(--brand-bg-light, #f7f2f7);
	border-top: 5px solid var(--brand-accent, #af4bac);
	min-height: 260px;
	padding: 30px;
}

.strategy-card h3 {
	color: var(--text-dark, #28272d);
	font-size: 26px;
	font-weight: 600;
	line-height: 1.18;
	margin: 0 0 14px;
}

.strategy-card p {
	margin-bottom: 0;
}

.strategy-band {
	background: var(--brand-bg-alt, #f4f4f4);
	padding-bottom: 86px;
	padding-top: 86px;
}

.strategy-band .strategy-split {
	grid-template-columns: minmax(320px, 0.52fr) minmax(0, 0.48fr);
}

.strategy-band h2 {
	font-size: clamp(32px, 3.5vw, 50px);
	max-width: 720px;
}

.strategy-steps {
	display: grid;
	gap: 0;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	margin-top: 46px;
}

.strategy-step {
	background: #fff;
	border-left: 1px solid rgba(0, 0, 0, 0.08);
	padding: 30px;
}

.strategy-step:first-child {
	border-left: 0;
}

.strategy-step span {
	color: var(--brand-accent, #af4bac);
	display: block;
	font-size: 14px;
	font-weight: 700;
	letter-spacing: 0.14em;
	margin-bottom: 18px;
	text-transform: uppercase;
}

.strategy-step h3 {
	color: var(--text-dark, #28272d);
	font-size: 24px;
	line-height: 1.18;
	margin: 0 0 12px;
}

.strategy-step p {
	margin-bottom: 0;
}

.strategy-proof {
	background: var(--hero-bg, #351965);
	color: #fff;
	display: grid;
	gap: 40px;
	grid-template-columns: minmax(0, 0.7fr) minmax(260px, 0.3fr);
	padding-bottom: 70px;
	padding-top: 70px;
}

.strategy-proof h2,
.strategy-proof p {
	color: inherit;
}

.strategy-proof-stat {
	align-self: center;
	border-left: 4px solid var(--brand-kicker, #f9981d);
	font-size: 22px;
	font-weight: 600;
	line-height: 1.35;
	padding-left: 24px;
}

.strategy-testimonial {
	background: #fff;
	padding-bottom: 86px;
	padding-top: 86px;
}

.strategy-testimonial .testimonial-card {
	margin: 0 auto;
	max-width: 1080px;
	padding: 0 60px;
	position: relative;
	text-align: center;
}

.strategy-testimonial .testimonial-card::before {
	background: url("../images/quote-icon.png") no-repeat center top;
	background-size: 100%;
	content: "";
	display: block;
	height: 128px;
	margin: 0 auto 38px;
	max-width: 186px;
	width: 100%;
}

.strategy-testimonial .testim-content {
	margin: 0 auto;
	max-width: 960px;
}

#viv-cont-w .strategy-testimonial .testim-con-in {
	color: #161718;
	font-family: 'Publico-Italic';
	font-size: clamp(24px, 3vw, 34px);
	font-style: italic;
	font-weight: 500;
	line-height: 1.48;
	margin-bottom: 32px;
}

#viv-cont-w .strategy-testimonial .testim-con-in p {
	margin: 0;
}

.strategy-testimonial .testim-con-in strong {
	color: var(--hero-bg, #351965);
	font-weight: 800;
}

.strategy-testimonial .testim-img {
	align-items: center;
	background: var(--hero-bg, #351965);
	border-radius: 50%;
	color: #fff;
	display: flex;
	font-size: 28px;
	font-weight: 700;
	height: 128px;
	justify-content: center;
	letter-spacing: 0.04em;
	margin: 0 auto 24px;
	overflow: hidden;
	width: 128px;
}

.strategy-testimonial .testim-meta {
	font-size: 0;
	text-align: center;
}

.strategy-testimonial .testim-meta > span,
.strategy-testimonial .testim-meta a {
	color: #161718;
	display: inline-block;
	font-size: 15px;
	font-weight: 400;
	letter-spacing: 0.02em;
	text-transform: uppercase;
}

.strategy-testimonial .testim-meta > span.testim-name {
	font-weight: 700;
}

.strategy-testimonial .testim-pos:before,
.strategy-testimonial .testim-com:before {
	content: ", ";
}

.strategy-more-solutions {
	background: var(--brand-bg-alt, #f4f4f4);
	display: grid;
	gap: 34px;
	grid-template-columns: 1fr;
	padding-bottom: 86px;
	padding-top: 86px;
	scroll-margin-top: 120px;
}

.strategy-more-intro {
	background: #fff;
	border-left: 6px solid var(--brand-kicker, #f9981d);
	padding: 42px;
}

.strategy-more-intro h2 {
	color: var(--text-dark, #28272d);
	font-size: clamp(32px, 4vw, 56px);
	font-weight: 500;
	line-height: 1.04;
	margin: 0 0 22px;
}

.strategy-more-intro p:not(.strategy-kicker) {
	font-size: 23px;
	line-height: 1.45;
	margin: 0 0 28px;
	max-width: 720px;
}

.strategy-service-map {
	display: grid;
	gap: 18px;
	grid-template-columns: repeat(4, minmax(0, 1fr));
}

.strategy-service-group {
	background: #fff;
	border-top: 5px solid var(--brand-accent, #af4bac);
	display: grid;
	gap: 0;
	padding: 24px;
}

.strategy-service-group h3 {
	color: var(--text-dark, #28272d);
	font-size: 22px;
	font-weight: 700;
	line-height: 1.16;
	margin: 0 0 18px;
	min-height: 52px;
}

.strategy-service-group a,
.strategy-service-group span {
	border-top: 1px solid rgba(40, 39, 45, 0.1);
	color: var(--text-dark, #28272d) !important;
	display: block;
	font-size: 16px;
	line-height: 1.35;
	padding: 13px 0;
	text-decoration: none;
	transition: background-color 0.2s ease, color 0.2s ease;
}

.strategy-service-group a:not(.strategy-service-cta)::after {
	color: var(--brand-accent, #af4bac);
	content: '\2192';
	display: inline-block;
	font-weight: 700;
	margin-left: 8px;
	transition: transform 0.2s ease;
}

.strategy-service-group a:not(.strategy-service-cta):hover,
.strategy-service-group a:not(.strategy-service-cta):focus {
	color: var(--brand-accent, #af4bac) !important;
	text-decoration: none;
}

.strategy-service-group a:not(.strategy-service-cta):hover::after,
.strategy-service-group a:not(.strategy-service-cta):focus::after {
	transform: translateX(3px);
}

.strategy-service-cta {
	border-top: 0 !important;
	color: var(--brand-accent, #af4bac) !important;
	font-size: 14px !important;
	font-weight: 700;
	letter-spacing: 0.08em;
	padding-bottom: 0 !important;
	text-transform: uppercase;
}

.strategy-service-cta::after {
	content: '\2192';
	margin-left: 8px;
}

.strategy-service-cta-secondary {
	color: var(--hero-bg, #351965) !important;
	padding-top: 8px !important;
}

.strategy-full-service-link {
	background: var(--brand-bg-light, #f7f2f7);
	padding-bottom: 86px;
	padding-top: 86px;
}

.strategy-full-service-card {
	background: #fff;
	border-top: 7px solid var(--brand-accent, #af4bac);
	box-shadow: 0 18px 42px rgba(53, 25, 101, 0.1);
	display: grid;
	gap: 34px;
	grid-template-columns: minmax(0, 0.68fr) minmax(220px, 0.32fr);
	margin: 0 auto;
	max-width: 1120px;
	padding: 42px;
}

.strategy-full-service-card h2 {
	color: var(--hero-bg, #351965);
	font-size: clamp(32px, 4vw, 56px);
	font-weight: 500;
	line-height: 1.04;
	margin: 0 0 18px;
}

.strategy-full-service-card p {
	font-size: 21px;
	line-height: 1.45;
	margin: 0;
}

.strategy-full-service-list {
	align-self: center;
	border-left: 1px solid rgba(175, 75, 172, 0.25);
	display: grid;
	gap: 12px;
	padding-left: 28px;
}

.strategy-full-service-list span {
	color: var(--text-dark, #28272d);
	font-size: 15px;
	font-weight: 700;
	letter-spacing: 0.08em;
	line-height: 1.3;
	text-transform: uppercase;
}

.strategy-full-service-card .strategy-button-row {
	margin-top: 28px;
}

.strategy-process-deep {
	background: var(--brand-bg-light, #f7f2f7);
	padding-bottom: 88px;
	padding-top: 88px;
}

.strategy-process-deep-inner {
	margin: 0 auto;
	max-width: 1180px;
}

.strategy-process-deep h2 {
	color: var(--hero-bg, #351965);
	font-size: clamp(34px, 4vw, 58px);
	font-weight: 500;
	line-height: 1.04;
	margin: 0 0 24px;
	max-width: 820px;
}

.strategy-process-deep-intro {
	font-size: 22px;
	line-height: 1.45;
	margin: 0 0 42px;
	max-width: 780px;
}

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

.strategy-process-card {
	background: #fff;
	border-top: 5px solid var(--brand-accent, #af4bac);
	padding: 28px;
}

.strategy-process-card span {
	color: var(--brand-accent, #af4bac);
	display: block;
	font-size: 13px;
	font-weight: 700;
	letter-spacing: 0.14em;
	margin-bottom: 16px;
	text-transform: uppercase;
}

.strategy-process-card h3 {
	color: var(--text-dark, #28272d);
	font-size: 24px;
	line-height: 1.18;
	margin: 0 0 12px;
}

.strategy-process-card p {
	font-size: 17px;
	line-height: 1.55;
	margin: 0 0 18px;
}

.strategy-process-card ul {
	list-style: none;
	margin: 0;
	padding: 0;
}

.strategy-process-card li {
	border-top: 1px solid rgba(40, 39, 45, 0.1);
	color: rgba(40, 39, 45, 0.78);
	font-size: 14px;
	line-height: 1.35;
	padding: 10px 0 0;
}

.strategy-principles {
	background: #fff;
	padding-bottom: 88px;
	padding-top: 88px;
}

.strategy-principles-intro {
	display: grid;
	gap: 48px;
	grid-template-columns: minmax(280px, 0.42fr) minmax(0, 0.58fr);
	margin: 0 auto 44px;
	max-width: 1180px;
}

.strategy-principles h2 {
	color: var(--text-dark, #28272d);
	font-size: clamp(34px, 4vw, 58px);
	font-weight: 500;
	line-height: 1.04;
	margin: 0;
}

.strategy-principles-intro p:not(.strategy-kicker) {
	font-size: 22px;
	line-height: 1.5;
	margin: 0 0 20px;
}

.strategy-principles-grid {
	display: grid;
	gap: 18px;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	margin: 0 auto;
	max-width: 1180px;
}

.strategy-principle {
	background: var(--brand-bg-light, #f7f2f7);
	border-top: 5px solid var(--brand-accent, #af4bac);
	padding: 28px;
}

.strategy-principle span {
	color: var(--brand-accent, #af4bac);
	display: block;
	font-size: 13px;
	font-weight: 700;
	letter-spacing: 0.14em;
	margin-bottom: 18px;
	text-transform: uppercase;
}

.strategy-principle h3 {
	color: var(--text-dark, #28272d);
	font-size: 25px;
	line-height: 1.18;
	margin: 0 0 12px;
}

.strategy-principle p {
	font-size: 17px;
	line-height: 1.55;
	margin: 0;
}

.strategy-values-callout {
	background: var(--hero-bg, #351965);
	color: #fff;
	display: grid;
	gap: 30px;
	grid-template-columns: minmax(0, 0.72fr) auto;
	margin: 28px auto 0;
	max-width: 1180px;
	padding: 34px;
}

.strategy-values-callout h3,
.strategy-values-callout p {
	color: inherit;
	margin: 0;
}

.strategy-values-callout h3 {
	font-size: clamp(28px, 3vw, 42px);
	font-weight: 500;
	line-height: 1.08;
	margin-bottom: 12px;
}

.strategy-values-callout p {
	color: rgba(255, 255, 255, 0.82);
	font-size: 18px;
	line-height: 1.5;
}

.strategy-values-callout .strategy-button {
	align-self: center;
	background: transparent;
	border-color: rgba(255, 255, 255, 0.78);
	white-space: nowrap;
}

.strategy-values-callout .strategy-button:hover {
	background: #fff;
	border-color: #fff;
	color: var(--hero-bg, #351965) !important;
}

.strategy-logo-proof {
	background: var(--brand-bg-alt, #f4f4f4);
	padding-bottom: 88px;
	padding-top: 88px;
}

.strategy-logo-proof-inner {
	display: grid;
	gap: 44px;
	grid-template-columns: minmax(280px, 0.35fr) minmax(0, 0.65fr);
	margin: 0 auto;
	max-width: 1180px;
}

.strategy-logo-proof h2 {
	color: var(--text-dark, #28272d);
	font-size: clamp(32px, 4vw, 52px);
	font-weight: 500;
	line-height: 1.06;
	margin: 0;
}

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

.strategy-logo-grid img {
	background: #fff;
	display: block;
	height: 96px;
	object-fit: contain;
	padding: 18px;
	width: 100%;
}

.strategy-portfolio-links {
	background: #fff;
	padding-bottom: 88px;
	padding-top: 88px;
}

.strategy-portfolio-links-inner {
	margin: 0 auto;
	max-width: 1180px;
}

.strategy-portfolio-head {
	align-items: end;
	display: grid;
	gap: 28px;
	grid-template-columns: minmax(0, 0.7fr) auto;
	margin-bottom: 34px;
}

.strategy-portfolio-head h2 {
	color: var(--text-dark, #28272d);
	font-size: clamp(32px, 4vw, 54px);
	font-weight: 500;
	line-height: 1.06;
	margin: 0;
}

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

.strategy-portfolio-card {
	background: var(--brand-bg-light, #f7f2f7);
	border-top: 5px solid var(--brand-accent, #af4bac);
	color: var(--text-dark, #28272d) !important;
	display: block;
	min-height: 190px;
	padding: 28px;
	text-decoration: none;
}

.strategy-portfolio-card span {
	color: var(--brand-accent, #af4bac);
	display: block;
	font-size: 13px;
	font-weight: 700;
	letter-spacing: 0.12em;
	margin-bottom: 16px;
	text-transform: uppercase;
}

.strategy-portfolio-card strong {
	display: block;
	font-size: 24px;
	line-height: 1.18;
	margin-bottom: 14px;
}

.strategy-portfolio-card em {
	color: rgba(40, 39, 45, 0.72);
	display: block;
	font-size: 16px;
	font-style: normal;
	line-height: 1.45;
}

.strategy-portfolio-card:hover,
.strategy-portfolio-card:focus {
	background: var(--hero-bg, #351965);
	color: #fff !important;
	text-decoration: none;
}

.strategy-portfolio-card:hover span,
.strategy-portfolio-card:focus span,
.strategy-portfolio-card:hover em,
.strategy-portfolio-card:focus em {
	color: rgba(255, 255, 255, 0.78);
}

.case-study-hero {
	grid-template-columns: minmax(0, 0.56fr) minmax(300px, 0.44fr);
}

.case-study-hero .strategy-hero-copy {
	align-self: stretch;
	background: rgba(255, 255, 255, 0.08);
	border-left: 5px solid var(--brand-kicker, #f9981d);
	display: grid;
	gap: 22px;
	max-width: none;
	padding: 34px;
}

.case-study-meta {
	display: grid;
	gap: 12px;
}

.case-study-meta span {
	border-top: 1px solid rgba(255, 255, 255, 0.18);
	color: rgba(255, 255, 255, 0.76);
	display: block;
	font-size: 13px;
	font-weight: 700;
	letter-spacing: 0.12em;
	padding-top: 12px;
	text-transform: uppercase;
}

.case-study-hero .strategy-hero-copy p {
	font-size: 21px;
	margin-bottom: 0;
}

.case-study-actions {
	align-items: center;
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	margin-top: 6px;
}

.case-study-actions .strategy-button {
	font-size: 13px;
	padding: 13px 20px 11px;
}

.case-study-image-card {
	background: #fff;
	display: block;
	min-height: 320px;
	overflow: hidden;
}

.case-study-image-card img {
	display: block;
	height: 100%;
	min-height: 320px;
	object-fit: cover;
	width: 100%;
}

.case-study-image-card-featured img {
	object-fit: contain;
	padding: 24px;
}

.case-study-results {
	background: var(--brand-bg-light, #f7f2f7);
	border-top: 5px solid var(--brand-accent, #af4bac);
	display: grid;
	gap: 22px;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	margin-top: 40px;
	padding: 28px;
}

.case-study-result strong,
.case-study-result span {
	display: block;
}

.case-study-result strong {
	color: var(--hero-bg, #351965);
	font-size: 34px;
	font-weight: 500;
	line-height: 1.05;
	margin-bottom: 8px;
}

.case-study-result span {
	color: rgba(40, 39, 45, 0.72);
	font-size: 15px;
	line-height: 1.45;
}

.case-study-gallery {
	background: var(--brand-bg-alt, #f4f4f4);
	padding-bottom: 88px;
	padding-top: 88px;
}

.case-study-gallery-inner,
.case-study-more-inner {
	margin: 0 auto;
	max-width: 1180px;
}

.case-study-gallery-head,
.case-study-more-head {
	display: grid;
	gap: 28px;
	grid-template-columns: minmax(0, 0.42fr) minmax(0, 0.58fr);
	margin-bottom: 34px;
}

.case-study-more-head {
	align-items: end;
	grid-template-columns: minmax(0, 0.7fr) auto;
}

.case-study-gallery h2,
.case-study-more h2 {
	color: var(--text-dark, #28272d);
	font-size: clamp(32px, 4vw, 54px);
	font-weight: 500;
	line-height: 1.06;
	margin: 0;
}

.case-study-gallery-head p {
	font-size: 20px;
	line-height: 1.5;
	margin: 0;
}

.case-study-gallery-grid {
	display: grid;
	gap: 18px;
	grid-template-columns: 1.2fr 0.8fr;
}

.case-study-gallery-grid img {
	background: #fff;
	display: block;
	height: 100%;
	min-height: 260px;
	object-fit: cover;
	width: 100%;
}

.case-study-gallery-grid img:first-child {
	grid-row: span 2;
	min-height: 540px;
}

.case-study-more {
	background: #fff;
	padding-bottom: 88px;
	padding-top: 88px;
}

.strategy-cta {
	background: #fff;
	padding-bottom: 92px;
	padding-top: 92px;
	text-align: center;
}

.strategy-cta p {
	font-size: 22px;
	margin-left: auto;
	margin-right: auto;
	max-width: 720px;
}

@media (max-width: 900px) {
	.strategy-hero,
	.strategy-split,
	.strategy-band .strategy-split,
	.strategy-proof,
	.strategy-more-solutions,
	.strategy-testimonial .vpi-tstm-a-w {
		grid-template-columns: 1fr;
	}

	.case-study-hero,
	.case-study-gallery-head,
	.case-study-gallery-grid,
	.case-study-more-head {
		grid-template-columns: 1fr;
	}

	.strategy-hero {
		min-height: 0;
		padding-top: 82px;
	}

	.strategy-hero-title .strategy-hero-copy {
		border-left: 0;
		border-top: 4px solid var(--brand-kicker, #f9981d);
		padding-left: 0;
		padding-top: 28px;
	}

	.strategy-services,
	.strategy-steps,
	.strategy-service-map,
	.strategy-full-service-card,
	.strategy-process-grid,
	.strategy-principles-intro,
	.strategy-principles-grid,
	.strategy-values-callout,
	.strategy-logo-proof-inner,
	.strategy-portfolio-head,
	.case-study-results,
	.strategy-portfolio-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.strategy-services,
	.strategy-steps,
	.strategy-full-service-card,
	.strategy-principles-intro,
	.strategy-values-callout,
	.strategy-logo-proof-inner,
	.strategy-portfolio-head,
	.case-study-results {
		grid-template-columns: 1fr;
	}

	.case-study-gallery-grid img:first-child {
		grid-row: auto;
		min-height: 300px;
	}

	.strategy-full-service-list {
		border-left: 0;
		border-top: 1px solid rgba(175, 75, 172, 0.25);
		padding-left: 0;
		padding-top: 24px;
	}

	.strategy-step,
	.strategy-step:first-child {
		border-left: 0;
		border-top: 1px solid rgba(0, 0, 0, 0.08);
	}

	.strategy-step:first-child {
		border-top: 0;
	}
}

@media (max-width: 560px) {
	.strategy-landing {
		font-size: 16px;
	}

	.strategy-next-solution {
		bottom: 14px;
		left: 14px;
		min-width: 0;
		padding: 12px 44px 12px 16px;
		right: 14px;
		top: auto;
	}

	.strategy-next-solution strong {
		font-size: 16px;
	}

	.strategy-hero,
	.strategy-section,
	.strategy-band,
	.strategy-proof,
	.strategy-testimonial,
	.strategy-more-solutions,
	.strategy-full-service-link,
	.strategy-process-deep,
	.strategy-principles,
	.strategy-logo-proof,
	.strategy-portfolio-links,
	.case-study-gallery,
	.case-study-more,
	.strategy-cta {
		padding-left: 20px;
		padding-right: 20px;
	}

	.strategy-more-intro,
	.strategy-full-service-card,
	.strategy-process-card {
		padding: 28px;
	}

	.strategy-more-intro p:not(.strategy-kicker) {
		font-size: 20px;
	}

	.strategy-service-map {
		grid-template-columns: 1fr;
	}

	.strategy-process-grid {
		grid-template-columns: 1fr;
	}

	.strategy-principles-grid,
	.case-study-results,
	.strategy-portfolio-grid {
		grid-template-columns: 1fr;
	}

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

	.strategy-values-callout {
		padding: 28px;
	}

	.strategy-values-callout .strategy-button {
		justify-self: start;
		white-space: normal;
	}

	.strategy-service-group h3 {
		min-height: 0;
	}

	.strategy-testimonial .testimonial-card {
		padding: 28px;
	}

	.strategy-testimonial-slider {
		padding: 28px;
	}

	.strategy-testimonial-avatar {
		font-size: 24px;
		height: 92px;
		width: 92px;
	}

	.strategy-hero-copy p,
	.strategy-lede,
	.strategy-cta p {
		font-size: 20px;
	}
}
