/*
 * ALI Blocks — shared component CSS (base.css)
 *
 * Extracted from themes/ali/assets/css/ali-base.css:
 *   - .ali-label          (~lines 213–234)
 *   - .cs-label           (~lines 236–245)
 *   - .ali-heading        (~lines 343–354)
 *   - .ali-btn (all variants used by the 5 blocks) (~lines 356–461)
 *   - .cs-image-text (full block) (~lines 1220–1364)
 *
 * All --ali-* variables and bare brand color literals are replaced with
 * the --block-* token convention defined in tokens.css.
 * Reveal rules (.reveal / .cs-reveal / .sc-reveal) are NOT included:
 * those depend on ali-base.js which is not bundled here. Any element
 * carrying those classes will be fully visible (no opacity:0 shipped).
 */

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

.ali-label::before {
	content: '';
	width: 24px;
	height: 2px;
	background: var(--block-accent, #3DAABD);
	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, #3DAABD);
}
.cs-label::before {
	content: ''; width: 28px; height: 2px;
	background: var(--block-accent, #3DAABD); border-radius: 2px;
}

/* ── Section heading ─────────────────────────────── */
.ali-heading {
	font-family: var(--block-font-heading, 'DM Serif Display', Georgia, serif);
	font-size: clamp(1.8rem, 3vw, 2.4rem);
	font-weight: 400;
	color: var(--block-dark, #1a2332);
	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(--block-accent, #3DAABD);
	color: #fff;
	font-family: var(--block-font-body, 'Karla', sans-serif);
	font-size: .82rem;
	font-weight: 600;
	letter-spacing: .04em;
	padding: 12px 28px;
	border: none;
	border-radius: var(--block-btn-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(--block-accent-deep, #2B8A9A);
	color: #fff;
	transform: translateY(-2px);
	box-shadow: 0 6px 24px color-mix(in srgb, var(--block-accent, #3DAABD) 30%, transparent);
}

.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(--block-dark, #1a2332);
}

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

.ali-btn--outline-teal {
	background: transparent;
	border: 1.5px solid var(--block-accent, #3DAABD);
	color: var(--block-accent, #3DAABD) !important;
}
.ali-btn--outline-teal:hover {
	background: var(--block-accent, #3DAABD);
	color: #fff !important;
	box-shadow: 0 6px 24px color-mix(in srgb, var(--block-accent, #3DAABD) 30%, transparent);
}

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

.ali-btn--ghost {
	background: none;
	border: none;
	color: var(--block-accent, #3DAABD) !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;
}

/* ── 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(--block-bg, #faf9f7); }
.cs-image-text--bg-sky   { background: #E8F4F6; }
.cs-image-text--bg-warm  { background: #F5F2ED; }
.cs-image-text--bg-navy  { background: var(--block-dark, #1a2332); 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, color-mix(in srgb, var(--block-accent, #3DAABD) 6%, transparent));
	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(--block-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(--block-dark, #1a2332);
	margin: 16px 0 24px;
}
.cs-image-text__text h3 {
	font-family: var(--block-font-heading, 'DM Serif Display', Georgia, serif);
	font-size: clamp(1.3rem, 2vw, 1.6rem);
	color: var(--block-dark, #1a2332);
	margin: 16px 0 24px;
	line-height: 1.25;
}
.cs-image-text__body p {
	font-size: 1.02rem;
	color: var(--block-text-secondary, #5a5a5a);
	margin: 0 0 16px;
	line-height: 1.8;
}
.cs-image-text__body p strong { color: var(--block-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: var(--block-font-heading, 'DM Serif Display', Georgia, serif);
	font-size: 1.35rem;
	color: var(--block-dark, #1a2332);
	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, #3DAABD);
	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, #2B8A9A);
	transform: translateY(-1px);
	box-shadow: 0 6px 24px color-mix(in srgb, var(--block-accent, #3DAABD) 25%, transparent);
	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; }
}

/* ── cs-intro (intro-text block) ────────────────── */
.cs-intro {
	padding: 100px 40px;
	background: var(--block-bg, #faf9f7);
	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(--block-text-secondary, #5a5a5a);
	margin: 0 0 20px;
	line-height: 1.85;
}
.cs-intro p strong { color: var(--block-text, #2c2c2c); font-weight: 600; }

/* Background variants */
.cs-intro--bg-white  { background: #fff; }
.cs-intro--bg-cream  { background: var(--block-bg, #faf9f7); }
.cs-intro--bg-sky    { background: #E8F4F6; }
.cs-intro--bg-warm   { background: #F5F2ED; }
.cs-intro--bg-navy   { background: var(--block-dark, #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, #3DAABD); }

/* 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, color-mix(in srgb, var(--block-accent, #3DAABD) 6%, transparent));
	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, #3DAABD); }
.cs-intro .ali-heading { margin-bottom: 24px; }

/* Inline buttons */
.cs-intro__buttons { display: flex; flex-wrap: wrap; gap: 12px; justify-content: center; align-items: center; margin-top: 28px; }
.cs-intro__buttons .ali-btn--outline-teal { border-width: 1.5px; }
.cs-intro__buttons .ali-btn--filled { background: var(--block-accent, #3DAABD); color: #fff !important; }
.cs-intro__buttons .ali-btn--filled:hover { background: var(--block-accent-deep, #2B8A9A); color: #fff !important; box-shadow: 0 6px 24px color-mix(in srgb, var(--block-accent) 30%, transparent); }
.cs-intro--bg-navy .cs-intro__buttons .ali-btn--outline-secondary { border-color: rgba(255,255,255,.4); color: #fff; }
.cs-intro--bg-navy .cs-intro__buttons .ali-btn--outline-secondary:hover { background: rgba(255,255,255,.12); border-color: rgba(255,255,255,.6); }
.cs-intro--bg-navy .cs-intro__buttons .ali-btn--ghost { color: #fff; }
.cs-intro--cols-2 .cs-intro__body { column-count: 2; column-gap: 40px; text-align: left; }
.cs-intro--cols-3 .cs-intro__body { column-count: 3; column-gap: 40px; text-align: left; }
@media (max-width: 768px) {
	.cs-intro--cols-2 .cs-intro__body,
	.cs-intro--cols-3 .cs-intro__body { column-count: 1; text-align: center; }
}

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

/* ── Reveal stagger delays (shared utility) ───────── */
.reveal-d1 { transition-delay: .1s; }
.reveal-d2 { transition-delay: .2s; }
.reveal-d3 { transition-delay: .3s; }

/* ── Partner logos (partner-logos block) ─────────── */
.cs-partner {
	padding: 70px 40px 80px;
	background: var(--block-bg, #faf9f7);
}
.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(--block-dark, #1a2332);
	margin: 16px 0 0;
}
.cs-partner-header p {
	font-size: .88rem;
	color: var(--block-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, var(--block-bg, #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; }
}

/* ── Card section (card-section block) ───────────── */
.ali-card-section {
	padding: 100px 24px;
	position: relative;
	overflow: hidden;
}
.ali-card-section--bg-cream { background: var(--block-bg, #faf9f7); }
.ali-card-section--bg-sky { background: #E8F2FA; }
.ali-card-section--bg-warm { background: #F9F5F0; }
.ali-card-section--bg-navy { background: var(--block-dark, #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(--block-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, color-mix(in srgb, var(--block-accent) 8%, transparent));
	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, #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: var(--block-font-heading);
	font-weight: 400;
	font-size: clamp(1.3rem, 2vw, 1.6rem);
	color: var(--block-accent, #3DAABD);
	margin: 0 0 16px;
	line-height: 1.3;
}
.ali-card-section__body h4 {
	font-family: var(--block-font-heading);
	font-weight: 400;
	font-size: clamp(1.1rem, 1.5vw, 1.25rem);
	color: var(--block-dark, #1a2332);
	margin: 32px 0 12px;
	line-height: 1.3;
}
.ali-card-section__body p {
	color: var(--block-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, #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; }
}

/* ─────────────────────────────────────────────────────────────
   Floating animation — used by floating-image & form-embed side image
   ───────────────────────────────────────────────────────────── */
@keyframes aliFloat {
	0%, 100% { transform: translateY(0) rotate(0deg); }
	50% { transform: translateY(-10px) rotate(2deg); }
}

/* ── Glass card (donation-section) ── */
.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;
}

/* ── Reveal stagger utilities (donation-section uses reveal-delay-1..4) ── */
.reveal-delay-1 { transition-delay: .1s; }
.reveal-delay-2 { transition-delay: .2s; }
.reveal-delay-3 { transition-delay: .3s; }
.reveal-delay-4 { transition-delay: .4s; }

/* ── Floating image block ── */
.ali-floating-image {
	padding: 60px 24px;
	display: flex;
	justify-content: center;
	align-items: center;
}
.ali-floating-image--bg-cream { background: var(--block-bg, #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); }

/* ── Form embed block ── */
.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: var(--block-font-heading);
	font-size: clamp(1.6rem, 2.5vw, 2rem);
	font-weight: 400;
	color: var(--block-dark, #1a2332);
	margin: 0 0 12px;
}
.cs-form-embed-header p {
	font-size: .92rem;
	color: var(--block-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(--block-bg, #FDFCF9); }
.cs-form-embed--bg-sky { background: #E8F4F6; }
.cs-form-embed--bg-warm { background: #F5F2ED; }
.cs-form-embed--bg-navy { background: var(--block-dark, #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 and sidebar block ── */
.cs-text-sidebar {
	background: #fff;
	padding: 72px 24px 80px;
}
.cs-text-sidebar--cream { background: var(--block-bg, #FDFCFA); }
.cs-text-sidebar--sky   { background: #E8F4F6; }
.cs-text-sidebar--warm  { background: #F5F2ED; }
.cs-text-sidebar--navy  { background: var(--block-dark, #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(--block-text-secondary, #5a5a5a);
}
.cs-text-sidebar-body strong {
	color: var(--block-text, #2c2c2c);
}
.cs-text-sidebar h2 {
	font-family: var(--block-font-heading);
	font-size: clamp(1.8rem, 3vw, 2.5rem);
	font-weight: 400;
	color: var(--block-dark, #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, #3DAABD);
}
.cs-text-sidebar-box h3 {
	font-family: var(--block-font-heading);
	font-size: 1.15rem;
	font-weight: 400;
	color: var(--block-dark, #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, #3DAABD);
	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(--block-text-secondary, #5a5a5a);
	line-height: 1.6;
}
.cs-text-sidebar-step strong {
	color: var(--block-text, #2c2c2c);
}

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

/* ── Share buttons block ── */
.cs-share {
	background: #fff;
	padding: 56px 24px;
	text-align: center;
}
.cs-share-inner {
	max-width: 600px;
	margin: 0 auto;
}
.cs-share h2 {
	font-family: var(--block-font-heading);
	font-size: clamp(1.3rem, 2vw, 1.6rem);
	font-weight: 400;
	color: var(--block-dark, #1a2332);
	margin: 0 0 12px;
}
.cs-share p {
	font-size: .92rem;
	color: var(--block-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: var(--block-btn-radius, 50px);
	font-family: var(--block-font-body);
	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(--block-dark, #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(--block-text, #2c2c2c) !important; border: 1px solid rgba(0,0,0,.1); }
.cs-share-btn--link:hover { border-color: var(--block-accent, #3DAABD); color: var(--block-accent, #3DAABD) !important; transform: translateY(-1px); }

/* ── Share: background variants ── */
.cs-share--bg-cream { background: var(--block-bg, #FDFCF9); }
.cs-share--bg-sky   { background: #E8F4F6; }
.cs-share--bg-warm  { background: #F5F2ED; }
.cs-share--bg-navy  { background: var(--block-dark, #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, var(--block-accent,#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;
	}
}
