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

html {
	font-family: "メイリオ", "Meiryo", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "ＭＳ Ｐゴシック", sans-serif;
	font-size: 62.5%;
	height:100%;
}
body {
	width: 100%;
	height:100%;
	color: #21282A;
	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{
    display: block;
	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:#ffffff;
	background:#ff7b7b;
	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;
}
.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;
}

@keyframes spin {
    0%          { transform:rotate(0deg); }
    50%         { transform:rotate(180deg); }
    100%        { transform:rotate(360deg); }
}

@-webkit-keyframes spin {
    0%          { -webkit-transform:rotate(0deg); }
    50%         { -webkit-transform:rotate(180deg); }
    100%        { -webkit-transform:rotate(360deg); }
}

@-moz-keyframes spin {
    0%          { -moz-transform:rotate(0deg); }    
    50%         { -moz-transform:rotate(180deg); }
    100%        { -moz-transform:rotate(360deg); }
}

.loader_wrap{
	position: relative;
}
.loader_overlay{
	position: absolute;
	top: 0;
	bottom: 0;
	right: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: 50;
	display: flex;
	align-items: center;
	justify-content: center;
}
.loader_overlay.bg_white{
    background: rgba(255,255,255,0.7);
}

/* 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: #da4f54;
	font-size:1.2rem;
	border-radius:5px;
	margin-bottom:1rem;
	padding:1rem;
	position: relative;
}

/* validation success */
div.success {
    font-size: 1.2rem;
    border-radius: 5px;
    margin-bottom: 1rem;
    padding: 1rem;
    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.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;
}

/* 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 .close{
	font-size:4rem;
	text-align: right;
	margin-bottom: 1rem;
	line-height: 1;
}

.btn_burger {
	width: 60%;
	height: 60%;
	display: inline-block;
}

/* header */
.header{
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height:4.6rem;
    background: #fff;
    border-bottom: solid 2px #D5DADB;
    position: sticky;
    top: 0;
    z-index: 11;
    box-sizing: border-box;
}
.header .prev{
    font-size: 3.2rem;
    width:4.6rem;
    height:4.6rem;
    display: flex;
    align-items: center;
    justify-content: center;
    position: absolute;
    left: 0;
}
.header .prev a{
    display: block;
}
.header .page_ttl{
	font-size: 16px;
	font-weight: bold;
	text-align: center;
	padding: 0 4.6rem;
	overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.header .page_title{
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    font-size: 16px;
	font-weight: bold;
    text-align: center;
    padding: 0.4rem 4.6rem 0;
    min-width: 0;
}
.header .page_title span{
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}


/* ダイアログ */
.dialog{
    display: flex;
    align-items: center;
    justify-content: center;
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    padding: 1.6rem;
    background: rgba(0,0,0,0.2);
    z-index: 50;
}
.dialog .content{
    background: #fff;
    border-radius: 0.8rem;
    overflow: hidden;
}
.dialog .content .message{
    font-size: 1.4rem;
    padding: 1.6rem 2.4rem;
    text-align: center;
}
.dialog .content .message .ttl{
    font-size: 1.6rem;
    font-weight: bold;
    margin-bottom: 1rem;
}
.dialog .content .message p{
	margin-bottom: 1em;
}
.dialog .content .action{
    display: flex;
    align-items: center;
    justify-content: center;
    border-top: solid 1px #ccc;
}
.dialog .content .action .button{
    color: #00A0C8;
    background: #fff;
    font-size: 1.4rem;
    font-weight: bold;
    width: 100%;
    height: 3em;
    line-height: 3em;
    padding: 0;
    border: none;
    outline: none;
}

.dialog .content .action .button:disabled{
	color: rgb(0, 160, 200, 0.3);
	cursor: default;
}

.dialog .content .action .button + .button {
    border-left: solid 1px #ccc;
}

/* doDialog */
.doDialog {
    width: 24rem;
    font-size: 1.4rem;
    text-align: center;
    color: #fff;
    margin: 0 auto;
    padding: 2rem;
    background: rgba(0, 0, 0, 0.85);
    border-radius: 8px;
    display: block;
    transform: translate(-50%);
    box-sizing: border-box;
    position: fixed;
    top: 50%;
    left: 50%;
    z-index: 500;
}

/* 部門名  */
.page_detail .term_block .content_box .box_body .ranking_list .label {
  display: flex;
  align-items: center;
  justify-content: center;
  color: #55c5b9;
  min-width: 20rem;
  height: 3rem;
  margin-bottom: 2rem;
  padding: 0 2rem;
  border: solid 2px #55c5b9;
  border-radius: 3rem;
  font-size: 1.1rem;
  font-weight: bold;
  text-align: center;
  width: 80%;
  margin-left: auto;
  margin-right: auto;
  margin-top: 1rem;
}

/* VD-3907 */
@media screen and (max-width: 480px) {
	.mobile_block{
		display: block;
	}
}
/* VD-3907 end */