/* ===== WebGen landing — editorial / brutalist-typographic (shared) ===== */
:root{ --ink:#0E0E10; --gray:#B9BDC4; --paper:#F5F3EC; --lime:#C6F23E; --hot:#FF5A3C; }
*{ box-sizing:border-box; }
html,body{ margin:0; padding:0; }
body{ font-family:'Inter',system-ui,sans-serif; color:var(--ink); background:var(--paper); -webkit-font-smoothing:antialiased; overflow-x:hidden; }
a{ color:inherit; transition:.2s ease; }
img{ max-width:100%; }
::selection{ background:var(--lime); }
.wrap{ max-width:1240px; margin:0 auto; padding:0 28px; }

/* reveal */
[data-reveal]{ opacity:0; transform:translateY(28px); transition:opacity .7s ease, transform .7s cubic-bezier(.2,.8,.2,1); }
[data-reveal].in{ opacity:1; transform:none; }

/* header */
header{ position:sticky; top:0; z-index:60; background:rgba(245,243,236,.86); backdrop-filter:saturate(160%) blur(10px); border-bottom:2px solid var(--ink); }
.hd{ display:flex; align-items:center; justify-content:space-between; gap:24px; padding:14px 0; }
.logo{ font-family:'Archivo'; font-weight:900; font-size:24px; letter-spacing:-.04em; text-decoration:none; color:var(--ink); }
.logo b{ color:var(--lime); -webkit-text-stroke:1px var(--ink); }
nav.menu{ display:flex; gap:26px; font-family:'Archivo'; font-weight:700; font-size:14px; text-transform:uppercase; letter-spacing:.02em; }
nav.menu a{ text-decoration:none; color:var(--ink); opacity:.7; }
nav.menu a:hover,nav.menu a.is-active{ opacity:1; }
.start{ font-family:'Archivo'; font-weight:800; font-size:14px; text-transform:uppercase; text-decoration:none; color:var(--ink); background:var(--lime); border:2px solid var(--ink); padding:10px 18px; border-radius:100px; white-space:nowrap; transition:.2s; }
.start:hover{ transform:translate(-2px,-2px); box-shadow:4px 4px 0 var(--ink); }
#burger{ display:none; width:42px; height:42px; border:2px solid var(--ink); border-radius:10px; background:none; cursor:pointer; flex-direction:column; gap:4px; align-items:center; justify-content:center; }
#burger span{ width:18px; height:2px; background:var(--ink); }
#mob{ display:none; flex-direction:column; gap:2px; padding:8px 0 16px; border-top:2px solid var(--ink); }
#mob a{ font-family:'Archivo'; font-weight:700; text-transform:uppercase; font-size:16px; padding:12px 0; text-decoration:none; border-bottom:1px solid rgba(14,14,16,.1); }
@media(max-width:860px){ nav.menu,.start{ display:none; } #burger{ display:flex; } }

/* marquee */
.marq{ border-top:2px solid var(--ink); border-bottom:2px solid var(--ink); background:var(--ink); color:var(--paper); overflow:hidden; }
.marq.lime{ background:var(--lime); color:var(--ink); }
.marq .track{ display:inline-flex; white-space:nowrap; animation:scroll 24s linear infinite; font-family:'Archivo'; font-weight:800; text-transform:uppercase; font-size:15px; letter-spacing:.04em; padding:11px 0; }
.marq .track span{ padding:0 26px; }
@keyframes scroll{ to{ transform:translateX(-50%); } }

/* hero */
.hero{ position:relative; padding:54px 0 30px; }
.kick{ font-family:'Archivo'; font-weight:700; font-size:13px; letter-spacing:.14em; text-transform:uppercase; color:var(--ink); opacity:.55; margin:0 0 26px; max-width:330px; line-height:1.5; }
.statement{ font-family:'Archivo'; font-weight:900; font-size:clamp(40px,7.4vw,108px); line-height:.96; letter-spacing:-.035em; margin:0; max-width:14ch; }
.statement .g{ color:var(--gray); }
.statement .mark{ position:relative; white-space:nowrap; }
.statement .mark svg{ position:absolute; left:-2%; bottom:-.14em; width:104%; height:.36em; z-index:-1; }
.hero .sub{ font-size:19px; line-height:1.55; color:#3a3a40; max-width:520px; margin:34px 0 28px; }
.hero .acts{ display:flex; flex-wrap:wrap; gap:14px; }

/* buttons */
.big-btn{ font-family:'Archivo'; font-weight:800; font-size:17px; text-transform:uppercase; text-decoration:none; padding:16px 30px; border-radius:100px; border:2px solid var(--ink); transition:.2s; display:inline-block; }
.big-btn.fill{ background:var(--ink); color:var(--paper); }
.big-btn.fill:hover{ transform:translate(-3px,-3px); box-shadow:5px 5px 0 var(--lime); }
.big-btn.line{ background:var(--paper); }
.big-btn.line:hover{ background:var(--lime); transform:translate(-3px,-3px); box-shadow:5px 5px 0 var(--ink); }

/* doodles */
.doodle{ position:absolute; color:var(--lime); pointer-events:none; }
.spin{ animation:spin 9s linear infinite; }
@keyframes spin{ to{ transform:rotate(360deg); } }
.bob{ animation:bob 3.2s ease-in-out infinite; }
@keyframes bob{ 50%{ transform:translateY(-12px); } }
@media (prefers-reduced-motion: reduce){ .spin,.bob,.marq .track{ animation:none !important; } }

/* collage */
.collage{ position:absolute; inset:0; pointer-events:none; }
.tile{ position:absolute; border:2px solid var(--ink); border-radius:14px; box-shadow:6px 6px 0 var(--ink); overflow:hidden; }
.tile .cap{ position:absolute; left:0; bottom:0; right:0; font-family:'Archivo'; font-weight:900; text-transform:uppercase; font-size:13px; padding:8px 10px; background:var(--ink); color:var(--paper); letter-spacing:.02em; }
@media(max-width:980px){ .collage,.doodle{ display:none; } }

/* big bleed word */
.bleed{ font-family:'Anton'; font-weight:400; font-size:clamp(120px,24vw,360px); line-height:.8; letter-spacing:-.02em; color:var(--ink); white-space:nowrap; margin:0; text-align:center; }
.bleed .o{ color:var(--paper); -webkit-text-stroke:2px var(--ink); }

/* section heads */
.eyebrow{ font-family:'Archivo'; font-weight:800; font-size:13px; letter-spacing:.12em; text-transform:uppercase; display:inline-block; background:var(--lime); border:2px solid var(--ink); padding:5px 12px; border-radius:100px; }
.h2{ font-family:'Archivo'; font-weight:900; font-size:clamp(34px,5vw,64px); line-height:.98; letter-spacing:-.03em; margin:18px 0 0; }
.h2 .g{ color:var(--gray); }
.lead{ font-size:18px; line-height:1.55; color:#3a3a40; margin:22px 0 0; max-width:620px; }
.page-head{ padding:70px 0 10px; }

/* steps */
.steps{ display:grid; grid-template-columns:repeat(auto-fit,minmax(250px,1fr)); border:2px solid var(--ink); border-radius:20px; overflow:hidden; background:#fff; }
.step{ padding:34px 28px; border-right:2px solid var(--ink); }
.step:last-child{ border-right:none; }
.step .no{ font-family:'Anton'; font-size:64px; line-height:.8; color:var(--lime); -webkit-text-stroke:2px var(--ink); }
.step h3{ font-family:'Archivo'; font-weight:800; font-size:21px; margin:16px 0 8px; }
.step p{ font-size:15px; line-height:1.55; color:#4a4a50; margin:0; }
@media(max-width:760px){ .step{ border-right:none; border-bottom:2px solid var(--ink); } .step:last-child{ border-bottom:none; } }

/* feature cards (neo-brutal) */
.feats{ display:grid; grid-template-columns:repeat(auto-fit,minmax(290px,1fr)); gap:18px; }
.feat{ border:2px solid var(--ink); border-radius:18px; background:#fff; padding:28px; transition:.2s; }
.feat:hover{ transform:translate(-4px,-4px); box-shadow:7px 7px 0 var(--ink); }
.feat .ic{ width:52px; height:52px; border:2px solid var(--ink); border-radius:13px; display:flex; align-items:center; justify-content:center; font-size:24px; background:var(--lime); margin-bottom:16px; }
.feat h3{ font-family:'Archivo'; font-weight:800; font-size:20px; margin:0 0 8px; }
.feat p{ font-size:15px; line-height:1.55; color:#4a4a50; margin:0; }

/* media frame */
.frame{ border:2px solid var(--ink); border-radius:20px; overflow:hidden; background:#000; box-shadow:10px 10px 0 var(--ink); }
.frame video,.frame img{ display:block; width:100%; }

/* stats */
.stats{ display:grid; grid-template-columns:repeat(auto-fit,minmax(180px,1fr)); gap:24px; }
.stat .num{ font-family:'Anton'; font-size:clamp(64px,9vw,120px); line-height:.85; color:var(--ink); }
.stat .num.lime{ color:var(--lime); -webkit-text-stroke:2px var(--ink); }
.stat .lbl{ font-family:'Archivo'; font-weight:700; font-size:15px; text-transform:uppercase; letter-spacing:.02em; margin-top:8px; }

/* templates */
.tpls{ display:grid; grid-template-columns:repeat(auto-fit,minmax(200px,1fr)); gap:18px; }
.tpl{ text-decoration:none; color:var(--ink); border:2px solid var(--ink); border-radius:14px; overflow:hidden; background:#fff; transition:.2s; }
.tpl:hover{ transform:translate(-4px,-4px); box-shadow:7px 7px 0 var(--ink); }
.tpl .mk{ height:150px; position:relative; }
.tpl .mk .pg{ position:absolute; top:10px; right:10px; font-family:'Archivo'; font-weight:800; font-size:11px; text-transform:uppercase; background:var(--paper); border:2px solid var(--ink); border-radius:8px; padding:3px 8px; }
.tpl .meta{ padding:14px 16px; border-top:2px solid var(--ink); }
.tpl .nm{ font-family:'Archivo'; font-weight:800; font-size:16px; }
.tpl .tg{ font-size:13px; color:#7a7a82; margin-top:3px; }

/* pricing */
.prices{ display:grid; grid-template-columns:repeat(auto-fit,minmax(300px,1fr)); gap:24px; align-items:stretch; }
.price{ border:2px solid var(--ink); border-radius:22px; padding:34px 30px; display:flex; flex-direction:column; background:#fff; }
.price.hl{ background:var(--ink); color:var(--paper); box-shadow:10px 10px 0 var(--lime); }
.price .tag{ font-family:'Archivo'; font-weight:800; text-transform:uppercase; font-size:12.5px; letter-spacing:.04em; display:inline-block; background:var(--lime); color:var(--ink); border:2px solid var(--ink); padding:4px 12px; border-radius:100px; align-self:flex-start; margin-bottom:14px; }
.price h3{ font-family:'Archivo'; font-weight:900; font-size:26px; margin:0 0 6px; }
.price .sub{ font-size:14.5px; opacity:.7; margin:0 0 20px; }
.price .amt{ font-family:'Anton'; font-size:64px; line-height:.85; }
.price .per{ font-family:'Archivo'; font-weight:700; font-size:15px; }
.price ul{ list-style:none; padding:0; margin:22px 0 0; display:flex; flex-direction:column; gap:12px; font-size:15px; }
.price li::before{ content:"✓ "; font-weight:900; color:var(--lime); -webkit-text-stroke:.5px var(--ink); }
.price.hl li::before{ color:var(--lime); }

/* faq */
.faq{ display:flex; flex-direction:column; gap:14px; }
.faq-item{ border:2px solid var(--ink); border-radius:16px; overflow:hidden; background:#fff; }
.faq-btn{ width:100%; text-align:left; background:none; border:none; cursor:pointer; padding:22px 24px; display:flex; align-items:center; justify-content:space-between; gap:18px; font-family:'Archivo'; font-weight:800; font-size:19px; color:var(--ink); }
.faq-icon{ pointer-events:none; flex:none; width:30px; height:30px; border:2px solid var(--ink); border-radius:9px; background:var(--lime); display:flex; align-items:center; justify-content:center; font-size:18px; font-weight:900; transition:transform .25s ease; }
.faq-panel{ max-height:0; overflow:hidden; transition:max-height .32s ease; }
.faq-panel p{ margin:0; padding:0 24px 24px; font-size:15.5px; line-height:1.65; color:#4a4a50; }

/* CTA */
.cta{ border:2px solid var(--ink); border-radius:26px; background:var(--lime); padding:70px 40px; text-align:center; box-shadow:10px 10px 0 var(--ink); }
.cta h2{ font-family:'Archivo'; font-weight:900; font-size:clamp(34px,5.5vw,72px); line-height:.95; letter-spacing:-.03em; margin:0 0 26px; }

/* footer */
footer{ background:var(--ink); color:var(--paper); margin-top:80px; }
.ft{ display:flex; flex-wrap:wrap; gap:30px; justify-content:space-between; padding:56px 0 40px; }
.ft a{ text-decoration:none; color:var(--paper); opacity:.7; }
.ft a:hover{ opacity:1; color:var(--lime); }
.ft .col h4{ font-family:'Archivo'; font-weight:800; text-transform:uppercase; font-size:13px; letter-spacing:.08em; margin:0 0 14px; opacity:.6; }
.ft .col div{ display:flex; flex-direction:column; gap:10px; font-size:14.5px; }
.ftlogo{ font-family:'Archivo'; font-weight:900; font-size:40px; letter-spacing:-.04em; }

/* legal pages */
.legal{ max-width:820px; margin:0 auto; padding:10px 28px 40px; }
.legal .upd{ font-family:'Archivo'; font-weight:700; font-size:13px; text-transform:uppercase; letter-spacing:.04em; color:#7a7a82; margin:0 0 10px; }
.legal h2{ font-family:'Archivo'; font-weight:900; font-size:23px; letter-spacing:-.02em; margin:36px 0 12px; }
.legal h2:first-of-type{ margin-top:10px; }
.legal p,.legal li{ font-size:16px; line-height:1.7; color:#2a2a30; }
.legal ul{ padding-left:20px; margin:8px 0; display:flex; flex-direction:column; gap:6px; }
.legal a{ color:var(--ink); text-decoration:underline; text-decoration-color:var(--lime); text-decoration-thickness:3px; }
.legal .note{ border:2px solid var(--ink); border-radius:14px; padding:16px 18px; background:#fff; font-size:14.5px; line-height:1.6; }
