.advoc8-design .advoc8-container {
	width: min(100% - 40px, var(--advoc8-container-max));
	margin: 0 auto;
}

.advoc8-design .section {
	padding: var(--advoc8-section-spacing) 0;
}

.advoc8-design .advoc8-section {
	position: relative;
	isolation: isolate;
}

.advoc8-design .advoc8-section--dark {
	background: var(--advoc8-color-bg-dark);
	color: #ffffff;
}

.advoc8-design .advoc8-section--light {
	background: var(--advoc8-color-bg);
	color: var(--advoc8-color-text);
	border-top: 1px solid var(--advoc8-color-border);
	border-bottom: 1px solid var(--advoc8-color-border);
}

.advoc8-design h1,
.advoc8-design h2,
.advoc8-design h3,
.advoc8-design h4 {
	font-family: var(--advoc8-font-display);
	line-height: 1.05;
	letter-spacing: -0.03em;
	color: #ffffff;
}

.advoc8-design .hero h1 {
	font-size: clamp(2.9rem, 6vw, 5.35rem);
	max-width: 14ch;
	margin-bottom: 20px;
}

.advoc8-design .hero-medium h1 {
	font-size: clamp(2.2rem, 4.5vw, 3.6rem);
	max-width: 22ch;
}

.advoc8-design .hero-compact h1 {
	font-size: clamp(2rem, 4vw, 3.2rem);
	max-width: 28ch;
	margin-left: auto;
	margin-right: auto;
}

.advoc8-design .hero p {
	max-width: 60ch;
}

.advoc8-design p {
	color: rgba(255, 255, 255, 0.72);
	font-size: 1em;
	line-height: 1.78;
}

.advoc8-design .advoc8-eyebrow,
.advoc8-design .advoc8-kicker,
.advoc8-design .advoc8-stat-card span {
	display: inline-block;
	font-size: 0.8em;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	font-weight: 800;
	color: rgba(255, 255, 255, 0.62);
}

.advoc8-design .advoc8-eyebrow {
	margin-bottom: 18px;
}

.advoc8-design .advoc8-actions {
	display: flex;
	align-items: center;
	gap: 14px;
	flex-wrap: wrap;
	margin-top: 28px;
}

.advoc8-design .btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
	min-height: 46px;
	padding: var(--advoc8-btn-padding-y) var(--advoc8-btn-padding-x);
	border-radius: var(--advoc8-radius-btn);
	font-family: var(--advoc8-font-body);
	font-size: var(--advoc8-btn-font-size);
	font-weight: 700;
	line-height: 1;
	border: 1px solid transparent;
	cursor: pointer;
	transition: transform var(--_anim-dur) var(--advoc8-ease-out), box-shadow var(--_anim-dur) var(--advoc8-ease-out), border-color var(--_anim-dur) var(--advoc8-ease-out), background var(--_anim-dur) var(--advoc8-ease-out);
}

.advoc8-design .btn:hover {
	transform: translateY(-1px);
}

.advoc8-design .btn-primary {
	background: linear-gradient(135deg, var(--advoc8-color-accent), var(--advoc8-color-accent-hover));
	color: #ffffff;
	box-shadow: 0 18px 34px rgba(var(--advoc8-color-accent-rgb), 0.28);
}

.advoc8-design .btn-secondary {
	background: rgba(255, 255, 255, 0.06);
	color: #ffffff;
	border-color: rgba(255, 255, 255, 0.2);
}

.advoc8-design .advoc8-section--light .btn-secondary {
	background: var(--advoc8-color-bg);
	color: var(--advoc8-color-text);
	border-color: var(--advoc8-color-border);
}

.advoc8-design .advoc8-section-head {
	display: flex;
	align-items: end;
	justify-content: space-between;
	gap: clamp(20px, 4vw, 56px);
	margin-bottom: 28px;
}

.advoc8-design .advoc8-section-head > :first-child {
	flex: 1 1 0;
	min-width: 0;
}

.advoc8-design .advoc8-section-head h2 {
	font-size: clamp(2rem, 4vw, 3.4rem);
	max-width: none;
}

.advoc8-design .advoc8-section-head p {
	flex: 0 1 34rem;
	max-width: 34rem;
	margin: 0 0 0.35rem;
}

.advoc8-design .advoc8-section-head--stacked {
	flex-direction: column;
	align-items: start;
	justify-content: start;
	gap: 14px;
}

.advoc8-design .advoc8-section-head--stacked h2,
.advoc8-design .advoc8-section-head--stacked p {
	max-width: none;
}

.advoc8-design .advoc8-section-head--stacked p {
	flex: 0 1 auto;
	max-width: 62ch;
	margin: 0;
}

.advoc8-design .stat-grid,
.advoc8-design .advoc8-card-grid {
	display: grid;
	gap: 18px;
}

.advoc8-design .stat-grid {
	grid-template-columns: repeat(4, minmax(0, 1fr));
}

.advoc8-design .advoc8-card-grid.advoc8-cols-3 {
	grid-template-columns: repeat(3, minmax(0, 1fr));
}

.advoc8-design .advoc8-card-grid.advoc8-cols-4 {
	grid-template-columns: repeat(4, minmax(0, 1fr));
}

.advoc8-design .advoc8-card-grid > *,
.advoc8-design .stat-grid > * {
	min-width: 0;
}

.advoc8-design .advoc8-card {
	border-radius: var(--advoc8-radius-xl);
	border: 1px solid rgba(255, 255, 255, 0.1);
	background: linear-gradient(165deg, rgba(255, 255, 255, 0.06), rgba(255, 255, 255, 0.03));
	padding: 1.45rem;
	box-shadow: var(--advoc8-shadow-lg);
}

.advoc8-design .advoc8-card i {
	font-size: 1.15rem;
	margin-bottom: 14px;
	color: var(--advoc8-color-accent);
}

.advoc8-design .advoc8-card h3 {
	font-size: 1.22rem;
	margin-bottom: 10px;
	letter-spacing: -0.02em;
	color: #ffffff;
}

.advoc8-design .advoc8-stat-card strong {
	display: block;
	font-family: var(--advoc8-font-display);
	font-size: var(--advoc8-text-4xl);
	color: #ffffff;
	margin-bottom: 6px;
}

.advoc8-design .advoc8-section--light h1,
.advoc8-design .advoc8-section--light h2,
.advoc8-design .advoc8-section--light h3,
.advoc8-design .advoc8-section--light h4 {
	color: var(--advoc8-color-text);
}

.advoc8-design .advoc8-section--light p,
.advoc8-design .advoc8-section--light .advoc8-eyebrow,
.advoc8-design .advoc8-section--light .advoc8-kicker,
.advoc8-design .advoc8-section--light .advoc8-stat-card span {
	color: var(--advoc8-color-text-muted);
}

.advoc8-design .advoc8-section--light .advoc8-card {
	background: var(--advoc8-color-bg-secondary);
	border-color: var(--advoc8-color-border);
	box-shadow: none;
}

.advoc8-design .advoc8-section--light .advoc8-card h3,
.advoc8-design .advoc8-section--light .advoc8-stat-card strong {
	color: var(--advoc8-color-text);
}

@media (max-width: 1100px) {
	.advoc8-design .advoc8-section-head {
		flex-direction: column;
		align-items: start;
		justify-content: start;
		gap: 14px;
	}

	.advoc8-design .advoc8-section-head p {
		flex: 0 1 auto;
		width: 100%;
		max-width: 62ch;
		margin: 0;
	}

	.advoc8-design .stat-grid,
	.advoc8-design .advoc8-card-grid.advoc8-cols-3,
	.advoc8-design .advoc8-card-grid.advoc8-cols-4 {
		grid-template-columns: 1fr 1fr;
	}
}

@media (max-width: 780px) {
	.advoc8-design {
		font-size: 13pt;
	}

	.advoc8-design .section {
		padding: 64px 0;
	}
}

@media (max-width: 640px) {
	.advoc8-design .advoc8-container {
		width: min(100% - 24px, var(--advoc8-container-max));
	}

	.advoc8-design .stat-grid,
	.advoc8-design .advoc8-card-grid.advoc8-cols-3,
	.advoc8-design .advoc8-card-grid.advoc8-cols-4 {
		grid-template-columns: 1fr;
	}

	.advoc8-design .advoc8-actions {
		width: 100%;
	}

	.advoc8-design .advoc8-actions .btn {
		width: 100%;
	}

	.advoc8-design .advoc8-section-head h2 {
		font-size: clamp(1.85rem, 8vw, 2.6rem);
	}

	.advoc8-design .advoc8-card {
		padding-left: 1.2rem;
		padding-right: 1.2rem;
	}
}

@keyframes advoc8-fade-in {
	from {
		opacity: 0;
	}
	to {
		opacity: 1;
	}
}

@keyframes advoc8-fade-in-up {
	from {
		opacity: 0;
		transform: translate3d(0, 18px, 0);
	}
	to {
		opacity: 1;
		transform: translate3d(0, 0, 0);
	}
}

.advoc8-design .advoc8-section,
.advoc8-design .advoc8-card-grid > *,
.advoc8-design .advoc8-faq-list > *,
.advoc8-design .logo-strip > *,
.advoc8-design .story-badges > * {
	opacity: calc(1 - var(--advoc8-anim-enabled));
	will-change: opacity, transform;
}

.advoc8-design .advoc8-section.advoc8-anim-visible {
	animation: advoc8-fade-in var(--_anim-dur) var(--advoc8-ease-out) both;
}

.advoc8-design .advoc8-card-grid > *.advoc8-anim-visible,
.advoc8-design .advoc8-faq-list > *.advoc8-anim-visible,
.advoc8-design .logo-strip > *.advoc8-anim-visible,
.advoc8-design .story-badges > *.advoc8-anim-visible {
	animation: advoc8-fade-in-up var(--_anim-dur) var(--advoc8-ease-out) both;
}

.advoc8-design .advoc8-card-grid > *:nth-child(1),
.advoc8-design .advoc8-faq-list > *:nth-child(1),
.advoc8-design .logo-strip > *:nth-child(1),
.advoc8-design .story-badges > *:nth-child(1) {
	animation-delay: calc(var(--_anim-stagger) * 1);
}

.advoc8-design .advoc8-card-grid > *:nth-child(2),
.advoc8-design .advoc8-faq-list > *:nth-child(2),
.advoc8-design .logo-strip > *:nth-child(2),
.advoc8-design .story-badges > *:nth-child(2) {
	animation-delay: calc(var(--_anim-stagger) * 2);
}

.advoc8-design .advoc8-card-grid > *:nth-child(3),
.advoc8-design .advoc8-faq-list > *:nth-child(3),
.advoc8-design .logo-strip > *:nth-child(3),
.advoc8-design .story-badges > *:nth-child(3) {
	animation-delay: calc(var(--_anim-stagger) * 3);
}

.advoc8-design .advoc8-card-grid > *:nth-child(4),
.advoc8-design .advoc8-faq-list > *:nth-child(4),
.advoc8-design .logo-strip > *:nth-child(4),
.advoc8-design .story-badges > *:nth-child(4) {
	animation-delay: calc(var(--_anim-stagger) * 4);
}

/* ==========================================================================
   Hover Effects — opt-in classes for interactive micro-interactions.
   All effects respect --advoc8-anim-enabled (disabled at prefers-reduced-motion).
   Apply to cards, panels, images, icons, badges — anything interactive.
   ========================================================================== */

/* --- Rise: element lifts up, shadow deepens --- */
.advoc8-design .advoc8-hover-rise {
	transition:
		transform var(--_anim-dur) var(--advoc8-ease-out),
		box-shadow var(--_anim-dur) var(--advoc8-ease-out);
}

.advoc8-design .advoc8-hover-rise:hover {
	transform: translateY(calc(-6px * var(--advoc8-anim-enabled)));
	box-shadow:
		0 20px 40px rgba(0, 0, 0, calc(0.22 * var(--advoc8-anim-enabled))),
		0 0 0 1px rgba(255, 255, 255, calc(0.08 * var(--advoc8-anim-enabled)));
}

.advoc8-design .advoc8-section--light .advoc8-hover-rise:hover {
	box-shadow:
		0 20px 40px rgba(0, 0, 0, calc(0.08 * var(--advoc8-anim-enabled))),
		0 0 0 1px rgba(0, 0, 0, calc(0.04 * var(--advoc8-anim-enabled)));
}

/* --- Grow: element scales up subtly --- */
.advoc8-design .advoc8-hover-grow {
	transition:
		transform var(--_anim-dur) var(--advoc8-ease-out),
		box-shadow var(--_anim-dur) var(--advoc8-ease-out);
}

.advoc8-design .advoc8-hover-grow:hover {
	transform: scale(calc(1 + 0.04 * var(--advoc8-anim-enabled)));
	box-shadow:
		0 14px 28px rgba(0, 0, 0, calc(0.18 * var(--advoc8-anim-enabled)));
}

.advoc8-design .advoc8-section--light .advoc8-hover-grow:hover {
	box-shadow:
		0 14px 28px rgba(0, 0, 0, calc(0.06 * var(--advoc8-anim-enabled)));
}

/* --- Composable: rise + grow can be combined on the same element --- */

/* Utilities */
.advoc8-design .advoc8-text-center { text-align: center; }
.advoc8-design .advoc8-narrow { max-width: 680px; margin-left: auto; margin-right: auto; }
.advoc8-design .advoc8-narrow-md { max-width: 600px; margin-left: auto; margin-right: auto; }
.advoc8-design .advoc8-narrow-sm { max-width: 560px; margin-left: auto; margin-right: auto; }

/* Form panel */
.advoc8-design .advoc8-form-panel {
  border-radius: var(--advoc8-radius-xl);
  border: 1px solid rgba(255, 255, 255, 0.12);
  background: linear-gradient(165deg, rgba(255, 255, 255, 0.06), rgba(255, 255, 255, 0.03));
  padding: clamp(22px, 3vw, 32px);
}

.advoc8-design .advoc8-section--light .advoc8-form-panel {
  border-color: var(--advoc8-color-border);
  background: var(--advoc8-color-bg-secondary);
}

/* Form elements */
.advoc8-design .advoc8-form { display: grid; gap: 14px; }
.advoc8-design .advoc8-form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }

.advoc8-design .advoc8-input,
.advoc8-design .advoc8-select,
.advoc8-design .advoc8-textarea {
  min-height: 46px;
  padding: 0 14px;
  border-radius: var(--advoc8-radius-lg);
  border: 1px solid rgba(255, 255, 255, 0.18);
  background: rgba(255, 255, 255, 0.06);
  color: #ffffff;
  font-family: var(--advoc8-font-body);
  font-size: 0.9rem;
}

.advoc8-design .advoc8-textarea {
  padding: 14px;
  resize: vertical;
}

.advoc8-design .advoc8-input::placeholder,
.advoc8-design .advoc8-textarea::placeholder {
  color: rgba(255, 255, 255, 0.5);
}

.advoc8-design .advoc8-section--light .advoc8-input,
.advoc8-design .advoc8-section--light .advoc8-select,
.advoc8-design .advoc8-section--light .advoc8-textarea {
  border-color: var(--advoc8-color-border);
  background: var(--advoc8-color-bg);
  color: var(--advoc8-color-text);
}

.advoc8-design .advoc8-section--light .advoc8-input::placeholder,
.advoc8-design .advoc8-section--light .advoc8-textarea::placeholder {
  color: var(--advoc8-color-text-muted);
}

.advoc8-design .advoc8-checkbox-label {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 0.88rem;
  color: rgba(255, 255, 255, 0.7);
  cursor: pointer;
}

.advoc8-design .advoc8-section--light .advoc8-checkbox-label {
  color: var(--advoc8-color-text-muted);
}

.advoc8-design .advoc8-checkbox-label input[type="checkbox"] {
  width: 18px;
  height: 18px;
}

.advoc8-design .advoc8-form-note {
  text-align: center;
  font-size: 0.82em;
  margin-top: 12px;
}

/* Amount grid */
.advoc8-design .advoc8-amount-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
  margin-bottom: 18px;
}

.advoc8-design .advoc8-toggle-row {
  display: flex;
  gap: 10px;
  margin-bottom: 14px;
}

.advoc8-design .advoc8-toggle-row .btn { flex: 1; min-height: 44px; }

/* Blockquote */
.advoc8-design .advoc8-blockquote {
  font-family: var(--advoc8-font-display);
  font-size: clamp(1.3rem, 3vw, 1.8rem);
  line-height: 1.5;
  letter-spacing: -0.02em;
  font-style: italic;
  margin: 0;
}

.advoc8-design .advoc8-cite {
  display: block;
  margin-top: 14px;
  font-size: 0.9rem;
  font-weight: 700;
  font-style: normal;
  color: var(--advoc8-color-accent);
}

/* Checklist item */
.advoc8-design .advoc8-checklist-item {
  display: flex;
  align-items: start;
  gap: 14px;
  padding: 14px 18px;
  border-radius: var(--advoc8-radius-lg);
  border: 1px solid rgba(255, 255, 255, 0.12);
  background: rgba(255, 255, 255, 0.04);
}

.advoc8-design .advoc8-section--light .advoc8-checklist-item {
  border-color: var(--advoc8-color-border);
  background: var(--advoc8-color-bg-secondary);
}

/* Inline list item */
.advoc8-design .advoc8-inline-panel {
  padding: 14px 18px;
  border-radius: var(--advoc8-radius-lg);
  border: 1px solid rgba(255, 255, 255, 0.12);
  background: rgba(255, 255, 255, 0.04);
}

.advoc8-design .advoc8-section--light .advoc8-inline-panel {
  border-color: var(--advoc8-color-border);
  background: var(--advoc8-color-bg-secondary);
}

/* Resource badge */
.advoc8-design .advoc8-badge {
  display: inline-block;
  padding: 3px 10px;
  border-radius: var(--advoc8-radius-sm);
  font-size: 0.72rem;
  font-weight: 800;
  text-transform: uppercase;
  color: #ffffff;
  margin-bottom: 10px;
}

/* Big stat display */
.advoc8-design .advoc8-big-stat {
  font-family: var(--advoc8-font-display);
  font-size: var(--advoc8-text-5xl);
  display: block;
  color: var(--advoc8-color-accent);
}

/* Impact amount */
.advoc8-design .advoc8-impact-amount {
  font-family: var(--advoc8-font-display);
  font-size: var(--advoc8-text-4xl);
  display: block;
  color: var(--advoc8-color-accent);
}

@media (max-width: 640px) {
  .advoc8-design .advoc8-form-row { grid-template-columns: 1fr; }
  .advoc8-design .advoc8-amount-grid { grid-template-columns: repeat(2, 1fr); }
}

/* Nav list pattern (platform renders nav as ul>li>a) */
.nav ul,
.nav ul li {
  list-style: none;
  margin: 0;
  padding: 0;
}

.nav ul {
  display: flex;
  align-items: center;
  gap: inherit;
}

.nav ul li a {
  display: block;
  position: relative;
}

/* Social icons (platform pattern) */
.socialNetworks {
  display: flex;
  gap: 14px;
  margin-top: 14px;
}

.system-social-icon-link {
  color: rgba(255, 255, 255, 0.85);
  font-size: 1.3em;
  transition: color 0.2s var(--advoc8-ease-out);
}

.system-social-icon-link:hover {
  color: #ffffff;
}

.advoc8-section--light .system-social-icon-link {
  color: var(--advoc8-color-text-muted);
}

.advoc8-section--light .system-social-icon-link:hover {
  color: var(--advoc8-color-text);
}

/* Email signup */
.advoc8-design .advoc8-email-signup {
  display: flex;
  gap: 10px;
  margin-top: 18px;
  max-width: 420px;
}

.advoc8-design .advoc8-email-signup input {
  flex: 1;
  min-height: 46px;
  padding: 0 16px;
  border-radius: var(--advoc8-radius-btn);
  border: 1px solid rgba(255, 255, 255, 0.18);
  background: rgba(255, 255, 255, 0.06);
  color: #ffffff;
  font-size: 0.9rem;
  font-family: var(--advoc8-font-body);
}

.advoc8-design .advoc8-email-signup input::placeholder {
  color: rgba(255, 255, 255, 0.5);
}

.advoc8-design .advoc8-section--light .advoc8-email-signup input {
  background: var(--advoc8-color-bg-secondary);
  border-color: var(--advoc8-color-border);
  color: var(--advoc8-color-text);
}

.advoc8-design .advoc8-section--light .advoc8-email-signup input::placeholder {
  color: var(--advoc8-color-text-muted);
}

/* Info split (two-column content layout) */
.advoc8-design .info-split {
  display: grid;
  grid-template-columns: 1.05fr 0.95fr;
  gap: clamp(28px, 4vw, 48px);
  align-items: start;
}

@media (max-width: 1100px) {
  .advoc8-design .info-split {
    grid-template-columns: 1fr;
  }
}

/* Mini list (icon + text rows) */
.advoc8-design .advoc8-mini-list {
  display: grid;
  gap: 10px;
  margin-top: 18px;
}

.advoc8-design .advoc8-mini-list span {
  display: flex;
  align-items: start;
  gap: 10px;
  color: rgba(255, 255, 255, 0.7);
  line-height: 1.6;
}

.advoc8-design .advoc8-section--light .advoc8-mini-list span {
  color: var(--advoc8-color-text-muted);
}

/* Tag pill */
.advoc8-design .advoc8-tag {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 0 14px;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.14);
  background: rgba(255, 255, 255, 0.06);
  font-size: 0.83rem;
  font-weight: 700;
  letter-spacing: 0.01em;
}

.advoc8-design .advoc8-section--light .advoc8-tag {
  background: var(--advoc8-color-bg-secondary);
  border-color: var(--advoc8-color-border);
  color: var(--advoc8-color-text);
}
