/* =========================================================================
   CMH One-Page — dark / premium design system
   Owned by the theme. No page builder, no third-party CSS.
   Ported from design/preview/home-preview.html (dark theme tokens).
   ========================================================================= */

:root{
	--bg:#0b0f19; --bg-alt:#0f1525; --surface:#121a2b; --surface-2:#0f1525;
	--text:#e7ecf5; --muted:#94a3b8; --border:#1f2940;
	--accent:#22d3ee; --accent-2:#818cf8;
	--gradient:linear-gradient(120deg,#22d3ee,#818cf8);
	--hero-bg:radial-gradient(1200px 600px at 70% -10%,rgba(129,140,248,.30),transparent 60%),
		radial-gradient(900px 500px at 10% 10%,rgba(34,211,238,.18),transparent 55%),#0b0f19;
	--hero-text:#ffffff; --hero-muted:#aab6cc;
	--card-shadow:0 1px 2px rgba(0,0,0,.4),0 10px 30px rgba(0,0,0,.35);
	--card-shadow-hover:0 16px 44px rgba(34,211,238,.20);
	--on-accent:#06121a; --footer-bg:#070a12; --footer-text:#94a3b8;
	--header-h:74px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
	margin:0;
	font-family:'Inter',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
	background:var(--bg); color:var(--text); line-height:1.6;
	-webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4,.display{font-family:'Space Grotesk','Inter',sans-serif; line-height:1.12; letter-spacing:-.02em; margin:0}
p{margin:0}
a{color:inherit; text-decoration:none}
img{max-width:100%; display:block}
ul{margin:0; padding:0; list-style:none}

/* Kill WordPress' root block-gap margins between header/main/footer so the hero
   meets the very top edge with no seam (we control spacing via section padding). */
.wp-site-blocks{padding-top:0}
.wp-site-blocks > *{margin-block:0}

.container{width:min(1180px,92%); margin-inline:auto}
.eyebrow{
	display:inline-flex; align-items:center; gap:.5rem; font-weight:600; font-size:.8rem;
	letter-spacing:.14em; text-transform:uppercase; color:var(--accent);
}
.section{padding:clamp(56px,8vw,110px) 0; scroll-margin-top:90px}
.section-head{max-width:680px; margin:0 auto clamp(36px,5vw,60px); text-align:center}
.section-head h2{font-size:clamp(1.8rem,3.6vw,2.7rem); margin:.6rem 0 .8rem; color:#fff}
.section-head h2 .grad,.grad{
	background:var(--gradient); -webkit-background-clip:text; background-clip:text; color:transparent;
}
.section-head p{color:var(--muted); font-size:1.05rem}

/* ---- Inline SVG icons ---- */
.icon{
	width:1em; height:1em; flex:none; display:inline-block; vertical-align:-.125em;
	fill:none; stroke:currentColor; stroke-width:1.9; stroke-linecap:round; stroke-linejoin:round;
}

/* ---- Buttons ---- */
.btn{
	display:inline-flex; align-items:center; gap:.55rem; font-weight:600; font-size:.95rem;
	padding:.85rem 1.5rem; border-radius:999px; cursor:pointer; border:1px solid transparent;
	transition:transform .18s ease, box-shadow .18s ease, background .2s, color .2s, border-color .2s;
}
.btn .icon{font-size:1.05em}
.btn-primary{background:var(--gradient); color:var(--on-accent); box-shadow:0 10px 26px rgba(34,211,238,.30)}
.btn-primary:hover{transform:translateY(-2px); box-shadow:0 16px 36px rgba(34,211,238,.42)}
.btn-ghost{background:transparent; color:var(--text); border-color:var(--border)}
.btn-ghost:hover{border-color:var(--accent); color:var(--accent)}

/* ----------------------------- Header ---------------------------- */
/* The block template-part wraps <header> in a div that's only as tall as the
   header, which would trap position:sticky. display:contents removes that wrapper
   from layout so the header sticks against the page scroll. */
.wp-block-template-part{display:contents}

header.site{
	position:fixed; top:0; left:0; right:0; z-index:50;
	/* Subtle top scrim at rest so the nav reads cleanly over the banner (premium),
	   instead of floating on a transparent strip. Swaps to glass on scroll. */
	background:linear-gradient(to bottom, rgba(11,15,25,.72), rgba(11,15,25,0));
	border-bottom:1px solid transparent;
	transition:background .3s ease, border-color .3s ease, box-shadow .3s ease;
}
/* The WordPress admin bar (only visible to logged-in users) is also fixed at top:0;
   offset our fixed header so they don't overlap. Visitors never see this. */
body.admin-bar header.site{ top:32px; }
@media screen and (max-width:782px){ body.admin-bar header.site{ top:46px; } }
header.site.scrolled{
	background:rgba(13,19,34,.82);
	-webkit-backdrop-filter:saturate(140%) blur(12px);
	backdrop-filter:saturate(140%) blur(12px);
	border-bottom-color:var(--border);
	box-shadow:0 10px 30px rgba(0,0,0,.38);
}
.nav{display:flex; align-items:center; justify-content:space-between; height:var(--header-h)}
.brand{display:flex; align-items:center; gap:.6rem}
.brand-logo{height:64px; width:auto}
.menu{display:flex; gap:2rem; font-weight:500; font-size:.95rem}
.menu a{color:var(--hero-muted); transition:.18s; position:relative; padding:.25rem 0}
.menu a:hover{color:var(--text)}
.menu a::after{content:""; position:absolute; left:0; bottom:-4px; height:2px; width:0; background:var(--gradient); transition:.25s}
.menu a:hover::after,.menu a.active::after{width:100%}
.menu a.active{color:var(--text)}
.nav-cta{display:flex; align-items:center; gap:1rem}
.menu-toggle{
	display:none; background:transparent; border:1px solid var(--border); color:var(--text);
	width:44px; height:44px; border-radius:12px; cursor:pointer; align-items:center; justify-content:center;
}
.menu-toggle .icon{font-size:1.4rem}

/* ----------------------------- Hero ------------------------------ */
.hero{position:relative; overflow:hidden; background:var(--hero-bg); color:var(--hero-text)}
.hero .container{position:relative; z-index:2; display:grid; grid-template-columns:1.1fr .9fr; gap:3rem; align-items:center;
	padding:calc(var(--header-h) + clamp(48px,8vw,96px)) 0 clamp(60px,9vw,110px)}
.hero h1{font-size:clamp(2.3rem,5vw,4rem); margin:1rem 0 1.2rem}
.hero p.lead{font-size:1.15rem; color:var(--hero-muted); max-width:46ch; margin-bottom:2rem}
.hero .actions{display:flex; gap:1rem; flex-wrap:wrap}
/* ---- Hero "AI growth engine" — transparent animated stage ---- */
.hero-visual{position:relative; aspect-ratio:1/1; width:100%; max-width:480px; margin-inline:auto;
	background:transparent; box-shadow:none; overflow:visible}
.ai-stage{position:absolute; inset:0}
.ai-stage .layer{position:absolute; inset:0; will-change:transform; transition:transform .25s ease-out}

/* depth orbs */
.orb{position:absolute; border-radius:50%; filter:blur(34px); opacity:.55}
.orb-1{width:52%; height:52%; left:2%; top:-2%;
	background:radial-gradient(circle, rgba(34,211,238,.55), transparent 70%); animation:cmh-drift 9s ease-in-out infinite}
.orb-2{width:58%; height:58%; right:-2%; bottom:0;
	background:radial-gradient(circle, rgba(129,140,248,.5), transparent 70%); animation:cmh-drift 11s ease-in-out infinite reverse}

/* self-drawing growth chart */
.growth-chart{position:absolute; left:8%; bottom:7%; width:84%; height:46%; overflow:visible}
.chart-line{stroke-dasharray:400; stroke-dashoffset:400; vector-effect:non-scaling-stroke;
	filter:drop-shadow(0 0 6px rgba(34,211,238,.5)); animation:cmh-draw 2.6s ease-out .3s forwards}
/* A bright light segment that travels along the same line, on top of it. */
.chart-pulse{fill:none; stroke:#ffffff; stroke-width:3.5; stroke-linecap:round; vector-effect:non-scaling-stroke;
	stroke-dasharray:8 200; opacity:0; filter:drop-shadow(0 0 5px #22d3ee) drop-shadow(0 0 9px #22d3ee);
	animation:cmh-run 4.6s linear 3s infinite}
.chart-area{opacity:0; animation:cmh-fade 1.4s ease-out 1.6s forwards}

/* lead-flow connection lines */
.links{position:absolute; inset:0; width:100%; height:100%; overflow:visible}
.links line{stroke:rgba(34,211,238,.4); stroke-width:1.4; stroke-dasharray:2 4;
	vector-effect:non-scaling-stroke; animation:cmh-flow 1.6s linear infinite}
.links line:nth-child(2){animation-duration:2s}
.links line:nth-child(3){animation-duration:1.3s}
.links line:nth-child(4){animation-duration:2.3s}

/* AI core */
.ai-core{position:absolute; left:50%; top:50%; width:120px; height:120px; transform:translate(-50%,-50%);
	display:grid; place-items:center}
.core-ring{position:absolute; inset:0; border-radius:50%; border:1.5px dashed rgba(34,211,238,.55);
	animation:cmh-spin 16s linear infinite}
.core-pulse{position:absolute; inset:16%; border-radius:50%;
	background:radial-gradient(circle, rgba(34,211,238,.4), transparent 70%); animation:cmh-pulse 2.8s ease-in-out infinite}
.core-dot{position:relative; width:56px; height:56px; border-radius:17px; display:grid; place-items:center;
	background:linear-gradient(135deg,#22d3ee,#818cf8); color:#06121a; box-shadow:0 12px 30px rgba(34,211,238,.45)}
.core-dot .icon{font-size:28px; stroke-width:2}
.core-label{position:absolute; bottom:-24px; left:50%; transform:translateX(-50%); white-space:nowrap;
	font-size:11px; font-weight:600; letter-spacing:.14em; text-transform:uppercase; color:#22d3ee}

/* platform chips + output stats (positioned at the line endpoints) */
.chip,.stat{position:absolute; display:inline-flex; align-items:center; gap:.4rem;
	font-size:.8rem; font-weight:600; transform:translate(-50%,-50%); white-space:nowrap;
	box-shadow:0 8px 22px rgba(0,0,0,.38); backdrop-filter:blur(6px)}
.chip{padding:.46rem .8rem; border-radius:999px; background:rgba(18,26,43,.85); border:1px solid var(--border);
	color:#e7ecf5; transition:border-color .2s ease, box-shadow .2s ease}
.chip .icon{color:#22d3ee; font-size:1rem}
.chip .brand{width:17px; height:17px; display:block; flex:none}
.chip:hover{border-color:#22d3ee; box-shadow:0 12px 30px rgba(34,211,238,.35)}
.stat{padding:.42rem .72rem; border-radius:12px; background:rgba(18,26,43,.9); border:1px solid var(--border); color:#cbd5e1}
.stat .icon{color:#22d3ee} .stat b{color:#22d3ee}
.chip-1{left:20%; top:20%; animation:cmh-float-c 6s ease-in-out infinite}
.chip-2{left:80%; top:24%; animation:cmh-float-c 7s ease-in-out infinite .4s}
.chip-3{left:16%; top:74%; animation:cmh-float-c 6.5s ease-in-out infinite .8s}
.chip-4{left:84%; top:62%; animation:cmh-float-c 7.5s ease-in-out infinite .2s}
.stat-1{left:9%; top:50%; animation:cmh-float-c 5.6s ease-in-out infinite .3s}
.stat-2{left:62%; top:90%; animation:cmh-float-c 6.2s ease-in-out infinite .6s}

/* A — detail window that deploys on hover (anchored toward the stage centre so
   it never overflows outward) */
.chip-pop{position:absolute; width:max-content; max-width:178px; padding:.6rem .75rem; border-radius:12px;
	background:rgba(13,19,34,.96); border:1px solid #243049; box-shadow:0 18px 44px rgba(0,0,0,.55);
	text-align:left; white-space:normal; line-height:1.3; opacity:0; visibility:hidden; pointer-events:none; z-index:6;
	transition:opacity .22s ease, transform .24s cubic-bezier(.2,.8,.2,1), visibility .24s}
.chip-pop .pop-t{display:block; color:#fff; font-size:.78rem; font-weight:700}
.chip-pop .pop-d{display:block; margin-top:.25rem; color:#9fb0c9; font-size:.7rem; font-weight:500}
.chip-1 .chip-pop{top:calc(100% + 10px); left:0; transform-origin:top left; transform:translateY(8px) scale(.9)}
.chip-2 .chip-pop{top:calc(100% + 10px); right:0; transform-origin:top right; transform:translateY(8px) scale(.9)}
.chip-3 .chip-pop{bottom:calc(100% + 10px); left:0; transform-origin:bottom left; transform:translateY(-8px) scale(.9)}
.chip-4 .chip-pop{bottom:calc(100% + 10px); right:0; transform-origin:bottom right; transform:translateY(-8px) scale(.9)}
.chip:hover{animation-play-state:paused; z-index:7}
.chip:hover .chip-pop{opacity:1; visibility:visible; transform:translateY(0) scale(1)}

/* B — engine reacts: hovered platform's flow line lights up + core/stats respond */
.core-dot{transition:transform .25s ease, box-shadow .25s ease}
.engine-on .links line{stroke-opacity:.7}
.links line.lit{stroke:#22d3ee; stroke-width:2.4; animation-duration:.7s; filter:drop-shadow(0 0 4px rgba(34,211,238,.85))}
.engine-on .core-ring{border-color:rgba(34,211,238,.95)}
.engine-on .core-dot{transform:scale(1.07); box-shadow:0 16px 44px rgba(34,211,238,.7)}
.engine-on .stat{border-color:#22d3ee; box-shadow:0 12px 30px rgba(34,211,238,.4)}
.engine-on .stat .icon,.engine-on .stat b{filter:drop-shadow(0 0 5px rgba(34,211,238,.8))}

@keyframes cmh-spin{to{transform:rotate(360deg)}}
@keyframes cmh-pulse{0%,100%{transform:scale(.85);opacity:.5}50%{transform:scale(1.15);opacity:.95}}
@keyframes cmh-float-c{0%,100%{transform:translate(-50%,-50%)}50%{transform:translate(-50%,calc(-50% - 9px))}}
@keyframes cmh-drift{0%,100%{transform:translate(0,0)}50%{transform:translate(10px,-8px)}}
@keyframes cmh-flow{to{stroke-dashoffset:-18}}
@keyframes cmh-draw{to{stroke-dashoffset:0}}
@keyframes cmh-fade{to{opacity:1}}
@keyframes cmh-run{
	0%{stroke-dashoffset:0; opacity:1}
	61%{stroke-dashoffset:-100; opacity:1}
	61.5%{opacity:0}
	100%{stroke-dashoffset:-100; opacity:0}
}

@media(prefers-reduced-motion:reduce){
	.ai-stage *{animation:none !important}
	.chart-line{stroke-dashoffset:0}
	.chart-area{opacity:1}
}

/* --------------------------- Stat bar ---------------------------- */
.stats{position:relative; z-index:5; margin-top:-40px}
.stats .grid{display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--border);
	border:1px solid var(--border); border-radius:20px; overflow:hidden; box-shadow:var(--card-shadow)}
.stat{background:var(--surface); padding:1.6rem 1.2rem; text-align:center}
.stat .num{font-family:'Space Grotesk'; font-size:2rem; font-weight:700; color:var(--accent)}
.stat .lbl{color:var(--muted); font-size:.9rem}

/* --------------------------- Services ---------------------------- */
.services{background:var(--bg-alt)}
.cards{display:grid; grid-template-columns:repeat(4,1fr); gap:1.2rem}
.card{
	background:var(--surface); border:1px solid var(--border); border-radius:18px; padding:1.7rem 1.5rem;
	box-shadow:var(--card-shadow); transition:transform .2s ease, box-shadow .2s ease, border-color .2s;
	position:relative; overflow:hidden;
}
.card::before{content:""; position:absolute; inset:0 0 auto 0; height:3px; background:var(--gradient);
	transform:scaleX(0); transform-origin:left; transition:.3s}
.card:hover{transform:translateY(-6px); box-shadow:var(--card-shadow-hover); border-color:transparent}
.card:hover::before{transform:scaleX(1)}
.card .ico{
	width:54px; height:54px; border-radius:14px; display:grid; place-items:center; font-size:1.5rem;
	color:var(--accent); background:rgba(34,211,238,.12); margin-bottom:1.1rem;
}
.card .ico .brand-ico{width:26px; height:26px; display:block}
.card h3{font-size:1.12rem; margin-bottom:.5rem; color:#fff}
.card p{color:var(--muted); font-size:.92rem}

/* ------------------------- AI band ------------------------------- */
.ai-band{background:var(--bg)}
.ai-inner{
	max-width:1000px; margin:0 auto; text-align:center;
	background:linear-gradient(160deg, rgba(34,211,238,.08), rgba(129,140,248,.06));
	border:1px solid var(--border); border-radius:20px; padding:clamp(2rem,5vw,2.8rem);
	position:relative; overflow:hidden;
}
.ai-inner::before{content:""; position:absolute; top:0; left:0; right:0; height:2px; background:var(--gradient)}
.ai-inner h3{font-size:clamp(1.3rem,3vw,1.7rem); color:#fff; margin:.8rem 0 1.4rem}
.ai-points{display:flex; flex-wrap:wrap; gap:1rem 1.9rem; justify-content:center}
.ai-points li{display:inline-flex; align-items:center; gap:.55rem; color:#cbd5e1; font-size:.98rem; font-weight:500}
.ai-points .icon{color:var(--accent)}

/* ---------------------------- About ------------------------------ */
.about .grid{display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,5vw,4rem); align-items:center}
.about h2{font-size:clamp(1.7rem,3.4vw,2.5rem); margin:.6rem 0 1rem; color:#fff}
.about p{color:var(--muted); margin-bottom:1.4rem}
.bars{display:grid; gap:1.1rem; margin:1.5rem 0 2rem}
.bar .top{display:flex; justify-content:space-between; font-weight:600; font-size:.9rem; margin-bottom:.4rem}
.bar .track{height:9px; border-radius:999px; background:var(--border); overflow:hidden}
.bar .fill{display:block; height:100%; width:0; border-radius:999px; background:var(--gradient);
	transition:width 1.1s cubic-bezier(.22,1,.36,1)}
.about-visual{
	width:100%; background:linear-gradient(160deg, rgba(34,211,238,.10), rgba(129,140,248,.07));
	border:1px solid var(--border); border-radius:20px; padding:clamp(28px,4vw,40px); position:relative; overflow:hidden;
}
.about-visual::before{content:""; position:absolute; inset:0; pointer-events:none;
	background:radial-gradient(620px 300px at 18% -10%, rgba(34,211,238,.14), transparent 60%)}
.about-visual .av-title{font-size:1.5rem; color:#fff; margin:0 0 1.4rem; position:relative}
.av-list{display:grid; gap:.9rem; position:relative}
.av-list li{display:flex; align-items:center; gap:.75rem; color:#cbd5e1; font-weight:500}
.av-list .icon{flex:none; width:30px; height:30px; border-radius:9px; padding:6px;
	background:rgba(34,211,238,.14); color:var(--accent)}

/* -------------------------- Expertise ---------------------------- */
.expertise{background:var(--bg-alt)}
.tabs{display:flex; gap:.6rem; justify-content:center; flex-wrap:wrap; margin-bottom:2.2rem}
.tab{
	font:inherit; font-weight:600; cursor:pointer; padding:.7rem 1.3rem; border-radius:999px;
	border:1px solid var(--border); background:var(--surface); color:var(--muted); transition:.2s;
}
.tab:hover{color:var(--text)}
.tab.active{background:var(--gradient); color:var(--on-accent); border-color:transparent; box-shadow:0 8px 22px rgba(34,211,238,.28)}
.panel{display:none; max-width:760px; margin:0 auto; text-align:center}
.panel.active{display:block; animation:fade .4s ease}
.panel .lead-ico{font-size:2.2rem; color:var(--accent); margin-bottom:1rem}
.panel h3{font-size:1.5rem; margin-bottom:.7rem; color:#fff}
.panel p{color:var(--muted); font-size:1.05rem}
@keyframes fade{from{opacity:0; transform:translateY(8px)}to{opacity:1; transform:none}}

/* ---------------------------- Contact ---------------------------- */
.contact{background:var(--bg)}
.contact-box{
	max-width:760px; margin:0 auto; background:var(--surface); border:1px solid var(--border);
	border-radius:24px; padding:clamp(1.4rem,3vw,2rem); box-shadow:var(--card-shadow);
}
/* Let GHL's form_embed.js size the iframe to its own content — impose no height
   on our side (a fixed/min height is what forces the internal scrollbar). */
.contact-box iframe{width:100%; border:none; border-radius:12px; display:block}

/* Native contact form */
.cmh-form .form-grid{display:grid; grid-template-columns:1fr 1fr; gap:1rem 1.1rem}
.cmh-form .field{display:flex; flex-direction:column; gap:.4rem; text-align:left}
.cmh-form .field-full{grid-column:1 / -1}
.cmh-form label{font-size:.8rem; font-weight:600; color:#cbd5e1}
.cmh-form input,.cmh-form select,.cmh-form textarea{
	width:100%; padding:.8rem .9rem; border-radius:12px; background:#0d1322;
	border:1px solid var(--border); color:#e7ecf5; font:inherit; font-size:.95rem;
	transition:border-color .2s ease, box-shadow .2s ease, background .2s ease;
}
.cmh-form input::placeholder,.cmh-form textarea::placeholder{color:#5b6678}
.cmh-form input:focus,.cmh-form select:focus,.cmh-form textarea:focus{
	outline:none; border-color:var(--accent); box-shadow:0 0 0 3px rgba(34,211,238,.18); background:#0f1525;
}
.cmh-form textarea{resize:vertical; min-height:120px}
.cmh-form select{
	appearance:none; -webkit-appearance:none; cursor:pointer; padding-right:2.2rem;
	background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='none' stroke='%2394a3b8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M4 6l4 4 4-4'/%3E%3C/svg%3E");
	background-repeat:no-repeat; background-position:right .9rem center;
}
.cmh-form select option{background:#0d1322; color:#e7ecf5}
.cf-hp{position:absolute; left:-9999px; width:1px; height:1px; overflow:hidden}
.cmh-form .form-actions{display:flex; align-items:center; gap:1.1rem; margin-top:1.3rem; flex-wrap:wrap}
.cmh-form .form-note{color:#94a3b8; font-size:.82rem; margin:0}
.cmh-form .field.invalid input,.cmh-form .field.invalid select,.cmh-form .field.invalid textarea{
	border-color:#f87171; box-shadow:0 0 0 3px rgba(248,113,113,.15);
}
.form-status{margin:1rem 0 0; font-size:.9rem; font-weight:600; display:none}
.form-status.ok{display:block; color:#34d399}
.form-status.err{display:block; color:#f87171}
@media(max-width:560px){.cmh-form .form-grid{grid-template-columns:1fr}}

/* ---------------------------- Footer ----------------------------- */
footer.site{background:var(--footer-bg); color:var(--footer-text); padding:clamp(40px,6vw,64px) 0 26px}
.fgrid{display:flex; flex-wrap:wrap; gap:1.5rem 2rem; align-items:center; justify-content:space-between; margin-bottom:2rem}
footer .brand-logo{height:100px}
.fmenu{display:flex; flex-wrap:wrap; gap:1.2rem 1.6rem; font-size:.92rem}
.fmenu a:hover{color:#fff}
.copy{border-top:1px solid rgba(255,255,255,.10); padding-top:1.4rem; text-align:center; font-size:.85rem; opacity:.85}

/* --------------------- Standalone (legal) pages ------------------ */
.page-shell{padding:clamp(90px,12vw,140px) 0 clamp(56px,8vw,90px)}
.page-shell .container{width:min(820px,92%)}
.page-shell h1{font-size:clamp(2rem,4vw,3rem); color:#fff; margin-bottom:1.5rem}
.page-shell .entry{color:#cbd5e1}
.page-shell .entry h2{color:#fff; margin:2rem 0 .8rem}
.page-shell .entry h3{color:#fff; margin:1.4rem 0 .6rem}
.page-shell .entry p,.page-shell .entry li{color:#cbd5e1; margin-bottom:1rem}
.page-shell .entry a{color:var(--accent)}
.page-shell .entry ul{list-style:disc; padding-left:1.4rem}
/* Let embedded forms (GoHighLevel iframes) span full width and expand to their
   own height — WordPress shouldn't box them in. form_embed.js sets the height. */
.page-shell .entry iframe{width:100%; border:0; display:block}

/* --------------------------- Reveal ------------------------------ */
.reveal{opacity:0; transform:translateY(22px); transition:opacity .6s ease, transform .6s ease}
.reveal.in{opacity:1; transform:none}
@media(prefers-reduced-motion:reduce){
	html{scroll-behavior:auto}
	.reveal{opacity:1; transform:none; transition:none}
}

/* ------------------------- Responsive ---------------------------- */
@media(max-width:980px){
	.hero .container{grid-template-columns:1fr; gap:2.5rem}
	.hero-visual{max-width:420px}
	.cards{grid-template-columns:repeat(2,1fr)}
	.stats .grid{grid-template-columns:repeat(2,1fr)}
	.about .grid{grid-template-columns:1fr}
}
@media(max-width:760px){
	.menu-toggle{display:inline-flex}
	.nav-cta .btn{display:none}
	.menu{
		position:absolute; top:var(--header-h); left:0; right:0; flex-direction:column; gap:0;
		background:rgba(13,19,34,.97); backdrop-filter:blur(12px);
		padding:0 6%; max-height:0; overflow:hidden; border-top:1px solid transparent;
		opacity:0; visibility:hidden;
		transition:max-height .3s ease, opacity .25s ease, visibility .3s, padding .3s ease;
	}
	.menu.open{max-height:70vh; opacity:1; visibility:visible; padding:.5rem 6%; border-top-color:var(--border)}
	.menu a{padding:.9rem 0; border-bottom:1px solid var(--border)}
	.menu a::after{display:none}
}
@media(max-width:560px){
	.cards{grid-template-columns:1fr}
	/* Compact the hero AI scene so nothing clips on small screens. */
	.hero-visual{max-width:340px}
	.chip{font-size:.72rem; padding:.4rem .6rem}
	.chip .brand{width:15px; height:15px}
	.stat{font-size:.7rem; padding:.36rem .55rem}
	.ai-core{width:96px; height:96px}
	.core-dot{width:46px; height:46px}
	.core-dot .icon{font-size:22px}
	.core-label{bottom:-20px; font-size:10px}
	.chip-1{left:24%; top:17%} .chip-2{left:76%; top:21%}
	.chip-3{left:22%; top:75%} .chip-4{left:78%; top:63%}
	.stat-1{left:17%; top:47%} .stat-2{left:57%; top:89%}
}
