:root{
  --blood:#c4121a;--blood-bright:#ff1f2e;--blood-deep:#7a0a0e;
  --ink:#0a0506;--ash:#1f0d10;--bone:#e8d8d8;--bone-dim:#9a8484;
  --glass:rgba(30,8,11,.55);--glass-line:rgba(196,18,26,.28);
}

/* ===== CUSTOM SCROLLBAR — кровавая капля ===== */
*{scrollbar-width:thin;scrollbar-color:var(--blood) var(--ink)}
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-track{background:rgba(10,5,6,.7);border-radius:6px}
::-webkit-scrollbar-thumb{
  background:linear-gradient(180deg,var(--blood-bright),var(--blood-deep));
  border-radius:6px;border:2px solid var(--ink);
  box-shadow:0 0 8px rgba(255,31,46,.5),inset 0 1px 0 rgba(255,255,255,.1)}
::-webkit-scrollbar-thumb:hover{
  background:linear-gradient(180deg,#ff5560,var(--blood-bright));
  box-shadow:0 0 14px rgba(255,31,46,.8)}
::-webkit-scrollbar-corner{background:var(--ink)}

/* ===== PRELOADER ===== */
#preloader{position:fixed;inset:0;z-index:10000;
  background:radial-gradient(circle at 50% 50%,rgba(20,7,9,.95),var(--ink) 80%);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.2rem;
  transition:opacity .7s ease,filter .7s ease}
#preloader.gone{opacity:0;filter:blur(20px);pointer-events:none}
.pre-ring{position:absolute;width:200px;height:200px;border-radius:50%;
  border:1px solid var(--glass-line);animation:spin 3s linear infinite;
  box-shadow:0 0 40px rgba(196,18,26,.25) inset}
.pre-gengar{width:96px;height:96px;object-fit:contain;position:relative;z-index:2;
  animation:prePulse 1.6s ease-in-out infinite;
  filter:drop-shadow(0 0 22px rgba(196,18,26,.6))}
@keyframes prePulse{
  0%,100%{transform:scale(1);filter:drop-shadow(0 0 12px rgba(196,18,26,.4))}
  50%{transform:scale(1.1);filter:drop-shadow(0 0 32px rgba(255,31,46,.9))}}
.pre-text{font-family:'Cinzel',serif;font-weight:900;
  font-size:.85rem;letter-spacing:.65em;color:var(--bone-dim);
  text-transform:uppercase;position:relative;z-index:2;
  animation:preBreathe 2s ease-in-out infinite}
@keyframes preBreathe{0%,100%{opacity:.5}50%{opacity:1}}

/* ===== POINTER SPARKS — искры вылетают сзади курсора ===== */
.cursor-spark{position:fixed;border-radius:50%;pointer-events:none;z-index:9997;
  transform:translate(-50%,-50%);
  animation:sparkFly .6s ease-out forwards;will-change:transform,opacity}
.spark-red{background:radial-gradient(circle,rgba(255,31,46,.95) 0%,rgba(196,18,26,.55) 50%,rgba(122,10,14,0) 100%);
  box-shadow:0 0 6px rgba(255,31,46,.6)}
.spark-dark{background:radial-gradient(circle,rgba(40,8,12,.95) 0%,rgba(20,5,7,.5) 50%,rgba(0,0,0,0) 100%)}
@keyframes sparkFly{
  0%{opacity:1;transform:translate(-50%,-50%) scale(1)}
  100%{opacity:0;transform:translate(calc(-50% + var(--sx,0)),calc(-50% + var(--sy,0))) scale(.2)}}

/* ===== SETTINGS POPUP — разворачивается снизу langbar ===== */
#settingsPopup{position:fixed;top:0;left:0;z-index:59;
  background:var(--glass);backdrop-filter:blur(10px);
  /* борде нет когда свёрнут — границы вообще нет в layout */
  border-width:0;border-style:solid;border-color:var(--glass-line);
  border-radius:0 0 12px 12px;
  box-shadow:0 0 0 rgba(0,0,0,0);
  max-height:0;padding:0 1.1rem;
  overflow:hidden;pointer-events:none;
  transition:max-height .35s cubic-bezier(.2,.9,.3,1.2),
             padding .35s ease,
             border-width .25s ease,
             box-shadow .35s ease}
#settingsPopup.show{max-height:400px;padding:.9rem 1.1rem;
  border-width:0 1px 1px 1px;  /* верх 0 — стыкуется с langbar, остальные стороны 1px */
  box-shadow:0 12px 30px rgba(0,0,0,.5);
  pointer-events:auto}

/* когда popup открыт — у langbar плоская нижняя граница (стыкуется без шва) */
.langbar.popup-open{border-bottom-left-radius:0;border-bottom-right-radius:0;border-bottom-color:transparent}
.settings-title{font-family:'Cinzel',serif;font-size:.78rem;color:var(--bone);
  letter-spacing:.2em;text-transform:lowercase;margin-bottom:.6rem;
  padding-bottom:.5rem;border-bottom:1px solid var(--glass-line)}
.settings-row{display:flex;align-items:center;justify-content:space-between;
  gap:.8rem;padding:.45rem 0;font-family:'JetBrains Mono',monospace;font-size:.72rem;
  color:var(--bone-dim);letter-spacing:.05em}
.settings-row label{display:flex;align-items:center;gap:.55rem;cursor:inherit;flex:1}
.settings-row input[type="checkbox"]{appearance:none;-webkit-appearance:none;
  width:32px;height:18px;border-radius:18px;
  background:var(--ash);border:1px solid var(--glass-line);
  position:relative;transition:.25s;flex-shrink:0}
.settings-row input[type="checkbox"]::before{content:"";position:absolute;
  width:12px;height:12px;border-radius:50%;
  background:var(--bone-dim);left:2px;top:2px;transition:.25s}
.settings-row input[type="checkbox"]:checked{
  background:linear-gradient(135deg,var(--blood),var(--blood-deep));
  border-color:var(--blood-bright)}
.settings-row input[type="checkbox"]:checked::before{
  transform:translateX(14px);background:#fff}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;scrollbar-gutter:stable}
/* gengar поверх всего — на каждом элементе и псевдоэлементе */
*,*::before,*::after{cursor:url('../img/cursor-body.png') 4 2,auto!important}
body{background:var(--ink);color:var(--bone);font-family:'Cormorant Garamond',serif;overflow-x:hidden}
::selection{background:var(--blood);color:#fff}
a{color:inherit}

.atmos{position:fixed;inset:0;z-index:-2;overflow:hidden}
.atmos::before{content:"";position:absolute;inset:-20%;
  background:radial-gradient(60% 50% at 25% 30%,rgba(196,18,26,.45),transparent 60%),
    radial-gradient(55% 45% at 80% 70%,rgba(122,10,14,.55),transparent 60%),
    radial-gradient(40% 40% at 50% 100%,rgba(255,31,46,.18),transparent 60%),
    linear-gradient(135deg,#160709,#050203 70%);
  filter:blur(8px) saturate(1.2);animation:drift 22s ease-in-out infinite alternate}
@keyframes drift{0%{transform:translate(0,0) scale(1.05)}50%{transform:translate(-3%,2%) scale(1.12)}100%{transform:translate(2%,-2%) scale(1.05)}}
.grain{position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:.05;mix-blend-mode:overlay}
.grain svg{width:100%;height:100%}
.vignette{position:fixed;inset:0;z-index:50;pointer-events:none;box-shadow:inset 0 0 200px 60px rgba(0,0,0,.85)}
.embers{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.ember{position:absolute;bottom:-10px;width:3px;height:3px;border-radius:50%;
  background:var(--blood-bright);box-shadow:0 0 6px 2px rgba(255,31,46,.6);animation:rise linear infinite;opacity:0}
@keyframes rise{0%{transform:translateY(0) translateX(0);opacity:0}10%{opacity:.9}90%{opacity:.5}100%{transform:translateY(-100vh) translateX(40px);opacity:0}}

/* ENTER */
#enter{position:fixed;inset:0;z-index:100;display:flex;flex-direction:column;align-items:center;justify-content:center;
  background:radial-gradient(circle at 50% 50%,rgba(20,7,9,.6),var(--ink) 75%);
  transition:opacity 1.1s ease,filter 1.1s ease,transform 1.1s ease}
#enter.leaving{opacity:0;filter:blur(28px);transform:scale(1.25);pointer-events:none}
.enter-name{font-family:'Cinzel',serif;font-weight:900;font-size:clamp(3rem,13vw,9rem);letter-spacing:.08em;
  color:var(--bone);position:relative;text-shadow:0 0 40px rgba(196,18,26,.55);animation:breathe 3.4s ease-in-out infinite}
.enter-name::after{content:"ovelray";position:absolute;left:0;top:0;color:var(--blood-bright);mix-blend-mode:screen;
  filter:blur(14px);opacity:.7;animation:breathe 3.4s ease-in-out infinite}
@keyframes breathe{0%,100%{transform:scale(1);text-shadow:0 0 30px rgba(196,18,26,.4)}50%{transform:scale(1.03);text-shadow:0 0 60px rgba(255,31,46,.75)}}
.enter-hint{margin-top:2.4rem;font-family:'JetBrains Mono',monospace;font-size:.78rem;letter-spacing:.45em;
  text-transform:uppercase;color:var(--bone-dim);min-height:1.2em;position:relative}
.enter-hint .hint-text{display:inline-block;transition:opacity .5s ease,transform .5s ease;
  background:linear-gradient(90deg,var(--bone-dim),#ff8088,var(--bone-dim));background-size:200% auto;
  -webkit-background-clip:text;background-clip:text;color:transparent;animation:hintShimmer 4s linear infinite}
.enter-hint .hint-text.fading{opacity:0;transform:translateY(-6px)}
@keyframes hintShimmer{to{background-position:200% center}}
.enter-ring{position:absolute;width:min(70vw,520px);height:min(70vw,520px);border:1px solid var(--glass-line);border-radius:50%;animation:spin 30s linear infinite}
.enter-ring.r2{width:min(52vw,380px);height:min(52vw,380px);border-style:dashed;animation:spin 22s linear infinite reverse;border-color:rgba(255,31,46,.18)}
@keyframes spin{to{transform:rotate(360deg)}}

/* SITE */
#site{opacity:0;transform:translateY(30px);transition:opacity 1.2s ease .4s,transform 1.2s ease .4s;
  min-height:100vh;padding:clamp(1.2rem,4vw,3rem);padding-top:5rem;max-width:1100px;margin:0 auto;pointer-events:none}
@media (min-aspect-ratio:16/10) and (min-width:1200px){
  #site{max-width:1500px;font-size:1.18rem}
}
@media (min-aspect-ratio:2/1) and (min-width:1700px){
  #site{max-width:2000px;font-size:1.35rem}
}
#site.revealed{opacity:1;transform:translateY(0);pointer-events:auto}
.reveal{opacity:0;transform:translateY(24px);transition:opacity .8s ease,transform .8s ease}
#site.revealed .reveal{opacity:1;transform:translateY(0)}
#site.revealed .reveal:nth-child(1){transition-delay:.5s}
#site.revealed .reveal:nth-child(2){transition-delay:.62s}
#site.revealed .reveal:nth-child(3){transition-delay:.74s}
#site.revealed .reveal:nth-child(4){transition-delay:.86s}
#site.revealed .reveal:nth-child(5){transition-delay:.98s}
#site.revealed .reveal:nth-child(6){transition-delay:1.1s}
#site.revealed .reveal:nth-child(7){transition-delay:1.22s}
#site.revealed .reveal:nth-child(8){transition-delay:1.34s}

/* lang switch */
.langbar{position:fixed;top:1rem;right:1rem;z-index:60;display:flex;gap:.3rem;align-items:center;
  background:var(--glass);backdrop-filter:blur(10px);padding:.35rem;border-radius:12px;
  border:1px solid var(--glass-line);opacity:0;transform:translateY(-10px);transition:.5s}
.langbar.show{opacity:1;transform:translateY(0)}
.langbar button{font-family:'JetBrains Mono',monospace;font-size:.66rem;letter-spacing:.05em;
  background:transparent;border:none;color:var(--bone-dim);padding:.35rem .55rem;border-radius:8px;transition:.25s;text-transform:uppercase}
.langbar button:hover{color:var(--bone)}

/* ===== current-language button + chevron ===== */
.lang-wrap{position:relative;display:inline-flex}
.lang-current{display:inline-flex;align-items:center;gap:.3rem;padding:.35rem .55rem!important;
  border:1px solid transparent!important;border-radius:8px;color:#fff!important;
  background:linear-gradient(180deg,var(--blood),var(--blood-deep))!important;
  box-shadow:0 2px 10px rgba(196,18,26,.35),inset 0 1px 0 rgba(255,255,255,.08);
  transition:transform .18s ease,box-shadow .25s ease,background .25s ease}
.lang-current:hover{background:linear-gradient(180deg,#ff3340,var(--blood))!important;
  box-shadow:0 4px 18px rgba(255,31,46,.5),inset 0 1px 0 rgba(255,255,255,.1);
  transform:translateY(-1px)}
.lang-current .lang-chev{font-size:.7rem;line-height:1;transition:transform .3s cubic-bezier(.34,1.4,.64,1);opacity:.95}
.lang-current.open .lang-chev{transform:rotate(180deg)}

/* ===== dropdown с языками — позиционируется относительно lang-wrap ===== */
.lang-drop-menu{position:absolute;top:calc(100% + 10px);right:0;z-index:65;
  background:
    radial-gradient(120% 70% at 90% 0%,rgba(196,18,26,.22),transparent 60%),
    linear-gradient(180deg,rgba(22,8,10,.97),rgba(10,5,6,.97));
  backdrop-filter:blur(16px);
  border:1px solid rgba(196,18,26,.55);border-radius:14px;padding:.55rem;
  box-shadow:
    0 24px 70px rgba(0,0,0,.7),
    0 0 50px rgba(196,18,26,.3),
    inset 0 1px 0 rgba(255,31,46,.15);
  display:grid;grid-template-columns:repeat(4,minmax(64px,1fr));gap:.3rem;
  width:max-content;max-width:min(360px,calc(100vw - 2rem));
  opacity:0;
  transform:translateY(-14px) scale(.85);
  transform-origin:top right;
  transition:opacity .35s ease, transform .55s cubic-bezier(.34,1.6,.36,1);
  pointer-events:none;
  isolation:isolate;
}
/* пульсирующий ripple от верхнего правого угла при открытии */
.lang-drop-menu::after{
  content:"";position:absolute;top:-2px;right:8px;width:18px;height:18px;
  border-radius:50%;background:radial-gradient(circle,rgba(255,31,46,.9),transparent 70%);
  opacity:0;transform:scale(0);pointer-events:none;
  transition:none;
}
.lang-drop-menu.open::after{
  animation:lang-ripple .9s cubic-bezier(.18,.85,.28,1) forwards;
}
@keyframes lang-ripple{
  0%   { opacity:.9; transform:scale(.4) }
  50%  { opacity:.35 }
  100% { opacity:0;  transform:scale(14) }
}
/* connector-«хвостик» от dropdown к кнопке */
.lang-drop-menu::before{
  content:"";position:absolute;top:-6px;right:14px;
  width:12px;height:12px;
  background:linear-gradient(135deg,rgba(196,18,26,.55),transparent 55%),
             linear-gradient(180deg,rgba(22,8,10,.97),rgba(10,5,6,.97));
  border-top:1px solid rgba(196,18,26,.55);
  border-left:1px solid rgba(196,18,26,.55);
  transform:rotate(45deg);
  border-radius:2px 0 0 0;
}
.lang-drop-menu[hidden]{display:none!important}
.lang-drop-menu.open{opacity:1;transform:translateY(0) scale(1);pointer-events:auto}

.lang-opt{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.15rem;
  padding:.6rem .45rem;border-radius:10px;cursor:inherit;
  border:1px solid transparent;background:rgba(255,255,255,.015);
  font-family:'JetBrains Mono',monospace;color:var(--bone-dim);
  transition:transform .2s ease,background .2s ease,color .2s ease,border-color .2s ease,box-shadow .2s ease;
  text-align:center;overflow:hidden;
  min-width:64px;
  opacity:0;transform:translateY(-10px) scale(.7);
}
/* каскадное появление пунктов после открытия (используя --i, проставленный из JS) */
.lang-drop-menu.open .lang-opt{
  animation:lang-pop .55s cubic-bezier(.34,1.55,.36,1) forwards;
  animation-delay:calc(var(--i,0) * 35ms + 80ms);
}
@keyframes lang-pop{
  0%   { opacity:0; transform:translateY(-10px) scale(.7); }
  60%  { opacity:1; transform:translateY(2px) scale(1.08); }
  100% { opacity:1; transform:translateY(0)  scale(1); }
}
.lang-opt::before{
  content:"";position:absolute;inset:0;border-radius:inherit;
  background:radial-gradient(circle at 50% 0%,rgba(255,31,46,.25),transparent 65%);
  opacity:0;transition:opacity .25s ease;pointer-events:none
}
.lang-opt:hover{color:var(--bone);border-color:rgba(196,18,26,.55);
  transform:translateY(-2px);box-shadow:0 4px 14px rgba(0,0,0,.4)}
.lang-opt:hover::before{opacity:1}
.lang-opt.active{background:linear-gradient(180deg,var(--blood),var(--blood-deep));
  color:#fff;border-color:var(--blood-bright);
  box-shadow:0 0 18px rgba(255,31,46,.45),inset 0 1px 0 rgba(255,255,255,.08)}
.lang-opt.active::before{opacity:0}
.lang-opt .code{font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;font-weight:700;line-height:1;position:relative;z-index:1}
.lang-opt .name{font-size:.58rem;letter-spacing:.04em;color:var(--bone-dim);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;
  font-family:'Cormorant Garamond',serif;font-style:italic;position:relative;z-index:1}
.lang-opt.active .name{color:rgba(255,255,255,.75)}

/* Адаптив — на узких экранах меньше колонок */
@media (max-width:600px){
  .lang-drop-menu{grid-template-columns:repeat(3,minmax(60px,1fr));max-width:calc(100vw - 1rem);right:auto;left:auto}
  .lang-wrap{position:static}
  .lang-drop-menu{right:1rem}
  .lang-opt{padding:.5rem .35rem;min-width:60px}
}
@media (max-width:380px){
  .lang-drop-menu{grid-template-columns:repeat(2,1fr)}
}

/* ===== РАДАРНАЯ ВОЛНА смены языка =====
   Тонкое кольцо расходится из точки клика. Центр уже прозрачный когда
   гребень добегает до периферии. Покрытие до 32:9 (5120px). */
.lang-wipe{position:fixed;top:0;left:0;width:2px;height:2px;border-radius:50%;
  z-index:55;  /* НИЖЕ langbar (z-index 60) — toolbar чистый */
  pointer-events:none;opacity:0;
  transform:translate(-50%,-50%) scale(0);
  /* кольцо: всё прозрачно кроме тонкой полоски на 50% радиуса */
  background:
    radial-gradient(circle at center,
      transparent 0%,
      transparent 46%,
      rgba(255,255,255,.9)  48%,
      rgba(255,80,90,1)     49.5%,
      rgba(255,31,46,1)     50%,
      rgba(196,18,26,.85)   50.5%,
      rgba(122,10,14,.5)    52%,
      transparent 56%);
  filter:blur(.6px) drop-shadow(0 0 8px rgba(255,31,46,.5));
  transition:
    transform 1.8s cubic-bezier(.18,.85,.28,1),
    opacity   1.8s ease-out;
}
.lang-wipe.expand{
  opacity:1;
  transform:translate(-50%,-50%) scale(3000);
}
/* fade накладывается ПОВЕРХ .expand — scale остаётся на максимуме,
   плавно гаснет только opacity (1.4s ease-out → нет схлопывания внутрь) */
.lang-wipe.expand.fade{
  opacity:0;
  transition: opacity 1.4s cubic-bezier(.3,.05,.4,1);
}

/* langbar остаётся ВЫШЕ волны (z-index 60 > 55) — волна «обтекает» его */
.langbar{z-index:60;transition:background .25s ease,border-color .25s ease}
/* во время смены языка делаем langbar плотнее → волна не просвечивает через glass */
html.lang-changing .langbar,
html.lang-changing .lang-drop-menu{
  background:rgba(10,5,6,.92)!important;
  border-color:rgba(196,18,26,.5)
}

/* ===== плавное появление и затухание blur'а после волны =====
   Транзишн на ВСЁМ #site (не только на :lang-changing) — поэтому когда класс снимется,
   фильтр плавно сходит на нет за .9s. */
#site{ transition: filter .9s cubic-bezier(.25,.6,.3,1); }
#site.lang-changing{ filter:blur(.5px) brightness(.85); }

/* ===== ЗЕМЛЕТРЯСЕНИЕ —
   X (основной) + Y (заметный) + rotate вокруг оси.
   Анимация бежит ОДИН РАЗ (не infinite) и сама затухает к концу → плавное завершение. */
@keyframes quake-strong{
  0%   { transform: translate3d(0,0,0)        rotate(0deg); }
  /* мощный начальный удар */
  4%   { transform: translate3d(-6px,3.5px,0) rotate(-3deg); }
  8%   { transform: translate3d(6px,-3.5px,0) rotate(3deg); }
  12%  { transform: translate3d(-6px,3px,0)   rotate(-2.6deg); }
  16%  { transform: translate3d(5px,-3px,0)   rotate(2.4deg); }
  /* быстрое колебание */
  22%  { transform: translate3d(-4.5px,2.5px,0) rotate(-2deg); }
  28%  { transform: translate3d(4.5px,-2.5px,0) rotate(2deg); }
  35%  { transform: translate3d(-4px,2px,0)   rotate(-1.6deg); }
  42%  { transform: translate3d(4px,-2px,0)   rotate(1.6deg); }
  /* угасание */
  52%  { transform: translate3d(-3px,1.5px,0) rotate(-1.2deg); }
  62%  { transform: translate3d(2.5px,-1.2px,0) rotate(.9deg); }
  72%  { transform: translate3d(-2px,1px,0)   rotate(-.7deg); }
  82%  { transform: translate3d(1.5px,-.7px,0) rotate(.5deg); }
  92%  { transform: translate3d(-.7px,.3px,0) rotate(-.25deg); }
  100% { transform: translate3d(0,0,0)        rotate(0deg); }
}
/* для крупных блоков — амплитуды меньше (иначе текст плывёт), но всё равно явно ощутимо */
@keyframes quake-mid{
  0%   { transform: translate3d(0,0,0)         rotate(0deg); }
  6%   { transform: translate3d(-3px,1.5px,0)  rotate(-1.2deg); }
  12%  { transform: translate3d(3px,-1.5px,0)  rotate(1.2deg); }
  20%  { transform: translate3d(-3px,1.3px,0)  rotate(-1deg); }
  28%  { transform: translate3d(2.5px,-1.3px,0) rotate(1deg); }
  38%  { transform: translate3d(-2.2px,1px,0)  rotate(-.7deg); }
  50%  { transform: translate3d(2px,-1px,0)    rotate(.7deg); }
  62%  { transform: translate3d(-1.5px,.7px,0) rotate(-.5deg); }
  74%  { transform: translate3d(1.2px,-.6px,0) rotate(.4deg); }
  86%  { transform: translate3d(-.6px,.3px,0)  rotate(-.2deg); }
  100% { transform: translate3d(0,0,0)         rotate(0deg); }
}

/* transform-origin: center — чтобы поворот был вокруг центра карточки */
.lang-changing .lnk,
.lang-changing .scratch-card,
.lang-changing .friend-card,
.lang-changing .ach-btn,
.lang-changing .music-nav,
.lang-changing .ly-spot,
.lang-changing .seg,
.lang-changing .profile,
.lang-changing .accordion,
.lang-changing .lanyard,
.lang-changing .music-panel,
.lang-changing .scratch-grid,
.lang-changing .sec-title,
.lang-changing .friends-egg,
.lang-changing .pre-gengar,
.lang-changing .links-marquee,
.lang-changing .footer{
  transform-origin: center center;
}

/* МЕЛКИЕ ИКОНКИ — сильное землетрясение, 1.3с с встроенным затуханием */
.lang-changing .lnk,
.lang-changing .scratch-card,
.lang-changing .friend-card,
.lang-changing .ach-btn,
.lang-changing .music-nav,
.lang-changing .ly-spot,
.lang-changing .seg{
  animation: quake-strong 1.3s cubic-bezier(.36,.07,.19,.97) both;
}
/* КРУПНЫЕ блоки — средняя амплитуда, чуть дольше */
.lang-changing .profile,
.lang-changing .accordion,
.lang-changing .lanyard,
.lang-changing .music-panel,
.lang-changing .scratch-grid,
.lang-changing .sec-title,
.lang-changing .friends-egg,
.lang-changing .pre-gengar,
.lang-changing .links-marquee,
.lang-changing .footer{
  animation: quake-mid 1.4s cubic-bezier(.36,.07,.19,.97) both;
}
/* кнопка достижений в langbar */
.langbar .ach-btn{display:flex;align-items:center;justify-content:center;
  width:28px;height:28px;padding:0;color:var(--blood-bright);position:relative}
.langbar .ach-btn svg{width:16px;height:16px;fill:currentColor;transition:.25s}
.langbar .ach-btn svg[fill="none"]{fill:none}
.langbar .ach-btn:hover{background:rgba(196,18,26,.2);color:#fff}
.langbar .ach-btn:hover svg{transform:scale(1.15);filter:drop-shadow(0 0 6px rgba(255,31,46,.7))}

/* мигающая стрелочка под шестерёнкой настроек — пропадает после первого клика */
.settings-arrow{position:absolute;top:calc(100% + 4px);left:50%;
  transform:translateX(-50%);color:var(--blood-bright);font-size:1.2rem;line-height:1;
  pointer-events:none;text-shadow:0 0 8px rgba(255,31,46,.7);
  animation:settingsArrowBlink 1.4s ease-in-out infinite,
            settingsArrowBounce 1.1s cubic-bezier(.5,0,.5,1) infinite}
.settings-arrow.gone{opacity:0;transform:translateX(-50%) translateY(-10px);transition:.4s}
@keyframes settingsArrowBlink{0%,100%{opacity:.35}50%{opacity:1}}
@keyframes settingsArrowBounce{
  0%,100%{transform:translateX(-50%) translateY(0)}
  50%{transform:translateX(-50%) translateY(5px)}
}
.langbar .ach-btn.has-new::after{content:"";position:absolute;top:3px;right:3px;
  width:6px;height:6px;border-radius:50%;background:var(--blood-bright);
  box-shadow:0 0 6px var(--blood-bright);animation:auraPulse 1.5s ease-in-out infinite}
.langbar-sep{width:1px;height:18px;background:var(--glass-line);margin:0 .15rem;align-self:center}

.profile{display:flex;gap:1.6rem;align-items:center;flex-wrap:wrap;padding:1.6rem;border-radius:20px;
  background:var(--glass);backdrop-filter:blur(14px);border:1px solid var(--glass-line);
  box-shadow:0 20px 60px rgba(0,0,0,.5),inset 0 1px 0 rgba(255,255,255,.04);position:relative;overflow:hidden}
.profile::before{content:"";position:absolute;inset:0;background:linear-gradient(120deg,transparent,rgba(196,18,26,.08),transparent);animation:sheen 6s ease-in-out infinite}
@keyframes sheen{0%,100%{transform:translateX(-60%)}50%{transform:translateX(60%)}}
.avatar{width:104px;height:104px;border-radius:50%;flex-shrink:0;
  background:radial-gradient(circle at 35% 30%,#3a1115,#120407);position:relative;
  display:flex;align-items:center;justify-content:center;
  font-family:'Cinzel',serif;font-size:2.4rem;color:var(--bone);overflow:visible}
.avatar .av-img{position:absolute;inset:5px;border-radius:50%;overflow:hidden;
  background:radial-gradient(circle at 35% 30%,#3a1115,#120407);
  display:flex;align-items:center;justify-content:center;z-index:2;
  box-shadow:0 0 30px rgba(196,18,26,.5) inset}
.avatar .av-img img{width:100%;height:100%;object-fit:cover}
.avatar::before{content:"";position:absolute;inset:-4px;border-radius:50%;z-index:1;
  background:conic-gradient(from 0deg,var(--blood-bright),transparent 25%,var(--blood-deep) 50%,transparent 75%,var(--blood-bright));
  animation:spin 4s linear infinite;filter:blur(1px)}
.avatar::after{content:"";position:absolute;inset:-10px;border-radius:50%;z-index:0;
  box-shadow:0 0 24px 4px rgba(255,31,46,.45);animation:auraPulse 3s ease-in-out infinite}
@keyframes auraPulse{0%,100%{box-shadow:0 0 18px 2px rgba(255,31,46,.35)}50%{box-shadow:0 0 36px 8px rgba(255,31,46,.65)}}
.pinfo h1{font-family:'Cinzel',serif;font-weight:700;font-size:2.4rem;letter-spacing:.04em;line-height:1;
  position:relative;display:inline-block;
  background:linear-gradient(90deg,#fff 0%,#ff5560 25%,#fff 50%,#ff5560 75%,#fff 100%);
  background-size:200% auto;-webkit-background-clip:text;background-clip:text;color:transparent;
  animation:nameShimmer 5s linear infinite,namePulse 3.4s ease-in-out infinite}
@keyframes nameShimmer{to{background-position:200% center}}
@keyframes namePulse{0%,100%{filter:drop-shadow(0 0 8px rgba(196,18,26,.4))}50%{filter:drop-shadow(0 0 20px rgba(255,31,46,.7))}}
.tags{display:flex;gap:.5rem;margin:.6rem 0;flex-wrap:wrap}
.tag{font-family:'JetBrains Mono',monospace;font-size:.66rem;padding:.25rem .6rem;border-radius:6px;
  letter-spacing:.1em;text-transform:uppercase;background:rgba(196,18,26,.14);border:1px solid var(--glass-line);color:#e0a0a4}
.bio-line{font-style:italic;font-size:1.15rem;color:var(--bone-dim);display:inline-flex;align-items:center;gap:.55rem;flex-wrap:wrap}
.bio-line .gengar-deco{width:32px;height:32px;object-fit:contain;flex-shrink:0;
  filter:drop-shadow(0 0 8px rgba(255,31,46,.55))}

/* LANYARD live status */
.lanyard{margin-top:1rem;display:flex;align-items:center;gap:.9rem;padding:.8rem 1rem;width:100%;
  border-radius:14px;background:rgba(0,0,0,.3);border:1px solid var(--glass-line)}
.lanyard .art{width:54px;height:54px;border-radius:10px;object-fit:cover;background:#1a0809;flex-shrink:0;border:1px solid var(--glass-line)}
.lanyard .meta{flex:1;min-width:0}
.lanyard .st{font-family:'JetBrains Mono',monospace;font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:var(--blood-bright);display:flex;align-items:center;gap:.4rem}
.lanyard .st .dot{width:7px;height:7px;border-radius:50%;background:#43b581;box-shadow:0 0 8px #43b581}
.lanyard .ttl{font-weight:600;font-size:1.05rem;color:var(--bone);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.lanyard .sub{font-size:.92rem;color:var(--bone-dim);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ly-spot{position:relative;flex-shrink:0;width:38px;height:38px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  background:radial-gradient(circle at 30% 30%,rgba(255,31,46,.22),rgba(122,10,14,.18) 70%,transparent);
  border:1px solid var(--blood);color:var(--blood-bright);
  text-decoration:none;transition:.25s ease;
  box-shadow:0 0 12px rgba(255,31,46,.18),inset 0 0 10px rgba(255,31,46,.08)}
.ly-spot:hover{background:linear-gradient(135deg,var(--blood),var(--blood-deep));
  color:#fff;border-color:var(--blood-bright);
  box-shadow:0 0 22px rgba(255,31,46,.55);transform:scale(1.06)}
.ly-spot:active{transform:scale(.94)}

/* всплывашка «слушай со мной» при наведении */
.ly-spot-tip{
  position:absolute;right:calc(100% + 10px);top:50%;
  transform:translateY(-50%) translateX(8px);
  white-space:nowrap;
  font-family:'JetBrains Mono',monospace;
  font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--bone);
  background:rgba(20,7,9,.92);backdrop-filter:blur(8px);
  border:1px solid var(--glass-line);
  padding:.45rem .65rem;border-radius:8px;
  box-shadow:0 6px 22px rgba(0,0,0,.5),0 0 14px rgba(196,18,26,.15);
  opacity:0;pointer-events:none;
  transition:opacity .25s ease,transform .25s cubic-bezier(.34,1.4,.64,1)
}
.ly-spot-arrow{
  position:absolute;right:calc(100% - 2px);top:50%;
  transform:translateY(-50%) translateX(8px);
  color:var(--blood-bright);
  opacity:0;pointer-events:none;
  filter:drop-shadow(0 0 6px rgba(255,31,46,.5));
  transition:opacity .25s ease,transform .25s cubic-bezier(.34,1.4,.64,1)
}
.ly-spot:hover .ly-spot-tip,
.ly-spot:focus-visible .ly-spot-tip{
  opacity:1;transform:translateY(-50%) translateX(0)
}
.ly-spot:hover .ly-spot-arrow,
.ly-spot:focus-visible .ly-spot-arrow{
  opacity:1;transform:translateY(-50%) translateX(-4px)
}
/* стрелка-«хвостик» к тултипу */
.ly-spot-tip::after{
  content:"";position:absolute;left:100%;top:50%;
  transform:translateY(-50%);
  border:5px solid transparent;
  border-left-color:rgba(20,7,9,.92)
}
@media (max-width:480px){
  .ly-spot-tip{display:none}
  .ly-spot-arrow{display:none}
}

.sec-title{font-family:'Cinzel',serif;font-size:1rem;letter-spacing:.3em;text-transform:uppercase;color:#d4565d;
  margin:2.6rem .4rem 1rem;display:flex;align-items:center;gap:.8rem}
.sec-title::after{content:"";flex:1;height:1px;background:linear-gradient(90deg,var(--glass-line),transparent)}

/* social links — marquee (бегущая строка) */
.links-marquee{position:relative;overflow-x:hidden;overflow-y:visible;padding:2rem 0 2.2rem;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);
          mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent)}
.links-marquee-track{display:flex;gap:.85rem;width:max-content;will-change:transform}
/* marquee движется JS-ом (extras.js) — плавное замедление при hover вместо стопа */
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.links-marquee .lnk{flex:0 0 auto;min-width:175px}

.lnk{display:flex;align-items:center;gap:.7rem;padding:.95rem 1.1rem;border-radius:14px;text-decoration:none;color:var(--bone);
  background:var(--glass);border:1px solid var(--glass-line);backdrop-filter:blur(10px);position:relative;overflow:hidden;
  transition:transform .35s cubic-bezier(.2,.8,.2,1),border-color .35s,box-shadow .35s;
  font-family:'JetBrains Mono',monospace;font-size:.82rem}
.lnk::before{content:"";position:absolute;inset:0;background:radial-gradient(120px 60px at var(--mx,50%) var(--my,50%),rgba(255,31,46,.22),transparent 70%);opacity:0;transition:opacity .35s}
.lnk:hover{transform:translateY(-4px);border-color:var(--blood);box-shadow:0 8px 22px rgba(122,10,14,.45),0 0 18px rgba(255,31,46,.25),0 0 0 1px rgba(255,31,46,.3)}
.lnk:hover::before{opacity:1}
.lnk .ico{width:32px;height:32px;flex-shrink:0;display:flex;align-items:center;justify-content:center;border-radius:8px;
  background:rgba(0,0,0,.35);color:var(--blood-bright);border:1px solid rgba(255,31,46,.2);transition:.35s}
.lnk .ico svg{width:18px;height:18px;fill:currentColor}
.lnk .ico img{width:18px;height:18px;object-fit:contain;filter:brightness(0) saturate(100%) invert(28%) sepia(86%) saturate(3500%) hue-rotate(345deg) brightness(105%) contrast(95%);transition:filter .35s}
/* для уже окрашенных png — без filter */
.lnk .ico img.keep-color{filter:none}
/* hover — белый силуэт как у SVG */
.lnk:hover .ico img,
.lnk:hover .ico img.keep-color{filter:brightness(0) invert(1)}
.lnk:hover .ico{color:#fff;background:var(--blood-deep);border-color:var(--blood-bright);box-shadow:0 0 12px rgba(255,31,46,.5)}
.lnk b{display:block;font-weight:500;color:var(--bone)}
.lnk small{display:block;color:var(--bone-dim);font-size:.66rem;margin-top:1px}

/* collapsible about */
.accordion{background:var(--glass);border:1px solid var(--glass-line);border-radius:18px;
  backdrop-filter:blur(14px);overflow:hidden;box-shadow:0 16px 40px rgba(0,0,0,.45);margin-bottom:1rem}
.acc-head{display:flex;align-items:center;justify-content:space-between;padding:1.3rem 1.5rem;user-select:none;transition:background .3s}
.acc-head:hover{background:rgba(196,18,26,.08)}
.acc-head h3{font-family:'Cinzel',serif;font-size:1.2rem;letter-spacing:.06em;color:#e0a0a4;display:flex;align-items:center;gap:.6rem}
.arca-logo{width:1.2rem;height:1.2rem;object-fit:contain;vertical-align:middle;opacity:1;position:relative;top:2px}
.acc-arrow{width:24px;height:24px;display:flex;align-items:center;justify-content:center;color:var(--blood-bright);transition:transform .45s cubic-bezier(.2,.8,.2,1);font-size:1.2rem}
.accordion.open .acc-arrow{transform:rotate(180deg)}
.acc-body{display:grid;grid-template-rows:0fr;transition:grid-template-rows .55s cubic-bezier(.2,.8,.2,1)}
.accordion.open .acc-body{grid-template-rows:1fr}
.acc-inner{overflow:hidden}
.acc-content{padding:0 1.5rem 1.5rem;font-size:1.1rem;line-height:1.6;color:var(--bone-dim)}
.acc-content p{margin-bottom:.8rem}
.acc-content a{color:#ff5560;text-decoration:none;border-bottom:1px solid rgba(255,85,96,.4);transition:.25s}
.acc-content a:hover{color:#fff;border-color:#fff}
.acc-content .stat{display:inline-block;font-family:'JetBrains Mono',monospace;font-size:.85rem;color:#e0a0a4;
  background:rgba(196,18,26,.14);padding:.15rem .5rem;border-radius:5px;margin:0 .15rem}

.arca-links{display:grid;grid-template-columns:1fr 1fr;gap:.5rem;margin-top:1rem}
@media(max-width:600px){.arca-links{grid-template-columns:1fr}}
.arca-links a{font-family:'JetBrains Mono',monospace;font-size:.78rem;color:var(--bone);text-decoration:none;
  padding:.6rem .8rem;border-radius:9px;background:rgba(0,0,0,.25);border:1px solid var(--glass-line);
  transition:.3s;display:flex;align-items:center;gap:.6rem}
.arca-links a .ai{width:20px;height:20px;flex-shrink:0;display:flex;align-items:center;justify-content:center;color:var(--blood-bright)}
.arca-links a .ai svg{width:16px;height:16px;fill:currentColor}
.arca-links a .ai img{width:16px;height:16px;object-fit:contain;
  filter:brightness(0) saturate(100%) invert(28%) sepia(86%) saturate(3500%) hue-rotate(345deg) brightness(105%) contrast(95%)}
.arca-links a .ai img.keep-color{filter:none}
.arca-links a .at{flex:1;color:var(--bone);transition:.3s}
.arca-links a .aa{color:var(--blood-bright)}
.arca-links a:hover{border-color:var(--blood);background:rgba(196,18,26,.16);padding-left:1.1rem}
.arca-links a:hover .at{color:#ff5560}

/* volume card (playlist unlock) */
.vol-card{display:flex;align-items:center;gap:1.1rem;padding:1.4rem 1.6rem;border-radius:18px;
  user-select:none;-webkit-user-select:none;-webkit-touch-callout:none;
  background:var(--glass);border:1px solid var(--glass-line);backdrop-filter:blur(14px);
  box-shadow:0 16px 40px rgba(0,0,0,.45);flex-wrap:wrap}
.vol-ico{font-size:1.5rem;filter:grayscale(.3);transition:.3s;min-width:32px;text-align:center}
.vol-track{position:relative;flex:1;min-width:180px;height:10px;border-radius:6px;
  background:rgba(0,0,0,.4);border:1px solid var(--glass-line);cursor:inherit}
.vol-fill{position:absolute;left:0;top:0;height:100%;width:0;border-radius:6px;
  background:linear-gradient(90deg,var(--blood-deep),var(--blood-bright));
  box-shadow:0 0 12px rgba(255,31,46,.6)}
.vol-knob{position:absolute;top:50%;left:0;width:22px;height:22px;border-radius:50%;
  transform:translate(-50%,-50%);background:radial-gradient(circle at 35% 30%,#ff5560,#7a0a0e);
  border:2px solid #ff8088;box-shadow:0 0 14px rgba(255,31,46,.8);cursor:inherit}
body.dragging,body.dragging *{user-select:none!important;-webkit-user-select:none!important}
.vol-track.resetting .vol-fill,.vol-track.resetting .vol-knob{transition:all .7s cubic-bezier(.4,0,.2,1)}
.vol-val{font-family:'JetBrains Mono',monospace;font-size:.9rem;color:#e0a0a4;min-width:44px;text-align:right}
.vol-hint{flex-basis:100%;font-family:'JetBrains Mono',monospace;font-size:.62rem;letter-spacing:.2em;
  color:var(--bone-dim);text-transform:uppercase;animation:hintFloat 2.4s ease-in-out infinite}

.modal-wide{max-width:720px}
.playlist-frame{width:100%;height:420px;border-radius:12px;overflow:hidden;border:1px solid var(--glass-line)}
.pl-eq{display:inline-flex;align-items:flex-end;gap:2px;height:20px}
.pl-eq i{width:3px;background:var(--blood-bright);border-radius:2px;animation:eq .9s ease-in-out infinite}
.pl-eq i:nth-child(1){height:40%;animation-delay:0s}
.pl-eq i:nth-child(2){height:90%;animation-delay:.2s}
.pl-eq i:nth-child(3){height:60%;animation-delay:.4s}
.pl-eq i:nth-child(4){height:80%;animation-delay:.1s}
@keyframes eq{0%,100%{transform:scaleY(.4)}50%{transform:scaleY(1)}}

/* scratch grid */
.scratch-tip{text-align:center;font-family:'JetBrains Mono',monospace;font-size:.7rem;letter-spacing:.2em;
  text-transform:uppercase;color:var(--bone-dim);margin:-.4rem 0 1.1rem}
.scratch-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.85rem;min-height:200px}
@media(max-width:760px){.scratch-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.scratch-grid{grid-template-columns:1fr}}
.scratch-card{position:relative;width:100%;aspect-ratio:16/9;border-radius:14px;overflow:hidden;
  border:1px solid var(--glass-line);box-shadow:0 12px 30px rgba(0,0,0,.45);
  user-select:none;-webkit-user-select:none;-webkit-touch-callout:none;transition:transform .4s,box-shadow .4s}
.scratch-card .sp{position:absolute;inset:0;background-size:cover;background-position:center}
.scratch-canvas{position:absolute;inset:0;width:100%;height:100%;touch-action:none;
  cursor:inherit}
.scratch-card.done .scratch-canvas{pointer-events:none;opacity:0;transition:opacity .6s}
.scratch-label{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  font-family:'JetBrains Mono',monospace;font-size:.85rem;letter-spacing:.25em;text-transform:uppercase;
  color:rgba(232,216,216,.6);pointer-events:none;z-index:2;transition:opacity .5s;
  animation:scratchPulse 1.8s ease-in-out infinite}
@keyframes scratchPulse{0%,100%{opacity:.4;transform:scale(1)}50%{opacity:.85;transform:scale(1.08)}}
.scratch-card.done .scratch-label{opacity:0;animation:none}
.scratch-card.done:hover{transform:translateY(-4px);box-shadow:0 16px 36px rgba(122,10,14,.6)}
.scratch-card.done::after{content:"⛶";position:absolute;right:8px;bottom:6px;font-size:.9rem;color:#fff;
  opacity:0;transition:opacity .3s;text-shadow:0 0 6px rgba(0,0,0,.9);z-index:3}
.scratch-card.done:hover::after{opacity:.9}

/* gallery modal — specificity бьёт .modal{max-width:560px} */
.modal.modal-gallery{max-width:none;width:min(96vw,1800px);padding:1.6rem 1.8rem}
.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:.7rem;
  max-height:78vh;overflow-y:auto;padding:.3rem}
.gallery-grid::-webkit-scrollbar{width:8px}
.gallery-grid::-webkit-scrollbar-thumb{background:var(--blood-deep);border-radius:4px}
.gallery-grid .gphoto{aspect-ratio:16/9;border-radius:12px;overflow:hidden;position:relative;
  border:1px solid var(--glass-line);background:#1a0809;transition:transform .35s,box-shadow .35s;
  opacity:0;transform:scale(.9) translateY(10px);animation:gphotoIn .5s ease forwards}
@keyframes gphotoIn{to{opacity:1;transform:scale(1) translateY(0)}}
.gallery-grid .gphoto img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.gallery-grid .gphoto:hover{transform:translateY(-4px);box-shadow:0 12px 28px rgba(122,10,14,.6);z-index:2}
.gallery-grid .gphoto:hover img{transform:scale(1.08)}
.gallery-grid .gphoto::after{content:"⛶";position:absolute;right:8px;bottom:6px;font-size:.9rem;color:#fff;
  opacity:0;transition:opacity .3s;text-shadow:0 0 6px rgba(0,0,0,.9)}
.gallery-grid .gphoto:hover::after{opacity:.9}
@media(min-aspect-ratio:16/10){.gallery-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}}
@media(min-aspect-ratio:21/9){.gallery-grid{grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:1rem}.modal.modal-gallery{width:min(94vw,2400px)}}

/* lightbox */
.lightbox{position:fixed;inset:0;z-index:120;background:rgba(3,1,2,.94);backdrop-filter:blur(12px);
  display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .4s}
.lightbox.show{opacity:1;pointer-events:auto}
.lb-img{max-width:90vw;max-height:85vh;border-radius:12px;box-shadow:0 30px 90px rgba(0,0,0,.8),0 0 60px rgba(196,18,26,.25);
  transform:scale(.85);transition:transform .45s cubic-bezier(.2,.9,.3,1.2),opacity .25s ease;border:1px solid var(--glass-line);
  background:#0a0506}
.lightbox.show .lb-img{transform:scale(1)}
.lightbox.loading .lb-img{opacity:.18;filter:blur(2px) saturate(.6)}
/* spinner поверх во время загрузки нового фото */
.lb-spinner{position:absolute;left:50%;top:50%;width:64px;height:64px;margin:-32px 0 0 -32px;
  border:3px solid rgba(255,31,46,.18);border-top-color:var(--blood-bright);border-radius:50%;
  opacity:0;pointer-events:none;animation:lbSpin .9s linear infinite;transition:opacity .25s ease}
.lightbox.loading .lb-spinner{opacity:1}
@keyframes lbSpin{to{transform:rotate(360deg)}}
.lb-progress{position:absolute;left:50%;top:calc(50% + 46px);transform:translateX(-50%);
  font-family:'JetBrains Mono',monospace;font-size:.65rem;letter-spacing:.25em;color:var(--bone-dim);
  opacity:0;transition:opacity .25s ease;text-transform:uppercase}
.lightbox.loading .lb-progress{opacity:.85}
.lb-close{position:absolute;top:1.4rem;right:1.6rem;font-family:'JetBrains Mono',monospace;font-size:1.8rem;
  color:var(--bone);background:none;border:none;transition:.25s;z-index:2}
.lb-close:hover{color:var(--blood-bright);transform:rotate(90deg)}
.lb-nav{position:absolute;top:50%;transform:translateY(-50%);font-size:3rem;color:var(--bone);
  background:rgba(30,8,11,.5);border:1px solid var(--glass-line);width:54px;height:54px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;transition:.25s;backdrop-filter:blur(6px)}
.lb-nav:hover{color:#fff;border-color:var(--blood);background:rgba(196,18,26,.3)}
.lb-prev{left:1.5rem}.lb-next{right:1.5rem}
.lb-counter{position:absolute;bottom:1.4rem;left:50%;transform:translateX(-50%);font-family:'JetBrains Mono',monospace;
  font-size:.8rem;letter-spacing:.2em;color:var(--bone-dim)}
.lb-caption{position:absolute;bottom:4rem;left:50%;transform:translateX(-50%);
  max-width:min(80vw,860px);text-align:center;
  font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1.1rem;
  color:var(--bone);background:rgba(10,5,6,.7);backdrop-filter:blur(8px);
  padding:.6rem 1.2rem;border-radius:10px;border:1px solid var(--glass-line);
  opacity:0;pointer-events:none;transition:opacity .35s ease;
  text-shadow:0 0 8px rgba(0,0,0,.6)}
.lb-caption.show{opacity:1}
@media(max-width:600px){.lb-nav{width:42px;height:42px;font-size:2rem}.lb-prev{left:.5rem}.lb-next{right:.5rem}}

/* music control (FAB + hover panel) */
#musicWrap{position:fixed;bottom:1.4rem;right:1.4rem;z-index:60;display:flex;align-items:center;gap:.6rem}
#music{position:relative;width:52px;height:52px;border-radius:50%;
  border:1px solid var(--glass-line);background:var(--glass);backdrop-filter:blur(10px);color:var(--blood-bright);
  display:flex;align-items:center;justify-content:center;box-shadow:0 8px 24px rgba(0,0,0,.5);
  transition:.3s;font-size:1.1rem;opacity:0;pointer-events:none}
#music.show{opacity:1;pointer-events:auto}
#music:hover{border-color:var(--blood);transform:scale(1.08)}
#music.playing{animation:pulseBtn 2s ease-in-out infinite}
@keyframes pulseBtn{0%,100%{box-shadow:0 8px 24px rgba(0,0,0,.5)}50%{box-shadow:0 8px 30px rgba(255,31,46,.6)}}
#music .ic-on,#music .ic-off{position:relative;display:inline-block;transition:opacity .35s,transform .35s}
#music .ic-off{position:absolute}
#music .ic-off::after{content:"";position:absolute;left:-3px;top:50%;width:130%;height:2px;background:var(--blood-bright);
  transform:rotate(45deg);transform-origin:center;box-shadow:0 0 6px rgba(255,31,46,.8)}
#music.playing .ic-on{opacity:1;transform:scale(1)}
#music.playing .ic-off{opacity:0;transform:scale(.6)}
#music:not(.playing) .ic-on{opacity:0;transform:scale(.6)}
#music:not(.playing) .ic-off{opacity:1;transform:scale(1);animation:mutePulse 1.6s ease-in-out infinite}
@keyframes mutePulse{0%,100%{opacity:.55}50%{opacity:1}}
.music-panel{display:flex;flex-direction:column;gap:.5rem;align-items:flex-end;
  opacity:0;transform:translateX(10px);transition:.35s}
#musicWrap:hover .music-panel{opacity:1;transform:translateX(0)}
.music-tip{font-family:'JetBrains Mono',monospace;font-size:.7rem;letter-spacing:.05em;color:var(--bone);
  background:var(--glass);backdrop-filter:blur(10px);border:1px solid var(--glass-line);
  padding:.5rem .85rem;border-radius:10px;white-space:nowrap;box-shadow:0 8px 20px rgba(0,0,0,.5)}

/* music panel row: prev / slider / next */
.music-row{display:flex;align-items:center;gap:.4rem}
.music-nav{width:26px;height:26px;border-radius:8px;flex-shrink:0;
  background:var(--glass);backdrop-filter:blur(10px);
  border:1px solid var(--glass-line);color:var(--blood-bright);
  font-size:1.2rem;line-height:1;display:flex;align-items:center;justify-content:center;
  transition:.25s;padding:0}
.music-nav:hover{border-color:var(--blood);color:#fff;background:rgba(196,18,26,.3);transform:scale(1.08)}
.music-nav:active{transform:scale(.92)}
.music-shuffle svg{transition:transform .5s ease}
.music-shuffle:hover svg{transform:rotate(15deg)}
.music-shuffle.spin svg{animation:shufSpin .55s ease}
@keyframes shufSpin{
  0%   { transform: rotate(0)   scale(1); }
  50%  { transform: rotate(180deg) scale(1.15); }
  100% { transform: rotate(360deg) scale(1); }
}

/* mini volume slider (div-based, наследует gengar) */
.vol-mini{position:relative;width:120px;height:8px;border-radius:6px;
  background:rgba(0,0,0,.5);border:1px solid var(--glass-line);cursor:inherit}
.vol-mini-fill{position:absolute;left:0;top:0;height:100%;width:50%;border-radius:6px;
  background:linear-gradient(90deg,var(--blood-deep),var(--blood-bright));
  box-shadow:0 0 8px rgba(255,31,46,.5)}
.vol-mini-knob{position:absolute;top:50%;left:50%;width:14px;height:14px;border-radius:50%;
  transform:translate(-50%,-50%);background:radial-gradient(circle at 35% 30%,#ff5560,#7a0a0e);
  border:2px solid #ff8088;box-shadow:0 0 8px rgba(255,31,46,.7);cursor:inherit}

footer{text-align:center;margin:3rem 0 1rem;font-family:'JetBrains Mono',monospace;font-size:.66rem;letter-spacing:.2em;color:var(--bone-dim);text-transform:uppercase;transition:.3s}
footer .hb{display:inline-block;animation:heartbeat 1.4s ease-in-out infinite;color:var(--blood-bright)}
.friends-egg{transition:filter .3s,transform .3s;position:relative;
  color:var(--blood-bright);text-shadow:0 0 8px rgba(255,31,46,.7);
  animation:heartbeat 1.4s ease-in-out infinite,eggGlow 2s ease-in-out infinite}
@keyframes eggGlow{0%,100%{text-shadow:0 0 6px rgba(255,31,46,.5)}50%{text-shadow:0 0 16px rgba(255,31,46,1)}}
.friends-egg::after{content:"";position:absolute;left:50%;top:50%;width:22px;height:22px;
  transform:translate(-50%,-50%);border:1.5px solid var(--blood-bright);border-radius:50%;
  opacity:0;animation:eggRing 1.8s ease-out infinite}
@keyframes eggRing{0%{opacity:.8;width:14px;height:14px}100%{opacity:0;width:42px;height:42px}}
.friends-egg:hover{filter:drop-shadow(0 0 12px rgba(255,31,46,1));transform:scale(1.5)}
.foot-hint{font-family:'JetBrains Mono',monospace;font-size:.58rem;letter-spacing:.25em;
  color:var(--blood-bright);margin-top:.5rem;opacity:.65;animation:hintFloat 2.4s ease-in-out infinite}
@keyframes hintFloat{0%,100%{opacity:.4;transform:translateY(0)}50%{opacity:.85;transform:translateY(-2px)}}
.foot-contact{margin-top:.9rem;font-family:'JetBrains Mono',monospace;font-size:.7rem;letter-spacing:.18em;
  color:var(--bone-dim);opacity:.8;text-transform:lowercase}
.foot-contact a{color:#e0a0a4;text-decoration:none;border-bottom:1px solid rgba(224,160,164,.3);
  padding-bottom:1px;transition:.25s;position:relative;display:inline-block}
.foot-contact a:hover{color:#ff5560;border-color:#ff5560;text-shadow:0 0 8px rgba(255,85,96,.5)}
.email-copied{position:absolute;left:50%;top:-2em;transform:translateX(-50%) translateY(8px);
  background:linear-gradient(135deg,var(--blood),var(--blood-deep));color:#fff;
  padding:.25rem .65rem;border-radius:6px;
  font-family:'JetBrains Mono',monospace;font-size:.6rem;letter-spacing:.15em;white-space:nowrap;text-transform:uppercase;
  opacity:0;pointer-events:none;
  transition:transform .35s cubic-bezier(.2,.9,.3,1.2),opacity .25s ease;
  box-shadow:0 6px 16px rgba(0,0,0,.5),inset 0 0 0 1px rgba(255,85,96,.4)}
.foot-contact a.copied .email-copied{opacity:1;transform:translateX(-50%) translateY(-3px)}

/* "скопировано" overlay для email-ссылки в marquee — выезжает сверху, перекрывает карточку */
.lnk .lnk-copied{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,var(--blood),var(--blood-deep));color:#fff;
  font-family:'JetBrains Mono',monospace;font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;
  border-radius:14px;z-index:5;pointer-events:none;
  transform:translateY(-100%);opacity:0;
  transition:transform .45s cubic-bezier(.2,.9,.3,1.2),opacity .25s ease;
  box-shadow:0 6px 18px rgba(0,0,0,.5),inset 0 0 0 1px rgba(255,85,96,.5)}
.lnk.copied .lnk-copied{transform:translateY(0);opacity:1;
  transition:transform .35s cubic-bezier(.2,.9,.3,1.2),opacity .15s ease}
.foot-copy{margin-top:.6rem;font-size:.6rem;letter-spacing:.18em;color:var(--bone-dim);opacity:.7}
@keyframes heartbeat{0%,100%{transform:scale(1)}15%{transform:scale(1.3)}30%{transform:scale(1)}45%{transform:scale(1.2)}}

/* modals */
.modal-bg{position:fixed;inset:0;z-index:90;background:rgba(5,2,3,.8);backdrop-filter:blur(8px);
  display:flex;align-items:center;justify-content:center;padding:1.5rem;opacity:0;pointer-events:none;transition:opacity .4s}
.modal-bg.show{opacity:1;pointer-events:auto}
.modal{background:linear-gradient(160deg,#1a0709,#0d0405);border:1px solid var(--glass-line);
  border-radius:22px;max-width:560px;width:100%;padding:2.2rem;position:relative;
  box-shadow:0 30px 80px rgba(0,0,0,.7),0 0 60px rgba(196,18,26,.2);
  transform:scale(.85) translateY(20px);transition:transform .5s cubic-bezier(.2,.9,.3,1.2)}
.modal-bg.show .modal{transform:scale(1) translateY(0)}
.modal .close{position:absolute;top:1rem;right:1.2rem;font-family:'JetBrains Mono',monospace;
  font-size:1.4rem;color:var(--bone-dim);background:none;border:none;transition:.25s;line-height:1}
.modal .close:hover{color:var(--blood-bright);transform:rotate(90deg)}
.modal h2{font-family:'Cinzel',serif;font-size:1.5rem;text-align:center;color:var(--bone);
  display:flex;align-items:center;justify-content:center;gap:.6rem;flex-wrap:wrap;margin-bottom:1.4rem}
.marker-heart{display:inline-block;width:38px;height:38px;vertical-align:middle}
.marker-heart path{fill:none;stroke:#e0202c;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round;
  filter:drop-shadow(0 0 4px rgba(224,32,44,.5));
  stroke-dasharray:140;stroke-dashoffset:140;animation:drawHeart 1.4s ease forwards .2s, heartPulse 1.8s ease-in-out infinite 1.6s}
@keyframes drawHeart{to{stroke-dashoffset:0}}
@keyframes heartPulse{0%,100%{transform:scale(1)}50%{transform:scale(1.08)}}
.marker-heart .fillh{fill:#c4121a;opacity:0;animation:fillIn .6s ease forwards 1.2s}
@keyframes fillIn{to{opacity:.85}}
/* modal-friends — шире чем стандартная модалка */
.modal.modal-friends{max-width:none;width:min(95vw,1200px);padding:1.8rem 2rem}
@media(min-aspect-ratio:21/9){.modal.modal-friends{width:min(92vw,1600px)}}

/* friends marquee (бегущая строка фото в модалке) */
.friends-marquee{position:relative;overflow-x:hidden;overflow-y:visible;
  margin-bottom:1.2rem;padding:2rem 0 2.2rem;height:auto;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent);
          mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent)}
.friends-marquee-track{height:220px}
.friends-marquee-track{display:flex;gap:.7rem;width:max-content;will-change:transform;height:100%}
/* JS-marquee — см. extras.js */
.friend-card{flex:0 0 auto;width:380px;height:220px;border-radius:14px;overflow:hidden;
  border:1px solid var(--glass-line);transition:transform .3s,box-shadow .3s;position:relative;
  background:linear-gradient(135deg,#2a0d10,#0d0405)}
@media(max-width:760px){.friend-card{width:260px;height:150px}.friends-marquee{height:170px}}
.friend-card img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s}
.friend-card:hover{transform:translateY(-4px);box-shadow:0 8px 22px rgba(122,10,14,.45),0 0 22px rgba(255,31,46,.25),0 0 0 1px rgba(255,31,46,.3);z-index:2}
.friend-card:hover img{transform:scale(1.06)}
.friend-card::after{content:"⛶";position:absolute;right:8px;bottom:6px;color:#fff;font-size:.9rem;
  opacity:0;transition:.3s;text-shadow:0 0 6px rgba(0,0,0,.9)}
.friend-card:hover::after{opacity:.9}
.friends-names{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center}
.friends-names span{font-family:'JetBrains Mono',monospace;font-size:.78rem;color:#e0a0a4;
  background:rgba(196,18,26,.14);border:1px solid var(--glass-line);padding:.35rem .7rem;border-radius:8px;transition:.25s}
.friends-names span:hover{background:rgba(196,18,26,.3);color:#fff;transform:translateY(-2px)}
.friends-names span.more{background:none;border-color:transparent;color:var(--bone-dim);font-style:italic}
@media(max-width:720px){.profile{justify-content:center;text-align:center}}

/* ============================================================
   COOKIE BANNER
   ============================================================ */
#cookieBanner{position:fixed;left:1rem;right:1rem;bottom:1rem;z-index:200;
  display:flex;align-items:center;gap:1rem;flex-wrap:wrap;justify-content:center;
  padding:.9rem 1.2rem;border-radius:14px;
  background:linear-gradient(160deg,rgba(26,7,9,.92),rgba(13,4,5,.92));
  backdrop-filter:blur(14px);border:1px solid var(--glass-line);
  box-shadow:0 20px 50px rgba(0,0,0,.6),0 0 0 1px rgba(196,18,26,.15) inset;
  font-family:'JetBrains Mono',monospace;font-size:.72rem;letter-spacing:.05em;color:var(--bone-dim);
  transform:translateY(calc(100% + 2rem));opacity:0;
  transition:transform .55s cubic-bezier(.2,.9,.3,1.2),opacity .35s ease;
  max-width:780px;margin:0 auto}
#cookieBanner.show{transform:translateY(0);opacity:1}
#cookieBanner .cookie-text{flex:1;min-width:260px;line-height:1.5}
#cookieBanner .cookie-btn{font-family:'JetBrains Mono',monospace;font-size:.7rem;letter-spacing:.2em;
  text-transform:uppercase;padding:.55rem 1.2rem;border-radius:8px;
  background:linear-gradient(135deg,var(--blood),var(--blood-deep));color:#fff;
  border:1px solid rgba(255,85,96,.4);transition:transform .25s,box-shadow .25s;flex-shrink:0}
#cookieBanner .cookie-btn:hover{transform:translateY(-2px);box-shadow:0 8px 20px rgba(196,18,26,.55)}
#cookieBanner .cookie-btn:active{transform:translateY(0)}
@media(max-width:600px){
  #cookieBanner{flex-direction:column;text-align:center;padding:1rem .9rem}
  #cookieBanner .cookie-text{min-width:0}
}

/* ============================================================
   ACHIEVEMENTS — TOAST
   ============================================================ */
.ach-toast{position:fixed;top:1.2rem;right:1.2rem;z-index:210;
  display:flex;align-items:center;gap:.8rem;padding:.85rem 1.1rem;border-radius:14px;
  background:linear-gradient(160deg,#2a0d10,#0d0405);
  border:1px solid var(--glass-line);
  box-shadow:0 14px 40px rgba(0,0,0,.6),0 0 30px rgba(196,18,26,.4),inset 0 0 0 1px rgba(255,85,96,.25);
  max-width:320px;
  transform:translateX(calc(100% + 2rem));opacity:0;
  transition:transform .5s cubic-bezier(.2,.9,.3,1.2),opacity .3s ease}
.ach-toast.show{transform:translateX(0);opacity:1}
.ach-toast-icon{width:42px;height:42px;border-radius:10px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,var(--blood),var(--blood-deep));color:#fff;
  font-family:'Cinzel',serif;font-size:1.4rem;font-weight:700;
  box-shadow:0 0 16px rgba(255,31,46,.6),inset 0 1px 0 rgba(255,255,255,.15)}
.ach-toast-body{flex:1;min-width:0}
.ach-toast-label{font-family:'JetBrains Mono',monospace;font-size:.55rem;letter-spacing:.25em;
  text-transform:uppercase;color:#ff5560;margin-bottom:.15rem}
.ach-toast-name{font-family:'Cinzel',serif;font-size:1rem;color:var(--bone);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
@media(max-width:480px){.ach-toast{left:1rem;right:1rem;max-width:none}}

/* ============================================================
   ACHIEVEMENTS — MODAL
   ============================================================ */
.ach-modal-bg{position:fixed;inset:0;z-index:130;background:rgba(5,2,3,.85);backdrop-filter:blur(10px);
  display:flex;align-items:center;justify-content:center;padding:1.5rem;
  opacity:0;pointer-events:none;transition:opacity .4s}
.ach-modal-bg.show{opacity:1;pointer-events:auto}
.ach-modal{background:linear-gradient(160deg,#1a0709,#0d0405);
  border:1px solid var(--glass-line);border-radius:22px;width:min(95vw,860px);max-height:88vh;
  padding:2rem 2.2rem;position:relative;overflow:hidden;display:flex;flex-direction:column;
  box-shadow:0 30px 80px rgba(0,0,0,.7),0 0 60px rgba(196,18,26,.2);
  transform:scale(.9) translateY(20px);transition:transform .5s cubic-bezier(.2,.9,.3,1.2)}
.ach-modal-bg.show .ach-modal{transform:scale(1) translateY(0)}
.ach-close{position:absolute;top:1rem;right:1.2rem;font-family:'JetBrains Mono',monospace;
  font-size:1.4rem;color:var(--bone-dim);background:none;border:none;transition:.25s;line-height:1}
.ach-close:hover{color:var(--blood-bright);transform:rotate(90deg)}
.ach-h2{font-family:'Cinzel',serif;font-size:1.6rem;color:var(--bone);
  display:flex;align-items:center;justify-content:center;gap:1rem;flex-wrap:wrap;margin-bottom:1.5rem;text-transform:lowercase}
.ach-progress-pill{font-family:'JetBrains Mono',monospace;font-size:.65rem;letter-spacing:.18em;
  text-transform:uppercase;color:#e0a0a4;background:rgba(196,18,26,.18);
  border:1px solid var(--glass-line);padding:.3rem .7rem;border-radius:8px}
.ach-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:.7rem;
  overflow-y:auto;padding:.3rem;max-height:65vh}
.ach-list::-webkit-scrollbar{width:8px}
.ach-list::-webkit-scrollbar-thumb{background:var(--blood-deep);border-radius:4px}
.ach-card{display:flex;align-items:center;gap:.85rem;padding:.85rem;border-radius:12px;
  background:rgba(0,0,0,.3);border:1px solid var(--glass-line);
  transition:transform .25s,border-color .25s,background .25s;opacity:.55}
.ach-card.unlocked{opacity:1;background:rgba(196,18,26,.08);border-color:rgba(255,85,96,.35)}
.ach-card.unlocked:hover{transform:translateY(-2px);border-color:var(--blood-bright);
  box-shadow:0 6px 18px rgba(122,10,14,.5)}
.ach-card-icon{width:42px;height:42px;border-radius:10px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  background:rgba(0,0,0,.4);color:var(--bone-dim);
  font-family:'Cinzel',serif;font-size:1.4rem;font-weight:700;
  border:1px solid var(--glass-line);transition:.3s}
.ach-card.unlocked .ach-card-icon{background:linear-gradient(135deg,var(--blood),var(--blood-deep));
  color:#fff;border-color:var(--blood-bright);
  box-shadow:0 0 14px rgba(255,31,46,.45),inset 0 1px 0 rgba(255,255,255,.1)}
.ach-card-body{flex:1;min-width:0}
.ach-card-name{font-family:'Cinzel',serif;font-size:.95rem;color:var(--bone);margin-bottom:.15rem;
  text-transform:lowercase;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ach-card.unlocked .ach-card-name{color:#ff5560}
.ach-card-desc{font-family:'JetBrains Mono',monospace;font-size:.65rem;letter-spacing:.05em;
  color:var(--bone-dim);line-height:1.4}
