:root{
  --bg:#040608;
  --panel:#0c1015;
  --panel-2:#121821;
  --line:rgba(175,194,228,.12);
  --text:#edf1f7;
  --muted:#b7c1d2;
  --warm:#7c2c22;
  --violet:#6d2a58;
  --cool:#123450;
  --shadow:0 22px 50px rgba(0,0,0,.38);
  --max:1200px;
  --header-h:202px;
}

*{box-sizing:border-box}
html{
  background:var(--bg);
  scroll-behavior:smooth;
}
body{
  margin:0;
  min-height:100vh;
  background:
    radial-gradient(circle at top, rgba(33,47,63,.18), transparent 38%),
    linear-gradient(180deg, #020304, #06080b 40%, #040608 100%);
  color:var(--text);
  font-family:"Inter",system-ui,sans-serif;
  overflow-x:hidden;
}

a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}

#ambient-canvas{
  position:fixed;
  inset:0;
  width:100%;
  height:100%;
  z-index:2200;
  pointer-events:none;
  opacity:1;
}

.floating-cubes{
  position:fixed;
  inset:0;
  z-index:70;
  pointer-events:none;
}
.cube{
  position:absolute;
  opacity:.11;
  filter:drop-shadow(0 18px 38px rgba(0,0,0,.42));
  transform-style:preserve-3d;
}
.cube-1{width:110px;top:8%;left:6%;animation:cubeFloatA 24s ease-in-out infinite}
.cube-2{width:84px;top:20%;right:9%;animation:cubeFloatB 18s ease-in-out infinite}
.cube-3{width:96px;bottom:18%;left:8%;animation:cubeFloatC 22s ease-in-out infinite}
.cube-4{width:72px;top:54%;right:16%;animation:cubeFloatB 20s ease-in-out infinite reverse}
.cube-5{width:58px;bottom:12%;right:8%;animation:cubeFloatA 26s ease-in-out infinite reverse}
.cube-6{width:92px;top:38%;left:44%;animation:cubeFloatC 28s ease-in-out infinite}

@keyframes cubeFloatA{
  0%,100%{transform:translate3d(0,0,0) rotate(0deg)}
  50%{transform:translate3d(18px,-24px,0) rotate(10deg)}
}
@keyframes cubeFloatB{
  0%,100%{transform:translate3d(0,0,0) rotate(0deg)}
  50%{transform:translate3d(-16px,20px,0) rotate(-12deg)}
}
@keyframes cubeFloatC{
  0%,100%{transform:translate3d(0,0,0) rotate(0deg)}
  50%{transform:translate3d(12px,-14px,0) rotate(8deg)}
}

.site-header{
  position:absolute;
  top:0;
  left:0;
  right:0;
  z-index:1200;
  height:min(100vh, 860px);
  display:block;
  padding:0;
  pointer-events:none;
  background:
    linear-gradient(90deg, rgba(2,3,5,.72), rgba(2,3,5,.24) 16%, rgba(2,3,5,0) 34%),
    linear-gradient(180deg, rgba(2,3,5,.48), rgba(2,3,5,0) 28%);
  border-bottom:0;
}
.brand-lockup{
  position:absolute;
  top:18px;
  right:clamp(20px,4vw,58px);
  display:flex;
  align-items:center;
  flex:0 0 auto;
  isolation:isolate;
  pointer-events:auto;
}
.brand-lockup::before{
  content:"";
  position:absolute;
  inset:10px;
  z-index:-1;
  border-radius:50%;
  background:radial-gradient(circle, rgba(255,255,255,.22), rgba(185,0,42,.18) 42%, transparent 70%);
  filter:blur(14px);
  opacity:.92;
}
.brand-lockup img{
  width:183px;
  height:183px;
  object-fit:contain;
  filter:
    brightness(1.34)
    contrast(1.18)
    saturate(1.16)
    drop-shadow(0 0 10px rgba(255,255,255,.28))
    drop-shadow(0 0 28px rgba(185,0,42,.52))
    drop-shadow(0 14px 30px rgba(0,0,0,.68));
}
.site-nav{
  position:fixed;
  top:clamp(128px, 19vh, 180px);
  left:clamp(18px, 3.8vw, 52px);
  width:clamp(112px, 12vw, 158px);
  display:grid;
  gap:11px;
  align-items:start;
  justify-items:stretch;
  pointer-events:auto;
  will-change:transform;
}
.site-nav a{
  position:relative;
  display:block;
  padding:9px 8px 10px;
  border-radius:0;
  border:1px solid transparent;
  color:#e8edf0;
  font-family:"Cinzel",serif;
  font-size:clamp(.78rem, .92vw, .98rem);
  font-weight:800;
  line-height:1.02;
  letter-spacing:.045em;
  text-align:left;
  text-transform:uppercase;
  background:
    linear-gradient(110deg, #f8fbff 0%, #7d8589 16%, #f3f6f8 31%, #17191b 43%, #85001f 55%, #d01947 70%, #5b0618 84%, #f0f4f6 100%);
  background-clip:text;
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  -webkit-text-stroke:.22px rgba(245,250,255,.2);
  text-shadow:none;
  filter:
    drop-shadow(0 2px 2px rgba(0,0,0,.86))
    drop-shadow(0 0 12px rgba(185,0,42,.18));
  transition:transform .22s ease, filter .22s ease, border-color .22s ease, background-color .22s ease;
}
.nav-stack{
  display:grid;
  gap:11px;
}
.nav-stack a{
  min-width:0;
}
.site-nav a::after{
  content:"";
  position:absolute;
  left:8px;
  right:18px;
  bottom:4px;
  height:1px;
  background:linear-gradient(90deg, rgba(248,251,255,.64), rgba(208,25,71,.8), transparent);
  opacity:.24;
  transform:scaleX(.64);
  transform-origin:left;
  transition:opacity .22s ease, transform .22s ease;
}
.site-nav a:hover,
.site-nav a:focus-visible{
  border-color:rgba(208,25,71,.22);
  background-color:rgba(255,255,255,.035);
  transform:translateX(5px);
  filter:
    drop-shadow(0 2px 2px rgba(0,0,0,.86))
    drop-shadow(0 0 18px rgba(208,25,71,.42));
  outline:none;
}
.site-nav a:hover::after,
.site-nav a:focus-visible::after,
.site-nav a.active::after{
  opacity:.9;
  transform:scaleX(1);
}
.site-nav a.active{
  border-color:rgba(177,120,50,.32);
  background-color:rgba(177,120,50,.07);
  filter:
    drop-shadow(0 2px 2px rgba(0,0,0,.86))
    drop-shadow(0 0 20px rgba(177,120,50,.34));
}

main{
  position:relative;
  z-index:110;
}
.sr-only{
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
  border:0;
}

.hero{
  position:relative;
  min-height:100vh;
  display:flex;
  justify-content:flex-end;
  align-items:flex-start;
  padding:clamp(88px, 13vh, 104px) clamp(244px, 20vw, 300px) 56px clamp(170px, 16vw, 230px);
  background-image:url("assets/images/Dorian Duerinckx/landing-hero-dorian.png");
  background-size:auto 100vh;
  background-repeat:no-repeat;
  background-position:clamp(52px, 7vw, 104px) top;
  overflow:hidden;
}
.hero-mobile-visual{
  display:none;
}
.hero-mobile-visual img{
  width:100%;
  height:auto;
}
.hero-overlay{
  position:absolute;
  inset:0;
  background:
    linear-gradient(90deg, rgba(3,5,7,.12) 0%, rgba(3,5,7,.03) 34%, rgba(3,5,7,.22) 58%, rgba(3,5,7,.72) 100%),
    linear-gradient(180deg, rgba(0,0,0,.08) 0%, rgba(0,0,0,.22) 48%, rgba(0,0,0,.64) 100%);
}

.hero-copy{
  position:relative;
  z-index:2;
  width:min(590px,40vw);
  margin-right:0;
  padding:0;
  border:none;
  border-radius:0;
  background:transparent;
  box-shadow:none;
  backdrop-filter:none;
}
.hero-copy::before{
  content:none;
}
.hero-title{
  margin:0;
  display:block;
  font-family:"Cinzel",serif;
  font-size:clamp(2.7rem, 4.85vw, 5.25rem);
  font-weight:800;
  line-height:.82;
  letter-spacing:0;
  text-align:right;
  color:#e8edf0;
  background:
    linear-gradient(110deg, #f8fbff 0%, #7d8589 14%, #f3f6f8 26%, #17191b 40%, #85001f 52%, #d01947 64%, #5b0618 78%, #f0f4f6 100%);
  background-size:260% 100%;
  background-position:0% 50%;
  background-clip:text;
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  -webkit-text-stroke:.7px rgba(245,250,255,.2);
  filter:
    drop-shadow(0 4px 2px rgba(0,0,0,.86))
    drop-shadow(0 0 22px rgba(185,0,42,.28));
  animation:heroNameChromeSweep 5.8s ease-in-out infinite;
}
@keyframes heroNameChromeSweep{
  0%,
  100%{
    background-position:0% 50%;
  }
  44%{
    background-position:100% 50%;
  }
}
@media (prefers-reduced-motion: reduce){
  .hero-title{
    animation:none;
  }
}
.eyebrow{
  margin:0 0 10px;
  text-transform:uppercase;
  letter-spacing:.28em;
  font-size:.75rem;
  color:#d0d8e6;
}
.section-heading h2{
  margin:0;
  font-family:"Cinzel",serif;
  line-height:1.05;
}
.hero h1:not(.hero-title){
  font-size:clamp(2.25rem, 4.8vw, 3.9rem);
  font-weight:800;
  letter-spacing:.055em;
  text-transform:uppercase;
  color:#e8edf0;
  background:
    linear-gradient(110deg, #f8fbff 0%, #6f787d 18%, #f3f6f8 34%, #15191b 47%, #7e001e 58%, #d01947 73%, #5b0618 86%, #f0f4f6 100%);
  background-clip:text;
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  -webkit-text-stroke:.6px rgba(245,250,255,.16);
  filter:drop-shadow(0 3px 2px rgba(0,0,0,.82)) drop-shadow(0 0 18px rgba(185,0,42,.22));
}
.hero-subtitle{
  margin:14px 0 0;
  max-width:44ch;
  color:#d7deea;
  line-height:1.75;
  font-size:1.02rem;
}

.section-shell{
  position:relative;
  width:min(calc(100% - 40px), var(--max));
  margin:24px auto;
  padding:28px;
  border:1px solid var(--line);
  border-radius:30px;
  background:linear-gradient(180deg, rgba(12,16,21,.88), rgba(7,10,14,.94));
  box-shadow:var(--shadow);
  backdrop-filter:blur(16px);
  scroll-margin-top:28px;
}
.section-heading{
  max-width:760px;
  margin-bottom:24px;
}
.section-heading h2{
  font-size:clamp(2rem, 4vw, 3rem);
}
.track-card{
  scroll-margin-top:24px;
}
.section-heading p,
.track-card p,
.about-copy p{
  line-height:1.7;
  color:var(--muted);
}

.music-toolbar{
  display:flex;
  justify-content:flex-end;
  align-items:center;
  gap:12px;
  margin:0 0 18px;
}
.music-toolbar label{
  color:#f6f8fc;
  font-size:.76rem;
  letter-spacing:.16em;
  text-transform:uppercase;
}
.music-toolbar select{
  min-width:190px;
  appearance:none;
  color:#f9fbff;
  background:
    linear-gradient(135deg, rgba(165,31,53,.24), rgba(29,79,134,.18) 48%, rgba(177,120,50,.20)),
    rgba(8,12,18,.86);
  border:1px solid rgba(255,255,255,.18);
  border-radius:14px;
  padding:11px 42px 11px 14px;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.14), 0 14px 30px rgba(0,0,0,.28);
  cursor:pointer;
}

.track-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:18px;
  perspective:1200px;
}
.track-card{
  position:relative;
  padding:19px 17px 17px;
  border-radius:20px;
  color:#fff;
  background:
    linear-gradient(145deg, rgba(255,255,255,.12), rgba(255,255,255,.026) 38%, rgba(3,6,11,.90)),
    rgba(7,9,14,.84);
  border:1px solid transparent;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.24),
    inset 0 -24px 46px rgba(0,0,0,.36),
    0 30px 56px rgba(0,0,0,.54),
    0 12px 18px rgba(0,0,0,.28),
    0 2px 0 rgba(255,255,255,.06);
  overflow:hidden;
  transform:translateZ(0) rotateX(.5deg);
  backdrop-filter:blur(16px) saturate(1.18);
  transition:transform .22s ease, box-shadow .22s ease;
}
.track-card:hover{
  transform:translateY(-6px) rotateX(1.2deg);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.26),
    inset 0 -24px 46px rgba(0,0,0,.34),
    0 38px 70px rgba(0,0,0,.60),
    0 16px 24px rgba(0,0,0,.34),
    0 2px 0 rgba(255,255,255,.08);
}
.track-card::after{
  content:"";
  position:absolute;
  inset:0;
  z-index:3;
  border-radius:inherit;
  padding:1px;
  background:linear-gradient(120deg, #a51f35, #1d4f86 50%, #b17832);
  -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;
  mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  mask-composite:exclude;
  pointer-events:none;
}
.track-card::before{
  content:"";
  position:absolute;
  inset:1px;
  z-index:1;
  border-radius:inherit;
  background:
    radial-gradient(circle at 16% 0%, rgba(165,31,53,.25), transparent 34%),
    radial-gradient(circle at 82% 8%, rgba(29,79,134,.22), transparent 32%),
    linear-gradient(180deg, rgba(255,255,255,.09), transparent 42%);
  opacity:.78;
  pointer-events:none;
}
.track-card-video{
  position:absolute;
  inset:0;
  z-index:0;
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:var(--artwork-position, center);
  transform:translateX(var(--artwork-shift-x, 0));
  opacity:.72;
  pointer-events:none;
}
.track-card > :not(.track-card-video){
  position:relative;
  z-index:2;
}
.track-card h3{
  position:relative;
  margin:0 0 8px;
  font-size:1.12rem;
  color:#b17832;
  text-shadow:
    0 0 16px rgba(177,120,50,.32),
    0 1px 1px rgba(0,0,0,.45);
}
.track-card p{
  position:relative;
  color:#f8fbff;
  text-shadow:0 1px 1px rgba(0,0,0,.42);
}
.player-track-title{
  color:#b17832;
  text-shadow:
    0 0 9px rgba(177,120,50,.28),
    0 1px 1px rgba(0,0,0,.45);
}
.headstone-top{
  position:relative;
  display:flex;
  justify-content:space-between;
  gap:8px;
  align-items:center;
  margin-bottom:14px;
}
.track-index,
.track-time{
  font-size:.7rem;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:#ffffff;
  text-shadow:0 1px 1px rgba(0,0,0,.44);
}
.track-card audio{
  display:none !important;
  pointer-events:none;
}
.player-shell{
  position:relative;
  margin-top:16px;
  display:grid;
  grid-template-columns:1fr;
  gap:12px;
  align-items:center;
}
.track-actions{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}
.play-toggle{
  justify-self:start;
  width:48px;
  height:48px;
  border:1px solid rgba(255,255,255,.18);
  border-radius:18px;
  background:
    linear-gradient(145deg, rgba(165,31,53,.92), rgba(29,79,134,.86) 52%, rgba(177,120,50,.88));
  color:#fff;
  box-shadow:0 12px 20px rgba(0,0,0,.38), inset 0 1px 0 rgba(255,255,255,.16);
  cursor:pointer;
}
.play-toggle .icon-pause{display:none}
.play-toggle.playing .icon-play{display:none}
.play-toggle.playing .icon-pause{display:inline}
.track-share{
  min-height:40px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:7px;
  padding:0 13px;
  border:1px solid color-mix(in srgb, var(--track-accent, #b17832), white 18%);
  border-radius:999px;
  background:rgba(5,8,13,.56);
  color:#fff;
  font-size:.72rem;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.16), 0 10px 18px rgba(0,0,0,.28);
  cursor:pointer;
  transition:background .18s ease, border-color .18s ease, transform .18s ease;
}
.track-share:hover,
.track-share:focus-visible,
.track-share.shared{
  background:color-mix(in srgb, var(--track-accent, #b17832), rgba(5,8,13,.72) 68%);
  border-color:color-mix(in srgb, var(--track-accent, #b17832), white 42%);
  transform:translateY(-1px);
}
.track-share span[aria-hidden="true"]{
  font-size:1rem;
  line-height:1;
}
.share-dialog-backdrop{
  position:fixed;
  inset:0;
  z-index:1000;
  display:grid;
  place-items:center;
  padding:20px;
  background:rgba(3,6,11,.72);
  backdrop-filter:blur(10px);
}
.share-dialog-backdrop[hidden]{
  display:none;
}
body.share-dialog-open{
  overflow:hidden;
}
.share-dialog{
  position:relative;
  width:min(100%,430px);
  padding:24px;
  border:1px solid rgba(255,255,255,.18);
  border-radius:18px;
  color:#fff;
  background:
    radial-gradient(circle at 18% 0%, rgba(139,92,246,.24), transparent 34%),
    linear-gradient(180deg, rgba(18,24,33,.98), rgba(7,10,15,.98));
  box-shadow:0 30px 80px rgba(0,0,0,.62), inset 0 1px 0 rgba(255,255,255,.14);
}
.share-dialog h3{
  margin:4px 42px 10px 0;
  font-size:1.35rem;
  line-height:1.15;
}
.share-dialog p{
  color:#dce6f2;
}
.share-dialog-close{
  position:absolute;
  top:14px;
  right:14px;
  width:34px;
  height:34px;
  border:1px solid rgba(255,255,255,.18);
  border-radius:50%;
  background:rgba(255,255,255,.08);
  color:#fff;
  font-weight:800;
  cursor:pointer;
}
.share-dialog-close:hover,
.share-dialog-close:focus-visible{
  border-color:rgba(255,255,255,.42);
  background:rgba(255,255,255,.16);
}
.share-dialog-link{
  width:100%;
  min-height:44px;
  margin:12px 0;
  padding:0 12px;
  border:1px solid rgba(255,255,255,.18);
  border-radius:10px;
  background:rgba(0,0,0,.34);
  color:#fff;
  font:inherit;
}
.share-dialog-actions{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
}
.share-dialog-actions button,
.share-dialog-actions a{
  min-height:42px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:0 12px;
  border:1px solid rgba(255,255,255,.18);
  border-radius:999px;
  background:rgba(255,255,255,.08);
  color:#fff;
  font-size:.76rem;
  font-weight:800;
  letter-spacing:.08em;
  text-transform:uppercase;
  text-decoration:none;
  cursor:pointer;
}
.share-dialog-actions button:hover,
.share-dialog-actions button:focus-visible,
.share-dialog-actions a:hover,
.share-dialog-actions a:focus-visible{
  border-color:rgba(255,255,255,.42);
  background:rgba(139,92,246,.34);
}
.share-dialog-status{
  min-height:20px;
  margin:12px 0 0;
  font-size:.84rem;
  color:#ffffff;
}
.progress-wrap{
  width:calc(100% - 1in);
  min-width:120px;
  margin-inline:auto;
  cursor:pointer;
}
.progress-bar{
  width:100%;
  height:10px;
  border-radius:999px;
  overflow:hidden;
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.14);
}
.progress-fill{
  display:block;
  height:100%;
  width:0%;
  background:linear-gradient(90deg, #a51f35, #1d4f86, #b17832);
  box-shadow:0 0 22px rgba(165,31,53,.34);
}
.time-row{
  display:flex;
  justify-content:space-between;
  gap:10px;
  font-size:.76rem;
  color:#ffffff;
  margin-top:8px;
}

.video-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(250px,1fr));
  gap:18px;
}
.video-card,
.gallery-card,
.about-stack{
  background:linear-gradient(180deg, rgba(15,20,27,.92), rgba(9,12,17,.98));
  border:1px solid rgba(175,194,228,.12);
  border-radius:22px;
  overflow:hidden;
  box-shadow:var(--shadow);
}
.video-card{
  display:block;
  transition:transform .28s ease, border-color .28s ease;
}
.video-card:hover{
  transform:translateY(-4px);
  border-color:rgba(175,194,228,.28);
}
.video-thumb{
  position:relative;
  aspect-ratio:16/10;
  background:radial-gradient(circle at center, rgba(92,48,114,.26), rgba(8,10,14,.94) 70%);
}
.video-thumb img{
  width:100%;
  height:100%;
  object-fit:cover;
}
.play-badge{
  position:absolute;
  right:14px;
  bottom:14px;
  padding:9px 13px;
  border-radius:999px;
  background:rgba(7,10,14,.82);
  border:1px solid rgba(255,255,255,.08);
  font-size:.72rem;
  letter-spacing:.16em;
  text-transform:uppercase;
}
.video-copy{
  padding:16px 18px 20px;
}
.video-copy h3{
  margin:0;
  font-size:1rem;
  line-height:1.35;
  letter-spacing:.02em;
  color:#e7ddd1;
  text-shadow:0 1px 6px rgba(0,0,0,.45);
}

.gallery-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:20px;
}
.gallery-card{
  position:relative;
  padding:0;
  border:1px solid rgba(175,194,228,.14);
  cursor:pointer;
  min-height:330px;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  text-align:left;
  isolation:isolate;
  background:linear-gradient(180deg, rgba(15,20,27,.92), rgba(9,12,17,.98));
  transition:transform .22s ease, border-color .22s ease, box-shadow .22s ease;
}
.gallery-card:hover,
.gallery-card:focus-visible{
  transform:translateY(-4px);
  border-color:rgba(216,58,58,.42);
  box-shadow:0 22px 52px rgba(0,0,0,.42), 0 0 0 1px rgba(92,164,255,.16);
  outline:none;
}
.album-cover-stack{
  position:absolute;
  inset:0;
  overflow:hidden;
  z-index:0;
}
.album-cover-stack::after{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(180deg, rgba(5,8,12,.08), rgba(5,8,12,.62) 52%, rgba(5,8,12,.96)),
    linear-gradient(90deg, rgba(203,42,42,.22), transparent 38%, rgba(58,132,211,.18));
}
.album-cover-stack img{
  width:100%;
  height:100%;
  object-fit:cover;
  filter:saturate(1.05) contrast(1.08);
  transform:scale(1.02);
}
.album-card-copy{
  position:relative;
  z-index:1;
  display:grid;
  gap:8px;
  padding:22px;
}
.album-card-title{
  font-size:1.45rem;
  line-height:1.05;
  color:#f4f7fb;
  font-family:var(--display);
}
.album-card-meta{
  width:max-content;
  padding:5px 9px;
  border:1px solid rgba(255,255,255,.12);
  border-radius:999px;
  color:#dce7f7;
  background:rgba(4,7,10,.48);
  font-size:.72rem;
  letter-spacing:.12em;
  text-transform:uppercase;
}
.album-card-description{
  color:#c4cedd;
  line-height:1.45;
  font-size:.92rem;
}

.about-section{
  overflow:hidden;
}
.about-panel{
  position:relative;
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(300px,.48fr);
  gap:28px;
  align-items:start;
  padding:24px;
  border:1px solid rgba(180,194,224,.14);
  border-radius:28px;
  background:
    radial-gradient(circle at 16% 8%, rgba(165,31,53,.22), transparent 32%),
    radial-gradient(circle at 82% 16%, rgba(29,79,134,.24), transparent 34%),
    linear-gradient(145deg, rgba(255,255,255,.08), rgba(255,255,255,.025) 42%, rgba(4,7,12,.86));
  box-shadow:0 28px 70px rgba(0,0,0,.44), inset 0 1px 0 rgba(255,255,255,.12);
  backdrop-filter:blur(18px);
}
.about-panel::before{
  content:"";
  position:absolute;
  inset:0;
  border-radius:inherit;
  border:1px solid transparent;
  background:linear-gradient(120deg, #a51f35, #1d4f86 52%, #b17832) border-box;
  mask:linear-gradient(#000 0 0) padding-box, linear-gradient(#000 0 0);
  mask-composite:exclude;
  pointer-events:none;
}
.about-copy{
  position:relative;
  z-index:1;
  display:flex;
  flex-direction:column;
  justify-content:flex-start;
}
.about-copy h2{
  margin:0;
  max-width:13ch;
  font-family:"Cinzel",serif;
  font-size:clamp(2.35rem, 5.4vw, 4.9rem);
  font-weight:800;
  line-height:.98;
  letter-spacing:.045em;
  text-transform:uppercase;
  color:#e8edf0;
  background:
    linear-gradient(110deg, #f8fbff 0%, #7d8589 18%, #f3f6f8 34%, #17191b 47%, #85001f 58%, #d01947 73%, #5b0618 86%, #f0f4f6 100%);
  background-clip:text;
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  -webkit-text-stroke:.55px rgba(245,250,255,.18);
  filter:drop-shadow(0 3px 2px rgba(0,0,0,.82)) drop-shadow(0 0 18px rgba(185,0,42,.25));
}
.about-body{
  margin-top:24px;
  display:grid;
  gap:15px;
  max-width:78ch;
}
.about-body p{
  margin:0;
  color:#cbd4e2;
  font-size:.98rem;
  line-height:1.78;
}
.about-body p:first-child,
.about-closing{
  color:#f4eadf;
  font-size:1.05rem;
}
.about-closing{
  padding:16px 18px;
  border:1px solid rgba(255,255,255,.12);
  border-radius:18px;
  background:
    linear-gradient(135deg, rgba(165,31,53,.16), rgba(29,79,134,.10) 52%, rgba(177,120,50,.12)),
    rgba(4,7,12,.48);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08);
}
.about-tags{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:22px;
}
.about-tags span{
  padding:8px 11px;
  border:1px solid rgba(255,255,255,.12);
  border-radius:999px;
  color:#f5f8ff;
  background:rgba(255,255,255,.045);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08);
  font-size:.86rem;
}
.about-tags em{
  color:#c9b28f;
  font-style:normal;
}
.about-media-stack{
  position:sticky;
  top:24px;
  z-index:1;
  display:grid;
  gap:18px;
  align-self:start;
}
.about-visual{
  position:relative;
  z-index:1;
  border-radius:22px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.12);
  box-shadow:0 22px 54px rgba(0,0,0,.42);
  background:rgba(2,4,7,.78);
}
.about-visual-primary{
  aspect-ratio:4 / 5;
}
.about-visual-secondary{
  aspect-ratio:4 / 3;
}
.about-visual-logo{
  aspect-ratio:1;
  display:grid;
  place-items:center;
  padding:18px;
  background:
    radial-gradient(circle at 50% 34%, rgba(208,25,71,.2), transparent 44%),
    #010101;
}
.about-visual-square{
  aspect-ratio:1;
}
.about-visual-wide{
  aspect-ratio:16 / 9;
}
.about-visual > img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:43% center;
  filter:saturate(1.02) contrast(1.06) brightness(1.05);
}
.about-visual-secondary > img{
  object-position:48% center;
}
.about-visual-logo > img{
  width:100%;
  height:100%;
  object-fit:contain;
  object-position:center;
  filter:drop-shadow(0 0 20px rgba(208,25,71,.28));
}
.about-visual-square > img,
.about-visual-wide > img{
  object-position:center;
}
.about-visual::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, transparent 34%, rgba(3,5,8,.68));
}
.about-visual-logo::after{
  background:linear-gradient(180deg, rgba(255,255,255,.03), transparent 50%, rgba(3,5,8,.36));
}
.about-sigil{
  position:absolute;
  right:18px;
  bottom:18px;
  z-index:1;
  width:96px;
  height:96px;
  display:grid;
  place-items:center;
  border-radius:22px;
  background:rgba(4,7,12,.64);
  border:1px solid rgba(255,255,255,.12);
  backdrop-filter:blur(10px);
}
.about-sigil img{
  width:74px;
  height:74px;
  object-fit:contain;
  filter:drop-shadow(0 12px 24px rgba(0,0,0,.5));
}
.signup-card{
  position:relative;
  z-index:1;
  grid-column:1 / -1;
  display:grid;
  grid-template-columns:minmax(0,.8fr) minmax(280px,1fr);
  gap:10px 18px;
  align-items:end;
  padding:18px;
  border:1px solid rgba(255,255,255,.12);
  border-radius:20px;
  background:rgba(4,7,12,.64);
}
.signup-card h3{
  margin:0;
  color:#f7f9fd;
  font-family:"Cinzel",serif;
  font-size:1.45rem;
}
.signup-card p{
  margin:0;
  color:#c9d2df;
}
.signup-card .eyebrow{
  grid-column:1 / -1;
  margin:0;
}
.signup-row{
  display:flex;
  gap:10px;
}
.signup-row input{
  min-width:0;
  flex:1;
  padding:13px 14px;
  border:1px solid rgba(255,255,255,.14);
  border-radius:14px;
  color:#fff;
  background:rgba(255,255,255,.06);
}
.signup-row button{
  padding:13px 18px;
  border:1px solid rgba(255,255,255,.16);
  border-radius:14px;
  color:#fff;
  background:linear-gradient(135deg, rgba(165,31,53,.94), rgba(29,79,134,.88));
  cursor:pointer;
  font-weight:800;
  letter-spacing:.08em;
  text-transform:uppercase;
}

.site-footer{
  position:relative;
  z-index:110;
  padding:28px 20px 44px;
  text-align:center;
  color:#cad4e2;
}
.footer-note{color:#93a0b3}

.library-player{
  position:fixed;
  right:18px;
  bottom:18px;
  z-index:1260;
  width:min(420px, calc(100% - 36px));
  display:grid;
  grid-template-columns:minmax(0,1fr) auto auto;
  gap:8px 12px;
  align-items:center;
  padding:10px 12px;
  border:1px solid rgba(180,194,224,.18);
  border-radius:18px;
  background:
    linear-gradient(135deg, rgba(165,31,53,.22), rgba(29,79,134,.16) 48%, rgba(177,120,50,.18)),
    rgba(5,8,12,.94);
  box-shadow:0 22px 58px rgba(0,0,0,.50), inset 0 1px 0 rgba(255,255,255,.10);
  backdrop-filter:blur(18px);
  opacity:0;
  transform:translateY(18px) scale(.98);
  pointer-events:none;
  transition:opacity .7s ease, transform .7s ease;
}
.library-player.expanded{
  width:min(520px, calc(100% - 36px));
  grid-template-columns:minmax(0,1fr) auto;
  gap:14px 18px;
  padding:16px;
  border-radius:20px;
}
.library-player.visible{
  opacity:1;
  transform:translateY(0) scale(1);
  pointer-events:auto;
}
.library-player-meta{
  min-width:0;
  display:grid;
  gap:2px;
}
.library-player-label{
  color:#aeb8c7;
  font-size:.58rem;
  letter-spacing:.16em;
  text-transform:uppercase;
}
.library-player strong{
  overflow:hidden;
  color:#f8fbff;
  font-size:1rem;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.library-player-meta span:last-child{
  display:none;
  overflow:hidden;
  color:#c7d1df;
  font-size:.8rem;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.library-player.expanded .library-player-meta span:last-child{
  display:block;
}
.library-player-controls{
  display:flex;
  align-items:center;
  gap:6px;
}
.library-player button{
  border:1px solid rgba(255,255,255,.14);
  border-radius:999px;
  background:rgba(255,255,255,.06);
  color:#fff;
  cursor:pointer;
  font-weight:800;
  letter-spacing:.06em;
  text-transform:uppercase;
  transition:transform .2s ease, border-color .2s ease, background .2s ease, opacity .2s ease;
}
.library-player button:hover:not(:disabled){
  transform:translateY(-1px);
  border-color:rgba(255,178,110,.28);
  background:rgba(255,255,255,.10);
}
.library-player button:disabled{
  cursor:not-allowed;
  opacity:.45;
}
.library-player:not(.expanded) #library-prev,
.library-player:not(.expanded) #library-next,
.library-player:not(.expanded) .library-player-volume,
.library-player:not(.expanded) #library-play:disabled,
.library-player:not(.expanded) #library-pause:disabled{
  display:none;
}
.library-player-expand{
  min-height:34px;
  padding:0 11px;
  font-size:.62rem;
}
.library-player.expanded .library-player-expand{
  grid-column:2;
}
.library-player.expanded .library-player-controls{
  grid-column:1 / -1;
  justify-content:end;
}
#library-prev,
#library-next{
  width:38px;
  height:38px;
  display:grid;
  place-items:center;
  font-size:1.7rem;
  line-height:1;
}
#library-play,
#library-pause,
#library-mute{
  min-height:38px;
  padding:0 13px;
  font-size:.68rem;
}
#library-play{
  background:linear-gradient(135deg, rgba(165,31,53,.92), rgba(29,79,134,.82));
}
.library-player-progress{
  grid-column:1 / -1;
  display:grid;
  grid-template-columns:minmax(0,1fr);
  gap:0;
  align-items:center;
  color:#d8e1ee;
  font-size:.76rem;
}
.library-player.expanded .library-player-progress{
  grid-template-columns:44px minmax(0,1fr) 44px;
  gap:10px;
}
.library-player:not(.expanded) #library-current-time,
.library-player:not(.expanded) #library-duration{
  display:none;
}
.library-player-volume{
  grid-column:1 / -1;
  display:grid;
  grid-template-columns:auto minmax(110px,180px);
  gap:10px;
  align-items:center;
  justify-content:end;
}
.library-player input[type="range"]{
  width:100%;
  accent-color:#b17832;
  cursor:pointer;
}

body.library-player-active{
  padding-bottom:88px;
}
body.library-player-expanded{
  padding-bottom:190px;
}

.lightbox{
  position:fixed;
  inset:0;
  z-index:1300;
  display:none;
  place-items:center;
  background:rgba(2,4,6,.9);
  backdrop-filter:blur(14px);
  padding:24px;
}
.lightbox.open{display:grid}
.viewer-open{overflow:hidden}
.album-viewer-shell{
  width:min(1240px, 96vw);
  max-height:94vh;
  display:grid;
  grid-template-rows:auto minmax(0,1fr) auto;
  gap:16px;
  padding:18px;
  border:1px solid rgba(192,207,230,.14);
  border-radius:24px;
  background:linear-gradient(180deg, rgba(12,16,22,.96), rgba(3,5,9,.98));
  box-shadow:0 36px 90px rgba(0,0,0,.62);
}
.album-viewer-top{
  display:flex;
  align-items:end;
  justify-content:space-between;
  gap:16px;
  padding-right:58px;
}
.album-viewer-top .eyebrow{
  margin:0 0 4px;
}
.album-viewer-top h3{
  margin:0;
  color:#f5f7fb;
  font-family:var(--display);
  font-size:clamp(1.3rem, 2.4vw, 2.2rem);
}
.album-viewer-count{
  margin:0;
  color:#aeb9c8;
  font-size:.84rem;
  letter-spacing:.14em;
  text-transform:uppercase;
}
.album-stage{
  min-height:0;
  display:grid;
  grid-template-columns:54px minmax(0,1fr) 54px;
  gap:14px;
  align-items:center;
}
.lightbox-figure{
  margin:0;
  min-width:0;
  min-height:0;
  height:100%;
  display:grid;
  grid-template-rows:minmax(0,1fr) auto;
  gap:12px;
  justify-items:center;
  align-items:center;
}
#lightbox-image{
  width:100%;
  height:100%;
  max-height:68vh;
  object-fit:contain;
  border-radius:18px;
  background:rgba(0,0,0,.24);
  box-shadow:0 30px 70px rgba(0,0,0,.56);
}
#lightbox-caption{
  color:#d6dfed;
  text-align:center;
  min-height:1.3em;
}
.lightbox-close{
  position:absolute;
  top:18px;
  right:18px;
  width:48px;
  height:48px;
  border:none;
  border-radius:999px;
  background:rgba(8,11,16,.8);
  color:#fff;
  font-size:2rem;
  cursor:pointer;
}
.album-nav{
  width:54px;
  height:72px;
  border:1px solid rgba(255,255,255,.12);
  border-radius:16px;
  background:rgba(8,11,16,.72);
  color:#f5f8ff;
  font-size:2.8rem;
  line-height:1;
  cursor:pointer;
  box-shadow:0 14px 32px rgba(0,0,0,.32);
}
.album-nav:hover,
.album-nav:focus-visible,
.lightbox-close:hover,
.lightbox-close:focus-visible{
  border-color:rgba(95,168,255,.42);
  background:rgba(22,29,39,.9);
  outline:none;
}
.album-thumbs{
  display:flex;
  gap:10px;
  overflow-x:auto;
  padding:2px 2px 8px;
  scrollbar-color:#516075 rgba(255,255,255,.08);
}
.album-thumbs button{
  flex:0 0 78px;
  width:78px;
  aspect-ratio:1;
  padding:0;
  border:1px solid rgba(255,255,255,.11);
  border-radius:12px;
  overflow:hidden;
  background:rgba(255,255,255,.04);
  cursor:pointer;
  opacity:.62;
}
.album-thumbs button.active,
.album-thumbs button:hover,
.album-thumbs button:focus-visible{
  opacity:1;
  border-color:#d83a3a;
  box-shadow:0 0 0 2px rgba(95,168,255,.28);
  outline:none;
}
.album-thumbs img{
  width:100%;
  height:100%;
  object-fit:cover;
}

@media (max-width: 920px){
  .site-header{
    height:auto;
    min-height:var(--header-h);
    display:flex;
    align-items:flex-start;
    justify-content:space-between;
    gap:16px;
    padding:12px 18px;
    pointer-events:auto;
  }
  .brand-lockup{
    position:relative;
    top:auto;
    right:auto;
    order:2;
  }
  .site-nav{
    position:relative;
    top:auto;
    left:auto;
    order:1;
    width:auto;
    max-width:calc(100% - 154px);
    display:flex;
    flex-wrap:wrap;
    gap:8px 12px;
    align-items:flex-start;
  }
  .site-nav a{
    padding:8px 5px;
    font-size:.78rem;
  }
  .site-nav a:hover,
  .site-nav a:focus-visible{
    transform:translateY(-1px);
  }
  .nav-stack{
    gap:8px;
  }
  .floating-cubes{
    display:none;
  }
  .hero{
    min-height:auto;
    display:grid;
    gap:22px;
    justify-content:stretch;
    align-items:end;
    padding:calc(var(--header-h) + 28px) min(5vw,42px) 46px;
    background-image:none;
  }
  .hero-mobile-visual{
    position:relative;
    z-index:1;
    display:block;
    width:min(620px, 92vw);
    margin:0 auto;
  }
  .hero-mobile-visual img{
    border:1px solid rgba(255,255,255,.08);
    box-shadow:0 26px 70px rgba(0,0,0,.46);
  }
  .hero-copy{
    width:min(620px, 100%);
    margin:0 auto;
  }
  .hero-title{
    font-size:clamp(2.345rem, 8.4vw, 3.85rem);
    text-align:left;
  }
  .hero-overlay{
    background:
      linear-gradient(180deg, rgba(3,5,7,.14), rgba(3,5,7,.78) 76%, rgba(3,5,7,.92)),
      linear-gradient(90deg, rgba(165,31,53,.10), transparent 34%, rgba(29,79,134,.10));
  }
  .about-panel{
    grid-template-columns:1fr;
  }
  .about-copy h2{
    max-width:14ch;
  }
  .about-body{
    max-width:none;
  }
  .about-media-stack{
    position:relative;
    top:auto;
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .about-visual-primary,
  .about-visual-secondary{
    aspect-ratio:4 / 3;
  }
  .signup-card{
    grid-template-columns:1fr;
  }
  .gallery-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .album-stage{
    grid-template-columns:44px minmax(0,1fr) 44px;
    gap:10px;
  }
  .album-nav{
    width:44px;
    height:60px;
    font-size:2.2rem;
  }
}
@media (max-width: 720px){
  :root{--header-h:150px}
  .site-header{
    padding:10px 14px;
    gap:12px;
    flex-wrap:nowrap;
  }
  .brand-lockup img{
    width:130px;
    height:130px;
  }
  .site-nav{
    flex:1 1 auto;
    justify-content:flex-start;
    gap:4px;
    max-width:calc(100% - 126px);
  }
  .site-nav a{
    padding:7px 6px;
    font-size:.72rem;
  }
  .nav-stack{
    gap:2px;
  }
  .nav-stack a{
    min-width:68px;
  }
  .hero{
    padding:calc(var(--header-h) + 14px) 18px 34px;
    gap:18px;
  }
  .hero-mobile-visual{
    width:min(390px, 96vw);
  }
  .hero-copy{
    width:100%;
    padding:0;
    margin-right:0;
  }
  .hero-title{
    font-size:clamp(2.1rem, 10.5vw, 3.29rem);
  }
  .section-shell{
    width:min(calc(100% - 20px), var(--max));
    padding:24px;
  }
  .library-player{
    left:10px;
    right:10px;
    bottom:10px;
    width:auto;
    grid-template-columns:minmax(0,1fr) auto auto;
    gap:8px 10px;
  }
  .library-player.expanded{
    width:auto;
    grid-template-columns:1fr;
    gap:12px;
  }
  .library-player.expanded .library-player-expand{
    grid-column:auto;
    justify-self:end;
  }
  body.library-player-active{
    padding-bottom:84px;
  }
  body.library-player-expanded{
    padding-bottom:250px;
  }
  .library-player.expanded .library-player-controls{
    display:grid;
    grid-template-columns:40px 1fr 1fr 40px;
  }
  .library-player-volume{
    grid-template-columns:auto minmax(0,1fr);
    justify-content:stretch;
  }
  .music-toolbar{
    align-items:stretch;
    flex-direction:column;
  }
  .eyebrow{
    letter-spacing:.18em;
    font-size:.68rem;
  }
  .hero h1{
    font-size:clamp(2.1rem, 12vw, 3.2rem);
    letter-spacing:.035em;
  }
  .music-toolbar select{
    width:100%;
  }
  .about-panel{
    padding:18px;
    border-radius:22px;
  }
  .about-copy h2{
    font-size:clamp(2.1rem, 11vw, 3.4rem);
  }
  .about-body p{
    font-size:.95rem;
    line-height:1.7;
  }
  .about-media-stack{
    grid-template-columns:1fr;
  }
  .about-visual-primary,
  .about-visual-secondary{
    aspect-ratio:16 / 10;
  }
  .about-tags span{
    width:100%;
  }
  .signup-row{
    flex-direction:column;
  }
  .signup-row button{
    width:100%;
  }
  .gallery-grid{grid-template-columns:1fr}
  .gallery-card{min-height:300px}
  .lightbox{padding:10px}
  .album-viewer-shell{
    width:100%;
    max-height:96vh;
    border-radius:18px;
    padding:12px;
  }
  .album-viewer-top{
    align-items:start;
    flex-direction:column;
    padding-right:52px;
    gap:6px;
  }
  .album-stage{
    grid-template-columns:1fr;
    grid-template-rows:minmax(0,1fr) auto;
  }
  .album-nav{
    position:absolute;
    top:50%;
    transform:translateY(-50%);
    z-index:2;
  }
  .album-prev{left:14px}
  .album-next{right:14px}
  #lightbox-image{max-height:62vh}
  .album-thumbs button{
    flex-basis:64px;
    width:64px;
  }
}

.music-section{
  overflow:visible;
}
.music-player-app{
  display:grid;
  grid-template-columns:minmax(250px,.8fr) minmax(360px,1.18fr) minmax(250px,.82fr);
  gap:18px;
  align-items:stretch;
  min-height:640px;
}
.music-column{
  min-width:0;
  border:1px solid rgba(180,194,224,.14);
  border-radius:26px;
  background:
    linear-gradient(145deg, rgba(255,255,255,.07), rgba(255,255,255,.02) 42%, rgba(4,7,12,.82)),
    rgba(5,8,12,.72);
  box-shadow:0 24px 58px rgba(0,0,0,.42), inset 0 1px 0 rgba(255,255,255,.08);
  backdrop-filter:blur(18px);
}
.music-column > summary{
  display:none;
}
.music-library-column{
  padding:16px;
  overflow:hidden;
}
.music-player-app .music-toolbar{
  position:sticky;
  top:12px;
  z-index:3;
  align-items:stretch;
  flex-direction:column;
  margin:0 0 14px;
}
.music-player-app .music-toolbar select{
  min-width:0;
  width:100%;
}
.music-catalog-actions{
  display:flex;
  justify-content:center;
  margin:-10px 0 22px;
}
.catalog-open-button{
  min-height:46px;
  padding:0 28px;
  border:1px solid rgba(255,255,255,.22);
  border-radius:8px;
  color:#fff;
  background:
    linear-gradient(135deg, rgba(180,39,44,.9), rgba(24,30,38,.9) 52%, rgba(206,143,57,.72)),
    rgba(10,13,18,.88);
  box-shadow:0 18px 44px rgba(0,0,0,.36), inset 0 1px 0 rgba(255,255,255,.16);
  font:800 .78rem/1 "Inter",system-ui,sans-serif;
  letter-spacing:.08em;
  text-transform:uppercase;
  cursor:pointer;
}
.catalog-open-button:hover,
.catalog-open-button:focus-visible{
  border-color:rgba(255,255,255,.42);
  transform:translateY(-1px);
}
.catalog-open{
  overflow:hidden;
}
.catalog-overlay{
  position:fixed;
  inset:0;
  z-index:1500;
  display:grid;
  place-items:center;
  padding:clamp(16px, 4vw, 42px);
  opacity:0;
  pointer-events:none;
  transition:opacity 220ms ease;
}
.catalog-overlay[hidden]{
  display:none;
}
.catalog-overlay.open{
  opacity:1;
  pointer-events:auto;
}
.catalog-backdrop{
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at 20% 18%, rgba(139,40,44,.24), transparent 32%),
    radial-gradient(circle at 80% 70%, rgba(196,128,48,.18), transparent 30%),
    rgba(1,3,6,.97);
  backdrop-filter:blur(14px);
}
.catalog-shell{
  position:relative;
  width:min(1120px, 100%);
  min-height:min(740px, calc(100vh - 42px));
  display:grid;
  grid-template-rows:auto minmax(0,1fr) auto;
  gap:18px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.16);
  border-radius:18px;
  background:
    linear-gradient(145deg, rgba(255,255,255,.08), rgba(255,255,255,.025) 42%, rgba(5,7,11,.94)),
    rgba(6,8,12,.92);
  box-shadow:0 30px 92px rgba(0,0,0,.68), inset 0 1px 0 rgba(255,255,255,.12);
  isolation:isolate;
}
.catalog-shell::before{
  content:"";
  position:absolute;
  inset:-20% -12% auto;
  height:42%;
  z-index:-1;
  background:
    linear-gradient(110deg, transparent 0 14%, rgba(255,255,255,.08) 14% 15%, transparent 15% 25%),
    radial-gradient(circle at 50% 0%, rgba(255,255,255,.12), transparent 58%);
  opacity:.72;
  transform:skewY(-5deg);
}
.catalog-header,
.catalog-footer{
  display:flex;
  align-items:center;
  justify-content:space-between;
  min-width:0;
  padding:18px 22px;
}
.catalog-header{
  border-bottom:1px solid rgba(255,255,255,.1);
}
.catalog-header h3{
  margin:0;
  color:#fff;
  font:800 clamp(1.05rem, 2.4vw, 1.55rem)/1.1 "Inter",system-ui,sans-serif;
  letter-spacing:.02em;
}
.catalog-close{
  min-height:38px;
  padding:0 14px;
  border:1px solid rgba(255,255,255,.18);
  border-radius:8px;
  color:#fff;
  background:rgba(255,255,255,.06);
  font:800 .7rem/1 "Inter",system-ui,sans-serif;
  letter-spacing:.08em;
  text-transform:uppercase;
  cursor:pointer;
}
.catalog-close:hover,
.catalog-close:focus-visible{
  background:rgba(255,255,255,.12);
}
.catalog-frame{
  position:relative;
  min-height:540px;
  display:grid;
  grid-template-columns:76px minmax(0,1fr) 76px;
  align-items:center;
  perspective:1300px;
}
.catalog-stage{
  position:relative;
  height:100%;
  min-height:520px;
  outline:none;
  touch-action:pan-y;
  user-select:none;
}
.catalog-stage:focus-visible{
  box-shadow:inset 0 0 0 2px rgba(255,255,255,.24);
}
.catalog-rail{
  position:absolute;
  inset:0;
  transform-style:preserve-3d;
}
.catalog-song-card{
  --catalog-accent:#b4272c;
  --catalog-bg:url("assets/images/song-backgrounds/tarot-01.png");
  position:absolute;
  left:50%;
  top:50%;
  width:min(520px, 72vw);
  min-height:455px;
  opacity:0;
  pointer-events:none;
  transform:translate3d(-50%, -50%, -260px) rotateY(0deg) scale(.74);
  transition:transform 320ms cubic-bezier(.2,.7,.25,1), opacity 220ms ease, filter 220ms ease;
  transform-style:preserve-3d;
  filter:saturate(.75) brightness(.66);
}
.catalog-song-card.is-active,
.catalog-song-card.is-prev,
.catalog-song-card.is-next{
  opacity:1;
}
.catalog-song-card.is-active{
  z-index:3;
  pointer-events:auto;
  transform:translate3d(-50%, -50%, 95px) rotateX(0deg) rotateY(0deg) rotateZ(0deg) scale(1);
  filter:saturate(1.08) brightness(1);
}
.catalog-song-card.is-prev{
  z-index:2;
  transform:translate3d(calc(-50% - min(34vw, 360px)), -50%, -80px) rotateY(47deg) rotateZ(2deg) scale(.78);
}
.catalog-song-card.is-next{
  z-index:2;
  transform:translate3d(calc(-50% + min(34vw, 360px)), -50%, -80px) rotateY(-47deg) rotateZ(-2deg) scale(.78);
}
.catalog-song-card.is-hidden{
  visibility:hidden;
}
.catalog-card-face{
  position:relative;
  min-height:455px;
  display:grid;
  grid-template-rows:auto 168px auto auto;
  gap:16px;
  overflow:hidden;
  padding:18px;
  border:1px solid color-mix(in srgb, var(--catalog-accent), rgba(255,255,255,.28) 44%);
  border-radius:10px;
  color:#fff;
  background:
    linear-gradient(105deg, rgba(255,255,255,.16) 0 1px, transparent 1px 13%),
    linear-gradient(180deg, rgba(255,255,255,.09), rgba(255,255,255,.025) 34%, rgba(2,4,8,.9)),
    rgba(8,11,16,.96);
  box-shadow:
    0 30px 82px rgba(0,0,0,.62),
    14px 0 0 color-mix(in srgb, var(--catalog-accent), #111827 72%),
    inset 0 1px 0 rgba(255,255,255,.18);
  clip-path:polygon(0 0, calc(100% - 20px) 0, 100% 20px, 100% 100%, 18px 100%, 0 calc(100% - 18px));
}
.catalog-card-face::before{
  content:"";
  position:absolute;
  inset:0;
  z-index:-1;
  background:
    linear-gradient(90deg, rgba(2,4,8,.88), rgba(2,4,8,.42)),
    var(--catalog-bg) center / cover no-repeat;
  filter:saturate(1.04) contrast(1.08) brightness(.58);
  transform:scale(1.04);
}
.catalog-card-face::after{
  content:"";
  position:absolute;
  inset:8px 8px auto auto;
  width:70px;
  height:70px;
  border-top:1px solid rgba(255,255,255,.28);
  border-right:1px solid rgba(255,255,255,.28);
  opacity:.58;
}
.catalog-card-topline{
  display:flex;
  justify-content:space-between;
  gap:16px;
  color:rgba(255,255,255,.74);
  font:800 .68rem/1 "Inter",system-ui,sans-serif;
  letter-spacing:.1em;
  text-transform:uppercase;
}
.catalog-card-art{
  position:relative;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.16);
  border-radius:8px;
  background:var(--catalog-bg) center / cover no-repeat;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.06), 0 18px 36px rgba(0,0,0,.38);
}
.catalog-card-video{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:var(--artwork-position, center);
  transform:translateX(var(--artwork-shift-x, 0));
}
.catalog-card-art::after{
  content:"";
  position:absolute;
  inset:0;
  z-index:1;
  background:
    linear-gradient(120deg, rgba(255,255,255,.12), transparent 34%),
    radial-gradient(circle at 78% 22%, color-mix(in srgb, var(--catalog-accent), transparent 42%), transparent 34%);
}
.catalog-card-copy{
  display:grid;
  gap:7px;
}
.catalog-card-copy h4{
  margin:0;
  color:#fff;
  font:900 clamp(1.35rem, 3.4vw, 2.25rem)/.98 "Inter",system-ui,sans-serif;
  text-wrap:balance;
}
.catalog-card-copy p{
  margin:0;
  color:#f0f4f8;
  font-size:.92rem;
  font-weight:700;
}
.catalog-card-copy span{
  color:rgba(237,241,247,.82);
  font-size:.86rem;
  line-height:1.45;
}
.catalog-card-controls{
  position:relative;
  z-index:2;
  display:grid;
  grid-template-columns:auto auto minmax(132px,1fr);
  gap:10px;
  align-items:center;
}
.catalog-card-controls button{
  min-height:42px;
  padding:0 16px;
  border:1px solid rgba(255,255,255,.18);
  border-radius:8px;
  color:#fff;
  background:rgba(255,255,255,.08);
  font:900 .72rem/1 "Inter",system-ui,sans-serif;
  letter-spacing:.08em;
  text-transform:uppercase;
  cursor:pointer;
}
.catalog-card-controls [data-catalog-play]{
  background:
    radial-gradient(circle at 35% 20%, rgba(255,255,255,.26), transparent 36%),
    var(--catalog-accent);
  box-shadow:0 0 28px color-mix(in srgb, var(--catalog-accent), transparent 46%);
}
.catalog-card-controls button:hover,
.catalog-card-controls button:focus-visible{
  border-color:rgba(255,255,255,.42);
  transform:translateY(-1px);
}
.catalog-card-controls label{
  display:grid;
  gap:6px;
  min-width:0;
  color:rgba(255,255,255,.74);
  font:800 .62rem/1 "Inter",system-ui,sans-serif;
  letter-spacing:.09em;
  text-transform:uppercase;
}
.catalog-volume-control{
  --catalog-volume-level:100%;
  position:relative;
  padding:5px 0 7px;
  cursor:pointer;
  touch-action:none;
}
.catalog-card-controls input[type="range"]{
  width:100%;
  height:24px;
  margin:0;
  appearance:none;
  -webkit-appearance:none;
  border-radius:999px;
  background:transparent;
  cursor:pointer;
  touch-action:none;
  accent-color:var(--catalog-accent);
}
.catalog-card-controls input[type="range"]::-webkit-slider-runnable-track{
  height:8px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.16);
  background:
    linear-gradient(90deg, var(--catalog-accent) 0 var(--catalog-volume-level), rgba(255,255,255,.18) var(--catalog-volume-level) 100%);
}
.catalog-card-controls input[type="range"]::-webkit-slider-thumb{
  width:20px;
  height:20px;
  margin-top:-7px;
  -webkit-appearance:none;
  border:2px solid rgba(255,255,255,.9);
  border-radius:50%;
  background:var(--catalog-accent);
  box-shadow:0 0 18px color-mix(in srgb, var(--catalog-accent), transparent 32%);
}
.catalog-card-controls input[type="range"]::-moz-range-track{
  height:8px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.16);
  background:rgba(255,255,255,.18);
}
.catalog-card-controls input[type="range"]::-moz-range-progress{
  height:8px;
  border-radius:999px;
  background:var(--catalog-accent);
}
.catalog-card-controls input[type="range"]::-moz-range-thumb{
  width:18px;
  height:18px;
  border:2px solid rgba(255,255,255,.9);
  border-radius:50%;
  background:var(--catalog-accent);
  box-shadow:0 0 18px color-mix(in srgb, var(--catalog-accent), transparent 32%);
}
.catalog-song-card.is-playing .catalog-card-face{
  box-shadow:
    0 30px 82px rgba(0,0,0,.62),
    14px 0 0 color-mix(in srgb, var(--catalog-accent), #111827 72%),
    0 0 36px color-mix(in srgb, var(--catalog-accent), transparent 40%),
    inset 0 1px 0 rgba(255,255,255,.18);
}
.catalog-nav{
  position:relative;
  z-index:4;
  width:58px;
  height:58px;
  justify-self:center;
  border:1px solid rgba(255,255,255,.16);
  border-radius:50%;
  color:#fff;
  background:rgba(255,255,255,.07);
  box-shadow:0 16px 34px rgba(0,0,0,.36);
  font-size:2.3rem;
  line-height:1;
  cursor:pointer;
}
.catalog-nav:hover,
.catalog-nav:focus-visible{
  background:rgba(255,255,255,.14);
}
.catalog-footer{
  justify-content:center;
  border-top:1px solid rgba(255,255,255,.1);
  color:rgba(255,255,255,.7);
  font:800 .68rem/1 "Inter",system-ui,sans-serif;
  letter-spacing:.12em;
}
.music-player-app .track-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:12px;
  max-height:555px;
  overflow:auto;
  padding:2px 4px 10px 2px;
  perspective:none;
  scrollbar-color:rgba(255,255,255,.34) rgba(255,255,255,.06);
}
.music-player-app .track-card{
  min-height:0;
  padding:15px;
  border-radius:18px;
  transform:none;
  cursor:pointer;
  background:
    linear-gradient(90deg, rgba(4,7,12,.88), rgba(4,7,12,.66)),
    var(--track-bg),
    rgba(7,9,14,.84);
  background-size:cover;
  background-position:center;
}
.music-player-app .track-card:hover,
.music-player-app .track-card.active{
  transform:translateY(-2px);
  border-color:color-mix(in srgb, var(--track-accent), white 18%);
  box-shadow:0 18px 36px rgba(0,0,0,.45), 0 0 0 1px color-mix(in srgb, var(--track-accent), transparent 42%);
}
.music-player-app .track-card::before{
  background:
    radial-gradient(circle at 15% 0%, color-mix(in srgb, var(--track-accent), transparent 58%), transparent 34%),
    linear-gradient(180deg, rgba(255,255,255,.08), rgba(0,0,0,.2));
}
.music-player-app .track-card::after{
  background:linear-gradient(120deg, var(--track-accent), rgba(95,168,255,.72), rgba(255,188,76,.72));
}
.music-player-app .track-card h3{
  color:#fff;
  font-size:1rem;
  line-height:1.2;
}
.music-player-app .track-card p{
  margin:0;
  font-size:.78rem;
  color:#d8e1ee;
}
.music-player-app .player-shell{
  margin-top:12px;
  grid-template-columns:1fr;
}
.music-player-app .track-actions{
  gap:10px;
}
.music-player-app .play-toggle{
  justify-self:start;
  width:42px;
  height:42px;
  border-radius:50%;
  background:linear-gradient(135deg, var(--track-accent), rgba(255,255,255,.18));
}
.music-player-app .track-share{
  min-height:38px;
  max-width:calc(100% - 54px);
}
.music-player-app .progress-fill{
  background:linear-gradient(90deg, var(--track-accent), rgba(255,255,255,.72));
}
.now-playing-column{
  position:relative;
  overflow:hidden;
}
.music-player-app .library-player{
  --song-bg:url("assets/images/song-backgrounds/tarot-01.png");
  --song-accent:#e13b64;
  --audio-level:.22;
  --audio-pulse-scale:1;
  --audio-pulse-glow:.22;
  --audio-pulse-opacity:.72;
  position:relative;
  inset:auto;
  z-index:1;
  width:100%;
  min-height:100%;
  display:grid;
  grid-template-columns:1fr;
  grid-template-rows:auto minmax(235px,.88fr) auto auto auto auto;
  gap:12px;
  align-items:center;
  justify-items:center;
  padding:24px;
  border:0;
  border-radius:26px;
  overflow:hidden;
  color:#fff;
  background:#07090e;
  box-shadow:none;
  opacity:1;
  transform:none;
  pointer-events:auto;
  isolation:isolate;
}
.music-player-app .library-player::before{
  content:"";
  position:absolute;
  inset:0;
  z-index:-2;
  background:var(--song-bg) center / cover no-repeat;
  filter:saturate(1.12) contrast(1.08) brightness(.58);
  transform:scale(1.08);
}
.music-player-app .library-player::after{
  content:"";
  position:absolute;
  inset:0;
  z-index:-1;
  background:
    radial-gradient(circle at 50% 34%, color-mix(in srgb, var(--song-accent), transparent 70%), transparent 31%),
    linear-gradient(180deg, rgba(2,3,7,.42), rgba(2,3,7,.72) 45%, rgba(2,3,7,.96)),
    linear-gradient(120deg, rgba(93,60,255,.24), transparent 42%, rgba(255,122,39,.2));
}
.mobile-player-top{
  width:100%;
  display:grid;
  grid-template-columns:42px 1fr 42px;
  align-items:center;
  color:#fff;
  font-size:.68rem;
  font-weight:800;
  letter-spacing:.22em;
  text-align:center;
  text-transform:uppercase;
}
.mobile-player-nav,
.mobile-player-favorite{
  width:42px;
  height:42px;
  display:grid;
  place-items:center;
  border:1px solid rgba(255,255,255,.14);
  border-radius:50%;
  color:#fff;
  background:rgba(255,255,255,.06);
  font-size:1.5rem;
}
.mobile-player-favorite{
  padding:0;
  color:var(--song-accent);
  cursor:pointer;
}
.mobile-artwork-stage{
  width:min(315px, 72vw);
  aspect-ratio:1;
  display:grid;
  place-items:center;
  align-self:center;
}
.artwork-orbit{
  position:relative;
  width:100%;
  aspect-ratio:1;
  display:grid;
  place-items:center;
  transform:scale(var(--audio-pulse-scale));
  transition:transform 120ms linear;
}
.artwork-orbit img,
.artwork-orbit video{
  position:relative;
  z-index:1;
  width:67%;
  aspect-ratio:1;
  border-radius:50%;
  object-fit:cover;
  object-position:var(--artwork-position, center);
  transform:translateX(var(--artwork-shift-x, 0));
  display:block;
  border:1px solid rgba(255,255,255,.22);
  box-shadow:
    0 26px 66px rgba(0,0,0,.6),
    0 0 calc(26px + 54px * var(--audio-pulse-glow)) color-mix(in srgb, var(--song-accent), transparent 34%),
    0 0 calc(8px + 24px * var(--audio-level)) rgba(255,255,255,.16);
}
.artwork-orbit img[hidden],
.artwork-orbit video[hidden]{
  display:none;
}
.music-player-app .library-player.has-animated-artwork.full-card-artwork .artwork-orbit video{
  width:76%;
  height:auto;
  max-width:none;
  aspect-ratio:1;
  border-radius:50%;
  object-fit:cover;
}
.music-player-app .library-player.full-card-artwork .artwork-orbit img,
.music-player-app .library-player.full-card-artwork .artwork-orbit video{
  width:auto;
  height:88%;
  max-width:66%;
  aspect-ratio:auto;
  border-radius:14px;
  object-fit:contain;
  background:rgba(0,0,0,.42);
  box-shadow:
    0 26px 66px rgba(0,0,0,.62),
    0 0 calc(24px + 58px * var(--audio-pulse-glow)) color-mix(in srgb, var(--song-accent), transparent 32%),
    0 0 0 1px rgba(255,255,255,.14);
}
.artwork-ring{
  position:absolute;
  z-index:3;
  border-radius:50%;
  pointer-events:none;
}
.artwork-ring-outer{
  inset:4%;
  border:3px solid color-mix(in srgb, var(--song-accent), white 10%);
  box-shadow:
    0 0 calc(18px + 74px * var(--audio-pulse-glow)) color-mix(in srgb, var(--song-accent), transparent 24%),
    0 0 calc(2px + 18px * var(--audio-level)) rgba(255,255,255,.2),
    inset 0 0 calc(24px + 34px * var(--audio-pulse-glow)) rgba(255,255,255,.1);
  opacity:var(--audio-pulse-opacity);
  transform:scale(calc(.995 + .07 * var(--audio-level)));
  animation:artworkPulse 2.4s ease-in-out infinite;
}
.artwork-ring-outer::before{
  content:"";
  position:absolute;
  left:50%;
  top:50%;
  width:16px;
  height:16px;
  border-radius:50%;
  background:var(--song-accent);
  box-shadow:0 0 24px var(--song-accent), 0 0 44px var(--song-accent);
  offset-path:circle(46% at 50% 50%);
  offset-rotate:0deg;
  offset-distance:0%;
  transform:translate(-50%, -50%);
  animation:artworkOrbitDot 11s linear infinite;
}
.artwork-ring-inner{
  inset:13%;
  border:1px solid rgba(255,255,255,.38);
  box-shadow:
    0 0 calc(14px + 34px * var(--audio-pulse-glow)) rgba(255,255,255,.12),
    0 0 calc(8px + 28px * var(--audio-level)) color-mix(in srgb, var(--song-accent), transparent 48%);
  transform:scale(calc(1 + .045 * var(--audio-level)));
  animation:artworkSpin 16s linear infinite reverse;
}
.music-player-app .library-player-meta{
  width:min(520px,100%);
  display:grid;
  gap:5px;
  text-align:center;
}
.music-player-app .library-player-label{
  color:rgba(255,255,255,.72);
  font-size:.66rem;
  letter-spacing:.2em;
}
.music-player-app .library-player strong{
  color:#fff;
  font-size:clamp(1.35rem, 3vw, 2.15rem);
  line-height:1.06;
  text-wrap:balance;
  white-space:normal;
}
.music-player-app .library-player-meta span{
  display:block;
}
#library-player-description{
  color:rgba(255,255,255,.76);
  font-size:.86rem;
}
#library-player-artist{
  color:#f1f5f9;
  font-size:.94rem;
}
.library-player-detail-row{
  display:flex !important;
  justify-content:center;
  gap:14px;
  color:rgba(255,255,255,.78);
  font-size:.78rem;
}
.music-player-app .library-player-progress{
  width:calc(100% - 1in);
  min-width:220px;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:7px 0;
  color:rgba(255,255,255,.82);
}
.music-player-app #library-progress{
  grid-column:1 / -1;
  width:100%;
  height:10px;
  appearance:none;
  -webkit-appearance:none;
  border-radius:999px;
  background:rgba(255,255,255,.18);
  border:1px solid rgba(255,255,255,.16);
}
.music-player-app #library-progress::-webkit-slider-runnable-track{
  height:10px;
  border-radius:999px;
  background:rgba(255,255,255,.18);
}
.music-player-app #library-progress::-webkit-slider-thumb{
  width:18px;
  height:18px;
  margin-top:-4px;
  -webkit-appearance:none;
  border-radius:50%;
  background:var(--song-accent);
  box-shadow:0 0 18px color-mix(in srgb, var(--song-accent), transparent 28%);
}
.music-player-app #library-progress::-moz-range-track{
  height:10px;
  border-radius:999px;
  background:rgba(255,255,255,.18);
  border:1px solid rgba(255,255,255,.16);
}
.music-player-app #library-progress::-moz-range-thumb{
  width:18px;
  height:18px;
  border:0;
  border-radius:50%;
  background:var(--song-accent);
  box-shadow:0 0 18px color-mix(in srgb, var(--song-accent), transparent 28%);
}
.music-player-app #library-current-time{
  justify-self:start;
}
.music-player-app #library-duration{
  justify-self:end;
}
.music-player-app .library-player input[type="range"]{
  accent-color:var(--song-accent);
}
.music-player-app .library-player-controls{
  display:grid;
  grid-template-columns:58px 84px 58px;
  gap:22px;
  justify-content:center;
  align-items:center;
}
.music-player-app .library-player:not(.expanded) #library-prev,
.music-player-app .library-player:not(.expanded) #library-next{
  display:grid;
}
.music-player-app .library-player:not(.expanded) .library-player-volume{
  display:grid;
}
.music-player-app #library-prev,
.music-player-app #library-next{
  width:58px;
  height:58px;
  grid-row:1;
  border-radius:50%;
  font-size:2.2rem;
}
.music-player-app #library-prev{grid-column:1}
.music-player-app #library-next{grid-column:3}
.music-player-app #library-play,
.music-player-app #library-pause{
  grid-column:2;
  grid-row:1;
  width:84px;
  height:84px;
  min-height:84px;
  padding:0;
  border-radius:50%;
  font-size:.78rem;
  background:radial-gradient(circle at 35% 28%, rgba(255,255,255,.28), transparent 32%), var(--song-accent);
  box-shadow:0 0 calc(28px + 36px * var(--audio-level)) color-mix(in srgb, var(--song-accent), transparent 34%), 0 18px 38px rgba(0,0,0,.44);
}
.music-player-app #library-play:disabled,
.music-player-app #library-pause:disabled{
  display:none;
}
.music-player-app #library-stop{
  min-height:38px;
  padding:0 18px;
  border-radius:999px;
  font-size:.68rem;
}
.music-player-app .library-player-volume{
  width:min(360px,100%);
  display:grid;
  grid-template-columns:auto minmax(0,1fr);
  gap:10px;
  justify-content:center;
}
.song-details-column{
  overflow:hidden;
}
.song-details-card{
  --song-bg:url("assets/images/song-backgrounds/tarot-01.png");
  --song-accent:#e13b64;
  position:relative;
  min-height:100%;
  display:grid;
  align-content:stretch;
  overflow:hidden;
  border-radius:inherit;
  isolation:isolate;
}
.song-details-image{
  position:absolute;
  inset:0;
  z-index:-2;
  background:var(--song-bg) center / cover no-repeat;
  filter:saturate(1.12) contrast(1.08) brightness(.62);
  transform:scale(1.04);
}
.song-details-card::after{
  content:"";
  position:absolute;
  inset:0;
  z-index:-1;
  background:
    linear-gradient(180deg, rgba(3,5,9,.12), rgba(3,5,9,.62) 42%, rgba(3,5,9,.96)),
    radial-gradient(circle at 75% 20%, color-mix(in srgb, var(--song-accent), transparent 62%), transparent 34%);
}
.song-details-content{
  display:grid;
  gap:18px;
  align-content:start;
  align-self:stretch;
  padding:24px;
}
.song-details-content h3{
  margin:0;
  color:#fff;
  font-family:var(--display);
  font-size:clamp(1.45rem, 3vw, 2.25rem);
  line-height:1.05;
}
.song-details-content dl{
  display:grid;
  gap:12px;
  margin:0;
}
.song-details-content dl > div{
  padding:12px;
  border:1px solid rgba(255,255,255,.12);
  border-radius:14px;
  background:rgba(3,5,9,.48);
  backdrop-filter:blur(10px);
}
.song-details-content dt{
  color:rgba(255,255,255,.62);
  font-size:.66rem;
  letter-spacing:.16em;
  text-transform:uppercase;
}
.song-details-content dd{
  margin:4px 0 0;
  color:#fff;
}
.song-lyrics-panel{
  min-height:230px;
  max-height:330px;
  display:grid;
  grid-template-rows:auto minmax(0,1fr);
  overflow:hidden;
  border:1px solid color-mix(in srgb, var(--song-accent), rgba(255,255,255,.16) 42%);
  border-radius:14px;
  background:linear-gradient(180deg, rgba(3,5,9,.62), rgba(3,5,9,.38));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.09), 0 18px 34px rgba(0,0,0,.28);
  backdrop-filter:blur(12px);
}
.song-lyrics-panel[hidden]{
  display:none;
}
.song-lyrics-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:13px 14px 10px;
  border-bottom:1px solid rgba(255,255,255,.09);
  color:rgba(255,255,255,.72);
  font:800 .66rem/1 "Inter",system-ui,sans-serif;
  letter-spacing:.14em;
  text-transform:uppercase;
}
#song-lyrics-status{
  color:color-mix(in srgb, var(--song-accent), white 26%);
  text-align:right;
}
.song-lyrics-scroller{
  min-height:0;
  overflow:hidden auto;
  padding:72px 16px;
  scroll-behavior:smooth;
  scrollbar-color:color-mix(in srgb, var(--song-accent), transparent 22%) transparent;
}
.song-lyrics-scroller::-webkit-scrollbar{
  width:7px;
}
.song-lyrics-scroller::-webkit-scrollbar-track{
  background:rgba(255,255,255,.04);
}
.song-lyrics-scroller::-webkit-scrollbar-thumb{
  border-radius:999px;
  background:color-mix(in srgb, var(--song-accent), transparent 22%);
}
.song-lyrics-intro,
.song-lyrics-section{
  margin:0 0 14px;
  color:rgba(255,255,255,.48);
  font:800 .64rem/1 "Inter",system-ui,sans-serif;
  letter-spacing:.16em;
  text-transform:uppercase;
}
.song-lyrics-section{
  margin-top:22px;
  color:color-mix(in srgb, var(--song-accent), white 22%);
}
.song-lyrics-instrumental{
  margin:8px 0 18px;
  padding:12px;
  border:1px solid rgba(255,255,255,.1);
  border-radius:10px;
  color:rgba(255,255,255,.56);
  background:rgba(255,255,255,.045);
  font:800 .7rem/1 "Inter",system-ui,sans-serif;
  letter-spacing:.14em;
  text-align:center;
  text-transform:uppercase;
  transition:color 180ms ease, background 180ms ease, border-color 180ms ease, box-shadow 180ms ease;
}
.song-lyrics-instrumental.is-active{
  border-color:color-mix(in srgb, var(--song-accent), white 12%);
  color:#fff;
  background:color-mix(in srgb, var(--song-accent), transparent 78%);
  box-shadow:0 0 18px color-mix(in srgb, var(--song-accent), transparent 48%);
}
.song-lyrics-instrumental.is-past{
  color:rgba(255,255,255,.42);
}
.song-lyric-line{
  margin:0 0 16px;
  color:rgba(255,255,255,.45);
  font-size:.98rem;
  font-weight:800;
  line-height:1.45;
  transition:color 180ms ease, opacity 180ms ease, transform 180ms ease;
}
.song-lyric-line.is-active{
  color:#fff;
  opacity:1;
  transform:translateX(2px);
}
.song-lyric-line.is-past{
  color:rgba(255,255,255,.6);
}
.song-lyric-word{
  display:inline-block;
  padding:1px 2px 2px;
  border-radius:5px;
  transition:color 120ms ease, background 120ms ease, box-shadow 120ms ease, transform 120ms ease;
}
.song-lyric-word.is-done{
  color:color-mix(in srgb, var(--song-accent), #fff 18%);
}
.song-lyric-word.is-active{
  color:#fff;
  background:linear-gradient(180deg, color-mix(in srgb, var(--song-accent), white 8%), var(--song-accent));
  box-shadow:0 0 18px color-mix(in srgb, var(--song-accent), transparent 34%);
  transform:translateY(-1px);
}

@keyframes artworkSpin{
  to{transform:rotate(360deg)}
}
@keyframes artworkOrbitDot{
  to{offset-distance:100%}
}
@keyframes artworkPulse{
  0%,100%{scale:1}
  50%{scale:calc(1.012 + .06 * var(--audio-level))}
}

@media (min-width: 768px) and (max-width: 1023px){
  .music-player-app{
    grid-template-columns:minmax(240px,.8fr) minmax(0,1.2fr);
  }
  .song-details-column{
    grid-column:1 / -1;
    min-height:320px;
  }
  .song-details-content dl{
    grid-template-columns:repeat(3,minmax(0,1fr));
  }
}

@media (max-width: 767px){
  #music .section-heading{
    margin-bottom:12px;
  }
  #music .section-heading h2{
    font-size:clamp(1.9rem, 9vw, 2.45rem);
  }
  #music .section-heading > p{
    display:none;
  }
  .section-shell#music,
  #music.section-shell{
    width:100%;
    padding:18px 10px 28px;
    border-radius:0;
    border-left:0;
    border-right:0;
  }
  .music-player-app{
    display:flex;
    flex-direction:column;
    min-height:0;
    gap:12px;
  }
  .music-catalog-actions{
    margin:-4px 0 14px;
  }
  .catalog-overlay{
    padding:8px;
  }
  .catalog-shell{
    min-height:calc(100vh - 16px);
    border-radius:14px;
  }
  .catalog-header,
  .catalog-footer{
    padding:14px;
  }
  .catalog-frame{
    min-height:0;
    grid-template-columns:1fr;
  }
  .catalog-stage{
    min-height:610px;
  }
  .catalog-nav{
    position:absolute;
    top:42%;
    z-index:6;
    width:46px;
    height:46px;
    font-size:1.8rem;
    transform:translateY(-50%);
  }
  .catalog-prev{
    left:10px;
  }
  .catalog-next{
    right:10px;
  }
  .catalog-song-card{
    width:min(390px, 82vw);
    min-height:520px;
  }
  .catalog-song-card.is-active{
    transform:translate3d(-50%, -50%, 75px) rotateX(0deg) rotateY(0deg) rotateZ(0deg) scale(1);
  }
  .catalog-song-card.is-prev{
    transform:translate3d(calc(-50% - 58vw), -50%, -90px) rotateY(54deg) scale(.72);
  }
  .catalog-song-card.is-next{
    transform:translate3d(calc(-50% + 58vw), -50%, -90px) rotateY(-54deg) scale(.72);
  }
  .catalog-card-face{
    min-height:520px;
    grid-template-rows:auto 190px auto auto;
    padding:16px;
  }
  .catalog-card-controls{
    grid-template-columns:1fr 1fr;
  }
  .catalog-card-controls label{
    grid-column:1 / -1;
  }
  .now-playing-column{
    order:1;
    border:0;
    background:transparent;
    box-shadow:none;
  }
  .music-library-column{
    order:2;
  }
  .song-details-column{
    order:3;
  }
  .music-column{
    border-radius:22px;
  }
  .music-column > summary{
    display:flex;
    min-height:54px;
    align-items:center;
    justify-content:space-between;
    padding:0 16px;
    color:#fff;
    font-size:.72rem;
    font-weight:900;
    letter-spacing:.18em;
    text-transform:uppercase;
    cursor:pointer;
  }
  .music-column > summary::after{
    content:"+";
    font-size:1.35rem;
    line-height:1;
  }
  .music-column[open] > summary::after{
    content:"-";
  }
  .music-library-column{
    padding:0;
  }
  .music-library-column .music-toolbar,
  .music-library-column .track-grid{
    margin:0 14px 14px;
  }
  .music-player-app .track-grid{
    max-height:62vh;
  }
  .music-player-app .library-player{
    min-height:680px;
    border-radius:30px;
    padding:18px 16px 20px;
    grid-template-rows:auto 252px auto auto auto auto;
    gap:10px;
  }
  .mobile-artwork-stage{
    width:min(286px, 76vw);
  }
  .music-player-app .library-player strong{
    font-size:clamp(1.45rem, 8vw, 2.1rem);
  }
  .music-player-app .library-player-controls{
    grid-template-columns:56px 82px 56px;
    gap:18px;
  }
  .music-player-app #library-play,
  .music-player-app #library-pause{
    width:82px;
    height:82px;
    min-height:82px;
  }
  .song-details-card{
    min-height:0;
    border-radius:0 0 22px 22px;
  }
  .song-details-content{
    padding:0 16px 18px;
  }
  .song-lyrics-panel{
    min-height:260px;
    max-height:42vh;
  }
  .song-lyric-line{
    font-size:.92rem;
  }
}

@media (max-width: 420px){
  .music-player-app .library-player{
    border-radius:24px;
    padding:14px 12px 16px;
    gap:10px;
  }
  .catalog-open-button{
    width:min(100%, 220px);
  }
  .catalog-stage{
    min-height:570px;
  }
  .catalog-song-card{
    width:min(340px, 86vw);
    min-height:500px;
  }
  .catalog-card-face{
    min-height:500px;
    grid-template-rows:auto 170px auto auto;
    padding:14px;
  }
  .catalog-card-copy h4{
    font-size:clamp(1.18rem, 8vw, 1.75rem);
  }
  .catalog-card-controls button{
    padding:0 10px;
  }
  .mobile-player-top{
    grid-template-columns:36px 1fr 36px;
    font-size:.6rem;
  }
  .mobile-player-nav,
  .mobile-player-favorite{
    width:36px;
    height:36px;
  }
  .mobile-artwork-stage{
    width:min(276px, 82vw);
  }
  .music-player-app .library-player-controls{
    grid-template-columns:50px 74px 50px;
    gap:14px;
  }
  .music-player-app #library-prev,
  .music-player-app #library-next{
    width:50px;
    height:50px;
  }
  .music-player-app #library-play,
  .music-player-app #library-pause{
    width:74px;
    height:74px;
    min-height:74px;
  }
  .library-player-detail-row{
    flex-direction:column;
    gap:3px;
  }
}
