@charset "UTF-8";
/* =============================================
                    CONTENTS
============================================= */
body{ background: #fff; width: 100vw; overflow-x: clip;}
#contents{ background: #000;}
.inner{ position: relative;}
.min{ font-family: "Noto Serif JP", serif; font-weight: 600;}
.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 .mv{ position: relative;}
#main .mv h1{ position: relative; z-index: 1;}
#main .mv .bg{ position: absolute; top: 0;}
#main .detail{ background: #111 url(../img/bg.jpg) top center repeat; padding: 55px 0 80px;}
#main .detail p{ line-height: 1.8; color: #fff;}
/* section */
#sec01,
#sec02{ background: #111 url(../img/bg.jpg) top center repeat;}
#sec01 .profile-box .inner,
#sec02 .profile-box .inner{ position: relative; z-index: 1; height: 100%;}
#sec01 .profile-box .profile,
#sec02 .profile-box .profile{ position: absolute;  top: 50%; transform: translateY(-50%);}
#sec01 .profile-box .profile h2,
#sec02 .profile-box .profile h2{ line-height: 1.0;}
#sec01 .profile-box .bg,
#sec02 .profile-box .bg{ position: absolute; top: 0;}
#sec01 .comment-box .subtit-box p{ color: #d81e19;}
#sec02 .comment-box .subtit-box p{ color: #009944;}
#sec01 .comment-box .subtit-box p,
#sec02 .comment-box .subtit-box p{ font-weight: 900; line-height: 1.3;}
#sec01 .comment-box .subtit-box p span,
#sec02 .comment-box .subtit-box p span{ font-weight: 100; color: #fff;}
#sec01 .comment-box .subtit-box h3,
#sec02 .comment-box .subtit-box h3{ font-weight: 900; line-height: 1.3; color: #fff; }
#sec01 .comment-box .comment p,
#sec02 .comment-box .comment p{ line-height: 1.8; color: #fff;}
#sec01 .comment-box .comment p strong{ color: #d81e19;}
#sec02 .comment-box .comment p strong{ color: #009944;}
#sec01 .comment-box .comment .flex-list li p span{ display: block;}
#sec03 .tit-box{ text-align: center;}
#sec03 .tit-box p{ line-height: 1.0; color: #d81e19;}
#sec03 .tit-box h2{ font-weight: 900; line-height: 1.3; color: #fff;}
#sec03 .read{ line-height: 1.8; color: #fff;}
#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 h1 img{ width: 100%;}
#main .mv .bg img{ width: 100%;}
#main .detail{ 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 */
#sec01 .profile-box,
#sec02 .profile-box{ position: relative; aspect-ratio: 1 / 0.321;}
#sec01 .profile-box .profile{ padding-left: 540px;}
#sec02 .profile-box .profile{ padding-right: 540px;}
#sec01 .profile-box .profile h2,
#sec02 .profile-box .profile h2{ font-size: 54px; margin-bottom: 35px;}
#sec01 .profile-box .profile h2 span{ font-size: 18px;}
#sec01 .profile-box .profile p,
#sec02 .profile-box .profile p{ font-size: 18px; line-height: 1.8;}
#sec01 .profile-box .bg img,
#sec02 .profile-box .bg img{ width: 100%;}
#sec01 .comment-box,
#sec02 .comment-box{ padding: 75px 0 100px;}
#sec01 .comment-box .subtit-box,
#sec02 .comment-box .subtit-box{ margin-bottom: 40px;}
#sec01 .comment-box .subtit-box p,
#sec02 .comment-box .subtit-box p{ font-size: 24px; text-align: center; margin-bottom: 30px;}
#sec01 .comment-box .subtit-box h3,
#sec02 .comment-box .subtit-box h3{ font-size: 38px; text-align: center;}
#sec01 .comment-box .comment,
#sec02 .comment-box .comment{ margin-bottom: 20px;}
#sec01 .comment-box .comment .img,
#sec02 .comment-box .comment .img{ margin-bottom: 40px;}
#sec01 .comment-box .comment p,
#sec02 .comment-box .comment p{ font-size: 18px; margin-bottom: 35px;}
#sec01 .comment-box .comment .flex-list li,
#sec02 .comment-box .comment .flex-list li{ display: flex; align-items: center; margin-bottom: 40px;}
#sec01 .comment-box .comment .flex-list li:nth-child(even),
#sec02 .comment-box .comment .flex-list li:nth-child(even){ flex-flow: row-reverse;}
#sec01 .comment-box .comment .flex-list li .img,
#sec02 .comment-box .comment .flex-list li .img,
#sec01 .comment-box .comment .flex-list li p,
#sec02 .comment-box .comment .flex-list li p{ width: 520px; margin-bottom: 0;}
#sec01 .comment-box .comment .flex-list li p span{ margin-top: 35px;}
#sec01 .comment-box .comment .flex-list li:nth-child(odd) .img,
#sec02 .comment-box .comment .flex-list li:nth-child(odd) .img{ margin-right: auto;}
#sec01 .comment-box .comment .flex-list li:nth-child(even) .img,
#sec02 .comment-box .comment .flex-list li:nth-child(even) .img{ margin-left: auto;}
#sec03{ background: url(../img/sec03-bg_pc.jpg) top center no-repeat; padding: 75px 0 100px;}
#sec03 .tit-box{ margin-bottom: 30px;}
#sec03 .tit-box p{ font-size: 28px; margin-bottom: 20px;}
#sec03 .tit-box h2{ font-size: 60px;}
#sec03 .read{ font-size: 18px; text-align: center; 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{ 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 */
#sec01 .profile-box,
#sec02 .profile-box{ position: relative; aspect-ratio: 1 / 0.867;}
#sec01 .profile-box .profile{ padding: 0 20px 0 48%;}
#sec02 .profile-box .profile{ padding: 0 48% 0 20px;}
#sec01 .profile-box .profile h2,
#sec02 .profile-box .profile h2{ font-size: 28px; margin-bottom: 15px;}
#sec01 .profile-box .profile h2 span{ font-size: 12px; display: block; margin-top: 10px;}
#sec01 .profile-box .profile p,
#sec02 .profile-box .profile p{ background: rgba(255, 255, 255, 0.6); backdrop-filter: blur(12px); font-size: 14px; line-height: 1.6; padding: 10px;}
#sec01 .comment-box,
#sec02 .comment-box{ padding: 35px 0 50px;}
#sec01 .comment-box .inner,
#sec02 .comment-box .inner{ padding: 0 20px;}
#sec01 .comment-box .subtit-box,
#sec02 .comment-box .subtit-box{ margin-bottom: 20px;}
#sec01 .comment-box .subtit-box p,
#sec02 .comment-box .subtit-box p{ font-size: 19px; margin-bottom: 10px;}
#sec01 .comment-box .subtit-box h3,
#sec02 .comment-box .subtit-box h3{ font-size: 27px;}
#sec01 .comment-box .comment,
#sec02 .comment-box .comment{ margin-bottom: 10px;}
#sec01 .comment-box .comment .img,
#sec02 .comment-box .comment .img{ margin-bottom: 20px;}
#sec01 .comment-box .comment p,
#sec02 .comment-box .comment p{ font-size: 17px; margin-bottom: 15px;}
#sec01 .comment-box .comment .flex-list li p span{ margin-top: 10px;}
#sec03{ background: url(../img/sec03-bg_sp.jpg) top center no-repeat; background-size: 100%; padding: 35px 0 50px;}
#sec03 .inner{ padding: 0 20px;}
#sec03 .tit-box p{ font-size: 19px; margin-bottom: 10px;}
#sec03 .tit-box h2{ font-size: 36px; margin-bottom: 15px;}
#sec03 .read{ font-size: 17px; 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;}

}

/* ==== SP(375px以下) ===== */
@media screen and (max-width: 375px){
#sec01 .profile-box .profile h2,
#sec02 .profile-box .profile h2{ font-size: 26px;;}
#sec01 .profile-box .profile p,
#sec02 .profile-box .profile p{ font-size: 12px;}

}
