:root{
  --c1:#ff5e9c; --c2:#ff8a5c; --c3:#a06bff; --ink:#3a2540; --ink-soft:#7a5f86;
  --card:#fffafd; --shadow:0 24px 60px -18px rgba(160,60,120,.4);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:"Trebuchet MS","Segoe UI",system-ui,-apple-system,sans-serif;color:var(--ink);
  background:linear-gradient(-45deg,#ffd9e8,#ffc7d6,#ffd8c2,#e9d4ff,#ffd9e8);background-size:400% 400%;
  animation:bgshift 20s ease infinite;min-height:100vh}
@keyframes bgshift{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}

a{color:var(--c1);text-decoration:none}
.nav{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;background:rgba(255,255,255,.7);backdrop-filter:blur(10px);position:sticky;top:0;z-index:10}
.nav .brand{font-weight:800;font-size:18px;color:var(--ink)}
.nav .navlinks{display:flex;gap:16px;align-items:center}
.nav .navlinks a{color:var(--ink-soft);font-weight:600;font-size:15px}

.btn{display:inline-block;cursor:pointer;border:none;font-family:inherit;font-weight:700;color:#fff;
  background:linear-gradient(120deg,var(--c1),var(--c2));padding:15px 32px;font-size:17px;border-radius:50px;
  box-shadow:0 12px 30px -10px rgba(255,94,156,.8);transition:transform .12s,filter .12s}
.btn:hover{transform:translateY(-2px) scale(1.03);filter:brightness(1.04)}
.btn:active{transform:translateY(1px)}
.btn.small{padding:9px 18px;font-size:14px}
.btn.full{width:100%;text-align:center}
.btn.ghost{background:#fff;color:var(--c1);box-shadow:0 8px 22px -12px rgba(255,94,156,.6);border:2px solid #ffd9e8}

/* ---------- лендинг ---------- */
.hero-land{max-width:820px;margin:0 auto;padding:70px 22px 40px;text-align:center}
.hero-land .pre{letter-spacing:5px;text-transform:uppercase;color:var(--ink-soft);font-size:14px;margin-bottom:16px}
.hero-land h1{font-size:clamp(30px,6vw,56px);line-height:1.08;font-weight:800;
  background:linear-gradient(90deg,var(--c1),var(--c3),var(--c2),var(--c1));background-size:300% auto;
  -webkit-background-clip:text;background-clip:text;color:transparent;animation:flow 7s linear infinite}
@keyframes flow{to{background-position:300% center}}
.hero-land .lead{color:var(--ink-soft);font-size:clamp(16px,2.4vw,20px);max-width:640px;margin:22px auto 30px;line-height:1.5}
.land-steps{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-top:42px}
.land-steps .ls{background:rgba(255,255,255,.7);border-radius:14px;padding:14px 18px;font-weight:600;color:var(--ink);font-size:15px}
.land-steps .ls b{color:var(--c1)}

/* ---------- тарифы ---------- */
.pricing{max-width:820px;margin:30px auto;padding:30px 22px 50px;text-align:center}
.pricing h2{font-size:30px;margin-bottom:26px}
.plans{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px}
.plan{background:var(--card);border-radius:22px;padding:30px 26px;box-shadow:var(--shadow);position:relative;text-align:left;border:2px solid transparent}
.plan.pro{border-color:var(--c4,#ffd36e);background:linear-gradient(180deg,#fff,#fff6fb)}
.plan .pbadge{position:absolute;top:-12px;right:20px;background:linear-gradient(120deg,var(--c1),var(--c2));color:#fff;font-size:12px;font-weight:800;padding:5px 14px;border-radius:20px}
.plan .pname{font-size:18px;font-weight:800;color:var(--ink-soft)}
.plan .pprice{font-size:38px;font-weight:900;margin:6px 0 16px;color:var(--ink)}
.plan .pprice span{font-size:14px;font-weight:600;color:var(--ink-soft)}
.plan ul{list-style:none;display:flex;flex-direction:column;gap:9px;margin-bottom:20px}
.plan ul li{padding-left:24px;position:relative;color:var(--ink);font-size:15px}
.plan ul li::before{content:"✓";position:absolute;left:0;color:var(--c1);font-weight:800}
.plan .curplan{font-weight:700;color:#1f9d57;background:#e7f9ee;display:inline-block;padding:9px 18px;border-radius:30px}
.land-foot{text-align:center;color:var(--ink-soft);padding:30px;font-size:14px}

/* ---------- вход/регистрация ---------- */
.authwrap{display:flex;align-items:center;justify-content:center;padding:50px 20px}
.authbox{background:var(--card);border-radius:24px;padding:38px 32px;width:380px;max-width:100%;box-shadow:var(--shadow)}
.authbox.center{text-align:center}
.authbox h1{font-size:24px;margin-bottom:18px}
.authbox input{width:100%;padding:14px 16px;border:2px solid #ffe1ec;border-radius:14px;font-size:16px;font-family:inherit;margin-bottom:12px;outline:none;transition:border-color .2s}
.authbox input:focus{border-color:var(--c1)}
.authbox .muted{color:var(--ink-soft);font-size:14px;margin:10px 0;line-height:1.5}
.authbox .muted.center{text-align:center;margin-top:18px}
.authbox .err{background:#ffe7ef;color:#e0356b;padding:11px 14px;border-radius:12px;font-size:14px;margin-bottom:14px;text-align:center}
.tabs{display:flex;gap:8px;margin-bottom:18px;background:#fff0f6;padding:5px;border-radius:14px}
.tab{flex:1;border:none;background:transparent;font-family:inherit;font-weight:700;font-size:14px;color:var(--ink-soft);padding:10px;border-radius:10px;cursor:pointer;transition:.15s}
.tab.on{background:#fff;color:var(--c1);box-shadow:0 4px 12px -6px rgba(255,94,156,.5)}
.loading{text-align:center;color:var(--ink-soft);padding:80px 20px;font-size:16px}

.forgot{margin:14px 0 6px;text-align:left}
.forgot summary{cursor:pointer;color:var(--c1);font-weight:600;font-size:14px;list-style:none}
.forgot summary::-webkit-details-marker{display:none}
.forgot .faq-a{color:var(--ink-soft);font-size:13.5px;line-height:1.5;margin-top:8px}
.forgot code{background:#fff0f6;color:#c43d76;padding:1px 5px;border-radius:5px;font-size:12px}
.legal{max-width:760px;margin:0 auto;padding:30px 20px 60px;color:var(--ink);line-height:1.6}
.legal h1{font-size:clamp(24px,6vw,34px);margin-bottom:16px}
.legal h3{font-size:18px;margin:22px 0 6px;color:var(--ink)}
.legal p{color:var(--ink-soft);margin-bottom:8px}
.legal-note{background:#fff3df;border:1px solid #ffd36e;border-radius:12px;padding:12px 14px;color:#8a6a2f;font-size:14px;margin-bottom:22px}
.legal-foot{margin-top:30px;border-top:1px dashed #f0dcea;padding-top:16px;font-size:14px}
.land-foot a{color:var(--c1);font-weight:600}

@media(max-width:560px){
  .nav{padding:11px 14px}
  .nav .brand{font-size:15px}
  .nav .navlinks{gap:9px;font-size:13px}
  .nav .navlinks a{font-size:13px}
  .authwrap{padding:28px 14px}
  .authbox{padding:28px 20px;border-radius:20px}
  .hero-land{padding:40px 16px 30px}
}
