﻿/* 共通定義 */
body {
	font: 14px/2 "メイリオ", Meiryo, "ＭＳ Ｐゴシック", Osaka, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro";	/*文字サイズ、行間、フォント指定*/
}

.style-pc-mode {
	display: block;
}

.style-sp-mode {
	display: none;
}

.text-center {
	text-align: center;
}

/* Header Section */
#logo_img {
	width: 230px;
}

/* Slider Section */
.slider-banner {
	margin-bottom: 50px;
}

.slider-fontsize {
	font-size: 80%;
	font-wight: bold;
}

/* EsterLine Section */
.esterline-section {
	padding: 30px 0px;
	background-image: url(../img/esterline/back.jpg);
}

.new-title01-margin {
	margin: 0px;	
}

.new-title02-margin {
	margin: 0px;	
}

.new-topics-section {
	background-color: #c8c8c8;
	padding: 0px;
	margin: 0px 0px;
	height: 150px;
	color: #000;
	opacity: 1;
}

.new-topics-section:hover {
	opacity: 0.7;
}

.foreign-info-section {
	background-color: #fff;
	padding: 0px;
	margin: 0px 0px;
	height: 100px;
	color: #000;
	opacity: 1;
}

.foreign-info-section:hover {
	opacity: 0.7;
}

.ester-line-section {
	background-color: #fff;
	padding: 0px;
	margin: 0px 0px;
	height: 300px;
	color: #000;
	opacity: 1;
}

.ester-line-section:hover {
	opacity: 0.7;
}

.topics-new {
	float: left;
	margin-top: 5px;
	padding-left: 5px;
}

/* Service Section */
.service-title {
	margin-top:10px;
}

.service-arrow {
	display: block;
	text-align: center;
}

/* Title Section */
.title-section {
	margin-top: 30px;
	margin-bottom: 30px;
}

/* Company Section */
.company-section {
	margin-bottom: 30px;
}

.table-color1 th {
	color: #000;
	background-color: #7dc7ff;
}

.table-color2 th {
	color: #fff;
	background-color: #0777cc;
}

.table-color1 td {
	color: #000;
	background-color: #f3f3f3;
}

.table-color2 td {
	color: #000;
}

/* Map Section */
.map {
    height: 500px;
    width: 100%;
}

/* Social Section */
.social-section {
	margin-top: 30px;
	margin-bottom: 30px;
}

.social-title {
	margin-top: 30px;
}

/* Contact Section */
.contact-section {
	background: #333 url(../img/contact/back-main.jpg) center fixed;
	padding: 50px 0px;
}

.contact-section:after {
  top: 0;
  left: 0;
  width: 100%;
  height: 100%; 
  content: " ";
  position: absolute;
  background: rgba(0,0,0,0.99);
}

.contact-section:before {
  top: 0;
  left: 0;
  width: 100%;
  height: 100%; 
  content: " ";
  position: absolute;
}

.contact-title {
	color: #fff;
	margin-bottom: 20px;
}

.contact-comment {
	color: #000;
	background-color: #fff;
	padding: 10px;
	border-radius: 10px;
	opacity: 0.8;
	margin-bottom: 30px;
}

.text-red {
	color: #ff0000;
}

.margin-bottom-15 {
	margin-bottom: 15px;
}

.contact-address {
	color: #000;
	background-color: #fff;
	padding: 20px;
	border-style: solid;
	border-color: #3697d9;
	border-radius: 10px;
	opacity: 0.8;
	margin-top: 30px;
	margin-bottom: 30px;

}

.contact-form {
	margin-top: 100px;
	color: #000;
	background-color: #fff;
	padding: 10px;
	border-style: solid;
	border-color: #3697d9;
	border-radius: 10px;
}

.sky-form .state-error input,
.sky-form .state-error textarea {
	border-color: #e0aaaa;
}

.sky-form .state-error + em {
	display: block;
	margin-top: 6px;
	padding: 0 1px;
	font-style: normal;
	font-size: 11px;
	line-height: 15px;
	color: #ee9393;
}
.sky-form .rating.state-error + em {
	margin-top: -4px;
	margin-bottom: 4px;
}

.sky-form .state-success input {
	border-color: #f0fff0;
}

.sky-form .input.state-disabled input {
	border-color: #f0fff0;
}

.sky-form .message {
	display: none;
	color: #6fb679;
}

.sky-form .message i {
	display: block;
	margin: 0 auto 20px;
	width: 81px;
	height: 81px;
	border: 1px solid #6fb679;
	border-radius: 50%;
	font-size: 30px;
	line-height: 81px;
}

.sky-form.submited fieldset,
.sky-form.submited footer {
	display: none;
}

.sky-form.submited .message {
	display: block;
	padding: 25px 30px;
	font: 300 18px/27px 'Open Sans', Helvetica, Arial, sans-serif;
	text-align: center;
}

.sky-form.submited .message p {
	color: #000;
}

/* Footer Section */
.site-map {
	margin-bottom: 7px;
}




/* Contact Form 2019.08.08 */
.contact-form {
	margin-top: 4vw;
	color: #000;
	background-color: #fff;
	padding: 1vw 2vw;
	border-style: solid;
	border-width: thin;
	border-color: #3697d9;
	border-radius: 1.5vw;
}

.contact-form p {
	font-size: 0.9vw;
}

.contact-form label {
	font-size: 0.9vw;
}

.form-control {
	margin-top: -0.6vw;
	margin-bottom: 0;
}

.form-checkbox {
	margin-top: -0.6vw;
	margin-bottom: 1.5vw;
}

.contact-error {
	font-size: 0.9vw;
}

.text-link, .text-link:hover {
	text-decoration-line: underline;
	text-decoration-color: red;
}

.mail-link {
	text-decoration-line: underline;
	text-decoration-color: black;
	color: black;
}

.policy-error {
	margin-top: -2vw;
	font-size: 0.9vw;
}

.complete-section {
	margin-top: 6vw;
	margin-bottom: 6vw;
}















/*ここからスマートフォン用（768px以下）環境の設定
---------------------------------------------------------------------------*/
@media (max-width : 768px) {
	.style-pc-mode {
		display: none;
	}

	.style-sp-mode {
		display: block;
	}

	#logo-img-mobile {
		width: 250px;
	}

	.ester-line-section {
		height: auto;
	}

	.service-comment {
		line-height: 150%;
	}




	.contact-form {
		margin-top: 20px;
		padding: 10px 10px;
		border-radius: 10px;
	}

	.contact-form p {
		font-size: 16px;
	}

	.contact-form label {
		margin-top: -10px;
		font-size: 14px;
	}

	.form-control {
		margin-top: -10px;
	}

	.form-checkbox {
		margin-top: -20px;
		margin-bottom: 20px;
	}

	.contact-error {
		font-size: 14px;
	}

	.policy-error {
		margin-top: -10px;
		font-size: 14px;
	}

	.complete-section {
		margin-top: 60px;
		margin-bottom: 60px;
	}
}
