:root {
	--black: #05070a;
	--black-2: #090d12;
	--panel: #0d1219;
	--panel-2: #111822;
	--white: #f7f9fc;
	--muted: #9ba6b4;
	--blue: #168bff;
	--blue-bright: #4aa7ff;
	--line: rgba(255,255,255,.1);
	--glass: rgba(14,20,28,.76);
	--shell: min(1220px, calc(100% - 48px));
	--radius: 22px;
	--shadow-blue: 0 24px 80px rgba(22,139,255,.16);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; scroll-padding-top: 80px; }
body { margin: 0; background: var(--black); color: var(--white); font-family: Inter, "Helvetica Neue", Arial, sans-serif; font-size: 16px; line-height: 1.65; -webkit-font-smoothing: antialiased; }
img { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button, input, select, textarea { font: inherit; }
button, a, summary, input, select, textarea { outline-offset: 4px; }
:focus-visible { outline: 2px solid var(--blue-bright); }
.shell { width: var(--shell); margin-inline: auto; }
.screen-reader-text, .honeypot { position: absolute !important; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }
.skip-link { position: fixed; z-index: 999; left: 16px; top: -100px; padding: 10px 16px; background: var(--blue); color: #fff; }
.skip-link:focus { top: 16px; }

.site-header { position: fixed; z-index: 100; top: 0; left: 0; width: 100%; border-bottom: 1px solid transparent; transition: .3s ease; }
.site-header.is-scrolled, body:not(.home) .site-header { background: rgba(5,7,10,.84); border-color: var(--line); backdrop-filter: blur(18px); }
.nav-wrap { display: flex; align-items: center; justify-content: space-between; min-height: 82px; }
.brand { display: inline-flex; align-items: center; gap: 12px; }
.brand-mark { display: grid; place-items: center; width: 46px; height: 46px; background: var(--blue); color: #fff; border-radius: 8px 18px 8px 8px; box-shadow: 0 0 30px rgba(22,139,255,.38); font-size: 13px; font-weight: 900; letter-spacing: -.04em; }
.brand-copy { display: flex; flex-direction: column; line-height: 1.05; }
.brand-copy strong { font-size: 14px; letter-spacing: .15em; }
.brand-copy small { margin-top: 6px; color: #7f8b9b; font-size: 8px; letter-spacing: .16em; text-transform: uppercase; }
.custom-logo { width: auto; max-height: 54px; }
.primary-nav { display: flex; align-items: center; gap: 25px; }
.primary-nav a { color: #c7ced7; font-size: 12px; font-weight: 700; }
.primary-nav a:hover { color: #fff; }
.primary-nav .nav-cta { padding: 11px 17px; background: var(--blue); color: #fff; border-radius: 5px; box-shadow: 0 8px 30px rgba(22,139,255,.22); }
.nav-toggle { display: none; padding: 10px; background: none; border: 0; }

.section { position: relative; padding: 125px 0; overflow: clip; }
.section-heading { max-width: 800px; margin-bottom: 64px; }
.section-heading > p:last-child, .heading-wide > p:last-child { max-width: 680px; color: var(--muted); }
.heading-wide { display: grid; grid-template-columns: 1.4fr .6fr; gap: 36px 70px; align-items: end; margin-bottom: 65px; }
.heading-wide .eyebrow { grid-column: 1 / -1; }
.eyebrow { display: flex; align-items: center; gap: 13px; margin: 0 0 20px; color: var(--blue-bright); font-size: 10px; font-weight: 800; letter-spacing: .18em; text-transform: uppercase; }
.eyebrow > span:first-child { display: grid; place-items: center; width: 29px; height: 29px; border: 1px solid rgba(74,167,255,.45); border-radius: 50%; font-size: 8px; }
h1, h2, h3 { margin-top: 0; font-weight: 750; line-height: .98; letter-spacing: -.05em; }
h1 { margin-bottom: 20px; font-size: clamp(60px, 7.7vw, 112px); }
h2 { margin-bottom: 28px; font-size: clamp(48px, 6vw, 82px); }
h3 { font-size: 24px; line-height: 1.15; }
h1 em, h2 em { color: transparent; font-style: normal; -webkit-text-stroke: 1px var(--blue-bright); text-shadow: 0 0 35px rgba(22,139,255,.18); }
.lead { font-size: 20px; color: #d9dee6; }
.button-row { display: flex; flex-wrap: wrap; gap: 14px; }
.button { display: inline-flex; align-items: center; justify-content: center; gap: 25px; min-height: 58px; padding: 0 23px; border: 1px solid transparent; border-radius: 5px; color: #fff; font-size: 12px; font-weight: 800; letter-spacing: .03em; cursor: pointer; transition: .25s ease; }
.button:hover { transform: translateY(-2px); box-shadow: 0 15px 40px rgba(22,139,255,.2); }
.button-blue { background: var(--blue); }
.button-ghost { background: rgba(255,255,255,.03); border-color: var(--line); backdrop-filter: blur(10px); }
.button-full { width: 100%; }
.text-link { display: inline-flex; gap: 25px; align-items: center; padding-bottom: 5px; border-bottom: 1px solid rgba(74,167,255,.45); color: #fff; font-size: 12px; font-weight: 800; }

.hero { display: flex; align-items: center; min-height: 940px; padding: 160px 0 100px; background: #040609; }
.hero-photo { position: absolute; inset: 0; }
.hero-photo::after { content: ""; position: absolute; inset: 0; background: linear-gradient(90deg, #040609 3%, rgba(4,6,9,.94) 35%, rgba(4,6,9,.32) 71%, rgba(4,6,9,.63) 100%), linear-gradient(0deg, #040609 0%, transparent 40%); }
.hero-photo img { width: 100%; height: 100%; object-fit: cover; object-position: center; opacity: .88; }
.hero-grid { position: absolute; inset: 0; opacity: .18; background-image: linear-gradient(rgba(255,255,255,.07) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.07) 1px, transparent 1px); background-size: 70px 70px; mask-image: linear-gradient(90deg, #000, transparent 66%); }
.hero-content { position: relative; z-index: 2; }
.hero-content > * { max-width: 720px; }
.hero-subtitle { margin: 0 0 10px; color: #fff; font-size: 22px; font-weight: 700; }
.hero-text { margin: 0 0 34px; color: #aeb7c2; font-size: 16px; }
.trust-line { margin: 27px 0 0; color: #778493; font-size: 10px; letter-spacing: .06em; text-transform: uppercase; }
.scroll-cue { position: absolute; z-index: 3; right: 35px; bottom: 48px; display: flex; align-items: center; gap: 13px; color: #6e7987; font-size: 8px; letter-spacing: .22em; text-transform: uppercase; transform: rotate(90deg); }
.scroll-cue i { width: 50px; height: 1px; background: var(--blue); }

.scene-3d { position: fixed; z-index: 1; right: -80px; top: 38vh; width: 420px; height: 420px; pointer-events: none; perspective: 900px; opacity: 0; transition: opacity .5s; }
.scene-3d.is-visible { opacity: .25; }
.dumbbell-3d { position: absolute; inset: 50%; width: 300px; height: 90px; transform-style: preserve-3d; transform: translate(-50%,-50%) rotateX(58deg) rotateY(var(--db-y, 0deg)) rotateZ(var(--db-z, -24deg)); filter: drop-shadow(0 20px 30px rgba(22,139,255,.25)); }
.db-bar { position: absolute; left: 52px; top: 35px; width: 196px; height: 20px; border-radius: 20px; background: linear-gradient(#53616f, #171e26 48%, #718092); box-shadow: inset 0 2px 3px rgba(255,255,255,.35); }
.db-weight { position: absolute; top: 9px; width: 28px; height: 72px; border-radius: 7px; background: linear-gradient(90deg,#050608,#303a46 48%,#090c10); border: 1px solid #46525f; box-shadow: inset 0 0 12px #000, 0 0 12px rgba(22,139,255,.2); }
.db-weight::after { content: ""; position: absolute; inset: 6px; border: 1px solid rgba(74,167,255,.5); border-radius: 4px; }
.db-weight-a { left: 25px; height: 88px; top: 1px; }
.db-weight-b { left: 55px; }
.db-weight-c { right: 55px; }
.db-weight-d { right: 25px; height: 88px; top: 1px; }

.problem { background: var(--black-2); }
.problem-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 14px; }
.glass-card { min-height: 260px; padding: 28px; background: linear-gradient(145deg,rgba(255,255,255,.055),rgba(255,255,255,.015)); border: 1px solid var(--line); border-radius: var(--radius); }
.glass-card > span { color: var(--blue); font-family: monospace; font-size: 11px; }
.glass-card h3 { margin: 65px 0 16px; }
.glass-card p { margin: 0; color: var(--muted); font-size: 13px; }
.positioning { display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: 30px; margin-top: 40px; padding: 30px; border: 1px solid rgba(22,139,255,.28); border-radius: var(--radius); background: rgba(22,139,255,.05); }
.positioning-mark { display: grid; place-items: center; width: 55px; height: 55px; background: var(--blue); border-radius: 50%; font-size: 12px; font-weight: 900; }
.positioning p { margin: 0; color: #c4ccd6; }

.coaching { background: #06090d; }
.package-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 16px; }
.package-card { position: relative; display: flex; flex-direction: column; min-height: 720px; padding: 34px; background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius); }
.package-popular, .package-complete { border-color: rgba(22,139,255,.55); box-shadow: var(--shadow-blue); }
.package-complete { background: linear-gradient(155deg,#101b28,#0b1017 70%); }
.package-badge { position: absolute; right: 20px; top: 0; padding: 8px 12px; background: var(--blue); border-radius: 0 0 7px 7px; font-size: 9px; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; }
.package-top { display: flex; justify-content: space-between; align-items: center; margin-bottom: 65px; }
.package-number { color: var(--blue); font-family: monospace; }
.package-mode { padding: 5px 9px; border: 1px solid var(--line); border-radius: 99px; color: #8e9aa9; font-size: 9px; text-transform: uppercase; }
.package-card h3 { margin-bottom: 13px; font-size: 29px; }
.package-subtitle { min-height: 48px; color: #dbe1e8 !important; font-weight: 700; }
.package-card > p { color: var(--muted); font-size: 13px; }
.feature-list { margin: 24px 0; padding: 0; list-style: none; color: #c6ced8; font-size: 12px; }
.feature-list li { margin: 10px 0; }
.feature-list li::before { content: "↗"; margin-right: 9px; color: var(--blue); }
.package-price { margin-top: auto; color: #dbe1e8 !important; font-weight: 700; }
.nutrition-note { padding: 12px; border-left: 2px solid var(--blue); background: rgba(22,139,255,.06); font-size: 10px !important; }

.comparison { background: var(--black-2); }
.comparison-wrap { overflow-x: auto; border: 1px solid var(--line); border-radius: var(--radius); }
table { width: 100%; min-width: 780px; border-collapse: collapse; background: var(--panel); }
th, td { padding: 20px; border-bottom: 1px solid var(--line); text-align: center; font-size: 12px; }
th:first-child, td:first-child { text-align: left; }
th { color: #fff; background: rgba(255,255,255,.025); font-size: 10px; letter-spacing: .08em; text-transform: uppercase; }
th.recommended { color: var(--blue-bright); }
.yes { display: inline-grid; place-items: center; width: 24px; height: 24px; background: rgba(22,139,255,.15); color: var(--blue-bright); border-radius: 50%; }
.comparison-cta { display: flex; align-items: center; justify-content: space-between; gap: 30px; margin-top: 28px; }
.comparison-cta p { max-width: 650px; color: var(--muted); }

.analysis { background: radial-gradient(circle at 80% 50%,rgba(22,139,255,.08),transparent 35%),#05070a; }
.analysis-grid { display: grid; grid-template-columns: .8fr 1.2fr; align-items: center; gap: 90px; }
.analysis-copy > p:not(.eyebrow) { color: var(--muted); }
.tag-list { display: flex; flex-wrap: wrap; gap: 7px; padding: 0; list-style: none; }
.tag-list li { padding: 7px 10px; border: 1px solid var(--line); border-radius: 99px; color: #bdc6d1; font-size: 10px; }
.privacy-note { padding-left: 15px; border-left: 2px solid #354050; font-size: 11px; }
.dashboard { padding: 28px; background: linear-gradient(145deg,#101720,#070b10); border: 1px solid rgba(74,167,255,.25); border-radius: var(--radius); box-shadow: var(--shadow-blue); }
.dashboard-head { display: flex; align-items: center; justify-content: space-between; }
.dashboard-head div { display: flex; flex-direction: column; }
.dashboard-head span { color: #607083; font-size: 8px; letter-spacing: .16em; }
.dashboard-head strong { font-size: 16px; }
.live-dot { color: var(--blue-bright) !important; }
.live-dot::before { content: ""; display: inline-block; width: 6px; height: 6px; margin-right: 7px; background: var(--blue); border-radius: 50%; box-shadow: 0 0 10px var(--blue); }
.chart { position: relative; height: 250px; margin: 30px 0; overflow: hidden; }
.chart-grid { position: absolute; inset: 0; background-image: linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px); background-size: 50px 50px; }
.chart svg { position: relative; width: 100%; height: 100%; }
.chart-line { stroke-dasharray: 900; stroke-dashoffset: 900; transition: stroke-dashoffset 1.5s ease; }
.is-visible .chart-line { stroke-dashoffset: 0; }
.metric-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 10px; }
.metric-grid > div { padding: 14px; background: rgba(255,255,255,.03); border-radius: 8px; }
.metric-grid span, .metric-grid small { display: block; color: #677587; font-size: 8px; text-transform: uppercase; }
.metric-grid strong { display: block; margin: 6px 0; color: #fff; font-size: 21px; }

.process { background: var(--black-2); }
.process-list { border-top: 1px solid var(--line); }
.process-step { display: grid; grid-template-columns: 100px 1fr; padding: 32px 0; border-bottom: 1px solid var(--line); }
.process-step > span { color: var(--blue); font-family: monospace; }
.process-step div { display: grid; grid-template-columns: .8fr 1.2fr; gap: 35px; }
.process-step h3, .process-step p { margin: 0; }
.process-step p { color: var(--muted); font-size: 13px; }
.process-cta { margin-top: 40px; }

.benefits { background: #06090d; }
.benefit-grid { display: grid; grid-template-columns: repeat(3,1fr); border-top: 1px solid var(--line); border-left: 1px solid var(--line); }
.benefit-grid article { min-height: 250px; padding: 30px; border-right: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.benefit-grid span { color: var(--blue); font-family: monospace; font-size: 10px; }
.benefit-grid h3 { margin: 55px 0 14px; }
.benefit-grid p { color: var(--muted); font-size: 13px; }

.about { background: #05070a; }
.about-grid { display: grid; grid-template-columns: .85fr 1.15fr; align-items: center; gap: 90px; }
.about-media { position: relative; min-height: 700px; }
.about-media::before { content: ""; position: absolute; inset: 20px -20px -20px 20px; border: 1px solid rgba(22,139,255,.3); border-radius: var(--radius); }
.about-media img { position: absolute; z-index: 1; width: 100%; height: 100%; object-fit: cover; border-radius: var(--radius); filter: saturate(.8); }
.photo-label { position: absolute; z-index: 2; left: 20px; bottom: 20px; padding: 12px 16px; background: rgba(5,7,10,.85); border: 1px solid var(--line); border-radius: 6px; backdrop-filter: blur(12px); }
.photo-label span, .photo-label small { display: block; }
.photo-label span { color: var(--blue-bright); font-size: 9px; font-weight: 800; letter-spacing: .12em; }
.photo-label small { color: #8894a3; font-size: 8px; }
.about-copy > p:not(.eyebrow):not(.lead):not(.philosophy) { color: var(--muted); }
.trainer-facts { display: grid; grid-template-columns: 1fr 1fr; gap: 1px; margin: 28px 0; background: var(--line); border: 1px solid var(--line); }
.trainer-facts div { padding: 17px; background: var(--black); }
.trainer-facts small, .trainer-facts strong { display: block; }
.trainer-facts small { color: #687586; font-size: 8px; letter-spacing: .12em; text-transform: uppercase; }
.trainer-facts strong { margin-top: 5px; font-size: 12px; }
.philosophy { color: var(--blue-bright); font-size: 18px; font-style: italic; }

.expectations { background: linear-gradient(115deg,#0a1018,#080b10); }
.expectations-grid { display: grid; grid-template-columns: .9fr 1.1fr; gap: 90px; align-items: start; }
.expectation-list { border-top: 1px solid var(--line); }
.expectation-list > div { display: grid; grid-template-columns: 60px 1fr; padding: 21px 0; border-bottom: 1px solid var(--line); }
.expectation-list span { color: var(--blue); font-family: monospace; font-size: 10px; }
.expectation-list strong { font-size: 15px; }

.faq { background: #05070a; }
.faq-grid { display: grid; grid-template-columns: .75fr 1.25fr; gap: 100px; align-items: start; }
.faq-intro { position: sticky; top: 120px; }
.faq-intro > p:not(.eyebrow) { color: var(--muted); }
.accordion { border-top: 1px solid var(--line); }
.accordion details { border-bottom: 1px solid var(--line); }
.accordion summary { display: flex; justify-content: space-between; align-items: center; gap: 20px; padding: 25px 0; cursor: pointer; list-style: none; font-size: 15px; font-weight: 700; }
.accordion summary::-webkit-details-marker { display: none; }
.accordion summary i { color: var(--blue); font-size: 22px; font-style: normal; transition: .2s; }
.accordion details[open] summary i { transform: rotate(45deg); }
.accordion details p { margin: -5px 45px 25px 0; color: var(--muted); font-size: 13px; }

.contact { background: radial-gradient(circle at 50% 0,rgba(22,139,255,.13),transparent 30%),var(--black-2); }
.contact-heading { max-width: 780px; margin: 0 auto 60px; text-align: center; }
.contact-heading .eyebrow { justify-content: center; }
.contact-heading > p:last-child { color: var(--muted); }
.contact-card { width: min(900px,100%); margin: 0 auto; padding: 42px; background: rgba(11,16,23,.9); border: 1px solid rgba(74,167,255,.25); border-radius: var(--radius); box-shadow: var(--shadow-blue); }
fieldset { margin: 0 0 30px; padding: 0; border: 0; }
legend { width: 100%; margin-bottom: 18px; padding-bottom: 10px; border-bottom: 1px solid var(--line); color: var(--blue-bright); font-size: 10px; font-weight: 800; letter-spacing: .14em; text-transform: uppercase; }
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 15px; }
.contact-card label > span:first-child { display: block; margin-bottom: 6px; color: #c9d0d9; font-size: 10px; font-weight: 700; }
.contact-card input:not([type="checkbox"]), .contact-card select, .contact-card textarea { width: 100%; margin-bottom: 15px; padding: 13px 14px; background: #080c11; border: 1px solid #202a36; border-radius: 5px; color: #fff; }
.contact-card input:focus, .contact-card select:focus, .contact-card textarea:focus { border-color: var(--blue); box-shadow: 0 0 0 3px rgba(22,139,255,.12); }
.contact-card select { color-scheme: dark; }
.choice-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 8px; }
.choice-grid label { position: relative; cursor: pointer; }
.choice-grid input { position: absolute; opacity: 0; }
.choice-grid span { display: block !important; min-height: 44px; margin: 0 !important; padding: 12px !important; border: 1px solid #202a36; border-radius: 5px; font-size: 10px !important; text-align: center; }
.choice-grid input:checked + span { background: rgba(22,139,255,.14); border-color: var(--blue); color: #fff; }
.privacy-check { display: grid; grid-template-columns: 18px 1fr; gap: 10px; align-items: start; color: var(--muted); font-size: 10px; }
.privacy-check input { margin-top: 3px; accent-color: var(--blue); }
.privacy-check span { margin: 0 !important; font-size: inherit !important; font-weight: 400 !important; }
.privacy-link { margin: 2px 0 20px 28px; font-size: 10px; text-decoration: underline; }
.form-footnote { margin: 12px 0 0; color: #6d7887; font-size: 10px; text-align: center; }
.form-notice { margin-bottom: 25px; padding: 14px; border-radius: 5px; font-size: 12px; }
.form-notice.success { background: rgba(22,139,255,.13); border: 1px solid var(--blue); }
.form-notice.error { background: rgba(255,82,82,.12); border: 1px solid #ff5252; }

.final-cta { min-height: 720px; display: flex; align-items: center; text-align: center; background: radial-gradient(circle,rgba(22,139,255,.15),transparent 45%),#040609; }
.final-cta .shell { position: relative; z-index: 2; }
.final-cta .eyebrow { justify-content: center; }
.final-cta h2 { font-size: clamp(50px,7vw,95px); }
.final-cta p:not(.eyebrow) { max-width: 680px; margin: 0 auto 30px; color: var(--muted); }
.final-orbit { position: absolute; width: 650px; height: 650px; left: 50%; top: 50%; border: 1px solid rgba(22,139,255,.15); border-radius: 50%; transform: translate(-50%,-50%); box-shadow: 0 0 0 100px rgba(22,139,255,.025),0 0 0 200px rgba(22,139,255,.015); }

.site-footer { padding: 75px 0 24px; background: #020304; border-top: 1px solid var(--line); }
.footer-grid { display: grid; grid-template-columns: 1.5fr repeat(3,.7fr); gap: 50px; }
.footer-grid > div:first-child p { max-width: 360px; margin-top: 25px; color: #65717f; font-size: 11px; }
.footer-column { display: flex; flex-direction: column; gap: 8px; color: #727e8d; font-size: 11px; }
.footer-column > strong { margin-bottom: 10px; color: #fff; font-size: 9px; letter-spacing: .14em; text-transform: uppercase; }
.footer-column a:hover { color: var(--blue-bright); }
.footer-bottom { display: flex; justify-content: space-between; margin-top: 50px; padding-top: 20px; border-top: 1px solid var(--line); color: #4f5a67; font-size: 9px; letter-spacing: .08em; text-transform: uppercase; }
.portfolio-credit { color: #8190a2; transition: color .2s; }
.portfolio-credit:hover { color: var(--blue-bright); }
.mobile-cta { display: none; }
.portfolio-cta {
	position: fixed;
	z-index: 95;
	right: 20px;
	bottom: 20px;
	display: grid;
	grid-template-columns: 1fr auto;
	min-width: 270px;
	padding: 13px 15px 13px 17px;
	background: rgba(7,11,16,.9);
	border: 1px solid rgba(74,167,255,.55);
	border-radius: 10px;
	box-shadow: 0 18px 55px rgba(0,0,0,.45), 0 0 28px rgba(22,139,255,.12);
	backdrop-filter: blur(16px);
	transition: transform .2s, border-color .2s;
}
.portfolio-cta:hover { transform: translateY(-3px); border-color: var(--blue-bright); }
.portfolio-cta-kicker { grid-column: 1; color: var(--blue-bright); font-size: 8px; font-weight: 800; letter-spacing: .14em; text-transform: uppercase; }
.portfolio-cta strong { grid-column: 1; margin-top: 2px; color: #fff; font-size: 12px; letter-spacing: -.01em; }
.portfolio-cta-arrow { grid-column: 2; grid-row: 1 / 3; align-self: center; display: grid; place-items: center; width: 34px; height: 34px; margin-left: 18px; background: var(--blue); border-radius: 50%; color: #fff; }

.reveal { opacity: 0; transform: translateY(24px); transition: opacity .7s ease,transform .7s ease; }
.reveal.is-visible { opacity: 1; transform: none; }
.content-shell { width: min(840px,calc(100% - 40px)); margin: 0 auto; padding: 160px 0 100px; }
.content-shell h1 { font-size: clamp(50px,7vw,82px); }
.entry-content a { color: var(--blue-bright); text-decoration: underline; }
.post-card { margin-bottom: 18px; padding: 28px; background: var(--panel); border: 1px solid var(--line); border-radius: 12px; }
.post-card h2 { font-size: 30px; }

@media (max-width: 1060px) {
	:root { --shell: min(100% - 40px,820px); }
	.primary-nav { gap: 15px; }
	.primary-nav a:not(.nav-cta) { display: none; }
	.problem-grid { grid-template-columns: 1fr 1fr; }
	.package-grid { grid-template-columns: 1fr; }
	.package-card { min-height: auto; }
	.package-top { margin-bottom: 40px; }
	.analysis-grid, .about-grid, .expectations-grid, .faq-grid { grid-template-columns: 1fr; gap: 60px; }
	.about-media { min-height: 700px; max-width: 600px; }
	.faq-intro { position: static; }
	.scene-3d { right: -170px; }
}

@media (max-width: 720px) {
	:root { --shell: calc(100% - 30px); }
	html { scroll-padding-top: 70px; }
	.section { padding: 88px 0; }
	.nav-wrap { min-height: 70px; }
	.nav-toggle { display: grid; gap: 6px; }
	.nav-toggle > span:not(.screen-reader-text) { width: 25px; height: 1px; background: #fff; }
	.primary-nav { position: absolute; display: none; top: 70px; left: 0; width: 100%; max-height: calc(100vh - 70px); overflow: auto; padding: 24px 15px 30px; background: rgba(5,7,10,.97); border-top: 1px solid var(--line); flex-direction: column; align-items: stretch; gap: 0; }
	.primary-nav.is-open { display: flex; }
	.primary-nav a:not(.nav-cta) { display: block; padding: 12px; border-bottom: 1px solid var(--line); }
	.primary-nav .nav-cta { margin-top: 14px; text-align: center; }
	.hero { min-height: 920px; padding-top: 125px; align-items: flex-start; }
	.hero-photo::after { background: linear-gradient(180deg,rgba(4,6,9,.2),#040609 62%); }
	.hero-photo img { object-position: 65% top; height: 52%; }
	h1 { font-size: clamp(55px,16vw,76px); }
	h2 { font-size: clamp(43px,13vw,59px); }
	.hero-subtitle { font-size: 18px; }
	.hero-text { font-size: 14px; }
	.button-row { align-items: stretch; flex-direction: column; }
	.button { width: 100%; }
	.trust-line { line-height: 2; }
	.scroll-cue { display: none; }
	.heading-wide { grid-template-columns: 1fr; gap: 10px; }
	.problem-grid, .benefit-grid { grid-template-columns: 1fr; }
	.glass-card { min-height: 220px; }
	.positioning { grid-template-columns: 1fr; }
	.package-card { padding: 26px 20px; }
	.comparison-cta { align-items: stretch; flex-direction: column; }
	.analysis-grid { gap: 45px; }
	.dashboard { padding: 18px; }
	.chart { height: 200px; }
	.metric-grid { grid-template-columns: 1fr; }
	.process-step { grid-template-columns: 45px 1fr; }
	.process-step div { grid-template-columns: 1fr; gap: 10px; }
	.about-media { min-height: 520px; }
	.about-media::before { display: none; }
	.trainer-facts, .form-grid, .choice-grid { grid-template-columns: 1fr; }
	.contact-card { padding: 28px 18px; }
	.footer-grid { grid-template-columns: 1fr 1fr; }
	.footer-grid > div:first-child { grid-column: 1 / -1; }
	.final-cta { min-height: 650px; }
	.scene-3d { right: -230px; top: 52vh; transform: scale(.72); }
	.portfolio-cta { left: 15px; right: 15px; bottom: 12px; min-width: 0; }
	body { padding-bottom: 58px; }
}

@media (max-width: 430px) {
	.footer-grid { grid-template-columns: 1fr; }
	.footer-grid > div:first-child { grid-column: auto; }
	.footer-bottom { flex-direction: column; gap: 8px; }
	.brand-copy strong { font-size: 12px; }
}

@media (prefers-reduced-motion: reduce) {
	html { scroll-behavior: auto; }
	*,*::before,*::after { animation-duration: .01ms !important; animation-iteration-count: 1 !important; transition-duration: .01ms !important; }
	.reveal { opacity: 1; transform: none; }
	.scene-3d { display: none; }
	.chart-line { stroke-dashoffset: 0; }
}
