@charset "UTF-8";
/* Body */
body {
	font-family:"Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, "sans-serif";
	background-color: #F7F7F7;
	margin-top: 0px;
	margin-right: 0px;
	margin-bottom: 0px;
	margin-left: 0px;
	font-style: normal;
	font-weight: 500;
}
/* Container */
.container {
	width: 90%;
	margin-left: auto;
	margin-right: auto;
	height: 870px;
	background-color: #F7F7F7;
}
/* Navigation */
header {
	width: 95%;
	height: 15%;
	background-color:rgba(247,247,247,0);
	position: fixed;
}
.logo {
	color: #fff;
	font-weight: bold;
	text-align: undefined;
	width: 10%;
	float: left;
	margin-top: 15px;
	margin-left: 25px;
	letter-spacing: 4px;
}
.container header nav {
	margin-top: 0px;
	margin-right: 0px;
	margin-bottom: 0px;
	margin-left: 0px;
	width: 20%;
	float: right;
	overflow: auto;
	display: inline-block;
	background: rgba(238,238,0,0);
}
header nav ul {
	padding: 0px;
	float: none;
}
nav {
	float: right;
	width: 50%;
	text-align: right;
	margin-right: 25px;
}
header nav ul {
	list-style: none;
	float: right;
}
nav ul li {
    padding: 5px;
	color: #565656;
	font-size: 12px;
	text-align: right;
	margin-right: 25px;
	letter-spacing: 2px;
	font-weight: bold;
	transition: all 0.3s linear;
}

ul   { 
	list-style:none;
	padding-left:0;
}

ul li a {
	padding:3px 3px 3px 3px;
	color: #F7F7F7;
	text-decoration: none;
	text-shadow: -1px -1px 0.5px rgba(255, 255, 255, .7),
              -1px -1px 0.5px rgba(255, 255, 255, .5),
              1px 1px 0.5px rgba(255, 255, 255, .075),
              1px 1px 0.5px rgba(0, 0, 0, .15);
}
ul li:hover a {
	color: #B7BCC2;
}
hr {
	margin-top: 10px;
	margin-bottom: 10px;
	height:1px;
	color:#E5E9EF;
	background-color: #E5E9EFCCD9;
	border:none;
	box-shadow: -1px 1px 1px rgba(255, 255, 255, .7),
              -1px -1px 1px rgba(255, 255, 255, .5),
              1px 1px 1px rgba(255, 255, 255, .075),
              1px 1px 1px rgba(0, 0, 0, .15);
}
.hero_header {
	color: #FFFFFF;
	text-align: center;
	margin-top: 0px;
	margin-right: 0px;
	margin-bottom: 0px;
	margin-left: 0px;
	letter-spacing: 4px;
}
/* Hero Section */
.hero {
	background-color: #F7F7F7;
	padding-top: 100px;
	padding-bottom: px;
}
.conceptline{
	font-size:12px;
	letter-spacing: 0.2em;
	line-height: 1.8em;
	width:70%;
	margin:0 auto;
}
.light {
	font-weight: bold;
	color: #717070;
}
.tagline {
	text-align: center;
	color: #FFFFFF;
	margin-top: 4px;
	font-weight: lighter;
	text-transform: uppercase;
	letter-spacing: 1px;
}
/* About Section */
.text_column {
	width: 29%;
	text-align: justify;
	font-weight: lighter;
	line-height: 25px;
	float: left;
	padding-left: 20px;
	padding-right: 20px;
	color: #A3A3A3;
}
.about {
	margin-left: auto;
	margin-right: auto;
	padding-left: 25px;
	padding-right: 25px;
	padding-top: 35px;
	padding-bottom: 35px;
	display: inline-block;
	background-color: #F7F7F7;
	margin-top: 0px;
	margin-bottom: 20px;
	color:#454545;
}
/* Stats Gallery */
.stats {
	text-align: center;
	color: #717070;
	margin-bottom: 5px;
}
.gallery {
	margin-right: auto;
	margin-left : auto;
	clear: both;
	display:flex;
	width: 100%;
	background-color: #F7F7F7;
	/* [disabled]min-width: 400px;
*/
	padding-bottom: 35px;
	padding-top: 0px;
	margin-top: -5px;
	margin-bottom: 0px;
}

.thumbnail {
	width: 25%;
	float: left;
	margin-top:35px;
	margin-left:auto;
	margin-right: auto;
	margin-bottom: 35px;
	padding-bottom: 35px;
	padding-left:1.5em;
	padding-right:1.5em
}
.gallery .thumbnail h4 {
	text-align: center;
	margin-top: 5px;
	margin-right: 5px;
	margin-bottom: 15px;
	margin-left: 5px;
	color: #454545;
	font-weight:bold;
}
.gallery .thumbnail p {
	margin-top: 0px;
	margin-right: 0px;
	margin-bottom: 0px;
	margin-left: 0px;
	color: #A3A3A3;
}
/* Parallax Section */
.banner {
	background-color: #2D9AB7;
	background-image: url("../images/bg_parallax.png");
	height: 400px;
	background-attachment: fixed;
	background-size: cover;
	background-repeat: no-repeat;
}
.parallax {
	color: #FFFFFF;
	text-align: right;
	padding-right: 100px;
	padding-top: 110px;
	letter-spacing: 2px;
	margin-top: 0px;
}
.parallax_description {
	color: #FFFFFF;
	text-align: right;
	padding-right: 100px;
	width: 30%;
	float: right;
	font-weight: lighter;
	line-height: 23px;
	margin-top: 0px;
	margin-right: 0px;
	margin-bottom: 0px;
	margin-left: 0px;
}
/* More info */
footer {
	width: 100%;
	margin-left: auto;
	margin-right: auto;
	background-color: #F7F7F7;
	position: absolute;/*←絶対位置*/
    bottom: 0; /*下に固定*/
}
.footer_column {
	width: 50%;
	padding-top: 30px;
	float: left;
}
footer .footer_column h3 {
	color: #565656;
	text-align: center;
}
footer .footer_column p {
	color: #717070;
	background-color: #F7F7F7;
}
.cards {
	width: 100%;
	height: auto;
	max-width: 400px;
	max-height: 200px;
}
footer .footer_column p {
	padding-left: auto;
	padding-right: auto;
	line-height: 25px;
	font-weight: lighter;
	margin-left: 20px;
	margin-right: 20px;
}
.button {
	width: 200px;
	margin-top: 40px;
	margin-right: auto;
	margin-bottom: auto;
	margin-left: auto;
	padding-top: 20px;
	padding-right: 10px;
	padding-bottom: 20px;
	padding-left: 10px;
	text-align: center;
	vertical-align: middle;
	border-radius: 0px;
	text-transform: uppercase;
	font-weight: bold;
	letter-spacing: 2px;
	border: 3px solid #FFFFFF;
	color: #FFFFFF;
	transition: all 0.3s linear;
}
.button:hover {
	background-color: #FEFEFE;
	color: #565656;
	cursor: pointer;
}
.description{
	
	color: #565656;
	text-align: ;
	margin:0 0 0 auto;
	padding-top: 20px;
	font-size: 13px;
	font-weight: 700;
	line-height: 2em;
}
.description2{
	margin-left: auto;
	margin-right: auto;
	padding-left: auto;
	padding-right: auto;
	color: #565656;
	text-align: ;
	margin:0 0 0 auto;
	padding-top: 20px;
	font-size: 13px;
	font-weight: 700;
	line-height: 2em;
}
.copyright {
	text-align: center;
	padding-top: 20px;
	padding-bottom: 20px;
	background-color: #F7F7F7;
	color: #565656;
	font-weight: ;
	border-top-width: 2px;
}
.footer_banner {
	background-color: #B3B3B3;
	padding-top: 60px;
	padding-bottom: 60PX;
	margin-bottom: 0px;
	background-image: url(../images/pattern.png);
	background-repeat: repeat;
}
footer {
	display: inline-block;
}
.hidden {
	display: none;
}

.effect-fade {
　opacity : 0;
　transform : translate(0, 45px);
　transition : all 300ms;
}

.effect-fade.effect-scroll {
　opacity : 1;
　transform : translate(0, 0);
}
#maps{
		margin-left: auto;
		margin-right:auto;
        height: 200px;
		width:100%;
      }
/*Contact Form*/
form {
  padding: 5px;
  width: 80%;
  margin-left: auto;
  margin-right: auto;
}

.segment {
  padding: 32px 0;
  text-align: center;
}

button, input, textarea {
  border: 0;
  outline: 0;
  font-size: 16px;
  border-radius: 20px;
  padding: 16px;
  background-color: #F7F7F7;
  text-shadow: 1px 1px 0 #FFF;
}

.label {
  display: block;
  margin-bottom: 24px;
  width: 100%;
}

input {
  margin-right: 8px;
  box-shadow: inset 2px 2px 5px #BABECC, inset -5px -5px 10px #FFF;
  width: 100%;
  box-sizing: border-box;
  transition: all 0.2s ease-in-out;
  appearance: none;
  -webkit-appearance: none;
}
input:focus {
  box-shadow: inset 1px 1px 2px #BABECC, inset -1px -1px 2px #FFF;
}

textarea {
  height:100px;
  margin-right: 8px;
  box-shadow: inset 2px 2px 5px #BABECC, inset -5px -5px 10px #FFF;
  width: 100%;
  box-sizing: border-box;
  transition: all 0.2s ease-in-out;
  appearance: none;
  -webkit-appearance: none;
}

button {
  width: 100%;
  color: #61677C;
  font-weight: bold;
  box-shadow: -5px -5px 20px #FFF, 5px 5px 20px #BABECC;
  transition: all 0.2s ease-in-out;
  cursor: pointer;
  font-weight: 600;
}
button:hover {
  box-shadow: -2px -2px 5px #FFF, 2px 2px 5px #BABECC;
}
button:active {
  box-shadow: inset 1px 1px 2px #BABECC, inset -1px -1px 2px #FFF;
}
button .icon {
  margin-right: 8px;
}
button.unit {
  border-radius: 8px;
  line-height: 0;
  width: 48px;
  height: 48px;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  margin: 0 8px;
  font-size: 19.2px;
}
button.unit .icon {
  margin-right: 0;
}
button.red {
  display: block;
  width: 100%;
  color: #AE1100;
}
.buttoncenter{
	text-align: center;
}
.send{text-align:center;margin:20px 0 0}
.input-group {
  display: flex;
  align-items: center;
  justify-content: flex-start;
}
.input-group label {
  margin: 0;
  flex: 1;
}


.thanks{
	display:none;color:#fff
}
#anim{
	width: 100%;
}

.grecaptcha-badge { visibility: hidden; }

/* Mobile */
@media (max-width: 320px) {
.logo {
	width: 100%;
	text-align: center;
	margin-top: 13px;
	margin-right: 0px;
	margin-bottom: 0px;
	margin-left: 0px;
}
.container header nav {
	margin-top: 0px;
	margin-right: 0px;
	margin-bottom: 0px;
	margin-left: 0px;
	width: 100%;
	float: none;
	display: none;
}
header nav ul {
}
nav ul li {
	margin-top: 0px;
	margin-right: 0px;
	margin-bottom: 0px;
	margin-left: 0px;
	width: 100%;
	text-align: center;
}
.gallery {
	clear: both;
	display:grid;
	width:100%;
	background-color: #E0E5EC;
	/* [disabled]min-width: 400px;
*/
	padding-bottom: 35px;
	padding-top: 0px;
	margin-top: -5px;
	margin-bottom: 0px;
}
.text_column {
	width: 100%;
	text-align: justify;
	padding-top: 0px;
	padding-right: 0px;
	padding-bottom: 0px;
	padding-left: 0px;
}
.thumbnail {
	width: 75%;
	float: left;
	margin-top:35px;
	margin-left:auto;
	margin-right: auto;
	margin-bottom: 35px;
	padding-bottom: 35px;
	padding-left:1.5em;
	padding-right:1.5em
}
.footer_column {
	width: 100%;
	margin-top: 0px;
}
.parallax {
	text-align: center;
	margin-top: 0px;
	margin-right: 0px;
	margin-bottom: 0px;
	margin-left: 0px;
	padding-top: 40%;
	padding-right: 0px;
	padding-bottom: 0px;
	padding-left: 0px;
	width: 100%;
	font-size: 18px;
}
.parallax_description {
	padding-top: 0px;
	padding-right: 0px;
	padding-bottom: 0px;
	padding-left: 0px;
	width: 90%;
	margin-top: 25px;
	margin-right: 0px;
	margin-bottom: 0px;
	margin-left: 12px;
	float: none;
	text-align: center;
}
.banner {
	background-color: #2D9AB7;
	background-image: none;
}
.tagline {
	margin-top: 20px;
	line-height: 22px;
}
.conceptlinesp{
	width:95%;
	font-size:12px;
	letter-spacing: 0.2em;
	line-height: 1.8em;
	margin:0 auto;
}
.hero_header {
	padding-left: 10px;
	padding-right: 10px;
	line-height: 22px;
	text-align: center;
}
}

img.icon{
	width: 50px;
	height: 50px;
}


/* Small Tablets */
@media ( min-width : 321px ) and (max-width : 768px ){
.logo {
	width: 50%;
	text-align: left;
	margin-top: 13px;
	margin-right: 0px;
	margin-bottom: 0px;
	margin-left: 0px;
	color: #043745;
}
.container header nav {
	margin-top: 0px;
	margin-right: 15px;
	margin-bottom: 0px;
	margin-left: 0px;
	width: 30%;
	float: right;
	overflow: auto;
	display: inline-block;
	background: rgba(238,238,0,0);
}
header nav ul {
	padding: 0px;
	float: none;
}
nav ul li {
	margin-top: -5px;
	margin-right: 10px;
	margin-bottom: 0px;
	margin-left: 0px;
	width: 100%;
	text-align: right;
	padding-top: 8px;
	padding-bottom: 8px;
}
.gallery {
	margin-right: auto;
	margin-left : auto;
	clear: both;
	display:grid;
	width: 100%;
	background-color: #F7F7F7;
	/* [disabled]min-width: 400px;
*/
	padding-bottom: 35px;
	padding-top: 0px;
	margin-top: -5px;
	margin-bottom: 0px;
}
.text_column {
	width: 100%;
	text-align: left;
	padding-top: 0px;
	padding-right: 0px;
	padding-bottom: 0px;
	padding-left: 0px;
}
.thumbnail {
	width: 100%;
}
.footer_column {
	width: 100%;
	margin-top: 0px;
}
.parallax {
	text-align: center;
	margin-top: 0px;
	margin-right: 0px;
	margin-bottom: 0px;
	margin-left: 0px;
	padding-top: 40%;
	padding-right: 0px;
	padding-bottom: 0px;
	padding-left: 0px;
	width: 100%;
	font-size: 18px;
}
.parallax_description {
	padding-top: 0px;
	padding-right: 0px;
	padding-bottom: 0px;
	padding-left: 0px;
	margin-top: 30%;
	margin-right: 0px;
	margin-bottom: 0px;
	margin-left: 0px;
	float: none;
	width: 100%;
	text-align: center;
}
.thumbnail {
	width: 50%;
}
.parallax {
	margin-top: 0px;
	margin-right: 0px;
	margin-bottom: 0px;
	margin-left: 0px;
	padding-right: 0px;
	padding-bottom: 0px;
	padding-left: 0px;
	padding-top: 20%;
}
.parallax_description {
	margin-top: 0px;
	margin-right: 0px;
	margin-bottom: 0px;
	margin-left: 0px;
	width: 100%;
	padding-top: 30px;
}
.banner {
	padding-left: 20px;
	padding-right: 20px;
}
.conceptlinesp{
	width:95%;
	font-size:12px;
	letter-spacing: 0.2em;
	line-height: 1.8em;
	margin:0 auto;
}
.footer_column {
	width: 100%;
}


/* Small Desktops */
@media (min-width: 768px) and (max-width: 1096px) {
.text_column {
	width: 100%;
}
.thumbnail {
	width: 50%;
}
.text_column {
	width: 100%;
	margin-top: 0px;
	margin-right: 0px;
	margin-bottom: 0px;
	margin-left: 0px;
	padding-top: 0px;
	padding-right: 0px;
	padding-bottom: 0px;
	padding-left: 0px;
}
.banner {
	margin-top: 0px;
	padding-top: 0px;
}
}
.neumobutton {
  padding: 1.5em 5em;
  width: 50px;
  background: #E0E5EC;
  border: none;
  border-radius: .5rem;
  color: #444444;
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: .2rem;
  text-align: center;
  outline: none;
  cursor: pointer;
  transition: .2s ease-in-out;
  box-shadow: -1px -1px 3px rgba(255, 255, 255, .7),
              -1px -1px 3px rgba(255, 255, 255, .5),
              1px 1px 3px rgba(255, 255, 255, .075),
              1px 1px 3px rgba(0, 0, 0, .15);
}
.neumobutton:hover {
  box-shadow: -2px -2px 6px rgba(255, 255, 255, .6),
              -2px -2px 4px rgba(255, 255, 255, .4),
              2px 2px 2px rgba(255, 255, 255, .05),
              2px 2px 4px rgba(0, 0, 0, .1);
}
.neumobutton:active {
  box-shadow: inset -2px -2px 6px rgba(255, 255, 255, .7),
              inset -2px -2px 4px rgba(255, 255, 255, .5),
              inset 2px 2px 2px rgba(255, 255, 255, .075),
              inset 2px 2px 4px rgba(0, 0, 0, .15);
}.active {
}
.acticve {
}

