@charset "UTF-8";
/* =============================================
                    CONTENTS
============================================= */
body{ background: #fff; width: 100vw; overflow-x: clip;}
#contents{ background: #000;}
.inner{ position: relative;}
.en{ font-family: "Roboto Condensed", sans-serif; font-weight: 700;}
.special-bnr a{ box-shadow: 0 0 20px rgba(0, 0, 0, 0.9); transition: .4s; display: block;}
.red-btn a{ background: #d81e19; font-weight: 700; color: #fff; text-align: center; text-decoration: none; box-shadow: 4px 4px 20px rgba(0, 0, 0, 0.4); display: block; position: relative;}
.red-btn a::after{ content: ""; border-top: 2px solid #fff; border-right: 2px solid #fff; width: 8px; height: 8px; transform: rotate(45deg); position: absolute; top: 50%; margin-top: -6px;}
/* main */
#main .detail p{ line-height: 1.8; color: #fff;}
/* section */
section .tit-box{ text-align: center;}
section .tit-box p{ line-height: 1.0; color: #d81e19;}
section .tit-box h2{ font-weight: 900; line-height: 1.3; color: #fff;}
section .read{ line-height: 1.8; color: #fff;}
#sec01 .text-box p{ line-height: 1.8; color: #fff;}
#sec01 .text-box p:last-of-type{ margin-bottom: 0;}
#sec01 .box01{ background: url(../img/sec01-box01-bg.jpg) top left repeat;}
#sec01 .box01 .struggle-list{ display: flex; flex-wrap: wrap;}
#sec01 .box01 .struggle-list li{ text-align: center; margin-right: auto;}
#sec01 .box01 .struggle-list li p{ font-weight: 700; line-height: 1.6; color: #fff;}
#sec01 .box01 .struggle-list li p strong{ font-weight: 700; color: #d81e19;}
#sec01 .box02{ background: url(../img/sec01-box02-bg.jpg) top left repeat;}
#sec02 .tit-box h2{ color: #000;}
#sec02 .read{ color: #000;}
#sec02 .box{ position: relative;}
#sec02 .box::before{ content: ""; background: #000; width: 1px; position: absolute; top: 0; left: 50%; transform: translateX(-50%);}
#sec02 .box h3{ font-weight: 900; line-height: 1.3; text-align: center;}
#sec02 .box .profile{ display: flex; align-items: center; justify-content: center;}
#sec02 .box .profile .detail .name{ font-weight: 700; line-height: 1.0;}
#sec02 .box .profile .detail .data{ font-weight: 700; line-height: 1.0;}
#sec02 .box .comment-list li:last-of-type{ margin-bottom: 0;}
#sec02 .box .comment-list li p{ line-height: 1.8;}
#sec03 .scroll table{ width: 100%;}
#sec03 .scroll table th{ background: #ededed; border: 1px solid #333; line-height: 1.3; text-align: center; vertical-align: middle;}
#sec03 .scroll table td{ background: #fff; border: 1px solid #333; line-height: 1.3; text-align: center; vertical-align: middle;}
/* footer */
footer .bottom{ background: #000;}
footer .bottom p,
footer .bottom p a{ color: #fff;}

/* ==== PC ===== */
@media screen and (min-width: 768px){
.inner{ width: 1080px; margin: 0 auto;}
.special-bnr a:hover{ box-shadow: none;}
.red-btn{ width: 520px; margin: 0 auto;}
.red-btn.two-lines a{ padding: 17px 0 21px; border-radius: 42px;}
.red-btn.one-line a{ padding: 30px 0 34px; border-radius: 42px;}
.red-btn a:hover{ box-shadow: none;}
.red-btn p{ font-size: 20px;}
.red-btn p.sub{ font-size: 16px; margin-bottom: 10px;}
.red-btn a::after{ right: 40px;}
/* main */
#main .mv{ background-image: url(../img/main-bg01_pc.jpg) , url(../img/main-bg02_pc.jpg);background-position: top center, top left; background-repeat: no-repeat , repeat-x;}
#main .mv .inner{ height: 660px;}
#main .mv h1{ position: absolute; left: 215px; top: 87px;}
#main .detail{ background: #000 url(../img/main-detail-bg_pc.jpg) top center repeat-y; padding: 55px 0 80px;}
#main .detail p{ font-size: 18px; text-align: center; margin-bottom: 20px;}
#main .detail p:last-of-type{ margin-bottom: 55px;}
/* section */
section .tit-box{ margin-bottom: 30px;}
section .tit-box p{ font-size: 28px; margin-bottom: 20px;}
section .tit-box h2{ font-size: 38px;}
section .read{ font-size: 18px; text-align: center; margin-bottom: 35px;}
#sec01 .text-box{ text-align: center; margin-bottom: 55px;}
#sec01 .text-box p{ font-size: 18px; margin-bottom: 20px;}
#sec01 .box01{ padding: 75px 0 100px;}
#sec01 .box01 .struggle-list{ margin-bottom: 35px;}
#sec01 .box01 .struggle-list li:last-of-type{ margin-right: 0;}
#sec01 .box01 .struggle-list li .img{ margin-bottom: 10px;}
#sec01 .box02{ padding: 75px 0 100px;}
#sec01 .box02 .img{ margin-bottom: 35px;}
#sec02{ background-color: #fff; background-image: url(../img/sec02-bg01_pc.png) , url(../img/sec02-bg02.jpg);background-position: top center, top left; background-repeat: no-repeat , repeat; padding: 75px 0 100px;}
#sec02 .tit-box h2{ font-size: 60px;}
#sec02 .box{ padding-top: 120px; margin-bottom: 40px;}
#sec02 .box.last{ margin-bottom: 60px;}
#sec02 .box::before{ height: 80px;}
#sec02 .box h3{ font-size: 38px; margin-bottom: 35px;}
#sec02 .box .profile{ margin-bottom: 40px;}
#sec02 .box .profile .detail{ margin-left: 20px;}
#sec02 .box .profile .detail .name{ font-size: 24px; margin-bottom: 10px;}
#sec02 .box .profile .detail .name span{ font-size: 16px;}
#sec02 .box .profile .detail .data{ font-size: 16px;}
#sec02 .box .comment-list li{ display: flex; align-items: center; margin-bottom: 40px;}
#sec02 .box .comment-list li:nth-of-type(even){ flex-direction: row-reverse;}
#sec02 .box .comment-list li p{ font-size: 18px; width: 520px; margin-left: auto;}
#sec02 .box .comment-list li:nth-of-type(even) p{ margin-right: auto; margin-left: 0;}
#sec03{ background: url(../img/sec03-bg_pc.jpg) top center no-repeat; padding: 75px 0 100px;}
#sec03 .tit-box h2{ font-size: 60px;}
#sec03 .read{ margin-bottom: 300px;}
#sec03 .scroll{ margin-bottom: 60px;}
#sec03 .scroll table th{ padding: 10px;}
#sec03 .scroll table td{ padding: 10px;}
#sec03 .red-btn{ margin-bottom: 60px;}
}

/* ==== SP ===== */
@media screen and (max-width: 767px){
.red-btn.two-lines a{ padding: 10px 0 14px; border-radius: 42px;}
.red-btn.one-line a{ padding: 10px 0 14px; border-radius: 42px;}
.red-btn a:hover{ box-shadow: none;}
.red-btn p{ font-size: 16px; line-height: 1.3;}
.red-btn p.sub{ font-size: 12px; margin-bottom: 4px;}
.red-btn a::after{ right: 30px;}
/* main */
#main .detail{ background: #000 url(../img/main-detail-bg_sp.jpg) top center repeat-y; background-size: 100%; padding: 25px 0 40px;}
#main .detail .inner{ padding: 0 20px;}
#main .detail p{ font-size: 17px; margin-bottom: 10px;}
#main .detail p:last-of-type{ margin-bottom: 25px;}
/* section */
section .inner{ padding: 0 20px;}
section .tit-box{ margin-bottom: 15px;}
section .tit-box p{ font-size: 19px; margin-bottom: 10px;}
section .tit-box h2{ font-size: 27px;}
section .read{ font-size: 17px; margin-bottom: 20px;}
#sec01 .text-box{ margin-bottom: 25px;}
#sec01 .text-box p{ font-size: 17px; margin-bottom: 10px;}
#sec01 .box01{ padding: 35px 0 50px;}
#sec01 .box01 .struggle-list li{ width: 47%; margin-bottom: 20px;}
#sec01 .box01 .struggle-list li:nth-child(2n){ margin-right: 0;}
#sec01 .box01 .struggle-list li .img{ margin-bottom: 5px;}
#sec01 .box02{ padding: 75px 0 100px;}
#sec01 .box02 .img{ margin-bottom: 35px;}
#sec01 .box02{ padding: 35px 0 50px;}
#sec01 .box02 .img{ margin-bottom: 20px;}
#sec02{ background-color: #fff; background-image: url(../img/sec02-bg01_sp.png) , url(../img/sec02-bg02.jpg);background-position: top center, top left; background-repeat: no-repeat , repeat; background-size: 100% , auto; padding: 35px 0 50px;}
#sec02 .tit-box h2{ font-size: 36px;}
#sec02 .box{ padding-top: 60px; margin-bottom: 20px;}
#sec02 .box.last{ margin-bottom: 25px;}
#sec02 .box::before{ height: 40px;}
#sec02 .box h3{ font-size: 27px; margin-bottom: 15px;}
#sec02 .box .profile{ margin-bottom: 20px;}
#sec02 .box .profile .ico{ width: 80px;}
#sec02 .box .profile .detail{ margin-left: 10px;}
#sec02 .box .profile .detail .name{ font-size: 19px; margin-bottom: 10px;}
#sec02 .box .profile .detail .name span{ font-size: 14px;}
#sec02 .box .profile .detail .data{ font-size: 14px;}
#sec02 .box .comment-list li{ margin-bottom: 20px;}
#sec02 .box .comment-list li p{ font-size: 17px; margin-top: 10px;}
#sec03{ background: url(../img/sec03-bg_sp.jpg) top center no-repeat; background-size: 100%; padding: 35px 0 50px;}
#sec03 .tit-box h2{ font-size: 36px;}
#sec03 .read{ margin-bottom: 24vh;}
#sec03 .scroll{ overflow-x: scroll; padding: 0 20px; margin: 0 -20px 10px;}
#sec03 .scroll table{ width: 700px;}
#sec03 .scroll table th{ padding: 5px;}
#sec03 .scroll table td{ padding: 5px;}
#sec03 p.sp{ color: #ededed; text-align: center; margin-bottom: 30px;}
#sec03 .red-btn{ margin-bottom: 30px;}

/* footer */
footer .bottom{ padding-bottom: 30px;}

}