@charset "utf-8";

/*
/*    CSS(pctb) MENU
*/



/*
*********************************************************************************
/*
/* 大枠
/*
/*******************************************************************************/

body {
	min-width: 1240px;
	overflow-x: auto;
}

/*
*********************************************************************************
/*
/* header
/*
/*******************************************************************************/


.mv::before {
	top: calc((100lvh / 2) - 215px);
	height: 26px;
}

.mv::after {
	height: 150px;
}

.mv_counter {
	width: 100px;
	gap: 0 !important;
}

.mv_door {
	width: 204px;
}

.mv_svg {
	width: 204px;
}
.mv_scroll {
	width: 45px;
	bottom: 70px;
}

.mv_scroll::after {
	height: 76px;
}
        @keyframes scrollLineAnimation {
            0% {
                height: 0vw;
                bottom: 6px;
            }
           80% {
                height: 76px;
                bottom: -70px;
            }
            100% {
                height: 0vw;
                bottom:-76px;
            }
        }

.gnav {
	width: 320px;
}

.gnav_btn {
		width: 30px;
		height: 23px;
		top: 47px;
		right: 40px;
}

.js_header_on .gnav_btn {
	right: 330px;
}


.gnav .nav_logo {
	height: 105px;
}

.gnav .nav_logo a {
	width: 112px;
}

.gnav .nav_con .cta_li {
	padding: 20px;
	gap: 20px;
}

.gnav .gnav_list a {
	height: 60px;
	font-size: 1.6rem;
	padding-left: 20px;
}

.gnav .gnav_list a::after {
	width: 8px;
	height: 100%;
	right: 25px;
	transition: 0.5s ease;
}

.gnav .gnav_list a:hover {
	opacity: 1;
	color: var(--gold);
}

.gnav .gnav_list a:hover::after {
	filter: var(--svg_gold);
	transition: 0.5s ease;
}

.gnav .nav_con {
	padding-bottom: 130px;
}

.gnav_in {
	height: auto;
}

/*
*********************************************************************************
/*
/* モジュール
/*
/*******************************************************************************/
/*------------------------------------------------------------------------------
--------------------------------------------------------------------------------
テキスト */
/*------------------------------------------------------------------------------
--------------------------------------------------------------------------------
タイトル */


.site_tl_box {
	margin-bottom: 40px;
}
.site_tl_box .site_tl_en {
	width: 705px;
	margin: 0 auto;
}


.site_tl_box .site_tl_ja {
	width: 250px;
	padding-bottom: 20px;
	margin-top: 25px;
}

.site_tl_box .site_tl_ja::after {
	width: 158px;
}


/*------------------------------------------------------------------------------
--------------------------------------------------------------------------------
リスト */
/*------------------------------------------------------------------------------
--------------------------------------------------------------------------------
ボタン */

/*------------------------------------------------------------------------------
CTA */

.cta_li a {
	height: 58px;
	font-size: 1.69rem;
}

.cta_li a::after {
	width: 15px;
	height: 20px;
	margin-top: -1px;
	right: 15px;
}



/*------------------------------------------------------------------------------
--------------------------------------------------------------------------------
youtube */


/*------------------------------------------------------------------------------
--------------------------------------------------------------------------------
mv */

/*------------------------------------------------------------------------------
--------------------------------------------------------------------------------
テキストアニメーション */


/*------------------------------------------------------------------------------
--------------------------------------------------------------------------------
message */


#message {
	padding-bottom: 35px;
}



#message .con01 {
	padding-top: 140px;
	height: 788px;
}
#message .con01 .tl {
	width: 108px;
	top: 10px;
	left: 104px;
}

#message .con01 .txt {
	width: 119px;
}
#message .con02 .txt01 {
	padding-left: calc(50% - 306px);
	height: 385px;
}

#message .con02 .txt02 {
	padding-left: calc(50% + 220px);
	height: 420px;
}

#message .message_in::before {
	background: url(../images/message_bg01_pc.webp) no-repeat center top/ cover;
	height: 964px;
	top: 630px;
	width: 100%;
}

#message .con02 {
	height: 805px;
}

#message .con03::before {
	background: url(../images/message_bg02_pc.webp) no-repeat center top /cover;
	width: 947px;
	height: 1170px;
	top: 0%;
	left: 50%;
	transform: translate(-50%, 0%);
}

#message .con03 {
	padding-top: 115px;
}
#message .con03 .txt04 {
	margin: 0 auto 0 50%;
}


#message .con03 .img01 {
	width: 660px;
	left: inherit;
	right: calc(50% - 330px + 35vw);
	top: 105px;
}

#message .con03 .inner {
	height: 1260px;
}

#message .con03 .img02 {
	opacity: 1;
	width: 660px;
	right: inherit;
	left: calc(50% - 330px + 31vw);
	bottom: 0;
}

#message .con03 .img03 {
	width: 445px;
	left: 0;
	bottom: -60px;
}

#message .con04 {
	height: 850px;
}

#message .con04 .img01 {
	width: 738px;
	top: 350px;
	left: calc(50% - 600px);
}
#message .con04 .txt05 {
  width: 170px;
}

#message .con04 .inner >.sa:first-child {position: relative;z-index: 10;}

#message .con04 .img02 {
	width: 493px;
	top: 580px;
}

#message .message_scroll a {
	width: 75px;
	height: 75px;
	bottom: -38px;
}
   
#message .message_scroll::after {
	height: 75px;
	bottom: -38px;
}

        @keyframes scrollLineAnimation02 {
            0% {
                height: 0%;
                bottom:37px;
            }
           80% {
                height: 75px;
                bottom: -38px;
            }
            100% {
                height: 0%;
                bottom:-38px;
            }
        }
/*------------------------------------------------------------------------------
--------------------------------------------------------------------------------
story */

.story_area {
	background: #f7f7f7 url(../images/story_bg_pc.webp) repeat-x center top / 2449px auto;
	padding-top: 218px;
	padding-bottom: 80px;
}
.story_area #story {
	padding-top: 0;
}

.story_area #story .inner {
	padding: 0;
	width: 840px;
	margin: 0 auto;
}


/*------------------------------------------------------------------------------
--------------------------------------------------------------------------------
history */

#history::before {
	height: 70px;
}

#history .site_tl_box {
	margin-bottom: 20px;
}
#history .site_tl_box .site_tl_en {
	margin: 0 auto;
	padding-top: 70px;
}


#history .history_sliders {display: grid;width: 1040px;margin: 0 auto;grid-template-columns: 580px 1fr;grid-template-rows: auto 220px 50px 60px;gap: 0 60px;align-items: end;padding-bottom: 80px;}

#history .history_slider01 {
	width: 100%;
	grid-column: 2 / 3;
	grid-row: 1/2;
	margin: 0 0 80px 0;
}

#history .history_slider02 {
	width: 100%;
	margin: 0;
	padding: 90px;
	height: 560px;
	grid-column: 1/2;
	grid-row: 1 / 5;
}

#history .history_slider02:before {
	background: url(../images/history_frame_pc.webp) no-repeat left center / contain;
}

#history .history_slider03 {
	grid-column: 2 / 3;
	grid-row: 2 / 3;
	width: 100%;
}
#history .history_sliders .swiper-pagination {
	grid-column: 2 / 3;
	grid-row: 4 / 5;
	padding-bottom: 15px;
	text-align: left;
}

#history  .year {
	width: 168px;
}

#history .history_slider03 .swiper-slide {
	width: 100% !important;
}

#history .txt_block .catch {
	width: 241px;
	margin: 0 0 40px;
	padding-bottom: 15px;
}

#history .txt_block .catch::after {
	width: 158px;
	left: 0;
	transform: inherit;
}

#history .txt_block .txt {
	text-align: left;
	font-size: 1.9rem;
}


#history .slide_area .link {
	grid-column: 2 / 3;
	grid-row: 3 / 4;
	margin-top: 35px;
	font-size: 1.6rem;
	text-align: left;
}

#history .slide_area .link a {
	padding-right: 37px;
}

#history .slide_area .link a::after {
	width: 15px;
	height: 20px;
	margin-top: -1px;
	right: 15px;
}

/*------------------------------------------------------------------------------
--------------------------------------------------------------------------------
vision */



#vision {background-image: url(../images/vision_bg_pc.webp);padding-bottom: 80px;}

#vision::before {
	height: 70px;
}

#vision .site_tl_box {
	margin-bottom: 35px;
	padding-top: 70px;
}

#vision .site_tl_box .site_tl_en {
	width: 705px;
	margin: 0 auto;
}

#vision .site_tl_box .site_tl_ja {
	margin-top: 40px;
}

#vision .site_tl_box .site_tl_ja::after {
	width: 158px;
}

#vision .catch {
	font-size: 2.4rem;
	margin-top: 50px;
}

#vision .con_logo {
	width: 174px;
	margin: 35px auto calc(182px + 45vw);
}

#vision .cta_li,
#news .cta_li,
.f_cta .cta_li{display: grid;grid-template-columns: 350px 350px;gap: 60px;width: 760px;margin: 0 auto;}

#vision .cta_li a ,
#news .cta_li a ,
.f_cta .cta_li a {
	height: 100px;
	font-size: 2rem;
}

#vision .cta_li a::after,
#news .cta_li a::after,
.f_cta .cta_li a::after{
	right: 40px;
}

/*------------------------------------------------------------------------------
--------------------------------------------------------------------------------
youtube */
.youtube {
	border-radius: 10px;
}

/*------------------------------------------------------------------------------
--------------------------------------------------------------------------------
news */

#news {
	padding-bottom: 75px;
	background: #fff;
}

#news::before {
	height: 70px;
	height: 75px;
	background: linear-gradient(to bottom, rgba(232, 227, 220, 1) 0%, rgb(255 255 255) 100%);
}

#news .site_tl_box {
	margin-bottom: 45px;
}
#news .site_tl_box .site_tl_en {
	width: 705px;
	padding-top: 65px;
	margin: 0 auto 40px;
}

#news .site_tl_box .site_tl_ja::after {
	width: 158px;
}

.news_li .date {
	font-size: 1.6rem;
}

.news_li {
	width: 760px;
	margin: 0 auto;
}


.news_li>li::after {
	width: 100%;
}
.news_li a {
	display: grid;
	grid-template-columns: 115px 1fr;
	padding: 16px 16px 16px 0;
	opacity: 1;
	transition: 0.5s ease;
}
.news_li a:hover {
	opacity: 1;
	transition: 0.5s ease;
	color: var(--gold)
}

.news_li a::after {
	width: 5px;
	height: 10px;
	right: 0;
}

#news .btn_link {
	width: 760px;
	margin: 40px auto 0;
	font-size: 1.6rem;
}


#news .btn_link a {
	padding-right: 22px;
}
#news .btn_link a::after {
	width: 15px;
	height: 20px;
	margin-top: -1px;
	right: 0;
}

/*------------------------------------------------------------------------------
--------------------------------------------------------------------------------
f_cta */

.f_cta {
	background: #fff url(../images/footer_bg_pc.webp) repeat-x center bottom / auto 218px;
	padding-bottom: 240px;
}

/*------------------------------------------------------------------------------
--------------------------------------------------------------------------------
下層 */

body:not(#frontpage) header {
	height: 120px;
}
body:not(#frontpage) header>.logo {
	width: 112px;
	margin: 0 auto 0 40px;
}


body:not(#frontpage) main {
	background: #fff url(../images/footer_bg_pc.webp) repeat-x center bottom / auto 218px;
	padding-bottom: 240px;
}

body:not(#frontpage) .bread_area ul {
	font-size: 1.2rem;
	padding-top: 140px;
}

body:not(#frontpage) .bread_area li:not(:last-child)::after {
	width: 4px;
	height: 10px;
}

body:not(#frontpage) .bread_area li:not(:last-child) {
	padding-right: 20px;
	margin-right: 15px;
}

body:not(#frontpage) .site_tl_box .site_tl_en {
	width: 705px;
	padding-top: 65px;
	margin: 0 auto 40px;
}


.news_detail_tl .txt {
	font-size: 2.4rem;
	padding-bottom: 30px;
	margin-bottom: 30px;
}

.news_detail_area {
	width: 795px;
	margin: 0 auto;
}

.news_detail_con {
	font-size: 1.6rem;
}

.news_detail_con>*+* {
	margin-top: 25px;
}

.news_control {
	width: 795px;
	margin: 0 auto;
	padding-top: 30px;
	margin-top: 30px;
	font-size: 1.6rem;
}

.page_list_num {
	gap: 25px;
}

.pagge_move_link p.prev a::before {
	width: 15px;
	height: 20px;
	margin-top: 0px;
	left: 0;
}

.pagge_move_link p.next a::before {
	width: 15px;
	height: 20px;
	margin-top: 0px;
	right: 0;
}

.pagge_move_link {
	margin: 50px 0 0;
}

.pagge_move_link p.prev a {
	padding-left: 30px;
}

.pagge_move_link p.next a {
	padding-right: 30px;
}

/*------------------------------------------------------------------------------
--------------------------------------------------------------------------------
footer */


footer #pagetop {
	width: 45px;
	top: -70px;
	left: 50%;
	transform: translate(-50%, 0%);
	right: inherit;
}

footer .f_logo {
	width: 112px;
	order: 1;
	margin: 0 55px 0 0;
}

footer .f_nav_wrap {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	padding-top: 60px;
}

footer .f_nav_wrap nav {
	order: 2;
}

footer .sns {
	order: 3;
	width: 100%;
	grid-template-columns: repeat(3, 38px);
	margin: 50px auto 20px;
	justify-content: center;
	gap: 3px;
}
footer .f_nav_wrap nav ul {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	gap: 55px;
}

footer .f_nav_wrap nav a {
	font-size: 1.4rem;
	padding-right: 18px;
}
footer .f_nav_wrap nav a[target="_blank"]::after {
	width: 10px;
	top: 7px;
}


footer small {
	order: 5;
	width: 100%;
	font-size: 1rem;
	padding: 0 0 15px;
}



