/*
 * ALI Base Stylesheet
 * Shared design tokens, reset, typography, animations, and components
 * used across all custom page templates.
 */

/* ── Karla (body font, self-hosted variable) ─────── */
@font-face {
	font-family: 'Karla';
	src: url('../../fonts/Karla-VariableFont_wght.ttf') format('truetype');
	font-weight: 100 900;
	font-display: swap;
}
@font-face {
	font-family: 'Karla';
	src: url('../../fonts/Karla-Italic-VariableFont_wght.ttf') format('truetype');
	font-weight: 100 900;
	font-style: italic;
	font-display: swap;
}

/* ── CSS Variables ───────────────────────────────── */
:root {
	--ali-teal: #3DAABD;
	--ali-teal-deep: #2B8A9A;
	--ali-teal-glow: rgba(61, 170, 189, .15);
	--ali-navy: #1a2332;
	--ali-navy-light: #243044;
	--ali-cream: #faf9f7;
	--ali-warm-gray: #f2f0ed;
	--ali-text: #2c2c2c;
	--ali-text-secondary: #5a5a5a;
	--ali-radius: 16px;
	--ali-radius-sm: 10px;
	--ali-link-ext: var(--ali-teal);
	--ali-link-ext-deep: var(--ali-teal-deep);

	/* cs- block tokens (used by icon-cards, team-grid, partner-logos, intro-text) */
	--cs-teal: #3DAABD;
	--cs-teal-deep: #2E8E9E;
	--cs-teal-glow: rgba(61, 170, 189, .10);
	--cs-teal-soft: #EAF6F8;
	--cs-teal-pale: #D4EEF2;
	--cs-navy: #1a2332;
	--cs-navy-light: #243044;
	--cs-cream: #FDFCF9;
	--cs-warm: #F5F2ED;
	--cs-sky: #E8F4F6;
	--cs-text: #2c2c2c;
	--cs-text-secondary: #5a5a5a;
	--cs-radius: 18px;
	--cs-radius-sm: 12px;
}

/* ── Skip to Content ─────────────────────────────── */
.skip-to-content {
	position: absolute;
	left: -9999px;
	top: auto;
	width: 1px;
	height: 1px;
	overflow: hidden;
	z-index: 10000;
	background: var(--ali-navy);
	color: #fff;
	padding: .8rem 1.5rem;
	font-size: .95rem;
	text-decoration: none;
	border-radius: 0 0 var(--ali-radius-sm) 0;
}
.skip-to-content:focus {
	position: fixed;
	left: 0;
	top: 0;
	width: auto;
	height: auto;
	overflow: visible;
}

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

html {
	font-size: 112.5%;
}
body {
	margin: 0;
	font-family: 'Karla', sans-serif;
	color: var(--ali-text);
	line-height: 1.6;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

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

a {
	color: var(--ali-teal);
	text-decoration: none;
	transition: color .25s ease;
}

a:hover {
	color: var(--ali-teal-deep);
}

/* Preserve Gutenberg/Elementor button styles */
a.wp-block-button__link,
a.wp-element-button,
a.elementor-button {
	color: #fff;
	text-decoration: none;
	transition: filter .25s ease, transform .25s ease, box-shadow .25s ease;
}

a.wp-block-button__link:hover,
a.wp-element-button:hover,
a.elementor-button:hover {
	color: #fff;
	filter: brightness(1.15);
	transform: translateY(-1px);
	box-shadow: 0 4px 12px rgba(0, 0, 0, .15);
}

/* ── Typography ──────────────────────────────────── */
h1, h2, h3, h4, h5, h6 {
	font-family: 'DM Serif Display', serif;
	font-weight: 400;
	line-height: 1.2;
}

/* ── Animations ──────────────────────────────────── */
@keyframes fadeInUp {
	from { opacity: 0; transform: translateY(40px); }
	to   { opacity: 1; transform: translateY(0); }
}

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

@keyframes float {
	0%, 100% { transform: translateY(0); }
	50%      { transform: translateY(-8px); }
}

@keyframes scaleIn {
	from { opacity: 0; transform: scale(.92); }
	to   { opacity: 1; transform: scale(1); }
}

/* ── Scroll reveal ───────────────────────────────── */
.reveal,
.sc-reveal,
.cs-reveal {
	opacity: 0;
	transform: translateY(30px);
	transition: opacity .7s cubic-bezier(.22, 1, .36, 1), transform .7s cubic-bezier(.22, 1, .36, 1);
}

.reveal.visible,
.sc-reveal.visible,
.cs-reveal.visible {
	opacity: 1;
	transform: translateY(0);
}

/* Delay variants (all naming conventions) */
.reveal-d1,
.reveal-delay-1,
.reveal.delay-1,
.sc-reveal.delay-1,
.cs-reveal.delay-1 { transition-delay: .1s; }
.reveal-d2,
.reveal-delay-2,
.reveal.delay-2,
.sc-reveal.delay-2,
.cs-reveal.delay-2 { transition-delay: .2s; }
.reveal-d3,
.reveal-delay-3,
.reveal.delay-3,
.sc-reveal.delay-3,
.cs-reveal.delay-3 { transition-delay: .3s; }
.sc-reveal.delay-4,
.cs-reveal.delay-4 { transition-delay: .4s; }

/* ── Section label ───────────────────────────────── */
.ali-label {
	font-family: 'Karla', sans-serif;
	font-size: .7rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .15em;
	color: var(--block-accent, var(--ali-teal));
	margin: 0 0 16px;
	display: flex;
	align-items: center;
	gap: 10px;
}

.ali-label::before {
	content: '';
	width: 24px;
	height: 2px;
	background: var(--block-accent, var(--ali-teal));
	border-radius: 1px;
}
.ali-label--no-line::before { display: none; }

/* ── cs-label (block variant) ───────────────────── */
.cs-label {
	display: inline-flex; align-items: center; gap: 8px;
	font-size: .8rem; font-weight: 600; letter-spacing: .15em;
	text-transform: uppercase; color: var(--block-accent, var(--cs-teal));
}
.cs-label::before {
	content: ''; width: 28px; height: 2px;
	background: var(--block-accent, var(--cs-teal)); border-radius: 2px;
}

/* ── cs-page wrapper ────────────────────────────── */
.cs-page *, .cs-page *::before, .cs-page *::after { box-sizing: border-box; }
.cs-page {
	font-family: 'Karla', sans-serif;
	color: var(--cs-text);
	line-height: 1.7;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	overflow-x: hidden;
	background: #fff;
}
.cs-page a:not([class*="__cta"]):not([class*="__btn"]):not(.ali-btn):not(.cs-hero-cta) { color: var(--cs-teal); text-decoration: none; transition: color .25s ease; }
.cs-page a:not([class*="__cta"]):not([class*="__btn"]):not(.ali-btn):not(.cs-hero-cta):hover { color: var(--cs-teal-deep); }
.cs-page > .alignwide {
	max-width: 1140px;
	margin-inline: auto;
}
.cs-page h1, .cs-page h2, .cs-page h3 { font-family: 'DM Serif Display', serif; font-weight: 400; line-height: 1.2; }

/* ── cs-intro (intro-text block) ────────────────── */
.cs-intro {
	padding: 100px 40px;
	background: var(--cs-cream);
	position: relative;
	overflow: hidden;
}
.cs-intro-inner {
	max-width: 800px; margin: 0 auto;
	text-align: center;
	position: relative; z-index: 1;
}
.cs-intro p {
	font-size: 1.1rem;
	color: var(--cs-text-secondary);
	margin: 0 0 20px;
	line-height: 1.85;
}
.cs-intro p strong { color: var(--cs-text); font-weight: 600; }

/* Background variants */
.cs-intro--bg-white  { background: #fff; }
.cs-intro--bg-cream  { background: var(--cs-cream, #FDFCF9); }
.cs-intro--bg-sky    { background: #E8F4F6; }
.cs-intro--bg-warm   { background: #F5F2ED; }
.cs-intro--bg-navy   { background: var(--ali-navy, #1a2332); }

/* Dark background text inversion */
.cs-intro--bg-navy p                  { color: rgba(255,255,255,.85); }
.cs-intro--bg-navy p strong           { color: #fff; }
.cs-intro--bg-navy .ali-heading       { color: #fff; }
.cs-intro--bg-navy .ali-label         { color: var(--block-accent, var(--ali-teal)); }

/* Font size variants */
.cs-intro--size-small p  { font-size: 0.95rem; }
.cs-intro--size-large p  { font-size: 1.25rem; line-height: 1.9; }

/* Max width variants */
.cs-intro--width-narrow .cs-intro-inner { max-width: 640px; }
.cs-intro--width-wide .cs-intro-inner   { max-width: 960px; }

/* Decorative circle */
.cs-intro__circle {
	position: absolute;
	top: -80px; right: -80px;
	width: 320px; height: 320px;
	border-radius: 50%;
	background: var(--block-accent-glow, rgba(61,170,189,.06));
	pointer-events: none;
	z-index: 0;
}

/* Label + heading spacing */
.cs-intro .ali-label   { margin-bottom: 12px; justify-content: center; font-size: .7rem; color: var(--block-accent, var(--ali-teal)); }
.cs-intro .ali-heading { margin-bottom: 24px; }

@media (max-width: 768px) {
	.cs-intro { padding: 60px 24px; }
	.cs-intro p { font-size: 1rem; }
	.cs-intro--size-large p { font-size: 1.1rem; }
}

/* ── Section heading ─────────────────────────────── */
.ali-heading {
	font-family: 'DM Serif Display', serif;
	font-size: clamp(1.8rem, 3vw, 2.4rem);
	font-weight: 400;
	color: var(--ali-navy);
	margin: 0 0 28px;
	line-height: 1.15;
}
h3.ali-heading {
	font-size: clamp(1.3rem, 2vw, 1.6rem);
}

/* ── Pill button ─────────────────────────────────── */
.ali-btn {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	background: var(--ali-teal);
	color: #fff;
	font-family: 'Karla', sans-serif;
	font-size: .82rem;
	font-weight: 600;
	letter-spacing: .04em;
	padding: 12px 28px;
	border: none;
	border-radius: 50px;
	cursor: pointer;
	transition: all .3s cubic-bezier(.22, 1, .36, 1);
	text-decoration: none;
}

.ali-btn::after {
	content: '\2192';
	transition: transform .3s ease;
}

.ali-btn:hover {
	background: var(--ali-teal-deep);
	color: #fff;
	transform: translateY(-2px);
	box-shadow: 0 6px 24px rgba(61, 170, 189, .3);
}

.ali-btn:hover::after {
	transform: translateX(3px);
}

.ali-btn--outline {
	background: transparent;
	border: 2px solid rgba(255, 255, 255, .25);
	color: #fff;
}

.ali-btn--outline:hover {
	background: rgba(255, 255, 255, .08);
	border-color: rgba(255, 255, 255, .5);
	color: #fff;
	box-shadow: 0 6px 24px rgba(0, 0, 0, .15);
}

.ali-btn--white {
	background: #fff;
	color: var(--ali-navy);
}

.ali-btn--white:hover {
	background: #fff;
	color: var(--ali-teal-deep);
	box-shadow: 0 8px 30px rgba(0, 0, 0, .15);
}

.ali-btn--outline-teal {
	background: transparent;
	border: 1.5px solid var(--block-accent, var(--ali-teal));
	color: var(--block-accent, var(--ali-teal)) !important;
}
.ali-btn--outline-teal:hover {
	background: var(--block-accent, var(--ali-teal));
	color: #fff !important;
	box-shadow: 0 6px 24px var(--block-accent-glow, rgba(61,170,189,.3));
}

.ali-btn--outline-secondary {
	background: transparent;
	border: 1.5px solid var(--block-accent, var(--ali-teal));
	color: var(--block-accent, var(--ali-teal)) !important;
}
.ali-btn--outline-secondary:hover {
	background: var(--block-accent, var(--ali-teal));
	color: #fff !important;
}

.ali-btn--ghost {
	background: none;
	border: none;
	color: var(--block-accent, var(--ali-teal)) !important;
	font-weight: 600;
	padding: 10px 8px;
	text-decoration: none !important;
}
.ali-btn--ghost:hover {
	text-decoration: underline !important;
}

.ali-btn--amber {
	background: #E8A817;
	color: #fff !important;
}
.ali-btn--amber:hover {
	background: #C48E0E;
	color: #fff !important;
	box-shadow: 0 6px 24px rgba(232, 168, 23, .3);
}

.ali-btn--sm {
	padding: 10px 22px;
	font-size: .78rem;
}

/* ── Glassmorphism card ──────────────────────────── */
.ali-glass {
	background: rgba(255, 255, 255, .06);
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
	border: 1px solid rgba(255, 255, 255, .1);
	border-radius: 12px;
}

/* ── FAQ accordion ───────────────────────────────── */
.ali-faq-item {
	border-bottom: 1px solid rgba(0, 0, 0, .08);
}

.ali-faq-item:first-child {
	border-top: 1px solid rgba(0, 0, 0, .08);
}

button.ali-faq-toggle {
	width: 100%;
	background: transparent;
	border: none;
	color: var(--ali-navy);
	font-family: 'Karla', sans-serif;
	font-size: .95rem;
	font-weight: 500;
	text-align: left;
	padding: 20px 44px 20px 0;
	cursor: pointer;
	position: relative;
	line-height: 1.45;
	transition: color .25s ease;
	border-radius: 0;
	box-shadow: none;
	margin: 0;
}

button.ali-faq-toggle:hover {
	color: var(--block-accent-deep, var(--ali-teal-deep));
	background: transparent;
}

.ali-faq-toggle::after {
	content: '';
	position: absolute;
	right: 0;
	top: 50%;
	width: 28px;
	height: 28px;
	transform: translateY(-50%);
	border-radius: 50%;
	border: 1px solid rgba(0, 0, 0, .1);
	background: transparent;
	transition: all .3s cubic-bezier(.22, 1, .36, 1);
}

.ali-faq-toggle::before {
	content: '';
	position: absolute;
	right: 0;
	top: 50%;
	width: 28px;
	height: 28px;
	transform: translateY(-50%);
	background: var(--block-accent, var(--ali-teal));
	z-index: 1;
	transition: transform .3s ease;
	-webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'%3E%3Crect x='5.25' y='1' width='1.5' height='10' rx='.75'/%3E%3Crect x='1' y='5.25' width='10' height='1.5' rx='.75'/%3E%3C/svg%3E");
	mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'%3E%3Crect x='5.25' y='1' width='1.5' height='10' rx='.75'/%3E%3Crect x='1' y='5.25' width='10' height='1.5' rx='.75'/%3E%3C/svg%3E");
	-webkit-mask-size: 12px 12px;
	mask-size: 12px 12px;
	-webkit-mask-repeat: no-repeat;
	mask-repeat: no-repeat;
	-webkit-mask-position: center;
	mask-position: center;
}

.ali-faq-item.open .ali-faq-toggle::before {
	transform: translateY(-50%) rotate(180deg);
	-webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'%3E%3Crect x='1' y='5.25' width='10' height='1.5' rx='.75'/%3E%3C/svg%3E");
	mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'%3E%3Crect x='1' y='5.25' width='10' height='1.5' rx='.75'/%3E%3C/svg%3E");
}

.ali-faq-item.open .ali-faq-toggle::after {
	background: var(--block-accent-glow, var(--ali-teal-glow));
	border-color: var(--block-accent-glow, rgba(61, 170, 189, .3));
}

.ali-faq-content {
	max-height: 0;
	overflow: hidden;
	transition: max-height .4s cubic-bezier(.22, 1, .36, 1), padding .4s ease;
}

.ali-faq-item.open .ali-faq-content {
	max-height: 600px;
	padding-bottom: 22px;
}

.ali-faq-content p {
	margin: 0 0 12px;
	font-size: .9rem;
	line-height: 1.8;
	color: var(--ali-text-secondary);
}

.ali-faq-content p:last-child {
	margin-bottom: 0;
}


/* ── External link indicator ────────────────────── */
/* Matches external links (target="_blank") inside article content areas.
   Excludes share buttons, theme buttons, WP/Elementor buttons, image-only links.
   Color controlled by --ali-link-ext / --ali-link-ext-deep variables. */
.ali-ext-link,
.ali-page-content a[target="_blank"]:not(.ali-share__btn):not(.ali-btn):not(.wp-block-button__link):not(.wp-element-button):not(.elementor-button),
.ali-single-article a[target="_blank"]:not(.ali-share__btn):not(.ali-btn):not(.wp-block-button__link):not(.wp-element-button):not(.elementor-button),
.blog-single-article a[target="_blank"]:not(.ali-share__btn):not(.ali-btn):not(.wp-block-button__link):not(.wp-element-button):not(.elementor-button),
.riv-article a[target="_blank"]:not(.ali-share__btn):not(.ali-btn):not(.wp-block-button__link):not(.wp-element-button):not(.elementor-button),
.agg-article a[target="_blank"]:not(.ali-share__btn):not(.ali-btn):not(.wp-block-button__link):not(.wp-element-button):not(.elementor-button),
.com-article a[target="_blank"]:not(.ali-share__btn):not(.ali-btn):not(.wp-block-button__link):not(.wp-element-button):not(.elementor-button) {
	color: var(--ali-link-ext);
	text-decoration: none;
	border-bottom: 2px solid var(--ali-link-ext);
	padding: 1px 3px 2px;
	border-radius: 3px;
	transition: color .25s ease, background .25s ease, border-color .25s ease;
}

.ali-ext-link:hover,
.ali-page-content a[target="_blank"]:not(.ali-share__btn):not(.ali-btn):not(.wp-block-button__link):not(.wp-element-button):not(.elementor-button):hover,
.ali-single-article a[target="_blank"]:not(.ali-share__btn):not(.ali-btn):not(.wp-block-button__link):not(.wp-element-button):not(.elementor-button):hover,
.blog-single-article a[target="_blank"]:not(.ali-share__btn):not(.ali-btn):not(.wp-block-button__link):not(.wp-element-button):not(.elementor-button):hover,
.riv-article a[target="_blank"]:not(.ali-share__btn):not(.ali-btn):not(.wp-block-button__link):not(.wp-element-button):not(.elementor-button):hover,
.agg-article a[target="_blank"]:not(.ali-share__btn):not(.ali-btn):not(.wp-block-button__link):not(.wp-element-button):not(.elementor-button):hover,
.com-article a[target="_blank"]:not(.ali-share__btn):not(.ali-btn):not(.wp-block-button__link):not(.wp-element-button):not(.elementor-button):hover {
	color: #fff;
	background: var(--ali-link-ext);
	border-color: var(--ali-link-ext);
}

.ali-ext-link::after,
.ali-page-content a[target="_blank"]:not(.ali-share__btn):not(.ali-btn):not(.wp-block-button__link):not(.wp-element-button):not(.elementor-button)::after,
.ali-single-article a[target="_blank"]:not(.ali-share__btn):not(.ali-btn):not(.wp-block-button__link):not(.wp-element-button):not(.elementor-button)::after,
.blog-single-article a[target="_blank"]:not(.ali-share__btn):not(.ali-btn):not(.wp-block-button__link):not(.wp-element-button):not(.elementor-button)::after,
.riv-article a[target="_blank"]:not(.ali-share__btn):not(.ali-btn):not(.wp-block-button__link):not(.wp-element-button):not(.elementor-button)::after,
.agg-article a[target="_blank"]:not(.ali-share__btn):not(.ali-btn):not(.wp-block-button__link):not(.wp-element-button):not(.elementor-button)::after,
.com-article a[target="_blank"]:not(.ali-share__btn):not(.ali-btn):not(.wp-block-button__link):not(.wp-element-button):not(.elementor-button)::after {
	content: "";
	display: inline-block;
	width: .6em;
	height: .6em;
	margin-left: .25em;
	position: relative;
	top: -.05em;
	background: currentColor;
	-webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M18 13v6a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2V8a2 2 0 0 1 2-2h6'/%3E%3Cpolyline points='15 3 21 3 21 9'/%3E%3Cline x1='10' y1='14' x2='21' y2='3'/%3E%3C/svg%3E");
	-webkit-mask-size: contain;
	-webkit-mask-repeat: no-repeat;
	mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M18 13v6a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2V8a2 2 0 0 1 2-2h6'/%3E%3Cpolyline points='15 3 21 3 21 9'/%3E%3Cline x1='10' y1='14' x2='21' y2='3'/%3E%3C/svg%3E");
	mask-size: contain;
	mask-repeat: no-repeat;
}

/* ── Urgent Banner (site-wide via Customizer) ────── */
.hp-banner {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	z-index: 400;
	padding: 12px 24px;
	text-align: center;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 16px;
	flex-wrap: wrap;
}
body:has(.hp-banner) .ali-header-minimal {
	top: 44px;
}
.hp-banner-text {
	font-family: 'Karla', sans-serif;
	font-size: .9rem;
	font-weight: 600;
	color: #fff;
	margin: 0;
}
.hp-banner-btn {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	background: rgba(255,255,255,.2);
	color: #fff !important;
	font-family: 'Karla', sans-serif;
	font-size: .78rem;
	font-weight: 700;
	letter-spacing: .04em;
	padding: 8px 20px;
	border-radius: 50px;
	text-decoration: none !important;
	transition: background .25s ease;
	white-space: nowrap;
}
.hp-banner-btn:hover {
	background: rgba(255,255,255,.35);
	color: #fff !important;
}
.hp-banner-btn::after {
	content: '\2192';
}

/* ── Complianz Cookie Banner ────────────────────── */
#cmplz-cookiebanner-container .cmplz-cookiebanner {
	font-family: 'Karla', sans-serif !important;
	background: var(--ali-navy) !important;
	color: #fff !important;
	border: none !important;
	border-radius: var(--ali-radius) !important;
	box-shadow: 0 8px 32px rgba(0,0,0,.25) !important;
	padding: 1.5rem 2rem !important;
	max-width: 480px !important;
}
/* Close (X) button */
#cmplz-cookiebanner-container .cmplz-cookiebanner .cmplz-close {
	background: none !important;
	border: none !important;
	outline: none !important;
	box-shadow: none !important;
	color: rgba(255,255,255,.5) !important;
	font-size: 1.2rem !important;
	padding: .25rem !important;
	line-height: 1 !important;
	cursor: pointer !important;
}
#cmplz-cookiebanner-container .cmplz-cookiebanner .cmplz-close:hover,
#cmplz-cookiebanner-container .cmplz-cookiebanner .cmplz-close:focus {
	color: #fff !important;
	outline: none !important;
	box-shadow: none !important;
}
#cmplz-cookiebanner-container .cmplz-cookiebanner .cmplz-title {
	font-family: 'DM Serif Display', serif !important;
	font-size: 1.15rem !important;
	color: #fff !important;
	margin-bottom: .4rem !important;
}
#cmplz-cookiebanner-container .cmplz-cookiebanner .cmplz-message {
	font-size: .85rem !important;
	line-height: 1.5 !important;
	color: rgba(255,255,255,.75) !important;
	margin-bottom: .8rem !important;
}
#cmplz-cookiebanner-container .cmplz-cookiebanner .cmplz-message a {
	color: var(--ali-teal) !important;
	text-decoration: underline !important;
}
#cmplz-cookiebanner-container .cmplz-cookiebanner .cmplz-message a:hover {
	color: #fff !important;
}
#cmplz-cookiebanner-container .cmplz-cookiebanner .cmplz-buttons {
	display: flex !important;
	flex-wrap: wrap !important;
	gap: .4rem !important;
	align-items: center !important;
}
#cmplz-cookiebanner-container .cmplz-cookiebanner .cmplz-btn {
	font-family: 'Karla', sans-serif !important;
	font-weight: 700 !important;
	font-size: .8rem !important;
	border-radius: 50px !important;
	padding: .5rem 1.2rem !important;
	border: none !important;
	cursor: pointer !important;
	transition: background .2s ease, transform .15s ease !important;
	text-transform: none !important;
	letter-spacing: 0 !important;
	line-height: 1.3 !important;
	flex: none !important;
	width: auto !important;
}
#cmplz-cookiebanner-container .cmplz-cookiebanner .cmplz-btn:hover {
	transform: translateY(-1px) !important;
}
#cmplz-cookiebanner-container .cmplz-cookiebanner .cmplz-btn.cmplz-accept {
	background: var(--ali-teal) !important;
	color: #fff !important;
}
#cmplz-cookiebanner-container .cmplz-cookiebanner .cmplz-btn.cmplz-accept:hover {
	background: var(--ali-teal-deep) !important;
}
#cmplz-cookiebanner-container .cmplz-cookiebanner .cmplz-btn.cmplz-deny {
	background: rgba(255,255,255,.1) !important;
	color: rgba(255,255,255,.7) !important;
	border: 1px solid rgba(255,255,255,.15) !important;
}
#cmplz-cookiebanner-container .cmplz-cookiebanner .cmplz-btn.cmplz-deny:hover {
	background: rgba(255,255,255,.18) !important;
	color: #fff !important;
}
#cmplz-cookiebanner-container .cmplz-cookiebanner .cmplz-btn.cmplz-view-preferences,
#cmplz-cookiebanner-container .cmplz-cookiebanner .cmplz-btn.cmplz-save-preferences {
	background: transparent !important;
	color: rgba(255,255,255,.6) !important;
	text-decoration: underline !important;
	padding: .3rem .6rem !important;
	font-size: .75rem !important;
	font-weight: 500 !important;
}
#cmplz-cookiebanner-container .cmplz-cookiebanner .cmplz-btn.cmplz-view-preferences:hover,
#cmplz-cookiebanner-container .cmplz-cookiebanner .cmplz-btn.cmplz-save-preferences:hover {
	color: #fff !important;
}
/* Category toggles in preferences view */
#cmplz-cookiebanner-container .cmplz-cookiebanner .cmplz-categories {
	margin: .8rem 0 !important;
}
#cmplz-cookiebanner-container .cmplz-cookiebanner .cmplz-category {
	border-color: rgba(255,255,255,.12) !important;
	padding: .5rem 0 !important;
}
#cmplz-cookiebanner-container .cmplz-cookiebanner .cmplz-category .cmplz-category-header .cmplz-category-title {
	color: #fff !important;
	font-weight: 600 !important;
	font-size: .85rem !important;
}
#cmplz-cookiebanner-container .cmplz-cookiebanner .cmplz-category .cmplz-description {
	color: rgba(255,255,255,.55) !important;
	font-size: .78rem !important;
}
/* Toggle switch — teal when active */
#cmplz-cookiebanner-container .cmplz-cookiebanner .cmplz-toggle .cmplz-slider {
	background: rgba(255,255,255,.2) !important;
}
#cmplz-cookiebanner-container .cmplz-cookiebanner .cmplz-toggle input:checked + .cmplz-slider {
	background: var(--ali-teal) !important;
}
/* ── Gutenberg columns containment ─────────────── */
.wp-block-columns {
	max-width: 1140px;
	margin-left: auto;
	margin-right: auto;
	padding: 80px 24px;
}

/* Mobile adjustments */
@media (max-width: 900px) {
	.wp-block-columns {
		padding-top: 60px;
		padding-bottom: 60px;
		padding-left: 0;
		padding-right: 0;
	}
	#cmplz-cookiebanner-container .cmplz-cookiebanner {
		max-width: calc(100% - 1.5rem) !important;
		padding: 1.2rem 1.4rem !important;
		margin: .75rem !important;
		border-radius: var(--ali-radius-sm) !important;
	}
	#cmplz-cookiebanner-container .cmplz-cookiebanner .cmplz-buttons {
		flex-direction: column !important;
	}
	#cmplz-cookiebanner-container .cmplz-cookiebanner .cmplz-btn {
		width: 100% !important;
		text-align: center !important;
	}
}

/* ── Content Block ──────────────────────────────── */
.ali-content-block:not(.alignwide):not(.alignfull) {
	max-width: var(--wp--style--global--content-size, 780px);
	margin-left: auto;
	margin-right: auto;
}
.ali-content-block-inner {
	max-width: 1140px;
	margin: 0 auto;
	padding: 60px 24px;
}
.ali-content-block--narrow .ali-content-block-inner {
	max-width: 780px;
}

/* Background colors */
.ali-content-block--bg-cream { background: var(--ali-cream, #FDFCF9); }
.ali-content-block--bg-sky   { background: #E8F4F6; }
.ali-content-block--bg-warm  { background: #F5F2ED; }
.ali-content-block--bg-navy  { background: var(--ali-navy, #1a2332); color: #fff; }
.ali-content-block--bg-navy .ali-label { color: rgba(255,255,255,.7); }
.ali-content-block--bg-navy .ali-heading { color: #fff; }
.ali-content-block--bg-navy .ali-content-block__body p,
.ali-content-block--bg-navy .ali-content-block__body li { color: rgba(255,255,255,.85); }
.ali-content-block--bg-navy .ali-content-block__body a { color: #7dd3e1; text-decoration-color: rgba(125,211,225,.3); }
.ali-content-block--bg-navy .ali-content-block__body a:hover { text-decoration-color: #7dd3e1; }
.ali-content-block--bg-navy .ali-content-block__legal { color: rgba(255,255,255,.6); }

/* Center header */
.ali-content-block--center .ali-label { justify-content: center; }
.ali-content-block--center .ali-heading { text-align: center; }

/* 2-column body (opt-in via toggle, desktop only) */
.ali-content-block--two-cols .ali-content-block__body {
	column-count: 2;
	column-gap: 40px;
}

/* Body typography (moved from sostienici.css) */
.ali-content-block__body p {
	margin: 0 0 16px;
	font-size: .93rem;
	line-height: 1.8;
	color: var(--ali-text-secondary);
}
.ali-content-block__body strong {
	color: var(--ali-text);
}
.ali-content-block__body ul {
	padding-left: 0;
	margin: 0 0 20px;
	list-style: none;
}
.ali-content-block__body li {
	margin-bottom: 14px;
	font-size: .93rem;
	line-height: 1.8;
	position: relative;
	padding-left: 20px;
	color: var(--ali-text-secondary);
}
.ali-content-block__body li::before {
	content: '';
	position: absolute;
	left: 0;
	top: 11px;
	width: 6px;
	height: 6px;
	border-radius: 50%;
	background: var(--block-accent, var(--ali-teal));
}
.ali-content-block__body a {
	color: var(--ali-teal-deep);
	text-decoration: underline;
	text-underline-offset: 3px;
	text-decoration-color: rgba(61,170,189,.3);
	transition: text-decoration-color .2s;
}
.ali-content-block__body a:hover {
	text-decoration-color: var(--ali-teal-deep);
}
.ali-content-block__legal {
	font-size: .82rem;
	color: #999;
	margin-top: 24px;
	border-top: 1px solid rgba(0,0,0,.06);
	padding-top: 16px;
}

@media (max-width: 900px) {
	.ali-content-block--two-cols .ali-content-block__body {
		column-count: 1;
	}
	.ali-content-block-inner {
		padding: 40px 18px;
	}
}

/* ── Form Embed ─────────────────────────────────── */
.cs-form-embed:not(.alignwide):not(.alignfull) {
	max-width: var(--wp--style--global--content-size, 780px);
	margin-left: auto;
	margin-right: auto;
}
.cs-form-embed { padding: 90px 40px; }
.cs-form-embed-inner { max-width: 1140px; margin: 0 auto; }
.cs-form-embed-header {
	margin-bottom: 24px;
}
.cs-form-embed-header h2 {
	font-family: 'DM Serif Display', serif;
	font-size: clamp(1.6rem, 2.5vw, 2rem);
	font-weight: 400;
	color: var(--ali-navy, #1a2332);
	margin: 0 0 12px;
}
.cs-form-embed-header p {
	font-size: .92rem;
	color: var(--ali-text-secondary, #5a5a5a);
	margin: 0;
	line-height: 1.7;
}

/* ── Form embed: centered header ── */
.cs-form-embed-header--center { text-align: center; }
.cs-form-embed-header--center .cs-label { justify-content: center; }
.cs-form-embed-header--center .cs-label::before { display: none; }

/* ── Form embed: background variants ── */
.cs-form-embed--bg-cream { background: var(--ali-cream, #FDFCF9); }
.cs-form-embed--bg-sky { background: #E8F4F6; }
.cs-form-embed--bg-warm { background: #F5F2ED; }
.cs-form-embed--bg-navy { background: var(--ali-navy, #1a2332); }
.cs-form-embed--bg-navy .cs-form-embed-header h2 { color: #fff; }
.cs-form-embed--bg-navy .cs-form-embed-header p { color: rgba(255,255,255,.8); }
.cs-form-embed--bg-navy .cs-label { color: rgba(255,255,255,.7); }

/* ── Form embed: side image layout ── */
.cs-form-embed--has-side-image .cs-form-embed-content {
	display: grid;
	grid-template-columns: 1fr 360px;
	gap: 48px;
	align-items: start;
}
.cs-form-embed-side-image {
	display: flex;
	justify-content: center;
	align-items: flex-start;
	padding-top: 20px;
}
.cs-form-embed-side-image img {
	width: 100%;
	height: auto;
	animation: aliFloat 5s ease-in-out infinite;
	filter: drop-shadow(0 16px 40px rgba(0,0,0,.12));
	transition: transform .4s ease;
}
.cs-form-embed-side-image img:hover { transform: scale(1.03); animation-play-state: paused; }

@media (max-width: 900px) {
	.cs-form-embed { padding: 60px 20px; }
	.cs-form-embed--has-side-image .cs-form-embed-content {
		grid-template-columns: 1fr;
		gap: 32px;
	}
	.cs-form-embed-side-image { justify-content: center; }
	.cs-form-embed-side-image img { max-width: 260px !important; }
}

/* ── Text & Sidebar ─────────────────────────────── */
.cs-text-sidebar {
	background: #fff;
	padding: 72px 24px 80px;
}
.cs-text-sidebar--cream { background: var(--ali-cream, #FDFCFA); }
.cs-text-sidebar--sky   { background: #E8F4F6; }
.cs-text-sidebar--warm  { background: #F5F2ED; }
.cs-text-sidebar--navy  { background: var(--ali-navy, #1a2332); color: #fff; }
.cs-text-sidebar--navy h2,
.cs-text-sidebar--navy h3 { color: #fff; }
.cs-text-sidebar--navy .cs-text-sidebar-body,
.cs-text-sidebar--navy .cs-text-sidebar-step p { color: rgba(255,255,255,.85); }
.cs-text-sidebar--navy .cs-text-sidebar-box { background: rgba(255,255,255,.08); border-left-color: rgba(255,255,255,.2); }
.cs-text-sidebar-inner {
	max-width: 1140px;
	margin: 0 auto;
	display: grid;
	grid-template-columns: 1.1fr .9fr;
	gap: 56px;
	align-items: start;
}
.cs-text-sidebar-body p {
	margin: 0 0 16px;
	font-size: .95rem;
	line-height: 1.8;
	color: var(--ali-text-secondary, #5a5a5a);
}
.cs-text-sidebar-body strong {
	color: var(--ali-text, #2c2c2c);
}
.cs-text-sidebar h2 {
	font-family: 'DM Serif Display', serif;
	font-size: clamp(1.8rem, 3vw, 2.5rem);
	font-weight: 400;
	color: var(--ali-navy, #1a2332);
	margin: 0 0 24px;
	line-height: 1.12;
}
.cs-text-sidebar-box {
	background: var(--block-accent-pale, rgba(61,170,189,.08));
	border-radius: 16px;
	padding: 28px 28px 24px;
	border-left: 3px solid var(--block-accent, var(--ali-teal));
}
.cs-text-sidebar-box h3 {
	font-family: 'DM Serif Display', serif;
	font-size: 1.15rem;
	font-weight: 400;
	color: var(--ali-navy, #1a2332);
	margin: 0 0 14px;
}
.cs-text-sidebar-steps {
	display: flex;
	flex-direction: column;
	gap: 16px;
}
.cs-text-sidebar-step {
	display: flex;
	align-items: flex-start;
	gap: 14px;
}
.cs-text-sidebar-num {
	flex-shrink: 0;
	width: 32px;
	height: 32px;
	border-radius: 50%;
	background: var(--block-accent, var(--ali-teal));
	color: #fff;
	font-size: .78rem;
	font-weight: 700;
	display: flex;
	align-items: center;
	justify-content: center;
}
.cs-text-sidebar-step p {
	margin: 0;
	font-size: .88rem;
	color: var(--ali-text-secondary, #5a5a5a);
	line-height: 1.6;
}
.cs-text-sidebar-step strong {
	color: var(--ali-text, #2c2c2c);
}

@media (max-width: 900px) {
	.cs-text-sidebar-inner {
		grid-template-columns: 1fr;
		gap: 36px;
	}
}

/* ── Share Buttons ──────────────────────────────── */
.cs-share {
	background: #fff;
	padding: 56px 24px;
	text-align: center;
}
.cs-share-inner {
	max-width: 600px;
	margin: 0 auto;
}
.cs-share h2 {
	font-family: 'DM Serif Display', serif;
	font-size: clamp(1.3rem, 2vw, 1.6rem);
	font-weight: 400;
	color: var(--ali-navy, #1a2332);
	margin: 0 0 12px;
}
.cs-share p {
	font-size: .92rem;
	color: var(--ali-text-secondary, #5a5a5a);
	margin: 0 0 24px;
	line-height: 1.7;
}
.cs-share-links {
	display: flex;
	justify-content: center;
	gap: 12px;
	flex-wrap: wrap;
}
.cs-share-btn {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 10px 20px;
	border-radius: 50px;
	font-family: 'Karla', sans-serif;
	font-size: .82rem;
	font-weight: 600;
	text-decoration: none !important;
	transition: all .3s cubic-bezier(.22,1,.36,1);
	border: none;
	cursor: pointer;
}
.cs-share-btn svg { flex-shrink: 0; }
.cs-share-btn--whatsapp { background: #25D366; color: #fff !important; }
.cs-share-btn--whatsapp:hover { background: #1FAD55; transform: translateY(-1px); box-shadow: 0 6px 20px rgba(37,211,102,.25); color: #fff !important; }
.cs-share-btn--facebook { background: #1877F2; color: #fff !important; }
.cs-share-btn--facebook:hover { background: #0C63D4; transform: translateY(-1px); box-shadow: 0 6px 20px rgba(24,119,242,.25); color: #fff !important; }
.cs-share-btn--linkedin { background: #0A66C2; color: #fff !important; }
.cs-share-btn--linkedin:hover { background: #004182; transform: translateY(-1px); box-shadow: 0 6px 20px rgba(10,102,194,.25); color: #fff !important; }
.cs-share-btn--x { background: var(--ali-navy, #1a2332); color: #fff !important; }
.cs-share-btn--x:hover { background: #000; transform: translateY(-1px); color: #fff !important; }
.cs-share-btn--telegram { background: #26A5E4; color: #fff !important; }
.cs-share-btn--telegram:hover { background: #1D8ABF; transform: translateY(-1px); box-shadow: 0 6px 20px rgba(38,165,228,.25); color: #fff !important; }
.cs-share-btn--email { background: #6B7280; color: #fff !important; }
.cs-share-btn--email:hover { background: #4B5563; transform: translateY(-1px); box-shadow: 0 6px 20px rgba(107,114,128,.25); color: #fff !important; }
.cs-share-btn--link { background: #fff; color: var(--ali-text, #2c2c2c) !important; border: 1px solid rgba(0,0,0,.1); }
.cs-share-btn--link:hover { border-color: var(--ali-teal); color: var(--ali-teal) !important; transform: translateY(-1px); }

/* ── Share: background variants ── */
.cs-share--bg-cream { background: var(--ali-cream, #FDFCF9); }
.cs-share--bg-sky   { background: #E8F4F6; }
.cs-share--bg-warm  { background: #F5F2ED; }
.cs-share--bg-navy  { background: var(--ali-navy, #1a2332); }
.cs-share--bg-navy h2 { color: #fff; }
.cs-share--bg-navy p  { color: rgba(255,255,255,.8); }

/* ── Share: display mode ── */
.cs-share--icon-only .cs-share-btn { padding: 10px 14px; gap: 0; }
.cs-share--label-only .cs-share-btn svg { display: none; }

/* ── Share: accent / custom color mode ── */
.cs-share--accent .cs-share-btn,
.cs-share--custom .cs-share-btn {
	background: var(--share-btn-bg, #3DAABD) !important;
	color: #fff !important;
	border-color: transparent !important;
}
.cs-share--accent .cs-share-btn:hover,
.cs-share--custom .cs-share-btn:hover {
	filter: brightness(.88);
	transform: translateY(-1px);
	box-shadow: 0 6px 20px rgba(0,0,0,.15);
}

/* ── Share: copy feedback ── */
.cs-share-btn--link.is-copied {
	background: #22c55e !important;
	color: #fff !important;
	border-color: transparent !important;
}
.cs-share-btn--link.is-copied svg { display: none; }
.cs-share-btn--link.is-copied::before {
	content: "";
	display: inline-block;
	width: 16px; height: 16px;
	background: #fff;
	-webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E");
	-webkit-mask-size: contain;
	mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E");
	mask-size: contain;
	flex-shrink: 0;
}

/* ── Share: navy bg + official buttons ── */
.cs-share--bg-navy .cs-share-btn--link {
	background: rgba(255,255,255,.1);
	color: #fff !important;
	border-color: rgba(255,255,255,.2);
}
.cs-share--bg-navy .cs-share-btn--link:hover {
	background: rgba(255,255,255,.2);
	color: #fff !important;
	border-color: rgba(255,255,255,.4);
}

@media (max-width: 520px) {
	.cs-share-btn span {
		display: none;
	}
	.cs-share-btn {
		padding: 10px 14px;
		gap: 0;
	}
}

/* ── Image + Text block (ali/image-text) ─────────── */
.cs-image-text {
	padding: 80px 40px;
	background: #fff;
	position: relative;
	overflow: hidden;
}
.cs-image-text--bg-cream { background: var(--ali-cream); }
.cs-image-text--bg-sky   { background: #E8F4F6; }
.cs-image-text--bg-warm  { background: #F5F2ED; }
.cs-image-text--bg-navy  { background: var(--ali-navy); color: #fff; }
.cs-image-text--bg-navy h2,
.cs-image-text--bg-navy h3            { color: #fff; }
.cs-image-text--bg-navy .cs-image-text__body,
.cs-image-text--bg-navy .cs-image-text__highlight { color: rgba(255,255,255,.85); }

.cs-image-text__circle {
	position: absolute;
	top: -100px; right: -100px;
	width: 350px; height: 350px;
	border-radius: 50%;
	background: var(--block-accent-glow, rgba(61,170,189,.06));
	pointer-events: none;
}

.cs-image-text__inner {
	max-width: 1140px;
	margin: 0 auto;
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 60px;
	align-items: center;
}
.cs-image-text--split-33-67 .cs-image-text__inner { grid-template-columns: 1fr 2fr; }
.cs-image-text--split-40-60 .cs-image-text__inner { grid-template-columns: 2fr 3fr; }
.cs-image-text--split-60-40 .cs-image-text__inner { grid-template-columns: 3fr 2fr; }
.cs-image-text--split-67-33 .cs-image-text__inner { grid-template-columns: 2fr 1fr; }
.cs-image-text__inner--reverse .cs-image-text__img  { order: 2; }
.cs-image-text__inner--reverse .cs-image-text__text { order: 1; }

.cs-image-text__img {
	border-radius: var(--ali-radius, 16px);
	overflow: hidden;
	box-shadow: 0 8px 40px rgba(0,0,0,.08);
}
.cs-image-text__img img,
.cs-image-text__img video {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	aspect-ratio: 16/10;
	transition: transform .5s cubic-bezier(.22,1,.36,1);
}
.cs-image-text__img:hover img,
.cs-image-text__img:hover video { transform: scale(1.03); }
/* Tilt variant overrides the default scale hover */
.cs-image-text__img--tilt:hover img { transform: rotate(-1.5deg) scale(1.04); }

.cs-image-text__video-wrap { position: relative; }
.cs-image-text__play {
	position: absolute;
	inset: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	background: none;
	border: none;
	cursor: pointer;
	padding: 0;
	z-index: 1;
}
.cs-image-text__play::before {
	content: "";
	width: 68px;
	height: 68px;
	border-radius: 50%;
	background: rgba(0,0,0,.55);
	position: absolute;
	transition: background .2s;
}
.cs-image-text__play:hover::before { background: rgba(0,0,0,.7); }
.cs-image-text__play svg { position: relative; margin-left: 3px; }
.cs-image-text__play.is-playing { display: none; }

.cs-image-text__text h2 {
	font-size: clamp(2rem, 3.5vw, 2.8rem);
	color: var(--ali-navy);
	margin: 16px 0 24px;
}
.cs-image-text__text h3 {
	font-family: 'DM Serif Display', serif;
	font-size: clamp(1.3rem, 2vw, 1.6rem);
	color: var(--ali-navy);
	margin: 16px 0 24px;
	line-height: 1.25;
}
.cs-image-text__body p {
	font-size: 1.02rem;
	color: var(--ali-text-secondary, #5a5a5a);
	margin: 0 0 16px;
	line-height: 1.8;
}
.cs-image-text__body p strong { color: var(--ali-text, #2c2c2c); font-weight: 600; }
.cs-image-text__body p:last-child { margin-bottom: 0; }
.cs-image-text__body p a { text-decoration: underline; text-underline-offset: 2px; }

.cs-image-text__highlight {
	font-family: 'DM Serif Display', serif;
	font-size: 1.35rem;
	color: var(--ali-navy);
	line-height: 1.45;
	margin: 0 0 16px;
	font-weight: 400;
}

.cs-image-text__cta {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	background: var(--block-accent, var(--ali-teal));
	color: #fff;
	font-size: .85rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .05em;
	padding: 12px 28px;
	border-radius: 10px;
	margin-top: 20px;
	transition: all .3s cubic-bezier(.22,1,.36,1);
	text-decoration: none;
}
.cs-image-text__cta:hover {
	background: var(--block-accent-deep, #2e8a9a);
	transform: translateY(-1px);
	box-shadow: 0 6px 24px var(--block-accent-glow, rgba(61,170,189,.25));
	color: #fff;
}

@media (max-width: 900px) {
	.cs-image-text { padding: 60px 24px; }
	.cs-image-text .cs-image-text__inner { grid-template-columns: 1fr; gap: 32px; }
	.cs-image-text__inner--reverse .cs-image-text__img  { order: 0; }
	.cs-image-text__inner--reverse .cs-image-text__text { order: 0; }
}

/* ── Partner Logos block (ali/partner-logos) ──────── */
.cs-partner {
	padding: 70px 40px 80px;
	background: var(--ali-cream);
}
.cs-partner-inner { max-width: 1140px; margin: 0 auto; }
.cs-partner-header {
	text-align: center;
	margin-bottom: 48px;
}
.cs-partner-header .cs-label { justify-content: center; }
.cs-partner-header .cs-label::before { display: none; }
.cs-partner-header h2 {
	font-size: clamp(1.5rem, 2.5vw, 2rem);
	color: var(--ali-navy);
	margin: 16px 0 0;
}
.cs-partner-header p {
	font-size: .88rem;
	color: var(--ali-text-secondary, #5a5a5a);
	max-width: 700px;
	margin: 16px auto 0;
	line-height: 1.7;
}
.cs-partner-grid {
	display: flex;
	align-items: center;
	justify-content: center;
	flex-wrap: wrap;
	gap: 32px 56px;
}
.cs-partner-logo {
	display: block;
	height: 56px;
	object-fit: contain;
	transition: all .3s ease;
}
.cs-partner--bg-cream { background: var(--wp--preset--color--cream, #faf9f7); }
.cs-partner--grayscale .cs-partner-logo { filter: grayscale(100%) opacity(.5); transition: filter .3s ease; }
.cs-partner--grayscale .cs-partner-logo:hover { filter: grayscale(0%) opacity(1); }
@media (max-width: 768px) {
	.cs-partner { padding: 50px 24px 60px; }
	.cs-partner-grid { gap: 32px; }
}

/* ── Floating Image block ──────────────────────── */
@keyframes aliFloat {
	0%, 100% { transform: translateY(0) rotate(0deg); }
	50% { transform: translateY(-10px) rotate(2deg); }
}
.ali-floating-image {
	padding: 60px 24px;
	display: flex;
	justify-content: center;
	align-items: center;
}
.ali-floating-image--bg-cream { background: var(--ali-cream, #faf9f7); }
.ali-floating-image--bg-sky { background: #E8F2FA; }
.ali-floating-image--bg-warm { background: #F9F5F0; }
.ali-floating-image img {
	width: 100%;
	height: auto;
	animation: aliFloat 5s ease-in-out infinite;
	filter: drop-shadow(0 16px 40px rgba(0,0,0,.12));
	transition: transform .4s ease;
}
.ali-floating-image img:hover { transform: scale(1.03); }

/* ── Card Section block ────────────────────────── */
.ali-card-section {
	padding: 100px 24px;
	position: relative;
	overflow: hidden;
}
.ali-card-section--bg-cream { background: var(--ali-cream, #faf9f7); }
.ali-card-section--bg-sky { background: #E8F2FA; }
.ali-card-section--bg-warm { background: #F9F5F0; }
.ali-card-section--bg-navy { background: var(--ali-navy, #1a2332); color: #fff; }
.ali-card-section__header {
	text-align: center;
	max-width: 740px;
	margin: 0 auto 48px;
}
.ali-card-section__header .ali-label { justify-content: center; }
.ali-card-section__header .ali-label::before { display: none; }
.ali-card-section__desc {
	color: var(--ali-text-secondary, #5a5a5a);
	margin-top: 16px;
	font-size: 1.02rem;
	line-height: 1.7;
}
.ali-card-section--bg-navy .ali-card-section__desc { color: rgba(255,255,255,.65); }
.ali-card-section__circle {
	position: absolute;
	top: -80px;
	right: -80px;
	width: 320px;
	height: 320px;
	border-radius: 50%;
	background: var(--block-accent-glow, rgba(61,170,189,.08));
	pointer-events: none;
}
.ali-card-section__card {
	max-width: 1140px;
	margin: 0 auto;
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 0;
	background: #fff;
	border-radius: 18px;
	overflow: hidden;
}
.ali-card-section__card--elevated { box-shadow: 0 8px 40px rgba(0,0,0,.06); }
.ali-card-section__card--flat { border: 1px solid rgba(0,0,0,.08); }
.ali-card-section__card--outlined { border-top: 4px solid var(--block-accent, var(--ali-teal, #3DAABD)); }
.ali-card-section__card--text-only { grid-template-columns: 1fr; }
.ali-card-section__card--reverse .ali-card-section__text { order: 2; }
.ali-card-section__card--reverse .ali-card-section__media { order: 1; }
.ali-card-section__card--split-33-67 { grid-template-columns: 1fr 2fr; }
.ali-card-section__card--split-40-60 { grid-template-columns: 2fr 3fr; }
.ali-card-section__card--split-60-40 { grid-template-columns: 3fr 2fr; }
.ali-card-section__card--split-67-33 { grid-template-columns: 2fr 1fr; }
.ali-card-section__text {
	padding: 48px;
	display: flex;
	flex-direction: column;
	justify-content: center;
}
.ali-card-section__body h3 {
	font-family: 'DM Serif Display', serif;
	font-weight: 400;
	font-size: clamp(1.3rem, 2vw, 1.6rem);
	color: var(--block-accent, var(--ali-teal, #3DAABD));
	margin: 0 0 16px;
	line-height: 1.3;
}
.ali-card-section__body h4 {
	font-family: 'DM Serif Display', serif;
	font-weight: 400;
	font-size: clamp(1.1rem, 1.5vw, 1.25rem);
	color: var(--ali-navy, #1a2332);
	margin: 32px 0 12px;
	line-height: 1.3;
}
.ali-card-section__body p {
	color: var(--ali-text-secondary, #5a5a5a);
	line-height: 1.8;
	margin: 0 0 16px;
}
.ali-card-section__body p:last-child { margin-bottom: 0; }
.ali-card-section__cta {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	background: var(--block-accent, var(--ali-teal, #3DAABD));
	color: #fff;
	font-size: .85rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .05em;
	padding: 12px 28px;
	border-radius: 10px;
	margin-top: 24px;
	text-decoration: none;
	transition: opacity .25s ease, transform .25s ease;
}
.ali-card-section__cta:hover {
	opacity: .9;
	transform: translateY(-2px);
	color: #fff;
}
.ali-card-section__media img,
.ali-card-section__media video {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

@media (max-width: 900px) {
	.ali-card-section { padding: 64px 20px; }
	.ali-card-section__header { margin-bottom: 32px; }
	.ali-card-section__card { grid-template-columns: 1fr; }
	.ali-card-section__card--reverse .ali-card-section__media { order: -1; }
	.ali-card-section__text { padding: 32px 24px; }
}
@media (max-width: 520px) {
	.ali-card-section { padding: 48px 16px; }
	.ali-card-section__text { padding: 28px 20px; }
}

/* ── Gutenberg full-width group blocks — match custom block padding ── */
@media (max-width: 900px) {
	.wp-block-group.alignfull {
		padding-left: 20px !important;
		padding-right: 20px !important;
	}
}
@media (max-width: 520px) {
	.wp-block-group.alignfull {
		padding-left: 16px !important;
		padding-right: 16px !important;
	}
}
