@charset "utf-8";
.pc{
    display: block;
}
.sp{
    display: none;
}
.noto{
    font-family: 'Noto Sans JP', sans-serif;
}
body {
    color: #2F2F2F;
    background-color: #FAF8F6;
    font-family: 'Shippori Mincho', serif;
    font-weight: 500;
}
main{
    margin-top:100px;
}
.page-top{
    position:fixed;
    bottom:70px;
    right:30px;
    display:flex;
    justify-content:center;
    align-items:center;
    text-align:center;
    width:60px;
    height:60px;
    border-radius:10px;
    z-index:99;
    cursor:pointer;
}
a.anchor{
    display: block;
    position: relative;
    top: -110px;
    visibility: hidden;
}
/*
a.link-group{
    position: fixed;
    top:120px;
    right:0;
    padding:15px 30px 15px 15px;
    line-height: 1.3em;
    z-index: 555;
}
*/
.contain{
    width:90vw;
    max-width:1800px;
    margin:auto;
}
.contain02{
    width:80vw;
    max-width: 1200px;
    margin:auto;
}
.contain03{
    width:70vw;
    max-width:1000px;
    margin:auto;
}
section{
    display:flex;
    flex-flow:column nowrap;
    justify-content:center;
    align-items:center;
    padding:5em 0 8em 0;
}
h2{
    display:inline-block;
    padding:10px 2em;
    font-size:2em;
    text-align: center;
    line-height: 0.8em;
    border-bottom:solid 1px;
}
h2 span{
    font-size:16px;
}
.ribon01{
    display: flex;
    justify-content: center;
    align-items: center;
    width:100%;
    height:45px;
    font-size:20px;
    font-weight: 500;
    text-align: center;
}
.both{
    width:100%;
    display: flex;
    justify-content: center;
    align-items: center;
}
.both::before, .both::after{
    content: "";
    flex-grow:1;
    height:1px;
}
.both::before{
    margin-right:15px;
}
.both::after{
    margin-left:15px;
}
.both.btdn-c::before, .both.btdn-c::after{
    background-color:#66BCC9;
}
.both.ishi-c::before, .both.ishi-c::after{
    background-color:#434B80;
}
.both.heart-c::before, .both.heart-c::after{
    background-color:#d3562c;
}
.btdn-c{
    color:#5BA9B4;
}
.btdn-b{
    color:#FAF8F6;
    background-color:#5BA9B4;
}
.ishi-c{
    color:#434B80;
}
.ishi-b{
    color:#FAF8F6;
    background-color:#434B80;
}
.heart-c{
    color:#d3562c;
}
.heart-b{
    color:#FAF8F6;
    background-color:#d3562c;
}
.yasu-c{
    color:#8588C2;
}
.yasu-b{
    color:#FAF8F6;
    background-color:#8588C2;
}
.service-list{
    width:100%;
    margin:auto;
}
.service-list ul{
    display: flex;
    flex-flow:row wrap;
    justify-content: space-between;
    color:#FAF8F6;
}
.service-list ul li{
    width:49%;
    height:100px;
    margin:15px 0 0;
}
.service-list ul li a{
    display:flex;
    justify-content: flex-end;
    align-items: flex-end;
    width:100%;
    height:100%;
    background-repeat:no-repeat;
    background-size: cover;
    background-position: center;
    background-blend-mode:soft-light;
}
.service-list ul li:nth-of-type(1) a {
    background-image: url(../img/nav-ishi01.jpg);
    background-position: 50% 45%;
}
.service-list ul li:nth-of-type(2) a{
    background-image: url(../img/nav-ishi02.jpg);
    background-position: 50% 25%;
}
.service-list ul li:nth-of-type(3) a{
    background-image: url(../img/nav-ishi03.jpg);
}
.service-list ul li:nth-of-type(4) a{
    background-image: url(../img/service-ishi04-1.jpg);
}
.service-list ul li:nth-of-type(5) a{
    background-image: url(../img/nav-ishi05.jpg);
}
.service-list ul li:nth-of-type(6) a{
    background-image: url(../img/nav-ishi06.jpg);
    background-position: 50% 55%;
}
.service-list ul li:nth-of-type(7) a{
    background-image: url(../img/nav-ishi07.jpg);
}
.service-list ul li:nth-of-type(8) a{
    background-image: url(../img/nav-ishi08.jpg);
    background-position: 50% 10%;
}
.service-list ul li a:hover{
    opacity: 0.8;
    transition: .3s;
}
.service-list ul li a span{
    display: block;
    margin:0 10px 15px;
    font-size:18px;
    text-align: right;
    text-shadow:1px 1px 0px #000, 2px 2px 0px #000, 3px 3px 2px #000;
}
.service-list.ishi ul li a{
    background-color:#434B80;
}
.service-list ul li a:hover{
    opacity: 0.9;
    background-color:#000;
    background-blend-mode:normal;
    transition: .5s;
}
.service-nav.ishi{
    border-bottom:solid 1px #434B80;
}
.service-nav ul{
    display: flex;
    flex-flow: row wrap;
    justify-content: space-between;
    align-items: center;
}
.service-nav ul li{
    width:24%;
    min-width:250px;
    height:50px;
    margin:0 0 10px;
    color: #FAF8F6;
}
.service-nav.ishi ul li{
    background-color:#434B80;
}
.service-nav ul li a{
    display: flex;
    justify-content: center;
    align-items: center;
    width:auto;
    height:100%;
    padding:0 1em;
    text-align: center;
}
.service-nav ul li:hover{
    opacity: 0.8;
    transition: .3s;
}
header{
    width:100%;
    background-color:#FAF8F6;
    position:fixed;
    top:0;
    left:0;
    z-index: 999;
    box-shadow: 0px 5px 5px rgb(55,51,52,0.5);
}
.header-top{
    display:flex;
    height:30px;
    padding:0 10px;
    font-size:90%;
}
.header-top .contain, .header-bottom .contain{
    display:flex;
    justify-content:space-between;
    align-items:center;
}
.header-top i{
    font-size:1.2em;
}
.header-top p:nth-of-type(2){
    font-family:'Noto Sans JP', sans-serif;
    font-weight:400;
    letter-spacing:1px;
}
.header-bottom{
    display:flex;
    justify-content:space-between;
    align-items:center;
    height:70px;
}
.header-bottom .contain{
    height:100%;
    margin-right:0;
}
.logo-M{
    width:220px;
    margin-right:5px;
}
.header-bottom h1 a{
    display: flex;
    align-items: center;
}
.slide-top img{
    width:100%;
    height:80vh;
    object-position:50% 35%;
}
header nav{
    display: flex;
    align-items: center;
    width:55%;
    height:100%;
    font-size:14px;
    white-space: nowrap;
}
header nav.ishi{
    width:60%;
}
header nav.group{
    width:40%;
    margin-right:5vw;
}
header nav.group a:hover{
    opacity: 0.8;
    transition: .3s;
}
header nav ul{
    display:flex;
    justify-content:space-between;
    align-items: center;
    width:100%;
    height:100%;
}
header nav ul li{
    height:100%;
}
header nav ul li a{
    display: flex;
    align-items: center;
    height:100%;
    line-height: 1.3em;
}
header nav.group ul li{
    display: flex;
    align-items:center;
}
header nav.group ul li a{
    height:60%;
    padding:0 25px;
}
header nav ul li:nth-last-child(1) a{
    padding:0 25px;
    text-align: right;
}
header nav ul li:nth-last-child(1):hover{
    opacity: 0.7;
    transition: .3s;
}
.link-btn{
    padding:5px 1em;
}
.link-btn02{
    border:solid 1px;
    padding:1em 2em;
}
.link-btn02:hover{
    opacity: 0.7;
    transition: .3s;
}
section.news ul{
    display:flex;
    flex-flow:column;
    justify-content:flex-start;
    align-items:flex-start;
    width:100%;
    margin:2em auto;
}
section.news ul li{
    margin:1em 0;
}
section.news ul li a{
    display:flex;
    align-items: center;
}
section.news div{
    display: flex;
    margin-bottom:10px;
}
section.news div span{
    display:block;
}
section.news div span:nth-of-type(1){
    width:115px;
    text-align:center;
}
section.news span:nth-of-type(1){
     text-align: center;
    width:115px;
} 
section.news span:nth-of-type(1), span.news-day{
    margin-right:0.5em;
}
span.news-day{
    background-color:#EAEAEA;
    padding:3px 8px;
}
span.news-title{
    overflow: hidden;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
}
section .box01{
    margin:1.6em 0;
}
section .box01 p, section.shop .box02 .cont02 p{
    font-size:18px;
    text-align:center;
    line-height:1.8em;
}
div.movie{
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin:auto auto 3em;
}
div.movie iframe{
    width:47%;
    min-width:420px;
    height:350px;
    margin:1em 0;
}
section.concept .box02{
    display:flex;
    flex-flow:row wrap;
    justify-content:space-between;
    align-items:center;
    width:100%;
}
section.concept .box02 li{
    width:30%;
    min-width:260px;
    margin:1em auto;
}
section.concept .box02 li a{
    display:block;
}
section.concept .box02 .cont01{
    position:absolute;
    top:55%;
    left:50%;
    transform:translateY(-50%) translateX(-50%);
    -webkit- transform: translateY(-50%) translateX(-50%);
    width:80%;
    margin:auto;
    color:#FAF8F6;
    font-size:20px;
    text-align:center;
}
section.concept .box02 .cont01 h3{
    margin:25px 0 0px;
    font-weight: normal;
}
section.concept .box02 .cont01 img{
    filter: drop-shadow(0px 0px 10px #fff);
}
/*仕様変更*/
section.concept .box02 .cont01 span{
    display:block;
    margin:50px 0;
}
/*ここまで*/
section.member .wrapper{
    display:flex;
    flex-flow:column;
    justify-content:center;
    align-items:center;
    background-image:url(../img/lightP02.png);
    background-size:contain;
    background-repeat:no-repeat;
    background-position:center;
}
section.member .eyecatch{
    width:100%;
    height:35vh;
    min-height:380px;
    border-radius: 10px;
    object-position: 50% 20%;
}
section.member ul{
    display:flex;
    flex-flow:row wrap;
    justify-content:space-between;
    align-items:flex-start;
    width:100%;
    margin:2em 0;
}
section.member ul li{
    display:flex;
    flex-flow:column;
    justify-content:center;
    align-items:flex-start;
    width:32%;
    margin:0 auto;
    line-height: 1.6em;
}
section.member ul h3{
    display:flex;
    flex-flow:row nowrap;
    align-items:center;
    margin-left:10%;
    color:#8588C2;
    font-size:22px;
}
section.member ul h3 img{
    width:55px;
    margin-right:10px;
}
section.member ul .cont01{
    width:85%;
    margin:1em 1em 0 auto;
    line-height: 2em;
    position:relative;
}
section.member ul .sub-title{
    display: flex;
    margin-top:10px;
    font-weight: bold;
    color:#8588C2;
    border-bottom:dotted 2px;
    letter-spacing: 1px;
}
section.member ul .circle{
    position:absolute;
    z-index:-1;
    display:inline-block;
    width:220px;
    height:220px;
    top:100px;
    left:60%;
    transform:translateY(-50%) translateX(-50%);
    -webkit- transform: translateY(-50%) translateX(-50%);
    margin:auto;
    border-radius:50%;
    background-color:#D8D9ED;
    opacity: 0.6;
}
section.greeting .box01{
    background-image:url(../img/flo02.png);
    background-size:contain;
    background-repeat:no-repeat;
    background-position:left bottom;
}
aside .company{
    width:800px;
    margin:auto;
}
section.company .box01{
    width:100%;
    margin:50px 0;
}
section.company h3{
    display:flex;
    align-items:center;
    font-size:20px;
}
section.company h3 img{
    width:200px;
    margin-right:15px;
}
section.company table{
    width:100%;
    margin-top:1.3em;
    font-family:'Noto Sans JP', sans-serif;
    text-align:left;
    line-height:1.6em;
    border-collapse:collapse;
}
section.company table th{
    width:40%;
    padding:1em 1.5em;
    font-weight:400;
    border:solid 2px #FAF8F6;
}
section.company table.btdn th{
    background-color:#EAF2F3;
}
section.company table.ishi th{
    background-color:#EEEEF3;
}
section.company table.heart th{
    background-color:#F7EFED;
}
section.company table td{
    width:60%;
    padding:1em 1.5em;
    font-weight: 400;
    border:solid 2px #EAEAEA;
}
footer{
    width:100%;
    display:flex;
    flex-flow:column;
    justify-content:center;
    align-items:center;
}
footer.btdn{
    background-color:#E9F3F4;
}
footer.ishi{
    background-color:#EEEEF3;
}
footer.heart{
    background-color:#FDEBE8;
}
footer .box01{
    display:flex;
    flex-flow:column;
    justify-content:center;
    align-items:center;
    width:80%;
    margin:2.3em auto;
    padding:50px 30px 35px 30px;
    background-color:#FAF8F6;
}
.box-tel{
    display:flex;
    justify-content:space-around;
    align-items:center;
    width:100%;
}
.box-tel a:hover{
    opacity: 0.8;
    transition: .3s;
}
footer .box01 ul{
    display:flex;
    flex-flow:row;
    justify-content:space-around;
    align-items:center;
    width:80%;
    margin:auto;
}
footer .box01 ul img{
    width:180px;
}
footer h2{
    margin:0 0 30px 0;
}
footer .both{
    margin:30px 0;
    font-size:20px;
}
.box-tel .part{
    display: flex;
    justify-content: center;
    align-items: center;
    width:30%;
    height:135px;
    padding:7px;
    border:solid 1px;
}
footer.btdn .box-tel .part{
    width:45%;
}
.cont-tel{
    display:flex;
    flex-flow:column;
    justify-content:center;
    align-items:center;
    width:100%;
    height:80%;
    padding:10px;
    text-align:center;
    font-family:'Noto Sans JP', sans-serif;
    border:solid 1px;
}
.cont-tel p:nth-of-type(1){
    width:100%;
    border-bottom:solid 2px;
    padding-bottom:10px;
    font-size:14px;
    line-height: 1.3em;
}
footer.group .cont-tel p:nth-of-type(1), footer.btdn .cont-tel p:nth-of-type(1){
    font-size:20px;
}
footer.group .cont-tel p:nth-of-type(2), footer.btdn .cont-tel p:nth-of-type(2){
    display: flex;
    align-items: center;
    margin-top:10px;
    font-size:26px;
    font-weight: bold;
    letter-spacing: 1px;
}
.cont-tel div{
    display:flex;
    align-items:center;
    margin-top:10px;
    font-size:22px;
    font-weight:700;
    letter-spacing:1px;
}
.cont-tel i{
    font-size:1.8em;
}
.cont-tel span{
    font-size:12px;
    font-weight:normal;
}
footer .box02, footer .box03{
    display:flex;
    align-items: center;
    font-family:'Noto Sans JP', sans-serif;
    font-size:14px;
    font-weight:800;
    margin:1em auto 2em auto;
}
footer .box02{
    justify-content:space-around;
    width:50%;
}
footer .box03{
    justify-content: space-around;
    width:70%;
    padding-top:30px;
}
footer .box02 a:hover, footer .box03 a:hover{
    text-decoration: underline;
}
footer.btdn .box03{
    border-top:solid 2px #66BCC9;
}
footer.ishi .box03{
    border-top:solid 2px #BEC2D9;
}
footer.ishi ul.box03 li a{
    display: flex;
    align-items: center;
}
footer .box03 img{
    width:120px;
}
footer small{
    display:flex;
    justify-content:center;
    align-items:center;
    width:100%;
    height:30px;
    font-size:14px;
}
/*information*/
article.information-list{
    width:70vw;
    max-width:1000px;
    margin:2em auto 0;
    border-bottom:dotted 2px;
}
article.information-list.btdn{
    border-bottom-color:#5BA9B4;
}
article.information-list.ishi{
    border-bottom-color:#575c85;
}
article.information-list.heart{
    border-bottom-color:#d3562c;
}
article.information-list ul li{
    margin:1em 0;
    border:solid 1px;
}
article.information-list.btdn ul li{
    background-color:#E9F3F4;
    border-color:#95c4cb;
}
article.information-list.ishi ul li{
    background-color:#EEEEF3;
    border-color:#aaaecb;
}
article.information-list.heart ul li{
    background-color:#FDEBE8;
    border-color:#d3a99b;
}
article.information-list ul li:hover{
    opacity: 0.7;
    transition: .3s;
}
article.information-list ul li a{
    display: flex;
    align-items: center;
    padding:1em;
}
article.information-list h3{
    font-size:22px;
    margin-left:1em;
    padding-left:1em;
    line-height: 1.3em;
    border-left:solid 1px;
    overflow: hidden;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
}
article.information-list.btdn h3{
    border-left-color:#95c4cb;
}
article.information-list.ishi h3{
    border-left-color:#aaaecb;
}
article.information-list.heart h3{
    border-left-color:#d3a99b;
}
article.information{
    width:70vw;
    max-width:1000px;
    margin:auto;
    padding-bottom:2em;
    border-bottom:dotted 2px;
}
article.information.btdn{
    border-color:#5BA9B4;
}
article.information.ishi{
    border-color:#434B80;
}
article.information.heart{
    border-color:#d3562c;
}
article.information .box01{
    margin:1em 0;
    padding-bottom:10px;
    line-height: 1.6em;
    border-bottom:solid 1px;
    background-image: url(../img/flo-p-line01.png);
    background-repeat: no-repeat;
    background-size:50%;
    background-position: center right;
}
article.information .box01 h3{
    font-size:26px;
}
article.information p{
    line-height: 1.6em;
    padding:1em;
}
article.information .box02 img{
    width:auto;
    max-width:100%;
}
.box-pn{
    display: flex;
    justify-content: space-between;
    align-items: center;
    width:70vw;
    max-width:1000px;
    margin:1em auto;
}
.box-pn .cont01{
    display: flex;
    max-width:40%;
    line-height: 1.1em;
}
.box-pn .cont01 span{
    overflow: hidden;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
}
aside.information{
    padding:3em 0;
}
aside.information a{
    display: flex;
    justify-content: center;
    align-items: center;
    margin:auto;
}
/*sub*/
.sub-catch{
    position: relative;
    height:35vh;
    background-repeat: no-repeat;
    background-size: cover;
    background-blend-mode:overlay;/*追加*/
}
.sub-catch.btdn{
    background-color:#78a8b7;
    background-blend-mode: multiply;
}
.sub-catch.ishi{
    background-color:#575c85;
    background-blend-mode:overlay;
}
.sub-catch.heart{
    background-color:#2c6291c4;
    background-blend-mode: exclusion;
}
.sub-catch.service{
    background-image: url(../img/service-ishi.jpg);
    background-position: 50% 15%;
}
.sub-catch.company{
    background-image: url(../img/company01.jpg);
    background-position: 50% 40%;
}
.sub-catch.faq{
    background-image: url(../img/company06_g.jpg);
}
.sub-catch.find{
    background-image: url(../img/find.jpg);
    background-position: 50% 20%;
}
.sub-catch.contact{
    background-image: url(../img/company04_g.jpg);
}
.sub-catch.info.group{
    background-image: url(../img/slide01_g.jpg);
    background-position: 50% 65%;
}
.sub-catch.info.btdn{
    background-image: url(../img/slide01_g.jpg);
}
.sub-catch.info.ishi{
    background-image: url(../img/company04_g.jpg);
}
.sub-catch.info.heart{
    background-image: url(../img/point01.jpg);
    background-position: 50% 60%;
}
.sub-catch h2 {
    color: #FAF8F6;
    font-weight: 500;
    border: none;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translateY(-50%) translateX(-50%);
    -webkit- transform: translateY(-50%) translateX(-50%);
    margin: auto;
    white-space: nowrap;
    text-shadow:0 0 5px #000;
}
/*石のコバヤシ*/
iframe.information-nav{
    width:100%;
    height:580px;
}
section.concept .box03{
    display: flex;
    justify-content: space-between;
}
section.concept .box03 .cont01{
    width:30%;
    text-align: center;
}
section.concept .box03 .cont01 a{
    position: relative;
}
section.concept .box03 .cont01 a i{
    position: absolute;
    z-index: 3;
    bottom:10px;
    right:10px;
    font-size:20px;
    color:#fff;
    opacity: 0.7;
}
section.concept .box03 .cont01 h3{
    margin:10px 0;
}
section.contact.ishi ul{
    display:flex;
    flex-flow:row wrap;
    justify-content:space-around;
    width:80%;
}
section.contact.ishi ul a{
    display:block;
    width:200px;
    padding:15px 20px;
    text-align:center;
}
section.contact iframe{
    width:50%;
    min-width:320px;
    height:380px;
}
section.contact .logo{
    width:30%;
    min-width:230px;
    height:auto;
    margin:3em 0;
}
footer.ishi .box-tell01{
    font-size:16px;
}
/*service*/
section.service.ishi{
    padding:80px 0 0;
}
section.service .box01{
    display: flex;
    justify-content: center;
    align-items: center;
    width:100%;
}
section.service.reverse .box01{
    flex-flow: row-reverse;
}
section.service .box01 .fade{
    width:50%;
    position: relative;
}
section.service .box01 .fade i{
    position: absolute;
    z-index: 3;
    bottom:40px;
    right:10px;
    font-size:24px;
    color:#fff;
    opacity: 0.9;
}
section.service .box01 .fade .slick-prev{
    left:-10px;
}
section.service .box01 .fade .slick-prev:before, section.service .box01 .fade .slick-next:before{
    color:#fff;
    font-size:35px;
    text-shadow:2px 2px 2px #000, -1px -1px 2px #000, 1px 1px 2px #000;
}
section.service .box01 .fade .slick-next{
    right:-10px;
}
section.service .box01 .fade .slick-dots{
    bottom:0px;
}
.slick-dotted.slick-slider{
    margin-bottom:0;
}
.slick-dots li.slick-active button:before{
    opacity: 1;
    color:#434B80;
}
.slick-dots{
    height:30px;
    background-color:rgb(255,255,255,0.4);
}
section.service .box01 .fade img{
    width:auto;
    height:460px;
}
section.service .box01 .fade.service-b li{
    position: relative;
}
section.service .box01 .fade.service-b li .pop01{
    position: absolute;
    top:15px;
    right:15px;
    display: flex;
    justify-content: center;
    align-items: center;
    padding:20px 1em;
    font-size:26px;
    border:solid 2px;
    box-shadow:5px 5px 5px rgb(0,0,0,0.5);
}
section.service .box01 .fade.service-b.reverse li .pop01{
    right:inherit;
    left:15px;
}
section.service.ishi .cont01{
    display: flex;
    flex-flow: column;
    justify-content: space-between;
    width:50%;
    height:460px;
}
section.service.ishi h2{
    display: flex;
    align-items: center;
    line-height:normal;
    padding:10px;
}
section.service.ishi h2 img{
    width:50px;
    height:auto;
    margin-right:10px;
}
section.service.ishi .cont02{
    height:75%;
    padding:1em 10%;
    position: relative;
}
section.service.ishi .cont02 a{
    display: flex;
    align-items: center;
    margin:1em 0 0;
    padding:5px 15px;
    font-size:18px;
    font-weight: 600;
    background:#FAF8F6;
    border-radius: 5px;
}
section.service.ishi .cont02 a i{
    font-size:32px;
}
section.service.ishi p{
    display: flex;
    flex-flow: column;
    justify-content: center;
    align-items: center;
    height:100%;
    text-align: left;
    font-size:95%;
}
section.service.ishi .cont02 span {
    background-repeat: no-repeat;
    position: absolute;
}
section.service.ishi .cont02 span:nth-of-type(1){
    width:42px;
    height:42px;
    background-image: url(../img/bg-ichimatsu01.png);
    top:0;
    left:0;
}
section.service.ishi .cont02 span:nth-of-type(2){
    width:22px;
    height:22px;
    background-image: url(../img/bg-ichimatsu02.png);
    top:0;
    right:0;
}
section.service.ishi .cont02 span:nth-of-type(3){
    width:22px;
    height:22px;
    background-image: url(../img/bg-ichimatsu03.png);
    bottom:0;
    left:0;
}
section.service.ishi .cont02 span:nth-of-type(4){
    width:105px;
    height:82px;
    background-image: url(../img/bg-ichimatsu04.png);
    bottom:0;
    right:0;
}
/*company*/
section.company-sub p{
    text-align: left;
}
section.company-sub.obsession .box02 img{
    width:120px;
}
section.company-sub .wrapper{
    display: flex;
    flex-flow: row wrap;
    justify-content: space-between;
    align-items: center;
    margin:2em auto;
}
section.company-sub .wrapper.reverse{
    flex-flow: row-reverse;
}
section.company-sub .wrapper .cont01{
    display: flex;
    flex-flow: column;
    justify-content: center;
    align-items: flex-start;
    width:46%;
    height:354px;
    font-size:18px;
    line-height: 1.6em;
    background-image: url(../img/flo01_r.png);
    background-repeat: no-repeat;
    background-size: 80%;
    background-position: top right;
}
section.company-sub .wrapper .cont01 ul{
    padding: 0 2em 0 4em;
}
section.company-sub .wrapper .cont01 ul li{
    margin:10px 0;
    text-indent: -2em;
}
section.company-sub .wrapper .cont03{
    width:50%;
}
section.company-sub .wrapper .cont03 h3{
    margin:5px 0;
    text-align: right;
}
section.company-sub p{
    padding:0 2em;
    line-height: 1.6em;
}
section.company-sub.obsession p{
    text-align: center;
}
section.company-sub .box02{
    display: flex;
    flex-flow: row wrap;
    justify-content: space-around;
    align-items: flex-start;
    width:85%;
    margin:auto;
}
section.company-sub .box02 .cont02{
    display: flex;
    flex-flow: column;
    justify-content:center;
    align-items: center;
    margin:1em 0;
    font-family: 'Noto Sans JP', sans-serif;
}
section.company-sub .box02 .cont02 p{
    font-size:14px;
}
section.company-sub.history img{
    height:480px;
}
section.company-sub.history ul{
    margin:2em 0;
    background-image: url(../img/col-flo.png);
    background-repeat: repeat-y;
    background-position: top right;
    background-size:80%;
}
section.company-sub.history ul li{
    margin:1em 0;
}
/*find*/
section.find .box01, section.shop .box02{
    width:100%;
    background-color:#F4F4F5;
}
section.shop .box02{
    background-color:transparent;
}
section.find .box01 h2{
    border-bottom:none;
    border-left:solid 10px;
    padding:10px;
    text-align: left;
}
section.find .box02, section.shop .box02{
    display: flex;
    align-items: center;
    height:460px;
    margin:0 1em;
    border-bottom:dotted 2px #434B80;
}
section.shop .box02{
    border-bottom:dotted 2px #5BA9B4;
}
section.shop .box02:nth-last-child(1){
    border-bottom:none;
}
section.find h3, section.shop h3{
    display: flex;
    align-items: center;
    font-size:20px;
    white-space: nowrap;
}
section.find h3 span, section.shop h3 span{
    display:flex;
    justify-content: center;
    align-items: center;
    font-size:26px;
    color:#FAF8F6;
    background-color:#434B80;
    margin-right:5px;
    padding:3px;
}
section.shop h3 span{
    background-color:#5BA9B4;
}
section.find h3::after, section.shop h3::after{
    content: "";
    width:100%;
    height:1px;
    background-color:#434B80;
}
section.shop h3::after{
    background-color:#5BA9B4;
}
section.find .box02 .cont01, section.find .box02 iframe, section.shop .box02 .cont01, section.shop .box02 iframe{
    width:50%;
}
section.find .box02 iframe, section.shop .box02 iframe{
    height:80%;
}
section.find .box02 .cont01 ul{
    display: flex;
    justify-content: space-between;
    margin:2em 0 1em;
}
section.find .box02 .cont01 ul li{
    width:30%;
}
section.find .box02 .cont01 ul img{
    height:80px;
}
section.find .box02 .cont02, section.shop .box02 .cont02{
    padding:1em;
}
section.find .box02 .cont02 p, section.shop .box02 .cont02 p{
    text-align: left;
}
section.find .box02 .cont03, section.shop .box02 .cont03{
    display: flex;
    justify-content: space-between;
}
section.find .box02 .cont03 a{
    display: flex;
    justify-content: center;
    align-items: center;
    width:47%;
    height:50px;
}
section.find .btn{
    display: flex;
    justify-content: center;
    align-items: center;
    width:90%;
    height:50px;
    margin:3em auto;
}
aside.find-c {
    margin-bottom:5em;
    padding:2em 0;
    background-color: #EEEEF3;
}
aside.find-c .box03 {
    display: flex;
    flex-flow: column;
    justify-content: center;
    align-items: center;
    width:70%;
    margin:3em auto;
    padding:1em;
    background-color: #FAF8F6;
}
aside.find-c .box03 p{
    width:80%;
    margin:auto;
    line-height: 1.6em;
}
aside.find-c .box03 h2{
    display: flex;
    justify-content: center;
    width:8em;
    margin:1em auto;
}
aside.find-c .box-tel{
    flex-flow: column;
    margin-bottom:2em;
}
aside.find-c .box-tel .part{
    width:80%;
    margin:10px 0;
}
aside.find-c .cont-tel p:nth-of-type(1){
    font-size:18px;
}
aside.find-c .cont-tel p:nth-of-type(2){
    width:auto;
}
/*faq*/
section.faq{
    width:70vw;
    max-width:800px;
    margin:auto;
}
section.faq .box01{
    width:100%;
}
section.faq .box01 .cont01{
    margin:1em 0;
}
.acd-check{
    display: none;
}
.acd-label{
    border:solid 1px #434B80;
    background: #fff;
    color: #434B80;
    display: flex;
    align-items: center;
    margin-bottom: 1px;
    position: relative;
    font-size:20px;
    height:50px;
}
.acd-label:after{
    color:#FAF8F6;
    background: #434B80;
    box-sizing: border-box;
    border-radius: 10px;
    content: 'ひらく';
    display: block;
    padding: 10px 20px;
    position: absolute;
    right: 10px;
    font-size:18px;
}
.acd-label span{
    margin:0 5px 0 0.5em;
    font-size:32px;
}
.acd-content{
    border: 1px solid #EEEEF3;
    background-color: #EEEEF3;
    height: 0;
    opacity: 0;
    padding: 0 10px;
    transition: .5s;
    visibility: hidden;
    display: flex;
    flex-flow: row wrap;
    justify-content: space-between;
    align-items: center;
}
.acd-content p{
    display: flex;
    align-items: flex-start;
    word-break: break-all;
    line-height: 1.6em;
}
section.faq .box01 p{
    text-align: left;
}
.acd-a{
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;
    padding:5px;
    color:#fff;
    background-color:#434B80;
    font-size:18px;
    margin:0 10px 0 0;
}
.acd-check:checked + .acd-label:after{
    content: 'とじる';
    font-size:18px;
}
.acd-check:checked + .acd-label + .acd-content{
    height:auto;
    opacity: 1;
    padding: 1em;
    visibility: visible;
}
/*contact*/
section.contact .box02{
    display: flex;
    flex-flow: column;
    justify-content: center;
    align-items: center;
}
section.contact .box-tel{
    flex-flow: column;
    margin-bottom:3em;
}
section.contact .box-tel .part{
    width:80%;
    margin:1em 0;
}
section.contact .box-tel .cont-tel{
    flex-flow: row;
    justify-content: space-between;
}
section.contact .box-tel .cont-tel p:nth-of-type(1){
    display: flex;
    justify-content: center;
    align-items: center;
    width:55%;
    height:90%;
    padding-bottom:0;
    font-size:22px;
    border-bottom:none;
    border-right:solid 2px;
}
section.contact .box-tel .cont-tel p:nth-of-type(2){
    display: flex;
    align-items: center;
    width:40%;
    margin-top:0;
    font-size:26px;
    font-weight: 600;
}
/*form*/
form.ishi{
    width:60%;
    margin:50px auto;
    padding:2em;
    background-color:#EEEEF3;
    border-radius: 25px;
}
form .cont01{
    margin:1em 0;
}
form label{
    display: flex;
    align-items: center;
    font-size:22px;
    font-weight: 600;
}
form.ishi label span{
    display: flex;
    justify-content: center;
    align-items: center;
    width:30px;
    height:30px;
    margin-right:5px;
    font-size:6px;
    border-radius: 50%;
    color:#FAF8F6;
    background-color:#434B80;
}
form input, form textarea{
    width:30em;
    margin:10px 0;
    padding:5px;
    border:solid 1px #999;
}
form input{
    height:30px;
}
form textarea{
    height:15em;
}
form input.btn{
    width:15em;
    height:50px;
    font-size:20px;
}
/*コバヤシ仏壇*/
ul.link-box{
    display: flex;
    flex-flow: row wrap;
    justify-content: space-between;
    align-items: center;
    width:100%;
}
ul.link-box li{
    width:32%;
    min-width:200px;
    margin:8px 0;
    position: relative;
}
ul.link-box li a{
    display: block;
    padding:5px;
    box-shadow:2px 2px 6px #999, -2px -2px 6px #999;
}
ul.link-box.products-t li a{
    background-color:#E8D56C;
}
ul.link-box.service-t li a{
    background-color:#66BCC9;
}
ul.link-box li a:hover{
    opacity: 0.7;
    transition: .3s;
    -webkit-transition: .3s;
    -moz-transition: .3s;
    -ms-transition: .3s;
    -o-transition: .3s;
}
ul.link-box li h3{
    position: absolute;
    padding:10px 15px;
    font-size:22px;
    background-color:rgb(255,255,255,0.8);
}
ul.link-box.products-t li h3{
    color:#978838;
    top:5px;
    left:5px;
    text-shadow:1px 1px 0 #fff, 1px 0px 0 #fff, 0px 1px 0 #fff, -1px -1px 0 #fff, -1px 0 0 #fff, 0px -1px 0 #fff,
    2px 2px 5px #000, 2px 2px 3px #000;
}
ul.link-box.service-t li h3{
    color:#3194A3;
    bottom:5px;
    right:5px;
    text-shadow:1px 1px 0 #fff, 1px 0px 0 #fff, 0px 1px 0 #fff, -1px -1px 0 #fff, -1px 0 0 #fff, 0px -1px 0 #fff,
    2px 2px 5px #3194A3, 2px 2px 3px #3194A3;
}
ul.link-box li img{
    height:220px;
}
section.products-t .link-btn, section.service-t .link-btn{
    width:100%;
    margin:1em 0;
    padding:15px 0;
    font-size:20px;
    text-align: center;
}
section.products-t .link-btn:hover, section.service-t .link-btn:hover{
    opacity: 0.7;
    transition: .3s;
    -webkit-transition: .3s;
    -moz-transition: .3s;
    -ms-transition: .3s;
    -o-transition: .3s;
}
section.repair .wrapper{
    display:flex;
    flex-flow:row;
    justify-content:center;
    align-items:center;
    margin:30px 0;
}
section.repair .box01{
    width:70%;
    margin:auto;
    padding:50px 3em;
}
section.repair .box01 p{
    text-align:left;
}
section.repair .box02{
    display:flex;
    flex-flow:column;
    justify-content:center;
    align-items:center;
}
section.repair .box02 img{
    margin-bottom:1.6em;
}
section.shop .box03{
    display: flex;
    align-items: center;
    background-color:#E9F3F4;
    margin:10px 0 0;
    padding:10px;
    border-radius: 10px;
}
section.shop .box03 .cont03{
    display: flex;
    flex-flow: column;
    justify-content: center;
    align-items: center;
    width:20%;
    text-align: center;
}
section.shop .box03 img{
    width:70px;
    margin-bottom:5px;
    border-radius: 5px;
}
section.shop .box03 h4{
    color:#5BA9B4;
    text-shadow:1px 1px #fff, 1px 0 #fff, 0 1px #fff, -1px -1px #fff, -1px 0 #fff, 0 -1px #fff,
        2px 2px #fff, 2px 0 #fff, 0 2px #fff, -2px -2px #fff, -2px 0 #fff, 0 -2px #fff;
    font-weight: 700;
}
section.shop .box02 .box03 p{
    width:100%;
    margin:0 0 0 10px;
    padding:10px;
    font-size:16px;
    line-height: 1.6em;
    background-color:#FAF8F6;
}
/*取扱商品*/
.sub-catch.products{
    background-image: url(../img/butsudan.jpg);
    background-position: center;
}
.service-nav.btdn{
    border-bottom:solid 1px #66BCC9;
}
.service-nav.btdn li{
    background-color:#5BA9B4;
    width:32%;
    font-size:20px;
}
section.products.btdn{
    height:464px;
    margin:3.8em auto;
    padding:10px;
    background-color:#66BCC9;
    background-image: url(../img/cloud-wa.png);
    background-repeat: no-repeat;
    background-size:auto;
    background-position: center;
    border-radius: 15px;
    -webkit-border-radius: 15px;
    -moz-border-radius: 15px;
    -ms-border-radius: 15px;
    -o-border-radius: 15px;
}
section.products.btdn .box01{
    display: flex;
    flex-flow: row nowrap;
    justify-content: space-between;
    align-items: flex-end;
    width:auto;
    height:100%;
    min-height:390px;
    margin:10px;
    padding:25px;
    border:solid 2px #fff;
    border-radius: 15px;
    -webkit-border-radius: 15px;
    -moz-border-radius: 15px;
    -ms-border-radius: 15px;
    -o-border-radius: 15px;
}
section.products.btdn.reverse .box01{
    flex-flow: row-reverse;
}
section.products.btdn .box01 .cont01{
    display: flex;
    flex-flow: column;
    justify-content: flex-end;
    width:50%;
    min-width:430px;
    height:100%;
}
section.products.btdn .box01 h3{
    display: flex;
    align-items: center;
    margin:15px;
    color:#fff;
    font-size:30px;
    font-weight: normal;
}
section.products.btdn .box01 h3 img, section.service.btdn h3 img{
    width:50px;
    margin-right:8px;
}
section.products.btdn .box01 .cont02{
    display: flex;
    align-items: center;
    min-height:50%;
    margin:0 20px 0 0;
    padding:3em 2em;
    background-color:#FAF8F6;
    border-radius: 15px;
    -webkit-border-radius: 15px;
    -moz-border-radius: 15px;
    -ms-border-radius: 15px;
    -o-border-radius: 15px;
}
section.products.btdn.reverse .box01 .cont02{
    margin:0 0 0 20px;
}
section.products.btdn .box01 .cont02 p{
    font-size:1rem;
    text-align: left;
}
section.products.btdn .box01 .cont03{
    display: flex;
    align-items: flex-end;
    width:50%;
    height:100%;
}
section.products.btdn .box01 .cont03 img{
    height:90%;
    min-height:370px;
    box-shadow:2px 2px 15px rgb(0,0,0,0.5);
}
aside.products ul{
    display: flex;
    flex-flow: row nowrap;
    justify-content: space-around;
    align-items: center;
    margin:3em auto;
}
aside.products ul li{
    width:40%;
    font-size:20px;
    text-align: center;
    border:solid 1px;
}
aside.products ul li a{
    display: block;
    padding:15px 0;
}
aside.products ul li a:hover{
    color:#fff;
    background-color:#5BA9B4;
    transition: .3s;
    -webkit-transition: .3s;
    -moz-transition: .3s;
    -ms-transition: .3s;
    -o-transition: .3s;
}
/*サービス一覧*/
.sub-catch.service.btdn{
    background-image: url(../img/flower.jpg);
    background-position: 50% 30%;
}
section.service.btdn{
    padding:5em 0;
}
section.service.btdn h3{
    display: flex;
    align-items: center;
    margin-right:auto;
    font-size:30px;
    text-align: left;
}
section.service.btdn .box01{
    flex-flow: column;
    align-items: stretch;
}
section.service.btdn .box01 img{
    height:43vh;
    min-height:320px;
    margin:0 0 2em;
    border-radius: 10px;
}
section.service.btdn .box01 p{
    margin:0 1em;
    text-align: left;
}
section.service.btdn .link-btn{
    padding:15px 30px;
    border-radius: 15px;
    box-shadow: 5px 5px 5px rgb(200, 200, 200, 1),
        5px 5px 5px transparent inset;
    transition:.3s;
    -webkit-border-radius: 15px;
    -moz-border-radius: 15px;
    -ms-border-radius: 15px;
    -o-border-radius: 15px;
}
section.service.btdn .link-btn:hover{
    box-shadow: 5px 5px 5px transparent,
        5px 5px 5px rgb(200, 200, 200, 1) inset;
}
/*豆知識、FAQ*/
.sub-catch.faq.btdn{
    background-image: url(../img/rakugan.jpg);
    background-position: 50% 55%;
}
.service-nav.btdn.faq li{
    width:30%;
    padding:0;
    font-size:20px;
}
section.point h3.btdn-c i, section.faq h3.btdn-c i{
    background-color:#66BCC9;
}
section.point h4{
    display: flex;
    align-items: center;
    margin:2em 0 10px;
    font-size: 22px;
}
section.point .box01 h4:nth-of-type(1){
    margin:0 0 10px;
}
section.point h4 img{
    width:35px;
    height:auto;
    margin-right:5px;
}
section.point h5{
    display: flex;
    align-items: center;
    margin:0 1em 5px;
    padding:5px;
    font-size: 20px;
    border-radius: 5px;
}
section.point .btdn h5{
    background-color:#e3edef;
}
section.point h5 img{
    width:20px;
    height:auto;
}
section.point p{
    margin:0 40px 1em;
}
section.faq{
    width:80vw;
    max-width:1200px;
}
section.faq.btdn .acd-label{
    color:#66BCC9;
    border: solid 1px #66BCC9;
}
section.faq.btdn .acd-label::after{
    background-color:#66BCC9;
}
section.faq.btdn .acd-label h4{
    color:#2F2F2F;
}
section.faq.btdn .acd-a{
    background-color:#66BCC9;
}
section.faq.btdn .acd-content{
    background-color:#E9F3F4;
}
/*お問い合わせ*/
.sub-catch.btdn.contact{
    background-image: url(../img/point01.jpg);
    background-position: 50% 55%;
}
section.contact.btdn .wrapper{
    display: flex;
    flex-flow: column;
    justify-content: space-between;
    align-items: flex-start;
    width:100%;
}
section.contact.btdn .box02{
    display: flex;
    flex-flow: row;
    justify-content: space-around;
    align-items: center;
    padding:2em 0;
}
section.contact.btdn .box02:nth-of-type(1){
    border-bottom:dashed 1px #5BA9B4;
}
section.contact.btdn .box02 a{
    width:35%;
}
section.contact.btdn .box02 .cont-tel{
    width:auto;
}
section.contact.btdn .box02 .cont02{
    color:#5BA9B4;
    font-size:20px;
}
section.contact.btdn .box02 iframe{
    box-shadow:2px 2px 5px #999;
}
aside.contact.btdn .box01{
    display: flex;
    justify-content: space-around;
    align-items: center;
    margin-bottom:3em;
}
aside.contact.btdn .box01 .link-btn{
    width:40%;
    padding:15px 0;
    text-align: center;
    border:solid 1px;
}
aside.contact.btdn .box01 .link-btn:hover{
    color:#fff;
    background-color:#5BA9B4;
    transition: .3s;
    -webkit-transition: .3s;
    -moz-transition: .3s;
    -ms-transition: .3s;
    -o-transition: .3s;
}
/*ハート・ホール*/
section.concept.heart .box02 li a {
    display: flex;
    justify-content: center;
    align-items: center;
    height: 100px;
    padding: 0px 30px;
    border-radius: 10px;
    box-shadow: 5px 5px 5px rgb(200, 200, 200, 1),
        5px 5px 5px transparent inset;
    transition:.3s;
}
section.concept.heart .box02 li a:hover {
    box-shadow: 5px 5px 5px transparent,
        5px 5px 5px rgb(200, 200, 200, 1) inset;
}
section.plan ul{
    display: flex;
    flex-flow: row wrap;
    justify-content: space-around;
    align-items: flex-start;
}
section.plan ul li{
    width:30%;
    height:200px;
    margin:3.6em 0;
    line-height: 1.3em;
    z-index: 1;
}
section.plan ul li.plan04{
    width:70%;
    margin:8em 0;
}
section.plan ul h3{
    display: flex;
    align-items: center;
}
section.plan ul li.plan04 h3{
    justify-content: center;
}
section.plan ul h3 img{
    width:40px;
    height:40px;
    margin-right:1em;
}
section.plan ul h3 span{
    font-size:26px;
}
section.plan ul li .cont01{
    margin:1em;
    padding:1em;
    position: relative;
}
section.plan ul li .cont01 p{
    line-height: 1.8em;
}
section.plan ul .square{
    position: absolute;
    z-index: -1;
    display: inline-block;
    width:220px;
    height:220px;
    top:60%;
    left:60%;
    transform:translateY(-60%) translateX(-60%);
    -webkit- transform: translateY(-60%) translateX(-60%);
    margin:auto;
    background-color:#FDEBE8;
}
section.plan ul li.plan04 .square{
    width:100%;
    height:180px;
    left:50%;
    transform:translateY(-60%) translateX(-50%);
    -webkit- transform: translateY(-60%) translateX(-50%);
}
section.cuisine .slide-fade{
    width:100%;
    margin:2em 0;
}
section.cuisine .slide-fade .slick-dots, section.map .slide-fade .slick-dots{
    background-color:transparent;
    bottom:-30px;
}
section .slide-fade.heart .slick-dots li button:before{
    color:#f7caca;
    font-size:43px;
}
section .slide-fade.heart .slick-dots li.slick-active button:before{
    color:#d3562c;
}
section.cuisine .box01{
    display: flex;
    justify-content: center;
    align-items: center;
    width:80%;
    max-width:800px;
    background-image: url(../img/lightO02.png);
    background-repeat: no-repeat;
    background-position: center center;
    background-size:cover;
}
section.cuisine .box01 p{
    margin:auto;
}
section.flower img{
    height: 50vh;
    max-height: 430px;
    margin: 1.6em 0;
    box-shadow: 5px 10px 10px rgb(55,51,52,0.5);
    border-radius: 10px;
}
section.company.heart iframe{
    width:100%;
    height:35vh;
    min-height:260px;
}
footer.heart .part, section.heart.contact .part{
    padding:8px;
}
footer.heart .part:hover, section.heart.contact .part:hover{
    opacity: 0.8;
    transition: .3s;
}
footer.heart .cont-tel, section.heart.contact .cont-tel{
    width:auto;
    flex-flow: row;
    border:solid 1px #fff;
}
footer.heart .cont-tel div, section.heart.contact .cont-tel div{
    margin-top:0;
    padding:0 0 0 1em;
}
footer.heart .cont-tel p:nth-of-type(1), section.heart.contact .cont-tel p:nth-of-type(1){
    width:auto;
    padding:0 1em;
    font-size:18px;
    font-family:"s-SemiBold";
    border-bottom:none;
    border-right:solid 1px;
}
footer.heart .box03{
    border-top:solid 2px #d9ae9a;
}
/*プラン*/
.sub-catch.plan{
    background-image: url(../img/plan-t02.jpg);
    background-position: 50% 30%;
}
.sub-catch.heart h2{
    text-shadow:1px 1px 3px #000;
}
.nav-wrap{
    display: flex;
    flex-flow: row wrap;
    justify-content: space-around;
    align-items: flex-start;
    width:80vw;
    max-width:1000px;
    margin:auto auto 3em;
    border-bottom:solid 1px #d3562c;
}
.service-nav.heart{
    width:45%;
    min-width:320px;
    max-width:500px;
    margin:2em auto;
    padding:20px 0 10px;
    background-color:#FDEBE8;
    border-radius: 15px;
    -webkit-border-radius: 15px;
    -moz-border-radius: 15px;
    -ms-border-radius: 15px;
    -o-border-radius: 15px;
}
.service-nav.heart img{
    width:auto;
    max-width:300px;
    height:50px;
    margin:auto;
    object-fit: contain;
}
.service-nav.heart ul{
    flex-flow: column wrap;
    margin:1em auto;
}
.service-nav.heart ul li{
    width:60%;
    height:38px;
    background-color:#d3562c;
}
.plan-wrap{
    margin:auto auto 5em;
    padding:2em;
    border-radius: 15px;
    background-color:#FDEBE8;
    -webkit-border-radius: 15px;
    -moz-border-radius: 15px;
    -ms-border-radius: 15px;
    -o-border-radius: 15px;
    position: relative;
}
.plan-wrap::before, .plan-wrap::after{
    content:"";
    width:100px;
    height: 100px;
    background-image: url(../img/flo-w-pop.png);
    background-repeat: no-repeat;
    background-position: center;
    background-size:contain;
    position: absolute;
    top:15px;
}
.plan-wrap::before{
    left:15px;
}
.plan-wrap::after{
    right:15px;
    transform: scaleX(-1);
}
.plan-wrap h2{
    display: flex;
    justify-content: center;
    align-items: center;
    border-bottom:none;
}
.plan-wrap h2 img{
    width:50%;
}
section.plan{
    width:90%;
    margin:2em auto 3em;
    padding:4em 2em;
    border-radius: 15px;
    -webkit-border-radius: 15px;
    -moz-border-radius: 15px;
    -ms-border-radius: 15px;
    -o-border-radius: 15px;
    background-color:#FAF8F6;
}
section.concept.plan{
    width:80vw;
    padding:5em 0 3em;
}
section.plan h3{
    display: flex;
    justify-content: flex-start;
    align-items: center;
    width:100%;
    font-size:32px;
}
section.plan h3 .icon{
    width:38px;
    height:38px;
    margin-right:10px;
}
section.plan .catch{
    height:35vh;
    max-height:360px;
    margin:1.6em 0;
    box-shadow:5px 10px 10px rgb(55,51,52,0.5);
    border-radius: 10px;
}
section.plan .cont02{
    padding:0 1em;
    line-height: 1.6em;
}
section.plan .link-btn{
    text-align: right;
    color:#d3562c;
    margin:2em 2em 0 auto;
    padding:10px 15px;
    border:solid 1px #d3562c;
}
section.plan .link-btn:hover{
    color:#fff;
    background-color:#d3562c;
    transition: .3s;
    -webkit-transition: .3s;
    -moz-transition: .3s;
    -ms-transition: .3s;
    -o-transition: .3s;
}
/*都留・和*/
.sub-catch.tsuru{
    background-image: url(../img/tsuru02.jpg);
    background-position: 50% 60%;
}
.sub-catch.nagomi{
    background-image: url(../img/nagomi01.jpg);
    background-position: 50% 60%;
}
.sub-catch.tsuru.img h2, .sub-catch.nagomi.img h2{
    padding:3%;
    background-color:rgb(255,255,255,0.7);
    border-radius: 10px;
    -webkit-border-radius: 10px;
    -moz-border-radius: 10px;
    -ms-border-radius: 10px;
    -o-border-radius: 10px;
}
section.map h3{
    font-size:26px;
}
section.map img.map{
    margin:2em 0 100px;
}
section.map .slide-fade{
    width:100%;
}
section.map .slide-fade img{
    height:70vh;
    min-height:320px;
    max-height:630px;
}
section.map .slide-fade img.bath{
    object-position: 50% 70%;
}
section.map .box02{
    width:100%;
    margin:2em auto 3em;
    font-size:20px;
    border-radius:15px;
    -webkit-border-radius:15px;
    -moz-border-radius:15px;
    -ms-border-radius:15px;
    -o-border-radius:15px;
}
section.map .box02 h4{
    text-align: center;
    margin:1em 0;
}
section.map .box02 .cont01{
    margin:1em 2em;
    line-height: 1.3em;
    background-color:#FAF8F6;
}
section.map .box02 .cont01 p, section.map .box02 .cont01 ul{
    padding:1em;
    font-size:16px;
    text-align: left;
}
section.map .box02 .cont01 ul:nth-of-type(1) li{
    display: flex;
    align-items: center;
    margin:2em 0;
    padding-bottom:5px;
    border-bottom:dotted #ED6030;
}
section.map .box02 .cont01 ul li img{
    display: inline-block;
    width:30px;
    margin-right:10px;
}
section.map .box02 .cont01 ul:nth-of-type(2){
    display: flex;
    flex-flow: row wrap;
    justify-content: space-around;
}
section.map .box02 .cont01 ul:nth-of-type(2) li{
    width:33%;
    margin:0 0 50px;
    text-align: center;
}
section.map .box02 .cont01 ul:nth-of-type(2) li i{
    display: block;
    text-align: center;
    margin-bottom:10px;
    color:#ED6030;
    font-size:50px;
}
section.map .link-btn{
    width:100%;
    padding:20px 0;
    text-align:center;
    font-size:20px;
}
section.map .link-btn:hover{
    opacity: 0.7;
    transition: .3s;
    -webkit-transition: .3s;
    -moz-transition: .3s;
    -ms-transition: .3s;
    -o-transition: .3s;
}
/*豆知識・FAQ*/
.sub-catch.faq.heart{
    background-image: url(../img/hall-faq.jpg);
    background-position: 50% 30%;
}
.service-nav.heart.faq{
    width:80vw;
    max-width:1200px;
    margin:auto auto 3em;
    background-color:transparent;
    border-bottom:solid 1px #d3562c;
    border-radius: inherit;
    -webkit-border-radius: inherit;
    -moz-border-radius: inherit;
    -ms-border-radius: inherit;
    -o-border-radius: inherit;
}
.service-nav.faq ul{
    display: flex;
    flex-flow: row wrap;
}
.service-nav.faq ul li{
    width:45%;
    padding:10px 0;
    font-size:18px;
}
section.point, section.faq{
    align-items: flex-start;
}
section.point h3, section.faq h3{
    display: flex;
    align-items: center;
    text-align: left;
    font-size:22px;
    font-weight: 800;
}
section.point h3 i, section.faq h3 i{
    display: flex;
    justify-content: center;
    align-items: center;
    width:43px;
    height:43px;
    margin-right:10px;
    font-size:32px;
    color:#FAF8F6;
}
section.point h3.heart-c i, section.faq h3.heart-c i{
    background-color:#d3562c;
}
section.point img.catch{
    height:35vh;
    min-height:320px;
    max-height:500px;
    margin:1em 0 1em;
    border-radius: 10px;
    box-shadow:5px 5px 5px rgb(0,0,0,0.5);
}
section.point .box01{
    padding:0 1em;
}
section.point .box01 p{
    text-align: left;
    margin-bottom:1em;
}
section.point .heart h5{
    background-color:#faeae4;
}
section.faq.heart{
    width:80vw;
    max-width:1200px;
}
section.faq.heart .acd-label{
    color:#d3562c;
    border: solid 1px #d3562c;
}
section.faq.heart .acd-label::after{
    background-color:#d3562c;
}
section.faq.heart .acd-label h4{
    color:#2F2F2F;
}
section.faq.heart .acd-a{
    background-color:#d3562c;
}
section.faq.heart .acd-content{
    background-color:#FDEBE8;
}
/*お問い合わせ*/
.sub-catch.heart.contact{
    background-image: url(../img/birdseye-hall02.jpg);
    background-position: 50% 50%;
}
section.contact.heart{
    padding:5em 0;
}
aside.contact.heart .box01{
    display: flex;
    justify-content: space-around;
    align-items: center;
    margin-bottom:3em;
}
aside.contact.heart .box01 .link-btn{
    width:40%;
    padding:15px 0;
    text-align: center;
    border:solid 1px;
}
aside.contact.heart .box01 .link-btn:hover{
    color:#fff;
    background-color:#d3562c;
    transition: .3s;
    -webkit-transition: .3s;
    -moz-transition: .3s;
    -ms-transition: .3s;
    -o-transition: .3s;
}
section.contact.heart iframe{
    width:100%;
    margin:2em 0 0;
}
/*animation*/
/*line*/
.lineText{
    position:relative;
}
.lineText span.mask{
    position:relative;
    display:block;
    line-height:0;
}
.lineText span.mask::before,
.lineText span.mask::after{
    position:absolute;
    top:5%;
    right:5%;
    bottom:5%;
    left:5%;
    z-index:3;
    content:"";
    opacity:0;
    transition:.5s ease-in-out;
}
.lineText span.mask::before{
    border-top:1px solid #fff;
    border-bottom:1px solid #fff;
    transform:scale(0,1);
}
.lineText span.mask::after{
    border-right:1px solid #fff;
    border-left:1px solid #fff;
    transform:scale(1,0);
}
.lineText:hover span.mask::before,
.lineText:hover span.mask::after{
    opacity:1;
    transform:scale(1);
}
.lineText span.cap{
    opacity:0;
    transition:.5s ease-in-out;
    position:absolute;
    z-index:3;
    top:50%;
    left:50%;
    transform:translate(-50%, -50%);
    color:#fff;
    line-height:1.5;
}
.lineText:hover span.cap{
    opacity:1;
}
/*fadeInTrigger*/
.fadeInTrigger {
    opacity: 0;
}
.fadeIn {
    animation-name: fadeInAnime;
    animation-duration:1.4s;
    animation-fill-mode:forwards;
    opacity: 0;
}
@keyframes fadeInAnime {
    from {
        opacity: 0;
    }
    to {
        opacity: 1;
    }
}
.delay01 {
    animation-delay: 0.2s;
}
.delay02 {
    animation-delay: 0.4s;
}
.delay03 {
    animation-delay: 0.6s;
}
.delay04 {
    animation-delay: 0.8s;
}
.delay05 {
    animation-delay: 1s;
}
