:root{
  --bg:#101010;
  --bg-2:#181818;
  --panel:#1c1c1c;
  --line:rgba(255,255,255,.14);
  --text:#ededed;
  --muted:#a2a2a2;
  --soft:#7d7d7d;
  --accent:#f2f2f2;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--bg);
  color:var(--text);
  font-family:'Noto Sans JP',sans-serif;
  line-height:1.9;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%}
::selection{background:#f2f2f2;color:#111}
@keyframes nb-bob{0%,100%{transform:translate(-50%,0)}50%{transform:translate(-50%,8px)}}

.wrap{max-width:1080px;margin:0 auto;padding:0 24px}

/* shared section atoms */
.eyebrow{font-family:'Cormorant Garamond',serif;letter-spacing:.34em;text-transform:uppercase;color:var(--soft);font-size:13px;margin-bottom:18px}
.sec-h2{font-family:'Shippori Mincho',serif;font-weight:700;font-size:30px;letter-spacing:.04em;margin:0 0 8px;color:var(--text)}
.sec-h2 .en{display:block;font-family:'Cormorant Garamond',serif;font-weight:500;font-size:15px;letter-spacing:.3em;text-transform:uppercase;color:var(--soft);margin-top:6px}
.rule{width:46px;height:2px;background:var(--accent);margin:22px 0 30px}
.sec-pad{padding:96px 0}

/* header */
.hdr-bar{position:sticky;top:0;z-index:50;backdrop-filter:blur(8px);background:rgba(16,16,16,.78);border-bottom:1px solid var(--line)}
#hdr{max-width:1080px;margin:0 auto;padding:0 24px;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;height:92px}
#hdr-logo{display:flex;align-items:center;text-decoration:none;color:var(--text);justify-self:start}
#hdr-logo img{height:58px;width:auto;display:block}
#nav{display:flex;gap:30px;list-style:none;margin:0;padding:0;justify-self:center}
.nav-link{font-size:13px;letter-spacing:.18em;color:var(--muted);text-decoration:none;transition:color .25s}
.nav-link:hover{color:var(--text)}
#hdr-lang{display:flex;gap:10px;font-family:'Cormorant Garamond',serif;font-size:13px;letter-spacing:.15em;justify-self:end}
#hdr-lang a{text-decoration:none;color:var(--soft);transition:color .25s}
#hdr-lang a.on{color:var(--text)}
#hdr-lang a:hover{color:var(--text)}
#hdr-lang span{color:var(--soft)}

/* hero */
#top{min-height:100vh;display:flex;align-items:center;position:relative;overflow:hidden;background:#070707}
#freyja{position:absolute;right:0;top:-92px;height:calc(100% + 92px);width:auto;z-index:1;pointer-events:none;filter:drop-shadow(-30px 10px 70px rgba(0,0,0,.7))}
#fade-h{position:absolute;inset:0;z-index:2;pointer-events:none;background:linear-gradient(90deg,#070707 32%,rgba(7,7,7,.55) 56%,rgba(7,7,7,0) 78%)}
#fade-v{position:absolute;inset:0;z-index:2;pointer-events:none;background:linear-gradient(0deg,rgba(7,7,7,.85),rgba(7,7,7,0) 30%)}
#hero-content{position:relative;z-index:3;width:100%;max-width:1080px;margin:0 auto;padding:0 24px;display:flex}
#hero-block{display:flex;flex-direction:column;align-items:center;width:max-content;max-width:100%}
#hero-logo{width:600px;max-width:88vw;height:auto;display:block}
#hero-sns{display:flex;gap:16px;flex-wrap:wrap;justify-content:center;margin-top:52px}
.hero-sns-btn{display:flex;align-items:center;justify-content:center;width:58px;height:58px;border-radius:50%;border:2px solid rgba(255,255,255,.65);color:#e8e8e8;font-size:23px;text-decoration:none;transition:.25s}
.hero-sns-btn:hover{color:#111;background:#f2f2f2;border-color:#f2f2f2}
#scroll-cue{position:absolute;bottom:34px;left:50%;transform:translateX(-50%);z-index:3;color:#cfcfcf;font-family:'Cormorant Garamond',serif;letter-spacing:.3em;font-size:11px;animation:nb-bob 2.4s ease-in-out infinite}

/* about */
#about-grid{display:grid;grid-template-columns:300px 1fr;gap:56px;align-items:center}
.about-icon{display:flex;align-items:center;justify-content:center}
.about-icon img{width:300px;max-width:100%;height:auto;display:block}
.about-body p{color:var(--muted);margin:0 0 16px;font-size:15px}
.about-body p:last-child{margin-bottom:0}
.about-body strong{color:var(--text);font-weight:700}

/* works */
#works-grid{display:grid;grid-template-columns:3fr 2fr;border:1px solid var(--line);background:var(--panel)}
#works-art{position:relative;background:#eceae4;border-right:1px solid var(--line);overflow:hidden;align-self:stretch;display:flex;align-items:flex-end;justify-content:center}
#works-art .key{width:100%;height:auto;display:block}
#works-art .title-logo{position:absolute;top:28px;left:50%;transform:translateX(-50%);width:64%;max-width:340px;height:auto;filter:drop-shadow(0 0 4px rgba(255,255,255,1)) drop-shadow(0 0 8px rgba(255,255,255,1)) drop-shadow(0 0 16px rgba(255,255,255,.95)) drop-shadow(0 0 30px rgba(255,255,255,.8))}
html[lang="en"] #works-art .title-logo{width:86%;max-width:480px}
#works-info{padding:44px;display:flex;flex-direction:column;justify-content:center}
#works-info h3{font-family:'Shippori Mincho',serif;font-weight:600;font-size:26px;letter-spacing:.06em;margin:0 0 6px;color:var(--text)}
.works-sub{font-family:'Cormorant Garamond',serif;letter-spacing:.22em;text-transform:uppercase;color:var(--soft);font-size:12px;margin-bottom:22px}
#works-info p{color:var(--muted);font-size:14.5px;margin:0 0 18px}
#works-info strong{color:var(--text);font-weight:700}
#works-info .platform{color:var(--text);font-size:13px;letter-spacing:.06em;margin:0;font-weight:500}
.trailer{margin-top:24px;border:1px solid var(--line);position:relative;width:100%;aspect-ratio:16/9;line-height:0;background:#000}
.trailer iframe{position:absolute;inset:0;width:100%;height:100%;border:0;display:block}
.yt-facade{position:absolute;inset:0;width:100%;height:100%;padding:0;border:0;cursor:pointer;background-color:#000;background-position:center;background-size:cover;display:flex;align-items:center;justify-content:center}
.yt-facade .yt-play{width:68px;height:48px;border-radius:12px;background:rgba(0,0,0,.72);display:flex;align-items:center;justify-content:center;color:#fff;font-size:26px;transition:.25s}
.yt-facade:hover .yt-play{background:#f00}
.works-btns{display:flex;gap:16px;flex-wrap:wrap;margin-top:22px;justify-content:center}
.steam-btn{display:inline-flex;align-items:center;gap:14px;padding:14px 30px;background:linear-gradient(135deg,#1b2838,#2a475e);border:1px solid #66c0f4;color:#fff;text-decoration:none;transition:.25s}
.steam-btn:hover{background:linear-gradient(135deg,#2a475e,#3a6a8e)}
.steam-btn i{font-size:30px;color:#fff}
.steam-btn .stack{display:flex;flex-direction:column;line-height:1.2;text-align:left}
.steam-btn .small{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:#9fd3f0}
.steam-btn .big{font-family:'Cormorant Garamond',serif;font-size:19px;letter-spacing:.08em}
.btn-outline{display:inline-flex;align-items:center;font-family:'Cormorant Garamond',serif;letter-spacing:.18em;text-transform:uppercase;font-size:14px;padding:0 30px;border:1px solid var(--accent);color:var(--accent);text-decoration:none;transition:.25s}
.btn-outline:hover{background:var(--accent);color:#111}

/* links */
#links-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:16px;margin-bottom:40px}
.link-card{aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;border:1px solid var(--line);background:var(--panel);color:var(--muted);text-decoration:none;transition:.25s}
.link-card:hover{color:#111;background:var(--accent);border-color:var(--accent);transform:translateY(-3px)}
.link-card i{font-size:26px}
.link-card span{font-size:11px;letter-spacing:.12em}
#patreon-card{display:flex;align-items:center;gap:30px;border:1px solid var(--line);background:var(--panel);padding:40px 44px;text-decoration:none}
#patreon-card .pic{flex:none;width:72px;height:72px;border-radius:50%;border:1px solid var(--accent);display:flex;align-items:center;justify-content:center;font-size:34px;color:var(--text)}
#patreon-card h3{font-family:'Shippori Mincho',serif;font-weight:600;font-size:22px;margin:0 0 6px;color:var(--text)}
#patreon-card p{color:var(--muted);font-size:14px;margin:0}
#patreon-join{margin-left:auto}
#patreon-join span{font-family:'Cormorant Garamond',serif;letter-spacing:.18em;text-transform:uppercase;font-size:13px;padding:13px 26px;border:1px solid var(--accent);color:var(--text);display:inline-block}

/* contact */
#contact{text-align:center}
.contact-text{color:var(--muted);max-width:560px;margin:0 auto 30px;font-size:15px}
.mail-btn{font-family:'Cormorant Garamond',serif;letter-spacing:.18em;text-transform:uppercase;font-size:13px;padding:13px 26px;border:1px solid var(--accent);background:var(--accent);color:#111;text-decoration:none;display:inline-block;transition:.25s}
.mail-btn:hover{background:#fff}

/* footer */
.site-footer{background:#000;border-top:1px solid var(--line);padding:48px 0;text-align:center}
.site-footer img{height:30px;width:auto;margin:0 auto 18px;opacity:.85;display:block}
.site-footer p{color:rgba(255,255,255,.5);font-size:12px;letter-spacing:.1em;margin:0}

/* responsive */
@media (max-width:860px){
  #hdr{display:flex;flex-wrap:wrap;justify-content:center;gap:10px 22px;height:auto;padding:14px 16px}
  #hdr-logo{justify-self:center}
  #nav{gap:18px;justify-self:center;flex-wrap:wrap;justify-content:center}
  #hdr-lang{justify-self:center}
  #hero-content{justify-content:center;align-items:flex-start;padding-top:0}
  #hero-block{align-items:center;text-align:center;margin-top:58vw;padding-bottom:40px}
  #hero-logo{filter:drop-shadow(0 0 7px rgba(0,0,0,.9)) drop-shadow(0 0 16px rgba(0,0,0,.75)) drop-shadow(0 0 28px rgba(0,0,0,.6))}
  #hero-sns a{box-shadow:0 0 12px 4px rgba(0,0,0,.6);background:rgba(0,0,0,.32)}
  #freyja{width:100%;height:auto;max-height:none;left:0;right:auto;top:0;bottom:auto;transform:none;-webkit-mask-image:linear-gradient(180deg,#000 82%,rgba(0,0,0,0) 99%);mask-image:linear-gradient(180deg,#000 82%,rgba(0,0,0,0) 99%)}
  #fade-h{background:linear-gradient(180deg,rgba(7,7,7,0) 26%,rgba(7,7,7,.5) 54%,rgba(7,7,7,.92) 82%)}
  #fade-v{background:none}
  #works-grid{grid-template-columns:1fr}
  #works-art{min-height:340px;border-right:none;border-bottom:1px solid var(--line)}
  #works-info{padding:32px 26px}
  #about-grid{grid-template-columns:1fr;gap:34px;justify-items:center;text-align:left}
  #links-grid{grid-template-columns:repeat(3,1fr)}
  #patreon-card{flex-direction:column;text-align:center;gap:18px;padding:30px 24px}
  #patreon-card #patreon-join{margin-left:0}
  .sec-pad{padding:64px 0}
}
@media (max-width:430px){
  #links-grid{grid-template-columns:repeat(2,1fr)}
}
