/*
* Prefixed by https://autoprefixer.github.io
* PostCSS: v7.0.29,
* Autoprefixer: v9.7.6
* Browsers: last 4 version
*/

/*
* Prefixed by https://autoprefixer.github.io
* PostCSS: v7.0.29,
* Autoprefixer: v9.7.6
* Browsers: last 4 version
*/

/*
* Prefixed by https://autoprefixer.github.io
* PostCSS: v7.0.29,
* Autoprefixer: v9.7.6
* Browsers: last 4 version
*/

@charset "utf-8";

@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght @400;700&display=swap');

/* clearfix
-------------------------------------------------- */
body {
    max-width: 100%;
    margin: 0;
    font-size: 13px;
    /* 13px相当（ベース16px） */
    line-height: 1.231;
    font-family: "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif;
    overflow-x: hidden;
}

html {
    font-size: 16px;
    scroll-behavior: smooth;
}

#wrapper {
    position: relative;
    width: 100%;
    height: 100%;
    -webkit-text-size-adjust: 100%;
    color: #333;
    font-size: 1.4rem;
}

.clearfix::after {
    content: "";
    display: block;
    clear: both;
}

#top-head {
    position: fixed;
    z-index: 999;
    top: 0px;
    width: 100%;
    background: #F6F6F6;
    border-bottom: 1px solid #e6e6e6;
    -webkit-box-shadow: 0 0 5px #eee;
    box-shadow: 0 0 5px #eee;
}

.page-top {
    top: 57px;
}

#logo {
    max-width: 50%;
    display: block;
    margin: 0 auto;
}

nav {
    width: 100%;
    height: 57px;
    position: relative;
    background: #F6F6F6;
}

.drawer {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -webkit-flex-direction: row;
    -ms-flex-direction: row;
    flex-direction: row;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
    -ms-flex-pack: justify;
    justify-content: space-between;
    position: relative;
    height: 57px;
    padding: 0 1rem;
}

#logo img {
    width: 140px;
}

/*ナビゲーション部分*/
.menu {
    text-align: center;
    background-color: rgba(255, 255, 255, 0.9);
    -webkit-transition: 0s ease;
    -webkit-transition: .0s ease;
    -o-transition: .0s ease;
    transition: .0s ease;
    /*滑らかに表示*/
    -webkit-transform: translateX(-105%);
    -ms-transform: translateX(-105%);
    transform: translateX(-105%);
    /*左に隠しておく*/
}

.menu ul li a {
    display: block;
    font-weight: bold;
    padding: 1.5rem;
    border-bottom: 1px dotted #CCC;
    text-decoration: none;
    opacity: 1;
    font-size: 1rem;
}

.menu ul li a:hover {
    background-color: rgba(0, 0, 0, 0.5);
    color: #00bfff;
}

.menu__second-level li {
    display: none;
}

/*OPEN時の動き*/
.menu.open {
    -webkit-transform: translateX(0%);
    -ms-transform: translateX(0%);
    transform: translateX(0%);
    /*中身を表示（右へスライド）*/
    -webkit-transition: .5s ease;
    -o-transition: .5s ease;
    transition: .5s ease;
    /*滑らかに表示*/
}

/*トグルボタンのスタイルを指定*/
.Toggle {
    display: block;
    position: fixed;
    /* bodyに対しての絶対位置指定 */
    width: 32px;
    height: 32px;
    cursor: pointer;
    z-index: 3;
    right: 15px;
    top: 15px;
}

.Toggle span {
    display: block;
    position: absolute;
    width: 30px;
    border-bottom: solid 4px #333;
    -webkit-transition: .35s ease-in-out;
    /*変化の速度を指定*/
    /*変化の速度を指定*/
    -o-transition: .35s ease-in-out;
    transition: .35s ease-in-out;
    /*変化の速度を指定*/
}

.Toggle span:nth-child(1) {
    top: 5px;
}

.Toggle span:nth-child(2) {
    top: 15px;
}

.Toggle span:nth-child(3) {
    top: 25px;
}

.Toggle.active span:nth-child(1) {
    top: 18px;
    -webkit-transform: rotate(-45deg);
    -ms-transform: rotate(-45deg);
    transform: rotate(-45deg);
}

/* 2番目と3番目のspanを45度に */
.Toggle.active span:nth-child(2),
.Toggle.active span:nth-child(3) {
    top: 18px;
    -webkit-transform: rotate(45deg);
    -ms-transform: rotate(45deg);
    transform: rotate(45deg);
}

/* スライド*/
.swiper-slide {
    z-index: 1;
}

.swiper-container {
    text-align: center;
    background-color: rgba(65, 105, 225, 0.1);
}

.swiper-container .swiper-slide img {
    max-width: 1150px;
    width: 100%;
    -o-object-fit: cover;
    object-fit: cover;
    font-family: 'object-fit:cover;';
}

.prettyprint {
    border: none;
    background: #fafafa;
    color: #697d86;
}

#thumbs {
    display: none;
}




/*コンテンツエリア*/

#main__content {

    overflow-x: hidden;
}

.full-width {
    width: 100vw;
    position: relative;
    left: 50%;
    right: 50%;
    margin-left: -50vw;
    margin-right: -50vw;
    text-align: center;

}
.full-width--ec{
    width: 100%;
    display: flex;
    justify-content: center;
    align-items:center;
    padding: 1rem;

}
.full-width--ec_blk1{
    width: 80%;
    padding-right: 1rem;
}
.full-width--ec_blk2{
    width: 20%;
}
.full-width h2 {
    width: 100%;
    padding: 0 30px 10px;
    text-align: center;
    font-size: 1rem;

}

.full-width li {
    list-style: none;
    text-align: center;
    text-shadow:
        0 0 0.10rem #fFF,
        0 0 0.15rem #fFF,
        0 0 0.80rem #fFF,
        0 0 1.00rem #fFF;
}

.full-width a {
    color: #333;
    text-decoration: none;
}

.back_1 {
    background-image: url("../img/eco-back.png");
    /*コンテンツ全体の背景画像*/
    background-repeat: repeat-y;
    /*背景画像を縦方向に繰り返す*/
    background-attachment: fixed;
}

.back_2 {
    background-image: url("../img/keep-back.png");
    /*コンテンツ全体の背景画像*/
    background-repeat: repeat-y;
    /*背景画像を縦方向に繰り返す*/
    background-attachment: fixed;
}

.back_3 {
    background-image: url("../img/banner-back.png");
    /*コンテンツ全体の背景画像*/
    background-repeat: repeat-y;
    /*背景画像を縦方向に繰り返す*/
    background-attachment: fixed;
}

.back_3 img {
    max-height: 230px;
}

.box__area {
    width: 100%;
    max-width: 1090px;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    text-align: center;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    margin: 0 auto;
}

.full-width > img {
    max-width: 100vw;
    height: auto;
}

.site__wrap .full-width img {
    max-width: 70vw;
}

.page-top__title,
.news__title,
.work__title {
    padding: 0 6rem;
    padding-top: 3.6rem;
    background-color: #fff;

    max-width: 1024px;
    margin: 0 auto;
}

.page-top__title {
    padding-top: 1.6rem;
}

.page-top__title h3,
.news__title h3,
.work__title h3 {
    text-align: center;
    font-size: 1.6rem;
    margin-bottom: 2rem;
    border-bottom: 2px solid #333;
}

.page-top__one {
    width: 100%;
    background-color: #edfdf1;
}

.page-top__two {
    width: 100%;
    background-color: #fff5f5;
}

.page-top__three {
    height: 100%;
    background-color: #f5f5f5;
    display: flex;
}

.page-top__three:before {
    content: "";
    display: block;
    width: 0;
    height: 0;
    padding-bottom: 65%;
}

.site__wrap {
    width: 100%;
    text-align: center;
    padding: 2rem;
    -webkit-box-sizing: border-box;
    /*webkit系*/
    /*Firefox*/
    box-sizing: border-box;
    max-width: 1024px;
    margin: 0 auto;
    padding-top: 0;
}

.PC-img,
.TAB-img {
    display: none !important;
}

.site__wrap > h2 img {
    width: 180px;
}


.site__wrap p {
    text-align: justify;
    margin-top: 1.5rem;
}

.wrap {
    display: -webkit-box;
    display: -ms-flexbox;
    -ms-flex-wrap: wrap;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
    display: -webkit-flex;
    display: flex;
}

.content {
    display: -webkit-box;
    display: -ms-flexbox;
    -ms-flex-wrap: wrap;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
    display: -webkit-flex;
    display: flex;
    -webkit-justify-content: space-around;
    -ms-flex-pack: distribute;
    justify-content: space-around;
}

.page-top__one .content,
.page-top__two .content {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 100%;
    -webkit-flex: 0 0 100%;
    flex: 0 0 100%;
    margin-top: 0.8rem;
}

.page-top__one .content p,
.page-top__two .content p {
    margin-top: 20px;
    padding-left: 30px;
    padding-right: 45px;
}

.page-top__one .content img,
.page-top__two .content img {
    border: 1px solid rgba(0, 0, 0, 0.7);
}

.wrap .content img {
    -webkit-box-sizing: border-box;
    /*webkit系*/
    /*Firefox*/
    box-sizing: border-box;
    margin: 15px 0;
    width: 100%;
}

div.g-inner {
    position: relative;
    width: 100%;
    background-color: #f5f5f5;

}

.page-top__three .site__wrap {
    box-shadow: rgba(0, 0, 0, 0.1) 0px 4px 12px;
    background-color: #fffafa;
    margin: 10px auto;
}

#view {
    position: absolute;
    width: 100%;
    top: -10px;
}

#view img {
    max-width: 700px;
    width: 100%;
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    z-index: 2;
}

#thumbBtn {
    position: absolute;
    top: -10px;
    z-index: 1;
}

#thumbBtn:before {
    content: "";
    display: block;
    width: 0;
    height: 0;
    padding-bottom: 45vw;
}

#thumbBtn li {
    padding: 0 0 0 2px;
    float: left;
    text-align: right;
    cursor: pointer;
    width: 33%;
}

#thumbBtn li img {
    border: solid 1px #ccc;
    background-color: #800000;
    max-width: 100%;
}

#thumbBtn li.active {
    opacity: 0.5;
    filter: alpha(opacity=50);
    -ms-filter: "alpha( opacity=50 )";
}

/*bottom news */
*,
*:before,
*:after {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
}

.info {
    padding: 0 1.2rem;
    text-align: left;
    line-height: 1.3;
    color: #444;
    overflow: auto;
    width: 100%;
    height: 15rem;
    background-color: #f5f5f5;
    border: 1px solid rgba(0, 0, 0, 0.1);
}

.info dl {
    padding: 1rem 0;
    border-bottom: 1px solid #ccc;
}

.info dt {
    color: #0000cd;
    font-weight: bold;
    padding-bottom: 0.7rem;
    width: 13rem;
    font-size: 1rem;
}

.info dt span {
    text-align: right;
    position: relative;
    font-size: 0.8rem;
    background-color: #0000cd;
    border-radius: 1rem;
    color: #fff;
    margin: 0 1rem;
    padding: 0.2rem 1.5rem;
    text-decoration: none;
}

.info dd {
    font-size: 1rem;
}

.info a {
    color: #000;
}

.info__box {
    margin: 2rem auto;
    width: 11rem;
    padding: 1rem 1rem 0.5rem 1rem;
    color: #fff;
    background-color: #0000cd;
}

.info__box a {
    color: #fff;
    text-decoration: none;
    font-size: 1rem;

}

@media screen and (min-width: 480px) {
    .info dt {
        clear: left;
        float: left;
    }

    .info dd {
        margin-left: 0.5rem;
    }
}

/**** バナー ***/
.banner {
    padding-top: 2rem;
}

.banner img {
    margin-top: 30px;
    border: 1px solid #000;
    max-width: 300px;
}

/***フッター***/
#footer04 {}

.inner-block {
    background-color: #f5f5f5;
    padding: 0 2rem;
    border-bottom: 1px solid #000;

}

#footer04 .cont {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    padding: 2rem 0 1rem 0;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    width: 100%;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
    -ms-flex-pack: justify;
    justify-content: space-between;
    text-align: center;
}

#footer04 .cont-item {
    display: block;
    width: 50%;
}

#footer04 .nav a {
    display: block;
    color: #696969;
    text-decoration: none;
}

#footer04 .nav .ttl {
    display: block;
    margin: 2rem 0 0.8rem;
    font-size: 1rem;
    font-weight: bold;
    color: #696969;
}


#footer04 .nav .ttl:first-child {
    margin-top: 0;
}



#footer04 .nav ul {
    display: block;
    margin: 0;
    font-size: 1rem;
    line-height: 2;
}

#footer04 .nav li {
    display: block;
    font-size: 0.8rem;
    line-height: 2;
}

#footer04 .nav li:first-child {
    margin-top: 0;
}

#footer04 .cont-item:nth-child(n+3) {
    margin-top: 30px;
}

#footer04 .company {
    width: 100%;
    background: #4169e1;
    padding: 1rem 2rem;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    display: -webkit-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    -webkit-justify-content: space-between;
    justify-content: space-between;
}

.footer-inner {
    width: 100%;
}

#footer04 .logo img {
    width: 100%;
    max-width: 250px;
}

#footer04 .address,
.tell {
    -webkit-box-flex: 1;
    -ms-flex: 1 1 70%;
    -webkit-flex: 1 1 70%;
    flex: 1 1 70%;
    margin: 10px 0 0;
    font-size: 1rem;
    line-height: 2;
    color: #fff;
}

#footer04 .tell {
    width: 100%;
    margin: 28px 0 0;
    margin: 10px 0 0;
    font-size: 0.8rem;
    line-height: 2;
    color: #fff;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    display: -webkit-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
}

#footer04 .tell ul {
    width: 50%;
    padding-bottom: 1rem;
    text-align: left;
}

#footer04 .tell li {
    list-style: none;
}

#footer04 .tell li:first-child {
    font-size: 1.1rem;
    width: 70%;
    border-bottom: 1px solid #fff;
    margin-bottom: 0.5rem;
}

.copyright {
    background-color: #4169e1;
    text-align: center;
    font-size: 0.7rem;
    color: #ccc;
    padding: 1rem;
}

@media screen and (min-width: 767px) {

    #wrapper {
        font-size: 1.6rem;
    }


    .page-top {
        top: 70px;
    }

    nav {
        height: 70px;
    }

    .drawer {
        height: 70px;
    }

    #logo img {
        width: 200px;
    }

    /*ナビゲーション部分*/

    .menu ul li a {
        font-size: 1.2rem;
    }

    /*トグルボタンのスタイルを指定*/
    .Toggle {
        width: 64px;
        height: 42px;
    }

    .Toggle span {
        width: 40px;
    }


    .Toggle span:nth-child(2) {
        top: 20px;
    }

    .Toggle span:nth-child(3) {
        top: 35px;
    }


    /* スライド*/






    /*コンテンツエリア*/

    #main__content {
        overflow-x: hidden;
    }

    .site__wrap .full-width {
        padding: 20px;
        text-align: center;
        -webkit-box-pack: center;
        -webkit-justify-content: center;
        -ms-flex-pack: center;
        justify-content: center;
        -webkit-box-align: center;
        -webkit-align-items: center;
        -ms-flex-align: center;
        align-items: center;
    }

    .site__wrap .full-width h2 {
        width: 40%;
        padding: 0 0px 0px;
        font-size: 1.6rem;
        margin: 0 auto;
        text-align: center;
    }

    .site__wrap .full-width img {
        width: 50%;
    }
    .full-width--ec {
        padding: 1rem 2rem;
    }
    .page-top__title,
    .news__title,
    .work__title {
        padding: 0 15rem;
        padding-top: 3.6rem;
    }

    .page-top__title {
        padding-top: 2.6rem;
    }

    .page-top__title h3,
    .news__title h3,
    .work__title h3 {
        font-size: 1.6rem;
        margin-bottom: 2rem;
    }


    .site__wrap {
        padding-bottom: 2rem;
    }

    .site__wrap > h3 img {
        width: 180px;
    }


    .site__wrap p {
        font-size: 1rem;
        margin: 1.5rem 0;
    }

    .SP-img {
        display: none !important;
    }

    .TAB-img {
        display: block !important;
    }

    .content img {
        margin: 20px 0;
    }

    .page-top__one .content img,
    .page-top__two .content img {
        border: none;
    }

    .box {
        width: 100%;
        min-width: 660px;
        background-color: #fff;
        padding: 22px;
        margin: 20px 0;
        border-radius: 5px;
    }

    .content:hover .box {
        zoom: 1;
        filter: alpha(opacity=30);
        opacity: 0.3;
        -webkit-transition: opacity 0.6s ease-in;
        -moz-transition: opacity 0.6s ease-in;
        -ms-transition: opacity 0.6s ease-in;
        -o-transition: opacity 0.6s ease-in;
        transition: opacity 0.6s ease-in;
    }

    /* マウスオーバーされた特定のDIVのスタイル */
    .content .box:hover {
        box-shadow: 0 2px 10px #666;
        color: #fff;
        cursor: pointer;

        /* opacity */
        zoom: 1;
        filter: alpha(opacity=100);
        opacity: 1;
    }

    .box figure.img {
        float: left;
    }

    .box figure.img img {
        width: 80%;
    }

    .box h4 {
        border-bottom: 4px double #464646;
        padding: 5px;
        font-size: 26px;
        padding-right: 30px;
        overflow: hidden;
        margin-bottom: 25px;
        position: relative;
        background-color: #fff;
    }

    .content a {
        display: block;
        text-decoration: none;
        border: none;
        color: #333;
        z-index: 5;
        max-width: 38rem;
    }

    .box ul {
        display: -webkit-box;
        display: -ms-flexbox;
        display: -webkit-flex;
        display: flex;
        flex-wrap: wrap;
        overflow: hidden;
        margin-top: 20px;
        background-color: #fff;
    }

    .box ul li {
        padding: 0.25rem 0.5rem;
        margin: 0.25rem 0.25rem;
        color: #FFF;
        background: #3cb371;
        border-bottom: solid 3px #008000;
        -webkit-box-shadow: 0 3px 6px rgba(0, 0, 0, 0.25);
        box-shadow: 0 3px 6px rgba(0, 0, 0, 0.25);
        border-radius: 9px;
        font-size: 0.7rem;
    }

    .box .button__red li {
        background: #ffb6c1;
        border-bottom: solid 3px #ff69b4;
    }

    .page-top__three:before {
        padding-bottom: 64%;
    }

    #view img {
        max-width: 900px;
        width: 100%;
        position: absolute;
        left: 50%;
        top: 20%;
        transform: translate(-50%, 10%);
        -webkit-transform: translate(-50%, 10%);
        -ms-transform: translate(-50%, 10%);
    }

    #thumbBtn li img {
        border: solid 1px #ccc;
        background-color: #800000;
        width: 292px;
        margin-bottom: 5px;
    }

    #thumbBtn:before {
        content: "";
        display: block;
        width: 0;
        height: 0;
        padding-bottom: 45vw;
    }

    /*bottom news */
    /**** バナー ***/
    #footer04 .banner{
        padding-top: 0;
    }
    .banner img {
    }

    .info__box {
        padding: 1rem 1rem 0.25rem 1rem;
    }




    /***フッター***/

    #footer04 .cont {
        display: -webkit-box;
        display: -webkit-flex;
        display: -ms-flexbox;
        display: flex;
        padding: 30px 0;
    }

    #footer04 .cont-item {
        display: block;
        width: calc(100% / 5);
        text-align: center;
    }

    #footer04 .nav a {
        display: block;
    }

    #footer04 .nav .ttl {
        display: block;
        margin: 30px 0 6px;
        font-size: 1rem;
        font-weight: bold;
    }

    #footer04 .nav .ttl:first-child {
        margin-top: 0;
    }

    #footer04 .nav ul {
        display: block;
        font-size: 0.9rem;
        line-height: 2;
    }

    #footer04 .company {
        margin-top: 0px;
        padding: 1rem 2rem 0rem 5rem;
        -webkit-box-pack: justify;
    }

    #footer04 .logo {
        width: 50%;
    }

    #footer04 .company__sub {
        margin-top: 0px;
        -webkit-flex-wrap: wrap;
        flex-wrap: wrap;
        -ms-flex-wrap: wrap;
        display: -webkit-box;
        display: -ms-flexbox;
        display: -webkit-flex;
        display: flex;
        -webkit-box-pack: justify;
        -ms-flex-pack: justify;
        -webkit-justify-content: space-between;
        justify-content: space-between;
        align-items: flex-end;
        padding-bottom: 1rem;
    }

    #footer04 .address {
        -webkit-box-flex: 1;
        -ms-flex: 0%;
        -webkit-flex: 0%;
        flex: 0%;
        margin: auto 0 0;
        font-size: 1.2rem;
    }

    #footer04 .tell {
        width: 100%;
        font-size: 1.0rem;
        text-align: center;
    }

    #footer04 .cont-item:nth-child(n+3) {
        margin-top: 0px;
    }

    .copyright {}

}

@media screen and (min-width: 1024px) {

    .PC-img__not {
        display: none !important;
    }
    .full-width--ec{
        max-width: 65rem;
        display: flex;
        justify-content: center;
        align-items:center;
        margin: 0 auto;
    }
    .full-width--ec_blk2 img{
        width: 100%;
        max-width: 11rem;
        max-height:11rem;
    }
    .page-top {
        top: 80px;
    }

    .header a {
        color: inherit;
    }

    header::after {

        display: none;
    }


    nav {
        width: 1024px;
        display: -webkit-box;
        display: -webkit-flex;
        display: -ms-flexbox;
        display: flex;
        height: 80px;
        margin: 0 auto;
    }


    .drawer {
        height: 80px;
    }

    #logo {
        max-width: 100%;
    }

    #logo img {}

    .Toggle {
        display: none;
    }

    .menu {
        width: 100%;
        background-color: transparent;
        margin-top: 0;
        -webkit-transform: translateX(0);
        -ms-transform: translateX(0);
        transform: translateX(0);
    }

    .menu ul {
        height: 90px;
        display: -webkit-box;
        display: -webkit-flex;
        display: -ms-flexbox;
        display: flex;
        -webkit-flex-wrap: wrap;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
        -webkit-box-pack: end;
        -webkit-justify-content: flex-end;
        -ms-flex-pack: end;
        justify-content: flex-end;
        -webkit-box-align: center;
        -webkit-align-items: center;
        -ms-flex-align: center;
        align-items: center;
    }

    .menu ul li a {
        padding: 0 1rem;
        border-bottom: none;
        color: #000;
    }

    .menu ul li a:hover {
        background-color: transparent;
    }

    .menu > ul {
        position: relative;
        width: 100%;
        max-width: 1000px;
        margin: 0 auto;
    }


    .menu > ul > li {
        float: left;
        height: 50px;
        line-height: 50px;
    }

    .menu > ul > li a {
        display: block;
        margin: 0 10px;
        font-size: 1rem;
    }

    .menu > ul > li a:hover {}

    .menu__second-level {
        visibility: hidden;
        opacity: 0;
        z-index: 1;
        padding-top: 10px;
    }

    .menu__third-level {
        visibility: hidden;
        opacity: 0;
    }

    .menu__fourth-level {
        visibility: hidden;
        opacity: 0;
    }

    .menu > ul > li:hover {
        -webkit-transition: all .5s;
        -o-transition: all .5s;
        transition: all .5s;
    }

    .menu__second-level li {
        position: relactive;
        display: block;
        width: 100%;
        background-color: rgba(246, 246, 246, 0.9);
        padding: 10px 0 10px 0;
        border: 2px solid #e6e6e6;
        box-shadow: 0 0 5px #eee;
        border-top: 0;
    }

    .menu__second-level li a {
        opacity: 1;
    }

    .menu__third-level li {}

    .menu__second-level li a:hover {
        background: #111;
        color: #00bfff !important;

    }

    .menu__third-level li a:hover {
        background: #2a1f1f;
    }

    .menu__fourth-level li a:hover {
        background: #1d0f0f;
    }

    /* 下矢印 */
    .init-bottom:after {
        position: relative;
        content: '';
        display: inline-block;
        width: 6px;
        height: 6px;
        left: 12.5px;
        top: -3.5px;
        margin: 0px 0 0 -5px;
        border-right: 1px solid #000;
        border-bottom: 1px solid #000;
        -webkit-transform: rotate(45deg);
        -ms-transform: rotate(45deg);
        transform: rotate(45deg);
    }

    .init-bottom:hover {
        border-color: #00bfff;
    }

    /* floatクリア */
    .menu > ul:before,
    .menu > ul:after {
        content: " ";
        display: table;
    }

    .menu > ul:after {
        clear: both;
    }

    .menu > ul {
        *zoom: 1;
    }

    .menu > ul > .menu__single {
        position: relative;
    }

    .menu__single .menu__second-level {
        position: absolute;
        top: 40px;
        left: -63px;
        width: 250px;
        height: 100%;
    }

    .menu__single:hover .menu__second-level {
        top: 50px;
        visibility: visible;
        opacity: 1;
        -webkit-transition: all .2s ease;
        -o-transition: all .2s ease;
        transition: all .2s ease;
    }





    /*  スライド****/

    .swiper-slide-next {
        opacity: 0.1;
    }

    .swiper-slide-prev {
        opacity: 0.1;
    }




    /*コンテンツエリア*/

    .site__wrap {
        max-width: 1000px;
        margin: 0 auto;
        /*bottom news*/
        padding: 0rem;

    }

    .full-width h2 {
        font-size: 2rem;

    }

    .site__wrap .full-width {
        padding: 0px;

    }

    .content_border {
        margin-bottom: 15px;
        background: #ffc0cb;
        box-shadow: 5px 5px 5px #999;
    }

    .content_border-green {
        background: #e1fdf1;
        box-shadow: 5px 5px 5px #999;
    }

    .img-border {
        border-bottom: 4px double #464646;
        margin: 20px 0;
    }

    .back_1 {
        background-size: contain;
    }

    .back_2 {
        background-size: contain;
    }

    .back_3 {
        background-size: contain;
    }

    .PC-img {
        display: block !important;
    }

    .wrap .content img {
        margin: 15px auto;
        width: 200px;
    }

    .box {
        min-width: 0px;
        padding: 15px;

    }

    .page-top__one .content,
    .page-top__two .content {
        margin: 5% 0 8% 0;
    }

    .page-top__one .content__box {
        width: 23%;
    }

    .page-top__two .content__box {
        width: 30%;
    }

    .box figure.img {
        float: none;
        margin: 0 auto;
        width: 80%;

    }

    .box figure.img img {
        width: 70%;

    }

    .box h4 {
        padding-right: 0px;
        font-size: 1.3rem;
    }

    .page-top__one .box h4 {}

    .box p {
        margin: 0px;
    }

    .box ul {
        margin-top: 0px;
        flex-wrap:nowrap;
    }

    .box ul li {
        font-size: 0.8rem;
        margin: 0 auto;
        width: 50%;
        margin-bottom: 5px;
        margin-left: 5px;
    }

    .content__box .box-green > a > .PC-img {
        display: flex !important;
    }

    .page-top__one .content p,
    .page-top__two .content p {
        padding-left: 10px;
        padding-right: 10px;
        font-size: 0.9rem;
    }

    .page-top__three:before {
        content: "";
        display: block;
        width: 0;
        height: 0;
        padding-bottom: 380px;

    }

    div.g-inner {
        position: relative;
        width: 100%;
        background-color: #f5f5f5;
    }

    #view {
        position: absolute;
        width: 100%;
    }

    #view img {
        max-width: 700px;
        width: 100%;
        position: absolute;
        top: 40px;
        left: 10%;
        transform: translateX(-10%);
        -webkit-transform: translateX(-10%);
        -ms-transform: translateX(-10%);
    }

    #thumbBtn {
        position: absolute;
        left: 75%;
        transform: translateX(-10%);
        -webkit-transform: translateX(-10%);
        -ms-transform: translateX(-10%);
    }

    #thumbBtn:before {
        content: "";
        display: inline-block;
        width: 0;
        height: 0;
        padding-bottom: 0vw;
    }

    #thumbBtn li {
        padding: 8px 0 0 10px;
        float: none;
        text-align: right;
        width: 100%;
        cursor: pointer;
    }

    #thumbBtn li img {
        border: solid 1px #ccc;
        margin-bottom: 0px;
    }

    .footer-inner {
        max-width: 1024px;
        margin: 0 auto;
    }

    /***フッター***/
    #footer04 .cont {
        margin: 0 auto;
    }

    #footer04 .company {
        margin: 0 auto;
    }

    #footer04 .logo {
        width: 30%;
    }

    #footer04 .address {
        font-size: 1rem;
    }

    #footer04 .tell ul {
        width: 30%;
    }
    #footer04 .banner .site__wrap .content{
        max-width: 50rem;
        margin: 1rem auto;
        margin-bottom: 2rem;
        -webkit-justify-content: space-between;
        justify-content: space-between;

    }
    #footer04 .banner .site__wrap .content a img{
        margin: 1rem;
    }
}
