@charset "utf-8";


/* main
---------------------------------------------------------------------- */
#top_contents{
    background: url(../images/bg_top.png) center top no-repeat;
    background-size: cover;
    overflow: hidden;
    position: relative;
}

#top_contents:before{
    background: url(../images/bg_footer.png) center top no-repeat;
    background-size: 100% 32px;
    content: " ";
    display: block;
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    width: 100%;
    height: 32px;
}

#main{
    background: url(../images/bg_main.png) left top no-repeat;
    background-size: 100%;
    max-width: 936px;
    width: 100%;
    min-height: 717px;
    margin: 30px auto;
    padding: 30px 50px 30px 120px;
    text-align: center;
}


/* header
---------------------------------------------------------------------- */
#top_header .top_title{
    max-width: 723px;
    width: 100%;
    margin: auto;
    padding: 10px;
}

#top_header .top_title.sp{
    display: none;
}

#top_header .top_title img{
    width: 100%;
    height: auto;
}

#top_header h1{
    font-size: 0;
    padding: 0 10px;
}

#top_header h1 img{
    display: inline-block;
}

#top_logo{
    width: 83%;
    height: auto;
    padding: 10px 10px;
}

#top_caracter{
    width: 17%;
    height: auto;
}


/* search
---------------------------------------------------------------------- */
#search h2{
    padding: 10px 0;
    text-align: center;
}

.search_box_cont{
    font-size: 0;
}

.search_box{
    display: inline-block;
    width: 33.33%;
    padding: 10px;
    vertical-align: top;
}

.search_box_wrap{
    background: #ffee5c;
    -webkit-border-radius: 2px;
    border-radius: 2px;
    -webkit-box-shadow: 0px 4px 4px 0px rgba(57, 81, 51, 0.6);
    box-shadow: 0px 4px 4px 0px rgba(57, 81, 51, 0.6);
/*     height: 210px; */
    position: relative;
    width: 100%;
}

.search_box_wrap:before{
    content: " ";
    display: block;
    padding-top: 95%;
}

.search_box_inner{
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    margin: auto;
    padding: 20px;
}

.search_h img,
.search_title img{
    width: 100%;
    height: auto;
}

.search_title{
    padding: 15px 0;
}





























@media screen and (max-width: 767px){
/* main
---------------------------------------------------------------------- */
#main{
    background: none;
    min-height: auto;
    margin: 20px auto 30px;
    padding: 0 10px;
}

#main_inner{
    background: url(../images/bg_main_sp.png) center top repeat-y;
    background-size: 100%;
    position: relative;
    padding: 0 8% 40px 13%;
}

#main_before{
    position: relative;
    width: 100%;
    height: 100%;
    padding-top: 15%;
}

#main_before .inner{
    background: url(../images/bg_main_sp_before.png) center bottom no-repeat;
    background-size: 100%;
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    width: 100%;
    height: 100%;
}

#main_after{
    position: relative;
    width: 100%;
    height: 100%;
    padding-top: 24%;
}

#main_after .inner{
    background: url(../images/bg_main_sp_after.png) center top no-repeat;
    background-size: 100%;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    width: 100%;
    height: 100%;
}

/* header
---------------------------------------------------------------------- */
#top_header .top_title.pc{
    display: none;
}

#top_header .top_title.sp{
    position: absolute;
    top: -3%;
    left: 2%;
    right: 0;
    display: block;
    padding: 0;
}

#top_header .top_title.sp img{
    width: 80%;
}

#top_header h1{
    position: relative;
    padding: 20% 0 10px;
}

#top_header h1 img{
    display: block;
}

#top_logo{
    width: 100%;
    padding: 0;
}

#top_caracter{
    width: 45%;
    float: right;
    z-index: 1;
    padding: 10px 0 0 10px;
    position: relative;
}


/* search
---------------------------------------------------------------------- */
#search h2{
    text-align: left;
    padding: 30px 0;
}

#search h2 img{
    width: 55%;
    height: auto;
}

.search_box{
    display: block;
    width: 100%;
    padding: 10px 0;
}

.search_box_wrap:before{
    padding-top: 90%;
}

.search_box_inner{
    padding: 30px;
}


}