: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:90;
  pointer-events:none;
}

.dust-layer{
  position:fixed;
  inset:0;
  z-index:60;
  pointer-events:none;
  opacity:.22;
  background:
    radial-gradient(circle at 12% 20%, rgba(255,255,255,.06) 0 1px, transparent 2px),
    radial-gradient(circle at 65% 40%, rgba(255,255,255,.04) 0 1px, transparent 2px),
    radial-gradient(circle at 80% 20%, rgba(255,255,255,.045) 0 1.3px, transparent 2px),
    radial-gradient(circle at 28% 78%, rgba(255,255,255,.03) 0 1px, transparent 2px),
    radial-gradient(circle at 46% 58%, rgba(198,220,255,.035) 0 1px, transparent 2px),
    radial-gradient(circle at 90% 84%, rgba(255,255,255,.04) 0 1px, transparent 2px);
  background-size:210px 210px, 180px 180px, 250px 250px, 190px 190px, 230px 230px, 170px 170px;
  animation:dustDrift 16s linear infinite;
}
@keyframes dustDrift{
  from{transform:translate3d(0,0,0)}
  to{transform:translate3d(-60px,35px,0)}
}

.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:var(--header-h);
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:24px;
  padding:10px 28px;
  background:linear-gradient(180deg, rgba(2,3,5,.55), rgba(2,3,5,0));
  border-bottom:0;
}
.brand-lockup{
  order:2;
  position:relative;
  display:flex;
  align-items:center;
  flex:0 0 auto;
  isolation:isolate;
}
.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));
}
nav{
  order:1;
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}
nav a{
  padding:10px 14px;
  border-radius:999px;
  font-size:.88rem;
  color:#d9e1ee;
  border:1px solid transparent;
  text-shadow:0 2px 8px rgba(0,0,0,.72);
  transition:all .24s ease;
}
nav a:hover{
  border-color:rgba(175,194,228,.18);
  background:rgba(255,255,255,.04);
}
nav a.active{
  color:#f4e7d5;
  border-color:rgba(177,120,50,.32);
  background:rgba(177,120,50,.08);
  text-shadow:0 0 14px 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:center;
  padding:40px min(7vw,84px) 56px;
  background-image:url("assets/images/Dorian Duerinckx/landing-hero-dorian.png");
  background-size:auto 100vh;
  background-repeat:no-repeat;
  background-position:left 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,.18) 0%, rgba(3,5,7,.04) 34%, rgba(3,5,7,.18) 58%, rgba(3,5,7,.78) 100%),
    linear-gradient(180deg, rgba(0,0,0,.16), rgba(0,0,0,.34));
}

.hero-copy{
  position:relative;
  z-index:2;
  width:min(430px,100%);
  margin-right:clamp(1rem, 4vw, 4rem);
  padding:0;
  border:none;
  border-radius:0;
  background:transparent;
  box-shadow:none;
  backdrop-filter:none;
  text-shadow:0 3px 18px rgba(0,0,0,.72);
}
.eyebrow{
  margin:0 0 10px;
  text-transform:uppercase;
  letter-spacing:.28em;
  font-size:.75rem;
  color:#d0d8e6;
}
.hero h1,
.section-heading h2{
  margin:0;
  font-family:"Cinzel",serif;
  line-height:1.05;
}
.hero h1{
  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:18px 0 0;
  max-width:44ch;
  color:#d7deea;
  line-height:1.75;
  font-size:1.02rem;
}
.hero-actions{
  margin-top:24px;
  display:flex;
  flex-wrap:wrap;
  gap:12px;
}
.button{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:128px;
  padding:13px 18px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.09);
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
  font-size:.78rem;
  transition:transform .2s ease, background .2s ease, border-color .2s ease;
}
.button:hover{transform:translateY(-2px)}
.button-primary{
  background:linear-gradient(135deg, rgba(124,44,34,.92), rgba(109,42,88,.90), rgba(18,52,80,.86));
}
.button-secondary{
  background:rgba(255,255,255,.05);
}

.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;
  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;
  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 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:48px 1fr;
  gap:12px;
  align-items:center;
}
.play-toggle{
  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}
.progress-wrap{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-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-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-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;
    align-items:center;
    flex-wrap:wrap;
  }
  .floating-cubes{
    display:none;
  }
  .dust-layer{
    opacity:.14;
  }
  .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-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;
  }
  nav{
    flex:1 1 auto;
    justify-content:flex-start;
    gap:4px;
  }
  nav a{
    padding:7px 6px;
    font-size:.72rem;
  }
  .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;
  }
  .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;
  }
}
