@charset "UTF-8";
/* =============================================
                    COMMON
============================================= */
body{ font-family: "Noto Sans JP", "ヒラギノ角ゴ ProN W6", "Hiragino Kaku Gothic ProN", Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;}
.en{ font-family: "Roboto Condensed", "メイリオ", "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", "ＭＳ ゴシック", sans-serif; font-weight: 700;}
sup{ font-size: 70%; vertical-align: top; position: relative; top: -0.1em;}

/* =============================================
                    CONTENTS
============================================= */
*{ box-sizing: border-box;}
.btn-blue a{ background: #102749; font-weight: 700; line-height: 1.3; color: #fff; text-align: center; text-decoration: none; display: block; position: relative; cursor: pointer; border-radius: 60px;}
.btn-blue a::after{
    content: "\f105";
    font-family: FontAwesome;
    font-size: 18px;
    font-weight: bold;
    color: #fff;
    position: absolute;
    top: 50%;
    transform: translateY(-50%) rotate(0deg);
}
.btn-black a{ background: #000; font-weight: 700; line-height: 1.3; color: #fff; text-align: center; text-decoration: none; display: block; position: relative; cursor: pointer; border-radius: 60px;}
.btn-black a::after{
    content: "\f105";
    font-family: FontAwesome;
    font-size: 18px;
    font-weight: bold;
    color: #fff;
    position: absolute;
    top: 50%;
    transform: translateY(-50%) rotate(0deg);
}
.btn-list li a::before{ content: ""; position: absolute; top: 54%; transform: translateY(-50%) rotate(0deg); z-index: 1; display: block;}
.btn-list li.mini a::before{ background: url(../img/item-mini.png) center center no-repeat; background-size: 100%;}
.btn-list li.pro a::before{ background: url(../img/item-pro.png) center center no-repeat; background-size: 100%;}
.btn-list li.hybrid a::before{ background: url(../img/item-hybrid.png) center center no-repeat; background-size: 100%;}
header{ background: #fff; box-shadow: 0 0 10px rgba(0, 0, 0, 0.25); position: relative; z-index: 10;}
header .inner{ display: flex; align-items: center;}
header .logo-GDO{ margin-right: auto;}
#main{ background: #e7ecef;}
#main .box01{ background: url(../img/main-bg02.jpg) repeat-x; -webkit-animation: bgroop 30s linear infinite; animation: bgroop 30s linear infinite;}
#main .box01 p{ line-height: 1.8;}
#main .box01 p strong{ font-weight: 700; color: #e73918;}
#main .box01 nav ul{ display: flex; align-items: center; border-radius: 10px; box-shadow: 0 0 10px rgba(0, 0, 0, 0.25);}
#main .box01 nav ul li{ border-right: 1px solid #40526d; width: calc(100% / 3);}
#main .box01 nav ul li:last-of-type{ border: none;}
#main .box01 nav ul li a{ background: #102749; font-weight: 700; line-height: 1.3; color: #fff; text-align: center; text-decoration: none; display: block; position: relative;}
#main .box01 nav ul li:first-of-type a{ border-radius: 10px 0 0 10px;}
#main .box01 nav ul li:last-of-type a{ border-radius: 0 10px 10px 0;}
#main .box01 nav ul li a::after{
    content: "\f105";
    font-family: FontAwesome;
    font-size: 18px;
    font-weight: bold;
    position: absolute;
    bottom: 8px;
    left: 50%;
    transform: translateX(-50%) rotate(90deg);
}
section{ border-top: 10px solid #102749;}
section .tit-box{ text-align: center;}
section .tit-box h2{ font-weight: 700; line-height: 1.3; color: #102749;}
section .tit-box p{ font-weight: 700; color: #e73918;}
section .stit-box{ text-align: center;}
section .stit-box h3{ font-weight: 700; line-height: 1.3; color: #102749;}
#sec01 .feature-list > li{ border-bottom: 1px solid #e7ecef;}
#sec01 .feature-list li:last-of-type{ border-bottom: none; margin-bottom: 0;}
#sec01 .feature-list li .box .detail p{ line-height: 1.8;}
#sec01 .feature-list li .box .detail .sbox{ background: #e7ecef; border-radius: 8px; display: flex; align-items: center;}
#sec01 .feature-list li .box .detail .sbox .img02{ flex-shrink: 0;}
#sec01 .feature-list li .ex-list{ border-top: 1px dotted #e7ecef;}
#sec01 .feature-list li .ex-list li{ border-bottom: 1px dotted #e7ecef; display: flex; align-items: center;}
#sec01 .feature-list li .ex-list li .ico{ flex-shrink: 0;}
#sec01 .feature-list li .ex-list li p{ line-height: 1.6;}
#sec01 .feature-list li .btn-list{ flex-wrap: wrap;justify-content: center}
#sec01 .feature-list li .btn-list li{ margin-bottom: 20px}

#sec02{ background: #e7ecef;}
#sec02 .box .detail p{ line-height: 1.8;}
#sec02 .questionary-list dt{ background: #102749; background-repeat: no-repeat; border-bottom: 1px solid #fff; font-weight: 700; line-height: 1.3; color: #fff; position: relative; cursor: pointer;}
#sec02 .questionary-list dt::before,
#sec02 .questionary-list dt::after{ content: ""; background: #fff; position: absolute;}
#sec02 .questionary-list dt::before{ width: 26px; height: 2px; top: 50%; right: 20px; transform: translateY(-50%);}
#sec02 .questionary-list dt::after{ width: 2px; height: 26px; top: 50%; right: 32px; transform: translateY(-50%);}
#sec02 .questionary-list dt.ac::after{ display: none;}
#sec02 .questionary-list dt.q01{ background-image: url(../img/sec02-qa01-ico.png);}
#sec02 .questionary-list dt.q02{ background-image: url(../img/sec02-qa02-ico.png);}
#sec02 .questionary-list dt.q03{ background-image: url(../img/sec02-qa03-ico.png);}
#sec02 .questionary-list dt.q04{ background-image: url(../img/sec02-qa04-ico.png);}
#sec02 .questionary-list dt.q05{ background-image: url(../img/sec02-qa05-ico.png);}
#sec02 .questionary-list dd{ background: #fff; display: none;}
#sec02 .questionary-list dd .comment-list li{ display: flex; align-items: center;}
#sec02 .questionary-list dd .comment-list li .ico{ flex-shrink: 0;}
#sec02 .questionary-list dd .comment-list li .detail p{ line-height: 1.6;}
#sec02 .questionary-list dd .comment-list li .detail p.data{ text-align: right;}
#sec03 .product-list li{ background: #e7ecef;}
#sec03 .product-list li:last-of-type{ margin-bottom: 0;}
#sec03 .product-list li .detail h3{ font-weight: 700; line-height: 1.3;}
#sec03 .product-list li .detail p{ line-height: 1.6;}
#sec03 .product-list li .detail p:nth-of-type(1){ border-bottom: 1px solid #c6ced3;}


/* 202509  */
#sec04 .feature-list > li{ border-bottom: 1px solid #e7ecef;}
#sec04 .feature-list li:last-of-type{ border-bottom: none; margin-bottom: 0;}
#sec04 .feature-list li .box .detail p{ line-height: 1.8;}


/* // 202509  */



.swiper .swiper-button-prev{
    left: 0px !important;
}
.swiper .swiper-button-next{
    right: 0px !important;
}
.swiper .swiper-button-next::after, .swiper .swiper-button-prev::after{
    font-size: 0 !important;
    width: 30px;
    height: 30px;
}
.swiper .swiper-button-prev:after{
    background: url(../img/arrow_l.png) left top no-repeat;
    background-size: 100%;
}
.swiper .swiper-button-next:after{
    background: url(../img/arrow_r.png) left top no-repeat;
    background-size: 100%;
}
.swiper .swiper-pagination{ 
    position: static;
    margin-top: 10px;  
}
.swiper .swiper-pagination-bullet {
    background-color: #102749;
    opacity: 1;
}
.swiper .swiper-pagination-bullet-active {
    background-color: #e73918;
}
#page-top{ position: fixed; z-index: 90; display: none;}
#page-top a{ display: block;}
footer{ background: #000; color: #fff; text-align: center;}
footer a{ color: #fff;}

/* ==== PC ===== */
@media screen and (min-width: 768px){
body{ font-size: 16px;}
#contents{ min-width: 1046px; overflow: hidden;}
a:hover,a:hover img{ opacity: 0.8; transition: .4s;}
.pc{ display: block;}
.sp{ display: none;}
.btn-blue a{ box-shadow: 5px 5px 20px rgba(0, 0, 0, 0.25); font-size: 24px; padding: 20px 0;}
.btn-blue a::after{ font-size: 20px; right: 15px;}
.btn-blue a:hover{ box-shadow: none; transition: .4s;}
.btn-black a{ box-shadow: 5px 5px 20px rgba(0, 0, 0, 0.25); font-size: 24px; padding: 20px 0;}
.btn-black a::after{ font-size: 20px; right: 15px;}
.btn-black a:hover{ box-shadow: none; transition: .4s;}
.btn-blue a .en,
.btn-black a .en{ font-size: 28px;}
.btn-list{ display: flex; margin-top: 60px;}
.btn-list li{ width: 510px; margin-right: auto;}
.btn-list li:last-of-type{ margin-right: 0;}
.btn-list li a::before{ width: 100px; height: 100px; left: 30px;}
.inner{ width: 1046px; margin: 0 auto; position: relative}
header{ padding: 18px 0 26px;}
header .logo-R2G{ margin-top: 6px;}
#main .mv{ background: url(../img/main-bg01_pc.jpg) center center no-repeat; background-size: cover; height: 500px; margin-bottom: 35px;}
#main .mv .inner{ height: 500px;}
#main .mv h1{ position: absolute; top: 0; right: 0;}
#main .box01{ background-size: 1250px; padding-bottom: 230px;}
@-webkit-keyframes bgroop {
    from {
        background-position: 0  bottom;
    }
    to {
        background-position: -1250px bottom;
    }
}
@keyframes bgroop {
    from {
        background-position: 0 bottom;
    }
    to {
        background-position: -1250px bottom;
    }
}
#main .box01 p{ font-size: 18px; text-align: center; margin-bottom: 10px;}
#main .box01 p:last-of-type{ margin-bottom: 35px;}
#main .box01 nav ul{ width: 750px; margin: 0 auto;}
#main .box01 nav ul li a{ font-size: 22px; padding: 15px 0 35px;}
section{ padding-top: 55px;}
section .tit-box{ margin-bottom: 60px;}
section .tit-box h2{ font-size: 52px; margin-bottom: 12px;}
section .tit-box p{ font-size: 24px;}
section .tit-box .img{ margin-top: 35px;}
section .tit-box .img img{ width: 100%;}
section .stit-box{ margin-bottom: 40px;}
section .stit-box .ico{ width: 80px; margin: 0 auto 25px;}
section .stit-box .ico img{ width: 100%;}
section .stit-box h3{ font-size: 40px;}
#sec01 .feature-list > li{ padding-bottom: 100px; margin-bottom: 60px;}
#sec01 .feature-list li .box{ display: flex; align-items: center;}
#sec01 .feature-list li:nth-of-type(even) .box{ flex-flow: row-reverse;}
#sec01 .feature-list li .box .img01{ flex-shrink: 0; width: 504px; margin-right: auto;}
#sec01 .feature-list li:nth-of-type(even) .box .img01{ margin-right: 0; margin-left: auto;}
#sec01 .feature-list li .box .img01 img{ width: 100%;}
#sec01 .feature-list li .box .detail{ width: 504px;}
#sec01 .feature-list li .box .detail p{ font-size: 18px;}
#sec01 .feature-list li .box .detail p.notes{ font-size: 14px; margin-top: 10px;}
#sec01 .feature-list li .box .detail .sbox{ padding: 20px; margin-top: 25px;}
#sec01 .feature-list li .box .detail .sbox p{ font-size: 16px;}
#sec01 .feature-list li .box .detail .sbox .img02{ width: 80px; margin-right: 20px;}
#sec01 .feature-list li .box .detail .sbox .img02 img{ width: 100%;}
#sec01 .feature-list li .ex-list{ display: flex; align-items: center; flex-wrap: wrap; margin-top: 60px;}
#sec01 .feature-list li .ex-list li{ border-bottom: 1px dotted #e7ecef; width: 50%; padding: 30px 20px;}
#sec01 .feature-list li .ex-list li:nth-of-type(odd){ border-right: 1px dotted #e7ecef;}
#sec01 .feature-list li .ex-list li .ico{ width: 60px; margin-right: 20px;}
#sec01 .feature-list li .ex-list li .ico img{ width: 100%;}
#sec01 .feature-list li .ex-list li p{ font-size: 16px;}
#sec02{ padding-bottom: 100px;}
#sec02 .box{ display: flex; align-items: center; margin-bottom: 60px;}
#sec02 .box .img01{ flex-shrink: 0; width: 504px; margin-right: auto;}
#sec02 .box .img01 img{ width: 100%;}
#sec02 .box .detail{ width: 504px;}
#sec02 .box .detail p{ font-size: 18px;}
#sec02 .questionary-list dt{ background-size: 50px; background-position: left 20px center; font-size: 24px; padding: 25px 0px 25px 90px;}
#sec02 .questionary-list dd{ padding: 30px;}
#sec02 .questionary-list dd .img-box{ display: flex; align-items: center; margin-bottom: 30px;}
#sec02 .questionary-list dd .img-box img{ width: 100%;}
#sec02 .questionary-list dd .img-box .img01{ width: 484px; margin-right: auto;}
#sec02 .questionary-list dd .comment-list{ display: flex; align-items: center; border-left: 1px dotted #e7ecef;}
#sec02 .questionary-list dd .comment-list li{ border-right: 1px dotted #e7ecef; display: flex; align-items: center; padding: 20px;}
#sec02 .questionary-list dd .comment-list.column3 li{ width: calc(100% / 3);}
#sec02 .questionary-list dd .comment-list.column2 li{ width: calc(100% / 2);}
#sec02 .questionary-list dd .comment-list li .ico{ width: 50px; margin-right: 15px;}
#sec02 .questionary-list dd .comment-list li .ico img{ width: 100%;}
#sec02 .questionary-list dd .comment-list li .detail p{ font-size: 16px;}
#sec02 .questionary-list dd .comment-list li .detail p.data{ font-size: 14px;}
#sec03{ padding-bottom: 100px;}
#sec03 .tit-box{ margin-bottom: 40px;}
#sec03 .product-list li{ display: flex; align-items: center; padding: 30px; margin-bottom: 40px;}
#sec03 .product-list li .img{ flex-shrink: 0; width: 320px; margin-right: 30px;}
#sec03 .product-list li .img img{ width: 100%; padding: 0 15px;}
#sec03 .product-list li .detail h3{ font-size: 34px; margin-bottom: 10px;}
#sec03 .product-list li .detail p:nth-of-type(1){ font-size: 16px; padding-bottom: 15px; margin-bottom: 15px;}
#sec03 .product-list li .detail p:nth-of-type(2){ font-size: 14px; margin-bottom: 20px;}

	
	
/*  202509  */

#sec04 .feature-list > li{ padding-bottom: 100px; margin-bottom: 60px;}
#sec04 .feature-list li .box{ display: flex; align-items: center;}
#sec04 .feature-list li:nth-of-type(even) .box{ flex-flow: row-reverse;}
#sec04 .feature-list li .box .img01{ flex-shrink: 0; width: 424px; margin-right: auto;}
#sec04 .feature-list li:nth-of-type(even) .box .img01{ margin-right: 0; margin-left: auto;}
#sec04 .feature-list li .box .img01 img{ width: 100%;}
#sec04 .feature-list li .box .detail{ width: 584px;}
#sec04 .feature-list li .box .detail p{ font-size: 18px;}
#sec04 .feature-list li .box .detail p.notes{ font-size: 14px; margin-top: 10px;}
	
#sec04 .feature-list li .box .detail h4{ font-size: 30px;padding-bottom: 50px;position: relative;letter-spacing: .05em;font-weight: 600;}
#sec04 .feature-list li .box .detail h4::after{ content: "";position: absolute;bottom: 20px;left: 0;width: 73px;height: 8px;background: #e73918;}

#sec04 .feature-list li .btn-blue a{ width: 50%;margin: 50px auto 80px}

	
	
/* // 202509  */

	
	
#page-top{ right: 20px; bottom: 20px;}
footer{ padding: 60px 0;}
footer .cp{ margin-top: 20px;}
}

/* ==== SP ===== */
@media screen and (max-width: 767px){
body{ font-size: 14px;}
img{ width: 100%;}
.pc{ display: none;}
.sp{ display: block;}
.btn-blue a{ box-shadow: 5px 5px 20px rgba(0, 0, 0, 0.25); font-size: 20px; padding: 10px 0;}
.btn-blue a::after{ font-size: 16px; right: 20px;}
.btn-black a{ box-shadow: 5px 5px 20px rgba(0, 0, 0, 0.25); font-size: 20px; padding: 10px 0;}
.btn-black a::after{ font-size: 16px; right: 20px;}
.btn-blue a .en,
.btn-black a .en{ font-size: 28px;}
.btn-list{ margin-top: 35px;}
.btn-list li{ margin-bottom: 20px;}
.btn-list li:last-of-type{ margin-bottom: 0;}
.btn-list li a::before{ width: 70px; height: 70px; left: 15px;}
header{ padding: 12px 20px 14px;}
header .logo-GDO{ width: 73px;}
header .logo-R2G{ width: 90px; margin-top: 1px;}
#main .mv h1{ margin-bottom: 20px;}
#main .box01{ background-size: 625px; padding: 0 20px 130px;}
@-webkit-keyframes bgroop {
    from {
        background-position: 0  bottom;
    }
    to {
        background-position: -625px bottom;
    }
}
@keyframes bgroop {
    from {
        background-position: 0 bottom;
    }
    to {
        background-position: -625px bottom;
    }
}
#main .box01 p{ font-size: 17px; margin-bottom: 10px;}
#main .box01 p:last-of-type{ margin-bottom: 25px;}
#main .box01 nav ul{ margin: 0 -10px;}
#main .box01 nav ul li a{ font-size: 15px; padding: 15px 0 30px;}
section{ padding-top: 35px;}
section .inner{ padding: 0 20px;}
section .tit-box{ margin-bottom: 20px;}
section .tit-box h2{ font-size: 30px; margin-bottom: 10px;}
section .tit-box p{ font-size: 14px;}
section .tit-box .img{ margin-top: 20px;}
section .stit-box{ margin-bottom: 20px;}
section .stit-box .ico{ width: 60px; margin: 0 auto 10px;}
section .stit-box h3{ font-size: 22px;}
#sec01 .feature-list > li{ padding-bottom: 50px; margin-bottom: 30px;}
#sec01 .feature-list li .box .img01{ margin-bottom: 15px;}
#sec01 .feature-list li .box .detail p{ font-size: 17px;}
#sec01 .feature-list li .box .detail p.notes{ font-size: 12px; line-height: 1.6; text-indent: -15px; padding-left: 15px; margin-top: 10px;}
#sec01 .feature-list li .box .detail .sbox{ padding: 15px; margin-top: 15px;}
#sec01 .feature-list li .box .detail .sbox p{ font-size: 14px;}
#sec01 .feature-list li .box .detail .sbox .img02{ width: 60px; margin-right: 10px;}
#sec01 .feature-list li .ex-list{ margin-top: 20px;}
#sec01 .feature-list li .ex-list li{ border-bottom: 1px dotted #e7ecef; padding: 15px;}
#sec01 .feature-list li .ex-list li .ico{ width: 40px; margin-right: 15px;}
#sec01 .feature-list li .ex-list li p{ font-size: 14px;}
#sec02{ padding-bottom: 50px;}
#sec02 .box{ margin-bottom: 25px;}
#sec02 .box .img01{ margin-bottom: 15px;}
#sec02 .box .detail p{ font-size: 17px;}
#sec02 .questionary-list{ margin: 0 -20px;}
#sec02 .questionary-list dt{ background-size: 40px; background-position: left 20px center; font-size: 20px; padding: 20px 40px 20px 70px;}
#sec02 .questionary-list dd{ padding: 20px 20px 0 20px;}
#sec02 .questionary-list dd .img-box{ margin-bottom: 20px;}
#sec02 .questionary-list dd .comment-list{ border-top: 1px dotted #e7ecef;}
#sec02 .questionary-list dd .comment-list li{ border-bottom: 1px dotted #e7ecef; padding: 15px;}
#sec02 .questionary-list dd .comment-list li:last-of-type{ border-bottom: none;}
#sec02 .questionary-list dd .comment-list li .ico{ width: 40px; margin-right: 15px;}
#sec02 .questionary-list dd .comment-list li .detail p{ font-size: 14px;}
#sec02 .questionary-list dd .comment-list li .detail p.data{ font-size: 12px;}
#sec02 .questionary-list dd .img02{ margin: 0 -20px;}
#sec03{ padding-bottom: 50px;}
#sec03 .product-list li{ padding: 15px 0 20px; margin-bottom: 20px;}
#sec03 .product-list li .img img{ padding: 0 15px;}
#sec03 .product-list li .detail{ padding: 15px 25px 0;}
#sec03 .product-list li .detail h3{ font-size: 28px; text-align: center; margin-bottom: 5px;}
#sec03 .product-list li .detail p:nth-of-type(1){ font-size: 14px; padding-bottom: 10px; margin-bottom: 10px;}
#sec03 .product-list li .detail p:nth-of-type(2){ font-size: 12px; margin-bottom: 15px;}
	
/*  202509  */

#sec04 .feature-list > li{ padding-bottom: 50px; margin-bottom: 30px;}
#sec04 .feature-list li .box .img01{ margin-bottom: 15px;}
#sec04 .feature-list li .box .detail p{ font-size: 17px;}
#sec04 .feature-list li .box .detail p.notes{ font-size: 12px; line-height: 1.6; text-indent: -15px; padding-left: 15px; margin-top: 10px;}

#sec04 .feature-list li .box .detail h4{ font-size: 28px;padding-bottom: 40px;position: relative;letter-spacing: .05em;font-weight: 600;text-align: center;}
#sec04 .feature-list li .box .detail h4::after{ content: "";position: absolute;bottom: 15px;left: 50%;width: 60px;height: 5px;background: #e73918;transform: translateX(-50%)}

#sec04 .feature-list li .btn-blue a{ width: 100%;margin: 20px auto 40px}


/* // 202509  */


#page-top{ right: 10px; bottom: 20px; width: 12%;}
footer{ font-size: 10px; padding: 30px 0;}
footer .cp{ margin-top: 10px;}
}