@charset "utf-8";
@import 'remodal.css';
@import 'remodal-default-theme.css';

body {
	padding-top: 100px;
	font-family: "Noto Sans JP", "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, "sans-serif";
	font-size: 16px;
	font-weight: 300;
	color: #333;
	line-height: 1.6em;
}
main {
	width:100% !important;
}

ul, ol {
	list-style-type: none;
	padding: 0;
	margin: 0;
}

h1, .h1, h2, .h2, h3, .h3, h4, .h4, h5, .h5, h6, .h6, label, button, .btn, p {
	margin: 0;
}

h1, .h1, h2, .h2, h3, .h3, h4, .h4, h5, .h5, h6, .h6 {
	display: block;
}

h1, .h1 {
	font-family: "Sawarabi Mincho";
	font-size: 50px;
	font-weight: 500;
	line-height: 1.6em;
	text-transform: uppercase;
	text-shadow: 
		0 0 25px #edf8ff, 
		0 0 20px #edf8ff, 
		0 0 0.40px #edf8ff;
}

h2 {
	font-size: 25px;
	line-height: 1.8em;
	font-weight: 600;
	padding: 40px 0 20px;
}
h2.section-title span {
	font-size: 16px;
	font-weight: 400;
	padding-left: 2em;
}
h2.wrench {
	padding: 0;
	margin-bottom: 25px;
}
h2.wrench:before {
	font-family: "Font Awesome 5 Free";
	content: '\f0ad';
	font-weight: 900;
	margin-right: 8px;
}

/*h3 {
	font-size: 20px;
	line-height: 2.4em;
	font-weight: 600;
	padding: 40px 0 20px;
	text-align: center;
}*/

h3 {
  position: relative;
  padding: 1.2em 1em;
  text-align: center;
	width: 85%;
	margin: 2em auto;
	color: #0d5b86;
}
h3:before,
h3:after {
  position: absolute;
  content: '';
}
h3:after {
  top: 0;
  left: 0;
  width: 30px;
  height: 30px;
  border-top: 2px solid #0d5b86;
  border-left: 2px solid #0d5b86;
}
h3:before {
  right: 0;
  bottom: 0;
  width: 30px;
  height: 30px;
  border-right: 2px solid #0d5b86;
  border-bottom: 2px solid #0d5b86;
}

h4 {
	font-size: 20px;
	font-weight: 400;
}


.overlay {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: rgba(50, 70, 81, 0.3);
}
.pipes{
	background: url("../img/bg_main.png") top left no-repeat;
	background-size: contain;
}

dl {
	padding: 15px 0 0;
}
dl dt {
	padding-bottom: 5px;	
}
dl dt:before {
	content: '■';
	margin-right: 2px;
	}
dl dd {
	margin: 0 0 15px 0;
}
ul.list01 li:before {
	content: '※';
}
ul.list01 li {
	text-indent: -1em;
    margin: 0 0 1em 1em;
}
ul.list01 li span {
	font-weight: 500;
}

/*トップへ戻るボタン*/
.pagetop {
	position:fixed; /*固定*/
	bottom:20px; /*場所を右下に移動*/
	right:20px; /*場所を右下に移動*/
	display:block; /*aタグをblock要素に変更*/
	background-color:#fff;
	color:#000;
	width:70px;
	height:70px;
	text-align:center;
	line-height: 30px;
	font-size: 25px;
	text-decoration: none;
	font-weight: 300;
	border: 1px solid #333;
	border-radius:35px;
	padding-top:35px;
	box-sizing:border-box;
	z-index: 99999;
}
.pagetop:before {
	content:'pagetop';
	position:absolute;
	top:10px;
	left:0;
	width:100%;
	text-align:center;
	font-size:13px;
}
.pagetop:after {
	content: '___';
	font-size: 40px;
	position:absolute;
	top:14px;
	left:0;
	width:100%;
	text-align:center;
	font-size:20px;
}
.pagetop a, .pagetop a:hover, .pagetop:hover {
  	opacity:0.7;
	text-decoration: none;
	color:#307195;
	border: 1px solid #307195;
}



/**********************
NAVIGATION
***********************/

#main-navigation.navbar {
	min-height: 100px;
	font-weight: 600;
	text-transform: uppercase;
	line-height: 1;
	margin-bottom: 0;
}

#main-navigation.navbar .navbar-nav {
    display: inline-block;
    float: none;
}

#main-navigation.navbar .navbar-collapse {
    text-align: center;
}

#main-navigation.navbar-fixed-top .navbar-collapse {
	max-height: 380px;
}

#main-navigation.navbar-default {
	background-color: #ffffff;
}

#main-navigation .navbar-brand, 
#main-navigation.navbar-default .navbar-nav>li>a.navbar-brand {
	height: 100px;
	padding: 29px 35px 23px;
}

#main-navigation .navbar-brand img {
	max-height: 48px;
}

#brand-mobile {
	display: none;
}

#main-navigation .navbar-brand-center {
	position: absolute;
	left: 50%;
	transform: translateX(-50%);
}

#brand-desktop {
	display: block;
}

.navbar-default .navbar-nav>li>a {
	color: #334752;
	padding: 40px 35px;
}

#main-navigation.navbar-default .navbar-nav>li>a:focus, 
#main-navigation.navbar-default .navbar-nav>li>a:hover {
	color: #ccc;
	background-color: transparent;
}

#main-navigation.navbar-default .navbar-nav>.active>a, 
#main-navigation.navbar-default .navbar-nav>.active>a:focus, 
#main-navigation.navbar-default .navbar-nav>.active>a:hover {
	color: #ccc;
	background-color: transparent;
}

#main-navigation.navbar-default .navbar-toggle {
	margin-top: 34px;
	margin-bottom: 34px;
	border: 0;
	border-radius: 0;
}

#main-navigation.navbar-default .navbar-toggle:focus, 
#main-navigation.navbar-default .navbar-toggle:hover {
	background-color: transparent;
}

#main-navigation.navbar-default .navbar-toggle .icon-bar {
	background: #ccc;
	width: 22px;
	-webkit-transition: all 0.3s;
	transition: all 0.3s;
}

#main-navigation .navbar-toggle.collapsed .icon-bar {
	background: #334752;
}

.navbar-toggle .icon-bar:nth-of-type(1) {
	-webkit-transform: rotate(45deg);
	-ms-transform: rotate(45deg);
	transform: rotate(45deg);
	-webkit-transform-origin: 10% 10%;
	-ms-transform-origin: 10% 10%;
	transform-origin: 10% 10%;
}

.navbar-toggle .icon-bar:nth-of-type(2) {
	opacity: 0;
	filter: alpha(opacity=0);
}

.navbar-toggle .icon-bar:nth-of-type(3) {
	-webkit-transform: rotate(-45deg);
	-ms-transform: rotate(-45deg);
	transform: rotate(-45deg);
	-webkit-transform-origin: 10% 90%;
	-ms-transform-origin: 10% 90%;
	transform-origin: 10% 90%;
}

.navbar-toggle.collapsed .icon-bar:nth-of-type(1) {
	-webkit-transform: rotate(0);
	-ms-transform: rotate(0);
	transform: rotate(0);
}

.navbar-toggle.collapsed .icon-bar:nth-of-type(2) {
	opacity: 1;
	filter: alpha(opacity=100);
}

.navbar-toggle.collapsed .icon-bar:nth-of-type(3) {
	-webkit-transform: rotate(0);
	-ms-transform: rotate(0);
	transform: rotate(0);
}


/**********************
HOME SECTION
***********************/

#home {
	height: 690px;
}

.carousel {
	width: 100%;
	height: 100%;
}

.carousel .item {
	height: 690px;
	background-size: cover;
}
.carousel .slider01 {
	background: url("../img/slider01.png") center center no-repeat;
}
.carousel .slider02 {
	background: url("../img/slider02.png") center center no-repeat;
}
.carousel .slider03 {
	background: url("../img/slider03.png") center center no-repeat;
}

.carousel-caption {
	padding: 0;
	bottom: 50%;
	transform: translateY(50%);
}

.carousel-caption .btn-default {
	margin-top: 31px;
}

.carousel-caption .h1 {
	margin-top: 27px;
}

.carousel-caption p {
	margin-top: 36px;
	font-size: 20px;
}

.carousel-indicators li {
	margin: 1px 8px;
	border-color: #ffffff;
	background-color: #ffffff;
}

.carousel-indicators .active {
	margin: 0 8px;
	border-radius: 8px;
	border-color: #ccc;
	background-color: #ccc;
}

.carousel-control {
	opacity: 0;
}

.carousel-control span {
	color: #ccc;
}


/**********************
MESSAGE SECTION
***********************/

#message {
	padding: 40px 0 0;
}

.img-president {
	padding: 0 0 20px;
}
.president-name {
	margin: 20px 0;
}

.pdgt100 {
	padding-top:100px;
}


/**********************
ABOUT SECTION
**********************/

#about {
	padding: 80px 0 0;
}

.pdgl60 {
	padding-left: 60px;
}
.pdgr60	{
	padding-right: 60px;
}

.map {
	height: 0;
	overflow: hidden;
	padding-bottom: 56.25%;
	position: relative;
	margin:40px 0;
}
.map iframe {
	position: absolute;
	left: 0;
	top: 0;
	height: 100%;
	width: 100%;
}
.list01 p {
	text-indent: 0;
	padding-left: 1.0em;
}
dl.dl-nonflt dt, dl.dl-nonflt dd {
	float: none;
}
dl.dl-nonflt dt {
	padding-bottom: 1em;
}

/**********************
RECRUIT SECTION
***********************/

#recruit {
	padding: 50px 0 0;
}


/**********************
IMAGE SECTION
***********************/

#image {
	padding: 0;
	min-height: 600px;
	background: url("../img/bg_plant.png") bottom left no-repeat;
	background-size: cover;
}

#image h4 {
	padding-top: 20%;
	font-size: 25px;
	font-weight: 600;
	line-height: 2.0em;
	text-align: center;
}

/**********************
CONTACT US SECTION
***********************/

#contact {
	padding: 89px 0 93px;
	background: #324651;
	color: #ffffff;
}

#contact .section-title {
	color: #ffffff;
}

#contact form {
	margin-top: 92px;
}

#contact form input, 
#contact form textarea {
	display: block;
	width: 100%;
	font-weight: 300;
	padding: 18px 26px;
	color: #ffffff;
	background: transparent;
	border: 1px solid #ffffff;
	border-radius: 5px;
}

#contact form input:focus,
#contact form input:active,
#contact form textarea:focus,
#contact form textarea:active {
	outline: none;
}

#contact form textarea {
	resize: none;
}

#contact form input::-webkit-input-placeholder,
#contact form textarea::-webkit-input-placeholder { /* Chrome/Opera/Safari */
  color: #ffffff;
}
#contact form input::-moz-placeholder,
#contact form textarea::-moz-placeholder { /* Firefox 19+ */
  color: #ffffff;
}
#contact form input:-ms-input-placeholder,
#contact textarea:-ms-input-placeholder { /* IE 10+ */
  color: #ffffff;
}
#contact form input:-moz-placeholder,
#contact form textarea:-moz-placeholder { /* Firefox 18- */
  color: #ffffff;
}

#contact form .row:last-of-type {
	margin-top: 30px;
}

.btn-default {
	padding: 9px 0;
	width: 150px;
	letter-spacing: 0.025em;
	text-transform: uppercase;
	font-size: 15px;
	font-weight: 600;
	border-radius: 20px;
	box-sizing: border-box;
	transition: all 0.3s;
	outline: none;
	box-shadow: none;	
}
.btn-default.white-blue {
	color: #334752;
	background-color: #ffffff;
	border: 1px solid #ffffff;
}

.btn-default.white-blue:hover,
.btn-default.white-blue.active.focus, 
.btn-default.white-blue.active:focus, 
.btn-default.white-blue.active:hover, 
.btn-default.white-blue:active.focus, 
.btn-default.white-blue:active:focus, 
.btn-default.white-blue:active:hover {
	color: #ffffff;
	background: #334752;
	border: 1px solid #ffffff;
	box-shadow: none;
	outline: none;
}
#contact form .btn {
	margin: 53px 10px;
	width: 140px;
}
.btn-wrap	{
	width: 340px;
	margin: 0 auto;
}


/**********************
FOOTER SECTION
***********************/

#footer {
	padding: 20px 0 40px;
	font-size: 0.9em;
}
#footer h2 {
	font-size: 25px;
	padding: 0 0 20px;
}
.footer-logo	{
	margin-top: 40px;
}
.address span {
	font-size: 0.8em;
	margin-right: 5px;
}
.tel:before {
	font-family: "Font Awesome 5 Free";
	content: '\f095';
	font-weight: 900;
	margin-right: 5px;
}

.fax:before {
	font-family: "Font Awesome 5 Free";
	content: '\f1ac';
	font-weight: 900;
	margin-right: 5px;
}

#footer .copyright {
	font-size: 15px;
}

/*POLICY*/
.remodal {
	text-align: left;
}
.remodal dl {
	padding: 2em 0;
}
.remodal dl dt, .remodal dl dd {
	float: none;
}
.remodal ul {
	list-style-type:disc;
	margin-left: 2em;
}
#footer p > a.policy-remodal {
	cursor: pointer;
	text-decoration: none;
}
#footer p > a.policy-remodal:hover {
    color: #ff4800;
}

.btn-default.blue-white {
	color: #1781bb;
	background-color: #ffffff;
	border: 1px solid #1781bb;
}

.btn-default.blue-white:hover,
.btn-default.blue-whitee.active.focus, 
.btn-default.blue-white.active:focus, 
.btn-default.blue-white.active:hover, 
.btn-default.blue-white:active.focus, 
.btn-default.blue-white:active:focus, 
.btn-default.blue-white:active:hover {
	color: #ffffff;
	background: #1781bb;
	border: 1px solid #ffffff;
	box-shadow: none;
	outline: none;
}

/**********************
HELPER CLASSES
***********************/

.mgt20	{
	margin-top: 20px;
}
.mgt40	{
	margin-top: 40px;
}
.mgt80	{
	margin-top: 80px;
}
.pdgl40	{
	padding-left: 40px;
}


/**********************
RESPONSIVE
***********************/

@media only screen and (min-width: 1440px) {

	dl {
		padding: 0;
		margin:0;
	}
	dl dt {
		clear: left;
		float: left;
	}
	dl.dl30 dt {
		width: 30%;
	}
	dl.dl25 dt {
		width: 25%;
	}
	dl.dl30 dd {
		margin: 0 0 10px 31%;
	}
	dl.dl25 dd {
		margin: 0 0 10px 26%;
	}

	
	/**********************
	HOME SECTION
	***********************/
	.carousel-caption {
		left: 15%;
		right: 15%;
	}
	.president-profile dl {
		font-size: 0.9em;
		padding: 0;
		margin:0;
	}
	.president-profile dl dt {
		width: 20%;
		font-weight: normal;
	}
	.president-profile dl dd {
		margin: 5px 0 0 21%;
	}
}

@media only screen and (min-width: 1200px) {

	/**********************
	MESSAGE SECTION
	***********************/
	.img-president {
		width: 60%;
	}

	/**********************
	IMAGE SECTION
	***********************/

	#image {
		min-height: 1024px;
	}

}

@media only screen and (max-width: 1199px) {
	
	/**********************
	NAVIGATION
	***********************/
	#main-navigation .container {
		width: 100%;
	}
	#main-navigation.navbar-default .navbar-nav>li>a {
		padding: 40px 20px;
	}
	#main-navigation .navbar-brand, #main-navigation.navbar-default .navbar-nav>li>a.navbar-brand {
		padding: 29px 23px 23px;
	}

	
	/**********************
	HOME SECTION
	***********************/
	.carousel-caption .h1 {
		font-size: 30px;
	}


	/**********************
	MESSAGE SECTION
	***********************/
	.pdgt100 {
		padding-top: 60px;
	}
	
	/**********************
	ABOUT SECTION
	***********************/
	.pdgl60 {
		padding-left: 0;
	}
	.pdgr60 {
		padding-right: 0;
	}
	#about, #recruit, #contact {
	padding: 40px 0 0;
	}

	
	/**********************
	IMAGE SECTION
	***********************/

	#image h2 {
		text-align: left;
		margin-left: 20px;
	}	

}

@media only screen and (max-width: 991px) {
	
	/**********************
	CONTACT US SECTION
	***********************/
	#contact .contact-form .row div:not(:first-of-type) {
		margin-top: 30px;
	}

}

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

	/**********************
	DEFAULT
	***********************/

	h2.section-title {
		font-size: 25px;
	}
	
	/**********************
	NAVIGATION
	***********************/

	#main-navigation.navbar .navbar-nav {
	    display: block;
	}

	#brand-mobile {
		display: block;
	}

	#main-navigation .navbar-brand-center {
		padding: 29px 45px 23px;
	}

	#brand-desktop {
		display: none;
	}

	#main-navigation.navbar-default .navbar-nav>li>a {
		padding: 20px 0;
	}

	/**********************
	HOME SECTION
	***********************/
	.carousel-caption .h1 {
		font-size: 25px;
	}

}