:root {
  --ink: #15121d;
  --ink-soft: #5d5769;
  --cream: #f8f1e7;
  --cream-2: #ede2d0;
  --night: #050713;
  --violet: #191331;
  --gold: #f0cc88;
  --gold-2: #c69146;
  --white: #fffaf0;
  --glass: rgba(19, 15, 42, .56);
  --shadow: 0 30px 90px rgba(0, 0, 0, .36);
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; min-width: 320px; font-family: Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif; color: var(--ink); background: var(--cream); overflow-x: hidden; }
body.calculation-open, body.report-open, body.legal-open { overflow: hidden; }
body.is-loaded .reveal { opacity: 1; transform: translateY(0); }
[hidden] { display: none !important; }
a { color: inherit; text-decoration: none; }
button, input { font: inherit; }
.global-bg { position: fixed; inset: 0; z-index: -10; background: #070816; }
.container { width: min(1370px, calc(100% - 64px)); margin: 0 auto; }
.reveal { opacity: 0; transform: translateY(18px); transition: opacity .9s ease, transform .9s ease; }
.glass { background: linear-gradient(145deg, rgba(38, 27, 66, .68), rgba(9, 9, 25, .52)); border: 1px solid rgba(255,255,255,.16); box-shadow: var(--shadow), inset 0 1px 0 rgba(255,255,255,.08); backdrop-filter: blur(24px); }

.site-header { position: fixed; top: 0; left: 50%; z-index: 60; transform: translateX(-50%); width: min(1430px, calc(100% - 56px)); height: 82px; display: flex; align-items: center; justify-content: space-between; color: #fff8eb; transition: .32s ease; }
.site-header.is-scrolled { top: 12px; height: 62px; padding: 0 18px; border: 1px solid rgba(255,255,255,.13); border-radius: 999px; background: rgba(7, 7, 22, .76); backdrop-filter: blur(22px); box-shadow: 0 18px 60px rgba(0,0,0,.25); }
.brand { display: inline-flex; align-items: center; gap: 14px; font-family: "Cormorant Garamond", Georgia, serif; font-size: 26px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; white-space: nowrap; }
.brand-mark { width: 42px; height: 42px; border: 1px solid rgba(240,204,136,.82); border-radius: 50%; position: relative; flex: 0 0 auto; }
.brand-mark::before, .brand-mark::after, .brand-mark i::before, .brand-mark i::after { content: ""; position: absolute; background: var(--gold); opacity: .88; }
.brand-mark::before { width: 1px; height: 58px; left: 50%; top: -8px; }
.brand-mark::after { height: 1px; width: 58px; left: -8px; top: 50%; }
.brand-mark i::before { width: 8px; height: 8px; border-radius: 50%; background: transparent; border: 1px solid var(--gold); left: 16px; top: 16px; }
.brand-mark i::after { width: 20px; height: 1px; left: 10px; top: 20px; transform: rotate(45deg); }
.desktop-nav { display: flex; align-items: center; gap: clamp(22px, 3vw, 52px); font-size: 15px; color: rgba(255,248,235,.9); }
.desktop-nav a, .footer-links a, .mobile-menu a { transition: color .2s ease; }
.desktop-nav a:hover, .footer-links a:hover, .mobile-menu a:hover { color: var(--gold); }
.login-link { height: 50px; display: inline-flex; align-items: center; justify-content: center; padding: 0 34px; border: 1px solid rgba(240,204,136,.38); border-radius: 999px; color: #fff5dd; background: rgba(255,255,255,.035); backdrop-filter: blur(16px); }
.menu-button { display: none; width: 44px; height: 44px; border: 1px solid rgba(255,255,255,.18); border-radius: 50%; background: rgba(255,255,255,.04); cursor: pointer; align-items: center; justify-content: center; flex-direction: column; gap: 5px; }
.menu-button span { width: 18px; height: 1px; background: #fff; }
.mobile-menu { display: none; position: fixed; z-index: 58; top: 88px; left: 24px; right: 24px; padding: 20px; border: 1px solid rgba(255,255,255,.14); border-radius: 24px; background: rgba(9, 9, 27, .9); backdrop-filter: blur(22px); color: #fff8ec; box-shadow: var(--shadow); }
.mobile-menu.is-open { display: grid; gap: 16px; }

.hero { position: relative; min-height: 980px; padding: 150px 0 48px; color: var(--white); overflow: hidden; isolation: isolate; background: linear-gradient(90deg, rgba(3,5,16,.84) 0%, rgba(3,5,16,.6) 34%, rgba(3,5,16,.22) 62%, rgba(3,5,16,.74) 100%), linear-gradient(180deg, rgba(5,7,19,.24) 0%, rgba(5,7,19,.2) 58%, rgba(5,7,19,.94) 100%), url("assets/hero-bg-premium.png") center top / cover no-repeat, #050713; }
.hero::before { content: ""; position: absolute; inset: -20%; z-index: -1; background: radial-gradient(circle at calc(50% + var(--mx, 0px)) calc(30% + var(--my, 0px)), rgba(155, 105, 219, .13), transparent 31%), radial-gradient(circle at 78% 66%, rgba(235, 190, 119, .1), transparent 24%); }
.hero::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, transparent 72%, rgba(5,7,19,.9) 100%); pointer-events: none; }
.hero-grid { position: relative; z-index: 2; display: grid; grid-template-columns: minmax(0, 1fr) 520px; gap: 88px; align-items: center; }
.hero-copy { max-width: 690px; }
.eyebrow, .section-kicker { margin: 0 0 22px; color: var(--gold); font-size: 13px; font-weight: 700; letter-spacing: .34em; text-transform: uppercase; }
h1, h2, h3 { margin-top: 0; }
.hero h1, .centered-section h2, .report-copy h2, .how-section h2, .cta-box h2 { font-family: "Cormorant Garamond", Georgia, serif; font-weight: 600; letter-spacing: -.045em; }
.hero h1 { margin: 0; max-width: 720px; font-size: clamp(66px, 7.6vw, 112px); line-height: .92; color: #f8dbad; text-shadow: 0 24px 80px rgba(240,204,136,.16); }
.hero-lead { margin: 32px 0 0; max-width: 630px; color: rgba(255,248,236,.83); font-size: 20px; line-height: 1.75; }
.btn { min-height: 56px; display: inline-flex; align-items: center; justify-content: center; border-radius: 999px; padding: 0 30px; border: 0; cursor: pointer; font-weight: 700; transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease; }
.btn:hover { transform: translateY(-2px); }
.btn:disabled { cursor: not-allowed; opacity: .48; transform: none; box-shadow: none; }
.btn-primary { color: #201527; background: linear-gradient(135deg, #ffe3a8, #c89447); box-shadow: 0 18px 48px rgba(207,154,72,.32), inset 0 1px 0 rgba(255,255,255,.42); }
.btn-ghost, .btn-outline { color: #fff4df; border: 1px solid rgba(240,204,136,.35); background: rgba(255,255,255,.035); }
.btn-dark { color: var(--cream); background: #171126; box-shadow: 0 18px 42px rgba(16,10,28,.22); }
.btn-wide { width: 100%; margin-top: 8px; }
.form-actions { display: grid; grid-template-columns: minmax(0, 1fr) 112px; gap: 12px; }
.form-actions .btn { width: 100%; padding: 0 22px; }

.trust-row { position: relative; z-index: 3; margin-top: 36px; display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 28px; }
.trust-item { display: flex; gap: 18px; align-items: center; min-width: 0; }
.trust-item b { color: #f6d491; font-size: 18px; line-height: 1.25; }
.trust-item p { margin: 6px 0 0; color: rgba(255,248,236,.72); font-size: 14px; line-height: 1.55; }
.line-icon, .strip-icon, .feature-icon { position: relative; display: inline-flex; align-items: center; justify-content: center; flex: 0 0 auto; border: 1px solid rgba(240,204,136,.45); border-radius: 50%; color: var(--gold); }
.line-icon { width: 60px; height: 60px; }
.asset-icon { display: block; object-fit: contain; border: 0; padding: 0; background: transparent; border-radius: 0; filter: drop-shadow(0 12px 28px rgba(0,0,0,.34)) drop-shadow(0 0 18px rgba(240,204,136,.15)); }
.line-icon.asset-icon { width: 96px; height: 96px; }
.strip-icon.asset-icon { width: 116px; height: 116px; }
.feature-icon.asset-icon { width: 118px; height: 118px; }

.calc-card { position: relative; z-index: 3; padding: 38px; border-radius: 30px; }
.calc-card::before { content: ""; position: absolute; inset: 1px; border-radius: 29px; background: radial-gradient(circle at 32% 8%, rgba(255,255,255,.12), transparent 42%); pointer-events: none; }
.calc-card__header { position: relative; text-align: center; margin-bottom: 28px; }
.calc-card h2 { margin: 0 0 8px; font-family: "Cormorant Garamond", Georgia, serif; font-size: 34px; color: #fff2d7; }
.calc-card p { margin: 0; color: rgba(255,248,236,.68); }
.birth-form { position: relative; display: grid; gap: 10px; }
.birth-form label { position: relative; }
.birth-form label > span { display: block; height: 0; overflow: hidden; }
.input-wrap { position: relative; display: flex; align-items: center; gap: 12px; height: 64px; padding: 0 18px; border: 1px solid rgba(255,255,255,.18); border-radius: 14px; background: rgba(4, 6, 21, .28); color: rgba(255,248,236,.56); transition: border-color .2s ease, background .2s ease; }
.input-wrap:focus-within { border-color: rgba(240,204,136,.62); background: rgba(4,6,21,.42); }
.form-icon { width: 20px; height: 20px; flex: 0 0 20px; color: rgba(240,204,136,.82); fill: none; stroke: currentColor; stroke-width: 1.7; stroke-linecap: round; stroke-linejoin: round; filter: drop-shadow(0 0 10px rgba(240,204,136,.12)); }
.input-wrap input { min-width: 0; width: 100%; border: 0; outline: 0; color: #fff8ec; background: transparent; }
.input-wrap input::placeholder { color: rgba(255,248,236,.52); }
.input-wrap:has(input[aria-invalid]) { border-color: rgba(255, 141, 141, .72); }
.birth-form label.has-error .input-wrap { border-color: rgba(255, 112, 128, .86); box-shadow: 0 0 0 1px rgba(255,112,128,.18), inset 0 1px 0 rgba(255,255,255,.04); }
.birth-form label.has-error .input-wrap input { padding-right: 34px; }
.field-error { position: absolute; z-index: 12; width: 20px; height: 20px; display: grid; place-items: center; border-radius: 50%; color: #1b0e18; background: #ff7d91; font-size: 13px; font-weight: 900; line-height: 1; box-shadow: 0 0 18px rgba(255,112,128,.28); cursor: help; }
.input-wrap .field-error { right: 18px; top: 50%; transform: translateY(-50%); }
.field-error::after { content: attr(data-message); position: absolute; right: 0; bottom: calc(100% + 10px); width: max-content; max-width: 260px; padding: 10px 12px; border: 1px solid rgba(255,125,145,.38); border-radius: 12px; color: #fff8ec; background: rgba(30,12,28,.96); box-shadow: 0 18px 36px rgba(0,0,0,.34), inset 0 1px 0 rgba(255,255,255,.08); font-size: 12px; font-weight: 700; line-height: 1.35; opacity: 0; visibility: hidden; transform: translateY(4px); transition: opacity .16s ease, transform .16s ease, visibility .16s ease; pointer-events: none; white-space: normal; }
.field-error:hover::after, .field-error:focus-visible::after { opacity: 1; visibility: visible; transform: translateY(0); }
.time-hint { position: absolute; left: 0; right: 0; top: calc(100% + 8px); z-index: 7; margin: 0; padding: 12px 14px; border: 1px solid rgba(240,204,136,.24); border-radius: 14px; color: rgba(255,248,236,.78); background: rgba(12,10,28,.94); box-shadow: 0 18px 44px rgba(0,0,0,.3), inset 0 1px 0 rgba(255,255,255,.08); backdrop-filter: blur(14px); font-size: 12px; line-height: 1.45; opacity: 0; visibility: hidden; transform: translateY(-10px); transition: opacity .22s ease, transform .22s ease, visibility .22s ease; pointer-events: none; }
.time-field:focus-within { z-index: 9; }
.time-field:focus-within:not(.has-error):not(.has-value) .time-hint { opacity: 1; visibility: visible; transform: translateY(0); }
.legal-consent { display: grid; grid-template-columns: 18px minmax(0, 1fr); gap: 11px; align-items: start; padding: 2px 3px 0; color: rgba(255,248,236,.72); font-size: 12px; line-height: 1.45; }
.birth-form .legal-consent > span { display: block; height: auto; overflow: visible; }
.legal-consent input { width: 18px; height: 18px; margin: 1px 0 0; accent-color: var(--gold); }
.legal-consent a { color: #ffe1aa; border-bottom: 1px solid rgba(240,204,136,.38); }
.legal-consent.has-error input { outline: 1px solid rgba(255,112,128,.86); box-shadow: 0 0 0 4px rgba(255,112,128,.12); }
.legal-consent .field-error { right: 0; top: 1px; width: 18px; height: 18px; font-size: 12px; }
.place-suggest { position: absolute; left: 0; right: 0; top: calc(100% + 8px); z-index: 8; max-height: 270px; overflow-y: auto; padding: 8px; border: 1px solid rgba(240,204,136,.26); border-radius: 16px; background: rgba(12, 10, 28, .96); box-shadow: 0 22px 60px rgba(0,0,0,.38), inset 0 1px 0 rgba(255,255,255,.08); backdrop-filter: blur(18px); }
.place-suggest button { width: 100%; display: block; padding: 12px 14px; border: 0; border-radius: 12px; color: #fff8ec; background: transparent; text-align: left; cursor: pointer; line-height: 1.35; }
.place-suggest button:hover, .place-suggest button.is-active { background: rgba(240,204,136,.13); color: #ffe1aa; }
.place-suggest__state { padding: 12px 14px; color: rgba(255,248,236,.62); line-height: 1.45; }
.privacy-note { position: relative; margin-top: 20px !important; text-align: center; font-size: 14px; }
.form-result { position: relative; margin-top: 18px; padding: 15px 16px; border-radius: 16px; color: #fff2d7; background: rgba(240,204,136,.12); border: 1px solid rgba(240,204,136,.24); line-height: 1.6; }

.hero-strip { position: relative; z-index: 3; margin-top: 78px; padding: 26px 32px; border-radius: 28px; display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); }
.hero-strip article { display: flex; align-items: center; gap: 22px; padding: 0 24px; min-height: 96px; border-right: 1px solid rgba(255,255,255,.12); }
.hero-strip article:last-child { border-right: 0; }
.strip-icon { width: 66px; height: 66px; }
.hero-strip h3 { margin: 0 0 6px; font-family: "Cormorant Garamond", Georgia, serif; color: #ffe1aa; font-size: 25px; }
.hero-strip p { margin: 0; color: rgba(255,248,236,.7); line-height: 1.55; font-size: 14px; }

.free-report-section { padding: 96px 0 106px; }
.free-report-section::before { content: ""; position: absolute; inset: 0; background: radial-gradient(circle at 18% 16%, rgba(240,204,136,.14), transparent 26%), radial-gradient(circle at 82% 72%, rgba(126,82,179,.22), transparent 30%); }
.free-report-shell { position: relative; z-index: 2; display: grid; gap: 34px; }
.free-report-head { max-width: 840px; }
.free-report-head h2 { margin: 0 0 18px; font-family: "Cormorant Garamond", Georgia, serif; font-size: clamp(44px, 5vw, 68px); line-height: 1.02; color: #ffe2b4; letter-spacing: -.045em; }
.free-report-head p { margin: 0; max-width: 720px; color: rgba(255,248,236,.8); font-size: 18px; line-height: 1.7; }
.report-birth-line { margin-top: 18px; display: inline-flex; max-width: 100%; padding: 11px 16px; border: 1px solid rgba(240,204,136,.28); border-radius: 999px; color: #ffe8bb; background: rgba(255,255,255,.045); line-height: 1.4; }
.report-metrics { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 18px; }
.report-metric { min-height: 156px; padding: 24px; border-radius: 22px; border: 1px solid rgba(255,255,255,.13); background: linear-gradient(145deg, rgba(42,31,74,.58), rgba(9,9,25,.36)); }
.report-metric span { display: block; margin-bottom: 12px; color: rgba(255,248,236,.6); font-size: 13px; font-weight: 700; letter-spacing: .16em; text-transform: uppercase; }
.report-metric b { display: block; color: #ffe1aa; font-family: "Cormorant Garamond", Georgia, serif; font-size: 34px; line-height: 1.05; }
.report-metric p { margin: 14px 0 0; color: rgba(255,248,236,.72); line-height: 1.65; }
.free-report-flow { display: grid; gap: 28px; align-items: start; }
.report-highlights, .full-report-offer { min-width: 0; }
.report-highlights { display: grid; gap: 16px; }
.report-highlight, .report-aspects { min-width: 0; overflow-wrap: anywhere; padding: 26px 28px; border-radius: 24px; border: 1px solid rgba(255,255,255,.12); background: rgba(255,255,255,.045); }
.report-highlight h3, .report-aspects h3, .full-report-offer h3 { margin: 0 0 10px; font-family: "Cormorant Garamond", Georgia, serif; color: #ffe1aa; font-size: 30px; line-height: 1.12; }
.report-highlight p { margin: 0; color: rgba(255,248,236,.76); font-size: 16px; line-height: 1.75; }
.report-aspects { display: grid; gap: 12px; }
.report-aspect { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 8px 18px; padding: 14px 0; border-top: 1px solid rgba(255,255,255,.1); }
.report-aspect:first-of-type { border-top: 0; }
.report-aspect b { color: rgba(255,248,236,.88); }
.report-aspect span { min-width: 220px; flex: 1 1 260px; color: rgba(240,204,136,.8); text-align: right; white-space: normal; }
.full-report-offer { order: -1; width: 100%; margin: 0; padding: 26px 28px; border-radius: 24px; display: grid; grid-template-columns: minmax(0, 1fr) 188px; grid-template-rows: auto auto auto; gap: 8px 28px; align-items: start; }
.full-report-offer > span { grid-column: 1; grid-row: 1; }
.full-report-offer h3 { grid-column: 1; grid-row: 2; }
.full-report-offer p { grid-column: 1; grid-row: 3; }
.full-report-offer ul { grid-column: 1; }
.full-report-price { grid-column: 2; grid-row: 2; }
.full-report-offer [data-full-report-button] { grid-column: 2; grid-row: 3; }
.full-report-offer [data-full-report-status] { grid-column: 2; grid-row: 4; }
.full-report-offer > span { display: block; margin-bottom: 2px; color: var(--gold); font-size: 11px; font-weight: 800; letter-spacing: .22em; text-transform: uppercase; }
.full-report-offer h3 { font-size: 27px; }
.full-report-offer p { max-width: 600px; margin: 0; color: rgba(255,248,236,.76); font-size: 14px; line-height: 1.55; }
.full-report-offer ul { margin: 0; padding: 0; list-style: none; display: grid; gap: 12px; }
.full-report-offer ul:empty { display: none; }
.full-report-offer li { position: relative; padding-left: 24px; color: rgba(255,248,236,.82); line-height: 1.55; }
.full-report-offer li::before { content: ""; position: absolute; left: 0; top: .7em; width: 8px; height: 8px; border-radius: 50%; background: linear-gradient(135deg, #ffe3a8, #c89447); box-shadow: 0 0 18px rgba(240,204,136,.42); }
.full-report-offer small { display: none; margin-top: 0; color: rgba(255,248,236,.58); text-align: center; line-height: 1.45; }
.full-report-offer small.is-ready, .full-report-offer small.is-error { display: block; padding: 14px 16px; border: 1px solid rgba(240,204,136,.34); border-radius: 16px; color: #fff4df; background: rgba(240,204,136,.12); box-shadow: inset 0 1px 0 rgba(255,255,255,.08); }
.full-report-offer small.is-error { border-color: rgba(255,112,128,.38); color: #ffccd6; background: rgba(255,112,128,.08); }
.report-download-link { color: #ffe1aa; font-weight: 800; text-decoration: underline; text-decoration-thickness: 1px; text-underline-offset: 4px; }
.full-report-offer .btn:disabled { cursor: wait; opacity: .72; transform: none; }
.full-report-price { display: grid; gap: 0; justify-items: center; margin: 0; color: rgba(255,248,236,.66); transform: translateY(-8px); }
.full-report-price span { font-size: 10px; font-weight: 800; letter-spacing: .18em; text-transform: uppercase; }
.full-report-price b { color: #ffe1aa; font-family: "Cormorant Garamond", Georgia, serif; font-size: 38px; line-height: 1; }
.full-report-order { grid-column: 1 / -1; display: grid; grid-template-columns: minmax(0, 1fr) 240px; gap: 12px; padding-top: 16px; border-top: 1px solid rgba(255,255,255,.12); }
.full-report-order label { display: grid; gap: 8px; color: rgba(255,248,236,.72); font-size: 12px; font-weight: 700; line-height: 1.35; }
.full-report-order input[type="text"] { width: 100%; min-height: 44px; border: 1px solid rgba(255,255,255,.14); border-radius: 14px; padding: 0 14px; outline: 0; color: #fff8ec; background: rgba(4,6,21,.36); }
.full-report-order input[type="text"]:focus { border-color: rgba(240,204,136,.62); }
.captcha-row { display: grid; grid-template-columns: 112px minmax(0, 1fr); gap: 10px; align-items: center; }
.captcha-image { min-height: 44px; border: 1px solid rgba(240,204,136,.28); border-radius: 14px; overflow: hidden; background: rgba(255,248,236,.08); }
.captcha-image svg { display: block; width: 100%; height: 44px; }
.order-check { grid-template-columns: 18px minmax(0, 1fr); align-items: start; gap: 10px; font-weight: 600; }
.order-check input { width: 18px; height: 18px; margin: 0; accent-color: var(--gold); }
.order-check a { color: #ffe1aa; border-bottom: 1px solid rgba(240,204,136,.38); }
.full-report-order__actions { grid-column: 1 / -1; display: grid; grid-template-columns: minmax(0, 1fr) minmax(210px, .68fr); gap: 10px; }
.full-report-order__error { grid-column: 1 / -1; margin: 0; color: #ffb4c2; font-size: 13px; font-weight: 700; line-height: 1.45; }
.report-bottom-cta { display: flex; justify-content: center; padding: 2px 0 8px; }

.calculation-overlay { position: fixed; inset: 0; z-index: 90; display: grid; place-items: center; padding: 28px; color: #fff8ec; background: rgba(3, 4, 14, .82); backdrop-filter: blur(18px); }
.calculation-panel { position: relative; width: min(520px, 100%); padding: 42px 34px 38px; border-radius: 30px; text-align: center; overflow: hidden; }
.calculation-panel::before { content: ""; position: absolute; inset: -40%; background: conic-gradient(from 120deg, transparent, rgba(240,204,136,.16), transparent, rgba(114,80,166,.2), transparent); animation: slow-spin 9s linear infinite; }
.calculation-panel > * { position: relative; z-index: 1; }
.calculation-panel h2 { margin: 12px 0 14px; font-family: "Cormorant Garamond", Georgia, serif; font-size: clamp(34px, 5vw, 48px); line-height: 1.02; color: #ffe1aa; letter-spacing: -.035em; }
.calculation-status { min-height: 28px; margin: 0; color: rgba(255,248,236,.78); font-size: 16px; line-height: 1.55; transition: opacity .2s ease; }
.astro-loader { position: relative; width: 174px; height: 174px; margin: 0 auto 26px; }
.astro-loader__ring, .astro-loader__orbit, .astro-loader__moon, .astro-loader__star { position: absolute; inset: 0; border-radius: 50%; }
.astro-loader__ring { border: 1px solid rgba(240,204,136,.34); box-shadow: inset 0 0 32px rgba(240,204,136,.1), 0 0 32px rgba(240,204,136,.12); }
.astro-loader__ring::before, .astro-loader__ring::after { content: ""; position: absolute; left: 50%; top: 10px; width: 1px; height: 154px; background: linear-gradient(180deg, transparent, rgba(240,204,136,.58), transparent); transform-origin: 50% 77px; }
.astro-loader__ring::after { transform: rotate(90deg); }
.astro-loader__orbit { border: 1px solid rgba(255,226,180,.38); }
.astro-loader__orbit--one { transform: rotate(-18deg) scaleX(1.18); animation: orbit-one 7s linear infinite; }
.astro-loader__orbit--two { transform: rotate(48deg) scaleX(1.06); animation: orbit-two 10s linear infinite reverse; }
.astro-loader__moon { inset: 68px; border: 1px solid rgba(240,204,136,.46); background: radial-gradient(circle at 35% 30%, #ffe7b6, #c69248 64%, rgba(198,146,72,.2)); box-shadow: 0 0 28px rgba(240,204,136,.34); animation: pulse-moon 2.8s ease-in-out infinite; }
.astro-loader__star::before, .astro-loader__star::after { content: ""; position: absolute; left: 50%; top: 50%; width: 92px; height: 1px; background: linear-gradient(90deg, transparent, #ffe1aa, transparent); transform: translate(-50%, -50%); }
.astro-loader__star::after { transform: translate(-50%, -50%) rotate(90deg); }
.report-close { position: sticky; top: 0; z-index: 4; justify-self: end; width: 46px; height: 46px; margin: 0 0 -8px; border: 1px solid rgba(255,255,255,.16); border-radius: 50%; background: rgba(255,255,255,.055); cursor: pointer; box-shadow: 0 16px 40px rgba(0,0,0,.2); }
.report-close::before, .report-close::after { content: ""; position: absolute; left: 50%; top: 50%; width: 18px; height: 2px; border-radius: 999px; background: #ffe1aa; }
.report-close::before { transform: translate(-50%, -50%) rotate(45deg); }
.report-close::after { transform: translate(-50%, -50%) rotate(-45deg); }
.free-report-section { position: fixed; inset: 0; z-index: 85; padding: 54px 0; overflow-y: auto; background: linear-gradient(180deg, rgba(5,7,19,.9), rgba(5,7,19,.96)), url("assets/space-bg.jpg") center / cover no-repeat; }
.free-report-section.is-open { display: block; }
.free-report-section .free-report-shell { width: min(1180px, calc(100% - 42px)); margin: 0 auto; padding: 30px; border-radius: 30px; background: linear-gradient(145deg, rgba(38, 27, 66, .78), rgba(9, 9, 25, .76)); border: 1px solid rgba(255,255,255,.16); box-shadow: var(--shadow), inset 0 1px 0 rgba(255,255,255,.08); backdrop-filter: blur(24px); }

@keyframes slow-spin {
  to { transform: rotate(360deg); }
}
@keyframes orbit-one {
  to { transform: rotate(342deg) scaleX(1.18); }
}
@keyframes orbit-two {
  to { transform: rotate(408deg) scaleX(1.06); }
}
@keyframes pulse-moon {
  0%, 100% { transform: scale(1); opacity: .88; }
  50% { transform: scale(1.08); opacity: 1; }
}

@media(max-width: 1240px) {
  .full-report-offer { width: 100%; }
}

.section-light { position: relative; padding: 86px 0 96px; background: radial-gradient(circle at 10% 18%, rgba(231,192,121,.18), transparent 28%), radial-gradient(circle at 90% 100%, rgba(61,39,88,.1), transparent 24%), var(--cream); }
.centered-section { text-align: center; }
.section-kicker { color: #a2703a; }
.centered-section h2, .how-section h2, .cta-box h2 { font-size: clamp(42px, 5vw, 64px); line-height: 1.05; color: #1c1724; }
.features-grid { margin-top: 56px; display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); border-top: 1px solid rgba(20,14,30,.12); }
.feature-card { padding: 44px 26px 12px; border-right: 1px solid rgba(20,14,30,.1); }
.feature-card:last-child { border-right: 0; }
.feature-icon { width: 72px; height: 72px; margin: 0 auto 22px; color: #3a284a; border-color: rgba(58,40,74,.18); font-family: "Cormorant Garamond", Georgia, serif; font-size: 22px; }
.feature-card h3 { margin: 0 0 12px; font-size: 18px; }
.feature-card p { margin: 0; color: var(--ink-soft); line-height: 1.75; }

.section-dark, .report-section, .reviews-section { position: relative; color: #fff8ec; overflow: hidden; background: linear-gradient(180deg, rgba(5,7,19,.88), rgba(5,7,19,.94)), url("assets/space-bg.jpg") center / cover no-repeat; }
.free-report-section.section-dark { position: fixed; inset: 0; z-index: 85; padding: 54px 0; overflow-x: hidden; overflow-y: auto; background: linear-gradient(180deg, rgba(5,7,19,.9), rgba(5,7,19,.96)), url("assets/space-bg.jpg") center / cover no-repeat; }
.report-section { padding: 92px 0 106px; }
.report-section::before, .reviews-section::before { content: ""; position: absolute; inset: 0; background: radial-gradient(circle at 77% 20%, rgba(164,105,214,.22), transparent 28%), radial-gradient(circle at 18% 72%, rgba(240,204,136,.1), transparent 24%); }
.report-grid { position: relative; z-index: 2; display: grid; grid-template-columns: 390px 1fr; gap: 80px; align-items: center; }
.section-kicker.gold { color: var(--gold); }
.report-copy h2 { margin: 0 0 24px; color: #ffe2b4; font-size: clamp(44px, 5vw, 66px); line-height: 1.02; }
.report-copy p { color: rgba(255,248,236,.78); font-size: 18px; line-height: 1.8; }
.book-preview { position: relative; min-height: 420px; display: flex; justify-content: center; perspective: 1200px; }
.book-page { width: 340px; height: 410px; padding: 30px; background: linear-gradient(135deg, #fffaf2, #e7ded2); color: #251d2b; box-shadow: 0 35px 90px rgba(0,0,0,.36); }
.chart-page { border-radius: 18px 0 0 18px; transform: rotateY(5deg); }
.text-page { border-radius: 0 18px 18px 0; transform: rotateY(-5deg); }
.chart-circle { position: relative; width: 220px; height: 220px; margin: 8px auto 28px; border: 1px solid rgba(42,38,56,.28); border-radius: 50%; background: repeating-conic-gradient(from -10deg, rgba(53,40,82,.1) 0 1deg, transparent 1deg 30deg); }
.chart-circle::before { content: ""; position: absolute; inset: 34px; border: 1px solid rgba(42,38,56,.18); border-radius: 50%; }
.chart-circle span { position: absolute; inset: 50%; width: 96px; height: 1px; background: rgba(153,92,98,.72); transform-origin: left center; }
.chart-circle span:nth-child(1){ transform: rotate(25deg); } .chart-circle span:nth-child(2){ transform: rotate(118deg); } .chart-circle span:nth-child(3){ transform: rotate(208deg); } .chart-circle span:nth-child(4){ transform: rotate(304deg); }
.mini-table { display: grid; gap: 10px; }
.mini-table i { height: 8px; border-radius: 99px; background: rgba(42,38,56,.16); }
.text-page h3 { font-family: "Cormorant Garamond", Georgia, serif; font-size: 25px; }
.insight-card { padding: 14px 16px; border-radius: 14px; background: rgba(25,19,49,.07); margin-bottom: 14px; }
.insight-card p { margin: 6px 0 0; color: #625b68; font-size: 13px; line-height: 1.45; }
.floating-label { position: absolute; z-index: 2; padding: 18px 26px; border-radius: 999px; color: #fff5dd; background: rgba(25,17,50,.88); box-shadow: 0 20px 52px rgba(0,0,0,.28); }
.floating-label-left { left: 30px; bottom: 68px; }
.floating-label-right { right: 22px; top: 210px; }

.how-section { text-align: center; }
.steps-grid { margin-top: 46px; display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 24px; }
.step-card { padding: 34px; border-radius: 26px; background: rgba(255,255,255,.44); border: 1px solid rgba(20,14,30,.09); box-shadow: 0 20px 50px rgba(44,32,56,.08); }
.step-card span { display: block; color: #b47c3e; letter-spacing: .18em; font-weight: 800; margin-bottom: 16px; }
.step-card h3 { font-family: "Cormorant Garamond", Georgia, serif; font-size: 30px; margin-bottom: 10px; }
.step-card p { color: var(--ink-soft); line-height: 1.7; }
.reviews-section { padding: 92px 0; }
.reviews-grid { position: relative; z-index: 2; display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.review-card { border-radius: 26px; padding: 30px; }
.review-card p { margin: 0 0 22px; line-height: 1.75; color: rgba(255,248,236,.82); }
.review-card b { color: var(--gold); }
.cta-section { padding: 72px 0 86px; }
.cta-box { position: relative; min-height: 260px; display: grid; place-items: center; text-align: center; overflow: hidden; }
.cta-box p { color: var(--ink-soft); font-size: 18px; margin-bottom: 28px; }
.sun-ornament, .moon-ornament { position: absolute; width: 220px; height: 220px; border-radius: 50%; opacity: .18; border: 1px solid #9e6f37; }
.sun-ornament { left: 0; top: 28px; background: radial-gradient(circle, transparent 32%, #9e6f37 33% 34%, transparent 35%); }
.moon-ornament { right: 16px; bottom: -18px; box-shadow: -48px 0 0 rgba(158,111,55,.3); }
.site-footer { padding: 36px 0; color: rgba(255,248,236,.72); background: #060714; }
.footer-grid { display: grid; grid-template-columns: auto 1fr auto; gap: 24px; align-items: center; }
.site-footer .brand { color: #fff8ec; font-size: 22px; }
.footer-links { display: flex; gap: 24px; }
.legal-modal { position: fixed; inset: 0; z-index: 80; display: grid; place-items: center; padding: 24px; background: rgba(2, 3, 12, .78); backdrop-filter: blur(16px); }
.legal-modal__panel { position: relative; width: min(820px, 100%); max-height: min(720px, calc(100vh - 48px)); overflow-y: auto; padding: clamp(28px, 4vw, 46px); border-radius: 28px; color: rgba(255,248,236,.82); }
.legal-modal__content h2 { margin: 0 0 20px; color: #ffe1aa; font-family: "Cormorant Garamond", Georgia, serif; font-size: clamp(34px, 5vw, 52px); line-height: 1.04; letter-spacing: -.035em; }
.legal-modal__content p { margin: 0 0 16px; line-height: 1.75; }
.legal-modal__content p:last-child { margin-bottom: 0; }
.legal-modal__content b { color: #ffe1aa; }
.legal-modal__close { position: sticky; top: 0; z-index: 2; float: right; width: 42px; height: 42px; margin: -12px -12px 8px 18px; border: 1px solid rgba(255,255,255,.16); border-radius: 50%; background: rgba(255,255,255,.07); cursor: pointer; }
.legal-modal__close::before, .legal-modal__close::after { content: ""; position: absolute; left: 50%; top: 50%; width: 17px; height: 2px; border-radius: 999px; background: #ffe1aa; }
.legal-modal__close::before { transform: translate(-50%, -50%) rotate(45deg); }
.legal-modal__close::after { transform: translate(-50%, -50%) rotate(-45deg); }
.legal-page { color: #fff8ec; background: #060714; }
.legal-page .global-bg { background: radial-gradient(circle at 78% 8%, rgba(126,82,179,.22), transparent 30%), radial-gradient(circle at 18% 24%, rgba(240,204,136,.12), transparent 26%), #060714; }
.legal-page__header { width: min(1370px, calc(100% - 64px)); min-height: 92px; margin: 0 auto; display: flex; align-items: center; justify-content: space-between; gap: 24px; }
.legal-page__main { padding: 54px 0 86px; }
.legal-page__card { width: min(920px, calc(100% - 64px)); margin: 0 auto; padding: clamp(30px, 5vw, 56px); border-radius: 30px; }
.legal-page__card h1 { margin: 0 0 18px; font-family: "Cormorant Garamond", Georgia, serif; font-size: clamp(52px, 7vw, 78px); line-height: .98; color: #ffe1aa; letter-spacing: -.045em; }
.legal-page__lead { margin: 0 0 34px; max-width: 760px; color: rgba(255,248,236,.78); font-size: 18px; line-height: 1.75; }
.legal-page__card article { padding: 24px 0; border-top: 1px solid rgba(255,255,255,.1); }
.legal-page__card article:first-of-type { border-top: 0; }
.legal-page__card h2 { margin: 0 0 12px; font-family: "Cormorant Garamond", Georgia, serif; font-size: 32px; color: #ffe1aa; line-height: 1.12; }
.legal-page__card p { margin: 0 0 12px; color: rgba(255,248,236,.78); line-height: 1.78; }
.legal-page__card p:last-child { margin-bottom: 0; }
.legal-page__footer { border-top: 1px solid rgba(255,255,255,.08); }

@media (max-width: 1180px) {
  .desktop-nav { display: none; }
  .menu-button { display: inline-flex; }
  .hero-grid { grid-template-columns: 1fr; gap: 48px; }
  .calc-card { max-width: 560px; }
  .hero-strip, .features-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .trust-row, .steps-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .hero-strip article:nth-child(2) { border-right: 0; }
  .hero-strip article { border-bottom: 1px solid rgba(255,255,255,.12); }
  .hero-strip article:nth-child(n+3) { border-bottom: 0; }
  .features-grid { border-top: 0; gap: 16px; }
  .feature-card { border: 1px solid rgba(20,14,30,.1); border-radius: 22px; background: rgba(255,255,255,.36); }
  .report-grid { grid-template-columns: 1fr; }
  .free-report-flow { grid-template-columns: 1fr; }
}
@media (max-width: 760px) {
  .container { width: min(100% - 32px, 1370px); }
  .site-header { width: calc(100% - 28px); height: 70px; }
  .brand { font-size: 20px; gap: 10px; }
  .brand-mark { width: 34px; height: 34px; }
  .brand-mark::before { height: 48px; top: -7px; }
  .brand-mark::after { width: 48px; left: -7px; }
  .login-link { display: none; }
  .hero { min-height: auto; padding: 116px 0 34px; }
  .hero h1 { font-size: clamp(48px, 15vw, 70px); }
  .hero-lead { font-size: 16px; line-height: 1.7; }
  .eyebrow, .section-kicker { font-size: 11px; letter-spacing: .22em; }
  .trust-row { grid-template-columns: 1fr; margin-top: 36px; }
  .line-icon { width: 52px; height: 52px; }
  .line-icon.asset-icon { width: 76px; height: 76px; }
  .strip-icon.asset-icon { width: 92px; height: 92px; }
  .feature-icon.asset-icon { width: 96px; height: 96px; }
  .calc-card { padding: 24px; border-radius: 24px; }
  .calc-card h2 { font-size: 29px; }
  .input-wrap { height: 58px; }
  .form-actions { grid-template-columns: 1fr; }
  .hero-strip { grid-template-columns: 1fr; padding: 14px; margin-top: 42px; }
  .hero-strip article { border-right: 0; border-bottom: 1px solid rgba(255,255,255,.12) !important; padding: 18px 12px; }
  .hero-strip article:last-child { border-bottom: 0 !important; }
  .free-report-section.section-dark { padding: 18px 0; }
  .free-report-section .free-report-shell { width: calc(100% - 24px); padding: 22px; border-radius: 24px; }
  .calculation-overlay { padding: 18px; }
  .calculation-panel { padding: 34px 22px 30px; border-radius: 24px; }
  .astro-loader { width: 138px; height: 138px; }
  .astro-loader__ring::before, .astro-loader__ring::after { top: 9px; height: 120px; transform-origin: 50% 60px; }
  .astro-loader__moon { inset: 54px; }
  .astro-loader__star::before, .astro-loader__star::after { width: 72px; }
  .report-close { width: 42px; height: 42px; }
  .free-report-head h2 { font-size: 42px; }
  .free-report-head p { font-size: 16px; }
  .report-birth-line { border-radius: 18px; }
  .report-metrics { grid-template-columns: 1fr; }
  .report-metric, .report-highlight, .report-aspects, .full-report-offer { padding: 22px; border-radius: 20px; }
  .full-report-offer { width: 100%; grid-template-columns: 1fr; grid-template-rows: none; gap: 12px; align-items: stretch; }
  .full-report-offer > span, .full-report-offer h3, .full-report-offer p, .full-report-offer ul, .full-report-price, .full-report-offer [data-full-report-button], .full-report-offer [data-full-report-status] { grid-column: 1; grid-row: auto; }
  .full-report-offer > span { margin-bottom: 0; font-size: 10px; letter-spacing: .2em; }
  .full-report-offer h3 { margin: 0; font-size: 26px; line-height: 1.05; }
  .full-report-offer p { max-width: none; font-size: 14px; line-height: 1.55; }
  .full-report-price { display: flex; align-items: baseline; justify-content: flex-start; gap: 10px; transform: none; margin: -2px 0 0; }
  .full-report-price b { font-size: 36px; }
  .full-report-offer [data-full-report-button] { width: 100%; min-height: 54px; margin-top: 2px; }
  .full-report-order { grid-template-columns: 1fr; }
  .full-report-order__actions { grid-template-columns: 1fr; }
  .captcha-row { grid-template-columns: 112px minmax(110px, 1fr); }
  .report-aspect { align-items: flex-start; flex-direction: column; gap: 6px; }
  .report-aspect span { white-space: normal; }
  .section-light { padding: 64px 0; }
  .centered-section h2, .how-section h2, .cta-box h2 { font-size: 42px; }
  .trust-row, .features-grid, .steps-grid, .reviews-grid { grid-template-columns: 1fr; }
  .feature-card { padding: 30px 22px; }
  .report-section, .reviews-section { padding: 66px 0; }
  .book-preview { min-height: auto; flex-direction: column; align-items: center; gap: 0; }
  .book-page { width: min(100%, 330px); height: auto; min-height: 330px; transform: none; border-radius: 20px; }
  .text-page { margin-top: -8px; }
  .floating-label { display: none; }
  .footer-grid { grid-template-columns: 1fr; text-align: center; justify-items: center; }
  .footer-links { flex-wrap: wrap; justify-content: center; }
  .legal-modal { padding: 14px; }
  .legal-modal__panel { max-height: calc(100vh - 28px); padding: 24px; border-radius: 22px; }
  .legal-page__header { width: calc(100% - 32px); min-height: 78px; }
  .legal-page__header .btn { min-height: 44px; padding: 0 18px; }
  .legal-page__main { padding: 28px 0 56px; }
  .legal-page__card { width: calc(100% - 32px); border-radius: 24px; }
  .legal-page__card h1 { font-size: 46px; }
  .legal-page__card h2 { font-size: 28px; }
}
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation: none !important; transition: none !important; scroll-behavior: auto !important; }
  .reveal { opacity: 1; transform: none; }
}
