@import url(https://fonts.googleapis.com/css?family=Lato:400,700);
@import url(http://fonts.googleapis.com/earlyaccess/notosansjp.css);

body {
	font-family: Lato, "Noto Sans JP", "游ゴシック Medium", "游ゴシック体", "Yu Gothic Medium", YuGothic, "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	font-size: 14px;
	-webkit-text-size-adjust: 100%;
	line-height: 1.4em;
	min-height: 100%;
	display: flex;
	flex-direction: column;
	margin-top: 100px !important;
}
html {
	height: 100%;
}
#header .container {
	width: 100%;
}
.wrapper {
	flex:1 1 auto;
}
#top-bg {
	text-align:center;
	background-color: white;
	margin-top: 62px;
}
#img-top-bg {
	width: 100%;
	height: 360px;
	margin: 0 auto;
}
#img-otc-logo {
 	width: 400px;	
/*	height: 250px;	*/
	margin: 50px auto;
	position: absolute;
	left: 0;
	right: 0;
	padding-top: 40px;
}
.container h2 {
	color: #397DA2;
}
@media screen and (max-width: 680px) {
	body {
		font-size: 0.95em;
	}
	ul.navbar-nav  li {
		text-align: center;
	}
	#top-bg {
		margin-top: 52px;
	}
	.header-logo {
		display: block;
		top: 10px !important;
		left : 0px !important;
	}
}
@media screen and (max-width: 480px) {
	body {
		font-size: 0.9em;
	}
}
.label {
	clear: both;
	padding: 0 !important;
}
.container h2
{
	background-color: transparent !important;
	border-left: 0 !important;
	text-align: center;
	font-weight: bold;
	font-size: 2.4rem;
	width: 100%;
	max-width: 1024px;
	margin: 0px auto !important;
	padding-bottom: 10px;
}
.container h2 a {
	color: #397DA2 !important;
}
.services h3  {
	color: #397DA2 !important;
	font-size: 1.8rem;
	margin-bottom: 1.6rem;
}
#global-menu div,
#footer div {
	vertical-align: middle;
}
@media screen and (max-width: 680px) {
	#logo {
		width: 200px;
	}
	div.message {
		font-size: 0.9em;
	}
	div.message br {
		display: none;
	}
}
@media screen and (max-width: 480px) {
	#fixed-menu-button-open {
		display: block;
	}
	#logo {
		width: 200px;
		height: 50px;
		margin: 0 0 0 10px;
	}
	div.message {
		font-size: 0.7em;
	}
	div.message br {
		display: none;
	}
	ul.navbar-nav {
		width: auto !important;
	}
	div.link h2 {
		font-size: 1.0em;
	}
}
@media screen and (max-width: 480px) {
	#global-menu {
		display: none;
	}
	#global-menu {
		width: 220px;
		padding-top: 60px;
		position: fixed;
		top: 0;
		right: 0;
		background: #4C4C4C;
		height: 100%;
	}
	#global-menu a {
		display: inline-block;
		width: 100%;
		border-bottom: #666666 solid 1px;
		padding: 1em 0 1em 0;
	}
}
#main {
	margin: 20px auto 0;
	width: 100%;
	max-width: 1000px;
}
#main div {
	padding: 10px 20px;
}
#footer {
	margin-top: 20px;
	width: 100%;
	height: 60px;
	display: block;
	text-align: center;
	font-size:12px;
}
div.box
{
	margin:auto;
	width:150px;
	height:150px;
	border:1px black solid;
	text-align: center;
}

/** header **/
div.container-fluid
{
	width:60%;
	height:auto;
	background-color: transparent;
}
 > ul > li > a:link,
 > ul > li > a:visited,
 > ul > li > a:hover,
 > ul > li > a:active
{
	font-size: 1.2em;
	line-height: 31px;
	color:#397DA2!important;
	margin-left:1px;
	margin-right:1px;
	text-decoration: none;
	padding: 10px 20px !important;
}
 > ul > li > a:hover,
 > ul > li > a:active
{
	text-decoration: underline;
}
#otc-logo {
	background-size: 400px;
	background-image: url('../img/otc-logo.png');
	background-position: center;
	background-repeat: no-repeat;
	width: 100%;
	height: 280px;
	margin: 20px auto;
	text-align: center;
}

/** navbar **/
.nav>li>a {
	padding: 20px !important;
	color: #397DA2 !important;
	font-size: 1.6rem !important;
	font-size: 1.0em !important;
}
ul.navbar-nav
{
	max-width: 1200px;
	width: 100%;
	float: none;
	text-align: center;
	margin: 0 auto;
	z-index: 1000;
}
ul.nav.navbar-nav > li
{
	margin: 0 auto;
	float: none;
	display: inline-block;
}

/** general **/
a:hover
{
	text-decoration: underline;
}
span.line{
	display: block;
}
span.line-label{
	display: block;
	margin-top: 20px;
	margin-bottom: 10px;
	margin-left: -10px;
}
span.line-list{
	display: block;
	margin-left: 20px;
}
span.line > ul > li{
	margin-left: 30px;
}
span.line > a:link,
span.line > a:visited,
span.line > a:hover,
span.line > a:active{
	color: #397DA2;
	padding-bottom: 4px;
	display: inline-block;
	text-decoration: underline;
}
.center
{
	text-align: center;
}
button.btn>span
{
	margin-right:10px;
}
span.required
{
	margin-left: 5px;	
	color: #397DA2;
	background-color: #EAFFFE;
	font-size:100%;
}

/** footer **/
footer > div.footer-wrapper
{
	margin-top: 40px;
	margin-bottom: 20px;
}
ul.footer-menu>li
{
	display:inline-block;
	margin-left:5px;
	margin-right:5px;
}
ul.footer-menu > li > a
{
	text-decoration: underline;
}
.tbledit>tbody>tr>th
{
	width: 110px;
	font-size:100%;
	background-color: #cfebfb;
	padding:4px!important;
}
.tbledit>tbody>tr>td
{
	font-size:100%;	
}
/** プライバシー **/
h3.sub-title
{
	color:black;
	font-size:180%;
	margin-top:20px;
	margin-bottom:20px;
}
div.content>p
{
	font-size:100%;
	line-height: 2.2;
	margin-left: 10px;
}

/** index header **/
div.bg-header
{
	width:600px;
	margin: 0 auto;
	padding: 0;
	position: relative;
}
div.bg-header> img
{
	width: 100%;
	height: auto;
}
div.header-inner
{
	position:absolute;
	width:100%;
	top:20%;
	text-align: center;
}
@media screen and (max-width: 900px) {
	p.header-title
	{
		color:white;
		opacity: 0.89;
		font-size:270%;
		font-weight: 700;
		text-align: center;
	}
}
@media screen and (max-width: 680px) {
	p.header-title
	{
		color:white;
		opacity: 0.89;
		font-size:170%;
		font-weight: 700;
		text-align: center;
	}
}
@media screen and (max-width: 480px) {
	p.header-title
	{
		color:white;
		opacity: 0.89;
		font-size:130%;
		font-weight: 700;
		text-align: center;
	}
	p.header-detail
	{
	    color:#c1d6ff;
		opacity: 0.89;
		font-size:80%;
		font-weight: 700;
		text-align: center;
		max-width:620px;
		margin-left:5px;
		margin-right:5px;
	}
}

/** contact **/
.radio-container0 > label > input
{
	position: relative;
	top: 6px;
}
.radio-container > label
{
	font-weight: 400;
	display: inline-block;
	margin-right: 10px;
}
.radio-container > label>input[type="radio"]
{
	margin-top: 0px!important;
	margin-right:4px;
	position: relative;
	top: -2px;
}
img.menu-icon
{
	width:32px;
	height: 32px;
}

table.contact-table td{
	border-style: solid;
	border: 1px #A6A6A6 solid;
	vertical-align: middle;
	text-align: right;
	font-size: 10pt;
	line-height: 260%;
	padding-bottom:3px;
	padding-top:3px;
}
.contact-line{
	font-size: 0.9em;
}

/* news */
ul.news {
	padding: 0 0.5em;
	position: relative;
}
ul.news li {
	line-height: 1.5;
	padding: 0.5em 0 0.5em 0em;
	border-bottom: dashed 1px silver;
	list-style-type: none!important;
}
ul.news span {
	color: #ffb03f;
	margin-right:5px;
}
ul.news li:last-of-type{
	border-bottom: none;
}
panel {
	width: 500px;
}
#panel > dt {
	border-bottom: solid 1px white;
	background-color: #00BCD4;
	color: white;
	cursor: pointer;
	padding: 10px;
	font-weight: bold;
}
#panel > dd {
	border: solid 1px Silver;
	margin: 0px;
	padding: 10px;
}
.submenu
{
	margin-top:-6px;
	background-color: #084ea1;
}
.submenu-bold
{
	color:white;
	margin-left: 15px;
	font-weight: bold;
}

/** question **/
ul.default {
	padding: 0 0.5em;
	position: relative;
}
ul.default li {
	line-height: 1.5;
	padding: 0.5em 0 0.5em 0em;
	border-bottom: dashed 1px silver;
	list-style-type: none!important;
}
ul.default span {
	color: #6495ed;
	margin-right:5px;
}
@media screen and (max-width: 480px) {
	ul.default li {
		line-height: 1.5;
		padding: 0.5em 0 0.5em 0em;
		border-bottom: dashed 1px silver;
		list-style-type: none!important;
		margin-left:-15px;
	}
}
ul.default li:last-of-type{
	border-bottom: none;
}
.num
{
	text-align: right;
}
#tbl-price > thead > tr
{
	background-color:#4b89ca;
	color:white;
}
#tbl-function
{
	max-width:700px;
}
#tbl-function>tbody>tr.odd
{
	background-color:#C6C9DE;
}
#tbl-function > thead > tr,
#tbl-function > tbody > tr.header
{
	background-color:#4b89ca;
	color:white;
}
@media screen and (max-width: 480px) {
	#tbl-price,
	#tbl-function
	{
		max-width:320px;
		font-size:8pt;
	}
	#tbl-price>tbody>tr>th,
	#tbl-price>tbody>tr>td
	{
		padding: 6px!important;
	}
}
ul.download
{
	list-style-type: none!important;
}
ul.question
{
	list-style: none;
	margin-left: -5px;
}
div.bg-header-postoffice
{
	width:100%;
	height: 420px;
	background-image:url('../img/postoffice-top.png');
	background-size: cover;
}

/* headerのリンク */
div.link > p > a:link,
div.link > p > a:visited,
div.link > p > a:hover,
div.link > p > a:active
{
	font-size: 1.8em;
	font-weight: bold;
	color: black!important;
	margin-left: 1px;
	margin-right: 1px;
}

/* TOPページ */
div.message
{
	margin: 0 auto 20px;
	color: #397DA2;
}
div.message > p
{
	margin: 10px 0 0 0;
	font-size: 1.4em;
	line-height: 160%;
	text-align: center;
}

/* TOPページのボタンデザイン */
#services-bookmark {
	height: 70px;
}
div.services {
	width: 100%;
	margin: 0 auto;
	text-align: center;
}
.header-logo {
	display: none;
	width: 120px;
	height: 90px;
	background-size: contain;
	background-position: center center;
	background-repeat: no-repeat;
	background-image: url(/img/otc-logo-header.png);
	position: fixed;
	left: 250px !important;
	top: 0px;
	transform: translate(-50%, 0%);
}
div.service-icon {
	width: 100%;
	height: 70px;
	border-radius: 20px;
	background-size: contain;
	background-position: center;
	background-repeat: no-repeat;
}
div.service-icon-postoffice {
	background-image: url(../img/service-icon-postoffice.png);
}
div.service-icon-postoffice-maintenance {
	background-image: url(../img/service-icon-postoffice-maintenance.png);
}
div.service-icon-postoffice-infrastructure {
	background-image: url(../img/service-icon-postoffice-infrastructure.png);
}
div.service-icon-wisealert {
	background-image: url(../img/service-icon-wisealert.png);
}
div.service-icon-orca {
	background-image: url(../img/service-icon-orca.png);
}
div.service-icon-programming {
	background-image: url(../img/service-icon-si.png);
}
div.service-button {
	display: inline-block;
	-moz-border-radius: 20px;
	-webkit-border-radius: 20px;
	border-radius: 20px;
	border: 1px solid #397DA2;
	background-color: #E2F7F7;
	width: 300px;
	height: 270px;
	margin-top: 10px;
	margin-bottom: 10px;
	margin-left: 10px;
	margin-right: 10px;
	text-align: center;
	text-decoration: none;
	line-height: 30px;
}
div.orca-agree-button, div.personal-agree-button, div.univoice-agree-button {
	display: inline-block;
	-moz-border-radius: 10px;
	-webkit-border-radius: 10px;
	border-radius: 10px;
	border: 1px solid #ffd332;
	background-color: #fff8ca;
	width: 100%;
	height: 85px;
	margin-top: 0px;
	margin-bottom: 0px;
	padding-top: 10px;
	padding-left: 30px;
	text-align: left;
	text-decoration: none;
	line-height: 30px;
}
div.button-title {
	height: 70px;
	font-size: 1.5em;
	font-weight: bold;
	color: #397DA2;
	margin-top: 20px;
	margin-bottom: 15px;
}
div.button-text {
	height: 60px;
	color: #333;
	font-size: 0.9em;
	line-height: 140%;
	margin: 10px 30px 0;
	text-align: left;
}
div.button-text > ul > li{
	width: 100%;
	margin-right: auto;
	padding-right: auto;
}
div.button-link{
	-moz-border-radius: 20px;
	-webkit-border-radius: 20px;
	border-radius: 20px;
	background-color: #397DA2;
	color: white;
	width: 140px;
	height: 35px;
	margin: 0 auto;
	line-height: 32px;
	text-align: center;
	text-decoration: none;
	font-size: 1.4em;
}
a.link-in-button:link,
a.link-in-button:visited,
a.link-in-button:hover,
a.link-in-button:active{
	text-decoration: none;
}

/* 各ページの共通テンプレート*/
div.label {
	height: 90px;
	font-size: 1.8em;
	line-height: 160%;
	color: #397DA2; 
	display: block !important;
}
div.label > p {
	margin-bottom: 20px;
}
div.container-title{	/* プライバシーポリシーのみで利用 */
	color: #397DA2;
	font-size: 1.4em;
	margin-top: 30px;
}
div.main-label{
	width: 100%;
	position: fixed;
	top: 100px;
	left: 50%;
	transform: translate(-50%, -50%);
	background-color: #fff;
	font-size: 2.0em;
	color: #397DA2;
}
p.liner{
	margin-bottom: 3px;
}

table.news-table {
	border-style: solid;
    border-collapse: separate;
    border-radius: 10px;
	border: 1px solid #397DA2;
    overflow: hidden;
/*	background-color: #E2F7F7; */
	background-color: white;
}

/* 会社概要 */
#about .company-col-title > span {
	background-color: #f2f2f2;
	display: inline-block;
	width: 100%;
	border-radius: 4px;
	color: #397DA2;
	padding: 4px 8px;
}
#about.container, #map.container {
	width: 800px !important;
	padding: 0 !important;
}
.company-table{
	margin-top:20px;
	margin-bottom: 30px;
}
.company-colgroup{
	width: 160px;
}
.company-col-title{
	color: #397DA2;
	padding-left: 10px;
	padding-top: 6px;
	padding-bottom: 6px;
	font-weight: normal;
	text-align: center;
}
.company-col-text{
	color: black;
	padding-top: 6px;
	padding-bottom: 6px;
	padding-left: 20px;
}
.company-spacer{
	width: 20px;
}
.company-access{
	background-color: #397DA2;
	color: white;
	width: 800px;
	margin: 0 auto;
	padding-top: 5px;
	padding-left: 5px;
}
.company-map{
	width: 800px;
}

/* お問い合わせ */
#contact-group > label {
	width: 100%;
	max-width: 840px;
	margin: 0 auto;	
}
span.contact-label {
	font-size: 10pt;
	color: black;
	font-weight: normal;
}
.contact-waku {
	width: 100%;
	max-width: 840px;
	border: 1px solid #397DA2;
	padding: 10px;
	border-radius: 10px;
	margin: 0 auto 20px;
	margin-top: -15px;
}

/* お知らせ */
#info-block {
	margin: 0 auto;
	width: 100%;
	max-width: 860px;
}
.info-table{
	width: 900px;
	margin: 0 auto;
}
.info-table > tbody > tr {
	border-bottom: 1px solid #f2f2f2;
}
.info-colgroup1 {
	width: 130px;
	height: 50px;
}
.info-colgroup2 {
	width: 100px;
}
.info-col-title {
	color: #4c4c4c;
	padding: 10px;	
}
.info-col-cate span {
	color: white;
	font-size: 0.8em;
	border-radius: 4px;
	display: inline-block;
	padding: 4px 8px;
	width: 100%;
	text-align: center;
}
.info-col-cate-all {
	background-color: #FECC6D;
}
.info-col-cate-po {
	background-color: #004080;
}
.info-col-cate-ov {
	background-color: #2D8179;
}
.info-col-text {
	padding-left: 20px !important;
}
.info-col-text > a:link,
.info-col-text > a:visited,
.info-col-text > a:hover,
.info-col-text > a:active
{
	color: #397DA2 !important;
	text-decoration: underline;
}
.info-date {
	float: right;
	color: #397DA2;
	font-size: 1.2em;
	margin: 0 auto 20px;
	display: inline-block;
}
.info-text {
	width: 800px;
	margin: 0 auto;
	color: #4c4c4c;
	font-size: 1.0em;
}
.info-text .line {
	margin-bottom: 4px;
}
.info-table-tbody > tr{
	border: 2px #979797 solid;
}

/* footer */
ul.footer-menu > li > a:link,
ul.footer-menu > li > a:visited,
ul.footer-menu > li > a:hover,
ul.footer-menu > li > a:active
{
	font-size: 1.2em;
	color: #397DA2 !important;
	text-decoration: none;
}
.col-md-12 {
	margin-bottom: 10px;
}
.copyright {
	color: #4c4c4c;
}
ul.left-20 > li
{
	margin-left:20px;
}
.form-group {
	width: 100%;
	max-width: 770px;
	margin: auto;
}
.form-row {
	margin-left:10px;
}
.form-col {
	display: inline;
	height: 34px;
	padding: 6px 12px;
	font-size: 14px;
	line-height: 1.42857143;
	color: #555555;
	background-color: #fff;
	background-image: none;
	border: 1px solid #ccc;
	border-radius: 4px;
	-webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);
	box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);
	-webkit-transition: border-color ease-in-out .15s, box-shadow ease-in-out .15s;
	-o-transition: border-color ease-in-out .15s, box-shadow ease-in-out .15s;
	transition: border-color ease-in-out .15s, box-shadow ease-in-out .15s;
	margin-bottom: 10px;
}
input.chkbox {
	display: inline-block;
	margin: 0 2px !important;
	padding: 0;
	vertical-align: middle;
 	position:relative;
	top: -1px !important;
}

/* プロダクトページ(PostOffice,ORCA-Voice) */
.container-product {
	width: 1000px !important;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 50px;
}
div.product-top-menu{
	width: 80%;
	text-align: center;
	margin: 0 auto;
	color: #397DA2;
}
div.product-top-menu a:hover {
	text-decoration: none;
}
div.side-menu{
	width: 220px;
	height: 100%;
	top: 0;
	position: fixed;
	padding-top: 100px;
	padding-left: 2%;
	margin-top: 0px;
	color: #397DA2;
	background-color: white;
}
div.side-menu-line{
	margin-bottom: 15px;
	cursor: pointer;
}
div.side-menu > div > a:link,
div.side-menu > div > a:visited,
div.side-menu > div > a:hover,
div.side-menu > div > a:active{
	color: #397DA2;
	text-decoration: none;
}
div.main-field{
	color: #4c4c4c;
	margin-top: 0px;
	margin-left: 225px;
	margin-right: 50px;
	filter: alpha(opacity=0);
}
div.product-page{
	margin-bottom: 50px;
	line-height: 30px;
}
div.product-label {
	height: 90px;
	font-size: 1.3em;
	line-height: 160%;
	color: #397DA2; 
	text-align: center;
}
div.product-subtitle{
	font-size: 1.2em;
	color: #3988B1;
}
span.page-title{
	font-size: 1.3em;
	color: #397DA2;
}
div.product-sub-title{
	color: #397DA2;
	font-size: 1.3em;
}
.product-line{
	font-size: 1.0em;
}

/* postoffice */
div.sub-title{
	margin-top: 20px;
}
div.sub-title > a:link,
div.sub-title > a:visited,
div.sub-title > a:hover,
div.sub-title > a:active{
	color: #397DA2;
}
table.postoffice-table td{
	border-style: solid;
	border: 2px #808080 solid;
	vertical-align: middle;
	text-align: right;
}
div.postoffice-sub-title{
	font-size: 20px;
}

/* orca */
table.orca-table td{
	border-style: solid;
	border: 2px #808080 solid;
	vertical-align: middle;
}

#product-top-menu span {
  cursor: pointer;
}
@media screen and (max-width: 480px) {
  #product-top-menu {
   font-size: 4vw;

  }
  #frmContact .label {
    white-space: normal;
    font-size: 6vw;
  }
  #subtext {
    margin: 0 !important;
  }
}
