.elementor-3654 .elementor-element.elementor-element-c3c6017 > .elementor-container > .elementor-column > .elementor-widget-wrap{align-content:flex-start;align-items:flex-start;}.elementor-3654 .elementor-element.elementor-element-c3c6017{margin-top:0px;margin-bottom:0px;padding:0px 0px 0px 0px;}.elementor-3654 .elementor-element.elementor-element-a10ba5d{width:var( --container-widget-width, 100.072% );max-width:100.072%;--container-widget-width:100.072%;--container-widget-flex-grow:0;}.elementor-3654 .elementor-element.elementor-element-a10ba5d > .elementor-widget-container{margin:0px 0px 0px 0px;padding:0px 0px 0px 0px;}/* Start custom CSS for html, class: .elementor-element-a10ba5d */.elementor-location-header, #content .page-header,.elementor-location-footer {display:none!important}

:root {
	--obsidian:      #080C14;
	--ink:           #0F1624;
	--slate:         #18213A;
	--slate-light:   #222D48;
	--champagne:     #0094ea;
	--champ-light:   #4aafea;
	--champ-pale:    #a9d1e9;
	--cream:         #f4f4f4;
	--off-white:     #fafafa;
	--white:         #FFFFFF;
	--text-body:     #111;
	--text-mid:      #444;
	--text-subtle:   #666;
	--border-dark:   rgba(169,209,233,0.18);
	--border-light:  #eee;
	--green-ok:      #1B6B42;
	--red-err:       #C0392B;

	--r:   8px;
	--r-lg: 16px;
	--sh-gold: 0 8px 32px rgba(169,209,233,0.22);
	--sh-dark: 0 24px 64px rgba(0,0,0,0.5);
	--sh-card: 0 4px 20px rgba(0,0,0,0.07);
	--ease: cubic-bezier(0.22, 1, 0.36, 1);
}

/* ============================================================
RESET
============================================================ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { font-size: 18px; scroll-behavior: smooth; }

body {
	font-family: 'DM Sans', system-ui, sans-serif;
	color: var(--text-body);
	background: var(--off-white);
	line-height: 1.65;
	-webkit-font-smoothing: antialiased;
	overflow-x: hidden;
}
b, strong {
	font-weight: 800;
}




/* ---- Logo image ---- */
.logo-img {
	height: 48px!important;
	width: auto;
	display: block;
	/* logo is colored; invert to white for dark header/footer */
	filter: brightness(0) invert(1);
}
.logo-img-color {
	height: 48px;
	width: auto;
	display: block;
}

/* ---- Hero photo panel ---- */
.hero-photo-panel {
	position: relative;
	border-radius: var(--r-lg);
	overflow: hidden;
	align-self: stretch;
	min-height: 460px;
	flex-shrink: 0;
}
.hero-photo-panel img {
	width: 100%; height: 100%;
	object-fit: cover;
	object-position: center 30%;
	display: block;
}
.hero-photo-panel-overlay {
	position: absolute; inset: 0;
	background: linear-gradient(
		to bottom,
		rgba(8,12,20,0.2) 0%,
		rgba(8,12,20,0.05) 40%,
		rgba(8,12,20,0.5) 100%
	);
}
.hero-photo-caption {
	position: absolute;
	bottom: 1.25rem; left: 1.5rem; right: 1.5rem;
	background: rgba(8,12,20,0.75);
	backdrop-filter: blur(12px);
	border: 1px solid rgba(169,209,233,0.25);
	border-radius: var(--r);
	padding: 0.85rem 1.1rem;
	display: flex; align-items: center; gap: 0.7rem;
}
.hero-photo-caption-icon {
	width: 32px; height: 32px; border-radius: 50%;
	background: rgba(169,209,233,0.15);
	border: 1px solid rgba(169,209,233,0.4);
	display: flex; align-items: center; justify-content: center;
	font-size: 0.85rem; flex-shrink: 0;
}
.hero-photo-caption-text {
	line-height: 1.2;
}
.hero-photo-caption-text strong {
	display: block;
	font-size: 0.82rem; font-weight: 600; color: var(--white);
	font-family: 'Fraunces', Georgia, serif;
	font-optical-sizing: auto;
}
.hero-photo-caption-text span {
    font-size: 0.72rem;
    color: rgba(255,255,255,0.5);
    letter-spacing: .01em;
}
@media (max-width: 768px) {
	.hero-photo-caption {
		bottom: unset;
		top: 20px;
	}
}

/* ---- Freedom photo banner ---- */
.freedom-banner {
	position: relative;
	overflow: hidden;
	min-height: 480px;
	display: flex; align-items: center;
}
.freedom-banner-img {
	position: absolute; inset: 0;
	width: 100%; height: 100%;
	object-fit: cover;
	object-position: center 40%;
}
@media (max-width: 768px) {
	.freedom-banner-img {
		object-position: 65% 40%;
	}
}
.freedom-banner-overlay {
	position: absolute; inset: 0;
	background: linear-gradient(
		105deg,
		rgba(8,12,20,0.88) 0%,
		rgba(8,12,20,0.72) 45%,
		rgba(8,12,20,0.35) 100%
	);
}
.freedom-inner {
	position: relative; z-index: 1;
	max-width: 1450px; margin: 0 auto;
	padding: 5rem 3rem;
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 4rem; align-items: center;
}
.freedom-content h2 {
	font-size: clamp(2rem, 4vw, 3.2rem);
	font-weight: 800; color: var(--white);
	letter-spacing: -0.015em;
	margin-bottom: 1.25rem;
	font-optical-sizing: auto;
}
.freedom-content h2 em {
	font-style: italic;
	color: var(--champagne);
}
.freedom-content p {
	font-size: 1.05rem; color: rgba(255,255,255,0.7);
	line-height: 1.7; margin-bottom: 2rem;
}
.freedom-stats {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 1rem;
}
.freedom-stat {
	background: rgba(0,0,0,0.3);
	border: 1px solid rgba(169,209,233,0.2);
	border-radius: var(--r);
	padding: 1.25rem;
}
.freedom-stat-num {
	font-family: 'Fraunces', Georgia, serif;
	font-size: 1.9rem; font-weight: 800;
	color: var(--champagne); display: block;
	letter-spacing: -0.02em; line-height: 1;
	font-optical-sizing: auto;
}
.freedom-stat-label {
	font-size: 0.8rem; color: rgba(255,255,255,0.5);
	margin-top: 0.3rem; display: block;
}

/* ---- Testimonials photo feature ---- */
.test-section-photo {
	width: 100%; max-width: 420px;
	border-radius: var(--r-lg);
	overflow: hidden; flex-shrink: 0;
	position: relative;
}
.test-section-photo img {
	width: 100%; height: 320px;
	object-fit: cover; object-position: center 25%;
	display: block;
}
.test-section-photo-overlay {
	position: absolute; inset: 0;
	background: linear-gradient(to top, rgba(15,22,36,0.7) 0%, transparent 60%);
}
.test-section-photo-tag {
	position: absolute; bottom: 1.25rem; left: 1.25rem;
	background: var(--champagne);
	color: var(--obsidian);
	font-size: 0.75rem; font-weight: 700;
	letter-spacing: 0.06em; text-transform: uppercase;
	padding: 0.35rem 0.85rem; border-radius: 100px;
}
.test-layout {
	display: grid;
	grid-template-columns: 420px 1fr;
	gap: 3rem; align-items: start;
}

/* grain overlay on dark sections */
.grain::after {
	content: '';
	position: absolute;
	inset: 0;
	background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
	background-size: 200px;
	pointer-events: none;
	z-index: 0;
	opacity: 0.6;
}

/* ADA skip nav */
.skip-nav {
	position: absolute; top: -120px; left: 1rem;
	background: var(--champagne); color: var(--obsidian);
	padding: 0.75rem 1.5rem; border-radius: var(--r);
	font-weight: 700; font-size: 0.95rem; z-index: 9999;
	text-decoration: none; transition: top 0.2s;
}
.skip-nav:focus { top: 1rem; }

:focus-visible {
	outline: 2px solid var(--champagne);
	outline-offset: 3px;
	border-radius: 3px;
}

img { max-width: 100%; height: auto; display: block; }
a { color: var(--champagne); }
a:hover { color: var(--champ-light); }
p { margin-bottom: 1rem; }
p:last-child { margin-bottom: 0; }

h1,h2,h3,h4 {
	font-family: 'Fraunces', Georgia, serif!important;
	line-height: 1.08!important;
	letter-spacing: -0.01em!important;
	font-optical-sizing: auto!important;
}

.visually-hidden {
	position: absolute; width: 1px; height: 1px;
	overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap;
}

/* ============================================================
BUTTONS
============================================================ */
.btn {
	display: inline-flex; align-items: center; justify-content: center;
	gap: 0.5rem;
	font-family: 'DM Sans', sans-serif!important;
	font-size: 1rem!important; font-weight: 600!important;
	padding: 0.875rem 1.875rem!important;
	border-radius: var(--r)!important;
	border: 1.5px solid transparent;
	cursor: pointer!important; text-decoration: none!important;
	transition: all 0.2s var(--ease);
	white-space: nowrap; min-height: 52px;
	letter-spacing: 0.01em!important;
	    color: rgb(255, 255, 255) !important;
    background-color: rgb(0, 0, 0) !important;
}
.btn:hover {
	border: 1.5px solid transparent!important;
}
.btn:active { transform: scale(0.98); }

.btn-gold {
	background: var(--champagne)!important;
	color: var(--obsidian)!important;
	border-color: var(--champagne)!important;
	box-shadow: var(--sh-gold)!important;
}
.btn-gold:hover {
	background: var(--champ-light)!important;
	border-color: var(--champ-light)!important;
	color: var(--obsidian)!important;
	box-shadow: 0 12px 40px rgba(169,209,233,0.35)!important;
	transform: translateY(-1px)!important;
}

.btn-ghost-light {
	background: transparent!important;
	color: var(--white)!important;
	border-color: rgba(255,255,255,0.3)!important;
}
.btn-ghost-light:hover {
	background: rgba(255,255,255,0.08)!important;
	border-color: rgba(255,255,255,0.6)!important;
	color: var(--white)!important;
}

.btn-dark {
	background: var(--ink)!important;
	color: var(--white)!important;
	border-color: var(--ink)!important;
}
.btn-dark:hover {
	background: var(--slate)!important;
	border-color: var(--slate)!important;
	color: var(--white)!important;
}

.btn-lg { font-size: 1.05rem!important; padding: 1rem 2.25rem!important; min-height: 58px!important; }

/* ============================================================
TOP STRIP
============================================================ */
.topstrip {
	background: var(--champagne);
	color: var(--obsidian);
	text-align: center;
	padding: 0.5rem 1.5rem;
	font-size: 0.82rem;
	font-weight: 600;
	letter-spacing: 0.04em;
}
.topstrip a { color: var(--obsidian); font-weight: 700; }
@media (max-width: 768px) {
	.topstrip {
		font-size: 0.7rem;
	}
}


/* ============================================================
HEADER
============================================================ */
.site-header {
	position: sticky; top: 0; z-index: 200;
	background: rgba(8,12,20,0.92);
	backdrop-filter: blur(20px) saturate(180%);
	-webkit-backdrop-filter: blur(20px) saturate(180%);
	border-bottom: 1px solid var(--border-dark);
	max-width: 100%!important;
	padding: 0;
}

.header-inner {
	max-width: 1450px; margin: 0 auto;
	padding: 0 2rem;
	display: flex; align-items: center; justify-content: space-between;
	gap: 2rem; min-height: 72px;
}

.logo {
	display: flex; align-items: center; gap: 0.85rem;
	text-decoration: none; flex-shrink: 0;
}
.logo-icon {
	width: 40px; height: 40px;
	border: 1.5px solid var(--champagne);
	border-radius: 6px;
	display: flex; align-items: center; justify-content: center;
	font-family: 'Fraunces', Georgia, serif;
	font-weight: 800; font-size: 0.88rem;
	color: var(--champagne);
	letter-spacing: 0;
	font-optical-sizing: auto;
}
.logo-text { display: flex; flex-direction: column; gap: 0.05rem; }
.logo-name {
	font-family: 'Fraunces', Georgia, serif;
	font-size: 1rem; font-weight: 700;
	color: var(--white); letter-spacing: 0;
	font-optical-sizing: auto;
}
.logo-sub {
	font-size: 0.68rem; font-weight: 500;
	color: var(--champagne); letter-spacing: 0.08em;
	text-transform: uppercase;
}

.header-right {
	display: flex; align-items: center; gap: 1.5rem;
}
#hdr-cta {
	margin: 0;
}
.live-badge {
	display: flex; align-items: center; gap: 0.45rem;
	font-size: 0.78rem; font-weight: 600;
	color: rgba(255,255,255,0.6);
}
.live-dot {
	width: 7px; height: 7px; border-radius: 50%;
	background: #22C55E;
	box-shadow: 0 0 0 3px rgba(34,197,94,0.25);
	animation: livepulse 2s ease-in-out infinite;
}
@keyframes livepulse {
	0%,100% { box-shadow: 0 0 0 3px rgba(34,197,94,0.25); }
	50%      { box-shadow: 0 0 0 6px rgba(34,197,94,0.08); }
}

.header-phone {
	font-family: 'Fraunces', Georgia, serif;
	font-size: 1.15rem; font-weight: 700;
	color: var(--white); text-decoration: none;
	letter-spacing: 0;
	font-optical-sizing: auto;
	display: flex; align-items: center; gap: 0.4rem;
	transition: color 0.15s;
}
.header-phone:hover { color: var(--champagne); }

/* ============================================================
HERO
============================================================ */
.hero {
	position: relative;
	background: var(--obsidian);
	overflow: hidden;
	min-height: 800px;
	display: flex;
	align-items: center;
}
@media (max-width: 768px) {
	.hero {
		height: auto;
	}
}

/* Layered dark gradient mesh */
.hero-bg {
	position: absolute; inset: 0;
	background:
		radial-gradient(ellipse 55% 70% at 15% 50%, rgba(169,209,233,0.06) 0%, transparent 60%),
		radial-gradient(ellipse 40% 60% at 80% 20%, rgba(100,130,200,0.04) 0%, transparent 55%),
		radial-gradient(ellipse 30% 40% at 90% 80%, rgba(169,209,233,0.03) 0%, transparent 50%);
	z-index: 0;
}

/* Subtle grid lines */
.hero-grid {
	position: absolute; inset: 0;
	background-image:
		linear-gradient(rgba(169,209,233,0.04) 1px, transparent 1px),
		linear-gradient(90deg, rgba(169,209,233,0.04) 1px, transparent 1px);
	background-size: 80px 80px;
	z-index: 0;
	mask-image: linear-gradient(to bottom, transparent 0%, black 20%, black 80%, transparent 100%);
}

.hero-inner {
	max-width: 100%;
	margin: 0 auto;
	padding: clamp(40px,3vw,100px);
	display: grid;
	grid-template-columns: 440px 1fr 400px;
	gap: 2.5rem;
	align-items: center;
	position: relative;
	z-index: 1;
	width: 100%;
}

/* Eyebrow */
.eyebrow {
	display: inline-flex; align-items: center; gap: 0.6rem;
	margin-bottom: 1.5rem;
}
.eyebrow-line {
	width: 32px; height: 1.5px; background: var(--champagne);
}
.eyebrow-text {
	font-size: 0.75rem; font-weight: 600;
	letter-spacing: 0.14em; text-transform: uppercase;
	color: var(--champagne);
}

.hero h1 {
	font-size: clamp(2rem, 5vw, 3rem);
	font-weight: 800;
	color: var(--white);
	margin-bottom: 1.5rem;
	line-height: 1.04;
	letter-spacing: -0.015em;
	font-optical-sizing: auto;
}
.hero h1 .accent { color: var(--champagne); }

.hero-lead {
	font-size: 1.05rem; font-weight: 300;
	color: rgba(255,255,255,0.65);
	margin-bottom: 2.5rem;
	line-height: 1.7;
}

.hero-chips {
	display: flex; flex-wrap: wrap; gap: 0.5rem;
	margin-bottom: 2.5rem;
}
.chip {
	display: inline-flex; align-items: center; gap: 0.35rem;
	border: 1px solid rgba(169,209,233,0.3);
	background: rgba(169,209,233,0.06);
	color: rgba(255,255,255,0.8);
	font-size: 0.82rem; font-weight: 500;
	padding: 0.35rem 0.85rem;
	border-radius: 100px;
}
.chip-check { color: var(--champagne); font-size: 0.7rem; }

.hero-ctas {
	display: flex; flex-wrap: wrap; gap: 1rem; align-items: center;
}
.hero-footnote {
	font-size: 0.78rem; color: rgba(255,255,255,0.35);
	margin-top: 1rem; letter-spacing: 0.02em;
}

/* ---- Hero Form Card ---- */
.gform_heading {
    display: none;
}
.gform_wrapper.gravity-theme .gfield_required {
    color: #eb917d!important;
    font-size: 10px!important;
    padding-left: 3px!important;
    font-weight: 600!important;
}
.gfield input {
    font-size: 14px!important;
    font-weight: 600!important;
    border-radius: 6px;
}
.elementor-kit-5 input[type="submit"] {
    font-family: 'DM Sans', sans-serif !important;
    font-weight: 600 !important;
    border-radius: var(--r) !important;
    border: 1.5px solid transparent;
    cursor: pointer !important;
    text-decoration: none !important;
    transition: all 0.2s var(--ease);
    white-space: nowrap;
    letter-spacing: 0.001em !important;
    font-size: .95rem !important;
    padding: .75rem 1rem !important;
    min-height: 58px !important;
    background: var(--champagne) !important;
    color: var(--obsidian) !important;
    border-color: var(--champagne) !important;
    box-shadow: var(--sh-gold) !important;
}
.elementor-kit-5 input[type="submit"]:hover {
    background: var(--champ-light)!important;
    border-color: var(--champ-light)!important;
    color: var(--obsidian)!important;
    box-shadow: 0 12px 40px rgba(169,209,233,0.35)!important;
    transform: translateY(-1px)!important;
}
.elementor-kit-5 p {
    margin-block-end: 1em!important;
}
.gform_confirmation_message {
    text-align: center;
    line-height: 1.75;
}

.hero-card {
	background: rgba(255,255,255,0.035);
	border: 1px solid rgba(169,209,233,0.2);
	border-radius: var(--r-lg);
	padding: 2.25rem 2rem;
	backdrop-filter: blur(24px);
	position: relative;
	overflow: hidden;
}
/* gold top line */
.hero-card::before {
	content: '';
	position: absolute; top: 0; left: 0; right: 0;
	height: 2px;
	background: linear-gradient(90deg, transparent, var(--champagne), transparent);
}

.card-heading {
	font-family: 'Fraunces', Georgia, serif;
	font-size: 1.3rem; font-weight: 700;
	color: var(--white); margin-bottom: 0.25rem;
	letter-spacing: -0.01em;
	font-optical-sizing: auto;
}
.card-sub {
	font-size: 0.83rem; color: rgba(255,255,255,0.45);
	margin-bottom: 1.75rem;
}

.field { margin-bottom: 1rem; }
.field label {
	display: block;
	font-size: 0.8rem; font-weight: 600;
	color: rgba(255,255,255,0.6);
	margin-bottom: 0.4rem; letter-spacing: 0.03em;
	text-transform: uppercase;
}
.field input {
	width: 100%;
	background: rgba(255,255,255,0.06);
	border: 1px solid rgba(255,255,255,0.12);
	border-radius: var(--r);
	padding: 0.8rem 1rem;
	font-family: 'DM Sans', sans-serif;
	font-size: 1rem; color: var(--white);
	transition: border-color 0.18s, box-shadow 0.18s;
}
.field input:focus {
	outline: none;
	border-color: var(--champagne);
	box-shadow: 0 0 0 3px rgba(169,209,233,0.15);
}
.field input::placeholder { color: rgba(255,255,255,0.22); }

.card-privacy {
	font-size: 0.75rem; color: rgba(255,255,255,0.3);
	margin-top: 0.75rem; display: flex; gap: 0.4rem;
	align-items: flex-start;
}
.card-privacy::before { content: '🔒'; font-size: 0.7rem; flex-shrink: 0; }

.card-divider {
	display: flex; align-items: center; gap: 0.75rem;
	font-size: 0.75rem; color: rgba(255,255,255,0.25);
	margin: 1.25rem 0;
}
.card-divider::before, .card-divider::after {
	content: ''; flex: 1; height: 1px;
	background: rgba(255,255,255,0.1);
}

.card-phone {
	text-align: center;
}
.card-phone a {
	font-family: 'Fraunces', Georgia, serif;
	font-size: 1.55rem; font-weight: 800;
	color: var(--champagne); text-decoration: none;
	letter-spacing: -0.01em;
	display: flex; align-items: center; justify-content: center; gap: 0.35rem;
	font-optical-sizing: auto;
}
.card-phone a:hover { color: var(--champ-light); }
.card-phone p { font-size: 0.72rem; color: rgba(255,255,255,0.28); margin-top: 0.2rem; }

/* ============================================================
STAT STRIP
============================================================ */
.stat-strip {
	background: var(--ink);
	border-top: 1px solid rgba(169,209,233,0.12);
	border-bottom: 1px solid rgba(169,209,233,0.12);
	padding: 0;
}
.stat-strip-inner {
	max-width: 1450px; margin: 0 auto;
	display: grid;
	grid-template-columns: repeat(4, 1fr);
}
.stat-item {
	padding: 2rem 1.5rem;
	text-align: center;
	border-right: 1px solid rgba(169,209,233,0.1);
	transition: background 0.2s;
}
.stat-item:last-child { border-right: none; }
.stat-item:hover { background: rgba(169,209,233,0.04); }

.stat-num {
	font-family: 'Fraunces', Georgia, serif;
	font-size: clamp(1.8rem, 3vw, 2.75rem);
	font-weight: 800;
	color: var(--champagne);
	letter-spacing: -0.02em;
	display: block; line-height: 1;
	margin-bottom: 0.4rem;
	font-optical-sizing: auto;
}
.stat-label {
	font-size: 0.8rem; font-weight: 500;
	color: rgba(255,255,255,0.45);
	letter-spacing: 0.03em;
}


/* ============================================================
LOGO MARQUEE
============================================================ */
.logo-bar {
	background: var(--off-white);
	border-top: 1px solid var(--border-light);
	border-bottom: 1px solid var(--border-light);
	padding: 0;
	overflow: hidden;
	position: relative;
}

/* fade-out edges */
.logo-bar::before,
.logo-bar::after {
	content: '';
	position: absolute;
	top: 0; bottom: 0;
	width: 120px;
	z-index: 2;
	pointer-events: none;
}
.logo-bar::before {
	left: 0;
	background: linear-gradient(to right, var(--off-white) 0%, transparent 100%);
}
.logo-bar::after {
	right: 0;
	background: linear-gradient(to left, var(--off-white) 0%, transparent 100%);
}

.logo-bar-label {
	text-align: center;
	font-size: 0.7rem;
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--text-subtle);
	padding: 1.5rem 2rem 0.5rem;
}

.logo-track-wrap {
	width: 100%;
	overflow: hidden;
	padding: 1.25rem 0 1.5rem;
}

.logo-track {
	display: flex;
	align-items: center;
	gap: 0;
	width: max-content;
	animation: marquee 28s linear infinite;
}

.logo-track:hover { animation-play-state: paused; }

@keyframes marquee {
	0%   { transform: translateX(0); }
	100% { transform: translateX(-50%); }
}

.logo-track-item {
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 0 3rem;
	flex-shrink: 0;
	border-right: 1px solid var(--border-light);
}
.logo-track-item:last-child { border-right: none; }

.logo-track-item img {
	height: 100px;
	width: auto;
	object-fit: contain;
	display: block;
	transition: filter 0.25s ease, transform 0.25s ease;
}
.logo-track-item img:hover {
	filter: grayscale(0%) opacity(1);
	transform: scale(1.06);
}

@media (max-width: 640px) {
	.logo-bar::before,
	.logo-bar::after { width: 60px; }
	.logo-track-item { padding: 0 2rem; }
	.logo-track-item img { height: 30px; max-width: 100px; }
	.logo-track { animation-duration: 22s; }
}
@media (prefers-contrast: high) {
	:root { --champagne: #A07800; --border-dark: rgba(160,120,0,0.5); }
	.hero-grid { display: none; }
}

/* ============================================================
SECTION SHARED
============================================================ */
.section { padding: 6rem 2rem; }
.section-dark { background: var(--ink); }
.section-cream { background: var(--cream); }
.section-off { background: var(--off-white); }
.container { max-width: 1450px; margin: 0 auto; }
.panel-1col.container { max-width: 100%; }

.section-kicker {
	font-size: 0.73rem; font-weight: 700;
	letter-spacing: 0.14em; text-transform: uppercase;
	color: var(--champagne);
	display: flex; align-items: center; gap: 0.6rem;
	margin-bottom: 1rem;
}
.section-kicker::before {
	content: ''; display: block;
	width: 24px; height: 1.5px; background: var(--champagne);
}

.section-title {
	font-size: clamp(1.75rem, 3.5vw, 2.85rem);
	font-weight: 800;
	letter-spacing: -0.015em;
	margin-bottom: 1.25rem!important;
	font-optical-sizing: auto;
}
.section-title.light { color: var(--white); }

.section-body {
	font-size: 1.02rem; color: var(--text-mid);
	max-width: 600px; line-height: 1.7;
}
.section-body.light { color: rgba(255,255,255,0.55); }

/* ============================================================
PAIN SECTION
============================================================ */
.pain-header {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 3rem; align-items: end;
	margin-bottom: 3.5rem;
}
.pain-header-right {
	display: flex; justify-content: flex-end; align-items: flex-end;
}

.pain-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 1.25px;
	background: var(--border-light);
	border: 1px solid var(--border-light);
	border-radius: var(--r-lg);
	overflow: hidden;
}

.pain-card {
	background: var(--white);
	padding: 2rem 1.75rem;
	transition: background 0.2s var(--ease), transform 0.2s var(--ease);
	position: relative;
}
.pain-card::after {
	content: '';
	position: absolute;
	bottom: 0; left: 1.75rem; right: 1.75rem;
	height: 2px;
	background: var(--champagne);
	transform: scaleX(0); transform-origin: left;
	transition: transform 0.3s var(--ease);
}
.pain-card:hover { background: var(--cream); }
.pain-card:hover::after { transform: scaleX(1); }

.pain-num {
	font-family: 'Fraunces', sans-serif;
	font-size: 0.72rem; font-weight: 700;
	letter-spacing: 0.1em; color: var(--champagne);
	margin-bottom: 1rem;
}
.pain-card h3 {
	font-size: 1.05rem; font-weight: 700;
	letter-spacing: -0.01em; margin-bottom: 0.6rem;
	color: var(--text-body);
}
.pain-card p { font-size: 0.9rem; color: var(--text-mid); line-height: 1.6; }

/* ============================================================
WHY US
============================================================ */
.why-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 5rem; align-items: center;
}

.why-list { list-style: none; padding: 0; margin-top: 2rem; }
.why-row {
	display: flex; align-items: flex-start; gap: 1rem;
	padding: 1.25rem 0;
	border-bottom: 1px solid rgba(255,255,255,0.07);
}
.why-row:first-child { border-top: 1px solid rgba(255,255,255,0.07); }
.why-tick {
	width: 22px; height: 22px; border-radius: 50%;
	background: rgba(169,209,233,0.12);
	border: 1px solid rgba(169,209,233,0.4);
	display: flex; align-items: center; justify-content: center;
	color: var(--champagne); font-size: 0.65rem; font-weight: 700;
	flex-shrink: 0; margin-top: 0.1rem;
}
.why-row-text strong { color: var(--white); display: block; margin-bottom: 0.2rem; font-size: 0.97rem; }
.why-row-text span { font-size: 0.87rem; color: rgba(255,255,255,0.45); line-height: 1.5; }

/* Warning box */
.warning-box {
	margin-top: 2rem;
	border: 1px solid rgba(255,180,50,0.25);
	background: rgba(255,180,50,0.05);
	border-radius: var(--r);
	padding: 1.25rem 1.5rem;
	display: flex; gap: 1rem; align-items: flex-start;
}
.warning-icon { font-size: 1.1rem; flex-shrink: 0; margin-top: 0.05rem; }
.warning-box p {
	font-size: 0.87rem; color: rgba(255,200,80,0.8);
	line-height: 1.6; margin: 0;
}
.warning-box a { color: rgba(255,200,80,0.9); }

/* Attorney visual */
.attorney-visual {
	position: relative;
}
.attorney-frame {
	border-radius: var(--r-lg);
	border: 1px solid var(--border-dark);
	background: var(--slate);
	overflow: hidden;
}
.attorney-head {
	background: linear-gradient(160deg, var(--slate-light), var(--slate));
	padding: 2em 2.5rem 0;
	text-align: center;
	position: relative;
}
.attorney-head::after {
	content: '';
	position: absolute;
	bottom: -1px; left: 0; right: 0; height: 40px;
	background: var(--slate);
	clip-path: ellipse(55% 100% at 50% 100%);
}
.attorney-monogram {
	width: 110px; height: 110px; border-radius: 50%;
	background: url(https://ogradylawlv.com/wp-content/uploads/2026/04/ogrady-headshot-1.webp);
	background-size: cover;
	background-repeat: no-repeat;
	border: 2px solid var(--champagne);
	display: flex; align-items: center; justify-content: center;
	margin: 0 auto;
	position: relative; z-index: 1;
}
.attorney-body {
	padding: 1.75rem 2rem 2rem;
}
.attorney-name {
	font-family: 'Fraunces', Georgia, serif;
	font-size: 1.35rem; font-weight: 800; color: var(--white);
	letter-spacing: -0.01em; text-align: center;
	margin-bottom: 0.2rem;
	font-optical-sizing: auto;
}
.attorney-role {
	font-size: 0.75rem; font-weight: 600; letter-spacing: 0.1em;
	text-transform: uppercase; color: var(--champagne);
	text-align: center; margin-bottom: 1.75rem;
}
.attr-row {
	display: flex; gap: 1px;
	background: rgba(169,209,233,0.1);
	border-radius: var(--r);
	overflow: hidden; margin-bottom: 1.5rem;
}
.attr {
	flex: 1; background: rgba(255,255,255,0.03);
	padding: 1rem 0.75rem; text-align: center;
}
.attr-val {
	font-family: 'Fraunces', Georgia, serif;
	font-size: 1.3rem; font-weight: 800;
	color: var(--champagne); letter-spacing: -0.01em;
	display: block; line-height: 1;
	font-optical-sizing: auto;
}
.attr-lab { font-size: 0.68rem; color: rgba(255,255,255,0.38); margin-top: 0.3rem; display: block; }

.bbb-pill {
	display: flex; align-items: center; justify-content: center; gap: 0.5rem;
	border: 1px solid rgba(169,209,233,0.3);
	background: rgba(169,209,233,0.06);
	border-radius: 100px; padding: 0.6rem 1.25rem;
	font-size: 0.82rem; font-weight: 700;
	color: var(--champagne); letter-spacing: 0.04em;
}

/* ============================================================
PROCESS
============================================================ */
.process-row {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 1.5rem;
	counter-reset: steps;
}
.process-step {
	position: relative;
	padding: 2rem 1.75rem;
	background: var(--white);
	border: 1px solid var(--border-light);
	border-radius: var(--r-lg);
	transition: box-shadow 0.2s var(--ease), transform 0.2s var(--ease);
}
.process-step:hover {
	box-shadow: var(--sh-card);
	transform: translateY(-3px);
}
/* connecting line */
.process-step:not(:last-child)::after {
	content: '→';
	position: absolute;
	right: -1.1rem; top: 50%;
	transform: translateY(-50%);
	color: var(--champagne);
	font-size: 1rem;
	z-index: 2;
	font-weight: 300;
}
.step-n {
	font-family: 'Fraunces', Georgia, serif;
	font-size: 2.5rem; font-weight: 800;
	color: var(--champ-pale);
	line-height: 1; margin-bottom: 1rem;
	letter-spacing: -0.02em;
	font-optical-sizing: auto;
}
.process-step h3 {
	font-size: 1rem; font-weight: 700;
	letter-spacing: -0.01em; margin-bottom: 0.5rem;
	color: var(--text-body);
}
.process-step p { font-size: 0.87rem; color: var(--text-mid); line-height: 1.6; }

/* ============================================================
TESTIMONIALS
============================================================ */
.test-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 1.5rem;
}
.test-card {
	background: rgba(255,255,255,0.04);
	border: 1px solid rgba(169,209,233,0.15);
	border-radius: var(--r-lg);
	padding: 2rem;
	transition: background 0.2s var(--ease), border-color 0.2s var(--ease);
}
.test-card:hover {
	background: rgba(255,255,255,0.065);
	border-color: rgba(169,209,233,0.3);
}
.test-stars { color: var(--champagne); font-size: 0.9rem; margin-bottom: 1rem; letter-spacing: 0.05em; }
.test-quote {
	font-size: 0.97rem; font-weight: 400;
	color: rgba(255,255,255,0.75);
	line-height: 1.7; font-style: italic;
	margin-bottom: 1.5rem!important;
}
.test-author { display: flex; gap: 0.85rem; align-items: center; }
.test-avatar {
	width: 38px; height: 38px; border-radius: 50%;
	background: rgba(169,209,233,0.15);
	border: 1px solid rgba(169,209,233,0.35);
	display: flex; align-items: center; justify-content: center;
	font-family: 'Fraunces', Georgia, serif;
	font-size: 0.82rem; font-weight: 700; color: var(--champagne);
	flex-shrink: 0;
	font-optical-sizing: auto;
}
.test-name { font-size: 0.8rem; font-weight: 600; color: var(--white); }
.test-label { font-size: 0.55rem; color: var(--champagne); font-weight: 600; letter-spacing: 0.01em; margin-top: 0.1rem; }

/* ============================================================
BOTTOM CTA
============================================================ */
.cta-sect {
	background: var(--obsidian);
	padding: 7rem 2rem;
	position: relative; overflow: hidden;
}
.cta-sect .grain::after { opacity: 0.5; }

.cta-bg-ring {
	position: absolute;
	width: 600px; height: 600px; border-radius: 50%;
	border: 1px solid rgba(169,209,233,0.06);
	left: 50%; top: 50%;
	transform: translate(-50%, -50%);
	pointer-events: none;
}
.cta-bg-ring:nth-child(2) {
	width: 900px; height: 900px;
	border-color: rgba(169,209,233,0.035);
}

.cta-inner {
	max-width: 600px; margin: 0 auto;
	text-align: center; position: relative; z-index: 1;
}

.cta-inner .section-title { color: var(--white); }
.cta-inner .section-title .accent { color: var(--champagne); }
.cta-inner .section-body { margin: 0 auto 2.5rem; color: rgba(255,255,255,0.5); }

.cta-form-box {
	background: rgba(255,255,255,0.03);
	border: 1px solid rgba(169,209,233,0.2);
	border-radius: var(--r-lg);
	padding: 2.25rem 2rem;
	text-align: left;
	position: relative;
}
.cta-form-box::before {
	content: '';
	position: absolute; top: 0; left: 0; right: 0; height: 2px;
	background: linear-gradient(90deg, transparent, var(--champagne), transparent);
	border-radius: var(--r-lg) var(--r-lg) 0 0;
}

.cta-divider {
	display: flex; align-items: center; gap: 0.75rem;
	font-size: 0.73rem; color: rgba(255,255,255,0.22);
	letter-spacing: 0.04em; margin: 1.5rem 0;
}
.cta-divider::before, .cta-divider::after {
	content: ''; flex: 1; height: 1px;
	background: rgba(255,255,255,0.1);
}
.cta-call-num {
	text-align: center;
}
.cta-call-num a {
	font-family: 'Fraunces', Georgia, serif;
	font-size: 1.9rem; font-weight: 800;
	color: var(--champagne); text-decoration: none;
	letter-spacing: -0.015em;
	display: flex; align-items: center; justify-content: center; gap: 0.4rem;
	font-optical-sizing: auto;
}
.cta-call-num a:hover { color: var(--champ-light); }
.cta-call-sub { font-size: 0.73rem; color: rgba(255,255,255,0.25); margin-top: 0.3rem; }
@media (max-width: 768px) {
	.cta-sect {
		padding: 3rem 2rem;
	}
	.cta-call-num a {
		font-size: 1.5rem;
	}
}


/* ============================================================
FOOTER
============================================================ */
.footer {
	background: #050810;
	padding: 3.5rem 2rem 2rem;
	border-top: 1px solid rgba(169,209,233,0.1);
}
.footer-grid {
	max-width: 1450px; margin: 0 auto;
	display: grid;
	grid-template-columns: 1.4fr 1fr 1fr;
	gap: 3rem;
}
.footer-about p {
	font-size: 0.85rem; color: rgba(255,255,255,0.32);
	line-height: 1.65; margin-top: 1rem;
}
.footer-col-head {
	font-size: 0.7rem; font-weight: 700;
	letter-spacing: 0.12em; text-transform: uppercase;
	color: var(--champagne); margin-bottom: 1rem;
}
.footer-nav-list { list-style: none; padding: 0; }
.footer-nav-list li { margin-bottom: 0.55rem; }
.footer-nav-list a {
	font-size: 0.88rem; color: rgba(255,255,255,0.42);
	text-decoration: none; transition: color 0.15s;
}
.footer-nav-list a:hover { color: rgba(255,255,255,0.8); }
.footer-phone-link {
	display: block;
	font-family: 'Fraunces', Georgia, serif;
	font-size: 1.35rem; font-weight: 800;
	color: var(--white); text-decoration: none;
	letter-spacing: -0.01em; margin-bottom: 0.3rem;
	font-optical-sizing: auto;
}
.footer-phone-link:hover { color: var(--champagne); }
.footer-avail { font-size: 0.75rem; color: rgba(255,255,255,0.3); margin-bottom: 1.25rem; }

.footer-bottom {
	max-width: 1450px; margin: 2.5rem auto 0;
	padding-top: 1.5rem;
	border-top: 1px solid rgba(255,255,255,0.06);
	display: flex; flex-wrap: wrap; gap: 0.75rem;
	justify-content: space-between;
	font-size: 0.7rem; color: rgba(255,255,255,0.22);
}

.footer-disclaimer {
	max-width: 1450px; margin: 1.25rem auto 0;
	font-size: 0.75rem; color: rgba(255,255,255,0.18);
	line-height: 1.6; padding-top: 1rem;
	border-top: 1px solid rgba(255,255,255,0.04);
}

/* ============================================================
STICKY PHONE BAR (mobile)
============================================================ */
.mobile-bar {
	display: none;
	position: fixed; bottom: 0; left: 0; right: 0;
	background: var(--champagne);
	padding: 0.75rem 1.5rem;
	z-index: 300;
	align-items: center; justify-content: center;
	gap: 0.5rem;
}
.mobile-bar a {
	font-family: 'Fraunces', Georgia, serif;
	font-size: 1.15rem; font-weight: 800;
	color: var(--obsidian); text-decoration: none;
	letter-spacing: -0.01em;
	font-optical-sizing: auto;
}

/* ============================================================
ANIMATIONS
============================================================ */
.fade-up {
	opacity: 0;
	transform: translateY(28px);
	transition: opacity 0.7s var(--ease), transform 0.7s var(--ease);
}
.fade-up.visible { opacity: 1; transform: translateY(0); }
.fade-up:nth-child(2) { transition-delay: 0.08s; }
.fade-up:nth-child(3) { transition-delay: 0.16s; }
.fade-up:nth-child(4) { transition-delay: 0.24s; }
.fade-up:nth-child(5) { transition-delay: 0.32s; }
.fade-up:nth-child(6) { transition-delay: 0.4s; }

/* ============================================================
RESPONSIVE
============================================================ */
@media (max-width: 960px) {
	.hero-inner { grid-template-columns: 1fr; gap: 2.5rem; padding: 1.5rem 1.5rem; }
	.hero-card { max-width: 500px; margin: 0 auto; width: 100%; padding: 1.5rem;}
	.hero-photo-panel { min-height: 360px; }
	.stat-strip-inner { grid-template-columns: repeat(2, 1fr); }
	.stat-item:nth-child(2) { border-right: none; }
	.pain-grid { grid-template-columns: 1fr 1fr; }
	.why-grid { grid-template-columns: 1fr; gap: 3rem; }
	.process-row { grid-template-columns: 1fr 1fr; }
	.process-step:nth-child(2)::after { display: none; }
	.test-layout { grid-template-columns: 1fr; }
	.test-section-photo { max-width: 100%; }
	.test-section-photo img { height: 240px; }
	.test-grid { grid-template-columns: 1fr; }
	.freedom-inner {
		grid-template-columns: auto;
		gap: 0;
		padding: 2rem 1rem;
	}
	.btn-lg {
		font-size: .9rem;
		min-height: 50px;
	}
	.btn {
		font-size: .75rem!important;
	}
	.footer-grid { grid-template-columns: 1fr; gap: 2rem; }
	.freedom-content {
    margin: 0 0 2rem;
}
}

@media (max-width: 640px) {
	html { font-size: 17px; }
	.section { padding: 4rem 1.25rem; }
	.pain-grid { grid-template-columns: 1fr; }
	.pain-header { grid-template-columns: 1fr;margin-bottom: 1.5rem; }
	.pain-header-right { display: none; }
	.process-row { grid-template-columns: 1fr; }
	.process-step::after { display: none !important; }
	.header-inner { padding: 0 1.25rem; }
	.header-phone { font-size: 1rem; }
	.live-badge { display: none; }
	.mobile-bar { display: flex; }
	body { padding-bottom: 56px; }
	.stat-strip-inner { grid-template-columns: repeat(2, 1fr); }
}

@media (prefers-reduced-motion: reduce) {
	*, .fade-up { animation: none !important; transition: none !important; transform: none !important; opacity: 1 !important; }
}
@media (prefers-contrast: high) {
	:root { --champagne: #A07800; --border-dark: rgba(160,120,0,0.5); }
	.hero-grid { display: none; }
}/* End custom CSS */