@import url('https://fonts.googleapis.com/css2?family=Oswald:wght@400;500;600;700&family=Noto+Sans+JP:wght@300;400;500;700;900&family=Shippori+Mincho:wght@500;700;800&display=swap');

:root{
  --ink:#0c0d0f;
  --steel:#1a1d22;
  --steel-soft:#23262c;
  --chrome:#b9c1cb;
  --chrome-dim:#6e7680;
  --turf:#c79a3e;
  --turf-soft:#8a6e2c;
  --blueprint:#5d92c4;
  --paper:#f3efe4;
  --paper-dim:#cfc9ba;
  --line:rgba(185,193,203,0.18);
  --maxw:1120px;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  background:var(--ink);
  color:var(--paper);
  font-family:'Noto Sans JP', sans-serif;
  font-weight:300;
  line-height:1.9;
  -webkit-font-smoothing:antialiased;
}
img,svg{display:block; max-width:100%;}
a{color:inherit; text-decoration:none;}
.eyebrow{
  font-family:'Oswald', sans-serif;
  font-weight:600;
  letter-spacing:.22em;
  text-transform:uppercase;
  font-size:.74rem;
  color:var(--turf);
}
.jp-display{
  font-family:'Noto Sans JP', sans-serif;
  font-weight:900;
  letter-spacing:.01em;
}
.mincho{ font-family:'Shippori Mincho', serif; }
.wrap{ max-width:var(--maxw); margin:0 auto; padding:0 28px; }
.hairline{ border:none; border-top:1px solid var(--line); margin:0; }

:focus-visible{ outline:2px solid var(--blueprint); outline-offset:3px; }

/* ---------- top bar ---------- */
.topbar{
  position:fixed; top:0; left:0; right:0; z-index:50;
  display:flex; align-items:center; justify-content:space-between;
  padding:16px 24px;
  background:linear-gradient(to bottom, rgba(12,13,15,.92), rgba(12,13,15,0));
  font-family:'Oswald', sans-serif;
}
.topbar__mark{ font-size:.85rem; letter-spacing:.18em; color:var(--paper); font-weight:600; }
.topbar__mark span{ color:var(--turf); }
.topbar__cta{
  font-size:.72rem; letter-spacing:.12em; text-transform:uppercase;
  color:var(--ink); background:var(--chrome); padding:9px 16px; border-radius:2px;
  font-weight:600;
  transition:background .25s ease;
}
.topbar__cta:hover{ background:var(--turf); }

/* ---------- hero ---------- */
.hero{
  position:relative;
  min-height:100vh;
  display:flex; flex-direction:column; justify-content:center;
  overflow:hidden;
  padding:120px 0 80px;
}
.hero__bg{
  position:absolute; inset:0; z-index:0; overflow:hidden;
  background:var(--ink);
}
.hero__bg img{
  width:100%; height:100%; object-fit:cover; object-position:center 22%;
  filter:saturate(.88) brightness(.88) contrast(1.02);
}
.hero__scrim{
  position:absolute; inset:0; z-index:1;
  background:
    linear-gradient(100deg, rgba(12,13,15,.97) 0%, rgba(12,13,15,.88) 32%, rgba(12,13,15,.5) 56%, rgba(12,13,15,.08) 80%),
    linear-gradient(to top, rgba(12,13,15,.75) 0%, rgba(12,13,15,0) 26%);
}
.hero__grid{
  position:absolute; inset:0; z-index:2; opacity:.22; mix-blend-mode:screen;
}
.hero__content{ position:absolute; z-index:3; }
.hero__credit{
  position:absolute; right:28px; bottom:30px; z-index:3;
  font-family:'Oswald', sans-serif; font-size:.68rem; letter-spacing:.12em; text-transform:uppercase;
  color:var(--chrome); background:rgba(12,13,15,.45); padding:7px 12px; border:1px solid var(--line);
}
@media (max-width:760px){ .hero__credit{ display:none; } }
.hero__meta-top{
  display:flex; align-items:center; gap:14px; margin-bottom:34px; flex-wrap:wrap;
}
.hero__meta-top .eyebrow{ font-size:.78rem; }
.hero__meta-top .dot{ width:5px; height:5px; border-radius:50%; background:var(--chrome-dim); }
.hero__meta-top .loc{
  font-family:'Oswald', sans-serif; font-size:.78rem; letter-spacing:.14em;
  color:var(--chrome); text-transform:uppercase;
}
.hero h1{
  font-size:clamp(2.4rem, 6.4vw, 4.6rem);
  margin:0 0 18px;
  line-height:1.28;
  color:var(--paper);
}
.hero h1 em{
  font-style:normal;
  color:var(--turf);
}
.hero__sub{
  font-family:'Noto Sans JP', sans-serif;
  font-weight:500;
  font-size:clamp(1.05rem, 2.3vw, 1.45rem);
  line-height:1.7;
  letter-spacing:.01em;
  color:var(--chrome);
  margin:0 0 30px;
  max-width:34em;
}
.hero__lede{
  max-width:42em;
  font-size:1.02rem;
  color:var(--paper-dim);
  font-weight:300;
}
.hero__dates{
  margin-top:48px; display:flex; gap:40px; flex-wrap:wrap;
}
.hero__dates div{ font-family:'Oswald', sans-serif; }
.hero__dates .num{ font-size:1.5rem; color:var(--paper); font-weight:600; letter-spacing:.02em; }
.hero__dates .lbl{ font-size:.68rem; letter-spacing:.16em; text-transform:uppercase; color:var(--chrome-dim); margin-top:4px; }
.hero__scroll{
  position:absolute; bottom:32px; left:28px; z-index:2;
  display:flex; align-items:center; gap:10px;
  font-family:'Oswald', sans-serif; font-size:.68rem; letter-spacing:.2em; text-transform:uppercase;
  color:var(--chrome-dim);
}
.hero__scroll .bar{ width:1px; height:38px; background:var(--chrome-dim); position:relative; overflow:hidden; }
.hero__scroll .bar::after{
  content:''; position:absolute; top:-100%; left:0; width:100%; height:100%;
  background:var(--turf);
  animation:scrollDrop 2.2s ease-in-out infinite;
}
@keyframes scrollDrop{ 0%{top:-100%;} 60%{top:100%;} 100%{top:100%;} }

/* ---------- section rhythm ---------- */
.section{ padding:108px 0; position:relative; }
.section--tight{ padding:72px 0; }
.section-head{ max-width:46em; margin-bottom:46px; }
.section-head .eyebrow{ display:block; margin-bottom:16px; }
.section-head h2{
  font-size:clamp(1.7rem, 3.4vw, 2.5rem);
  margin:0;
  line-height:1.45;
  color:var(--paper);
}
.body-text{ max-width:42em; color:var(--paper-dim); font-size:1.02rem; }
.body-text p{ margin:0 0 1.4em; }
.body-text p:last-child{ margin-bottom:0; }
.body-text strong{ color:var(--paper); font-weight:500; }

/* ---------- lede / context ---------- */
.lede{
  display:grid; grid-template-columns: 1.5fr 1fr; gap:64px;
}
.lede__facts{ border-left:1px solid var(--line); padding-left:32px; }
.lede__facts dl{ margin:0; }
.lede__facts dt{
  font-family:'Oswald', sans-serif; font-size:.68rem; letter-spacing:.16em; text-transform:uppercase;
  color:var(--chrome-dim); margin-top:22px;
}
.lede__facts dt:first-child{ margin-top:0; }
.lede__facts dd{ margin:6px 0 0; font-size:.98rem; color:var(--paper); font-weight:400; }
@media (max-width:760px){
  .lede{ grid-template-columns:1fr; gap:36px; }
  .lede__facts{ border-left:none; border-top:1px solid var(--line); padding-left:0; padding-top:28px; }
}

/* ---------- video clip component ---------- */
.clip{ display:flex; gap:28px; align-items:center; flex-wrap:wrap; }
.clip__video{
  position:relative; flex-shrink:0; width:170px;
  border:1px solid var(--line); overflow:hidden; background:#000;
}
.clip__video video{ width:100%; aspect-ratio:9/16; object-fit:cover; display:block; }
.clip__tag{
  position:absolute; left:8px; top:8px; z-index:2;
  font-family:'Oswald', sans-serif; font-size:.58rem; letter-spacing:.1em; text-transform:uppercase;
  color:var(--paper); background:rgba(12,13,15,.55); padding:3px 7px;
}
.clip__caption{ flex:1; min-width:220px; font-size:.95rem; color:var(--paper-dim); }
.clip__caption .lbl{
  display:block; margin-bottom:6px; font-family:'Oswald', sans-serif; font-size:.74rem;
  letter-spacing:.1em; text-transform:uppercase; color:var(--turf);
}
.clip--feature .clip__video{ width:225px; }
.onsite-strip{ margin-top:42px; padding-top:38px; border-top:1px solid var(--line); }

/* ---------- interview ---------- */
.interview{ background:var(--steel); }
.interview__grid{ display:grid; grid-template-columns: 88px 1fr; gap:32px; }
.interview__num{
  font-family:'Oswald', sans-serif; font-size:.8rem; color:var(--chrome-dim);
  letter-spacing:.1em;
}
.pull{
  margin:40px 0 0;
  padding:34px 0 34px 28px;
  border-left:3px solid var(--turf);
  max-width:36em;
}
.pull p{
  font-family:'Shippori Mincho', serif;
  font-weight:700;
  font-size:clamp(1.15rem, 2.2vw, 1.5rem);
  line-height:1.85;
  color:var(--paper);
  margin:0;
}
.pull cite{
  display:block; margin-top:18px; font-style:normal;
  font-family:'Oswald', sans-serif; font-size:.74rem; letter-spacing:.1em;
  color:var(--chrome-dim); text-transform:uppercase;
}
@media (max-width:760px){
  .interview__grid{ grid-template-columns:1fr; }
}

/* ---------- statement (big quote block) ---------- */
.statement{
  text-align:center;
  padding:130px 0;
  background:
    linear-gradient(180deg, var(--ink) 0%, var(--steel) 50%, var(--ink) 100%);
}
.statement .eyebrow{ display:block; text-align:center; margin-bottom:28px; }
.statement h3{
  font-family:'Shippori Mincho', serif;
  font-weight:800;
  font-size:clamp(1.7rem, 5vw, 3.1rem);
  line-height:1.6;
  margin:0 auto;
  max-width:18em;
  color:var(--paper);
}
.statement h3 .accent{ color:var(--turf); }
.statement cite{
  display:block; margin-top:28px; font-style:normal;
  font-family:'Oswald', sans-serif; font-size:.78rem; letter-spacing:.14em;
  color:var(--chrome-dim); text-transform:uppercase;
}
.statement .note{
  max-width:32em; margin:30px auto 0; font-size:.95rem; color:var(--paper-dim);
}

/* ---------- watch / social ---------- */
.watch{ background:var(--steel); }
.watch__grid{ display:flex; gap:18px; flex-wrap:wrap; margin-top:30px; }
.social-card{
  flex:1; min-width:220px;
  border:1px solid var(--line);
  padding:24px 22px;
  display:flex; align-items:center; gap:16px;
  transition:border-color .25s ease, background .25s ease;
}
.social-card:hover{ border-color:var(--turf); background:rgba(199,154,62,0.05); }
.social-card__icon{
  width:42px; height:42px; border-radius:50%;
  border:1px solid var(--chrome-dim);
  display:flex; align-items:center; justify-content:center; flex-shrink:0;
}
.social-card__icon svg{ width:18px; height:18px; fill:var(--chrome); }
.social-card__text .ttl{ font-family:'Oswald', sans-serif; font-size:.88rem; letter-spacing:.06em; color:var(--paper); }
.social-card__text .sub{ font-size:.82rem; color:var(--chrome-dim); margin-top:2px; }

/* ---------- spec table ---------- */
.spec-table-wrap{ overflow-x:auto; border:1px solid var(--line); }
table.spec{
  width:100%; border-collapse:collapse; min-width:680px;
  font-family:'Oswald', sans-serif;
}
table.spec th, table.spec td{
  padding:14px 16px; text-align:center; border-bottom:1px solid var(--line); font-size:.88rem;
}
table.spec thead th{
  background:var(--steel-soft); color:var(--chrome); font-weight:500; letter-spacing:.04em;
  font-size:.74rem; text-transform:uppercase;
}
table.spec tbody th{
  text-align:left; color:var(--chrome); font-weight:400; background:var(--steel-soft);
  font-family:'Noto Sans JP', sans-serif; font-size:.85rem; white-space:nowrap;
}
table.spec td{ color:var(--paper-dim); }
table.spec td.hl, table.spec th.hl{ background:rgba(199,154,62,0.10); color:var(--paper); position:relative; }
table.spec td.hl::after{ content:''; }
.spec-flag{
  display:inline-block; margin-top:4px; font-size:.62rem; letter-spacing:.08em; color:var(--turf);
}
.spec-foot{
  display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:18px; margin-top:26px;
}
.spec-foot p{ font-size:.86rem; color:var(--chrome-dim); margin:0; max-width:30em; }

/* ---------- CTA buttons ---------- */
.btn{
  display:inline-flex; align-items:center; gap:10px;
  font-family:'Oswald', sans-serif; font-size:.8rem; letter-spacing:.1em; text-transform:uppercase;
  padding:14px 26px; border-radius:2px; font-weight:600;
}
.btn--solid{ background:var(--turf); color:var(--ink); }
.btn--solid:hover{ background:#dab155; }
.btn--ghost{ border:1px solid var(--chrome-dim); color:var(--paper); }
.btn--ghost:hover{ border-color:var(--paper); }
.btn svg{ width:13px; height:13px; fill:currentColor; }

/* ---------- final CTA ---------- */
.final-cta{
  text-align:center; padding:130px 0;
  background:linear-gradient(180deg, var(--ink), #0a1a26 60%, var(--ink));
}
.final-cta h2{
  font-size:clamp(1.7rem, 4vw, 2.7rem); max-width:18em; margin:0 auto 22px; line-height:1.5;
}
.final-cta p{ color:var(--paper-dim); max-width:32em; margin:0 auto 36px; }
.final-cta__btns{ display:flex; gap:16px; justify-content:center; flex-wrap:wrap; }
.tagline{
  margin:36px 0 0; text-align:left;
  font-family:'Shippori Mincho', serif; font-weight:700;
  font-size:clamp(1.15rem, 2.4vw, 1.5rem); line-height:1.7; color:var(--paper);
  border-top:1px solid var(--line); padding-top:30px; max-width:38em;
}
.tagline .accent{ color:var(--turf); }

/* ---------- footer ---------- */
footer{ border-top:1px solid var(--line); padding:60px 0 40px; }
.foot-grid{ display:grid; grid-template-columns:1.2fr 1fr 1fr; gap:40px; }
@media (max-width:760px){ .foot-grid{ grid-template-columns:1fr; gap:30px; } }
.foot-grid h4{
  font-family:'Oswald', sans-serif; font-size:.72rem; letter-spacing:.14em; text-transform:uppercase;
  color:var(--chrome-dim); margin:0 0 14px;
}
.foot-grid address, .foot-grid p{ font-size:.86rem; color:var(--paper-dim); margin:0 0 6px; line-height:1.7; font-style:normal; }
.foot-grid a{ color:var(--paper-dim); }
.foot-grid a:hover{ color:var(--turf); }
.foot-bottom{
  margin-top:46px; padding-top:24px; border-top:1px solid var(--line);
  font-size:.74rem; color:var(--chrome-dim); display:flex; justify-content:space-between; flex-wrap:wrap; gap:10px;
}

/* ---------- reveal animation ---------- */
.reveal{ opacity:0; transform:translateY(22px); transition:opacity .8s ease, transform .8s ease; }
.reveal.is-visible{ opacity:1; transform:translateY(0); }

@media (prefers-reduced-motion: reduce){
  *{ animation:none !important; transition:none !important; }
  .reveal{ opacity:1; transform:none; }
}


/* =====================================
   HERO KV absolute layout
===================================== */

.hero{
  position:relative;
  min-height:100vh;
  overflow:hidden;
}

.hero__content{
  position:absolute;
  z-index:3;
  left:7%;
  top:75%;
  transform:translateY(-40%);
  max-width:900px;
  padding:0;
  margin:0;
}

.hero h1{
  font-size:clamp(2.5rem,5.6vw,4.8rem);
  line-height:1.28;
  max-width:850px;
}

.hero__sub,
.hero__lede{
  max-width:720px;
}

.hero__dates{
  margin-top:40px;
  justify-content:flex-start;
}

@media(max-width:1024px){
  .hero__content{
    left:6%;
    top:55%;
    transform:translateY(-35%);
  }
}

@media(max-width:768px){
  .hero__content{
    left:24px;
    right:24px;
    top:52%;
    transform:translateY(-20%);
    max-width:none;
  }
}

/* =====================================
   HERO 上部情報配置
===================================== */


/* Photo credit */
.hero__credit{
  top:120px;
  bottom:auto;
  right:auto;
  left:7%;

  background:none;
  border:none;
  padding:0;

  color:var(--chrome);
}


/* SPECIAL FEATURE / LOCATION */
.hero__meta-top{
  position:absolute;
  top:-130px;
  left:0;

  margin:0;
  width:100%;
}


/* タイトル位置は維持 */
.hero h1{
  margin-top:0;
}


/* =====================
   smartphone
===================== */

@media(max-width:768px){


  .hero__credit{
    display:block;

    top:95px;
    left:28px;

    font-size:.55rem;
    opacity:.75;
  }


  .hero__meta-top{
    position:absolute;
    top:-180px;
    left:0;

    display:flex;
    gap:12px;
  }


}

/* =====================================
   HERO サブコピー SPサイズ調整
===================================== */

@media(max-width:768px){

  .hero__sub{
    font-size:80%;
    line-height:1.8;
  }

}


/* =====================================
   HERO 日付エリア文字被り修正
===================================== */

.hero__dates{
  align-items:flex-start;
}

.hero__dates > div{
  display:flex;
  flex-direction:column;
  gap:8px; /* 上下間隔 */
}

.hero__dates .num{
  line-height:1.1;
}

.hero__dates .lbl{
  line-height:1.4;
  margin-top:0;
}


/* smartphone */
@media(max-width:768px){

  .hero__dates{
    gap:24px;
  }

  .hero__dates > div{
    gap:6px;
  }

  .hero__dates .num{
    font-size:1.25rem;
  }

  .hero__dates .lbl{
    font-size:.6rem;
  }

}

/* =====================================
   HERO グリッド線削除
===================================== */

.hero__grid{
  display:none !important;
}