/* =================================
	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: 'Press Start 2P';
	src: url('/um/library/fonts/Press_Start_2P/PressStart2P-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.cover {
	position:relative;
	overflow:hidden;
}
@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;
}
}

/*	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;
	background-color:#fff;
}
@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:0;
}
p.btot-off {
	right:30px;
	bottom:-130px;
}
p.backtotop a {
	background-image:url(../img/cmn_bktotop.png);
	background-repeat:no-repeat;
	background-position:left top;
	width:120px;
	height:130px;
	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(108,100%,24%,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
================================= */

.idx div.footer {
	background-image:url(../img/cmn_bg_wrap.png);
	background-repeat:repeat;
}
.cmn div.footer {
	background-color:hsla(56,100%,50%,1);
}
div.footer div.footer-inner {
	text-align:left;
	background-repeat:no-repeat;
}
@media all and (min-width: 768px) {
.cmn div.footer {
	background-color:hsla(56,100%,50%,0.9);
}
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.footer-lef-lef {
	float:left;
}
div.footer-rig, div.footer-lef aside.footer-lef-rig {
	float:right;
}
.idx div.footer-lef {
	width:668px;
}
.idx div.footer-lef > aside {
}
.cmn div.footer-lef {
	width:612px;
}
.cmn div.footer-lef > aside {
}
div.footer-rig {
	width:300px;
}
}
@media all and (max-width: 767px) {
.idx div.footer {
	background-position:left top;
	background-size:16px 270px;
}
.cmn div.footer {
	background-color:hsla(56,100%,50%,0.9);
}
div.footer {
	padding:20px 0;
}
}
@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
============================== */
div.footer div div aside section {
	background-size:32px 32px;
	background-position:left top;
}
/*
div.footer aside section.sns-twitter {
	background-image:url(../img/sns_bg_tw.png);
	background-color:#55acee;
}
div.footer aside section.sns-insta {
	background-image:url(../img/sns_bg_ig.png);
	background-color:#cf2e92;
}
div.footer aside section.sns-line {
	background-image:url(../img/sns_bg_ln.png);
	background-color:#00c300;
}
*/
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-image:url(../img/sns_h2.png);
	background-repeat:no-repeat;
}
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;
}
div.footer-lef aside section.sns-twitter h2 a:before {
	background-position:left top;
}
div.footer-lef aside section.sns-line h2 a:before {
	background-position:left bottom;
}
div.footer-lef aside section.sns-insta h2 a:before {
	background-position:right bottom;
}
div.footer-lef aside section.sns-twitter > div {
	background-color:#fff;
}
@media all and (min-width: 768px) {
div.footer-lef h2 a {
	background-size:225px 200px;
	height:50px;
}
div.footer-lef section.sns-twitter h2 a {
	background-position:-30px 0;
}
div.footer-lef section.sns-insta h2 a {
	background-position:-30px -50px;
}
div.footer-lef section.sns-line h2 a {
	background-position:-30px -100px;
}
div.footer-lef aside section h2 a:before {
	background-size:100px 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-size:180px 160px;
	height:40px;
}
div.footer-lef section.sns-twitter h2 a {
	background-position:0 0;
}
div.footer-lef section.sns-insta h2 a {
	background-position:0 -40px;
}
div.footer-lef section.sns-line h2 a {
	background-position:0 -80px;
}
div.footer-lef aside section h2 a:before {
	background-size:80px 80px;
	right:26px;
	width:40px;
	height:40px;
}
div.footer-lef aside section {
	padding-bottom:12px;
}
div.footer-lef aside section > div {
	margin:0 12px;
}
div.footer-lef section.sns-twitter > div {
	margin:0 10px;
}
}


/*	instagram
============================== */
div.footer aside section.sns-insta div.insta ul {
	list-style-type:none;
}
div.footer aside section.sns-insta div.insta ul li {
	float:left;
	width:33.333333333333333%;
}
div.footer aside section.sns-insta div.insta ul li:nth-child(1),
div.footer aside section.sns-insta div.insta ul li:nth-child(2),
div.footer aside section.sns-insta div.insta ul li:nth-child(3) {
	margin-bottom:6px;
}
div.footer aside section.sns-insta div.insta ul li span,
div.footer aside section.sns-insta div.insta ul li span a,
div.footer aside section.sns-insta div.insta ul li span a img {
	display:block;
}
div.footer aside section.sns-insta div.insta ul li:nth-child(3n-2) span {
	margin-right:4px;
}
div.footer aside section.sns-insta div.insta ul li:nth-child(3n-1) span {
	margin-left:2px;
	margin-right:2px;
}
div.footer aside section.sns-insta div.insta ul li:nth-child(3n) span {
	margin-left:4px;
}
div.footer aside section.sns-insta div.insta ul li span a {
	position:relative;
	height:0;
	padding-top:100%;
	background-repeat:no-repeat;
	background-position:center center;
	background-size:cover;
}
div.footer aside section.sns-insta div.insta ul li span a img {
	position: absolute;
	left:0;
	top:0;
	width:100%;
	height:100%;
}
@media all and (min-width: 768px) {
div.footer aside section.sns-insta {
	margin-bottom:12px;
}
}
@media all and (max-width: 767px) {
}


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




/*	line and ig banner
============================== */
aside.footer-bn ul {
	list-style-type:none;
}
aside.footer-bn ul li:first-child {
}
aside.footer-bn ul li a, aside.footer-bn ul li span {
	display:block;
}
aside.footer-bn ul li a span {
	text-indent:110%;white-space:nowrap;overflow:hidden;
}
aside.footer-bn ul li a.lazy-done {
	-webkit-animation: fadeIn 700ms;
	animation: fadeIn 700ms;
}
@media all and (min-width: 768px) {
aside.footer-bn {
	padding-bottom:10px;
}
aside.footer-bn ul li {
	float:left;
}
.idx aside.footer-bn ul li {
	width:320px;
}
.cmn aside.footer-bn ul li {
	width:300px;
}
.idx aside.footer-bn ul li a span {
	height:165px;
}
.idx aside.footer-bn ul li:not(:last-child) {
	margin-right:10px;
}
.cmn aside.footer-bn ul li:not(:last-child) {
	margin-right:12px;
}
.cmn aside.footer-bn ul li a {
	background-size:cover;
}
.cmn aside.footer-bn ul li a span {
	height:155px;
}
aside.footer-bn ul li.sns-line a.lazy-done {
	background-image:url(../img/sns_bn_line.png?0);
}
aside.footer-bn ul li.sns-insta a.lazy-done {
	background-image:url(../img/sns_bn_ig.png?1);
}
aside.footer-bn ul li.sns-tiktok a.lazy-done {
	background-image:url(../img/sns_bn_tiktok.png?1);
}
}
@media all and (max-width: 767px) {
aside.footer-bn {
	padding:0 10px 10px;
}
aside.footer-bn ul li:not(:last-child) {
	margin-bottom:10px;
}
aside.footer-bn ul li a {
	position:relative;
	height:0;
	padding-top:37.3333333333333%;
	background-position:center center;
	background-repeat:no-repeat;
	background-size:cover;
}
aside.footer-bn ul li a span {
	position:absolute;
	left:0;
	top:0;
	width:100%;
	height:100%;
}
aside.footer-bn ul li.sns-line a.lazy-done {
	background-image:url(../img/sns_bn_line_smp.png?0);
}
aside.footer-bn ul li.sns-insta a.lazy-done {
	background-image:url(../img/sns_bn_ig_smp.png?1);
}
aside.footer-bn ul li.sns-tiktok a.lazy-done {
	background-image:url(../img/sns_bn_tiktok_smp.png?1);
}
}


/* =================================
	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 fadeOut {
	from {
		opacity: 1;
	}
	to {
		opacity: 0;
	}
}
@keyframes fadeOut {
	from {
		opacity: 1;
	}
	to {
		opacity: 0;
	}
}

@-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);
	}
}



.swing {
	animation-name: swing;
	animation-duration: 2s;
	animation-delay: .45s;
	animation-iteration-count: infinite;
}

@-webkit-keyframes swing {
	0%,100% { 
		-webkit-transform-origin: bottom center; 
	}
	10% { -webkit-transform: rotate(-15deg); }  
	20% { -webkit-transform: rotate(10deg); }
	30% { -webkit-transform: rotate(-5deg); }   
	40% { -webkit-transform: rotate(5deg); }    
	50% { -webkit-transform: rotate(-3deg); }

	60% { -webkit-transform: rotate(2deg); }
	70% { -webkit-transform: rotate(-2deg); }
	80% { -webkit-transform: rotate(1deg); }
	90% { -webkit-transform: rotate(-1deg); }
	100% { -webkit-transform: rotate(0deg); }
}