/* ============================================================
   index.html — top page specific
   ============================================================ */

/* HERO */
.hero{
  position:relative;
  height:100vh;
  min-height:760px;
  background:var(--ink);
  color:var(--paper);
  overflow:hidden;
}
.hero-stage{
  position:absolute; inset:24px;
  overflow:hidden;
  border:1px solid rgba(243,239,232,.15);
}
.hero-img{
  position:absolute; inset:0;
  transform:scale(1.05);
}
.hero-scrim{
  position:absolute; inset:0;
  background:
    linear-gradient(180deg, rgba(15,13,12,.45) 0%, rgba(15,13,12,.15) 40%, rgba(15,13,12,.75) 100%);
}
.hero-tl{ position:absolute; top:28px; left:28px; }
.hero-tr{ position:absolute; top:28px; right:28px; text-align:right; }
.hero-bl{ position:absolute; bottom:80px; right:28px; display:flex; gap:12px; }
.hero-br{ position:absolute; bottom:80px; left:28px; }

.hero-body{
  position:absolute;
  left:48px; bottom:120px;
  right:48px;
  max-width:1200px;
}
.hero-title{
  font-size:clamp(56px, 8.2vw, 128px);
  line-height:1.02;
  font-weight:300;
  font-variation-settings:"SOFT" 60,"opsz" 144;
  letter-spacing:-.03em;
}
.hero-title span{ display:block; }
.hero-title .ln2{ padding-left:1.2em; }
.hero-title .ital{ font-style:italic; font-weight:300; color:rgba(243,239,232,.85); }
.hero-sub{
  font-size:16px;
  margin-top:40px;
  line-height:2;
  max-width:560px;
  color:rgba(243,239,232,.88);
  word-break:keep-all;
  line-break:strict;
  overflow-wrap:break-word;
}

.marquee{
  position:absolute; left:0; right:0; bottom:24px;
  overflow:hidden;
  border-top:1px solid rgba(243,239,232,.18);
  border-bottom:1px solid rgba(243,239,232,.18);
  padding:14px 0;
  background:rgba(15,13,12,.55);
  pointer-events:none;
}
.marquee-inner{
  display:flex; gap:32px;
  white-space:nowrap;
  animation: marq 50s linear infinite;
  font-family:var(--f-mono);
  font-size:11px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:rgba(243,239,232,.75);
}
.marquee-inner span{ display:inline-block; }
@keyframes marq{
  from{ transform:translateX(0); }
  to  { transform:translateX(-50%); }
}

/* MANIFESTO */
.manifesto{
  display:grid;
  grid-template-columns: 200px 1fr 340px;
  gap:56px;
  align-items:start;
}
.manifesto-meta{
  display:flex; flex-direction:column; gap:12px;
  padding-top:12px;
}
.manifesto-meta .sig{
  font-size:11px;
  color:var(--ink-3);
  letter-spacing:.15em;
}
.mani-body{
  font-size:clamp(44px, 5vw, 72px);
  line-height:1.08;
  letter-spacing:-.02em;
  font-weight:300;
}
.mani-body .ital{ font-style:italic; color:var(--clay); }
.mani-jp{
  font-size:15px;
  line-height:2.1;
  color:var(--ink-2);
  max-width:320px;
  padding-top:16px;
  border-top:1px solid var(--line);
}

/* SERVICE */
.svc-grid{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap:0;
  border-top:1px solid var(--ink);
  border-left:1px solid var(--ink);
}
.svc{
  padding:40px 28px 36px;
  border-bottom:1px solid var(--ink);
  border-right:1px solid var(--ink);
  background:var(--paper-2);
  display:flex; flex-direction:column;
  min-height:420px;
  transition: background .3s;
}
.svc:hover{ background:var(--paper); }
.svc-no{
  font-size:10px;
  letter-spacing:.22em;
  color:var(--ink-3);
  margin-bottom:36px;
}
.svc h3{
  font-size:44px;
  line-height:0.98;
  letter-spacing:-.02em;
  font-weight:300;
  font-variation-settings:"SOFT" 50,"opsz" 144;
}
.svc-jp{
  font-size:14px;
  margin-top:12px;
  color:var(--ink-2);
}
.svc p{
  font-family:var(--f-jp);
  font-size:13px;
  line-height:2;
  color:var(--ink-2);
  margin-top:auto;
  padding-top:24px;
}
.svc-tags{
  display:flex; gap:6px; flex-wrap:wrap;
  margin-top:16px;
}
.svc-tags li{
  font-family:var(--f-mono);
  font-size:9px;
  letter-spacing:.16em;
  text-transform:uppercase;
  padding:3px 9px;
  border:1px solid var(--line);
  border-radius:100px;
  color:var(--ink-3);
}

/* WORKS TEASER */
.work-feat{
  display:grid;
  grid-template-columns: 1.35fr 1fr;
  gap:24px;
  margin-bottom:56px;
}
.w-lg{ display:flex; flex-direction:column; }
.w-lg .ph{ aspect-ratio: 5/4; width:100%; }
.w-col{ display:flex; flex-direction:column; gap:24px; }
.w-sm{ display:flex; flex-direction:column; flex:1; }
.w-sm .ph{ aspect-ratio: 16/10; width:100%; flex:1; }

.w-meta{
  margin-top:20px;
  padding-top:16px;
  border-top:1px solid var(--ink);
  display:flex; justify-content:space-between; align-items:flex-end; gap:16px;
}
.w-meta .tick{ letter-spacing:.22em; }
.w-meta h4{
  font-size:34px;
  font-weight:300;
  letter-spacing:-.02em;
  margin:6px 0 4px;
  line-height:1;
}
.w-meta .jp{ font-size:13px; color:var(--ink-2); }
.w-meta.small h4{ font-size:22px; }
.w-meta.small{ margin-top:12px; padding-top:12px; }

.works-cta{ text-align:center; }

/* NUMBERS (dark) */
.stats{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap:0;
  border-top:1px solid rgba(243,239,232,.2);
}
.stat{
  padding:48px 20px 8px;
  border-right:1px solid rgba(243,239,232,.15);
}
.stat:last-child{ border-right:0; }
.stat-num{
  font-size:clamp(68px, 8vw, 120px);
  line-height:0.9;
  letter-spacing:-.03em;
  color:var(--paper);
}
.stat-num .pct{ font-size:.55em; color:var(--clay); }
.stat-num .slash{
  font-size:.35em;
  color:rgba(243,239,232,.55);
  letter-spacing:.02em;
}
.stat-lbl{
  font-size:13px;
  margin-top:20px;
  color:rgba(243,239,232,.85);
}

/* PROCESS */
.process{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  border-top:1px solid var(--ink);
  list-style:none;
  padding:0; margin:0;
}
.process li{
  padding:40px 28px 48px;
  border-right:1px solid rgba(0,0,0,.08);
  position:relative;
}
.process li:last-child{ border-right:0; }
.p-num{
  font-size:11px;
  letter-spacing:.22em;
  color:var(--clay);
  margin-bottom:32px;
}
.process h4{
  font-family:'Fraunces', serif;
  font-weight:400;
  font-size:40px;
  line-height:1;
  letter-spacing:-.02em;
  margin:0 0 6px;
}
.p-jp{
  font-size:13px;
  color:var(--ink-2);
  margin-bottom:24px;
}
.p-txt{
  font-size:14px;
  line-height:1.9;
  color:var(--ink-2);
  max-width:32em;
}

/* NEWS */
.news{ border-top:1px solid var(--ink); }
.news li{
  display:grid;
  grid-template-columns: 140px 110px 1fr 40px;
  gap:32px;
  align-items:center;
  padding:22px 8px;
  border-bottom:1px solid var(--line);
  cursor:pointer;
  transition:background .25s, padding-left .25s;
}
.news li:hover{ padding-left:24px; background:var(--paper-2); }
.news .date{ font-size:12px; }
.news .tag{
  font-size:10px;
  letter-spacing:.2em;
  padding:4px 10px;
  border:1px solid var(--ink);
  border-radius:100px;
  text-align:center;
  width:fit-content;
  text-transform:uppercase;
}
.news .title{ font-size:15px; }
.news .arrow-s{ text-align:right; color:var(--ink-3); }

/* CONTACT CTA */
.cta{
  display:grid;
  grid-template-columns: 1.1fr 1fr;
  gap:80px;
  align-items:start;
}
.cta-h{
  font-size:clamp(64px, 7.5vw, 110px);
  line-height:0.95;
  margin:22px 0 32px;
  letter-spacing:-.02em;
  font-weight:300;
}
.cta-h .ital{ font-style:italic; color:#ffe9c9; }
.cta-jp{ font-size:15px; line-height:2; max-width:460px; opacity:.95; }
.cta-right{
  display:flex; flex-direction:column;
  gap:28px;
  padding-top:12px;
}
.ch{
  border-top:1px solid rgba(255,240,220,.35);
  padding-top:20px;
  display:block;
}
.ch-big{ font-size:28px; line-height:1.2; letter-spacing:-.01em; margin-top:8px; font-weight:400; }
.ch-mid{ font-size:28px; line-height:1.2; margin-top:8px; font-weight:400; letter-spacing:-.01em; }
.ch-sub{ font-size:13px; opacity:.85; margin-top:8px; }
.ch-addr{ font-size:18px; line-height:1.8; margin-top:8px; }

/* STRENGTH 3points */
.str3{
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:0;
  border-top:1px solid var(--ink);
  border-left:1px solid var(--ink);
}
.str3 article{
  padding:40px 28px 44px;
  border-right:1px solid var(--ink);
  border-bottom:1px solid var(--ink);
  min-height:340px;
  display:flex; flex-direction:column;
}
.str3-no{ font-size:10px; letter-spacing:.24em; color:var(--ink-3); margin-bottom:28px; }
.str3 h3{ font-size:44px; line-height:.96; letter-spacing:-.02em; font-weight:300; }
.str3 .jp{ font-size:14px; color:var(--ink-2); margin:10px 0 18px; }
.str3 p{ font-family:var(--f-jp); font-size:13px; line-height:2; color:var(--ink-2); margin-top:auto; }

/* Company profile table */
.co-table{ border-top:1px solid var(--ink); max-width:960px; }
.co-table > div{
  display:grid;
  grid-template-columns:180px 1fr;
  gap:24px;
  padding:18px 4px;
  border-bottom:1px solid var(--line);
}
.co-table dt{
  font-size:13px; color:var(--ink-3);
  font-family:var(--f-jp);
  letter-spacing:.08em;
}
.co-table dd{
  font-family:var(--f-jp);
  font-size:15px; color:var(--ink);
}
.co-table a{ border-bottom:1px solid var(--line); }
.co-table a:hover{ color:var(--clay); border-color:currentColor; }
.co-more{ margin-top:32px; }
.co-more-solo{
  margin-top:48px; display:grid; grid-template-columns:1fr auto; align-items:end;
  gap:40px; padding-top:40px; border-top:1px solid var(--ink);
}
.co-lede{ font-size:15px; line-height:1.95; color:var(--ink-2); max-width:48ch; margin:0; }
@media (max-width:720px){
  .co-more-solo{ grid-template-columns:1fr; gap:24px; align-items:start; }
}

/* Contact form */
.cform{ max-width:900px; }
.cform-grid{
  display:grid; grid-template-columns:1fr 1fr;
  gap:28px 32px;
}
.fld{ display:flex; flex-direction:column; gap:10px; }
.fld.full{ grid-column:1 / -1; }
.fld .lbl{
  font-family:var(--f-jp);
  font-size:13px;
  display:inline-flex; align-items:center; gap:10px;
  color:var(--ink-2);
}
.fld .lbl em{ font-style:normal; }
.fld .lbl .mono{
  font-size:10px; letter-spacing:.18em; color:var(--ink-3);
}
.fld .lbl .req{
  font-size:10px; padding:2px 8px;
  background:var(--clay); color:var(--paper);
  border-radius:100px; letter-spacing:.12em;
}
.fld .lbl .opt{
  font-size:10px; padding:2px 8px;
  border:1px solid var(--line); color:var(--ink-3);
  border-radius:100px; letter-spacing:.12em;
}
.fld input, .fld select, .fld textarea{
  font-family:var(--f-jp);
  font-size:15px;
  padding:14px 16px;
  background:var(--paper-2);
  border:1px solid var(--line);
  border-radius:0;
  color:var(--ink);
  outline:none;
  transition:border-color .2s, background .2s;
  font-variant-numeric:tabular-nums;
}
.fld input:focus, .fld select:focus, .fld textarea:focus{
  border-color:var(--ink);
  background:var(--paper);
}
.fld textarea{ resize:vertical; min-height:140px; line-height:1.8; }
.fld select{ appearance:none; background-image:linear-gradient(45deg,transparent 50%,var(--ink) 50%),linear-gradient(-45deg,transparent 50%,var(--ink) 50%); background-position: calc(100% - 20px) 50%, calc(100% - 14px) 50%; background-size: 6px 6px; background-repeat:no-repeat; padding-right:44px; }
.cform-foot{
  margin-top:40px;
  display:flex; justify-content:space-between; align-items:center;
  gap:24px; flex-wrap:wrap;
  padding-top:24px; border-top:1px solid var(--line);
}
.cform-note{ font-size:13px; color:var(--ink-2); line-height:1.9; max-width:480px; }
.cform-note a{ border-bottom:1px solid var(--line); }
.submit{ padding:18px 32px; font-size:12px; }

/* consent row */
.fld.consent{
  flex-direction:row; align-items:flex-start; gap:12px;
  padding:18px 20px; border:1px solid var(--line); background:rgba(0,0,0,.015);
  border-radius:2px; cursor:pointer;
}
.fld.consent input[type=checkbox]{
  appearance:auto; width:18px; height:18px; margin:2px 0 0; accent-color:var(--clay); cursor:pointer; flex:0 0 auto;
}
.fld.consent span{
  font-family:var(--f-jp); font-size:14px; line-height:1.85; color:var(--ink-2);
}
.fld.consent a{ color:var(--clay); border-bottom:1px solid var(--clay); font-weight:500; }
.fld.consent .req{
  display:inline-block; margin-left:8px;
  font-size:10px; padding:2px 8px; font-style:normal;
  background:var(--clay); color:var(--paper); border-radius:100px; letter-spacing:.12em;
}

/* form status message */
.cform-status{
  margin-top:20px; padding:18px 22px;
  font-family:var(--f-jp); font-size:14px; line-height:1.85;
  border:1px solid var(--line); border-radius:2px;
}
.cform-status.loading{ color:var(--ink-2); background:rgba(0,0,0,.02); }
.cform-status.success{ color:var(--paper); background:var(--clay); border-color:var(--clay); }
.cform-status.error  { color:#a33; background:#fef2ef; border-color:#f0c5bb; }

/* Responsive */
@media (max-width: 1100px){
  .hero-stage{ inset:16px; }
  .hero-body{ left:24px; right:24px; bottom:140px; }
  .manifesto{ grid-template-columns:1fr; gap:32px; }
  .svc-grid{ grid-template-columns:1fr 1fr; }
  .str3{ grid-template-columns:1fr; }
  .str3 article{ min-height:auto; }
  .co-table > div{ grid-template-columns:140px 1fr; gap:16px; }
  .cform-grid{ grid-template-columns:1fr; gap:22px; }
  .work-feat{ grid-template-columns:1fr; }
  .stats{ grid-template-columns:1fr 1fr; }
  .stat{ border-bottom:1px solid rgba(243,239,232,.15); }
  .process{ grid-template-columns:1fr 1fr; }
  .process li{ border-bottom:1px solid rgba(0,0,0,.08); }
  .process li:nth-child(2n){ border-right:0; }
  .cta{ grid-template-columns:1fr; gap:48px; }
}
@media (max-width: 760px){
  .hero{ min-height:640px; }
  .hero-stage{ inset:8px; }
  .hero-title{ font-size:44px; line-height:1.1; }
  .hero-title .ln2{ padding-left:0.6em; }
  .hero-body{ bottom:100px; left:20px; right:20px; }
  .hero-bl{ position:static; margin-top:24px; flex-wrap:wrap; }
  .hero-br, .hero-tr{ display:none; }
  .marquee{ bottom:8px; }
  .svc-grid{ grid-template-columns:1fr; }
  .svc{ min-height:auto; }
  .svc h3{ font-size:36px; }
  .stats{ grid-template-columns:1fr; }
  .stat{ border-right:0; padding:32px 12px 8px; }
  .process{ grid-template-columns:1fr; }
  .process li{ border-right:0; border-bottom:1px solid rgba(0,0,0,.08); padding:32px 4px 36px; }
  .process h4{ font-size:32px; }
  .ch-big{ font-size:22px; }
  .ch-mid{ font-size:22px; }
  .news li{ grid-template-columns: 1fr auto; gap:8px 14px; padding:18px 4px; }
  .news .title{ grid-column:1/-1; }
  .news .arrow-s{ display:none; }
  .cta-h{ font-size:56px; }
}
