/*
 * Theme Name: GS Custom Theme
 * Theme URI: https://github.com/your-org/gs-custom-theme
 * Description: Custom WordPress theme built with Timber and Twig.
 * Author: Your Name
 * Author URI: https://yoursite.com
 * Version: 1.0.0
 * License: GNU General Public License v2 or later
 * License URI: http://www.gnu.org/licenses/gpl-2.0.html
 * Text Domain: gs-custom-theme
*/

/* ==========================================================================
   CSS Variables (colors, typography, spacing, container)
   ========================================================================== */
:root {
	/* Colors */
	--color-bg: #000000;
	--color-bg-header: #0A192F;
	--color-bg-card: #0A192F;
	--color-text: #FFFFFF;
	--color-text-muted: #8892B0;
	--color-accent: #0080FF;
	--color-accent-blue: #3399FF;
	--color-border: #0080FF;
	--color-border-light: rgba(255, 255, 255, 0.15);

	/* Button gradient (sections only; header uses solid fill) */
	--gradient-primary: linear-gradient(180deg, #0080FF 0%, #002A57 100%);
	--gradient-primary-hover: linear-gradient(180deg, #1a8cff 0%, #003366 100%);

	/* Typography - clamp(min, preferred, max) for responsive */
	--font-primary: 'Jost', sans-serif;
	--font-secondary: 'Inter', sans-serif;
	--font-third: 'Poppins', sans-serif;

	/* Headings – all with clamp for responsive */
	--text-h1: clamp(2rem, 5vw, 3.5rem);
	--text-h2: clamp(1.5rem, 3.5vw, 2.5rem);
	--text-h3: clamp(1.25rem, 2.5vw, 1.75rem);
	--text-h4: clamp(1.125rem, 2.2vw, 1.5rem);
	--text-h5: clamp(1rem, 2vw, 1.25rem);
	--text-h6: clamp(0.9375rem, 1.8vw, 1.125rem);

	--text-body: clamp(0.9375rem, 1.5vw, 1rem);
	--text-small: clamp(0.8125rem, 1.2vw, 0.875rem);
	--text-nav: clamp(0.875rem, 1.2vw, 1rem);
	--text-btn: clamp(0.875rem, 1.2vw, 1rem);

	/* Paragraph font-size variants (p tag) – clamp for mobile responsive */
	--text-p-large: clamp(1.0625rem, 2.8vw, 1.375rem);   /* 17px–22px */
	--text-p-medium: clamp(1rem, 2.5vw, 1.25rem);         /* 16px–20px */
	--text-p-small: clamp(0.875rem, 2vw, 1.125rem);      /* 14px–18px */

	/* Case study page: H2 = 44px on big screens, intro = 16px with clamp */
	--case-study-h2: clamp(1.25rem, 4vw, 2.75rem);       /* 20px–44px (highlight + upcoming sections) */
	--case-study-h2-32: clamp(1.25rem, 3vw, 2rem);       /* 20px–32px (scope/impact section) */
	--case-study-h2-44: clamp(1.5rem, 4vw, 2.75rem);      /* 24px–44px (data viz section) */
	--case-study-h2-narrow: clamp(1.125rem, 2.5vw, 2rem); /* 18px–32px (content block + tags) */
	--case-study-intro: clamp(0.875rem, 2vw, 1rem);      /* 14px–16px */

	/* Line heights */
	--leading-tight: 1.2;
	--leading-snug: 1.375;
	--leading-normal: 1.6;
	--leading-relaxed: 1.75;

	/* Spacing */
	--space-xs: 0.25rem;
	--space-sm: 0.5rem;
	--space-md: 1rem;
	--space-lg: 1.5rem;
	--space-xl: 2rem;
	--space-2xl: 3rem;
	--space-3xl: 4rem;
	--section-padding: clamp(3rem, 8vw, 5rem);

	/* Container: 1140px max-width, 15px left/right padding */
	--container-max: 1140px;
	--container-padding: 15px;
	--container: min(var(--container-max), 100% - (var(--container-padding) * 2));
	--container-margin: 0 auto;

	/* Border radius */
	--radius-sm: 4px;
	--radius-md: 8px;
	--radius-lg: 12px;
	--radius-xl: 16px;
	--radius-2xl: 24px;
	--radius-header: 16px;
}

/* Smooth scroll for section navigation (nav links with #anchor) */
html {
	scroll-behavior: smooth;
}

/* Offset scroll target so fixed header doesn’t cover section title */
[id]:target,
section[id] {
	scroll-margin-top: 100px;
}

/* ==========================================================================
   Base & typography
   ========================================================================== */
body {
	font-family: var(--font-secondary);
	font-size: var(--text-body);
	line-height: var(--leading-normal);
	color: var(--color-text);
	background-color: var(--color-bg);
	-webkit-font-smoothing: antialiased;
}

h1, .h1, .section-title--h1 {
	font-family: var(--font-primary);
	font-size: var(--text-h1);
	font-weight: 700;
	line-height: var(--leading-tight);
}

h2, .h2, .section-title {
	font-family: var(--font-primary);
	font-size: var(--text-h2);
	font-weight: 700;
	line-height: var(--leading-snug);
}

/* Section title alignment/size utility classes */
.section-title--center { text-align: center; }
.section-title--left { text-align: left; }
.section-title--right { text-align: right; }
.section-title--small { font-size: clamp(1.25rem, 2.5vw, 1.5rem); }
.section-title--large { font-size: clamp(2rem, 4vw, 3rem); }

/* Paragraph font-size variants (use on p or wrapper) */
.text-p-large { font-size: var(--text-p-large); }
.text-p-medium { font-size: var(--text-p-medium); }
.text-p-small { font-size: var(--text-p-small); }

h3, .h3 {
	font-family: var(--font-primary);
	font-size: var(--text-h3);
	font-weight: 600;
}

h4, .h4 {
	font-family: var(--font-primary);
	font-size: var(--text-h4);
	font-weight: 600;
	line-height: var(--leading-snug);
}

h5, .h5 {
	font-family: var(--font-primary);
	font-size: var(--text-h5);
	font-weight: 600;
	line-height: var(--leading-snug);
}

h6, .h6 {
	font-family: var(--font-primary);
	font-size: var(--text-h6);
	font-weight: 600;
	line-height: var(--leading-snug);
}

/* ==========================================================================
   Layout – container
   ========================================================================== */
.gs-container,
.header__inner,
.footer__inner {
	max-width: var(--container-max);
	margin: var(--container-margin);
	padding-left: var(--container-padding);
	padding-right: var(--container-padding);
}

/* ==========================================================================
   Skip link & accessibility
   ========================================================================== */
.skip-link {
	position: absolute;
	top: -100px;
	left: var(--container-padding);
	background: var(--color-accent-blue);
	color: var(--color-bg);
	padding: var(--space-md) var(--space-lg);
	z-index: 100000;
	font-size: var(--text-body);
	transition: top 0.2s;
}
.skip-link:focus {
	top: var(--space-md);
}

/* ==========================================================================
   Header (Part 1) – hide on scroll down, show on scroll up
   ========================================================================== */
.header {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	z-index: 1000;
	margin: 0;
	max-width: none;
	transition: transform 0.25s ease;
	padding: 20px 0 0 0;
	@media (max-width: 768px) {
		padding: 10px 20px 20px;
	}
}

.header--hidden {
	transform: translateY(-102%);
}

/* Reserve space so content is not under fixed header */
body {
	padding-top: 100px;
}

.header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: var(--space-lg);
	max-width: 980px;
	min-height: 70px;
    padding: 16px 20px;
	background-color: var(--color-bg-header);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-header) var(--radius-header);

}

.hdr-logo {
	margin: 0;
	font-size: var(--text-h3);
	font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
}

.hdr-logo-link {
	display: inline-flex;
	align-items: center;
	gap: var(--space-sm);
	text-decoration: none;
	color: var(--color-accent-blue);
	font-family: var(--font-primary);
}

.hdr-logo-img {
	display: block;
	width: 100%;
}

/* Nav: links + menu items with button classes */
.nav-main {
	display: flex;
	align-items: center;
	gap: var(--space-lg);
	flex-wrap: wrap;
}

.nav-main ul {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	align-items: center;
	gap: var(--space-sm);
}

.nav-main li {
	margin: 0;
}

.nav-main a {
	display: inline-block;
	text-decoration: none;
	color: var(--color-text);
	font-family: var(--font-secondary);
	font-size: var(--text-nav);
	padding: var(--space-sm) var(--space-md);
	transition: color 0.2s;
}

.nav-main a:hover {
	color: var(--color-accent);
}

/* Menu items as buttons: add CSS class in WP (e.g. btn-outline or btn-primary) */
.nav-main a.btn,
.btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: var(--space-sm);
	padding: var(--space-sm) var(--space-lg);
	border-radius: var(--radius-md);
	font-family: var(--font-third);
	font-size: var(--text-btn);
	font-weight: 500;
	text-decoration: none;
	cursor: pointer;
	transition: opacity 0.2s, background 0.2s, border-color 0.2s, color 0.2s;
}

/* Section buttons: icon inherits text color (hover included) */
.hero .btn svg,
.section-intro .btn svg,
.section-achievements .btn svg,
.home-section .btn svg {
	fill: currentColor;
	flex-shrink: 0;
}

/* Outline button (e.g. LinkedIn) */
.nav-main a.btn-outline,
.btn-outline {
	background: transparent;
	color: var(--color-text);
	border: 1px solid var(--color-text);
}

.nav-main a.btn-outline:hover,
.btn-outline:hover {
	background: rgba(255, 255, 255, 0.08);
	border-color: var(--color-accent);
	color: var(--color-accent);
}

/* Primary / gradient button (e.g. Download CV) */
/* Header buttons: solid fill (no gradient) */
.nav-main a.btn-primary,
.nav-main .btn-primary {
	background: #0080FF;
	color: var(--color-text);
	border: 1px solid  var(--color-accent);
}

.nav-main a.btn-primary:hover,
.nav-main .btn-primary:hover {
	background: #1a8cff;
	opacity: 0.95;
}

/* Hamburger button – visible only on mobile */
.hamburger {
	display: none;
	align-items: center;
	justify-content: center;
	width: 44px;
	height: 44px;
	padding: 0;
	margin: 0;
	background: transparent;
	border: none;
	cursor: pointer;
	color: var(--color-text);
	z-index: 1002;
	position: relative;
	flex-shrink: 0;
}

.hamburger:focus {
	outline: 2px solid var(--color-accent);
	outline-offset: 2px;
}

.hamburger__line {
	display: block;
	position: absolute;
	width: 22px;
	height: 2px;
	background-color: currentColor;
	border-radius: 1px;
	transition: transform 0.25s ease, opacity 0.25s ease;
}

.hamburger__line--1 { top: 14px; }
.hamburger__line--2 { top: 21px; }
.hamburger__line--3 { top: 28px; }

.hamburger[aria-expanded="true"] .hamburger__line--1 {
	top: 21px;
	transform: rotate(45deg);
}

.hamburger[aria-expanded="true"] .hamburger__line--2 {
	opacity: 0;
}

.hamburger[aria-expanded="true"] .hamburger__line--3 {
	top: 21px;
	transform: rotate(-45deg);
}

/* Mobile: show hamburger, nav as overlay drawer */
@media (max-width: 768px) {
	body{
		padding-top: 60px;
	}

	.header__inner {
		min-height: 40px;
		padding: 8px 16px;
	}

	.hdr-logo-img {
		max-width: 100px;
	}
	.hamburger {
		display: flex;
	}

	.nav-main {
		position: fixed;
		top: 0;
		right: 0;
		bottom: 0;
		width: min(320px, 85vw);
		max-width: 100%;
		background-color: var(--color-bg-header);
		border-left: 1px solid var(--color-border);
		flex-direction: column;
		align-items: stretch;
		justify-content: flex-start;
		padding: 90px var(--space-xl) var(--space-xl);
		gap: 0;
		transform: translateX(100%);
		visibility: hidden;
		transition: transform 0.3s ease, visibility 0.3s ease;
		z-index: 1001;
		box-shadow: -4px 0 24px rgba(0, 0, 0, 0.2);
	}

	.header.is-menu-open .nav-main {
		transform: translateX(0);
		visibility: visible;
	}

	.nav-main ul {
		flex-direction: column;
		align-items: stretch;
		gap: 0;
	}

	.nav-main li {
		border-bottom: 1px solid var(--color-border-light);
	}

	.nav-main a {
		display: block;
		padding: var(--space-md) var(--space-lg);
	}

	.nav-main li .btn{
		margin: 10px;
	}

	/* Backdrop when menu open */
	.header.is-menu-open .header__inner::before {
		content: "";
		position: fixed;
		inset: 0;
		background: rgba(0, 0, 0, 0.5);
		z-index: 1000;
	}
}

/* ==========================================================================
   Main content wrapper
   ========================================================================== */
.content-wrapper {
	padding-top: var(--space-lg);
	/* padding-bottom: var(--space-3xl); */
}

.content-wrapper .gs-container {
	max-width: var(--container-max);
}

/* ==========================================================================
   Buttons (gradient & outline) – used in hero and elsewhere
   ========================================================================== */
.btn-wrap {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-md);
}

.btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: var(--space-sm);
	padding: var(--space-md) var(--space-xl);
	border-radius: var(--radius-md);
	font-family: var(--font-third);
	font-size: var(--text-btn);
	font-weight: 500;
	text-decoration: none;
	cursor: pointer;
	transition: opacity 0.2s, background 0.2s, border-color 0.2s;
}

.btn-gradient {
	background: var(--gradient-primary);
	color: var(--color-text);
	border: none;
}

.btn-gradient:hover {
	background: var(--gradient-primary-hover);
	opacity: 0.95;
}

.btn-ghost {
	background: transparent;
	color: var(--color-text);
	border: 1px solid var(--color-text);
}

.btn-ghost:hover {
	background: rgba(255, 255, 255, 0.08);
	border-color: var(--color-accent);
	color: var(--color-accent);
}

/* ==========================================================================
   Hero section (Part 2 – three sub-sections)
   ========================================================================== */
.hero {
	padding: var(--section-padding) 0;
}

.hero__inner {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--space-2xl);
	align-items: center;
}

@media (max-width: 768px) {
	.hero__inner {
		grid-template-columns: 1fr;
		text-align: center;
	}
	.hero__actions { justify-content: center; }
}

.hero__greeting {
	font-size: var(--text-p-large);
	color: var(--color-text);
	margin-bottom: var(--space-sm);
    font-family: var(--font-secondary);
}

.hero__greeting .highlight,
.highlight,
.hero__greeting span {
	color: var(--color-accent-blue);
}

.hero__title {
	font-family: var(--font-primary);
	font-size: var(--text-h2);
	font-weight: 700;
	line-height: var(--leading-snug);
	color: var(--color-text);
	margin: 0 0 var(--space-lg);
}

.hero__actions {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-md);
}

/* Hero right: quote + image */
.hero__right {
	display: flex;
	flex-direction: column;
	gap: var(--space-lg);
}

.hero__quote-box {
	background: var(--color-bg-card);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	padding: var(--space-lg);
}

.hero__quote-text {
	font-size: var(--text-body);
	color: var(--color-text);
	margin: 0 0 var(--space-sm);
	font-style: italic;
}

.hero__quote-attribution {
	font-size: var(--text-small);
	color: var(--color-text-muted);
}

.hero__image-wrap {
	border-radius: var(--radius-lg);
	overflow: hidden;
	line-height: 0;
}

.hero__image-wrap img {
	width: 100%;
	height: auto;
	display: block;
}

/* ==========================================================================
   Intro / About section (section 2)
   ========================================================================== */
.section-intro {
	padding: 0;
	text-align: center;
}

.section-intro .gs-container {
	max-width: 946px;
}

.section-intro__text p{
	font-size: clamp(1.5rem, 3.2vw, 2rem);
	line-height: var(--leading-normal);
	color: var(--color-text);
    font-weight: 300;
    font-family: var(--font-secondary);
}

.section-intro__text p strong {
	/* color: var(--color-accent-blue); */
    font-weight: 600;
}

/* ==========================================================================
   About Me section – static design match
   ========================================================================== */
.section-about {
	padding: var(--section-padding) 0;
	text-align: center;
}

.section-about__heading {
	font-family: var(--font-secondary);
	font-size: var(--text-p-small);
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--color-accent);
	margin: 0 0 var(--space-2xl);
}

.section-about__hero {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	gap: var(--space-lg);
	margin-bottom: var(--space-lg);
	
}

.section-about__avatar-wrap {
	position: relative;
	width: 170px;
	height: 170px;
	border-radius: var(--radius-xl);
	border: 1px solid var(--color-accent);
	overflow: hidden;
	background: var(--color-bg-card);
	flex-shrink: 0;
}

.section-about__avatar {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.section-about__avatar-placeholder {
	display: none;
	font-size: var(--text-small);
	color: var(--color-text-muted);
	align-items: center;
	justify-content: center;
	position: absolute;
	inset: 0;
}

.section-about__avatar-wrap--placeholder .section-about__avatar {
	display: none;
}

.section-about__avatar-wrap--placeholder .section-about__avatar-placeholder {
	display: flex;
}

.section-about__title-block {
	min-width: 200px;
}

.section-about__title-line {
	font-family: var(--font-primary);
	font-size: clamp(1.5rem, 4vw, 2.8rem);
	font-weight: 700;
	color: var(--color-text);
	margin: 0 0 var(--space-md);
	line-height: var(--leading-tight);
}

.section-about__title-line--blue {
	color: var(--color-accent);
    font-weight: 400;
}

.section-about__bio {
	max-width: 720px;
	margin: 0 auto var(--space-2xl);
	font-size: var(--text-p-medium);
	line-height: var(--leading-relaxed);
	color: var(--color-text);
	text-align: center;
}

.section-about__thrive {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	gap: var(--space-lg);
	margin-bottom: var(--space-2xl);
}

.section-about__thrive-label {
	font-family: var(--font-secondary);
	font-size: var(--text-p-large);
	font-weight: 400;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--color-text);
}

.section-about__thrive-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--space-md);
}

.section-about__pill {
	display: flex;
	align-items: center;
	justify-content: center;
	padding: var(--space-md) var(--space-xl);
	font-family: var(--font-primary);
	font-size: var(--text-p-large);
	font-weight: 300;
	color: var(--color-text);
	background: linear-gradient(180deg, rgba(0, 128, 255, 0.15) 0%, rgba(0, 42, 87, 0.4) 100%);
	border: 1px solid var(--color-border);
	border-radius: 6px;
	
	@media (min-width: 567px){
    	min-width: 160px;
	}
}

.section-about__beyond {
	font-family: var(--font-secondary);
	font-size: var(--text-p-large);
	font-weight: 400;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--color-text);
}

.section-about__footer-statement {
	font-size: var(--text-p-medium);
	color: var(--color-accent);
	margin: 0;
	text-align: center;
	max-width: 640px;
	margin-left: auto;
	margin-right: auto;
}

@media (max-width: 639px) {
	.section-about__hero {
		flex-direction: column;
		text-align: center;
	}
	.section-about__thrive {
		flex-direction: column;
	}
	.section-about__thrive-grid {
		grid-template-columns: 1fr 1fr;
	}
	@media(min-width: 375px){
	    .section-about__hero {
	        flex-wrap: nowrap;
	        flex-direction: row;
	    }
	    
	    .section-about__avatar-wrap {
	        width: 100px;
	        height: 100px;
	    }
    	.section-about__thrive-grid span:first-child {
          grid-column: span 2;
          font-size:24px;
        }
        
        .section-about__thrive-grid .section-about__pill{
            font-weight: 500;
            font-size:20px;
            line-height: 30px;
            background: linear-gradient(180.18deg, rgba(0, 128, 255, 0) 0.16%, #0080FF 243.94%);
        }
        
        .section-about__thrive-grid span:last-child {
          grid-column: span 2;
          font-size:24px;
        }
	}
}
@media (max-width: 375px) {
    .section-about__thrive-grid {
		grid-template-columns: 1fr;
	}
}
/* ==========================================================================
   Product Design Process section (static: left panel + right full image)
   ========================================================================== */
.section-product-design {
	padding: var(--section-padding) 0;
	background-color: var(--color-bg);
}

.section-product-design__header {
	display: grid;
	grid-template-columns: 1fr 2fr;
	gap: var(--space-xl);
	align-items: start;
	margin-bottom: var(--space-xl);
}

.section-product-design__title {
	font-family: var(--font-primary);
	font-size: var(--text-h2);
	font-weight: 700;
	line-height: var(--leading-tight);
	color: var(--color-text);
	margin: 0;
}

.section-product-design__intro {
	font-size: var(--text-p-small);
	line-height: var(--leading-normal);
	color: var(--color-text);
	margin: 0;
	max-width: 520px;
}

.section-product-design__main {
	display: grid;
	grid-template-columns: 1fr 2fr;
	gap: var(--space-xl);
	align-items: stretch;
	margin-bottom: var(--space-xl);
}

.section-product-design__panel {
	border-radius: var(--radius-xl);
	border: 1px solid var(--color-border);
	overflow: hidden;
}

.section-product-design__panel--left {
	background: linear-gradient(0deg, #0080FF -39.26%, #002A57 61.22%);
	padding: var(--space-xl);
}

.section-product-design__panel-title {
	font-family: var(--font-primary);
	font-size: var(--text-h3);
	font-weight: 700;
	line-height: var(--leading-snug);
	color: var(--color-text);
	margin: 0 0 var(--space-lg);
}

.section-product-design__pills {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--space-md);
}

.section-product-design__pill {
	display: inline-flex;
	align-items: center;
	gap: var(--space-sm);
	padding: var(--space-md) var(--space-lg);
	background-color: #001121;
	border: 1px solid var(--color-border);
	border-radius: 12px;
}

.section-product-design__pill-icon-wrap {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}

.section-product-design__pill-icon {
	width: 24px;
	height: 24px;
	display: block;
	object-fit: contain;
}

.section-product-design__pill-icon-fallback {
	display: none;
	font-size: 1.25rem;
	font-weight: 700;
	color: var(--color-text);
}

.section-product-design__pill-icon-fallback--show {
	display: inline-block;
}

.section-product-design__pill-label {
	font-family: var(--font-secondary);
	font-size: var(--text-body);
	font-weight: 500;
	color: var(--color-text);
}

.section-product-design__panel--right {
	background-color: #0B1A2C;
	min-height: 280px;
}

.section-product-design__image-wrap {
	position: relative;
	width: 100%;
	height: 100%;
	min-height: 280px;
}

.section-product-design__image {
	width: 100%;
	height: 100%;
	min-height: 280px;
	object-fit: cover;
	display: block;
}

.section-product-design__image-placeholder {
	display: none;
	position: absolute;
	inset: 0;
	align-items: center;
	justify-content: center;
	padding: var(--space-lg);
	font-size: var(--text-small);
	color: var(--color-text-muted);
	text-align: center;
}

.section-product-design__image-wrap--placeholder .section-product-design__image {
	display: none;
}

.section-product-design__image-wrap--placeholder .section-product-design__image-placeholder {
	display: flex;
}

.section-product-design__footer {
	font-size: var(--text-p-small);
	line-height: var(--leading-normal);
	color: var(--color-text);
	margin: 0;
}

.section-product-design__footer-highlight {
	color: var(--color-accent);
	font-weight: 600;
}

@media (max-width: 768px) {
	.section-product-design__header {
		grid-template-columns: 1fr;
		gap: var(--space-md);
	}

	.section-product-design__main {
		grid-template-columns: 1fr;
	}

	.section-product-design__panel--right {
		min-height: 0;
		height: auto;
	}

	.section-product-design__image-wrap,
	.section-product-design__image {
		min-height: 0;
		height: auto;
	}
	.section-product-design__image-wrap{
	    border: none;
	    height: auto;
	}

	/*.section-product-design__pills {*/
	/*	grid-template-columns: 1fr;*/
	/*}*/
}

@media (max-width: 480px) {
	.section-product-design__pill {
		padding: var(--space-sm) var(--space-md);
	}
}

/* ==========================================================================
   Achievements section (section 3)
   ========================================================================== */
.section-achievements {
	padding: var(--section-padding) 0;
}

.achievements__title {
	margin-bottom: var(--space-xl);
}

.achievements-wrapper{
    display: grid;
    grid-template-columns: 2fr 1fr;
    gap: 20px;
}

.achievements__grid {
	/* display: grid;
	grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); */
	gap: -10px 15px;
    justify-items: center;
    text-align: center;
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    grid-template-rows: repeat(2, 1fr);
}
.achievement.card-1 { grid-area: 1 / 1 / 2 / 3; }
.achievement.card-2 { grid-area: 1 / 3 / 2 / 5; }
.achievement.card-3 { grid-area: 2 / 2 / 3 / 4; }
.achievement.card-4 { grid-area: 2 / 4 / 3 / 6; }

/* Achievement number: Jost, transparent fill, outline only (button gradient blue) */
.achievement__number {
	font-family: var(--font-primary);
	font-size: clamp(2.5rem, 6vw, 5rem);
	font-weight: 700;
	line-height: var(--leading-tight);
	margin-bottom: var(--space-sm);
    background: -webkit-linear-gradient(180deg, #0080FF 46%, #003263 74.5%);
  -webkit-background-clip: text;
  -webkit-text-stroke: 2px transparent;
  color: black;
}

.achievement__description {
	font-size: var(--text-p-medium);
	color: var(--color-text);
	margin: 0;
}
@media (max-width: 600px){
	.achievements-wrapper{
		grid-template-columns: 1fr;
	}
	.achievements__grid {
		order: 2;
	}
}
/* ==========================================================================
   Testimonials section – Swiper, cards, mobile responsive
   ========================================================================== */
.section-testimonials {
	padding: var(--section-padding) 0;
}

.section-testimonials .testimonials-swiper.swiper{
    padding-bottom: 30px;
}



.testimonials__header {
	text-align: start;
	margin-bottom: var(--space-2xl);
}

.testimonials__description {
	font-size: var(--text-p-small);
	font-family: var(--font-secondary);
	font-weight: 600;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	color: var(--color-accent);
	margin: 0 0 var(--space-sm);
}

.testimonials__title {
	margin: var(--space-sm);
}

.testimonials-swiper {
	overflow: hidden;
	padding-bottom: var(--space-2xl);
}

.testimonials-swiper .swiper-wrapper {
	align-items: stretch;
	padding-bottom: 30px;
}

.testimonials-swiper .swiper-slide {
	height: auto;
}

.testimonial-card {
	height: 100%;
	display: flex;
	flex-direction: column;
	padding: var(--space-lg);
	padding-left: var(--space-xl);
	border-left: 1px solid var(--color-accent);
    border-right: 1px solid var(--color-accent);
	/* background: rgba(10, 25, 47, 0.4); */
	/* border-radius: 0 var(--radius-md) var(--radius-md) 0; */
}

.testimonial-card__content {
	/* flex: 1; */
	color: var(--color-text);
	line-height: var(--leading-relaxed);
	margin: 0 0 var(--space-md);
}

.testimonial-card__content p:last-child {
	margin-bottom: 0;
}

.testimonial-card__name {
	font-family: var(--font-primary);
	font-size: var(--text-p-medium);
	font-weight: 700;
	color: var(--color-text);
	margin: 0 0 var(--space-xs);
}

.testimonial-card__verified {
	font-size: var(--text-small);
	color: var(--color-text-muted);
	margin: 0;
}

.testimonials__cta {
	text-align: center;
	margin-top: var(--space-xl);
}

.testimonials__view-all {
	font-family: var(--font-third);
	font-size: var(--text-body);
	color: var(--color-text);
	text-decoration: none;
}

.testimonials__view-all:hover {
	color: var(--color-accent);
	text-decoration: underline;
}

/* Swiper pagination – theme colors */
.section-testimonials .swiper-pagination-bullet {
	background: var(--color-text-muted);
	opacity: 0.6;
}

.section-testimonials .swiper-pagination-bullet-active {
	background: var(--color-accent);
	opacity: 1;
}
.section-testimonials .swiper-pagination.swiper-pagination-clickable.swiper-pagination-bullets.swiper-pagination-horizontal{
    bottom: 0;
}
/* Mobile responsive */
@media (max-width: 639px) {
	.section-testimonials {
		padding: clamp(2rem, 6vw, 3rem) 0;
	}
	.testimonials__header {
		margin-bottom: var(--space-xl);
	}
	.testimonials__description {
		font-size: clamp(0.75rem, 2vw, 0.875rem);
	}
	.testimonial-card {
		padding: var(--space-md);
		padding-left: var(--space-lg);
		border-left-width: 2px;
	}
	.testimonial-card__content {
		font-size: var(--text-p-small);
	}
	.testimonials-swiper {
		padding-bottom: var(--space-xl);
	}
}

@media (min-width: 640px) and (max-width: 1023px) {
	.testimonial-card {
		padding: var(--space-md) var(--space-lg);
		padding-left: var(--space-xl);
	}
}

/* ==========================================================================
   Work Section – heading (left title + highlight, right description), accordion
   ========================================================================== */
.section-work {
	padding: var(--section-padding) 0;
	background: linear-gradient(180.43deg, #0080FF -44.23%, #000000 20%);
	position: relative;
	z-index: 0;
}
.section-work::before{
	background: radial-gradient(3% 3% at 50% 18.92%, rgba(4, 4, 6, 0.4) 0%, rgba(4, 4, 6, 0.8) 100%);
	top: 0;
	left: 0;
	right: 0;
	width: 100%;
	height: 100%;
	position: absolute;
	z-index: 1;
}

.work-header {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--space-xl);
	align-items: center;
	margin-bottom: var(--space-xl);
}

.work-header__left {
	position: relative;
}

.work-header__highlight {
	display: block;
	font-family: var(--font-secondary);
	font-size: var(--text-p-medium);
	color: var(--color-accent);
	margin-bottom: var(--space-xs);
}

.work-header__title {
	font-family: var(--font-primary);
	font-size: clamp(2rem, 5vw, 3.5rem);
	font-weight: 700;
	color: var(--color-text);
	margin: 0;
	line-height: var(--leading-tight);
}

.work-header__description {
	color: var(--color-text);
	margin: 0;
}

/* Accordion: collapsed = title only */
.work-accordion__item {
	border-bottom: 1px solid var(--color-border-light);
}

.work-accordion__trigger {
	width: 100%;
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: var(--space-lg) 0;
	background: none;
	border: none;
	color: var(--color-text);
	font-family: var(--font-primary);
	font-size: var(--text-h3);
	font-weight: 600;
	text-align: left;
	cursor: pointer;
	transition: color 0.2s;
}

.work-accordion__trigger:hover {
	color: var(--color-accent);
}

.work-accordion__trigger-title {
	pointer-events: none;
}

.work-accordion__panel {
	overflow: hidden;
}

.work-accordion__panel[hidden] {
	display: none;
}

.work-accordion__inner {
	display: grid;
	grid-template-columns: 1.4fr 1fr;
	gap: var(--space-xl);
	align-items: start;
	padding-bottom: var(--space-2xl);
}

.work-accordion__content {
	min-width: 0;
}

.work-accordion__highlight {
	display: flex;
	align-items: center;
	gap: var(--space-sm);
	font-size: var(--text-p-small);
	color: var(--color-accent);
	margin: 0 0 var(--space-sm);
}

.work-accordion__bar {
	width: 4px;
	height: 1em;
	background: var(--color-accent);
	flex-shrink: 0;
}

.work-accordion__item-title {
	font-family: var(--font-primary);
	font-size: var(--text-h2);
	font-weight: 700;
	color: var(--color-text);
	margin: 0 0 var(--space-md);
	padding-bottom: var(--space-md);
	border-bottom: 1px solid var(--color-border-light);
	line-height: var(--leading-snug);
}

.work-accordion__description {
	color: var(--color-text-muted);
	margin: 0 0 var(--space-lg);
	@media(max-width: 460px){
	    display: none;
	}
}

.work-accordion__services-heading {
	font-family: var(--font-primary);
	font-size: var(--text-h4);
	font-weight: 600;
	color: var(--color-text);
	margin: 0 0 var(--space-md);
}

.work-accordion__tags {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-sm);
	justify-content: space-evenly;
	list-style: none;
	margin: 0 0 var(--space-lg);
	padding: 0;
	@media (max-width: 460px){
	    gap: 10px;
	}
}

.work-accordion__tag {
	display: inline-block;
	padding: var(--space-sm) var(--space-lg);
	font-size: var(--text-small);
	color: var(--color-text);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	background-color: #001121;
	@media (max-width: 460px){
	    padding: 8px 10px;
	    font-size: 10px;
	    line-height: 12px;
	}
}

/* Single card wrapping all 3 metrics (one border, 3 columns inside) */
.work-accordion__metrics-card {
	background: #001121;
	border: 1px solid #0080FF;
	border-radius: var(--radius-lg);
	margin-bottom: var(--space-xl);
	overflow: hidden;
}

.work-accordion__metrics {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
}

.work-metric {
	padding: var(--space-lg);
	text-align: center;
}

.work-metric:not(:last-child) {
	/* border-right: 1px solid rgba(0, 128, 255, 0.25); */
}

.work-metric__number {
	display: block;
	font-family: var(--font-primary);
	font-size: clamp(1.6rem, 3vw, 2.2rem);
	font-weight: 700;
	color: var(--color-text);
	margin-bottom: var(--space-xs);
}

.work-metric__summary {
	font-size: var(--text-p-small);
	color: var(--color-text);
	line-height: var(--leading-tight);
}

.work-accordion__image {
	flex-shrink: 0;
	width: min(100%, 460px);
	border-radius: var(--radius-md);
	overflow: hidden;
	background: var(--color-bg-card);
}

.work-accordion__image img {
	width: 100%;
	height: auto;
	display: block;
}

@media (max-width: 767px) {
	.work-header {
		grid-template-columns: 1fr;
		gap: var(--space-md);
	}
	.work-accordion__inner {
		grid-template-columns: 1fr;
	}
	.work-accordion__image {
		width: 100%;
		order: -1;
	}
	
	.work-metric:not(:last-child) {
		border-right: none;
		border-bottom: 1px solid rgba(0, 128, 255, 0.25);
	}
}

@media (max-width: 567px) {
    .work-metric__number {
        font-size: 16px;
        line-height: 24px;
    }
    .work-metric__summary {
        display: block;
        font-size: 10px;
        line-height: 16px;
    }
}
@media (max-width: 375px) {
    .work-accordion__metrics {
		grid-template-columns: 1fr;
	}
}
/* ==========================================================================
   Section 8 – Design & Analytics Tools (showcase only, not clickable)
   ========================================================================== */
.section-tools {
	padding: var(--section-padding) 0;
}

.tools__title {
	margin-bottom: var(--space-2xl);
}

.tools__title .highlight {
	color: var(--color-accent);
}

.tools-grid {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: var(--space-md);
	list-style: none;
	margin: 0;
	padding: 0;
}

.tools-grid__item {
	display: block;
}

.tools-grid__img-wrap {
	display: flex;
	align-items: center;
	justify-content: center;
	width: clamp(64px, 12vw, 88px);
	height: clamp(64px, 12vw, 88px);
	padding: var(--space-md);
	background: var(--color-bg-card);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	pointer-events: none;
	cursor: default;
}

.tools-grid__img-wrap img {
	width: 100%;
	height: 100%;
	object-fit: contain;
	display: block;
}

@media (max-width: 639px) {
	.tools-grid {
		gap: var(--space-md);
	}
	.tools-grid__img-wrap {
		width: 56px;
		height: 56px;
		padding: var(--space-sm);
	}
}

/* ==========================================================================
   Section 9 – UX, Product & Conversion Skills (showcase only)
   Wrapper: background #001121, gradient border
   ========================================================================== */
.section-skills-tags {
	padding: var(--section-padding) 0;
}

.skills-tags__wrapper {
	--skills-wrapper-bg: #001121;
	border: 1px solid transparent;
	border-radius: var(--radius-2xl);
	padding: var(--space-3xl) var(--space-xl);
	background-image: linear-gradient(var(--skills-wrapper-bg), var(--skills-wrapper-bg)), linear-gradient(360deg, #0080FF 0%, rgba(0, 128, 255, 0) 100%);
	background-origin: padding-box, border-box;
	background-clip: padding-box, border-box;
}

.skills-tags__title {
	margin: 0 0 var(--space-xl);
}

.skills-tags__title .highlight {
	color: var(--color-accent);
}

.skills-tags__list {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: var(--space-md);
	margin: 0;
	padding: 0;
	list-style: none;
	max-width: 812px;
	margin: auto auto var(--space-xl);
}

.skills-tags__tag {
	display: inline-block;
	padding: var(--space-sm) var(--space-lg);
	font-family: var(--font-secondary);
	font-size: var(--text-p-small);
	color: var(--color-text);
	background: transparent;
	border: 1px solid var(--color-border);
	border-radius: 999px;
	pointer-events: none;
	cursor: default;
}

@media (max-width: 639px) {
	.skills-tags__wrapper {
		padding: var(--space-xl) var(--space-sm);
	}
	.skills-tags__title {
		margin-bottom: var(--space-xl);
	}
	.skills-tags__list {
		gap: var(--space-sm);
	}
	.skills-tags__tag {
		padding: var(--space-xs) var(--space-md);
		font-size: var(--text-small);
	}
}

/* ==========================================================================
   Footer (Part 11)
   ========================================================================== */
.footer {
	background: var(--color-bg);
	padding: var(--section-padding) 0;
	/* border-top: 1px solid var(--color-border-light); */
}

.footer__segment {
	padding: var(--space-xl) 0;
	
}

.footer__segment.border {
	border-bottom: 1px solid var(--color-border-light);
}

.footer__cta {
	font-family: var(--font-primary);
	font-size: var(--text-h2);
	font-weight: 700;
	line-height: var(--leading-snug);
	text-align: center;
	color: var(--color-text);
	margin: 0;
}

.footer__cta--case-study {
	font-weight: 400;
}

.footer__contact {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: var(--space-xl);
	list-style: none;
	margin: 0;
	padding: 0;
	
	@media (max-width: 567px){
	    row-gap: 15px;
	}
}

.footer__contact a {
	display: inline-flex;
	align-items: center;
	gap: var(--space-sm);
	color: var(--color-accent);
	font-size: clamp(16px, 3vw, 20px);
	text-decoration: none;
}

.footer__contact a:hover {
	text-decoration: underline;
}

.footer__bottom {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: center;
	gap: var(--space-md);
}

.footer__copyright {
	font-size: var(--text-small);
	color: var(--color-text);
	margin: 0;
}

.footer__legal {
	display: flex;
	gap: var(--space-md);
	list-style: none;
	margin: 0;
	padding: 0;
}

.footer__legal a {
	color: var(--color-accent);
	font-size: var(--text-small);
	text-decoration: none;
}

.footer__legal a:hover {
	text-decoration: underline;
}

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

.footer__legal li + li::before {
	content: "|";
	margin-right: var(--space-md);
	color: var(--color-text-muted);
}

/* ==========================================================================
   Placeholder sections (4–9) – same container, section padding
   ========================================================================== */
.home-section {
	padding: var(--section-padding) 0;
}

/* .home-section:nth-child(even) {
	background: rgba(10, 25, 47, 0.3);
} */

/* ==========================================================================
   Case Study: Container (uses gs-container with case-study width)
   - Below 1560px: max-width 946px
   - 1560px and above: max-width 1200px
   ========================================================================== */
.gs-container--case-study {
	width: 100%;
	max-width: 900px;
	margin-left: auto;
	margin-right: auto;
	box-sizing: border-box;
}

@media (min-width: 1560px) {
	.gs-container--case-study,
	.gs-container {
		max-width: 1200px;
	}
	.header__inner.gs-container{
		max-width: 946px;
	}
}

/* Section inners use full width of container */
.gs-container--case-study .case-study-hero__grid {
	max-width: 100%;
}

.gs-container--case-study .gs-container {
	max-width: 100%;
}

.gs-container--case-study .case-study-content-block__inner {
	max-width: 100%;
}

.gs-container--case-study .case-study-content-block__item {
	max-width: 100%;
}

/* ==========================================================================
   Case Study Hero Section (flexible content layout: hero)
   ========================================================================== */
.case-study-section--hero {
	background-color: #000000;
	padding: clamp(2rem, 6vw, 4rem) 0;
}

/* .case-study-hero {
	width: 100%;
} */

.case-study-hero__grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: clamp(1.5rem, 4vw, 3rem);
	align-items: start;
	max-width: var(--container-max);
	margin: 0 auto;
	padding-left: var(--container-padding);
	padding-right: var(--container-padding);
}

.case-study-hero__left {
	min-width: 0;
}

.case-study-hero__labels {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: var(--space-md);
	margin-bottom: var(--space-lg);
	padding: 8px;
	border-radius: 8px;
	background-color: #001121;
	border: 1px solid #002F5D;
	width: fit-content;
}

.case-study-hero__tag {
	display: inline-block;
	background: var(--color-accent-blue);
	color: var(--color-text);
	font-size: var(--text-small);
	font-family: var(--font-primary);
	font-weight: 500;
	padding: var(--space-xs) var(--space-md);
	border-radius: var(--radius-sm);
}

.case-study-hero__logo-wrap {
	display: inline-flex;
	align-items: center;
	flex-shrink: 0;
}

.case-study-hero__logo {
	display: block;
	width: 100%;
	/* height: 36px; */
	object-fit: contain;
	max-width: 120px;
}

.case-study-hero__client-name {
	font-size: var(--text-p-medium);
	font-weight: 500;
	color: var(--color-text);
}

.case-study-hero__client-name-highlight {
	color: #8B7FE8;
}

.case-study-hero__title {
	font-family: var(--font-primary);
	font-size: var(--case-study-h2);
	font-weight: 700;
	line-height: var(--leading-tight);
	color: var(--color-text);
	margin: 0 0 var(--space-lg);
}

.case-study-hero__description {
	font-size: var(--text-p-small);
	line-height: var(--leading-normal);
	color: var(--color-text-muted);
	margin: 0 0 var(--space-md);
}

.case-study-hero__description--2 {
	margin-bottom: 0;
}

/* Right side: info card */
.case-study-hero__right {
	min-width: 0;
}

.case-study-hero__card {
	position: relative;
	background: var(--color-bg-card);
	border-radius: var(--radius-xl);
	padding: var(--space-xl);
	overflow: hidden;
}

.case-study-hero__card-bg {
	position: absolute;
	inset: 0;
	pointer-events: none;
}

.case-study-hero__card-bg img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	opacity: 0.4;
}

.case-study-hero__card-inner {
	position: relative;
	z-index: 1;
}

.case-study-hero__card-row {
	display: flex;
	flex-direction: column;
	gap: var(--space-xs);
	padding: var(--space-md) 0;
	border-bottom: 1px solid var(--color-border-light);
}

.case-study-hero__card-row:first-child {
	padding-top: 0;
}

.case-study-hero__card-row:last-child,
.case-study-hero__card-row--tools {
	border-bottom: none;
	padding-bottom: 0;
}

.case-study-hero__card-label {
	font-size: var(--text-small);
	color: var(--color-text-muted);
}

.case-study-hero__card-value {
	font-size: var(--text-p-medium);
	font-weight: 600;
	color: var(--color-text);
	margin: 0;
}

.case-study-hero__card-row--tools .case-study-hero__card-value {
	/*display: none;*/
}

.case-study-hero__card-tools {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-md);
	align-items: center;
	margin-top: var(--space-xs);
}

.case-study-hero__tool {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 32px;
	flex-shrink: 0;
}

.case-study-hero__tool img {
	width: 100%;
	height: 100%;
	object-fit: contain;
}

/* Mobile: stack left then card, full width */
@media (max-width: 768px) {
	.case-study-hero__grid {
		grid-template-columns: 1fr;
		gap: var(--space-xl);
	}

	.case-study-hero__labels {
		margin-bottom: var(--space-md);
	}

	.case-study-hero__title {
		margin-bottom: var(--space-md);
	}

	.case-study-hero__card {
		padding: var(--space-lg);
	}

	.case-study-hero__card-row {
		padding: var(--space-sm) 0;
	}
}

/* ==========================================================================
   Case Study Content Block (flexible layout: content_block)
   Variants: content_with_list | tags | paragraph_only
   ========================================================================== */
.case-study-section--content_block {
	background-color: var(--color-bg);
	padding: 40px 0;
}

/* Inner: for Tags variant it's the single box; for Content items variant no box (each item is a box) */
.case-study-content-block__inner {
	width: 100%;
	max-width: min(946px, var(--section-inner-max, 946px));
	margin: 0 auto 30px;
	padding: var(--space-xl);
	padding-left: calc(var(--container-padding) + var(--space-xl));
	padding-right: calc(var(--container-padding) + var(--space-xl));
	border: 1px solid #002F5D;
	border-radius: var(--radius-xl);
	background: transparent;
	box-sizing: border-box;
}

/* Content items variant: no single outer box, each item is its own box */
.case-study-content-block--content_with_list .case-study-content-block__inner {
	border: none;
	background: transparent;
	padding: 0;
}

/* Repeater items: single section, row gap controlled by --gap-* */
.case-study-content-block__items {
	display: flex;
	flex-direction: column;
}

.case-study-content-block--gap-small .case-study-content-block__items {
	gap: var(--space-md);
}

.case-study-content-block--gap-medium .case-study-content-block__items {
	gap: var(--space-2xl);
}

.case-study-content-block--gap-large .case-study-content-block__items {
	gap: var(--space-3xl);
}

/* Each content item = separate box: border #002F5D, transparent background */
.case-study-content-block__item {
	display: flex;
	flex-direction: column;
	gap: var(--space-md);
	border: 1px solid #002F5D;
	border-radius: var(--radius-xl);
	background: transparent;
	padding: var(--space-xl);
	padding-left: calc(var(--container-padding) + var(--space-xl));
	padding-right: calc(var(--container-padding) + var(--space-xl));
}

.case-study-content-block__item-heading {
	font-family: var(--font-primary);
	font-size: var(--case-study-h2-narrow);
	font-weight: 500;
	color: #ffffff;
	margin: 0;
	line-height: var(--leading-snug);
}

.case-study-content-block__item-content {
	margin: 0;
	color: var(--color-text);
}

.case-study-content-block__item-content p {
	margin: 0 0 var(--space-sm);
}

.case-study-content-block__item-content p:last-child {
	margin-bottom: 0;
}

.case-study-content-block__item-content ul {
	list-style: none;
	margin: 0 0 var(--space-sm);
	padding: 0;
}

.case-study-content-block__item-content ul li {
	position: relative;
	padding-left: 1.25em;
	margin-bottom: var(--space-xs);
}

.case-study-content-block__item-content ul li::before {
	content: "";
	position: absolute;
	left: 0;
	top: 0.5em;
	width: 6px;
	height: 6px;
	background: #002F5D;
	border-radius: 50%;
}

.case-study-content-block__heading {
	font-family: var(--font-primary);
	font-size: var(--case-study-h2-narrow);
	font-weight: 700;
	color: #ffffff;
	/* margin: 0 0 var(--space-lg); */
	line-height: var(--leading-snug);
}

.case-study-content-block__intro {
	margin: 0 0 var(--space-lg);
	color: var(--color-text);
	font-size: var(--case-study-intro);
}

.case-study-content-block__intro:last-child {
	margin-bottom: 0;
}

.case-study-content-block__intro p {
	margin: 0 0 var(--space-sm);
}

.case-study-content-block__intro p:last-child {
	margin-bottom: 0;
}

.case-study-content-block__list {
	list-style: none;
	margin: 0 0 var(--space-lg);
	padding: 0;
}

.case-study-content-block__list-item {
	position: relative;
	padding-left: 1.25em;
	margin-bottom: var(--space-sm);
	color: var(--color-text);
	font-size: var(--text-p-small);
	line-height: var(--leading-normal);
}

.case-study-content-block__list-item::before {
	content: "";
	position: absolute;
	left: 0;
	top: 0.5em;
	width: 6px;
	height: 6px;
	/* background: var(--color-accent-blue); */
	border-radius: 50%;
}

.case-study-content-block__list-item :last-child {
	margin-bottom: 0;
}

.case-study-content-block__question {
	margin: 0;
	padding-left: 1em;
	border-left: 3px solid var(--color-accent-blue);
	color: var(--color-text);
	font-size: var(--text-p-small);
	font-style: italic;
	line-height: var(--leading-normal);
}

/* Tags variant: heading left, tags wrap on right – constrain inner to 946px */
.case-study-content-block--tags .case-study-content-block__inner {
	display: flex;
	flex-direction: column;
	gap: var(--space-md);
	min-width: 0;
	background: linear-gradient(181.22deg, rgba(0, 128, 255, 0) -37.15%, #0080FF 240.5%);
	
	@media (max-width: 567px){
      padding: 30px 15px;
  }
}


.case-study-content-block__tags-wrap {
	display: flex;
	flex-direction: column;
	gap: var(--space-md);
	min-width: 0;
}

.case-study-content-block__tags {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-md);
	align-items: center;
	justify-content: center;
}

.case-study-content-block__tag {
	display: inline-block;
	padding: var(--space-xs) var(--space-md);
	border: 1px solid #002F5D;
	border-radius: var(--radius-md);
	color: var(--color-text);
	font-size: var(--text-small);
	font-weight: 500;
	background: #000000;
}

@media (min-width: 769px) {
	.case-study-content-block--tags .case-study-content-block__inner {
		flex-direction: row;
		flex-wrap: wrap;
		align-items: flex-start;
		align-items: center;
	}

	.case-study-content-block--tags .case-study-content-block__heading {
		flex: 0 0 auto;
		min-width: 200px;
		max-width: 200px;
		/* margin-right: var(--space-xl); */
	}

	.case-study-content-block--tags .case-study-content-block__tags-wrap {
		flex: 1 1 60%;
		min-width: 0;
		max-width: 100%;
	}
}

/* ==========================================================================
   Case Study: Highlight Cards (2 layout styles)
   Style 1: Heading left + intro right + 3 blue cards
   Style 2: Centered heading + 3 blue cards + 1 dark bottom card
   ========================================================================== */
.case-study-section--highlight_cards {
	background-color: #000000;
	padding: clamp(2rem, 5vw, 3.5rem) 0;
}

.case-study-highlight-cards__inner {
    @media(min-width: 768px){
	width: 100%;
    }
}

/* Header: Style 1 = two columns, Style 2 = centered */
.case-study-highlight-cards__header {
	margin-bottom: var(--space-2xl);
}

.case-study-highlight-cards__header--heading_left_intro {
	display: grid;
	grid-template-columns: 1fr 2fr;
	gap: var(--space-xl);
	align-items: center;
}

.case-study-highlight-cards__header--centered_bottom_card {
	text-align: center;
	margin-bottom: var(--space-xl);
}

.case-study-highlight-cards__title {
	font-family: var(--font-primary);
	font-size: var(--case-study-h2);
	font-weight: 700;
	color: #ffffff;
	margin: 0;
	line-height: var(--leading-snug);
}

.case-study-highlight-cards__intro {
	margin: 0;
	color: #B6B6B6;
	font-size: var(--case-study-intro);
}

.case-study-highlight-cards__intro p {
	margin: 0 0 var(--space-sm);
}

.case-study-highlight-cards__intro p:last-child {
	margin-bottom: 0;
}

/* 3 blue cards – horizontal row */
.case-study-highlight-cards__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--space-lg);
}

.case-study-highlight-cards__card {
	background: #0080FF;
	border-radius: 0;
	padding: var(--space-xl);
	min-height: 0;
	text-align: center;
}

.case-study-highlight-cards__card-text {
	margin: 0;
	color: #ffffff;
	font-size: var(--text-p-small);
	line-height: var(--leading-normal);
}

/* Style 2 only: dark bottom card */
.case-study-highlight-cards__bottom-card {
	margin-top: var(--space-2xl);
	border: 1px solid #0080FF;
	border-radius: var(--radius-md);
	background: #001121;
	padding: var(--space-xl);
	max-width: 800px;
	text-align: center;
	margin-left: auto;
	margin-right: auto;
}

.case-study-highlight-cards__bottom-card-content {
	margin: 0;
	color: #0080FF;
}

.case-study-highlight-cards__bottom-card-content p {
	margin: 0 0 var(--space-md);
}

.case-study-highlight-cards__bottom-card-content p:last-child {
	margin-bottom: 0;
}

/* Mobile: stack header and cards */
@media (max-width: 768px) {
	.case-study-highlight-cards__header--heading_left_intro {
		grid-template-columns: 1fr;
		gap: var(--space-md);
	}

	.case-study-highlight-cards__grid {
		grid-template-columns: 1fr;
		gap: var(--space-md);
	}

	.case-study-highlight-cards__card {
		padding: var(--space-lg);
	}

	.case-study-highlight-cards__bottom-card {
		margin-top: var(--space-lg);
		padding: var(--space-lg);
	}
}

/* ==========================================================================
   Case Study: From Curiosity to Commitment (left intro + 2x3 grid)
   ========================================================================== */
.case-study-section--curiosity_commitment {
	padding: clamp(2rem, 5vw, 3.5rem) 0;
}

.case-study-curiosity-grid__inner {
    @media(min-width: 768px){
	width: 100%;
    }
}

/* ==========================================================================
   Case Study: Per-section inner max-width control
   Use inline style: --section-inner-max: <number>px on the __inner element.
   ========================================================================== */
.case-study-process-section__inner,
.case-study-key-problems__inner,
.case-study-scope-impact__inner,
.case-study-media-section__inner,
.case-study-media-section__fullwidth .case-study-media-section__flex,
.case-study-curiosity-grid__inner {
	max-width: min(var(--container-max), var(--section-inner-max, var(--container-max)));
	margin-left: auto;
	margin-right: auto;
}

.case-study-curiosity-grid__layout {
	display: grid;
	grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr);
	gap: var(--space-2xl);
	align-items: center;
}

.case-study-curiosity-grid__intro {
	color: #ffffff;
}

.case-study-curiosity-grid__title {
	font-family: var(--font-primary);
	font-size: var(--case-study-h2);
	font-weight: 700;
	color: #ffffff;
	margin: 0 0 var(--space-md);
	line-height: var(--leading-snug);
}

.case-study-curiosity-grid__text {
	color: #B6B6B6;
	font-size: var(--case-study-intro);
}

.case-study-curiosity-grid__text p {
	margin: 0 0 var(--space-sm);
}

.case-study-curiosity-grid__text p:last-child {
	margin-bottom: 0;
}

.case-study-curiosity-grid__grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 0px;
}

.case-study-curiosity-grid__card {
	background: linear-gradient(89.57deg, #001121 69.72%, #004687 129.44%);
    border-radius: 0;
    padding: var(--space-lg);
    min-height: 0;
    display: flex;
    align-items: center;
    outline: 1px solid #0080FF;
}

.case-study-curiosity-grid__card-text {
	margin: 0;
	color: #ffffff;
	font-size: var(--text-p-small);
	line-height: var(--leading-normal);
}

@media (max-width: 900px) {
	.case-study-curiosity-grid__layout {
		grid-template-columns: 1fr;
		gap: var(--space-xl);
	}

	.case-study-curiosity-grid__grid {
		grid-template-columns: 1fr;
		gap: var(--space-md);
	}

	.case-study-curiosity-grid__card {
		padding: var(--space-md-lg, var(--space-lg));
	}
}

/* ==========================================================================
   Case Study: Personas Slider (image-only Swiper) – full-width on all devices
   ========================================================================== */
.case-study-section--personas_slider {
	/* background-color: #000c1a; */
	padding: clamp(2.5rem, 6vw, 4rem) 0;
	overflow: hidden;
}

.case-study-personas-slider {
	width: 100%;
}

.case-study-personas-slider__inner {
    @media(min-width: 768px){
	width: 100%;
    }
	max-width: 100%;
}

.case-study-personas-slider__header {
	text-align: center;
	margin-bottom: var(--space-2xl);
	max-width: 946px;
	margin: auto;
}

.case-study-personas-slider__content-title-wrap {
	text-align: center;
	max-width: 946px;
	margin: var(--space-2xl) auto;
}

.case-study-personas-slider__section-title {
	margin: 0 0 var(--space-xs);
	font-size: var(--case-study-h2-44);
}

.case-study-personas-slider__content-title {
	margin: 0 0 var(--space-sm);
	font-family: var(--font-primary);
	font-weight: 700;
	font-size: var(--case-study-h2-32);
	line-height: 1.15;
	color: #ffffff;
}

.case-study-personas-slider__description {
	margin: 0;
	/* max-width: 720px; */
	margin-left: auto;
	margin-right: auto;
	font-size: 18px;
	line-height: 1.6;
	color: #B6B6B6;
}

/* Full-width track: break out of container, 100% viewport */
.case-study-personas-slider__fullwidth {
	width: 100vw;
	position: relative;
	left: 50%;
	right: 50%;
	margin-left: -50vw;
	margin-right: -50vw;
	padding-left: var(--space-md);
	padding-right: var(--space-md);
	box-sizing: border-box;
}

.case-study-personas-slider__track {
	position: relative;
	width: 100%;
	overflow: hidden;
}

.case-study-personas-slider__track .swiper-wrapper {
	align-items: stretch;
}

.case-study-personas-slider__slide {
	display: flex;
	justify-content: center;
	align-items: center;
	box-sizing: border-box;
	/* opacity: 0.6; */
}

.case-study-personas-slider__image {
	width: 100%;
	height: auto;
	max-width: 100%;
	object-fit: contain;
	border-radius: var(--radius-lg);
	box-shadow: 0 24px 80px rgba(0, 0, 0, 0.6);
	transition: transform 300ms ease, opacity 300ms ease;
	transform: scale(var(--ps-inactive-scale, 0.92));
	transform-origin: center center;
}

.case-study-personas-slider__slide.swiper-slide-active .case-study-personas-slider__image {
	transform: scale(var(--ps-active-scale, 1.05));
	opacity: 1;
	z-index: 2;
}

.case-study-personas-slider__slide.swiper-slide-prev .case-study-personas-slider__image,
.case-study-personas-slider__slide.swiper-slide-next .case-study-personas-slider__image {
	opacity: 0.85;
}

.case-study-personas-slider__pagination.swiper-pagination {
	position: relative;
	margin-top: var(--space-xl);
	text-align: center;
}

.case-study-personas-slider__pagination .swiper-pagination-bullet {
	background: #ffffff;
	opacity: 0.4;
}

.case-study-personas-slider__pagination .swiper-pagination-bullet-active {
	background: #0080FF;
	opacity: 1;
}

@media (max-width: 768px) {
	.case-study-personas-slider__content-title {
		font-size: clamp(1.75rem, 6vw, 2.5rem);
	}

	.case-study-personas-slider__fullwidth {
		padding-left: var(--space-sm);
		padding-right: var(--space-sm);
	}

	.case-study-personas-slider__image {
		max-width: 100%;
	}
}

/* ==========================================================================
   Case Study: Left Content + Right Full Image
   Title 36px (clamp), heading 20px, paragraph 16px. Mobile: stack.
   ========================================================================== */
.case-study-section--left_content_right_image {
	background-color: var(--color-bg);
	padding: clamp(2rem, 5vw, 3.5rem) 0;
	overflow-x: hidden;
}

.case-study-lcri__layout {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--space-2xl);
	align-items: center;
}

.case-study-lcri__title {
	font-family: var(--font-primary);
	font-weight: 700;
	font-size: clamp(1.5rem, 3.5vw, 2.25rem);
	line-height: 1.2;
	color: var(--color-text);
	margin: 0 0 var(--space-xl);
}

.case-study-lcri__item {
	margin-bottom: var(--space-lg);
}

.case-study-lcri__item:last-child {
	margin-bottom: 0;
}

.case-study-lcri__heading {
	font-family: var(--font-third);
	font-size: 20px;
	font-weight: 700;
	color: var(--color-accent);
	margin: 0 0 var(--space-sm);
	line-height: 1.3;
}

.case-study-lcri__paragraph {
	font-size: 16px;
	line-height: 1.6;
	color: var(--color-text);
	font-weight: 500;
	margin: 0;
	font-family: var(--font-secondary);
	letter-spacing: 1px;
}

.case-study-lcri__media {
	position: relative;
	width: 100%;
	min-height: 280px;
}

.case-study-lcri__img {
	width: 100%;
	height: auto;
	max-width: 100%;
	display: block;
	object-fit: cover;
	border-radius: var(--radius-lg);
}

@media (max-width: 768px) {
	.case-study-lcri__layout {
		grid-template-columns: 1fr;
		gap: var(--space-xl);
	}

	.case-study-lcri__media {
		order: -1;
		min-height: 0;
	}
}

/* ==========================================================================
   Case Study: List of Items (title wrapper like process + blue cards grid)
   ========================================================================== */
.case-study-section--list_items {
	background-color: var(--color-bg);
	padding: clamp(2rem, 5vw, 3.5rem) 0;
	overflow-x: hidden;
}

.case-study-list-items__inner {
    @media(min-width: 768px){
	width: 100%;
    }
}

.case-study-list-items__row--header {
	display: grid;
	grid-template-columns: auto 1fr;
	gap: var(--space-xl) var(--space-2xl);
	align-items: center;
	margin-bottom: var(--space-2xl);
}

.case-study-list-items__title {
	font-family: var(--font-primary);
	font-size: var(--case-study-h2);
	font-weight: 700;
	color: var(--color-text);
	margin: 0;
	line-height: 1.2;
	min-width: 0;
}

.case-study-list-items__intro {
	font-size: 16px;
	font-weight: 400;
	color: var(--color-text-muted);
	margin: 0;
	min-width: 0;
}

.case-study-list-items__intro p:last-child {
	margin-bottom: 0;
}

.case-study-list-items__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--space-md);
}

.case-study-list-items__card {
	background: #0080FF;
	border-radius: var(--radius-md);
	padding: var(--space-lg);
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	min-height: 0;
}

/* First item (h3): text only, no background, centered in wrapper */
.case-study-list-items__card--text-only {
	background: transparent;
	padding: 0;
	justify-content: center;
	text-align: center;
}

.case-study-list-items__card-title {
	font-family: var(--font-primary);
	font-size: clamp(1.5rem, 4vw, 2.25rem);
	font-weight: 600;
	color: #ffffff;
	margin: 0;
	line-height: 1.3;
}

.case-study-list-items__card--text-only .case-study-list-items__card-title {
	color: var(--color-text);
}

.case-study-list-items__card-text {
	font-size: 20px;
	line-height: 1.5;
	color: #ffffff;
	margin: 0;
}

@media (max-width: 900px) {
	.case-study-list-items__grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 768px) {
	.case-study-list-items__row--header {
		grid-template-columns: 1fr;
		gap: var(--space-md);
		margin-bottom: var(--space-xl);
	}

	.case-study-list-items__title {
		font-size: clamp(1.375rem, 5vw, 2rem);
	}

	.case-study-list-items__grid {
		grid-template-columns: 1fr;
		gap: var(--space-md);
	}
}

/* ==========================================================================
   Case Study: Competitive Gaps (logo cards + highlighted text)
   ========================================================================== */
.case-study-section--competitive_gaps_section {
	background-color: var(--color-bg);
	padding: clamp(2rem, 5vw, 3.5rem) 0;
	overflow-x: hidden;
}

.case-study-competitive-gaps__inner {
    @media(min-width: 768px){
	width: 100%;
    }
	text-align: center;
}

.case-study-competitive-gaps__title {
	font-family: var(--font-primary);
	font-weight: 600;
	font-size: 32px;
	line-height: 1.3;
	color: var(--color-text);
	margin: 0 0 var(--space-xl);
}

.case-study-competitive-gaps__grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: var(--space-lg);
	justify-items: center;
	margin-bottom: var(--space-2xl);
}

.case-study-competitive-gaps__card {
	background: #ffffff;
	border-radius: var(--radius-lg);
	overflow: hidden;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	width: 100%;
	max-width: 260px;
	box-shadow: 0 18px 36px rgba(0, 0, 0, 0.35);
}

.case-study-competitive-gaps__card-logo-wrap {
	padding: var(--space-lg) var(--space-lg) var(--space-md);
	display: flex;
	align-items: center;
	justify-content: center;
	background: #ffffff;
}

.case-study-competitive-gaps__card-logo {
	max-width: 100%;
	height: auto;
	display: block;
}

.case-study-competitive-gaps__card-caption {
	background: linear-gradient(152.09deg, #001121 52.92%, #004687 123.43%);
	color: #ffffff;
	font-family: var(--font-primary);
	font-weight: 500;
	font-size: 16px;
	line-height: 1.4;
	padding: var(--space-md) var(--space-lg);
	border-radius: 0 0 var(--radius-lg) var(--radius-lg);
	border: 1px solid var(--color-accent);
}

.case-study-competitive-gaps__highlight {
	max-width: 960px;
	margin: 0 auto;
	font-family: var(--font-secondary);
	font-weight: 400;
	font-size: 32px;
	line-height: 44px;
	color: #0080ff;
}

@media (max-width: 1024px) {
	.case-study-competitive-gaps__grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 768px) {
	.case-study-competitive-gaps__title {
		font-size: clamp(1.375rem, 5vw, 2rem);
		margin-bottom: var(--space-lg);
	}

	.case-study-competitive-gaps__grid {
		grid-template-columns: 1fr 1fr;
		gap: var(--space-md);
	}

	.case-study-competitive-gaps__card {
		max-width: 100%;
	}

	.case-study-competitive-gaps__highlight {
		font-size: clamp(1.5rem, 6vw, 2rem);
		line-height: 1.3;
		padding: 0 var(--space-sm);
	}
}

@media (max-width: 520px) {
	.case-study-competitive-gaps__grid {
		grid-template-columns: 1fr;
	}
}

/* ==========================================================================
   Case Study: Media Section (3 styles)
   Style 1: Heading + intro + single image in container
   Style 2: Heading + tagline (colored) + full-width image(s) in flex
   Style 3: Title wrapper (left/center) + accent description + single image + achievement metrics
   ========================================================================== */
.case-study-section--media_section {
	background-color: var(--color-bg);
	padding: clamp(2rem, 5vw, 3.5rem) 0;
	overflow-x: hidden;
}

.case-study-media-section__inner {
    @media(min-width: 768px){
	width: 100%;
    }
}

/* Header */
.case-study-media-section__header {
	text-align: center;
	margin-bottom: var(--space-2xl);
	max-width: 900px;
	margin-left: auto;
	margin-right: auto;
}

.case-study-media-section__title {
	font-family: var(--font-primary);
	font-size: var(--case-study-h2);
	font-weight: 700;
	color: #ffffff;
	margin: 0 0 var(--space-lg);
	line-height: var(--leading-snug);
}

.case-study-media-section__intro {
	margin: 0;
	color: var(--color-text);
	text-align: center;
}

.case-study-media-section__intro p {
	margin: 0 0 var(--space-sm);
}

.case-study-media-section__intro p:last-child {
	margin-bottom: 0;
}

.case-study-media-section__tagline {
	margin: 0;
	font-size: var(--case-study-intro);
	color: var(--color-accent-blue);
	text-align: center;
}

/* Style 3: alignment modifiers for header */
.case-study-media-section__header--left {
	text-align: left;
	margin-left: 0;
	margin-right: auto;
}

.case-study-media-section__header--center {
	text-align: center;
}

.case-study-media-section__metrics-desc {
	margin: 0;
	margin-top: var(--space-sm);
	font-family: var(--font-secondary);
	font-size: var(--case-study-intro);
	color: var(--color-accent-blue);
}

/* Style 1: image inside container */
.case-study-media-section__container {
	width: 100%;
	max-width: var(--container-max);
	margin: 0 auto;
}

.case-study-media-section__container .case-study-media-section__img {
	width: 100%;
	height: auto;
	display: block;
	vertical-align: middle;
}

/* Style 2: full-width wrapper (breaks out of case-study-container to span viewport) */
.case-study-media-section__fullwidth {
	width: 100vw;
	position: relative;
	left: 50%;
	right: auto;
	transform: translateX(-50%);
	box-sizing: border-box;
	overflow-x: hidden;
}

.case-study-media-section__fullwidth .case-study-media-section__flex {
	max-width: var(--container-max);
	margin-left: auto;
	margin-right: auto;
	padding-left: var(--container-padding);
	padding-right: var(--container-padding);
}

/* Single image: flex container uses full width */
.case-study-media-section__fullwidth .case-study-media-section__flex--single {
	max-width: 100%;
}

.case-study-media-section__flex {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-md);
	justify-content: center;
	align-items: flex-start;
}

.case-study-media-section__flex-item {
	flex: 1 1 auto;
	min-width: 0;
	max-width: 100%;
	overflow: hidden;
}

/* Single image in Style 2: make it full width of the flex container */
.case-study-media-section__flex-item:only-child {
	flex: 1 1 100%;
	max-width: 100%;
}

.case-study-media-section__flex-item img {
	width: 100%;
	max-width: 100%;
	height: auto;
	display: block;
	vertical-align: middle;
	object-fit: contain;
}

/* Style 3: metrics row inside container – flex: 3 items = 3 cols, 4 items = 4 cols, wrap, min 3 max 4 cols */
.case-study-media-section__metrics {
	--metrics-gap: clamp(1rem, 2vw, 1.5rem);
	margin-top: var(--space-2xl);
	background: #ffffff;
	border-radius: 24px;
	border: 1px solid var(--color-accent);
	font-size: clamp(1.75rem, 3.6vw, 2.75rem);
	display: flex;
	flex-wrap: wrap;
	gap: var(--metrics-gap);
	box-shadow: 0 18px 36px rgba(0, 0, 0, 0.25);
}

.case-study-media-section__metric {
	flex: 1 1 calc((100% - 3 * var(--metrics-gap)) / 4);
	min-width: calc((100% - 3 * var(--metrics-gap)) / 4);
	max-width: calc((100% - 2 * var(--metrics-gap)) / 3);
	text-align: center;
	padding: var(--space-lg);
	box-sizing: border-box;
}

.case-study-media-section__metric-label {
	font-family: var(--font-primary);
	font-weight: 700;
	font-size: clamp(1.75rem, 3.6vw, 2.5rem);
	line-height: 1.3;
	color: #0080ff;
	margin-bottom: 4px;
}

.case-study-media-section__metric-text {
	font-family: var(--font-secondary);
	font-size: 1.15rem;
	line-height: 1.4;
	color: #000000;
}

@media (max-width: 768px) {
	.case-study-media-section__header {
		margin-bottom: var(--space-xl);
	}

	.case-study-media-section__flex {
		flex-direction: column;
		gap: var(--space-md);
	}

	.case-study-media-section__flex-item {
		max-width: 100%;
	}

	.case-study-media-section__metrics {
		flex-direction: column;
		padding: var(--space-lg) var(--space-md);
	}

	.case-study-media-section__metric {
		flex: 1 1 100%;
		min-width: 100%;
		max-width: 100%;
		text-align: center;
	}
}

/* ==========================================================================
   Case Study: Two Column Items (repeat: left/right image or content)
   ========================================================================== */
.case-study-section--two_column_items .case-study-two-col__inner {
	/* max-width: 100%; */
}

.case-study-two-col {
	background-color: var(--color-bg);
	padding: clamp(2rem, 5vw, 3.5rem) 0;
	overflow-x: hidden;
}

.case-study-two-col__header {
	width: 100%;
	margin-bottom: var(--space-2xl);
}

.case-study-two-col__header--left {
	text-align: left;
}

.case-study-two-col__header--center {
	text-align: center;
}

.case-study-two-col__header--right {
	text-align: right;
}

.case-study-two-col__header--left .case-study-two-col__title {
	text-align: inherit;
}

.case-study-two-col__header--center .case-study-two-col__title {
	text-align: inherit;
}

.case-study-two-col__header--right .case-study-two-col__title {
	text-align: inherit;
}

.case-study-two-col__title {
	font-family: var(--font-primary);
	font-size: var(--case-study-h2);
	font-weight: 700;
	color: var(--color-text);
	margin: 0;
	line-height: 1.2;
}

.case-study-two-col__item {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--space-2xl);
	align-items: start;
	margin-bottom: var(--space-3xl);
}

/* Big screen: content column 1.2, image column 1.8 */
.case-study-two-col__item--content-left {
	grid-template-columns: 1.2fr 1.8fr;
}

.case-study-two-col__item--content-right {
	grid-template-columns: 1.8fr 1.2fr;
}

/* Vertical center when row uses single tagline style (one or both columns) */
.case-study-two-col__item--single-tagline-align {
	align-items: center;
}

.case-study-two-col__item:last-child {
	margin-bottom: 0;
}

.case-study-two-col__col {
	min-width: 0;
}

.case-study-two-col__media {
	width: 100%;
}

.case-study-two-col__media img {
	width: 100%;
	max-width: 100%;
	height: auto;
	display: block;
	border-radius: 8px;
}

.case-study-two-col__content {
	background-color: var(--color-bg-card);
	border: 1px solid rgba(51, 153, 255, 0.35);
	border-radius: 12px;
	padding: var(--space-xl);
	box-sizing: border-box;
	box-shadow: 0 0 0 1px rgba(51, 153, 255, 0.15);
}

.case-study-two-col__content--border-off {
	border: none;
	box-shadow: none;
	background-color: transparent;
}

.case-study-two-col__ux-card {
	display: flex;
	flex-direction: column;
	gap: var(--space-lg);
}

.case-study-two-col__ux-row {
	display: flex;
	flex-direction: column;
	gap: var(--space-xs);
}

.case-study-two-col__ux-heading {
	font-family: var(--font-primary);
	font-size: clamp(1.0625rem, 2vw + 1rem, 1.25rem);
	font-weight: 400;
	color: var(--color-accent-blue);
	margin: 0 0 var(--space-xs);
	line-height: 1.3;
}

.case-study-two-col__ux-text {
	font-family: var(--font-secondary);
	font-size: clamp(0.875rem, 1.5vw + 0.75rem, 1rem);
	color: #B6B6B6;
	margin: 0;
	line-height: 1.5;
}

.case-study-two-col__ux-text strong,
.case-study-two-col__content strong {
	color: #ffffff;
	font-weight: 400;
}

.case-study-two-col__list-item strong {
	color: #ffffff;
	font-weight: 400;
}

.case-study-two-col__list-card {
	display: flex;
	flex-direction: column;
	gap: var(--space-md);
}

.case-study-two-col__list-heading {
	font-family: var(--font-primary);
	/* font-size: clamp(1.0625rem, 2vw + 1rem, 1.25rem); */
	font-weight: 700;
	color: var(--color-accent-blue);
	margin: 0 0 var(--space-sm);
	line-height: 1.3;
}

.case-study-two-col__list {
	list-style: none;
	margin: 0;
	padding: 0;
}

.case-study-two-col__list-item {
	position: relative;
	padding-left: var(--space-lg);
	margin-bottom: var(--space-md);
	font-family: var(--font-secondary);
	font-size: clamp(0.875rem, 1.5vw + 0.75rem, 1rem);
	color: #B6B6B6;
	line-height: 1.5;
}

.case-study-two-col__list-item::before {
	content: "";
	position: absolute;
	left: 0;
	top: 0.2em;
	bottom: 0.2em;
	width: 3px;
	background-color: var(--color-accent-blue);
	border-radius: 2px;
}

.case-study-two-col__list-item:last-child {
	margin-bottom: 0;
}

/* Below 991px: equal width columns */
@media (max-width: 991px) {
	.case-study-two-col__item,
	.case-study-two-col__item--content-left,
	.case-study-two-col__item--content-right {
		grid-template-columns: 1fr 1fr;
	}
}

@media (max-width: 768px) {
	.case-study-two-col__item {
		grid-template-columns: 1fr;
		gap: var(--space-xl);
	}
	
	/* Stacked layout: keep top alignment like other rows */
	.case-study-two-col__item--single-tagline-align {
		align-items: start;
	}

	.case-study-two-col__item--mobile-reverse {
		display: flex;
		flex-direction: column-reverse;
	}
}

/* ==========================================================================
   Case Study: Process Section (title + intro, image inside container, tagline)
   Row 1: Title left, intro right. Row 2: Image. Row 3: Tagline with gap above.
   ========================================================================== */
.case-study-section--process_section .case-study-process-section__inner {
	/* max-width: 100%; */
}

.case-study-process-section {
	background-color: var(--color-bg);
	padding: clamp(2rem, 5vw, 3.5rem) 0;
	overflow-x: hidden;
}

.case-study-process-section__row--header {
	display: grid;
	grid-template-columns: auto 1fr;
	gap: var(--space-xl) var(--space-2xl);
	align-items: center;
	margin-bottom: var(--space-2xl);
}

.case-study-process-section__title {
	font-family: var(--font-primary);
	font-size: var(--case-study-h2);
	font-weight: 700;
	color: var(--color-text);
	margin: 0;
	line-height: 1.2;
	min-width: 0;
}

.case-study-process-section__intro {
	font-size: 16px;
	font-weight: 400;
	color: var(--color-text-muted);
	margin: 0;
	min-width: 0;
}

.case-study-process-section__intro p:last-child {
	margin-bottom: 0;
}

/* Row 2: image inside container */
.case-study-process-section__image-wrap {
	width: 100%;
	margin-bottom: var(--space-2xl);
	box-sizing: border-box;
}

.case-study-process-section__img {
	width: 100%;
	max-width: 100%;
	height: auto;
	display: block;
	border-radius: 8px;
	object-fit: contain;
}

/* Row 3: tagline with gap above */
.case-study-process-section__tagline {
	font-family: var(--font-secondary);
	font-size: clamp(0.9375rem, 2vw, 1rem);
	color: var(--color-accent-blue);
	margin: 0;
	margin-top: var(--space-xl);
	line-height: 1.5;
	text-align: center;
}

/* Mobile: stack title and intro */
@media (max-width: 768px) {
	.case-study-process-section__row--header {
		grid-template-columns: 1fr;
		gap: var(--space-md);
		margin-bottom: var(--space-xl);
	}

	.case-study-process-section__image-wrap {
		margin-bottom: var(--space-xl);
	}

	.case-study-process-section__tagline {
		margin-top: var(--space-lg);
	}
}

/* Mobile: case study section h2s – readable size, clearly larger than body text */
@media (max-width: 768px) {
	.case-study-process-section__title,
	.case-study-two-col__title,
	.case-study-media-section__title,
	.case-study-highlight-cards__title,
	.case-study-content-block__heading,
	.case-study-title-image-points__heading,
	.case-study-scope-impact__heading,
	.case-study-scope-impact__subheading,
	.case-study-key-problems__heading,
	.case-study-data-viz__heading,
	.case-study-list-items__title {
		font-size: clamp(1.375rem, 5vw, 2rem);
	}
}

/* ==========================================================================
   Case Study: Title + Image or Title + Points (2 variants)
   Style 1: Title left, image right. Style 2: Points left, title right; View More.
   ========================================================================== */
.case-study-section--title_image_points .case-study-title-image-points__inner {
	max-width: 100%;
}

.case-study-title-image-points {
	background-color: var(--color-bg);
	padding: clamp(2rem, 5vw, 3.5rem) 0;
	overflow-x: hidden;
}

.case-study-title-image-points__grid {
	display: grid;
	gap: clamp(16px, 2.5vw, 24px);
	align-items: start;
}

.case-study-title-image-points__grid--title-left {
	grid-template-columns: 35% 60%;
}

.case-study-title-image-points__grid--points-left {
	grid-template-columns: 70% 30%;
}

.case-study-title-image-points__heading {
	font-family: var(--font-primary);
	font-size: var(--case-study-h2);
	font-weight: 700;
	color: var(--color-text);
	margin: 0;
	line-height: 1.2;
}

.case-study-title-image-points__description {
	font-family: var(--font-secondary);
	font-size: clamp(0.9375rem, 1.25vw, 1.125rem);
	color: #B6B6B6;
	line-height: 1.5;
	margin: var(--space-md) 0 0;
}

.case-study-title-image-points__description p {
	margin: 0 0 0.5em;
}

.case-study-title-image-points__description p:last-child {
	margin-bottom: 0;
}

.case-study-title-image-points__col--image,
.case-study-title-image-points__col--title {
	min-width: 0;
}

.case-study-title-image-points__col--points {
	display: flex;
	flex-direction: column;
	gap: 0;
	min-width: 0;
}

.case-study-title-image-points__image-wrap {
	width: 100%;
}

.case-study-title-image-points__img {
	width: 100%;
	max-width: 100%;
	height: auto;
	display: block;
	/* border-radius: 8px; */
	object-fit: contain;
}

/* Points cards (Style 2) – match screenshot: left bright blue + purple heading, right dark + blue Learning */
.case-study-title-image-points__points-list {
	display: flex;
	flex-direction: column;
	gap: clamp(16px, 2.5vw, 24px);
}

.case-study-title-image-points__point {
	display: grid;
	grid-template-columns: 55% 45%;
	gap: 0;
	background: transparent;
	border: 1px solid rgba(51, 153, 255, 0.6);
	overflow: hidden;
}

.case-study-title-image-points__point-problem {
	background: #0066FF;
	padding: clamp(1rem, 2.5vw, 1.5rem);
}

.case-study-title-image-points__point-heading {
	font-family: var(--font-primary);
	font-size: clamp(1rem, 1.5vw, 1.25rem);
	font-weight: 700;
	color: var(--color-bg-header);
	margin: 0 0 var(--space-sm);
	line-height: 1.3;
}

.case-study-title-image-points__point-desc {
	font-family: var(--font-secondary);
	font-size: clamp(0.875rem, 1.5vw, 1rem);
	color: #ffffff;
	line-height: 1.5;
	margin: 0;
}

.case-study-title-image-points__point-learning {
	padding: clamp(1rem, 2.5vw, 1.5rem);
	background: #0D1117;
}

.case-study-title-image-points__point-learning p {
	margin: 0;
	font-family: var(--font-secondary);
	font-size: clamp(0.875rem, 1.5vw, 1rem);
	color: #ffffff;
	line-height: 1.5;
}

.case-study-title-image-points__point-learning strong {
	color: #0066FF;
	font-weight: 700;
	display: block;
	margin-bottom: 12px;
	font-family: var(--font-primary);
	font-size: clamp(1rem, 1.5vw, 1.25rem);
}

/* View More: hidden block + smooth expand */
.case-study-title-image-points__hidden {
	display: flex;
	flex-direction: column;
	gap: clamp(16px, 2.5vw, 24px);
	max-height: 0;
	overflow: hidden;
	transition: max-height 0.4s ease-out;
}

.case-study-title-image-points--expanded .case-study-title-image-points__hidden {
	margin-top: var(--space-lg);
	max-height: 5000px;
	transition: max-height 0.5s ease-in;
}

.case-study-title-image-points--expanded .case-study-title-image-points__hidden + .case-study-title-image-points__view-more-wrap .case-study-title-image-points__view-more-icon {
	transform: rotate(180deg);
}

.case-study-title-image-points__view-more-wrap {
	margin-top: var(--space-xl);
	text-align: center;
}

.case-study-title-image-points__view-more {
	display: inline-flex;
	align-items: center;
	gap: var(--space-sm);
	background: none;
	border: none;
	color: var(--color-accent-blue);
	font-family: var(--font-secondary);
	font-size: 1rem;
	cursor: pointer;
	padding: var(--space-sm) 0;
	transition: color 0.2s;
}

.case-study-title-image-points__view-more:hover {
	color: #ffffff;
}

.case-study-title-image-points__view-more-icon {
	display: inline-block;
	transition: transform 0.3s ease;
}

/* 1024px and below: both columns 50% */
@media (max-width: 1024px) {
	.case-study-title-image-points__grid--title-left,
	.case-study-title-image-points__grid--points-left {
		grid-template-columns: 1fr 1fr;
	}
}

/* Mobile: stack, both 100% width */
@media (max-width: 768px) {
	.case-study-title-image-points__grid--title-left,
	.case-study-title-image-points__grid--points-left {
		grid-template-columns: 1fr;
	}

	.case-study-title-image-points__point {
		grid-template-columns: 1fr;
	}
}

/* ==========================================================================
   Case Study: Scope / Impact Section (2 styles)
   Style A: Grid of boxes. Style B: Three columns in one bordered box.
   Heading 32px desktop, mobile responsive.
   ========================================================================== */
.case-study-section--scope_impact_section .case-study-scope-impact__inner {
	max-width: min(var(--container-max), var(--section-inner-max, var(--container-max)));
}

.case-study-scope-impact {
	background-color: var(--color-bg);
	padding: clamp(2rem, 5vw, 3.5rem) 0;
	overflow-x: hidden;
}

.case-study-scope-impact__heading {
	font-family: var(--font-primary);
	font-weight: 700;
	color: var(--color-text);
	text-align: center;
	margin: 0 0 var(--space-md);
	line-height: 1.2;
}

.case-study-scope-impact--h2-32 .case-study-scope-impact__heading {
	font-size: var(--case-study-h2-32);
}

.case-study-scope-impact--h2-44 .case-study-scope-impact__heading {
	font-size: var(--case-study-h2-44);
}

.case-study-scope-impact__subheading {
	font-family: var(--font-primary);
	font-weight: 700;
	color: var(--color-text);
	text-align: center;
	margin: 0 0 var(--space-2xl);
	line-height: 1.2;
}

.case-study-scope-impact--h3-32 .case-study-scope-impact__subheading {
	font-size: var(--case-study-h2-32);
}

.case-study-scope-impact--h3-44 .case-study-scope-impact__subheading {
	font-size: var(--case-study-h2-44);
}

/* Style A: grid of boxes */
.case-study-scope-impact__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: clamp(16px, 2.5vw, 24px);
}

.case-study-scope-impact__box {
	background: linear-gradient(180deg, #002F5A 0%, #001438 100%);
	border: 1px solid rgba(51, 153, 255, 0.65);
	border-radius: 12px;
	padding: var(--space-lg);
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 100px;
	box-sizing: border-box;
}

.case-study-scope-impact__box-text {
	margin: 0;
	font-family: var(--font-secondary);
	font-size: clamp(1rem, 2.5vw, 1.25rem);
	color: #ffffff;
	text-align: center;
	line-height: 1.5;
}

/* Style B: table structure (3 cols × N rows), horizontally scrollable on mobile */
.case-study-scope-impact__table-scroll {
	width: 100%;
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
	border: 1px solid rgba(51, 153, 255, 0.5);
	border-radius: 12px;
	background: #001121;
}

.case-study-scope-impact__table {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	min-width: 480px;
	width: 100%;
	padding: var(--space-2xl) 0;
}

.case-study-scope-impact__table-row {
	display: contents;
}

.case-study-scope-impact__table-row--head {
	/* background: rgba(0, 47, 93, 0.3); */
	
}

.case-study-scope-impact__table-cell {
	padding: var(--space-sm) var(--space-lg);
	font-family: var(--font-secondary);
	font-size: clamp(0.875rem, 1.5vw, 1rem);
	color: #B6B6B6;
	line-height: 1.5;
	/* border-right: 1px solid rgba(51, 153, 255, 0.2); */
	/* border-bottom: 1px solid rgba(51, 153, 255, 0.2); */
	box-sizing: border-box;
	font-weight: 400;
}

.case-study-scope-impact__table-cell:nth-child(3n) {
	border-right: none;
}

.case-study-scope-impact__table-cell:nth-last-child(-n+3) {
	border-bottom: none;
}

.case-study-scope-impact__table-row--head .case-study-scope-impact__table-cell {
	font-family: var(--font-secondary);
	font-weight: 400;
	color: var(--color-accent-blue);
	font-size: clamp(1rem, 1.5vw, 1.25rem);
	
}
.case-study-scope-impact__table-cell strong{
	font-weight: 400;
	color: #FFFFFF;
}

/* Tablet: grid 2 cols for Style A */
@media (max-width: 991px) {
	.case-study-scope-impact__grid {
		grid-template-columns: repeat(2, 1fr);
	}

	.case-study-scope-impact__table {
		min-width: 420px;
	}
}

/* Mobile: single column for Style A; Style B table scrolls horizontally */
@media (max-width: 768px) {
	.case-study-scope-impact__grid {
		grid-template-columns: 1fr;
	}

	.case-study-scope-impact__table-scroll {
		margin-left: calc(-1 * var(--container-padding));
		margin-right: calc(-1 * var(--container-padding));
		width: calc(100% + (2 * var(--container-padding)));
		border-radius: 0;
		border-left: none;
		border-right: none;
	}

	.case-study-scope-impact__table {
		min-width: 360px;
	}
}

/* Style C: Post-Launch Insights & Iteration */
.case-study-scope-impact__pli-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: clamp(16px, 2.5vw, 24px);
	margin: var(--space-2xl) 0;
}

.case-study-scope-impact__pli-card {
	background: linear-gradient(180deg, #003a73 0%, #00163a 100%);
	border-radius: var(--radius-lg);
	border: 1px solid var(--color-accent);
	box-shadow: 0 18px 36px rgba(0, 0, 0, 0.45);
	padding: clamp(1.5rem, 3vw, 2.25rem);
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
}

.case-study-scope-impact__pli-card-title {
	font-family: var(--font-secondary);
	font-weight: 500;
	font-size: clamp(1rem, 2.5vw, 1.25rem);
	line-height: 1.4;
	color: #ffffff;
}

.case-study-scope-impact__pli-bar {
	display: grid;
	grid-template-columns: auto minmax(0, 1.5fr) auto minmax(0, 1.5fr);
	align-items: center;
	gap: clamp(0.75rem, 1.5vw, 1.25rem);
	padding-top: var(--space-2xl);
	border-top: 0.5px solid rgba(0, 128, 255, 0.65);
	margin-top: var(--space-xl);
}

.case-study-scope-impact__pli-col--label {
	justify-self: flex-start;
}

.case-study-scope-impact__pli-label {
	font-family: var(--font-primary);
	font-weight: 600;
	font-size: clamp(22px, 3vw, 36px);
	line-height: 1.4;
	color: #0080ff;
}

.case-study-scope-impact__pli-col--text {
	border-left: 2px solid #0080ff;
	padding-left: clamp(0.75rem, 1.5vw, 1.25rem);
}

.case-study-scope-impact__pli-text {
	margin: 0;
	font-family: var(--font-secondary);
	font-size: 16px;
	line-height: 1.6;
	color: #ffffff;
}

@media (max-width: 991px) {
	.case-study-scope-impact__pli-grid {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}

	.case-study-scope-impact__pli-bar {
		grid-template-columns: 1fr 2fr;
		row-gap: var(--space-md);
	}
}

@media (max-width: 768px) {
	.case-study-scope-impact__pli-grid {
		grid-template-columns: 1fr;
	}

	.case-study-scope-impact__pli-card {
		padding: var(--space-lg) var(--space-md);
	}

	.case-study-scope-impact__pli-bar {
		grid-template-columns: 1fr;
		text-align: left;
	}

	.case-study-scope-impact__pli-col--label {
		justify-self: flex-start;
	}

	.case-study-scope-impact__pli-col--text {
		border-left: none;
		padding-left: 0;
	}
}

/* ==========================================================================
   Case Study: Key Problems Section (heading 32px, blue label + bordered content)
   ========================================================================== */
.case-study-key-problems {
	background-color: var(--color-bg);
	padding: clamp(2rem, 5vw, 3.5rem) 0;
	overflow-x: hidden;
}

.case-study-key-problems__heading {
	font-family: var(--font-primary);
	font-size: var(--case-study-h2-32);
	font-weight: 700;
	color: var(--color-text);
	text-align: center;
	margin: 0 0 var(--space-md);
	line-height: 1.2;
}

.case-study-key-problems__subheading {
	font-family: var(--font-secondary);
	font-size: clamp(0.9375rem, 1.5vw, 1.125rem);
	color: #ffffff;
	text-align: center;
	margin: 0 0 var(--space-2xl);
	line-height: 1.5;
	max-width: 800px;
	margin-left: auto;
	margin-right: auto;
}

.case-study-key-problems__list {
	list-style: none;
	margin: 0 0 var(--space-2xl);
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: clamp(12px, 2vw, 20px);
}

.case-study-key-problems__item {
	display: grid;
	grid-template-columns: 35% 1fr;
	/* gap: clamp(16px, 2vw, 24px); */
	align-items: stretch;
	min-height: 0;
}

.case-study-key-problems__label {
	background: #0080FF;
	color: #ffffff;
	font-family: var(--font-primary);
	font-size: clamp(1rem, 2vw, 1.25rem);
	font-weight: 500;
	padding: var(--space-md) var(--space-lg);
	display: flex;
	align-items: center;
	/* border-radius: 12px 0 0 12px; */
	box-sizing: border-box;
}

.case-study-key-problems__content {
	background: #0D1B2A;
	border: 1px solid #3498DB;
	/* border-radius: 0 12px 12px 0; */
	padding: var(--space-md) var(--space-lg);
	font-family: var(--font-secondary);
	font-size: clamp(0.9375rem, 1.25vw, 1.15rem);
	font-weight: 300;
	color: #ffffff;
	line-height: 1.5;
	box-sizing: border-box;
}

.case-study-key-problems__content p:first-child {
	margin-top: 0;
}

.case-study-key-problems__content p:last-child {
	margin-bottom: 0;
}

.case-study-key-problems__content strong {
	font-weight: 600;
	color: #ffffff;
}

.case-study-key-problems__conclusion {
	font-family: var(--font-secondary);
	font-size: clamp(0.9375rem, 1.25vw, 1.125rem);
	color: #ffffff;
	text-align: center;
	line-height: 1.5;
	margin: 0;
	max-width: 720px;
	margin-left: auto;
	margin-right: auto;
}

/* Key Problems: ≤1024px → 50% / 50% */
@media (max-width: 1024px) {
	.case-study-key-problems__item {
		grid-template-columns: 50% 1fr;
	}
}

/* Key Problems: mobile stack (100% each) */
@media (max-width: 768px) {
	.case-study-key-problems__item {
		grid-template-columns: 1fr;
		gap: 0;
	}

	.case-study-key-problems__label {
		border-radius: 12px 12px 0 0;
	}

	.case-study-key-problems__content {
		border-radius: 0 0 12px 12px;
		border-top: none;
	}
}

/* ==========================================================================
   Case Study: Data Viz Section (heading 44px or 32px, items: row1 title+tagline|desc, row2 image+2col)
   ========================================================================== */
.case-study-data-viz {
	background-color: var(--color-bg);
	padding: clamp(2rem, 5vw, 3.5rem) 0;
	overflow-x: hidden;
}

.case-study-data-viz__heading {
	font-family: var(--font-primary);
	font-weight: 700;
	color: var(--color-text);
	text-align: center;
	margin: 0 0 var(--space-2xl);
	line-height: 1.2;
}

.case-study-data-viz--heading-44 .case-study-data-viz__heading {
	font-size: var(--case-study-h2-44);
}

.case-study-data-viz--heading-32 .case-study-data-viz__heading {
	font-size: var(--case-study-h2-32);
}

.case-study-data-viz__items {
	display: flex;
	flex-direction: column;
	gap: var(--space-3xl);
}

.case-study-data-viz__item {
	display: flex;
	flex-direction: column;
	gap: var(--space-2xl);
}

/* First row: title + tagline (left ~40%) | description (right ~60%) */
.case-study-data-viz__row1 {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: clamp(20px, 3vw, 32px);
	align-items: start;
}

.case-study-data-viz__left {
	min-width: 0;
}

.case-study-data-viz__title {
	font-family: var(--font-primary);
	font-size: clamp(1.25rem, 2vw, 1.75rem);
	font-weight: 500;
	color: #ffffff;
	margin: 0 0 var(--space-sm);
	line-height: 1.2;
}

.case-study-data-viz__number {
	color: var(--color-accent-blue, #3498DB);
	margin-right: 0.25em;
}

.case-study-data-viz__pipe {
	color: rgba(255, 255, 255, 0.5);
	margin: 0 0.35em 0 0;
	font-weight: 400;
}

.case-study-data-viz__tagline {
	font-family: var(--font-secondary);
	font-size: clamp(1rem, 1.25vw, 1.45rem);
	color: var(--color-text);
	margin: 0;
	line-height: 1.4;
}
.case-study-data-viz__tagline span{
    color: var(--color-accent-blue, #3498DB);
}

.case-study-data-viz__description {
	font-family: var(--font-secondary);
	font-size: clamp(1rem, 1.25vw, 1.25rem);
	color: #B6B6B6;
	line-height: 1.5;
}

.case-study-data-viz__description p {
	margin: 0 0 0.5em;
}

.case-study-data-viz__description p:last-child {
	margin-bottom: 0;
}

/* Second row: images gallery */
.case-study-data-viz__row2 {
	margin-top: 0;
}

.case-study-data-viz__gallery {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: clamp(16px, 2.5vw, 24px);
}

.case-study-data-viz__gallery--single {
	grid-template-columns: 1fr;
}

.case-study-data-viz__gallery-item {
	min-width: 0;
	border-radius: 12px;
	overflow: hidden;
	/*background: rgba(13, 22, 42, 0.8);*/
	/*border: 1px solid rgba(51, 153, 255, 0.35);*/
}

.case-study-data-viz__gallery-img {
	display: block;
	width: 100%;
	height: auto;
	vertical-align: middle;
}

/* Data Viz: tablet – row1 50/50 */
@media (max-width: 1024px) {
	.case-study-data-viz__row1 {
		grid-template-columns: 1fr 1fr;
	}
}

/* Data Viz: mobile – stack row1 and gallery */
@media (max-width: 768px) {
	.case-study-data-viz__row1 {
		grid-template-columns: 1fr;
		gap: var(--space-md);
	}
	.case-study-data-viz__gallery {
		grid-template-columns: 1fr;
	}
}


/* ==========================================================================
   Password-protected content – popup overlay with blurred background
   ========================================================================== */
.password-popup-overlay {
	position: fixed;
	inset: 0;
	z-index: 10000;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: var(--space-lg);
	box-sizing: border-box;
}

.password-popup-backdrop {
	position: absolute;
	inset: 0;
	background: rgba(10, 25, 47, 0.75);
	backdrop-filter: blur(12px);
	-webkit-backdrop-filter: blur(12px);
}

.password-popup-card {
	position: relative;
	z-index: 1;
	width: 100%;
	max-width: 420px;
	background: var(--color-bg-card);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-xl);
	padding: var(--space-2xl);
	box-shadow: 0 20px 60px rgba(0, 0, 0, 0.4);
}

.password-popup-title {
	font-family: var(--font-primary);
	font-size: var(--text-h4);
	font-weight: 600;
	color: var(--color-text);
	margin: 0 0 var(--space-sm);
	line-height: var(--leading-snug);
}

.password-popup-desc {
	color: var(--color-text-muted);
	font-size: var(--text-body);
	margin: 0 0 var(--space-xl);
	line-height: var(--leading-normal);
}

.password-form {
	display: flex;
	flex-direction: column;
	gap: var(--space-md);
}

.password-form-label {
	display: block;
	font-size: var(--text-small);
	font-weight: 500;
	color: var(--color-text);
	margin: 0;
}

.password-box {
	width: 100%;
	padding: var(--space-md) var(--space-lg);
	font-family: var(--font-secondary);
	font-size: var(--text-body);
	color: var(--color-text);
	background: var(--color-bg);
	border: 1px solid var(--color-border-light);
	border-radius: var(--radius-md);
	box-sizing: border-box;
	transition: border-color 0.2s, box-shadow 0.2s;
}

.password-box::placeholder {
	color: var(--color-text-muted);
}

.password-box:focus {
	outline: none;
	border-color: var(--color-accent);
	box-shadow: 0 0 0 2px rgba(0, 128, 255, 0.25);
}

.password-btn {
	align-self: flex-start;
	padding: var(--space-md) var(--space-xl);
	font-family: var(--font-primary);
	font-size: var(--text-btn);
	font-weight: 600;
	color: var(--color-text);
	background: var(--gradient-primary);
	border: 1px solid var(--color-accent);
	border-radius: var(--radius-md);
	cursor: pointer;
	transition: background 0.2s, transform 0.1s;
}

.password-btn:hover {
	background: var(--gradient-primary-hover);
}

.password-btn:focus {
	outline: 2px solid var(--color-accent);
	outline-offset: 2px;
}

/* WordPress default password form (e.g. when shown inside content) – same popup style */
.post-password-form {
	position: fixed;
	inset: 0;
	z-index: 10000;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	padding: var(--space-lg);
	box-sizing: border-box;
}

.post-password-form::before {
	content: '';
	position: absolute;
	inset: 0;
	background: rgba(10, 25, 47, 0.75);
	backdrop-filter: blur(12px);
	-webkit-backdrop-filter: blur(12px);
	z-index: 0;
}

.post-password-form > p {
	width: 100%;
	max-width: 420px;
	margin: 0;
	padding: var(--space-md) var(--space-2xl);
	background: var(--color-bg-card);
	border: 1px solid var(--color-border);
	box-shadow: 0 20px 60px rgba(0, 0, 0, 0.4);
	position: relative;
	z-index: 1;
	box-sizing: border-box;
}

.post-password-form > p:first-child {
	border-radius: var(--radius-xl) var(--radius-xl) 0 0;
	padding-bottom: var(--space-sm);
	font-family: var(--font-primary);
	font-size: var(--text-h4);
	font-weight: 600;
	color: var(--color-text);
}

.post-password-form > p:last-child {
	border-radius: 0 0 var(--radius-xl) var(--radius-xl);
	border-top: none;
	padding-top: var(--space-lg);
}

.post-password-form > p:only-child,
.post-password-form > p:first-child:last-child {
	border-radius: var(--radius-xl);
	border-top: 1px solid var(--color-border);
}

.post-password-form label {
	display: block;
	font-size: var(--text-small);
	font-weight: 500;
	color: var(--color-text);
	margin-bottom: var(--space-sm);
}

.post-password-form input[type="password"] {
	width: 100%;
	padding: var(--space-md) var(--space-lg);
	font-family: var(--font-secondary);
	font-size: var(--text-body);
	color: var(--color-text);
	background: var(--color-bg);
	border: 1px solid var(--color-border-light);
	border-radius: var(--radius-md);
	box-sizing: border-box;
	margin-bottom: var(--space-md);
}

.post-password-form input[type="password"]:focus {
	outline: none;
	border-color: var(--color-accent);
	box-shadow: 0 0 0 2px rgba(0, 128, 255, 0.25);
}

.post-password-form input[type="submit"] {
	padding: var(--space-md) var(--space-xl);
	font-family: var(--font-primary);
	font-size: var(--text-btn);
	font-weight: 600;
	color: var(--color-text);
	background: var(--gradient-primary);
	border: 1px solid var(--color-accent);
	border-radius: var(--radius-md);
	cursor: pointer;
	transition: background 0.2s;
}

.post-password-form input[type="submit"]:hover {
	background: var(--gradient-primary-hover);
}



.cs-title-image-puzzle {
  position: relative;
  padding: 80px 0;
  
}

.cs-title-image-puzzle__inner {
  display: flex;
  flex-direction: column;
  gap: 32px;
}

.cs-title-image-puzzle__text {
  max-width: 640px;
}

.cs-title-image-puzzle__title {
  font-size: 1.72rem;
  line-height: 1.1;
  font-weight: 400;
  padding: 8px 16px;
  border: 1px solid #0080FF;
  color: #0080FF;
  background: linear-gradient(179.32deg, #001121 0.59%, #004687 240.99%);
  margin: 0 0 12px;
  width: fit-content;
  border-radius: 4px;
  
  @media(max-width: 567px){
      font-size: 18px !important;
      line-height: 26px;
      border-radius: 2px;
  }
}

.cs-title-image-puzzle__intro {
  margin: 0;
}

.cs-title-image-puzzle__image-wrap {
  position: relative;
  /*border-radius: 24px;*/
  overflow: hidden;
  
}

.cs-title-image-puzzle__image {
  display: block;
  width: 100%;
  height: auto;
}

/* Gallery grid – 2-column, natural image size (no zoom/crop) */
.cs-title-image-puzzle__gallery {
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  gap: 20px;
}

.cs-title-image-puzzle__gallery-item {
  position: relative;
  /*border-radius: 16px;*/
  overflow: hidden;
}

/* Natural size: no forced height or aspect – avoids zoomed/cropped look */
.cs-title-image-puzzle__gallery-item .cs-title-image-puzzle__image {
  width: 100%;
  height: auto;
  object-fit: contain;
  display: block;
  vertical-align: middle;
}

/* Title tube style: same font, weight 400, color #0080FF, border, radius 4px, gradient background */
/*.cs-title-image-puzzle__title-tube {*/
/*  padding: 1rem 1.25rem;*/
/*  border: 1px solid #0080FF;*/
/*  border-radius: 4px;*/
/*  background: linear-gradient(179.32deg, #001121 0.59%, #004687 240.99%);*/
/*}*/

.cs-title-image-puzzle__title-tube .cs-title-image-puzzle__title {
  font-weight: 400;
  color: #0080FF;
  margin: 0 0 0.5rem;
}

.cs-title-image-puzzle__title-tube .cs-title-image-puzzle__title:last-child,
.cs-title-image-puzzle__title-tube .cs-title-image-puzzle__intro:last-child {
  margin-bottom: 0;
}

.cs-title-image-puzzle__title-tube .cs-title-image-puzzle__intro {
  color: #0080FF;
  margin: 0;
  font-weight: 400;
}

/* Style 3 (split): 2× grid, first cell = title (tube), rest = images */
.cs-title-image-puzzle--split .cs-title-image-puzzle__inner {
  padding: 0;
}

.cs-title-image-puzzle__overlay-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
  @media (max-width: 567px){
      padding-left: 12px;
      padding-right: 12px;
  }
}

.cs-title-image-puzzle__grid-title {
  grid-column: 1;
  grid-row: 1;
}

.cs-title-image-puzzle--split .cs-title-image-puzzle__grid-title.tip-align-center {
  text-align: center;
}

.cs-title-image-puzzle--split .cs-title-image-puzzle__grid-title.tip-align-right {
  text-align: right;
}

.cs-title-image-puzzle--split .cs-title-image-puzzle__gallery-item .cs-title-image-puzzle__image {
  width: 100%;
  height: auto;
  object-fit: contain;
}

/* Style 2 (overlay): image column + title column, text vertical align */
.cs-title-image-puzzle--overlay .cs-title-image-puzzle__inner {
  flex-direction: row;
  align-items: stretch;
  gap: 48px;
}

.cs-title-image-puzzle__col {
  flex: 1 1 0;
  min-width: 0;
}

.cs-title-image-puzzle__col--image {
  display: flex;
}

.cs-title-image-puzzle__inner--image-right {
  flex-direction: row-reverse;
}

.cs-title-image-puzzle--overlay .cs-title-image-puzzle__gallery--flex-wrap {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  gap: 16px;
}

.cs-title-image-puzzle--overlay .cs-title-image-puzzle__gallery-item--auto-width .cs-title-image-puzzle__image {
  width: 100%;
  height: auto;
  object-fit: cover;
  display: block;
  vertical-align: middle;
}

.cs-title-image-puzzle--split-text-top .cs-title-image-puzzle__col--text {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
}

.cs-title-image-puzzle--split-text-middle .cs-title-image-puzzle__col--text {
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.cs-title-image-puzzle--split-text-bottom .cs-title-image-puzzle__col--text {
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}

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

.tip-align-center {
  text-align: center;
  margin-left: auto;
  margin-right: auto;
}

.tip-align-right {
  text-align: right;
  margin-left: auto;
}


/* Auto-width gallery items: flex basis 50% so two per row; large image takes full row */
.cs-title-image-puzzle__gallery-item--auto-width {
  flex: 1 1 calc(50% - 8px);
  min-width: min(100%, 280px);
  max-width: 100%;
}

@media (max-width: 768px) {
  .cs-title-image-puzzle {
    padding: 56px 0;
  }

  .cs-title-image-puzzle__title {
    font-size: 2rem;
  }

  .cs-title-image-puzzle__gallery,
  .cs-title-image-puzzle__overlay-grid {
    grid-template-columns: 1fr;
  }

  .cs-title-image-puzzle__grid-title {
    grid-column: 1;
  }

  .cs-title-image-puzzle__gallery-item--auto-width {
    flex: 1 1 100%;
    min-width: 100%;
  }

  .cs-title-image-puzzle--overlay .cs-title-image-puzzle__inner {
    flex-direction: column;
  }
}



/* ==========================================================================
   Case Study: Dashboard flow (section kicker + blocks: style 1 / 2 / 3)
   ========================================================================== */

.case-study-dfb {
	background-color: var(--color-bg);
	padding: clamp(2rem, 5vw, 3.5rem) 0;
	overflow-x: hidden;
}

.case-study-dfb__inner {
	width: 100%;
}

/* Section kicker: number + text white; pipe only blue */
.case-study-dfb__sec-head {
	margin-top: 0;
	margin-bottom: var(--space-2xl);
}

.case-study-dfb__sec-title {
	font-family: var(--font-primary);
	font-weight: 700;
	color: var(--color-text);
	margin: 0;
	line-height: 1.2;
}

.case-study-dfb__sec-num,
.case-study-dfb__sec-kicker-txt {
	color: var(--color-text);
}

.case-study-dfb__sec-pipe {
	color: var(--color-accent-blue);
	margin: 0 0.35em;
	font-weight: 400;
}

.case-study-dfb__sec-head--split {
	display: grid;
	grid-template-columns: 1fr 1fr;
	align-items: center;
	gap: var(--space-lg) var(--space-2xl);
}

.case-study-dfb__sec-head--split.case-study-dfb__sec-head--align-left .case-study-dfb__sec-kicker-col,
.case-study-dfb__sec-head--split.case-study-dfb__sec-head--align-left .case-study-dfb__sec-aside-col {
	text-align: left;
}

.case-study-dfb__sec-head--split.case-study-dfb__sec-head--align-center .case-study-dfb__sec-kicker-col,
.case-study-dfb__sec-head--split.case-study-dfb__sec-head--align-center .case-study-dfb__sec-aside-col {
	text-align: center;
}

.case-study-dfb__sec-head--split.case-study-dfb__sec-head--align-right .case-study-dfb__sec-kicker-col,
.case-study-dfb__sec-head--split.case-study-dfb__sec-head--align-right .case-study-dfb__sec-aside-col {
	text-align: right;
}

.case-study-dfb__sec-head:not(.case-study-dfb__sec-head--split).case-study-dfb__sec-head--align-left {
	text-align: left;
}

.case-study-dfb__sec-head:not(.case-study-dfb__sec-head--split).case-study-dfb__sec-head--align-center {
	text-align: center;
}

.case-study-dfb__sec-head:not(.case-study-dfb__sec-head--split).case-study-dfb__sec-head--align-right {
	text-align: right;
}

.case-study-dfb__sec-aside {
	font-family: var(--font-secondary);
	font-size: clamp(0.875rem, 2vw, 1rem);
	color: #b6b6b6;
	margin: 0;
	line-height: 1.45;
}

/* Section main title (first line, above kicker) */
.case-study-dfb__sec-main-title {
	font-family: var(--font-primary);
	font-weight: 700;
	color: var(--color-text);
	margin: 0 0 var(--space-lg);
	line-height: 1.2;
}

/* More space before blocks when there is no kicker row */
.case-study-dfb__inner:not(:has(.case-study-dfb__sec-head)) .case-study-dfb__sec-main-title {
	margin-bottom: var(--space-2xl);
}

.case-study-dfb__sec-main-title--align-left {
	text-align: left;
}

.case-study-dfb__sec-main-title--align-center {
	text-align: center;
}

.case-study-dfb__sec-main-title--align-right {
	text-align: right;
}

@media (min-width: 769px) {
	.case-study-dfb__sec-title--size-32 {
		font-size: 32px;
	}

	.case-study-dfb__sec-title--size-44 {
		font-size: 44px;
	}

	.case-study-dfb__sec-main-title--size-32 {
		font-size: 32px;
	}

	.case-study-dfb__sec-main-title--size-44 {
		font-size: 44px;
	}
}

@media (max-width: 768px) {
	.case-study-dfb__sec-title--size-32 {
		font-size: clamp(1.25rem, 5.5vw, 2rem);
	}

	.case-study-dfb__sec-title--size-44 {
		font-size: clamp(1.35rem, 6vw, 2.5rem);
	}

	.case-study-dfb__sec-main-title--size-32 {
		font-size: clamp(1.25rem, 5.5vw, 2rem);
	}

	.case-study-dfb__sec-main-title--size-44 {
		font-size: clamp(1.35rem, 6vw, 2.5rem);
	}

	.case-study-dfb__sec-head--split {
		grid-template-columns: 1fr;
		align-items: start;
	}
}

/* Block kicker reuses .case-study-dfb__sec-title + pipe spans */
.case-study-dfb__blk-kicker {
	margin: 0;
	font-weight: 500;
}

.case-study-dfb__blk-head--column .case-study-dfb__blk-kicker {
	margin-bottom: var(--space-sm);
}

/* Blocks */
.case-study-dfb__block {
	margin-bottom: var(--space-3xl);
}

.case-study-dfb__block:last-child {
	margin-bottom: 0;
}

/* Per-block header */
.case-study-dfb__blk-head {
	margin-bottom: var(--space-xl);
}

.case-study-dfb__blk-head--row .case-study-dfb__blk-head-row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	align-items: center;
	gap: var(--space-lg) var(--space-2xl);
}

.case-study-dfb__blk-head--column.case-study-dfb__blk-head--text-left {
	text-align: left;
}

.case-study-dfb__blk-head--column.case-study-dfb__blk-head--text-center {
	text-align: center;
}

.case-study-dfb__blk-head--column.case-study-dfb__blk-head--text-right {
	text-align: right;
}

.case-study-dfb__blk-head-desc {
	font-family: var(--font-secondary);
	font-size: clamp(0.875rem, 1.8vw, 1rem);
	color: #b6b6b6;
	line-height: 1.5;
	margin: 0;
}

.case-study-dfb__blk-s1-media img {
	width: 100%;
	max-width: 100%;
	height: auto;
	display: block;
	border-radius: 8px;
}

/* Two-column rows (style 2) */
.case-study-dfb__group {
	margin-bottom: 0;
}

.case-study-dfb__row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--space-2xl);
	align-items: start;
}

.case-study-dfb__row--valign-center {
	/*align-items: center;*/
}

.case-study-dfb__row--content-left {
	grid-template-columns: 1.1fr 1fr;
}

.case-study-dfb__row--content-right {
	grid-template-columns: 1fr 1.1fr;
}

.case-study-dfb__col {
	min-width: 0;
}

.case-study-dfb__media img {
	width: 100%;
	max-width: 100%;
	height: auto;
	display: block;
	border-radius: 8px;
}

/* Filled boxes: 2-col blue + optional drill row */
.case-study-dfb__filled {
	display: flex;
	flex-direction: column;
	gap: var(--space-md);
}

.case-study-dfb__filled-eyebrow {
	font-family: var(--font-secondary);
	font-size: clamp(1rem, 2vw, 1.15rem);
	font-weight: 500;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: var(--color-accent-blue);
	margin: 0;
	line-height: 1.3;
}

.case-study-dfb__filled-title {
	font-family: var(--font-secondary);
	font-size: clamp(0.9375rem, 2vw, 1.0625rem);
	color: #fff;
	margin: 0;
	line-height: 1.45;
}

.case-study-dfb__filled-blue-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 16px;
	margin: 0;
}

.case-study-dfb__filled-blue-cell {
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 4.5rem;
	padding: var(--space-md);
	background: var(--color-accent);
	border-radius: 8px;
	font-family: var(--font-secondary);
	font-size: clamp(1rem, 2vw, 1.15rem);
	font-weight: 500;
	color: #fff;
	text-align: center;
	line-height: 1.35;
	box-sizing: border-box;
}

.case-study-dfb__drill-label {
	font-family: var(--font-primary);
	font-size: 1rem;
	font-weight: 400;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: #ffffff;
	margin: var(--space-sm) 0 0;
}

.case-study-dfb__drill-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 12px;
	margin-top: var(--space-md);
}

.case-study-dfb__drill-cell {
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 3rem;
	padding: var(--space-sm) var(--space-sm);
	border-radius: 8px;
	border: 1px solid rgba(51, 153, 255, 0.75);
	background: linear-gradient(180deg, rgba(0, 50, 90, 0.55) 0%, rgba(0, 10, 24, 0.9) 100%);
	font-family: var(--font-secondary);
	font-size: clamp(0.75rem, 1.5vw, 0.875rem);
	color: #fff;
	text-align: center;
	line-height: 1.35;
	box-sizing: border-box;
}

/* Vertical bar card + piped row (blue | only) */
.case-study-dfb__vb-card {
	background-color: var(--color-bg-card);
	border: 1px solid rgba(51, 153, 255, 0.35);
	border-radius: 12px;
	padding: var(--space-lg) var(--space-xl);
	box-sizing: border-box;
	box-shadow: 0 0 0 1px rgba(51, 153, 255, 0.12);
}

.case-study-dfb__vb-card-title {
	font-family: var(--font-primary);
	font-size: clamp(1rem, 2vw, 1.125rem);
	font-weight: 500;
	color: var(--color-accent-blue);
	margin: 0 0 var(--space-md);
	line-height: 1.35;
}

.case-study-dfb__vb-rule {
	height: 1px;
	background: rgba(255, 255, 255, 0.12);
	margin-bottom: var(--space-md);
}

.case-study-dfb__vb-piped-row {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.25rem 0.15rem;
	margin: 0;
	font-family: var(--font-secondary);
	font-size: clamp(0.875rem, 1.5vw, 1rem);
	line-height: 1.45;
}

.case-study-dfb__pipe {
	color: var(--color-accent-blue);
	font-weight: 400;
	margin: 0 0.35em;
}

.case-study-dfb__piped-text {
	color: #fff;
}

.case-study-dfb__vb-footer {
	font-family: var(--font-secondary);
	font-size: clamp(0.8125rem, 1.5vw, 0.9375rem);
	font-style: italic;
	color: var(--color-accent-blue);
	margin: var(--space-md) 0 0;
	line-height: 1.45;
}

/* Style 3: blue box grid */
.case-study-dfb__bb-grid {
	display: grid;
	gap: var(--space-md);
}

.case-study-dfb__bb-grid--cols-3 {
	grid-template-columns: repeat(3, minmax(0, 1fr));
}

.case-study-dfb__bb-item {
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 5.5rem;
	padding: var(--space-lg) var(--space-md);
	background: var(--color-accent);
	border-radius: 8px;
	box-sizing: border-box;
	text-align: center;
}

.case-study-dfb__bb-item-inner {
	display: inline-flex;
	flex-wrap: wrap;
	align-items: baseline;
	justify-content: center;
	gap: 0.35rem 0.5rem;
	font-family: var(--font-third);
	color: #fff;
	line-height: 1.35;
}

.case-study-dfb__bb-num {
	font-size: clamp(1.125rem, 2.5vw, 1.375rem);
	font-weight: 500;
}

.case-study-dfb__bb-text {
	font-size: clamp(0.875rem, 2vw, 1rem);
	font-weight: 500;
}

@media (max-width: 991px) {
	.case-study-dfb__row,
	.case-study-dfb__row--content-left,
	.case-study-dfb__row--content-right {
		grid-template-columns: 1fr 1fr;
	}

	.case-study-dfb__blk-head--row .case-study-dfb__blk-head-row {
		grid-template-columns: 1fr;
		align-items: start;
	}
}

@media (max-width: 768px) {
	.case-study-dfb__row,
	.case-study-dfb__row--content-left,
	.case-study-dfb__row--content-right {
		grid-template-columns: 1fr;
		gap: var(--space-xl);
	}

	.case-study-dfb__row--mobile-reverse {
		display: flex;
		flex-direction: column-reverse;
	}

	.case-study-dfb__filled-blue-grid {
		grid-template-columns: 1fr;
	}

	.case-study-dfb__drill-grid {
		grid-template-columns: 1fr;
	}

	.case-study-dfb__bb-grid--cols-3 {
		grid-template-columns: 1fr;
	}
}


/* ==========================================================================
   Case Study: Stacked content section (title + repeater: image or content box)
   ========================================================================== */
.case-study-section--stacked_content_section {
	overflow-x: hidden;
}

.case-study-stacked-content {
	background-color: var(--color-bg);
	padding: clamp(2rem, 5vw, 3.5rem) 0;
}

.case-study-stacked-content__outer.gs-container {
	max-width: min(var(--container-max), var(--scs-section-inner-max, var(--container-max)));
	margin-left: auto;
	margin-right: auto;
}

.case-study-stacked-content__header {
	margin-bottom: var(--space-2xl);
}

.case-study-stacked-content__header--left {
	text-align: left;
}

.case-study-stacked-content__header--center {
	text-align: center;
}

.case-study-stacked-content__header--right {
	text-align: right;
}

.case-study-stacked-content__title {
	font-family: var(--font-primary);
	font-size: var(--text-h2);
	font-weight: 700;
	color: var(--color-text);
	margin: 0;
	line-height: var(--leading-snug);
}

.case-study-stacked-content__repeater {
	display: flex;
	flex-direction: column;
	gap: clamp(1.25rem, 3vw, 2rem);
}

.case-study-stacked-content__row {
	width: 100%;
}

.case-study-stacked-content__row-inner {
	width: 100%;
	max-width: min(100%, var(--scs-item-inner-max, 100%));
	margin-left: auto;
	margin-right: auto;
}

.case-study-stacked-content__figure {
	margin: 0;
	width: 100%;
}

.case-study-stacked-content__img {
	display: block;
	width: 100%;
	max-width: 100%;
	height: auto;
	border-radius: var(--radius-lg);
	object-fit: contain;
}

.case-study-stacked-content__box {
	background-color: var(--color-bg-card);
	border: 1px solid rgba(51, 153, 255, 0.65);
	border-radius: var(--radius-xl);
	padding: clamp(1.25rem, 3vw, 2rem);
	box-sizing: border-box;
	text-align: center;
	box-shadow: 0 12px 28px rgba(0, 0, 0, 0.25);
}

.case-study-stacked-content__box-heading {
	font-family: var(--font-primary);
	font-size: clamp(1.35rem, 2.2vw, 2rem);
	font-weight: 500;
	color: var(--color-text);
	margin: 0 0 var(--space-md);
	line-height: 1.3;
}

.case-study-stacked-content__box-intro {
	font-family: var(--font-third);
	margin: 0;
	line-height: 1.55;
}

/* Normal: ~16–18px, light body text */
.case-study-stacked-content__box-intro--normal {
	font-size: clamp(1rem, 2.2vw, 1.125rem);
	color: var(--color-text);
}

/* Accent: ~18–20px, blue */
.case-study-stacked-content__box-intro--accent {
	font-size: clamp(1.125rem, 2.5vw, 1.25rem);
	color: var(--color-accent-blue);
	font-weight: 500;
}

@media (max-width: 768px) {
	.case-study-stacked-content__header {
		margin-bottom: var(--space-xl);
	}

	.case-study-stacked-content__box {
		padding: var(--space-lg) var(--space-md);
	}
}
