/* ============================================================
   Брат VPS — design system
   ============================================================ */

:root{
  /* palette */
  --bg:#0b0f14;
  --surface:#10161f;
  --surface-2:#0d1420;
  --border:#1e293b;
  --muted:#778196;
  --text:#e8eef9;
  --blue:#3b82f6;
  --cyan:#22d3ee;
  --grad:linear-gradient(135deg,#3b82f6,#22d3ee);
  --green:#10b981;
  --amber:#f59e0b;
  --red:#ef4444;
  --btn2-bg:#17202b;
  --btn2-border:#233143;
  --badge-bg:#0d1420;
  --badge-border:#223247;
  --ok-border:#1c4634;
  --ok-text:#b6f0d6;
  --ok-bg:#0c1a14;
  --sec-border:#1e3a5f;
  --sec-bg:linear-gradient(180deg,#0b1622,#0a1320);
  --shadow:0 10px 30px rgba(0,0,0,.25);
  --r-card:16px;
  --r-btn:12px;
  --r-pill:999px;
  --maxw:1100px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--bg);
  color:var(--text);
  font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  font-size:16px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
/* ambient glow */
body::before{
  content:"";
  position:fixed;
  inset:0;
  background:
    radial-gradient(900px 480px at 78% -8%, rgba(34,211,238,.10), transparent 60%),
    radial-gradient(800px 500px at 8% 4%, rgba(59,130,246,.12), transparent 55%);
  pointer-events:none;
  z-index:0;
}
a{color:inherit;text-decoration:none}
img,svg{display:block;max-width:100%}
button{font-family:inherit}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px;position:relative;z-index:1}

/* ---------- typography helpers ---------- */
.eyebrow{
  font-size:13px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;
  color:var(--cyan);margin:0 0 10px;
}
.section-head{max-width:680px;margin:0 0 30px}
.section-head h2{
  font-size:clamp(26px,3.6vw,38px);font-weight:800;letter-spacing:-.02em;
  margin:0 0 10px;line-height:1.12;
}
.section-head p{margin:0;color:var(--muted);font-size:17px}
.accent{color:var(--cyan)}
section{padding:64px 0;position:relative}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  height:48px;padding:0 22px;border-radius:var(--r-btn);
  font-weight:600;font-size:15px;border:1px solid transparent;cursor:pointer;
  transition:transform .15s ease, box-shadow .2s ease, border-color .2s ease, background .2s ease;
  white-space:nowrap;
}
.btn:active{transform:translateY(1px)}
.btn-primary{
  background:var(--grad);color:#04121f;border:none;
  box-shadow:0 8px 24px rgba(34,211,238,.22);
}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 14px 34px rgba(34,211,238,.34)}
.btn-secondary{background:var(--btn2-bg);color:var(--text);border-color:var(--btn2-border)}
.btn-secondary:hover{transform:translateY(-2px);border-color:#33455c}
.btn-ghost{background:transparent;color:var(--text);border-color:var(--border)}
.btn-ghost:hover{border-color:#33455c;background:rgba(255,255,255,.02)}
.btn-tg{
  background:linear-gradient(135deg,#2aabee,#229ed9);color:#fff;border:none;
  box-shadow:0 8px 22px rgba(34,158,217,.28);
}
.btn-tg:hover{transform:translateY(-2px)}
.btn-block{width:100%}
.btn-lg{height:54px;padding:0 28px;font-size:16px}

/* ---------- pill badges ---------- */
.pill{
  display:inline-flex;align-items:center;gap:7px;
  padding:7px 14px;border-radius:var(--r-pill);
  font-size:13.5px;font-weight:500;
  background:var(--badge-bg);border:1px solid var(--badge-border);color:var(--text);
}
.pill .dot{width:7px;height:7px;border-radius:50%;background:var(--cyan)}
.pill-ok{background:var(--ok-bg);border-color:var(--ok-border);color:var(--ok-text)}
.pill-ok .dot{background:var(--green)}

/* ---------- generic card ---------- */
.card{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--r-card);box-shadow:var(--shadow);
}

/* ============================================================
   HEADER
   ============================================================ */
.header{
  position:sticky;top:0;z-index:60;
  border-bottom:1px solid transparent;
  transition:background .25s ease,border-color .25s ease,backdrop-filter .25s ease;
}
.header.scrolled{
  background:rgba(11,15,20,.72);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  border-bottom-color:var(--border);
}
.header-inner{display:flex;align-items:center;gap:22px;height:72px}
.brand{display:flex;align-items:center;gap:12px;min-width:0}
.brand .logo{
  width:38px;height:42px;flex:0 0 auto;
  display:grid;place-items:center;
  filter:drop-shadow(0 4px 12px rgba(34,211,238,.35));
}
.brand .logo svg{width:38px;height:42px}
.brand .bt{display:flex;flex-direction:column;line-height:1.15;min-width:0}
.brand .bt b{font-weight:700;font-size:16px}
.brand .bt span{font-size:12px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.nav{display:flex;align-items:center;gap:26px;margin-left:auto}
.nav a{color:var(--muted);font-size:14.5px;font-weight:500;transition:color .15s}
.nav a:hover{color:var(--text)}
.header .btn{height:42px;padding:0 18px;font-size:14px}

/* ============================================================
   HERO
   ============================================================ */
.hero{padding-top:38px}
.hero-card{
  display:grid;grid-template-columns:1.28fr 1fr;gap:46px;align-items:center;
  padding:54px;overflow:hidden;position:relative;
  background:
    linear-gradient(180deg,rgba(34,211,238,.04),transparent 40%),
    var(--surface);
}
.hero-card::before{
  content:"";position:absolute;inset:0;pointer-events:none;opacity:.5;
  background-image:linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),
                   linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);
  background-size:34px 34px;
  -webkit-mask-image:radial-gradient(circle at 70% 30%,#000,transparent 72%);
  mask-image:radial-gradient(circle at 70% 30%,#000,transparent 72%);
}
.hero-card>*{position:relative;z-index:1}
.hero-card::after{
  content:"";position:absolute;right:-120px;top:-120px;width:420px;height:420px;
  background:radial-gradient(circle,rgba(34,211,238,.14),transparent 65%);pointer-events:none;
}
.hero h1{
  font-size:clamp(32px,4.6vw,52px);font-weight:800;letter-spacing:-.03em;
  line-height:1.06;margin:0 0 18px;
}
.hero .sub{color:var(--muted);font-size:18px;margin:0 0 24px;max-width:540px}
.hero-pills{display:flex;flex-wrap:wrap;gap:9px;margin-bottom:26px}
.hero-cta{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:24px}
.pay-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.pay-row .lbl{font-size:12.5px;color:var(--muted);margin-right:2px}
.pay-ico{
  height:30px;min-width:46px;padding:0 9px;border-radius:7px;
  background:#fff;display:flex;align-items:center;justify-content:center;
  font-weight:800;font-size:12px;letter-spacing:.02em;
}
.pay-ico.mir{background:#0f754e;color:#fff}
.pay-ico.mc{background:#1a1a1a;color:#fff}
.pay-ico.visa{background:#1434cb;color:#fff;font-style:italic;letter-spacing:.06em}
.pay-tag{
  height:30px;padding:0 11px;border-radius:7px;display:flex;align-items:center;
  font-size:12.5px;font-weight:600;background:var(--badge-bg);border:1px solid var(--badge-border);color:var(--text);
}

/* phone mockup */
.phone-col{display:flex;justify-content:center}
.phone{
  width:288px;border-radius:38px;padding:14px;
  background:linear-gradient(180deg,#161d28,#0c121b);
  border:1px solid #243246;position:relative;
  box-shadow:0 40px 80px rgba(0,0,0,.55), 0 0 0 1px rgba(34,211,238,.08), 0 0 60px rgba(34,211,238,.12);
}
.phone-screen{
  background:linear-gradient(180deg,#0a111b,#0a0f17);
  border-radius:26px;border:1px solid #1a2434;padding:20px 18px 18px;position:relative;overflow:hidden;
}
.notch{width:118px;height:24px;background:#05080d;border-radius:0 0 16px 16px;margin:-20px auto 16px;}
.phone-top{display:flex;align-items:center;gap:11px;margin-bottom:18px}
.phone-top .pic{width:38px;height:42px;display:grid;place-items:center;filter:drop-shadow(0 4px 10px rgba(34,211,238,.4))}
.phone-top .pic svg{width:38px;height:42px}
.phone-top b{font-size:15px;display:block}
.phone-top span{font-size:11.5px;color:var(--green);display:inline-flex;align-items:center;gap:6px}
.live{width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 0 0 rgba(16,185,129,.6);animation:pulse 2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(16,185,129,.5)}70%{box-shadow:0 0 0 7px rgba(16,185,129,0)}100%{box-shadow:0 0 0 0 rgba(16,185,129,0)}}
.svc{display:flex;align-items:center;gap:11px;padding:11px 12px;border-radius:12px;background:rgba(255,255,255,.025);border:1px solid #16202e;margin-bottom:9px}
.svc .g{width:9px;height:9px;border-radius:50%;background:var(--green);box-shadow:0 0 10px rgba(16,185,129,.7);flex:0 0 auto}
.svc .nm{font-size:13.5px;font-weight:500;flex:1}
.svc .st{font-size:11.5px;color:var(--green);font-weight:600}
.phone-foot{text-align:center;font-size:11.5px;color:var(--muted);margin-top:14px}

/* ============================================================
   KPI STRIP
   ============================================================ */
.kpi-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:14px}
.kpi{padding:22px 18px;text-align:left}
.kpi .num{font-size:clamp(22px,2.4vw,28px);font-weight:800;letter-spacing:-.02em;line-height:1}
.kpi .num .accent{color:var(--cyan)}
.kpi .lbl{font-size:13px;color:var(--muted);margin-top:8px}

/* ============================================================
   GENERIC GRIDS
   ============================================================ */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}

/* works cards */
.work{padding:22px 20px;transition:transform .15s ease,border-color .2s}
.work:hover{transform:translateY(-2px);border-color:#2a3a52}
.work .check{width:26px;height:26px;border-radius:8px;background:var(--ok-bg);border:1px solid var(--ok-border);color:var(--green);display:grid;place-items:center;font-size:14px;font-weight:800;margin-bottom:13px}
.work b{font-size:16px;display:block;margin-bottom:5px}
.work p{margin:0;color:var(--muted);font-size:14px}

/* steps */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:34px}
.step{padding:30px 24px 26px;position:relative;overflow:visible}
.step .nbadge{
  position:absolute;top:-20px;left:24px;height:40px;min-width:40px;padding:0 14px;
  border-radius:var(--r-pill);background:var(--grad);color:#04121f;font-weight:800;font-size:17px;
  display:flex;align-items:center;justify-content:center;box-shadow:0 8px 20px rgba(34,211,238,.32);
}
.step b{display:block;font-size:18px;margin:14px 0 9px}
.step p{margin:0;color:var(--muted);font-size:14.5px}

/* ============================================================
   PRICING
   ============================================================ */
.price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;align-items:stretch}
.price-grid.cols-2{grid-template-columns:repeat(2,1fr);max-width:760px;margin:0 auto}
.price-grid.cols-4{grid-template-columns:repeat(4,1fr)}
.price-grid.cols-5{grid-template-columns:repeat(5,1fr)}
.tcard{
  padding:28px 24px;display:flex;flex-direction:column;position:relative;overflow:hidden;
  transition:transform .15s ease,border-color .2s;
}
.tcard:hover{transform:translateY(-3px)}
.tcard.hit{border-color:#2b5e86;box-shadow:0 0 0 1px rgba(34,211,238,.25),0 18px 50px rgba(34,211,238,.14)}
.ribbon{
  position:absolute;top:16px;right:-34px;transform:rotate(45deg);
  width:140px;text-align:center;font-size:11px;font-weight:800;letter-spacing:.1em;
  padding:5px 0;color:#04121f;background:var(--grad);box-shadow:var(--shadow);
}
.ribbon.trial{background:linear-gradient(135deg,#f59e0b,#fbbf24)}
.tcard .tname{font-size:18px;font-weight:700}
.tcard .tdesc{font-size:13.5px;color:var(--muted);margin-top:4px;min-height:20px}
.tcard .price{display:flex;align-items:baseline;gap:10px;margin:18px 0 4px}
.tcard .price .now{font-size:38px;font-weight:800;letter-spacing:-.02em}
.tcard .price .cur{font-size:20px;font-weight:700;color:var(--muted)}
.tcard .price .old{font-size:16px;color:var(--muted);text-decoration:line-through}
.tcard .pnote{font-size:13px;color:var(--muted);margin-bottom:18px}
.tfeat{list-style:none;padding:0;margin:0 0 22px;display:flex;flex-direction:column;gap:11px;flex:1}
.tfeat li{display:flex;gap:10px;font-size:14px;align-items:flex-start}
.tfeat li::before{content:"✓";color:var(--green);font-weight:800;flex:0 0 auto}
.pay-note{
  margin-top:24px;display:flex;flex-wrap:wrap;gap:14px 22px;justify-content:center;
  color:var(--muted);font-size:13.5px;
}
.pay-note span{display:inline-flex;align-items:center;gap:7px}
.pay-note span::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--cyan)}

/* empty / loading / error for tariffs */
.t-state{grid-column:1/-1;text-align:center;padding:48px 20px;color:var(--muted)}
.spinner{width:34px;height:34px;border-radius:50%;border:3px solid var(--border);border-top-color:var(--cyan);margin:0 auto 14px;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* ============================================================
   SECURITY
   ============================================================ */
.sec-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.sec-card{padding:24px 22px;border:1px solid var(--sec-border);background:var(--sec-bg);border-radius:var(--r-card);box-shadow:var(--shadow);transition:transform .15s}
.sec-card:hover{transform:translateY(-2px)}
.sec-card .ico{font-size:24px;margin-bottom:12px}
.sec-card b{font-size:16px;display:block;margin-bottom:6px}
.sec-card p{margin:0;color:var(--muted);font-size:14px}
.guarantee{
  margin-top:18px;display:flex;align-items:center;gap:20px;padding:24px 26px;
  border:1px solid var(--ok-border);background:var(--ok-bg);border-radius:var(--r-card);
}
.guarantee .ico{font-size:30px;flex:0 0 auto}
.guarantee b{font-size:17px;display:block;margin-bottom:3px}
.guarantee p{margin:0;color:var(--muted);font-size:14px}

/* ============================================================
   COMPARISON TABLE
   ============================================================ */
.cmp-wrap{border:1px solid var(--border);border-radius:var(--r-card);overflow:hidden;box-shadow:var(--shadow)}
table.cmp{width:100%;border-collapse:collapse;font-size:14.5px}
table.cmp th,table.cmp td{padding:16px 22px;text-align:left;border-bottom:1px solid var(--border)}
table.cmp thead th{background:var(--surface-2);font-weight:700;font-size:14px}
table.cmp tbody tr:last-child td{border-bottom:none}
table.cmp td.feat{color:var(--muted);font-weight:500}
table.cmp .col-us{background:var(--ok-bg)}
table.cmp .us{color:var(--ok-text);font-weight:600}
table.cmp .us::before{content:"✓ ";color:var(--green);font-weight:800}
table.cmp .free{color:var(--muted)}
.cmp-note{margin-top:14px;color:var(--muted);font-size:14px}
.cmp-note a{color:var(--cyan);font-weight:600}

/* ============================================================
   REVIEWS
   ============================================================ */
.rev-card{padding:24px 22px}
.stars{color:var(--amber);font-size:15px;letter-spacing:2px;margin-bottom:12px}
.rev-card .quote{font-size:15px;margin:0 0 18px;line-height:1.5}
.rev-author{display:flex;align-items:center;gap:12px}
.avatar{width:42px;height:42px;border-radius:50%;background:var(--grad);display:grid;place-items:center;color:#04121f;font-weight:800;font-size:17px;flex:0 0 auto}
.rev-author b{font-size:14.5px;display:block}
.rev-author span{font-size:13px;color:var(--muted)}

/* ============================================================
   LOCATIONS + PLATFORMS
   ============================================================ */
:root{--magenta:#d946ef}
.loc-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:start}
.loc-col{min-width:0}
.tag-pill{
  display:inline-flex;align-items:center;gap:8px;padding:8px 16px;border-radius:var(--r-pill);
  font-size:14px;font-weight:600;margin-bottom:20px;background:var(--badge-bg);
}
.tag-cyan{border:1px solid #1e4a55;color:var(--cyan)}
.tag-magenta{border:1px solid #4a2455;color:var(--magenta)}
.loc-title{font-size:clamp(26px,3.2vw,36px);font-weight:800;letter-spacing:-.02em;line-height:1.1;margin:0 0 30px}
.loc-title .accent{color:var(--cyan)}
.loc-title .accent-m{color:var(--magenta)}

.loc-lead{color:var(--muted);font-size:17px;margin:-12px 0 28px;max-width:460px}
.dev-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:20px}
.dev-list li{display:flex;gap:14px;align-items:flex-start}
.dev-list .dl-ico{
  flex:0 0 auto;width:28px;height:28px;border-radius:9px;margin-top:2px;
  background:var(--ok-bg);border:1px solid var(--ok-border);color:var(--green);
  display:grid;place-items:center;font-size:14px;font-weight:800;
}
.dev-list b{display:block;font-size:16px;font-weight:600;margin-bottom:3px}
.dev-list span{color:var(--muted);font-size:14px}

/* platform cards */
.plat-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.plat-card{
  padding:26px 24px;border-radius:var(--r-card);min-height:140px;
  background:linear-gradient(155deg,#101a26,#0c1119);border:1px solid #1c2c3e;
  display:flex;flex-direction:column;transition:transform .15s ease,border-color .2s;
}
.plat-card:hover{transform:translateY(-3px);border-color:#2b4a66}
.plat-ico{margin-bottom:auto;color:var(--cyan)}
.plat-ico svg{width:34px;height:34px;fill:none;stroke:currentColor;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}
.plat-card b{font-size:17px;margin:20px 0 5px}
.plat-card span{color:var(--muted);font-size:14px}

/* ============================================================
   ACCORDIONS (specs + faq)
   ============================================================ */
details.acc{border:1px solid var(--border);border-radius:var(--r-btn);background:var(--surface);margin-bottom:12px;overflow:hidden}
details.acc summary{
  list-style:none;cursor:pointer;padding:18px 22px;font-weight:600;font-size:15.5px;
  display:flex;align-items:center;justify-content:space-between;gap:14px;
}
details.acc summary::-webkit-details-marker{display:none}
details.acc summary::after{content:"+";font-size:22px;color:var(--cyan);font-weight:400;transition:transform .2s}
details.acc[open] summary::after{transform:rotate(45deg)}
details.acc .acc-body{padding:0 22px 20px;color:#c6d0e0;font-size:14.5px}
.spec-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:6px}
.spec{padding:20px;border:1px solid var(--border);border-radius:var(--r-btn);background:var(--surface-2)}
.spec b{display:block;font-size:15px;margin-bottom:12px;color:var(--text)}
.spec dl{margin:0;display:flex;flex-direction:column;gap:9px}
.spec .kv{display:flex;justify-content:space-between;gap:14px;font-size:13.5px}
.spec .kv dt{color:var(--muted)}
.spec .kv dd{margin:0;font-weight:500;text-align:right}
.spec-note{margin-top:14px;color:var(--muted);font-size:13.5px}

/* ============================================================
   TELEGRAM CARDS
   ============================================================ */
.tg-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.tg-card{padding:26px 24px;display:block;transition:transform .15s,border-color .2s}
.tg-card:hover{transform:translateY(-3px);border-color:#2b5e86}
.tg-card .ico{font-size:28px;margin-bottom:13px}
.tg-card b{font-size:17px;display:block;margin-bottom:6px}
.tg-card p{margin:0 0 12px;color:var(--muted);font-size:14px}
.tg-card .arrow{color:var(--cyan);font-size:14px;font-weight:600}

/* ============================================================
   FINAL CTA
   ============================================================ */
.final{padding:54px;text-align:center;background:linear-gradient(180deg,#101824,#0b121b)}
.final h2{font-size:clamp(28px,4vw,42px);font-weight:800;letter-spacing:-.02em;margin:0 0 12px}
.final p{color:var(--muted);font-size:18px;margin:0 auto 28px;max-width:520px}
.final .cta{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-bottom:24px}
.final .gbox{display:inline-flex;align-items:center;gap:10px;color:var(--ok-text);font-size:14px;font-weight:500;padding:10px 18px;border-radius:var(--r-pill);background:var(--ok-bg);border:1px solid var(--ok-border)}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{border-top:1px solid var(--border);padding:38px 0 120px;margin-top:30px}
.footer-top{display:flex;justify-content:space-between;gap:24px;flex-wrap:wrap;margin-bottom:20px}
.footer-top .fl{color:var(--muted);font-size:13.5px;line-height:1.7}
.footer-brand{display:inline-flex;align-items:center;gap:10px;margin-bottom:10px}
.footer-brand .logo{width:30px;height:34px;display:grid;place-items:center;filter:drop-shadow(0 4px 10px rgba(34,211,238,.3))}
.footer-brand .logo svg{width:30px;height:34px}
.footer-brand b{color:var(--text);font-size:17px;font-weight:700}
.fl-sub{display:block}
.footer-links{display:flex;flex-wrap:wrap;gap:8px 22px;align-items:flex-start}
.footer-links a{color:var(--muted);font-size:13.5px;transition:color .15s}
.footer-links a:hover{color:var(--text)}
.disclaimer{color:#566072;font-size:12.5px;line-height:1.6;max-width:780px}

/* ============================================================
   STICKY MOBILE CTA
   ============================================================ */
.mcta{
  position:fixed;left:0;right:0;bottom:0;z-index:55;display:none;
  align-items:center;justify-content:space-between;gap:14px;
  padding:12px 18px calc(12px + env(safe-area-inset-bottom));
  background:rgba(11,15,20,.82);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border-top:1px solid var(--border);
}
.mcta .ml{line-height:1.2}
.mcta .ml span{font-size:12px;color:var(--muted);display:block}
.mcta .ml b{font-size:18px}
.mcta .btn{height:46px}

/* ============================================================
   FLOATING TELEGRAM
   ============================================================ */
.tg-float{
  position:fixed;right:20px;bottom:20px;z-index:56;width:54px;height:54px;border-radius:50%;
  background:linear-gradient(135deg,#2aabee,#229ed9);display:grid;place-items:center;
  box-shadow:0 12px 30px rgba(34,158,217,.4);transition:transform .15s;
}
.tg-float:hover{transform:translateY(-3px)}
.tg-float svg{width:26px;height:26px;fill:#fff;margin-right:2px}

/* ============================================================
   COOKIE BANNER
   ============================================================ */
.cookie{
  position:fixed;left:18px;right:18px;bottom:18px;z-index:70;max-width:680px;margin:0 auto;
  display:flex;align-items:center;gap:18px;padding:18px 22px;border-radius:var(--r-card);
  background:rgba(13,20,32,.9);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border:1px solid var(--border);box-shadow:0 20px 50px rgba(0,0,0,.5);
}
.cookie p{margin:0;font-size:13.5px;color:var(--muted);flex:1}
.cookie p a{color:var(--cyan)}
.cookie .btn{height:42px;flex:0 0 auto}
.cookie.hide{display:none}

/* ============================================================
   PAYMENT MODAL
   ============================================================ */
.overlay{
  position:fixed;inset:0;z-index:90;background:rgba(0,0,0,.7);
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  display:none;align-items:center;justify-content:center;padding:20px;
}
.overlay.open{display:flex}
.modal{
  width:100%;max-width:440px;max-height:92vh;overflow-y:auto;
  background:var(--surface);border:1px solid var(--border);border-radius:var(--r-card);
  box-shadow:0 30px 80px rgba(0,0,0,.6);padding:28px;position:relative;
  animation:pop .2s ease;
}
@keyframes pop{from{transform:scale(.96);opacity:0}to{transform:scale(1);opacity:1}}
.modal .close{
  position:absolute;top:16px;right:16px;width:34px;height:34px;border-radius:9px;
  background:var(--btn2-bg);border:1px solid var(--btn2-border);color:var(--muted);
  font-size:18px;cursor:pointer;display:grid;place-items:center;transition:color .15s,border-color .15s;
}
.modal .close:hover{color:var(--text);border-color:#33455c}
.modal h3{font-size:21px;font-weight:800;margin:0 0 6px;letter-spacing:-.01em}
.modal .mdesc{color:var(--muted);font-size:14px;margin:0 0 20px}
.mstep{display:none}
.mstep.active{display:block}
.tariff-chip{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:14px 16px;border-radius:var(--r-btn);background:var(--surface-2);border:1px solid var(--border);margin-bottom:18px;
}
.tariff-chip .nm{font-weight:600;font-size:15px}
.tariff-chip .pr{font-weight:800;font-size:18px}
.field{margin-bottom:16px}
.field label{display:block;font-size:13px;color:var(--muted);margin-bottom:7px;font-weight:500}
.input{
  width:100%;height:48px;padding:0 14px;border-radius:var(--r-btn);
  background:var(--surface-2);border:1px solid var(--border);color:var(--text);font-size:15px;
  transition:border-color .15s,box-shadow .15s;
}
.input::placeholder{color:#566072}
.input:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(59,130,246,.18)}
.input.err{border-color:var(--red);box-shadow:0 0 0 3px rgba(239,68,68,.15)}
.msg{font-size:13px;margin-top:8px;display:none}
.msg.show{display:block}
.msg.error{color:var(--red)}
.msg.ok{color:var(--green)}
.methods{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:18px}
.method{
  padding:16px 8px;border-radius:var(--r-btn);background:var(--surface-2);border:1px solid var(--border);
  cursor:pointer;text-align:center;transition:border-color .15s,box-shadow .15s,transform .12s;
}
.method:hover{transform:translateY(-2px)}
.method .mi{font-size:22px;margin-bottom:7px}
.method .ml{font-size:13px;font-weight:600}
.method.sel{border-color:var(--blue);box-shadow:0 0 0 3px rgba(59,130,246,.2),0 8px 20px rgba(59,130,246,.15)}
.amount{text-align:center;font-size:30px;font-weight:800;margin:4px 0 20px;letter-spacing:-.02em}
.wait{text-align:center;padding:18px 0 6px}
.hourglass{font-size:48px;animation:flip 1.6s ease-in-out infinite}
@keyframes flip{0%,40%{transform:rotate(0)}50%,90%{transform:rotate(180deg)}100%{transform:rotate(180deg)}}
.wait .small{color:var(--muted);font-size:13px;margin-top:10px}
.success-ico{font-size:52px;text-align:center;margin-bottom:10px}
.expiry{text-align:center;color:var(--muted);font-size:14px;margin-bottom:18px}
.expiry b{color:var(--ok-text)}
.sub-url{
  display:flex;align-items:center;gap:10px;padding:13px 14px;border-radius:var(--r-btn);
  background:var(--surface-2);border:1px solid var(--border);margin-bottom:14px;
}
.sub-url code{font-family:'SF Mono',ui-monospace,Menlo,monospace;font-size:12.5px;color:var(--cyan);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}
.sub-url .cp{flex:0 0 auto;background:var(--btn2-bg);border:1px solid var(--btn2-border);color:var(--text);border-radius:8px;height:34px;padding:0 12px;font-size:12.5px;cursor:pointer;font-weight:600}
.sub-url .cp:hover{border-color:#33455c}
.modal-actions{display:flex;flex-direction:column;gap:10px;margin-top:6px}
.support-links{display:flex;gap:18px;justify-content:center;margin-top:16px;font-size:13px}
.support-links a{color:var(--cyan);font-weight:500}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:980px){
  .nav{display:none}
  .hero-card{grid-template-columns:1fr;gap:36px;padding:36px}
  .phone-col{order:2}
  .kpi-grid{grid-template-columns:repeat(2,1fr)}
  .kpi:last-child{grid-column:1/-1}
  .grid-3,.steps,.sec-grid,.price-grid,.price-grid.cols-4,.price-grid.cols-5,.spec-grid,.tg-grid{grid-template-columns:1fr}
  .loc-grid{grid-template-columns:1fr;gap:48px}
  .grid-2,.price-grid.cols-2{grid-template-columns:1fr}
  .steps{gap:30px;margin-top:24px}
  .mcta{display:flex}
  .tg-float{bottom:84px}
  .final{padding:40px 26px}
}
@media (max-width:600px){
  section{padding:48px 0}
  .wrap{padding:0 16px}
  .hero-card{padding:26px 22px}
  .hero .sub{font-size:16px}
  table.cmp th,table.cmp td{padding:13px 14px;font-size:13px}
  .modal{padding:22px}
  .cookie{flex-direction:column;align-items:stretch;text-align:center}
  .cookie .btn{width:100%}
  .footer{padding-bottom:140px}
}
