:root{--bg:#f6f5fb;--ink:#1d1b2e;--mut:#6b6880;--vio:#6d4ef0;--vio-d:#5739d6;--teal:#1fb5a8;--card:#fff;--line:#e7e4f3;--soft:#efecfb}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Outfit',sans-serif;background:var(--bg);color:var(--ink);line-height:1.6;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4{font-weight:600;line-height:1.15;letter-spacing:-.02em}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:1140px;margin:0 auto;padding:0 24px}
.ind{background:linear-gradient(90deg,var(--vio),var(--teal));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
/* nav */
.nav{position:sticky;top:0;z-index:50;background:rgba(246,245,251,.8);backdrop-filter:blur(14px);transition:.3s}
.nav.scr{box-shadow:0 6px 30px rgba(109,78,240,.08)}
.nav-in{display:flex;align-items:center;justify-content:space-between;height:76px}
.logo{font-size:22px;font-weight:700;display:flex;align-items:center;gap:9px}
.logo .b{width:34px;height:34px;border-radius:11px;background:linear-gradient(135deg,var(--vio),var(--teal));color:#fff;display:grid;place-items:center;font-size:17px}
.menu{display:flex;align-items:center;gap:30px}
.menu a{font-size:15px;font-weight:500;color:var(--mut);transition:.2s}
.menu a:hover,.menu a.act{color:var(--vio)}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer}
.burger span{width:24px;height:2px;background:var(--ink);border-radius:2px}
.btn{display:inline-flex;align-items:center;gap:8px;padding:13px 26px;border-radius:14px;font-weight:600;font-size:15px;cursor:pointer;border:0;transition:.25s;font-family:inherit}
.btn-pr{background:linear-gradient(135deg,var(--vio),var(--vio-d));color:#fff;box-shadow:0 10px 26px rgba(109,78,240,.3)}
.btn-pr:hover{transform:translateY(-2px);box-shadow:0 14px 32px rgba(109,78,240,.4)}
.btn-gh{background:#fff;color:var(--vio);border:1.5px solid var(--line)}
.btn-gh:hover{border-color:var(--vio)}
.btn-lt{background:#fff;color:var(--vio)}
.btn-lt:hover{transform:translateY(-2px)}
/* hero */
.hero{padding:70px 0 96px;position:relative;overflow:hidden}
.hero::before{content:"";position:absolute;top:-160px;right:-120px;width:500px;height:500px;background:radial-gradient(circle,rgba(109,78,240,.18),transparent 70%);border-radius:50%}
.hero::after{content:"";position:absolute;bottom:-180px;left:-100px;width:440px;height:440px;background:radial-gradient(circle,rgba(31,181,168,.16),transparent 70%);border-radius:50%}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:center;position:relative}
.badge{display:inline-block;padding:7px 16px;background:var(--soft);border-radius:30px;font-size:13px;font-weight:600;color:var(--vio);margin-bottom:22px}
.hero h1{font-size:56px;margin-bottom:20px}
.lead{font-size:19px;color:var(--mut);margin-bottom:32px;max-width:520px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.hero-vis img{border-radius:26px;box-shadow:0 30px 70px rgba(109,78,240,.2)}
/* sections */
section{padding:88px 0}
.eyebrow{font-size:13px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--teal);margin-bottom:12px}
.sec-h{font-size:42px;margin-bottom:14px}
.sec-sub{color:var(--mut);font-size:18px;max-width:620px;margin-bottom:48px}
.feat{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.fcard{background:var(--card);border:1px solid var(--line);border-radius:22px;padding:34px 30px;transition:.3s}
.fcard:hover{transform:translateY(-6px);box-shadow:0 22px 48px rgba(109,78,240,.12)}
.fcard .ic{width:56px;height:56px;border-radius:16px;background:var(--soft);display:grid;place-items:center;font-size:26px;margin-bottom:18px}
.fcard h3{font-size:21px;margin-bottom:10px}
.fcard p{color:var(--mut);font-size:15px}
/* stats */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;background:linear-gradient(135deg,var(--vio),var(--teal));border-radius:28px;padding:48px 30px;color:#fff}
.stat{text-align:center}
.stat .num{font-size:48px;font-weight:700}
.stat .lbl{font-size:14px;opacity:.9;margin-top:4px}
/* modules */
.mods{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.mod{display:flex;gap:20px;background:var(--card);border:1px solid var(--line);border-radius:20px;padding:28px;transition:.25s}
.mod:hover{box-shadow:0 16px 40px rgba(109,78,240,.1);transform:translateY(-3px)}
.mod .n{flex-shrink:0;width:48px;height:48px;border-radius:14px;background:linear-gradient(135deg,var(--vio),var(--teal));color:#fff;display:grid;place-items:center;font-size:20px;font-weight:700}
.mod h3{font-size:19px;margin-bottom:5px}
.mod p{color:var(--mut);font-size:15px}
/* steps */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.step{text-align:center;background:var(--card);border:1px solid var(--line);border-radius:20px;padding:30px 22px;transition:.25s}
.step:hover{transform:translateY(-4px);box-shadow:0 16px 36px rgba(109,78,240,.1)}
.step .c{width:58px;height:58px;border-radius:50%;background:var(--soft);color:var(--vio);display:grid;place-items:center;font-size:24px;font-weight:700;margin:0 auto 16px}
.step h3{font-size:18px;margin-bottom:6px}
.step p{color:var(--mut);font-size:14px}
/* about/cert */
.abt{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.abt img{border-radius:24px;box-shadow:0 24px 56px rgba(109,78,240,.18)}
.abt h2{font-size:38px;margin-bottom:16px}
.abt p{color:var(--mut);margin-bottom:14px;font-size:16px}
.cert{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;background:var(--soft);border-radius:28px;padding:48px}
.cert img{border-radius:20px;box-shadow:0 20px 50px rgba(109,78,240,.16)}
.cert h2{font-size:34px;margin:12px 0}
.cert p{color:var(--mut);margin-bottom:16px}
.cert ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.cert li{padding-left:28px;position:relative}
.cert li::before{content:"✦";position:absolute;left:0;color:var(--teal)}
/* reviews */
.revs{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.rev{background:var(--card);border:1px solid var(--line);border-radius:22px;padding:30px;transition:.3s}
.rev:hover{transform:translateY(-5px);box-shadow:0 18px 44px rgba(109,78,240,.1)}
.rev .stars{color:var(--teal);margin-bottom:12px;letter-spacing:2px}
.rev p{color:var(--mut);font-style:italic;margin-bottom:18px}
.rev .who{display:flex;align-items:center;gap:12px}
.rev .av{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--vio),var(--teal));color:#fff;display:grid;place-items:center;font-weight:700}
.rev .who b{display:block;font-size:15px}
.rev .who span{font-size:13px;color:var(--mut)}
/* faq */
.faq{max-width:780px;margin:0 auto;display:flex;flex-direction:column;gap:14px}
.qa{background:var(--card);border:1px solid var(--line);border-radius:18px;overflow:hidden}
.qa .q{padding:22px 26px;font-weight:600;font-size:17px;cursor:pointer;display:flex;justify-content:space-between;align-items:center}
.qa .pl{color:var(--vio);font-size:24px;transition:.3s}
.qa.open .pl{transform:rotate(45deg)}
.qa .a{max-height:0;overflow:hidden;transition:max-height .35s}
.qa.open .a{max-height:240px}
.qa .a p{padding:0 26px 22px;color:var(--mut)}
/* cta */
.cta{background:linear-gradient(135deg,var(--vio),var(--teal));border-radius:32px;padding:66px 40px;text-align:center;color:#fff}
.cta h2{font-size:40px;margin-bottom:12px}
.cta p{opacity:.92;margin-bottom:28px;font-size:18px}
/* page hero */
.phero{padding:74px 0 50px;text-align:center;position:relative;overflow:hidden}
.phero::before{content:"";position:absolute;top:-120px;left:50%;transform:translateX(-50%);width:600px;height:340px;background:radial-gradient(ellipse,rgba(109,78,240,.14),transparent 70%)}
.phero h1{font-size:52px;margin-bottom:14px;position:relative}
.phero p{color:var(--mut);font-size:18px;max-width:600px;margin:0 auto;position:relative}
/* contacts */
.cgrid{display:grid;grid-template-columns:1fr 1fr;gap:40px;margin-bottom:40px}
.cinfo{display:flex;flex-direction:column;gap:22px}
.ci{display:flex;gap:16px;align-items:flex-start}
.ci .ic{width:46px;height:46px;border-radius:13px;background:var(--soft);display:grid;place-items:center;font-size:20px;flex-shrink:0}
.ci h4{font-size:16px;margin-bottom:3px}
.ci p{color:var(--mut);font-size:15px}
.cform{background:var(--card);border:1px solid var(--line);border-radius:24px;padding:36px;display:flex;flex-direction:column}
.cform label{font-weight:600;font-size:14px;margin:14px 0 6px}
.cform input,.cform textarea{padding:13px 16px;border:1px solid var(--line);border-radius:13px;font-family:inherit;font-size:15px;background:var(--bg)}
.cform textarea{min-height:100px;resize:vertical}
.cform button{margin-top:22px}
.form-msg{display:none;margin-top:16px;padding:14px;background:var(--soft);border-radius:13px;color:var(--vio-d);font-weight:600;text-align:center}
.form-msg.show{display:block}
.map{border-radius:24px;overflow:hidden;border:1px solid var(--line)}
.map iframe{width:100%;height:340px;border:0;display:block}
/* policy */
.policy{max-width:820px}
.policy p{color:var(--mut);margin-bottom:16px}
.policy h2{font-size:24px;margin:30px 0 12px}
.policy ul{margin:0 0 16px 22px;color:var(--mut)}
.policy li{margin-bottom:8px}
/* footer */
footer{background:#1d1b2e;color:#b8b4d0;padding:62px 0 30px;margin-top:40px}
.fgrid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;margin-bottom:36px}
footer .logo{color:#fff;margin-bottom:14px}
.fgrid p{color:#8f8ba8;font-size:15px;max-width:300px}
.fcol h4{font-size:16px;margin-bottom:14px;color:#fff}
.fcol a{display:block;color:#8f8ba8;font-size:14px;margin-bottom:9px;transition:.2s}
.fcol a:hover{color:var(--teal)}
.fbot{border-top:1px solid #322f4a;padding-top:24px;display:flex;justify-content:space-between;color:#7a7694;font-size:13px;flex-wrap:wrap;gap:10px}
/* cookie */
.cookie{position:fixed;left:24px;bottom:24px;max-width:420px;background:#fff;border:1px solid var(--line);border-radius:20px;padding:24px;box-shadow:0 20px 50px rgba(0,0,0,.16);z-index:100;transform:translateY(160%);transition:.45s;opacity:0}
.cookie.show{transform:translateY(0);opacity:1}
.cookie p{font-size:14px;color:var(--mut);margin-bottom:16px}
.ck-b{display:flex;gap:10px}
.ck-b .btn{padding:10px 18px;font-size:14px}
/* reveal */
.reveal{opacity:0;transform:translateY(28px);transition:.7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
@media(max-width:860px){.hero-grid,.abt,.cert,.cgrid{grid-template-columns:1fr}.feat,.stats,.mods,.steps,.revs{grid-template-columns:1fr 1fr}.hero h1{font-size:42px}.menu{position:fixed;top:76px;right:0;bottom:0;width:78%;max-width:320px;background:#fff;flex-direction:column;align-items:flex-start;padding:30px;gap:22px;transform:translateX(110%);transition:.35s;box-shadow:-10px 0 40px rgba(0,0,0,.1)}.menu.open{transform:none}.burger{display:flex}}
@media(max-width:560px){.feat,.stats,.mods,.steps,.revs{grid-template-columns:1fr}.sec-h{font-size:30px}.phero h1{font-size:36px}.fgrid{grid-template-columns:1fr}}

/* SVG icons replacing emoji — scale with container font-size */
.ico{width:1em;height:1em;display:inline-block;vertical-align:-0.125em;flex-shrink:0}
.ic .ico{width:1em;height:1em}
.b .ico{width:1.05em;height:1.05em}
.badge .ico{width:1.05em;height:1.05em;vertical-align:-0.18em;margin-right:2px}
.ci .ic .ico{width:1em;height:1em}
