/* =========================================================
   biolink — dark neon glass
   Bricolage Grotesque (display) · Manrope (body) · JetBrains Mono (mono)
   ========================================================= */

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

:root{
  --bg:#05050a;
  --mono:'JetBrains Mono',ui-monospace,monospace;
  --display:'Bricolage Grotesque',serif;
  --body:'Manrope',system-ui,sans-serif;
}

html,body{height:100%}
body{
  font-family:var(--body);
  background:var(--bg);
  color:var(--text);
  overflow:hidden;
  min-height:100svh;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

/* ---------------- ФОН ---------------- */
.bg-layer{position:fixed;inset:0;z-index:0;overflow:hidden}
.bg-media{position:absolute;inset:-4%;width:108%;height:108%;
  background-size:cover;background-position:center;
  filter:blur(var(--bg-blur));transform:scale(1.04)}
video.bg-media{object-fit:cover}
.bg-gradient{
  background:
    radial-gradient(60% 80% at 15% 10%, color-mix(in srgb,var(--accent) 55%, transparent), transparent 60%),
    radial-gradient(55% 70% at 85% 90%, color-mix(in srgb,var(--accent2) 50%, transparent), transparent 60%),
    radial-gradient(40% 50% at 90% 10%, color-mix(in srgb,var(--accent2) 30%, transparent), transparent 60%),
    linear-gradient(135deg,#07060f,#0a0814 40%,#05060d);
  animation:bgShift 18s ease-in-out infinite alternate;
}
@keyframes bgShift{
  0%{filter:hue-rotate(0deg) saturate(1)}
  100%{filter:hue-rotate(24deg) saturate(1.15)}
}
.bg-overlay{position:absolute;inset:0;
  background:radial-gradient(120% 120% at 50% 40%, transparent, rgba(0,0,0,.65) 100%);
  opacity:var(--bg-overlay)}
.bg-overlay::after{content:"";position:absolute;inset:0;
  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='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.45'/%3E%3C/svg%3E");
  opacity:.04;mix-blend-mode:overlay;pointer-events:none}

#particles{position:fixed;inset:0;z-index:1;pointer-events:none}

#cursor-glow{position:fixed;top:0;left:0;width:520px;height:520px;z-index:1;
  margin:-260px 0 0 -260px;border-radius:50%;pointer-events:none;
  background:radial-gradient(circle, color-mix(in srgb,var(--accent) 22%, transparent), transparent 65%);
  opacity:0;transition:opacity .4s;will-change:transform;mix-blend-mode:screen}

/* ---------------- ЭКРАН ВХОДА ---------------- */
.enter{position:fixed;inset:0;z-index:50;display:grid;place-items:center;
  background:rgba(3,3,8,.55);backdrop-filter:blur(22px) saturate(1.2);
  cursor:pointer;transition:opacity .8s ease, backdrop-filter .8s ease}
.enter.hide{opacity:0;backdrop-filter:blur(0);pointer-events:none}
.enter-inner{position:relative;display:grid;place-items:center;text-align:center}
.enter-ring{position:absolute;width:160px;height:160px;border-radius:50%;
  border:1px solid color-mix(in srgb,var(--accent) 60%, transparent);
  box-shadow:0 0 60px -10px var(--accent);animation:pulse 2.4s ease-in-out infinite}
@keyframes pulse{0%,100%{transform:scale(1);opacity:.7}50%{transform:scale(1.12);opacity:1}}
.enter-text{font-family:var(--mono);font-size:13px;letter-spacing:.42em;
  text-transform:uppercase;padding-left:.42em;color:var(--text);
  animation:flick 2.4s ease-in-out infinite}
@keyframes flick{0%,100%{opacity:.55}50%{opacity:1}}

/* ---------------- СЦЕНА / КАРТОЧКА ---------------- */
.stage{position:relative;z-index:2;min-height:100svh;display:grid;place-items:center;
  padding:28px;perspective:1400px}

.card{
  position:relative;width:min(420px,92vw);
  padding:38px 30px 24px;
  border-radius:var(--rounded);
  background:color-mix(in srgb, #0c0b18 var(--card-op), rgba(255,255,255,.02));
  background:linear-gradient(160deg,
     rgba(255,255,255,calc(var(--card-op) * .16)),
     rgba(12,11,24,calc(.4 + var(--card-op) * .5)));
  backdrop-filter:blur(var(--card-blur)) saturate(1.3);
  -webkit-backdrop-filter:blur(var(--card-blur)) saturate(1.3);
  border:1px solid rgba(255,255,255,.08);
  text-align:center;
  transform-style:preserve-3d;
  transition:transform .15s ease-out;
  opacity:0;animation:cardIn 1s cubic-bezier(.2,.9,.25,1) .15s forwards;
}
body.loading .card{animation:none;opacity:0}
@keyframes cardIn{from{opacity:0;transform:translateY(26px) scale(.96)}to{opacity:1;transform:none}}

.card-shine{position:absolute;inset:0;border-radius:inherit;pointer-events:none;
  background:linear-gradient(105deg,transparent 30%, rgba(255,255,255,.10) 48%, transparent 60%);
  background-size:240% 240%;background-position:var(--sx,150%) 0;transition:background-position .2s;
  opacity:.7;mix-blend-mode:overlay}

.card>*{transform:translateZ(28px)}
.card-shine,.card-foot{transform:none}

/* avatar */
.avatar-wrap{position:relative;width:118px;height:118px;margin:0 auto 18px}
.avatar{width:100%;height:100%;border-radius:50%;object-fit:cover;display:block;
  border:3px solid rgba(255,255,255,.12);position:relative;z-index:2}
.avatar-placeholder{display:grid;place-items:center;font-family:var(--display);
  font-size:46px;font-weight:800;color:#fff;
  background:linear-gradient(135deg,var(--accent),var(--accent2))}
.avatar-ring{position:absolute;inset:-7px;border-radius:50%;z-index:1;
  background:conic-gradient(from 0deg,var(--accent),var(--accent2),var(--accent));
  filter:blur(3px);opacity:.9;animation:spin 6s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* username */
.username{font-family:var(--display);font-weight:800;font-size:30px;line-height:1.1;
  letter-spacing:-.02em;display:inline-flex;align-items:center;gap:8px;justify-content:center;
  background:linear-gradient(120deg,#fff,var(--accent2),var(--accent));
  background-size:200% auto;-webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;animation:shimmer 6s linear infinite}
@keyframes shimmer{to{background-position:200% center}}

.badges{display:inline-flex;gap:4px;vertical-align:middle}
.badge{width:20px;height:20px;display:inline-grid;place-items:center}
.badge svg{width:18px;height:18px}
.badge-verified{color:var(--accent2)}
.badge-staff{color:#5865f2}
.badge-premium{color:#ffb43d}
.badge-developer{color:#3ad07a}
.badge-og{color:#ff5d7a}

.subtitle{font-family:var(--mono);font-size:12.5px;color:rgba(244,244,248,.55);
  margin-top:6px;letter-spacing:.04em}

.bio{margin:16px auto 4px;max-width:34ch;font-size:14.5px;line-height:1.6;
  color:rgba(244,244,248,.82);min-height:1.6em}
.bio .caret{display:inline-block;width:.6ch;color:var(--accent);animation:flick 1s steps(1) infinite}

/* social links */
.links{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;margin:22px 0 6px}
.social{width:42px;height:42px;display:grid;place-items:center;border-radius:13px;
  color:rgba(244,244,248,.8);
  background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);
  transition:transform .25s cubic-bezier(.2,.9,.3,1.4),background .25s,color .25s,box-shadow .25s;
  opacity:0;animation:popIn .5s ease forwards;animation-delay:calc(.5s + var(--d))}
@keyframes popIn{from{opacity:0;transform:translateY(10px) scale(.8)}to{opacity:1;transform:none}}
.social svg{width:20px;height:20px}
.social:hover{transform:translateY(-5px) scale(1.08);color:#fff;
  background:linear-gradient(135deg,var(--accent),var(--accent2));
  box-shadow:0 10px 28px -8px var(--accent)}

/* discord card */
.discord-card{display:flex;align-items:center;gap:12px;margin:20px 0 0;padding:12px 14px;
  border-radius:16px;text-align:left;
  background:rgba(88,101,242,.10);border:1px solid rgba(88,101,242,.25);
  opacity:0;animation:fadeUp .6s ease .7s forwards}
@keyframes fadeUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
.discord-card[data-loading="1"]{opacity:.5}
.dc-avatar-wrap{position:relative;flex:0 0 auto}
.dc-avatar{width:44px;height:44px;border-radius:50%;object-fit:cover;background:#1c1c28}
.dc-status{position:absolute;right:-2px;bottom:-2px;width:15px;height:15px;border-radius:50%;
  border:3px solid #14131f;background:#747f8d}
.dc-status.online{background:#3ba55d}.dc-status.idle{background:#faa61a}
.dc-status.dnd{background:#ed4245}.dc-status.offline{background:#747f8d}
.dc-body{flex:1;min-width:0}
.dc-name{font-weight:700;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dc-activity{display:flex;align-items:center;gap:6px;font-size:12px;color:rgba(244,244,248,.6);font-family:var(--mono);min-width:0}
.dc-activity span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dc-act-icon{width:16px;height:16px;border-radius:4px;object-fit:cover;flex:0 0 auto}
.dc-logo{color:#5865f2;flex:0 0 auto}.dc-logo svg{width:22px;height:22px}

/* spotify */
.spotify-card{display:none;gap:12px;align-items:center;margin-top:10px;padding:10px 12px;
  border-radius:16px;text-align:left;
  background:rgba(30,215,96,.08);border:1px solid rgba(30,215,96,.22)}
.spotify-card.show{display:flex}
.sp-art{width:48px;height:48px;border-radius:8px;object-fit:cover;flex:0 0 auto}
.sp-body{flex:1;min-width:0}
.sp-label{display:flex;align-items:center;gap:5px;font-size:10px;color:#1ed760;
  text-transform:uppercase;letter-spacing:.08em;font-family:var(--mono)}
.sp-label svg{width:13px;height:13px}
.sp-song{font-weight:700;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sp-artist{font-size:11.5px;color:rgba(244,244,248,.6);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sp-bar{height:3px;border-radius:3px;background:rgba(255,255,255,.15);margin-top:6px;overflow:hidden}
.sp-bar span{display:block;height:100%;width:0;background:#1ed760;transition:width 1s linear}

.card-foot{margin-top:18px;padding-top:14px;border-top:1px solid rgba(255,255,255,.06);
  display:flex;justify-content:center}
.views{display:inline-flex;align-items:center;gap:6px;font-family:var(--mono);font-size:12px;
  color:rgba(244,244,248,.5)}

/* ---------------- ПЛЕЕР ---------------- */
.player{position:fixed;left:20px;bottom:20px;z-index:30;display:flex;align-items:center;gap:12px;
  padding:10px 14px 10px 10px;border-radius:18px;max-width:330px;
  background:rgba(12,11,24,.6);backdrop-filter:blur(20px);
  border:1px solid rgba(255,255,255,.08);box-shadow:0 16px 40px -16px #000;
  opacity:0;transform:translateY(20px);transition:opacity .6s ease,transform .6s ease}
.player.show{opacity:1;transform:none}
.player-btn{width:42px;height:42px;flex:0 0 auto;border:none;border-radius:50%;cursor:pointer;
  display:grid;place-items:center;color:#fff;
  background:linear-gradient(135deg,var(--accent),var(--accent2));
  box-shadow:0 8px 20px -6px var(--accent);transition:transform .2s}
.player-btn:hover{transform:scale(1.07)}
.player-btn svg{width:20px;height:20px;grid-area:1/1}
.player-btn .ic-pause{display:none}
.player-btn.playing .ic-play{display:none}
.player-btn.playing .ic-pause{display:block}
.player-meta{min-width:0;flex:1}
.player-title{font-weight:700;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.player-artist{font-size:11px;color:rgba(244,244,248,.55);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.player-bar{height:4px;border-radius:4px;background:rgba(255,255,255,.14);margin-top:6px;cursor:pointer;overflow:hidden}
.player-bar span{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--accent),var(--accent2))}
.player-vol{display:flex;align-items:center;gap:6px;flex:0 0 auto;color:rgba(244,244,248,.7)}
.player-vol input[type=range]{-webkit-appearance:none;appearance:none;width:64px;height:4px;border-radius:4px;
  background:rgba(255,255,255,.18);outline:none;cursor:pointer}
.player-vol input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:13px;height:13px;border-radius:50%;
  background:var(--accent2);box-shadow:0 0 8px var(--accent2);cursor:pointer}
.player-vol input[type=range]::-moz-range-thumb{width:13px;height:13px;border:none;border-radius:50%;background:var(--accent2)}

.admin-link{position:fixed;right:16px;bottom:16px;z-index:30;width:34px;height:34px;
  display:grid;place-items:center;border-radius:10px;text-decoration:none;font-size:15px;
  color:rgba(244,244,248,.35);background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.06);transition:all .25s}
.admin-link:hover{color:#fff;transform:rotate(60deg)}

@media (max-width:480px){
  .card{padding:32px 22px 20px}
  .username{font-size:26px}
  .player{left:12px;right:12px;bottom:12px;max-width:none}
  .player-vol{display:none}
}

@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001s !important;animation-iteration-count:1 !important}
}
