@charset "UTF-8";



.construction_tab {
    margin: 0 1%;
    margin-bottom: 3rem;
    display: block;
}
.construction_tab li {
    margin: 0;
}
.construction_tab li a {
    padding: 12px 6px 10px;
    border: 1px solid #999;
    border-radius: 3px 3px 3px 3px;
    text-decoration: none;
    background-color: #eee;
    font-size: 1.3rem;
    color: #888;
    margin: 0 2px;
    display: block;
}
.construction_tab li .active {
    background: #fff;
}
@media screen and (min-width: 768px), print{
    .construction_tab {
        display: flex;
    }
    .construction_tab li {
        display: flex;
    }
    .construction_tab li a {
        padding: 9px 6px 10px;
        border: 2px solid #eee;
        border-bottom: none;
        border-radius: 3px 3px 0 0;
    }
}

.is-sp .tab_sp, .is-pc .tab_pc {
    display: block;
    width: 100%;
}
.is-pc .tab_sp, .is-sp .tab_pc {
    display: none;
}
.is-sp .tab_sp {
    position: relative;
    width: 93.5%;
}
.is-sp .tab_sp::after {
    width: 10px;
    height: 10px;
}

.is-sp .tab_sp .sp_title {
    margin: 0 3% 5px 3.5%;
    font-weight: 600;
    font-size: 12px;
}
.is-sp .tab_sp::after {
    content: '';
    width: 10px;
    height: 10px;
    border: 0px;
    border-bottom: solid 2px #b4b3b3;
    border-right: solid 2px #b4b3b3;
    -ms-transform: rotate(45deg);
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
    position: absolute;
    top: 50%;
    right: 10px;
    margin-top: -10px;
}
.is-sp .tab_sp .sp_select {
    font-size: 16px;
    margin: 0 3.5% 20px 3.5%;
    cursor: pointer; /* マウスカーソルの形を指定する */
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    width: 100%;
    height: 36px;
    background: transparent;
    position: relative;
    z-index: 1;
    padding: 0 40px 0 10px;
    border: 1px solid #b4b3b3;
    border-radius: 4px;
}


.complection_text {
    font-size: 1.3rem!important;
}
.list-result__image .construction_not_img {
    line-height: 32.57vw!important;
}
@media screen and (min-width: 768px), print{
    .list-result__image .construction_not_img {
        line-height: 173px!important;
    }
}




.construction_name {
    padding: 5.33vw 0;
    font-size: 4.53vw;
    line-height: 5.33vw;
    font-weight: bold;
    border-bottom: 2px solid #ccc;
}
.construction_copy {
    padding: 3.33vw 0;
    font-size: 3vw;
    line-height: 5.86vw;
}
.construction_list {
    border-top: 1px dashed #ccc;
}
.construction_item {
    margin: 1vw 0;
    font-size: 3vw;
    line-height: 5vw;
}

@media screen and (min-width: 768px), print{
    .construction_name {
        padding: 0 0 5px;
        font-size: 24px;
        line-height: 34px;
    }
    .construction_copy {
        padding: 15px 0;
        font-size: 14px;
        line-height: 28px;
    }
    .construction_item {
        margin: 10px 0;
        font-size: 14px;
        line-height: 20px;
    }
}

.construction_main .detail-image {
    padding: 0!important;
    margin: 0 2.6vw;
    border: none!important;
}
.construction_main_caption {
    width: 80%;
    margin: 0 10%;
    padding: 10px 0 20px;
    line-height: 1.5;
}

@media screen and (min-width: 768px), print{
    .construction_main .detail-image  {
        margin: 0!important;
    }
}



.construction_img_list {
    width: 100%;
    margin: 0 2.6vw;
}
/*.construction_img_list .detail-image__sub-item {*/
    /*margin-right: 1.5%!important;*/
/*}*/
.device-pc.is-sp .detail-image__sub-item, .detail-image__sub-item, .detail-image__sub-item:nth-child(4n)  {
    margin-right: 10px!important;
}
.construction_sub .construction_sub_caption {
    display: none;
}

/** 携帯端末のスライダー部分 **/

.construction_img_list {
    overflow-x: auto;
    overflow-y: hidden;
    width: 80%;
    margin: 0 10%;
    position: relative;
}
@media screen and (min-width: 768px), print {
    .construction_img_list {
        width: 100%;
    }
}
.slide_btn {
    position: absolute;
    top: 0;
    width: 95%;
    margin: 0 2.6vw;
}
.prev_img, .next_img {
    position: absolute;
    top: 0;
    z-index: 10;
    opacity: 0.7;
    background-color: rgba(102, 102, 102, 0.8);
    width: 25px;
}
.prev_img {
    left: 0;
}
.next_img {
    right: 0;
}
.prev_img img, .next_img img {
    margin: 0 9px;
}
.construction_img_list ul {
    width: 100%;
    -webkit-overflow-scrolling: touch;
    -webkit-transform: translateZ(0px);
}
.construction_img_list .sub_box5 {
    width: 125%;
}
.construction_img_list .sub_box6 {
    width: 150%;
}
.construction_img_list .sub_box7 {
    width: 175%;
}
.construction_img_list .sub_box8 {
    width: 200%;
}
.construction_img_list .sub_box9 {
    width: 225%;
}
.construction_img_list .sub_box10 {
    width: 250%;
}

.construction_img_list::-webkit-scrollbar {
    display: none;
    height: 0 !important;
}

.construction_sub:first-child {
    margin: 0;
}
/** ** ** ** **/

@media screen and (min-width: 768px), print{
    .construction_img_list {
        margin: 0;
    }
    .construction_img_list ul {
        width: 80%!important;
        margin: 0 10%;
    }
    .construction_img_list .detail-image__sub-item {
        margin-right: 10px!important;
    }
}

.no_height {
    min-height: auto;
}

h1 span {
    font-size: 2.7vw;
    font-weight: normal;
    text-decoration-style: solid!important;
    display: block;
    margin-top: 5px;
}
.casestudy-title {
    width: 100%;
    padding: 5.21vw 1.82vw 3.82vw;
}
.casestudy-title h1 {
    font-size: 5.21vw;
    margin-left: 5px;
}
@media screen and (min-width: 768px), print {
    h1 span {
        font-size: 14px;
    }
    .casestudy-title {
        padding: 30px 0 45px;
    }
    .casestudy-title h1 {
        font-size: 28px;
        margin-left: 0;
    }
}

.construction_copy a, .construction_main_caption a {
    color: #39f!important;
    text-decoration: underline!important;
}
.construction_copy a:hover, .construction_main_caption a:hover {
    opacity: 0.7;
}

.new_text {
    color: red;
    font-size: 12px;
}


.swiper-button-prev {
    /*background-image: url(/img/top_navArrow_left.png);*/
}
.swiper-button-next, .swiper-container-rtl .swiper-button-prev {
    /*background-image: url(/img/top_navArrow_right.png);*/
}

.image-right {
    width: 10%;
    float: right;
}
.image-center {
    width: 80%;
    display: inline-block;
}
.image-left {
    width: 10%;
    float: left;
}
.image-right img, .image-left img {
    padding: 0 40%;
    cursor: pointer;
    width: 0;
}

.casestudy-title h1 {
    display: inline-block;
}
.casestudy-title .detail-btn {
    margin: 20px auto 0;
    text-align: center;
}
.casestudy-title .detail-btn .btn-blue {
    color: #fff;
    background: #0077ed;
    border: solid 1px #0077ed;
    height: 30px;
    width: 140px;
    border-radius: 5px;
    cursor: pointer;
    margin: 0px 5px 10px;
}
#search_box {
    display: none;
    margin-bottom: 10px;
    margin-left: 14px;
}
#search_box .search_title {
    display: flex;
    align-items: center;
    font-size: 20px;
    border-radius: 5px;
}
#search_box .all_change {
    margin-bottom: 10px;
}
#search_box .all_change samp {
    margin: 5px;
    padding: 3px 7px;
    border: 1px solid #999;
    border-radius: 5px;
    background: #eee;
    cursor: pointer;
}
#search_box .category_box {
    display: inline-block;
    margin: 0 20px 10px 0;
}
#search_box .category_box input, #search_box .category_box label {
    cursor: pointer;
}
#search_box .key_title {
    display: inline-block;
    margin-right: 30px;
    vertical-align: top;
    margin-top: 17px;
}
#search_box .key_box {
    display: inline-block;
    width: 240px;
}
#search_box .key_box input[type='text']{
    display: block;
    padding: 5px;
    margin: 10px auto;
    width: 100%;
}
#search_box .andor_box {
    display: block;
    margin: 5px auto;
    text-align: center;
}
#search_box .key_button {
    text-align: center;
    margin-top: 10px;
}


#search_box .btn {
    height: 30px;
    width: 20%;
    border-radius: 5px;
    cursor: pointer;
    margin: 0px 5px 10px;
}

#search_box .btn-blue {
    color: #fff;
    background: #0077ed;
    border: solid 1px #0077ed;
}

#search_box .btn-white {
    color: #000;
    background: #fff;
    border: solid 1px #bbb;
}
.search_total {
    display: flex;
    align-items: center;
    font-size: 14px;
    margin: 10px;
}

@media screen and (min-width: 768px), print {
    #search_box {
        margin-left: 10px;
    }
    .casestudy-title .detail-btn {
        margin: 10px auto;
        float: right;
    }
    #search_box .btn {
        width: 100px;
    }
    #search_box .key_box {
        width: auto;
    }
    #search_box .key_box input[type='text']{
        display: inline-block;
        width: 280px;
    }
    #search_box .andor_box {
        display: inline-block;
        margin: 0 10px;
    }
}
