/*
 * IDU Blocks — shared structural CSS.
 * Loaded BEFORE each block's style.css. Every selector is scoped to .idu-block
 * (or a child) so Salient/BuddyBoss styles neither leak in nor get overridden
 * globally.
 */

/* ---------- base ---------- */
.idu-block,
.idu-block *,
.idu-block *::before,
.idu-block *::after {
	box-sizing: border-box;
}

.idu-block {
	font-family: var(--idu-font);
	color: var(--idu-ink);
	-webkit-font-smoothing: antialiased;
}

/* ---------- section rhythm ---------- */
.idu-block.idu-section {
	padding-block: 88px;
	position: relative;
}
@media (max-width: 900px) {
	.idu-block.idu-section {
		padding-block: 64px;
	}
}
@media (max-width: 600px) {
	.idu-block.idu-section {
		padding-block: 48px;
	}
}

/* Theme backgrounds (every section supports cream / light / dark) */
.idu-block[class*="--cream"] {
	background: var(--idu-cream);
}
.idu-block[class*="--light"] {
	background: var(--idu-white);
}
.idu-block[class*="--dark"] {
	background: var(--idu-dark);
	color: var(--idu-on-dark);
}

/* ---------- container ---------- */
.idu-container {
	width: 100%;
	max-width: var(--idu-container);
	margin-inline: auto;
	padding-inline: 24px;
}
@media (max-width: 600px) {
	.idu-container {
		padding-inline: 18px;
	}
}

/* ---------- section heading ---------- */
.idu-eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--idu-accent);
}
.idu-eyebrow::before {
	content: "";
	width: 22px;
	height: 2px;
	background: var(--idu-accent);
}
.idu-block[class*="--dark"] .idu-eyebrow,
.idu-block[class*="--dark"] .idu-eyebrow::before {
	color: var(--idu-on-dark);
	background: var(--idu-on-dark);
}
.idu-block[class*="--dark"] .idu-eyebrow {
	background: transparent;
}

.idu-section-head {
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	gap: 20px;
	margin-bottom: 34px;
}
.idu-section-head--center {
	flex-direction: column;
	align-items: center;
	text-align: center;
}
.idu-section-title {
	margin: 0;
	font-size: var(--idu-h2);
	line-height: 1.12;
	letter-spacing: -0.01em;
	font-weight: 700;
}
.idu-section-link {
	flex: none;
	display: inline-flex;
	align-items: center;
	gap: 7px;
	font-size: 14px;
	font-weight: 600;
	color: var(--idu-ink);
	text-decoration: none;
}
.idu-section-link:hover {
	color: var(--idu-accent);
}

/* ---------- buttons ---------- */
.idu-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	padding: 13px 24px;
	border-radius: var(--idu-radius-pill);
	font-size: 15px;
	font-weight: 600;
	line-height: 1;
	text-decoration: none;
	border: 1.5px solid transparent;
	cursor: pointer;
	transition: transform 0.18s ease, background 0.18s ease, color 0.18s ease, border-color 0.18s ease;
}
.idu-btn:hover {
	transform: translateY(-1px);
}
.idu-btn--primary {
	background: var(--idu-primary);
	color: var(--idu-primary-ink);
}
.idu-btn--primary:hover {
	background: #000;
	color: #fff;
}
.idu-btn--outline {
	background: transparent;
	color: var(--idu-ink);
	border-color: var(--idu-line-2);
}
.idu-btn--outline:hover {
	border-color: var(--idu-ink);
}
.idu-btn--accent {
	background: var(--idu-accent);
	color: var(--idu-accent-ink);
}
.idu-block[class*="--dark"] .idu-btn--outline {
	color: var(--idu-on-dark);
	border-color: rgba(255, 255, 255, 0.4);
}
.idu-block[class*="--dark"] .idu-btn--primary {
	background: #fff;
	color: #16130f;
}

/* ---------- carousel dots ---------- */
.idu-dots {
	display: flex;
	justify-content: center;
	gap: 8px;
	margin-top: 22px;
}
.idu-dots:empty {
	display: none;
}
.idu-dot {
	width: 8px;
	height: 8px;
	padding: 0;
	border: none;
	border-radius: 50%;
	background: var(--idu-line-2);
	cursor: pointer;
	transition: width 0.2s ease, background 0.2s ease;
}
.idu-dot.is-active {
	width: 22px;
	border-radius: 4px;
	background: var(--idu-accent);
}

/* ---------- editor-only helpers ---------- */
.idu-editor-note {
	margin-top: 18px;
	padding: 8px 12px;
	font-size: 12px;
	color: var(--idu-muted);
	background: rgba(0, 0, 0, 0.03);
	border-radius: var(--idu-radius-sm);
	display: inline-block;
}

/* ---------- card primitives (shared by feed sections) ---------- */
.idu-card {
	background: var(--idu-white);
	border: 1px solid var(--idu-line);
	border-radius: var(--idu-radius);
	box-shadow: var(--idu-shadow-sm);
	transition: transform 0.18s ease, box-shadow 0.18s ease;
}
.idu-card:hover {
	transform: translateY(-3px);
	box-shadow: var(--idu-shadow);
}
.idu-chip {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	padding: 4px 10px;
	font-size: 12px;
	color: var(--idu-muted);
	background: var(--idu-cream);
	border-radius: var(--idu-radius-pill);
}
.idu-chip .idu-icon {
	width: 13px;
	height: 13px;
}

/* ---------- scroll reveal ---------- */
.idu-reveal {
	opacity: 0;
	transform: translateY(18px);
	transition: opacity 0.6s ease, transform 0.6s ease;
	will-change: opacity, transform;
}
.idu-reveal.idu-is-in-view {
	opacity: 1;
	transform: none;
}
@media (prefers-reduced-motion: reduce) {
	.idu-reveal {
		opacity: 1;
		transform: none;
		transition: none;
	}
}
