@charset "utf-8";

/*! normalize.css v8.0.0 | MIT License | github.com/necolas/normalize.css */
html{line-height:1.15;-webkit-text-size-adjust:100%}body{margin:0}h1{font-size:2em;margin:.67em 0}hr{box-sizing:content-box;height:0;overflow:visible}pre{font-family:monospace,monospace;font-size:1em}a{background-color:transparent}abbr[title]{border-bottom:none;text-decoration:underline;text-decoration:underline dotted}b,strong{font-weight:bolder}code,kbd,samp{font-family:monospace,monospace;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}img{border-style:none}button,input,optgroup,select,textarea{font-family:inherit;font-size:100%;line-height:1.15;margin:0}button,input{overflow:visible}button,select{text-transform:none}[type=button],[type=reset],[type=submit],button{-webkit-appearance:button}[type=button]::-moz-focus-inner,[type=reset]::-moz-focus-inner,[type=submit]::-moz-focus-inner,button::-moz-focus-inner{border-style:none;padding:0}[type=button]:-moz-focusring,[type=reset]:-moz-focusring,[type=submit]:-moz-focusring,button:-moz-focusring{outline:1px dotted ButtonText}fieldset{padding:.35em .75em .625em}legend{box-sizing:border-box;color:inherit;display:table;max-width:100%;padding:0;white-space:normal}progress{vertical-align:baseline}textarea{overflow:auto}[type=checkbox],[type=radio]{box-sizing:border-box;padding:0}[type=number]::-webkit-inner-spin-button,[type=number]::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}[type=search]::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}details{display:block}summary{display:list-item}template{display:none}[hidden]{display:none}

/* box-sizing */
html {
	-webkit-box-sizing: border-box;
	   -moz-box-sizing: border-box;
			box-sizing: border-box;
}
*,
*::before,
*::after {
	-webkit-box-sizing: inherit;
	   -moz-box-sizing: inherit;
			box-sizing: inherit;
}

/* common */
html {
	font-size: 62.5%;/* 10px */
}
body {
	position: relative;
	background: #333;
	color: #fff;
	font: 1.6em/1.6 sans-serif;
	word-wrap: break-word;
}
a:link {
	color: #090;
}
a:visited {
	color: #808080;
}
a:hover,
a:focus {
	color: #f30;
}
img {
	width: 100%;
	height: auto;
	vertical-align: bottom;
}
.clearfix:after {
	content: "";
	clear: both;
	display: block;
}

/* Contents
------------------------------------------------------------ */
#wrapper {
	background: #fff;
	color: #000;
}
.container {
	position: relative;
	width: 1000px;
	margin: 0 auto;
}

/* Header */
header {
	position: relative;
	border-bottom: 1px solid #ccc;
}
header .container {
	display: flex;
	justify-content: space-between;
	height: 50px;
}
header .logo {
	flex: 0 1 170px;
	align-self: center;
	margin: 0;
	font-size: inherit;
}
header .login {
	flex: 0 1 160px;
	align-self: flex-start;
	margin: 0;
}
header .login img:hover {
	opacity: .7;
	filter: alpha(opacity=70);
}

/* Footer */
footer {
	margin: 40px 0 0;
	padding-top: 20px;
	border-top: 1px solid #ccc;
	font-size: 0.75em;
	text-align: center;
}
footer .logo {
	width: 220px;
	margin: 0 auto 20px;
}
footer .menu {
	margin: 0 0 1em;
	color: #999;
}
footer .menu a:link {
	color: #666;
	text-decoration: none;
}
footer .menu a:visited {
	color: #999;
	text-decoration: none;
}
footer .menu a:hover,
footer .menu a:focus {
	color: #80cc00;
	text-decoration: underline;
}
footer .menu a:not(:first-child) {
	margin-left: .75em;
}
footer .copyright {
	padding: 15px 0;
	background: #333;
	font-size: 0.833em;
	color: #fff;
}


/* Entry
------------------------------------------------------------ */
.cont01 {
	height: 580px;
	background: url(./../img/before/pcCont01.jpg) no-repeat;
}
.cont01 .race {
	height: 370px;
}
.cont01 .race p {
	width: 440px;
	margin: 0;
	padding-top: 148px;
	font: bold 1.4em/1.1 sans-serif;
	text-align: center;
}
.cont01 .live {
	width: 310px;
	height: 174px;
	margin-left: 637px;
}

.obi {
	background: #000;
	text-align: center;
}

/* Form */
.entry-form {
	margin: 0 0 40px;
	padding-top: 30px;
	text-align: center;
}
.entry-form .error {
	font-size: 87.5%;
	font-weight: bold;
	color: #f00;
	text-align: center;
}
.entry-form .input input {
	width: 800px;
	margin: 10px auto 5px;
	padding: .75em 3%;
	border: 2px solid #f00;
	border-radius: 8px;
	font-size: 125%;
	box-shadow: 1px 1px 3px 0 rgba(0,0,0,0.2) inset;
}
.entry-form .input input:focus {
	outline: 0;
}
::-webkit-input-placeholder {
	color: #ccc;
	opacity: 1;
}
::-moz-placeholder {
	color: #ccc;
	opacity: 1;
}
/* IE 10 later */
:-ms-input-placeholder {
	color: #ccc;
}
.entry-form .base {
	position: relative;
}
.entry-form .arrow {
	width: 36px;
}
.entry-form .btn {
	margin: 10px auto;
}
.entry-form .btn input[type="submit"] {
	width: 800px;
	height: 100px;
	border: 0 none;
	background: url(./../img/before/pcBtn01.gif) no-repeat;
	text-indent: 110%;
	white-space: nowrap;
	overflow: hidden;
	outline: 0;
	cursor: pointer;
}
.entry-form .btn input[type="submit"]:hover {
	background-position: center bottom;
}

.entry-form .confirm {
	margin: 0;
	color: #666;
}
.entry-form .balloon {
	position: absolute;
	top: 25px;
	left: 46px;
}
@keyframes swing {
	0% { transform: rotate(0deg); }
	25% { transform: rotate(10deg); }
	50% { transform: rotate(0deg); }
	75% { transform: rotate(-10deg); }
	100% { transform: rotate(0deg); }
}
.swing {
	animation-name: swing;
	-moz-animation: swing linear 1.5s infinite;
	-moz-transform-origin: 114px 50px;
	-webkit-animation: swing linear 1.5s infinite;
	-webkit-transform-origin: 114px 50px;
	animation: swing linear 1.5s infinite;
	transform-origin: 114px 50px;
}

.certificates {
	margin: 0 0 40px;
}

body.entry .contents {
	margin-bottom: 70px;
}
body.entry .attention {
	font-size: 0.75em;
	color: #666;
}


/* Complete
------------------------------------------------------------ */
.complete02 {
	height: 440px;
	padding-top: 140px;
	background: url(./../img/before/pcComplete02.jpg) no-repeat;
	font-size: 0.875em;
}
.complete02 .pc {
	float: left;
	width: 380px;
	margin-left: 90px;
	text-align: center;
}
.complete02 .btn {
	width: 340px;
	margin:0 auto 15px;
}
.complete02 .btn img:hover {
	opacity: .7;
	filter: alpha(opacity=70);
}
.complete02 .mb {
	float: right;
	width: 380px;
	margin-right: 90px;
}
.complete02 .text {
	margin: 0 20px 15px;
}
.complete02 .info {
	margin: 0 20px;
	padding: 15px;
	border-radius: 6px;
	background: #fff8e6;
}


/* Sub pages
------------------------------------------------------------ */
body.sub .contents {
	width: 800px;
	margin: 2em auto 0;
	font-size: 87.5%;
}
body.sub .contents h1 {
	margin: 0 0 1.5em;
	padding: .5em 1.5em;
	border-left: 10px solid #574445;
	font: normal 150%/1.1 sans-serif;
	background: #796A6B;
	color: #fff;
}
body.sub .contents dl {
	margin-left: 1em;
	margin-right: 1em;
}
body.sub .contents dl dt {
	font-weight: bold;
	color: #333;
}
body.sub .contents dl dd {
	margin-bottom: 1em;
}
body.sub .back {
	margin: 50px auto 0;
	text-align: center;
}
body.sub .back a {
	display: inline-block;
	padding: .5em 1em;
	border-radius: .25em;
	border: 1px solid #999;
	color: #999;
	text-decoration: none;
}
body.sub .back a:hover {
	background: #f0f0f0;
}

.company {
	height: 160px;
	background: url(./../img/before/pcCompany.png) center no-repeat;
}
.outline {
	height: 336px;
	background: url(./../img/before/pcOutline.png) center no-repeat;
}
.mail {
	height: 40px;
}
.mail00 {
	background: url(./../img/before/pcCompanyMail00.png) center no-repeat;
}
.mail01 {
	background: url(./../img/before/pcCompanyMail01.png) center no-repeat;
}
.mail02 {
	background: url(./../img/before/pcCompanyMail02.png) center no-repeat;
}
.mail03 {
	background: url(./../img/before/pcCompanyMail03.png) center no-repeat;
}
.mail04 {
	background: url(./../img/before/pcCompanyMail04.png) center no-repeat;
}
.mail05 {
	background: url(./../img/before/pcCompanyMail05.png) center no-repeat;
}
.mail06 {
	background: url(./../img/before/pcCompanyMail06.png) center no-repeat;
}
.mail07 {
	background: url(./../img/before/pcCompanyMail07.png) center no-repeat;
}
.mail08 {
	background: url(./../img/before/pcCompanyMail08.png) center no-repeat;
}
.mail09 {
	background: url(./../img/before/pcCompanyMail09.png) center no-repeat;
}
.mail10 {
	background: url(./../img/before/pcCompanyMail10.png) center no-repeat;
}
.mail11 {
	background: url(./../img/before/pcCompanyMail11.png) center no-repeat;
}
.mail15 {
	background: url(./../img/before/pcCompanyMail15.png) center no-repeat;
}


/* Modal window
------------------------------------------------------------ */
.modal-overlay {
	z-index: 1;
	display: none;
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 120%;
	height: 100vh;
	background-color: rgba(0,0,0,0.75);
}
.modal-content {
	z-index: 2;
	display: none;
	position: fixed;
	width: 640px;
	margin: 0;
	padding: 20px;
	border: 8px solid #6c3;
	border-radius: 6px;
	background: #fff;
	color: #000;
	box-shadow: 0 0 10px #000;
}
.modal-close {
	position: relative;
	display: inline-block;
	width: 24px;
	height: 24px;
	margin: 0;
	overflow: hidden;
}
.modal-close::before,
.modal-close::after {
	content: '';
	position: absolute;
	width: 100%;
	height: 4px;
	top: 50%;
	left: 0;
	margin-top: -2px;
	background: #c0c0c0;
}
.modal-close::before {
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
}
.modal-close::after {
	-webkit-transform: rotate(-45deg);
	transform: rotate(-45deg);
}
.modal-image {
	width: 80%;
	margin-left: auto;
	margin-right: auto;
	text-align: center;
}
.modal-text {
	margin: 0;
	font-size: 3.2rem;
	line-height: 1.4;
	text-align: center;
}
