@charset "UTF-8";

#content-wrapper{
  display: flex;
  gap: 65px;
}
#content-heading{
  width: 245px;
  background: url(../images/heading_image.jpg) top center / 100% auto no-repeat;
}

#content-heading h1{
  text-align:center;
  font-size: 1em;
  font-weight: 300;
  margin-top: 125px;
}

#content-article{
  flex:1;
  margin-bottom: 80px;
  
}

@media only screen and (max-width: 860px) {
  #content-article{
    margin-bottom: 60px;
  }
}
@media only screen and (max-width: 1080px) {
#content .wrapper{
  padding:0;
}
#content-wrapper{
  display: flex;
  flex-direction: column;
  gap: 50px 65px;
}
#content-heading{
  width: 100%;
  height: 100%;
  aspect-ratio: 375 / 200;
  background: url(../images/page_visual-sp.jpg) top center / 100% auto no-repeat;
  position: relative;
}

#content-heading h1{
  text-align:center;
  font-size: 1.05em;
  font-weight: 300;
  margin-top: 0;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%,-50%);
}

#content-article{
  flex:1;
  margin-bottom: 80px;
  padding: 0 17.5px;
}
}

#works h2{
  font-size: 1.44em;
  font-weight: 300;
  margin-top: 65px;
  border-bottom: 1px solid #333;
}
#works h2 + p{
  font-size: 1em;
  line-height: 1.94;
  font-weight: 300;
  margin-top: 15px;
  margin-bottom: 30px;
}
#works .works-index{
  display: flex;
  flex-direction: column;
}
#works .works-index .works{
  display: flex;
  gap: 50px;
}
#works .works-index .works .image{
  width: 290px;
  padding: 16px 0;
}
#works .works-index .works .text{
  flex: 1;
  padding:16px 20px;
  border-bottom: 1px solid #333;
}
#works .works-index .works .text h3{
  font-size: 1.44em;
  line-height: 1.42;
  font-weight: 400;
  text-indent: -20px;
}
#works .works-index .works .text h3:before{
  content:"》";

}
#works .works-index .works .text p{
  font-size: 1.16em;
  line-height: 1.76;
  font-weight: 300;
}

@media only screen and (max-width: 1080px) {
  
#works h2{
  font-size: 1.44em;
  font-weight: 300;
  margin-top: 0;
  border-bottom: 1px solid #333;
}
}

@media only screen and (max-width: 750px) {
#works .works-index .works{
  display: flex;
  flex-direction: column;
  gap: 16px;
}
#works .works-index .works .image{
  width: 290px;
  margin: auto;
  padding: 16px 0 0;
}
#works .works-index .works .text{
  flex: 1;
  padding:0 20px 16px;
  border-bottom: 1px solid #333;
}
#works .works-index .works .text h3{
  font-size: 1.44em;
  line-height: 1.42;
  font-weight: 400;
  text-indent: -20px;
}
#works .works-index .works .text h3:before{
  content:"》";

}
#works .works-index .works .text p{
  font-size: 1.16em;
  line-height: 1.76;
  font-weight: 300;
}
}


#about h2{
  font-size: 1.55em;
  line-height: 2.14;
  font-weight: 300;
  margin-top: 35px;
  padding-left: 15px;
  border-left: 4.5px solid #333;
  margin-bottom: 45px;
}
#about #director{
  display: flex;
  gap: 25px;
  align-items: end;
  margin-bottom: 45px;
}
#about #director .image{
  width: 345px;
}
#about #director .text{
  flex: 1;
}
#about h3{
  font-size: 1.06em;
  line-height: 1.78;
  font-weight: 300;
  margin-top: 45px;
  margin-bottom: 25px;
}
#about p{
  font-size: 1em;
  line-height: 2.55;
  font-weight: 300;
}
#about table#information{
  margin-top: 150px;
  border-collapse: collapse;
  width: 100%;
}
#about table#information th{
  background: #eceded;
  text-align: center;
  vertical-align: middle;
  font-size: 0.95em;
  line-height: 1.78;
  border: 1px solid #1a1004;
  padding: 10px 45px;
  font-weight: 300;
}
#about table#information td{
  text-align: left;
  vertical-align: top;
  font-size: 0.95em;
  line-height: 1.78;
  border: 1px solid #1a1004;
  padding: 10px 20px;
  font-weight: 300;
}

@media only screen and (max-width: 1080px) {
#about h2{
  font-size: 1em;
  line-height: 1.8;
  font-weight: 300;
  margin-top: 0;
  padding-left: 15px;
  border-left: 4.5px solid #333;
  margin-bottom: 45px;
}
}

@media only screen and (max-width: 750px) {
#about #director{
  display: flex;
  flex-direction: column;
  gap: 20px;
  align-items: start;
  margin-bottom: 70px;
  max-width: 345px;
  margin: auto;
}
#about #director .image{
  width: 100%;
  margin: auto;
}
#about table#information{
  margin-top: 30px;
  border-collapse: collapse;
  width: 100%;
}
#about table#information th,
#about table#information td{
  display: block;
}
#about table#information th{
  text-align: left;
  vertical-align: top;
  font-size: 0.95em;
  line-height: 1.78;
  border: 1px solid #1a1004;
  padding: 10px 20px;
  font-weight: 300;
}
#about table#information td{
  border-top: none;
}
#about table#information tr+ tr th{
  border-top: none;
}
}