*{box-sizing:border-box}
:root{
  --bg:#050507;
  --text:#f3eee8;
  --muted:rgba(255,255,255,.72);
  --line:rgba(255,255,255,.14);
  --panel:rgba(255,255,255,.04);
}
html{scroll-behavior:smooth}
body{
  margin:0;
  color:var(--text);
  font-family:"Noto Sans JP",sans-serif;
  background:
    radial-gradient(circle at 50% 12%, rgba(191,129,82,.18), transparent 20%),
    radial-gradient(circle at 50% 60%, rgba(84,92,131,.10), transparent 26%),
    linear-gradient(180deg,#040406 0%,#08070b 100%);
  letter-spacing:.03em;
}
body::before{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  background:
    radial-gradient(circle at 20% 20%, rgba(255,255,255,.02), transparent 22%),
    radial-gradient(circle at 80% 70%, rgba(255,255,255,.015), transparent 20%);
  mix-blend-mode:screen;
}
a{color:inherit;text-decoration:none}
.container{width:min(1120px,calc(100% - 48px));margin:0 auto}
.narrow{width:min(820px,calc(100% - 48px))}
.site-header{
  position:fixed; inset:0 0 auto 0; z-index:20;
  background:linear-gradient(180deg,rgba(4,4,6,.78),rgba(4,4,6,.1),transparent);
}
.header-inner{
  width:min(1120px,calc(100% - 48px));
  margin:0 auto;
  padding:24px 0;
  display:flex; align-items:center; justify-content:space-between;
}
.brand{
  font-family:"Cormorant Garamond",serif;
  font-size:1.65rem; letter-spacing:.08em;
}
.nav{display:flex; gap:24px; font-size:.95rem; color:rgba(255,255,255,.76)}
.hero{
  min-height:100vh;
  position:relative;
  display:grid; place-items:center;
  background-image:url('hero.jpg');
  background-size:cover;
  background-position:center center;
}
.hero-overlay{
  position:absolute; inset:0;
  background:
    linear-gradient(180deg, rgba(3,3,4,.35) 0%, rgba(3,3,4,.22) 32%, rgba(4,4,6,.66) 76%, rgba(4,4,6,.96) 100%);
}
.hero-content{
  position:relative; z-index:1;
  text-align:center; padding:120px 24px 96px;
}
.eyebrow,.section-label{
  font-family:"Cormorant Garamond",serif;
  text-transform:uppercase;
  letter-spacing:.16em;
  color:rgba(255,255,255,.88);
}
.eyebrow{font-size:1.1rem; margin:0 0 24px}
.hero h1{
  margin:0;
  font-family:"Cormorant Garamond",serif;
  font-weight:500;
  font-size:clamp(4rem,10vw,7rem);
  line-height:.95;
  text-shadow:0 10px 35px rgba(0,0,0,.36);
}
.role{
  margin:16px 0 0;
  font-family:"Cormorant Garamond",serif;
  font-size:clamp(1.4rem,3vw,2rem);
  letter-spacing:.08em;
}
.section{padding:72px 0}
.section-label{
  margin:0 0 24px;
  text-align:center;
  font-size:1.15rem;
}
.works-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:28px;
}
.work-card{display:block}
.thumb{
  position:relative;
  aspect-ratio:16/9;
  background-size:cover;
  background-position:center;
  border:1px solid var(--line);
  overflow:hidden;
}
.thumb::after{
  content:"";
  position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,.05), rgba(0,0,0,.24));
}
.play{
  position:absolute; left:50%; top:50%;
  transform:translate(-50%,-50%);
  z-index:1;
  width:64px; height:64px;
  border-radius:999px;
  display:grid; place-items:center;
  background:rgba(0,0,0,.38);
  border:1px solid rgba(255,255,255,.24);
  font-size:1.2rem;
}
.work-title{
  margin-top:16px;
  text-align:center;
  font-family:"Cormorant Garamond",serif;
  font-size:2rem;
  letter-spacing:.06em;
}
.center{text-align:center; margin-top:38px}
.outline-button{
  display:inline-block;
  padding:16px 34px;
  border:1px solid var(--line);
  letter-spacing:.14em;
  text-transform:uppercase;
  font-size:.9rem;
}
.about-wrap{text-align:center}
.about h2{
  margin:0 0 22px;
  font-family:"Cormorant Garamond",serif;
  font-size:clamp(2.8rem,6vw,4.3rem);
  font-weight:500;
}
.about-text{
  margin:0 auto;
  color:var(--muted);
  line-height:2.1;
  font-size:1rem;
}
.service-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:18px;
}
.service-card{
  min-height:106px;
  display:grid; place-items:center;
  text-align:center;
  padding:18px;
  border:1px solid var(--line);
  background:var(--panel);
  letter-spacing:.07em;
}
.contact-row{
  display:flex; align-items:center; justify-content:center; gap:28px;
  flex-wrap:wrap;
  font-family:"Cormorant Garamond",serif;
  font-size:2rem;
  text-align:center;
}
.divider{
  width:1px; height:28px; background:var(--line);
}
@media (max-width: 900px){
  .works-grid{grid-template-columns:1fr; gap:24px}
  .service-grid{grid-template-columns:repeat(2,1fr)}
  .work-title{font-size:1.8rem}
}
@media (max-width: 640px){
  .header-inner{padding:18px 0}
  .nav{display:none}
  .container,.narrow{width:min(100%,calc(100% - 28px))}
  .hero{min-height:88vh; background-position:center center}
  .eyebrow{font-size:1rem}
  .hero h1{font-size:clamp(3.4rem,14vw,5rem)}
  .role{font-size:1.25rem}
  .section{padding:56px 0}
  .service-grid{grid-template-columns:1fr}
  .contact-row{font-size:1.45rem; gap:16px}
  .divider{display:none}
  .outline-button{width:100%; max-width:320px}
}
