@charset "UTF-8";
/*font*/
/*$base_font: -apple-system, BlinkMacSystemFont, "Helvetica Neue", "Yu Gothic", YuGothic, Verdana, Meiryo, sans-serif;*/
@font-face { font-family: "Yu Gothic"; src: local("Yu Gothic Medium"); font-weight: 100; }

@font-face { font-family: "Yu Gothic"; src: local("Yu Gothic Medium"); font-weight: 200; }

@font-face { font-family: "Yu Gothic"; src: local("Yu Gothic Medium"); font-weight: 300; }

@font-face { font-family: "Yu Gothic"; src: local("Yu Gothic Medium"); font-weight: 400; }

@font-face { font-family: "Yu Gothic"; src: local("Yu Gothic Bold"); font-weight: bold; }

@font-face { font-family: "Helvetica Neue"; src: local("Helvetica Neue Regular"); font-weight: 100; }

@font-face { font-family: "Helvetica Neue"; src: local("Helvetica Neue Regular"); font-weight: 200; }

/*! based on html5doctor.com Reset Stylesheet v1.6.1 Author: Richard Clark - http://richclarkdesign.com */
html { box-sizing: border-box; }

*, ::before, ::after { box-sizing: inherit; }

body { background: transparent; color: #000; line-height: 1; -webkit-text-size-adjust: 100%; }

html[lang="ja"] body { font-family: "Noto Sans JP", -apple-system, BlinkMacSystemFont, "Helvetica Neue", YuGothic, Verdana, Meiryo, sans-serif; }

/* main elements group */
audio, canvas, progress, video { display: -moz-inline-stack; display: inline-block; vertical-align: middle; *vertical-align: auto; zoom: 1; *display: inline; vertical-align: baseline; }

audio:not([controls]) { display: none; height: 0; }

/* a */
header#pc { position: absolute; top: 0; left: 0; z-index: 99; width: 100%; }

/* 前へ次への矢印カスタマイズ */
.swiper-button-prev:after, .swiper-button-next:after { bottom: 0; content: ""; height: 0; margin: auto; position: absolute; top: 0; width: 0; z-index: 99; cursor: pointer; }

/* 前への矢印カスタマイズ */
.swiper-button-prev:after { width: 20px; height: 20px; border-top: 3px solid #fff; border-right: 3px solid #fff; left: 6px; transform: rotate(-135deg); }

/* 次への矢印カスタマイズ */
.swiper-button-next:after { width: 20px; height: 20px; border-top: 3px solid #fff; border-left: 3px solid #fff; right: 6px; transform: rotate(135deg); }

#top_mv { height: 100vh; width: 100%; position: relative; z-index: 1; overflow: hidden; }

#top_mv::after { content: ""; position: absolute; width: 100%; height: 100%; z-index: 2; background: rgba(0, 0, 0, 0.2); left: 0; top: 0; }

#top_mv #top_mv_in { height: 100vh; width: 100vw; position: relative; z-index: 3; display: -ms-flexbox; display: flex; -ms-flex-pack: center; justify-content: center; -ms-flex-align: center; align-items: center; }

#top_mv #top_mv_in #top_txt_area { width: 90%; max-width: 1400px; margin: 0 auto; text-align: center; }

#top_mv #top_mv_in #top_txt_area h2 { color: #fff; font-size: 4vw; font-weight: 100; display: none; }

#top_mv #top_mv_in #top_txt_area h2.en { font-family: "Ostrich", Meiryo, YuGothic, "Hiragino Kaku Gothic Pro", "Osaka", sans-serif; font-weight: 300; font-size: 3vw; letter-spacing: 0.1em; }

#top_mv video { position: fixed; left: 50%; top: 50%; transform: translate(-50%, -50%); min-width: 100%; min-height: 100%; z-index: 1; }

#main_txt del { text-decoration: none; }

main { background: #fff; position: relative; z-index: 3; padding-bottom: 60px; }

#top_sub { max-width: 1400px; margin: 0 auto 60px; width: 92%; }

#top_sub #top_sub_in { width: 100%; margin: 0 auto; max-width: 940px; display: -ms-flexbox; display: flex; -ms-flex-pack: start; justify-content: flex-start; -ms-flex-align: start; align-items: flex-start; padding: 30px 0; }

#top_sub #top_sub_in li { width: 49%; margin-right: 2%; }

#top_sub #top_sub_in li a { border: solid 1px #000; padding: 16px; transition: 0.3s ease-in; font-family: "Ostrich", Meiryo, YuGothic, "Hiragino Kaku Gothic Pro", "Osaka", sans-serif; display: block; width: 100%; font-size: 1.875rem; text-align: center; }

#top_sub #top_sub_in li a:hover { background: #000; color: #fff; }

#top_sub #top_sub_in li:last-child { margin-right: 0; }

/***top_sub***/
#info_area { display: -ms-flexbox; display: flex; -ms-flex-pack: start; justify-content: flex-start; -ms-flex-align: start; align-items: flex-start; max-width: 1400px; margin: 0 auto 80px; width: 92%; padding-top: 50px; }

#info_area .info_area_l { width: 48%; margin-right: 4%; }

#info_area .info_area_l.rev { margin-right: 0; }

.info_area_md { display: -ms-flexbox; display: flex; -ms-flex-pack: start; justify-content: flex-start; -ms-flex-align: start; align-items: flex-start; margin-bottom: 20px; }

.info_area_md .info_area_link a { display: block; padding: 4px 20px; background: #000; font-size: 0.875rem; color: #fff; border-radius: 100px; transition: 0.3s ease-in; }

.info_area_md .info_area_link a:hover { background: #eee; color: #000; }

.info_area_md .info_area_md001 { font-family: "Ostrich", Meiryo, YuGothic, "Hiragino Kaku Gothic Pro", "Osaka", sans-serif; font-size: 1.625rem; margin-right: auto; }

.info_list .info_list_in { border-bottom: solid 1px #eee; }

.info_list .info_list_in .info_list_box { display: -ms-flexbox; display: flex; -ms-flex-pack: start; justify-content: flex-start; -ms-flex-align: start; align-items: flex-start; padding: 28px 0; position: relative; }

.info_list .info_list_in .info_list_box:hover::before { background: #f7f7f7; transform: scale(0.85, 0.85); }

.info_list .info_list_in .info_list_box::before { content: ""; display: block; background: #fff; position: absolute; top: 0; left: 0; width: 100%; height: 100%; z-index: -1; transition: 0.3s ease-in; }

.info_list .info_list_in .info_list_box .info_list_box_r .ca001 { background: #eee; padding: 10px 20px; display: -moz-inline-stack; display: inline-block; vertical-align: middle; *vertical-align: auto; zoom: 1; *display: inline; line-height: 1; border-radius: 100px; margin-bottom: 10px; font-size: 0.875rem; }

.info_list .info_list_in .info_list_box .info_list_box_r.add_ph { display: -ms-flexbox; display: flex; -ms-flex-pack: start; justify-content: flex-start; -ms-flex-align: start; align-items: flex-start; width: 80%; }

.info_list .info_list_in .info_list_box .info_list_box_r.add_ph .info_list_box_r_l { width: 70%; margin-right: 5%; }

.info_list .info_list_in .info_list_box .info_list_box_r.add_ph .info_list_box_r_r { width: 25%; }

.info_list .info_list_in .info_list_box .info_list_box_r.add_ph .info_list_box_r_r img { max-width: 100%; width: 100%; }

.info_list .info_list_in .info_list_box .info_list_box_l { width: 20%; padding: 0 18px; text-align: center; }

.info_list .info_list_in .info_list_box .info_list_box_l i, .info_list .info_list_in .info_list_box .info_list_box_l em { font-family: "Ostrich", Meiryo, YuGothic, "Hiragino Kaku Gothic Pro", "Osaka", sans-serif; display: block; line-height: 1; }

.info_list .info_list_in .info_list_box .info_list_box_l i { font-size: 1.625rem; }

.info_list .info_list_in .info_list_box .info_list_box_l em { font-size: 5.375rem; }

.info_list .info_list_in:first-child { border-top: solid 1px #eee; }

.top_md_001 { font-size: 2.3vw; font-family: "Ostrich", Meiryo, YuGothic, "Hiragino Kaku Gothic Pro", "Osaka", sans-serif; line-height: 1.2; margin-bottom: 30px; }

.top_md_002 { font-size: 3.3vw; font-weight: 200; line-height: 1.2; }

#top_about { position: relative; overflow-x: hidden; padding-top: 45px; }

#top_about::after { content: ""; display: block; width: 50vw; height: 60%; background: #f7f7f7; top: 15%; left: 50%; margin-left: -10%; z-index: -2; position: absolute; }

#top_about::before { content: ""; display: block; width: 20vw; height: 72%; position: absolute; top: 0; left: 0; background-image: url(/image/top_bg001.jpg); background-repeat: none; background-position: center center; background-size: cover; z-index: -1; }

#top_md001 { margin: 0 0 0 auto; width: 96%; padding-left: 12vw; }

.top_txt001 { line-height: 2.3; }

.md_btn001 { padding-top: 40px; }

.md_btn001.gray { padding-top: 20px; }

.md_btn001.gray a { border: none; background: #ababab; color: #fff; }

.md_btn001.gray a::before { border-top: 2px solid #fff; border-right: 2px solid #fff; }

.md_btn001 a { border-radius: 100px; border: solid 1px #000; padding: 20px 62px 20px 35px; position: relative; display: block; width: 60%; max-width: 350px; transition: 0.3s ease-in; }

.md_btn001 a:hover { background: #000; color: #fff; }

.md_btn001 a:hover::before { right: 30px; border-top: 2px solid #fff; border-right: 2px solid #fff; }

.md_btn001 a::before { content: ""; display: block; position: absolute; margin-top: -5px; top: 50%; right: 25px; width: 10px; height: 10px; border-top: 2px solid #000; border-right: 2px solid #000; transform: rotate(45deg); transition: 0.3s ease-in; }

#top_about_in001 { margin: 0 0 0 auto; width: 96%; padding-left: 12vw; position: relative; }

#top_about_in001 #top_about_bg002 { width: 30vw; position: relative; margin-left: -12vw; padding-top: 80px; }

#top_about_in001 #top_about_bg002 img { width: 100%; }

#top_about_in001 #top_about_in001_in { display: -ms-flexbox; display: flex; -ms-flex-pack: start; justify-content: flex-start; -ms-flex-align: start; align-items: flex-start; padding-top: 35px; }

#top_about_in001 #top_about_in001_in #top_about_in001_in_l { width: 40%; padding-right: 5%; }

#top_about_in001 #top_about_in001_in #top_about_in001_in_r { width: 65%; }

#top_about_in001 #top_about_in001_in #top_about_in001_in_r img { width: 100%; }

#top_lineup { position: relative; margin-top: -45px; padding-top: 120px; z-index: -1; margin-bottom: 60px; }

#top_lineup #top_lineup_md { width: 90%; margin: 0 auto 66px; max-width: 1150px; }

#top_lineup #top_lineup_md .top_lineup_md_in { font-size: 2.3vw; font-family: "Ostrich", Meiryo, YuGothic, "Hiragino Kaku Gothic Pro", "Osaka", sans-serif; line-height: 1.2; color: #fff; }

#top_lineup::before { content: ""; display: block; position: absolute; top: 0; left: 0; width: 100%; height: 10vw; min-height: 473px; background-image: url(/image/top_bg002.jpg); background-repeat: none; background-position: right center; background-size: cover; z-index: -1; }

#top_lineup_box { width: 92%; margin: 0 auto; max-width: 1690px; }

#top_lineup_box_in { display: -ms-flexbox; display: flex; -ms-flex-pack: start; justify-content: flex-start; -ms-flex-align: start; align-items: flex-start; -ms-flex-wrap: wrap; flex-wrap: wrap; }

#top_lineup_box_in .top_lineup_list { width: caic(100%/3); width: 33.3333%; }

#top_lineup_box_in .top_lineup_list a { display: block; position: relative; }

#top_lineup_box_in .top_lineup_list a:hover .top_li .top_li_link { background: #fff; color: #000; }

#top_lineup_box_in .top_lineup_list a:hover .top_li .top_li_link span::before { border-top: 2px solid #000; border-right: 2px solid #000; }

#top_lineup_box_in .top_lineup_list a:hover .top_li_ph img { transform: scale(1.1) translate(0, 0); }

#top_lineup_box_in .top_lineup_list a .top_li { position: absolute; z-index: 2; left: 0; top: 0; display: -ms-flexbox; display: flex; -ms-flex-pack: center; justify-content: center; -ms-flex-align: center; align-items: center; -ms-flex-direction: column; flex-direction: column; width: 100%; height: 100%; }

#top_lineup_box_in .top_lineup_list a .top_li .top_li_link { border: solid 1px #fff; border-radius: 100px; padding: 10px 16px; width: 60%; max-width: 280px; color: #fff; text-align: center; position: relative; transition: 0.3s ease-in; }

#top_lineup_box_in .top_lineup_list a .top_li .top_li_link span { padding-right: 20px; position: relative; }

#top_lineup_box_in .top_lineup_list a .top_li .top_li_link span::before { content: ""; display: block; position: absolute; margin-top: -3px; top: 50%; right: 0; width: 8px; height: 8px; border-top: 2px solid #fff; border-right: 2px solid #fff; transform: rotate(45deg); transition: 0.3s ease-in; }

#top_lineup_box_in .top_lineup_list a .top_li .top_li_md { color: #fff; font-size: 1.5vw; line-height: 1.2; display: -ms-flexbox; display: flex; -ms-flex-pack: center; justify-content: center; -ms-flex-align: center; align-items: center; text-align: center; margin-bottom: 30px; -ms-flex-direction: column; flex-direction: column; }

#top_lineup_box_in .top_lineup_list a .top_li .top_li_md a, #top_lineup_box_in .top_lineup_list a .top_li .top_li_md span { font-size: 1vw; color: #fff; }

#top_lineup_box_in .top_lineup_list a .top_li .top_li_md a:hover, #top_lineup_box_in .top_lineup_list a .top_li .top_li_md span:hover { text-decoration: underline; }

#top_lineup_box_in .top_lineup_list a .top_li_ph { position: relative; z-index: 1; overflow: hidden; }

#top_lineup_box_in .top_lineup_list a .top_li_ph img { width: 100%; transition: 0.5s ease-in; display: block; transform: scale(1.01, 1.01); }

#top_lineup_box_in .top_lineup_list:nth-child(3n) { margin-right: 0; }

#top_service #top_service_in { width: 92%; margin: 0 auto; max-width: 1600px; }

#top_service #top_service_in #top_service_box { display: -ms-flexbox; display: flex; -ms-flex-pack: start; justify-content: flex-start; -ms-flex-align: start; align-items: flex-start; -ms-flex-wrap: wrap; flex-wrap: wrap; }

#top_service #top_service_in #top_service_box .top_service_list { width: 50%; padding: 50px 4%; }

#top_service #top_service_in #top_service_box .top_service_list .top_service_md { font-size: 2.125rem; margin-bottom: 30px; text-align: center; }

#top_service #top_service_in #top_service_box .top_service_list .top_service_txt { line-height: 2; }

#top_service #top_service_in #top_service_box .top_service_list:first-child { border-right: solid 1px #ddd; }

.top_service_link a { border-radius: 100px; border: solid 1px #000; padding: 14px 0 14px 0; position: relative; display: block; width: 60%; max-width: 350px; transition: 0.3s ease-in; text-align: center; margin: 40px auto 0; }

.top_service_link a span { position: relative; padding: 0 35px; }

.top_service_link a span::before { content: ""; display: block; position: absolute; margin-top: -4px; top: 50%; right: 0; width: 10px; height: 10px; border-top: 2px solid #000; border-right: 2px solid #000; transform: rotate(45deg); transition: 0.3s ease-in; }

.top_service_link a:hover { background: #000; color: #fff; }

.top_service_link a:hover span::before { right: 5px; border-top: 2px solid #fff; border-right: 2px solid #fff; }

@media all and (-ms-high-contrast: none){
 body{ font-family: Verdana, Meiryo, sans-serif; } }

@media screen and (max-width: 1000px){
 #top_mv #top_mv_in #top_txt_area h2.en{ font-size: 2.5rem; }
 #info_area{ -ms-flex-wrap: wrap; flex-wrap: wrap; margin: 0 auto 40px; }
 #info_area .info_area_l{ width: 100%; margin-right: 0; margin-bottom: 60px; }
 #info_area .info_area_l.rev{ margin-bottom: 0; }
 .info_area_md{ -ms-flex-align: center; align-items: center; }
 .info_area_md .info_area_link a{ font-size: 1.0625rem; }
 .info_area_md .info_area_md001{ font-size: 2rem; }
 .info_list .info_list_in .info_list_box .info_list_box_r.add_ph{ -ms-flex-wrap: wrap; flex-wrap: wrap; -ms-flex-direction: column-reverse; flex-direction: column-reverse; }
 .info_list .info_list_in .info_list_box .info_list_box_r.add_ph .info_list_box_r_l{ width: 100%; margin-right: 0; }
 .info_list .info_list_in .info_list_box .info_list_box_r.add_ph .info_list_box_r_r{ width: 100%; margin-bottom: 20px; height: 100px; overflow: hidden; position: relative; }
 .info_list .info_list_in .info_list_box .info_list_box_r.add_ph .info_list_box_r_r img{ position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); }
 .info_list .info_list_in .info_list_box .info_list_box_l{ padding: 0; margin-right: 20px; }
 .info_list .info_list_in .info_list_box .info_list_box_l i{ font-size: 1.0625rem; }
 .info_list .info_list_in .info_list_box .info_list_box_l em{ font-size: 3.625rem; }
 .top_md_001{ font-size: 1.875rem; }
 .top_md_002{ font-size: 2.125rem; }
 #top_about{ padding-top: 30px; }
 #top_about::after{ display: none; }
 #top_about::before{ height: 50%; width: 50vw; }
 #top_md001{ margin: 0 auto; width: 90%; padding-left: 0; }
 .md_btn001 a{ width: 80%; max-width: inherit; margin: 0 auto; }
 #top_about_in001{ padding-left: 0; width: 90%; margin: 0 auto 40px; }
 #top_about_in001 #top_about_bg002{ display: none; }
 #top_about_in001 #top_about_in001_in{ padding-top: 30px; -ms-flex-wrap: wrap; flex-wrap: wrap; -ms-flex-direction: column-reverse; flex-direction: column-reverse; }
 #top_about_in001 #top_about_in001_in #top_about_in001_in_l{ width: 100%; padding-right: 0; }
 #top_about_in001 #top_about_in001_in #top_about_in001_in_r{ width: 100%; margin-bottom: 20px; }
 #top_lineup{ margin-top: 0; padding-top: 40px; margin-bottom: 0; }
 #top_lineup #top_lineup_md{ margin: 0 auto 30px; }
 #top_lineup #top_lineup_md .top_lineup_md_in{ font-size: 1.875rem; text-align: center; }
 #top_lineup::before{ height: 6vw; min-height: 300px; background-position: 70% 50%; }
 #top_lineup_box_in .top_lineup_list{ width: 100%; margin-bottom: 10px; }
 #top_lineup_box_in .top_lineup_list a:hover .top_li_ph img{ transform: scale(1) translate(-50%, -50%); }
 #top_lineup_box_in .top_lineup_list a .top_li .top_li_md{ font-size: 1.625rem; margin-bottom: 20px; }
 #top_lineup_box_in .top_lineup_list a .top_li .top_li_md a, #top_lineup_box_in .top_lineup_list a .top_li .top_li_md span{ font-size: 1.25rem; }
 #top_lineup_box_in .top_lineup_list a .top_li_ph{ width: 100%; max-width: 100%; height: 200px; }
 #top_lineup_box_in .top_lineup_list a .top_li_ph img{ position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); }
 #top_service #top_service_in #top_service_box .top_service_list{ width: 100%; padding: 20px 4%; }
 #top_service #top_service_in #top_service_box .top_service_list .top_service_md{ font-size: 1.625rem; margin-bottom: 20px; }
 #top_service #top_service_in #top_service_box .top_service_list:first-child{ border-right: none; border-bottom: dotted 1px #ddd; }
 .top_service_link a{ width: 80%; margin: 20px auto 0; } }
