@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=JetBrains+Mono:wght@400;600&display=swap');
:root{
  --bg-1:#070b14;
  --bg-2:#0c1424;
  --text:#e8ecff;
  --muted:#a8b3cc;
  --accent:#6cd5ff;
  --accent-2:#8b7bff;
  --glass:rgba(14,22,38,.58);
  --line:rgba(130,170,255,.18);
}
*{box-sizing:border-box}
body{
  margin:0;
  font-family:'Space Grotesk','Trebuchet MS','Verdana',sans-serif;
  background:transparent;
  color:var(--text);
  min-height:100%;
  overflow-x:hidden;
  overflow-y:auto;
  position:relative;
}
body::before{
  content:'';
  position:fixed;
  inset:-42vmax;
  background:
    conic-gradient(
      from 0deg at 50% 50%,
      rgba(109,213,255,.06) 0deg,
      rgba(139,123,255,.05) 120deg,
      rgba(79,112,255,.05) 240deg,
      rgba(109,213,255,.06) 360deg
    ),
    radial-gradient(circle at 15% 25%,rgba(109,213,255,.17),transparent 32%),
    radial-gradient(circle at 82% 8%,rgba(139,123,255,.15),transparent 30%),
    radial-gradient(circle at 50% 88%,rgba(79,112,255,.12),transparent 28%);
  background-repeat:no-repeat;
  background-size:cover;
  pointer-events:none;
  animation:ambient-rotate 120s linear infinite;
}
body::after{
  content:'';
  position:fixed;
  inset:0;
  background:radial-gradient(220px circle at var(--cursor-x,50%) var(--cursor-y,50%),rgba(109,213,255,.09),transparent 68%);
  pointer-events:none;
  opacity:.45;
  transition:background .15s linear;
}
@keyframes ambient-rotate{
  0%{transform:rotate(0deg) scale(1.2)}
  100%{transform:rotate(360deg) scale(1.2)}
}
body .dust{position:fixed;inset:0;pointer-events:none;overflow:hidden}
body .dust span{
  position:absolute;
  width:var(--dust-size,2px);
  height:var(--dust-size,2px);
  background:rgba(255,255,255,0.8);
  border-radius:50%;
  opacity:0;
  will-change:transform,opacity;
  animation-name:dust-random;
  animation-duration:var(--dust-duration,15s);
  animation-delay:var(--dust-delay,0s);
  animation-timing-function:linear;
  animation-iteration-count:infinite;
  /* Все параметры задаются через JS */
}
@keyframes dust-random{
  0%{transform:translate3d(0,0,0);opacity:0}
  10%{opacity:var(--dust-opacity,0.55)}
  90%{opacity:var(--dust-opacity,0.55)}
  100%{transform:translate3d(var(--dx,50px),var(--dy,-100vh),0);opacity:0}
}
html{
  min-height:100%;
  scroll-behavior:auto;
  scrollbar-gutter:stable;
  background:linear-gradient(145deg,var(--bg-1),var(--bg-2) 45%,#0b1020 100%);
  background-attachment:fixed;
}
@supports(scrollbar-color:rgba(255,255,255,.3) transparent){
  html{scrollbar-color:rgba(255,255,255,.3) transparent;scrollbar-width:thin}
}
.scroll-progress{
  position:fixed;
  top:0;
  left:0;
  width:100%;
  height:3px;
  background:linear-gradient(90deg,var(--accent),#9b9cff,var(--accent-2));
  transform-origin:left center;
  transform:scaleX(0);
  box-shadow:0 0 18px rgba(109,213,255,.6);
  z-index:2500;
  pointer-events:none;
}
.container{max-width:1120px;margin:auto;padding:26px 24px}
.header-container{padding-top:0}
.header .container{padding-top:14px;padding-bottom:14px}
.header{
  position:fixed;
  top:0;
  left:0;
  right:0;
  z-index:1000;
  background:linear-gradient(180deg,rgba(13,19,35,.78),rgba(13,19,35,.6));
  border-bottom:1px solid var(--line);
  backdrop-filter:blur(16px) saturate(130%);
  transition:transform .6s ease,background .35s ease;
  box-shadow:0 14px 28px rgba(2,8,18,.28);
  overflow:visible;
}
.header::after{content:'';position:absolute;bottom:-1px;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(109,213,255,.45),transparent)}
.header-glow{position:absolute;top:-24px;left:50%;transform:translateX(-50%);width:min(620px,82vw);height:130px;background:radial-gradient(ellipse at center top,rgba(109,213,255,0.17) 0%,rgba(109,213,255,0.05) 40%,transparent 72%);pointer-events:none;animation:header-glow 9s ease-in-out infinite}
@keyframes header-glow{0%,100%{opacity:0.3}50%{opacity:0.6}}
.header-hidden{transform:translateY(-100%)}
.header-inner{display:flex;align-items:center;justify-content:space-between}
.logo{font-weight:700;display:flex;align-items:center;gap:10px;letter-spacing:.2px}
.logo-icon{
  width:34px;
  height:34px;
  border-radius:10px;
  display:grid;
  place-items:center;
  background:linear-gradient(135deg,var(--accent),var(--accent-2));
  box-shadow:0 8px 16px rgba(79,112,255,.35);
  animation:logo-pulse 3s ease-in-out infinite;
}
.logo-icon::before{content:'EGNT';font-size:.72rem;color:#041025;font-weight:700}
@keyframes logo-pulse{0%,100%{transform:translateY(0);opacity:1}50%{transform:translateY(-2px);opacity:.95}}
.logo-text{background:linear-gradient(90deg,#f8fbff,#b9c8ff 65%,#a5f0ff);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
main.container{padding-top:100px}
.nav{position:relative;display:flex;gap:14px}
.nav a{
  color:var(--muted);
  text-decoration:none;
  padding:7px 13px;
  border-radius:10px;
  z-index:2;
  transition:color .25s ease,transform .25s ease;
  position:relative;
  letter-spacing:.2px;
}
.nav a::after{content:'';position:absolute;left:9px;right:9px;bottom:5px;height:2px;background:linear-gradient(90deg,transparent,var(--accent),transparent);opacity:0;transition:opacity .25s ease}
.nav a:hover::after,.nav a.active::after{opacity:1}
.nav a:hover,.nav a.active{color:#fff;transform:translateY(-1px)}
.nav-highlight{
  position:absolute;
  top:0;
  left:0;
  height:100%;
  border-radius:10px;
  background:linear-gradient(135deg,rgba(109,213,255,.2),rgba(139,123,255,.2));
  backdrop-filter:blur(8px);
  box-shadow:0 10px 26px rgba(80,117,255,.22),inset 0 0 0 1px rgba(190,220,255,.26);
  transition:all .35s ease;
  opacity:0;
  z-index:1;
  pointer-events:none;
}
.burger{
  display:none;
  flex-direction:column;
  justify-content:center;
  align-items:center;
  gap:5px;
  width:42px;
  height:42px;
  padding:0;
  border:1px solid rgba(170,205,255,.28);
  border-radius:12px;
  background:linear-gradient(145deg,rgba(12,22,42,.86),rgba(18,31,58,.78));
  box-shadow:0 8px 16px rgba(0,0,0,.28);
  cursor:pointer;
}
.burger span{
  display:block;
  width:22px;
  height:2px;
  background:linear-gradient(90deg,#ffffff,#93c8ff);
  transform-origin:center;
  transition:transform .26s ease,opacity .2s ease;
}
.burger.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.is-open span:nth-child(2){opacity:0}
.burger.is-open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Hero секция (только для главной) */
.hero{
  position: relative;
  width: 100vw;
  aspect-ratio: 1080 / 608;
  min-height: 300px;
  margin-left: calc(50% - 50vw);
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  background: url('images/hero.gif') center / cover no-repeat;
  transition: transform .2s ease-out;
  overflow: hidden;
}
.hero::before{
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,transparent 0%,rgba(0,0,0,0.4) 100%);
  pointer-events:none;
}
.hero::after{
  content:'';
  position:absolute;
  inset:-20% -18%;
  background:linear-gradient(112deg,transparent 35%,rgba(109,213,255,.18) 50%,transparent 65%);
  opacity:.42;
  mix-blend-mode:screen;
  transform:translateX(-45%) skewX(-10deg);
  animation:hero-scan 10s linear infinite;
  pointer-events:none;
}
@keyframes hero-scan{
  0%{transform:translateX(-48%) skewX(-10deg)}
  100%{transform:translateX(48%) skewX(-10deg)}
}
.hero h1{font-size:clamp(1.6rem,5vw,3.2rem);margin-bottom:16px;line-height:1.14;word-wrap:break-word;animation:fadeInUp 1s ease;text-shadow:0 10px 30px rgba(0,0,0,.45)}
@keyframes fadeInUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}
.hero-panel{
  padding:26px 24px;
  border-radius:22px;
  background:linear-gradient(145deg,rgba(7,12,24,.72),rgba(12,20,40,.58));
  border:1px solid rgba(170,205,255,.22);
  backdrop-filter: blur(12px) saturate(120%);
  box-shadow:0 24px 70px rgba(0,0,0,0.45),0 0 40px rgba(109,213,255,.1);
  max-width:calc(100vw - 40px);
}
.hero .btns{display:flex;gap:12px;justify-content:center;margin-top:16px;flex-wrap:wrap}
.hero .btn{
  padding:11px 20px;
  border:1px solid rgba(170,205,255,.28);
  border-radius:10px;
  background:linear-gradient(135deg,rgba(109,213,255,.2),rgba(139,123,255,.16));
  color:#f7fbff;
  text-decoration:none;
  transition:transform .25s ease,box-shadow .25s ease,background .25s ease;
  font-size:clamp(0.85rem,2vw,1rem);
}
.hero .btn:hover{transform:translateY(-2px);box-shadow:0 12px 24px rgba(84,123,255,.25);background:linear-gradient(135deg,rgba(109,213,255,.28),rgba(139,123,255,.24))}

/* Карточки и кнопки */
.card{
  --rx:0deg;
  --ry:0deg;
  --raise:0px;
  --mx:50%;
  --my:50%;
  background:linear-gradient(155deg,rgba(17,25,44,.72),rgba(12,18,34,.62));
  border:1px solid rgba(160,195,255,.16);
  border-radius:18px;
  padding:24px;
  padding-right:170px;
  margin-bottom:18px;
  position:relative;
  transition:box-shadow .62s ease,border-color .62s ease;
  overflow:hidden;
  box-shadow:0 16px 36px rgba(0,0,0,.28);
  transform:perspective(1100px) rotateX(var(--rx)) rotateY(var(--ry)) translateY(var(--raise));
  transform-style:preserve-3d;
  will-change:transform;
  isolation:isolate;
}
.card::before{content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(170,225,255,0.14),transparent);transition:left .55s ease;pointer-events:none;z-index:0}
.card::after{
  content:'';
  position:absolute;
  inset:0;
  background:radial-gradient(220px circle at var(--mx) var(--my),rgba(109,213,255,.16),transparent 70%);
  opacity:0;
  transition:opacity .25s ease;
  pointer-events:none;
  z-index:0;
}
.card:hover::before{left:100%}
.card:hover{box-shadow:0 24px 44px rgba(0,0,0,0.4),0 0 35px rgba(109,213,255,.1);border-color:rgba(170,225,255,.28)}
.card:hover::after{opacity:1}
.card > *{position:relative;z-index:1}
.card-image{position:absolute;top:24px;right:24px;width:128px;height:128px;border-radius:16px;border:2px solid rgba(170,205,255,0.38);object-fit:cover;z-index:2;transition:transform .5s ease}
.card:hover .card-image{transform:scale(1.05)}
.card h2,.card h3,.card p,.card .game-btns{max-width:calc(100% - 196px)}
.btn{
  display:inline-block;
  padding:10px 20px;
  border-radius:10px;
  border:1px solid rgba(170,205,255,.2);
  background:linear-gradient(135deg,rgba(109,213,255,.18),rgba(139,123,255,.16));
  color:#fff;
  text-decoration:none;
  transition:transform .25s ease,box-shadow .25s ease,background .25s ease;
}
.btn:hover{transform:translateY(-2px);box-shadow:0 12px 24px rgba(84,123,255,.22);background:linear-gradient(135deg,rgba(109,213,255,.26),rgba(139,123,255,.24))}

/* Кнопки игр */
.game-btns{display:flex;gap:12px;flex-wrap:wrap;margin-top:16px}
.game-btn{
  padding:12px 24px;
  border:1px solid rgba(170,205,255,.26);
  border-radius:10px;
  background:linear-gradient(145deg,rgba(9,16,30,.74),rgba(17,32,64,.62));
  background-size:220% 220%;
  animation:button-flow 8s linear infinite;
  backdrop-filter:blur(10px);
  color:#fff;
  text-decoration:none;
  transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease;
  cursor:pointer;
}
.game-btn:hover{transform:translateY(-2px);box-shadow:0 12px 24px rgba(79,112,255,.25);border-color:rgba(170,225,255,.42)}
@keyframes button-flow{
  0%{background-position:0% 50%}
  100%{background-position:100% 50%}
}

/* Поля для копирования / код */
.code-block{background:rgba(0,0,0,0.4);border:1px solid rgba(255,255,255,0.08);border-radius:8px;padding:16px;margin:16px 0;position:relative}
.code-block code{font-family:'JetBrains Mono','Consolas','Monaco',monospace;font-size:0.9rem;color:#e0e0e0;display:block;white-space:pre-wrap;word-break:break-all}
.copy-btn{position:relative;top:8px;right:0px;padding:6px 12px;border-radius:6px;background:rgba(255,255,255,0.1);border:none;color:#aaa;font-size:0.8rem;cursor:pointer;transition:all .3s}
.copy-btn:hover{background:rgba(255,255,255,0.2);color:#fff}
.copy-btn.copied{background:rgba(76,175,80,0.3);color:#4caf50}

/* Фотогалерея */
.gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px;margin-top:24px}
.gallery-item{
  --rx:0deg;
  --ry:0deg;
  --raise:0px;
  --mx:50%;
  --my:50%;
  position:relative;
  border-radius:16px;
  overflow:hidden;
  cursor:pointer;
  border:1px solid rgba(160,195,255,.16);
  background:linear-gradient(155deg,rgba(17,25,44,.72),rgba(12,18,34,.62));
  box-shadow:0 14px 34px rgba(0,0,0,.3);
  transition:box-shadow .62s ease,border-color .62s ease;
  transform:perspective(1100px) rotateX(var(--rx)) rotateY(var(--ry)) translateY(var(--raise));
  transform-style:preserve-3d;
  will-change:transform;
  isolation:isolate;
}
.gallery-item::before{content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(170,225,255,0.14),transparent);transition:left .55s ease;pointer-events:none;z-index:0}
.gallery-item::after{
  content:'';
  position:absolute;
  inset:0;
  background:radial-gradient(220px circle at var(--mx) var(--my),rgba(109,213,255,.16),transparent 70%);
  opacity:0;
  transition:opacity .25s ease;
  pointer-events:none;
  z-index:0;
}
.gallery-item:hover{box-shadow:0 24px 44px rgba(0,0,0,.4),0 0 35px rgba(109,213,255,.1);border-color:rgba(170,225,255,.28)}
.gallery-item:hover::before{left:100%}
.gallery-item:hover::after{opacity:1}
.gallery-item > *{position:relative;z-index:1}
.gallery-item img{width:100%;height:280px;object-fit:cover;display:block;transform:translateZ(20px) scale(1);transition:transform .62s cubic-bezier(.22,1,.36,1)}
.gallery-item:hover img{transform:translateZ(20px) scale(1.05)}
.gallery-item:focus-visible{outline:2px solid rgba(255,255,255,.7);outline-offset:3px}
.gallery-caption{position:absolute;bottom:0;left:0;right:0;padding:16px;background:linear-gradient(transparent,rgba(0,0,0,0.8));color:#fff;font-size:0.9rem;transition:transform .3s ease}
.gallery-item:hover .gallery-caption{transform:translateY(-4px)}

/* Лайтбокс для просмотра фото */
.lightbox{position:fixed;inset:0;background:rgba(0,0,0,.92);z-index:10000;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;pointer-events:none;transition:opacity .35s ease,visibility 0s linear .35s}
.lightbox.active{opacity:1;visibility:visible;pointer-events:auto;transition:opacity .35s ease}
.lightbox img{position:fixed;left:0;top:0;width:0;height:0;object-fit:contain;transform-origin:top left;will-change:transform,left,top,width,height;border-radius:12px;box-shadow:0 20px 60px rgba(0,0,0,.5);transition:opacity .18s ease}
.lightbox-close{position:absolute;top:20px;right:30px;font-size:40px;color:#fff;cursor:pointer;background:none;border:none;transition:color .3s;z-index:10001}
.lightbox-close:hover{color:#aaa}
.lightbox-prev,.lightbox-next{position:fixed;top:50%;transform:translateY(-50%);font-size:40px;color:#fff;cursor:pointer;background:rgba(0,0,0,.25);border:1px solid rgba(255,255,255,.15);border-radius:12px;padding:14px 18px;transition:color .3s,background .3s,border-color .3s;z-index:10001}
.lightbox-prev:hover,.lightbox-next:hover{color:#aaa;background:rgba(0,0,0,.45);border-color:rgba(255,255,255,.28)}
.lightbox-prev{left:20px}
.lightbox-next{right:20px}
.lightbox-meta{position:fixed;left:50%;bottom:20px;transform:translateX(-50%);z-index:10001;text-align:center;width:min(680px,calc(100vw - 40px));padding:12px 16px;border-radius:12px;background:rgba(0,0,0,.38);backdrop-filter:blur(8px)}
.lightbox-counter{display:block;font-size:.8rem;letter-spacing:.08em;text-transform:uppercase;color:#cfcfcf}
.lightbox-caption{margin:6px 0 0;font-size:1rem;color:#fff}
.lightbox-hint{margin:6px 0 0;font-size:.82rem;color:#b6b6b6}
.lightbox-thumbs{margin-top:10px;display:flex;gap:8px;overflow-x:auto;padding:6px 4px 8px;scrollbar-width:thin;scroll-snap-type:x proximity;overscroll-behavior-x:contain;-webkit-overflow-scrolling:touch;cursor:grab;touch-action:pan-x;user-select:none}
.lightbox-thumbs.is-dragging{cursor:grabbing}
.lightbox-thumb{flex:0 0 58px;width:58px;height:44px;padding:0;border-radius:8px;border:1px solid rgba(255,255,255,.2);background:transparent;cursor:pointer;overflow:hidden;opacity:.44;transform:translateY(0) scale(.86);filter:saturate(.74);transition:opacity .24s ease,border-color .24s ease,transform .24s cubic-bezier(.22,1,.36,1),box-shadow .24s ease,filter .24s ease;scroll-snap-align:center}
.lightbox-thumb img{width:100%;height:100%;object-fit:cover;display:block;pointer-events:none}
.lightbox-thumb.is-near{opacity:.75;transform:translateY(-1px) scale(.96);filter:saturate(.9)}
.lightbox-thumb.is-far{opacity:.44}
.lightbox-thumb:hover{opacity:.9;border-color:rgba(255,255,255,.45);transform:translateY(-1px) scale(1)}
.lightbox-thumb.is-active{opacity:1;border-color:#fff;transform:translateY(-3px) scale(1.14);filter:none;box-shadow:0 12px 22px rgba(0,0,0,.38)}
.lightbox-thumb:focus-visible{outline:2px solid rgba(255,255,255,.8);outline-offset:2px}

/* Анимации */
.fade{opacity:0;translate:0 18px;filter:blur(6px);transition:opacity 1s ease,translate 1s cubic-bezier(.16,1,.3,1),filter 1s ease}
.fade.visible{opacity:1;translate:0 0;filter:blur(0)}
.fade.card-1{transition-delay:.1s}
.fade.card-2{transition-delay:.2s}
.fade.card-3{transition-delay:.3s}
.fade.card-4{transition-delay:.4s}
.fade.card-5{transition-delay:.5s}
.fade.card-6{transition-delay:.6s}
.fade.card-7{transition-delay:.7s}
.fade.card-8{transition-delay:.8s}
.fade.card-9{transition-delay:.9s}
.fade.card-10{transition-delay:1.0s}

/* Плавающие элементы для живости */
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
.float-slow{animation:float 6s ease-in-out infinite}
.float-medium{animation:float 4s ease-in-out infinite}
.float-fast{animation:float 3s ease-in-out infinite}

/* Пульсация для кнопок/акцентов */
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.7}}
.pulse{animation:pulse 2s ease-in-out infinite}

/* Градиентная анимация */
@keyframes gradient-shift{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}
.gradient-animated{background:linear-gradient(-45deg,#1a1a2e,#16213e,#0f3460,#1a1a2e);background-size:400% 400%;animation:gradient-shift 15s ease infinite}

/* Свечение при наведении */
.glow-hover{transition:box-shadow .3s ease}
.glow-hover:hover{box-shadow:0 0 30px rgba(255,255,255,0.1)}

/* Мерцание для статусов */
@keyframes shimmer{0%{opacity:.6}50%{opacity:1}100%{opacity:.6}}
.shimmer{animation:shimmer 2s infinite}

/* Футер */
.footer{border-top:1px solid rgba(255,255,255,.08);padding:0 0 0px;text-align:center;position:relative;overflow:visible;isolation:isolate}
.footer::before{
  content:'';
  position:absolute;
  bottom:-120px;
  left:50%;
  transform:translateX(-50%);
  width:min(1100px,90vw);
  height:clamp(180px,22vw,260px);
  background:radial-gradient(ellipse at center top,rgba(100,150,255,.14) 0%,rgba(100,150,255,.06) 38%,transparent 82%);
  pointer-events:none;
  filter:blur(6px);
  animation:footer-glow 6s ease-in-out infinite;
}
@keyframes footer-glow{0%,100%{opacity:.34;transform:translateX(-50%) scale(1)}50%{opacity:.62;transform:translateX(-50%) scale(1.06)}}
.footer a{position:relative;display:inline-block;transition:transform .3s ease,color .3s ease}
.footer a:hover{transform:translateY(-2px);color:#fff}

/* Мобильное меню */
.mobile-menu{
  position:fixed;
  top:74px;
  left:12px;
  right:12px;
  background:linear-gradient(160deg,rgba(11,19,36,.96),rgba(16,28,52,.94));
  border:1px solid rgba(170,205,255,.24);
  border-radius:14px;
  backdrop-filter:blur(14px);
  display:flex;
  flex-direction:column;
  z-index:101;
  box-shadow:0 18px 36px rgba(0,0,0,.4);
  opacity:0;
  visibility:hidden;
  pointer-events:none;
  transform:translateY(-10px) scale(.985);
  transition:opacity .24s ease,transform .28s ease,visibility 0s linear .28s;
}
.mobile-menu.is-open{
  opacity:1;
  visibility:visible;
  pointer-events:auto;
  transform:translateY(0) scale(1);
  transition:opacity .24s ease,transform .28s ease;
}
.mobile-menu a{
  padding:14px 16px;
  color:#eef5ff;
  text-decoration:none;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.mobile-menu a:last-child{border-bottom:none}
@media(max-width:768px){
  body::after{display:none}
  body.menu-open{overflow:hidden}
  .header .container{padding:10px 14px}
  .logo{min-width:0;gap:8px}
  .logo-text{font-size:.9rem;max-width:56vw;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .nav{display:none}
  .burger{display:flex}
  .header-inner{min-height:56px}
  main.container{padding-top:86px}
  .mobile-menu{top:68px;left:10px;right:10px}
  .hero-panel{padding:22px 16px}
  .card{padding-right:24px}
  .card-image{position:static;width:100%;height:auto;max-height:220px;margin-top:14px}
  .card h2,.card h3,.card p,.card .game-btns{max-width:100%}
  .lightbox-prev,.lightbox-next{font-size:28px;padding:10px 12px}
  .lightbox-prev{left:10px}
  .lightbox-next{right:10px}
  .lightbox-meta{bottom:12px;width:calc(100vw - 24px);padding:10px 12px}
  .lightbox-thumbs{gap:6px}
  .lightbox-thumb{flex-basis:50px;width:50px;height:38px}
  .lightbox-hint{display:none}
  .footer{padding-bottom:130px}
  .footer::before{width:min(560px,92vw);bottom:-84px;height:160px;opacity:.26}
}
@media(max-width:480px){
  .logo-text{max-width:48vw}
  .logo-icon{width:30px;height:30px;border-radius:9px}
  .footer{padding-bottom:108px}
  .footer::before{display:none}
}

/* Эффекты страниц */
.page-blur{position:fixed;inset:0;z-index:9999;pointer-events:none;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);animation:page-sharpen .8s ease forwards}
@keyframes page-sharpen{0%{opacity:1;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px)}100%{opacity:0;backdrop-filter:blur(0);-webkit-backdrop-filter:blur(0)}}

@media (prefers-reduced-motion: reduce){
  body::before,.hero::after,.game-btn{animation:none}
  .fade,.card,.game-btn{transition:none}
  .card{--rx:0deg;--ry:0deg;--raise:0px;transform:translateY(0)}
  .card::after{display:none}
  .gallery-item{--rx:0deg;--ry:0deg;--raise:0px;transform:translateY(0)}
  .gallery-item::after{display:none}
  .lightbox-thumb,.lightbox-thumb.is-near,.lightbox-thumb.is-active{transition:none;transform:none}
}

/* Header box для страницы игр */
.header-box{
  margin-top:16px;
  padding:24px 28px;
  border-radius:18px;
  background:rgba(0,0,0,0.45);
  backdrop-filter:blur(12px);
  box-shadow:0 16px 40px rgba(0,0,0,.4);
}

/* ============================================
   Фоновые эффекты (комбо)
   ============================================ */

/* Волны/аура */
.bg-waves
{
    position: fixed;
    inset: 0;
    pointer-events: none;
    z-index: 0;
    overflow: hidden;
}

.bg-waves::before,
.bg-waves::after
{
    content: '';
    position: absolute;
    width: 200%;
    height: 200%;
    top: -50%;
    left: -50%;
    background: radial-gradient(ellipse at center, rgba(109, 213, 255, 0.08) 0%, transparent 60%);
    animation: wave-rotate 20s linear infinite;
    opacity: 0.5;
}

.bg-waves::after
{
    background: radial-gradient(ellipse at center, rgba(139, 123, 255, 0.06) 0%, transparent 60%);
    animation: wave-rotate 25s linear infinite reverse;
    opacity: 0.4;
}

@keyframes wave-rotate
{
    0% { transform: rotate(0deg) scale(1); }
    50% { transform: rotate(180deg) scale(1.1); }
    100% { transform: rotate(360deg) scale(1); }
}

/* Туман/дым */
.bg-fog
{
    position: fixed;
    inset: 0;
    pointer-events: none;
    z-index: 0;
    overflow: hidden;
}

.bg-fog span
{
    position: absolute;
    width: 400px;
    height: 400px;
    background: radial-gradient(circle, rgba(109, 213, 255, 0.12), transparent 70%);
    border-radius: 50%;
    filter: blur(40px);
    animation: fog-drift linear infinite;
    opacity: 0;
}

.bg-fog span:nth-child(1)
{
    left: 10%;
    top: 60%;
    animation-duration: 35s;
    animation-delay: 0s;
}

.bg-fog span:nth-child(2)
{
    left: 70%;
    top: 40%;
    animation-duration: 40s;
    animation-delay: 5s;
}

.bg-fog span:nth-child(3)
{
    left: 50%;
    top: 80%;
    animation-duration: 38s;
    animation-delay: 10s;
}

.bg-fog span:nth-child(4)
{
    left: 30%;
    top: 30%;
    animation-duration: 42s;
    animation-delay: 3s;
}

.bg-fog span:nth-child(5)
{
    left: 80%;
    top: 70%;
    animation-duration: 36s;
    animation-delay: 8s;
}

@keyframes fog-drift
{
    0%
    {
        transform: translate(0, 0) scale(0.8);
        opacity: 0;
    }
    10%
    {
        opacity: 0.6;
    }
    90%
    {
        opacity: 0.6;
    }
    100%
    {
        transform: translate(100px, -150px) scale(1.2);
        opacity: 0;
    }
}

/* Северное сияние */
.bg-aurora
{
    position: fixed;
    inset: 0;
    pointer-events: none;
    z-index: 0;
    overflow: hidden;
}

.bg-aurora::before,
.bg-aurora::after
{
    content: '';
    position: absolute;
    width: 100%;
    height: 100%;
    background: linear-gradient(180deg, 
        transparent 0%, 
        rgba(109, 213, 255, 0.06) 20%, 
        rgba(139, 123, 255, 0.08) 40%, 
        rgba(79, 112, 255, 0.06) 60%, 
        transparent 80%);
    opacity: 0;
    animation: aurora-pulse 15s ease-in-out infinite;
    mix-blend-mode: screen;
}

.bg-aurora::after
{
    background: linear-gradient(180deg, 
        transparent 0%, 
        rgba(109, 213, 255, 0.04) 30%, 
        rgba(139, 123, 255, 0.06) 50%, 
        rgba(79, 112, 255, 0.04) 70%, 
        transparent 100%);
    animation: aurora-pulse 18s ease-in-out infinite reverse;
    animation-delay: 3s;
}

@keyframes aurora-pulse
{
    0%, 100%
    {
        opacity: 0.3;
        transform: translateY(0) scaleY(1);
    }
    50%
    {
        opacity: 0.6;
        transform: translateY(-20px) scaleY(1.1);
    }
}

/* ============================================
   Сверчки / жучки внизу сайта
   ============================================ */

.footer .bugs
{
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 170px;
    pointer-events: none;
    overflow: hidden;
    z-index: 0;
}

.footer .container
{
    position: relative;
    z-index: 2;
}

.footer .bugs span
{
    position: absolute;
    bottom: 0;
    width: 3px;
    height: 3px;
    background: rgba(100, 255, 100, 0.6);
    border-radius: 50%;
    opacity: 0;
    animation: bug-crawl ease-in-out infinite;
    box-shadow: 0 0 4px rgba(100, 255, 100, 0.4);
    /* Все параметры задаются через JS */
}

@keyframes bug-crawl
{
    0%
    {
        transform: translateX(0) translateY(0);
        opacity: 0;
    }
    10%
    {
        opacity: 0.72;
    }
    25%
    {
        transform: translateX(12px) translateY(-14px);
    }
    50%
    {
        transform: translateX(-10px) translateY(-30px);
    }
    75%
    {
        transform: translateX(8px) translateY(-12px);
    }
    90%
    {
        opacity: 0.72;
    }
    100%
    {
        transform: translateX(0) translateY(0);
        opacity: 0;
    }
}

/* ============================================
   Падающие звёзды
   ============================================ */

.shooting-stars
{
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    pointer-events: none;
    z-index: 0;
    overflow: hidden;
}

.shooting-stars span
{
    position: absolute;
    top: 50%;
    left: 50%;
    width: 4px;
    height: 4px;
    background: linear-gradient(45deg, #fff, transparent);
    border-radius: 50%;
    opacity: 0;
    animation: shooting-star 8s ease-in-out infinite;
    box-shadow: 0 0 10px rgba(109, 213, 255, 0.8), 0 0 20px rgba(109, 213, 255, 0.4);
}

.shooting-stars span:nth-child(1) { top: 10%; left: 80%; animation-delay: 0s; animation-duration: 6s; }
.shooting-stars span:nth-child(2) { top: 20%; left: 60%; animation-delay: 2s; animation-duration: 7s; }
.shooting-stars span:nth-child(3) { top: 15%; left: 90%; animation-delay: 4s; animation-duration: 5s; }
.shooting-stars span:nth-child(4) { top: 25%; left: 70%; animation-delay: 6s; animation-duration: 8s; }
.shooting-stars span:nth-child(5) { top: 5%; left: 85%; animation-delay: 8s; animation-duration: 6s; }

@keyframes shooting-star
{
    0%
    {
        transform: translateX(0) translateY(0) rotate(45deg);
        opacity: 0;
        width: 4px;
    }
    5%
    {
        opacity: 1;
        width: 60px;
    }
    20%
    {
        transform: translateX(-300px) translateY(300px) rotate(45deg);
        opacity: 0;
        width: 4px;
    }
    100%
    {
        opacity: 0;
    }
}

/* ============================================
   Плавающие орбы
   ============================================ */

.floating-orbs
{
    position: fixed;
    inset: 0;
    pointer-events: none;
    z-index: 0;
    overflow: hidden;
}

.floating-orbs span
{
    position: absolute;
    border-radius: 50%;
    background: radial-gradient(circle at 30% 30%, rgba(109, 213, 255, 0.4), transparent 70%);
    filter: blur(8px);
    animation: orb-float linear infinite;
    opacity: 0;
}

.floating-orbs span:nth-child(1)
{
    width: 80px;
    height: 80px;
    left: 10%;
    top: 80%;
    animation-duration: 20s;
    animation-delay: 0s;
}

.floating-orbs span:nth-child(2)
{
    width: 60px;
    height: 60px;
    left: 80%;
    top: 60%;
    animation-duration: 25s;
    animation-delay: 5s;
}

.floating-orbs span:nth-child(3)
{
    width: 100px;
    height: 100px;
    left: 60%;
    top: 90%;
    animation-duration: 22s;
    animation-delay: 10s;
}

.floating-orbs span:nth-child(4)
{
    width: 50px;
    height: 50px;
    left: 30%;
    top: 70%;
    animation-duration: 18s;
    animation-delay: 3s;
}

.floating-orbs span:nth-child(5)
{
    width: 70px;
    height: 70px;
    left: 90%;
    top: 85%;
    animation-duration: 24s;
    animation-delay: 8s;
}

@keyframes orb-float
{
    0%
    {
        transform: translate(0, 0) scale(0.8);
        opacity: 0;
    }
    10%
    {
        opacity: 0.5;
    }
    90%
    {
        opacity: 0.5;
    }
    100%
    {
        transform: translate(100px, -200px) scale(1.2);
        opacity: 0;
    }
}

/* ============================================
   Анимация текста при появлении
   ============================================ */

.text-reveal
{
    overflow: hidden;
}

.text-reveal span
{
    display: inline-block;
    opacity: 0;
    transform: translateY(100%);
    animation: reveal-text 0.8s ease forwards;
}

@keyframes reveal-text
{
    to
    {
        opacity: 1;
        transform: translateY(0);
    }
}

/* ============================================
   Ripple эффект для кнопок
   ============================================ */

.ripple
{
    position: relative;
    overflow: hidden;
}

.ripple::after
{
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    width: 0;
    height: 0;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.4);
    transform: translate(-50%, -50%);
    transition: width 0.6s, height 0.6s;
}

.ripple:active::after
{
    width: 300px;
    height: 300px;
}

/* ============================================
   Глитч эффект для заголовков
   ============================================ */

.glitch-text
{
    position: relative;
}

.glitch-text::before,
.glitch-text::after
{
    content: attr(data-text);
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

.glitch-text::before
{
    animation: glitch-1 2s infinite;
    clip-path: polygon(0 0, 100% 0, 100% 45%, 0 45%);
    transform: translate(-2px, 0);
    opacity: 0.8;
}

.glitch-text::after
{
    animation: glitch-2 3s infinite;
    clip-path: polygon(0 55%, 100% 55%, 100% 100%, 0 100%);
    transform: translate(2px, 0);
    opacity: 0.8;
}

@keyframes glitch-1
{
    0%, 100% { transform: translate(0); }
    20% { transform: translate(-2px, 2px); }
    40% { transform: translate(-2px, -2px); }
    60% { transform: translate(2px, 2px); }
    80% { transform: translate(2px, -2px); }
}

@keyframes glitch-2
{
    0%, 100% { transform: translate(0); }
    20% { transform: translate(2px, -2px); }
    40% { transform: translate(2px, 2px); }
    60% { transform: translate(-2px, -2px); }
    80% { transform: translate(-2px, 2px); }
}

/* ============================================
   Неоновая обводка для карточек
   ============================================ */

.neon-border
{
    position: relative;
}

.neon-border::before
{
    content: '';
    position: absolute;
    inset: -2px;
    background: linear-gradient(45deg, #6cd5ff, #8b7bff, #6cd5ff);
    background-size: 400%;
    border-radius: inherit;
    opacity: 0;
    z-index: -1;
    transition: opacity 0.3s;
    animation: neon-flow 3s linear infinite;
}

.neon-border:hover::before
{
    opacity: 1;
}

@keyframes neon-flow
{
    0% { background-position: 0% 50%; }
    100% { background-position: 400% 50%; }
}

/* ============================================
   Частицы при наведении
   ============================================ */

.particle-hover
{
    position: relative;
}

.particle-hover::after
{
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    width: 10px;
    height: 10px;
    background: radial-gradient(circle, rgba(109, 213, 255, 0.8), transparent);
    border-radius: 50%;
    transform: translate(-50%, -50%) scale(0);
    opacity: 0;
    transition: transform 0.4s, opacity 0.4s;
    pointer-events: none;
}

.particle-hover:hover::after
{
    transform: translate(-50%, -50%) scale(4);
    opacity: 0;
}
