/* works grid */
.works-grid{
  margin-top:56px;display:grid;
  grid-template-columns:repeat(12,1fr);grid-auto-rows:minmax(80px,auto);gap:18px;
}
.work{
  position:relative;border:1px solid var(--line);background:var(--bg-2);overflow:hidden;
  transition:border-color .25s,transform .4s cubic-bezier(.2,.7,.2,1);
  cursor:pointer;display:flex;flex-direction:column;justify-content:space-between;
}
.work:before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(135deg, rgba(196,255,61,.06), transparent 30%);
  opacity:0;transition:opacity .25s;z-index:2;
}
.work:hover{border-color:var(--acid);transform:translateY(-4px)}
.work:hover:before{opacity:1}
.work .vis{flex:1;min-height:220px;position:relative;background:#0a0c0f;overflow:hidden}
.work .vis img.thumb{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  filter:brightness(0.55) contrast(1.05) grayscale(0.55) sepia(0.35) hue-rotate(35deg) saturate(0.9);
  transition:filter .35s,transform .6s cubic-bezier(.2,.7,.2,1);z-index:0;
}
.work:hover .vis img.thumb{
  filter:brightness(0.75) contrast(1.05) grayscale(0.25) sepia(0.25) hue-rotate(30deg) saturate(1.1);
  transform:scale(1.04);
}
.work .vis .vignette{
  position:absolute;inset:0;z-index:1;pointer-events:none;
  background:
    linear-gradient(135deg, rgba(196,255,61,.10), transparent 55%),
    linear-gradient(0deg, rgba(13,15,18,.8) 0%, rgba(13,15,18,0) 35%, rgba(13,15,18,0) 70%, rgba(7,8,10,.5) 100%);
}
.work .vis .scan-overlay{
  position:absolute;inset:0;z-index:2;pointer-events:none;
  background:repeating-linear-gradient(to bottom, rgba(196,255,61,.04) 0 1px, transparent 1px 4px);
  mix-blend-mode:overlay;
}
.work .vis .play-icon{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);z-index:3;
  width:54px;height:54px;border:1px solid rgba(255,255,255,.4);border-radius:50%;
  display:grid;place-items:center;
  transition:border-color .25s,background .25s;
  background:rgba(7,8,10,.4);backdrop-filter:blur(4px);
}
.work .vis .play-icon:after{
  content:"";display:block;width:0;height:0;
  border-left:10px solid #fff;border-top:7px solid transparent;border-bottom:7px solid transparent;
  margin-left:3px;
}
.work:hover .vis .play-icon{border-color:var(--acid);background:rgba(196,255,61,.15)}
.work:hover .vis .play-icon:after{border-left-color:var(--acid)}
.work .vis .corner-mark{
  position:absolute;top:14px;left:14px;
  font-family:var(--mono);font-size:9px;letter-spacing:.18em;color:#cdd2d6;text-transform:uppercase;z-index:4;
  text-shadow:0 0 8px rgba(0,0,0,.6);
}
.work .vis .corner-mark .k{color:var(--acid)}
.work .vis .crosshair{position:absolute;inset:0;pointer-events:none;z-index:2;opacity:.18}
.work .vis .crosshair:before,.work .vis .crosshair:after{content:"";position:absolute;background:#fff}
.work .vis .crosshair:before{left:50%;top:0;bottom:0;width:1px}
.work .vis .crosshair:after{top:50%;left:0;right:0;height:1px}
.work .meta{
  padding:20px 22px;border-top:1px solid var(--line);
  display:flex;flex-direction:column;gap:8px;position:relative;z-index:2;background:var(--bg-2);
}
.work .meta .top{
  display:flex;justify-content:space-between;align-items:center;
  font-family:var(--mono);font-size:10px;color:var(--ink-dim);letter-spacing:.14em;text-transform:uppercase;
}
.work .meta .top .tag{color:var(--acid)}
.work .meta h3{margin:0;font-family:'Noto Sans JP',sans-serif;font-weight:500;font-size:18px;line-height:1.45;letter-spacing:-.01em;color:var(--ink)}
.work .meta .en{font-family:var(--mono);font-size:11px;color:var(--ink-dim);line-height:1.6}
.work .meta .open{
  display:flex;justify-content:space-between;align-items:center;
  font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-mute);
  border-top:1px solid var(--line);padding-top:14px;margin-top:8px;
}
.work .meta .open .arr{color:var(--acid);display:flex;align-items:center;gap:8px}
.work .meta .open .arr svg{width:24px;height:8px}
.work:hover h3{color:var(--acid)}
.work:hover .meta .open .arr{transform:translateX(4px);transition:transform .25s}
.work.w1{grid-column:span 7;grid-row:span 2}
.work.w2{grid-column:span 5;grid-row:span 2}
.work.w3{grid-column:span 4;grid-row:span 2}
.work.w4{grid-column:span 4;grid-row:span 2}
.work.w5{grid-column:span 4;grid-row:span 2}
.work.pick{border-color:var(--acid)}
.work.pick:after{
  content:"FEATURED TODAY";position:absolute;top:14px;right:14px;z-index:4;
  font-family:var(--mono);font-size:9px;letter-spacing:.18em;color:#000;background:var(--acid);
  padding:5px 10px;text-transform:uppercase;box-shadow:0 4px 16px rgba(196,255,61,.25);
}

/* lab */
.lab-head{
  display:grid;grid-template-columns:1fr auto;align-items:end;gap:24px;
  margin-top:48px;margin-bottom:32px;
}
.lab-head .meta-row{
  display:flex;gap:12px;align-items:center;
  font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-dim);
}
.lab-head .meta-row .badge{
  border:1px solid var(--acid);color:var(--acid);padding:6px 10px;display:flex;gap:8px;align-items:center;
}
.lab-head .meta-row .badge:before{content:"";width:6px;height:6px;background:var(--acid);border-radius:50%;animation:pulse 1.6s infinite}
.lab-intro{
  font-family:'Noto Sans JP',sans-serif;font-size:15px;line-height:1.9;color:var(--ink-dim);max-width:60ch;margin:0 0 40px;
}
.lab-intro b{color:var(--ink);font-weight:500}
.lab-intro .accent{color:var(--acid)}
.lab-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:18px}
.lab-cell{
  position:relative;border:1px solid var(--line);background:var(--bg-2);overflow:hidden;
  transition:border-color .25s,background .25s;display:flex;flex-direction:column;
}
.lab-cell:hover{border-color:var(--acid);background:var(--bg-3)}
.lab-cell .lc-head{
  display:flex;justify-content:space-between;align-items:center;
  padding:14px 18px;border-bottom:1px solid var(--line);
  font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-dim);
}
.lab-cell .status{padding:3px 8px;font-family:var(--mono);font-size:9px;letter-spacing:.18em;border:1px solid var(--line-2)}
.lab-cell .status.live{color:var(--acid);border-color:var(--acid)}
.lab-cell .status.beta{color:#9af8ff;border-color:#9af8ff}
.lab-cell .status.draft{color:#ff9a3c;border-color:#ff9a3c}
.lab-cell .lc-body{padding:24px;flex:1;display:flex;flex-direction:column;gap:14px}
.lab-cell .lc-body h3{
  font-family:'Noto Sans JP',sans-serif;font-weight:500;font-size:18px;line-height:1.4;letter-spacing:-.01em;margin:0;color:var(--ink);
}
.lab-cell .lc-body .ja{font-family:'Noto Sans JP',sans-serif;font-size:13px;line-height:1.85;color:var(--ink-dim);margin:0}
.lab-cell .lc-foot{
  margin-top:auto;border-top:1px solid var(--line);padding:14px 18px;
  font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-mute);
  display:flex;justify-content:space-between;align-items:center;
}
.lab-cell.shader{grid-column:span 8;grid-row:span 2}
.lab-cell.lc-2{grid-column:span 4}
.lab-cell.lc-3{grid-column:span 4}
.lab-cell.lc-4{grid-column:span 4}
.lab-cell.lc-5{grid-column:span 4}
.shader-stage{position:relative;aspect-ratio:16/9;background:#000;overflow:hidden;border-bottom:1px solid var(--line)}
.shader-stage canvas{position:absolute;inset:0;width:100%;height:100%;display:block}
.shader-stage .stamp{
  position:absolute;top:14px;left:14px;
  font-family:var(--mono);font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-dim);z-index:2;
}
.shader-stage .stamp .k{color:var(--acid)}
.shader-stage .stamp2{
  position:absolute;top:14px;right:14px;
  font-family:var(--mono);font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-mute);z-index:2;
}
.knobs{padding:20px 24px;display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.knob{display:flex;flex-direction:column;gap:6px;font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-dim)}
.knob .row{display:flex;justify-content:space-between;align-items:center}
.knob .val{color:var(--acid)}
.knob input[type="range"]{-webkit-appearance:none;appearance:none;width:100%;height:2px;background:var(--line-2);outline:none;border-radius:0;cursor:pointer}
.knob input[type="range"]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:14px;height:14px;background:var(--acid);border-radius:0;cursor:pointer;box-shadow:0 0 0 1px var(--bg)}
.knob input[type="range"]::-moz-range-thumb{width:14px;height:14px;background:var(--acid);border:0;border-radius:0;cursor:pointer}
.knob .preset-row{display:flex;gap:6px;margin-top:4px}
.knob .preset{padding:5px 10px;border:1px solid var(--line-2);font-family:var(--mono);font-size:9px;letter-spacing:.16em;color:var(--ink-dim);cursor:pointer;background:transparent;transition:all .2s}
.knob .preset:hover{border-color:var(--acid);color:var(--acid)}
.knob .preset.active{background:var(--acid);color:#000;border-color:var(--acid)}
.audio-card .lc-body{display:grid;grid-template-rows:auto 1fr auto;gap:12px}
.audio-card .vu{height:64px;border:1px solid var(--line-2);display:flex;align-items:flex-end;gap:2px;padding:6px;background:#06080a}
.audio-card .vu span{display:block;flex:1;background:var(--line-2);min-height:2px;transition:background .15s}
.audio-card .vu.on span{background:var(--acid)}
.audio-card .toggle{
  font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  border:1px solid var(--acid);color:var(--acid);background:transparent;padding:10px 14px;cursor:pointer;
  display:flex;justify-content:space-between;align-items:center;width:100%;transition:background .2s,color .2s;
}
.audio-card .toggle.on{background:var(--acid);color:#000}
.audio-card .toggle .dot{width:8px;height:8px;background:currentColor;border-radius:50%}
.seed-card .seed-display{
  font-family:var(--mono);font-size:24px;letter-spacing:.06em;color:var(--acid);
  padding:18px;border:1px solid var(--line-2);background:#06080a;text-align:center;line-height:1.2;
}
.seed-card .seed-display small{display:block;font-size:9px;color:var(--ink-dim);letter-spacing:.2em;margin-bottom:8px}
.trail-card .trail-count{
  font-family:var(--mono);font-size:32px;letter-spacing:.04em;color:var(--acid);
  padding:14px 18px;border:1px solid var(--line-2);background:#06080a;text-align:center;line-height:1;
}
.trail-card .trail-count small{display:block;font-size:9px;color:var(--ink-dim);letter-spacing:.2em;margin-bottom:8px}

/* suno embed */
.suno-embed{margin-top:40px;border:1px solid var(--line);background:var(--bg-2);overflow:hidden}
.suno-head{
  padding:12px 18px;display:flex;justify-content:space-between;align-items:center;
  font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-dim);
  border-bottom:1px solid var(--line);
}
.suno-head .status-tag{color:var(--acid);border:1px solid var(--acid);padding:3px 8px;font-size:9px;letter-spacing:.18em}

/* music */
.music-head{display:grid;grid-template-columns:1fr auto;align-items:end;gap:20px;margin-bottom:48px}
.music-head .now-playing{
  font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-dim);
  display:flex;align-items:center;gap:10px;
}
.music-head .now-playing b{color:var(--acid);font-weight:500;display:flex;align-items:center;gap:8px}
.music-head .now-playing b:before{content:"";display:block;width:8px;height:8px;background:var(--acid);border-radius:50%;animation:pulse 1.6s infinite}
.music{display:grid;grid-template-columns:5fr 7fr;gap:60px;align-items:start}
.album{position:relative;border:1px solid var(--line);background:var(--bg-2);padding:28px}
.album .cover{aspect-ratio:1/1;background:#0a0c0f;border:1px solid var(--line-2);position:relative;overflow:hidden}
.album .cover img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.album .cover:after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:repeating-linear-gradient(to bottom, rgba(255,255,255,.025) 0 1px, transparent 1px 4px);
  mix-blend-mode:overlay;
}
.album .cover .title{
  position:absolute;left:24px;right:24px;bottom:24px;
  font-family:var(--sans);font-weight:700;font-size:clamp(28px,3.2vw,48px);line-height:.9;letter-spacing:-.02em;z-index:2;
}
.album .cover .title small{display:block;font-family:var(--mono);font-size:10px;font-weight:400;letter-spacing:.2em;color:var(--ink-dim);margin-bottom:6px}
.album .info{
  margin-top:20px;display:flex;justify-content:space-between;
  font-family:var(--mono);font-size:10px;color:var(--ink-dim);text-transform:uppercase;letter-spacing:.12em;
}
.album .info b{color:var(--acid);font-weight:500}
.tracklist{font-family:var(--mono);font-size:13px}
.tracklist .row{
  display:grid;grid-template-columns:48px 1fr auto 80px;gap:20px;
  padding:14px 0;border-bottom:1px solid var(--line);
  align-items:center;cursor:pointer;color:var(--ink-dim);transition:color .2s,padding .2s;
}
.tracklist .row:hover{color:var(--ink);padding-left:8px}
.tracklist .row:hover .num{color:var(--acid)}
.tracklist .row .num{color:var(--ink-dim);letter-spacing:.1em}
.tracklist .row .title{color:var(--ink);font-family:var(--sans);font-size:15px;letter-spacing:-.01em;display:flex;align-items:center;gap:14px}
.tracklist .row .title .ja{font-family:'Noto Sans JP',sans-serif;font-size:11px;color:var(--ink-dim);font-weight:300}
.tracklist .row .wf{display:flex;gap:2px;align-items:center;height:14px;opacity:.4}
.tracklist .row .wf span{display:block;width:2px;background:var(--ink-dim);border-radius:1px}
.tracklist .row.playing .wf{opacity:1}
.tracklist .row.playing .wf span{background:var(--acid);animation:bars 1s infinite}
@keyframes bars{0%,100%{transform:scaleY(.3)}50%{transform:scaleY(1)}}
.tracklist .row .dur{text-align:right;font-size:11px;letter-spacing:.08em}
.tracklist .row.playing .num{color:var(--acid)}
.tracklist .row.playing .title{color:var(--acid)}
.tracklist .row.playing .num:before{content:"▶ "}

/* about */
.about{display:grid;grid-template-columns:1fr;gap:60px;margin-top:56px;align-items:start;max-width:72ch}
.about .text{font-family:'Noto Sans JP',sans-serif;font-size:16px;line-height:1.95;color:var(--ink-dim)}
.about .text p{margin:0 0 18px}
.about .text p:first-child{font-size:20px;color:var(--ink);line-height:1.7}
.about .text b{color:var(--ink);font-weight:500}
.about .text .accent{color:var(--acid)}

/* contact */
.contact-head{display:grid;grid-template-columns:1fr auto;align-items:end;gap:40px;margin-top:48px;margin-bottom:48px}
.contact-head .status{
  font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-dim);
  border:1px solid var(--line-2);padding:14px 18px;display:flex;align-items:center;gap:12px;background:var(--bg-2);
}
.contact-head .status b{color:var(--acid);font-weight:500;display:flex;align-items:center;gap:8px}
.contact-head .status b:before{content:"";display:block;width:8px;height:8px;background:var(--acid);border-radius:50%;animation:pulse 1.6s infinite}
.contact-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.contact-grid a{
  background:var(--bg);padding:32px 24px;
  display:flex;flex-direction:column;gap:14px;
  transition:background .2s,color .2s;position:relative;overflow:hidden;
}
.contact-grid a:before{content:"";position:absolute;left:0;top:0;width:0;height:1px;background:var(--acid);transition:width .35s cubic-bezier(.2,.7,.2,1)}
.contact-grid a:hover:before{width:100%}
.contact-grid a:hover{background:#0e1115;color:var(--acid)}
.contact-grid a .label{font-family:var(--mono);font-size:10px;color:var(--ink-dim);letter-spacing:.2em;text-transform:uppercase}
.contact-grid a .val{font-family:var(--sans);font-size:18px;font-weight:500;letter-spacing:-.01em}
.contact-grid a .arrow{margin-top:auto;font-family:var(--mono);font-size:11px;color:var(--ink-dim);letter-spacing:.1em;display:flex;justify-content:space-between;align-items:center}
.contact-grid a:hover .arrow{color:var(--acid)}
.contact-grid a .arrow svg{width:24px;height:8px;transition:transform .2s}
.contact-grid a:hover .arrow svg{transform:translateX(4px)}

/* footer */
footer{
  padding:60px;border-top:1px solid var(--line);
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;
  font-family:var(--mono);font-size:10px;color:var(--ink-dim);text-transform:uppercase;letter-spacing:.12em;
  position:relative;z-index:5;
}
footer .end{text-align:right;color:var(--acid)}

/* responsive */
@media (max-width:1100px){
  .contact-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:900px){
  .hero{padding:150px 24px 48px}
  .hero-inner{grid-template-columns:1fr;gap:28px}
  .hero-side{justify-self:start;max-width:none}
  .hero-foot{grid-template-columns:repeat(2,1fr)}
  .sec{padding:80px 24px}
  .works-grid{grid-template-columns:repeat(6,1fr)}
  .work.w1,.work.w2,.work.w3,.work.w4,.work.w5{grid-column:span 6}
  .music,.about{grid-template-columns:1fr;gap:32px}
  .contact-grid{grid-template-columns:1fr 1fr}
  .contact-head{grid-template-columns:1fr;gap:16px}
  footer{grid-template-columns:1fr;padding:32px 24px}
  nav.top .links{display:none}
  .music-head{grid-template-columns:1fr;align-items:start}
  .hero .scan-frame{display:none}
  .lab-grid{grid-template-columns:1fr}
  .lab-cell.shader,.lab-cell.lc-2,.lab-cell.lc-3,.lab-cell.lc-4,.lab-cell.lc-5{grid-column:span 1;grid-row:span 1}
  .knobs{grid-template-columns:repeat(2,1fr)}
  .interview-card{grid-template-columns:1fr}
  .interview-card .iv-side{border-right:0;border-bottom:1px solid var(--line);min-height:auto}
}
