@charset "utf-8";
/* ===================================================================
CSS
 file name  :  top.css
=================================================================== */
/* =====================================
メイン
======================================== */
h1.main_title{
    margin-top: 100px;
    font-size: 4.0rem;
    font-weight: bold;
    text-align: center;
}
.main_subtext{
    margin-top: 10px;
    font-size: 1.8rem;
    font-weight: bold;
    text-align: center;
}
.slide_wrap{
    margin-top: 50px;
	overflow: hidden;
}
ul.main_slide li{
    width: 910px;
    margin: 0 20px;
}
@media screen and (max-width: 768px) {
    h1.main_title{
        margin-top: 50px;
        font-size: 2.8rem;
    }
    .main_subtext{
        margin-top: 5px;
        font-size: 1.4rem;
    }
    .slide_wrap{
        margin-top: 40px;
    }
    ul.main_slide li{
        width: 88vw;
        margin: 0 2vw;
    }
    ul.main_slide li img{
        width: 100%;
        height: 150vw;
        object-fit: cover;
    }
    ul.main_slide li{
        margin-bottom: 5vw;
    }
}
/* =====================================
悩み
======================================== */
@media print, screen and (min-width: 769px) {
    ul.problem_list{
        display: flex;
        justify-content: space-between;
        max-width: 1000px;
        margin: 60px auto auto;
    }
    ul.problem_list li{
        width: 30%;
        padding: 40px 30px
    }
    ul.problem_list li p{
        text-align: center;
    }
    ul.problem_list li .image{
        margin-top: 20px;
    }
}
ul.problem_list li{
    box-shadow: 0 5px 10px rgba(0, 0, 0, 0.3);
    border-radius: 5px;
}
ul.problem_list li p{
    font-weight: bold;
}
@media screen and (max-width: 768px) {
    ul.problem_list{
        max-width: 480px;
        margin: auto;
    }
    ul.problem_list li{
        box-shadow: 0 3px 6px rgba(0, 0, 0, 0.3);
        margin: 20px auto auto;
        display: flex;
        flex-direction: row-reverse;
        align-items: center;
        padding: 20px;
    }
    ul.problem_list li .image{
        width: 50%;
        padding-right: 20px;
    }
    ul.problem_list li .text{
        width: 50%;
    }
}
/* =====================================
メリット
======================================== */
ul.merit_list{
    display: flex;
    justify-content: space-between;
    max-width: 1080px;
    margin: 60px auto auto;
}
@media print, screen and (min-width: 769px) {
    ul.merit_list li{
        width: 23%;
        padding: 25px 20px
    }
}
ul.merit_list li{
    border: 5px solid #EAEAEA;
}
ul.merit_list li .number{
    max-width: 80px;
    margin: auto;
}
ul.merit_list li .image{
    max-width: 180px;
    margin: 20px auto auto;
}
ul.merit_list li p{
    margin-top: 20px;
    text-align: center;
    font-weight: bold;
}
@media screen and (max-width: 768px) {
    ul.merit_list{
        max-width: 600px;
        margin: auto;
        padding-top: 10px;
        flex-wrap: wrap;
    }
    ul.merit_list li{
        width: 46%;
        max-width: 250px;
        margin: 20px auto auto;
        padding: 20px 20px;
    }
    ul.merit_list li .image{
        margin: 15px auto auto;
    }
    ul.merit_list li p{
        margin-top: 10px;
    }
}
@media screen and (max-width: 480px) {
    ul.merit_list{
        display: block;
    }
    ul.merit_list li{
        width: 100%;
        max-width: 250px;
    }
}
/* =====================================
より安く、より自由に
======================================== */
.comparison_comment{
    margin: 60px auto auto;
    text-align: center;
}
.simulation_wrap{
    margin: 50px auto auto;
    background: #F0F7FF;
    padding: 80px 50px 50px 50px;
}
.simulation_box{
    background: #FFF;
    max-width: 1080px;
    margin: auto;
    padding: 0 50px 50px 50px;
}
h3.balloon{
    position: relative;
    display: block;
    background: #226BBE;
    width: 100%;
    border-radius: 5px;
    text-align: center;
    font-size: 2.8rem;
    font-weight: bold;
    color: #FFFFFF;
    transform: translateY(-30px);
}
h3.balloon:before {
    content: "";
    position: absolute;
    top: 100%;
    left: 50%;
    margin-left: -15px;
    border: 15px solid transparent;
    border-top: 15px solid #226BBE;
}
.simulation_title{
    font-size: 2.0rem;
    font-weight: bold;
    color: #226BBE;
    text-align: center;
    border: 1px solid #226BBE;
}
.simulation_title.pay{
    margin-top: 50px;
}
.simulation_image{
    margin: 30px auto auto;
}
.simulation_attention{
    margin: 20px auto auto;
    font-size: 1.4rem;
}
.simulation_comment{
    margin: 50px auto auto;
    text-align: center;
}
.simulation_comment p{
    margin-top: 1em;
}
.simulation_comment .large{
    font-weight: bold;
    font-size: 1.8rem;
}
@media screen and (max-width: 768px) {
    .comparison_comment{
        margin: 30px auto auto;
    }
    .simulation_wrap{
        margin: 30px auto auto;
        padding: 50px 20px 40px 20px;
    }
    .simulation_box{
        max-width: 640px;
        padding: 0 20px 20px 20px;
    }
    h3.balloon{
        font-size: 1.4rem;
        transform: translateY(-15px);
    }
    h3.balloon:before {
        margin-left: -9px;
        border:9px solid transparent;
        border-top: 9px solid #226BBE;
    }
    .simulation_title{
        font-size: 1.4rem;
    }
    .simulation_title.pay{
        margin-top: 30px;
    }
    .simulation_image{
        margin: 20px auto auto;
        max-width: 480px;
    }
    .simulation_attention{
        margin: 10px auto auto;
        font-size: 1.0rem;
    }
    .simulation_comment{
        margin: 30px auto auto;
    }
    .simulation_comment .large{
        font-size: 1.4rem;
    }
}
/* =====================================
強み
======================================== */
.title_strengths{
    margin: 70px auto auto;
    max-width: 124px;
}
.lead_strengths{
    margin-top: 30px;
    text-align: center;
    font-size: 2.8rem;
    font-weight: bold;
}
.img_support{
    margin: 50px auto auto;
    max-width: 1018px;
}
@media print, screen and (min-width: 769px) {
    .graph_wrap{
        display: flex;
        justify-content: space-between;
        margin-top: 50px;
    }
}
.graph_wrap > div{
    width: 48%;
    border: 1px solid #CCCCCC;
}
.graph_comment{
    margin-top: 30px;
}
@media screen and (max-width: 768px) {
    .title_strengths{
        margin: 35px auto auto;
        max-width: 92px;
    }
    .lead_strengths{
        margin-top: 20px;
        font-size: 1.8rem;
    }
    .img_support{
        margin: 25px auto auto;
        max-width: 360px;
    }
    .graph_wrap > div{
        margin: 20px auto auto;
        width: 100%;
        max-width: 360px;
        border: 1px solid #CCCCCC;
    }
}
/* =====================================
お客様の声
======================================== */
.bg_voice{
    margin-top: 120px;
    background: #FDFDF5;
}
.voice_wrap{
	max-width: 1180px;
	margin: auto;
	padding: 70px 50px 70px 50px;;
}
h2.sub_title.voice_title{
    background: url("../images/top/bg_voice_title.png") no-repeat top center;
    background-size: 140px auto;
    padding-top: 30px;
}
@media print, screen and (min-width: 769px) {
    ul.voice_list{
        margin-top: 70px;
        display: flex;
        justify-content: space-between;
    }
    ul.voice_list li{
        width: 33.333%;
        padding: 0 20px;
    }
}
ul.voice_list li .image{
    margin: auto;
    width: 81%;
    max-width: 260px;
    position: relative;
    z-index: 100;
}
ul.voice_list li .text{
    z-index: 10;
    transform: translateY(-20px);
    background: #FFF;
    border-radius: 5px;
    box-shadow: 0 5px 10px rgba(0, 0, 0, 0.3);
    padding: 40px 30px 30px 30px;
    min-height: 280px;
}
ul.voice_list li .text .voice_name{
    text-align: center;
    font-size: 1.4rem;
    font-weight: bold;
}
ul.voice_list li .text p{
    margin-top: 1em;
}
@media screen and (max-width: 768px) {
    .bg_voice{
        margin-top: 50px;
    }
    .voice_wrap{
        padding: 40px 20px 40px 20px;;
    }
    h2.sub_title.voice_title{
        background: url("../images/top/bg_voice_title.png") no-repeat top center;
        background-size: 70px auto;
        padding-top: 15px;
    }
    ul.voice_list{
        max-width: 300px;
        margin: auto;
    }
    ul.voice_list li{
        margin-top: 20px;
    }
    ul.voice_list li .image{
        max-width: 195px;
    }
    ul.voice_list li .text{
        padding: 40px 30px 30px 30px;
        min-height: inherit;
    }
    ul.voice_list li .text .voice_name{
        font-size: 1.2rem;
    }
}
/* =====================================
事例
======================================== */
.case_lead{
    text-align: center;
    font-size: 2.2rem;
    font-weight: bold;
    margin-top: 10px;
}
@media screen and (min-width: 1080px) {
    .case_box{
        min-height: 540px;
    }
}
@media print, screen and (min-width: 769px) {
    .case_box{
        position: relative;
        margin-top: 80px;
    }
    .case_box .text{
        width: 46%;
        padding: 60px 16% 60px 3.7%;
        background: #F7F7F7;
    }
}
.case_box .text .case_no{
    width: 40px;
}
.case_box .text .case_catch{
    font-size: 1.8rem;
    font-weight: bold;
    margin: 1em auto auto;
}
.case_box .text .case_name{
    margin: 1em auto auto;
    border-top: 1px solid #000;
    padding-top: 1em;
    font-weight: bold;
}
.case_box .text dl.case_data{
    margin: 10px auto auto;
}
.case_box .text dl.case_data dt{
    color: #777777;
}
.case_box .text dl.case_data dd{
    padding-left: 100px;
    margin-top: -2em;
}
@media print, screen and (min-width: 769px) {
    .case_box .photo{
        width: 66%;
        position: absolute;
        top: 60px;
        right: 0;
        box-shadow: 0 5px 20px rgba(0, 0, 0, 0.3);
    }
}
@media screen and (max-width: 768px) {
    .wrap_wide_nomal.case_sp{
        padding: 50px 0px 0 0px;;
    }
    .case_lead{
        font-size: 1.6rem;
        margin-top: 5px;
    }
    .case_box{
        background: linear-gradient(180deg, #F7F7F7 0%, #F7F7F7 80%, #FFFFFF 80%, #FFFFFF 100%);
        margin-top: 40px;
    }
    .case_box .text{
        padding: 30px 20px;
        max-width: 520px;
        margin: auto;
    }
    .case_box .text .case_no{
        width: 24px;
    }
    .case_box .text .case_catch{
        font-size: 1.4rem;
    }
    .case_box .photo{
        padding: 0 20px;
        max-width: 520px;
        margin: auto;
    }
    .case_box .photo img{
        box-shadow: 0 3px 10px rgba(0, 0, 0, 0.3);
    }
}
/* =====================================
よくあるご質問
======================================== */
.bg_qa{
    margin-top: 120px;
    background: #FDFDF5;
}
.qa_wrap{
	max-width: 1180px;
	margin: auto;
	padding: 70px 50px 70px 50px;;
}
h2.sub_title.qa_title{
    background: url("../images/top/bg_qa_title.png") no-repeat top center;
    background-size: 65px auto;
    padding-top: 30px;
}
dl.qa_list{
    margin-top: 70px;
    border-top: 1px solid #EDEDED;
}
dl.qa_list dt{
    background: url("../images/top/icon_q.png") no-repeat top 34px left;
    background-size: 23px auto;
    padding: 30px 0 30px 60px;
    font-weight: bold;
    font-size: 1.8rem;
}
dl.qa_list dd{
    background: url("../images/top/icon_a.png") no-repeat top 4px left;
    background-size: 23px auto;
    padding: 0px 0 30px 60px;
    border-bottom: 1px solid #EDEDED;
}
@media screen and (max-width: 768px) {
    .bg_qa{
        margin-top: 50px;
    }
    .qa_wrap{
        padding: 40px 20px;
    }
    h2.sub_title.qa_title{
        background: url("../images/top/bg_qa_title.png") no-repeat top center;
        background-size: 34px auto;
        padding-top: 15px;
    }
    dl.qa_list{
        margin-top: 30px;
    }
    dl.qa_list dt{
        background: url("../images/top/icon_q.png") no-repeat top 18px left;
        background-size: 15px auto;
        padding: 15px 0 15px 30px;
        font-size: 1.2rem;
    }
    dl.qa_list dd{
        background: url("../images/top/icon_a.png") no-repeat top 4px left;
        background-size: 15px auto;
        padding: 0px 0 15px 30px;
    }
}