body {
	background: url(/image/jp/register/tiny_grid.png);
	padding-top: 0;
	padding-bottom: 40px;
}
.container-narrow {
	margin: 0 auto;
	max-width: 700px;
}
header {
	padding: 20px 0;
	background: url(/image/jp/register/bg_head.png) repeat-x #FFF;
	margin-bottom: 30px;
	border-bottom: 1px solid #ddd;
}
img {
	max-width: 100%;
	height: auto;
	width: auto\9; /* ie8 */
}
.box {
	position: relative;
	padding: 10px;
	background-color: #fff;
	border: 1px solid #ddd;
	-webkit-border-radius: 4px;
	-moz-border-radius: 4px;
	border-radius: 4px;
	margin-bottom: 30px;
}
h1 {
	position: relative;
	color: #fff;
	text-shadow: -1px -1px #0084ce;
	background: #64bbe8;
	font-size: 20px;
	line-height: 1;
	margin: 0 -20px 20px -20px;
	padding: 10px 5px 10px 20px;
	box-shadow: 0 1px 3px #777;
}
h1:after, h1:before {
	content: "";
	position: absolute;
	top: 100%;
	height: 0;
	width: 0;
	border: 5px solid transparent;
	border-top: 5px solid #0084ce;
}
h1:after {
	left: 0;
	border-right: 5px solid #0084ce;
}
h1:before {
	right: 0;
	border-left: 5px solid #0084ce;
}
h2 {
	display: inline-block;
	font-size: 16px;
	position: relative;
	color: #fff;
	text-shadow: -1px -1px #0168a1;
	background: #0084ce;
	line-height: 30px;
	margin: 0 -20px 10px -20px;
	padding: 0 10px 0 20px!important;
	box-shadow: 0 1px 3px #777;
}
h2:after {
	content: "";
	position: absolute;
	top: 100%;
	height: 0;
	width: 0;
	border: 5px solid transparent;
	border-top: 5px solid #0168a1;
}
h2:after {
	left: 0;
	border-right: 5px solid #0168a1;
}
.control-label {
	position: relative;
	color: #fff;
	text-shadow: -1px -1px #0084ce;
	background: #64bbe8;
	line-height: 30px;
	margin: 0 -20px 10px -20px;
	padding: 0 5px 0 20px!important;
	box-shadow: 0 1px 3px #777;
}
.control-label:after {
	content: "";
	position: absolute;
	top: 100%;
	height: 0;
	width: 0;
	border: 5px solid transparent;
	border-top: 5px solid #0084ce;
}
.control-label:after {
	left: 0;
	border-right: 5px solid #0084ce;
}
.text-block {
	line-height: 30px;
	vertical-align: middle;
}
table {
	word-break:break-all;
	word-wrap:break-word;
}
.pmark{
	height:50px;
}

.fb-login-wrap {
	margin-bottom:20px;
	overflow: hidden;
}

.fb-login-btn {
	background-color: #4267b2;
	border-radius: 4px;
	border:none;
	color: #fff;
	height: 40px;
	width: 266px;
	font-size: 16px;
	cursor: pointer;
}

.fb-login-btn .fb-login-icn {
	display: inline-block;
	width:24px;
	float:left;
	padding:8px 4px 0 8px;
	margin: 0;
}

.fb-login-btn .fb-login-icn svg.fb-icon_s{
	vertical-align: bottom;
	height: 24px;
	width: 24px;
}

.fb-login-btn .fb-login-msg {
	display: inline-block;
	height: 40px;
	line-height: 40px;
	padding: 0 24px 0 12px;
	margin: 0;
	font-family: Helvetica, Arial, "hiragino kaku gothic pro",meiryo,"ms pgothic",sans-serif;
}

.snsiconShareBlock {
	text-align: center;
	padding: 2.0rem;
	border: 5px solid #21ABE7;
	border-radius: 8px;
	max-width: 720px;
	background-color: #fff;
}

.snsShareText {
	margin-bottom: 1.5rem;
}

.snsShareHeading {
	font-size: 1.5rem;
	font-weight: bold;
}

.snsShareMessage {
	font-size: 1.2rem;
	margin-top: 0.5rem;
	line-height: 1.6;
}

.snsShareIcons {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 1rem;
}

.snsShareIcons a {
	display: inline-block;
}

.snsShareIcons a img {
	width: 48px;
	height: 48px;
	object-fit: contain;
	transition: transform 0.2s;
}
.snsShareIcons a:hover img {
	transform: scale(1.1);
}
@media screen and (min-width: 767px) {
	.snsiconShareBlock {
		margin: 1rem 2rem !important;
	}
}

@media screen and (max-width: 767px) {
header {
	margin-left: -20px;
	margin-right: -20px;
	padding-left: 20px;
}
img {
	max-width: 50%;
	height: auto;
}
table {
	table-layout:fixed;
}

	.snsShareIcons {
		gap: 0.8rem !important;
	}
	.snsShareIcons a img {
		width: 40px;
		height: 40px;
		max-width: 80%;
	}
	.snsiconShareBlock {
		padding: 1.2rem 0rem;
	}
	.snsShareHeading {
		font-size: 0.9rem;
	}
	.snsShareMessage {
		font-size: 0.8rem;
	}

}
