*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}
:root{
  --black:#050505;--white:#f0ece4;--gray:#888;--dim:#444;--faint:#1a1a1a;
  --glass:rgba(255,255,255,.04);--glass-border:rgba(255,255,255,.06);
  --serif:'Cormorant Garamond',Georgia,serif;--sans:'Syne',sans-serif;
  --safe-bottom:env(safe-area-inset-bottom,0px);--tint:0,0,0;
}
html,body{height:100%;overflow:hidden;font-family:var(--sans);background:var(--black);color:var(--white);
  scrollbar-width:none;-ms-overflow-style:none}
*::-webkit-scrollbar{display:none}
*{scrollbar-width:none;-ms-overflow-style:none}

@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeDown{from{opacity:0;transform:translateY(-16px)}to{opacity:1;transform:translateY(0)}}
@keyframes slideGlass{from{transform:translateX(-100%);opacity:0}to{transform:translateX(0);opacity:1}}
@keyframes expandUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
@keyframes grain{0%,100%{transform:translate(0,0)}10%{transform:translate(-5%,-10%)}30%{transform:translate(3%,2%)}50%{transform:translate(-2%,5%)}70%{transform:translate(5%,-5%)}90%{transform:translate(-3%,8%)}}

.reveal{animation:fadeUp .7s cubic-bezier(.22,1,.36,1) forwards;opacity:0}
.r1{animation-delay:.1s}.r2{animation-delay:.2s}.r3{animation-delay:.3s}
.r4{animation-delay:.4s}.r5{animation-delay:.5s}.r6{animation-delay:.6s}

.grain{position:fixed;top:-50%;left:-50%;width:200%;height:200%;pointer-events:none;z-index:9999;opacity:.025;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");
  animation:grain 8s steps(10) infinite}

#app{height:100%;position:relative;overflow:hidden}
.scene{height:100%;overflow-y:auto;overflow-x:hidden;scroll-behavior:smooth}
.tint{position:fixed;top:0;left:0;right:0;bottom:0;pointer-events:none;z-index:0;
  background:radial-gradient(ellipse at 50% 0%,rgba(var(--tint),.12) 0%,transparent 70%);transition:background 1.5s ease}

.nav-bar{position:fixed;top:0;left:0;right:0;z-index:50;
  display:flex;align-items:center;justify-content:center;padding-top:env(safe-area-inset-top,0px);height:calc(54px + env(safe-area-inset-top,0px));
  background:rgba(5,5,5,.85);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
  border-bottom:1px solid rgba(255,255,255,.04);animation:fadeDown .5s ease forwards}
.nav-bar-center{display:flex;align-items:center;gap:2px;
  background:rgba(255,255,255,.04);border-radius:32px;padding:3px}
.nav-bar-center button{background:none;border:none;color:var(--gray);cursor:pointer;padding:8px 14px;
  border-radius:28px;font-family:var(--sans);font-size:10px;font-weight:600;letter-spacing:.08em;
  text-transform:uppercase;transition:all .3s;display:flex;align-items:center;gap:5px;flex-shrink:0}
.nav-bar-center button:hover{color:var(--white)}
.nav-bar-center button.active{color:var(--white);background:rgba(255,255,255,.08)}
.nav-bar-center button svg{width:16px;height:16px;flex-shrink:0}
.nav-bar .nav-label{display:none}
@media(min-width:900px){
  .nav-bar-center button{padding:8px 18px}
  .nav-bar .nav-label{display:inline}
}

.cover-hero{position:relative;height:85vh;min-height:500px;overflow:hidden;display:flex;align-items:flex-end}
.cover-hero img{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;filter:brightness(.4) contrast(1.1);transition:transform 8s ease}
.cover-hero:hover img{transform:scale(1.03)}
.cover-hero-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(transparent 30%,rgba(5,5,5,.6) 60%,var(--black) 100%)}
.cover-hero-watermark{position:absolute;top:50%;left:50%;transform:translate(-50%,-55%);z-index:1;
  font-family:var(--sans);font-size:clamp(60px,15vw,240px);font-weight:900;letter-spacing:-.04em;
  color:transparent;-webkit-text-stroke:1px rgba(200,160,80,.15);
  text-transform:uppercase;pointer-events:none;
  background:linear-gradient(180deg,rgba(200,160,80,.12) 0%,rgba(200,160,80,.04) 100%);
  -webkit-background-clip:text;background-clip:text;
  width:100%;text-align:center;box-sizing:border-box;overflow:hidden;padding:0 5%}
.cover-hero-content{position:relative;z-index:2;padding:0 8% 8vh;width:100%}
.cover-label{font-family:var(--sans);font-size:10px;font-weight:700;letter-spacing:.25em;text-transform:uppercase;color:var(--gray);margin-bottom:16px}
.cover-title{font-family:var(--serif);font-size:clamp(48px,10vw,120px);font-weight:300;line-height:.9;letter-spacing:-.02em;margin-bottom:16px;font-style:italic}
.cover-sub{font-family:var(--sans);font-size:13px;color:var(--gray);font-weight:400;letter-spacing:.04em;max-width:400px;line-height:1.6}

.editorial{padding:0 8% 120px}
.section-label{font-family:var(--sans);font-size:10px;font-weight:700;letter-spacing:.3em;text-transform:uppercase;color:var(--dim);margin-bottom:40px;padding-top:80px}

/* Discover artist grid */
.artist-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:32px 24px;padding:20px 0 40px}
.artist-grid-item{text-align:center;cursor:pointer;transition:transform .3s}
.artist-grid-item:hover{transform:translateY(-4px)}
.artist-grid-item img{width:100px;height:100px;border-radius:50%;object-fit:cover;margin-bottom:12px;
  border:2px solid rgba(255,255,255,.06);transition:border-color .3s}
.artist-grid-item:hover img{border-color:rgba(255,255,255,.15)}
.artist-grid-name{font-family:var(--serif);font-size:16px;font-weight:400;font-style:italic;margin-bottom:4px}
.artist-grid-genre{font-family:var(--sans);font-size:8px;font-weight:600;letter-spacing:.15em;text-transform:uppercase;color:var(--dim)}

/* Collection sections */
.collection-album-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:20px;padding:20px 0}

/* === STATIONS === */
.radio-dial{position:relative;margin:40px 0;padding:20px 0;border-top:1px solid var(--faint);border-bottom:1px solid var(--faint);overflow:hidden;touch-action:none;cursor:grab;user-select:none;-webkit-user-select:none}
.radio-dial:active{cursor:grabbing}
.radio-dial-track{position:relative;height:80px;display:flex;align-items:center}
.radio-dial-band{position:absolute;left:0;top:0;height:100%;transition:transform .1s ease-out;display:flex;align-items:flex-end;gap:6px;padding-bottom:30px}
.radio-dial-tick{width:1px;height:16px;background:rgba(255,255,255,.08);flex-shrink:0}
.radio-dial-tick.major{height:28px;background:rgba(255,255,255,.15)}
.radio-dial-freq{position:absolute;top:4px;font-family:var(--sans);font-size:8px;color:var(--dim);letter-spacing:.05em;transform:translateX(-50%);white-space:nowrap}
.radio-dial-station{position:absolute;bottom:0;display:flex;flex-direction:column;align-items:center;transform:translateX(-50%);cursor:pointer;transition:all .3s}
.radio-dial-station-dot{width:8px;height:8px;border-radius:50%;background:var(--dim);transition:all .3s;margin-bottom:4px}
.radio-dial-station-name{font-family:var(--sans);font-size:7px;letter-spacing:.08em;text-transform:uppercase;color:var(--dim);transition:color .3s;white-space:nowrap}
.radio-dial-station.active .radio-dial-station-dot{background:var(--white);box-shadow:0 0 12px rgba(255,255,255,.4)}
.radio-dial-station.active .radio-dial-station-name{color:var(--white)}
.radio-needle{position:absolute;left:50%;top:0;bottom:0;width:2px;background:var(--white);z-index:3;transform:translateX(-50%);box-shadow:0 0 8px rgba(255,255,255,.3)}
.radio-needle::before{content:'';position:absolute;top:-6px;left:50%;transform:translateX(-50%);width:0;height:0;border-left:5px solid transparent;border-right:5px solid transparent;border-top:6px solid var(--white)}
.radio-now{text-align:center;padding:24px 0;min-height:80px}
.radio-freq-display{font-family:var(--sans);font-size:clamp(40px,10vw,64px);font-weight:800;letter-spacing:-.02em;color:var(--white);transition:opacity .3s}
.radio-freq-display.static{opacity:.4}
.radio-freq-label{font-family:var(--sans);font-size:9px;font-weight:600;letter-spacing:.25em;text-transform:uppercase;color:var(--dim);margin-top:4px}
.radio-station-name{font-family:var(--serif);font-size:clamp(22px,5vw,36px);font-style:italic;color:var(--white);margin-top:8px;transition:opacity .3s;min-height:36px}
.radio-static-bar{height:3px;background:rgba(255,255,255,.06);border-radius:2px;margin:12px auto 0;max-width:200px;overflow:hidden}
.radio-static-bar-fill{height:100%;background:var(--white);border-radius:2px;transition:width .15s}
.station-card{display:grid;grid-template-columns:auto 1fr auto;gap:16px;align-items:center;padding:16px;
  border:1px solid rgba(255,255,255,.06);border-radius:8px;cursor:pointer;transition:all .3s;margin-bottom:12px}
.station-card:hover{border-color:rgba(255,255,255,.12);background:rgba(255,255,255,.02)}
.station-card-freq{font-family:var(--sans);font-size:28px;font-weight:800;color:var(--white);min-width:56px;text-align:center}
.station-card-info{display:flex;flex-direction:column;gap:3px}
.station-card-name{font-family:var(--serif);font-size:16px;font-style:italic}
.station-card-desc{font-family:var(--sans);font-size:9px;color:var(--dim);letter-spacing:.05em}
.station-card-count{font-family:var(--sans);font-size:9px;color:var(--dim)}
.station-card.active{border-color:rgba(255,255,255,.25);background:rgba(255,255,255,.04)}
.station-card.active .station-card-freq{text-shadow:0 0 12px rgba(255,255,255,.3)}
.station-eq{display:flex;align-items:flex-end;gap:2px;height:16px}
.station-eq-bar{width:3px;background:var(--white);border-radius:1px;animation:eqBounce .6s ease infinite alternate}
.station-eq-bar:nth-child(2){animation-delay:.15s}
.station-eq-bar:nth-child(3){animation-delay:.3s}
@keyframes eqBounce{0%{height:4px}100%{height:16px}}

/* Station Builder */
.station-builder{border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:24px;margin-bottom:24px;background:rgba(255,255,255,.02)}
.station-builder-row{display:flex;gap:12px;margin-bottom:20px;position:relative;align-items:flex-end;overflow:hidden}
.station-builder-input{flex:1;min-width:0;background:none;border:none;border-bottom:1px solid rgba(255,255,255,.15);
  color:var(--white);font-family:var(--serif);font-size:18px;font-style:italic;padding:8px 0;outline:none}
.station-builder-input::placeholder{color:var(--dim)}
.station-builder-input:focus{border-color:rgba(255,255,255,.4)}
.station-builder-freq-input{width:80px;background:none;border:none;border-bottom:1px solid rgba(255,255,255,.15);
  color:var(--white);font-family:var(--sans);font-size:24px;font-weight:800;text-align:center;padding:8px 0;outline:none}
.station-builder-freq-input::placeholder{color:var(--dim)}
.station-builder-freq-input:focus{border-color:rgba(255,255,255,.4)}
.station-builder-freq-label{font-family:var(--sans);font-size:10px;color:var(--dim);letter-spacing:.1em;align-self:flex-end;padding-bottom:10px}
.station-builder-albums{display:flex;gap:12px;overflow-x:auto;padding:8px 0 16px;-webkit-overflow-scrolling:touch}
.station-builder-albums::-webkit-scrollbar{display:none}
.station-builder-album{flex-shrink:0;width:80px;cursor:pointer;opacity:.5;transition:all .3s;text-align:center}
.station-builder-album.selected{opacity:1}
.station-builder-album img{width:80px;height:80px;object-fit:cover;border-radius:4px;border:2px solid transparent;transition:border-color .3s}
.station-builder-album.selected img{border-color:var(--white)}
.station-builder-album-name{font-family:var(--sans);font-size:8px;color:var(--dim);margin-top:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.station-builder-tracks{max-height:300px;overflow-y:auto;margin-bottom:16px}
.station-builder-track{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:6px;cursor:pointer;transition:all .2s}
.station-builder-track:hover{background:rgba(255,255,255,.03)}
.station-builder-track.added{background:rgba(255,255,255,.06)}
.station-builder-track-check{width:18px;height:18px;border-radius:50%;border:1px solid rgba(255,255,255,.2);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .2s;font-size:10px}
.station-builder-track.added .station-builder-track-check{background:var(--white);color:var(--black);border-color:var(--white)}
.station-builder-track-name{font-family:var(--serif);font-size:14px;font-style:italic;flex:1}
.station-builder-track-artist{font-family:var(--sans);font-size:9px;color:var(--dim)}
.station-builder-footer{display:flex;justify-content:space-between;align-items:center;padding-top:16px;border-top:1px solid rgba(255,255,255,.06)}
.station-builder-count{font-family:var(--sans);font-size:11px;color:var(--gray)}
.station-builder-save{background:none;border:1px solid rgba(255,255,255,.2);border-radius:24px;
  padding:10px 28px;font-family:var(--sans);font-size:10px;font-weight:600;letter-spacing:.15em;
  text-transform:uppercase;color:var(--white);cursor:pointer;transition:all .3s}
.station-builder-save:hover{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.3)}
.station-builder-save:disabled{opacity:.3;cursor:default}
.create-station-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:16px;
  background:none;border:1px dashed rgba(255,255,255,.15);border-radius:8px;cursor:pointer;
  font-family:var(--sans);font-size:10px;font-weight:600;letter-spacing:.15em;text-transform:uppercase;
  color:var(--gray);transition:all .3s}
.create-station-btn:hover{border-color:rgba(255,255,255,.3);color:var(--white);background:rgba(255,255,255,.02)}
.create-station-btn svg{width:16px;height:16px}

/* Similar artists discovery card */
.similar-card{display:grid;grid-template-columns:1fr 1fr;margin-bottom:40px;min-height:300px;border-radius:6px;overflow:hidden;background:rgba(255,255,255,.02)}
.similar-card-img{position:relative;overflow:hidden}
.similar-card-img img{width:100%;height:100%;object-fit:cover;filter:brightness(.4)}
.similar-card-img-overlay{position:absolute;bottom:0;left:0;right:0;padding:20px;
  background:linear-gradient(transparent,rgba(5,5,5,.8))}
.similar-card-title{font-family:var(--serif);font-size:clamp(16px,2.5vw,24px);font-weight:300;font-style:italic;line-height:1.2}
.similar-card-right{display:flex;flex-direction:column;justify-content:center;padding:24px;gap:16px}
.similar-card-label{font-family:var(--sans);font-size:9px;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--dim)}
.similar-card-artists{display:flex;flex-direction:column;gap:12px}
.similar-card-artist{display:flex;align-items:center;gap:12px;cursor:pointer;padding:10px 14px;
  border-radius:28px;border:1px solid rgba(255,255,255,.08);
  transition:all .3s}
.similar-card-artist:hover{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.15)}
.similar-card-artist img{width:40px;height:40px;border-radius:50%;object-fit:cover}
.similar-card-artist-name{font-family:var(--serif);font-size:15px;font-style:italic}
.similar-card-artist-genre{font-family:var(--sans);font-size:8px;letter-spacing:.12em;text-transform:uppercase;color:var(--dim)}
.collection-album{cursor:pointer;transition:transform .3s}
.collection-album:hover{transform:translateY(-4px)}
.collection-album img{width:100%;aspect-ratio:1;object-fit:cover;border-radius:4px;margin-bottom:8px}
.collection-album-title{font-family:var(--serif);font-size:14px;font-weight:400;font-style:italic;margin-bottom:2px}
.collection-album-sub{font-family:var(--sans);font-size:9px;color:var(--dim);letter-spacing:.08em}
.spread{display:grid;grid-template-columns:1fr 1fr;gap:0;margin-bottom:100px;cursor:pointer;transition:transform .5s cubic-bezier(.22,1,.36,1)}
.spread:hover{transform:translateY(-4px)}
.spread-img{position:relative;overflow:hidden;aspect-ratio:1}
.spread-img img{width:100%;height:100%;object-fit:cover;transition:transform .8s cubic-bezier(.22,1,.36,1)}
.spread:hover .spread-img img{transform:scale(1.04)}
.spread-text{display:flex;flex-direction:column;justify-content:center;padding:10% 8%}
.spread-eyebrow{font-family:var(--sans);font-size:9px;font-weight:700;letter-spacing:.3em;text-transform:uppercase;color:var(--dim);margin-bottom:16px}
.spread-title{font-family:var(--serif);font-size:clamp(28px,4vw,52px);font-weight:300;font-style:italic;line-height:1;margin-bottom:20px}
.spread-desc{font-family:var(--sans);font-size:12px;color:var(--gray);line-height:1.7;max-width:340px}
.spread-cta{margin-top:24px;font-family:var(--sans);font-size:10px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--white);opacity:.5;transition:opacity .3s}
.spread:hover .spread-cta{opacity:1}

/* Alternating layout — flip image and text sides */
.spread.flip{direction:rtl}
.spread.flip>*{direction:ltr}

/* Vertical image spread — taller image */
.spread.vertical .spread-img{aspect-ratio:2/3}

/* Full-width feature image */
.spread-full{position:relative;margin-bottom:100px;cursor:pointer;overflow:hidden;border-radius:2px;
  transition:transform .5s cubic-bezier(.22,1,.36,1)}
.spread-full:hover{transform:translateY(-4px)}
.spread-full img{width:100%;aspect-ratio:16/9;object-fit:cover;display:block;
  filter:brightness(.5);transition:all .8s cubic-bezier(.22,1,.36,1)}
.spread-full:hover img{transform:scale(1.02);filter:brightness(.6)}
.spread-full-overlay{position:absolute;bottom:0;left:0;right:0;padding:8%;
  background:linear-gradient(transparent,rgba(5,5,5,.8))}
.spread-full-eyebrow{font-family:var(--sans);font-size:9px;font-weight:700;letter-spacing:.3em;
  text-transform:uppercase;color:var(--dim);margin-bottom:12px}
.spread-full-title{font-family:var(--serif);font-size:clamp(24px,3.5vw,44px);font-weight:300;
  font-style:italic;line-height:1.1;margin-bottom:8px}
.spread-full-desc{font-family:var(--sans);font-size:12px;color:var(--gray);line-height:1.6;max-width:500px}

/* Lyric highlight card */
.lyric-card{padding:60px 12%;text-align:center;margin-bottom:80px;position:relative}
.lyric-card-text{font-family:var(--serif);font-size:clamp(20px,3vw,36px);font-weight:300;
  font-style:italic;line-height:1.5;color:var(--white);margin-bottom:16px}
.lyric-card-attr{font-family:var(--sans);font-size:9px;font-weight:600;letter-spacing:.25em;
  text-transform:uppercase;color:var(--dim)}

.pullquote{font-family:var(--serif);font-size:clamp(24px,3.5vw,44px);font-style:italic;font-weight:300;line-height:1.4;color:var(--gray);padding:80px 12%;text-align:center;border-top:1px solid var(--faint);border-bottom:1px solid var(--faint);margin-bottom:100px}

.stats{display:flex;justify-content:center;gap:48px;padding:40px 0;margin-bottom:60px}
.stat-num{font-family:var(--serif);font-size:36px;font-weight:300;font-style:italic}
.stat-label{font-family:var(--sans);font-size:9px;font-weight:700;letter-spacing:.25em;text-transform:uppercase;color:var(--dim);margin-top:4px;text-align:center}

.artist-hero{position:relative;height:80vh;min-height:450px;overflow:visible;display:flex;align-items:flex-end}
.artist-hero>img{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;filter:brightness(.35) contrast(1.1) saturate(1.1)}
.artist-hero-grad{position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(transparent 40%,var(--black) 100%)}
.artist-hero-content{position:relative;z-index:2;padding:0 8% 6vh;width:100%}
.artist-name{font-family:var(--serif);font-size:clamp(56px,12vw,140px);font-weight:300;font-style:italic;line-height:.85;letter-spacing:-.03em;margin-bottom:12px;max-width:65%}
.artist-genre{font-family:var(--sans);font-size:11px;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--gray)}
.artist-body{padding:0 8% 120px;position:relative}

/* Parallax avatar — 3x bigger on desktop */
.artist-avatar-frame{position:absolute;z-index:10;right:8%;bottom:-100px;
  width:clamp(140px,25vw,360px);aspect-ratio:1;
  border-radius:6px;overflow:hidden;
  box-shadow:0 24px 60px rgba(0,0,0,.7),0 0 0 1px rgba(255,255,255,.08),0 0 80px rgba(var(--tint),.15);
  transform:perspective(800px) rotateY(-2deg) rotateX(1deg);
  transition:transform .5s cubic-bezier(.22,1,.36,1),box-shadow .5s ease}
.artist-avatar-frame:hover{transform:perspective(800px) rotateY(0deg) rotateX(0deg) translateY(-4px);
  box-shadow:0 32px 80px rgba(0,0,0,.8),0 0 0 1px rgba(255,255,255,.12),0 0 100px rgba(var(--tint),.2)}
.artist-avatar-frame img{width:100%;height:100%;object-fit:cover;display:block}

/* Tune In button — broadcast signal animation */
.tunein-btn{display:flex;align-items:center;gap:10px;background:none;
  border:1px solid rgba(255,255,255,.15);border-radius:28px;padding:8px 20px 8px 14px;
  cursor:pointer;transition:all .4s;position:relative;overflow:hidden;font-family:var(--sans)}
.tunein-btn:hover{border-color:rgba(255,255,255,.3)}
.tunein-icon{width:20px;height:20px;position:relative;display:flex;align-items:center;justify-content:center}
.tunein-icon svg{width:20px;height:20px;color:var(--gray);transition:color .3s}
.tunein-label{font-size:10px;font-weight:600;letter-spacing:.15em;text-transform:uppercase;
  color:var(--gray);transition:color .3s}
.tunein-btn:hover .tunein-label,.tunein-btn:hover .tunein-icon svg{color:var(--white)}

/* Signal rings animation */
.tunein-rings{position:absolute;top:50%;left:22px;transform:translate(-50%,-50%);pointer-events:none}
.tunein-ring{position:absolute;top:50%;left:50%;width:8px;height:8px;
  border:1px solid var(--white);border-radius:50%;
  transform:translate(-50%,-50%);opacity:0}

.tunein-btn.tuning .tunein-ring:nth-child(1){animation:signalPulse .8s ease-out forwards}
.tunein-btn.tuning .tunein-ring:nth-child(2){animation:signalPulse .8s ease-out .15s forwards}
.tunein-btn.tuning .tunein-ring:nth-child(3){animation:signalPulse .8s ease-out .3s forwards}

/* Tuned in state */
.tunein-btn.tuned{border-color:rgba(255,255,255,.25);background:rgba(255,255,255,.04)}
.tunein-btn.tuned .tunein-icon svg{color:var(--white)}
.tunein-btn.tuned .tunein-label{color:var(--white)}
.tunein-btn.tuned .tunein-glow{position:absolute;top:50%;left:22px;width:6px;height:6px;
  border-radius:50%;background:var(--white);transform:translate(-50%,-50%);
  box-shadow:0 0 8px rgba(255,255,255,.4);animation:glowPulse 2s ease infinite}

@keyframes signalPulse{
  0%{width:8px;height:8px;opacity:.8}
  100%{width:40px;height:40px;opacity:0}
}
@keyframes glowPulse{
  0%,100%{opacity:.6;box-shadow:0 0 6px rgba(255,255,255,.3)}
  50%{opacity:1;box-shadow:0 0 12px rgba(255,255,255,.5)}
}

/* Artist name link */
.artist-link{cursor:pointer;text-decoration:none;color:inherit;transition:color .3s}
.artist-link:hover{color:var(--white);text-decoration:underline;text-underline-offset:3px}

.bio{max-width:600px;margin-bottom:80px}
.bio p{font-family:var(--serif);font-size:20px;font-weight:300;line-height:1.8;color:var(--gray);font-style:italic}

.album-feature{display:grid;grid-template-columns:1.2fr 1fr;gap:60px;align-items:start;margin-bottom:80px}
.album-feature-art img{width:100%;border-radius:2px;box-shadow:0 40px 80px rgba(0,0,0,.5);cursor:pointer}
.album-feature-label{font-family:var(--sans);font-size:9px;font-weight:700;letter-spacing:.3em;text-transform:uppercase;color:var(--dim);margin-bottom:12px}
.album-feature-title{font-family:var(--serif);font-size:clamp(32px,5vw,56px);font-weight:300;font-style:italic;line-height:1;margin-bottom:8px}
.album-feature-year{font-family:var(--sans);font-size:11px;color:var(--dim);letter-spacing:.1em;margin-bottom:40px}

.tracklist{list-style:none}
.track{display:flex;align-items:center;padding:18px 0;border-bottom:1px solid rgba(255,255,255,.04);cursor:pointer;transition:all .3s;gap:16px;position:relative}
.track:hover{padding-left:12px}
.track:first-child{border-top:1px solid rgba(255,255,255,.04)}
.track-num{font-family:var(--serif);font-size:14px;color:var(--dim);width:28px;text-align:center;flex-shrink:0;font-style:italic}
.track-name{font-family:var(--serif);font-size:clamp(18px,2.5vw,28px);font-weight:400;flex:1;transition:color .3s}
.track:hover .track-name{color:var(--white)}
.track-actions{display:flex;align-items:center;gap:12px}
.track-dur{font-family:var(--sans);font-size:11px;color:var(--dim);letter-spacing:.05em;flex-shrink:0}
.track.playing .track-name{color:var(--white)}
.track.playing .track-num{color:var(--white)}
.track-progress{position:absolute;bottom:0;left:0;height:1px;background:var(--white);transition:width .3s linear}

.lyrics-btn{background:none;border:1px solid rgba(255,255,255,.1);border-radius:20px;padding:4px 12px;color:var(--gray);font-family:var(--sans);font-size:9px;font-weight:600;letter-spacing:.15em;text-transform:uppercase;cursor:pointer;transition:all .3s}
.lyrics-btn:hover{border-color:var(--white);color:var(--white)}

.play-area{display:flex;align-items:center;gap:24px;margin-bottom:48px}
.play-circle{width:52px;height:52px;border-radius:50%;border:1px solid rgba(255,255,255,.2);background:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--white);transition:all .4s}
.play-circle:hover{background:var(--white);color:var(--black);border-color:var(--white)}
.play-circle svg{width:18px;height:18px;margin-left:2px}

.index{padding:100px 8% 120px}
.index-title{font-family:var(--serif);font-size:clamp(36px,6vw,72px);font-weight:300;font-style:italic;margin-bottom:48px}
.search-field{background:none;border:none;border-bottom:1px solid var(--faint);font-family:var(--serif);font-size:28px;font-weight:300;font-style:italic;color:var(--white);width:100%;padding:16px 0;outline:none;margin-bottom:48px;transition:border-color .3s}
.search-field:focus{border-color:rgba(255,255,255,.2)}
.search-field::placeholder{color:var(--dim)}
.index-entry{display:flex;align-items:center;gap:20px;padding:20px 0;border-bottom:1px solid rgba(255,255,255,.03);cursor:pointer;transition:all .3s}
.index-entry:hover{padding-left:12px}
.index-entry img{width:56px;height:56px;border-radius:50%;object-fit:cover;flex-shrink:0}
.index-entry-name{font-family:var(--serif);font-size:24px;font-weight:400;font-style:italic;flex:1}
.index-entry-genre{font-family:var(--sans);font-size:10px;color:var(--dim);letter-spacing:.15em;text-transform:uppercase}

.library{padding:100px 8% 120px}
.library-title{font-family:var(--serif);font-size:clamp(36px,6vw,72px);font-weight:300;font-style:italic;margin-bottom:48px}
.library-section{margin-bottom:64px}
.library-section-label{font-family:var(--sans);font-size:10px;font-weight:700;letter-spacing:.3em;text-transform:uppercase;color:var(--dim);margin-bottom:24px}
.album-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:32px}
.album-card{cursor:pointer;transition:transform .5s cubic-bezier(.22,1,.36,1)}
.album-card:hover{transform:translateY(-6px)}
.album-card img{width:100%;aspect-ratio:1;object-fit:cover;border-radius:2px;box-shadow:0 20px 60px rgba(0,0,0,.4)}
.album-card-title{font-family:var(--serif);font-size:18px;font-weight:400;font-style:italic;margin-top:14px}
.album-card-sub{font-family:var(--sans);font-size:10px;color:var(--dim);margin-top:4px}

.player-float{position:fixed;bottom:calc(20px + env(safe-area-inset-bottom,0px));left:50%;transform:translateX(-50%);z-index:60;
  display:flex;align-items:center;gap:14px;padding:10px 14px 10px 10px;
  background:rgba(15,15,15,.8);backdrop-filter:blur(30px);-webkit-backdrop-filter:blur(30px);
  border:1px solid var(--glass-border);border-radius:50px;cursor:pointer;
  animation:expandUp .4s cubic-bezier(.22,1,.36,1) forwards;max-width:440px;width:90%;transition:all .3s}
.player-float:hover{background:rgba(20,20,20,.9);border-color:rgba(255,255,255,.1)}
.player-float img{width:40px;height:40px;border-radius:50%;object-fit:cover;flex-shrink:0}
.player-float-info{flex:1;min-width:0}
.player-float-title{font-family:var(--serif);font-size:14px;font-style:italic;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.player-float-artist{font-family:var(--sans);font-size:9px;color:var(--dim);letter-spacing:.1em;text-transform:uppercase;margin-top:1px}
.player-float-btn{background:none;border:none;color:var(--white);cursor:pointer;padding:6px;display:flex;align-items:center}
.player-float-btn svg{width:18px;height:18px}

.player-full{position:fixed;top:0;left:0;right:0;bottom:0;z-index:80;background:var(--black);
  display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 8%;
  animation:expandUp .5s cubic-bezier(.22,1,.36,1)}
.player-full-close{position:absolute;top:calc(20px + env(safe-area-inset-top,0px));right:24px;background:none;border:none;color:var(--gray);cursor:pointer;font-family:var(--sans);font-size:10px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;padding:10px;transition:color .3s}
.player-full-close:hover{color:var(--white)}
.player-full-art{width:min(320px,60vw);aspect-ratio:1;border-radius:4px;object-fit:cover;box-shadow:0 40px 100px rgba(0,0,0,.6);margin-bottom:40px}
.player-full-title{font-family:var(--serif);font-size:clamp(24px,4vw,36px);font-weight:400;font-style:italic;text-align:center;margin-bottom:4px}
.player-full-artist{font-family:var(--sans);font-size:10px;color:var(--dim);letter-spacing:.2em;text-transform:uppercase;text-align:center;margin-bottom:32px}
.player-full-bar{width:100%;max-width:400px;height:2px;background:rgba(255,255,255,.08);border-radius:1px;cursor:pointer;margin-bottom:8px}
.player-full-fill{height:100%;background:var(--white);border-radius:1px;transition:width .3s linear}
.player-full-times{display:flex;justify-content:space-between;width:100%;max-width:400px;margin-bottom:32px}
.player-full-time{font-family:var(--sans);font-size:10px;color:var(--dim)}
.player-full-controls{display:flex;align-items:center;gap:28px}
.player-full-main{width:48px;height:48px;border-radius:50%;border:1px solid rgba(255,255,255,.3);background:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--white);transition:all .3s}
.player-full-main:hover{background:var(--white);color:var(--black);border-color:var(--white)}
.player-full-main svg{width:18px;height:18px}
.pf-sec{background:none;border:none;color:var(--dim);cursor:pointer;padding:4px;transition:color .3s}
.pf-sec:hover{color:var(--white)}
.pf-sec svg{width:20px;height:20px}
.player-lyrics{margin-top:32px;max-width:400px;max-height:160px;overflow-y:auto;text-align:center}
.player-lyrics-line{font-family:var(--serif);font-size:15px;font-style:italic;color:rgba(255,255,255,.7);line-height:2}

.lyrics-overlay{position:fixed;top:0;left:0;right:0;bottom:0;z-index:90;
  background:rgba(5,5,5,.92);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  display:flex;align-items:center;justify-content:center;animation:fadeIn .3s ease}
.lyrics-modal{max-width:480px;width:90%;max-height:80vh;overflow-y:auto;padding:40px;text-align:center}
.lyrics-modal-title{font-family:var(--serif);font-size:28px;font-weight:300;font-style:italic;margin-bottom:4px}
.lyrics-modal-sub{font-family:var(--sans);font-size:9px;color:var(--dim);letter-spacing:.2em;text-transform:uppercase;margin-bottom:36px}
.lyrics-modal-section{font-family:var(--sans);font-size:9px;font-weight:700;letter-spacing:.25em;text-transform:uppercase;color:var(--dim);margin:28px 0 10px}
.lyrics-modal-line{font-family:var(--serif);font-size:18px;font-weight:300;font-style:italic;line-height:2;color:var(--gray)}
.lyrics-modal-close{position:fixed;top:24px;right:24px;background:none;border:none;color:var(--gray);cursor:pointer;font-family:var(--sans);font-size:10px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;padding:10px;z-index:91}
.lyrics-modal-close:hover{color:var(--white)}

.back{position:fixed;top:20px;left:24px;z-index:50;background:none;border:none;color:var(--gray);cursor:pointer;padding:8px;transition:color .3s;display:flex;align-items:center;gap:6px;font-family:var(--sans);font-size:10px;font-weight:600;letter-spacing:.15em;text-transform:uppercase}
.back:hover{color:var(--white)}
.back svg{width:18px;height:18px}

/* Vinyl Collect Button — slides into sleeve */
.collect-btn{background:none;border:none;cursor:pointer;padding:2px;position:relative;
  display:flex;align-items:center;width:40px;height:24px;overflow:visible;transition:all .3s}
.vinyl-wrap{position:relative;width:20px;height:20px;display:flex;align-items:center}
.vinyl-wrap svg{width:18px;height:18px;position:relative;z-index:2;transition:all .6s cubic-bezier(.22,1,.36,1)}
.collect-btn .vinyl-disc{color:var(--dim);transition:color .3s}
.collect-btn:hover .vinyl-disc{color:var(--gray)}

/* The sleeve — sits to the right, vinyl slides into it */
.vinyl-sleeve{position:absolute;right:0;top:50%;transform:translateY(-50%);
  width:16px;height:20px;border-radius:2px;
  border:1px solid rgba(255,255,255,.1);border-left:none;
  background:rgba(255,255,255,.03);opacity:0;transition:opacity .3s}

/* Collecting animation */
.collect-btn.collecting .vinyl-sleeve{opacity:1;animation:sleeveAppear .2s ease forwards}
.collect-btn.collecting .vinyl-wrap svg{animation:vinylSlideIn .7s cubic-bezier(.22,1,.36,1) forwards}

/* Collected state — disc rests inside sleeve */
.collect-btn.collected .vinyl-disc{color:var(--white)}
.collect-btn.collected .vinyl-sleeve{opacity:1;border-color:rgba(255,255,255,.2);background:rgba(255,255,255,.06)}
.collect-btn.collected .vinyl-wrap svg{transform:translateX(8px) scale(.7)}

@keyframes sleeveAppear{
  0%{opacity:0;width:0}
  100%{opacity:1;width:16px}
}
@keyframes vinylSlideIn{
  0%{transform:translateX(0) rotate(0deg) scale(1)}
  30%{transform:translateX(-3px) rotate(-15deg) scale(.95)}
  60%{transform:translateX(5px) rotate(180deg) scale(.75)}
  100%{transform:translateX(8px) rotate(360deg) scale(.7)}
}

@media(max-width:768px){
  .cover-hero{height:70vh;min-height:400px}
  .cover-hero-content{padding:0 6% 6vh}
  .spread{grid-template-columns:1fr}
  .spread.flip{direction:ltr}
  .spread-text{padding:8% 0}
  .spread-full-overlay{padding:6%}
  .editorial{padding:0 6% 120px}
  .stats{gap:24px}
  .artist-hero{height:60vh}
  .artist-hero-content{padding:0 6% 4vh}
  .artist-name{max-width:55%;font-size:clamp(40px,10vw,80px)}
  .artist-body{padding:40px 6% 120px}
  .artist-avatar-frame{right:6%;bottom:-50px;width:120px!important}
  .similar-card{grid-template-columns:1fr;min-height:auto}
  .similar-card-img{min-height:200px}
  .album-feature{grid-template-columns:1fr;gap:32px}
  .index{padding:80px 6% 120px}
  .library{padding:80px 6% 120px}
  .album-grid{grid-template-columns:repeat(2,1fr);gap:16px}
  .player-float{bottom:12px;max-width:92%}
  .pullquote{padding:48px 6%}
  .lyric-card{padding:40px 6%}
  .back{top:14px;left:14px}
}

/* ==========================================
   AUTH — Login, Profile Pill, Menu
   ========================================== */

/* Login Screen */
.auth-screen{position:fixed;inset:0;z-index:9999;background:#050505;display:flex;align-items:center;justify-content:center;padding:40px}
.auth-content{text-align:center;width:100%;max-width:360px}
.auth-logo{font-family:var(--sans);font-size:clamp(48px,12vw,80px);font-weight:800;letter-spacing:-.04em;color:var(--white);margin-bottom:12px}
.auth-tagline{font-family:var(--serif);font-size:16px;font-style:italic;color:var(--gray);margin-bottom:48px}
.auth-google-btn{display:inline-flex;align-items:center;justify-content:center;background:#fff;color:#333;border:none;border-radius:28px;padding:14px 32px;font-family:var(--sans);font-size:13px;font-weight:600;cursor:pointer;transition:all .3s;box-shadow:0 2px 12px rgba(0,0,0,.3);white-space:nowrap;overflow:visible}
.auth-google-btn svg{flex-shrink:0}
.auth-google-btn:hover{transform:translateY(-1px);box-shadow:0 4px 20px rgba(0,0,0,.4)}
.auth-google-btn:active{transform:translateY(0)}
/* Profile Bubble — inside nav pill */
.profile-bubble{position:relative;display:flex;align-items:center;padding:2px}
.profile-bubble-btn{background:none;border:none;cursor:pointer;padding:0;border-radius:50%;transition:all .3s;display:flex;align-items:center;justify-content:center}
.profile-bubble-btn:hover{opacity:.8}
.profile-bubble-btn img{width:28px;height:28px;border-radius:50%;object-fit:cover;display:block}
.profile-bubble-initial{width:28px;height:28px;border-radius:50%;background:rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;font-family:var(--sans);font-size:10px;font-weight:700;color:var(--white)}

/* Dropdown Menu */
.auth-menu{position:absolute;top:calc(100% + 8px);left:0;background:rgba(20,20,20,.95);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:16px;min-width:200px;opacity:0;transform:translateY(-8px);pointer-events:none;transition:all .25s ease;z-index:900}
.auth-menu.open{opacity:1;transform:translateY(0);pointer-events:auto}
.auth-menu-name{font-family:var(--sans);font-size:13px;font-weight:600;color:var(--white);margin-bottom:2px}
.auth-menu-email{font-family:var(--sans);font-size:11px;color:var(--dim);margin-bottom:16px;word-break:break-all}
.auth-menu-logout{display:block;width:100%;background:none;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:10px;font-family:var(--sans);font-size:10px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--gray);cursor:pointer;transition:all .3s}
.auth-menu-logout:hover{border-color:rgba(255,255,255,.2);color:var(--white)}

/* ==========================================
   FREQUENCY DIAL PAD
   ========================================== */
.freq-dial-btn{display:flex;align-items:center;gap:4px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:10px;padding:8px 10px;cursor:pointer;transition:all .3s;position:relative;flex-shrink:0;max-width:120px}
.freq-dial-btn:hover{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.12)}
.freq-dial-display{font-family:var(--sans);font-size:18px;font-weight:700;letter-spacing:.02em;display:flex;align-items:baseline}
.freq-dial-label{font-family:var(--sans);font-size:8px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--dim);margin-left:2px}
.freq-ghost{color:rgba(255,255,255,.12);font-variant-numeric:tabular-nums;font-size:16px}
.freq-dot{color:rgba(255,255,255,.2);margin:0 1px;font-size:16px}
.freq-lit{color:var(--white);font-variant-numeric:tabular-nums;font-size:18px}

/* Overlay */
#freq-pad-overlay{position:fixed;z-index:900;animation:freqFadeIn .2s ease}
@keyframes freqFadeIn{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}
.freq-pad{background:rgba(15,15,15,.97);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:20px;width:220px}
.freq-pad-display{text-align:center;font-family:var(--sans);font-size:36px;font-weight:700;letter-spacing:.04em;margin-bottom:16px;padding:12px 0;display:flex;align-items:baseline;justify-content:center}
.freq-pad-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}
.freq-pad-key{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.06);border-radius:10px;padding:14px 0;font-family:var(--sans);font-size:18px;font-weight:600;color:var(--white);cursor:pointer;transition:all .15s;-webkit-tap-highlight-color:transparent}
.freq-pad-key:hover{background:rgba(255,255,255,.1)}
.freq-pad-key:active{background:rgba(255,255,255,.15);transform:scale(.95)}
.freq-pad-del{color:var(--dim);font-size:20px}
.freq-pad-done{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--white);background:rgba(255,255,255,.08)}
.freq-pad-done:hover{background:rgba(255,255,255,.14)}

/* ==========================================
   NOW PLAYING FLOAT — Visualizer + Label
   ========================================== */
.player-float-label{font-family:var(--sans);font-size:8px;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--dim);margin-bottom:1px}
.player-float-eq{display:flex;align-items:flex-end;gap:2px;height:14px;margin-right:10px}
.player-float-eq-bar{width:2.5px;border-radius:1px;background:var(--white);animation:eqBounce .6s ease-in-out infinite alternate}
.player-float-eq-bar:nth-child(1){height:6px;animation-delay:0s}
.player-float-eq-bar:nth-child(2){height:12px;animation-delay:.15s}
.player-float-eq-bar:nth-child(3){height:8px;animation-delay:.3s}
.player-float-eq-bar:nth-child(4){height:14px;animation-delay:.1s}
@keyframes eqBounce{0%{height:3px}100%{height:14px}}

/* Top bar content spacer */
.scene{padding-top:calc(54px + env(safe-area-inset-top, 0px)) !important}

/* ==========================================
   PHASE 3 — Discover Grid, Mixtape, Collection Grid
   ========================================== */

/* 3-across on mobile, 2-across on larger screens (existing grid handles desktop) */
@media(max-width:600px){
  .discover-grid{grid-template-columns:repeat(3,1fr) !important;gap:12px !important}
  .discover-grid .artist-grid-item img{width:100%;aspect-ratio:1;object-fit:cover;border-radius:8px}
  .discover-grid .artist-grid-name{font-size:11px}
  .discover-grid .artist-grid-genre{font-size:9px}
  .collection-album-grid{grid-template-columns:repeat(3,1fr) !important;gap:10px !important}
  .collection-album img{border-radius:6px}
  .collection-album-title{font-size:11px}
  .collection-album-sub{font-size:9px}
}

/* Daily Mixtape card */
.mixtape-card{display:flex;align-items:center;gap:16px;padding:16px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);border-radius:14px;cursor:pointer;transition:all .3s}
.mixtape-card:hover{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.1)}
.mixtape-covers{display:grid;grid-template-columns:1fr 1fr;gap:3px;width:80px;height:80px;border-radius:10px;overflow:hidden;flex-shrink:0}
.mixtape-covers img{width:100%;height:100%;object-fit:cover}
.mixtape-info{flex:1;min-width:0}
.mixtape-title{font-family:var(--sans);font-size:14px;font-weight:700;color:var(--white);margin-bottom:4px}
.mixtape-sub{font-family:var(--sans);font-size:11px;color:var(--dim);margin-bottom:8px}
.mixtape-cta{font-family:var(--sans);font-size:10px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--gray);display:flex;align-items:center;gap:6px}
.mixtape-cta svg{width:14px;height:14px}

/* Mixtape track list in Discover */
.mixtape-tracklist{margin-top:8px;border:1px solid rgba(255,255,255,.06);border-radius:14px;overflow:hidden;background:rgba(255,255,255,.02)}
.mixtape-track{display:flex;align-items:center;padding:12px 16px;gap:12px;cursor:pointer;transition:background .2s}
.mixtape-track:hover{background:rgba(255,255,255,.04)}
.mixtape-track:not(:last-child){border-bottom:1px solid rgba(255,255,255,.04)}
.mixtape-track-num{font-family:var(--sans);font-size:11px;color:var(--dim);width:20px;text-align:right;flex-shrink:0}
.mixtape-track-info{flex:1;min-width:0}
.mixtape-track-title{font-family:var(--serif);font-size:15px;font-style:italic;color:var(--white);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mixtape-track-artist{font-family:var(--sans);font-size:10px;color:var(--dim);margin-top:2px}
.mixtape-track-dur{font-family:var(--sans);font-size:10px;color:var(--dim);flex-shrink:0}

/* ==========================================
   BOOT / LOADING SCREEN
   ========================================== */
.boot-screen{position:fixed;inset:0;z-index:100;background:#050505;display:flex;align-items:center;justify-content:center;overflow:hidden}
.boot-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;opacity:.6}
.boot-overlay{position:absolute;inset:0;background:linear-gradient(transparent 40%,rgba(5,5,5,.95))}
.boot-content{position:relative;z-index:2;text-align:center;padding-bottom:15vh}
.boot-logo{font-family:var(--sans);font-size:clamp(48px,12vw,80px);font-weight:900;letter-spacing:-.04em;color:var(--white);margin-bottom:8px;animation:bootFade 1.2s ease forwards}
.boot-sub{font-family:var(--serif);font-size:14px;font-style:italic;color:var(--gray);letter-spacing:.02em;animation:bootFade 1.2s ease .3s both}
@keyframes bootFade{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
