/* ============================================================
   NEROMAX — Editorial / Bold-Typography identity
   Крупная редакторская типографика, тонкие линии, острые углы,
   обложки как главный визуальный акцент. Всё статично:
   анимации только transform/opacity, тяжёлого рендера нет.
   ============================================================ */
:root{
  --bg:#060510; --bg-2:#04030b;
  --fg:#F4F2FF; --muted:#8c86b6; --faint:#5a5680;
  --violet:#8b5cff; --magenta:#ff2fd0; --cyan:#29e0ff; --accent:#29e0ff;
  --line:rgba(255,255,255,.10); --line-2:rgba(255,255,255,.18);
  --panel:rgba(16,13,32,.55);
  --r:6px; --r-lg:12px; --maxw:1240px;
  --ease:cubic-bezier(.2,.7,.2,1);
  --mono:'Space Grotesk',ui-monospace,monospace;
  --display:'Archivo Black',system-ui,sans-serif;
  --serif:'Playfair Display',Georgia,serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{overflow-x:clip;max-width:100%;overflow-anchor:none;scroll-padding-top:96px}
body{font-family:'Poppins',system-ui,sans-serif;background:var(--bg);color:var(--fg);
  line-height:1.6;overflow-x:clip;max-width:100%;-webkit-font-smoothing:antialiased;}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
::selection{background:var(--magenta);color:#fff}
.mono{font-family:var(--mono)}

/* ============ STATIC BACKGROUND ============ */
.bg{position:fixed;inset:0;z-index:-3;background:#060510 url("assets/bg2.webp") center/cover no-repeat;}
.bg::after{content:"";position:absolute;inset:0;background:
  radial-gradient(75% 65% at 50% 38%, transparent, rgba(6,5,16,.62) 100%),
  linear-gradient(180deg, rgba(6,5,16,.45), rgba(6,5,16,.2) 30%, rgba(6,5,16,.72));}
.grain{position:fixed;inset:0;z-index:-2;pointer-events:none;opacity:.045;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");}

/* mono label helper used across sections */
.kicker{display:inline-flex;align-items:center;gap:10px;font-family:var(--mono);font-size:.72rem;
  letter-spacing:.28em;text-transform:uppercase;color:var(--cyan);font-weight:600;}
.kicker::before{content:"";width:28px;height:1px;background:var(--cyan);opacity:.7}

/* ============ NAV ============ */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;
  padding:18px clamp(16px,5vw,56px);transition:background .3s,border-color .3s;border-bottom:1px solid transparent;}
.nav.scrolled{background:rgba(6,5,16,.86);border-bottom-color:var(--line);}
.brand{display:flex;align-items:center;gap:11px}
.brand-mark{color:var(--cyan);display:grid;place-items:center}
.brand-text{font-family:var(--display);font-size:1.15rem;letter-spacing:.04em}
.nav-links{display:flex;gap:30px}
.nav-links a{font-family:var(--mono);color:var(--muted);font-size:.82rem;letter-spacing:.06em;font-weight:500;position:relative;transition:color .2s}
.nav-links a:hover,.nav-links a:focus-visible{color:var(--fg)}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-7px;width:0;height:1px;background:var(--cyan);transition:width .25s var(--ease)}
.nav-links a:hover::after,.nav-links a:focus-visible::after{width:100%}
.nav-toggle{display:none;flex-direction:column;gap:5px;padding:8px}
.nav-toggle span{width:24px;height:2px;background:var(--fg);border-radius:2px;transition:.3s var(--ease)}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ============ HERO (editorial, left-aligned, oversized) ============ */
.hero{min-height:100svh;display:flex;align-items:center;padding:140px clamp(16px,5vw,56px) 90px;position:relative}
.hero-inner{max-width:var(--maxw);width:100%;margin:0 auto;animation:rise .8s var(--ease) both}
.eyebrow{display:inline-flex;align-items:center;gap:10px;font-family:var(--mono);font-size:.74rem;letter-spacing:.28em;
  text-transform:uppercase;color:var(--muted);margin-bottom:30px;padding-bottom:14px;border-bottom:1px solid var(--line)}
.eyebrow .dot{width:7px;height:7px;border-radius:50%;background:var(--cyan);box-shadow:0 0 10px var(--cyan);animation:blink 2.4s infinite}
.hero-title{font-family:var(--display);font-size:clamp(2.8rem,13.5vw,12rem);line-height:.9;letter-spacing:-.03em;
  white-space:nowrap;max-width:100%;
  background:linear-gradient(180deg,#fff 30%,#b9a8ff 70%,var(--violet));-webkit-background-clip:text;background-clip:text;color:transparent;}
.hero-tagline{font-family:var(--serif);font-style:italic;font-weight:500;font-size:clamp(1.4rem,4.4vw,2.6rem);
  color:var(--fg);margin-top:18px;line-height:1.1}
.hero-tagline em{font-style:italic;background:linear-gradient(110deg,var(--cyan),var(--magenta));-webkit-background-clip:text;background-clip:text;color:transparent}
.hero-sub{color:var(--muted);font-size:clamp(1rem,1.4vw,1.18rem);max-width:520px;margin:26px 0 38px;font-weight:300}
.hero-cta{display:flex;gap:16px;flex-wrap:wrap}
.hero-eq{display:flex;align-items:flex-end;gap:5px;height:48px;margin-top:64px;opacity:.9}
.hero-eq span{width:4px;height:100%;transform-origin:bottom;border-radius:1px;background:linear-gradient(180deg,var(--cyan),var(--violet));transform:scaleY(.45)}
/* в покое — статичные полосы со ступенчатой высотой; анимация только при воспроизведении */
.hero-eq span:nth-child(3n+1){transform:scaleY(.75)} .hero-eq span:nth-child(3n+2){transform:scaleY(.3)} .hero-eq span:nth-child(4n){transform:scaleY(.9)} .hero-eq span:nth-child(5n){transform:scaleY(.2)}
body.is-playing .hero-eq span{animation:eqbar 1.3s ease-in-out infinite}
.hero-eq span:nth-child(3n){background:linear-gradient(180deg,var(--magenta),var(--violet));animation-duration:.95s}
.hero-eq span:nth-child(even){animation-duration:1.7s}
.hero-eq span:nth-child(1){animation-delay:-.2s}.hero-eq span:nth-child(2){animation-delay:-.6s}.hero-eq span:nth-child(3){animation-delay:-.9s}.hero-eq span:nth-child(4){animation-delay:-.3s}.hero-eq span:nth-child(5){animation-delay:-.7s}.hero-eq span:nth-child(6){animation-delay:-1s}.hero-eq span:nth-child(7){animation-delay:-.4s}.hero-eq span:nth-child(8){animation-delay:-.8s}.hero-eq span:nth-child(9){animation-delay:-.1s}.hero-eq span:nth-child(10){animation-delay:-.5s}.hero-eq span:nth-child(11){animation-delay:-.9s}.hero-eq span:nth-child(12){animation-delay:-.2s}.hero-eq span:nth-child(13){animation-delay:-.6s}.hero-eq span:nth-child(14){animation-delay:-1.1s}.hero-eq span:nth-child(15){animation-delay:-.35s}.hero-eq span:nth-child(16){animation-delay:-.75s}.hero-eq span:nth-child(17){animation-delay:-.15s}.hero-eq span:nth-child(18){animation-delay:-.55s}

.btn{display:inline-flex;align-items:center;gap:10px;padding:15px 28px;border-radius:var(--r);font-family:var(--mono);
  font-weight:600;font-size:.9rem;letter-spacing:.04em;transition:transform .2s var(--ease),background .25s,color .25s,border-color .25s}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--fg);color:#0a0818}
.btn-primary:hover,.btn-primary:focus-visible{background:var(--cyan);color:#03121a}
.btn-ghost{border:1px solid var(--line-2);color:var(--fg)}
.btn-ghost:hover,.btn-ghost:focus-visible{border-color:var(--cyan);color:var(--cyan)}
.scroll-hint{position:absolute;right:clamp(16px,5vw,56px);bottom:34px;display:flex;flex-direction:column;align-items:center;gap:8px;
  color:var(--muted);font-family:var(--mono);font-size:.68rem;letter-spacing:.2em;text-transform:uppercase}
.scroll-hint svg{animation:bob 1.8s infinite ease-in-out}

/* ============ MARQUEE ============ */
.marquee{position:relative;overflow:hidden;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:20px 0;background:rgba(255,255,255,.015)}
.marquee::before,.marquee::after{content:"";position:absolute;top:0;bottom:0;width:14%;z-index:2;pointer-events:none}
.marquee::before{left:0;background:linear-gradient(90deg,var(--bg),transparent)}
.marquee::after{right:0;background:linear-gradient(270deg,var(--bg),transparent)}
.marquee-track{display:flex;width:max-content;animation:scroll-x 32s linear infinite;will-change:transform}
.marquee-group{display:flex;align-items:center;gap:30px;padding-right:30px;flex:none;white-space:nowrap;
  font-family:var(--display);font-size:1.05rem;letter-spacing:.06em}
.marquee-group span{color:transparent;-webkit-text-stroke:1px var(--line-2)}
.marquee-group i{color:var(--cyan);font-style:normal;font-size:.7rem}

/* ============ SECTIONS / editorial headers ============ */
.section{max-width:var(--maxw);margin:0 auto;padding:clamp(72px,10vw,140px) clamp(16px,5vw,56px)}
.section-head{margin-bottom:clamp(40px,6vw,72px);max-width:760px}
.section-title{font-family:var(--display);font-size:clamp(2.4rem,6vw,4.6rem);line-height:.95;letter-spacing:-.02em;margin-top:18px;
  background:linear-gradient(180deg,#fff,#c8c2f0);-webkit-background-clip:text;background-clip:text;color:transparent}
.section-desc{color:var(--muted);margin-top:18px;font-weight:300;max-width:560px;font-size:1.02rem}

/* ============ PLAYER ============ */
.player-wrap{display:grid;grid-template-columns:380px 1fr;gap:clamp(20px,3vw,40px);align-items:start}
.now-playing{position:sticky;top:96px;border:1px solid var(--line);border-radius:var(--r-lg);padding:22px;background:var(--panel)}
.np-art{position:relative;aspect-ratio:1;border-radius:var(--r);overflow:hidden;display:grid;place-items:center;
  background:#15102e linear-gradient(135deg,#241a52,#0c0a1e);background-size:cover;background-position:center;
  border:1px solid var(--line);margin-bottom:14px}
.np-art.has-cover .np-art-icon{opacity:0}
.np-art-icon{position:relative;z-index:2;color:rgba(255,255,255,.55)}
.np-art-eq{position:absolute;inset:0;z-index:1;display:none;align-items:flex-end;justify-content:center;gap:6px;padding:24%;
  background:linear-gradient(180deg,transparent,rgba(0,0,0,.45))}
.np-art-eq i{flex:1;max-width:13px;height:100%;transform-origin:bottom;border-radius:2px;background:linear-gradient(180deg,var(--cyan),var(--magenta));animation:eqbar 1.1s ease-in-out infinite}
.np-art-eq i:nth-child(2){animation-delay:-.4s}.np-art-eq i:nth-child(3){animation-delay:-.7s}.np-art-eq i:nth-child(4){animation-delay:-.2s}.np-art-eq i:nth-child(5){animation-delay:-.55s}
.now-playing.playing .np-art-eq{display:flex}
/* 3D-эквалайзер поверх обложки (only while playing) */
.np-eq3d{position:absolute;inset:0;z-index:3;display:block;width:100%;height:100%;border-radius:inherit;opacity:0;pointer-events:none;transition:opacity .45s ease}
.now-playing.playing .np-eq3d{opacity:1}
/* во время игры плитка — цельный тёмный виджет (обложка не просвечивает) */
.now-playing.playing .np-art.eq3d-ready{background-image:none!important;background-color:#070710}
/* скрим под виджетом — читаемость свечения на светлой обложке */
.np-art.eq3d-ready.has-cover::after{content:"";position:absolute;inset:0;z-index:2;pointer-events:none;opacity:0;transition:opacity .45s ease;
  background:radial-gradient(120% 120% at 50% 35%,rgba(4,4,9,.18),rgba(4,4,9,.6))}
.now-playing.playing .np-art.eq3d-ready.has-cover::after{opacity:1}
/* нижний фейд ПОВЕРХ виджета — гасит полоску обложки/кончики отражений у нижней кромки */
.np-art.eq3d-ready::before{content:"";position:absolute;left:0;right:0;bottom:0;height:24%;z-index:4;pointer-events:none;opacity:0;transition:opacity .45s ease;
  background:linear-gradient(to bottom,transparent 0%,rgba(7,7,14,.4) 55%,#07070e 100%)}
.now-playing.playing .np-art.eq3d-ready::before{opacity:1}
/* когда 3D активен — CSS-бары не нужны (остаются фолбэком, если three.js не загрузился) */
.np-art.eq3d-ready .np-art-eq{display:none!important}
.viz{width:100%;height:46px;display:block;margin:6px 0 14px;opacity:.9}
.np-label{font-family:var(--mono);font-size:.68rem;letter-spacing:.22em;text-transform:uppercase;color:var(--cyan)}
.np-title{font-family:var(--mono);font-size:1.3rem;font-weight:700;margin-top:6px;line-height:1.15}
.np-artist{color:var(--muted);font-size:.88rem;font-family:var(--mono)}
.np-progress{display:flex;align-items:center;gap:12px;margin:18px 0}
.np-time{font-family:var(--mono);font-size:.74rem;color:var(--muted);font-variant-numeric:tabular-nums;min-width:34px;text-align:center}
.np-bar{position:relative;flex:1;height:4px;background:var(--line-2);border-radius:0;cursor:pointer}
.np-bar:focus-visible{outline:2px solid var(--cyan);outline-offset:4px}
.np-bar-fill{height:100%;width:0;background:var(--cyan)}
.np-bar-knob{position:absolute;top:50%;left:0;width:11px;height:11px;border-radius:50%;background:#fff;transform:translate(-50%,-50%);opacity:0;transition:opacity .2s}
.np-bar:hover .np-bar-knob,.np-bar:focus-visible .np-bar-knob{opacity:1}
.np-controls{display:flex;align-items:center;justify-content:center;gap:16px}
.ctrl{width:46px;height:46px;border-radius:50%;display:grid;place-items:center;color:var(--fg);border:1px solid transparent;transition:transform .2s var(--ease),background .2s,border-color .2s}
.ctrl:hover,.ctrl:focus-visible{border-color:var(--line-2)}
.ctrl:active{transform:scale(.92)}
.ctrl-play{width:60px;height:60px;background:var(--fg);color:#0a0818;border-radius:50%}
.ctrl-play:hover,.ctrl-play:focus-visible{background:var(--cyan);color:#03121a;transform:scale(1.05)}
.ctrl-sm{width:40px;height:40px;color:var(--muted)}
.ctrl-sm[aria-pressed="true"]{color:var(--cyan)}

/* track grid — covers forward */
.track-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:clamp(12px,1.4vw,20px)}
.track-card{position:relative;cursor:pointer;transition:transform .25s var(--ease)}
.track-card:hover{will-change:transform}
.track-card:focus-visible{outline:2px solid var(--cyan);outline-offset:4px}
.card-art{position:relative;aspect-ratio:1;border-radius:var(--r);overflow:hidden;background:var(--art);border:1px solid var(--line)}
.card-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;transition:transform .5s var(--ease),filter .3s}
.track-card:hover .card-img{transform:scale(1.06)}
.card-art::before{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,transparent 45%,rgba(4,3,12,.8))}
.card-art::after{content:"";position:absolute;inset:0;z-index:1;border:1px solid transparent;transition:border-color .25s;border-radius:var(--r)}
.track-card:hover .card-art::after,.track-card.active .card-art::after{border-color:var(--cyan)}
.card-play{position:absolute;right:12px;bottom:12px;z-index:2;width:46px;height:46px;border-radius:50%;display:grid;place-items:center;
  background:var(--cyan);color:#03121a;opacity:0;transform:translateY(8px);transition:.25s var(--ease)}
.track-card:hover .card-play,.track-card.active .card-play{opacity:1;transform:none}
.card-eq{position:absolute;left:12px;bottom:16px;z-index:2;display:none;gap:3px;align-items:flex-end;height:18px}
.card-eq i{width:3px;height:100%;transform-origin:bottom;background:var(--cyan);animation:eqbar 1s infinite ease-in-out}
.card-eq i:nth-child(2){animation-delay:-.3s}.card-eq i:nth-child(3){animation-delay:-.6s}.card-eq i:nth-child(4){animation-delay:-.15s}
.track-card.playing .card-eq{display:flex}
.card-meta{padding:12px 2px 0;display:flex;align-items:baseline;justify-content:space-between;gap:10px}
.card-title{min-width:0;font-family:var(--mono);font-weight:600;font-size:.96rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.track-card.active .card-title{color:var(--cyan)}
.card-row{display:flex;flex-direction:column;align-items:flex-end;gap:2px;flex:none}
.card-tag{font-family:var(--mono);font-size:.66rem;letter-spacing:.12em;color:var(--faint)}
.card-dur{font-family:var(--mono);font-size:.78rem;color:var(--muted);font-variant-numeric:tabular-nums}

/* ============ STATS ============ */
.stats-band{max-width:var(--maxw);margin:0 auto;padding:0 clamp(16px,5vw,56px);
  display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.stat{padding:38px 18px;border-left:1px solid var(--line)}
.stat:first-child{border-left:none}
.stat strong{display:block;font-family:var(--display);font-size:clamp(2.2rem,4.5vw,3.4rem);line-height:1;
  background:linear-gradient(150deg,#fff,var(--cyan));-webkit-background-clip:text;background-clip:text;color:transparent;font-variant-numeric:tabular-nums}
.stat span{display:block;margin-top:12px;font-family:var(--mono);font-size:.72rem;letter-spacing:.14em;color:var(--muted);text-transform:uppercase}

/* ============ PROCESS ============ */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2vw,28px);counter-reset:step}
.step{padding:32px 28px;border:1px solid var(--line);border-radius:var(--r-lg);background:var(--panel);position:relative;overflow:hidden;transition:border-color .25s}
.step:hover{border-color:var(--line-2)}
.step-num{font-family:var(--display);font-size:3.4rem;line-height:1;color:transparent;-webkit-text-stroke:1px var(--line-2);display:block;margin-bottom:16px}
.step-ic{display:none}
.step h3{font-family:var(--mono);font-size:1.18rem;font-weight:600;margin-bottom:10px}
.step p{color:var(--muted);font-weight:300;font-size:.96rem}

/* ============ ABOUT ============ */
.about-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(32px,5vw,64px);align-items:center}
.about-text .section-title{margin-top:14px}
.about-text p{color:var(--muted);font-weight:300;margin-top:18px;font-size:1.05rem}
.tags{display:flex;flex-wrap:wrap;gap:10px;margin-top:28px}
.tags span{font-family:var(--mono);font-size:.78rem;letter-spacing:.06em;padding:8px 14px;border:1px solid var(--line);border-radius:999px;color:var(--muted);transition:.2s}
.tags span:hover{color:var(--cyan);border-color:var(--cyan)}
.about-visual{aspect-ratio:1;position:relative;display:grid;place-items:center;overflow:hidden;min-height:300px;border:1px solid var(--line);border-radius:var(--r-lg)}
.orb{width:110px;height:110px;border-radius:50%;background:radial-gradient(circle at 32% 30%,var(--cyan),var(--violet) 55%,var(--magenta));box-shadow:0 0 70px rgba(139,92,255,.5);animation:float 7s infinite ease-in-out}
.ring{position:absolute;border-radius:50%;border:1px solid var(--line-2)}
.ring-1{width:190px;height:190px;animation:spin 18s linear infinite}
.ring-2{width:290px;height:290px;border-style:dashed;animation:spin 26s linear infinite reverse}
.ring-3{width:390px;height:390px;border-color:var(--line);animation:spin 36s linear infinite}

/* ============ CHAT ============ */
.chat{max-width:800px;margin:0 auto;border:1px solid var(--line);border-radius:var(--r-lg);background:var(--panel);padding:24px;display:flex;flex-direction:column;gap:16px}
.chat-feed{display:flex;flex-direction:column;gap:12px;max-height:min(60vh,480px);overflow-y:auto;padding:6px 6px 2px;scrollbar-width:thin}
.chat-feed::-webkit-scrollbar{width:5px}.chat-feed::-webkit-scrollbar-thumb{background:var(--line-2)}
.msg{display:flex;flex-direction:column;gap:4px;max-width:80%;align-self:flex-start;animation:rise .3s var(--ease) both}
.msg.mine{align-self:flex-end;align-items:flex-end}
.msg-head{display:flex;gap:8px;align-items:baseline;font-family:var(--mono);font-size:.74rem}
.msg-name{font-weight:600;color:var(--cyan)}
.msg.mine .msg-name{color:var(--magenta)}
.msg-time{color:var(--faint)}
.msg-body{padding:11px 15px;border-radius:var(--r);background:rgba(255,255,255,.04);border:1px solid var(--line);word-break:break-word;font-size:.95rem}
.msg.mine .msg-body{background:rgba(41,224,255,.1);border-color:rgba(41,224,255,.3)}
.chat-empty{text-align:center;color:var(--muted);padding:32px;font-weight:300}
.chat-form{display:flex;flex-direction:column;gap:10px;border-top:1px solid var(--line);padding-top:16px}
.chat-name{max-width:220px}
.chat-row{display:flex;gap:10px}
.chat-input,.chat-name{flex:1;padding:13px 15px;border-radius:var(--r);font-size:.95rem;background:rgba(255,255,255,.03);
  border:1px solid var(--line);color:var(--fg);transition:border-color .2s;min-height:46px}
.chat-input:focus,.chat-name:focus{outline:none;border-color:var(--cyan)}
.chat-input::placeholder,.chat-name::placeholder{color:var(--faint)}
.chat-send{padding:13px 18px;flex:none}

/* ============ CONTACT ============ */
.section-contact{text-align:center}
.contact{max-width:760px;margin:0 auto}
.contact .kicker{margin-bottom:14px}
.contact .section-title{margin:0 auto}
.contact .section-desc{margin:16px auto 0}
.contact-links{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-top:34px}
.clink{display:flex;align-items:center;gap:10px;padding:13px 22px;border:1px solid var(--line);border-radius:999px;
  font-family:var(--mono);font-size:.84rem;color:var(--muted);transition:.2s var(--ease)}
.clink:hover,.clink:focus-visible{color:var(--cyan);border-color:var(--cyan)}
.footer{margin-top:56px;display:flex;gap:10px;justify-content:center;align-items:center;color:var(--faint);font-family:var(--mono);font-size:.78rem;letter-spacing:.08em}
.footer-dot{opacity:.5}

/* ============ MINI PLAYER ============ */
.mini{position:fixed;left:50%;bottom:18px;transform:translate(-50%,160%);z-index:90;display:flex;align-items:center;gap:14px;
  padding:9px 18px 9px 9px;border-radius:999px;width:min(440px,92vw);background:rgba(10,8,22,.94);
  -webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--line-2);transition:transform .4s var(--ease)}
.mini.show{transform:translate(-50%,0)}
.mini-play{width:42px;height:42px;flex:none;border-radius:50%;display:grid;place-items:center;background:var(--cyan);color:#03121a}
.mini-info{flex:1;min-width:0;display:flex;flex-direction:column;line-height:1.25;font-family:var(--mono)}
.mini-info strong{font-size:.88rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mini-info span{font-size:.72rem;color:var(--muted)}
.mini-bar{position:absolute;left:0;bottom:0;width:100%;height:2px;background:var(--line);overflow:hidden}
.mini-fill{height:100%;width:0;background:var(--cyan)}

/* ============ animations (transform/opacity only) ============ */
@keyframes rise{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:none}}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(6px)}}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.25}}
@keyframes eqbar{0%,100%{transform:scaleY(.16)}50%{transform:scaleY(1)}}
@keyframes float{0%,100%{transform:translateY(-12px)}50%{transform:translateY(12px)}}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes scroll-x{to{transform:translateX(-50%)}}
.reveal{opacity:0;transform:translateY(30px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}
/* sticky-элемент не двигаем трансформом — только лёгкий fade, иначе дёргает скролл */
.now-playing.reveal{transform:none}

/* ============ responsive ============ */
@media(max-width:1024px){.track-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:920px){
  .player-wrap{grid-template-columns:1fr}
  .now-playing{position:static;max-width:420px}
  .steps{grid-template-columns:1fr}
  .stats-band{grid-template-columns:repeat(2,1fr)}
  .stat:nth-child(3){border-left:none}.stat:nth-child(3),.stat:nth-child(4){border-top:1px solid var(--line)}
  .about-grid{grid-template-columns:1fr;gap:36px}
  .about-visual{max-width:320px;margin:0 auto;width:100%}
}
@media(max-width:680px){
  .nav-links{position:fixed;inset:66px 0 auto;flex-direction:column;gap:0;background:rgba(6,5,16,.98);
    -webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:8px 0;border-bottom:1px solid var(--line);
    transform:translateY(-130%);transition:transform .35s var(--ease)}
  .nav-links.open{transform:none}
  .nav-links a{padding:16px 28px;width:100%}
  .nav-links a::after{display:none}
  .nav-toggle{display:flex}
  /* hero: естественный поток, без обрезки верха под шапкой */
  .hero{align-items:flex-start;min-height:auto;padding:118px 18px 72px}
  .hero-sub{max-width:none}
  .hero-cta{width:100%}
  .hero-cta .btn{flex:1 1 auto;justify-content:center}
  .hero-eq{margin-top:44px;height:40px}
  .track-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .chat-name{max-width:none}
  .scroll-hint{display:none}
}
/* очень узкие телефоны (≤360px) */
@media(max-width:360px){
  .track-grid{grid-template-columns:minmax(0,1fr)}
  .nav{padding:16px 16px}
}
/* элемент за пределами экрана — его анимации замораживаются (ноль нагрузки при скролле) */
.anim-pause,.anim-pause *{animation-play-state:paused!important}

/* очень широкие мониторы — контент не растягивается, остаётся читаемым по центру */
@media(min-width:1700px){ :root{--maxw:1360px} }
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}
}
