/**
 * GLASS — Infinite Frontend Styles.
 *
 * Visitor-facing styles for infinite-scroll pages.
 * v1.8.3 — 22 section types.
 *
 * @package AJT_Glass
 * @since   1.8.2
 */

/* ══════════════════════════════════════════════════════════════
   RESET & BASE
   ══════════════════════════════════════════════════════════════ */

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

body.inf-page {
	margin: 0; padding: 0;
	font-family: var(--inf-font, 'Nunito Sans', sans-serif);
	font-size: 17px; font-weight: 400; line-height: 1.7;
	color: var(--inf-text, #2D2836);
	background: var(--inf-bg, #ffffff);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	/* v11.7.3 — Changed from overflow-x: hidden to overflow-x: clip.
	 * overflow-x: hidden breaks position: sticky on child elements
	 * (Blinds header) because it creates a new scroll container.
	 * overflow: clip clips without creating a scroll container. */
	overflow-x: clip;

	/* ── Semantic Design Tokens (v5.0.0.9) ────────────────
	 * All default to --inf-plum for backward compatibility.
	 * Override individually via Global Styles or custom CSS. */
	--inf-btn-bg: var(--inf-plum, #A04398);
	--inf-btn-bg-hover: var(--inf-plum-dark, #8A3784);
	--inf-btn-text: #fff;
	--inf-link-color: var(--inf-accent-color);
	--inf-link-hover: var(--inf-teal, #007991);
	--inf-accent-color: var(--inf-accent-color);
	--inf-focus-ring: var(--inf-plum, #A04398);
}

/* ── Aggressive theme reset ───────────────────────────────── */
body.inf-page, body.inf-page * {
	box-sizing: border-box;
}
body.inf-page h1, body.inf-page h2, body.inf-page h3, body.inf-page h4, body.inf-page h5, body.inf-page h6 {
	font-family: var(--inf-heading-font, var(--inf-font, 'Nunito Sans', sans-serif));
	color: inherit !important;
	margin: 0;
	padding: 0;
	border: none;
	line-height: 1.2;
}
body.inf-page p, body.inf-page ul, body.inf-page ol, body.inf-page blockquote, body.inf-page figure {
	margin: 0;
	padding: 0;
}
body.inf-page img { max-width: 100%; height: auto; display: block; border: none; }
body.inf-page a {
	color: var(--inf-link-color);
	text-decoration: none;
	transition: color 0.2s ease;
	background: none;
	border: none;
}
/* v6.2.7 — Restore background/border for Blinds CTA buttons.
 * The global 'a' reset above strips background from all links,
 * which breaks .bld-bar__cta--solid and --gradient buttons. */
body.inf-page .bld-bar__cta--solid {
	background: var(--bld-accent) !important;
	color: #fff !important;
}
body.inf-page .bld-bar__cta--gradient {
	background: linear-gradient(135deg, var(--bld-accent), #E94560) !important;
	color: #fff !important;
	border: none !important;
}
body.inf-page .bld-bar__cta--outline {
	background: transparent !important;
	border: 1.5px solid currentColor !important;
}
body.inf-page .bld-bar__cta:hover {
	color: #fff !important;
}
body.inf-page a:hover { color: var(--inf-link-hover); }
body.inf-page a:focus { outline: 2px solid var(--inf-focus-ring); outline-offset: 2px; }
body.inf-page button { font-family: inherit; }
body.inf-page summary { cursor: pointer; }

.inf-container { max-width: var(--inf-max-w, 1200px); margin: 0 auto; padding: 0 32px; width: 100%; }
/* v6.0.2 — Base .inf-wrap styles. Several sections (posts, form, image_text,
 * columns) use .inf-wrap instead of .inf-container. Without base styles,
 * content_width (wide/full) had no visible effect because there was no
 * max-width or centring margin to constrain. */
.inf-wrap { max-width: var(--inf-max-w, 1200px); margin: 0 auto; padding: 0 32px; width: 100%; box-sizing: border-box; }
.inf-full-bleed { width: 100%; padding: 0; }

/* ── Shared Section Heading ───────────────────────────────── */

.inf-section__heading {
	font-size: clamp(28px, 4vw, 44px); font-weight: 900;
	line-height: 1.15; letter-spacing: -0.02em;
	margin: 0 0 12px; text-align: center;
	color: inherit !important;
}
.inf-section__sub {
	font-size: 18px; opacity: 0.7; margin: 0 0 48px;
	text-align: center; max-width: 640px; margin-left: auto; margin-right: auto;
	line-height: 1.6; color: inherit !important;
}

/* Force color inheritance into all sections — theme-proof.
 * Sections with .inf-portal--no-color-force opt out so delegated
 * third-party content (CM, MSP Hub) can control its own colours. */
body.inf-page .inf-section:not(.inf-portal--no-color-force),
body.inf-page .inf-header,
body.inf-page .inf-banner,
body.inf-page .inf-footer,
body.inf-page .inf-divider,
body.inf-page .inf-spacer {
	color: inherit;
}
body.inf-page .inf-section:not(.inf-portal--no-color-force) *,
body.inf-page .inf-header *,
body.inf-page .inf-banner *,
body.inf-page .inf-footer * {
	color: inherit;
}
body.inf-page .inf-section:not(.inf-portal--no-color-force) a,
body.inf-page .inf-footer a { color: inherit !important; }
body.inf-page .inf-section:not(.inf-portal--no-color-force) .inf-btn { color: inherit; }
body.inf-page .inf-hero__heading,
body.inf-page .inf-cta__heading,
body.inf-page .inf-content__heading {
	color: inherit !important;
}

/* ══════════════════════════════════════════════════════════════
   HEADER
   ══════════════════════════════════════════════════════════════ */

.inf-header { position: relative; z-index: 1000; transition: background 0.35s ease, box-shadow 0.35s ease; }
.inf-header--sticky { position: fixed; top: 0; left: 0; right: 0; }
.inf-header--sticky.inf-header--scrolled { box-shadow: 0 2px 20px rgba(0,0,0,0.12); }
.inf-header__inner { display: flex; align-items: center; justify-content: space-between; height: 72px; gap: 24px; }
.inf-header__logo {
	display: flex; align-items: center; gap: 10px;
	text-decoration: none !important; color: inherit !important; flex-shrink: 0;
}
.inf-header__logo-img { height: 36px; width: auto; }
.inf-header__logo-text { font-size: 18px; font-weight: 800; letter-spacing: -0.02em; }
.inf-header__nav { flex: 1; display: flex; justify-content: center; }
.inf-header__menu { list-style: none; margin: 0; padding: 0; display: flex; gap: 8px; align-items: center; }
.inf-header__menu li { position: relative; }
.inf-header__menu li a {
	display: inline-block; padding: 8px 16px; font-size: 14px; font-weight: 600;
	color: inherit !important; text-decoration: none !important; border-radius: 6px;
	transition: background 0.15s ease, opacity 0.15s ease; opacity: 0.85;
}
.inf-header__menu li a:hover { opacity: 1; background: rgba(255,255,255,0.1); }
.inf-header__menu li ul { display: none; position: absolute; top: 100%; left: 0; min-width: 200px; background: #fff; border-radius: 8px; box-shadow: 0 8px 30px rgba(0,0,0,0.15); padding: 8px 0; z-index: 100; list-style: none; }
.inf-header__menu li:hover > ul { display: block; }
.inf-header__menu li ul li a { display: block; padding: 8px 20px; color: #2D2836; font-size: 13px; border-radius: 0; opacity: 1; }
.inf-header__menu li ul li a:hover { background: #F5F4F6; }
.inf-header__cta {
	display: inline-flex; align-items: center; padding: 9px 22px; font-size: 13px;
	font-weight: 700; color: #fff !important; background: var(--inf-btn-bg) !important;
	border-radius: 8px; text-decoration: none !important;
	transition: background 0.2s ease, transform 0.15s ease; flex-shrink: 0;
}
.inf-header__cta:hover {
	background: var(--inf-btn-bg-hover) !important; color: var(--inf-btn-text) !important; transform: translateY(-1px);
}
.inf-header__toggle { display: none; flex-direction: column; gap: 4px; background: none; border: none; cursor: pointer; padding: 8px; }
.inf-header__toggle span { display: block; width: 22px; height: 2px; background: currentColor; border-radius: 1px; transition: transform 0.25s ease, opacity 0.25s ease; }
.inf-header__toggle[aria-expanded="true"] span:nth-child(1) { transform: translateY(6px) rotate(45deg); }
.inf-header__toggle[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.inf-header__toggle[aria-expanded="true"] span:nth-child(3) { transform: translateY(-6px) rotate(-45deg); }

/* ══════════════════════════════════════════════════════════════
   HERO
   ══════════════════════════════════════════════════════════════ */

.inf-hero { position: relative; display: flex; align-items: center; justify-content: center; overflow: hidden; }
.inf-hero__overlay { position: absolute; inset: 0; z-index: 1; }
.inf-hero__video { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; z-index: 0; }
.inf-hero__content { position: relative; z-index: 2; padding: 80px 32px; }
.inf-hero--center .inf-hero__content { text-align: center; }
.inf-hero--left .inf-hero__content { text-align: left; max-width: 720px; }
.inf-hero--right .inf-hero__content { text-align: right; max-width: 720px; margin-left: auto; }
.inf-hero__heading { font-size: clamp(32px, 6vw, 64px); font-weight: 900; line-height: 1.1; letter-spacing: -0.03em; margin: 0 0 16px; }
.inf-hero__sub { font-size: clamp(16px, 2.5vw, 22px); font-weight: 400; opacity: 0.85; margin: 0 0 24px; line-height: 1.5; }
.inf-hero__body { font-size: 17px; opacity: 0.8; margin: 0 0 32px; max-width: 600px; }
.inf-hero--center .inf-hero__body { margin-left: auto; margin-right: auto; }
.inf-hero__actions { display: flex; gap: 12px; flex-wrap: wrap; }
.inf-hero--center .inf-hero__actions { justify-content: center; }
.inf-hero--right .inf-hero__actions { justify-content: flex-end; }

/* ══════════════════════════════════════════════════════════════
   BUTTONS
   ══════════════════════════════════════════════════════════════ */

body.inf-page .inf-btn {
	display: inline-flex; align-items: center; gap: 8px; padding: 12px 28px;
	font-family: inherit; font-size: 15px; font-weight: 700; border-radius: 10px;
	border: 2px solid transparent; cursor: pointer; text-decoration: none !important;
	transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
	line-height: 1.4;
}
/* v6.0.3 — Changed from shorthand 'background' to 'background-color' on all
   button variants. The shorthand resets background-image/size/etc and more
   importantly, 'background: !important' beats inline 'background-color: !important'
   in the cascade, preventing canvas element_styles from overriding button colours. */
body.inf-page .inf-btn--primary {
	background-color: var(--inf-btn-bg) !important;
	color: #fff !important;
	border-color: var(--inf-btn-bg) !important;
}
body.inf-page .inf-btn--primary:hover {
	background-color: var(--inf-btn-bg-hover) !important;
	border-color: var(--inf-btn-bg-hover) !important;
	color: #fff !important;
	transform: translateY(-2px);
	box-shadow: 0 4px 16px rgba(160, 67, 152, 0.3);
}
body.inf-page .inf-btn--ghost {
	background-color: transparent !important;
	color: inherit !important;
	border-color: currentColor !important;
	opacity: 0.7;
}
body.inf-page .inf-btn--ghost:hover {
	opacity: 1;
	background-color: rgba(255,255,255,0.1) !important;
	color: inherit !important;
}
/* v5.1.0.1 — Borderless / text-only button variant. */
body.inf-page .inf-btn--borderless {
	background-color: transparent !important;
	color: inherit !important;
	border-color: transparent !important;
	padding-left: 4px;
	padding-right: 4px;
	opacity: 0.8;
}
body.inf-page .inf-btn--borderless:hover {
	opacity: 1;
	text-decoration: underline;
}
body.inf-page .inf-btn--lg { padding: 16px 36px; font-size: 17px; }

/* ══════════════════════════════════════════════════════════════
   CONTENT
   ══════════════════════════════════════════════════════════════ */

.inf-content__grid { display: grid; gap: 48px; align-items: center; }
.inf-content--img-right .inf-content__grid, .inf-content--img-left .inf-content__grid { grid-template-columns: 1fr 1fr; }
.inf-content--img-left .inf-content__media { order: -1; }
.inf-content--img-above .inf-content__grid, .inf-content--img-below .inf-content__grid { grid-template-columns: 1fr; }
.inf-content--img-above .inf-content__media { order: -1; }
.inf-content--text-only .inf-content__grid { grid-template-columns: 1fr; max-width: 780px; margin: 0 auto; }
.inf-content__heading { font-size: clamp(24px, 3.5vw, 40px); font-weight: 800; line-height: 1.2; letter-spacing: -0.02em; margin: 0 0 20px; }
.inf-content__body { font-size: 17px; line-height: 1.8; }
.inf-content__body p { margin: 0 0 16px; }
.inf-content__body p:last-child { margin-bottom: 0; }
.inf-content__img { border-radius: 12px; width: 100%; }

/* ══════════════════════════════════════════════════════════════
   MEDIA
   ══════════════════════════════════════════════════════════════ */

.inf-media__img, .inf-media__video { width: 100%; border-radius: 12px; }
.inf-media--full .inf-media__img, .inf-media--full .inf-media__video { border-radius: 0; }
.inf-media__caption { text-align: center; font-size: 14px; color: var(--inf-text); opacity: 0.6; margin: 12px 0 0; font-style: italic; }

/* ══════════════════════════════════════════════════════════════
   GALLERY
   ══════════════════════════════════════════════════════════════ */

.inf-gallery__grid { display: grid; gap: 16px; }
.inf-gallery--cols-2 .inf-gallery__grid { grid-template-columns: repeat(2, 1fr); }
.inf-gallery--cols-3 .inf-gallery__grid { grid-template-columns: repeat(3, 1fr); }
.inf-gallery--cols-4 .inf-gallery__grid { grid-template-columns: repeat(4, 1fr); }
.inf-gallery__item { margin: 0; overflow: hidden; border-radius: 10px; }
.inf-gallery__img { width: 100%; aspect-ratio: 4/3; object-fit: cover; transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1); }
.inf-gallery__item:hover .inf-gallery__img { transform: scale(1.04); }
.inf-gallery__caption { padding: 8px 0 0; font-size: 13px; color: var(--inf-text); opacity: 0.6; }

/* ══════════════════════════════════════════════════════════════
   CTA
   ══════════════════════════════════════════════════════════════ */

.inf-cta__inner { text-align: center; max-width: 720px; margin: 0 auto; }
.inf-cta__heading { font-size: clamp(24px, 4vw, 44px); font-weight: 900; line-height: 1.15; letter-spacing: -0.02em; margin: 0 0 16px; }
.inf-cta__body { font-size: 18px; opacity: 0.85; margin: 0 0 28px; line-height: 1.6; }

/* ══════════════════════════════════════════════════════════════
   TESTIMONIAL
   ══════════════════════════════════════════════════════════════ */

.inf-testimonial__grid { display: grid; gap: 24px; }
.inf-testimonial--single .inf-testimonial__grid { max-width: 680px; margin: 0 auto; }
.inf-testimonial--grid .inf-testimonial__grid { grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); }
.inf-testimonial__card { margin: 0; padding: 32px; background: rgba(255,255,255,0.06); border: 1px solid rgba(0,0,0,0.06); border-radius: 14px; position: relative; }
.inf-testimonial__card::before { content: '\201C'; position: absolute; top: 16px; left: 24px; font-size: 48px; line-height: 1; color: var(--inf-accent-color); opacity: 0.25; font-family: Georgia, serif; }
.inf-testimonial__text { font-size: 17px; line-height: 1.7; margin: 0 0 20px; font-style: italic; }
.inf-testimonial__author { display: flex; align-items: center; gap: 12px; }
.inf-testimonial__avatar { width: 44px; height: 44px; border-radius: 50%; object-fit: cover; }
.inf-testimonial__name { font-style: normal; font-weight: 700; font-size: 14px; display: block; }
.inf-testimonial__role { font-size: 13px; opacity: 0.6; }

/* ══════════════════════════════════════════════════════════════
   SPACER
   ══════════════════════════════════════════════════════════════ */

.inf-spacer { display: flex; align-items: center; justify-content: center; }
.inf-spacer__divider { border: none; border-top: 2px solid; margin: 0 auto; }

/* ══════════════════════════════════════════════════════════════
   CODE
   ══════════════════════════════════════════════════════════════ */

.inf-code { padding: 0; }

/* ══════════════════════════════════════════════════════════════
   FEATURES (v1.8.3)
   ══════════════════════════════════════════════════════════════ */

.inf-features__grid { display: grid; gap: 32px; }
.inf-features--cols-2 .inf-features__grid { grid-template-columns: repeat(2, 1fr); }
.inf-features--cols-3 .inf-features__grid { grid-template-columns: repeat(3, 1fr); }
.inf-features--cols-4 .inf-features__grid { grid-template-columns: repeat(4, 1fr); }
.inf-features__item { text-align: center; padding: 32px 20px; border-radius: 14px; transition: background 0.2s ease, transform 0.2s ease; }
.inf-features__item:hover { background: rgba(0,0,0,0.03); transform: translateY(-2px); }
.inf-features__icon { font-size: 36px; margin-bottom: 16px; line-height: 1; }
.inf-features__title { font-size: 18px; font-weight: 800; margin: 0 0 8px; }
.inf-features__desc { font-size: 15px; opacity: 0.7; margin: 0; line-height: 1.6; }

/* ══════════════════════════════════════════════════════════════
   PRICING (v1.8.3)
   ══════════════════════════════════════════════════════════════ */

.inf-pricing__grid { display: grid; gap: 24px; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); max-width: 1000px; margin: 0 auto; }
.inf-pricing__card { background: #fff; border: 2px solid rgba(0,0,0,0.08); border-radius: 16px; padding: 40px 32px; text-align: center; display: flex; flex-direction: column; transition: transform 0.2s ease, box-shadow 0.2s ease; position: relative; overflow: hidden; }
.inf-pricing__card:hover { transform: translateY(-4px); box-shadow: 0 12px 40px rgba(0,0,0,0.1); }
.inf-pricing__card--featured { border-color: var(--inf-accent-color); box-shadow: 0 8px 30px rgba(160,67,152,0.15); transform: scale(1.04); }
.inf-pricing__card--featured:hover { transform: scale(1.04) translateY(-4px); }
.inf-pricing__badge { position: absolute; top: 0; left: 0; right: 0; background: var(--inf-accent-color); color: #fff; font-size: 11px; font-weight: 800; text-transform: uppercase; letter-spacing: 0.1em; padding: 6px 0; }
.inf-pricing__card--featured .inf-pricing__name { margin-top: 20px; }
.inf-pricing__name { font-size: 20px; font-weight: 800; margin: 0 0 8px; }
.inf-pricing__price { margin: 0 0 16px; }
.inf-pricing__amount { font-size: 48px; font-weight: 900; letter-spacing: -0.03em; line-height: 1; }
.inf-pricing__period { font-size: 15px; opacity: 0.5; margin-left: 4px; }
.inf-pricing__desc { font-size: 14px; opacity: 0.6; margin: 0 0 24px; }
.inf-pricing__features { list-style: none; padding: 0; margin: 0 0 32px; text-align: left; flex: 1; }
.inf-pricing__feat { padding: 8px 0; font-size: 14px; border-bottom: 1px solid rgba(0,0,0,0.06); display: flex; align-items: center; gap: 8px; }
.inf-pricing__feat::before { content: '✓'; color: var(--inf-accent-color); font-weight: 700; font-size: 13px; flex-shrink: 0; }
.inf-pricing__card .inf-btn { margin-top: auto; align-self: center; width: 100%; justify-content: center; text-decoration: none !important; }

/* ══════════════════════════════════════════════════════════════
   FAQ (v1.8.3)
   ══════════════════════════════════════════════════════════════ */

.inf-faq__list { max-width: 780px; margin: 0 auto; }
.inf-faq__item { border-bottom: 1px solid rgba(0,0,0,0.08); }
.inf-faq__question { font-size: 17px; font-weight: 700; padding: 20px 0; cursor: pointer; list-style: none; display: flex; align-items: center; justify-content: space-between; gap: 16px; }
.inf-faq__question::-webkit-details-marker { display: none; }
.inf-faq__question::after { content: '+'; font-size: 24px; font-weight: 300; color: var(--inf-accent-color); transition: transform 0.2s ease; flex-shrink: 0; }
.inf-faq__item[open] .inf-faq__question::after { content: '−'; }
.inf-faq__answer { padding: 0 0 20px; font-size: 16px; opacity: 0.75; line-height: 1.7; }

/* ══════════════════════════════════════════════════════════════
   STATS (v1.8.3)
   ══════════════════════════════════════════════════════════════ */

.inf-stats__grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); gap: 32px; text-align: center; }
.inf-stats__number { font-size: clamp(36px, 5vw, 56px); font-weight: 900; letter-spacing: -0.03em; line-height: 1; margin-bottom: 8px; color: var(--inf-accent-color); }
.inf-stats__label { font-size: 15px; font-weight: 600; opacity: 0.6; text-transform: uppercase; letter-spacing: 0.05em; }

/* ══════════════════════════════════════════════════════════════
   TEAM (v1.8.3)
   ══════════════════════════════════════════════════════════════ */

.inf-team__grid { display: grid; gap: 32px; }
.inf-team--cols-2 .inf-team__grid { grid-template-columns: repeat(2, 1fr); }
.inf-team--cols-3 .inf-team__grid { grid-template-columns: repeat(3, 1fr); }
.inf-team--cols-4 .inf-team__grid { grid-template-columns: repeat(4, 1fr); }
.inf-team__card { text-align: center; padding: 32px 20px; border-radius: 14px; border: 1px solid rgba(0,0,0,0.06); transition: transform 0.2s ease, box-shadow 0.2s ease; }
.inf-team__card:hover { transform: translateY(-4px); box-shadow: 0 8px 24px rgba(0,0,0,0.08); }
.inf-team__photo { width: 120px; height: 120px; border-radius: 50%; object-fit: cover; margin: 0 auto 16px; }
.inf-team__photo-placeholder { width: 120px; height: 120px; border-radius: 50%; background: rgba(0,0,0,0.06); display: flex; align-items: center; justify-content: center; margin: 0 auto 16px; color: rgba(0,0,0,0.2); }
.inf-team__name { font-size: 18px; font-weight: 800; margin: 0 0 4px; }
.inf-team__role { font-size: 14px; color: var(--inf-accent-color); font-weight: 600; margin: 0 0 12px; }
.inf-team__bio { font-size: 14px; opacity: 0.6; margin: 0; line-height: 1.6; }

/* ══════════════════════════════════════════════════════════════
   LOGOS (v1.8.3)
   ══════════════════════════════════════════════════════════════ */

.inf-logos__heading { font-size: 13px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.1em; opacity: 0.4; text-align: center; margin: 0 0 32px; }
.inf-logos__grid { display: flex; flex-wrap: wrap; align-items: center; justify-content: center; gap: 40px; }
.inf-logos__item { flex-shrink: 0; }
.inf-logos__img { height: 40px; width: auto; opacity: 0.5; filter: grayscale(1); transition: opacity 0.2s ease, filter 0.2s ease; }
.inf-logos__img:hover { opacity: 1; filter: none; }

/* ══════════════════════════════════════════════════════════════
   TIMELINE (v1.8.3)
   ══════════════════════════════════════════════════════════════ */

.inf-timeline__track { position: relative; max-width: 800px; margin: 0 auto; padding: 20px 0; }
.inf-timeline__track::before { content: ''; position: absolute; left: 50%; top: 0; bottom: 0; width: 2px; background: rgba(0,0,0,0.1); transform: translateX(-50%); }
.inf-timeline__event { position: relative; display: flex; margin-bottom: 48px; }
.inf-timeline__event:last-child { margin-bottom: 0; }
.inf-timeline__event--left { justify-content: flex-start; padding-right: calc(50% + 32px); }
.inf-timeline__event--right { justify-content: flex-end; padding-left: calc(50% + 32px); }
.inf-timeline__dot { position: absolute; left: 50%; top: 24px; width: 14px; height: 14px; background: var(--inf-accent-color); border: 3px solid var(--inf-bg, #fff); border-radius: 50%; transform: translateX(-50%); z-index: 2; }
.inf-timeline__card { background: rgba(0,0,0,0.03); border: 1px solid rgba(0,0,0,0.06); border-radius: 12px; padding: 24px; max-width: 340px; width: 100%; }
.inf-timeline__date { font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.06em; color: var(--inf-accent-color); display: block; margin-bottom: 8px; }
.inf-timeline__title { font-size: 17px; font-weight: 800; margin: 0 0 8px; }
.inf-timeline__desc { font-size: 14px; opacity: 0.7; margin: 0; line-height: 1.6; }

/* ══════════════════════════════════════════════════════════════
   CARDS (v1.8.3)
   ══════════════════════════════════════════════════════════════ */

.inf-cards__grid { display: grid; gap: 24px; }
.inf-cards--cols-2 .inf-cards__grid { grid-template-columns: repeat(2, 1fr); }
.inf-cards--cols-3 .inf-cards__grid { grid-template-columns: repeat(3, 1fr); }
.inf-cards--cols-4 .inf-cards__grid { grid-template-columns: repeat(4, 1fr); }
.inf-cards__card { border: 1px solid rgba(0,0,0,0.08); border-radius: 14px; overflow: hidden; transition: transform 0.2s ease, box-shadow 0.2s ease; background: #fff; }
.inf-cards__card:hover { transform: translateY(-4px); box-shadow: 0 8px 24px rgba(0,0,0,0.08); }
.inf-cards__img-wrap { overflow: hidden; }
.inf-cards__img { width: 100%; aspect-ratio: 16/10; object-fit: cover; transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1); }
.inf-cards__card:hover .inf-cards__img { transform: scale(1.04); }
.inf-cards__icon { font-size: 32px; padding: 24px 24px 0; }
.inf-cards__body { padding: 24px; }
.inf-cards__title { font-size: 18px; font-weight: 800; margin: 0 0 8px; }
.inf-cards__desc { font-size: 15px; opacity: 0.65; margin: 0 0 16px; line-height: 1.6; }
.inf-cards__link { font-size: 14px; font-weight: 700; color: var(--inf-accent-color) !important; text-decoration: none !important; }
.inf-cards--bordered .inf-cards__card { border-width: 2px; }
.inf-cards--shadow .inf-cards__card { border: none; box-shadow: 0 4px 20px rgba(0,0,0,0.08); }

/* ══════════════════════════════════════════════════════════════
   ACCORDION (v1.8.3)
   ══════════════════════════════════════════════════════════════ */

.inf-accordion__list { max-width: 780px; margin: 0 auto; }
.inf-accordion__item { border: 1px solid rgba(0,0,0,0.08); border-radius: 10px; margin-bottom: 12px; overflow: hidden; }
.inf-accordion__title { font-size: 16px; font-weight: 700; padding: 18px 24px; cursor: pointer; list-style: none; display: flex; align-items: center; justify-content: space-between; gap: 16px; background: rgba(0,0,0,0.02); }
.inf-accordion__title::-webkit-details-marker { display: none; }
.inf-accordion__title::after { content: '▸'; font-size: 16px; transition: transform 0.2s ease; flex-shrink: 0; }
.inf-accordion__item[open] .inf-accordion__title::after { transform: rotate(90deg); }
.inf-accordion__content { padding: 16px 24px 24px; font-size: 15px; line-height: 1.7; opacity: 0.8; }

/* ══════════════════════════════════════════════════════════════
   TABS (v1.8.3)
   ══════════════════════════════════════════════════════════════ */

.inf-tabs__nav { display: flex; gap: 4px; justify-content: center; margin-bottom: 32px; flex-wrap: wrap; }
.inf-tabs__btn { font-family: inherit; font-size: 14px; font-weight: 700; padding: 10px 24px; background: rgba(0,0,0,0.04); border: none; border-radius: 8px; cursor: pointer; color: inherit; opacity: 0.6; transition: all 0.2s ease; }
.inf-tabs__btn:hover { opacity: 1; background: rgba(0,0,0,0.08); }
.inf-tabs__btn--active { background: var(--inf-accent-color); color: #fff; opacity: 1; }
.inf-tabs__panel { display: none; font-size: 16px; line-height: 1.7; }
.inf-tabs__panel--active { display: block; }

/* ══════════════════════════════════════════════════════════════
   BANNER (v1.8.3)
   ══════════════════════════════════════════════════════════════ */

.inf-banner { padding: 14px 0; }
.inf-banner__inner { display: flex; align-items: center; justify-content: center; gap: 12px; flex-wrap: wrap; text-align: center; }
.inf-banner__icon { font-size: 18px; }
.inf-banner__text { font-size: 14px; font-weight: 600; }
.inf-banner__link { font-size: 14px; font-weight: 800; color: inherit !important; text-decoration: underline !important; text-underline-offset: 2px; opacity: 0.9; }
.inf-banner__link:hover { opacity: 1; color: inherit !important; }

/* ══════════════════════════════════════════════════════════════
   FOOTER (v1.8.3)
   ══════════════════════════════════════════════════════════════ */

.inf-footer__grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 40px; margin-bottom: 40px; }
.inf-footer__heading { font-size: 14px; font-weight: 800; text-transform: uppercase; letter-spacing: 0.06em; margin: 0 0 16px; opacity: 0.7; }
.inf-footer__content { font-size: 14px; opacity: 0.6; line-height: 1.8; }
.inf-footer__content a { color: inherit !important; opacity: 0.8; text-decoration: none !important; }
.inf-footer__content a:hover { opacity: 1; color: inherit !important; }
.inf-footer__bottom { border-top: 1px solid rgba(255,255,255,0.1); padding-top: 24px; }
.inf-footer__copy { font-size: 13px; opacity: 0.4; margin: 0; text-align: center; }

/* ══════════════════════════════════════════════════════════════
   BLOCK (v1.8.3)
   ══════════════════════════════════════════════════════════════ */

.inf-block { /* Inherits section padding — no special styles needed. */ }

/* ══════════════════════════════════════════════════════════════
   SCROLL ANIMATIONS
   ══════════════════════════════════════════════════════════════ */

[data-inf-animate] { opacity: 0; transition: opacity 0.7s cubic-bezier(0.16, 1, 0.3, 1), transform 0.7s cubic-bezier(0.16, 1, 0.3, 1); }
[data-inf-animate="fade-up"]    { transform: translateY(30px); }
[data-inf-animate="fade-down"]  { transform: translateY(-30px); }
[data-inf-animate="fade-left"]  { transform: translateX(30px); }
[data-inf-animate="fade-right"] { transform: translateX(-30px); }
[data-inf-animate="zoom-in"]    { transform: scale(0.95); }
[data-inf-animate="none"]       { opacity: 1; transform: none; }
[data-inf-animate].inf-visible  { opacity: 1; transform: none; }

@media (prefers-reduced-motion: reduce) {
	[data-inf-animate] { opacity: 1; transform: none; transition: none; }
}

/* ══════════════════════════════════════════════════════════════
   RESPONSIVE
   ══════════════════════════════════════════════════════════════ */

@media (max-width: 900px) {
	.inf-container { padding: 0 20px; }
	.inf-header__nav { display: none; }
	.inf-header__nav.inf-header__nav--open { display: block; position: absolute; top: 72px; left: 0; right: 0; background: inherit; padding: 16px 20px 24px; box-shadow: 0 8px 30px rgba(0,0,0,0.15); }
	.inf-header__nav.inf-header__nav--open .inf-header__menu { flex-direction: column; gap: 4px; }
	.inf-header__nav.inf-header__nav--open .inf-header__menu li ul { position: static; display: block; box-shadow: none; padding-left: 16px; }
	.inf-header__toggle { display: flex; }
	.inf-content--img-right .inf-content__grid, .inf-content--img-left .inf-content__grid { grid-template-columns: 1fr; }
	.inf-content--img-left .inf-content__media { order: 0; }
	.inf-gallery--cols-4 .inf-gallery__grid, .inf-gallery--cols-3 .inf-gallery__grid { grid-template-columns: repeat(2, 1fr); }
	.inf-features--cols-4 .inf-features__grid, .inf-features--cols-3 .inf-features__grid { grid-template-columns: repeat(2, 1fr); }
	.inf-team--cols-4 .inf-team__grid, .inf-team--cols-3 .inf-team__grid { grid-template-columns: repeat(2, 1fr); }
	.inf-cards--cols-4 .inf-cards__grid, .inf-cards--cols-3 .inf-cards__grid { grid-template-columns: repeat(2, 1fr); }
	.inf-timeline__track::before { left: 20px; }
	.inf-timeline__event--left, .inf-timeline__event--right { padding-left: 52px; padding-right: 0; justify-content: flex-start; }
	.inf-timeline__dot { left: 20px; }
	.inf-timeline__card { max-width: 100%; }
}

@media (max-width: 640px) {
	body.inf-page { font-size: 16px; }
	.inf-container { padding: 0 16px; }
	.inf-hero__content { padding: 48px 16px; }
	.inf-hero__heading { margin-bottom: 12px; }
	.inf-content__heading { margin-bottom: 14px; }
	.inf-gallery--cols-2 .inf-gallery__grid, .inf-gallery--cols-3 .inf-gallery__grid, .inf-gallery--cols-4 .inf-gallery__grid { grid-template-columns: 1fr; }
	.inf-testimonial--grid .inf-testimonial__grid { grid-template-columns: 1fr; }
	.inf-features--cols-2 .inf-features__grid, .inf-features--cols-3 .inf-features__grid, .inf-features--cols-4 .inf-features__grid { grid-template-columns: 1fr; }
	.inf-team--cols-2 .inf-team__grid, .inf-team--cols-3 .inf-team__grid, .inf-team--cols-4 .inf-team__grid { grid-template-columns: 1fr; }
	.inf-cards--cols-2 .inf-cards__grid, .inf-cards--cols-3 .inf-cards__grid, .inf-cards--cols-4 .inf-cards__grid { grid-template-columns: 1fr; }
	.inf-pricing__grid { grid-template-columns: 1fr; }
	.inf-pricing__card--featured { transform: none; }
	.inf-pricing__card--featured:hover { transform: translateY(-4px); }
	.inf-stats__grid { grid-template-columns: repeat(2, 1fr); }
	.inf-btn--lg { padding: 14px 28px; font-size: 15px; }
	.inf-footer__grid { grid-template-columns: 1fr; }
}

/* ══════════════════════════════════════════════════════════════
 * NEW SECTION TYPES (v1.9.0)
 * ══════════════════════════════════════════════════════════════ */

/* ── Divider ────────────────────────────────────────────────── */
.inf-divider { line-height: 0; overflow: hidden; }
.inf-divider svg { display: block; width: 100%; }

/* ── Countdown ──────────────────────────────────────────────── */
.inf-countdown { text-align: center; }
.inf-countdown__grid { display: flex; justify-content: center; gap: 32px; flex-wrap: wrap; }
.inf-countdown__unit { text-align: center; min-width: 80px; }
.inf-countdown__value { font-size: clamp(36px, 8vw, 64px); font-weight: 900; line-height: 1; font-variant-numeric: tabular-nums; }
.inf-countdown__label { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; opacity: .5; margin-top: 6px; }

/* ── Contact Form ───────────────────────────────────────────── */
.inf-contact { }
.inf-contact__form { display: grid; gap: 16px; max-width: 560px; margin: 0 auto; }
.inf-contact__input,
.inf-contact__textarea {
	width: 100%; padding: 12px 16px; border: 1px solid rgba(0,0,0,.12);
	border-radius: 8px; font-size: 15px; font-family: inherit;
	background: rgba(255,255,255,.8); transition: border-color 0.2s;
}
.inf-contact__input:focus,
.inf-contact__textarea:focus { outline: none; border-color: var(--inf-accent-color); }
.inf-contact__textarea { resize: vertical; min-height: 120px; }
.inf-contact__btn {
	display: inline-block; padding: 14px 28px; background: var(--inf-accent-color);
	color: #fff; border: none; border-radius: 8px; font-weight: 700;
	font-size: 15px; cursor: pointer; transition: background 0.2s;
}
.inf-contact__btn:hover { background: var(--inf-btn-bg-hover); }

/* ── Map Embed ──────────────────────────────────────────────── */
.inf-map__frame { width: 100%; border: none; border-radius: 12px; }

/* ── Video Embed ────────────────────────────────────────────── */
.inf-video__wrap { position: relative; border-radius: 12px; overflow: hidden; }
.inf-video__wrap iframe { position: absolute; top: 0; left: 0; width: 100%; height: 100%; border: none; }

/* ── Newsletter ─────────────────────────────────────────────── */
.inf-newsletter { text-align: center; }
.inf-newsletter__form { display: flex; gap: 12px; max-width: 460px; margin: 0 auto; }
.inf-newsletter__input {
	flex: 1; padding: 12px 16px; border: none; border-radius: 8px;
	font-size: 15px; font-family: inherit;
}
.inf-newsletter__btn {
	padding: 12px 24px; background: var(--inf-space); color: #fff;
	border: none; border-radius: 8px; font-weight: 700; font-size: 14px;
	cursor: pointer; transition: background 0.2s; white-space: nowrap;
}
.inf-newsletter__btn:hover { opacity: .9; }

/* ── Icon Grid ──────────────────────────────────────────────── */
.inf-icon-grid__grid { display: grid; gap: 24px; }
.inf-icon-grid--cols-3 .inf-icon-grid__grid { grid-template-columns: repeat(3, 1fr); }
.inf-icon-grid--cols-4 .inf-icon-grid__grid { grid-template-columns: repeat(4, 1fr); }
.inf-icon-grid--cols-5 .inf-icon-grid__grid { grid-template-columns: repeat(5, 1fr); }
.inf-icon-grid--cols-6 .inf-icon-grid__grid { grid-template-columns: repeat(6, 1fr); }
.inf-icon-grid__item { text-align: center; padding: 20px; transition: transform 0.2s; }
.inf-icon-grid__item:hover { transform: translateY(-2px); }
.inf-icon-grid__icon { margin-bottom: 8px; }
.inf-icon-grid__label { font-size: 14px; font-weight: 700; }
.inf-icon-grid__item a { color: inherit; text-decoration: none; }

/* ── Comparison Table ───────────────────────────────────────── */
.inf-comparison__table { width: 100%; border-collapse: collapse; }
.inf-comparison__table th,
.inf-comparison__table td { padding: 14px 16px; text-align: center; }
.inf-comparison__table th { font-weight: 700; border-bottom: 2px solid var(--inf-accent-color); }
.inf-comparison__table th:first-child,
.inf-comparison__table td:first-child { text-align: left; font-weight: 600; }
.inf-comparison__table td { border-bottom: 1px solid rgba(0,0,0,.06); }
.inf-comparison__table tbody tr:hover { background: rgba(160,67,152,.03); }
.inf-comparison__check { color: #059669; font-weight: 800; }
.inf-comparison__cross { color: #DC2626; }

/* ── Card Style Variants (v1.9.0) ───────────────────────────── */
.inf-cards--elevated .inf-cards__card { box-shadow: 0 8px 32px rgba(0,0,0,.12); border: none; }
.inf-cards--glass .inf-cards__card { background: rgba(255,255,255,.08); backdrop-filter: blur(12px); border: 1px solid rgba(255,255,255,.18); }
.inf-cards--minimal .inf-cards__card { border: none; border-radius: 0; border-bottom: 2px solid rgba(0,0,0,.06); }
.inf-cards--gradient .inf-cards__card { background: linear-gradient(135deg, rgba(160,67,152,.06), rgba(0,121,145,.06)); border: none; }

/* ── Extra Animations (v1.9.0) ──────────────────────────────── */
@keyframes infSlideLeft { from { opacity: 0; transform: translateX(60px); } to { opacity: 1; transform: translateX(0); } }
@keyframes infSlideRight { from { opacity: 0; transform: translateX(-60px); } to { opacity: 1; transform: translateX(0); } }
@keyframes infBounce { 0% { opacity: 0; transform: translateY(40px); } 60% { transform: translateY(-8px); } 100% { opacity: 1; transform: translateY(0); } }
@keyframes infFlip { from { opacity: 0; transform: perspective(400px) rotateY(90deg); } to { opacity: 1; transform: perspective(400px) rotateY(0); } }
@keyframes infZoomOut { from { opacity: 0; transform: scale(1.15); } to { opacity: 1; transform: scale(1); } }

.inf-section[data-inf-animate="slide-left"].inf-visible { animation: infSlideLeft 0.6s ease forwards; }
.inf-section[data-inf-animate="slide-right"].inf-visible { animation: infSlideRight 0.6s ease forwards; }
.inf-section[data-inf-animate="bounce"].inf-visible { animation: infBounce 0.7s ease forwards; }
.inf-section[data-inf-animate="flip"].inf-visible { animation: infFlip 0.6s ease forwards; }
.inf-section[data-inf-animate="zoom-out"].inf-visible { animation: infZoomOut 0.5s ease forwards; }

@media (max-width: 640px) {
	.inf-icon-grid--cols-3 .inf-icon-grid__grid,
	.inf-icon-grid--cols-4 .inf-icon-grid__grid,
	.inf-icon-grid--cols-5 .inf-icon-grid__grid,
	.inf-icon-grid--cols-6 .inf-icon-grid__grid { grid-template-columns: repeat(2, 1fr); }
	.inf-countdown__grid { gap: 16px; }
	.inf-countdown__value { font-size: 36px; }
	.inf-newsletter__form { flex-direction: column; }
	.inf-comparison__table { font-size: 13px; }
	.inf-comparison__table th,
	.inf-comparison__table td { padding: 10px 8px; }
}

/* ══════════════════════════════════════════════════════════════
 * v3.0.0: Columns / Layout Container
 * ══════════════════════════════════════════════════════════════ */
.inf-section--columns .inf-wrap {
	max-width: var(--inf-max-w, 1200px);
	margin: 0 auto;
	padding: 0 32px;
}
.inf-section--columns .inf-column > .inf-section {
	padding-left: 0 !important;
	padding-right: 0 !important;
}
.inf-section--columns .inf-column > .inf-section .inf-wrap {
	padding: 0;
	max-width: none;
}
/* v6.0.2 — Some child sections use .inf-container instead of .inf-wrap
 * (e.g. post_loop). Apply the same column reset so they don't enforce
 * 1200px max-width and extra padding inside a narrow column cell. */
.inf-section--columns .inf-column > .inf-section .inf-container {
	padding: 0;
	max-width: none;
}
@media (max-width: 767px) {
	.inf-section--columns .inf-wrap {
		grid-template-columns: 1fr !important;
	}
}

/* ══════════════════════════════════════════════════════════════
 * v3.0.0: Image + Text responsive
 * ══════════════════════════════════════════════════════════════ */
.inf-section--image-text .inf-wrap {
	max-width: var(--inf-max-w, 1200px);
	margin: 0 auto;
	padding: 0 32px;
}
@media (max-width: 767px) {
	.inf-section--image-text .inf-wrap {
		grid-template-columns: 1fr !important;
	}
	.inf-image-text__media { order: -1; }
}

/* ══════════════════════════════════════════════════════════════
 * v3.0.0: Slider
 * ══════════════════════════════════════════════════════════════ */
.inf-slider__track { will-change: transform; }
.inf-slider__arrow:hover { background: rgba(0,0,0,.6); }
.inf-slider__dot { transition: background .2s ease; }
.inf-slider__dot--active { background: #fff; }

@media (max-width: 767px) {
	.inf-slider { height: 350px !important; }
	.inf-slider__slide h2 { font-size: 28px !important; }
	.inf-slider__arrow { width: 36px; height: 36px; font-size: 16px; }
}

/* ══════════════════════════════════════════════════════════════
 * v3.0.0: Posts Grid responsive
 * ══════════════════════════════════════════════════════════════ */
@media (max-width: 1024px) {
	.inf-posts-grid { grid-template-columns: repeat(2, 1fr) !important; }
}
@media (max-width: 640px) {
	.inf-posts-grid { grid-template-columns: 1fr !important; }
}

/* ══════════════════════════════════════════════════════════════
 * v3.0.0: Form Builder
 * ══════════════════════════════════════════════════════════════ */
.inf-form input:focus,
.inf-form textarea:focus,
.inf-form select:focus {
	outline: none;
	border-color: var(--inf-accent-color);
	box-shadow: 0 0 0 3px rgba(160, 67, 152, 0.1);
}
.inf-form__submit:hover {
	opacity: .9;
	transform: translateY(-1px);
	transition: all .15s ease;
}
.inf-form__submit:disabled {
	opacity: .6;
	cursor: not-allowed;
}
.inf-form__status {
	animation: infFadeUp 0.3s ease;
}

/* ══════════════════════════════════════════════════════════════
 * v3.1.0 — SHOWCASE-PARITY ENHANCEMENTS
 * ══════════════════════════════════════════════════════════════ */

/* ── Section Label / Eyebrow ──────────────────────────────── */

.inf-section__label {
	display: block;
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 2px;
	text-transform: uppercase;
	opacity: .35;
	margin-bottom: 12px;
	text-align: center;
}

/* ── Full-Width & Dark Section Support ────────────────────── */

.inf-section--full-width {
	width: 100vw;
	margin-left: calc(-50vw + 50%);
	padding-left: 0;
	padding-right: 0;
}
.inf-section--full-width > .inf-container {
	max-width: var(--inf-max-w, 1200px);
	margin: 0 auto;
	padding: 0 32px;
}

/* ── v5.1.0.1 — Content Width Tiers ─────────────────────────
 *
 * Wide: content breaks out beyond --inf-max-w to 1400px / 92vw.
 *       Background stays within the page flow (no full-bleed).
 *
 * Full + Wide Content: full-bleed background with content
 *       expanded to 1400px instead of the page default.
 *
 * Full Bleed: full-bleed background AND content — no inner
 *       max-width constraint at all (edge-to-edge).
 * ──────────────────────────────────────────────────────────── */

/* Wide content — section stays in flow, content goes wider. */
.inf-section--wide > .inf-container,
.inf-section--wide > .inf-wrap {
	max-width: min(1400px, 92vw);
}

/* Full-width background with wider content inside. */
.inf-section--full-width.inf-section--wide-content > .inf-container,
.inf-section--full-width.inf-section--wide-content > .inf-wrap {
	max-width: min(1400px, 92vw);
	padding: 0 32px;
}

/* Full bleed — background AND content go edge-to-edge. */
.inf-section--full-width.inf-section--content-full > .inf-container,
.inf-section--full-width.inf-section--content-full > .inf-wrap {
	max-width: none;
	padding: 0 clamp(16px, 3vw, 48px);
}

/* v6.0.2 — Changed from shorthand 'background' to 'background-color'.
   The shorthand resets background-image to 'none', which clobbers any
   bg_image set via inline style on sections like hero that combine
   dark_section with a background image. */
.inf-section--dark {
	background-color: #1a1c2e;
	color: rgba(255,255,255,.85);
	border-top: 1px solid rgba(160,67,152,.1);
}
.inf-section--dark h1,
.inf-section--dark h2,
.inf-section--dark h3 { color: #fff !important; }
.inf-section--dark .inf-section__sub { color: rgba(255,255,255,.5); }

/* ── Per-Card Accent on Features & Cards ──────────────────── */

.inf-features__item {
	--card-accent: var(--inf-accent-color);
}
.inf-features__icon {
	color: var(--card-accent);
	background: color-mix(in srgb, var(--card-accent) 10%, transparent);
}

/* ── Sticky Nav Enhancements ──────────────────────────────── */

.inf-header--blur.inf-header--scrolled {
	backdrop-filter: blur(20px) saturate(1.4);
	-webkit-backdrop-filter: blur(20px) saturate(1.4);
}

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

.inf-header--sticky {
	transition: transform .4s cubic-bezier(.16,1,.3,1),
	            background .3s ease,
	            box-shadow .3s ease;
}

.inf-header--scrolled {
	box-shadow: 0 1px 12px rgba(0,0,0,.1);
}

/* ── Hero Badge ───────────────────────────────────────────── */

.inf-hero__badge {
	display: inline-block; padding: 6px 18px; border-radius: 100px;
	background: rgba(160,67,152,.15); border: 1px solid rgba(160,67,152,.25);
	color: var(--inf-accent-color); font-size: 11px; font-weight: 700;
	letter-spacing: 1.5px; text-transform: uppercase;
	margin-bottom: 28px;
}

/* ── Hero Stats ───────────────────────────────────────────── */

.inf-hero__stats {
	display: flex; justify-content: center; gap: 48px;
	margin-top: 40px;
}
.inf-hero__stat { text-align: center; }
.inf-hero__stat-num {
	display: block; font-family: var(--inf-heading-font);
	font-size: clamp(32px, 5vw, 48px); font-weight: 900;
	line-height: 1;
}
.inf-hero__stat-label {
	font-size: 10px; text-transform: uppercase; letter-spacing: 1px;
	opacity: .4; margin-top: 4px; display: block;
}

/* ── Hero Scroll Indicator ────────────────────────────────── */

.inf-hero__scroll {
	position: absolute; bottom: 40px; left: 50%;
	transform: translateX(-50%); text-align: center;
}
.inf-hero__scroll span {
	font-size: 10px; text-transform: uppercase; letter-spacing: 2px;
	opacity: .35; display: block; margin-bottom: 8px;
}
.inf-hero__scroll-line {
	width: 1px; height: 48px; margin: 0 auto;
	background: linear-gradient(to bottom, currentColor 50%, transparent);
	opacity: .25;
	animation: inf-scroll-pulse 2s ease-in-out infinite;
}
@keyframes inf-scroll-pulse {
	0%, 100% { opacity: .15; transform: scaleY(1); }
	50% { opacity: .4; transform: scaleY(1.2); }
}

/* ── Hero Background Patterns ─────────────────────────────── */

.inf-hero__pattern {
	position: absolute; inset: 0; pointer-events: none; z-index: 0;
}
.inf-hero__pattern--grid {
	background-image:
		linear-gradient(rgba(160,67,152,.06) 1px, transparent 1px),
		linear-gradient(90deg, rgba(160,67,152,.06) 1px, transparent 1px);
	background-size: 60px 60px;
	mask-image: radial-gradient(ellipse 70% 70% at 50% 50%, black 30%, transparent);
	-webkit-mask-image: radial-gradient(ellipse 70% 70% at 50% 50%, black 30%, transparent);
}
.inf-hero__pattern--dots {
	background-image: radial-gradient(circle, rgba(160,67,152,.08) 1px, transparent 1px);
	background-size: 32px 32px;
	mask-image: radial-gradient(ellipse 60% 60% at 50% 50%, black, transparent);
	-webkit-mask-image: radial-gradient(ellipse 60% 60% at 50% 50%, black, transparent);
}
.inf-hero__pattern--gradient-orbs { overflow: hidden; }
.inf-hero__pattern--gradient-orbs::before {
	content: ''; position: absolute; top: -20%; right: -10%;
	width: 800px; height: 800px; border-radius: 50%;
	background: radial-gradient(circle, rgba(160,67,152,.12), transparent 70%);
	animation: inf-orb-pulse 8s ease-in-out infinite alternate;
}
.inf-hero__pattern--gradient-orbs::after {
	content: ''; position: absolute; bottom: -10%; left: -10%;
	width: 600px; height: 600px; border-radius: 50%;
	background: radial-gradient(circle, rgba(0,121,145,.1), transparent 70%);
	animation: inf-orb-pulse 10s ease-in-out infinite alternate-reverse;
}
@keyframes inf-orb-pulse {
	0% { transform: scale(1); opacity: .6; }
	100% { transform: scale(1.15); opacity: 1; }
}

/* ── Floating Icons Pattern ───────────────────────────────── */

.inf-hero__pattern--floating-icons {
	overflow: hidden;
}
.inf-hero__float-icon {
	position: absolute;
	font-size: 28px;
	opacity: .15;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 56px;
	height: 56px;
	border-radius: 16px;
	border: 1px solid rgba(255,255,255,.08);
	background: rgba(255,255,255,.03);
	backdrop-filter: blur(4px);
	-webkit-backdrop-filter: blur(4px);
	pointer-events: none;
	will-change: transform;
}

/* Three distinct orbit paths */
.inf-hero__float-icon--orbit-0 {
	animation: inf-float-drift-0 20s ease-in-out infinite;
}
.inf-hero__float-icon--orbit-1 {
	animation: inf-float-drift-1 25s ease-in-out infinite;
}
.inf-hero__float-icon--orbit-2 {
	animation: inf-float-drift-2 18s ease-in-out infinite;
}

@keyframes inf-float-drift-0 {
	0%   { transform: translate(0, 0) rotate(0deg); }
	25%  { transform: translate(30px, -20px) rotate(5deg); }
	50%  { transform: translate(-10px, -40px) rotate(-3deg); }
	75%  { transform: translate(-30px, -10px) rotate(4deg); }
	100% { transform: translate(0, 0) rotate(0deg); }
}

@keyframes inf-float-drift-1 {
	0%   { transform: translate(0, 0) rotate(0deg); }
	25%  { transform: translate(-25px, 30px) rotate(-4deg); }
	50%  { transform: translate(20px, 15px) rotate(6deg); }
	75%  { transform: translate(35px, -25px) rotate(-2deg); }
	100% { transform: translate(0, 0) rotate(0deg); }
}

@keyframes inf-float-drift-2 {
	0%   { transform: translate(0, 0) rotate(0deg) scale(1); }
	33%  { transform: translate(-20px, -30px) rotate(8deg) scale(1.05); }
	66%  { transform: translate(25px, 20px) rotate(-5deg) scale(.95); }
	100% { transform: translate(0, 0) rotate(0deg) scale(1); }
}

@media (max-width: 767px) {
	.inf-hero__float-icon { width: 40px; height: 40px; font-size: 20px; opacity: .08; }
}

@media (prefers-reduced-motion: reduce) {
	.inf-hero__float-icon { animation: none !important; }
}

/* ── Rich Cards ───────────────────────────────────────────── */

.inf-rich-cards__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 32px;
}
.inf-rich-cards--cols-2 .inf-rich-cards__grid { grid-template-columns: repeat(2, 1fr); }
.inf-rich-cards--cols-3 .inf-rich-cards__grid { grid-template-columns: repeat(3, 1fr); }

.inf-rich-card {
	position: relative;
	background: #fff;
	border: 1px solid rgba(0,0,0,.06);
	border-radius: 16px;
	padding: 32px;
	transition: border-color .3s, transform .2s, box-shadow .3s;
	overflow: hidden;
}
.inf-rich-card:hover {
	border-color: color-mix(in srgb, var(--card-accent) 30%, transparent);
	transform: translateY(-2px);
	box-shadow: 0 8px 32px rgba(0,0,0,.12);
}

/* Accent top border */
.inf-rich-card__accent-bar {
	position: absolute;
	top: 0; left: 0; right: 0;
	height: 3px;
	background: var(--card-accent, var(--inf-accent-color));
	border-radius: 16px 16px 0 0;
}

/* Header row */
.inf-rich-card__header {
	display: flex;
	align-items: center;
	gap: 16px;
	margin-bottom: 16px;
}
.inf-rich-card__icon {
	width: 48px; height: 48px;
	display: flex; align-items: center; justify-content: center;
	border-radius: 12px;
	background: color-mix(in srgb, var(--card-accent) 12%, transparent);
	color: var(--card-accent);
	flex-shrink: 0;
}
.inf-rich-card__icon svg { width: 24px; height: 24px; }
.inf-rich-card__icon--emoji { font-size: 24px; }
.inf-rich-card__title-group { display: flex; flex-wrap: wrap; align-items: baseline; gap: 8px; }
.inf-rich-card__name { font-size: 20px; font-weight: 800; line-height: 1.2; }
.inf-rich-card__version {
	font-size: 11px; font-weight: 700;
	padding: 2px 10px; border-radius: 100px;
	background: color-mix(in srgb, var(--card-accent) 12%, transparent);
	color: var(--card-accent);
	letter-spacing: .3px;
}

/* Tagline */
.inf-rich-card__tagline {
	font-size: 15px; font-weight: 600; line-height: 1.5;
	margin-bottom: 12px; opacity: .75;
}

/* Description */
.inf-rich-card__desc {
	font-size: 14px; line-height: 1.7;
	margin-bottom: 20px; opacity: .55;
}

/* Feature list */
.inf-rich-card__features { margin-bottom: 24px; }
.inf-rich-card__features-title {
	font-size: 10px; font-weight: 700; text-transform: uppercase;
	letter-spacing: 1px; opacity: .4; margin-bottom: 10px;
}
.inf-rich-card__features ul { list-style: none; display: grid; gap: 6px; }
.inf-rich-card__features li {
	font-size: 13px; padding-left: 16px; position: relative;
	line-height: 1.5; opacity: .65;
}
.inf-rich-card__features li::before {
	content: ''; position: absolute; left: 0; top: 7px;
	width: 5px; height: 5px; border-radius: 50%;
	background: var(--card-accent, var(--inf-accent-color));
	opacity: .6;
}
.inf-rich-card__more {
	opacity: .35; font-style: italic;
}
.inf-rich-card__more::before { display: none; }

/* Tech tags */
.inf-rich-card__tech { display: flex; flex-wrap: wrap; gap: 6px; }
.inf-rich-card__tag {
	font-size: 10px; font-weight: 600; letter-spacing: .5px;
	padding: 3px 10px; border-radius: 100px;
	border: 1px solid rgba(0,0,0,.08);
	opacity: .5;
}

/* Stat grid */
.inf-rich-card__stats {
	display: grid; grid-template-columns: repeat(auto-fit, minmax(80px, 1fr));
	gap: 12px; margin-top: 16px;
	padding: 16px; border-radius: 10px;
	background: rgba(0,0,0,.02);
}
.inf-rich-card__stat { text-align: center; }
.inf-rich-card__stat-val {
	display: block; font-size: 16px; font-weight: 800;
	color: var(--card-accent, var(--inf-accent-color));
}
.inf-rich-card__stat-key {
	display: block; font-size: 10px; text-transform: uppercase;
	letter-spacing: .5px; opacity: .4;
}

/* Meta container */
.inf-rich-card__meta {
	display: flex; flex-direction: column; gap: 16px;
	margin-bottom: 20px;
}

/* Link */
.inf-rich-card__link {
	display: inline-flex; align-items: center; gap: 4px;
	font-size: 13px; font-weight: 700;
	color: var(--card-accent, var(--inf-accent-color));
	text-decoration: none;
	transition: gap .2s;
}
.inf-rich-card__link:hover { gap: 8px; }

/* Compact variant */
.inf-rich-card--compact { padding: 24px; }
.inf-rich-card--compact .inf-rich-card__icon { width: 40px; height: 40px; border-radius: 10px; }
.inf-rich-card--compact .inf-rich-card__icon svg { width: 20px; height: 20px; }
.inf-rich-card--compact .inf-rich-card__desc { font-size: 13px; margin-bottom: 16px; }

/* Dark section override */
.inf-section--dark .inf-rich-card {
	background: rgba(255,255,255,.03);
	border-color: rgba(255,255,255,.08);
}
.inf-section--dark .inf-rich-card__name { color: #fff; }
.inf-section--dark .inf-rich-card__stats { background: rgba(255,255,255,.03); }
.inf-section--dark .inf-rich-card__tag { border-color: rgba(255,255,255,.1); }

/* Responsive */
@media (max-width: 1024px) {
	.inf-rich-cards--cols-3 .inf-rich-cards__grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 767px) {
	.inf-rich-cards--cols-2 .inf-rich-cards__grid,
	.inf-rich-cards--cols-3 .inf-rich-cards__grid { grid-template-columns: 1fr; }
	.inf-rich-card { padding: 24px; }
}

/* Full-width card layout at desktop */
@media (min-width: 900px) {
	.inf-rich-cards--cols-1 .inf-rich-card--full {
		display: grid;
		grid-template-columns: 1fr 1fr;
		gap: 32px;
	}
	.inf-rich-cards--cols-1 .inf-rich-card--full .inf-rich-card__header,
	.inf-rich-cards--cols-1 .inf-rich-card--full .inf-rich-card__tagline {
		grid-column: 1 / -1;
	}
}

/* ── Skills Section ───────────────────────────────────────── */

.inf-skills__grid { display: grid; gap: 28px; }
.inf-skills__card {
	background: rgba(255,255,255,.03);
	border: 1px solid rgba(0,0,0,.06);
	border-radius: 12px; padding: 28px;
	transition: border-color .3s, background .3s;
}
.inf-skills__card:hover {
	border-color: rgba(160,67,152,.2);
	background: rgba(0,0,0,.01);
}
.inf-skills__category {
	font-family: var(--inf-heading-font);
	font-size: 20px; letter-spacing: .5px;
	margin-bottom: 16px;
}
.inf-skills__list { list-style: none; display: grid; gap: 8px; }
.inf-skills__list li {
	font-size: 13px; opacity: .55; padding-left: 16px;
	position: relative; line-height: 1.5;
}
.inf-skills__list li::before {
	content: ''; position: absolute; left: 0; top: 7px;
	width: 4px; height: 4px; border-radius: 50%;
	background: var(--inf-accent-color); opacity: .5;
}

/* Dark variant for skills */
.inf-section--dark .inf-skills__card {
	background: rgba(255,255,255,.03);
	border-color: rgba(255,255,255,.06);
}
.inf-section--dark .inf-skills__card:hover {
	border-color: rgba(160,67,152,.2);
	background: rgba(255,255,255,.05);
}

/* ── Footer Social Links ──────────────────────────────────── */

.inf-footer__bottom {
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 16px;
	border-top: 1px solid rgba(255,255,255,.08);
	padding-top: 24px;
	margin-top: 32px;
}
.inf-footer__social {
	display: flex; gap: 12px;
}
.inf-footer__social-link {
	display: flex; align-items: center; justify-content: center;
	width: 36px; height: 36px; border-radius: 50%;
	background: rgba(255,255,255,.08);
	text-decoration: none; font-size: 16px;
	transition: background .2s;
}
.inf-footer__social-link:hover {
	background: rgba(160,67,152,.3);
}

/* ── Hero Responsive (v3.1.0 additions) ───────────────────── */

@media (max-width: 767px) {
	.inf-hero__stats { gap: 24px; flex-wrap: wrap; }
	.inf-hero__stat-num { font-size: 32px; }
	.inf-hero__scroll { display: none; }
}

/* ══════════════════════════════════════════════════════════════
 * PHASE 2 SECTIONS (v3.2.0)
 * ══════════════════════════════════════════════════════════════ */

/* ── Portfolio ── */
.inf-portfolio__filters {
    display: flex; flex-wrap: wrap; justify-content: center;
    gap: 8px; margin-bottom: 32px;
}
.inf-portfolio__filter {
    padding: 8px 20px; border-radius: 100px; border: 1px solid rgba(0,0,0,.1);
    background: transparent; font-size: 13px; font-weight: 600;
    cursor: pointer; transition: all .2s; font-family: inherit; color: inherit;
}
.inf-portfolio__filter:hover { border-color: var(--inf-accent-color); color: var(--inf-accent-color); }
.inf-portfolio__filter--active { background: var(--inf-accent-color); color: #fff; border-color: var(--inf-accent-color); }

.inf-portfolio__grid {
    display: grid; grid-template-columns: repeat(3, 1fr);
}
.inf-portfolio--cols-2 .inf-portfolio__grid { grid-template-columns: repeat(2, 1fr); }
.inf-portfolio--cols-4 .inf-portfolio__grid { grid-template-columns: repeat(4, 1fr); }

.inf-portfolio__item { position: relative; overflow: hidden; border-radius: 12px; }
.inf-portfolio__item--hidden { display: none; }
.inf-portfolio__image { position: relative; aspect-ratio: 4/3; overflow: hidden; }
.inf-portfolio__image img {
    width: 100%; height: 100%; object-fit: cover;
    transition: transform .4s ease;
}
.inf-portfolio__item:hover .inf-portfolio__image img { transform: scale(1.05); }

.inf-portfolio__overlay {
    position: absolute; inset: 0;
    background: linear-gradient(to top, rgba(0,0,0,.75) 0%, transparent 60%);
    display: flex; flex-direction: column; justify-content: flex-end;
    padding: 24px; opacity: 0; transition: opacity .3s ease;
}
.inf-portfolio__item:hover .inf-portfolio__overlay { opacity: 1; }

.inf-portfolio__title { color: #fff; font-size: 16px; font-weight: 700; margin: 0 0 4px; }
.inf-portfolio__desc { color: rgba(255,255,255,.7); font-size: 13px; margin: 0 0 12px; }
.inf-portfolio__actions { display: flex; gap: 8px; }
.inf-portfolio__lb-btn, .inf-portfolio__link-btn {
    width: 36px; height: 36px; border-radius: 50%;
    background: rgba(255,255,255,.15); backdrop-filter: blur(8px);
    border: 1px solid rgba(255,255,255,.2); color: #fff;
    display: flex; align-items: center; justify-content: center;
    cursor: pointer; transition: background .2s;
    text-decoration: none;
}
.inf-portfolio__lb-btn:hover, .inf-portfolio__link-btn:hover { background: rgba(255,255,255,.3); }

/* Portfolio lightbox */
.inf-portfolio__lightbox {
    position: fixed; inset: 0; z-index: 99999;
    background: rgba(0,0,0,.9); backdrop-filter: blur(20px);
    display: flex; align-items: center; justify-content: center;
    flex-direction: column; opacity: 0; pointer-events: none;
    transition: opacity .3s ease;
}
.inf-portfolio__lightbox--open { opacity: 1; pointer-events: auto; }
.inf-portfolio__lb-close {
    position: absolute; top: 20px; right: 24px;
    background: none; border: none; color: #fff; font-size: 36px;
    cursor: pointer; line-height: 1; opacity: .7; transition: opacity .2s;
}
.inf-portfolio__lb-close:hover { opacity: 1; }
.inf-portfolio__lb-img { max-width: 90vw; max-height: 80vh; border-radius: 8px; object-fit: contain; }
.inf-portfolio__lb-caption { color: rgba(255,255,255,.6); font-size: 14px; margin-top: 16px; }

@media (max-width: 1024px) { .inf-portfolio--cols-4 .inf-portfolio__grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 767px) {
    .inf-portfolio__grid { grid-template-columns: repeat(2, 1fr) !important; }
    .inf-portfolio__overlay { opacity: 1; background: linear-gradient(to top, rgba(0,0,0,.6) 0%, transparent 50%); }
}
@media (max-width: 480px) { .inf-portfolio__grid { grid-template-columns: 1fr !important; } }

/* ── Counter ── */
.inf-counter__grid {
    display: grid; grid-template-columns: repeat(4, 1fr); gap: 32px;
}
.inf-counter--cols-2 .inf-counter__grid { grid-template-columns: repeat(2, 1fr); }
.inf-counter--cols-3 .inf-counter__grid { grid-template-columns: repeat(3, 1fr); }

.inf-counter__item { text-align: center; }
.inf-counter__icon { font-size: 36px; margin-bottom: 12px; }
.inf-counter__value {
    font-family: var(--inf-heading-font, inherit);
    font-size: clamp(36px, 6vw, 56px); font-weight: 900; line-height: 1;
    color: var(--counter-accent, var(--inf-accent-color));
}
.inf-counter__prefix, .inf-counter__suffix { font-size: .6em; opacity: .8; }
.inf-counter__label {
    font-size: 12px; font-weight: 600; text-transform: uppercase;
    letter-spacing: 1px; opacity: .45; margin-top: 8px;
}

@media (max-width: 767px) {
    .inf-counter__grid { grid-template-columns: repeat(2, 1fr); gap: 24px; }
    .inf-counter__value { font-size: 36px; }
}

/* ── Progress Bar ── */
.inf-progress__bar-item { margin-bottom: 20px; }
.inf-progress__bar-header {
    display: flex; justify-content: space-between; align-items: center;
    margin-bottom: 8px;
}
.inf-progress__bar-label { font-size: 14px; font-weight: 600; }
.inf-progress__bar-percent { font-size: 13px; font-weight: 700; opacity: .6; }
.inf-progress__bar-track {
    height: 10px; background: rgba(0,0,0,.06); border-radius: 100px; overflow: hidden;
}
.inf-progress__bar-fill {
    height: 100%; border-radius: 100px; transition: width 1.5s cubic-bezier(.4,0,.2,1);
}

/* Progress circle */
.inf-progress__circle-grid { display: flex; flex-wrap: wrap; justify-content: center; gap: 40px; }
.inf-progress__circle-item { position: relative; text-align: center; width: 140px; }
.inf-progress__circle-svg { width: 120px; height: 120px; transform: rotate(-90deg); }
.inf-progress__circle-bg { fill: none; stroke: rgba(0,0,0,.06); stroke-width: 8; }
.inf-progress__circle-fill {
    fill: none; stroke-width: 8; stroke-linecap: round;
    transition: stroke-dashoffset 1.5s cubic-bezier(.4,0,.2,1);
}
.inf-progress__circle-text {
    position: absolute; top: 50%; left: 50%;
    transform: translate(-50%, -50%);
    font-size: 22px; font-weight: 800;
}
.inf-progress__circle-label { font-size: 13px; font-weight: 600; margin-top: 8px; opacity: .6; }

/* ── Table ── */
.inf-table__scroll { overflow-x: auto; -webkit-overflow-scrolling: touch; border-radius: 12px; border: 1px solid rgba(0,0,0,.08); }
.inf-table {
    width: 100%; border-collapse: collapse; font-size: 14px; min-width: 500px;
}
.inf-table th {
    padding: 14px 16px; font-size: 10px; font-weight: 700; text-transform: uppercase;
    letter-spacing: .8px; text-align: left; background: rgba(0,0,0,.02);
    border-bottom: 2px solid rgba(0,0,0,.06); user-select: none; white-space: nowrap;
}
.inf-table--sortable th { cursor: pointer; transition: background .2s; }
.inf-table--sortable th:hover { background: rgba(0,0,0,.04); }
.inf-table__sort-icon { margin-left: 4px; font-size: 10px; opacity: .3; }
.inf-table td { padding: 12px 16px; border-bottom: 1px solid rgba(0,0,0,.04); }
.inf-table--striped tbody tr:nth-child(even) td { background: rgba(0,0,0,.015); }
.inf-table tbody tr:hover td { background: rgba(160,67,152,.03); }
.inf-table--compact th { padding: 10px 12px; }
.inf-table--compact td { padding: 8px 12px; font-size: 13px; }

/* Dark section overrides */
.inf-section--dark .inf-table__scroll { border-color: rgba(255,255,255,.08); }
.inf-section--dark .inf-table th { background: rgba(255,255,255,.03); border-color: rgba(255,255,255,.08); }
.inf-section--dark .inf-table td { border-color: rgba(255,255,255,.04); }
.inf-section--dark .inf-table--striped tbody tr:nth-child(even) td { background: rgba(255,255,255,.02); }
.inf-section--dark .inf-table tbody tr:hover td { background: rgba(160,67,152,.08); }
.inf-section--dark .inf-progress__bar-track { background: rgba(255,255,255,.08); }
.inf-section--dark .inf-progress__circle-bg { stroke: rgba(255,255,255,.08); }

/* ── Before/After ── */
.inf-ba__container {
    position: relative; overflow: hidden; border-radius: 12px;
    cursor: ew-resize; user-select: none; max-width: 900px; margin: 0 auto;
    touch-action: pan-y;
}
.inf-ba__container[data-orientation="vertical"] { cursor: ns-resize; touch-action: pan-x; }
.inf-ba__before, .inf-ba__after { position: relative; }
.inf-ba__before { position: absolute; inset: 0; z-index: 2; }
.inf-ba__before img, .inf-ba__after img {
    width: 100%; height: 100%; object-fit: cover; display: block;
    pointer-events: none;
}
.inf-ba__label {
    position: absolute; padding: 6px 14px; border-radius: 100px;
    background: rgba(0,0,0,.55); backdrop-filter: blur(8px);
    color: #fff; font-size: 11px; font-weight: 700; letter-spacing: .5px;
    text-transform: uppercase; pointer-events: none;
}
.inf-ba__label--before { bottom: 16px; left: 16px; }
.inf-ba__label--after { bottom: 16px; right: 16px; }

.inf-ba__handle {
    position: absolute; z-index: 3;
}
.inf-ba__container[data-orientation="horizontal"] .inf-ba__handle {
    top: 0; bottom: 0; width: 3px; transform: translateX(-50%);
}
.inf-ba__container[data-orientation="vertical"] .inf-ba__handle {
    left: 0; right: 0; height: 3px; transform: translateY(-50%);
}
.inf-ba__handle-line {
    position: absolute; background: #fff;
    box-shadow: 0 0 8px rgba(0,0,0,.3);
}
.inf-ba__container[data-orientation="horizontal"] .inf-ba__handle-line { top: 0; bottom: 0; left: 50%; width: 3px; transform: translateX(-50%); }
.inf-ba__container[data-orientation="vertical"] .inf-ba__handle-line { left: 0; right: 0; top: 50%; height: 3px; transform: translateY(-50%); }

.inf-ba__handle-grip {
    position: absolute; width: 44px; height: 44px;
    background: #fff; border-radius: 50%;
    box-shadow: 0 2px 12px rgba(0,0,0,.25);
    display: flex; align-items: center; justify-content: center;
    color: var(--inf-accent-color);
}
.inf-ba__container[data-orientation="horizontal"] .inf-ba__handle-grip { top: 50%; left: 50%; transform: translate(-50%, -50%); }
.inf-ba__container[data-orientation="vertical"] .inf-ba__handle-grip { top: 50%; left: 50%; transform: translate(-50%, -50%); }

/* ── Enhanced Animations (v3.2.0) ── */
.inf-hover-lift { transition: transform .3s ease, box-shadow .3s ease; }
.inf-hover-lift:hover { transform: translateY(-4px); box-shadow: 0 12px 40px rgba(0,0,0,.1); }

.inf-hover-glow { transition: box-shadow .3s ease; }
.inf-hover-glow:hover { box-shadow: 0 0 30px rgba(160,67,152,.15); }

.inf-hover-border { transition: border-color .3s ease; }
.inf-hover-border:hover { border-color: var(--inf-accent-color) !important; }

.inf-hover-scale { transition: transform .3s ease; }
.inf-hover-scale:hover { transform: scale(1.015); }

[data-inf-animate="bounce"] { animation-timing-function: cubic-bezier(.68,-.55,.27,1.55); }
[data-inf-animate="flip"] { perspective: 600px; }
[data-inf-animate="flip"].inf-visible { animation: infFlip .6s ease forwards; }
@keyframes infFlip {
    from { transform: rotateY(-90deg); opacity: 0; }
    to { transform: rotateY(0); opacity: 1; }
}

/* Parallax scroll effect wrapper */
.inf-parallax-bg {
    background-attachment: fixed;
    background-size: cover;
    background-position: center;
}
@media (max-width: 767px) {
    .inf-parallax-bg { background-attachment: scroll; }
}

/* ── Dynamic Content Tag Placeholder ── */
.inf-dynamic-tag {
    display: inline; font-style: inherit;
}

/* ── Blinds Enhancements (v3.2.0) ── */
/* Mobile drawer (bottom-sheet style) */
.bld-drawer {
    position: fixed; bottom: 0; left: 0; right: 0; z-index: 99990;
    background: #fff; border-radius: 16px 16px 0 0;
    box-shadow: 0 -4px 32px rgba(0,0,0,.15);
    transform: translateY(100%); transition: transform .35s cubic-bezier(.16,1,.3,1);
    max-height: 85vh; overflow-y: auto;
    display: none;
}
.bld-drawer--open { display: block; transform: translateY(0); }
.bld-drawer__handle {
    display: flex; justify-content: center; padding: 12px 0 8px;
}
.bld-drawer__handle-bar {
    width: 40px; height: 4px; border-radius: 4px; background: rgba(0,0,0,.15);
}
.bld-drawer__content { padding: 0 24px 32px; }
.bld-drawer__backdrop {
    position: fixed; inset: 0; z-index: 99989;
    background: rgba(0,0,0,.4); opacity: 0; pointer-events: none;
    transition: opacity .3s ease;
}
.bld-drawer__backdrop--visible { opacity: 1; pointer-events: auto; }

/* Search bar in header */
.bld-bar__search {
    position: relative; display: flex; align-items: center;
}
.bld-bar__search-input {
    padding: 8px 16px 8px 36px; border: 1px solid rgba(255,255,255,.15);
    border-radius: 100px; background: rgba(255,255,255,.08);
    color: inherit; font-size: 13px; font-family: inherit;
    width: 200px; transition: width .3s ease, border-color .2s;
}
.bld-bar__search-input::placeholder { color: rgba(255,255,255,.4); }
.bld-bar__search-input:focus { width: 280px; border-color: rgba(255,255,255,.3); outline: none; }
.bld-bar__search-icon {
    position: absolute; left: 12px; pointer-events: none;
    opacity: .5; display: flex;
}

/* Cart icon */
.bld-bar__cart {
    position: relative; display: flex; align-items: center;
    text-decoration: none; color: inherit; padding: 6px;
}
.bld-bar__cart-count {
    position: absolute; top: -2px; right: -4px;
    min-width: 18px; height: 18px;
    background: var(--inf-btn-bg); color: var(--inf-btn-text);
    font-size: 10px; font-weight: 800; border-radius: 100px;
    display: flex; align-items: center; justify-content: center;
    padding: 0 4px;
}
.bld-bar__cart-count:empty { display: none; }

/* Sticky shrink */
.bld-bar--shrink { transition: padding .4s ease, font-size .4s ease; }
.bld-bar--shrink.bld-bar--scrolled { padding-top: 8px; padding-bottom: 8px; }
.bld-bar--shrink.bld-bar--scrolled .bld-bar__logo-img {
    max-height: 32px; transition: max-height .4s ease;
}

/* ── Popup / Modal System (v3.2.0) ── */
.inf-popup-overlay {
    position: fixed; inset: 0; z-index: 99998;
    background: rgba(0,0,0,.6); backdrop-filter: blur(8px);
    display: flex; align-items: center; justify-content: center;
    opacity: 0; pointer-events: none; transition: opacity .3s ease;
}
.inf-popup-overlay--visible { opacity: 1; pointer-events: auto; }

.inf-popup {
    background: #fff; border-radius: 16px; position: relative;
    max-width: 90vw; max-height: 85vh; overflow-y: auto;
    box-shadow: 0 24px 80px rgba(0,0,0,.2);
    animation: infPopupIn .35s cubic-bezier(.16,1,.3,1);
}
@keyframes infPopupIn {
    from { transform: scale(.92) translateY(20px); opacity: 0; }
    to { transform: scale(1) translateY(0); opacity: 1; }
}
.inf-popup--sm { width: 480px; }
.inf-popup--md { width: 640px; }
.inf-popup--lg { width: 900px; }
.inf-popup--xl { width: 960px; }
.inf-popup--full { width: 95vw; height: 90vh; }

.inf-popup__close {
    position: absolute; top: 16px; right: 16px; z-index: 10;
    width: 32px; height: 32px; border-radius: 50%;
    background: rgba(0,0,0,.06); border: none;
    display: flex; align-items: center; justify-content: center;
    cursor: pointer; font-size: 18px; color: inherit;
    transition: background .2s;
}
.inf-popup__close:hover { background: rgba(0,0,0,.1); }

.inf-popup__content { padding: 40px; }
.inf-popup__content .inf-section { padding-top: 0 !important; padding-bottom: 0 !important; }

/* v4.0.0 — Per-section alignment controls ───────────────── */
.inf-section--pos-left .inf-container,.inf-section--pos-left .inf-wrap{margin-left:0;margin-right:auto}
.inf-section--pos-right .inf-container,.inf-section--pos-right .inf-wrap{margin-left:auto;margin-right:0}
.inf-section--pos-center .inf-container,.inf-section--pos-center .inf-wrap{margin-left:auto;margin-right:auto}
.inf-section[style*="--inf-section-max-w"] .inf-container,.inf-section[style*="--inf-section-max-w"] .inf-wrap{max-width:var(--inf-section-max-w)}
.inf-section--valign-start{display:flex;align-items:flex-start}
.inf-section--valign-center{display:flex;align-items:center}
.inf-section--valign-end{display:flex;align-items:flex-end}
.inf-section--valign-start .inf-container,.inf-section--valign-center .inf-container,.inf-section--valign-end .inf-container{width:100%}

/* v4.2.0 — When section has explicit text-align via inline style, override
   child defaults that hardcode text-align:center. The inline style on the
   section sets text-align, and this rule forces children to inherit it. */
.inf-section[style*="text-align"] .inf-section__heading,
.inf-section[style*="text-align"] .inf-section__sub,
.inf-section[style*="text-align"] .inf-section__label,
.inf-section[style*="text-align"] .inf-features__item,
.inf-section[style*="text-align"] .inf-pricing__card,
.inf-section[style*="text-align"] .inf-stats__grid,
.inf-section[style*="text-align"] .inf-team__card,
.inf-section[style*="text-align"] .inf-icon-grid__item,
.inf-section[style*="text-align"] .inf-cta__inner,
.inf-section[style*="text-align"] .inf-logos__heading,
.inf-section[style*="text-align"] .inf-banner__inner,
.inf-section[style*="text-align"] .inf-footer__copy,
.inf-section[style*="text-align"] .inf-countdown,
.inf-section[style*="text-align"] .inf-countdown__unit,
.inf-section[style*="text-align"] .inf-newsletter,
.inf-section[style*="text-align"] .inf-comparison__table td,
.inf-section[style*="text-align"] .inf-hero__stat,
.inf-section[style*="text-align"] .inf-rich-card__stat,
.inf-section[style*="text-align"] .inf-counter__item,
.inf-section[style*="text-align"] .inf-progress__circle-item,
.inf-section[style*="text-align"] .inf-media__caption,
.inf-section[style*="text-align"] .inf-hero__content,
.inf-section[style*="text-align"] .inf-hero__heading,
.inf-section[style*="text-align"] .inf-hero__sub,
.inf-section[style*="text-align"] .inf-hero__body,
.inf-section[style*="text-align"] .inf-hero__actions,
.inf-section[style*="text-align"] .inf-container {
	text-align: inherit !important;
}

/* ══════════════════════════════════════════════════════════════
 * v5.0.0 — New Section Styles
 * ══════════════════════════════════════════════════════════════ */

/* ═══ Horizontal Scroll ═══ */
.inf-hscroll{position:relative;overflow:hidden}
.inf-hscroll__track{position:sticky;top:0;height:100vh;width:100%;overflow:hidden}
.inf-hscroll__track::-webkit-scrollbar{display:none}
.inf-hscroll__slides{display:flex;height:100%;will-change:transform;transition:transform .05s linear}
.inf-hscroll__slide{flex:0 0 100vw;width:100vw;height:100%;display:flex;align-items:center;justify-content:center;position:relative}
.inf-hscroll__slide-content{max-width:680px;padding:40px;text-align:center}
.inf-hscroll__heading{font-family:var(--inf-heading-font,var(--inf-font));font-weight:900;font-size:clamp(2rem,5vw,3.5rem);margin:0 0 16px}
.inf-hscroll__body{font-size:1.1em;line-height:1.7;opacity:.7;margin:0 0 24px}
.inf-hscroll__dots{position:absolute;bottom:24px;left:50%;transform:translateX(-50%);display:flex;gap:8px;z-index:2}
.inf-hscroll__dot{width:10px;height:10px;border-radius:50%;background:rgba(255,255,255,.3);transition:background .3s}
.inf-hscroll__dot--active{background:var(--inf-accent-color)}
.inf-hscroll__arrow{position:absolute;right:32px;top:50%;transform:translateY(-50%);font-size:32px;opacity:.3;animation:inf-hscroll-pulse 2s ease-in-out infinite}
@keyframes inf-hscroll-pulse{0%,100%{opacity:.3;transform:translateY(-50%) translateX(0)}50%{opacity:.6;transform:translateY(-50%) translateX(8px)}}

/* ═══ Scroll Direction ═══ */
.inf-scroll-dir{display:flex;align-items:center;justify-content:center;min-height:120px;text-align:center}
.inf-scroll-dir__inner{display:flex;flex-direction:column;align-items:center;gap:12px}
.inf-scroll-dir__arrow{font-weight:900;line-height:1;transition:transform .3s;opacity:.6}
.inf-scroll-dir:hover .inf-scroll-dir__arrow{opacity:1}
.inf-scroll-dir--right:hover .inf-scroll-dir__arrow{transform:translateX(12px)}
.inf-scroll-dir--left:hover .inf-scroll-dir__arrow{transform:translateX(-12px)}
.inf-scroll-dir--down:hover .inf-scroll-dir__arrow{transform:translateY(12px)}
.inf-scroll-dir--up:hover .inf-scroll-dir__arrow{transform:translateY(-12px)}
.inf-scroll-dir__label{font-size:.85em;font-weight:700;text-transform:uppercase;letter-spacing:.1em;opacity:.4}

/* ═══ Image Hero ═══ */
.inf-image-hero{position:relative;display:flex;overflow:hidden}
.inf-image-hero__overlay{position:absolute;inset:0;z-index:1}
.inf-image-hero__content{position:relative;z-index:2;display:flex;flex-direction:column;gap:16px;max-width:780px;width:100%}
.inf-image-hero--center{align-items:center;justify-content:center;text-align:center}
.inf-image-hero--center .inf-image-hero__content{align-items:center}
.inf-image-hero--left{align-items:flex-start;justify-content:center}
.inf-image-hero--right{align-items:flex-end;justify-content:center}
.inf-image-hero--v-start{align-items:inherit;justify-content:flex-start;padding-top:80px}
.inf-image-hero--v-end{align-items:inherit;justify-content:flex-end;padding-bottom:80px}
.inf-image-hero__label{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.15em;opacity:.6}
.inf-image-hero__heading{font-family:var(--inf-heading-font,var(--inf-font));font-weight:900;font-size:clamp(2.5rem,6vw,5rem);margin:0;line-height:1.1}
.inf-image-hero__sub{font-size:1.15em;line-height:1.6;opacity:.75;margin:0;max-width:600px}
.inf-image-hero__actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:8px}

/* ═══ Image Mosaic ═══ */
.inf-image-mosaic__grid{display:grid;grid-auto-rows:250px;grid-auto-flow:dense}
.inf-image-mosaic__item{margin:0;overflow:hidden;position:relative;cursor:pointer}
.inf-image-mosaic__item--tall{grid-row:span 2}
.inf-image-mosaic__item--wide{grid-column:span 2}
.inf-image-mosaic__item--large{grid-column:span 2;grid-row:span 2}
.inf-image-mosaic__item--rounded{border-radius:12px}
.inf-image-mosaic__img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.inf-image-mosaic__item:hover .inf-image-mosaic__img{transform:scale(1.05)}
.inf-image-mosaic__caption{position:absolute;bottom:0;left:0;right:0;padding:12px 16px;background:linear-gradient(transparent,rgba(0,0,0,.7));color:#fff;font-size:.85em;font-weight:600;opacity:0;transform:translateY(4px);transition:opacity .3s,transform .3s}
.inf-image-mosaic__item:hover .inf-image-mosaic__caption{opacity:1;transform:translateY(0)}

/* ═══ Image Editorial ═══ */
.inf-editorial__grid{display:grid;grid-template-columns:1.2fr 1fr;gap:0;align-items:center}
.inf-editorial--image-right .inf-editorial__grid{grid-template-columns:1fr 1.2fr}
.inf-editorial--image-right .inf-editorial__image-wrap{order:2}
.inf-editorial--image-right .inf-editorial__text{order:1}
.inf-editorial__image-wrap{overflow:hidden;border-radius:16px}
.inf-editorial__image{width:100%;height:100%;object-fit:cover;display:block}
.inf-editorial__placeholder{width:100%;height:100%;background:var(--inf-accent-color);opacity:.08;border-radius:16px}
.inf-editorial__text{padding:40px;position:relative;z-index:2;margin-left:calc(var(--editorial-overlap,60px) * -1)}
.inf-editorial--image-right .inf-editorial__text{margin-left:0;margin-right:calc(var(--editorial-overlap,60px) * -1)}
.inf-editorial__heading{font-family:var(--inf-heading-font,var(--inf-font));font-weight:900;font-size:2rem;margin:0 0 16px;line-height:1.2}
.inf-editorial__body{font-size:1em;line-height:1.8;opacity:.65}
.inf-editorial__body p{margin:0 0 16px}
@media(max-width:768px){.inf-editorial__grid{grid-template-columns:1fr !important}.inf-editorial__text{margin:0!important;padding:24px 0}.inf-editorial--image-right .inf-editorial__image-wrap{order:0}}

/* ═══ Image Carousel ═══ */
.inf-img-carousel__track{display:flex;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.inf-img-carousel__track::-webkit-scrollbar{display:none}
.inf-img-carousel__track--peek{padding:0 calc(50vw - 600px)}
.inf-img-carousel__slide{flex:0 0 auto;width:min(85vw,800px);scroll-snap-align:center;position:relative;overflow:hidden;border-radius:16px}
.inf-img-carousel__img{width:100%;height:100%;object-fit:cover;display:block}
.inf-img-carousel__caption{position:absolute;bottom:0;left:0;right:0;padding:16px 20px;background:linear-gradient(transparent,rgba(0,0,0,.65));color:#fff;font-size:.9em;font-weight:600}
@media(max-width:768px){.inf-img-carousel__track--peek{padding:0 16px}.inf-img-carousel__slide{width:85vw}}

/* ══════════════════════════════════════════════════════════════
   CANVAS LAYOUT MODE (v5.1.0)
   Absolute positioning of sections — matches canvas editor.
   Below 1024px: auto-falls back to flow mode for mobile safety.
   ══════════════════════════════════════════════════════════════ */

.inf-canvas-layout {
	position: relative;
	width: 100%;
	overflow: visible;
}

.inf-canvas-item {
	/* Absolute-positioned items get inline styles from PHP. */
	transition: opacity 0.3s ease, transform 0.3s ease;
}

/* v6.0.0.3 — Ensure sections inside canvas items fill the canvas item's width.
 * Without this, grid-based sections (columns) can't calculate fr units because
 * their parent (the canvas item) has no explicit width context when absolutely
 * positioned. The canvas item gets width from PHP/JS, and the section inside
 * must inherit it fully. */
.inf-canvas-item > [data-inf-live-index],
.inf-canvas-item > section,
.inf-canvas-item > div {
	width: 100%;
	box-sizing: border-box;
}

/* Columns sections inside canvas items need explicit width inheritance
 * so the CSS grid grid-template-columns with fr units can resolve. */
.inf-canvas-item .inf-section--columns {
	width: 100%;
}
.inf-canvas-item .inf-section--columns .inf-wrap {
	width: 100%;
	box-sizing: border-box;
}

/* Flow items inside canvas layout — no absolute positioning, normal document flow. */
.inf-canvas-item--flow {
	position: relative;
	width: 100%;
}

/* ── Responsive fallback: below 1024px → revert to flow ────── */
@media (max-width: 1024px) {
	.inf-canvas-layout {
		min-height: auto !important;
	}
	.inf-canvas-item {
		position: relative !important;
		left: auto !important;
		top: auto !important;
		width: 100% !important;
		height: auto !important;
		z-index: auto !important;
		margin-bottom: 0;
	}
}

/* ══════════════════════════════════════════════════════════════
 * v5.2.0 — Hero Logo Image
 * ══════════════════════════════════════════════════════════════ */

.inf-hero__logo { margin-bottom: 24px; }
.inf-hero__logo-img { max-height: 80px; object-fit: contain; }
.inf-hero--center .inf-hero__logo { text-align: center; }
.inf-hero--left .inf-hero__logo { text-align: left; }
.inf-hero--right .inf-hero__logo { text-align: right; }

/* ══════════════════════════════════════════════════════════════
 * v5.2.0 — Testimonial Enhancements
 * ══════════════════════════════════════════════════════════════ */

.inf-testimonial__stars {
	color: #F59E0B;
	font-size: 15px;
	letter-spacing: 2px;
	margin-bottom: 10px;
}
.inf-testimonial__headline {
	font-size: 18px;
	font-weight: 800;
	margin: 0 0 12px;
	line-height: 1.3;
}
.inf-testimonial__company-logo {
	height: 24px;
	margin-left: auto;
	opacity: .5;
	object-fit: contain;
	transition: opacity .2s ease;
}
.inf-testimonial__card:hover .inf-testimonial__company-logo { opacity: .8; }

/* ══════════════════════════════════════════════════════════════
 * v5.2.0 — Feature Showcase
 * ══════════════════════════════════════════════════════════════ */

.inf-feature-showcase__grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 48px;
	align-items: center;
}
.inf-feature-showcase--text-right .inf-feature-showcase__text { order: 2; }
.inf-feature-showcase--text-right .inf-feature-showcase__cards { order: 1; }

.inf-feature-showcase__body {
	font-size: 16px;
	line-height: 1.75;
	opacity: .75;
	margin-bottom: 28px;
}
.inf-feature-showcase__actions { display: flex; gap: 12px; flex-wrap: wrap; }

.inf-feature-showcase__cards {
	display: grid;
	gap: 16px;
}
.inf-feature-showcase__cards--cols-1 { grid-template-columns: 1fr; }
.inf-feature-showcase__cards--cols-2 { grid-template-columns: repeat(2, 1fr); }
.inf-feature-showcase__cards--cols-3 { grid-template-columns: repeat(3, 1fr); }

.inf-feature-showcase__card {
	padding: 24px;
	background: rgba(0,0,0,.03);
	border: 1px solid rgba(0,0,0,.06);
	border-radius: 14px;
	transition: transform .25s ease, box-shadow .25s ease;
}
.inf-feature-showcase__card:hover {
	transform: translateY(-2px);
	box-shadow: 0 8px 24px rgba(0,0,0,.06);
}
.inf-feature-showcase__card-img {
	border-radius: 10px;
	overflow: hidden;
	margin-bottom: 12px;
}
.inf-feature-showcase__card-img img {
	width: 100%;
	height: 140px;
	object-fit: cover;
	display: block;
}
.inf-feature-showcase__card-icon {
	font-size: 32px;
	margin-bottom: 12px;
}
.inf-feature-showcase__card-title {
	font-size: 15px;
	font-weight: 700;
	margin: 0 0 6px;
}
.inf-feature-showcase__card-desc {
	font-size: 13px;
	opacity: .6;
	margin: 0;
	line-height: 1.5;
}

@media (max-width: 767px) {
	.inf-feature-showcase__grid {
		grid-template-columns: 1fr;
		gap: 32px;
	}
	.inf-feature-showcase--text-right .inf-feature-showcase__text { order: 1; }
	.inf-feature-showcase--text-right .inf-feature-showcase__cards { order: 2; }
}

/* ══════════════════════════════════════════════════════════════
 * v5.2.0 — Numbered Value Props
 * ══════════════════════════════════════════════════════════════ */

.inf-numbered-props__list { max-width: 900px; margin: 0 auto; }

.inf-numbered-props__item {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 32px;
	align-items: start;
	padding: 32px 0;
}
.inf-numbered-props__left {
	display: flex;
	gap: 16px;
	align-items: baseline;
}
.inf-numbered-props__num {
	font-size: 48px;
	font-weight: 900;
	opacity: .12;
	line-height: 1;
	color: var(--inf-plum);
	flex-shrink: 0;
}
.inf-numbered-props__title {
	font-size: 20px;
	font-weight: 700;
	margin: 0;
}
.inf-numbered-props__desc {
	font-size: 15px;
	opacity: .65;
	margin: 0;
	line-height: 1.75;
}
.inf-numbered-props__divider {
	border: none;
	border-top: 1px solid rgba(0,0,0,.08);
	margin: 0;
}
.inf-section--dark .inf-numbered-props__divider {
	border-top-color: rgba(255,255,255,.1);
}

@media (max-width: 767px) {
	.inf-numbered-props__item {
		grid-template-columns: 1fr;
		gap: 16px;
	}
}

/* ══════════════════════════════════════════════════════════════
 * v5.2.0 — Carousel
 * ══════════════════════════════════════════════════════════════ */

.inf-carousel__wrap { position: relative; }

.inf-carousel__viewport {
	overflow: hidden;
	border-radius: 14px;
}
.inf-carousel__track {
	display: flex;
	transition: transform .5s cubic-bezier(.4, 0, .2, 1);
}
.inf-carousel--fade .inf-carousel__track,
.inf-carousel--scale .inf-carousel__track {
	display: grid;
	grid-template-columns: 1fr;
}
.inf-carousel--fade .inf-carousel__slide,
.inf-carousel--scale .inf-carousel__slide {
	grid-area: 1 / 1;
	opacity: 0;
	transition: opacity .5s ease, transform .5s ease;
}
.inf-carousel--fade .inf-carousel__slide.inf-carousel__slide--active { opacity: 1; }
.inf-carousel--scale .inf-carousel__slide.inf-carousel__slide--active { opacity: 1; transform: scale(1); }
.inf-carousel--scale .inf-carousel__slide { transform: scale(.92); }

/* Continuous smooth scroll */
.inf-carousel--continuous .inf-carousel__track { transition: none; }
.inf-carousel--continuous .inf-carousel__arrow { display: none; }
.inf-carousel--continuous .inf-carousel__dots { display: none; }
.inf-carousel--continuous .inf-carousel__viewport { border-radius: 0; }

.inf-carousel__slide { flex-shrink: 0; min-width: 0; }

/* Arrow buttons */
.inf-carousel__arrow {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	z-index: 2;
	width: 44px;
	height: 44px;
	border-radius: 50%;
	background: rgba(255,255,255,.9);
	border: 1px solid rgba(0,0,0,.08);
	box-shadow: 0 2px 12px rgba(0,0,0,.1);
	font-size: 20px;
	font-weight: 700;
	cursor: pointer;
	transition: background .2s, transform .2s;
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--inf-space, #25283D);
}
.inf-carousel__arrow:hover { background: #fff; transform: translateY(-50%) scale(1.05); }
.inf-carousel__arrow--prev { left: -22px; }
.inf-carousel__arrow--next { right: -22px; }

/* Inside a container section, arrows may be clipped by overflow:hidden
   (applied for border-radius). Pull them inside the carousel viewport. */
.inf-container-wrap__inner .inf-carousel__arrow--prev { left: 8px; }
.inf-container-wrap__inner .inf-carousel__arrow--next { right: 8px; }

/* Dots */
.inf-carousel__dots {
	display: flex;
	justify-content: center;
	gap: 8px;
	margin-top: 24px;
}
.inf-carousel__dot {
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background: rgba(0,0,0,.15);
	border: none;
	padding: 0;
	cursor: pointer;
	transition: background .2s, transform .2s;
}
.inf-carousel__dot--active {
	background: var(--inf-plum, #A04398);
	transform: scale(1.3);
}
.inf-section--dark .inf-carousel__dot { background: rgba(255,255,255,.2); }
.inf-section--dark .inf-carousel__dot--active { background: var(--inf-plum, #A04398); }

/* Card types */
.inf-carousel__card { height: 100%; }
.inf-carousel__card--image { border-radius: 12px; overflow: hidden; }
.inf-carousel__card--image img { width: 100%; height: 100%; object-fit: cover; display: block; }
.inf-carousel__caption {
	padding: 12px 16px;
	font-size: 13px;
	opacity: .65;
	text-align: center;
}

.inf-carousel__card--testimonial {
	padding: 28px;
	background: rgba(0,0,0,.03);
	border: 1px solid rgba(0,0,0,.06);
	border-radius: 14px;
	display: flex;
	flex-direction: column;
}
.inf-carousel__stars {
	color: #F59E0B;
	font-size: 14px;
	letter-spacing: 2px;
	margin-bottom: 10px;
}
.inf-carousel__headline {
	font-size: 16px;
	font-weight: 800;
	margin: 0 0 10px;
}
.inf-carousel__text {
	font-style: italic;
	opacity: .75;
	margin: 0 0 16px;
	flex: 1;
}
.inf-carousel__author {
	display: flex;
	align-items: center;
	gap: 10px;
	margin-top: auto;
}
.inf-carousel__avatar {
	width: 36px;
	height: 36px;
	border-radius: 50%;
	object-fit: cover;
}
.inf-carousel__name { font-size: 14px; font-weight: 700; font-style: normal; display: block; }
.inf-carousel__role { font-size: 12px; opacity: .6; display: block; }
.inf-carousel__company-logo {
	height: 24px;
	margin-left: auto;
	opacity: .5;
	object-fit: contain;
}

.inf-carousel__card--card {
	background: rgba(0,0,0,.03);
	border: 1px solid rgba(0,0,0,.06);
	border-radius: 14px;
	overflow: hidden;
	transition: transform .25s ease, box-shadow .25s ease;
}
.inf-carousel__card--card:hover {
	transform: translateY(-2px);
	box-shadow: 0 8px 24px rgba(0,0,0,.06);
}
.inf-carousel__card-img img { width: 100%; height: 180px; object-fit: cover; display: block; }
.inf-carousel__card-body { padding: 20px; }
.inf-carousel__card-icon { font-size: 28px; margin-bottom: 10px; }
.inf-carousel__card-title { font-size: 16px; font-weight: 700; margin: 0 0 8px; }
.inf-carousel__card-desc { font-size: 14px; opacity: .65; margin: 0 0 12px; line-height: 1.5; }
.inf-carousel__card-link {
	font-size: 13px;
	font-weight: 700;
	color: var(--inf-plum, #A04398);
	text-decoration: none;
}
.inf-carousel__card-link:hover { text-decoration: underline; }

.inf-carousel__card--logo {
	display: flex;
	align-items: center;
	justify-content: center;
	height: 80px;
	padding: 16px;
}
.inf-carousel__logo-img { max-height: 48px; object-fit: contain; opacity: .5; transition: opacity .2s; }
.inf-carousel__card--logo:hover .inf-carousel__logo-img { opacity: .8; }

.inf-carousel__card--custom { padding: 24px; }

@media (max-width: 767px) {
	.inf-carousel__arrow--prev { left: 4px; }
	.inf-carousel__arrow--next { right: 4px; }
	.inf-carousel__arrow { width: 36px; height: 36px; font-size: 16px; }
}

/* v5.2.0 — Naked carousel: strip card chrome */
.inf-carousel--naked .inf-carousel__card--card,
.inf-carousel--naked .inf-carousel__card--testimonial,
.inf-carousel--naked .inf-carousel__card--image,
.inf-carousel--naked .inf-carousel__card--logo,
.inf-carousel--naked .inf-carousel__card--custom {
	background: none;
	border: none;
	box-shadow: none;
	border-radius: 0;
	padding: 0;
}
.inf-carousel--naked .inf-carousel__card--card:hover {
	transform: none;
	box-shadow: none;
}

/* ══════════════════════════════════════════════════════════════
   CM + DELEGATE ISOLATION — v6.2.2
   Sections containing delegated third-party content (CM shortcode,
   MSP Hub portal tabs) opt out of the blanket color-inherit rule
   via a modifier class on the <section> element. The third-party
   CSS then controls its own colours without interference.
   ══════════════════════════════════════════════════════════════ */

/* CM shell hidden — Blinds provides nav. */
.inf-portal-delegate--cm .ajt-cm-topbar,
.inf-portal-delegate--cm .ajt-cm-admin-bar { display: none !important; }
.inf-portal-delegate--cm .ajt-cm-content { padding-top: 0 !important; margin-top: 0 !important; }
.inf-portal-delegate--cm .ajt-cm { min-height: auto !important; max-width: none !important; }

/* Hide redundant Glass heading — CM delegate content provides its own titles. */
.inf-portal--staff > .inf-portal__inner > .inf-portal__heading { display: none !important; }

/* Staff portal wide layout. */
.inf-portal--staff .inf-portal__inner { max-width: 1600px !important; padding-left: 24px !important; padding-right: 24px !important; }

/* Ticket modal above Blinds. */
.inf-portal-delegate--cm .ajt-cm-modal-overlay { z-index: 10000 !important; }

/* ══════════════════════════════════════════════════════════════
   PHASE 7.1 — ELEMENT PRIMITIVES (v7.0.0)
   Lightweight nestable elements inside container sections.
   ══════════════════════════════════════════════════════════════ */

.inf-el { box-sizing: border-box; }
.inf-el-heading { margin: 0; }
.inf-el-heading a { color: inherit; text-decoration: none; }
.inf-el-heading a:hover { opacity: 0.85; }
.inf-el-text { margin: 0; }
.inf-el-text p:last-child { margin-bottom: 0; }
.inf-el-image { display: block; max-width: 100%; height: auto; }

/* Button element — 4 variants. */
.inf-el-button {
	display: inline-flex; align-items: center; justify-content: center;
	padding: 12px 24px; border-radius: var(--inf-btn-radius, 8px);
	font-weight: 600; font-size: 15px; text-decoration: none;
	transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1); cursor: pointer;
	border: none; line-height: 1.4;
}
.inf-el-button--fill {
	background: var(--inf-accent, #A04398); color: #fff;
}
.inf-el-button--fill:hover { filter: brightness(1.1); transform: translateY(-1px); }
.inf-el-button--outline {
	background: transparent; color: var(--inf-accent, #A04398);
	border: 2px solid var(--inf-accent, #A04398);
}
.inf-el-button--outline:hover { background: rgba(160, 67, 152, 0.06); }
.inf-el-button--ghost {
	background: transparent; color: var(--inf-accent, #A04398);
}
.inf-el-button--ghost:hover { background: rgba(160, 67, 152, 0.06); }
.inf-el-button--link {
	background: transparent; color: var(--inf-accent, #A04398);
	padding: 0; text-decoration: underline;
}
.inf-el-button--link:hover { opacity: 0.8; }

.inf-el-icon { display: inline-flex; align-items: center; justify-content: center; line-height: 1; }
.inf-el-spacer { width: 100%; }
.inf-el-divider { margin: 0; }
.inf-el-video { width: 100%; overflow: hidden; border-radius: var(--inf-radius, 8px); }
.inf-el-video iframe { display: block; }
.inf-el-embed { width: 100%; }
.inf-el-container { width: 100%; }
.inf-container-children { width: 100%; }

/* v11.2.0 — Living hero background canvas. v11.3.0 — Generalised to all sections. */
.inf-hero__living-bg,
.inf-living-bg {
	position: absolute;
	inset: 0;
	z-index: 1;
	overflow: hidden;
	pointer-events: none;
}
.inf-hero__living-bg canvas,
.inf-living-bg canvas {
	width: 100%;
	height: 100%;
	display: block;
	pointer-events: auto;
}
/* Allow mouse tracking on the canvas for cursor-reactive modes. */
.inf-hero { position: relative; }
.inf-hero .inf-hero__content { position: relative; z-index: 2; }
/* v11.3.0 — Any section with a living bg needs position:relative and content above.
 * IMPORTANT: Only apply to standard (non-scroll) sections. Scroll-driven sections
 * (scroll_story, morph_hero, etc.) have their own absolute/sticky positioning
 * that must not be overridden. */
.inf-section--has-living-bg:not(.inf-scroll-story):not(.inf-scroll-story-h):not(.inf-split-scroll):not(.inf-text-reveal) { position: relative; }
.inf-section--has-living-bg:not(.inf-scroll-story):not(.inf-scroll-story-h):not(.inf-split-scroll):not(.inf-text-reveal) > *:not(.inf-living-bg) { position: relative; z-index: 2; }
/* v11.3.0 — Per-scene living backgrounds in scroll stories.
 * Scene divs already have position:absolute from infinite-scroll.css.
 * The living-bg canvas uses position:absolute;inset:0 from .inf-living-bg.
 * Layers already have their own z-index from infinite-scroll.css. */
.inf-scroll-story__scene > .inf-living-bg--scene { z-index: 0; }
.inf-scroll-story-h__scene > .inf-living-bg--scene { z-index: 0; }

/* ═══════════════════════════════════════════════════════════════
 * v11.6.0 — Magnetic Buttons
 * Buttons shift toward the cursor, spring back on leave.
 * JS adds transform via inline style; CSS handles the transition.
 * ═══════════════════════════════════════════════════════════════ */
[data-magnetic-btn="1"] .inf-btn {
	will-change: transform;
	transition: transform 0.45s cubic-bezier(0.23, 1, 0.32, 1);
}

/* ═══════════════════════════════════════════════════════════════
 * v11.6.0 — Texture Overlays
 * Pure CSS pseudo-element with SVG filter patterns.
 * Zero JS, zero performance cost, pointer-events: none.
 * ═══════════════════════════════════════════════════════════════ */
[data-texture] {
	position: relative;
}
[data-texture]::after {
	content: '';
	position: absolute;
	inset: 0;
	z-index: 3;
	pointer-events: none;
	mix-blend-mode: overlay;
	opacity: var(--inf-texture-opacity, 0.15);
}
/* Film grain — feTurbulence noise at small scale */
[data-texture="film_grain"]::after {
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='g'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23g)'/%3E%3C/svg%3E");
	background-size: 200px 200px;
}
/* Fine noise — higher frequency */
[data-texture="fine_noise"]::after {
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='1.2' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
	background-size: 200px 200px;
}
/* Coarse noise — lower frequency, larger grain */
[data-texture="coarse_noise"]::after {
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='c'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.3' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23c)'/%3E%3C/svg%3E");
	background-size: 200px 200px;
}
/* Scanlines — repeating 2px horizontal lines */
[data-texture="scanlines"]::after {
	background-image: repeating-linear-gradient(
		to bottom,
		transparent 0px,
		transparent 2px,
		rgba(0,0,0,0.3) 2px,
		rgba(0,0,0,0.3) 4px
	);
	background-size: 100% 4px;
}
/* Halftone — radial dot grid */
[data-texture="halftone"]::after {
	background-image: radial-gradient(circle, rgba(0,0,0,0.4) 1px, transparent 1px);
	background-size: 4px 4px;
}

/* ═══════════════════════════════════════════════════════════════
 * v11.6.0 — Horizontal Gallery
 * Sticky section with images scrolling horizontally driven by
 * vertical scroll progress. Track uses translateX via JS.
 * ═══════════════════════════════════════════════════════════════ */
.inf-scroll-zone--hgallery {
	position: relative;
}
.inf-hgallery {
	display: flex;
	align-items: center;
	overflow: hidden;
}
.inf-hgallery__track {
	display: flex;
	align-items: stretch;
	height: 100%;
	will-change: transform;
}
.inf-hgallery__item {
	flex: 0 0 auto;
	height: 100%;
	position: relative;
	display: flex;
	flex-direction: column;
}
.inf-hgallery__item img {
	height: 100%;
	width: auto;
	max-width: none;
	object-fit: cover;
	display: block;
}
.inf-hgallery__caption {
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	padding: 16px 20px;
	background: linear-gradient(transparent, rgba(0,0,0,0.65));
	color: #fff;
	font-size: 14px;
	line-height: 1.4;
	margin: 0;
}
/* Snap variant */
.inf-hgallery--snap .inf-hgallery__track {
	scroll-snap-type: x mandatory;
}
.inf-hgallery--snap .inf-hgallery__item {
	scroll-snap-align: start;
}
/* Ensure texture overlay sits above gallery images */
.inf-hgallery[data-texture]::after {
	z-index: 5;
}
