/* ============================================================
   Adobe Garamond Pro — @font-face declarations
   Loads as soon as the font files exist at:
     /wp-content/themes/orbit-child/assets/fonts/AdobeGaramondPro-Regular.{woff2,woff,otf}
   Until then, the fallback chain in --orbit-font-serif kicks in.
   ============================================================ */
@font-face {
	font-family: 'Adobe Garamond Pro';
	font-style: normal;
	font-weight: 400;
	font-display: swap;
	src:
		url('../fonts/AdobeGaramondPro-Regular.woff2') format('woff2'),
		url('../fonts/AdobeGaramondPro-Regular.woff')  format('woff'),
		url('../fonts/AdobeGaramondPro-Regular.otf')   format('opentype'),
		url('../fonts/AdobeGaramondPro-Regular.ttf')   format('truetype');
}
@font-face {
	font-family: 'Adobe Garamond Pro';
	font-style: italic;
	font-weight: 400;
	font-display: swap;
	src:
		url('../fonts/AdobeGaramondPro-Italic.woff2') format('woff2'),
		url('../fonts/AdobeGaramondPro-Italic.woff')  format('woff'),
		url('../fonts/AdobeGaramondPro-Italic.otf')   format('opentype');
}
@font-face {
	font-family: 'Adobe Garamond Pro';
	font-style: normal;
	font-weight: 600;
	font-display: swap;
	src:
		url('../fonts/AdobeGaramondPro-Semibold.woff2') format('woff2'),
		url('../fonts/AdobeGaramondPro-Semibold.woff')  format('woff'),
		url('../fonts/AdobeGaramondPro-Semibold.otf')   format('opentype');
}
@font-face {
	font-family: 'Adobe Garamond Pro';
	font-style: normal;
	font-weight: 700;
	font-display: swap;
	src:
		url('../fonts/AdobeGaramondPro-Bold.woff2') format('woff2'),
		url('../fonts/AdobeGaramondPro-Bold.woff')  format('woff'),
		url('../fonts/AdobeGaramondPro-Bold.otf')   format('opentype');
}

:root{
	--primaryColor:#0B0B0F;
	--accentColor:#0D65FE;
}

/* ============================================================
   Orbit — global typography & helpers
   These rules layer on top of Neve so Elementor sections inherit
   the right fonts and the design tokens by default.
   ============================================================ */

body,
.elementor-widget-text-editor,
.elementor-widget-heading,
button,
input,
select,
textarea {
	font-family: var(--orbit-font-sans);
	color: var(--orbit-text);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

/* Serif accent — apply this class to the "Trusted by leading beauty…" heading */
.orbit-serif,
.orbit-serif h1,
.orbit-serif h2,
.orbit-serif h3 {
	font-family: var(--orbit-font-serif);
	font-weight: 500;
	letter-spacing: -0.01em;
}

/* Section eyebrow labels (ATRIBUTION & PERFORMANCE, INSIGHTS DRIVE GROWTH, REAL TIME ANALYTICS) */
.orbit-eyebrow {
	font-family: var(--orbit-font-sans);
	font-size: 0.78rem;
	font-weight: 600;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--orbit-blue);
}

/* CTA buttons */
.orbit-btn-primary,
.elementor-button.orbit-btn-primary {
	background: var(--orbit-blue);
	color: var(--orbit-white);
	border-radius: var(--orbit-radius-pill);
	padding: 12px 26px;
	font-weight: 600;
	border: none;
	transition: background-color 0.18s ease, transform 0.18s ease;
}
.orbit-btn-primary:hover,
.elementor-button.orbit-btn-primary:hover {
	background: var(--orbit-blue-600);
}

.orbit-btn-ghost-light,
.elementor-button.orbit-btn-ghost-light {
	background: var(--orbit-white);
	color: var(--orbit-ink);
	border-radius: var(--orbit-radius-pill);
	padding: 12px 26px;
	font-weight: 600;
	border: none;
}

/* Checklist (✓ Take payments, Manage your team, etc.) — render in Elementor Icon List
   and add CSS class "orbit-checklist". */
.orbit-checklist .elementor-icon-list-icon svg,
.orbit-checklist .elementor-icon-list-icon i {
	color: var(--orbit-blue);
}
.orbit-checklist .elementor-icon-list-text {
	color: var(--orbit-text);
	font-weight: 500;
}

/* "Learn More about Orbit →" link */
.orbit-link-arrow a,
a.orbit-link-arrow {
	color: var(--orbit-blue);
	font-weight: 600;
	text-decoration: none;
}
.orbit-link-arrow a:hover,
a.orbit-link-arrow:hover {
	text-decoration: underline;
}

/* Dark sections (hero + Turn bookings into Insight) */
.orbit-section-dark {
	background: var(--orbit-dark-section);
	color: var(--orbit-white);
}
.orbit-section-dark h1,
.orbit-section-dark h2,
.orbit-section-dark h3,
.orbit-section-dark p {
	color: var(--orbit-white);
}
.orbit-section-dark .orbit-eyebrow {
	color: #93C5FD;
}

/* Image/card lift used for the chart and dashboard panels */
.orbit-card-lift img {
	border-radius: var(--orbit-radius-lg);
	box-shadow: var(--orbit-shadow-card-strong);
}

/* Trusted-by logo strip — legacy selector kept for back-compat. */
.orbit-logo-strip img {
	filter: grayscale(100%);
	opacity: 0.85;
	max-height: 36px;
	width: auto;
	transition: opacity 0.2s ease;
}
.orbit-logo-strip img:hover {
	opacity: 1;
}

/* ============================================================
   TRUSTED BY — consolidated section with fade hover on logos
   ============================================================ */
.orbit-trusted-section {
	background: #FFFFFF;
}
.orbit-trusted-section > .elementor-container {
	max-width: 1280px !important;
	margin: 0 auto;
}

.orbit-trusted-title .elementor-heading-title {
	font-family: var(--orbit-font-serif) !important;
	font-weight: 400 !important;
	font-size: 34px !important;  /* was 44px */
	line-height: 1.18;
	letter-spacing: -0.3px;
	color: #0B0B0F;
}

/* The flex row of 7 logos — always single line */
.orbit-trusted-strip {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 32px;
	flex-wrap: nowrap;          /* lock to one line */
	max-width: 1180px;
	margin: 0 auto;
	width: 100%;
}
.orbit-trusted-item {
	flex: 1 1 0;                /* each logo gets equal share of the row */
	min-width: 0;               /* allow shrinking below intrinsic size */
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 60px;
}
.orbit-trusted-item img {
	max-height: 44px;
	max-width: 100%;            /* never overflow its flex slot */
	width: auto;
	height: auto;
	display: block;
	object-fit: contain;
	filter: grayscale(100%);
	opacity: 1;
	transition: filter 0.35s ease, opacity 0.35s ease, transform 0.35s ease;
}
.orbit-trusted-item:hover img {
	filter: grayscale(0%);
	opacity: 1;
	transform: translateY(-2px);
}


/* ========= Header ======= */
.bars {
  display: flex;
  align-items: center;
}







/* Responsive — still single line, just smaller on narrower viewports */
@media (max-width: 1024px) {
	.orbit-trusted-title .elementor-heading-title {
		font-size: 44px;
	}
	.orbit-trusted-strip {
		gap: 20px;
	}
	.orbit-trusted-item img {
		max-height: 32px;
	}
}
@media (max-width: 767px) {
	.orbit-trusted-title .elementor-heading-title {
		font-size: 32px;
	}
	.orbit-trusted-strip {
		gap: 12px;
	}
	.orbit-trusted-item img {
		max-height: 22px;
	}
	
	 .orbit-trusted-strip {
		 gap: 0;
		 flex-wrap: wrap;
		 justify-content: center;
		 margin-top:25px
	}
	.orbit-trusted-item {
	  flex: 1 1 100%;
	  min-width: 0;
	  display: flex;
	  align-items: center;
	  justify-content: center;
	  min-height: 60px;
	  max-width: 33.33%;
	}
	 .orbit-trusted-item img {
		max-height: 35px;
	  }
}

/* Footer newsletter input + submit — legacy selectors kept for back-compat. */
.orbit-newsletter input[type="email"] {
	border: 0;
	border-bottom: 1px solid var(--orbit-border);
	background: transparent;
	padding: 10px 0;
	width: 100%;
	font-family: var(--orbit-font-sans);
}
.orbit-newsletter button[type="submit"] {
	background: var(--orbit-black);
	color: var(--orbit-white);
	border: 0;
	padding: 10px 22px;
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

/* ============================================================
   FOOTER — Theme Builder template (post 23) styles
   ============================================================ */
.orbit-footer-section {
	background: #000 !important;
	color: #fff;
}
.orbit-footer-section > .elementor-container {
	max-width: 1400px !important;
	margin: 0 auto;
	align-items: flex-start;
	gap: 0;
	flex-wrap: nowrap;
}

/* Force explicit column widths — Elementor doesn't ship CSS for non-standard
   column sizes like 13 or 48, so without this the columns size to content
   and the layout breaks on wide viewports. */
.orbit-footer-section .orbit-foot-col-1,
.orbit-footer-section .orbit-foot-col-2,
.orbit-footer-section .orbit-foot-col-3,
.orbit-footer-section .orbit-foot-col-4 {
	width: 14% !important;
	max-width: 14% !important;
	flex: 0 0 14% !important;
}
.orbit-footer-section .orbit-foot-col-5 {
	width: 44% !important;
	max-width: 44% !important;
	flex: 0 0 44% !important;
}

/* Inter-column gutter — tight between cols 1-4, generous before col 5 */
.orbit-foot-col > .elementor-widget-wrap {
	padding: 0 16px 0 0;
}
.orbit-foot-col-5 > .elementor-widget-wrap {
	padding: 0 0 0 70px;
}

.orbit-foot-block {
	color: #fff;
	font-family: var(--orbit-font-sans);
}

/* Column headings — Playfair serif */
.orbit-foot-h {
	font-family: var(--orbit-font-serif);
	font-weight: 400;
	font-size: 24px;
	color: #fff;
	margin: 0 0 26px;
	line-height: 1.2;
}
.orbit-foot-h-spacer {
	visibility: hidden;
}

/* Muted sub-headings */
.orbit-foot-sub {
	font-family: var(--orbit-font-sans);
	color: #6B7280;
	font-size: 14px;
	font-weight: 400;
	margin: 0 0 16px;
	letter-spacing: 0.01em;
}

/* Link lists — a touch more breathing room than before */
.orbit-foot-list {
	list-style: none;
	margin: 0;
	padding: 0;
}
.orbit-foot-list li {
	margin: 0 0 7px;
}
.orbit-foot-list li a {
	color: #fff;
	text-decoration: none;
	font-size: 15px;
	font-weight: 400;
	line-height: 1.5;
	transition: opacity 0.18s ease;
	display: inline-block;
}
.orbit-foot-list li a:hover {
	opacity: 0.9;
}

/* Newsletter block */
.orbit-foot-newsletter {
	color: #fff;
	font-family: var(--orbit-font-sans);
	max-width: 480px;
}
.orbit-foot-newsletter-lead {
	color: #fff;
	font-size: 15px;
	line-height: 1.55;
	margin: 0 0 18px;
	font-weight: 400;
}

/* Compact single-line form to match the reference:
   - white input bar, pure-black SUBMIT pinned right
   - thin light outline around the whole form
   - smaller overall height than v2 */
.orbit-newsletter-form {
	display: flex;
	align-items: stretch;
	background: #fff;
	overflow: hidden;
	width: 100%;
	max-width: 460px;
	margin-bottom: 32px;
	min-height: 46px;
	border: 1px solid rgba(255, 255, 255, 0.18);
}
.orbit-newsletter-form input[type="email"] {
	flex: 1 1 auto;
	min-width: 0;
	border: 0;
	outline: 0;
	background: #fff;
	color: #111827;
	padding: 12px 16px;
	font-family: var(--orbit-font-sans);
	font-size: 14px;
}
.orbit-newsletter-form button[type="submit"] {
	flex: 0 0 auto;
	background: #000000 !important;
	color: #fff;
	border: 0;
	padding: 0 26px;
	font-family: var(--orbit-font-sans);
	font-weight: 700;
	font-size: 12px;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	cursor: pointer;
	line-height: 1;
}
.orbit-newsletter-form button[type="submit"]:hover {
	background: #000000 !important;
	opacity: 0.85;
}

/* Social icon row */
.orbit-foot-social {
	display: flex;
	align-items: center;
	gap: 24px;
}
.orbit-foot-social a {
	color: #fff;
	font-size: 22px;
	width: 30px;
	height: 30px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	text-decoration: none;
	transition: opacity 0.2s ease, transform 0.2s ease;
}
.orbit-foot-social a:hover {
	opacity: 0.75;
	transform: translateY(-2px);
}
.orbit-foot-social i {
	color: #fff;
}

/* ============================================================
   FOOTER — responsive
   Tablet: 2-up grid, newsletter spans both cols on its row
   Mobile: stacked, one column per row
   ============================================================ */
@media (max-width: 1200px) {
	.orbit-footer-section > .elementor-container {
		flex-wrap: wrap !important;
		gap: 0;
	}
	/* Use the SAME specific selectors as the desktop rules so they win */
	.orbit-footer-section .orbit-foot-col-1,
	.orbit-footer-section .orbit-foot-col-2,
	.orbit-footer-section .orbit-foot-col-3,
	.orbit-footer-section .orbit-foot-col-4 {
		width: 50% !important;
		max-width: 50% !important;
		flex: 0 0 50% !important;
		margin-bottom: 36px !important;
	}
	.orbit-footer-section .orbit-foot-col-5 {
		width: 100% !important;
		max-width: 100% !important;
		flex: 0 0 100% !important;
	}
	/* Drop the big left-padding gap before the newsletter on smaller viewports */
	.orbit-footer-section .orbit-foot-col > .elementor-widget-wrap,
	.orbit-footer-section .orbit-foot-col-5 > .elementor-widget-wrap {
		padding: 0 16px 0 0 !important;
	}
}

@media (max-width: 700px) {
	.orbit-footer-section .orbit-foot-col-1,
	.orbit-footer-section .orbit-foot-col-2,
	.orbit-footer-section .orbit-foot-col-3,
	.orbit-footer-section .orbit-foot-col-4,
	.orbit-footer-section .orbit-foot-col-5 {
		width: 100% !important;
		max-width: 100% !important;
		flex: 0 0 100% !important;
		margin-bottom: 28px !important;
	}
	.orbit-footer-section > .elementor-container {
		padding-left: 6px !important;
		padding-right: 6px !important;
	}
	.orbit-footer-section {
		padding-left: 24px !important;
		padding-right: 24px !important;
	}
	/* Hide the visibility-hidden spacer headings — they take vertical space
	   for desktop alignment, but become wasted space when columns stack. */
	.orbit-foot-h-spacer {
		display: none !important;
	}
	.orbit-newsletter-form {
		max-width: 100% !important;
	}
}

/* ============================================================
   PRICING PAGE
   ============================================================ */
.orbit-pricing-section-hero,
.orbit-pricing-section-controls,
.orbit-pricing-section-cards {
	background: #F8FAFC !important;
}

/* Hero */
.orbit-pricing-hero {
	text-align: center;
	max-width: 880px;
	margin: 0 auto;
}
.orbit-pricing-title {
	font-family: var(--orbit-font-serif);
	font-weight: 400;
	font-size: 54px;
	line-height: 1.15;
	letter-spacing: -0.4px;
	color: #0B0B0F;
	margin: 0 0 18px;
}
.orbit-pricing-sub {
	font-family: var(--orbit-font-sans);
	font-size: 17px;
	line-height: 1.55;
	color: #4B5563;
	margin: 0;
}

/* Slider + Monthly/Yearly controls row */
.orbit-pricing-controls {
	display: grid;
	grid-template-columns: 1fr 1.6fr auto;
	gap: 40px;
	align-items: center;
	max-width: 1180px;
	margin: 40px auto 0;
}
.orbit-pricing-pv-label {
	font-family: var(--orbit-font-sans);
	font-size: 15px;
	color: #1F2937;
}
.orbit-pricing-pv-label strong {
	font-weight: 700;
}

/* Slider visual: bubble above + track with min/max labels */
.orbit-pricing-slider-rail {
	position: relative;
	padding-top: 30px;
}
.orbit-pricing-slider-bubble {
	position: absolute;
	top: 0;
	left: 4%;
	transform: translateX(-50%);
	background: #2563EB;
	color: #fff;
	font-family: var(--orbit-font-sans);
	font-weight: 600;
	font-size: 12px;
	padding: 4px 10px;
	border-radius: 8px;
}
.orbit-pricing-slider-bubble::after {
	content: '';
	position: absolute;
	left: 50%;
	bottom: -4px;
	transform: translateX(-50%) rotate(45deg);
	width: 8px;
	height: 8px;
	background: #2563EB;
}
.orbit-pricing-slider-track {
	display: flex;
	align-items: center;
	gap: 12px;
}
.orbit-pricing-slider-track input[type="range"] {
	flex: 1;
	-webkit-appearance: none;
	appearance: none;
	height: 4px;
	background: #E5E7EB;
	border-radius: 999px;
	outline: 0;
}
.orbit-pricing-slider-track input[type="range"]::-webkit-slider-thumb {
	-webkit-appearance: none;
	appearance: none;
	width: 26px;
	height: 26px;
	border-radius: 999px;
	background: #fff;
	border: 1px solid #E5E7EB;
	box-shadow: 0 1px 4px rgba(0,0,0,0.08);
	cursor: pointer;
	background-image:
		linear-gradient(to right, #2563EB 1px, transparent 1px),
		linear-gradient(to right, #2563EB 1px, transparent 1px);
	background-size: 2px 8px, 2px 8px;
	background-position: 9px center, 15px center;
	background-repeat: no-repeat;
}
.orbit-pricing-slider-track input[type="range"]::-moz-range-thumb {
	width: 26px;
	height: 26px;
	border-radius: 999px;
	background: #fff;
	border: 1px solid #E5E7EB;
	box-shadow: 0 1px 4px rgba(0,0,0,0.08);
	cursor: pointer;
}
.orbit-pricing-slider-min,
.orbit-pricing-slider-max {
	font-family: var(--orbit-font-sans);
	font-size: 12px;
	color: #6B7280;
}

/* Billing toggle (Monthly / Yearly) */
.orbit-pricing-billing {
	position: relative;
	display: flex;
	align-items: center;
}
.orbit-billing-badge {
	position: absolute;
	top: -22px;
	right: 6px;
	background: #FEF3C7;
	color: #92400E;
	font-family: var(--orbit-font-sans);
	font-size: 11px;
	font-weight: 600;
	padding: 3px 10px;
	border-radius: 999px;
	white-space: nowrap;
}
.orbit-billing-toggle {
	display: inline-flex;
	background: #fff;
	border-radius: 999px;
	padding: 4px;
	border: 1px solid #E5E7EB;
}
.orbit-billing-toggle button {
	border: 0;
	background: transparent;
	font-family: var(--orbit-font-sans);
	font-size: 14px;
	font-weight: 600;
	padding: 8px 18px;
	border-radius: 999px;
	color: #1F2937;
	cursor: pointer;
	transition: all 0.18s ease;
}
.orbit-billing-toggle button.is-active {
	background: #2563EB;
	color: #fff;
}

/* Pricing grid */
.orbit-pricing-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 22px;
	max-width: 1280px;
	margin: 50px auto 0;
}

/* Card */
.orbit-card {
	background: #fff;
	border-radius: 16px;
	padding: 32px 28px;
	display: flex;
	flex-direction: column;
	border: 1px solid #E5E7EB;
	box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
}
.orbit-card-dark {
	background: #0B0B0F;
	color: #fff;
	border-color: #0B0B0F;
}
.orbit-card-head {
	margin-bottom: 22px;
}
.orbit-card-name {
	font-family: var(--orbit-font-sans);
	font-weight: 700;
	font-size: 18px;
	color: #0B0B0F;
	margin: 0 0 16px;
}
.orbit-card-dark .orbit-card-name {
	color: #fff;
}
.orbit-card-price {
	display: flex;
	align-items: baseline;
	gap: 6px;
}
.orbit-card-price-num {
	font-family: var(--orbit-font-sans);
	font-weight: 700;
	font-size: 40px;
	color: #0B0B0F;
	line-height: 1;
}
.orbit-card-custom {
	font-family: var(--orbit-font-sans);
	font-weight: 700;
	font-size: 32px;
	color: #fff;
	line-height: 1;
}
.orbit-card-price-cycle {
	font-family: var(--orbit-font-sans);
	font-size: 14px;
	color: #6B7280;
}
.orbit-card-dark .orbit-card-price-cycle {
	color: #9CA3AF;
}

/* CTA */
.orbit-card-cta {
	display: block;
	text-align: center;
	background: #2563EB;
	color: #fff !important;
	text-decoration: none;
	font-family: var(--orbit-font-sans);
	font-weight: 600;
	font-size: 14px;
	padding: 12px 16px;
	border-radius: 8px;
	transition: background 0.18s ease;
	margin-bottom: 24px;
}
.orbit-card-cta:hover {
	background: #1D4FD8;
}
.orbit-card-cta-dark {
	background: #1F2937;
	color: #fff !important;
}
.orbit-card-cta-dark:hover {
	background: #2D3748;
}

/* Feature list */
.orbit-card-features {
	list-style: none;
	margin: 0;
	padding: 0;
	flex: 1;
}
.orbit-card-features li {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	font-family: var(--orbit-font-sans);
	font-size: 14px;
	line-height: 1.5;
	color: #1F2937;
	margin: 0 0 12px;
}
.orbit-card-dark .orbit-card-features li {
	color: #E5E7EB;
}
.orbit-card-check {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 18px;
	height: 18px;
	flex: 0 0 18px;
	border-radius: 999px;
	color: #2563EB;
	font-weight: 700;
	font-size: 13px;
	line-height: 1;
	margin-top: 1px;
}
.orbit-card-dark .orbit-card-check {
	color: #60A5FA;
}

/* Responsive */
@media (max-width: 1024px) {
	.orbit-pricing-title {
		font-size: 38px;
	}
	.orbit-pricing-controls {
		grid-template-columns: 1fr;
		gap: 24px;
	}
	.orbit-pricing-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}
@media (max-width: 600px) {
	.orbit-pricing-grid {
		grid-template-columns: 1fr;
	}
	.orbit-pricing-title {
		font-size: 28px;
	}
}

/* ============================================================
   GLOBAL RESPONSIVE POLISH — section padding for tablet & mobile
   ============================================================ */
@media (max-width: 1023px) {
	/* Hero */
	.orbit-hero {
		padding-top: 110px !important;
		padding-bottom: 110px !important;
	}
	/* Feature sections (attribution / insights) */
	.orbit-feature-section {
		padding-top: 70px !important;
		padding-bottom: 70px !important;
	}
	.orbit-feature-section > .elementor-container {
		flex-direction: column;
	}
	.orbit-feature-section > .elementor-container > .elementor-column {
		width: 100% !important;
	}
	.orbit-attr-chart,
	.orbit-ins-chart {
		max-width: 520px;
	}
	/* Analytics split → stack */
	.orbit-analytics-section > .elementor-container {
		flex-direction: column;
		min-height: 0;
	}
	.orbit-analytics-section .orbit-analytics-photo,
	.orbit-analytics-section .orbit-analytics-photo > .elementor-widget-wrap {
		min-height: 360px;
	}
	.orbit-analytics-section .orbit-analytics-text {
		padding: 70px 32px !important;
	}
	/* Trusted-by */
	.orbit-trusted-section {
		padding-top: 70px !important;
		padding-bottom: 70px !important;
	}
	/* Final CTA */
	.orbit-cta-section {
		padding-top: 110px !important;
		padding-bottom: 110px !important;
	}
}

@media (max-width: 600px) {
	/* Hero CTA buttons stack on small phones */
	.orbit-hero-cta {
		flex-direction: column;
		align-items: center;
	}
	.orbit-hero-cta a {
		width: 100%;
		max-width: 280px;
		text-align: center;
	}
	/* Feature sections tighten */
	.orbit-feature-section {
		padding-top: 50px !important;
		padding-bottom: 50px !important;
		padding-left: 20px !important;
		padding-right: 20px !important;
	}
	.orbit-attr-chart > .elementor-widget-container,
	.orbit-ins-chart > .elementor-widget-container {
		padding: 20px !important;
		border-radius: 18px !important;
	}
	/* Analytics text panel */
	.orbit-analytics-section .orbit-analytics-text {
		padding: 56px 22px !important;
	}
	/* Trusted-by */
	.orbit-trusted-section {
		padding-top: 50px !important;
		padding-bottom: 50px !important;
		padding-left: 20px !important;
		padding-right: 20px !important;
	}
	/* Final CTA */
	.orbit-cta-section {
		padding-top: 90px !important;
		padding-bottom: 90px !important;
		min-height: auto !important;
	}
}

/* ============================================================
   GLOBAL NORMALIZER — unified type scale + consistent gutters
   This block runs LAST in the stylesheet, so it wins over any
   per-section size declared earlier. Tweak here to retune the
   whole site at once.
   ============================================================ */

/* Hero (page-top) — Adobe Garamond Pro, big serif */
.orbit-hero .orbit-hero-title .elementor-heading-title,
.orbit-pricing-title {
	font-family: var(--orbit-font-serif) !important;
	font-weight: 400 !important;
	font-size: var(--fs-hero) !important;
	line-height: var(--lh-tight) !important;
	letter-spacing: -0.3px;
}

/* All H2 section titles — one size everywhere */
.orbit-attr-section .orbit-attr-heading .elementor-heading-title,
.orbit-feature-section .orbit-ins-heading .elementor-heading-title,
.orbit-analytics-section .orbit-an-heading .elementor-heading-title,
.orbit-trusted-title .elementor-heading-title,
.orbit-cta-section .orbit-cta-heading .elementor-heading-title {
	font-size: var(--fs-section) !important;
	line-height: var(--lh-tight) !important;
	letter-spacing: -0.3px;
}

/* Eyebrows — uniform across all sections */
.orbit-feature-section .orbit-eyebrow .elementor-heading-title,
.orbit-analytics-section .orbit-an-eyebrow .elementor-heading-title {
	font-size: var(--fs-small) !important;
	font-weight: 600 !important;
	letter-spacing: 2px;
	text-transform: uppercase;
}

/* Body paragraphs everywhere — same size + line-height */
.orbit-hero .orbit-hero-sub p,
.orbit-feature-section .orbit-attr-body p,
.orbit-feature-section .orbit-ins-body p,
.orbit-analytics-section .orbit-an-body p,
.orbit-cta-section .orbit-cta-sub p,
.orbit-pricing-sub {
	font-size: var(--fs-body) !important;
	line-height: var(--lh-body) !important;
}

/* Checklist items — same as body */
.orbit-feature-section .orbit-checklist .elementor-icon-list-text,
.orbit-feature-section .orbit-checklist .elementor-icon-list-text * {
	font-size: var(--fs-body) !important;
	line-height: 1.5 !important;
}

/* ----- Consistent horizontal padding on every content section ----- */
.orbit-hero,
.orbit-feature-section,
.orbit-trusted-section,
.orbit-cta-section,
.orbit-pricing-section-hero,
.orbit-pricing-section-controls,
.orbit-pricing-section-cards {
	padding-left: var(--pad-x-desktop) !important;
	padding-right: var(--pad-x-desktop) !important;
}

/* Tablet — type scales down, gutters narrow */
@media (max-width: 1024px) {
	.orbit-hero .orbit-hero-title .elementor-heading-title,
	.orbit-pricing-title {
		font-size: 42px !important;
	}
	.orbit-attr-section .orbit-attr-heading .elementor-heading-title,
	.orbit-feature-section .orbit-ins-heading .elementor-heading-title,
	.orbit-analytics-section .orbit-an-heading .elementor-heading-title,
	.orbit-trusted-title .elementor-heading-title,
	.orbit-cta-section .orbit-cta-heading .elementor-heading-title {
		font-size: 32px !important;
	}
	.orbit-hero,
	.orbit-feature-section,
	.orbit-trusted-section,
	.orbit-cta-section,
	.orbit-pricing-section-hero,
	.orbit-pricing-section-controls,
	.orbit-pricing-section-cards {
		padding-left: var(--pad-x-tablet) !important;
		padding-right: var(--pad-x-tablet) !important;
	}
	/* Analytics right-panel gutter aligns with the site gutter */
	.orbit-analytics-section .orbit-analytics-text {
		padding-left: var(--pad-x-tablet) !important;
		padding-right: var(--pad-x-tablet) !important;
	}
}

/* Mobile — tighter still */
@media (max-width: 600px) {
	.orbit-hero .orbit-hero-title .elementor-heading-title,
	.orbit-pricing-title {
		font-size: 32px !important;
		letter-spacing: -0.2px;
	}
	.orbit-attr-section .orbit-attr-heading .elementor-heading-title,
	.orbit-feature-section .orbit-ins-heading .elementor-heading-title,
	.orbit-analytics-section .orbit-an-heading .elementor-heading-title,
	.orbit-trusted-title .elementor-heading-title,
	.orbit-cta-section .orbit-cta-heading .elementor-heading-title {
		font-size: 26px !important;
	}
	.orbit-hero .orbit-hero-sub p,
	.orbit-feature-section .orbit-attr-body p,
	.orbit-feature-section .orbit-ins-body p,
	.orbit-analytics-section .orbit-an-body p,
	.orbit-cta-section .orbit-cta-sub p,
	.orbit-pricing-sub {
		font-size: 15px !important;
	}
	.orbit-feature-section .orbit-checklist .elementor-icon-list-text,
	.orbit-feature-section .orbit-checklist .elementor-icon-list-text * {
		font-size: 15px !important;
	}

	.orbit-hero,
	.orbit-feature-section,
	.orbit-trusted-section,
	.orbit-cta-section,
	.orbit-pricing-section-hero,
	.orbit-pricing-section-controls,
	.orbit-pricing-section-cards {
		padding-left: var(--pad-x-mobile) !important;
		padding-right: var(--pad-x-mobile) !important;
	}
	.orbit-analytics-section .orbit-analytics-text {
		padding-left: var(--pad-x-mobile) !important;
		padding-right: var(--pad-x-mobile) !important;
	}

	/* Footer matches the site gutter on mobile */
	.orbit-footer-section {
		padding-left: var(--pad-x-mobile) !important;
		padding-right: var(--pad-x-mobile) !important;
	}
	.orbit-header,
	.orbit-header > .elementor-container {
		padding-left: var(--pad-x-mobile) !important;
		padding-right: var(--pad-x-mobile) !important;
	}
}

/* ============================================================
   ELEMENT NORMALIZER — equal vertical rhythm + container widths
   + identical internal spacing for every content section.
   Header/footer are kept on their own scale.
   ============================================================ */

/* ----- 1. Identical vertical padding on every section ----- */
.orbit-hero,
.orbit-feature-section,
.orbit-analytics-section,
.orbit-trusted-section,
.orbit-cta-section,
.orbit-pricing-section-hero,
.orbit-pricing-section-controls,
.orbit-pricing-section-cards {
	padding-top: var(--pad-y-desktop) !important;
	padding-bottom: var(--pad-y-desktop) !important;
}
/* Hero and final-CTA get a touch more breathing room (they're tall photo sections) */
.orbit-hero,
.orbit-cta-section {
	padding-top: calc(var(--pad-y-desktop) + 30px) !important;
	padding-bottom: calc(var(--pad-y-desktop) + 30px) !important;
}

@media (max-width: 1024px) {
	.orbit-hero,
	.orbit-feature-section,
	.orbit-analytics-section,
	.orbit-trusted-section,
	.orbit-cta-section,
	.orbit-pricing-section-hero,
	.orbit-pricing-section-controls,
	.orbit-pricing-section-cards {
		padding-top: var(--pad-y-tablet) !important;
		padding-bottom: var(--pad-y-tablet) !important;
	}
	.orbit-hero,
	.orbit-cta-section {
		padding-top: calc(var(--pad-y-tablet) + 20px) !important;
		padding-bottom: calc(var(--pad-y-tablet) + 20px) !important;
	}
}
@media (max-width: 600px) {
	.orbit-hero,
	.orbit-feature-section,
	.orbit-analytics-section,
	.orbit-trusted-section,
	.orbit-cta-section,
	.orbit-pricing-section-hero,
	.orbit-pricing-section-controls,
	.orbit-pricing-section-cards {
		padding-top: var(--pad-y-mobile) !important;
		padding-bottom: var(--pad-y-mobile) !important;
	}
	.orbit-hero,
	.orbit-cta-section {
		padding-top: calc(var(--pad-y-mobile) + 16px) !important;
		padding-bottom: calc(var(--pad-y-mobile) + 16px) !important;
	}
}

/* ----- 2. Single content max-width — every section shares it ----- */
.orbit-hero > .elementor-container,
.orbit-feature-section > .elementor-container,
.orbit-trusted-section > .elementor-container,
.orbit-cta-section > .elementor-container,
.orbit-pricing-section-hero > .elementor-container,
.orbit-pricing-section-controls > .elementor-container,
.orbit-pricing-section-cards > .elementor-container {
	max-width: 1280px !important;
	margin-left: auto !important;
	margin-right: auto !important;
}
/* Analytics is a full-bleed split section (no max-width on container) */

/* ----- 3. Consistent internal vertical spacing ----- */
/* Eyebrow → title gap */
.orbit-feature-section .orbit-eyebrow,
.orbit-analytics-section .orbit-an-eyebrow {
	margin-bottom: 12px !important;
}
/* Title → body gap */
.orbit-attr-section .orbit-attr-heading,
.orbit-feature-section .orbit-ins-heading,
.orbit-analytics-section .orbit-an-heading,
.orbit-cta-section .orbit-cta-heading,
.orbit-hero .orbit-hero-title {
	margin-bottom: 18px !important;
}
.orbit-trusted-title {
	margin-bottom: 0 !important;   /* trusted has its own spacer */
}
/* Body → next element gap */
.orbit-feature-section .orbit-attr-body,
.orbit-feature-section .orbit-ins-body,
.orbit-analytics-section .orbit-an-body,
.orbit-hero .orbit-hero-sub,
.orbit-cta-section .orbit-cta-sub {
	margin-bottom: 22px !important;
}
/* Checklist → link gap */
.orbit-feature-section .orbit-checklist {
	margin-bottom: 20px !important;
}

/* ----- 4. Equal chart card sizes ----- */
.orbit-attr-chart,
.orbit-ins-chart {
	max-width: 560px !important;
}
.orbit-attr-chart > .elementor-widget-container,
.orbit-ins-chart > .elementor-widget-container {
	padding: 28px !important;
	border-radius: 22px !important;
}

/* ----- 5. Equal pricing card heights via grid stretch ----- */
.orbit-pricing-grid {
	align-items: stretch;
}
.orbit-card {
	height: 100%;
}

/* Container width override to match the mockup */
.orbit-container .elementor-container {
	max-width: var(--orbit-container);
}

/* ============================================================
   HEADER — black bar (pre-today simple version restored)
   ============================================================ */
.orbit-header {
	background: #000 !important;
}
.orbit-header .elementor-container {
	max-width: 1600px !important;
	margin: 0 auto;
}

/* Force the logo to render white on the black header even if the
   uploaded PNG is dark or has dark glyphs. */
.orbit-logo-light img {
	filter: brightness(0) invert(1);
	max-height: 48px;
	width: auto;
}

/* Nav link hover */
.orbit-nav-dark a {
	transition: opacity 0.15s ease;
}
.orbit-nav-dark a:hover {
	opacity: 0.75;
}

/* Start Free button hover */
.orbit-header a[href="#"][style*="#2563EB"]:hover {
	background: #1D4FD8 !important;
}

/* ----- Header right column: two Elementor Button widgets sit side-by-side ----- */
.orbit-header .orbit-actions-col > .elementor-widget-wrap {
	display: flex !important;
	flex-direction: row !important;
	align-items: center;
	justify-content: flex-end;
	gap: 24px;
	flex-wrap: nowrap;
}
.orbit-header .orbit-actions-col .elementor-widget {
	width: auto !important;
	max-width: none;
	margin: 0 !important;
}
.orbit-header .orbit-actions-col .elementor-button-wrapper {
	width: auto;
}

/* Sign In — text-style (no background) */
.orbit-header .orbit-btn-signin .elementor-button {
	background: transparent !important;
	background-color: transparent !important;
	color: #fff !important;
	border: 0;
	box-shadow: none !important;
}
.orbit-header .orbit-btn-signin .elementor-button:hover {
	background: transparent !important;
	opacity: 0.8;
}

/* Start Free — pill */
.orbit-header .orbit-btn-startfree .elementor-button {
	color: #fff !important;
	background: #2563EB !important;
	background-color: #2563EB !important;
	border: 0;
	line-height: 1;
}
.orbit-header .orbit-btn-startfree .elementor-button:hover {
	background: #1D4FD8 !important;
	background-color: #1D4FD8 !important;
}

/* ----- Elementor Pro Nav Menu widget (the WordPress menu) ----- */
.orbit-header .orbit-wp-nav .elementor-nav-menu {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 28px;
	margin: 0;
	padding: 0;
	list-style: none;
}
.orbit-header .orbit-wp-nav .elementor-nav-menu li {
	margin: 0;
}
.orbit-header .orbit-wp-nav .elementor-nav-menu a,
.orbit-header .orbit-wp-nav .elementor-item {
	color: #fff !important;
	font-family: var(--orbit-font-sans);
	font-weight: 500;
	font-size: 17px;
	text-decoration: none !important;
	padding: 6px 4px !important;
	border: 0 !important;
	background: transparent !important;
	transition: opacity 0.15s ease;
}
.orbit-header .orbit-wp-nav .elementor-nav-menu a:hover,
.orbit-header .orbit-wp-nav .elementor-item:hover,
.orbit-header .orbit-wp-nav .elementor-item.elementor-item-active {
	color: #fff !important;
	opacity: 0.75;
	background: transparent !important;
}

/* ============================================================
   HERO — Playfair serif headline matching the user's reference
   ============================================================ */
.orbit-hero {
	overflow: hidden;
}
.orbit-hero .orbit-hero-title,
.orbit-hero .orbit-hero-title .elementor-heading-title {
	font-family: var(--orbit-font-serif) !important;
	font-weight: 400 !important;
	color: #fff;
	letter-spacing: -0.3px;
	line-height: 1.12;
	font-size: clamp(28px, 4vw, 48px) !important;  /* was 58px ceiling */
	margin: 0;
}
.orbit-hero .orbit-hero-sub,
.orbit-hero .orbit-hero-sub p {
	font-family: var(--orbit-font-sans);
	color: #E5E7EB;
	font-size: 18px;
	line-height: 1.6;
	margin-top: 14px;
	margin-bottom: 12px;
}

/* Hero CTA buttons hover */
.orbit-hero-cta a[style*="#FFFFFF"]:hover,
.orbit-hero-cta a[style*="#fff"]:hover {
	background: #F3F4F6 !important;
}
.orbit-hero-cta a[style*="#2563EB"]:hover {
	background: #1D4FD8 !important;
}

/* ============================================================
   FEATURE SECTIONS — shared specs for Attribution + Insights
   (both use the .orbit-feature-section class plus their own
    modifier class so per-side image/text styles can differ)
   ============================================================ */
.orbit-feature-section > .elementor-container {
	max-width: 1280px !important;
	margin: 0 auto;
	gap: 80px;
	align-items: stretch;
}
.orbit-feature-section > .elementor-container > .elementor-column {
	display: flex;
	flex-direction: column;
	justify-content: center;
}
.orbit-feature-section .orbit-eyebrow .elementor-heading-title {
	font-family: var(--orbit-font-sans);
	font-weight: 600;
	font-size: 14px;
	letter-spacing: 2px;
	color: #2563EB;
	text-transform: uppercase;
	margin: 0 0 8px;
}
.orbit-feature-section .orbit-attr-heading .elementor-heading-title,
.orbit-feature-section .orbit-ins-heading .elementor-heading-title {
	font-family: var(--orbit-font-sans);
	font-weight: 700;
	font-size: 36px;
	line-height: 1.18;
	letter-spacing: -0.4px;
	color: #0B0B0F;
	margin: 0 0 12px;
}
.orbit-feature-section .orbit-attr-body p,
.orbit-feature-section .orbit-ins-body p {
	font-family: var(--orbit-font-sans);
	font-size: 16px;
	line-height: 1.55;
	color: #4B5563;
	margin: 0 0 18px;
}
.orbit-feature-section .orbit-checklist .elementor-icon-list-text,
.orbit-feature-section .orbit-checklist .elementor-icon-list-text * {
	color: #2563EB !important;
	font-family: var(--orbit-font-sans);
	font-weight: 500;
	font-size: 16px;
}
.orbit-feature-section .orbit-checklist .elementor-icon-list-icon i,
.orbit-feature-section .orbit-checklist .elementor-icon-list-icon svg {
	color: #2563EB !important;
	fill: #2563EB !important;
	font-size: 16px;
}
.orbit-feature-section .orbit-checklist .elementor-icon-list-item:not(:last-child) {
	margin-bottom: 8px !important;
}
.orbit-feature-section .orbit-checklist {
	margin-bottom: 18px !important;
}

/* Both image cards (left in Attribution, right in Insights) */
.orbit-attr-chart,
.orbit-ins-chart {
	max-width: 600px;
	margin: 0 auto;
}
.orbit-attr-chart > .elementor-widget-container,
.orbit-ins-chart > .elementor-widget-container {
	padding: 32px !important;
	border-radius: 24px !important;
	background: #F3F4F6;
}
.orbit-attr-chart img,
.orbit-ins-chart img {
	width: 100%;
	height: auto;
	display: block;
}

/* Responsive */
@media (max-width: 1024px) {
	.orbit-feature-section .orbit-attr-heading .elementor-heading-title,
	.orbit-feature-section .orbit-ins-heading .elementor-heading-title {
		font-size: 30px;
	}
	.orbit-feature-section > .elementor-container {
		gap: 40px;
	}
}
@media (max-width: 767px) {
	.orbit-feature-section .orbit-attr-heading .elementor-heading-title,
	.orbit-feature-section .orbit-ins-heading .elementor-heading-title {
		font-size: 26px;
	}
}

/* ============================================================
   REAL TIME ANALYTICS — split layout (photo | black panel)
   ============================================================ */
.orbit-analytics-section {
	overflow: hidden;
	background: #000 !important;
}
/* Force pure black on the section, both columns, and the photo-column
   fallback so there's no tonal shift between left and right halves. */
.orbit-analytics-section,
.orbit-analytics-section .orbit-analytics-photo,
.orbit-analytics-section .orbit-analytics-text {
	background-color: #000 !important;
}
.orbit-analytics-section > .elementor-container {
	max-width: 100% !important;
	width: 100%;
	margin: 0 !important;
	padding: 0 !important;
	gap: 0 !important;
	align-items: stretch;
	min-height: 640px;
}
.orbit-analytics-section > .elementor-container > .elementor-column {
	padding: 0 !important;
}

/* Left photo column: enforce a minimum height so the photo always covers */
.orbit-analytics-section .orbit-analytics-photo {
	min-height: 640px;
}
.orbit-analytics-section .orbit-analytics-photo > .elementor-widget-wrap {
	min-height: 640px;
}

/* Right text column: keep content vertically centered, give it room to breathe */
.orbit-analytics-section .orbit-analytics-text > .elementor-widget-wrap {
	display: flex;
	flex-direction: column;
	justify-content: center;
	max-width: 560px;
}

/* Eyebrow / heading / body / button rhythm on the right side */
.orbit-analytics-section .orbit-an-eyebrow {
	margin-bottom: 22px !important;
}
.orbit-analytics-section .orbit-an-eyebrow .elementor-heading-title {
	color: #2563EB;
	font-family: var(--orbit-font-sans);
	font-weight: 600;
	font-size: 14px;
	letter-spacing: 2px;
	text-transform: uppercase;
}
.orbit-analytics-section .orbit-an-heading {
	margin-bottom: 32px !important;
}
.orbit-analytics-section .orbit-an-heading .elementor-heading-title {
	font-family: var(--orbit-font-serif) !important;
	font-weight: 400 !important;
	color: #fff;
	font-size: 40px !important;  /* was 50px */
	line-height: 1.12;
	letter-spacing: -0.3px;
}
.orbit-analytics-section .orbit-an-body {
	margin-bottom: 38px !important;
}
.orbit-analytics-section .orbit-an-body p {
	font-family: var(--orbit-font-sans);
	color: #D1D5DB;
	font-size: 16px;
	line-height: 1.65;
	margin: 0;
}

/* CTA hover */
.orbit-analytics-section a.orbit-an-cta:hover {
	background: #1D4FD8 !important;
}

/* ============================================================
   FINAL CTA — "One powerful platform. Unlimited possibilities."
   ============================================================ */
.orbit-cta-section {
	background-attachment: scroll;
}
.orbit-cta-section > .elementor-container {
	max-width: 1280px !important;
	margin: 0 auto;
}
.orbit-cta-section .orbit-cta-heading {
	margin-bottom: 14px !important;
}
.orbit-cta-section .orbit-cta-heading .elementor-heading-title {
	font-family: var(--orbit-font-serif) !important;  /* now matches the brand serif */
	font-weight: 400 !important;
	color: #FFFFFF;
	font-size: 44px !important;  /* was 54px */
	line-height: 1.18;
	letter-spacing: -0.3px;
	margin: 0;
}
.orbit-cta-section .orbit-cta-sub {
	margin-bottom: 28px !important;
}
.orbit-cta-section .orbit-cta-sub p {
	font-family: var(--orbit-font-sans);
	color: #E5E7EB;
	font-size: 17px;
	line-height: 1.5;
	margin: 0;
}
.orbit-cta-section a.orbit-cta-btn:hover {
	background: #1D4FD8 !important;
}

/* Responsive */
@media (max-width: 1024px) {
	.orbit-cta-section .orbit-cta-heading .elementor-heading-title {
		font-size: 48px;
	}
	.orbit-cta-section {
		padding-top: 120px !important;
		padding-bottom: 120px !important;
	}
}
@media (max-width: 767px) {
	.orbit-cta-section .orbit-cta-heading .elementor-heading-title {
		font-size: 34px;
	}
	.orbit-cta-section .orbit-cta-sub p {
		font-size: 15px;
	}
}

/* Responsive */
@media (max-width: 1024px) {
	.orbit-analytics-section .orbit-an-heading .elementor-heading-title {
		font-size: 44px;
	}
	.orbit-analytics-section .orbit-analytics-text {
		padding: 80px 48px !important;
	}
}
@media (max-width: 767px) {
	.orbit-analytics-section > .elementor-container {
		flex-direction: column;
		min-height: 0;
	}
	.orbit-analytics-section .orbit-analytics-photo,
	.orbit-analytics-section .orbit-analytics-photo > .elementor-widget-wrap {
		min-height: 320px;
	}
	.orbit-analytics-section .orbit-an-heading .elementor-heading-title {
		font-size: 36px;
	}
	.orbit-analytics-section .orbit-analytics-text {
		padding: 60px 30px !important;
	}
}

/* ============================================================
   (kept for back-compat with the prior selectors)
   ============================================================ */
.orbit-attr-section > .elementor-container {
	max-width: 1280px !important;
	margin: 0 auto;
	gap: 80px;
	align-items: stretch; /* lets the two columns share a baseline */
}

/* Vertically center each column's content within the equal-height row */
.orbit-attr-section > .elementor-container > .elementor-column {
	display: flex;
	flex-direction: column;
	justify-content: center;
}

/* Image card sized larger to give the chart more presence */
.orbit-attr-chart {
	max-width: 600px; /* 25% larger than 480px */
	margin: 0 auto;
}
.orbit-attr-chart > .elementor-widget-container {
	padding: 32px !important;
	border-radius: 24px !important;
}
.orbit-attr-chart img {
	width: 100%;
	height: auto;
	display: block;
}

/* Force the checklist text + checks to the design blue */
.orbit-attr-checklist .elementor-icon-list-text,
.orbit-attr-checklist .elementor-icon-list-text * {
	color: #2563EB !important;
	font-family: var(--orbit-font-sans);
	font-weight: 500;
	font-size: 16px;          /* was 17px */
}
.orbit-attr-checklist .elementor-icon-list-icon i,
.orbit-attr-checklist .elementor-icon-list-icon svg {
	color: #2563EB !important;
	fill: #2563EB !important;
	font-size: 16px;
}
/* .orbit-attr-checklist .elementor-icon-list-item:not(:last-child) {
	margin-bottom: 12px !important;
} */

/* Tighten the eyebrow letterspacing and heading kerning */
.orbit-attr-section .orbit-eyebrow .elementor-heading-title {
	font-family: var(--orbit-font-sans);
	font-weight: 600;
	font-size: 14px;
	letter-spacing: 2px;
	color: #2563EB;
	text-transform: uppercase;
}
.orbit-attr-section .orbit-attr-heading .elementor-heading-title {
	font-family: var(--orbit-font-sans);
	font-weight: 700;
	font-size: 36px;          /* was 42px */
	line-height: 1.18;
	letter-spacing: -0.4px;
	color: #0B0B0F;
}
.orbit-attr-section .orbit-attr-body p {
	font-family: var(--orbit-font-sans);
	font-size: 16px;          /* was 17px */
	line-height: 1.55;
	color: #4B5563;
	margin: 0;
}

/* Tightened vertical rhythm in the right column.
   These override the inline Elementor margins so the rebuild script
   doesn't need to be re-run. */
.orbit-attr-section .orbit-eyebrow {
	margin-bottom: 8px !important;   /* was 10 */
}
.orbit-attr-section .orbit-attr-heading {
	margin-bottom: 12px !important;  /* was 16 */
}
.orbit-attr-section .orbit-attr-body {
	margin-bottom: 18px !important;  /* was 22 */
}
.orbit-attr-section .orbit-attr-checklist {
	margin-bottom: 18px !important;  /* was 24 — tightens space before the Learn More link */
}

/* Tighter checklist rows */
.orbit-attr-checklist .elementor-icon-list-item:not(:last-child) {
	margin-bottom: 8px !important;   /* was 10 */
}

/* Learn-more link */
.orbit-learn-link:hover {
	text-decoration: underline !important;
	color: #1D4FD8 !important;
}

/* Responsive */
@media (max-width: 1024px) {
	.orbit-attr-section .orbit-attr-heading .elementor-heading-title {
		font-size: 34px;
	}
	.orbit-attr-section > .elementor-container {
		gap: 40px;
	}
}
@media (max-width: 767px) {
	.orbit-attr-section .orbit-attr-heading .elementor-heading-title {
		font-size: 28px;
	}
}

/* ============================================================
   Pricing Plans HTML
   ============================================================ */

/* ── Controls bar ── */
  .controls {
    margin-bottom: 2rem;
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    gap: 1.25rem;
    justify-content: space-between;
  }
.controls > div {
    flex: 1 1 100%;
    max-width: 320px;
  }
  .controls > div:nth-child(2) {   
    max-width: 100%;
  }

  .pageview-label {
    font-size: 15px;
    color: #555;
    white-space: nowrap;
    flex-shrink: 0;
	font-family:"Averta", Sans-serif;
  }
  .pageview-label strong {
    color: #111;
    font-weight: 700;
  }

  .slider-wrap {
    flex: 1;
    min-width: 180px;
    position: relative;
    padding-top: 0;
	font-family: "Averta", Sans-serif;
  }

  .bubble {
    position: absolute;
    top: -35px;
    left: 0;
    background: #111;
    color: #fff;
    font-size: 11px;
    font-weight: 700;
    padding: 3px 9px;
    border-radius: 20px;
    transform: translateX(-50%);
    white-space: nowrap;
    pointer-events: none;
    transition: left 0.04s linear;
	margin-left: 12px;  
  }
  .bubble::after {
    content: '';
    position: absolute;
    bottom: -4px;
    left: 50%;
    transform: translateX(-50%);
    border: 5px solid transparent;
    border-top-color: #111;
    border-bottom: none;
  }

  input[type="range"] {
    -webkit-appearance: none;
    appearance: none;
  width: 100%;
  height: 5px;
  background: #e7e7e7;
  border-radius: 100px;
  outline: none;
  cursor: pointer;
  }
  input[type="range"]::-webkit-slider-thumb {
    width: 20px;
    height: 20px;
    background: url('https://orbitanalytics.creativehausdev.com/wp-content/uploads/2026/05/orbit-logo.png') no-repeat #0B0B0F;
    border-radius: 100%;
    border: none;
    cursor: pointer;
	background-size: 70%;
	border:2px solid #fff;
	padding:10px;
	  background-position: center center;
    cursor: pointer;
    transition: transform 0.1s;
  }
  input[type="range"]::-webkit-slider-thumb:hover { transform: scale(1.15); }
  input[type="range"]::-moz-range-thumb {
    width: 20px;
    height: 20px;
    background: url('https://orbitanalytics.creativehausdev.com/wp-content/uploads/2026/05/orbit-logo.png') no-repeat #0B0B0F;
    border-radius: 100%;
    border: none;
    cursor: pointer;
	background-size: 70%;
	border:2px solid #fff;
	padding:10px;
	  background-position: center center;
  }

  .slider-labels {
    display: flex;
  justify-content: space-between;
  font-size: 16px;
  color: var(--primaryColor);
  margin-top: 5px;
  position: absolute;
  width: calc(100% + 90px);
  top: 50%;
  transform: translate(-50% , -50%);
  left: calc(50% + 8px);
	  font-weight:400;
  }

  /* ── Billing toggle ── */
  .billing-wrap {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-shrink: 0;
	  justify-content: end;
  }

  .free-badge {
    background: #fef3cd;
    color: #7a4f00;
    font-size: 11px;
    font-weight: 700;
    padding: 3px 10px;
    border-radius: 20px;
    transition: opacity 0.2s, transform 0.2s;
	  right: 0;
  top: -30px;
	  position:absolute;
  }
  .free-badge.hidden {
    opacity: 0;
    pointer-events: none;
    transform: scale(0.9);
  }

  .toggle {
    display: flex;
	  background: #fff;
	  border-radius: 100px;
	  padding: 5px;
	  gap: 2px;
	  border: 2px solid #eee;
  }
  .toggle button {
    border: none;
    background: transparent;
    padding: 7px 18px;
    border-radius: 20px;
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
    color: #666;
    transition: background 0.15s, color 0.15s;
  }
  .toggle button.active {
    background: #111;
    color: #fff;
  }

  /* ── Cards grid ── */
  .cards {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
  }

@media screen and (max-width:1279px){
	.cards{
		grid-template-columns: repeat(2, 1fr);
	}
}

  @media (max-width: 900px) {
    .cards { grid-template-columns: repeat(2, 1fr); }
	  .controls{
		  flex-wrap: wrap;
		  margin-bottom:0;
	  }  
	  .controls > div{
		  text-align:center;
		  max-width:100%;
		  position:relative;
	  }
	  .billing-wrap{
		  justify-content:center;
	  }
	  .slider-labels{
		  position:static;
		  transform:unset;
		  width:100%;
	  }
  }
  @media (max-width: 560px) {
    .cards { grid-template-columns: 1fr; }
    .controls { flex-direction: column; align-items: stretch; }
    .billing-wrap { justify-content: center; }
  }

  .card {
    border: 2px solid #e8e8e8;
    border-radius: 16px;
    padding: 1.5rem;
    display: flex;
    flex-direction: column;
    gap: 12px;
    background: #fff;
    transition: border-color 0.2s;
  }
  .card:hover { border-color: #bbb; }
  .card.dark {
    background: #111;
    color: #fff;
    border-color: #111;
  }
  .card.dark:hover { border-color: #333; }

  .plan-name {
    font-size: 22px;
	  font-weight: 700;	 
	  color: var(--primaryColor);
	  font-family: ;
  }
  .card.dark .plan-name { color: white; }

  .price-block { display: flex; flex-direction: column; gap: 3px; }

  .price {
    font-size: 40px;
    font-weight: 900;
    letter-spacing: -1px;
    line-height: 1;
    color: #111;
  }
  .card.dark .price { color: #fff; }

  .price-per {
    font-size: 15px;
    font-weight: 400;
    color: #888;
    letter-spacing: 0;
  }

  .price-note {
    font-size: 12px;
    color: var(--primaryColor);
    min-height: 16px;
    transition: all 0.2s;
  }
 .card.dark .price {
  color: #fff;
  font-size: 36px;
}

  .cta-btn {
    display: block;
    width: 100%;
    text-align: center;
    padding: 11px 0;
    border-radius: 10px;
    font-size: 16px;
    font-weight: bold;
    cursor: pointer;
    border: none;
    transition: opacity 0.15s, transform 0.1s;
    text-decoration: none;
  }
  .cta-btn:hover { opacity: 1; background:var(--accentColor);}
  .cta-btn:active { transform: scale(0.98); }
  .cta-dark { background: #111; color: #fff; }
  .cta-light { background: #fff; color: #111; border: 1.5px solid #ddd; }
  .card.dark .cta-light { background: #fff; color: #111; border-color: #fff; }

  .features {
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 9px;
    flex: 1;
	margin-top:10px;
  }
  .features li {
    font-size: 15px;
    color: var(--primaryColor);
    display: flex;
    align-items: flex-start;
    gap: 7px;
    line-height: 1.45;
	font-weight:400;
	display:flex;
	align-items:center;
  }
  .card.dark .features li { color: white; }
  .features li .check {
    width: 16px;
    height: 16px;
    flex-shrink: 0;
    margin-top: 1px;
	  fill:var(--pimaryColor);
  }
.features li .check path {
  stroke: white;
}
.card.dark .features li .check {
  fill: white;
}
.card.dark .features li .check path {
  stroke: var(--primaryColor);
}

  /* check icon */
  .check-icon { color: #111; }
  .card.dark .check-icon { color: #fff; }

  /* ── Bottom CTA ── */
  .bottom-cta {
    margin-top: 4rem;
    background: #f5f5f5;
    border-radius: 20px;
    padding: 2.5rem;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 1.5rem;
  }
  .bottom-cta h3 {
    font-size: clamp(18px, 2.5vw, 24px);
    font-weight: 800;
    max-width: 420px;
  }
  .bottom-cta p {
    font-size: 14px;
    color: #666;
    margin-top: 6px;
    max-width: 380px;
  }
  .bottom-cta-btns { display: flex; gap: 10px; flex-wrap: wrap; }
  .btn-primary {
    padding: 12px 24px;
    background: #111;
    color: #fff;
    border: none;
    border-radius: 10px;
    font-size: 14px;
    font-weight: 700;
    cursor: pointer;
    transition: opacity 0.15s;
  }
  .btn-primary:hover { opacity: 0.85; }
  .btn-secondary {
    padding: 12px 24px;
    background: transparent;
    color: #111;
    border: 1.5px solid #ddd;
    border-radius: 10px;
    font-size: 14px;
    font-weight: 700;
    cursor: pointer;
    transition: border-color 0.15s;
  }
  .btn-secondary:hover { border-color: #999; }


