@charset 'utf-8';

@import url(https://fonts.googleapis.com/css?family=Roboto:400,500,700);

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, font, img, ins, kbd, q, s, samp,small, strike, strong, sub, sup, tt, var,dl, dt, dd, ol, ul, li,fieldset, form, label, legend,table, caption, tbody, tfoot, thead, tr, th, td {
  border: 0;
  font-weight: inherit;
  font-style: inherit;
  font-size: 100%;
  font-family: inherit;
  margin: 0;
  outline: 0;
  padding: 0;
  vertical-align: baseline;
}
* {
  margin: 0;
  padding: 0;
}
:focus {
  outline: 0;
}
ol, ul {
  list-style: none;
}
table {
  border-collapse: collapse;
  border-spacing: 0;
}
caption, th, td {
  font-weight: normal;
  text-align: left;
}
em, strong {
  font-weight: bold;
}
* {
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  -webkit-touch-callout: none;
  -webkit-text-size-adjust: 100%;
}
body {
	font-family: 'Roboto','Hiragino Kaku Gothic Pro','ヒラギノ角ゴ Pro W3','メイリオ',meiryo,'ＭＳ Ｐゴシック',sans-serif;
	font-size: 14px;
	color: #666;
	background: #fff;
}
.clearfix, .wrapper {
	min-height: 1px;
}
.clearfix:after, .wrapper:after, .container:after {
	content: "";
	display: block;
	clear: both;
}
a {
	color: #666;
	text-decoration: none;
}
a:hover {
	text-decoration: underline;
}
.container {
	position: relative;
	width: 400px;
	margin: 0 auto;
}
.container-static {
	width: 810px;
}
hr {
	margin: 30px 0 0 0;
	padding: 0 0 30px 0;
	border: none;
	border-top: 1px solid #ccc;
}
.header {
	padding: 8px 0;
	border-bottom: 1px solid #ccc;
	margin: 0 0 30px;
}
.header .logo {
	text-align: center;
}
.header .logo li {
	vertical-align: middle;
	display: inline-block;
	margin: 0 0 0 10px;
}
.header .logo li:first-child {
	margin: 0;
}
.header h1 a {
	display: block;
	background: url(/images/logo.svg) no-repeat top left;
	background-size: 100%;
	width: 60px;
	height: 0;
	padding: 35px 0 0 0;
	overflow: hidden;
	margin: 0 auto;
}
.header h2 img {
	display: block;
	width: 60px;
}
.header-index {
	padding: 60px 0 0;
	margin: 0 0 60px;
	border: none;
}
.header-index h1 {
	background: url(/images/logo.svg) no-repeat top left;
	background-size: 100%;
	width: 337px;
	height: 0;
	padding: 199px 0 0 0;
	overflow: hidden;
	margin: 0 auto;
}
.about dt {
	font-size: 20px;
	font-weight: bold;
	margin: 0 0 5px;
}
.about dd {
	font-size: 16px;
	line-height: 1.8;
	margin: 0 0 30px;
}
.about dd ul {
	margin: 20px 0 0 0;
	text-align: left;
}
.about dd li {
	vertical-align: middle;
	display: inline-block;
	width: 190px;
	margin: 10px auto;
}
.about dd li:first-child {
	margin: 0 20px 0 0;
}
.about dd li img {
	display: block;
	width: 100%;
}
.page-header {
	margin: 0 0 30px;
}
.page-header h2 {
	font-size: 18px;
	text-align: center;
	margin: 0 0 30px;
}
.page-header p {
	margin: 5px 0 0;
	line-height: 22px;
}
.privacypolicy ol {
	list-style-type: decimal;
	margin: 0 0 0 20px;
}
.privacypolicy li {
	margin: 0 0 30px;
}
.privacypolicy a {
	color: #cbb677;
}
.terms dd, .terms p {
	margin: 0 0 30px;
}
.terms dt {
	font-weight: bold;
}
.terms a {
	color: #cbb677;
}
.contact a {
	color: #cbb677;
}
.terms, .privacypolicy {
	line-height: 2;
}
.notification {
	text-align: center;
	font-weight: bold;
	margin: 0 0 30px;
	background: #e5ecf9;
	border: 1px solid #3366cc;
	color: #3366cc;
	padding: 10px 0;
	border-radius: 4px;
}
.errors {
	color: #cc0000;
	text-align: center;
	font-weight: bold;
	line-height: 2;
	margin: 0 0 30px;
}
.form dl {
	margin: 0 0 45px;
}
.form dt {
	margin: 0 0 5px;
}
.form dd {
	margin: 0 0 30px;
}
.form dd.agreement {
	text-align: center;
}
.form dd.agreement a {
	color: #b7b090;
}
.form .autologin {
	margin: 10px 0 0 0;
}
.form input[type=text],
.form input[type=password] {
	font-size: 18px;
	padding: 10px;
	border: 1px solid #d2d2d2;
	background: #f8f8f0;
	width: 100%;
	box-sizing: border-box;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
}
.form input[type=text].disabled {
	background: #efefef;
}
.form textarea {
	font-size: 18px;
	padding: 10px;
	border: 1px solid #d2d2d2;
	background: #f8f8f0;
	width: 100%;
	height: 300px;
	box-sizing: border-box;
}
.form input[type=checkbox] {
	display: none;
}
.form input[type="checkbox"] + label {
	cursor: pointer;
	position: relative;
	box-sizing: border-box;
	display: inline-block;
	vertical-align: middle;
	height: 22px;
	margin: 0;
	padding: 0 0 0 32px;
	background: url(/images/checkbox@2x.png) no-repeat left top;
	background-size: 22px 44px;
	background-position: 0 0;
}
.form input[type="checkbox"]:checked + label {
	background-position: 0 -22px;
}
.form label {
	line-height: 22px;
}
.form select {
	color: #555;
	font-size: 18px;
	padding: 12px 16px;
	border: 1px solid #e0e0de;
	width: 100%;
	box-sizing: border-box;
	border-radius: 0;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	background: #f8f8f0 url(/images/select_arrow@2x.png) no-repeat center right 10px;
	background-size: 18px 18px;
}
.form select::-ms-expand {
	display: none;
}
.authorize p {
	font-weight: bold;
	margin: 0 0 30px;
}
.authorize .box {
	text-align: center;
	border: 1px solid #bfbfbf;
	border-radius: 15px;
	margin: 0 0 60px;
}
.authorize hr {
	margin: 0;
	padding: 0;
}
.authorize ul {
	padding: 30px;
}
.authorize li {
	text-align: left;
	vertical-align: middle;
	display: inline-block;
	margin: 0 0 0 15px;
}
.authorize li p {
	color: #999;
	font-weight: normal;
	margin: 0;
}
.authorize li:first-child {
	margin: 0;
}
.authorize li img {
	width: 120px;
}
.authorize dl {
	padding: 30px;
}
.authorize dt {
	color: #999;
	margin: 0 0 10px;
}
.authorize dd {
	font-weight: bold;
}
.apps {
	margin: 0 0 60px;
}
.apps li {
	display: table;
	border-bottom: 1px solid #ccc;
	padding: 30px 0;
}
.apps li:first-child {
	border-top: 1px solid #ccc;
}
.apps .app {
	vertical-align: top;
	display: table-cell;
	width: 170px;
	padding: 0 30px 0 0;
}
.apps .app img {
	width: 100%;
	display: block;
	margin: 0 0 10px;
}
.apps .app h3 {
	font-size: 18px;
	font-weight: bold;
}
.apps .app p {
	color: #999;
}
.apps .action {
	width: 200px;
	vertical-align: middle;
	display: table-cell;
}
.action {
	text-align: center;
}
.action li:first-child {
	margin: 0;
}
.action li {
	margin: 30px 0 0 0;
}
.apps .text {
	width: 200px;
	vertical-align: middle;
	display: table-cell;
}
.apps .text h3 {
	font-size: 18px;
	font-weight: bold;
	margin: 4px 0px;
}
.apps .text p {
	color: #999;
	margin: 4px 0px;
}
.actions {
	text-align: center;
}
.actions li {
	vertical-align: top;
	width: 180px;
	display: inline-block;
	margin: 0 0 0 30px;
}
.actions li:first-child {
	margin: 0;
}
.actions li .btn {
	width: 100%;
}
.btn {
	display: block;
	text-align: center;
	cursor: pointer;
	border: none;
	background: #b7b090;
	color: #fff;
	font-size: 18px;
	padding: 18px 0;
	width: 100%;
	border-radius: 6px;
	line-height: 1;
	margin: 0 auto;
}
.btn:hover {
	text-decoration: none;
	opacity: 0.8;
}
.btn span {
	font-size: 14px;
}
.btn-logout {
	background: #b5b5b5;
}
.btn-cancel,
.btn-skip {
	background: #b5b5b5;
}
.btn-app-cancel {
	background: #eee;
	border: 1px solid #b5b5b5;
	color: #606060;
}
.btn-app-cancel:hover {
	background: #b5b5b5;
	border: 1px solid #b5b5b5;
	color: #fff;
}
.btn-facebook {
	background: #3b5998;
}
.btn-twitter {
	background: #000000;
}
.btn-contact {
	width: 285px;
}
.btn-login {
	display: inline-block;
	width: 64%;
	margin-right: 2%;
}
.btn-signup {
	display: inline-block;
	width: 34%;
}
.footer {
	margin: 60px 0 30px;
}
.footer ul {
	text-align: center;
	margin: 0 0 30px;
}
.footer li {
	display: inline;
	margin: 0 0 0 30px;
}
.footer li:first-child {
	margin: 0;
}
.footer p {
	text-align: center;
	color: #999;
}
body.index .footer li:first-child {
	display: none;
}
body.index .footer li:nth-child(2) {
	margin: 0;
}

/**
 * icon
 */
[class*="icon"] {
	position: relative;
	display: inline-block;
	vertical-align: top;
	background: url(/images/sprite@2x.png) no-repeat top left;
	background-size: 60px 48px;
	overflow: hidden;
	margin: 0;
}
.icon-fitin-mark {
	top: 0;
	width: 60px;
	height: 27px;
	background-position: 0 0;
	margin: 0;
}
.icon-fb {
	top: 0;
	width: 21px;
	height: 21px;
	background-position: 0 -27px;
	margin: 0 5px 0 0;
}
.icon-tw {
	top: 0;
	width: 21px;
	height: 21px;
	background-position: -21px -27px;
	margin: 0 5px 0 0;
}
.breadcrumb {
	font-size: 18px;
	text-align: center;
	margin: 0 0 30px;
}
.breadcrumb a {
	color: #b7b090;
}

.explain {
	margin: 30px 0px;
}

dt span.explain {
	margin: 0px 0px 0px 10px;
}

.link-unregister {
	margin: 40px -30px 20px -30px;
	width: auto;
	border-style: solid;
	border-width: 1px 0px;
	border-color: #999;
	padding: 24px 0px;
}

.link-unregister .link-block {
	text-align: center;
}
.link-unregister .link-block a{
	font-weight: bold;
}

.unregister-message {
	text-align: center;
	padding: 10px 0px;
}

.seeyouagain {
	text-align: center;
	padding: 10px 0px;
}

@media screen and (min-width: 481px) and (max-width:640px) {
	body {
		font-size: 24px;
	}
	.container {
		width: 480px;
	}
	.header h1 a {
		width: 120px;
		padding: 70px 0 0 0;
	}
	.header h2 img {
		width: 120px;
	}
	.footer {
		font-size: 22px;
	}
	.footer li:first-child {
		display: block;
		margin: 0 0 30px;
	}
	.about dt {
		font-size: 28px;
	}
	.about dd {
		font-size: 20px;
	}
	.about dd li {
		width: 230px;
	}
	.form label {
		font-size: 22px;
	}
	.page-header h2 {
		font-size: 32px;
	}
	.page-header p {
		font-size: 20px;
		line-height: 28px;
	}
	.actions li {
		width: 225px;
	}
	.apps .action {
		width: 280px;
	}
	.apps .text {
		width: 280px;
	}
	.btn {
		font-size: 24px;
	}
	[class*="icon"] {
		background-size: 80px 64px;
	}
	.icon-fitin-mark {
		width: 80px;
		height: 36px;
	}
	.icon-fb {
		width: 28px;
		height: 28px;
		background-position: 0 -36px;
	}
	.icon-tw {
		width: 28px;
		height: 28px;
		background-position: -28px -36px;
	}
}
