/* =================================
	TBS Reset CSS
================================= */

html,body,div,span,applet,object,iframe,h1,h2,h3,h4,h5,h6,p,blockquote,pre,a,abbr,acronym,address,big,cite,code,del,dfn,em,img,ins,kbd,q,s,samp,small,strike,strong,sub,sup,tt,var,b,u,i,center,dl,dt,dd,ol,ul,li,fieldset,form,label,legend,table,caption,tbody,tfoot,thead,tr,th,td,article,aside,canvas,details,embed,figure,figcaption,footer,header,hgroup,menu,nav,output,ruby,section,summary,time,mark,audio,video,main {margin:0;padding:0;border:0;font-size:100%;}
article,aside,details,figcaption,figure,footer,header,hgroup,menu,nav,section,main {display:block;}
body {font-family:Verdana,"Hiragino Kaku Gothic ProN",Meiryo,sans-serif;line-height:1;}
ol,ul {list-style:none;}
blockquote,q {quotes:none;}
blockquote:before,blockquote:after,q:before,q:after {content:'';content:none;}
table {border-collapse:collapse;border-spacing:0;}
wbr:after {content:"\00200B";}

/*	TBS reset
============================== */
.alt {position:absolute;top:-5000px;left:-9999px;}
.clearfix:after {content:"";clear:both;display:block;}
.hide-txt {text-indent:110%;white-space:nowrap;overflow:hidden;}
.fp-causion {display:none;}
.nocontxt {-webkit-touch-callout: none;-webkit-user-select: none;user-select: none;-webkit-user-drag:none;}
.nocontxt img {pointer-events: none;}
@media all and (min-width:768px) {
.alt-pc {position:absolute;top:-5000px;left:-9999px;}
.clearfix-pc:after {content:"";clear:both;display:block;}
.hide-txt-pc {text-indent:110%;white-space:nowrap;overflow:hidden;}
}
@media all and (max-width:767px) {
.alt-smp {position:absolute;top:-5000px;left:-9999px;}
.clearfix-smp:after {content:"";clear:both;display:block;}
.hide-txt-smp {text-indent:110%;white-space:nowrap;overflow:hidden;}
}
div.embed-tbsplayer {
background-color:#000;
position:relative;
height:0;
padding-top:56.25%;
}
div.embed-tbsplayer .tbs-player {
position:absolute;
left:0;
top:0;
width:100%;
height:100%;
}
div.embed-tbsplayer-audio {
background-color:#fff;
}
div.embed-tbsplayer-audio .tbs-player {
height:46px;
}
div.lbx-overlay {
z-index:10000;position:absolute;background-color:#000;width:100%;height:100%;left:0;top:0;right:0;bottom:0;opacity:0.9;
}

/* =================================
	common CSS
================================= */

/* link */
a:link {
	text-decoration:underline;
	color:#c3191e;
}
a:visited {
	text-decoration:none;
	color:#c3191e;
}
a:active {
	text-decoration:none;
	color:#c3191e;
}
a:hover {
	text-decoration:underline;
	color:#c3191e;
}

/* text-color */
.gray {color:#808080;}
.black {color:#171717;}
.purple {color:#a757a8;}
.ultramarine {color:#465daa;}
.blue {color:#0067c0;}
.lightblue {color:#afdfe4;}
.deepgreen {color:#060;}
.green {color:#008000;}
.yellowgreen {color:#b9c42f;}
.yellow {color:#ffb74c;}
.orange {color:#ff7b00;}
.pink {color:#f58f98;}
.vermilion {color:#ef454a;}
.red {color:#ed1a3d;}
.carmine {color:#c22047;}
.magenta {color:#ec008c;}
.brown {color:#994c00;}
.reddishbrown {color:#800000;}
.yellowocher {color:#c39143;}
.gold {color:#ffd700;}
.silver {color:#c0c0c0;}

.big {
	font-size:120%;
}
.s {
	font-size:87.5%;
}
.ff {
	font-family:serif;
}
.lazy {
	display:block;
	position:relative;
}
.wbr {
	white-space: nowrap;
	display: inline-block;
}
.txta-cen {
	text-align:center;
}
.udrline {
	text-decoration:underline;
}

/*	Web Fonts
============================== */
@font-face {
	font-family: 'Fjalla One';
	src: url('/um/library/fonts/Fjalla_One/FjallaOne-Regular.ttf') format("truetype");
	font-weight:normal;
	font-style:normal;
}

/*	background
============================== */

html, body, div#con-body {
	background-color:transparent;
}
body {
	color:#222;
	text-align:center;
	-webkit-text-size-adjust:100%;
	-ms-text-size-adjust: 100%;
	/* font-family:-apple-system,BlinkMacSystemFont,"Helvetica Neue","Yu Gothic",YuGothic,"ヒラギノ角ゴ ProN W3",Hiragino Kaku Gothic ProN,Arial,"メイリオ",Meiryo,sans-serif;
	font-family:-apple-system,BlinkMacSystemFont,"Helvetica Neue","ヒラギノ角ゴ ProN W3",Hiragino Kaku Gothic ProN,Arial,"メイリオ",Meiryo,sans-serif; */
	font-family:"Helvetica Neue","游ゴシック Medium","Yu Gothic Medium","ヒラギノ角ゴ ProN W3",Hiragino Kaku Gothic ProN,Arial,"メイリオ",Meiryo,sans-serif;
}
div#con-body {
}
div.tbs-fix-bg {
	width: 100%;
	height: 100%;
	position: fixed;
	background-image: url(../img/cmn_bg2.png);
	background-repeat:no-repeat;
	background-position:center center;
	background-size: cover;
	background-color:#eef0f2;
	z-index: -1;
}
div.cover {
	position:relative;
	overflow:hidden;
	/* background-image:url(../img/cmn_bg.png);
	background-position:center center;
	background-color:#eef0f2;
	background-attachment:fixed; */
}
@media all and (min-width: 768px) {
div#con-body {
}
div.cover {
	min-width:980px;
}
}
@media all and (max-width: 767px) {
div#con-body {
}
div.cover {
	min-width:320px;
	background-size:cover;
}
}

/*	copyright
============================== */
p.copyright {
	line-height:1.25;
	text-align:center;
}
p.copyright a {
}
@media all and (min-width: 768px) {
	p.copyright {
		font-size:75%;
		padding:25px 0 30px;
	}
	.cmn p.copyright {
		background-color:#eef0f2;
	}
	p.copyright a:hover {
		text-decoration:none;
	}
}
@media all and (max-width: 767px) {
	p.copyright {
		font-size:62.5%;
		padding:15px 10px;
	}
}

/*	rectangle
============================== */
div.recta div {
	width:300px;
	height:250px;
	overflow:hidden;
}
@media all and (min-width: 768px) {
}
@media all and (max-width: 767px) {
	div.recta {
		padding:10px 0;
	}
	div.recta div {
		margin:0 auto;
	}
}

/*	back to top
============================== */
p.backtotop {
	z-index:20;
	-webkit-transition-duration:300ms;
	-webkit-transition-timing-function:ease-in-out;
	transition-duration:300ms;
	transition-timing-function:ease-in-out;
}
p.backtotop a, p.backtotop span {
	display:block;
}
p.btot-on, p.btot-off {
	position:fixed;
}
@media all and (min-width: 768px) {
p.backtotop {
	transition-property:bottom;
}
p.btot-on {
	right:30px;
	bottom:30px;
}
p.btot-off {
	right:30px;
	bottom:-120px;
}
p.backtotop a {
	background-image:url(../img/cmn_bktotop.png);
	background-repeat:no-repeat;
	background-position:left top;
	width:102px;
	height:102px;
	text-indent:110%;white-space:nowrap;overflow:hidden;
}
}
@media all and (max-width: 767px) {
p.backtotop {
	min-width:320px;
	transition-property:bottom;
}
p.btot-on, p.btot-off {
	width:100%;
}
p.btot-on {
	bottom:0;
}
p.btot-off {
	bottom:-40px;
}
p.backtotop a {
	z-index:20;
	position:relative;
	text-decoration:none;
	color:#fff;
	text-shadow:0 2px 2px hsla(0, 0%, 0%, .5);
	background-color:hsla(356,93%,38%,0.9);
	height:40px;
}
p.backtotop a span {
	position:absolute;
	left:50%;
	top:50%;
	margin-top:-0.5em;
	margin-left:-5em;
	font-size:83%;
	font-weight:bold;
}
p.backtotop a span:before {
	position:absolute;
	left:50%;
	top:50%;
	margin-top:-8px;
	margin-left:-7em;
	display:block;
	content:"";
	background-image:url(../img/arrow16.svg);
	background-repeat:no-repeat;
	background-position:left top;
	background-size:16px 100px;
	width:16px;
	height:16px;
	background-color:#fff;
	border-radius:8px;
}
}

/*	shadow
============================== */
@media all and (min-width: 768px) {
.shadow, .shadow-pc {
	-webkit-box-shadow:0 0 12px 0 hsla(0,0%,0%,0.25);
	box-shadow:0 0 12px 0 hsla(0,0%,0%,0.25);
}
}
@media all and (max-width: 767px) {
.shadow, .shadow-smp {
	-webkit-box-shadow:0 0 6px 0 hsla(0,0%,0%,0.25);
	box-shadow:0 0 6px 0 hsla(0,0%,0%,0.25);
}
}


/* =================================
	footer SNS
================================= */

.cmn div.footer {
	position:relative;
	z-index:5;
}
div.footer div.footer-inner {
	text-align:left;
	background-repeat:no-repeat;
}
@media all and (min-width: 768px) {
div.footer {
	background-position:center top;
	padding:30px 0;
}
div.footer div.footer-inner {
	margin:0 auto;
}
.idx div.footer div.footer-inner {
	width:980px;
}
.cmn div.footer div.footer-inner {
	width:924px;
}
div.footer-lef, div.footer-lef aside.lef-ln {
	float:right;
}
div.footer-rig, div.footer-lef aside.lef-tw {
	float:left;
}
div.footer-lef {
	float:left;
}
div.footer-rig {
	float:right;
}
.idx div.footer-lef {
	width:668px;
}
.idx div.footer-lef > aside {
	width:328px;
}
.cmn div.footer-lef {
	width:612px;
}
.cmn div.footer-lef > aside {
	width:300px;
}
div.footer-rig {
	width:300px;
}
}
@media all and (max-width: 767px) {
}
@media all and (max-width: 479px) {
}

/*	SNS buttons
============================== */
div.sns-btns {
/*	background-image: -webkit-gradient(linear, left top, right top, from(hsla(0,0%,100%,0)), color-stop(0.25, hsla(0,0%,100%,1)), color-stop(0.75, hsla(0,0%,100%,1)), to(hsla(0,0%,100%,0)));
	background-image: -webkit-linear-gradient(left, hsla(0,0%,100%,0), hsla(0,0%,100%,1) 25%, hsla(0,0%,100%,1) 75%, hsla(0,0%,100%,0));
	background-image: linear-gradient(to right, hsla(0,0%,100%,0), hsla(0,0%,100%,1) 50%, hsla(0,0%,100%,1) 75%, hsla(0,0%,100%,0)); */
}
@media all and (min-width: 768px) {
div.sns-btns {
	padding-top:22px;
	height:90px;
	-webkit-box-sizing:border-box;
	-moz-box-sizing:border-box;
	box-sizing:border-box;
}
div.sns-btns div.tw {
	width:100px;
	float:left;
	margin-left:40px;
}
div.sns-btns div.fb {
	float:right;
}
}
@media all and (max-width: 767px) {
div.sns-btns {
	padding:10px 0 7px;
	text-align:center;
	background-color:hsla(0,0%,100%,0.5);
}
div.sns-btns div.tw, div.sns-btns div.fb {
	display:inline-block;
}
div.sns-btns div.tw {
	padding-right:50px;
}
}

/*	sns line twitter
============================== */
div.footer-lef aside section h2 {
	position:relative;
}
div.footer-lef aside section h2 a {
	display:block;
	text-indent:110%;white-space:nowrap;overflow:hidden;
	background-repeat:no-repeat;
}
div.footer-lef > aside.lef-ln h2 a {
	background-position:left bottom;
}
div.footer-lef > aside.lef-tw h2 a {
	background-position:left top;
}
div.footer-lef aside section h2 a:before {
	content:"";
	display:block;
	position:absolute;
	top:0;
	background-image:url(../img/sns_logos.svg);
	background-repeat:no-repeat;
}
aside section.sns-line {
	background-color:#00c300;
}
aside section.sns-timeline {
	background-color:#55acee;
}
div.footer-lef aside section > div {
	background-color:#fff;
}
@media all and (min-width: 768px) {
div.footer-lef h2 a {
	background-image:url(../img/sns_h2_pc.png);
	height:50px;
}
div.footer-lef aside section h2 a:before {
	background-size:50px 100px;
	right:10px;
	width:50px;
	height:50px;
}
div.footer-lef aside section.sns-line h2 a:before {
	background-position:0 -50px;
}
div.footer-lef aside section {
	padding-bottom:10px;
}
div.footer-lef aside section > div {
	margin:0 10px;
}
}
@media all and (max-width: 767px) {
div.footer-lef h2 a {
	background-image:url(../img/sns_h2_smp.png);
	background-size:130px 74px;
	height:37px;
}
div.footer-lef aside section h2 a:before {
	background-size:37px 74px;
	right:26px;
	width:37px;
	height:37px;
}
div.footer-lef aside section.sns-line h2 a:before {
	background-position:0 -37px;
}
div.footer-lef aside section {
	padding-bottom:12px;
}
div.footer-lef aside section > div {
	margin:0 26px;
}
}

/*	LINE
============================== */
aside section.sns-line div a,
aside section.sns-line div a img {
	display:block;
}
aside section.sns-line div a {
	text-decoration:none;
	margin:0 auto;
}
@media all and (min-width: 768px) {
aside section.sns-line div {
	padding:13px 0;
}
aside section.sns-line div a img {
	background-image:url(../img/sns_line_qr.png);
	background-repeat:no-repeat;
	background-position:center center;
}
aside section.sns-line div a,
aside section.sns-line div a img {
	width:120px;
	height:120px;
}
aside section.sns-line div a img {
	background-size:120px 120px;
}
.cmn aside section.sns-line div a,
.cmn aside section.sns-line div a img {
	width:130px;
	height:130px;
}
.cmn aside section.sns-line div a img {
	background-size:130px 130px;
}
}
@media all and (max-width: 767px) {
aside section.sns-line div {
}
aside section.sns-line div a {
	background-image:url(../img/cmn_btn_linesmp.png?0);
	background-repeat:no-repeat;
	background-position:center center;
	background-size:200px 60px;
}
aside section.sns-line div a,
aside section.sns-line div a img {
	height:60px;
}
}


/*	Paravi
============================== */
aside div.bn-paravi a,
aside div.bn-paravi a span,
aside div.bn-paravi a span img {
	display:block;
}
aside div.bn-paravi a span {
	background-position:center center;
	background-repeat:no-repeat;
	background-size:cover;
}
aside div.bn-paravi a span.lazy-done {
	-webkit-animation: fadeIn 700ms;
	animation: fadeIn 700ms;
}
@media all and (min-width: 768px) {
aside div.bn-paravi {
	margin-bottom:12px;
}
aside div.bn-paravi a span img {
	width:328px;
	height:122px;
}
.cmn aside div.bn-paravi a span img {
	width:300px;
	height:112px;
}
}
@media all and (max-width: 767px) {
aside div.bn-paravi {
	padding:20px 26px;
}
aside div.bn-paravi a span {
	position:relative;
	height:0;
	padding-top:37.1900826446281%;
}
aside div.bn-paravi a span img {
	position: absolute;
	left:0;
	top:0;
	width:100%;
	height:100%;
}
}


/* =================================
	TBS Modal CSS
================================= */

/* =================================
	TBS Modal CSS
================================= */

.md-box {
	position:absolute;
	z-index:10001;
	left:50%;
	top:50%;
}
.md-close {
	padding-right:4px;
}
.md-close a, .md-close a span {
	display:block;
}
.md-box .md-close a {
	width:100%;
/*	cursor:-webkit-zoom-out;
	cursor:zoom-out; */
}
.md-close a:after {
	display:block;
	content:"";
	clear:both;
}
.md-close a span {
	float:right;
	background-repeat:no-repeat;
	font-size:2px;text-indent:110%;white-space:nowrap;overflow:hidden;
	cursor:pointer;
}
.md-inner {
	position:relative;
	background-color:#000;
	overflow:hidden;
}
.md-inner video {
	width:100%;
	max-width:100%;
	height:auto;
}
.md-inner div.md-pics {
	background-repeat:no-repeat;
	background-position:center center;
}
.md-caption {
	text-align:left;
	line-height:1.25;
	padding:0.5em 0;
}

/*	case narrow
============================== */
.md-nrw {
	width:100%;
	position:absolute;
	z-index:5200;
}
.md-nrw .md-caption {
	background-color:#000;
	bottom:0;
	width:100%;
}


@media all and (min-width: 640px), (min-height: 640px) {
.md-close a {
	height:46px;
}
.md-close a span {
	width:40px;
	height:40px;
}
.md-close a span {
	background-position:left top;
}
.md-inner {
	margin-bottom:6px;
}
.md-caption {
	font-size:75%;
}
}
@media all and (max-width: 639px), (max-height: 639px) {
.md-close a {
	height:28px;
}
.md-close a span {
	width:24px;
	height:24px;
}
.md-close a span {
	background-position:0 -200px;
}
.md-inner {
	margin-bottom:4px;
}
.md-caption {
	font-size:67.5%;
}
}

/*	customize
============================== */
.md-close a span {
	background-image:url(/um/img/btn_modal.svg);
	background-color:#000;
}
.md-inner {
	/*background-color: rgba(0,0,0,0.5);*/
	-webkit-box-shadow: rgba(0,0,0,0.5) 0px 0px 5px 2px;
	box-shadow: rgba(0,0,0,0.5) 0px 0px 5px 2px;
}
.md-caption {
	color:#fff;
	word-break:break-all;
}
@media all and (min-width: 640px), (min-height: 640px) {
.md-close a span {
	border-radius:20px;
}
}
@media all and (max-width: 639px), (max-height: 639px) {
.md-close a span {
	border-radius:12px;
}
}


div.modal-overlay {
z-index:10000;position:absolute;background-color:#000;width:100%;height:100%;left:0;top:0;right:0;bottom:0;opacity:0.9;
}

/*	印刷禁止対応
============================== */
@media print {
div.modal-overlay {
	display:none;
}
.md-box, .md-close {
	display:none;
}
}



/* =================================
	keyframes
================================= */

@-webkit-keyframes fadeIn {
	from {
		opacity: 0;
	}
	to {
		opacity: 1;
	}
}
@keyframes fadeIn {
	from {
		opacity: 0;
	}
	to {
		opacity: 1;
	}
}

@-webkit-keyframes slideInUp {
	from {
		-webkit-transform: translate3d(0, 100%, 0);
		visibility: visible;
	}
	to {
		-webkit-transform: translate3d(0, 0, 0);
	}
}
@keyframes slideInUp {
	from {
		transform: translate3d(0, 100%, 0);
		visibility: visible;
	}
	to {
		transform: translate3d(0, 0, 0);
	}
}

@-webkit-keyframes slideInDown {
	from {
		-webkit-transform: translate3d(0, -100%, 0);
		visibility: visible;
	}
	to {
		-webkit-transform: translate3d(0, 0, 0);
	}
}
@keyframes slideInDown {
	from {
		transform: translate3d(0, -100%, 0);
		visibility: visible;
	}

	to {
		transform: translate3d(0, 0, 0);
	}
}

@-webkit-keyframes slideInLeft {
	from {
		-webkit-transform: translate3d(-100%, 0, 0);
		visibility: visible;
	}
	to {
		-webkit-transform: translate3d(0, 0, 0);
	}
}
@keyframes slideInLeft {
	from {
		transform: translate3d(-100%, 0, 0);
		visibility: visible;
	}
	to {
		transform: translate3d(0, 0, 0);
	}
}

@-webkit-keyframes slideInRight {
	from {
		-webkit-transform: translate3d(100%, 0, 0);
		visibility: visible;
	}
	to {
		-webkit-transform: translate3d(0, 0, 0);
	}
}
@keyframes slideInRight {
	from {
		transform: translate3d(100%, 0, 0);
		visibility: visible;
	}
	to {
		transform: translate3d(0, 0, 0);
	}
}

@-webkit-keyframes fadeInRight {
	from {
		opacity: 0;
		-webkit-transform: translate3d(100%, 0, 0);
	}
	to {
		opacity: 1;
		-webkit-transform: none;
	}
}
@keyframes fadeInRight {
	from {
		opacity: 0;
		transform: translate3d(100%, 0, 0);
	}
	to {
		opacity: 1;
		transform: none;
	}
}

@-webkit-keyframes fadeInLeft {
	from {
		opacity: 0;
		-webkit-transform: translate3d(-100%, 0, 0);
	}
	to {
		opacity: 1;
		-webkit-transform: none;
	}
}
@keyframes fadeInLeft {
	from {
		opacity: 0;
		transform: translate3d(-100%, 0, 0);
	}
	to {
		opacity: 1;
		transform: none;
	}
}

@-webkit-keyframes flipInX {
	from {
		-webkit-transform: perspective(400px) rotate3d(1, 0, 0, 90deg);
		-webkit-animation-timing-function: ease-in;
		opacity: 0;
	}
	40% {
		-webkit-transform: perspective(400px) rotate3d(1, 0, 0, -20deg);
		-webkit-animation-timing-function: ease-in;
	}
	60% {
		-webkit-transform: perspective(400px) rotate3d(1, 0, 0, 10deg);
		opacity: 1;
	}
	80% {
		-webkit-transform: perspective(400px) rotate3d(1, 0, 0, -5deg);
	}
	to {
		-webkit-transform: perspective(400px);
	}
}
@keyframes flipInX {
	from {
		transform: perspective(400px) rotate3d(1, 0, 0, 90deg);
		animation-timing-function: ease-in;
		opacity: 0;
	}
	40% {
		transform: perspective(400px) rotate3d(1, 0, 0, -20deg);
		animation-timing-function: ease-in;
	}
	60% {
		transform: perspective(400px) rotate3d(1, 0, 0, 10deg);
		opacity: 1;
	}
	80% {
		transform: perspective(400px) rotate3d(1, 0, 0, -5deg);
	}
	to {
		transform: perspective(400px);
	}
}