@charset "utf-8";
/* CSS Document */

/* Reset Style */
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 {
	margin: 0;
	padding: 0;
	border: 0;
	outline: 0;
	font: inherit;
	font-size: 100%;
	vertical-align: baseline;
	background: transparent;
}
body {
	line-height: 1;
}
article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section {
	display: block;
}
ol, ul {
	list-style: none
}
blockquote, q {
	quotes: none;
}
blockquote:before, blockquote:after, q:before, q:after {
	content: '';
	content: none;
}
a {
	margin: 0;
	padding: 0;
	font-size: 100%;
	vertical-align: baseline;
	background: transparent;
}
ins {
	background-color: #ff9;
	color: #000;
	text-decoration: none;
}
mark {
	background-color: #ff9;
	color: #000;
	font-style: italic;
	font-weight: bold;
}
del {
	text-decoration: line-through;
}
abbr[title], dfn[title] {
	border-bottom: 1px dotted;
	cursor: help;
}
table {
	border-collapse: collapse;
	border-spacing: 0;
}
hr {
	display: block;
	height: 1px;
	border: 0;
	border-top: 1px solid #cccccc;
	margin: 1em 0;
	padding: 0;
}
input, select {
	vertical-align: middle;
}
input[type="button"],
input[type="submit"],
input[type="reset"],
button{
	-webkit-appearance: none;
}

/* Template Style */
html {
	font-family: "メイリオ", "Meiryo", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "ＭＳ Ｐゴシック", sans-serif;
	font-size: 62.5%;
	height:100%;
}
body {
	width: 100%;
	height:100%;
	color: #333333;
	font-size: 16px;
	font-size: 1.6rem;
	line-height: 1.5;
}
a {
	color: inherit;
	text-decoration: none;
}
input, select, textarea {
	font-size: inherit;
	font-family: inherit;
	box-shadow: none;
	-webkit-appearance: none;
	border-radius: 0;
}
select, textarea {
	font-size: inherit;
	font-family: inherit;
	-webkit-appearance: none;
	background: inherit;
}
img{
	max-width: 100%;
}
strong{
	font-weight:bold;
}
button{
	border: none;
}

input[type=range]::-webkit-slider-runnable-track {
	width: 100%;
	height: 5px;
	cursor: pointer;
	box-shadow: inset 0px 1px 0px #d1d6df;
	background: #dde1e7;
	border-radius: 0px;
	border: none;
}
input[type=range]::-webkit-slider-thumb {
	position: relative;
	z-index: 2;
	box-shadow: 0px 1px 0px #d1d6df;
	border: none;
	height: 12px;
	width: 5px;
	border-radius: 0px;
	background: #dde1e7;
	cursor: pointer;
	-webkit-appearance: none;
	margin-top: -4px;
}
input[type=range]::-webkit-slider-thumb:after {
	position: absolute;
	z-index: 1;
	top: 4px;
	bottom: 0;
	right: 5px;
	display: inline-block;
	content: "";
	width: 2000px;
	height: 5px;
	background-color: #55c5b9;
	-ms-pointer-events: none;
	pointer-events: none;
}
input[type=range]::-moz-range-track {
	width: 100%;
	height: 5px;
	cursor: pointer;
	box-shadow: inset 0px 1px 0px #d1d6df;
	background: #dde1e7;
	border-radius: 0px;
	border: none;
	outline: none;
}
input[type=range]::-moz-range-thumb {
	-moz-appearance: none;
	-webkit-appearance: none;
	position: relative;
	z-index: 2;
	box-shadow: 0px 1px 0px #d1d6df;
	border: none;
	height: 5px;
	width: 5px;
	border-radius: 0px;
	background: #dde1e7;
	cursor: pointer;
	outline: none;
	box-shadow: 0 -5px 0 0 #dde1e7, 0 -3px 0 0 #dde1e7, 0 5px 0 0 #dde1e7, -5px 0 0 0 #55c5b9, -9px 0 0 0 #55c5b9, -13px 0 0 0 #55c5b9, -17px 0 0 0 #55c5b9, -21px 0 0 0 #55c5b9, -25px 0 0 0 #55c5b9, -29px 0 0 0 #55c5b9, -33px 0 0 0 #55c5b9, -37px 0 0 0 #55c5b9, -41px 0 0 0 #55c5b9, -45px 0 0 0 #55c5b9, -49px 0 0 0 #55c5b9, -53px 0 0 0 #55c5b9, -57px 0 0 0 #55c5b9, -61px 0 0 0 #55c5b9, -65px 0 0 0 #55c5b9, -69px 0 0 0 #55c5b9, -73px 0 0 0 #55c5b9, -77px 0 0 0 #55c5b9, -81px 0 0 0 #55c5b9, -85px 0 0 0 #55c5b9, -89px 0 0 0 #55c5b9, -93px 0 0 0 #55c5b9, -97px 0 0 0 #55c5b9, -101px 0 0 0 #55c5b9, -105px 0 0 0 #55c5b9, -109px 0 0 0 #55c5b9, -111px 0 0 0 #55c5b9, -115px 0 0 0 #55c5b9, -119px 0 0 0 #55c5b9, -123px 0 0 0 #55c5b9, -127px 0 0 0 #55c5b9, -131px 0 0 0 #55c5b9, -135px 0 0 0 #55c5b9, -139px 0 0 0 #55c5b9, -143px 0 0 0 #55c5b9, -147px 0 0 0 #55c5b9, -151px 0 0 0 #55c5b9, -155px 0 0 0 #55c5b9, -159px 0 0 0 #55c5b9, -163px 0 0 0 #55c5b9, -167px 0 0 0 #55c5b9, -171px 0 0 0 #55c5b9, -175px 0 0 0 #55c5b9, -179px 0 0 0 #55c5b9, -183px 0 0 0 #55c5b9, -187px 0 0 0 #55c5b9;
}
input[type=range]::-ms-track {
	width: 100%;
	height: 5px;
	cursor: pointer;
	background: transparent;
	border-color: transparent;
	color: transparent;
}
input[type=range]::-ms-fill-lower {
	background: #55c5b9;
	border: none;
	border-radius: 0px;
}
input[type=range]::-ms-fill-upper {
	background: #dde1e7;
	border: none;
	border-radius: 0px;
}
input[type=range]::-ms-thumb {
	border: none;
	height: 12px;
	width: 5px;
	border-radius: 0px;
	background: #dde1e7;
	box-shadow: 0px 1px 0px #d1d6df;
	cursor: pointer;
}
.secret.on{
	background-image: url(/viewer/img/login/eye_open.png);
}
.secret {
	display: inline-block;
	background-image: url(/viewer/img/login/eye_closed.png);
	background-position: center center;
	background-repeat: no-repeat;
	background-size: contain;
	width: 2.7rem;
	height: 1.5rem;
	cursor: pointer;
}
.page_wrap {
	width:100%;
	min-height:100%;
	position: relative;
}

/* color */
.c_red{
	color:#ff5555;
}
.c_pink{
	color:#ff7b7b;
}
.c_green{
	color: #2ebfbc;
}
.c_blue{
	color:#2596f6;
}

/* bg color */
.bg_white{
	background:#fff;
}
.bg_gray{
	background:#f2f4f5;
}

/* font size */
.t_small{
	font-size:0.8em;
}

/* text align */
.t_center {
	text-align: center !important;
}
.t_left {
	text-align: left !important;
}
.t_right {
	text-align: right !important;
}

/* text link */
.t_link {
	color: #0ca5e5;
	text-decoration: underline;
	-webkit-transition: all 0.2s linear;
	transition: all 0.2s linear;
}
.t_link:hover {
	color: #3dc8ff !important;
}

/* list style */
.indent_list{
	padding-left: 1em;
}
.indent_list .list-item + .list-item{
	margin-top: 1rem;
}

.utility_list {
	padding-left: 1em;
	text-indent: -1em;
}
/* display none */
.hide {
	display: none !important;
}

/* width */
.max_width{
	width:100%;
}
.req{
	color:#ff7b7b;
	font-weight:bold;
	margin-right:0.6rem;
	display: inline-block;
}
.any{
	color:#ffffff;
	background:#b5b4b4;
	font-size:1.4rem;
	height:3.2rem;
	line-height:3.2rem;
	border-radius:3.2rem;
	margin-right:0.6rem;
	display: inline-block;
	vertical-align: text-bottom;
	width: 48px;
	text-align: center;
}


/* box-shadow */
.box_shadow{
	box-shadow: 0 0 2px 2px rgba(0,0,0,0.2);
}

/* loader */
.loader{
	display: block;
	-webkit-animation: spin 1.5s linear infinite;
	-moz-animation: spin 1.5s linear infinite;
	-ms-animation: spin 1.5s linear infinite;
	-o-animation: spin 1.5s linear infinite;
	animation: spin 1.5s linear infinite;
}
.loader_wrap{
	position: relative;
}
.loader_overlay{
/*
	position: absolute;
	top: 0;
	bottom: 0;
	right: 0;
	left: 0;
	background: rgba(0,0,0,0.7);
*/
	width: 100%;
	height: 100%;
	z-index: 50;
	display: flex;
	align-items: center;
	justify-content: center;
}

/* clear fix */
.cf:after {
	content: ".";
	display: block;
	clear: both;
	height: 0;
	visibility: hidden;
}
.cf {
	min-height: 1px;
}
* html .cf {
	height: 1px;/*¥*//*/
	height: auto;
	overflow: hidden;
	/**/
}

/* validation error */
div.error{
	color: #fff;
	background:url("/sp/images/error.png") no-repeat left 1.0rem top 1.0rem #da4f54;
	background-size: 1.4em;
	font-size:14px;
	font-size:1.4rem;
	border-radius:5px;
	margin-bottom:1rem;
	padding:1rem 1em 1rem 2.6em;
	position: relative;
}
div.error:before{
    content: '';
    position: absolute;
    display: block;
    width: 0;
    height: 0;
    bottom: -10px;
    left: 15px;
    border-right: 20px solid transparent;
    border-top: 10px solid #da4f54;
    border-left: 20px solid transparent;
}
div.error:after{
    content: '';
    position: absolute;
    display: block;
    width: 0;
    height: 0;
    bottom: -10px;
    left: 30px;
    border-right: 25px solid transparent;
    border-top: 10px solid #ffffff;
    border-left: 5px solid transparent;
}

/* validation success */
div.success {
    font-size: 14px;
    font-size: 1.4rem;
    border-radius: 5px;
    margin-bottom: 1rem;
    padding: 1.2rem 1.2rem 1.2rem 2.4rem;
    text-indent: -1em;
    background-color: #dff0d8;
    border-color: #d6e9c6;
    color: #3c763d;
}

/* color style */
.c_gray{
	color:#a2aab1;
}
.c_purple{
	color: #ff0087 !important;
}

/* btn style */
.btn_style{
	cursor: pointer;
	-webkit-transition: all 0.2s linear;
	transition: all 0.2s linear;
	box-sizing: border-box;
}
.btn_style_not_hover{
	pointer-events: none;
	-webkit-transition: all 0.2s linear;
	transition: all 0.2s linear;
	box-sizing: border-box;
}
.btn_style_not_hover.btn_gray{
	color:#fff;
	background: #9b9b9b;
	border: 2px solid #9b9b9b;
}


.btn_style.btn_pink{
	color:#fff;
	background:#ff0087;
	border: 2px solid #ff0087;
}
.btn_style.btn_pink-o{
	color:#ff0087;
	background:inherit;
	border:solid 2px #ff0087;
}
.btn_style.btn_pink-o:hover{
	color:#fff;
	background:#ff0087;
}
.btn_style.btn_green{
	color:#fff;
	background:#42bfc0;
	border: 2px solid #42bfc0;
}
.btn_style.btn_green:hover{
	color:#42bfc0;
	background:#fff;
}
.btn_style.btn_green.inset_shadow{
	box-shadow: 0px -2px 0px 0px #37a6a7 inset;
}
.btn_style.btn_green-o{
	color:#42bfc0;
	background:#fff;
	border:solid 2px #42bfc0;
}
.btn_style.btn_green-o:hover{
	background:#42bfc0;
	color:#fff;
}
.btn_style.btn_blue{
	color:#fff;
	background:#0ca5e5;
	border: 2px solid #0ca5e5;
}
.btn_style.btn_blue:hover{
	color:#0ca5e5;
	background:#fff;
}
.btn_style.btn_blue-o{
	color:#0ca5e5;
	background:#fff;
	border: solid 2px #0ca5e5;
}
.btn_style.btn_blue-o:hover{
	color:#fff;
	background:#0ca5e5;
}
.btn_style.btn_purple{
	color: #fff;
	background: #d39ef1;
	border: 2px solid #d39ef1;
}
.btn_style.btn_purple:hover{
	color:#d39ef1;
	background:#fff;
}
.btn_style.btn_gray{
	color:#fff;
	background: #9b9b9b;
	border: 2px solid #9b9b9b;
}
.btn_style.btn_gray:hover{
	background: #fff;
	color:#9b9b9b;
}
.btn_style.btn_gray-o{
	color: #9b9b9b;
	background:#fff;
	border:solid 2px #9b9b9b;
}
.btn_style.btn_gray-o:hover{
	background:#9b9b9b;
	color:#fff;
}
.btn_style.btn_purple{
	color:#fff;
	background: #cb9eee;
	border: 2px solid #cb9eee;
}
.btn_style.btn_purple:hover{
	color: #cb9eee;
	background:#fff;
}
.btn_style.btn_purple-o{
	color: #cb9eee;
	background:#fff;
	border:solid 2px #cb9eee;
}
.btn_style.btn_purple-o:hover{
	color:#fff;
	background: #cb9eee;
}
.btn_style.btn_white-o{
	color:#fff;
	border:solid 2px #fff;
}
.btn_style.disable{
	color: #fff;
	background:#dddddd;
	pointer-events: none;
}
.btn_style.shadow{
	box-shadow: 0px 0px 8px 4px rgba(0,0,0,0.4);
}

/* form item */
.selectbox{
	position: relative;
}
.selectbox::before {
	content: '';
	position: absolute;
	top: 50%;
	right: 1em;
	width: 0;
	height: 0;
	margin-top:-3px;
	padding: 0;
	border-left: 6px solid transparent;
	border-right: 6px solid transparent;
	border-top: 6px solid #666666;
	pointer-events: none;
}


/* Base Style */
.l-block-header,
.l-block-footer{
	margin:0;
}
.l-block-main{
    min-width: auto;
    min-height: auto;
}

.p-header-siteLogo img{
    max-width:none;
}


/* modal style */
.modal .modal_bg{
	position: fixed;
	top: 0;
	right: 0;
	left: 0;
	bottom: 0;
	background:rgba(0,0,0,0.2);
}
.modal .modal_head .modal_close{
	font-size:4rem;
	text-align: right;
	margin-bottom: 1rem;
	line-height: 1;
}