/*
	H2 Energy Management System - The Hydrogen based renewable energy management system monitor
	スタイルシート
*/

/*
	各タグの基底設定（背景、フォントなど）
*/

body {
	font-family: 'M PLUS Rounded 1c', sans-serif;
	overflow:scroll;
	background-color:#eeeeee;
	margin:0;
	padding:0;
	opacity:1.0;
}

input[type="button" i] {
	appearance: none;
	-webkit-appearance: none;
	font-family: 'M PLUS Rounded 1c', sans-serif;
}

/*
	画面サイズ固定
	ホルダー(holder)は画面中央に配置されます
*/

.fix {
	overflow:hidden;
	width:100%;
	height:100%;
}

.fix .container {
	position: absolute;
	left:50%;
	top:50%;
	margin: auto;
}

/* --------------------------------------------------------------------------------------------------------------------------------- */

/*
	FullHDサイズホルダー
	サイズ: [1900px, 1060px]
*/

.fix .container .holder-fullhd {
	position: absolute;
	overflow:hidden;
	left: 10px;
	top: 0px;
	width:1900px;
	height:1010px;
	visibility: visible;
	background-color:#ffffff;
	font-size: 45px;
	color: #000000;
}

.holder-fullhd .header {
	position: absolute;
	overflow:hidden;
	width:1900px;
	height:50px;
}

.holder-fullhd .footer {
	position: absolute;
	overflow:hidden;
	width:1900px;
	height:50px;
}

.holder-fullhd .fulll {
	position: absolute;
	overflow:hidden;
	width:1900px;
	height:900px;
}

.holder-fullhd .halfarea-vertical {
	position: absolute;
	overflow:hidden;
	width:945px;
	height:900px;
}

.holder-fullhd .halfarea-horizontal {
	position: absolute;
	overflow:hidden;
	width: 1900px;
	height: 450px;
}

.holder-fullhd .quaterarea {
	position: absolute;
	overflow:hidden;
	width: 945px;
	height: 450px;
}

.holder-fullhd .imageicon-square {
	position: absolute;
	overflow:hidden;
	width: 72px;
	height: 72px;
	background-color: transparent;
}

.holder-fullhd .imageicon-vertical {
	position: absolute;
	overflow:hidden;
	width: 64px;
	height: 128px;
	background-color: transparent;
}

.holder-fullhd .imageicon-horizontal {
	position: absolute;
	overflow:hidden;
	width: 128px;
	height: 64px;
	background-color: transparent;
}

.holder-fullhd .separator-vertical {
	position: absolute;
	overflow:hidden;
	width:2px;
	height:900px;
	background-color: #000000;
}

.holder-fullhd .separator-horizontal {
	position: absolute;
	overflow:hidden;
	width: 1900px;
	height: 2px;
	background-color: #000000;
}

/* --------------------------------------------------------------------------------------------------------------------------------- */

/*
	Raspberry PI 公式タッチパネル用サイズホルダー
	サイズ: [800px, 480px]
*/

.fix .container .holder-rpi {
	position: absolute;
	overflow:hidden;
	left: -400px;
	top: -240px;
	width:800px;
	height:480px;
	visibility: visible;
	background-color:#ffffff;
	font-size: 24px;
	color: #000000;
}

.holder-rpi .header {
	position: absolute;
	overflow:hidden;
	width:800px;
	height:40px;
	margin: 0px;
	padding: 2px 2px 2px 2px;
	font-size: 24px;
	display: flex;
	align-items: center;
	justify-content: left;
}

.holder-rpi .footer {
	position: absolute;
	overflow:hidden;
	width:800px;
	height:40px;
	margin: 0px;
	padding: 2px 2px 2px 2px;
	font-size: 24px;
	display: flex;
	align-items: center;
	justify-content: left;
}

.holder-rpi .full {
	position: absolute;
	overflow:hidden;
	background-color: #eeeeff;
	width:800px;
	height:396px;
	margin: 0px;
	padding: 0px;
}

.holder-rpi .halfarea-vertical {
	position: absolute;
	overflow:hidden;
	width:398px;
	height:396px;
	margin: 0px;
	padding: 4px 4px 4px 4px;
}

.holder-rpi .halfarea-horizontal {
	position: absolute;
	overflow:hidden;
	width: 800px;
	height: 196px;
	margin: 0px;
	padding: 4px 4px 4px 4px;
}

.holder-rpi .quaterarea {
	position: absolute;
	overflow:hidden;
	width: 398px;
	height: 196px;
	margin: 0px;
	padding: 4px 4px 4px 4px;
}

.holder-rpi .imageicon-square {
	position: absolute;
	overflow:hidden;
	width: 80px;
	height: 80px;
	background-color: transparent;
	background-size: contain;
	background-repeat: no-repeat;
	background-position: center;
}

.holder-rpi .imageicon-vertical {
	position: absolute;
	overflow:hidden;
	width: 64px;
	height: 128px;
	background-color: transparent;
	background-size: contain;
	background-repeat: no-repeat;
	background-position: center;
}

.holder-rpi .imageicon-horizontal {
	position: absolute;
	overflow:hidden;
	width: 128px;
	height: 64px;
	background-color: transparent;
	background-size: contain;
	background-repeat: no-repeat;
	background-position: center;
}

.holder-rpi .arrow-horizontal {
	position: absolute;
	overflow:hidden;
	width: 70px;
	height: 20px;
	background-color: transparent;
	background-size: 100% 100%;
	background-repeat: no-repeat;
	background-position: center;
}

.holder-rpi .arrow-horizontal-middle {
	position: absolute;
	overflow:hidden;
	width: 80px;
	height: 20px;
	background-color: transparent;
	background-size: 100% 100%;
	background-repeat: no-repeat;
	background-position: center;
}

.holder-rpi .arrow-horizontal-middlelong {
	position: absolute;
	overflow:hidden;
	width: 90px;
	height: 20px;
	background-color: transparent;
	background-size: 100% 100%;
	background-repeat: no-repeat;
	background-position: center;
}

.holder-rpi .arrow-horizontal-long {
	position: absolute;
	overflow:hidden;
	width: 160px;
	height: 20px;
	background-color: transparent;
	background-size: 100% 100%;
	background-repeat: no-repeat;
	background-position: center;
}

.holder-rpi .arrow-vertical {
	position: absolute;
	overflow:hidden;
	width: 20px;
	height: 70px;
	background-color: transparent;
	background-size: 100% 100%;
	background-repeat: no-repeat;
	background-position: center;
}

.holder-rpi .arrow-vertical-middle {
	position: absolute;
	overflow:hidden;
	width: 20px;
	height: 80px;
	background-color: transparent;
	background-size: 100% 100%;
	background-repeat: no-repeat;
	background-position: center;
}

.holder-rpi .arrow-vertical-middlelong {
	position: absolute;
	overflow:hidden;
	width: 20px;
	height: 90px;
	background-color: transparent;
	background-size: 100% 100%;
	background-repeat: no-repeat;
	background-position: center;
}

.holder-rpi .arrow-vertical-long {
	position: absolute;
	overflow:hidden;
	width: 20px;
	height: 1600px;
	background-color: transparent;
	background-size: 100% 100%;
	background-repeat: no-repeat;
	background-position: center;
}

.holder-rpi .separator-vertical {
	position: absolute;
	overflow:hidden;
	width:2px;
	height:396px;
	background-color: #000000;
}

.holder-rpi .separator-horizontal {
	position: absolute;
	overflow:hidden;
	width: 800px;
	height: 2px;
	background-color: #000000;
}

.holder-rpi .values {
	position: absolute;
	overflow: hidden;
	width: 64px;
	height: 68px;
	font-size: 12px;
	background-color: transparent;
	margin: 0px;
	padding: 4px 4px 4px 4px;
}

.holder-rpi .list-table {
	position: absolute;
	overflow:hidden;
	width:760px;
	height:340px;
	margin: 0px;
	padding: 0px;
}

/*
	背景色
*/
.holder-rpi .back-normal {
	background-color: #ffffff;
}

.holder-rpi .back-alert {
	background-color: #ffdddd;
}

.holder-rpi .back-activating {
	background-color: #ff9f3f;
}

/*
	テキスト表示属性
*/
.holder-rpi .text-header {
	font-size: 18px;
}

.holder-rpi .text-footer {
	font-size: 18px;
}

.holder-rpi .text-title {
	font-size: 24px;
}

.holder-rpi .text-label {
	font-size: 18px;
}

.holder-rpi .text-value-sys {
	font-size: 12px;
}

.holder-rpi .text-unit-sys {
	font-size: 10px;
}

.holder-rpi .text-caption-list {
	font-size: 10px;
}

.holder-rpi .text-value-list {
	font-size: 10px;
}

.holder-rpi .text-alert {
	color: #ff0000;
}

/*
	テーブル
*/
.holder-rpi .table-list {
	border-collapse: collapse;
	background-color: #eeeeee;
	border: 0px;
	margin: 0px;
	padding: 0px;
	width: 100%;
}

.holder-rpi .tr-list {
	border: 0px;
	margin: 0px;
	padding: 0px
}

.holder-rpi .td-list-caption {
	border: 1px #000000 solid;
	background-color: #cccccc;
	border-right-style: dashed;
	font-size: 10px;
	margin: 0px;
	padding: 4px;
	width: 96px;
}

.holder-rpi .td-list-value {
	border: 1px #000000 solid;
	background-color: #cccccc;
	border-left-style: dashed;
	font-size: 10px;
	margin: 0px;
	padding: 4px;
	width: 96px;
}

/*
	ボタン表示属性
*/
.holder-rpi .button-status {
	font-size: 12px;
	margin: 0px;
	padding: 4px 4px 4px 4px;
}

/* --------------------------------------------------------------------------------------------------------------------------------- */

/*
	水素EMSモニター用画面
	サイズ: [1600px, 900px]
*/

.fix .container .holder-ems {
	position: absolute;
	overflow:hidden;
	left: -800px;
	top: -450px;
	width: 1600px;
	height: 900px;
	visibility: visible;
	background-color:#ffffff;
	font-size: 36px;
	color: #000000;
}

.holder-ems .header {
	position: absolute;
	overflow: hidden;
	width: 1600px;
	height: 60px;
	margin: 0px;
	padding: 2px 2px 2px 2px;
	font-size: 36px;
	display: flex;
	align-items: center;
	justify-content: left;
}

.holder-ems .footer {
	position: absolute;
	overflow: hidden;
	width: 1600px;
	height: 60px;
	margin: 0px;
	padding: 2px 2px 2px 2px;
	font-size: 36px;
	display: flex;
	align-items: center;
	justify-content: left;
}

.holder-ems .full {
	position: absolute;
	overflow: hidden;
	background-color: #eeeeff;
	width: 1600px;
	height: 780px;
	margin: 0px;
	padding: 0px;
	border: 0px
}

.holder-ems .halfarea-vertical {
	position: absolute;
	overflow: hidden;
	width: 796px;
	height: 776px;
	margin: 0px;
	padding: 4px 4px 4px 4px;
	border: 0px
}

.holder-ems .halfarea-horizontal {
	position: absolute;
	overflow:hidden;
	width: 800px;
	height: 386px;
	margin: 0px;
	padding: 4px 4px 4px 4px;
	border: 0px
}

.holder-ems .quaterarea {
	position: absolute;
	overflow: hidden;
	width: 796px;
	height: 386px;
	margin: 0px;
	padding: 4px 4px 4px 4px;
	border: 0px
}

.holder-ems .imageicon-square {
	position: absolute;
	overflow:hidden;
	width: 160px;
	height: 160px;
	background-color: transparent;
	background-size: contain;
	background-repeat: no-repeat;
	background-position: center;
}

.holder-ems .imageicon-vertical {
	position: absolute;
	overflow:hidden;
	width: 128px;
	height: 256px;
	background-color: transparent;
	background-size: contain;
	background-repeat: no-repeat;
	background-position: center;
}

.holder-ems .imageicon-horizontal {
	position: absolute;
	overflow:hidden;
	width: 256px;
	height: 128px;
	background-color: transparent;
	background-size: contain;
	background-repeat: no-repeat;
	background-position: center;
}

.holder-ems .arrow-horizontal {
	position: absolute;
	overflow:hidden;
	width: 140px;
	height: 40px;
	background-color: transparent;
	background-size: 100% 100%;
	background-repeat: no-repeat;
	background-position: center;
}

.holder-ems .arrow-horizontal-middle {
	position: absolute;
	overflow:hidden;
	width: 160px;
	height: 40px;
	background-color: transparent;
	background-size: 100% 100%;
	background-repeat: no-repeat;
	background-position: center;
}

.holder-ems .arrow-horizontal-middlelong {
	position: absolute;
	overflow:hidden;
	width: 180px;
	height: 40px;
	background-color: transparent;
	background-size: 100% 100%;
	background-repeat: no-repeat;
	background-position: center;
}

.holder-ems .arrow-horizontal-long {
	position: absolute;
	overflow:hidden;
	width: 320px;
	height: 40px;
	background-color: transparent;
	background-size: 100% 100%;
	background-repeat: no-repeat;
	background-position: center;
}

.holder-ems .arrow-vertical {
	position: absolute;
	overflow:hidden;
	width: 40px;
	height: 140px;
	background-color: transparent;
	background-size: 100% 100%;
	background-repeat: no-repeat;
	background-position: center;
}

.holder-ems .arrow-vertical-middle {
	position: absolute;
	overflow:hidden;
	width: 40px;
	height: 160px;
	background-color: transparent;
	background-size: 100% 100%;
	background-repeat: no-repeat;
	background-position: center;
}

.holder-ems .arrow-vertical-middlelong {
	position: absolute;
	overflow:hidden;
	width: 40px;
	height: 180px;
	background-color: transparent;
	background-size: 100% 100%;
	background-repeat: no-repeat;
	background-position: center;
}

.holder-ems .arrow-vertical-long {
	position: absolute;
	overflow:hidden;
	width: 40px;
	height: 320px;
	background-color: transparent;
	background-size: 100% 100%;
	background-repeat: no-repeat;
	background-position: center;
}

.holder-ems .separator-vertical {
	position: absolute;
	overflow:hidden;
	width: 2px;
	height: 776px;
	background-color: #000000;
}

.holder-ems .separator-horizontal {
	position: absolute;
	overflow:hidden;
	width: 1600px;
	height: 2px;
	background-color: #000000;
}

.holder-ems .values {
	position: absolute;
	overflow: hidden;
	width: 128px;
	height: 128px;
	background-color: transparent;
	background-repeat: no-repeat;
	background-size: 100% 100%;
	margin: 0px;
	padding: 4px 4px 4px 4px;
	font-size: 18px;
}

.holder-ems .list-table {
	position: absolute;
	overflow:hidden;
	width: 1560px;
	height: 760px;
	margin: 0px;
	padding: 0px;
}

/*
	背景色
*/
.holder-ems .back-normal {
	background-color: #ffffff;
}

.holder-ems .back-alert {
	background-color: #ffdddd;
}

.holder-ems .back-activating {
	background-color: #ff9f3f;
}

/*
	テキスト表示属性
*/
.holder-ems .text-header {
	font-size: 24px;
}

.holder-ems .text-footer {
	font-size: 24px;
}

.holder-ems .text-title {
	font-size: 24px;
}

.holder-ems .text-label {
	font-size: 24px;
}

.holder-ems .text-group-sys {
	font-weight: 800;
	font-size: 18px;
}

.holder-ems .text-pname-sys {
	font-weight: 400;
	font-size: 18px;
}

.holder-ems .text-value-sys {
	font-size: 16px;
}

.holder-ems .text-unit-sys {
	font-size: 14px;
}

.holder-ems .text-caption-list {
	font-size: 11px;
}

.holder-ems .text-value-list {
	font-size: 14px;
}

.holder-ems .text-alert {
	color: #ff0000;
}

/*
	テーブル
*/
.holder-ems .table-list {
	border-collapse: collapse;
	background-color: #eeeeee;
	border: 0px;
	margin: 0px;
	padding: 0px;
	width: 100%;
	border-top-style: solid;
	border-bottom-style: solid;
	border-left-style: solid;
	border-right-style: solid;
}

.holder-ems .tr-list {
	border: 0px;
	margin: 0px;
	padding: 0px;
	border-top-style: solid;
	border-bottom-style: solid;
}

.holder-ems .td-list-caption {
	border: 2px #000000 solid;
	background-color: #f5e173;
	border-right-style: dashed;
	font-size: 16px;
	margin: 0px;
	padding: 2px;
	width: 84px;
}

.holder-ems .td-list-value {
	border: 2px #000000 solid;
	background-color: #CCFFFF;
	border-left-style: dashed;
	font-size: 16px;
	margin: 0px;
	padding: 2px;
	width: 84px;
	text-align: right;
}

.holder-ems .td-list-message {
	border: 2px #000000 solid;
	background-color: #CCFFFF;
	border-left-style: dashed;
	font-size: 16px;
	margin: 0px;
	padding: 2px;
	width: 84px;
	text-align: left;
}

/*
	ボタン表示属性
*/

.holder-ems .button-status {
	font-size: 20px;
	margin: 0px;
	padding: 4px 4px 4px 4px;
}

/*
	テキストボックス表示属性
*/
.holder-ems .text-control {
	font-size: 20px;
	margin: 0px;
	padding: 4px 4px 4px 4px;
}

/* --------------------------------------------------------------------------------------------------------------------------------- */

/*
	フェードイン効果
*/

@keyframes animefadein {
	0% { opacity: 0.0; }
	100% { opacity: 1.0; }
}

.animefadein {
	animation-name: animeblink;
	animation-fill-mode: forwards;
	animation-delay: 0.5s;
	animation-duration: 2s;
	animation-iteration-count: 1;
}

/*
	ブリンク効果
*/

@keyframes animeblink {
	0% { opacity: 0.0; }
	100% { opacity: 1.0; }
}

.animenext {
	animation-name: animeblink;
	animation-duration: 2s;
	animation-iteration-count: infinite;
}

/* --------------------------------------------------------------------------------------------------------------------------------- */

/*
	ナビゲーションバーが隠れるのを防止(bootstrup)
*/
.bsbody {
	padding-top: 5rem;
}

/*
	Bootstrup用レイアウト
*/

.holder-ems-bs {
	font-size: clamp(12px, 1.0vw, 16px);
}

.holder-ems-bsflow {
	position: relative;
	display: inline-block;
	margin-left: auto;
	margin-right: auto;
	margin-top: auto;
	margin-bottom: auto;
	width: 100%;
	font-size: clamp(4px, 0.9vw, 32px);
}

.holder-ems-bsflow .arrow-vertical {
	position: absolute;
	overflow:hidden;
	/* width: 40px; */
	/* height: 140px; */
	background-color: transparent;
	background-size: 100% 100%;
	background-repeat: no-repeat;
	background-position: center;
}

.holder-ems-bsflow .arrow-horizontal {
	position: absolute;
	overflow:hidden;
	/* width: 140px; */
	/* height: 40px; */
	background-color: transparent;
	background-size: 100% 100%;
	background-repeat: no-repeat;
	background-position: center;
}

.holder-ems-bsflow .values {
	position: absolute;
	overflow: hidden;
	/* width: 128px; */
	/* height: 128px; */
	background-color: transparent;
	background-repeat: no-repeat;
	background-size: 100% 100%;
	margin: 0px;
	padding: 4px 4px 4px 4px;
	/* font-size: 18px; */
}

.holder-ems-bscol {
	margin-left: auto;
	margin-right: auto;
	margin-top: auto;
	margin-bottom: auto;
	width: 100%;
}

.holder-ems-bscol .values {
	/* overflow: hidden; */
	/* width: 128px; */
	/* height: 128px; */
	background-color: transparent;
	background-repeat: no-repeat;
	background-size: 100% 100%;
	margin: 0px;
	padding: 4px 4px 4px 4px;
	/* font-size: 18px; */
}

.holder-ems-bslist {
	font-size: clamp(12px, 1.0vw, 16px);
}

.holder-ems-bslist .td-list-caption {
	border: 1px #a3a3a3 solid;
	background-color: #f5e173;
	border-right-style: dashed;
}

.holder-ems-bslist .td-list-value {
	border: 1px #a3a3a3 solid;
	background-color: #CCFFFF;
	border-left-style: dashed;
	text-align: right;
}

.holder-ems-bs .text-group-sys {
	font-weight: 800;
	font-size: 110%;
}

.holder-ems-bs .text-pname-sys {
	font-weight: 400;
	font-size: 110%;
}

.holder-ems-bs .text-value-sys {
	font-size: 100%;
}

.holder-ems-bs .text-valuestr-sys {
	font-size: 150%;
}

.holder-ems-bs .text-unit-sys {
	font-size: 80%;
}

.holder-ems-bs .text-alert {
	color: #ff0000;
}
