/*
Theme Name: VPNGame RU
Theme URI: https://vpngame.online/
Author: ChatGPT
Author URI: https://openai.com/
Description: Лёгкая SEO-оптимизированная WordPress-тема для русскоязычной версии VPNGame — игрового VPN/акселератора.
Version: 1.0.0
Tested up to: 6.5
Requires PHP: 7.4
Text Domain: vpngame-ru
*/

:root {
  --vpn-bg: #090b18;
  --vpn-bg-2: #11172e;
  --vpn-bg-3: #151c38;
  --vpn-card: rgba(255,255,255,.075);
  --vpn-card-solid: #141b34;
  --vpn-text: #f7f8ff;
  --vpn-muted: #abb5d6;
  --vpn-soft: #e8edff;
  --vpn-line: rgba(255,255,255,.12);
  --vpn-accent: #ff3b63;
  --vpn-accent-2: #7b5cff;
  --vpn-green: #28e08a;
  --vpn-yellow: #ffcb55;
  --vpn-blue: #37b7ff;
  --vpn-shadow: 0 22px 70px rgba(0,0,0,.35);
  --vpn-radius: 26px;
  --vpn-radius-sm: 16px;
  --vpn-container: 1180px;
  --vpn-font: Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--vpn-font);
  color: var(--vpn-text);
  background:
    radial-gradient(circle at 12% 0%, rgba(255,59,99,.22), transparent 30rem),
    radial-gradient(circle at 88% 8%, rgba(123,92,255,.24), transparent 32rem),
    linear-gradient(180deg, #080a16 0%, #0a0e1e 45%, #0d1020 100%);
  line-height: 1.65;
  overflow-x: hidden;
}
body.vpn-menu-open { overflow: hidden; }
a { color: inherit; text-decoration: none; }
img { max-width: 100%; height: auto; }
button, input, textarea, select { font: inherit; }
.vpn-container { width: min(100% - 40px, var(--vpn-container)); margin-inline: auto; }
.vpn-section { padding: 92px 0; position: relative; }
.vpn-section--tight { padding: 56px 0; }
.vpn-kicker { display: inline-flex; align-items: center; gap: 8px; padding: 8px 13px; border-radius: 999px; color: #fff; background: rgba(255,59,99,.12); border: 1px solid rgba(255,59,99,.26); font-size: 14px; font-weight: 800; letter-spacing: .02em; }
.vpn-kicker:before { content: ""; width: 8px; height: 8px; border-radius: 50%; background: var(--vpn-green); box-shadow: 0 0 18px var(--vpn-green); }
.vpn-section-head { max-width: 760px; margin-bottom: 34px; }
.vpn-section-head.center { margin-inline: auto; text-align: center; }
.vpn-section-head h1,
.vpn-section-head h2 { margin: 14px 0 12px; line-height: 1.05; letter-spacing: -.04em; }
.vpn-section-head h1 { font-size: clamp(40px, 6vw, 76px); }
.vpn-section-head h2 { font-size: clamp(31px, 4vw, 52px); }
.vpn-section-head p { margin: 0; color: var(--vpn-muted); font-size: 18px; }
.vpn-lead { color: var(--vpn-muted); font-size: 18px; max-width: 720px; }
.vpn-gradient-text { background: linear-gradient(90deg, var(--vpn-accent), var(--vpn-yellow), var(--vpn-green)); -webkit-background-clip: text; background-clip: text; color: transparent; }

.vpn-site-header { position: sticky; top: 0; z-index: 80; border-bottom: 1px solid rgba(255,255,255,.08); background: rgba(8,10,22,.82); backdrop-filter: blur(18px); transition: background .2s ease, box-shadow .2s ease; }
.vpn-site-header.is-scrolled { background: rgba(8,10,22,.94); box-shadow: 0 14px 40px rgba(0,0,0,.22); }
.vpn-header-row { height: 78px; display: flex; align-items: center; justify-content: space-between; gap: 20px; }
.vpn-logo { display: inline-flex; align-items: center; gap: 12px; font-weight: 950; letter-spacing: -.03em; font-size: 24px; }
.vpn-logo-mark { position: relative; width: 42px; height: 42px; flex: 0 0 auto; border-radius: 14px; background: linear-gradient(135deg, var(--vpn-accent), var(--vpn-accent-2)); box-shadow: 0 16px 40px rgba(255,59,99,.28); }
.vpn-logo-mark:before { content: ""; position: absolute; inset: 11px 9px 10px 11px; border-radius: 3px 12px 12px 3px; border: 3px solid #fff; border-left-width: 7px; transform: skewX(-8deg); }
.vpn-logo-mark:after { content: ""; position: absolute; width: 8px; height: 8px; right: 8px; top: 8px; border-radius: 50%; background: var(--vpn-green); box-shadow: 0 0 14px var(--vpn-green); }
.vpn-logo span:last-child { color: #ffffff; }
.vpn-main-nav { display: flex; align-items: center; gap: 6px; }
.vpn-nav-list { display: flex; align-items: center; gap: 4px; margin: 0; padding: 0; list-style: none; }
.vpn-nav-link, .vpn-dropdown-toggle { display: inline-flex; align-items: center; gap: 8px; padding: 11px 13px; border-radius: 14px; color: var(--vpn-muted); font-weight: 800; border: 0; background: transparent; cursor: pointer; }
.vpn-nav-link:hover, .vpn-nav-link:focus-visible, .vpn-dropdown-toggle:hover, .vpn-dropdown-toggle:focus-visible { color: #fff; background: rgba(255,255,255,.08); outline: 0; }
.vpn-dropdown { position: relative; }
.vpn-dropdown-toggle:after { content: ""; width: 7px; height: 7px; border-right: 2px solid currentColor; border-bottom: 2px solid currentColor; transform: rotate(45deg) translateY(-2px); opacity: .8; }
.vpn-dropdown-menu { position: absolute; top: calc(100% + 12px); left: 0; min-width: 250px; padding: 10px; margin: 0; list-style: none; border-radius: 20px; background: rgba(17,23,46,.98); border: 1px solid var(--vpn-line); box-shadow: var(--vpn-shadow); opacity: 0; visibility: hidden; transform: translateY(8px); transition: .18s ease; }
.vpn-dropdown:hover .vpn-dropdown-menu, .vpn-dropdown:focus-within .vpn-dropdown-menu, .vpn-dropdown.is-open .vpn-dropdown-menu { opacity: 1; visibility: visible; transform: translateY(0); }
.vpn-dropdown-menu a { display: block; padding: 11px 12px; border-radius: 13px; color: var(--vpn-muted); font-weight: 750; }
.vpn-dropdown-menu a:hover { color: #fff; background: rgba(255,255,255,.08); }
.vpn-header-actions { display: flex; align-items: center; gap: 10px; }
.vpn-burger { display: none; width: 46px; height: 46px; border: 1px solid var(--vpn-line); border-radius: 14px; background: rgba(255,255,255,.06); color: #fff; padding: 10px; cursor: pointer; }
.vpn-burger span { display: block; height: 2px; background: #fff; border-radius: 999px; margin: 6px 0; transition: .2s ease; }
.vpn-burger.is-active span:nth-child(1) { transform: translateY(8px) rotate(45deg); }
.vpn-burger.is-active span:nth-child(2) { opacity: 0; }
.vpn-burger.is-active span:nth-child(3) { transform: translateY(-8px) rotate(-45deg); }

.vpn-btn { display: inline-flex; align-items: center; justify-content: center; gap: 10px; min-height: 48px; padding: 13px 20px; border-radius: 15px; font-weight: 900; border: 1px solid transparent; cursor: pointer; transition: .18s ease; }
.vpn-btn--primary { background: linear-gradient(135deg, var(--vpn-accent), #ff7a55); color: #fff; box-shadow: 0 18px 42px rgba(255,59,99,.32); }
.vpn-btn--primary:hover { transform: translateY(-2px); box-shadow: 0 22px 52px rgba(255,59,99,.42); }
.vpn-btn--ghost { border-color: var(--vpn-line); background: rgba(255,255,255,.06); color: #fff; }
.vpn-btn--ghost:hover { background: rgba(255,255,255,.1); transform: translateY(-2px); }
.vpn-btn--green { color: #07120d; background: linear-gradient(135deg, var(--vpn-green), #8cffb5); box-shadow: 0 18px 42px rgba(40,224,138,.25); }

.vpn-hero { padding: 26px 0 26px; position: relative; overflow: hidden; }
.vpn-hero:after { content: ""; position: absolute; inset: auto -10% -160px -10%; height: 300px; background: radial-gradient(ellipse at center, rgba(55,183,255,.13), transparent 62%); pointer-events: none; }
.vpn-hero-grid { display: grid; grid-template-columns: 1.05fr .95fr; gap: 54px; align-items: center; position: relative; z-index: 1; }
.vpn-hero h1 { margin: 18px 0 18px; font-size: clamp(42px, 7vw, 86px); line-height: .98; letter-spacing: -.06em; }
.vpn-hero-text { color: var(--vpn-muted); font-size: 20px; max-width: 700px; }
.vpn-hero-actions { display: flex; flex-wrap: wrap; gap: 14px; margin: 30px 0 26px; }
.vpn-hero-points { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 12px; margin: 26px 0 0; padding: 0; list-style: none; }
.vpn-hero-points li { padding: 14px; border-radius: 18px; border: 1px solid var(--vpn-line); background: rgba(255,255,255,.055); color: var(--vpn-muted); font-weight: 750; }
.vpn-hero-points b { display: block; color: #fff; font-size: 20px; }
.vpn-visual { min-height: 520px; border-radius: 34px; position: relative; overflow: hidden; background: linear-gradient(145deg, rgba(255,255,255,.11), rgba(255,255,255,.035)); border: 1px solid var(--vpn-line); box-shadow: var(--vpn-shadow); }
.vpn-visual:before { content: ""; position: absolute; inset: -40px; background: radial-gradient(circle at 30% 20%, rgba(255,59,99,.28), transparent 26%), radial-gradient(circle at 82% 23%, rgba(40,224,138,.2), transparent 24%), radial-gradient(circle at 64% 84%, rgba(123,92,255,.25), transparent 30%); filter: blur(2px); }
.vpn-visual-card { position: absolute; inset: 46px; border-radius: 26px; border: 1px solid rgba(255,255,255,.14); background: rgba(8,10,22,.72); backdrop-filter: blur(16px); padding: 28px; }
.vpn-ping-board { position: absolute; left: 28px; right: 28px; bottom: 32px; display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.vpn-ping { border-radius: 20px; padding: 18px; background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.1); }
.vpn-ping small { display: block; color: var(--vpn-muted); font-weight: 800; }
.vpn-ping strong { font-size: 38px; line-height: 1; }
.vpn-ping.is-good strong { color: var(--vpn-green); }
.vpn-route-map { position: absolute; inset: 34px 26px 170px; border-radius: 24px; background: linear-gradient(135deg, rgba(55,183,255,.1), rgba(123,92,255,.08)); overflow: hidden; }
.vpn-route-map:before { content: ""; position: absolute; inset: 18%; border: 2px dashed rgba(255,255,255,.18); border-radius: 50%; transform: rotate(-14deg); }
.vpn-node { position: absolute; width: 16px; height: 16px; border-radius: 50%; background: var(--vpn-green); box-shadow: 0 0 0 8px rgba(40,224,138,.14), 0 0 30px rgba(40,224,138,.75); }
.vpn-node.n1 { left: 18%; top: 52%; }
.vpn-node.n2 { left: 46%; top: 22%; background: var(--vpn-accent); box-shadow: 0 0 0 8px rgba(255,59,99,.14), 0 0 30px rgba(255,59,99,.75); }
.vpn-node.n3 { right: 18%; top: 60%; background: var(--vpn-yellow); box-shadow: 0 0 0 8px rgba(255,203,85,.14), 0 0 30px rgba(255,203,85,.75); }
.vpn-connection-line { position: absolute; left: 22%; right: 20%; top: 44%; height: 2px; background: linear-gradient(90deg, var(--vpn-green), var(--vpn-accent), var(--vpn-yellow)); transform: rotate(-8deg); box-shadow: 0 0 18px rgba(255,255,255,.4); }

.vpn-grid-2 { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 24px; }
.vpn-grid-3 { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 22px; }
.vpn-grid-4 { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 18px; }
.vpn-card { border: 1px solid var(--vpn-line); background: var(--vpn-card); border-radius: var(--vpn-radius); padding: 26px; box-shadow: 0 14px 44px rgba(0,0,0,.18); }
.vpn-card--solid { background: var(--vpn-card-solid); }
.vpn-card h3 { margin: 12px 0 9px; font-size: 23px; line-height: 1.2; }
.vpn-card p { margin: 0; color: var(--vpn-muted); }
.vpn-icon { width: 48px; height: 48px; display: inline-grid; place-items: center; border-radius: 16px; background: linear-gradient(135deg, rgba(255,59,99,.22), rgba(123,92,255,.22)); font-size: 24px; }
.vpn-mini-list { display: grid; gap: 12px; margin: 18px 0 0; padding: 0; list-style: none; }
.vpn-mini-list li { position: relative; padding-left: 28px; color: var(--vpn-muted); }
.vpn-mini-list li:before { content: ""; position: absolute; left: 0; top: .55em; width: 12px; height: 12px; border-radius: 50%; background: var(--vpn-green); box-shadow: 0 0 14px rgba(40,224,138,.55); }

.vpn-games-strip { display: grid; grid-template-columns: repeat(6, minmax(0, 1fr)); gap: 12px; }
.vpn-game-pill { min-height: 82px; padding: 12px; border-radius: 18px; display: grid; align-content: center; justify-items: center; text-align: center; background: rgba(255,255,255,.06); border: 1px solid var(--vpn-line); color: #fff; font-weight: 850; transition: .18s ease; }
.vpn-game-pill:hover { transform: translateY(-3px); background: rgba(255,255,255,.1); }
.vpn-game-dot { width: 28px; height: 28px; border-radius: 10px; margin-bottom: 8px; background: linear-gradient(135deg, var(--vpn-accent), var(--vpn-accent-2)); }

.vpn-pricing { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 18px; }
.vpn-plan { position: relative; overflow: hidden; padding: 24px; border-radius: 26px; border: 1px solid var(--vpn-line); background: rgba(255,255,255,.07); }
.vpn-plan.is-featured { background: linear-gradient(180deg, rgba(255,59,99,.18), rgba(255,255,255,.08)); border-color: rgba(255,59,99,.42); box-shadow: 0 24px 60px rgba(255,59,99,.2); }
.vpn-badge { display: inline-flex; padding: 6px 10px; border-radius: 999px; background: rgba(40,224,138,.14); color: #b9ffd9; font-size: 13px; font-weight: 900; }
.vpn-plan h3 { margin: 18px 0 8px; font-size: 25px; }
.vpn-price { display: flex; align-items: baseline; gap: 7px; margin: 14px 0; }
.vpn-price strong { font-size: 42px; letter-spacing: -.04em; }
.vpn-price span { color: var(--vpn-muted); font-weight: 750; }
.vpn-plan ul { margin: 20px 0; padding: 0; list-style: none; display: grid; gap: 10px; }
.vpn-plan li { color: var(--vpn-muted); padding-left: 26px; position: relative; }
.vpn-plan li:before { content: "✓"; position: absolute; left: 0; color: var(--vpn-green); font-weight: 950; }

.vpn-table-wrap { overflow-x: auto; border-radius: 24px; border: 1px solid var(--vpn-line); background: rgba(255,255,255,.055); }
.vpn-table { width: 100%; border-collapse: collapse; min-width: 720px; }
.vpn-table th, .vpn-table td { padding: 16px 18px; border-bottom: 1px solid var(--vpn-line); text-align: left; }
.vpn-table th { color: #fff; background: rgba(255,255,255,.055); }
.vpn-table td { color: var(--vpn-muted); }
.vpn-status { display: inline-flex; align-items: center; gap: 8px; color: #c5ffd9; font-weight: 850; }
.vpn-status:before { content: ""; width: 9px; height: 9px; border-radius: 50%; background: var(--vpn-green); box-shadow: 0 0 14px var(--vpn-green); }

.vpn-cta { padding: 12px 42px; border-radius: 34px; overflow: hidden; position: relative; background: linear-gradient(135deg, rgba(255,59,99,.22), rgba(123,92,255,.18)), rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.14); box-shadow: var(--vpn-shadow); }
.vpn-cta:after { content: ""; position: absolute; width: 260px; height: 260px; right: -80px; top: -80px; border-radius: 50%; background: radial-gradient(circle, rgba(40,224,138,.28), transparent 70%); }
.vpn-cta h2 { margin: 0 0 12px; font-size: clamp(30px, 4vw, 50px); line-height: 1.08; letter-spacing: -.04em; }
.vpn-cta p { margin: 0 0 24px; color: var(--vpn-muted); max-width: 700px; }

.vpn-faq { display: grid; gap: 12px; }
.vpn-faq-item { border: 1px solid var(--vpn-line); border-radius: 20px; background: rgba(255,255,255,.055); overflow: hidden; }
.vpn-faq-question { width: 100%; display: flex; justify-content: space-between; align-items: center; gap: 18px; padding: 20px 22px; color: #fff; background: transparent; border: 0; text-align: left; cursor: pointer; font-weight: 900; }
.vpn-faq-question:after { content: "+"; width: 28px; height: 28px; flex: 0 0 auto; display: grid; place-items: center; border-radius: 50%; background: rgba(255,255,255,.09); color: var(--vpn-green); }
.vpn-faq-item.is-open .vpn-faq-question:after { content: "−"; }
.vpn-faq-answer { max-height: 0; overflow: hidden; transition: max-height .25s ease; }
.vpn-faq-answer > div { padding: 0 22px 20px; color: var(--vpn-muted); }

.vpn-page-hero { padding: 26px 0 26px; border-bottom: 1px solid rgba(255,255,255,.08); background: radial-gradient(circle at 80% 0%, rgba(255,59,99,.18), transparent 30rem); }
.vpn-page-hero h1 { margin: 14px 0 14px; font-size: clamp(38px, 6vw, 68px); line-height: 1; letter-spacing: -.05em; }
.vpn-breadcrumbs { color: var(--vpn-muted); font-size: 14px; font-weight: 750; }
.vpn-breadcrumbs a { color: #fff; }
.vpn-content { padding: 20px 0 26px; }
.vpn-content h2 { margin: 42px 0 16px; font-size: clamp(28px, 3vw, 42px); line-height: 1.15; letter-spacing: -.03em; }
.vpn-content h3 { margin: 25px 0 10px; font-size: 24px; }
.vpn-content p { color: var(--vpn-muted); }
.vpn-content a:not(.vpn-btn) { color: #fff; border-bottom: 1px solid rgba(255,255,255,.24); }
.vpn-content ul, .vpn-content ol { color: var(--vpn-muted); padding-left: 22px; }
.vpn-note { padding: 18px 20px; border-radius: 18px; background: rgba(40,224,138,.11); border: 1px solid rgba(40,224,138,.26); color: #d9ffe9; }
.vpn-split { display: grid; grid-template-columns: 1fr 1fr; gap: 28px; align-items: center; }
.vpn-media-box { min-height: 320px; border-radius: 30px; border: 1px solid var(--vpn-line); background: radial-gradient(circle at 25% 25%, rgba(255,59,99,.24), transparent 32%), radial-gradient(circle at 78% 70%, rgba(40,224,138,.18), transparent 32%), rgba(255,255,255,.055); position: relative; overflow: hidden; }
.vpn-media-box:before { content: ""; position: absolute; inset: 42px; border-radius: 24px; border: 2px dashed rgba(255,255,255,.16); }
.vpn-media-box:after { content: "VPNGame"; position: absolute; left: 32px; bottom: 26px; color: rgba(255,255,255,.18); font-size: 42px; font-weight: 950; letter-spacing: -.06em; }

.vpn-site-footer { border-top: 1px solid rgba(255,255,255,.1); background: #070914; padding: 62px 0 28px; }
.vpn-footer-grid { display: grid; grid-template-columns: 1.4fr repeat(3, 1fr); gap: 28px; }
.vpn-footer-title { margin: 0 0 14px; color: #fff; font-weight: 950; }
.vpn-footer-text, .vpn-site-footer p { color: var(--vpn-muted); }
.vpn-footer-links { margin: 0; padding: 0; list-style: none; display: grid; gap: 9px; }
.vpn-footer-links a { color: var(--vpn-muted); }
.vpn-footer-links a:hover { color: #fff; }
.vpn-footer-bottom { display: flex; justify-content: space-between; gap: 18px; flex-wrap: wrap; border-top: 1px solid rgba(255,255,255,.08); margin-top: 38px; padding-top: 22px; color: var(--vpn-muted); font-size: 14px; }

.vpn-404 { min-height: 70vh; display: grid; place-items: center; text-align: center; padding: 80px 0; }
.vpn-404 h1 { font-size: clamp(80px, 18vw, 190px); line-height: .85; margin: 0; letter-spacing: -.08em; }

@media (max-width: 1040px) {
  .vpn-main-nav { position: fixed; inset: 78px 16px auto 16px; z-index: 999; display: none; flex-direction: column; align-items: stretch; max-height: calc(100vh - 96px); overflow-y: auto; padding: 16px; border-radius: 24px; background: rgba(10,14,30,.98); border: 1px solid var(--vpn-line); box-shadow: var(--vpn-shadow); }
  .vpn-main-nav.is-open { display: flex; }
  .vpn-nav-list { flex-direction: column; align-items: stretch; }
  .vpn-nav-link, .vpn-dropdown-toggle { width: 100%; justify-content: space-between; }
  .vpn-dropdown-menu { position: static; min-width: auto; margin-top: 6px; opacity: 1; visibility: visible; transform: none; display: none; box-shadow: none; background: rgba(255,255,255,.05); }
  .vpn-dropdown.is-open .vpn-dropdown-menu { display: block; }
  .vpn-burger { display: block; }
  .vpn-header-actions .vpn-btn--ghost { display: none; }
  .vpn-hero-grid, .vpn-split { grid-template-columns: 1fr; }
  .vpn-visual { min-height: 440px; }
  .vpn-grid-4, .vpn-pricing { grid-template-columns: repeat(2, minmax(0,1fr)); }
  .vpn-games-strip { grid-template-columns: repeat(4, minmax(0, 1fr)); }
  .vpn-footer-grid { grid-template-columns: 1fr 1fr; }
	.visual {display: none;}
}

@media (max-width: 720px) {
  .vpn-container { width: min(100% - 28px, var(--vpn-container)); }
  .vpn-section { padding: 64px 0; }
  .vpn-header-row { height: 68px; }
  .vpn-main-nav { top: 68px; }
  .vpn-logo { font-size: 21px; }
  .vpn-logo-mark { width: 38px; height: 38px; }
  .vpn-header-actions .vpn-btn--primary { width: auto; }
  .vpn-hero { padding: 26px 0 26px; }
  .vpn-hero-points, .vpn-grid-2, .vpn-grid-3, .vpn-grid-4, .vpn-pricing { grid-template-columns: 1fr; }
  .vpn-games-strip { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .vpn-visual { min-height: 360px; border-radius: 24px; }
  .vpn-visual-card { inset: 22px; padding: 18px; }
  .vpn-route-map { inset: 20px 16px 150px; }
  .vpn-ping-board { left: 16px; right: 16px; bottom: 18px; grid-template-columns: 1fr; }
  .vpn-ping strong { font-size: 30px; }
  .vpn-card, .vpn-cta { padding: 22px; border-radius: 22px; }
  .vpn-footer-grid { grid-template-columns: 1fr; }
  .vpn-table { min-width: 620px; }
}

@media (max-width: 420px) {
  .vpn-hero-actions .vpn-btn, .vpn-cta .vpn-btn { width: 100%; }
  .vpn-games-strip { grid-template-columns: 1fr; }
}
@media (max-width: 370px) {
	header .vpn-logo span {
		display:none;
	}}
.vpn-game-logo { width: 28px; height: 28px; margin-bottom: 8px; }