/* BodieZ By J — shared design system (ChromeRonin-grade) */
@font-face{font-family:'Bebas Neue';src:url('/assets/fonts/bebas-neue-400.woff2') format('woff2');font-weight:400;font-display:swap}
@font-face{font-family:'Barlow';src:url('/assets/fonts/barlow-400.woff2') format('woff2');font-weight:400;font-display:swap}
@font-face{font-family:'Barlow';src:url('/assets/fonts/barlow-600.woff2') format('woff2');font-weight:600;font-display:swap}
@font-face{font-family:'Barlow';src:url('/assets/fonts/barlow-700.woff2') format('woff2');font-weight:700;font-display:swap}
:root{
--black:#0a0a0a;--ink:#0d0d0f;--card:#151517;--card2:#101012;--bone:#e9e7e0;--bone2:#dcd9d0;--bone-ink:#16150f;--bone-gray:#4a483f;
--red:#e02020;--red-dark:#b01818;--off:#e8e6e1;--gray:#9a988f;--gray-d:#6f6d64;--line:rgba(255,255,255,.09);--line-bone:rgba(0,0,0,.12);
--mono:ui-monospace,'SF Mono','JetBrains Mono','IBM Plex Mono',Consolas,'Courier New',monospace;
--disp:'Bebas Neue','Arial Narrow',sans-serif;--body:'Barlow',system-ui,sans-serif}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--black);color:var(--off);font-family:var(--body);line-height:1.6;-webkit-font-smoothing:antialiased}
img{display:block;max-width:100%}
a{color:inherit}
.wrap{max-width:1120px;margin:0 auto;padding:0 26px}
.label{font-family:var(--mono);font-size:11px;letter-spacing:2.5px;text-transform:uppercase;color:var(--gray)}
.label .dot{color:var(--red)}
h1,h2,h3{font-family:var(--disp);font-weight:400;line-height:.98;text-transform:uppercase;color:var(--off);letter-spacing:.5px}
h1{font-size:clamp(46px,8.5vw,104px);margin:16px 0 20px}
h2{font-size:clamp(30px,5vw,52px);margin:10px 0 6px}
h3{font-size:21px;font-family:var(--body);font-weight:700;text-transform:none;letter-spacing:0}
p{color:var(--gray)}
p.lead{font-size:19px;color:var(--off);max-width:660px}
.mono-sm{font-family:var(--mono);font-size:12px;letter-spacing:1px;text-transform:uppercase;color:var(--gray)}
.btn{display:inline-block;background:var(--red);color:#fff;text-decoration:none;font-family:var(--mono);font-weight:600;text-transform:uppercase;letter-spacing:1.5px;font-size:13px;padding:16px 30px;border-radius:2px;transition:background .2s,transform .2s}
.btn:hover{background:var(--red-dark);transform:translateY(-1px)}
.btn-ghost{display:inline-block;border:1px solid var(--line);color:var(--off);text-decoration:none;font-family:var(--mono);font-weight:600;text-transform:uppercase;letter-spacing:1.5px;font-size:13px;padding:15px 28px;border-radius:2px;transition:border-color .2s,color .2s}
.btn-ghost:hover{border-color:var(--off)}
.btn-sm{padding:11px 18px;font-size:12px}
/* nav */
nav.site{position:sticky;top:0;z-index:50;background:rgba(10,10,10,.9);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav-in{display:flex;align-items:center;justify-content:space-between;height:66px;max-width:1120px;margin:0 auto;padding:0 26px}
.brand{font-family:var(--disp);font-weight:400;letter-spacing:2px;text-transform:uppercase;font-size:24px;color:var(--off);text-decoration:none}
.brand b{color:var(--red);font-weight:400}
.nav-links{display:flex;gap:26px;align-items:center;list-style:none}
.nav-links a{text-decoration:none;font-family:var(--mono);font-weight:500;letter-spacing:1px;text-transform:uppercase;font-size:12px;color:var(--gray);transition:color .2s}
.nav-links a:hover{color:var(--off)}
.nav-links a.cta{color:var(--off);border:1px solid var(--line);padding:8px 14px;border-radius:2px}
.nav-links a.cta:hover{border-color:var(--red);color:#fff}
.burger{display:none;background:none;border:0;cursor:pointer;padding:8px;flex-direction:column;gap:5px}
.burger span{display:block;width:24px;height:2px;background:var(--off)}
@media(max-width:860px){
.nav-links{position:fixed;inset:66px 0 auto 0;background:var(--black);flex-direction:column;gap:0;padding:8px 0;border-bottom:1px solid var(--line);display:none}
.nav-links.open{display:flex}.nav-links li{width:100%;text-align:center}.nav-links a{display:block;padding:16px}
.burger{display:flex}}
/* sections */
section{padding:78px 0;border-bottom:1px solid var(--line)}
.hero{padding:96px 0 86px;background:radial-gradient(1100px 460px at 78% -20%,rgba(224,32,32,.10),transparent)}
.hero .meta{display:flex;gap:10px;flex-wrap:wrap;margin-top:22px}
.hero .meta span{font-family:var(--mono);font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--gray);border:1px solid var(--line);padding:7px 12px;border-radius:2px}
.btns{display:flex;gap:14px;flex-wrap:wrap;margin-top:28px}
.head{max-width:720px}
/* hairline grid cells */
.grid{display:grid;gap:1px;margin-top:36px;background:var(--line)}
.g2{grid-template-columns:repeat(2,1fr)}.g3{grid-template-columns:repeat(3,1fr)}.g4{grid-template-columns:repeat(4,1fr)}
@media(max-width:820px){.g3,.g4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.g2,.g3,.g4{grid-template-columns:1fr}}
.cell{background:var(--black);padding:28px 26px}
.cell h3{margin-bottom:8px;color:var(--off)}
.cell .n{font-family:var(--mono);font-size:12px;color:var(--red);letter-spacing:1px}
.cell .tl{color:var(--red);text-decoration:none;font-family:var(--mono);font-size:12px;letter-spacing:1px;text-transform:uppercase}
.cell .tl:hover{color:#fff}
/* product / plan cards */
.pcard{background:var(--card);border:1px solid var(--line);border-radius:4px;overflow:hidden;display:flex;flex-direction:column}
.pcard .cover{aspect-ratio:4/5;overflow:hidden;background:#0d0d0d}
.pcard .cover img{width:100%;height:100%;object-fit:cover}
.pcard .pb{padding:22px;display:flex;flex-direction:column;flex:1}
.pcard .code{font-family:var(--mono);font-size:11px;letter-spacing:1px;text-transform:uppercase;color:var(--gray)}
.pcard h3{margin:8px 0 6px}
.pcard .price{font-family:var(--disp);font-size:34px;color:var(--off);margin:10px 0 16px}
.pcard .price small{font-family:var(--mono);font-size:12px;color:var(--gray);letter-spacing:1px}
.pcard .pa{display:flex;gap:10px;margin-top:auto;flex-wrap:wrap}
.plan{background:var(--card);border:1px solid var(--line);border-radius:4px;padding:26px;display:flex;flex-direction:column}
.plan.feat{border-color:rgba(224,32,32,.5)}
.plan .tier{font-family:var(--mono);font-size:12px;letter-spacing:1.5px;text-transform:uppercase;color:var(--red)}
.plan h3{margin:8px 0 2px;font-family:var(--disp);font-weight:400;text-transform:uppercase;font-size:28px;letter-spacing:.5px}
.plan .term{font-family:var(--mono);font-size:11px;color:var(--gray);letter-spacing:1px;text-transform:uppercase}
.plan .price{font-family:var(--disp);font-size:44px;color:var(--off);margin:12px 0 14px}
.plan ul{list-style:none;margin:0 0 20px;display:grid;gap:9px}
.plan li{color:var(--gray);font-size:15px;padding-left:20px;position:relative}
.plan li::before{content:'—';position:absolute;left:0;color:var(--red);font-family:var(--mono)}
.plan .pa{margin-top:auto}
/* bone editorial */
.bone{background:var(--bone);color:var(--bone-ink);border-bottom:1px solid var(--line-bone)}
.bone h2,.bone h3{color:var(--bone-ink)}
.bone p{color:var(--bone-gray)}.bone .label{color:#7a776a}
.bone .btn-ghost{border-color:rgba(0,0,0,.2);color:var(--bone-ink)}.bone .btn-ghost:hover{border-color:var(--bone-ink)}
.steps{margin-top:34px;display:grid;gap:0}
.step{display:grid;grid-template-columns:64px 1fr;gap:18px;padding:22px 0;border-top:1px solid var(--line-bone)}
.step .sn{font-family:var(--mono);font-size:13px;color:var(--red);letter-spacing:1px;padding-top:4px}
.step h3{font-size:20px;margin-bottom:4px}
/* results grid */
.rgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;margin-top:34px;background:var(--line)}
@media(max-width:820px){.rgrid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:520px){.rgrid{grid-template-columns:repeat(2,1fr)}}
.rgrid img{width:100%;aspect-ratio:1/1;object-fit:cover;filter:grayscale(.15)}
/* pullquote */
.pull{max-width:840px}
.pull blockquote{font-family:var(--disp);font-size:clamp(28px,4vw,48px);line-height:1.05;text-transform:uppercase;color:var(--off);letter-spacing:.5px}
.bone .pull blockquote{color:var(--bone-ink)}
.pull .by{font-family:var(--mono);font-size:12px;letter-spacing:1.5px;text-transform:uppercase;color:var(--gray);margin-top:18px}
.pull .by b{color:var(--red);font-weight:400}
/* split (image + text) */
.split{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center}
@media(max-width:820px){.split{grid-template-columns:1fr;gap:26px}}
.split img{width:100%;border-radius:4px;filter:grayscale(.12)}
/* faq */
.faq{max-width:820px;margin-top:26px}
.faq details{border-top:1px solid var(--line);padding:18px 0}
.faq summary{cursor:pointer;font-family:var(--body);font-weight:700;color:var(--off);font-size:18px;list-style:none;display:flex;justify-content:space-between;gap:16px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:'+';color:var(--red);font-family:var(--mono)}
.faq details[open] summary::after{content:'\2013'}
.faq p{margin-top:10px}
.cta-band{text-align:center;background:linear-gradient(180deg,#121212,#0a0a0a)}
/* prose (blog/legal) */
.prose{max-width:760px}
.prose p{color:var(--off);opacity:.86;margin:0 0 18px;font-size:17px}
.prose h2{margin:36px 0 12px}.prose h3{margin:26px 0 10px}
.prose ul,.prose ol{margin:0 0 18px 22px;color:var(--off);opacity:.86}
.prose a{color:var(--red);text-decoration:underline}
.prose img{border-radius:4px;margin:22px 0}
/* footer */
footer.site{padding:44px 0 96px;color:var(--gray);font-size:14px;border-top:1px solid var(--line)}
.foot-in{display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;align-items:flex-start}
.foot-links{display:flex;gap:18px;flex-wrap:wrap;font-family:var(--mono);font-size:12px;letter-spacing:1px;text-transform:uppercase}
.foot-links a{color:var(--gray);text-decoration:none}.foot-links a:hover{color:var(--off)}
.crumb{font-family:var(--mono);font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--gray);margin-bottom:6px}
.crumb a{color:var(--gray);text-decoration:none}
/* sticky mobile CTA */
.mcta{position:fixed;left:0;right:0;bottom:0;z-index:60;display:none;gap:12px;align-items:center;justify-content:space-between;background:rgba(10,10,10,.96);backdrop-filter:blur(10px);border-top:1px solid var(--line);padding:11px 16px calc(11px + env(safe-area-inset-bottom))}
.mcta span{font-family:var(--mono);font-size:11px;letter-spacing:1px;text-transform:uppercase;color:var(--gray)}
@media(max-width:860px){.mcta{display:flex}body.has-mcta{padding-bottom:72px}}
/* motion */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s cubic-bezier(.2,.6,.2,1),transform .7s cubic-bezier(.2,.6,.2,1)}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}html{scroll-behavior:auto}}

/* forms */
.form{max-width:640px;margin-top:30px;display:grid;gap:18px}
.form .field{display:flex;flex-direction:column;gap:7px}
.form .field.full{grid-column:1/-1}
.form label{font-family:var(--mono);font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--gray)}
.form input,.form select,.form textarea{background:var(--card);border:1px solid var(--line);border-radius:3px;padding:13px 14px;color:var(--off);font-family:var(--body);font-size:16px}
.form input:focus,.form select:focus,.form textarea:focus{outline:none;border-color:var(--red)}
.form textarea{min-height:150px;resize:vertical}
.form .hp{position:absolute;left:-9999px}