@charset "utf-8";

* {
	box-sizing: border-box;
}

html {
	height: 100%;
	min-height: 550px;
}

body {
	height: 100%;
	font-family: "游ゴシック", "YuGothic", "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", "ＭＳ ゴシック", sans-serif;
	font-weight: normal;
	font-size: 18px;
	text-align: center;
}

.red {
	color: #F00;
}

.gray {
	color: #888;
}


#background-image {
	background-image: url('./background.jpg');
	background-size: cover;
	background-repeat: no-repeat;
	background-position: center center;
	filter: blur(8px);
    -ms-filter: blur(8px);
	-webkit-filter: blur(8px);
	position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
	margin: auto;
	z-index: 1;
}

.content {
 	background: rgba(255, 255, 255, 0.85);
 	border-radius: 20px;
 	box-shadow: 0px 0px 10px rgba(255, 255, 255, 0.70);
	width: 80%;
	height: 80%;
	max-width: 560px;
	max-height: 640px;
	min-width: 500px;
	min-height: 550px;
 	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	margin: auto;
 	text-align: center;
 	z-index: 2;
 	padding: 50px;
}

.content p {
	line-height: 1.8em;
}

.content h1 {
	font-size: 1.4em;
}

.content input[type="text"], .content input[type="password"] {
	height: 40px;
	background-color: transparent;
	border: none;
	border-bottom: 2px solid rgb(41, 171, 226);
	font-size: 1.1em;
	margin: 0px 0px;
}

.content select {
    appearance: none;
    -webkit-appearance: none;
	-moz-appearance: none;
	border-radius: inherit;
	height: 40px;
	background-image: url('./selectbg.png');
	background-position: right;
	background-size: contain;
	background-repeat: no-repeat;
	background-color: transparent;
	border: none;
	border-bottom: 2px solid rgb(41, 171, 226);
	font-size: 1.1em;
	margin: 0px 0px;
}

@media all and (-ms-high-contrast: none), (-ms-high-contrast: active) {
	.content select {
    	background-image: none;
	}
}


.content .content-inside {
	height: 100%;
}

.content .content-header {
    font-size: 2.0em;
	padding-bottom: 10px;
	margin-bottom: 15px;
	display: inline-block;
	border-bottom: 2px solid rgb(41,171,226);
}

.content .content-header-logo {
	background-image: url('./tslogo.svg');
	background-size: fill;
	background-repeat: no-repeat;
	background-position: center center;
	margin: 0px auto 30px auto;
	padding: 10px;
	height: 50%;
}

.content .content-header-logo-small {
	height: 25%;
}

.content .content-warning {
	color: #ff4500;
	line-height: 0.6em;
	font-size: 0.8em;
	padding: 0;
}

.content .content-success {
	color: #228b22;
	line-height: 0.6em;
	font-size: 0.8em;
	padding: 0;
}

.content .form-title {
	float: left;
	font-weight: bold;
	color: rgb(41, 171, 226);
	display: block;
	width: 100%;
	margin-top: 15px;
}

.content .form-label {
	font-size: 0.8em;
	display: block;
	height: 1.5em;
	color: rgb(41, 171, 226);
}

.content .form-submit {
	display: none;
}

.content .content-bottom {
	position: absolute;
	left: 0;
	right: 0;
	bottom: -40px;
}

.content .content-bottom a {
	color: #fff;
	font-size: 0.9em;
}

.content-login input[type="text"], #login input[type="password"] {
	width: 400px;
	margin: 15px 0;
	text-align: center;
}

#register2 {
    width: 1000px;
	height: 620px;
	max-width: none;
    display: none;
}

#register2 .content-header-tsfont {
    width: 135px;
	margin: 0 15px;
}

#register2 .content-header-text {
	font-weight: middle;
}

#register2 .namecard {
	width: 1000px;
	height: 264px;
	position: absolute;
	top: 260px;
	left: 0;
	right: 0;
	z-index: 4;
	background-image: url('./pass_a.png');
	background-size: cover;
	background-repeat: no-repeat;
	background-position: center center;
	text-align: left;
}

#register2 .namecard-left {
	float: right;
	width: 420px;
	padding: 8px 50px;
}

#register2 .namecard-right {
	float: right;
	width: 290px;
	padding-left: 20px;
	font-size: 0.8em;
}

#register2 .namecard-left-field {
	float: left;
	margin-right: 5px;
}

#register2 .namecard-left-field input {
	width: 150px;
}

#register2 .namecard-left-field select {
	width: 150px;
}

.register-append {
    display: none;
	width: 1000px;
	height: 620px;
	max-width: none;
}

.register-append .namecard-left {
	width: 262px;
	height: 100%;
	position: absolute;
	top: 0;
	left: 100px;
	right: 0;
	z-index: 4;
	background-image: url('./pass_b.png');
	background-size: contain;
	background-repeat: no-repeat;
	background-position: center center;
	color: rgb(41, 171, 226);
}

.register-append .namecard-left span {
	white-space: nowrap;
	overflow: hidden;
    text-overflow: ellipsis;
}

.register-append .namecard-left-box {
	position: absolute;
	top: 300px;
	left: 0;
	right: 0;
	margin: auto;
	z-index: 5;
	width: 200px;
	height: 200px;
    text-align: center;
	overflow: hidden;
}

.register-append .namecard-left-top {
	font-size: 1.7em;
	letter-spacing: 2px;
	line-height: 1.3em;
	border-bottom: solid 1px rgb(41,171,226);
	padding-bottom: 10px;
}

.register-append .namecard-left-bottom {
	font-size: 0.8em;
	letter-spacing: 1px;
	margin-top: 10px;
}

.register-append .namecard-right {
	width: 500px;
	height: 100%;
	position: absolute;
	top: 0px;
	right: 100px;
	z-index: 4;
	padding: 75px 0;
	text-align: left;
}

.register-append .namecard-right-form-field {
	float: left;
	margin-right: 5px;
}

.register-append .namecard-right-form-field select {
	width: 400px;
}

.register-append .namecard-right-form-field .form-label {
	margin-bottom: 10px;
}

.next-button {
	width: calc(100% - 100px);
	position: absolute;
	bottom: 5%;
	z-index: 5;
}

.button-accent {
    letter-spacing: 0.5em;
    text-indent: 0.5em;
	border-radius: 5px;
	border: 3px solid rgb(247, 147, 30);
	color: rgb(247, 147, 30);
	background-color: transparent;
	font-size: 1em;
	font-weight: bold;
	width: 180px;
	height: 50px;
	margin-top: 10px;
}

.button-accent:hover {
	color: rgb(255, 255, 255);
	background-color: rgb(247, 147, 30);
}

.button-accent:disabled {
	border-color: rgba(247, 147, 30, 0.8);
	background-color: rgba(0, 0, 0, 0.07);
	color: rgba(247, 147, 30, 0.8);
}

.button-accent-loading {
	border-radius: 5px;
	border: 3px solid rgb(247, 147, 30);
	color: rgb(255, 255, 255);
	background-color: rgb(247, 147, 30);
	width: 180px;
	height: 50px;
	margin-top: 10px;
}

.button-accent-loading img {
	margin-top: 8px;
}

#finish {
	height: 300px;
	width: 640px;
}

#footer {
	font-size: 0.8em;
	letter-spacing: 0.1em;
	text-shadow: 0px, 0px, 3px, #000;
	color: rgb(255, 255, 255);
	width: 600px;
	position: absolute;
	bottom: 1%;
	right: 0;
	left: 0;
	margin: auto;
	display: block;
	z-index: 3;
}

#footer a {
	color: rgb(255, 255, 255);
}
