/* for lyna */
@charset "UTF-8";

/* オリジナルのレイアウト
----------------------------------------*/
html {
	font-size: 1rem;
	font-size: 10px;
}

body {
	color: #333;
	font-family: 'Lato Number', 'PT Sans Alphabet', 'Noto Sans JP', 'Noto Sans CJK JP Subset', sans-serif;
	background: #fff;
	font-size: 1.4rem;
	line-height: 1.5;
	height: 100%;
	min-width: 1200px;
	-webkit-text-size-adjust: 100%;
}
.page_login .wrapper {
	background: url(/img/modules/login/bg.png) no-repeat left top / 100% 100%;
}
.wrapper {
	overflow: hidden;
	height: 100%;
	min-width: 1200px;
}
.page_login .wrapper {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	align-content: center;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
}
a {
	text-decoration: none;
	color: inherit;
}

/* font
----------------------------------------*/
/* only for zrn Brandon GrotesqueはGoogleFontsにはなく、商用の様子
.en {
	font-family: 'Brandon Grotesque Bold', sans-serif;
}
*/

/* header
----------------------------------------*/
.header {
	z-index: 1000;
	display: none;
}

/* login */
.page_login .header {
	width: 100%;
	text-align: center;
	margin-bottom: 30px;
}
.page_login .header h1 {
	font-size: 3rem;
	font-weight: bold;
	letter-spacing: .1em;
	opacity: 0;
	transition: opacity 2s;
}
.page_login .header.show h1 {
	opacity: 1;
}
.page_login .header h1 .en {
	font-size: 1.4rem;
	color: #666;
	display: block;
	margin: 10px 0 0;
	letter-spacing: .06em;
}
.page_login .header h1::after {
	content: '';
	display: block;
	height: 3px;
	width: 40px;
	background: #98CB98;
	margin: 19px auto 0;
}
.page_login.planner .header h1::after {
	background: #D99591;
}

/* menu */
.page_menu .header img {
	display: block;
}
.page_menu .header {
	height: 56px;
	position: absolute;
	top: 15px;
	left: 15px;
	right: 15px;
	padding-right: 8px;
	background: #3A4150;
	border-radius: 30px;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: start;
	-ms-flex-pack: start;
	justify-content: flex-start;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	color: #fff;
	box-shadow: 0 0 26px rgba(0, 0, 0, .16);
}
.page_menu .header h1 {
	font-size: 1.6rem;
	padding: 16px 40px;
	letter-spacing: .1em;
	margin-right: 8px;
}
.page_menu .header_nav > ul {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: start;
	-ms-flex-pack: start;
	justify-content: flex-start;
	-webkit-box-align: stretch;
	-ms-flex-align: stretch;
	align-items: stretch;
}
.page_menu .header_nav > ul > li + li::before {
	content: '';
	display: block;
	width: 2px;
	background: #4D5361;
	position: absolute;
	left: -1px;
	top: 8px;
	bottom: 8px;
}
.page_menu .header_nav > ul button {
	-webkit-appearance: none;
	appearance: none;
	color: #fff;
	font-family: inherit;
	border: 0;
	background: none;
	font-weight: 500;
	padding: 10px 48px 10px 77px;
	height: 56px;
	letter-spacing: .1em;
	cursor: pointer;
	transition: background .3s;
}
.page_menu .header_nav > ul li button.current {
	background: #4D5361;
}
.page_menu .header_nav > ul li button:hover {
	background: #767a85;
}
.page_menu .header_nav > ul button:focus {
	outline: none;
}
.page_menu .header_nav > ul button::after {
	content: '';
	display: block;
	width: 5px;
	height: 5px;
	border-radius: 2px;
	border-top: 3px solid #98CB98;
	border-right: 3px solid #98CB98;
	-webkit-transform: rotate(135deg);
	transform: rotate(135deg);
	position: absolute;
	right: 31px;
	top: 50%;
	margin-top: -5px;
}
.page_menu .header_nav > ul button.current::after {
	-webkit-transform: rotate(-45deg);
	transform: rotate(-45deg);
	margin-top: -2px;
}
.page_menu .header_nav_car > button::before {
	content: '';
	display: block;
	width: 38px;
	height: 24px;
	background: url(/img/modules/menu/icon_car.svg) no-repeat;
	position: absolute;
	left: 30px;
	top: 50%;
	margin-top: -13px;
}
.page_menu .header_nav > ul > .header_nav_report > button {
	padding-left: 69px;
	padding-right: 56px;
}
.page_menu .header_nav > ul > .header_nav_report > button::after {
	right: 41px;
}
.page_menu .header_nav_report > button::before {
	content: '';
	display: block;
	width: 20px;
	height: 26px;
	background: url(/img/modules/menu/icon_report.svg) no-repeat;
	position: absolute;
	left: 41px;
	top: 50%;
	margin-top: -13px;
}
.page_menu .header_nav > ul > .header_nav_safety > button {
	padding-left: 54px;
	padding-right: 56px;
}
.page_menu .header_nav > ul > .header_nav_safety > button::after {
	right: 39px;
}
.page_menu .header_nav_safety > button::before {
	content: '';
	display: block;
	width: 20px;
	height: 20px;
	background: url(/img/modules/menu/icon_safety.svg) no-repeat;
	position: absolute;
	left: 25px;
	top: 50%;
	margin-top: -10px;
}
.page_menu .header_nav_sub {
	position: absolute;
	display: none;
	width: 100%;
	background: #3A4150;
}
.page_menu .header_nav_sub li {
	border-top: 1px solid #3A4150;
	font-size: 1.3rem;
}
.page_menu .header_nav_sub li a {
	display: block;
	padding: 10px 15px;
	letter-spacing: .1em;
	transition: background .3s;
	background: #4D5361;
}
.page_menu .header_nav_sub li a:hover {
	background: #767a85;
}
.page_menu .header_date {
	margin: 0 20px 0 auto;
	font-size: 1.3rem;
}
.header_user a {
	display: block;
	transition: opacity .3s;
}
.header_user a:hover {
	opacity: .6;
}

@media only screen and (max-width: 768px) {
}

/* contents
----------------------------------------*/
.page_menu main,
.page_menu .contents {
	width: 100%;
	height: 100%;
}
.page_login .contents {
	display: flex;
	flex-flow: row wrap;
	justify-content: center;
	align-items: flex-start;
	align-content: flex-start;
	border-radius: 15px;
	box-shadow: 0 4px 20px rgba(231, 68, 122, .4);
	opacity: 0;
	transition: opacity 1.5s;
	transition-delay: .5s;
}
.page_login .contents.show {
	opacity: 1;
}

/* map_block
----------------------------------------*/
.page_menu .map_block {
	height: 100%;
	background: #ccc;
}

/* login
----------------------------------------*/
.login_block {
	background-color: #fff;
	border-radius: 15px;
	width: 650px;
	margin: 0 auto;
	padding: 36px 36px 37px;
	box-shadow: 0 4px 20px rgba(231, 68, 122, .4);
	color: #666;
}
/* only for zrn
.login_block.show {
	opacity: 1;
}
*/
.exist-news .login_block {
	border-radius: 15px 0 0 15px;
	border-radius: none;
	box-shadow: none;
	height: 600px;
	width: 450px;
	padding-top: 66px;
}
.manegement .login_block {
	background: -moz-linear-gradient(top, #bdd8bd 0%, #d9e6d9 100%);
	background: -webkit-linear-gradient(top, #bdd8bd 0%,#d9e6d9 100%);
	background: linear-gradient(to bottom, #bdd8bd 0%,#d9e6d9 100%);
}
/* only for zrn
.planner .login_block {
	background: -moz-linear-gradient(top, #E0BDBB 50%, #E9DFD9 100%);
	background: -webkit-linear-gradient(top, #E0BDBB 50%,#E9DFD9 100%);
	background: linear-gradient(to bottom, #E0BDBB 50%,#E9DFD9 100%);
}
*/
.login_block .logo {
	width: 100%;
	margin-bottom: 30px;
	text-align: center;
}
.login_block .logo img {
	width: 120px;
}
.login_block form {
	width: 325px;
	margin: 0 auto;
}
.login_block dt {
	font-size: 1.2rem;
	letter-spacing: .3px;
	margin-bottom: 5px;
	opacity: 0;
	transform: translateY(50px);
	transition: opacity .5s, transform .5s;
}
.login_block dd {
	margin-bottom: 25px;
	opacity: 0;
	transform: translateY(50px);
	transition: opacity .5s, transform .5s;
}
.show.contents .login_block dt:nth-of-type(1),
.show.contents .login_block dd:nth-of-type(1) {
	transition-delay: .8s;
}
.show.contents .login_block dt:nth-of-type(2),
.show.contents .login_block dd:nth-of-type(2) {
	transition-delay: 1.1s;
}
.login_block input[type="text"],
.login_block input[type="password"] {
	background: #dfecef;
	border: 0;
	font-size: 1.2rem;
	font-family: inherit;
	width: 100%;
	border-radius: 20px;
	padding: 11px 20px;
	letter-spacing: .09em;
}
.login_block input[type="text"]:focus,
.login_block input[type="password"]:focus {
	outline: none;
}
.login_block input[type="text"]::placeholder,
.login_block input[type="password"]::placeholder {
	color: #999;
	font-weight: bold;
}
.login_block input[type="text"]:-ms-input-placeholder,
.login_block input[type="password"]:-ms-input-placeholder {
	color: #999;
	font-weight: bold;
}
.login_block input[type="text"]::-ms-input-placeholder,
.login_block input[type="password"]::-ms-input-placeholder {
	color: #999;
	font-weight: bold;
}
.login_btn {
	margin-top: 40px;
	opacity: 0;
	transform: translateY(50px);
	transition: opacity .5s, transform .5s;
	transition-delay: 1.4s;
}
.login_btn button {
	-webkit-appearance: none;
	appearance: none;
	border: 0;
	width: 100%;
	padding: 10px 10px 10px 47px;
	background: #e7447a;
	font-weight: 500;
	font-family: inherit;
	text-align: center;
	color: #fff;
	border-radius: 25px;
	transition: opacity .3s;
	cursor: pointer;
}
.login_btn button:focus {
	outline: none;
}
.login_btn button::after {
	content: '';
	width: 14px;
	height: 14px;
	display: inline-block;
	margin-left: 18px;
	vertical-align: -1px;
	background: url(/img/modules/login/icon_btn_arrow.svg) no-repeat;
	transition: transform .3s;
}
.login_btn button:disabled {
	opacity: .3;
	cursor: default;
}
.login_btn button[type="submit"]:not(:disabled) {
	animation-fill-mode: forwards;
	animation-duration: 1000ms;
	animation-name: login_btn;
}
.login_btn button[type="submit"]:not(:disabled):hover::after {
	transform: translateX(10px);
}
.login_link {
	text-align: center;
	font-size: 1.2rem;
	margin-top: 30px;
	opacity: 0;
	transform: translateY(50px);
	transition: opacity .5s, transform .5s;
	transition-delay: 1.7s;
}
.login_link a {
	text-decoration: underline;
	transition: opacity .3s;
}
.login_link a:hover {
	opacity: .6;
}
.show.contents .login_block dt,
.show.contents .login_block dd,
.show.contents .login_block .login_btn,
.show.contents .login_block .login_link {
	opacity: 1;
	transform: translateY(0);
}

@keyframes login_btn {
	0% {
		transform: scale(1);
	}
	50% {
		transform: scale(1.2);
	}
	100% {
		transform: scale(1);
	}
}

.login_block .message {
	color: red;
	height: 60px;
	padding-bottom: 40px;
	text-align: center;
}
.login_block .message.empty {
	display: block;
}

/*news
----------------------------------------*/
.news_block {
	background-color: #eeece7;
	border-radius: 0 15px 15px 0;
	width: 450px;
	height: 600px;
	padding: 30px 25px;
}
.news_block h2 {
	display: block;
	width: 4em;
	margin: 0 auto;
}
.news_block h2::after {
	content: '';
	border-bottom: 3px solid #555;
	display: block;
	width: 40px;
	margin: 5px auto 0;
}
.news_block .news_body {
	height: 500px;
	margin-top: 20px;
	overflow-x: hidden;
	overflow-y: auto;
	word-wrap: break-word;
	overflow-wrap: break-word;
}
.news_block .news_body .news {
	font-size: 14px;
	text-align: left;
	margin-right: 5px;
}
.news_block .news_body .news:nth-child(n+2) {
	border-top: 1px solid #555;
	margin-top: 15px;
	padding-top: 15px;
}
.news_block .news_body .news > * {
	padding-left: 5px;
}
.news_block .news_body .news .news-title {
	font-weight: 700;
	padding: 8px 0 5px 5px;
}
.news_block .news_body .news .news-content {
	padding: 5px 5px 0 10px;
}

/*footer
----------------------------------------*/
