/* Malich Experience — flagship site. Tokens from ../styles.css */
:root{ --xp-nav-h:70px; }
*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{ margin:0; background:var(--navy-900); color:var(--text-body); font-family:var(--font-body);
  overflow-x:hidden; }
::selection{ background:rgba(255,63,175,.35); color:#fff; }

/* scrollbar */
body::-webkit-scrollbar{ width:10px; }
body::-webkit-scrollbar-track{ background:var(--navy-900); }
body::-webkit-scrollbar-thumb{ background:var(--navy-600); border-radius:10px; }
body::-webkit-scrollbar-thumb:hover{ background:var(--navy-500); }

.xp{ position:relative; }
.xp-grad-text{ background:var(--grad-logo); -webkit-background-clip:text; background-clip:text; color:transparent; }
.xp-eyebrow{ font-family:var(--font-logo); font-size:11px; letter-spacing:.22em; text-transform:uppercase; color:var(--neon-pink-bright); }

/* ---------- NAV ---------- */
.xp-nav{ position:fixed; inset:0 0 auto 0; height:var(--xp-nav-h); z-index:60; display:flex; align-items:center;
  justify-content:space-between; padding:0 clamp(18px,4vw,46px); transition:background .3s, border-color .3s, backdrop-filter .3s;
  border-bottom:1px solid transparent; }
.xp-nav.scrolled{ background:rgba(5,9,24,.72); backdrop-filter:blur(16px); -webkit-backdrop-filter:blur(16px); border-bottom-color:var(--border-subtle); }
.xp-logo{ display:flex; align-items:center; gap:11px; cursor:pointer; }
.xp-logo__word{ font-family:var(--font-logo); font-size:22px; letter-spacing:.08em; }
.xp-nav__links{ display:flex; gap:30px; }
.xp-nav__links a{ font-family:var(--font-body); font-weight:600; font-size:14px; color:var(--ink-200); position:relative; transition:color .2s; }
.xp-nav__links a:hover{ color:#fff; }
.xp-nav__links a::after{ content:""; position:absolute; left:0; bottom:-6px; width:0; height:2px; background:var(--grad-pink-blue); transition:width .25s var(--ease-out); border-radius:2px; }
.xp-nav__links a:hover::after{ width:100%; }
.xp-nav__cta{ display:flex; align-items:center; gap:12px; }

/* generic neon button */
.xp-btn{ font-family:var(--font-heading); font-weight:700; letter-spacing:.02em; border:1px solid transparent;
  border-radius:999px; cursor:pointer; display:inline-flex; align-items:center; gap:9px; white-space:nowrap;
  transition:transform .13s var(--ease-out), box-shadow .25s, background .25s, color .2s; }
.xp-btn--primary{ background:var(--grad-pink-blue); color:#0a0f22; box-shadow:var(--glow-pink-sm); }
.xp-btn--primary:hover{ transform:translateY(-2px); box-shadow:var(--glow-pink-md), var(--glow-blue-sm); }
.xp-btn--primary:active{ transform:translateY(0) scale(.97); }
.xp-btn--ghost{ background:rgba(57,199,255,.05); color:#fff; border-color:var(--electric-blue); }
.xp-btn--ghost:hover{ background:rgba(57,199,255,.14); box-shadow:var(--glow-blue-sm); transform:translateY(-2px); }
.xp-btn--lg{ font-size:16px; padding:15px 30px; }
.xp-btn--sm{ font-size:13px; padding:10px 18px; }

/* ---------- HERO ---------- */
.xp-hero{ position:relative; min-height:100vh; display:flex; align-items:center; overflow:hidden; }
.xp-hero__sky{ position:absolute; inset:-8% 0 0 0; background-size:cover; background-position:center 30%; opacity:.42;
  transform:scale(1.06); will-change:transform; }
.xp-hero__scrim{ position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(5,9,24,.55) 0%, rgba(5,9,24,.25) 35%, rgba(7,13,38,.85) 78%, var(--navy-900) 100%); }
.xp-hero__sun{ position:absolute; left:50%; top:34%; width:min(640px,84vw); aspect-ratio:1; transform:translate(-50%,-50%);
  background:radial-gradient(circle, rgba(255,63,175,.42) 0%, rgba(166,91,255,.22) 38%, transparent 66%); filter:blur(8px); }
.xp-floor{ position:absolute; left:-30%; right:-30%; bottom:0; height:42vh;
  background-image:linear-gradient(rgba(255,63,175,.55) 1px, transparent 1px), linear-gradient(90deg, rgba(57,199,255,.45) 1px, transparent 1px);
  background-size:60px 60px; transform:perspective(380px) rotateX(64deg); transform-origin:bottom;
  mask:linear-gradient(transparent, #000 55%); -webkit-mask:linear-gradient(transparent, #000 55%);
  animation:xp-floor 5s linear infinite; opacity:.6; }
@keyframes xp-floor{ from{ background-position-y:0; } to{ background-position-y:60px; } }

.xp-hero__inner{ position:relative; z-index:5; width:100%; max-width:1180px; margin:0 auto; padding:120px clamp(20px,5vw,46px) 60px; }
.xp-hero__badge{ display:inline-flex; align-items:center; gap:9px; padding:7px 15px; border-radius:999px;
  background:rgba(255,63,175,.12); border:1px solid rgba(255,63,175,.4); margin-bottom:26px;
  font-family:var(--font-logo); font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:#fff; }
.xp-hero__badge i{ width:7px; height:7px; border-radius:50%; background:var(--neon-pink); box-shadow:0 0 8px var(--neon-pink); animation:xp-pulse 1.6s ease-in-out infinite; }
@keyframes xp-pulse{ 0%,100%{ opacity:1; } 50%{ opacity:.3; } }

.xp-hero__title{ font-family:var(--font-display); font-weight:900; font-size:clamp(62px, 13vw, 184px); line-height:.86;
  letter-spacing:-.03em; margin:0; color:#fff;
  background:var(--grad-logo); -webkit-background-clip:text; background-clip:text; color:transparent;
  filter:drop-shadow(0 0 50px rgba(255,63,175,.4)); animation:xp-glow 4s ease-in-out infinite; }
@keyframes xp-glow{ 0%,100%{ filter:drop-shadow(0 0 40px rgba(255,63,175,.32)); } 50%{ filter:drop-shadow(0 0 70px rgba(57,199,255,.42)); } }
.xp-hero__sub{ font-family:var(--font-body); font-size:clamp(16px,2vw,21px); color:var(--ink-200); max-width:540px;
  line-height:1.6; margin:26px 0 0; }
.xp-hero__cta{ display:flex; gap:14px; margin-top:36px; flex-wrap:wrap; }
.xp-hero__stats{ display:flex; gap:clamp(24px,5vw,56px); margin-top:48px; flex-wrap:wrap; }
.xp-hero__stats div{ display:flex; flex-direction:column; }
.xp-hero__stats b{ font-family:var(--font-display); font-weight:800; font-size:clamp(22px,3vw,32px); color:#fff; }
.xp-hero__stats span{ font-size:12px; color:var(--ink-300); letter-spacing:.05em; margin-top:2px; }

.xp-hero__viz{ position:absolute; left:0; bottom:0; width:300px; height:140px; z-index:3; opacity:.9;
  mask:linear-gradient(90deg, transparent, #000 12%, #000 88%, transparent); -webkit-mask:linear-gradient(90deg, transparent, #000 12%, #000 88%, transparent); }
.xp-hero__viz--right{ left:auto; right:0; transform:scaleX(-1); }   /* spiegelverkehrt auf der rechten Seite */
.xp-scroll{ position:absolute; left:50%; bottom:24px; transform:translateX(-50%); z-index:6; display:flex; flex-direction:column; align-items:center; gap:7px;
  font-family:var(--font-logo); font-size:9px; letter-spacing:.2em; text-transform:uppercase; color:var(--ink-400); }
.xp-scroll i{ width:20px; height:32px; border:1.5px solid var(--ink-400); border-radius:12px; position:relative; }
.xp-scroll i::after{ content:""; position:absolute; left:50%; top:6px; width:3px; height:6px; background:var(--neon-pink); border-radius:2px; transform:translateX(-50%); animation:xp-scrolldot 1.6s ease-in-out infinite; }
@keyframes xp-scrolldot{ 0%{ opacity:0; top:6px; } 40%{ opacity:1; } 100%{ opacity:0; top:18px; } }

/* ---------- SECTIONS ---------- */
.xp-section{ position:relative; max-width:1180px; margin:0 auto; padding:clamp(70px,10vw,120px) clamp(20px,5vw,46px); }
.xp-section__head{ margin-bottom:46px; }
.xp-section__title{ font-family:var(--font-display); font-weight:800; font-size:clamp(34px,5vw,58px); color:#fff; letter-spacing:-.02em; margin:12px 0 0; line-height:1; }
.xp-section__sub{ color:var(--ink-300); font-size:16px; margin-top:14px; max-width:540px; line-height:1.6; }

/* reveal */
.reveal{ opacity:0; transform:translateY(34px); transition:opacity .7s var(--ease-out), transform .7s var(--ease-out); }
.reveal.in{ opacity:1; transform:none; }
@media (prefers-reduced-motion: reduce){ .reveal{ opacity:1; transform:none; transition:none; } .xp-floor,.xp-hero__title{ animation:none; } }

/* ---------- TRACKS ---------- */
.xp-tracks{ display:flex; flex-direction:column; gap:12px; }
.xp-track{ display:grid; grid-template-columns:54px 1fr auto; align-items:center; gap:18px;
  padding:14px 18px 14px 14px; border-radius:var(--radius-lg); background:var(--surface-1);
  border:1px solid var(--border-subtle); cursor:pointer; transition:background .25s, border-color .25s, transform .2s; }
.xp-track:hover{ background:var(--surface-card); border-color:var(--border-strong); transform:translateX(4px); }
.xp-track.is-current{ border-color:var(--border-neon); background:linear-gradient(90deg, rgba(255,63,175,.10), rgba(57,199,255,.05)); box-shadow:var(--glow-pink-sm); }
.xp-track__play{ width:54px; height:54px; border-radius:50%; border:none; cursor:pointer; flex:none; position:relative;
  background:var(--grad-pink-blue-135); color:#0a0f22; display:flex; align-items:center; justify-content:center;
  box-shadow:var(--glow-pink-sm); transition:transform .15s var(--ease-snap); }
.xp-track__play:hover{ transform:scale(1.07); }
.xp-track__art{ position:absolute; inset:0; border-radius:50%; opacity:0; }
.xp-track__main{ min-width:0; }
.xp-track__title{ display:flex; align-items:center; gap:10px; }
.xp-track__title h3{ font-family:var(--font-heading); font-weight:700; font-size:18px; color:#fff; margin:0; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.xp-track__tag{ font-family:var(--font-logo); font-size:9px; letter-spacing:.12em; text-transform:uppercase; padding:3px 8px; border-radius:999px;
  background:var(--grad-pink-blue); color:#0a0f22; }
.xp-track__meta{ font-size:13px; color:var(--ink-300); margin-top:4px; display:flex; gap:8px; align-items:center; }
.xp-track__wave{ width:120px; height:30px; flex:none; }
.xp-track__actions{ display:flex; align-items:center; gap:6px; }
.xp-icon-btn{ width:40px; height:40px; border-radius:50%; border:none; background:transparent; color:var(--ink-300); cursor:pointer;
  display:flex; align-items:center; justify-content:center; transition:background .2s, color .2s, transform .15s; }
.xp-icon-btn:hover{ background:rgba(120,140,220,.12); color:#fff; }
.xp-icon-btn:active{ transform:scale(.9); }
.xp-icon-btn.liked{ color:var(--neon-pink); }
.xp-icon-btn.liked svg{ fill:var(--neon-pink); filter:drop-shadow(0 0 8px rgba(255,63,175,.7)); }
.xp-like-pop{ animation:xp-likepop .4s var(--ease-snap); }
@keyframes xp-likepop{ 0%{ transform:scale(1); } 40%{ transform:scale(1.4); } 100%{ transform:scale(1); } }
.xp-track__likes{ font-family:var(--font-mono); font-size:11px; color:var(--ink-400); min-width:34px; }
@keyframes xpbar{ 0%,100%{ transform:scaleY(.32); } 50%{ transform:scaleY(1); } }

/* ---------- LIBRARY (search / filter / sort / view) ---------- */
.xp-lib__bar{ display:flex; align-items:center; justify-content:space-between; gap:14px; flex-wrap:wrap; margin-bottom:18px; }
.xp-search{ display:flex; align-items:center; gap:10px; flex:1; min-width:220px; max-width:440px;
  padding:11px 15px; border-radius:999px; background:var(--surface-1); border:1px solid var(--border-subtle);
  color:var(--ink-300); transition:border-color .2s, box-shadow .2s; }
.xp-search:focus-within{ border-color:var(--border-neon); box-shadow:var(--glow-pink-sm); }
.xp-search input{ flex:1; min-width:0; background:transparent; border:none; outline:none; color:#fff;
  font-family:var(--font-body); font-size:14px; }
.xp-search input::placeholder{ color:var(--ink-400); }
.xp-search__clear{ display:flex; border:none; background:transparent; color:var(--ink-400); cursor:pointer; padding:0; }
.xp-search__clear:hover{ color:#fff; }
.xp-lib__tools{ display:flex; align-items:center; gap:10px; }
.xp-sort{ appearance:none; -webkit-appearance:none; padding:10px 34px 10px 14px; border-radius:999px; cursor:pointer;
  background:var(--surface-1) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%238ea0c8' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E") no-repeat right 13px center;
  border:1px solid var(--border-subtle); color:#fff; font-family:var(--font-body); font-size:13px; }
.xp-sort:hover{ border-color:var(--border-strong); }
.xp-sort option{ background:var(--navy-800, #0b1230); color:#fff; }
.xp-viewtoggle{ display:flex; border-radius:999px; background:var(--surface-1); border:1px solid var(--border-subtle); padding:3px; }
.xp-viewtoggle button{ display:flex; align-items:center; justify-content:center; width:38px; height:34px; border:none;
  background:transparent; color:var(--ink-400); cursor:pointer; border-radius:999px; transition:color .2s, background .2s; }
.xp-viewtoggle button:hover{ color:#fff; }
.xp-viewtoggle button.active{ background:var(--grad-pink-blue); color:#0a0f22; }

.xp-filterrow{ display:flex; align-items:baseline; gap:14px; margin-bottom:12px; }
.xp-filterrow__label{ flex:none; width:74px; font-family:var(--font-logo); font-size:10px; letter-spacing:.16em;
  text-transform:uppercase; color:var(--ink-400); padding-top:3px; }
.xp-chips{ display:flex; flex-wrap:wrap; gap:8px; }
.xp-chip{ padding:7px 14px; border-radius:999px; cursor:pointer; font-family:var(--font-body); font-size:13px;
  background:var(--surface-1); border:1px solid var(--border-subtle); color:var(--ink-200);
  transition:border-color .2s, background .2s, color .2s, transform .12s; }
.xp-chip:hover{ border-color:var(--border-strong); color:#fff; transform:translateY(-1px); }
.xp-chip.active{ background:var(--grad-pink-blue); border-color:transparent; color:#0a0f22; font-weight:600; box-shadow:var(--glow-pink-sm); }

.xp-lib__count{ display:flex; align-items:center; gap:14px; margin:20px 0 16px; font-size:13px; color:var(--ink-400); }
.xp-lib__reset{ border:none; background:transparent; color:var(--neon-pink-bright); cursor:pointer; font-size:13px; font-family:var(--font-body); }
.xp-lib__reset:hover{ text-decoration:underline; }
.xp-lib__empty{ padding:50px 20px; text-align:center; color:var(--ink-300); font-size:15px; }
.xp-lib__empty button{ border:none; background:transparent; color:var(--neon-pink-bright); cursor:pointer; font-size:15px; font-family:var(--font-body); }
.xp-lib__empty button:hover{ text-decoration:underline; }

/* grid of cover cards */
.xp-grid{ display:grid; grid-template-columns:repeat(auto-fill, minmax(190px, 1fr)); gap:18px; }
.xp-card{ background:var(--surface-1); border:1px solid var(--border-subtle); border-radius:var(--radius-lg);
  overflow:hidden; cursor:pointer; transition:transform .2s, border-color .25s, box-shadow .25s; }
.xp-card:hover{ transform:translateY(-4px); border-color:var(--border-strong); box-shadow:var(--shadow-xl); }
.xp-card.is-current{ border-color:var(--border-neon); box-shadow:var(--glow-pink-sm); }
.xp-card__cover{ position:relative; aspect-ratio:1; overflow:hidden; }
.xp-card__cover img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.xp-card__cover::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg, transparent 45%, rgba(5,9,24,.55)); }
.xp-card__tag{ position:absolute; top:10px; left:10px; z-index:2; font-family:var(--font-logo); font-size:9px;
  letter-spacing:.12em; text-transform:uppercase; padding:4px 9px; border-radius:999px; background:var(--grad-pink-blue); color:#0a0f22; }
.xp-card__play{ position:absolute; right:12px; bottom:12px; z-index:3; width:46px; height:46px; border-radius:50%; border:none;
  cursor:pointer; background:var(--grad-pink-blue); color:#0a0f22; display:flex; align-items:center; justify-content:center;
  box-shadow:var(--glow-pink-sm); opacity:0; transform:translateY(8px) scale(.85); transition:opacity .22s, transform .22s var(--ease-snap); }
.xp-card:hover .xp-card__play, .xp-card.is-current .xp-card__play{ opacity:1; transform:translateY(0) scale(1); }
.xp-card__play:hover{ transform:scale(1.08); }
.xp-card__eq{ position:absolute; left:12px; bottom:16px; z-index:3; display:flex; align-items:flex-end; gap:3px; height:18px; }
.xp-card__eq i{ width:3px; background:var(--neon-pink-bright); border-radius:2px; box-shadow:0 0 8px var(--neon-pink); animation:xp-eq 1s ease-in-out infinite; }
.xp-card__eq i:nth-child(1){ height:60%; animation-delay:-.2s; } .xp-card__eq i:nth-child(2){ height:100%; animation-delay:-.5s; }
.xp-card__eq i:nth-child(3){ height:45%; animation-delay:0s; } .xp-card__eq i:nth-child(4){ height:80%; animation-delay:-.35s; }
@keyframes xp-eq{ 0%,100%{ transform:scaleY(.35); } 50%{ transform:scaleY(1); } }
.xp-card__body{ padding:13px 14px 14px; }
.xp-card__body h3{ font-family:var(--font-heading); font-weight:700; font-size:15px; color:#fff; margin:0;
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.xp-card__meta{ font-size:12px; color:var(--ink-300); margin-top:4px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.xp-card__foot{ display:flex; align-items:center; justify-content:space-between; gap:8px; margin-top:10px; }
.xp-card__likes{ display:flex; align-items:center; gap:5px; font-family:var(--font-mono); font-size:11px; color:var(--ink-400); }
.xp-card__btns{ display:flex; gap:2px; }
/* info button on the cover (top-right, opposite the tag) */
.xp-card__info{ position:absolute; top:10px; right:10px; z-index:3; width:30px; height:30px; border-radius:50%;
  display:flex; align-items:center; justify-content:center; cursor:pointer; color:#fff;
  background:rgba(5,9,24,.62); border:1px solid rgba(255,255,255,.35); backdrop-filter:blur(6px); -webkit-backdrop-filter:blur(6px);
  box-shadow:0 2px 8px rgba(0,0,0,.35); transition:background .2s, transform .15s, border-color .2s; }
.xp-card__info:hover{ background:var(--neon-pink); border-color:var(--neon-pink); color:#0a0f22; transform:scale(1.08); }
.xp-card__btns .xp-icon-btn{ width:32px; height:32px; }

/* ---------- VIDEOS & REELS ---------- */
.xp-video{ position:relative; border-radius:var(--radius-xl, 20px); overflow:hidden; border:1px solid var(--border-strong);
  box-shadow:var(--shadow-xl); background:#000; }
.xp-video video{ display:block; width:100%; aspect-ratio:16/9; object-fit:cover; background:#000; }
.xp-video__cap{ position:absolute; left:0; right:0; bottom:0; padding:28px 20px 16px; pointer-events:none;
  font-family:var(--font-heading); font-weight:700; font-size:16px; color:#fff;
  background:linear-gradient(transparent, rgba(5,9,24,.8)); }

.xp-reels{ display:grid; grid-template-columns:repeat(auto-fill, minmax(190px, 1fr)); gap:18px; margin-top:26px; }
.xp-reel{ position:relative; padding:0; border:1px solid var(--border-subtle); border-radius:var(--radius-lg); overflow:hidden;
  cursor:pointer; background:#000; aspect-ratio:9/16; transition:transform .2s, border-color .25s, box-shadow .25s; }
.xp-reel:hover{ transform:translateY(-4px); border-color:var(--border-neon); box-shadow:var(--glow-pink-sm); }
.xp-reel__vid{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.xp-reel::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(5,9,24,.15) 0%, transparent 35%, rgba(5,9,24,.7)); }
.xp-reel__play{ position:absolute; left:50%; top:50%; transform:translate(-50%,-50%); z-index:2;
  width:54px; height:54px; border-radius:50%; background:var(--grad-pink-blue); color:#0a0f22;
  display:flex; align-items:center; justify-content:center; box-shadow:var(--glow-pink-sm);
  transition:transform .18s var(--ease-snap); }
.xp-reel:hover .xp-reel__play{ transform:translate(-50%,-50%) scale(1.12); }
.xp-reel__cap{ position:absolute; left:12px; right:12px; bottom:12px; z-index:2; text-align:left;
  font-family:var(--font-heading); font-weight:600; font-size:13px; color:#fff; }

/* reel lightbox */
.xp-reelmodal{ position:fixed; inset:0; z-index:100; display:flex; align-items:center; justify-content:center;
  padding:24px; background:rgba(3,6,18,.86); backdrop-filter:blur(8px); -webkit-backdrop-filter:blur(8px);
  animation:xp-fade .2s ease-out; }
@keyframes xp-fade{ from{ opacity:0; } to{ opacity:1; } }
.xp-reelmodal__vid{ max-height:88vh; max-width:min(440px, 94vw); aspect-ratio:9/16; width:auto;
  border-radius:var(--radius-lg); border:1px solid var(--border-neon); box-shadow:var(--glow-pink-md), var(--shadow-xl); background:#000; }
.xp-reelmodal__close{ position:absolute; top:20px; right:22px; width:44px; height:44px; border-radius:50%;
  border:1px solid var(--border-strong); background:rgba(5,9,24,.6); color:#fff; cursor:pointer;
  display:flex; align-items:center; justify-content:center; transition:background .2s, transform .15s; }
.xp-reelmodal__close:hover{ background:rgba(255,63,175,.2); transform:scale(1.05); }

/* ---------- HOME: featured + newest ---------- */
.xp-featgrid{ display:grid; grid-template-columns:1fr 1fr; gap:18px; margin-bottom:14px; }
.xp-feature{ display:grid; grid-template-columns:160px 1fr; gap:18px; align-items:center; padding:16px; cursor:pointer;
  border-radius:var(--radius-xl, 20px); border:1px solid var(--border-strong); position:relative; overflow:hidden;
  background:linear-gradient(135deg, rgba(255,63,175,.10), rgba(57,199,255,.06));
  transition:transform .2s, border-color .25s, box-shadow .25s; }
.xp-feature:hover{ transform:translateY(-4px); border-color:var(--border-neon); box-shadow:var(--glow-pink-sm); }
.xp-feature.is-current{ border-color:var(--border-neon); box-shadow:var(--glow-pink-md); }
.xp-feature__cover{ position:relative; width:160px; height:160px; flex:none; border-radius:var(--radius-md); overflow:hidden; }
.xp-feature__cover img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.xp-feature__cover .xp-card__eq{ left:12px; bottom:12px; }
.xp-feature__body{ min-width:0; }
.xp-feature__body h3{ font-family:var(--font-display); font-weight:800; font-size:clamp(20px,2.4vw,28px); color:#fff; margin:8px 0 0; line-height:1.05;
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.xp-feature__meta{ font-size:13px; color:var(--ink-300); margin-top:6px; }
.xp-feature__row{ display:flex; align-items:center; gap:8px; margin-top:16px; flex-wrap:wrap; }
.xp-feature__likes{ font-family:var(--font-mono); font-size:11px; color:var(--ink-400); margin-left:2px; }

.xp-subhead{ font-family:var(--font-heading); font-weight:700; font-size:18px; color:#fff; margin:34px 0 16px; display:flex; align-items:baseline; gap:10px; }
.xp-subhead span{ font-family:var(--font-body); font-weight:400; font-size:13px; color:var(--ink-400); }
.xp-morewrap{ display:flex; justify-content:center; margin-top:36px; }

/* newest-tracks row: exactly 5 across on desktop, fewer on smaller screens */
.xp-grid--row5{ grid-template-columns:repeat(5, 1fr); }
@media (max-width:1024px){ .xp-grid--row5{ grid-template-columns:repeat(3, 1fr); } }
@media (max-width:640px){ .xp-grid--row5{ grid-template-columns:repeat(2, 1fr); } }

/* ---------- MUSIC PAGE ---------- */
.xp-musicpage{ position:relative; min-height:100vh; }
.xp-musicpage__hero{ position:relative; overflow:hidden; padding:calc(var(--xp-nav-h) + 44px) 0 30px;
  border-bottom:1px solid var(--border-subtle); background:linear-gradient(180deg, rgba(255,63,175,.10), rgba(7,13,38,0) 72%); }
.xp-musicpage__grid-bg{ position:absolute; left:-30%; right:-30%; top:-40%; height:170%; opacity:.5;
  background-image:linear-gradient(rgba(255,63,175,.18) 1px, transparent 1px), linear-gradient(90deg, rgba(57,199,255,.16) 1px, transparent 1px);
  background-size:54px 54px; transform:perspective(420px) rotateX(58deg); transform-origin:top;
  mask:radial-gradient(70% 70% at 50% 0%, #000, transparent 75%); -webkit-mask:radial-gradient(70% 70% at 50% 0%, #000, transparent 75%); }
.xp-musicpage__inner{ position:relative; z-index:2; max-width:1180px; margin:0 auto; padding:0 clamp(20px,5vw,46px); }
.xp-crumbs{ display:flex; align-items:center; gap:9px; margin-bottom:22px; font-family:var(--font-logo); font-size:11px; letter-spacing:.14em; text-transform:uppercase; }
.xp-crumbs a{ color:var(--ink-300); transition:color .2s; }
.xp-crumbs a:hover{ color:#fff; }
.xp-crumbs span{ color:var(--ink-500, var(--ink-400)); }
.xp-crumbs b{ color:var(--neon-pink-bright); font-weight:700; }
.xp-musicpage__headrow{ display:flex; align-items:flex-end; justify-content:space-between; gap:20px; flex-wrap:wrap; }
.xp-back{ flex:none; }
.xp-musicpage__title{ font-family:var(--font-display); font-weight:900; font-size:clamp(40px,7vw,84px); line-height:.9; letter-spacing:-.03em; color:#fff; margin:10px 0 0; }
.xp-musicpage__sub{ color:var(--ink-300); font-size:16px; margin-top:14px; }
.xp-musicpage__body{ max-width:1180px; margin:0 auto; padding:32px clamp(20px,5vw,46px) 130px; }

/* ---------- TRACK INFO MODAL ---------- */
.xp-infomodal{ position:fixed; inset:0; z-index:100; display:flex; align-items:center; justify-content:center; padding:24px;
  background:rgba(3,6,18,.86); backdrop-filter:blur(8px); -webkit-backdrop-filter:blur(8px); animation:xp-fade .2s ease-out; }
.xp-infocard{ position:relative; display:grid; grid-template-columns:170px 1fr; gap:22px; align-items:center;
  width:min(560px, 94vw); padding:22px; border-radius:var(--radius-xl, 20px);
  background:var(--navy-800, #0b1230); border:1px solid var(--border-neon); box-shadow:var(--glow-pink-md), var(--shadow-xl); }
.xp-infocard__close{ position:absolute; top:12px; right:12px; width:36px; height:36px; border-radius:50%;
  border:1px solid var(--border-strong); background:rgba(5,9,24,.6); color:#fff; cursor:pointer;
  display:flex; align-items:center; justify-content:center; transition:background .2s, transform .15s; }
.xp-infocard__close:hover{ background:rgba(255,63,175,.2); transform:scale(1.05); }
.xp-infocard__cover{ position:relative; width:170px; height:170px; flex:none; border-radius:var(--radius-md); overflow:hidden; }
.xp-infocard__cover img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.xp-infocard__body{ min-width:0; }
.xp-infocard__body h3{ font-family:var(--font-display); font-weight:800; font-size:clamp(20px,2.6vw,28px); color:#fff; margin:6px 0 14px; line-height:1.05; }
.xp-credits{ margin:0; display:flex; flex-direction:column; gap:1px; }
.xp-credits__row{ display:grid; grid-template-columns:104px 1fr; gap:12px; padding:7px 0; border-top:1px solid var(--border-subtle); }
.xp-credits__row:first-child{ border-top:none; }
.xp-credits dt{ font-family:var(--font-logo); font-size:10px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-400); padding-top:2px; }
.xp-credits dd{ margin:0; font-family:var(--font-body); font-size:14px; color:#fff; }

/* ---------- ABOUT / FEATURES ---------- */
.xp-about{ display:grid; grid-template-columns:1.1fr 1fr; gap:46px; align-items:center; }
.xp-about__art{ position:relative; aspect-ratio:1; border-radius:var(--radius-2xl); overflow:hidden; border:1px solid var(--border-strong); box-shadow:var(--shadow-xl); }
.xp-about__art img{ width:100%; height:100%; object-fit:cover; }
.xp-about__art::after{ content:""; position:absolute; inset:0; background:radial-gradient(70% 60% at 30% 20%, rgba(255,63,175,.25), transparent 60%); }
.xp-about p{ font-size:17px; line-height:1.75; color:var(--ink-200); }
.xp-features{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:18px; }
.xp-feat{ padding:26px; border-radius:var(--radius-lg); background:var(--glass-bg); backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px);
  border:1px solid var(--glass-border); position:relative; overflow:hidden; transition:transform .3s, border-color .3s; }
.xp-feat:hover{ transform:translateY(-4px); border-color:var(--border-neon); }
.xp-feat__icon{ width:50px; height:50px; border-radius:var(--radius-md); display:flex; align-items:center; justify-content:center;
  background:var(--grad-pink-blue-135); color:#0a0f22; margin-bottom:16px; box-shadow:var(--glow-pink-sm); }
.xp-feat h3{ font-family:var(--font-heading); font-weight:700; font-size:19px; color:#fff; margin:0 0 8px; }
.xp-feat p{ font-size:14px; color:var(--ink-300); line-height:1.6; margin:0; }

/* ---------- PLATFORMS / CTA band ---------- */
.xp-band{ position:relative; text-align:center; padding:clamp(60px,9vw,110px) 24px; overflow:hidden;
  background:linear-gradient(135deg, rgba(255,63,175,.14), rgba(57,199,255,.12)); border-top:1px solid var(--border-subtle); border-bottom:1px solid var(--border-subtle); }
.xp-band h2{ font-family:var(--font-display); font-weight:900; font-size:clamp(34px,6vw,72px); color:#fff; letter-spacing:-.02em; margin:0 0 18px; filter:drop-shadow(0 0 40px rgba(166,91,255,.4)); }
.xp-band p{ color:var(--ink-200); font-size:18px; max-width:520px; margin:0 auto 30px; }
.xp-socials{ display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }
.xp-social{ display:inline-flex; align-items:center; gap:9px; padding:12px 20px; border-radius:999px;
  background:rgba(5,9,24,.5); border:1px solid var(--border-strong); color:#fff; font-family:var(--font-heading); font-weight:600; font-size:14px;
  cursor:pointer; transition:transform .15s, border-color .2s, box-shadow .25s; }
.xp-social:hover{ transform:translateY(-3px); border-color:var(--electric-blue); box-shadow:var(--glow-blue-sm); }

/* ---------- FOOTER ---------- */
.xp-footer{ max-width:1180px; margin:0 auto; padding:46px clamp(20px,5vw,46px) 130px; display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:18px; }
.xp-footer span{ font-size:12px; color:var(--ink-400); }
.xp-footer__links{ display:flex; gap:22px; }
.xp-footer__links a{ font-size:13px; color:var(--ink-300); }
.xp-footer__links a:hover{ color:#fff; }

/* ---------- STICKY PLAYER ---------- */
.xp-player{ position:fixed; left:0; right:0; bottom:0; z-index:70; transform:translateY(120%); transition:transform .45s var(--ease-out);
  display:grid; grid-template-columns:minmax(0,1fr) auto minmax(0,1fr); align-items:center; gap:18px;
  padding:12px clamp(14px,3vw,26px); background:rgba(5,9,24,.9); backdrop-filter:blur(22px); -webkit-backdrop-filter:blur(22px);
  border-top:1px solid var(--border-strong); }
.xp-player.show{ transform:translateY(0); }
.xp-player__viz{ position:absolute; left:0; right:0; top:0; height:3px; }
.xp-player__track{ display:flex; align-items:center; gap:13px; min-width:0; }
.xp-player__art{ width:52px; height:52px; flex:none; border-radius:10px; position:relative; overflow:hidden; display:flex; align-items:center; justify-content:center; }
.xp-player__art canvas{ position:absolute; inset:0; width:100%; height:100%; }
.xp-player__meta{ min-width:0; }
.xp-player__meta strong{ display:block; font-family:var(--font-heading); font-weight:700; font-size:14px; color:#fff; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.xp-player__meta span{ font-size:11px; color:var(--ink-300); }
.xp-player__center{ display:flex; flex-direction:column; align-items:center; gap:7px; width:min(440px,42vw); }
.xp-player__btns{ display:flex; align-items:center; gap:8px; }
.xp-play{ width:46px; height:46px; border-radius:50%; border:none; cursor:pointer; background:var(--grad-pink-blue); color:#0a0f22;
  display:flex; align-items:center; justify-content:center; box-shadow:var(--glow-pink-sm); transition:transform .15s var(--ease-snap); }
.xp-play:hover{ transform:scale(1.07); }
.xp-player__scrub{ display:flex; align-items:center; gap:10px; width:100%; font-family:var(--font-mono); font-size:11px; color:var(--ink-400); }
.xp-rail{ flex:1; height:5px; border-radius:999px; background:var(--navy-600); overflow:hidden; cursor:pointer; position:relative; }
.xp-fill{ height:100%; background:var(--grad-pink-blue); box-shadow:var(--glow-pink-sm); width:0%; }
.xp-player__right{ display:flex; align-items:center; justify-content:flex-end; gap:8px; }
.xp-vol{ width:84px; height:5px; border-radius:999px; background:var(--navy-600); overflow:hidden; cursor:pointer; }
.xp-vol__fill{ height:100%; background:var(--electric-blue); width:80%; }

/* ---------- TOAST ---------- */
.xp-toast{ position:fixed; left:50%; bottom:104px; translate:-50% 20px; z-index:90;
  padding:12px 22px; border-radius:999px; background:rgba(5,9,24,.92); border:1px solid var(--border-neon);
  color:#fff; font-family:var(--font-heading); font-weight:600; font-size:14px; box-shadow:var(--glow-pink-sm);
  opacity:0; pointer-events:none; transition:opacity .3s, transform .3s; display:flex; align-items:center; gap:9px; }
.xp-toast.show{ opacity:1; translate:-50% 0; }

/* ---------- HERO SOCIAL LINKS ---------- */
.xp-hero__follow{ margin-top:44px; }
.xp-hero__followlabel{ display:block; font-family:var(--font-logo); font-size:11px; letter-spacing:.2em; text-transform:uppercase; color:var(--ink-300); margin-bottom:14px; }
.xp-hero__social{ display:flex; gap:12px; flex-wrap:wrap; }
.xp-soc{ width:50px; height:50px; border-radius:50%; flex:none; display:flex; align-items:center; justify-content:center;
  background:rgba(5,9,24,.5); border:1px solid var(--border-strong); color:#fff;
  transition:transform .15s, border-color .2s, box-shadow .25s, background .2s; }
.xp-soc:hover{ transform:translateY(-3px); border-color:var(--electric-blue); box-shadow:var(--glow-blue-sm); background:rgba(57,199,255,.12); }

.xp-band__contact{ margin-top:24px; font-size:15px; color:var(--ink-200); }
.xp-band__contact a{ color:var(--neon-pink-bright); font-weight:600; }
.xp-band__contact a:hover{ text-decoration:underline; }

/* ---------- PROSE (Impressum / Datenschutz / Kontakt) ---------- */
.xp-prose{ max-width:760px; }
.xp-prose h2{ font-family:var(--font-heading); font-weight:700; font-size:20px; color:#fff; margin:30px 0 8px; }
.xp-prose p, .xp-prose li{ color:var(--ink-200); font-size:15px; line-height:1.7; }
.xp-prose a{ color:var(--neon-pink-bright); }
.xp-prose a:hover{ text-decoration:underline; }
.xp-prose ul{ padding-left:20px; }
.xp-prose strong{ color:#fff; }

/* ---------- CONTACT FORM ---------- */
.xp-form__lead{ max-width:560px; color:var(--ink-200); font-size:15px; line-height:1.7; margin:0 0 4px; }
.xp-form__lead a{ color:var(--neon-pink-bright); }
.xp-form__lead a:hover{ text-decoration:underline; }
.xp-form{ max-width:560px; display:flex; flex-direction:column; gap:16px; margin-top:18px; }
.xp-form label{ display:flex; flex-direction:column; gap:7px; font-family:var(--font-heading); font-weight:600; font-size:13px; color:var(--ink-200); }
.xp-form input, .xp-form textarea{ width:100%; padding:12px 14px; border-radius:var(--radius-md); background:var(--surface-1);
  border:1px solid var(--border-subtle); color:#fff; font-family:var(--font-body); font-size:15px; }
.xp-form input:focus, .xp-form textarea:focus{ outline:none; border-color:var(--border-neon); box-shadow:var(--glow-pink-sm); }
.xp-form textarea{ resize:vertical; min-height:120px; }
.xp-form button{ align-self:flex-start; }
.xp-hp{ position:absolute; left:-9999px; top:-9999px; width:1px; height:1px; overflow:hidden; }
.xp-form__err{ color:#ff7aa8; font-size:14px; }
.xp-form__hint{ font-size:12px; color:var(--ink-400); margin:0; }
.xp-form__hint a{ color:var(--ink-300); }
.xp-form__done{ max-width:560px; padding:18px 20px; border-radius:var(--radius-lg); margin-top:18px;
  background:linear-gradient(135deg, rgba(255,63,175,.12), rgba(57,199,255,.08)); border:1px solid var(--border-neon); color:#fff; font-size:15px; }

/* ---------- PLAYER MODE TOGGLE ---------- */
.xp-mode.is-on{ color:var(--electric-blue); }
.xp-mode.is-on svg{ filter:drop-shadow(0 0 6px rgba(57,199,255,.6)); }

/* ---------- PLAY / LIKE STATS ---------- */
.xp-card__stats{ display:flex; align-items:center; gap:11px; min-width:0; }
.xp-stat{ display:inline-flex; align-items:center; gap:4px; font-family:var(--font-mono); font-size:11px; color:var(--ink-400); white-space:nowrap; }
.xp-stat.is-liked{ color:var(--neon-pink); }
.xp-track__stat{ display:inline-flex; align-items:center; gap:4px; font-family:var(--font-mono); font-size:11px; color:var(--ink-400); white-space:nowrap; }
.xp-track__likes{ display:inline-flex; align-items:center; gap:4px; min-width:0; white-space:nowrap; }

/* ---------- RESPONSIVE ---------- */
@media (max-width:860px){
  .xp-nav__links{ display:none; }
  .xp-about{ grid-template-columns:1fr; }
  .xp-features{ grid-template-columns:1fr; }
  .xp-track{ grid-template-columns:48px 1fr auto; gap:12px; }
  .xp-track__wave{ display:none; }
  .xp-grid{ grid-template-columns:repeat(auto-fill, minmax(140px,1fr)); gap:12px; }
  .xp-reels{ grid-template-columns:repeat(auto-fill, minmax(130px,1fr)); gap:12px; }
  .xp-featgrid{ grid-template-columns:1fr; }
  .xp-feature{ grid-template-columns:104px 1fr; gap:14px; }
  .xp-feature__cover{ width:104px; height:104px; }
  .xp-infocard{ grid-template-columns:1fr; justify-items:center; text-align:left; gap:16px; }
  .xp-infocard__cover{ width:140px; height:140px; }
  .xp-infocard__body{ width:100%; }
  .xp-lib__bar{ flex-direction:column; align-items:stretch; }
  .xp-search{ max-width:none; }
  .xp-lib__tools{ justify-content:space-between; }
  .xp-filterrow{ flex-direction:column; gap:6px; }
  .xp-filterrow__label{ width:auto; }
  .xp-player{ grid-template-columns:1fr auto; }
  .xp-player__right{ display:none; }
  .xp-player__center{ width:auto; }
  .xp-player__scrub{ display:none; }
  .xp-soc{ width:46px; height:46px; }
  .xp-track__stat{ display:none; }   /* Liste: Plays auf dem Handy ausblenden (Platz) */
  .xp-form button{ align-self:stretch; justify-content:center; }
  .xp-musicpage__headrow{ flex-direction:column; align-items:flex-start; gap:14px; }
}
