@import url(http://fonts.googleapis.com/earlyaccess/notosansjapanese.css);

/* ベース--------------------------------- */
html{
    scroll-behavior: smooth;
}
html, body {
    height: 100%;
}
body{
    position: relative;
    font-family: 'Noto Sans Japanese', sans-serif;
    color:#4F4F4F;
    font-size: 16px;
    transition: .3s;
}

.wrap{
    position: relative;
    width: 100%;
    height: auto;
    line-height: 140%;
}
#main{
    position: relative;
    height: 710px;
    background: url(/common/img/mv.png) center no-repeat;
    background-size: cover;
}

/* header--------------------------------- */
header{
    width: 100%;
    height: 120px;
    position: relative;
    z-index: 3;
    display: flex;
    align-items: center;
    justify-content: space-between;
    transition: .3s;
    background-color: rgba(255, 255, 255, 0);
}
header>div{
    display: flex;
    align-items: center;
    transition: .3s;
}
header h1 a{
    display: flex;
    font-size: 30px;
    line-height: 45px;
    color: #FFFFFF;
    margin: 0 0 0 30px;
    white-space: nowrap;
    font-weight: bold;
    transition: .3s;
}
header h1 img{
    display: inline-block;
    transition: .3s;
    width: 100%;
    height: auto;
}
header h1 .black_logo{
    display: none;
}
.is-animation .black_logo{
    display: block;
}
.is-animation .white_logo{
    display: none;
}

header nav ul li{
    display: inline-block;
    margin-right: 20px;
}
header nav ul li a{
    text-decoration: none;
    color: #FFF;
    font-size: 14px;
    transition: .3s;
}
header nav ul li a:hover{
    color: #F2994A;
}
.is-animation {
    position: fixed;
    background-color: rgba(255, 255, 255, 0.9);
    transition: all .4s ease 0s, background .6s ease .2s;
    height: 80px;
  }
.is-animation .tel,.is-animation .web{
    overflow:hidden;
    height: 80px;
}
.is-animation .tel img{
    position: relative;
    top:-1px;
}
.is-animation .web img{
    position: relative;
    margin-top:-20px;
}
.is-animation ul li a{
    color:#4F4F4F;
    font-weight: bold;
}
.is-animation h1 a{
    color:#4F4F4F;
}
.is-animation  h1 a{
    margin: 0 0 0 10px;
}
header nav ul .sp_menu{
    display: none;
}
/* MV--------------------------------- */
#main h2{
    display: block;
    position: absolute;
    top: 50%;
    left:60px;
    font-family: YuMincho,'Yu Mincho',serif;
    font-style: normal;
    font-weight: normal;
    font-size: 36px;
    line-height: 50px;
    color: #FFFFFF;
}
#main .caution{
    width: 410px;
    position: absolute;
    right: 0;
    bottom: 0;
    background:rgba(255,255,255,0.6);
    display: flex;
    justify-content: space-between;
    padding: 15px;
}
#main .caution img{
    margin-right: 12px;
}
/* コンテンツベース--------------------------------- */
.content{
    width: 100%;
    padding:100px 100px;
    display: block;
}
.flex_box{
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}
.content p{
    line-height: 30px;
    margin-bottom: 20px;
}
.content img{
    width: 100%;
    height: auto;
}
.t_right{
    margin-top: 20px;
    text-align: right;
}
a[href^="tel:"] {
	cursor: default; }
/* about--------------------------------- */
#about .content img{
    width: calc(100% + 100px);
    margin-right: -100px;
    height: auto;
}
.sec_right, .sec_left{
    width: 48%;
}
.content h1{
    font-size: 34px;
    line-height: 50px;
    color: #F2994A;
    padding-bottom: 30px;
    font-weight: bold;
}

/* flow--------------------------------- */
#flow{
    background: #EFEAE1;
}
#flow .content{
    display: block;
}
#flow .flex_box dl>div{
    margin-bottom:60px;
}
#flow .flex_box dl{
    flex-basis:calc((100% - 25px) / 2);
    max-width:calc((100% - 25px) / 2);
}
#flow .flex_box dl:nth-child(even){
    margin-right:0;
}

#flow .flex_box dt{
    font-weight: bold;
    font-size: 21px;
    margin: 20px 0 10px 0;
}

/* price--------------------------------- */
#price .flex_box dl{
    flex-basis:calc((100% - 50px) / 3);
    max-width:calc((100% - 50px) / 3);
}
#price .flex_box dt{
    font-weight: bold;
    font-size: 21px;
    margin: 20px 0 10px 0;
}
#price .flex_box p{
    color:#F3994F;
    font-weight: bold;
    text-align: right;
    margin-top: 20px;
}
#price .del {
    text-decoration-line: line-through;
    text-decoration-style:double;
    text-decoration-color: rgba(253, 76, 6, 0.664);
  }
#price  .limit{
    font-size: 14px;
    background: #F3994F;
    color: #FFFFFF;
    padding: 2px 6px;
    margin: 0 4px 0 10px;
    font-weight: normal;
  }
.sp_only{
    display: none;
}

/* NEWS--------------------------------- */
#news{
    background: url(/common/img/logo2.svg) right no-repeat;
    background-size: 15%;
    background-color: #efeae167;
}
#news .timeline_t{
    height: 480px;
    overflow: hidden;
    font-size: 14px;
}
#news .f_button_box{
    position: relative;
}
#news .f_button_box .f_button{
    position: absolute;
    right: 0;
    top:0;
}
#news .f_button{
    width:200px ;
    background: #199CED;
    text-align: center;
    padding:6px 0px;
    color: #FFF;
    font-weight: bold;
    transition: .3s;
}
#news .f_button:hover{
    background: #0e5988;
}


/* QA--------------------------------- */
#q_a ul{
    width: 100%;
}
#q_a ul li{
    width: 100%;
    background: #EFEAE1;
    padding: 30px;
    margin-bottom: 20px;
}
#q_a ul li p{
    margin-bottom:0px;
}
#q_a ul li .question{
    font-size: 18px;
    font-weight: bold;
    line-height: 30px;
    border-bottom: 1px solid #d1d1d1;
    padding-bottom: 6px;
}
#q_a ul li .anser{
    margin-top:10px;
}

/* foot--------------------------------- */
footer{
    background: #3D1D00;
}
footer .content h1{
    color: #FFFFFF;
}
footer .content{
    color: #FFFFFF;
}
footer .content dl{
    display: flex;
    flex-wrap: wrap;
    margin-top: 30px;
    align-items: center;
    justify-content: center;
}
footer .content dl dt{
    width: 20%;
    text-align: justify;
    text-align-last: justify;
    padding-right: 30px;
}
footer .content dl dd{
    width: 80%;
    border-left:1px solid #747474;
    padding-left: 30px;
    font-weight: 200;
    display: inline-block;
}
footer .content dl dd div{
    display: inline;
    display: flex;
    align-items: center;
}
footer .content dl dd div:nth-child(1){
    margin-bottom: 20px;
}
footer .content .foot_tel dd .title{
    width: 60px;
}
footer .content .foot_tel  .number{
    font-weight: bold;
    font-size: 34px;
    line-height: 49px;
}
footer .content .foot_tel dd img{
    width: 30px;
    height: auto;
    vertical-align: middle;
    margin-right: 12px;
}
footer .content .foot_tel dd .r_btn a{
    width: 260px;
    text-align: center;
    display: inline-block;
    background: #FFFFFF;
    color: #4F4F4F;
    font-size: 20px;
    padding: 12px 0;
    font-weight: bold;
    transition: .3s;
}
footer .content .foot_tel dd .r_btn a:hover{
    background: #FFFFFF;
    opacity: 0.8;
}
footer .copy{
    background: #FFFFFF;
    text-align: center;
    font-size: 9px;
    padding: 10px 0;
}
footer .content .sec_right a{
    display: inline-block;
    margin-top: 10px;
    text-decoration: underline;
    color: #F2994A;
}
footer  .f_button{
    margin-top:10px;
    width:100% ;
    background: #199CED;
    text-align: center;
    padding:6px 0px;
    color: #FFF;
    font-weight: bold;
    transition: .3s;
    margin-bottom:0px;
    margin-top: 30px;
}
footer .f_button:hover{
    background: #0e5988;
}
footer .caut{
    display: block;
    margin-top: 20px;
    font-size: 14px;
    color: #d8d8d8;
}