@charset "UTF-8";
/* 
	
CSS common.css */





/*//////////////////


font import


//////////////////*/

@import url(fonts/roboto.css);
@import url(//fonts.googleapis.com/css2?family=EB+Garamond&display=swap);
@import url(//fonts.googleapis.com/earlyaccess/notosansjapanese.css);

















/*//////////////////


Body


//////////////////*/

body { /* min-width: 1080px; */ font-family: 'Hiragino Kaku Gothic Pro','ヒラギノ角ゴ Pro W3','メイリオ',Meiryo,'ＭＳ Ｐゴシック',sans-serif; font-size: 1.6rem; color: #333; line-height: 2; letter-spacing: 0.03em; box-sizing: border-box; }
@media screen and (max-width: 1040px) { 
	body{ padding-right: 0; }
}
@media screen and (max-width: 767px) { 
}
@media screen and (max-width: 479px) { 
	
}




















/*//////////////////


基本構成


//////////////////*/

.noscrpt p { padding: 5px; background: #004680; font-weight: bold; text-align: center; }


/* secwrap：セクションを丸ごと囲う（背景画像セクションなど） */
.secwrap { padding: 100px 0; }
.secwrap.min { padding: 80px 0; }
.secwrap.end { padding-bottom: 0; margin-bottom: 80px; } /* 連続しない時 */
.secwrap>.section:last-child { margin-bottom: 0; }
@media screen and (max-width: 1040px){
	.secwrap { padding: 80px 0; }
}
@media screen and (max-width: 767px){
	.secwrap,
	.secwrap.min { padding: 60px 0; }
	.secwrap.end { margin-bottom: 60px; } /* 連続しない時 */
}


/* section */
.section { margin-bottom: 130px; }
.section.min { margin-bottom: 100px; }
.section:last-child { margin-bottom: 0; }
@media screen and (max-width: 1040px){
}
@media screen and (max-width: 767px){
	.section{ margin-bottom: 70px; }
	.section.min { margin-bottom: 60px; }
}


/* insec */
.insec { margin-bottom: 45px; }
.insec.wide { margin-bottom: 80px; }
.insec.middle { margin-bottom: 60px; }
.insec:last-child { margin-bottom: 0; }
@media screen and (max-width: 767px) {
	.insec.wide,
	.insec.middle { margin-bottom: 45px; }
}

.inbox{ margin-bottom: 30px; }
@media screen and (max-width: 767px){
	.inbox{ margin-bottom: 20px; }
}

/* incnt */
.incnt { max-width: 1040px; width: 88%; margin: 0 auto; position: relative; }
.incnt.min { max-width: 880px; }
.incnt.wide { max-width: 1180px; }
.incnt.wider { max-width: 1380px; }
.incnt.fix { max-width: none; width: calc(100% - 120px); margin: 0 60px; }
.incnt.max { max-width: none; width: 100%; }
@media screen and (max-width: 1280px){
	.incnt.fix { width: calc(100% - 80px); margin: 0 40px; }
}
@media screen and (max-width: 1040px){
	.incnt, .incnt.max, .incnt.wider, .incnt.wide, .incnt.min { width: 88%; }
	.incnt.fix{ width: calc(100% - 12%); margin: 0 6%; }
}
@media screen and (max-width: 767px){
	.incnt, .incnt.max, .incnt.wider, .incnt.wide, .incnt.min { width: 88%; }
	.incnt.none { width: 100%; }
}


/* basecnt */
/*
.basecnt { display: flex; justify-content: space-between; align-items: flex-start; }
.basecnt .inside { width: 25%; margin-top: -2px; }
.basecnt .inmain { width: 71%; }
@media screen and (max-width: 1040px) { 
	.basecnt { display: block; }
	.basecnt .inside { width: 100%; margin-top: 0px; }
	.basecnt .inmain { width: 100%; }
}
*/




















/*//////////////////


内部レイアウト


//////////////////*/


/* block */
.block { margin-bottom: 30px; }
@media screen and (max-width: 767px) {
}


/* inblock */
.inblock {  }
@media screen and (max-width: 767px) {
	.inblock { }
}


/* 装飾ボックス */
.bgbox { background: #f8f5ef; padding: 55px 80px; }
.bgbox.white { background: #fff; }
.bgbox.blue { background: #f2f5f6;}
.bgbox.min { padding: 40px; }
.bgbox.wide { padding: 60px; }
@media screen and (max-width: 1040px) { 
	.bgbox, .bgbox.wide { padding-left: 6%; padding-right: 6%; }
}
@media screen and (max-width: 767px) { 
	.bgbox, .bgbox.wide { padding: 25px 6%; }
}

.borderbox { border: 2px solid #9f8553; padding: 40px 6% 60px; box-sizing: border-box; border-radius: 10px; }
.borderbox.black { background: #333; }
.borderbox.min { padding: 40px; }
.borderbox.wide { padding: 60px; }
@media screen and (max-width: 1040px) { 
	.borderbox, .borderbox.wide { padding-left: 6%; padding-right: 6%; }
}
@media screen and (max-width: 639px) { 
	.borderbox, .borderbox.wide { padding: 25px 6%; }
}


/* 画面幅いっぱい（IEではサポートしていない） */
.normalbox { margin: 0 calc(50% - 440px); position: relative; } /* width:880px; */
.widebox { margin: 0 calc(50% - 590px); position: relative; } /* width:1080px; */
.widerbox { margin: 0 calc(50% - 690px); position: relative; } /* width:1380px; */
.fixbox { margin: 0 calc(50% - 50vw + 120px); position: relative; } /* padding:0 60px; */
.maxbox { margin: 0 calc(50% - 50vw); position: relative; } /* width:100%; */
@media screen and (max-width: 1500px){
	.widerbox { margin: 0 calc(50% - 44vw); } /* padding:0 6%; */
}
@media screen and (max-width: 1280px){
	.widebox, .fixbox { margin: 0 calc(50% - 44vw); } /* padding:0 6%; */
}
@media screen and (max-width: 1040px){
	.normalbox { margin: 0 calc(50% - 44vw); } /* padding:0 6%; */
}



/*
.imgbox.type1 { display: flex; flex-wrap: wrap; }
.imgbox.type1 .item { display: flex; align-items: center; }
.imgbox.type1 .item.padding { padding: 8%; box-sizing: border-box; }
.imgbox.type1 .item img { object-fit: cover; font-family: 'object-fit: cover;'; display: block; width: 100%; height: 100%; }
@media screen and (max-width: 767px) {
	.imgbox.type1 { display: block; }
	.imgbox.type1 .item { width: 100%; }
}


.basebox { padding: 80px 100px; background: #fff; box-sizing: border-box; margin-bottom: 20px; }
@media screen and (max-width: 1180px) { 
	.basebox { padding: 60px; }
}*/



/* スマホ横スクロール（js連動）　data-spwidth属性にスマホ時の表示サイズを記載 */
.scrollmsg { display: none; color: #004680; margin-bottom: 10px; }
@media screen and (max-width: 767px) {
	.scrollmsg { display: block; }
	.scrollwrap { overflow: auto; -webkit-overflow-scrolling: touch; /*滑らかに*/  border: 8px solid #f1f1f1; box-sizing: border-box; }
	.scroll { overflow: auto; text-align: center; -webkit-overflow-scrolling: touch; /*滑らかに*/ }
}


/* 回り込み不可取り消し */
.dcf:after { display: none;  }




















/*//////////////////


基本テキスト、画像装飾


//////////////////*/

/* 装飾 */
.mincho { font-family: yu-mincho-pr6n,"游明朝体",YuMincho,"Yu Mincho","ヒラギノ明朝 Pro W3","Hiragino Mincho Pro","ＭＳ Ｐ明朝","MS PMincho",serif; } /* 明朝体 */
.gothic { font-family: 'Hiragino Kaku Gothic Pro','ヒラギノ角ゴ Pro W3','メイリオ',Meiryo,'ＭＳ Ｐゴシック',sans-serif;  } /* 明朝体 */
.tategaki { -webkit-writing-mode: vertical-rl; -ms-writing-mode: tb-rl; writing-mode: vertical-rl; display: inline-block; text-align: left; } /* 縦書きテキスト */
.roboto { font-family: Roboto, 'Roboto', sans-serif; letter-spacing: 0.05em; } 
.garamondfont{ font-family: 'EB Garamond', serif; letter-spacing: 0.1em; }
.notofont{ font-family: 'Noto Sans Japanese', sans-serif; letter-spacing: 0.05em; }



/* テキスト寄せ */
.tl { text-align: left!important; }
.tc { text-align: center!important; }
.tr { text-align: right!important; }

.tcspl{ text-align: center; }
@media screen and (max-width: 767px) { 
	.tcspl{ text-align: left; }
}


/* 文字装飾 */
strong,
strong span { font-weight: bold!important; }
del { text-decoration: line-through!important; }

.inb { display: inline-block; } /* inline-block */
.palt { font-feature-settings : "palt"; letter-spacing: 0.05em; } /* 自動カーニング */
.bold,
.bold span,
.bold li { font-weight: bold!important; } /* 太字 */
.normal,
.normal span { font-weight: normal!important; }
.underline { text-decoration: underline!important; } /* 下線 */
.linethrough { text-decoration: line-through!important; } /* 取り消し線 */
.linehigh { line-height: 2.4; } /* 取り消し線 */
.linelow { line-height: 1.4; } /* 取り消し線 */
.line1 { line-height: 1; } /* 取り消し線 */


/* txt */
.txt.small { font-size: 1.5rem; }
.txt.big1 { font-size: 1.8rem; }
.txt.big2 { font-size: 2rem; }
.txt.big3 { font-size: 2.8rem; }
@media screen and (max-width: 767px) { 
	.txt.big3 { font-size: 2rem; }
}


/* txt.color */
.txt.blue { color: #034150; }
.txt.skyblue { color: #7CD0F1; }
.txt.black { color: #333; }
.txt.white { color: #fff; }
.txt.light { color: #f7f7f7; }
.txt.grey { color: #aaa; }
.txt.red { color: #e50312; }
.txt.yellow { color: #ffff00; }

/* bg */
.bg.blue { background: #034150; }
.bg.skyblue { background: #7CD0F1; }
.bg.black { background: #333; }
.bg.white { background: #fff; }
.bg.light { background: #f7f7f7; }
.bg.grey { background: #aaa; }
.bg.red { background: #e50312; }
.bg.yellow { background: #ffff00; }

.bg.black.txt.white{ background: #333; color: #fff; }
.bg.blue.txt.white{ background: #034150; color: #fff; }

/* border */
.border.blue { border: 1px solid #034150; }
.border.skyblue { border: 1px solid #7CD0F1; }
.border.black { border: 1px solid #333; }
.border.white { border: 1px solid #fff; }
.border.light { border: 1px solid #f7f7f7; }
.border.grey { border: 1px solid #aaa; }
.border.yellow { border: 1px solid #ffff00; }
.border.red { border: 1px solid #e50312; }

/* marker */
.marker.blue { background: linear-gradient(transparent 60%, #034150 0%); }
.marker.skyblue { background: linear-gradient(transparent 60%, #7CD0F1 0%); }
.marker.black { background: linear-gradient(transparent 60%, #333 0%); }
.marker.black.txt.white { color: #fff; background: linear-gradient(transparent 60%, #333 0%); }
.marker.white { background: linear-gradient(transparent 60%, #fff 0%); }
.marker.light { background: linear-gradient(transparent 60%, #f7f7f7 0%); }
.marker.grey { background: linear-gradient(transparent 60%, #aaa 0%); }
.marker.red { background: linear-gradient(transparent 60%, #e50312 0%); }
.marker.yellow { background: linear-gradient(transparent 60%, #ffff00 0%); }


/* blockquote */
blockquote, q { margin: 0; padding: 0; border: 0; font-style:normal; font-weight: normal; vertical-align: baseline; background:transparent; quotes: none; }
blockquote:before, blockquote:after,
q:before, q:after { content: ''; content: none; }
blockquote{ border-left: 2px solid #191919; padding-left: 20px; padding-right: 20px; }


/* iframe（動画） */
.iframe { clear: both; text-align: center; position: relative; width: 100%; padding-top: 56.25%; }
.iframe iframe { position: absolute; top: 0; right: 0; width: 100% !important; height: 100% !important; }


/* reset */
li, ol, ul, dl, dt, dd { list-style-type : none; padding: 0; margin: 0; list-style: none; }


/* indext */
p.indent,
ul.indent li, 
ol.indent li { padding-left: 1em!important; text-indent: -1em; /* font-feature-settings : "palt"; */ }


/* caution */
p.caution,
ul.caution li { padding-left: 1em!important; text-indent: -1em; /* font-feature-settings : "palt"; */ }
p.caution:before,
ul.caution li:before { content:"※"!important; }


/* none */
ul.none li { padding-left: 0!important; text-indent: 0!important; }
ul.none li:before { content: ""!important; }


/* margin */
ul.margin5 li, ol.margin5 li { margin-bottom: 5px; }
ul.margin10 li, ol.margin10 li { margin-bottom: 10px; }


/* 画像を中央でトリミング */
img.objectfit { object-fit: cover; font-family: 'object-fit: cover;'; display: block; width: 100%; height: 100%; }


.dotlist{ margin-left: -15px; text-align: left; }
.dotlist>li{ margin-left: 15px; display: inline-block; vertical-align: middle; }
.editbody ul.dotlist>li:before{ content: none }
.editbody ul.dotlist>li:before{ content: ""; background: #9f8553; width: 8px; height: 8px; border-radius: 50%; display: inline-block; vertical-align: 2px; margin-right: 5px; }
.editbody .bgbox{ padding: 35px 6%; }
.editbody .dotlist{ font-size: 1.8rem; }
@media screen and (max-width: 1040px){
}
@media screen and (max-width: 767px) { 
	.editbody .dotlist{ font-size: 1.6rem; }
}
@media screen and (max-width: 639px){
}
@media screen and (max-width: 479px){
}


.sakuralist img{ width: 36px; }




.spanlist{ margin-left: -5px; margin-bottom: -10px; }
.spanlist>li{ margin-left: 5px; display: inline-block; margin-bottom: 10px; }
.spanlist>li>span{ display: inline-block; background: #142D58; line-height: 1; color: #fff; padding: 10px 17px; letter-spacing: 0.05em; }
@media screen and (max-width: 767px){
	.spanlist>li>span{ font-size: 1em; }
}

.gallerylist{ display: flex; flex-direction: row; margin-left: -20px; }
.gallerylist>li{ margin-left: 20px; }
.editbody ul.gallerylist>li:before{ content: none }
.editbody ul.gallerylist li{ padding-left: 0!important; text-indent: 0!important; }
@media screen and (max-width: 767px){
	.gallerylist{ display: block; margin-left: 0; margin-bottom: -15px; }
	.gallerylist>li{ margin-left: 0; margin-bottom: 15px; }
}



.inblist{ margin-left: -15px; text-align: left; }
.inblist>li{ display: inline-block; vertical-align: middle; margin-left: 15px; padding-left: 1em!important; text-indent: -1em; }

.pricetxt{  }
.pricetxt .price{ display: inline-block; font-weight: bold; font-size: 3.2rem; line-height: 1.8; vertical-align: bottom; }
.pricetxt .priceunit{ display: inline-block; vertical-align: text-bottom; font-weight: bold; font-size: 1.8rem; }
@media screen and (max-width: 1040px) {
	.pricetxt .price { font-size: 2.8rem; }
}
@media screen and (max-width: 767px) { 
	.pricetxt .price { font-size: 2.4rem; vertical-align: 5px; }
	.pricetxt .priceunit{ font-size: 1.6rem; }
}

.sppackpricebox{ margin-left: -25px; margin-bottom: 30px; }
.sppackpricebox .sppackicon{ display: inline-block; vertical-align: middle; margin-left: 25px; }
.sppackpricebox .sppackicon>span{ font-weight: bold; font-style: italic; font-size: 2.8rem; color: #fff; background: #e53012; display: inline-block; line-height: 1; padding: 13px 17px; letter-spacing: 0.05em; }
.sppackpricebox .pricetxt{ display: inline-block; vertical-align: middle; margin-left: 25px; }
@media screen and (max-width: 1040px){
	.sppackpricebox .sppackicon>span{ font-size: 2.4rem; padding: 10px 15px; }
}
@media screen and (max-width: 767px) { 
	.sppackpricebox{ margin-bottom: 20px; }
}



/*//////////////////


タイトル・コピー・訴求テキスト


//////////////////*/



/* sectitlebox */
.copytxt{ font-size: 2.4rem; font-weight: bold; line-height: 1.6; margin-bottom: 30px; color: #9f8553; text-align: center; letter-spacing: 0.1em;  }
.copytxt.min{ margin-bottom: 20px; }
@media screen and (max-width: 1040px) {
}
@media screen and (max-width: 767px) { 
	.copytxt { font-size: 2rem; text-align: left; }
	.copytxt._1{ text-align: center; }
}
@media screen and (max-width: 479px){
}

.sectitle{ font-weight: 900; font-size: 2.5rem;line-height: 2; letter-spacing: 0.2em; text-align: center; margin-bottom: 30px; font-family: 'Noto Sans Japanese', sans-serif }
body:not(#index) .sectitle{ text-align: left; }
body.wp .sectitle{ margin-bottom: 50px }
.sectitle>span{ font-weight: 900 }
.sectitle._line{ position: relative; padding-left: 45px }
.sectitle._line:before{ content: ""; width: 30px; height: 6px; background: #1c5461; display: inline-block; position: absolute; top: 0; bottom: 0; margin-top: auto; margin-bottom: auto; left: 0; }
.sectitle._blue{ color: #1c5461 }
.sectitle.mincho{ font-family: yu-mincho-pr6n,"游明朝体",YuMincho,"Yu Mincho","ヒラギノ明朝 Pro W3","Hiragino Mincho Pro","ＭＳ Ｐ明朝","MS PMincho",serif; }
@media screen and (max-width: 1040px) {
}
@media screen and (max-width: 767px) { 
	body.wp .sectitle{ margin-bottom: 30px }
	.sectitle{ font-size: 2rem; margin-bottom: 20px }
}
@media screen and (max-width: 479px){
}

.indexsectitle{ margin-bottom: 20px }
.indexsectitle .sectitle{ margin-bottom: 5px }
.indexsectitle .entitle{ font-size: 1.8rem; font-family: 'EB Garamond', serif; letter-spacing: 0.2em; margin-bottom: 10px; text-align: center; color: #034150 }
.indexsectitle .entitle._inherit{ color: inherit; }
.indexsectitle._tl .sectitle,
.indexsectitle._tl .entitle{ text-align: left; }
@media screen and (max-width: 1040px) {
}
@media screen and (max-width: 767px) { 
	.indexsectitle{ margin-bottom: 15px }
	.indexsectitle .sectitle{ margin-bottom: 5px }
	.indexsectitle .sectitle,
	.indexsectitle .entitle{ text-align: left; }
}
@media screen and (max-width: 479px){
}


/* insectitle */
.insectitle{ font-size: 2.4rem; color: #fff; background: #9f8553; line-height: 1.6; padding: 16px 4%; letter-spacing: 0.03em; margin-bottom: 40px; text-align: left; font-weight: bold; display: flex; flex-direction: row; align-items: center; }
.insectitle:before{ content: ""; border: 2px solid #fff; width: 20px; height: 20px; display: inline-block; margin-right: 15px; }
.insectitle._1{ text-align: center; justify-content: center; }
.insectitle._1:before{ content: none }
@media screen and (max-width: 1040px) {
}
@media screen and (max-width: 767px) { 
	.insectitle { font-size: 2rem; padding: 10px 6%; margin-bottom: 30px; }
	.insectitle:before{ border: 1px solid #fff; width: 16px; height: 16px; }
	.insectitle._1{ text-align: left; justify-content: flex-start; }
}
@media screen and (max-width: 479px){
}


/* blocktitle */
.blocktitle{ font-size: 2rem; line-height: 1.6; margin-bottom: 30px; font-weight: bold; letter-spacing: 0.1em; font-weight: 900; font-family: 'Noto Sans Japanese', sans-serif; }
.blocktitle._blue{ color: #1c5461 }
@media screen and (max-width: 1040px) {
}
@media screen and (max-width: 767px) { 
	.blocktitle{ text-align: left; margin-bottom: 20px; font-size: 1.8rem }
}


/* subtitle */
.subtitle { text-align: left; line-height: 1.7; color: #000; font-size: 2rem; font-weight: bold; margin-bottom: 10px; }
.subtitle span.ez-toc-section { font-weight: bold; }
.subtitle.pink { color: #e96da3; }
@media screen and (max-width: 767px) { 
	.subtitle { font-size: 1.6rem; }
}

.icontitle{ margin-bottom: 10px; }
.icontitle>span{ background: #333; color: #fff; display: inline-block; padding: 9px 12px; line-height: 1.2; font-weight: bold; letter-spacing: 0.05em; }
@media screen and (max-width: 767px) { 
	.icontitle>span{ padding: 7px 10px; }
}




.boxtxttitle{  }
.boxtxttitle>p{ display: inline-block; padding: 10px 20px; line-height: 1.4; background: #333; color: #fff; font-weight: bold; font-size: 2.4rem; margin-bottom: 5px; }
.boxtxttitle>p:last-child{ margin-bottom: 0; }
@media screen and (max-width: 1040px) {
	.boxtxttitle>p{ font-size: 2rem; }
}
@media screen and (max-width: 767px) { 
	.boxtxttitle>p{ font-size: 1.8rem; padding: 8px 15px; }
}
@media screen and (max-width: 479px){
	.boxtxttitle>p{ font-size: 1.6rem; }
}

/* copy */
.copy{ font-weight: bold; font-size: 1.8rem; line-height: 1.6; margin-bottom: 30px;  font-family: 'Noto Sans Japanese', sans-serif; letter-spacing: 0.05em; }
@media screen and (max-width: 767px) { 
	.copy{ margin-bottom: 20px; }
}

/* title */
.title.type1 { }
@media screen and (max-width: 767px) { 
	.title.type1 {  }
}













/*//////////////////


リンク・ボタン


//////////////////*/

/* init */
a, input[type=submit] { color: #333; transition: 0.3s; }
a:hover { color: #666; }
a.btn, button { transition: 0.6s; backface-visibility: hidden; color: inherit; }
a.btn:hover, a.btn:active, a.btn::link, a.btn::visited,
button:hover, button:active, button::link, button::visited { text-decoration: underline; }
a.opacity:hover, a.opacity:active { opacity: 0.7; color: #333; }
@media screen and (max-width: 640px) {
	a { transition: none; }
	a.opacity:hover, a.opacity:active { opacity: 1; }
}

/* ボタン装飾 */
a.btn, button, input[type=submit] { display: inline-block; font-size: 100%; padding:20px 20px; min-width: 220px; line-height: 1.6; text-align: center; text-decoration: none!important; position: relative; }
a.btn.mwnone { min-width: 0; }
@media screen and (max-width: 767px) {
/*	a.btn, button { padding: 20px 10%; min-width: 0; max-width: 88%; }
	button { min-width: 180px; }*/
}
@media screen and (max-width: 400px) {
/*	a.btn, button { padding: 20px 5%; width: 90%; }*/
}

/* ボタン個別設定 */
/*a.btn.blue { background: #004680; color: #fff; border: 1px solid #004680; }
a.btn.blue:hover { background: #fff; color: #004680; }
a.btn.black { background: #333; color: #fff; }
a.btn.black:hover { background: #ccc; }
a.btn.white { background: #fff; color: #333; }
a.btn.white:hover { background: #333; color: #fff; }
button.blue { background: #004680; color: #fff; border: 1px solid #004680; }
button.blue:hover { background: #fff; color: #004680; }
button.light { background: #eee; color: #333; border: 1px solid #eee; }
button.light:hover { background: #ccc; border: 1px solid #aaa; }
input[type=submit].black { background: #333; color: #fff; }
input[type=submit].black:hover { background: #ccc; }
*/

/* リンクボタン */
a.linkbtn { color: #004680; font-size: 1.4rem; text-decoration: none; position: relative; padding-right: 40px; line-height: 1; }
@media screen and (max-width: 767px) {
	
}


/* ボタンボックス */
.btnbox { text-align: center; }
.btnbox a, .btnbox button { text-align: center; margin: 0 5px 10px; }
@media screen and (max-width: 767px) {
	
}


/* テキストリンク */
a.linktxt { color: #333; transition: 0.3s; }
a.linktxt:visited{ color: inherit; }
a.linktxt:hover{ color: #666; }


.txtlink{ font-weight: bold; text-decoration: none; color: #9f8553; }
.txtlink:after{ content: ""; background: url(../img/common/arr1_cha.svg) no-repeat; width: 20px; height: 20px; display: inline-block; background-size: contain; margin-left: 10px; vertical-align: -4px; }


.bottomlink{ margin-top: 35px; text-align: center; }
.bottomlink._tl{ text-align: left; }
.bottomlink .btnlink{ max-width: 280px; width: 100%; box-sizing: border-box; }
@media screen and (max-width: 767px) {
	.bottomlink{ margin-top: 25px; }
	.bottomlink._tl{ text-align: center; }
}

.tel{ text-decoration: none; cursor: default; }
.tel:hover{ color: inherit }







a.btnlink,
span.btnlink { color: #fff; background: #034150; text-align: center; font-size: 1.8rem; padding: 11px 20px; text-decoration: none; box-sizing: border-box; display: inline-block; line-height: 1.6; border: 1px solid #034150; letter-spacing: 0.2em }
a.btnlink.white,
span.btnlink.white{ color: #034150; background: #fff; border: 1px solid #fff }
a.btnlink:hover{ color: #034150; background: #fff; }
@media screen and (max-width: 767px) {
	a.btnlink,
	span.btnlink{ font-size: 1.6rem; padding: 13px 20px; }
}



/*//////////////////


テーブル


//////////////////*/

/* reset */
table { border-collapse: collapse; border-spacing:0; text-align: left; font-style:normal; font-weight:normal; width:100%; }
table th, table td { text-align: left; vertical-align: middle; list-style: none; word-break: break-all; }
table th { font-weight: bold }
table.base, table.type1 { width: 100%; margin: 10px 0; margin-bottom: 5px; }


/* common */
table.base th, table.base td,
table.type1 th, table.type1 td { padding: 36px 4%; line-height: 1.8; border: 1px solid #000000; }
@media screen and (max-width: 1040px) { 
	table.base th, table.base td,
	table.type1 th, table.type1 td{ padding-top: 20px; padding-bottom: 20px; }
}


/* type1 */
table.type1 thead th { background: #eee; text-align: center; } 
table.type1 tbody th { background: #f7f7f7; font-weight: normal; border-right: none }
table.type1 tbody th+td{ border-left: none }















/*//////////////////


svgアイコン


//////////////////*/

/* 線 */
svg.lineblack { stroke: #333; fill-opacity: 0; }
svg.linewhite { stroke: #fff; fill-opacity: 0; }

/* 塗り */
svg.black { fill: #333; stroke-opacity: 0; }
svg.white { fill: #fff; stroke-opacity: 0; }

















/*//////////////////


paddding・margin・border


//////////////////*/

/* border */
.border { border-color: #333; }
.border.all { border: 1px solid; }
.border.btm { border-bottom: 1px solid; }
.border.top { border-top: 1px solid; }
.border.left { border-left: 1px solid; }
.border.right { border-right: 1px solid; }
.bt0{ border-top:0!important; }
.bb0{ border-bottom:0!important; }
.br0{ border-right:0!important; }
.bl0{ border-left:0!important; }
.b0{ border:0!important; }


/* paddding・margin */
.pt0 { padding-top: 0px !important; }
.pb0 { padding-bottom: 0px !important; }
.pl0 { padding-left: 0px !important; }
.pr0 { padding-right: 0px !important; }
.mt0 { margin-top: 0px !important; }
.mb0 { margin-bottom: 0px !important; }
.ml0 { margin-left: 0px !important; }
.mr0 { margin-right: 0px !important; }
.pt10 { padding-top: 10px !important; }
.pb10 { padding-bottom: 10px !important; }
.pl10 { padding-left: 10px !important; }
.pr10 { padding-right: 10px !important; }
.mt10 { margin-top: 10px !important; }
.mb10 { margin-bottom: 10px !important; }
.ml10 { margin-left: 10px !important; }
.mr10 { margin-right: 10px !important; }
.pt15 { padding-top: 15px !important; }
.pb15 { padding-bottom: 15px !important; }
.pl15 { padding-left: 15px !important; }
.pr15 { padding-right: 15px !important; }
.mt15 { margin-top: 15px !important; }
.mb15 { margin-bottom: 15px !important; }
.ml15 { margin-left: 15px !important; }
.mr15 { margin-right: 15px !important; }
.pt20 { padding-top: 20px !important; }
.pb20 { padding-bottom: 20px !important; }
.pl20 { padding-left: 20px !important; }
.pr20 { padding-right: 20px !important; }
.mt20 { margin-top: 20px !important; }
.mb20 { margin-bottom: 20px !important; }
.ml20 { margin-left: 20px !important; }
.mr20 { margin-right: 20px !important; }
.pt30 { padding-top: 30px !important; }
.pb30 { padding-bottom: 30px !important; }
.pl30 { padding-left: 30px !important; }
.pr30 { padding-right: 30px !important; }
.mt30 { margin-top: 30px !important; }
.mb30 { margin-bottom: 30px !important; }
.ml30 { margin-left: 30px !important; }
.mr30 { margin-right: 30px !important; }
.pt40 { padding-top: 40px !important; }
.pb40 { padding-bottom: 40px !important; }
.pl40 { padding-left: 40px !important; }
.pr40 { padding-right: 40px !important; }
.mt40 { margin-top: 40px !important; }
.mb40 { margin-bottom: 40px !important; }
.ml40 { margin-left: 40px !important; }
.mr40 { margin-right: 40px !important; }
.pt50 { padding-top: 50px !important; }
.pb50 { padding-bottom: 50px !important; }
.pl50 { padding-left: 50px !important; }
.pr50 { padding-right: 50px !important; }
.mt50 { margin-top: 50px !important; }
.mb50 { margin-bottom: 50px !important; }
.ml50 { margin-left: 50px !important; }
.mr50 { margin-right: 50px !important; }
.pt60 { padding-top: 60px !important; }
.pb60 { padding-bottom: 60px !important; }
.pl60 { padding-left: 60px !important; }
.pr60 { padding-right: 60px !important; }
.mt60 { margin-top: 60px !important; }
.mb60 { margin-bottom: 60px !important; }
.ml60 { margin-left: 60px !important; }
.mr60 { margin-right: 60px !important; }
.pt70 { padding-top: 70px !important; }
.pb70 { padding-bottom: 70px !important; }
.pl70 { padding-left: 70px !important; }
.pr70 { padding-right: 70px !important; }
.mt70 { margin-top: 70px !important; }
.mb70 { margin-bottom: 70px !important; }
.ml70 { margin-left: 70px !important; }
.mr70 { margin-right: 70px !important; }
.pt80 { padding-top: 80px !important; }
.pb80 { padding-bottom: 80px !important; }
.pl80 { padding-left: 80px !important; }
.pr80 { padding-right: 80px !important; }
.mt80 { margin-top: 80px !important; }
.mb80 { margin-bottom: 80px !important; }
.ml80 { margin-left: 80px !important; }
.mr80 { margin-right: 80px !important; }
.pt90 { padding-top: 90px !important; }
.pb90 { padding-bottom: 90px !important; }
.pl90 { padding-left: 90px !important; }
.pr90 { padding-right: 90px !important; }
.mt90 { margin-top: 90px !important; }
.mb90 { margin-bottom: 90px !important; }
.ml90 { margin-left: 90px !important; }
.mr90 { margin-right: 90px !important; }
.pt100 { padding-top: 100px !important; }
.pb100 { padding-bottom: 100px !important; }
.pl100 { padding-left: 100px !important; }
.pr100 { padding-right: 100px !important; }
.mt100 { margin-top: 100px !important; }
.mb100 { margin-bottom: 100px !important; }
.ml100 { margin-left: 100px !important; }
.mr100 { margin-right: 100px !important; }

/* para */
.para-1 { margin-top: 10px!important; }
.para-2 { margin-top: 20px!important; }
.para-3 { margin-top: 30px!important; } @media screen and (max-width: 767px) { .para-3 { margin-top: 20px!important; } }
.para-4 { margin-top: 40px!important; } @media screen and (max-width: 767px) { .para-4 { margin-top: 30px!important; } }
.para-5 { margin-top: 50px!important; } @media screen and (max-width: 767px) { .para-5 { margin-top: 30px!important; } }
.para-6 { margin-top: 60px!important; } @media screen and (max-width: 767px) { .para-6 { margin-top: 40px!important; } }
.para-7 { margin-top: 70px!important; } @media screen and (max-width: 767px) { .para-7 { margin-top: 50px!important; } }
.para-8 { margin-top: 80px!important; } @media screen and (max-width: 767px) { .para-8 { margin-top: 50px!important; } }
.para-9 { margin-top: 90px!important; } @media screen and (max-width: 767px) { .para-9 { margin-top: 60px!important; } }
.para-10 { margin-top: 100px!important; } @media screen and (max-width: 767px) { .para-10 { margin-top: 60px!important; } }
.para-12 { margin-top: 120px!important; } @media screen and (max-width: 767px) { .para-12 { margin-top: 80px!important; } }
.para-14 { margin-top: 140px!important; } @media screen and (max-width: 767px) { .para-14 { margin-top: 80px!important; } }
.para-16 { margin-top: 160px!important; } @media screen and (max-width: 767px) { .para-16 { margin-top: 100px!important; } }
.para-18 { margin-top: 180px!important; } @media screen and (max-width: 767px) { .para-18 { margin-top: 100px!important; } }
.para-20 { margin-top: 200px!important; } @media screen and (max-width: 767px) { .para-20 { margin-top: 120px!important; } }
.para1 { margin-bottom: 10px!important; }
.para2 { margin-bottom: 20px!important; }
.para3 { margin-bottom: 30px!important; } @media screen and (max-width: 767px) { .para3 { margin-bottom: 20px!important; } }
.para4 { margin-bottom: 40px!important; } @media screen and (max-width: 767px) { .para4 { margin-bottom: 30px!important; } }
.para5 { margin-bottom: 50px!important; } @media screen and (max-width: 767px) { .para5 { margin-bottom: 30px!important; } }
.para6 { margin-bottom: 60px!important; } @media screen and (max-width: 767px) { .para6 { margin-bottom: 40px!important; } }
.para7 { margin-bottom: 70px!important; } @media screen and (max-width: 767px) { .para7 { margin-bottom: 50px!important; } }
.para8 { margin-bottom: 80px!important; } @media screen and (max-width: 767px) { .para8 { margin-bottom: 50px!important; } }
.para9 { margin-bottom: 90px!important; } @media screen and (max-width: 767px) { .para9 { margin-bottom: 60px!important; } }
.para10 { margin-bottom: 100px!important; } @media screen and (max-width: 767px) { .para10 { margin-bottom: 60px!important; } }
.para12 { margin-bottom: 120px!important; } @media screen and (max-width: 767px) { .para12 { margin-bottom: 80px!important; } }
.para14 { margin-bottom: 140px!important; } @media screen and (max-width: 767px) { .para14 { margin-bottom: 80px!important; } }
.para16 { margin-bottom: 160px!important; } @media screen and (max-width: 767px) { .para16 { margin-bottom: 100px!important; } }
.para18 { margin-bottom: 180px!important; } @media screen and (max-width: 767px) { .para18 { margin-bottom: 100px!important; } }
.para20 { margin-bottom: 200px!important; } @media screen and (max-width: 767px) { .para20 { margin-bottom: 120px!important; } }


/* 内側に余白 */
.pad5 { padding: 5px; }
.pad10 { padding: 10px; }
.pad20 { padding: 20px; }
.pad30 { padding: 30px; }
.pad40 { padding: 40px; }
.pad50 { padding: 50px; }
.pad60 { padding: 60px; }
.pad70 { padding: 70px; }
.pad80 { padding: 80px; }
.pad90 { padding: 90px; }
.pad100 { padding: 100px; }
.pad120 { padding: 120px; }
.pad140 { padding: 140px; }
.pad160 { padding: 160px; }
.pad180 { padding: 180px; }
.pad200 { padding: 200px; }
.pad4 { padding: 4%; }
.pad6 { padding: 6%; }
.pad8 { padding: 8%; }
@media screen and (max-width: 767px){
	.pad20 { padding: 4%; }
	.pad30 { padding: 6%; }
	.pad40, .pad50, .pad60 { padding: 8%; }
	.pad70, .pad80, .pad90, .pad100 { padding: 12%; }
	.pad120, .pad140, .pad160, .pad180, .pad200 { padding: 16%; }

}

/* 高さ指定ボックス（画像ボックスなどで使用） */
.h100 { height: 300px; }
.h200 { height: 300px; }
.h300 { height: 300px; }
.h400 { height: 400px; }
.h500 { height: 500px; }
.h600 { height: 600px; }
.h700 { height: 700px; }
.h800 { height: 800px; }
.h900 { height: 900px; }
.h1000 { height: 1000px; }
@media screen and (max-width: 1280px){
	.h100, .h200, .h300, .h400, .h500, .h600, .h700, .h800, .h900, .h1000 { height: auto; }
}

/* 画像幅の設定（imgflexboxなどで使用） */
.w-10 { width: 10%; }
.w-20 { width: 20%; }
.w-30 { width: 30%; }
.w-40 { width: 40%; }
.w-45 { width: 45%; }
.w-50 { width: 50%; }
.w-55 { width: 55%; }
.w-60 { width: 60%; }
.w-70 { width: 70%; }
.w-80 { width: 80%; }
.w-90 { width: 90%; }

/* 画像最大幅の設定 */
img.max200 { max-width: 200px; }
img.max300 { max-width: 300px; }
img.max400 { max-width: 400px; }
img.max450 { max-width: 450px; }
img.max500 { max-width: 500px; }
img.max600 { max-width: 600px; }
img.max700 { max-width: 700px; }
@media screen and (max-width: 767px) { 
	img.max200, img.max300, img.max400, img.max450, img.max500, img.max600, img.max700 { display: block; margin-left: auto; margin-right: auto;  }
}


/* 上下内側に余白 */
.ud0 { padding-top: 0px!important; padding-bottom: 0px!important; }
.ud5 { padding-top: 5px!important; padding-bottom: 5px!important; }
.ud10 { padding-top: 10px!important; padding-bottom: 10px!important; }
.ud20 { padding-top: 20px!important; padding-bottom: 20px!important; }
.ud30 { padding-top: 30px!important; padding-bottom: 30px!important; }
.ud40 { padding-top: 40px!important; padding-bottom: 40px!important; }
.ud60 { padding-top: 60px!important; padding-bottom: 60px!important; }
.ud80 { padding-top: 80px!important; padding-bottom: 80px!important; }
.ud100 { padding-top: 100px!important; padding-bottom: 100px!important; }
.ud120 { padding-top: 120px!important; padding-bottom: 120px!important; }
.ud140 { padding-top: 140px!important; padding-bottom: 140px!important; }
.ud160 { padding-top: 160px!important; padding-bottom: 160px!important; }
.ud180 { padding-top: 180px!important; padding-bottom: 180px!important; }
.ud200 { padding-top: 200px!important; padding-bottom: 200px!important; }
@media screen and (max-width: 767px){
	.ud20, .ud30 { padding-top: 20px!important; padding-bottom: 20px!important; }
	.ud40, .ud60 { padding-top: 40px!important; padding-bottom: 40px!important; }
	.ud80, .ud100 { padding-top: 60px!important; padding-bottom: 60px!important; }
	.ud120, .ud140 { padding-top: 80px!important; padding-bottom: 80px!important; }
	.ud160, .ud180, .ud200 { padding-top: 100px!important; padding-bottom: 100px!important; }
}

/* 表示非表示切り替え　*/
.tablethide { display: block; }
.tablethide.inb { display: inline-block; }
.tablethide.inline { display: inline; }
.tabletblock { display: none; }
@media screen and (max-width: 1040px) {
	.tablethide { display: none !important; }
	.tabletblock { display: block; }
	.tabletblock.inb { display: inline-block; }
	.tabletblock.inline { display: inline; }
}
.middlehide { display: block; }
.middlehide.inb { display: inline-block; }
.middlehide.inline { display: inline; }
.middleblock { display: none; }
@media screen and (max-width: 767px) {
	.middlehide { display: none !important; }
	.middleblock { display: block; }
	.middleblock.inb { display: inline-block; }
	.middleblock.inline { display: inline; }
}
.landhide { display: block; }
.landhide.inb { display: inline-block; }
.landhide.inline { display: inline; }
.landblock { display: none; }
@media screen and (max-width: 639px) {
	.landhide { display: none !important; }
	.landblock { display: block; }
	.landblock.inb { display: inline-block; }
	.landblock.inline { display: inline; }
}
.sphide { display: block; }
.sphide.inb { display: inline-block; }
.sphide.inline { display: inline; }
.spblock { display: none; }
@media screen and (max-width: 479px) {
	.sphide { display: none !important; }
	.spblock { display: block; }
	.spblock.inb { display: inline-block; }
	.spblock.inline { display: inline; }
}
.porthide { display: block; }
.porthide.inb { display: inline-block; }
.porthide.inline { display: inline; }
.portblock { display: none; }
@media screen and (max-width: 400px) {
	.porthide { display: none !important; }
	.portblock { display: block; }
	.portblock.inb { display: inline-block; }
	.portblock.inline { display: inline; }
}




















/*//////////////////


ユニーク設定


//////////////////*/






.newslist{ border-top: 1px solid #ccc; }
.newslist>li{ border-bottom: 1px solid #ccc; }
.newslist>li>dl{ padding: 23px 0; display: flex; flex-direction: row; align-items: center; }
.newslist>li>dl>dt{  display: flex; flex-shrink: 0; justify-content: center; margin-right: 45px; }
.newsicon{ font-weight: bold; font-size: 1.3rem; line-height: 1; width: 85px; box-sizing: border-box; display: flex; height: 30px; justify-content: center; align-items: center; letter-spacing: 0.05em; font-family: yu-mincho-pr6n,"游明朝体",YuMincho,"Yu Mincho","ヒラギノ明朝 Pro W3","Hiragino Mincho Pro","ＭＳ Ｐ明朝","MS PMincho",serif; background: #688d96; color: #fff; }
.newslist>li>dl>dt .date{ margin-right: 20px; letter-spacing: 0.05em; color: #034150; font-family: 'EB Garamond', serif; display: inline-block; vertical-align: middle; width: 80px }
.newslist>li>dl>dd{  }
.newslist>li>dl>dd a{ text-decoration: none; }
.newslist>li>dl>dd a:hover{ color: #9f8553; }
@media screen and (max-width: 1040px){
}
@media screen and (max-width: 767px) { 
	.newslist>li>dl{ padding: 15px 0 10px; display: block; }
	.newslist>li>dl>dt{ justify-content: flex-start; margin-bottom: 10px }
	.newslist>li>dl>dt .date{ margin-right: 10px; font-size: 1.6rem }
}
@media screen and (max-width: 639px){
}
@media screen and (max-width: 479px){
}







/* formbox1 */
.formbox1{ overflow: hidden; }
.formbox1>ul{ margin-bottom: -35px; }
.formbox1>ul>li{ margin-bottom: 35px; }
.formbox1>ul>li>dl{ display: -webkit-flex; display: -moz-flex; display: -ms-flex; display: -o-flex; display: flex; -webkit-flex-direction: row; -moz-flex-direction: row; -ms-flex-direction: row; -o-flex-direction: row; flex-direction: row; }
.formbox1>ul>li>dl>dt{ width: 230px; padding-top: 12px; flex-shrink: 0 }
.formbox1>ul>li>dl>dd{ flex-grow: 1; padding-right: 6% }
.formbox1._pt0>ul>li>dl>dt{ padding-top: 0; }
@media screen and (max-width: 1040px){
	.formbox1>ul{ margin-bottom: -20px; }
	.formbox1>ul>li{ margin-bottom: 20px; }
	.formbox1>ul>li>dl{ display: block; }
	.formbox1>ul>li>dl>dt{ width: 100%; padding-top: 0; font-weight: bold; margin-bottom: 10px; padding-left: 0; }
	.formbox1>ul>li>dl>dd{ width: 100% }
}
@media screen and (max-width: 767px){
}

.formbox1>ul>li>dl input[type="text"],
.formbox1>ul>li>dl input[type="tel"],
.formbox1>ul>li>dl input[type="email"],
.formbox1>ul>li>dl input[type="password"],
.formbox1>ul>li>dl textarea { background: #f2f2f2 !important; border: 1px solid #fff !important; font-size: 16px; height: 50px; }
.formbox1>ul>li>dl textarea{ height: 270px; }
.formbox1>ul>li>dl input[type="text"]:focus,
.formbox1>ul>li>dl input[type="tel"]:focus,
.formbox1>ul>li>dl input[type="email"]:focus,
.formbox1>ul>li>dl input[type="password"]:focus { border: 1px solid #191919 !important; }
.formbox1>ul>li>dl select{ max-width: 370px; width: 100%; background: url("../img/common/selectarr.svg") no-repeat 95% center, #fff; background-size: 16px 10px; border: 1px solid #CCC !important; font-size: 16px; height: 50px; }
.formbox1>ul>li>dl .tel{ max-width: 384px; width: 100%; }
.privacycheck{ text-align: center; margin-top: 50px; }
.privacycheck+.link{ text-align: center; }
.privacycheck+.link>a{ color: #992a6c; }
.privacycheck+.link>a:hover{ text-decoration: none; }
.btnarea{ margin-top: 50px; }
.btnarea>ul{ display: -webkit-flex; display: -moz-flex; display: -ms-flex; display: -o-flex; display: flex; -webkit-flex-direction: row; -moz-flex-direction: row; -ms-flex-direction: row; -o-flex-direction: row; flex-direction: row; justify-content: center; margin-left: -10px; }
.btnarea>ul>li{ max-width: 240px; margin-left: 10px; width: calc(50% - 10px) }

.formbox1 .commentbox{ text-align: right; }
.btnarea>ul>li .submit,
.btnarea>ul>li .btn { color: #fff; background: #034150; text-align: center; padding: 16px 20px; text-decoration: none; box-sizing: border-box; display: inline-block; line-height: 1.6; border: 1px solid #034150; letter-spacing: 0.2em; width: 100% }
.btnarea>ul>li .btn{ color: #191919; border: 1px solid #191919; background: transparent; }
.btnarea>ul>li .btn:hover{ color: #fff; background: #191919; }
.btnarea>ul>li .submit:hover{ color: #034150; background: #fff; }
@media screen and (max-width: 767px) {
	.btnarea{ margin-top: 40px }
	.btnarea>ul>li .submit,
	.btnarea>ul>li .btn { font-size: 1.6rem; padding: 13px 20px; }
}
@media screen and (max-width: 1040px){
	.formbox1>ul>li>dl input[type="text"],
	.formbox1>ul>li>dl input[type="tel"],
	.formbox1>ul>li>dl input[type="email"],
	.formbox1>ul>li>dl input[type="password"],
	.formbox1>ul>li>dl textarea,
	.formbox1>ul>li>dl select { font-size: 16px; }
}
@media screen and (max-width: 767px){
	.formbox1>ul>li>dl input[type="text"],
	.formbox1>ul>li>dl input[type="tel"],
	.formbox1>ul>li>dl input[type="email"],
	.formbox1>ul>li>dl input[type="password"],
	.formbox1>ul>li>dl select{ height: 60px; }
	.formbox1>ul>li>dl textarea{ height: 300px; }
}
@media screen and (max-width: 639px) { 
	.btnarea>ul{ display: block; margin-left: 0; margin-bottom: -10px; }
	.btnarea>ul>li{ margin-left: 0; margin-bottom: 10px; width: 100%; margin-left: auto; margin-right: auto; }
}





.dllist{ border-top: 1px solid #9ab3b9 }
.dllist>li{ border-bottom: 1px solid #9ab3b9 }
.dllist>li>dl{ display: flex; flex-direction: row;  }
.dllist>li dt{ font-family: 'Noto Sans Japanese', sans-serif; letter-spacing: 0.05em; font-weight: 900; color: #1c5461; background: #f2f5f6; padding: 23px 9%; width: 260px; box-sizing: border-box; display: flex; flex-shrink: 0; text-align: left; }
.dllist._hiraginodt>li dt{ font-family: 'Hiragino Kaku Gothic Pro','ヒラギノ角ゴ Pro W3','メイリオ',Meiryo,'ＭＳ Ｐゴシック',sans-serif; font-weight: bold; }
.dllist>li dd{ padding: 23px 8%; letter-spacing: 0.1em  }
@media screen and (max-width: 1040px){
	.dllist>li dt,
	.dllist>li dd{ padding: 23px 6%; }
	.dllist>li dt{ width: 30% }
}
@media screen and (max-width: 767px) {
}
@media screen and (max-width: 639px){
	.dllist>li dt{ width: 40% }
}
@media screen and (max-width: 479px){
}






.spectable{  }
.spectable>table{  }
.spectable>table tr{  }
.spectable>table tr td,
.spectable>table tr th{  padding: 24px 6%; }
.spectable>table tr td{  }
.spectable>table>thead{  }
.spectable>table>thead>tr>th{ color: #ffffff; background: #356773; font-family: 'Noto Sans Japanese', sans-serif; letter-spacing: 0.05em; border-right: 1px solid #fff; text-align: center; box-sizing: border-box; border-bottom: 1px solid #fff }
.spectable>table>thead>tr>th:first-child{ width: 30% }
.spectable>table>thead>tr>th:nth-child(2){ width: 35% }
.spectable>table>thead>tr>th:last-child{ border-right: 0 }
.spectable>table>tbody{  }
.spectable>table>tbody>tr:nth-child(even)>td{ background: #f2f5f6 }
.spectable>table>tbody>tr>td{ border-right: 1px solid #9ab3b9; border-bottom: 1px solid #9ab3b9; }
.spectable>table>tbody>tr>td:last-child{ border-right: 0 }
.spectable>table>tbody>tr>th{ font-family: 'Noto Sans Japanese', sans-serif; letter-spacing: 0.05em; background: #cdd9dc; font-weight: 900; text-align: center; border-right: 1px solid #9ab3b9; border-bottom: 1px solid #ffffff; color: #1c5461 }
.spectable>table>tbody>tr>th._bdb{ border-bottom: 1px solid #9ab3b9; }
.spectable>table>tbody>tr>td:nth-last-child(2){ font-family: 'Noto Sans Japanese', sans-serif; letter-spacing: 0.05em; font-weight: 900; color: #1c5461 }
.spectable>table>tbody>tr>td:nth-last-child(1){  }
@media screen and (max-width: 1040px){
}
@media screen and (max-width: 767px) { 
	.spectable>table>thead>tr>th{ display: none }
	.spectable>table>tbody>tr,
	.spectable>table>tbody>tr>td,
	.spectable>table>tbody>tr>th{ display: block; border:0!important; }
	.spectable>table>tbody>tr>td:nth-last-child(2){ padding-top: 15px; padding-bottom: 0; }
	.spectable>table>tbody>tr>td:nth-last-child(1){ padding-top: 0; padding-bottom: 15px; }
	.spectable>table>tbody>tr>th{ padding: 15px 6%; }
}
@media screen and (max-width: 639px){
}
@media screen and (max-width: 479px){
}


.innavlist{ margin-top: 50px }
.innavlist>ul{ display: flex; flex-direction: row; position: relative; justify-content: center; }
.innavlist>ul>li:last-child:after{ content: ""; background: #688d96; display: inline-block; position: absolute; top:0; bottom: 0; right: 0; width: 1px; height: 50px }
.innavlist>ul>li{ position: relative; flex-grow: 1; max-width: 290px }
.innavlist>ul>li._1{ flex-shrink: 0 }
.innavlist>ul>li:before{ content: ""; background: #688d96; display: inline-block; position: absolute; top:0; bottom: 0; left: 0; width: 1px; height: 50px }
.innavlist>ul>li>a{ font-weight: 900; font-size: 1.6rem; width: 100%; height: 50px; color: #034150; text-decoration: none; text-align: center; display: flex; align-items: center; justify-content: center; letter-spacing: 0.2em; box-sizing: border-box; }
.innavlist>ul>li>a:after{ content: ""; background: url(../img/common/arr2_blue.svg) no-repeat; background-size: contain; width: 12px; height: 10px; display: inline-block; margin-left: 5px }
@media screen and (max-width: 1040px){
	.innavlist>ul{ flex-wrap: wrap; margin-bottom: -10px }
	.innavlist>ul>li:last-child:after{ content: none }
	.innavlist>ul>li{ width: 50%; margin-bottom: 10px; max-width: 50% }
	.innavlist>ul>li:last-child:after,
	.innavlist>ul>li:nth-child(2n):after{ content: ""; background: #688d96; display: inline-block; position: absolute; top:0; bottom: 0; right: 0; width: 1px; height: 50px }
}
@media screen and (max-width: 767px) { 
}
@media screen and (max-width: 639px){
	.innavlist{ margin-top: 30px }
	.innavlist>ul{ display: block; }
	.innavlist>ul>li{ width: 100%; max-width: 100% }
	.innavlist>ul>li>a{ height: 40px }
	.innavlist>ul>li:last-child:after,
	.innavlist>ul>li:nth-child(2n):after,
	.innavlist>ul>li:before{ height: 40px }
	.innavlist>ul>li:after{ content: ""; background: #688d96; display: inline-block; position: absolute; top:0; bottom: 0; right: 0; width: 1px; height: 40px }
}
@media screen and (max-width: 479px){
}



.performancelist{ display: flex; flex-direction: row; margin-left: -5px; margin-bottom: -5px; flex-wrap: wrap; }
.performancelist>li{ margin-left: 5px; margin-bottom: 5px; width: calc(33.33% - 5px) }
.performancelist>li>.inwrap{ position: relative; text-decoration: none; display: flex; width: 100%; cursor: default; }
.performancelist>li .link{ background: rgba(76,76,76,.5); padding: 30px 6%; display: flex; flex-direction: column; align-items: center; justify-content: center; height: 330px; box-sizing: border-box; width: 100%; transition: .3s; opacity: 0; }
.performancelist>li .link>.inwrap{ display: inline-block; padding: 8px 20px; max-width: 186px; width: 100%; border: 1px solid #fff; color: #fff; transition: .3s; text-align: center; box-sizing: border-box; font-size: 1.8rem; letter-spacing: 0.2em; cursor: pointer; }
.performancelist>li img{ position: absolute; top: 0; bottom: 0; left: 0; right: 0; width: 100%; height: 100%; object-fit: cover; font-family: 'object-fit: cover;'; z-index: -1 }
.performancelist>li>.inwrap:hover .link{ opacity: 1 }
.performancelist>li>.inwrap .link>.inwrap:hover{ background: #fff; color: #034150 }
@media screen and (max-width: 1040px){
	.performancelist>li{ width: calc(50% - 5px) }
	.performancelist>li .link{ height: 280px; opacity: 1!important }
}
@media screen and (max-width: 767px) { 
	.performancelist>li{ width: calc(100% - 5px) }
	.performancelist>li .link{ height: 230px }
}
@media screen and (max-width: 639px){
}
@media screen and (max-width: 479px){
}



.performanceimage { width: 100%;  }
.performanceimage .showimagewrap{ position: relative; }
.performanceimage .showimagewrap .prev,
.performanceimage .showimagewrap .next{ width: 62px; height: 62px; display: flex; align-items: center; justify-content: center; background: #1c5461; border: 1px solid #1c5461; position: absolute; top: 0; bottom: 0; margin-bottom: auto; margin-top: auto; z-index: 10; text-decoration: none; cursor: pointer; transition: 0.3s }
.performanceimage .showimagewrap .prev{ left: -20px; }
.performanceimage .showimagewrap .next{ right: -20px; }
.performanceimage .showimagewrap .prev svg,
.performanceimage .showimagewrap .next svg{ width: 8px; height: 12px }
.performanceimage .showimagewrap .prev svg{ -webkit-transform:rotate(180deg); transform:rotate(180deg); }
.performanceimage .showimagewrap .next svg .arr1_st0.st0,
.performanceimage .showimagewrap .prev svg .arr1_st0.st0{ transition: .3s }
.performanceimage .showimagewrap .prev:hover,
.performanceimage .showimagewrap .next:hover { color: #034150; background: #fff; }
.performanceimage .showimagewrap .prev:hover .arr1_st0.st0,
.performanceimage .showimagewrap .next:hover .arr1_st0.st0{ stroke:#034150; }
.performanceimage .showimage { margin-bottom: 10px; position: relative; background-color: #f2f2f2; width: 100%; }
.performanceimage .showimage li { opacity:0; position:absolute; z-index:-1; width: 100%;  }
.performanceimage .showimage li.current{ opacity:1; position:static; z-index:1; animation: fadeIn 2s ease 0s 1 normal; -webkit-animation: fadeIn 2s ease 0s 1 normal; }
.performanceimage .showimage li p.img{ width: 100%; display: -webkit-flex; display: -moz-flex; display: -ms-flex; display: -o-flex; display: flex; -ms-align-items: center; align-items: center; justify-content: center; }
.performanceimage .showimage li img{ width: 100%; height: 100%;  object-fit: contain; font-family: 'object-fit: contain;'; /*IE対策*/ }
.performanceimage .showimage li:first-child { display: block; }
.performanceimage .imagelist { width: 100%; }
.performanceimage .imagelist ul { margin-left: -10px; }
.performanceimage .imagelist li { width: calc(25% - 10px); float: left; margin-left: 10px; }
.performanceimage .imagelist li>img{ width: 100%; height: 146px; object-fit: cover; font-family: 'object-fit: cover;'; /*IE対策*/ background-color: #f2f2f2; }

@keyframes fadeIn { /*「fadeIn」と名前をそろえる*/
    0% {opacity: 0; position:static; z-index:1;  } /*アニメーション開始時は完全に透過*/
    100% {opacity: 1} /*アニメーション終了時は透過しない*/
}
@media screen and (max-width: 1040px){
}
@media screen and (max-width: 767px) { 
	.performanceimage .showimagewrap .prev,
	.performanceimage .showimagewrap .next{ width: 40px; height: 40px; }
	.performanceimage .showimagewrap .prev{ left: -14px; }
	.performanceimage .showimagewrap .next{ right: -14px; }
	.performanceimage .showimagewrap .prev svg,
	.performanceimage .showimagewrap .next svg{ width: 8px; height: 12px }
	.performanceimage .showimage li.current{ animation: fadeIn 1s ease 0s 1 normal; -webkit-animation: fadeIn 1s ease 0s 1 normal; }
	.performanceimage .imagelist li{ position: relative; }
	.performanceimage .imagelist li:before{content: ""; display: block; padding-top: 100%; }
	.performanceimage .imagelist li img{position: absolute; width: 100%; height: 100%; top: 0; right: 0; bottom: 0; left: 0; margin: auto; display: block; }
	/*.performanceimage { width: 100%; }
	.performanceimage .showimage,
	.performanceimage .showimagewrap .prev,
	.performanceimage .showimagewrap .next { display: none!important; }
	.performanceimage .imagelist {margin-bottom: 15px; }
	.performanceimage .imagelist ul { margin-left: 0; }
	.performanceimage .imagelist li { width: 100%; margin-left: 0; margin-bottom: 15px; }
	.performanceimage .imagelist li>img{ height: auto; }*/
}
@media screen and (max-width: 639px){
}
@media screen and (max-width: 479px){
}


.performancesinglebox{ margin-left: -15px; color: #034150; margin-bottom: 40px; }
.performancesinglebox ._category{ display: inline-block; font-weight: bold; vertical-align: middle; margin-left: 15px }
.performancesinglebox ._category span{ font-weight: bold; }
.performancesinglebox ._category span:after{ content: " /"; }
.performancesinglebox ._category span:last-child:after{ content: none }
.performancesinglebox .material{ display: inline-block; font-weight: bold; vertical-align: middle; margin-left: 15px }
.performancedate{ font-size: 1.8rem; margin-bottom: 5px; color: #034150; letter-spacing: 0.2em }
@media screen and (max-width: 1040px){
}
@media screen and (max-width: 767px) { 
}
@media screen and (max-width: 639px){
}
@media screen and (max-width: 479px){
}

.incnt.pagermin{ max-width: 600px; width: 88% }
.performancesinglepager{ text-align: center; margin-left: -15px; margin-bottom: -15px }
.performancesinglepager>li{ display: inline-block; vertical-align: middle; margin-left: 15px; margin-bottom: 15px }
.performancesinglepager>li>a{ background: #034150; color: #fff; font-size: 1.8rem; padding: 7px 10px; display: inline-block; text-decoration: none; width: 280px; box-sizing: border-box; border: 1px solid #034150; letter-spacing: 0.2em }
.performancesinglepager>li>a svg{  }
.performancesinglepager>li>a svg{ width: 8px; height: 12px; margin-left: 15px }
.performancesinglepager>li>a.prev svg{ -webkit-transform:rotate(180deg); transform:rotate(180deg); margin-left: 0; margin-right: 15px }
.performancesinglepager>li>a svg .arr1_st0.st0{ transition: .3s }
.performancesinglepager>li>a:hover { color: #034150; background: #fff; }
.performancesinglepager>li>a:hover .arr1_st0.st0{ stroke:#034150; }
@media screen and (max-width: 1040px){
}
@media screen and (max-width: 767px) { 
}
@media screen and (max-width: 639px){
	.performancesinglepager{ margin-bottom: -10px }
	.performancesinglepager>li{ margin-bottom: 10px }
	.performancesinglepager>li{ display: block; }
	.performancesinglepager>li>a{ width: 100% }
}
@media screen and (max-width: 479px){
}