@font-face {
    font-family: 'AvenirSerif';
    src: url('https://lc.hitachi-rep.co.jp/creacasa/fonts/AveriaSerif-Bold.ttf') format('truetype');
    font-weight: 700;
}
@font-face {
    font-family: 'AvenirSerif';
    src: url('https://lc.hitachi-rep.co.jp/creacasa/fonts/AveriaSerif-Regular.ttf') format('truetype');
    font-weight: 400;
}
@font-face {
    font-family: 'AvenirSerif';
    src: url('https://lc.hitachi-rep.co.jp/creacasa/fonts/AveriaSerif-Light.ttf') format('truetype');
    font-weight: 300;
}
.en {
    font-family: 'AvenirSerif';
    letter-spacing: 0.1em;
    display: block;
    font-size: 2em;
    margin-bottom: 18px;
}
.topicpath {
    font-size: 1em;
}
.topicpath,
.topicpath ol li a {
    color: #000;
}
.topicpath li img {
    width: 20px;
    vertical-align: top;
    margin-right: 10px;
}
#main-visual {
    background-size: cover !important;
    padding: 160px 0;
}
#main-visual .text {
    position: relative;
    width: 370px;
    max-width: 95%;
    background-color: #1a1a1a;
    padding: 65px 30px 135px;
    margin: 0 auto;
    max-height: 300px;
}
#main-visual .text h2 {
    color: #fff;
    font-size: 1.22em;
    text-align: center;
    letter-spacing: 0.06em;
    margin-bottom: 0;
    line-height: 1.2;
    padding: .8em 0 .7em;
}
#main-visual .text img {
    width: 167px !important;
    position: absolute;
    right: -7px;
    bottom: -17px;
}
@media (max-width: 430px) {
    #main-visual .text {
        padding: 40px 30px 50px;
        max-height: 180px;
    }
    #main-visual .text h2 {
        font-size: 1.16em;
    }
    #main-visual .text img {
        width: 130px !important;
    }
}
h3,
h4 {
    font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
}
.footer-link {
    border: 2px solid #000;
    position: relative;
}
.footer-link a {
    padding: 20px;
    display: block;
    margin-bottom: 0;
    text-align: center;
    -webkit-transition: all .3s ease;
    transition: all .3s ease;
    color: #fff;
    font-family: 'AvenirSerif';
    letter-spacing: 0.1em;
    background: #000;
}
.footer-link a:hover {
    background-color: #fff;
    text-decoration: none;
    color: #000;
}
.mb20 {
    margin-bottom: 20px !important;
}

.faq #main-visual{
    background: url(../images/concept/concept-bg.jpg) no-repeat center;
}
.secFaq .listWrap {
    margin-top: 10vw;
    padding: 10px;
    box-shadow: 0px 2px 7px #000;
    background-color: rgba(255, 255, 255, .95);
}
.secFaq .listWrap dt {
    position: relative;
    border: none;
	float: none;
}
.fontSerif {
    font-family: 'Noto Serif Japanese';
    font-weight: 400;
}
.fontSerif.weightMedium {
    font-weight: 500;
}
.secFaq .listWrap dt .sign {
    display: block;
    position: relative;
}
.secFaq .listWrap dt .sign:before {
    position: absolute;
    top: 50%;
    right: 15px;
    width: 12px;
    height: 1px;
    background: #000;
    content: "";
    -webkit-transition: -webkit-transform .3s;
    transition: -webkit-transform .3s;
    transition: transform .3s;
    transition: transform .3s, -webkit-transform .3s;
}
.secFaq .listWrap dt.on .sign:before {
    -webkit-transform: rotate(180deg);
    transform: rotate(180deg);
}
.secFaq .listWrap .inner {
    display: block;
    position: relative;
}
.secFaq .listWrap dt .inner {
    line-height: 1.64;
    padding: 20px 35px 20px 55px;
    font-size: 1rem;
}
.secFaq .listWrap dt .inner:before {
    position: absolute;
    top: 50%;
    left: 25px;
    line-height: 1;
    margin-top: -8px;
    font-family: "Libre Baskerville", serif;
    font-weight: normal;
    font-size: .8rem;
    content: "Q";
}
.secFaq .listWrap dt .sign:after {
    position: absolute;
    top: 50%;
    right: 15px;
    width: 12px;
    height: 1px;
    background: #000;
    content: "";
    -webkit-transition: -webkit-transform .3s;
    transition: -webkit-transform .3s;
    transition: transform .3s;
    transition: transform .3s, -webkit-transform .3s;
    -webkit-transform: rotate(90deg);
    transform: rotate(90deg);
}
.secFaq .listWrap dt.on .sign:after {
    -webkit-transform: rotate(180deg);
    transform: rotate(180deg);
}
.secFaq .listWrap dd {
    display: none;
}
.secFaq .listWrap dd {
    background: #eceef0;
}
.secFaq .listWrap dd .inner {
    line-height: 2;
    padding: 14px 25px;
    font-size: 1rem;
}
.secFaq .btn {
    margin-top: 15px;
    width:300px;
}
.mod_btn01 {
    display: block;
    padding: 15px;
    color: #fff;
    font-weight: 400;
    text-align: left;
    background: #3b3b3b;
    border: 1px solid #3b3b3b;
    -webkit-transition: .3s;
    transition: .3s;
}
.anime-btnFill {
    z-index: 1;
    box-sizing: border-box;
    position: relative;
    display: block;
    overflow: hidden;
    width: 100% !important;
    -webkit-transition: 0.5s ease-in-out;
    transition: 0.5s ease-in-out;
}
.anime-btnFill:hover {
    color:#4cb3b9;

}
.mod_btn01:hover {
    color: #fff;
    text-decoration: none;
}
.anime-btnFill:hover:before {
    -webkit-transform: translateX(0);
    transform: translateX(0);
}
.anime-btnFill:before {
    z-index: -1;
    box-sizing: border-box;
    content: '';
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    background-color: #24140c;
    -webkit-transform: translateX(-100%);
    transform: translateX(-100%);
    -webkit-transition: 0.5s ease-in-out;
    transition: 0.5s ease-in-out;
}
.anime-btnFill:before {
    z-index: -1;
    box-sizing: border-box;
    content: '';
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    background-color: #24140c;
    -webkit-transform: translateX(-100%);
    transform: translateX(-100%);
    -webkit-transition: 0.5s ease-in-out;
    transition: 0.5s ease-in-out;
}
.mod_btn01:hover span:before {
    background: #fff;
}
.mod_btn01:hover span:after {
    border-top: 1px solid #fff;
    border-right: 1px solid #fff;
}
.mod_btn01 span {
    position: relative;
    display: block;
}
.mod_btn01 span:before {
    width: 30px;
    height: 1px;
    background: #fff;
}
.mod_btn01 span:before, .mod_btn01 span:after {
    content: "";
    display: block;
    position: absolute;
    top: 50%;
    right: 0;
    -webkit-transition: .2s;
    transition: .2s;
    -webkit-transition-delay: .2s;
    transition-delay: .2s;
}
.mod_btn01 span:after {
    width: 4px;
    height: 4px;
    margin-top: -1px;
    border-top: 1px solid #fff;
    border-right: 1px solid #fff;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
}
.faq-images{
    width: 60%;
    margin: -17em 0 0 auto;
}
.faq-images02{
    width: 60%;
    margin: -17em 0 15em;
}

@media screen and (min-width: 768px){
    .secFaq .listWrap dt .inner {
        line-height: 2;
        padding: 24px 47px;
        font-size: 1rem;
        cursor: pointer;
        -webkit-transition: 0.5s ease-in-out;
        transition: 0.5s ease-in-out;
    }
    .secFaq .listWrap dt .inner:hover{
        color:#4cb3b9;
    }
    .secFaq .listWrap dt .inner:before {
        top: 30px;
        left: 12px;
        margin-top: 0;
        font-size: 1rem;
    }
    .secFaq .listWrap dd .inner {
        line-height: 2;
        padding: 34px 12px;
        font-size: .8rem;
    }
    .secFaq .listWrap dd .inner .btn {
        width: 295px;
        margin-top: 20px;
    }
    .mod_btn01 {
        display: block;
        padding: 14px 30px;
        color: #3b3b3b;
        font-size: .8rem;
        background: transparent;
        border: 1px solid #3b3b3b;
    }
    .mod_btn01 span:before {
        width: 30px;
        height: 1px;
        background: #3b3b3b;
    }
    .mod_btn01 span:after {
        width: 4px;
        height: 4px;
        margin-top: -1px;
        border-top: 1px solid #3b3b3b;
        border-right: 1px solid #3b3b3b;
    }
    .mod_btn01 span:before, .mod_btn01 span:after {
        right: 0;
    }
}
@media screen and (max-width: 767px){
    .secFaq .btn {
        width: 100% !important;
    }
    .faq-images02,.faq-images {
        width: 100%;
        margin: 10vw 0 10vw 0;
    }
    .contact-footerLink-top{
        margin-bottom: 20px;
    }
    #siryouseikyuu span.wpcf7-list-item {
        width: 50%;
        margin-bottom: 30px;
    }
}
@media (max-width: 575px){
    #keyWord,#mediaName{
        position: static;
    }
    #siryouseikyuu span.wpcf7-list-item {
        width: 100%;
    }
}
@media (max-width: 430px){
    #main-visual .text h2 {
        font-size: 1.16em;
    }
}
