@charset "UTF-8";
/* Scss Document */
.flex_30 {
    width: 30%;
}
.flex_31 {
    width: 31%;
}
.flex_32 {
    width: 32%;
}
.flex_33 {
    width: 33%;
}
.flex_34 {
    width: 34%;
}
.flex_35 {
    width: 35%;
}
.flex_36 {
    width: 36%;
}
.flex_37 {
    width: 37%;
}
.flex_38 {
    width: 38%;
}
.flex_39 {
    width: 39%;
}
.flex_40 {
    width: 40%;
}
.flex_41 {
    width: 41%;
}
.flex_42 {
    width: 42%;
}
.flex_43 {
    width: 43%;
}
.flex_44 {
    width: 44%;
}
.flex_45 {
    width: 45%;
}
.flex_46 {
    width: 46%;
}
.flex_47 {
    width: 47%;
}
.flex_48 {
    width: 48%;
}
.flex_49 {
    width: 49%;
}
.flex_50 {
    width: 50%;
}
.flex_51 {
    width: 51%;
}
.flex_52 {
    width: 52%;
}
.flex_53 {
    width: 53%;
}
.flex_54 {
    width: 54%;
}
.flex_55 {
    width: 55%;
}
.flex_56 {
    width: 56%;
}
.flex_57 {
    width: 57%;
}
.flex_58 {
    width: 58%;
}
.flex_59 {
    width: 59%;
}
.flex_60 {
    width: 60%;
}
.flex_61 {
    width: 61%;
}
.flex_62 {
    width: 62%;
}
.flex_63 {
    width: 63%;
}
.flex_64 {
    width: 64%;
}
.flex_65 {
    width: 65%;
}
.flex_66 {
    width: 66%;
}
.flex_67 {
    width: 67%;
}
.flex_68 {
    width: 68%;
}
.flex_69 {
    width: 69%;
}
.flex_70 {
    width: 70%;
}
.padding100 {
    padding-top: 100px;
    padding-bottom: 100px;
}
.padding110 {
    padding-top: 110px;
    padding-bottom: 110px;
}
.padding120 {
    padding-top: 120px;
    padding-bottom: 120px;
}
.padding130 {
    padding-top: 130px;
    padding-bottom: 130px;
}
.padding140 {
    padding-top: 140px;
    padding-bottom: 140px;
}
.padding150 {
    padding-top: 150px;
    padding-bottom: 150px;
}
.padding160 {
    padding-top: 160px;
    padding-bottom: 160px;
}
.padding170 {
    padding-top: 170px;
    padding-bottom: 170px;
}
.padding180 {
    padding-top: 180px;
    padding-bottom: 180px;
}
.padding190 {
    padding-top: 190px;
    padding-bottom: 190px;
}
.padding200 {
    padding-top: 200px;
    padding-bottom: 200px;
}
.padding210 {
    padding-top: 210px;
    padding-bottom: 210px;
}
.padding220 {
    padding-top: 220px;
    padding-bottom: 220px;
}
.padding230 {
    padding-top: 230px;
    padding-bottom: 230px;
}
.padding240 {
    padding-top: 240px;
    padding-bottom: 240px;
}
.padding250 {
    padding-top: 250px;
    padding-bottom: 250px;
}
.padding260 {
    padding-top: 260px;
    padding-bottom: 260px;
}
.padding270 {
    padding-top: 270px;
    padding-bottom: 270px;
}
.padding280 {
    padding-top: 280px;
    padding-bottom: 280px;
}
.padding290 {
    padding-top: 290px;
    padding-bottom: 290px;
}
.padding300 {
    padding-top: 300px;
    padding-bottom: 300px;
}
.margin100 {
    margin-top: 100px;
    margin-bottom: 100px;
}
.margin110 {
    margin-top: 110px;
    margin-bottom: 110px;
}
.margin120 {
    margin-top: 120px;
    margin-bottom: 120px;
}
.margin130 {
    margin-top: 130px;
    margin-bottom: 130px;
}
.margin140 {
    margin-top: 140px;
    margin-bottom: 140px;
}
.margin150 {
    margin-top: 150px;
    margin-bottom: 150px;
}
.margin160 {
    margin-top: 160px;
    margin-bottom: 160px;
}
.margin170 {
    margin-top: 170px;
    margin-bottom: 170px;
}
.margin180 {
    margin-top: 180px;
    margin-bottom: 180px;
}
.margin190 {
    margin-top: 190px;
    margin-bottom: 190px;
}
.margin200 {
    margin-top: 200px;
    margin-bottom: 200px;
}
.margin210 {
    margin-top: 210px;
    margin-bottom: 210px;
}
.margin220 {
    margin-top: 220px;
    margin-bottom: 220px;
}
.margin230 {
    margin-top: 230px;
    margin-bottom: 230px;
}
.margin240 {
    margin-top: 240px;
    margin-bottom: 240px;
}
.margin250 {
    margin-top: 250px;
    margin-bottom: 250px;
}
.margin260 {
    margin-top: 260px;
    margin-bottom: 260px;
}
.margin270 {
    margin-top: 270px;
    margin-bottom: 270px;
}
.margin280 {
    margin-top: 280px;
    margin-bottom: 280px;
}
.margin290 {
    margin-top: 290px;
    margin-bottom: 290px;
}
.margin300 {
    margin-top: 300px;
    margin-bottom: 300px;
}
.pt-110 {
    padding-top: 110px;
}
.pt-120 {
    padding-top: 120px;
}
.pt-130 {
    padding-top: 130px;
}
.pt-140 {
    padding-top: 140px;
}
.pt-150 {
    padding-top: 150px;
}
.pt-160 {
    padding-top: 160px;
}
.pt-170 {
    padding-top: 170px;
}
.pt-180 {
    padding-top: 180px;
}
.pt-190 {
    padding-top: 190px;
}
.pt-200 {
    padding-top: 200px;
}
.pt-210 {
    padding-top: 210px;
}
.pt-220 {
    padding-top: 220px;
}
.pt-230 {
    padding-top: 230px;
}
.pt-240 {
    padding-top: 240px;
}
.pt-250 {
    padding-top: 250px;
}
.pt-260 {
    padding-top: 260px;
}
.pt-270 {
    padding-top: 270px;
}
.pt-280 {
    padding-top: 280px;
}
.pt-290 {
    padding-top: 290px;
}
.pt-300 {
    padding-top: 300px;
}
.pb-110 {
    padding-bottom: 110px;
}
.pb-120 {
    padding-bottom: 120px;
}
.pb-130 {
    padding-bottom: 130px;
}
.pb-140 {
    padding-bottom: 140px;
}
.pb-150 {
    padding-bottom: 150px;
}
.pb-160 {
    padding-bottom: 160px;
}
.pb-170 {
    padding-bottom: 170px;
}
.pb-180 {
    padding-bottom: 180px;
}
.pb-190 {
    padding-bottom: 190px;
}
.pb-200 {
    padding-bottom: 200px;
}
.pb-210 {
    padding-bottom: 210px;
}
.pb-220 {
    padding-bottom: 220px;
}
.pb-230 {
    padding-bottom: 230px;
}
.pb-240 {
    padding-bottom: 240px;
}
.pb-250 {
    padding-bottom: 250px;
}
.pb-260 {
    padding-bottom: 260px;
}
.pb-270 {
    padding-bottom: 270px;
}
.pb-280 {
    padding-bottom: 280px;
}
.pb-290 {
    padding-bottom: 290px;
}
.pb-300 {
    padding-bottom: 300px;
}
.mt-110 {
    margin-top: 110px;
}
.mt-120 {
    margin-top: 120px;
}
.mt-130 {
    margin-top: 130px;
}
.mt-140 {
    margin-top: 140px;
}
.mt-150 {
    margin-top: 150px;
}
.mt-160 {
    margin-top: 160px;
}
.mt-170 {
    margin-top: 170px;
}
.mt-180 {
    margin-top: 180px;
}
.mt-190 {
    margin-top: 190px;
}
.mt-200 {
    margin-top: 200px;
}
.mt-210 {
    margin-top: 210px;
}
.mt-220 {
    margin-top: 220px;
}
.mt-230 {
    margin-top: 230px;
}
.mt-240 {
    margin-top: 240px;
}
.mt-250 {
    margin-top: 250px;
}
.mt-260 {
    margin-top: 260px;
}
.mt-270 {
    margin-top: 270px;
}
.mt-280 {
    margin-top: 280px;
}
.mt-290 {
    margin-top: 290px;
}
.mt-300 {
    margin-top: 300px;
}
.mb-110 {
    margin-bottom: 110px;
}
.mb-120 {
    margin-bottom: 120px;
}
.mb-130 {
    margin-bottom: 130px;
}
.mb-140 {
    margin-bottom: 140px;
}
.mb-150 {
    margin-bottom: 150px;
}
.mb-160 {
    margin-bottom: 160px;
}
.mb-170 {
    margin-bottom: 170px;
}
.mb-180 {
    margin-bottom: 180px;
}
.mb-190 {
    margin-bottom: 190px;
}
.mb-200 {
    margin-bottom: 200px;
}
.mb-210 {
    margin-bottom: 210px;
}
.mb-220 {
    margin-bottom: 220px;
}
.mb-230 {
    margin-bottom: 230px;
}
.mb-240 {
    margin-bottom: 240px;
}
.mb-250 {
    margin-bottom: 250px;
}
.mb-260 {
    margin-bottom: 260px;
}
.mb-270 {
    margin-bottom: 270px;
}
.mb-280 {
    margin-bottom: 280px;
}
.mb-290 {
    margin-bottom: 290px;
}
.mb-300 {
    margin-bottom: 300px;
}
* {
    text-decoration: none !important;
}
.max_img100 img {
    max-width: 100%;
    height: auto;
}
.side_bar {
    position: fixed;
    right: 0;
    top: calc(50% + 63px);
    transform: translateY(-50%);
    z-index: 999;
    border-top: 1px solid #FFF;
    border-left: 1px solid #FFF;
}
.side_bar > div {
    width: 60px;
    padding: 30px 0;
    font-size: 15px;
    writing-mode: vertical-rl;
    font-family: "NotoSansCJKjp-Regular_ver";
    border-bottom: 1px solid #FFF;
}
.side_bar > div:nth-child(1) {
    background-color: #2e9568;
}
.side_bar > div:nth-child(2) {
    background-color: #f39801;
}
.side_bar > div:nth-child(3) {
    background-color: #da4b13;
}
.side_bar a {
    display: flex;
    justify-content: center;
    align-items: center;
    color: #FFF;
    width: 100%;
    height: 100%;
    font-weight: normal !important;
    letter-spacing: 0.1em;
}
.side_bar a img {
    margin-bottom: 10px;
}
.radius10 {
    border-radius: 10px;
}
.radius20 {
    border-radius: 20px;
}
.bg_gray_fdfdfd {
    background-color: #fdfdfd;
}
/************************/
.cy_header {
    padding: 40px 0;
}
.h_flex {
    display: flex;
    justify-content: space-between;
    align-items: center;
    max-width: 1760px;
    width: 90%;
    margin: 0 auto;
}
.logo {
    width: 175px;
    position: relative;
    z-index: 99999999;
}
.cy_nav {
    width: calc(100% - 200px);
}
.cy_nav ul {
    display: flex;
    justify-content: space-between;
    max-width: 980px;
    margin-left: auto;
}
.cy_nav a {
    color: inherit;
    font-weight: bold;
    position: relative;
}
.cy_nav a:after {
    content: "";
    border-bottom: 2px solid #ffd85f;
    position: absolute;
    bottom: -5px;
    left: 50%;
    width: 0;
    transform: translateX(-50%);
    transition: 0.3s ease;
}
.cy_nav a:hover:after {
    width: 100%;
}
/**********/
.top_main {
    max-width: calc(100% - 120px);
    margin: 0 auto;
    width: calc(100% - 120px);
    overflow: hidden;
    position: relative;
}
.top_main, .flexslider, .flexslider li {
    height: 830px;
    border-radius: 80px;
    overflow: hidden;
}
#fade1 {
    background: url("../images/fade1.jpg") 50% 0/cover no-repeat;
}
#fade2 {
    background: url("../images/fade2.jpg") 50% 0/cover no-repeat;
}
#fade3 {
    background: url("../images/fade3.jpg") 50% 0/cover no-repeat;
}
.flexslider li {
    animation: fade 4s linear forwards;
    transform: scale(1.1);
}
@keyframes fade {
    0% {
        transform: scale(1.1);
    }
    100% {
        transform: scale(1);
    }
}
.top_title {
    font-size: 60px;
    color: #FFF;
    font-weight: bold;
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    bottom: 130px;
    width: 90%;
    max-width: 1600px;
    z-index: 500;
    line-height: 1.5em;
    opacity: 0;
}
.top_title.titleStart {
    animation: title 1s ease 0.8s forwards;
}
@keyframes title {
    0% {
        opacity: 0;
        transform: translateX(-50%) translateY(30px);
    }
    100% {
        opacity: 1;
        transform: translateX(-50%) translateY(0);
    }
}
/*******************/
.title_38 {
    font-size: 38px;
    font-weight: bold;
}
.center {
    text-align: center;
}
.eng_16 {
    font-size: 16px;
    letter-spacing: 0.2em;
    color: #2e9568;
}
.color_2e9568 {
    color: #2e9568;
}
.news {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    column-gap: 80px;
    row-gap: 80px;
}
.radius30 {
    overflow: hidden;
    border-radius: 30px;
}
.n_cate {
    margin: 15px 0 10px;
}
.n_cate span {
    display: inline-block;
    padding: 0 10px;
    line-height: 1.5em;
    border-radius: 50px;
    color: #FFF;
    font-size: 14px;
}
.n_cate.green span {
    background-color: #2e9568;
}
.n_cate.orange span {
    background-color: #f39801;
}
.n_title {
    font-size: 14px;
}
.more {
    width: 100%;
    max-width: 470px;
    margin-left: auto;
    margin-right: auto;
    position: relative;
    background-color: #FFF;
}
.more a {
    border: 2px solid #101111;
    border-radius: 5px;
    display: block;
    margin: 0 auto;
    padding: 25px 10px;
    letter-spacing: 0.05em;
    position: relative;
    color: inherit;
    text-align: center;
    transition: 0.5s ease;
    z-index: 500;
}
.more img {
    position: absolute;
    right: 25px;
    top: 50%;
    transform: translateY(-50%);
    transition: 0.5s ease;
}
.more:after {
    content: "";
    background-color: #101111;
    position: absolute;
    top: 0;
    right: 0;
    width: 0;
    height: 100%;
    transition: 0.5s ease;
    border-radius: 5px;
}
.more:hover a {
    color: #FFF;
}
.more:hover .shape_off {
    opacity: 0;
    right: 0;
}
.more:hover .shape_on {
    animation: shape_on2 0.5s ease 0.1s forwards;
}
.more:hover:after {
    width: 100%;
    left: 0;
}
.more .shape_on {
    opacity: 0;
    right: 50px;
    animation: shape_on 0.5s ease 0s forwards;
}
.more.more_w {
    background-color: inherit;
}
.more.more_w a {
    border-color: #FFF;
    color: #FFF;
}
.more.more_w:hover a {
    color: #101111;
}
.more.more_w:after {
    background-color: #FFF;
}
@keyframes shape_on {
    0% {
        opacity: 1;
        right: 25px;
    }
    50% {
        opacity: 0;
        right: 50px;
    }
    100% {
        opacity: 0;
        right: 50px;
    }
}
@keyframes shape_on2 {
    0% {
        opacity: 0;
        right: 50px;
    }
    50% {
        opacity: 0;
        right: 50px;
    }
    100% {
        opacity: 1;
        right: 25px;
    }
}
/***********************/
.top_af_bg {
    position: relative;
}
.top_af_bg:after {
    content: "";
    background-color: #2e9568;
    position: absolute;
    top: 0;
    right: 0;
    height: 100%;
    max-width: 1840px;
    width: calc(100% - 10px);
    border-radius: 80px 0 0 80px;
}
.w900_auto {
    width: 100%;
    max-width: 900px;
    margin-left: auto;
    margin-right: auto;
}
.be_af_border {
    display: flex;
    align-items: center;
    justify-content: center;
}
.be_af_border:before, .be_af_border:after {
    content: "";
    border-bottom: 2px solid #FFF;
    width: 42px;
    height: 2px;
}
.be_af_border:before {
    margin-right: 30px;
}
.be_af_border:after {
    margin-left: 30px;
}
.title_24 {
    font-size: 24px;
    font-weight: bold;
}
.text_15 {
    font-size: 15px;
}
.letter003 {
    letter-spacing: 0.03em;
}
.line_height22 {
    line-height: 2.2em;
}
.bg_w {
    background-color: #FFF;
}
.radius100 {
    border-radius: 100px;
}
.padding50 {
    padding: 50px;
}
.title_28 {
    font-size: 28px;
    font-weight: bold;
}
.inline_block {
    display: inline-block;
}
.text_20 {
    font-size: 20px;
}
/****************/
.top_bg {
    background: url("../images/top5.jpg") 50% 0/cover no-repeat;
    height: 680px;
}
.ver_title {
    position: absolute;
    right: 0;
    top: -390px;
    z-index: 500;
    background-color: #FFF;
    width: 250px;
    border-radius: 15px;
    padding: 70px 20px;
    display: flex;
    align-items: center;
    writing-mode: vertical-rl;
}
.ver_title h2 {
    font-family: "NotoSansCJKjp-Regular_ver";
    white-space: nowrap;
    text-align: left;
}
.ver_title p {
    white-space: nowrap;
    text-align: left;
}
.title_35 {
    font-size: 35px;
    font-weight: bold;
}
.big_40 {
    font-size: 40px;
}
.span_bb {
    background: linear-gradient(transparent 60%, #ffd85f 60%);
}
.text_17 {
    font-size: 17px;
}
.top_grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    column-gap: 100px;
    row-gap: 100px;
}
.top_grid > div {
    position: relative;
}
.top_grid > div:after {
    content: "";
    background: url("../images/top7.png") 50% 50%/45px 100% no-repeat;
    width: 100px;
    height: 46px;
    position: absolute;
    right: -100px;
    top: 50%;
    transform: translateY(-50%);
}
.top_grid > div:last-child:after {
    display: none;
}
.top_banner {
    background: url("../images/top10.png") 50% 0/cover no-repeat;
    height: 400px;
    position: relative;
}
.top_banner a {
    display: block;
    color: #FFF;
    position: relative;
    z-index: 550;
    height: 100%;
}
.top_banner:after {
    content: "";
    border: 2px solid #FFF;
    position: absolute;
    top: 20px;
    left: 20px;
    width: calc(100% - 40px);
    height: calc(100% - 40px);
    border-radius: 20px;
}
.top_banner .banner_title {
    position: absolute;
    right: 80px;
    top: 50%;
    transform: translateY(-50%);
    z-index: 500;
    color: #FFF;
}
.top_banner .banner_title h2 {
    font-size: 40px;
    font-weight: bold;
    line-height: 1.5em;
    letter-spacing: 0.15em;
}
.top_banner .banner_title p {
    margin-top: 30px;
    font-size: 15px;
    text-align: right;
}
.top_banner .banner_title p img {
    margin-left: 30px;
}
.top_banner .banner_title p span {
    border-bottom: 2px solid #FFF;
    display: inline-block;
    padding-bottom: 5px;
}
.banner_img {
    position: absolute;
    left: 40px;
    top: 0;
    z-index: 500;
}
/**********************/
.top_af_bg2 {
    position: relative;
}
.top_af_bg2:after {
    content: "";
    background: url("../images/top_bg.jpg") left 0/320px 260px repeat;
    position: absolute;
    top: 0;
    left: 0;
    max-width: 1840px;
    width: calc(100% - 10px);
    height: 100%;
    border-radius: 0 80px 80px 0;
}
.top_model a {
    color: inherit;
}
.top_model img {
    transition: 0.5s ease;
}
.top_model a:hover .model_off {
    opacity: 0;
}
.top_model a:hover .model_on {
    opacity: 1;
}
.top_model a:hover .model_shape:after {
    transform: translate(-50%, -50%) scale(1.05);
}
.model_title {
    position: relative;
    padding: 10px 60px 10px 20px;
    font-size: 20px;
    font-weight: bold;
}
.model_title p {
    letter-spacing: 0.15em;
}
.model_title span {
    font-size: 28px;
}
.model_shape {
    width: 37px;
    height: 37px;
    border: 1px solid #2e9568;
    border-radius: 50%;
    position: absolute;
    right: 20px;
    top: 8px;
    overflow: hidden;
    background-color: #FFF;
}
.model_shape img {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    z-index: 500;
}
.model_shape:after {
    content: "";
    background-color: #2e9568;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%) scale(0);
    border-radius: 50%;
    transition: 0.3s ease;
    width: 100%;
    height: 100%;
}
.model_on {
    opacity: 0;
}
/************/
.slider.slider_style {
    width: calc(100% + 600px);
    margin-left: -35px;
}
.slider.slider_style h3 {
    font-size: 22px;
    margin: 15px 0 20px;
}
.slider.slider_style p {
    font-size: 15px;
}
.slider li {
    float: left;
    position: relative;
    z-index: 900;
    padding: 0 35px;
}
.radius40 {
    border-radius: 60px;
    overflow: hidden;
}
/************************/
.bg_gray_f5f5f5 {
    background-color: #f5f5f5;
}
.blog_grid {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
}
.blog_grid > div {
    max-width: 590px;
    width: 48%;
    margin: 25px 0;
}
.blog_grid > div a {
    color: inherit;
    display: flex;
    justify-content: space-between;
}
.blog_left {
    width: 46%;
}
.blog_left img {
    width: 100%;
    height: auto;
}
.blog_right {
    width: 49%;
    padding-top: 25px;
}
.b_time {
    font-size: 14px;
}
.b_title {
    font-weight: bold;
    margin-top: 5px;
}
/*************************/
.under_banner {
    display: flex;
    justify-content: space-between;
}
.under_banner > div {
    width: 50%;
    height: 450px;
    position: relative;
    overflow: hidden;
}
.under_banner > div a {
    display: flex;
    justify-content: center;
    align-items: center;
    height: 100%;
    position: relative;
    z-index: 500;
}
.under_banner > div a:hover:after {
    opacity: 0;
}
.under_banner > div a:hover .banner_bg1, .under_banner > div a:hover .banner_bg2 {
    filter: blur(0);
}
.under_banner > div a:after {
    content: "";
    background-color: rgba(0, 0, 0, 0.31);
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    transition: 0.5s ease;
}
.banner_bg1 {
    background: url("../images/top19.jpg") 50% 0/cover no-repeat;
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    filter: blur(2px);
    transition: 0.5s ease;
}
.banner_bg2 {
    background: url("../images/top20.jpg") 50% 0/cover no-repeat;
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    filter: blur(2px);
    transition: 0.5s ease;
}
/************************/
.f_bg {
    background-color: #2e9568;
    padding: 130px 0;
    color: #FFF;
    position: relative;
}
.page_top {
    position: absolute;
    right: 20px;
    bottom: 40px;
    cursor: pointer;
}
.f_flex {
    display: flex;
    justify-content: space-between;
}
.f_left {
    width: 400px;
}
.f_logo img {
    width: 312px;
    height: auto;
}
.f_tel {
    margin-top: 5px;
    font-size: 35px;
}
.f_right {
    width: calc(100% - 400px);
}
.f_links {
    width: 100%;
    max-width: 340px;
    margin-left: auto;
}
.f_links a {
    margin: 10px 0;
    background-color: #FFF;
    display: block;
    padding: 20px 30px;
    border-radius: 10px;
    position: relative;
    color: #2e9568;
    font-weight: bold;
}
.f_links a img {
    position: absolute;
    right: 15px;
    top: 50%;
    transform: translateY(-50%);
}
.f_nav {
    margin-top: 10px;
    display: flex;
    max-width: 500px;
    margin-left: auto;
    margin-top: 20px;
}
.f_nav > div:nth-child(1) {
    display: flex;
    align-items: center;
    font-size: 14px;
}
.f_nav > div:nth-child(1) a {
    color: #FFF;
}
.f_nav > div:nth-child(1) p {
    padding: 0 20px;
    border-right: 1px solid #FFF;
    line-height: 1em;
}
.f_nav > div:nth-child(1) p:last-child {
    border-right: 0;
}
.f_nav > div:nth-child(2) {
    display: flex;
    align-items: center;
}
.f_nav > div:nth-child(2) a {
    margin: 0 10px;
}
.copy {
    font-size: 14px;
    background-color: #FFF;
    padding: 40px 0;
    text-align: center;
}
/*******************************************************************

    家づくりの想い

*******************************************************************/
.concept_main {
    background: url("../images/concept1.jpg") 50% 0/cover no-repeat;
}
.main_size {
    width: calc(100% - 120px);
    max-width: calc(100% - 120px);
    margin: 0 auto;
    height: 400px;
    overflow: hidden;
    border-radius: 80px;
    text-align: center;
    display: flex;
    justify-content: center;
    align-items: center;
    color: #FFF;
}
.main_size h2 {
    font-weight: bold;
    font-size: 50px;
    line-height: 1.3em;
}
.main_size p {
    margin-top: 0;
    font-size: 20px;
    letter-spacing: 0.2em;
}
/**********************/
.concept_padding {
    padding: 130px 0 430px;
}
.title_45 {
    font-size: 45px;
    font-weight: bold;
}
.yellow_ffd85f {
    color: #ffd85f;
}
.big_50 {
    font-size: 50px;
}
.letter005 {
    letter-spacing: 0.05em;
}
.line_height24 {
    line-height: 2.4em;
}
.con_ab1 {
    position: absolute;
    left: 0;
    bottom: 0;
}
.con_ab2 {
    position: absolute;
    right: 0;
    bottom: 70px;
}
.con_ab_img1 {
    position: absolute;
    left: 0;
    bottom: -60px;
}
.con_ab_img2 {
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    text-align: right;
    bottom: -300px;
    width: 100%;
    max-width: 1600px;
}
.con_ab_img2 img {
    max-width: 430px;
}
/********************/
.bg_fafa_img {
    background: url("../images/concept_bg.jpg") left 0/880px 623px repeat;
}
.radius_right_top {
    border-top-right-radius: 120px;
}
.radius_left_bottom {
    border-bottom-left-radius: 120px;
}
.concept_flex {
    display: flex;
    justify-content: space-between;
    position: relative;
}
.concept_flex.right_style .concept_left {
    justify-content: flex-start;
    position: absolute;
    right: 0;
    left: auto;
}
.concept_flex.right_style .concept_right {
    border-radius: 0 80px 80px 0;
    margin-left: 0;
}
.concept_left {
    width: 27%;
    display: flex;
    justify-content: flex-end;
    position: absolute;
    top: 0;
    left: 0;
}
.concept_title .font2 {
    width: 108px;
    height: 108px;
    background-color: #2e9568;
    color: #FFF;
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 48px;
    border-radius: 20px;
}
.concept_title h3 {
    font-family: "JPOM00H_ver";
    writing-mode: vertical-rl;
    text-orientation: upright;
    font-size: 42px;
    line-height: 1.5em;
    padding: 20px 0;
    position: relative;
    width: 108px;
    display: flex;
    align-items: center;
    white-space: nowrap;
}
.concept_right {
    width: 66%;
    height: 580px;
    border-radius: 80px 0 0 80px;
    margin-left: auto;
    padding-right: 14px;
}
.concept_bg1 {
    background: url("../images/concept5.png") 50% 0/cover no-repeat;
}
.w960_right {
    width: 66%;
    margin-left: auto;
}
.concept_bg2 {
    background: url("../images/concept6.png") 50% 0/cover no-repeat;
}
.concept_bg3 {
    background: url("../images/concept7.png") 50% 0/cover no-repeat;
}
.concept_bg4 {
    background: url("../images/concept8.png") 50% 0/cover no-repeat;
}
/***********************/
.under_flex {
    display: flex;
    justify-content: space-between;
}
.under_flex > div {
    width: 48%;
    position: relative;
    border-radius: 50px;
    overflow: hidden;
}
.under_flex > div:after {
    content: "";
    background-color: rgba(0, 0, 0, 0.5);
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    transition: 0.5s ease;
}
.under_flex > div:hover:after {
    opacity: 0;
}
.under_flex a {
    color: #FFF;
    position: relative;
    z-index: 500;
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;
    height: 320px;
}
.under_flex .shape {
    position: absolute;
    right: 25px;
    bottom: 25px;
}
.under_flex h3 {
    font-size: 30px;
    font-weight: bold;
}
.under_bg1 {
    background: url("../images/concept9.png") 55% 0/cover no-repeat;
}
.under_bg2 {
    background: url("../images/concept10.png") 50% 0/cover no-repeat;
}
/*******************************************************************

    家づくりの流れ

*******************************************************************/
.flow_main {
    background: url("../images/flow1.jpg") 50% 0/cover no-repeat;
}
/*******************/
.flow_flex {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    width: 100%;
    max-width: 1100px;
    margin: 0 auto;
}
.flow_flex > div {
    width: calc(25% - 60px);
    position: relative;
    margin: 30px 30px;
    text-align: center;
}
.flow_flex > div:nth-child(1) .max_img100:before {
    display: none;
}
.flow_flex .max_img100 {
    position: relative;
}
.flow_flex .max_img100:before {
    content: "";
    background: url("../images/flow3.jpg") 50% 0/20px 16px no-repeat;
    width: 120px;
    height: 16px;
    position: absolute;
    left: -90px;
    top: 50%;
    transform: translateY(-50%);
}
.flow_flex p {
    margin-top: 20px;
    font-weight: bold;
    font-size: 20px;
    line-height: 1.2em;
}
.flow_flex p span {
    font-size: 15px;
}
.flow_bg {
    background: url("../images/flow10.jpg") 50% 0/cover no-repeat;
    height: 700px;
    border-radius: 0 100px 0 100px;
}
/***********************/
.orange_f39801 {
    color: #f39801;
}
.green_adbc32 {
    color: #adbc32;
}
.title_30 {
    font-size: 30px;
}
.flow_flex2 {
    background-image: linear-gradient(to right, #2e9568, #2e9568 2px, transparent 2px, transparent 8px);
    /* 幅2の線を作る */
    background-size: 8px 2px;
    /* グラデーションの幅・高さを指定 */
    background-position: left top;
    /* 背景の開始位置を指定 */
    background-repeat: repeat-x;
    /* 横向きにのみ繰り返す */
}
.flow_flex2 > div {
    display: flex;
    justify-content: space-between;
    padding: 80px 0;
    background-image: linear-gradient(to right, #2e9568, #2e9568 2px, transparent 2px, transparent 8px);
    /* 幅2の線を作る */
    background-size: 8px 2px;
    /* グラデーションの幅・高さを指定 */
    background-position: left bottom;
    /* 背景の開始位置を指定 */
    background-repeat: repeat-x;
    /* 横向きにのみ繰り返す */
}
.flow_left {
    max-width: 430px;
    width: 38%;
}
.flow_right {
    width: 60%;
}
.flow_right h3 {
    margin: 20px 0 10px;
}
.point {
    color: #2e9568;
    font-size: 18px;
    letter-spacing: 0.12em;
}
.point span {
    font-size: 30px;
    padding-left: 10px;
}
.point:after {
    content: "";
    border-bottom: 1px solid #2e9568;
    width: 25px;
    display: block;
    margin-top: 5px;
}
/********************/
.flow_list {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    column-gap: 110px;
    row-gap: 60px;
    padding-right: 110px;
    max-width: 1210px;
    margin-left: auto;
    margin-right: auto;
}
.flow_list > div {
    position: relative;
}
.flow_list > div:last-child .img100:after {
    display: none;
}
.flow_list h3 {
    text-align: center;
    font-size: 20px;
    letter-spacing: 0;
    line-height: 1.3em;
    margin-top: 20px;
    font-weight: bold;
}
.flow_list .img100 {
    position: relative;
}
.flow_list .img100:after {
    content: "";
    background: url("../images/flow15.jpg") 50% 0/28px 22px no-repeat;
    width: 110px;
    height: 22px;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    right: -110px;
    text-align: center;
}
.flow_num {
    font-size: 35px;
    color: #2e9568;
    position: absolute;
    left: 15px;
    top: -25px;
    text-shadow: -1px -1px 0 #FFF, 1px -1px 0 #FFF, -1px 1px 0 #FFF, 1px 1px 0 #FFF;
    z-index: 500;
}
.grid3 {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    column-gap: 60px;
    row-gap: 60px;
}
.grid3 h3 {
    text-align: center;
    margin-bottom: 10px;
    font-size: 20px;
}
/*******************************************************************

    ごあいさつ

*******************************************************************/
.greeting_main {
    background: url("../images/greeting1.jpg") 50% 0/cover no-repeat;
}
/**************/
.title_55 {
    font-size: 55px;
    font-weight: bold;
    line-height: 1.5em;
}
.big_60 {
    font-size: 60px;
}
.name_box {
    display: flex;
    justify-content: flex-end;
    align-items: center;
}
.name_box p {
    font-size: 18px;
    text-align: right;
}
.name_box .name1 {
    font-size: 20px;
}
.name_box .name2 {
    font-size: 28px;
}
.name_box:before {
    content: "";
    border-bottom: 3px solid #2e9568;
    flex-grow: 2;
    margin-right: 30px;
}
/*******************************************************************

    沿革

*******************************************************************/
.history_main {
    background: url("../images/history1.jpg") 80% 0/cover no-repeat;
}
/*******/
.history_table {
    position: relative;
}
.history_table > div {
    display: flex;
    justify-content: space-between;
    font-size: 17px;
    font-weight: bold;
}
.history_table > div:nth-child(n+2) {
    margin-top: 55px;
}
.history_table:after {
    content: "";
    border-left: 1px solid #2e9568;
    width: 1px;
    height: calc(100% - 22px);
    position: absolute;
    left: 185px;
    top: 10px;
}
.his_cell1 {
    width: 190px;
    position: relative;
}
.his_cell1:after {
    content: "";
    background-color: #2e9568;
    width: 9px;
    height: 9px;
    border-radius: 50%;
    position: absolute;
    right: 0;
    top: 10px;
}
.his_cell2 {
    width: calc(100% - 260px);
}
/*******************************************************************

    制震装置MIRAIE

*******************************************************************/
.miraie_main {
    background: url("../images/miraie1.jpg") 50% 0/cover no-repeat;
}
.youtube {
    position: relative;
}
.youtube:before {
    content:"";
    display: block;
    padding-top: 56.25%;
}
.youtube iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}
/***********/
.miraie_af_bg {
    position: relative;
}
.miraie_af_bg:after {
    content: "";
    background-color: #2e9568;
    border-radius: 80px 0 0 80px;
    width: calc(100% - 20px);
    max-width: 1840px;
    position: absolute;
    right: 0;
    top: 0;
    height: calc(100% - 120px);
}
.flex_center {
    display: flex;
    justify-content: center;
}
.padding60_20 {
    padding: 60px 20px;
}
/*************/
.miraie_flex {
    display: flex;
    justify-content: space-between;
}
.miraie_flex > div {
    position: relative;
    width: calc(50% - 110px);
    border: 2px solid #d2d2d2;
    border-radius: 20px;
    padding: 70px 20px;
}
.miraie_flex > div:nth-child(1):after {
    content: "";
    background: url("../images/miraie5.png") 50% 0/100px 101px no-repeat;
    position: absolute;
    top: 50%;
    right: -220px;
    width: 220px;
    height: 101px;
    transform: translateY(-50%);
}
.miraie_flex .max_img100 {
    text-align: center;
}
.miraie_flex h3 {
    font-size: 25px;
    text-align: center;
    border-radius: 50px;
    margin: 30px 0 20px;
    font-weight: bold;
    line-height: 1.3em;
    padding: 3px 0 0;
}
.miraie_flex > div:nth-child(1) h3 {
    color: #2e9568;
    border: 1px solid #2e9568;
}
.miraie_flex > div:nth-child(2) h3 {
    background-color: #2e9568;
    border: 1px solid #2e9568;
    color: #FFF;
}
.miraie_flex p {
    padding: 0 5px;
}
.miraie_width {
    width: 100%;
    max-width: 350px;
    margin-left: auto;
    margin-right: auto;
}
/*******************/
.miraie_flex2 {
    display: flex;
    justify-content: space-between;
}
.miraie_flex2 > div {
    width: 31.33%;
    max-width: 360px;
    position: relative;
}
.miraie_flex2 .max_img100 {
    border: 2px solid #d2d2d2;
    border-radius: 30px;
    height: 240px;
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;
}
.miraie_flex2 h3 {
    min-height: 120px;
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 23px;
    text-align: center;
    line-height: 1.5em;
}
.miraie_flex2 .mini {
    font-size: 14px;
}
.miraie_num {
    position: absolute;
    left: -15px;
    top: -15px;
    z-index: 500;
}
/**************/
.title_33 {
    font-size: 33px;
}
.mini_17 {
    font-size: 17px;
    position: relative;
    top: -13px;
}
.padding40_20 {
    padding: 40px 20px;
}
.bg_w {
    background-color: #FFF;
}
.padding100_100 {
    padding: 100px;
}
/***************/
.text_23 {
    font-size: 23px;
}
.span_17 {
    font-size: 17px;
    position: relative;
    top: -15px;
}
/**************/
.span_13 {
    font-size: 13px;
    position: relative;
    top: -5px;
}
.text_13 {
    font-size: 13px;
}
.line_height15 {
    line-height: 1.5em;
}
/*******************************************************************

    モデルハウス

*******************************************************************/
.model_main {
    background: url("../images/model1.jpg") 50% 0/cover no-repeat;
}
/**詳細***************/
.view_main {
    padding: 80px 0 150px;
}
.view_main h2 {
    font-size: 50px;
    letter-spacing: 0.03em;
    line-height: 1.3em;
}
.view_main .eng_16 {
    font-size: 20px;
}
.slider1 {
    text-align: center;
}
.slider1 li {
    padding: 0 140px;
    margin: 0;
}
.slider1 img {
    width: 100%;
    height: auto;
}
.slider2 {
    display: grid;
    grid-template-columns: repeat(10, 1fr);
    column-gap: 20px;
    row-gap: 20px;
    margin-top: 40px;
}
.slider2 img {
    width: 100%;
    height: auto;
}
.slider2 li {
    padding: 0;
    margin: 0;
    cursor: pointer;
    overflow: hidden;
    border-radius: 25px;
    transition: 0.3s ease;
    position: relative;
}
.slider2 li.thumbnail-current:after {
    content: "";
    border: 2px solid #2e9568;
    position: absolute;
    top: 0;
    left: 0;
    border-radius: 25px;
    width: 100%;
    height: 100%;
}
.view_bb {
    padding-bottom: 20px;
    background-image: linear-gradient(to right, #2e9568, #2e9568 2px, transparent 2px, transparent 8px);
    /* 幅2の線を作る */
    background-size: 8px 2px;
    /* グラデーションの幅・高さを指定 */
    background-position: left bottom;
    /* 背景の開始位置を指定 */
    background-repeat: repeat-x;
    /* 横向きにのみ繰り返す */
}
.view_flex > div {
    display: flex;
    justify-content: space-between;
    margin: 25px 0;
    font-size: 18px;
}
.view_cell1 {
    width: 130px;
    background-color: #2e9568;
    color: #FFF;
    text-align: center;
    border-radius: 5px;
    padding-top: 3px;
    line-height: 1.3em;
    display: flex;
    justify-content: center;
    align-items: center;
}
.view_cell2 {
    width: calc(100% - 170px);
}
.more_flex {
    display: flex;
    justify-content: space-between;
}
.more_flex .more {
    width: 47%;
    margin: 0;
    max-width: 600px;
    font-size: 20px;
}
/*******************************************************************

    ZEH

*******************************************************************/
.zeh_main {
    background: url("../images/zeh1.jpg") 50% 0/cover no-repeat;
}
/**************/
.zeh_img {
    text-align: right;
}
.zeh_img img {
    max-width: 100%;
    height: auto;
}
.zeh_title {
    text-align: center;
    position: relative;
    max-width: 1100px;
    margin-left: auto;
    margin-right: auto;
    font-size: 45px;
    letter-spacing: 0.05em;
    padding: 15px 50px;
}
.zeh_title:before, .zeh_title:after {
    content: "";
    position: absolute;
    background: url("../images/zeh4.png") left 0/100% 100% no-repeat;
    width: 45px;
    height: 38px;
}
.zeh_title:before {
    left: 0;
    top: 0;
}
.zeh_title:after {
    right: 0;
    bottom: 0;
    transform: scale(-1, -1);
}
.span_50 {
    font-size: 50px;
}
.blue_6ec4cc {
    color: #6ec4cc;
}
/********************/
.zeh_grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    column-gap: 70px;
    row-gap: 70px;
}
.zeh_grid > div {
    background-color: #FFF;
    padding: 40px 20px;
    border-radius: 30px;
}
.zeh_grid > div:nth-child(1) {
    border: 2px solid #f39801;
}
.zeh_grid > div:nth-child(1) h3 {
    color: #f39801;
}
.zeh_grid > div:nth-child(2) {
    border: 2px solid #adbc32;
}
.zeh_grid > div:nth-child(2) h3 {
    color: #adbc32;
}
.zeh_grid > div:nth-child(3) {
    border: 2px solid #6ec4cc;
}
.zeh_grid > div:nth-child(3) h3 {
    color: #6ec4cc;
}
.zeh_grid h3 {
    font-size: 30px;
    text-align: center;
    margin: 10px 0 20px;
}
.zeh_grid p {
    font-size: 15px;
    text-align: center;
}
.zeh_icon {
    text-align: center;
    height: 75px;
    display: flex;
    justify-content: center;
    align-items: center;
}
.zeh_bg {
    background-color: #2e9568;
    padding: 40px;
    border-radius: 200px;
    color: #FFF;
}
.w860_auto {
    max-width: 860px;
    margin-left: auto;
    margin-right: auto;
}
.check_list li {
    margin: 5px 0;
    position: relative;
    font-size: 25px;
    padding-left: 30px;
}
.check_list img {
    position: absolute;
    left: 0;
    top: 12px;
}
/****************/
.zeh_grid2 {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    column-gap: 30px;
    row-gap: 30px;
}
.zeh_grid2 > div {
    background-color: #FFF;
    border-radius: 30px;
    padding: 60px 40px;
    display: flex;
    justify-content: space-between;
    align-items: center;
}
.zeh_left {
    width: 117px;
}
.zeh_right {
    width: calc(100% - 150px);
}
/***********************************/
.zeh_table table {
    width: 100%;
}
.zeh_table th {
    width: 300px;
}
.zeh_table th, .zeh_table td {
    padding: 23px 0;
    font-weight: bold;
    line-height: 1.5em;
    text-align: center;
}
.zeh_table td {
    border: 1px solid #eeeeee;
}
.zeh_table tr:nth-child(1) td {
    background-color: #2e9568;
    color: #FFF;
    font-size: 15px;
    letter-spacing: 0;
    border-right: 1px solid #eeeeee;
    text-align: center;
}
.zeh_table tr:nth-child(1) td:nth-child(2) {
    border-radius: 10px 0 0 0;
}
.zeh_table tr:nth-child(1) td:last-child {
    border-radius: 0 10px 0 0;
    border-right: 0;
}
.zeh_table tr:nth-child(n+2) th {
    background-color: #2e9568;
    color: #FFF;
    text-align: center;
    border-bottom: 1px solid #eeeeee;
}
.zeh_table tr:nth-child(n+2) td {
    font-size: 20px;
}
.zeh_table tr:nth-child(2) th {
    border-radius: 10px 0 0 0;
}
.zeh_table tr:last-child th {
    border-radius: 0 0 0 10px;
}
/*******************************************************************

    標準仕様

*******************************************************************/
.iproud_main {
    background: url("../images/ip1.jpg") 50% 0/cover no-repeat;
}
/*************/
.title_40 {
    font-size: 40px;
}
.ip_border_title {
    background: url("../images/ip_border.png") 50% 0/100% 100% no-repeat;
    width: 100%;
    height: 113px;
    padding-top: 15px;
}
.red_e21422 {
    color: #e21422;
}
.text_18 {
    font-size: 18px;
}
/****************/
.ip_border {
    border: 3px solid #2e9568;
    border-radius: 30px;
    padding: 60px 20px;
}
/*******************/
.tab_bg {
    background-color: #f5f5f5;
    padding: 80px 0;
}
.tab ul, .tab2 ul {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    column-gap: 20px;
    row-gap: 20px;
}
.tab a, .tab2 a {
    color: #62584e;
    border: 2px solid #62584e;
    display: block;
    padding: 20px 5px;
    text-align: center;
    font-size: 23px;
    border-radius: 10px;
    transition: 0.5s ease;
}
.tab a:hover, .tab2 a:hover {
    background-color: #62584e;
    color: #FFF;
}
.tab .active a, .tab2 .active a {
    background-color: #62584e;
    color: #FFF;
}
.af_bb:after {
    content: "";
    display: block;
    border-bottom: 3px solid #2e9568;
    width: 60px;
    margin: 10px auto 0;
}
.sp_pdf {
    display: none;
}
.tab_mt {
    margin-top: 80px;
}
/*******************************************************************

    会社概要

*******************************************************************/
.company_main {
    background: url("../images/company_top1.jpg") 50% 0/cover no-repeat;
}
/****************/
.com_left {
    position: absolute;
    left: 0;
    top: 0;
    writing-mode: vertical-rl;
    max-width: 575px;
    width: 36%;
}
.com_title {
    font-size: 45px;
    white-space: nowrap;
    line-height: 2.2em;
}
.com_title span {
    font-size: 50px;
}
.com_right {
    width: 62%;
    margin-left: auto;
    padding-top: 100px;
}
.com_right p {
    padding-right: 14px;
}
.com_bg {
    background: url("../images/company_top2.jpg") 60% 0/cover no-repeat;
    height: 510px;
    max-width: 1180px;
    border-radius: 80px 0 0 80px;
}
/********************/
.com_flex {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
}
.com_flex > div {
    max-width: 480px;
    width: 48%;
    position: relative;
}
.com_flex > div:nth-child(n+3) {
    margin-top: 70px;
}
.com_flex a {
    color: inherit;
}
.com_flex a:hover .com_off {
    opacity: 0;
}
.com_flex a:hover .com_on {
    opacity: 1;
}
.com_flex h3 {
    letter-spacing: 0.05em;
}
.com_shape {
    position: absolute;
    right: 20px;
    bottom: 10px;
}
.com_shape img {
    transition: 0.5s ease;
}
.com_shape .com_on {
    position: absolute;
    right: 0;
    top: 0;
    opacity: 0;
}
/*******************************************************************

    会社概要

*******************************************************************/
.profile_main {
    background: url("../images/company1.jpg") 50% 0/cover no-repeat;
}
.pro_table {
    position: relative;
}
.pro_table > div {
    display: flex;
    justify-content: space-between;
    font-size: 18px;
    position: relative;
}
.pro_table > div:after {
    content: "";
    background-image: linear-gradient(to right, #62584e, #62584e 2px, transparent 2px, transparent 8px);
    /* 幅2の線を作る */
    background-size: 8px 2px;
    /* グラデーションの幅・高さを指定 */
    background-position: left bottom;
    /* 背景の開始位置を指定 */
    background-repeat: repeat-x;
    /* 横向きにのみ繰り返す */
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 2px;
}
.pro_table:before {
    content: "";
    background-image: linear-gradient(to right, #62584e, #62584e 2px, transparent 2px, transparent 8px);
    /* 幅2の線を作る */
    background-size: 8px 2px;
    /* グラデーションの幅・高さを指定 */
    background-position: left top;
    /* 背景の開始位置を指定 */
    background-repeat: repeat-x;
    /* 横向きにのみ繰り返す */
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 2px;
    z-index: 500;
}
.pro_cell1 {
    padding: 40px 30px;
    width: 250px;
    background-color: #dcede6;
}
.pro_cell2 {
    width: calc(100% - 250px);
    padding: 40px 20px 40px 70px;
}
.map iframe {
    width: 100%;
    height: 650px;
}
/*******************************************************************

    資料請求・お問い合わせ

*******************************************************************/
.contact_border {
    border: 2px solid #2e9568;
    border-radius: 30px;
    padding: 40px;
    text-align: center;
    max-width: 830px;
    margin-left: auto;
    margin-right: auto;
}
.title_22 {
    font-size: 22px;
}
.c_tel {
    font-size: 38px;
    line-height: 1.3em;
    margin: 10px 0 0;
}
.c_tel img {
    position: relative;
    margin-right: 10px;
    top: -3px;
}
.contact_form {
    border-bottom: 2px solid #d9d8d7;
    padding-bottom: 60px;
}
.contact_form > div {
    display: flex;
    justify-content: space-between;
    margin: 40px 0;
    font-size: 15px;
}
.c_cell1 {
    width: 320px;
    padding-top: 12px;
    position: relative;
}
.hissu {
    background-color: #f39801;
    padding: 0 15px;
    border-radius: 50px;
    color: #FFF;
    font-size: 14px;
    position: absolute;
    right: 0;
    top: 10px;
}
.c_cell2 {
    width: calc(100% - 340px);
}
.size, .area {
    padding: 10px 25px;
    width: 100%;
    background-color: #f5f5f5;
    border: 0;
    border-radius: 5px;
}
.size {
    height: 55px;
}
.half_size .size {
    max-width: 330px;
}
.area {
    height: 250px;
}
.postal_flex {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    max-width: 330px;
}
.postal_cell1 {
    width: 20px;
}
.postal_cell2 {
    margin: 0 10px 0;
    flex-grow: 2;
    width: calc(100% - 155px);
}
.postal_cell3 {
    width: 115px !important;
}
.postal_cell3 span {
    background-color: #62584e;
    color: #FFF;
    font-size: 14px;
    border-radius: 50px;
    text-align: center;
    display: block;
    padding: 5px 0;
    font-weight: normal;
}
.label_flex {
    display: flex;
    flex-wrap: wrap;
    margin-top: 3px;
    max-width: 800px;
}
.label_flex input[type=radio] {
    position: relative;
    left: -10px;
}
.label_flex .wpcf7-list-item {
    display: inline-block;
    margin-right: 25px;
    padding-left: 10px;
    margin-top: 10px;
}
.day_table {
    display: flex;
    align-items: center;
    justify-content: space-between;
    max-width: 370px;
}
.day_cell1 {
    width: 70px;
}
.day_cell2 {
    width: calc(100% - 70px);
}
.calendar_icon {
    position: absolute;
    right: 10px;
    top: 50%;
    transform: translateY(-50%);
}
.border_337ab7 {
    border-bottom: 1px solid #337ab7;
}

/************/
.indent_p {
    text-indent: -1em;
    padding-left: 1em;
}
.a_bb a {
    color: #2e9568;
    border-bottom: 1px solid #2e9568;
}
.submit {
    width: 100%;
    max-width: 470px;
    margin-left: auto;
    margin-right: auto;
    position: relative;
    transition: 0.5s ease;
    background-color: #101111;
    border-radius: 5px;
}
.submit input {
    display: block;
    width: 100%;
    text-align: center;
    padding: 25px;
    color: #FFF;
    font-size: 20px;
    border: 0;
    position: relative;
    z-index: 500;
    background: none;
}
.submit .c_shape {
    position: absolute;
    right: 20px;
    top: 50%;
    transform: translateY(-50%);
}
.submit:hover {
    background-color: #2e9568;
}
/*******************************************************************

    来場予約

*******************************************************************/
.border_color_black.be_af_border:before, .border_color_black.be_af_border:after {
    border-color: #101111;
}
.zeh_bg.bg_w {
    background-color: #FFF;
}
.re_inline_block {
    font-size: 19px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    max-width: 680px;
    margin: 0 auto;
}
.re_inline_block span {
    display: block;
}
.re_inline_block span:nth-child(1) {
    width: 300px;
}
.re_inline_block span:nth-child(2) {
    width: 20px;
}
.re_inline_block span:nth-child(3) {
    width: calc(100% - 380px);
}
/**********/
.day_flex {
    display: flex;
    justify-content: space-between;
    max-width: 790px;
}
.day_left {
    width: 49%;
}
.day_right {
    width: 49%;
}
.re_size {
    max-width: 180px;
    position: relative;
}
.re_size .size {
    width: calc(100% - 30px);
}
.re_span {
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
}
/*******************************************************************

    プライバシーポリシー

*******************************************************************/
.pri_title {
    position: relative;
    font-size: 25px;
    letter-spacing: 0.05em;
    padding-left: 60px;
}
.pri_title .font2 {
    font-size: 18px;
    display: flex;
    justify-content: center;
    align-items: center;
    background-color: #2e9568;
    border-radius: 50%;
    width: 40px;
    height: 40px;
    position: absolute;
    left: 0;
    top: 0;
    padding-left: 1px;
    padding-bottom: 1px;
    color: #FFF;
}
.pri_pl {
    padding-left: 16px;
}
.pri_link {
    width: 100%;
    max-width: 370px;
    position: relative;
    background-color: #FFF;
}
.pri_link a {
    border: 2px solid #101111;
    border-radius: 5px;
    display: block;
    margin: 0 auto;
    padding: 25px 10px 25px 20px;
    letter-spacing: 0.05em;
    position: relative;
    color: inherit;
    text-align: center;
    transition: 0.5s ease;
    z-index: 500;
}
.pri_link:after {
    content: "";
    background-color: #101111;
    position: absolute;
    top: 0;
    right: 0;
    width: 0;
    height: 100%;
    transition: 0.5s ease;
    border-radius: 5px;
}
.pri_link:hover a {
    color: #FFF;
}
.pri_link:hover:after {
    width: 100%;
    left: 0;
}
.pri_link:hover img {
    filter: invert(100%);
}
.pri_link img {
    transition: 0.5s ease;
}
.pri_mail {
    position: absolute;
    top: calc(50% - 2px);
    transform: translateY(-50%);
    left: 45px;
}
.pri_shape {
    position: absolute;
    top: calc(50% - 2px);
    transform: translateY(-50%);
    right: 30px;
}
/*******************************************************************

    施工事例

*******************************************************************/
.works_main {
    background: url("../images/case1.jpg") 50% 0/cover no-repeat;
}
/**********************/
.works_flex {
    display: flex;
    justify-content: space-between;
}
.works_left {
    width: calc(100% - 320px);
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
}
.works_left > div {
    width: 48%;
}
.works_left > div:nth-child(n+3) {
    margin-top: 80px;
}
.works_left > div .img100 {
    border-radius: 55px;
    overflow: hidden;
}
.works_left p {
    font-size: 18px;
    margin-top: 15px;
}
.title_23 {
    font-size: 23px;
}
.works_right {
    width: 220px;
}
.title_23 {
    font-size: 23px;
}
.cate_bb {
    border-bottom: 1px solid #76706a;
    padding-bottom: 20px;
    margin-bottom: 40px;
}
.cate_list li {
    margin: 15px 0;
}
.cate_list a {
    color: inherit;
}
.cate_list span {
    color: #2e9568;
    margin-right: 15px;
}
/*******************************************************************

    お知らせ

*******************************************************************/
.news_tab {
    background-color: #f5f5f5;
    padding: 15px;
    display: flex;
    justify-content: space-between;
    border-radius: 50px;
    width: 100%;
    max-width: 370px;
    margin: 0 auto;
}
.news_tab > p {
    width: 32.33%;
}
.news_tab > p a {
    display: block;
    color: #2e9568;
    border-radius: 50px;
    padding: 5px 0 2px;
    text-align: center;
    transition: 0.5s ease;
}
.news_tab > p a:hover {
    background-color: #2e9568;
    color: #FFF;
}
/***************/
.b_time_in {
    color: #adbc32;
    font-size: 14px;
    margin-top: 15px;
}
.b_title {
    font-size: 16px;
    line-height: 1.6em;
    margin-top: 5px;
}
/*******************************************************************

    アイビーホームの家作り

*******************************************************************/
.commit_main {
    background: url("../images/commit1.jpg") 50% 0/cover no-repeat;
}
/*******************/
.commit_width {
    width: calc(100% - 20px);
    max-width: 1600px;
    margin-left: auto;
}
.commit_bg {
    background: url("../images/commit2.jpg") 100% 0/cover no-repeat;
    border-radius: 100px 0 0 100px;
    height: 660px;
    width: calc(100% + 320px);
}
.commit_title {
    background-color: #FFF;
    display: inline-block;
    padding: 50px 20px 0 0;
    border-radius: 0 20px 0 0;
    margin-top: -100px;
    font-size: 45px;
}
.commit_title span {
    font-size: 50px;
}
.commit_grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    column-gap: 80px;
    row-gap: 120px;
}
.commit_grid > div {
    position: relative;
}
.commit_grid h3 {
    margin: 25px 0 25px;
    text-align: center;
    font-size: 30px;
    letter-spacing: 0.03em;
}
.commit_grid h3:after {
    content: "";
    border-bottom: 2px solid #2e9568;
    width: 30px;
    margin: 2px auto 0;
    display: block;
}
.commit_grid .more {
    margin-top: 40px;
    background-color: #FFF;
}
.commit_grid .more:after {
    background-color: #2e9568;
}
.commit_grid .more a {
    border: 2px solid #2e9568;
    color: #2e9568;
}
.commit_grid .more a:hover {
    color: #FFF;
}
.commit_text {
    font-size: 15px;
}
/* PC用
------------------------------------------------------------*/

@media only screen and (max-width: 1500px) {
.side_bar > div {
    padding: 20px 0;
    font-size: 14px;
}
}
@media only screen and (max-width: 1300px) {
    /************************/
    .cy_nav ul {
        max-width: 800px;
    }
    .cy_nav a {
        font-size: 14px;
    }
    /****************/
    .ver_title {
        top: -500px;
    }
}
@media only screen and (max-width: 1024px) {
    .padding100 {
        padding-top: 120px;
        padding-bottom: 120px;
    }
    .padding110 {
        padding-top: 120px;
        padding-bottom: 120px;
    }
    .padding120 {
        padding-top: 120px;
        padding-bottom: 120px;
    }
    .padding130 {
        padding-top: 120px;
        padding-bottom: 120px;
    }
    .padding140 {
        padding-top: 120px;
        padding-bottom: 120px;
    }
    .padding150 {
        padding-top: 120px;
        padding-bottom: 120px;
    }
    .padding160 {
        padding-top: 120px;
        padding-bottom: 120px;
    }
    .padding170 {
        padding-top: 120px;
        padding-bottom: 120px;
    }
    .padding180 {
        padding-top: 120px;
        padding-bottom: 120px;
    }
    .padding190 {
        padding-top: 120px;
        padding-bottom: 120px;
    }
    .padding200 {
        padding-top: 120px;
        padding-bottom: 120px;
    }
    .padding210 {
        padding-top: 120px;
        padding-bottom: 120px;
    }
    .padding220 {
        padding-top: 120px;
        padding-bottom: 120px;
    }
    .padding230 {
        padding-top: 120px;
        padding-bottom: 120px;
    }
    .padding240 {
        padding-top: 120px;
        padding-bottom: 120px;
    }
    .padding250 {
        padding-top: 120px;
        padding-bottom: 120px;
    }
    .padding260 {
        padding-top: 120px;
        padding-bottom: 120px;
    }
    .padding270 {
        padding-top: 120px;
        padding-bottom: 120px;
    }
    .padding280 {
        padding-top: 120px;
        padding-bottom: 120px;
    }
    .padding290 {
        padding-top: 120px;
        padding-bottom: 120px;
    }
    .padding300 {
        padding-top: 120px;
        padding-bottom: 120px;
    }
    .margin100 {
        margin-top: 120px;
        margin-bottom: 120px;
    }
    .margin110 {
        margin-top: 120px;
        margin-bottom: 120px;
    }
    .margin120 {
        margin-top: 120px;
        margin-bottom: 120px;
    }
    .margin130 {
        margin-top: 120px;
        margin-bottom: 120px;
    }
    .margin140 {
        margin-top: 120px;
        margin-bottom: 120px;
    }
    .margin150 {
        margin-top: 120px;
        margin-bottom: 120px;
    }
    .margin160 {
        margin-top: 120px;
        margin-bottom: 120px;
    }
    .margin170 {
        margin-top: 120px;
        margin-bottom: 120px;
    }
    .margin180 {
        margin-top: 120px;
        margin-bottom: 120px;
    }
    .margin190 {
        margin-top: 120px;
        margin-bottom: 120px;
    }
    .margin200 {
        margin-top: 120px;
        margin-bottom: 120px;
    }
    .margin210 {
        margin-top: 120px;
        margin-bottom: 120px;
    }
    .margin220 {
        margin-top: 120px;
        margin-bottom: 120px;
    }
    .margin230 {
        margin-top: 120px;
        margin-bottom: 120px;
    }
    .margin240 {
        margin-top: 120px;
        margin-bottom: 120px;
    }
    .margin250 {
        margin-top: 120px;
        margin-bottom: 120px;
    }
    .margin260 {
        margin-top: 120px;
        margin-bottom: 120px;
    }
    .margin270 {
        margin-top: 120px;
        margin-bottom: 120px;
    }
    .margin280 {
        margin-top: 120px;
        margin-bottom: 120px;
    }
    .margin290 {
        margin-top: 120px;
        margin-bottom: 120px;
    }
    .margin300 {
        margin-top: 120px;
        margin-bottom: 120px;
    }
    .pt-120 {
        padding-top: 120px;
    }
    .pt-130 {
        padding-top: 120px;
    }
    .pt-140 {
        padding-top: 120px;
    }
    .pt-150 {
        padding-top: 120px;
    }
    .pt-160 {
        padding-top: 120px;
    }
    .pt-170 {
        padding-top: 120px;
    }
    .pt-180 {
        padding-top: 120px;
    }
    .pt-190 {
        padding-top: 120px;
    }
    .pt-200 {
        padding-top: 120px;
    }
    .pt-210 {
        padding-top: 120px;
    }
    .pt-220 {
        padding-top: 120px;
    }
    .pt-230 {
        padding-top: 120px;
    }
    .pt-240 {
        padding-top: 120px;
    }
    .pt-250 {
        padding-top: 120px;
    }
    .pt-260 {
        padding-top: 120px;
    }
    .pt-270 {
        padding-top: 120px;
    }
    .pt-280 {
        padding-top: 120px;
    }
    .pt-290 {
        padding-top: 120px;
    }
    .pt-300 {
        padding-top: 120px;
    }
    .pb-120 {
        padding-bottom: 120px;
    }
    .pb-130 {
        padding-bottom: 120px;
    }
    .pb-140 {
        padding-bottom: 120px;
    }
    .pb-150 {
        padding-bottom: 120px;
    }
    .pb-160 {
        padding-bottom: 120px;
    }
    .pb-170 {
        padding-bottom: 120px;
    }
    .pb-180 {
        padding-bottom: 120px;
    }
    .pb-190 {
        padding-bottom: 120px;
    }
    .pb-200 {
        padding-bottom: 120px;
    }
    .pb-210 {
        padding-bottom: 120px;
    }
    .pb-220 {
        padding-bottom: 120px;
    }
    .pb-230 {
        padding-bottom: 120px;
    }
    .pb-240 {
        padding-bottom: 120px;
    }
    .pb-250 {
        padding-bottom: 120px;
    }
    .pb-260 {
        padding-bottom: 120px;
    }
    .pb-270 {
        padding-bottom: 120px;
    }
    .pb-280 {
        padding-bottom: 120px;
    }
    .pb-290 {
        padding-bottom: 120px;
    }
    .pb-300 {
        padding-bottom: 120px;
    }
    .mt-120 {
        margin-top: 120px;
    }
    .mt-130 {
        margin-top: 120px;
    }
    .mt-140 {
        margin-top: 120px;
    }
    .mt-150 {
        margin-top: 120px;
    }
    .mt-160 {
        margin-top: 120px;
    }
    .mt-170 {
        margin-top: 120px;
    }
    .mt-180 {
        margin-top: 120px;
    }
    .mt-190 {
        margin-top: 120px;
    }
    .mt-200 {
        margin-top: 120px;
    }
    .mt-210 {
        margin-top: 120px;
    }
    .mt-220 {
        margin-top: 120px;
    }
    .mt-230 {
        margin-top: 120px;
    }
    .mt-240 {
        margin-top: 120px;
    }
    .mt-250 {
        margin-top: 120px;
    }
    .mt-260 {
        margin-top: 120px;
    }
    .mt-270 {
        margin-top: 120px;
    }
    .mt-280 {
        margin-top: 120px;
    }
    .mt-290 {
        margin-top: 120px;
    }
    .mt-300 {
        margin-top: 120px;
    }
    .mb-120 {
        margin-bottom: 120px;
    }
    .mb-130 {
        margin-bottom: 120px;
    }
    .mb-140 {
        margin-bottom: 120px;
    }
    .mb-150 {
        margin-bottom: 120px;
    }
    .mb-160 {
        margin-bottom: 120px;
    }
    .mb-170 {
        margin-bottom: 120px;
    }
    .mb-180 {
        margin-bottom: 120px;
    }
    .mb-190 {
        margin-bottom: 120px;
    }
    .mb-200 {
        margin-bottom: 120px;
    }
    .mb-210 {
        margin-bottom: 120px;
    }
    .mb-220 {
        margin-bottom: 120px;
    }
    .mb-230 {
        margin-bottom: 120px;
    }
    .mb-240 {
        margin-bottom: 120px;
    }
    .mb-250 {
        margin-bottom: 120px;
    }
    .mb-260 {
        margin-bottom: 120px;
    }
    .mb-270 {
        margin-bottom: 120px;
    }
    .mb-280 {
        margin-bottom: 120px;
    }
    .mb-290 {
        margin-bottom: 120px;
    }
    .mb-300 {
        margin-bottom: 120px;
    }
    .none1024 {
        display: none;
    }
    /************************/
    .cy_header {
        padding: 30px 0;
    }
    .cy_nav {
        display: none;
    }
    /**********/
    .top_main, .flexslider, .flexslider li {
        height: 600px;
        border-radius: 60px;
    }
    .top_title {
        font-size: 40px;
    }
    /*******************/
    .title_38 {
        font-size: 28px;
        font-weight: bold;
    }
    .news {
        column-gap: 20px;
        row-gap: 60px;
    }
    /****************/
    .ver_title {
        top: -350px;
    }
    .title_35 {
        font-size: 26px;
        font-weight: bold;
    }
    .big_40 {
        font-size: 30px;
    }
    .top_banner .banner_title h2 {
        font-size: 30px;
    }
    /************/
    .slider.slider_style {
        width: calc(100% + 200px);
        margin-left: 0;
        padding-left: 10px;
    }
    .slider.slider_style h3 {
        font-size: 18px;
        margin: 15px 0 20px;
    }
    .slider.slider_style p {
        font-size: 15px;
    }
    .slider.slider_style li {
        float: left;
        position: relative;
        z-index: 900;
        padding: 0 20px 0 0;
    }
    .slider.slider_style li img {
        border-radius: 50px;
    }
    .radius40 {
        border-radius: 40px;
        overflow: hidden;
    }
    /************************/
    .f_bg {
        padding: 130px 0;
    }
    .f_flex {
        display: block;
    }
    .f_left {
        width: 100%;
        text-align: center;
    }
    .f_right {
        width: 100%;
        margin-top: 40px;
    }
    .f_links {
        max-width: 340px;
        margin: 0 auto;
    }
    .f_nav {
        justify-content: center;
        max-width: 100%;
        margin-top: 40px;
    }
    /*******************************************************************

    家づくりの想い

*******************************************************************/
    .main_size h2 {
        font-size: 34px;
    }
    /**********************/
    .concept_padding {
        padding: 130px 0 200px;
    }
    .title_45 {
        font-size: 32px;
    }
    .big_50 {
        font-size: 40px;
    }
    .sp_flex {
        display: flex;
        justify-content: space-between;
        margin-top: 50px;
    }
    .sp_flex img {
        width: 100%;
        height: auto;
    }
    .con_ab_img1 {
        position: static;
        width: 48%;
    }
    .con_ab_img2 {
        position: static;
        width: 48%;
        transform: translateX(0);
    }
    .con_ab_img2 img {
        max-width: 100%;
    }
    /********************/
    .concept_title h3 {
        font-size: 34px;
    }
    /*******************************************************************

    家づくりの流れ

*******************************************************************/
    .title_30 {
        font-size: 26px;
    }
    .flow_right {
        width: 57%;
    }
    /********************/
    .flow_list {
        column-gap: 60px;
        padding-right: 60px;
    }
    .flow_list .img100:after {
        width: 60px;
        right: -60px;
    }
    /*******************************************************************

    ごあいさつ

*******************************************************************/
    .title_55 {
        font-size: 35px;
    }
    .big_60 {
        font-size: 45px;
    }
    .padding100_100 {
        padding: 40px;
    }
    /*******************************************************************

    モデルハウス

*******************************************************************/
    .slider2 {
        column-gap: 10px;
        row-gap: 10px;
    }
    .slider2 li {
        border-radius: 10px;
    }
    .slider2 li.thumbnail-current:after {
        border-radius: 10px;
    }
    /*******************************************************************

    ZEH

*******************************************************************/
    .zeh_title {
        font-size: 35px;
    }
    .span_50 {
        font-size: 40px;
    }
    /********************/
    .zeh_grid {
        column-gap: 20px;
        row-gap: 20px;
    }
    .zeh_bg {
        padding: 40px;
        border-radius: 50px;
    }
    /****************/
    .ip_border_title {
        height: 85px;
        padding-top: 15px;
    }
    /*******************************************************************

    会社概要

*******************************************************************/
    .com_left {
        position: absolute;
        left: 0;
        top: 0;
        writing-mode: vertical-rl;
        max-width: 575px;
        width: 30%;
    }
    .com_title {
        font-size: 36px;
        white-space: nowrap;
        line-height: 2.2em;
    }
    .com_title span {
        font-size: 50px;
    }
    .com_right {
        width: 66%;
        margin-left: auto;
        padding-top: 0;
    }
    .com_bg {
        background: url("../images/company_top2.jpg") 60% 0/cover no-repeat;
        height: 510px;
        max-width: 1180px;
        border-radius: 80px 0 0 80px;
    }
    /*******************************************************************

    施工事例

*******************************************************************/
    .works_flex {
        display: block;
    }
    .works_left {
        width: 100%;
    }
    .works_right {
        width: 100%;
        margin-top: 80px;
    }
    /*******************************************************************

    アイビーホームの家作り

*******************************************************************/
    .commit_bg {
        background: url("../images/commit2.jpg") 100% 0/cover no-repeat;
        border-radius: 100px 0 0 100px;
        height: 450px;
        width: calc(100% + 40px);
    }
    .commit_title {
        font-size: 30px;
    }
    .commit_title span {
        font-size: 35px;
    }
    .commit_grid {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        column-gap: 40px;
        row-gap: 60px;
    }
    .commit_grid h3 {
        font-size: 24px;
    }
}
@media only screen and (max-width: 740px) {
    .flex_30 {
        width: 100%;
    }
    .flex_31 {
        width: 100%;
    }
    .flex_32 {
        width: 100%;
    }
    .flex_33 {
        width: 100%;
    }
    .flex_34 {
        width: 100%;
    }
    .flex_35 {
        width: 100%;
    }
    .flex_36 {
        width: 100%;
    }
    .flex_37 {
        width: 100%;
    }
    .flex_38 {
        width: 100%;
    }
    .flex_39 {
        width: 100%;
    }
    .flex_40 {
        width: 100%;
    }
    .flex_41 {
        width: 100%;
    }
    .flex_42 {
        width: 100%;
    }
    .flex_43 {
        width: 100%;
    }
    .flex_44 {
        width: 100%;
    }
    .flex_45 {
        width: 100%;
    }
    .flex_46 {
        width: 100%;
    }
    .flex_47 {
        width: 100%;
    }
    .flex_48 {
        width: 100%;
    }
    .flex_49 {
        width: 100%;
    }
    .flex_50 {
        width: 100%;
    }
    .flex_51 {
        width: 100%;
    }
    .flex_52 {
        width: 100%;
    }
    .flex_53 {
        width: 100%;
    }
    .flex_54 {
        width: 100%;
    }
    .flex_55 {
        width: 100%;
    }
    .flex_56 {
        width: 100%;
    }
    .flex_57 {
        width: 100%;
    }
    .flex_58 {
        width: 100%;
    }
    .flex_59 {
        width: 100%;
    }
    .flex_60 {
        width: 100%;
    }
    .flex_61 {
        width: 100%;
    }
    .flex_62 {
        width: 100%;
    }
    .flex_63 {
        width: 100%;
    }
    .flex_64 {
        width: 100%;
    }
    .flex_65 {
        width: 100%;
    }
    .flex_66 {
        width: 100%;
    }
    .flex_67 {
        width: 100%;
    }
    .flex_68 {
        width: 100%;
    }
    .flex_69 {
        width: 100%;
    }
    .flex_70 {
        width: 100%;
    }
    .padding100 {
        padding-top: 80px;
        padding-bottom: 80px;
    }
    .padding110 {
        padding-top: 80px;
        padding-bottom: 80px;
    }
    .padding120 {
        padding-top: 80px;
        padding-bottom: 80px;
    }
    .padding130 {
        padding-top: 80px;
        padding-bottom: 80px;
    }
    .padding140 {
        padding-top: 80px;
        padding-bottom: 80px;
    }
    .padding150 {
        padding-top: 80px;
        padding-bottom: 80px;
    }
    .padding160 {
        padding-top: 80px;
        padding-bottom: 80px;
    }
    .padding170 {
        padding-top: 80px;
        padding-bottom: 80px;
    }
    .padding180 {
        padding-top: 80px;
        padding-bottom: 80px;
    }
    .padding190 {
        padding-top: 80px;
        padding-bottom: 80px;
    }
    .padding200 {
        padding-top: 80px;
        padding-bottom: 80px;
    }
    .padding210 {
        padding-top: 80px;
        padding-bottom: 80px;
    }
    .padding220 {
        padding-top: 80px;
        padding-bottom: 80px;
    }
    .padding230 {
        padding-top: 80px;
        padding-bottom: 80px;
    }
    .padding240 {
        padding-top: 80px;
        padding-bottom: 80px;
    }
    .padding250 {
        padding-top: 80px;
        padding-bottom: 80px;
    }
    .padding260 {
        padding-top: 80px;
        padding-bottom: 80px;
    }
    .padding270 {
        padding-top: 80px;
        padding-bottom: 80px;
    }
    .padding280 {
        padding-top: 80px;
        padding-bottom: 80px;
    }
    .padding290 {
        padding-top: 80px;
        padding-bottom: 80px;
    }
    .padding300 {
        padding-top: 80px;
        padding-bottom: 80px;
    }
    .margin100 {
        margin-top: 80px;
        margin-bottom: 80px;
    }
    .margin110 {
        margin-top: 80px;
        margin-bottom: 80px;
    }
    .margin120 {
        margin-top: 80px;
        margin-bottom: 80px;
    }
    .margin130 {
        margin-top: 80px;
        margin-bottom: 80px;
    }
    .margin140 {
        margin-top: 80px;
        margin-bottom: 80px;
    }
    .margin150 {
        margin-top: 80px;
        margin-bottom: 80px;
    }
    .margin160 {
        margin-top: 80px;
        margin-bottom: 80px;
    }
    .margin170 {
        margin-top: 80px;
        margin-bottom: 80px;
    }
    .margin180 {
        margin-top: 80px;
        margin-bottom: 80px;
    }
    .margin190 {
        margin-top: 80px;
        margin-bottom: 80px;
    }
    .margin200 {
        margin-top: 80px;
        margin-bottom: 80px;
    }
    .margin210 {
        margin-top: 80px;
        margin-bottom: 80px;
    }
    .margin220 {
        margin-top: 80px;
        margin-bottom: 80px;
    }
    .margin230 {
        margin-top: 80px;
        margin-bottom: 80px;
    }
    .margin240 {
        margin-top: 80px;
        margin-bottom: 80px;
    }
    .margin250 {
        margin-top: 80px;
        margin-bottom: 80px;
    }
    .margin260 {
        margin-top: 80px;
        margin-bottom: 80px;
    }
    .margin270 {
        margin-top: 80px;
        margin-bottom: 80px;
    }
    .margin280 {
        margin-top: 80px;
        margin-bottom: 80px;
    }
    .margin290 {
        margin-top: 80px;
        margin-bottom: 80px;
    }
    .margin300 {
        margin-top: 80px;
        margin-bottom: 80px;
    }
    .pt-110 {
        padding-top: 80px;
    }
    .pt-120 {
        padding-top: 80px;
    }
    .pt-130 {
        padding-top: 80px;
    }
    .pt-140 {
        padding-top: 80px;
    }
    .pt-150 {
        padding-top: 80px;
    }
    .pt-160 {
        padding-top: 80px;
    }
    .pt-170 {
        padding-top: 80px;
    }
    .pt-180 {
        padding-top: 80px;
    }
    .pt-190 {
        padding-top: 80px;
    }
    .pt-200 {
        padding-top: 80px;
    }
    .pt-210 {
        padding-top: 80px;
    }
    .pt-220 {
        padding-top: 80px;
    }
    .pt-230 {
        padding-top: 80px;
    }
    .pt-240 {
        padding-top: 80px;
    }
    .pt-250 {
        padding-top: 80px;
    }
    .pt-260 {
        padding-top: 80px;
    }
    .pt-270 {
        padding-top: 80px;
    }
    .pt-280 {
        padding-top: 80px;
    }
    .pt-290 {
        padding-top: 80px;
    }
    .pt-300 {
        padding-top: 80px;
    }
    .pb-110 {
        padding-bottom: 80px;
    }
    .pb-120 {
        padding-bottom: 80px;
    }
    .pb-130 {
        padding-bottom: 80px;
    }
    .pb-140 {
        padding-bottom: 80px;
    }
    .pb-150 {
        padding-bottom: 80px;
    }
    .pb-160 {
        padding-bottom: 80px;
    }
    .pb-170 {
        padding-bottom: 80px;
    }
    .pb-180 {
        padding-bottom: 80px;
    }
    .pb-190 {
        padding-bottom: 80px;
    }
    .pb-200 {
        padding-bottom: 80px;
    }
    .pb-210 {
        padding-bottom: 80px;
    }
    .pb-220 {
        padding-bottom: 80px;
    }
    .pb-230 {
        padding-bottom: 80px;
    }
    .pb-240 {
        padding-bottom: 80px;
    }
    .pb-250 {
        padding-bottom: 80px;
    }
    .pb-260 {
        padding-bottom: 80px;
    }
    .pb-270 {
        padding-bottom: 80px;
    }
    .pb-280 {
        padding-bottom: 80px;
    }
    .pb-290 {
        padding-bottom: 80px;
    }
    .mt-110 {
        margin-top: 80px;
    }
    .mt-120 {
        margin-top: 80px;
    }
    .mt-130 {
        margin-top: 80px;
    }
    .mt-140 {
        margin-top: 80px;
    }
    .mt-150 {
        margin-top: 80px;
    }
    .mt-160 {
        margin-top: 80px;
    }
    .mt-170 {
        margin-top: 80px;
    }
    .mt-180 {
        margin-top: 80px;
    }
    .mt-190 {
        margin-top: 80px;
    }
    .mt-200 {
        margin-top: 80px;
    }
    .mt-210 {
        margin-top: 80px;
    }
    .mt-220 {
        margin-top: 80px;
    }
    .mt-230 {
        margin-top: 80px;
    }
    .mt-240 {
        margin-top: 80px;
    }
    .mt-250 {
        margin-top: 80px;
    }
    .mt-260 {
        margin-top: 80px;
    }
    .mt-270 {
        margin-top: 80px;
    }
    .mt-280 {
        margin-top: 80px;
    }
    .mt-290 {
        margin-top: 80px;
    }
    .mt-300 {
        margin-top: 80px;
    }
    .mb-110 {
        margin-bottom: 80px;
    }
    .mb-120 {
        margin-bottom: 80px;
    }
    .mb-130 {
        margin-bottom: 80px;
    }
    .mb-140 {
        margin-bottom: 80px;
    }
    .mb-150 {
        margin-bottom: 80px;
    }
    .mb-160 {
        margin-bottom: 80px;
    }
    .mb-170 {
        margin-bottom: 80px;
    }
    .mb-180 {
        margin-bottom: 80px;
    }
    .mb-190 {
        margin-bottom: 80px;
    }
    .mb-200 {
        margin-bottom: 80px;
    }
    .mb-210 {
        margin-bottom: 80px;
    }
    .mb-220 {
        margin-bottom: 80px;
    }
    .mb-230 {
        margin-bottom: 80px;
    }
    .mb-240 {
        margin-bottom: 80px;
    }
    .mb-250 {
        margin-bottom: 80px;
    }
    .mb-260 {
        margin-bottom: 80px;
    }
    .mb-270 {
        margin-bottom: 80px;
    }
    .mb-280 {
        margin-bottom: 80px;
    }
    .mb-290 {
        margin-bottom: 80px;
    }
    .mb-300 {
        margin-bottom: 80px;
    }
    .side_bar {
        position: fixed;
        right: 0;
        top: auto;
        bottom: 0;
        transform: translateY(0);
        width: 100%;
        display: flex;
        justify-content: space-between;
        border-top: 1px solid #FFF;
        border-left: 0;
    }
    .side_bar > div {
        width: 30%;
        height: 50px;
        font-size: 11px;
        writing-mode: horizontal-tb;
        border-bottom: 0;
    }
    .side_bar > div:nth-child(3) {
        width: 40%;
    }
    .side_bar > div:nth-child(1) {
        background-color: #2e9568;
    }
    .side_bar > div:nth-child(2) {
        background-color: #f39801;
    }
    .side_bar a {
        display: flex;
        justify-content: center;
        align-items: center;
    }
    .side_bar a img {
        margin-bottom: 0;
        margin-right: 5px;
    }
    /************************/
    .cy_header {
        padding: 20px 0;
    }
    .logo {
        width: 175px;
    }
    .logo img {
        width: 100%;
        height: auto;
    }
    /**********/
    .top_main {
        max-width: 90%;
        width: 90%;
    }
    .top_main, .flexslider, .flexslider li {
        height: 500px;
        border-radius: 50px;
        position: relative;
    }
    .top_title {
        font-size: 5vw;
        bottom: auto;
        top: 50%;
        transform: translateY(-50%);
        text-align: center;
        line-height: 1.8em;
    }
    @keyframes title {
        0% {
            opacity: 0;
            transform: translateX(-50%) translateY(-40%);
        }
        100% {
            opacity: 1;
            transform: translateX(-50%) translateY(-50%);
        }
    }
    /*******************/
    .title_38 {
        font-size: 24px;
    }
    .eng_16 {
        font-size: 14px;
    }
    .news {
        grid-template-columns: repeat(2, 1fr);
        row-gap: 40px;
    }
    .news.top_news > div:nth-child(3) {
        display: none;
    }
    .radius30 {
        border-radius: 20px;
    }
    .n_cate {
        margin: 10px 0 5px;
    }
    .n_cate span {
        font-size: 13px;
    }
    .n_title {
        font-size: 11px;
    }
    .more {
        width: 100%;
        max-width: 240px;
    }
    .more a {
        padding: 10px 10px;
    }
    /***********************/
    .top_af_bg {
        position: relative;
    }
    .top_af_bg:after {
        width: calc(100% - 10px);
        border-radius: 60px 0 0 60px;
    }
    .sp_plr20 {
        padding-left: 10px;
        padding-right: 10px;
    }
    .sp_plr10 {
        padding-left: 10px;
        padding-right: 10px;
    }
    .w900_auto {
        width: 100%;
        max-width: 900px;
        margin-left: auto;
        margin-right: auto;
    }
    .be_af_border:before, .be_af_border:after {
        width: 30px;
    }
    .be_af_border:before {
        margin-right: 20px;
    }
    .be_af_border:after {
        margin-left: 20px;
    }
    .title_24 {
        font-size: 18px;
    }
    .text_15 {
        font-size: 14px;
    }
    .radius100 {
        border-radius: 50px;
    }
    .padding50 {
        padding: 30px;
    }
    .title_28 {
        font-size: 20px;
        font-weight: bold;
    }
    .text_20 {
        font-size: 14px;
    }
    /****************/
    .top_bg {
        height: 250px;
    }
    .sp_minus {
        padding-top: 0;
        margin-top: -40px;
    }
    .ver_title {
        position: static;
        top: 0;
        width: auto;
        border-radius: 0;
        padding: 0;
        display: inline-block;
        writing-mode: horizontal-tb;
        margin-bottom: 40px;
        background-color: #FFF;
        margin-left: -6%;
        border-radius: 0 20px 0 0;
        padding: 10px 20px 0;
    }
    .ver_title h2 {
        font-family: "NotoSansCJKjp-Regular";
        white-space: nowrap;
        text-align: left;
    }
    .ver_title p {
        white-space: nowrap;
        text-align: left;
    }
    .title_35 {
        font-size: 20px;
        font-weight: bold;
    }
    .big_40 {
        font-size: 24px;
    }
    .text_17 {
        font-size: 15px;
    }
    /*
.top_grid {
    display: grid;
    grid-template-columns: repeat(1, 1fr);
    column-gap: 0;
    row-gap: 100px;
    > div {
        position: relative;
        &:after {
            background: url("../images/top7.png") 50% 50%/45px 100% no-repeat;
            width: 100%;
            height: 46px;
            position: absolute;
            right: 50%;
            top: calc(100% + 23px);
            transform: translateX(50%);
        }
        &:last-child:after {
            display: none;
        }
    }
}
*/
    .top_grid {
        display: grid;
        grid-template-columns: repeat(3, 1fr);
        column-gap: 30px;
        row-gap: 30px;
    }
    .top_grid > div {
        position: relative;
    }
    .top_grid > div:after {
        content: "";
        background: url("../images/top7.png") 50% 50%/20px 100% no-repeat;
        width: 30px;
        height: 21px;
        position: absolute;
        right: -30px;
        top: 50%;
        transform: translateY(-50%);
    }
    .top_grid > div:last-child:after {
        display: none;
    }
    .top_banner {
        height: auto;
    }
    .top_banner a {
        padding: 180px 10px 80px;
    }
    .top_banner:after {
        top: 5px;
        left: 5px;
        width: calc(100% - 10px);
        height: calc(100% - 10px);
        border-radius: 10px;
    }
    .top_banner .banner_title {
        position: static;
        padding: 0;
        transform: translateY(0);
        z-index: 500;
    }
    .top_banner .banner_title h2 {
        font-size: 20px;
        font-weight: bold;
        text-align: center;
    }
    .top_banner .banner_title p {
        margin-top: 20px;
        font-size: 15px;
        text-align: center;
    }
    .top_banner .banner_title p img {
        margin-left: 20px;
    }
    .banner_img {
        left: 0;
        width: 100%;
        text-align: center;
    }
    .banner_img img {
        width: 150px;
        height: auto;
    }
    /**********************/
    .top_af_bg2 {
        position: relative;
    }
    .top_af_bg2:after {
        width: calc(100% - 10px);
        border-radius: 0 60px 60px 0;
    }
    .model_title {
        padding: 10px 50px 10px 10px;
        font-size: 12px;
    }
    .model_title span {
        font-size: 18px;
    }
    .model_shape img {
        position: absolute;
        right: 10px;
    }
    .model_on {
        opacity: 0;
    }
    /************/
    .slider.slider_style {
        width: calc(100% + 200px);
        margin-left: 0;
        padding-left: 10px;
    }
    .slider.slider_style h3 {
        font-size: 16px;
        margin: 15px 0 20px;
    }
    .slider.slider_style p {
        font-size: 13px;
    }
    .slider.slider_style li {
        float: left;
        position: relative;
        z-index: 900;
        padding: 0 20px 0 0;
    }
    .slider.slider_style li img {
        border-radius: 40px;
    }
    /************************/
    .blog_grid {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        column-gap: 20px;
        row-gap: 40px;
    }
    .blog_grid > div {
        width: 100%;
        max-width: 100%;
        margin: 0;
    }
    .blog_grid > div a {
        display: block;
    }
    .blog_left {
        width: 100%;
    }
    .blog_right {
        width: 100%;
        padding-top: 10px;
    }
    .b_time {
        font-size: 12px;
    }
    .b_title {
        font-size: 13px;
    }
    /*************************/
    .under_banner {
        display: block;
    }
    .under_banner > div {
        width: 100%;
        height: 180px;
        margin-top: 2px;
    }
    .banner_bg1 {
        filter: blur(0);
    }
    .banner_bg2 {
        filter: blur(0);
    }
    /************************/
    .f_bg {
        padding: 60px 0;
    }
    .page_top {
        right: 10px;
        bottom: 20px;
    }
    .f_logo {
        margin-bottom: 30px;
    }
    .f_logo img {
        width: 220px;
        height: auto;
    }
    .f_tel {
        margin-top: 5px;
        font-size: 30px;
    }
    .f_tel img {
        margin-right: 10px;
        position: relative;
        top: -2px;
    }
    .f_nav {
        margin-top: 40px;
        display: block;
    }
    .f_nav > div:nth-child(1) {
        display: block;
        align-items: center;
        font-size: 14px;
    }
    .f_nav > div:nth-child(1) a {
        color: #FFF;
    }
    .f_nav > div:nth-child(1) p {
        padding: 10px 0;
        border-right: 0;
        text-align: center;
    }
    .f_nav > div:nth-child(2) {
        justify-content: center;
        margin-top: 30px;
    }
    .copy {
        font-size: 12px;
        padding: 20px 0 65px;
    }
    /*******************************************************************

    家づくりの想い

*******************************************************************/
    .main_size {
        height: 250px;
        border-radius: 20px;
        width: 90%;
        max-width: 90%;
    }
    .main_size h2 {
        padding-top: 15px;
        font-size: 26px;
        line-height: 1.3em;
    }
    .main_size p {
        font-size: 16px;
        letter-spacing: 0.2em;
    }
    /**********************/
    .concept_padding {
        padding: 60px 0 60px;
    }
    .title_45 {
        font-size: 22px;
    }
    .big_50 {
        font-size: 28px;
    }
    .letter005 {
        letter-spacing: 0.05em;
    }
    .line_height24 {
        line-height: 2.2em;
    }
    .con_ab1 {
        position: absolute;
        left: 0;
        bottom: 0;
        display: none;
    }
    .con_ab2 {
        position: absolute;
        right: 0;
        bottom: 70px;
        display: none;
    }
    .center.minita-l {
        text-align: left;
    }
    .sp_flex {
        margin-top: 40px;
    }
    /********************/
    .radius_right_top {
        border-top-right-radius: 60px;
    }
    .radius_left_bottom {
        border-bottom-left-radius: 60px;
    }
    .concept_flex {
        display: block;
    }
    .concept_flex.right_style .concept_left {
        justify-content: flex-start;
        position: static;
        right: 0;
        left: auto;
    }
    .concept_flex.right_style .concept_right {
        border-radius: 0 20px 20px 0;
        margin-left: 0;
    }
    .concept_left {
        width: 100%;
        display: flex;
        justify-content: space-between;
        position: static;
        top: 0;
        left: 0;
    }
    .concept_title {
        display: flex;
        align-items: center;
        justify-content: space-between;
        width: 90%;
        margin-left: auto;
        margin-right: auto;
        margin-top: 25px;
    }
    .concept_title .font2 {
        width: 60px;
        height: 60px;
        background-color: #2e9568;
        color: #FFF;
        display: flex;
        justify-content: center;
        align-items: center;
        font-size: 22px;
        border-radius: 10px;
    }
    .concept_title h3 {
        white-space: normal;
        width: calc(100% - 70px);
        writing-mode: horizontal-tb;
        text-orientation: upright;
        font-size: 20px;
        line-height: 1.5em;
        padding: 0;
        position: relative;
        display: block;
    }
    .concept_right {
        width: 95%;
        height: 250px;
        border-radius: 20px 0 0 20px;
        margin-left: auto;
    }
    .w960_right {
        width: 90%;
        margin: 0 auto;
    }
    /***********************/
    .under_flex {
        display: block;
    }
    .under_flex > div {
        width: 100%;
        border-radius: 20px;
        margin: 10px 0;
    }
    .under_flex > div:after {
        content: "";
        background-color: rgba(0, 0, 0, 0.5);
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        transition: 0.5s ease;
    }
    .under_flex > div:hover:after {
        opacity: 0;
    }
    .under_flex a {
        text-align: left;
        padding-left: 20px;
        height: 150px;
        justify-content: flex-start;
    }
    .under_flex .shape {
        position: absolute;
        right: 20px;
        bottom: auto;
        top: 50%;
        transform: translateY(-50%);
    }
    .under_flex h3 {
        font-size: 20px;
        font-weight: bold;
    }
    /*******************************************************************

    家づくりの流れ

*******************************************************************/
    .flow_flex > div {
        width: calc(50% - 40px);
        margin: 20px 20px;
    }
    .flow_flex > div:nth-child(1) .max_img100:before {
        display: none;
    }
    .flow_flex .max_img100:before {
        width: 40px;
        left: -40px;
    }
    .flow_flex p {
        margin-top: 10px;
        font-size: 15px;
        line-height: 1.2em;
    }
    .flow_flex p span {
        font-size: 15px;
    }
    .flow_bg {
        height: 300px;
        border-radius: 0 20px 0 20px;
    }
    /***********************/
    .title_30 {
        font-size: 22px;
    }
    .flow_flex2 > div {
        display: block;
        padding: 40px 0;
    }
    .flow_left {
        max-width: 430px;
        width: 100%;
    }
    .flow_right {
        width: 100%;
        margin-top: 20px;
        padding: 0 10px;
    }
    .flow_right h3 {
        margin: 15px 0 10px;
    }
    .point {
        font-size: 15px;
    }
    .point span {
        font-size: 26px;
        padding-left: 10px;
    }
    /********************/
    .flow_list {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        column-gap: 40px;
        row-gap: 30px;
        padding-right: 40px;
    }
    .flow_list > div {
        position: relative;
    }
    .flow_list > div:last-child .img100:after {
        display: none;
    }
    .flow_list h3 {
        font-size: 15px;
        margin-top: 20px;
    }
    .flow_list .img100:after {
        background: url("../images/flow15.jpg") 50% 0/20px 15px no-repeat;
        width: 40px;
        height: 15px;
        right: -40px;
    }
    .flow_num {
        font-size: 30px;
        left: 10px;
        top: -25px;
    }
    .grid3 {
        display: grid;
        grid-template-columns: repeat(3, 1fr);
        column-gap: 10px;
        row-gap: 10px;
    }
    /*******************************************************************

    ごあいさつ

*******************************************************************/
    .title_55 {
        font-size: 23px;
        line-height: 1.8em;
    }
    .big_60 {
        font-size: 30px;
    }
    .name_box p {
        font-size: 14px;
        line-height: 2em;
    }
    .name_box .name1 {
        font-size: 16px;
    }
    .name_box .name2 {
        font-size: 22px;
    }
    .name_box:before {
        margin-right: 30px;
    }
    /*******************************************************************

    沿革

*******************************************************************/
    .history_table > div {
        display: flex;
        justify-content: space-between;
        font-size: 14px;
        font-weight: bold;
    }
    .history_table > div:nth-child(n+2) {
        margin-top: 55px;
    }
    .history_table:after {
        height: calc(100% - 18px);
        left: 105px;
        top: 10px;
    }
    .his_cell1 {
        width: 110px;
        position: relative;
    }
    .his_cell1:after {
        top: 8px;
    }
    .his_cell2 {
        width: calc(100% - 130px);
    }
    /*******************************************************************

    制震装置MIRAIE

*******************************************************************/
    .miraie_af_bg:after {
        border-radius: 20px 0 0 20px;
        width: calc(100% - 10px);
        height: calc(100% - 60px);
    }
    .padding60_20 {
        padding: 30px 30px;
    }
    /*************/
    .miraie_flex {
        display: block;
    }
    .miraie_flex > div {
        width: 100%;
        border: 2px solid #d2d2d2;
        border-radius: 20px;
        padding: 30px 20px;
    }
    .miraie_flex > div:nth-child(2) {
        margin-top: 100px;
    }
    .miraie_flex > div:nth-child(1):after {
        background: url("../images/miraie5.png") 50% 0/50px 50px no-repeat;
        top: calc(100% + 25px);
        right: 50%;
        width: 100%;
        height: 50px;
        transform: translateX(50%);
    }
    .miraie_flex .max_img100 {
        text-align: center;
    }
    .miraie_flex h3 {
        font-size: 20px;
        margin: 20px 0 20px;
    }
    /*******************/
    .miraie_flex2 {
        display: block;
    }
    .miraie_flex2 > div {
        width: 100%;
        max-width: 100%;
    }
    .miraie_flex2 > div:nth-child(n+2) {
        margin-top: 50px;
    }
    .miraie_flex2 .max_img100 {
        border-radius: 20px;
        height: 240px;
    }
    .miraie_flex2 h3 {
        min-height: 0;
        display: block;
        font-size: 20px;
        text-align: center;
        margin: 20px 0;
    }
    .miraie_flex2 .mini {
        font-size: 14px;
    }
    .miraie_num {
        position: absolute;
        left: -5px;
        top: -15px;
        z-index: 500;
    }
    .miraie_num img {
        width: 60px;
        height: auto;
    }
    /**************/
    .title_33 {
        font-size: 20px;
    }
    .mini_17 {
        font-size: 14px;
        top: -5px;
    }
    .padding40_20 {
        padding: 30px 30px;
    }
    .bg_w {
        background-color: #FFF;
    }
    .padding100_100 {
        padding: 30px 10px;
    }
    /***************/
    .text_23 {
        font-size: 15px;
    }
    .span_17 {
        font-size: 14px;
        top: -5px;
    }
    /**************/
    .span_13 {
        font-size: 13px;
        position: relative;
        top: -5px;
    }
    .text_13 {
        font-size: 13px;
    }
    .line_height15 {
        line-height: 1.8em;
    }
    /*******************************************************************

    モデルハウス

*******************************************************************/
    .view_main {
        padding: 50px 0 60px;
    }
    .view_main h2 {
        font-size: 26px;
        letter-spacing: 0.03em;
        line-height: 1.3em;
    }
    .view_main .eng_16 {
        font-size: 16px;
    }
    .slider1 {
        text-align: center;
    }
    .slider1 li {
        padding: 0 40px;
        margin: 0;
    }
    .slider2 {
        grid-template-columns: repeat(7, 1fr);
        margin-top: 20px;
    }
    .slider2 li {
        border-radius: 5px;
    }
    .slider2 li.thumbnail-current:after {
        border-radius: 5px;
    }
    .view_bb {
        padding-bottom: 20px;
        background-image: linear-gradient(to right, #2e9568, #2e9568 2px, transparent 2px, transparent 8px);
        /* 幅2の線を作る */
        background-size: 8px 2px;
        /* グラデーションの幅・高さを指定 */
        background-position: left bottom;
        /* 背景の開始位置を指定 */
        background-repeat: repeat-x;
        /* 横向きにのみ繰り返す */
    }
    .view_flex > div {
        display: flex;
        margin: 25px 0;
        font-size: 14px;
    }
    .view_cell1 {
        width: 90px;
        border-radius: 5px;
        padding-top: 0px;
    }
    .view_cell2 {
        width: calc(100% - 110px);
    }
    .more_flex {
        display: block;
    }
    .more_flex .more {
        width: 100%;
        margin: 10px 0;
        font-size: 16px;
    }
    /*******************************************************************

    ZEH

*******************************************************************/
    .zeh_img {
        text-align: center;
    }
    .zeh_img img {
        max-width: 150px;
        height: auto;
    }
    .zeh_title {
        font-size: 20px;
        letter-spacing: 0.05em;
        padding: 15px 10px;
        line-height: 2.2em;
    }
    .zeh_title:before, .zeh_title:after {
        width: 30px;
        height: 23px;
    }
    .zeh_title:before {
        top: -15px;
    }
    .zeh_title:after {
        bottom: -15px;
    }
    .span_50 {
        font-size: 28px;
    }
    /********************/
    .zeh_grid {
        display: grid;
        grid-template-columns: repeat(1, 1fr);
        column-gap: 0;
        row-gap: 20px;
    }
    .zeh_grid > div {
        padding: 30px 20px;
        border-radius: 20px;
    }
    .zeh_grid h3 {
        font-size: 22px;
        text-align: center;
        margin: 20px 0 15px;
    }
    .zeh_grid p {
        font-size: 14px;
        text-align: left;
    }
    .zeh_bg {
        padding: 30px;
        border-radius: 20px;
    }
    .check_list li {
        margin: 5px 0;
        position: relative;
        font-size: 16px;
        padding-left: 30px;
    }
    .check_list img {
        top: 5px;
    }
    /****************/
    .zeh_grid2 {
        display: grid;
        grid-template-columns: repeat(1, 1fr);
        column-gap: 0;
        row-gap: 20px;
    }
    .zeh_grid2 > div {
        border-radius: 20px;
        padding: 20px 20px;
        display: flex;
        justify-content: space-between;
        align-items: center;
    }
    .zeh_left {
        width: 80px;
    }
    .zeh_left img {
        width: 100%;
        height: auto;
    }
    .zeh_right {
        width: calc(100% - 100px);
    }
    .zeh_right h3 {
        line-height: 1.5em;
    }
    /***********************************/
    .zeh_table {
        overflow-x: scroll;
    }
    .zeh_table table {
        width: 640px;
    }
    .zeh_table th {
        width: 100px;
    }
    .zeh_table th, .zeh_table td {
        padding: 15px 0;
        font-size: 12px;
    }
    .zeh_table tr:nth-child(1) td {
        font-size: 12px;
    }
    .zeh_table tr:nth-child(1) td:nth-child(2) {
        border-radius: 10px 0 0 0;
    }
    .zeh_table tr:nth-child(1) td:last-child {
        border-radius: 0 10px 0 0;
    }
    .zeh_table tr:nth-child(n+2) td {
        font-size: 14px;
    }
    .zeh_table tr:nth-child(2) th {
        border-radius: 10px 0 0 0;
    }
    .zeh_table tr:last-child th {
        border-radius: 0 0 0 10px;
    }
    /*******************************************************************

    標準仕様

*******************************************************************/
    .title_40 {
        font-size: 20px;
    }
    /****************/
    .ip_border_title {
        background: none;
        height: auto;
        padding-top: 0;
        border: 1px solid #2e9568;
        padding: 15px 0;
        border-radius: 20px;
    }
    .text_18 {
        font-size: 14px;
    }
    /****************/
    .ip_border {
        border-radius: 20px;
        padding: 20px 20px;
    }
    /*******************/
    .tab_bg {
        padding: 40px 0;
    }
    .tab ul, .tab2 ul {
        display: grid;
        grid-template-columns: repeat(3, 1fr);
        column-gap: 5px;
        row-gap: 5px;
    }
    .tab a, .tab2 a {
        padding: 5px 5px;
        font-size: 15px;
        border-radius: 10px;
        transition: 0.5s ease;
    }
    .af_bb:after {
        border-bottom: 2px solid #2e9568;
        width: 30px;
        margin: 5px auto 0;
    }
    .sp_pdf {
        display: block;
        margin-top: 30px;
        text-align: center;
    }
    .sp_pdf a {
        background-color: #62584e;
        color: #FFF;
        width: 100%;
        max-width: 200px;
        display: block;
        margin: 0 auto;
        padding: 13px 0 10px;
        border-radius: 10px;
    }
    .sp_pdf a img {
        width: 15px;
        height: auto;
        margin-right: 10px;
        position: relative;
        top: -2px;
    }
    .tab_mt {
        margin-top: 30px;
    }
    /*******************************************************************

    会社概要

*******************************************************************/
    .com_left {
        position: static;
        left: 0;
        top: 0;
        writing-mode: horizontal-tb;
        max-width: 90%;
        width: 90%;
        margin-left: auto;
        margin-right: auto;
    }
    .com_title {
        font-size: 20px;
        line-height: 2em;
        margin-bottom: 30px;
        text-align: center;
        white-space: normal;
    }
    .com_title span {
        font-size: 26px;
    }
    .com_right {
        width: 90%;
        margin: 0 auto;
    }
    .com_right p {
        padding: 0;
    }
    .com_bg {
        width: 100%;
        margin-left: auto;
        height: 250px;
        max-width: 1180px;
        border-radius: 20px;
    }
    /********************/
    .com_flex {
        display: flex;
        justify-content: space-between;
        flex-wrap: wrap;
    }
    .com_flex > div {
        max-width: 480px;
        width: 48%;
        position: relative;
    }
    .com_flex > div:nth-child(n+3) {
        margin-top: 20px;
    }
    .com_flex a {
        color: inherit;
    }
    .com_flex a:hover .com_off {
        opacity: 0;
    }
    .com_flex a:hover .com_on {
        opacity: 1;
    }
    .com_flex h3 {
        font-size: 16px;
        letter-spacing: 0.05em;
        margin: 15px 0 5px;
    }
    .com_shape {
        position: static;
        margin-top: 0px;
        text-align: center;
    }
    .com_shape img {
        width: 25px;
        height: auto;
    }
    .com_shape .com_on {
        display: none;
    }
    /*******************************************************************

    会社概要

*******************************************************************/
    .pro_table {
        position: relative;
    }
    .pro_table > div {
        font-size: 14px;
    }
    .pro_cell1 {
        padding: 20px 10px;
        width: 100px;
    }
    .pro_cell2 {
        width: calc(100% - 100px);
        padding: 20px 15px;
    }
    .map iframe {
        width: 100%;
        height: 350px;
    }
    /*******************************************************************

    資料請求・お問い合わせ

*******************************************************************/
    .contact_border {
        border-radius: 20px;
        padding: 30px 10px;
    }
    .title_22 {
        font-size: 18px;
    }
    .c_tel {
        font-size: 30px;
        line-height: 1.3em;
        margin: 10px 0 0;
    }
    .c_tel img {
        margin-right: 10px;
        top: -2px;
        width: 20px;
        height: auto;
    }
    .contact_form {
        padding-bottom: 60px;
    }
    .contact_form > div {
        display: block;
        margin: 40px 0;
        font-size: 14px;
    }
    .c_cell1 {
        width: 100%;
        padding-top: 0;
        font-size: 16px;
    }
    .hissu {
        font-size: 12px;
        top: 0;
        line-height: 1em;
        padding: 5px 15px;
    }
    .c_cell2 {
        width: 100%;
        margin-top: 15px;
    }
    .size, .area {
        padding: 10px 15px;
    }
    .size {
        height: 50px;
    }
    .half_size .size {
        max-width: 330px;
    }
    .area {
        height: 250px;
    }
    .postal_flex {
        display: flex;
        align-items: center;
        justify-content: space-between;
        width: 100%;
        max-width: 330px;
    }
    .postal_cell1 {
        width: 20px;
    }
    .postal_cell2 {
        margin: 0 10px 0;
        flex-grow: 2;
    }
    .postal_cell3 {
        width: 115px;
    }
    .postal_cell3 span {
        font-size: 12px;
        padding: 5px 0 3px;
        font-weight: normal;
    }
    .label_flex {
        display: block;
    }
    .label_flex .wpcf7-list-item {
        display: block;
        margin-right: 0;
        padding-left: 10px;
        margin-top: 10px;
    }
    .label_flex input[type=radio] {
        position: relative;
        left: -10px;
    }
    /************/
    .submit input {
        padding: 20px;
        font-size: 16px;
    }
    /*******************************************************************

    来場予約

*******************************************************************/
    .minita-c {
        text-align: center;
    }
    .re_inline_block {
        font-size: 14px;
        display: block;
        flex-wrap: wrap;
        width: 100%;
        max-width: 680px;
        margin: 0 auto;
    }
    .re_inline_block:nth-child(n+2) {
        margin-top: 15px;
    }
    .re_inline_block span {
        display: block;
    }
    .re_inline_block span:nth-child(1) {
        width: 100%;
        font-size: 16px;
    }
    .re_inline_block span:nth-child(2) {
        display: none;
        width: 20px;
    }
    .re_inline_block span:nth-child(3) {
        width: 100%;
        padding-left: 18px;
        display: block;
        margin-top: 5px;
    }
    /*******************************************************************

    プライバシーポリシー

*******************************************************************/
    .pri_title {
        font-size: 18px;
        padding-left: 40px;
    }
    .pri_title .font2 {
        font-size: 16px;
        width: 30px;
        height: 30px;
        padding-left: 0px;
        padding-top: 0;
    }
    .pri_pl {
        padding-left: 16px;
    }
    /*******************************************************************

    施工事例

*******************************************************************/
    .works_left > div {
        width: 48%;
    }
    .works_left > div:nth-child(n+3) {
        margin-top: 40px;
    }
    .works_left > div .img100 {
        border-radius: 20px;
    }
    .works_left p {
        font-size: 14px;
    }
    .works_right {
        width: 100%;
        margin-top: 80px;
    }
    .title_23 {
        font-size: 20px;
    }
    .cate_bb {
        padding-bottom: 10px;
        margin-bottom: 20px;
    }
    .cate_list li {
        margin: 15px 0;
    }
    /*******************************************************************

    アイビーホームの家作り

*******************************************************************/
    .commit_bg {
        border-radius: 40px 0 0 40px;
        height: 300px;
        width: calc(100% + 16px);
    }
    .commit_title {
        padding: 20px 5px 0 0;
        margin-top: -50px;
        font-size: 18px;
        letter-spacing: 0em;
    }
    .commit_title span {
        font-size: 20px;
    }
    .commit_grid {
        grid-template-columns: repeat(1, 1fr);
        column-gap: 0;
        row-gap: 40px;
    }
    .commit_grid > div {
        padding-bottom: 0;
    }
    .commit_grid h3 {
        margin: 15px 0 15px;
        font-size: 20px;
    }
    .commit_grid .more {
        position: static;
        transform: translateX(0);
        margin-top: 20px;
    }
    .commit_text {
        font-size: 13px;
    }
}
/* スマートフォン 縦(ポートレート) */
@media only screen and (max-width: 380px) {
    .ver_title h2 {
        font-size: 18px;
    }
    .ver_title p {
        font-size: 12px;
    }
}