@charset "utf-8";
/* CSS Document */
.sp-none{
	display: block;
}
.pc-none{
	display: none;
}
#bgimg {
    z-index: -1;
    position: fixed;
    top: 0px;
    left: 0px;
    width: 100%;
    height: 100vh;
}
#bgimg img {
    width: 100%;
    height: 100vh;
    object-fit: cover;
}
#main_visual{
    position: relative;
    height: 100vh;
}
#main_visual h2   {
    width: 48%;
    position: absolute;
    left: 3%;
    bottom: 80px;
    z-index: 10;
}
#main_visual h2 img{
    width: 100%;
    height: auto;
}
#main_visual p{
    width: 60%;
    margin: 0 0 0 auto;
    position: absolute;
    right: 0;
    bottom: 0;
    z-index: 0;
}
#main_visual p img{
    width: 100%;
    height: auto;
}#top_bnr1 {
    width: 100%;
    height: 100vh;
    position: relative;
    z-index: 10;
    color: #FFFFFF;
}
#top_bnr1:after {
    position: absolute;
    visibility: visible;
    content: " ";
    z-index: -1;
    width: 100%;
    height: 100vh;
    background-image: -webkit-linear-gradient(0deg,rgba(0,0,0,0.00) 0%,rgba(0,0,0,1.00) 100%);
    background-image: -moz-linear-gradient(0deg,rgba(0,0,0,0.00) 0%,rgba(0,0,0,1.00) 100%);
    background-image: -o-linear-gradient(0deg,rgba(0,0,0,0.00) 0%,rgba(0,0,0,1.00) 100%);
    background-image: linear-gradient(90deg,rgba(0,0,0,0.00) 0%,rgba(0,0,0,1.00) 100%);
    top: 0;
    left: 0;
    mix-blend-mode: multiply;
}
#top_bnr1 .inner {
    position: absolute;
    width: 50%;
    right: 0px;
    top: 50%;
    transform: translateY(-50%);
    text-align: left;
}
#top_bnr1 h3 {
    padding-left: 8%;
    width: 64%;
    max-width: 430px;
    display: block;
    float: none;
    padding-bottom: 50px;
}
#top_bnr1 h3 img {
    width: 100%;
    height: auto;
}
#top_bnr1 .come {
    padding-left: 8%;
    font-size: 18px;
    line-height: 2.6em;
}
#top_bnr2 {
    background-color: #FFFFFF;
    width: 100%;
    overflow: hidden;
    background-image: url(../images/bg.png);
    background-repeat: repeat-x;
    background-position: center top;
}
#top_bnr2 .inner {
    width: 90%;
    margin: 0 auto;
    max-width: 1056px;
    padding: 212px 0 70px;
    text-align: left;
    position: relative;
}
#top_bnr2 .inner h3 {
    font-size: 20px;
    line-height: 2.6em;
    font-weight: bold;
    padding-bottom: 80px;
}
#top_bnr2 .inner .inbox {
    width: 41%;
    float: left;
    font-size: 34px;
    line-height: 1.6em;
    font-weight: bold;
    padding-bottom: 70px;
    position: relative;
    z-index: 10;
}
#top_bnr2 .inner .inbox h4{
    font-weight: bold;
}
#top_bnr2 .inner .come {
    width: 41%;
    float: right;
    font-size: 16px;
    line-height: 2em;
    padding-bottom: 70px;
    position: relative;
    z-index: 10;
}
#top_bnr2 .inner .bg_round{
    width: 840px;
    height: 840px;
    position: absolute;
    border: 1px solid #C4C4C4;
    border-radius: 420px;
    top: 40px;
    left: 50%;
    z-index: 0;
}
#top_bnr2 .inner .bg_round02{
    width: 540px;
    height: 540px;
    position: absolute;
    border: 1px solid #C4C4C4;
    border-radius: 420px;
    bottom: -490px;
    left: calc(50% - 840px);
    z-index: 0;
}

#top_bnr2 .inner02 {
    position: relative;
    text-align: left;
    padding-bottom: 150px;
}
#top_bnr2 .inner02 h3 {
    font-size: 20px;
    line-height: 2.6em;
    font-weight: bold;
    padding-bottom: 80px;
    position: relative;
    z-index: 10;
    width: 50%;
    margin-right: 0px;
    margin-left: auto;
    text-align: left;
}
#top_bnr2 .inner02 h3 img {
    width: 100%;
    height: auto;
    text-align: left;
    max-width: 388px;
}

#top_bnr2 .inner02wrap{
    width: 90%;
    max-width: 1056px;
    margin: 0 auto;
}
#top_bnr2 .inner02 .come {
    width: 50%;
    background-color: #FFFFFF;
    position: relative;
    text-align: left;
    z-index: 10;
    margin-left: auto;
    margin-right: 0;
    padding-bottom: 50px;
}
#top_bnr2 .inner02 .come .come02 {
    padding: 70px 10% 30px 10%;
}
#top_bnr2 .inner02 .photo {
    position: absolute;
    width: 80%;
    height: 68%;
    top: 44px;
    left: 0px;
    overflow: hidden;
    z-index: 5;
}
#top_bnr2 .inner02 .photo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
#top_bnr2 .inner02 .bg_round{
    width: 962px;
    height: 962px;
    position: absolute;
    border: 1px solid #C4C4C4;
    border-radius: 500px;
    bottom: -490px;
    left: calc(50% - 1253px);
    z-index: 0;
}

#top_bnr2 .inner03 {
    width: 100%;
    position: relative;
    margin-bottom: 200px;
}
#top_bnr2 .inner03 .inbox{
    position: absolute;
    left: 50%;
    top: 50%;
    width: 90%;
    max-width: 1056px;
    transform: translateX(-50%) translateY(-50%);
    z-index: 10;
}
#top_bnr2 .inner03 .photo{
    width: 45%;
    margin: 0 0 0 auto;
    position: relative;
    z-index: 5;
}
#top_bnr2 .inner03 .photo p:first-of-type{
    width: 72%;
    margin: 0 0 0 auto;
    position: relative;
    padding-bottom: 11%;
}
#top_bnr2 .inner03 .photo p:last-of-type{
    width: 38%;
    position: absolute;
    left: 0;
    bottom: 0;
}
#top_bnr2 .inner03 .photo p img {
    width: 100%;
    height: auto;
}
#top_bnr2 .inner03 h3 {
    font-size: 20px;
    width: 60%;
    line-height: 2.6em;
    font-weight: bold;
    padding-bottom: 70px;
    position: relative;
    z-index: 10;
    margin-right: auto;
    margin-left:0;
    text-align: left;
}
#top_bnr2 .inner03 h3 img {
    width: 100%;
    height: auto;
    text-align: left;
    max-width: 622px;
}
#top_bnr2 .inner03 .come{
    width:45%;
    text-align: left;
    margin-right: auto;
    margin-left:0;
    padding-bottom: 50px;
}
#top_bnr2 .inner03 .bg_round{
    width: 420px;
    height: 420px;
    position: absolute;
    border: 1px solid #C4C4C4;
    border-radius: 420px;
    top: -130px;
    left: calc(50% + 180px);
    z-index: 0;
}


#top_bnr2 .inner04 {
    width: 100%;
    position: relative;
    margin-bottom: 200px;
}
#top_bnr2 .inner04 h3 {
    font-size: 20px;
    width: 60%;
    line-height: 2.6em;
    font-weight: bold;
    padding-bottom: 70px;
    position: relative;
    z-index: 10;
    margin-right: auto;
    margin-left:0;
    text-align: left;
}
#top_bnr2 .inner04 h3 img {
    width: 100%;
    height: auto;
    text-align: left;
    max-width: 603px;
}
#top_bnr2 .inner04 .come{
    width:31%;
    text-align: left;
    margin-right: auto;
    margin-left:0;
    padding-bottom: 50px;
}
#top_bnr2 .inner04 .inbox{
    position: absolute;
    left: 50%;
    bottom: 0;
    width: 90%;
    max-width: 1056px;
    transform: translateX(-50%) ;
    z-index: 10;
}
#top_bnr2 .inner04 .photo{
    width: 60%;
    margin: 0 0 0 auto;
    position: relative;
    z-index: 5;
}
#top_bnr2 .inner04 .photo img {
    width: 100%;
    height: auto;
    right: -2%;
    position: relative;
}
#top_bnr2 .inner04 .bg_round{
    width: 960px;
    height: 960px;
    position: absolute;
    border: 1px solid #C4C4C4;
    border-radius: 500px;
    top: -150px;
    left: calc(50% - 756px);
    z-index: 0;
}

#top_bnr2 .inner05 {
    width: 90%;
    max-width: 1056px;
    margin: 0 auto;
    margin-bottom: 150px;
    position: relative;
}
#top_bnr2 .inner05 .contactbut{
    text-align: center;
    color: #FFF;
    font-weight: bold;
    background-image: url(../images/bg_contact.jpg);
    background-position: center center;
    background-size: cover;
    background-repeat: no-repeat;
    position: relative;
    z-index: 10;
}
#top_bnr2 .inner05 .contactbut h4{    
    font-size: 20px;
    line-height: 1.6em;
    font-weight: bold;
    font-family: "Lato", sans-serif;
}
#top_bnr2 .inner05 .contactbut a{
    display: block;
    background-color: #000;
    color: #fff;
    padding: 50px 25px;
    transition: 0.5s;
}
#top_bnr2 .inner05 .contactbut a:hover{
    text-decoration: none;
    background-color: rgba(0,0,0,0.40);
}
#top_bnr2 .inner05 .contactbut p{
    font-size: 46px;
    line-height: 1.2em;
}
#top_bnr2 .inner05 .bg_round{
    width: 550px;
    height: 550px;
    position: absolute;
    border: 1px solid #C4C4C4;
    border-radius: 420px;
    top: -40px;
    left: calc(50% + 220px);
    z-index: 0;
}

.slidewrap {
    padding-bottom: 190px;
}

.slidewrap img {
    width: 100%;
    height: auto;
}


.but   {
}
#top_bnr1 .but{
    margin-top: 50px;
}
#top_bnr2 .inner .but{
    clear: both;
    text-align: center;
    position: relative;
    z-index: 10;
}

#top_bnr2 .inner02 .but{
    margin: 0 10%;
    position: relative;
    z-index: 10;
}
#top_bnr2 .inner03 .but{
    margin: 0 auto0 0;
    text-align: left;
    position: relative;
    z-index: 10;
}
#top_bnr2 .inner04 .but{
    margin: 0 auto0 0;
    text-align: left;
    position: relative;
    z-index: 10;
}
.but a {
    display: inline-block;
    background-color: #0000FE;
    padding: 15px 90px 15px 26px;
    border-radius: 60px;
    color: #FFFFFF;
    position: relative;
    transition: 0.2s;
    line-height: 1.2em;
    text-align: left;
}
.but a:after{
    content: " ";
    visibility: visible;
    background-image: url(../images/arrow.png);
    width: 13px;
    height: 11px;
    position: absolute;
    background-repeat: no-repeat;
    background-size: cover;
    right: 26px;
    top: 50%;
    transform: translateY(-50%);
}
.but a:hover{
    text-decoration: none;
    background-color: #000;
}
