/* ============================================================
   FrogCube — store styles
   Monochrome · two themes · large motion · no glow
   ============================================================ */

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{min-height:100vh;overflow-x:hidden}
img,svg{display:block;max-width:100%}
button{font:inherit;color:inherit;background:none;border:none;cursor:pointer}
a{color:inherit;text-decoration:none}
ul{list-style:none}
:focus-visible{outline:2px solid var(--fg);outline-offset:3px;border-radius:6px}

/* ---------- Themes ---------- */
:root{
  --easing:cubic-bezier(.16,1,.3,1);
  --easing-soft:cubic-bezier(.65,.05,.36,1);
  --r-xs:12px; --r-sm:16px; --r-md:24px; --r-lg:34px; --r-xl:46px; --r-pill:999px;
  --maxw:1280px;
  --t:.55s var(--easing);
}
[data-theme="dark"]{
  --bg:#0a0a0b; --bg-2:#101012; --fg:#f6f6f7; --fg-dim:#a7a7ad;
  --muted:rgba(255,255,255,.06); --muted-2:rgba(255,255,255,.1);
  --line:rgba(255,255,255,.12); --line-strong:rgba(255,255,255,.22);
  --card:#121214; --card-2:#17171a; --elev:#1d1d21;
  --solid-bg:#f6f6f7; --solid-fg:#0a0a0b;
  --shadow:0 40px 90px -45px rgba(0,0,0,.92);
  --grid-line:rgba(255,255,255,.04); --word:rgba(255,255,255,.035);
}
[data-theme="light"]{
  --bg:#f4f4f2; --bg-2:#ffffff; --fg:#0a0a0b; --fg-dim:#5c5c63;
  --muted:rgba(0,0,0,.04); --muted-2:rgba(0,0,0,.07);
  --line:rgba(0,0,0,.12); --line-strong:rgba(0,0,0,.24);
  --card:#ffffff; --card-2:#f0f0ee; --elev:#ffffff;
  --solid-bg:#0a0a0b; --solid-fg:#f4f4f2;
  --shadow:0 40px 80px -50px rgba(0,0,0,.4);
  --grid-line:rgba(0,0,0,.05); --word:rgba(0,0,0,.045);
}

body{
  background:var(--bg); color:var(--fg);
  font-family:'Manrope',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  font-size:16px; line-height:1.55; letter-spacing:-.01em;
  transition:background var(--t),color var(--t);
}

/* ---------- Cursor ---------- */
.cursor,.cursor-dot{position:fixed;top:0;left:0;border-radius:50%;pointer-events:none;z-index:9999;mix-blend-mode:difference}
.cursor{width:34px;height:34px;border:1.5px solid #fff;transform:translate(-50%,-50%);transition:width .3s var(--easing),height .3s var(--easing),background .3s,border-color .3s;will-change:transform}
.cursor-dot{width:5px;height:5px;background:#fff;transform:translate(-50%,-50%)}
.cursor.is-hover{width:62px;height:62px;background:rgba(255,255,255,.12);border-color:transparent}
@media (hover:none){.cursor,.cursor-dot{display:none}}

/* ---------- Preloader ---------- */
.preloader{position:fixed;inset:0;z-index:10000;background:var(--bg);display:grid;place-items:center;transition:opacity .7s var(--easing),visibility .7s}
.preloader.done{opacity:0;visibility:hidden}
.preloader__inner{display:flex;flex-direction:column;align-items:center;gap:22px}
.preloader__logo{font-family:'Unbounded';font-size:clamp(28px,6vw,52px);font-weight:800;letter-spacing:-.03em}
.preloader__logo b{font-weight:300}
.preloader__bar{width:200px;height:3px;background:var(--muted-2);border-radius:99px;overflow:hidden}
.preloader__bar i{display:block;height:100%;width:0;background:var(--fg);border-radius:99px;animation:load 1.4s var(--easing) forwards}
@keyframes load{0%{width:0}60%{width:75%}100%{width:100%}}

/* ---------- Background ---------- */
.bg{position:fixed;inset:0;z-index:-1;overflow:hidden}
.bg__grid{position:absolute;inset:-2px;
  background-image:linear-gradient(var(--grid-line) 1px,transparent 1px),linear-gradient(90deg,var(--grid-line) 1px,transparent 1px);
  background-size:64px 64px;
  -webkit-mask-image:radial-gradient(circle at 50% 30%,#000 0%,transparent 80%);
  mask-image:radial-gradient(circle at 50% 30%,#000 0%,transparent 80%)}
.bg__canvas{position:absolute;inset:0;width:100%;height:100%;opacity:.9}
.bg__noise{position:absolute;inset:0;opacity:.5;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.025'/%3E%3C/svg%3E")}
.bg__word{position:fixed;left:50%;top:46%;transform:translate(-50%,-50%);
  font-family:'Unbounded';font-weight:900;font-size:clamp(70px,21vw,360px);
  letter-spacing:-.05em;color:var(--word);white-space:nowrap;user-select:none;line-height:.8}
.bg__word span{display:inline-block;transition:transform .9s var(--easing),opacity .9s var(--easing),filter .9s var(--easing)}
.bg__word.swap span{transform:translateY(40px) scale(.94);opacity:0;filter:blur(8px)}

/* ---------- Scroll progress ---------- */
.scroll-progress{position:fixed;left:0;top:0;height:3px;width:100%;z-index:120}
.scroll-progress i{display:block;height:100%;width:0;background:var(--fg);transition:width .12s linear}

/* ---------- Layout ---------- */
.section{max-width:var(--maxw);margin:0 auto;padding:clamp(70px,11vw,150px) clamp(20px,5vw,40px)}
.section__head{max-width:680px;margin-bottom:clamp(34px,5vw,64px)}
.kicker{display:inline-block;font-size:13px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--fg-dim);
  padding:7px 14px;border:1px solid var(--line);border-radius:var(--r-pill);margin-bottom:22px}
.section__title{font-family:'Unbounded';font-weight:800;font-size:clamp(40px,8vw,92px);line-height:.95;letter-spacing:-.04em}
.section__lead{margin-top:18px;font-size:clamp(16px,2.2vw,19px);color:var(--fg-dim);max-width:560px}

/* ---------- Navigation (floating bar) ---------- */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;justify-content:center;padding:16px clamp(14px,4vw,28px);transition:padding .5s var(--easing)}
.nav__bar{display:flex;align-items:center;gap:18px;width:100%;max-width:var(--maxw);
  padding:9px 9px 9px 18px;border:1px solid var(--line);border-radius:var(--r-md);
  background:color-mix(in srgb,var(--bg) 64%,transparent);backdrop-filter:blur(20px) saturate(1.4);
  transition:background .5s,border-color .5s,box-shadow .5s,transform .5s var(--easing)}
.nav.scrolled{padding-top:10px}
.nav.scrolled .nav__bar{background:color-mix(in srgb,var(--bg) 86%,transparent);box-shadow:var(--shadow);border-color:var(--line-strong)}
.nav__brand{display:flex;align-items:center;gap:11px;font-family:'Unbounded';font-weight:700;font-size:18px;letter-spacing:-.03em}
.nav__logo{display:grid;place-items:center;color:var(--fg);transition:transform .6s var(--easing)}
.nav__brand:hover .nav__logo{transform:rotate(-12deg) scale(1.08)}
.nav__name b{font-weight:300}
.nav__name.big{font-size:34px}

.nav__links{display:flex;align-items:center;gap:2px;position:relative;margin:0 auto}
.nav__links a{position:relative;z-index:1;font-weight:600;font-size:15px;padding:10px 16px;border-radius:var(--r-pill);color:var(--fg-dim);transition:color .35s}
.nav__links a.active{color:var(--fg)}
.nav__pin{position:absolute;top:0;left:0;height:100%;border-radius:var(--r-pill);background:var(--muted);z-index:0;opacity:0;transition:transform .45s var(--easing),width .45s var(--easing),opacity .35s}
.nav__pin.show{opacity:1}

.nav__actions{display:flex;align-items:center;gap:10px}

/* IP pill */
.ip-pill{display:flex;align-items:center;gap:9px;padding:10px 15px;border:1px solid var(--line);border-radius:var(--r-pill);
  font-weight:600;font-size:14px;font-variant-numeric:tabular-nums;transition:border-color .3s,background .3s,color .3s}
.ip-pill:hover{border-color:var(--line-strong);background:var(--muted)}
.ip-pill__dot{width:8px;height:8px;border-radius:50%;background:var(--fg);position:relative;flex:0 0 auto}
.ip-pill__dot::after{content:"";position:absolute;inset:-4px;border-radius:50%;border:1px solid var(--fg);animation:ping 1.8s var(--easing) infinite;opacity:0}
@keyframes ping{0%{transform:scale(.6);opacity:.7}100%{transform:scale(1.7);opacity:0}}
.ip-pill__ico{width:16px;height:16px;opacity:.6;transition:opacity .3s}
.ip-pill:hover .ip-pill__ico{opacity:1}
.ip-pill.copied{background:var(--solid-bg);color:var(--solid-fg);border-color:transparent}
.ip-pill.copied .ip-pill__dot{background:var(--solid-fg)}

/* Theme toggle */
.theme-toggle{padding:0}
.theme-toggle__track{display:flex;align-items:center;width:62px;height:34px;border-radius:var(--r-pill);border:1px solid var(--line);background:var(--muted);padding:3px;transition:background .5s,border-color .5s}
.theme-toggle:hover .theme-toggle__track{border-color:var(--line-strong)}
.theme-toggle__thumb{position:relative;width:28px;height:28px;border-radius:50%;background:var(--fg);color:var(--bg);display:grid;place-items:center;transform:translateX(0);transition:transform .6s var(--easing),background .5s}
[data-theme="light"] .theme-toggle__thumb{transform:translateX(28px)}
.theme-toggle__thumb svg{position:absolute;width:16px;height:16px;transition:opacity .5s var(--easing),transform .6s var(--easing)}
.ico-sun{fill:none;stroke:var(--bg);stroke-width:2;stroke-linecap:round}
.ico-moon{fill:var(--bg)}
.theme-toggle__thumb .rays{transition:transform .6s var(--easing);transform-origin:center}
[data-theme="dark"] .ico-sun{opacity:0;transform:rotate(-90deg) scale(.4)}
[data-theme="dark"] .ico-moon{opacity:1;transform:rotate(0) scale(1)}
[data-theme="light"] .ico-sun{opacity:1;transform:rotate(0) scale(1)}
[data-theme="light"] .ico-moon{opacity:0;transform:rotate(90deg) scale(.4)}
[data-theme="light"] .ico-sun .rays{transform:rotate(45deg)}

.burger{display:none;flex-direction:column;gap:5px;width:44px;height:44px;border:1px solid var(--line);border-radius:14px;align-items:center;justify-content:center}
.burger i{width:18px;height:2px;background:var(--fg);border-radius:2px;transition:transform .4s var(--easing),opacity .3s}
.burger.on i:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.on i:nth-child(2){opacity:0}
.burger.on i:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ---------- Hero ---------- */
.hero{position:relative;min-height:100vh;display:flex;flex-direction:column;justify-content:center;max-width:var(--maxw);margin:0 auto;padding:120px clamp(20px,5vw,40px) 80px}
.hero__badge{display:inline-flex;align-items:center;gap:9px;align-self:flex-start;padding:9px 16px;border:1px solid var(--line);border-radius:var(--r-pill);font-size:14px;font-weight:600;background:color-mix(in srgb,var(--card) 60%,transparent);backdrop-filter:blur(6px)}
.hero__badge b{font-weight:800}
.pulse{position:relative;width:8px;height:8px;border-radius:50%;background:var(--fg)}
.pulse::after{content:"";position:absolute;inset:0;border-radius:50%;border:1.5px solid var(--fg);animation:ping 1.8s var(--easing) infinite;opacity:0}
.hero__title{font-family:'Unbounded';font-weight:800;font-size:clamp(48px,12vw,170px);line-height:.86;letter-spacing:-.05em;margin:26px 0}
.hero__title .line{display:block;overflow:hidden;padding-bottom:.04em}
.hero__title .word{display:inline-block;transform:translateY(110%);transition:transform 1.1s var(--easing)}
.hero.in .word{transform:translateY(0)}
.hero__title .line:nth-child(2) .word{transition-delay:.08s}
.hero__title .line:nth-child(3) .word{transition-delay:.16s}
.outline{-webkit-text-stroke:2px var(--fg);color:transparent;background:linear-gradient(var(--fg),var(--fg)) no-repeat;background-size:0% 100%;-webkit-background-clip:text;background-clip:text;transition:background-size 1s var(--easing) .4s}
.hero.in .outline{background-size:100% 100%}
.hero__sub{max-width:540px;font-size:clamp(16px,2.4vw,20px);color:var(--fg-dim);margin-bottom:34px}
.hero__sub b{color:var(--fg);font-weight:700}
.hero__cta{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:60px}
.hero__stats{display:flex;flex-wrap:wrap;gap:clamp(24px,5vw,60px)}
.stat b{display:block;font-family:'Unbounded';font-weight:700;font-size:clamp(30px,5vw,52px);line-height:1;letter-spacing:-.04em}
.stat span{font-size:14px;color:var(--fg-dim)}
.hero__scroll{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:10px;font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--fg-dim)}
.hero__scroll i{width:1px;height:46px;background:linear-gradient(var(--fg-dim),transparent);position:relative;overflow:hidden}
.hero__scroll i::after{content:"";position:absolute;top:0;left:0;width:100%;height:40%;background:var(--fg);animation:scrolldown 2s var(--easing) infinite}
@keyframes scrolldown{0%{transform:translateY(-100%)}100%{transform:translateY(280%)}}

/* ---------- Buttons ---------- */
.btn{position:relative;display:inline-flex;align-items:center;gap:10px;font-weight:700;font-size:15px;padding:15px 26px;border-radius:var(--r-pill);border:1px solid transparent;overflow:hidden;transition:transform .4s var(--easing),background .4s,color .4s,border-color .4s}
.btn svg{width:18px;height:18px}
.btn span{position:relative;z-index:1}
.btn--solid{background:var(--solid-bg);color:var(--solid-fg)}
.btn--solid svg{position:relative;z-index:1}
.btn--solid::before{content:"";position:absolute;inset:0;background:var(--fg-dim);transform:translateY(101%);transition:transform .5s var(--easing);z-index:0;opacity:.18}
.btn--solid:hover::before{transform:translateY(0)}
.btn--solid:hover{transform:translateY(-3px)}
.btn--solid:hover svg{transform:translateX(4px);transition:transform .4s var(--easing)}
.btn--ghost{background:transparent;color:var(--fg);border-color:var(--line-strong)}
.btn--ghost:hover{background:var(--fg);color:var(--bg);transform:translateY(-3px);border-color:var(--fg)}
.btn--block{width:100%;justify-content:center;padding:17px}
.btn[disabled]{opacity:.45;pointer-events:none}

/* ---------- Grids ---------- */
.grid{display:grid;gap:18px}
.grid--ranks{grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}
.grid--tokens{grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}
.grid--cases{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}
.grid--services{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}
.grid--social{grid-template-columns:repeat(auto-fit,minmax(290px,1fr))}

/* ---------- Card base ---------- */
.card{position:relative;background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:26px;transition:transform .5s var(--easing),border-color .5s,background .5s;overflow:hidden;will-change:transform}
.card:hover{border-color:var(--line-strong);transform:translateY(-6px)}
.card__shine{position:absolute;width:340px;height:340px;border-radius:50%;left:var(--mx,50%);top:var(--my,0);transform:translate(-50%,-50%);background:radial-gradient(circle,var(--muted-2),transparent 60%);opacity:0;transition:opacity .4s;pointer-events:none}
.card:hover .card__shine{opacity:1}
.tag{position:absolute;top:18px;right:18px;font-size:11px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;padding:6px 11px;border-radius:var(--r-pill);background:var(--fg);color:var(--bg)}
.card.is-top{border-color:var(--line-strong)}
.card.is-top::before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(135deg,var(--muted) 0 2px,transparent 2px 11px);opacity:.5;pointer-events:none}

/* Rank */
.rank{display:flex;flex-direction:column;gap:18px;min-height:340px}
.rank__top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.rank__tier{font-family:'Unbounded';font-size:13px;font-weight:600;color:var(--fg-dim)}
.rank__num{font-family:'Unbounded';font-weight:800;font-size:64px;line-height:.8;letter-spacing:-.05em;color:transparent;-webkit-text-stroke:1.4px var(--line-strong);transition:-webkit-text-stroke .5s,color .5s}
.card:hover .rank__num{color:var(--fg);-webkit-text-stroke:1.4px var(--fg)}
.rank__name{font-family:'Unbounded';font-weight:700;font-size:30px;letter-spacing:-.03em;line-height:1}
.rank__perks{display:flex;flex-direction:column;gap:9px}
.rank__perks li{display:flex;gap:10px;align-items:flex-start;font-size:14px;color:var(--fg-dim);line-height:1.4}
.rank__perks li svg{flex:0 0 auto;width:16px;height:16px;margin-top:2px}
.rank__perks li svg path{stroke:var(--fg);stroke-width:2.4;fill:none;stroke-linecap:round;stroke-linejoin:round}
.rank__foot,.case__foot,.service__foot{margin-top:auto;display:flex;align-items:center;justify-content:space-between;gap:14px;padding-top:18px;border-top:1px solid var(--line)}
.price{display:flex;flex-direction:column;line-height:1}
.price small{font-size:12px;color:var(--fg-dim);text-decoration:line-through;text-decoration-color:var(--line-strong)}
.price b{font-family:'Unbounded';font-weight:700;font-size:26px;letter-spacing:-.03em}
.buy{display:inline-flex;align-items:center;gap:7px;font-weight:700;font-size:14px;padding:11px 18px;border-radius:var(--r-pill);background:var(--solid-bg);color:var(--solid-fg);transition:transform .35s var(--easing),gap .35s}
.buy svg{width:15px;height:15px}
.buy:hover{transform:scale(1.05);gap:11px}

/* Token */
.token{display:flex;flex-direction:column;gap:14px;text-align:center;align-items:center;min-height:250px;justify-content:center}
.token__icon{width:64px;height:64px;display:grid;place-items:center;border:1px solid var(--line);border-radius:var(--r-md);transition:transform .6s var(--easing)}
.token:hover .token__icon{transform:rotate(8deg) scale(1.06)}
.token__icon svg{width:32px;height:32px}
.token__amt{font-family:'Unbounded';font-weight:700;font-size:34px;letter-spacing:-.04em;line-height:.9}
.token__amt span{font-size:14px;color:var(--fg-dim);font-family:'Manrope';font-weight:600;display:block;margin-top:4px}
.token__bonus{font-size:12px;font-weight:700;padding:5px 11px;border-radius:99px;background:var(--muted);color:var(--fg)}
.token .buy{margin-top:6px}

/* Case */
.case{display:flex;flex-direction:column;gap:20px;min-height:420px}
.case__art{position:relative;height:180px;border-radius:var(--r-md);border:1px solid var(--line);overflow:hidden;display:grid;place-items:center;background:var(--card-2);perspective:700px}
.case__cube{width:96px;height:96px;position:relative;transform-style:preserve-3d;animation:spin 14s linear infinite}
.case__cube i{position:absolute;inset:0;border:2px solid var(--fg);border-radius:14px;background:color-mix(in srgb,var(--card) 70%,transparent)}
.case__cube i:nth-child(1){transform:translateZ(48px)}
.case__cube i:nth-child(2){transform:rotateY(180deg) translateZ(48px)}
.case__cube i:nth-child(3){transform:rotateY(90deg) translateZ(48px)}
.case__cube i:nth-child(4){transform:rotateY(-90deg) translateZ(48px)}
.case__cube i:nth-child(5){transform:rotateX(90deg) translateZ(48px)}
.case__cube i:nth-child(6){transform:rotateX(-90deg) translateZ(48px)}
@keyframes spin{0%{transform:rotateX(-22deg) rotateY(0)}100%{transform:rotateX(-22deg) rotateY(360deg)}}
.case__rays{position:absolute;inset:0;background:repeating-conic-gradient(from 0deg,var(--muted) 0deg 8deg,transparent 8deg 16deg);opacity:.35;animation:rot 26s linear infinite}
@keyframes rot{to{transform:rotate(360deg)}}
.case__name{font-family:'Unbounded';font-weight:700;font-size:26px;letter-spacing:-.03em}
.case__desc{font-size:14px;color:var(--fg-dim)}
.case__drops{display:flex;flex-wrap:wrap;gap:7px}
.chip{font-size:12px;font-weight:600;padding:6px 11px;border:1px solid var(--line);border-radius:99px;color:var(--fg-dim)}

/* Service */
.service{display:flex;flex-direction:column;gap:16px;min-height:260px}
.service__icon{width:54px;height:54px;border-radius:var(--r-md);border:1px solid var(--line);display:grid;place-items:center;transition:background .4s,color .4s,transform .5s var(--easing)}
.service:hover .service__icon{background:var(--fg);color:var(--bg);transform:translateY(-3px)}
.service__icon svg{width:26px;height:26px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.service__name{font-family:'Unbounded';font-weight:700;font-size:24px;letter-spacing:-.03em}
.service__desc{font-size:14px;color:var(--fg-dim)}
.service__foot .price small{font-size:11px}

/* rate note */
.rate-note{display:inline-flex;align-items:center;gap:10px;margin-top:26px;padding:13px 20px;border:1px dashed var(--line-strong);border-radius:var(--r-pill);font-size:14px;color:var(--fg-dim)}
.rate-note svg{width:18px;height:18px;flex:0 0 auto}
.rate-note b{color:var(--fg)}

/* ---------- FAQ ---------- */
.faq__list{display:flex;flex-direction:column;gap:12px}
.faq-item{border:1px solid var(--line);border-radius:var(--r-md);background:var(--card);overflow:hidden;transition:border-color .4s,background .4s}
.faq-item:hover{border-color:var(--line-strong)}
.faq-item__q{width:100%;display:flex;align-items:center;justify-content:space-between;gap:18px;padding:24px 26px;text-align:left;font-family:'Unbounded';font-weight:600;font-size:clamp(17px,2.4vw,22px);letter-spacing:-.02em}
.faq-item__q i{flex:0 0 auto;width:26px;height:26px;position:relative}
.faq-item__q i::before,.faq-item__q i::after{content:"";position:absolute;background:var(--fg);border-radius:2px;transition:transform .45s var(--easing)}
.faq-item__q i::before{top:50%;left:0;width:100%;height:2px;transform:translateY(-50%)}
.faq-item__q i::after{left:50%;top:0;width:2px;height:100%;transform:translateX(-50%)}
.faq-item.open .faq-item__q i::after{transform:translateX(-50%) scaleY(0)}
.faq-item__a{max-height:0;overflow:hidden;transition:max-height .5s var(--easing)}
.faq-item__a p{padding:0 26px 26px;color:var(--fg-dim);max-width:760px}

/* ---------- Support / social ---------- */
.social{display:flex;align-items:center;gap:16px;padding:24px;border:1px solid var(--line);border-radius:var(--r-lg);background:var(--card);transition:transform .5s var(--easing),background .5s,color .5s,border-color .5s;will-change:transform}
.social:hover{transform:translateY(-6px);background:var(--fg);color:var(--bg);border-color:var(--fg)}
.social__ico{width:58px;height:58px;flex:0 0 auto;border-radius:var(--r-md);border:1px solid var(--line);display:grid;place-items:center;transition:background .5s,color .5s,border-color .5s}
.social:hover .social__ico{background:var(--bg);color:var(--fg);border-color:transparent}
.social__ico svg{width:30px;height:30px;fill:currentColor}
.social__meta{flex:1;min-width:0}
.social__meta h3{font-family:'Unbounded';font-weight:700;font-size:21px;letter-spacing:-.02em}
.social__meta span{font-size:14px;opacity:.7}
.social__go{display:inline-flex;align-items:center;gap:6px;font-weight:700;font-size:14px;white-space:nowrap}
.social__go svg{width:16px;height:16px;transition:transform .4s var(--easing)}
.social:hover .social__go svg{transform:translate(3px,-3px)}

/* ---------- Footer ---------- */
.footer{max-width:var(--maxw);margin:40px auto 0;padding:60px clamp(20px,5vw,40px) 36px;border-top:1px solid var(--line)}
.footer__top{display:flex;flex-wrap:wrap;gap:50px;justify-content:space-between;margin-bottom:50px}
.footer__brand p{margin-top:14px;color:var(--fg-dim);max-width:320px}
.footer__brand b{color:var(--fg)}
.footer__social{display:flex;gap:10px;margin-top:20px}
.footer__social a{width:44px;height:44px;border:1px solid var(--line);border-radius:var(--r-sm);display:grid;place-items:center;transition:background .4s,color .4s,transform .4s var(--easing)}
.footer__social a:hover{background:var(--fg);color:var(--bg);transform:translateY(-3px)}
.footer__social svg{width:20px;height:20px;fill:currentColor}
.footer__cols{display:flex;gap:56px;flex-wrap:wrap}
.footer__cols h4{font-size:13px;letter-spacing:.12em;text-transform:uppercase;color:var(--fg-dim);margin-bottom:16px}
.footer__cols a{display:block;padding:5px 0;font-weight:600;color:var(--fg);opacity:.8;transition:opacity .3s,transform .3s var(--easing)}
.footer__cols a:hover{opacity:1;transform:translateX(4px)}
.footer__bottom{display:flex;flex-wrap:wrap;gap:14px;justify-content:space-between;padding-top:26px;border-top:1px solid var(--line);font-size:13px;color:var(--fg-dim)}
.footer__stripe b{color:var(--fg);font-weight:800;letter-spacing:-.02em}

/* ---------- Modal (centered) ---------- */
.modal{position:fixed;inset:0;z-index:200;display:grid;place-items:center;padding:18px;visibility:hidden;pointer-events:none}
.modal.open{visibility:visible;pointer-events:auto}
.modal__backdrop{position:absolute;inset:0;background:rgba(0,0,0,.55);opacity:0;transition:opacity .45s var(--easing);backdrop-filter:blur(5px)}
.modal.open .modal__backdrop{opacity:1}
.modal__card{position:relative;width:min(480px,100%);max-height:90vh;display:flex;flex-direction:column;background:var(--bg-2);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow);overflow:hidden;
  transform:translateY(28px) scale(.96);opacity:0;transition:transform .55s var(--easing),opacity .4s}
.modal.open .modal__card{transform:none;opacity:1}
.modal__card.is-wide{width:min(780px,100%)}
.modal__close{position:absolute;top:16px;right:16px;z-index:5;width:42px;height:42px;border:1px solid var(--line);border-radius:var(--r-pill);display:grid;place-items:center;background:var(--bg-2);transition:background .3s,transform .4s var(--easing)}
.modal__close:hover{background:var(--muted);transform:rotate(90deg)}
.modal__close svg{width:20px;height:20px}
.modal__content{overflow-y:auto;overscroll-behavior:contain}
.modal__content::-webkit-scrollbar{width:9px}
.modal__content::-webkit-scrollbar-thumb{background:var(--line-strong);border-radius:99px;border:3px solid var(--bg-2)}

/* purchase modal */
.buy-modal{padding:30px;display:flex;flex-direction:column;gap:18px}
.buy-head .kicker{margin-bottom:14px}
.buy-head h3{font-family:'Unbounded';font-weight:700;font-size:26px;letter-spacing:-.03em;line-height:1.05;padding-right:40px}
.po{border:1px solid var(--line);border-radius:var(--r-md);padding:16px;background:var(--card);display:flex;gap:14px;align-items:center}
.po__badge{width:50px;height:50px;flex:0 0 auto;border-radius:var(--r-sm);border:1px solid var(--line);display:grid;place-items:center;font-family:'Unbounded';font-weight:800;font-size:20px}
.po__meta{flex:1;min-width:0}
.po__meta h4{font-family:'Unbounded';font-weight:700;font-size:16px;letter-spacing:-.02em}
.po__meta span{font-size:13px;color:var(--fg-dim)}
.po__price{font-family:'Unbounded';font-weight:700;font-size:18px;white-space:nowrap}

.field{display:flex;flex-direction:column;gap:8px}
.field label{font-size:13px;font-weight:600;color:var(--fg-dim)}
.field label .req{color:var(--fg);opacity:.45;font-weight:500}
.field input{width:100%;padding:14px 16px;border:1px solid var(--line);border-radius:var(--r-sm);background:var(--card);color:var(--fg);font:inherit;font-weight:600;transition:border-color .3s,background .3s}
.field input::placeholder{color:var(--fg-dim);font-weight:500}
.field input:focus{outline:none;border-color:var(--fg);background:var(--bg-2)}
.field.err input{border-color:var(--fg);animation:shake .4s var(--easing)}
.field.err .field__msg{font-weight:700}
@keyframes shake{10%,90%{transform:translateX(-2px)}30%,70%{transform:translateX(4px)}50%{transform:translateX(-7px)}}
.field__msg{font-size:12px;color:var(--fg);opacity:.85;min-height:14px}

.row{display:flex;gap:14px;flex-wrap:wrap;align-items:flex-end}
.row .field{flex:1;min-width:140px}

.stepper{display:flex;align-items:center;border:1px solid var(--line);border-radius:var(--r-pill);width:fit-content;overflow:hidden}
.stepper button{width:44px;height:46px;display:grid;place-items:center;font-size:20px;font-weight:700;transition:background .25s}
.stepper button:hover{background:var(--muted)}
.stepper input{width:74px;text-align:center;border:none;background:transparent;font:inherit;font-weight:800;font-family:'Unbounded';color:var(--fg)}
.stepper input::-webkit-outer-spin-button,.stepper input::-webkit-inner-spin-button{-webkit-appearance:none}

/* Duration selector (Segmented Control) */
.duration-select{display:flex;border:1px solid var(--line);border-radius:var(--r-sm);overflow:hidden;background:var(--card)}
.duration-btn{flex:1;padding:12px 10px;text-align:center;font-size:13px;font-weight:700;color:var(--fg-dim);border-right:1px solid var(--line);transition:background .3s,color .3s;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;cursor:pointer}
.duration-btn:last-child{border-right:none}
.duration-btn:hover{background:var(--muted);color:var(--fg)}
.duration-btn.active{background:var(--fg);color:var(--bg)}
.badge-discount{font-size:10px;font-weight:800;padding:2px 6px;border-radius:4px;background:var(--muted);color:var(--fg)}
.duration-btn.active .badge-discount{background:color-mix(in srgb,var(--bg) 18%,transparent);color:var(--bg)}

/* payment methods (Stripe) */
.pay{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
.pay button{display:flex;align-items:center;gap:11px;padding:13px 14px;border:1px solid var(--line);border-radius:var(--r-sm);font-weight:700;font-size:14px;color:var(--fg);transition:border-color .3s,background .3s}
.pay button:hover{border-color:var(--line-strong)}
.pay button.active{border-color:var(--fg);background:var(--muted)}
.pm-ico{width:40px;height:26px;flex:0 0 auto;border:1px solid var(--line);border-radius:7px;display:grid;place-items:center;background:var(--bg-2)}
.pm-ico svg{width:26px;height:16px;fill:var(--fg)}
.pay button .pm-check{margin-left:auto;width:18px;height:18px;border-radius:50%;border:1.6px solid var(--line-strong);display:grid;place-items:center;transition:.3s}
.pay button.active .pm-check{border-color:var(--fg);background:var(--fg)}
.pay button.active .pm-check::after{content:"";width:7px;height:7px;border-radius:50%;background:var(--bg)}

.stripe-badge{display:flex;align-items:center;justify-content:center;gap:7px;font-size:12px;color:var(--fg-dim);padding-top:2px}
.stripe-badge svg{width:14px;height:14px}
.stripe-badge b{color:var(--fg);font-weight:800;letter-spacing:-.02em;font-size:13px}

.agree{display:flex;gap:11px;align-items:flex-start;font-size:13px;color:var(--fg-dim);line-height:1.45;cursor:pointer}
.agree input{appearance:none;-webkit-appearance:none;flex:0 0 auto;width:20px;height:20px;margin-top:1px;border:1.6px solid var(--line-strong);border-radius:7px;cursor:pointer;transition:.25s;position:relative}
.agree input:checked{background:var(--fg);border-color:var(--fg)}
.agree input:checked::after{content:"";position:absolute;left:6px;top:2px;width:5px;height:10px;border:solid var(--bg);border-width:0 2px 2px 0;transform:rotate(45deg)}
.agree a{color:var(--fg);text-decoration:underline;text-underline-offset:2px}
.agree.err{color:var(--fg)}
.agree.err input{animation:shake .4s var(--easing)}

.summary{display:flex;flex-direction:column;gap:9px;padding-top:4px}
.lineitem{display:flex;justify-content:space-between;font-size:14px;color:var(--fg-dim)}
.lineitem b{color:var(--fg);font-weight:700}
.divider{height:1px;background:var(--line)}
.total-row{display:flex;align-items:baseline;justify-content:space-between;margin-top:2px}
.total-row span{font-size:14px;color:var(--fg-dim)}
.total-row b{font-family:'Unbounded';font-weight:800;font-size:32px;letter-spacing:-.04em}
.buy-hint{text-align:center;font-size:12px;color:var(--fg-dim)}

/* success */
.success{display:flex;flex-direction:column;align-items:center;text-align:center;gap:16px;padding:50px 30px}
.success__check{width:88px;height:88px;border-radius:50%;border:2px solid var(--fg);display:grid;place-items:center}
.success__check svg{width:42px;height:42px}
.success__check path{stroke:var(--fg);stroke-width:3;fill:none;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:40;stroke-dashoffset:40;animation:draw .6s var(--easing) .15s forwards}
@keyframes draw{to{stroke-dashoffset:0}}
.success h3{font-family:'Unbounded';font-weight:700;font-size:25px}
.success p{color:var(--fg-dim);max-width:320px}
.success b{color:var(--fg)}

/* legal */
.legal{padding:38px 36px 40px}
.legal__kicker{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--fg-dim)}
.legal h2{font-family:'Unbounded';font-weight:700;font-size:clamp(24px,4vw,34px);letter-spacing:-.03em;margin:10px 0 6px;padding-right:40px}
.legal__date{font-size:13px;color:var(--fg-dim);margin-bottom:24px}
.legal h3{font-family:'Unbounded';font-weight:600;font-size:17px;letter-spacing:-.02em;margin:26px 0 10px}
.legal p{color:var(--fg-dim);margin-bottom:10px;line-height:1.6}
.legal ul{margin:0 0 10px;padding-left:4px;display:flex;flex-direction:column;gap:7px}
.legal li{position:relative;padding-left:20px;color:var(--fg-dim);line-height:1.55}
.legal li::before{content:"";position:absolute;left:2px;top:9px;width:6px;height:6px;border-radius:2px;background:var(--fg)}
.legal b{color:var(--fg)}

/* ---------- Toast ---------- */
.toast{position:fixed;left:50%;bottom:30px;transform:translate(-50%,140%);z-index:300;display:flex;align-items:center;gap:11px;padding:14px 22px;border-radius:var(--r-pill);background:var(--solid-bg);color:var(--solid-fg);font-weight:700;font-size:14px;box-shadow:var(--shadow);transition:transform .6s var(--easing);max-width:90vw}
.toast.show{transform:translate(-50%,0)}
.toast svg{width:18px;height:18px;flex:0 0 auto}

/* ---------- Reveal ---------- */
.reveal{opacity:0;transform:translateY(36px);transition:opacity .9s var(--easing),transform .9s var(--easing)}
.reveal.in{opacity:1;transform:none}
.card.reveal,.social.reveal{transition-delay:var(--d,0ms)}

@media (max-width:1120px){
  .nav__links{display:none}
  .burger{display:flex}
  .nav__bar{padding:9px 9px 9px 16px}
  .nav__links.mobile{display:flex;position:fixed;inset:0;flex-direction:column;justify-content:center;align-items:center;gap:12px;background:var(--bg);z-index:99;transform:translateY(-100%);transition:transform .6s var(--easing);overflow-y:auto;padding:60px 0;box-sizing:border-box}
  .nav__links.mobile.show{transform:translateY(0)}
  .nav__links.mobile a{font-family:'Unbounded';font-size:28px;color:var(--fg);padding:10px 20px;flex-shrink:0}
  .nav__pin{display:none}
  .ip-pill__text{display:none}
}
@media (max-width:560px){
  .hero__title{font-size:clamp(32px,9vw,48px)}
  .hero__stats{gap:24px}
  .ip-pill__text{display:none}
  .ip-pill{padding:9px 11px}
  .nav__bar{padding:6px 6px 6px 12px;gap:8px}
  .nav__brand{font-size:16px;gap:8px}
  .nav__actions{gap:6px}
  .theme-toggle__track{width:52px;height:30px;padding:2px}
  .theme-toggle__thumb{width:24px;height:24px}
  [data-theme="light"] .theme-toggle__thumb{transform:translateX(22px)}
  .burger{width:38px;height:38px;border-radius:10px}
  .pay{grid-template-columns:1fr}
  .buy-modal,.legal{padding:26px 22px}
}
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;transition-duration:.001ms!important}
  html{scroll-behavior:auto}
}

/* ===== Language toggle (RU/EN) ===== */
.lang-toggle{display:inline-flex;align-items:center;justify-content:center;min-width:44px;height:38px;padding:0 13px;border-radius:12px;border:1px solid rgba(125,125,125,.28);background:transparent;color:inherit;font-family:Manrope,system-ui,sans-serif;font-weight:800;font-size:13px;letter-spacing:.05em;cursor:pointer;transition:transform .18s ease,background .18s ease,border-color .18s ease}
.lang-toggle:hover{background:rgba(125,125,125,.14);border-color:rgba(125,125,125,.5);transform:translateY(-1px)}
.lang-toggle:active{transform:translateY(0)}

/* ===== Refined navigation (чище и легче) ===== */
.nav__bar{gap:14px;padding:9px 10px 9px 18px;background:color-mix(in srgb,var(--bg) 72%,transparent);backdrop-filter:saturate(140%) blur(16px);-webkit-backdrop-filter:saturate(140%) blur(16px);border:1px solid var(--line);border-radius:16px}
.nav.scrolled .nav__bar{background:color-mix(in srgb,var(--bg) 90%,transparent)}
.nav__brand{font-family:'Manrope',system-ui,sans-serif;font-weight:700;font-size:16px;letter-spacing:.01em}
.nav__name b{font-weight:800}
.nav__links a{font-family:'Manrope',system-ui,sans-serif;font-weight:500;font-size:14px;letter-spacing:0;padding:9px 14px;color:var(--fg-dim)}
.nav__links a.active{font-weight:600;color:var(--fg)}
.lang-toggle{font-family:'Manrope',system-ui,sans-serif;font-weight:700;font-size:12px}

/* ===== Крупные заголовки чуть легче (не "пиздец жирный") ===== */
.section__title{font-weight:700;font-size:clamp(32px,5.5vw,64px);letter-spacing:-.03em}
.hero__title{font-weight:700;font-size:clamp(40px,9vw,124px);letter-spacing:-.045em}
.rank__name,.case__name,.service__name{font-weight:600}

/* ===== Баннер «Создать тикет» (раздел поддержки) ===== */
.ticket-cta{display:flex;align-items:center;gap:18px;max-width:var(--maxw);margin:0 auto 22px;padding:18px 22px;border:1px solid var(--line);border-radius:18px;background:color-mix(in srgb,var(--bg) 55%,transparent);text-decoration:none;color:inherit;transition:transform .25s,border-color .25s}
.ticket-cta:hover{transform:translateY(-2px);border-color:var(--line-strong)}
.ticket-cta__ico{flex:0 0 auto;width:50px;height:50px;border-radius:13px;display:grid;place-items:center;background:#229ED9;color:#fff}
.ticket-cta__body{flex:1;min-width:0}
.ticket-cta__body b{display:block;font-size:18px;margin-bottom:2px}
.ticket-cta__body span{opacity:.72;font-size:14px;line-height:1.4}
.ticket-cta__btn{flex:0 0 auto;white-space:nowrap;padding:11px 20px;border-radius:12px;background:var(--fg);color:var(--bg);font-weight:700;font-size:14px}
@media(max-width:640px){.ticket-cta{flex-direction:column;text-align:center}}
