@charset "utf-8";
/*----------------------------------------
    common set
----------------------------------------*/
html{
	font-family:'游ゴシック体', 'Yu Gothic', YuGothic,'メイリオ',Meiryo,'ヒラギノ角ゴ Pro W3','Hiragino Kaku Gothic Pro','ＭＳ ゴシック',sans-serif;
	font-size:62.5%;
	color: #000;
	-webkit-text-size-adjust:100%;
	line-height:1.5;
	font-weight: 500;
}
body {
    min-width: auto;
    overflow: hidden;
}
.center {
    text-align: center;
}

/*font-size*/
.text_10{ font-size: 1.0rem;}
.text_12{ font-size: clamp(1.0rem,1.154vw,1.2rem);}
.text_14{ font-size: clamp(1.2rem,1.346vw,1.4rem);}
.text_16{ font-size: clamp(1.4rem,1.538vw,1.6rem);}
.text_18{ font-size: clamp(1.5rem,1.731vw,1.8rem); }
.text_20{ font-size: clamp(1.7rem,1.923vw,2.0rem); }
.text_22{ font-size: clamp(1.7rem,2.115vw,2.2rem);}
.text_24{ font-size: clamp(1.8rem,2.308vw,2.4rem);}
.text_26{ font-size: clamp(1.8rem,2.500vw,2.6rem); }
.text_28{ font-size: clamp(2.0rem,2.692vw,2.8rem); }
.text_30{ font-size: clamp(2.0rem,2.885vw,3.0rem); }
.text_32{ font-size: clamp(2.0rem,3.077vw,3.2rem); }
.text_34{ font-size: clamp(2.1rem,3.269vw,3.4rem); }
.text_36{ font-size: clamp(2.2rem,3.462vw,3.6rem); }
.text_46{ font-size: clamp(2.6rem,4.423vw,4.6rem); }


img {
    max-width: 100%;
}
img.respon {
    object-fit: unset;
    width: 100%;
    height: auto;
}

.rela {
    position: relative;
}

.bg_beige {
    background-color: #fdfcf4;
}

/* under_page */
.pan_nav{
    display: flex;
    column-gap: 20px;
    padding-top: 30px;
    padding-bottom: 30px;
}
.pan_nav a{
    position: relative;
}
.pan_nav a::after{
    content: ">";
    position: absolute;
    right: 0;
    top: 50%;
    transform: translate(150%,-50%);
}
.pan_nav.text_white a{
    color: #fff;
}
/*----------------------------------------
    contents
----------------------------------------*/

/* layout frame */
.const--container{
    font-size: 1.6rem;
}
/* .const--container p{
    line-height: 180%;
} */
p{
    line-height: 180%;
}
.pan_frame {
    width: 75%;
    max-width: 1280px;
    margin: 0 auto 0;
    padding-bottom: 100px;
}
.const--insert{
    width: 75%;
    max-width: 1280px;
    /* min-width: 1000px; */
    margin: 0 auto 0;
    padding: 100px 0;
}
.wrap{overflow: hidden;}

/* text_ style */
.under_line{
    display: inline-block;
    border-bottom: 5px solid #000;
    padding: 0 0 5px 0;
}

.title-const{
    text-align: center;
    margin: 0 0 50px 0;
}
.title-const h2{
    font-size: 7.0rem;
    font-family: din-2014, sans-serif;
    font-weight: 700;
    line-height: 1;
}
.title-const p{
    font-size: 2.4rem;
    font-weight: 800;
}
.copy{
    text-align: center;
    font-size: 3.0rem;
    font-weight: 800;
    line-height: 1.2;
}

.const-list-title{
    overflow: hidden;
    padding: 30px 0;
}
.const-list-title .num{
    font-size: 18rem;
    font-family: din-2014, sans-serif;
    font-weight: 700;
    line-height: 1;
    float: right;
    color: #be0d0d;
}
.const-list-title h2{
    float: left;
    font-size: 7.7rem;
    margin: 50px 0 0 0;
    color: #be0d0d;
}
.const-list-title h2 span{
    display: inline-block;
    padding: 0 0 5px 0;
    border-bottom: 8px solid #be0d0d;
}

.const--title {
    padding-bottom: 120px;
    margin-bottom: 120px;
    border-bottom: 1px solid #000;
}

@media screen and (max-width: 800px) {
    .const-list-title .num {
        font-size: 5.0rem;
        float: none;
        text-align: center;
    }
    .const-list-title h2 {
        float: none;
        font-size: 3.7rem;
        margin: 10px 0 0 0;
        text-align: center;
    }
    .const-list-title h2 span {
        border-bottom: 5px solid #be0d0d;
    }
    .const-list-title {
        /* padding: 40px 0; */
    }
}

/**/
.const-list-item {
    margin: 100px 0 0 0;
}
.const-list-item h2{
    font-size: 3.5rem;
    text-align: center;
    margin: 0 0 40px 0;
    line-height: 150%;
}
.const-list-item .box h3 {
    text-align: center;
    margin: 0 0 40px 0;
}

.const-list-item .box .right{
    width: 60%;
    margin: 0 auto 30px;
    border: 1px solid #ddd;
}
.const-list-item .box .right iframe{
    width: 100%;
    height: 500px;
}
.const-list-item .box p.lead{
    width: 800px;
    margin: 0 auto;
}
.const-list h2.ttl{
    margin: 0 0 30px 0;
}
/* hyblid */
.hyblid > ul > li{
    overflow: hidden;
    padding: 50px 0;
    border-top: 1px solid #000;
}
.hyblid > ul > li:first-child {
    border-top: none ;
}
.hyblid > ul > li > .pic {
    float: left;
    width: 35%;
}
.hyblid > ul > li > .txt{
    float: right;
    width: 60%;
    position: relative;
}
.hyblid > ul > li > .pic.box50,
.hyblid > ul > li > .txt.box50 {
    width: 48%;
}
.hyblid > ul > li > .txt .inn h3{
    font-weight: 800;
    margin: 0 0 30px 0;
}
/**/
.first-left{
    width: 48%;
    float: left;
}
.first-left h2{
    font-size: 3.5rem;
    font-weight: 800;
}
.first-left .label{line-height: 1;margin: 30px 0;}
.first-left .label span{
    color: #fff;
    background-color: #02CBE5;
    padding: 5px 30px;
    border-radius: 30px;
    font-family: din-2014, sans-serif;
    font-weight: 700;
    font-size: 2.0rem;
    line-height: 1;
}
.first-left .youtube{
    margin: 30px 0 0 0;
}
.first-left .youtube iframe{
    width: 100%;
    height: 400px;
}

.first-right{
    width: 48%;
    float: right;
    background-color: #f1f1f1;
    padding: 30px;
}
.first-right .md{
    text-align: center;
    font-size: 2.0rem;
    font-weight: 800;
    line-height: 150%;
    margin: 0 0 20px 0;
}
.first-right .pic img{
    width: 100%;
    height: auto;
}
.first-right ul{overflow: hidden;}
.first-right ul li:first-child{
    width: 100%;
}
.first-right ul li{
    width: 32%;
    float: left;
    margin: 0 2% 0 0;
}
.first-right ul li:last-child{margin: 0;}
.first-right ul li .pic{
    height: 120px;
}
.first-right ul li .pic img{
    object-fit: cover;
    width: 100%;
    height: 100%;
}
.first-right .pic-left{
    width: 48%;
    float: left;
}
.first-right .pic-left .pic{
    height: 280px;
}
.first-right .pic-left .pic img{
    object-fit: cover;
    width: 100%;
    height: 100%;
}

.first-right .pic-right{
    width: 48%;
    float: right;
}
.first-right .pic-right .pic{
    height: 150px;
}
.first-right .pic-right .pic img{
    object-fit: cover;
    width: 100%;
    height: 100%;
}
.first-right .wrap p{
    font-size: 1.2rem;
}
/*  mv  */
.main-const{
    /* margin: 0 0 100px 0; */
}
.main-const img{
    width: 100%;
    height: auto;
}
/* concept */
.const--concept > .const--insert {
 padding: 0 0 100px;
 border-bottom: 1px solid #000;
}
.const--concept .logo {
 margin-bottom: 50px;
 text-align: center;
}
.const--concept .logo p {
 margin-top: 20px;
 font-size: 2.2rem;
 font-weight: 700;
}
.const--concept .logo p::before,
.const--concept .logo p::after {
 content: "―";
 display: inline-block;
}
.const--concept .logo p::before {
 margin-right: 0.5em;
}
.const--concept .logo p::after {
 margin-left: 0.5em;
}
.const--concept .copy {
 line-height: 1.75;
 max-width: 960px;
 margin: auto;
}
.const--concept .txt {
    max-width: 960px;
    margin: 30px auto 0;
    font-size: 1.5rem
}
::-webkit-full-page-media, :future, :root .const--concept .copy {
    width: 900px;
}
::-webkit-full-page-media, :future, :root .const--concept .txt {
    width: 900px;
}
/* eco */
.eco-bottom {
    display: flex;
    justify-content: space-between;
    width: 100%;
    margin-top: 40px;
    padding: 60px 80px 35px 70px;
    background-color: #F2F2F2;
}
.eco-bottom .txt {
    width: 48%;
}
.eco-bottom .txt p {
    margin: 1em 0 0;
}
.eco-bottom .video {
    width: 42%;
}
.eco-bottom .video .link {
    position: relative;
    display: block;
    margin-top: 1em;
    padding-left: 50px;
    color: #BE0C0D;
}
.eco-bottom .video .link::before {
    content: "";
    position: absolute;
    left: 0;
    top: 50%;
    width: 37px;
    height: 26px;
    margin-top: -13px;
    background: url(../img/ico-youtube.png) left top / 100% auto no-repeat;
}
/* three */
.three {
 margin: 50px 0 ;
}
.three ul{overflow: hidden;}
.three ul li{
 width: 32%;
 float: left;
 margin: 0 2% 0 0;
}
.three ul li:last-child{margin: 0;}
.three ul li .pic img{
 width: 100%;
 height: auto;
}
.three ul li .md{
 text-align: center;
 border-top: 1px solid #ddd;
 padding: 15px 0;
 font-size: 2.0rem;
 font-weight: 800;
}
/* two */
.two {margin: 50px 0 0 0;}
.two ul{overflow: hidden;}
.two ul li{
 width: 48%;
 float: left;
 margin: 0 4% 0 0;
 text-align: center;
 overflow: hidden;
}
.two ul li:last-child{
 margin: 0;
 background-color: #f1f1f1;
 padding: 15px;
}
.two ul li img{
 max-width: 100%;
 height: auto;
}
.two ul li .pic img{
 width: 100%;
 height: auto;
}
.two ul li .pic {
 width: 38%;
 float: left;
}
.two ul li .txt {
 width: 58%;
 float: right;
 text-align: left;
}
.two ul li .txt h3{
 text-align: left;
 border-bottom: 1px solid #ddd;
 padding: 0 0 6px 0;
 margin: 0 0 12px 0;
 font-size: 1.7rem;
 font-weight: 800;
}
.past{
 background-color: #fff;
 padding: 7px;
 font-size: 1.2rem;
 margin: 0 0 10px 0;
}
.two ul li .txt p{
 margin: 0 0 5px 0;;
}
.two ul li .txt .blue{
 font-size: 1.6rem;
 font-weight: 800;
}

/**/
.three-right{
    width: 48%;
float: right;
}
.three-right img{
width: 80%;
height: auto;
}

/* chart sign */
.chart img{width: 100%;height: auto;}
.chart {
 width: 40%;
 float: left;
}
.sign{
 float: right;
 width: 55%;
 border-left: 1px solid #ddd;
 padding: 0 0 0 50px;
}
.sign h3{
 background-color: #f1f1f1;
 padding: 10px 0;
}
.sign .pic img{
 width: 100%;
 height: auto;
 border: 1px solid #ddd;
}
.sign .pic{
 width: 220px;
 float: left;
 margin: 0 30px 0 0;
}

/* ライオン部分　*/
.cept{
 height: 400px;
 background-image: url(../img/cept.jpg);
 background-attachment: fixed;
 background-position: center center;
 background-size: cover;
 position: relative;
}
.cept .inn{
 position: absolute;
 top: 50%;
 left: 50%;
 -webkit-transform: translateY(-50%) translateX(-50%);
 transform: translateY(-50%) translateX(-50%);
 width: 95%;
 z-index:1;
 text-align: center;
 color: #fff;
 vertical-align: middle;
}
.cept .inn h2{
 font-size: 3.2rem;
 font-weight: 800;
 margin: 0 0 30px 0;
}
.cept .inn h2 span {
    display: inline-block;
    padding: 10px 30px;
    background-color: #000;
}
/*　btn */
.bt{width: 350px;margin: 0 auto;}
.bt span{
 display: block;
 text-align: center;
 background-color: #fff;
 padding: 12px 0;
 border-radius: 30px;
}
@media screen and (max-width: 800px) {
    .bt {
        width: 220px;
    }
    .bt span {
        padding: 10px 0;
    }
}
/* security */
.security {
 padding: 100px 0 50px;
 border-top: 1px solid #000;
}
.security h3 {
 color: #0C8C92;
 font-size: 5.8rem;
 font-weight: 900;
 font-feature-settings: "palt";
 text-align: center;
}
.security p.lead {
 width: 60%;
 margin: 1em auto 0;
 line-height: 1.9;
 font-size: 1.5rem;
 text-align: left;
}
.security .service {
 display: flex;
 justify-content: space-between;
 margin-top: 75px;
}
.security .service > div {
 position: relative;
}
.security .service > div::after {
 content: "";
 position: absolute;
}
.security .service .heading {
 position: absolute;
 top: -20px;
 margin: 0;
 padding: 20px 40px 20px 20px;
 color: #fff;
 font-size: 2.4rem;
 font-weight: 900;
 line-height: 1;
}
.security .service h4 {
 color: #0C8C92;
 font-feature-settings: "palt";
}
.security .service .txt {
 margin: 0;
 font-size: 1.5rem;
}
.security .service .basic {
 width: 39%;
 padding: 70px 50px 50px;
 background-color: #F6F7F7;
}
.security .service .basic::after {
 right: 15px;
 bottom: 30px;
 width: 222px;
 height: 201px;
 background: url(../img/quality_deco01.png) left top / 100% auto no-repeat;
}
.security .service .basic .heading {
 left: 50px;
 background-color: #666;
}
.security .service .basic h4 {
 font-size: 4.1rem;
 line-height: 1.2;
}
.security .service .basic h4 small {
 display: block;
 margin-left: 2em;
 color: #0C8C92;
 font-size: 1.5rem;
 font-weight: 400;
}
.security .service .basic h4 + .txt {
 margin-top: 1em;
 line-height: 1.9;
}
.security .service .option {
 width: 55%;
 padding: 65px 40px 30px;
 background-color: #D2DEDF;
}
.security .service .option::before {
    content: "";
    position: absolute;
    top: 50%;
    left: -48px;
    width: 25px;
    height: 25px;
    margin-top: -12.5px;
    background: url(../img/ico-plus.png) left top / 100% auto no-repeat; 
}
.security .service .option::after {
 top: -115px;
 right: -3px;
 width: 182px;
 height: 174px;
 background: url(../img/quality_deco02.png) left top / 100% auto no-repeat;
}
.security .service .option .heading {
 left: 40px;
 background-color: #0C8C92;
}
.security .service .option h4 {
 font-size: 3.7rem;
}
.security .service .option h4 small {
 margin-left: 0.5em;
 color: #0C8C92;
 font-size: 2.9rem;
}
.security .service .option ul > li {
 padding: 20px 40px 20px 20px;
 background-color: #fff;
}
.security .service .option ul > li::after {
 display: block;
 clear: both;
 content: "";
}
.security .service .option ul > li + li {
 margin-top: 15px;
}
.security .service .option ul > li .img {
 float: right;
 width: 32%;
 margin-left: 30px;
}
.security .service .option ul > li .img img {
 max-width: 100%;
}
.security .service .option ul > li .txt {
 margin-top: 1em;
 line-height: 1.3;
}
.security .service .notes {
 color: #0C8C92;
 margin: 0;
 font-size: 1.5rem;
 text-align: right;
}
.security .security_txt {
 margin: 50px 0 0;
 font-size: 1.5rem;
 text-align: center;
}
/**/
.acc-circle {
    position: absolute;
    top: 0;
    left: 0;
    transform: translate(10%,-30%);
}
.ins-figure {
    max-width: 760px;
    margin-left: auto;
    margin-right: auto;
}
.two_list {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: 15px;
}
.two_list > div {
    width: 48%;
}
@media screen and (max-width: 1280px) {

    .security {
        padding: 50px 0 25px;
    }
    .security h3 {
        font-size: 3.7rem;
        line-height: 150%;
    }
    .security p.lead {
        width: 100%;
    }
    .security .service .heading {
        width: 80%;
        padding: 10px;
        font-size: 1.8rem;
        text-align: center;
    }
    .security .service {
        display: block;
        margin-top: 30px;
    }
    .security .service .basic {
        width: 100%;
        padding: 40px 30px 200px;
    }
    .security .service .basic::after {
        right: 0;
        bottom: 15px;
    }
    .security .service .basic .heading {
        left: 50%;
        transform: translateX(-50%);
    }
    .security .service .basic h4 {
        font-size: 3.0rem;
    }
    .security .service br {
        display: none;
    }
    .security .service .option {
        width: 100%;
        margin-top: 100px;
        padding: 200px 20px 20px;
    }
    .security .service .option::before {
        top: -70px;
        left: 50%;
        margin-top: 0;
        margin-left: -12.5px;
    }
    .security .service .option::after {
        top: 30px;
        left: 50%;
        transform: translateX(-50%);
    }
    .security .service .option .heading {
        left: 50%;
        transform: translateX(-50%);   
    }
    .security .service .option h4 {
        font-size: 3.0rem;
    }
    .security .service .option h4 small {
        display: block;
        font-size: 2.0rem;
        margin-left: 0;
        margin-top: 5px;
    }
    .security .service .option ul > li {
        padding: 15px;
    }
    .security .service .option ul > li .img {
        float: none;
        width: 100%;
        margin-left: 0;
        margin-bottom: 20px;
        text-align: center;
    }
    .security .security_txt {
        margin-top: 25px;
    }
    .security .service .basic h4 small {
        margin-left: 0;
    }

}
@media screen and (max-width: 1100px) {

    .first-left {
        width: 100%;
        float: none;
    }
    .first-left h2 {
        font-size: 2.5rem;
        line-height: 150%;
    }
    .first-left .label {
        margin: 20px 0;
    }
    .first-left .label span {
        padding: 3px 20px;
        font-size: 1.5rem;
    }
    .first-left .youtube {
        margin: 20px 0 10px 0;
    }
    .first-left .youtube iframe {
        aspect-ratio: 4 / 3;
        width: 100%;
        height: auto;
    }
    .first-right {
        width: 100%;
        float: none;
        padding: 15px;
    }
    .first-right .md {
     font-size: 1.7rem;
        margin: 0 0 10px 0;
    }
    .first-right .pic-left {
        width: 100%;
        float: none;
    }
    .first-right .pic-right {
        width: 100%;
        float: none;
    }
    .first-right .pic-right .pic {
        height: 200px;
    }

}

@media screen and (max-width: 1000px) {
    .const--concept .copy {
        width: 100%;
    }
    .const--concept .txt {
        width: 100%;
    }
    ::-webkit-full-page-media, :future, :root .const--concept .copy {
        width: 100%;
    }
    
    ::-webkit-full-page-media, :future, :root .const--concept .txt {
        width: 100%;
    }

    .sign {
        float: none;
        width: 100%;
        border-left: none;
        padding: 0 0 0 0px;
    }
    .const-list-item .box .sign h3 {
        padding: 7px 0;
        font-size: 1.5rem;
    }
    .sign .pic {
        width: 180px;
        float: none;
        margin: 0 auto 15px;
    }
    .sign .txt {
        float: none;
        width: 100%;
    }
    .sign .txt dt {
        border-bottom: none;
        margin: 0 0 15px 0;
    }
    .chart {
        width: 100%;
        float: none;
        margin: 0 0 15px 0;
    }
    
}
@media screen and (max-width: 800px) {
.sp_left {
    text-align: left;
}
p {
    font-size: 1.5rem;
    line-height: 150%;
}

.main-const {
    /* margin: 0 0 50px 0; */
}
.title-const{
 margin: 0 0 30px 0;
}

.title-const h2 {
    font-size:4.0rem;
}
.title-const p {
    font-size:1.8rem;
    margin: 0;
}
.copy {
    font-size: 2.0rem;
    font-feature-settings: 'palt';
}
.const--concept {
    /* margin-bottom: 60px; */
}
.const--concept > .const--insert {
    padding: 0 20px 50px;
}
.const--concept .logo img {
    max-width: 100%;
}
.const--concept .logo p {
    margin-top: 10px;
    font-size:1.6rem;
}
.pan_frame{
    width: 100%;
    padding: 0px 20px 20px;
}
.const--insert {
    width: 100%;
    padding: 50px 20px;
    /* max-width: 100%;
    min-width: 100%;
    padding: 0 20px; */
}
.const-list {
    /* margin: 50px 0 0 0; */
}
.const-list-top {
    display: block;
    padding-top: 50px;
    text-align: center;
}
.const-list-top h2 {
    font-size: 5.0rem;
}
.const-list-top .txt {
    margin-left: 0;
    margin-top: 1em;
}


.eco-bottom {
    display: block;
    padding: 30px;
    margin-top: 20px;
}
.eco-bottom .txt {
    width: 100%;
}
.eco-bottom .video {
    width: 100%;
    margin-top: 20px;
}
.eco-bottom .video img {
    max-width: 100%;
}

.const-list-item {
    margin: 60px 0 0 0;
}
.const-list-item h2 {
    font-size: 2.5rem;
    margin: 0 0 20px 0;
}
.const-list-item .box {
    /* margin: 0 0 50px 0; */
}
.const-list-item .box h3 {
    margin: 0 0 20px 0;
    font-size: 2.0rem;
    line-height: 150%;
}
.const-list-item .box h3 span {
    border-bottom: 3px solid #000;
}
.const-list-item .box .right {
    width: 100%;
    margin: 0 auto 20px;
}
.const-list-item .box .right iframe {
    height: 200px;
}
.const-list-item .box p.lead {
    width: auto;
    text-align: left;
}
.const-list-item .box p.lead br{display: none;}
.three {
    margin: 25px 0;
}
.three ul li {
    width: 100%;
    float: none;
    margin: 0 0 25px 0;
}

.three ul li .md {
    padding: 12px 0;
    font-size: 1.6rem;
}

.cept {
    height: 300px;
    background-attachment:inherit;
}
.cept .inn h2 {
    font-size: 20px;
    margin: 0 0 20px 0;
}

.const-list h2.ttl {
    margin: 0 0 20px 0;
    font-size: 2.5rem;
    line-height: 150%;
}

.hyblid > ul > li > .pic {
    float: none;
    width: 100%!important;
    /* height: 200px; */
    margin: 0 0 20px 0;
}

.hyblid > ul > li > .txt {
    float: none;
    width: 100%!important;
    height: auto;
}
.hyblid > ul > li > .txt .inn {
    position:relative;
    top:auto;
    left:auto;
    -webkit-transform: inherit;
    transform:inherit;
}
.hyblid > ul > li > .txt .inn h3 {
    font-size: 2.0rem;
    margin: 0 0 20px 0;
}


.two {
    margin: 30px 0 0 0;
}
.two ul li {
    width: 100%;
    float: none;
    margin: 0 0 15px 0;
}
.three-right {
    width: 100%;
    float: none;
}
.three-right img {
    width: 100%;
}

.two_list > div {
    width: 100%;
}

}

