:root{
  --bg:#020812;
  --bg-deep:#01040b;
  --panel:#071321;
  --panel2:#0b1b2e;
  --line:rgba(83,188,255,.42);
  --line-soft:rgba(83,188,255,.18);
  --blue:#1677ff;
  --accent-blue:#53bcff;
  --cyan:#9ce9ff;
  --text:#f3f8ff;
  --muted:#b5c9d9;
  --warning-red:#ff3f46;
  --shadow:0 18px 52px rgba(0,0,0,.48);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  width:100%;
  max-width:100%;
  overflow-x:hidden;
  background:
    radial-gradient(circle at 52% 0%,rgba(34,108,180,.38) 0%,rgba(2,8,18,0) 34%),
    linear-gradient(180deg,#061327 0%,var(--bg) 44%,var(--bg-deep) 100%);
  color:var(--text);
  font-family:'Noto Sans JP','Hiragino Kaku Gothic ProN','Yu Gothic',system-ui,sans-serif;
  line-height:1.85;
  letter-spacing:0;
}
a{color:inherit;text-decoration:none}
img,video,canvas,svg{max-width:100%;height:auto}
img{display:block}
.site-wrap{
  max-width:none;
  margin:auto;
  padding:0 0 42px;
}
.breadcrumb{
  width:100%;
  padding:12px clamp(18px,4vw,64px) 0;
  background:var(--bg);
  color:var(--muted);
  font-size:.82rem;
}
.breadcrumb ol{
  display:flex;
  flex-wrap:wrap;
  gap:6px 10px;
  max-width:1280px;
  margin:0 auto;
  padding:0;
  list-style:none;
}
.breadcrumb li:not(:last-child)::after{
  content:'/';
  margin-left:10px;
  color:rgba(156,233,255,.42);
}
.breadcrumb a:hover{
  color:var(--cyan);
}
.hero{
  position:relative;
  min-height:720px;
  background:
    linear-gradient(90deg,rgba(1,6,15,.88) 0%,rgba(1,6,15,.45) 46%,rgba(1,6,15,.82) 100%),
    linear-gradient(180deg,rgba(1,6,15,.1),rgba(1,6,15,.92)),
    url('../images/encore-hero.jpg') center/cover no-repeat;
  overflow:hidden;
}
.hero:after{
  content:'';
  position:absolute;
  inset:auto 0 0;
  height:120px;
  background:linear-gradient(180deg,rgba(1,6,15,0),var(--bg));
  pointer-events:none;
}
.hero-inner{
  position:relative;
  z-index:1;
  max-width:1180px;
  min-height:720px;
  margin:auto;
  display:grid;
  grid-template-columns:minmax(0,1.1fr) minmax(280px,.75fr);
  gap:34px;
  align-items:center;
  padding:58px 22px 88px;
}
.eyebrow{
  color:var(--cyan);
  font-weight:900;
  font-size:1.05rem;
}
.hero h1{
  margin:.14em 0;
  font-family:Impact,'Arial Black',sans-serif;
  font-size:7.6rem;
  line-height:.86;
  text-shadow:0 8px 24px rgba(0,0,0,.82),0 0 28px rgba(83,188,255,.22);
}
.hero h1 span{
  display:block;
  color:var(--cyan);
  font-size:.34em;
}
.lead{
  max-width:660px;
  font-size:1.34rem;
  font-weight:800;
  text-shadow:0 4px 18px rgba(0,0,0,.86);
}
.hero-actions{
  display:flex;
  gap:14px;
  flex-wrap:wrap;
  margin-top:28px;
}
.btn{
  display:inline-flex;
  min-height:48px;
  align-items:center;
  justify-content:center;
  gap:.55em;
  border:1px solid var(--line);
  background:rgba(5,17,31,.86);
  color:var(--text);
  padding:12px 24px;
  border-radius:6px;
  box-shadow:var(--shadow);
  font-weight:800;
  transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease;
}
.btn.primary{
  background:linear-gradient(180deg,#168bff,#064a98);
  border-color:rgba(156,233,255,.68);
}
.btn:hover{
  transform:translateY(-3px);
  box-shadow:0 0 28px rgba(83,188,255,.34);
}
.album-jacket{
  position:relative;
  align-self:center;
  justify-self:end;
  width:min(100%,440px);
  aspect-ratio:1;
  margin:0;
  overflow:hidden;
  border:1px solid rgba(156,233,255,.72);
  border-radius:8px;
  background:#030914;
  box-shadow:0 28px 70px rgba(0,0,0,.62),0 0 42px rgba(83,188,255,.22);
}
.album-jacket:before{
  content:'';
  position:absolute;
  inset:12px;
  z-index:2;
  border:1px solid rgba(156,233,255,.42);
  pointer-events:none;
}
.album-jacket img{
  width:100%;
  height:100%;
  object-fit:cover;
  filter:saturate(1.1) contrast(1.08);
}
.album-jacket figcaption{
  position:absolute;
  inset:auto 0 0;
  z-index:3;
  display:grid;
  gap:2px;
  padding:22px 24px 26px;
  background:linear-gradient(180deg,rgba(1,6,15,0),rgba(1,6,15,.88) 38%,rgba(1,6,15,.98));
  color:#fff;
  text-shadow:0 5px 18px rgba(0,0,0,.9);
}
.album-jacket span{
  color:var(--warning-red);
  font-weight:900;
  font-size:.88rem;
}
.album-jacket strong{
  font-family:Impact,'Arial Black',sans-serif;
  font-size:clamp(3rem,5vw,4.7rem);
  line-height:.86;
}
.album-jacket em{
  color:var(--cyan);
  font-style:normal;
  font-weight:900;
  font-size:1rem;
}
.scroll-hint{
  position:absolute;
  z-index:2;
  left:50%;
  bottom:28px;
  transform:translateX(-50%);
  color:var(--cyan);
  font-size:.82rem;
  text-align:center;
  animation:bounce 1.6s infinite;
}
@keyframes bounce{50%{transform:translate(-50%,7px)}}

.section{
  margin:0;
  border:1px solid var(--line-soft);
  background:linear-gradient(135deg,rgba(8,22,38,.92),rgba(2,8,18,.96));
  border-left:0;
  border-right:0;
  border-radius:0;
  box-shadow:var(--shadow);
  overflow:hidden;
}
.section-pad{
  width:100%;
  max-width:1280px;
  margin-inline:auto;
  padding:48px clamp(18px,4vw,64px);
}
.section h2{
  margin:0 0 14px;
  color:var(--cyan);
  font-size:1.75rem;
  line-height:1.35;
}
.section h3{
  margin:0 0 10px;
  color:var(--cyan);
  font-size:1.18rem;
}
.wide-visual{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(0,1fr);
  gap:26px;
  align-items:center;
}
.wide-visual.reverse{grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr)}
.visual-bg{
  width:100%;
  min-height:260px;
  aspect-ratio:16/9;
  background:center/cover no-repeat;
  border-radius:7px;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.08),0 18px 46px rgba(0,0,0,.34);
  object-fit:cover;
}
.muted{color:var(--muted)}
.grid-2{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(0,1.45fr);
  gap:22px;
  width:100%;
  margin:0;
  padding:28px clamp(18px,4vw,64px);
  background:linear-gradient(180deg,rgba(1,7,16,.38),rgba(5,18,32,.54));
}
.info-list{
  list-style:none;
  padding:0;
  margin:0;
}
.info-list li{
  display:grid;
  grid-template-columns:130px minmax(0,1fr);
  gap:14px;
  padding:8px 0;
  border-bottom:1px solid var(--line-soft);
}
.info-list strong{color:var(--cyan)}
.check-list{
  margin:0;
  padding-left:0;
  list-style:none;
}
.check-list li{
  position:relative;
  min-width:0;
  margin:10px 0;
  padding-left:31px;
}
.check-list li:before{
  content:'';
  position:absolute;
  left:0;
  top:.55em;
  width:18px;
  height:18px;
  border-radius:50%;
  background:radial-gradient(circle,var(--cyan) 0 32%,var(--blue) 36% 100%);
  box-shadow:0 0 18px rgba(83,188,255,.58);
}
.timeline{
  list-style:none;
  margin:0;
  padding:0;
  border-left:2px solid var(--accent-blue);
}
.timeline li{
  position:relative;
  display:grid;
  grid-template-columns:88px minmax(0,1fr);
  gap:14px;
  min-width:0;
  padding:4px 0 16px 22px;
}
.timeline li:before{
  content:'';
  position:absolute;
  left:-7px;
  top:14px;
  width:12px;
  height:12px;
  background:var(--accent-blue);
  border-radius:50%;
  box-shadow:0 0 0 5px rgba(83,188,255,.14),0 0 22px rgba(83,188,255,.55);
}
.accent-year{
  color:var(--cyan);
  font-weight:900;
}
.tracklist{
  columns:2;
  column-gap:58px;
  list-style:none;
  margin:0;
  padding:0;
}
.tracklist li{
  break-inside:avoid;
  padding:4px 0;
}
.tracklist b{
  display:inline-block;
  width:34px;
  color:var(--accent-blue);
}
.bonus-tracks{
  background:linear-gradient(135deg,rgba(4,18,32,.96),rgba(2,8,18,.98));
}
.bonus-kicker{
  margin:0 0 8px;
  color:var(--cyan);
  font-weight:900;
}
.bonus-lead{
  margin:0 0 14px;
  color:#d9f5ff;
  font-size:1.12rem;
  font-weight:800;
}
.bonus-tracks .section-pad > p:not(.bonus-kicker):not(.bonus-lead){
  max-width:980px;
  margin:0 0 24px;
}
.bonus-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:16px;
  margin-top:22px;
}
.bonus-card{
  min-width:0;
  min-height:250px;
  padding:22px;
  border:1px solid var(--line-soft);
  border-radius:8px;
  background:linear-gradient(180deg,rgba(9,25,43,.94),rgba(2,8,18,.98));
  box-shadow:0 18px 44px rgba(0,0,0,.26);
}
.bonus-label{
  display:inline-block;
  margin-bottom:14px;
  color:var(--cyan);
  font-size:.78rem;
  font-weight:900;
}
.bonus-card h3{
  margin:0 0 10px;
  color:var(--cyan);
  font-size:1.2rem;
}
.bonus-card p{
  margin:0;
}
.featured-title{
  text-align:center;
  border:0;
  background:transparent;
  box-shadow:none;
  width:100%;
  margin:0;
  padding:48px clamp(18px,4vw,64px) 14px;
}
.songs{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:16px;
  width:100%;
  margin:0;
  padding:20px clamp(18px,4vw,64px) 48px;
  background:linear-gradient(180deg,rgba(1,7,16,.18),rgba(5,18,32,.45));
}
.song-card{
  min-height:390px;
  border:1px solid var(--line-soft);
  background:linear-gradient(180deg,rgba(9,25,43,.96),rgba(2,8,18,.98));
  border-radius:8px;
  overflow:hidden;
  transition:transform .25s ease,box-shadow .25s ease;
}
.song-card:hover{
  transform:translateY(-6px);
  box-shadow:0 0 30px rgba(83,188,255,.24);
}
.song-img{
  width:100%;
  height:150px;
  object-fit:cover;
  filter:saturate(1.04) contrast(1.05);
}
.song-body{padding:20px}
.song-card h3{
  display:flex;
  align-items:center;
  gap:10px;
  margin:0 0 10px;
  font-size:1.08rem;
  line-height:1.35;
}
.num{
  display:inline-grid;
  flex:0 0 auto;
  place-items:center;
  width:38px;
  height:38px;
  border-radius:8px;
  background:linear-gradient(180deg,var(--accent-blue),#0757ac);
  color:#fff;
  font-weight:900;
  box-shadow:0 0 18px rgba(83,188,255,.28);
}
.affiliate{
  background:
    linear-gradient(90deg,rgba(1,8,18,.92),rgba(4,25,46,.76)),
    url('../images/encore-affiliate-purchase.jpg') center/cover no-repeat;
}
.affiliate h2{text-align:center}
.shop-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:22px;
  max-width:880px;
  margin:22px auto 0;
}
.shop-card{
  padding:25px;
  text-align:center;
  border:1px solid rgba(156,233,255,.38);
  border-radius:8px;
  background:rgba(3,12,24,.88);
  color:var(--text);
  box-shadow:var(--shadow);
}
.shop-logo{
  font-family:Arial Black,Arial,sans-serif;
  font-size:2.55rem;
  line-height:1;
  color:var(--cyan);
}
.shop-card ul{
  display:inline-block;
  margin:16px 0 20px;
  text-align:left;
}
.shop-card .btn{
  width:100%;
  box-shadow:none;
}
.shop-card .amazon-btn,
.shop-card .rakuten-btn{
  background:linear-gradient(180deg,#168bff,#064a98);
  color:#fff;
}
.critics-panel{
  width:calc(100% - 32px);
  margin:36px auto 0;
  border:1px solid var(--line);
  border-radius:6px;
  background:rgba(3,8,14,.96);
}
.critics-layout{
  max-width:none;
  padding:34px 28px 28px;
}
.critics-intro{
  display:grid;
  grid-template-columns:1fr;
  gap:12px;
  align-items:start;
}
.critics-intro h2{
  margin:0;
}
.critic-lead{
  max-width:760px;
  margin:0 auto;
  color:var(--text);
  font-weight:700;
}
.review-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:14px;
  margin-top:28px;
}
.quote-card,
.mini-card{
  min-height:162px;
  padding:22px 20px;
  border:1px solid var(--line-soft);
  border-radius:6px;
  background:rgba(2,7,12,.72);
}
.quote-card h3,
.mini-card h3{
  color:var(--cyan);
}
.mini-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:14px;
  width:100%;
  margin:0;
  padding:36px 16px 0;
  background:linear-gradient(180deg,rgba(1,7,16,.18),rgba(5,18,32,.34));
}
.mini-card{
  min-height:204px;
}
.footer{
  padding:20px 0 30px;
  color:#8198aa;
  text-align:center;
  font-size:.82rem;
}
.footer a{
  color:var(--cyan);
  text-decoration:underline;
  text-underline-offset:3px;
}
.home-btn{
  display:flex;
  justify-content:center;
  width:100%;
  margin:0 auto 8px;
  padding:28px clamp(18px,4vw,64px) 8px;
}
.to-top{
  position:fixed;
  right:22px;
  bottom:22px;
  z-index:20;
  display:grid;
  width:48px;
  height:48px;
  place-items:center;
  border:1px solid rgba(156,233,255,.68);
  border-radius:50%;
  background:linear-gradient(180deg,#168bff,#064a98);
  color:#fff;
  font-weight:900;
  box-shadow:var(--shadow);
}

.curtain-demo{padding:28px 28px 32px}
.demo-stage{
  position:relative;
  min-height:360px;
  overflow:hidden;
  border:1px solid var(--line);
  border-radius:8px;
  background:url('../images/encore-reveal-stage.jpg') center/cover no-repeat;
}
.demo-stage:before{
  content:'';
  position:absolute;
  inset:0;
  background:radial-gradient(circle at center,rgba(83,188,255,.18),rgba(1,6,15,.78));
}
.curtain-panel{
  position:absolute;
  top:0;
  bottom:0;
  z-index:2;
  width:54%;
  background-size:cover;
  background-repeat:no-repeat;
  transition:transform 8s cubic-bezier(.22,.85,.24,1);
}
.curtain-left{
  left:0;
  background-image:url('../images/encore-curtain-left.png');
  background-position:right center;
}
.curtain-right{
  right:0;
  background-image:url('../images/encore-curtain-right.png');
  background-position:left center;
}
.curtain-reveal.is-open .curtain-left{transform:translateX(-92%)}
.curtain-reveal.is-open .curtain-right{transform:translateX(92%)}
.demo-content{
  position:relative;
  z-index:1;
  display:grid;
  min-height:360px;
  place-items:center;
  padding:34px;
  text-align:center;
}
.demo-content h2{
  margin:0;
  font-size:2.6rem;
  line-height:1.35;
  text-shadow:0 3px 18px #000;
}
.demo-content p{
  color:var(--muted);
  font-size:1.05rem;
}
.fade-up,.slide-left,.slide-right{opacity:1;transform:none}
.js .fade-up{
  opacity:0;
  transform:translateY(42px);
  transition:opacity .8s ease,transform .8s ease;
}
.js .fade-up.is-visible{opacity:1;transform:translateY(0)}
.js .slide-left{
  opacity:0;
  transform:translateX(-55px);
  transition:opacity .9s ease,transform .9s ease;
}
.js .slide-right{
  opacity:0;
  transform:translateX(55px);
  transition:opacity .9s ease,transform .9s ease;
}
.js .slide-left.is-visible,
.js .slide-right.is-visible{
  opacity:1;
  transform:translateX(0);
}
.site-wrap > .curtain-reveal{
  width:100%;
  max-width:none;
  margin-top:0;
  margin-left:0;
  margin-right:0;
  border-left:0;
  border-right:0;
  border-radius:0;
  background:#010711;
}
.site-wrap > .curtain-reveal .curtain-demo{padding:0}
.site-wrap > .curtain-reveal .demo-stage{
  min-height:500px;
  border-left:0;
  border-right:0;
  border-radius:0;
}
.site-wrap > .curtain-reveal .demo-content{min-height:500px}

.about-layout{padding-inline:40px}
.about-article{
  width:100%;
  max-width:1100px;
  margin-inline:auto;
}
.about-article p{margin:0 0 1.35em}
.about-lead{
  color:#d9f5ff;
  font-size:1.18rem;
  font-weight:800;
}
.about-promo-image{
  width:100%;
  max-width:860px;
  margin:30px auto 36px;
  aspect-ratio:16/6;
  object-fit:cover;
  border:1px solid var(--line-soft);
  border-radius:7px;
  box-shadow:var(--shadow);
}
.about-divider{
  height:1px;
  margin:42px 0 30px;
  border:0;
  background:linear-gradient(90deg,transparent,var(--line),transparent);
}
.about-notes{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  column-gap:34px;
  row-gap:4px;
  margin:0 auto;
  padding:24px;
  border:1px solid var(--line-soft);
  border-radius:7px;
  background:rgba(2,8,18,.46);
  color:var(--muted);
  font-size:.9rem;
}
.about-notes h3{
  grid-column:1/-1;
  margin:0 0 16px;
  color:var(--cyan);
}
.about-notes p{
  margin:0;
  padding:0 0 14px;
  border-bottom:1px solid rgba(83,188,255,.14);
}
.about-notes p:last-child{
  margin-bottom:0;
}
.tracklist-cover{
  width:100%;
  max-width:520px;
  aspect-ratio:1;
  margin:0;
  justify-self:center;
  overflow:hidden;
  border:1px solid var(--line-soft);
  border-radius:7px;
  background:#030914;
  box-shadow:var(--shadow);
}
.tracklist-cover img{
  width:100%;
  height:100%;
  object-fit:cover;
}
.ad-section{
  width:100%;
  max-width:none;
  margin:0 auto;
  padding:34px clamp(18px,4vw,64px);
  overflow:hidden;
  text-align:center;
}
.ad-label{
  margin:0 0 8px;
  color:rgba(255,255,255,.55);
  font-size:.75rem;
  line-height:1.4;
}
.ad-placeholder{
  width:100%;
  max-width:970px;
  margin-inline:auto;
  min-height:120px;
  padding:14px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.12);
  border-radius:12px;
  background:rgba(8,16,28,.72);
  box-shadow:0 14px 38px rgba(0,0,0,.28);
}
.ad-placeholder .adsbygoogle{
  display:block;
  width:100%;
  max-width:100%;
}
.ad-desktop{display:block}
.ad-mobile{display:none}

.section,.section-pad,.wide-visual,.wide-visual > *,.grid-2,.grid-2 > *,.check-list,.check-list li,.timeline,.timeline li,.image-caption-box,.image-caption-box figcaption{
  min-width:0;
}
.section h2,.section h3,.check-list li,.timeline li,.image-caption-box figcaption,.song-card h3,.shop-logo{
  overflow-wrap:anywhere;
  word-break:normal;
}
.image-caption-box{
  width:100%;
  max-width:100%;
  margin:0;
  overflow:hidden;
}
.image-caption-box figcaption{
  max-width:100%;
  margin-top:10px;
  color:var(--muted);
  font-size:.95rem;
}

@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  .js .fade-up,.js .slide-left,.js .slide-right{opacity:1!important;transform:none!important}
  .curtain-reveal.is-open .curtain-left{transform:translateX(-92%)}
  .curtain-reveal.is-open .curtain-right{transform:translateX(92%)}
}
@media(max-width:980px){
  .hero h1{font-size:6rem}
  .songs{grid-template-columns:repeat(2,minmax(0,1fr))}
  .review-grid{grid-template-columns:1fr}
}
@media(max-width:860px){
  .hero{min-height:auto}
  .hero-inner,.wide-visual,.wide-visual.reverse,.grid-2,.shop-grid,.mini-grid{
    grid-template-columns:1fr;
  }
  .hero-inner{
    min-height:auto;
    padding-top:42px;
  }
  .album-jacket{
    justify-self:start;
    width:min(100%,380px);
  }
  .tracklist{columns:1}
  .info-list li{grid-template-columns:112px minmax(0,1fr)}
  .section-pad{padding:24px}
  .demo-stage,.demo-content{min-height:300px}
  .site-wrap > .curtain-reveal .demo-stage,
  .site-wrap > .curtain-reveal .demo-content{min-height:390px}
  .ad-desktop{display:none}
  .ad-mobile{display:block}
  .critics-panel{
    width:calc(100% - 28px);
    margin:28px auto 0;
  }
  .critics-layout{
    padding:28px 18px;
  }
  .critics-intro{
    grid-template-columns:1fr;
    gap:14px;
  }
  .critic-lead{
    max-width:none;
    margin:0;
  }
}
@media(max-width:620px){
  .site-wrap{padding-inline:0}
  .breadcrumb{padding-inline:18px}
  .hero-inner{padding:34px 16px 70px}
  .hero h1{font-size:4.05rem}
  .hero h1 span{font-size:.36em}
  .lead{font-size:1.05rem}
  .hero-actions{display:grid}
  .btn{width:100%}
  .album-jacket{
    justify-self:center;
    width:min(100%,330px);
  }
  .album-jacket figcaption{padding:18px 20px 22px}
  .bonus-grid{grid-template-columns:1fr}
  .songs{grid-template-columns:1fr}
  .section{margin:16px 0}
  .critics-panel{
    width:calc(100% - 24px);
    margin:22px auto 0;
  }
  .mini-grid{
    padding:22px 12px 0;
  }
  .section h2{font-size:1.45rem}
  .demo-content h2{font-size:1.65rem}
  .site-wrap > .curtain-reveal .demo-stage,
  .site-wrap > .curtain-reveal .demo-content{min-height:320px}
  .about-layout{padding:22px 18px}
  .about-promo-image{margin:22px auto 28px}
  .about-notes{
    grid-template-columns:1fr;
    padding:18px;
  }
  .timeline li{
    grid-template-columns:66px minmax(0,1fr);
    gap:10px;
    padding-left:18px;
  }
  .ad-section{
    max-width:100%;
    margin:30px auto;
    padding:12px;
  }
  .ad-placeholder{
    min-height:100px;
    padding:10px;
  }
}
