/* =============================================
   FoxlyVPN — style.css
   Правь цвета, размеры шрифтов здесь
   ============================================= */

/* === ЦВЕТА (меняй здесь) === */
:root {
  --bg-main:    #0a0e1a;   /* фон страницы */
  --bg-card:    #0d1117;   /* фон карточек */
  --orange:     #ff6b00;   /* акцент оранжевый */
  --orange-lt:  #ff9500;   /* светлый оранжевый */
  --blue:       #00d4ff;   /* акцент голубой */
  --blue-dk:    #0099ff;   /* тёмный голубой */
  --green:      #22c55e;   /* зелёный (Online) */
  --text:       #ffffff;
  --text-muted: rgba(255,255,255,0.55);
  --text-dim:   rgba(255,255,255,0.35);
  --border:     rgba(255,255,255,0.08);
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; overflow-x: hidden; }
body {
  font-family: system-ui, -apple-system, 'Segoe UI', sans-serif;
  background: var(--bg-main);
  color: var(--text);
  overflow-x: hidden;
  line-height: 1.6;
  /* cursor: url('data:image/svg+xml;base64,...') 16 16, auto; */ /* Removed for Chrome compatibility */
}
a {
  /* cursor: url('data:image/svg+xml;base64,...') 16 16, pointer; */ /* Removed for Chrome compatibility */
}

a { color: inherit; text-decoration: none; cursor: pointer; }
img { max-width: 100%; display: block; }

/* === SCROLLBAR === */
::-webkit-scrollbar { width: 5px; }
::-webkit-scrollbar-track { background: var(--bg-main); }
::-webkit-scrollbar-thumb { background: var(--orange); border-radius: 3px; }

/* === INTERACTIVE CURSOR === */
#interactive-cursor {
  position: fixed;
  top: 0;
  left: 0;
  pointer-events: none;
  z-index: 9999;
}
.cursor-ball {
  position: absolute;
  width: 8px;
  height: 8px;
  background: var(--orange);
  border-radius: 50%;
  box-shadow: 0 0 10px rgba(255,107,0,0.6);
  transition: transform 0.1s ease-out;
}
.cursor-ball.ball-1 { background: #ff6b00; transition-delay: 0s; }
.cursor-ball.ball-2 { background: #00d4ff; transition-delay: 0.05s; }
.cursor-ball.ball-3 { background: #fff; transition-delay: 0.1s; }
.cursor-ball.ball-4 { background: #ff9500; transition-delay: 0.15s; }
.cursor-ball.ball-5 { background: #0099ff; transition-delay: 0.2s; }
.cursor-ball.ball-6 { background: #22c55e; transition-delay: 0.25s; }
.cursor-ball.ball-7 { background: #ef4444; transition-delay: 0.3s; }
.cursor-ball.ball-8 { background: #8b5cf6; transition-delay: 0.35s; }

/* === ANIMATIONS === */
@keyframes float {
  0%,100% { transform: translateY(0); }
  50%      { transform: translateY(-16px); }
}
@keyframes pulse-glow {
  0%,100% { box-shadow: 0 0 20px rgba(255,107,0,0.4), 0 0 40px rgba(255,107,0,0.2); }
  50%      { box-shadow: 0 0 40px rgba(255,107,0,0.8), 0 0 80px rgba(255,107,0,0.4); }
}
@keyframes blink {
  0%,100% { opacity:1; } 50% { opacity:0.3; }
}
@keyframes gradient-shift {
  0%   { background-position: 0% 50%; }
  50%  { background-position: 100% 50%; }
  100% { background-position: 0% 50%; }
}
@keyframes shimmer {
  0%   { background-position: -200% 0; }
  100% { background-position:  200% 0; }
}
@keyframes phone-sway {
  0%,100% { transform: rotate(-2deg); }
  50%     { transform: rotate(2deg); }
}
@keyframes fadeUp {
  from { opacity:0; transform:translateY(32px); }
  to   { opacity:1; transform:translateY(0); }
}
@keyframes fadeIn {
  from { opacity:0; } to { opacity:1; }
}
@keyframes pulse-number {
  0% { color: var(--orange); transform: scale(1); }
  50% { color: var(--orange-lt); transform: scale(1.1); }
  100% { color: inherit; transform: scale(1); }
}
@keyframes loading-pulse {
  0% { background-position: 0% 0; }
  50% { background-position: 100% 0; }
  100% { background-position: 0% 0; }
}
@keyframes pulse-ring {
  0% { box-shadow: 0 0 0 0 rgba(34,197,94,0.5); }
  70% { box-shadow: 0 0 0 6px rgba(34,197,94,0); }
  100% { box-shadow: 0 0 0 0 rgba(34,197,94,0); }
}

/* Орбиты — desktop (радиусы 130–190px) */
@keyframes orb1  { 0%{transform:rotate(0deg)   translateX(145px) rotate(0deg)}   100%{transform:rotate(360deg)  translateX(145px) rotate(-360deg)} }
@keyframes orb2  { 0%{transform:rotate(60deg)  translateX(175px) rotate(-60deg)} 100%{transform:rotate(420deg)  translateX(175px) rotate(-420deg)} }
@keyframes orb3  { 0%{transform:rotate(120deg) translateX(130px) rotate(-120deg)}100%{transform:rotate(480deg)  translateX(130px) rotate(-480deg)} }
@keyframes orb4  { 0%{transform:rotate(180deg) translateX(188px) rotate(-180deg)}100%{transform:rotate(540deg)  translateX(188px) rotate(-540deg)} }
@keyframes orb5  { 0%{transform:rotate(240deg) translateX(155px) rotate(-240deg)}100%{transform:rotate(600deg)  translateX(155px) rotate(-600deg)} }
@keyframes orb6  { 0%{transform:rotate(300deg) translateX(135px) rotate(-300deg)}100%{transform:rotate(660deg)  translateX(135px) rotate(-660deg)} }
@keyframes orb7  { 0%{transform:rotate(30deg)  translateX(178px) rotate(-30deg)} 100%{transform:rotate(390deg)  translateX(178px) rotate(-390deg)} }
@keyframes orb8  { 0%{transform:rotate(90deg)  translateX(140px) rotate(-90deg)} 100%{transform:rotate(450deg)  translateX(140px) rotate(-450deg)} }
@keyframes orb9  { 0%{transform:rotate(150deg) translateX(165px) rotate(-150deg)}100%{transform:rotate(510deg)  translateX(165px) rotate(-510deg)} }
@keyframes orb10 { 0%{transform:rotate(210deg) translateX(132px) rotate(-210deg)}100%{transform:rotate(570deg)  translateX(132px) rotate(-570deg)} }
@keyframes orb11 { 0%{transform:rotate(270deg) translateX(178px) rotate(-270deg)}100%{transform:rotate(630deg)  translateX(178px) rotate(-630deg)} }
@keyframes orb12 { 0%{transform:rotate(330deg) translateX(150px) rotate(-330deg)}100%{transform:rotate(690deg)  translateX(150px) rotate(-690deg)} }

/* Орбиты — mobile (радиусы ~85px) */
@keyframes orb1s  { 0%{transform:rotate(0deg)   translateX(88px)  rotate(0deg)}   100%{transform:rotate(360deg)  translateX(88px)  rotate(-360deg)} }
@keyframes orb2s  { 0%{transform:rotate(60deg)  translateX(100px) rotate(-60deg)} 100%{transform:rotate(420deg)  translateX(100px) rotate(-420deg)} }
@keyframes orb3s  { 0%{transform:rotate(120deg) translateX(82px)  rotate(-120deg)}100%{transform:rotate(480deg)  translateX(82px)  rotate(-480deg)} }
@keyframes orb4s  { 0%{transform:rotate(180deg) translateX(108px) rotate(-180deg)}100%{transform:rotate(540deg)  translateX(108px) rotate(-540deg)} }
@keyframes orb5s  { 0%{transform:rotate(240deg) translateX(92px)  rotate(-240deg)}100%{transform:rotate(600deg)  translateX(92px)  rotate(-600deg)} }
@keyframes orb6s  { 0%{transform:rotate(300deg) translateX(84px)  rotate(-300deg)}100%{transform:rotate(660deg)  translateX(84px)  rotate(-660deg)} }
@keyframes orb7s  { 0%{transform:rotate(30deg)  translateX(104px) rotate(-30deg)} 100%{transform:rotate(390deg)  translateX(104px) rotate(-390deg)} }
@keyframes orb8s  { 0%{transform:rotate(90deg)  translateX(86px)  rotate(-90deg)} 100%{transform:rotate(450deg)  translateX(86px)  rotate(-450deg)} }
@keyframes orb9s  { 0%{transform:rotate(150deg) translateX(96px)  rotate(-150deg)}100%{transform:rotate(510deg)  translateX(96px)  rotate(-510deg)} }
@keyframes orb10s { 0%{transform:rotate(210deg) translateX(82px)  rotate(-210deg)}100%{transform:rotate(570deg)  translateX(82px)  rotate(-570deg)} }
@keyframes orb11s { 0%{transform:rotate(270deg) translateX(102px) rotate(-270deg)}100%{transform:rotate(630deg)  translateX(102px) rotate(-630deg)} }
@keyframes orb12s { 0%{transform:rotate(330deg) translateX(90px)  rotate(-330deg)}100%{transform:rotate(690deg)  translateX(90px)  rotate(-690deg)} }

@keyframes cursor-orb1 { 0%{transform:rotate(0deg) translateX(20px) rotate(0deg)} 100%{transform:rotate(360deg) translateX(20px) rotate(-360deg)} }
@keyframes cursor-orb2 { 0%{transform:rotate(60deg) translateX(25px) rotate(-60deg)} 100%{transform:rotate(420deg) translateX(25px) rotate(-420deg)} }
@keyframes cursor-orb3 { 0%{transform:rotate(120deg) translateX(18px) rotate(-120deg)} 100%{transform:rotate(480deg) translateX(18px) rotate(-480deg)} }
@keyframes cursor-orb4 { 0%{transform:rotate(180deg) translateX(28px) rotate(-180deg)} 100%{transform:rotate(540deg) translateX(28px) rotate(-540deg)} }
@keyframes cursor-orb5 { 0%{transform:rotate(240deg) translateX(22px) rotate(-240deg)} 100%{transform:rotate(600deg) translateX(22px) rotate(-600deg)} }

/* === LAYOUT === */
.container { max-width: 1200px; margin: 0 auto; padding: 0 24px; }
.section    { padding: 100px 24px; }
.section-alt { 
  background: rgba(13,17,23,0.6); 
  transition: background 0.3s, border-color 0.3s;
  border-top: 1px solid transparent;
  border-bottom: 1px solid transparent;
}
.section-alt:hover {
  background: rgba(13,17,23,0.8);
  border-color: rgba(255,107,0,0.1);
}

/* === HEADER === */
#header {
  position: fixed; top:0; left:0; right:0; z-index: 100;
  transition: background 0.3s, backdrop-filter 0.3s, border-color 0.3s;
  border-bottom: 1px solid transparent;
}
#header.scrolled {
  background: rgba(10,14,26,0.95);
  backdrop-filter: blur(20px);
  border-color: var(--border);
}
.header-inner {
  max-width: 1200px; margin: 0 auto; padding: 0 24px;
  height: 70px; display: flex; align-items: center; justify-content: space-between;
}
.logo { display:flex; align-items:center; gap:10px; }
.logo img { 
  width:40px; height:40px; border-radius:8px; object-fit:cover;
  transition: transform 0.3s;
}
.logo:hover img { transform: rotate(5deg) scale(1.05); }
.logo-text { font-weight:700; font-size:20px; }
.logo-text span { color: var(--orange); }

.nav-links { display:flex; gap:24px; align-items:center; }
.nav-links a {
  font-size:14px; font-weight:500; color: var(--text-muted);
  transition: color 0.2s; padding-bottom:2px;
  border-bottom: 2px solid transparent;
}
.nav-links a:hover, .nav-links a.active { 
  color:#fff; 
  border-color: var(--orange);
  text-shadow: 0 0 8px rgba(255,107,0,0.5);
}

.header-btns { display:flex; gap:10px; }
.btn-outline {
  padding: 8px 18px; border-radius:10px; font-size:13px; font-weight:700;
  border:1px solid var(--orange); color:var(--orange);
  transition: all 0.3s;
  white-space: nowrap;
  text-align: center;
  display: inline-flex; align-items: center; justify-content: center;
}
.btn-outline:hover { background: rgba(255,107,0,0.1); }
.btn-primary {
  padding: 8px 18px; border-radius:10px; font-size:13px; font-weight:700; color:#fff;
  background: linear-gradient(135deg, var(--orange), var(--orange-lt));
  box-shadow: 0 4px 15px rgba(255,107,0,0.3);
  transition: transform 0.15s, box-shadow 0.2s, background 0.2s;
  text-align: center;
  display: inline-flex; align-items: center; justify-content: center;
}
.btn-primary:hover { 
  transform: translateY(-2px) scale(1.02);
  box-shadow: 0 8px 25px rgba(255,107,0,0.6);
}
.btn-primary:active {
  transform: translateY(0) scale(0.98);
}

/* Burger */
.burger { display:none; flex-direction:column; gap:5px; cursor:pointer; padding:4px; background:none; border:none; }
.burger span { display:block; width:22px; height:2px; background:#fff; border-radius:2px; transition:all 0.3s; }
.mobile-menu {
  display: none;
  background: rgba(10,14,26,0.98);
  border-top: 1px solid var(--border);
  padding: 16px 24px 20px;
}
.mobile-menu.open { display:block; }
.mobile-menu a {
  display:block; color:rgba(255,255,255,0.8); padding:10px 0;
  font-size:15px; border-bottom:1px solid rgba(255,255,255,0.05);
}
.mobile-menu-btns { display:flex; gap:10px; margin-top:16px; margin-bottom:10px; }
.mobile-menu-btns a { flex:1; min-width:120px; text-align:center; padding:12px 16px; border-radius:10px; font-size:13px; font-weight:700; }
.mobile-menu-btns a.btn-outline {
  border: none;
  outline: 2px solid var(--orange);
}

/* === HERO === */
#hero {
  min-height: 100vh;
  display: flex; align-items: center;
  padding-top: 90px;
  background:
    radial-gradient(ellipse at 20% 50%, rgba(255,107,0,0.08) 0%, transparent 60%),
    radial-gradient(ellipse at 80% 20%, rgba(0,212,255,0.08) 0%, transparent 50%),
    var(--bg-main);
}
.hero-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px;
  align-items: center;
  max-width: 1200px; margin: 0 auto; padding: 60px 24px; width:100%;
}
.hero-text { display:flex; flex-direction:column; gap:24px; }
.hero-badge {
  display: inline-flex; align-items:center; gap:8px;
  background: rgba(255,107,0,0.12); border:1px solid rgba(255,107,0,0.3);
  border-radius:50px; padding:6px 16px; font-size:13px; font-weight:600; color:var(--orange-lt);
  width: fit-content;
  animation: fadeIn 0.6s ease;
}
.badge-dot { width:8px; height:8px; border-radius:50%; background:var(--orange); display:inline-block; animation:blink 1.5s ease-in-out infinite; }
.hero-h1 {
  font-size: clamp(36px, 5vw, 64px); font-weight:900; line-height:1.1;
  background: linear-gradient(135deg, var(--orange) 0%, var(--orange-lt) 30%, var(--blue) 70%, var(--blue-dk) 100%);
  background-size: 200% 200%;
  animation: gradient-shift 4s ease infinite;
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}
.hero-sub { font-size:18px; color:rgba(255,255,255,0.65); line-height:1.7; }
.hero-sub span { color:var(--blue); font-weight:600; }
.hero-stats { display:flex; gap:32px; flex-wrap:wrap; }
.stat-num { font-size:32px; font-weight:800; color:var(--orange); }
.stat-lbl { font-size:13px; color:var(--text-muted); margin-top:2px; }
.hero-ctas { display:flex; gap:14px; flex-wrap:wrap; }
.btn-hero-primary {
  display:inline-flex; align-items:center; gap:8px;
  padding:16px 32px; border-radius:14px; font-size:16px; font-weight:700; color:#fff;
  background: linear-gradient(135deg, var(--orange), var(--orange-lt));
  box-shadow: 0 4px 15px rgba(255,107,0,0.3); 
  transition: transform 0.15s, box-shadow 0.2s;
}
.btn-hero-primary:hover { 
  transform: translateY(-2px) scale(1.02);
  box-shadow: 0 8px 25px rgba(255,107,0,0.6);
}
.btn-hero-primary:active { transform: translateY(0) scale(0.98); }
.btn-hero-outline {
  display:inline-flex; align-items:center; gap:8px;
  padding:16px 28px; border-radius:14px; font-size:16px; font-weight:600;
  color:rgba(255,255,255,0.8); border:1px solid rgba(255,255,255,0.15);
  background:rgba(255,255,255,0.03); transition:all 0.3s;
}
.btn-hero-outline:hover { border-color:rgba(255,107,0,0.4); color:#fff; }

/* Orbit */
.hero-visual {
  display:flex; justify-content:center; align-items:center;
  position:relative; height:400px;
}
.hero-glow1 {
  position:absolute; width:300px; height:300px; border-radius:50%;
  background:radial-gradient(circle, rgba(255,107,0,0.15) 0%, transparent 70%);
  filter:blur(40px); pointer-events:none;
  transition: transform 0.1s;
}
.hero-glow2 {
  position:absolute; width:200px; height:200px; border-radius:50%;
  background:radial-gradient(circle, rgba(0,212,255,0.1) 0%, transparent 70%);
  filter:blur(30px); transform:translate(60px,-40px); pointer-events:none;
  transition: transform 0.1s;
}
.orbit-wrap { position:relative; width:400px; height:400px; flex-shrink:0; }
.orbit-center {
  position:absolute; top:50%; left:50%; transform:translate(-50%,-50%);
  animation:float 3s ease-in-out infinite; z-index:10;
}
.orbit-ring {
  width:210px; height:210px; border-radius:50%; padding:4px;
  background:linear-gradient(135deg,#ff6b00,#ff9500,#0a0e1a,#ff6b00);
  box-shadow:0 0 40px rgba(255,107,0,0.5),0 0 80px rgba(255,107,0,0.2);
  animation:pulse-glow 2s ease-in-out infinite;
}
.orbit-ring-inner { width:100%; height:100%; border-radius:50%; padding:3px; background:#0a0e1a; }
.orbit-ring-inner img { width:100%; height:100%; border-radius:50%; object-fit:cover; }

.orbit-balls { position:absolute; top:50%; left:50%; width:0; height:0; pointer-events:none; }
.orbit-ball {
  position:absolute; border-radius:50%; top:0; left:0;
}
.orbit-balls .orbit-ball:nth-child(1)  { width:16px;height:16px;margin:-8px;background:#ff6b00;box-shadow:0 0 14px 4px rgba(255,107,0,0.9);animation:orb1 4s linear infinite; }
.orbit-balls .orbit-ball:nth-child(2)  { width:12px;height:12px;margin:-6px;background:#00d4ff;box-shadow:0 0 12px 3px rgba(0,212,255,0.9);animation:orb2 6s linear infinite; }
.orbit-balls .orbit-ball:nth-child(3)  { width:9px;height:9px;margin:-4px;background:#fff;box-shadow:0 0 8px 2px rgba(255,255,255,0.7);animation:orb3 3.5s linear infinite; }
.orbit-balls .orbit-ball:nth-child(4)  { width:18px;height:18px;margin:-9px;background:#ff9500;box-shadow:0 0 16px 5px rgba(255,149,0,0.85);animation:orb4 7s linear infinite; }
.orbit-balls .orbit-ball:nth-child(5)  { width:13px;height:13px;margin:-6px;background:#0099ff;box-shadow:0 0 12px 3px rgba(0,153,255,0.8);animation:orb5 5s linear infinite; }
.orbit-balls .orbit-ball:nth-child(6)  { width:10px;height:10px;margin:-5px;background:#ff6b00;box-shadow:0 0 10px 3px rgba(255,107,0,0.7);animation:orb6 4.5s linear infinite; }
.orbit-balls .orbit-ball:nth-child(7)  { width:14px;height:14px;margin:-7px;background:#00d4ff;box-shadow:0 0 12px 4px rgba(0,212,255,0.7);animation:orb7 8s linear infinite; }
.orbit-balls .orbit-ball:nth-child(8)  { width:8px;height:8px;margin:-4px;background:rgba(255,255,255,0.9);box-shadow:0 0 8px rgba(255,255,255,0.6);animation:orb8 3s linear infinite; }
.orbit-balls .orbit-ball:nth-child(9)  { width:15px;height:15px;margin:-7px;background:#ff6b00;box-shadow:0 0 14px 4px rgba(255,107,0,0.8);animation:orb9 6.5s linear infinite; }
.orbit-balls .orbit-ball:nth-child(10) { width:9px;height:9px;margin:-4px;background:#0099ff;box-shadow:0 0 10px 2px rgba(0,153,255,0.7);animation:orb10 5.5s linear infinite; }
.orbit-balls .orbit-ball:nth-child(11) { width:17px;height:17px;margin:-8px;background:#00d4ff;box-shadow:0 0 16px 5px rgba(0,212,255,0.75);animation:orb11 9s linear infinite; }
.orbit-balls .orbit-ball:nth-child(12) { width:11px;height:11px;margin:-5px;background:#ff9500;box-shadow:0 0 12px 3px rgba(255,149,0,0.8);animation:orb12 4.2s linear infinite; }

/* Small orbits override */
.orbit-balls.small .orbit-ball:nth-child(1)  { animation-name:orb1s; }
.orbit-balls.small .orbit-ball:nth-child(2)  { animation-name:orb2s; }
.orbit-balls.small .orbit-ball:nth-child(3)  { animation-name:orb3s; }
.orbit-balls.small .orbit-ball:nth-child(4)  { animation-name:orb4s; }
.orbit-balls.small .orbit-ball:nth-child(5)  { animation-name:orb5s; }
.orbit-balls.small .orbit-ball:nth-child(6)  { animation-name:orb6s; }
.orbit-balls.small .orbit-ball:nth-child(7)  { animation-name:orb7s; }
.orbit-balls.small .orbit-ball:nth-child(8)  { animation-name:orb8s; }
.orbit-balls.small .orbit-ball:nth-child(9)  { animation-name:orb9s; }
.orbit-balls.small .orbit-ball:nth-child(10) { animation-name:orb10s; }
.orbit-balls.small .orbit-ball:nth-child(11) { animation-name:orb11s; }
.orbit-balls.small .orbit-ball:nth-child(12) { animation-name:orb12s; }

/* === GLASS CARDS === */
.glass-card {
  background: rgba(13,17,23,0.8);
  backdrop-filter: blur(20px);
  border: 1px solid var(--border);
  border-radius: 20px;
}
.card-hover { transition: transform 0.3s, box-shadow 0.3s; }
.card-hover:hover { transform:translateY(-4px); box-shadow:0 20px 40px rgba(255,107,0,0.12); }

/* === SECTION HEADERS === */
.sec-title {
  font-size: clamp(28px, 4vw, 48px); font-weight:800; margin-bottom:16px;
  text-align:center;
}
.sec-title span { color:var(--orange); }
.sec-sub { font-size:17px; color:var(--text-muted); text-align:center; margin-bottom:60px; }

/* === TECH SECTION === */
.tech-cards { display:grid; grid-template-columns:repeat(auto-fit,minmax(240px,1fr)); gap:20px; margin-bottom:60px; }
.tech-card {
  padding:28px; border-radius:20px; background:rgba(13,17,23,0.8);
  border:1px solid rgba(255,255,255,0.07);
  border-top-width:3px;
  transition: transform 0.3s, box-shadow 0.3s, border-color 0.3s;
  position:relative; overflow:hidden;
}
.tech-card::after {
  content: '';
  position: absolute;
  top: -50%; left: -50%;
  width: 200%; height: 200%;
  background: linear-gradient(45deg, transparent, rgba(255,255,255,0.03), transparent);
  transform: translateX(-100%) rotate(25deg);
  transition: transform 0.6s;
  pointer-events: none;
}
.tech-card:hover::after {
  transform: translateX(100%) rotate(25deg);
}
.tech-card:hover { 
  transform:translateY(-4px); 
  box-shadow:0 20px 40px rgba(255,107,0,0.15);
  border-color: rgba(255,107,0,0.5);
}
.tech-card-icon { 
  font-size:40px; margin-bottom:16px;
  transition: transform 0.2s ease;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 50px;
  height: 50px;
}
.tech-card:hover .tech-card-icon { transform: scale(1.1) rotate(3deg); }
.tech-card h3 { font-size:18px; font-weight:700; margin-bottom:10px; }
.tech-card p { font-size:14px; color:var(--text-muted); line-height:1.6; }

/* === GLASS CARDS (used in multiple sections) === */
.glass-card {
  padding: 28px;
  border-radius: 20px;
  background: rgba(13,17,23,0.65);
  border: 1px solid rgba(255,255,255,0.07);
  position: relative;
  overflow: hidden;
  transition: transform 0.3s, border-color 0.3s, box-shadow 0.3s;
}
.glass-card::after {
  content: '';
  position: absolute;
  top: -50%; left: -50%;
  width: 200%; height: 200%;
  background: linear-gradient(45deg, transparent, rgba(255,255,255,0.03), transparent);
  transform: translateX(-100%) rotate(25deg);
  transition: transform 0.6s;
  pointer-events: none;
}
.glass-card:hover::after {
  transform: translateX(100%) rotate(25deg);
}
.card-hover { cursor: default; }
.card-hover:hover {
  transform: translateY(-6px);
  border-color: rgba(255,107,0,0.25);
  box-shadow: 0 20px 40px rgba(255,107,0,0.18);
}

/* Comparison table */
.compare-table-wrap { overflow-x:auto; -webkit-overflow-scrolling:touch; display: flex; justify-content: center; }
.compare-table { width:100%; max-width:none; border-collapse:collapse; font-size:14px; }
.compare-table th, .compare-table td { padding:14px 20px; text-align:left; border-bottom:1px solid rgba(255,255,255,0.05); }
.compare-table thead { background: rgba(255,107,0,0.06); }
.compare-table thead th { padding: 14px 20px; text-align: left; font-size: 13px; color: rgba(255,255,255,0.55); font-weight: 600; }
.compare-table thead th:nth-child(n+2) { text-align: center; }
.compare-table thead th.compare-col-primary { color: rgb(255,107,0); }
.compare-table tbody tr { border-top: 1px solid rgba(255,255,255,0.04); }
.compare-table tbody tr:nth-child(even) { background: rgba(255,255,255,0.01); }
.compare-table tbody tr:hover { background: rgba(255,255,255,0.04); }
.compare-table td { padding: 14px 20px; font-size: 14px; color: rgba(255,255,255,0.7); font-weight: 500; }
.compare-table td:first-child { text-align: left; }
.compare-table td:not(:first-child) { text-align: center; }
.compare-table td.compare-primary { background: rgba(255,107,0,0.04); font-weight: 700; color: rgba(255,255,255,0.95); }
.compare-table td.compare-primary span { display: inline-flex; align-items: center; gap: 5px; font-size: 12px; }
.compare-table td:not(.compare-primary) span { display: inline-flex; align-items: center; gap: 5px; font-size: 12px; color: rgba(255,255,255,0.65); }
.dot { display: inline-block; width: 8px; height: 8px; border-radius: 50%; margin-right: 5px; vertical-align: middle; }

/* === HAPP APP === */
.app-grid {
  display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center;
  max-width:1200px; margin:0 auto;
}
.app-features { display:flex; flex-direction:column; gap:14px; margin:24px 0; }
.app-feature {
  display:flex; align-items:flex-start; gap:14px;
  padding:14px 16px; border-radius:12px;
  background:rgba(255,255,255,0.03); border:1px solid rgba(255,255,255,0.06);
  transition: transform 0.2s, border-color 0.2s;
}
.app-feature:hover {
  transform: translateX(4px);
  border-color: rgba(255,107,0,0.3);
}
.app-feature-icon { font-size:20px; flex-shrink:0; }
.app-feature-text { font-size:14px; color:rgba(255,255,255,0.75); line-height:1.5; }
.phone-mockup {
  width:260px; height:540px; background:#0d1117; border-radius:40px;
  border:6px solid rgba(255,255,255,0.12); position:relative; overflow:hidden;
  box-shadow:0 30px 80px rgba(0,0,0,0.6),0 0 0 1px rgba(255,107,0,0.1);
  animation:phone-sway 4s ease-in-out infinite;
  margin:0 auto;
}
.phone-notch {
  position:absolute; top:12px; left:50%; transform:translateX(-50%);
  width:80px; height:20px; background:#0d1117; border-radius:12px; z-index:10;
  border:2px solid rgba(255,255,255,0.08);
}
.phone-btn-r1 { position:absolute; right:-8px; top:100px; width:4px; height:50px; background:rgba(255,255,255,0.12); border-radius:2px; }
.phone-btn-r2 { position:absolute; right:-8px; top:160px; width:4px; height:50px; background:rgba(255,255,255,0.12); border-radius:2px; }
.phone-btn-l  { position:absolute; left:-8px;  top:110px; width:4px; height:70px; background:rgba(255,255,255,0.12); border-radius:2px; }
.phone-mockup img { width:100%; height:100%; object-fit:cover; object-position:top; }

/* === DOWNLOADS === */
.dl-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(240px,1fr)); gap:20px; }
.dl-card { 
  padding:28px; border-radius:20px; background:rgba(13,17,23,0.8); border:1px solid rgba(255,255,255,0.07); position:relative; overflow:hidden; transition:transform 0.3s, box-shadow 0.3s, border-color 0.3s;
}
.dl-card:hover { 
  transform:translateY(-4px); 
  border-color: rgba(255,107,0,0.5);
  box-shadow: 0 20px 40px rgba(255,107,0,0.15);
}
.dl-card::after {
  content: '';
  position: absolute;
  top: -50%; left: -50%;
  width: 200%; height: 200%;
  background: linear-gradient(45deg, transparent, rgba(255,255,255,0.03), transparent);
  transform: translateX(-100%) rotate(25deg);
  transition: transform 0.6s;
}
.dl-card:hover::after {
  transform: translateX(100%) rotate(25deg);
}
.dl-card-glow { position:absolute; top:-30px; right:-30px; width:120px; height:120px; border-radius:50%; filter:blur(30px); pointer-events:none; }
.dl-card-header { display:flex; align-items:center; gap:14px; margin-bottom:20px; }
.dl-card-title { font-size:18px; font-weight:800; }
.dl-card-count { font-size:11px; color:var(--text-dim); margin-top:2px; }
.dl-links { display:flex; flex-direction:column; gap:8px; }
.dl-link {
  display:flex; align-items:center; gap:10px;
  padding:11px 14px; border-radius:10px;
  background:rgba(255,255,255,0.03); border:1px solid rgba(255,255,255,0.07);
  transition: all 0.2s;
}
.dl-link:hover { 
  transform:translateX(4px);
  border-color: rgba(255,107,0,0.3);
}
.dl-link-info { flex:1; }
.dl-link-name { font-size:13px; font-weight:600; color:#fff; }
.dl-link-sub  { font-size:11px; color:rgba(255,255,255,0.4); margin-top:1px; }
.dl-link svg:last-child { transition: transform 0.2s; }
.dl-link:hover svg:last-child { transform: translateX(4px); }

/* === PRICING === */
.price-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); gap:24px; }
.price-card {
  padding:36px 32px; border-radius:24px; background:rgba(13,17,23,0.8);
  border:1px solid rgba(255,255,255,0.07); position:relative; overflow:hidden;
  transition: transform 0.3s, box-shadow 0.3s, border-color 0.3s;
  z-index: 1;
  display: flex;
  flex-direction: column;
}
.price-card::before {
  content: '';
  position: absolute;
  top: -1px; left: -1px; right: -1px; bottom: -1px;
  border-radius: inherit;
  padding: 1px;
  background: linear-gradient(135deg, #ff6b00, #ff9500, #00d4ff);
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  opacity: 0;
  transition: opacity 0.3s;
  pointer-events: none;
  z-index: 0;
}
.price-card::after {
  content: '';
  position: absolute;
  top: -50%; left: -50%;
  width: 200%; height: 200%;
  background: linear-gradient(45deg, transparent, rgba(255,255,255,0.03), transparent);
  transform: translateX(-100%) rotate(25deg);
  transition: transform 0.6s;
  pointer-events: none;
  z-index: 2;
}
.price-card:hover::before {
  opacity: 1;
}
.price-card:hover::after {
  transform: translateX(100%) rotate(25deg);
}
.price-card:hover { 
  transform:translateY(-6px); 
  box-shadow:0 25px 50px rgba(0,0,0,0.4);
  border-color: rgba(255,107,0,0.3);
}
.price-card.popular {
  border: 2px solid rgba(255,107,0,0.9);
  box-shadow:0 0 40px rgba(255,107,0,0.2);
  background: rgba(18, 18, 22, 0.9);
}
.price-popular-badge {
  position:absolute; top:20px; right:20px;
  padding:4px 12px; border-radius:50px; font-size:11px; font-weight:700;
  background:linear-gradient(90deg,#ff6b00,#ff9500,#ffb700,#ff6b00);
  background-size:200% 100%; animation:shimmer 2s linear infinite;
  color:#fff;
}
.price-name { font-size:22px; font-weight:800; margin-bottom:6px; }
.price-devices { font-size:13px; color:var(--text-muted); margin-bottom:28px; }
.price-amount { font-size:52px; font-weight:900; color:var(--orange); line-height:1; margin-bottom:4px; }
.price-amount span { font-size:20px; font-weight:600; }
.price-period { font-size:13px; color:var(--text-muted); margin-bottom:32px; }
.price-features { display:flex; flex-direction:column; gap:12px; margin-bottom:32px; }
.price-feature { display:flex; align-items:center; gap:10px; font-size:14px; color:rgba(255,255,255,0.8); }
.price-feature::before { content:'✓'; color:var(--green); font-weight:700; flex-shrink:0; }
.btn-price {
  display:block; width:100%; padding:16px; border-radius:14px;
  text-align:center; font-size:16px; font-weight:700; color:#fff;
  background:linear-gradient(135deg,var(--orange),var(--orange-lt));
  box-shadow:0 4px 15px rgba(255,107,0,0.3); transition: transform 0.15s, box-shadow 0.2s;
  margin-top: auto;
}
.btn-price:hover { 
  transform: translateY(-2px) scale(1.02);
  box-shadow:0 8px 25px rgba(255,107,0,0.6);
}
.btn-price:active { transform: translateY(0) scale(0.98); }
.btn-price-outline {
  display:block; width:100%; padding:16px; border-radius:14px;
  text-align:center; font-size:16px; font-weight:600;
  border:1px solid rgba(255,255,255,0.15); color:rgba(255,255,255,0.8);
  background:rgba(255,255,255,0.03); transition: all 0.3s;
}
.btn-price-outline:hover { border-color:rgba(255,107,0,0.4); color:#fff; }

.btn-outline-orange, .btn-outline-blue, .btn-primary {
  display:block; width:100%; padding:16px; border-radius:14px;
  text-align:center; font-size:16px; font-weight:700; text-decoration:none;
  border:1px solid rgba(255,255,255,0.2); color:rgba(255,255,255,0.85);
  background:rgba(255,255,255,0.03); transition: transform 0.15s, box-shadow 0.2s, background 0.2s, border-color 0.2s;
  margin-top: auto;
}
.btn-outline-orange:hover {
  background:rgba(255,107,0,0.12);
  border-color:rgba(255,107,0,0.6);
  color:#fff;
  transform: translateY(-2px) scale(1.02);
  box-shadow:0 8px 25px rgba(255,107,0,0.4);
}
.btn-outline-blue:hover {
  background:rgba(0,212,255,0.12);
  border-color:rgba(0,212,255,0.6);
  color:#fff;
  transform: translateY(-2px) scale(1.02);
  box-shadow:0 8px 25px rgba(0,212,255,0.4);
}
.btn-primary:hover {
  background:rgba(255,255,255,0.12);
  border-color:rgba(255,255,255,0.4);
  transform: translateY(-2px) scale(1.02);
  box-shadow:0 8px 25px rgba(255,255,255,0.25);
}
.btn-outline-orange:active, .btn-outline-blue:active, .btn-primary:active { transform: translateY(0) scale(0.98); }

/* === SERVERS === */
.servers-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(300px,1fr)); gap:16px; }
.server-card {
  padding:22px 24px; border-radius:18px; background:rgba(13,17,23,0.8);
  border:1px solid rgba(255,255,255,0.07); transition: all 0.3s;
  position:relative; overflow:hidden;
}
.server-card::after {
  content: '';
  position: absolute;
  top: -50%; left: -50%;
  width: 200%; height: 200%;
  background: linear-gradient(45deg, transparent, rgba(255,255,255,0.03), transparent);
  transform: translateX(-100%) rotate(25deg);
  transition: transform 0.6s;
  pointer-events: none;
}
.server-card:hover::after {
  transform: translateX(100%) rotate(25deg);
}
.server-card:hover { 
  border-color:rgba(255,107,0,0.3); 
  transform: scale(1.02);
  box-shadow: 0 20px 40px rgba(255,107,0,0.1);
}
.server-head { display:flex; justify-content:space-between; align-items:flex-start; margin-bottom:16px; }
.server-flag { font-size:30px; line-height:1; margin-right:12px; }
.server-country { font-weight:800; font-size:16px; line-height:1.2; }
.server-city { font-size:13px; color:var(--text-muted); margin-top:2px; }
.online-badge { 
  display:flex; align-items:center; gap:6px; background:rgba(34,197,94,0.1); padding:4px 10px; border-radius:50px; border:1px solid rgba(34,197,94,0.25);
  position: relative;
  margin-right: 0;
}
.online-badge .dot-blink { width:7px; height:7px; background:var(--green); border-radius:50%; animation:blink 1.5s ease-in-out infinite; }
.online-badge span { font-size:11px; color:var(--green); font-weight:700; }
.online-badge::before {
  content: '';
  position: absolute;
  width: 100%; height: 100%;
  border-radius: 50px;
  box-shadow: none;
  animation: none;
  pointer-events: none;
}
.server-uptime { font-size:10px; color:var(--text-dim); text-align:right; margin-top:4px; }
.server-proto { font-size:10px; font-weight:700; color:var(--orange); background:rgba(255,107,0,0.1); border:1px solid rgba(255,107,0,0.25); padding:3px 10px; border-radius:50px; letter-spacing:0.5px; display:inline-block; margin-bottom:14px; }
.server-stats { display:grid; grid-template-columns:1fr 1fr; gap:10px; margin-bottom:14px; }
.server-stat { background:rgba(255,255,255,0.03); border-radius:10px; padding:10px 12px; border:1px solid rgba(255,255,255,0.05); }
.server-stat-lbl { font-size:10px; color:rgba(255,255,255,0.4); text-transform:uppercase; letter-spacing:0.5px; margin-bottom:4px; }
.server-stat-val { 
  font-size:20px; font-weight:800; line-height:1; 
  transition: color 0.3s, transform 0.3s;
}
.server-stat-val.updated {
  animation: none;
}
.server-stat-unit { font-size:11px; font-weight:500; color:rgba(255,255,255,0.4); margin-left:2px; }
.server-ip { font-size:11px; color:rgba(255,255,255,0.25); margin-bottom:12px; font-family:monospace; }
.server-bar { height:5px; background:rgba(255,255,255,0.06); border-radius:3px; overflow:hidden; }
.server-bar-fill { 
  height:100%; border-radius:3px; 
  transition: width 0.5s ease;
  background-size: 200% 100%;
  animation: loading-pulse 2s infinite;
}

/* === HOW IT WORKS === */
.steps-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:24px; margin-bottom:50px; }
.step-card {
  padding:28px; border-radius:20px; background:rgba(13,17,23,0.8);
  border:1px solid rgba(255,255,255,0.07); position:relative; overflow:hidden;
  transition: transform 0.3s, border-color 0.3s;
}
.step-card::after {
  content: '';
  position: absolute;
  top: -50%; left: -50%;
  width: 200%; height: 200%;
  background: linear-gradient(45deg, transparent, rgba(255,255,255,0.03), transparent);
  transform: translateX(-100%) rotate(25deg);
  transition: transform 0.6s;
  pointer-events: none;
}
.step-card:hover::after {
  transform: translateX(100%) rotate(25deg);
}
.step-card:hover { 
  transform:translateY(-4px);
  border-color: rgba(255,107,0,0.5);
  box-shadow: 0 20px 40px rgba(255,107,0,0.15);
}
.step-num-bg { position:absolute; top:-10px; right:-10px; font-size:80px; font-weight:900; color:rgba(255,107,0,0.06); line-height:1; pointer-events:none; }
.step-icon { font-size:40px; margin-bottom:16px; transition: transform 0.2s; display:flex; align-items:center; justify-content:center; width:50px; height:50px; }
.step-card:hover .step-icon { transform: scale(1.1); }
.step-title { font-size:18px; font-weight:700; color:var(--orange); margin-bottom:10px; }
.step-desc { font-size:14px; color:rgba(255,255,255,0.6); line-height:1.6; }

/* === REVIEWS === */
.reviews-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); gap:20px; margin-bottom:40px; }
.review-card {
  padding:24px; border-radius:20px; background:rgba(13,17,23,0.8);
  border:1px solid rgba(255,255,255,0.07); display:flex; flex-direction:column; gap:16px;
  transition: transform 0.3s, border-color 0.3s;
  position:relative; overflow:hidden;
}
.review-card::after {
  content: '';
  position: absolute;
  top: -50%; left: -50%;
  width: 200%; height: 200%;
  background: linear-gradient(45deg, transparent, rgba(255,255,255,0.03), transparent);
  transform: translateX(-100%) rotate(25deg);
  transition: transform 0.6s;
  pointer-events: none;
}
.review-card:hover::after {
  transform: translateX(100%) rotate(25deg);
}
.review-card:hover { 
  transform:translateY(-4px); 
  border-color: rgba(255,107,0,0.5);
  box-shadow: 0 20px 40px rgba(255,107,0,0.15);
}
.review-header { display:flex; align-items:center; gap:14px; }
.review-avatar { width:44px; height:44px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:18px; font-weight:700; color:#fff; flex-shrink:0; }
.review-name { font-weight:700; font-size:15px; }
.review-stars { color:#fbbf24; font-size:13px; letter-spacing:1px; }
.review-text { font-size:14px; color:rgba(255,255,255,0.7); line-height:1.65; }
.review-date { font-size:12px; color:rgba(255,255,255,0.3); }

/* === FOOTER === */
footer {
  border-top:1px solid rgba(255,255,255,0.06);
  padding:60px 24px 32px;
}
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:40px; margin-bottom:48px; }
.footer-brand p { font-size:14px; color:rgba(255,255,255,0.45); line-height:1.6; margin:12px 0 16px; }
.footer-tg { display:inline-flex; align-items:center; gap:6px; font-size:13px; color:#0099cc; font-weight:600; }
.footer-col h4 { font-size:14px; font-weight:700; color:rgba(255,255,255,0.9); margin-bottom:16px; text-transform:uppercase; letter-spacing:1px; }
.footer-col a { 
  display:block; 
  font-size:14px; 
  color:rgba(255,255,255,0.45); 
  margin-bottom:10px; 
  transition: color 0.2s;
  position: relative;
  width: fit-content;
}
.footer-col a::after {
  content: '';
  position: absolute;
  bottom: -2px; left: 0;
  width: 0; height: 1px;
  background: var(--orange);
  transition: width 0.2s;
}
.footer-col a:hover { color: var(--orange); }
.footer-col a:hover::after { width: 100%; }
.footer-bottom { border-top:1px solid rgba(255,255,255,0.06); padding-top:24px; display:flex; flex-wrap:wrap; justify-content:space-between; align-items:center; gap:16px; }
.footer-copy { font-size:13px; color:rgba(255,255,255,0.3); }
.footer-legal { display:flex; gap:20px; flex-wrap:wrap; }
.footer-legal a { font-size:13px; color:rgba(255,255,255,0.35); transition: color 0.2s; }
.footer-legal a:hover { color:var(--orange); }

/* === GIFT BANNER === */
.gift-banner {
  display:inline-flex; align-items:center; gap:12px;
  padding:16px 28px; border-radius:16px; font-size:15px; font-weight:600;
  background:rgba(255,107,0,0.06); border:1px solid rgba(255,107,0,0.2); color:rgba(255,255,255,0.8);
  transition: all 0.3s;
}
.gift-banner:hover { background:rgba(255,107,0,0.1); border-color:rgba(255,107,0,0.35); }

/* === LEGAL PAGES === */
.legal-page { max-width:900px; margin:0 auto; padding:60px 24px 100px; }
.legal-page h1 { font-size:clamp(28px,4vw,44px); font-weight:900; margin:20px 0 12px; line-height:1.15; }
.legal-page h2 { font-size:20px; font-weight:700; color:var(--orange); margin:0 0 14px; padding-bottom:10px; border-bottom:1px solid rgba(255,107,0,0.15); }
.legal-page p { font-size:15px; color:rgba(255,255,255,0.7); line-height:1.8; white-space:pre-line; margin-bottom:12px; }
.legal-notice { background:rgba(255,149,0,0.08); border:1px solid rgba(255,149,0,0.3); border-radius:14px; padding:16px 20px; margin-bottom:40px; display:flex; gap:12px; }

/* === SCROLL ANIMATIONS === */
.animate { opacity:0; transform:translateY(32px); transition: opacity 0.6s ease, transform 0.6s ease; }
.animate.visible { opacity:1; transform:translateY(0); }

/* Каскадные задержки для карточек тарифов */
.price-card:nth-child(1) { transition-delay: 0.1s; }
.price-card:nth-child(2) { transition-delay: 0.2s; }
.price-card:nth-child(3) { transition-delay: 0.3s; }

/* === RESPONSIVE === */
@media (max-width: 768px) {
  .section { padding: 60px 24px; }

  /* Header */
  .nav-links, .header-btns { display:none; }
  .burger { display:flex; }

  /* Hero */
  .hero-grid { grid-template-columns:1fr; gap:32px; padding:40px 24px; }
  .hero-visual { height:280px; }
  .orbit-wrap { width:260px; height:260px; }
  .orbit-ring { width:140px; height:140px; }
  .hero-glow1 { width:200px; height:200px; }
  .hero-glow2 { width:140px; height:140px; }
  .orbit-balls .orbit-ball:nth-child(1)  { animation-name:orb1s; }
  .orbit-balls .orbit-ball:nth-child(2)  { animation-name:orb2s; }
  .orbit-balls .orbit-ball:nth-child(3)  { animation-name:orb3s; }
  .orbit-balls .orbit-ball:nth-child(4)  { animation-name:orb4s; }
  .orbit-balls .orbit-ball:nth-child(5)  { animation-name:orb5s; }
  .orbit-balls .orbit-ball:nth-child(6)  { animation-name:orb6s; }
  .orbit-balls .orbit-ball:nth-child(7)  { animation-name:orb7s; }
  .orbit-balls .orbit-ball:nth-child(8)  { animation-name:orb8s; }
  .orbit-balls .orbit-ball:nth-child(9)  { animation-name:orb9s; }
  .orbit-balls .orbit-ball:nth-child(10) { animation-name:orb10s; }
  .orbit-balls .orbit-ball:nth-child(11) { animation-name:orb11s; }
  .orbit-balls .orbit-ball:nth-child(12) { animation-name:orb12s; }

  /* App section */
  .app-grid { grid-template-columns:1fr; gap:32px; }
  .phone-mockup { display:none; }

  /* Footer */
  .footer-grid { grid-template-columns:1fr 1fr; gap:32px; }
  .footer-brand { grid-column:1/-1; }

  /* Compare table */
  .compare-table th, .compare-table td { padding: 10px 12px; font-size: 12px; }
  .compare-table thead th { padding: 10px 12px; font-size: 12px; }
  .compare-table td span { font-size: 11px; }

  /* Hide compare section on mobile */
  .compare-section { display: none; }
}

@media (max-width: 480px) {
  .footer-grid { grid-template-columns:1fr; }
  .hero-h1 { font-size:32px; }

  /* Compare table */
  .compare-table th, .compare-table td { padding: 8px 10px; font-size: 11px; }
  .compare-table thead th { padding: 8px 10px; font-size: 11px; }
  .compare-table td span { font-size: 10px; }
}

@media (max-width: 480px) {
  .footer-grid { grid-template-columns:1fr; }
  .hero-h1 { font-size:32px; }
  .price-amount { font-size:42px; }
}