@charset "utf-8";
/*
Noto Serif Japanese
font-family: 'Noto Serif JP', serif;
Medium 500
Bold 700
Black 900

Bodoni Moda
font-family: 'Bodoni Moda', serif;
SemiBold 600
/*------------------------------------
	reset
-------------------------------------*/
body,div,dl,dt,dd,ul,ol,li,h1,h2,h3,h4,h5,h6,pre,form,fieldset,input,textarea,p,blockquote,th,td { margin: 0; padding: 0; }
address,caption,cite,code,dfn,em,strong,th,var { font-style: normal; }
ul,ol { list-style-type: none; }
em,strong,th,address { font-style: normal; font-weight: normal; text-align: left; }
h1,h2,h3,h4,h5,h6 { font-weight: normal; font-size: 100%; }
img,
object,
embed { border: 0; vertical-align: top; }
img { max-width: 100%; height: auto; vertical-align: bottom; }
a{ outline: none;}
hr { border: none;}
table { border-collapse: collapse; border-spacing: 0; font-size: 100%; }
li { list-style-type: none; }
strong { font-weight: bold; }

/*------------------------------------
	base
-------------------------------------*/
body {position: relative; background: #fff; color: #000; font-family: 'Noto Serif JP', serif; font-weight: 500; line-height: 1.5; font-size: 1.5rem; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; -webkit-text-size-adjust:100%;}
a{outline: none;}
/*txt img active*/
::selection ,
::-moz-selection { background:#666; }
img::selection,
img::-moz-selection { background:none; }
/*cookie*/
#onetrust-banner-sdk{ outline: none; }

/*------------------------------------
	fade
-------------------------------------*/
.wrap_f{ width: 100%; height: 100%; position: relative;}
.wrap_f::after {content: ''; display: block; position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: #000; pointer-events: none; user-select: none; z-index: 300; opacity: 1; transition:2s; }
.wrap_f.fade::after { opacity: 0; pointer-events: none; user-select: none; }

/*------------------------------------
	contents
-------------------------------------*/
.wrapper{ position: relative; overflow: hidden; width: 100%; background: #fff;}

/*anime set
------------------------*/
#main .main_img img,
#main .main_title img,
.txt_box p,
.img_box,
.detail,
.notes,
h2,
h3,
#fm_photo_box img,
.title_box p,
#fm_movie a,
#fm_movie p,
#strap ul li img,
#strap ul li:nth-child(2) img,
#strap p,
#store ul li ,
#store ul li:nth-child(2) ,
.info_r p{ visibility: hidden;}

/*------------------------------------
	header
-------------------------------------*/
header{ position: absolute; left: 0px; top: 0px; z-index: 9999; width: 100%; }
header div{ margin: 0; line-height: 1; font-size: 1px; display: block; }
header div img{ width: 100%; vertical-align: top;}
/*------ header logo ------*/
header .seiko_logo{ width: 130px; position:absolute; right: 30px; top: 30px; text-align: right;}
header .ks_logo{ width: 195px; position:absolute; left: 30px; top: 30px; }
@media (max-width: 1600px) {
header .seiko_logo{ width: 8.17vw; right: 1.85vw; top: 1.85vw; }
header .ks_logo{ width: 12.3vw; left: 1.9vw; top: 1.8vw; }
}/*END*/
@media screen and (orientation: portrait) {
header .seiko_logo{ width: 130px; right: 30px; top: 30px; }
header .ks_logo{ width: 200px; left: 30px; top: 30px; }
}/*END*/
@media screen and (max-width: 780px) and (orientation: portrait) { 
header .seiko_logo{ width: 17vw; right: 3.8vw; top: 3.8vw; }
header .ks_logo{ width: 25vw; left: 3.8vw; top: 3.8vw; }
}/*END*/
@media screen and (max-width: 640px) and (orientation: portrait) {
header .seiko_logo{ width: 20vw; right: 3.8vw; top: 3.8vw; }
header .ks_logo{ width: 33vw; left: 3.8vw; top: 3.8vw; }
}/*END*/

/*------------------------------------
	main
-------------------------------------*/
/* main */
#main { width: 100%; position: relative; color: #fff;  z-index: 1; overflow: hidden; }
#main img{ width: 100%; }

/* main_title */
#main .main_title{ width: 66.2%; position: absolute; top: 49.7%; left: 0%; z-index: 2;text-align: center;}
#main .main_title .main_title_head{ font-size: 3.1vw; line-height: 1; font-family: 'Times New Roman', Times, serif; transform: skewX(-10deg); }

#main .main_title .main_title_head span.main_title_01{ margin-left: -1vw; letter-spacing: 0.1vw;}
#main .main_title .main_title_head span.main_title_02{ font-size: 5.4vw; letter-spacing: 0.09vw; line-height: 1; display: block;}
#main .main_title .main_title_head span.main_title_03{ margin-left: 1.5vw; letter-spacing: 0.1vw;}
#main .main_title h1{ margin-top: 1.7vw; font-size: 1.58vw; line-height: 1; padding: 0.9vw .8vw 1.1vw; display: inline-block; position: relative; font-weight: 600; }

#main .main_title h1::before,
#main .main_title h1::after{ width: 100%; height: 2px; content: ''; width: 100%; background: #fff;}
#main .main_title h1::before{position: absolute; left: 0; top: 0;}
#main .main_title h1::after{ position: absolute; left: 0; bottom: 0;}


@media (max-width: 1300px) {
#main .main_title h1::before,
#main .main_title h1::after{ height: 1px;}
}/*END*/

@media screen and (orientation: portrait) {
#main .main_title{ width: 100%; position: absolute; top: 71%; left: 0%; z-index: 2;}
#main .main_title .main_title_head{ font-size: 4.6vw;}
#main .main_title .main_title_head span.main_title_01{ margin-left: -1vw; letter-spacing: 0.1vw;}
#main .main_title .main_title_head span.main_title_02{ font-size: 7.85vw; letter-spacing: 0.09vw; line-height: 1; display: block;}
#main .main_title .main_title_head span.main_title_03{ margin-left: 1.5vw; letter-spacing: 0.1vw;}
#main .main_title h1{ margin-top: 2.2vw; font-size: 2.3vw; line-height: 1; padding: 1.4vw .8vw 1.6vw; display: inline-block; }
#main .main_title h1::before,
#main .main_title h1::after{ height: 2px;}
}/*END*/
@media screen and (max-width: 640px) and (orientation: portrait) {
#main .main_title{ width: 100%; position: absolute; top: 75.8%; left: 0%; z-index: 2;}
#main .main_title .main_title_head{ font-size: 5.1vw;}
#main .main_title .main_title_head span.main_title_01{ margin-left: -1.4vw; letter-spacing: 0.1vw;}
#main .main_title .main_title_head span.main_title_02{ font-size: 8.8vw; letter-spacing: 0.09vw; line-height: 1; display: block;}
#main .main_title .main_title_head span.main_title_03{ margin-left: 2.5vw; letter-spacing: 0.1vw;}
#main .main_title h1{ margin-top: 2.5vw; font-size: 2.57vw; line-height: 1; padding: 1.6vw .8vw 1.8vw; display: inline-block; }
#main .main_title h1::before,
#main .main_title h1::after{ height: 1px; opacity: 0.8;}
}/*END*/





/*[ on / off ]*/
.main_img .x15{display:block;}
.main_img .x1{display:none;}
.main_img .tab{display:none;}
.main_img .sp{display:none;}
@media (max-width: 1400px) {
.main_img .x15{display:none;}
.main_img .x1{display:block;}
.main_img .tab{display:none;}
.main_img .sp{display:none;}
}/*END*/
@media screen and (orientation: portrait) {
.main_img .x15{display:none;}
.main_img .x1{display:none;}
.main_img .tab{display:block;}
.main_img .sp{display:none;}
}/*END*/
@media screen and (max-width: 640px) and (orientation: portrait) {
.main_img .x15{display:none;}
.main_img .x1{display:none;}
.main_img .tab{display:none;}
.main_img .sp{display:block;}
}/*END*/

/*------------------------------------
	txt
-------------------------------------*/
/*letter-spacing
--------------------*/
.ls_1{letter-spacing: 1px;}
@media (max-width: 1400px) {
.ls_1{letter-spacing: .5px;}
}/*END*/
@media (max-width: 1024px) {
.ls_1{letter-spacing: 1px;}
}/*END*/
@media (max-width: 640px) {
.ls_1{letter-spacing: 0px;}
}/*END*/

/*line-height
--------------------*/
/*--- lh_2 ---*/
.lh_22{line-height: 2.2;}
.lh_2{line-height: 2;}
.lh_18{line-height: 1.8;}
.lh_16{line-height: 1.6;}
.lh_12{line-height: 1.4;}
.lh_1{line-height: 1;}
@media (max-width: 1400px) {
.lh_22{line-height: 2;}
}/*END*/
@media (max-width: 640px) {
.lh_22{line-height: 2;}
}/*END*/

/*txt size
--------------------*/
/*--- txt ---*/
.txt37 { font-size: 37px; }
.txt20 { font-size: 20px; }
.txt17 { font-size: 17px; }
.txt16 { font-size: 16px; }
.txt15 { font-size: 15px; }
.txt14 { font-size: 14px; }
@media (max-width: 1200px) {
.txt37 { font-size: 34px; }
.txt20 { font-size: 18px; }
.txt17 { font-size: 16px; }
.txt16 { font-size: 16px; }
.txt15 { font-size: 15px; }
.txt14 { font-size: 13px; }
}/*END*/
@media (max-width: 500px) {
.txt37 { font-size: 29px; }
.txt20 { font-size: 16px; }
.txt17 { font-size: 14px; }
.txt16 { font-size: 14px; }
.txt15 { font-size: 13px; }
.txt14 { font-size: 13px; }
}/*END*/
@media (max-width: 380px) {
.txt37 { font-size: 7.5vw; }
.txt20 { font-size: 4.2vw; }
.txt17 { font-size: 3.7vw; }
.txt16 { font-size: 3.7vw; }
.txt15 { font-size: 3.45vw; }
.txt14 { font-size: 3.45vw; }
}/*END*/
.ff_times{ font-family: 'Times New Roman', Times, serif;}

/*margin-top
--------------------*/
.mt50{ margin-top: 50px;}
.mt20{ margin-top: 20px;}
.mt15{ margin-top: 15px;}
.mt10{ margin-top: 10px;}
@media (max-width: 640px) {
.mt15{ margin-top: 12px;}
}/*END*/
@media (max-width: 380px) {
.mt15{ margin-top: 2vw;}
}/*END*/

/*margin-top
--------------------*/
.pt20{ padding-top: 20px;}
.pt15{ padding-top: 15px;}
.pt10{ padding-top: 10px;}

/*------------------------------------
	lead
-------------------------------------*/
#lead{ padding: 80px 0; text-align: center;}
#lead .txt_box{ margin: 0 auto; width: 90%; text-align: center;}
#lead .txt_box p span{ display: inline-block;}
@media (max-width: 640px) {
#lead{ padding: 60px 0;}
}/*END*/
@media (max-width: 380px) {
#lead{ padding: 15vw 0;}
}/*END*/
/* on off */
.lead_br1{display: block;}
.lead_br2{display: none;}
@media (max-width: 960px) {
.lead_br1{display: none;}
.lead_br2{display: block;}
}/*END*/
@media (max-width: 680px) {
.lead_br2{display: none;}
}/*END*/

/*detail*/
.detail{max-width: 90%; margin-top: 60px; padding: 25px 40px; text-align: center; border-top:solid 1px #000;border-bottom:solid 1px #000; display: inline-block;}
.detail table{ width: auto !important; max-width: 100%; display: inline-block; text-align: left; vertical-align: bottom;}
.detail table th,
.detail table td{ padding: 5px 0; }
.detail table td span{ display: inline-block; }
.detail table th{ letter-spacing: 4px; padding-right: 20px; text-align: center; vertical-align: top; }
.detail table th{ position: relative; white-space: nowrap;}
.detail table th::after{ content: '：'; position: absolute; right: 0; }
/*notes*/
.notes{ margin-top: 35px;}
@media (max-width: 750px) {
.detail table th,
.detail table td{ padding: 10px 0; }
.detail table th{ letter-spacing: 2px; padding-right: 20px; text-align: center; vertical-align: top; }
}/*END*/
@media (max-width: 700px) {
.detail table td span{ display: block; }
}/*END*/
@media (max-width: 640px) {
.detail{margin-top: 50px; padding: 25px 40px; }
.notes{ margin-top: 30px;}
}/*END*/
@media (max-width: 500px) {
.detail { padding: 20px 20px;}
.detail table th,
.detail table td{ padding: 10px 0; }
.detail table th{ letter-spacing: 1px; padding-right: 16px;}
}/*END*/
@media (max-width: 380px) {
.detail{margin-top: 12vw; }
.detail {margin-top: 12vw; padding: 5vw 4vw;}
.detail table th,
.detail table td{ padding: 2.5vw 0; }
.detail table th{ letter-spacing: 1px; padding-right: 16px;}
.notes{ margin-top: 8vw;}
}/*END*/

/*------------------------------------
	fanmeeting
-------------------------------------*/
#fanmeeting { width: 93.75%; max-width: 1500px; margin: 0 auto; color: #fff; text-align: center; }

/*fm_photo_box
-------------------*/
#fm_photo_box { padding-bottom: 90px; background: #191919; text-align: center;}
#fm_photo_box h2{ padding: 75px 0; width: 90%; margin: 0 auto; line-height: 2; }
#fm_photo_box h2 span{ display: inline-block;}
#fm_photo_box img{ margin: 0 auto; width: 90%; max-width: 1200px; }
@media (max-width: 1200px) {
#fm_photo_box { padding-bottom: 90px; background: #191919; text-align: center;}
#fm_photo_box h2{ padding: 65px 0; width: 90%; margin: 0 auto; }
}/*END*/
@media (max-width: 1024px) {
#fm_photo_box { padding-bottom: 0px;}
#fm_photo_box img{ width: 100%; }
}/*END*/
@media (max-width: 960px) {
#fm_photo_box h2{  line-height:1.8;}
}/*END*/
@media (max-width: 600px) {
#fanmeeting { width: 95%; }
#fm_photo_box h2{ padding: 10.7vw 0; width: 90%; margin: 0 auto;  line-height:1.6;}
}/*END*/
.fm_photo_br1{display: block;}
.fm_photo_br2{display: none;}
@media (max-width: 960px) {
.fm_photo_br1{display: none;}
.fm_photo_br2{display: block;}
}/*END*/
@media (max-width: 480px) {
.fm_photo_br1{display: none;}
.fm_photo_br2{display: none;}
}/*END*/

/*fm_select_comment
-------------------*/
#fm_select_comment {padding-bottom: 100px; background: #2b2b2b;}
#fm_select_comment .title_box{ padding: 80px 0; }
#fm_select_comment .title_box h2{ text-align: center; font-family: 'Times New Roman', Times, serif;}
#fm_select_comment .title_box h2 small{ font-size: 25px; line-height: 1; display: block;}
#fm_select_comment .title_box h2 span{ font-size: 56px; line-height: 1; }
#fm_select_comment .title_box p{ line-height: 2.4;  text-align: center;}
#fm_select_comment ul{ margin: 0 auto; width: 90%; max-width: 1200px;}
#fm_select_comment ul li { display: flex;}
#fm_select_comment ul li:nth-child(even) { flex-direction : row-reverse;}
#fm_select_comment ul li .img_box{ width: 50%; }
#fm_select_comment ul li .txt_box{ width: 50%; display: flex; align-items: center; justify-content: center;}
#fm_select_comment ul li .txt_box .inner{ width: 68%; padding-bottom: 20px; text-align: left;}
#fm_select_comment ul li .txt_box .inner p span{ display: inline-block;}
@media (max-width: 1024px) {
#fm_select_comment {padding-bottom: 20px;}
#fm_select_comment ul{ margin: 0 auto; width: 80%; max-width: 600px;}
#fm_select_comment ul li h3{ text-align: center;}
#fm_select_comment ul li { display: block;}
#fm_select_comment ul li .img_box{ width: 100%; }
#fm_select_comment ul li .txt_box{ padding: 40px 0 90px; width: 100%; display: block;}
#fm_select_comment ul li .txt_box .inner{ width: 95%; padding-bottom: 0px;}
}/*END*/
@media (max-width: 640px) {
#fm_select_comment .title_box{ padding: 60px 0;  text-align: left;}
#fm_select_comment .title_box h2 small{ font-size: 22px;}
#fm_select_comment .title_box h2 span{ font-size: 52px; }
#fm_select_comment ul{ margin: 0 auto; width: 80%; max-width: 600px;}
#fm_select_comment ul li .txt_box{ padding: 6vw 0 14vw;}
}/*END*/
@media (max-width: 550px) {
#fm_select_comment {padding-bottom: 10px;}
#fm_select_comment .title_box{ padding: 11vw 0; }
#fm_select_comment .title_box h2 small{ font-size: 4vw;}
#fm_select_comment .title_box h2 span{ font-size: 9.5vw; }
#fm_select_comment ul li .txt_box{ padding: 7vw 0 14vw;}
}/*END*/

/*fm_movie
-------------------*/
#fm_movie{ padding: 100px 0 90px; background: #000; }
@media (max-width: 950px) {
#fm_movie{ padding: 100px 0 90px; background: #000; }
}/*END*/
@media (max-width: 640px) {
#fm_movie{ padding: 15vw 0 14vw; background: #000; }
}/*END*/
.movie{position: relative; margin: 0 auto;max-width: 800px; width: 80%; text-align: center; overflow: hidden; z-index: 4;}
.movie a{ margin: 0 auto; position: relative; display: inline-block; overflow: hidden;  }
.movie a img{ transition: 1s; }
.movie a:hover img{ transform: scale(1.05); opacity: 0.6;}

/* play movie*/
.movie a span.play{ position: absolute; left: 50%; top: 50%; width: 70px; height: 70px; margin: -35px 0 0 -35px; display: inline-block;  background: rgba(255,255,255,0); border: solid 1.5px rgba(255,255,255,.6); border-radius: 50%; box-sizing: border-box; z-index: 3; transition: 0.3s; }
.movie a span.play::after{ border-width: 10px 0 10px 16px; margin: -10px 0 0 -5px; border-color: transparent transparent transparent #fff; left: 50%; top: 50%; position: absolute; content: ''; display: block; width: 0; height: 0; border-style: solid; }
.movie a:hover span.play{ background: rgba(255,255,255,0.2); border: solid 2px rgba(255,255,255,0); }
@media (max-width: 1400px) {
.movie a span.play{ display: inline-block; width: 60px; height: 60px; margin: -30px 0 0 -30px; }
.movie a span.play::after{ border-width: 8px 0 8px 13px; margin: -8px 0 0 -5px;  }
}/*END*/
@media (max-width: 750px) {
.movie a span.play{ display: inline-block; width: 50px; height: 50px;  margin: -25px 0 0 -25px; }
.movie a span.play::after{ border-width: 7px 0 7px 11px; margin: -7px 0 0 -4px;  }
}/*END*/

/*------------------------------------
	strap
-------------------------------------*/
#strap { margin: 0 auto; color: #000; width: 100%; text-align: center; position: relative; }
#strap::after { content: ''; display: block; width: 100%; height:400px; position: absolute; left: 0; bottom: 0; z-index: 0; background: linear-gradient(to top, #f3f3f3 0%, #fff 100%);}
#strap .title_box{ margin: 0 auto; padding: 100px 0; width: 90%;}
.txt62 { font-size: 62px; }
.txt22 { font-size: 22px; }
#strap ul{ margin: 0 auto; width: 90%; max-width: 1400px; position: relative; display: flex; justify-content: space-between; z-index: 2; }
#strap ul::after{ content: ''; display: block; width: 1px; height: 100%; position: absolute; left: 50%; top: 0; background: #d1d1d1;}
#strap ul li { width: 46.4%;}
#strap ul li h2 small{ font-size: 30px; line-height: 1; display: block;}
#strap ul li h2 span{ font-size: 38px; line-height: 1.3;}
#strap ul li .strap_img{ padding-top: 35px; margin: 0px auto 0; width: 90%; max-width: 533px;}
#strap ul li p{ margin-top: 20px;}
#strap ul li .strap_img2{ margin-top: 80px; }
#strap .strap_bottom_txt{ padding: 90px 0; margin: 0 auto; width: 90%; position: relative; z-index: 2;}
#strap .strap_bottom_txt span{display: inline-block;}
@media (max-width: 1350px) {
#strap .title_box{ margin: 0 auto; padding: 100px 0; width: 90%;}
#strap .title_box h2 span{ display: block; }
.txt62 { font-size: 60px; }
.txt22 { font-size: 20px; }
#strap ul li .strap_img2{ margin-top: 6vw; }
#strap .strap_bottom_txt{ padding: 80px 0;}
}/*END*/
@media (max-width: 900px) {
#strap .title_box{ margin: 0 auto; padding: 90px 0; width: 90%;}
.txt62 { font-size: 6.7vw; }
.txt22 { font-size: 19px; }
#strap .strap_bottom_txt{ padding: 80px 0;}
}/*END*/
@media (max-width: 700px) {/*ブレイク*/
#strap ul{ margin: 0 auto; width: 90%; max-width: 1400px; position: relative; display: block;  }
#strap ul::after { display: none; }
#strap ul li { padding: 10vw 0 15vw; margin: 0 auto; width: 100%; max-width:600px; border-top: solid 1px #d1d1d1; display: block;}
#strap ul li .strap_img2{ margin-top: 8vw; width: 80%; max-width: 533px;}
#strap ul li:nth-child(2){ padding: 10vw 0 0;}
#strap ul li h2 small{ font-size: 5vw;}
#strap ul li h2 span{ font-size: 6vw;}
#strap ul li p{ margin-top: 10px;}
}/*END*/
@media (max-width: 640px) {
#strap .title_box{ margin: 0 auto; padding: 80px 0; width: 90%;}
#strap .title_box h3 span{ display: block; }
.txt22 { font-size: 3.2vw; }
#strap .strap_bottom_txt{ padding: 12vw 0;}
#strap ul li .strap_img{ padding-top: 6vw;}
}/*END*/
@media (max-width: 500px) {
#strap .title_box{ margin: 0 auto; padding: 15vw 0; width: 90%;}
#strap .strap_bottom_txt{ padding: 60px 0;}
}/*END*/
@media (max-width: 450px) {
#strap .title_box h3 span{ display: block; }
.txt62 { font-size: 8vw; }
.txt22 { font-size: 3.6vw; }
#strap ul li h2 small{ font-size: 6.5vw;}
#strap ul li h2 span{ font-size: 7.5vw;}
}/*END*/
@media (max-width: 1160px) {
#strap ul li p .sp_none{ display: none;}
#strap ul li p .sp_block{ display: block;}
}/*END*/

/*------------------------------------
	store
-------------------------------------*/
#store{ width: 100%;}
#store .title_box{ text-align: center; padding: 90px 0; }
#store .title_box h2{ font-size: 56px; line-height: 1;} 
#store ul{ margin: 0 auto; width: 80%; max-width: 1220px; display: flex;  justify-content: space-between; } 
#store ul li{ width: 49.2%;}
#store ul li a{ padding: 52px 0; font-size: 17px; line-height: 1; text-align: center; display: block; color: #fff; background: #000; text-decoration: none; position: relative; transition: 0.3s;}
#store ul li a:hover{ opacity: 0.7;}
#store ul li a:after{ position: absolute; right: 20px; top: 0; width: 15px; height: 100%; content: ''; background: url("../img/link_arrow.svg") center center no-repeat; background-size: contain; display:block; transition:.5s;}
@media (max-width: 1100px){
#store ul li a{ padding: 4.5vw 0; }
#store ul li a:after{ position: absolute; right: 1.8vw; width: 1.3vw; }
}/*END*/
@media (max-width: 750px){
#store .title_box{ text-align: center; padding: 80px 0 50px; }
#store .title_box h2{ font-size: 50px; line-height: 1;} 
#store ul{ margin: 0 auto; width: 70%; max-width: 1220px; display: block;  justify-content: space-between; } 
#store ul li{ width: 100%;}
#store ul li a{ padding: 40px 0; font-size: 16px; }
#store ul li:nth-child(1){ margin-bottom: 20px;}
#store ul li a:after{ position: absolute; right: 2.2vw; width: 13px; }
}/*END*/

@media (max-width: 500px){
#store .title_box{ text-align: center; padding: 60px 0 30px; }
#store ul{ margin: 0 auto; width: 75%;}
#store .title_box h2{ font-size: 46px; line-height: 1;} 
#store ul li a{ padding: 30px 0; font-size: 14px; }
#store ul li a:after{ position: absolute; right: 2.2vw; width: 10px; }

}/*END*/
@media (max-width: 410px){
#store .title_box h2{ font-size: 42px; line-height: 1;} 
#store ul li a{ padding: 30px 0; font-size: 13px; }
}/*END*/
@media (max-width: 380px){
#store ul{ margin: 0 auto; width: 80%;}
}/*END*/

/*------------------------------------
	info
-------------------------------------*/
#info{  background: linear-gradient(to bottom, rgba(255,255,255,0) 0%, rgba(255,255,255,1) 100%);  margin: 0 auto; text-align: center; display: block; position: relative; z-index: 200;}
#info .inner{ width: 85%; padding: 80px 0 100px; margin: 0 auto; display: flex; justify-content: center; }
#info .info_l{ padding:0 60px 0 0; border-right: solid 1px #ccc; display: flex; align-items: center; }
#info .info_r{ padding: 12px 0 12px 60px; text-align: left; }
/*txt*/
#info .info_l h2{ font-size: 42px; line-height: 1; }
#info .info_r p{ font-size: 16px; line-height: 1.4; padding: 5px 0 5px 16px; }
#info .info_r p span{ display: inline-block; }
#info .info_r p::before{ content: '・'; font-size: 16px; margin-left: -16px; }
@media (max-width: 1300px){
#info{ margin: 0 auto; text-align: center; display: block;}
#info .inner{ width: 85%; padding: 70px 0 90px; margin: 0 auto; display: flex; justify-content: center; }
#info .info_l{ padding:0 50px 0 0; border-right: solid 1px #ccc; display: flex; align-items: center; }
#info .info_r{ padding: 11px 0 11px 50px; text-align: left; }
/*txt*/
#info .info_l h2{ font-size: 40px; line-height: 1; }
#info .info_r p{ font-size: 15px; line-height: 1.4; padding: 5px 0 5px 15px; }
#info .info_r p span{ display: inline-block; }
#info .info_r p::before{ content: '・'; font-size: 15px; margin-left: -15px; }
}/*END*/
@media (max-width: 1150px){
#info{  margin: 0 auto;  text-align: center; display: block;}
#info .inner{ width: 85%; padding: 65px 0 85px; margin: 0 auto; display: flex; justify-content: center; }
#info .info_l{ padding:0 40px 0 0; border-right: solid 1px #ccc; display: flex; align-items: center; }
#info .info_r{ padding: 11px 0 11px 40px; text-align: left; }
/*txt*/
#info .info_l h2{ font-size: 38px; line-height: 1; }
#info .info_r p{ font-size: 14px; line-height: 1.4; padding: 4px 0 4px 14px; }
#info .info_r p span{ display: inline-block; }
#info .info_r p::before{ content: '・'; font-size: 14px; margin-left: -14px; }
}/*END*/
@media (max-width: 1000px){
#info{ margin: 80px auto 0; text-align: left;}
#info .inner{ width: 80%; border-top:solid 1px #ccc; padding: 70px 0 80px; margin: 0 auto; display: block; }
#info .info_l{ padding:0 0px 0 0; border-right: none; display: block;  }
#info .info_r{ padding: 30px 0 0px 0px; text-align: left; }
/*txt*/
#info .info_l h2{ font-size: 34px; line-height: 1; }
#info .info_r p{ font-size: 14px; line-height: 1.4; padding: 6px 0 6px 14px; }
#info .info_r p span{ display: inline-block; }
#info .info_r p::before{ content: '・'; font-size: 14px; margin-left: -14px; }
}/*END*/
@media (max-width: 640px){
#info{ margin: 60px auto 0; }
#info .inner{ width: 90%; padding: 50px 0 70px; margin: 0 auto; display: block; }
#info .info_l{ padding:0 0px 0 0; border-right: none; display: block;  }
#info .info_r{ margin: 0 auto; width: 95%; padding: 40px 0 0px 0px; text-align: left; }
/*txt*/
#info .info_l h2{ font-size: 28px; line-height: 1; text-align: center; }
#info .info_r p{ font-size: 13px; line-height: 1.4; padding: 6px 0 6px 13px; }
#info .info_r p span{ display: inline-block; }
#info .info_r p::before{ content: '・'; font-size: 13px; margin-left: -13px; }
}/*END*/

/*------------------------------------
	bottom_link
-------------------------------------*/
#bottom_link{ margin-top: 0px; display: flex; background: #000; width: 100%; position: relative; z-index: 200;}
.link_store,
.link_ks { width: 100%; }
.link_store a .link_bg{ background: url(../img/link_store.jpg) center center ;background-size: cover; z-index: -1; opacity: 0.4; }
.link_ks a .link_bg{ background: url(../img/link_ks.jpg) center center ;background-size: cover; z-index: -1; opacity: 0.7; }
#bottom_link div a{ width: 100%; height:19vw; display: flex; align-items: center; text-align: center; overflow: hidden;}
#bottom_link div .inner{ position: relative; z-index: 2; width: 100%; }
#bottom_link div h2{ color: #fff; width: 100%; }
#bottom_link a { position: relative; display: block; width: 100%; height: 100%; text-align: center; text-decoration: none;}
#bottom_link a .link_bg{ position: absolute; left: 0; top: 0; width: 100%; height: 100%; z-index: 1; transition: 1s;}
#bottom_link a:hover .link_bg{ transform: scale(1.07);}
/*PSX*/
/*Store*/
#bottom_link h2{ font-size: 18px; letter-spacing: 2.5px;line-height: 1; }
/*hover*/
#bottom_link a h2{ transition: .5s;}
#bottom_link a:hover h2{opacity: 0.7;}
#bottom_link a h2:after{ margin: 24px auto 0; width: 21px; height: 21px; content: ''; background: url("../img/link_arrow.svg"); display:block; position: relative; left: 0px;transition:.5s;}
#bottom_link a:hover h2:after{position: relative; left: 5px;}
@media screen and (max-width: 1900px) {
#bottom_link div a{ height:360px;}
}/*END*/
@media screen and (max-width: 1600px) {
#bottom_link div a{ height:21.5vw;}
#bottom_link a h2:after{ margin: 18px auto 0; width: 20px; height: 20px;}
}/*END*/
@media screen and (max-width: 1200px) {
/* > */
#bottom_link a h2:after{ margin: 18px auto 0; width: 18px; height: 18px;}
#bottom_link h2{ font-size: 16px; letter-spacing: .1vw;  }
}/*END*/
@media screen and ( max-width: 1000px) {
#bottom_link div a{ height:230px;  }
/*Store*/
#bottom_link h2{ font-size: 16px; letter-spacing: .2vw;  }
/* > */
#bottom_link a h2:after{ margin: 18px auto 0; width: 18px; height: 18px;}
}/*END*/
@media screen and (max-width: 750px) {
#bottom_link{ display: block; background: #000; width: 100%; }
#bottom_link div a{ height:230px; width: 100%;  }
#bottom_link h2{ font-size: 18px; letter-spacing: .2vw;  }
#bottom_link a h2:after{ margin: 18px auto 0; width: 18px; height: 18px;}
}/*END*/
@media screen and (max-width: 500px) {
#bottom_link h2{ font-size: 15px; letter-spacing: .2vw;}
}/*END*/
@media screen and (max-width: 450px) {
#bottom_link div a{ height:45vw; }
/*Store*/
#bottom_link h2{ font-size: 15px; letter-spacing: .2vw;}
}/*END*/
@media screen and (max-width: 400px) {
#bottom_link div a{ height:50vw; }
#bottom_link a h2:after{ margin: 10px auto 0; width: 16px; height: 16px;}
/*Store*/
#bottom_link h2{ font-size: 14px; letter-spacing: .1vw;}
}/*END*/

/*------------------------------------
	gotop
-------------------------------------*/
.gotop { position:absolute; bottom:0px; right:20px;width:50px; height:70px; box-sizing:border-box; border-radius: 0%; z-index: 2000!important;  z-index: 200;}
.gotop a{ position: relative; display:block; background:rgba(33,33,33,0.8); text-decoration:none;width:50px; height:50px; box-sizing:border-box; border-radius: 0%; z-index: 11; transition: 0.3s; }
.gotop a::after { position:absolute; top:50%; left:50%; content: ''; width: 16px; height: 16px; margin: -8px 0 0 -8px; background: url("../img/page_top.svg") no-repeat ; background-size: cover;}
.gotop a:hover { background:rgba(60,60,60,0.5); }
@media (max-width: 500px) {
.gotop { position:absolute; bottom:0px; right:10px; width:40px; height:50px; }
.gotop a{ width:40px; height:40px; }
.gotop a::after { width: 14px; height: 14px; margin: -7px 0 0 -7px; }
}/*END*/

/*------------------------------------
	footer
-------------------------------------*/
.bottom_space{height: 140px; background: #fff; position: relative; width: 100%; z-index: 200;}
footer{  background: #262626; width: 100%; height: auto; position: relative; z-index: 200; }
footer::after { content:" "; display:block; clear:both;}
.foot_l{ float: left; margin: 59px 0 0 40px;}
.foot_l .foot_logo { float: left; line-height: 1; margin-bottom: 53px; }
.foot_l .foot_logo img { width: 131px; transition: 0.2s; }
.foot_l .foot_logo a:hover img{ opacity: 0.6;}
.foot_l .copyright { float: left; margin: 13px 0 0 32px; font-size: 12px; line-height: 1; letter-spacing: 1px; color: #fff; font-family: 'Noto Sans JP', sans-serif; font-weight: 400; }
@media (max-width: 750px) { 
.foot_l{ float: none; margin: 39px 0 0 0px; text-align: center;}
.foot_l .foot_logo { float: none; line-height: 1; margin-bottom: 23px; }
.foot_l .copyright { float: none; margin: 13px 0 0 0px; padding-bottom: 30px; font-size: 12px; line-height: 1; color: #fff; }
}/*END*/
.foot_r { float: right; padding-top: 58px; margin: 0 35px 0 0 ; }
.foot_r .sns { display: flex; list-style-type: none; }
.foot_r .sns img{ width: 100%;}
.foot_r .sns li.tw img { padding: 2px;}
.foot_r .sns li.ig img { padding: 5.5px;}
.foot_r .sns > li { width: 40px; margin-right: 12px; padding: 5px; line-height: 1; border-radius: 50%; transition: 0.3s; background: #3c3c3c;}
.foot_r .sns > li:nth-child(3){ margin-right: 0; }
.foot_r .sns > li:hover{ opacity: 0.5; }
@media (max-width: 750px) {
.foot_r { float: none; padding-top: 40px; margin: 0px; }
.foot_r .sns { position: static; margin-bottom: 20px; justify-content: center; }
.foot_r .sns > li { margin-right: 10px; }
}/*END*/
@media (height:500px) {
.bottom_space{margin-top: 100px;}
}/*END*/

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