@charset "UTF-8";
/* CSS Document */

/***
* top.css
*/

@media only print, only screen and (min-width: 18.75em){

#header,
#main,
#footer{
  opacity: 0;
  visibility: hidden;
  transition-duration: 0.8s;
}

#header.active,
#main.active,
#footer.active{
  opacity: 1;
  visibility: visible;
  transition-duration: 0.8s;
}

#logo{
  opacity: 1;
  visibility: visible;
  display: block;
}

#btnBack{
  display: none;
}

#titleBg{
  width: 100%;
  position: fixed;
  top: 50%;
  left: 50%;
  margin-top: -10px;
  z-index: -1;
  font-family: "Canela Web", "Times New Roman", Times, "serif";
  font-size: 12vw;
  line-height: 1.071;
  letter-spacing: 0.08em;
  text-align: center;
  transform: translate(-50%, -50%) scale(1);
  filter: blur(0);
  opacity: 1;
  transition-duration: 0.8s;
}

#titleBg.active{
  transform: translate(-50%, -50%) scale(1.14);
  filter: blur(15px);
  opacity: 0;
}

section{
  height: 100vh;
  position: relative;
}

.sectionImg .land{
  width: 252px;
  position: absolute;
  top: 50%;
  left: 50%;
  margin-top: -10px;
  transform: translate(-50%, -50%);
}

.sectionImg .port{
  width: 168px;
  position: absolute;
  top: 50%;
  left: 50%;
  margin-top: -10px;
  transform: translate(-50%, -50%);
}

.topTtl{
  width: 100%;
  position: fixed;
  bottom: 60px;
  font-family: "Canela Web", "Times New Roman", Times, "serif";
  font-size: 20px;
  letter-spacing: 0.16em;
  text-align: center;
}

.sectionTtl{
  width: 100%;
  font-family: "Canela Web", "Times New Roman", Times, "serif";
  font-size: 10.667vw;
  letter-spacing: 0.16em;
  position: fixed;
  top: 50%;
  left: 50%;
  margin-top: -10px;
  transform: translate(-50%, -50%);
  text-align: center;
  z-index: -1;
}

#concept{
  height: auto;
}

#concept .sectionTtl{
  position: relative;
  margin: 10vw 0 100px 0;
  top: 0;
  left: 50%;
  transform: translate(-50%, -50%);
}

#conceptWrap{
  padding: 0 15px;
}

#conceptTxt{
  float: left;
  margin-top: -4px;
}

#conceptImg{
  width: 29.28vw;
  float: right;
}

#concept h4{
  margin-bottom: 40px;
  font-family: "Canela Web", "Times New Roman", Times, "serif";
  font-size: 28px;
  letter-spacing: 0.16em;
}

#concept p{
  font-size: 13px;
  line-height: 1.923;
}

#footer{
  display: block;
}

}

@media only print, only screen and (min-width: 1000px){

#header,
#main,
#footer{
  opacity: 0;
  visibility: hidden;
  transition-duration: 0.8s;
}

#header.active,
#main.active,
#footer.active{
  opacity: 1;
  visibility: visible;
  transition-duration: 0.8s;
}

#logo,
#subNav{
  display: block;
}

#btnBack,
#nav{
  display: none;
}

#titleBg{
  width: 100%;
  position: fixed;
  top: 50%;
  left: 50%;
  margin-top: -30px;
  z-index: -1;
  font-family: "Canela Web", "Times New Roman", Times, "serif";
  font-size: 10vw;
  line-height: 1.071;
  letter-spacing: 0.08em;
  text-align: center;
  transform: translate(-50%, -50%) scale(1);
  filter: blur(0);
  opacity: 1;
  transition-duration: 0.8s;
}

#titleBg.active{
  transform: translate(-50%, -50%) scale(1.14);
  filter: blur(15px);
  opacity: 0;
}

#titleBg .pc{
  display: inline-block !important;
}

section{
  height: 100vh;
  position: relative;
}

.sectionImg .land{
  width: 32.14vw;
  position: absolute;
  top: 50%;
  left: 50%;
  margin-top: -20px;
  transform: translate(-50%, -50%);
}

.sectionImg .port{
  width: 21.42vw;
  position: absolute;
  top: 50%;
  left: 50%;
  margin-top: -20px;
  transform: translate(-50%, -50%);
}

.sectionTtl{
  width: 100%;
  font-family: "Canela Web", "Times New Roman", Times, "serif";
  font-size: 9.643vw;
  letter-spacing: 0.16em;
  position: fixed;
  top: 50%;
  left: 50%;
  margin-top: -20px;
  transform: translate(-50%, -50%);
  text-align: center;
  opacity: 1;
  transition-duration: 0.5s;
  color: #DED9D6;
  z-index: -1;
}

#topNav{
  width: 100%;
  position: fixed;
  bottom: 100px;
  font-family: "Canela Web", "Times New Roman", Times, "serif";
  font-size: 19px;
  text-align: center;
  letter-spacing: 0.16em;
}

#topNav li{
  margin-right: 26px;
  display: inline-block;
}

#topNav li:last-child{
  margin-right: 0;
}

#topNav a{
  color: #DED9D6;
}

#topNav li.active a{
  color: #333333;
}

#concept{
  height: 8000px;
  padding-bottom: 114px;
}

#concept .sectionTtl{
  position: relative;
  margin: 10vw 0 100px 0;
  top: 0;
  left: 50%;
  transform: translate(-50%, -50%);
}

#conceptWrap{
  padding: 0 15px;
}

#conceptTxt{
  float: left;
  margin-top: -4px;
}

#conceptImg{
  width: 29.28vw;
  float: right;
}

#concept h4{
  margin-bottom: 40px;
  font-family: "Canela Web", "Times New Roman", Times, "serif";
  font-size: 28px;
  letter-spacing: 0.16em;
}

#concept p{
  font-size: 13px;
  line-height: 1.923;
}

#footer{
  display: block;
}

}