*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{--bg:#ffffff;--text:#111111;--text2:#888888;--border:#eeeeee;--sans:"Helvetica Neue","Noto Sans SC","PingFang SC",sans-serif}
html{-webkit-text-size-adjust:100%}
body{font-family:var(--sans);font-size:15px;line-height:1.5;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}

/* -- header -- */
.site-header{z-index:1000;width:100%;padding:14px 28px;position:fixed;top:0;left:0}
.header-inner{background:rgba(238,238,238,.6);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-radius:12px;border:1px solid rgba(255,255,255,.24);justify-content:space-between;align-items:center;padding:16px;display:flex;max-width:1280px;margin:0 auto}
.logo{font-size:24px;font-weight:700;letter-spacing:.05em;color:var(--text)}



/* -- filter panel (sliding drawer) -- */
.filter-overlay{position:fixed;inset:0;z-index:90;background:rgba(0,0,0,.12);opacity:0;pointer-events:none;transition:opacity .3s ease}
.filter-overlay.open{opacity:1;pointer-events:auto}

/* -- grid -- */
.grid{max-width:1280px;margin:0 auto;padding:24px 28px 100px;display:grid;grid-template-columns:1fr 1fr 1fr;column-gap:20px;row-gap:48px}
@media(max-width:960px){.grid{grid-template-columns:1fr 1fr;padding:24px 20px 90px;row-gap:40px}}
@media(max-width:600px){.grid{grid-template-columns:1fr;padding:20px 16px 80px;row-gap:36px}}

/* -- card -- */
.album-card{cursor:pointer;display:block;position:relative;min-width:0;opacity:0;transform:translateY(32px);transition:opacity .55s cubic-bezier(.4,0,.2,1),transform .55s cubic-bezier(.4,0,.2,1)}
.album-card.reveal{opacity:1;transform:translateY(0)}
.album-card img{width:100%;display:block;background:#f5f5f5;aspect-ratio:1;object-fit:fill;transition:transform .35s ease}
.album-card .info{line-height:1.5;padding:0}
.album-card .album-label{font-size:20px;color:var(--text);font-weight:700;line-height:1.3;margin-top:20px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.album-card .artist{font-size:11px;color:var(--text2);letter-spacing:.06em;text-transform:uppercase;margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.album-card .title{font-size:15px;color:var(--text);font-weight:400;line-height:1.4;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
@media(hover:hover){.album-card:hover img{transform:scale(1.06)}}

/* -- count bar -- */
.count-bar{position:fixed;bottom:0;left:0;width:100%;text-align:center;padding:12px 20px;font-size:11px;color:var(--text2);background:var(--bg);letter-spacing:.06em}

/* -- modal -- */
.modal{position:fixed;inset:0;z-index:2000;background:rgba(0,0,0,.8);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .3s;padding:0}
.modal.open{opacity:1;pointer-events:auto}
.modal-inner{background:var(--bg);width:100vw;height:100vh;max-width:none;max-height:none;overflow-y:auto;display:flex;flex-direction:row;position:relative}
.modal.open .modal-inner{animation:modalIn .35s cubic-bezier(.4,0,.2,1)}
@keyframes modalIn{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
.modal-media{width:50%;flex-shrink:0}
.modal-media img{width:100%;height:100%;object-fit:cover;display:block}
.modal-content{flex:1;padding:64px 56px 56px 48px;display:flex;flex-direction:column;justify-content:center}
.modal .modal-close{position:absolute;top:14px;right:14px;z-index:2;background:rgba(0,0,0,.04);border:none;cursor:pointer;width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--text2);transition:background .2s}
.modal .modal-close:hover{background:rgba(0,0,0,.1)}
.modal .artist{font-size:12px;color:var(--text2);letter-spacing:.08em;text-transform:uppercase;margin-bottom:10px}
.modal .title{font-size:26px;font-weight:500;line-height:1.25;margin-bottom:24px}
.modal .meta{display:flex;flex-wrap:wrap;gap:32px;margin-bottom:28px}
.modal .meta-item{font-size:12px;color:var(--text2)}
.modal .meta-item .label{display:block;font-size:9px;letter-spacing:.08em;margin-bottom:3px;text-transform:uppercase;color:var(--text)}
.modal .desc{font-size:13px;line-height:1.75;color:var(--text2);margin-bottom:36px;max-height:50vh;overflow-y:auto;white-space:pre-wrap;scrollbar-width:thin}
.modal .desc::-webkit-scrollbar{width:0;background:transparent}
.modal .desc::-webkit-scrollbar-thumb{background:transparent;border-radius:2px}
.modal .desc:hover::-webkit-scrollbar,.modal .desc:active::-webkit-scrollbar{width:4px}
.modal .desc:hover::-webkit-scrollbar-thumb,.modal .desc:active::-webkit-scrollbar-thumb{background:rgba(136,136,136,.6)}
.modal .actions{display:flex;gap:10px}
.modal .actions .btn{padding:14px 34px;font-size:13px;letter-spacing:.08em;font-family:var(--sans);border:1px solid var(--text);background:var(--text);color:#fff;cursor:pointer;transition:opacity .2s;display:inline-flex;align-items:center;text-transform:uppercase;text-decoration:none;-webkit-tap-highlight-color:transparent}
.modal .actions .btn:hover{opacity:.85}
.modal .actions .btn.outline{background:var(--bg);color:var(--text);position:relative;overflow:hidden}
.modal .actions .btn.outline::after{content:"";position:absolute;bottom:0;left:0;width:0;height:1px;background:var(--text);transition:width .45s cubic-bezier(.4,0,.2,1)}
.modal .actions .btn.outline:hover::after{width:100%}
.modal .actions .btn.outline:hover{opacity:1}

@media(max-width:700px){
.modal-inner{flex-direction:column;width:100vw;height:100vh;max-width:none;max-height:none}
.modal-media{width:100%;max-height:45vh}
.modal-media img{max-height:45vh;object-fit:cover}
.modal-content{padding:32px 28px}
.modal .title{font-size:22px}
}

/* -- label tags (auwa-like text roll) -- */
.label-tags{display:flex;flex-wrap:wrap;gap:12px 24px}
.label-tag{background:none;border:none;cursor:pointer;font-family:var(--sans);font-size:12px;letter-spacing:.12em;text-transform:uppercase;padding:0;color:var(--text2);transition:color .35s ease;-webkit-tap-highlight-color:transparent}
.label-tag .tag-text{position:relative;display:inline-block;overflow:hidden;padding-bottom:.12em}
.label-tag .tag-front{display:block;transition:transform .4s cubic-bezier(.4,0,.2,1)}
.label-tag .tag-back{position:absolute;inset:0;transform:translateY(110%);transition:transform .4s cubic-bezier(.4,0,.2,1)}
.label-tag:hover .tag-front{transform:translateY(-110%)}
.label-tag:hover .tag-back{transform:translateY(0)}
.label-tag.active{color:var(--text)}
.label-tag:hover{color:var(--text)}

/* -- header tags -- */
.header-tags{background:var(--bg);margin-top:110px}
.header-tags-inner{max-width:1280px;margin:0 auto;padding:12px 28px;display:flex;flex-wrap:wrap;gap:10px 24px}
.header-tags .label-tag{font-size:11px;letter-spacing:.1em}
@media(max-width:600px){
.header-tags-inner{padding:10px 16px;gap:8px 18px}
.header-tags .label-tag{font-size:10px}
}

/* -- page load (hidden until Enter) -- */
.site-header,.header-tags,.grid,#footer,.filter-overlay,.filter-panel{opacity:0;transition:opacity .7s ease}
.page-ready .site-header,.page-ready .header-tags,.page-ready .grid,.page-ready #footer,.page-ready .filter-overlay,.page-ready .filter-panel{opacity:1}

/* -- intro overlay -- */
.intro-overlay{position:fixed;inset:0;z-index:300;background:#000;display:flex;align-items:center;justify-content:center;transition:opacity .7s ease,transform .7s cubic-bezier(.4,0,.2,1)}
.intro-overlay.hidden{opacity:0;transform:translateY(-16px);pointer-events:none}
.intro-inner{text-align:center}
.intro-line{overflow:hidden;margin:0;height:auto;min-height:64px}
.intro-line .word{display:block;font-size:48px;color:rgba(255,255,255,.5);font-weight:300;letter-spacing:1px;line-height:1.1;font-family:Manrope,var(--sans);transform:translateY(100%);opacity:0;transition:transform .8s cubic-bezier(.4,0,.2,1),opacity .8s ease}
.intro-line.show .word{transform:translateY(0);opacity:1}
.intro-line+.intro-line{margin-top:2px}
.intro-line+.intro-line .word{font-size:80px;font-weight:300;color:rgba(255,255,255,.5);letter-spacing:-1px;line-height:1.2;transition-delay:.15s}
.intro-enter-wrap{opacity:0;transition:opacity .6s ease;margin-top:40px}
.intro-enter-wrap.show{opacity:1}
.intro-enter{background:none;border:none;color:#fff;font-size:20px;letter-spacing:.15em;cursor:pointer;font-family:var(--sans);transition:opacity .3s;display:inline-flex;align-items:center;gap:.3em}
.intro-enter .bk{transition:transform .35s cubic-bezier(.4,0,.2,1)}
.intro-enter:hover .bk:first-child{transform:translateX(-4px)}
.intro-enter:hover .bk:last-child{transform:translateX(4px)}
@media(max-width:600px){
.intro-line .word{font-size:40px}
.intro-line+.intro-line .word{font-size:32px;font-weight:300}
.intro-line{height:auto;min-height:40px}
.intro-enter-wrap{margin-top:32px}
}

::-webkit-scrollbar{width:4px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:#ddd;border-radius:2px}

/* -- footer -- */
#footer{background:var(--bg);border-top:1px solid var(--border);padding:28px 0}
.footer-inner{max-width:1280px;margin:0 auto;padding:0 28px;display:flex;align-items:center;justify-content:space-between}
.footer-logo{font-size:18px;font-weight:700;letter-spacing:.1em;color:var(--text2);font-family:var(--sans);cursor:default;user-select:none;-webkit-user-select:none;display:inline-flex;gap:0}
.footer-count{font-size:11px;color:var(--text2);letter-spacing:.06em}
.footer-logo .hc-char{display:inline-block;transition:color .3s ease}
.footer-logo .hc-char.orig{color:var(--text2)}
.footer-logo .hc-char.glitch{color:var(--text)}
@media(max-width:600px){
#footer{padding:24px 0}
.footer-inner{padding:0 16px}
.footer-logo{font-size:15px}
}

/* -- burger (laurenti style) -- */
.burger{cursor:pointer;background:none;border:none;width:24px;height:18px;position:relative;padding:0}
.burger span{background:var(--text);width:100%;height:2px;transition:all .35s cubic-bezier(.4,0,.2,1);position:absolute;left:0}
.burger span:first-child{top:0}
.burger span:nth-child(2){bottom:2px}
.burger.active span:first-child{top:8px;transform:rotate(45deg)}
.burger.active span:nth-child(2){bottom:8px;transform:rotate(-45deg)}
@media(max-width:600px){
.site-header{padding:12px 16px}
@media(max-width:600px){.header-inner{padding:12px 16px}}
.burger{width:22px;height:16px}
}



/* -- medias (laurenti-style) -- */
.intro-overlay .medias{position:absolute;inset:0;z-index:1;overflow:hidden;pointer-events:none}
.intro-overlay .media{position:absolute;width:180px;aspect-ratio:3/2;transform-origin:50%;transform:translateZ(0);border-radius:6px;overflow:hidden;opacity:0;will-change:transform;transition:transform 1.2s cubic-bezier(.19,1,.22,1),opacity 1.2s cubic-bezier(.19,1,.22,1)}
.intro-overlay .media.show{opacity:1}
.intro-overlay .media-img{border-radius:6px;width:100%;height:100%;object-fit:cover;display:block}
.intro-overlay .media:nth-child(1){top:16%;left:10%;width:200px;transition-delay:0s}
.intro-overlay .media:nth-child(2){top:12%;right:12%;width:204px;transition-delay:.5s}
.intro-overlay .media:nth-child(3){bottom:12%;left:12%;width:242px;transition-delay:1.5s}
.intro-overlay .media:nth-child(4){bottom:6%;right:18%;width:230px;transition-delay:1s}
.intro-overlay .media:nth-child(5){top:45%;right:6%;width:180px;transition-delay:2s}

@keyframes float1{0%,100%{transform:translate(0,0)}25%{transform:translate(12px,0)}50%{transform:translate(-6px,0)}75%{transform:translate(0,-10px)}}
@keyframes float2{0%,100%{transform:translate(0,0)}25%{transform:translate(-8px,12px)}50%{transform:translate(-16px,0)}75%{transform:translate(8px,-12px)}}
@keyframes float3{0%,100%{transform:translate(0,0)}25%{transform:translate(16px,-8px)}50%{transform:translate(-4px,4px)}75%{transform:translate(0,-16px)}}
@keyframes float4{0%,100%{transform:translate(0,0)}25%{transform:translate(12px,6px)}50%{transform:translate(-10px,0)}75%{transform:translate(0,-6px)}}
@keyframes float5{0%,100%{transform:translate(0,0)}25%{transform:translate(4px,12px)}50%{transform:translate(-8px,0)}75%{transform:translate(0,-10px)}}
.intro-overlay .media.show{animation:float1 6s ease-in-out 2s infinite}
.intro-overlay .media:nth-child(2).show{animation-duration:8s}
.intro-overlay .media:nth-child(3).show{animation-duration:12s}
.intro-overlay .media:nth-child(4).show{animation-duration:8s}
.intro-overlay .media:nth-child(5).show{animation-duration:10s}
.intro-overlay .media:nth-child(2).show{animation-name:float2}
.intro-overlay .media:nth-child(3).show{animation-name:float3}
.intro-overlay .media:nth-child(4).show{animation-name:float4}
.intro-overlay .media:nth-child(5).show{animation-name:float5}

@media(max-width:768px){
.intro-overlay .media{width:110px}
.intro-overlay .media:nth-child(1){top:12%;left:6%;width:120px;transition-delay:0s}
.intro-overlay .media:nth-child(2){top:10%;right:8%;width:120px;transition-delay:.5s}
.intro-overlay .media:nth-child(3){bottom:15%;left:8%;width:143px;transition-delay:1.5s}
.intro-overlay .media:nth-child(4){bottom:8%;right:12%;width:130px;transition-delay:1s}
.intro-overlay .media:nth-child(5){top:42%;right:4%;width:110px;transition-delay:2s}
}

@media(max-width:700px){


.intro-line{height:auto;min-height:40px}
.intro-enter-wrap{margin-top:32px}
}

/* -- filter menu (laurenti-style full screen) -- */
.filter-panel{position:fixed;inset:0;z-index:99;pointer-events:none}
.filter-panel.open{pointer-events:auto}
.filter-menu{position:absolute;top:16px;bottom:16px;left:50%;width:1280px;margin-left:-640px;background:rgba(255,255,255,.85);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);display:flex;align-items:center;justify-content:center;opacity:0;transform:scale(.98);transition:opacity .4s ease,transform .4s cubic-bezier(.4,0,.2,1);border-radius:12px;overflow:hidden}
.filter-panel.open .filter-menu{opacity:1;transform:scale(1)}
.filter-menu-inner{width:100%;max-width:1280px;margin:auto;padding:60px 40px;display:flex;gap:80px}
.filter-menu-left{flex:1;display:flex;flex-direction:column;align-items:flex-start}
.filter-menu-right{flex:1;display:flex;flex-direction:column;justify-content:flex-end;align-items:flex-end}
.filter-close-wrap{margin-bottom:60px}
.filter-close{background:none;border:none;cursor:pointer;font-family:var(--sans);font-size:14px;letter-spacing:.08em;color:var(--text2);display:inline-flex;align-items:center;gap:.3em;padding:4px 0;transition:color .3s ease}
.filter-close span:first-child,.filter-close span:last-child{transition:transform .3s cubic-bezier(.4,0,.2,1)}
.filter-close:hover span:first-child{transform:translateX(-3px)}
.filter-close:hover span:last-child{transform:translateX(3px)}
.filter-options-list{display:flex;flex-direction:column;gap:4px}
.filter-option{background:none;border:none;cursor:pointer;font-family:Manrope,var(--sans);font-size:clamp(28px,3.5vw,48px);font-weight:300;color:var(--text2);text-align:left;padding:6px 0;display:flex;align-items:center;gap:12px;transition:color .35s ease,transform .35s cubic-bezier(.4,0,.2,1);position:relative}
.filter-option:hover{color:var(--text);transform:translateX(4px)}
.filter-option.active{color:var(--text)}
.fo-num{font-size:.35em;font-weight:400;color:var(--text2);opacity:.4;width:1.8em;text-align:right;flex-shrink:0}
.filter-option:hover .fo-num{opacity:.6}
.filter-option.active .fo-num{opacity:.6}
.filter-info{display:none}
.filter-description{font-size:11px;color:var(--text2);letter-spacing:.08em;margin-bottom:20px;text-transform:uppercase}
.filter-search-block{width:100%;max-width:320px}
.filter-search-block input{width:100%;background:none;border:none;border-bottom:1px solid var(--border);font-family:var(--sans);font-size:14px;color:var(--text);padding:10px 0;outline:none;transition:border-color .3s ease}
.filter-search-block input::placeholder{color:var(--text2)}
.filter-search-block input:focus{border-bottom-color:var(--text)}
@media(max-width:700px){
.filter-menu-inner{flex-direction:column;gap:40px;padding:40px 24px}
.filter-close-wrap{margin-bottom:36px}
.filter-option{font-size:clamp(22px,5vw,32px)}
.filter-menu-right{align-items:stretch}
.filter-search-block{max-width:none}
}
