/**
 * The Word Smithy - Main Stylesheet
 *
 * @package TheWordSmithy
 * @since 1.0.0
 */

/* ==========================================================================
   CSS Custom Properties (Design Tokens)
   ========================================================================== */

:root {
	/* Colors */
	--tws-ink: #231F20;
	--tws-orange: #F76810;
	--tws-white: #FFFFFF;
	--tws-bg-alt: #FAFAFA;
	--tws-ink-70: rgba(35, 31, 32, 0.7);
	--tws-ink-40: rgba(35, 31, 32, 0.4);
	--tws-ink-20: rgba(35, 31, 32, 0.2);
	--tws-ink-10: rgba(35, 31, 32, 0.1);

	/* Typography */
	--font-highrise: 'Highrise', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
	--font-roboto: 'Roboto', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
	--font-mallians: 'Mallians', 'Brush Script MT', cursive;

	/* Spacing */
	--spacing-xs: 0.5rem;
	--spacing-sm: 1rem;
	--spacing-md: 1.5rem;
	--spacing-lg: 2rem;
	--spacing-xl: 3rem;
	--spacing-2xl: 4rem;
	--spacing-3xl: 6rem;

	/* Layout */
	--max-width: 1440px;
	--content-width: 72ch;
	--grid-gap: 2rem;

	/* Border Radius */
	--radius-sm: 4px;
	--radius-md: 8px;
	--radius-lg: 12px;

	/* Transitions */
	--transition-base: 0.2s ease-in-out;
	--transition-slow: 0.4s ease-in-out;

	/* Shadows */
	--shadow-sm: 0 2px 4px rgba(35, 31, 32, 0.1);
	--shadow-md: 0 4px 8px rgba(35, 31, 32, 0.15);
	--shadow-lg: 0 8px 16px rgba(35, 31, 32, 0.2);
}

/* ==========================================================================
   Base & Reset
   ========================================================================== */

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

html {
	font-size: 16px;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	scroll-behavior: smooth;
}

@media (prefers-reduced-motion: reduce) {
	html {
		scroll-behavior: auto;
	}
}

body {
	margin: 0;
	font-family: var(--font-roboto);
	font-size: 1rem;
	line-height: 1.6;
	color: var(--tws-ink);
	background-color: var(--tws-white);
}

img {
	max-width: 100%;
	height: auto;
	display: block;
}

a {
	color: var(--tws-orange);
	text-decoration: none;
	transition: color var(--transition-base);
}

a:hover,
a:focus {
	color: var(--tws-ink);
}

a:focus-visible {
	outline: 2px solid var(--tws-orange);
	outline-offset: 2px;
}

/* Script Font Utility */
.script-font {
	font-family: var(--font-mallians);
	font-size: 1.25em;
	color: var(--tws-orange);
}

/* ==========================================================================
   Typography
   ========================================================================== */

h1, h2, h3, h4, h5, h6 {
	font-family: var(--font-highrise);
	font-weight: 700;
	text-transform: uppercase;
	line-height: 1.2;
	margin-top: 0;
}

h1 {
	font-size: clamp(2.5rem, 6vw, 4rem);
	margin-bottom: 1.5rem;
}

h2 {
	font-size: clamp(2rem, 5vw, 3rem);
	margin-bottom: 1.25rem;
}

h3 {
	font-size: clamp(1.5rem, 4vw, 2.5rem);
	margin-bottom: 1rem;
}

h4 {
	font-size: clamp(1.25rem, 3vw, 2rem);
	margin-bottom: 0.875rem;
}

h5 {
	font-size: clamp(1.125rem, 2.5vw, 1.5rem);
	margin-bottom: 0.75rem;
}

h6 {
	font-size: clamp(1rem, 2vw, 1.25rem);
	margin-bottom: 0.625rem;
}

/* Typography Utility Classes */
.h1 { font-size: clamp(2.5rem, 6vw, 4rem); font-family: var(--font-highrise); font-weight: 700; text-transform: uppercase; line-height: 1.2; }
.h2 { font-size: clamp(2rem, 5vw, 3rem); font-family: var(--font-highrise); font-weight: 700; text-transform: uppercase; line-height: 1.2; }
.h3 { font-size: clamp(1.5rem, 4vw, 2.5rem); font-family: var(--font-highrise); font-weight: 700; text-transform: uppercase; line-height: 1.2; }
.h4 { font-size: clamp(1.25rem, 3vw, 2rem); font-family: var(--font-highrise); font-weight: 700; text-transform: uppercase; line-height: 1.2; }
.h5 { font-size: clamp(1.125rem, 2.5vw, 1.5rem); font-family: var(--font-highrise); font-weight: 700; text-transform: uppercase; line-height: 1.2; }
.h6 { font-size: clamp(1rem, 2vw, 1.25rem); font-family: var(--font-highrise); font-weight: 700; text-transform: uppercase; line-height: 1.2; }

.lead {
	font-size: 1.25rem;
	line-height: 1.6;
	margin-bottom: 1.5rem;
}

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

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

.text-right {
	text-align: right;
}

.section-heading {
	text-align: center;
	margin-bottom: var(--spacing-2xl);
	position: relative;
}

.section-heading::after {
	content: '';
	display: block;
	width: 60px;
	height: 4px;
	background-color: var(--tws-orange);
	margin: var(--spacing-md) auto 0;
}

.section-title {
	font-family: var(--font-highrise);
	font-size: clamp(2rem, 5vw, 3rem);
	font-weight: 700;
	text-transform: uppercase;
	line-height: 1.2;
	margin-bottom: 1.5rem;
}

.section-intro {
	font-size: 1.125rem;
	line-height: 1.6;
	max-width: var(--content-width);
	margin: 0 auto var(--spacing-xl);
}

.page-title {
	font-family: var(--font-highrise);
	font-size: clamp(2.5rem, 6vw, 4rem);
	font-weight: 700;
	text-transform: uppercase;
	line-height: 1.2;
	margin-bottom: 1.5rem;
}

.page-intro {
	font-size: 1.25rem;
	line-height: 1.6;
	max-width: var(--content-width);
	margin: 0 auto 2rem;
}

/* ==========================================================================
   Layout
   ========================================================================== */

.container {
	max-width: var(--max-width);
	margin: 0 auto;
	padding: 0 var(--spacing-lg);
}

.site-main {
	min-height: 50vh;
}

.section-spacing {
	padding: var(--spacing-3xl) 0;
}

.bg-light {
	background-color: var(--tws-bg-alt);
}

.bg-dark {
	background-color: var(--tws-ink);
	color: var(--tws-white);
}

.bg-orange {
	background-color: var(--tws-orange);
	color: var(--tws-white);
}

/* Page Header */
.page-header {
	padding: var(--spacing-3xl) var(--spacing-lg);
	text-align: center;
	background-color: var(--tws-bg-alt);
}

.page-header--services {
	background-color: var(--tws-ink);
	color: var(--tws-white);
}

.page-header--services .page-title {
	color: var(--tws-orange);
}

/* Site Header */
.site-header {
	position: sticky;
	top: 0;
	z-index: 100;
	background-color: var(--tws-white);
	box-shadow: var(--shadow-sm);
}

.site-header__container {
	max-width: var(--max-width);
	margin: 0 auto;
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.site-header__logo img {
	max-height: 100px;
	width: auto;
}

.site-logo {
	max-height: 100px;
	width: auto;
}

/* Primary Navigation */
.primary-navigation ul {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	gap: var(--spacing-lg);
}

.primary-navigation a {
	font-family: var(--font-highrise);
	font-size: 1.3rem;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	color: var(--tws-ink);
	transition: color var(--transition-base);
}

.primary-navigation a:hover,
.primary-navigation a:focus,
.primary-navigation a.current {
	color: var(--tws-orange);
}

.nav-menu {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	gap: var(--spacing-lg);
}

/* Sub-menu / Dropdown Navigation */
.menu-item-has-children {
	position: relative;
}

.sub-menu {
	display: none !important;
	position: absolute;
	top: 100%;
	left: 0;
	background-color: var(--tws-white);
	box-shadow: var(--shadow-md);
	list-style: none;
	margin: 0.5rem 0 0 0;
	padding: var(--spacing-sm);
	min-width: 200px;
	z-index: 101;
	border-radius: var(--radius-sm);
	opacity: 0;
	visibility: hidden;
	transform: translateY(-10px);
	transition: opacity var(--transition-base), transform var(--transition-base), visibility 0s var(--transition-base);
}

.menu-item-has-children:hover .sub-menu,
.menu-item-has-children:focus-within .sub-menu {
	display: block !important;
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
	transition: opacity var(--transition-base), transform var(--transition-base), visibility 0s 0s;
}

.sub-menu li {
	margin: 0;
}

.sub-menu a {
	display: block;
	padding: var(--spacing-sm);
	color: var(--tws-ink);
	white-space: nowrap;
}

.sub-menu a:hover,
.sub-menu a:focus {
	color: var(--tws-orange);
	background-color: var(--tws-bg-alt);
}

.current-menu-parent > a {
	color: var(--tws-orange);
}

/* Mobile Navigation */
@media (max-width: 768px) {
	.primary-navigation {
		position: fixed;
		top: 0;
		right: -100%;
		width: 280px;
		height: 100vh;
		background-color: var(--tws-white);
		box-shadow: var(--shadow-lg);
		padding: var(--spacing-3xl) var(--spacing-lg);
		transition: right var(--transition-slow);
		z-index: 999;
		overflow-y: auto;
	}

	.primary-navigation.is-open {
		right: 0;
	}

	.primary-navigation ul,
	.nav-menu {
		flex-direction: column;
		gap: var(--spacing-md);
	}

	.primary-navigation a {
		font-size: 1rem;
		display: block;
		padding: var(--spacing-sm) 0;
	}

	.sub-menu {
		position: static;
		box-shadow: none;
		padding-left: var(--spacing-md);
		margin-top: var(--spacing-xs);
		display: none;
	}

	.menu-item-has-children.is-open .sub-menu {
		display: block;
	}
}

/* Mobile Navigation Toggle */
.mobile-nav-toggle {
	display: none;
	padding: 0;
	background: transparent;
	border: none;
	cursor: pointer;
	z-index: 1000;
	position: relative;
}

@media (max-width: 768px) {
	.mobile-nav-toggle {
		display: flex;
		align-items: center;
		justify-content: center;
		width: 48px;
		height: 48px;
	}
}

.mobile-nav-toggle .icon {
	width: 24px;
	height: 24px;
	fill: var(--tws-ink);
	transition: opacity var(--transition-base);
}

.mobile-nav-toggle .icon-close {
	position: absolute;
	opacity: 0;
	pointer-events: none;
}

.mobile-nav-toggle[aria-expanded="true"] .icon-menu {
	opacity: 0;
	pointer-events: none;
}

.mobile-nav-toggle[aria-expanded="true"] .icon-close {
	opacity: 1;
	pointer-events: auto;
}

.mobile-nav-toggle:hover .icon,
.mobile-nav-toggle:focus .icon {
	fill: var(--tws-orange);
}

/* Body overlay when nav is open */
body.nav-open {
	overflow: hidden;
}

body.nav-open::before {
	content: '';
	position: fixed;
	inset: 0;
	background-color: rgba(35, 31, 32, 0.5);
	z-index: 998;
	animation: fadeIn 0.3s ease-in-out;
}

@keyframes fadeIn {
	from {
		opacity: 0;
	}
	to {
		opacity: 1;
	}
}

/* Footer */
.site-footer {
	padding: var(--spacing-3xl) var(--spacing-lg);
	background-color: var(--tws-ink);
	color: var(--tws-white);
}

.site-footer__container {
	max-width: var(--max-width);
	margin: 0 auto;
}

.site-footer h4 {
	color: var(--tws-orange);
	font-size: 1.125rem;
	margin-bottom: var(--spacing-md);
}

.site-footer a {
	color: var(--tws-white);
}

.site-footer a:hover,
.site-footer a:focus {
	color: var(--tws-orange);
}

.footer-divider {
	margin: var(--spacing-2xl) 0;
	border: none;
	height: 1px;
	background-color: rgba(255, 255, 255, 0.2);
}

.footer-bottom {
	font-size: 0.875rem;
	opacity: 0.8;
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: var(--spacing-md);
}

.footer-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
	gap: var(--spacing-2xl);
	margin-bottom: var(--spacing-2xl);
}

.footer-col {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-md);
}

.footer-col--brand {
	max-width: 300px;
}

.footer-logo img {
	max-width: 200px;
	margin-bottom: var(--spacing-md);
}

.footer-title {
	color: var(--tws-orange);
	font-size: 1.5rem;
	font-weight: 700;
	text-transform: uppercase;
	margin-bottom: var(--spacing-sm);
}

.footer-tagline {
	font-size: 1rem;
	line-height: 1.6;
	margin-bottom: var(--spacing-sm);
}

.footer-menu,
.footer-contact,
.footer-legal {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: var(--spacing-sm);
}

.footer-legal {
	flex-direction: row;
	gap: var(--spacing-md);
}

.footer-columns {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
	gap: var(--spacing-2xl);
	margin-bottom: var(--spacing-2xl);
}

.copyright {
	margin: 0;
}

/* ==========================================================================
   Buttons
   ========================================================================== */

.btn,
.wp-block-button__link {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.875rem 1.75rem;
	font-family: var(--font-roboto);
	font-size: 1rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	border-radius: var(--radius-sm);
	cursor: pointer;
	transition: all var(--transition-base);
	border: 2px solid transparent;
	text-decoration: none;
}

.btn:focus-visible,
.wp-block-button__link:focus-visible {
	outline: 2px solid var(--tws-orange);
	outline-offset: 2px;
}

.btn svg,
.wp-block-button__link svg {
	width: 20px;
	height: 20px;
	fill: currentColor;
}

.btn-primary,
.wp-block-button.is-style-fill .wp-block-button__link {
	background-color: var(--tws-orange);
	color: var(--tws-white);
}

.btn-primary:hover,
.btn-primary:focus,
.wp-block-button.is-style-fill .wp-block-button__link:hover,
.wp-block-button.is-style-fill .wp-block-button__link:focus {
	background-color: var(--tws-ink);
	color: var(--tws-white);
}

.btn-secondary,
.wp-block-button.is-style-outline .wp-block-button__link {
	background-color: transparent;
	color: var(--tws-ink);
	border-color: var(--tws-ink);
}

.btn-secondary:hover,
.btn-secondary:focus,
.wp-block-button.is-style-outline .wp-block-button__link:hover,
.wp-block-button.is-style-outline .wp-block-button__link:focus {
	background-color: var(--tws-ink);
	color: var(--tws-white);
}

.btn-tertiary {
	background-color: transparent;
	color: var(--tws-orange);
	padding-left: 0;
	padding-right: 0;
	border: none;
}

.btn-tertiary:hover,
.btn-tertiary:focus {
	color: var(--tws-ink);
	text-decoration: underline;
}

.btn-large {
	padding: 1.125rem 2.25rem;
	font-size: 1.125rem;
}

/* ==========================================================================
   Icons
   ========================================================================== */

.icon {
	display: inline-block;
	width: 24px;
	height: 24px;
	fill: currentColor;
	vertical-align: middle;
}

.icon-small {
	width: 16px;
	height: 16px;
}

.icon-large {
	width: 32px;
	height: 32px;
}

/* ==========================================================================
   Grids & Cards
   ========================================================================== */

.services-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
	gap: var(--spacing-2xl);
}

.services-grid--large {
	grid-template-columns: 1fr;
	gap: var(--spacing-3xl);
}

.industries-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
	gap: var(--spacing-xl);
}

.industry-item {
	padding: var(--spacing-lg);
	background-color: var(--tws-bg-alt);
	border-radius: var(--radius-md);
	text-align: center;
}

.industry-icon {
	width: 48px;
	height: 48px;
	margin: 0 auto var(--spacing-md);
}

.industry-icon svg {
	width: 100%;
	height: 100%;
	fill: var(--tws-orange);
}

.contact-grid {
	display: grid;
	grid-template-columns: 1fr 1.5fr;
	gap: var(--spacing-3xl);
	align-items: start;
}

@media (max-width: 900px) {
	.contact-grid {
		grid-template-columns: 1fr;
	}
}

.testimonials-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
	gap: var(--spacing-2xl);
}

.faq-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
	gap: var(--spacing-xl);
	max-width: 1200px;
	margin: 0 auto;
}

.faq-item {
	padding: var(--spacing-lg);
	background-color: var(--tws-white);
	border-radius: var(--radius-md);
	border: 1px solid var(--tws-ink-20);
}

.alt-contact-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
	gap: var(--spacing-xl);
}

.alt-contact-card {
	padding: var(--spacing-xl);
	background-color: var(--tws-bg-alt);
	border-radius: var(--radius-md);
	text-align: center;
}

/* ==========================================================================
   ACF Blocks
   ========================================================================== */

/* Hero Block */
.tws-hero {
	position: relative;
	min-height: 25vh;
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	background-color: #f5f2ed;
	/*background-size: cover;*/
	background-position: left;
	background-repeat: repeat-x;
	overflow: hidden;
	padding: var(--spacing-2xl) var(--spacing-lg);
}

.tws-hero--center {
	text-align: center;
}

.tws-hero__container {
	position: relative;
	z-index: 1;
	max-width: 1000px;
	width: 100%;
	padding: 0 var(--spacing-lg);
}

.tws-hero__content-card {
	background: rgba(255, 255, 255, 0.95);
	backdrop-filter: blur(10px);
	border-radius: 20px;
	padding: var(--spacing-md) var(--spacing-md);
	box-shadow: 0 20px 60px rgba(35, 31, 32, 0.15);
	border: 1px solid rgba(255, 255, 255, 0.8);
	max-width: 700px;
	margin: 0 auto;
}

.tws-hero__content-card img {
	max-height: 200px;
}

.tws-hero__logo img,
.tws-hero__mark svg {
	max-width: 350px;
	margin: 0 auto var(--spacing-lg);
}

.tws-hero__mark svg {
	width: 80px;
	height: 80px;
	fill: var(--tws-ink);
}

.tws-hero__heading {
	color: var(--tws-orange);
	margin-bottom: var(--spacing-md);
}

.tws-hero__subheading {
	font-size: 1.5rem;
	margin: 0px;
	color: var(--tws-ink);
}

.tws-hero__cta {
	display: flex;
	flex-wrap: wrap;
	gap: var(--spacing-md);
	justify-content: center;
}

@media (max-width: 768px) {
	.tws-hero {
		min-height: 70vh;
		padding: var(--spacing-xl) var(--spacing-md);
	}

	.tws-hero__content-card {
		padding: var(--spacing-xl) var(--spacing-lg);
		border-radius: 16px;
	}

	.tws-hero__logo img,
	.tws-hero__mark svg {
		max-width: 250px;
	}

	.tws-hero__subheading {
		font-size: 1.4rem;
	}

	.tws-hero__cta {
		flex-direction: column;
		align-items: stretch;
	}
}

/* Trust Bar Block */
.tws-trust-bar {
	padding: var(--spacing-3xl) var(--spacing-lg);
	background-color: var(--tws-white);
}

.tws-trust-bar__container {
	max-width: var(--max-width);
	margin: 0 auto;
}

.tws-trust-bar__heading {
	text-align: center;
	margin-bottom: var(--spacing-2xl);
}

.tws-trust-bar__logos {
	margin-bottom: var(--spacing-3xl);
}

.logo-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
	gap: var(--spacing-xl);
	align-items: center;
	justify-items: center;
}

.logo-item img {
	width: auto;
	height: 70px;
	max-width: 100%;
	object-fit: contain;
	opacity: 1;
	transition: opacity var(--transition-base);
	filter: grayscale(0%);
}

.logo-item img:hover {
	opacity: 0.7;
	filter: grayscale(100%);
}

.tws-trust-bar__awards {
	margin-top: var(--spacing-2xl);
}

.awards-heading {
	text-align: center;
	margin-bottom: var(--spacing-xl);
}

.awards-list {
	display: flex;
	flex-wrap: wrap;
	gap: var(--spacing-md);
	justify-content: center;
}

.award-item {
	display: flex;
	align-items: center;
	gap: var(--spacing-sm);
	padding: var(--spacing-sm) var(--spacing-md);
	background-color: var(--tws-bg-alt);
	border-radius: var(--radius-sm);
}

.award-logo img {
	width: auto;
	max-height: 50px;
	opacity: 0.9;
	transition: opacity var(--transition-base);
}

.award-item:hover .award-logo img {
	opacity: 1;
}

.award-name {
	font-weight: 500;
}

.award-year {
	color: var(--tws-ink-70);
	font-size: 0.875rem;
	margin-left: var(--spacing-xs);
}

.award-text {
	display: flex;
	align-items: center;
	gap: var(--spacing-xs);
	font-family: var(--font-highrise);
	font-size: 20px;
}

@media (max-width: 768px) {
	.logo-grid {
		grid-template-columns: repeat(auto-fit, minmax(100px, 1fr));
		gap: var(--spacing-lg);
	}

	.logo-item img {
		height: 50px;
	}
}

/* Services Grid Block */
.tws-services-grid {
	padding: var(--spacing-3xl) var(--spacing-lg);
}

.tws-services-grid__container {
	max-width: var(--max-width);
	margin: 0 auto;
}

.tws-services-grid__header {
	max-width: var(--content-width);
	margin: 0 auto var(--spacing-3xl);
	text-align: center;
}

.tws-services-grid__header .section-intro {
	font-size: 1.125rem;
	color: var(--tws-ink-70);
}

.tws-services-grid__items {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(400px, 1fr));
	gap: var(--spacing-lg);
}

.service-card {
	background-color: var(--tws-white);
	padding: var(--spacing-2xl);
	border: 2px solid var(--tws-ink-20);
	border-radius: var(--radius-md);
	transition: all var(--transition-base);
	display: flex;
	flex-direction: column;
}

.service-card:hover {
	border-color: var(--tws-orange);
	box-shadow: var(--shadow-md);
}

.service-card--featured {
	border: 2px solid var(--tws-orange);
	padding: var(--spacing-2xl);
}

.service-card__icon {
	width: 60px;
	height: 60px;
	margin-bottom: var(--spacing-md);
}

.service-card__icon svg {
	width: 100%;
	height: 100%;
	fill: var(--tws-orange);
}

.service-card__content {
	flex: 1;
}

.service-card__header {
	display: flex;
	align-items: center;
	gap: var(--spacing-md);
	margin-bottom: var(--spacing-md);
}

.service-card__header .service-card__icon {
	margin-bottom: 0;
	flex-shrink: 0;
}

.service-card__title {
	color: #000;
	margin-bottom: 0;
}

.service-card__excerpt {
	font-size: 1.125rem;
	line-height: 1.6;
	margin-bottom: var(--spacing-lg);
}

.service-card__description {
	margin-bottom: var(--spacing-lg);
}

.service-card__features {
	list-style: none;
	padding: 0;
	margin: 0 0 var(--spacing-xl) 0;
}

.service-card__features li {
	display: flex;
	align-items: flex-start;
	gap: var(--spacing-sm);
	margin-bottom: var(--spacing-sm);
}

.service-card__features svg {
	width: 20px;
	height: 20px;
	fill: var(--tws-orange);
	flex-shrink: 0;
	margin-top: 2px;
}

.service-card__outcomes {
	padding: var(--spacing-md);
	background-color: var(--tws-bg-alt);
	border-radius: var(--radius-sm);
	margin-bottom: var(--spacing-lg);
}

.service-card__cta {
	margin-top: auto;
	padding-top: var(--spacing-lg);
}

.service-card__image {
	margin-top: var(--spacing-lg);
	border-radius: var(--radius-md);
	overflow: hidden;
}

.service-card__image img {
	width: 100%;
	height: auto;
}

@media (max-width: 900px) {
	.tws-services-grid__items {
		grid-template-columns: 1fr;
	}
}

/* Services Overview Section */
.services-overview {
	padding: var(--spacing-3xl) 0;
}

/* Work Grid Block */
.tws-work-grid {
	padding: var(--spacing-3xl) var(--spacing-lg);
}

.tws-work-grid__container {
	max-width: var(--max-width);
	margin: 0 auto;
}

.tws-work-grid__header {
	margin-bottom: var(--spacing-2xl);
}

.tws-work-grid__filters {
	margin-bottom: var(--spacing-2xl);
	padding-bottom: var(--spacing-xl);
	border-bottom: 1px solid var(--tws-ink-20);
}

.filters-toggle {
	display: inline-flex;
	align-items: center;
	gap: var(--spacing-sm);
	padding: var(--spacing-sm) var(--spacing-md);
	background-color: var(--tws-bg-alt);
	border: 1px solid var(--tws-ink-20);
	border-radius: var(--radius-sm);
	cursor: pointer;
	transition: all var(--transition-base);
}

.filters-toggle:hover {
	background-color: var(--tws-ink);
	color: var(--tws-white);
}

.filters-toggle svg {
	width: 20px;
	height: 20px;
}

.filters-panel {
	display: none;
	margin-top: var(--spacing-md);
	padding: var(--spacing-md);
	background-color: var(--tws-bg-alt);
	border-radius: var(--radius-md);
	gap: var(--spacing-md);
	flex-wrap: wrap;
}

.filters-panel.is-open {
	display: flex;
}

.filter-group {
	flex: 1 1 200px;
}

.filter-group label {
	display: block;
	font-size: 0.875rem;
	font-weight: 700;
	text-transform: uppercase;
	margin-bottom: var(--spacing-xs);
}

.filter-group select {
	width: 100%;
	padding: var(--spacing-sm);
	border: 1px solid var(--tws-ink-20);
	border-radius: var(--radius-sm);
	font-family: var(--font-roboto);
	font-size: 1rem;
}

.filter-group select:focus {
	outline: 2px solid var(--tws-orange);
	outline-offset: 2px;
}

.filters-reset {
	padding: var(--spacing-sm) var(--spacing-md);
	background-color: transparent;
	color: var(--tws-orange);
	border: none;
	text-transform: uppercase;
	font-weight: 700;
	font-size: 0.875rem;
	cursor: pointer;
}

.filters-reset:hover {
	text-decoration: underline;
}

.tws-work-grid__items {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(350px, 1fr));
	gap: var(--spacing-2xl);
}

@media (max-width: 768px) {
	.tws-work-grid__items {
		grid-template-columns: 1fr;
	}
}

/* Case Study Card */
.case-study-card {
	background-color: var(--tws-white);
	border-radius: var(--radius-md);
	overflow: hidden;
	box-shadow: var(--shadow-sm);
	transition: all var(--transition-base);
}

.case-study-card:hover {
	box-shadow: var(--shadow-lg);
	transform: translateY(-4px);
}

.case-study-card__link {
	display: block;
	color: inherit;
}

.case-study-card__link:hover,
.case-study-card__link:focus {
	color: inherit;
}

.case-study-card__image {
	aspect-ratio: 4 / 3;
	overflow: hidden;
	background-color: var(--tws-bg-alt);
}

.case-study-card__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform var(--transition-slow);
}

.case-study-card__image:hover img {
	transform: scale(1.05);
}

.case-study-card__content {
	padding: var(--spacing-lg);
}

.case-study-card__title {
	font-size: 1.5rem;
	margin-bottom: var(--spacing-sm);
}

.case-study-card__client {
	color: var(--tws-ink-70);
	margin-bottom: var(--spacing-sm);
}

.case-study-card__meta {
	display: flex;
	gap: var(--spacing-sm);
	font-size: 0.875rem;
	color: var(--tws-ink-70);
	margin-bottom: var(--spacing-md);
}

.case-study-card__meta .meta-year::after {
	content: ' • ';
	margin-left: var(--spacing-sm);
}

.case-study-card__disciplines {
	display: flex;
	flex-wrap: wrap;
	gap: var(--spacing-xs);
}

.discipline-tag {
	padding: 0.25rem 0.75rem;
	background-color: var(--tws-orange);
	color: var(--tws-white);
	font-size: 0.75rem;
	font-weight: 700;
	text-transform: uppercase;
	border-radius: var(--radius-sm);
}

/* Testimonial Block */
.tws-testimonial-block {
	padding: var(--spacing-3xl) var(--spacing-lg);
}

.tws-testimonial-block__container {
	max-width: var(--max-width);
	margin: 0 auto;
}

.tws-testimonial-block__content {
	width: 100%;
	max-width: 100%;
	overflow: hidden;
}

.tws-testimonial-block .section-heading {
	color: currentColor;
}

.testimonial {
	background-color: rgba(255, 255, 255, 0.1);
	padding: var(--spacing-2xl);
	border-radius: var(--radius-md);
	margin: 0;
	width: 100%;
	box-sizing: border-box;
	overflow: hidden;
}

.testimonial__quote {
	font-size: 1.25rem;
	line-height: 1.6;
	margin-bottom: var(--spacing-xl);
	position: relative;
	width: 100%;
	box-sizing: border-box;
}

.testimonial__quote::before {
	content: '"';
	font-size: 4rem;
	line-height: 1;
	color: var(--tws-orange);
	position: absolute;
	top: -1rem;
	left: -1rem;
}

.testimonial__quote p {
	margin: 0;
	padding-left: 2rem;
	word-wrap: break-word;
	overflow-wrap: break-word;
	max-width: 100%;
}

.testimonial__footer {
	display: flex;
	align-items: center;
	gap: var(--spacing-md);
}

.testimonial__author {
	display: flex;
	flex-direction: column;
}

.testimonial__logo img {
	max-width: 100px;
	max-height: 40px;
}

.testimonial__name {
	display: block;
	font-weight: 700;
	font-style: normal;
	margin-bottom: 0.25rem;
}

.testimonial__meta {
	font-size: 0.875rem;
	opacity: 0.8;
}

.testimonial-carousel {
	position: relative;
	overflow: hidden;
	width: 100%;
}

.testimonial-track {
	display: flex;
	transition: transform var(--transition-slow);
	width: 100%;
}

.testimonial-slide {
	min-width: 100%;
	width: 100%;
	flex-shrink: 0;
	box-sizing: border-box;
}

.testimonial-controls {
	display: flex;
	gap: var(--spacing-md);
	justify-content: center;
	margin-top: var(--spacing-xl);
}

.testimonial-controls button,
.carousel-prev,
.carousel-next {
	width: 48px;
	height: 48px;
	border-radius: 50%;
	background-color: rgba(255, 255, 255, 0.2);
	border: 2px solid currentColor;
	color: inherit;
	cursor: pointer;
	transition: all var(--transition-base);
	display: flex;
	align-items: center;
	justify-content: center;
}

.testimonial-controls button:hover,
.carousel-prev:hover,
.carousel-next:hover {
	background-color: var(--tws-orange);
	border-color: var(--tws-orange);
	color: var(--tws-white);
}

.testimonial-controls button svg,
.carousel-prev svg,
.carousel-next svg {
	width: 24px;
	height: 24px;
	fill: currentColor;
}

.testimonial-dots {
	display: flex;
	gap: var(--spacing-sm);
	justify-content: center;
	margin-top: var(--spacing-md);
}

.carousel-dot {
	width: 12px;
	height: 12px;
	border-radius: 50%;
	background-color: rgba(255, 255, 255, 0.3);
	border: 2px solid rgba(255, 255, 255, 0.5);
	cursor: pointer;
	padding: 0;
	transition: all var(--transition-base);
}

.carousel-dot:hover {
	background-color: rgba(255, 255, 255, 0.5);
	border-color: rgba(255, 255, 255, 0.8);
}

.carousel-dot.is-active {
	background-color: var(--tws-orange);
	border-color: var(--tws-orange);
	transform: scale(1.2);
}

.testimonial-grid {
	display: grid;
	gap: var(--spacing-2xl);
}

/* Testimonial Card */
.testimonial-card {
	background-color: var(--tws-white);
	padding: var(--spacing-xl);
	border-radius: var(--radius-md);
	box-shadow: var(--shadow-sm);
	border-left: 4px solid var(--tws-orange);
}

.testimonial-card__content {
	margin-bottom: var(--spacing-lg);
}

.testimonial-card__content p {
	font-size: 1.125rem;
	line-height: 1.6;
	font-style: italic;
	margin: 0;
}

.testimonial-card__author {
	display: flex;
	align-items: center;
	gap: var(--spacing-md);
}

.testimonial-card__author img {
	width: auto;
	height: 80px;
	border-radius: var(--radius-sm);
	object-fit: cover;
	border: 2px solid var(--tws-orange);
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

.testimonial-card__author strong {
	font-weight: 700;
	color: var(--tws-ink);
	display: block;
}

.testimonial-card__author span {
	font-size: 0.875rem;
	color: var(--tws-ink-70);
	display: block;
}

/* Testimonials Preview */
.testimonials-preview {
	padding: var(--spacing-3xl) 0;
}

/* CTA Block */
.tws-cta-block {
	position: relative;
	padding: var(--spacing-3xl) var(--spacing-lg);
	background-size: cover;
	background-position: center;
}

.tws-cta-block__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(to right, rgba(35, 31, 32, 0.8), rgba(35, 31, 32, 0.6));
}

.tws-cta-block__container {
	position: relative;
	z-index: 1;
	max-width: var(--content-width);
	margin: 0 auto;
	text-align: center;
}

.tws-cta-block__heading {
	margin-bottom: var(--spacing-lg);
}

.tws-cta-block__text {
	font-size: 1.125rem;
	margin-bottom: var(--spacing-xl);
}

.tws-cta-block__buttons {
	display: flex;
	flex-wrap: wrap;
	gap: var(--spacing-md);
	justify-content: center;
}

.tws-cta-block--orange {
	background-color: var(--tws-orange);
	color: var(--tws-white);
}

.tws-cta-block--orange .tws-cta-block__heading {
	color: var(--tws-white);
}

.tws-cta-block--ink {
	background-color: var(--tws-ink);
	color: var(--tws-white);
}

.tws-cta-block--ink .tws-cta-block__heading {
	color: var(--tws-orange);
}

.tws-cta-block--alt {
	background-color: var(--tws-bg-alt);
}

/* CTA Section */
.cta-section {
	padding: var(--spacing-3xl) 0;
}

.cta-block {
	padding: var(--spacing-3xl);
	border-radius: var(--radius-lg);
	text-align: center;
}

.cta-block.bg-orange {
	background-color: var(--tws-orange);
	color: var(--tws-white);
}

.cta-block.bg-orange h2 {
	color: var(--tws-white);
}

/* CTA Block Button Overrides */
.cta-block.bg-orange .btn-primary {
	background-color: transparent;
	color: var(--tws-white);
	border: 2px solid var(--tws-white);
	transition: all var(--transition-base);
}

.cta-block.bg-orange .btn-primary:hover,
.cta-block.bg-orange .btn-primary:focus {
	background-color: var(--tws-ink);
	color: var(--tws-white);
	border-color: var(--tws-ink);
	transform: translateY(-2px);
	box-shadow: 0 4px 12px rgba(35, 31, 32, 0.3);
}

.cta-block__content {
	margin-bottom: var(--spacing-xl);
}

.cta-block__actions {
	display: flex;
	flex-wrap: wrap;
	gap: var(--spacing-md);
	justify-content: center;
}

/* Contact Strip Block */
.tws-contact-strip {
	padding: var(--spacing-3xl) var(--spacing-lg);
}

.tws-contact-strip__container {
	max-width: var(--max-width);
	margin: 0 auto;
}

.tws-contact-strip__header {
	max-width: var(--content-width);
	margin: 0 auto var(--spacing-3xl);
	text-align: center;
}

.contact-intro {
	font-size: 1.125rem;
	line-height: 1.6;
	text-align: center;
	max-width: var(--content-width);
	margin: 0 auto;
}

.tws-contact-strip__content {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--spacing-3xl);
	align-items: start;
}

.contact-methods {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-xl);
}

.contact-method {
	display: flex;
	gap: var(--spacing-md);
	padding: var(--spacing-lg);
	background-color: var(--tws-bg-alt);
	border-radius: var(--radius-md);
}

.contact-method__icon svg {
	width: 32px;
	height: 32px;
	fill: var(--tws-orange);
}

.contact-method__content {
	flex: 1;
}

.contact-method__label {
	display: block;
	font-size: 0.875rem;
	font-weight: 700;
	text-transform: uppercase;
	color: var(--tws-ink-70);
	margin-bottom: 0.25rem;
}

.contact-method__link {
	font-size: 1.125rem;
	font-weight: 500;
	color: var(--tws-ink);
}

.contact-method__link:hover {
	color: var(--tws-orange);
}

.timezone-note {
	font-size: 0.875rem;
	color: var(--tws-ink-70);
	font-style: italic;
}

.contact-form-wrapper {
	background-color: var(--tws-bg-alt);
	padding: var(--spacing-xl);
	border-radius: var(--radius-md);
}

.contact-form {
	background-color: var(--tws-bg-alt);
	padding: var(--spacing-xl);
	border-radius: var(--radius-md);
}

@media (max-width: 900px) {
	.tws-contact-strip__content {
		grid-template-columns: 1fr;
	}
}

/* Contact Content */
.contact-content {
	padding: var(--spacing-3xl) 0;
}

.contact-info {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-xl);
}

.availability-note {
	padding: var(--spacing-lg);
	background-color: var(--tws-bg-alt);
	border-radius: var(--radius-md);
}

.social-links {
	padding: var(--spacing-lg);
	background-color: var(--tws-bg-alt);
	border-radius: var(--radius-md);
}

.social-icons {
	display: flex;
	gap: var(--spacing-md);
}

.social-link {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 48px;
	height: 48px;
	background-color: var(--tws-white);
	border-radius: 50%;
	color: var(--tws-ink);
	transition: all var(--transition-base);
}

.social-link:hover,
.social-link:focus {
	background-color: var(--tws-orange);
	color: var(--tws-white);
}

.social-link svg {
	width: 24px;
	height: 24px;
	fill: currentColor;
}

/* Contact FAQ */
.contact-faq {
	padding: var(--spacing-3xl) 0;
}

/* Alternative Contact Methods */
.alternative-contact {
	padding: var(--spacing-3xl) 0;
}

/* Process Steps */
.how-it-works-section {
	padding: var(--spacing-3xl) 0;
}

.process-steps {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-2xl);
	max-width: 900px;
	margin: 0 auto;
}

.process-step {
	display: flex;
	gap: var(--spacing-lg);
	padding: var(--spacing-xl);
	background-color: var(--tws-white);
	border-radius: var(--radius-md);
	border: 2px solid var(--tws-ink-20);
	transition: all var(--transition-base);
}

.process-step:hover {
	border-color: var(--tws-orange);
	box-shadow: var(--shadow-md);
}

.process-step__number {
	flex-shrink: 0;
	width: 64px;
	height: 64px;
	display: flex;
	align-items: center;
	justify-content: center;
	background-color: var(--tws-orange);
	color: var(--tws-white);
	font-family: var(--font-highrise);
	font-size: 2rem;
	font-weight: 700;
	border-radius: 50%;
}

.process-step__content {
	flex: 1;
}

.process-step__content h3,
.process-step__content h4 {
	margin-top: 0;
	margin-bottom: var(--spacing-sm);
	color: var(--tws-orange);
}

.process-step__content p {
	margin: 0;
}

/* ==========================================================================
   Forms
   ========================================================================== */

.form-row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--spacing-md);
	margin-bottom: var(--spacing-md);
}

@media (max-width: 768px) {
	.form-row {
		grid-template-columns: 1fr;
	}
}

.form-group {
	margin-bottom: var(--spacing-md);
}

.form-group label {
	display: block;
	font-size: 0.875rem;
	font-weight: 700;
	margin-bottom: var(--spacing-xs);
	color: var(--tws-ink);
}

.form-group input[type="text"],
.form-group input[type="email"],
.form-group input[type="tel"],
.form-group input[type="file"],
.form-group select,
.form-group textarea {
	width: 100%;
	padding: var(--spacing-sm);
	border: 1px solid var(--tws-ink-20);
	border-radius: var(--radius-sm);
	font-family: var(--font-roboto);
	font-size: 1rem;
	background-color: var(--tws-white);
	transition: border-color var(--transition-base);
}

.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
	outline: none;
	border-color: var(--tws-orange);
	box-shadow: 0 0 0 3px rgba(247, 104, 16, 0.1);
}

.form-group textarea {
	resize: vertical;
	min-height: 120px;
}

.form-checkbox {
	display: flex;
	align-items: flex-start;
}

.form-checkbox label {
	display: flex;
	align-items: flex-start;
	gap: var(--spacing-sm);
	font-weight: 400;
	cursor: pointer;
}

.form-checkbox input[type="checkbox"] {
	margin-top: 0.25rem;
	width: 20px;
	height: 20px;
	flex-shrink: 0;
	cursor: pointer;
}

.form-help {
	display: block;
	font-size: 0.875rem;
	color: var(--tws-ink-70);
	margin-top: var(--spacing-xs);
}

.form-actions {
	margin-top: var(--spacing-xl);
	display: flex;
	flex-direction: column;
	gap: var(--spacing-md);
	align-items: flex-start;
}

.form-note {
	font-size: 0.875rem;
	color: var(--tws-ink-70);
	margin: 0;
}

.required {
	color: var(--tws-orange);
}

/* ==========================================================================
   Utility Classes
   ========================================================================== */

.no-results {
	text-align: center;
	padding: var(--spacing-3xl);
	color: var(--tws-ink-70);
	font-size: 1.125rem;
}

.breadcrumbs {
	display: flex;
	align-items: center;
	gap: var(--spacing-xs);
	font-size: 0.875rem;
	padding: var(--spacing-md) 0;
	color: var(--tws-ink-70);
}

.breadcrumbs svg {
	width: 16px;
	height: 16px;
	fill: currentColor;
}

.breadcrumbs a {
	color: inherit;
}

.breadcrumbs a:hover {
	color: var(--tws-orange);
}

/* About Teaser Section */
.about-teaser-section {
	padding: var(--spacing-3xl) var(--spacing-lg);
}

/* Industries Section */
.industries-section {
	padding: var(--spacing-3xl) 0;
}

/* ==========================================================================
   Accessibility
   ========================================================================== */

.sr-only,
.screen-reader-text {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border-width: 0;
}

@media (prefers-reduced-motion: reduce) {
	*,
	*::before,
	*::after {
		animation-duration: 0.01ms !important;
		animation-iteration-count: 1 !important;
		transition-duration: 0.01ms !important;
		scroll-behavior: auto !important;
	}
}

/* Skip to main content link */
.skip-link {
	position: absolute;
	top: -100px;
	left: 0;
	background-color: var(--tws-orange);
	color: var(--tws-white);
	padding: var(--spacing-sm) var(--spacing-md);
	z-index: 9999;
}

.skip-link:focus {
	top: 0;
}

/* ==========================================================================
   About Page Styles
   ========================================================================== */

/* About Grid */
.about-grid {
	display: grid;
	grid-template-columns: 400px 1fr;
	gap: var(--spacing-3xl);
	align-items: start;
	margin-bottom: var(--spacing-3xl);
}

.about-grid__image {
	position: sticky;
	top: calc(var(--spacing-2xl) + 80px);
}

.about-grid__image img {
	width: 100%;
	height: auto;
	border-radius: var(--radius-lg);
	box-shadow: var(--shadow-lg);
}

.about-grid__content h2,
.about-grid__content h3 {
	color: var(--tws-orange);
	margin-bottom: var(--spacing-md);
}

.about-grid__content p {
	margin-bottom: var(--spacing-md);
	line-height: 1.8;
}

/* Credentials Section */
.credentials-section {
	background-color: var(--tws-bg-alt);
}

.credentials-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: var(--spacing-xl);
	margin-top: var(--spacing-2xl);
}

.credential-item {
	background-color: var(--tws-white);
	padding: var(--spacing-xl);
	border-radius: var(--radius-md);
	text-align: center;
	transition: all var(--transition-base);
	border: 2px solid transparent;
}

.credential-item:hover {
	border-color: var(--tws-orange);
	box-shadow: var(--shadow-md);
	transform: translateY(-4px);
}

.credential-icon {
	width: 60px;
	height: 60px;
	margin: 0 auto var(--spacing-md);
	display: flex;
	align-items: center;
	justify-content: center;
	background-color: var(--tws-bg-alt);
	border-radius: 50%;
}

.credential-icon svg {
	width: 32px;
	height: 32px;
	fill: var(--tws-orange);
}

.credential-item h3 {
	font-size: 1.5rem;
	margin-bottom: var(--spacing-sm);
	color: var(--tws-ink);
}

.credential-item p {
	font-size: 0.9375rem;
	line-height: 1.6;
	color: var(--tws-ink-70);
	margin: 0;
}

/* Career Timeline */
.timeline-section {
	padding: var(--spacing-3xl) 0;
}

.timeline {
	max-width: 900px;
	margin: var(--spacing-3xl) auto 0;
	position: relative;
	padding-left: var(--spacing-3xl);
}

.timeline::before {
	content: '';
	position: absolute;
	left: 20px;
	top: 0;
	bottom: 0;
	width: 2px;
	background: linear-gradient(to bottom, var(--tws-orange), var(--tws-ink-20));
}

.timeline-item {
	position: relative;
	margin-bottom: var(--spacing-3xl);
	padding-left: var(--spacing-xl);
}

.timeline-item:last-child {
	margin-bottom: 0;
}

.timeline-marker {
	position: absolute;
	left: -46px;
	top: 4px;
	width: 40px;
	height: 40px;
	border-radius: 50%;
	background-color: var(--tws-white);
	border: 3px solid var(--tws-orange);
	box-shadow: 0 0 0 4px var(--tws-white), var(--shadow-sm);
	z-index: 1;
}

.timeline-content {
	background-color: var(--tws-white);
	padding: var(--spacing-lg);
	border-radius: var(--radius-md);
	box-shadow: var(--shadow-sm);
	transition: all var(--transition-base);
}

.timeline-content:hover {
	box-shadow: var(--shadow-md);
	transform: translateX(8px);
}

.timeline-date {
	display: inline-block;
	padding: 0.25rem 0.75rem;
	background-color: var(--tws-orange);
	color: var(--tws-white);
	border-radius: var(--radius-sm);
	font-size: 0.875rem;
	font-weight: 700;
	margin-bottom: var(--spacing-sm);
}

.timeline-content h3 {
	font-size: 1.5rem;
	margin-bottom: 0.25rem;
	color: var(--tws-ink);
}

.timeline-company {
	color: var(--tws-orange);
	font-weight: 600;
	margin-bottom: var(--spacing-sm);
	display: block;
}

.timeline-content p {
	margin: 0;
	line-height: 1.7;
	color: var(--tws-ink-70);
}

/* About Page Responsive */
@media (max-width: 900px) {
	.about-grid {
		grid-template-columns: 1fr;
		gap: var(--spacing-2xl);
	}

	.about-grid__image {
		position: relative;
		top: 0;
		max-width: 400px;
		margin: 0 auto;
	}

	.credentials-grid {
		grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
		gap: var(--spacing-md);
	}

	.timeline {
		padding-left: var(--spacing-2xl);
	}

	.timeline::before {
		left: 12px;
	}

	.timeline-marker {
		left: -38px;
		width: 32px;
		height: 32px;
	}
}

@media (max-width: 768px) {
	.about-grid__image {
		max-width: 100%;
	}

	.credentials-grid {
		grid-template-columns: 1fr;
	}

	.credential-item {
		padding: var(--spacing-lg);
	}

	.timeline {
		padding-left: var(--spacing-xl);
	}

	.timeline-item {
		padding-left: var(--spacing-md);
	}

	.timeline-marker {
		width: 24px;
		height: 24px;
		left: -30px;
	}
}

/* ==========================================================================
   Speaking & Teaching Page Styles
   ========================================================================== */

/* Speaking Overview Section */
.speaking-overview {
	background-color: var(--tws-white);
}

.overview-grid {
	display: grid;
	grid-template-columns: 1.5fr 1fr;
	gap: var(--spacing-3xl);
	align-items: start;
}

.overview-content {
	padding-right: var(--spacing-xl);
}

.overview-stats {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--spacing-lg);
	position: sticky;
	top: calc(var(--spacing-2xl) + 80px);
}

.stat-box {
	background: linear-gradient(135deg, var(--tws-orange) 0%, #ff8534 100%);
	padding: var(--spacing-xl);
	border-radius: var(--radius-lg);
	text-align: center;
	color: var(--tws-white);
	box-shadow: var(--shadow-md);
	transition: all var(--transition-base);
}

.stat-box:hover {
	transform: translateY(-4px);
	box-shadow: var(--shadow-lg);
}

.stat-number {
	display: block;
	font-size: 2.5rem;
	font-weight: 700;
	line-height: 1;
	margin-bottom: var(--spacing-xs);
	font-family: var(--font-highrise);
}

.stat-label {
	display: block;
	font-size: 0.875rem;
	opacity: 0.95;
	text-transform: uppercase;
	letter-spacing: 0.05em;
}

/* Overview Quote */
.overview-quote {
	position: sticky;
	top: calc(var(--spacing-2xl) + 80px);
}

.student-quote {
	background: linear-gradient(135deg, var(--tws-orange) 0%, #ff8534 100%);
	padding: var(--spacing-xl);
	border-radius: var(--radius-md);
	box-shadow: var(--shadow-md);
	margin: 0;
	color: var(--tws-white);
}

.quote-content p {
	font-size: 1.125rem;
	line-height: 1.6;
	font-style: italic;
	margin: 0 0 var(--spacing-lg) 0;
	color: var(--tws-white);
}

.quote-author {
	font-style: normal;
}

.quote-author strong {
	font-weight: 700;
	color: var(--tws-white);
	display: block;
	margin-bottom: var(--spacing-xs);
}

.quote-author span {
	font-size: 0.875rem;
	color: var(--tws-white);
	opacity: 0.95;
	display: block;
}

/* Topics Section */
.topics-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
	gap: var(--spacing-xl);
	margin-top: var(--spacing-2xl);
}

.topic-card {
	background-color: var(--tws-white);
	padding: var(--spacing-xl);
	border-radius: var(--radius-md);
	border: 2px solid var(--tws-ink-10);
	transition: all var(--transition-base);
	position: relative;
}

.topic-card:hover {
	border-color: var(--tws-orange);
	box-shadow: var(--shadow-md);
	transform: translateY(-4px);
}

.topic-card__header {
	display: flex;
	align-items: center;
	gap: var(--spacing-md);
	margin-bottom: var(--spacing-md);
}

.topic-icon {
	width: 48px;
	height: 48px;
	flex-shrink: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	background: linear-gradient(135deg, var(--tws-orange) 0%, #ff8534 100%);
	border-radius: var(--radius-md);
	transition: all var(--transition-base);
}

.topic-card:hover .topic-icon {
	transform: scale(1.05);
}

.topic-icon svg {
	width: 24px;
	height: 24px;
	fill: var(--tws-white);
}

.topic-card h3 {
	color: var(--tws-ink);
	margin-bottom: 0;
}

.topic-card p {
	color: var(--tws-ink-70);
	line-height: 1.7;
	margin-bottom: var(--spacing-md);
}

.topic-duration {
	display: inline-block;
	padding: var(--spacing-xs) var(--spacing-sm);
	background-color: var(--tws-bg-alt);
	border-radius: var(--radius-sm);
	font-size: 0.875rem;
	color: var(--tws-ink-70);
	font-weight: 500;
}

/* Workshops Section */
.workshops-grid {
	display: grid;
	gap: var(--spacing-2xl);
	margin-top: var(--spacing-2xl);
}

.workshop-card {
	background-color: var(--tws-white);
	border-radius: var(--radius-lg);
	overflow: hidden;
	border: 2px solid var(--tws-ink-10);
	transition: all var(--transition-base);
}

.workshop-card:hover {
	border-color: var(--tws-orange);
	box-shadow: var(--shadow-lg);
}

.workshop-header {
	background: linear-gradient(135deg, var(--tws-orange) 0%, #ff8534 100%);
	padding: var(--spacing-xl);
	color: var(--tws-white);
	display: flex;
	justify-content: space-between;
	align-items: baseline;
	flex-wrap: wrap;
	gap: var(--spacing-md);
}

.workshop-header h3 {
	color: var(--tws-white);
	margin: 0;
	flex: 1;
}

.workshop-duration {
	font-size: 0.875rem;
	opacity: 0.95;
	background-color: rgba(255, 255, 255, 0.2);
	padding: var(--spacing-xs) var(--spacing-sm);
	border-radius: var(--radius-sm);
	white-space: nowrap;
}

.workshop-content {
	padding: var(--spacing-xl);
}

.workshop-content h4 {
	color: var(--tws-orange);
	margin-top: var(--spacing-lg);
	margin-bottom: var(--spacing-sm);
}

.workshop-content ul {
	list-style: none;
	padding: 0;
	margin-bottom: var(--spacing-lg);
}

.workshop-content ul li {
	padding-left: var(--spacing-lg);
	margin-bottom: var(--spacing-sm);
	position: relative;
	color: var(--tws-ink-70);
	line-height: 1.6;
}

.workshop-content ul li::before {
	content: '✓';
	position: absolute;
	left: 0;
	color: var(--tws-orange);
	font-weight: 700;
}

.workshop-meta {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-xs);
	padding-top: var(--spacing-lg);
	border-top: 2px solid var(--tws-ink-10);
	margin-top: var(--spacing-lg);
}

.workshop-meta span {
	font-size: 0.9375rem;
	color: var(--tws-ink-70);
}

/* Past Engagements */
.engagements-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: var(--spacing-xl);
	margin-top: var(--spacing-2xl);
}

.engagement-item {
	background-color: var(--tws-white);
	padding: var(--spacing-lg);
	border-radius: var(--radius-md);
	border-left: 4px solid var(--tws-orange);
	transition: all var(--transition-base);
}

.engagement-item:hover {
	box-shadow: var(--shadow-md);
	transform: translateX(4px);
}

.engagement-item h3 {
	color: var(--tws-orange);
	margin-bottom: var(--spacing-xs);
	font-size: 1.125rem;
}

.engagement-item p {
	color: var(--tws-ink-70);
	margin: 0;
	line-height: 1.6;
}

/* Speaking Page Responsive */
@media (max-width: 900px) {
	.overview-grid {
		grid-template-columns: 1fr;
		gap: var(--spacing-2xl);
	}

	.overview-stats,
	.overview-quote {
		position: relative;
		top: 0;
	}

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

@media (max-width: 600px) {
	.overview-stats {
		grid-template-columns: 1fr;
	}

	.topics-grid {
		grid-template-columns: 1fr;
	}

	.workshop-header {
		flex-direction: column;
		align-items: flex-start;
	}

	.engagements-grid {
		grid-template-columns: 1fr;
	}
}

/* ==========================================================================
   Strategy & Writing Pages Styles
   ========================================================================== */

/* Service Hero Section */
.service-hero {
	padding: var(--spacing-3xl) 0 var(--spacing-2xl);
	background-color: var(--tws-bg-alt);
}

.service-hero .container {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--spacing-3xl);
	align-items: center;
}

.service-hero__content {
	max-width: 600px;
}

.service-hero__image img {
	width: 100%;
	height: auto;
	border-radius: var(--radius-lg);
	box-shadow: var(--shadow-lg);
}

/* Breadcrumb */
.breadcrumb {
	margin-bottom: var(--spacing-md);
}

.breadcrumb ol {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-wrap: wrap;
	gap: var(--spacing-xs);
}

.breadcrumb li {
	display: flex;
	align-items: center;
	font-size: 0.875rem;
	color: var(--tws-ink-70);
}

.breadcrumb li:not(:last-child)::after {
	content: '›';
	margin-left: var(--spacing-xs);
	color: var(--tws-ink-40);
}

.breadcrumb a {
	color: var(--tws-ink-70);
	transition: color var(--transition-base);
}

.breadcrumb a:hover {
	color: var(--tws-orange);
}

/* Service Detail Section */
.service-detail__intro {
	max-width: 800px;
	margin: 0 auto var(--spacing-3xl);
	text-align: center;
}

/* Offerings Grid */
.offerings-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
	gap: var(--spacing-xl);
	margin-top: var(--spacing-2xl);
}

.offering-card {
	background-color: var(--tws-white);
	padding: var(--spacing-xl);
	border-radius: var(--radius-lg);
	border: 2px solid var(--tws-ink-10);
	transition: all var(--transition-base);
	display: flex;
	flex-direction: column;
}

.offering-card:hover {
	border-color: var(--tws-orange);
	box-shadow: var(--shadow-lg);
	transform: translateY(-4px);
}

.offering-card__icon {
	width: 64px;
	height: 64px;
	margin-bottom: var(--spacing-md);
	display: flex;
	align-items: center;
	justify-content: center;
	background: linear-gradient(135deg, var(--tws-orange) 0%, #ff8534 100%);
	border-radius: var(--radius-md);
	transition: all var(--transition-base);
}

.offering-card:hover .offering-card__icon {
	transform: rotate(-5deg) scale(1.05);
}

.offering-card__icon svg {
	width: 32px;
	height: 32px;
	fill: var(--tws-white);
}

.offering-card h3 {
	color: var(--tws-orange);
	margin-bottom: var(--spacing-sm);
}

.offering-card p {
	color: var(--tws-ink-70);
	line-height: 1.7;
	margin-bottom: var(--spacing-md);
	flex-grow: 1;
}

.offering-deliverables {
	list-style: none;
	padding: 0;
	margin: var(--spacing-lg) 0 0;
	border-top: 2px solid var(--tws-ink-10);
	padding-top: var(--spacing-md);
}

.offering-deliverables li {
	padding: var(--spacing-xs) 0 var(--spacing-xs) var(--spacing-lg);
	position: relative;
	font-size: 0.9375rem;
	color: var(--tws-ink-70);
	line-height: 1.6;
}

.offering-deliverables li::before {
	content: '•';
	position: absolute;
	left: 0;
	color: var(--tws-orange);
	font-weight: 700;
	font-size: 1.2rem;
}

/* Process Timeline (Strategy Page) */
.process-timeline {
	max-width: 900px;
	margin: var(--spacing-3xl) auto 0;
	position: relative;
	padding-left: var(--spacing-3xl);
}

.process-timeline::before {
	content: '';
	position: absolute;
	left: 30px;
	top: 0;
	bottom: 0;
	width: 3px;
	background: linear-gradient(to bottom, var(--tws-orange), var(--tws-ink-20));
}

.process-phase {
	position: relative;
	padding: 0 0 var(--spacing-2xl) var(--spacing-xl);
}

.process-phase:last-child {
	padding-bottom: 0;
}

.process-phase__marker {
	position: absolute;
	left: -53px;
	top: 0;
	width: 64px;
	height: 64px;
	border-radius: 50%;
	background: linear-gradient(135deg, var(--tws-orange) 0%, #ff8534 100%);
	display: flex;
	align-items: center;
	justify-content: center;
	box-shadow: 0 0 0 6px var(--tws-bg-alt), var(--shadow-md);
	transition: all var(--transition-base);
}

.process-phase:hover .process-phase__marker {
	transform: scale(1.1);
	box-shadow: 0 0 0 6px var(--tws-bg-alt), var(--shadow-lg);
}

.process-phase__number {
	font-size: 1.75rem;
	font-weight: 700;
	color: var(--tws-white);
	font-family: var(--font-highrise);
}

.process-phase__content {
	background-color: var(--tws-white);
	padding: var(--spacing-xl);
	border-radius: var(--radius-md);
	border: 2px solid var(--tws-ink-10);
	transition: all var(--transition-base);
}

.process-phase:hover .process-phase__content {
	border-color: var(--tws-orange);
	box-shadow: var(--shadow-md);
}

.process-phase__content h3 {
	color: var(--tws-orange);
	margin-top: 0;
	margin-bottom: var(--spacing-sm);
}

.process-phase__content p {
	color: var(--tws-ink-70);
	line-height: 1.7;
	margin-bottom: var(--spacing-sm);
}

.process-phase__duration {
	font-size: 0.875rem;
	color: var(--tws-orange);
	font-weight: 500;
	display: inline-block;
	padding: var(--spacing-xs) var(--spacing-sm);
	background-color: rgba(247, 104, 16, 0.1);
	border-radius: var(--radius-sm);
	margin-bottom: 0;
}

.process-note {
	max-width: 800px;
	margin: var(--spacing-3xl) auto 0;
	padding: var(--spacing-xl);
	background-color: var(--tws-white);
	border-radius: var(--radius-md);
	border-left: 4px solid var(--tws-orange);
}

/* Case Study Preview */
.case-study-preview {
	position: relative;
}

.featured-case-study {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--spacing-3xl);
	align-items: center;
	margin-top: var(--spacing-2xl);
	background: linear-gradient(135deg, var(--tws-white) 0%, var(--tws-bg-alt) 100%);
	padding: var(--spacing-3xl);
	border-radius: var(--radius-lg);
	border: 2px solid var(--tws-ink-10);
	box-shadow: var(--shadow-md);
	transition: all var(--transition-base);
	overflow: hidden;
	position: relative;
}

.featured-case-study::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 4px;
	background: linear-gradient(90deg, var(--tws-orange) 0%, #ff8534 100%);
	opacity: 0;
	transition: opacity var(--transition-base);
}

.featured-case-study:hover {
	border-color: var(--tws-orange);
	box-shadow: var(--shadow-lg);
	transform: translateY(-4px);
}

.featured-case-study:hover::before {
	opacity: 1;
}

.featured-case-study__image {
	position: relative;
	overflow: hidden;
	border-radius: var(--radius-lg);
	box-shadow: var(--shadow-md);
	aspect-ratio: 4 / 3;
}

.featured-case-study__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	border-radius: var(--radius-lg);
	transition: transform var(--transition-slow);
}

.featured-case-study:hover .featured-case-study__image img {
	transform: scale(1.05);
}

.featured-case-study__content {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-lg);
}

.featured-case-study h3 {
	margin: 0;
	color: var(--tws-ink);
	font-size: clamp(1.75rem, 3vw, 2.25rem);
}

.featured-case-study__content > p.h5 {
	margin: 0;
	font-size: 1.125rem;
}

.featured-case-study__content > p:not(.h5):not(.stat-label) {
	color: var(--tws-ink-70);
	line-height: 1.7;
	margin: 0;
}

/* Featured Case Study Stats */
.featured-case-study .case-study-stats {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--spacing-lg);
	margin: var(--spacing-lg) 0;
	padding: var(--spacing-xl);
	background-color: var(--tws-white);
	border-radius: var(--radius-md);
	border: 2px solid var(--tws-ink-10);
	box-shadow: var(--shadow-sm);
}

.featured-case-study .stat-item {
	text-align: center;
}

.featured-case-study .stat-value {
	display: block;
	font-family: var(--font-highrise);
	font-size: 2.5rem;
	font-weight: 700;
	color: var(--tws-orange);
	line-height: 1;
	margin-bottom: var(--spacing-sm);
	text-shadow: 0 2px 4px rgba(247, 104, 16, 0.1);
}

.featured-case-study .stat-label {
	display: block;
	font-size: 0.875rem;
	color: var(--tws-ink-70);
	line-height: 1.4;
}

.text-orange {
	color: var(--tws-orange);
}

/* Writing Principles Section */
.principles-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
	gap: var(--spacing-xl);
	margin-top: var(--spacing-2xl);
}

.principle-item {
	background-color: var(--tws-white);
	padding: var(--spacing-xl);
	border-radius: var(--radius-md);
	border: 2px solid var(--tws-ink-10);
	transition: all var(--transition-base);
	position: relative;
	padding-top: calc(var(--spacing-3xl) + var(--spacing-md));
}

.principle-item:hover {
	border-color: var(--tws-orange);
	box-shadow: var(--shadow-md);
	transform: translateY(-4px);
}

.principle-number {
	position: absolute;
	top: var(--spacing-lg);
	left: var(--spacing-xl);
	width: 48px;
	height: 48px;
	border-radius: 50%;
	background: linear-gradient(135deg, var(--tws-orange) 0%, #ff8534 100%);
	color: var(--tws-white);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 1.5rem;
	font-weight: 700;
	font-family: var(--font-highrise);
	box-shadow: var(--shadow-sm);
	transition: all var(--transition-base);
}

.principle-item:hover .principle-number {
	transform: scale(1.15);
}

.principle-item h3 {
	color: var(--tws-orange);
	margin-top: 0;
	margin-bottom: var(--spacing-sm);
}

.principle-item p {
	color: var(--tws-ink-70);
	line-height: 1.7;
	margin: 0;
}

/* Work Samples Section */
.samples-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
	gap: var(--spacing-2xl);
	margin-top: var(--spacing-2xl);
}

.sample-card {
	background-color: var(--tws-white);
	border-radius: var(--radius-lg);
	overflow: hidden;
	border: 2px solid var(--tws-ink-10);
	transition: all var(--transition-base);
	display: flex;
	flex-direction: column;
}

.sample-card:hover {
	border-color: var(--tws-orange);
	box-shadow: var(--shadow-lg);
	transform: translateY(-4px);
}

.sample-card__image {
	position: relative;
	overflow: hidden;
	aspect-ratio: 3 / 2;
}

.sample-card__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform var(--transition-slow);
}

.sample-card:hover .sample-card__image img {
	transform: scale(1.05);
}

.sample-card__content {
	padding: var(--spacing-xl);
	display: flex;
	flex-direction: column;
	flex-grow: 1;
}

.sample-tag {
	display: inline-block;
	padding: var(--spacing-xs) var(--spacing-sm);
	background: linear-gradient(135deg, var(--tws-orange) 0%, #ff8534 100%);
	color: var(--tws-white);
	border-radius: var(--radius-sm);
	font-size: 0.75rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	margin-bottom: var(--spacing-md);
	align-self: flex-start;
}

.sample-card h3 {
	color: var(--tws-ink);
	margin-bottom: var(--spacing-sm);
}

.sample-card p {
	color: var(--tws-ink-70);
	line-height: 1.7;
	margin-bottom: var(--spacing-lg);
	flex-grow: 1;
}

/* Featured Testimonial */
.featured-testimonial {
	max-width: 900px;
	margin: 0 auto;
	background-color: var(--tws-white);
	padding: var(--spacing-3xl);
	border-radius: var(--radius-lg);
	border: 2px solid var(--tws-orange);
	box-shadow: var(--shadow-lg);
	position: relative;
}

.featured-testimonial::before {
	content: '"';
	position: absolute;
	top: var(--spacing-lg);
	left: var(--spacing-xl);
	font-size: 6rem;
	line-height: 1;
	color: var(--tws-orange);
	opacity: 0.2;
	font-family: Georgia, serif;
}

.featured-testimonial__quote {
	position: relative;
	z-index: 1;
}

.featured-testimonial__quote p {
	font-size: 1.25rem;
	line-height: 1.8;
	color: var(--tws-ink);
	margin: 0;
	font-style: italic;
}

.featured-testimonial__author {
	display: flex;
	align-items: center;
	gap: var(--spacing-md);
	margin-top: var(--spacing-xl);
	padding-top: var(--spacing-xl);
	border-top: 2px solid var(--tws-ink-10);
}

.featured-testimonial__author img {
	width: auto;
	height: 100px;
	border-radius: var(--radius-sm);
	object-fit: cover;
	border: 3px solid var(--tws-orange);
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}

.featured-testimonial__author strong {
	display: block;
	color: var(--tws-orange);
	font-size: 1.125rem;
	margin-bottom: var(--spacing-xs);
}

.featured-testimonial__author span {
	display: block;
	color: var(--tws-ink-70);
	font-size: 0.9375rem;
}

/* Strategy & Writing Pages Responsive */
@media (max-width: 900px) {
	.service-hero .container {
		grid-template-columns: 1fr;
		gap: var(--spacing-2xl);
	}

	.service-hero__image {
		order: -1;
	}

	.featured-case-study {
		grid-template-columns: 1fr;
		padding: var(--spacing-2xl);
		gap: var(--spacing-2xl);
	}

	.featured-case-study__image {
		order: -1;
	}

	.featured-case-study .case-study-stats {
		grid-template-columns: repeat(3, 1fr);
		gap: var(--spacing-md);
		padding: var(--spacing-lg);
	}

	.featured-case-study .stat-value {
		font-size: 2rem;
	}

	.process-timeline {
		padding-left: var(--spacing-2xl);
	}

	.process-phase__marker {
		width: 48px;
		height: 48px;
		left: -41px;
	}

	.process-phase__number {
		font-size: 1.25rem;
	}
}

@media (max-width: 768px) {
	.offerings-grid {
		grid-template-columns: 1fr;
	}

	.principles-grid {
		grid-template-columns: 1fr;
	}

	.samples-grid {
		grid-template-columns: 1fr;
	}

	.featured-case-study {
		padding: var(--spacing-xl);
	}

	.featured-case-study .case-study-stats {
		grid-template-columns: 1fr;
		gap: var(--spacing-lg);
	}

	.featured-case-study .stat-value {
		font-size: 2.25rem;
	}

	.featured-testimonial {
		padding: var(--spacing-xl);
	}

	.featured-testimonial::before {
		font-size: 4rem;
	}

	.featured-testimonial__quote p {
		font-size: 1.125rem;
	}

	.process-timeline {
		padding-left: var(--spacing-xl);
	}

	.process-phase {
		padding-left: var(--spacing-md);
	}

	.process-phase__marker {
		width: 40px;
		height: 40px;
		left: -34px;
	}

	.process-phase__number {
		font-size: 1.125rem;
	}
}

/* ==========================================================================
   Services Page Enhancements
   ========================================================================== */

/* Process Steps */
.process-steps {
	display: grid;
	gap: var(--spacing-xl);
	margin-top: var(--spacing-2xl);
	max-width: 900px;
	margin-left: auto;
	margin-right: auto;
}

.process-step {
	display: flex;
	gap: var(--spacing-lg);
	align-items: flex-start;
	background-color: var(--tws-white);
	padding: var(--spacing-xl);
	border-radius: var(--radius-md);
	border: 2px solid var(--tws-ink-10);
	transition: all var(--transition-base);
	position: relative;
}

.process-step:hover {
	border-color: var(--tws-orange);
	box-shadow: var(--shadow-md);
	transform: translateX(8px);
}

.process-step__number {
	width: 56px;
	height: 56px;
	border-radius: 50%;
	background: linear-gradient(135deg, var(--tws-orange) 0%, #ff8534 100%);
	color: var(--tws-white);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 1.5rem;
	font-weight: 700;
	font-family: var(--font-highrise);
	flex-shrink: 0;
	box-shadow: var(--shadow-sm);
	transition: all var(--transition-base);
}

.process-step:hover .process-step__number {
	transform: scale(1.1);
	box-shadow: var(--shadow-md);
}

.process-step__content {
	flex: 1;
}

.process-step__content h3 {
	color: var(--tws-orange);
	margin-top: 0;
	margin-bottom: var(--spacing-sm);
}

.process-step__content p {
	color: var(--tws-ink-70);
	line-height: 1.7;
	margin: 0;
}

/* Enhanced Service Cards */
.services-grid--large .service-card {
	transition: all var(--transition-base);
}

.services-grid--large .service-card:hover {
	transform: translateY(-4px);
}

.service-card--featured .service-card__icon {
	background: linear-gradient(135deg, var(--tws-orange) 0%, #ff8534 100%);
	border-radius: var(--radius-md);
	display: flex;
	align-items: center;
	justify-content: center;
	transition: all var(--transition-base);
}

.service-card--featured:hover .service-card__icon {
	transform: rotate(5deg) scale(1.05);
}

.service-card--featured .service-card__icon svg {
	width: 32px;
	height: 32px;
	fill: var(--tws-white);
}

/* Enhanced Industry Items */
.industries-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
	gap: var(--spacing-xl);
	margin-top: var(--spacing-2xl);
}

.industry-item {
	transition: all var(--transition-base);
	border: 2px solid transparent;
	cursor: default;
}

.industry-item:hover {
	background-color: var(--tws-white);
	border-color: var(--tws-orange);
	box-shadow: var(--shadow-md);
	transform: translateY(-4px);
}

.industry-icon {
	width: 56px;
	height: 56px;
	margin: 0 auto var(--spacing-md);
	background: linear-gradient(135deg, var(--tws-orange) 0%, #ff8534 100%);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: all var(--transition-base);
}

.industry-item:hover .industry-icon {
	transform: scale(1.1) rotate(5deg);
}

.industry-icon svg {
	width: 28px;
	height: 28px;
	fill: var(--tws-white);
}

.industry-item h3 {
	color: var(--tws-orange);
	margin-bottom: var(--spacing-xs);
}

.industry-item p {
	color: var(--tws-ink-70);
	margin: 0;
	font-size: 0.9375rem;
	line-height: 1.6;
}

/* Services Page Responsive */
@media (max-width: 768px) {
	.process-step {
		flex-direction: column;
		text-align: center;
		padding: var(--spacing-lg);
	}

	.process-step__number {
		margin: 0 auto var(--spacing-md);
	}

	.industries-grid {
		grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
	}
}

/* ==========================================================================
   Work Portfolio Page Styles
   ========================================================================== */

/* Work Filters */
.work-filters {
	background-color: var(--tws-bg-alt);
	padding: var(--spacing-xl) 0;
	border-bottom: 2px solid var(--tws-ink-10);
}

.filters-bar {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-lg);
}

.filters-group {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: var(--spacing-sm);
}

.filter-label {
	font-weight: 600;
	color: var(--tws-ink);
	margin-right: var(--spacing-sm);
	font-size: 0.9375rem;
}

.filter-btn {
	padding: var(--spacing-xs) var(--spacing-md);
	background-color: var(--tws-white);
	border: 2px solid var(--tws-ink-10);
	border-radius: var(--radius-md);
	color: var(--tws-ink-70);
	font-size: 0.875rem;
	font-weight: 500;
	cursor: pointer;
	transition: all var(--transition-base);
	font-family: var(--font-roboto);
}

.filter-btn:hover {
	border-color: var(--tws-orange);
	color: var(--tws-orange);
	transform: translateY(-2px);
	box-shadow: var(--shadow-sm);
}

.filter-btn.active {
	background: linear-gradient(135deg, var(--tws-orange) 0%, #ff8534 100%);
	border-color: var(--tws-orange);
	color: var(--tws-white);
	box-shadow: var(--shadow-sm);
}

.filter-btn.active:hover {
	transform: translateY(-2px);
	box-shadow: var(--shadow-md);
}

/* Work Grid */
.work-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(360px, 1fr));
	gap: var(--spacing-2xl);
}

/* Work Cards */
.work-card {
	background-color: var(--tws-white);
	border-radius: var(--radius-lg);
	overflow: hidden;
	border: 2px solid var(--tws-ink-10);
	transition: all var(--transition-base);
	display: flex;
	flex-direction: column;
	height: 100%;
}

.work-card:hover {
	border-color: var(--tws-orange);
	box-shadow: var(--shadow-lg);
	transform: translateY(-8px);
}

.work-card__link {
	display: flex;
	flex-direction: column;
	height: 100%;
	text-decoration: none;
	color: inherit;
}

.work-card__image {
	position: relative;
	overflow: hidden;
	aspect-ratio: 4 / 3;
	background-color: var(--tws-ink);
}

.work-card__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform var(--transition-slow);
}

.work-card:hover .work-card__image img {
	transform: scale(1.08);
}

.work-card__content {
	padding: var(--spacing-xl);
	display: flex;
	flex-direction: column;
	flex-grow: 1;
}

.work-card__meta {
	display: flex;
	flex-wrap: wrap;
	gap: var(--spacing-xs);
	margin-bottom: var(--spacing-md);
}

.work-tag {
	display: inline-block;
	padding: var(--spacing-xs) var(--spacing-sm);
	background-color: var(--tws-bg-alt);
	color: var(--tws-ink-70);
	border-radius: var(--radius-sm);
	font-size: 0.75rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	transition: all var(--transition-base);
}

.work-card:hover .work-tag {
	background: linear-gradient(135deg, var(--tws-orange) 0%, #ff8534 100%);
	color: var(--tws-white);
}

.work-card__title {
	font-size: 1.5rem;
	font-weight: 700;
	color: var(--tws-ink);
	margin: 0 0 var(--spacing-sm);
	line-height: 1.3;
	font-family: var(--font-highrise);
	transition: color var(--transition-base);
}

.work-card:hover .work-card__title {
	color: var(--tws-orange);
}

.work-card__excerpt {
	color: var(--tws-ink-70);
	line-height: 1.7;
	margin-bottom: var(--spacing-lg);
	flex-grow: 1;
}

.work-card__stats {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-xs);
	padding-top: var(--spacing-md);
	border-top: 2px solid var(--tws-ink-10);
	margin-top: auto;
}

.work-card__stats .stat-item {
	font-size: 0.875rem;
	color: var(--tws-ink-70);
	line-height: 1.5;
}

.work-card__stats .stat-item strong {
	color: var(--tws-orange);
	font-weight: 700;
	font-size: 1rem;
}

/* No Results Message */
.no-results {
	text-align: center;
	padding: var(--spacing-3xl);
	background-color: var(--tws-bg-alt);
	border-radius: var(--radius-lg);
	margin-top: var(--spacing-2xl);
}

.no-results p {
	font-size: 1.125rem;
	color: var(--tws-ink-70);
	margin-bottom: var(--spacing-md);
}

/* Work Page Responsive */
@media (max-width: 1024px) {
	.work-grid {
		grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
		gap: var(--spacing-xl);
	}
}

@media (max-width: 768px) {
	.work-filters {
		padding: var(--spacing-md) 0;
	}

	.filters-bar {
		gap: var(--spacing-md);
	}

	.filters-group {
		flex-direction: column;
		align-items: flex-start;
		width: 100%;
	}

	.filter-label {
		width: 100%;
		margin-bottom: var(--spacing-xs);
	}

	.work-grid {
		grid-template-columns: 1fr;
		gap: var(--spacing-lg);
	}

	.work-card__content {
		padding: var(--spacing-lg);
	}
}

@media (max-width: 480px) {
	.filter-btn {
		font-size: 0.8125rem;
		padding: var(--spacing-xs) var(--spacing-sm);
	}
}

/* ==========================================================================
   Case Study Detail Page Styles
   ========================================================================== */

/* Breadcrumb Navigation */
.breadcrumb {
	margin-bottom: var(--spacing-xl);
}

.breadcrumb ol {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: var(--spacing-sm);
	list-style: none;
	margin: 0;
	padding: 0;
	font-size: 0.875rem;
}

.breadcrumb li {
	display: flex;
	align-items: center;
}

.breadcrumb li:not(:last-child)::after {
	content: '/';
	margin-left: var(--spacing-sm);
	color: var(--tws-ink-40);
}

.breadcrumb a {
	color: var(--tws-ink-70);
	transition: color var(--transition-base);
}

.breadcrumb a:hover {
	color: var(--tws-orange);
}

.breadcrumb li[aria-current="page"] {
	color: var(--tws-ink);
	font-weight: 500;
}

/* Case Study Hero Section */
.case-study-hero {
	padding: var(--spacing-3xl) 0;
	background: linear-gradient(to bottom, var(--tws-bg-alt) 0%, var(--tws-white) 100%);
}

.case-study-hero__content {
	margin-bottom: var(--spacing-3xl);
}

.case-study-meta {
	display: flex;
	flex-wrap: wrap;
	gap: var(--spacing-sm);
	margin-bottom: var(--spacing-lg);
}

.case-tag {
	display: inline-flex;
	align-items: center;
	padding: var(--spacing-xs) var(--spacing-md);
	background: linear-gradient(135deg, var(--tws-orange) 0%, #ff8534 100%);
	color: var(--tws-white);
	border-radius: 50px;
	font-size: 0.75rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	box-shadow: 0 2px 8px rgba(247, 104, 16, 0.2);
	transition: all var(--transition-base);
}

.case-tag:hover {
	transform: translateY(-2px);
	box-shadow: 0 4px 12px rgba(247, 104, 16, 0.3);
}

/* Case Study Details Grid */
.case-study-details {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
	gap: var(--spacing-lg);
	margin-top: var(--spacing-xl);
	padding: var(--spacing-xl);
	background-color: var(--tws-white);
	border-radius: var(--radius-lg);
	border: 2px solid var(--tws-ink-10);
	box-shadow: var(--shadow-sm);
}

.detail-item {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-xs);
}

.detail-label {
	font-size: 0.8125rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	color: var(--tws-ink-70);
}

.detail-value {
	font-size: 1.125rem;
	font-weight: 600;
	color: var(--tws-ink);
}

/* Case Study Hero Image */
.case-study-hero__image {
	position: relative;
	overflow: hidden;
	border-radius: var(--radius-lg);
	box-shadow: var(--shadow-lg);
	aspect-ratio: 3 / 2;
}

.case-study-hero__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform var(--transition-slow);
}

.case-study-hero__image:hover img {
	transform: scale(1.05);
}

/* Stats Grid */
.case-study-stats {
	background: linear-gradient(135deg, var(--tws-ink) 0%, #3a3638 100%);
	color: var(--tws-white);
}

.stats-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
	gap: var(--spacing-2xl);
}

.stat-card {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	padding: var(--spacing-xl);
	background-color: rgba(255, 255, 255, 0.05);
	border-radius: var(--radius-lg);
	border: 2px solid rgba(255, 255, 255, 0.1);
	transition: all var(--transition-base);
	position: relative;
	overflow: hidden;
}

.stat-card::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 4px;
	background: linear-gradient(90deg, var(--tws-orange) 0%, #ff8534 100%);
	opacity: 0;
	transition: opacity var(--transition-base);
}

.stat-card:hover {
	background-color: rgba(255, 255, 255, 0.08);
	border-color: var(--tws-orange);
	transform: translateY(-8px);
	box-shadow: 0 12px 24px rgba(0, 0, 0, 0.3);
}

.stat-card:hover::before {
	opacity: 1;
}

.stat-value {
	font-family: var(--font-highrise);
	font-size: clamp(2.5rem, 5vw, 4rem);
	font-weight: 700;
	color: var(--tws-orange);
	line-height: 1;
	margin-bottom: var(--spacing-md);
	display: block;
	text-shadow: 0 2px 8px rgba(247, 104, 16, 0.3);
}

.stat-label {
	font-size: 0.9375rem;
	line-height: 1.5;
	color: rgba(255, 255, 255, 0.9);
	font-weight: 500;
}

/* Case Study Section */
.case-study-section {
	position: relative;
}

.case-study-content {
	max-width: 900px;
	margin: 0 auto;
}

.case-study-content p {
	font-size: 1.0625rem;
	line-height: 1.8;
	margin-bottom: var(--spacing-lg);
	color: var(--tws-ink);
}

.case-study-content h3 {
	margin-top: var(--spacing-2xl);
	margin-bottom: var(--spacing-lg);
}

.case-study-content ul {
	margin: var(--spacing-lg) 0;
	padding-left: var(--spacing-xl);
}

.case-study-content ul li {
	font-size: 1.0625rem;
	line-height: 1.8;
	margin-bottom: var(--spacing-sm);
	position: relative;
}

.case-study-content ul li::marker {
	color: var(--tws-orange);
}

/* Case Study Objectives Box */
.case-study-objectives {
	margin-top: var(--spacing-2xl);
	padding: var(--spacing-xl);
	background-color: var(--tws-bg-alt);
	border-left: 4px solid var(--tws-orange);
	border-radius: var(--radius-md);
}

.case-study-objectives h3 {
	margin-top: 0;
	color: var(--tws-orange);
}

.case-study-objectives ul {
	margin-bottom: 0;
}

/* Case Study Insight Box */
.case-study-insight {
	margin: var(--spacing-2xl) 0;
	padding: var(--spacing-2xl);
	background: linear-gradient(135deg, var(--tws-orange) 0%, #ff8534 100%);
	color: var(--tws-white);
	border-radius: var(--radius-lg);
	box-shadow: 0 8px 24px rgba(247, 104, 16, 0.25);
	position: relative;
	overflow: hidden;
}

.case-study-insight::before {
	content: '"';
	position: absolute;
	top: -20px;
	left: var(--spacing-lg);
	font-size: 12rem;
	font-family: Georgia, serif;
	color: rgba(255, 255, 255, 0.1);
	line-height: 1;
	z-index: 0;
}

.case-study-insight h4 {
	position: relative;
	z-index: 1;
	margin-top: 0;
	color: var(--tws-white);
	font-size: 1.25rem;
	margin-bottom: var(--spacing-md);
}

.case-study-insight p {
	position: relative;
	z-index: 1;
	font-size: 1.125rem;
	line-height: 1.7;
	margin-bottom: 0;
	color: var(--tws-white);
}

/* Case Study Quote */
.case-study-quote {
	margin: var(--spacing-3xl) 0;
	text-align: center;
}

.case-study-quote blockquote {
	margin: 0;
	padding: var(--spacing-2xl);
	position: relative;
}

.case-study-quote p {
	font-family: var(--font-highrise);
	font-size: clamp(1.25rem, 3vw, 1.75rem);
	line-height: 1.6;
	color: var(--tws-ink);
	font-style: italic;
	font-weight: 400;
	margin: 0;
	position: relative;
	text-transform: none;
}

.case-study-quote p::before {
	content: '\201C';
	font-size: 4rem;
	color: var(--tws-orange);
	position: absolute;
	top: -1.5rem;
	left: -1rem;
	font-family: Georgia, serif;
	line-height: 1;
}

/* Execution Grid */
.execution-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: var(--spacing-xl);
	margin-top: var(--spacing-2xl);
}

.execution-item {
	padding: var(--spacing-xl);
	background-color: var(--tws-white);
	border-radius: var(--radius-lg);
	border: 2px solid var(--tws-ink-10);
	transition: all var(--transition-base);
}

.execution-item:hover {
	border-color: var(--tws-orange);
	box-shadow: var(--shadow-md);
	transform: translateY(-4px);
}

.execution-item h3 {
	margin-top: 0;
	color: var(--tws-orange);
	font-size: 1.25rem;
}

.execution-item p {
	margin-bottom: 0;
	font-size: 1rem;
}

/* Impact Grid */
.impact-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
	gap: var(--spacing-2xl);
	margin-top: var(--spacing-2xl);
}

.impact-item {
	padding: var(--spacing-2xl);
	background-color: var(--tws-white);
	border-radius: var(--radius-lg);
	border: 2px solid var(--tws-ink-10);
	box-shadow: var(--shadow-sm);
	transition: all var(--transition-base);
}

.impact-item:hover {
	border-color: var(--tws-orange);
	box-shadow: var(--shadow-lg);
	transform: translateY(-6px);
}

.impact-item h3 {
	margin-top: 0;
	color: var(--tws-orange);
	border-bottom: 3px solid var(--tws-orange);
	padding-bottom: var(--spacing-md);
	margin-bottom: var(--spacing-lg);
}

.impact-item ul {
	margin: 0;
	padding-left: var(--spacing-lg);
}

.impact-item li {
	margin-bottom: var(--spacing-md);
	line-height: 1.6;
}

.impact-item li:last-child {
	margin-bottom: 0;
}

.impact-item strong {
	color: var(--tws-orange);
	font-weight: 700;
}

/* Deliverables Grid */
.deliverables-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
	gap: var(--spacing-lg);
	margin-top: var(--spacing-2xl);
}

.deliverable-item {
	padding: var(--spacing-xl);
	background-color: var(--tws-bg-alt);
	border-radius: var(--radius-lg);
	border-left: 4px solid var(--tws-orange);
	transition: all var(--transition-base);
}

.deliverable-item:hover {
	background-color: var(--tws-white);
	box-shadow: var(--shadow-md);
	transform: translateX(8px);
}

.deliverable-item h3 {
	margin-top: 0;
	font-size: 1.125rem;
	color: var(--tws-ink);
}

.deliverable-item p {
	margin-bottom: 0;
	font-size: 0.9375rem;
	line-height: 1.6;
}

/* Featured Testimonial - Case Study Version */
.case-study-testimonial {
	background: linear-gradient(135deg, var(--tws-ink) 0%, #3a3638 100%);
	color: var(--tws-white);
}

.case-study-testimonial .featured-testimonial {
	max-width: 900px;
	margin: 0 auto;
	padding: var(--spacing-3xl);
	background-color: rgba(255, 255, 255, 0.05);
	border-radius: var(--radius-lg);
	border: 2px solid rgba(255, 255, 255, 0.1);
	box-shadow: 0 8px 32px rgba(0, 0, 0, 0.3);
}

.case-study-testimonial .featured-testimonial__quote {
	margin-bottom: var(--spacing-xl);
	position: relative;
}

.case-study-testimonial .featured-testimonial__quote::before {
	content: '\201C';
	font-size: 6rem;
	color: var(--tws-orange);
	position: absolute;
	top: -2rem;
	left: -1rem;
	font-family: Georgia, serif;
	line-height: 1;
	opacity: 0.5;
}

.case-study-testimonial .featured-testimonial__quote p {
	font-size: 1.25rem;
	line-height: 1.7;
	color: var(--tws-white);
	font-style: italic;
	margin: 0;
	position: relative;
	z-index: 1;
}

.case-study-testimonial .featured-testimonial__author {
	display: flex;
	align-items: center;
	gap: var(--spacing-lg);
	padding-top: var(--spacing-lg);
	border-top: 2px solid rgba(255, 255, 255, 0.1);
}

.case-study-testimonial .featured-testimonial__author img {
	width: auto;
	height: 100px;
	border-radius: var(--radius-sm);
	border: 3px solid var(--tws-orange);
	object-fit: cover;
	box-shadow: 0 4px 16px rgba(247, 104, 16, 0.3);
}

.case-study-testimonial .featured-testimonial__author strong {
	display: block;
	font-family: var(--font-highrise);
	font-size: 1.25rem;
	color: var(--tws-orange);
	margin-bottom: var(--spacing-xs);
}

.case-study-testimonial .featured-testimonial__author span {
	display: block;
	font-size: 0.9375rem;
	color: rgba(255, 255, 255, 0.8);
}

/* Related Projects */
.next-project {
	background-color: var(--tws-bg-alt);
}

.related-projects {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
	gap: var(--spacing-2xl);
	margin-top: var(--spacing-2xl);
}

/* Responsive Adjustments */
@media (max-width: 1024px) {
	.stats-grid {
		grid-template-columns: repeat(2, 1fr);
		gap: var(--spacing-xl);
	}

	.impact-grid {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 768px) {
	.case-study-hero {
		padding: var(--spacing-2xl) 0;
	}

	.case-study-details {
		grid-template-columns: 1fr;
		gap: var(--spacing-md);
		padding: var(--spacing-lg);
	}

	.stats-grid {
		grid-template-columns: 1fr;
		gap: var(--spacing-lg);
	}

	.stat-card {
		padding: var(--spacing-lg);
	}

	.case-study-content {
		padding: 0 var(--spacing-sm);
	}

	.execution-grid {
		grid-template-columns: 1fr;
		gap: var(--spacing-lg);
	}

	.deliverables-grid {
		grid-template-columns: 1fr;
	}

	.case-study-testimonial .featured-testimonial {
		padding: var(--spacing-xl);
	}

	.case-study-testimonial .featured-testimonial__quote::before {
		font-size: 4rem;
		top: -1rem;
	}

	.case-study-testimonial .featured-testimonial__quote p {
		font-size: 1.0625rem;
	}

	.case-study-testimonial .featured-testimonial__author {
		flex-direction: column;
		text-align: center;
		gap: var(--spacing-md);
	}

	.related-projects {
		grid-template-columns: 1fr;
		gap: var(--spacing-lg);
	}
}

@media (max-width: 480px) {
	.case-study-meta {
		gap: var(--spacing-xs);
	}

	.case-tag {
		font-size: 0.6875rem;
		padding: 6px 12px;
	}

	.stat-value {
		font-size: 2.5rem;
	}

	.case-study-insight {
		padding: var(--spacing-lg);
	}

	.case-study-insight::before {
		font-size: 8rem;
	}

	.case-study-quote p::before {
		font-size: 3rem;
		top: -1rem;
		left: -0.5rem;
	}

	.execution-item,
	.deliverable-item {
		padding: var(--spacing-lg);
	}

	.impact-item {
		padding: var(--spacing-lg);
	}
}

/* ==========================================================================
   Print Styles
   ========================================================================== */

@media print {
	*,
	*::before,
	*::after {
		background: transparent !important;
		color: #000 !important;
		box-shadow: none !important;
		text-shadow: none !important;
	}

	a,
	a:visited {
		text-decoration: underline;
	}

	a[href]::after {
		content: " (" attr(href) ")";
	}

	img {
		page-break-inside: avoid;
		max-width: 100% !important;
	}

	h2,
	h3 {
		page-break-after: avoid;
	}

	.site-header,
	.site-footer,
	.tws-hero__cta,
	.contact-form,
	.filters-panel {
		display: none;
	}
}


@font-face {
	font-family: "Mallians";
	src:
			url("../fonts/Mallians.woff2") format("woff2");
	font-weight: normal;
	font-style: normal;
	font-display: swap;
}

@font-face {
	font-family: "Highrise";
	src:
			url("../fonts/Highrise-Bold.woff2") format("woff2");
	font-weight: normal;
	font-style: normal;
	font-display: swap;
}
