/* ============================================================
   黑王船 BLACK DEITIES CRUISER — shared theme
   Death / thrash metal: ash-on-charcoal, ember-red, ritual fire.
   ============================================================ */

:root{
  --bg:      #0a0807;
  --bg2:     #0d0a09;
  --panel:   #131010;
  --panel2:  #1a1614;
  --text:    #ece6e1;
  --text2:   #c4bab4;
  --muted:   #a99f99;
  --muted2:  #8f8580;
  --faint:   #6f6661;
  --red:     #e0181b;
  --red2:    #ff2a2f;
  --ember:   #ff5a2c;
  --ember2:  #ff7a2c;
  --line:    rgba(236,230,225,.12);
  --line2:   rgba(236,230,225,.26);
  --redline: rgba(224,24,27,.28);
  --maxw:    1180px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--bg);
  color:var(--text);
  font-family:'Barlow','Noto Sans TC',sans-serif;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
  min-height:100vh;
}
a{text-decoration:none;color:inherit}
img{display:block;max-width:100%}
button{font-family:inherit}
::selection{background:var(--red);color:#fff}

/* ---------- keyframes ---------- */
@keyframes emberRise{0%{transform:translateY(0) scale(1);opacity:0}12%{opacity:.85}80%{opacity:.5}100%{transform:translateY(-360px) scale(.3);opacity:0}}
@keyframes flameGlow{0%,100%{opacity:.5;transform:translateX(-50%) scaleY(1) scaleX(1)}50%{opacity:.85;transform:translateX(-50%) scaleY(1.18) scaleX(1.05)}}
@keyframes bob{0%,100%{transform:translateY(0);opacity:.55}50%{transform:translateY(7px);opacity:1}}
@keyframes grain{0%,100%{transform:translate(0,0)}25%{transform:translate(-2%,1%)}50%{transform:translate(1%,-2%)}75%{transform:translate(2%,2%)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}

/* ---------- atmosphere (grain + embers) ---------- */
.grain{
  position:fixed;inset:-50%;z-index:1;pointer-events:none;opacity:.04;mix-blend-mode:screen;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)'/%3E%3C/svg%3E");
  animation:grain 8s steps(5) infinite;
}
.embers{position:fixed;inset:0;pointer-events:none;z-index:1;overflow:hidden}
.embers span{position:absolute;bottom:4%;border-radius:50%;opacity:0;animation:emberRise linear infinite}

/* ---------- layout ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
main{position:relative;z-index:2;display:block}
.page-section{position:relative;z-index:2;max-width:var(--maxw);margin:0 auto;padding:clamp(80px,9vw,130px) 24px}
.page-top{padding-top:clamp(120px,14vw,180px)}      /* clears the fixed nav on inner pages */

/* ---------- nav ---------- */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  background:rgba(10,8,7,.82);
  border-bottom:1px solid var(--line);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  transition:background .35s,border-color .35s,box-shadow .35s;
}
.nav.scrolled{background:rgba(10,8,7,.94);border-bottom-color:var(--redline);box-shadow:0 10px 34px rgba(0,0,0,.5)}
.nav-inner{max-width:1280px;margin:0 auto;padding:0 24px;height:64px;display:flex;align-items:center;justify-content:space-between;gap:20px}
.nav-logo{display:flex;align-items:center;gap:11px;cursor:pointer}
.nav-logo img{height:38px;width:auto;filter:drop-shadow(0 0 6px rgba(224,24,27,.55))}
.nav-logo .seal{
  height:38px;width:38px;display:flex;align-items:center;justify-content:center;
  border:1.5px solid var(--red);border-radius:50%;
  font-family:'Noto Sans TC',serif;font-weight:900;font-size:16px;color:var(--red);
  box-shadow:0 0 8px rgba(224,24,27,.5);
}
.nav-logo .brand{font-family:'Oswald','Noto Sans TC',sans-serif;font-weight:600;font-size:15px;letter-spacing:.18em;color:var(--text)}
.nav-links{display:flex;align-items:center;gap:28px}
.nav-links a{font-family:'Oswald','Noto Sans TC',sans-serif;font-weight:500;font-size:14px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);cursor:pointer;transition:color .2s;position:relative}
.nav-links a:hover{color:var(--red)}
.nav-links a.active{color:var(--text)}
.nav-links a.active::after{content:"";position:absolute;left:0;right:0;bottom:-6px;height:2px;background:var(--red);box-shadow:0 0 8px rgba(224,24,27,.7)}
.lang-btn{font-family:'Oswald',sans-serif;font-weight:500;font-size:13px;letter-spacing:.12em;color:var(--text);background:transparent;border:1px solid var(--line2);padding:6px 12px;cursor:pointer;transition:all .2s}
.lang-btn:hover{border-color:var(--red);color:var(--red)}
.nav-burger{display:none;flex-direction:column;gap:5px;background:transparent;border:none;cursor:pointer;padding:6px}
.nav-burger span{display:block;width:22px;height:2px;background:var(--text)}

.drawer{position:fixed;inset:0;z-index:99;background:rgba(8,6,5,.97);backdrop-filter:blur(8px);display:none;flex-direction:column;align-items:center;justify-content:center;gap:6px}
.drawer.open{display:flex;animation:fadeUp .25s ease}
.drawer .close{position:absolute;top:20px;right:24px;font-size:34px;line-height:1;color:var(--text);background:none;border:none;cursor:pointer}
.drawer a{font-family:'Oswald','Noto Sans TC',sans-serif;font-weight:600;font-size:26px;letter-spacing:.14em;text-transform:uppercase;color:var(--text);padding:12px;cursor:pointer}
.drawer a.active{color:var(--red)}
.drawer .lang-btn{margin-top:16px;font-size:15px;color:var(--red);border-color:rgba(224,24,27,.5)}

/* ---------- section heading (label + title) ---------- */
.kicker{display:flex;align-items:center;gap:14px;margin-bottom:16px}
.kicker::before{content:"";width:30px;height:2px;background:var(--red)}
.kicker span{font-family:'Oswald','Noto Sans TC',sans-serif;font-weight:500;font-size:13px;letter-spacing:.3em;text-transform:uppercase;color:var(--red)}
.sec-title{margin:0 0 44px;font-family:'Oswald','Noto Sans TC',sans-serif;font-weight:600;font-size:clamp(32px,5vw,58px);line-height:1.02;text-transform:uppercase;color:var(--text)}
.sec-title.plain{text-transform:none}

.divider{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.divider .ln{position:relative;height:1px;background:linear-gradient(90deg,transparent,var(--redline),transparent)}
.divider .ln span{position:absolute;left:50%;top:50%;width:8px;height:8px;background:var(--red);transform:translate(-50%,-50%) rotate(45deg);box-shadow:0 0 12px rgba(224,24,27,.7)}

/* ---------- HERO (home) ---------- */
.hero{position:relative;width:100%;min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:120px 24px 90px;overflow:hidden}
.hero-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 30%;opacity:.34;filter:grayscale(.35) contrast(1.05)}
.hero-bg.placeholder{background:radial-gradient(120% 90% at 50% 10%,#2a1110,#0a0807 70%);opacity:.7}
.hero-veil{position:absolute;inset:0;background:radial-gradient(120% 90% at 50% 18%, rgba(10,8,7,.35), rgba(10,8,7,.82) 62%, #0a0807 100%)}
.hero-topfade{position:absolute;left:0;right:0;top:0;height:90px;background:linear-gradient(180deg,rgba(10,8,7,.9),transparent)}
.hero-flame{position:absolute;bottom:-60px;left:50%;width:min(900px,120%);height:340px;background:radial-gradient(60% 100% at 50% 100%, rgba(224,24,27,.55), rgba(224,24,27,.12) 45%, transparent 72%);filter:blur(8px);animation:flameGlow 4.5s ease-in-out infinite;pointer-events:none}
.hero-botfade{position:absolute;bottom:0;left:0;right:0;height:160px;background:linear-gradient(180deg,transparent,#0a0807)}
.hero-inner{position:relative;z-index:3;display:flex;flex-direction:column;align-items:center;width:100%;max-width:840px}
.hero-wordmark{width:clamp(290px,64vw,700px);height:auto;filter:brightness(1.32) drop-shadow(0 0 26px rgba(224,24,27,.34))}
.hero-wordmark-text{font-family:'Oswald','Noto Sans TC',sans-serif;font-weight:700;font-size:clamp(40px,11vw,116px);line-height:.92;letter-spacing:.02em;text-transform:uppercase;color:var(--text);text-shadow:0 0 30px rgba(224,24,27,.45);margin:0}
.hero-wordmark-text .zh{display:block;font-size:clamp(48px,13vw,150px);color:var(--text);letter-spacing:.06em}
.hero-tags{margin-top:26px;display:flex;align-items:center;gap:14px;flex-wrap:wrap;justify-content:center;font-family:'Lora','Oswald','Noto Sans TC',serif;font-weight:500;font-size:clamp(12px,1.5vw,15px);letter-spacing:.34em;text-transform:uppercase;color:#cdbfb9}
.hero-tags .dot{width:5px;height:5px;background:var(--red);transform:rotate(45deg);box-shadow:0 0 8px rgba(224,24,27,.8)}
.hero-socials{margin-top:34px;display:flex;flex-wrap:wrap;align-items:center;justify-content:center}
.hero-socials a{font-family:'Oswald',sans-serif;font-weight:400;font-size:13px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);padding:8px 16px;transition:color .2s}
.hero-socials a:hover{color:var(--red)}
.scroll-cue{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);z-index:3;display:flex;flex-direction:column;align-items:center;gap:8px;cursor:pointer;animation:bob 2.4s ease-in-out infinite}
.scroll-cue span{font-family:'Oswald',sans-serif;font-size:11px;letter-spacing:.34em;color:var(--muted2)}
.scroll-cue .line{display:block;width:1px;height:30px;background:linear-gradient(var(--red),transparent)}

/* ---------- NEWS card ---------- */
.news{position:relative;z-index:3;max-width:var(--maxw);margin:0 auto;padding:0 24px;transform:translateY(-46px)}
.news-card{background:var(--panel);border:1px solid var(--redline);box-shadow:0 24px 60px rgba(0,0,0,.55);display:flex;flex-wrap:wrap;align-items:stretch}
.news-media{flex:1 1 300px;position:relative;min-height:240px;overflow:hidden;background:repeating-linear-gradient(45deg,#1a1614,#1a1614 11px,#141110 11px,#141110 22px)}
.news-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.news-media::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent 50%,rgba(19,16,16,.9))}
.news-body{flex:2 1 420px;padding:clamp(28px,4vw,48px);display:flex;flex-direction:column;justify-content:center;gap:16px}
.news-body .k{font-family:'Oswald',sans-serif;font-size:12px;letter-spacing:.28em;text-transform:uppercase;color:var(--red)}
.news-body h2{margin:0;font-family:'Oswald','Noto Sans TC',sans-serif;font-weight:600;font-size:clamp(24px,3.2vw,38px);line-height:1.08;color:var(--text)}
.news-body p{margin:0;font-size:clamp(15px,1.6vw,17px);line-height:1.7;color:var(--muted);max-width:50ch}
.btn-fill{display:inline-flex;align-items:center;gap:10px;font-family:'Oswald','Noto Sans TC',sans-serif;font-weight:500;font-size:14px;letter-spacing:.16em;text-transform:uppercase;color:#0a0807;background:var(--red);padding:13px 26px;cursor:pointer;transition:background .2s;width:fit-content}
.btn-fill:hover{background:var(--red2)}

/* ---------- ABOUT ---------- */
.about-grid{display:flex;flex-wrap:wrap;gap:clamp(30px,5vw,64px);align-items:flex-start}
.about-grid h2{flex:1 1 300px;margin:0;font-family:'Oswald','Noto Sans TC',sans-serif;font-weight:700;font-size:clamp(38px,7vw,76px);line-height:.98;color:var(--text)}
.about-body{flex:1.4 1 400px;display:flex;flex-direction:column;gap:20px}
.about-body p{margin:0;font-size:clamp(16px,1.8vw,19px);line-height:1.85;color:var(--text2)}
.about-body p+p{font-size:clamp(15px,1.6vw,17px);color:var(--muted)}
.about-photo{width:100%;margin-top:40px;border:1px solid var(--line);max-height:520px;object-fit:cover}

/* ---------- SHOWS ---------- */
.shows-list{display:flex;flex-direction:column;border-bottom:1px solid var(--line)}
.show-row{display:flex;flex-wrap:wrap;align-items:center;gap:clamp(18px,3vw,40px);padding:28px 4px;border-top:1px solid var(--line);transition:background .25s}
.show-row:hover{background:rgba(224,24,27,.05)}
.show-date{flex:0 0 auto;text-align:center;min-width:72px;font-family:'Oswald',sans-serif;line-height:1}
.show-date .mon{font-size:14px;letter-spacing:.18em;color:var(--red)}
.show-date .day{font-size:44px;font-weight:600;color:var(--text);margin:2px 0}
.show-date .year{font-size:13px;letter-spacing:.14em;color:var(--muted2)}
.show-info{flex:1 1 300px;min-width:240px}
.show-info .type{font-family:'Oswald',sans-serif;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted2);margin-bottom:8px}
.show-info h3{margin:0 0 8px;font-family:'Oswald','Noto Sans TC',sans-serif;font-weight:600;font-size:clamp(20px,2.4vw,27px);line-height:1.15;color:var(--text)}
.show-info .venue{font-size:15px;color:var(--text2);margin-bottom:6px}
.show-info p{margin:0;font-size:14px;line-height:1.6;color:var(--muted2);max-width:60ch}
.btn-line{display:inline-flex;align-items:center;gap:8px;font-family:'Oswald','Noto Sans TC',sans-serif;font-weight:500;font-size:13px;letter-spacing:.14em;text-transform:uppercase;color:var(--text);border:1px solid var(--line2);padding:11px 20px;transition:all .2s;cursor:pointer}
.btn-line:hover{border-color:var(--red);color:var(--red)}
.note{margin:26px 0 0;font-size:13px;color:var(--faint)}

/* ---------- MUSIC ---------- */
.release{display:flex;flex-wrap:wrap;gap:clamp(30px,5vw,60px);padding-bottom:clamp(40px,5vw,64px);margin-bottom:clamp(40px,5vw,64px);border-bottom:1px solid var(--line)}
.release:last-child{border-bottom:0;margin-bottom:0;padding-bottom:0}
.release-left{flex:1 1 300px;min-width:260px;display:flex;flex-direction:column;gap:24px}
.cover{position:relative;border:1px solid var(--redline);box-shadow:0 0 40px rgba(224,24,27,.18);aspect-ratio:1/1;overflow:hidden;background:repeating-linear-gradient(45deg,#1a1614,#1a1614 11px,#141110 11px,#141110 22px)}
.cover img{width:100%;height:100%;object-fit:cover}
.cover .ph{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:'Oswald',sans-serif;letter-spacing:.2em;color:var(--faint);text-transform:uppercase;font-size:13px}
.release-title{font-family:'Oswald','Noto Sans TC',sans-serif;font-weight:600;font-size:21px;color:var(--text)}
.release-meta{font-size:14px;letter-spacing:.06em;color:var(--muted2);margin-top:4px}
.eyebrow{font-family:'Oswald',sans-serif;font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--muted2);margin-bottom:12px}
.platforms{display:flex;flex-wrap:wrap;gap:10px}
.platforms a{font-family:'Oswald',sans-serif;font-weight:500;font-size:13px;letter-spacing:.1em;text-transform:uppercase;color:var(--text);border:1px solid var(--line2);padding:10px 16px;transition:all .2s}
.platforms a:hover{border-color:var(--red);color:var(--red)}
.release-right{flex:1.3 1 380px;min-width:300px}
.tracks{border-bottom:1px solid var(--line)}
.track{display:flex;align-items:baseline;gap:18px;padding:18px 6px;border-top:1px solid var(--line);transition:background .2s}
.track:hover{background:rgba(224,24,27,.05)}
.track .n{font-family:'Oswald',sans-serif;font-size:14px;color:var(--red);min-width:24px}
.track .name{flex:1}
.track .name .t{font-family:'Oswald','Noto Sans TC',sans-serif;font-weight:500;font-size:clamp(17px,2vw,21px);color:var(--text);line-height:1.2}
.track .name .s{font-size:13px;color:var(--faint);margin-top:2px}
.track .dur{font-family:'Oswald',sans-serif;font-size:14px;color:var(--muted2);font-variant-numeric:tabular-nums}
.release-embed{flex-basis:100%;width:100%;margin-top:6px}
.release-embed iframe.embed-spotify{display:block;border:0}
.embed-yt{position:relative;aspect-ratio:16/9;border:1px solid var(--redline)}
.embed-yt iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
/* expandable per-track player */
.track.expandable{cursor:pointer}
.track .chev{flex:0 0 auto;margin-left:14px;color:var(--muted2);font-size:11px;line-height:1;transition:transform .3s ease,color .2s}
.track.expandable:hover{background:rgba(224,24,27,.05)}
.track.expandable:hover .chev{color:var(--red)}
.track.open{background:rgba(224,24,27,.08)}
.track.open .n{color:var(--red)}
.track.open .chev{transform:rotate(180deg);color:var(--red)}
.track-panel{display:grid;grid-template-rows:0fr;transition:grid-template-rows .38s cubic-bezier(.4,0,.2,1);border-bottom:1px solid transparent}
.track-panel.open{grid-template-rows:1fr;border-bottom-color:var(--line)}
.track-panel-inner{overflow:hidden;opacity:0;transition:opacity .3s ease .05s}
.track-panel.open .track-panel-inner{opacity:1}
.track-panel-inner .embed-spotify,.track-panel-inner .embed-yt{margin:10px 6px 18px}

/* ---------- MERCH ---------- */
.merch-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:clamp(16px,2.4vw,28px)}
.merch-card{display:flex;flex-direction:column;background:var(--panel);border:1px solid var(--line);transition:border-color .25s}
.merch-card:hover{border-color:var(--redline)}
.merch-img{position:relative;aspect-ratio:1/1;overflow:hidden;background:repeating-linear-gradient(45deg,#1a1614,#1a1614 11px,#141110 11px,#141110 22px)}
.merch-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.merch-img .ph{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:11px;letter-spacing:.12em;color:var(--faint);text-align:center;padding:0 12px;text-transform:uppercase}
.merch-body{padding:18px 18px 22px;display:flex;flex-direction:column;gap:8px;flex:1}
.merch-head{display:flex;justify-content:space-between;align-items:baseline;gap:10px}
.merch-head h3{margin:0;font-family:'Oswald','Noto Sans TC',sans-serif;font-weight:500;font-size:16px;line-height:1.25;color:var(--text)}
.merch-head .price{font-family:'Oswald',sans-serif;font-weight:600;font-size:16px;color:var(--red);white-space:nowrap}
.merch-body p{margin:0;font-size:13px;line-height:1.55;color:var(--muted2);flex:1}
.merch-sold{margin-top:6px;font-family:'Oswald','Noto Sans TC',sans-serif;font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);cursor:pointer;transition:color .2s}
.merch-sold:hover{color:var(--red)}

/* ---------- MEDIA ---------- */
.media-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:clamp(16px,2.4vw,26px)}
.video-card{display:block;cursor:pointer}
.video-thumb{position:relative;aspect-ratio:16/9;overflow:hidden;background:repeating-linear-gradient(45deg,#15110f,#15110f 11px,#100d0c 11px,#100d0c 22px);border:1px solid var(--line)}
.video-thumb img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.8;transition:transform .5s,opacity .3s}
.video-card:hover .video-thumb img{transform:scale(1.05);opacity:1}
.video-thumb .ph{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:11px;letter-spacing:.12em;color:var(--faint);text-transform:uppercase}
.video-thumb .tag{position:absolute;top:12px;left:12px;font-family:'Oswald',sans-serif;font-size:11px;letter-spacing:.16em;color:#0a0807;background:var(--red);padding:3px 9px}
.video-thumb .play{position:absolute;inset:0;display:flex;align-items:center;justify-content:center}
.video-thumb .play i{width:54px;height:54px;border-radius:50%;background:rgba(10,8,7,.6);border:1px solid rgba(236,230,225,.5);display:flex;align-items:center;justify-content:center;backdrop-filter:blur(2px)}
.video-thumb .play i::after{content:"";display:block;width:0;height:0;border-left:14px solid var(--text);border-top:9px solid transparent;border-bottom:9px solid transparent;margin-left:4px}
.video-card h3{margin:14px 0 0;font-family:'Oswald','Noto Sans TC',sans-serif;font-weight:500;font-size:17px;line-height:1.25;color:var(--text)}

/* video modal */
.yt-modal{position:fixed;inset:0;z-index:200;background:rgba(8,6,5,.9);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;padding:40px;opacity:0;pointer-events:none;transition:opacity .3s}
.yt-modal.open{opacity:1;pointer-events:auto}
.yt-stage{position:relative;width:min(1100px,96vw);aspect-ratio:16/9;background:#000;border:1px solid var(--redline);box-shadow:0 40px 80px rgba(0,0,0,.6)}
.yt-stage iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.yt-close{position:absolute;top:-44px;right:0;width:38px;height:38px;background:rgba(10,8,7,.6);border:1px solid var(--line2);border-radius:50%;color:var(--text);cursor:pointer;font-size:20px;line-height:1;display:flex;align-items:center;justify-content:center;transition:.2s}
.yt-close:hover{border-color:var(--red);color:var(--red)}

/* ---------- EPK ---------- */
.epk-grid{display:flex;flex-wrap:wrap;gap:clamp(30px,5vw,64px);align-items:flex-start}
.epk-main{flex:1.5 1 420px;min-width:300px;display:flex;flex-direction:column;gap:20px}
.epk-main p{margin:0;font-size:clamp(15px,1.7vw,18px);line-height:1.85;color:var(--text2)}
.epk-lead{font-size:clamp(17px,2vw,20px) !important;color:var(--text) !important;border-left:2px solid var(--red);padding-left:18px}
.epk-side{flex:1 1 260px;min-width:240px;display:flex;flex-direction:column;gap:34px}
.epk-block .eyebrow{margin-bottom:14px}
.members{display:flex;flex-direction:column;gap:0;border-bottom:1px solid var(--line)}
.member{display:flex;justify-content:space-between;align-items:baseline;gap:12px;padding:12px 0;border-top:1px solid var(--line)}
.member .name{font-family:'Oswald','Noto Sans TC',sans-serif;font-weight:500;font-size:16px;color:var(--text)}
.member .role{font-family:'Oswald',sans-serif;font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--red)}
.tech-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}
.tech-list li{position:relative;padding-left:20px;font-size:14px;line-height:1.6;color:var(--text2)}
.tech-list li::before{content:"";position:absolute;left:0;top:9px;width:6px;height:6px;background:var(--red);transform:rotate(45deg)}
.epk-downloads{display:flex;flex-direction:column;gap:10px}
.epk-downloads a{display:inline-flex;align-items:center;gap:10px;font-family:'Oswald','Noto Sans TC',sans-serif;font-size:13px;letter-spacing:.1em;text-transform:uppercase;color:var(--text);border:1px solid var(--line2);padding:12px 16px;transition:all .2s}
.epk-downloads a:hover{border-color:var(--red);color:var(--red)}
.epk-photos{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px;margin-top:30px}
.epk-photo{position:relative;aspect-ratio:4/3;overflow:hidden;border:1px solid var(--line);background:repeating-linear-gradient(45deg,#1a1614,#1a1614 11px,#141110 11px,#141110 22px)}
.epk-photo img{width:100%;height:100%;object-fit:cover}
.epk-photo figcaption{position:absolute;left:0;right:0;bottom:0;padding:8px 10px;font-size:12px;color:var(--text2);background:linear-gradient(transparent,rgba(8,6,5,.85))}

/* ---------- CONTACT ---------- */
.contact-wrap{position:relative;overflow:hidden}
.contact-glow{position:absolute;bottom:-90px;left:50%;transform:translateX(-50%);width:min(700px,110%);height:320px;background:radial-gradient(60% 100% at 50% 100%,rgba(224,24,27,.4),transparent 70%);filter:blur(10px);pointer-events:none}
.contact-cols{display:flex;flex-wrap:wrap;gap:clamp(30px,5vw,70px);position:relative}
.contact-col{flex:1 1 320px;min-width:280px}
.contact-col .eyebrow{margin-bottom:14px}
.contact-col p{margin:0 0 18px;font-size:16px;line-height:1.7;color:var(--text2);max-width:42ch}
.contact-email{font-family:'Oswald',sans-serif;font-weight:500;font-size:clamp(18px,2.4vw,26px);letter-spacing:.04em;color:var(--text);border-bottom:1px solid rgba(224,24,27,.5);padding-bottom:4px;transition:color .2s;display:inline-block}
.contact-email:hover{color:var(--red)}
.contact-socials{display:flex;flex-direction:column;gap:2px}
.contact-socials a{font-family:'Oswald',sans-serif;font-weight:400;font-size:17px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);padding:7px 0;transition:color .2s}
.contact-socials a:hover{color:var(--red)}

/* ---------- FOOTER ---------- */
.footer{position:relative;z-index:2;border-top:1px solid var(--line);margin-top:40px}
.footer-inner{max-width:var(--maxw);margin:0 auto;padding:34px 24px;display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:18px}
.footer-brand{display:flex;align-items:center;gap:12px}
.footer-brand .seal{height:34px;width:34px;display:flex;align-items:center;justify-content:center;border:1.5px solid var(--red);border-radius:50%;font-family:'Noto Sans TC',serif;font-weight:900;font-size:15px;color:var(--red);box-shadow:0 0 6px rgba(224,24,27,.5)}
.footer-brand img{height:34px;width:auto;filter:drop-shadow(0 0 6px rgba(224,24,27,.5))}
.footer-brand span{font-family:'Oswald','Noto Sans TC',sans-serif;font-weight:500;font-size:13px;letter-spacing:.16em;color:var(--muted)}
.footer-top{font-family:'Oswald',sans-serif;font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted2);cursor:pointer;transition:color .2s}
.footer-top:hover{color:var(--red)}

/* ---------- entrance ---------- */
.reveal{animation:fadeUp .5s ease both}

/* ---------- responsive ---------- */
@media (max-width:880px){
  .nav-links{display:none}
  .nav-burger{display:flex}
}
@media (max-width:760px){
  .about-grid h2{flex-basis:100%}
  .release{flex-direction:column}
  .show-row{gap:14px}
  .show-date{display:flex;align-items:baseline;gap:10px;min-width:0}
  .show-date .day{font-size:30px;margin:0}
}
